# Old Company Name in Catalogs and Other Documents

On April 1<sup>st</sup>, 2010, NEC Electronics Corporation merged with Renesas Technology Corporation, and Renesas Electronics Corporation took over all the business of both companies. Therefore, although the old company name remains in this document, it is a valid Renesas Electronics document. We appreciate your understanding.

Renesas Electronics website: http://www.renesas.com

April 1<sup>st</sup>, 2010 Renesas Electronics Corporation

Issued by: Renesas Electronics Corporation (http://www.renesas.com)

Send any inquiries to http://www.renesas.com/inquiry.

#### Notice

- 1. All information included in this document is current as of the date this document is issued. Such information, however, is subject to change without any prior notice. Before purchasing or using any Renesas Electronics products listed herein, please confirm the latest product information with a Renesas Electronics sales office. Also, please pay regular and careful attention to additional and different information to be disclosed by Renesas Electronics such as that disclosed through our website.
- Renesas Electronics does not assume any liability for infringement of patents, copyrights, or other intellectual property rights of third parties by or arising from the use of Renesas Electronics products or technical information described in this document. No license, express, implied or otherwise, is granted hereby under any patents, copyrights or other intellectual property rights of Renesas Electronics or others.
- 3. You should not alter, modify, copy, or otherwise misappropriate any Renesas Electronics product, whether in whole or in part.
- 4. Descriptions of circuits, software and other related information in this document are provided only to illustrate the operation of semiconductor products and application examples. You are fully responsible for the incorporation of these circuits, software, and information in the design of your equipment. Renesas Electronics assumes no responsibility for any losses incurred by you or third parties arising from the use of these circuits, software, or information.
- 5. When exporting the products or technology described in this document, you should comply with the applicable export control laws and regulations and follow the procedures required by such laws and regulations. You should not use Renesas Electronics products or the technology described in this document for any purpose relating to military applications or use by the military, including but not limited to the development of weapons of mass destruction. Renesas Electronics products and technology may not be used for or incorporated into any products or systems whose manufacture, use, or sale is prohibited under any applicable domestic or foreign laws or regulations.
- 6. Renesas Electronics has used reasonable care in preparing the information included in this document, but Renesas Electronics does not warrant that such information is error free. Renesas Electronics assumes no liability whatsoever for any damages incurred by you resulting from errors in or omissions from the information included herein.
- 7. Renesas Electronics products are classified according to the following three quality grades: "Standard", "High Quality", and "Specific". The recommended applications for each Renesas Electronics product depends on the product's quality grade, as indicated below. You must check the quality grade of each Renesas Electronics product before using it in a particular application. You may not use any Renesas Electronics product for any application categorized as "Specific" without the prior written consent of Renesas Electronics. Further, you may not use any Renesas Electronics. Renesas Electronics shall not be in any way liable for any damages or losses incurred by you or third parties arising from the use of any Renesas Electronics product for an application categorized as "Specific" or for which the product is not intended where you have failed to obtain the prior written consent of Renesas Electronics. The quality grade of each Renesas Electronics product is "Standard" unless otherwise expressly specified in a Renesas Electronics data sheets or data books, etc.
  - "Standard": Computers; office equipment; communications equipment; test and measurement equipment; audio and visual equipment; home electronic appliances; machine tools; personal electronic equipment; and industrial robots.
  - "High Quality": Transportation equipment (automobiles, trains, ships, etc.); traffic control systems; anti-disaster systems; anticrime systems; safety equipment; and medical equipment not specifically designed for life support.
  - "Specific": Aircraft; aerospace equipment; submersible repeaters; nuclear reactor control systems; medical equipment or systems for life support (e.g. artificial life support devices or systems), surgical implantations, or healthcare intervention (e.g. excision, etc.), and any other applications or purposes that pose a direct threat to human life.
- 8. You should use the Renesas Electronics products described in this document within the range specified by Renesas Electronics, especially with respect to the maximum rating, operating supply voltage range, movement power voltage range, heat radiation characteristics, installation and other product characteristics. Renesas Electronics shall have no liability for malfunctions or damages arising out of the use of Renesas Electronics products beyond such specified ranges.
- 9. Although Renesas Electronics endeavors to improve the quality and reliability of its products, semiconductor products have specific characteristics such as the occurrence of failure at a certain rate and malfunctions under certain use conditions. Further, Renesas Electronics products are not subject to radiation resistance design. Please be sure to implement safety measures to guard them against the possibility of physical injury, and injury or damage caused by fire in the event of the failure of a Renesas Electronics product, such as safety design for hardware and software including but not limited to redundancy, fire control and malfunction prevention, appropriate treatment for aging degradation or any other appropriate measures. Because the evaluation of microcomputer software alone is very difficult, please evaluate the safety of the final products or system manufactured by you.
- 10. Please contact a Renesas Electronics sales office for details as to environmental matters such as the environmental compatibility of each Renesas Electronics product. Please use Renesas Electronics products in compliance with all applicable laws and regulations that regulate the inclusion or use of controlled substances, including without limitation, the EU RoHS Directive. Renesas Electronics assumes no liability for damages or losses occurring as a result of your noncompliance with applicable laws and regulations.
- 11. This document may not be reproduced or duplicated, in any form, in whole or in part, without prior written consent of Renesas Electronics.
- 12. Please contact a Renesas Electronics sales office if you have any questions regarding the information contained in this document or Renesas Electronics products, or if you have any other inquiries.
- (Note 1) "Renesas Electronics" as used in this document means Renesas Electronics Corporation and also includes its majorityowned subsidiaries.
- (Note 2) "Renesas Electronics product(s)" means any product developed or manufactured by or for Renesas Electronics.



**Preliminary Design Manual** 

# **CB-9 Family VX/VM Type**

# 0.35 $\mu$ m CMOS Cell-Based IC (CBIC)

NB85E, NB85ET

Document No. A14335EJ3V1DM00 (3rd edition) Date Published January 2002 NS CP(N)

© NEC Corporation 1999 Printed in Japan [MEMO]

#### **1** PRECAUTION AGAINST ESD FOR SEMICONDUCTORS

#### Note:

Strong electric field, when exposed to a MOS device, can cause destruction of the gate oxide and ultimately degrade the device operation. Steps must be taken to stop generation of static electricity as much as possible, and quickly dissipate it once, when it has occurred. Environmental control must be adequate. When it is dry, humidifier should be used. It is recommended to avoid using insulators that easily build static electricity. Semiconductor devices must be stored and transported in an anti-static container, static shielding bag or conductive material. All test and measurement tools including work bench and floor should be grounded. The operator should be grounded using wrist strap. Semiconductor devices must not be touched with bare hands. Similar precautions need to be taken for PW boards with semiconductor devices on it.

### (2) HANDLING OF UNUSED INPUT PINS FOR CMOS

#### Note:

No connection for CMOS device inputs can be cause of malfunction. If no connection is provided to the input pins, it is possible that an internal input level may be generated due to noise, etc., hence causing malfunction. CMOS devices behave differently than Bipolar or NMOS devices. Input levels of CMOS devices must be fixed high or low by using a pull-up or pull-down circuitry. Each unused pin should be connected to VDD or GND with a resistor, if it is considered to have a possibility of being an output pin. All handling related to the unused pins must be judged device by device and related specifications governing the devices.

### **③** STATUS BEFORE INITIALIZATION OF MOS DEVICES

#### Note:

Power-on does not necessarily define initial status of MOS device. Production process of MOS does not define the initial operation status of the device. Immediately after the power source is turned ON, the devices with reset function have not yet been initialized. Hence, power-on does not guarantee out-pin levels, I/O settings or contents of registers. Device is not initialized until the reset signal is received. Reset operation must be executed immediately after power-on for devices having reset function.

**OPENCAD** is a trademark of NEC Corporation.

Design Compiler is a registered trademark of Synopsys, Inc. in Japan.

Verilog-XL is a trademark of Cadence Design Systems, Inc..

The export of this product from Japan is regulated by the Japanese government. To export this product may be prohibited without governmental license, the need for which must be judged by the customer. The export or re-export of this product from a country other than Japan may also be prohibited without a license from that country. Please call an NEC sales representative.

- The information contained in this document is being issued in advance of the production cycle for the device. The parameters for the device may change before final production or NEC Corporation, at its own discretion, may withdraw the device prior to its production.
- Not all devices/types available in every country. Please check with local NEC representative for availability and additional information.
- No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Corporation. NEC Corporation assumes no responsibility for any errors which may appear in this document.
- NEC Corporation does not assume any liability for infringement of patents, copyrights or other intellectual property
  rights of third parties by or arising from use of a device described herein or any other liability arising from use
  of such device. No license, either express, implied or otherwise, is granted under any patents, copyrights or other
  intellectual property rights of NEC Corporation or others.
- Descriptions of circuits, software, and other related information in this document are provided for illustrative
  purposes in semiconductor product operation and application examples. The incorporation of these circuits,
  software, and information in the design of the customer's equipment shall be done under the full responsibility
  of the customer. NEC Corporation assumes no responsibility for any losses incurred by the customer or third
  parties arising from the use of these circuits, software, and information.
- While NEC Corporation has been making continuous effort to enhance the reliability of its semiconductor devices, the possibility of defects cannot be eliminated entirely. To minimize risks of damage or injury to persons or property arising from a defect in an NEC semiconductor device, customers must incorporate sufficient safety measures in its design, such as redundancy, fire-containment, and anti-failure features.
- NEC devices are classified into the following three quality grades:

"Standard", "Special", and "Specific". The Specific quality grade applies only to devices developed based on a customer designated "quality assurance program" for a specific application. The recommended applications of a device depend on its quality grade, as indicated below. Customers must check the quality grade of each device before using it in a particular application.

- Standard: Computers, office equipment, communications equipment, test and measurement equipment, audio and visual equipment, home electronic appliances, machine tools, personal electronic equipment and industrial robots
- Special: Transportation equipment (automobiles, trains, ships, etc.), traffic control systems, anti-disaster systems, anti-crime systems, safety equipment and medical equipment (not specifically designed for life support)
- Specific: Aircraft, aerospace equipment, submersible repeaters, nuclear reactor control systems, life support systems or medical equipment for life support, etc.

The quality grade of NEC devices is "Standard" unless otherwise specified in NEC's Data Sheets or Data Books. If customers intend to use NEC devices for applications other than those specified for Standard quality grade, they should contact an NEC sales representative in advance.

# **Regional Information**

Some information contained in this document may vary from country to country. Before using any NEC product in your application, please contact the NEC office in your country to obtain a list of authorized representatives and distributors. They will verify:

- · Device availability
- Ordering information
- Product release schedule
- · Availability of related technical literature
- Development environment specifications (for example, specifications for third-party tools and components, host computers, power plugs, AC supply voltages, and so forth)
- Network requirements

In addition, trademarks, registered trademarks, export restrictions, and other legal issues may also vary from country to country.

#### NEC Electronics Inc. (U.S.) Santa Clara, California Tel: 408-588-6000 800-366-9782 Fax: 408-588-6130 800-729-9288

#### **NEC Electronics (Europe) GmbH**

Duesseldorf, Germany Tel: 0211-65 03 01 Fax: 0211-65 03 327

• Branch The Netherlands Eindhoven, The Netherlands Tel: 040-244 58 45 Fax: 040-244 45 80

• Branch Sweden Taeby, Sweden Tel: 08-63 80 820 Fax: 08-63 80 388 NEC Electronics (France) S.A. Vélizy-Villacoublay, France Tel: 01-3067-58-00 Fax: 01-3067-58-99

NEC Electronics (France) S.A. Representación en España Madrid, Spain Tel: 091-504-27-87 Fax: 091-504-28-60

NEC Electronics Italiana S.R.L. Milano, Italy Tel: 02-66 75 41 Fax: 02-66 75 42 99

**NEC Electronics (UK) Ltd.** Milton Keynes, UK Tel: 01908-691-133 Fax: 01908-670-290 NEC Electronics Hong Kong Ltd. Hong Kong Tel: 2886-9318 Fax: 2886-9022/9044

NEC Electronics Hong Kong Ltd. Seoul Branch Seoul, Korea Tel: 02-528-0303 Fax: 02-528-4411

NEC Electronics Singapore Pte. Ltd. Novena Square, Singapore Tel: 253-8311 Fax: 250-3583

NEC Electronics Taiwan Ltd. Taipei, Taiwan Tel: 02-2719-2377 Fax: 02-2719-5951

#### NEC do Brasil S.A.

Electron Devices Division Guarulhos-SP, Brasil Tel: 11-6462-6810 Fax: 11-6462-6829

J01.12

# Major Revisions in This Edition (1/2)

| Pages                       | Pages Description                                                                                                               |  |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------|--|
| Throughout                  | Deletion of descriptions on NPB peripheral macro                                                                                |  |
| p.19                        | Modification of Figure 2-1 Clock Controller Connection Example (Placing Oscillator Inside ASIC and Attaching Resonator Outside) |  |
| p.25                        | Addition of Figure 3-1 NB85E ROM Area Setting (1) When one compiled ROM of 32 bits $\times$ 8 Kwords is connected               |  |
| p.25                        | Addition of Note in Figure 3-2 ROM Access Timing                                                                                |  |
| p.26                        | Addition of 3.2.1 When connecting one ROM                                                                                       |  |
| p.26                        | Addition of Figure 3-3 Example of Connecting One Compiled ROM (32 Bits x 8 Kwords) to VFB                                       |  |
| pp.27 to 31                 | Addition of 3.2.2 When connecting multiple ROMs                                                                                 |  |
| p.28                        | Modification of Figure 3-4 Example of Connecting Two Compiled ROMs (32 Bits × 4 Kwords) to VFB                                  |  |
| p.33                        | Modification of Figure 3-9 RAM Access Timing                                                                                    |  |
| p.34                        | Addition of Figure 3-10 NB85E RAM Area Setting (2) When connecting eight compiled RAMs of 8 bits × 2 Kwords                     |  |
| p.35                        | Modification of Figure 3-11 Example of Connecting Compiled Memory to VDB (Connecting Four<br>Compiled Memories)                 |  |
| p.36                        | Modification of Figure 3-12 Example of Connecting Compiled Memory to VDB (Connecting Eig<br>Compiled Memories)                  |  |
| pp.37 to 39                 | Addition of 3.3.1 Operation when eight RAMs are connected                                                                       |  |
| p.41                        | Modification of Figure 4-1 Example of Connecting User Logic to VSB                                                              |  |
| p.42                        | Modification of 4.1.1 Overview of VSB operation                                                                                 |  |
| p.44                        | Modification of Figure 4-4 VSB Timing (Address Hold)                                                                            |  |
| p.51                        | Modification of 4.2 Connection of Compiled Memory                                                                               |  |
| p.56                        | Modification of description in CHAPTER 5 CONNECTION OF MEMORY CONTROLLER (MEMC)                                                 |  |
| p.57                        | Modification of Figure 5-1 Example of Connecting NB85E, MEMC, and External Memory (SRAM, SDRAM)                                 |  |
| p.58                        | Modification of Figure 5-2 Example of Connection to SRAM                                                                        |  |
| pp.50 to 53 in 2nd edition  | Deletion of 5.1 (2) Register example and (3) Operation timing example                                                           |  |
| pp.55, 56 in 2nd<br>edition | Deletion of 5.2 (2) Register example and (3) Operation timing example                                                           |  |
| p.60                        | Modification of 5.3 Connection to SDRAM                                                                                         |  |
| p.61                        | Modification of Figure 5-4 Example of Connection to SDRAM                                                                       |  |
| pp.59 to 65 in 2nd edition  | Deletion of 5.3 (2) Register example and (3) Operation timing example                                                           |  |
| p.63                        | Modification of peripheral I/O area in 6.2 (1) Register mapping                                                                 |  |
| p.64                        | Modification of Figure 6-3 Example of Address Decoder HDL Creation                                                              |  |
| p.65                        | Modification of Figure 6-4 Example of User Logic HDL Creation                                                                   |  |

# Major Revisions in This Edition (2/2)

| Pages         | Description                                                                                            |  |
|---------------|--------------------------------------------------------------------------------------------------------|--|
| p.67          | Modification of Figure 6-6 Example of HDL Creation for User Logic with Retry Function                  |  |
| p.69          | Modification of Figure 7-1 Example of Connecting Instruction Cache (NB85E213) to NB85E                 |  |
| p.71          | Addition of 7.1.1 (7) Initial program settings                                                         |  |
| p.71          | Addition of 7.1.1 (8) Setting BHC register of NB85E                                                    |  |
| p.71          | Addition of 7.1.1 (9) Test bus auto wiring tool support                                                |  |
| p.72          | Addition of 7.1.1 (10) Tag clear procedure                                                             |  |
| p.73          | Modification of Figure 7-3 Example of Connecting Data Cache (NB85E263) to NB85E                        |  |
| p.74          | Addition of 7.2.1 (5) Test bus auto wiring tool support                                                |  |
| p.74          | Addition of 7.2.1 (6) Other                                                                            |  |
| p.75          | Addition of 7.2.1 (7) Operation during debugging                                                       |  |
| p.79          | Modification of Figure 8-4 Circuit Example for In-Circuit Emulator Connection (NB85E + RCU (NB85E901)) |  |
| p.80          | Modification of Figure 8-5 Circuit Example for In-Circuit Emulator Connection (NB85ET)                 |  |
| p.81          | Addition of 8.2.4 Design of timing with N-wire type in-circuit emulator                                |  |
| p.86          | Modification of Figure 9-2 Skew or Hold Violation Countermeasure Execution Example                     |  |
| p.90          | Modification of 9.5 (2) Product specifications                                                         |  |
| p.92          | Modification of Figure 10-1 Example of Connecting Peripheral Macro to NB85E                            |  |
| p.94          | Modification of 10.2.1 (1) (b) Input pin processing                                                    |  |
| p.94          | Modification of 10.2.1 (1) (c) Output pin processing                                                   |  |
| p.95          | Modification of 10.2.1 (2) Pins for test mode                                                          |  |
| p.95          | Modification of 10.2.1 (3) Cautions when using NB85E901 (RCU)                                          |  |
| p.95          | Modification of 10.2.1 (4) Cautions when using NB85ET                                                  |  |
| pp.98 and 99  | Addition of 10.3 Test Bus Auto Wiring                                                                  |  |
| pp.100 to 105 | Addition of 10.4 Test Bus PINF File Creation/Editing Methods                                           |  |
| p.106         | Addition of description in CHAPTER 11 (1) Creation of test patterns for checking connections           |  |
| p.112         | Addition of APPENDIX REVISION HISTORY                                                                  |  |

The mark  $\star$  shows major revised points.

#### PREFACE

 Target Readers
 This manual is intended for users who design ASICs using NEC Corporation's "CB-9

 Family VX/VM Type" high-speed, high-integration CMOS CBIC.

 
 Purpose
 The purpose of this manual is to give users an understanding of design methods and various restrictions and cautions specific to designing ASICs that have on-chip NB85E or NB85ET 32-bit microprocessor cores.

Be sure to observe the points (general information, cautions, and restrictions) described in this design manual. Failure to do so may lower the quality or performance of the ASIC or lead to malfunctions. Note, however, that these points do not necessarily guarantee a circuit, and necessary functions may not be satisfied as a result of placement and routing. Therefore, be sure to perform development after verifying operation.

**Organization** This manual is roughly organized into the following sections.

- Connection of clock controller
- Cache connection
- Connection of ROM/RAM to VFB/VDB
- Connection to VSB

- Cautions
- Connection of memory controller
- Connection to NPB

- Test circuit design
- Total chip simulation

Connection to in-circuit emulator (IE)

How to Use This Manual Note in this manual apply to both the NB85E and NB85ET, but the NB85E is used as the representative microprocessor core (CPU core) unless specifically stated otherwise. When using the NB85ET, read and modify the CPU core name and some of the pin names according to the following table (pin functions are the same in both products).

| Item     | Using NB85E <sup>№№ 1</sup><br>(Names used in this manual) | Using NB85ET<br>(Names must be changed to the following) |
|----------|------------------------------------------------------------|----------------------------------------------------------|
| CPU core | NB85E                                                      | NB85ET                                                   |
| Pin name | ne DCRESZ <sup>NOLE 2</sup> RESETZ                         |                                                          |
|          | DCSTOPZ                                                    | STOPZ                                                    |
|          | DCNMI2 to DCNMI0                                           | NMI2 to NMI0                                             |

- Notes 1. Includes systems in which the NB85E901 (run control unit (RCU)) is connected.
  - **2.** There is a pin of the same name but with a different function in the NB85ET. Be careful when reading and changing names.

Before using this manual, be sure to read the separate "CB-9 Family VX/VM Type Design Manual (A12745E)".

| Conventions       | Data significance:<br>Active low representation:<br>Note:<br>Caution:<br>Remark:<br>Numerical representation:                                                                                    | Higher digits on the left and lower digits of<br>xxxZ (Z after pin or signal name)<br>or xxxB (B after pin or signal name)<br>Footnote for item marked with Note in the<br>Information requiring particular attention<br>Supplementary information<br>Binary xxxx or xxxxB<br>Decimal xxxx<br>Hexadecimal xxxxH                            | -                                       |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|
|                   | Prefix indicating the power                                                                                                                                                                      | Interacted contrait XXXXII         of 2 (address space, memory capacity):         K (kilo) $2^{10} = 1024$ M (mega) $2^{20} = 1024^2$ G (giga) $2^{30} = 1024^3$                                                                                                                                                                           |                                         |
| Related Documents | ted Documents The related documents indicated in this publication may include prelined However, preliminary versions are not marked as such.                                                     |                                                                                                                                                                                                                                                                                                                                            | reliminary versions.                    |
|                   | • CB-9 Family VX/VM Type     • NEC SYSTEM LSI DESIC     • NEC SYSTEM LSI DESIC     • NEC SYSTEM LSI DESIC     • NB85E Hardware User's     • NB85ET Hardware User's     • Memory Controller NB85E | e Core Library<br>U Core, Memory Controller Design Manua<br>Memory Macro (Compiled Type)<br>Design Manua<br>GN OPENCAD <sup>™</sup> V5.4<br>OPC_VSHELL User's Manua<br>GN OPENCAD V5.4<br>Verilog-XL <sup>™</sup> Interface User's Manual<br>GN OPENCAD V5.4<br>Design Compiler <sup>™</sup> Interface User's Manual<br>Manual<br>s Manual | I (A12982E)<br>I (A15050E)<br>(A15052E) |
|                   | • IE-V850E-MC, IE-V850E-                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                            | (U14487E)<br>(U14482E)                  |

The related documents listed above are subject to change without notice. Be sure to use the latest version of each document for designing.

### CONTENTS

| CHAPTE | ER 1 OVERVIEW                                                         | 16 |
|--------|-----------------------------------------------------------------------|----|
| 1.1    | Design Flow for CBIC with On-Chip NB85E                               | 16 |
| 1.2    | Items Specifically for On-Chip NB85E                                  | 17 |
| 1.3    | System Example                                                        | 18 |
| CHAPTE | ER 2 CONNECTION OF CLOCK CONTROLLER                                   | 19 |
| СНАРТ  | ER 3 CONNECTION OF ROM/RAM TO VFB/VDB                                 | 23 |
| 3.1    | Overview                                                              | 23 |
| 3.2    | Connection of Compiled Memory to VFB                                  | 24 |
| *      | 3.2.1 When connecting one ROM                                         | 26 |
| *      | 3.2.2 When connecting multiple ROMs                                   | 27 |
| 3.3    | Connection of Compiled Memory to VDB                                  | 32 |
| *      | 3.3.1 Operation when eight RAMs are connected                         | 37 |
| СНАРТ  | ER 4 CONNECTION TO VSB                                                | 40 |
| 4.1    | Connection of User Logic                                              | 40 |
|        | 4.1.1 Overview of VSB operation                                       | 42 |
|        | 4.1.2 Circuit example                                                 | 45 |
| 4.2    | Connection of Compiled Memory                                         | 51 |
| СНАРТЕ | ER 5 CONNECTION OF MEMORY CONTROLLER (MEMC)                           | 56 |
| 5.1    | Connection to SRAM                                                    |    |
| 5.2    | Connection to Page ROM                                                | 59 |
| 5.3    | Connection to SDRAM                                                   | 60 |
| СНАРТЕ | ER 6 CONNECTION TO NPB                                                | 62 |
| 6.1    | Overview of NPB                                                       | 62 |
| 6.2    | Connection of User Logic                                              |    |
| СНАРТЕ | ER 7 CACHE CONNECTION                                                 |    |
| 7.1    | Connection of Instruction Cache                                       | 69 |
|        | 7.1.1 Cautions when using instruction cache                           |    |
| 7.2    |                                                                       |    |
|        | 7.2.1 Cautions when using data cache                                  |    |
| СНАРТЕ | ER 8 CONNECTION TO IN-CIRCUIT EMULATOR (IE)                           |    |
| 8.1    | Using In-Circuit Emulator for NB85E (IE-V850E-MC-A)                   |    |
| 8.2    | Using N-Wire Type In-Circuit Emulator (IE-70000-MC-NW-A)              |    |
|        | 8.2.1 Connector for in-circuit emulator connection (in target system) |    |
|        | 8.2.2 Circuit example when RCU (NB85E901) is connected to NB85E       |    |
|        | 8.2.3 Circuit example when NB85ET is connected                        |    |
| *      | 8.2.4 Design of timing with N-wire type in-circuit emulator           | 81 |

|   | CHAPTE | R 9 CAUTIONS                                               | 82  |
|---|--------|------------------------------------------------------------|-----|
|   | 9.1    | Bus Contention When Moving from Read Cycle to Write Cycle  |     |
|   |        | (Using MEMC (NB85E500))                                    | 82  |
|   | 9.2    | Cautions on Verilog Simulation                             | 83  |
|   | 9.3    | Cautions on BUNRI-Testing Chip                             | 84  |
|   | 9.4    | Timing Adjustment                                          | 85  |
|   |        | 9.4.1 Adjustment of clock skew or data line hold violation |     |
|   |        | 9.4.2 Resolution of hold violation using design compiler   |     |
|   |        | 9.4.3 Clock skew adjustment                                |     |
|   | 9.5    | Device File                                                | 90  |
|   | CHAPTE | R 10 TEST CIRCUIT DESIGN                                   | 91  |
|   | 10.1   | Peripheral Macro Connection Example in Test Mode           | 92  |
|   |        | 2 Processing Pins in Test Mode                             |     |
|   |        | 10.2.1 Processing NB85E and NB85ET pins                    |     |
|   |        | 10.2.2 Processing MEMC pins                                |     |
| * | 10.3   | 3 Test Bus Auto Wiring                                     | 98  |
|   |        | 10.3.1 Test bus auto wiring method                         |     |
|   |        | 10.3.2 Verification of test bus by dummy model             |     |
| * | 10.4   | Test Bus PINF File Creation/Editing Methods                | 100 |
|   |        | 10.4.1 PINF file creation example                          |     |
|   | CHAPTE | R 11 TOTAL CHIP SIMULATION                                 | 106 |
|   | 11.1   | Creation of Test Patterns for Checking Connections         |     |
|   |        | 2 Verifying Timing Between Macros                          |     |
|   | CHAPTE | R 12 ROM CODE CREATION                                     | 111 |
| * | APPEND | NX REVISION HISTORY                                        | 112 |

# LIST OF FIGURES (1/3)

| Figure | e No. Title                                                                                             | Page |
|--------|---------------------------------------------------------------------------------------------------------|------|
| 1-1    | System Example                                                                                          | 18   |
| 2-1    | Clock Controller Connection Example<br>(Placing Oscillator Inside ASIC and Attaching Resonator Outside) | 19   |
| 2-2    | Clock Controller Timing Chart                                                                           |      |
| 2-3    | Example of Clock Controller HDL Creation                                                                | 21   |
| 2-4    | Clock Controller Connection Example (Using PLL Macro)                                                   | 22   |
| 3-1    | NB85E ROM Area Setting                                                                                  | 25   |
| 3-2    | ROM Access Timing                                                                                       | 25   |
| 3-3    | Example of Connecting One Compiled ROM (32 Bits $\times8$ Kwords) to VFB                                |      |
| 3-4    | Example of Connecting Two Compiled ROMs (32 Bits $\times$ 4 Kwords) to VFB                              |      |
| 3-5    | ROM Read Timing (For Same MEM Area)                                                                     |      |
| 3-6    | ROM Read Timing (When MEM Area Has Changed)                                                             | 30   |
| 3-7    | CSB, OEB Generation Block                                                                               |      |
| 3-8    | CSB and OEB Timings                                                                                     |      |
| 3-9    | RAM Access Timing                                                                                       |      |
| 3-10   | NB85E RAM Area Setting                                                                                  |      |
| 3-11   | Example of Connecting Compiled Memories to VDB (Four Memories)                                          | 35   |
| 3-12   | Example of Connecting Compiled Memories to VDB (Eight Memories)                                         | 36   |
| 3-13   | RAM Read Timing (Read from Same RAM Area)                                                               |      |
| 3-14   | RAM Read Timing (When RAM Area Has Changed)                                                             |      |
| 3-15   | RAM Write Timing                                                                                        | 39   |
| 4-1    | Example of Connecting User Logic to VSB                                                                 | 41   |
| 4-2    | VSB Timing (No Wait)                                                                                    | 42   |
| 4-3    | VSB Timing (One Wait)                                                                                   | 43   |
| 4-4    | VSB Timing (Address Hold)                                                                               | 44   |
| 4-5    | HDL Creation Example for User Logic Operating with No Wait                                              | 45   |
| 4-6    | Timing Chart for No Wait                                                                                | 46   |
| 4-7    | HDL Creation Example for User Logic Operating with One Wait                                             | 47   |
| 4-8    | Timing Chart for One Wait Insertion                                                                     | 48   |
| 4-9    | Example of HDL Creation for User Logic in Which Address Hold Function Is Used                           | 49   |

# LIST OF FIGURES (2/3)

| Figure No. Title |                                                                                          | Page |
|------------------|------------------------------------------------------------------------------------------|------|
|                  |                                                                                          |      |
| 4-10             | Timing Chart for Address Hold                                                            | 50   |
| 4-11             | Example of Connecting Compiled Memory                                                    | 52   |
| 4-12             | Timing Chart for Compiled Memory Access                                                  | 53   |
| 4-13             | Example of HDL Creation for Compiled Memory Access Controller                            | 54   |
| 5-1              | Example of Connecting NB85E, MEMC, and External Memory (SRAM, SDRAM)                     | 57   |
| 5-2              | Example of Connection to SRAM                                                            | 58   |
| 5-3              | Example of Connection to Page ROM                                                        | 59   |
| 5-4              | Example of Connection to SDRAM                                                           | 61   |
| 6-1              | NPB Operation Timing Chart                                                               | 62   |
| 6-2              | Example of Connecting User Logic                                                         | 64   |
| 6-3              | Example of Address Decoder HDL Creation                                                  | 64   |
| 6-4              | Example of User Logic HDL Creation                                                       | 65   |
| 6-5              | User Logic Operation Timing Chart                                                        | 66   |
| 6-6              | Example of HDL Creation for User Logic with Retry Function                               | 67   |
| 6-7              | Operation Timing Chart of User Logic with Retry Function                                 | 68   |
| 7-1              | Example of Connecting Instruction Cache (NB85E213) to NB85E                              | 69   |
| 7-2              | Cache Area Setting Example                                                               | 71   |
| 7-3              | Example of Connecting Data Cache (NB85E263) to NB85E                                     | 73   |
| 8-1              | Connection of In-Circuit Emulator for NB85E (IE-V850E-MC-A)                              | 76   |
| 8-2              | Connection of N-Wire Type In-Circuit Emulator                                            | 77   |
| 8-3              | Pin Placement Diagram of Connector for In-Circuit Emulator Connection (in Target System) | 77   |
| 8-4              | Circuit Example for In-Circuit Emulator Connection (NB85E + RCU (NB85E901))              | 79   |
| 8-5              | Circuit Example for In-Circuit Emulator Connection (NB85ET)                              | 80   |
| 8-6              | Delays Between NB85ET and N-Wire Type In-Circuit Emulator                                | 81   |
| 9-1              | User Logic Design Example                                                                | 84   |
| 9-2              | Skew or Hold Violation Countermeasure Execution Example                                  | 86   |
| 10-1             | Example of Connecting Peripheral Macro to NB85E                                          | 92   |

# LIST OF FIGURES (3/3)

| Figure | No. Title                                                                             | Page |
|--------|---------------------------------------------------------------------------------------|------|
|        |                                                                                       |      |
| 10-2   | User Logic Design Example                                                             | 94   |
| 10-3   | User Logic Design Example                                                             | 96   |
| 10-4   | PINF File Creation Example (NB85E + NU85E500 + NU85E502 + NB85E901 + NB85E212)        | 101  |
| 10-5   | PINF File Creation Example (NB85ET + NU85E500 + NU85E502 + NB85E212)                  | 104  |
|        |                                                                                       |      |
| 11-1   | Block Diagram for Total Chip Simulation (When There Is No ROM in VFB)                 | 107  |
| 11-2   | Block Diagram for Total Chip Simulation                                               |      |
|        | (When There Is ROM in VFB and Creating Test Pattern by Connecting Virtual ROM to VSB) | 108  |
| 11-3   | Block Diagram for Total Chip Simulation                                               |      |
|        | (When There Is ROM in VFB and Writing Program for Testing in That ROM)                | 109  |

# LIST OF TABLES

| Table | No. Title                                                                        | Page |
|-------|----------------------------------------------------------------------------------|------|
| 4-1   | User Logic Interface Signals                                                     | 40   |
| 6-1   | Example of User Logic Address Assignment                                         | 63   |
| 8-1   | Pin Functions of Connector for In-Circuit Emulator Connection (in Target System) | 78   |



# 1.1 Design Flow for CBIC with On-Chip NB85E

#### 1.2 Items Specifically for On-Chip NB85E

#### (1) Total chip simulation

Total chip simulation is simulation that checks the connections between macros by operating the NB85E. See **CHAPTER 11 TOTAL CHIP SIMULATION** for the simulation method and cautions.

#### (2) System debugging

System debugging debugs the entire target system, including the CBIC under development.

#### (a) Debugging using breadboard

#### <1> Debugging using in-circuit emulator for NB85E (IE-V850E-MC-A)

Debug the target system by creating a breadboard using a general-purpose LSI, FPGA, and G/A. See **8.1 Using In-Circuit Emulator for NB85E (IE-V850E-MC-A)** regarding connecting to the IE-V850E-MC-A.

#### <2> Debugging using N-Wire type in-circuit emulator (IE-70000-MC-NW-A)

Since the NB85ET has a debug control unit (DCU) that supports an on-chip debug function, realtime debugging using an ES is possible by connecting to the IE-70000-MC-NW-A via a dedicated debug interface based on JTAG.

Similar debugging can be performed in the case of an NB85E if an NB85E901 (run control unit (RCU)) is connected.

| Debug           | NB85ET | NB85E + NB85E901 |
|-----------------|--------|------------------|
| Break           |        | $\checkmark$     |
| Event detection |        | _                |
| Trace           |        | _                |

See 8.2 Using N-Wire Type In-Circuit Emulator (IE-70000-MC-NW-A) regarding connecting to the in-circuit emulator.

#### (b) Debugging using co-simulation

Debug the target system using co-simulation.

Normally, integrated debugging of hardware and software using an in-circuit emulator is not possible before ES completion. However, co-simulation makes possible target-less debugging of both hardware and software at the system design stage before ES completion. Contact NEC for details.

#### (3) ROM code creation and revision

Sign-off to NEC must be performed using a specific format. See **CHAPTER 12 ROM CODE CREATION** regarding the format.

#### 1.3 System Example

In this manual, the ASIC shown below is used as an example and explained by focussing on the method of connecting each peripheral macro to the NB85E.





#### CHAPTER 2 CONNECTION OF CLOCK CONTROLLER

When using the NB85E software or hardware STOP mode, connect a clock controller between the oscillator (or external input clock) and NB85E or between the oscillator (or external input clock) and an other circuit related to VBCLK so that sufficient oscillation stabilization time can be guaranteed, allowing a stable clock to be supplied to the NB85E.



# Figure 2-1. Clock Controller Connection Example (Placing Oscillator Inside ASIC and Attaching Resonator Outside)

The oscillator oscillates when a low level is output from the CCENB pin of the clock controller. Oscillation stabilization time is counted by the counter register (CNTR) inside the clock controller. The standard value of CNTR is determined using the following relational expression.

CNTR >> Oscillation stabilization time [s] × Clock frequency [Hz]

\*

**Example** Using an oscillator for which the output clock frequency is 20 MHz and the oscillation stabilization time is 1 ms:

 $CNTR >> 1 \times 10^{-3} \times 20 \times 10^{6} = 20000 (4E20H)$ 

Caution If the STPAK pin of the NB85E is unused, input a high level to the STPAK pin. If a high level is not input, the HWSTOPRQ signal and SWSTOPRQ signal do not become active and STOP mode cannot be entered.

Figure 2-2 shows the timing chart of each signal of the clock controller in Figure 2-1 and Figure 2-3 shows an HDL creation example.



Figure 2-2. Clock Controller Timing Chart

In the example in Figure 2-3, the reset input of the NB85E (DCRESZ) is also controlled. This is in order to reliably supply a stable clock during a reset period. The DCRESZ signal rises after the oscillation stabilization time has been secured following the rise of the RESZ signal (system reset).

```
module CLKCTL(
      CCKOT, SWSTOPRQ, HWSTOPRQ, CGREL,
      CCKIN, CCENB, DCRESZ, RESZ
      );
                                        // Output to VBCLK pin of NB85E
      output
                       CCKOT ;
                       SWSTOPRQ ; // Input from SWSTOPRQ pin of NB85E
      input
                       HWSTOPRQ ; // Input from HWSTOPRQ pin of NB85E
      input
                                        // Output to CGREL pin of NB85E
      output
                       CGREL ;
                       CCKIN;
                                        // Input from CLKOUT pin of oscillator (or PLL)
      input
                                        // Output to ENB pin of oscillator (or PLL)
      output
                       CCENB ;
                       DCRESZ :
                                        // Output to DCRESZ pin of NB85E
      output
                       RESZ ;
                                        // System reset input
      input
      reg [7:0] CNTR ;
                                        // Oscillation stabilization time counter. The bit width is adjusted in accordance with the oscillation stabilization time.
                       CKOTEN ;
                                        // Clock output enable
      reg
      reg
                       DCRESZ;
                                        // NB85E reset
                       STOPRQZ = ~ (SWSTOPRQ | HWSTOPRQ);
      wire
                       CGREL = ( CNTR == 8'hFE ) ;
                                                         // CGREL output timing setting
      wire
                       CCKOT = CKOTEN & CCKIN ;
      wire
                       CCENB = ~STOPRQZ ;
      wire
      // synopsys async_set_reset "DCRESZ"
      always @( negedge CCKIN or negedge STOPRQZ or negedge RESZ ) begin
              if (~RESZ) begin
                       CNTR
                                        <= 8'h00 :
                       CKOTEN
                                        <= 1'b0 ;
                       DCRESZ
                                        <= 1'b0 ;
               end
               else begin
                       if( ~STOPRQZ ) begin
                               CNTR
                                                <= 8'h00 ;
                               CKOTEN
                                                <= 1'b0 ;
                       end
                       else begin
                               if ( CNTR == 8'hF0 ) CKOTEN
                                                                 <= 1'b1 ;
                                                                                 // Clock output timing setting. The oscillation stabilization time is F0H.
                               if ( CNTR == 8'hF5 ) DCRESZ
                                                                 <= 1'b1 ;
                                                                                 // DCRESZ output timing setting
                               if ( CNTR != 8'hFF ) CNTR
                                                                 <= CNTR + 1 ; // Internal counter stop timing setting
                       end
               end
       end
endmodule
```

| Figure 2-3. | Example of | <b>Clock Controller</b> | <b>HDL Creation</b> |
|-------------|------------|-------------------------|---------------------|
|-------------|------------|-------------------------|---------------------|

When using a PLL macro, the configuration is as shown in Figure 2-4.



Figure 2-4. Clock Controller Connection Example (Using PLL Macro)

The PLL macro and clock controller in Figure 2-4 are described below.

#### (1) PLL macro

"AAPLMWFB" is taken as an example (contact NEC for details about macros). The input clock corresponds to 5 MHz to 160 MHz, and the output clock to 50 MHz to 250 MHz.

In Figure 2-4, if each of pins M4 to M0, N6 to N0, and P2 to P0, which set counter values, and each of pins S1 and S0, which set VCO range setting switching, is set as follows, when a 16.384 MHz clock is input to the Fr pin, a 49.152 MHz (50% duty) signal is obtained from the Fo pin.

- M4 to M0: L, L, L, L, H
- N6 to N0: L, L, L, L, L, H, H
- P2 to P0: L, L, H
- S1, S0: L, L

Remark L: Low-level input H: High-level input

#### (2) Clock controller

A control pin (PSTBY) must be added for setting the PLL to standby mode when the controller shown in Figure 2-1 is in STOP mode.

In addition, if both the PLL (twPLL) and the OSC (twosc) are made to oscillate, the oscillation stabilization time must take into account the time interval twPLL+twosc.

# CHAPTER 3 CONNECTION OF ROM/RAM TO VFB/VDB

### 3.1 Overview

The NB85E provides a V850E fetch bus (VFB) that makes direct connection of ROM possible and a V850E data bus (VDB) that makes direct connection of RAM possible.

The VFB is a bus optimized for fetching instructions, and the VDB is a bus optimized for accessing data.

Since these buses are independent of the VSB, instructions can be fetched, or data accessed, even if the VSB is occupied by another macro.

#### 3.2 Connection of Compiled Memory to VFB

The VFB is a bus for fixed 32-bit access instruction fetches that is optimized for data access and by which one clock access is possible.

When a high level is input to the IFIROME pin, an instruction fetch from a ROM connected to the VFB is possible. The compiled ROM that can be used by the CB-9 Family VX/VM Type is fast synchronous ROM.

When connecting compiled ROM to the VFB, it is necessary to compute the relationship of the ROM access time and cycle time to the CPU clock frequency and check that the timing fits adequately (see **9.4 Timing Adjustment**).

Figure 3-1 shows the NB85E ROM area setting, Figure 3-2 shows the ROM access timing, Figure 3-3 shows an example in which one compiled ROM of 32 bits  $\times$  8 Kwords for the CB-9 Family VX Type is connected, and Figure 3-4 shows an example in which two compiled ROMs of 32 bits  $\times$  4 Kwords for the CB-9 Family VX Type are connected.

- Remarks 1. For details about compiled memory, refer to the CB-9 Family VX/VM Type Memory Macro (Compiled Type) Design Manual (A12982E).
  - 2. For the creation method of compiled memory, refer to NEC SYSTEM LSI DESIGN OPENCAD V5.4 OPC\_VSHELL User's Manual (A15050E).
  - When using compiled memory, test wiring is needed in order to use the ASIC standard test procedure. Refer to the CB-9 Family VX/VM Type Design Manual (A12745E) regarding the test procedure.



\*







25

#### ★ 3.2.1 When connecting one ROM

\*

Figure 3-3 shows an example of connecting one compiled ROM of 32 bits  $\times$  8 Kwords for the CB-9 Family VX Type.

The operation of the VFB of the NB85E is of the pipeline type, whereby an address and the data that corresponds to that address is shifted by only 1 cycle. Here, to facilitate securing of the address setup/hold time, a flip-flop is inserted between the IROMA14 to IROMA2 pins of the NB85E and the A12 to A0 pins of the compiled ROM. Also, since data is held while the IROMEN is low level, a level latch is inserted between the DO31 to DO0 pins of the compiled ROM and the IROMZ31 to IROMZ0 pins of the NB85E.

The compiled ROM addresses are allocated to 0x00000H to 0x07FFFH.

#### Figure 3-3. Example of Connecting One Compiled ROM (32 Bits × 8 Kwords) to VFB



Since the data bus inverts the actual data logic, be careful when dumping data during simulation.
 The figure shows the normal pin wiring method. Wire test pins in accordance with the ASIC test procedure (for details, refer to the CB-9 Family VX/VM Type Design Manual (A12745E)).

#### 3.2.2 When connecting multiple ROMs

Figure 3-4 shows an example of connecting two compiled ROMs of 32 bits  $\times$  4 Kwords for the CB-9 Family VX Type. For the ROM area memory map, refer to Figure 3-1 (2) When two compiled ROMs of 32 bits  $\times$  4 Kwords are connected.

When multiple ROMs (for example MEM0 and MEM1) are connected, normal read may be prevented because the CSB changes to inactive level prior to the completion of data read from ROM during continuous fetching for the area spanning MEM0 and MEM1 or during branching between MEM0 and MEM1.

To prevent this, in the connection example shown in Figure 3-4, a circuit that adjusts the CSB change timing during area changes is inserted between the IROMEN pin of the NB85E and the CSB pin of the compiled ROM. This circuit also functions as an address decoder between MEM0 and MEM1.

The compiled ROM addresses are allocated to 0x0000H to 0x3FFFH for MEM0 and 0x4000H to 0x7FFFH for MEM1.



Figure 3-4. Example of Connecting Two Compiled ROMs (32 Bits × 4 Kwords) to VFB

Since the data bus inverts the actual data logic, be careful when dumping data during simulation.
 The figure shows the normal pin wiring method. Wire test pins in accordance with the ASIC test procedure (for details, refer to the CB-9 Family VX/VM Type Design Manual (A12745E)).

#### (1) ROM read from the same MEM area

When the result of decoding addresses is MEM0 area (in Figure 3-4, IROMA14 is low level), CSB0 becomes active as soon as IROMEN becomes active. The address on the MEM0 side is latched at the rising edge of the next clock after CSB0 becomes active, OEB0 becomes active at the next falling edge, and the valid data is input to IROMZ31 to IROMZ0.

At the next rising edge after IROMEN becomes inactive, at the same time as OEB0 becomes inactive, IROMZ31 to IROMZ0 hold the value at that time. This is because the values are held without performing ROM read while IROMEN is inactive, through level latching between D0 and IROMZ31 to IROMZ0. At the next falling edge of the clock after OEB0 becomes inactive, CSB0 becomes inactive. Figure 3-5 shows the timing when the MEM0 area is accessed continually.



#### Figure 3-5. ROM Read Timing (For Same MEM Area)

#### (2) ROM read when MEM area has changed

Figure 3-6 shows the CSB0, CSB1, OEB0, and OEB1 timings during continuous access to A0 to A2 (MEM0 area) and A3 to A6 (MEM1 area).

Even if IROMA14 to IROMA2 become A3 and the ROM address changes from the MEM0 area to the MEM1 area, since the data (D2) read timing for A2 is one clock later, at the rising edge of VCLK, OEB0 is extended by 1 clock, and CSB0 by 1.5 clocks. CSB1 is made active at the falling edge of A3 for preparation to read D3. To avoid data conflict between MEM0 and MEM1, OEB1 becomes active 0.5 clocks after OEB0 becomes inactive.



Figure 3-6. ROM Read Timing (When MEM Area Has Changed)

Figure 3-7 shows the CSB0, OEB0 generation block, and Figure 3-8 shows the CSB0 and OEB0 timings. (<a> to <c> in Figure 3-7 correspond to <a> to <c> on the MEM0 side in Figure 3-8.)









#### 3.3 Connection of Compiled Memory to VDB

The VDB is a bus that is optimized for data access and can perform access in as fast as one clock.

Access is possible using 8-bit, 16-bit, or 32-bit units.

When connecting compiled RAM to the VDB, it is necessary to compute the relationship of the compiled RAM access time and cycle time to the CPU clock frequency and check that the timing fits adequately (see **9.4 Timing Adjustment**).

Figure 3-9 shows the RAM access timing, Figure 3-10 shows the NB85E RAM area setting, Figure 3-11 shows an example in which four compiled RAMs of 8 bits  $\times$  2 Kwords for the CB-9 Family VX Type are connected, and Figure 3-12 shows an example in which eight compiled RAMs of 8 bits  $\times$  2 Kwords are connected.

- Remarks 1. For details about compiled memory, refer to the CB-9 Family VX/VM Type Memory Macro (Compiled Type) Design Manual (A12982E).
  - 2. For the creation method of compiled memory, refer to NEC SYSTEM LSI DESIGN OPENCAD V5.4 OPC\_VSHELL User's Manual (A15050E).
  - 3. When using compiled memory, test wiring is needed in order to use the ASIC standard test procedure. Refer to the CB-9 Family VX/VM Type Design Manual (A12745E) regarding the test procedure.

Figure 3-9. RAM Access Timing



\*



Figure 3-10. NB85E RAM Area Setting





Preliminary Design Manual A14335EJ3V0DM





#### 3.3.1 Operation when eight RAMs are connected

### (1) Read from same RAM area

Figure 3-13 shows the timing when the RAM area of either MEM0 to MEM3 or MEM4 MEM7 is read. To support read access in the VDB pipeline method, OEB is generated with the result of decoding IRAMA13 delayed by 1 clock. To prevent data conflicts, CSB is generated by ORing the address decoding result and OEB.

As soon as the result of inputting and decoding IRAMEN and IRAMA13 (refer to  $\langle A \rangle$  in Figure 3-12) becomes active, CSBn becomes active. RAM starts being read at the next rising edge of the clock, but output is not performed because OEBn is inactive at that time. OEBn becomes active at the next falling edge of the clock, and valid data is input to IRAMZ31 to IRAMZ0 (n = 1, 0).

At the next rising edge after the decoded result becomes inactive, at the same time that OEBn becomes inactive, IRAMZ31 to IRAMZ0 hold the value at that time. This is because they hold the value without reading RAM while OEBn is inactive. At the next falling edge of the clock after OEBn becomes inactive, CSBn becomes inactive.

Since the pipeline method is not used during write access, the result of decoding IRAMA13 is transferred as is to CSB.



Figure 3-13. RAM Read Timing (Read from Same RAM Area)

### (2) Read when RAM area has changed

Figure 3-14 shows the CSB0, OEB0, CSB1, and OEB1 timings during continuous read access to A0 and A1 (MEM0 to MEM3 area) and A2 (MEM4 to MEM7 area).

Even if IRAMA13 to IRAMA2 change from A1 to A2, and the RAM address changes from the MEM0 to MEM3 area to the MEM4 to MEM7 area, the timing for reading the data (D1) corresponding to A1 is the rising edge of the clock 0.5 clocks later, so OEB0 and CSB0 for the MEM0 to MME3 area are extended 0.5 clocks and 1 clock, respectively. Since CSB1 reads D2, it becomes active when IRAMA13 to IRAMA2 become A2. In order to prevent data conflict, OEB1 becomes active 0.5 clocks after OEB0 becomes inactive.





Figure 3-15 shows the CSB0 and CSB1 timings during continuous write access to A0 and A1 (MEM0 to MEM3 area) and A2 (MEM4 to MEM7 area).

In the case of write access, since pipeline processing is not required, CSB is generated based on IRAMEN and the address decoding result.





### **CHAPTER 4 CONNECTION TO VSB**

### 4.1 Connection of User Logic

This section describes how to connect user logic to the VSB.

Three kinds of read/write 32-bit registers are taken as examples of user logic. These registers operate using no wait, one wait, and address hold.

Each register can be written in word units only and undefined values are written in bits that are written by byte or halfword instructions. Moreover, all bits are cleared (0) on reset input.

Signals that user logic uses in the interface to the outside are as follows.

| Signal Name   | I/O    | Function                                                                                  |
|---------------|--------|-------------------------------------------------------------------------------------------|
| VBCLK         | Input  | System clock                                                                              |
| VBRESZ        | Input  | System reset                                                                              |
| CSZ           | Input  | Select signal (one of VDCSZ7 to VDCSZ0)                                                   |
| VBA25 to VBA0 | Input  | Address input                                                                             |
| VBD31 to VBD0 | I/O    | Data input/output                                                                         |
| VBWRITE       | Input  | Write status                                                                              |
| VBWAIT        | Output | Wait response output                                                                      |
| VBAHLD        | Output | Address hold response output                                                              |
| VBLAST        | Output | Last response output                                                                      |
| BUNRI         | Input  | Normal/test mode selection input (used to make output high impedance status when testing) |

### Table 4-1. User Logic Interface Signals



### Figure 4-1. Example of Connecting User Logic to VSB

2. The user logic CSZ is an example when the CS2 area is used.

### 4.1.1 Overview of VSB operation

★ The basic VSB timing is 1-clock access, as shown in Figure 4-2. Also, the USB is a pipeline type bus that shifts data corresponding to addresses by one clock.

Timing adjustment is performed by inserting a wait cycle or address hold cycle as needed by manipulating the VBWAIT signal or VBAHLD signal.

### (1) For no wait (basic timing)

Output an address during one clock to perform a read or write during the next half clock.

The data bus (VBD31 to VBD0) drives only while the clock (VBCLK) is high level. While the clock is low level, it has undefined status in which the NB85E internal bus holder is driving (Weak unknown).

The VBWAIT, VBAHLD, and VBLAST signals drive only while the clock is low level. While the clock is high level, it has undefined status in which the NB85E internal bus holder is driving (Weak unknown).



Figure 4-2. VSB Timing (No Wait)

### (2) For one wait

Output an address in two clock periods to perform a read or write in the next half clock. By inserting a wait, a low-speed circuit can be connected.





### (3) For address hold

\*

Similar to the case for one wait, two clock periods are used for one data transfer. The time interval from address output until data input or output is the same as for basic timing, but since the address is held until the end of the read cycle or write cycle, designing the interface circuit is easy.



### Figure 4-4. VSB Timing (Address Hold)

### 4.1.2 Circuit example

#### (1) For no wait

An example of connecting user logic that operates using no wait is shown below. In this example, reading or writing is performed at high speed, but when the VBCLK frequency is high, guaranteeing the data setup time or hold time is difficult.



```
module UDL_NOWAIT( VBCLK, VBRESZ, CSZ, VBA, VBD, VBWRITE, VBWAIT, VBAHLD, VBLAST, BUNRI );
        input
                         VBCLK ;
        input
                         VBRESZ ;
                         CSZ;
        input
                         VBA ;
        input [25:0]
                         VBD;
        input [31:0]
                         VBWRITE ;
        input
        output
                         VBWAIT ;
        output
                         VBAHLD;
        output
                         VBLAST ;
                         BUNRI;
        input
// nowait
        reg [31:0]
                         reg1;
                         sel_reg_rd;
        reg
        reg
                         sel_reg_wr;
                         sel = (CSZ==1'b0 && VBA[7:2]==6'b0000_00) ? 1'b1 : 1'b0 ;
        wire
// wait control
                         VBWAIT = (~VBCLK & sel) ? 1'b0 : 1'bZ ;
        assign
                         VBAHLD = (~VBCLK & sel) ? 1'b0 : 1'bZ ;
        assign
        assign
                         VBLAST = (~VBCLK & sel) ? 1'b0 : 1'bZ ;
// read
                         VBD = ( sel_reg_rd & VBCLK & ~BUNRI ) ? reg1 : 32'hZZZZZZZ ;
        assign
        always @(VBCLK)
        begin
                if( VBCLK == 1'b0 )
                begin
                         sel_reg_rd <= sel & ~VBWRITE ;</pre>
                end
        end
// write
        always @( negedge VBCLK or negedge VBRESZ )
        begin
                if( ~VBRESZ)
                         reg1 <= 32'h00000000;
                else
                begin
                         if( sel_reg_wr )
                                reg1 <= VBD ;
                         sel_reg_wr <= sel & VBWRITE ;</pre>
                end
        end
endmodule
```



Figure 4-6. Timing Chart for No Wait

### (2) For insertion of one wait

An example of connecting user logic that operates using one wait is shown below. In this example, delaying the data read or write timing 1 clock makes it possible to have extra access time.

To increase the number of wait insertions, use a VBSTZ signal after extending it using a configuration like that of a shift register.



```
module UDL_1WAIT( VBCLK, VBRESZ, CSZ, VBA, VBD, VBSTZ, VBWRITE, VBWAIT, VBAHLD, VBLAST, BUNRI );
        input
                         VBCLK ;
                         VBRESZ;
        input
                         CSZ;
        input
        input [25:0]
                         VBA ;
                         VBD;
        input [31:0]
                         VBSTZ;
        input
        input
                         VBWRITE ;
        output
                        VBWAIT ;
        output
                         VBAHLD;
        output
                        VBLAST ;
        input
                         BUNRI;
        reg [31:0]
                         reg2;
        reg
                         sel_reg_rd ;
                         sel_reg_wr;
        reg
        wire
                         sel = (CSZ==1'b0 && VBA[7:2]==6'b0000_01) ? 1'b1 : 1'b0 ;
// wait control
                         wa = ~VBSTZ ; // 1wait
        wire
                         VBWAIT = (~VBCLK & sel) ? wa : 1'bZ ;
        assign
        assign
                         VBAHLD = (~VBCLK & sel) ? 1'b0 : 1'bZ ;
        assign
                         VBLAST = (~VBCLK & sel) ? 1'b0 : 1'bZ ;
// read
                        VBD = ( sel_reg_rd & VBCLK & ~BUNRI) ? reg2 : 32'hZZZZZZZ ;
        assign
        always @(VBCLK)
        begin
                if( VBCLK == 1'b0 )
                begin
                         sel_reg_rd <= sel & ~VBWRITE ;</pre>
                end
        end
// write
        always @( negedge VBCLK or negedge VBRESZ )
        begin
                if(~VBRESZ)
                         reg2 <= 32'h0000000;
                else
                begin
                         if( sel_reg_wr )
                                reg2 <= VBD ;
                         sel_reg_wr <= sel & VBWRITE & ~wa;
                end
        end
endmodule
```



### Figure 4-8. Timing Chart for One Wait Insertion

3. Input and output are shown as seen from the user logic.

### (3) For address hold

An example of connecting user logic in which the address hold function is used is shown below. In this example, the address does not change in a data read or write cycle. Therefore, address latch is not necessary and the circuit can be simplified.

This also can be combined with wait insertion to connect long-access-time I/O.

#### Figure 4-9. Example of HDL Creation for User Logic in Which Address Hold Function Is Used

```
module UDL_AHLD( VBCLK, VBRESZ, CSZ, VBA, VBD, VBSTZ, VBWRITE, VBWAIT, VBAHLD, VBLAST, BUNRI ) ;
        input
                        VBCLK ;
                        VBRESZ;
        input
                        CSZ;
        input
        input [25:0]
                        VBA ;
                        VBD;
        input [31:0]
                        VBSTZ;
        input
        input
                        VBWRITE ;
        output
                        VBWAIT ;
        output
                        VBAHLD;
        output
                        VBLAST ;
        input
                        BUNRI;
        reg [31:0]
                        reg3;
        wire
                        sel = (CSZ==1'b0 && VBA[7:2]==6'b0000_10) ? 1'b1 : 1'b0 ;
// wait control
        wire
                        wa = ~VBSTZ ; // 1wait
                        VBWAIT = (~VBCLK & sel) ? wa : 1'bZ ;
        assign
        assign
                        VBAHLD = (~VBCLK & sel) ? wa : 1'bZ ;
                        VBLAST = (~VBCLK & sel) ? 1'b0 : 1'bZ ;
        assign
// read
        rea
                        VBSTZ_1E
        always @(posedge VBCLK)
                        VBSTZ_1E = VBSTZ;
        wire
                        sel_reg_rd = (sel & ~VBWRITE);
        assign
                        VBD = ( sel_reg_rd & VBCLK & ~VBSTZ_1E & BUNRI ) ? reg3 : 32'hZZZZZZZ ;
// write
                        sel_reg_wr = (sel & VBWRITE & ~wa);
        wire
        always @( negedge VBCLK or negedge VBRESZ )
        begin
               if( ~VBRESZ )
                        reg3 <= 32'h00000000;
               else
               begin
                        if( sel_reg_wr )
                                reg3 <= VBD ;
               end
        end
endmodule
```



Figure 4-10. Timing Chart for Address Hold

## 4.2 Connection of Compiled Memory

This section describes how to connect high-density synchronous 1-port RAM to the VSB without using a memory controller (MEMC).

Figure 4-11 shows a connection example, Figure 4-12 shows a timing chart, and Figure 4-13 shows an example of the creation of the HDL for the compiled memory access controller (VSB\_VDL\_MEMCBC9).

The following high-density synchronous 1-port RAM is used in this connection example.

- Macro block name: W8K08100
- Memory capacity (total): 4 KB (1024 words  $\times$  8 bits  $\times$  4<sup>Note</sup>)
- Operating frequency: 66 MHz
- **Note** The bit width of a high-density synchronous 1-port RAM can be selected from 1 to 32 bits in 1-bit units. The VSB data bus width is 32 bits, but it must be possible to access RAM in 8-bit units. Therefore, connect four RAMs with a bit width of 8 bits to configure a 32-bit width.
- For a normal access, the VSB performs a "pipeline method" bus operation, which shifts the data to an arbitrary address by one cycle. In the connection example in Figure 4-11, compiled memory access control is simplified by controlling the VBWAIT, VBAHLD, and VBLAST signals and responding to the NB85E in address hold status when reading and in wait status when writing.

Moreover, CB-9 Family VX/VM Type synchronous RAM has the following timing restrictions.

- Address change that uses the same timing as a clock input signal (BE) rise is prohibited
- CSB signal change when the clock input signal (BE) is high level is prohibited

To observe these restrictions, measures like the following are taken in the connection example in Figure 4-11.

- The clock (VBCLK) is input to the NB85E at the clock input pin (BE)
- An address that changes at the rise of VBCLK and CSB (VDCSZ) are used by latching at the fall of VBCLK
- OEB is used by latching so that it has the same timing as CSB
- For WEB, VBBENZ signal, which is the byte enable signal from the NB85E, is used under the conditions CSB = 0 and OEB = 1







Figure 4-12. Timing Chart for Compiled Memory Access

| VRWA                                             |                                                                                                                                                   | D,VBLAST,BUNF                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                        | B,VBBENZ,WEB,VBSTZ                                                    | , |  |
|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|---|--|
| VDVVA                                            | II,VDANL                                                                                                                                          | D, VBLAST, BUINF                                                                                                                                                                                                                                                                                                                                                                                                     | ור <i>)</i> ,                                                                                                                                                                                                                                                                          |                                                                       |   |  |
| input                                            |                                                                                                                                                   | VPRESZ;                                                                                                                                                                                                                                                                                                                                                                                                              | // Reset                                                                                                                                                                                                                                                                               |                                                                       |   |  |
| input                                            |                                                                                                                                                   | VBCLK ;                                                                                                                                                                                                                                                                                                                                                                                                              | // System clock                                                                                                                                                                                                                                                                        |                                                                       |   |  |
| input                                            | [11:2]                                                                                                                                            | VBA ;                                                                                                                                                                                                                                                                                                                                                                                                                | // Address bus                                                                                                                                                                                                                                                                         | from VSB                                                              |   |  |
| output                                           | [9:0]                                                                                                                                             | Α;                                                                                                                                                                                                                                                                                                                                                                                                                   | // Address bus                                                                                                                                                                                                                                                                         | to Memory macro                                                       |   |  |
| input                                            |                                                                                                                                                   | VDCSZ ;                                                                                                                                                                                                                                                                                                                                                                                                              | // Chip area sel                                                                                                                                                                                                                                                                       | ect                                                                   |   |  |
| input                                            |                                                                                                                                                   | VBWRITE ;                                                                                                                                                                                                                                                                                                                                                                                                            | // Transfer dire                                                                                                                                                                                                                                                                       | ction                                                                 |   |  |
| input                                            | [3:0]                                                                                                                                             | VBBENZ ;                                                                                                                                                                                                                                                                                                                                                                                                             | // Byte enable                                                                                                                                                                                                                                                                         |                                                                       |   |  |
| output                                           |                                                                                                                                                   | CSB ;                                                                                                                                                                                                                                                                                                                                                                                                                | // Chip area sel                                                                                                                                                                                                                                                                       |                                                                       |   |  |
| output                                           | <b>10.01</b>                                                                                                                                      | OEB ;                                                                                                                                                                                                                                                                                                                                                                                                                | // RAM data ou                                                                                                                                                                                                                                                                         |                                                                       |   |  |
| output                                           | [3:0]                                                                                                                                             | WEB;                                                                                                                                                                                                                                                                                                                                                                                                                 | // Write enable                                                                                                                                                                                                                                                                        |                                                                       |   |  |
| input                                            |                                                                                                                                                   | VBSTZ ;                                                                                                                                                                                                                                                                                                                                                                                                              | // Transfer star                                                                                                                                                                                                                                                                       |                                                                       |   |  |
| output                                           |                                                                                                                                                   | VBWAIT ;                                                                                                                                                                                                                                                                                                                                                                                                             | // Wait respons                                                                                                                                                                                                                                                                        |                                                                       |   |  |
| output<br>output                                 |                                                                                                                                                   | VBAHLD ;<br>VBLAST ;                                                                                                                                                                                                                                                                                                                                                                                                 | // Address hold<br>// Last data res                                                                                                                                                                                                                                                    |                                                                       |   |  |
| input                                            |                                                                                                                                                   | BUNRI;                                                                                                                                                                                                                                                                                                                                                                                                               | // Test mode                                                                                                                                                                                                                                                                           | polise                                                                |   |  |
| input                                            |                                                                                                                                                   | BONNI,                                                                                                                                                                                                                                                                                                                                                                                                               | // Test mode                                                                                                                                                                                                                                                                           |                                                                       |   |  |
| wire                                             | [11:2]                                                                                                                                            | VBA ;                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                        |                                                                       |   |  |
| reg                                              | [9:0]                                                                                                                                             | Α;                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                        |                                                                       |   |  |
| reg                                              | [3:0]                                                                                                                                             | WEB;                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                        |                                                                       |   |  |
| reg                                              |                                                                                                                                                   | CSB,OEB ;                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                        |                                                                       |   |  |
| reg                                              |                                                                                                                                                   | ResOut ;                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                        |                                                                       |   |  |
| wire                                             | [3:0]                                                                                                                                             | VBBENZ ;                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                        |                                                                       |   |  |
| wire                                             | <b>14 C</b>                                                                                                                                       | VBWAIT, VBAHI                                                                                                                                                                                                                                                                                                                                                                                                        | LD,VBLAST ;                                                                                                                                                                                                                                                                            |                                                                       |   |  |
| reg                                              | [1:0]                                                                                                                                             | State ;                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                        |                                                                       |   |  |
| reg                                              | [2:0]                                                                                                                                             | Response ;<br>WRITE ;                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                        |                                                                       |   |  |
| reg                                              |                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                        |                                                                       |   |  |
| parame                                           | eter [1:0] S                                                                                                                                      | or Response({VB<br>S_READY = 2'b00                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                        | AST})<br>S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;                    |   |  |
| parame<br>parame<br>// synoj                     | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( negeo                                                                                             | or Response({VB<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or neg                                                                                                                                                                                                                                                                                                                        | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10                                                                                                                                                                                                                                                | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;                             |   |  |
| parame<br>parame<br>// synoj                     | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( negeo                                                                                             | or Response({VB<br>S_READY = 2'b00<br>O_READY = 3'b00<br>c_set_reset "VPR                                                                                                                                                                                                                                                                                                                                            | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo                                                                                                                                                                                                                  | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;                             |   |  |
| parame<br>parame<br>// synoj                     | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( negeo                                                                                             | or Response({VB<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or net<br>ESZ ) begin                                                                                                                                                                                                                                                                                                         | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo                                                                                                                                                                                                                  | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;                             |   |  |
| parame<br>parame<br>// synoj                     | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( negeo                                                                                             | or Response({VB<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or net<br>ESZ ) begin<br>A = 10'h0                                                                                                                                                                                                                                                                                            | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo<br>;                                                                                                                                                                                                             | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;                             |   |  |
| parame<br>parame<br>// synoj                     | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( negeo                                                                                             | or Response({VB'<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or nev<br>ESZ ) begin<br>A = 10'h0<br>CSB = 1'b1<br>OEB = 1'b1                                                                                                                                                                                                                                                               | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo<br>;                                                                                                                                                                                                             | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;                             |   |  |
| parame<br>parame<br>// synoj                     | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR                                                                                 | or Response({VB'<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or nev<br>ESZ ) begin<br>A = 10'h0<br>CSB = 1'b1<br>OEB = 1'b1                                                                                                                                                                                                                                                               | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo<br>;<br>;                                                                                                                                                                                                        | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;                             |   |  |
| parame<br>parame<br>// synoj                     | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR                                                                                 | br Response({VB'         S_READY = 2'b00         D_READY = 3'b00         c_set_reset "VPR         dge VBCLK or neg         ESZ ) begin         A = 10'h0         CSB = 1'b1         OEB = 1'b1         begin         A = VBA         CSB = VDC                                                                                                                                                                       | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo<br>;<br>;<br>;                                                                                                                                                                                                   | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;                             |   |  |
| parame<br>parame<br>// synoj                     | eter [1:0] \$<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR<br>end else                                                                    | br Response({VB'<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or nev<br>ESZ ) begin<br>A = 10'h00CSB = 1'b1OEB = 1'b1beginA = VBA                                                                                                                                                                                                                                                          | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo<br>;<br>;<br>;<br>;<br>SZ ; _                                                                                                                                                                                    | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;                             |   |  |
| parame<br>parame<br>// synoj<br>always           | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR                                                                                 | br Response({VB'         S_READY = 2'b00         D_READY = 3'b00         c_set_reset "VPR         dge VBCLK or neg         ESZ ) begin         A = 10'h0         CSB = 1'b1         OEB = 1'b1         begin         A = VBA         CSB = VDC                                                                                                                                                                       | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo<br>;<br>;<br>;<br>;<br>SZ ; _                                                                                                                                                                                    | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;                             |   |  |
| parame<br>parame<br>// synoj                     | eter [1:0] \$<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR<br>end else                                                                    | br Response({VB'         S_READY = 2'b00         D_READY = 3'b00         c_set_reset "VPR         dge VBCLK or neg         ESZ ) begin         A = 10'h0         CSB = 1'b1         OEB = 1'b1         begin         A = VBA         CSB = VDC                                                                                                                                                                       | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo<br>;<br>;<br>;<br>;<br>SZ ; _                                                                                                                                                                                    | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;                             |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] §<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end                                                              | br Response({VB<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or nev<br>ESZ ) begin<br>A = 10'h00CSB = 1'b1OEB = 1'b1begin $A = VBACSB = VDCOEB = VBW$                                                                                                                                                                                                                                      | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>NESZ"<br>gedge VPRESZ ) bo<br>) ;<br>;<br>;<br>;<br>SZ ;<br>RITE ;                                                                                                                                                                          | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin                     |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] §<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end<br>@( neged                                                  | br Response({VB<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or nev<br>ESZ ) begin<br>A = 10'h00CSB = 1'b1OEB = 1'b1begin $A = VBACSB = VDCOEB = VBW$                                                                                                                                                                                                                                      | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo<br>;<br>;<br>;<br>;<br>SZ ; _                                                                                                                                                                                    | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin                     |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] §<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end<br>@( neged                                                  | or Response({VB'<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or net<br>ESZ ) begin<br>A = 10'h0<br>CSB = 1'b1<br>OEB = 1'b1<br>begin<br>A = VBA<br>CSB = VDC<br>OEB = VBW                                                                                                                                                                                                                 | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo<br>);<br>;<br>;<br>SZ;<br>RITE ;<br>gedge VPRESZ ) bo                                                                                                                                                            | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin                     |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] §<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end<br>@( neged                                                  | br Response({VB'<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or nev<br>ESZ ) begin<br>A = 10'h0<br>CSB = 1'b1<br>OEB = 1'b1<br>begin<br>A = VBA<br>CSB = VDC<br>OEB = VBW                                                                                                                                                                                                                 | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo<br>);<br>;<br>;<br>SZ;<br>RITE ;<br>gedge VPRESZ ) bo                                                                                                                                                            | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin                     |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end<br>@( neged<br>if( ~VPR                                      | br Response({VB3         S_READY = 2'b00         D_READY = 3'b00         c_set_reset "VPR         dge VBCLK or neg         ESZ ) begin         A = 10'h0         CSB = 1'b1         OEB = 1'b1         begin         A = VBA         CSB = VDC3         OEB = VBW         dge VBCLK or neg         ESZ ) begin         WEB = 4'b11         WEB = 4'b11         WRITE = 0;                                            | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo<br>);<br>;<br>;<br>SZ;<br>RITE ;<br>gedge VPRESZ ) bo                                                                                                                                                            | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin                     |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end<br>@( neged<br>if( ~VPR                                      | br Response({VB3         S_READY = 2'b00         D_READY = 3'b00         c_set_reset "VPR         dge VBCLK or neg         ESZ ) begin         A = 10'h0         CSB = 1'b1         OEB = 1'b1         begin         A = VBA         CSB = VDC3         OEB = VBW         dge VBCLK or neg         ESZ ) begin         WEB = 4'b11         WEB = 4'b11         WRITE = 0;                                            | 0, S_WAIT = 2'b10,<br>00,O_WAIT = 3'b10<br>RESZ"<br>gedge VPRESZ ) bo<br>);<br>;<br>SZ;<br>RITE;<br>gedge VPRESZ ) bo<br>111;<br>/BWRITE ) begin                                                                                                                                       | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin                     |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end<br>if( ~VPR<br>end else                                      | br Response({VB'<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or neg<br>ESZ ) begin<br>A = 10'b0CSB = 1'b1OEB = 1'b1OEB = 1'b1Begin $A = VBACSB = VDCOEB = VBWdge VBCLK or negESZ ) beginWEB = 4'b11WRITE = 0;fit(~VBSTZ & VWEB = 4'b11WRITE = 1;$                                                                                                                                         | <pre>D, S_WAIT = 2'b10,<br/>D0,O_WAIT = 3'b10<br/>D0,O_WAIT = 3'b10<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1</pre>                                                                                                                   | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin                     |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end<br>if( ~VPR<br>end else                                      | br Response({VB'<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or neg<br>ESZ ) begin<br>A = 10'b0CSB = 1'b1OEB = 1'b1OEB = 1'b1Begin $A = VBACSB = VDCOEB = VBWdge VBCLK or negESZ ) beginWEB = 4'b11WRITE = 0;fit (~VBSTZ & VWEB = 4'b11WRITE = 1;fit (WRITE ) begin$                                                                                                                      | <pre>D, S_WAIT = 2'b10,<br/>D0,O_WAIT = 3'b10<br/>RESZ"<br/>gedge VPRESZ ) bo<br/>);<br/>;<br/>;<br/>SZ;<br/>RITE ;<br/>gedge VPRESZ ) bo<br/>111 ;<br/>/BWRITE ) begin<br/>111 ;<br/>n</pre>                                                                                          | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin                     |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end<br>if( ~VPR<br>end else                                      | br Response({VB'<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or neg<br>ESZ ) begin<br>A = 10'b0CSB = 1'b1OEB = 1'b1OEB = 1'b1Begin $A = VBACSB = VDCOEB = VBWdge VBCLK or negESZ ) beginWEB = 4'b11WRITE = 0;fit(~VBSTZ & VWEB = 4'b11WRITE = 1;$                                                                                                                                         | <pre>D, S_WAIT = 2'b10,<br/>D0,O_WAIT = 3'b10<br/>RESZ"<br/>gedge VPRESZ ) bo<br/>);<br/>;<br/>;<br/>SZ;<br/>RITE ;<br/>gedge VPRESZ ) bo<br/>111 ;<br/>/BWRITE ) begin<br/>111 ;<br/>n</pre>                                                                                          | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin<br>// write cycle 1 |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end<br>if( ~VPR<br>end else                                      | br Response({VB'<br>S_READY = 2'b00<br>D_READY = 3'b00<br>C_SEt_reset "VPR<br>dge VBCLK or neg<br>ESZ ) begin<br>A = 10'h0<br>CSB = 1'b1<br>OEB = 1'b1<br>OEB = 1'b1<br>OEB = 1'b1<br>Segin<br>A = VBA<br>CSB = VDC<br>OEB = VBW<br>dge VBCLK or neg<br>ESZ ) begin<br>WEB = 4'b11<br>WRITE = 0;<br>sif(~VBSTZ & V<br>WEB = 4'b11<br>WRITE = 1;<br>sif(WRITE ) begin<br>if(~CSB ) WEE<br>else WEB                    | <pre>D, S_WAIT = 2'b10,<br/>D0,O_WAIT = 3'b10<br/>RESZ"<br/>gedge VPRESZ ) bo<br/>);<br/>;<br/>;<br/>SZ;<br/>RITE ;<br/>gedge VPRESZ ) bo<br/>111 ;<br/>/BWRITE ) begin<br/>111 ;<br/>n</pre>                                                                                          | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin<br>// write cycle 1 |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] \$<br>eter [2:0] C<br>osys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end<br>@( neged<br>if( ~VPR<br>end else<br>end else<br>end else | br Response({VB'<br>S_READY = 2'b00<br>D_READY = 3'b00<br>C_SEt_reset "VPR<br>dge VBCLK or neg<br>ESZ ) begin<br>A = 10'h0<br>CSB = 1'b1<br>OEB = 1'b1<br>OEB = 1'b1<br>Begin<br>A = VBA<br>CSB = VDC<br>OEB = VBW<br>dge VBCLK or neg<br>ESZ ) begin<br>WEB = 4'b11<br>WRITE = 0;<br>fit (~VBSTZ & W<br>WEB = 4'b11<br>WRITE = 1;<br>fit (WRITE ) begin<br>if (~CSB ) WEE<br>else WEB<br>WRITE = 0;                 | <pre>D, S_WAIT = 2'b10,<br/>D0,O_WAIT = 3'b10<br/>D0,O_WAIT = 3'b10<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1<br/>D1</pre>                                                                                                                   | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin<br>// write cycle 1 |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] S<br>eter [2:0] C<br>psys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end<br>if( ~VPR<br>end else                                      | br Response({VB'<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or neg<br>ESZ ) begin<br>A = 10'h0<br>CSB = 1'b1<br>OEB = 1'b1<br>OEB = 1'b1<br>OEB = 1'b1<br>OEB = VBA<br>CSB = VDC<br>OEB = VBW<br>dge VBCLK or neg<br>ESZ ) begin<br>WEB = 4'b11<br>WRITE = 0;<br>if (~VBSTZ & V<br>WEB = 4'b11<br>WRITE = 1;<br>if (WRITE ) begin<br>if (~CSB ) WEE<br>else WEB<br>WRITE = 0;<br>begin   | <pre>D, S_WAIT = 2'b10,<br/>D0,O_WAIT = 3'b10<br/>RESZ"<br/>gedge VPRESZ ) bd<br/>);<br/>;<br/>;<br/>;<br/>SZ;<br/>RITE ;<br/>gedge VPRESZ ) bd<br/>11 ;<br/>/BWRITE ) begin<br/>11 ;<br/>/BWRITE ) begin<br/>11 ;<br/>/BWRITE ) begin<br/>11 ;<br/>s = VBBENZ ;<br/>= 4'b1111 ;</pre> | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin<br>// write cycle 1 |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] \$<br>eter [2:0] C<br>osys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end<br>@( neged<br>if( ~VPR<br>end else<br>end else<br>end else | br Response({VB'<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or net<br>ESZ ) begin<br>A = 10'h0<br>CSB = 1'b1<br>OEB = 1'b1<br>OEB = 1'b1<br>OEB = VBA<br>CSB = VDC<br>OEB = VBW<br>dge VBCLK or net<br>ESZ ) begin<br>WEB = 4'b11<br>WRITE = 0;<br>if (~VBSTZ & V<br>WEB = 4'b11<br>WRITE = 1;<br>if (WRITE ) begin<br>if (~CSB ) WEE<br>else WEB<br>WRITE = 0;<br>begin<br>WEB = 4'b111 | <pre>D, S_WAIT = 2'b10,<br/>D0,O_WAIT = 3'b10<br/>RESZ"<br/>gedge VPRESZ ) bd<br/>);<br/>;<br/>;<br/>;<br/>SZ;<br/>RITE ;<br/>gedge VPRESZ ) bd<br/>11 ;<br/>/BWRITE ) begin<br/>11 ;<br/>/BWRITE ) begin<br/>11 ;<br/>/BWRITE ) begin<br/>11 ;<br/>s = VBBENZ ;<br/>= 4'b1111 ;</pre> | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin<br>// write cycle 1 |   |  |
| parame<br>parame<br>// synoj<br>always<br>always | eter [1:0] \$<br>eter [2:0] C<br>osys asyn<br>@( neged<br>if( ~VPR<br>end else<br>end<br>@( neged<br>if( ~VPR<br>end else<br>end else<br>end else | br Response({VB'<br>S_READY = 2'b00<br>D_READY = 3'b00<br>c_set_reset "VPR<br>dge VBCLK or neg<br>ESZ ) begin<br>A = 10'h0<br>CSB = 1'b1<br>OEB = 1'b1<br>OEB = 1'b1<br>OEB = 1'b1<br>OEB = VBA<br>CSB = VDC<br>OEB = VBW<br>dge VBCLK or neg<br>ESZ ) begin<br>WEB = 4'b11<br>WRITE = 0;<br>if (~VBSTZ & V<br>WEB = 4'b11<br>WRITE = 1;<br>if (WRITE ) begin<br>if (~CSB ) WEE<br>else WEB<br>WRITE = 0;<br>begin   | <pre>D, S_WAIT = 2'b10,<br/>D0,O_WAIT = 3'b10<br/>RESZ"<br/>gedge VPRESZ ) bd<br/>);<br/>;<br/>;<br/>;<br/>SZ;<br/>RITE ;<br/>gedge VPRESZ ) bd<br/>11 ;<br/>/BWRITE ) begin<br/>11 ;<br/>/BWRITE ) begin<br/>11 ;<br/>/BWRITE ) begin<br/>11 ;<br/>s = VBBENZ ;<br/>= 4'b1111 ;</pre> | S_AHOLD = 2'b11 ;<br>0,O_AHOLD = 3'b110 ;<br>egin<br>// write cycle 1 |   |  |

# Figure 4-13. Example of HDL Creation for Compiled Memory Access Controller (1/2)



### Figure 4-13. Example of HDL Creation for Compiled Memory Access Controller (2/2)

## CHAPTER 5 CONNECTION OF MEMORY CONTROLLER (MEMC)

★ The NB85E500 is a memory controller for the NB85E and NB85ET, and the NU85E500 is a memory controller for the NB85E.

The Nx85E500 is used as follows according to the type of external memory to be connected.

| Target CPU Core | Type of External Memory to Be<br>Connected | Memory Controller (MEMC)     |
|-----------------|--------------------------------------------|------------------------------|
| NB85E           | SRAM, ROM, page ROM, flash memory          | NB85E500/NU85E500            |
|                 | SDRAM                                      | NB85E500/NU85E500 + NU85E502 |
| NB85ET          | SRAM, ROM, page ROM, flash memory          | NB85E500                     |
|                 | SDRAM                                      | NB85E500 + NU85E502          |

Memory with a width of 8, 16, or 32 bits can be connected, but in the case of the latter two, writing must be performed in byte units. Write to SRAM and SDRAM in byte units using the WE and DQM signals, respectively.

For details, refer to the Memory Controller NB85E, NB85ET User's Manual (A14206E).



### \* Figure 5-1. Example of Connecting NB85E, MEMC, and External Memory (SRAM, SDRAM)

57

## 5.1 Connection to SRAM

 $\star$ 

Figure 5-2 shows an example of connection to SRAM. In this connection example, four 8-bit width SRAMs are connected, making 32-bit width access possible.



Figure 5-2. Example of Connection to SRAM

## 5.2 Connection to Page ROM

Figure 5-3 shows an example of connection to a 32-bit width page ROM.





## 5.3 Connection to SDRAM

When connecting an SDRAM to the MEMC (NU85E502), the SDRAM must satisfy the following conditions.

- Read latency: 2 or 3
- Data bus width: 8, 16, or 32 bits
- Row address width: 11 bits or 12 bits
- Address multiplex width (column address width): 8, 9, or 10 bits
- Refresh: CBR refresh and self-refresh

Figure 5-4 shows an example of connecting SDRAM and the MEMC. In this example, two 64 Mb (1 Mword  $\times$  16 bits  $\times$  4 banks) SDRAMs are connected, and access is in 32 bits.

Refresh is 4096 cycles/64 ms (corresponding to 64 Mb SDRAM).

★ The SDRAM in this connection example is 64 Mb (1 Mword × 16 bits × 4 banks), and the refresh cycle is 4096 cycles, resulting in the following address configuration.

- Row address input: A0 to A11 (12)
- Column address input: A0 to A7 (8)
- Bank select: A12, A13 (2)

Also, since the data bus width is 32 bits, addresses are connected to the NU85E502 with a 2-bit shift. Therefore, the NU85E502 and SDRAM addresses are connected as follows.

Row address and bank address during active command execution

| A25 | A24 | A23   | A22  | A21 | A20 | A19 | A18 | A17 | A16 | A15 | A14 | A13 | A12 | A11 | A10 | A9  | A8   | A7    | A6  | A5  | A4  | A3  | A2  | A1 | A0 |
|-----|-----|-------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|------|-------|-----|-----|-----|-----|-----|----|----|
| a25 | a24 | a23   | a22  | a21 | a20 | a19 | a18 | a25 | a24 | a23 | a22 | a21 | a20 | a19 | a18 | a17 | a16  | a15   | a14 | a13 | a12 | a11 | a10 | a9 | a8 |
|     |     | -     | -    |     |     |     |     |     |     |     |     | -   |     |     |     |     |      |       |     |     |     |     |     |    |    |
|     | Bar | nk ad | dres | ses |     |     |     |     |     |     |     |     |     |     |     | Ro  | w ad | dress | ses |     |     |     |     |    |    |

Column address output during read/write command execution

| A25 | A24 | A23 | A22 | A21 | A20 | A19 | A18 | A17 | A16 | A15 | A14 | A13 | A12 | A11 | A10 | A9 | A8 | A7   | A6   | A5    | A4   | A3 | A2 | A1 | A0 |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|----|----|------|------|-------|------|----|----|----|----|
| a25 | a24 | a23 | a22 | a21 | a20 | a19 | a18 | a17 | a16 | a15 | a14 | a13 | 0   | a11 | a10 | a9 | a8 | a7   | a6   | a5    | a4   | a3 | a2 | a1 | a0 |
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     | •  |    |      |      |       |      |    |    |    |    |
|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |    |    | Colu | mn a | lddre | sses |    |    |    |    |

Connection of NU85E502 and SDRAM

A23, A22 (NU85E502)  $\rightarrow$  BA0 (A13), BA1 (A12) (SDRAM) A13 to A2 (NU85E502)  $\rightarrow$  A11 to A0 (SDRAM)



Figure 5-4. Example of Connection to SDRAM

## **CHAPTER 6 CONNECTION TO NPB**

### 6.1 Overview of NPB

- ★ The NPB (NEC peripheral bus) of the NB85E is a 16-bit width asynchronous bus that operates at a bus speed of 10 MHz or less. User logic operating at a frequency of 10 MHz or less can be connected.
  - **Remark** A macro connected to the VSB such as the MEMC, instruction cache, or data cache must also be connected to the NPB.



### Figure 6-1. NPB Operation Timing Chart

## 6.2 Connection of User Logic

This section shows an example of connecting user logic to the NPB.

An example of user logic in which two 8-bit registers and one 16-bit register are lined up has been created. The user logic macro name is UDL1 and the names of the registers are UDL11, UDL12, and UDL13.

### (1) Register mapping

The memory address at which the user logic is placed is in a programmable peripheral I/O area or peripheral I/O area within the following ranges (for details, refer to the **NB85E Hardware User's Manual (A13971E)**).

- xFFF200H to xFFF47FH
- xFFF520H to xFFF7BFH
- xFFF800H to xFFFFFH

An example in which the user logic registers are placed at addresses starting at address FFFF880H is shown below.

| Address  | Macro Name | Register Name | Bit Width |
|----------|------------|---------------|-----------|
| FFFF880  | UDL1       | UDL11         | 8 bits    |
| FFFF881  | UDL1       | UDL12         | 8 bits    |
| FFFFF882 | UDL1       | UDL13         | 16 bits   |

#### Table 6-1. Example of User Logic Address Assignment

### (2) Creation of address decoder

A connection example of user logic, an example of HDL creation for the address decoder and user logic, and a timing chart are shown below.

This example is designed so that UDL11, UDL12, and UDL13 are processed together in one module. Since four addresses are assigned, the address bus handles them using the two signals VPA0 and VPA1.

## Caution If user logic is connected to the NPB, design it so that the data bus is high impedance when in test mode (active level input to BUNRI pin) (see 10.2.1 Processing NB85E and NB85ET pins and the NB85E Hardware User's Manual (A13971E)).



Figure 6-2. Example of Connecting User Logic



```
module ADRSDEC_UDL (VPA, VPDACT, VPRESZ, UDL1_VPCS, BUNRI
);
           UDL1_ADR
                         = 12'b11_1000_1000_00 ; // 3880H
parameter
input [13:0] VPA ;
input
           VPRESZ, BUNRI ;
output
           VPDACT ;
output
           UDL1_VPCS ;
wire [13:0] VPA;
    assign VPDACT
                         = ~( UDL1_VPCS ) ;
    assign UDL1_VPCS = (UDL1_ADR == VPA[13:2]) & ~BUNRI;
endmodule
```

 $\star$ 

```
\star
```

Figure 6-4. Example of User Logic HDL Creation

```
module NPB_UDL1(
               VPA, VPDR, VPDW, VPCS, VPWRITE, VPSTB, VPUBENZ,
               VPRESZ, BUNRI
               );
       [1:0]
               VPA;
input
input
       [15:0]
               VPDW;
input
               VPCS, VPWRITE, VPSTB, VPUBENZ, VPRESZ, BUNRI ;
output [15:0] VPDR ;
       [15:0] dout ;
reg
//-- VPDR driver --
wire
       vpdrl_en, vpdrh_en;
       assign vpdrl_en = VPCS & ~VPWRITE & VPSTB & ~VPA[0] & ~BUNRI ;
       assign vpdrh_en = VPCS & ~VPWRITE & VPSTB & ~VPUBENZ & ~BUNRI ;
       assign VPDR[7:0] = (vpdrl_en)? dout[7:0]: 8'bzzzz_zzzz;
       assign VPDR[15:8] = ( vpdrh_en ) ? dout[15:8] : 8'bzzzz_zzzz ;
//-- User Logic Registor --
       [7:0] udl11, udl12;
reg
reg
       [15:0] udl13;
       // synopsys async_set_reset "VPRESZ"
        always @( VPSTB or VPRESZ ) begin
               if ( ~VPRESZ ) begin
                     dout <= 16'h0000 ;
                     udl11 <= 8'h00 ;
                     udl12 <= 8'h00;
                     udl13 <= 16'h0000 ;
               end
               else begin
                     if (VPSTB & VPCS) begin
                             if (~VPA[1]) begin
                                      if (~VPWRITE) begin
                                                             // read action
                                             dout <= { udl12, udl11 } ;
                                      end
                                      else begin
                                                              // write action
                                             if ( VPA[0] & ~VPUBENZ ) udl12 <= VPDW[15:8] ;
                                             else if ( ~VPA[0] & VPUBENZ ) udl11 <= VPDW[7:0] ;
                                             else if ( ~VPA[0] & ~VPUBENZ ) begin
                                                      udl12 <= VPDW[15:8];
                                                      udl11 <= VPDW[7:0];
                                              end
                                      end
                             end
                             else begin
                                      if (~VPWRITE) dout <= udl13;
                                                    udl13 <= VPDW ;
                                      else
                             end
                     end
               end
       end
endmodule
```



### Figure 6-5. User Logic Operation Timing Chart

### (3) Application example (example of creating user logic with retry function)

To use the user logic shown in the above design example as an intermediate buffer between a very lowspeed macro and the NPB, a retry function can be attached to the user logic.

Figure 6-6 shows an example of creating HDL for user logic with a retry function and Figure 6-7 shows an operation timing chart.

This example is designed so that a wait of one VPRETR signal is inserted when reading UDL13.

| module           | NPB_U           | VPA, VPDR, VPDW, VPCS, VPWRITE, VPSTB, VPUBENZ,                                                                     |
|------------------|-----------------|---------------------------------------------------------------------------------------------------------------------|
|                  |                 | VPRESZ, VPRETR, BUNRI<br>);                                                                                         |
| input            | [1:0]           | VPA ;                                                                                                               |
| input<br>input   |                 | VPDW ;<br>VPCS, VPWRITE, VPSTB, VPUBENZ, VPRESZ, BUNRI ;                                                            |
| output<br>output | [15:0]          | VPDR ;<br>VPRETR ;                                                                                                  |
| reg<br>reg       | [15:0]          | dout ;<br>VPRETR ;                                                                                                  |
| // VPD           | OR driver       | -                                                                                                                   |
| wire             | vpdrl_e         | n, vpdrh_en ;                                                                                                       |
|                  | •               | vpdrl_en = VPCS & ~VPWRITE & VPSTB & ~VPA[0] & ~BUNRI ;<br>vpdrh_en = VPCS & ~VPWRITE & VPSTB & ~VPUBENZ & ~BUNRI ; |
|                  | •               | VPDR[7:0] = ( vpdrl_en ) ? dout[7:0] : 8'bzzzz_zzzz ;<br>VPDR[15:8] = ( vpdrh_en ) ? dout[15:8] : 8'bzzzz_zzzz ;    |
| // Use           | r Logic R       | egistor                                                                                                             |
| reg<br>reg       | [7:0]<br>[15:0] | udl11, udl12 ;<br>udl13 ;                                                                                           |
| reg              |                 | retract;                                                                                                            |
|                  | // synop        | sys async_set_reset "VPRESZ"                                                                                        |
|                  | always          | @(VPSTB or VPRESZ) begin                                                                                            |
|                  |                 | if ( ~VPRESZ ) begin<br>dout <= 16'h0000 ;                                                                          |
|                  |                 | udl11 <= 8'h00 ;                                                                                                    |
|                  |                 | udi12 <= 8'h00 ;<br>udi13 <= 16'h000 ;                                                                              |
|                  |                 | VPRETR <= 1'b0;                                                                                                     |
|                  |                 | end                                                                                                                 |
|                  |                 | else begin<br>if ( VPSTB & VPCS ) begin                                                                             |
|                  |                 | if (~VPA[1]) begin                                                                                                  |
|                  |                 | if ( ~VPWRITE ) begin // read action                                                                                |
|                  |                 | dout <= { udl12, udl11 } ;                                                                                          |
|                  |                 | end<br>else begin // write action                                                                                   |
|                  |                 | if ( VPA[0] & ~VPUBENZ ) udl12 <= VPDW[15:8] ;                                                                      |
|                  |                 | else if ( ~VPA[0] & VPUBENZ ) udl11 <= VPDW[7:0] ;                                                                  |
|                  |                 | else if ( ~VPA[0] & ~VPUBENZ ) begin                                                                                |
|                  |                 | udl12 <= VPDW[15:8] ;<br>udl11 <= VPDW[7:0] ;                                                                       |
|                  |                 | end                                                                                                                 |
|                  |                 | end                                                                                                                 |
|                  |                 | end                                                                                                                 |

★

# Figure 6-6. Example of HDL Creation for User Logic with Retry Function (1/2)

67

Figure 6-6. Example of HDL Creation for User Logic with Retry Function (2/2)









## **CHAPTER 7 CACHE CONNECTION**

### 7.1 Connection of Instruction Cache

The following products are instruction caches that can be connected to the NB85E.

- NB85E212 ... 4 KB 2-way set associative instruction cache (4 words × 128 entries × 2 ways = 4 KB)
- NB85E213 ... 8 KB 2-way set associative instruction cache (4 words × 256 entries × 2 ways = 8 KB)

 $\star$ 



Figure 7-1. Example of Connecting Instruction Cache (NB85E213) to NB85E

### 7.1.1 Cautions when using instruction cache

### (1) Connection to NB85E

Connect pins that have the same pin name. However, leave the IBBTFT pin of the instruction cache open and fix the IBBTFT pin of the NB85E to low level.

### (2) Cache type selection pin setup

Input the following levels to cache type selection pins whose pin names begin with "IF".

| Pin Name | Input      | Level     |
|----------|------------|-----------|
|          | NB85E212   | NB85E213  |
| IFE128   | High level | Low level |
| IFDRCT   | Low level  | Low level |

### (3) Bus cycle status

In an area for which the instruction cache setting is set to cacheable by the cache configuration register (BHC) of the NB85E, the VBCTYP2 to VBCTYP0 signals of the NB85E always indicate a normal operation code fetch and do not indicate an operation code fetch of the target address in a branch instruction.

### (4) Operation on reset

On a reset, a tag is automatically cleared (invalidated) and the next data replacement is performed from way 0. Therefore, if there is an access to the instruction cache in a period of as many clock cycles as the number of lines after reset, the CPU stops until the tag is cleared (becomes invalid).

### (5) Register settings

Be sure to set the NB85E registers shown below in non-cacheable areas. However, set bit 4 of the instruction cache control register (ICC) in a cacheable area.

- Chip area select control registers (CSC0, CSC1)
- Peripheral I/O area select control register (BPC)
- Bus size configuration register (BSC)
- Endian configuration register (BEC)
- Cache configuration register (BHC)
- Instruction cache control register (ICC)<sup>Note</sup>
- Instruction cache data configuration register (ICD)

Note Excluding bit 4

### (6) Access to memory boundaries

If adjoining chip select (CSn) areas are a cacheable area and a non-cacheable area, the memory boundary between them can be continuously accessed only by a branch instruction (n = 7 to 0). Operation is not guaranteed if this memory boundary is continuously accessed by other than a branch instruction. An example is shown below.

Example Set cache areas as shown in Figure 7-2. In this case, access to memory areas is as follows.

- From CS0 area to CS1 area is only accessible using a branch instruction.
- From CS1 area to CS2 area is continuously accessible.

Figure 7-2. Cache Area Setting Example



#### (7) Initial program settings

\*

Always execute the following instruction before setting the BHC register of the NB85E with the initial settings of the user program immediately following system reset.

st.h r0, 0xfffff072[r0]

Following execution of this instruction, the cache is enabled by setting "cacheable" (BHn0 bit = 1) as the instruction cache setting with the BHC register (n = 7 to 0).

#### (8) Setting BHC register of NB85E

In the case of CSn areas for which an instruction to set the BHC register exists, cacheable/uncacheable settings for the instruction cache using this instruction cannot be performed (n = 7 to 0). Instruction cache cacheable/uncacheable settings are possible only for CSn areas for which no instruction for setting the BHC register exists.

For example, if a BHC register setting instruction exists in the CS0 area, the instruction cache of the CS0 area cannot be set (cacheable/uncacheable settings). In this case, only the instruction cache settings for areas CS1 to CS7 are possible.

However, instruction cache settings for all CSn areas from instructions that exist in memory areas connected to VFB or VDB are possible.

Remark VFB: Dedicated bus used to directly connect ROM (V850E fetch bus)

VDB: Dedicated bus used to directly connect RAM (V850E data bus)

### (9) Test bus auto wiring tool support

This instruction cache does not support test bus auto wiring tools because although it has a BUNRI pin, it does not have test buses (TBOx, TBIx).

#### ★ (10)Tag clear procedure

Way 0 shares the counter to clear tags with way 1.

Thus, clear tags (set (1) the TCLR0 bit or TCLR1 bit of the ICC register) when the counter for tag clearing is stopped (TCLR0 = TCLR1 = 0). When clearing the tags of way 0 and way 1 individually, if tag clearing for either way is executed during tag clear execution for the other way (TCLR0 or TCLR1 = 1), the counter stops in the middle of tag clearing. Consequently, normal tag clearing cannot be performed because the counter switches to perform the other tag clear operation still indicating the value it had when stopped halfway. Be sure to confirm that tag clearing for one way is completed (TCLR0 or TCLR1 = 0) before performing tag clearing tag clearing for the other way.

# 7.2 Connection of Data Cache

 $\star$ 

The following products are data caches that can be connected to the NB85E.

- NB85E252 ... 4 KB direct map data cache (4 words × 256 entries = 4 KB)
- NB85E263 ... 8 KB 2-way set associative data cache (4 words × 256 entries × 2 ways = 8 KB)



| NB85E              |             | Data cache<br>(NB85E263) |
|--------------------|-------------|--------------------------|
|                    | A           | , , ,                    |
| IRAMZ31 to IRAMZ0  | [·          | IRAMZ31 to IRAMZ0        |
| IDUNCH             |             | IDUNCH                   |
| IRAMA27 to IRAMA2  |             | IRAMA27 to IRAMA2        |
| IRAOZ31 to IRAOZ0  |             | IRAOZ31 to IRAOZ0        |
| IRAMWR3 to IRAMWR0 |             | IRAMWR3 to IRAMWR0       |
| IRAMRWB            | ►           | IRAMRWB                  |
| IRAMWT             | 4           | IRAMWT                   |
| IDAACK             | ►           | IDAACK                   |
| IDDARQ             | ▶           | IDDARQ                   |
| IDDRRQ             | 4           | IDDRRQ                   |
| IDDRDY             | ▶           | IDDRDY                   |
| IDDWRQ             | 4           | IDDWRQ                   |
| IDEA27 to IDEA0    | <           | IDEA27 to IDEA0          |
| IDED31 to IDED0    | k>          | IDED31 to IDED0          |
| IDES               | ▶           | IDES                     |
| IRRSA              | ►           | IRRSA                    |
| IDHUM              | 4           | IDHUM                    |
| IDRETR             | <b></b>     | IDRETR                   |
| IDRRDY             | •           | IDRRDY                   |
| IDSEQ2             | •           | IDSEQ2                   |
| IDSEQ4             | •           | IDSEQ4                   |
| IFIUNCH1           |             | IFIUNCH1                 |
| IFIWRTH            |             | IFIWRTH                  |
| IFIRABE            |             | IFIRABE                  |
|                    |             | IFIOECT                  |
|                    | Arbitrary — | IFIASEQ                  |
|                    |             | IFIDRCT                  |
|                    |             |                          |
|                    | Open -      |                          |
| VPA13 to VPA0      |             | VPA13 to VPA0            |
| VPD15 to VPD0      |             | VPD15 to VPD0            |
| VPRESZ             | ▶           | VPRESZ                   |
| VPSTB              | ▶           | VPSTB                    |
| VPTCLK             | ▶           | VPTCLK                   |
| © → BUNRI VPUBENZ  | ▶           | VPUBENZ                  |
|                    | <b></b>     | VPWRITE                  |
|                    | ►           | VBCLK                    |
|                    |             | BUNRI                    |

#### 7.2.1 Cautions when using data cache

#### (1) Connection to NB85E

Connect pins that have the same pin names.

#### (2) Cache type selection pin setup

Input the levels shown below to the cache type selection pins that have pin names beginning with "IFI". Connect the IFIUNCH1 and IFIWRTH pins to the NB85E.

| Pin Name                  | Input Level                 |                             |
|---------------------------|-----------------------------|-----------------------------|
|                           | NB85E252                    | NB85E263                    |
| IFIASEQ                   | Arbitrary <sup>Note 1</sup> | Arbitrary <sup>Note 1</sup> |
| IFIRABE                   | Low level                   | Low level                   |
| IFIDRCT <sup>Note 2</sup> | -                           | Low level                   |
| IFIOECT                   | Low level                   | Low level                   |

Notes 1. Set IFIASEQ depending on the system. For details, refer to the Instruction Cache, Data Cache NB85E, NB85ET User's Manual (A14247E).

2. NB85E263 only

#### (3) Bus cycle status

In all read cycles of an area for which the data cache setting is set to cacheable by the cache configuration register (BHC) of the NB85E and in write cycles when in write back mode (write allocate enabled), the VBCTYP2 to VBCTYP0 signals of the NB85E always indicate a data access and do not indicate a misalign access.

#### (4) Operation on reset

On a reset, a tag is automatically cleared (invalidated) and the next data replacement is performed from way 0. Therefore, if there is an access to the data cache in a period of as many clock cycles as the number of lines after reset, the CPU stops until the tag is cleared (becomes invalid).

#### ★ (5) Test bus auto wiring tool support

This data cache does not support test bus auto wiring tools because although it has a BUNRI pin, it does not have test buses (TBOx, TBIx).

#### ★ (6) Other

This data cache does not have a bus snoop circuit (which monitors the bus operation). Note that data in the data cache in the cases shown in the following examples is dirty data even when there is no write access to the data cache, and is data that has lost its coherency. To avoid this status, be sure to clear tags.

**Examples 1.** When DMA transfer is performed to the external memory of a cacheable area from RAM (Transfer data is not reflected in the data cache)

2. When the external memory contents of a cacheable area are overwritten by the external bus master

## (7) Operation during debugging

The data cache does not operate during debugging using an N-wire type in-circuit emulator.

Since access is performed directly only to external memory even if the data cache is enabled, when accessing external memory in a cacheable area during debugging, coherency is degraded. To prevent this, be sure to perform data cache tag clearing. Also, when using an in-circuit emulator (IE-V850E-MC-A), data cache debugging cannot be performed.

# CHAPTER 8 CONNECTION TO IN-CIRCUIT EMULATOR (IE)

#### 8.1 Using In-Circuit Emulator for NB85E (IE-V850E-MC-A)

When using an in-circuit emulator for an NB85E (IE-V850E-MC-A), three 100-pin connectors<sup>Note</sup> must be mounted on a breadboard in order to connect the in-circuit emulator for NB85E (IE-V850E-MC-A) to the option board (IE-V850E-MC-EM1-B) (for connector placement and dimensions and a signal list, refer to the **IE-V850E-MC-EM1-B**, **IE-V850E-MC-MM2 User's Manual (U14482E)**).

Note Recommended connector: XH3A-0141-A (by Omron Corporation)





Cautions 1. Since instruction and data cache pins, test mode pins, VFB and VDB pins, RCU pins, and peripheral evaluation chip mode pins are not needed in debugging using the IE-V850E-MC-A, these pins are not on the option board.

There also is no pin for setting the operating mode on the option board, but the initial value of the operating mode can be set using the CPU control register of the IE-V850E-MC-A.

2. When performing debugging, be sure to read the restrictions attached to the in-circuit emulator main unit (IE-V850E-MC-A) and to the option board (IE-V850E-MC-EM1-B).

# 8.2 Using N-Wire Type In-Circuit Emulator (IE-70000-MC-NW-A)

When using an N-Wire type in-circuit emulator (IE-70000-MC-NW-A), a connector for IE connection and a circuit for connection must be implemented in the target system.





# 8.2.1 Connector for in-circuit emulator connection (in target system)

Figure 8-3 shows a pin placement diagram of a connector for in-circuit emulator connection (in target system) and Table 8-1 shows the pin functions.

Remark The recommended connectors are as follows.

- 8830E-026-170S (by KEL Corporation): 26-pin straight type
- 8830E-026-170L (by KEL Corporation): 26-pin right-angle type





| Pin Number | Pin Name   | I/O    | Pin Function                                           |
|------------|------------|--------|--------------------------------------------------------|
| A1         | TRCCLK     | Input  | Trace clock input                                      |
| A2         | TRCDATA0   | Input  | Trace data 0 input                                     |
| A3         | TRCDATA1   | Input  | Trace data 1 input                                     |
| A4         | TRCDATA2   | Input  | Trace data 2 input                                     |
| A5         | TRCDATA3   | Input  | Trace data 3 input                                     |
| A6         | TRCEND     | Input  | Trace data end input                                   |
| A7         | DDI        | Output | Debug serial interface data output                     |
| A8         | DCK        | Output | Debug serial interface clock output                    |
| A9         | DMS        | Output | Debug serial interface transfer mode selection output  |
| A10        | DDO        | Input  | Debug serial interface data input                      |
| A11        | DRSTZ      | Output | DCU reset output                                       |
| A12        | (Reserved) | -      | (Leave open)                                           |
| A13        | (Reserved) | -      | (Leave open)                                           |
| B1         | GND        | -      | _                                                      |
| B2         | GND        | -      | _                                                      |
| B3         | GND        | -      | -                                                      |
| B4         | GND        | -      | -                                                      |
| B5         | GND        | -      | _                                                      |
| B6         | GND        | -      | _                                                      |
| B7         | GND        | -      | _                                                      |
| B8         | GND        | _      | _                                                      |
| В9         | GND        | -      | _                                                      |
| B10        | GND        | -      | _                                                      |
| B11        | (Reserved) | _      | (Leave open)                                           |
| B12        | (Reserved) | _      | (Leave open)                                           |
| B13        | VDD        | -      | +3.3 V input (for monitoring target power application) |

# Table 8-1. Pin Functions of Connector for In-Circuit Emulator Connection (in Target System)

#### 8.2.2 Circuit example when RCU (NB85E901) is connected to NB85E

Figure 8-4 shows a circuit example for the connector for in-circuit emulator connection (in the target system).





#### 8.2.3 Circuit example when NB85ET is connected

Figure 8-5 shows a circuit example for the connector for in-circuit emulator connection (in the target system).





- 5. When using an NEC in-circuit emulator (IE-70000-MC-NW-A), use a 3.3 V buffer. (To use a third-party in-circuit emulator, consult the tool vendor.)
- 6. Recommended buffer: A Schmitt type input buffer is recommended for the DRSTZ.
- **7.** The resistors used for pulling up/down outside the ASIC can be provided inside the ASIC without problem.
- **Remarks 1.** The V<sub>DD</sub> (pin B13) of the connector for in-circuit emulator connection (in the target system) is used only for detecting whether power is applied to the target system.
  - **2.** The DBINT pin is optional. When there is no need to input debug interrupts from outside, input a low level.
  - **3.** The EVTTRG pin is optional. It is mainly used as the trigger output for measurement devices such as a logic analyzer. When trigger output is not needed, leave it open.

#### 8.2.4 Design of timing with N-wire type in-circuit emulator

Design the timing between the NB85ET (or NB85E901) and N-wire type in-circuit emulator so as to satisfy the NB85ET (or NB85E901) and N-wire type in-circuit emulator timing specs, taking into consideration the following two delays.

- Wiring delay + delay caused by output buffer (From NB85ET (or NB85E901) macro to ASIC pins (refer to **<A>** in **Figure 8-6**))
- Delay caused by external load
   (From ASIC pins to N-wire type in-circuit emulator (refer to <B> in Figure 8-6))
- Remark For the NB85ET (or NB85E901) timing specs, refer to the CB-9 Family VX/VM Type CPU Core, Memory Controller Design Manual (A13195E). For the N-wire type in-circuit emulator specs, consult NEC if using the IE-70000-MC-NW-A, or the third party tool vendor if using an N-wire type incircuit emulator made by a company other than NEC.

Figure 8-6 shows the delays between the NB85ET and N-wire type in-circuit emulator.





# **CHAPTER 9 CAUTIONS**

# 9.1 Bus Contention When Moving from Read Cycle to Write Cycle (Using MEMC (NB85E500))

In cases in which a write cycle occurs after a read cycle (such as when writing data read from external ROM to external RAM), the bus timing is normally as follows.



In this case, if the external ROM data output hold time is one half clock of VBCLK or longer, the input data from the external ROM and the output data to the external RAM may conflict (<A> in the figure above). The following two countermeasures are available for avoiding this.

- (1) Insert an idle cycle according to the setting of the bus cycle control register (BCC). Set it so that an idle cycle is inserted behind the read cycle. However, the performance of ROM access (read cycle) declines.
- (2) Raise a read strobe signal (RDZ) one half clock early. However, since the NB85E data read is at the rise of the last clock of the read cycle, it is necessary to add a data latch inside the chip to prevent data deletion.



#### 9.2 Cautions on Verilog Simulation

To set data in general-purpose register "reg1" using the instruction "MOV imm32, reg1" in the Verilog simulation model of the NB85E, the write destination reg1 (all bits) must be initialized to "0" in advance. Note that if reg1 contains an undefined value ("x" or "z"), the result of executing the instruction is not correctly reflected in reg1 (restriction).

This occurs only in Verilog simulation and is not a problem in the actual chip. In addition, other MOV instructions ("MOV reg1, reg2", "MOV imm5, reg2") do not have such a restriction.

The measure taken to avoid this is to initialize all general-purpose registers at the beginning of the initialization routine. Initialize all registers using the program shown below before using registers.

| mov r0, r1  |  |
|-------------|--|
| mov r0, r2  |  |
| mov r0, r3  |  |
| mov r0, r4  |  |
| mov r0, r5  |  |
| mov r0, r6  |  |
| mov r0, r7  |  |
| mov r0, r8  |  |
| mov r0, r9  |  |
| mov r0, r10 |  |
| mov r0, r11 |  |
| mov r0, r12 |  |
| mov r0, r13 |  |
| mov r0, r14 |  |
| mov r0, r15 |  |
| mov r0, r16 |  |
| mov r0, r17 |  |
| mov r0, r18 |  |
| mov r0, r19 |  |
| mov r0, r20 |  |
| mov r0, r21 |  |
| mov r0, r22 |  |
| mov r0, r23 |  |
| mov r0, r24 |  |
| mov r0, r25 |  |
| mov r0, r26 |  |
| mov r0, r27 |  |
| mov r0, r28 |  |
| mov r0, r29 |  |
| mov r0, r30 |  |
| mov r0, r31 |  |
|             |  |
|             |  |

# 9.3 Cautions on BUNRI-Testing Chip

When BUNRI-testing a chip, ensure that user logic (macro that does not have a test function) is not selected.

However, for a macro in which a test function is implemented, it is necessary to ensure that it is selected even at the time of BUNRI testing. For details, see **CHAPTER 10 TEST CIRCUIT DESIGN**.





# 9.4 Timing Adjustment

When designing a circuit that performs high-speed operations, skew adjustment and hold time adjustment is required.

If there is a problem with skew or hold time, the following symptoms occur in simulation.

In particular, clock skew and data line hold timing require caution.

- After reset release, all is normal until an instruction fetch and all is undefined after several instructions are read from ROM.
- Data read from outside takes invalid values.
- Simulation cannot be performed at all (all output pins are undefined).
- A "Timing Violation" occurs (particularly a "\$hold" error).

#### 9.4.1 Adjustment of clock skew or data line hold violation

To guarantee the clock skew or data line hold time, use the following two methods together.

- Insertion of buffer in data bus (see <A> in Figure 9-2)
- Insertion of buffer in clock line (see <B> in Figure 9-2)
- **Remarks 1.** To insert a buffer for clock skew adjustment in a circuit using HDL, specify it in the structure description.
  - 2. For cautions on logic synthesis, refer to NEC SYSTEM LSI DESIGN OPENCAD V5.4 Design Compiler Interface User's Manual (A15058E).





#### 9.4.2 Resolution of hold violation using design compiler

The methods of adjusting a hold violation using the design compiler are to directly insert it in a circuit in the structure description in HDL or to describe it in a logic synthesis script. An example of a case handled using a logic synthesis script is shown below.

The module block in which portions that tie compiled memory to the CPU are cut from the circuit in Figure 9-2 is as follows (module name: GLOGIC).



For example, the script is as follows when the CPU clock frequency is 33 MHz (period 30 ns) and an IROMZ hold time of 4 ns or more is needed for VBCLK (input\_delay must also be specifically defined). In this example, a 5 ns to 7 ns delay is inserted in IROMZ.

```
/* Set the current_design */
current_design GLOGIC
create_clock -period 30 -waveform {0 15} find (port, "VBCLK")
set_fix_hold find (clock, "VBCLK")
set_output_delay 23 -max -clock "VBCLK" find (port, "IROMZ*")
set_output_delay -5 -min -clock "VBCLK" find (port, "IROMZ*")
```

#### 9.4.3 Clock skew adjustment

If the clock input to the BE pin is standardized to the clock signal input to the CPU (VBCLK), there is clock skew. This section describes how to calculate the clock skew adjustment taking the case of connecting compiled ROM to the VFB as an example.

#### (1) How to calculate clock skew (skew of BE signal against VBCLK signal)

From the relationship of the compiled ROM cycle time (tRc), access time (tAcc), and output hold time (tOH) to the CPU clock frequency (fVBCLK), data input setup time (tSIDK), and hold time (tHKID), the degree to which skew of the BE signal against the VBCLK signal is permitted can be found using the following calculation.

The meaning of each symbol is as follows.

- tsk<sup>-</sup>: Value when BE skew against VBCLK is proceeding
- tsk<sup>+</sup>: Value when BE skew against VBCLK is lagging
- ton: ROM output hold time
- tRC: ROM cycle time
- tacc: ROM access time
- tsidk: CPU data input setup time
- thkid: CPU data input hold time
- fvbclk: CPU clock frequency (Hz)

# (a) Data hold condition ( $\Delta t_{sk}$ < ton – thkid: however, trc < 1/fvBcLk)



(b) Data setup condition ( $\Delta t_{sk}^+ < (1/f_{VBCLK} - t_{ACC}) - t_{SIDK}$ : however,  $t_{RC} < 1/f_{VBCLK}$ )



(2) Calculation example of permissible value of clock skew (skew of BE signal against VBCLK signal) For example, for a CB-9 Family VX Type (VDD = 3.3 V) 32-bit × 4 Kword fast synchronous ROM, if toH = 0.7 ns, tACC = 7.8 ns, tRC = 12.5 ns, VBCLK frequency (fVBCLK) = 20 MHz (period: 50 ns), tSIDK = 0 ns, tHKID = 4 ns and the wiring delay is made small enough to ignore, the calculation is as follows.

$$\begin{split} &\Delta t_{sk}^- < to H - t_{HKID} = 0.7 - 4 = -3.3 \text{ (ns)} \\ &\Delta t_{sk}^+ < (1/f_{VBCLK} - t_{ACC}) - t_{SIDK} = (50 - 7.8) - 0 = 42.2 \text{ (ns)} \\ &(\text{However, } t_{RC} < 50 \text{ (ns)}) \end{split}$$



From this result, it is known that the BE signal must be slowed at least 4 ns (against VBCLK). The following measures can be taken if the skew timing is not suitable.

- Extend the output hold time by inserting a buffer for delay adjustment in memory data output (<A> in Figure 9-2).
- Insert a buffer for delay adjustment to slow BE signal input to memory against timing of VBCLK input to NB85E (<B> in Figure 9-2).

# 9.5 Device File

A device file is needed when using a C compiler/assembler (CA850), integrated debugger (ID850), or system simulator (SM850).

This device file is provided by NEC, but its contents differ depending on the development environment and type. Therefore, consult with NEC in advance concerning the following items.

#### (1) Development environment

Manufacturer and name of development tools (compiler, debugger, and in-circuit emulator) to be used.

#### **\*** (2) Product specifications

- (a) CPU core (NB85E, NB85E + NB85E901, or NB85ET)
- (b) Memory controllers (NB85E500, NU85E500, or NU85E502)
- (c) Size of RAM to connect to VDB
- (d) Size of ROM to connect to VFB
- (e) Settings of IFIROME, IFIROB2, IFIRA64, IFIRA32, IFIRA16, IFIMAEN, IFID256, IFINSZ1, IFINSZ0, IFIWRTH, IFIUNCH1, and IFIUNCH0 pins
- (f) Address assigned to each register name of user logic

# **CHAPTER 10 TEST CIRCUIT DESIGN**

Since the NB85E has an on-chip test interface control unit (TIC), tests of the NB85E itself and peripheral macros (such as instruction cache, data cache, and memory controller (MEMC)) are performed via the test bus (TBI39 to TBI0, TBO34 to TBO0).

The test bus is activated when the TEST signal or BUNRI signal is active.

Tests for compiled memory connected to the VFB and VDB are performed using the test bus of that memory.

# 10.1 Peripheral Macro Connection Example in Test Mode

Figure 10-1 shows an example of connecting a peripheral macro to the NB85E.





\*

#### 10.2 Processing Pins in Test Mode

#### 10.2.1 Processing NB85E and NB85ET pins

#### (1) Other than test mode pins

#### (a) I/O pins

When testing a peripheral macro via test interface pins, if the peripheral macro and user logic are both connected to the VSB, a signal conflict may occur when in test mode. In order to prevent signal conflict, it is necessary to enable only the peripheral macro signal. Therefore, design the user logic so that the following I/O pins connected to user logic are high impedance in test mode (see **Figure 10-2**). If the design is already such that each signal does not conflict in test mode, this restriction dose not apply.

• VBWAIT

VBLAST

• VBWRITE

- VBSEQ2 to VBSEQ0
   VBBSTR
- VDSELPZ
- VBBENZ3 to VBBENZ0
- VBCTYP2 to VBCTYP0
- VPD15 to VPD0
- VBA27 to VBA0VBD31 to VBD0

• VBTTYP1, VBTTYP0

- VBAHLD
- VDCSZ7 to VDCSZ0
- VBSIZE1, VBSIZE0
- VBLOCK
- VBSTZ

Make I/O pins other than the above the same as in normal mode (leave open if unused).

Caution Although NEC supports test bus auto wiring tools, these are not supported in the NB85E. The user should perform test bus wiring.



Figure 10-2. User Logic Design Example

# (b) Input pin processing

Input a low level to the VAREQ pin. No particular handling is required for pins other than VAREQ (handle them the same way as in normal mode).

# (c) Output pin processing

No particular handling is required (handle them the same way as in normal mode).

\*

#### (2) Pins for test mode

Perform pin processing for the pins for test mode as follows.

|   | Pin Name       | I/O    |                                                          | Pin Processing         |                                        |
|---|----------------|--------|----------------------------------------------------------|------------------------|----------------------------------------|
|   |                |        | If MEMC is connected                                     | If cache is connected  | If MEMC and cache are not<br>connected |
| * | PHTDOn         | Input  | Connect to PHTDOn pin of NB85E500/NU85E500.              | _                      | Input low level.                       |
| * | PHTDINn        | Output | Connect to PHTDINn pin of NB85E500/NU85E500.             | _                      | Leave open.                            |
| * | VPRESZ         | Output | Connect to VPRESZ pin of NB85E500/NU85E500 and NU85E502. | Connect to VPRESZ pin. |                                        |
| * | VPTCLK         | Output | Connect to VPTCLK pin of NB85E500/NU85E500 and NU85E502. | Connect to VPTCLK pin. |                                        |
| * | TESEN          | Output | -                                                        | -                      |                                        |
| * | PHTEST         | Output | Connect to PHTEST pin of NB85E500/NU85E500.              | _                      |                                        |
|   | TMODEn, TBREDZ | Output | Leave open.                                              |                        |                                        |

#### **Remark** n = 1, 0

\*

\*

# (3) Cautions when using NB85E901 (RCU)

If the NB85E901 (RCU) is connected to the NB85E, the following pins are used in the unit test mode. Output all these pins outside the chip as external pins.

- TBI39 to TBI0<sup>Note 1</sup> DRSTZ<sup>Note 2</sup>
- TBO34 to TBO0<sup>Note 1</sup> DMS<sup>Note 2</sup>
- TEST<sup>Note 1</sup> DDI<sup>Note 2</sup>
- BUNRI DDO<sup>Note 2</sup>
- DCK<sup>Note 2</sup>
- DBINT<sup>Notes 1, 2</sup>

Notes 1. Can also function as normal mode pin(s).

2. NB85E901 pin

#### (4) Cautions when using NB85ET

Thirteen N-wire type in-circuit emulator connection pins (DCK, DRSTZ, DMS, DDI, DDO, DBINT, EVTTRG, TRCCLK, TRCDATA3 to TRCDATA0, TRCEND) are also used in the unit test mode of the NB85ET in addition to test buses. Output all these pins outside the chip as external pins. Do not use these pins as alternate-function pins (however, the EVTTRG pin and the DBINT pin can be shared with non-test bus pins (other than TBI39 to TBI0, TBO34 to TBO0)).

#### 10.2.2 Processing MEMC pins

(1) NB85E500

#### (a) Pins for connecting external memory

These operate the same in test mode as in normal mode.

Therefore, if user logic, SRAM, or the like is connected to the data bus (D31 to D0), data bus signals may conflict when in test mode. In order to avoid this, design the user logic so that pins D31 to D0 are high impedance in test mode (see **Figure 10-3**).

Make pins other than D31 to D0 the same as in normal mode (if unused, process them according to the contents shown in the unused pin processing in the Memory Controller NB85E, NB85ET User's Manual (A14206E)).

Input signals at input pins (HLDRQZ, WAITZ, SELFREF) are ignored.

# Caution Although NEC supports test bus auto wiring tools, these are not supported in the NB85E. The user should perform test bus wiring.



Figure 10-3. User Logic Design Example

#### (b) Pins for test mode

Connect to NB85E as shown in Figure 10-1.

#### (c) Other pins

Make the same as in normal mode (if unused, process them according to the contents shown in the unused pin processing in the Memory Controller NB85E, NB85ET User's Manual (A14206E)).

#### (2) NU85E502

#### (a) Pins for connecting external memory

These operate the same in test mode as in normal mode. Input pins (D31 to D0) are ignored regardless of input values.

#### (b) Pins for test mode

Connect to NB85E as shown in Figure 10-1.

#### (c) Other pins

Make the same as in normal mode.

#### ★ 10.3 Test Bus Auto Wiring

Since the NB85E and NB85E peripheral macros do not support test bus auto wiring tools, test bus wiring had to be performed by the user, but it is possible to apply an auto wiring tool by using the method described in **10.3.1 Test bus auto wiring method** (auto wiring using the auto wiring tool is possible only for the NB85E and NB85ET).

Connection prior to auto wiring or netlist editing following auto wiring is required for NB85E peripheral macros (memory controller, instruction/data cache, etc.) and user logic.

Also, test bus PINF file creation/editing is required regardless of whether test bus auto wiring is performed (for details, refer to **10.4 Test Bus PINF File Creation/Editing Methods**).

#### 10.3.1 Test bus auto wiring method

#### (1) NB85E

Perform auto wiring using the normal method.

#### (2) NB85ET

Perform auto wiring using the normal method. However, specify the pins for N-wire type in-circuit emulator connection (DCK, DRSTZ, DMS, DDI, DDO, DBINT, EVTTRG, TRCCLK, TRCDATA3 to TRCDATA0, TRCEND) during auto wiring so that they are not shared with test pins (however, the DBINT and EVTTRG pins can be shared with pins other than test bus pins).

#### (3) Memory controller (NB85E500, NU85E500, NU85E502)

Memory controllers are not eligible for auto wiring because they do not have test mode pins. Perform connection to the NB85E beforehand. The NB85E test mode pins are used for unit testing of the NB85E500, NU85E500, and NU85E502.

#### (4) Instruction cache (NB85E212, NB85E213), data cache (NB85E252, NB85E263)

Although they have a BUNRI pin, these caches are not eligible for auto wiring because they do not have TBIx and TBOx pins.

Since connecting the BUNRI pin beforehand makes auto wiring impossible, connect the TMODE1 pin of the NB85E to the BUNRI pin of the NB85E2xx (during auto wiring, the TMODE1 signal of the NB85E replaces the BUNRI signal). The NB85E2xx unit test is performed using the test mode pins of the NB85E.

#### (5) NB85E901

Although the NB85E901 has BUNRI and TEST pins, it is not eligible for auto wiring because it does not have the TBIx and TBOx pins.

Since connecting the BUNRI and TEST pins beforehand makes auto wiring impossible, clamp the BUNRI pin to low level, connect the TEST pin to the TMODE1 pin of the NB85E, and perform auto wiring of the test bus. Convert the PWC format netlist output following execution to a Verilog netlist, and connect the signal input to the BUNRI pin of the NB85E to the BUNRI pin of the NB85E901. Then convert the Verilog netlist to the PWC format again.

The NB85E901 uses the test mode pins of the NB85E and the N-wire type in-circuit emulator connection pins of the NB85E901 (DCK, DRSTZ, DMS, DDI, DDO, DBINT) during unit tests. Be sure to output the N-wire type in-circuit emulator connection pins outside the chip as external pins. Also, specify them so that they are not shared with test pins during auto wiring (the DBINT pin can be shared with pins that are used in normal mode).

#### (6) User logic

In the user logic design examples shown in Figures 10-2 and 10-3, an external BUNRI pin is set beforehand, and the user logic is designed using that BUNRI signal. However, if the BUNRI pin is connected beforehand, auto wiring becomes impossible. Therefore, clamp the BUNRI input signal to the user logic to low level similarly to the NB85E901, edit the netlist following auto wiring, and then reconnect the BUNRI signal.

#### 10.3.2 Verification of test bus by dummy model

Following test bus auto wiring, verification of the test bus connection can be done through simulation using a dummy model for the NB85E and NB85ET.

However, test bus connection verification via this dummy model consists only of verifying whether the NB85E and NB85ET test busses are normally connected.

Connection with the CPU core and NB85E peripheral macros, and connection on the normal pin side such as Nwire in-circuit emulator connection pins is not possible. Nor is it possible to verify whether unit testing of NB85E peripheral macros that use the test bus of the NB85E and NB85ET has been performed normally. Therefore, if the NB85E core and an NB85E peripheral macro are connected, or if the user circuit is connected to the VSB or memory controller, perform total chip simulation using a full-function model, as required (refer to **CHAPTER 11 TOTAL CHIP SIMULATION**).

## \* 10.4 Test Bus PINF File Creation/Editing Methods

Since the memory controller, instruction/data cache, and NB85E901, which are peripheral macros of the NB85E, are not eligible for auto wiring, that macro information is not reflected in the PINF file created during auto wiring. Neither is the information of the N-wire type in-circuit emulator connection pins used during separation tests for the NB85E901 and NB85ET.

The method used to edit the PINF file created automatically is described below. Even if auto wiring is not performed, this PINF file is required to create the test patterns used to perform unit tests for mega macros.

A PINF file creation example is shown below.

#### 10.4.1 PINF file creation example

#### (1) For NB85E + NU85E500 + NU85E502 + NB85E901 + NB85E212

 BUNRI external pin name:
 BUNRI

 Test mode setting external pin names:
 TMC1, TMC2

 TMC1 = TMC2 = 0 (NB85E and NB85E peripheral macro unit test)

- **Remarks 1.** In the case of the unit test mode of a mega macro that does not use the NB85E test bus, it is not necessary to set N-wire type in-circuit emulator connection pins.
  - **2.** The N-wire type in-circuit emulator connection pins of the NB85E901 are used as external pins without changing their names.
  - 3. \*DECODER block: Describes the pin settings required for macro testing.
  - **4.** \*TESTBUS block: Describes the test signal I/O pins.

# Figure 10-4. PINF File Creation Example (NB85E + NU85E500 + NU85E502 + NB85E901 + NB85E212) (1/2)

| MACRO NB85E (MACRO1)      | Specification of pin during NB85E unit test                                                                   |
|---------------------------|---------------------------------------------------------------------------------------------------------------|
| *DECODER                  |                                                                                                               |
| TMC1 : 0                  | )                                                                                                             |
| TMC2 : 0                  | Specify the NB85E unit test mode                                                                              |
| BUNRI : 1                 |                                                                                                               |
| DCK : 1                   |                                                                                                               |
| DMS : 1                   | Set the N-wire pin of NB85E901 to inactive level                                                              |
| DDI : 1                   | (However, reset pin is active)                                                                                |
| DRSTZ:0                   | ( Even if the DBINT pin is not set as a dedicated pin, it is required for macro separation testing, so set is |
| DBINT : 0                 | as an alternate-function pin)                                                                                 |
| *TESTBUS                  | )                                                                                                             |
|                           | )                                                                                                             |
| xxxx : TBI0               |                                                                                                               |
| : :                       |                                                                                                               |
| xxxx : TBI39              | Describe the test bus pins (xxxx: alternate-function external pin name)                                       |
| xxxx : TBO0               |                                                                                                               |
| : :                       |                                                                                                               |
| xxxx : TBO34              | )                                                                                                             |
| *END                      |                                                                                                               |
| MACRO NU85E500 (MACRO2)   | Pin specification during NU85E500 unit test                                                                   |
| *DECODER                  | -                                                                                                             |
| TMC1 : 0                  | )                                                                                                             |
| TMC2:0                    | Specify the NB85E unit test mode                                                                              |
| BUNRI : 1                 |                                                                                                               |
| DCK : 1                   |                                                                                                               |
| DOK : 1                   | Set the N-wire pin of the NB85E901 to the inactive level                                                      |
|                           | (However, reset pin is active)                                                                                |
| DDI:1                     | (Even if the DBINT pin is not set as a dedicated pin, it is required for macro separation testing, so set it  |
| DRSTZ:0                   | as an alternate-function pin)                                                                                 |
| DBINT : 0                 | )                                                                                                             |
| *TESTBUS                  |                                                                                                               |
| xxxx : TBI0               | )                                                                                                             |
| : :                       |                                                                                                               |
| xxxx : TBI39              | Describe the test bus pins (xxxx: alternate-function external pin name)                                       |
| xxxx : TBO0               | Describe the test bus pins (xxxx, atemate-unction external pin hame)                                          |
| : :                       |                                                                                                               |
| xxxx : TBO34              | J                                                                                                             |
| *END                      |                                                                                                               |
| MACRO NU85E502Cn (MACRO3) | Pin specification during NU85E502 unit test (n = 7 to 0 (set the chip select area corresponding to            |
| *DECODER                  | <sup>-</sup> NU85E500))                                                                                       |
| TMC1 : 0                  | ٦                                                                                                             |
| TMC1:0                    |                                                                                                               |
|                           | Specify the NB85E unit test mode                                                                              |
| BUNRI : 1                 | J                                                                                                             |
| DCK : 1                   | Set the N-wire pin of the NB85E901 to the inactive level                                                      |
| DMS : 1                   | (However, reset pin is active)                                                                                |
| DDI : 1                   | (Even if the DBINT pin is not set as a dedicated pin, it is required for macro separation testing, so set it  |
| DRSTZ:0                   | as an alternate-function pin)                                                                                 |
| DBINT : 0                 | J                                                                                                             |
| *TESTBUS                  |                                                                                                               |
| xxxx : TBI0               |                                                                                                               |
| : :                       |                                                                                                               |
| xxxx : TBI39              |                                                                                                               |
| xxxx : TBO0               | Describe the test bus pins (xxxx: alternate-function external pin name)                                       |
| : :                       |                                                                                                               |
| xxxx : TBO34              |                                                                                                               |
| *END                      |                                                                                                               |
| MACRO NB85E212 (MACRO4)   | Pin specification during NB85E212 unit test                                                                   |
| *DECODER                  | I III Speemoution during NEODEZ 12 drift test                                                                 |
|                           | )                                                                                                             |
| TMC1:0                    | Specify the NB85E unit test mode                                                                              |
| TMC2 : 0                  | Specity the NDODE unit test mode                                                                              |
| BUNRI : 1                 | J                                                                                                             |
| DCK : 1                   | Set the N-wire pin of the NB85E901 to the inactive level                                                      |
| DMS : 1                   | (However, reset pin is active)                                                                                |
| DDI : 1                   | (Even if the DBINT pin is not set as a dedicated pin, it is required for macro separation testing, so set it  |
| DRSTZ:0                   | as an alternate-function pin)                                                                                 |
| DBINT : 0                 |                                                                                                               |
|                           |                                                                                                               |

