

IEC 62528

Edition 1.0 2007-11

### INTERNATIONAL STANDARD

**IEEE 1500™** 

Standard testability method for embedded core-based integrated circuits

INTERNATIONAL ELECTROTECHNICAL COMMISSION

PRICE CODE

ISBN 2-8318-9481-6

#### **CONTENTS**

| FOI | OREWORD4                                           |             |  |
|-----|----------------------------------------------------|-------------|--|
| IEE | E Introduction                                     | 7           |  |
| 1.  | Overview                                           | Ç           |  |
|     |                                                    | 10          |  |
|     | <u>*</u>                                           | 10          |  |
| 2.  | Normative references                               | 10          |  |
| 3.  | Definitions, acronyms, and abbreviations           | 11          |  |
| ٥.  | · · · · · · · · · · · · · · · · · · ·              | 11          |  |
|     |                                                    |             |  |
|     | •                                                  |             |  |
| 4.  | Structure of this standard                         |             |  |
|     | *                                                  | 17          |  |
|     | 4.2 Descriptions                                   |             |  |
| 5.  | Introduction and motivations of two compliance lev | rels        |  |
| 6.  | Overview of the IEEE 1500 scalable hardware arch   | itecture 19 |  |
| 0.  |                                                    |             |  |
|     | 11 ' '                                             |             |  |
|     |                                                    |             |  |
|     |                                                    |             |  |
|     |                                                    |             |  |
| 7   | WID :                                              | 21          |  |
| 7.  | WIR instructions                                   |             |  |
|     |                                                    |             |  |
|     |                                                    | ons         |  |
|     |                                                    | ntion       |  |
|     | <del>-</del>                                       |             |  |
|     | _                                                  |             |  |
|     | <del>-</del>                                       |             |  |
|     |                                                    |             |  |
|     |                                                    |             |  |
|     |                                                    |             |  |
|     | 7.14 Wx_INTEST instruction                         | 40          |  |
| 8.  | Wrapper serial port (WSP)                          |             |  |
|     | 8.1 WSP terminals                                  |             |  |
| 9.  | Wrapper parallel port (WPP)                        | 43          |  |
| ٠.  |                                                    |             |  |
| 1.0 |                                                    |             |  |
| 10. |                                                    |             |  |
|     |                                                    |             |  |
|     |                                                    | 44          |  |
|     | 10.3 WIR operation                                 | 47          |  |
| 11. | Wrapper bypass register (WBY)                      | 49          |  |
|     | 11.1 WBY register configuration and selection      | 49          |  |

|     | 11.2 WBY design                                                      | 50  |  |  |
|-----|----------------------------------------------------------------------|-----|--|--|
|     | 11.3 WBY operation                                                   | 51  |  |  |
| 12. | Wrapper boundary register (WBR).                                     |     |  |  |
|     | 12.1 WBR structure and operation                                     |     |  |  |
|     | 12.2 WBR cell structure and operation.                               |     |  |  |
|     | 12.3 WBR operation events                                            |     |  |  |
|     | •                                                                    |     |  |  |
|     | 12.4 WBR operation modes                                             |     |  |  |
|     | 12.5 Parallel access to the WBR                                      |     |  |  |
|     | 12.6 WBR cell naming                                                 |     |  |  |
|     | 12.7 WBR cell examples                                               |     |  |  |
|     | 12.8 IEEE 1500 WBR example                                           | 68  |  |  |
| 13. | Wrapper states                                                       |     |  |  |
|     | 13.1 Wrapper Disabled and Wrapper Enabled states                     | 71  |  |  |
| 14. | WSP timing diagram                                                   | 72  |  |  |
|     | 14.1 Specifications                                                  | 72  |  |  |
|     | 14.2 Description                                                     | 73  |  |  |
|     | 14.3 Synchronous reset timing                                        |     |  |  |
| 15. | WSP configurations for IEEE 1500 system chips                        | 78  |  |  |
|     | 15.1 Connecting multiple WSPs                                        |     |  |  |
| 1.0 | DI a contrata (DoD)                                                  | 0.1 |  |  |
| 16. | Plug-and-play (PnP)                                                  |     |  |  |
|     | 16.1 Background and definition                                       |     |  |  |
|     | 16.2 PnP aspects of standard instructions                            |     |  |  |
|     | 16.3 PnP limitations on protocols                                    |     |  |  |
|     | 16.4 Non-PnP in IEEE Std 1500                                        | 83  |  |  |
| 17. |                                                                      | 83  |  |  |
|     | 17.1 General rules                                                   | 83  |  |  |
|     | 17.2 Per-terminal rules                                              | 85  |  |  |
|     | 17.3 Test pattern information rules                                  | 86  |  |  |
| 18. | Compliance definitions specific to unwrapped cores                   | 89  |  |  |
|     | 18.1 General rules                                                   | 89  |  |  |
|     | 18.2 Per-terminal rules                                              | 90  |  |  |
|     | 18.3 Additional test information rules                               |     |  |  |
| 19. | Compliance definitions specific to wrapped cores                     | 91  |  |  |
|     | 19.1 General rules                                                   |     |  |  |
|     | 19.2 Per-terminal rules.                                             |     |  |  |
|     | 19.3 Wrapper protocol information rules                              |     |  |  |
| 20. | IEEE 1500 application                                                | 93  |  |  |
|     | 20.1 CTL (IEEE P1450.6) overview                                     |     |  |  |
|     | 20.2 IEEE 1500 examples                                              |     |  |  |
|     | •                                                                    |     |  |  |
| Ann | nex A (normative) Bubble diagram definition                          | 110 |  |  |
| Ann | nex B (informative) WBR cell examples                                | 112 |  |  |
| Δnn | nex C (informative) Relationship of IEEE Std 1500 to IEEE Std 1149.1 | 121 |  |  |
|     |                                                                      |     |  |  |
| Ann | Annex D (informative) List of participants                           |     |  |  |

