

**CPE DDR Configuration** 

**Application Note** 

BROADCOMCOMFIDERIIA

Broadcom, the pulse logo, Connecting everything, Avago Technologies, Avago, and the A logo are among the trademarks of Broadcom and/or its affiliates in the United States, certain other countries and/or the EU.

Copyright © 2017 by Broadcom. All Rights Reserved.

The term "Broadcom" refers to Broadcom Limited and/or its subsidiaries. For more information, please visit www.broadcom.com.

Broadcom reserves the right to make changes without further notice to any products or data herein to improve reliability, function, or design. Information furnished by Broadcom is believed to be accurate and reliable. However, Broadcom does not assume any liability arising out of the application or use of this information, nor the application or use of any product or circuit described herein, neither does it convey any license under its patent rights nor the rights of others.



#### **Table of Contents**

| Chapter 1: DDR Configuration                                                                                                             | 4  |
|------------------------------------------------------------------------------------------------------------------------------------------|----|
| 1.1 Introduction                                                                                                                         | 4  |
| 1.2 Supported Broadcom Devices                                                                                                           | 4  |
| 1.3 Preventing Automatic DDR Config Update                                                                                               | 5  |
| 1.4 DDR Settings Word Bit Mask                                                                                                           | 5  |
| 1.5 Changing DDR Configuration                                                                                                           | 7  |
| 1.6 Early Key Abort and DDR Safe Mode                                                                                                    | 7  |
| 1.7 DDR Strap Configuration                                                                                                              | 8  |
| Chapter 2: Supported DDR Configurations                                                                                                  | 9  |
| 2.1 BCM63138/BCM63148 DDR Configurations                                                                                                 | g  |
| 2.2 BCM62118 DDR Configurations                                                                                                          | 10 |
| 2.3 BCM6858X DDR Configurations                                                                                                          | 10 |
| 2.1 BCM63138/BCM63148 DDR Configurations 2.2 BCM62118 DDR Configurations 2.3 BCM6858X DDR Configurations 2.4 BCM68460 DDR Configurations | 11 |
| 2.5 BCM68360 DDR Configurations                                                                                                          | 11 |
| 2.6 BCM68560 DDR Configurations 2.7 BCM63158 DDR Configurations  Revision History                                                        | 11 |
| 2.7 BCM63158 DDR Configurations                                                                                                          | 12 |
| Revision History                                                                                                                         | 13 |
| Revision History                                                                                                                         |    |

### **Chapter 1: DDR Configuration**

#### 1.1 Introduction

This document describes how to set up DDR parameters via an NVRAM.

DDR configuration parameters (size, clock, speed grade, memory chip data width, and so on) are stored in the NVRAM. The DDR configuration is a 32-bit board parameter ID, <code>bp\_ulMemoryConfig</code> in the boardparms.c file for a particular board ID and is saved in NVRAM.

When a new board first boots up, the CFE ROM uses default safe mode DDR configuration to initialize the DDR and run CFE RAM. The CFE RAM then saves the configuration to NVRAM. The CFE RAM always compares the DDR configuration from the value set in *boardparms.c* to the NVRAM configuration. If they are different, it updates to the NVRAM configuration and reboots automatically. This allows the DDR configuration to be updated on a board automatically if a new software release changes the DDR configuration.

#### 1.2 Supported Broadcom Devices

This document applies to all Broadcom devices that support NVRAM DDR configuration, the following is not an exhaustive list:

- BCM63138
- BCM63148
- BCM63158
- BCM62118
- BCM6858X
- BCM68360
- BCM68460
- BCM68560
- BCM4908

In some devices, the DDR configuration can be set by bootstraps. For more information regarding these devices, see the DDR Strap Configuration section.

#### 1.3 Preventing Automatic DDR Config Update

To prevent the automatic update when setting the NVRAM configuration, set bit #31 (see Changing DDR Configuration). When CFE starts, and just before DDR Shmoo is running, the CFE prints out the current DDR configuration in NVRAM:

```
MAIN
DRAM
NVRAM memcMCB chksum 0xf51e43ef
DDR3-1600 CL11 128MBx2
```

The DDR configuration board parameter is defined in the following format in boardparms.c:

