极速闪存启动:SD与SPI模式的智能初始化指南

最近很多客户朋友在询问我们 CS 创世 SD NAND 能不能使用 SPI 接口,两者使用起来有何区别,下面为大家详细解答。

SD MODE:

CS 创世 SD NAND 支持 SD 模式和 SPI 模式,SD NAND 默认为 SD 模式,上电后,其初始化过程如下:

  1. 配置时钟,0-400KHZ,设置工作模式

  2. 发送 CMD0,使卡进入 idle 状态,该指令没有反馈

  3. 发送 CMD8,如果有反应,那就是 CRC 值与发送的相同,说明该卡兼容 SD2.0 协议,同时还是获取 SD 的工作电压

  4. 发送 CMD55+ACMD41, 判断 SD 卡的上电是否正确,短响应成功说明该卡为 SD 卡(短响应第 31 位为 1,说明为 HC 卡),否则发送 CM0, 有反应说明为 MMC 卡

  5. 发送 CMD2 验证 SD 卡是否正确接入,长响应(CID)

  6. 发送 CMD3,读取 SD 卡的 RCA(地址),短响应

  7. 发送 CMD9,获取 CSD 寄存器来获取卡的相关信息

  8. 发送 CMD7,使能 SD 卡

  9. 配置高速时钟,准备数据传输,一般为 20M-25M

SPI MODE:

  1. 设置 SPI 时钟为低速 0~400khz-------------SD 卡初始化只能在低速模式下进行

  2. 发送至少 74 个周期的时钟信号 ------------- 建议适当多发送一些 (怕有些电路有延时)

  3. 发送 SD 卡命令 CMD0------------------------- 使在 SD 卡收到复位命令时,CS 为有效电平(低电平),则 SD 卡切换到 SPI 模式,进入 IDLE 状态

  4. 发送 CMD8(SD2.0)-------- 针对 SD2.0 进行鉴别同时读取后续 4 个字节返回值,判断其是否支持工作电压(例如:2.7~3.6v 支持则为 0x01aa)

  5. 发送 CMD55+ACMD41(SD2.0)----- 检测初始化是否完成

  6. 发送 CMD58------------------------ 对 SD2.0 版本进一步确认 SD 卡型号(SDHC 为扇区块寻址,普通 SD 卡为字节寻址)

  7. 发送 CMD55+ACMD41(SD1.0)---------------- 检测返回值进行判断为 SD1.0 或 MMC 卡

  8. 发送 CMD55+ACMD41(SD1.0)---------------- 检测初始化是否完成

  9. 发送 CMD16------------------------------------- 设置 SD 卡扇区大小(默认为 512 字节)

设置 SPI 时钟为高速,最大为 25Mhz,初始化完成

SD 模式与 SPI 模式的区别:

1.SD NAND 默认为 SD MODE,而进入 SPI MODE 必须在第一次上电的时候就要点复位

2.SD MODE 默认为单线输出 date0, 但是在高速模式下可以走四线,date0~date3; 在 SD NAND 下走的 SPI MODE ,只能走单线模式,其通信只有 CS(片选)、CLK(时钟)、DI(输入)、DO(输出)

  1. 很多客户由于板子上只有 SPI 接口,所以用 SPI MODE 能让客户减少设计上的压力,不过 SD NAND 使用 SPI MODE 只能走单线,相比于 SD MODE 四线来说传输速度会慢。

  2. 接口连接:

以上为 CS 创世 SD NAND 在 SD MODE 和 SPI MODE 使用时的初始化过程介绍, 目前 CS 创世 SD NAND 在市面上广泛应用,在穿戴类的消费市场,以及航空航天、铁路交通、水利检测等工业领域都有应用,欢迎有兴趣的朋友来电咨询,我们竭诚为您服务。

相关推荐
DS小龙哥14 天前
基于Zynq FPGA的雷龙SD NAND存储芯片性能测试
fpga开发·sd nand·雷龙·spi nand·spi nand flash·工业级tf卡·嵌入式tf卡