Xilinx zynq-7000系列FPGA移植Linux操作系統詳細教程

?

Xilinx zynq-7000系列FPGA移植Linux操作系統詳細教程

一:前言

最近手上壓了一塊米聯客的Miz7035,一塊xilinx zynq-7000系列的開發板,想著正好學習一下linux在ARM9上的移植,網上基本都是ZC702、zed的教程,這對于買了非標準板的人來說就不太友好,很多文件都不知道是怎么生成的。本著學習加分享的心態,把這兩天移植linux的過程寫下來,盡可能詳細。驅動和系統移植不是我的專長,很多地方我也是知其然不知其所以然,寫得不對的地方歡迎指正。

二:前期準備?

1、一臺安裝好linux系統的主機,我安裝的是centos7.2.

2、一塊zynq-7000系列的FPGA開發板,我手上的是米聯客miz7035,其他zynq系列一樣通用。

3、vivado開發環境,我安裝的2018.2版本

4、u-boot,device-tree,kernel下載。地址分別是:https://github.com/Xilinx/u-boot-xlnx (u-boot)、https://github.com/Xilinx/linux-xlnx(kernel)、https://github.com/Xilinx/device-tree-xlnx(device-tree)。

5、根文件系統,這里我裂墻推薦Debian,Debian這個Linux系統,底層非常穩定,內核和內存的占用都非常小,下載地址:https://pan.baidu.com/s/1eHmjGd-dTtgnITjG2D3CYA

三:操作步驟

1.設置交叉編譯環境

因為最終運行在arm9上,所以uboot、內核,文件系統編譯都需要用arm-linux交叉編譯工具,zynq2000使用的是arm-linux-gnueabihf,交叉編譯工具可以從網上單獨下載,也可直接使用vivado自帶的交叉編譯工具。使用方法也很簡單

source /opt/Xilinx/SDK/2018.2/settings64.sh

或者

gedit /opt/Xilinx/SDK/2018.2/.settings64-SDK_Core_Tools.sh

將該文件中的內容全部復制到bashrc,更新環境變量,這樣在新的終端中打開,環境變量也不會消失。

?

2.u-boot編譯

進入u-boot文件夾,

make distclean  //清除配置文件和編譯中間結果
make CROSS_COMPILE=arm-linux-gnueabihf- zynq_mz7x_defconfig //重新配置,生成makefile,具體板子不一樣,在U-Boot/configs文件夾下
make CROSS_COMPILE=arm-linux-gnueabihf- tools  //編譯開發所需要的工具
make CROSS_COMPILE=arm-linux-gnueabihf-  //編譯,完成后生成一個elf文件u-boot,uboot.bin,u-boot.srec等文件

最后把編譯生成的u-boot后綴改成.elf,連同u-boot.img和spl/boot.bin,一共三個文件拷貝出來。

?

3.kernel內核編譯

export PATH=${YOUR_UBOOT_DIR}/tools:$PATH  //編譯內核如果要生成uImage,則需要用到mkimage工具,該工具在u-boot/tools下有提供
make distclean //清除配置文件和編譯中間結果
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- xilinx_mz7x_defconfig  //重新配置,生成makefile 
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- prepare scripts  //編譯開發所需要的工具
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- UIMAGE_LOADADDR=0x8000 uImage  //編譯內核,且生成uImage

?最后把{KERNEL_DIR}/arch/arm/boot/zImage,{KERNEL_DIR}/arch/arm/boot/uImage拷貝出來。

??? # zImage? - compressed kernel image
??? # uImage? - zImage plus U-Boot header
uImage是在zImage之前加上一個長度為0x40的“頭”,說明這個映像文件的類型、加載位置、生成時間、大小等信息。換句話說,如果直接從uImage的0x40位置開始執行,zImage和uImage沒有任何區別。

?

4、設備樹編譯

?經過內核編譯,在kernel文件夾下script/dtc中有編譯好的設備樹編譯工具

cd kernel/scripts/dtc
./dtc -I dts -O dtb -o devicetree.dtb /FPGA工程目錄/SDK目錄/device_tree_bsp_0/system-top.dts //dts為sdx工程中生成,編譯后在當前目錄下生成一個名為devicetree.dtb)。

?

5. 編譯并安裝內核模塊,更新文件系統

