#### NARLabs

### 416x416變數宣告

```
drawh 🖾
     typedef struct ImgS
         int h:
         int c;
         unchar *data:
     -}ImgS;
     //The first saved frame
     unchar FstFrame[TBSIZE] = {0};
     unchar chn1[CHNLSIZE] = {0}; //??B
     unchar chn2[CHNLSIZE] = {0}; //??G
     unchar chn3[CHNLSIZE] = {0}; //??R
      //Jackol define
     unchar DwnCh1[DWNSIZE] = {0}; //??B
      unchar DwnCh2[DWNSIZE] = {0}; //??G
      unchar Padding1[PADDSIZE] = {0}; //??!
      unchar Padding2[PADDSIZE] = {0}; //??G
      unchar Padding3[PADDSIZE] = {0}; //??R
      //CY add for verify AXI DMA function
     unchar Padding1 RX[PADDSIZE] = {0}; //??!
      unchar Padding2_RX[PADDSIZE] = {0}; //??
       inchar Padding3 RX[PADDSIZE] = {0}; //?3
```

- PADDSIZE=173056 (416\*416)
- Downsize影像變數
  - Padding1 \ Padding2 \ Padding3
- IP運算完之變數
  - Padding1\_RX \ Padding2\_RX \ Padding3\_RX

106

#### **NARLabs**

# AXI DMA傳輸副程式

- void AXI\_DMA\_Transfer( UINTPTR BuffAddr, u32 Length, int Direction)
- Direction參數說明:
  - DDR到IP: XAXIDMA DMA TO DEVICE
  - IP到DDR: XAXIDMA DEVICE TO DMA
  - PADDSIZE: 資料長度 (Byte)
- 使用範例:

```
AXI_DMA_Transfer((UINTPTR)(&Padding1) ,PADDSIZE, XAXIDMA_DMA_TO_DEVICE);

AXI_DMA_Transfer((UINTPTR)(&Padding1_RX),PADDSIZE, XAXIDMA_DEVICE_TO_DMA);

Xil_DCacheFlushRange((UINTPTR)Padding1, PADDSIZE);

Xil_DCacheFlushRange((UINTPTR)Padding1_RX, PADDSIZE);
```

### DCache刷新副程式

NARLabs

- void Xil\_DCacheFlushRange(INTPTR adr, INTPTR len)
- 使用範例:

```
Xil_DCacheFlushRange((UINTPTR)(&Padding1),
Xil_DCacheFlushRange((UINTPTR)(&Padding1),
Xil_DCacheFlushRange((UINTPTR)(&Padding1),
Xil_DCacheFlushRange((UINTPTR)(&Padding2),
PADDSIZE);
Xil_DCacheFlushRange((UINTPTR)(&Padding2, RX),
Xil_DCacheFlushRange((UINTPTR)(&Padding3),
Xil_DCacheFlushRange((UINTPTR)(&Padding3),
PADDSIZE);
Xil_DCacheFlushRange((UINTPTR)(&Padding3),
PADDSIZE);
Xil_DCacheFlushRange((UINTPTR)(&Padding3),
PADDSIZE);

//start Padding to IP,CYCHEN add-
AXI_DMA_Transfer(&Padding1_RX,PADDSIZE, XAXIDMA_DEVICE_TO_DMA);
Xil_DCacheFlushRange((UINTPTR)Padding1_RX, PADDSIZE);
Xil_DCacheFlushRange((UINTPTR)Padding1_RX, PADDSIZE);
```

107

# AXI DMA/IP 驗證

#### **NARLabs**



108