

Z8 Encore!®, eZ80Acclaim!®, and ZNEOTM

# ZiLOG Nexus Interface API

**Reference Manual** 

RM004502-0506

## Nexus Interface API Reference Manual



This publication is subject to replacement by a later edition. To determine whether a later edition exists, or to request copies of publications, contact:

#### ZiLOG Worldwide Headquarters

532 Race Street San Jose, CA 95126 Telephone: 408.558.8500

Fax: 408.558.8300 www.ZiLOG.com

#### **Document Disclaimer**

ZiLOG is a registered trademark of ZiLOG Inc. in the United States and in other countries. All other products and/or service names mentioned herein may be trademarks of the companies with which they are associated. ©2006 by 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. Devices sold by ZiLOG, Inc. are covered by warranty and limitation of liability provisions appearing in the ZiLOG, Inc. Terms and Conditions of Sale. ZiLOG, Inc. makes no warranty of merchantability or fitness for any purpose Except with the express written approval of ZiLOG, use of information, devices, or technology as critical components of life support systems is not authorized. No licenses are conveyed, implicitly or otherwise, by this document under any intellectual property rights.

# Table of Contents

| Table of Contents                                                    | iii |
|----------------------------------------------------------------------|-----|
| List of Tables                                                       | V   |
| Introduction                                                         | 1   |
| Conventions                                                          |     |
| Trademarks                                                           | 2   |
| Online Information                                                   | 2   |
| Implementation                                                       | 3   |
| Vendor Extensions                                                    |     |
| Naming Conventions                                                   | 3   |
| Target Address                                                       | 3   |
| Target Word                                                          | 4   |
| Target Registers                                                     | 4   |
| Target Events                                                        | 4   |
| Target Spec                                                          | 5   |
| Control Operations                                                   | 5   |
| Control Data                                                         | 7   |
| Set Event Extensions                                                 | 12  |
| API Commands                                                         | 13  |
| <pre>void nx_ClearEvent (nxt_Handle * handle, const int eid)</pre>   | 13  |
| nxt_Status nx_Close (nxt_Handle * handle)                            | 14  |
| nxt_Status nx_Control (nxt_Handle * handle, nxt_CtrlData ctrl) .     | 14  |
| nxt_Status nx_GetEvent (nxt_Handle * handle, nxt_ReceivedEven        | t * |
| event, int maxBytes, const int block)                                | 15  |
| nxt_Status nx_GetLastError (nxt_Handle * handle, char * lastError    |     |
| maxBytes)                                                            | 16  |
| <pre>nxt_Handle* nx_Open (const nxt_TargetSpec * tSpec, void(*</pre> |     |
| errorCallback)(const char *), nxt_Status * status)                   | 17  |

RM004502-0506 Table of Contents



| nxt_Status nx_ReadMem (nxt_Handle * handle, const int map, const int         | t |
|------------------------------------------------------------------------------|---|
| accessPriority, const nxvt_Address addr, const size_t numBytes,              |   |
| const int accessSize, void ** bytesRead) 1                                   | 7 |
| <pre>nxt_Status nx_SetEvent (nxt_Handle * handle, const nxt_SetEvent *</pre> |   |
| setEvent)                                                                    |   |
| nxt_Status nx_WriteMem (nxt_Handle * handle, const int map, const int        | t |
| accessPriority, const nxvt_Address addr, const size_t numBytes,              | _ |
| const int accessSize, const void * bytesToWrite)                             | 9 |
| Appendix                                                                     | 1 |
| Glossary                                                                     | 1 |
| Nexus Vendor Extensions Reference                                            | 1 |
| Defines                                                                      | 1 |
| Typedefs                                                                     | 3 |
| Enumerations                                                                 | 3 |
| Structures                                                                   | 8 |
| nxvt_ExtProgramErase                                                         | 0 |
| nxvt ExtProgramSet                                                           |   |
| nxvt_TargetConfiguration                                                     |   |
| nxvt IntProgramErase                                                         |   |
| nxvt IntProgramSet                                                           |   |
| nxvt Registers                                                               |   |
| nxvt VendorDefinedCtrlData                                                   |   |
| nxvt VendorDefinedTargetSpec                                                 |   |
| nxvt_VendorDefinedBasicSetEvent                                              |   |
| Standard Registers Access                                                    |   |
| Z8 Encore!                                                                   |   |
| eZ80Acclaim!                                                                 |   |
| ZNEO 50                                                                      |   |
|                                                                              |   |

Table of Contents RM004502-0506

# Nexus Interface API Reference Manual



#### v

# List of Tables

| Table 1. | Vendor-Specific Target Event Types                  | .4 |
|----------|-----------------------------------------------------|----|
| Table 2. | Nexus API Vendor-Specific Control Operations        | .6 |
| Table 3. | NXV_CTRL_GET_REGISTER Index Values for Z8 Encore!   | 47 |
| Table 4. | NXV_CTRL_GET_REGISTER Index Values for eZ80Acclaim! | 49 |
| Table 5. | NXV_CTRL_GET_REGISTER Index Values for ZNEO         | 50 |

RM004502-0506 List of Tables

# Nexus Interface API Reference Manual



List of Tables RM004502-0506

# Introduction

The Nexus Forum 5001 standard is an open industry standard that provides a general-purpose interface for the software development and debugging of embedded processors.

The Nexus API defines two layers of abstraction: Target Abstraction Layer (TAL) and Hardware Abstraction Layer (HAL). The TAL provides an implementation of the Nexus debug semantics, using the underlying target's on-chip debug hardware. The HAL is the underlying layer that communicates with the target system.

Tools are built on top of the TAL, which is also referred to as the Nexus API. As a general rule, the Nexus API only provides facilities to access the debug hardware features and does not implement functionality that is normally provided in the tool vendor's higher-level APIs. For example, the Nexus API provides facilities to run and single step one instruction. It is up to the tool vendor to provide source level single step, step over, and step out.

In order to allow for processor specific features, the Nexus standard allows vendor-defined extensions in terms of

- Vendor-defined extensions to standard Nexus operations
- Additional vendor-defined operations
- Additional vendor-defined information in messages

In addition, basic data types associated with addresses, target data and registers are also defined through vendor extensions.

This document defines vendor-specific extensions used in the ZiLOG implementation of the IEEE ISTO-5001 Nexus Standard TAL.

The IEEE ISTO-5001 Nexus Standard is available from the IEEE ISTO organization at <a href="http://www.nexus5001.org">http://www.nexus5001.org</a>.



In the context of this document, the term vendor refers to ZiLOG.

**Note:** Support for Z8 components is not provided in this release. References to Z8 components in Nexus headers are preliminary.

#### **Conventions**

The following assumptions and conventions are adopted to provide clarity and ease of use:

## **Courier Typeface**

Commands, code lines and fragments, bits, equations, hexadecimal addresses, and various executable items are distinguished from general text by the use of the Courier typeface.

#### **Hexadecimal Values**

Hexadecimal values are designated by a lowercase h and appear in the Courier typeface.

• Example: STAT is set to F8h.

#### **Asterisks**

An asterisk preceding a parameter denotes the parameter as a pointer.

## **Trademarks**

eZ80<sup>®</sup>, Z8 Encore!<sup>®</sup>, and eZ80Acclaim!<sup>®</sup> are registered trademarks of ZiLOG, Inc. ZNEO<sup>TM</sup> is a trademark of ZiLOG, Inc.

#### **Online Information**

Please visit **ZiLOG's website** for:

- Product information for Z8 Encore!®, eZ80Acclaim!®, and ZNEO<sup>TM</sup> microprocessors and microcontrollers.
- Online copies of Z8 Encore!<sup>®</sup>, eZ80Acclaim!<sup>®</sup>, and ZNEO<sup>TM</sup> documentation

Introduction RM004502-0506

3

# **Implementation**

The ZiLOG Nexus API extends the standard Nexus API by providing the necessary vendor extensions to support ZiLOG part families, debug communication tools and emulators.

The following ZiLOG debug tools are currently supported by the ZiLOG Nexus API:

- Ethernet Smart Cable
- USB Smart Cable
- ZPAKII
- Serial Smart Cable

# **Vendor Extensions**

The Nexus API uses vendor defined data types, either embedded in standard Nexus data structures or passed directly in to Nexus API functions. Refer to the appendix for a detailed reference of ZiLOG's vendor extension data types.

# **Naming Conventions**

Per the Nexus API specification, the following naming conventions are used for ZiLOG's vendor extensions:

- Data types are prefixed with "nxvt".
- Constants are prefixed with "NXV\_".

# **Target Address**

The type nxvt\_Address, which specifies a target address, is defined as an unsigned long based on the requirement to support addresses up to 32

RM004502-0506 Vendor Extensions



bits. nxvt\_Address is used for setting up events triggered by an address, such as execution breakpoints. nxvt\_Address is also used by nx ReadMem and nx WriteMem for memory access.

# **Target Word**

The type nxvt\_Word, which specifies a target word, is defined as an unsigned long based on the requirement to support 32-bit register values. nxvt Word is used for setting data-triggered breakpoints and events.

# **Target Registers**

The type nxvt\_Registers specifies target register format. Since the format of the registers is processor-dependent, this is defined simply as a buffer to hold the processor's standard register set.

