国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

基于Nios II的USB接口模塊設計

發布時間:2010-8-1 13:05    發布者:lavida
關鍵詞: NIOS , USB接口
1.引言  

隨著電路規模越來越大,片上系統(SoC)已經成為IC設計的發展趨勢,相應地也有了更加靈活的片上可編程系統(SOPC)。Nios II CPU是一個基于流水線設計的通用RISC微處理器,擁有五級流水線和指令與數據內存分開的哈佛結構,具有可配置功能。用戶可以根據需求在SOPC Builder中增減IP核,從而實現資源優化。為了構建一個更簡潔高效的片上系統,用戶可以自行開發IP組件,作為用戶自定義邏輯添加到AVALON總線。AVALON總線是一種結構相對簡單的總線,用于連接Nios II和其他外設。它規定了主從部件間的端口連接關系,以及部件間通信的時序關系。  

AVALON總線擁有多種傳輸模式,以適應不同外設要求。基本傳輸模式是在主從外設之間進行單字節,半字或字的傳輸。AVALON總線還支持一些高級傳輸模式,例如支持流操作,支持延時操作,支持多個主設備同時訪問。  

2.用戶自定義邏輯模塊設計流程  

通常來說,EDA廠商及第三方提供的IP核都是通用的,但進行SOPC設計時,用戶可能有特殊需求,這時必須使用用戶自定義邏輯來實現所要的功能。SOPC Builder集成在Altera公司的EDA工具Quartus II中。用戶可以通過SOPC Builder提供的圖形用戶界面從Altera公司提供的IP庫中選取一些組件,如Nios II,DMA,SRAM,FLASH等等,根據實際需要設置這些IP的配置參數。用戶還可以自己編寫HDL代碼模塊作為用戶自定義邏輯方便地添加到SOPC Builder中,設計流程如圖1所示。  

  
圖1 SOPC設計流程  

3.USB接口模塊的添加  

這里以常用的USB控制芯片SL811HS為例詳細介紹如何在Nios II中添加用戶自定義模塊。圖2是系統結構圖。  

3.1 USB控制芯片介紹

SL811HS 是Cypress 公司的嵌入式USB host/slave 接口芯片,支持USB1.1 的全速和低速設備。提供USB 主機的硬件接口及總線管理機制,片內集成SIE、USB 收發器和根HUB,能夠完成嵌入式USB 主機所需的功能。  


  
SL811HS的地址和數據均通過ad[7..0]分時傳輸,通過a0(數據/地址選擇線)電平的高低加以區分,當a0置為低電平時,ad[7..0]上傳輸的是SL811片內寄存器/緩沖區的地址;反之高電平則為數據。nwr、nrd、ncs、nrst分別為寫控制線、讀控制線、片選線和復位線,均是低電平有效,Nios II通過這幾根控制線完成對SL811HS片內緩沖區讀寫、片選和復位等操作。intrq是中斷請求信號線。當SL811HS檢測到外設插入、拔出或者數據發送錯誤、超時、數據溢出等異常情況時,通過將intrq置高電平通知Nios II。  

3.2 USB接口模塊設計   

AVALON總線為用戶提供了非常友好的接口,使得系統搭建時的一些細節問題得到屏蔽,大大減輕了系統搭建的工作量。在SL811HS與AVALON總線的接口轉換verilog代碼中,只需建立SL811HS端口與AVALON總線端口的映射關系即可。nios_intrq、nios_read_n、nios_write_n、nios_cs_n、nios_reset_n、nios_write_data[7..0]、nios_read_data[7..0]、nios_aDDRess分別對應NiosII中的中斷、讀、寫、片選、復位、寫數據、讀數據、地址信號。intrq、nrd、nwr、ncs、nrst、ad[7..0]、a0分別對應SL811HS的中斷、讀、寫、片選、復位、數據/地址線、數據/地址選擇信號。如圖3所示。  

  
圖3 自定義USB接口模塊   

在Quartus II中對模塊功能進行仿真,由于SL811HS是數據/地址復用端口, Nios II對其緩沖區寫的時候,先把地址通過nios_write_data[7..0]發送到ad[7..0],然后把數據通過nios_write_data[7..0]發送到ad[7..0]。從SL811HS緩沖區讀數據的時候,先把緩沖區地址通過nios_write_data[7..0]發送到ad[7..0],然后通過ad[7..0]讀數據到nios_read_data[7..0]中。如圖4所示。  


   
圖4 接口轉換模塊仿真波形  

3.3添加用戶自定義邏輯

