User manual

Table Of Contents
Zynq-7000 AP SoC Technical Reference Manual www.xilinx.com 322
UG585 (v1.11) September 27, 2016
Chapter 10: DDR Memory Controller
10.8 Error Correction Code (ECC)
There is optional ECC support in half-bus width (16-bit) data width configuration only.
Externally 26 bits of a DRAM DDR device are required, 16-bits for data and 10 bits for ECC. Each data
byte uses an independent 5-bit ECC field. This mode provides single error correction and dual error
detection. The ECC bits are interlaced with the data bits and unused bits as shown in Table 10-13.
10.8.1 ECC Initialization
ECC is supported in 16-bit bus mode only. When enabled, a write operation computes and stores an
ECC code along with the data, and a read operation reads and checks the data against the stored ECC
code. It is therefore possible to receive ECC errors when reading uninitialized memory locations. To
avoid this problem, all memory locations must be written before being read. Note that, since ECC is
computed and checked over a byte resolution, a read of 1 byte is done to a 16-bit location that has
only that byte initialized (second byte of 16-bit location is uninitialized) does not result in an ECC
error. The controller only checks ECC on the byte that has been read. Writing to the entire DDR DRAM
through the CPU can be time intensive. It may be worthwhile to use a DMA device to generate larger
bursts to the DDR controller initialization and offload the CPU. Note that only the ARM CPU and ACP
interfaces can access the lowest 512 KB of DDR (see Table 4-1), CPU software may still need to
initialize this region of ECC-based DDR.
Note that while only two data byte lanes are used for actual data, all four lanes are used in ECC mode,
and therefore DDR training must be performed on all lanes.
10.8.2 ECC Error Behavior
For correctable ECC errors, there is no error actively signaled via an interrupt or AXI response.
For uncorrectable ECC errors, the controller returns a SLVERR response back to the re-questing AXI
bus master. In both cases, information regarding the error (such as column, row and bank error
address, error byte lane, etc.) is logged in the controller register space.
When the controller detects a correctable ECC error, it does the following:
Table 10-13: ECC Data Bit Assignments
DRAM DQ pin Number of Pins Function
DQ[7:0] 8 First Data Byte
DQ[15:8] 8 Second Data Byte
DQ[20:16] 5 ECC bits associated with first Data Byte
DQ[23:21] 3 Unused bits. Connect to DRAM for proper
initialization purpose
DQ[28:24] 5 ECC bits associated with second Data Byte
DQ[31:29] 3 Unused bits. Connect to DRAM for proper
initialization purpose