0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

ZYNQ Linux操作系統(tǒng)移植四個(gè)部分說(shuō)明文檔

電子設(shè)計(jì) ? 來(lái)源:Felven的博客 ? 作者:Felven的博客 ? 2020-12-14 14:59 ? 次閱讀

一、組成
ZYNQ上面移植Linux操作系統(tǒng)包括四個(gè)部分,uboot,devicetree,kernel,ramdisk.

其中uboot類似于bios,負(fù)責(zé)對(duì)設(shè)備進(jìn)行簡(jiǎn)單的初始化,devicetree以樹(shù)的形式對(duì)zynq相連的硬件設(shè)備進(jìn)行描述,kernel是加載的操作系統(tǒng)內(nèi)核,ramdisk是操作系統(tǒng)啟動(dòng)之后掛載的文件系統(tǒng)。

二、啟動(dòng)過(guò)程
移植操作系統(tǒng)后zynq的啟動(dòng)過(guò)程如下,首先加載bootrom(zynq中自帶,用戶無(wú)法修改),然后執(zhí)行fsbl(這個(gè)根據(jù)硬件在sdk中創(chuàng)建),然后執(zhí)行uboot,uboot會(huì)將kernel、devicetree和ramdisk載入ddr,跳轉(zhuǎn)到內(nèi)核入口處執(zhí)行,這樣linux就啟動(dòng)了。

o4YBAF9uELeAVxYlAACA6TM13kY883.png

對(duì)bootrom、fsbl和uboot詳細(xì)描述如下。

o4YBAF9uELuABxXtAAQSHlX-gg8443.png

三、uboot設(shè)置
uboot可以從xilinx 官方github上面下載,地址是:

通常uboot不需要升級(jí),目前使用的版本為xilinx 2015年底發(fā)布的版本2015.4.不過(guò)針對(duì)不同的模塊uboot需要進(jìn)行修改,主要修改下面幾個(gè)地方。

1、參考時(shí)鐘修改
地址位于arch/arm/cpu/armv7/zynq/clk.c

由于ZYNQ設(shè)計(jì)大多使用50M參考時(shí)鐘,需要更改參考時(shí)鐘

# define CONFIG_ZYNQ_PS_CLK_FREQ 33333333UL更改為

# define CONFIG_ZYNQ_PS_CLK_FREQ 50000000UL

2、串口配置修改
地址位于include/configs/zynq_zc70x.h

根據(jù)硬件串口情況進(jìn)行配置

#define CONFIG_ZYNQ_SERIAL_UART1 使用串口1

#define CONFIG_ZYNQ_SERIAL_UART0 使用串口0

如果兩個(gè)串口都啟用,一起配置即可。

3、DDR配置修改
地址位于include/configs/zynq_zc70x.h

根據(jù)DDR實(shí)際大小地址修改配置參數(shù)

#define CONFIG_SYS_SDRAM_SIZE (1024 * 1024 * 1024) 1GB DDR

#define CONFIG_SYS_SDRAM_SIZE (512 * 1024 * 1024) 512MB DDR

4、PHY地址配置
地址位于include/configs/zynq_zc70x.h

根據(jù)硬件PHY地址進(jìn)行配置,通常硬件會(huì)將PHY地址設(shè)置為0

#define CONFIG_ZYNQ_GEM_PHY_ADDR0 0

如果硬件啟用了兩個(gè)網(wǎng)卡,則需要設(shè)置兩個(gè)PHY的地址

#define CONFIG_ZYNQ_GEM0

#define CONFIG_ZYNQ_GEM_PHY_ADDR0 1


#define CONFIG_ZYNQ_GEM1

#define CONFIG_ZYNQ_GEM_PHY_ADDR1 18

5、啟動(dòng)方式配置
地址位于include/configs/zynq_common.h

如果使用QSPI flash方式啟動(dòng),需要配置QSPI FLASH對(duì)應(yīng)地址,如下。

