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

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

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

3天內不再提示

ZYNQ Linux操作系統移植四個部分說明文檔

電子設計 ? 來源:Felven的博客 ? 作者:Felven的博客 ? 2020-12-14 14:59 ? 次閱讀

一、組成
ZYNQ上面移植Linux操作系統包括四個部分,uboot,devicetree,kernel,ramdisk.

其中uboot類似于bios,負責對設備進行簡單的初始化,devicetree以樹的形式對zynq相連的硬件設備進行描述,kernel是加載的操作系統內核,ramdisk是操作系統啟動之后掛載的文件系統。

二、啟動過程
移植操作系統后zynq的啟動過程如下,首先加載bootrom(zynq中自帶,用戶無法修改),然后執行fsbl(這個根據硬件在sdk中創建),然后執行uboot,uboot會將kernel、devicetree和ramdisk載入ddr,跳轉到內核入口處執行,這樣linux就啟動了。

o4YBAF9uELeAVxYlAACA6TM13kY883.png

對bootrom、fsbl和uboot詳細描述如下。

o4YBAF9uELuABxXtAAQSHlX-gg8443.png

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

通常uboot不需要升級,目前使用的版本為xilinx 2015年底發布的版本2015.4.不過針對不同的模塊uboot需要進行修改,主要修改下面幾個地方。

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

由于ZYNQ設計大多使用50M參考時鐘,需要更改參考時鐘

# define CONFIG_ZYNQ_PS_CLK_FREQ 33333333UL更改為

# define CONFIG_ZYNQ_PS_CLK_FREQ 50000000UL

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

根據硬件串口情況進行配置

#define CONFIG_ZYNQ_SERIAL_UART1 使用串口1

#define CONFIG_ZYNQ_SERIAL_UART0 使用串口0

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

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

根據DDR實際大小地址修改配置參數

#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

根據硬件PHY地址進行配置,通常硬件會將PHY地址設置為0

#define CONFIG_ZYNQ_GEM_PHY_ADDR0 0

如果硬件啟用了兩個網卡,則需要設置兩個PHY的地址

#define CONFIG_ZYNQ_GEM0

#define CONFIG_ZYNQ_GEM_PHY_ADDR0 1


#define CONFIG_ZYNQ_GEM1

#define CONFIG_ZYNQ_GEM_PHY_ADDR1 18

5、啟動方式配置
地址位于include/configs/zynq_common.h

如果使用QSPI flash方式啟動,需要配置QSPI FLASH對應地址,如下。

"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啟動時板子的IP地址

#define CONFIG_SERVERIP 192.168.100.6 //uboot啟動時能訪問的遠程服務器地址,若采用TFTP加載,需要將本地電腦配置為該地址

7、啟動延遲設置
地址位于include/configs/zynq_common.h

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

Uboot默認延遲7s再從QSPI flash中加載操作系統,如果設置為-1表明禁止自動加載

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

Uboot中需要對5396進行初始化,同時使用GPIO對PHY或NOR FLASH等進行復位,可以在eth.c中增加代碼

void mygpio_init()

{ }

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

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

進入u-boot文件夾

$ make distclean //文件夾清理

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

pIYBAF9uEL6AMFBQAALA61J4tLc224.png

$ make

編譯完成后文件夾下會出現u-boot文件,將其修改為u-boot.elf

pIYBAF9uEMGAVTaHAAEUBK1PLhE618.png

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

不同板子的devicetree可以根據xilinx sdk生成,操作過程如下。

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

o4YBAF9uEMKAd6XkAAD_9qCZ7T0945.png

2、創建devicetree BSP文件

o4YBAF9uEMWAa6t6AAGDcllJTKE440.png

創建完成后得到文件如下

pIYBAF9uEMiACjpUAAJ1w0Kz-40516.png

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

o4YBAF9uEMqAG0PrAACzS2-9Wm4844.png

4、如果需要修改devicetree文件,可以通過dtc工具轉換為可讀文件dts

pIYBAF9uEMyAFFBeAAD4aKdvEPw344.png

生成的1.dts可打開,里面能看到zynq端的外設信息和啟用情況。通常需要修改網卡配置,如下,下例中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 = ;

};

};

};

當對dts修改完成后,再次使用dtc工具編譯產生devicetree.dtb即可

五、文件系統設置
文件系統一般隨zynq開發板發布,可以從prebuit中找到文件系統的tar文件

o4YBAF9uENGAdTbqAANeO7N49Ds478.png

解壓后得到的文件如下

o4YBAF9uENKAaN0UAAB4NNelZFk463.png

在文件系統中,如果需要添加用戶自定義的shell腳本或可執行程序,可以放在/usr/bin目錄下。如果要設置系統自啟動項,可以在/etc/rc5.d中增加shell腳本。

pIYBAF9uENSAcBMKAAEaKMBjqkE746.png

這里進行了IP地址的配置

o4YBAF9uENeAbdCcAAImwuHNbn0338.png