nxvt\_Registers is included in the structure that holds received events. The nxvt\_Registers type is also used by the control operations NX\_CTRL\_RESTART\_FROM\_BREAKSTEP and NXV\_CTRL\_GET\_REGISTERS\_ALL.

# **Target Events**

The Nexus API defines event types for break and step. These are supplemented by the event types listed in Table 1. Note that these events are read-only and are therefore prefixed with NXV\_READ\_EVENT in order to distinguish them from settable events, such as breakpoints.

 Table 1. Vendor-Specific Target Event Types

| Event Type               | Description                                        |
|--------------------------|----------------------------------------------------|
| NXV_READ_EVENT_HALT_SLP  | Target has entered halt or lower power sleep mode. |
| NXV_READ_EVENT_EXT_RESET | Target reset has been detected.                    |

**Table 1. Vendor-Specific Target Event Types** 

| Event Type                       | Description                                                       |
|----------------------------------|-------------------------------------------------------------------|
| NXV_READ_EVENT_POWER_LOSS        | Target power loss has been detected                               |
| NXV_READ_EVENT_CONNECTION_CLOSED | Target connection has been closed.                                |
| NXV_READ_EVENT_BREAK_TRACEFULL   | Target has ceased execution due to a trace buffer full condition. |
| NXV_READ_EVENT_BREAK_EVENT       | Target has ceased execution due to an event system match.         |

# **Target Spec**

The nxvt\_VendorDefinedTargetSpec structure contains vendor-specific information required to establish a connection with a target. nxvt\_VendorDefinedTargetSpec is embedded within the nxt\_TargetSpec structure that is passed to nx\_Open.

nxvt\_VendorDefinedTargetSpec contains the following members:

- pOpenParameters String containing target or implementation specific parameters needed during a communication session.
- comminfo Structure that contains the type of communication method to use between host and target, with associated parameters.

# **Control Operations**

The Nexus API function nx\_Control provides general purpose target control. The Nexus specification defines a set of standard control operations while enabling vendors to define processor-specific control operations that extend functionality.

RM004502-0506 Vendor Extensions



Table 2 lists the ZiLOG Nexus API vendor-specific control operations.

**Table 2. Nexus API Vendor-Specific Control Operations** 

| Operation Type                                            | Description                                                                                       |
|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------|
| NXV_CTRL_CANCEL                                           | Cancel an operation in progress.                                                                  |
| NXV_CTRL_CRC_MEMORY                                       | Calculate CRC over a range of memory.                                                             |
| NXV_CTRL_ERASE_EXT_PROGRAM                                | Erase external program flash memory.                                                              |
| NXV_CTRL_ERASE_INT_PROGRAM                                | Erase internal program flash memory.                                                              |
| NXV_CTRL_GET_REGISTER                                     | Get the value of a standard or on-<br>chip peripheral register.                                   |
| NXV_CTRL_GET_REGISTERS_ALL                                | Get all standard registers.                                                                       |
| NXV_CTRL_GET_TARGET_STATUS                                | Get the target status (running, halted, etc).                                                     |
| NXV_CTRL_GET_TRACE                                        | Retrieve trace frame.                                                                             |
| NXV_CTRL_INITIALIZE_TARGET                                | Initialize the target debug session.                                                              |
| NXV_CTRL_OTP_CONFIGURE                                    | Configure OTP EPROM                                                                               |
| NXV_CTRL_OTP_CONTROL                                      | Perform an OTP control operation (read, burn, blank check, etc.).                                 |
| NXV_CTRL_SET_EXT_PROGRAM Program external program memory. | Write a value to a standard or on-<br>chip peripheral register.                                   |
| NXV_CTRL_SET_INT_PROGRAM                                  | Program internal program memory. This may be flash RAM, OTP or other, depending on the processor. |

Table 2. Nexus API Vendor-Specific Control Operations

| Operation Type             | Description                                                                                         |
|----------------------------|-----------------------------------------------------------------------------------------------------|
| NXV_CTRL_SET_REGISTER      | Write a value to a standard or on-<br>chip peripheral register.                                     |
| NXV_CTRL_SET_ZDI_FREQUENCY | Set the debug frequency.                                                                            |
| NXV_CTRL_TRACE_CONTROL     | Trace control and configuration.                                                                    |
| NXV_CTRL_UPGRADE_FIRMWARE  | Upgrade debug tool firmware. Currently supported only for USB Smart Cable and Ethernet Smart Cable. |

#### **Control Data**

nxvt\_VendorDefinedCtrlData is defined as a union of structures, each of which contains the parameters for a given vendor-specific Control Operation. nxvt\_VendorDefinedCtrlData is a member of the nxt\_CtrlData structure.

The nxt\_CtrlData structure is passed in by value to nx\_Control. Therefore any data to be returned to the caller must be done through the use of pointer data types within nxvt VendorDefinedCtrlData.

nxvt\_VendorDefinedCtrlData contains the structures listed in the following sections.

setRegister. setRegister contains parameters for
NXV\_CTRL\_SET\_REGISTER. It contains the following members:

- type Indicates whether register is a standard register, on-chip peripheral register, or other.
- address Register index for standard registers, or address for peripheral register.
- value The value to write.

RM004502-0506 Vendor Extensions



getRegister. getRegister contains parameters for
NXV CTRL GET REGISTER. It contains the following members:

- type Indicates whether register is a standard register, on-chip peripheral register, or other.
- address Register index for standard registers, or address for peripheral register.
- pValue Pointer to a long in which to store for the value read.

getRegistersAll. setRegistersAll is used with NXV\_CTRL\_GET\_REGISTERS\_ALL. It contains a pointer to nxvt Registers type to store the standard register values returned.

getTargetStatus. getTargetStatus is used with
NXV\_CTRL\_GET\_TARGET\_STATUS. It contains a pointer to an
nxvt TargetStatusType to hold the returned target status.

initializeTarget. initializeTarget is used with NXV\_CTRL\_INITIALIZE\_TARGET. It contains a pointer to a structure containing information about the target configuration that is used to initialize a debug session. The NXV\_CTRL\_INITIALIZE\_TARGET command is normally sent immediately after calling nx\_open in order to establish and initialize the connection to the target.

**setIntProgram.** setIntProgram is used by NXV\_CTRL\_SET\_INT\_PROGRAM, which is used to program internal flash or OTP memory. It contains the following members:

- infoPage Indicates whether to program the flash info page or normal program memory.
- address The starting address.
- pData Pointer to a buffer containing the data to program.
- numberOfBytes Size of the data in bytes.



eraseIntProgram. erasetIntProgram is used by NXV\_CTRL\_ERASE\_INT\_PROGRAM, which is used to erase internal flash memory. It contains the following members:

- startPage The page to start erase.
- numberOfPages Number of pages to erase.

eraseExtProgram. eraseExtProgram is used by NXV\_CTRL\_ERASE\_EXT\_PROGRAM, which is used to erase external flash memory. It contains the following members:

- byData Indicates whether the erase algorithm sequence consists of data only, or both addresses and data.
- pBlockAddressList List of the first address of each block or sector to erase.
- numberOfBlocks Number of blocks to erase.
- pDataEraseSeq The sequence of bytes to erase a block.
- pAddrEraseSeq Sequence of addresses at which to write erase sequence values (used only if byData is zero).
- segSize Size of erase sequence.
- verifyValue Status value that indicates erase is complete.
- verifyMask Mask value to AND with status value before comparing to verifyValue.

# setExtProgram. setExtProgram is used by

NXV\_CTRL\_SET\_EXT\_PROGRAM, which is used to program external flash or other type of non-volatile memory. It contains the following members:

• byData – Indicates type of programming algorithm to use. If non-zero, the programming sequence consists of writing a sequence of bytes to the address to be written. If zero, the programming algorithm consists of an address/data sequence to unlock the memory, followed by data writes.

RM004502-0506 Vendor Extensions



- address Address to start programming.
- pData The program data.
- numberOfBytes Size of data, in bytes.
- pwriteSeq Write sequence (used if byData is nonzero).
- pDataUnlockSeq Unlock sequence data (used if byData is zero).
- pAddrUnlockSeq Unlock sequence addresses (used if byData is zero).
- seqSize Size of write or unlock sequence.
- verifyValue Status value that indicates erase is complete.
- verifyMask Mask value to AND with status value before comparing to verifyValue.

upgradeFirmware. upgradeFirmware is used by
NXV\_CTRL\_UPGRADE\_FIRMWARE, which is used to update the debug tool
firmware. It contains the following members:

- pFirmware Binary firmware image.
- size Size of firmware image in bytes.

**getTrace.** getTrace is used by NXV\_CTRL\_GET\_TRACE, which is used to upload a block of trace frames from the debugger. It contains the following members:

- offset Offset of first frame to retrieve, relative to the oldest frame in the buffer.
- numberOfFrames Number of frames to retrieve. May be zero if caller wishes only to query number of available frames.
- pBuffer Buffer to hold the trace frames. May be NULL if numberOfFrames is zero.
- pAvailable (optional) Set to total number of frames available upon successful return.



traceControl. traceControl is an enumerated type used by NXV\_CTRL\_TRACE\_CONTROL, which is used to configure and control trace features. traceControl specifies an operation to perform, such as reset trace system, reset trace buffer, and enable break on trace full.

setZdiFrequency. setZdiFrequency is used by NXV\_CTRL\_SET\_ZDI\_FREQUENCY, which is used to set the debugger Frequency for eZ80Acclaim! It contains the following members:

