国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

ZYNQ通過AXI DMA實現(xiàn)PL發(fā)送連續(xù)大量數(shù)據(jù)到PS DDR

這篇具有很好參考價值的文章主要介紹了ZYNQ通過AXI DMA實現(xiàn)PL發(fā)送連續(xù)大量數(shù)據(jù)到PS DDR。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

硬件:ZYNQ7100
軟件:Vivado 2017.4、Xilinx SDK 2017.4
??ZYNQ PL 和 PS 的通信方式有 AXI GPIO、BRAM、DDR等。對于數(shù)據(jù)量較少、地址不連續(xù)、長度規(guī)則的情況,BRAM 比較適用。而對于傳輸速度要求高、數(shù)據(jù)量大、地址連續(xù)的情況,比如 ADC,可以通過 AXI DMA 來完成。

1、硬件設計

1.1 ZYNQ7 Processing System IP核

??選中 M AXI GP0 和 S AXI HP0
zynq中ps和pl通過dma通信,ZYNQ,FPGA,fpga開發(fā),嵌入式硬件??選中 PL 到 PS 的中斷端口
zynq中ps和pl通過dma通信,ZYNQ,FPGA,fpga開發(fā),嵌入式硬件其他按開發(fā)板要求配置。

1.2 AXI Direct Memory Access IP核

??AXI Direct Memory Access IP核配置如下圖所示。由于只需要 PL 向 PS 的 DDR寫數(shù)據(jù),所以只使能了寫通道。
zynq中ps和pl通過dma通信,ZYNQ,FPGA,fpga開發(fā),嵌入式硬件

1.3 AXI4-Stream Data FIFO IP核

??AXI4-Stream Data FIFO IP核用于緩存數(shù)據(jù),它的接口按照 AXI4-Stream 協(xié)議通信,它的配置如下圖所示。
zynq中ps和pl通過dma通信,ZYNQ,FPGA,fpga開發(fā),嵌入式硬件

1.4 連續(xù)數(shù)據(jù)生成模塊

?? 編寫一個生成連續(xù)數(shù)據(jù)的模塊,它在接收到一個觸發(fā)信號上升沿后,按 AXI4-Stream 協(xié)議輸出連續(xù)數(shù)據(jù)。

module dma_frame_gen #(
    parameter TRANS_NUM = 32'd1550336 //1514*1024
    )
    (
    input resetn,
    input clk,
    input trans_start,
    // axi-stream
    output [31:0] m_axis_tdata,
    output [3:0] m_axis_tkeep,
    output m_axis_tlast,
    output m_axis_tvalid,
    input m_axis_tready
    );
    
assign m_axis_tkeep = 4'b1111;
reg trans_start_0, trans_start_1;
wire pos_trans_start;
assign pos_trans_start = trans_start_0 & (~trans_start_1);
always @(posedge clk or negedge resetn) begin
    if(~resetn) begin
        trans_start_0 <= 1'd0;
        trans_start_1 <= 1'd0;
    end
    else begin
        trans_start_0 <= trans_start;
        trans_start_1 <= trans_start_0;
    end
end
localparam IDLE = 2'b00;
localparam TRANS = 2'b01;
localparam DONE = 2'b10;
reg [1:0] state;
reg [31:0] trans_cnt;
reg [31:0] r_tdata;
reg r_tvalid, r_tlast;
always @(posedge clk or negedge resetn) begin
    if(!resetn) begin
        state <= IDLE;
        r_tdata <= 32'd0;
        r_tvalid <= 1'b0;
    end
    else begin
        r_tdata <= 32'd0;
        r_tvalid <= 1'b0;
        case(state)
            IDLE: begin
                if(pos_trans_start && m_axis_tready) begin
                    state <= TRANS;
                end
                else begin
                    state <= IDLE;
                end
            end
            TRANS: begin
                if(trans_cnt < TRANS_NUM) begin
                    state <= TRANS;
                    r_tvalid <= 1'b1;
                    r_tdata <= trans_cnt;
                end
                else begin
                    state <= DONE;
                end
            end
            DONE: begin
                state <= IDLE;
            end
            default: begin
                state <= IDLE;
            end
        endcase
    end
end
always @(posedge clk or negedge resetn) begin
    if(!resetn) begin
        r_tlast <= 1'b0;
    end
    else begin
        if(state == TRANS && trans_cnt == TRANS_NUM-1) begin
            r_tlast <= 1'b1;
        end
        else begin
            r_tlast <= 1'b0;
        end
    end
end
always @(posedge clk or negedge resetn) begin
    if(!resetn) begin
        trans_cnt <= 0;
    end
    else begin
        if(state == TRANS) begin
            trans_cnt <= trans_cnt + 1;
        end
        else begin
            trans_cnt <= 32'd0;
        end
    end