# Figure 10-4. PINF File Creation Example (NB85E + NU85E500 + NU85E502 + NB85E901 + NB85E212) (2/2)

| *TESTBUS                | х<br>х                                                                                           |
|-------------------------|--------------------------------------------------------------------------------------------------|
| xxxx : TBI0             |                                                                                                  |
| : :                     |                                                                                                  |
| xxxx : TBI39            | Describe the test bus pin (xxxx: alternate-function external pin name)                           |
| xxxx : TBO0             | Describe the test bus pin (XXXX. alternate-function external pin hame)                           |
| : :                     |                                                                                                  |
| xxxx : TBO34            |                                                                                                  |
| *END                    |                                                                                                  |
| MACRO NB85E901 (MACRO5) | - Pin specification during NB85E901 unit test mode                                               |
| *DECODER                |                                                                                                  |
| TMC1 : 0                | J                                                                                                |
| TMC2 : 0                | Specify the NB85E unit test mode                                                                 |
| BUNRI : 1               | J                                                                                                |
| *TESTBUS                |                                                                                                  |
| xxxx : TBI0             |                                                                                                  |
| : :                     |                                                                                                  |
| xxxx : TBI39            |                                                                                                  |
| xxxx : TBO0             | Describe the test bus pins (xxxx: alternate-function external pin name)                          |
| : :                     |                                                                                                  |
| xxxx : TBO34            |                                                                                                  |
| DCK : DCK               | j                                                                                                |
| DMS : DMS               |                                                                                                  |
| DDI : DDI               |                                                                                                  |
| DRSTZ : DRSTZ           | During NB85E901 unit test, enter all the N-wire pins (both input and output) to the TESTBUS bloc |
| DBINT : DBINT           |                                                                                                  |
| DBO : DBO               |                                                                                                  |
| *END                    |                                                                                                  |
| MACRO NXXXXXX (MACRO6)  | Pin specification during macro unit test other than Nx85Exxx                                     |
| *DECODER                |                                                                                                  |
| TMC1 : 0                | )                                                                                                |
| TMC2 : 1                | Specify the Nxxxxxx unit test mode                                                               |
| BUNRI : 1               |                                                                                                  |
| *TESTBUS                |                                                                                                  |
| xxxx : TBI0             |                                                                                                  |
| : :                     |                                                                                                  |
| xxxx : TBI20            |                                                                                                  |
| xxxx : TBO0             | Describe the Nxxxxxx test bus pins (xxxx: alternate-function external pin name)                  |
| : :                     |                                                                                                  |
| xxxx : TBO20            |                                                                                                  |
| *END                    | J                                                                                                |

