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

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

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

【ZYNQ Ultrascale+ MPSOC FPGA教程】第三十章自定義IP實(shí)驗(yàn)

FPGA技術(shù)專欄 ? 來(lái)源:芯驛電子科技 ? 作者:芯驛電子科技 ? 2021-02-01 10:13 ? 次閱讀

原創(chuàng)聲明:

本原創(chuàng)教程由芯驛電子科技(上海)有限公司(ALINX)創(chuàng)作,版權(quán)歸本公司所有,如需轉(zhuǎn)載,需授權(quán)并注明出處。

適用于板卡型號(hào):

AXU2CGA/AXU2CGB/AXU3EG/AXU4EV-E/AXU4EV-P/AXU5EV-E/AXU5EV-P /AXU9EG/AXU15EG

實(shí)驗(yàn)Vivado工程目錄為“custom_pwm_ip /vivado”。

實(shí)驗(yàn)vitis工程目錄為“custom_pwm_ip /vitis”。

Xilinx官方為大家提供了很多IP核,在Vivado的IP Catalog中可以查看這些IP核,用戶在構(gòu)建自己的系統(tǒng)中,不可能只使用Xilinx官方的免費(fèi)IP核,很多時(shí)候需要?jiǎng)?chuàng)建屬于自己的用戶IP核,創(chuàng)建自己的IP核有很多好處,例如系統(tǒng)設(shè)計(jì)定制化;設(shè)計(jì)復(fù)用,可以在在IP核中加入license, 有償提供給別人使用;簡(jiǎn)化系統(tǒng)設(shè)計(jì)和縮短設(shè)計(jì)時(shí)間。用ZYNQ系統(tǒng)設(shè)計(jì)IP核,最常用的就是使用AXI總線將PS同PL部分的IP核連接起來(lái)。本實(shí)驗(yàn)將為大家介紹如何在Vivado中構(gòu)建AXI總線類型的IP核,此IP核用來(lái)產(chǎn)生一個(gè)PWM,用這個(gè)控制開(kāi)發(fā)板上的LED,做一個(gè)呼吸燈的效果。

FPGA工程師工作內(nèi)容

以下為FPGA工程師負(fù)責(zé)內(nèi)容。

1. PWM介紹

我們經(jīng)常使用PWM來(lái)控制LED,蜂鳴器等,通過(guò)調(diào)節(jié)脈沖的占空比來(lái)調(diào)節(jié)LED的亮度。