#### INTERNATIONAL ELECTROTECHNICAL COMMISSION

### STANDARD TESTABILITY METHOD FOR EMBEDDED CORE-BASED INTEGRATED CIRCUITS

#### **FOREWORD**

- 1) The International Electrotechnical Commission (IEC) is a worldwide organization for standardization comprising all national electrotechnical committees (IEC National Committees). The object of IEC is to promote international co-operation on all questions concerning standardization in the electrical and electronic fields. To this end and in addition to other activities, IEC publishes International Standards, Technical Specifications, Technical Reports, Publicly Available Specifications (PAS) and Guides (hereafter referred to as "IEC Publication(s)"). Their preparation is entrusted to technical committees; any IEC National Committee interested in the subject dealt with may participate in this preparatory work. International, governmental and non-governmental organizations liaising with the IEC also participate in this preparation. IEC collaborates closely with the International Organization for Standardization (ISO) in accordance with conditions determined by agreement between the two organizations.
- 2) The formal decisions or agreements of IEC on technical matters express, as nearly as possible, an international consensus of opinion on the relevant subjects since each technical committee has representation from all interested IEC National Committees.
- 3) IEC Publications have the form of recommendations for international use and are accepted by IEC National Committees in that sense. While all reasonable efforts are made to ensure that the technical content of IEC Publications is accurate, IEC cannot be held responsible for the way in which they are used or for any misinterpretation by any end user.
- 4) In order to promote international uniformity, IEC National Committees undertake to apply IEC Publications transparently to the maximum extent possible in their national and regional publications. Any divergence between any IEC Publication and the corresponding national or regional publication shall be clearly indicated in the latter.
- 5) IEC provides no marking procedure to indicate its approval and cannot be rendered responsible for any equipment declared to be in conformity with an IEC Publication.
- 6) Attention is drawn to the possibility that some of the elements of this IEC Publication may be the subject of patent rights. IEC shall not be held responsible for identifying any or all such patent rights.

International Standard IEC/IEEE 62528 has been processed through Technical Committee 93: Design automation.

The text of this standard is based on the following documents:

| IEEE Std   | FDIS        | Report on voting |
|------------|-------------|------------------|
| 1500(2005) | 93/250/FDIS | 93/261/RVD       |

Full information on the voting for the approval of this standard can be found in the report on voting indicated in the above table.

The committee has decided that the contents of this publication will remain unchanged until the maintenance result date indicated on the IEC web site under "http://webstore.iec.ch" in the data related to the specific publication. At this date, the publication will be

- · reconfirmed.
- · withdrawn,
- replaced by a revised edition, or
- amended.

#### **IEC/IEEE Dual Logo International Standards**

This Dual Logo International Standard is the result of an agreement between the IEC and the Institute of Electrical and Electronics Engineers, Inc. (IEEE). The original IEEE Standard was submitted to the IEC for consideration under the agreement, and the resulting IEC/IEEE Dual Logo International Standard has been published in accordance with the ISO/IEC Directives.