"sf probe 0 0 0 && " /

"sf read 0x3000000 0x400000 ${kernel_size} && " /

"sf read 0x2A00000 0x900000 ${devicetree_size} && " /

"echo Copying ramdisk... && " /

"sf read 0x2000000 0x920000 ${ramdisk_size} && " /

"bootm 0x3000000 0x2000000 0x2A00000/0" /

6、IP地址配置
地址位于include/configs/zynq_common.h

#define CONFIG_IPADDR 192.168.100.12 //uboot啟動(dòng)時(shí)板子的IP地址

#define CONFIG_SERVERIP 192.168.100.6 //uboot啟動(dòng)時(shí)能訪問(wèn)的遠(yuǎn)程服務(wù)器地址,若采用TFTP加載,需要將本地電腦配置為該地址

7、啟動(dòng)延遲設(shè)置
地址位于include/configs/zynq_common.h

#define CONFIG_BOOTDELAY 7 /* -1 to Disable autoboot */

Uboot默認(rèn)延遲7s再?gòu)腝SPI flash中加載操作系統(tǒng),如果設(shè)置為-1表明禁止自動(dòng)加載

8、初始化設(shè)置
地址位于net/eth.c 和 arch/arm/lib/board.c

Uboot中需要對(duì)5396進(jìn)行初始化,同時(shí)使用GPIO對(duì)PHY或NOR FLASH等進(jìn)行復(fù)位,可以在eth.c中增加代碼

void mygpio_init()

{ }

然后將Mygpio_init()加入到arch/arm/lib/board.c中

9、Uboot編譯
修改完成后,可以使用下列命令編譯產(chǎn)生uboot

進(jìn)入u-boot文件夾

$ make distclean //文件夾清理

$ make zynq_zc70x_config // 載入配置,通常使用zynq_zc70x.h文件

pIYBAF9uEL6AMFBQAALA61J4tLc224.png

$ make

編譯完成后文件夾下會(huì)出現(xiàn)u-boot文件,將其修改為u-boot.elf

pIYBAF9uEMGAVTaHAAEUBK1PLhE618.png

四、devicetree設(shè)置
devicetree源文件可以從xilinx官方下載,地址:https://github.com/Xilinx/device-tree-xlnx/releases

不同板子的devicetree可以根據(jù)xilinx sdk生成,操作過(guò)程如下。

1、在XILINX SDK中打開(kāi)板子的ZYNQ工程,在xilinx tools中添加devicetree的源文件地址

o4YBAF9uEMKAd6XkAAD_9qCZ7T0945.png

2、創(chuàng)建devicetree BSP文件

o4YBAF9uEMWAa6t6AAGDcllJTKE440.png

創(chuàng)建完成后得到文件如下

pIYBAF9uEMiACjpUAAJ1w0Kz-40516.png

3、將dtsi,dts文件拷入linux系統(tǒng)下,使用dts工具制作devicetree.dtb文件

o4YBAF9uEMqAG0PrAACzS2-9Wm4844.png

4、如果需要修改devicetree文件,可以通過(guò)dtc工具轉(zhuǎn)換為可讀文件dts

pIYBAF9uEMyAFFBeAAD4aKdvEPw344.png

生成的1.dts可打開(kāi),里面能看到zynq端的外設(shè)信息和啟用情況。通常需要修改網(wǎng)卡配置,如下,下例中phy地址為0

ethernet@e000b000 {

compatible = "xlnx,ps7-ethernet-1.00.a";

reg = ;

status = "okay";

interrupt-parent = ;

interrupts = ;

clocks = ;

clock-names = "ref_clk", "aper_clk";

#address-cells = ;

#size-cells = ;

enet-reset = ;

local-mac-address = [00 0a 35 00 00 00];

phy-mode = "rgmii";

phy-handle = ;

xlnx,eth-mode = ;

xlnx,has-mdio = ;

xlnx,ptp-enet-clock = ;

mdio {

#address-cells = ;

#size-cells = ;

phy@0 {

compatible = "marvell,88e1111";

device_type = "ethernet-phy";

reg = ;

linux,phandle = ;

phandle = ;

};

};

};

