

## **CoreApbNvm**

Handbook



#### Actel Corporation, Mountain View, CA 94043

© 2008 Actel Corporation. All rights reserved.

Printed in the United States of America

Part Number: 50200139-1

Release: March 2009

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**

|   | Introduction                                                                                                                                                                    | 5<br>5              |
|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|
| 1 | Supported Interfaces                                                                                                                                                            | 9                   |
| 2 | Tool Flows 1   SmartDesign 1                                                                                                                                                    | 1                   |
| 3 | NVM Addressing 1   Overview 1   Auto-Increment Feature 1                                                                                                                        | 3<br>.3<br>.3       |
| 4 | Registers 1   Register Map 1   Register Descriptions 1   Software Flow 1                                                                                                        | 5<br>5<br>7         |
| 5 | Interface Descriptions 2   Parameters 2   Ports 2                                                                                                                               | 1<br>21<br>22       |
| 6 | Testing and Verification                                                                                                                                                        | 5                   |
| 7 | Ordering Information                                                                                                                                                            | 7<br>?7             |
| A | List of Document Changes                                                                                                                                                        | 9                   |
| В | Product Support 3   Customer Service 3   Actel Customer Technical Support Center 3   Actel Technical Support 3   Website 3   Contacting the Customer Technical Support Center 3 | 1<br>51<br>51<br>51 |
|   | Index                                                                                                                                                                           | 3                   |



## Introduction

### **Core Overview**

CoreApbNvm allows advanced microcontroller bus architecture (AMBA) Peripheral Bus (APB) access to the Actel Fusion® nonvolatile memory (NVM), using a simple register-based access scheme. The core is designed to be configurable for use in various applications, using variable APB bus widths and a number of NVM instances (where supported). In addition, CoreApbNvm contains an Init/Config block which is used on reset to initialize RAM with the contents of NVM0. After reset, the Init/Config block can also be used to copy a user-specified number of words from NVM, starting at a user-specified base address.

Figure 1 shows the CoreApbNvm block diagram.



Figure 1 · CoreApbNvm Block Diagram





#### **Key Features**

- CoreApbNvm has the following features:
- Fully AMBA 2 APB-compliant
- Compatible with AMBA 3 APB
- Multiple memory sizes and variable number of NVM blocks
- Configurable 8-, 16-, or 32-bit data bus size
- Configurable APB address width in range of 8 to 32 bits
- Init/Config block for fetching data from NVM to RAM, primarily for CoreABC soft-mode initialization
- Remapping function via Init/Config block to load RAM from different addresses of NVM
- Register controlled auto increment mode

#### **Core Version**

This handbook applies to CoreApbNVM v2.1.

#### **Supported Families**

All Fusion devices are supported by CoreApbNvm.

#### **Utilization and Performance**

Table 1 to Table 3 on page 7 describe the tile count and performance of CoreApbNvm for various configurations.

#### Table 1 · High-Tile Parameter Values

| Family |            | Cells or Tiles |       | Utiliz  | ation      | Performance |
|--------|------------|----------------|-------|---------|------------|-------------|
| 1 anny | Sequential | Combinatorial  | Total | Device  | Percentage | Terrormance |
| Fusion | 159        | 458            | 617   | AFS1500 | 1%         | 56.5 MHz    |

*Note:* Data in this table were achieved using typical synthesis and layout settings. Top-level parameters/generics that differ from the default values were set as follows: APB\_DWIDTH = 32, NUM\_INSTANCES = 4, INIT\_ENABLED = 1.

#### Table 2 · Typical Parameter Values

| Family  |                               | Cells or Tiles |       | Utiliz            | ation | Performance  |  |
|---------|-------------------------------|----------------|-------|-------------------|-------|--------------|--|
| 1 anniy | Sequential Combinatorial Tota |                | Total | Device Percentage |       | i citormanee |  |
| Fusion  | 111                           | 284            | 395   | AFS090            | 17%   | 68.4 MHz     |  |

*Note:* Data in this table were achieved using typical synthesis and layout settings. Top-level parameters/generics that differ from the default values were set as follows: APB\_DWIDTH = 8, NUM\_INSTANCES = 1, INIT\_ENABLED = 1.

#### CoreApbNvm