在其他開(kāi)發(fā)板中我們使用過(guò)的一個(gè)pwm模塊如下:

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////Copyright(c)2017,ALINX(shanghai)TechnologyCo.,Ltd////Allrightsreserved////////Thissourcefilemaybeusedanddistributedwithoutrestrictionprovided////thatthiscopyrightstatementisnotremovedfromthefileandthatany////derivativeworkcontainstheoriginalcopyrightnoticeandtheassociated////disclaimer.//////////////////////////////////////////////////////////////////////////////////////////================================================================================//Description:pwmmodel//pwmoutperiod=frequency(pwm_out)*(2**N)/frequency(clk);////================================================================================//RevisionHistory://DateByRevisionChangeDescription//--------------------------------------------------------------------------------//2017/5/3meisq1.0Original//********************************************************************************/`timescale1ns/1psmoduleax_pwm#(
	parameterN=32//pwmbitwidth
)(inputclk,inputrst,input[N-1:0]period,input[N-1:0]duty,outputpwm_out);reg[N-1:0]period_r;reg[N-1:0]duty_r;reg[N-1:0]period_cnt;regpwm_r;assignpwm_out=pwm_r;always@(posedgeclkorposedgerst)beginif(rst==1)begin
period_r<={?N?{1'b0}};
????????duty_r?<={?N?{1'b0}};endelsebegin
????????period_r?<=?period;
????????duty_r???<=?duty;endendalways@(posedge?clk?orposedge?rst)beginif(rst==1)
????????period_cnt?<={?N?{1'b0}};else
????????period_cnt?<=?period_cnt?+?period_r;endalways@(posedge?clk?orposedge?rst)beginif(rst==1)begin
????????pwm_r?<=1'b0;endelsebeginif(period_cnt?>=duty_r)
pwm_r<=1'b1;else
????????????pwm_r?<=1'b0;endendendmodule

可以看到這個(gè)PWM模塊需要2個(gè)參數(shù)“period”、“duty”來(lái)控制頻率和占空比,”period”為步進(jìn)值,也就是計(jì)數(shù)器每個(gè)周期要加的值。Duty為占空比的值。我們需要設(shè)計(jì)一些寄存器來(lái)控制這些參數(shù),這里需要使用AXI總線,PS通過(guò)AXI總線來(lái)讀寫寄存器。

o4YBAGAKNOWAMIpZAAAi-fLhhz8189.jpg

2. Vivado工程建立

用”ps_hello”工程另存為一個(gè)名為“custom_pwm_ip”工程

2.1 創(chuàng)建自定義IP

1)點(diǎn)擊菜單“Tools->Create and Package IP...”

pIYBAGAKNOWAYRWiAABIfv9cBdQ374.jpg

2)選擇“Next”

o4YBAGAKNOaAd6lfAAB2EXt0RTg212.jpg

3)選擇創(chuàng)建一個(gè)新的AXI4設(shè)備

pIYBAGAKNOeAUu1-AAB6oP_Qa0A344.jpg

4)名稱填寫“ax_pwm”,描述填寫“alinx pwm”,然后選擇一個(gè)合適的位置用來(lái)放IP

o4YBAGAKNOiAbEQmAABagsezIr0688.jpg

5)下面參數(shù)可以指定接口類型、寄存器數(shù)量等,這里不需要修改,使用AXI Lite Slave接口,4個(gè)寄存器。

pIYBAGAKNOiAAdpBAABj7UBQhxY405.jpg

6)點(diǎn)擊“Finish”完成IP的創(chuàng)建

pIYBAGAKNOmANiB3AACJJceyGfg743.jpg

7)在“IP Catalog”中可以看到剛才創(chuàng)建的IP

o4YBAGAKNOqAXt_1AABfnsJvQ5s292.jpg

8)這個(gè)時(shí)候的IP只有簡(jiǎn)單的寄存器讀寫功能,我們需要修改IP,選擇IP,右鍵“Edit in IP Packager”

pIYBAGAKNOuABb-XAAB5wL2-2-0474.jpg

9)這是彈出一個(gè)對(duì)話框,可以填寫工程名稱和路徑,這里默認(rèn),點(diǎn)擊“OK”

o4YBAGAKNOuAEtetAAA17-JaJbI828.jpg

10)Vivado打開(kāi)了一個(gè)新的工程

o4YBAGAKNOyACrsZAACwZlnFUKU430.jpg

11)添加PWM功能的核心代碼

pIYBAGAKNO2AEJd1AAB56r7YR5g428.jpg

12)添加代碼時(shí)選擇復(fù)制代碼到IP目錄

o4YBAGAKNO2AP6e3AABhBRYK7xc945.jpg

13)修改“ax_pwm_v1_0.v”,添加一個(gè)pwm輸出端口

pIYBAGAKNO-AFDbbAACY2vDAPcs658.jpg

14)修改“ax_pwm_v1_0.v”,在例化“ax_pwm_V1_0_S00_AXI”,中添加pwm端口的例化

o4YBAGAKNPCAND1fAACXrElhvdk323.jpg

15)修改“ax_pwm_v1_0_s00_AXI.v”文件,添加pwm端口,這個(gè)文件是實(shí)現(xiàn)AXI4 Lite Slave的核心代碼

pIYBAGAKNPGAfVKeAAC1P18MXRQ939.jpg

