資料介紹
描述
本教程展示了如何為 Minized 創建 PYNQ,它使用帶有額外存儲選項的 EMMC 內存作為 PMOD sdcard。
準備環境
首先,我們需要使用這些腳本從 Avnet GitHub 克隆存儲庫,我們將構建我們的項目和 BSP。
mkdir Avnet;
cd Avnet;
git clone https://github.com/Avnet/bdf.git --branch master;
git clone https://github.com/Avnet/hdl.git --branch 2019.1;
git clone https://github.com/Avnet/petalinux.git --branch 2019.1;
git clone https://github.com/Xilinx/PYNQ.git --branch image_v2.5.4;
wget http://downloads.element14.com/downloads/zedboard/minized/minized_ttc_2019_1.bsp.zip?ICID=minized-datasheet-widget;
unzip minized_ttc_2019_1.bsp.zip?ICID=minized-datasheet-widget;
轉到 petalinux → 腳本并編輯“make_minized_qspi_minimal_bsp.sh”
cd petalinux/scripts;
gedit make_minized_qspi_minimal_bsp.sh;
更改 Vivado 和 Petalinux 安裝路徑
運行腳本并等待它完成。
./make_minized_qspi_minimal_bsp.sh
同時,我們將基于“minized_ttc_2019.1.bsp”創建項目
打開新終端和源 petalinux settings.sh
source /home/bartek/petalinux20191/settings.sh
并創建項目
petalinux-create -t project -s minized_ttc_2019_1.bsp
打開新創建的項目。
cd minized_ttc_2019_1
在里面您可以看到“硬件”文件夾,其中包含用于構建該 BSP 的硬件設計。
我們將需要修改用于該項目的設備樹,否則 Petalinux 將無法在 FPGA 管理器打開的情況下構建。
轉到項目規范→元用戶→食譜-bsp→設備樹→文件并編輯“system-user.dtsi”
cd project-spec/meta-user/recipes-bsp/device-tree;
gedit system-user.dtsi
我們可以安全地刪除引用 Wi-Fi 模塊和加速度計的節點。
我以前嘗試過,重新編程 FPGA 會導致 Wi-Fi 驅動程序崩潰,這就是我刪除它的原因,如果你離開加速度計節點,petalinux 構建也會失敗。
/include/ "system-conf.dtsi"
/ {
aliases {
serial0 = &uart1;
serial1 = &uart0;
};
};
&flash0 {
compatible = "micron,n25q128", "jedec,spi-nor";
};
/{
usb_phy0: usb_phy@0 {
compatible = "ulpi-phy";
#phy-cells = <0>;
reg = <0xe0002000 0x1000>;
view-port = <0x0170>;
drv-vbus;
};
};
&usb0 {
dr_mode = "otg";
usb-phy = <&usb_phy0>;
} ;
/* QSPI addresses are defined with petalinux-config, but here they are overwritten so that one can program the flash internally */
&qspi {
#address-cells = <1>;
#size-cells = <0>;
flash0: flash@0 {
compatible = "micron,m25p80";
reg = <0x0>;
#address-cells = <1>;
#size-cells = <1>;
spi-max-frequency = <50000000>;
partition@0x00000000 {
label = "boot";
reg = <0x00000000 0x00ff0000>;
};
};
};
/* PMOD SD Interface */
&sdhci0 {
status = "okay";
bus-width= <4>;
xlnx,has-cd = <0x0>;
xlnx,has-power = <0x0>;
xlnx,has-wp = <0x0>;
/* cd-inverted; */
wp-inverted;
mmccardpmod: mmccardpmod@1 {
/* reg = <0>; */
compatible = "mmc-card";
};
};
/* SD Interface for eMMC */
&sdhci1 {
status = "okay";
non-removeable;
bus-width= <4>;
xlnx,has-cd = <0x0>;
xlnx,has-power = <0x0>;
xlnx,has-wp = <0x0>;
mmccard: mmccard@0 {
reg = <0>;
compatible = "mmc-card";
broken-hpi;
};
};
/* Console UART. UART1 is tied to the USB serial port on the Zedboard */
&uart1 {
status = "okay";
current-speed = <115200>;
port-number = <0>;
};
/ {
};
PYNQ 設置
打開 PYNQ → sdbuild → 腳本并運行“setup_host.sh”腳本(如果你之前沒有)。
cd PYNQ/sdbuild/scripts;
bash setup_host.sh
現在我們需要修改 PYNQ 的引導設置。
打開 PYNQ → sdbuild → boot → meta-pynq → recipes-bsp → device-tree 并編輯“pynq_bootargs.dtsi”
cd PYNQ/sdbuild/boot/meta-pynq/recipes-bsp/device-tree;
gedit pynq_bootargs.dtsi
將“/dev/mmcblk0p2”更改為“/dev/mmcblk1p2”
此外,您將需要為 arm 架構預構建的 rootfs映像。請參閱 PYNQ 快速移植指南。
下載它。
轉到 PYNQ → sdbuild 并輸入:
make BOARDS=Pynq-Z1
查看 PYNQ 是否設置正確。
修改最小化最小
我們在開始時為 Minized QSPI 運行的腳本現在應該完成了。
打開 petalinux → 項目 → minized_qspi_minimal_2019_1 并添加實用程序包以格式化內存(可選)。
cd petalinux/projects/minized_qspi_minimal_2019_1;
petalinux-config -c rootfs
啟用“e2fsprogs”、“e2fsprogs-resize2fs”、“e2fsprogs-e2fsck”包。
您可以在 petalinux 窗口中使用“/”搜索軟件包。
退出并重建項目
petalinux-build
現在我們將通過 JTAG 啟動我們的系統。
petalinux-boot --jtag --fpga --kernel --verbose;
登錄到 Minized,例如使用 cutecom 或 putty。
格式化 EMMC
現在我們將格式化 EMMC。(可選,稍后我們可以使用“dd”將圖像寫入EMMC)
使用“df -h”命令列出所有已安裝的驅動器及其位置
df -h
或“fdisk -l”
fdisk -l
EMMC 是“/dev/mmcblk1”
我們需要創建兩個分區。一個用于“image.ub”,第二個用于“rootfs”
第一個分區需要是 FAT32,第二個分區需要是 ext4。
打開 mmcblk1。
fdisk /dev/mmcblk1
使用 fdisk 刪除分區并寫入更改。
d
1
d
2
w
現在我們需要創建新分區(您可以使用“format_emmc.sh”腳本作為參考,它位于本地/bin 中)。
fdisk /dev/mmcblk1
o
n
p
1
enter (default command)
+255M
w
現在我們有了第一個分區,例如 255Mb。
fdisk /dev/mmcblk1
n
p
2
enter (default command)
enter (default command)
w
制作第一個分區 w95 fat32
fdisk /dev/mmcblk1
t
1
b
w
或使用 mkfs 將 mmblk1p1 格式化為 fat32
mkfs.vfat -F 32 -n boot /dev/mmcblk1p1
將 mmblk1p2 格式化為 ext4
mkfs.ext4 -L root /dev/mmcblk1p2
現在您的 EMMC 已準備好作為存儲介質。
創建基礎項目
打開 hdl → 項目 → minized_petalinux →MINIZED_2019_1
打開塊設計并刪除未使用的 IP(您可以將 SD 卡管理器連接到 SDIO_0 端口以獲得額外存儲)。
生成新的雙流并從項目中導出 HDF。
創建 PYNQ 映像
轉到 minized_ttc_2019_1 項目并更改引用的 HDF 和圖像打包配置。
cd minized_ttc_2019_1;
petalinux-config --get-hw-description=/home/bartek/Desktop/Minized_EMMC/Avnet;
構建項目并打包新的 BSP。
petalinux-build;
petalinux-package --bsp --p ${PWD} --hwsource /home/bartek/Desktop/Minized_EMMC/Avnet/hdl/Projects/minized_petalinux/MINIZED_2019_1 -o MinizedEMMCPynq;
使用先前下載的“bionic.arm.2.5.img”將創建的 BSP 復制到 PYNQ → sdbuild
并創建 PYNQ 鏡像
cd PYNQ/sdbuild;
bash scripts/image_from_prebuilt.sh MinizedEMMCPynq MinizedEMMCPynq.bsp arm bionic.arm.2.5.img;
最好為 Minized 創建自定義圖像。我們需要對 PYNQ 板項目進行一些修改。(準備好的包在附件 MinizedPynq.7z 中)將其提取到某個地方,例如“ PYNQ/zz ”<-這是我們的板存儲庫。
我已經修改了 petalinux_bsp → meta-user → ... → user_2018-06-26-17-14-00.cfg
并為某些 USB Wi-Fi 模塊啟用內核驅動程序。
在打包 BSP 之前,您可以通過“ petalinux-config -c kernel ”來執行此操作。
cd PYNQ/sdbuild;
make PREBUILT=/home/bartek/PYNQ/sdbuild/bionic.arm.2.5.img BOARDDIR=/home/bartek/PYNQ/zz BOARD=Minizedzik
如果它不起作用,請嘗試添加 PYNQ_SDIST:
make PYNQ_SDIST=/home/bartek/Downloads/pynq-2.5.tar.gz PREBUILT=/home/bartek/PYNQ/sdbuild/bionic.arm.2.5.img BOARDDIR=/home/bartek/PYNQ/zz BOARD=Minizedzik
縮小的圖像應該在輸出文件夾中。
恢復 USB 驅動器上的磁盤映像。
并將 partition2 的大小調整為小于 EMMC 減去 partition1 的大小(例如 7Gb)并檢查錯誤。
將 USB 驅動器連接到 Minized。
使用“dd”命令將圖像寫入 EMMC(這需要一段時間)。
dd if=/dev/sda of=/dev/mmcblk1
如果您希望檢查錯誤。
e2fsck /dev/mmcblk1p1
e2fsck /dev/mmcblk1p2
使用“minized_ttc_2019_1”BOOT.bin 最小化的程序
petalinux-build;
petalinux-package --boot --fpga --u-boot -o BOOT.bin --force;
program_flash -f ./BOOT.bin -offset 0 -flash_type qspi_single -fsbl ./images/linux/zynq_fsbl.elf;
Minized 將使用 QSPI 內存來加載 BOOT.bin。
ZYNQ 將使用該 BOOT.bin 來加載 FSBL 為 FPGA 進行 Minized 編程,然后加載 u-boot 以在“/dev/mmcblk1p1”分區上搜索 image.ub。Image.ub 將等到“/dev/mmcblk1p2”被掛載并加載rootfs。
現在 Minized 應該使用 PYNQ 系統啟動。
現在讓我們掛載 pmod sdcard 并編寫一些東西來測試功能。
mkdir mnt;
ls -l /dev | grep mmc;
sudo mount /dev/mmcblk0p2 mnt;
打開 mnt 文件夾并創建.txt 文件。
cd mnt;
sudo nano TestWrite.txt;
退出并保存,umount sdcard。
cd ..;
sudo umount mnt;
讓我們檢查一下 sdcard 上的內容。
創建疊加層
我已將此項目升級為 Vivado 2020.1 版本。
打開 Vitis HLS 并為 xc7z007 芯片創建新的空項目。
單擊源→新文件
?
創建附加 IP 核
轉到項目設置→綜合并在“頂級功能”中鍵入“添加”
單擊確定并運行綜合。
將我們的 IP 導出到本地 IP 存儲庫。
提取“add.zip”
打開 Vivado 并將新 IP 添加到項目并將其連接到 AXI 互連。
?
保存項目并導出比特流。
打開 Vivado 項目并搜索bistream和.hwh文件。
?
?
復制并重命名這些文件。
?
將它們上傳到 Minized,但首先我們需要 Wi-Fi。
啟動 Minized 并連接到它,例如使用 putty。
?
如您所見,Minized 檢測到了我們的無線適配器
sudo nano /etc/wpa_supplicant/wpa_supplicant.conf
?
sudo wpa_supplicant -c /etc/wpa_supplicant/wpa_supplicant.conf -i wlan0 -B
sudo dhclient wlan0
打開互聯網瀏覽器并連接到 Minized(密碼是 xilinx)
http://192.168.0.105:9090/tree?
通過 jupyter notebook 上傳文件。
?
結束
現在您已準備好基于這三個項目開發自己的 IOT 應用程序。
讓您的 Minized 工作并分享您的工作 :)
- 使用Tensil和PYNQ在PYNQ Z1 FPGA板上運行機器學習
- 基于Pynq的汽車儀表板
- 如何為Minized創建可工作的PYNQ系統
- MiniZed和Mighty機器人
- 用于MiniZed的7段LED顯示硬件和VHDL模塊
- 如何為探測器構建活動創建探測器
- 使用Ultra96 PYNQ測定織物GSM
- 如何為LCD1602顯示器創建自定義字符
- 如何創建和使用LabVIEW中的LLB文件 0次下載
- 如何為混合動力汽車/電動汽車設計加熱和冷卻系統 23次下載
- 何為NFC?資料下載
- Visual C++和MFC創建的應用程序基礎知識 0次下載
- allegro與PADS的區別及創建PCB封裝的步驟 67次下載
- PYNQ的常見問題
- AN1246中文手冊之如何在Microchip圖形庫中創建控件
- 使用PYNQ訓練和實現BNN 592次閱讀
- Java反射技術實現對象的創建 2336次閱讀
- 如何為ATE應用創建具有拉電流和灌電流功能的雙輸出電壓軌 836次閱讀
- 創建STM32工程模板 1296次閱讀
- 如何創建 Docker 鏡像的能力 1147次閱讀
- 如何為MSP430設計固件以收集和處理IC的數據 2159次閱讀
- 如何為制造和組裝做好最好的PCB設計準備 1671次閱讀
- ADI公司:加速邁向工業4.0 1119次閱讀
- 米爾PYNQ開發板來了 964次閱讀
- digilent支持Python編程的Zynq開發板介紹 3577次閱讀
- Avnet MiniZed單核Zynq 7Z007S入門開發方案 5344次閱讀
- PYNQ中MicroBlaze程序文件的加載過程 2271次閱讀
- PYNQ 基于Zynq架構添加了對python的支持 8860次閱讀
- 一文詳解Avnet Zynq 7Z007SMiniZed開發方案 9892次閱讀
- 低成本 MiniZed Zynq SoC 開發板 7449次閱讀
下載排行
本周
- 1山景DSP芯片AP8248A2數據手冊
- 1.06 MB | 532次下載 | 免費
- 2RK3399完整板原理圖(支持平板,盒子VR)
- 3.28 MB | 339次下載 | 免費
- 3TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 4DFM軟件使用教程
- 0.84 MB | 295次下載 | 免費
- 5元宇宙深度解析—未來的未來-風口還是泡沫
- 6.40 MB | 227次下載 | 免費
- 6迪文DGUS開發指南
- 31.67 MB | 194次下載 | 免費
- 7元宇宙底層硬件系列報告
- 13.42 MB | 182次下載 | 免費
- 8FP5207XR-G1中文應用手冊
- 1.09 MB | 178次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應用800例(新編版)
- 0.00 MB | 33566次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關電源設計實例指南
- 未知 | 21549次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數字電路基礎pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅動電路設計》 溫德爾著
- 0.00 MB | 6656次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537798次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420027次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191187次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183279次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論
查看更多