OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 9397|回复: 8

usb读卡器功能,freertos下运行失败,求指教

[复制链接]

14

主题

40

帖子

0

精华

初级会员

Rank: 2

积分
150
金钱
150
注册时间
2012-2-15
在线时间
9 小时
发表于 2013-12-1 00:52:06 | 显示全部楼层 |阅读模式
  最近学习freertos,移植方便,创建任务什么的运行都挺好,usb读卡功能调用了原子的读卡文件,编译通过,运行usb读卡任务,系统死掉,也无相应的读卡器功能,个人认为是usb中断对freertos系统产生了影响,但是测试了ucos就没什么问题啊,请大侠们指教,问题会出在哪儿啊?
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165309
金钱
165309
注册时间
2010-12-1
在线时间
2108 小时
发表于 2013-12-1 10:51:30 | 显示全部楼层
仿真跟踪代码,看看怎么死的。。。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

0

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
62
金钱
62
注册时间
2019-8-14
在线时间
21 小时
发表于 2019-9-2 22:21:47 | 显示全部楼层
我也遇到了同样的问题,请问楼主解决问题了吗?
回复 支持 反对

使用道具 举报

0

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
62
金钱
62
注册时间
2019-8-14
在线时间
21 小时
发表于 2019-9-2 22:23:57 | 显示全部楼层
我也遇到了同样的问题,请问楼主解决了吗?
回复 支持 反对

使用道具 举报

0

主题

3

帖子

0

精华

新手上路

积分
48
金钱
48
注册时间
2019-7-19
在线时间
12 小时
发表于 2019-11-19 10:04:52 | 显示全部楼层
本帖最后由 社会如此多娇 于 2019-11-19 10:07 编辑

在FREERTOS实时操作系统下使用原子的USB读卡器实验首先需要修改USB_OTG_BSP_uDelay 和USB_OTG_BSP_mDelay 函数,将其换成软件延时,软件延时如下所示(系统时钟168hz)
void s_delay_us(u32 us)
{
                u8 i = 0;
                while(us--)
                {
                        i = 42;
                        while(i--);
                };
}

void s_delay_ms(u32 ms)
{
                u16 i = 0;
                while(ms--)
                {
                        i = 41750;
                        while(i--);
                };
        }

void USB_OTG_BSP_uDelay (const uint32_t usec)
{
           s_delay_us(usec);
}

void USB_OTG_BSP_mDelay (const uint32_t msec)
{  
        s_delay_ms(msec);
}

但是修改之后还是不能正常运行,找了很长时间的原因,发现会进入hardfult异常,原因是“试图切入ARM状态”。
先说原因吧,是因为ftl.c文件里的NAND_EraseBlock(source_block)函数调用了delay_ms(NAND_TBERS_DELAY)函数造成的,下面分析原因。
在实时操作系统下使用原子的USB读卡器例程,接上串口会出打印Error:..\FreeRTOS\portable\RVDS\ARM_CM4F\port.c,441,看port.c文件的441行,提示在中断中调用了API函数要以FromISR结尾。分析441行程序,void vPortEnterCritical( void )
{
    portDISABLE_INTERRUPTS();
    uxCriticalNesting++;    /*临界区嵌套*/
    if( uxCriticalNesting == 1 )
   {
       configASSERT( ( portNVIC_INT_CTRL_REG & portVECTACTIVE_MASK ) == 0 ); /*判断有没有中断发生*/
    }
}

#define portNVIC_INT_CTRL_REG                ( * ( ( volatile uint32_t * ) 0xe000ed04 ) )  中断控制状态寄存器,低8位数据减16为当前发生的终端编号
configASSERT( ( portNVIC_INT_CTRL_REG & portVECTACTIVE_MASK ) == 0 ); 该语句表示进入临界区,有中断发生就报错。
以上分析可知,之所以报错,程序运行错误,是因为进入临界区发生了中断,反过来也可以为正在执行中断函数,运行了包含进入临界区的函数的程序。
分析USB读卡器程序可以看出,所有USB相关的程序都是在OTG_FS_IRQHandler(void)中断函数中执行的,仿真只有在写文件时会出现上述错误。USB读卡器
底层使用的时ftl.c文件里的读写,该文件里的FTL_WriteSectors()写函数会调用FTL_CopyAndWriteToBlock();
FTL_CopyAndWriteToBlock()会调用NAND_EraseBlock(source_block);        
而NAND_EraseBlock(source_block)调用了delay_ms(NAND_TBERS_DELAY)函数,
delay_ms(NAND_TBERS_DELAY)会执行xAlreadyYielded = xTaskResumeAll();语句,
xTaskResumeAll()里包含taskENTER_CRITICAL();也就是进入临界区函数,也就是在这里报错的,将NAND_EraseBlock(source_block)调用了delay_ms(NAND_TBERS_DELAY)改为软件延时则可以正常运行。
回复 支持 反对

使用道具 举报

4

主题

10

帖子

0

精华

初级会员

Rank: 2

积分
52
金钱
52
注册时间
2020-1-9
在线时间
11 小时
发表于 2020-3-13 19:32:33 | 显示全部楼层
社会如此多娇 发表于 2019-11-19 10:04
在FREERTOS实时操作系统下使用原子的USB读卡器实验首先需要修改USB_OTG_BSP_uDelay 和USB_OTG_BSP_mDelay  ...

我参考你的方式进行修改,结果只能显示U盘标识,但是无法打开,请问这是什么原因呢?谢谢
回复 支持 反对

使用道具 举报

4

主题

10

帖子

0

精华

初级会员

Rank: 2

积分
52
金钱
52
注册时间
2020-1-9
在线时间
11 小时
发表于 2020-3-15 14:19:18 | 显示全部楼层
g758993137 发表于 2020-3-13 19:32
我参考你的方式进行修改,结果只能显示U盘标识,但是无法打开,请问这是什么原因呢?谢谢

我找到原因了,时钟没有设置对,没有满足48M
回复 支持 反对

使用道具 举报

3

主题

8

帖子

0

精华

初级会员

Rank: 2

积分
53
金钱
53
注册时间
2020-11-7
在线时间
15 小时
发表于 2021-7-2 13:04:53 | 显示全部楼层
社会如此多娇 发表于 2019-11-19 10:04
在FREERTOS实时操作系统下使用原子的USB读卡器实验首先需要修改USB_OTG_BSP_uDelay 和USB_OTG_BSP_mDelay  ...

可能版本不一样了,现在我手上的NAND usb读卡器裸机正常,加freertos就进入HardFault_Handler,但NAND_EraseBlock(source_block)中没有延时函数!你能把你之前用NAND文件或者工程发我吗
回复 支持 反对

使用道具 举报

3

主题

8

帖子

0

精华

初级会员

Rank: 2

积分
53
金钱
53
注册时间
2020-11-7
在线时间
15 小时
发表于 2021-7-2 19:58:08 | 显示全部楼层
guozhengdong55 发表于 2021-7-2 13:04
可能版本不一样了,现在我手上的NAND usb读卡器裸机正常,加freertos就进入HardFault_Handler,但NAND_Er ...

找到原因了额,正点原子应该跟新以前的bug了,只是我在初始化nand中调用了delay,导致中断中调用了非中断级临界区。问题是解决了,但为什么中断中调用非中断级api会死机还没找到原因
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-22 18:42

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表