usb2.0协议学习———usb_init.c(转)

这个文件是主要是初始化。函数很简单:

/*******************************************************************************

* Function Name : USB_Init

* Deion : USB系统初始化

* Input : None.

* Output : None.

* Return : None.

*******************************************************************************/

USB_Init(void)

{

pInformation = &Device_Info; //注册设备信息结构体

pInformation->ControlState = 2; //控制状态为IN_DATA

pProperty = &Device_Property; //注册设备的常用一些函数结构体

pUser_Standard_Rests = &User_Standard_Requests;

/* Initialize devices one by one */

pProperty->Init(); //注册初始化函数

}

从代码中可以看到,首先是注册了一个Device_Info结构体给USB,这个结构体保存着USB的各项信息,接着设置控制状态为IN_DATA,USB初始化只有在这个状态才能接受主机发送过来,接下去注册函数常用的一些函数及标准请求,最后执行注册过的初始化函数。

一看就知道跟中断相关。在该文件中定义了两个函数,分别为低优先级的端点正确传输中断服务程序CTR_LP()和高优先级端点正确传输的中断服务程序CTR_HP()。

在我们的CUstomHID函数中,只用到CTR_LP()函数。该函数中在usb_istr.c中的USB_istr()函数中被调用。CTR就是正确传输,只有检测到ISTR中的CTR位置位后,才会调用CTR_LP()函数。

/*******************************************************************************

* Function Name : CTR_LP.

* Deion : 低优先级的端点正确传输中断服务程序

* Input : None.

* Output : None.

* Return : None.

*******************************************************************************/

void CTR_LP(void)

{

__IO uint16_t wEPVal = 0;

while(((wIstr = _GetISTR()) & ISTR_CTR) != 0) //读取中断状态寄存器的值,看是否是CRT(正确传输中断)

{

EPindex = (uint8_t)(wIstr & ISTR_EP_ID); //获取中断的端点号,

if (EPindex == 0) //如果端点0

{

SaveRState = _GetENDPOINT(ENDP0); //读取端点0的状态寄存器

SaveTState = SaveRState & EPTX_STAT; //保存端点0发送状态

SaveRState &= EPRX_STAT; //保存端点0接收状态

_SetEPRxTxStatus(ENDP0,EP_RX_NAK,EP_TX_NAK); //设置端点0对主机以NAK方式响应所有的接收和发送请求

if ((wIstr & ISTR_DIR) == 0) //如果是IN令牌

{

_ClearEP_CTR_TX(ENDP0); //清除端点0正确发送

In0_Process(); //处理IN令牌包

/* before terminate set Tx & Rx status */

_SetEPRxTxStatus(ENDP0,SaveRState,SaveTState); //在传输之前设置端点0接收发送状态位

return;

}

else//OUT令牌

{

wEPVal = _GetENDPOINT(ENDP0); //获取端点0的端点寄存器的值

if ((wEPVal &EP_SETUP) != 0) //SETUP分组传输完成标志位

{

_ClearEP_CTR_RX(ENDP0); //清除端点0的接收标志位

Setup0_Process(); //端点0建立阶段的数据处理

_SetEPRxTxStatus(ENDP0,SaveRState,SaveTState);//设置端点0阶接收发送标志位

return;

}

else if ((wEPVal & EP_CTR_RX) != 0) //正确接收标志位

{

_ClearEP_CTR_RX(ENDP0); //清除端点0正确标志位

Out0_Process(); //处理OUT令牌包

_SetEPRxTxStatus(ENDP0,SaveRState,SaveTState);//设置端点0的接收发送状态

return;

}

}

}/* if(EPindex == 0) */

else //如果非0端点

{

wEPVal = _GetENDPOINT(EPindex); //获取该端点的端点寄存器的值

if ((wEPVal & EP_CTR_RX) != 0) //正确接收标志

{

_ClearEP_CTR_RX(EPindex); //清除端点正确接收标志

(*pEpInt_OUT[EPindex-1])(); //调用注册过的端点OUT处理函数

} /* if((wEPVal & EP_CTR_RX) */

if ((wEPVal & EP_CTR_TX) != 0) //正确发送标志

{

_ClearEP_CTR_TX(EPindex); //清除正确发送标志

(*pEpInt_IN[EPindex-1])(); //调用注册过的端点IN处理函数

} /* if((wEPVal & EP_CTR_TX) != 0) */

}/* if(EPindex == 0) else */

}/* while(...) */

}

