2022-01-02 09:14:03 +08:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2006-2022, RT-Thread Development Team
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*
|
|
|
|
* Change Logs:
|
|
|
|
* Date Author Notes
|
|
|
|
* 2021-12-31 BruceOu first implementation
|
2023-06-03 16:28:05 +08:00
|
|
|
* 2023-06-03 CX fixed sf probe error bug
|
2022-01-02 09:14:03 +08:00
|
|
|
*/
|
|
|
|
#include <board.h>
|
|
|
|
#include "drv_spi.h"
|
|
|
|
#include "spi_flash.h"
|
|
|
|
|
|
|
|
#ifdef RT_USING_SFUD
|
|
|
|
#include "spi_flash_sfud.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <rthw.h>
|
|
|
|
#include <finsh.h>
|
|
|
|
|
|
|
|
#define SPI_BUS_NAME "spi0"
|
|
|
|
#define SPI_DEVICE_NAME "spi01"
|
|
|
|
#define SPI_FLASH_DEVICE_NAME "gd25q"
|
|
|
|
|
2023-06-03 16:28:05 +08:00
|
|
|
#define GD25Q_SPI_CS_GPIOX_CLK RCU_GPIOE
|
|
|
|
#define GD25Q_SPI_CS_GPIOX GPIOE
|
2022-01-02 09:14:03 +08:00
|
|
|
#define GD25Q_SPI_CS_GPIOX_PIN_X GPIO_PIN_3
|
|
|
|
|
|
|
|
static int rt_hw_spi_flash_init(void)
|
|
|
|
{
|
|
|
|
rt_err_t res;
|
|
|
|
static struct rt_spi_device spi_dev_gd25q; /* SPI device */
|
2022-01-07 21:32:00 +08:00
|
|
|
static struct gd32_spi_cs spi_cs;
|
|
|
|
spi_cs.GPIOx = GD25Q_SPI_CS_GPIOX;
|
2022-01-02 09:14:03 +08:00
|
|
|
spi_cs.GPIO_Pin = GD25Q_SPI_CS_GPIOX_PIN_X;
|
2023-06-03 16:28:05 +08:00
|
|
|
|
|
|
|
rcu_periph_clock_enable(GD25Q_SPI_CS_GPIOX_CLK);
|
2022-01-02 09:14:03 +08:00
|
|
|
#if defined SOC_SERIES_GD32F4xx
|
2022-01-07 21:32:00 +08:00
|
|
|
gpio_mode_set(spi_cs.GPIOx, GPIO_MODE_OUTPUT, GPIO_PUPD_NONE, spi_cs.GPIO_Pin);
|
2022-01-02 09:14:03 +08:00
|
|
|
gpio_output_options_set(spi_cs.GPIOx, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ, spi_cs.GPIO_Pin);
|
|
|
|
|
|
|
|
gpio_bit_set(spi_cs.GPIOx, spi_cs.GPIO_Pin);
|
|
|
|
#else
|
2022-01-07 21:32:00 +08:00
|
|
|
gpio_init(spi_cs.GPIOx, GPIO_MODE_AF_PP, GPIO_OSPEED_50MHZ, spi_cs.GPIO_Pin);
|
2022-01-02 09:14:03 +08:00
|
|
|
|
|
|
|
#endif
|
2022-01-07 21:32:00 +08:00
|
|
|
res = rt_spi_bus_attach_device(&spi_dev_gd25q, SPI_FLASH_DEVICE_NAME, SPI_BUS_NAME, (void*)&spi_cs);
|
2022-01-02 09:14:03 +08:00
|
|
|
|
2022-01-07 21:32:00 +08:00
|
|
|
if (res != RT_EOK)
|
2022-01-02 09:14:03 +08:00
|
|
|
{
|
|
|
|
rt_kprintf("rt_spi_bus_attach_device() run failed!\n");
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
return RT_EOK;
|
|
|
|
}
|
|
|
|
INIT_DEVICE_EXPORT(rt_hw_spi_flash_init);
|
|
|
|
|
|
|
|
#ifdef RT_USING_SFUD
|
|
|
|
static int rt_hw_spi_flash_with_sfud_init(void)
|
|
|
|
{
|
2023-06-03 16:28:05 +08:00
|
|
|
if (RT_NULL == rt_sfud_flash_probe(SPI_FLASH_DEVICE_NAME, SPI_DEVICE_NAME))
|
2022-01-02 09:14:03 +08:00
|
|
|
{
|
2023-03-17 00:12:16 -04:00
|
|
|
return -RT_ERROR;
|
2022-01-02 09:14:03 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
return RT_EOK;
|
|
|
|
}
|
|
|
|
INIT_COMPONENT_EXPORT(rt_hw_spi_flash_with_sfud_init)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef RT_USING_DFS
|
|
|
|
#include <dfs_fs.h>
|
|
|
|
|
|
|
|
int mnt_init(void)
|
|
|
|
{
|
|
|
|
if (dfs_mount(SPI_FLASH_DEVICE_NAME, "/", "elm", 0, 0) == 0)
|
|
|
|
{
|
|
|
|
rt_kprintf("spi flash mount success !\n");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
rt_kprintf("spi flash mount failed!\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
MSH_CMD_EXPORT(mnt_init, mount spi flash to file system);
|
|
|
|
#endif
|