當(dāng)對(duì)dts修改完成后,再次使用dtc工具編譯產(chǎn)生devicetree.dtb即可

五、文件系統(tǒng)設(shè)置
文件系統(tǒng)一般隨zynq開(kāi)發(fā)板發(fā)布,可以從prebuit中找到文件系統(tǒng)的tar文件

o4YBAF9uENGAdTbqAANeO7N49Ds478.png

解壓后得到的文件如下

o4YBAF9uENKAaN0UAAB4NNelZFk463.png

在文件系統(tǒng)中,如果需要添加用戶自定義的shell腳本或可執(zhí)行程序,可以放在/usr/bin目錄下。如果要設(shè)置系統(tǒng)自啟動(dòng)項(xiàng),可以在/etc/rc5.d中增加shell腳本。

pIYBAF9uENSAcBMKAAEaKMBjqkE746.png

這里進(jìn)行了IP地址的配置

o4YBAF9uENeAbdCcAAImwuHNbn0338.png

1、文件系統(tǒng)制作
當(dāng)修改完rootfs后,可以通過(guò)下面命令制作uramdisk文件系統(tǒng)

$sh -c 'cd rootfs/ && find . | cpio -H newc -o' | gzip -9 > new_initramfs.cpio.gz

$mkimage -A arm -T ramdisk -C gzip -d new_initramfs.cpio.gz uramdisk.image.gz

執(zhí)行完畢將會(huì)得到uramdisk.image.gz

六、內(nèi)核配置
內(nèi)核可以從xilinx官方git下載,地址:

目前l(fā)inux內(nèi)核中已經(jīng)集成了常見(jiàn)的驅(qū)動(dòng),驅(qū)動(dòng)源碼位于drivers文件夾下。針對(duì)內(nèi)核的修改位于 arch/arm/configs/xilinx_zynq_defconfig文件中,該文件中定義了內(nèi)核所包含的驅(qū)動(dòng)程序。

1、調(diào)試輸出打印
在xilinx_zynq_defconfig中,需要根據(jù)硬件設(shè)計(jì)正確配置串口打印。

CONFIG_DEBUG_LL=y

CONFIG_DEBUG_ZYNQ_UART0=y //使用串口0打印輸出

CONFIG_EARLY_PRINTK=y

2、內(nèi)核編譯
修改完xilinx_zynq_defconfig后,可以使用下面命令編譯內(nèi)核

$sudo //編譯內(nèi)核需要運(yùn)行在root權(quán)限下

$make distclean //清理文件

$make ARCH=arm xilinx_zynq_defconfig //讀取內(nèi)核配置信息,即xilinx_zynq_defconfig中的內(nèi)容

$make ARCH=arm menuconfig //進(jìn)入內(nèi)核菜單進(jìn)行可視化配置,如果xilinx_zynq_defconfig中對(duì)內(nèi)核配置準(zhǔn)確時(shí),該步驟可以省略

$make ARCH=arm UIMAGE_LOADADDR=0x8000 uImage -j4 //編譯產(chǎn)生uImage

產(chǎn)生的文件位于arch/arm/boot文件夾內(nèi)

pIYBAF9uENmAV0RkAACFVqGhqHM345.png

七、常見(jiàn)驅(qū)動(dòng)
1、I2C驅(qū)動(dòng)
目前板子上都會(huì)用到I2C,首先需要知道I2C從設(shè)備的地址,如2/4/8這些.在devicetree中進(jìn)行設(shè)置

pIYBAF9uENuAGShtAAFJWxUxz6M774.png

在內(nèi)核中添加1848的驅(qū)動(dòng)

o4YBAF9uEN2AFbyuAADO0KtUlZM540.png

