#ifndef __USBREG_H
#define __USBREG_H
/* usb設(shè)備中斷定義 usb_devintst usb_devinten usb_devintclr usb_devintdet*/
#define FRAME_INT 0x00000001 //每隔1MS產(chǎn)生一次幀中斷,該中斷用在同步包的傳輸中
#define EP_FAST_INT 0x00000002 //端點的快速中斷,在端點中斷優(yōu)先級中設(shè)置端點優(yōu)先級別
#define EP_SLOW_INT 0x00000004 //端點的慢速中斷,在端點中斷優(yōu)先級中設(shè)置端點優(yōu)先級別
#define DEV_STAT_INT 0x00000008 //usb中斷復(fù)位 掛起或者改變連接的時候觸發(fā)
#define CCEMTY_INT 0x00000010 //命令代碼寄存器為空的時候中斷,標志著寫入的命令已經(jīng)執(zhí)行
#define CDFULL_INT 0x00000020 //命令數(shù)據(jù)寄存器已滿,現(xiàn)在可以讀取數(shù)據(jù)
#define RxENDPKT_INT 0x00000040 //在端點緩沖區(qū)中的當前數(shù)據(jù)包已經(jīng)傳送給CPU
#define TxENDPKT_INT 0x00000080 //傳遞到端點緩沖區(qū)中的包長度和指定的最大長度相等,端點滿
#define EP_RLZED_INT 0x00000100 //端點被使用,在設(shè)置選擇端點或者設(shè)備最大長度的時候完成設(shè)置,置位
#define ERR_INT 0x00000200 //usb的任何總線錯誤中斷
/* usb數(shù)據(jù)傳送長度相關(guān) */
#define PKT_LNGTH_MASK 0x000003FF //接收包長度和發(fā)送包長度設(shè)置的掩碼 usb_rxplen usb_txplen
#define PKT_DV 0x00000400 //usb接受包數(shù)據(jù)有效 在傳輸過程特別是同步端點中有效 usb_rxplen
#define PKT_RDY 0x00000800 //usb接收包指示的長度有效并隨時可以讀出(在使用PKT_DV的情況下)usb_rxplen
/* usb控制字節(jié)定義 usb_ctrl */
#define CTRL_RD_EN 0x00000001 //usb讀模式控制 需要從usb中讀取數(shù)據(jù)
#define CTRL_WR_EN 0x00000002 //usb寫模式控制,需要向usb端點寫入數(shù)據(jù),讀寫完成時,自動清零
#define CTRL_LOG_ENDPOINT_MASK (0X0F<<2)//2-5位
/* usb命令寄存器的命令 usb_cmd_code 8-15位 02為讀 01為寫 05為純命令*/
#define CMD_SET_ADDR 0x00D00500 //設(shè)置設(shè)備地址 后面跟設(shè)備地址 0-6為地址 7為設(shè)備使能 1設(shè)備使能 0設(shè)備不響應(yīng)自身地址的包
#define CMD_CFG_DEV 0x00D80500 //配置設(shè)備,將所有已經(jīng)使能的非控制端點作出響應(yīng)(很重要)
#define CMD_SET_MODE 0x00F30500 //設(shè)置模式包括時鐘 輸入端點 輸出端點 批量端點的ack
#define CMD_RD_FRAME 0x00F50500 //幀編號
#define DAT_RD_FRAME 0x00F50200 //讀取幀編號
#define CMD_RD_TEST 0x00FD0500 //測試寄存器
#define DAT_RD_TEST 0x00FD0200 //讀取測試寄存器,如果usb_clk在運行,那么將返回0xa50f
#define CMD_SET_DEV_STAT 0x00FE0500 //設(shè)置設(shè)備狀態(tài) 包括usb連接 uab掛起或者usb總線復(fù)位
#define CMD_GET_DEV_STAT 0x00FE0500 //獲取設(shè)備狀態(tài)
#define DAT_GET_DEV_STAT 0x00FE0200 //讀取設(shè)備狀態(tài)
#define CMD_GET_ERR_CODE 0x00FF0500 //獲取錯誤代碼
#define DAT_GET_ERR_CODE 0x00FF0200 //讀取錯誤代碼 數(shù)據(jù)低四位是錯誤代碼 0x0000無錯誤
#define CMD_RD_ERR_STAT 0x00FB0500 //讀取錯誤狀態(tài) 包括crc錯誤 pid錯誤 填充錯誤等usb總線錯誤
#define DAT_RD_ERR_STAT 0x00FB0200 //讀取錯誤狀態(tài)
#define DAT_WR_BYTE(x) (0x00000100 | ((x) << 16)) //向usb命令數(shù)據(jù)寄存器寫入數(shù)據(jù),因為只有16-23位是有效的
#define CMD_SEL_EP(x) (0x00000500 | ((x) << 16)) //usb選擇端點
#define DAT_SEL_EP(x) (0x00000200 | ((x) << 16)) //選擇端點 可以獲得端點狀態(tài)端點空 滿或者其他
#define CMD_SEL_EP_CLRI(x) (0x00400500 | ((x) << 16)) //usb選擇端點/清除中斷
#define DAT_SEL_EP_CLRI(x) (0x00400200 | ((x) << 16)) //usb設(shè)置端點狀態(tài)(端點使能,端點暫停 速率反饋等)
#define CMD_SET_EP_STAT(x) (0x00400500 | ((x) << 16)) //
#define CMD_CLR_BUF 0x00F20500
#define DAT_CLR_BUF 0x00F20200 //usb清除端點緩沖區(qū)
#define CMD_VALID_BUF 0x00FA0500 //確認緩沖區(qū),當該命令發(fā)送時,告訴端點下一個in包來的時候?qū)⒍它c緩沖區(qū)數(shù)據(jù)發(fā)送到主機
/* 設(shè)備地址設(shè)置 0-6為地址 7為設(shè)備使能 1設(shè)備使能 0設(shè)備不響應(yīng)自身地址的包*/
#define DEV_ADDR_MASK 0x7F
#define DEV_EN 0x80
/* 設(shè)備配置 所有已經(jīng)使能的非控制端點作出響應(yīng)*/
#define CONF_DVICE 0x01
/* 設(shè)置模式 命令的數(shù)據(jù)定義 */
#define AP_CLK 0x01 //在掛起狀態(tài)是否能夠關(guān)閉48M時鐘
#define INAK_CI 0x02 //控制IN端點的nak中斷 0數(shù)據(jù)處理成功完成之后才返回nak中斷 1
#define INAK_CO 0x04 //控制out端點的nak中斷
#define INAK_II 0x08 //中斷in端點的nak中斷
#define INAK_IO 0x10 //中斷out端點的nak 中斷
#define INAK_BI 0x20 //批量in nak端點的nak中斷
#define INAK_BO 0x40 //批量out端點的nak中斷
/* 設(shè)置設(shè)備狀態(tài)的命令數(shù)據(jù)定義 */
#define DEV_CON 0x01 // 0 connect關(guān)鍵低電平 1 connect管腳高電平
#define DEV_CON_CH 0x02 //連接發(fā)生了改變
#define DEV_SUS 0x04 //設(shè)備被掛起
#define DEV_SUS_CH 0x08 //設(shè)備掛起位發(fā)生變化
#define DEV_RST 0x10 //設(shè)備接收到總線復(fù)位
/* 錯誤代碼數(shù)據(jù)定義 */
#define ERR_EC_MASK 0x0F //錯誤代碼掩碼
#define ERR_EA 0x10 //當前存在錯誤代碼
/* 錯誤狀態(tài)的具體定義 */
#define ERR_PID 0x01 //PID編碼錯誤
#define ERR_UEPKT 0x02 //意外的數(shù)據(jù)包
#define ERR_DCRC 0x04 //數(shù)據(jù)crc錯誤
#define ERR_TIMOUT 0x08 //超時錯誤
#define ERR_EOP 0x10 //數(shù)據(jù)包結(jié)尾錯誤
#define ERR_B_OVRN 0x20 //緩沖區(qū)溢出
#define ERR_BTSTF 0x40 //位填充錯誤
#define ERR_TGL 0x80 //數(shù)據(jù)PID中的錯誤翻轉(zhuǎn)位
/* 端點選擇寄存器返回的端點信息 */
#define EP_SEL_F 0x01 //in端點空或者out端點滿
#define EP_SEL_ST 0x02 //暫停的端點指示器
#define EP_SEL_STP 0x04 //所選端點上一次接受到setup包
#define EP_SEL_PO 0x08 //之前接受到包被setup包覆蓋
#define EP_SEL_EPN 0x10 //設(shè)備發(fā)送nack
#define EP_SEL_B_1_FULL 0x20 //緩沖區(qū)1狀態(tài) 1滿 0空
#define EP_SEL_B_2_FULL 0x40