

**Application Note** 

# Porting RZK/ZTP Applications to the eZ80L925148MODG Module

AN036602-1013

# Abstract

This document describes procedures for porting ZTP 2.4.x applications to the eZ80L925148MODG Module (Zilog Module Label 99C1400-001G) and the eZ80Acclaim! Development Platform (99C0858–001). The new eZ80L925148MODG Module features the same physical form factor as the eZ80L925048MODG Module (99C0857-001) it replaces; however, the new eZ80L925148MODG Module uses a different external Flash module. This new eZ80L925148MODG Module (99C1400-001G) is affixed to the eZ80Acclaim! Development Platform, as indicated in Figure 1.



Figure 1. eZ80L92 Module Affixed to the eZ80Acclaim! Development Platform



**Note:** The source code file associated with this application note, <u>AN0366-SC01</u>, is available free for download from the Zilog website. This source code has been tested with ZDSII – eZ80Acclaim! version 5.2.1 and ZTP version 2.4.1. Subsequent releases of ZDSII may require you to modify the code supplied with this application note.

## **Differences Between the Modules**

The hardware differences between the older eZ80L925048MOD Module and the new eZ80L925148MODG Module are summarized in Table 1. Click the links in this table to learn more about how these changes affect ZTP applications.

Table 1. Hardware Differences Between eZ80L925x48MOD Modules

| Component/<br>Feature    | 99C0857 Hardware<br>Implementation | 99C1400 Hardware<br>Implementation                                                     | Affected Project<br>Settings                                                                               | Application<br>Modification   |
|--------------------------|------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|-------------------------------|
| External Flash<br>on CS0 | 1 MB Micron<br>MT28F008B3          | 8MB Spansion<br>S29GL064N<br>eZ80Acclaim!<br>Development<br>Platform Jumper<br>Changes | CS0 Configuration<br>New ZTGT Files and<br>Address Spaces<br>eZ80L925148MODG<br>Preprocessor<br>Definition | Optional ZFS<br>Configuration |
| IrDA                     | Yes                                | No                                                                                     | N/A                                                                                                        | Remove IRDA code              |

The hardware changes listed in Table 1 require modifications to your ZTP project before the application will function with the eZ80L925148MODG Module. Although this document describes the changes required specifically when using the eZ80Acclaim! Development Platform, similar project file changes may also be required when using hardware platforms with the eZ80L925148MODG Module.

To learn more about the eZ80L925148MODG Module, refer to the <u>eZ80L92 Module</u> <u>Product Specification (PS0318)</u>. For a demonstration program that includes the changes required to support the eZ80L925148MODG Module, refer to the ZTPDemo\_eZ80L925148MODG.zdsproj file in the AN0366-SC01\_<version>.exe

installation package. The remaining sections of this document describe the project and/or application changes required to support these hardware changes.

# **CS0** Configuration

1 MB of external Flash memory is mapped to the CS0 on the eZ80L925048MOD Module. Applications that use this older module typically configured the CS0 as follows for RAM build configurations:

| CS0 Lower Bound | 0x100000 |
|-----------------|----------|
| CS0 Upper Bound | 0x1FFFFF |



CS0 Control0x88CS0 Bus Mode0x82

The new eZ80L925148MODG Module is equipped with 8MB of Flash mapped to the CS0. To avoid conflicts with SRAM memory that is mapped to the first 512KB to 1MB of the eZ80L92 address space in RAM build configurations, the CS0 should continue to be configured with a lower bound of  $0 \times 100000$ . This configuration would imply a CS0 upper bound of  $0 \times 8FFFFF$  on the eZ80L925148MODG Module.

However, be advised that when using the eZ80Acclaim! Development Platform (99C0858) with the eZ80L925148MODG Module, the GPIO and LED matrix are mapped into the CS2 memory at 0x800000. Also, the gate array logic on the eZ80Acclaim! Development Platform limits the upper bound of the CS0 mapping to 0x7FFFFF. Consequently, Zilog recommends the following CS0 settings for use with the eZ80L925148MODG Module on the eZ80Acclaim! Development Platform for RAM builds:

