2018-12-17 10:44:30 +08:00
|
|
|
/*
|
2021-03-14 15:33:55 +08:00
|
|
|
* Copyright (c) 2006-2021, RT-Thread Development Team
|
2018-12-17 10:44:30 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*
|
|
|
|
* Change Logs:
|
|
|
|
* Date Author Notes
|
|
|
|
* 2018-12-14 balanceTWK add sdcard port file
|
2021-02-26 10:23:01 +08:00
|
|
|
* 2021-02-26 Meco Man fix a bug that cannot use fatfs in the main thread at starting up
|
2018-12-17 10:44:30 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <rtthread.h>
|
|
|
|
|
2018-12-18 14:07:38 +08:00
|
|
|
#ifdef BSP_USING_SDCARD
|
2018-12-17 10:44:30 +08:00
|
|
|
|
|
|
|
#include <dfs_elm.h>
|
|
|
|
#include <dfs_fs.h>
|
2022-01-11 15:20:14 +08:00
|
|
|
#include <dfs_file.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <sys/statfs.h>
|
2018-12-17 10:44:30 +08:00
|
|
|
#include "drv_spi.h"
|
|
|
|
#include "spi_msd.h"
|
|
|
|
|
2019-04-12 10:18:57 +08:00
|
|
|
#define DBG_TAG "app.card"
|
|
|
|
#define DBG_LVL DBG_INFO
|
2018-12-17 10:44:30 +08:00
|
|
|
#include <rtdbg.h>
|
|
|
|
|
2021-04-17 16:28:09 +08:00
|
|
|
static void sd_mount(void *parameter)
|
2018-12-17 10:44:30 +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!");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-17 16:28:09 +08:00
|
|
|
static int onboard_sdcard_mount(void)
|
2018-12-17 10:44:30 +08:00
|
|
|
{
|
|
|
|
rt_thread_t tid;
|
|
|
|
|
2021-02-26 10:23:01 +08:00
|
|
|
if (dfs_mount("sd0", "/", "elm", 0, 0) == RT_EOK)
|
2018-12-17 10:44:30 +08:00
|
|
|
{
|
2021-02-26 10:23:01 +08:00
|
|
|
LOG_I("sd card mount to '/'");
|
2018-12-17 10:44:30 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2021-02-26 10:23:01 +08:00
|
|
|
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:44:30 +08:00
|
|
|
}
|
2021-02-26 10:23:01 +08:00
|
|
|
|
2018-12-17 10:44:30 +08:00
|
|
|
return RT_EOK;
|
|
|
|
}
|
2021-04-17 16:28:09 +08:00
|
|
|
INIT_APP_EXPORT(onboard_sdcard_mount);
|
2018-12-17 10:44:30 +08:00
|
|
|
|
|
|
|
static int rt_hw_spi1_tfcard(void)
|
|
|
|
{
|
|
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
|
|
rt_hw_spi_device_attach("spi1", "spi10", GPIOC, GPIO_PIN_3);
|
|
|
|
return msd_init("sd0", "spi10");
|
|
|
|
}
|
|
|
|
INIT_DEVICE_EXPORT(rt_hw_spi1_tfcard);
|
|
|
|
|
2018-12-18 14:07:38 +08:00
|
|
|
#endif /* BSP_USING_SDCARD */
|
2018-12-17 10:44:30 +08:00
|
|
|
|