OpenEdv-开源电子网

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

STM32F407+Ucosii+fatfs调试SD卡f_write返回9

[复制链接]

1

主题

10

帖子

0

精华

初级会员

Rank: 2

积分
120
金钱
120
注册时间
2019-9-5
在线时间
25 小时
发表于 2020-11-4 16:50:02 | 显示全部楼层 |阅读模式
5金钱
STM32F407VE,RAM192KB,最近调SD卡,裸机跑没问题,可以从创建文件夹,往file.csv中写数据,但是加入操作系统后,发现可以创建文件夹KEY_UP和文件file.csv,但是数据就是写不进去,仿真得出f_write返回值为9,没有找到原因。。。
另外问题,Fatfs的内存分配多少比较合适,最近刚开始看内存分配,发现偶尔ucosii+fatfs程序初上电状态不对,求大佬们给点建议=。=
main.c文件
u8 ress;
static void        Task_Start(void *p_arg)
{       
        u32 free,total;
        u8 res;
        (void)p_arg;       
       
    OS_CPU_SysTickInit(168000000/OS_TICKS_PER_SEC);                               
        NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);
        BSP_GPIO_Init();
    BSP_USART1_Init(115200);       
        BSP_CAN_Init(BPS_500K);
       
        my_mem_init(SRAMIN);                                       
        disk_initialize(0);                                               
        FATFS_Init();                                               
       
        f_mount(fs[0],"0:",1);                                        
        FATFS_GetFree("0:",&total,&free);               
       
        ress = f_mkdir("KEY_UP");
        ress = f_open(file, "KEY_UP/file.csv", FA_CREATE_ALWAYS | FA_WRITE);
        do
        {
                ress = f_write(file, buffer1, 5,&bw);
                if(ress)
                {
                        break;
                }
        }
        while (bw < 100);
        ress = f_close(file);
               
        OS_MboxMsg_BoardTest = OSMboxCreate((void*)0);
        OS_MboxMsg_CanSend   = OSMboxCreate((void*)0);
        OSStatInit();                                                                                               

        OSTaskCreate(Task_CanSend,                (void *)0,        (OS_STK *)&TASK_CANSEND_STK                [TASK_CANSEND_STK_SIZE                -1],        4);
        OSTaskCreate(Task_BoardTest,        (void *)0,        (OS_STK *)&TASK_BOARDTEST_STK        [TASK_BOARDTEST_STK_SIZE        -1],        5);
        OSTaskCreate(Task_LedManage,        (void *)0,        (OS_STK *)&TASK_LEDMAN_STK                [TASK_LEDMAN_STK_SIZE                -1],        6);
//        OSTaskCreate(Task_SDCardManage,        (void *)0,        (OS_STK *)&TASK_SDCARD_STK                [TASK_SDCARD_STK_SIZE                -1],        7);
//        OSTaskCreate(Task_Other,                (void *)0,        (OS_STK *)&TASK_OTHER_STK                [TASK_OTHER_STK_SIZE                -1],        7);
        while(1)
        {
                OSTaskSuspend(START_TASK_PRIO);                                                        
        }

}

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

21

主题

2205

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
5141
金钱
5141
注册时间
2014-8-26
在线时间
1317 小时
发表于 2020-11-4 20:20:19 | 显示全部楼层
文件是否打开成功了?
回复

使用道具 举报

1

主题

10

帖子

0

精华

初级会员

Rank: 2

积分
120
金钱
120
注册时间
2019-9-5
在线时间
25 小时
 楼主| 发表于 2020-11-5 08:11:41 | 显示全部楼层
login_FAE 发表于 2020-11-4 20:20
文件是否打开成功了?

文件打开成功了 f_open返回0
回复

使用道具 举报

1

主题

10

帖子

0

精华

初级会员

Rank: 2

积分
120
金钱
120
注册时间
2019-9-5
在线时间
25 小时
 楼主| 发表于 2020-11-5 14:53:13 | 显示全部楼层
原因找到了,应该是在f_close函数执行时,f_write并没有执行完,SD卡写入需要时间,而在裸机能执行的原因是我在f_close执行前加了一句printf("f_write ok"),将程序拖慢SD卡写入成功。
        ress = f_mkdir("KEY_UP");
        ress = f_open(file, "KEY_UP/file.csv", FA_CREATE_ALWAYS | FA_WRITE);
        do
        {
                ress = f_write(file, buffer1, 5,&bw);
                if(ress)
                {
                        break;
                }
        }
        while (bw < 100);
        OSTimeDlyHMSM(0,0,0,20);      //加入延时
        ress = f_close(file);
求解:(1)我并不知道这个写入需要多久。
          (2)目前我把外部RAM和CCM的内存全屏蔽了,只用了内部RAM的50KB,不太清楚fatfs一般需要开多大内存。
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2020-11-6 01:18:46 | 显示全部楼层
tyb0 发表于 2020-11-5 14:53
原因找到了,应该是在f_close函数执行时,f_write并没有执行完,SD卡写入需要时间,而在裸机能执行的原因是 ...

写入时间是不可控的,可能几十ms,可能几百ms,甚至上秒
看你写入的数据长度,以及当前SD卡的状态
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-21 10:55

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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