#### (2) For NB85ET + NU85E500 + NU85E502 + NB85E212

BUNRI external pin name: BUNRI Test mode setting external pin names: TMC1, TMC2 TMC1 – TMC2 – 0 (NR85ET and NR85ET paripharal maara ur

TMC1 = TMC2 = 0 (NB85ET and NB85ET peripheral macro unit test)

- **Remarks1.** In the case of a separation test mode that does not use the NB85E test bus, it is not necessary to set N-wire type in-circuit emulator connection pins.
  - **2.** The N-wire type in-circuit emulator connection pins of the NB85E901 are used as external pins without changing their names.
  - 3. \*DECODER block: Describes the pin settings required for macro testing.
  - 4. \*TESTBUS block: Describes the test signal I/O pins.

| MACRO NB85ET (MACRO1)     | } Pin specification during NB85ET unit test                                                          |
|---------------------------|------------------------------------------------------------------------------------------------------|
| *DECODER                  |                                                                                                      |
| TMC1:0                    | )                                                                                                    |
| TMC2 : 0                  | Specify the NB85ET unit test mode                                                                    |
|                           | S opecity the NDOOL 1 unit test mode                                                                 |
| BUNRI : 1                 |                                                                                                      |
| *TESTBUS                  |                                                                                                      |
| xxxx : TBI0               |                                                                                                      |
|                           |                                                                                                      |
| : :                       |                                                                                                      |
| xxxx : TBI39              | Specify the test hus pipe (vvvv: alternate function external pip pame)                               |
| xxxx : TBO0               | Specify the test bus pins (xxxx: alternate-function external pin name)                               |
| : :                       |                                                                                                      |
|                           |                                                                                                      |
| xxxx : TBO34              | J                                                                                                    |
| DCK : DCK                 |                                                                                                      |
| DMS : DMS                 |                                                                                                      |
|                           |                                                                                                      |
| DDI : DDI                 |                                                                                                      |
| DDO : DDO                 |                                                                                                      |
| DRSTZ : DRSTZ             |                                                                                                      |
| DBINT : DBINT             | During NP85ET unit test, onter all the Nuvire pine (both input and output) to the TESTPLIC block     |
|                           | During NB85ET unit test, enter all the N-wire pins (both input and output) to the TESTBUS block      |
| TRCCLK : TRCCLK           | (Even if the DBINT and EVTTRG pins are not set as dedicated pins, they are required during ma        |
| TRCDATA0 : TRCDATA0       | separation testing, so set them as alternate-function pins even if not setting them as dedicated p   |
| TRCDATA1 : TRCDATA1       |                                                                                                      |
|                           |                                                                                                      |
| TRCDATA2 : TRCDATA2       |                                                                                                      |
| TRCDATA3 : TRCDATA3       |                                                                                                      |
| TRCEND : TRCEND           |                                                                                                      |
| EVTTRG : EVTTRG           |                                                                                                      |
|                           | )                                                                                                    |
| *END                      |                                                                                                      |
| MACRO NU85E500 (MACRO2)   | Pin specification during NU85E500 unit test                                                          |
| *DECODER                  |                                                                                                      |
|                           |                                                                                                      |
| TMC1 : 0                  |                                                                                                      |
| TMC2 : 0                  | Specify the NB85ET unit test mode                                                                    |
| BUNRI : 1                 |                                                                                                      |
|                           | <                                                                                                    |
| DCK : 1                   |                                                                                                      |
| DMS : 1                   | Set N-wire pin of NB85ET to inactive level                                                           |
| DDI : 1                   | (However, reset pin is active)                                                                       |
| DRSTZ : 0                 | (Even if the DBINT pin is not set as a dedicated pin, it is required for macro separation testing, s |
|                           | set it as an alternate-function pin)                                                                 |
| DBINT : 0                 | set it as an alternate-function piny                                                                 |
| *TESTBUS                  |                                                                                                      |
| xxxx : TBI0               | )                                                                                                    |
|                           |                                                                                                      |
| : :                       |                                                                                                      |
| xxxx : TBI39              |                                                                                                      |
| xxxx : TBO0               | Describe test bus pins (xxxx: alternate-function external pin name)                                  |
|                           |                                                                                                      |
| : :                       |                                                                                                      |
| xxxx : TBO34              |                                                                                                      |
| *END                      | ·                                                                                                    |
| MACRO NU85E502Cn (MACRO3) | ∑ Pin specification during NU85E502 unit test (n = 7 to 0 (set the chip select area corresponding to |
|                           | NU85E500))                                                                                           |
| *DECODER                  |                                                                                                      |
| TMC1 : 0                  |                                                                                                      |
| TMC2 : 0                  | Specify the NB85ET unit test mode                                                                    |
|                           |                                                                                                      |
| BUNRI : 1                 |                                                                                                      |
| DCK : 1                   | Cat the Nuvive pip of the NDSEET to the insetion local                                               |
| DMS : 1                   | Set the N-wire pin of the NB85ET to the inactive level                                               |
|                           | (However, reset pin is active)                                                                       |
| DDI:1                     | (Even if the DBINT pin is not set as a dedicated pin, it is required for macro separation testing, s |
| DRSTZ:0                   | set it as an alternate-function pin)                                                                 |
| DBINT : 0                 |                                                                                                      |
| *TESTBUS                  | 1                                                                                                    |
|                           | )                                                                                                    |
| xxxx : TBI0               |                                                                                                      |
| : :                       |                                                                                                      |
| xxxx : TBI39              |                                                                                                      |
|                           | > Describe the test bus pins (xxxx: alternate-function external pin name)                            |
| xxxx : TBO0               |                                                                                                      |
| : :                       |                                                                                                      |
|                           |                                                                                                      |
| xxxx : TBO34              |                                                                                                      |
| xxxx : TBO34<br>*END      | )                                                                                                    |

