STM32用一线式驱动SD NAND,SDIO的一线式驱动

发布者:RadiantDusk最新更新时间:2024-05-14 来源: elecfans关键字:STM32  NAND  SDIO 手机看文章 扫描二维码
随时随地手机看文章

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);/* 释放内存 */}


实验现象

image.png

image.png

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

image.png

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


关键字:STM32  NAND  SDIO 引用地址:STM32用一线式驱动SD NAND,SDIO的一线式驱动

上一篇:IAP技术助力STM32进行程序更新
下一篇:STM32单片机实现固件在线升级(IAP)

推荐阅读最新更新时间:2024-11-13 17:20

stm32之滴答定时器(3):滴答定时器的初始化设置
所谓初始化呢,实际就是对于定时器的参数的设置,这里实际只有一个函数,SysTick_Config,这个函数如下 static __INLINE uint32_t SysTick_Config(uint32_t ticks) { if (ticks SysTick_LOAD_RELOAD_Msk) return (1); SysTick- LOAD = (ticks & SysTick_LOAD_RELOAD_Msk) - 1; NVIC_SetPriority (SysTick_IRQn, (1 __NVIC_PRIO_BITS) - 1);
[单片机]
STM32 基础系列教程 4 – 基本定时器
前言 学习stm32 基本定时器的使用,用基本定时器产生定时500ms定时中断,控制LED闪烁。 示例详解 基于硬件平台: STM32F10C8T6最小系统板, MCU 的型号是 STM32F103c8t6, 使用stm32cubemx 工具自动产生的配置工程,使用KEIL5编译代码。 本示例所用的最小系统板原理图: 从本节开始,关于CUBEMX工具及KEIL工具的操作将不再细讲,如果还有不熟悉的可以查看之前的教程文档。下面直接介绍工程配置: 系统时钟树 定时器配置 引脚配置 中断配置 工程代码 分别在tim.c stm32f1xx_it.c 及main.c 中加入如下图所示代码:
[单片机]
<font color='red'>STM32</font> 基础系列教程 4 – 基本定时器
STM32学习笔记---SysTick定时器
Q:什么是SYSTick定时器? SysTick 是一个24 位的倒计数定时器,当计到0 时,将从RELOAD 寄存器中自动重装载定时初值。只要不把它在SysTick 控制及状态寄存器中的使能位清除,就永不停息。 Q:为什么要设置SysTick定时器? (1)产生操作系统的时钟节拍 SysTick定时器被捆绑在NVIC中,用于产生SYSTICK异常(异常号:15)。在以前,大多操作系统需要一个硬件定时器来产生操作系统需要的滴答中断,作为整个系统的时基。因此,需要一个定时器来产生周期性的中断,而且最好还让用户程序不能随意访问它的寄存器,以维持操作系统 心跳 的节律。 (2)便于不同处理器之间程序移植。 Cortex‐M3处
[单片机]
STM32学习笔记(五)---NVIC
F407在内核水平上搭载了一个异常响应系统,支持为数众多的系统异常和中断,其中系统异常有10个,中断有82个。 一、NVIC简介 NVIC是嵌套向量中断控制器,控制着整个芯片中断相关的功能,它跟内核紧密耦合,是内核里面的一个外设。 在配置中断的时候一般只用ISER、ICER和IP这三个寄存器,ISER用来使能中断,ICER用来失能中断,IP用来设置中断的优先级。 二、中断优先级 优先级定义 NVIC有一个专门的中断优先级寄存器NVIC_IPRx,来配置外部中断的优先级,IPR宽度为8bit,原则上每个外部中断可配置的优先级为0-255,数值越小,优先级越高。 F407中只使用了高4位,bit 表达优先级的这4b
[单片机]
<font color='red'>STM32</font>学习笔记(五)---NVIC
谈谈晶振的原理以及晶振和STM32的关系
01 压电效应 压电效应: 某些电介质在沿一定方向上受到外力的作用而变形时,其内部会产生极化现象,同时在它的两个相对表面上出现正负相反的电荷。 正压电效应: 当外力去掉后,电介质又会恢复到不带电的状态。 逆压电效应: 当作用力的方向改变时,电荷的极性也随之改变。相反,当在电介质的极化方向上施加电场,这些电介质也会发生变形,电场去掉后,电介质的变形随之消失。 当在晶体表面上施加机械压力时,与机械压力成比例的电压出现在晶体上。该电压会导致晶体失真,失真的量将与施加的电压成比例,并且还与施加在晶体上的交流电压成正比,从而导致晶体以其固有频率振动。这种压电效应会产生机械振动或振荡,可用来代替以前的振荡器中的标准LC振荡电路。 下图展示了:
[单片机]
谈谈晶振的原理以及晶振和<font color='red'>STM32</font>的关系
stm32的八种GPIO配置模式
1. 模拟输入; 2. 浮空输入; 3. 上拉输入; 4. 下拉输入; 5. 开漏输出; 6. 推挽输出; 7. 复用开漏输出; 8. 复用推挽输出 具体的: 1.模拟输入 从上图我们可以看到,我觉得模拟输入最重要的一点就是,他不经过输入数据寄存器,所以我们无法通过读取输入数据寄存器来获取模拟输入的值,我觉得这一点也是很好理解的,因为输入数据寄存器中存放的不是0就是1,而模拟输入信号不符合这一要求,所以自然不能放进输入数据寄存器。该输入模式,使我们可以获得外部的模拟信号。 2.浮空输入 该输入状态,我的理解是,它的输入完全由外部决定,我觉得在数据通信中应该可以使用该模式。应为在数据通信中,我们直观的理解就是线路两端连接着发送端
[单片机]
<font color='red'>stm32</font>的八种GPIO配置模式
stm32f2xx与stm32f10x在正交编码器应用定时器初始化中的区别
注意: 如果stm32f2xx系列上面的网址的代码要做适当修改。 以下说重点:stm32f2xx系列,在调试中对GPIO的初始化,切记选择GPIO_Mode_AF模式,即端口复用。 随后,要做端口映射处理,即调用:GPIO_PinAFConfig()函数。 这2个方式不选择,timer是不会有反应的 本人是stm32f207,花了4天惨痛代价。 以下贴代码: /* Private define ------------------------------------------------------------*/ #define ENCODER_TIMER TIM3 //
[单片机]
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved