原创
菜农NUC100学习笔记2(USB红杏是怎样出墙的?)
- /*-------------------------------------------------------------------------------
- 文 件 名 : NUC1xxcfg.h
- 创 建 人 : Cortex-M0菜鸟HotPower@163.com,HotPower@126.com,QQ:1270688699
- 个 人 网 站 : www.hotpower.org,www.hotpower.net,www.hotpage.net.cn(合作及导航)
- 创 建 日 期 : 2010.10.18 18:18
- 最近修改日期 : 2010.12.6 3:18
- 创 建 地 点 : 西安大雁塔村队部
- 版 本 号 : V1.05 (红杏版)
- 修 改 原 因 : 规范并使寄存器模式也能控制到所有位
- 说 明 : 菜农掌握本版本的解释权利。
- 由于本头文件为开源,出现问题恕不承担一切责任。
- 备 注 : 本头文件风格归属于菜农的《红杏出墙》系列,堪称“红杏级别”
- 将本文件拷贝到...\CMSIS\CM0\DeviceSupport\Nuvoton\NUC1xx内。
- -------------------------------------------------------------------------------*/
- //----------------------------------------------------//
- typedef enum
- {
- USBD_INTEN_BUS = 0,//1/0使能/禁止BUS事件中断
- USBD_INTEN_USB = 1,//1/0 使能/禁止USB事件中断
- USBD_INTEN_FLD = 2,//1/0使能/禁止 浮动检测中断
- USBD_INTEN_WAKEUP = 3,//1/0 使能/禁止 唤醒功能
- USBD_INTEN_WAKEUP_EN = 8,//1/0 使能/禁止USB 唤醒功能
- USBD_INTEN_INNAK_EN = 15,//1/0 在接到IN标志后,设备响应NAK,使能/禁止中断
- }NU_USBD_INTEN_ENUM;
- typedef volatile union
- {
- NU_REG Regs;
- USBD_INTEN_T Bits;
- }NU_USBD_INTEN_T;
- //----------------------------------------------------//
- typedef enum
- {
- USBD_INTSTS_BUS = 0,//Bus 事件发生,通过ATTR[3:0]可知是哪类Bus事件发生,向EVF[0]写1清标志
- USBD_INTSTS_USB = 1,//USB 事件发生,通过STS[6:4]可知是哪类USB事件发生
- USBD_INTSTS_FLD = 2,//浮动检测事件发生,向EVF[2]写1 清标志
- USBD_INTSTS_WAKEUP = 3,//唤醒事件发生,向EVF[3]写1 清标志
- USBD_INTSTS_EPTF = 16,//1 = USB事件发生,通过STS[xxxx]可知是哪类USB事件发生
- USBD_INTSTS_SETUP = 31,//1 = Setup事件发生,向EVF[31]写1清标志
- }NU_USBD_INTSTS_ENUM;
- typedef volatile union
- {
- NU_REG Regs;
- USBD_INTSTS_T Bits;
- }NU_USBD_INTSTS_T;
- //----------------------------------------------------//
- typedef enum
- {
- USBD_FADDR_FADDR = 0//USB设备的功能地址
- }NU_USBD_FADDR_ENUM;
- typedef volatile union
- {
- NU_REG Regs;
- USBD_FADDR_T Bits;
- }NU_USBD_FADDR_T;
- //----------------------------------------------------//
- typedef enum
- {
- USBD_EPSTS_OVERRUN = 7,//输出数据超过最大有效载荷或安装数据超过8字节
- USBD_EPSTS_EPSTS0 = 8,//端点0的系统状态(000=In ACK~111=同步传输结束)
- USBD_EPSTS_EPSTS1 = 11,//端点1的系统状态(000=In ACK~111=同步传输结束)
- USBD_EPSTS_EPSTS2 = 14,//端点2的系统状态(000=In ACK~111=同步传输结束)
- USBD_EPSTS_EPSTS3 = 17,//端点3的系统状态(000=In ACK~111=同步传输结束)
- USBD_EPSTS_EPSTS4 = 20,//端点4的系统状态(000=In ACK~111=同步传输结束)
- USBD_EPSTS_EPSTS5 = 23,//端点5的系统状态(000=In ACK~111=同步传输结束)
- }NU_USBD_EPSTS_ENUM;
- typedef volatile union
- {
- NU_REG Regs;
- USBD_EPSTS_T Bits;
- }NU_USBD_EPSTS_T;
- //----------------------------------------------------//
- typedef enum
- {
- USBD_ATTR_USBRST = 0,//SE0(single-ended 0) 超过2.5uS,总线复位.
- USBD_ATTR_SUSPEND = 1,//Bus空闲超过3mS,表示 要么电缆没连接,要么主机正在休眠.
- USBD_ATTR_RESUME = 2,//从暂停中恢复
- USBD_ATTR_TIMEOUT = 3,//无响应超过18位时间
- USBD_ATTR_PHY_EN = 4,//使能 PHY
- USBD_ATTR_RWAKEUP = 5,//使USB总线处于K状态,以便远程唤醒.
- USBD_ATTR_USB_EN = 7,//使能 USB
- USBD_ATTR_DPPU_EN = 8,//使能 DP上拉电阻
- USBD_ATTR_PDB = 9,//掉电 PHY, 低电平有效
- }NU_USBD_ATTR_ENUM;
- typedef volatile union
- {
- NU_REG Regs;
- USBD_ATTR_T Bits;
- }NU_USBD_ATTR_T;
- //----------------------------------------------------//
- typedef enum
- {
- USBD_FLDET_FLDET = 0//1/0: 连接/悬空
- }NU_USBD_FLDET_ENUM;
- typedef volatile union
- {
- NU_REG Regs;
- USBD_FLDET_T Bits;
- }NU_USBD_FLDET_T;
- //----------------------------------------------------//
- typedef enum
- {
- USBD_BUFSEG_BUFSEG = 3//仅用于标记设置(总线缓冲有效的开始地址= {BUFSEG[8:3], 3’b000})
- }NU_USBD_BUFSEG_ENUM;
- typedef volatile union
- {
- NU_REG Regs;
- USBD_BUFSEG_T Bits;
- }NU_USBD_BUFSEG_T;
- //----------------------------------------------------//
- typedef enum
- {
- USBD_EP_BUFSEG_BUFSEG = 0//USB缓冲有效的开始地址
- }NU_USBD_EP_BUFSEG_ENUM;
- typedef volatile union
- {
- NU_REG Regs;
- USBD_BUFSEG_T Bits;
- }NU_USBD_EP_BUFSEG_T;
- //----------------------------------------------------//
- typedef enum
- {
- USBD_EP_MXPLD_MXPLD = 0//ReadIN : 发送到主机的数据长度,OUT : 从主机接收到数据的实际长度.)
- //WriteIN : 发送到主机的数据长度,OUT : 从主机接收到数据的最大长度
- //注:一旦MXPLD被写,数据包将在IN/OUT标志到达之后立即发送/接收.
- }NU_USBD_EP_MXPLD_ENUM;
- typedef volatile union
- {
- NU_REG Regs;
- USBD_MXPLD_T Bits;
- }NU_USBD_EP_MXPLD_T;
- //----------------------------------------------------//
- typedef enum
- {
- USBD_EP_CFG_EPT = 0,//端点号
- USBD_EP_CFG_ISOCH = 4,//同步,无握手
- USBD_EP_CFG_STATE = 5,//状态(00 = 禁止端点01 = Out 端点10 = IN 端点11 = 无定义)
- USBD_EP_CFG_DSQ = 7,//主机应答之后,IN标记自动指定为数据0或1.
- USBD_EP_CFG_STALL_CTL = 9,//1 = 在setup阶段允许自动清stall
- }NU_USBD_EP_CFG_ENUM;
- typedef volatile union
- {
- NU_REG Regs;
- USBD_CFG_T Bits;
- }NU_USBD_EP_CFG_T;
- //----------------------------------------------------//
- typedef enum
- {
- USBD_EP_CFGP_CFGP = 0,//IN: 写 ‘1’ 清in ready (由MXPLD置1).OUT: 写 ‘1’清out ready(由MXPLD置1)
- USBD_EP_CFGP_STALL = 1,//置1, 使设备响应STALL
- }NU_USBD_EP_CFGP_ENUM;
- typedef volatile union
- {
- NU_REG Regs;
- USBD_CFGP_T Bits;
- }NU_USBD_EP_CFGP_T;
- //----------------------------------------------------//
- typedef struct
- {
- __IO NU_USBD_EP_BUFSEG_T BUFSEG;//端点0~5的缓冲分割寄存器
- __IO NU_USBD_EP_MXPLD_T MXPLD;//端点0~5的最大有效载荷寄存器
- __IO NU_USBD_EP_CFG_T CFG;//端点0~5的配置寄存器
- __IO NU_USBD_EP_CFGP_T CFGP;//端点0~5的额外配置寄存器
- }NU_USBD_EP_T;
- //----------------------------------------------------//
- typedef enum
- {
- USBD_DRVSE0_DRVSE0 = 0//1/0: 驱动 se0/无
- }NU_USBD_DRVSE0_ENUM;
- typedef volatile union
- {
- NU_REG Regs;
- USBD_DRVSE0_T Bits;
- }NU_USBD_DRVSE0_T;
- //----------------------------------------------------//
- typedef enum
- {
- USBD_PDMA_PDMA_RW = 0,//0 = 从内存读数据到USB缓存,1 = 从USB缓存读数据到内存
- USBD_PDMA_PDMA_EN = 0//0 = 禁止PDMA,1 = 使能PDMA,该位在PDMA传输完毕后自动清零.
- }NU_USBD_PDMA_ENUM;
- typedef volatile union
- {
- NU_REG Regs;
- USBD_PDMA_T Bits;
- }NU_USBD_PDMA_T;
- //----------------------------------------------------//
- typedef struct
- {
- __IO NU_USBD_INTEN_T INTEN;//中断使能寄存器
- __IO NU_USBD_INTSTS_T INTSTS;//中断事件标志寄存器
- __IO NU_USBD_FADDR_T FADDR;//功能地址寄存器
- __IO NU_USBD_EPSTS_T EPSTS;//系统状态寄存器
- __IO NU_USBD_ATTR_T ATTR;//总线状态&归属寄存器
- __I NU_USBD_FLDET_T FLDET;//悬空检测寄存器
- __IO NU_USBD_BUFSEG_T BUFSEG;//缓冲分割寄存器
- __I NU_REG RESERVE0;
- union{
- __IO NU_USBD_EP_T EP[6];//端点数组0~5
- struct{
- __IO NU_USBD_EP_T EP0;//端点0
- __IO NU_USBD_EP_T EP1;//端点1
- __IO NU_USBD_EP_T EP2;//端点2
- __IO NU_USBD_EP_T EP3;//端点3
- __IO NU_USBD_EP_T EP4;//端点4
- __IO NU_USBD_EP_T EP5;//端点5
- };
- };
- __I NU_REG RESERVE1[4];
- __IO NU_USBD_DRVSE0_T DRVSE0;//驱动SE0寄存器(1/0: 驱动 se0/无)
- __I NU_REG RESERVE2[4];
- __IO NU_USBD_PDMA_T PDMA;//PDMA 控制寄存器
- }NU_USBD_T;
- //----------------------------------------------------//
- #define USBDs (*((NU_USBD_T *) USBD_BASE))//定位全局结构变量USBDs
- //----------------------------------------------------//
- #define USBDx ((NU_USBD_T *) USBD_BASE)
- //----------------------------------------------------//
复制代码
关闭
站长推荐
/1
用户315561 2010-12-10 09:31
用户1584993 2010-12-6 15:36