# Figure 10-5. PINF File Creation Example (NB85ET + NU85E500 + NU85E502 + NB85E212) (1/2)

| MACRO NB85E212 (MACRO4)<br>*DECODER                                 | Pin specification during NB85E212 unit test                                                                                                                                                                                   |
|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TMC1 : 0<br>TMC2 : 0<br>BUNRI : 1                                   | Specify the NB85ET unit test mode                                                                                                                                                                                             |
| DCK : 1<br>DMS : 1<br>DDI : 1<br>DRSTZ : 0<br>DBINT : 0<br>*TESTBUS | Set N-wire pin of NB85ET to inactive level<br>(However, reset pin is active)<br>(Even if the DBINT pin is not set as a dedicated pin, it is required for macro separation testing, so<br>set it as an alternate-function pin) |
| xxxx : TBI0<br>: :<br>xxxx : TBI39<br>xxxx : TBO0<br>: :            | Describe the test bus pin names (xxxx: alternate-function external pin name)                                                                                                                                                  |
| xxxx : TBO34<br>*END<br>MACRO Nxxxxxx (MACRO6)                      | Pin specification during macro unit test other than Nx85Exxx                                                                                                                                                                  |
| *DECODER<br>TMC1 : 0<br>TMC2 : 1                                    | Specify the Nxxxxxx unit test mode                                                                                                                                                                                            |
| BUNRI : 1<br>*TESTBUS<br>xxxx : TBI0                                |                                                                                                                                                                                                                               |
| : :<br>xxxx : TBl20<br>xxxx : TBO0<br>: :                           | > Describe the Nxxxxxx test bus pins (xxxx: alternate-function external pin name)                                                                                                                                             |
| xxxx : TBO20<br>*END                                                | J                                                                                                                                                                                                                             |