| CS0 Lower Bound | 0x100000 |
|-----------------|----------|
| CS0 Upper Bound | 0x7FFFFF |
| CS0 Control     | 0x88     |
| CS0 Bus Mode    | 0x01     |

When using a Flash (or Copy to RAM) build configuration, the lower bound on the CS0 is typically set to  $0 \times 00$  and the chip selects for SRAM are configured such that the static RAM is located above the highest memory address occupied by the external Flash.

## eZ80Acclaim! Development Platform Jumper Changes

When using the eZ80L925148MODG Module with the eZ80Acclaim! Development Platform, it is typically necessary to install Jumper J20. By default, the external chip select signal on the eZ80Acclaim! Development Platform, nCS\_EX, features a jumper in the 1–2 position of J19, which routes memory requests in the CS0 range of  $0 \times 400000$  to  $0 \times 7FFFFF$  to the eZ80Acclaim! Development Platform. As a result, access is prevented to the upper 4MB of the external 8MB Flash space on the eZ80L925148MODG Module. To maximize the amount of external Flash memory, the eZ80L92 MCU can access on the eZ80L925148MODG Module. It is necessary to install a shunt on J20.

# **New ZTGT Files and Address Spaces**

The AN0366-SC01\_<version>.exe installation and later ZDSII - eZ80Acclaim! releases include two new Zilog target (ZTGT) files for the eZ80L925148MODG Module. These files are named eZ80L925148MODG\_RAM.ztgt and eZ80L925148MODG\_Flash.ztgt.



## **RAM Build Configuration**

For applications using the RAM build configuration, select the eZ80L925148MODG\_RAM target by observing the following brief procedure.

- 1. From the **Project** menu in ZDS II, choose **Settings**... to open the Project Settings dialog.
- 2. In the left pane, click **Debugger**. In the Target pane, select the **eZ80L925148MODG\_RAM** target.
- 3. Click the **Setup** button. The Configure Target dialog will appear, as shown in Figure 2, which presents the default settings for the eZ80L925148MODG\_RAM ZTGT file. If you have not previously modified the contents of the eZ80L925148MODG\_RAM file, then you should see the values in Figure 2 after clicking the Setup button. Verify that the your settings match the values shown in this figure.

