# 一、檔案說明

1. original\_code

此次專題希望你只動到 image\_processing 這個 IP,若你不小心改到 其他不該改的 IP,原始 verilog code 都可以在這個資料夾內找到,例 如 VGA\_IP 這個 IP 會用到 vga\_sdk\_ctrl.v 跟 vga\_sdk\_top.v,此兩.v 檔都可以從此資料夾找到,但請自己 package 成 IP 後,在加入 block design (此步驟可參考步驟教學中的步驟 7~步驟 11)。

2. python\_make\_image\_pixel\_data

若想將顯示的圖片換成自己喜歡的圖片,此資料夾內有寫好的 py 檔 幫你將圖片轉成 rgb 共 12bits 的 data,請再自行將 data 寫入 main.c 內的 img 矩陣。

3. vivado\_file

主要 project 用到的檔案都在這

4. SDK\_file

SDK 會用到 main.c 在這

# 二、架構說明

1. 架構圖 (共有 7 個 IP,可想像成 7 個有不同功能的 module)



#### 2. 各 IP 說明

## A. ZYNQ7 Procseeing System

主要是製造 clk·FCLK\_CLK0 為 100 MHz 的 clk·FCLK\_CLK 1 為 25 MHz 的 clk

#### B. AXI Interconnect

讓你寫的軟體(SDK內的c++)跟硬體(你的block design)溝 通

## C. Processor System Reset

製造 reset 訊號給 B, D

D. Bram

存放 SDK 讀進來的 img

E. Image\_processor

主要做影像處理的地方就在這,請修改此 IP 的 code 完成你的影

像處理,做好的 pixel 的 data 要 output 到下一個 IP

(memory\_for\_processor), 存放你影像處理後的圖片。

F. Memory\_for\_processing

存放你影像處理後的圖片

G. VGA\_TOP

負責讓圖片顯示在 VGA 的 IP

3. 注意事項

因硬體限制,目前的設計為 400x300,若沒有要修改解析度,請不要

自行修改除了 E (image\_processor) 以外的 IP!

若有需要修改解析度,請找我 (只能變小不能變大)

# 三、步驟教學

1. 打開 project\_for\_zhuanti\vivado\_file\project\_1 內的 project\_1.xpr



2. 點選 Open Block Design,即可看到 IP 架構圖



4. 開始改 code,對著 image\_processor 按右鍵,選擇 Edit in IP

Packager 後按 OK OK ,按完後會自動另開一個 vivado,讓你可以獨立修改



5. 打開 image\_processor IP packager 後,點兩下 Design Sources 內的 image\_processor.v



6. 點開 image\_processor.v 便可打開程式碼,開始設計你的影像處理!!



7. 改完 code 後,須將 image\_processor 這個 IP 重新包裝,儲存好.v 檔

後點選左上角 PROJECT MANAGEMENT 內的 Package IP



8. 點選非綠勾勾的選項,並點選 Merge changes.....Wizard



9. 一直弄到所有綠勾勾都消失,即表示完成修改,驚嘆號不用管他,最後點選 Re-Package IP 即完成 IP 的包裝,此時會問你要不要關掉視窗,自

#### 行決定



10. 回到我們的 project\_1, 因為你有修改 code, 他會跟你說你的 IP 過期

## 了,點選 Refresh IP Catalog



11. 點選畫面下方的 Upgrade Selected, 然後 OK, 然後 Skip



12.點選左側的 Generate Bitstream,此時會開始製作位元流,後續會將
Bitstream 燒上板子,讓板子開始有作用,由於做 Bitstream 前需要先
將你的 block design 做合成電路的動作,直接點 Generate Bitstream
會自動先做好 Synthesis 跟 Implementation,算是偷懶的小撇步。

Note: 此步驟會跑比較久, 跑完後會跳出小視窗, 按 cancel 就好



13. 腳位 (若有需要改),選取左側 Open Synthesized Design,開起後點 選上方 Layout 中的 I/O Planning 設定板子的腳位



完成 pin 腳設定後按 Ctrl+S 儲存,如下圖所示,注意因為使用板子是ZedBoard,I/O Std 都要改為 LCVMOS33 才可以正常運作。



完成 pin 腳設定後按 Ctrl+S 儲存,如下圖所示,注意因為使用板子是ZedBoard,I/O Std 都要改為 LCVMOS33 才可以正常運作。



按下 OK 後會跳出如下的視窗,打上檔名後按下 OK,即可在 Project

Manager 的 Constraints 中看到我們創立的檔案。點開可看到裡面儲存

的即是剛才 I/O Planning 時所設定個個 ports 對應板子 pin 腳的資訊



## 14.點選 Export Hardware,



## 15. 將 Include bitstream 勾起來並按 OK



16.接著就是打開 SDK



17. 創立— Application Project



### 若發現沒有 Application project 這個選項,請將

vivado\_file/project\_1/project\_1.sdk 這個資料夾刪掉並重新 launch

#### SDK (步驟 15)



18. Project name 隨意取,其他欄位照圖上選,確認都一樣後點選 Next



## 19.選擇 Empty Application 後點選 Finish



20.將 SDK\_file 資料夾下的 main.c 拖曳到 src 目錄底下後點選 copy file



21.點選 main.c 即可打開程式碼,但可能會跳出這個視窗,按 No 就好



## 22. 對著蟲蟲按右鍵,選 Debug Configuraions



#### 23. 左側最下面選項點兩項可跳出以下視窗,將內容改成如下圖



24. Application 這邊也要改,勾選 ps7\_cortexa9\_0 後按 Apply,再按

## debug 後按 yes,此時 SDK 即開始將電路燒上 Zedboard



25. 先點選這個 resume 按鈕,再將 rst 設為 1(指撥開關撥到 1)做重置動作,再將 rst 撥回 0,即可看到你的圖片,大功告成!!!(如果你設計沒問題的話··)





# 五、可能遇到的問題:

# 1. SDK 打不開:

把 project\_for\_zhuanti\vivado\_file\project\_1\project\_1.sdk 目錄下

的.metadata 資料夾刪除,即可解決問題。

| .metadata                      | 2021/4/20 下午 09:55 | 檔案資料夾  |        |
|--------------------------------|--------------------|--------|--------|
| .sdk                           | 2021/4/20 下午 09:56 | 檔案資料夾  |        |
| design_1_wrapper_hw_platform_0 | 2021/4/21 上午 11:12 | 檔案資料夾  |        |
| Remote Systems Temp Files      | 2021/4/20 下午 09:55 | 檔案資料夾  |        |
| ☐ VGA                          | 2021/4/20 下午 09:56 | 檔案資料夾  |        |
| VGA_bsp                        | 2021/4/21 上午 11:12 | 檔案資料夾  |        |
| design_1_wrapper.hdf           | 2021/4/23 下午 03:49 | HDF 檔案 | 460 KB |
| SDK                            | 2021/4/21 下午 02:08 | 文字文件   | 47 KB  |