1、文件系統制作
當修改完rootfs后,可以通過下面命令制作uramdisk文件系統

$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

執行完畢將會得到uramdisk.image.gz

六、內核配置
內核可以從xilinx官方git下載,地址:

目前linux內核中已經集成了常見的驅動,驅動源碼位于drivers文件夾下。針對內核的修改位于 arch/arm/configs/xilinx_zynq_defconfig文件中,該文件中定義了內核所包含的驅動程序。

1、調試輸出打印
在xilinx_zynq_defconfig中,需要根據硬件設計正確配置串口打印。

CONFIG_DEBUG_LL=y

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

CONFIG_EARLY_PRINTK=y

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

$sudo //編譯內核需要運行在root權限下

$make distclean //清理文件

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

$make ARCH=arm menuconfig //進入內核菜單進行可視化配置,如果xilinx_zynq_defconfig中對內核配置準確時,該步驟可以省略

$make ARCH=arm UIMAGE_LOADADDR=0x8000 uImage -j4 //編譯產生uImage

產生的文件位于arch/arm/boot文件夾內

pIYBAF9uENmAV0RkAACFVqGhqHM345.png

七、常見驅動
1、I2C驅動
目前板子上都會用到I2C,首先需要知道I2C從設備的地址,如2/4/8這些.在devicetree中進行設置

pIYBAF9uENuAGShtAAFJWxUxz6M774.png

在內核中添加1848的驅動

o4YBAF9uEN2AFbyuAADO0KtUlZM540.png

編譯內核的時候加入該驅動,同時修改makefile和kconfig文件

pIYBAF9uEN-AKuG6AAGcZ2UjQwE993.png

這樣在編譯內核的時候就能看到將驅動編進內核的選項了。

pIYBAF9uEOGAXXKOAAEK6FT4Fow752.png


o4YBAF9uEOOAQ4COAACr1JAXrW0025.png

編譯完內核后,啟動時就能看到1848的從設備

pIYBAF9uEOWAZDR_AAGCWbxSXJY608.png

2、ADC驅動
ADC為ZYNQ用來監測電壓或電流的通道,目前ZYNQ中集成了16個通道,首先需要在devicetree中設置啟用的通道,圖中啟用的是0,1,8三個通道

o4YBAF9uEOeAdkVvAACePOBUXc0956.png

內核中啟用ADC驅動

o4YBAF9uEOqALkYuAALM8Wgyf4A920.png


pIYBAF9uEO6AXrTEAAMBiRFhPxo365.png


o4YBAF9uEPGAaSz7AANXI02i7CY601.png

系統啟動后就能看到輸出了,這里輸出的是溫度值

o4YBAF9uEPaAHSDgAAQdG9ZhonQ882.png


pIYBAF9uEPiAd_iDAAGNdVMKyk4343.png

實際溫度還需要進行換算,結果如下

o4YBAF9uEPyAMSGCAANgyEvE1UQ029.png

3、NOR FLASH驅動
NOR FLAHS驅動主要實現文件系統的掛載,這里不需要設置devicetree,只需要在內核中添加掛載文件系統的代碼

pIYBAF9uEP-AAG3pAAH3lfykgbw288.png

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

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

#defineWINDOW_SIZE 0x8000000 //nor flash大小

在makefile中將該驅動編譯進內核即可

o4YBAF9uEQGAOZtOAACRtPBXfVg765.png

啟動后就能看到掛載的文件系統了

pIYBAF9uEQOAGBC4AAG4TWrQZhs322.png

4、外部中斷驅動
當zynq接收來自外部的GPIO中斷時,需要使用UIO機制及時響應中斷,首先在devicetree中模擬出四個GPIO設備

o4YBAF9uEQaADY5IAAJODkPcmHg981.png

注意上面的中斷號0x1e-0x21要與硬件實際相連的中斷管腳一致。

同時在devicetree中啟用UIO機制

o4YBAF9uEQeAHuLQAACje5Q-BBs547.png

在編譯內核時將UIO驅動編譯進內核

pIYBAF9uEQmAXjB-AAESSskar1E386.png

當操作系統啟動完成后就能看到四個外部GPIO設備產生的中斷了

pIYBAF9uEQ6ANu9GAAQIdcAuZOA931.png

八、啟動文件制作
如下圖所示,在SDK中創建boot.bin需要包含下面五個文件

Fsbl.elf

Zynq_top.bin

u-boot.elf

uImage

devicetree.dtb

uramdisk.image.gz

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

pIYBAF9uEROALacYAAS3fSaHpCI455.png


pIYBAF9uERaAU2V8AANG7gbqJ-g675.png


o4YBAF9uERuADv8pAAPaaMcltz0247.png

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


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

    關注

    87

    文章

    11335

    瀏覽量

    210086
  • 操作系統
    +關注

    關注

    37

    文章

    6874

    瀏覽量

    123569
  • Zynq
    +關注

    關注

    10

    文章

    610

    瀏覽量

    47241
