www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 嵌入式 > 嵌入式硬件
[導(dǎo)讀]U-Boot的編譯與移植到QT-S3C44B0X開發(fā)板上

s3c44b0x主板啟動用到的代碼分析
一 首先從cpu/s3c44b0/start.S這個文件開始執(zhí)行,這個文件主要作以下幾點:
1 設(shè)置處理器的工作模式。
2 初始化中斷向量。
3 關(guān)閉看門狗功能。
4 允許timer5的中斷(時鐘中斷)。
5 允許IRQ中斷,進制FIQ中斷。
6 設(shè)置時鐘控制寄存器控制CPU的主頻。根據(jù)我自己的開發(fā)板進行了設(shè)置。(下面介紹了時鐘主頻的計算公式)。
7 調(diào)用board/<your.board>/lowlevel.S對存儲器進行初始化。這個文件主要是根據(jù)開發(fā)板設(shè)置每個存儲器的BANK。我修改了這個文件使其支持我的開發(fā)板。
8 將ROM中的U-BOOT代碼拷貝到RAM中。并在RAM中設(shè)置好中斷向量表。
9 設(shè)置堆棧。
10 跳到lib_arm/board.c中執(zhí)行start_armboot.
二 執(zhí)行l(wèi)ib_arm/board.c中的start_armboot,主要完成一下工作:
1 調(diào)用cpu/<your.board>/cpu.c中的cpu_init()來刷新所有cache,將0x00000000~0x0c000000區(qū)設(shè)為非cache區(qū)。并使用全部8K空間作為cache??偩€優(yōu)先級為默認優(yōu)先級。
2 調(diào)用board/<your.board>/<your.board>.c中的board_init()根據(jù)具體的開發(fā)板對PORT進行設(shè)置。我修改這個文件使其支持我的開發(fā)板。
3 調(diào)用cpu/s3c44b0/interrupts.c 中的interrupt_init()初始化Timer1定時器使其在指定時間產(chǎn)生中斷。
4 根據(jù)include/configs/<your.board>.h配置文件中(CFG_ENV_IS_IN_<*>)環(huán)境變量保存位置選項來調(diào)用common/env_*.c對應(yīng)文件中的env_init()。其作用是初始化環(huán)境變量。由于我的配置文件中的選項是CFG_ENV_IS_IN_FLASH,所以我修改board/<your.board>/flash.c使它支持我板子的FLASH。
5 調(diào)用本文件中的init_baudrate()來設(shè)置串口的波特率,這個函數(shù)的功能是可以使用環(huán)境變量對串口波特率進行修改。
6 調(diào)用cpu/s3c44b0/serial.c文件中的serial_init()對串口進行初始化。我修改這個文件使它支持我的開發(fā)板時鐘頻率對應(yīng)的串口波特率。(下面介紹了串口波特率的計算公式)。
7 調(diào)用common/console.c文件中的console_init_f()對控制臺進行初始化。
8 調(diào)用本文件中的display_banner()顯示標題信息。
9 調(diào)用board/<your.board>/<your.board>.c文件中的dram_init()對SDRAM進行初始化,其主要作用是在全局變量gd中設(shè)置SDRAM的起始地址與大小。
10 調(diào)用本文件中的display_dram_config()顯示一些配置信息。
11 調(diào)用flash_init()來初始化FLASH。如果CFG_FLASH_CFI_DRIVER在配置文件中被定義,則調(diào)用drivers/cfi_flash.c中flash_init()驅(qū)動。否則將調(diào)用自己的FALSH驅(qū)動。


移植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文件,根據(jù)自己的開發(fā)板提供的石英振蕩頻率(Fin)來設(shè)置自己想要的時鐘主頻。
9 修改board/51EDA/QT/lowlevel_init.S文件,根據(jù)自己的開發(fā)板對存儲器(Bank)進行初始化。
10 修改board/51EDA/QT/QT.c文件,根據(jù)自己的開發(fā)板對PORT進行初始化。
11 修改board/51EDA/QT/flash.c文件,使它支持自己的開發(fā)板。
12 修改cpu/s3c44b0/serial.c文件,使它支持自己想要的波特率。
13 修改include/configs/QT.h文件,設(shè)置里面的選項使其滿足自己的要求。


遇到的問題:
1. 在對應(yīng)自己的開發(fā)板修改了board目錄下的lowlevel_init.S,QT.c文件后串口終于出東西了。但是總是出現(xiàn)亂碼,無論設(shè)置成什么樣的時波特率,都是亂碼,于是認為是自己的CPU主頻的串口的波特率計算錯誤,查看相關(guān)資料修改了cpu目錄下的start.S和serial.c文件中的系統(tǒng)時鐘和串口波特率部分后,串口終于讀到正確的數(shù)據(jù)了。(下面是有關(guān)cpu時鐘頻率和串口波特率的計算公式)。
S3C44B0的系統(tǒng)時鐘設(shè)置公式
一. 通過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應(yīng)該盡可能的大)
e) 1MHz <= Fin/p < 2MHz (最好是Fin/p = 1MHz)
f) 如果PLL打開則:Fpllo = Fout
g) 這樣計算出MDIV, PDIV, SDIV的值寫入PLLCON寄存器中就可設(shè)置Fpllo的輸出頻率。
二. PLL的鎖存時間(為輸出穩(wěn)定時鐘頻率需要的平靜時間)
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中的環(huán)境變量總是出錯,并且每次讀出的數(shù)據(jù)都不一樣,在通過調(diào)試器進行觀察后發(fā)現(xiàn)原來是DECLARE_GLOBAL_DATA_PTR的使用問題,這是當前我使用的這個版本(u-boot-1.1.4)的一個bug,于是換了一個更新的版本(u-boot-2006-05-10-1800),這個版本已經(jīng)將這個bug去處掉了。終于讀出了正確的環(huán)境變量。
3. 每當我使用出現(xiàn)錯誤死機重啟后都無法正常啟動,只有關(guān)掉電源10-30分鐘后在啟動就會正常,通過調(diào)試器對程序的觀察發(fā)現(xiàn),在start.S文件中將程序從flash復(fù)制到RAM中時,它只復(fù)制到了bss段的開始,而并沒有對bss段進行復(fù)制(bss初始化為0的靜態(tài)變量區(qū)),這樣到的當我運行的程序出現(xiàn)錯誤對bss段進行了寫入后,而內(nèi)存在斷電后數(shù)據(jù)并沒有馬上消失,這樣就導(dǎo)致在重啟后讀取值為0的靜態(tài)變量時出現(xiàn)了錯誤的數(shù)據(jù)。于是我修改了程序,讓它將bss段也復(fù)制到內(nèi)存,這樣當重啟后總是會對內(nèi)存的bss段進行初始化。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