新闻中心

FPGA:SD卡

作者:时间:2024-01-08来源:EPW编译收藏

SD 卡可轻松与 连接。我们的项目分为两部分:

本文引用地址:http://www.eepw.com.cn/article/202401/454549.htm

SD 卡 1 - 连接

SD 卡可轻松与 连接。 它们有不同的尺寸(标准、迷你和微型),但在电气上它们的工作方式相同。 让我们关注 micro-SD 卡,因为它们非常小且现在很受欢迎。

Micro-SD 卡有 8 个针脚。首先,电源连接在引脚 4 和 6 上。

然后,您需要 3 到 6 个 FPGA 引脚连接,具体取决于您决定使用的操作模式。

SPI模式

在SPI模式下,DI/DO线是单向的。这意味着:

  • 无需在 DI/DO 上上拉

  • 命令(以及执行扇区写入时的扇区数据)将发送到 DI 引脚

  • 响应(以及执行扇区读取时的扇区数据)从 DO 引脚接收

SPI模式通常用于微控制器系统。 有了FPGA,我们可以更好地为...

SD 模式

在 SD 模式下,CMD/DATx 线是双向的。这意味着:

  • CMD/DATx 上需要上拉(FPGA 通常可以在内部提供)

  • 命令/响应在CMD引脚上发送/接收

  • 扇区数据(用于扇区读取和写入)从 DATx 引脚发送/接收

例如,我们需要在 SD 1 位模式下进行这些连接:

SD 卡 2 - 协议

SD 卡使用命令/响应方案。 例如,命令“17”允许读取卡内存的一个扇区(512字节)。 所有通信都与主机提供的时钟同步(在本例中为FPGA)。 启动时时钟应低于 400KHz,并且在一些卡初始化后可以更快。

所有命令和大多数响应的长度为 48 位(6 字节)。 扇区数据以 512 字节的倍数表示。 例如,这里有一个简单的代码,允许向 SD 卡发送命令。

// we use the Xylo-E FX2 FIFO2 as data source for "commanding" an SD card
// the SD card is used in one-bit SD mode

// first we are going to drive the SD card at a much slower speed than the FPGA itself
// let's create a "shift" signal that is asserted once every 64 clock periods
reg [5:0] cnt=0;  
always @(posedge clk) cnt <= cnt+1;
reg shift=0;  
always @(posedge clk) shift <= &cnt;

// now we serialize every byte we get from the FIFO2reg [2:0] cntbit=0;
reg shifting=0;
reg [7:0] data=0;
always @(posedge clk) if(shift) shifting <= shifting ? ~(&cntbit & ~FIFO2_data_available) : FIFO2_data_available;
always @(posedge clk) if(shift & shifting) cntbit <= cntbit+1;
always @(posedge clk) if(shift) data <= (FIFO2_data_available & (~shifting | &cntbit)) ? FIFO_DATAIN : {data[6:0],1'b0};
assign FIFO_RD = shift & (~shifting | &cntbit);

// and send the serial data to the SD cardassign SD_CLK = cnt[5];
assign SD_CMD = shifting ? data[7] : 1'bZ;

有些命令没有回复,而其他一些命令会在SD_DAT行发出响应。 例如,要初始化卡,我们从 CMD0 开始,然后是 CMD8:

  • CMD0 “GO_IDLE_STATE”

  • CMD8“SEND_IF_COND”,预期响应

以下是使用 Xylo-E 演示软件录制的会话:

❌SD.exeUSB driver opened
CMD0 400000000095
CMD8 48000001AA87... OK
CMD55 770000000065... OK
CMD41 694018000019... OK
CMD55 770000000065... OK
CMD41 694018000019... OK
SDHC/SDXC (high capacity) card
CMD2 42000000004D... OK
ASTC  3.4
CMD3 430000000021... OK
RCA=0100
CMD7 4700010000DD... OK
CMD13 4D0001000053... OK
CMD17 510000000055... OK
FAT32 detected
Reading 1 sector(s) starting at 8192
CMD17 5100002000B1... OK
Directory /

经过一些初始化后,卡接受 CMD17“READ_SINGLE_BLOCK”,以便可以从卡中读取文件。



关键词: FPGA SD卡

评论


相关推荐

技术专区

关闭