```
{bp ulMemoryConfig, .u.ul = BP DDR SPEED 533 8 8 8 | BP DDR TOTAL SIZE 128MB|
   BP_DDR_DEVICE_WIDTH 16},
```

This means single ×16 DDR chip of total size 128 MB running at DDR3 1066 data rate with CAS latency = 8.

```
{bp_ulMemoryConfig, .u.ul = BP_DDR_SPEED_1067_14_14_14 | BP_DDR_TOTAL_SIZE_1024MB|
BP_DDR_DEVICE_WIDTH_16 | BP_DDR_TOTAL_WIDTH_32BIT},
```

This means two x16 DDR chips of 512 MB each running at DDR3 2133 data rate with CAS latency = 14

NOTE: For production, it is required to store the DDR configuration data in the NVRAM, so DDR initialization in the first boot will be as required and not in safe mode.

#### 1.4 DDR Settings Word Bit Mask

The complete parameter definitions of the word written to NVRAM are listed below (taken from boardparms.h):

```
#define BP DDR SPEED MASK
#define BP DDR SPEED SHIFT
#define BP DDR SPEED SAFE
#define BP DDR SPEED 400 6 6 6
#define BP DDR SPEED 533 7 7
#define BP DDR SPEED 533 8 8
#define BP DDR SPEED 667 9 9
#define BP DDR SPEED 667 10 10 10
#define BP DDR SPEED 800 10 10 10
#define BP DDR SPEED 800 11 11 11
                                         7
#define BP DDR SPEED 1067 11 11 11
#define BP DDR SPEED 1067 12 12 12
#define BP DDR SPEED 1067 13 13 13
                                         10
#define BP_DDR_SPEED_1067_14_14 14
                                         11
#define BP DDR SPEED 933 10 10 10
                                         12
#define BP DDR SPEED 933 11 11 11
                                         13
#define BP DDR SPEED 933 12 12 12
#define BP DDR SPEED 933 13 13 13
                                         15
#define BP DDR SPEED CUSTOM 1
                                         27
#define BP DDR SPEED CUSTOM 2
                                         28
#define BP DDR SPEED CUSTOM 3
                                         29
#define BP DDR SPEED CUSTOM 4
                                         30
#define BP DDR DEVICE WIDTH MASK
                                         0xe0
#define BP DDR DEVICE WIDTH SHIFT
                                         5
```

CPF-AN3100 Broadcom

```
#define BP DDR DEVICE WIDTH 8
                                         (0 << BP DDR DEVICE WIDTH SHIFT)
#define BP DDR DEVICE WIDTH 16
                                         (1 << BP DDR DEVICE WIDTH SHIFT)
#define BP DDR DEVICE WIDTH 32
                                         (2 << BP DDR DEVICE WIDTH SHIFT)
#define BP DDR TOTAL SIZE MASK
#define BP DDR TOTAL SIZE SHIFT
#define BP DDR TOTAL SIZE 64MB
                                         (1 << BP DDR TOTAL SIZE SHIFT)
#define BP DDR TOTAL SIZE 128MB
                                         (2 << BP DDR TOTAL SIZE SHIFT)
#define BP DDR TOTAL SIZE 256MB
                                         (3 << BP DDR TOTAL SIZE SHIFT)
#define BP_DDR_TOTAL_SIZE_512MB
                                         (4 << BP DDR TOTAL SIZE SHIFT)
#define BP_DDR_TOTAL_SIZE_1024MB
                                         (5 << BP_DDR_TOTAL_SIZE_SHIFT)
#define BP DDR TOTAL SIZE 2048MB
                                         (6 << BP DDR TOTAL SIZE SHIFT)
#define BP DDR TOTAL SIZE 4096MB
                                         (7 << BP DDR TOTAL SIZE SHIFT)
#define BP DDR SSC CONFIG MASK
                                         0xf000
#define BP DDR SSC CONFIG SHIFT
                                         12
#define BP_DDR_SSC_CONFIG NONE
                                         (0 << BP DDR SSC CONFIG SHIFT)</pre>
                                         (1 << BP_DDR_SSC_CONFIG_SHIFT) /*1% SSC*/
#define BP DDR SSC CONFIG 1
                                         (2 << BP_DDR_SSC_CONFIG_SHIFT) /*0.5% SSC*/
#define BP DDR SSC CONFIG 2
#define BP DDR SSC CONFIG CUSTOM
                                         (3 << BP DDR SSC CONFIG SHIFT)
#define BP DDR TEMP MASK
                                         0x30000
#define BP_DDR_TEMP_SHIFT
                                         16
                                         (0 << BP_DDR_TEMP_SHIFT)
#define BP DDR TEMP NORMAL
                                                                     /* Self-Refresh for Normal
Temperature */
                                         (1 << BP_DDR_TEMP_SHIFT)
#define BP DDR TEMP EXTENDED SRT
                                                                     /* Self-Refresh for Extended
Temperature */
#define BP DDR TEMP EXTENDED ASR
                                        (2 << BP DDR TEMP SHIFT)
                                                                   /* Auto Self-Refresh Enabled for
Normal and Extended Temperature */
#define BP DDR TOTAL WIDTH MASK
                                         0xc0000
#define BP DDR TOTAL WIDTH SHIFT
                                         18
#define BP DDR TOTAL WIDTH 16BIT
                                         (0 << BP DDR TOTAL WIDTH SHIFT)
#define BP DDR TOTAL WIDTH 32BIT
                                         (1 << BP DDR TOTAL WIDTH SHIFT)
#define BP DDR CONFIG MASK
                                        (BP DDR CONFIG DEBUG|BP DDR CONFIG OVERRIDE))
                                         (1 << 30)
#define BP DDR CONFIG DEBUG
#define BP DDR CONFIG OVERRIDE
                                         (1 << 31)
```

### 1.5 Changing DDR Configuration

When using a different DDR chip than the chip specified in the Broadcom reference design, create a new board ID with the correct <code>bp\_ulMemoryConfig</code> setting. Loading the new code will automatically update the DDR configuration in the NVRAM.

CFE also supports a "ddr" command to manually change the DDR configuration from the CFE prompt without making any software change:

```
CFE> ddr
DDR Config OVERRIDE : 0x307 0x80000303
Config Changed... REBOOT NEEDED
*** command status = 0
CFE>
```

The command writes the new configuration to NVRAM. In the example above, 0x307 is the old DDR configuration in the NVRAM and CFE board parameters. This command changes the DDR clock from 800 MHz to 533 MHz. It is also necessary to set bit 31. This bit is the NVRAM configuration overwrite bit that tells the CFE to not compare its built-in board parameter configuration 0x307 against NVRAM setting 0x303 and to update NVRAM. This ensures that CFE always uses the value entered from the command line.

#### 1.6 Early Key Abort and DDR Safe Mode

CFE-ROM can be aborted before DDR initialization, this enables the user to set DDR configuration in runtime. In order to abort CFE-ROM:

- 1. Power off the device.
- 2. Hold down the 'a' key.
- 3. Power on the device. The following message will appear:

```
CFE-ROM WAS ABORTED

Please choose one of the following options:

c - continue

s - DDR safe mode

i - followed by 0 to boot to a previous fs image

0 - followed by hex numbers to select MCB; CR/NL to continue
```

a. Press 's' for safe mode:

If a board failed to boot due to a DDR memory problem, the CFE has an option to run in DDR safe mode and allow the board to boot for further debugging or fixing with a new DDR configuration. The DDR safe mode runs with conservative DDR parameters.

To keep the board in safe mode without this special key abort, run the DDR command in CFE console and set the DDR configuration to 0x80000000 and reset the board:

```
CFE> ddr
DDR Config OVERRIDE : 0x223 0x80000000
Config Changed... REBOOT NEEDED
*** command status = 0
```

b. For Runtime selection: press '0' and Hex number

The number is according to the DDR Settings Word Bit Mask section.

#### 1.7 DDR Strap Configuration

For the following devices, the DDR settings can be configured through NVRAM, as described in this document, or by straps: BCM6858XX, BCM5504X, BCM49508

■ To take DDR parameters from NVRAM, the signal STRAP\_SOFTWARE2 (GPIO\_45) must be set to 0 at boot up. In this case, all other DDR straps will be ignored.

■ To take DDR parameters from the straps, the signal STRAP\_SOFTWARE2 (GPIO\_45) must be set to 1. In this case the DDR clock will be 1067 MHz (CAS latency=14), and the DDR density will be set according to the following table:

|                      |                             | STRAP_DDR_16BIT_ENABLE |                    |
|----------------------|-----------------------------|------------------------|--------------------|
| STRAP_SW_1 (GPIO_44) | STRAP_DDR_DENSITY (GPIO_42) | 1: 16 bit DDR          | 0: 32 bit DDR      |
| 1                    | 1                           | = 2Gb x 1 = 256 MB     | = 2Gb x 2 = 512 MB |
| 0                    | 1                           | = 8Gb x 1 = 1 GB       | = 8Gb x 2 = 2 GB   |

For any configuration not listed in the table above, settings must be taken from NVRAM.

### **Chapter 2: Supported DDR Configurations**

Each configuration has a corresponding MCB that is used by the DDR library during the initialization. CFE currently supports a limited number of common configurations and MCB due to the image size limitation.

The supported configuration is defined in cfe/cfe/arch/arm/board/bcm63xx\_rom/src/bcm63xx\_impl1/2\_ddr\_mcb.c.

The following tables list the currently supported configurations for the various devices. For the latest updates, see the software release notes.

### 2.1 BCM63138/BCM63148 DDR Configurations

Table 1: BCM63138/BCM63148 DDR Configurations Supported

| Configuration                                         | Value             |
|-------------------------------------------------------|-------------------|
| DDR3-1066 CL8 Total 128 MB one 16-bit part            | 0x223             |
| DDR3-1600 CL11 Total 128 MB One 16-bit part           | 0x227             |
| DDR3-1066 CL8 Total 256 MB One 16-bit part            | 0x323             |
| DDR3-1066 CL8 Total 256 MB two 8-bit parts            | 0x303             |
| DDR3-1600 CL11 Total 256 MB One 16-bit part           | 0x327             |
| DDR3-1600 CL11 Total 256 MB Two 8-bit parts           | 0x307             |
| DDR3-1600 CL11 Total 256 MB One 16-bit part 0.5% SSC  | 0x2327            |
| DDR3-1600 CL11 Total 256 MB One 16-bit part HT SRT    | 0x10327           |
| DDR3-1600 CL11 Total 256 MB One 16-bit part HT ASR    | 0x20327           |
| DDR3-800 CL6 Total 512 MB One 16-bit part             | 0x421 (safe mode) |
| DDR3-1066 CL8 Total 512 MB One 16-bit part            | 0x423             |
| DDR3-1066 CL8 Total 512 MB two 8-bit parts            | 0x403             |
| DDR3-1600 CL11 Total 512 MB one 16-bit part           | 0x427             |
| DDR3-1600 CL11 Total 512 MB two 8-bit parts           | 0x407             |
| DDR3-1600 CL11 Total 512 MB one 16-bit part 0.5% SSC  | 0x2427            |
| DDR3-1600 CL11 Total 512 MB two 8-bit parts 0.5% SSC  | 0x2407            |
| DDR3-1600 CL11 Total 512 MB one 16-bit part HT SRT    | 0x10427           |
| DDR3-1600 CL11 Total 512 MB one 16-bit part HT ASR    | 0x20427           |
| DDR3-1066 CL8 Total 1024 MB two 8-bit parts           | 0x503             |
| DDR3-1600 CL11 Total 1024 MB two 8-bit parts          | 0x507             |
| DDR3-1600 CL11 Total 1024 MB two 8-bit parts 0.5% SSC | 0x2507            |

### 2.2 BCM62118 DDR Configurations

Table 2: BCM62118 DDR Configurations Supported