本文提供的rootfs是已經編譯好的,如果想要重新編譯或者更新文件系統,可以下載后解壓,然后執行以下步驟

cd your_downlood_kernel_dir //打開編譯好的內核文件夾
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- modules //編譯內核模塊,
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- modules_install INSTALL_MOD_PATH=../rootfs  // 在上一步打開的終端中,重新安裝內核模塊,安裝路徑為解壓出來的rootfs路徑
tar -cvzf rootfs.tar.gz rootfs。//將安裝好內核模塊的根文件系統重新壓縮

?

6.生成啟動鏡像文件

制作啟動鏡像需要用到三個文件:fsbl.elf、system.bit和第二步生成的u-boot.elf。

打開SDK工具,生成fsbl的方法網上很多,自己查閱,不贅述了,這里只介紹如何制作boot image

在fsbl工程目錄上右鍵選擇Create Boot Image

加入u-boot.elf的路徑,然后Create Image,就會在指定的輸出路徑上生成BOOT.bin

?

7.設置UBOOT環境變量

新建一個uEnv.txt,輸入內容:

optargs=console=tty0 consoleblank=0 vt.global_cursor_default=0

這部分不是很懂,有清楚的請留言。

?

8.制作SD卡

找一張SD卡,通過系統自帶的磁盤工具,首先格式化。然后創建兩個分區,一個100M FAT格式,命名為UBOOT,剩余的8G ext4格式,命名為rootfs。如圖所示:

將步驟6、7、4、3生成的BOOT.bin、uEnv.txt、devicetree.dtb、uImage拷貝到UBOOT分區下

將步驟5生成的rootfs.tar.gz解壓到rootfs分區下。

?

四:實驗結果

?

五、結束語

至此,debian在zynq上的移植全部結束,之后,我將分享如何在linux基礎上開發字符驅動,以及如何運行QT程序,并通過一個攝像頭采集的例子作為具體應用。

?

?

?

?

轉載于:https://www.cnblogs.com/yuzeren48/p/10282478.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/450065.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/450065.shtml
英文地址,請注明出處:http://en.pswp.cn/news/450065.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

程序員的創業困境 誰來幫助出出主意?

【編者按】有人說,程序員是吃青春飯的,到一定年齡就得考慮轉行,也有人選擇自己創業。而當創業使你偏離了之前持續學習專業知識的軌道時,你會選擇在創業路上繼續堅持還是回歸自己的老本行?編程編了十幾年的Dan McComas半…

節選—Android 視頻直播 ( 從快播到直播,從高清到無碼 )十年視頻開發項目