| Family |            | Cells or Tiles |       | Utiliz    | Performance  |          |
|--------|------------|----------------|-------|-----------|--------------|----------|
| 1 anny | Sequential | Combinatorial  | Total | Dev       | 1 errormance |          |
| Fusion | 73         | 143            | 216   | AFS090 9% |              | 71.7 MHz |

#### Table 3 · Low-Tile Parameter Values

*Note:* Data in this table was achieved using typical synthesis and layout settings. Top-level parameters/generics that differ from the default values were set as follows: APB\_DWIDTH = 8, NUM\_INSTANCES = 1, INIT\_ENABLED = 0.



## **Supported Interfaces**

CoreApbNvm has an AMBA 2 APB Slave interface, with signals for an Init/Config Master interface and AMBA 3 APB operation.



Figure 1-3  $\cdot$  APB Data Read Cycle



## **SmartDesign**

CoreApbNvm is available for download to the SmartDesign IP Catalog, via the Libero<sup>®</sup> Integrated Design Environment (IDE) web repository. For information on using SmartDesign to instantiate, configure, connect, and generate cores, please refer to the Libero IDE online help.

Figure 2-1 shows the CoreApbNvm configuration window with the corresponding top-level parameters.

|   | — APB_DWIDTH<br>— APB_AWIDTH |
|---|------------------------------|
|   | — APB_DWIDTH<br>— APB_AWIDTH |
|   | — APB_DWIDTH<br>— APB_AWIDTH |
|   | — APB_AWIDTH                 |
|   |                              |
|   | — NUM_INSTANCES              |
|   | INIT_ENABLED                 |
|   | INIT_AWIDTH                  |
|   |                              |
|   | INIT_BASE_ADDRESS_RST        |
|   | INIT_WORD_COUNT_RST          |
|   | INIT_SPARE_PAGE_RST          |
|   |                              |
|   | INIT_BASE_ADDRESS_0          |
|   | INIT_WORD_COUNT_0            |
|   | INIT_SPARE_PAGE_0            |
|   |                              |
| _ |                              |
|   |                              |
|   |                              |

Figure 2-1 · CoreApbNvm Configuration Window



#### **Tool Flows**

### **Example System**

Figure 2-2 shows a typical system using CoreABC (proc), CoreAPB, and CoreApbNvm.



Figure 2-2 · Sample System with CoreABC and CoreAI

Note the connection between the Init/Config interface from CoreApbNvm (Init/Config Master) and CoreABC (Init/ Config Slave). The CoreABC outputs connect directly to the custom initialization interface of CoreApbNvm. This connection allows for CoreABC to initiate a RAM-reload from different address spaces, so different programs can be loaded from the NVM during CoreABC execution, real-time. APB bus interfaces are autoconnected in SmartDesign.

## **NVM Addressing**

### **Overview**

Table 3-1 below illustrates the bits required to read/write an address in the NVM.

| 20  | 19  | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10    | 9     | 8    | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----|-----|----|----|----|----|----|----|----|----|-------|-------|------|-------|---|---|---|---|---|---|---|
| NVN | A # | SP |    |    |    |    |    |    |    | 18-bi | it NV | M ad | dress |   |   |   |   |   |   |   |

