国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

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

3天內不再提示

深度解讀S3C2410A的嵌入式系統的U-Boot移植

電子工程師 ? 來源:現代電子技術 ? 作者:丁小俊 ? 2021-05-05 17:45 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

0 引 言

ARM嵌入式處理器已被廣泛應用于消費電子產品、無線通信網絡通信工業控制等領域。其中,ARM9的芯片更是以其低價格、低功耗、高性能在手持設備中占據著重要市場。在嵌入式操作系統中,LinuxVxworks,WinCE三足鼎立,其中Linux由于其開源性、穩定性、安全性、可裁減性更是一支獨放。在嵌入式系統中,如何實現在ARM9平臺下Linux操作系統的引導工作是嵌入式技術開發的重要環節。

1 嵌入式系統的軟件組成

1.1 系統的軟件組成

嵌入式的軟件系統主要由Bootloader、操作系統、文件系統、應用程序等組成。其中,Bootloader是介于硬件和操作系統之間的一層,其作用就好像PC機中的BIOS。系統加電運行后,由系統自動加載。通過這段程序,可以初始化硬件設備,建立內存空間的映射圖,從而將系統的硬件環境帶到一個合適的狀態,以便為最終調用操作系統內核準備好環境。對于一個嵌入式系統,通常BootLoader是依賴于硬件而實現的。對于不同類型的嵌入式芯片、不同的操作系統和外圍接口都需要重新移植、修改和編譯Bootloader。

1.2 U-Boot分析

嵌入式Linux系統中常用的Bootloader引導程序有U-Boot,redboot,blob和vivi等,其中U-Boot遵循GPL條款的開放源碼項目,功能最為強大;U-Boot對PowerPC系列處理器支持最豐富,同時還支持MIPS,x86,ARM,Nios,XScale等諸多常用系列的處理器;U-Boot引導程序分為Stage 1和Stage 2兩大部分,Stage 1中主要包括設備初始化、中斷設置、時鐘設置和存儲器初始化等工作,并且采用匯編語言實現,而一些通用功能大多采用C語言實現,放在Stage 2中。

2 U-Boot的啟動分析

Stage 1的代碼在CPU/arm920t/start.s中定義,它包括從系統上電后在0x00000000地址開始執行的部分。這部分代碼系統啟動后,從NAND FLASH自動加載到SDRAM中,它包括對S3C2410A中寄存器的初始化和將U-Boot的Stage 2代碼從FLASH拷貝到SDRAM。Stage 2的起始地址是在Stage1代碼中指定的。被復制到SDRAM后,就從第一階段跳到這個入口地址,開始執行剩余部分代碼。第二階段主要是對內存的分配,對NAND FLASH以及對外圍設備的初始化,其代碼在lib-arm/board.C中。啟動的流程分析如圖1所示。

pIYBAGB1aliAESuvAABYoeFqfI8363.png

(1)跳轉到C語言程序之后,首先定義初始化函數表,程序在lib-arm/board.e中,如下所示:

o4YBAGB1amqAaI7xAACXumMCR_0447.png

(2)初始化FLASH設備和顯示FLASH設備信息;

(3)初始化系統內存分配函數;

(4)如果目標系統擁有NAND設備,則初始化NAND設備;

(5)初始化顯示設備;

(6)初始化網絡設備,填寫IP地址、MAC地址等信息;

(7)開啟中斷處理;

(8)進入命令循環,接收用戶從串口的命令輸入。

3 U-Boot的移植方法

本文選用交叉編譯環境arm-linux-gcc-2.95.3,選用U-Boot-1.1.4版本作為移植平臺。為了使U-Boot支持新的開發板,一種簡便的做法是在U-Boot已經支持的開發板中選擇一種與目標板接近的,在其基礎上進行修改。這里選用的是smdk2410的配置。

3.1 修改cpu/arm920t/start.S文件

Start.s是采用匯編語言編寫的U-Boot程序入口代碼,完成對底層硬件的初始化,其中有一個很重要的功能是從NAND FLASH中把Stage 2階段的代碼復制到SDRAM中。在此階段,涉及到對NANDFLASH的讀操作,在U-Boot中,沒有對NANDFLASH讀操作的驅動,采用以下方法實現:

pIYBAGB1apuAdZ9dAABqd2lZsyg313.png

通過調用board/smdk2410/nand_read.C中的nand_read_11函數將Stage 2階段的代碼復制到ram中。

3.2 修改board/smdk2410目錄下文件

(1)增加對NANDFLASH的讀驅動nand_read.c

o4YBAGB1asiAPKbKAADjA2rQaSI613.png

