STM32一线式驱动SD NAND和SDIO

SDIO的一线式和四线式
SDIO(Secure Digital Input/Output)是一种用于在嵌入式系统中连接外部设备的标准接口。在SDIO标准中,一线式和四线式是指SDIO接口的不同工作模式。
一线式(Single-Line Mode):
工作原理: 在一线式模式下,SDIO接口仅使用单个数据线进行通信。这个模式通常用于相对简单的应用,其中数据传输速度要求不是很高。
适用情境: 适用于对数据传输速度要求不高的场景,例如连接一些低速外设。
四线式(Four-Line Mode):
工作原理: 在四线式模式下,SDIO接口使用四根线进行通信,包括一个命令线、一个数据线、一个时钟线和一个电源线。这个模式支持更高的数据传输速度。
适用情境: 适用于对数据传输速度有较高要求的应用,例如连接高速外设,比如摄像头、Wi-Fi模块等。
选择一线式还是四线式取决于具体的应用需求。如果应用对速度要求不高,或者对硬件资源有限,可以选择一线式。如果需要更高的数据传输速度,特别是在连接高速外设的情况下,四线式可能更为合适。
需要注意的是,使用四线式模式可能会对系统的硬件和软件设计提出更高的要求,因为需要支持更复杂的通信协议和更高的时钟频率。
STM32的SDIO一线式驱动SD NAND
有些平台和MCU没有SDIO接口的,STM32大部分型号有SDIO接口,具体可以看芯片手册,
程序代码

SD NAND初始化
/**

  • @brief 初始化SD卡

  • @param 无

  • @retval 返回值:0 初始化正确;其他值,初始化错误
    */uint8_t sd_init(void){
    uint8_t SD_Error;

    /* 初始化时的时钟不能大于400KHZ /
    g_sdcard_handler.Instance = SDIO;
    g_sdcard_handler.Init.ClockEdge = SDIO_CLOCK_EDGE_RISING; /
    上升沿 /
    g_sdcard_handler.Init.ClockBypass = SDIO_CLOCK_BYPASS_DISABLE; /
    不使用bypass模式,直接用HCLK进行分频得到SDIO_CK /
    g_sdcard_handler.Init.ClockPowerSave = SDIO_CLOCK_POWER_SAVE_DISABLE; /
    空闲时不关闭时钟电源 /
    g_sdcard_handler.Init.BusWide = SDIO_BUS_WIDE_1B; /
    1位数据线 /
    g_sdcard_handler.Init.HardwareFlowControl = SDIO_HARDWARE_FLOW_CONTROL_ENABLE; /
    开启硬件流控 /
    g_sdcard_handler.Init.ClockDiv = SDIO_TRANSFER_CLK_DIV; /
    SD传输时钟频率最大25MHZ */

    SD_Error = HAL_SD_Init(&g_sdcard_handler);
    if (SD_Error != HAL_OK)
    {
    return 1;
    }
    // SD_Error = HAL_SD_ConfigWideBusOperation(&g_sdcard_handler, SDIO_BUS_WIDE_4B); /* 使能宽总线模式,-O0 优化会有问题 */// if (SD_Error != HAL_OK)// {// return 2;// }

    return 0;}
    测试SD NAND的写入
    /**

  • @brief 初始化SD卡

  • @param 无

  • @retval 返回值:0 初始化正确;其他值,初始化错误
    */uint8_t sd_init(void){
    uint8_t SD_Error;

    /* 初始化时的时钟不能大于400KHZ /
    g_sdcard_handler.Instance = SDIO;
    g_sdcard_handler.Init.ClockEdge = SDIO_CLOCK_EDGE_RISING; /
    上升沿 /
    g_sdcard_handler.Init.ClockBypass = SDIO_CLOCK_BYPASS_DISABLE; /
    不使用bypass模式,直接用HCLK进行分频得到SDIO_CK /
    g_sdcard_handler.Init.ClockPowerSave = SDIO_CLOCK_POWER_SAVE_DISABLE; /
    空闲时不关闭时钟电源 /
    g_sdcard_handler.Init.BusWide = SDIO_BUS_WIDE_1B; /
    1位数据线 /
    g_sdcard_handler.Init.HardwareFlowControl = SDIO_HARDWARE_FLOW_CONTROL_ENABLE; /
    开启硬件流控 /
    g_sdcard_handler.Init.ClockDiv = SDIO_TRANSFER_CLK_DIV; /
    SD传输时钟频率最大25MHZ */

    SD_Error = HAL_SD_Init(&g_sdcard_handler);
    if (SD_Error != HAL_OK)
    {
    return 1;
    }
    // SD_Error = HAL_SD_ConfigWideBusOperation(&g_sdcard_handler, SDIO_BUS_WIDE_4B); /* 使能宽总线模式,-O0 优化会有问题 */// if (SD_Error != HAL_OK)// {// return 2;// }

    return 0;}
    测试SD NAND的读出
    /**

  • @brief 测试SD卡的读取

  • @note 从secaddr地址开始,读取seccnt个扇区的数据

  • @param secaddr : 扇区地址

  • @param seccnt : 扇区数

  • @retval 无
    */void sd_test_read(uint32_t secaddr, uint32_t seccnt){
    uint32_t i;
    uint8_t *buf;
    uint8_t sta = 0;

    buf = mymalloc(SRAMIN, seccnt * 512); /* 申请内存,从SDRAM申请内存 /
    sta = sd_read_disk(buf, secaddr, seccnt); /
    读取secaddr扇区开始的内容 */

    if (sta == 0)
    {
    lcd_show_string(30, 170, 200, 16, 16, “USART1 Sending Data…”, BLUE);
    printf(“SECTOR %d DATA:\r\n”, secaddr);

     for (i = 0; i < seccnt * 512; i++)
     {
         printf("%x ", buf[i]); /* 打印secaddr开始的扇区数据 */
     }
    
     printf("\r\nDATA ENDED\r\n");
     lcd_show_string(30, 170, 200, 16, 16, "USART1 Send Data Over!", BLUE);
    

    }
    else
    {
    printf(“err:%d\r\n”, sta);
    lcd_show_string(30, 170, 200, 16, 16, "SD read Failure! ", BLUE);
    }

    myfree(SRAMIN, buf); /* 释放内存 */}
    实验现象

  • 使用的芯片是MK-米客方德的工业级芯片MKDV1GIL-AS,

    需要工程的可以联系MK-米客方德。

    物联沃分享整理
    物联沃-IOTWORD物联网 » STM32一线式驱动SD NAND和SDIO

    发表评论