在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

電子發燒友App

硬聲App

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示
電子發燒友網>電子資料下載>嵌入式開發>U-Boot的編譯與移植到QT-S3C44B0X開發板解析

U-Boot的編譯與移植到QT-S3C44B0X開發板解析

2017-11-06 | rar | 0.4 MB | 次下載 | 1積分

資料介紹

 s3c44b0x主板啟動用到的代碼分析
  一 首先從cpu/s3c44b0/start.S這個文件開始執行,這個文件主要作以下幾點:
  1 設置處理器的工作模式。
  2 初始化中斷向量。
  3 關閉看門狗功能。
  4 允許timer5的中斷(時鐘中斷)。
  5 允許IRQ中斷,進制FIQ中斷。
  6 設置時鐘控制寄存器控制CPU的主頻。根據我自己的開發板進行了設置。(下面介紹了時鐘主頻的計算公式)。
  7 調用board/《your.board》/lowlevel.S對存儲器進行初始化。這個文件主要是根據開發板設置每個存儲器的BANK。我修改了這個文件使其支持我的開發板。
  8 將ROM中的U-BOOT代碼拷貝到RAM中。并在RAM中設置好中斷向量表。
  9 設置堆棧。
  10 跳到lib_arm/board.c中執行start_armboot.
  二 執行lib_arm/board.c中的start_armboot,主要完成一下工作:
  1 調用cpu/《your.board》/cpu.c中的cpu_init()來刷新所有cache,將0x00000000~0x0c000000區設為非cache區。并使用全部8K空間作為cache。總線優先級為默認優先級。
  2 調用board/《your.board》/《your.board》.c中的board_init()根據具體的開發板對PORT進行設置。我修改這個文件使其支持我的開發板。
  3 調用cpu/s3c44b0/interrupts.c 中的interrupt_init()初始化Timer1定時器使其在指定時間產生中斷。
  4 根據include/configs/《your.board》.h配置文件中(CFG_ENV_IS_IN_《*》)環境變量保存位置選項來調用common/env_*.c對應文件中的env_init()。其作用是初始化環境變量。由于我的配置文件中的選項是CFG_ENV_IS_IN_FLASH,所以我修改board/《your.board》/flash.c使它支持我板子的FLASH。
  5 調用本文件中的init_baudrate()來設置串口的波特率,這個函數的功能是可以使用環境變量對串口波特率進行修改。
  6 調用cpu/s3c44b0/serial.c文件中的serial_init()對串口進行初始化。我修改這個文件使它支持我的開發板時鐘頻率對應的串口波特率。(下面介紹了串口波特率的計算公式)。
  7 調用common/console.c文件中的console_init_f()對控制臺進行初始化。
  8 調用本文件中的display_banner()顯示標題信息
  9 調用board/《your.board》/《your.board》.c文件中的dram_init()對SDRAM進行初始化,其主要作用是在全局變量gd中設置SDRAM的起始地址與大小。
  10 調用本文件中的display_dram_config()顯示一些配置信息。
  11 調用flash_init()來初始化FLASH。如果CFG_FLASH_CFI_DRIVER在配置文件中被定義,則調用drivers/cfi_flash.c中flash_init()驅動。否則將調用自己的FALSH驅動。
  移植U-BOOT過程
  一 為我的QT板子建立一個模板
  1 cp –r board/dave board/51EDA
  2 mv board/51EDA/B2 board/51EDA/QT
  3 mv board/51EDA/QT/B2.c board/51EDA/QT/QT.c
  4 cp include/configs/B2.h include/configs/QT.h
  5 將board/51EDA/所有文件中的B2改為QT,將include/configs/QT.h中的B2改為QT。
  6 修改Makefile和MAKEALL文件,為QT添加新的選項。
  7 然后開始編譯,能夠正確通過,說明上面為我的QT板子建立的模板正確,下面開始修改模板中的文件使其支持自己的QT板子。
  8 修改cpu/s3c44b0/start.S文件,根據自己的開發板提供的石英振蕩頻率(Fin)來設置自己想要的時鐘主頻。
  9 修改board/51EDA/QT/lowlevel_init.S文件,根據自己的開發板對存儲器(Bank)進行初始化。
  10 修改board/51EDA/QT/QT.c文件,根據自己的開發板對PORT進行初始化。
  11 修改board/51EDA/QT/flash.c文件,使它支持自己的開發板。
  12 修改cpu/s3c44b0/serial.c文件,使它支持自己想要的波特率。
  13 修改include/configs/QT.h文件,設置里面的選項使其滿足自己的要求。
  遇到的問題:
  1. 在對應自己的開發板修改了board目錄下的lowlevel_init.S,QT.c文件后串口終于出東西了。但是總是出現亂碼,無論設置成什么樣的時波特率,都是亂碼,于是認為是自己的CPU主頻的串口的波特率計算錯誤,查看相關資料修改了cpu目錄下的start.S和serial.c文件中的系統時鐘和串口波特率部分后,串口終于讀到正確的數據了。(下面是有關cpu時鐘頻率和串口波特率的計算公式)。
  S3C44B0的系統時鐘設置公式
  一。 通過PLL輸出時鐘脈沖頻率的計算:
  a) Fpllo = (m * Fin) / (p * 2s)
  b) m = (MDIV + 8), p = (PDIV + 2), s = SDIV
  c) 20MHz 《 Fpllo 《 66MHz
  d) Fpllo * 2s 《 170MHz (s應該盡可能的大)
  e) 1MHz 《= Fin/p 《 2MHz (最好是Fin/p = 1MHz)
  f) 如果PLL打開則:Fpllo = Fout
  g) 這樣計算出MDIV, PDIV, SDIV的值寫入PLLCON寄存器中就可設置Fpllo的輸出頻率。
  二。 PLL的鎖存時間(為輸出穩定時鐘頻率需要的平靜時間)
  a) T_lock = (1 / Fin) * n 》 280us. (n = LTIMECNT value)
  S3C44B0的UART波特率計算公式
  UBRDIVn = ( (int)(MCLK / (bps * 16) + 0.5) – 1 )
  MCLK = Fout = Fpllo
  Bps = 1200,9600,19200,38400,57600,115200
  2. 在使用printenv與bdinfo命令讀取flash中的環境變量總是出錯,并且每次讀出的數據都不一樣,在通過調試器進行觀察后發現原來是DECLARE_GLOBAL_DATA_PTR的使用問題,這是當前我使用的這個版本(u-boot-1.1.4)的一個bug,于是換了一個更新的版本(u-boot-2006-05-10-1800),這個版本已經將這個bug去處掉了。終于讀出了正確的環境變量。
  3. 每當我使用出現錯誤死機重啟后都無法正常啟動,只有關掉電源10-30分鐘后在啟動就會正常,通過調試器對程序的觀察發現,在start.S文件中將程序從flash復制到RAM中時,它只復制到了bss段的開始,而并沒有對bss段進行復制(bss初始化為0的靜態變量區),這樣到的當我運行的程序出現錯誤對bss段進行了寫入后,而內存在斷電后數據并沒有馬上消失,這樣就導致在重啟后讀取值為0的靜態變量時出現了錯誤的數據。于是我修改了程序,讓它將bss段也復制到內存,這樣當重啟后總是會對內存的bss段進行初始化。
