其中hello_led.c是這樣寫IO口的:
IOWR_ALTERA_AVALON_PIO_DATA(LED_PIO_BASE, led);
首先在altera_avalon_pio_regs.h找到定義
#include
#define IORD_ALTERA_AVALON_PIO_DATA(base) IORD(base, 0)
#define IOWR_ALTERA_AVALON_PIO_DATA(base, data) IOWR(base, 0, data)
因此在NIOSII中可以調用#include
(詳情可參見D:alterakits
ios2documents n2cpu_nii51007.pdf 文檔page:7, Table 7–2:
和n2sw_nii5v2.pdf.pdf 文檔page:111, Table 7–1:)
接著在smallsoftwarehello_led_0_syslibDebugsystem_description下的system.h
中,有以下內容:
#define LED_PIO_TYPE "altera_avalon_pio"
#define LED_PIO_BASE 0x00004000
其中LED_PIO_BASE(IO寄存器地址?)為0x00004000同SopcBuilder中設置一致!
(其實在SopcBuilder中有關NiosII的配置,就是通過system.h來傳送給IDE的!)
最后用IOWR(0x00004000, 0, led);替代IOWR_ALTERA_AVALON_PIO_DATA(LED_PIO_BASE, led);
編譯,下載到開發(fā)板上,運行成功!
初級知識,就當是拋磚引玉,這只是庫函數(shù)級,應該還有匯編級代碼,請各位大蝦繼續(xù)!
---