<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > u-boot-在2440上的移植詳解(一)

          u-boot-在2440上的移植詳解(一)

          作者: 時間:2016-12-01 來源:網(wǎng)絡 收藏

            #gedit cpu/arm920t/start.S

          本文引用地址:http://www.ex-cimer.com/article/201612/340975.htm

            #if defined(CONFIG_S3C2400) || defined(CONFIG_S3C2410) || defined(CONFIG_S3C)

            /* turn off the watchdog */

            # if defined(CONFIG_S3C2400)

            # define pWTCON 0x15300000

            # define INTMSK 0x14400008 /* Interupt-Controller base addresses */

            # define CLKDIVN 0x14800014 /* clock divisor register */

            #else //下面2410和的寄存器地址是一致的

            # define pWTCON 0x53000000

            # define INTMSK 0x4A000008 /* Interupt-Controller base addresses */

            # define INTSUBMSK 0x4A00001C

            # define CLKDIVN 0x4C000014 /* clock divisor register */

            # endif

            ldr r0, =pWTCON

            mov r1, #0x0

            str r1, [r0]

            /*

            * mask all IRQs by setting all bits in the INTMR - default

            */

            mov r1, #0xffffffff

            ldr r0, =INTMSK

            str r1, [r0]

            # if defined(CONFIG_S3C2410)

            ldr r1, =0x3ff

            ldr r0, =INTSUBMSK

            str r1, [r0]

            # endif

            # if defined(CONFIG_S3C)//添加s3c2440的中斷禁止部分

            ldr r1, =0x7fff //根據(jù)2440芯片手冊,INTSUBMSK寄存器有15位可用

            ldr r0, =INTSUBMSK

            str r1, [r0]

            # endif

            # if defined(CONFIG_S3C2440) //添加s3c2440的時鐘部分

            #define MPLLCON 0x4C000004 //系統(tǒng)主頻配置寄存器基地址

            #define UPLLCON 0x4C000008 //USB時鐘頻率配置寄存器基地址

            ldr r0, =CLKDIVN //設置分頻系數(shù)FCLK:HCLK:PCLK = 1:4:8

            mov r1, #5

            str r1, [r0]

            ldr r0, =MPLLCON //設置系統(tǒng)主頻為405MHz

            ldr r1, =0x7F021 //這個值參考芯片手冊“PLL VALUE SELECTION TABLE”部分

            str r1, [r0]

            ldr r0, =UPLLCON //設置USB時鐘頻率為48MHz

            ldr r1, =0x38022 //這個值參考芯片手冊“PLL VALUE SELECTION TABLE”部分

            str r1, [r0]

            # else //其他開發(fā)板的時鐘部分,這里就不用管了,我們現(xiàn)在是做2440的

            /* FCLK:HCLK:PCLK = 1:2:4 */

            /* default FCLK is 120 MHz ! */

            ldr r0, =CLKDIVN

            mov r1, #3

            str r1, [r0]

            # endif

            #endif /* CONFIG_S3C2400 || CONFIG_S3C2410 || CONFIG_S3C2440 */

            S3C2440的時鐘部分除了在start.S中添加外,還要分別在board/samsung/my2440/my2440.c和cpu/arm920t/s3c24x0/speed.c中修改或添加部分代碼,如下:

            #gedit board/samsung/my2440/my2440.c //設置主頻和USB時鐘頻率參數(shù)與start.S中的一致

            #define FCLK_SPEED 2 //設置默認等于2,即下面紅色代碼部分有效

            #if FCLK_SPEED==0 /* Fout = 203MHz, Fin = 12MHz for Audio */

            #define M_MDIV 0xC3

            #define M_PDIV 0x4

            #define M_SDIV 0x1

            #elif FCLK_SPEED==1 /* Fout = 202.8MHz */

            #define M_MDIV 0xA1

            #define M_PDIV 0x3

            #define M_SDIV 0x1

            #elif FCLK_SPEED==2 /* Fout = 405MHz */

            #define M_MDIV 0x7F //這三個值根據(jù)S3C2440芯片手冊“PLL VALUE SELECTION TABLE”部分進行設置

            #define M_PDIV 0x2

            #define M_SDIV 0x1

            #endif

            #define USB_CLOCK 2 //設置默認等于2,即下面紅色代碼部分有效

            #if USB_CLOCK==0

            #define U_M_MDIV 0xA1

            #define U_M_PDIV 0x3

            #define U_M_SDIV 0x1

            #elif USB_CLOCK==1

            #define U_M_MDIV 0x48

            #define U_M_PDIV 0x3

            #define U_M_SDIV 0x2

            #elif USB_CLOCK==2 /* Fout = 48MHz */

            #define U_M_MDIV 0x38 //這三個值根據(jù)S3C2440芯片手冊“PLL VALUE SELECTION TABLE”部分進行設置

            #define U_M_PDIV 0x2

            #define U_M_SDIV 0x2

            #endif

            #gedit cpu/arm920t/s3c24x0/speed.c //根據(jù)設置的分頻系數(shù)FCLK:HCLK:PCLK = 1:4:8修改獲取時鐘頻率的函數(shù)

            static ulong get_PLLCLK(int pllreg)

            {

            S3C24X0_CLOCK_POWER * const clk_power = S3C24X0_GetBase_CLOCK_POWER();

            ulong r, m, p, s;

            if (pllreg == MPLL)

            r = clk_power->MPLLCON;

            else if (pllreg == UPLL)

            r = clk_power->UPLLCON;

            else

            hang();

            m = ((r & 0xFF000) >> 12) + 8;

            p = ((r & 0x003F0) >> 4) + 2;

            s = r & 0x3;

            #if defined(CONFIG_S3C2440)

            if(pllreg == MPLL)

            { //參考S3C2440芯片手冊上的公式:PLL=(2 * m * Fin)/(p * 2s)

            return((CONFIG_SYS_CLK_FREQ * m * 2) / (p << s));

            }

            #endif

            return((CONFIG_SYS_CLK_FREQ * m) / (p << s));

            }

            /* return HCLK frequency */

            ulong get_HCLK(void)

            {

            S3C24X0_CLOCK_POWER * const clk_power = S3C24X0_GetBase_CLOCK_POWER();

            #if defined(CONFIG_S3C2440)

            return(get_FCLK()/4);

            #endif

            return((clk_power->CLKDIVN & 0x2) ? get_FCLK()/2 : get_FCLK());

            }

            好了!修改完畢后我們再重新編譯,然后再下載到RAM中運行測試。結果終端有輸出信息并且出現(xiàn)類似Shell的命令行,這說明這一部分移植完成。示意圖如下:

              

          u-boot-在2440上的移植詳解(一) - 地獄伏龍 - 臥龍居


          上一頁 1 2 下一頁

          關鍵詞: u-boot 2440

          評論


          相關推薦

          技術專區(qū)

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();