# RONTGRADE

## **APPLICATION NOTE**

### UT700

Enable BCH and Reed Solomon EDAC UT700 LEON 3FT

> 6/21/2016 Version #: 1.0.0

6/21/2016

#### **Table 1: Cross Reference of Applicable Products**

| Product Name   | Manufacturer Part<br>Number | SMD #      | Device Type       | Internal PIC Number |
|----------------|-----------------------------|------------|-------------------|---------------------|
| UT700 LEON 3FT | UT700                       | 5962-13238 | Memory Controller | WQ03                |

#### **1.0 Overview**

The UT700 LEON 3FT consists of multiple on-chip modules and a fault tolerance memory controller that supports three types of memory devices, PROM, SRAM, and SDRAM respectively. These three types of memory devices are mapped into its specific memory regions defined by the UT700 LEON 3FT architecture. Please see Figure 1 for the types of memories mapping onto the memory map.





Note: For maximum PROM, SRAM, and SDRAM support sizes, please refer to the UT700 LEON 3FT Functional Manual.

The memory controller employs two types of fault-tolerance techniques. Each type of the fault-tolerance techniques can be applied to the specific memory types using the GPIOs' setting and the memory configuration registers (MCFGX) provided by the memory controller. The memory controller also supports memory devices with data bus width of 8, 16 and 32-bits.

This Application Note (AN) will provide concise ways to enable EDAC for the different types of memory devices mapped to the UT700 LEON fault tolerance memory controller both in hardware and software.

6/21/2016

#### 2.0 UT700 LEON 3FT Memory Controller

The fault tolerance memory controller provides both the BCH EDAC and Reed-Solomon EDAC features to improve the data integrity of the memory devices.

The BCH EDAC algorithm generates a 7-bit checksum for every 32-bit word and provides a single-bit-error correction and a dual-bit-error detection to that data word. BCH EDAC can be used on PROM, SRAM, and SDRAM memory by setting the corresponding EDAC enable bits in the MCFGX and the respective GPIO settings. For more details about the BCH EDAC, please refer to the UT700 LEON 3FT Functional Manual **3.10.1** BCH EDAC.

The Reed-Solomon EDAC algorithm provides a block error correction that generates a 16-bit checksum for every 32-bit data word and is capable of correcting any two adjacent 4-bit-nibble errors. The Reed-Solomon EDAC only supports SDRAM. For more details about the Reed-Solomon EDAC, please refer to the UT700 LEON 3FT Functional Manual **3.10.2** Reed-Solomon EDAC.

**Table 2** provides a breakdown of all the memory device configurations that are supported by the BCH and the Reed-Solomon EDAC.

| Memory Type  | ECH EDAC  | Remarks                           | Reed-Solomon EDAC | Remarks                      |
|--------------|-----------|-----------------------------------|-------------------|------------------------------|
| 8-bit PROM   | Supported | Configuration using GPIO[2:0] and | Not Supported     |                              |
| 32-bit PROM  | Supported | mkprom2                           | Not Supported     | N.A                          |
| 8-bit SRAM   | Supported | Configuration using MCECY         | Not Supported     | N.A                          |
| 32-bit SRAM  | Supported | Configuration using MCFGX         | Not Supported     |                              |
| 32-bit SDRAM | Supported | Configuration using MCFGX         | Supported         | Configuration<br>using MCFGX |

#### **Table 2: Types of Memory Device Configurations**

#### **3.0 Memory Configuration**

The following sections will show how each memory device is configured to function with the UT700 LEON 3FT memory controller with EDAC enabled. Hardware block diagrams will be referenced that show how the memory devices are connected to the UT700 LEON 3FT Memory Controller. Software examples will be provided to show how to set the MCFGX to enable the memory devices in different operation modes as shown in Table 2.

#### 3.1 Programmable Read-Only Memory, PROM

At Power-On-Reset (POR), the UT700 goes through a series of internal initialization steps followed by the reading of the PROM for the next flow control instruction required by the system to function.

Therefore, using the MCFGX to configure the PROM bus width will not work; the UT700 needs to know how to read the instruction from the PROM to perform the configuration.

The correct way to configure the PROM data bus width and enable BCH EDAC is to drive the GPIO [2:0] to its appropriate states as shown in **Table 3.** 

#### Table 3: PROM Data Bus and ECH EDAC Configuration