本文轉載自Android 視頻直播 ( 從快播到直播,從高清到無碼 )十年視頻開發項目,截取其中技術概念比較相關的部分,并做了重新的排版。 視頻和直播的準備: android-java層:camera相關(視頻&#x…

getDeclaredMethod和getMethod的區別

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 getDeclaredMethod*()獲取的是類自身聲明的所有方法,包含public、protected和private方法。getMethod*()獲取的是類的所有共有…

12.5PMP試題每日一題

在什么情況下項目正式受控于實施整體變更控制過程:A、從項目啟動到收尾的所有過程B、只有當項目基準建立之后C、在項目基準建立之前D、只要有人提起變更請求的時候 作者:Tracy19890201(同微信號) 答案將于明天和新題一起揭曉&…

在線預覽word,excel文檔

Google Doc 示例:https://jsfiddle.net/7xr419yb/ Microsoft Office 示例:https://jsfiddle.net/gcuzq343/轉載于:https://www.cnblogs.com/alexguoyihao/p/10314626.html

如何遷移整個git倉庫

轉自準備更換git托管,如何遷移原git倉庫一個回答 如果你想從別的 Git 托管服務那里復制一份源代碼到新的 Git 托管服務器上的話,可以通過以下步驟來操作。 從原地址克隆一份裸版本庫,比如原本托管于 GitHub。 git clone –bare git://githu…

關于創業:希望有人在N年前就告訴我的一些事兒

【編者按】原文作者為前微軟員工、創業家Amir Khella,他離開微軟后開始自主創業,并成功創辦了多家公司。他經常在博客中分享自己的創業故事和經驗。以下是其中一篇博文,他認為創業者想要成功,首先需要找到自己的方向,再…

Rust核心團隊前成員Brian Anderson加入PingCAP

昨天,國內新型分布式數據庫公司PingCAP聯合創始人兼CEO劉奇在朋友圈宣布,Rust核心團隊前成員Brian Anderson將加入公司。PingCAP聯合創始人兼CTO黃東旭進一步向InfoQ記者證實了此消息,并透露Brian將從事TiKV相關的工作,從存儲引擎…

JeeSite 是什么、概述

見JeeSite官網:http://jeesite4.mydoc.io/ 前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 總體概述 快速訪問 JeeSite 官網地址:http://jeesite.comJeeSite 在…

單機單網卡最大tcp長連接數真的是65535嗎?

很早微博上一直討論比較多的問題,這里轉載個知乎的答案:單機單網卡最大tcp長連接數真的是65535嗎? 作者:許懷遠 鏈接:https://www.zhihu.com/question/66553828/answer/244313925 來源:知乎 著作權歸作者…

觀察者模式-Observer Pattern

1.主要優點 觀察者模式的主要優點如下: (1) 觀察者模式可以實現表示層和數據邏輯層的分離,定義了穩定的消息更新傳遞機制,并抽象了更新接口,使得可以有各種各樣不同的表示層充當具體觀察者角色。 (2) 觀察者模式在觀察目標和觀察者…

賭還是不賭 你應該辭職去創業嗎?

【編者按】本文的作者是Amir Khella,他是一位著名的用戶體驗設計師,也是創業顧問和企業家。在過去的三年里,他成功的打造了十幾家公司,其中不少還被大企所收購,比如說Google收購了他的DocVerse,LimeLight N…

Python 深淺copy 和文件操作

深淺copy 1,先看賦值運算。 l1 [1,2,3,[barry,alex]] l2 l1l1[0] 111 print(l1) # [111, 2, 3, [barry, alex]] print(l2) # [111, 2, 3, [barry, alex]]l1[3][0] wusir print(l1) # [111, 2, 3, [wusir, alex]] print(l2) # [111, 2, 3, [wusir, alex]] 對…

這樣安靜下去...

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 我從來就不想要整個世界,我只想這樣安靜下去 ... 放肆我所有癡狂的心愿,無怨無悔 ... 縱我一執燃燒后成灰的稻草…

C# 實現生成帶二維碼的專屬微信公眾號推廣海報

原文:C# 實現生成帶二維碼的專屬微信公眾號推廣海報很多微信公眾號中需要生成推廣海報的功能,粉絲獲得專屬海報后可以分享到朋友圈或發給朋友,為公眾號代言邀請好友即可獲取獎勵的。海報自帶渠道二維碼,粉絲長按二維碼即可關注微信公眾號&…

Android應用開發—PendingIntent:如何判斷兩個PendingIntent對等

摘錄自:PendingIntent詳解 如何判斷兩個PendingIntent對等: 兩個PendingIntent對等是指它們的operation一樣, 且其它們的Intent的action, data, categories, components和flags都一樣。但是它們的Intent的Extra可以不一樣。 主要常量 FLAG_CANCEL_CUR…

最新研究顯示人類智力逐漸下降且變得更愚蠢

請大家去測試智力,看看是否正常水平?真的,智力在下降,在網絡、電子設備和化肥、農藥,轉基因等因素下,人越來越差了。 保存到相冊研究人員稱現代人類將逐漸智力下降,這是因為我們不再需要智力來維…

缺陷的背后---LIMIT M,N 分頁查找

一、問題發現篇 最近組內做了一次典型缺陷分享時,翻閱2018年的缺陷,找到了一個讓我覺得“有料”的bug(別的同事測試發現的),先大致簡單的描述下這個問題: 需要實現的功能:從一個DB庫同步某一段時…

Android應用開發—Intent組件詳解

轉載自:Android中Intent組件詳解 Intent是不同組件之間相互通訊的紐帶,封裝了不同組件之間通訊的條件。 Intent本身是定義為一個類別(Class),一個Intent對象表達一個目的(Goal)或期望(Expectation),敘述其所期望的服務或動作、與…

angularjs 結構的兩種寫法(2)

app.js里面 route.js 本項目中的路由寫法,路由的意思是:對應的跳轉頁面路徑,比如此處當路由是member.user-statisttic時,是會跳轉到url:http://.../user-statisttic.html頁面,然后此頁面對應的ctrl會解析也頁面的參數。…