IEEE Standards documents are developed within the IEEE Societies and the Standards Coordinating Committees of the IEEE Standards Association (IEEE-SA) Standards Board. The IEEE develops its standards through a consensus development process, approved by the American National Standards Institute, which brings together volunteers representing varied viewpoints and interests to achieve the final product. Volunteers are not necessarily members of the Institute and serve without compensation. While the IEEE administers the process and establishes rules to promote fairness in the consensus development process, the IEEE does not independently evaluate, test, or verify the accuracy of any of the information contained in its standards.

Use of an IEC/IEEE Dual Logo International Standard is wholly voluntary. The IEC and IEEE disclaim liability for any personal injury, property or other damage, of any nature whatsoever, whether special, indirect, consequential, or compensatory, directly or indirectly resulting from the publication, use of, or reliance upon this, or any other IEC or IEEE Standard document.

The IEC and IEEE do not warrant or represent the accuracy or content of the material contained herein, and expressly disclaim any express or implied warranty, including any implied warranty of merchantability or fitness for a specific purpose, or that the use of the material contained herein is free from patent infringement. IEC/IEEE Dual Logo International Standards documents are supplied "AS IS".

The existence of an IEC/IEEE Dual Logo International Standard does not imply that there are no other ways to produce, test, measure, purchase, market, or provide other goods and services related to the scope of the IEC/IEEE Dual Logo International Standard. Furthermore, the viewpoint expressed at the time a standard is approved and issued is subject to change brought about through developments in the state of the art and comments received from users of the standard.

Every IEEE Standard is subjected to review at least every five years for revision or reaffirmation. When a document is more than five years old and has not been reaffirmed, it is reasonable to conclude that its contents, although still of some value, do not wholly reflect the present state of the art. Users are cautioned to check to determine that they have the latest edition of any IEEE Standard.

In publishing and making this document available, the IEC and IEEE are not suggesting or rendering professional or other services for, or on behalf of, any person or entity. Neither the IEC nor IEEE is undertaking to perform any duty owed by any other person or entity to another. Any person utilizing this, and any other IEC/IEEE Dual Logo International Standards or IEEE Standards document, should rely upon the advice of a competent professional in determining the exercise of reasonable care in any given circumstances.

Interpretations – Occasionally questions may arise regarding the meaning of portions of standards as they relate to specific applications. When the need for interpretations is brought to the attention of IEEE, the Institute will initiate action to prepare appropriate responses. Since IEEE Standards represent a consensus of concerned interests, it is important to ensure that any interpretation has also received the concurrence of a balance of interests. For this reason, IEEE and the members of its societies and Standards Coordinating Committees are not able to provide an instant response to interpretation requests except in those cases where the matter has previously received formal consideration.

Comments for revision of IEC/IEEE Dual Logo International Standards are welcome from any interested party, regardless of membership affiliation with the IEC or IEEE. Suggestions for changes in documents should be in the form of a proposed change of text, together with appropriate supporting comments. Comments on standards and requests for interpretations should be addressed to:

Secretary, IEEE-SA Standards Board, 445 Hoes Lane, P.O. Box 1331, Piscataway, NJ 08855-1331, USA and/or General Secretary, IEC, 3, rue de Varembé, PO Box 131, 1211 Geneva 20, Switzerland.

Authorization to photocopy portions of any individual standard for internal or personal use is granted by the Institute of Electrical and Electronics Engineers, Inc., provided that the appropriate fee is paid to Copyright Clearance Center. To arrange for payment of licensing fee, please contact Copyright Clearance Center, Customer Service, 222 Rosewood Drive, Danvers, MA 01923 USA; +1 978 750 8400. Permission to photocopy portions of any individual standard for educational classroom use can also be obtained through the Copyright Clearance Center.

NOTE – Attention is called to the possibility that implementation of this standard may require use of subject matter covered by patent rights. By publication of this standard, no position is taken with respect to the existence or validity of any patent rights in connection therewith. The IEEE shall not be responsible for identifying patents for which a license may be required by an IEEE standard or for conducting inquiries into the legal validity or scope of those patents that are brought to its attention.

# IEEE Standard Testability Method for Embedded Core-based Integrated Circuits

Sponsor

Test Technology Technical Council of the IEEE Computer Society

Approved 30 June 2005

**American National Standards Institute** 

Approved 20 March 2005

**IEEE-SA Standards Board** 

**Abstract:** This standard defines a mechanism for the test of core designs within a system on chip (SoC). This mechanism constitutes a hardware architecture and leverages the core test language (CTL) to facilitate communication between core designers and core integrators.

**Keywords:** core test, embedded core test, IP test, test reuse

#### **IEEE Introduction**

IEEE Std 1500 is a scalable standard architecture for enabling test reuse and integration for embedded cores and associated circuitry. It foregoes addressing analog circuits and focuses on facilitating efficient test of digital aspects of systems on chip (SoCs). IEEE Std 1500 has serial and parallel test access mechanisms (TAMs) and a rich set of instructions suitable for testing cores, SoC interconnect, and circuitry. In addition, IEEE Std 1500 defines features that enable core isolation and protection. IEEE Std 1500 will reduce test cost through improved automation, promote good design-for-test (DFT) technique, and improve test quality through improved access.

Core test language (CTL) is the official mechanism for describing IEEE 1500 wrappers and test data associated with cores. CTL is defined in IEEE P1450.6 <sup>TMa</sup> and was originally begun as part of the development of IEEE Std 1500.

IEEE Std 1500 was broadly influenced by the past work of the IEEE Std 1149.1™ Working Group and has several members from that group. IEEE Std 1149.1 and IEEE Std 1500 have similar goals at different levels of integration. IEEE Std 1149.1 describes a wrapper architecture and access mechanism designed for the purpose of testing components of a board whereas IEEE Std 1500 has a similar structure targeted towards testing cores in an SoC.

IEEE Std 1500 has been a continuous effort for its participants due to the goal of resolving the needs of reconciling and accommodating disparate test strategies and motives. The greatest effort has been put into supporting as many requirements as possible while still producing a cohesive and consistent standard.

#### Objective of the IEEE 1500 effort

The Embedded Core Test Working Group was approved in 1997 with the charter to develop a standard test method for integrated circuits (ICs) containing embedded cores, i.e., reusable megacells. That method would be independent of the underlying functionality of the IC or its individual embedded cores. The method will create the necessary testability requirements for detection and diagnosis of such ICs, while allowing for ease of interoperability of cores originated from distinct sources. This method will be usable for all classes of digital cores including hierarchical ones (subclause 15.1 discusses hierarchical core-wrapper configurations).

In order to satisfy that charter, the Embedded Core Test Working Group was organized into several task forces:

Core Test Language
Scalable Architecture
Compliance Definition/Information Model
Terminology/Glossary
Edition
Mergeable Cores Test
Benchmarking
Industry & Media Relations

<sup>&</sup>lt;sup>a</sup>Information on references can be found in Clause 2.

#### **Achievements**

Since its inception, the Embedded Core Test Working Group has produced eight drafts of the preliminary standard, considering all aspects of core-based test. Due concern has been given to ensuring that a broad spectrum of users will be satisfied through flexibility. Both serial and parallel TAMs were developed. A definition for core wrappers was created, and a set of instructions developed. The CTL was begun, and an information model and compliance definition using that language were developed.

#### **Notice to users**

#### **Errata**

Errata, if any, for this and all other standards can be accessed at the following URL: <a href="http://standards.ieee.org/reading/ieee/updates/errata/index.html">http://standards.ieee.org/reading/ieee/updates/errata/index.html</a>. Users are encouraged to check this URL for errata periodically.

#### Interpretations

Current interpretations can be accessed at the following URL: <a href="http://standards.ieee.org/reading/ieee/interp/">http://standards.ieee.org/reading/ieee/interp/</a> index.html.

#### **Patents**

Attention is called to the possibility that implementation of this standard may require use of subject matter covered by patent rights. By publication of this standard, no position is taken with respect to the existence or validity of any patent rights in connection therewith. The IEEE shall not be responsible for identifying patents or patent applications for which a license may be required to implement an IEEE standard or for conducting inquiries into the legal validity or scope of those patents that are brought to its attention.

## STANDARD TESTABILITY METHOD FOR EMBEDDED CORE-BASED INTEGRATED CIRCUITS

#### 1. Overview