?

評論

查看更多

下載排行

本周

  1. 1EN60335-1安規標準 中文版本
  2. 1.86 MB   |  53次下載  |  1 積分
  3. 2LT7406FJ N溝道增強型功率MOSFET規格書
  4. 1.38 MB   |  2次下載  |  免費
  5. 3米爾-瑞芯微RK3562核心板開發板,4核CPU,ARM中量級多面手
  6. 3.45 MB  |  2次下載  |  免費
  7. 4運算放大電路入門教程
  8. 0.70 MB   |  1次下載  |  免費
  9. 5開源鴻蒙版真4K顯示器廣告機主板AIoT-6780SE彩頁
  10. 613.79 KB  |  1次下載  |  免費
  11. 6LTS6806SR N溝道增強型功率MOSFET規格書
  12. 0.99 MB   |  次下載  |  免費
  13. 7LT3810FP-X N溝道增強型功率MOSFET規格書
  14. 0.92 MB   |  次下載  |  免費
  15. 8LTS4008TRB N溝道增強型功率MOSFET規格書
  16. 1.58 MB   |  次下載  |  免費

本月

  1. 1STM32CubeMX用于STM32配置和初始化C代碼生成
  2. 21.90 MB   |  619次下載  |  免費
  3. 2STM32開發板教程之STM32開發指南免費下載
  4. 24.88 MB   |  176次下載  |  3 積分
  5. 3DeepSeek:從入門到精通
  6. 5.36 MB   |  95次下載  |  1 積分
  7. 4EN60335-1安規標準 中文版本
  8. 1.86 MB   |  53次下載  |  1 積分
  9. 5OAH0428最新規格書(中文)
  10. 2.52 MB   |  27次下載  |  10 積分
  11. 6UHV系列雷電沖擊電壓發生器試驗裝置詳細說明使用
  12. 1.07 MB   |  17次下載  |  免費
  13. 7Altium-常用3D封裝庫(Step)接插件篇
  14. 4.95 MB   |  14次下載  |  免費
  15. 8介紹一些常用的電子元器件
  16. 3.20 MB   |  8次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935124次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關降壓/升壓雙向直流/直流轉換器 PCB layout 設計
  4. 1.48MB  |  420063次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233088次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費下載
  8. 340992  |  191371次下載  |  10 積分
  9. 5十天學會AVR單片機與C語言視頻教程 下載
  10. 158M  |  183336次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81583次下載  |  10 積分
  13. 7Keil工具MDK-Arm免費下載
  14. 0.02 MB  |  73814次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65988次下載  |  10 積分
主站蜘蛛池模板: 四虎影院最新地址 | 美女牲交视频一级毛片 | 国产人成午夜免费噼啪视频 | 在线 | 一区二区三区四区 | 久久久这里有精品999 | 国产网站黄色 | 久久久久久久久久免免费精品 | 大尺度视频网站久久久久久久久 | 都市激情综合网 | 色香视频在线 | h版欧美一区二区三区四区 h网站亚洲 | 51xx嘿嘿午夜 | 欧美色图首页 | 轻点灬大ji巴太粗太长了啊h | 麻豆色哟哟网站 | 99青草| 亚洲网站免费观看 | 级毛片| you ji z z日本人在线观看 | 黄 色 片成 人免费观看 | 51成人网| 亚洲男人天堂手机版 | 深夜释放自己vlog糖心旧版本 | 四虎影视在线影院在线观看 | www网站在线观看 | 亚洲成在人线影视天堂网 | 四虎在线最新永久免费 | 黄视频网站在线看 | 色欧美在线| 午夜刺激爽爽视频免费观看 | 成人a视频 | 亚洲综合色一区 | 国产性较精品视频免费 | 欧美人成网站免费大全 | 在线三级网址 | 国产色播| 欧美草逼| 四虎在线观看免费永久 | 伊人色婷婷综在合线亚洲 | 亚洲偷图色综合色就色 | 三级在线网站 |