# Figure 10-5. PINF File Creation Example (NB85ET + NU85E500 + NU85E502 + NB85E212) (2/2)

# CHAPTER 11 TOTAL CHIP SIMULATION

Total chip simulation is simulation performed for the entire CBIC by operating the NB85E. The following are the two goals of total chip simulation.

#### (1) Creation of test patterns for checking connections

Creates test patterns (test patterns for selection by tester) that perform checks of connections between macros, checks of connections between user logic and macros, and checks of connections between external pins and macros or user logic.

It is difficult to perform all the connection checks between the NB85E and peripheral macros (memory controller, cache, NB85E901) and the memory controller (NB85E500/NU85E500 and NU85E502) on the user's side. Therefore, connection checks can be performed by executing Verilog simulation with a full function model using unit test patterns via a test bus for all the macros prepared by NEC. Consult NEC on how to obtain unit test patterns.

#### (2) Verification of timing between macros

Checks the timing between macros, between a macro and user logic, or between a macro or user logic and external pins.

# 11.1 Creation of Test Patterns for Checking Connections

It is extremely difficult to input the necessary instruction pattern for the CPU read timing while referencing a program in order to create test patterns for checking connections. Therefore, ROM is placed virtually outside the CBIC (virtual ROM) and the program for testing<sup>Note</sup> is allocated there.