IEEE Std 1500<sup>TM</sup> defines a scalable architecture for independent, modular test development and test application for embedded design blocks and also enables test of the external logic surrounding these cores. Modular testing is typically a requirement for embedded nonlogic blocks, such as memories, and for embedded predesigned nonmergeable intellectual property (IP) cores. In addition, the IEEE 1500 architecture can also be used to partition large design blocks into smaller blocks of more manageable size and to facilitate test reuse for blocks that are reused from one system-on-chip (SoC) design to the next.

The IEEE 1500 architecture comprises hardware requirements, through the definition of a standardized core wrapper, and uses a test-specific language to communicate information between core providers and core users. This language is the IEEE P1450.6<sup>TM 1</sup> core test language (CTL). Although IEEE Std 1500 limited itself to test aspects internal to nonmergeable cores, careful consideration was given to the interoperability of such cores, resulting in plug-and-play (PnP) requirement definitions. SoC-specific issues such as those related to the design of test access mechanisms (TAMs) are excluded from this standard and assumed to be addressed by the SoC designer.

IEEE Std 1500 specifically focuses on defining test requirements for unidirectional non-tristate digital terminals, as these represent a minimum and mandatory set of requirements upon which the more complex bidirectional terminals are based. It is, therefore, implied that support for bidirectional or tristatable terminals is provided only to the extent that the individual unidirectional terminals, i.e., the bidirectional or tristatable terminal, are available for IEEE 1500 wrapper insertion. In addition, the hardware architecture defined in this standard anticipates a synchronous wrapper design methodology.

While IEEE Std 1500 does not discuss chip-level design, the architecture defined in this standard does not prevent interfacing with IEEE 1149.1<sup>TM</sup>-based standards. An example of this interface is provided in Annex C for the reader's benefit.

All rules described in this standard apply to the case where the IEEE 1500 wrapper is enabled (the wrapper logic actively participates in the test of the core) except rules specific to the Wrapper Disabled state of the IEEE 1500 wrapper. In Wrapper Disabled state, the IEEE 1500 wrapper is disabled, allowing functional

<sup>&</sup>lt;sup>1</sup>Information on references can be found in Clause 2.

operation of the wrapped core. IEEE P1450.6 constructs were added to this standard, where appropriate, to further guide the reader. It is anticipated that the reader will refer to these CTL constructs documented in IEEE P1450.6. Additional discussion that complements the body of this standard are presented in annex clauses:

- Annex A contains the legend for IEEE 1500 wrapper cells.
- Annex B shows examples of IEEE 1500 wrapper cells.
- Annex C presents similarities between IEEE Std 1500 and IEEE Std 1149.1 and discusses an example interface between IEEE Std 1500 and IEEE Std 1149.1.

#### 1.1 Scope

IEEE Std 1500 has developed a standard design-for-testability method for integrated circuits (ICs) containing embedded nonmergeable cores. This method is independent of the underlying functionality of the IC or its individual embedded cores. The method creates the necessary requirements for the test of such ICs, while allowing for ease of interoperability of cores that may have originated from different sources.

#### 1.2 Purpose

The aim of IEEE Std 1500 is to provide a consistent scalable solution to the test reuse challenges specific to the reuse of nonmergeable cores, while preserving the IP aspects that are often associated with these cores. This objective is achieved through provision of a core-centric methodology that enables successful integration of cores into SoCs.

IEEE Std 1500 provides a bridge between core providers and core users and also facilitates the automation of test data transfer and reuse between these two entities via the use of the IEEE P1450.6 CTL. This automation relies on information requirements (the information model) placed on the core provider to ensure that the core can be successfully integrated by the core user. The result is shorter time to market for core providers and core users.

The data transfer and reuse from the core provider to the core user are based on the premise that the core test data are left unchanged, while the test protocol is adapted from the IEEE 1500 hardware interface to the SoC.

#### 2. Normative references

The following referenced documents are indispensable for the application of this document. For dated references, only the edition cited applies. For undated references, the latest edition of the referenced document (including any amendments or corrigenda) applies.

IEEE Std 1149.1, IEEE Standard Test Access Port and Boundary-Scan Architecture.<sup>2</sup>

IEEE P1450.6, Draft Standard for Standard Test Interface Language (STIL) for Digital Test Vector Data—Core Test Language (CTL), http://grouper.ieee.org/groups/ctl/.

<sup>&</sup>lt;sup>2</sup>IEEE publications are available from the Institute of Electrical and Electronics Engineers, 445 Hoes Lane, Piscataway, NJ 08854, USA (http://standards.ieee.org/).