rt-thread/bsp/stm32/stm32f407-atk-explorer/board/ports/drv_sdcard.c

71 lines
1.5 KiB
C
Raw Normal View History

2018-12-17 10:46:07 +08:00
/*
2021-03-14 15:33:55 +08:00
* Copyright (c) 2006-2021, RT-Thread Development Team
2018-12-17 10:46:07 +08:00
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2018-12-13 balanceTWK add sdcard port file
* 2021-05-10 Meco Man fix a bug that cannot use fatfs in the main thread at starting up
2018-12-17 10:46:07 +08:00
*/
#include <rtthread.h>
#ifdef BSP_USING_SDCARD
2018-12-17 10:46:07 +08:00
#include <dfs_elm.h>
#include <dfs_fs.h>
#include <dfs_posix.h>
#define DBG_TAG "app.card"
#define DBG_LVL DBG_INFO
2018-12-17 10:46:07 +08:00
#include <rtdbg.h>
static void sd_mount(void *parameter)
2018-12-17 10:46:07 +08:00
{
while (1)
{
rt_thread_mdelay(500);
if(rt_device_find("sd0") != RT_NULL)
{
if (dfs_mount("sd0", "/", "elm", 0, 0) == RT_EOK)
{
LOG_I("sd card mount to '/'");
break;
}
else
{
LOG_W("sd card mount to '/' failed!");
}
}
}
}
static int onboard_sdcard_mount(void)
2018-12-17 10:46:07 +08:00
{
rt_thread_t tid;
if (dfs_mount("sd0", "/", "elm", 0, 0) == RT_EOK)
2018-12-17 10:46:07 +08:00
{
LOG_I("sd card mount to '/'");
2018-12-17 10:46:07 +08:00
}
else
{
tid = rt_thread_create("sd_mount", sd_mount, RT_NULL,
1024, RT_THREAD_PRIORITY_MAX - 2, 20);
if (tid != RT_NULL)
{
rt_thread_startup(tid);
}
else
{
LOG_E("create sd_mount thread err!");
}
2018-12-17 10:46:07 +08:00
}
2018-12-17 10:46:07 +08:00
return RT_EOK;
}
INIT_APP_EXPORT(onboard_sdcard_mount);
2018-12-17 10:46:07 +08:00
#endif /* BSP_USING_SDCARD */