編譯內(nèi)核的時(shí)候加入該驅(qū)動(dòng),同時(shí)修改makefile和kconfig文件

pIYBAF9uEN-AKuG6AAGcZ2UjQwE993.png

這樣在編譯內(nèi)核的時(shí)候就能看到將驅(qū)動(dòng)編進(jìn)內(nèi)核的選項(xiàng)了。

pIYBAF9uEOGAXXKOAAEK6FT4Fow752.png


o4YBAF9uEOOAQ4COAACr1JAXrW0025.png

編譯完內(nèi)核后,啟動(dòng)時(shí)就能看到1848的從設(shè)備

pIYBAF9uEOWAZDR_AAGCWbxSXJY608.png

2、ADC驅(qū)動(dòng)
ADC為ZYNQ用來(lái)監(jiān)測(cè)電壓或電流的通道,目前ZYNQ中集成了16個(gè)通道,首先需要在devicetree中設(shè)置啟用的通道,圖中啟用的是0,1,8三個(gè)通道

o4YBAF9uEOeAdkVvAACePOBUXc0956.png

內(nèi)核中啟用ADC驅(qū)動(dòng)

o4YBAF9uEOqALkYuAALM8Wgyf4A920.png


pIYBAF9uEO6AXrTEAAMBiRFhPxo365.png


o4YBAF9uEPGAaSz7AANXI02i7CY601.png

系統(tǒng)啟動(dòng)后就能看到輸出了,這里輸出的是溫度值

o4YBAF9uEPaAHSDgAAQdG9ZhonQ882.png


pIYBAF9uEPiAd_iDAAGNdVMKyk4343.png

實(shí)際溫度還需要進(jìn)行換算,結(jié)果如下

o4YBAF9uEPyAMSGCAANgyEvE1UQ029.png

3、NOR FLASH驅(qū)動(dòng)
NOR FLAHS驅(qū)動(dòng)主要實(shí)現(xiàn)文件系統(tǒng)的掛載,這里不需要設(shè)置devicetree,只需要在內(nèi)核中添加掛載文件系統(tǒng)的代碼

pIYBAF9uEP-AAG3pAAH3lfykgbw288.png

上圖中將NOR FALSH分為2個(gè)區(qū),大小分別為32MB和64MB,需要注意的是NOR FLASH的起始地址和容量大小設(shè)置

#defineWINDOW_ADDR 0x80000000 //和vivado里面的emc起始地址一致

#defineWINDOW_SIZE 0x8000000 //nor flash大小

在makefile中將該驅(qū)動(dòng)編譯進(jìn)內(nèi)核即可

o4YBAF9uEQGAOZtOAACRtPBXfVg765.png

啟動(dòng)后就能看到掛載的文件系統(tǒng)了

pIYBAF9uEQOAGBC4AAG4TWrQZhs322.png

4、外部中斷驅(qū)動(dòng)
當(dāng)zynq接收來(lái)自外部的GPIO中斷時(shí),需要使用UIO機(jī)制及時(shí)響應(yīng)中斷,首先在devicetree中模擬出四個(gè)GPIO設(shè)備

o4YBAF9uEQaADY5IAAJODkPcmHg981.png

注意上面的中斷號(hào)0x1e-0x21要與硬件實(shí)際相連的中斷管腳一致。

同時(shí)在devicetree中啟用UIO機(jī)制

o4YBAF9uEQeAHuLQAACje5Q-BBs547.png

在編譯內(nèi)核時(shí)將UIO驅(qū)動(dòng)編譯進(jìn)內(nèi)核

pIYBAF9uEQmAXjB-AAESSskar1E386.png

當(dāng)操作系統(tǒng)啟動(dòng)完成后就能看到四個(gè)外部GPIO設(shè)備產(chǎn)生的中斷了

pIYBAF9uEQ6ANu9GAAQIdcAuZOA931.png

八、啟動(dòng)文件制作
如下圖所示,在SDK中創(chuàng)建boot.bin需要包含下面五個(gè)文件

