Intel
®
81341 and 81342 I/O Processors
December 2007
Developer’s Manual
Order Number: 315037-002US
681
SRAM Memory Controller—Intel
®
81341 and 81342
8.3.2
SRAM Memory Interface Support
The 81341 and 81342 memory controller supports 1.0 Mbytes of on-chip SRAM. The
SMCU supports a 256-bit data bus width memory with ECC. The SMCU supports 7-bit
ECC on every 32-bit data quantity, providing higher performance when the core
processor is processing data by eliminating any RMW cycle required for 4-Byte store
ECC generation.
The SMCU supports seamless read/write bursting of long data streams.
8.3.2.1
SRAM Initialization
Initialization software should initialize the entire SRAM memory array in order to have
the correct ECC values for each ECC location. Refer to
Section 8.3.3, “Error Correction
) for more details.Reading from an uninitialized memory
location will result in an ECC error. By default data parity checking is disabled, firmware
must enable data parity checking if required. Refer to
Control and Status Register — SPARCSR” on page 706
8.3.2.2
SRAM Read Sequence
Read transactions require ECC codes to be calculated and compared with the ECC
returned by the SRAM array. The following steps describe the read sequence.
1. Each of the SMCU inbound memory transaction ports decodes the address to
determine if the transaction should be claimed.
— If the address falls in the SRAM address range indicated by the SRAMBAR and
SRAMUBAR the SMCU claims the transaction.
2. Once the SMARB selects the highest priority port transaction, it forwards the
transaction to the SRAM control block.
3. Upon receipt of the data, the SRAM Control Block calculates the ECC code from the
data and compares it with the ECC returned by the SRAM array.
“Error Correction and Detection” on page 683
explains the ECC algorithm in more
detail.
4. Assuming the calculated ECC matches the read ECC, the SRAM Control Block drives
the data back to the corresponding memory port.
— For each burst read issued, the memory controller increments the address by
sixteen.
The SMCU continues to return data to the corresponding memory port based on the
byte count of the transaction.