- frequency Desired frequency, in hertz.
- tableSelect Selects which frequency table to use, with zero being the default. Set this to one to use the alternate frequency table.

**otpConfigure.** otpConfigure is used by NXV\_CTRL\_OTP\_CONFIGURE, which is used to set OTP EPROM configuration options. It contains the following members:

- optionSize Size of option data, in bytes.
- optionData The option data.
- optionMask Mask for option data.
- algoSize Size of the algorithm, if included. Algorithm information is optional. Set to zero if pAlgoData not set.
- pAlgoData Pointer to a character array containing an algorithm.
   Algorithm information is optional. Set to zero if no algorithm provided.

**otpControl.** otpControl contains parameters for NXV\_CTRL\_OTP\_CONTROL, which is used to perform OTP operations. It contains the following members:

operation - Indicates the type of OTP operation to be performed.
 Set to one of NXV\_OTP\_CTRL\_BLANK\_CHECK,
 NXV\_OTP\_CTRL\_WRITE, NXV\_OTP\_CTRL\_READ,
 NXV OTP CTRL VERIFY, or NXV OTP CTRL READ OPTIONS.

RM004502-0506 Vendor Extensions



• param - Operation-specific data. Currently used only with NXV\_OTP\_CTRL\_READ\_OPTIONS as a pointer to an unsigned long value to store the option data read.

**crcMemory.** crcMemory contains parameters used by NXV\_CTRL\_CRC\_MEMORY.

crcMemory is currently supported only for Z8 Encore! and ZNeo.

- address Address at which to begin CRC calculation. This is used only for ZNEO and must be aligned to 4KB boundary. The address parameter is ignored for Z8 Encore!, which always starts CRC from address zero.
- numBytes Number of bytes to CRC. numBytes is used only for ZNEO, and must e a multiple of 4096. The numBytes parameter is ignored for Z8 Encore!, which performs CRC on entire range of internal flash memory.
- pcrc Pointer to CRC value returned.

#### **Set Event Extensions**

The nxvt\_VendorDefinedExtensionSetEvent and nxvt\_VendorDefinedBasicSetEvent types are intended to be used to support event features not provided for in the standard Nexus API event types.

nxvt\_VendorDefinedBasicSetEvent is used to support ZiLOG emulator advanced break and event capabilities that support features beyond simple breakpoints, such as starting and stopping trace on an event trigger. The nxvt\_VendorDefinedBasicSetEvent structure contains event data which defines the event trigger, a data mask to mask off don't care bits in the event data, and an enumerated type nxvt\_EventAction that defines the action to take. The event trigger data format is processor-specific. At minimum it consists of status flags, data, and address.

nxvt\_VendorDefinedExtensionSetEvent is currently not used, and is simply typedef'ed as an int.

# **API Commands**

This section lists the Nexus API commands implemented by ZiLOG.

# void nx ClearEvent (nxt Handle \* handle, const int eid)

The nx\_ClearEvent function clears a debug event previously set with nx SetEvent.

Only execution breakpoint events are supported by the on-chip debug capability embedded in the processors. The Z8Encore! emulator has richer event capabilities, including support for access and data breakpoints, in addition to execution breakpoints.

The eid value must be a value between breakMinEventId and break-MaxEventId, inclusive. breakMinEventId and breakMaxEventId are members of the nxt\_Capability structure in the handle returned from nx\_Open. Note that nx\_ClearEvent does not return a status, so there is no error feedback if the event ID value is out of range or has no active event associated with it.

#### Preconditions:

- handle identifies an active Nexus session. It is returned is from a successful invocation of nx Open.
- eid is the ID of an event previously set up with nx\_SetEvent.

Postconditions: Once this function completes, the specified event will be disabled

Note that target processor execution must be suspended in order to clear breakpoint events.

RM004502-0506 API Commands



# nxt Status nx Close (nxt Handle \* handle)

nx\_Close terminates an open connection to a target. An attempt to close a connection that is not open will return NX ERROR FAILED.

Preconditions: Handle is from successful invocation of nx Open.

#### Postconditions:

- Closes the connection and deallocates the resources allocated for the Nexus session.
- Returned status indicates whether the close was successful.

# nxt Status nx Control (nxt Handle \* handle, nxt CtrlData ctrl)

nx\_Control is used for non-event related target control, such as run, stop, and go. Trace features are also implemented through nx\_Control.

#### Preconditions:

- handle is from a successful invocation of nx\_Open.
- ctrl specifies the control operation to apply.

Postconditions: If successful, returns NX\_ERROR\_NONE; otherwise may invoke the error callback installed with nx\_Open, then returns NX\_ERROR\_FAILED or NX\_ERROR\_NO\_CAPABILITY

The following control operations are currently supported:

- NX\_CTRL\_RESETORHALT Put processor in reset, resume execution from current PC, or stop execution.
- NX\_CTRL\_CLIENTBREAK Enable or disable breakpoints.
- NX\_CTRL\_RESTART\_FROM\_BREAKSTEP Restart from a previous breakpoint.

In addition to the standard Nexus operations listed above, several vendorspecific operations are also supported. Refer to Table 2 for a list of vendor-specific operations.

# nxt\_Status nx\_GetEvent (nxt\_Handle \* handle, nxt\_ReceivedEvent \* event, int maxBytes, const int block)

The nx\_GetEvent function is used to read read a target event. Events are generated when target execution is suspended, such as in single step, or halted due to a due to a breakpoint previously set with nx\_SetEvent. The received event data for single step and breakpoints includes an nxvt\_Registers structure that contains the target's register state at the time of the event.

Vendor specific events are generated upon detection of processor entering halt mode, external reset, and target power loss. There is no additional data associated with these events.

For eZ80Acclaim! family processors, once the processor enters halt mode it no longer responds to debug commands and therefore requires a reset command to be issued via nx\_Control to re-enter debug mode. This is not the case for Z8 Encore! and ZNEO family processors.

#### Preconditions:

- handle is a from a successful invocation of nx\_Open.
- event is a pointer to a block of memory to receive the event.
- maxBytes is set by the caller to indicate the number of bytes that can be received in the event block of memory.
- block specifies whether this function will block until an event is available from the target.

Postconditions: If no event is available, NX\_ERROR\_FAILED is returned. If an event is available, the event data is written to the event buffer passed in, and NX ERROR NONE is returned.

If the connection to the target is closed while a caller is blocked innx\_GetEvent, nx\_GetEvent will return event NXV\_READ\_EVENT\_CONNECTION\_CLOSED.

RM004502-0506 API Commands



The following receive event types are supported. Those with the NXV\_prefix are ZiLOG vendor extensions.

- NX BREAK STEP
- NXV READ EVENT HALT SLP
- NXV READ EVENT EXT RESET
- NXV READ EVENT POWER LOSS
- NXV READ EVENT CONNECTION CLOSED
- NXV READ EVENT TRACEFULL
- NXV READ EVENT BREAK EVENT

# nxt\_Status nx\_GetLastError (nxt\_Handle \* handle, char \* lastError, int maxBytes)

The nx\_GetLastError function returns error/status code from most recent nexus API call, and optionally a message containing details for the error. This API was not included in the nx\_api.h from IEEE ISTO but is mentioned in the Nexus Standard as an optional feature that can be used as an alternative to the error callback mechanism.

#### Preconditions:

- handle is a from a successful invocation of nx Open.
- lastError event is a pointer to a block of memory to receive message. May be set to NULL if caller is only interested in the actual status code.
- maxBytes is set by the caller to indicate the number of bytes that can be received in the block of memory.

Postconditions: Returns Nexus error/status code from last Nexus API call

# nxt\_Handle\* nx\_Open (const nxt\_TargetSpec \* tSpec, void(\* errorCallback)(const char \*), nxt Status \* status)

The nx Open function opens a Nexus debug session.

#### Preconditions:

- tSpec specifies the target setup (byte ordering and port type). It also contains the vendor defined nxvt\_VenderDefinedTargetSpec which contains parameters necessary to establish communication between the host and the target.
- errorCallback is a callback function which may be invoked when errors occur. It may be set to NULL to prevent callbacks.

Postconditions: If successful, a handle is returned and status is set to NX\_ERROR\_NONE. If fails, NULL is returned, and status is set to NX\_ERROR\_NO\_CAPABILITY.

The nxt\_Handle structure contains an nxt\_Capability structure. The nxt\_Capability structure is filled out according to the processor's capabilities upon successful open. The nxt\_Capability structure contains number of breakpoints and memory spaces supported, the Nexus API version and build version, and the debugger firmware version. The nxt Handle type also contains a copy of tSpec.

# nxt\_Status nx\_ReadMem (nxt\_Handle \* handle, const int map, const int accessPriority, const nxvt\_Address addr, const size\_t numBytes, const int accessSize, void \*\* bytesRead)

The nx ReadMem function reads from target memory.

#### Preconditions:

- handle from a successful invocation of nx\_Open.
- map specifies a memory map or space (not used for ZNEO).
- accessPriority specifies bus priority.

RM004502-0506 API Commands



- address is the address to read from.
- numBytes is used to specify how many bytes to read.
- accessSize is used to specify the byte access size to be used during the data transfer
- bytesRead points to where the data should be stored.

