

#### Introduction:-

The sdr/ddr sdram controller is a single controller for single data rate and double data rate sdrams. It supports load\_mr,auto\_referesh,precharge,act\_row,reada,writea, burst\_stop and nop commands. It can be programmed for burst lengths of 2,4 and 8 and CAS latencies of 2,2.5 and 3.

## Pin Diagram:-





Pin Description:-

| Pin Description:- |               |                                                                 |  |  |  |  |  |  |  |
|-------------------|---------------|-----------------------------------------------------------------|--|--|--|--|--|--|--|
| Pin Name          | Pin Direction | Pin Description                                                 |  |  |  |  |  |  |  |
|                   | HOST INTERI   | FACE                                                            |  |  |  |  |  |  |  |
| mclk              | In            | memory clock to controller                                      |  |  |  |  |  |  |  |
| s_resetn          | In            | sysnchronous negative reset                                     |  |  |  |  |  |  |  |
| sdr_req           | In            | to controller                                                   |  |  |  |  |  |  |  |
| sdr_req_adr       | In            | to controller(24 bit bus)                                       |  |  |  |  |  |  |  |
| sdr_req_len       | In            | 0 (4 bytes or less),                                            |  |  |  |  |  |  |  |
|                   |               | 1- (8 to 5 bytes),                                              |  |  |  |  |  |  |  |
|                   |               | 2 – (12 to 9 byte),                                             |  |  |  |  |  |  |  |
|                   |               | 3 - (16 - 13 bytes)                                             |  |  |  |  |  |  |  |
| sdr_req_wr_n      | In            | 0 – write to SDRAM 1 – read from SDRAM                          |  |  |  |  |  |  |  |
| sdr_req_ack       | Out           | Ack from controller that current read/write started             |  |  |  |  |  |  |  |
| sdr_rd_valid      | Out           | valid data on the bus from SDR controller to mermory controller |  |  |  |  |  |  |  |
| sdr_wr_next       | Out           | present next write data                                         |  |  |  |  |  |  |  |
| sdr_wr_data       | In            | 32 bits data to SDR controller                                  |  |  |  |  |  |  |  |
| sdr_wr_en_n       | In            | 4 bits – byte enables                                           |  |  |  |  |  |  |  |
| sdr_rd_data       | Out           | 32 bits data read.                                              |  |  |  |  |  |  |  |
| sdr_init_done     | Out           | initialization complete.                                        |  |  |  |  |  |  |  |
| sdr_en            | In            | enable/disable SDRAM (power_down?)                              |  |  |  |  |  |  |  |
| sdr_mode_reg      | In            | 12 bits mode register data.                                     |  |  |  |  |  |  |  |
| sdr_tras_d        | In            | 4 bits, Tras delay in clock cycs for SDRAM                      |  |  |  |  |  |  |  |
| sdr_trp_d         | In            | 4 bits, Trp delay                                               |  |  |  |  |  |  |  |
| sdr_trcd_d        | In            | 4 bits, Trcd delay                                              |  |  |  |  |  |  |  |
| sdr_cas           | In            | 3 bits Cas latency for SDRAM                                    |  |  |  |  |  |  |  |
| sdr_trca_d        | In            | 4 bits, Trca delay                                              |  |  |  |  |  |  |  |
| sdr_twr_d         | In            | 4 bits, Twr delay                                               |  |  |  |  |  |  |  |
| sdr_rfrsh         | In            | 12 bits, refresh time per row.                                  |  |  |  |  |  |  |  |
| sdr_rfmax         | In            | 3 bits, number of rows to refresh per burst.                    |  |  |  |  |  |  |  |



| Pin Name        | Pin Direction | Pin Description       |  |  |  |  |  |  |  |
|-----------------|---------------|-----------------------|--|--|--|--|--|--|--|
| SDRAM INTERFACE |               |                       |  |  |  |  |  |  |  |
| sdc_clk         | Out           | Clock for sdram       |  |  |  |  |  |  |  |
| sdc_ad          | Out           | Address bus           |  |  |  |  |  |  |  |
| sdc_ba          | Out           | Bank address          |  |  |  |  |  |  |  |
| sdc_dq          | Inout         | Data bus              |  |  |  |  |  |  |  |
| sdc_dqs         | Inout         | Data strobe           |  |  |  |  |  |  |  |
| sdc_rasb        | Out           | Row address select    |  |  |  |  |  |  |  |
| sdc_casb        | Out           | Column address select |  |  |  |  |  |  |  |
| sdc_web         | Out           | Write enable          |  |  |  |  |  |  |  |
| sdc_dm          | Out           | Data mask             |  |  |  |  |  |  |  |
| sdc_cke         | Out           | Clock enable          |  |  |  |  |  |  |  |
| sdc_csb         | Out           | Chip select           |  |  |  |  |  |  |  |



## State Diagram:-





## Block Diagram:-

