




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
關(guān)于PWM發(fā)生器的性能分析和應(yīng)用介紹在這篇實(shí)例之前,說點(diǎn)自己的兩點(diǎn)感受。一、這個(gè)zynq開發(fā)流程基本上是這樣一個(gè)節(jié)奏:PlanAhead為軟硬件結(jié)合的載體,在此可以設(shè)計(jì)硬件,然后將硬件導(dǎo)出到軟件設(shè)計(jì)?;玖鞒倘鐖D:這里三個(gè)軟件切換來切換去,極其麻煩,并且其中還可能要FPGA開發(fā)用到的ISE,應(yīng)該不是xilinx想要的結(jié)果,預(yù)計(jì)以后會(huì)集成到一個(gè)軟件上。二、剛使用這個(gè)平臺(tái)不久,碰到bug不少,說明xilinx推出時(shí)準(zhǔn)備不是很充分。用戶IPcore與PS交互數(shù)據(jù)分兩種方案:一種是通過EMIO交換數(shù)據(jù),將PL的IP核當(dāng)做系統(tǒng)外設(shè),性能有所欠缺。常用的是第二種:滿足AXI協(xié)議的IP核。此IPcore與AXI密切相關(guān),難度較高。為降低難度,xilinx提供wizard自動(dòng)生成axi總線相關(guān)代碼,做好地址譯碼邏輯、讀寫控制邏輯,并在工作區(qū)生成一些寄存器。用戶PL邏輯通過讀寫這些寄存器與PS交互。以PWM發(fā)生器為例,有兩個(gè)寄存器,一個(gè)調(diào)節(jié)周期的寄存器,一個(gè)調(diào)節(jié)占空比。PlanAhead建立工程,添加嵌入式資源進(jìn)入XPS,添加xml配置之后,進(jìn)入XPSHardware—>CreateorImportPeriphera。開始添加IPcorewizard過程,注意在IPinterface階段,userlogicmastersupport表示ip核內(nèi)部是否要加入master接口,一般用在較復(fù)雜外設(shè)。softwarereset和includedataphasetimer分別為是否開啟軟件中斷和數(shù)據(jù)周期計(jì)時(shí)器,在此我們不要這些,防止生成多余的AXImaster接口、復(fù)位和計(jì)時(shí)模塊。下一步選擇寄存器數(shù)量,這里我們用到占空比和周期reg,因此設(shè)為2。下一步仿真平臺(tái)不要,下一步勾選二三項(xiàng),第一項(xiàng)是生成verilogVHDL,我要VHDL,不選,二表示生成一個(gè)ISE工程便于測(cè)試和調(diào)試IPcore。三表示生成軟件驅(qū)動(dòng)庫文件,方便在SDK中使用IPcore。完成wizard。配置完成,接下來添加剛完成的IPcore,在IPcatalog中雙擊添加,不用修改ok即可在businterface可找到剛添加的pwm_ip_0,右鍵之,viewMPD,添加pwm_out接口,1bit的輸出PORTpwm_ou="",DIR=o這里添加的代碼在systemassemblyview中的port映射出添加的pwm_out,問題:在wizard完成后出現(xiàn)pwm_ip.vhd文件沒有user_logic的component塊。原因:勾選Generatestub‘user_logic’templateinveriloginsteadofVHDL之后會(huì)生成。右鍵pwm_ip_0,選擇browserHDLsources選pwm_ip.hdl在component加用戶邏輯user_logic,繼續(xù)右鍵pwm_ip_0,選擇browserHDLsources選user_logic.v添加自己要加的功能,這里我們加pwm發(fā)生功能,代碼如下wireovprd;//下一個(gè)周期開始信號(hào)reg[C_SLV_DEIDTH-1:0]pwm_counter;wirepre_pwm_out;//預(yù)輸出信號(hào)always@(posedgeBus2IP_Clk)beginif(!Bus2IP_Clk||ovprd||~slv_reg1[31])//時(shí)鐘0,下一個(gè)周期開始1,占空比reg31位0計(jì)數(shù)器復(fù)位pwm_counter=32'h8000_0000;elseif(slv_reg1[31])pwm_counter=pwm_counter+1'b1;elsepwm_counter=pwm_counter;endassignovprd=(pwm_counter[30:0]==slv_reg0[30:0])?1'b1:1'b0;assignpre_pwm_out=(slv_reg1<pwm_counter)?1'b0:1'b1;assignpwm_out=pre_pwm_out&slv_reg1[31];然后project—>RescanUserRepositories更新,可以在ports中看到新添加的引腳,選擇exteralports連接管腳。在Address中右上角GeneratedAddress自動(dòng)分配地址Project—>DesignRuleCheck沒有錯(cuò)誤后關(guān)閉XPS回到PA右鍵module_1,createtopHDLaddsource選擇添加約束,對(duì)應(yīng)之前的工程名runsynthesis,出現(xiàn)錯(cuò)誤,如下圖1重新建程序,更改新建xps工程名以及PA的約束名為system,而不使用module_1默認(rèn)名,另外一個(gè)改動(dòng)是wizard建立ipcore過程中去掉dataphasetimer模塊。之后錯(cuò)誤消失,但是警告如圖2,這個(gè)警告是由于約束地址造成,關(guān)系不大。下一步打開opensynthesizeddesign(不點(diǎn)開這個(gè)在PA界面找不到IOports標(biāo)簽)打開IOports,設(shè)置pwm_out的引腳,然后保存(點(diǎn)擊PA的保存標(biāo)簽會(huì)讓你選擇一個(gè)ucf文件來保存,不需要自己另外寫)。GenerateBitstream然后導(dǎo)出硬件到SDK,新建xilinxcproject,選擇helloworld模板。注意接下來是將自己的pwm_ip導(dǎo)入的過程,跟上一個(gè)實(shí)驗(yàn)不一樣的地方。選擇xilinxtools—>Repositories點(diǎn)擊new找到工程路徑到edk,ok。右擊hello_world_bsp_0,選擇BoardSupportPackageSetting,找到drivers中的pwm_ip_0,將drive欄目下的generic修改為pwm_ip,自此自設(shè)的IP核驅(qū)動(dòng)就已經(jīng)添加進(jìn)來了。這里會(huì)報(bào)錯(cuò),這是xilinx的一個(gè)bug,在hello_world_bsp_0上有一個(gè)紅叉,在pwm_ip_selftest.c中加入#definePWM_IP_USER_NUM_REG_2,添加之后還是報(bào)錯(cuò),如圖3注釋掉添加C代碼PWM_IP_mWriteReg(XPAR_PWM_IP_0_BASEADDR,0,10000);PWM_IP_mWriteReg(XPAR_PWM_IP_0_BASEADDR,4,0X80000000+5000);//5000/10000=50%保存報(bào)錯(cuò)'XPAR_PWM_IP_0_BASEADDR'undeclared(firstuseinthisfunction)修改后報(bào)錯(cuò)cannotfind-lxil(可能是project_1沒有改為對(duì)應(yīng)pwm_ip_test,導(dǎo)致庫文件宏定義之類的不能調(diào)用)發(fā)現(xiàn)PWM_IP_USER_NUM_REG2多寫了個(gè)下劃線的錯(cuò)誤。修改后錯(cuò)誤依舊,貌似不會(huì)重新編譯。因此要重新從PA導(dǎo)出硬件到SDK。選擇XilinxTools->ProgramFPGA在hello_world_0工程上右擊,選擇RunAs->LaunchonHardware運(yùn)行出現(xiàn)各種錯(cuò)誤,如下圖4、5換成memorytest模板后,萬用表查看JA1約為1.2V。用示波器看波形結(jié)果是正確的。helloworld模板不行,具體原因不明。總結(jié):第一、添加user_logic.v時(shí)要求為verilog代碼,在wizard過程中嘗試過使用VHDL而不是verilog,結(jié)果是生成的pwm_ip.hdl中沒有user_logic的component模塊。而pwm_ip.hdl又是VHDL語言,極其不便。第二、添加約束時(shí)使用默認(rèn)的module
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度房屋拆除安全風(fēng)險(xiǎn)評(píng)估與整改措施合同
- 2025年度藥店藥品市場(chǎng)調(diào)研與分析合作協(xié)議
- 二零二五年度兼職會(huì)計(jì)財(cái)務(wù)報(bào)告審核聘用合同模板
- 二零二五年度人工智能企業(yè)競業(yè)禁止與算法技術(shù)保密協(xié)議
- 二零二五年度實(shí)習(xí)教師實(shí)習(xí)期間實(shí)習(xí)單位實(shí)習(xí)導(dǎo)師考核評(píng)價(jià)與服務(wù)協(xié)議
- 洗浴供水合同范本
- 2025年度洗煤廠煤炭洗選項(xiàng)目質(zhì)量管理體系認(rèn)證合同
- 二零二五年度有限責(zé)任公司股東無息借款及資金補(bǔ)充合同
- 2025年度質(zhì)押擔(dān)保合同書:綠色建筑項(xiàng)目融資擔(dān)保
- 二零二五年度股票轉(zhuǎn)讓與市場(chǎng)推廣合同
- 2025年安全員C證(專職安全員)考試題庫
- 地理-天一大聯(lián)考2025屆高三四省聯(lián)考(陜晉青寧)試題和解析
- 醫(yī)療衛(wèi)生系統(tǒng)招聘考試(中醫(yī)學(xué)專業(yè)知識(shí))題庫及答案
- 貴州省貴陽市2024-2025學(xué)年九年級(jí)上學(xué)期期末語文試題(含答案)
- 小巴掌童話課件
- 教科版六年級(jí)科學(xué)下冊(cè)全冊(cè)教學(xué)設(shè)計(jì)教案
- 部編版小學(xué)五年級(jí)下冊(cè)《道德與法治》全冊(cè)教案含教學(xué)計(jì)劃
- 2024年青島遠(yuǎn)洋船員職業(yè)學(xué)院高職單招語文歷年參考題庫含答案解析
- 定額〔2025〕1號(hào)文-關(guān)于發(fā)布2018版電力建設(shè)工程概預(yù)算定額2024年度價(jià)格水平調(diào)整的通知
- 2024建筑施工安全生產(chǎn)隱患識(shí)別圖合集
- 2025年江蘇南京技師學(xué)院招聘工作人員19人高頻重點(diǎn)提升(共500題)附帶答案詳解
評(píng)論
0/150
提交評(píng)論