当前位置:首页 > 单片机 > 单片机
[导读]usb_init.c这个文件是主要是初始化。函数很简单:/******************************************************************************** Function Name : USB_Init* Description : USB系统初始化* Input : None

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


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

* Function Name : USB_Init

* Description : USB系统初始化

* Input : None.

* Output : None.

* Return : None.

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

void USB_Init(void)

{

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

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

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

pUser_Standard_Requests = &User_Standard_Requests;

/* Initialize devices one by one */

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

}



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



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

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

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

* Function Name : CTR_LP.

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

* 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.

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

* 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 number */

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(...) */

}


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

在嵌入式开发中,STM32的时钟系统因其灵活性和复杂性成为开发者关注的焦点。然而,看似简单的时钟配置背后,隐藏着诸多易被忽视的陷阱,轻则导致系统不稳定,重则引发硬件损坏。本文从时钟源选择、PLL配置、总线时钟分配等关键环...

关键字: STM32 时钟系统

在嵌入式系统开发中,STM32系列微控制器的内部温度传感器因其低成本、高集成度特性,广泛应用于设备自检、环境监测等场景。然而,受芯片工艺差异和电源噪声影响,其原始数据存在±1.5℃的固有误差。本文从硬件配置、校准算法、软...

关键字: STM32 温度传感器

在能源效率与智能化需求双重驱动下,AC-DC转换器的数字控制技术正经历从传统模拟方案向全数字架构的深刻变革。基于STM32微控制器的PFM(脉冲频率调制)+PWM(脉冲宽度调制)混合调制策略,结合动态电压调整(Dynam...

关键字: AC-DC STM32

当前智能家居产品需求不断增长 ,在这一背景下 ,对现有浇花装置缺陷进行了改进 ,设计出基于STM32单片机的全 自动家用浇花机器人。该设计主要由机械结构和控制系统构成 ,机械结构通过麦克纳姆轮底盘与喷洒装置的结合实现机器...

关键字: STM32 麦克纳姆轮 安全可靠 通过性强

用c++编程似乎是让你的Arduino项目起步的障碍吗?您想要一种更直观的微控制器编程方式吗?那你需要了解一下Visuino!这个图形化编程平台将复杂电子项目的创建变成了拖动和连接块的简单任务。在本文中,我们将带您完成使...

关键字: Visuino Arduino ESP32 STM32

基于STM32与LoRa技术的无线传感网络凭借其低功耗、广覆盖、抗干扰等特性,成为环境监测、工业自动化等场景的核心解决方案。然而,如何在复杂电磁环境中实现高效休眠调度与动态信道优化,成为提升网络能效与可靠性的关键挑战。本...

关键字: STM32 LoRa

在实时控制系统、高速通信协议处理及高精度数据采集等对时间敏感的应用场景中,中断响应延迟的优化直接决定了系统的可靠性与性能上限。STM32系列微控制器凭借其灵活的嵌套向量中断控制器(NVIC)、多通道直接内存访问(DMA)...

关键字: STM32 DMA

数字电源技术向高功率密度、高效率与高动态响应方向加速演进,STM32微控制器凭借其基于DSP库的算法加速能力与对LLC谐振变换器的精准控制架构,成为优化电源动态性能的核心平台。相较于传统模拟控制或通用型数字控制器,STM...

关键字: STM32 数字电源

STM32微控制器凭借其针对电机控制场景的深度优化,成为高精度、高可靠性驱动系统的核心选择。相较于通用型MCU,STM32在电机控制领域的核心优势集中体现在FOC(磁场定向控制)算法的硬件加速引擎与PWM死区时间的动态补...

关键字: STM32 电机控制

无线充电技术加速渗透消费电子与汽车电子领域,基于Qi协议的无线充电发射端开发成为智能设备能量补给的核心课题。传统模拟控制方案存在响应滞后、参数调整困难等问题,而基于STM32的数字PID控制结合FOD(Foreign O...

关键字: STM32 无线充电
关闭