| PC/STACK Registers                                                        |                  | Mode                              | _              |
|---------------------------------------------------------------------------|------------------|-----------------------------------|----------------|
| Program Counter (hex)                                                     | : <u>I</u>       | I Start in ADL r                  | node           |
| SPL Stack Pointer (he<br>SPS Stack Pointer (he                            |                  | External RAM<br>Range(hex): B800  | 100 — BFFFFF   |
| External Memory/ID                                                        |                  |                                   |                |
| Chip Select Registers:                                                    | CS0 ·            |                                   |                |
| Lower<br>Bound (hex): 10000<br>Control Register (hex):<br>Bus Mode (hex): | 0 - 7FFFFF<br>88 |                                   |                |
| Clock                                                                     |                  |                                   | 0000           |
| Oscillator                                                                | System Clock     | <pre>K Frequency (Hz): 4800</pre> | 0000           |
|                                                                           | (Oscillator      | Frequency = System C              | lock Frequency |
| Configure Flash                                                           |                  | ОК                                | Cancel         |

Figure 2. The Configure Target Dialog for the RAM Build



4. Examine the settings of the remaining chip selects in the **Chip Select Registers**: drop-down menu, and verify that the settings for CS0 to CS3 correspond to the values shown in Table 3.

| Chip Select | Memory Range      | CS Control | CS Bus Mode |
|-------------|-------------------|------------|-------------|
| CS0         | 0x100000-0x7FFFFF | 0x88       | 0x01        |
| CS1         | 0x000000-0x07FFFF | 0x08       | 0x01        |
| CS2         | 0x800000-0xBFFFFF | 0x28       | 0x01        |
| CS3         | 0x030000–0x030000 | 0x18       | 0x84        |

#### Table 2. Chip Select Settings for the RAM Build

5. When configuring RAM build configurations using the eZ80L925148MODG Module with the eZ80Acclaim! Development Platform, Zilog recommends using the settings in the Address Spaces selection of the Project Settings dialog, which is shown in Figure 3. Ensure that the project's settings match the values displayed in this figure.



| onfiguration: RAM                                                                                                                                                                                            | •                                       |                                     |      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-------------------------------------|------|
| Assembler<br>C<br>Code Generation<br>Listing Files<br>Preprocessor<br>Advanced<br>Deprecated<br>ZSL<br>RZK<br>Linker<br>Commands<br>Objects and Librarie<br>Address Spaces<br>Warnings<br>Output<br>Debugger | ROM<br>000000-07FFFF<br>ExtIO<br>0-FFFF | RAM<br>B80000-BFFF<br>IntIO<br>0-FF | FF   |
|                                                                                                                                                                                                              | OK                                      | Cancel                              | Help |

Figure 3. The Configure Target Dialog

## Flash and Copy to RAM Build Configurations

Applications using the FLASH or COPY TO RAM build configurations should select the eZ80L925148MODG\_Flash target by observing the following brief procedure:

- 1. From the **Project** menu in ZDSII, choose **Settings...** to open the Project Settings dialog.
- 2. In the left pane, click **Debugger**. In the Target pane, select the **eZ80L925148MODG\_Flash** target.
- 3. Click the **Setup** button. The Configure target dialog will appear, as shown in Figure 4, which presents the default settings for the eZ80L925148MODG\_Flash ZTGT file. If you have not modified the contents of the eZ80L925148MODG\_Flash.ztgt file, then you should see the values in Figure 4 after clicking the Setup button. Verify that your settings match the values shown in this figure.



| PC/STACK Registers                                   | Mode                            |
|------------------------------------------------------|---------------------------------|
| Program Counter (hex):  🗓                            | ✓ Start in ADL mode             |
| SPL Stack Pointer (hex): C80000                      | External RAM                    |
| SPS Stack Pointer (hex): FFFF                        | Range(hex): B80000 - C7FF       |
| External Memory/ID                                   |                                 |
| Chip Select Registers; CS0 🔹                         |                                 |
| Bound (hex): Lower Upper<br>000000 - 7FFFFF          |                                 |
| Control Register (hex): 88<br>Bus Mode (hex): 01     |                                 |
| Clock                                                | - 415 4900000                   |
| <ul> <li>Dscillator</li> <li>System Clock</li> </ul> | Frequency (Hz): 48000000        |
| (Oscillator F                                        | requency = System Clock Frequer |
|                                                      |                                 |

Figure 4. The Configure Target Dialog for the Flash/Copy to RAM Build

4. Examine the settings of the remaining chip selects in the **Chip Select Registers**: drop-down menu, and verify that the settings for CS0 to CS3 correspond to the values shown in Figure 3.

| Chip Select | Memory Range      | CS Control | CS Bus Mode |
|-------------|-------------------|------------|-------------|
| CS0         | 0x000000-0x7FFFFF | 0x88       | 0x01        |
| CS1         | 0xC00000-0xC7FFFF | 0x08       | 0x01        |
| CS2         | 0x800000-0xBFFFFF | 0x28       | 0x01        |
| CS3         | 0x030000-0x030000 | 0x18       | 0x84        |

5. When using the eZ80L925148MODG Module with the eZ80Acclaim! Development Platform, Zilog recommends the settings for the Address Spaces tab in the Project Set-



| onfiguration: FLASH                                                                                                                                                                                          | •                                      |                                      |      |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--------------------------------------|------|
| Assembler<br>C<br>Code Generation<br>Listing Files<br>Preprocessor<br>Advanced<br>Deprecated<br>ZSL<br>RZK<br>Linker<br>Commands<br>Objects and Librarie<br>Address Spaces<br>Warnings<br>Output<br>Debugger | ROM<br>000000-2FFFFF<br>EdiO<br>0-FFFF | RAM<br>C00000-C7FFI<br>IntiO<br>0-FF | F    |
|                                                                                                                                                                                                              | OK                                     | Cancel                               | Help |

tings menu for Flash build configurations which are shown in Figure 5. Verify that the settings match the values shown in this figure.

Figure 5. The Address Spaces Dialog for the Flash Build

**Note:** The ROM address space shown in Figure 5 only includes the first 3MB of external Flash memory. If the project requires additional ROM memory (i.e., code space), the upper range of the ROM address space can be increased up to 0x7FFFFF.

6. When configuring Copy to RAM build configurations using the eZ80L925148MODG Module with the eZ80Acclaim! Development Platform, Zilog recommends using the settings in the Address Spaces selection of the Project Settings dialog which are shown in Figure 6. Ensure that your project's settings match the values displayed in the following figure.



| Assembler<br>COPY_TO_RAM<br>Assembler<br>C<br>C<br>Code Generation<br>Listing Files<br>Preprocessor<br>Advanced<br>Deprecated<br>ZSL<br>RZK E | ROM<br>000000-2FFFFF<br>ExtIO<br>0-FFFF | RAM<br> B80000-BFFFFF,C00000-C7<br>IntIO<br> 0-FF |
|-----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------------------------------------------------|
| Linker<br>Commands<br>Objects and Librarie<br>Address Spaces<br>Warnings<br>Output<br>Debugger                                                |                                         |                                                   |

Figure 6. The Address Spaces Dialog for the Copy to RAM Build

## eZ80L925148MODG Preprocessor Definition

The eZ80L925148MODG preprocessor definition is used to simplify and unify project settings between the various build configurations (RAM, Flash and Copy to RAM). This new preprocessor definition replaces the following preprocessor definitions used with the eZ80L925048MOD Module: RAM\_BUILD and ZFS\_COPY\_TO\_RAM. RZK/ZTP projects that target the eZ80L925148MODG Module should include the eZ80L925148MODG preprocessor definition regardless of which build configuration is used and should not use the RAM\_BUILD or ZFS\_COPY\_TO\_RAM preprocessor definitions.

The eZ80L925148MODG preprocessor definition is used to select a memory configuration compatible with the optional Zilog File System (ZFS) and the optional data persistence module.



If the eZ80L925148MODG preprocessor definition is included in the project settings the compiler uses the settings in the ZFS\_Conf\_eZ80L925148MODG.c file to configure ZFS, as shown in the following code fragment from ZFS\_Conf.c.

```
#ifdef EZ80F910300KITG
    #include "ZFS_Conf_eZ80F910300KITG.c"
#else
    #ifdef EZ80L925148MODG
    #include "ZFS_Conf_eZ80L925148MODG.c"
    #else
    #include "ZFS_Conf_old.c"
    #endif
#endif
```

The eZ80L925148MODG preprocessor definition also determines the location of the block of Flash memory used to hold the Data Persistence variables as shown in the following code fragment in the DataPer\_Conf.c file:

```
#ifdef _EZ80L92
 #ifdef EZ80L925148MODG
 DATA_PER_CFG_t g_data_per_cfg =
  {
   ( void * ) 0x7F0000,
                                     /* starting address */
  ( UINT32 ) 0x002000UL,
                                     /* erasable block size */
 FS_AM29LV160_Init,
 FS_AM29LV160_Read,
 FS_AM29LV160_Write,
 FS_AM29LV160_Erase,
 FS AM29LV160 Close
 };
 #else
 DATA_PER_CFG_t g_data_per_cfg =
  {
  ( void * ) 0x004000,
                                    /* starting address */
  ( UINT32 ) 0x002000UL,
                                     /* erasable block size */
 MT28F008_Init,
 MT28F008_Read,
 MT28F008_Write,
 MT28F008_Erase,
 MT28F008 Close
 };
  #endif
#else
 DATA_PER_CFG_t g_data_per_cfg =
  {
  ( void * ) 0x000000,
                                     /* starting address */
  ( UINT32 ) 0x000100UL,
                                     /* erasable block size */
 IntFlash_IP_Init,
  IntFlash_IP_Read,
```



```
IntFlash_IP_Write,
IntFlash_IP_Erase,
IntFlash_IP_Close
};
#endif
```

# **Optional ZFS Configuration**

RZK/ZTP applications that use the Zilog File System (ZFS) can optionally modify the ZFS configuration file to allocate more, or less, Flash memory to ZFS. The default settings of the ZFS\_Conf\_eZ80L925148MODG.c file are listed below.

```
#define ZFS_TOTAL_NUM_BLOCKS ( 32 )
#define ZFS_TOTAL_NUM_SECTORS( 0x200000/ZFS_SEC_SIZE )
#define ZFS_TOTAL_NUM_VOLUMES( 1 )
#define ZFS_MAX_FILE_OPEN_COUNT( 20 )
#define ZFS_MAX_DIRS_SUPPORTED( 50 )
#define ERASE_FLASH( 0 )
ZFS_CONFIG_t g_zfs_cfg[ ZFS_TOTAL_NUM_VOLUMES ] =
ł
  "EXTF",
                                       // vol name
                                      // vol type
 ZFS_EXT_FLASH_DEV_TYPE,
  (UINT8*)0x300000,
                                      // vol_start_addr
 0x200000,
                                      // vol_size
                                      // vol_blocks
 ZFS_TOTAL_NUM_BLOCKS,
                                      // number of sectors
 ZFS_TOTAL_NUM_SECTORS,
 FS_AM29LV160_Init,
 FS_AM29LV160_Read,
 FS_AM29LV160_Write,
 FS_AM29LV160_Erase,
 FS_AM29LV160_Close
};
```

These settings will configure the ZFS to use 2MB of CS0 Flash from addresses  $0 \times 300000$  to  $0 \times 4$ FFFFF for the ZFS. In total, 32 Flash erase blocks (each 64 KB in size) are allocated to the ZFS giving a volume size of  $0 \times 200000$  bytes. Source code to the Flash driver used to read and write data to this volume is contained in the AM29LV160\_Driver.c file.

**Note:** The AM29LV160\_Driver.c file (and other ZFS Flash driver files) is modified in the ZTP 2.4.2 release to explicitly disable interrupts while modifying the contents of Flash. This modification is necessary to ensure that an interrupt does not cause a higher-priority thread to start running from external Flash or attempt to read data from external Flash while it is being programmed or erased.



## **Customer Support**

To share comments, get your technical questions answered, or report issues you may be experiencing with our products, please visit Zilog's Technical Support page at <u>http://support.zilog.com</u>.

To learn more about this product, find additional documentation, or to discover other facets about Zilog product offerings, please visit the Zilog Knowledge Base at <u>http://</u><u>zilog.com/kb</u> or consider participating in the Zilog Forum at <u>http://zilog.com/forum</u>.

This publication is subject to replacement by a later edition. To determine whether a later edition exists, please visit the Zilog website at <u>http://www.zilog.com</u>.



Warning: DO NOT USE THIS PRODUCT IN LIFE SUPPORT SYSTEMS.

#### LIFE SUPPORT POLICY

ZILOG'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS PRIOR WRITTEN APPROVAL OF THE PRESIDENT AND GENERAL COUNSEL OF ZILOG CORPORATION.

#### As used herein

Life support devices or systems are devices which (a) are intended for surgical implant into the body, or (b) support or sustain life and whose failure to perform when properly used in accordance with instructions for use provided in the labeling can be reasonably expected to result in a significant injury to the user. A critical component is any component in a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system or to affect its safety or effectiveness.

#### **Document Disclaimer**

©2013 Zilog, Inc. All rights reserved. Information in this publication concerning the devices, applications, or technology described is intended to suggest possible uses and may be superseded. ZILOG, INC. DOES NOT ASSUME LIABILITY FOR OR PROVIDE A REPRESENTATION OF ACCURACY OF THE INFORMATION, DEVICES, OR TECHNOLOGY DESCRIBED IN THIS DOCUMENT. ZILOG ALSO DOES NOT ASSUME LIABILITY FOR INTELLECTUAL PROPERTY INFRINGEMENT RELATED IN ANY MANNER TO USE OF INFORMATION, DEVICES, OR TECHNOLOGY DESCRIBED HEREIN OR OTHERWISE. The information contained within this document has been verified according to the general principles of electrical and mechanical engineering.

eZ80Acclaim!, ZTP and ZDSII are trademarks or registered trademarks of Zilog, Inc. All other product or service names are the property of their respective owners.