Postconditions: If successful, returns NX\_ERROR\_NONE and bytesRead points to the data read from the target's memory. If fails, may invoke the error callback installed with nx Open, then returns NX ERROR FAILED.

AccessPriority and accessSize are not currently used by the ZiLOG Nexus API and are ignored. The map parameter specifies the address space. A set of defines with the prefix NXV\_ADDR\_SPACE\_ are defined in nxvtypes.h for this parameter.

Note that target execution must be suspended in order to read target memory.

# nxt\_Status nx\_SetEvent (nxt\_Handle \* handle, const nxt\_SetEvent \* setEvent)

Set a breakpoints or single-step event.

#### Preconditions:

- handle is from a successful invocation of nx\_Open.
- setEvent defines the event to set. It is used with breakpoint events, but not single step events.

Postconditions: If successful, returns NX\_ERROR\_NONE else may invoke the error callback installed with nx\_Open, then returns NX ERROR FAILED or NX ERROR NO CAPABILITY.

The following event types are supported for all ZiLOG processors:

NX\_ETYPE\_STEP

• NX\_ETYPE\_BREAKPOINT with breakpoint.op set to NX\_BREAKPOINT\_INSTRADDR

The following event types are additionally be supported for emulators:

- NX\_ETYPE\_BREAKPOINT with breakpoint.op set to
   NX\_BREAKPOINT\_DATA\_ADDR, NX\_BREAKPOINT\_DATAVALUE, or
   NX\_BREAKPOINTDATAADDR\_AND\_DATAVALUE
- NX\_ETYPE\_BREAKPOINT with breakpoint.op set to NXV BREAKPOINT TRACEFULL
- NXV ETYPE EVENT

# nxt\_Status nx\_WriteMem (nxt\_Handle \* handle, const int map, const int accessPriority, const nxvt\_Address addr, const size\_t numBytes, const int accessSize, const void \* bytesToWrite)

Write to target memory.

#### Preconditions:

- handle from a successful invocation of nx\_Open.
- map specifies a memory map or address space (not used for ZNEO).
- accessPriority specifies bus priority (not used).
- addr is the address to write to.
- numBytes is used to specify how many bytes to write.
- accessSize is used to specify the byte access size to be used during the data transfer.
- bytesToWrite is a pointer to the data to write.

Postconditions: If successful, returns NX\_ERROR\_NONE and writes specifies data to the target's memory. Otherwise may invoke the error callback installed with nx Open, then returns NX ERROR FAILED.

RM004502-0506 API Commands



accessPriority and accessSize are not currently used by the Nexus API and are ignored. The map parameter specifies the address space. A set of defines with the prefix NXV\_ADDR\_SPACE\_ are defined in nxv-types.h for the map parameter.

# Appendix

# Glossary

TAL – Nexus Target Abstraction Layer (Nexus API)

HAL – Nexus Hardware Abstraction Layer

API - Application Programming Interface

ICE – In-circuit Emulator

DTL – Data Transfer Language. Communication language used between the host PC and a debug tool.

Nexus – IEEE ISTO-5001 Standard

eZ80 - ZiLOG Acclaim! Family processor

eZ8 - ZiLOG Encore! Family processor

ZNEO – ZiLOG ZNEO family processor

# **Nexus Vendor Extensions Reference**

#### **Defines**

```
#define NXV_ADDR_SPACE_eZ8_ROM 0
#define NXV_ADDR_SPACE_eZ8_XRAM 1
#define NXV_ADDR_SPACE_eZ8_RDATA 2
#define NXV_ADDR_SPACE_eZ8_EDATA 3
#define NXV_ADDR_SPACE_eZ8_NVDS 4
#define NX_ADDR_SPACE_eZ8_PRAM 5
#define NXV_ADDR_SPACE_eZ8_PRAM 0
```



```
#define NXV ADDR SPACE eZ80 ROM 1
#define NXV ADDR SPACE eZ80 EXTIO 2
#define NXV ADDR SPACE eZ80 INTIO 3
#define NXV ADDR SPACE eZ80 FLASHINFO 4
Note: ZNeo processor has a single unified memory
space, so there are no defined address spaces.
#define NXV REGISTER STANDARD (0)
#define NXV REGISTER PERIPHERAL (1)
#define NXV CTRL SET REGISTER (0x101)
#define NXV CTRL GET REGISTER (0x102)
#define NXV CTRL GET REGISTERS ALL (0x103)
#define NXV CTRL INITIALIZE TARGET (0x104)
#define NXV CTRL GET TARGET STATUS (0x105)
#define NXV CTRL ERASE INT PROGRAM (0x106)
#define NXV CTRL SET INT PROGRAM (0x107)
#define NXV CTRL ERASE EXT PROGRAM (0x108)
#define NXV CTRL SET EXT PROGRAM (0x109)
#define NXV CTRL UPGRADE FIRMWARE (0x10A)
#define NXV CTRL GET TRACE (0x10B)
#define NXV CTRL TRACE CONTROL (0x10C)
#define NXV CTRL SET ZDI FREQUENCY (0x10D)
#define NXV CTRL CANCEL (0x10E)
#define NXV CTRL OTP CONFIGURE (0x11F)
#define NXV CTRL OTP CONTROL (0x110)
#define NXV CTRL CRC MEMORY (0x111)
```

Appendix RM004502-0506



```
#define NXV_READ_EVENT_HALT_SLP 0x100
#define NXV_READ_EVENT_EXT_RESET 0x101
#define NXV_READ_EVENT_POWER_LOSS 0x102
#define NXV_READ_EVENT_CONNECTION_CLOSED 0x103
#define NXV_READ_EVENT_TRACEFULL 0x104
#define NXV_READ_EVENT_BREAK_EVENT 0x105
#define NXV_ETYPE_EVENT 0x100
#define NXV_BREAKPOINT TRACEFULL 0x100
```

# **Typedefs**

Types used for target addresses and data in Nexus data structures and API:

```
typedef unsigned long nxvt_Address
typedef unsigned long nxvt Word
```

NXV\_TARGET\_STATUS\_DEBUG, NXV TARGET STATUS HALT SLP,

#### **Enumerations**

#### nxvt TargetStatus

```
The nxvt_TargetStatus enumeration type represents the target status. It is used for status values returned from NXV_CTRL_GET_TARGET_STATUS control command. typedef enum {

NXV_TARGET_STATUS_NOT_CONNECTED,

NXV_TARGET_STATUS_IN_RESET,

NXV_TARGET_STATUS_RUNNING,
```



```
NXV_TARGET_STATUS_OCD_DISABLED,
    NXV_TARGET_STATUS_UNKNOWN
} nxvt TargetStatus;
```

**NXV\_TARGET\_STATUS\_NOT\_CONNECTED.** Indicates communication between the host PC and debug tool has not been established, or the connection has been closed.

**NXV\_TARGET\_STATUS\_IN\_RESET.** Indicates the target has been reset by an external source. When a reset is detected, a reset command must be issued from Nexus to re-synchronize communication with target. Alternatively, the connection may be closed and re-opened.

NXV\_TARGET\_STATUS\_RUNNING. The target CPU is running.

**NXV\_TARGET\_STATUS\_DEBUG.** The target CPU execution has been suspended. Debug commands such as reading and writing memory and registers are only allowed in this mode.

**NXV\_TARGET\_STATUS\_HALT\_SLP.** The target CPU is running in low power mode due to execution of a HALT or STOP instruction.

NXV\_TARGET\_STATUS\_OCD\_DISABLE. The on-chip debug (OCD) capability has been disabled. OCD capability is disabled by clearing certain option bits in the internal flash memory. Re-enabling the OCD usually requires mass-erase of the internal flash memory, which resets the option bits to ones. Applicable to ZNEO and Z8 Encore! only.

**NXV\_TARGET\_STATUS\_UNKNOWN.** Indicates the target status cannot be determined. This may be due to communication problem between the host PC and debug tool, or between the debug tool and the target CPU.

## nxvt\_EventAction

The nxvt\_EventAction enumeration type specifies the action to take when an event is triggered. They may be ORed together when multiple actions are needed.

Appendix RM004502-0506

nxvt\_EventAction values are used with NXV\_SET\_EVENT to define the action to take when the event is trigger. Only Z8 Encore! emulators support these complex events.

```
typedef enum
{
    NXV_EVENT_ACTION_NONE = 0,
    NXV_EVENT_ACTION_BREAK = 1,
    NXV_EVENT_ACTION_TRACE_START = 2,
    NXV_EVENT_ACTION_TRACE_STOP = 4,
    NXV_EVENT_ACTION_TRACE_WHILE = 8,
    NXV_EVENT_ACTION_EVENT_IN = 0x10,
    NXV_EVENT_ACTION_EVENT_OUT = 0x20,
    NXV_EVENT_ACTION_EVENT_OUT_PULSE = 0x40,
    NXV_EVENT_ACTION_ARM_NEXT_EVENT = 0x80
} nxvt_EventAction;
```

**NXV\_EVENT\_ACTION\_NONE.** Indicates that no action is to be taken. This effectively disables an event.

**NXV\_EVENT\_ACTION\_BREAK.** Suspend target execution when an event is triggered.

**NXV\_EVENT\_ACTION\_TRACE\_START.** Start capturing trace frames when event is triggered.

**NXV\_EVENT\_ACTION\_TRACE\_STOP.** Stop capturing trace frames when event is triggered.

