SDIO的一线式和四线式
SDIO(Secure Digital Input/Output)是一种用于在嵌入式系统中连接外部设备的标准接口。在SDIO标准中,一线式和四线式是指SDIO接口的不同工作模式。
一线式(Single-Line Mode):
工作原理: 在一线式模式下,SDIO接口仅使用单个数据线进行通信。这个模式通常用于相对简单的应用,其中数据传输速度要求不是很高。
适用情境: 适用于对数据传输速度要求不高的场景,例如连接一些低速外设。
四线式(Four-Line Mode):
工作原理: 在四线式模式下,SDIO接口使用四根线进行通信,包括一个命令线、一个数据线、一个时钟线和一个电源线。这个模式支持更高的数据传输速度。
适用情境: 适用于对数据传输速度有较高要求的应用,例如连接高速外设,比如摄像头、Wi-Fi模块等。
选择一线式还是四线式取决于具体的应用需求。如果应用对速度要求不高,或者对硬件资源有限,可以选择一线式。如果需要更高的数据传输速度,特别是在连接高速外设的情况下,四线式可能更为合适。
需要注意的是,使用四线式模式可能会对系统的硬件和软件设计提出更高的要求,因为需要支持更复杂的通信协议和更高的时钟频率。
STM32的SDIO一线式驱动[SD NAND]([SD NAND | MK-米客方德])
有些平台和MCU没有SDIO接口的,STM32大部分型号有SDIO接口,具体可以看芯片手册,
程序代码
SD NAND初始化
/**
* @brief初始化SD卡
* @param无
* @retval返回值:0 初始化正确;其他值,初始化错误
*/uint8_tsd_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)
{
return1;
}
//SD_Error = HAL_SD_ConfigWideBusOperation(&g_sdcard_handler, SDIO_BUS_WIDE_4B);/* 使能宽总线模式,-O0 优化会有问题 *///if (SD_Error != HAL_OK)//{//return 2;//}
return0;}
测试SD NAND的写入
/**
* @brief初始化SD卡
* @param无
* @retval返回值:0 初始化正确;其他值,初始化错误
*/uint8_tsd_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)
{
return1;
}
//SD_Error = HAL_SD_ConfigWideBusOperation(&g_sdcard_handler, SDIO_BUS_WIDE_4B);/* 使能宽总线模式,-O0 优化会有问题 *///if (SD_Error != HAL_OK)//{//return 2;//}
return0;}
测试SD NAND的读出
/**
* @brief测试SD卡的读取
*@note从secaddr地址开始,读取seccnt个扇区的数据
* @paramsecaddr : 扇区地址
* @paramseccnt: 扇区数
* @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:rn", secaddr);
for(i =0; i < seccnt *512; i++)
{
printf("%x ", buf[i]);/* 打印secaddr开始的扇区数据 */
}
printf("rnDATA ENDEDrn");
lcd_show_string(30,170,200,16,16,"USART1 Send Data Over!", BLUE);
}
else
{
printf("err:%drn", sta);
lcd_show_string(30,170,200,16,16,"SD read Failure! ", BLUE);
}
myfree(SRAMIN, buf);/* 释放内存 */}
实验现象
使用的芯片是MK-米客方德的工业级芯片MKDV1GIL-AS,
需要工程的可以联系MK-米客方德。