

### Application Note

AN2550

Rev. 0, 07/2003

MC68SZ328 Detailed Errata and Workaround Description of SDRAMC Self-Refresh Entry

### By Walter Law

## CONTENTS

| 1 Introduction 1          |
|---------------------------|
| 2 Problem Description 1   |
| 3 Occurrence of the       |
| Problem1                  |
| 4 Effect 1                |
| 5 Problem Investigation   |
| and Result 2              |
| 6 Software Workaround and |
| Comment 3                 |
| 7 Conclusion              |

#### 1 Introduction

This document describes in detail the SDRAM self-refresh entry failure issue of DragonBall SZ processor. It summarizes the test bench analysis and suggests a software workaround to completely solve the problem.

#### **Problem Description** 2

## SDRAMC failing to issue the self-refresh command

**Freescale Semiconductor, Inc.** 

In normal operation, the SDRAMC can issue a self-refresh command to the SDRAM by setting the Self Refresh Mode bit (RM bit), followed by a fixed period of time without SDRAM access. Receiving the self-refresh command, the SDRAM is able to retain data without the SDRAM clock signal input. It was found that the SDRAMC may not be able to issue the self-refresh mode command to the SDRAM (by setting the RM bit of DRAM controller Secondary Control Register).

This situation occurs when there is a refresh clock source (32.768kHz) rising edge, before the SDRAMC issues a self-refresh command. An Auto Refresh command is issued instead of self-refresh command, as indicated by the observation that the output of SDRAM clock enable pin (CLKE) is high and the SDRAM clock is not gated off.

#### 3 Occurrence of the Problem

The problem only occurs when there is a refresh clock source (32.768kHz) rising edge before the SDRAMC issues a self-refresh command. The probability of occurrence is less than 1%.

#### Effect 4

The SDRAMC may not be able to issue a self-refresh command after the RM bit is set and SDRAM is idle for fixed period of time. Data in the SDRAM cannot be retained in CPU sleep mode when the SDRAMC fails to issue a self-refresh entry command.

© Freescale Semiconductor, Inc., 2004. All rights reserved.



For More Information On This Go to: www.freescale



In practical applications, it is essential to retain the data inside the SDRAM when the CPU remains in sleep mode, during which time the SDRAM clock output from CPU is disabled. The SDRAM is set into self-refresh mode before the MC68SZ328 processor enters sleep mode. Failure to issue the self-refresh command will lead to corruption of the data in the SDRAM when the CPU goes to sleep mode.

# 5 Problem Investigation and Result

## 5.1 Problem Investigation

- 1. In Figure 1, the SDRAMC issues a self-refresh command and the SDRAM is put into self-refresh mode. The SDRAM clock enable is low, and the SDRAM clock is gated off.
- 2. In Figure 2, the SDRAMC issues an auto-refresh command rather than the self-refresh command, and therefore goes to the wrong state. The SDRAM cannot be put into self-refresh mode. The SDRAM clock enable is high, and the SDRAM clock is not gated off.

| 100/584<br>#ccum<br>0ff<br>18c/01<br>290 h | E C<br>Hes<br>Hes<br>1920 V | ): -:<br>): -:<br>): (: | ern 1<br>831D<br>831D<br>Ierkern<br>Time | <br>ta D<br>0 s | (mce)<br>(Trig to X<br>1 - 6 | Conter<br>Screen |
|--------------------------------------------|-----------------------------|-------------------------|------------------------------------------|-----------------|------------------------------|------------------|
| SDCEN<br>SDCE1                             |                             |                         |                                          |                 |                              |                  |
| SDCLK                                      |                             |                         |                                          | າແຫກ່           |                              |                  |
| SDCSH0<br>SDCSH0                           | 7                           | Л                       | l                                        | П               |                              |                  |
| SDRMS                                      |                             |                         |                                          | П               |                              |                  |
| SDCNS<br>ONEB                              |                             |                         | 1                                        |                 |                              |                  |

Figure 1. Proper Access Cycle



Figure 2. Error Access Cycle



## 5.2 Occurrence of the Problem

Figure 3, illustrates that when the RM bit is set between 6 to 14 clock after the 32.768KHz rising edge, the wrong access cycle will assert.



Figure 3. RM Bit Set Between 6 to 14 Clock after the 32.768KHz Rising Edge

# 6 Software Workaround and Comment

1. Check the rising edge of the clock sources by General-Purpose Timer.

Select the same clock source of the General-Purpose Timer and the refresh clock source in SDRAMC. For the MC68SZ328, the clock source is 32.768kHz. The presence of the refresh clock's rising edge can be checked by the General-Purpose Timer before the SDRAMC issues a self-refresh command. This procedure is recommended to avoid a possible timing conflict between the refresh rising edge during the issue of the self-refresh command.

Code Example 1 on page 4 provides an example of the workaround software code. The General-Purpose Timer2 was selected for this demonstration.



Code Example 1. Example Code for Workaround

```
//Initialization of timer 2
TCTL2 = 0X0029;
TPRER2=0x0001;
TCMP2 = 0X0001;
//poll the counter to 0
While((TCN2==0x0001)) {
             }
//poll the counter to 1
while((TCN2==0X0000)){
             }
//disable timer 2
TCTL2 = 0x0000;
//enter self-refresh
SECTL H = 0 \times 80;
//stop PLL
PLLCR H = 0x1c;
//stop core
```

 $asm{ stop #0x2000}$ 





Figure 4. Software Polling

Using software polling will avoid the issue of a timing conflict between the 32KHz rising edge and the self-refresh command.



# Freescale Semiconductor, Inc.

# 7 Conclusion

- 1. The SDRAM self-refresh entry failure issue is a logical design bug in the SDRAM module.
- 2. Timing of the failure is related to the refresh clock sources.
- 3. This application note provides a software workaround to avoid the bug in practical applications.



### How to Reach Us:

Home Page: www.freescale.com

E-mail: support@freescale.com

### USA/Europe or Locations Not Listed:

Freescale Semiconductor Technical Information Center, CH370 1300 N. Alma School Road Chandler, Arizona 85224 +1-800-521-6274 or +1-480-768-2130 support@freescale.com

### Europe, Middle East, and Africa:

Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) support@freescale.com

### Japan:

Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com

### Asia/Pacific:

Freescale Semiconductor Hong Kong Ltd. Technical Information Center 2 Dai King Street Tai Po Industrial Estate Tai Po, N.T., Hong Kong +800 2666 8080 support.asia@freescale.com

### For Literature Requests Only:

Freescale Semiconductor Literature Distribution Center P.O. Box 5405 Denver, Colorado 80217 1-800-441-2447 or 303-675-2140 Fax: 303-675-2150 LDCForFreescaleSemiconductor@hibbertgroup.com

Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters which may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part.



AN2550

For More Information On This Product, Go to: www.freescale.com