| PROM Data Bus Width  | GPIO[2] | GPIO[1] | GPIO[0] | Remarks       |
|----------------------|---------|---------|---------|---------------|
| 8-bit/No ECH EDAC    | 0       | 0       | 0       |               |
| 8-bit/With ECH EDAC  | 1       | 0       | 0       | mkprom2       |
| 32-bit/No ECH EDAC   | 0       | 1       | 0       |               |
| 32-bit/With ECH EDAC | 1       | 1       | 0       | mkprom2       |
| Not Used             | х       | 1       | 1       | Illegal state |

#### 3.1.0 PROM Configuration, BCH EDAC

Please refer to Memory Controller with EDAC chapter block diagrams (Figure 3.2 and Figure 3.4) for 8-bit and 32-bit Memory Interface Examples in the UT700 LEON 3FT Functional Manual. In addition to these block diagrams, the PROM also requires that the GPIO [2:0] be set to its appropriate states based on the data bus width of the PROM devices.

The GPIO pins setting are shown in Table 3. To set the GPIO to logic '1', a pull-up to 3.3V with a 1K and higher resistance resistor is needed. To set the GPIO to logic '0', a pull-down with a 10K resistor is needed.

There is no software setting requirement to configure the PROM memory interface. However, to support ECH EDAC, a special utility known as the MKPROM2 is required to generate the 7-bit checksums. These checksum bits will be stored in the upper 20% region of the PROM, a unique feature offered by the memory controller to reduce the number of chip counts and reduce the size of the PCB.

#### 8-bit PROM

In 8-bit mode, the mkprom2 utility offers two ways to generate the BCH EDAC checksums: a 4:1 space ratio or a 3:1 space ratio BCH checksum output file (they are the same except their space allocation). Appended are the command lines and parameters required to generate BCH checksums as follows:

mprom2 -romwidth 8 -romsize 2048 -romcs 1 Appl -mv8 -bch8 // 4:1 space ratio
mprom2 -romwidth 8 -romsize 2048 -romcs 1 Appl -mv8 -bch8q // 3:1 space ratio

The 4:1 space ratio BCH checksum requires a 20% of the upper PROM space while the 3:1 space ratio BCH checksum requires a 25% of the upper PROM space.

Once the checksum file is generated, you can use **GRMON (flash load <file>)** to program the application file and the checksum file to the PROM device. The code and the checksum bits are organized in the PROM as shown in Figure 2 and the coloring shows its relationship.

## FRONTGRADE

Version #: 1.0.0

6/21/2016





#### 32-bit PROM

MKPROM2 and GRMON do not support 32-bit PROM mode. For more information on 32-bit PROM mode, please contact your area FAE for more information.

8-bit/16-bit 8-bit 8-bit 8-bit 8-bit CD[0] CD[3] CD[1] CD[2] CB[0] CD[4] CD[5] CD[6] CD[7] CB[1] CD[8] CD[9] CD[10] CD[11] CB[2] CD[14] CD[12] CD[13] CD[15] CB[3]

In 32-bit mode, the code and BCH checksum bits are organized as shown in Figure 3.

Figure 3: 32-bit PROM Code and BCH Checksum organization

....

#### Legend:

CB: checksum bits CD: code

Please refer to the **GRMON** and **MKPROM2** documents for more information. The **GRMON** and **MKPROM2** utilities and it documents can be found on <u>www.frontgrade.com</u>.

#### 3.2 Static Random-Access Memory, SRAM

After POR, device initialization loads from the of PROM device. During this state, the stack and heap memory (SRAM/SDRAM) are not yet available to the system. This means that the application in the PROM must not access the volatile memory until it is initialized. Since this is the order of the system flow control, configuring and initializing the volatile memories via the MCFGX is possible.

The SRAM configuration and initialization are shown in the following section.

#### **3.2.0 SRAM Configuration, BCH EDAC**

Please reference to **3.1.0** for hardware connection block diagrams. SRAM configuration can be achieved via the MCFGX registers.

In **Table 4**, these are the codes needed to configure the SRAM for its respective operation as follows:

#### **Table 4: SRAM Data Bus and ECH EDAC Configuration**

**Memory Configuration Register 2** 

| Bit# | Name | 8-bit   | 32-bit  | Remarks                                                                                                           |
|------|------|---------|---------|-------------------------------------------------------------------------------------------------------------------|
| 14   | DE   | 0x0/0x1 | 0x0/0x1 | SDRAM controller disable automatically enable SRAM<br>0: SDRAM controller disabled<br>1: SDRAM controller enabled |
| 13   | SI   | x/0x0   | x/0x0   | SRAM enable                                                                                                       |
| 12-9 | SZ   | size    | size    | Size of each SRAM bank as 8 * 2 <i>SZ</i> KB<br>0000: 8KB<br>0001: 16KB<br>0010: 32KB<br><br>1111: 256MB          |
| 6    | RM   | 0x1     | 0x1     |                                                                                                                   |
| 5-4  | SD   | 0x0     | 0x2     | Data width of the SRAM area                                                                                       |
| 3-2  | SW   | 0x0     | 0x0     | Number of wait states during SRAM write cycles                                                                    |
| 1-0  | SR   | 0x0     | 0x0     | Number of wait states during SRAM read cycles                                                                     |