end
assign m_axis_tdata = r_tdata;
assign m_axis_tlast = r_tlast;
assign m_axis_tvalid = r_tvalid;
endmodule

?? 把此模塊添加到 block design 里,軟件能自動識別 AXI4-Stream 端口。
zynq中ps和pl通過dma通信,ZYNQ,FPGA,fpga開發(fā),嵌入式硬件

1.5 block design整體設計

??block design整體設計如下圖所示,主要的數(shù)據(jù)通路用橙色線表示。dma_frame_gen 的 m_axis 端口連接 AXI4-Stream Data FIFO 的 S_AXIS 端口,AXI4-Stream Data FIFO 的 M_AXIS 端口連接 AXI DMA Memory Access 的 S_AXIS_S2MM 端口,AXI DMA Memory Access 的 M_AXI_S2MM 端口連接 AXI SmartConnect 的 S00_AXI 端口,AXI SmartConnect 的 M00_AXI 端口連接 ZYNQ7 Processing System 的 S_AXI_HP0 端口。
zynq中ps和pl通過dma通信,ZYNQ,FPGA,fpga開發(fā),嵌入式硬件

2、軟件設計

2.1 AXI DMA 初始化和 DMA 中斷函數(shù)
void axi_dma_init()
{
	XAxiDma_Config *axi_dma_cfg_ptr;
	axi_dma_cfg_ptr = XAxiDma_LookupConfig(XPAR_AXIDMA_0_DEVICE_ID);
	XAxiDma_CfgInitialize(&axi_dma_0_inst, axi_dma_cfg_ptr);
	// interrupt
	XScuGic_SetPriorityTriggerType(&scugic_inst, XPAR_FABRIC_AXIDMA_0_VEC_ID, 0xA0, 0x3);
	XScuGic_Connect(&scugic_inst, XPAR_FABRIC_AXIDMA_0_VEC_ID, (Xil_InterruptHandler) axi_dma_rx_intr_handler, &axi_dma_0_inst);
	XScuGic_Enable(&scugic_inst, XPAR_FABRIC_AXIDMA_0_VEC_ID);
	XAxiDma_IntrEnable(&axi_dma_0_inst, XAXIDMA_IRQ_ALL_MASK, XAXIDMA_DEVICE_TO_DMA);
}
void axi_dma_rx_intr_handler(void *CallBackRef)
{
	int timeout;
	u32 irq_status;
	XAxiDma *axidma_inst = (XAxiDma *)CallBackRef;
	irq_status = XAxiDma_IntrGetIrq(axidma_inst, XAXIDMA_DEVICE_TO_DMA);
	XAxiDma_IntrAckIrq(axidma_inst, irq_status, XAXIDMA_DEVICE_TO_DMA);
	if ((irq_status & XAXIDMA_IRQ_ERROR_MASK))
	{
//		error = 1;
		XAxiDma_Reset(axidma_inst);
		timeout = 10000;
		while(timeout)
		{
			if (XAxiDma_ResetIsDone(axidma_inst)) break;
			timeout--;
		}
		return;
	}
	if ((irq_status & XAXIDMA_IRQ_IOC_MASK))
	{
		dma_rx_done = 1;
	}
}
2.2 初始化中斷
void interrupt_init()
{
	XScuGic_Config *intc_cfg_ptr;
	intc_cfg_ptr = XScuGic_LookupConfig(XPAR_SCUGIC_SINGLE_DEVICE_ID);
	XScuGic_CfgInitialize(&scugic_inst, intc_cfg_ptr, intc_cfg_ptr->CpuBaseAddress);

	Xil_ExceptionRegisterHandler(XIL_EXCEPTION_ID_INT, (Xil_ExceptionHandler)XScuGic_InterruptHandler, &scugic_inst);
	Xil_ExceptionEnable();
}
2.3 初始化 AXI GPIO
void axi_gpio_init()
{
	XGpio_Initialize(&axi_gpio_0_inst, XPAR_GPIO_0_DEVICE_ID);
	XGpio_SetDataDirection(&axi_gpio_0_inst, 1, 0x01);
}
2.4 main 函數(shù)

??在 main 函數(shù)中先執(zhí)行中斷、AXI GPIO 和 AXI DMA 的初始化函數(shù),然后 AXI GPIO 輸出一個信號上升沿觸發(fā) dma_frame_gen 模塊輸出連續(xù)數(shù)據(jù),XAxiDma_SimpleTransfer 函數(shù)觸發(fā)一次 DMA 傳輸,Xil_DCacheFlushRange 函數(shù)刷新 Data Cache。DMA 傳輸完成后觸發(fā) DMA 中斷,如果 DMA 傳輸成功,dma_rx_done 在 DMA 中斷中置 1。