收藏 人收藏

    評論

    相關推薦

    deepin操作系統介紹

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

    IP2368寄存器說明文檔

    轉換芯片,轉到 3.3V;? IP2368 INT 應用說明:IP2368 休眠時檢測到 INT 為高就會喚醒,喚醒之后,IP2368 主動拉高 INT,100ms之后,MCU 可進行 I2C 通信,進行寄存器的讀寫操作;IP2368 在進入休眠之前,會切換為輸入高阻來檢
    發表于 12-04 14:30 ?11次下載

    linux是實時系統還是分時操作系統

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

    linux操作系統安裝步驟 linux操作系統的特點及組成

    Linux操作系統安裝步驟 Linux操作系統是一種開源的操作系統,它以其穩定性、安全性和靈活性而聞名。以下是安裝
    的頭像 發表于 10-21 11:24 ?635次閱讀

    請問TAS6424E-Q1和TAS6424-Q1的區別主要有什么 是否有官方的說明文檔

    請問TAS6424E-Q1和TAS6424-Q1的區別是否有官方的說明文檔,除了數據手冊之外,多謝!
    發表于 10-09 10:11

    IP5385應用說明文檔

    IP5385 應用說明文檔
    發表于 10-08 09:25 ?11次下載

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

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

    16306鉦銘科通用協議說明文檔V1.2

    16306鉦銘科通用協議說明文檔V1.2
    發表于 07-09 11:52 ?0次下載

    工業實時操作系統對比:鴻道Intewell跟rt-linux有啥區別

    Intewell和RT-Linux是兩種不同的實時操作系統(RTOS),它們具有各自獨特的特點和優勢。以下是Intewell操作系統的一些關鍵特性,以及與RT-Linux的比較:
    的頭像 發表于 07-03 10:00 ?578次閱讀
    工業實時<b class='flag-5'>操作系統</b>對比:鴻道Intewell跟rt-<b class='flag-5'>linux</b>有啥區別

    AURIX3G可以使用Linux操作系統嗎?

    即使在 AURIX3G 中,也可以使用 Linux 操作系統嗎?
    發表于 05-22 07:12

    芯海應用筆記:CSS34P16P(A)型應用說明文檔

    Type-C 和 USB 供電端口控制解決方案。芯片可根據用戶需求靈活配置,操作簡便, 可快速實現方案功能。*附件:CSS34P16應用說明文檔.pdf
    發表于 05-16 14:46

    探討Linux操作系統的啟動流程

    這個部分比較有意思。因為在BIOS階段,計算機的行為基本上被寫死了,程序員可以做的事情并不多;但是,一旦進入操作系統,程序員幾乎可以定制所有方面。所以,這個部分與程序員的關系更密切。
    發表于 04-09 09:29 ?622次閱讀
    探討<b class='flag-5'>Linux</b><b class='flag-5'>操作系統</b>的啟動流程

    瑞薩CTSU程序在向嵌入式OS操作系統移植時的注意事項

    瑞薩CTSU程序在向嵌入式OS操作系統移植時的注意事項
    的頭像 發表于 03-29 08:05 ?377次閱讀
    瑞薩CTSU程序在向嵌入式OS<b class='flag-5'>操作系統</b><b class='flag-5'>移植</b>時的注意事項

    Linux操作系統上的射頻測試模式應用指南

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

    全國大學生計算機系統能力大賽操作系統設計賽-LoongArch 賽道廣東龍芯2K1000LA 平臺資料分享

    xv6-loongarch。 xv6 是MIT開發的一類Unix教學操作系統,與Linux或BSD不同,xv6非常簡單,足以在一學期內講完,但仍包含Unix的重要概念和組織結構。
    發表于 02-04 15:37
    主站蜘蛛池模板: 精品国产免费观看一区高清| 性欧美精品久久久久久久| 色最快国产| 亚洲地址一地址二地址三| 激情六月丁香| h视频在线免费观看| 日韩插插| 乱人伦精品一区二区| baoyu168成人免费视频| 俺也射| 伊人2233| 亚洲一区二区三区四区在线观看| 亚洲韩国欧美一区二区三区| 成 人 在 线 免费 8888 www| 亚洲精品视频网| 日韩欧美高清一区| 手机在线观看a| 欧美色视频日本片高清在线观看| 狠狠狠狠狠操| 国产在线一卡| 99国产精品农村一级毛片| 手机看片福利盒子久久青| 国产精品资源在线| 日本免费一区视频| 天天色影综合网| 毛色毛片免费观看| 成人99| 欧美精品xxxxbbbb| 国产黄色大片网站| 永久免费的拍拍拍网站| 亚洲国产成人精品青青草原100| 色麒麟影院| 国产一级特黄的片子| 色综合色综合色综合色综合| 日本人69xxⅹ69| 诱人的老师bd高清日本在线观看 | 天天激情| 5g国产精品影院天天5g天天爽| 一个综合色| 美女视频黄a全部| 天天爱天天做天天爽|