The CPU executes a simulation by reading the program for testing in the virtual ROM and extracts the results of dumping the pattern of all pins of the CBIC as the test pattern for checking connections.

This section describes the test pattern creation method for the following three cases.

- When ROM is not connected to VFB
- When ROM is connected to VFB and creating test pattern by connecting virtual ROM to VSB
- When ROM is connected to VFB and writing program for testing in that ROM
- **Note** In this chapter, "program for testing" is defined as a program for performing checks of connections between macros, checks of connections between macros and user logic, and checks of connections between macro or user logic and external pins.

#### (1) When ROM is not connected to VFB

Connect a virtual ROM in which the program for testing is written outside the CBIC. Dump all pins of the CBIC and extract them as the test pattern.



#### Figure 11-1. Block Diagram for Total Chip Simulation (When There Is No ROM in VFB)

#### (2) When ROM is connected to VFB

Creation of test patterns for checking connections when program ROM is connected to the VFB is described for when not writing a program for testing in VFB ROM and when writing one.

# (a) When not writing program for testing in ROM of VFB

#### (Create test pattern by connecting virtual ROM)

As shown in Figure 11-2, place virtual ROM outside the CBIC the same as when there is no ROM in the VFB, and dump all pins of the CBIC and extract them as the test pattern.

Perform test pattern creation by setting IFIROME = 0 and IFIROB2 = 1 and assigning the program for testing to the address 100000H.

