色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > s3c2410的時(shí)鐘和定時(shí)器

          s3c2410的時(shí)鐘和定時(shí)器

          作者: 時(shí)間:2016-11-21 來(lái)源:網(wǎng)絡(luò) 收藏
          外接晶振,然后通過(guò)內(nèi)部電路產(chǎn)生時(shí)鐘

          直接使用外部提供的時(shí)鐘源

          本文引用地址:http://cafeforensic.com/article/201611/319118.htm

          通過(guò)引腳的設(shè)置來(lái)選擇

          FCLK cpu

          HCLK AHB

          PCLK APB

          PLL 通過(guò)時(shí)鐘控制邏輯PLL來(lái)提高系統(tǒng)的時(shí)鐘

          UPLL USB

          MPLL FCLK HCLK PCLK

          沒(méi)有啟動(dòng)PLL FCLK=Fin(晶振頻率)

          s3c2410有五個(gè)16位的定時(shí)器 其中前面的四個(gè)定時(shí)器有PWM功能 即有一個(gè)輸出引腳 可以通過(guò)定時(shí)器來(lái)控制輸出引腳周期性的高、低電平。定時(shí)器的時(shí)鐘源是PCLK

          @******************************************************************************
          @ File:head.S
          @ 功能:初始化,設(shè)置中斷模式、系統(tǒng)模式的棧,設(shè)置好中斷處理函數(shù)
          @******************************************************************************

          .extern main
          .text
          .global _start
          _start:
          @******************************************************************************
          @ 中斷向量,本程序中,除Reset和HandleIRQ外,其它異常都沒(méi)有使用
          @******************************************************************************
          b Reset

          @ 0x04: 未定義指令中止模式的向量地址
          HandleUndef:
          b HandleUndef

          @ 0x08: 管理模式的向量地址,通過(guò)SWI指令進(jìn)入此模式
          HandleSWI:
          b HandleSWI

          @ 0x0c: 指令預(yù)取終止導(dǎo)致的異常的向量地址
          HandlePrefetchAbort:
          b HandlePrefetchAbort

          @ 0x10: 數(shù)據(jù)訪問(wèn)終止導(dǎo)致的異常的向量地址
          HandleDataAbort:
          b HandleDataAbort

          @ 0x14: 保留
          HandleNotUsed:
          b HandleNotUsed

          @ 0x18: 中斷模式的向量地址
          b HandleIRQ

          @ 0x1c: 快中斷模式的向量地址
          HandleFIQ:
          b HandleFIQ

          Reset:
          ldr sp, =4096 @ 設(shè)置棧指針,以下都是C函數(shù),調(diào)用前需要設(shè)好棧
          bl disable_watch_dog @ 關(guān)閉WATCHDOG,否則CPU會(huì)不斷重啟


          bl clock_init @ 設(shè)置MPLL,改變FCLK、HCLK、PCLK


          bl memsetup @ 設(shè)置存儲(chǔ)控制器以使用SDRAM
          bl copy_steppingstone_to_sdram @ 復(fù)制代碼到SDRAM中
          ldr pc, =on_sdram @ 跳到SDRAM中繼續(xù)執(zhí)行
          on_sdram:
          msr cpsr_c, #0xd2 @ 進(jìn)入中斷模式
          ldr sp, =4096 @ 設(shè)置中斷模式棧指針

          msr cpsr_c, #0xdf @ 進(jìn)入系統(tǒng)模式
          ldr sp, =0x34000000 @ 設(shè)置系統(tǒng)模式棧指針,

          bl init_led @ 初始化LED的GPIO管腳


          bl timer0_init @ 初始化定時(shí)器0


          bl init_irq @ 調(diào)用中斷初始化函數(shù),在init.c中
          msr cpsr_c, #0x5f @ 設(shè)置I-bit=0,開(kāi)IRQ中斷

          ldr lr, =halt_loop @ 設(shè)置返回地址
          ldr pc, =main @ 調(diào)用main函數(shù)
          halt_loop:
          b halt_loop

          HandleIRQ:
          sub lr, lr, #4 @ 計(jì)算返回地址
          stmdb sp!, { r0-r12,lr } @ 保存使用到的寄存器
          @ 注意,此時(shí)的sp是中斷模式的sp
          @ 初始值是上面設(shè)置的4096

          ldr lr, =int_return @ 設(shè)置調(diào)用ISR即EINT_Handle函數(shù)后的返回地址
          ldr pc, =Timer0_Handle @ 調(diào)用中斷服務(wù)函數(shù),在interrupt.c中
          int_return:
          ldmia sp!, { r0-r12,pc }^ @ 中斷返回, ^表示將spsr的值復(fù)制到cpsr

          #include "s3c24xx.h"

          void disable_watch_dog(void);
          void clock_init(void);
          void memsetup(void);
          void copy_steppingstone_to_sdram(void);
          void init_led(void);
          void timer0_init(void);
          void init_irq(void);


          void disable_watch_dog(void)
          {
          WTCON = 0; // 關(guān)閉WATCHDOG很簡(jiǎn)單,往這個(gè)寄存器寫(xiě)0即可
          }

          #define S3C2410_MPLL_200MHZ ((0x5c<<12)|(0x04<<4)|(0x00))
          #define S3C2440_MPLL_200MHZ ((0x5c<<12)|(0x01<<4)|(0x02))

          void clock_init(void)
          {
          // LOCKTIME = 0x00ffffff; // 使用默認(rèn)值即可
          CLKDIVN = 0x03; // FCLK:HCLK:PCLK=1:2:4, HDIVN=1,PDIVN=1


          __asm__(
          "mrc p15, 0, r1, c1, c0, 0n"
          "orr r1, r1, #0xc0000000n"
          "mcr p15, 0, r1, c1, c0, 0n"
          );


          if ((GSTATUS1 == 0x32410000) || (GSTATUS1 == 0x32410002))
          {
          MPLLCON = S3C2410_MPLL_200MHZ;
          }
          else
          {
          MPLLCON = S3C2440_MPLL_200MHZ;
          }
          }


          void memsetup(void)
          {
          volatile unsigned long *p = (volatile unsigned long *)MEM_CTL_BASE;



          p[0] = 0x22011110; //BWSCON
          p[1] = 0x00000700; //BANKCON0
          p[2] = 0x00000700; //BANKCON1
          p[3] = 0x00000700; //BANKCON2
          p[4] = 0x00000700; //BANKCON3
          p[5] = 0x00000700; //BANKCON4
          p[6] = 0x00000700; //BANKCON5
          p[7] = 0x00018005; //BANKCON6
          p[8] = 0x00018005; //BANKCON7


          p[9] = 0x008C04F4;
          p[10] = 0x000000B1; //BANKSIZE
          p[11] = 0x00000030; //MRSRB6
          p[12] = 0x00000030; //MRSRB7
          }

          void copy_steppingstone_to_sdram(void)
          {
          unsigned int *pdwSrc = (unsigned int *)0;
          unsigned int *pdwDest = (unsigned int *)0x30000000;

          while (pdwSrc < (unsigned int *)4096)
          {
          *pdwDest = *pdwSrc;
          pdwDest++;
          pdwSrc++;
          }
          }


          #define GPB5_out (1<<(5*2)) // LED1
          #define GPB6_out (1<<(6*2)) // LED2
          #define GPB7_out (1<<(7*2)) // LED3
          #define GPB8_out (1<<(8*2)) // LED4


          #define GPG11_eint (2<<(11*2)) // K1,EINT19
          #define GPG3_eint (2<<(3*2)) // K2,EINT11
          #define GPF3_eint (2<<(3*2)) // K3,EINT3
          #define GPF2_eint (2<<(2*2)) // K4,EINT2

          void init_led(void)
          {
          GPBCON = GPB5_out | GPB6_out | GPB7_out | GPB8_out ;
          }


          void timer0_init(void)
          {
          TCFG0 = 99; // 預(yù)分頻器0 = 99
          TCFG1 = 0x03; // 選擇16分頻
          TCNTB0 = 31250; // 0.5秒鐘觸發(fā)一次中斷
          TCON |= (1<<1); // 手動(dòng)更新
          TCON = 0x09; // 自動(dòng)加載,清“手動(dòng)更新”位,啟動(dòng)定時(shí)器0
          }


          void init_irq(void)
          {
          // 定時(shí)器0中斷使能
          INTMSK &= (~(1<<10));
          }


          #include "s3c24xx.h"

          void Timer0_Handle(void)
          {

          if(INTOFFSET == 10)
          {
          GPBDAT = ~(GPBDAT & (0xf << 5));
          }
          //清中斷
          SRCPND = 1 << INTOFFSET;
          INTPND = INTPND;
          }

          int main(void)
          {
          while(1);
          return 0;
          }




          評(píng)論


          技術(shù)專(zhuān)區(qū)

          關(guān)閉