int main()
{
	int status;
	FIL fil;
	volatile int rec_data[BUF_SIZE] = {0};

	interrupt_init();
	axi_gpio_init();
	axi_dma_init();
	XGpio_DiscreteWrite(&axi_gpio_0_inst, 1, 0x01);
	XAxiDma_SimpleTransfer(&axi_dma_0_inst, (UINTPTR) rec_data, BUF_SIZE*sizeof(int), XAXIDMA_DEVICE_TO_DMA);
	XGpio_DiscreteClear(&axi_gpio_0_inst, 1, 0x01);
	Xil_DCacheFlushRange((UINTPTR) rec_data, BUF_SIZE*sizeof(int)); //刷新Data Cache
	while(!dma_rx_done);
	return 0;
}

3、上板驗證

??用 Debug 模式運行程序,在 main 函數(shù)的 return 0; 行放斷點,當程序運行到斷點處時,看 rec_data 中存的是從 0 到 BUF_SIZE-1 的連續(xù)數(shù)值,實驗成功。
zynq中ps和pl通過dma通信,ZYNQ,FPGA,fpga開發(fā),嵌入式硬件zynq中ps和pl通過dma通信,ZYNQ,FPGA,fpga開發(fā),嵌入式硬件
??dma_frame_gen 的 m_axis 端口輸出波形如下圖所示。
zynq中ps和pl通過dma通信,ZYNQ,FPGA,fpga開發(fā),嵌入式硬件

??AXI4-Stream Data FIFO 的 M_AXIS 端口輸出波形如下圖所示。
zynq中ps和pl通過dma通信,ZYNQ,FPGA,fpga開發(fā),嵌入式硬件

??AXI DMA Memory Access 的 M_AXI_S2MM 端口的寫通道波形如下圖所示。
zynq中ps和pl通過dma通信,ZYNQ,FPGA,fpga開發(fā),嵌入式硬件文章來源地址http://www.zghlxwxcb.cn/news/detail-765257.html

到了這里,關于ZYNQ通過AXI DMA實現(xiàn)PL發(fā)送連續(xù)大量數(shù)據(jù)到PS DDR的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領支付寶紅包贊助服務器費用