(2)在smdk2410.C文件中添加對NANDFLASH初始化的程序

在此主要是對主板的GPIO的一些設置,并加上對NANDFLASH初始化程序。

o4YBAGB1awKAP5VmAAB0Cdw32VA388.png

pIYBAGB1axSAf55yAADhJCx3cEQ657.png

(3)在該目錄下的Makefile文件中添加nand_read.C文件的編譯

OBJS:=smdk24 10.o FLASH.o nand_read.o

3.3 在include文件中設置NAND FLASH硬件參數

在/linux/mtd/nand_ids.h中設置參數:

pIYBAGB1a0iAV6JYAAAyIvA0qbc179.png

3.4 編譯與運行

配置好以后,進入U-Boot主目錄,重新編譯U-Boot代碼,運行命令:

(1)查看交叉編譯器的版本號

arm-linux-gcc-v

(2)清除生成的連接

Make distclean

(3)編譯make smdk2410_config

(4)make CROSS-COMPILE=arm-linux-編譯成功后,將生成三個文件:

u-boot:ELF格式的文件,可以被大多數Debug程序識別。

u-boot.bin:二進制bin文件,純碎的U-Boot二進制執行代碼,不保存ELF格式和調試信息。這個文件用于燒到用戶的開發板中。

u-boot.srec:Motorola S-Record格式,可以通過串口下載到開發板中。

將得到的u-boot.bin文件借助于FLASH芯片燒寫工具,通過JTAG口下載到目標板后,檢查U-Boot能否正常工作。如果能從串口輸出正確的啟動信息,就表明移植基本成功。

4 結 語

目前筆者移植的U-Boot已經能穩定地運行在開發板上。U-Boot引導程序是嵌入式Linux系統軟件開發中的一個重要環節。在此通過分析U-Boot的代碼結構和啟動過程,并針對開發板系統的硬件資源,通過分析與調試,實現了U-Boot的移植,并且能夠引導嵌入式Linux內核和文件系統,為今后進一步開發奠定了堅實的基礎。

