

# Cortex-M1

Handbook



# Actel Corporation, Mountain View, CA 94043

© 2007 Actel Corporation. All rights reserved.

Printed in the United States of America

Part Number: 50200127-6

Release: June 2008

No part of this document may be copied or reproduced in any form or by any means without prior written consent of Actel.

Actel makes no warranties with respect to this documentation and disclaims any implied warranties of merchantability or fitness for a particular purpose. Information in this document is subject to change without notice. Actel assumes no responsibility for any errors that may appear in this document.

This document contains confidential proprietary information that is not to be disclosed to any unauthorized person without prior written consent of Actel Corporation.

### Trademarks

Actel and the Actel logo are registered trademarks of Actel Corporation.

Adobe and Acrobat Reader are registered trademarks of Adobe Systems, Inc.

All other products or brand names mentioned are trademarks or registered trademarks of their respective holders.

# **Table of Contents**

|   | Introduction5Key Features5Benefits5Supported Actel FPGA Families5                                                                                                                                           |
|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | Cortex-M1 Overview                                                                                                                                                                                          |
| 2 | Delivery and Deployment9CortexM1Top (Cortex-M1 top level)9Cortex-M1 SPIRIT Description9Cortex-M1 I/O Signals10                                                                                              |
| 3 | Supported Interfaces13External Interface13Tightly Coupled Memory (TCM) Interface14                                                                                                                          |
| 4 | Cortex-M1 Features15Programmer's Model15Data Types15Registers16Clocking and Resets22Nested Vectored Interrupt Controller23                                                                                  |
| 5 | Software Development                                                                                                                                                                                        |
| 6 | Cortex-M1 Design Entry Flow                                                                                                                                                                                 |
| 7 | Bus Functional Model (BFM)       31         BFM Usage Flow       32         Functionality       33         BFM Script Language       34         Timing Shell       36         Example BFM Use Case       36 |
| 8 | Debug39About Debug39JTAG Debug Interface40                                                                                                                                                                  |
| 9 | AC Parameters                                                                                                                                                                                               |
| A | Product Support                                                                                                                                                                                             |

## **Table of Contents**

| Actel Technical Support                          | . 69 |
|--------------------------------------------------|------|
| Website                                          | . 69 |
| Contacting the Customer Technical Support Center | . 69 |
| Index                                            | 71   |



# Introduction

This document describes the architecture and implementation of the 32-bit  $Cortex^{TM}$ -M1 microprocessor developed by ARM® specifically for use in FPGAs. Cortex-M1 is a functional subset of Cortex-M3, which uses the M3 three-stage pipeline and runs the ARMv6-M instruction set. The streamlined Cortex-M1, developed for use in embedded applications, is designed to balance size and speed when implemented in an FPGA.

# **Key Features**

- 32-bit RISC architecture (ARMv6-M)
- 32-bit AHB-Lite bus interface
- · Separate Tightly Coupled Memory Interfaces
- Three-stage pipeline
- 32-bit ALU
- 1–32 interrupts with 4 priority levels per interrupt
- 4-GB memory addressing range (the upper 0.5 GB is reserved)
- · Optional real-time debug unit
- JTAG interface

# **Benefits**

- Fully implemented in FPGA fabric
- · All microprocessor I/Os available to user
- · No license fees or royalties
- Can run all existing Thumb® code
- Upward-compatible with Cortex-M3

# Supported Actel FPGA Families

The Cortex-M1 version part number prefix is in parentheses.

- IGLOO™ (M1AGL)
- Fusion<sup>TM</sup> (M1AFS)
- ProASIC3L (M1A3PxxxxL)
- ProASIC®3 (M1A3P)
- ProASIC3E (M1A3PE)

The Cortex-M1 soft IP core is a member of ARM's Cortex family of processors and has been optimized for use in Actel ARM-enabled FPGAs.

Cortex-M1 is supplied with an AMBA AHB-Lite compliant interface for inclusion in an AMBA-based processor system, such as one generated by the Actel CoreConsole IP deployment platform. The processor also has a separate tightly coupled memory (TCM) interface.

# **Utilization and Performance**

Cortex-M1 can be implemented in several Actel FPGA devices. Table 1 gives typical utilization figures using standard synthesis tools for four different core configurations.

Table 1 · Cortex M1 Utilization Data