相關文章

  • ZYNQ AXI-DMA Linux Cache 一致

    ZYNQ AXI-DMA Linux Cache 一致

    平臺為 ZYNQ MPSOC 項目使用到AXI-DMA ,ADC模塊傳輸數(shù)據(jù)到DDR,應用層進行數(shù)據(jù)的讀取。在此做些記錄 用到了AXI-Stream , IP核用的 米聯(lián)客的ui_axisbufw,可以把流數(shù)據(jù)轉(zhuǎn)為AXI-Stream 接口 比較重要的參考鏈接 1.UltraScale+MPSoC+Cache+Coherency https://xilinx-wiki.atlassian.net/wiki/spaces/A/pages/18842098/Zynq+

    2024年02月03日
    瀏覽(14)
  • ZYNQ AXI_DMA_UDP以太網(wǎng)傳輸(二)問題記錄

    ZYNQ AXI_DMA_UDP以太網(wǎng)傳輸(二)問題記錄

    上一篇文章只是簡單的記錄一下調(diào)試成功的代碼 但調(diào)試成功這個過程很痛苦,踩了很多坑,特此記錄,留眼以后查看 參考博客 xilinx dma調(diào)試筆記 ZYNQ AXI DMA調(diào)試細節(jié) 在調(diào)試過程中出現(xiàn)這類問題基本上都是這一句代碼出了問題: 再往里面跳可以看見這樣一個函數(shù),在正點原子提

    2024年03月14日
    瀏覽(35)
  • ZYNQ AXI4總線訪問DDR3實現(xiàn)圖像數(shù)據(jù)乒乓存儲與顯示

    目錄 前言 一、添加端口 二、添加局部變量 三、例化讀寫FIFO 四、內(nèi)部變量修改,設置一次讀寫進行多少次突發(fā)操作 五、寫地址 六、讀地址 七、狀態(tài)機 1.寫狀態(tài)機 2.讀狀態(tài)機 總結(jié) 在Altera FPGA進行圖像處理時,我們采用的存儲芯片為SDRAM,當時參照正點原子的例程是封裝SDR

    2024年02月02日
    瀏覽(42)
  • FPGA----UltraScale+系列的PS側(cè)與PL側(cè)通過AXI-HP交互(全網(wǎng)唯一最詳)附帶AXI4協(xié)議校驗IP使用方法

    FPGA----UltraScale+系列的PS側(cè)與PL側(cè)通過AXI-HP交互(全網(wǎng)唯一最詳)附帶AXI4協(xié)議校驗IP使用方法

    1、之前寫過一篇關于ZYNQ系列通用的PS側(cè)與PL側(cè)通過AXI-HP通道的文檔,下面是鏈接。 FPGA----ZCU106基于axi-hp通道的pl與ps數(shù)據(jù)交互(全網(wǎng)唯一最詳)_zcu106調(diào)試_發(fā)光的沙子的博客-CSDN博客 大家好,今天給大家?guī)淼膬?nèi)容是,基于AXI4協(xié)議的采用AXI-HP通道完成PL側(cè)數(shù)據(jù)發(fā)送至PS側(cè)(PS側(cè)數(shù)

    2024年02月13日
    瀏覽(28)
  • ZYNQ——PL端流水燈的實現(xiàn)

    ZYNQ——PL端流水燈的實現(xiàn)

    本文介紹的是在ZYNQ 7020黑金開發(fā)板上實現(xiàn)PL端流水燈的例子,開發(fā)板上PL端的LED燈總共有4個,在原理圖中找到 PL LED 如下圖所示,通過看圖可知,給 LED 置低電平時燈才亮。 這里預想的實驗結(jié)果是:在1秒鐘內(nèi),4個LED各亮0.25秒,看起來就像流水燈一樣。 LED:4個,賦值為0時即點

    2024年02月09日
    瀏覽(24)
  • ZYNQ7000 PL與PS交互(一): PL到PS中斷的使用與實現(xiàn)

    ZYNQ7000 PL與PS交互(一): PL到PS中斷的使用與實現(xiàn)

    翻譯以xilinx用戶手冊ug585,知道ZYNQ7000有幾類中斷即可。 PS基于ARM架構,使用了兩個Cortex-A9處理器和GIC PL390中斷控制器。中斷結(jié)構與CPU密切相關,并接收來自IO外設和可編程單元PL的中斷請求。 本章主要信息: 私有、共享和軟件中斷。 GIC功能介紹 中斷優(yōu)先級和處理 1.1.1 Zynq 中

    2024年04月15日
    瀏覽(19)
  • AXI4-寫DMA如何使用verilog實現(xiàn)(三)DMA例子

    這里給一個小例子: 往0地址寫入 突發(fā)長度為256突發(fā),數(shù)據(jù)位寬為64bit 數(shù)據(jù)為0~255

    2024年02月12日
    瀏覽(21)
  • ZYNQ學習筆記(四):PL與PS數(shù)據(jù)交互——基于BRAM IP 核的(PS端讀寫+PL端讀)控制實驗

    ZYNQ學習筆記(四):PL與PS數(shù)據(jù)交互——基于BRAM IP 核的(PS端讀寫+PL端讀)控制實驗

    說起PS、PL數(shù)據(jù)交互,常見的有IO方式:MIO EMIO GPIO,還有利用BRAM或FIFO等,在上一篇文章ZYNQ學習筆記(三):PL與PS數(shù)據(jù)交互—— UART串口+AXI GPIO控制DDS IP核輸出實驗咱們學會了如何利用AXI GPIO IP核來實現(xiàn)PS(寫)與PL(讀)的數(shù)據(jù)交互,那么這篇文章來學習如何使用BRAM~ 本次實驗

    2024年02月05日
    瀏覽(20)
  • STM32 F4串口空閑中斷 + DMA實現(xiàn)數(shù)據(jù)發(fā)送

    最近在做 STM32 + ROS車的項目,STM32與ROS之間通信由于數(shù)據(jù)量大,所以在 STM32端 使用 空閑中斷 + DMA 的方案來減輕 CPU 的壓力。 一、空閑中斷 空閑中斷 顧名思義為空了,閑了,沒事了進的中斷,在 沒有數(shù)據(jù)流 的時候會進入進行讀取。 在我們串口進行發(fā)送時實則為連續(xù)發(fā)送,兩

    2024年02月16日
    瀏覽(27)
  • 通過修改HAL_UART_Transmit_DMA()函數(shù),解決串口發(fā)送DMA只能發(fā)送一次的問題

    廢話不多說,先上代碼: 在 stm32f1xx_hal_uart.c 文件中找到HAL_UART_Transmit_DMA()函數(shù)實現(xiàn),在 解鎖操作__HAL_UNLOCK;后添加代碼:huart - gState = HAL_UART_STATE_READY;? 編譯以后運行完美解決。而且在低延遲的高速while循環(huán)中反復調(diào)用串口DMA請求,都可以運行。 HAL_UART_Transmit_DMA()函數(shù)

    2024年02月13日
    瀏覽(34)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領取紅包,優(yōu)惠每天領

二維碼1

領取紅包

二維碼2

領紅包