編輯:jq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 嵌入式
    +關注

    關注

    5198

    文章

    20449

    瀏覽量

    334102
  • 無線通信
    +關注

    關注

    58

    文章

    4987

    瀏覽量

    146884
  • u-boot
    +關注

    關注

    0

    文章

    135

    瀏覽量

    39778
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    U-boot無法初始化計時器怎么處理?

    u-boot 崩潰并顯示此錯誤。 U-Boot SPL 2023.07-rc2-00170-g62df7a3944-dirty (Jun 27 2023 - 15:03:29 +0300)DDR
    發表于 03-02 08:30

    深入解析U-Boot image.c:RK平臺鏡像處理核心邏輯

    在瑞芯微(RK)平臺的嵌入式開發中,U-Boot作為核心的啟動加載程序,負責完成鏡像解析、校驗、加載等關鍵流程。而image.c正是U-Boot中處理鏡像(uImage)的核心文件,尤
    的頭像 發表于 02-24 16:46 ?1458次閱讀
    深入解析<b class='flag-5'>U-Boot</b> image.<b class='flag-5'>c</b>:RK平臺鏡像處理核心邏輯

    玩轉U-Boot bdinfo:嵌入式bsp開發者的定制、擴展與裁剪實戰指南

    作為嵌入式開發者,U-Boot 是我們調試、適配板卡的核心工具,而 bdinfo 命令更是板級信息調試的“利器”——它能直觀打印內存布局、Flash 信息、網絡配置、時鐘頻率等核心參數。但原廠
    的頭像 發表于 02-24 15:26 ?721次閱讀
    玩轉<b class='flag-5'>U-Boot</b> bdinfo:<b class='flag-5'>嵌入式</b>bsp開發者的定制、擴展與裁剪實戰指南

    深入解析RK3588 U-Boot板級文件:evb_rk3588.c核心邏輯拆解

    嵌入式開發領域,瑞芯微RK3588憑借超強的算力、豐富的接口和廣泛的場景適配性,成為高端邊緣計算、消費電子項目的熱門選擇。而U-Boot作為嵌入式系統的“第一道門”,負責硬件初始化、
    的頭像 發表于 02-24 15:24 ?775次閱讀
    深入解析RK3588 <b class='flag-5'>U-Boot</b>板級文件:evb_rk3588.<b class='flag-5'>c</b>核心邏輯拆解

    U-Boot SPL核心文件spl.c深度解析:從啟動流程到調試優化

    嵌入式系統開發中,U-Boot 的 SPL(Secondary Program Loader)扮演著至關重要的角色,它是系統上電后執行的第一個軟件組件之一,負責為后續啟動過程鋪平道路
    的頭像 發表于 02-05 14:08 ?144次閱讀
    <b class='flag-5'>U-Boot</b> SPL核心文件spl.<b class='flag-5'>c</b><b class='flag-5'>深度</b>解析:從啟動流程到調試優化

    深入解析U-Boot TPL代碼:嵌入式啟動的“第一棒”背后的秘密

    嵌入式系統啟動過程中,從按下電源鍵到操作系統開始運行,中間藏著一系列精密的初始化步驟。今天我們就來拆解 Rockchip 平臺 U-Boot 中的 TPL(Tiny Program
    的頭像 發表于 02-05 14:07 ?1068次閱讀
    深入解析<b class='flag-5'>U-Boot</b> TPL代碼:<b class='flag-5'>嵌入式</b>啟動的“第一棒”背后的秘密

    深入解析U-Boot命令處理核心文件:功能、調試與開發價值

    嵌入式系統開發中,U-Boot 作為主流的引導加載程序,其命令處理、交互邏輯和自動啟動流程是核心功能模塊。本文將圍繞command.c、cli.c
    的頭像 發表于 02-03 15:44 ?885次閱讀
    深入解析<b class='flag-5'>U-Boot</b>命令處理核心文件:功能、調試與開發價值

    深入解析U-Boot核心文件board_f.c:知識點、調試要點與開發價值

    嵌入式系統開發中,U-Boot 作為應用最廣泛的引導程序,其底層初始化邏輯直接決定了硬件啟動的穩定性與可靠性。
    的頭像 發表于 02-03 15:38 ?747次閱讀
    深入解析<b class='flag-5'>U-Boot</b>核心文件board_f.<b class='flag-5'>c</b>:知識點、調試要點與開發價值

    解析Rockchip平臺U-Boot核心文件:boot_rkimg.c到底做了什么?

    嵌入式開發中,U-Boot 作為引導程序的 “中流砥柱”,負責初始化硬件、加載內核并啟動系統。對于 Rockchip 平臺的設備(如常見的開發板、智能終端),boot_rkimg.c
    的頭像 發表于 02-03 15:29 ?750次閱讀
    解析Rockchip平臺<b class='flag-5'>U-Boot</b>核心文件:<b class='flag-5'>boot_rkimg.c</b>到底做了什么?

    深入理解?RK3506 U-Boot?重定位:從代碼到原理

    嵌入式系統中,U-Boot?作為引導加載程序,其啟動流程的核心環節之一就是 重定位(Relocation) 。對于?RK3506?這類基于?ARM Cortex-A?架構的芯片,重定
    的頭像 發表于 11-28 07:05 ?597次閱讀
    深入理解?RK3506 <b class='flag-5'>U-Boot</b>?重定位:從代碼到原理

    U-Boot 無法識別 NAND怎么解決?

    U-Boot 無法識別 NAND
    發表于 09-03 06:37

    新品|Stamp-S3A PIN1.27,ESP-32 嵌入式模組

    本期聚焦兩款高性能嵌入式模組:Stamp-S3A與Stamp-S3APIN1.27,兩款模組均搭載240MHzXtensaLX7雙核處理器,集成8MBFlash,具備可編程RGB指示燈與按鍵輸入
    的頭像 發表于 07-11 18:05 ?605次閱讀
    新品|Stamp-<b class='flag-5'>S3A</b> PIN1.27,ESP-32 <b class='flag-5'>嵌入式</b>模組

    飛凌嵌入式ElfBoard ELF 1板卡-uboot編譯u-boot/u-boot.bin/u-boot.imx

    u-boot文件就是編譯流程章節講的,鏈接器將鏈接各.o文件之后生成的.elf文件,該文件中包含了大量的調試信息、地址信息和注釋信息,不能被直接執行,需要轉換成為可執行的u-boot.bin文件,而
    發表于 05-22 11:24

    飛凌嵌入式ElfBoard ELF 1板卡-Uboot

    上節中講到U-Boot是BootLoader的一種,U-Boot全稱為Universal Boot Loader,即通用的BootLoader,所謂通用就是指它適用于多種嵌入式平臺,包
    發表于 05-22 10:44

    U-Boot 和 Bootloader,99% 的工程師都分不清?

    嵌入式軟件工程師聽說過 u-boot 和 bootloader,但很多工程師依然不知道他們到底是啥。 ? 今天就來簡單講講?u-boot 和 bootloader?的內容以及區別
    的頭像 發表于 03-25 20:47 ?1798次閱讀