|                | В                                 |                                   |                                   |                             |      |  |
|----------------|-----------------------------------|-----------------------------------|-----------------------------------|-----------------------------|------|--|
|                | Bank 0<br>Control<br>(controller0 | Bank 1<br>Control<br>(controller1 | Bank 2<br>Control<br>(controller2 | Bank 3 Control (controller3 | DATA |  |
| <b>ADDRESS</b> | Burst                             | ) Burst                           | Burst                             | Burst                       | PATH |  |
| LATCH          | Counter                           | Counter                           | Counter                           | Counter                     | FAIH |  |
|                | Rcd                               | Rcd                               | Rcd                               | Rcd                         |      |  |
|                | Counter                           | Counter                           | Counter                           | Counter                     |      |  |
|                | Cslt                              | Cslt                              | Cslt                              | Cslt                        |      |  |
|                | Counter                           | Counter                           | Counter                           | Counter                     |      |  |
|                | <u> </u>                          |                                   |                                   |                             |      |  |

## **Block Level Description:-**

### **Address Latch Module**



This module takes the address input from host(22bits) and gives out data for *mode register* on "sdc\_ad" when "mrs\_addr" input is high,determines the bank, cas latency,burst length and puts it on the corresponding outputs.When "row\_addr" input is high (activate row),"sdc\_addr" will have row address on it otherwise column address.

#### **Data Path Module**





This module controls the data on the datbus(sdc\_dq) according to the "sdc\_sel" input during the "write" cycle.If "sdc\_sel" is high (single data rate),it will write/read data on every positive edge of the clock else it will write/read data on both the edges of the clock. It also generates data strobe signal on "sdc\_dqs" for ddr—sdram, data\_valid signal on "u\_data\_valid" indicating the host that the data on "u\_data\_o" is valid during read cycle.

#### **Bank Controller Module**



The Bank controller module has 4 controllers for each bank.



It takes the command input and gives to appropriate controller depending on the bank address. It generates the commands for sdram on "sdc\_rasb,sdc\_casb,sdc\_web". It also gives read &write enable, data valid enable signals for data path module, mrs\_addr &row\_addr for address latch module. It also gives bank address to the sdram.

#### **Controller Module**



This module gets command from the bank controller depending on the bank address. It loads the burst, rcd, cas latency counters and starts them. It generates the commands for sdram for any particular bank.



# Pipeline Diagram :-

|          |     | l i   |            |             |        |            | <br>                |     | 1       |      | ı          | ı         | l i    |      | 1       |    |
|----------|-----|-------|------------|-------------|--------|------------|---------------------|-----|---------|------|------------|-----------|--------|------|---------|----|
| CYCLE    | 1   | 2     | 3          | 4           | 5      | 6          | 7                   | 8   | 9       | 10   | 11         | 12        | 13     | 14   | 15      | 16 |
| II CMD   |     | <br>  |            |             | İ      |            | <br>                |     | <br>    | <br> | <br> -<br> | <br>      | <br>   |      | !  <br> |    |
| U_CMD    | NOP | PRE   | No         | OP          | LMR    | NO         | )P                  | WR  |         |      | <br>       | NO        | PP     |      |         |    |
| CMD_O    | X   | NO    | )P         | PRE         | NO     | )P         | LMR                 | N(  | )<br>OP | ACT  | NO         | )P        | WR     |      | NOP     |    |
|          | 71  | 1 1 4 | <i>)</i> 1 |             | 110    | )1         |                     | 111 |         |      | 111        | <b>71</b> | ***    |      | 1101    |    |
| u_data_i |     |       |            | XX          |        |            |                     | D0  | D1      | D2   | D3         | D4        | D5     | D6   | D7      | XX |
|          |     | '     |            | <br>        |        |            |                     |     | <br>    | <br> |            |           |        |      |         |    |
| sdc_dq   |     | 2     | 3          |             | 5      |            | 7                   | 8   | ZZ      | 1    | 11         | 12        |        |      | 15      | D0 |
|          |     |       | <br>       | <br>        | <br>   | I          |                     |     | ]<br>   |      |            | <br>      | <br>   | <br> |         |    |
| CYCLE    | 1   | 2     | 3          | 4           | 5      | 6          | 7                   | 8   | 9       | 10   | 11         | 12        | 13     | 14   | 15      | 16 |
|          |     |       | <br>       | <br>        |        |            | i I                 |     | <br>    | <br> | '<br>      |           | <br>   | <br> |         |    |
| U_CMD    | NOP | RD    |            |             | NO     | OP         |                     |     |         |      |            | NO        | OP     |      |         |    |
| CMD O    | 37  | )<br> | 2.D        | A COTT      | 270    |            | DD                  |     | <br>    | NI   | <b>)</b> D |           | !<br>! |      | NOD     |    |
| CMD_O    | X   | N(    | JP         | ACT         | N(     | )P         | RD                  |     | , ,     | N(   | JP         |           |        |      | NOP     |    |
| sdc_dq   |     | <br>  | <br>       | I<br>I<br>I | <br>   | <br> -<br> | '<br>  <del>1</del> | —С  | AS(3)   | )    |            |           | <br>   | <br> |         |    |
| <u></u>  |     |       |            |             | Z      | ZZ         |                     |     |         |      | D0         | D1        | D2     | D3   | D4      | D5 |
| u_data_o |     |       | <u> </u>   | ]           | l<br>I |            |                     |     | <br>    |      |            |           |        | I    |         |    |
|          |     |       |            |             |        | XX         |                     |     |         |      |            | D0        | D1     | D2   | D3      | D4 |
|          |     |       |            |             |        |            |                     |     | t .     |      |            |           | 1      | 1    |         |    |





**CONTROLLER** 



