打印
[STM32F4]

读取U盘问题

[复制链接]
913|16
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
午夜粪车|  楼主 | 2021-4-12 21:56 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
最近在写一个STM32F429读U盘的IAP,调了快一周了,愣是卡在f_mount函数里面,实在没招了特来请教大家。debug发现:运行到函数disk_read中有个循环程序就卡在此循环中
do
                                        {
                                                status = USBH_MSC_Read10(&USB_OTG_Core, (uint8_t *)buff,sector,SECTOR_SIZE * count);
            USBH_MSC_HandleBOTXfer(&USB_OTG_Core ,&USB_Host);

                                                if (!HCD_IsDeviceConnected(&USB_OTG_Core))
                                                {
                                                        break;
                                                }
                                        }
                                        while (status == USBH_MSC_BUSY );


status == USBH_MSC_BUSY条件始终成立。debug进入“USBH_MSC_Read10”函数中,发现由于变量“USBH_MSC_BOTXferParam.CmdStateMachine”始终为0因此导致返回值为USBH_MSC_BUSY。

使用特权

评论回复
沙发
pengf| | 2021-4-12 21:58 | 只看该作者

然后呢?你是怎么应对这个的呢        

使用特权

评论回复
板凳
午夜粪车|  楼主 | 2021-4-12 22:00 | 只看该作者
通过查找发现在文件“usbh_msc_bot.c”中的函数“USBH_MSC_Init”中会将变量“USBH_MSC_BOTXferParam.CmdStateMachine”赋值非0值,在此函数“USBH_MSC_Init”中设置断点发现运行时不会进入此函数

使用特权

评论回复
地板
午夜粪车|  楼主 | 2021-4-12 22:04 | 只看该作者
进一步查找发现此函数只在文件“usbh_msc_core.c”中的函数“USBH_MSC_Handle”被调用,断点发现“USBH_MSC_Handle”函数不会被执行,不知道是何原因

使用特权

评论回复
5
午夜粪车|  楼主 | 2021-4-12 22:08 | 只看该作者
由于USBH_MSC_Handle均以指针的方式被调用,所以无从查找相关被调用的代码。

使用特权

评论回复
6
llljh| | 2021-4-12 22:10 | 只看该作者
USBH_MSC_Handle函数本来会在U盘枚举成功后被调用

使用特权

评论回复
7
renyaq| | 2021-4-12 22:12 | 只看该作者
如果中断标志没有正确清除,可能造成中断一直执行,调用不到USBH_MSC_Handle,也有可能是别的原因

使用特权

评论回复
8
heweibig| | 2021-4-12 22:14 | 只看该作者
你还可以试一下非官方的USB主机栈 TeenyUSB,主机目前支持U盘、键盘、鼠标以及HUB
代码地址: code.tusb.org

使用特权

评论回复
9
午夜粪车|  楼主 | 2021-4-12 22:16 | 只看该作者
问题已经找到了,是由于函数 "USBH_Process(&USB_OTG_Core, &USB_Host);" 运行次数不够就调用 "f_mount" 函数会出现楼上说的问题。保守估计至少要循环调用"USBH_Process(&USB_OTG_Core, &USB_Host);"函数持续1秒以上才可运行"f_mount"函数。                                                                                                  SysTick_Init();
        do
        {
                USBH_Process(&USB_OTG_Core, &USB_Host);
        }
        while (count_ms<8000 && (USB_Host.gState!=HOST_CLASS || USBH_MSC_BOTXferParam.MSCState!=0x05));//我居然设了最大8秒
        SysTick->CTRL=0x00; //Stop Counter

result = f_mount(&fs,"0:",1);        /* Mount a logical drive */

使用特权

评论回复
10
xxmmi| | 2021-4-12 22:18 | 只看该作者
运行次数是哪里有规定的吗

使用特权

评论回复
11
spark周| | 2021-4-12 22:21 | 只看该作者
U盘的东西 是不是一般都不怎么稳定呢

使用特权

评论回复
12
午夜粪车|  楼主 | 2021-4-12 22:23 | 只看该作者

好的,我明天去单位试一下,多谢各位大侠了哈        

使用特权

评论回复
13
磨砂| | 2021-5-7 13:18 | 只看该作者
这个函数是什么功能的啊

使用特权

评论回复
14
晓伍| | 2021-5-7 13:21 | 只看该作者
地线是怎么接的啊

使用特权

评论回复
15
八层楼| | 2021-5-7 13:28 | 只看该作者
没有遇到过这个问题

使用特权

评论回复
16
观海| | 2021-5-7 13:30 | 只看该作者
是不是带载能力不够啊

使用特权

评论回复
17
guanjiaer| | 2021-5-7 13:31 | 只看该作者
u盘运行很少稳定的

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

867

主题

10194

帖子

3

粉丝