/*******************************************************************************

* Function Name : CTR_HP.

* Deion : 高优先级端点正确传输的中断服务程序

* Input : None.

* Output : None.

* Return : None.

*******************************************************************************/

void CTR_HP(void)

{

uint32_t wEPVal = 0;

while (((wIstr = _GetISTR()) & ISTR_CTR) != 0) //获取中断状态寄存器,且是正确传输中断

{

_SetISTR((uint16_t)CLR_CTR); /* clear CTR flag *///清除正确传输标志

/* extract highest priority endpoint num*/

EPindex = (uint8_t)(wIstr & ISTR_EP_ID); //获取产生中断的端点号

/* process related endpoint register */

wEPVal = _GetENDPOINT(EPindex); //获取端点寄存器的值

if ((wEPVal & EP_CTR_RX) != 0) //端点正确接收标志

{

/* clear int flag */

_ClearEP_CTR_RX(EPindex); //清除正确接收标志

/* call OUT service function */

(*pEpInt_OUT[EPindex-1])(); //调用注册过的端点OUT函数

} /* if((wEPVal & EP_CTR_RX) */

else if ((wEPVal & EP_CTR_TX) != 0) //端点正确发送标志

{

/* clear int flag */

_ClearEP_CTR_TX(EPindex); //清除正确发送标志

/* call IN service function */

(*pEpInt_IN[EPindex-1])(); //调用注册过的端点IN函数

} /* if((wEPVal & EP_CTR_TX) != 0) */

}/* while(...) */

}

### 关于 UniApp 框架推荐资源与教程 #### 1. **Uniapp 官方文档** 官方文档是最权威的学习资料之一,涵盖了从基础概念到高级特性的全方位讲解。对于初学者来说,这是了解 UniApp 架构技术细节的最佳起点[^3]。 #### 2. **《Uniapp 从入门到精通:案例分析与最佳实践》** 该文章提供了系统的知识体系,帮助开发者掌握 Uniapp 的基础知识、实际应用以及开发过程中的最佳实践方法。它不仅适合新手快速上手,也能够为有经验的开发者提供深入的技术指导[^1]。 #### 3. **ThorUI-uniapp 开源项目教程** 这是一个专注于 UI 组件库设计实现的教学材料,基于 ThorUI 提供了一系列实用的功能模块。通过学习此开源项目的具体实现方式,可以更好地理解如何高效构建美观且一致的应用界面[^2]。 #### 4. **跨平台开发利器:UniApp 全面解析与实践指南** 这篇文章按照章节形式详细阐述了 UniApp 的各个方面,包括但不限于其工作原理、技术栈介绍、开发环境配置等内容,并附带丰富的实例演示来辅助说明理论知识点。 以下是几个重要的主题摘选: - **核心特性解析**:解释了跨端运行机制、底层架构组成及其主要功能特点。 - **开发实践指南**:给出了具体的页面编写样例代码,展示了不同设备间 API 调用的方法论。 - **性能优化建议**:针对启动时间缩短、图形绘制效率提升等方面提出了可行策略。 ```javascript // 示例代码片段展示条件编译语法 export default { methods: { showPlatform() { console.log(process.env.UNI_PLATFORM); // 输出当前平台名称 #ifdef APP-PLUS console.log('Running on App'); #endif #ifdef H5 console.log('Running on Web'); #endif } } } ``` #### 5. **其他补充资源** 除了上述提到的内容外,还有许多在线课程视频可供选择,比如 Bilibili 上的一些免费系列讲座;另外 GitHub GitCode 平台上也有不少优质的社区贡献作品值得借鉴研究。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值