16)修改“ax_pwm_v1_0_s00_AXI.v”文件,例化pwm核心功能代碼,將寄存器slv_reg0和slv_reg1用于pwm模塊的參數(shù)控制。

o4YBAGAKNPKARUiNAACZ2BvS7TY765.jpg

17)雙擊“component.xml”文件

pIYBAGAKNPOAMPOlAACG_4F_9Ds374.jpg

18)在“File Groups”選項(xiàng)中點(diǎn)擊“Merge changers from File Groups Wizard”

o4YBAGAKNPSAHXLoAABnifJeYpM486.jpg

19)在“Customization Parameters”選項(xiàng)中點(diǎn)擊“Merge changes form Customization Parameters Wizard”

pIYBAGAKNPSAdXnJAABkMLBuJyw511.jpg

20)點(diǎn)擊“Re-Package IP”完成IP的修改

o4YBAGAKNPWACkNEAABp4M9aDek479.jpg

2.2 添加自定義IP到工程

1)搜索“pwm”,添加“ax_pwm_v1.0”

pIYBAGAKNPaAfni5AACIPml-ZTs806.jpg

2)點(diǎn)擊“Run Connection Automation”

o4YBAGAKNPaASDjDAABPNbNzgIc749.jpg

3)導(dǎo)出pwm端口

pIYBAGAKNPeAZfx6AABmoU89YPw159.jpgpIYBAGAKNPiAbwHbAACsHwPdf2k965.jpg

4)保存設(shè)計(jì),并Generate Output Products

o4YBAGAKNPiAOfeQAABZos0RoU8815.jpg

5)添加xdc文件分配管腳,把pwm_0輸出端口分配給LED1,做一個(gè)呼吸燈,編譯生成bit文件,導(dǎo)出硬件

軟件工程師工作內(nèi)容

以下為軟件工程師負(fù)責(zé)內(nèi)容。

3. Vitis軟件編寫調(diào)試

1)啟動(dòng)Vitis,新建APP,模板選擇“Hello World”

pIYBAGAKNPmAYh0uAAArgMgWQW4897.jpg

2)在bsp里找到“xparameters.h”文件,這個(gè)非常重要的文件,里面找到了自定IP的寄存器基地址,可以找到自定義IP的基地址。

o4YBAGAKNPmAYRlMAABJ-S02plY133.jpg

3)有個(gè)寄存器讀寫宏和自定義IP的基地址,我們開(kāi)始編寫代碼,測(cè)試自定義IP,我們先通過(guò)寫寄存器AX_PWM_S00_AXI_SLV_REG0_OFFSET,控制PWM輸出頻率,然后通過(guò)寫寄存器AX_PWM_S00_AXI_SLV_REG1_OFFSET控制PWM輸出的占空比。

#include#include"platform.h"#include"xil_printf.h"#include"ax_pwm.h"#include"xil_io.h"#include"xparameters.h"#include"sleep.h"unsignedintduty;intmain(){
init_platform();

print("HelloWorld\n\r");

	//pwmoutperiod=frequency(pwm_out)*(2^N)/frequency(clk);	AX_PWM_mWriteReg(XPAR_AX_PWM_0_S00_AXI_BASEADDR,AX_PWM_S00_AXI_SLV_REG0_OFFSET,17179);//200hz	//duty=(2^N)*(1-(dutycycle))-1	while(1){
		for(duty=0x8fffffff;duty<0xffffffff;?duty?=?duty?+100000){
			AX_PWM_mWriteReg(XPAR_AX_PWM_0_S00_AXI_BASEADDR,?AX_PWM_S00_AXI_SLV_REG1_OFFSET,?duty);
			usleep(100);
		}
	}

????cleanup_platform();return0;}

4)通過(guò)運(yùn)行代碼,我們可以看到PLLED1呈現(xiàn)出一個(gè)呼吸燈的效果。