Virtual RAM is not required.

# Caution When load testing, the NB85E must be switched to ROMless mode. Therefore, establish pins IFIROME and IFIROB2 as the CBIC external pins.

# Figure 11-2. Block Diagram for Total Chip Simulation (When There Is ROM in VFB and Creating Test Pattern by Connecting Virtual ROM to VSB)



#### (b) When writing program for testing in ROM connected to VFB

Write the program for testing in the ROM of the VFB so that connections between macros or connections between macros and user logic can be verified and make settings so that this program for testing is executed only when testing.

In order to write the program for testing in the ROM of the VFB, actual operating programs<sup>Note</sup> must be decreased by the amount of the test program.

The main advantages in this case are the following.

\*

- When not assigning the external bus to CBIC pins, decrease the number of pins for testing (when reading virtual ROM, the address bus and data bus must be output externally)
- Decrease in the number of test patterns according to difference in number of clocks per access and bus width
- **Note** In this chapter, "actual operating program" is defined as a program for making the target system operate.

# Figure 11-3. Block Diagram for Total Chip Simulation (When There Is ROM in VFB and Writing Program for Testing in That ROM)



As a method of identifying execution of the program for testing and execution of the actual operating program, for example, set the pin for identification and ensure that the pin for identification is checked after NB85E initialization is performed. Depending on the level of the pin for identification, jump to the program for testing or the actual operating program and execute the program. Virtual ROM and virtual RAM are not needed in this case.

