在中断函数中触发输入输出中断后,判定为IN端点或OUT端点,即调用一个transfer_callback函数,该函数处理了0端点和非0端点(分为非0-IN端点和非0-OUT端点)的数据......然同时当调用cdc_acm_read和cdc_acm_write函数收发数时,会一路调用一个transfer_request函数,在该函数中也对IN端点和OUT端点做了数据处理,仔细对比了下,transfer_callback函数和transfer_request函数中对IN端点和OUT端点的处理程序非常相似,两者的具体区别能帮忙分析下吗?再有,在两个函数中,当为OUT端点时,传输大小和包个数的计数代码为: endpoint_size = ((fifo_length - 1 + endpoint.wMaxPacketSize) / endpoint.wMaxPacketSize) * endpoint.wMaxPacketSize; endpoint_size |= ((fifo_length - 1 + endpoint.wMaxPacketSize) / endpoint.wMaxPacketSize) << UX_DCD_OTG_FS_DIEPTSIZ_PKTCNT_SHIFT; 不动这两个代码,USB的写速率只能接近2MB/s...... 再网上看到这个博客https://www.stmcu.org.cn/module/forum/thread-613504-1-1.html,将这两个代码在transfer_request函数中改为如下: endpoint_size |= (UX_DCD_OTG_FS_DOEPTSIZ_XFRSIZ_MASK & (endpoint.wMaxPacketSize * (fifo_length - 1 + endpoint.wMaxPacketSize))); endpoint_size |= (UX_DCD_OTG_FS_DOEPTSIZ_PKTCNT_SHIFT & (((fifo_length - 1 + endpoint.wMaxPacketSize) / endpoint.wMaxPacketSize) << 19)); 而这时USB的写速率能达到20MB/s,测试了下,有时候会丢包1...... 想请教下这两个函数和速率的问题,还有这个计算传输大小和包个数的公式是怎么理解呢?如果对问题还有疑问,本人会及时回应,拜托大家了,谢谢! |
自已顶帖
评分
查看全部评分
是的,将目标板当成设备,通过USB接口连接到linux主机上,用dd命令测试读写速率的
评分
查看全部评分
endpoint_size |= (UX_DCD_OTG_FS_DOEPTSIZ_XFRSIZ_MASK & (endpoint.wMaxPacketSize * (fifo_length - 1 + endpoint.wMaxPacketSize)));
endpoint_size |= (UX_DCD_OTG_FS_DOEPTSIZ_PKTCNT_SHIFT & (((fifo_length - 1 + endpoint.wMaxPacketSize) / endpoint.wMaxPacketSize) << 19));
不断地进行或运算,总有一天会变成全1的。
应该是改为:
endpoint_size = (UX_DCD_OTG_FS_DOEPTSIZ_XFRSIZ_MASK & (endpoint.wMaxPacketSize * (fifo_length - 1 + endpoint.wMaxPacketSize)));
endpoint_size |= (UX_DCD_OTG_FS_DOEPTSIZ_PKTCNT_SHIFT & (((fifo_length - 1 + endpoint.wMaxPacketSize) / endpoint.wMaxPacketSize) << 19));
这样才可靠吧。
还有,按楼主提供的链接,里面讲述的是Cube的版本过低会出现丢包,楼主可以更新Cube的版本试试。
评分
查看全部评分
首先很感谢您的回复
按照链接那样修改,确实有丢包现象,然后根据您的建议修改,也有丢包现象,但速率又有所提升,您能帮忙理解这两句的含义吗?不是很明白这两句怎么来的......方便加联系方式吗?qq308676264
接口芯片不是外接,而是集成到控制器中的
我只是说如果集成的速度你觉得不够用,可以考虑换用外接的。
这样啊,不过集成的速率是有很大的提升空间,现在一直在做这个优化速率的工作,就像一楼的问题,通过修改该处,还有协议栈的其他地方,现在设备写速率能有40MB/s左右,但会有丢包现象。。。设备读速率还没改这个地方,速率只有3MB/s。。。不过应该都能提升的