tag 标签: sd卡

相关帖子
相关博文
  • 2024-10-25 17:42
    110 次阅读|
    0 个评论
    最近收到了来自深圳市雷龙发展有限公司寄来的存储卡,奈何最近也没有好的嵌入式项目需要用到, 哪 这里就简单给大家展示一下吧。 原始包装大概就是这样子了垃,有两个存储芯片和一个简单的转接器,测试的时候可以把芯片焊接到转接器上,等到自己真正开发的时候,可以设计好电路,直接把存储卡焊接到PCB板上,就可以正常读取了。 转接板的一头,其实就跟我们常见的TF卡一样,我们可以直接把它插到读卡器上读取 这里也就测试一下,实际使用时肯定不会这样用: 由于我是把tf卡插到读卡器里读取的,读卡器又是USB接口,所以这里被识别成了U盘一样的东西。 这篇文章也就一个简单的测试了,更多更详细的信息还是去这里:深圳市雷龙发展有限公司官网了解详细吧。
  • 热度 3
    2024-6-7 10:07
    441 次阅读|
    2 个评论
    相机是种能够捕捉美丽瞬间的神奇工具,有玩过相机的人都知道,它的行动储存装置就在一张小小的储存卡中,将拍摄的照片和影片都储存起来,而当中最通用的储存卡就是SD卡(Secure Digital Card)。SD卡发展历史已久,从前速度只有12.5MB/s,到目前最新的SD Express则高达3940MB/s,支持更高的分辨率与更大的容量,让用户不论是纪录日常生活,或是专业报导拍摄,都可以用SD卡来储存作品。 Source: SDcard官网 卡片阅读机阻抗控制的潜在风险 每一次拍摄的照片和影片都是珍贵的成果,它们记录了生活中的美好瞬间,然而一旦要透过卡片阅读机传送出来时,却发生无法读取、传送的状况,就成了令人崩溃的梦魇,百佳泰深究原因,可能是卡片阅读机里的阻抗未控制好,导致讯号传输的质量和效率降低,甚至出现错误或中断。 阻抗是指电路中的电阻和电抗的综合表现,它会影响电流的流动和电压的变化,导致阻抗控制不好的可能原因如下: 错误焊盘尺寸:因为设计不当,导致组件焊点形成不足或是焊接连接不当。这会造成电路的不连续或不稳定,影响讯号的传输质量。 加工不易:取决于每家板厂的能力,过小过于精密的设计并非每家厂商都有能力产出,不仅增加制造的成本和难度,也会降低产品的良率和可靠性。 阻抗控制:如果没考虑好匹配的阻抗值,易产生不连续的阻抗表现,导致讯号的反射和干扰,影响讯号的传输效率和准确性。 实际案例 百佳泰检测咨询经验丰富,实际经手案例中就遇过客户送测的SD connector其红线RX connector处为原始Pad量到的阻抗为74 ohm(左图),有非常明显的阻抗掉落现象。在经过专业团队的建议及修改后,阻抗提升12 ohm左右(右图),同时也保持了阻抗的连续性。
  • 热度 2
    2024-1-11 17:24
    353 次阅读|
    0 个评论
    stm32 CubeMx 实现SD卡/sd nand FATFS读写测试。   材料:stm32F407ZGT6开发板、雷龙公司的SD_NAND 测试板(CSNP1GCR01-AOW)。(一开始是使用 Nandflash的操作起来不太方便而且 stm32cubemx自带的 fatfs还没有磨损平衡算法,很是难受。)   CSNP1GCR01-AOW的优势:   不用写驱动程序自带坏块管理的NAND Flash(贴片式TF卡),尺寸小巧,简单易用,兼容性强,稳定可靠,固件可定制,LGA-8封装,标准SDIO接口,兼容SPI/SD接口,兼容各大MCU平台,可替代普通TF卡/SD卡,尺寸6x8mm毫米,内置SLC晶圆擦写寿命10万次,通过1万次随机掉电测试耐高低温,支持工业级温度-40°~+85°,机贴手贴都非常方便,速度级别Class10(读取速度23.5MB/S写入速度12.3MB/S)标准的SD 2.0协议使得用户可以直接移植标准驱动代码,省去了驱动代码编程环节。支持TF卡启动的SOC都可以用SD NAND,提供STM32参考例程及原厂技术支持,主流容量:128MB/512MB/4GB/8GB,比TF卡稳定,比eMMC便宜,样品免费试用(可到官网找客服小姐姐领取样品哦)。雷龙官网   话不多说开始正文:   stm32cubeMX 版本:6.6.1   MDK5 版本5.35   开始配置STM32   1、 配置时钟:   系统时钟树配置(我这里直接拉满,实际使用根据功耗要求作相应的调整)   2、 配置调试接口   注意DEBUG这个一定要配置,如果是默认的那下载一次程序之后第二次就下载不进去了.   3、配置SDIO:   (我这里还是用了DMA 减少mcu的资源开销)   配置完成之后随便选一个IO口作为SD_NAND的插入检测引脚(没有检测脚的也选上不然在生成代码的时候会有警告,看着很不舒服,我这里选的是 PE4 引脚)   4、配置SDIO的DMA   5、添加文件系统  6、配置堆栈大小(稍微调大一点,不然在读写大一点的数据的时候可能会出错)   7、生成代码   8、生成代码后在 bsp_driver_sd.c这个文件中将这三行代码注释(这是检测SD卡是否接入的引脚 如果不注释在挂载sdnand的时候会提示 not_ready)   9、在main.c中 添加测试代码 */ /* USER CODE END Header */ /* Includes ------------------------------------------------------------------*/ #include "main.h" #include "dma.h" #include "fatfs.h" #include "sdio.h" #include "gpio.h" /* Private includes ----------------------------------------------------------*/ /* USER CODE BEGIN Includes */ /* USER CODE END Includes */ /* Private typedef -----------------------------------------------------------*/ /* USER CODE BEGIN PTD */ FATFS fs; /* FatFs 文件系统对象 */ FIL file; /* 文件对象 */ FRESULT f_res; /* 文件操作结果 */ UINT fnum; /* 文件成功读写数量 */ BYTE ReadBuffer = {0}; /* 读缓冲区 */ BYTE WriteBuffer */ void* work, /* Pointer to working buffer */ UINT len /* Size of working buffer */ )  f_mkfs 这个函数有五个参数,老版本的只有三个参数   所以在格式化的时候得这么来操作 f_res = f_mkfs("0:/",FM_FAT|FM_SFD,0,&ReadBuffer,sizeof(ReadBuffer));
  • 热度 1
    2023-11-9 18:18
    528 次阅读|
    0 个评论
    为何我的SD卡读取不到?
    很多人认为记忆卡正逐渐淡出人们的视野,但随着技术的快速进步,以高清格式记录大容量照片和影片的新型相机模块出现后,对监控摄影机的需求不断增长,推动记忆卡在市场持续使用,也正因为这些新的需求,使用者会更在意记忆卡的使用质量,品牌或制造商都需更加留意重视。 记忆卡关键应用风险与验证方案实例分享 SD卡是目前最主流的记忆卡,而根据百佳泰在市场上收集到的客诉,以及多年来与各知名大厂的合作经验, 发现最严重的关键风险便是系统无法正常辨识记忆卡。 根据我们的实验数据显示一些SD卡在数据传输过程中, 会发生过冲的问题(undershoot/overshoot),,将产生串音(crosstalk)干扰频率讯号,造成系统端无法正常辨识SD卡 而产生客诉。 百佳泰拥有丰富的设备及经验,我们利用示波器量测SD卡连接器端相关脚位,观察在资料传输过程时,是否有产生异常波形,若有发现相关问题,即可快速回报客户端以即早改善错误,以下是实际量测频率与数据讯号范例: 本文分享是以硬件设计验证角度出发,确认使用者情境下的可能潜在问题。
  • 热度 10
    2022-12-15 18:09
    740 次阅读|
    0 个评论
    文章目录 1、存储芯片分类 2、NOR Flash 与NAND Flash的区别 3、什么是SD卡? 4、什么是SD NAND? 5、SD NAND的控制时序 6、FPGA实现SD NAND读写 6.1、设计思路 6.2、仿真结果 6.3、实验结果 1、存储芯片分类 目前市面上的存储芯片,大致可以将其分为3大类: ① EEPROM EEPROM (Electrically Erasable Programmable read only memory)是指带电可擦可编程只读存储器,是一种掉电后数据不丢失的存储芯片。EEPROM 可以在电脑上或专用设备上擦除已有信息,重新编程。 这类产品容量小,读取速度慢,且无法在应用过程中写入数据,十分不便。目前多存在于一些MCU内部,如遥控器,电风扇等各类低端、低速消费类产品。相信你读大学如果玩单片机的话,那么应该是不陌生。 ② NOR Flash NOR Flash由Intel在1988年发明,是市场上两种主要的非易失闪存技术之一。NOR Flash 技术的出现,彻底改变了原先由EPROM和EEPROM一统天下的局面。 NOR Flash可能是目前应用领域最广泛的一种存储芯片了,基本上主流的电子产品里都有使用,比如手机摄像头内部,或者屏幕驱动电路板。主要用来存储代码和一些比较小的数据文件。NOR Flash架构决定了它的容量不能做大,而且读取速度比较慢。好处在于简单易用,其接口可以实现地址寻址,也就意味着可以做到直接对某个地址直接操作,而不需要建立额外的文件系统。 ③ NAND Flash 虽然很多人平常说的Flash 存储器一半默认其就是NOR Flash ,但这无疑是不严谨的。FLASH产品可以分为两个大类:NOR Flash 和 NAND Flash 。 NAND Flash 是市场上两种主要的非易失闪存技术之一,由东芝公司在1989年发明。其强调降低每比特的成本,并拥有更高的性能,可以像磁盘一样可以通过接口轻松升级。 NAND Flash应该是目前最热门的存储芯片了。因为我们生活中经常使用的电子产品都会涉及到它。比如你买手机,肯定会考虑64GB,还是256GB?买笔记本是买256GB,还是512GB容量的硬盘呢?(目前电脑大部分采用了基于NAND Flash产品的固态硬盘) 2、NOR Flash 与 NAND Flash的区别 Flash 闪存是非易失存储器,可以对称为块的存储器单元块进行擦写和再编程。任何Flash 器件的写入操作都只能在空或已擦除的单元内进行,所以大多数情况下,在进行写入操作之前必须先执行擦除。NAND器件执行擦除操作是十分简单的,而NOR则要求在进行擦除前先要将目标块内所有的位都写为0。 执行擦除时块尺寸的不同进一步拉大了NOR和NAND之间的性能差距,统计表明,对于给定的一套写入操作(尤其是更新小文件时),更多的擦除操作必须在基于NOR的单元中进行。这样,当选择存储解决方案时,用户必须权衡以下因素: NOR Flash支持随机访问,所以支持XIP(execute In Place),NAND Flash需要按块进行读取,所以不支持XIP NAND FLASH理论读取速度与NOR Flash相近,实际情况会根据接口不同有些差异 NOR 与 NAND 写入前都需要先擦除,NOR在擦除时以64~128KB的块进行,执行一个写入/擦除操作的时间约5s,NAND在擦除时以8~32KB的块进行,执行一个写入/擦除操作的时间约4ms NAND 理论最大擦除次数比NOR多 NOR 驱动比NAND简单,NAND FLASH需要通过专门的NFI(NAND FLASH Interface)与Host端进行通信,驱动相对复杂 所有Flash 都会有位反转的问题,NAND 位反转概率要比NOR高,NAND Flash 必须要使用ECC NAND的单元尺寸几乎是NOR器件的一半,所以NAND成本更低   NOR 与 NAND 各有特点,应用场景与应用难度也不同,一般来讲,NOR适用于小容量、略低速且需要直接对地址块进行操作的应用,而NADN则适用于大容量的高速应用。SD NAND 在保留了NAND架构优质特性的同时改进了不足之处,内置的控制器能自行管理NAND Flash,无需在外部处理ECC和进行坏块管理,免去了MTD层,不需要写繁琐的驱动代码。 3、什么是SD卡? ①概述 SD卡的英文全称是Secure Digital Card,即安全数字卡(又叫安全数码卡),是在MMC 卡(Multimedia Card,多媒体卡)的基础上发展而来,主要增加了两个特色:更高的安全性和更快的读写速度。 ②容量标准和速度等级 若按照容量 对 SD 卡进行等级划分,SD 卡可分为 4 个等级,SD(Secure Digital Card,安全数字卡) 卡、SDHC 卡(Secure Digital High Capacity,高容量安全数字卡)、SDXC 卡( SD eXtended Capacity,容量扩大化的安全数字卡)和 SDUC(Secure Digital Ultra Capacity,超 容量安全数字卡)。现今,市场的主流 SD 产品是 SDHC 和 SDXC 这两种较大容量的存储 卡,SD 卡因容量过小,已逐渐被市场淘汰,SDUC 则是容量太大,预计会出现在未来市 场。SD 卡的四种容量标准,具体见下图: 不同品牌和厂商生产的 SD 卡在对存取速度上的定义标准不同,这会使用户在选择 SD卡时产生困扰。所以 SD 协会根据视频匀速写入到 SD 卡的最低持续速度来划分不同等级, 每个等级的速率是以每秒传输多少 MB 来衡量的,单位为 MB/S。 SD 协会定义了三种速度等级:速度等级、UHS 速度等级与视频速度等级。三种速度等级的具体传输速度如下图: 4、什么是SD NAND? 上文中提到的SD卡其实更应该叫做TF卡,在日常生活中最常见的应用就是数码相机的存储卡。因为它是可拆卸的,所以这类SD卡最大的优点就是便携方便,但同时也有容易丢失和接触不良等毛病,所以多用于消费类产品。 在工业级应用中,更多见的是一类贴片式的SD NAND产品,俗称贴片式T卡或贴片式SD卡。虽然SD NAND 和TF卡称呼上有些类似,但是SD NAND和TF卡有着本质上的区别: 为什么SD NAND和 TF卡 之间有这么大区别呢?因为 SD NAND是为内置存储而生,是焊接在PCB板上的,是针对工业级应用的产品,所以品质稳定、一致性高、使用稳定性高、同时尺寸也小。而TF卡主要是针对普通消费者,品质和一致性、使用稳定性等相对要求不高,再加上国内鱼龙混杂的市场环境,导致内置存储用TF卡的品质风险高。   NAND Flash产品的一个特质就是它的品质并不是0和1这么简单,有些品质隐患是使用一段时间之后才被发现,如果这个产品已经销往海外,处理起来会变得异常麻烦。使用SD NAND可以为客户产品带来整体品质的提升,提供确定性,是客户产品良好品牌和口碑的稳定基石。而使用TF卡时,产品整机不可控因素会增高,比如常见的卡座老化松动、TF触点氧化、TF卡遗失、抗震性能减退等等。综上所述,虽然SD NAND与TF卡使用的协议相同,但从外观到内在都有区别。正在使用TF卡的客户需要提升产品稳定性及耐用性时,SD NAND 是绝佳选择。 尽管 SD NAND和 TF卡之间有着这么大的区别,但具体到实际应用,其对外接口和驱动程序都是一样了,这说明可移植性非常好。 ① 物理结构 SD NAND从物理结构看包括 5 个部分,分别为存储单元、存储单元接口、电源检测、卡及接口控制器和对外接口,具体见下图。 存储单元是存储数据部件,存储单元通过存储单元接口与卡控制单元进行数据传输 存储单元接口是接口控制器与存储单元的数据交互通道 电源检测单元保证 SD NAND工作在合适的电压下,如出现掉电或上电状态时,它会使控制单元和存储单元接口复位 卡及接口控制单元控制 SDNAND的运行状态,它包括 8 个寄存器 对外接口单元控制 SD NAND引脚的输入输出,一般包含SDIO接口和SPI接口 ② 对外接口 SD NAND共有 9 个引脚,其中包括 3 根电源线、1 根时钟线、1 根命令线和 4根数据线。如下: CLK:同步时钟线,由主机产生,即由主控制器(FPGA)输出; 使用 SPI 模式 时,该引脚与 SPI 总线的 SCK 时钟信号相连 CMD:命令控制线, SDIO 主机通过该线发送命令控制 SD NAND,如果命令要求 SD NAND 提供应答(响应), SD NAND也是通过该线传输应答信息; 使用 SPI 模式时,该引脚与 SPI总线的 MOSI 信号相连, SPI 主机通过它向 SD NAND发送命令及数据,但因为 SPI 总线 的 MOSI 仅用于主机向从机输出信号,所以 SD NAND返回应答信息时不使用该信号线; DAT0-3:在 SDIO 模式下,它们均为数据线,传输读写数据, SD NAND可将 D0 拉低表 示忙状态; 在 SPI 模式下, DAT0 与 SPI 总线的 MISO 信号相连, SD NAND通过该信号线向主机发送数据或响应, DAT3 与总线的 CS 信号相连, SPI 主机通过该信号线选择要通讯的 SD NAND。 VDD、VSS1、VSS2:电源和地信号。 ③ 工作模式 SD NAND有两种工作模式:SDIO 模式与SPI模式 在 SDIO 模式下,SD NAND共使用到 CLK、CMD、DAT 6根信号线;SDIO 总线与多个 SD NAND连接时,可以共用 CLK 时钟信号线,对于 CMD、DAT 信号线,每个 SD NAND都要独立连接。SDIO 总线与 SD 卡连接方式,具体见下图。此模式使用IO引脚多,但传输速度高。 在 SPI 模式下,SD NAND共使用到 CS(DAT )、CLK、MISO(DAT )、MOSI(CMD) 4根信号线;SPI 总线与多个 SD NAND连接时,除 CS 片选信号线不可共用外,其他信号均可公用。SPI 总线与 SD NAND连方式,具体见下图。此模式使用IO引脚少,但传输速度慢。 ④ 内部寄存器 SD NAND总共有 8 个寄存器,用于设定或表示 SD NAND信息,寄存器描述具体见下图。 这些寄存器只能通过对应的命令访问,对 SD NAND的控制操作是通过命令来执行的, SD NAND定义了 64 个命令(部分命令不支持 SPI 模式) ,每个命令都有特殊意义,可以实现某一特定功能, SD NAND接收到命令后,根据命令要求对 SD NAND内部寄存器进行修改,程序控制中只需要发送组合命令就可以实现 SD NAND的控制以及读写操作。 内部寄存器就不展开讲了,我们用FPGA实现读写测试也不需要了解那么多寄存器。 5、SD NAND的控制时序 ① 命令与读写时序 SD NAND的通信是基于命令和数据传输的。通讯由一个起始位(“0”)开始,由一个停止位(“1”)终止。SD NAND通信一般是主机发送一个命令(Command),从设备在接收到命令后作出响应(Response),如有需要会有数据(Data)传输参与。SD NAND的基本交互是命令与响应交互, 见下图: SD NAND数据是以块(Block)形式传输的,SDHC 规格数据块长度一般为 512 字节,数据可以从主机到芯片,也可以是从芯片到主机。数据块需要 CRC 位来保证数据传输成功,CRC 位由 SD NAND系统硬件生成。单个数据块的读、写时序分别见下2图: 读写操作都是由主机发起的,主机发送不同的命令表示读或写, SD NAND接收到命令后先针对命令返回响应。在读操作中, SD NAND返回一个数据块,数据块中包含 CRC校验码;在写操作中,主机接收到命令响应后需要先发送一个标志(TOKEN)然后紧跟一个要写入的数据块,SD NAND接收完数据块后会返回一个数据响应及忙碌标志,当 SD NAND把接收到的数据写入到内部存储单元完成后,会停止发送忙碌标志,主机确认 SD NAND空闲后,才可以发送下一个命令。 SD NAND数据传输支持单块和多块读写,它们分别对应不同的操作命令, 结束多块读写时需要使用命令来停止操作。 ② 命令格式 SD NAND命令由主机发出,命令格式固定为 48bit,通过 CMD 信号线连续传输。SD NAND命令格式,具体见下图: 起始位和终止位:命令的主体包含在起始位与终止位之间,它们都只包含一个数据位,起始位为 0,终止位为 1。 传输标志:用于区分传输方向,该位为 1 时表示命令,方向为主机传输到 SD NAND,该位为 0 时表示响应,方向为 SD NAND传输到主机。命令主体内容包括命令、地址信息/参数和 CRC 校验三个部分。 命令号:它固定占用 6bit,所以总共有 64 个命令,每个命令都有特定的用途,部分命令不适用于 SPI 总线,或不适用于 SD NAND操作,只是专门用于 MMC 卡或者 SD I/O卡。 地址/参数:每个命令有 32bit 地址信息/参数用于命令附加内容,例如,广播命令没有地址信息,这 32bit 用于指定参数,而寻址命令这 32bit 用于指定目标 SD NAND的地址, 当使用 SDIO 驱动多个 SD NAND时,通过地址信息区分控制不同的SD NAND,使用 SPI 总线驱动时,通过片选引脚来选择不同的SD NAND,所以使用这些命令时地址可填充任意值。 CRC7 校验:长度为 7bit 的校验位用于验证命令传输内容正确性,如果发生外部干扰 导致传输数据个别位状态改变将导致校准失败,也意味着命令传输失败, SD NAND不执行命令。 使用 SDIO 驱动时,命令中必须包含正确的 CRC7 校验值;而使用 SPI 驱动时,命令中的 CRC7 校验默认是关闭的,即这 CRC7 校验位中可以写入任意值而不影响通讯,仅在发送 CMD0 命令时需要强制带标准的 CRC7 校验。 ③ 命令内容 SD NAND命令可分为标准命令 (如 CMD0)和特殊应用命令 (如 ACMD41),其中特殊应用命令只有在先写入 CMD55 命令后才能被识别。按照指令类型又可将 SD NAND命令分为基本命令、数据块写命令、数据块读命令、擦除命令等 12 种(class0 ~ class11)。 本次实验将会使用 SPI 模式实现 SD NAND的数据读写操作,所以接下来只列举 SPI 模式下常用的 SD 卡命令,具体见下表: SPI 模式下,上述各命令中,命令 CMD0 的 CRC7 校验为固定的 1001_010;命令CMD8 的 CRC7 校验为固定的 1000_011;其他命令的 CRC7 校验在 SPI 模式下无作用,赋值为 1111_111 即可。 ④ 响应格式 当 SD NAND接收到命令时,会向 SD NAND回传命令响应。SD NAND有 5 种类型的命令响应:R1、R1b、R2、R3、R7;SDIO NAND还支持另外两种命令响应:R4、R5。下文只对部分响应做介绍。 R1 响应格式,具体见下图: in idle state:当该位为 1 时,表示 SD NAND处于空闲状态 erase reset:因为接收到无需擦除操作的命令,擦除操作被复位 illegal command:接收到一个无效的命令代码 com crc error:接收到的上一个命令的 CRC 校验错误 erase sequence error:擦除命令的控制顺序错误 address error:读写的数据地址不对齐(数据地址需要按块大小对齐) parameter error:命令的参数错误 R3 响应格式,具体见下图: R3 响应包括 5 个字节,首先返回的第 1 个字节内容为 R1,剩下的其余字节为 OCR( Operation Conditions Register, 操作条件寄存器)寄存器的内容。 R7 响应格式,具体见下图: R7 响应包括 5 个字节,首先返回的第 1 个字节内容为 R1,R7 位为命令版本,R7 为保留位,R7 为反馈的电压范围,最后 1 个字节为检查模式。 6、FPGA实现SD NAND读写 接下来编写FPGA的Verilog代码实现向SD NAND的指定扇区中写入512个字节的数据,写完后将数据读出,并通过指示灯的方式验证数据是否被正确读写。需要说明的是,后文的读写操作均采用SPI模式。 6.1、设计思路 ① 上电时序 SD NAND同其他的许多芯片一样上电后需要保持一定的时间以便维持电压稳定,这个时间通常是74+个时钟周期,一般实际应用中可设置参数为74~100。只有经过这个过渡时间后,才可以执行后续的SD NAND初始化操作。 ② 初始化时序 SD NAND在正常读写操作之前,必须先对SD NAND进行初始化,使其工作在预期的工作模式。初始化流程如下: 1.SD NAND完成上电后,主机FPGA先对从机SD NAND发送至少74个以上的同步时钟,在上电同步期间,片选CS引脚和MOSI引脚必须为高电平(MOSI引脚除发送命令或数据外,其余时刻都为高电平); 2.拉低片选CS引脚,发送命令CMD0(0x40)复位SD NAND,命令发送完成后等待SD NAND返回响应数据; 3.SD NAND返回响应数据后,先等待8个时钟周期再拉高片选CS信号,此时判断返回的响应数据。如果返回的数据为复位完成信号0x01,在接收返回信息期间片选CS为低电平, 此时SD NAND进入SPI模式,并开始进行下一步,如果返回的值为其它值,则重新执行第2步; 4.拉低片选CS引脚,发送命令CMD8(0x48)查询SD NAND的版本号,只有SD2.0版本才支持此命令,命令发送完成后等待SD NAND返回响应数据; 5.SD NAND返回响应数据后,先等待8个时钟周期再拉高片选CS信号,此时判断返回的响应数据。如果返回的电压范围为4’b0001即2.7V~3.6V,说明2.0版本,进行下一步,否则重新执行第4步; 6.拉低片选CS引脚,发送命令CMD55(0x77)告诉SD NAND下一次发送的命令是应用相关命令,命令发送完成后等待SD NAND返回响应数据; 7.SD NAND返回响应数据后,先等待8个时钟周期再拉高片选CS信号,此时判断返回的响应数据。如果返回的数据为空闲信号0x01,开始进行下一步,否则重新执行第6步。 8.拉低片选CS引脚,发送命令ACMD41(0x69)查询SD NAND是否初始化完成,命令发送完成后等待SD NAND返回响应数据; 9.SD NAND返回响应数据后,先等待8个时钟周期再拉高片选CS信号,此时判断返回的响应数据。如果返回的数据为0x00,此时初始化完成,否则重新执行第6步。 ③ 写操作时序 至此,SD NAND完成了复位以及初始化操作,进入到SPI模式的读写操作。SD NAND读写一次的数据量必须为512字节的整数倍,即对SD NAND读写操作的最少数据量为512 个字节。我们可以通过命令CMD16来配置单次读写操作的数据长度,以使每次读写的数据量为 (n*512)个字节(n≥1),本次SD NAND的读写操作使用默认配置,即单次读写操作的数据量为512个字节。 SD NAND的写操作时序图如下图所示: 拉低片选信号 CS_N,向 SD NAND写入命令 CMD24,命令号为 0x58,携带参数为 4字节的 SD NAND写扇区地址,CRC 校验字节未使用直接写入 0xFF,命令发送完成后 等待 SD NAND返回响应数据 若 SD NAND返回正确响应数据 R1 为 0x00,等待 8 个时钟周期,向 SD NAND写入令牌0xFE,紧随其后写入 512 个字节的数据 数据发送完成后,再向 SD NAND写入 2 个字节的 CRC 校验字节。SPI 模式下不对数据进行 CRC 校验,直接写入两个字节的 0xFF 校验数据发送完成后, SD NAND会有响应数据返回,随后 SD NAND将 Miso 信号拉低进入写忙状态 MISO 信号再次拉高后 SD NAND退出写忙状态,等待 8 个时钟周期后拉高片选信号,SD NAND数据写操作完成,可以执行其它操作 ④ 读操作时序 SD NAND的读操作时序图如下图所示: 1.拉低片选信号 CS_N, 向 SD NAND写入命令 CMD17,命令号为 0x51,携带参数为 4字节的 SD NAND读扇区地址,CRC 校验字节未使用直接写入 0xFF,命令发送完成后 等待 SD NAND返回响应数据 2.若 SD NAND返回正确响应数据 R1 为 0x00,以 SD NAND返回的数据头 0xFE 为标志,接收自 SD NAND读出的 512 字节数据和 2 字节的 CRC 校验字节 3.解析到数据头 0xFE 后,接下来接收 SD NAND返回的 512 个字节的数据 4.数据解析完成后,接下来接收2个字节的 CRC 校验值。 由于 SPI 模式下不对数据进行 CRC 校验,可直接忽略这两个字节 5.CRC 校验字节接收完毕,等待 8 个时钟周期,拉高片选信号 CS_N,一次数据读操作完成 ⑤ 程序设计 通过前面介绍的SD NAND初始化、写操作以及读操作可知,SD NAND的这3个操作是相互独立且不能同时进行的,因此我们可以将SD NAND的初始化、写操作以及读操作分别划分为3个独立的模块,最后将这三个模块例化在SD NAND的控制器模块中,便于在其它工程项目中使用。 下图是系统框图,PLL时钟模块(PLL)为各个模块提供驱动时钟,SD NAND测试数据产生模块产生测试数据写入SD NAND,写完后从SD NAND中读出数据,最终读写测试结果由LED显示模块通过控制LED灯的显示状态来指示。 顶层模块:顶层模块完成了对其它四个模块的例化,SD NAND测试数据产生模块产生的开始写入信号及数据连接至SD NAND控制器模块,数据写完后从SD NAND控制器中读出数据, 并验证数据的正确性,将验证的结果连接至LED显示模块。 PLL时钟模块:PLL时钟模块通过调用锁相环(PLL)IP核来实现,总共输出2个时钟,频率都是50Mhz,但两个时钟相位相差180度。我们知道,SD卡的SPI通信模式为CPOL=1, CPHA=1;即SPI_CLK在空闲时为高电平,数据发送是在时钟的第一个边沿,也就是SPI_CLK由高 电平到低电平的跳变,所以数据采集是在上升沿,数据发送是在下降沿。为了在程序代码中统 一使用上升沿,我们使用两个相位相差180度的时钟来对SD NAND进行操作。 SD NAND测试数据产生模块:SD NAND测试数据产生模块产生的开始写入信号和数据写入SD NAND控制器模块中,数据写完后从SD NAND控制器中读出数据,并验证数据的正确性,将验证的结果发送给LED显示模块。 SD NAND控制器模块:SD NAND控制器模块例化了SD NAND初始化模块、 SD NAND写数据模块和SD NAND读数据模块。SD NAND初始化模块完成对SD NAND的上电初始化操作;SD NAND写数据模块完成对SD NAND的写操作;SD NAND读数据模块完成对SD NAND的读操作。 由于这三个模块都操作了SD NAND的引脚信号,且这三个模块在同一时间内不会同时操作,所以此模块实现了对其它三个模块的例化以及选择SD NAND的引脚连接至其中某一个模块。 LED显示模块:LED显示模块将SD NAND测试数据产生模块输出的验证结果值, 通过控制LED灯的显示状态来指示。 SD NAND控制器部分代码如下: module sd_ctrl_top( input clk_ref , //时钟信号 input clk_ref_180deg, //时钟信号,与clk_ref相位相差180度 input rst_n , //复位信号,低电平有效 //SD卡接口 input sd_miso , //SD卡SPI串行输入数据信号 output sd_clk , //SD卡SPI时钟信号 output reg sd_cs , //SD卡SPI片选信号 output reg sd_mosi , //SD卡SPI串行输出数据信号 //用户写SD卡接口 input wr_start_en , //开始写SD卡数据信号 input wr_sec_addr , //写数据扇区地址 input wr_data , //写数据 output wr_busy , //写数据忙信号 output wr_req , //写数据请求信号 //用户读SD卡接口 input rd_start_en , //开始读SD卡数据信号 input rd_sec_addr , //读数据扇区地址 output rd_busy , //读数据忙信号 output rd_val_en , //读数据有效信号 output rd_val_data , //读数据 output sd_init_done //SD卡初始化完成信号 ); //wire define wire init_sd_clk ; //初始化SD卡时的低速时钟 wire init_sd_cs ; //初始化模块SD片选信号 wire init_sd_mosi ; //初始化模块SD数据输出信号 wire wr_sd_cs ; //写数据模块SD片选信号 wire wr_sd_mosi ; //写数据模块SD数据输出信号 wire rd_sd_cs ; //读数据模块SD片选信号 wire rd_sd_mosi ; //读数据模块SD数据输出信号 //***************************************************** //** main code //***************************************************** //SD卡的SPI_CLK assign sd_clk = (sd_init_done==1'b0) ? init_sd_clk : clk_ref_180deg; //SD卡接口信号选择 always @(*) begin //SD卡初始化完成之前,端口信号和初始化模块信号相连 if(sd_init_done == 1'b0) begin sd_cs = init_sd_cs; sd_mosi = init_sd_mosi; end else if(wr_busy) begin sd_cs = wr_sd_cs; sd_mosi = wr_sd_mosi; end else if(rd_busy) begin sd_cs = rd_sd_cs; sd_mosi = rd_sd_mosi; end else begin sd_cs = 1'b1; sd_mosi = 1'b1; end end //SD卡初始化 sd_init u_sd_init( .clk_ref (clk_ref), .rst_n (rst_n), .sd_miso (sd_miso), .sd_clk (init_sd_clk), .sd_cs (init_sd_cs), .sd_mosi (init_sd_mosi), .sd_init_done (sd_init_done) ); //SD卡写数据 sd_write u_sd_write( .clk_ref (clk_ref), .clk_ref_180deg (clk_ref_180deg), .rst_n (rst_n), .sd_miso (sd_miso), .sd_cs (wr_sd_cs), .sd_mosi (wr_sd_mosi), //SD卡初始化完成之后响应写操作 .wr_start_en (wr_start_en & sd_init_done), .wr_sec_addr (wr_sec_addr), .wr_data (wr_data), .wr_busy (wr_busy), .wr_req (wr_req) ); //SD卡读数据 sd_read u_sd_read( .clk_ref (clk_ref), .clk_ref_180deg (clk_ref_180deg), .rst_n (rst_n), .sd_miso (sd_miso), .sd_cs (rd_sd_cs), .sd_mosi (rd_sd_mosi), //SD卡初始化完成之后响应读操作 .rd_start_en (rd_start_en & sd_init_done), .rd_sec_addr (rd_sec_addr), .rd_busy (rd_busy), .rd_val_en (rd_val_en), .rd_val_data (rd_val_data) ); endmodule SD NAND控制器模块输出的sd_init_done(SD NAND初始化完成信号)连接至SD NAND测试数据产生模块,只有在SD NAND初始化完成之后(sd_init_done为高电平),才能对SD NAND进行读写测试。SD NAND控制器模块将SD NAND的初始化以及读写操作封装成方便用户调用的接口,SD NAND测试数据产生模块只需对SD NAND控制器模块的用户接口进行操作即可完成对SD NAND的读写操作。 6.2、仿真结果 一般的测试中,我们都需要先进行仿真来观察时序等测试行为。此次实验由于找不到好的SD NAND的Verilog模型,所以仿真测试略。 6.3、实验结果 上文已经说了常用的相机中的TF卡与工业级的SD NAND(贴片式T卡)的区别,所以本次实验我选用的是深圳雷龙公司的一款SD NAND产品----CSNP32GCR01-AOW。 这是一家专业做存储产品的公司,NAND Flash是其主要产品。 该公司专注NAND Flash设计研发13年,在这一块可以说是相当专业。如果你对NAND Flash仍有疑惑的问题,或者你想在你的设计中使用NAND Flash产品,都可以直接联系: 深圳市雷龙发展有限公司 实验结果其实没什么好看的,LED灯常量表明说明从SD NAND读出的512个字节(256个16位数据) 与写入的数据相同,SD NAND读写测试程序下载验证成功。 PS:有个小细节可以说下,雷龙公司的SD NAND开发板还是蛮用心的,封装都是标准的Micro SD的封装,只要你的FPGA开发板上有SD卡座,就可以直接插上使用了,即插即用十分方便,有心了。 ———————————————— 【本文转载自CSDN,作者:孤独的单刀】   亲爱的卡友们,如果看完文章之后还是有疑惑或不懂的地方,请联系我们,自己去理解或猜答案是件很累的事,请把最麻烦的事情交给我们来处理,术业有专攻,闻道有先后, 深圳市雷龙发展 专注存储行业13年,专业提供小容量存储解决方案。
相关资源
  • 所需E币: 1
    时间: 2024-8-9 12:11
    大小: 2.3MB
    上传者: wuliangu
    文中介绍了WIFI及SD卡线路部分的处理,以及如何进行SDIO波形优化,怎么样进行相关软件的设置等等。
  • 所需E币: 3
    时间: 2019-12-26 01:08
    大小: 857.13KB
    上传者: 16245458_qq.com
    独家SD绝密资料……
  • 所需E币: 5
    时间: 2019-12-26 00:52
    大小: 14.31KB
    上传者: 二不过三
    TI公司的MSP430与SD卡连接的驱动测试版……
  • 所需E币: 5
    时间: 2019-12-26 00:50
    大小: 18.91KB
    上传者: 16245458_qq.com
    SD卡模块原理图及非弹出式SD卡PCB封装……
  • 所需E币: 4
    时间: 2019-12-26 00:49
    大小: 304.77KB
    上传者: quw431979_163.com
    SD卡接口规范的完整翻译……
  • 所需E币: 4
    时间: 2019-12-26 00:49
    大小: 857.09KB
    上传者: givh79_163.com
    SD卡的productmanual……
  • 所需E币: 4
    时间: 2019-12-26 00:49
    大小: 2.77MB
    上传者: 微风DS
    SD卡MMC卡规范协议……
  • 所需E币: 4
    时间: 2019-12-26 00:49
    大小: 182.61KB
    上传者: givh79_163.com
    SD卡,MMC卡MCU读取方案最完整的资料……
  • 所需E币: 3
    时间: 2019-12-26 00:49
    大小: 183.01KB
    上传者: 2iot
    SD卡MMC卡MCU读取方案最完整的资料……
  • 所需E币: 4
    时间: 2019-12-25 21:03
    大小: 82.14KB
    上传者: 978461154_qq
    SD卡读写源程序……
  • 所需E币: 5
    时间: 2019-12-28 21:07
    大小: 1.22MB
    上传者: 二不过三
    单片机读写USB、SD卡……
  • 所需E币: 3
    时间: 2019-12-25 17:09
    大小: 4.71MB
    上传者: 2iot
    全面介绍SD卡的硬件系统和操作方法SDMemoryCardSpecificationsPart1PHYSICALLAYERSPECIFICATIONVersion1.01April152001SDGroupMatsushitaElectricIndustrialCo.,Ltd.(MEI)SanDiskCorporationToshibaCorporationSD-MemoryCardSpecifications/Part1.PhysicalLayerSpecification;Version1.01Copyright(C)2000(C)2001bySDGroup(MEI,SanDisk,Toshiba)Conditionsforpublication:-PublisherandCopyrightHolder:SDGroup(MEI,SanDisk,Toshiba)-Exemption:Nonewillbeliableforanydamagefromuseofthisdocument.RevisionHistoryDateVersionChangescomparedtopreviousissue……
  • 所需E币: 3
    时间: 2019-12-25 16:36
    大小: 415.02KB
    上传者: wsu_w_hotmail.com
    freedev开发板使用手册……
  • 所需E币: 3
    时间: 2019-12-25 16:02
    大小: 1.32MB
    上传者: givh79_163.com
    扬创2440开发板ADS1.2工程示例开发手册……
  • 所需E币: 4
    时间: 2019-12-25 12:37
    大小: 165.1KB
    上传者: 978461154_qq
    介绍一种适用于单片机的嵌入式开源文件系统FatFsModule.相对于其他的开源FAT文件系统,它小巧、读/写速度快、功能强大、易于移植和使用,更适用于资源相对紧张的单片机.本文以AVR系列ATmega128单片机为例,用FatFsModule的简化版Tiny-FatFs在SD卡上实现FAT文件系统,并给出必要的代码移植说明及其功能测试.……
  • 所需E币: 3
    时间: 2019-12-25 12:36
    大小: 278.09KB
    上传者: 978461154_qq
    以ARM7TDMI-S为内核的32/16位微控制器LPC2148与SD卡相结合,实现在SD卡上建立FAT16文件系统.采集的温度数据以FAT16文件格式存入SD卡,可方便用户对温度数据进行读取与分析.本文描述了温度传感器ADT75的工作原理.……
  • 所需E币: 3
    时间: 2020-1-2 01:55
    大小: 126.55KB
    上传者: givh79_163.com
    将SD卡作为外部掉电存储介质应用于断路器离线测试仪中,介绍了以ATMEGA128单片机作为核心元件,用SPI方式读写SD卡的方法和相应的文件系统设计.该方案使断路器离线测试仪在使用过程中更加灵活,而且操作简单、节省了硬件资源,具有较高的实用价值.……
  • 所需E币: 3
    时间: 2019-12-25 11:13
    大小: 517.58KB
    上传者: quw431979_163.com
    如题pC1*pC8sIpЪpC#P-ǎppC/ppv/38pC)$-)-8sIpC1*pC.pC#ǎ))#__#-ǎ$__%($8……
  • 所需E币: 4
    时间: 2019-12-25 06:05
    大小: 1.05MB
    上传者: 2iot
    基于ARM的SD卡文件系统设计2009年第07期,第42卷通信技术Vol.42,No.07,2009总第211期CommunicationsTechnologyNo.211,Totally基于ARM的SD卡文件系统设计孟惠霞,吕书勇(济源职业技术学院,河南济源454650)【摘要】ARM以其高性能、低功耗、易扩展的特点成为了嵌入式系统全球领先的16/32位RISC微处理器内核。但由于嵌入式系统中数据量的增加,对存储设备的要求也越来越高。在众多存储卡中,SD卡占有越来越多的市场份额。文中介绍了基于ARM7平台设计的SD卡读写系统,包括SD卡与LPC2292的硬件接口电路设计及相应的软件程序设计。【关键词】嵌入式系统;ARM处理器;SD卡;FAT16文件系统【中图分类号】TP393【文献标识码】A【文章编号】1002-0802(2009)07-0135-02DesignofARM-bas……
  • 所需E币: 4
    时间: 2019-12-25 06:05
    大小: 568.91KB
    上传者: 16245458_qq.com
    SD卡I_O接口设计开发案例SD卡I/O接口设计刘晓梅1,董仲博2(1.烟台职业学院计算机与信息工程系,烟台264000;2.中国空间技术研究院五院513所第一研究室,烟台264000)摘要:SD卡是近年来流行的大容量便携式存储卡,存储介质绝大多数采用闪存。SDIO卡是SD协会在SD存储卡基础上定义的I/O接口卡,是对SD存储卡的扩展。在分析SD存储卡和I/O卡标准的基础上,着重讨论SD卡接口的特征与实现。关键词:Flash;SD卡;FIFO;SPI0引言DAT0~3:数据线4条,用于传输所要读写的数……