| D :             | Variant  | v2.4            |      |             |  |
|-----------------|----------|-----------------|------|-------------|--|
| Device          |          | Frequency (MHz) | Area | Utilization |  |
| M1AFS250-2      | No-debug | 64.371          | 4440 | 72.7%       |  |
| M1 A DC (00. 2  | No-debug | 68.563          | 4440 | 32.12%      |  |
| M1AFS600-2      | Debug    | 63.151          | 7453 | 53.91%      |  |
| M1AFS1500-2     | No-debug | 63.824          | 4440 | 11.56%      |  |
| WIIAF51500-2    | Debug    | 63.107          | 7453 | 19.41%      |  |
| M1AGL250V2      | No-debug | 26.428          | 4440 | 72.27%      |  |
| M1AGL250V5      | No-debug | 43.014          | 4440 | 72.27%      |  |
| M1AGL600V2      | No-debug | 25.808          | 4440 | 32.12%      |  |
| WIAGL600V2      | Debug    | 25.787          | 7453 | 53.91%      |  |
| MIACICONE       | No-debug | 40.616          | 4440 | 32.12%      |  |
| M1AGL600V5      | Debug    | 41.966          | 7453 | 53.91%      |  |
| M1A3P250-2      | No-debug | 65.729          | 4440 | 72.27%      |  |
| M1 A 2D (00, 2  | No-debug | 64.441          | 4440 | 32.12%      |  |
| M1A3P600-2      | Debug    | 62.794          | 7453 | 53.91%      |  |
| M1A3P1000-2     | No-debug | 67.893          | 4440 | 18.07%      |  |
| IVI1/A3P1000-2  | Debug    | 61.927          | 7453 | 30.33%      |  |
| M1A3PE1500-2    | No-debug | 60.942          | 4440 | 11.56%      |  |
| WITASF E 1500-2 | Debug    | 61.633          | 7453 | 19.41%      |  |

Notes: Configuration is 0 kbytes ITCM, 0 kbytes DTCM, small multiplier, 1 interrupt, no OS extensions, little-endian, and debug as shown.

All debug variants in the devices listed above use a smaller debug block than in earlier versions of the Cortex-M1. This smaller debug block contains only two breakpoints and one watchpoint.





# **Cortex-M1 Overview**

## **Cortex-M1 Processor**

Cortex-M1 is a general purpose 32-bit microprocessor that offers high performance and small size in FPGAs. The processor is highly configurable with tightly coupled memories, fast or small multiplier options, OS extensions, optional debug, and a 32-input interrupt controller. Cortex-M1 runs a subset of the Thumb-2 instruction set (ARMv6-M) that includes all base 16-bit Thumb instructions and a few Thumb-2 32-bit instructions (BL, MRS, MSR, ISB, DSB, and DMB). This enables writing very tight and efficient processor code, which is ideal for the limited memory typically found in deeply-embedded applications.

The main blocks in Cortex-M1 are shown in Figure 1-1 and include the processor core, the Nested Vectored Interrupt Controller (NVIC), the AHB interface, and the debug unit. The processor core supports 13 general purpose 32-bit registers, including a Link Register (LR), a Program Counter (PC), a Program Status Register (xPSR), and two banked Stack Pointers (SP). In addition to the AHB-Lite interface, there is a dedicated memory interface for access to the Instruction and Data Tightly Coupled Memories (ITCM and DTCM). The ITCM and DTCM are individually configurable from 0 bytes to 1,024 kbytes, providing ample space for optimizing memory transactions.



Figure 1-1 · Cortex-M1 Block Diagram with Debug

The NVIC is closely coupled to the Cortex-M1 core to achieve low-latency interrupt processing. The NVIC is configurable and supports 1, 4, 8, 16, or 32 interrupts with 4 levels of priority. The processor state is automatically saved on interrupt entry and restored on interrupt exit, with no instruction overhead to simplify software development.

## Cortex-M1 Overview

The 16-bit length of the Cortex-M1 Thumb instruction allows it to approach twice the code density of the standard 32-bit ARM code, while retaining most of the ARM performance advantages over a traditional 16-bit processor that uses 16-bit registers. This is possible because Thumb code operates on the 32-bit register set in the processor. Thumb code is able to provide up to 65% of the code size of ARM, and 160% of the performance of an equivalent ARM processor connected to a 16-bit memory system.





# **Delivery and Deployment**

Cortex-M1 is delivered as a CCZ (CoreConsole Component ZIP file), which can be added to the CoreConsole IP database. Using CoreConsole, the processor core can be instantiated, configured, and stitched into an AMBA-based subsystem. The implementation files used in a Libero® Integrated Design Environment (IDE) project for simulation and synthesis can then be generated. These files consist of the BFM files, test wrapper, and the Cortex-M1 secured CDB black box model file, which is the Cortex-M1 core that has gone through the place-and-route process and will be instantiated in the user device. This deployment flow is adopted to ensure that the design is kept completely secure at all times.

Initially, the Cortex-M1 processor is being made available for use in Actel M1 devices with only one user-selectable option: with or without debug. The core is configured with 0 kbytes ITCM, 0 kbytes DTCM, small multiplier, little endian, no OS extensions, and 1 interrupt. Additional versions of the core are planned that will make all of the user-configurable options available.

# CortexM1Top (Cortex-M1 top level)

The user need only select one core, corresponding to Cortex-M1 in the CoreConsole GUI. Cortex-M1 has built-in AHB-Lite Master support, so can connect directly an AHB bus (e.g., CoreAHB[Lite]), unlike CoreMP7, which requires CoreMP7Bridge to bridge from the ARM7TDMI-S native memory interface to an AHB bus. A top-level wrapper around the Cortex-M1 core contains the following functionality:

- · VHDL and Verilog versions
- Generics/parameters to allow users to select the following options (to the extent that they are selectable) in CoreConsole:
  - TCM size (0 kbytes, 2 kbytes, ... 1,024 kbytes, in "powers of 2" increments)
  - Multiplier type (small or fast)
  - Debug interface (RealView, FlashPro3, or none)
  - Die
  - OS extensions
  - Number of interrupts

Note: Not all combinations of these parameters are available to the user.

- Reset generation (combining watchdog reset from CoreWatchdog, if present and the soft reset output from Cortex-M1)
- Buffering of reset signals
- Multiplexing of debug-related JTAG signals (between RealView and FlashPro3 JTAG interfaces)

# Cortex-M1 SPIRIT Description

The SPIRIT IP-XACT description of Cortex-M1 is implemented at the top level (CortexM1Top). It provides only valid parameter selection choices in the CoreConsole configuration dialog box. It also takes care of ensuring the correct CDB black box module is exported to the Libero IDE project (as described in the "CortexM1Top (Cortex-M1 top level)" section).

# Cortex-M1 I/O Signals

CortexM1Top has fixed I/O signals, regardless of the Cortex-M1 variant chosen. All 32 interrupt signals and all the debug interface signals are always present, regardless of the configuration. The SPIRIT description is written so that unused inputs are tied inactive and unused outputs are left unconnected in the instantiation of CortexM1Top. The I/O signals present in CortexM1Top are described in Table 2-1.

Table 2-1 · Cortex-M1 Signal Descriptions

| Name        | Width | Type   | Description                             |
|-------------|-------|--------|-----------------------------------------|
| HCLK        | 1     | Input  | Main processor clock                    |
| NSYSRESET   | 1     | Input  | External push-button/power-up reset     |
| WDOGRES     | 1     | Input  | Watchdog reset to Cortex-M1             |
| WDOGRESn    | 1     | Output | Reset of watchdog timer                 |
| HRESETn     | 1     | Output | Reset to other components in AHB system |
| RV_TCK      | 1     | Input  | RealView JTAG                           |
| RV_nTRST    | 1     | Input  | RealView JTAG                           |
| RV_TMS      | 1     | Input  | RealView JTAG                           |
| RV_TDI      | 1     | Input  | RealView JTAG                           |
| RV_nSRST_IN | 1     | Input  | RealView JTAG                           |
| RV_TRCK     | 1     | Input  | RealView JTAG                           |
| RV_TDOUT    | 1     | Output | RealView JTAG                           |
| RV_nTDOEN   | 1     | Output | RealView JTAG                           |
| UJTAG_TCK   | 1     | Input  | FlashPro3 JTAG                          |
| UJTAG_TDI   | 1     | Input  | FlashPro3 JTAG                          |
| UJTAG_TMS   | 1     | Input  | FlashPro3 JTAG                          |
| UJTAG_TRSTB | 1     | Input  | FlashPro3 JTAG                          |
| UJTAG_TDO   | 1     | Output | FlashPro3 JTAG                          |
| IRQ[31:0]   | 32    | Input  | External Interrupts                     |
| NMI         | 1     | Input  | Non-maskable Interrupt                  |
| EDBGRQ      | 1     | Input  | External debug request                  |
| nTRST       | 1     | Input  | JTAG reset                              |
| JTAGTOP     | 1     | Output | State Controller Indicator              |
| nTDOEN      | 1     | Output | JTAG data out enable                    |
| LOCKUP      | 1     | Output | Core is locked up                       |
| HALTED      | 1     | Output | Core is in Halt debug state             |
| HREADY      | 1     | Input  | Slave ready signal                      |

\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_Cortex-M1 Handbook





Table 2-1 · Cortex-M1 Signal Descriptions (continued)

| Name         | Width | Туре   | Description                           |
|--------------|-------|--------|---------------------------------------|
| HRESP        | 1     | Input  | AHB response signal                   |
| HRDATA[31:0] | 32    | Input  | Data from Slave to Master             |
| HTRANS[1:0]  | 2     | Output | AHB transfer type signal              |
| HBURST[2:0]  | 3     | Output | AHB burst signal                      |
| HPROT[3:0]   | 4     | Output | Transfer protection bits              |
| HSIZE[2:0]   | 3     | Output | Transfer size                         |
| HWRITE       | 1     | Output | Transfer direction                    |
| HMASTLOCK    | 1     | Output | Transfer is part of a locked sequence |
| HADDR[31:0]  | 32    | Output | Transfer address                      |
| HWDATA[31:0] | 32    | Output | Data from Master to Slave             |

# **Supported Interfaces**

The processor contains two bus interfaces:

- · External interface
- Tightly Coupled Memory (TCM) interface

The processor also contains an internal Processor Peripheral Bus (PPB) for accesses to the Nested Vectored Interrupt Controller (NVIC), Data Watchpoint (DW) unit, and Breakpoint Unit (BPU).

# **External Interface**

The external interface is an AMBA AHB-Lite bus interface. Descriptions of the bus signals are shown in Table 2-1 on page 10. Processor accesses and debug accesses to external AHB peripherals can occur over this bus interface. Because AHB fetches take two cycles longer than TCM fetches, instructions and data should be contained in TCM where possible. If on-chip FPGA memory is used for the processor, use TCM memory rather than SRAM mapped onto the AHB interface. This enables the highest possible performance.

Figure 3-1 shows the timing of a read without wait states on the external interface. The Address A0 is presented on HADDR one cycle later than the internal address is generated, and the returned data D0 is registered again before use in the processor. This enables the AHB peripherals sufficient time to use the address generated.



Figure 3-1 · AHB Read without Wait States

Processor accesses and debug accesses share the external interface. Debug accesses take priority over processor accesses. Giving the highest priority to debug means that debug cannot be locked out by a continuously executing stream of core instructions. Timing of processor accesses might be changed by the presence of debug accesses. Debug accesses tend to be infrequent, so debug accesses generally do not have a major impact on processor accesses.

Any vendor-specific components with an AHB interface can populate this bus.

Unaligned accesses to this bus are not supported.

## **Write Buffer**

To prevent bus wait cycles from stalling the processor during data stores, buffered stores to the external interfaces go through a one-entry write buffer. If the write buffer is full, subsequent accesses to the bus stall until the write buffer has drained. The write buffer is only used if the bus waits for the data phase of the buffered store; otherwise the transaction is immediately completed on the bus.

The DMB and DSB instructions wait for the write buffer to drain before completing. If an interrupt arrives while DMB/DSB is waiting for the write buffer to drain, the processor returns to the opcode after the DMB/DSB, on completion of the interrupt. This is because interrupt processing is a so-called memory barrier operation. In other words, all reads and writes occurring before the interrupt appear to happen before the interrupt, so the DMB and DSB instructions must appear to have completed before the interrupt.

# **Tightly Coupled Memory (TCM) Interface**

Core access to Tightly Coupled Memories (TCMs) is made exclusively through a dedicated core memory interface.

The core memory interface is comprised of the following:

- Instruction Tightly Coupled Memory interface to access ITCM
- Data Tightly Coupled Memory interface to access DTCM

Because reads are speculatively fetched from TCMs, Device and Strongly-Ordered memory types such as FIFOs in TCM space are not supported. The processor does not support wait states for the memory interfaces. Figure 3-2 shows the signal timings for ITCM. The DTCM signal timings are the same as ITCM signal timings.



Figure 3-2 · ITCM Signal Timings

The write address, WA0, and write data, WD0, are presented in the same cycle. The Read Address (RA) is presented in one cycle, and the memory generates the Read Data (RD) in the next cycle. The sequence that Figure 3-2 shows is only possible on ITCM, where the RA read is an instruction fetch, and WA1 write is the product of a store instruction. The WA0-RA sequence is possible on DTCM.

In versions of the Cortex-M1 with non-zero sized ITCM, a TCM initialization state machine in the CortexM1Top wrapper module goes out onto the AHB bus and reads the ITCM initialization data from AHB location 0x00000000, and loads it into ITCM while holding the Cortex-M1 core itself in reset. Typically the NVM containing the program would have to be located at location 0x00000000.

In situations where there is only one large RAM available, but the user wants to run from RAM (for example, the user is debugging code on an Actel Cortex-M1 Development Board), the RAM should be mapped to location 0x6000000. The user should download the program (via debugger) to this location and start execution from this point. The user's software should be written/linked assuming this location during the debug stage. This is the only SRAM area in the memory map that supports both instruction fetches and data accesses. When the debugging has finished, the software needs to be rewritten and linked to assume the starting point of location 0x00000000.



# **Cortex-M1 Features**

# **Programmer's Model**

The Cortex-M1 processor implements a subset of the Thumb-2 (ARMv7) architecture called ARMv6-M. This includes all of the 16-bit Thumb-2 instructions and some of the 32-bit instructions. The processor does not support ARM instructions.

Thumb-2 (ARMv7) is ARM's latest instruction set architecture (ISA) developed for their new Cortex family of processors. Offering increased efficiency and performance, the Thumb-2 ISA differs from previous ARM architectures in that it includes both 16- and 32-bit instructions. The previous 16-bit Thumb instruction set and 32-bit ARM instruction set were separate and had to be executed from different modes within the processor. The new Thumb-2 ISA gives users all the advantages of the reduced code size of the 16-bit Thumb instructions and the higher performance of the 32-bit ARM instructions. This is achieved in a single ISA that can be executed from a single mode within the processor, increasing the efficiency of the code as it executes and improving the performance and throughput of the Cortex family of processors.

## **Processor Operating States**

The Cortex-M1 processor has two operating states:

- Thumb state This is normal execution, running the set of 16-bit, halfword-aligned Thumb and Thumb-2 instructions; as well as the 32-bit BL, MRS, MSR, ISB, DSB, and DMB instructions.
- Debug state This is the state when halting debug

### **Processor Operating Modes**

The Cortex-M1 processor supports two modes of operation:

- Thread mode Entered on Reset, and can be re-entered as the result of an exception return
- Handler mode Entered as the result of an exception

### **Main Stack and Process Stack Access**

Out of reset, all code uses the main stack with the processor in Thread mode. An exception handler such as SVC can change the stack from the main stack to the process stack by changing the EXC\_RETURN value it uses on exit. All exceptions continue to use the main stack. The stack pointer (R13) is a banked register that switches between the main stack and the process stack. At any given time only one stack—the process stack or the main stack—is visible using R13.

It is also possible to switch from the main stack to the process stack while in Thread mode by writing to the special purpose Control Register using an MSR instruction.

# **Data Types**

The processor supports the following data types:

- 32-bit words
- 16-bit halfwords
- 8-bit bytes

Note: Unless otherwise stated, the core can access all regions of the memory map, including the code region, with all data types. To support this, the system must support sub-word writes without corrupting neighboring bytes in that word (i.e., individual byte enables for writes).

# Registers

The processor has the following 32-bit registers (shown in Figure 4-1):

- 13 general purpose registers, R0-R12
- Stack Pointer (SP), R13
- Link Register (LR), R14
- Program Counter (PC), R15
- Program status registers, xPSR



Figure 4-1 · Cortex-M1 Register Set

# **General Purpose Registers**

The general purpose registers, R0–R12, have no architecture-specific uses.

- Low registers Registers R0—R7 are accessible by all instructions that specify a general purpose register.
- High registers Registers R8—R12 are accessible by some, but not all 16-bit instructions.

The R13, R14, and R15 registers have the following special functions:

- Stack pointer Register R13 is used as the Stack Pointer (SP). Because the SP ignores writes to bits [1:0], it is auto-aligned to a word (four-byte) boundary. It has banked register aliases, SP\_process and SP\_main. Handler mode always uses SP\_main, but Thread mode can be configured to use either SP\_main or SP\_process.
- Link register Register R14 is the subroutine Link Register (LR). The LR receives the return address from the Program Counter (PC) when a Branch and Link (BL) instruction is executed. The LR is also used for exception returns. At all other times, R14 can be treated as a general purpose register.
- Program counter Register R15 is the Program Counter (PC). Bit [0] is always 0, so instructions are always aligned to 16-bit halfword (two-byte) boundaries.





## **Special Purpose Program Status Registers (xPSR)**

Processor status at the system level is broken into three categories and can be accessed as individual registers, a combination of any two of the three, or a combination of all three using the MRS and MSR instructions.

- Application PSR (APSR) Contains the condition code flags. Before entering an exception, the processor saves the condition code flags on the stack. The APSR can be accessed with the MSR and MRS instructions.
- Interrupt PSR (IPSR) Contains the Interrupt Service Routine (ISR) number of the current exception
- Execution PSR (EPSR) Contains the *Thumb state bit* (T-bit). Unless the processor is in Debug state, the EPSR is not directly accessible and all fields read as zero using an MRS instruction. MSR instruction writes are ignored.

On entering an exception, the processor saves the combined information from the three status registers on the stack.

# **Special Purpose Priority Mask Register**

Use the special purpose Priority Mask Register to boost execution priority. The special purpose Priority Mask Register can be accessed by using the MSR and MRS instructions. The CPS instruction to set or clear PRIMASK can also be accessed.

# **Special Purpose Control Register**

The special purpose Control Register identifies the stack pointers used.

### **Stacks**

The processor supports two separate stacks:

- Process stack Thread mode can be configured to use the process stack. Thread mode uses the main stack out of reset. SP\_process is the *Stack Pointer* (SP) register for the process stack.
- Main stack Handler mode uses the main stack. SP\_main is the SP register for the main stack.

Only one stack, the process stack or the main stack, is visible at any time using R13. After pushing the content, the ISR uses the main stack and all subsequent interrupt preemptions also use the main stack.

#### **Memory Map**

Cortex-M1 has a defined memory map with the various processor interfaces addressed by different memory map regions, as shown in Figure 4-2 on page 18. The processor can access all regions within the memory map with the exception of the reserved regions. The reserved regions are Execute Never (XN) and instruction accesses are prevented by the processor hardware. The SRAM, Peripheral, External Device, and Private Peripheral Bus regions in the memory map are also XN. Instructions can be executed from the Code and External (not External Device) regions of the memory map.



Note: TCMs shown are maximum size (1,024 kbytes).

Figure 4-2 · Cortex-M1 Memory Map

The processor views memory as a linear collection of bytes numbered in ascending order from 0. For example:

- Bytes 0-3 hold the first stored word
- Bytes 4–7 hold the second stored word

The processor can access data words in memory in little-endian format or big-endian format.





In little-endian format, the byte with the lowest address in a word is the least significant byte of the word. The byte with the highest address in a word is the most significant. The byte at address 0 of the memory system connects to data lines 7–0.

In big-endian format, the byte with the lowest address in a word is the most significant byte of the word. The byte with the highest address in a word is the least significant. The byte at address 0 of the memory system connects to data lines 7–0.

Cortex-M1 always accesses code in little-endian format. Little-endian is the default memory format for ARM processors. The processor contains a configuration option that enables the user to select either the little-endian or big-endian format during implementation.

# **Subsystem Restrictions**

The fixed memory map of the Cortex-M1 places certain restrictions on the processor subsystem.

The Code region encompasses two CoreAHB/CoreAHBLite 256 MB slots (0 and 1). If the Data region of the memory map is being mapped to a device (RAM, for example), this must be mapped to AHB slot 2 or 3.

- 1. If the user has internal or external RAM mapped to the Data space and is using non-zero DTCM, there will be a wasted area of external RAM. If the user wishes to use non-zero DTCM, the external SRAM should be mapped up to the second SRAM space (0x60000000 and above).
- Similarly, if the user wishes to run from internal or external SRAM, with non-zero ITCM, this SRAM should be mapped to 0x60000000 and above. The RAM would be wasted if SRAM were remapped to location zero after boot.
- 3. If the user wishes to run from NVM, NVM can be left at location zero. The bottom part of NVM is copied over to the ITCM automatically by the Cortex-M1 wrapper after reset. From then on instruction fetches in the ITCM range would go to the ITCM, and instruction fetches above this space (but still within Code space) would go to NVM.

# **Exceptions**

The processor and the Nested Vectored Interrupt Controller (NVIC) prioritize and handle all exceptions. All exceptions are handled in Handler mode. The processor state is automatically stored to the stack on an exception, and automatically restored from the stack at the end of the exception handler Interrupt Service Routine (ISR). The following features enable efficient, low-latency exception handling:

- Automatic state saving and restoring. The processor pushes state registers on the stack before entering the ISR, and pops them after exiting the ISR with no instruction overhead.
- · Automatic reading of the vector table entry that contains the ISR address in code memory or data SRAM
- Closely-coupled interface between the processor and the NVIC to enable early processing of interrupts and processing
  of late-arriving interrupts with higher priority
- Configurable number of interrupts from 1 to 32
- · Four levels of interrupt priority that can be software-assigned
- Separate stacks for Handler and Thread modes if OS extensions are implemented
- ISR control transfer using the calling conventions of the C/C++ standard, Procedure Call Standard for the ARM Architecture (PCSAA)
- · Priority masking to support critical regions

# **Exception Types**

The types of exceptions supported in Cortex-M1 are listed in Table 4-1. A fault is an exception that results from an error condition. Faults can be reported synchronously or asynchronously to the instruction that caused them. In general, faults are reported synchronously. Faults caused by writes over the bus are asynchronous faults. A synchronous fault is always reported with the instruction that caused the fault. An asynchronous fault may vary in how it is reported with respect to the instruction that caused the fault.

Table 4-1 · Cortex-M1 Exceptions

| Position | Exception type                | Priority     | Description                                                                                                                     | Activated                   |
|----------|-------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------|
| _        | _                             | _            | Stack top is loaded from first entry of vector table on reset.                                                                  | _                           |
| 1        | Reset                         | -3 (highest) | Invoked on power-up and warm reset. On first instruction, drops to lowest priority. Thread mode.                                | Asynchronous                |
| 2        | Non-<br>maskable<br>Interrupt | -2           | Cannot be marked, prevented by activation, by any other exception. Cannot be preempted by any other exception other than Reset. | Asynchronous                |
| 3        | Hard Fault                    | -1           | All classes of Fault                                                                                                            | Synchronous or asynchronous |
| 4-10     | _                             | _            | Reserved.                                                                                                                       | _                           |
| 11       | SVCall                        | Configurable | System service call with SVC instruction.                                                                                       | Synchronous                 |
| 12-13    | _                             | _            | Reserved                                                                                                                        | _                           |
| 14       | PendSV                        | Configurable | Pendable request for system service. This is only pended by software.                                                           | Asynchronous                |
| 15       | SysTick                       | Configurable | System tick timer has fired.                                                                                                    | Asynchronous                |
| 16-48    | External<br>Interrupt         | Configurable | Asserted from outside the processor, IRQ[2 <sup>n-1</sup> :0], and fed through the NVIC (prioritized).                          | Asynchronous                |

# **Exception Priority**

In the processor exception model, priority determines when and how the processor handles exceptions. Software priority levels can be assigned to interrupts.

The NVIC supports software-assigned priority levels. A priority level from 0 (highest) to 3 (lowest) can be assigned to an interrupt by writing to the two-bit IP\_N field in an Interrupt Priority Register. Hardware priority ranges from -3 (highest), to 3 (lowest). By default, external interrupts have a hardware priority of 3, but hardware priority decreases with increasing interrupt number. The programmable priority level overrides the hardware priority. For example, IRQ(4) would have a default priority lower than IRQ(2), but if IRQ(4) is assigned a software priority of 1 and IRQ(2) is assigned 0, then IRQ(2) has priority over IRQ(4).





# **Servicing an Exception**

When the processor invokes an exception, it automatically pushes the following eight registers in two stages to the stack in the following order:

- 1. Processor Status Register (xPSR)
- 2. ReturnAddress ()
- 3. Link Register (LR)
- 4. R12
- 5. R3
- 6. R2
- 7. R1
- 8. R0

The SP is decremented by eight words on the completion of the stack push. Figure 4-3 shows the contents of the stack after an exception preempts the current program flow.



Figure 4-3 · Stack Contents from an Exception

When the processor services an exception, it takes the following steps before it enters the exception service routine.

- 1. It pushes 8 registers: xPSR, ReturnAddress (), R0, R1, R2, R3, R12, and LR on the selected stack
- 2. It reads the vector from the appropriate vector table entry, for example: (0x0) + (exception\_number \*4). This vector table read is done after all eight registers in the previous step are pushed onto the stack.
- 3. On Reset only, SP\_main is updated from the first entry in the vector table. Other exceptions do not modify SP\_main at this time and in this manner.
- 4. Updates PC with vector table read location. No other late-arriving exceptions can be processed until the first instruction of the exception starts to execute.
- 5. LR is set to EXC\_RETURN to exit from the exception.



Figure 4-4 shows a timing example of an exception entry without wait states.

Figure 4-4 · Exception Entry Without Wait States

After returning from the exception, the processor automatically pops the eight registers from the stack. The interrupt return value, EXC\_RETURN, passes as a data field in the LR, so exception functions can be normal C/C++ functions and do not require a veneer.

# **Clocking and Resets**

The processor requires only a single functional clock input, HCLK, and one reset signal, SYSRESETn. If debug is implemented, there is also a SWJ-DP clock and nTRST. The debug reset signal DBGRESETn relates to the debug logic clocked by HCLK.

The SYSRESETn signal resets the entire processor system with the exception of debug logic in two areas:

- Nested Vectored Interrupt Controller (NVIC)
- Debug subsystem

The TCMs and the register file cannot be reset by SYSRESETn or DBGRESETn.

#### **Reset Functionality**

The top-level wrapper (CortexM1Top) handles reset generation for the processor subsystem by combining various reset sources. This block also ensures that the various resets assert asynchronously to HCLK but negate synchronously to HCLK. The reset to the Cortex-M1 (SYSRESETn) is generated by the TcmInit block.

## **HRESETn**

HRESETn resets the AHB fabric and peripherals (except CoreWatchdog), and goes to the user top level (the top level of the CoreConsole subsystem). This signal is asserted whenever any of the following signals assert:

- NSYSRESET (external pushbutton/power-up reset)
- SYSRESETREQ (soft reset from Cortex-M1)
- WDOGRES (Watchdog reset from CoreWatchdog, if present in processor subsystem)

## **DBGRESETn**

DBGRESETn resets the debug circuitry within Cortex-M1. This is asserted if any of the following signals assert:

- NSYSRESET (external pushbutton/power-up reset)
- nTRST (Multiplexed version of FlashPro3 TRST or RealView TRST, depending on the selected active debugger interface)





#### **TcmInit**

TcmInit controls initialization of ITCM from AHB-mapped memory external to CortexM1Top (either on- or off-chip). This block detects the negation of HRESETn. At this point, it takes ownership of the AHB-Lite bus by means of multiplexing rather than arbitration. It performs a number of 32-bit reads in AHB space, starting at location 0x0, and copies the data into ITCM. The number of reads depends on the size of the ITCM. When the initialization of ITCM is complete, the ownership of the AHB bus is passed back to Cortex-M1. At this time, TcmInit also negates SYSRESETn to Cortex-M1.

# **Active Debug Interface Selection**

Depending on which debug interface the user requires (if any), the Debug Subsystem block multiplexes the appropriate debug signals to Cortex-M1. This block also instantiates the UJTAG macro and the uj\_jtag interface block.

# **Buffering**

The internally generated reset signals must be buffered with CLKINT buffers in this block. This is because the synthesis tools have no knowledge of the large fanout of these nets within the Cortex-M1 black box. The CLKINT buffers within the black box are removed at instantiation time by Designer. Note that there is no buffer added on HCLK in this block. The user must add a CLKINT buffer onto HCLK at the top-level.

# **Nested Vectored Interrupt Controller**

The NVIC facilitates low-latency exception and interrupt handling and implements System Control Registers. The NVIC supports reprioritizable interrupts. The NVIC and the processor core interface are closely coupled, which enables low-latency interrupt processing and efficient processing of late arriving interrupts. The NVIC registers are listed in Table 4-2 and can only be accessed using word transfers. Any attempt to write a halfword or byte individually causes corruption of the register bits. All NVIC registers and system debug registers are little-endian regardless of the endianness state of the processor.

Table 4-2 · Cortex-M1 NVIC Registers

| Name of Register                 | Туре | Address    | Reset Value |
|----------------------------------|------|------------|-------------|
| Irq 0 to 31 Set Enable Register  | R/W  | 0xE000E100 | 0x00000000  |
| Irq to 31 Clear Enable Register  | R/W  | 0xE000E180 | 0x00000000  |
| Irq to 31 Set Pending Register   | R/W  | 0xE000E200 | 0x00000000  |
| Irq to 31 Clear Pending Register | R/W  | 0xE000E280 | 0x00000000  |
| Priority 0 Register              | R/W  | 0xE000E400 | 0x00000000  |
| Priority 1 Register              | R/W  | 0xE000E404 | 0x00000000  |
| Priority 2 Register              | R/W  | 0xE000E408 | 0x00000000  |
| Priority 3 Register              | R/W  | 0xE000E40C | 0x00000000  |
| Priority 4 Register              | R/W  | 0xE000E410 | 0x00000000  |
| Priority 5 Register              | R/W  | 0xE000E414 | 0x00000000  |
| Priority 6 Register              | R/W  | 0xE000E418 | 0x00000000  |
| Priority 7 Register              | R/W  | 0xE000E41C | 0x00000000  |

### Cortex-M1 Features

The processor supports both level and pulse interrupts. A level interrupt is held asserted until it is cleared by the ISR accessing the device. A pulse interrupt is a variant of an edge model. The edge must be sampled on the rising edge of the processor clock (HCLK) instead of being asynchronous.

For level interrupts, if the signal is not deasserted before the return from the interrupt routine, the interrupt remains pending and re-activates. This is particularly useful for FIFO and buffer-based devices because it ensures that they drain either by a single ISR or by repeated invocations, with no extra work. This means that the device continues to assert the signal until the device is empty.

A pulse interrupt must be asserted for at least one HCLK cycle to enable the NVIC to latch the pending bit.

A pulse interrupt can be reasserted during the ISR so that the interrupt can be pending and active at the same time. If this occurs, the application design must ensure that a second pulse does not arrive before the first pulse is activated. The second pulse cannot set the pending bit and would have no effect, because the interrupt is already pending. However, if the interrupt is activated for at least one cycle, the NVIC latches the pending bit. After the ISR activates, the pending bit is cleared. After the bit is cleared if the interrupt is asserted again while it is activated, it can latch the pending bit again.





# **Software Development**

SoftConsole is the free-of-charge Actel software development environment that allows quick turn-around for C and C++ based projects targeting Cortex-M1 and other processor-based platforms available for use in Actel devices. SoftConsole allows users to create a project and transparently manages all compilation stages in order to generate a binary file ready to be used with the Cortex-M1 processor. SoftConsole includes a fully integrated debugger that offers easy access to memory contents, registers, and single-instruction execution. Programs developed with SoftConsole can be debugged on a target board or in the tool's simulator using the same uniform interface.

SoftConsole provides a flexible and easy-to-use graphical user interface for managing your software development projects. The tool gives you the ability to quickly develop and debug software programs and to implement them in Actel devices. SoftConsole enables users to edit and debug software programs, organize files, and configure settings in a project. This tool provides simultaneous access to multiple tool windows and the ability to quickly switch editing, debug, and synchronization views.

The compilation tools can be used to build C or C++ programs. The following tools are included in SoftConsole:

- SoftConsole Eclipse-based IDE
- · GCC Compiler
- · GDB Debugger
- · Support for program download and debug with FlashPro3

There are other tools available from ARM and third-party companies that can be purchased, including the RealView Development Suite, RealView Microcontroller Development Kit, and embedded workbench tools from IAR. The RealView and IAR tools feature compilers that offer a higher level of efficiency than the GCC compiler included in SoftConsole. If higher code density is required for an application than what can be achieved using GNU, Actel recommends that one of these other tools be purchased and used.

# **Cortex-M1 Design Entry Flow**

Libero IDE automatically manages Cortex-M1 through the tool flow when it is instantiated in a CoreConsole v1.3 project system design. The project system can consist of only the Cortex-M1 itself or it can include a range of subsystem and higher-level IP blocks. The overall flow is shown in Figure 6-1.



Figure 6-1 · Cortex-M1 Design Entry Flow

## **Design Flow if CoreConsole is Launched from Inside Libero IDE**

Users will typically launch CoreConsole from Libero IDE v8.x, though CoreConsole can also be used as a standalone tool. If CoreConsole is launched from Libero IDE, the CoreConsole design is located under the Libero IDE project folder. Import of the generated files by Libero IDE is transparent to the user.

## **Design Flow if CoreConsole is Used as Standalone Tool**

If CoreConsole is used as a standalone tool, the user must import the CoreConsole v1.3 project into Libero IDE v8.x by locating the CXF file for that project in the CoreConsole Libero IDE Export folder hierarchy. CoreConsole exports the generated files by default into the:

- CoreConsole\LiberoExport\<my\_coreconsole\_project>
- Where *CoreConsole* is the root folder of the CoreConsole installation, and <my\_coreconsole\_project> is the name of the project being generated. These files can be examined by navigating to the folder on your computer.
- When you install CoreConsole, you are given the option of selecting the name and location of the *CoreConsole* designs folder, in which case the files are output in <your\_selected\_folder>\LiberoExport\<my\_coreconsole\_project>.

## Cortex-M1 Design Entry Flow

The *LiberoExport* folder contains the full list of projects. Within each project folder is a common folder and project folder, as shown in Figure 6-2.



Figure 6-2 · CoreConsole\Libero Export Folder File Structure

The <my\_coreconsole\_project>.cxf file is an XML file that describes the layout and content of the design and is used by Libero IDE to import the CoreConsole project. Within the file set for each component there is a <comp\_n>.cxf XML file, which describes the sub-component of the design.

The my\_coresonsole\_project/my\_coreconsole\_project/my\_coreconsole\_project.cxf file must be imported into Libero IDE. Libero IDE copies the my\_coreconsole\_project folder and locates all the files in the appropriate locations in the Libero IDE workspace. Refer to the Actel Libero IDE User's Guide for more information on importing a CoreConsole project.

The Cortex-M1 files associated with this flow are shown in Figure 6-3. Normally the CoreConsole system project in Libero IDE consists of a range of RTL IP components alongside Cortex-M1. These components are implemented in a secure format that can only be read and used within the tools utilized by Libero IDE.



Libero IDE manages all the files imported from CoreConsole and passes them to the appropriate tools that it utilizes. The secure Cortex-M1 implementation is represented inside the IDE as CM1 when the RTL wrapper has been removed.





# Cortex-M1 Security

# **Cortex-M1 Security**

Cortex-M1 is delivered as a CDB file that the tools in Libero IDE can use to instantiate the processor core in a design. Similar to the earlier CoreMP7 ARM7 processor, the core is delivered in a black box that allows users to access the top-level I/O and use the core in Actel M1 devices, but not view the contents of the black box. The Cortex-M1 core top-level interface is visible (external ports that need to be routed to the rest of the design). Timing constraints and analysis are done at the interface of the Cortex-M1 core. The placement and routing of the Cortex-M1 within the FPGA fabric core is fixed. Libero IDE is aware of the core's placement and will fill in the unused tiles around the core with the IP blocks that users put together around Cortex-M1 in their CoreConsole project system. The Cortex-M1 black box cannot be unlocked and can only be programmed into an Actel M1 device.

# **Bus Functional Model (BFM)**

During the development of an FPGA-based SoC, various stages of testing can be performed. This may involve some or all of the following approaches:

- Hardware simulation, using Verilog or VHDL
- · Software simulation, using a host-based instruction set simulator (ISS) of the processor
- Hardware and software co-verification, using a full functional model of the processor in Verilog or VHDL form, or using a tool such as Seamless

Due to the rapid prototyping capability of FPGAs, integration of hardware and software often occurs earlier in the development cycle than it would for ASIC targets. Therefore, hardware and software co-verification (which can be very slow) are not as critical an issue for most FPGA-based system-level designs.

The CoreConsole IP Development Platform (IDP) provides a means for stitching together IP blocks using a bus fabric of choice. It generates a system testbench, controlled by a script-driven BFM of the Cortex-M1 processor. The BFM allows the developer to model bus transactions. This approach allows verification of connectivity of the various IP blocks and the system memory map presented to Cortex-M1 by the rest of the hardware.

This section describes the following aspects of Cortex-M1 BFM:

- Functionality
- · BFM usage flow
- · BFM script language
- Platforms
- Supported simulation tools
- Example BFM use case

# **BFM Usage Flow**

The BFM is part of an overall system test strategy, so it is helpful to look at the context in which it is used. Figure 7-1 shows the various components within a typical system-level testbench.



Figure 7-1 · BFM Simulation Environment

In Figure 7-1 it is assumed that the processor subsystem has been specified by selecting the processor, bus fabric, IP blocks, and the memory system using CoreConsole.

When building the system, the memory map of the system must be specified. Based on this information, CoreConsole generates the following outputs:

- Verilog/VHDL model of SoC subsystem
- · Verilog/VHDL models of IP cores
- Cortex-M1 BFM
- BFM test script
- System-level skeleton testbench





The BFM acts as a pin-for-pin replacement for the Cortex-M1 in the project system. It initiates cycle-accurate bus transactions on the native Cortex-M1 bus. It has no knowledge, however, of real Cortex-M1 instructions.

At this point, the BFM may be used to run a basic test of the system, using the skeleton system testbench. CoreConsole uses known attributes (from SPIRIT IP-XACT XML descriptions) of any registers or addressable locations within the IP cores, together with the user-defined memory map to generate a basic BFM script. This script does a write to and/or read from all accessible locations. It has knowledge of whether registers are read-only, read/write, clear-on-read, and write-only. From this it can decide what the expected data should be on reads.

The system Verilog/VHDL can be edited to add new design blocks in the above diagram. The system-level testbench can be edited to include tasks that test any newly added functionality, or for adding stubs to allow more complex system testing involving the IP cores. The BFM input scripts may also be manually enhanced, so that you can test access to register locations in newly added logic. In this way, stimuli can be provided to the system from the inside (via the Cortex-M1 BFM), as well as from the outside (via testbench tasks).

# **Functionality**

This section describes the specific functionality of the Cortex-M1 BFM. The BFM models the Cortex-M1 external bus. Specifically, it models the following bus signals:

- ADDR address bus
- WDATA write data bus
- RDATA read data bus
- WRITE indicates write access
- CLKEN clock enable

The BFM also models the following control signals:

- CLK clock
- SIZE memory access width

# **Cortex-M1 Pin Compatibility**

The BFM model is pin-for-pin compatible with the Cortex-M1. This allows the model to be dropped into the space that would be occupied by the processor core in the system testbench.

# **Cortex-M1 Bus Cycle Accuracy**

The bus cycle timings for the Cortex-M1 external bus signals are specified in the *Cortex-M1 Technical Reference Manual*. The Cortex-M1 BFM models these bus cycles exactly.

# **Scripting**

In order to provide a simple and extensible mechanism for providing stimuli to the BFM, a BFM scripting language is defined (see "BFM Script Language" on page 34). This allows initiating writes to system resources, reads from system resources (with or without checking of expected data), and waiting for interrupt events.

# **Self-Checking**

The BFM gives a pass/fail indication at the end of a test run. This is based on whether or not any of the expected data read checks failed.

### **Endianness**

The BFM supports both big and little-endian memory configurations. For byte and halfword transfers, it reads and writes data from/to the appropriate data lanes.

### **Interrupt Support**

The BFM has the ability to wait for the Cortex-M1 interrupt lines to be triggered before proceeding with the remainder of the test script.

## **Log File Generation**

The BFM generates output messages to the console of the simulation tool, and also generates an HTML log file. The messages in this file are color-coded so that any errors can be easily identified.

# **BFM Script Language**

The following script commands are defined for use by the BFM:

## Write

The write command causes the BFM to perform a write to a specified offset, within the memory map range of a specified system resource.

### **Syntax**

write width resource\_name byte\_offset data;

Width: This takes on the enumerated values of W, H or B, for word, halfword, or byte respectively.

resource\_name: This is a string containing the user-friendly instance name of the resource being accessed, as defined by the user in the memory map (when input to CoreConsole).

byte\_offset: This is the offset from the base of the resource, in bytes. It is specified as a hexadecimal value.

Data: This is the data to be written. It is specified as a hexadecimal value.

Example:

write W videoCodec 20 11223344;

#### Read

The read command causes the BFM to perform a read of a specified offset, within the memory map range of a specified system resource.

#### **Syntax**

### read width resource\_name byte\_offset;

Width: This takes on the enumerated values of W, H or B, for word, halfword, or byte respectively.

resource\_name: This is a string containing the user-friendly instance name of the resource being accessed, as defined by the user in the memory map (when input to CoreConsole).

byte\_offset: This is the offset from the base of the resource, in bytes. It is specified as a hexadecimal value.

Example:

read W videoCodec 20;



### Readcheck

The readcheck command causes the BFM to perform a read of a specified offset, within the memory map range of a specified system resource and to compare the read value with the expected value provided.

## **Syntax**

#### readcheck width resource\_name byte\_offset data;

Width: This takes on the enumerated values of W, H or B, for word, halfword, or byte respectively.

resource\_name: This is a string containing the user-friendly instance name of the resource being accessed, as defined by the user in the memory map (when input to CoreConsole).

byte\_offset: This is the offset from the base of the resource, in bytes. It is specified as a hexadecimal value.

Data: This is the expected read data. It is specified as a hexadecimal value.

Example:

readcheck W videoCodec 20 11223344;

## poll

This command continuously reads a specified location until a requested value is obtained. This command allows one or more bits of the read data to be masked out. This allows, for example, poll waiting for a ready bit to be set, while ignoring the values of the other bits in the location being read.

### **Syntax**

poll width resource\_name byte\_offset data\_bitmask;

### width

This takes on the enumerated values of W, H, or B, for word, halfword, or byte.

### resource\_name

This is a string containing the user-friendly instance name of the resource being accessed.

## byte\_offset

This is the offset from the base of the resource, in bytes. It is specified as a hexadecimal value.

### bitmask

The bitmask is ANDed with the read data and the result is then compared to the bitmask itself. If equal, then all the bits of interest are at their required value and the poll command is complete. If not equal, then the polling continues.

### wait

This command causes the BFM script to stall for a specified number of clock periods.

### **Syntax**

wait num\_clock\_ticks;

### num\_clock\_ticks

This is the number of CoreMP7 clock periods, during which the BFM stalls (doesn't initiate any bus transactions).

# **Timing Shell**

A timing shell is provided for each Cortex-M1 variant wrapped around the BFM itself. The BFM is bus cycle accurate and performs setup/hold checks to model output propagation delays.

# **Example BFM Use Case**

This section goes through an example use case of the Cortex-M1 BFM. In this system, the developer requires two additional Actel IP cores: the Core10/100 and the CoreUART.

### **SPIRIT IP-XACT Attributes**

CoreConsole has access to a database of Actel IP cores and a list of attributes for each core. These attributes are organized according to the SPIRIT IP-XACT specification in XML. For example, in the case of the CoreUART, the attributes would indicate that there are three registers, as shown in Table 7-1.

OffsetRegisterRead/WriteWidth0UART Status RegisterRByte1UART Tx DataWByte2UART Rx DataRByte

Table 7-1 · SPIRIT IP-XACT Attributes

Based on these attributes, CoreConsole can determine when generating the BFM script that there are three locations corresponding to the UART, which may be accessed. In this case, none of the registers are RW, so there will not be any self-checking that can be performed for the UART. Nevertheless, the bus transactions do take place and the cycles can be viewed in a waveform of the simulator.

### **Automatic BFM Script**

At this point, having run CoreConsole to completion, a BFM script is available. This would look similar to the following:

```
read B uart 0;
write B uart 4 bb;
read B uart 8;
write B mac 30 11;
readcheck B mac 11;
```

#### **Run BFM**

The developer may run the BFM with the automatic script, or edit the script to put in bus transactions to/from any new logic that has been added to the SoC. For example, transactions to/from the registers in a new block could be added.

The skeleton system-level testbench, generated by CoreConsole can also be modified to add some external resources (for example, models of SSRAM and FLASH) and some high-level tasks.





## Example BFM Use Case

When running the system simulation, messages appear in the console window of the simulation tool:

```
# read B uart 0;
Reading offset 0 of uart - data = 0x1c
# write B uart 4 bb;
Writing 0xbb to offset 4 of uart
# read B uart 8;
Reading offset 8 of uart - data = 0x28
# write B mac 30 11;
Writing 0x11 to offset 30 of mac
# readcheck B mac 11;
Reading offset 0 of mac
Error: Expected data = 0x11, Actual data = 0x22
Test Failed, with 1 error
```

# **Debug**

The ARM Debug Architecture uses a protocol converter box to allow the debugger to talk via a JTAG port directly to the core. The scan chains in the core that are required for test are re-used for debugging.

# **About Debug**

Debug facilitates the following:

- · Core halt
- Core stepping
- · Core register access
- · Read/Write to TCMs
- · Read/Write to AHB address space
- · Breakpoints
- · Watchpoints

The main debug components are as follows:

- · Debug control registers to access and control debugging of the core
- · BreakPoint Unit (BPU) to implement breakpoints
- · Data Watchpoint (DW) unit to implement watchpoints and trigger resources
- · Debug memory interfaces to access external ITCM and DTCM
- · ROM table

All debug components exist on the internal Private Peripheral Bus (PPB), 0xE000ED30 to 0xE000EEFF. Access to the debug components, debug control, and configuration are only available when the debug extension is present. You can never access the debug components from the processor, even when debug is present.

Debug control and data access occur through the Advanced High-Performance Bus-Access Port (AHB-AP).

Access includes the following:

- The AHB-PPB. Through this bus, the debugger can access debug, including the following:
  - debug control
  - DW unit
  - BPU unit
  - The ROM Table
  - TCMs, if configured
- The AHB address space. The AHB slaves in the debug system always expect 32-bit AHB transfers. If a byte or halfword access is created from the DAP, the transfer is extended to a 32-bit access and all 32 bits in the register are accessed. Figure 1-1 on page 7 shows the structure of the debug system, indicating how the AHB-AP can access each of the system components and external buses.

# JTAG Debug Interface

The Actel FlashPro3 programmer, which is used to program the FPGA and debug the Cortex-M1 core using SoftConsole, uses a standard 10-pin JTAG interface, shown in Figure 8-1. Other debuggers, including those in the RealView and IAR tools, use a 20-pin, 2.54 mm pitch IDC connector (Figure 8-2 on page 41). The cable can be used to mate with a keyed box header on the target.



Figure 8-1 · JTAG 10-Pin Connector Pinout

The signals on the 10-pin JTAG interface are shown in Table 8-1.

Table 8-1 · JTAG 10-Pin Connector Signals

| Signal            | Description                                                           |
|-------------------|-----------------------------------------------------------------------|
| V <sub>PUMP</sub> | 3.3 V Programming voltage                                             |
| GND               | Signal reference                                                      |
| TCK               | JTAG clock                                                            |
| TDI               | JTAG data input to device                                             |
| TDO               | JTAG data output from device                                          |
| TMS               | JTAG mode select                                                      |
| nTRST             | Programmable output pin may be set to Off, Toggle, LOW, or HIGH Level |
| VJTAG             | Reference voltage from the target board                               |
| N/C               | Programmer does not connect to this pin                               |





| $VT_{REF}$ | 1      | • | • 2  | V <sub>SUPPLY</sub> |
|------------|--------|---|------|---------------------|
| nTRST      | 3      | • | • 4  | GND                 |
| TDI        | 5      | • | • 6  | GND                 |
| TMS        | 7 ا    | • | • 8  | GND                 |
| TCK        | 9      | • | • 10 | GND                 |
| RTCK       | 11     | • | • 12 | GND                 |
| TDO        | L 13   | • | • 14 | GND                 |
| nSRST      | 15     | • | • 16 | GND                 |
| DBGRQ      | 17     | • | • 18 | GND                 |
| DBGAC      | (   19 | • | • 20 | GND                 |
|            |        |   |      | I                   |

Figure 8-2 · JTAG 20-Pin Connector Pinout

The signals on the 20-pin JTAG interface are shown in Table 8-2.

Table 8-2 · JTAG 20-Pin Connector Signals

| Signal | I/O              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DBGACK | _                | This pin is connected in the RealView ICE run control unit, but is not supported in the current release of the software. It is reserved for compatibility with other equipment to be used as a debug acknowledge signal from the target system. Actel recommends pulling this signal LOW on the target.                                                                                                                                                       |
| DBGRQ  | _                | This pin is connected in the RealView ICE run control unit, but is not supported in the current release of the software. It is reserved for compatibility with other equipment, to be used as a debug request signal to the target system. This signal is tied LOW. When applicable, RealView ICE uses the core's scanchain 2 to put the core in debug state. Actel recommends pulling this signal LOW on the target.                                         |
| GND    | _                | Ground.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| nSRST  | Input/<br>output | Open collector output from RealView ICE to the target system reset. This is also an input to RealView ICE so that a reset initiated on the target can be reported to the debugger. This pin must be pulled HIGH on the target to avoid unintentional resets when there is no connection.                                                                                                                                                                      |
| nTRST  | Output           | Open collector output from RealView ICE to the Reset signal on the target JTAG port. This pin must be pulled HIGH on the target to avoid unintentional resets when there is no connection.                                                                                                                                                                                                                                                                    |
| RTCK   | Input            | Return Test Clock signal from the target JTAG port to RealView ICE. Some targets must synchronize the JTAG inputs to internal clocks. To assist in meeting this requirement, a returned, and retimed, TCK can be used to dynamically control the TCK rate. RealView ICE provides Adaptive Clock Timing, which waits for TCK changes to be echoed correctly before making further changes. Targets that do not have to process TCK can simply ground this pin. |
| ТСК    | Output           | Test Clock signal from RealView ICE to the target JTAG port. Actel recommends pulling this pin LOW on the target.                                                                                                                                                                                                                                                                                                                                             |

## Debug

Table 8-2 · JTAG 20-Pin Connector Signals (continued)

| Signal              | I/O    | Description                                                                                                                                                                                                                                                                                                          |
|---------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TDI                 | Output | Test Data In signal from RealView ICE to the target JTAG port. Actel recommends pulling this pin HIGH on the target.                                                                                                                                                                                                 |
| TDO                 | Input  | Test Data Out from the target JTAG port to RealView ICE. Actel recommends pulling this pin HIGH on the target.                                                                                                                                                                                                       |
| TMS                 | Output | Test Mode signal from RealView ICE to the target JTAG port. This pin must be pulled HIGH on the target to avoid adverse effects from any spurious TCKs when there is no connection.                                                                                                                                  |
| V <sub>SUPPLY</sub> | Input  | This pin is not connected in the RealView ICE run control unit. It is reserved for compatibility with other equipment to be used as a power feed from the target system.                                                                                                                                             |
| VT <sub>REF</sub>   | Input  | This is the target reference voltage. It indicates that the target has power, and It must be at least 0.628 V. $VT_{REF}$ is normally fed from $V_{DD}$ on the target hardware and might have a series resistor (though this is not recommended). There is a 10 kB pull-down resistor on $VT_{REF}$ in RealView ICE. |



# **AC Parameters**

This section gives the AC timing parameters of the Cortex-M1 processor. The AC parameters are valid for v2.4 of Cortex-M1, operating under worst-case commercial conditions. In the following tables, all times are in nanoseconds. The parameter definitions are as follows:

- PERIOD is the minimum supported period of the clock signal specified.
- SETUP is the minimum time for which the specified input signal must be valid before the rising edge of the specified clock.
- HOLD is the minimum time for which the specified input signal must remain valid after the rising edge of the specified clock.
- CLOCK2OUT is the maximum propagation delay from the rising edge of the specified clock to the specified output signal to be guaranteed valid.

The AC parameters for the M1AFS250-2 no-debug variant are shown in Table 9-1.

Table 9-1 · M1AFS250-2 No-Debug Variant AC Parameters

| Parameter | Clock    | Signal    | Timing                          |
|-----------|----------|-----------|---------------------------------|
| PERIOD    | HCLK     | HCLK      | 15.5350                         |
| PERIOD    | SWCLKTCK | SWCLKTCK  | 15.5350                         |
| SETUP     | HCLK     | HRDATA    | 2.0880 0.1345<br>(2.088/15.535) |
| SETUP     | HCLK     | HREADY    | 5.5840 0.3595<br>(5.584/15.535) |
| SETUP     | HCLK     | HRESP     | 5.1580 0.3321<br>(5.158/15.535) |
| SETUP     | HCLK     | IRQ       | 4.4060 0.2837<br>(4.406/15.535) |
| SETUP     | HCLK     | NMI       | 4.3700 0.2814<br>(4.370/15.535) |
| HOLD      | HCLK     | HRDATA    | -0.2350                         |
| HOLD      | HCLK     | HREADY    | -0.7670                         |
| HOLD      | HCLK     | HRESP     | -1.4470                         |
| HOLD      | HCLK     | IRQ       | -0.5520                         |
| HOLD      | HCLK     | NMI       | -0.5010                         |
| SETUP     | HCLK     | SYSRESETn | 0.2870 0.0186<br>(0.287/15.535) |
| HOLD      | HCLK     | SYSRESETn | 0.1050                          |
| CLOCK2OUT | HCLK     | HADDR     | 3.1640 0.2038<br>(3.164/15.535) |
| CLOCK2OUT | HCLK     | HPROT     | 2.4940 0.1606<br>(2.494/15.535) |
| CLOCK2OUT | HCLK     | HSIZE     | 1.1100 0.0716<br>(1.110/15.535) |

Table 9-1 · M1AFS250-2 No-Debug Variant AC Parameters (continued)

| Parameter | Clock | Signal      | Timing                          |
|-----------|-------|-------------|---------------------------------|
| CLOCK2OUT | HCLK  | HTRANS      | 4.3760 0.2818<br>(4.376/15.535) |
| CLOCK2OUT | HCLK  | HWDATA      | 2.9670 0.1911<br>(2.967/15.535) |
| CLOCK2OUT | HCLK  | HWRITE      | 2.4360 0.1569<br>(2.436/15.535) |
| CLOCK2OUT | HCLK  | LOCKUP      | 2.5600 0.1649<br>(2.560/15.535) |
| CLOCK2OUT | HCLK  | SYSRESETREQ | 1.7790 0.1146<br>(1.779/15.535) |

The AC parameters for the M1AFS600-2 no-debug variant are shown in Table 9-2.

Table 9-2 · M1AFS600-2 No-Debug Variant AC Parameters

| Parameter | Clock    | Signal    | Timing                          |
|-----------|----------|-----------|---------------------------------|
| PERIOD    | HCLK     | HCLK      | 14.5850                         |
| PERIOD    | SWCLKTCK | SWCLKTCK  | 14.5850                         |
| SETUP     | HCLK     | HRDATA    | 1.7790 0.1221<br>(1.779/14.585) |
| SETUP     | HCLK     | HREADY    | 5.2140 0.3576<br>(5.214/14.585) |
| SETUP     | HCLK     | HRESP     | 4.6230 0.3171<br>(4.623/14.585) |
| SETUP     | HCLK     | IRQ       | 4.5860 0.3145<br>(4.586/14.585) |
| SETUP     | HCLK     | NMI       | 3.9270 0.2693<br>(3.927/14.585) |
| HOLD      | HCLK     | HRDATA    | -0.1780                         |
| HOLD      | HCLK     | HREADY    | -0.8520                         |
| HOLD      | HCLK     | HRESP     | -0.9440                         |
| HOLD      | HCLK     | IRQ       | -0.7930                         |
| HOLD      | HCLK     | NMI       | -0.6570                         |
| SETUP     | HCLK     | SYSRESETn | 0.2940 0.0203<br>(0.294/14.585) |
| HOLD      | HCLK     | SYSRESETn | 0.1060                          |
| CLOCK2OUT | HCLK     | HADDR     | 3.8040 0.2609<br>(3.804/14.585) |





Table 9-2 · M1AFS600-2 No-Debug Variant AC Parameters (continued)

| Parameter | Clock | Signal      | Timing                          |
|-----------|-------|-------------|---------------------------------|
| CLOCK2OUT | HCLK  | HPROT       | 2.4290 0.1666<br>(2.429/14.585) |
| CLOCK2OUT | HCLK  | HSIZE       | 1.1620 0.0798<br>(1.162/14.585) |
| CLOCK2OUT | HCLK  | HTRANS      | 4.4080 0.3023<br>(4.408/14.585) |
| CLOCK2OUT | HCLK  | HWDATA      | 3.3250 0.2281<br>(3.325/14.585) |
| CLOCK2OUT | HCLK  | HWRITE      | 3.0250 0.2075<br>(3.025/14.585) |
| CLOCK2OUT | HCLK  | LOCKUP      | 2.6280 0.1803<br>(2.628/14.585) |
| CLOCK2OUT | HCLK  | SYSRESETREQ | 1.8860 0.1294<br>(1.886/14.585) |

The AC parameters for the M1AFS600-2 debug variant are shown in Table 9-3.

Table 9-3 · M1AFS600-2 Debug Variant AC Parameters

| Parameter | Clock    | Signal   | Timing                          |
|-----------|----------|----------|---------------------------------|
| PERIOD    | HCLK     | HCLK     | 15.8350                         |
| PERIOD    | SWCLKTCK | SWCLKTCK | 15.4580                         |
| SETUP     | HCLK     | EDBGRQ   | 2.8420 0.1796<br>(2.842/15.835) |
| SETUP     | HCLK     | HRDATA   | 4.0340 0.2549<br>(4.034/15.835) |
| SETUP     | HCLK     | HREADY   | 6.3150 0.3989<br>(6.315/15.835) |
| SETUP     | HCLK     | HRESP    | 5.2580 0.3321<br>(5.258/15.835) |
| SETUP     | HCLK     | IRQ      | 4.4180 0.2791<br>(4.418/15.835) |
| SETUP     | HCLK     | NMI      | 3.7160 0.2348<br>(3.716/15.835) |
| SETUP     | SWCLKTCK | SWDITMS  | 4.5490 0.2944<br>(4.549/15.458) |
| SETUP     | SWCLKTCK | TDI      | 3.1070 0.2011<br>(3.107/15.458) |
| HOLD      | HCLK     | EDBGRQ   | -1.0880                         |

## **AC Parameters**

Table 9-3 · M1AFS600-2 Debug Variant AC Parameters (continued)

| Parameter | Clock    | Signal    | Timing                          |
|-----------|----------|-----------|---------------------------------|
| HOLD      | HCLK     | HRDATA    | -0.2820                         |
| HOLD      | HCLK     | HREADY    | -0.4130                         |
| HOLD      | HCLK     | HRESP     | -1.1850                         |
| HOLD      | HCLK     | IRQ       | -0.9750                         |
| HOLD      | HCLK     | NMI       | -0.5480                         |
| HOLD      | SWCLKTCK | SWDITMS   | 0.0400                          |
| HOLD      | SWCLKTCK | TDI       | 0.0860                          |
| SETUP     | HCLK     | DBGRESETn | 0.2800 0.0178<br>(0.280/15.835) |
| SETUP     | SWCLKTCK | DBGRESETn | 0.2390 0.0156<br>(0.239/15.458) |
| SETUP     | HCLK     | SYSRESETn | 0.2440 0.0155<br>(0.244/15.835) |
| SETUP     | SWCLKTCK | nTRST     | 2.5590 0.1656<br>(2.559/15.458) |
| HOLD      | HCLK     | DBGRESETn | 0.1310                          |
| HOLD      | SWCLKTCK | DBGRESETn | 2.0260                          |
| HOLD      | HCLK     | SYSRESETn | 0.1420                          |
| HOLD      | SWCLKTCK | nTRST     | 0.7810                          |
| CLOCK2OUT | HCLK     | HADDR     | 4.4560 0.2815<br>(4.456/15.835) |
| CLOCK2OUT | HCLK     | HALTED    | 3.6590 0.2312<br>(3.659/15.835) |
| CLOCK2OUT | HCLK     | HBURST    | 6.8760 0.4343<br>(6.876/15.835) |
| CLOCK2OUT | HCLK     | HMASTLOCK | 5.2090 0.3291<br>(5.209/15.835) |
| CLOCK2OUT | HCLK     | HPROT     | 4.8700 0.3076<br>(4.870/15.835) |
| CLOCK2OUT | HCLK     | HSIZE     | 4.7010 0.2970<br>(4.701/15.835) |
| CLOCK2OUT | HCLK     | HTRANS    | 5.3260 0.3364<br>(5.326/15.835) |
| CLOCK2OUT | HCLK     | HWDATA    | 3.4210 0.2161<br>(3.421/15.835) |







Table 9-3 · M1AFS600-2 Debug Variant AC Parameters (continued)

| Parameter | Clock    | Signal      | Timing                          |
|-----------|----------|-------------|---------------------------------|
| CLOCK2OUT | HCLK     | HWRITE      | 4.0920 0.2585<br>(4.092/15.835) |
| CLOCK2OUT | HCLK     | LOCKUP      | 3.0010 0.1896<br>(3.001/15.835) |
| CLOCK2OUT | HCLK     | SYSRESETREQ | 2.4060 0.1520<br>(2.406/15.835) |
| CLOCK2OUT | SWCLKTCK | JTAGTOP     | 5.6000 0.3624<br>(5.600/15.458) |
| CLOCK2OUT | SWCLKTCK | TDO         | 1.8160 0.1176<br>(1.816/15.458) |
| CLOCK2OUT | SWCLKTCK | nTDOEN      | 1.6630 0.1077<br>(1.663/15.458) |

The AC parameters for the M1AFS1500-2 no-debug variant are shown in Table 9-4.

Table 9-4 · M1AFS1500-2 No-Debug Variant AC Parameters

| Parameter | Clock    | Signal    | Timing                          |
|-----------|----------|-----------|---------------------------------|
| PERIOD    | HCLK     | HCLK      | 15.6680                         |
| PERIOD    | SWCLKTCK | SWCLKTCK  | 15.6680                         |
| SETUP     | HCLK     | HRDATA    | 1.4830 0.0948<br>(1.483/15.668) |
| SETUP     | HCLK     | HREADY    | 5.2200 0.3333<br>(5.220/15.668) |
| SETUP     | HCLK     | HRESP     | 5.2550 0.3355<br>(5.255/15.668) |
| SETUP     | HCLK     | IRQ       | 4.3750 0.2793<br>(4.375/15.668) |
| SETUP     | HCLK     | NMI       | 4.3690 0.2789<br>(4.369/15.668) |
| HOLD      | HCLK     | HRDATA    | -0.0390                         |
| HOLD      | HCLK     | HREADY    | -0.8660                         |
| HOLD      | HCLK     | HRESP     | -0.8140                         |
| HOLD      | HCLK     | IRQ       | -0.5320                         |
| HOLD      | HCLK     | NMI       | -0.6570                         |
| SETUP     | HCLK     | SYSRESETn | 0.2890 0.0185<br>(0.289/15.668) |
| HOLD      | HCLK     | SYSRESETn | 0.1360                          |

Table 9-4 · M1AFS1500-2 No-Debug Variant AC Parameters (continued)

| Parameter | Clock | Signal      | Timing                           |
|-----------|-------|-------------|----------------------------------|
| CLOCK2OUT | HCLK  | HADDR       | 3.7690 0.2407<br>(3.769/15.668)  |
| CLOCK2OUT | HCLK  | HPROT       | 2.6650 0.1702<br>(2.665/15.668)  |
| CLOCK2OUT | HCLK  | HSIZE       | 1.4040 0.0897<br>(1.404/15.668)  |
| CLOCK2OUT | HCLK  | HTRANS      | 5.1580 0.3293 (5.158/<br>15.668) |
| CLOCK2OUT | HCLK  | HWDATA      | 3.4720 0.2217<br>(3.472/15.668)  |
| CLOCK2OUT | HCLK  | HWRITE      | 2.9520 0.1885<br>(2.952/15.668)  |
| CLOCK2OUT | HCLK  | LOCKUP      | 2.7300 0.1743<br>(2.730/15.668)  |
| CLOCK2OUT | HCLK  | SYSRESETREQ | 2.0560 0.1313<br>(2.056/15.668)  |

The AC parameters for the M1AFS1500-2 debug variant are shown in Table 9-5.

Table 9-5 · M1AFS1500-2 Debug Variant AC Parameters

| Parameter | Clock    | Signal   | Timing                          |
|-----------|----------|----------|---------------------------------|
| PERIOD    | HCLK     | HCLK     | 15.8460                         |
| PERIOD    | SWCLKTCK | SWCLKTCK | 13.8220                         |
| SETUP     | HCLK     | EDBGRQ   | 1.4670 0.0927<br>(1.467/15.846) |
| SETUP     | HCLK     | HRDATA   | 3.8990 0.2462<br>(3.899/15.846) |
| SETUP     | HCLK     | HREADY   | 6.5110 0.4110<br>(6.511/15.846) |
| SETUP     | HCLK     | HRESP    | 5.2120 0.3290<br>(5.212/15.846) |
| SETUP     | HCLK     | IRQ      | 4.2570 0.2687<br>(4.257/15.846) |
| SETUP     | HCLK     | NMI      | 3.6640 0.2313<br>(3.664/15.846) |
| SETUP     | SWCLKTCK | SWDITMS  | 3.8650 0.2797<br>(3.865/13.822) |





Table 9-5 · M1AFS1500-2 Debug Variant AC Parameters (continued)

| Parameter | Clock    | Signal    | Timing                            |
|-----------|----------|-----------|-----------------------------------|
| SETUP     | SWCLKTCK | TDI       | 2.8850 0.2088<br>(2.885/13.822)   |
| HOLD      | HCLK     | EDBGRQ    | -0.3320                           |
| HOLD      | HCLK     | HRDATA    | -0.0950                           |
| HOLD      | HCLK     | HREADY    | -0.3310                           |
| HOLD      | HCLK     | HRESP     | -0.6840                           |
| HOLD      | HCLK     | IRQ       | -0.5970                           |
| HOLD      | HCLK     | NMI       | -0.5070                           |
| HOLD      | SWCLKTCK | SWDITMS   | -0.4540                           |
| HOLD      | SWCLKTCK | TDI       | -0.1220                           |
| SETUP     | HCLK     | DBGRESETn | 0.2690 0.0171<br>(0.269/15.846)   |
| SETUP     | SWCLKTCK | DBGRESETn | 0.3780 0.0274<br>(0.378/13.822)   |
| SETUP     | HCLK     | SYSRESETn | 0.2650 0.0168<br>(0.265/15.846)   |
| SETUP     | SWCLKTCK | nTRST     | 1.9730 0.1428<br>(1.973/13.822)   |
| HOLD      | HCLK     | DBGRESETn | 0.1570                            |
| HOLD      | SWCLKTCK | DBGRESETn | 1.8960                            |
| HOLD      | HCLK     | SYSRESETn | 0.1740                            |
| HOLD      | SWCLKTCK | nTRST     | 0.2220                            |
| CLOCK2OUT | HCLK     | HADDR     | 5.0960 0.3217<br>(5.096/15.846)   |
| CLOCK2OUT | HCLK     | HALTED    | 3.1900 0.2014<br>(3.190/15.846)   |
| CLOCK2OUT | HCLK     | HBURST    | 10.7490 0.6784<br>(10.749/15.846) |
| CLOCK2OUT | HCLK     | HMASTLOCK | 5.8170 0.3672<br>(5.817/15.846)   |
| CLOCK2OUT | HCLK     | HPROT     | 4.5220 0.2855<br>(4.522/15.846)   |
| CLOCK2OUT | HCLK     | HSIZE     | 5.3220 0.3360<br>(5.322/15.846)   |
| CLOCK2OUT | HCLK     | HTRANS    | 6.3270 0.3994<br>(6.327/15.846)   |

Table 9-5 · M1AFS1500-2 Debug Variant AC Parameters (continued)

| Parameter | Clock    | Signal      | Timing                          |
|-----------|----------|-------------|---------------------------------|
| CLOCK2OUT | HCLK     | HWDATA      | 4.2210 0.2665<br>(4.221/15.846) |
| CLOCK2OUT | HCLK     | HWRITE      | 4.2620 0.2691<br>(4.262/15.846) |
| CLOCK2OUT | HCLK     | LOCKUP      | 3.3890 0.2140<br>(3.389/15.846) |
| CLOCK2OUT | HCLK     | SYSRESETREQ | 2.0580 0.1300<br>(2.058/15.846) |
| CLOCK2OUT | SWCLKTCK | JTAGTOP     | 4.3890 0.3176<br>(4.389/13.822) |
| CLOCK2OUT | SWCLKTCK | TDO         | 1.2180 0.0882<br>(1.218/13.822) |
| CLOCK2OUT | SWCLKTCK | nTDOEN      | 1.2180 0.0882<br>(1.218/13.822) |

The AC parameters for the M1AGL250V2 no-debug variant are shown in Table 9-6.

Table 9-6  $\cdot$  M1AGL250V2 No-Debug Variant AC Parameters

| Parameter | Clock    | Signal   | Timing                            |
|-----------|----------|----------|-----------------------------------|
| PERIOD    | HCLK     | HCLK     | 37.8390                           |
| PERIOD    | SWCLKTCK | SWCLKTCK | 37.8390                           |
| SETUP     | HCLK     | HRDATA   | 7.8250 0.2069<br>(7.825/37.839)   |
| SETUP     | HCLK     | HREADY   | 14.0920 0.3725<br>(14.092/37.839) |
| SETUP     | HCLK     | HRESP    | 15.0450 0.3977<br>(15.045/37.839) |
| SETUP     | HCLK     | IRQ      | 12.6180 0.3336<br>(12.618/37.839) |
| SETUP     | HCLK     | NMI      | 12.1480 0.3211<br>(12.148/37.839) |
| HOLD      | HCLK     | HRDATA   | -0.2430                           |
| HOLD      | HCLK     | HREADY   | -1.4830                           |
| HOLD      | HCLK     | HRESP    | -1.7250                           |
| HOLD      | HCLK     | IRQ      | -1.5430                           |
| HOLD      | HCLK     | NMI      | -1.6080                           |





Table 9-6 · M1AGL250V2 No-Debug Variant AC Parameters (continued)

| Parameter | Clock | Signal      | Timing                            |
|-----------|-------|-------------|-----------------------------------|
| SETUP     | HCLK  | SYSRESETn   | 0.2900 0.0078<br>(0.290/37.839)   |
| HOLD      | HCLK  | SYSRESETn   | 0.1810                            |
| CLOCK2OUT | HCLK  | HADDR       | 12.4220 0.3284<br>(12.422/37.839) |
| CLOCK2OUT | HCLK  | HPROT       | 5.9070 0.1562<br>(5.907/37.839)   |
| CLOCK2OUT | HCLK  | HSIZE       | 2.9140 0.0771<br>(2.914/37.839)   |
| CLOCK2OUT | HCLK  | HTRANS      | 12.8000 0.3384<br>(12.800/37.839) |
| CLOCK2OUT | HCLK  | HWDATA      | 6.9300 0.1832<br>(6.930/37.839)   |
| CLOCK2OUT | HCLK  | HWRITE      | 6.1270 0.1620<br>(6.127/37.839)   |
| CLOCK2OUT | HCLK  | LOCKUP      | 6.8040 0.1799<br>(6.804/37.839)   |
| CLOCK2OUT | HCLK  | SYSRESETREQ | 4.4160 0.1168<br>(4.416/37.839)   |

The AC parameters for the M1AGL250V5 no-debug variant are shown in Table 9-7.

Table 9-7  $\cdot$  M1AGL250V5 No-Debug Variant AC Parameters

| Parameter | Clock    | Signal   | Timing                            |
|-----------|----------|----------|-----------------------------------|
| PERIOD    | HCLK     | HCLK     | 23.2480                           |
| PERIOD    | SWCLKTCK | SWCLKTCK | 23.2480                           |
| SETUP     | HCLK     | HRDATA   | 3.6370 0.1565<br>(3.637/23.248)   |
| SETUP     | HCLK     | HREADY   | 9.1290 0.3928<br>(9.129/23.248)   |
| SETUP     | HCLK     | HRESP    | 10.0430 0.4321<br>(10.043/23.248) |
| SETUP     | HCLK     | IRQ      | 7.2540 0.3121<br>(7.254/23.248)   |
| SETUP     | HCLK     | NMI      | 8.9340 0.3844<br>(8.934/23.248)   |
| HOLD      | HCLK     | HRDATA   | -0.1930                           |
| HOLD      | HCLK     | HREADY   | -1.1250                           |

Table 9-7  $\cdot$  M1AGL250V5 No-Debug Variant AC Parameters (continued)

| Parameter | Clock | Signal      | Timing                          |
|-----------|-------|-------------|---------------------------------|
| HOLD      | HCLK  | HRESP       | -1.2140                         |
| HOLD      | HCLK  | IRQ         | -0.9870                         |
| HOLD      | HCLK  | NMI         | -1.2220                         |
| SETUP     | HCLK  | SYSRESETn   | 0.2700 0.0117<br>(0.270/23.248) |
| HOLD      | HCLK  | SYSRESETn   | 0.1420                          |
| CLOCK2OUT | HCLK  | HADDR       | 5.0180 0.2159<br>(5.018/23.248) |
| CLOCK2OUT | HCLK  | HPROT       | 4.0840 0.1758<br>(4.084/23.248) |
| CLOCK2OUT | HCLK  | HSIZE       | 1.7660 0.0761<br>(1.766/23.248) |
| CLOCK2OUT | HCLK  | HTRANS      | 9.5320 0.4101<br>(9.532/23.248) |
| CLOCK2OUT | HCLK  | HWDATA      | 4.0450 0.1741<br>(4.045/23.248) |
| CLOCK2OUT | HCLK  | HWRITE      | 3.9300 0.1691<br>(3.930/23.248) |
| CLOCK2OUT | HCLK  | LOCKUP      | 5.7830 0.2489<br>(5.783/23.248) |
| CLOCK2OUT | HCLK  | SYSRESETREQ | 2.6730 0.1151<br>(2.673/23.248) |

The AC parameters for the M1AGL600V2 no-debug variant are shown in Table 9-8.

Table 9-8  $\cdot$  M1AGL600V2 No-Debug Variant AC Parameters

| Parameter | Clock    | Signal   | Timing                            |
|-----------|----------|----------|-----------------------------------|
| PERIOD    | HCLK     | HCLK     | 38.7470                           |
| PERIOD    | SWCLKTCK | SWCLKTCK | 38.7470                           |
| SETUP     | HCLK     | HRDATA   | 4.7450 0.1226<br>(4.745/38.747)   |
| SETUP     | HCLK     | HREADY   | 16.3540 0.4222<br>(16.354/38.747) |
| SETUP     | HCLK     | HRESP    | 13.9410 0.3599<br>(13.941/38.747) |
| SETUP     | HCLK     | IRQ      | 11.2130 0.2895<br>(11.213/38.747) |







Table 9-8  $\cdot$  M1AGL600V2 No-Debug Variant AC Parameters (continued)

| Parameter | Clock | Signal      | Timing                            |
|-----------|-------|-------------|-----------------------------------|
| SETUP     | HCLK  | NMI         | 8.6750 0.2240<br>(8.675/38.747)   |
| HOLD      | HCLK  | HRDATA      | -0.1600                           |
| HOLD      | HCLK  | HREADY      | -1.1330                           |
| HOLD      | HCLK  | HRESP       | -0.4990                           |
| HOLD      | HCLK  | IRQ         | -1.7990                           |
| HOLD      | HCLK  | NMI         | -1.0830                           |
| SETUP     | HCLK  | SYSRESETn   | 0.3400 0.0089<br>(0.340/38.747)   |
| HOLD      | HCLK  | SYSRESETn   | 0.1900                            |
| CLOCK2OUT | HCLK  | HADDR       | 9.5670 0.2470<br>(9.567/38.747)   |
| CLOCK2OUT | HCLK  | HPROT       | 5.8000 0.1498<br>(5.800/38.747)   |
| CLOCK2OUT | HCLK  | HSIZE       | 2.9090 0.0752<br>(2.909/38.747)   |
| CLOCK2OUT | HCLK  | HTRANS      | 12.9280 0.3338<br>(12.928/38.747) |
| CLOCK2OUT | HCLK  | HWDATA      | 6.9080 0.1784<br>(6.908/38.747)   |
| CLOCK2OUT | HCLK  | HWRITE      | 6.6310 0.1712<br>(6.631/38.747)   |
| CLOCK2OUT | HCLK  | LOCKUP      | 6.8800 0.1777<br>(6.880/38.747)   |
| CLOCK2OUT | HCLK  | SYSRESETREQ | 4.4540 0.1151<br>(4.454/38.747)   |

The AC parameters for the M1AGL600V2 debug variant are shown in Table 9-9.

Table 9-9 · M1AGL600V2 Debug Variant AC Parameters

| Parameter | Clock    | Signal   | Timing                            |
|-----------|----------|----------|-----------------------------------|
| PERIOD    | HCLK     | HCLK     | 38.7790                           |
| PERIOD    | SWCLKTCK | SWCLKTCK | 28.1460                           |
| SETUP     | HCLK     | EDBGRQ   | 3.9340 0.1015<br>(3.934/38.779)   |
| SETUP     | HCLK     | HRDATA   | 13.3760 0.3450<br>(13.376/38.779) |

## **AC Parameters**

Table 9-9 · M1AGL600V2 Debug Variant AC Parameters (continued)

| Parameter | Clock    | Signal    | Timing                             |
|-----------|----------|-----------|------------------------------------|
| SETUP     | HCLK     | HREADY    | 23.7890 0.6136<br>(23.789/38.779)  |
| SETUP     | HCLK     | HRESP     | 19.8220 0.5113<br>(19.822/38.779)  |
| SETUP     | HCLK     | IRQ       | 13.8760 0.3579<br>(13.876/38.779)  |
| SETUP     | HCLK     | NMI       | 9.3070 0.2401<br>(9.307/38.779)    |
| SETUP     | SWCLKTCK | SWDITMS   | 10.9890 0.3905<br>(10.989/28.146)  |
| SETUP     | SWCLKTCK | TDI       | 7.7900 0.2769<br>(7.790/28.146)    |
| HOLD      | HCLK     | EDBGRQ    | -0.5970                            |
| HOLD      | HCLK     | HRDATA    | -1.0200                            |
| HOLD      | HCLK     | HREADY    | -0.2670                            |
| HOLD      | HCLK     | HRESP     | -1.4320                            |
| HOLD      | HCLK     | IRQ       | -1.6320                            |
| HOLD      | HCLK     | NMI       | -0.6310                            |
| HOLD      | SWCLKTCK | SWDITMS   | -0.9760                            |
| HOLD      | SWCLKTCK | TDI       | 0.0550                             |
| SETUP     | HCLK     | DBGRESETn | 0.3610 0.0094<br>(0.361/38.779)    |
| SETUP     | SWCLKTCK | DBGRESETn | -0.1120 -0.0039<br>(-0.112/28.146) |
| SETUP     | HCLK     | SYSRESETn | 0.2770 0.0072<br>(0.277/38.779)    |
| SETUP     | SWCLKTCK | nTRST     | 4.8630 0.1729<br>(4.863/28.146)    |
| HOLD      | HCLK     | DBGRESETn | 0.2280                             |
| HOLD      | SWCLKTCK | DBGRESETn | 3.0980                             |
| HOLD      | HCLK     | SYSRESETn | 0.2510                             |
| HOLD      | SWCLKTCK | nTRST     | 0.6790                             |
| CLOCK2OUT | HCLK     | HADDR     | 14.9830 0.3865<br>(14.983/38.779)  |
| CLOCK2OUT | HCLK     | HALTED    | 6.4270 0.1658<br>(6.427/38.779)    |







Table 9-9 · M1AGL600V2 Debug Variant AC Parameters (continued)

| Parameter | Clock    | Signal      | Timing                            |
|-----------|----------|-------------|-----------------------------------|
| CLOCK2OUT | HCLK     | HBURST      | 24.2940 0.6266<br>(24.294/38.779) |
| CLOCK2OUT | HCLK     | HMASTLOCK   | 13.5260 0.3489<br>(13.526/38.779) |
| CLOCK2OUT | HCLK     | HPROT       | 11.2070 0.2891<br>(11.207/38.779) |
| CLOCK2OUT | HCLK     | HSIZE       | 11.0790 0.2858<br>(11.079/38.779) |
| CLOCK2OUT | HCLK     | HTRANS      | 18.2680 0.4712<br>(18.268/38.779) |
| CLOCK2OUT | HCLK     | HWDATA      | 9.3510 0.2412<br>(9.351/38.779)   |
| CLOCK2OUT | HCLK     | HWRITE      | 9.7630 0.2519<br>(9.763/38.779)   |
| CLOCK2OUT | HCLK     | LOCKUP      | 6.7720 0.1747<br>(6.772/38.779)   |
| CLOCK2OUT | HCLK     | SYSRESETREQ | 5.9050 0.1524<br>(5.905/38.779)   |
| CLOCK2OUT | SWCLKTCK | JTAGTOP     | 8.0430 0.2859<br>(8.043/28.146)   |
| CLOCK2OUT | SWCLKTCK | TDO         | 7.5720 0.2691<br>(7.572/28.146)   |
| CLOCK2OUT | SWCLKTCK | nTDOEN      | 3.2180 0.1144<br>(3.218/28.146)   |

The AC parameters for the M1AGL600V5 no-debug variant are shown in Table 9-10.

Table 9-10 · M1AGL600V5 No-Debug Variant AC Parameters

| Parameter | Clock    | Signal   | Timing                            |
|-----------|----------|----------|-----------------------------------|
| PERIOD    | HCLK     | HCLK     | 24.6210                           |
| PERIOD    | SWCLKTCK | SWCLKTCK | 24.6210                           |
| SETUP     | HCLK     | HRDATA   | 3.5540 0.1444<br>(3.554/24.621)   |
| SETUP     | HCLK     | HREADY   | 11.4190 0.4639<br>(11.419/24.621) |
| SETUP     | HCLK     | HRESP    | 7.6820 0.3121<br>(7.682/24.621)   |

Table 9-10 · M1AGL600V5 No-Debug Variant AC Parameters (continued)

| Parameter | Clock | Signal      | Timing                          |
|-----------|-------|-------------|---------------------------------|
| SETUP     | HCLK  | IRQ         | 6.9380 0.2819<br>(6.938/24.621) |
| SETUP     | HCLK  | NMI         | 6.3020 0.2561<br>(6.302/24.621) |
| HOLD      | HCLK  | HRDATA      | -0.1310                         |
| HOLD      | HCLK  | HREADY      | -0.9320                         |
| HOLD      | HCLK  | HRESP       | -1.0070                         |
| HOLD      | HCLK  | IRQ         | -1.0070                         |
| HOLD      | HCLK  | NMI         | -1.1000                         |
| SETUP     | HCLK  | SYSRESETn   | 0.2660 0.0109<br>(0.266/24.621) |
| HOLD      | HCLK  | SYSRESETn   | 0.1450                          |
| CLOCK2OUT | HCLK  | HADDR       | 5.8840 0.2391<br>(5.884/24.621) |
| CLOCK2OUT | HCLK  | НРКОТ       | 3.4740 0.1412<br>(3.474/24.621) |
| CLOCK2OUT | HCLK  | HSIZE       | 1.7940 0.0730<br>(1.794/24.621) |
| CLOCK2OUT | HCLK  | HTRANS      | 8.7980 0.3574<br>(8.798/24.621) |
| CLOCK2OUT | HCLK  | HWDATA      | 4.6210 0.1878<br>(4.621/24.621) |
| CLOCK2OUT | HCLK  | HWRITE      | 3.9110 0.1589<br>(3.911/24.621) |
| CLOCK2OUT | HCLK  | LOCKUP      | 4.3650 0.1774<br>(4.365/24.621) |
| CLOCK2OUT | HCLK  | SYSRESETREQ | 2.7280 0.1109<br>(2.728/24.621) |

The AC parameters for the M1AGL600V5 debug variant are shown in Table 9-11.

Table 9-11 · M1AGL600V5 Debug Variant AC Parameters

| Parameter | Clock    | Signal   | Timing                          |
|-----------|----------|----------|---------------------------------|
| PERIOD    | HCLK     | HCLK     | 23.8290                         |
| PERIOD    | SWCLKTCK | SWCLKTCK | 18.6540                         |
| SETUP     | HCLK     | EDBGRQ   | 2.4790 0.1041<br>(2.479/23.829) |





Table 9-11 · M1AGL600V5 Debug Variant AC Parameters (continued)

| Parameter | Clock    | Signal    | Timing                            |
|-----------|----------|-----------|-----------------------------------|
| SETUP     | HCLK     | HRDATA    | 10.3360 0.4339<br>(10.336/23.829) |
| SETUP     | HCLK     | HREADY    | 12.8220 0.5382<br>(12.822/23.829) |
| SETUP     | HCLK     | HRESP     | 11.8260 0.4964<br>(11.826/23.829) |
| SETUP     | HCLK     | IRQ       | 7.4770 0.3139<br>(7.477/23.829)   |
| SETUP     | HCLK     | NMI       | 5.7330 0.2407<br>(5.733/23.829)   |
| SETUP     | SWCLKTCK | SWDITMS   | 5.8580 0.3141<br>(5.858/18.654)   |
| SETUP     | SWCLKTCK | TDI       | 3.1610 0.1696<br>(3.161/18.654)   |
| HOLD      | HCLK     | EDBGRQ    | -0.4590                           |
| HOLD      | HCLK     | HRDATA    | -0.4830                           |
| HOLD      | HCLK     | HREADY    | -0.6050                           |
| HOLD      | HCLK     | HRESP     | -1.0860                           |
| HOLD      | HCLK     | IRQ       | -1.0600                           |
| HOLD      | HCLK     | NMI       | -0.5700                           |
| HOLD      | SWCLKTCK | SWDITMS   | -0.6880                           |
| HOLD      | SWCLKTCK | TDI       | 0.4130                            |
| SETUP     | HCLK     | DBGRESETn | 0.3020 0.0128<br>(0.302/23.829)   |
| SETUP     | SWCLKTCK | DBGRESETn | 0.2690 0.0145<br>(0.269/18.654)   |
| SETUP     | HCLK     | SYSRESETn | 0.2630 0.0111<br>(0.263/23.829)   |
| SETUP     | SWCLKTCK | nTRST     | 1.4090 0.0756<br>(1.409/18.654)   |
| HOLD      | HCLK     | DBGRESETn | 0.1870                            |
| HOLD      | SWCLKTCK | DBGRESETn | 2.7680                            |
| HOLD      | HCLK     | SYSRESETn | 0.1650                            |
| HOLD      | SWCLKTCK | nTRST     | 1.0450                            |
| CLOCK2OUT | HCLK     | HADDR     | 9.0930 0.3817<br>(9.093/23.829)   |

Table 9-11 · M1AGL600V5 Debug Variant AC Parameters (continued)

| Parameter | Clock    | Signal      | Timing                            |
|-----------|----------|-------------|-----------------------------------|
| CLOCK2OUT | HCLK     | HALTED      | 3.6240 0.1522<br>(3.624/23.829)   |
| CLOCK2OUT | HCLK     | HBURST      | 14.0430 0.5894<br>(14.043/23.829) |
| CLOCK2OUT | HCLK     | HMASTLOCK   | 8.6390 0.3626<br>(8.639/23.829)   |
| CLOCK2OUT | HCLK     | HPROT       | 7.8140 0.3280<br>(7.814/23.829)   |
| CLOCK2OUT | HCLK     | HSIZE       | 8.4320 0.3540<br>(8.432/23.829)   |
| CLOCK2OUT | HCLK     | HTRANS      | 12.2140 0.5127<br>(12.214/23.829) |
| CLOCK2OUT | HCLK     | HWDATA      | 6.1560 0.2584<br>(6.156/23.829)   |
| CLOCK2OUT | HCLK     | HWRITE      | 6.7680 0.2841<br>(6.768/23.829)   |
| CLOCK2OUT | HCLK     | LOCKUP      | 4.3260 0.1816<br>(4.326/23.829)   |
| CLOCK2OUT | HCLK     | SYSRESETREQ | 3.4980 0.1469<br>(3.498/23.829)   |
| CLOCK2OUT | SWCLKTCK | JTAGTOP     | 7.1530 0.3836<br>(7.153/18.654)   |
| CLOCK2OUT | SWCLKTCK | TDO         | 2.7610 0.1481<br>(2.761/18.654)   |
| CLOCK2OUT | SWCLKTCK | nTDOEN      | 2.7610 0.1481<br>(2.761/18.654)   |

The AC parameters for the M1A3P250-2 no-debug variant are shown in Table 9-12.

Table 9-12 · M1A3P250-2 No-Debug Variant AC Parameters

| Parameter | Clock    | Signal   | Timing                          |
|-----------|----------|----------|---------------------------------|
| PERIOD    | HCLK     | HCLK     | 15.2140                         |
| PERIOD    | SWCLKTCK | SWCLKTCK | 15.2140                         |
| SETUP     | HCLK     | HRDATA   | 2.0650 0.1358<br>(2.065/15.214) |
| SETUP     | HCLK     | HREADY   | 5.2010 0.3420<br>(5.201/15.214) |







Table 9-12 · M1A3P250-2 No-Debug Variant AC Parameters (continued)

| Parameter | Clock | Signal      | Timing                          |
|-----------|-------|-------------|---------------------------------|
| SETUP     | HCLK  | HRESP       | 5.0780 0.3339<br>(5.078/15.214) |
| SETUP     | HCLK  | IRQ         | 4.6320 0.3046<br>(4.632/15.214) |
| SETUP     | HCLK  | NMI         | 4.4890 0.2952<br>(4.489/15.214) |
| HOLD      | HCLK  | HRDATA      | -0.2120                         |
| HOLD      | HCLK  | HREADY      | -0.9700                         |
| HOLD      | HCLK  | HRESP       | -0.9160                         |
| HOLD      | HCLK  | IRQ         | -0.8330                         |
| HOLD      | HCLK  | NMI         | -0.7320                         |
| SETUP     | HCLK  | SYSRESETn   | 0.2480 0.0164<br>(0.248/15.214) |
| HOLD      | HCLK  | SYSRESETn   | 0.1260                          |
| CLOCK2OUT | HCLK  | HADDR       | 2.7900 0.1835<br>(2.790/15.214) |
| CLOCK2OUT | HCLK  | HPROT       | 2.3750 0.1562<br>(2.375/15.214) |
| CLOCK2OUT | HCLK  | HSIZE       | 1.0900 0.0717<br>(1.090/15.214) |
| CLOCK2OUT | HCLK  | HTRANS      | 4.2940 0.2823<br>(4.294/15.214) |
| CLOCK2OUT | HCLK  | HWDATA      | 2.8100 0.1848<br>(2.810/15.214) |
| CLOCK2OUT | HCLK  | HWRITE      | 2.4210 0.1592<br>(2.421/15.214) |
| CLOCK2OUT | HCLK  | LOCKUP      | 3.0180 0.1985<br>(3.018/15.214) |
| CLOCK2OUT | HCLK  | SYSRESETREQ | 2.1770 0.1432<br>(2.177/15.214) |

The AC parameters for the M1A3P600-2 no-debug variant are shown in Table 9-13.

Table 9-13 · M1A3P600-2 No-Debug Variant AC Parameters

| Parameter | Clock    | Signal   | Timing  |
|-----------|----------|----------|---------|
| PERIOD    | HCLK     | HCLK     | 15.5180 |
| PERIOD    | SWCLKTCK | SWCLKTCK | 15.5180 |

Table 9-13 · M1A3P600-2 No-Debug Variant AC Parameters (continued)

| Parameter | Clock | Signal      | Timing                          |
|-----------|-------|-------------|---------------------------------|
| SETUP     | HCLK  | HRDATA      | 1.7280 0.1115<br>(1.728/15.518) |
| SETUP     | HCLK  | HREADY      | 5.2380 0.3376<br>(5.238/15.518) |
| SETUP     | HCLK  | HRESP       | 4.8200 0.3107<br>(4.820/15.518) |
| SETUP     | HCLK  | IRQ         | 4.6660 0.3008<br>(4.666/15.518) |
| SETUP     | HCLK  | NMI         | 3.9320 0.2535<br>(3.932/15.518) |
| HOLD      | HCLK  | HRDATA      | -0.1420                         |
| HOLD      | HCLK  | HREADY      | -0.7710                         |
| HOLD      | HCLK  | HRESP       | -0.7630                         |
| HOLD      | HCLK  | IRQ         | -0.8100                         |
| HOLD      | HCLK  | NMI         | -0.8080                         |
| SETUP     | HCLK  | SYSRESETn   | 0.2550 0.0165<br>(0.255/15.518) |
| HOLD      | HCLK  | SYSRESETn   | 0.1400                          |
| CLOCK2OUT | HCLK  | HADDR       | 3.5190 0.2269<br>(3.519/15.518) |
| CLOCK2OUT | HCLK  | HPROT       | 2.1260 0.1371<br>(2.126/15.518) |
| CLOCK2OUT | HCLK  | HSIZE       | 1.1560 0.0746<br>(1.156/15.518) |
| CLOCK2OUT | HCLK  | HTRANS      | 5.3520 0.3450<br>(5.352/15.518) |
| CLOCK2OUT | HCLK  | HWDATA      | 2.6660 0.1719<br>(2.666/15.518) |
| CLOCK2OUT | HCLK  | HWRITE      | 2.5100 0.1618<br>(2.510/15.518) |
| CLOCK2OUT | HCLK  | LOCKUP      | 2.5970 0.1675<br>(2.597/15.518) |
| CLOCK2OUT | HCLK  | SYSRESETREQ | 1.8200 0.1174<br>(1.820/15.518) |



The AC parameters for the M1A3P600-2 debug variant are shown in Table 9-14.

Table 9-14 · M1A3P600-2 Debug Variant AC Parameters

| Parameter | Clock    | Signal    | Timing                          |
|-----------|----------|-----------|---------------------------------|
| PERIOD    | HCLK     | HCLK      | 15.9250                         |
| PERIOD    | SWCLKTCK | SWCLKTCK  | 13.5520                         |
| SETUP     | HCLK     | EDBGRQ    | 3.9610 0.2488<br>(3.961/15.925) |
| SETUP     | HCLK     | HRDATA    | 5.1560 0.3239<br>(5.156/15.925) |
| SETUP     | HCLK     | HREADY    | 6.1210 0.3845<br>(6.121/15.925) |
| SETUP     | HCLK     | HRESP     | 6.7030 0.4210<br>(6.703/15.925) |
| SETUP     | HCLK     | IRQ       | 5.0320 0.3161<br>(5.032/15.925) |
| SETUP     | HCLK     | NMI       | 3.9750 0.2497<br>(3.975/15.925) |
| SETUP     | SWCLKTCK | SWDITMS   | 1.9020 0.1404<br>(1.902/13.552) |
| SETUP     | SWCLKTCK | TDI       | 2.3370 0.1725<br>(2.337/13.552) |
| HOLD      | HCLK     | EDBGRQ    | -1.5960                         |
| HOLD      | HCLK     | HRDATA    | -0.5490                         |
| HOLD      | HCLK     | HREADY    | -0.5780                         |
| HOLD      | HCLK     | HRESP     | -0.8650                         |
| HOLD      | HCLK     | IRQ       | -1.2040                         |
| HOLD      | HCLK     | NMI       | -0.6020                         |
| HOLD      | SWCLKTCK | SWDITMS   | 0.6190                          |
| HOLD      | SWCLKTCK | TDI       | 0.0700                          |
| SETUP     | HCLK     | DBGRESETn | 0.2520 0.0159<br>(0.252/15.925) |
| SETUP     | SWCLKTCK | DBGRESETn | 0.1900 0.0141<br>(0.190/13.552) |
| SETUP     | HCLK     | SYSRESETn | 0.2380 0.0150<br>(0.238/15.925) |
| SETUP     | SWCLKTCK | nTRST     | 2.5160 0.1858<br>(2.516/13.552) |
| HOLD      | HCLK     | DBGRESETn | 0.1860                          |

Table 9-14 · M1A3P600-2 Debug Variant AC Parameters (continued)

| Parameter | Clock    | Signal      | Timing                          |
|-----------|----------|-------------|---------------------------------|
| HOLD      | SWCLKTCK | DBGRESETn   | 1.8400                          |
| HOLD      | HCLK     | SYSRESETn   | 0.1730                          |
| HOLD      | SWCLKTCK | nTRST       | 0.7670                          |
| CLOCK2OUT | HCLK     | HADDR       | 5.8230 0.3658<br>(5.823/15.925) |
| CLOCK2OUT | HCLK     | HALTED      | 4.4810 0.2815<br>(4.481/15.925) |
| CLOCK2OUT | HCLK     | HBURST      | 9.2580 0.5815<br>(9.258/15.925) |
| CLOCK2OUT | HCLK     | HMASTLOCK   | 6.0270 0.3786<br>(6.027/15.925) |
| CLOCK2OUT | HCLK     | HPROT       | 3.7370 0.2348<br>(3.737/15.925) |
| CLOCK2OUT | HCLK     | HSIZE       | 4.5020 0.2828<br>(4.502/15.925) |
| CLOCK2OUT | HCLK     | HTRANS      | 6.7000 0.4208<br>(6.700/15.925) |
| CLOCK2OUT | HCLK     | HWDATA      | 3.9340 0.2471<br>(3.934/15.925) |
| CLOCK2OUT | HCLK     | HWRITE      | 5.1260 0.3220<br>(5.126/15.925) |
| CLOCK2OUT | HCLK     | LOCKUP      | 4.6130 0.2898<br>(4.613/15.925) |
| CLOCK2OUT | HCLK     | SYSRESETREQ | 2.6080 0.1639<br>(2.608/15.925) |
| CLOCK2OUT | SWCLKTCK | JTAGTOP     | 4.8360 0.3569<br>(4.836/13.552) |
| CLOCK2OUT | SWCLKTCK | TDO         | 2.0220 0.1493<br>(2.022/13.552) |
| CLOCK2OUT | SWCLKTCK | nTDOEN      | 3.3850 0.2499<br>(3.385/13.552) |

The AC parameters for the M1A3P1000-2 no-debug variant are shown in Table 9-15.

Table 9-15  $\cdot$  M1A3P1000-2 No-Debug Variant AC Parameters

| Parameter | Clock    | Signal   | Timing  |
|-----------|----------|----------|---------|
| PERIOD    | HCLK     | HCLK     | 14.7290 |
| PERIOD    | SWCLKTCK | SWCLKTCK | 14.7290 |





Table 9-15 · M1A3P1000-2 No-Debug Variant AC Parameters (continued)

| Parameter | Clock | Signal      | Timing                          |
|-----------|-------|-------------|---------------------------------|
| SETUP     | HCLK  | HRDATA      | 1.8850 0.1281<br>(1.885/14.729) |
| SETUP     | HCLK  | HREADY      | 5.3720 0.3648<br>(5.372/14.729) |
| SETUP     | HCLK  | HRESP       | 5.1080 0.3469<br>(5.108/14.729) |
| SETUP     | HCLK  | IRQ         | 4.1180 0.2797<br>(4.118/14.729) |
| SETUP     | HCLK  | NMI         | 3.8140 0.2590<br>(3.814/14.729) |
| HOLD      | HCLK  | HRDATA      | -0.1050                         |
| HOLD      | HCLK  | HREADY      | -0.4230                         |
| HOLD      | HCLK  | HRESP       | -0.7540                         |
| HOLD      | HCLK  | IRQ         | -0.3670                         |
| HOLD      | HCLK  | NMI         | -0.5730                         |
| SETUP     | HCLK  | SYSRESETn   | 0.2690 0.0184<br>(0.269/14.729) |
| HOLD      | HCLK  | SYSRESETn   | 0.1810                          |
| CLOCK2OUT | HCLK  | HADDR       | 3.8530 0.2617<br>(3.853/14.729) |
| CLOCK2OUT | HCLK  | HPROT       | 2.5390 0.1725<br>(2.539/14.729) |
| CLOCK2OUT | HCLK  | HSIZE       | 1.2340 0.0839<br>(1.234/14.729) |
| CLOCK2OUT | HCLK  | HTRANS      | 4.6970 0.3190<br>(4.697/14.729) |
| CLOCK2OUT | HCLK  | HWDATA      | 3.0630 0.2081<br>(3.063/14.729) |
| CLOCK2OUT | HCLK  | HWRITE      | 2.5020 0.1700<br>(2.502/14.729) |
| CLOCK2OUT | HCLK  | LOCKUP      | 1.9960 0.1356<br>(1.996/14.729) |
| CLOCK2OUT | HCLK  | SYSRESETREQ | 1.9280 0.1310<br>(1.928/14.729) |

## **AC Parameters**

The AC parameters for the M1A3P1000-2 debug variant are shown in Table 9-16.

Table 9-16 · M1A3P1000-2 Debug Variant AC Parameters

| Parameter | Clock    | Signal    | Timing                          |
|-----------|----------|-----------|---------------------------------|
| PERIOD    | HCLK     | HCLK      | 16.1480                         |
| PERIOD    | SWCLKTCK | SWCLKTCK  | 14.5740                         |
| SETUP     | HCLK     | EDBGRQ    | 1.6090 0.0997<br>(1.609/16.148) |
| SETUP     | HCLK     | HRDATA    | 4.0740 0.2524<br>(4.074/16.148) |
| SETUP     | HCLK     | HREADY    | 6.2630 0.3879<br>(6.263/16.148) |
| SETUP     | HCLK     | HRESP     | 4.8390 0.2998<br>(4.839/16.148) |
| SETUP     | HCLK     | IRQ       | 4.6030 0.2852<br>(4.603/16.148) |
| SETUP     | HCLK     | NMI       | 3.9750 0.2463<br>(3.975/16.148) |
| SETUP     | SWCLKTCK | SWDITMS   | 4.2720 0.2932<br>(4.272/14.574) |
| SETUP     | SWCLKTCK | TDI       | 2.5640 0.1760<br>(2.564/14.574) |
| HOLD      | HCLK     | EDBGRQ    | -0.3720                         |
| HOLD      | HCLK     | HRDATA    | -0.5550                         |
| HOLD      | HCLK     | HREADY    | -0.4220                         |
| HOLD      | HCLK     | HRESP     | -0.9340                         |
| HOLD      | HCLK     | IRQ       | -0.7480                         |
| HOLD      | HCLK     | NMI       | -0.6390                         |
| HOLD      | SWCLKTCK | SWDITMS   | 0.3620                          |
| HOLD      | SWCLKTCK | TDI       | 0.1100                          |
| SETUP     | HCLK     | DBGRESETn | 0.2760 0.0172<br>(0.276/16.148) |
| SETUP     | SWCLKTCK | DBGRESETn | 0.3370 0.0232<br>(0.337/14.574) |
| SETUP     | HCLK     | SYSRESETn | 0.2550 0.0159<br>(0.255/16.148) |
| SETUP     | SWCLKTCK | nTRST     | 1.7040 0.1170<br>(1.704/14.574) |
| HOLD      | HCLK     | DBGRESETn | 0.1850                          |





Table 9-16 · M1A3P1000-2 Debug Variant AC Parameters (continued)

| Parameter | Clock    | Signal      | Timing                          |
|-----------|----------|-------------|---------------------------------|
| HOLD      | SWCLKTCK | DBGRESETn   | 1.9700                          |
| HOLD      | HCLK     | SYSRESETn   | 0.1680                          |
| HOLD      | SWCLKTCK | nTRST       | 0.8510                          |
| CLOCK2OUT | HCLK     | HADDR       | 5.0300 0.3116<br>(5.030/16.148) |
| CLOCK2OUT | HCLK     | HALTED      | 3.7660 0.2333<br>(3.766/16.148) |
| CLOCK2OUT | HCLK     | HBURST      | 8.1880 0.5072<br>(8.188/16.148) |
| CLOCK2OUT | HCLK     | HMASTLOCK   | 5.6450 0.3497<br>(5.645/16.148) |
| CLOCK2OUT | HCLK     | HPROT       | 5.0890 0.3152<br>(5.089/16.148) |
| CLOCK2OUT | HCLK     | HSIZE       | 4.7170 0.2922<br>(4.717/16.148) |
| CLOCK2OUT | HCLK     | HTRANS      | 6.1230 0.3793<br>(6.123/16.148) |
| CLOCK2OUT | HCLK     | HWDATA      | 3.4950 0.2165<br>(3.495/16.148) |
| CLOCK2OUT | HCLK     | HWRITE      | 3.9910 0.2473<br>(3.991/16.148) |
| CLOCK2OUT | HCLK     | LOCKUP      | 4.0190 0.2490<br>(4.019/16.148) |
| CLOCK2OUT | HCLK     | SYSRESETREQ | 2.4620 0.1526<br>(2.462/16.148) |
| CLOCK2OUT | SWCLKTCK | JTAGTOP     | 4.1070 0.2819<br>(4.107/14.574) |
| CLOCK2OUT | SWCLKTCK | TDO         | 2.2800 0.1565<br>(2.280/14.574) |
| CLOCK2OUT | SWCLKTCK | nTDOEN      | 2.4560 0.1686<br>(2.456/14.574) |

The AC parameters for the M1A3PE1500-2 no-debug variant are shown in Table 9-17.

Table 9-17  $\cdot$  M1A3PE1500-2 No-Debug Variant AC Parameters

| Parameter | Clock    | Signal   | Timing  |
|-----------|----------|----------|---------|
| PERIOD    | HCLK     | HCLK     | 16.4090 |
| PERIOD    | SWCLKTCK | SWCLKTCK | 16.4090 |

## **AC Parameters**

Table 9-17 · M1A3PE1500-2 No-Debug Variant AC Parameters (continued)

| Parameter | Clock | Signal      | Timing                          |
|-----------|-------|-------------|---------------------------------|
| SETUP     | HCLK  | HRDATA      | 1.7200 0.1049<br>(1.720/16.409) |
| SETUP     | HCLK  | HREADY      | 4.5090 0.2749<br>(4.509/16.409) |
| SETUP     | HCLK  | HRESP       | 4.4710 0.2726<br>(4.471/16.409) |
| SETUP     | HCLK  | IRQ         | 4.3620 0.2659<br>(4.362/16.409) |
| SETUP     | HCLK  | NMI         | 3.9830 0.2428<br>(3.983/16.409) |
| HOLD      | HCLK  | HRDATA      | 0.0220                          |
| HOLD      | HCLK  | HREADY      | -0.5530                         |
| HOLD      | HCLK  | HRESP       | -0.6870                         |
| HOLD      | HCLK  | IRQ         | -0.4440                         |
| HOLD      | HCLK  | NMI         | -0.4340                         |
| SETUP     | HCLK  | SYSRESETn   | 0.2760 0.0169<br>(0.276/16.409) |
| HOLD      | HCLK  | SYSRESETn   | 0.1690                          |
| CLOCK2OUT | HCLK  | HADDR       | 3.9320 0.2397<br>(3.932/16.409) |
| CLOCK2OUT | HCLK  | HPROT       | 2.7370 0.1669<br>(2.737/16.409) |
| CLOCK2OUT | HCLK  | HSIZE       | 1.3610 0.0830<br>(1.361/16.409) |
| CLOCK2OUT | HCLK  | HTRANS      | 4.5460 0.2771<br>(4.546/16.409) |
| CLOCK2OUT | HCLK  | HWDATA      | 3.3300 0.2030<br>(3.330/16.409) |
| CLOCK2OUT | HCLK  | HWRITE      | 2.8480 0.1737<br>(2.848/16.409) |
| CLOCK2OUT | HCLK  | LOCKUP      | 2.7070 0.1651<br>(2.707/16.409) |
| CLOCK2OUT | HCLK  | SYSRESETREQ | 2.0840 0.1271<br>(2.084/16.409) |







The AC parameters for the M1A3PE1500-2 debug variant are shown in Table 9-18.

Table 9-18 · M1A3PE1500-2 Debug Variant AC Parameters

| PERIOD | HCLK     |           |                                 |
|--------|----------|-----------|---------------------------------|
|        |          | HCLK      | 16.2250                         |
| PERIOD | SWCLKTCK | SWCLKTCK  | 15.2160                         |
| SETUP  | HCLK     | EDBGRQ    | 1.4680 0.0906<br>(1.468/16.225) |
| SETUP  | HCLK     | HRDATA    | 3.8410 0.2368<br>(3.841/16.225) |
| SETUP  | HCLK     | HREADY    | 5.1610 0.3182<br>(5.161/16.225) |
| SETUP  | HCLK     | HRESP     | 5.2710 0.3250<br>(5.271/16.225) |
| SETUP  | HCLK     | IRQ       | 3.9820 0.2455<br>(3.982/16.225) |
| SETUP  | HCLK     | NMI       | 3.4340 0.2117<br>(3.434/16.225) |
| SETUP  | SWCLKTCK | SWDITMS   | 3.8400 0.2525<br>(3.840/15.216) |
| SETUP  | SWCLKTCK | TDI       | 3.2970 0.2168<br>(3.297/15.216) |
| HOLD   | HCLK     | EDBGRQ    | -0.2780                         |
| HOLD   | HCLK     | HRDATA    | -0.0500                         |
| HOLD   | HCLK     | HREADY    | -0.2640                         |
| HOLD   | HCLK     | HRESP     | -0.6820                         |
| HOLD   | HCLK     | IRQ_      | -0.6140                         |
| HOLD   | HCLK     | NMI       | -0.4880                         |
| HOLD   | SWCLKTCK | SWDITMS   | 0.0230                          |
| HOLD   | SWCLKTCK | TDI       | -0.2980                         |
| SETUP  | HCLK     | DBGRESETn | 0.2570 0.0159<br>(0.257/16.225) |
| SETUP  | SWCLKTCK | DBGRESETn | 0.3370 0.0222<br>(0.337/15.216) |
| SETUP  | HCLK     | SYSRESETn | 0.2300 0.0143<br>(0.230/16.225) |
| SETUP  | SWCLKTCK | nTRST     | 1.2860 0.0846<br>(1.286/15.216) |
| HOLD   | HCLK     | DBGRESETn | 0.1960                          |

## **AC Parameters**

Table 9-18 · M1A3PE1500-2 Debug Variant AC Parameters (continued)

| Parameter | Clock    | Signal      | Timing                          |
|-----------|----------|-------------|---------------------------------|
| HOLD      | SWCLKTCK | DBGRESETn   | 2.2660                          |
| HOLD      | HCLK     | SYSRESETn   | 0.2110                          |
| HOLD      | SWCLKTCK | nTRST       | 0.7560                          |
| CLOCK2OUT | HCLK     | HADDR       | 5.3530 0.3300<br>(5.353/16.225) |
| CLOCK2OUT | HCLK     | HALTED      | 3.3540 0.2068<br>(3.354/16.225) |
| CLOCK2OUT | HCLK     | HBURST      | 9.5990 0.5917<br>(9.599/16.225) |
| CLOCK2OUT | HCLK     | HMASTLOCK   | 6.7940 0.4188<br>(6.794/16.225) |
| CLOCK2OUT | HCLK     | HPROT       | 4.2540 0.2623<br>(4.254/16.225) |
| CLOCK2OUT | HCLK     | HSIZE       | 4.8790 0.3008<br>(4.879/16.225) |
| CLOCK2OUT | HCLK     | HTRANS      | 6.2620 0.3860<br>(6.262/16.225) |
| CLOCK2OUT | HCLK     | HWDATA      | 4.2920 0.2646<br>(4.292/16.225) |
| CLOCK2OUT | HCLK     | HWRITE      | 4.3680 0.2693<br>(4.368/16.225) |
| CLOCK2OUT | HCLK     | LOCKUP      | 3.6720 0.2264<br>(3.672/16.225) |
| CLOCK2OUT | HCLK     | SYSRESETREQ | 2.0300 0.1252<br>(2.030/16.225) |
| CLOCK2OUT | SWCLKTCK | JTAGTOP     | 4.7600 0.3129<br>(4.760/15.216) |
| CLOCK2OUT | SWCLKTCK | TDO         | 1.2410 0.0817<br>(1.241/15.216) |
| CLOCK2OUT | SWCLKTCK | nTDOEN      | 1.9160 0.1260<br>(1.916/15.216) |







# **Product Support**

Actel backs its products with various support services including Customer Service, a Customer Technical Support Center, a web site, an FTP site, electronic mail, and worldwide sales offices. This appendix contains information about contacting Actel and using these support services.

## **Customer Service**

Contact Customer Service for non-technical product support, such as product pricing, product upgrades, update information, order status, and authorization.

From Northeast and North Central U.S.A., call 650.318.4480

From Southeast and Southwest U.S.A., call 650. 318.4480

From South Central U.S.A., call 650.318.4434

From Northwest U.S.A., call 650.318.4434

From Canada, call 650.318.4480

From Europe, call 650.318.4252 or +44 (0) 1276 401 500

From Japan, call 650.318.4743

From the rest of the world, call 650.318.4743

Fax, from anywhere in the world 650.318.8044

# **Actel Customer Technical Support Center**

Actel staffs its Customer Technical Support Center with highly skilled engineers who can help answer your hardware, software, and design questions. The Customer Technical Support Center spends a great deal of time creating application notes and answers to FAQs. So, before you contact us, please visit our online resources. It is very likely we have already answered your questions.

# **Actel Technical Support**

Visit the Actel Customer Support website (www.actel.com/custsup/search.html) for more information and support. Many answers available on the searchable web resource include diagrams, illustrations, and links to other resources on the Actel web site.

## Website

You can browse a variety of technical and non-technical information on the Actel home page, at www.actel.com.

# Contacting the Customer Technical Support Center

Highly skilled engineers staff the Technical Support Center from 7:00 A.M. to 6:00 P.M., Pacific Time, Monday through Friday. Several ways of contacting the Center follow:

#### **Email**

You can communicate your technical questions to our email address and receive answers back by email, fax, or phone. Also, if you have design problems, you can email your design files to receive assistance. We constantly monitor the email account throughout the day. When sending your request to us, please be sure to include your full name, company name, and your contact information for efficient processing of your request.

The technical support email address is tech@actel.com.

## **Product Support**

## **Phone**

Our Technical Support Center answers all calls. The center retrieves information, such as your name, company name, phone number and your question, and then issues a case number. The Center then forwards the information to a queue where the first available application engineer receives the data and returns your call. The phone hours are from 7:00 A.M. to 6:00 P.M., Pacific Time, Monday through Friday. The Technical Support numbers are:

650.318.4460 800.262.1060

Customers needing assistance outside the US time zones can either contact technical support via email (tech@actel.com) or contact a local sales office. Sales office listings can be found at www.actel.com/contact/offices/index.html.





# Index

| A                                   | self-checking 33                                   |
|-------------------------------------|----------------------------------------------------|
| about Debug 39                      | -                                                  |
| Actel                               | J                                                  |
| electronic mail 69                  | JTAG Debug interface 40                            |
| telephone 70                        | , c                                                |
| web-based technical support 69      | K                                                  |
| ••                                  | key features 5                                     |
| В                                   | ,                                                  |
| benefits 5                          | N                                                  |
| BFM script language 34              | nested vectored interrupt controller 23            |
| read 34                             | nested vectored interrupt controller 25            |
| readcheck 35                        | P                                                  |
| write 34                            |                                                    |
| BFM usage flow 32                   | product support 69–70<br>customer service 69       |
| J                                   | electronic mail 69                                 |
| C                                   | technical support 69                               |
| clocking and resets 22              | telephone 70                                       |
| active debug interface selection 23 | programmer's model 15                              |
| buffering 23                        | main stack and process stack access 15             |
| contacting Actel                    | main stack and process stack access 15             |
| customer service 69                 | R                                                  |
| electronic mail 69                  | registers 16                                       |
| telephone 70                        | exception priority 20                              |
| web-based technical support 69      | exception types 20                                 |
| Cortex-M1 I/O signals 10            | exception types 20                                 |
| Cortex-M1 processor 7               | general purpose registers 16                       |
| Cortex-M1 security 29               | servicing an exception 21                          |
| Cortex-M1 SPIRIT description 9      | special purpose control register 17                |
| CortexM1Top (Cortex-M1top level) 9  | special purpose priority mask register 17          |
| customer service 69                 | special purpose program status registers (xPSR) 17 |
|                                     | subsystem restrictions 19                          |
| D                                   | ,                                                  |
| data types 15                       | S                                                  |
|                                     | supported Actel FPGA families 5                    |
| E                                   | utilization and performance 6                      |
| example BFM use case 36             | dimental und performance o                         |
| SPIRIT IP-XACT attributes 36        | T                                                  |
| external interface 13               | technical support 69                               |
| write buffer 14                     | Tightly Coupled Memory interface 14                |
|                                     | timing shell 36                                    |
| F                                   | tilling offen 30                                   |
| functionality 33                    | W                                                  |
| Cortex-M1 bus cycle accuracy 33     | web-based technical support 69                     |
| Cortex-M1 pin compatibility 33      | web based technical support 07                     |
| scripting 33                        |                                                    |



# For more information about Actel's products, visit our website at **www.actel.com**

Actel Corporation • 2061 Stierlin Court • Mountain View, CA 94043 • USA

Phone 650.318.4200 • Fax 650.318.4600 • Customer Service: 650.318.1010 • Customer Applications Center: 800.262.1060

Actel Europe Ltd. • River Court, Meadows Business Park • Station Approach, Blackwater • Camberley Surrey GU17 9AB • United Kingdom Phone +44 (0) 1276 609 300 • Fax +44 (0) 1276 607 540

Actel Japan • EXOS Ebisu Building 4F • 1-24-14 Ebisu Shibuya-ku • Tokyo 150 • Japan

Phone +81.03.3445.7671 • Fax +81.03.3445.7668 • www.jpactel.com

**Actel Hong Kong** • Room 2107, China Resources Building • 26 Harbour Road • Wanchai • Hong Kong Phone +852 2185 6460 • Fax +852 2185 6488 • www.actel.com.cn

50200127-6/06.08

