Edit online

SDMC 配置

23 Dec 2024
Read time: 6 minute(s)

驱动配置

  1. Luban-Lite 根目录下执行 scons --menuconfig,进入 menuconfig 的功能配置界面,按如下选择:
    Board options  --->
        [ ] Using SDMC0
        [*] Using SDMC1
        [ ] Using SDMC2
        [*]   Enable the interrupt of SDMC
            SDMC1 Parameter  --->
                Select SDMC1 BUSWIDTH (sdmc 4-bit mode)  --->
                [ ] Using SDcard hotplug detection
                [ ] SDMC1 connect to a SDIO device
                (3) SDMC1 driver phase
                (0) SDMC1 sample phase
                (100000000) SDMC1 CMU clock frequency
  2. 当使用 RT-Thread 内核时,SDMC 驱动需要依赖 RT-Thread 的 SDIO 设备驱动框架,也是在 menuconfig 界面中打开,否则可略过:
    提示:

    为了简化使用,Using SDMCx 会自动打开 RT-Thread 的 SDIO 设备驱动框架。

    Rt-Thread options  --->
        RT-Thread Components  --->
            Device Drivers  --->
                [*]  Using SD/MMC device driver
                (512) The stack size for sdio irq thread
                (15)  The priority level value of sdio irq thread
                (8192) The stack size for mmcsd thread
                (22)  The priority level value of mmcsd thread
                (16)  mmcsd max partition

SDMC 自定义参数

SDMC 驱动在 menuconfig 中提供了下列扩展参数,方便用户根据板级硬件设计进行调整:
1. SDMC 自定义参数
参数名称 类型 取值范围 功能说明
SDMCx_BUSWIDTH1 Boolean 1 - 是,0 - 否 控制器 x 是否为 1 线模式
SDMCx_BUSWIDTH4 Boolean 1 - 是,0 - 否 控制器 x 是否为 4 线模式
SDMC0_BUSWIDTH8 Boolean 1 - 是,0 - 否 SDMC0 是否支持 8 线
SDMCx_IS_SDIO Boolean 1 - 是,0 - 否 控制器 x 是否用到 SDIO 外设
SDMCx_DRV_PHASE Integer 0 - 3 控制器 x 驱动相位
SDMCx_SMP_PHASE Integer 0 - 3 控制器 x 采样相位
SDMCx_CLK_FREQ Integer 31500000 - 200000000 控制器 x 输入时钟频率范围
提示:

SDMCx_DRV_PHASE 和 SDMCx_SMP_PHASE 分别用于调节发送、接收的信号相位,会影响兼容性,Luban-Lite 提供了调优后的配置,通常不需要修改。

D21x 默认配置

SDMC V1.0 包含三个接口,分别为 SDMC0、SDMC1 和 SDMC2,D21x 提供了三套 SDMC 控制器,默认配置如下:
Board options  --->
    [ ] Using SDMC0
    [*] Using SDMC1
    [ ] Using SDMC2
    [*]   Enable the interrupt of SDMC
        SDMC1 Parameter  --->
            Select SDMC1 BUSWIDTH (sdmc 4-bit mode)  --->
            [ ] Using SDcard hotplug detection
            [ ] SDMC1 connect to a SDIO device
            (3) SDMC1 driver phase
            (0) SDMC1 sample phase
            (100000000) SDMC1 CMU clock frequency

文件系统配置

  • RT-Thread
    如果有文件访问的场景,就需要打开相应的文件系统。以 FatFS 文件系统为例,需要打开 RT-Thread 中的 elm(即 FatFS)配置:
    Rt-Thread options  --->
        RT-Thread Components  --->
            [*] DFS: device virtual file system  --->
                [*]   Using posix-like functions, open/read/write/close
                [*]   Using working directory
                (4)   The maximal number of mounted file system
                (4)   The maximal number of file system type
                (16)  The maximal number of opened files
                [*]   Using mount table for file system
                [*]   Enable elm-chan fatfs
                        elm-chan's FatFs, Generic FAT Filesystem Module  --->
                [ ]   Using devfs for device objects
                [*]   Enable ReadOnly file system on flash
                [ ]   Enable RAM file system
    注意,上面的 Using mount table for filesystem 选项打开后,意味着可以系统启动后会根据一个 Table 配置来自动挂载文件系统。该 Table 定义在 board.c 中:
    #ifdef RT_USING_DFS_MNTTABLE
    #include <dfs_fs.h>
    
    const struct dfs_mount_tbl mount_table[] = {
    #ifdef AIC_USING_SDMC1
        {"sd0", "/sdcard", "elm", 0, 0, 0},
    #endif
        {0}
    };
    #endif
  • Baremetal
    Baremetal 默认打开文件系统配置:
    Local packages options  --->
        Third-party packages options  --->
            [*] DFS: device virtual file system for baremetal mode  --->
                [*]   Using posix-like functions, open/read/write/close
                (4)   The maximal number of mounted file system
                (4)   The maximal number of file system type
                (16)  The maximal number of opened files
                [ ]   Using mount table for file system
                [*]   Enable elm-chan fatfs
                        elm-chan's FatFs, Generic FAT Filesystem Module  --->
                [ ]   Enable ReadOnly file system on flash
                [ ]   Enable RAM file system
    设备上电后会直接将 Baremetal SDMC 设备自动挂载在根目录下。此部分定义在 main.c 中:
    #if defined(LPKG_USING_DFS_ELMFAT) && defined(AIC_SDMC_DRV)
        if (dfs_mount("sdmc", "/", "elm", 0, 0) < 0)
            pr_err("Failed to mount sdmc with FatFS\n");
    #endif

热插拔配置

目前 Luban-Lite 下只实现了 SDMC1 热插拔,用户可根据源码拓展至 SDMC0/2 中:

  • RT-Threadbsp/artinchip/drv/sdmc/drv_sdcard.c
    Board options  --->
        [*] Using SDMC1
            SDMC1 Parameter  --->
                [*] Using SDcard hotplug detection
  • Baremetal: bsp/artinchip/drv_bare/sdmc/sdcard.c
    Board options  --->
        [*] Using SDMC1
            SDMC1 Parameter  --->
                [*] Using SDcard hotplug detection