NXV\_EVENT\_ACTION\_TRACE\_WHILE. Capture trace frames as long as the event is active.

**NXV\_EVENT\_ACTION\_EVENT\_IN.** Event action is taken only if the input trigger is active when an event match occurs.

NXV\_EVENT\_ACTION\_EVENT\_OUT. Generate an output signal when event is triggered. the output signal level is pulsed if NXV\_EVENT\_ACTION\_EVENT\_OUT\_PULSE is set. Otherwise, the signal level is toggled.



NXV\_EVENT\_ACTION\_EVENT\_OUT\_PULSE. Pulse the output when event is triggered. Applicable only if NXV\_EVENT\_ACTION\_EVENT\_OUT is also set.

**NXV\_EVENT\_ARM\_NEXT\_EVENT.** Arm the next event when event is triggered. the next event is the identified by the current event ID plus one. For example, if event 2 is triggered, then event 3 would be armed if this action is set for event 2.

## nxvt\_CommType

The nxvt\_CommType enumeration type specifies the communication protocols used between host PC and target debug tool:

```
typedef enum
{
NXV_COMM_TYPE_ETHERNET = 0,
NXV_COMM_TYPE_SERIAL = 1,
NXV_COMM_TYPE_PARALLEL = 2,
NXV_COMM_TYPE_USB = 3
} nxvt CommType;
```

NXV\_COM\_TYPE\_ETHERNET. Host PC is connected to debug tool through a TCP/IP Ethernet connection. This type of communication is used with the ZiLOG ZPAKII and Ethernet Smart Cable.

**NXV\_COM\_TYPE\_SERIAL.** Host PC is connected to a debug tool through the serial port.

**NXV\_COM\_TYPE\_PARALLEL.** Host PC is connected via parallel port. Currently not supported by any ZiLOG debug tools.

**NXV\_COM\_TYPE\_USB.** Host PC is connected to a debug tool on USB. This is used with the ZiLOG USB Smart Cable.

# nxvt TargetRegisterType

The nxvt\_TargetRegisterType enumeration type specifies the type of register to read or write when used with the NXV\_CTRL\_GET\_REGISTER and NXV\_CTRL\_SET\_REGISTER commands

Appendix RM004502-0506

```
typedef enum
{
NXV_REGISTER_STANDARD, NXV_REGISTER_PERIPHERAL,
} nxvt TargetRegisterType;
```

**NXV\_REGISTER\_STANDARD.** Standard registers are internal processor registers, and include the program counter, stack pointer, flags, and general purpose data registers.

**NXV\_REGISTER\_PERIPHERAL.** Peripheral registers are used to control behavior of on-chip peripherals, such as UARTs, GPIO Ports, Timers, etc.

#### nxvt TraceControl

The nxvt\_TraceControl enumeration type is used with the NXV\_CTRL\_TRACE\_CONTROL operation to control the trace system. Only Z8 Encore! emulators currently support trace.

```
typedef enum
{
NXV_TRACE_CTRL_RESET_BUFFER,
NXV_TRACE_CTRL_RESET_SYSTEM,
NXV_TRACE_CTRL_ENABLE,
NXV_TRACE_CTRL_DISABLE,
NXV_TRACE_CTRL_ENABLE_BREAKONLIMIT,
NXV_TRACE_CTRL_DISABLE_BREAKONLIMIT
} nxvt_TraceControl;
```

NXV\_TRACE\_CTRL\_RESET\_BUFFER. Clear the trace buffer to zeroes and reset the trace write pointer to the beginning of the buffer.

NXV TRACE CTRL RESET SYSTEM. Reset trace system

NXV\_TRACE\_CTRL\_ENABLE. Enable trace capture.

**NXV\_TRACE\_CTRL\_DISABLE.** Disable trace capture. Note that for Z8 Encore! emulators, the trace system must be disabled in order to use complex events.

**NXV\_TRACE\_CTRL\_ENABLE\_BREAKONLIMIT.** Suspend target execution when trace buffer is full, or the number of frames captured reaches a predefined limit.



NXV\_TRACE\_CTRL\_DISABLE\_BREAKONLIMIT. Do not suspect target execution when trace buffer fills or reaches limit.

## nxvt\_OtpControl

```
The nxvt_OtpControl enumeration type is used with the NXV_CTRL_OTP_CONTROL operation to execute an OTP operation. typedef enum {
```

```
NXV_OTP_CTRL_BLANK_CHECK,
NXV_OTP_CTRL_READ,
NXV_OTP_CTRL_WRITE,
NXV_OTP_CTRL_VERIFY,
NXV_OTP_CTRL_READ_OPTIONS,
} nxvt OtpControl;
```

NXV OTP CTRL BLANK CHECK. Determine if OTP is blank

**NXV\_OTP\_CTRL\_READ.** Reads contents of OTP into emulator or OTP Programmer RAM.

**NXV\_OTP\_CTRL\_WRITE.** Writes contents of emulator or OTP Programmer RAM to OTP

**NXV\_OTP\_CTRL\_VERIFY.** Verifies contents of OTP against contents of emulator or OTP Programmer RAM.

NXV\_OTP\_CTRL\_READ\_OPTIONS. Read current OTP option settings

#### Structures

# nxvt\_CommInfo

The nxvt\_CommInfo structure contains information needed to establish a connection between the host and target. See nxvt VendorDefinedTargetSpec and nxvt TargetSpec.

```
typedef struct {
   nxvt_CommType type;
   union {
```

Appendix RM004502-0506

```
struct {
         unsigned char flowcontrol;
         unsigned char port;
         unsigned char parity;
         unsigned int baudrate;
         unsigned char databits;
         unsigned char stopbits;
      } serial;
      struct {
         char addr [16];
         int port;
      } ethernet;
       struct {
          char usbId [255];
       } usb;
   } u;
} nxvt CommInfo;
```

#### **Members**

type. Specifies the type of communication protocol to use. Valid values NXV\_COMM\_TYPE\_SERIAL, NXV\_COMM\_TYPE\_ETHERNET, or NXV\_COMM\_TYPE\_SERIAL

**serial.flowcontrol.** Non-zero value enables flow control for serial connection.

**serial.port.** COM port to user for serial connections. e.g., if using COM1 set to 1, for COM2 set to 2, etc.

**serial.parity.** Non-zero value enables parity checking for serial connection.

**serial.baudrate.** Bit rate to use for serial port. Typical values are 19200, 38400, 57600, and 115200.

**serial.databits.** Number of data bits per character for serial connection, usually set to 8.



**serial.stopbits.** Number of stop bits per character for serial connection, usually 1.

**ethernet.addr.** Null-terminated string containing the IP address to used for establishing an Ethernet connection, such as "168.192.1.50"

**ethernet.port.** TCP port number used with an ethernet connection.

**usb.usbId.** Vendor or implementation-specific string than uniquely identifies the usb device. If using ZiLOG USB Smart Cable driver, this is set to the USB Smart Cable serial number, which is embedded in the device descriptor. Sample code provided with the Nexus SDK shows how to get the serial number from a connected device

# nxvt ExtProgramErase

The nxvt\_ExtProgramErase structure contains external program memory erase parameters to use with NXV\_CTRL\_ERASE\_EXT\_PROGRAM control command.

```
typedef struct {
  int byData;
  const unsigned long * pBlockAddressList;
  unsigned numberOfBlocks;
  const unsigned char * pDataEraseSeq;
  const unsigned long * pAddrEraseSeq;
  int seqSize;
  int verifyValue;
  int verifyMask;
} nxvt ExtProgramErase;
```

## **Detailed Description**

Parameters to use with NXV\_CTRL\_ERASE\_EXT\_PROGRAM control command (eZ80 only).

if byData is true, the erase algorithm consists of writing a certain data sequence to the first address of each block to be erased, such as used with Micron MT series Q-Flash parts.

Appendix RM004502-0506

If byData is false, then the erase algorithm consists of writing specific data values to specific addresses in sequence. For example, a sequence may consist of writing 0xaa to address 0x555, 0x55 to address 0x2AA, etc., terminated by a write of the block or sector address to be erased. This type of algorithm is used for AMD, Atmel, and STMicro flash memory devices.

For example, to erase the first two sectors of AMD 29LV008B flash located at base address 0x100000, the parameters should be set as follows:

```
byData = false
pBlockAddressList = { 0x100000, 0x104000 }
numberOfBlocks = 2
pDataEraseSeq = { 0xAA, 0x55, 0x80, 0xAA, 0x55,
0x30 }
pAddrEraseSeq = {0x555,0x2AA,0x555,0x555,0x2AA, 0}
seqSize = 6
verifyValue = 0x80
verifyMask = 0x80
```

To erase two sectors of Micron MT28F008B located at address 0x100000, set parameters as follows:

```
byData = true
pBlockAddressList = { 0x100000, 0x104000 }
numberOfBlocks = 2
pDataEraseSeq = { 0x50, 0x20, 0xD0 }
seqSize = 3
verifyValue = 0x80
verifyMask = 0xF8
```

pAddrEraseSeq is not used in this case.

### Members

**byData.** Flag to indicate type of erase algorithm. A nonzero value indicates by-data erase algorithm.



**pBlockAddressList.** Array containing the start address of each block (or sector) to erase.

**numberOfBlocks.** Number of blocks to erase.

