久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费
標(biāo)題:
sopc自定義外設(shè)設(shè)計總結(jié)
[打印本頁]
作者:
51黑黑黑
時間:
2016-2-23 03:32
標(biāo)題:
sopc自定義外設(shè)設(shè)計總結(jié)
這學(xué)期一個半月了都在學(xué)習(xí)自定義外設(shè),開始時做最簡單的從外設(shè),到后來的主外設(shè)。一個接著一個做,已經(jīng)完成了三個自定義外設(shè)的設(shè)計。
做了這幾個外設(shè)后,感覺學(xué)到了很多東西。在調(diào)試中遇到了很多問題,但都一一解決了。
1、
Nios II 中IOWR和IORD函數(shù)默認(rèn)是32位的。
IOWR(BASE,0,1):在基地址為base的存儲器寫入1,不管你開的存儲器是8位或者16位的,默認(rèn)都是32位格式的存儲。若開設(shè)的是16位,則該使用IOWR_16DIRECT(base,0,1);寫入下一個地址使用IOWR_16DIRECT(base,2,1)或者IOWR_16DIRECT(base+2,0,1)。對于8位的也是一樣的。
IORD函數(shù)使用和IOER是類似的。
2、
Avalon slave文件中:
assign acc_reg_selected = !avs_s1_address[2] & !avs_s1_address[1] & !avs_s1_address[0]; //address 000
assign cal_h_reg_selected = !avs_s1_address[2] & !avs_s1_address[1] & avs_s1_address[0]; //address 001
assign cal_l_reg_selected = !avs_s1_address[2] & avs_s1_address[1] & !avs_s1_address[0]; //address 010
assign nuc_reg_selected = !avs_s1_address[2] & avs_s1_address[1] & avs_s1_address[0]; //address 011
assign nonuc_reg_selected = avs_s1_address[2] & !avs_s1_address[1] & !avs_s1_address[0]; //address 100
assign finish_reg_selected = avs_s1_address[2] & !avs_s1_address[1] & avs_s1_address[0]; //address 101
在reg.h文件中對應(yīng)的是:
#define IORD_ALTERA_AVALON_NUC_CONTROLLER_ACC(base) IORD_16DIRECT(base, 0)
#define IOWR_ALTERA_AVALON_NUC_CONTROLLER_ACC(base, data) IOWR_16DIRECT(base, 0, data)
#define ALTERA_AVALON_NUC_CONTROLLER_ACC_MSK (0x1)
#define ALTERA_AVALON_NUC_CONTROLLER_ACC_OFST (0)
#define IORD_ALTERA_AVALON_NUC_CONTROLLER_CAL_H(base) IORD_16DIRECT(base, 2)
#define IOWR_ALTERA_AVALON_NUC_CONTROLLER_CAL_H(base, data) IOWR_16DIRECT(base, 2, data)
#define ALTERA_AVALON_NUC_CONTROLLER_CAL_H_MSK (0x1)
#define ALTERA_AVALON_NUC_CONTROLLER_CAL_H_OFST (0)
#define IORD_ALTERA_AVALON_NUC_CONTROLLER_CAL_L(base) IORD_16DIRECT(base, 4)
#define IOWR_ALTERA_AVALON_NUC_CONTROLLER_CAL_L(base, data) IOWR_16DIRECT(base, 4, data)
#define ALTERA_AVALON_NUC_CONTROLLER_CAL_L_MSK (0x1)
#define ALTERA_AVALON_NUC_CONTROLLER_CAL_L_OFST (0)
#define IORD_ALTERA_AVALON_NUC_CONTROLLER_NUC(base) IORD_16DIRECT(base, 6)
#define IOWR_ALTERA_AVALON_NUC_CONTROLLER_NUC(base, data) IOWR_16DIRECT(base, 6, data)
#define ALTERA_AVALON_NUC_CONTROLLER_NUC_MSK (0x1)
#define ALTERA_AVALON_NUC_CONTROLLER_NUC_OFST (0)
#define IORD_ALTERA_AVALON_NUC_CONTROLLER_NONUC(base) IORD_16DIRECT(base, 8)
#define IOWR_ALTERA_AVALON_NUC_CONTROLLER_NONUC(base, data) IOWR_16DIRECT(base, 8, data)
這主要是因為設(shè)計的Slave總線數(shù)據(jù)時16位的,若直接使用IOWR和IORD會導(dǎo)致Slave總線的Address錯誤。若是32位的數(shù)據(jù)線,則可以直接使用,因為這兩個函數(shù)默認(rèn)的就是偏移量直接做乘以4處理。
3、
片上ram是以字節(jié)存儲的,所以,在設(shè)計主外設(shè)時,32位數(shù)據(jù)線的master,其地址對應(yīng)的加4,16位加2。
歡迎光臨 (http://m.zg4o1577.cn/bbs/)
Powered by Discuz! X3.1
主站蜘蛛池模板:
在线免费中文字幕
|
麻豆av免费观看
|
操亚洲
|
一本岛道一二三不卡区
|
亚洲第一区久久
|
麻豆国产一区二区三区四区
|
亚洲精品久
|
精品国产乱码久久久久久闺蜜
|
美女视频.
|
欧美 日韩 国产 一区
|
欧美激情 亚洲
|
久久精品国产一区
|
中文字幕日韩欧美
|
国产一二三视频在线观看
|
嫩草视频入口
|
91亚洲国产成人久久精品网站
|
成人久久久
|
国产精品片aa在线观看
|
岛国在线免费观看
|
欧美日本韩国一区二区
|
日本三级在线网站
|
日韩影音
|
久久激情网
|
中文字幕不卡在线88
|
波多野结衣一区二区
|
av中文在线
|
日韩有码在线观看
|
韩日一区二区
|
一区二区三区国产
|
99免费看
|
国产美女在线播放
|
国产一级片精品
|
欧美在线观看一区
|
久久精品国产a三级三级三级
|
羞羞的视频在线看
|
在线久草
|
国产目拍亚洲精品99久久精品
|
超碰在线国产
|
91精品久久久久久久久中文字幕
|
丝袜 亚洲 另类 欧美 综合
|
亚洲精品v
|