新聞中心

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

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

        作者: 時間:2016-12-01 來源:網絡 收藏

          #gedit cpu/arm920t/start.S

        本文引用地址:http://www.104case.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 //根據2440芯片手冊,INTSUBMSK寄存器有15位可用

          ldr r0, =INTSUBMSK

          str r1, [r0]

          # endif

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

          #define MPLLCON 0x4C000004 //系統主頻配置寄存器基地址

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

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

          mov r1, #5

          str r1, [r0]

          ldr r0, =MPLLCON //設置系統主頻為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 //其他開發板的時鐘部分,這里就不用管了,我們現在是做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時鐘頻率參數與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 //這三個值根據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 //這三個值根據S3C2440芯片手冊“PLL VALUE SELECTION TABLE”部分進行設置

          #define U_M_PDIV 0x2

          #define U_M_SDIV 0x2

          #endif

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

          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中運行測試。結果終端有輸出信息并且出現類似Shell的命令行,這說明這一部分移植完成。示意圖如下:

            

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


        上一頁 1 2 下一頁

        關鍵詞: u-boot 2440

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 如东县| 龙里县| 衡南县| 盘山县| 合江县| 奉新县| 临夏县| 泸西县| 枣强县| 黑龙江省| 临高县| 内丘县| 河间市| 云浮市| 灵山县| 容城县| 浮山县| 阜平县| 青铜峡市| 酉阳| 中宁县| 武隆县| 孝感市| 弋阳县| 宽甸| 天峨县| 湛江市| 行唐县| 柞水县| 名山县| 全椒县| 三亚市| 大田县| 普兰店市| 曲阳县| 东安县| 会理县| 肇源县| 沂水县| 大新县| 合阳县|