

題目: HPS FPGA and Custom QSYS Component



## 國立陽明交通大學 National Yang Ming Chiao Tung University 實驗程式碼





## system description:解掉註解即可

```
h2p_lw_led_addr=virtual_base + ( ( unsigned long ) ( ALT_LWFPGASLVS_OFST + PIO_LED_BASE ) & ( unsigned long) ( HW_REGS_MASK ) );
h2p_lw_seg_addr = virtual_base + ( ( unsigned long ) ( ALT_LWFPGASLVS_OFST + SEG7_LUT_0_BASE ) & ( unsigned long) ( HW_REGS_MASK ) );
// toggle the LEDs a bit
loop_count = 0;
led_mask = 0x01;
led\_direction = 0; // 0: left to right direction
*(uint32_t *)h2p_lw_led_addr = 0x3FF;
// wait 2s
     usleep( 2000*1000 );
while( loop_count < 60 ) {</pre>
      // control led, add ~ because the led is High-active
     *(uint32_t *)h2p_lw_led_addr = led_mask;
| usleep( 100*1000 );
*(uint32_t *)h2p_lw_seg_addr = loop_count;
     // wait 1s
     usleep( 1000*1000 );
     // update led mask
     if (led direction == 0) {
           if (led_mask == (0x01 << (PIO_LED_DATA_WIDTH-1)))</pre>
                led_direction = 1;
     }else{
           led mask >>= 1;
           if (led_mask == 0x01) {
                led_direction = 0;
                loop_count++;
} // while
```



HDL files: 將多餘的七段顯示器註解,並在 soc\_system 裡面宣告 LED 和七段顯示器的模組

```
/////// HEX0 ///////

output [6:0] HEX0,

/*

/////// HEX1 ///////

output [6:0] HEX1,

/////// HEX2 ///////

output [6:0] HEX2,

/////// HEX3 ///////

output [6:0] HEX3,

/////// HEX4 ///////

output [6:0] HEX4,

/////// HEX5 ///////

output [6:0] HEX5,*/
```

## 2. 實驗結果











## 3. 問題與討論

♣ SOC FPGA 包含 HPS 和 FPGA,可以單獨使用 HPS 或 FPGA,也能兩個一起用,HPS 包含 ARM 處理器、記憶體控制器(AXI-bridge)、I/O 周邊。FPGA 的 BUS 是 Avalon,HPS 和 FPGA 之間要用 AXI-bridge 連接。









