

# **SD Card** Read/Write with the **Nexys4** FPGA Platform

Jono Matthews | MIT EECS | 6.111 Fall 2015



#### **Common Uses in Projects**

#### **Video**

Large color images

#### **Audio**

High-quality sound effects Full-length songs

#### Misc.

Physiological recordings (ECG, EEG)

. . . •







input SD\_CD
output SD\_RESET
output SD\_SCK
output SD\_CMD
inout SD\_DAT[3:0]

**Vivado Constraints** 

### The sd controller Module: Pins and Clock

## The sd\_controller Module: Reading

```
. . . .
output ready, // HIGH if the SD card is ready for a read or
                  // write operation.
input [31:0] address, // Memory address for read/write operation. This
                  // MUST be a multiple of 512 bytes, due to SD
                  // sectoring.
input rd,
                  // Read-enable. When [ready] is HIGH, asseting [rd]
                  // will begin a 512-byte READ operation at
                  // [address]. [byte available] will transition HIGH
                  // as a new byte has been read from the SD card.
               The
                  // byte is presented on [dout].
output reg [7:0] dout, // Data output for READ operation.
```

## The sd\_controller Module: Writing

```
. . . .
output ready, // HIGH if the SD card is ready for a read or
                     // write operation.
input [31:0] address, // Memory address for read/write operation. This
                     // MUST be a multiple of 512 bytes, due to SD
                     // sectoring.
input wr,
                     // Write-enable. When [ready] is HIGH, asserting
                     // [wr] will begin a 512-byte WRITE operation at
                     // [address]. [ready for next byte] will transition
                     // HIGH to request that the next byte to be written
                     // should be presentated on [din].
input [7:0] din,
                                      // Data input for WRITE operation.
output reg ready for next byte, // A new byte should be presented on
                                  // [din].
```

### A Useful Tool: HxD

Raw disk editing
No filesystem needed

### **Windows:**

http://mh-nexus.de/en/hxd/

#### Mac:

http://www.macupdate.com/app/mac/17562/hexedit





## Playing **Audio** with the **Nexys4** FPGA Platform

Jono Matthews | MIT EECS | 6.111 Fall 2015

## Nexys4 Pins

ampPWM (audio PWM signal)

ampsd (keep asserted whenever sound should be playing)

### The audio PWM Module