**Memory Configuration Register 3** 

| Bit# | Name | 8-bit | 32-bit | Remarks                                                                                                                                 |
|------|------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 9    | SE   | 0x1   | 0x1    | Enable EDAC checking of the SDRAM or SRAM area<br>0: EDAC checking of the RAM area disabled<br>1: EDAC checking of the RAM area enabled |

Extracting the data from the Table 4 for 8-bit mode, the C codes are as appended.

| <pre>FRMCTRL.MCFG2.B.DE = 0x1;</pre> | // 0: SDRAM controller enabled                         |
|--------------------------------------|--------------------------------------------------------|
| <pre>FRMCTRL.MCFG2.B.SI = 0x0;</pre> | // 0: SRAM enabled                                     |
| FRMCTRL.MCFG2.B.SZ = 0xF;            | // 256MB                                               |
| <pre>FRMCTRL.MCFG2.B.RM = 0x1;</pre> | // Enable read-modify-write                            |
| FRMCTRL.MCFG2.B.SD = $0 \times 0$    | // 8-bit                                               |
| FRMCTRL.MCFG2.B.SW = 0x0             | // O wait state (write) change this for different SRAM |
| FRMCTRL.MCFG2.B.SR = $0 \times 0$    | // O wait state (read) change this for different SRAM  |
| FRMCTRL.MCFG3.B.SE = 0x1             | // 1 wait state (read) change this for different SRAM  |

In 8-bit mode, the checksum bits are stored similar to the PROM at the upper 20% of the SRAM. The difference is the checksum bits are created on the fly. For 32-bit mode, another 8-bit SRAM (size=20% of the 32-bit SRAM) is required for storing the checksum bits generated by the BCH engine and retrieving for error detection and correction.

The code and its respective checksum bits for 8-bit and 32-bit SRAMs are organized in the same format as the PROM device as shown in **Figure 2** and **Figure 3** respectively.

Please see Appendix A for the fault tolerance memory controller header file.

#### 3.3 Synchronous Dynamic Random-Access Memory, SDRAM

Similar to **3.2**, the SDRAM also needs to be initialized before being used. However, for SDRAM, the memory controller supports both BCH and Reed-Solomon EDAC.

The SDRAM configuration and initialization are shown in the following section.

3.3.0 SDRAM Configuration, BCH and Reed-Solomon EDAC

Please reference to **3.1.0** for hardware connection block diagrams. SDRAM configuration can be achieved via the MCFGX registers.

In **Table 5**, the 32-bit data width SDRAM supports both BCH and Reed-Solomon EDAC. These are the codes needed to configure the SDRAM for its respective operation mode as follows:

#### Table 5: SRAM Data Bus and ECH EDAC Configuration

**Memory Configuration Register 2** 

| Bit# | Name | ВСН       | Reed-<br>Solomon | Remarks                                                                                                           |
|------|------|-----------|------------------|-------------------------------------------------------------------------------------------------------------------|
| 14   | DE   | 0x0/0x1   | 0x0/0x1          | SDRAM controller disable automatically enable SRAM<br>0: SDRAM controller disabled<br>1: SDRAM controller enabled |
| 13   | SI   | x/0x0,0x1 | x/0x0,0x1        | 0:0x6000_0000, 1:0x4000_0000 (Memory Map address)                                                                 |

**Memory Configuration Register 3** 

| Bit# | Name | BCH | Reed-Solomon | Remarks                                                                                                                                 |
|------|------|-----|--------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 28   | RSE  | 0x0 | 0x1          | Reed-Solomon EDAC<br>0: BCH EDAC available for SDRAM<br>1: Reed-Solomon EDAC available for SDRAM                                        |
| 9    | SE   | 0x1 | 0x1          | Enable EDAC checking of the SDRAM or SRAM area<br>0: EDAC checking of the RAM area disabled<br>1: EDAC checking of the RAM area enabled |

Extracting the data from the Table 5 for Reed-Solomon, the C codes are as appended.