在圖形用戶界面SOPC Builder中,左欄有一項是添加用戶邏輯。選擇后,在Bus Userface Type 選中Avlaon Register Slave,設置為靜態地址對齊方式。加入用戶編寫的源代碼文件,同時指定Verilog代碼中各個信號的類型。nios_clk指定為“clk”類型, nios_read_n等指定為“read_n ”類型,nios_write_data[7..0]指定為“writedata” 類型,nios_address指定為“address ”類型,與SL811HS直接相連信號線的都指定為“export”類型。點擊Instantiation選擇Simulate user logic。再點擊Timing,根據SL811HS的時序要求,Setup設置為2,Wait設置為65,Hold設置為5,Unit設置為ns。點擊Finish Editing之后,回到主界面,在System Generation中選擇SDK和HDL,最后點擊Generate。   

當SOPC Builder生成一個Nios II處理器設計時,會完成以下工作:  

1) 系統存儲器映像一致性檢查。對外設地址和中斷優先級進行唯一性驗證,檢查其是否在CPU的有效訪問范圍之內。  
2) 為Nios II系統生成一個定制的軟件開發包SDK。  

生成Nios II處理器系統的硬件設計文件*.ptf,可以用這些文件來創建Nios II系統硬件。  

3.4 SL811HS讀寫函數的實現  

讀寫操作是Nios II與SL811HS最基本的通信方式,Nios II讀SL811HS緩沖區數據的時候,先用IOWR函數把所讀緩沖區的地址發送給SL811HS,然后調用IORD函數,得到的返回值就是緩沖區的數據。Nios II往SL811HS緩沖區寫數據的時候,先發地址,然后調用IOWR函數把數據發送到SL811HS緩沖區的指定地址。在用戶工程中的inc/excalibur.h可以找到USB模塊對應地址,根據這個地址來實現SL811HS寄存器的讀寫操作。Nios II每個寄存器占32位,而地址按字節分配,所以每個寄存器使用4個地址,USB模塊對應的地址寄存器地址為0x00900c00,數據寄存器地址為0x00900c04。  

#define ADDR_REG 0x00900c00  
#define DATA_REG 0x00900c04

sl811_read(u8 reg)  

{IOWR(ADDR_REG,0,reg);  
return IORD(DATA_REG,0);  
}  
sl811_write(u8 reg, u8 val)  
{IOWR(ADDR_REG,0,reg);  
IOWR(DATA_REG,0,val);  
}  

4.總結  

本文作者創新點:用verilog編寫Nios II用戶自定義邏輯模塊,實現AVALON總線時序與USB控制器SL811HS的時序轉換。同時給出了該模塊的底層讀寫函數。本模塊已成功在FPGA上實現視頻傳輸功能。  

SOPC技術利用庫,可以快速生成嵌入式系統。同時,可以方便地把用戶自定義的邏輯加入到系統中,體現了用設計嵌入式系統的靈活性。此外,還可以通過SOPC Builder向處理器中添加用戶自定義的指令,擴充了Nios II指令集。對于原型機的開發,是一種很好的開發方法,且能夠快速地生成最終產品,有效地縮短了開發周期。
本文地址:http://m.qingdxww.cn/thread-18322-1-1.html     【打印本頁】

本站部分文章為轉載或網友發布,目的在于傳遞和分享信息,并不代表本網贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問題,我們將根據著作權人的要求,第一時間更正或刪除。
您需要登錄后才可以發表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區
  • 使用SAM-IoT Wx v2開發板演示AWS IoT Core應用程序
  • 使用Harmony3加速TCP/IP應用的開發培訓教程
  • 集成高級模擬外設的PIC18F-Q71家族介紹培訓教程
  • 探索PIC16F13145 MCU系列——快速概覽
  • 貿澤電子(Mouser)專區

相關視頻

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯系我們
電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: 日本三级视频| 香蕉18xxoo欧美夜视频| 四虎影院视频| 午夜之女人本性| 亚洲精品日韩中文字幕久久久| 亚洲精品国产男人的天堂| 一级女人| 中国一级特黄真人毛片| 一本大道一卡二卡入口2021| 震床吃胸吃乳激情视频| 俄罗斯另类Z0Z0ZOZO| 国产午夜一级鲁丝片| 快播最新电影网站| 色欲AV色欲AV久久麻豆| 中国老妇xxxhd| 香蕉小说| 青青国产成人久久91| 婷婷丁香六月| 四虎影院最新入口| 在线观看亚洲免费| 国产福利一区二区精品| 免费成年人在线视频| 亚洲理论在线a中文字幕| 日本精品在线观看视频| 青草资源站| 亚洲成a人片在线观看中文app| 我要看逼| 中文久草| 久久99re2热在线播放7| 亚洲高清国产拍精品5g| 欧美日韩一二三四区| 亚洲综合在线观看一区www| 天天干天天操天天射| 日本成人一区二区三区| 爽爽影院在线| 四虎影院成人| 中国xxx69| 精品成人在线视频| 亚洲高清免费在线观看| 日本免费人成黄页在线观看视频| 日韩区在线观看|