久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3693|回復: 0
打印 上一主題 下一主題
收起左側

sopc自定義外設設計總結

[復制鏈接]
跳轉到指定樓層
樓主
ID:105323 發表于 2016-2-23 03:32 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
這學期一個半月了都在學習自定義外設,開始時做最簡單的從外設,到后來的主外設。一個接著一個做,已經完成了三個自定義外設的設計。
做了這幾個外設后,感覺學到了很多東西。在調試中遇到了很多問題,但都一一解決了。
1、
Nios II 中IOWR和IORD函數默認是32位的。
IOWR(BASE,0,1):在基地址為base的存儲器寫入1,不管你開的存儲器是8位或者16位的,默認都是32位格式的存儲。若開設的是16位,則該使用IOWR_16DIRECT(base,0,1);寫入下一個地址使用IOWR_16DIRECT(base,2,1)或者IOWR_16DIRECT(base+2,0,1)。對于8位的也是一樣的。
IORD函數使用和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文件中對應的是:
#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)

這主要是因為設計的Slave總線數據時16位的,若直接使用IOWR和IORD會導致Slave總線的Address錯誤。若是32位的數據線,則可以直接使用,因為這兩個函數默認的就是偏移量直接做乘以4處理。
3、
片上ram是以字節存儲的,所以,在設計主外設時,32位數據線的master,其地址對應的加4,16位加2。

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 91欧美| 亚洲欧洲一区二区 | 在线一级片 | 久操伊人 | 亚洲视频在线观看免费 | 一区视频在线 | 国产精品伦一区二区三级视频 | 2022精品国偷自产免费观看 | 欧美伊人 | 日韩毛片在线观看 | 欧美日本韩国一区二区三区 | 一区二区av在线 | 在线国产一区 | 欧美高清视频 | 91精品国产91久久久久福利 | 羞羞的视频免费在线观看 | www久久久 | 中文字幕一区二区三区四区 | 男人的天堂在线视频 | 欧产日产国产精品视频 | 欧美aaaa视频 | 日韩精品一区二区三区中文字幕 | 91精品国产综合久久久久久首页 | av天天干| 国产精品一区二区免费看 | 天天躁日日躁xxxxaaaa | 中文字幕在线欧美 | 亚洲高清成人在线 | 午夜小视频在线播放 | 成人精品一区 | 亚洲欧美国产精品久久 | 成人性生交大片免费看中文带字幕 | 中文字幕国产精品 | 99综合网 | 玖玖久久 | 婷婷综合五月天 | 农村妇女毛片精品久久久 | 在线资源视频 | 日韩一区精品 | 中文字幕一区二区三区四区 | 久久91 |