pDataEraseSeq. Array of bytes that define the erase sequence data.

**pAddrEraseSeq**. Array of addresses to write the erase sequence data to (used only if !byData).

eqSize. Size of erase sequence.

verifyValue. Status value that indicates erasure is complete.

**verifyMask.** Mask value to AND with status value to mask off don't care bits before comparing against verifyValue.

# nxvt\_ExtProgramSet

The nxvt\_ExtProgramSet structure contains external Program Memory programming parameters to use with

```
NXV_CTRL_SET_EXT_PROGRAM.
typedef struct {
   int byData;
   unsigned long address;
   const unsigned char * pData;
   unsigned numberOfBytes;
   const unsigned char * pWriteSeq;
   const unsigned char * pDataUnlockSeq;
   const unsigned long * pAddrUnlockSeq;
   int seqSize;
   int verifyValue;
   int verifyMask;
} nxvt ExtProgramSet;
```

## **Detailed Description**

if byData is true, the programming algorithm consists of writing one or more setup byte values to the address to be programmed, followed by the data.

If byData is false, the programming algorithm consists of unlocking the flash part by a sequence of writes of specific data values to specific addresses, followed by one or more data writes.

For example, to program 256 bytes of AMD AM29LV008B flash memory at address 0x100000, set the structure members as follows:

```
byData = false
address = 0x100000
pData = mydata, where mydata is a buffer containing
256 bytes of data
numberOfBytes = 256
pDataUnlockSeq = {0xAA, 0x55, 0xA0 }
pAddrUnlockSeq = { 0x555, 0x2AA, 0x555 }
seqSize = 3
verifyMask = 0xff
```

verifyValue is not used here – the verify value is the value written.

To program 256 bytes of Micron MT28F008B flash memory at address 0x100000, set the structure members as follows:

```
byData = true
address = 0x100000
pData = mydata, where mydata is a buffer containing
256 bytes of data
numberOfBytes = 256
pWriteSeq = { 0x50, 0x40 }
seqSize = 2
verifyValue = 0x80
verifyMask = 0xF8
note that pDataUnlockSeq and pAddrUnlockSeq are
not used here
```

#### Members

**byData.** Flag that indicates type of programming algorithm to use. Non-zero value indicates by-data programming algorithm.

address. Address at which to start programming.



```
pData. The data to write to the flash memory.
```

**numberOfBytes.** Size of data, in bytes.

**pWriteSeq.** Array containing the flash write sequence (if byData).

pDataUnlockSeq. Array containing the unlock sequence data (if !byData).

**pAddrUnlockSeq.** Array of addresses at which to write the unlock sequence data bytes (if !byData).

**seqSize.** Size of write sequence (if byData) or unlock sequence (if !byData).

verifyValue. Status value that indicates successful completion (if byData).

**verifyMask.** Mask value to AND with status value to mask off don't care bits before comparing against the verifyValue.

## nxvt TargetConfiguration

The nxvt\_TargetConfiguration structure contains target configuration parameters used to initialize the target for a debug session.

```
typedef struct {
  int size;
  char cpuName [32];
  int internalClock;
  unsigned long systemClockFreq;
  unsigned long targetClockFreg;
  unsigned long internal ROMSize;
  union {
      struct {
         unsigned char adl;
         unsigned long pc;
         unsigned long spl;
         unsigned long sps;
         int zdiAlternate:
         unsigned long flashLoaderRAM;
         unsigned long flashLoaderRAMSize;
         struct {
            unsigned char enable;
```

```
unsigned char enableEMAC;
      unsigned char page;
   } internalRAM;
   struct {
     unsigned char enable;
      unsigned char waitStates;
      unsigned char page;
   } internalFlash;
   struct {
      unsigned char lBound;
      unsigned char uBound;
      unsigned char control;
      unsigned char busMode;
   } chipSelects [4];
} eZ80
struct {
   int configTarget;
   int dac;
   int pinouts;
   int optBitsSize;
   struct {
      unsigned long address;
      unsigned char value;
   } optBits[128];
} eZ8;
struct {
   float targetVcc;
  unsigned long otpBitMask;
  unsigned long config;
   int fwImageIndex;
} z8;
struct {
    int externalBusSize;
   struct {
      unsigned char controlH;
      unsigned char controlL;
      unsigned char port;
```



```
chipSelects[6];
} zneo;
} u;
} nxvt_TargetConfiguration;
```

### **Detailed Description**

This structure is used by the NXV\_CTRL\_INITIALIZE\_TARGET control command. The data contained within is required to initialize the target to start a debug session.

Processor specific data members are defined in structures within a union.

The eZ80 structure contains information that is unique to eZ80Acclaim! family processors. Not all data is relevant to all processors. For example, if the processor has no internal Flash, the internalFlash specific data can be ignored.

The iceOptions structure is used only for Z8 Encore! emulators, and should be zeroed when connecting to "real" Z8 Encore! targets.

#### Members

size. The size of this structure in bytes.

**cpuName.** Null terminated string containing the CPU name, such as "eZ80F91".

**internalClock.** If non-zero, indicates target CPU is using internal clock source.

systemClockFreq. The target CPU system clock frequency, in Hertz.

targetClockFreq. Target CPU oscillator clock frequency, in Hertz. This value is the same value as systemClockFreq unless a PLL or divider is used.

internalROMSize. Size of internal flash or OTP memory, in bytes.

eZ80.adl. Initial value of ADL following a reset

eZ80.pc. Initial value for PC following a reset

eZ80.spl. Initial value for SPL following a reset

eZ80.sps. Initial value for SPS following a reset

**eZ80.zdiAlternate.** If non-zero, use lower ZDI clock frequencies. Using a the lower frequency settings may be required if the normal ZDI clock frequency settings do not give reliable performance.

**eZ80.flashLoaderRAM.** Address of a portion of RAM that flash erase and programming commands may use for scratch-pad. For the eZ80F92, this should normally be an address in external RAM due to a silicon bug that precludes use of internal RAM when erasing internal Flash RAM pages. If external RAM is not available, mass erase must be used instead of page erase for internal flash.

**eZ80.flashLoaderRAMSize.** Size of scratchpad RAM. 4 to 8 kb is recommended.

eZ80.internalRAM.enable. If nonzero, internal RAM is enabled.

**eZ80.internalRAM.enableEMAC.** If nonzero, EMAC ram is also enabled (if available)

**eZ80.internalRAM.page.** Page at which to map internal RAM. For example, if the CPU has 8KB of internal RAM and page is set to 0xB7, internal RAM addresses will range from 0xB7E000 to 0xB7FFFF.

eZ80.internalFlash.enable. If nonzero, internal flash memory is enabled.

**eZ80.internalFlash.waitStates.** Number of wait status to use for internal flash memory.

**eZ80.internalFlash.page.** Page at which to map internal Flash. For example, if the CPU has 128k Internal RAM and page is set to 0, Flash RAM will be mapped to the address range 0x000000 to 0x01FFFF.

**eZ80.chipSelects[n].lBound.** The upper 8 address bits of the lower bound of chip select n. n is a value between 0 and 3.

**eZ80.chipSelects[n].uBound.** The upper 8 address bits of the upper bound of chip select n. for example, if a chip select is used for addresses 0x100000 to 0x1FFFFF, lBound should be set to 0x10, and uBound should be set to 0x1F.



**eZ80.chipSelects[n].control.** The control value for chip select n. Refer to the CPU Product Specification for detailed information.

**eZ80.chipSelects[n].busMode.** The bus mode value for chip select n. Refer to the CPU Product Specification for detailed information.

**eZ8.configTarget(Z8 Encore! emulator only).** If true, indicates the following settings are to be used to configure the emulator following reset.

eZ8.dac (Z8 Encore! emulator only). DAC configuration.

eZ8.pinouts (Z8 Encore! emulator only). Output pin configuration.

eZ8.optBitsSize (Z8 Encore! emulator only). Number of option values

eZ8.optBits[n].address (Z8 Encore! emulator only). Array of option addresses.

eZ8.optBits[n].value (Z8 Encore! emulator only). Array of option values.

**zneo.externalBusSize.** Size of external data bus. Valid values are 0, 8, and 16. Set to zero if external bus is disabled.

**zneo.chipSelects[n].controlH.** Upper byte of chip select control register. n is a value between 0 and 5, which identifies which of the 6 chip selects. See the ZNeo CPU product Specification for details.

zneo.chipSelects[n].controlL lower. Byte of chip select control register.

**zneo.chipSelects[n].port.** Which port is used for chip select. Set to 'A' for portA, 'B' for portB, etc.

## nxvt IntProgramErase

The nxvt\_IntProgramErase structure contains internal flash memory erase parameters to use with NXV CTRL ERASE INT PROGRAM.

```
typedef struct {
   int startPage;
   int numberOfPages;
} nxvt_IntProgramErase;
```

### **Detailed Description**

Internal flash may be erased by page or mass erased. Set numberOfPages to -1 to do mass erase.

The number and size of the flash pages are processor-dependent.

Some eZ80Acclaim! Processors have a flash info page in addition to the normal internal program flash memory. The program flash is in pages 0 to 0x7f, and the flash info page is page 0x80.

### **Members**

numberOfPages. Number of pages to erase, or -1 for mass erase
startPage. First page to erase

# nxvt\_IntProgramSet

