

# Tips to Solve NOR FLASH Programming Problems

MANUAL

# Tips to Solve NOR FLASH Programming Problems

---

[TRACE32 Online Help](#)

[TRACE32 Directory](#)

[TRACE32 Index](#)

[TRACE32 Documents](#) .....



[FLASH Programming](#) .....



[Application Notes for FLASH](#) .....



[Tips to Solve NOR FLASH Programming Problems](#) .....

1

[Introduction](#) .....

4

[General Recommendation](#) .....

6

[TRACE32 Error Messages](#) .....

7

[TRACE32 Tool-based Programming](#) .....

8

[Sources of Errors](#)

9

[General Course of Action in the Case of Problems \(Tool-based\)](#)

10

1. Check Read Access to FLASH

11

2. Check Write Access to FLASH

18

3. Check the FLASH Protection

23

4. Check the Programming of a Single Data Value

26

5. Erase the FLASH

30

6. Check the Programming of a Complete File

33

[Target-controlled Programming](#) .....

34

[Sources of Errors](#)

35

[General Course of Action in the Case of Problems \(Target-controlled\)](#)

36

1. Check Read Access to RAM

37

2. Check Write Access to RAM

39

3. Check if Code can be Executed in RAM

40

4. Check if a Software Breakpoint can be Set

42

5. Check the FLASH Programming of a Complete File

43

[Errors Caused by Wrong Usage of the TRACE32 Commands](#) .....

47

[Unintentional Erasing of the Complete FLASH Device](#)

47

[Multiple FLASH Devices on one Target](#)

48

[FAQ](#) .....

48

[Appendix A](#) .....

49

[Conversion of the Tool-based to Target-controlled FLASH Programming](#)

49

[Checking the Bus Configuration](#)

50

[Main Difference between Intel and AMD/Spansion FLASH Devices](#)

51

|                                       |           |
|---------------------------------------|-----------|
| Intel FLASH Devices                   | 52        |
| Switch to ID-Mode (Intel)             | 52        |
| Status Analysis (Intel)               | 54        |
| AMD/Spansion FLASH Devices            | 56        |
| Switch to ID-Mode (AMD/Spansion)      | 56        |
| Switch to CFI Mode (AMD/Spansion)     | 58        |
| The SYStem.LOG.List Command           | 60        |
| Interpretation of the SYStem.LOG.List | 62        |
| Error Scenarios                       | 67        |
| <b>Appendix B .....</b>               | <b>68</b> |
| FLASH Width BYTE                      | 68        |
| FLASH Width WORD                      | 69        |
| FLASH Width LONG                      | 70        |
| FLASH Width QUAD                      | 72        |

## Introduction

---

The goal of this manual is to provide tips to solve problems that might arise while programming off-chip NOR FLASHes by TRACE32.

An introduction to the FLASH programming can be found in the [“Onchip/NOR FLASH Programming User’s Guide”](#) (norflash.pdf).

For a complete list of all FLASH programming commands refer to the [FLASH](#) command group.

Nearly all off-chip NOR FLASHes can be programmed via:

- TRACE32 tool-based FLASH programming
- target-controlled FLASH programming

Just a few FLASH devices work only via target-controlled FLASH programming. This affects the following FLASH devices:

- FLASHs that are connected to a PowerPC CPU in true little endian mode.
- FLASHs for which the CODE column in <https://www.lauterbach.com/ylist.html> shows “TARGET”.
- FLASHs for which the COMMENT column in <https://www.lauterbach.com/ylist.html> shows “not on all systems supported” may not be programmed via TRACE32 tool-based FLASH programming for all processor architectures.



| Atmel      |         |          |                              |
|------------|---------|----------|------------------------------|
| TYPE       | COMPANY | CODE     | COMMENT                      |
| AT29BV010  | ATMEL   | AT29C512 | not on all systems supported |
| AT29BV020  | ATMEL   | AT29C020 | not on all systems supported |
| AT29BV040  | ATMEL   | AT29C020 | not on all systems supported |
| AT29C010   | ATMEL   | AT29C512 | not on all systems supported |
| AT29C020   | ATMEL   | AT29C020 | not on all systems supported |
| AT29C040   | ATMEL   | AT29C020 | not on all systems supported |
| AT29C1024  | ATMEL   | TARGET   | at29c1024.bin                |
| AT29C256   | ATMEL   | AT29C256 | not on all systems supported |
| AT29C257   | ATMEL   | AT29C256 | not on all systems supported |
| AT29C512   | ATMEL   | AT29C512 | not on all systems supported |
| AT29LV010  | ATMEL   | AT29C512 | not on all systems supported |
| AT29LV020  | ATMEL   | AT29C020 | not on all systems supported |
| AT29LV040  | ATMEL   | AT29C020 | not on all systems supported |
| AT29LV1024 | ATMEL   | TARGET   | at29c1024.bin                |
| AT29LV256  | ATMEL   | AT29C256 | not on all systems supported |
| AT29LV512  | ATMEL   | AT29C512 | not on all systems supported |

For detailed information about both FLASH programming methods please refer to the [“Onchip/NOR FLASH Programming User’s Guide”](#) (norflash.pdf)

# General Recommendation

---

If you start with a new FLASH device, it is recommended to set up a script that uses TRACE32 tool-based FLASH programming first. Errors are less likely with this method because less target resources are required.

If the script that uses TRACE32 tool-based FLASH programming runs faultless, you can almost be sure that:

- The FLASH declaration is correct.
- The bus configuration registers for the FLASH devices are set up correctly.
- The interface between the CPU and the FLASH devices on your target hardware works faultless.
- TRACE32 can erase and program the FLASH devices correctly.

After TRACE32 tool-based FLASH programming works correctly, you can convert this script to a target-controlled FLASH programming script. This is advisable because target-controlled FLASH programming is much faster. Refer to **“Conversion of the Tool-based to Target-controlled FLASH Programming”** in *Tips to Solve NOR FLASH Programming Problems*, page 49 (flash\_diagnosis.pdf) for details.

# TRACE32 Error Messages

One of the following error messages is displayed, when a FLASH erasing/programming error occurs:

| TRACE32 Error Messages      |                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>programming error</b>    | Error in programming the FLASH. Proceed as described in “ <a href="#">General Course of Action in the Case of Problems (Tool-based)</a> ” in Tips to Solve NOR FLASH Programming Problems, page 10 (flash_diagnosis.pdf).                                                                                                                                                      |
| <b>erase error</b>          | Error in erasing the FLASH. Proceed as described in “ <a href="#">General Course of Action in the Case of Problems (Tool-based)</a> ” in Tips to Solve NOR FLASH Programming Problems, page 10 (flash_diagnosis.pdf).                                                                                                                                                          |
| <b>bus error</b>            | There is no memory at the address range declared for the FLASH. Please check the bus configuration for the FLASH device. Refer to “ <a href="#">Checking the Bus Configuration</a> ” in Tips to Solve NOR FLASH Programming Problems, page 50 (flash_diagnosis.pdf) for details.                                                                                               |
| <b>data alignment error</b> | Wrong or incorrect alignment used while writing the FLASH data. It is strongly recommended to use a format option equivalent to the <code>&lt;bus_width&gt;</code> in the FLASH declaration for all write accesses.<br><br><code>FLASH.Create ... Long</code><br><code>FLASH.Program ALL</code><br><code>Data.LOAD.Elf demo.elf /Long</code><br><code>FLASH.Program OFF</code> |

For target-controlled FLASH programming the following error message may be displayed:

| TRACE32 Error Messages                            |                                                                                                                                                                                                                                                                                                                          |
|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>FLASH algorithm did not execute completely</b> | Proceed as described in “ <a href="#">General Course of Action in the Case of Problems (Target-controlled)</a> ” in Tips to Solve NOR FLASH Programming Problems, page 36 (flash_diagnosis.pdf).<br><br>Make sure that the data cache is switched off, otherwise TRACE32 can not read/update the FLASH status registers. |

# TRACE32 Tool-based Programming

If TRACE32 tool-based FLASH programming is used, the FLASH algorithm is part of the TRACE32 software and runs on the host.



EBU=External Bus Unit

# Sources of Errors

---

## CPU Related Errors

---

- Wrong or incomplete configuration of the bus configuration registers for the FLASH devices
- FLASH area is indicated as cacheable and the data cache is on (TRACE32 can not read/update the FLASH status registers)

## Errors Related to Address/Data Bus or the Control Lines

---

- Defect on the data bus (short circuit, broken line, soldering problem ...)
- Defect on the address bus (short circuit, broken line, soldering problem ...)
- Swapped address or data lines
- Defect on a control line (Chip Select, Output Enable, Write Enable)

## Errors Related to the FLASH

---

- FLASH (sector) is locked

## Errors Related to the TRACE32 FLASH Declaration

---

- Wrong FLASH family code
- Wrong bus width definition

## Errors Related to the File that is Programmed

---

- The file that is programmed unintentionally overwrites peripheral configuration registers

## Alignment Error

---

- Wrong or incorrect alignment used while writing the FLASH data. It is strongly recommended to use a format option for all write accesses that is equivalent to the `<bus_width>` in the FLASH declaration.

```
FLASH.Create ... Long  
FLASH.Program ALL  
Data.LOAD.Elf demo.elf /Long  
FLASH.Program OFF
```

# General Course of Action in the Case of Problems (Tool-based)

---

In case of FLASH programming problems the following course of actions is recommended:



## 1. Check Read Access to FLASH

In case of FLASH programming problems it is recommended to test, if TRACE32 can read the FLASH contents. This can be checked by using the **Data.dump** command.

|                                                         |                                                                                              |
|---------------------------------------------------------|----------------------------------------------------------------------------------------------|
| <b>Data.dump</b> <start_address> <bus_width> /SpotLight | Display the contents of the FLASH in a Data.dump window.                                     |
|                                                         | Use the start address of the FLASH devices as <start_address>.                               |
|                                                         | <bus_width> defines the data bus width that is used to connect the FLASH devices to the CPU. |
|                                                         | If the option /Spotlight is used, changed FLASH contents is highlighted.                     |

```
FLASH.Program OFF ; Disable FLASH programming
Data.dump 0xA0000000 /Word /SpotLight ; Example 1
Data.dump 0x40000000 /Long /SpotLight ; Example 2
```





## 1. Verify that the specified address range is FLASH

Here an example of how to verify if there is FLASH at the specified address range:

```
FLASH.Program OFF ; Disable FLASH programming  
Data.TestList 0xa1000000++3fffff ; Check memory type located at  
; the specified address range.  
; It is recommended to specify  
; the complete FLASH address  
; space.
```



This test can have the following results:

|                         |             |
|-------------------------|-------------|
| ok                      | RAM         |
| read only               | FLASH / ROM |
| read fail<br>write fail | No memory   |

If the result is **No memory**:

- Please check the bus configuration registers. For details refer to "[Checking the Bus Configuration](#)" in Tips to Solve NOR FLASH Programming Problems, page 50 (flash\_diagnosis.pdf).
- Please check your target for hardware problems accessing the off-chip FLASH.

If the result is **RAM**:

- Please check the bus configuration registers. For details refer to "[Checking the Bus Configuration](#)" in Tips to Solve NOR FLASH Programming Problems, page 50 (flash\_diagnosis.pdf).
- Please check your target design for the correct FLASH address range.

Short description and link to newly introduced command:

**Data.TestList <address\_range>** Test memory type for specified address range

The memory test stays active as long as the **Data.TestList** window is displayed.

## 2. Is there a defect on a single data line?

If there is a defect on a single data line, a single bit is either permanently 0 or permanently 1.

Use the **Data.dump** command to display the FLASH contents.

If the FLASH is empty (0xff) it is easy to check, if a single data line is permanently 0. This behavior points to a short-circuit, a broken data line or soldering problems on your target.

If the FLASH isn't empty, a defective data line might be visible if you look carefully to the contents of the **Data.dump** window.

If a RAM is connected to the same data bus, it is possible to perform the following test for a short-circuit on a data line by using the RAM:

```
; Display the memory contents of the RAM
Data.dump 0x0++0x1fff /Long /SpotLight

; Write a bit shifting pattern to the RAM
Data.Pattern 0x0++0x1fff /LongShift

; Test if the bit shifting pattern is written correctly to RAM
Data.Pattern 0x0++0x1fff /LongShift /Compare
```



Short description and link to newly introduced command:

**Data.Pattern <range> [/<option>]** Fill memory with selected pattern

### 3. Is there a defect on a single address line?

A defective address line results in mirrored memory. This effect is only visible in the **Data.dump** window, if the FLASH is not empty.

| address     | 0        | 4        | 8        | C        |
|-------------|----------|----------|----------|----------|
| SD:A2000000 | 00098786 | 0040942D | 0AA8544E | 2D3873C4 |
| SD:A2000010 | 5D5692AC | 17617168 | 17A00192 | 7CBA449A |
| SD:A2000020 | 86D91B38 | 7455BFB5 | 3BB194F2 | D4CF89E2 |
| SD:A2000030 | CDD43216 | 985769BA | 78765BAB | 99888776 |
| SD:A2000040 | 00098786 | 0040942D | 0AA8544E | 2D3873C4 |
| SD:A2000050 | 5D5692AC | 17617168 | 17A00192 | 7CBA449A |
| SD:A2000060 | 86D91B38 | 7455BFB5 | 3BB194F2 | D4CF89E2 |
| SD:A2000070 | CDD43216 | 985769BA | 78765BAB | 99888776 |

Mirrored address range

Mirrored address ranges can be found by the following procedure:

```
&start_address=0x40000000

&flash_size=0x3fffff

; display a hex dump
Data.dump &start_address /Long

; store the contents of the first four 32-bit values into PRACTICE
; variables to build a test pattern
&v1=Data.Long(D:&start_address)

&v2=Data.Long(D:&start_address+0x4)

&v3=Data.Long(D:&start_address+0x8)

&v4=Data.Long(D:&start_address+0xc)

; search for the test pattern in the FLASH
Data.Find (&start_address+0x10)++&flash_size %Long &v1 &v2 &v3 &v4

IF FOUND()

; if the test pattern is found in the FLASH, lock carefully to
; the Data.dump window to check if this is a result of mirrored
; address ranges
Data.dump TRACK.ADDRESS() /Long

ENDIFO
```

Please be aware, that one reason for mirrored address ranges can also be a wrong bus configuration for the FLASH device.

Short description and link to newly introduced command:

**Data.Find** <range> %<format> <test\_pattern>

**FOUND()** returns true if the <test\_pattern> was found

**TRACK.ADDRESS()** returns the address at which the <test\_pattern> was found



### 1. Check the bus configuration registers

For details refer to “[Checking the Bus Configuration](#)” in Tips to Solve NOR FLASH Programming Problems, page 50 (flash\_diagnosis.pdf).

If only some bits are toggling, this leads to the assumption, that the timing for the FLASH is not set up correctly. In most cases it is sufficient to increase the number of waits states for the memory access by 1.

### 2. Check your target hardware

Keep the [Data.dump](#) window open. This way the FLASH memory contents is read 10 times/s. Please measure the following lines:

Measure if the Chip Select line becomes active, if the FLASH is accessed.

Measure if the Output Enable line becomes active, if the FLASH contents is read.

## 2. Check Write Access to FLASH

---

A simple way to check if TRACE32 has write access to the FLASH is to switch the FLASH into ID-mode (Autoselect Mode for AMD/Spansion devices, Read Identifier Mode for Intel devices).

In ID-mode the following information is provided:

- Manufacturer identification
- Device identification
- Sector protection information if available

### Intel FLASH Devices

---

The procedure to switch to ID-mode is described in “[Switch to ID-Mode \(Intel\)](#)” in Tips to Solve NOR FLASH Programming Problems, page 52 (flash\_diagnosis.pdf).

#### Alternative test procedures:

- Try to read the FLASH status and reset the status registers. For details refer to “[Status Analysis \(Intel\)](#)” in Tips to Solve NOR FLASH Programming Problems, page 54 (flash\_diagnosis.pdf). Reading the FLASH status requires less correctly operating address and data lines, but this check is sufficient to test the write access.

### AMD/Spansion FLASH Devices

---

The procedure to switch to ID-mode is described in “[Switch to ID-Mode \(AMD/Spansion\)](#)” in Tips to Solve NOR FLASH Programming Problems, page 56 (flash\_diagnosis.pdf).

#### Alternative test procedures:

- Try to switch to CFI mode for Intel/AMD FLASH devices, if CFI mode is supported by your FLASH device. For details refer to “[Switch to CFI Mode \(AMD/Spansion\)](#)” in Tips to Solve NOR FLASH Programming Problems, page 58 (flash\_diagnosis.pdf). Switching to CFI mode requires less correctly operating address and data lines, but this check is sufficient to test the write access.



If switching to ID mode is not possible, the write access to FLASH doesn't seem to work.

### 1. Check the bus configuration register

For details refer to "[“Checking the Bus Configuration”](#)" in Tips to Solve NOR FLASH Programming Problems, page 50 (flash\_diagnosis.pdf).

### 2. Check your target hardware

Please check the WE, OE and CS line on your target hardware.

Swapped or defect address/data lines can prohibit that the FLASH is switched to ID mode.



## 1. Is there a defect on an address line?

A defective address line results in mirrored memory. This effect is only visible in the **Data.dump** window, if the FLASH is not empty.



The screenshot shows a memory dump window with the title "[B::Data.dump 0xa2000000 /NoAscii]". The table has columns for address, 0, 4, 8, and C. The address column shows memory locations starting from SD:A2000000. The data columns show hex values. A red box highlights the address range from 0x00098786 to 0x00098787, which is repeated in the table, indicating a mirrored address range.

| address     | 0        | 4        | 8        | C        |
|-------------|----------|----------|----------|----------|
| SD:A2000000 | 00098786 | 0040942D | 0AA8544E | 2D3873C4 |
| SD:A2000010 | 5D5692AC | 17617168 | 17A00192 | 7CB8449A |
| SD:A2000020 | 86D91B38 | 7455BF85 | 3BB194F2 | D4CF89E2 |
| SD:A2000030 | CDD43216 | 985769BA | 78765BAB | 99888776 |
| SD:A2000040 | 00098786 | 0040942D | 0AA8544E | 2D3873C4 |
| SD:A2000050 | 5D5692AC | 17617168 | 17A00192 | 7CB8449A |
| SD:A2000060 | 86D91B38 | 7455BF85 | 3BB194F2 | D4CF89E2 |
| SD:A2000070 | CDD43216 | 985769BA | 78765BAB | 99888776 |

Mirrored address range

Mirrored address ranges can be found by the following procedure:

```
&start_address=0x40000000

&flash_size=0x3fffff

; display a hex dump
Data.dump &start_address /Long

; store the contents of the first four 32-bit values into PRACTICE
; variables to build a test pattern
&v1=Data.Long(D:&start_address)

&v2=Data.Long(D:&start_address+0x4)

&v3=Data.Long(D:&start_address+0x8)

&v4=Data.Long(D:&start_address+0xc)

; search for the test pattern in the FLASH
Data.Find (&start_address+0x10)++&flash_size %Long &v1 &v2 &v3 &v4

IF FOUND()

    ; if the test pattern is found in the FLASH, lock carefully to
    ; the Data.dump window to check if this is a result of mirrored
    ; address ranges
    Data.dump TRACK.ADDRESS() /Long

ENDIFD
```

Please be aware, that one reason for mirrored address ranges can also be a wrong bus configuration for the FLASH device.

For swapped address lines please check your schematics or measure each address line on your target.

Short description and link to newly introduced command:

**Data.Find** <range> %<format> <test\_pattern>

**FOUND()** returns true if the <test\_pattern> was found.

**TRACK.ADDRESS()** returns the address at which the <test\_pattern> was found.

## 2. Check the bus configuration registers

For details refer to “[Checking the Bus Configuration](#)” in Tips to Solve NOR FLASH Programming Problems, page 50 (flash\_diagnosis.pdf).

### 3. Check the FLASH Protection

The FLASH protection can be checked, if the FLASH is in ID-Mode. For a detailed description on how to switch the FLASH to ID-mode, refer to “[2. Check Write Access to FLASH](#)” in Tips to Solve NOR FLASH Programming Problems, page 18 (flash\_diagnosis.pdf).

E.g ID information for Intel 28F128W18T:

| address      | 0    | 2    | 4    | 6    | 8    | A    | C    | E    |
|--------------|------|------|------|------|------|------|------|------|
| SD:A00000000 | 0089 | 8866 | 0001 | 0001 | 0089 | BFCF | 0001 | 0001 |
| SD:A00000010 | 0089 | 8866 | 0001 | 0001 | 0089 | BFCF | 0001 | 0001 |
| SD:A00000020 | 0051 | 0052 | 0059 | 0003 | 0000 | 0039 | 0000 | 0000 |
| SD:A00000030 | 0000 | 0000 | 0000 | 0017 | 0019 | 0084 | 00C6 | 0004 |
| SD:A00000040 | 0000 | 0000 | 0000 | 0004 | 0000 | 0003 | 0000 | 0018 |
| SD:A00000050 | 0001 | 0000 | 0000 | 0000 | 0002 | 00FE | 0000 | 0000 |
| SD:A00000060 | 0001 | 0007 | 0000 | 0020 | 0000 | 0000 | 0000 | 0000 |

|                                |                                                 |
|--------------------------------|-------------------------------------------------|
| 1st word:<br>Manufacturer ID   | 0x89 (Intel)                                    |
| 2nd word:<br>Device ID         | 0x8866 (28F128W18T as bottom boot block device) |
| 3rd word:<br>Sector protection | 0x1 (sector locked)                             |

| Sector Protection Information |                                                      |
|-------------------------------|------------------------------------------------------|
| 0x0                           | Sector is not locked                                 |
| 0x1                           | Sector is locked                                     |
| any other value               | Please refer to the data sheet for your FLASH device |



**FLASH.UNLOCK <unit> | <range> | ALL**      Unlock FLASH

```
FLASH.UNLOCK ALL  
FLASH.UNLOCK 0xa0000000++0xffff
```

Some FLASH devices are locked after power-up. Refer to the data sheet for your FLASH device for details. If your FLASH device is locked after power-up, the following command sequence is recommended:

```
... ; Configure your CPU  
SYStem.Up ; Establish the communication  
           ; between TRACE32 and the CPU  
... ; Configure the bus configuration  
     ; registers  
FLASH.Create ... ; Declare your FLASH  
FLASH.UNLOCK ALL ; Remove the FLASH protection
```

FLASH devices behave differently when removing the protection.

- Each FLASH sector has to be unlocked separately. In this case the command **FLASH.UNLOCK ALL** is recommended if the complete FLASH device should be unprotected.

If the block address (BA) is required to unlock the FLASH, each sector has to be unlocked separately.

| Mode                        | Command         | Bus Cycles | First Bus Cycle |                   |                   | Second Bus Cycle |                   |                   |
|-----------------------------|-----------------|------------|-----------------|-------------------|-------------------|------------------|-------------------|-------------------|
|                             |                 |            | Oper            | Addr <sup>1</sup> | Data <sup>2</sup> | Oper             | Addr <sup>1</sup> | Data <sup>2</sup> |
| Block Locking/<br>Unlocking | Lock Block      | 2          | Write           | BA                | 0x60              | Write            | BA                | 0x01              |
|                             | Unlock Block    | 2          | Write           | BA                | 0x60              | Write            | BA                | 0xD0              |
|                             | Lock-down Block | 2          | Write           | BA                | 0x60              | Write            | BA                | 0x2F              |

- Each unlock takes effect on the complete FLASH device. In this case the command **FLASH.UNLOCK <range\_of\_first\_sector>** is more effective, since it performs much faster.

If the block address (BA) isn't required to unlock the FLASH, all sectors are unlocked in one step.

| Command               | Scaleable or Basic Command Set <sup>(14)</sup> | Bus Cycles Req'd | Notes | First Bus Cycle     |                     |                       | Second Bus Cycle    |                     |                       |
|-----------------------|------------------------------------------------|------------------|-------|---------------------|---------------------|-----------------------|---------------------|---------------------|-----------------------|
|                       |                                                |                  |       | Oper <sup>(1)</sup> | Addr <sup>(2)</sup> | Data <sup>(3,4)</sup> | Oper <sup>(1)</sup> | Addr <sup>(2)</sup> | Data <sup>(3,4)</sup> |
| Set Block Lock-Bit    | SCS                                            | 2                | 11    | Write               | X                   | 60H                   | Write               | BA                  | 01H                   |
| Clear Block Lock-Bits | SCS                                            | 2                | 12    | Write               | X                   | 60H                   | Write               | X                   | D0H                   |

For details refer to the data sheet of your FLASH device.

Please use the command **FLASH.LOCK** if you want to enable the sector protection after the FLASH is programmed.

**FLASH.LOCK <unit> | <range> | ALL**

Lock FLASH

Locking the FLASH is always performed sector-wise.

## 4. Check the Programming of a Single Data Value

---

Here a short example to program a single data value to FLASH.

```
; Search for empty FLASH cell
Data.Find 0x0++0xffff %Long 0xffffffff

; Display empty cell
Data.dump TRACK.ADDRESS() /SpotLight

; Enable FLASH programming
FLASH.Program ALL

; Write new data value to empty FLASH cell
Data.Set TRACK.ADDRESS() %Long 0x01234567

; Disable FLASH programming
FLASH.Program OFF
```

**Data.Find** <range> %<format> <test\_pattern>

**FOUND()** returns true if the <test\_pattern> was found.

**TRACK.ADDRESS()** returns the address at which the <test\_pattern> was found.



## 1. Log all read/write accesses that are performed by TRACE32 to write a single data value

If you succeeded to switch the FLASH to ID mode by using the **Data.Set** commands described in “[Switch to ID-Mode \(AMD/Spansion\)](#)” in [Tips to Solve NOR FLASH Programming Problems](#), page 56 (flash\_diagnosis.pdf), perform the following test sequence:

```
WinClear

SYStem.LOG.List

FLASH.Program ALL

; Search for empty FLASH cell
Data.Find 0x++0xffffffff %Long 0xffffffff

; Write single data value for empty FLASH cell
Data.Set TRACK.ADDRESS() %Long 0x01234567

FLASH.Program OFF
```

**Data.Find** <range> %<format> <test\_pattern>

**FOUND()** returns true if the <test\_pattern> was found.

**TRACK.ADDRESS()** returns the address at which the <test\_pattern> was found.

An introduction on how to analyze the logging of the TRACE32 read/write accesses is given in “[Interpretation of the SYStem.LOG.List](#)” in [Tips to Solve NOR FLASH Programming Problems](#), page 62 (flash\_diagnosis.pdf).

Compare the command register addresses used by TRACE32 with the command register addresses you used to switch to ID-mode. Differences in the command register addresses lead to the assumption that a wrong <family\_code> or a wrong <bus\_width> is used in the TRACE32 FLASH declaration.

Differences in the endianness used for the data values lead to the assumption that the FLASH is connected to your PowerPC CPU in true little endian mode. In this case only target-controlled FLASH programming can be used.

## 2. Is there a defect on a single data line?

To test for a defective data line, write a test pattern to the FLASH.

```
WinClear

FLASH.Program ALL

; Search for an empty FLASH cell
Data.Find 0x++0xffffffff %Long 0xffffffff

; Write test pattern 1
Data.Set TRACK.ADDRESS() %Long 0x55555555

; Check the result
Data.Print TRACK.ADDRESS() %Long

; Search for the next empty FLASH cell
Data.Find

; Write test pattern 2
Data.Set TRACK.ADDRESS() %Long 0xaaaaaaaa

; Check the result
Data.Print TRACK.ADDRESS() %Long

FLASH.Program OFF
```

In case of an error, check your target hardware for a defective data line.

**Data.Find** <range> %<format> <test\_pattern>

Repeat search by using **Data.Find** without any parameters.

**FOUND()** returns true if the <test\_pattern> was found.

**TRACK.ADDRESS()** returns the address at which the <test\_pattern> was found.

## 5. Erase the FLASH

Before you try to erase the complete FLASH it is recommended to test if a single FLASH sector can be erased.

Check the protection for a selected FLASH sector as described in “[3. Check the FLASH Protection](#)” in [Tips to Solve NOR FLASH Programming Problems](#), page 23 (flash\_diagnosis.pdf). Use the following command to erase this single sector.

**FLASH.Erase <range>**

Erase the contents of the specified address range

```
FLASH.Erase 0x0--0xfffff
```



### 1. Read the Status Registers for Intel FLASH devices.

Refer to “[Status Analysis \(Intel\)](#)” in [Tips to Solve NOR FLASH Programming Problems](#), page 54 (flash\_diagnosis.pdf) for details.

2. Use the SYStem.LOG.List window to check the correct FLASH declaration.
3. Use the SYStem.LOG.List window to check if the data cache is on.

Both test are described in “[Interpretation of the SYStem.LOG.List](#)”, page 62.



Please be aware that TRACE32 doesn't detect any problem in erasing a FLASH sector, if the FLASH sector is already empty.

If TRACE32 is able to erase a single sector, you can be sure that TRACE32 can erase the complete FLASH.



Please be aware that a bulk erase/chip erase command is used to erase the FLASH device if

- bulk erase/chip erase is supported by the FLASH device
- and if one of the following commands is used to erase the FLASH

**FLASH.Erase ALL**  
**FLASH.Erase <unit\_number>**  
**FLASH.Erase <range>**, when the <range> covers the complete address range declared for a <unit\_number>

For details refer also to “[Unintentional Erasing of the Complete FLASH Device](#)” in Tips to Solve NOR FLASH Programming Problems, page 47 (flash\_diagnosis.pdf).



Refer to "["3. Check the FLASH Protection"](#)" in Tips to Solve NOR FLASH Programming Problems, page 23 (flash\_diagnosis.pdf) in both cases.

## 6. Check the Programming of a Complete File

---

### Unintended Overwrite of Peripheral Configuration Registers

---

At this point it makes only sense to check if the file you want to program into FLASH unintentionally overwrites peripheral configuration registers.

Here an example, that shows you how to check if your file unintentionally overwrites important configuration registers.

```
Data.LOAD.Elf demo.elf /VM ; Download the file to the virtual  
; memory  
sYmbol.List.Map ; Display the load order and the  
; address ranges to which the file  
; was downloaded
```

Please make sure, that the file is solely downloaded to the address ranges of the FLASH.

If your file overwrites peripheral configuration registers, please check your map file or continue as follows:

```
FLASH.Program ALL ; Enable FLASH programming  
Data.LOAD.Elf demo.elf 0xc00000++0x1ffff ; Load file to FLASH address  
; ranges  
FLASH.Program OFF ; Disable FLASH programming
```

Short description and link to newly introduced command:

**sYmbol.List.MAP** Display to which address ranges in the memory a file was downloaded.

# Target-controlled Programming

If target-controlled FLASH programming is used, the FLASH algorithm is downloaded to the target RAM and is executed there.



The fact that the FLASH algorithm is downloaded to the target RAM and is executed there adds new requirements:

1. Read and write access to the target RAM by TRACE32
2. Execution of the downloaded FLASH algorithm on the target RAM
3. Setting of software breakpoints to target RAM

# Sources of Errors

---

## CPU Related Errors

---

- Wrong or incomplete configuration of the bus configuration registers for the RAM

## Errors Related to the RAM

---

- Wrong or incomplete SDRAM initialization
- Missing ECC initialization for the RAM

## Watchdog Problems

---

- The FLASH programming algorithm doesn't serve any active watchdog. An active watchdog results in an abort of the FLASH programming algorithm.

## Errors Related to the File that is Programmed

---

- The file that is programmed unintentionally overwrites the FLASH algorithm

## Address Range for FLASH Algorithm is to Small

---

- The data of the FLASH algorithm unintentionally overwrite the FLASH algorithm

# General Course of Action in the Case of Problems (Target-controlled)

---

After you defined both, the code range for the FLASH algorithm and the data range for the FLASH algorithm, the following course of action is recommended:



## 1. Check Read Access to RAM

To check if TRACE32 can read the RAM use the **Data.dump** command. It is recommended to perform all test either on the program or on the data range defined for the FLASH algorithm.

**Data.dump <start\_address> <bus\_width> /SpotLight**

```
Data.dump 0x1000 /Long /SpotLight
```

### Clear and Stable Display



Verify that the address range required for the FLASH algorithm and its data is RAM

**Data.TestList <address\_range>**

Test memory type for specified address range

```
Data.TestList 0x1000++0x2fff
```



If the result is **read fail** or **write fail**, please check the bus configuration registers for the RAM and the RAM initialization.

Since TRACE32 tool-based FLASH programming runs faultless, you can almost be sure that the address bus, the data bus and the control lines are working correctly.



## 2. Check Write Access to RAM

To test the write access to RAM, use the following command:

**Data.Pattern <range> [/<option>]** Fill memory with selected pattern

Example:

```
; Display the memory contents of the RAM
Data.dump 0x1000 /Long /SpotLight

; Write a bit shifting pattern to the RAM
Data.Pattern 0x1000++0x2fff /LongShift

; Test if the bit shifting pattern is written correctly to RAM
Data.Pattern 0x1000++0x2fff /LongShift /Compare
```



If TRACE32 can not write to RAM, check the bus configuration registers.

### 3. Check if Code can be Executed in RAM

To check, if code can be executed use the following command to write a small test program into RAM.



Example:

```
Data.Assemble 0x1000 b 0x1000 ; b 0x1000 prevents that test
                                ; program is unintentionally
                                ; re-entered after a TRAP or
                                ; interrupt

Data.Assemble 0x1002 mov r0,#1 ; Start of test program

Data.Assemble 0x1004 mov r1,#2

Data.Assemble 0x1006 add r2,r1,r0

Data.Assemble 0x1008 b 0x1002
```

Set the Program Counter/Instruction Pointer to the start address of your test program and perform a few single steps.

```
Register.Set pc 0x1002  
Step  
Step
```

Set the Program Counter/Instruction Pointer to the start address of your test program. Start the program execution, let it run for a few seconds and stop it again. With this test you can check if an active watchdog will cause problems for the target-controlled FLASH algorithm.

```
Register.Set pc 0x1002  
Go  
; WAIT 10.s          can be used only in scripts  
Break
```

Please check carefully, if the program execution is stopped within your test program. If this is not case this leads to the assumption, that the watchdog on your target needs to be deactivated.

## 4. Check if a Software Breakpoint can be Set

Check if a software breakpoint can be set to your small test program.



Example:

```
Break.Set 0x1004 /Program /SOFT
```

```
Go
```

## 5. Check the FLASH Programming of a Complete File

---

```
FLASH.Create ... TARGET ... ; Declare your FLASH
FLASH.TARGET ...
FLASH.Erase ; Erase the FLASH contents
FLASH.Program ALL ; Enable FLASH programming
Data.LOAD.Elf demo.elf ; Load file to FLASH address ranges
FLASH.Program OFF ; Disable FLASH programming
Data.LOAD.Elf demo.elf /Compare
```

### Programming of File Failed

---



## 1. Does the file that is programmed to the FLASH unintentionally overwrite important configuration registers or parts of the FLASH programming algorithm?

Here an example, that shows you how to check if your file unintentionally overwrites important configuration registers or parts of the FLASH programming algorithm.

```
Data.LOAD.Elf demo.elf /VM ; Download the file to the virtual  
; memory  
  
sYmbol.List.Map ; Display the load order and the  
; address ranges to which the file  
; was downloaded
```

Please make sure, that the file is solely downloaded to the address ranges of the FLASH.

If you also want to download some program parts to RAM, please proceed as follows:

```
FLASH.Program ALL ; Enable FLASH  
; programming  
  
Data.LOAD.Elf demo.elf 0xc00000++0x1ffff ; Load file to FLASH  
; address ranges  
  
FLASH.Program OFF ; Disable FLASH  
; programming  
  
Data.LOAD.Elf demo.elf 0xe00000++0x7fff ; Load file to the RAM  
; address ranges
```

Short description and link to newly introduced command:

**sYmbol.List.MAP**      Display to which address ranges in memory a file was downloaded.

2. Do the data of the FLASH programming algorithm unintentionally overwrite the FLASH algorithm?



Please make sure, that you reserve enough target RAM for the FLASH programming algorithm. The required size for the FLASH algorithm is calculated as follows:



**Figure:** Memory mapping for the `<code_range>`

Required size for the code is `size_of(<flash_algorithm>)` + 32 byte

The required size for the data of the FLASH algorithm is calculated as follows:



**Figure:** Memory mapping for the `<data_range>`

```
<buffer_size> =  
size_of(<data_range>) - 32 byte argument buffer - 256 byte stack
```

`<buffer_size>` is the maximum number of bytes that are transferred from the TRACE32 software to the external FLASH programming algorithm in one step.

Details on the memory mapping for the FLASH algorithm can be found in the "["Onchip/NOR FLASH Programming User's Guide"](#)" (norflash.pdf).

### 3. Check if the Correct FLASH Algorithm is used.

To check if the correct FLASH algorithm is used, use the following commands:

```
FLASH.Create ... TARGET ... ; FLASH declaration  
FLASH.TARGET ...  
...  
FLASH.Program ALL  
Data.List
```

The command **FLASH.Program ALL** loads the FLASH algorithm to the target RAM and set the program counter/instruction pointer correctly. Please look carefully to the code displayed in the **Data.List** window. If the code displayed there doesn't seem to be the code at the beginning of a function, check if you use the FLASH algorithm from the correct directory.



Ready-to-run binary files for target-controlled FLASH programming are available for the most common architectures in the TRACE32 demo folder under:

`~/demo/<architecture>/flash`

The FLASH algorithms are organized by `<bus_width>` and by `<endianness>`.

`<bus_width>_be` stands for FLASH support for big endian mode.  
`<bus_width>_le` stands for FLASH support for little endian mode.

If your processor architecture has a preferred endianness, this `<endianness>` is left out and only the `<bus_width>` is listed.

**Example:** the preferred `<endianness>` for the ARM architecture is little endian mode.

```
~/demo/arm/flash/long  
; algorithms for little endian  
~/demo/arm/flash/long_be  
; algorithms for big endian
```

If your FLASH is connected in true little endian mode to your PowerPC CPU, please use the FLASH algorithm from the directory

`~/demo/powerpc/flash/<bus_width>_tle`

## Unintentional Erasing of the Complete FLASH Device



Please be aware that a bulk erase/chip erase command is used to erase the FLASH device if

- bulk erase/chip erase is supported by the FLASH device
- and if one of the following commands is used to erase the FLASH

**FLASH.Erase ALL**

**FLASH.Erase <unit\_number>**

**FLASH.Erase <range>**, when the <range> covers the complete address range declared for a <unit\_number>

Here an example:

|                            |                                                                                |
|----------------------------|--------------------------------------------------------------------------------|
| <b>FLASH typ</b>           | S29CD016, chip erase possible                                                  |
| <b>FLASH start address</b> | 0xa2000000                                                                     |
| <b>FLASH sectors</b>       | 8 x 8 KByte (0x2000)<br>30 (0x1E) x 64 KByte (0x10000)<br>8 x 8 KByte (0x2000) |

TRACE32 FLASH declaration:

```
; FLASH declarations for the top boot sectors only
FLASH.Create 1. 0xa2000000--0xa200ffff 0x2000 AM29BDD Long

; FLASH.Create 1. 0xa2010000--0xa21effff 0x10000 AM29BDD Long

; FLASH.Create 1. 0xa21f0000--0xa21fffff 0x2000 AM29BDD Long

FLASH.List
```

The following command will erase the complete FLASH (**0xa2000000--0xa21fffff**):

```
FLASH.Erase ALL

FLASH.Erase 1.

FLASH.Erase 0xa2000000--0xa200ffff
```

# Multiple FLASH Devices on one Target

---

TRACE32 can handle only a single FLASH algorithm for target-controlled FLASH programming. This applies for both on-chip FLASH and off-chip FLASH devices.

The FLASH algorithm defined with the last **FLASH.TARGET** command is always the valid one.

If you have multiple FLASH devices on your target they require different FLASH algorithms, proceed as follows:

```
FLASH.Create 1. ... TARGET ... ; Declaration for first FLASH device
...
FLASH.Create 2. ... TARGET ... ; Declaration for second FLASH device
...
FLASH.TARGET ... am29lv100.bin ; Declare target algorithm for FLASH
; device with <unit_number> 1.

FLASH.Erase 1.

FLASH.Program 1.

Data.Load <file1>

FLASH.Program OFF

FLASH.TARGET ... i28f200b.bin ; Declare target algorithm for FLASH
; device with <unit_number> 2.

FLASH.Erase 2.

FLASH.Program 2.

Data.Load <file2>

FLASH.Program OFF
```

## FAQ

---

Please refer to <https://support.lauterbach.com/kb>.

## Conversion of the Tool-based to Target-controlled FLASH Programming

---

```
&FLASH_PROGRAMMING_METHOD="TRACE32 tool-based"
; &FLASH_PROGRAMMING_METHOD="target-controlled"

FLASH.RESet
IF "&FLASH_PROGRAMMING_METHOD"=="TRACE32 tool-based"
(
; FLASH.Create <unit_number> <physical_range> <sector_size> <family_code> <bus_witdth>
FLASH.Create 1. 0x40000000++0xffffffff 0x20000 I28F200B Long
)
IF "&FLASH_PROGRAMMING_METHOD"=="target-controlled"
(
; FLASH.Create <unit_number> <physical_range> <sector_size> TARGET <bus_witdth>
FLASH.Create 1. 0x40000000++0xffffffff 0x20000 TARGET Long

; FLASH.Target <code_address> <data_address> <buffer_size> <flash_algorithm>
FLASH.TARGET 0x0 0x1000 0x1000 ~/demo/arm/flash/long_be/i28f200b.bin
)
```

Conversion from TRACE32 tool-based FLASH declaration to target-controlled FLASH declaration:

1. Replace the <family\_code> by the keyword **TARGET** when using the **FLASH.Create** command.
2. Use the **FLASH.TARGET** command to specify the <code\_address>, <data\_address>, <buffer\_size> and the <flash\_algorithm>. Please remember to use the FLASH algorithm from the directory with the adequate <bus\_width> and the correct <endianness>. The name of <flash\_algorithm> matches with the <family\_code>.

After the declarations for the FLASH devices are done, all other commands of the command group FLASH apply to both programming methods.

For details, refer to the [“Onchip/NOR FLASH Programming User’s Guide”](#) (norflash.pdf).

# Checking the Bus Configuration

---

Correct settings in the bus configuration registers are key for the FLASH programming. The following settings in the bus configuration are of importance:

- The base address for the FLASH devices
- The size of the FLASH devices
- The bus size that is used to access the FLASH devices

If several FLASH devices are used in parallel to realize the required *<bus\_width>* between the processor and the FLASH memory, make sure that the *<bus\_width>* is configured correctly

- The timing (number of wait states for the access to the FLASH devices)
- The write access has to be enabled for the FLASH devices

Use the **PER.view** command to check the settings in the bus configuration registers:



# Main Difference between Intel and AMD/Spansion FLASH Devices

## Intel FLASH Devices

Commands are executed on Intel FLASH devices by writing a specified data value to any FLASH address.

| Command               | Scaleable or Basic Command Set <sup>(14)</sup> | Bus Cycles Req'd | Notes | First Bus Cycle     |                     |                       | Second Bus Cycle    |                     |                       |
|-----------------------|------------------------------------------------|------------------|-------|---------------------|---------------------|-----------------------|---------------------|---------------------|-----------------------|
|                       |                                                |                  |       | Oper <sup>(1)</sup> | Addr <sup>(2)</sup> | Data <sup>(3,4)</sup> | Oper <sup>(1)</sup> | Addr <sup>(2)</sup> | Data <sup>(3,4)</sup> |
| Read Array            | SCS/BCS                                        | 1                |       | Write               | X                   | FFH                   |                     |                     |                       |
| Read Identifier Codes | SCS/BCS                                        | ≥2               | 5     | Write               | X                   | 90H                   | Read                | IA                  | ID                    |
| Read Query            | SCS                                            | ≥2               |       | Write               | X                   | 98H                   | Read                | QA                  | QD                    |
| Read Status Register  | SCS/BCS                                        | 2                |       | Write               | X                   | 70H                   | Read                | X                   | SRD                   |
| Clear Status Register | SCS/BCS                                        | 1                |       | Write               | X                   | 50H                   |                     |                     |                       |

```
Data.Set 0xa0000000 %Long 0x90909090 ; Switch the FLASH device to ID mode
Data.Set 0xa0000000 %Long 0x70707070 ; Read FLASH status registers
Data.Set 0xa0000000 %Long 0x50505050 ; Reset FLASH status register
```

## AMD/Spansion FLASH Devices

Commands are executed on AMD/Spansion FLASH devices by writing a command sequence to the command registers of the FLASH.

| Command Sequence Read/Reset            | Bus Write Cycles Req'd | First Bus Write Cycle |      | Second Bus Write Cycle |      | Third Bus Write Cycle |      | Fourth Bus Read/Write Cycle |      | Fifth Bus Write Cycle |      | Sixth Bus Write Cycle |      |
|----------------------------------------|------------------------|-----------------------|------|------------------------|------|-----------------------|------|-----------------------------|------|-----------------------|------|-----------------------|------|
|                                        |                        | Addr                  | Data | Addr                   | Data | Addr                  | Data | Addr                        | Data | Addr                  | Data | Addr                  | Data |
| Read/Reset                             | 1                      | XXXH                  | F0H  |                        |      |                       |      |                             |      |                       |      |                       |      |
| Read/Reset                             | 4                      | 555H                  | AAH  | AAAH                   | 55H  | 555H                  | F0H  | RA                          | RD   |                       |      |                       |      |
| Autoselect Manufacturer ID             | 4                      | 555H                  | AAH  | AAAH                   | 55H  | 555H                  | 90H  | 00H                         | 01H  |                       |      |                       |      |
| Autoselect Device ID (Top Boot Device) | 4                      | 555H                  | AAH  | AAAH                   | 55H  | 555H                  | 90H  | 01H                         | B0H  |                       |      |                       |      |

**Example:** Switch an AM29BDD with *<bus\_width>* long to ID mode.

```
Data.Set 0xa0001554 %Long 0xaa
Data.Set 0xa000aa8 %Long 0x55
Data.Set 0xa0001554 %Long 0x90
```

## Switch to ID-Mode (Intel)

INTEL FLASH devices are switched to ID mode by writing 0x90 to any address of the FLASH address range.

**Data.Set <start\_address\_of\_flash> <bus\_width> 0x90**

INTEL FLASH devices are switched back to Read Mode by writing 0xff to any address of the FLASH address range.

**Data.Set <start\_address\_of\_flash> <bus\_width> 0xff**

Example for FLASH device M58BW016BB from ST Microelectronics. The FLASH device is connected to the CPU via a 32 bit data bus.

```
Data.Dump 0xa0000000 /Long /NoAscii      ; Display the ID mode
; information

Data.Set 0xa0000000 %Long 0x90          ; Switch the FLASH device to ID
; mode
```



ID information:

|                 |                                                              |
|-----------------|--------------------------------------------------------------|
| Manufacturer ID | 0x20 (ST Microelectronics)                                   |
| Device ID       | 0x8835 (FLASH device M58BW016BB as bottom boot block device) |

The ID information is either displayed:

- always at the beginning of each FLASH sector
- repetitive in each FLASH sector (see example above), the repetition rate depends on the FLASH device

```
Data.Set 0xa0000000 %Long 0xff          ; Switch the FLASH back to Read
; Mode
```

Intel FLASH devices can be switched to **Read Status Register** mode by writing 0x70 to any address of the FLASH.

## Data.Set <start\_address\_of\_flash> <bus\_width> 0x70

```
Data.Set 0xa0000000 %Long 0x70
```

```
Data.dump 0xa0000000 /Long
```



Any other value then 0x80 indicates an error. For a description of the error codes refer to the data sheet of your FLASH device.

## Status Register Definitions

| WSMS                    | ESS                                                                                                                                       | ECLBS | PSLBS | VPENS | R    | DPS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R     |  |  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|--|--|
| bit 7                   | bit 6                                                                                                                                     | bit 5 | bit 4 | bit 3 | bit2 | bit 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | bit 0 |  |  |
| High Z<br>When<br>Busy? | Status Register Bits                                                                                                                      |       |       |       |      | Notes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |  |  |
| No                      | SR.7 = WRITE STATE MACHINE STATUS<br>1 = Ready<br>0 = Busy                                                                                |       |       |       |      | Check STS or SR.7 to determine block erase, program, or lock-bit configuration completion. SR.6-SR.0 are not driven while SR.7 = "0."<br>If both SR.5 and SR.4 are "1"s after a block erase or lock-bit configuration attempt, an improper command sequence was entered.<br>SR.3 does not provide a continuous programming voltage level indication. The WSM interrogates and indicates the programming voltage level only after Block Erase, Program, Set Block Lock-Bit, or Clear Block Lock-Bits command sequences.<br>SR.1 does not provide a continuous indication of block lock-bit values. The WSM interrogates the block lock-bits only after Block Erase, Program, or Lock-Bit configuration command sequences. It informs the system, depending on the attempted operation, if the block lock-bit is set. Read the block lock configuration codes using the Read Identifier Codes command to determine block lock-bit status.<br>SR.0 is reserved for future use and should be masked when polling the status register. |       |  |  |
| Yes                     | SR.6 = ERASE SUSPEND STATUS<br>1 = Block Erase Suspended<br>0 = Block Erase in Progress/Completed                                         |       |       |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |  |  |
| Yes                     | SR.5 = ERASE AND CLEAR LOCK-BITS STATUS<br>1 = Error in Block Erasure or Clear Lock-Bits<br>0 = Successful Block Erase or Clear Lock-Bits |       |       |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |  |  |
| Yes                     | SR.4 = PROGRAM AND SET LOCK-BIT STATUS<br>1 = Error in Setting Lock-Bit<br>0 = Successful Set Block Lock Bit                              |       |       |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |  |  |
| Yes                     | SR.3 = PROGRAMMING VOLTAGE STATUS<br>1 = Low Programming Voltage Detected, Operation Aborted<br>0 = Programming Voltage OK                |       |       |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |  |  |
| Yes                     | SR.2 = PROGRAM SUSPEND STATUS<br>1 = Program suspended<br>0 = Program in progress/completed                                               |       |       |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |  |  |
| Yes                     | SR.1 = DEVICE PROTECT STATUS<br>1 = Block Lock-Bit Detected, Operation Abort<br>0 = Unlock                                                |       |       |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |  |  |
| Yes                     | SR.0 = RESERVED FOR FUTURE ENHANCEMENTS                                                                                                   |       |       |       |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |  |  |

Writing 0x50 to any address clears the status registers.

Writing 0xff to any address switches the FLASH device back to Read Mode.

```
Data.dump 0xa0000000 /Long /SpotLight  
Data.Set 0xa0000000 %Long 0x50  
Data.Set 0xa0000000 %Long 0xff
```

## Switch to ID-Mode (AMD/Spansion)

Switching to ID-mode is done by writing a specific command sequence to the command registers of the FLASH device.

To switch an AMD/Spansion FLASH device via TRACE32 to ID-mode, the following 3 commands have to be used:

```
Data.Set <start_address_of_flash>+<addr> <bus_width> <value1>
```

```
Data.Set <start_address_of_flash>+<addrb> <bus_width> <value2>
```

```
Data.Set <start_address_of_flash>+<addr> <bus_width> <value3>
```

<addr>, <addrb> and <value> depend on the FLASH device type and can be referenced from “[Appendix B](#)”, page 68.

Example for 2 AM29BL162C (16-bit mode) in parallel to realize a 32-bit bus.

```
Data.Set <start_address_of_flash>+0x1554 %Long 0x00aa00aa  
Data.Set <start_address_of_flash>+0xaa8 %Long 0x00550055  
Data.Set <start_address_of_flash>+0x1554 %Long 0x00900090
```

ID information:

|                                      |                                                              |
|--------------------------------------|--------------------------------------------------------------|
| <b>Manufacturer ID</b>               | 0x01 (AMD)                                                   |
| <b>Device ID</b>                     | 0x2203 (FLASH device AM29BL162C as bottom boot block device) |
| <b>Sector protection information</b> | 0 (Sector unlocked)                                          |



The ID information is either displayed:

- always at the beginning of each FLASH sector
- repetitive in each FLASH sector (see example above), the repetition rate depends on the FLASH device

**Data.Set** <start\_address\_of\_flash> <bus\_width> **0xf0** Switch the FLASH back to Read Mode

```
Data.Set <start_address_of_flash> %Long 0xf0f0f0f0f0
```



If switching to ID-mode for an AMD/Spansion device can be done and if the manufacturer-id and the device-id is displayed correctly, you can almost be sure that the data bus is working properly.

## Switch to CFI Mode (AMD/Spansion)

To switch an AMD/Spansion FLASH device via TRACE32 to CFI-mode, the following command has to be used:

**Data.Set <start\_address\_of\_flash>+<addr> <bus\_width> 0x98**

```
Data.dump <start_address_of_flash> /Long /SpotLight  
Data.Set <start_address_of_flash>+0x1554 %Long 0x98989898
```

| address    | 0        | 4        | 8        | C        | 0123456789ABCDEF        |
|------------|----------|----------|----------|----------|-------------------------|
| D:A2000000 | 00000000 | 00000000 | 00000000 | 00000000 | *****                   |
| D:A2000010 | 00000000 | 00000000 | 00000000 | 00000000 | *****                   |
| D:A2000020 | 00000000 | 00000000 | 00000000 | 00000000 | *****                   |
| D:A2000030 | 00000000 | 00000000 | 00000000 | 00000000 | *****                   |
| D:A2000040 | 00510051 | 00520052 | 00590059 | 00020002 | Q R R Y Y Y Y Y         |
| D:A2000050 | 00000000 | 00400040 | 00000000 | 00000000 | *****                   |
| D:A2000060 | 00000000 | 00000000 | 00000000 | 00270027 | *****                   |
| D:A2000070 | 00360036 | 00000000 | 00000000 | 00040004 | 6 6 6 6 6 6 6 6         |
| D:A2000080 | 00000000 | 00000000 | 00000000 | 00050005 | ***** ***** ***** ***** |
| D:A2000090 | 00000000 | 00040004 | 00000000 | 00150015 | ***** ***** ***** ***** |
| D:A20000A0 | 00010001 | 00000000 | 00000000 | 00000000 |                         |
| D:A20000B0 | 00040004 | 00000000 | 00000000 | 00400040 | ***** ***** *****       |
| D:A20000C0 | 00000000 | 00010001 | 00000000 | 00200020 | ***** ***** ***** ***** |
| D:A20000D0 | 00000000 | 00000000 | 00000000 | 00080080 | ***** ***** ***** ***** |
| D:A20000E0 | 00030003 | 00060006 | 00000000 | 00000000 | 1 1 1 1 1 1 1 1         |
| D:A20000F0 | 00040004 | 00000000 | 00000000 | 00000000 | 1 1 1 1 1 1 1 1         |
| D:A2000100 | 00050050 | 00520052 | 00490049 | 00310031 | P P R R I I 1 1         |
| D:A2000110 | 00030030 | 00000000 | 00020002 | 00010001 | 0 0 0 0 0 0 0 0         |
| D:A2000120 | 00010001 | 00040004 | 00000000 | 00030003 | 1 1 1 1 1 1 1 1         |
| D:A2000130 | 00000000 | 00000000 | 00000000 | 00000000 | ***** ***** ***** ***** |

The letters Q R Y indicate, that the FLASH is in CFI mode

In the example above 2 16 bit FLASH devices are used in parallel to realize a 32 bit bus. For this reason

|            |   |
|------------|---|
| 0x00510051 | Q |
| 0x00520052 | R |
| 0x00590059 | Y |

is displayed at address 0xa0000040.

Please be aware, that the memory display of **QRY** will vary depending on:

- the data width of the FLASH device
- the number of parallel FLASH devices

The address 0xa0000040 is also just an example.

The operations on AMD/Spansion FLASH devices (e.g. erasing, programming) are initiated by writing a command sequence to the command registers. Since these write accesses are performed by TRACE32, they are not visible to the user by default.

The TRACE32 **SYStem.LOG.List** window provides now the possibility to log all read and write accesses performed by TRACE32 in order to get full visibility. To restrict the logging to the read/write accesses to the FLASH device, it is recommended to close all TRACE32 windows, that display memory.

By using the **SYStem.LOG.List** window, you can check the following:

**1. Does TRACE32 use the correct addresses for the FLASH command registers?**

Wrong command register addresses lead to the assumption, that the wrong *<family\_code>* or the wrong *<bus\_width>* is used in the TRACE32 FLASH declaration.

**2. Does TRACE32 write the required data values in the correct endianness to the command registers?**

Differences in the endianness used for the data values lead to the assumption that the FLASH is connected to your PowerPC CPU in true little endian mode. In this case only target-controlled FLASH programming can be used.

**3. Can TRACE32 read the FLASH status correctly?**

If TRACE32 is unable to read the FLASH status, this leads to the assumption, that the data cache is on.

## SYStem.LOG.List <size> <file>

Log all read/write accesses performed by TRACE32.  
For support purposes it is possible to save the logging to a file.

The former **Data.LOG** command is now called **SYStem.LOG.List**.

Example for TRACE32 screen based logging:

```
WinCLEAR ; Close all TRACE32 windows
SYStem.LOG.List ; Open a data log window
... ; Perform your test sequence
```

By default the **SYStem.LOG.List** window can log up to 256 read/write accesses. To log more read/write accesses, define the required size.

```
WinCLEAR ; Close all TRACE32 windows
SYStem.LOG.List 1000. ; Open a data log window
... ; Perform your test sequence
```



The screenshot shows a window titled "B:Data.LOG 1000". The window has a toolbar with "Start", "Stop", and "Clear" buttons. The main area is a table with the following columns: access, address, width, data, and time. The data is as follows:

| access | address                | width | data        | time      |
|--------|------------------------|-------|-------------|-----------|
| WRITE  | D:A2015554--A2015557   | 4.    | AA 00 AA 00 | 25453.269 |
| WRITE  | D:A2000AAAB--A2000AAAB | 4.    | 55 00 55 00 | 25453.269 |
| WRITE  | D:A2015554--A2015557   | 4.    | 90 00 90 00 | 25453.269 |
| WRITE  | D:A2015554--A2015557   | 4.    | AA 00 AA 00 | 25453.269 |
| WRITE  | D:A2000AAAB--A2000AAAB | 4.    | 55 00 55 00 | 25453.269 |
| WRITE  | D:A20000000--A20000003 | 4.    | 30 00 30 00 | 25453.269 |
| READ   | D:A20000000--A20000003 | 4.    | 08 00 08 00 | 25453.269 |
| READ   | D:A20000000--A20000003 | 4.    | 4C 00 4C 00 | 25453.269 |
| READ   | D:A20000000--A20000003 | 4.    | 08 00 08 00 | 25453.269 |
| READ   | D:A20000000--A20000003 | 4.    | 4C 00 4C 00 | 25453.269 |
| READ   | D:A20000000--A20000003 | 4.    | 08 00 08 00 | 25453.269 |
| READ   | D:A20000000--A20000003 | 4.    | 4C 00 4C 00 | 25453.269 |

An unlimited number of read/write accesses can be logged, if the logging is redirected to a file.

```
WinCLEAR ; Close all TRACE32 windows  
SYStem.LOG.OPEN flashtest ; Open a file to store the data log  
                           ; information (standard extension .log)  
... ; Perform your test sequence  
SYStem.LOG.CLOSE ; Close the log file
```

### Example:



| D   | S          | XL       | Comment  |
|-----|------------|----------|----------|
| D.S | 0xA2015554 | 0x550055 | // write |
| D.S | 0xA2000000 | 0x550055 | // write |
| D.S | 0xA2015554 | 0x800000 | // write |
| D.S | 0xA2015554 | 0xA00000 | // write |
| D.S | 0xA2000000 | 0x550055 | // write |
| D.S | 0xA2000000 | 0x300030 | // write |
| D.S | 0xA2000000 | 0x800008 |          |
| D.S | 0xA2000000 | 0x4C004C |          |
| D.S | 0xA2000000 | 0x800008 |          |
| D.S | 0xA2000000 | 0x4C004C |          |
| D.S | 0xA2000000 | 0x800008 |          |
| D.S | 0xA2000000 | 0x4C004C |          |
| D.S | 0xA2000000 | 0x800008 |          |
| D.S | 0xA2000000 | 0x4C004C |          |

If the read/write accesses performed by TRACE32 are logged into a file, they are converted to [Data.Set](#) commands. This way it is possible to re-run the log with a TRACE32 Instruction Set Simulator.

The following shows a step by step interpretation of the TRACE32 read/write accesses logged to the **SYStem.LOG.List** window.

**FLASH configuration:** 2 AM29BL162C (16-bit mode) in parallel to realize a 32-bit bus width

**Tested FLASH command:** Sector erase

```
FLASH.Create ... Long
```

; FLASH declaration

```
FLASH.Erase 0xa2000000++0x3fff
```

; Erase the defined FLASH sector

## 1. Check the command register addresses

Please refer to the command definition for the sector erase in the data sheet for your FLASH device.

| Am29BL162C Command Definitions |        |                        |      |        |      |       |      |        |      |       |      |       |    |
|--------------------------------|--------|------------------------|------|--------|------|-------|------|--------|------|-------|------|-------|----|
| Command Sequence<br>(Note 1)   | Cycles | Bus Cycles (Notes 2-5) |      |        |      |       |      |        |      |       |      |       |    |
|                                |        | First                  |      | Second |      | Third |      | Fourth |      | Fifth |      | Sixth |    |
|                                |        | Addr                   | Data | Addr   | Data | Addr  | Data | Addr   | Data | Addr  | Data | Addr  |    |
| Sector Erase                   | 6      | 555                    | AA   | 2AA    | 55   | 555   | 80   | 555    | AA   | 2AA   | 55   | SA    | 30 |

- TRACE32 uses byte addresses to write to the FLASH command registers. If word addresses are used in the data sheet of the FLASH device, they have to be converted to byte addresses.
- If parallel FLASHes are used to realize the required *<bus\_width>*, this has also to be taken into account:

|                    |                                                        |
|--------------------|--------------------------------------------------------|
| 2 parallel FLASHes | Multiply the byte address of the command register by 2 |
| 4 parallel FLASHes | Multiply the byte address of the command register by 4 |

- Due to compatibility reasons TRACE32 uses 15 bit command register addresses instead of 11.

**Calculation example:**

|                                                                              |                      |
|------------------------------------------------------------------------------|----------------------|
| Command register address for first bus cycle<br>from data command definition | 0x555 (word address) |
| Conversion from word address to byte<br>address                              | $2 * 0x555 = 0xAAA$  |
| Multiplication for parallel FLASHes                                          | $2 * 0xAAA = 0x1554$ |
| Conversion from 11 bit address into 15 bit<br>command register address       | 0x15554              |

The **SYStem.LOG.List** window shows that TRACE32 uses the correct command register addresses.

The **width** column indicates the *<bus\_width>* used by TRACE32. 4. shows that TRACE32 perform 32 bit write accesses.



| access | address              | width | data        | time      |
|--------|----------------------|-------|-------------|-----------|
| WRITE  | D:A2015554--A2015557 | 4.    | AA 00 AA 00 | 25453.269 |
| WRITE  | D:A2000AAB--A2000AAB | 4.    | 55 00 55 00 | 25453.269 |
| WRITE  | D:A2015554--A2015557 | 4.    | 00 00 00 00 | 25453.269 |
| WRITE  | D:A2015554--A2015557 | 4.    | AA 00 AA 00 | 25453.269 |
| WRITE  | D:A2000AAB--A2000AAB | 4.    | 55 00 55 00 | 25453.269 |
| WRITE  | D:A2000000--A2000003 | 4.    | 30 00 30 00 | 25453.269 |
| READ   | D:A2000000--A2000003 | 4.    | 00 00 00 00 | 25453.269 |
| READ   | D:A2000000--A2000003 | 4.    | 4C 00 4C 00 | 25453.269 |
| READ   | D:A2000000--A2000003 | 4.    | 00 00 00 00 | 25453.269 |
| READ   | D:A2000000--A2000003 | 4.    | 4C 00 4C 00 | 25453.269 |
| READ   | D:A2000000--A2000003 | 4.    | 00 00 00 00 | 25453.269 |
| READ   | D:A2000000--A2000003 | 4.    | 4C 00 4C 00 | 25453.269 |

Write command sequence

Read status

## 2. Check the data values

Please refer to the command definition for the sector erase in the data sheet for your FLASH device.

| Am29BL162C Command Definitions |        |                        |      |        |      |       |      |        |      |       |      |       |      |
|--------------------------------|--------|------------------------|------|--------|------|-------|------|--------|------|-------|------|-------|------|
| Command Sequence<br>(Note 1)   | Cycles | Bus Cycles (Notes 2-5) |      |        |      |       |      |        |      |       |      |       |      |
|                                |        | First                  |      | Second |      | Third |      | Fourth |      | Fifth |      | Sixth |      |
|                                |        | Addr                   | Data | Addr   | Data | Addr  | Data | Addr   | Data | Addr  | Data | Addr  | Data |
| Sector Erase                   | 6      | 555                    | AA   | 2AA    | 55   | 555   | 80   | 555    | AA   | 2AA   | 55   | SA    | 30   |

The **width** column in the **SYStem.LOG.List** window indicates the *<bus\_width>* used by TRACE32.

The byte order is as follows:

| Byte Order         |             |
|--------------------|-------------|
| Little Endian Mode | B0 B1 B2 B3 |
| Big Endian Mode    | B3 B2 B1 B0 |

The **SYStem.LOG.List** window shows that TRACE32 writes the correct data values in little endian mode. Since 2 parallel FLASHes are used, B0 and B2 are used to write the data value.

| access | address              | width | data        | time      |
|--------|----------------------|-------|-------------|-----------|
| WRITE  | D:A2015554--A2015557 | 4.    | AA 00 AA 00 | 25453.269 |
| WRITE  | D:A2000AA8--A2000AA8 | 4.    | 55 00 55 00 | 25453.269 |
| WRITE  | D:A2015554--A2015557 | 4.    | 80 00 80 00 | 25453.269 |
| WRITE  | D:A2015554--A2015557 | 4.    | AA 00 AA 00 | 25453.269 |
| WRITE  | D:A2000AA8--A2000AA8 | 4.    | 55 00 55 00 | 25453.269 |
| WRITE  | D:A2000000--A2000003 | 4.    | 30 00 30 00 | 25453.269 |
| READ   | D:A2000000--A2000003 | 4.    | 08 00 08 00 | 25453.269 |
| READ   | D:A2000000--A2000003 | 4.    | 4C 00 4C 00 | 25453.269 |
| READ   | D:A2000000--A2000003 | 4.    | 08 00 08 00 | 25453.269 |
| READ   | D:A2000000--A2000003 | 4.    | 4C 00 4C 00 | 25453.269 |
| READ   | D:A2000000--A2000003 | 4.    | 08 00 08 00 | 25453.269 |
| READ   | D:A2000000--A2000003 | 4.    | 4C 00 4C 00 | 25453.269 |

Write command sequence

Read status

### 3. Check the status read

After TRACE32 wrote the required 6 commands to erase the FLASH sector, it starts reading the FLASH status.

Please refer to the write operation status information in the data sheet for your FLASH device.

| Write Operation Status |                            |                 |        |                 |     |                 |
|------------------------|----------------------------|-----------------|--------|-----------------|-----|-----------------|
| Operation              |                            | DQ7<br>(Note 2) | DQ6    | DQ5<br>(Note 1) | DQ3 | DQ2<br>(Note 2) |
| Standard<br>Mode       | Embedded Program Algorithm | DQ7#            | Toggle | 0               | N/A | No toggle       |
|                        | Embedded Erase Algorithm   | 0               | Toggle | 0               | 1   | Toggle          |

The following status bits are of importance:

| Status Bits  |                                                                         |
|--------------|-------------------------------------------------------------------------|
| <b>DQ2/6</b> | Bit 2 and Bit 6 need to toggle at each status read                      |
| <b>DQ5</b>   | DQ5==1 && DQ7==0 indicates a time-out caused by an internal FLASH error |
| <b>DQ7</b>   | A soon as DQ7 becomes 1, erasing of the FLASH sector is done            |

The following **SYStem.LOG.List** window shows that DQ2 and DQ6 are toggling at each status read.

| 8:Data.LOG 1000 |                      |       |             |           |
|-----------------|----------------------|-------|-------------|-----------|
| access          | address              | width | data        | time      |
| WRITE           | D:A2015554--A2015557 | 4.    | AA 00 AA 00 | 25453.269 |
| WRITE           | D:A200AA08--A200AA0B | 4.    | 55 00 55 00 | 25453.269 |
| WRITE           | D:A2015554--A2015557 | 4.    | 80 00 80 00 | 25453.269 |
| WRITE           | D:A2015554--A2015557 | 4.    | AA 00 AA 00 | 25453.269 |
| WRITE           | D:A200AA08--A200AA0B | 4.    | 55 00 55 00 | 25453.269 |
| WRITE           | D:A2000000--A2000003 | 4.    | 30 00 30 00 | 25453.269 |
| READ            | D:A2000000--A2000003 | 4.    | 08 00 08 00 | 25453.269 |
| READ            | D:A2000000--A2000003 | 4.    | 4C 00 4C 00 | 25453.269 |
| READ            | D:A2000000--A2000003 | 4.    | 08 00 08 00 | 25453.269 |
| READ            | D:A2000000--A2000003 | 4.    | 4C 00 4C 00 | 25453.269 |
| READ            | D:A2000000--A2000003 | 4.    | 08 00 08 00 | 25453.269 |
| READ            | D:A2000000--A2000003 | 4.    | 4C 00 4C 00 | 25453.269 |

Write command sequence

Read status

The **SYStem.LOG.List** window below shows that erasing the sector is done (DQ7==1). Afterwards the FLASH is switched back to read mode.

| access | address              | width | data        | time      |
|--------|----------------------|-------|-------------|-----------|
| READ   | D:A2000000--A2000003 | 4.    | 5C 00 FF FF | 25454.081 |
| READ   | D:A2000000--A2000003 | 4.    | 18 00 FF FF | 25454.081 |
| READ   | D:A2000000--A2000003 | 4.    | 5C 00 FF FF | 25454.081 |
| READ   | D:A2000000--A2000003 | 4.    | 18 00 FF FF | 25454.081 |
| READ   | D:A2000000--A2000003 | 4.    | FF FF FF FF | 25454.081 |
| WRITE  | D:A2000000--A2000003 | 4.    | F0 F0 F0 F0 | 25454.081 |
| WRITE  | D:A2000000--A2000003 | 4.    | F0 F0 F0 F0 | 25454.081 |

Read status

**Sector erase for both  
FLASH devices is done**

Write command  
to switch FLASH  
to read mode

The picture above shows, that the sector erase for one FLASH performed faster (Status already 0xff 0xff).

## Error Scenarios

**Erasing the FLASH sector failed because FLASH area is indicated as cacheable and data cache is on.**

| access | address                | width | data        |
|--------|------------------------|-------|-------------|
| WRITE  | D:A2015554--A2015557   | 4.    | AA 00 AA 00 |
| WRITE  | D:A2000AAAB--A2000AAAB | 4.    | 55 00 55 00 |
| WRITE  | D:A2015554--A2015557   | 4.    | 80 00 80 00 |
| WRITE  | D:A2015554--A2015557   | 4.    | AA 00 AA 00 |
| WRITE  | D:A2000AAAB--A2000AAAB | 4.    | 55 00 55 00 |
| WRITE  | D:A20000000--A20000003 | 4.    | 30 00 30 00 |
| READ   | D:A20000000--A20000003 | 4.    | 08 00 08 00 |
| READ   | D:A20000000--A20000003 | 4.    | 08 00 08 00 |
| READ   | D:A20000000--A20000003 | 4.    | 08 00 08 00 |
| READ   | D:A20000000--A20000003 | 4.    | 08 00 08 00 |

Write command sequence

Read status

**Status can only be read once**

Since the FLASH area is cached to the data cache, the status never changes. As a result, TRACE32 can't read the ready status (DQ7==1). This situation leads to an **erase timeout error**.

**Erasing the FLASH sector failed, because TRACE32 has no write access to the FLASH**

| B::Data.dump 0xa2000000 /NoAscii |          |          |          |
|----------------------------------|----------|----------|----------|
| address                          | 0        | 4        | 8        |
| D:A2000000                       | 12345678 | 00000876 | 009A89A8 |
| D:A2000010                       | 66690908 | 0975CA43 | 09876000 |
| D:A2000020                       | AAACCC55 | 00656789 | 00000000 |

  

| access | address                | width | data        |
|--------|------------------------|-------|-------------|
| WRITE  | D:A2015554--A2015557   | 4.    | AA 00 AA 00 |
| WRITE  | D:A2000AAAB--A2000AAAB | 4.    | 55 00 55 00 |
| WRITE  | D:A2015554--A2015557   | 4.    | 80 00 80 00 |
| WRITE  | D:A2015554--A2015557   | 4.    | AA 00 AA 00 |
| WRITE  | D:A2000AAAB--A2000AAAB | 4.    | 55 00 55 00 |
| WRITE  | D:A20000000--A20000003 | 4.    | 30 00 30 00 |
| READ   | D:A20000000--A20000003 | 4.    | 78 56 34 12 |
| READ   | D:A20000000--A20000003 | 4.    | 78 56 34 12 |
| WRITE  | D:A20000000--A20000003 | 4.    | F0 F0 F0 F0 |
| WRITE  | D:A20000000--A20000003 | 4.    | F0 F0 F0 F0 |

Write command sequence

FLASH is still in read mode,  
FLASH contents is read instead of status

# Appendix B

---

`&base=<start_address_of_flash>`

## FLASH Width BYTE

---

| CODE                                                                                      | Test write access                                                                                                                                           |
|-------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AM29F010<br>AM29LV010<br>AM29M010<br>AT49F010<br>SST29F010                                | <code>Data.Set &amp;base+0x5555 %Byte 0xaa</code><br><code>Data.Set &amp;base+0x2aaa %Byte 0x55</code><br><code>Data.Set &amp;base+0x5555 %Byte 0x90</code> |
| AM29F100B<br>AM29LV100B<br>AM29LV256B<br>AM29M100B<br>AM29M256B<br>AM29N256B<br>AT49F100B | <code>Data.Set &amp;base+0xaaaa %Byte 0xaa</code><br><code>Data.Set &amp;base+0x5555 %Byte 0x55</code><br><code>Data.Set &amp;base+0xaaaa %Byte 0x90</code> |

| CODE                                                                                      | Test write access                                                                        | Test PPC target for true little endian mode                                              |
|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| AM29F010<br>AM29LV010<br>AM29M010<br>AT49F010<br>SST29F010                                | D.S &base+0xaaaa %W 0xaaaa<br>D.S &base+0x5554 %W 0x5555<br>D.S &base+0xaaaa %W 0x9090   |                                                                                          |
| AM29F100<br>AM29LV100<br>AM29LV256<br>AM29M100<br>AM29M256<br>AM29N256<br>AT49F100        | D.S &base+0xaaaa %W 0x00aa<br>D.S &base+0x5554 %W 0x0055<br>D.S &base+0xaaaa %W 0x0090   | D.S &base+0xaaaa %W 0xaa00<br>D.S &base+0x5554 %W 0x5500<br>D.S &base+0xaaaa %W 0x9000   |
| AM29F100B<br>AM29LV100B<br>AM29LV256B<br>AM29M100B<br>AM29M256B<br>AM29N256B<br>AT49F100B | D.S &base+0x15554 %W 0xaaaa<br>D.S &base+0xaaaa %W 0x5555<br>D.S &base+0x15554 %W 0x9090 |                                                                                          |
| AM29BDDW                                                                                  | D.S &base+0x15554 %W 0x00aa<br>D.S &base+0xaaaa %W 0x0055<br>D.S &base+0x15554 %W 0x0090 | D.S &base+0x15554 %W 0xaa00<br>D.S &base+0xaaaa %W 0x5500<br>D.S &base+0x15554 %W 0x9000 |

| CODE                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AM29F010<br>AM29LV010<br>AM29M010<br>AT49F010<br>SST29F010                                | Data.Set &base+0x15554 %Long 0aaaaaaaaa<br>Data.Set &base+0xaaaa8 %Long 0x55555555<br>Data.Set &base+0x15554 %Long 0x90909090                                                                                                                                                                                                                                                            |
| AM29F100<br>AM29LV100<br>AM29LV256<br>AM29M100<br>AM29M256<br>AM29N256<br>AT49F100        | <p><b>Test write access</b></p> <p>Data.Set &amp;base+0x15554 %Long 0x00aa00aa<br/>Data.Set &amp;base+0xaaaa8 %Long 0x00550055<br/>Data.Set &amp;base+0x15554 %Long 0x00900090</p> <p>Test PPC target for true little endian mode</p> <p>Data.Set &amp;base+0x15554 %Long 0xaa00aa00<br/>Data.Set &amp;base+0xaaaa8 %Long 0x55005500<br/>Data.Set &amp;base+0x15554 %Long 0x90009000</p> |
| AM29F100B<br>AM29LV100B<br>AM29LV256B<br>AM29M100B<br>AM29M256B<br>AM29N256B<br>AT49F100B | Data.Set &base+0x2aaaa8 %Long 0aaaaaaaaa<br>Data.Set &base+0x15554 %Long 0x55555555<br>Data.Set &base+0x2aaaa8 %Long 0x90909090                                                                                                                                                                                                                                                          |
| AM29BDD                                                                                   | <p><b>Test write access</b></p> <p>Data.Set &amp;base+0x15554 %Long 0x000000aa<br/>Data.Set &amp;base+0xaaaa8 %Long 0x00000055<br/>Data.Set &amp;base+0x15554 %Long 0x00000090</p> <p>Test PPC target for true little endian mode</p> <p>Data.Set &amp;base+0x15554 %Long 0xaa000000<br/>Data.Set &amp;base+0xaaaa8 %Long 0x55000000<br/>Data.Set &amp;base+0x15554 %Long 0x90000000</p> |

| CODE      |                                                                                                                                                |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------|
| AM29BDDW  | <b>Test write access</b>                                                                                                                       |
|           | <pre>Data.Set &amp;base+0x2aaa8 %Long 0x00aa00aa Data.Set &amp;base+0x15554 %Long 0x00550055 Data.Set &amp;base+0x2aaa8 %Long 0x00900090</pre> |
|           | <b>Test PPC target for true little endian mode</b>                                                                                             |
|           | <pre>Data.Set &amp;base+0x2aaa8 %Long 0xaa00aa00 Data.Set &amp;base+0x15554 %Long 0x55005500 Data.Set &amp;base+0x2aaa8 %Long 0x90009000</pre> |
| AM29M2562 | <b>Test write access</b>                                                                                                                       |
|           | <pre>Data.Set &amp;base+0x15554 %Long 0x0000aaaa Data.Set &amp;base+0xaaa8 %Long 0x00005555 Data.Set &amp;base+0x15554 %Long 0x00009090</pre>  |
|           | <b>Test PPC target for true little endian mode</b>                                                                                             |
|           | <pre>Data.Set &amp;base+0x15554 %Long 0xaaaaa0000 Data.Set &amp;base+0xaaa8 %Long 0x55550000 Data.Set &amp;base+0x15554 %Long 0x90900000</pre> |

| CODE                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AM29F010<br>AM29LV010<br>AM29M010<br>AT49F010<br>SST29F010                                | Data.Set &base+0x2aaa8 %Quad 0aaaaaaaaaaaaaaaaaa<br>Data.Set &base+0x15550 %Quad 0x5555555555555555<br>Data.Set &base+0x2aaa8 %Quad 0x9090909090909090                                                                                                                                                                                                                                                                                          |
| AM29F100<br>AM29LV100<br>AM29LV256<br>AM29M100<br>AM29M256<br>AM29N256<br>AT49F100        | <p><b>Test write access</b></p> <p>Data.Set &amp;base+0x2aaa8 %Quad 0x00aa00aa00aa00aa<br/>Data.Set &amp;base+0x15550 %Quad 0x0055005500550055<br/>Data.Set &amp;base+0x2aaa8 %Quad 0x0090009000900090</p> <p><b>Test PPC target for true little endian mode</b></p> <p>Data.Set &amp;base+0x2aaa8 %Quad 0xaa00aa00aa00aa00<br/>Data.Set &amp;base+0x15550 %Quad 0x5500550055005500<br/>Data.Set &amp;base+0x2aaa8 %Quad 0x9000900090009000</p> |
| AM29F100B<br>AM29LV100B<br>AM29LV256B<br>AM29M100B<br>AM29M256B<br>AM29N256B<br>AT49F100B | Data.Set &base+0x55550 %Quad 0aaaaaaaaaaaaaaaaaa<br>Data.Set &base+0x2aaa8 %Quad 0x5555555555555555<br>Data.Set &base+0x55550 %Quad 0x9090909090909090                                                                                                                                                                                                                                                                                          |
| AM29BDD                                                                                   | <p><b>Test write access</b></p> <p>Data.Set &amp;base+0x2aaa8 %Quad 0x000000aa000000aa<br/>Data.Set &amp;base+0x15550 %Quad 0x0000005500000055<br/>Data.Set &amp;base+0x2aaa8 %Quad 0x0000009000000090</p> <p><b>Test PPC target for true little endian mode</b></p> <p>Data.Set &amp;base+0x2aaa8 %Quad 0xaa000000aa000000<br/>Data.Set &amp;base+0x15550 %Quad 0x5500000055000000<br/>Data.Set &amp;base+0x2aaa8 %Quad 0x9000000090000000</p> |

| CODE      |                                                                                                                                                                        |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AM29BDDW  | <b>Test write access</b>                                                                                                                                               |
|           | <pre>Data.Set &amp;base+0x55550 %Quad 0x00aa00aa00aa00aa Data.Set &amp;base+0x2aaa8 %Quad 0x0055005500550055 Data.Set &amp;base+0x55550 %Quad 0x0090009000900090</pre> |
|           | <b>Test PPC target for true little endian mode</b>                                                                                                                     |
|           | <pre>Data.Set &amp;base+0x55550 %Quad 0xaa00aa00aa00aa00 Data.Set &amp;base+0x2aaa8 %Quad 0x5500550055005500 Data.Set &amp;base+0x55550 %Quad 0x9000900090009000</pre> |
| AM29M2562 | <b>Test write access</b>                                                                                                                                               |
|           | <pre>Data.Set &amp;base+0x2aaa8 %Quad 0x0000aaaa0000aaaa Data.Set &amp;base+0x15550 %Quad 0x0000555500005555 Data.Set &amp;base+0x2aaa8 %Quad 0x0000909000009090</pre> |
|           | <b>Test PPC target for true little endian mode</b>                                                                                                                     |
|           | <pre>Data.Set &amp;base+0x2aaa8 %Quad 0xaaaa0000aaaa0000 Data.Set &amp;base+0x15550 %Quad 0x5555000055550000 Data.Set &amp;base+0x2aaa8 %Quad 0x9090000090900000</pre> |