| Configuration                                               | Value             |
|-------------------------------------------------------------|-------------------|
| DDR3-1066 CL8 Total 256MB One 16-bits part %1 SSC           | 0x1323            |
| DDR3-1066 CL8 Total 256MB Two 16-bits parts %1 SSC          | 0x41323           |
| DDR3-1600 CL8 Total 256MB One 16-bits part %1 SSC           | 0x1327            |
| DDR3-1600 CL8 Total 256MB Two 16-bits parts %1 SSC          | 0x41327           |
| DDR3-1066 CL8 Total 512 MB one 16-bit part 1% SSC           | 0x1423            |
| DDR3-1066 CL8 Total 512 MB Two 16-bit parts 1% SSC          | 0x41423           |
| DDR3-1600 CL11 Total 512 MB one 16-bit part 1% SSC          | 0x1427            |
| DDR3-1600 CL11 Total 512 MB Two 16-bit parts 1% SSC         | 0x41427           |
| DDR3-1066 CL8 Total 1024 MB one 16-bit part                 | 0x523 (safe mode) |
| DDR3-1066 CL8 Total 1024 MB one 16-bit part 1% SSC          | 0x1523            |
| DDR3-1066 CL8 Total 1024 MB two 16-bit parts 1% SSC         | 0x41523           |
| DDR3-1600 CL11 Total 1024 MB one 16-bit part 1% SSC         | 0x1527            |
| DDR3-1600 CL11 Total 1024 MB two 16-bit parts 1% SSC        | 0x41527           |
| DDR3-1600 CL11 Total 1024 MB two 16-bit parts 1% SSC HT SRT | 0x51527           |
| DDR3-1600 CL11 Total 1024 MB two 16-bit parts 1% SSC HT ASR | 0x61527           |
| DDR3-1066 CL8 Total 2048 MB two 16-bit parts 1% SSC         | 0x41623           |
| DDR3-1600 CL11 Total 2048 MB two 16-bit parts 1% SSC        | 0x41627           |

### 2.3 BCM6858X DDR Configurations

The DDR configurations shown in Table 3 are also valid for the following devices:

- BCM68580X/XV
- BCM55040
- BCM55045
- BCM49508
- BCM62119

Table 3: BCM6858 DDR Configurations Supported

| Configuration                                        | Value              |
|------------------------------------------------------|--------------------|
| DDR3-1600 CL11 Total 1024 MB one 16-bit part 1% SSC  | 0x1527 (safe mode) |
| DDR3-2133 CL14 Total 256 MB one 16-bit part 1% SSC   | 0x132B             |
| DDR3-2133 CL14 Total 512 MB one 16-bit part 1% SSC   | 0x142B             |
| DDR3-2133 CL14 Total 1024 MB one 16-bit part 1% SSC  | 0x152B             |
| DDR3-2133 CL14 Total 512 MB two 16-bit parts 1% SSC  | 0x4142B            |
| DDR3-2133 CL14 Total 1024 MB two 16-bit parts 1% SSC | 0x4152B            |
| DDR3-2133 CL14 Total 2048 MB two 16-bit parts 1% SSC | 0x4162B            |

**NOTE:** There are many available options for BCM6858X. Due to image size restriction, only part of them are enabled. All available configurations can be seen in *bcm63xx\_impl2\_ddr\_mcb.c*.

In order to enable a configuration bcm63xx\_impl2\_ddr\_mcb.c should be modified:

- 1. The appropriate .h file should be uncommented.
- 2. An appropriate entry should be added to the MCB[] array.

### 2.4 BCM68460 DDR Configurations

Table 4: BCM6846 DDR Configurations Supported

| Configuration                                       | Value              |
|-----------------------------------------------------|--------------------|
| DDR3-1600 CL11 Total 1024 MB one 16-bit part 1% SSC | 0x1527 (safe mode) |
| DDR3-1600 CL11 Total 512 MB one 16-bit part 1% SSC  | 0x1427             |
| DDR3-1600 CL11 Total 256 MB one 16-bit part 1% SSC  | 0x1327             |
| DDR3-2133 CL14 Total 1024 MB one 16-bit part 1% SSC | 0x1527             |

### 2.5 BCM68360 DDR Configurations

Table 5: BCM68360 B0 DDR Configurations Supported

| Configuration                                       | Value              |
|-----------------------------------------------------|--------------------|
| DDR3-1600 CL11 Total 1024 MB one 16-bit part 1% SSC | 0x1527 (safe mode) |
| DDR3-1600 CL11 Total 512 MB one 16-bit part 1% SSC  | 0x1427             |
| DDR3-1600 CL11 Total 256 MB one 16-bit part 1% SSC  | 0x1327             |
| DDR3-2133 CL14 Total 1024 MB one 16-bit part 1% SSC | 0x152B             |
| DDR3-2133 CL14 Total 512 MB one 16-bit part 1% SSC  | 0x142B             |
| DDR3-2133 CL14 Total 256 MB one 16-bit part 1% SSC  | 0x152B             |

# 2.6 BCM68560 DDR Configurations