#### 11.2 Verifying Timing Between Macros

Besides checking functions such as connections between macros, simulation performs real-time operation verification (real-time simulation). It verifies that there are no timing problems between the NB85E and other macros, the NB85E and user logic, other macros and user logic, or other circuits.

In order to operate the NB85E, a test program for timing verification is needed. The test program for timing verification is allocated in the ROM if there is ROM in the CBIC and in virtual ROM if there is no ROM, and simulation is performed (the test program for timing verification is used only in simulation; it need not actually be placed in ROM in the CBIC).

Real-time simulation predicts when an inconsistency occurs due to a delay difference in MIN. and MAX. simulation. In this case, confirm that there is no problem in inconsistent portions by checking that there are no timing or functional errors.

# **CHAPTER 12 ROM CODE CREATION**

A compiled type ROM (compiled ROM) is used as the ROM connected to the NB85E. Be aware of the following points when using compiled ROM.

(1) ROM code format at sign-off

NEC can receive orders in NINCF format. For details about NINCF format, refer to the CB-9 Family VX/VM Type Memory Macro (Compiled Type) Design Manual (A12982E).

(2) Assigning ROM code to multiple compiled ROMs

Consult NEC when assigning ROM code to multiple compiled ROMs.

#### (3) Simulation with ROM code

For details, refer to NEC SYSTEM LSI DESIGN OPENCAD V5.4 Verilog-XL Interface User's Manual (A15052E).

# APPENDIX REVISION HISTORY

Revisions up to the previous edition are shown below. The "Pages" column indicates pages in the earlier edition to which the revision was applied.

| (1) | 1st editi | on $\rightarrow$ 2nd | edition |
|-----|-----------|----------------------|---------|
|-----|-----------|----------------------|---------|

 $\star$ 

| Pages       | Description                                                                                                                                                                                                        |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Throughout  | <ul> <li>Change of name of NPB peripheral macros from "NANPxxx" to "QLNPBxxx"</li> <li>Deletion of description regarding NB85E501 of MEMC</li> <li>Change of name of MEMC from "NB85E502" to "NU85E502"</li> </ul> |  |
| pp.19 to 22 | Modification of CHAPTER 2 CONNECTION OF CLOCK CONTROL CIRCUIT                                                                                                                                                      |  |
| p.29        | Modification of Figure 3-6 Connection Example of Compiled ROM to VFB                                                                                                                                               |  |
| p.48        | Modification of Figure 5-1 Connection Example of NB85E, MEMC, and External Memory (SRAM, SDRAM)                                                                                                                    |  |
| pp.57, 58   | Deletion of description regarding a data cache connection in 5.3 Connection to SDRAM                                                                                                                               |  |
| p.72        | Modification of Figure 6-4 Connection Example of Address Decoder                                                                                                                                                   |  |
| p.75        | Modification of Figure 6-7 Connection Example of User Logic                                                                                                                                                        |  |
| p.76        | Modification of Figure 6-9 HDL Creation Example of User Logic                                                                                                                                                      |  |
| p.78        | Modification of Figure 6-11 HDL Creation Example of User Logic with Retry Function                                                                                                                                 |  |
| p.92        | Modification of <b>Remark 2</b> in <b>Figure 8-4 Recommended Circuit Example for IE Connection</b><br>(NB85E + RCU (NB85E901))                                                                                     |  |
| p.93        | Modification of Figure 8-5 Recommended Circuit Example for IE Connection (NB85ET)<br>Modification of Remarks 2 and 3                                                                                               |  |
| p.103       | Modification of 9.5 Device File                                                                                                                                                                                    |  |
| p.109       | Modification of 10.2.1 (3) Precautions when using NB85E901 (RCU) and (4) Precautions when using NB85ET                                                                                                             |  |

# NEC

# Facsimile Message

FAX

Although NEC has taken all possible steps to ensure that the documentation supplied to our customers is complete, bug free and up-to-date, we readily accept that errors may occur. Despite all the care and precautions we've taken, you may encounter problems in the documentation. Please complete this form whenever you'd like to report errors or suggest improvements to us.

Address

Tel.

From:

Name

Company

Thank you for your kind support.

| North America<br>NEC Electronics Inc.<br>Corporate Communications Dept.<br>Fax: +1-800-729-9288<br>+1-408-588-6130 | Hong Kong, Philippines, Oceania<br>NEC Electronics Hong Kong Ltd.<br>Fax: +852-2886-9022/9044 | Asian Nations except Philippines<br>NEC Electronics Singapore Pte. Ltd.<br>Fax: +65-250-3583 |
|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| Europe<br>NEC Electronics (Europe) GmbH<br>Market Communication Dept.<br>Fax: +49-211-6503-274                     | <b>Korea</b><br>NEC Electronics Hong Kong Ltd.<br>Seoul Branch<br>Fax: +82-2-528-4411         | Japan<br>NEC Semiconductor Technical Hotline<br>Fax: +81- 44-435-9608                        |
| South America<br>NEC do Brasil S.A.<br>Fax: +55-11-6462-6829                                                       | <b>Taiwan</b><br>NEC Electronics Taiwan Ltd.<br>Fax: +886-2-2719-5951                         |                                                                                              |

I would like to report the following error/make the following suggestion:

Document title: \_\_\_\_

Document number: \_\_\_\_

Page number:

If possible, please fax the referenced page or drawing.

| <b>Document Rating</b> | Excellent | Good | Acceptable | Poor |
|------------------------|-----------|------|------------|------|
| Clarity                |           |      |            |      |
| Technical Accuracy     |           |      |            |      |
| Organization           |           |      |            |      |