Fsbl.elf

Zynq_top.bin

u-boot.elf

uImage

devicetree.dtb

uramdisk.image.gz

制作過(guò)程中需要正確配置uimage,devicetree.dtb,uramdisk.image.gz的地址,讓其與u-boot中從QSPI flash加載地址匹配

pIYBAF9uEROALacYAAS3fSaHpCI455.png


pIYBAF9uERaAU2V8AANG7gbqJ-g675.png


o4YBAF9uERuADv8pAAPaaMcltz0247.png

制作完成后將boot.bin通過(guò)下載電纜燒入QSPI FLASH中即可。
編輯:hfy


聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11329

    瀏覽量

    209970
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    6862

    瀏覽量

    123507
  • Zynq
    +關(guān)注

    關(guān)注

    10

    文章

    610

    瀏覽量

    47228
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    deepin操作系統(tǒng)介紹

    希望從自己的能力和對(duì)桌面操作系統(tǒng)的理解,能給 Linux 的用戶與開(kāi)發(fā)者更多的選擇。我們也相信 deepin 能夠得到更多用戶的認(rèn)可與喜愛(ài),成為開(kāi)源世界的最佳選擇。? 一、 deepin 操作系統(tǒng) 先說(shuō)
    的頭像 發(fā)表于 12-23 09:08 ?449次閱讀
    deepin<b class='flag-5'>操作系統(tǒng)</b>介紹

    IP2368寄存器說(shuō)明文檔

    轉(zhuǎn)換芯片,轉(zhuǎn)到 3.3V;? IP2368 INT 應(yīng)用說(shuō)明:IP2368 休眠時(shí)檢測(cè)到 INT 為高就會(huì)喚醒,喚醒之后,IP2368 主動(dòng)拉高 INT,100ms之后,MCU 可進(jìn)行 I2C 通信,進(jìn)行寄存器的讀寫(xiě)操作;IP2368 在進(jìn)入休眠之前,會(huì)切換為輸入高阻來(lái)檢
    發(fā)表于 12-04 14:30 ?11次下載

    linux是實(shí)時(shí)系統(tǒng)還是分時(shí)操作系統(tǒng)

    大家平時(shí)玩單片機(jī)基本上對(duì)于μC/OS、FreeRTOS、ThreadX這些操作系統(tǒng)非常熟悉了,他們都屬于實(shí)時(shí)操作系統(tǒng)(RTOS),在工業(yè)領(lǐng)域比較廣泛;然而對(duì)于linux這樣的基于時(shí)間片劃分的非實(shí)時(shí)
    的頭像 發(fā)表于 11-11 11:43 ?552次閱讀

    linux操作系統(tǒng)安裝步驟 linux操作系統(tǒng)的特點(diǎn)及組成

    Linux操作系統(tǒng)安裝步驟 Linux操作系統(tǒng)是一種開(kāi)源的操作系統(tǒng),它以其穩(wěn)定性、安全性和靈活性而聞名。以下是安裝
    的頭像 發(fā)表于 10-21 11:24 ?623次閱讀

    請(qǐng)問(wèn)TAS6424E-Q1和TAS6424-Q1的區(qū)別主要有什么 是否有官方的說(shuō)明文檔

    請(qǐng)問(wèn)TAS6424E-Q1和TAS6424-Q1的區(qū)別是否有官方的說(shuō)明文檔,除了數(shù)據(jù)手冊(cè)之外,多謝!
    發(fā)表于 10-09 10:11

    IP5385應(yīng)用說(shuō)明文檔

    IP5385 應(yīng)用說(shuō)明文檔
    發(fā)表于 10-08 09:25 ?11次下載

    超低功耗 AT方案說(shuō)明文檔 新增716s/718p芯片模塊的固件獲取以及測(cè)試方法

    超低功耗 AT方案說(shuō)明文檔 新增716s/718p芯片模塊的固件獲取以及測(cè)試方法
    的頭像 發(fā)表于 07-18 09:36 ?987次閱讀
    超低功耗 AT方案<b class='flag-5'>說(shuō)明文檔</b> 新增716s/718p芯片模塊的固件獲取以及測(cè)試方法

    16306鉦銘科通用協(xié)議說(shuō)明文檔V1.2

    16306鉦銘科通用協(xié)議說(shuō)明文檔V1.2
    發(fā)表于 07-09 11:52 ?0次下載

    工業(yè)實(shí)時(shí)操作系統(tǒng)對(duì)比:鴻道Intewell跟rt-linux有啥區(qū)別

    Intewell和RT-Linux是兩種不同的實(shí)時(shí)操作系統(tǒng)(RTOS),它們具有各自獨(dú)特的特點(diǎn)和優(yōu)勢(shì)。以下是Intewell操作系統(tǒng)的一些關(guān)鍵特性,以及與RT-Linux的比較:
    的頭像 發(fā)表于 07-03 10:00 ?561次閱讀
    工業(yè)實(shí)時(shí)<b class='flag-5'>操作系統(tǒng)</b>對(duì)比:鴻道Intewell跟rt-<b class='flag-5'>linux</b>有啥區(qū)別

    AURIX3G可以使用Linux操作系統(tǒng)嗎?

    即使在 AURIX3G 中,也可以使用 Linux 操作系統(tǒng)嗎?
    發(fā)表于 05-22 07:12

    芯海應(yīng)用筆記:CSS34P16P(A)型應(yīng)用說(shuō)明文檔

    Type-C 和 USB 供電端口控制解決方案。芯片可根據(jù)用戶需求靈活配置,操作簡(jiǎn)便, 可快速實(shí)現(xiàn)方案功能。*附件:CSS34P16應(yīng)用說(shuō)明文檔.pdf
    發(fā)表于 05-16 14:46

    瑞薩CTSU程序在向嵌入式OS操作系統(tǒng)移植時(shí)的注意事項(xiàng)

    瑞薩CTSU程序在向嵌入式OS操作系統(tǒng)移植時(shí)的注意事項(xiàng)
    的頭像 發(fā)表于 03-29 08:05 ?371次閱讀
    瑞薩CTSU程序在向嵌入式OS<b class='flag-5'>操作系統(tǒng)</b><b class='flag-5'>移植</b>時(shí)的注意事項(xiàng)

    Linux操作系統(tǒng)上的射頻測(cè)試模式應(yīng)用指南

    電子發(fā)燒友網(wǎng)站提供《Linux操作系統(tǒng)上的射頻測(cè)試模式應(yīng)用指南.pdf》資料免費(fèi)下載
    發(fā)表于 02-19 09:39 ?0次下載
    <b class='flag-5'>Linux</b><b class='flag-5'>操作系統(tǒng)</b>上的射頻測(cè)試模式應(yīng)用指南

    全國(guó)大學(xué)生計(jì)算機(jī)系統(tǒng)能力大賽操作系統(tǒng)設(shè)計(jì)賽-LoongArch 賽道廣東龍芯2K1000LA 平臺(tái)資料分享

    xv6-loongarch。 xv6 是MIT開(kāi)發(fā)的一個(gè)類Unix教學(xué)操作系統(tǒng),與Linux或BSD不同,xv6非常簡(jiǎn)單,足以在一個(gè)學(xué)期內(nèi)講完,但仍包含Unix的重要概念和組織結(jié)構(gòu)。
    發(fā)表于 02-04 15:37

    Linux操作系統(tǒng)中如何按下PCIe的復(fù)位鍵

    Linux操作系統(tǒng)中,看如何按下PCIe的復(fù)位鍵
    的頭像 發(fā)表于 01-20 09:31 ?1679次閱讀
    <b class='flag-5'>Linux</b><b class='flag-5'>操作系統(tǒng)</b>中如何按下PCIe的復(fù)位鍵