金牌会员
 
- 积分
- 1920
- 金钱
- 1920
- 注册时间
- 2013-11-18
- 在线时间
- 268 小时
|
调代码的时候经常要用到串口,每次还要外接串口的话,很不方便,所以就想STM32的USB支持虚拟串口,这样就不需要再外接USB转串口来做串口调试。之前看到资料说STM32的VCP要另外安装驱动才行,不能做到免驱,一惧于这个不方便使用。而且修改官方的VCP源码后使用发现Windows8.1自身就带有STM32 VCP的驱动,就算你把驱动删了,一样通过驱动的网络更新重装安装上,这样也算是可以做到免驱。然后顺便把原子的USMART也放上去了。代码是基于STM32F4最新的Cube HAL库的,目前使用上发现的问题有:发送跟接收都没有相关的标志位或者中断来判断是否完成,现在发送是靠延时来保证,接收就只有靠轮循来查是否有接收
[mw_shl_code=c,true] USBD_CDC_SetTxBuffer(&USBD_Device, (uint8_t*)UserTxBuffer, strlen(UserTxBuffer));
while(USBD_CDC_TransmitPacket(&USBD_Device) == USBD_OK);
delay_us(50);[/mw_shl_code]
[mw_shl_code=c,true] if(USBD_CDC_ReceivePacket(&USBD_Device) == USBD_OK)
{
p = (uint8_t*)strstr((const char*)UserRxBuffer,"\r\n");
if(p)
{
*p = '\0'; //在末尾加入结束符.
len=strlen((const char *)UserRxBuffer); //得到此次接收到的数据长度[/mw_shl_code]
还有问题就是,本来usmart_dev.scan();是放在定时器中断来轮循,结果定时器中断期间,USB的中断无论我怎么配置都没法抢占定时器的中断,导致USB中断在定时器中断无法执行,USB就死了,发送无法正常发送。只有把usmart_dev.scan();放到main里来轮循。
STM32F4_VCP USMART.zip
(4.96 MB, 下载次数: 7068)
|
|