The nxvt\_IntProgramSet structure contains internal Program memory programming parameters to use with NXV\_CTRL\_SET\_INT\_PROGRAM control command.

```
typedef struct {
   int infoPage;
   unsigned long address;
   const unsigned char * pData;
   unsigned numberOfBytes;
} nxvt_IntProgramSet;
```

## **Detailed Description**

Parameters used with NXV\_CTRL\_SET\_INT\_PROGRAM control command to write to internal flash program memory.

### **Members**

**infoPage.** Flag that indicates whether writing to the info page or program flash. if non-zero, program info page (eZ80 only).

address. Address at which to start programming

pData. The data to program into the flash memory.



numberOfBytes. Size of data, in bytes.

## nxvt\_Registers

The nxvt\_Registers structure holds target register values. Format and contents of standard registers are processor-specific.

```
typedef struct {
  unsigned long pc;
  unsigned char standard [92];
} nxvt_Registers;
```

### **Members**

**pc.** Program counter. This is separated out from the other standard registers in order to facilitate run-from-break implementation in the nexus API. It may also be included in the standard register block data as well.

**standard.** Standard register set, including Stack Pointer, Flags, and general purpose registers. Format is processor specific. See "Standard Registers Access" on page 46.

# $nxvt\_Vendor Defined Ctrl Data$

The nxvt\_VendorDefinedCtrlData structure holds information for vendor defined control operations (see nx Control).

```
typedef struct {
   union {
     struct {
        nxvt_TargetRegisterType type;
        int address;
        unsigned long value;
    } setRegister;
   struct {
        nxvt_TargetRegisterType type;
        int address;
        unsigned long * pValue;
```

```
} getRegister;
struct {
   nxvt Registers * pBuf;
} getRegistersAll;
struct {
   nxvt TargetStatus * pStatus;
} getTargetStatus;
nxvt TargetConfiguration initializeTarget;
nxvt IntProgramErase eraseIntProgram;
nxvt IntProgramSet setIntProgram ;
nxvt ExtProgramErase eraseExtProgram;
nxvt ExtProgramSet setExtProgram;
struct {
   const unsigned char * pFirmware
   unsigned size;
} upgradeFirmware;
struct {
   unsigned offset;
   unsigned numberOfFrames;
   unsigned char *pBuffer;
   unsigned *pAvailable;
} getTrace;
struct {
   nxvt TraceControl operation;
   unsigned long param;
} traceControl;
struct {
   unsigned long frequency;
   int tableSelect;
} setZdiFrequency;
struct {
   unsigned optionSize;
   unsigned long optionData;
   unsigned long optionMask;
   unsigned algoSize;
   const unsigned char *pAlgoData;
} otpConfigure;
```



```
struct {
    nxvt_OtpControl operation;
    unsigned long param;
} otpControl;
struct {
    nxvt_Address address;
    unsigned long numBytes;
    unsigned long *pCrc;
    } crcMemory;
} u;
} nxvt_VendorDefinedCtrlData;
```

### **Detailed Description**

This structure consists of a union of structures, each of which contains parameters specific to a control command. In keeping with the Standard Nexus types, the union is named u.

#### Members

setRegister.type. type of register to write to. Valid values are NXV\_REGISTER\_STANDARD or NXV\_REGISTER\_PERIPHERAL. Use with NXV\_CTRL\_SET\_REGISTER.

**setRegister.address.** Identifies which register to write to. Set to register index if standard register, or register address if peripheral register. Use with NXV CTRL SET REGISTER.

**setRegister.value.** The value to write to the register. Use with NXV CTRL SET REGISTER.

getRegister.type. Type of register to read. Valid values are NXV\_REGISTER\_STANDARD or NXV\_REGISTER\_PERIPHERAL. Use with NXV\_CTRL\_GET\_REGISTER.

**getRegister.address.** Identifies which register to read. Set to register index if standard register, or register address if peripheral register. Use with NXV CTRL GET REGISTER.

**getRegister.pValue.** Pointer to the register value read. Use with NXV CTRL GET REGISTER.

getRegistersAll.pBuf. Pointer to buffer to hold standard registers values. See definition of nxvt\_Registers structure. Use with NXV CTRL GET REGISTERS ALL.

**getTargetStatus.pStatus.** Pointer to status value. Use with NXV\_CTRL\_GET\_TARGET\_STATUS.

initializeTarget. Target specific configuration parameters. See definition
of nxvt\_TargetConfiguration structure. Use with
NXV CTRL INITIALIZE TARGET.

eraseIntProgram. Parameters used for erasing internal flash memory. Use with NXV CTRL ERASE INT PROGRAM.

**setIntProgram.** Parameters and data to program internal flash memory. Use with NXV CTRL SET INT PROGRAM.

**eraseExtProgram.** Parameters used for erasing external flash memory. Use with NXV CTRL ERASE EXT PROGRAM.

**setExtProgram.** Parameters and data to program external flash memory. Use with NXV CTRL SET EXT PROGRAM.

**upgradeFirmware.pFirmware.** Pointer to buffer containing the firmware image. Use with NXV CTRL UPGRADE FIRMWARE.

**upgradeFirmware.size.** Size of firmware image, in bytes. Use with NXV CTRL UPGRADE FIRMWARE.

**getTrace.offset (Z8Encore emulator only).** Trace frame offset relative to oldest frame in the buffer. Since the trace buffer wraps around, the oldest frame is not necessarily the frame at location zero in the buffer. Use with NXV\_CTRL\_GET\_TRACE.

**getTrace.numberOfFrames (Z8Encore emulator only).** Number of trace frames to retrieve. Use with NXV\_CTRL\_GET\_TRACE.

**getTrace.pBuffer (Z8Encore emulator only).** Pointer to buffer to store trace frames. Use with NXV\_CTRL\_GET\_TRACE.

**getTrace.pAvailable (Z8Encore emulator only).** Number of trace frames available in the trace buffer. Use with NXV\_CTRL\_GET\_TRACE.



traceControl.operation (Z8Encore emulator only). Specifies a trace control operation to perform. Use with NXV CTRL TRACE CONTROL.

**traceControl.param (Z8Encore emulator only).** Operation-specific parameter. Use with NXV CTRL TRACE CONTROL.

**setZdiFrequency.frequency (eZ80Acclaim! only).** The target clock frequency upon which the ZDI frequence setting is to be based on. Use with NXV CTRL SET ZDI FREQUENCY.

**setZdiFrequency.tableSelect (eZ80Acclaim! only).** Set to one to select alternate frequency settings for ZDI Clock. use with NXV\_CTRL\_SET\_ZDI\_FREQUENCY.

**otpConfigure.optionSize (Z8 only).** Size of OTP option data, in bytes. Use with NXV CTRL OTP CONFIGURE.

**otpConfigure.optionData (Z8 only).** OTP option data. Use with NXV CTRL OTP CONFIGURE.

**otpConfigure.optionMask (Z8 only).** OTP option data mask. Use with NXV CTRL OTP CONFIGURE.

**otpConfigure.algoSize (Z8 only).** Size of OTP programming algorithm. Use with NXV CTRL OTP CONFIGURE.

**otpConfigure.pAlgoData (Z8 only).** OTP programming algorithm. Use with NXV CTRL OTP CONFIGURE.

**otpControl.operation (Z8 only).** Specifies an OTP operation to perform. Use with NXV CTRL OTP CONTROL.

**otpControl.param (Z8 only).** OTP operation-specific parameter. Use with NXV CTRL OTP CONTROL.

**crcMemory.address.** address of block of memory to calculate CRC on. Used for ZNeo only, and must be aligned to 4KB boundary.

**crcMemory.numBytes.** number of bytes in block of memory to CRC. Used for Zneo only, and must be multiple of 4096.

**crcMemory.pCrc.** pointer to returned memory CRC value.

# nxvt\_VendorDefinedTargetSpec

The nxvt\_VendorDefinedTargetSpec structure contains vendor-specific parameters needed to establish connection to target. See nxt TargetSpec and nx Open.

```
typedef struct {
   char const * pOpenParameters;
   nxvt_CommInfo comminfo;
} nxvt VendorDefinedTargetSpec;
```

### **Detailed Description**

popenParameters contains implementation specific parameters. For the ZiLOG Nexus API implementation, this should be set to the path and name of the algorithm ini file.

#### **Members**

comminfo. Communication parameters.

**pOpenParameters.** String containing processor and/or vendor specific target parameters.

## nxvt VendorDefinedBasicSetEvent

The nxvt\_VendorDefinedBasicSetEvent structure contains information for setting data breakpoints and events. Events are only supported on emulator targets.

```
typedef struct {
   nxvt_EventAction action;
   unsigned char trigger [8];
   unsigned char mask [8];
   nxvt_Address stepEnd;
} nxvt_VendorDefinedBasicSetEvent;
```

## **Detailed Description**

The action, trigger, and mask members are used for setting complex events. An event is triggered when the processor state matches the trigger



settings. The mask can be used to mask off "don't care" bits. Complex events are currently only supported on Z8 Encore! emulators. The format of data contained in trigger and mask arrays is as follows:

```
Byte 0: register address (MSB)
Byte 1: register address (LSB)
Byte 2: register data
Byte 3: CPU flags
Byte 4: PC (MSB)
Byte 5: PC (LSB)
Byte 6: reserved for future use
Byte 7: reserved for future use
```