| <pre>FRMCTRL.MCFG2.B.DE = 0x1;</pre> | // 0: SDRAM controller enabled       |
|--------------------------------------|--------------------------------------|
| <pre>FRMCTRL.MCFG2.B.SI = 0x0;</pre> | // 0: SDRAM mapped at 0x6000_0000    |
| FRMCTRL.MCFG3.B.RSE = 0x1            | // 0: BCH EDAC, 1: Reed-Solomon EDAC |
| FRMCTRL.MCFG3.B.SE = 0x1             | // 0: BCH EDAC, 1: Reed-Solomon EDAC |

The C codes above are required to enable EDAC for SDRAM, BCH or Reed-Solomon. Additional configurations are needed to set the other timing requirements for the type of SDRAM used. These settings can be found in MCFG2 and MCFG3.

The code and its respective checksum bits are organized in the same format as the PROM device as shown in **Figure 3** (For Reed-Solomon, CB is 16 bit wide).

Please see Appendix A for the fault tolerance memory controller header file.

#### **4.0 Summary and Conclusion**

For more information about our UT700 LEON 3FT/SPARCÔ V8 Microprocessor and other products please visit our website, <u>www.frontgrade.com</u>.

6/21/2016

#### **Appendix A: Header File**

| /*****           | * * * * * * * * * * * * * * * * * * * *           | ****     | ******                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------|---------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| * MODULE: FTMCTF | RL Memory Controller H                            | Register | S *                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| \*****           | ********                                          | *******  | **********                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| #define FRMCTRL  | ADDR 0x8000000                                    |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| struct FRMCTRL 7 |                                                   |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| union {          |                                                   |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | vuint32 t R;                                      |          | <pre>// Figure 3.5 Memory Configuration</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Register 1       |                                                   |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | struct {                                          |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | vuint32 t RES31                                   | :1;      | // Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                  | vuint32_t PB                                      | :1;      | // PROM area bus enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                  | vuint32 t AB                                      | :1;      | // Asynchronous bus ready                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                  | vuint32_t IBW                                     | :2;      | // PROM area bus enable<br>// Asynchronous bus ready<br>// I/O data bus width                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  | vuint32 t IB                                      | :1;      | // I/O area bus ready enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                  | vuint32 t BE                                      |          | // Bus error enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                  | vuint32 t RES24                                   | :1;      | // Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                  | vuint32 t IW                                      | :4;      | // Reserved<br>// Number of wait states during I/O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| accesses         |                                                   |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | vuint32 t IE                                      | :1;      | // I/O enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  | vuint32 t RES18                                   | :1;      | // Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                  |                                                   | :4:      | // PROM size is fixed at 256MB (1111)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                  | vuint32 <sup>t</sup> RES1312                      | :2;      | // Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                  | vuint32_t PZ<br>vuint32_t RES1312<br>vuint32_t PE | :1;      | // Reserved<br>// PROM size is fixed at 256MB (1111)<br>// Reserved<br>// PROM write enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                  | vuint32 t RES10                                   | :1;      | // Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                  | vuint32 t PD                                      |          | // Data width of the PROM area                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                  | vuint32 t PW                                      | :4;      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| write cycles     |                                                   |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | vuint32 t PR                                      | :4;      | <pre>// Number of wait states during PROM</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| read cycles      |                                                   |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | } B;                                              |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| } MCFG1;         |                                                   |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| union {          |                                                   |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7                | vuint32 t R;                                      |          | <pre>// Figure 3.6 Memory Configuration</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Register 2       |                                                   |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | struct {                                          |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | vuint32_t DR                                      | :1;      | // SDRAM refresh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                  | vuint32_t DP                                      | :1;      | // SDRAM TRP parameter<br>// SDRAM TRFC parameter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                  | vuint32_t DF                                      | :3;      | // SDRAM TRFC parameter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                  | vuint32_t DC                                      | :1;      | // SDRAM CAS parameter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                  | vuint32_t DZ                                      | :3;      | // Bank size for SDRAM chip selects                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| defined as 4MB*2 |                                                   |          | See Provide the second se<br>Second second sec<br>second second sec |
|                  | vuint32 t DS                                      | :2;      | // SDRAM column size is 2048 when bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [25:23] = 111    |                                                   |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | vuint32_t DD                                      | :2;      | // SDRAM command                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                  | vuint32_t BW                                      | :1;      | // Memory controller data bus width                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                  | vuint32_t PB                                      | :1;      | // SDRAM Page Burst                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                  | vuint32_t RES1615                                 | :2;      | // Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                  | vuint32_t DE                                      | :1;      | // SDRAM enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | vuint32_t SI                                      | :1;      | // SRAM disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  | vuint32_t SZ                                      | :4;      | // Size of each SRAM bank as 8*2^SZ KB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                  |                                                   |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

## FRONTGRADE

#### **APPLICATION NOTE**

Version #: 1.0.0

6/21/2016

|                     | vuint32_t RES8                         | :1;        | // Number of wait states during PROM                |
|---------------------|----------------------------------------|------------|-----------------------------------------------------|
| write cycles        |                                        |            |                                                     |
|                     | vuint32_t SB                           | :1;        | <pre>// Enable read-modify-write cycles on</pre>    |
| sub-word writes     |                                        | 1          |                                                     |
|                     | vuint32_t RM                           | :1;        | <pre>// Number of wait states during PROM</pre>     |
| read cycles         | vuint32 t SD                           | :2;        | // Data width of the SRAM area                      |
|                     | _                                      | :2;        |                                                     |
| write cycles        |                                        | • 2 /      | ,, namber of ware beaceb adding bight               |
|                     | vuint32 t SR                           | :2;        | // Number of wait states during SRAM                |
| read cycles         |                                        |            |                                                     |
| }                   | В;                                     |            |                                                     |
| } MCFG2;            |                                        |            |                                                     |
| union {             |                                        |            |                                                     |
|                     | uint32_t R;                            |            | <pre>// Figure 3.7 Memory Configuration</pre>       |
| Register 3          |                                        |            |                                                     |
| S                   | <pre>truct {   vuint32 t RES3129</pre> |            | // Reserved                                         |
|                     | vuint32 t RSE                          | :3;        |                                                     |
|                     | vuint32 t ME                           | :1;<br>:1; | // Memory EDAC                                      |
|                     |                                        |            |                                                     |
|                     | vuint32_t RLDVAL                       | :15;       | // SDRAM refresh counter reload value               |
|                     | vuint32_t WB                           | :1;        | // EDAC diagnostic write bypass                     |
|                     | vuint32_t RB                           | :1;        | <pre>// EDAC diagnostic read bypass</pre>           |
|                     | vuint32_t SE                           | :1;        | // Enable EDAC checking of the SDRAM or             |
| SRAM area           |                                        |            |                                                     |
|                     | vuint32_t PE                           | :1;        | <pre>// Enable EDAC checking of the PROM area</pre> |
| (GPI0[2])           |                                        | 0          |                                                     |
| ,                   |                                        | :8;        | // Test check bits                                  |
| }<br>} MCFG3;       | B;                                     |            |                                                     |
| } MCFG3;<br>union { |                                        |            |                                                     |
|                     | uint32 t R;                            |            | <pre>// Figure 3.8 Memory Configuration</pre>       |
| Register 4          |                                        |            | // ligure 5.0 Hemory configuration                  |
|                     | truct {                                |            |                                                     |
|                     | vuint32 t RES3117                      | :15;       | // Reserved                                         |
|                     | vuint32 t WB                           |            | // Reed Solomon EDAC diagnostics write              |
| bypass              |                                        |            |                                                     |
|                     | vuint32_t RTC                          | :16;       | // Reed Solomon test check bits                     |
| }                   | в;                                     |            |                                                     |
| } MCFG4;            |                                        |            |                                                     |
|                     |                                        |            |                                                     |

#### **Appendix B: Acronyms**

**BCH:** BCH codes were invented in 1959 by French mathematician Alexis Hocquenghem, and independently in 1960 by Raj Bose and D. K. Ray-Chaudhuri

EDAC: Error Detection and Correction

MCFX: Memory Configuration Register (1, 2, 3, or 4)

PROM: Programmable Read-only Memory

SRAM: Static Random-Access memory

SDRAM: Synchronous Dynamic Random-Access Memory

#### **Revision History**

| Date       | Revision # | Author | Change Description | Page # |
|------------|------------|--------|--------------------|--------|
| 06/15/2016 | 1.0.0      | MTS    | Initial Release    |        |
|            |            |        |                    |        |
|            |            |        |                    |        |
|            |            |        |                    |        |

**Frontgrade Technologies Proprietary Information** Frontgrade Technologies (Frontgrade or Company) reserves the right to make changes to any products and services described herein at any time without notice. Consult a Frontgrade sales representative to verify that the information contained herein is current before using the product described herein. Frontgrade does not assume any responsibility or liability arising out of the application or use of any product or service described herein, except as expressly agreed to in writing by the Company; nor does the purchase, lease, or use of a product or service convey a license to any patents, rights, copyrights, trademark rights, or any other intellectual property rights of the Company or any third party.