Table 6: BCM68560 DDR Configurations Supported

| Configuration                                        | Value              |
|------------------------------------------------------|--------------------|
| DDR3-1600 CL11 Total 1024 MB one 16-bit part 1% SSC  | 0x1527 (safe mode) |
| DDR3-1600 CL11 Total 512 MB one 16-bit part 1% SSC   | 0x1427             |
| DDR3-1600 CL11 Total 256 MB one 16-bit part 1% SSC   | 0x1327             |
| DDR3-2133 CL14 Total 1024 MB one 16-bit part 1% SSC  | 0x152B             |
| DDR3-2133 CL14 Total 512 MB one 16-bit part 1% SSC   | 0x142B             |
| DDR3-2133 CL14 Total 256 MB one 16-bit part 1% SSC   | 0x152B             |
| DDR3-1600 CL11 Total 512 MB two 16-bit parts 1% SSC  | 0x41427            |
| DDR3-1600 CL11 Total 1024 MB two 16-bit parts 1% SSC | 0x41427            |
| DDR3-2133 CL14 Total 512 MB two 16-bit parts 1% SSC  | 0x4142B            |
| DDR3-2133 CL14 Total 1024 MB two 16-bit parts 1% SSC | 0x4152B            |

## 2.7 BCM63158 DDR Configurations

Table 7: BCM63158 DDR Configurations Supported

| Configuration                                               | Value             |
|-------------------------------------------------------------|-------------------|
| DDR3-1066 CL8 Total 1024 MB one 16-bit part                 | 0x523 (safe mode) |
| DDR3-1600 CL11 Total 512 MB one 16-bit part 1% SSC          | 0x1427            |
| DDR3-1600 CL11 Total 1024 MB one 16-bit part 1% SSC         | 0x1527            |
| DDR3-1600 CL11 Total 512 MB two 16-bit parts 1% SSC         | 0x41427           |
| DDR3-1600 CL11 Total 2048 MB four 8-bit parts 1% SSC        | 0x41607           |
| DDR3-1600 CL11 Total 1024 MB two 16-bit parts 1% SSC        | 0x41527           |
| DDR3-1600 CL11 Total 4096 MB four 8-bit parts 1% SSC        | 0x41707           |
| DDR3-1600 CL11 Total 2048 MB two 16-bit parts 1% SSC        | 0x41627           |
| DDR3-1866 CL13 Total 512 MB one 16-bit part 1% SSC          | 0x142F            |
| DDR3-1866 CL13 Total 1024 MB one 16-bit part 1% SSC         | 0x152F            |
| DDR3-1866 CL13 Total 512 MB two 16-bit parts 1% SSC         | 0x4142F           |
| DDR3-1866 CL13 Total 2048 MB four 8-bit parts 1% SSC        | 0x4160F           |
| DDR3-1866 CL13 Total 1024 MB two 16-bit parts 1% SSC        | 0x4152F           |
| DDR3-1866 CL13 Total 4096 MB four 8-bit parts 1% SSC        | 0x4170F           |
| DDR3-1866 CL13 Total 2048 MB two 16-bit parts 1% SSC        | 0x4162F           |
| DDR3-2133 CL14 Total 512 MB one 16-bit part 1% SSC          | 0x142B            |
| DDR3-2133 CL14 Total 1024 MB one 16-bit part 1% SSC         | 0x152B            |
| DDR3-2133 CL14 Total 512 MB two 16-bit parts 1% SSC         | 0x4142B           |
| DDR3-2133 CL14 Total 2048 MB four 8-bit parts 1% SSC        | 0x4160B           |
| DDR3-2133 CL14 Total 1024 MB two 16-bit parts 1% SSC        | 0x4152B           |
| DDR3-2133 CL14 Total 4096 MB four 8-bit parts 1% SSC        | 0x4170B           |
| DDR3-2133 CL14 Total 2048 MB two 16-bit parts 1% SSC        | 0x4162B           |
| DDR3-2133 CL14 Total 1024 MB two 16-bit parts 1% SSC HT SRT | 0x5152B           |
| DDR3-2133 CL14 Total 1024 MB two 16-bit parts 1% SSC HT ASR | 0x6152B           |

### **Revision History**

CPE-AN3100; November 14, 2017

Initial draft.

BRONDCOM

BROADCOM