### Members

action. Action to take upon event detection (NXVT ETYPE EVENT).

**trigger.** Array containing the conditions that trigger an event for complex events (NXVT ETYPE EVENT).

Array containing trigger data mask for complex events (NXVT ETYPE EVENT).

**stepEnd.** The end address used for stepto events. Stepto events are used to step as long as the PC is between the starting PC value and the stepEnd value. (NXVT\_ETYPE\_STEPTO).

# **Standard Registers Access**

### **Z8** Encore!

Table 3 contains the index value to be used with NXV\_CTRL\_GET\_REGISTER for reading standard register values. This is also the format of the register block buffer returned by NXV\_CTRL\_GET\_REGISTERS\_ALL command. Note that where size is 2 bytes, the most significant byte is first in the buffer returned by NXV\_CTRL\_GET\_REGISTERS\_ALL. Note that the size is given in bytes,

but in some cases not all bits are used. Also note that flags bits can be accessed individually, or as a register.

Table 3. NXV\_CTRL\_GET\_REGISTER Index Values for Z8 Encore!

| Register Names | Index | Size in bytes |
|----------------|-------|---------------|
| PC             | 0     | 2             |
| SP             | 1     | 2             |
| R0             | 2     | 1             |
| R1             | 3     | 1             |
| R2             | 4     | 1             |
| R3             | 5     | 1             |
| R4             | 6     | 1             |
| R5             | 7     | 1             |
| R6             | 8     | 1             |
| R7             | 9     | 1             |
| R8             | 10    | 1             |
| R9             | 11    | 1             |
| R10            | 12    | 1             |
| R11            | 13    | 1             |
| R12            | 14    | 1             |
| R13            | 15    | 1             |
| R14            | 16    | 1             |
| R15            | 17    | 1             |
| FLAGS          | 18    | 1             |
| RP             | 19    | 1             |
| RR0            | 20    | 2             |



Table 3. NXV\_CTRL\_GET\_REGISTER Index Values for Z8 Encore!

| Register Names         | Index | Size in bytes |
|------------------------|-------|---------------|
| RR2                    | 21    | 2             |
| RR4                    | 22    | 2             |
| RR6                    | 23    | 2             |
| RR8                    | 24    | 2             |
| RR10                   | 25    | 2             |
| RR12                   | 26    | 2             |
| RR14                   | 27    | 2             |
| Carry Flag             | 28    | 1             |
| Zero Flag              | 29    | 1             |
| Signed Flag            | 30    | 1             |
| Overflow Flag          | 31    | 1             |
| Decimal Carry<br>Flag  | 32    | 1             |
| Half Carry Flag        | 33    | 1             |
| User defined<br>Flag 1 | 34    | 1             |
| User defined<br>Flag 2 | 35    | 1             |

### eZ80Acclaim!

The following table contains the index value to be used with NXV\_CTRL\_GET\_REGISTER for reading standard register values. This is also the format of the register block buffer returned by NXV\_CTRL\_GET\_REGISTERS\_ALL command. Note that where size is

more than one byte, the least significant byte is first in the register block buffer returned by  $\texttt{NXV\_CTRL\_GET\_REGISTERS\_ALL}$ .

Table 4. NXV\_CTRL\_GET\_REGISTER Index Values for eZ80Acclaim!

| Register Names | Index | Size in bytes                                                                                                              |
|----------------|-------|----------------------------------------------------------------------------------------------------------------------------|
| A              | 0     | 1                                                                                                                          |
| F              | 1     | 1                                                                                                                          |
| BC             | 2     | 3                                                                                                                          |
| DE             | 3     | 3                                                                                                                          |
| HL             | 4     | 3                                                                                                                          |
| A'             | 5     | 1                                                                                                                          |
| F'             | 6     | 1                                                                                                                          |
| BC'            | 7     | 3                                                                                                                          |
| DE'            | 8     | 3                                                                                                                          |
| HL'            | 9     | 3                                                                                                                          |
| IX             | 10    | 3                                                                                                                          |
| IY             | 11    | 3                                                                                                                          |
| Ī              | 12    | 1 or 2 bytes,<br>depending on<br>processor. See<br>processor<br>documentation<br>for size of<br>Interrupt Page<br>Register |
| R              | 13    | 1                                                                                                                          |
| ADL            | 14    | 1                                                                                                                          |
| MADL           | 15    | 1                                                                                                                          |



Table 4. NXV\_CTRL\_GET\_REGISTER Index Values for eZ80Acclaim!

| Register Names | Index | Size in bytes |
|----------------|-------|---------------|
| MBASE          | 16    | 1             |
| IEF1           | 17    | 1             |
| IEF2           | 18    | 1             |
| SPL            | 19    | 3             |
| SPS            | 20    | 2             |
| PC             | 21    | 3             |

### **ZNEO**

The following table contains the index value to be used with NXV\_CTRL\_GET\_REGISTER for reading standard register values. This is also the format of the register block buffer returned by NXV\_CTRL\_GET\_REGISTERS\_ALL command. Note that where size is more than one byte, the least significant byte is first in the register block buffer returned by NXV\_CTRL\_GET\_REGISTERS\_ALL.

Table 5. NXV\_CTRL\_GET\_REGISTER Index Values for ZNEO

| Register Names | Index | Size in bytes |
|----------------|-------|---------------|
| R0             | 0     | 4             |
| R1             | 1     | 4             |
| R2             | 2     | 4             |
| R3             | 3     | 4             |
| R4             | 4     | 4             |
| R5             | 5     | 4             |
| R6             | 6     | 4             |

Table 5. NXV\_CTRL\_GET\_REGISTER Index Values for ZNEO

| Register Names      | Index | Size in bytes |
|---------------------|-------|---------------|
| R7                  | 7     | 4             |
| R8                  | 8     | 4             |
| R9                  | 9     | 4             |
| R10                 | 10    | 4             |
| R11                 | 11    | 4             |
| R12                 | 12    | 4             |
| R13                 | 13    | 4             |
| R14                 | 14    | 4             |
| R15                 | 15    | 4             |
| SP                  | 16    | 4             |
| PC                  | 17    | 4             |
| FLAGS               | 18    | 1             |
| CARRY FLAG          | 19    | 1             |
| ZERO FLAG           | 20    | 1             |
| SIGN FLAG           | 21    | 1             |
| OVERFLOW FLAG       | 5 22  | 1             |
| BLANK FLAG          | 23    | 1             |
| USER 1 FLAG         | 24    | 1             |
| USER 2 FLAG         | 25    | 1             |
| INTERRUPT<br>ENABLE | 26    | 1             |
| PCOV                | 27    | 4             |



Table 5. NXV\_CTRL\_GET\_REGISTER Index Values for ZNEO

| Register Names | Index | Size in bytes |
|----------------|-------|---------------|
| SPOV           | 28    | 4             |
| CPUCTL         | 29    | 1             |



## A

```
API Commands 13
   nxt Handle* nx Open (const nxt TargetSpec * tSpec, void(* errorCallback)(const
      char *), nxt Status * status) 17
   nxt Status nx Close (nxt Handle * handle) 14
   nxt Status nx Control (nxt Handle * handle, nxt CtrlData ctrl) 14
   nxt Status nx GetEvent (nxt Handle * handle, nxt ReceivedEvent * event, int
      maxBytes, const int block) 15
   nxt Status nx GetLastError (nxt Handle * handle, char * lastError, int maxBytes) 16
   nxt Status nx ReadMem (nxt Handle * handle, const int map, const int access Priority,
      const nxvt Address addr, const size t numBytes, const int accessSize, void **
      bytesRead) 17
   nxt Status nx SetEvent (nxt Handle * handle, const nxt SetEvent * setEvent) 18
   nxt Status nx WriteMem (nxt Handle * handle, const int map, const int
      accessPriority, const nxvt Address addr, const size t numBytes, const int
      accessSize, const void * bytesToWrite) 19
   void nx ClearEvent (nxt Handle * handle, const int eid) 13
Asterisks 2
```

### $\mathbf{C}$

```
Control Data 7
eraseExtProgram 9
eraseIntProgram 9
getRegister 8
getRegistersAll 8
getTargetStatus 8
getTrace 10
initializeTarget 8
setExtProgram 9
setIntProgram 8
setRegister 7
traceControl 11
upgradeFirmware 10
```

### Nexus Interface API Reference Manual





Control Operations 5, 6 Conventions 2 Courier Typeface 2

# $\mathbf{E}$

eZ802

### G

Glossary 21

### H

Hexadecimal Values 2

### I

Implementation 3

# $\mathbf{M}$

Manual Objectives 1

# $\mathbf{N}$

Nexus Vendor Extensions Reference 21
NXVT\_COMMINFO Struct Reference 28
NXVT\_EXTPROGRAMERASE Struct Reference 30
NXVT\_EXTPROGRAMSET Struct Reference 32
NXVT\_INTPROGRAMERASE Struct Reference 38
NXVT\_INTPROGRAMSET Struct Reference 39
NXVT\_REGISTERS Struct Reference 40

# NXVT\_TARGETCONFIGURATION Struct Reference 34

## 0

Online Information 2

# S

Set Event Extensions 12

## T

Target Address 3
Target Events 4
Target Registers 4
Target Spec 5
Target Word 4
Trademarks 2

### $\mathbf{V}$

Vendor Extensions 3