As shown in Table 3-1, 21 bits are required to access any address, including spare page, in the NVM. There are the 18 bits as specified in the *Actel Fusion Mixed–Signal FPGAs* datasheet for sector, page, block, and byte addressing; as well as 2 bits (NVM #) to specify which of four NVM instantiations are being accessed, and 1 bit (SP) to access the spare page of the sector currently being accessed.

In most cases, 21 address bits will not be available on the APB address bus and they will need to be stored in three 8-bit registers, as described in "Register Map" on page 15.

Note: The spare page of sector 0 is unavailable for any user data. Writes to this page will return an error, while reads will return all zeroes.

### **Auto-Increment Feature**

CoreApbNvm has a register-controlled auto-increment feature, which is enabled by default. The auto-increment feature increments the address by the appropriate amount each time a NVM read or write operation is performed. The appropriate amount is calculated based on the APB data width (APB\_DWIDTH parameter). In 8-bit mode, all bits of the NVM address are used; in 16-bit mode, bit 0 is ignored; and in 32-bit mode, bits 1 and 0 are ignored. The following increments are used:

- 8 bit mode: increment by 1
- 16 bit mode: increment by 2
- 32 bit mode: increment by 4

## POWER MATTERS Registers

## **Register Map**

Table 4-1 describes the CoreApbNvm registers and their uses. The "Register Descriptions" section describes each register in detail.

| PADDR[4:0]<br>(hex) | Туре | Reset Value (hex) | Size (bits) | Brief Description                               |
|---------------------|------|-------------------|-------------|-------------------------------------------------|
| 0x00                | R/W  | 0x00              | APB_DWIDTH  | Address Register 1                              |
| 0x04                | R/W  | 0x00              | 8           | Address Register 2<br>Unused if APB_DWIDTH = 32 |
| 0x08                | R/W  | 0x00              | 8           | Address Register 3<br>Unused if APB_DWIDTH = 16 |
| 0x0C                | R/W  | 0x00              | APB_DWIDTH  | NVM Write Data                                  |
| 0x10                | W    | 0x00              | 8           | Control Register                                |
| 0x14                | R    | 0x80              | 8           | Status Register                                 |
| 0x18                | R    | 0x00              | APB_DWIDTH  | NVM Read Data                                   |

| Table | 4-1 | • | Register | Map |
|-------|-----|---|----------|-----|

Note: The lower 2 bits of PADDR are unused.

## **Register Descriptions**

#### **Address Registers**

Address registers are used to load addresses into the internal NVM address register when the load bit of the control register is written to. Reading values from the address register reads back the current NVM address stored in the internal (21 bit) NVM address register.

#### **8-bit Registers**

Address registers 1, 2, and 3 at address 0x00, 0x04, and 0x08 respectively, are used to store the 21-bit NVM address described in Table 3-1 on page 13. The actual address bit mapping scheme varies depending on the APB\_DWIDTH parameter, as described in the following sections.

#### **APB\_DWIDTH = 8**

The registers are all 8 bits wide and are mapped in the following manner:

Address Register 1: Bits 7 to 0 of the 21 bit NVM address.

Address Register 2: Bits 15 to 8 of the 21 bit NVM address.

Address Register 3: Bits 20:16 of the 21 bit NVM address.

Note: The top 3 bits of this register are unused.

Registers



#### **APB\_DWIDTH = 16**

Address Register 1 is 16 bits wide and Address Register 3 is not used. Registers are mapped as follows: Address Register 1: Bits 15 to 0 of the 21 bit NVM address.

Address Register 2: Bits 20 to 16 of the 21 bit NVM address.

Note: The top 3 bits of this register are unused.

Address Register 3: Unused.

#### APB\_DWIDTH = 32

Address Register 1 is 32 bits wide and Address Registers 2 and 3 are not used.

Address Register 1: Bits 20 to 0 of the 21 bit NVM address.

Note: The top 12 bits of this register are unused.

Address Register 2: Unused.

Address Register 3: Unused.

#### **NVM Write Data Register**

#### **APB\_DWIDTH-Sized Register**

This register stores the data that is to be written to the NVM. When a write operation is initiated, the data in this register is written to the NVM page buffer. For more information on the NVM write operation, please refer to the *Actel Fusion Mixed-Signal FPGAs* datasheet.

#### **Control Register**

#### 8-bit Register

This write register controls the operation of CoreApbNvm. Table 4-2 describes the operation of the control register.

| Table 4-2 · Control Register |   |   |   |   |  |  |  |  |  |
|------------------------------|---|---|---|---|--|--|--|--|--|
| 6                            | 5 | 4 | 3 | 2 |  |  |  |  |  |

| Bit | 7                      | 6 | 5 | 4              | 3                  | 2                      | 1 | 0         |
|-----|------------------------|---|---|----------------|--------------------|------------------------|---|-----------|
|     | NVM dis.<br>Auto-incr. | _ | _ | NVM<br>program | NVM read<br>enable | NVM<br>write<br>enable | - | Load addr |

**NVM disable auto-incr:** This is a toggle bit. By default, auto-increment is enabled. Writing a 1 to this address disables auto-increment. Writing a 1 again re-enables it, etc.

NVM program: Programs the current page with data loaded in the Page Buffer.

NVM read enable: Initiates a read to the current Page Buffer.

NVM write enable: Initiates a write to the current Page Buffer.

Load addr: Loads the address stored in APB-addressable Address Registers 1, 2, and 3 into an internal 21-bit address register. NVM address, spare page, and NVM number are then read from this internal register.

CoreApbNvm



#### **Status Register**

#### 8-bit Register

This read register gives access to the current status of CoreApbNvm. Table 4-3 describes the operation of the status register.

| Bit | 7                 | 6         | 5     | 4              | 3 | 2           | 1                 | 0                 |
|-----|-------------------|-----------|-------|----------------|---|-------------|-------------------|-------------------|
|     | NVM<br>auto-incr. | INIT busy | Error | End of<br>Page | - | NVM<br>busy | NVM<br>status [1] | NVM<br>status [0] |

| Table 4 | 4-3 · | Status | Register |
|---------|-------|--------|----------|
|---------|-------|--------|----------|

NVM auto-incr: This is a status bit. 1 indicates auto-increment is enabled. 0 indicates it is disabled.

INIT busy: RAM init in progress

Error: If the NVM status of any NVM operation is not "00" as described below, this bit is set to 1, and is "sticky." The error bit can only be cleared by writing any value to the status register.

End of Page: Status bit indicates that the current NVM address is at the end of a page. Auto-increment will cease to increment the NVM address at this point.

NVM busy: Tied directly to the NVM busy output signal. Please refer to the *Actel Fusion Mixed-Signal FPGAs* datasheet for more information.

NVM status [1:0]: Status of the last operation completed:

- 00: Successful completion
- 01: Read-/Unprotect-Page: single error detected and corrected

Write: operation addressed a write-protected page

Erase-Page: protection violation

Program: Page Buffer is unmodified

Protection violation

- 10: Read-/Unprotect-Page: two or more errors detected
- 11: Write: attempt to write to another page before programming current page

Erase-Page/Program: page write count has exceeded the 10-year retention threshold

#### **NVM Read Data**

#### **APB\_DWIDTH-Sized Register**

This read only register returns the read data from the last read operation.

### Software Flow

CoreApbNvm supports both read and write operation through a series of APB register writes and reads. "Read Operation" and "Read Operation" on page 18 describe typical write and read operations. Note that both operations assume address auto-incrementing is enabled. Software flows with auto-increment disabled would involve more address register writes.

#### Registers



#### **Read Operation**

The algorithm for a typical read operation is shown in Figure 4-1 on page 19. The read operation is used to read data from NVM. As with the write operation, write an initial address to the three address registers, followed by a load address (0x01) write to the command register. This loads the value of the address registers into a contiguous 21-bit internal register. Subsequent NVM writes and reads are done using this address. This is the register that is auto-incremented when address auto-incrementing is enabled. The actual read is performed by writing 0x08 to the control register. This sets the read enable bit and performs an NVM read operation. If a page boundary is being crossed, this can take several cycles. Poll the status register for the NVM busy bit, as well as the status. Once the NVM finishes its read operation, NVM read data is copied into the read data register, where it can be accessed via APB.

#### **Write Operation**

The algorithm for a typical write operation is shown in Figure 4-2 on page 20. The write operation is used to write data to the NVM. Write an initial address to the three address registers, followed by a load address (0x01) write to the command register. This loads the value of the address registers into a contiguous 21-bit internal register. Subsequent NVM writes and reads are done using this address. This contiguous 21-bit internal register is auto-incremented when address auto-incrementing is enabled. Write data to the NVM write data register, followed by writing 0x04 to the control register (write enable is set). This writes the data in the data register to the NVM page buffer. After the NVM finishes its write (busy bit is polled), check to make sure the write status is okay.

CoreApbNvm does not keep track of page addresses. Program the current page once the end of the page has been reached.

Note: Once the end of a page is reached, the internal address register ceases to be auto-incremented (i.e., when the lower 7 bits of the address register are 0h7F).

#### Notes

While the Init/Config is active (Busy bit is high), the APB does not have write or read access to the NVM. However, all APB registers are accessible.

Init/Config pulls data only from NVM0.

On reset, Init/Config initializes RAM with data starting at INIT\_BASE\_ADDRESS\_RST, described on Table 5-1 on page 21.

**CoreApbNvm** 







Registers









## Interface Descriptions

### **Parameters**

Table 5-1 outlines the generics for CoreApbNvm.

| Parameter             | Values                     | Description                                                                                                                                              |
|-----------------------|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| FAMILY                | 17                         | Must be set to match the supported<br>FPGA family<br>17 = Fusion                                                                                         |
| APB_DWIDTH            | 8,16,32                    | APB data width                                                                                                                                           |
| APB_AWIDTH            | 8 - 21                     | APB address width                                                                                                                                        |
| INIT_AWIDTH           | 11-16                      | Initialization address width                                                                                                                             |
| INIT_ENABLED          | 0 or 1                     | If 1, Init Config block is generated.<br>If 0, Init Config block is not<br>generated, outputs are tied low<br>(except INIT_DONE, which is tied<br>high). |
| INIT_BASE_ADDRESS_RST | 0 to (2**18) - 1           | Initialization base address at reset.<br>Must be aligned to page boundary<br>(0x00, 0x80, etc.)                                                          |
| INIT_WORD_COUNT_RST   | 0 to (2** INIT_AWIDTH) - 1 | Number of (9-bit) words to be<br>initialized to RAM, starting at the<br>base address above, at reset.                                                    |
| INIT_SPARE_PAGE_RST   | 0 or 1                     | 1 = data stored for this client is in<br>spare page addresses (init at reset).                                                                           |
| INIT_BASE_ADDRESS_0   | 0 to (2**18) - 1           | Initialization base address 0 for post-<br>reset initialization. Must be aligned<br>to page boundary (0x00, 0x80, etc.)                                  |
| INIT_WORD_COUNT_0     | 0 to (2** INIT_AWIDTH) - 1 | Number of words to be initialized to RAM, starting at the base address above.                                                                            |
| INIT_SPARE_PAGE_0     | 0 or 1                     | 1 = data stored for this client is in spare page addresses.                                                                                              |
| INIT_BASE_ADDRESS_1   | 0 to (2**18) - 1           | Initialization base address 1 for post-<br>reset initialization. Must be aligned<br>to page boundary (0x00, 0x80, etc.)                                  |
| INIT_WORD_COUNT_1     | 0 to (2** INIT_AWIDTH) - 1 | Number of words to be initialized to RAM, starting at the base address above.                                                                            |
| INIT_SPARE_PAGE_1     | 0 or 1                     | 1 = data stored for this client is in<br>spare page addresses.                                                                                           |

#### Table 5-1 · CoreApbNvm Generics



| Table 5-1 · CoreApbNvm Generics (continued) |  |
|---------------------------------------------|--|
|---------------------------------------------|--|

| Parameter           | Values                     | Description                                                                                                             |
|---------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------|
| INIT_BASE_ADDRESS_2 | 0 to (2**18) - 1           | Initialization base address 2 for post-<br>reset initialization. Must be aligned<br>to page boundary (0x00, 0x80, etc.) |
| INIT_WORD_COUNT_2   | 0 to (2** INIT_AWIDTH) - 1 | Number of words to be initialized to RAM, starting at the base address above.                                           |
| INIT_SPARE_PAGE_2   | 0 or 1                     | 1 = data stored for this client is in spare page addresses.                                                             |
| INIT_BASE_ADDRESS_3 | 0 to (2**18) - 1           | Initialization base address 3 for post-<br>reset initialization. Must be aligned<br>to page boundary (0x00, 0x80, etc.) |
| INIT_WORD_COUNT_3   | 0 to (2** INIT_AWIDTH) - 1 | Number of words to be initialized to RAM, starting at the base address above.                                           |
| INIT_SPARE_PAGE_3   | 0 or 1                     | 1 = data stored for this client is in spare page addresses.                                                             |

## Ports

Table 5-2 outlines the top-level signals for CoreApbNvm.

| Table 5-2 | · CoreApbNvm | Ports |
|-----------|--------------|-------|
|-----------|--------------|-------|

| Name                       | Туре   | Description                                                |
|----------------------------|--------|------------------------------------------------------------|
| APB Bus Signals            |        |                                                            |
| PCLK                       | Input  | APB System Clock – Reference clock for all internal logic  |
| PRESETN                    | Input  | APB active low asynchronous reset                          |
| PWDATA<br>[APB_DWIDTH-1:0] | Input  | APB write data                                             |
| PRDATA<br>[APB_DWIDTH-1:0] | Output | APB read data                                              |
| PADDR<br>[APB_AWIDTH-1:0]  | Input  | APB address bus.                                           |
| PENABLE                    | Input  | APB strobe – Indicates the second cycle of an APB transfer |
| PSEL                       | Input  | APB Slave select                                           |
| PWRITE                     | Input  | APB write/read select signal                               |

#### CoreApbNvm



| Name                | Туре   | Description                                                                                           |
|---------------------|--------|-------------------------------------------------------------------------------------------------------|
| PREADY              | Output | AMBA 3 APB-ready signal for future AMBA 3<br>APB compliance, tied high                                |
| PSLVERR             | Output | AMBA 3 APB transfer error signal for future<br>AMBA 3 APB compliance, tied low                        |
| Init/Config signals |        |                                                                                                       |
| INIT_DONE           | Output | Initialization done signal. Asserted when initialization is completed.                                |
| INIT_DATA[8:0]      | Output | Initialization data - to RAM blocks                                                                   |
| INIT_ADDR[11:0]     | Output | Initialization address - to RAM blocks                                                                |
| INIT_DATVAL         | Output | Init data valid signal                                                                                |
| INIT_BASE0          | Input  | Synchronous, active high signal to initialize RAM<br>with NVM data starting at<br>INIT_BASE_ADDRESS_0 |
| INIT_BASE1          | Input  | Synchronous, active high signal to initialize RAM<br>with NVM data starting at<br>INIT_BASE_ADDRESS_1 |
| INIT_BASE2          | Input  | Synchronous, active high signal to initialize RAM<br>with NVM data starting at<br>INIT_BASE_ADDRESS_2 |
| INIT_BASE3          | Input  | Synchronous, active high signal to initialize RAM<br>with NVM data starting at<br>INIT_BASE_ADDRESS_3 |

Note: Unless otherwise noted, all of the signals above are active high.



## **Testing and Verification**

CoreApbNvm comes with a simple user testbench, which can be invoked using Libero IDE. Refer to the Libero online help.

| U | Jser testbench |                 |  |  |  |
|---|----------------|-----------------|--|--|--|
|   | CoreApbNvm     | Stimulus Vector |  |  |  |
|   | АРВ            |                 |  |  |  |

Figure 6-1 · CoreApbNvm User Testbench

The user testbench includes examples of how to do simple APB writes and reads using predefined read/write functions. Modify this testbench to suit any needs.



## **Ordering Information**

## **Ordering Codes**

CoreApbNVM can be ordered through your local Actel sales representative. It should be ordered using the following number scheme: CoreApbNVM-XX, where XX is listed in Table 7-1.

| XX | Description                                   |
|----|-----------------------------------------------|
| OM | RTL for Obfuscated RTL – multiple-use license |
| RM | RTL for RTL source – multiple-use license     |

| Table | 7-1 | Ordering | Codes |
|-------|-----|----------|-------|
|-------|-----|----------|-------|

Note: CoreApbNvm-OM is included free with a Libero IDE license.



## **List of Document Changes**

The following table lists critical changes that were made in the current version of the document.

| Previous<br>Version | Changes in Current Version (v2.1)                    | Page |
|---------------------|------------------------------------------------------|------|
|                     | Corrected reference to CoreAI to CoreAPB.            | 12   |
| March 09            | Added information about usage of Address Registers.  | 15   |
|                     | Added End of Page support for Status Register bit 4. | 17   |

## **Product Support**

Actel

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 Actel's 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.

# POWER MATTERS

## Index

#### Α

Actel electronic mail 31 telephone 32 web-based technical support 31 website 31 AMBA 5 APB 5 data write cycle 9 auto-increment 13

#### С

contacting Actel customer service 31 electronic mail 31 telephone 32 web-based technical support 31 CoreABC 12 CoreAPB 12 CoreApbNvm block diagram 5 configuration window 11 features 6 overview 5 utilization and performance 6 version 6 customer service 31

#### Ε

example system 12

#### I

Init/Config interface timing diagram 9 interface descriptions 13

#### 0

ordering code 27

#### Ρ

product support 31–32 customer service 31 electronic mail 31 technical support 31 telephone 32 website 31

#### S

SmartDesign 11

#### Т

technical support 31 testbench operation 25

#### W

web-based technical support 31



## Actel is the leader in low-power and mixed-signal FPGAs and offers the most comprehensive portfolio of system and power management solutions. Power Matters. Learn more 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 • http://jp.actel.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

50200139-1/3.09