5)通過(guò)debug,我們來(lái)查看一下寄存器

pIYBAGAKNPqAZ3V6AADeZlioycM690.jpg

6)進(jìn)入debug狀態(tài),按“F6”可以單步運(yùn)行。

o4YBAGAKNPuAB7J-AADD8tKfMNM794.jpg

7)通過(guò)菜單可以查看“Memory”窗口

pIYBAGAKNPyAF581AAC9jX40CWg716.jpg

8)添加一個(gè)監(jiān)視地址“0x80000000”

o4YBAGAKNP2AKX8SAAAatVNNSRc158.jpgpIYBAGAKNP2AFIX5AAAfM_86tfo182.jpg

9)單步運(yùn)行,觀察變化

o4YBAGAKNP6AcdbWAADI0GQP9g4708.jpg

4. 實(shí)驗(yàn)總結(jié)

通過(guò)本實(shí)驗(yàn)我們掌握了更多的Vitis調(diào)試技巧,掌握了ARM + FPGA開(kāi)發(fā)的核心內(nèi)容,就是ARM和FPGA數(shù)據(jù)交互。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(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)投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1630

    文章

    21777

    瀏覽量

    604770
  • Xilinx
    +關(guān)注

    關(guān)注

    71

    文章

    2169

    瀏覽量

    121811
  • IP
    IP
    +關(guān)注

    關(guān)注

    5

    文章

    1715

    瀏覽量

    149737
  • Zynq
    +關(guān)注

    關(guān)注

    10

    文章

    610

    瀏覽量

    47231
  • MPSoC
    +關(guān)注

    關(guān)注

    0

    文章

    199

    瀏覽量

    24302
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    如何調(diào)試Zynq UltraScale+ MPSoC VCU DDR控制器

      如何調(diào)試Zynq UltraScale+ MPSoC VCU DDR控制器  Zynq UltraScale+
    發(fā)表于 01-07 16:02

    如何調(diào)試Zynq UltraScale+ MPSoC VCU DDR控制器

    如何調(diào)試 Zynq UltraScale+ MPSoC VCU DDR 控制器?
    發(fā)表于 01-22 06:29

    ZYNQ Ultrascale+ MPSOC FPGA教程

    ZYNQ Ultrascale+ MPSOC FPGA教程
    發(fā)表于 02-02 07:53

    Ti推出面向Zynq UltraScale+ MPSoC的電源參考設(shè)計(jì)

    本篇文章將與大家討論的是Xilinx Zynq UltraScale+ MPSoC的電源解決方案參考設(shè)計(jì)。
    發(fā)表于 03-14 02:24 ?3731次閱讀
    Ti推出面向<b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+</b> <b class='flag-5'>MPSoC</b>的電源參考設(shè)計(jì)

    Xilinx基于ARM的Zynq-7000和Zynq UltraScale+ MPSoC及RFSoC器件是否存在安全漏洞

    本文試圖搞清楚在 Xilinx 基于 ARM 的 Zynq-7000、Zynq UltraScale+ MPSoCZynq
    發(fā)表于 06-28 15:53 ?2686次閱讀

    Zynq UltraScale+ MPSoC存儲(chǔ)器接口系統(tǒng)的介紹

    該視頻重點(diǎn)介紹了UltraScale +產(chǎn)品系列的第一個(gè)成員Zynq?UltraScale+?MPSoC,并展示了使用可編程邏輯中的DDR4 SDRAM
    的頭像 發(fā)表于 11-29 06:36 ?3345次閱讀

    Zynq UltraScale+ MPSoC的發(fā)售消息

    Zynq?UltraScale+?MPSoC,現(xiàn)已開(kāi)始發(fā)售。視頻向您重點(diǎn)介紹了Xilinx UltraScale +產(chǎn)品組合的第一位成員
    的頭像 發(fā)表于 11-27 06:47 ?3623次閱讀

    米爾科技Zynq UltraScale+ MPSoC技術(shù)參考手冊(cè)介紹

    Zynq UltraScale+ MPSoC是Xilinx推出的第二代多處理SoC系統(tǒng),在第一代Zynq-7000的基礎(chǔ)上做了全面升級(jí),在單芯片上融合了功能強(qiáng)大的處理器系統(tǒng)(PS)和用
    的頭像 發(fā)表于 11-18 11:03 ?3246次閱讀
    米爾科技<b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+</b> <b class='flag-5'>MPSoC</b>技術(shù)參考手冊(cè)介紹

    如何調(diào)試 Zynq UltraScale+ MPSoC VCU DDR 控制器?

    Zynq UltraScale+ MPSoC VCU DDR 控制器是一款專用 DDR 控制器,只支持在 Zynq UltraScale+
    發(fā)表于 02-23 06:00 ?15次下載
    如何調(diào)試 <b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+</b> <b class='flag-5'>MPSoC</b> VCU DDR 控制器?

    米爾電子zynq ultrascale+ mpsoc底板外設(shè)資源清單分享

    米爾電子推出的國(guó)內(nèi)首款zynq ultrascale+ mpsoc平臺(tái)核心板(及開(kāi)發(fā)板):MYC-CZU3EG吸引了人工智能、工業(yè)控制、嵌入式視覺(jué)、ADAS、算法加速、云計(jì)算、有線/無(wú)線通信等
    發(fā)表于 01-07 15:20 ?3次下載
    米爾電子<b class='flag-5'>zynq</b> <b class='flag-5'>ultrascale+</b> <b class='flag-5'>mpsoc</b>底板外設(shè)資源清單分享

    ZYNQ Ultrascale+ MPSoC系列FPGA芯片設(shè)計(jì)

    基于 Xilinx 公司ZYNQ Ultrascale+ MPSoC系列 FPGA 芯片設(shè)計(jì),應(yīng)用于工廠自動(dòng)化、機(jī)器視覺(jué)、工業(yè)質(zhì)檢等工業(yè)領(lǐng)域
    發(fā)表于 11-02 14:35 ?1608次閱讀

    Zynq UltraScale+ MPSoC中的隔離方法

    電子發(fā)燒友網(wǎng)站提供《Zynq UltraScale+ MPSoC中的隔離方法.pdf》資料免費(fèi)下載
    發(fā)表于 09-13 17:11 ?1次下載
    <b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+</b> <b class='flag-5'>MPSoC</b>中的隔離方法

    Zynq UltraScale+ MPSoC的隔離設(shè)計(jì)示例

    電子發(fā)燒友網(wǎng)站提供《Zynq UltraScale+ MPSoC的隔離設(shè)計(jì)示例.pdf》資料免費(fèi)下載
    發(fā)表于 09-13 11:28 ?3次下載
    <b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+</b> <b class='flag-5'>MPSoC</b>的隔離設(shè)計(jì)示例

    Zynq UltraScale+ MPSoC驗(yàn)證數(shù)據(jù)手冊(cè)

    電子發(fā)燒友網(wǎng)站提供《Zynq UltraScale+ MPSoC驗(yàn)證數(shù)據(jù)手冊(cè).pdf》資料免費(fèi)下載
    發(fā)表于 09-15 10:13 ?0次下載
    <b class='flag-5'>Zynq</b> <b class='flag-5'>UltraScale+</b> <b class='flag-5'>MPSoC</b>驗(yàn)證數(shù)據(jù)手冊(cè)

    Zynq UltraScale+ MPSoC數(shù)據(jù)手冊(cè)

    電子發(fā)燒友網(wǎng)站提供《Zynq UltraScale+ MPSoC數(shù)據(jù)手冊(cè).pdf》資料免費(fèi)下載
    發(fā)表于 12-30 14:37 ?0次下載