

# SystemRDL 2.0 / D9 Register Description Language

October 16, 2017

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change.

- Abstract: Information about the registers in a circuit design is required throughout its lifetime, from initial architectural specification, through creation of an HDL description, verification of the design, post-silicon testing, to deployment of the circuit. A consistent and accurate description of the registers is necessary so the registers specified by the architects and the registers programmed by the users of the final product are the same. SystemRDL is a language for describing registers in circuit designs. SystemRDL descriptions are used as inputs to software tools that generate circuit logic, test programs, printed documentation, and other register artifacts. Generating all of these from a single source ensures their consistency and accuracy. The description of a register may correspond to a register in an preexisting circuit design, or it can serve as an input to a synthesis tool that creates the register logic and access interfaces. A description captures the behavior of the individual registers, the organization of the registers into register files, and the allocation of addresses to registers. A variety of register behaviors can be described: simple storage elements, storage elements with special read/write behavior (e.g., 'write 1 to clear'), interrupts, and counters.
- Keywords: hardware design, electronic design automation, SystemRDL, hierarchical register description,
   control and status registers, interrupt registers, counter registers, register synthesis, software generation, documentation generation, bus interface, memory, register addressing.
- 20
- 25
- 30
- 35
- 40
- 45
- 50

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change.

#### Notices

Accellera Systems Initiative (Accellera) Standards documents are developed within Accellera and the Technical Committee of Accellera. Accellera develops its standards through a consensus development process, approved by its members and board of directors, which brings together volunteers representing varied viewpoints and interests to achieve the final product. Volunteers are members of Accellera and serve without compensation. While Accellera administers the process and establishes rules to promote fairness in the consensus development process, Accellera does not independently evaluate, test, or verify the accuracy of any of the information contained in its standards.

Use of an Accellera Standard is wholly voluntary. Accellera disclaims 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 Accellera Standard document.

Accellera does not warrant or represent the accuracy or content of the material contained herein, and expressly disclaims any express or implied warranty, including any implied warranty of merchantability or suitability for a specific purpose, or that the use of the material contained herein is free from patent infringement. Accellera Standards documents are supplied "AS IS."

The existence of an Accellera 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 an Accellera Standard. Furthermore, the viewpoint expressed at the time a standard is approved and issued is subject to change due to developments in the state of the art and comments received from users of the standard. Every Accellera Standard is subjected to review periodically for revision and update. Users are cautioned to check to determine that they have the latest edition of any Accellera Standard.

In publishing and making this document available, Accellera is not suggesting or rendering professional or other services for, or on behalf of, any person or entity. Nor is Accellera undertaking to perform any duty owed by any other person or entity to another. Any person utilizing this, and any other Accellera 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 Accellera, Accellera will initiate action to prepare appropriate responses. Since Accellera 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, Accellera and the members of its Technical 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 Accellera Standards are welcome from any interested party, regardless of membership affiliation with Accellera. 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:

> Accellera Systems Initiative. 8698 Elk Grove Bldv Suite 1, #114 Elk Grove, CA 95624 USA

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. Accellera shall not

iii

1

5

10

15

20

25

30

35

40

45

50

| 1  | be responsible for identifying patents for which a license may be required by an Accellera standard<br>or for conducting inquiries into the legal validity or scope of those patents that are brought to its<br>attention.                                                                                                                                                                                                                                                                                                                                   |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5  | Accellera is the sole entity that may authorize the use of Accellera-owned certification marks and/or trade-<br>marks to indicate compliance with the materials set forth herein.                                                                                                                                                                                                                                                                                                                                                                            |
| 10 | Authorization to photocopy portions of any individual standard for internal or personal use must be granted<br>by Accellera, provided that permission is obtained from and any required fee is paid to Accellera. To arrange<br>for authorization please contact Lynn Bannister, Accellera Systems Initiative, 8698 Elk Grove Bldv Suite 1,<br>#114, Elk Grove, CA 95624, phone (916) 670-1056, e-mail lynn@accellera.org. Permission to photocopy<br>portions of any individual standard for educational classroom use can also be obtained from Accellera. |
| 15 | Suggestions for improvements to the SystemRDL 2.0 Specification are welcome. They should be sent to the SystemRDL email reflector                                                                                                                                                                                                                                                                                                                                                                                                                            |
|    | systemrdl@lists.accellera.org                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 20 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 25 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 30 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 25 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 55 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 40 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 45 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 50 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 55 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| The SystemRDL language was specifically designed to describe and implement a wide variety of registers<br>and memories. Using SystemRDL, developers can automatically generate and synchronize the register<br>specification in hardware design, software development, verification, and documentation. The intent behind<br>standardizing the language is to drastically reduce the development cycle for hardware designers, hardware<br>verification engineers, software developers, and documentation developers. | 5  |
| SystemRDL is intended for                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 10 |
| — RTL generation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |
| — RTL verification                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |
| — SystemC generation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 15 |
| — Documentation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 15 |
| <ul> <li>Pass through material for other tools, e.g., debuggers</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                            |    |
| — Software development                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 20 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 25 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 30 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 35 |

45

50

v

# <sup>1</sup> Participants

The following members took part in the SystemRDL Working Group (RDWG):

# Miles McCoo, Intel Corporation, Chair RDWG Joe Daniels, Technical Editor Accellera Systems Initiative, Inc.: Joe Daniels Allied Member: Michael Faust Cisco Systems, Inc: Steve Russell, Somasundaram Arunachalam Intel Corporation: Miles McCoo

Magillem Design Services: Guillaume Godet-Bar NVIDIA Corporation: John Berendsen

Semifore, Inc: Richard Weber

| 2  | <b>n</b> |
|----|----------|
| 71 |          |
| ~  | •        |

5

10

15

- 25
- 30
- 35
- 40

45

50

vi

| 1. | Ove  | rview                                 | 1     |
|----|------|---------------------------------------|-------|
|    | 1.1  | Scope                                 | 1 5   |
|    | 1.2  | Purpose                               | 1     |
|    | 1.3  | Motivation                            | 1     |
|    | 1.4  | Backward compatibility                | 2 10  |
|    | 1.5  | Conventions used                      | 2     |
|    |      | 1.5.1 Visual cues (meta-syntax)       | 2     |
|    |      | 1.5.2 Notational conventions          | 3     |
|    |      | 1.5.3 Examples                        | 3     |
|    | 1.6  | Use of color in this standard         | 3 15  |
|    | 1.7  | Contents of this standard             | 3     |
| 2. | Refe | erences                               | 5     |
| 3. | Defi | initions, acronyms, and abbreviations | 7 20  |
|    | 3.1  | Definitions                           | 7     |
|    | 3.2  | Acronyms and abbreviations            | 8     |
| 4. | Lexi | ical conventions                      | 9 25  |
|    | 4.1  | White space                           | 9     |
|    | 4.2  | Comments                              | 9     |
|    | 4.3  | Identifiers                           | 9     |
|    | 4.4  | Keywords                              | 10 30 |
|    | 4.5  | Strings                               | 10    |
|    | 4.6  | Numbers                               | 11    |
| 5. | Gen  | eral concepts, rules, and properties  | 13    |
|    | 5.1  | Key concepts and general rules        | 13    |
|    |      | 5.1.1 Defining components             | 13    |
|    |      | 5.1.2 Instantiating components        | 16    |
|    |      | 5.1.3 Specifying component properties | 21    |
|    |      | 5.1.4 Scoping and namespaces          | 23 40 |
|    | 5.2  | General component properties          | 25    |
|    |      | 5.2.1 Universal properties            | 25    |
|    |      | 5.2.2 Structural properties           | 26    |
|    | 5.3  | Content deprecation                   | 27    |
|    |      | 5.3.1 Semantics                       | 27 45 |
|    |      | 5.3.2 Examples                        | 27    |
| 6. | Data | a types                               | 29    |
|    | 6.1  | Overview                              | 29 50 |
|    | 6.2  | Primary data types                    | 29    |
|    |      | 6.2.1 Signed and unsigned data types  | 29    |
|    |      | 6.2.2 String data type                | 30    |
|    |      | 6.2.3 Boolean data type               | 30    |
|    |      | 6.2.4 Reserved enumeration types      | 30 55 |

| 1  |    |        | 6.2.5     | Enumerations                           |    |
|----|----|--------|-----------|----------------------------------------|----|
|    |    | 63     | Aggreg    | rate data types                        |    |
|    |    | 0.5    | Aggleg    | A rrays                                |    |
| 5  |    |        | 632       | Structures                             | 35 |
| 0  |    | 64     | Type c    | ompatibility                           | 37 |
|    |    | 6.5    | Casting   | z                                      |    |
| 10 | 7. | Expre  | essions . |                                        |    |
|    |    | 7.1    | Overvi    | ew                                     |    |
|    |    | 7.2    | Operate   | ors                                    |    |
|    |    |        | 7.2.1     | Assignment operators                   |    |
| 15 |    |        | 7.2.2     | Logical operators                      |    |
|    |    | 7.3    | Express   | sion evaluation rules                  |    |
|    |    |        | 7.3.1     | Rules for determining expression types |    |
|    |    |        | 7.3.2     | Rules for evaluating expressions       |    |
| 20 | 8. | Signal | ls        |                                        |    |
|    |    | 8.1    | Introdu   | ction                                  |    |
|    |    | 8.2    | Signal    | properties                             |    |
|    |    |        | 8.2.1     | Semantics                              |    |
| 25 |    |        | 8.2.2     | Example                                |    |
|    |    | 8.3    | Signal    | definition and instantiation           |    |
|    |    |        | 8.3.1     | Semantics                              |    |
|    |    |        | 8.3.2     | Example                                |    |
| 30 | 9. | Field  | compor    | nent                                   |    |
|    |    | 9.1    | Introdu   | iction                                 |    |
|    |    | 9.2    | Definin   | ng and instantiating fields            |    |
|    |    | 9.3    | Using f   | field instances                        |    |
| 35 |    | 9.4    | Field a   | ccess properties                       |    |
|    |    |        | 9.4.1     | Semantics                              |    |
|    |    |        | 9.4.2     | Example                                |    |
|    |    | 9.5    | Hardwa    | are signal properties                  |    |
| 10 |    |        | 9.5.1     | Semantics                              |    |
| 40 |    |        | 9.5.2     | Example                                |    |
|    |    | 9.6    | Softwa    | re access properties                   |    |
|    |    |        | 9.6.1     | Semantics                              |    |
|    |    | ~ -    | 9.6.2     | Examples                               |    |
| 15 |    | 9.7    | Hardwa    | are access properties                  |    |
| 43 |    |        | 9.7.1     | Semantics                              |    |
|    |    | 0.0    | 9.7.2     | Example                                |    |
|    |    | 9.8    | Counte    | r properties                           |    |
|    |    |        | 9.8.1     | Counter incrementing and decrementing  |    |
| 50 |    | 0.0    | 9.8.2     | Counter saturation and threshold       |    |
| 50 |    | 9.9    | Interrup  | pt properties                          |    |
|    |    |        | 9.9.1     | Semantics                              |    |
|    |    | 0.10   | 9.9.2     | Example                                |    |
|    |    | 9.10   | Miscell   | sancous field properties               |    |
| 55 |    |        | 9.10.1    | Semanucs                               |    |
| 55 |    |        | 9.10.2    | Ехаприе                                |    |

| 10. | Regist         | ter component                                  | 65 1   |
|-----|----------------|------------------------------------------------|--------|
|     | 10.1           | Defining and instantiating registers           | 65     |
|     | 10.2           | Instantiating registers                        | 65     |
|     | 10.3           | Instantiating internal registers               | 66 5   |
|     | 10.4           | Instantiating external registers               | 66     |
|     | 10.5           | Instantiating alias registers                  | 67     |
|     |                | 10.5.1 Semantics                               | 67     |
|     |                | 10.5.2 Example                                 | 67 10  |
|     | 10.6           | Register properties                            | 68     |
|     |                | 10.6.1 Semantics                               | 68     |
|     |                | 10.6.2 Example                                 | 68     |
|     | 10.7           | Understanding field ordering in registers      | 69     |
|     | 1017           | 10.7.1 Semantics                               | 69 15  |
|     |                | 10.7.2 Fxamples                                | 69     |
|     | 10.8           | Understanding interrunt registers              | 70     |
|     | 10.0           | 10.8.1 Semantics                               | 70     |
|     |                | 10.8.2 Example                                 | 70     |
|     |                | 10.8.2 Example                                 | 20     |
| 11. | Memo           | ory component                                  | .71    |
|     | 11.1           | Defining and instantiating memories            | 71     |
|     | 11.2           | Semantics                                      | 71     |
|     | 11.3           | Memory properties                              | 72 25  |
|     | 1110           | 11.3.1 Semantics                               | 72     |
|     |                | 1132 Fxample                                   | 72     |
|     |                |                                                | 12     |
| 12. | Regist         | ter file component                             | 73     |
|     | 12.1           | Defining and instantiating register files      | 73     |
|     | 12.2           | Semantics                                      | 74     |
|     | 12.3           | Register file properties                       | 74     |
|     |                | 12.3.1 Semantics                               | 74     |
|     |                | 12.3.2 Example                                 | 75 35  |
| 13  | ۸ ddre         | r<br>Pris man component                        | 77     |
| 15. | Audic          |                                                |        |
|     | 13.1           | Introduction                                   | 77     |
|     | 13.2           | Defining and instantiating address maps        | .77 40 |
|     | 13.3           | Semantics                                      | 77     |
|     | 13.4           | Address map properties                         | 77     |
|     |                | 13.4.1 Semantics                               | 78     |
|     |                | 13.4.2 Example                                 | 79     |
|     | 13.5           | Defining bridges or multiple view address maps | 79 45  |
|     |                | 13.5.1 Semantics                               | 79     |
|     |                | 13.5.2 Example                                 | 79     |
| 1.4 | <b>T</b> T : C |                                                | 0.1    |
| 14. | Verifi         | ication constructs                             | 50     |
|     | 14.1           | HDL path                                       | 81     |
|     |                | 14.1.1 Assigning HDL path                      | 81     |
|     |                | 14.1.2 Examples                                | 82     |
|     | 14.2           | Constraints                                    | 83     |
|     |                | 14.2.1 Describing constraints                  | 83 55  |

# Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change.

ix

| 1  |         | 14.2.2 Constraint component                                         |     |
|----|---------|---------------------------------------------------------------------|-----|
|    |         | 14.2.3 Example                                                      | 85  |
|    | 15. Use | er-defined properties                                               |     |
| 5  | 15      | 1 Defining and a second                                             | 97  |
|    | 15.     | 1 Defining user-defined properties                                  |     |
|    |         | 15.1.1 Semanues                                                     |     |
| 10 | 15      | <ol> <li>Assigning (and hinding) user-defined properties</li> </ol> |     |
| 10 | 10      | 15.2.1 Semantics                                                    |     |
|    |         | 15.2.2 Examples                                                     |     |
|    | 16. Pre | processor directives                                                |     |
| 15 |         | •<br>• • • • • • • • • • • •                                        |     |
|    | 16.     | 1 Embedded Perl preprocessing                                       |     |
|    |         | 16.1.1 Semantics                                                    |     |
|    | 1.6     | 16.1.2 Example                                                      |     |
| 20 | 16.     | 2 Verilog-style preprocessor                                        |     |
| 20 |         | 16.2.1 Verilog-style preprocessor directives                        |     |
|    |         | 16.2.2 Limitations on hested file inclusion                         |     |
|    | 17. Adv | vanced topics in SystemRDL                                          |     |
| 25 | 17.     | 1 Application of signals for reset                                  |     |
|    | 17.     | 2 Understanding hierarchical interrupts in SystemRDL                |     |
|    |         | 17.2.1 Example structure and perspective                            |     |
|    |         | 17.2.2 Code snippet 1                                               |     |
|    |         | 17.2.3 Code snippet 2                                               |     |
| 30 |         | 17.2.4 Code snippet 3                                               |     |
|    |         | 17.2.5 Code snippet 4                                               |     |
|    |         | 17.2.6 Code snippet 5                                               |     |
|    |         | 17.2.7 Code snippet 6                                               |     |
| 25 |         | 17.2.8 Code snippet 7                                               |     |
| 33 |         | 17.2.9 Code snippet 8                                               | 101 |
|    |         | 17.2.10 Code snippet 9                                              |     |
|    |         | 17.2.11 Code snippet 10                                             |     |
|    | 17      | 1/.2.12 Code snippet 11                                             |     |
| 40 | 1/      | 17.3.1 Bit ordering                                                 |     |
|    |         | 17.3.2 Byte ordering                                                |     |
|    | Annex A | (informative) Bibliography                                          | 107 |
|    |         | (informative) Dionography                                           |     |
| 45 | Annex B | (normative) Grammar                                                 | 109 |
|    | Annex C | (informative) Backward compatibility                                | 115 |
| 50 | Annex D | (normative) Reserved words                                          |     |
| 50 | Annex E | (normative) Access modes                                            | 121 |
|    | Annex F | (informative) Formatting text strings                               | 129 |
| 55 | Annex G | (informative) Component-property relationships                      | 133 |

10

15

20

# SystemRDL v2.0: A Register Description Language Specification

# 1. Overview

This clause explains the scope and purpose of this standard, describes the key features, details the conventions used, and summarizes its contents.

 The formal syntax of SystemRDL is described using Backus-Naur Form (BNF), which is summarized in
 25

 <u>Annex B</u>. The rest of this Standard is intended to be consistent with the SystemRDL grammar. If any discrepancies between the two occur, the grammar in <u>Annex B</u> shall take precedence.
 25

#### 1.1 Scope

SystemRDL is a language for the design and delivery of intellectual property (IP) products used in designs. SystemRDL semantics supports the entire life-cycle of registers from specification, model generation, and design verification to maintenance and documentation. Registers are not just limited to traditional configuration registers, but can also refer to register arrays and memories.

The intent of this standard is to define SystemRDL accurately. Its primary audience are implementers of tools supporting the language and users of the language. The focus is on defining the valid language constructs, their meanings and implications for the hardware and software that is specified or configured, how compliant tools are required to behave, and how to use the language.

### 1.2 Purpose

SystemRDL is designed to increase productivity, quality, and reuse during the design and development of complex digital systems. It can be used to share IP within and between groups, companies, and consortiums. This is accomplished by specifying a single source for the register description from which all views can be automatically generated, which ensures consistency between multiple views. A *view* is any output generated from the SystemRDL description, e.g., RTL code or documentation.

50

55

#### 1.3 Motivation

SystemRDL was created to minimize problems encountered in describing and managing registers. Typically in a traditional environment the system architect or hardware designer creates a functional specification of the registers in a design. This functional specification is most often text and lacks any formal syntactic or

#### 1

30

35

40

- 1 semantic rules. This specification is then used by other members of the team including software, hardware, and design verification. Each of these parties uses the specification to create representations of the data in the languages which they use in their aspect of the chip development process. These languages typically include Verilog, VHDL, C, C++, Vera, *e*, and SystemVerilog. Once the engineering team has an implementation in a HDL and some structures for design verification, then design verification and software development can begin.
- During these verification and validation processes, bugs are often encountered which require the original register specification to change. When these changes occur, all the downstream views of this data have to be updated accordingly. This process is typically repeated numerous times during chip development. In addition to the normal debug cycle, there are two additional aspects that can cause changes to the register specification. First, marketing requirements can change, which require changes to a register's specification. Second, physical aspects, such as area and timing constraints can drive changes to the register's specification. There are clearly a number of challenges with this approach:
  - a) The same information is being replicated in many locations by many individuals.
  - b) Propagating the changes to downstream customers is tedious, time-consuming, and error-prone.
  - c) Documentation updates are often postponed until late in the development cycle due to pressures to complete other more critical engineering items at hand.

These challenges often result in a low-quality product and wasted time due to having incompatible register views. SystemRDL was designed to eliminate these problems by defining a rich language that can formally describe register specifications. Through application of SystemRDL and a SystemRDL compiler, users can save time and eliminate errors by using a single source of specification and automatically generating any needed downstream views.

#### 1.4 Backward compatibility

One of the main goals for this update to the SystemRDL specification was to maintain backward compatibility to SystemRDL 1.0. In some cases, however, this was not possible. <u>Annex C</u> shows the known areas of incompatibility in advancing the SystemRDL specification from the SystemRDL1.0 to SystemRDL 2.0 versions.

#### 1.5 Conventions used

The conventions used throughout the document are included here.

#### 40 **1.5.1 Visual cues (meta-syntax)**

The meta-syntax for the description of the syntax rules uses the conventions shown in Table 1.

#### 45

50

55

20

25

30

35

#### Table 1—Document conventions

| Visual cue | Represents                                                                                                                                                                                                                                                                                             |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bold       | The <b>bold</b> font is used to indicate key terms, text that shall be typed exactly as it appears.<br>For example, in the following property definition, the keyword "default" and special char-<br>acter ":" (and optionally "=") shall be typed as they appear:<br>default property_name [= value]; |
| italic     | The <i>italic</i> font in running text represents user-defined variables. For example, a property name needs to be specified in the following line (after the "default" key term):<br><b>default</b> property_name [= value];                                                                          |

|  | -1 |  |
|--|----|--|
|  |    |  |
|  |    |  |
|  |    |  |
|  |    |  |

30

35

40

50

55

| Visual cue         | Represents                                                                                                                                                                                                                                           |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| courier            | The courier font in running text indicates SystemRDL or HDL code. For example, the following line indicates SystemRDL code:                                                                                                                          |
|                    | field myField {}; // defines a field type named "myField"                                                                                                                                                                                            |
| plain text         | The <u>normal</u> or <u>plain text</u> font in the BNF indicates syntactic categories (see <u>Annex B</u> ).                                                                                                                                         |
| [] square brackets | Square brackets indicate optional parameters. For example, the value assignment is optional in the following line:<br>default property_name [= value];                                                                                               |
| { } curly braces   | Curly braces ({ }) indicate items that can be repeated zero or more times. For example, the following shows one or more universal properties can be specified for this command:<br><i>mnemonic_name = value</i> [{{ <i>universal_property</i> ;}*}]; |
| * asterisk         | An asterisk (*) signifies that parameter can be repeated. For example, the following line means multiple properties can be specified for this command:<br><b>field</b> {[ <i>property</i> ;]*} <i>name</i> = <i>unsizedNumeric</i> ;                 |
| separator bar      | The separator bar ( ) character indicates alternative choices. For example, the following line shows the "in" or "out" key terms are possible values for the "-direction" parameter:<br>-direction <in out=""  =""></in>                             |

Table 1—Document conventions (Continued)

1.5.2 Notational conventions

The terms "required", "shall", "shall not", "should", "should not", "recommended", "may", and "optional" in this document are to be interpreted as described in the IETF Best Practices Document 14, RFC 2119.<sup>1</sup>

### 1.5.3 Examples

Any examples shown in this Standard are for information only and are only intended to illustrate the use of SystemRDL.

# 1.6 Use of color in this standard

This standard uses a minimal amount of color to enhance readability. The coloring is not essential and does not affect the accuracy of this standard when viewed in pure black and white. The places where color is used are the following:

- Cross references that are hyperlinked to other portions of this standard are shown in <u>underlined-blue</u> text (hyperlinking works when this standard is viewed interactively as a PDF file).
- Syntactic keywords and tokens in the formal language definitions are shown in **boldface-red text** 45 when initially defined.

# 1.7 Contents of this standard

The organization of the remainder of this standard is as follows:

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

35

40

45

50

55

4

| 1  | _ | <u>Clause 2</u> provides references to other applicable standards that are assumed or required for this standard.   |
|----|---|---------------------------------------------------------------------------------------------------------------------|
| ~  | — | <u>Clause 3</u> defines terms and acronyms used throughout the different specifications contained in this standard. |
| 3  | _ | Clause 4 defines the lexical conventions used in SystemRDL.                                                         |
|    |   | Clause 5 highlights the general concepts, rules, and properties in SystemRDL.                                       |
|    | — | Clause 6 defines the SystemRDL data types.                                                                          |
| 10 |   | Clause 7 describes how expressions are used in SystemRDL.                                                           |
|    |   | Clause 8 describes how signals are used in SystemRDL.                                                               |
|    |   | <u>Clause 9</u> defines the field components.                                                                       |
|    |   | <u>Clause 10</u> defines the register components.                                                                   |
| 15 | — | Clause 11 defines the memory components.                                                                            |
|    |   | Clause 12 defines the register file components.                                                                     |
|    |   | Clause 13 defines the address map components.                                                                       |
|    |   | <u>Clause 14</u> specifies the verification constructs.                                                             |
| 20 |   | Clause 15 specifies the user-defined properties.                                                                    |
|    | — | <u>Clause 16</u> defines the preprocessor directives.                                                               |
|    | — | Clause 17 describes advanced uses of SystemRDL.                                                                     |
|    | — | Annexes. Following <u>Clause 17</u> are a series of annexes.                                                        |
| 25 |   |                                                                                                                     |
|    |   |                                                                                                                     |

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change.

| 2. References                                                                                                                                                                                                                                                            | 1  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 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. | 5  |
| IEEE Std 1364 <sup>™</sup> , IEEE Standard for Verilog Hardware Description Language. <sup>2, 3</sup>                                                                                                                                                                    |    |
| IEEE Std 1685 <sup>™</sup> , IEEE Standard for IP-XACT, Standard Structure for Packaging, Integrating, and Reusing IP within Tool Flows.                                                                                                                                 | 10 |
| IEEE Std 1800 <sup>™</sup> , IEEE Standard for SystemVerilog Unified Hardware Design, Specification and Verifica-<br>tion Language.                                                                                                                                      | 15 |
| IEEE Std 1800.2 <sup>™</sup> , IEEE Standard for Universal Verification Methodology Language Reference Manual.                                                                                                                                                           | 10 |
| IETF Best Practices Document 14, RFC 2119.                                                                                                                                                                                                                               |    |
| The Apache ASP Embedding Syntax is available from the Apache web site: <u>http://www.apache-asp.org/syntax.html</u> .                                                                                                                                                    | 20 |
| The HTML 4.01 standard syntax is available from the W3 web site: <u>http://www.w3.org/TR/html401/</u> .                                                                                                                                                                  | 25 |
| The MD5 Message-Digest Algorithm is available from the IETF web site: <u>https://tools.ietf.org/html/rfc1321</u> .                                                                                                                                                       | 23 |
| The Perl programming language, Version 5, is available from the Perl web site: <u>http://www.perl.org/</u> .                                                                                                                                                             | 30 |
| The Unicode Standard, Version 9.0.0, is available from The Unicode Consortium web site: <u>http://www.unicode.org/versions/Unicode9.0.0/</u> .                                                                                                                           |    |
|                                                                                                                                                                                                                                                                          | 35 |

45

50

<sup>&</sup>lt;sup>2</sup>The IEEE standards or products referred to in this clause are trademarks of the Institute of Electrical and Electronics Engineers, Inc. <sup>3</sup>IEEE publications are available from the Institute of Electrical and Electronics Engineers, Inc., 445 Hoes Lane, Piscataway, NJ 08854, USA (http://standards.ieee.org/).

| 1  |  |  |  |  |
|----|--|--|--|--|
| 5  |  |  |  |  |
| 10 |  |  |  |  |
| 15 |  |  |  |  |
| 20 |  |  |  |  |
| 25 |  |  |  |  |
| 30 |  |  |  |  |
| 35 |  |  |  |  |
| 40 |  |  |  |  |
| 45 |  |  |  |  |
| 50 |  |  |  |  |
| 55 |  |  |  |  |

| 3. Definitions, acronyms, and abbreviations                                                                                                                                                                                                                                | 1  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| For the purposes of this document, the following terms and definitions apply. <i>The Authoritative Dictionary of IEEE Standards Terms</i> [B1] <sup>4</sup> should be referenced for terms not defined in this clause.                                                     | 5  |
| 3.1 Definitions                                                                                                                                                                                                                                                            |    |
| <b>address map</b> : Defines the organization of the <b>register</b> s, <b>register file</b> s, memories, and address maps into a software addressable space. Address maps can be organized hierarchically.                                                                | 10 |
| <b>byte order</b> : The ordering of the bytes from left to right or right to left or from most significant byte to least significant byte or least significant byte to most significant byte. This is often referred to as <i>endianness</i> . See also <u>Clause 17</u> . | 15 |
| <b>bit order</b> : The ordering of the bits from left to right or right to left or from most significant bit to least significant bit or least significant bit to most significant bit. See also <u>Clause 17</u> .                                                        |    |
| <b>component</b> : A basic building block in SystemRDL that acts as a container for information. Similar to a <i>struct</i> or <i>class</i> in programming languages.                                                                                                      | 20 |
| constraint: An assertion made for verification purposes that is evaluated at the runtime of the design.                                                                                                                                                                    |    |
| element: An instantiation of any SystemRDL component type.                                                                                                                                                                                                                 | 25 |
| <b>enumeration</b> : Used in field encodings and component property encodings. An identifier bound to some bit value or a list of values describing bit field encoding or component property encoding.                                                                     |    |
| field: The most basic component object. Fields serve as an abstraction of hardware storage elements.                                                                                                                                                                       | 30 |
| <b>keyword</b> : A predefined, non-escaped identifier (see $4.3$ ) that defines a language construct; keywords cannot be used as identifiers.                                                                                                                              |    |
| <b>memory</b> : A contiguous array of memory data elements. A data structure within a memory can be specified with virtual registers or register files.                                                                                                                    | 35 |
| <b>parameter</b> : A generalized value of a <b>component</b> definition that can be modified for each instance of the component.                                                                                                                                           | 40 |
| <b>property</b> : A characteristic, attribute, or a trait of a <b>component</b> in SystemRDL. Because they exist in their own namespace, property names do not conflict with the language and are not restricted as identifiers.                                           | τu |
| <b>RDLFormatCode</b> : A set of formatting tags which can be used on text strings.                                                                                                                                                                                         | 45 |
| register: A set of one or more fields which are accessible by software at a particular address.                                                                                                                                                                            | 15 |
| register file: A grouping of registers and other register files. Register files can be organized hierarchically.                                                                                                                                                           |    |
| <b>reserved words</b> : terms which have a similar effect to <b>keywords</b> ; all reserved words are explicitly reserved for future use.                                                                                                                                  | 50 |

<sup>&</sup>lt;sup>4</sup>The number in brackets correspond to those of the bibliography in <u>Annex A</u>.

1 signal: A wire used for interconnect or to define additional component inputs and/or outputs.

struct: User-defined structure for use in user-defined properties. See also <u>Clause 15</u>.

10 15

5

- 3.2 Acronyms and abbreviations
  - HDL hardware description language
- HTML hypertext markup language
  - IP intellectual property
  - LSB least significant bit
    - MSB most significant bit
    - RTL register transfer level

20

25

30

35

40

45

50

55

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change.

| 4. Lexical conventions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| This clause describes SystemRDL in terms of lexical conventions. SystemRDL source code is comprised of a stream of lexical tokens consisting of one or more characters. SystemRDL files shall use the Universal Coded Character Set, UCS, encoded using UTF-8. UCS code points beyond the ASCII code page are restricted to comments and character strings. SystemRDL is case-sensitive. SystemRDL identifiers are limited to ASCII letters, numbers, and the underscore ( ). The support for UTF-8 is limited to strings to | 5  |
| allow for non-English documentation. SystemRDL compilers shall ignore the byte-order mark.                                                                                                                                                                                                                                                                                                                                                                                                                                   | 10 |
| 4.1 White space                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |
| White space characters are: space (U+0020), horizontal tab (U+0009), line feed (U+000A), and carriage return (U+000D). All white space characters are syntactically insignificant, except in the following cases.                                                                                                                                                                                                                                                                                                            | 15 |
| a) Strings—Any number of consecutive white space characters is treated as a single space for purposes of generating documentation. See <u>4.5</u> .                                                                                                                                                                                                                                                                                                                                                                          |    |
| b) Single-line comments—A new-line character ( <i>line feed</i> , <i>carriage return</i> , or <i>line feed</i> plus <i>carriage return</i> ) terminates a single-line comment. See <u>4.2</u> .                                                                                                                                                                                                                                                                                                                              | 20 |
| c) Where more than one token is being used and spacing is required to separate the tokens.                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
| 4.2 Comments                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |
| There are two types of comments in SystemRDL: single-line comments and block comments. <i>Single-line comments</i> begin with // and are terminated by a new-line character. <i>Block comments</i> begin with /* and are terminated by the next */. Block comments may span any number of lines; they shall not be nested. Within a block comment, a single-line comment (//) has no significance.                                                                                                                           | 25 |
| Examples                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 30 |
| // single line comment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |
| Block                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 35 |
| // This is part of this Block comment                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 40 |
| 4.3 Identifiers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |
| An <i>identifier</i> assigns a name to a user-defined data type or its instance. There are two types of identifiers: simple and escaped. Identifiers are case-sensitive. <i>Simple identifiers</i> have a first character that is a letter or underscore () followed by zero or more letters, digits, and underscores. <i>Escaped identifiers</i> begin with ( followed by a simple identifier.                                                                                                                              | 45 |

Examples

```
50
my_identifier
My_IdEnTiFiEr
х
_y0123
_3
                                                                                       55
\field // This is escaped because it uses a keyword
```

### 1 **4.4 Keywords**

5

30

35

40

45

*Keywords* are predefined, non-escaped identifiers (see 4.3) that define language constructs. Keywords cannot be used as identifiers. Escaped keywords are treated as identifiers in SystemRDL. The keywords are listed in Table 2.

|    |             | Table 2-       | —SystemRDL key | ywords    |            |
|----|-------------|----------------|----------------|-----------|------------|
| 10 | abstract    | accesstype     | addressingtype | addrmap   | alias      |
| 10 | all         | bit            | boolean        | bothedge  | compact    |
|    | component   | componentwidth | constraint     | default   | enum       |
|    | external    | false          | field          | fullalign | hw         |
| 15 | inside      | internal       | level          | longint   | mem        |
|    | na          | negedge        | nonsticky      | number    | onreadtype |
|    | onwritetype | posedge        | property       | r         | rclr       |
| 20 | ref         | reg            | regalign       | regfile   | rset       |
|    | ruser       | rw             | rw1            | signal    | string     |
|    | struct      | SW             | this           | true      | type       |
| 25 | unsigned    | w              | w1             | wclr      | woclr      |
|    | woset       | wot            | wr             | wset      | wuser      |
|    | wzc         | wzs            | wzt            |           |            |

The following also apply.

- *Reserved words* have a similar effect as *keywords*; reserved words are explicitly reserved for future use. See also <u>Annex D</u>.
- The SystemRDL-detailed access modes are defined in <u>Annex E</u>.
- Right-hand side values defined in this standard are *keywords*. See also <u>Annex G</u>.
  - Left-hand side values that are not keywords are properties. See also <u>Annex G</u>.
  - Because they exist in their own namespace, *property names* do not conflict with the language and are not restricted as identifiers.

#### 4.5 Strings

A *string* is a sequence of characters enclosed by double quotes. The escape sequence " can be used to include a double quote within a string. To maintain consistency between all generated documentation formats, one or more consecutive white space characters within a string shall be converted to a single space for purposes of documentation generation. SystemRDL also has a set of formatting tags which can be used on text strings, see <u>Annex F</u>.

50 Examples

```
"This is a string"
"This is also
a string!"
55
"This third string contains a \"double quote\""
```

| 4.6 N                                     | lumbers                                                                                                                                                                                                                                                                                                                                                                        | 1  |
|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| There                                     | are several number formats in SystemRDL. All numbers in SystemRDL are unsigned.                                                                                                                                                                                                                                                                                                |    |
| a)                                        | Simple decimal: A sequence of decimal digits 0,, 9.                                                                                                                                                                                                                                                                                                                            | -  |
| b)                                        | Simple hexadecimal: $0x$ (or $0X$ ) followed by a sequence of decimal digits or characters a through f (upper- or lower-case).                                                                                                                                                                                                                                                 | 5  |
| c)                                        | <b>Verilog-style decimal</b> : Begins with a <i>width</i> specifying the number of binary bits (a positive decimal number) followed by a single quote ('), followed by a <b>d</b> or <b>D</b> for decimal, and then the number itself, represented as a sequence of digits 0 through 9.                                                                                        | 10 |
| d)                                        | <b>Verilog-style hexadecimal</b> : Begins with a <i>width</i> specifying the number of binary bits (a positive decimal number) followed by a single quote ('), followed by an <b>h</b> or <b>H</b> for hexadecimal), and then the number itself, represented as a sequence of digits <b>0</b> through <b>9</b> or characters <b>a</b> through <b>f</b> (upper- or lower-case). | 15 |
| e)                                        | <b>Verilog-style binary</b> : Begins with a <i>width</i> specifying the number of binary bits (a positive decimal number) followed by a single quote ('), followed by a <b>b</b> or <b>B</b> for binary, and then the number itself, represented as a sequence of the digits <b>0</b> and <b>1</b> .                                                                           |    |
| The n<br>and fi<br><i>width</i><br>not su | umeric portion of any number may contain multiple underscores (_) at any position, except the <i>width</i> rst position, which are ignored in the computation of the associated numeric value. Additionally the of a Verilog number needs to be specified. Ambiguous <i>width</i> Verilog-style numbers, e.g., 'hFF, are apported.                                             | 20 |
| It shal                                   | ll be an error if the value of a Verilog-style number does not fit within the specified bit-width.                                                                                                                                                                                                                                                                             | 25 |
| Exam                                      | ples                                                                                                                                                                                                                                                                                                                                                                           |    |
|                                           | <pre>40 // Simple decimal example<br/>0x45 // Simple hexadecimal example<br/>4'd1 // Verilog style decimal example (4 bits)<br/>3'b101 // Verilog style binary example (3 bits)<br/>32'bDE AD BE EE // Verilog style with 's</pre>                                                                                                                                             | 30 |

| 32'NDE_AD_BE_EF // Verilog style with _'s   |    |
|---------------------------------------------|----|
| 32'hdeadbeef // Same as above               |    |
| 7'h7f // Verilog style hex example (7 bits) | 35 |

45

50

55

| 1  |  |  |  |
|----|--|--|--|
| 5  |  |  |  |
| 10 |  |  |  |
| 15 |  |  |  |
| 20 |  |  |  |
| 25 |  |  |  |
| 30 |  |  |  |
| 35 |  |  |  |
| 40 |  |  |  |
| 45 |  |  |  |
| 50 |  |  |  |
| 55 |  |  |  |

| 5. General conce                                                                                                                                                                                                                                                                                                                           | epts, rules, and propertie                                                                               | s                                                                                                            |                                                 | 1  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|-------------------------------------------------|----|
| The concepts, rules, and properties described in this clause are common to all component types and do not determine how a component is implemented in a design.                                                                                                                                                                            |                                                                                                          | onent types and do not                                                                                       | 5                                               |    |
| 5.1 Key concepts                                                                                                                                                                                                                                                                                                                           | and general rules                                                                                        |                                                                                                              |                                                 |    |
| This subclause describe<br>language to define ha<br>component type.                                                                                                                                                                                                                                                                        | es the key concepts of SystemRDL rdware specifications. Subsequent                                       | and documents general rul<br>clauses will refine these                                                       | es about how to use the generic rules for each  | 10 |
| A <i>component</i> in SystemRDL is the basic building block or a container which contains properties that further describe the component's behavior. There are several structural components in SystemRDL: field, reg, mem, regfile, and addrmap. Additionally, there are several non-structural components: signal, enum, and constraint. |                                                                                                          | s properties that further<br>ystemRDL: <b>field</b> , <b>reg</b> ,<br>nts: <b>signal</b> , <b>enum</b> , and | 15                                              |    |
| Components can be defined in any order, as long as each component is defined before it is instantiated. All structural components (and signals) need to be instantiated before being generated.                                                                                                                                            |                                                                                                          | re it is instantiated. All                                                                                   | 20                                              |    |
| 5.1.1 Defining comp                                                                                                                                                                                                                                                                                                                        | oonents                                                                                                  |                                                                                                              |                                                 |    |
| To define components<br>to the component object<br>can be instantiated (see                                                                                                                                                                                                                                                                | in SystemRDL, each <i>definition state</i><br>of being defined (as listed in <u>Table 3</u><br>(5.1.2)). | <i>ement</i> shall begin with the l<br><u>3</u> ). All components need to                                    | keyword corresponding<br>be defined before they | 25 |
|                                                                                                                                                                                                                                                                                                                                            | Table 3—Compor                                                                                           | nent types                                                                                                   |                                                 |    |
|                                                                                                                                                                                                                                                                                                                                            | Туре                                                                                                     | Keyword                                                                                                      |                                                 | 30 |
|                                                                                                                                                                                                                                                                                                                                            | Field                                                                                                    | field                                                                                                        |                                                 |    |

reg

regfile

signal

enum

mem

constraint

addrmap

SystemRDL components can be defined in two ways: definitively or anonymously.

- *Definitive* defines a named component type, which is instantiated in a separate statement. The definitive definition is suitable for reuse.
- Anonymous defines an unnamed component type, which is instantiated in the same statement (see also <u>5.1.2</u>). The anonymous definition is suitable for components that are used once.

A *definitive definition* of a component appears as follows.

Register

Signal

Memory

Constraint

Register file

Address map

Enumeration

component new\_component\_name [#(parameter\_definition [, parameter\_definition]\*)]
{[component\_body]} [instance\_element [, instance\_element]\*];

An anonymous definition (and instantiation) of a component appears as follows.

13

35

40

45

50

| 1  | <pre>component {[component_body]} instance_element [, instance_element]*;</pre>                                                                                                                                                                                                                  |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | a) In both cases, <i>component</i> is one of the keywords specified in <u>Table 3</u> .                                                                                                                                                                                                          |
| 5  | b) For a definitively defined component, <i>new_component_name</i> is the user-specified name for th component.                                                                                                                                                                                  |
| C  | c) For a definitively defined component, <i>parameter_definition</i> is the user-specified parameter a defined in <u>5.1.1.1</u> .                                                                                                                                                               |
| 10 | d) For a anonymously defined component, <i>instance_element</i> is the description of the instantiation attributes, as defined in $5.1.2 \text{ a } 3$ .                                                                                                                                         |
|    | e) The <i>component_body</i> is comprised of zero or more of the following.                                                                                                                                                                                                                      |
|    | 1) Default property assignments                                                                                                                                                                                                                                                                  |
|    | 2) Property assignments                                                                                                                                                                                                                                                                          |
| 15 | 3) Component instantiations                                                                                                                                                                                                                                                                      |
|    | 4) Nested component definitions                                                                                                                                                                                                                                                                  |
|    | 5) Constraint definitions                                                                                                                                                                                                                                                                        |
| 20 | 6) Struct definitions                                                                                                                                                                                                                                                                            |
| 20 | f) The first instance name of an anonymous definition is also used as the component type name.                                                                                                                                                                                                   |
|    | g) The stride (+=), alignment (%), and offset (@) of anonymous instances are the same as the definitive instances in <u>5.1.2.3</u> .                                                                                                                                                            |
| 25 | The following code fragment shows a simple definitive <b>field</b> component definition for myField.                                                                                                                                                                                             |
|    | <pre>field myField {};</pre>                                                                                                                                                                                                                                                                     |
| 30 | The following code fragment shows a simple anonymous <b>field</b> component definition for myField.                                                                                                                                                                                              |
|    | <pre>field {} myField;</pre>                                                                                                                                                                                                                                                                     |
|    | 5.1.1.1 Defining component parameters                                                                                                                                                                                                                                                            |
| 35 | All definitive component types, except enumerations and constraints, may be parametrized using Verilog style parameters. To define Verilog-style parameters in SystemRDL, parameter definitions shall be specifie after the component's name. <i>parameter_definition</i> is defined as follows. |
|    | parameter_type parameter_name [= parameter_value]                                                                                                                                                                                                                                                |
| 40 | where                                                                                                                                                                                                                                                                                            |
|    | a) <i>narameter, type</i> is a type reference taken from the list of SystemRDI, types (see Table 7)                                                                                                                                                                                              |
|    | <ul> <li>b) parameter name is a user-specified parameter name</li> </ul>                                                                                                                                                                                                                         |
|    | <ul> <li>c) parameter value is a expression whose resolved type should be consistent with parameter type.</li> </ul>                                                                                                                                                                             |
| 45 |                                                                                                                                                                                                                                                                                                  |
|    | 5.1.1.2 Semantics                                                                                                                                                                                                                                                                                |
| 50 | a) If a parameter definition is assigned a parameter value, that value is the default value for the parameter.                                                                                                                                                                                   |
| 50 | b) If a parameter is not specified with a default value, every instance of the component needs to provid a value for the parameter.                                                                                                                                                              |
|    | c) The name of the parameter may be used elsewhere within the remainder of the component definitio to represent its value.                                                                                                                                                                       |
| 55 | d) Nested component definitions do not inherit from their parent's parameters.                                                                                                                                                                                                                   |

e)

1

|                                                                   | agg                                                 | regat                                            | e type).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |
|-------------------------------------------------------------------|-----------------------------------------------------|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 5.1.1.                                                            | 3 Ins                                               | ertir                                            | ng parameterized types in the type namespace                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 5  |
| Each d<br>declara<br>new ty<br>compo<br>resolve<br>names<br>name. | leclar<br>ation.<br>ype n<br>onent<br>ed pa<br>pace | red co<br>In a<br>ame<br>decla<br>aramo<br>of co | imponent's type name is added to the type namespace of the enclosing scope of component<br>ddition, instances of parameterized components which have parameter overrides create a<br>based on the parameterized component type name rules in the type namespace of the<br>aration enclosing scope. Subsequent instances of parameterized components with the same<br>eter values matching those of a component instance existing type name in the type<br>mponent declaration enclosing shall reuse the existing type name without adding a new type | 10 |
| It shall<br>name t<br>matche                                      | l be a<br>that c<br>es any                          | orres<br>orres                                   | or if a parameterized component instance has a type name which matches an existing type<br>ponds to a parameterized component instance with different resolved parameter values or<br>er type name.                                                                                                                                                                                                                                                                                                                                                  | 15 |
| 5.1.1.4                                                           | 4 Ge                                                | nera                                             | ted type naming rules                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 20 |
| Most g<br>instanc<br>genera                                       | gener<br>ce typ<br>tion j                           | ation<br>bes. T<br>proce                         | targets for elaborated SystemRDL platforms require some means of uniquely identifying<br>o provide a minimum level of compatibility between tool outputs, defining the type name<br>ss is necessary.                                                                                                                                                                                                                                                                                                                                                 | 20 |
| The for<br>argum                                                  | ollow<br>ents.                                      | ing s                                            | teps shall be used to construct the elaborated type names of instance with parameter                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 25 |
| a)                                                                | If tl<br>nan                                        | ne in<br>ne sha                                  | stance's defined arguments match the type's default parameter values, the instance's type all be used as is.                                                                                                                                                                                                                                                                                                                                                                                                                                         |    |
| b)                                                                | If th<br>eter                                       | ne ins<br><sup>,</sup> valu                      | tance's type is parameterized and all the defined arguments match the type's default param-<br>es, the instance's type name shall be used as is.                                                                                                                                                                                                                                                                                                                                                                                                     | 30 |
| c)                                                                | In a<br>inst<br>by a                                | all ot<br>ance <sup>s</sup><br>a sing            | her cases, the instance's generated type name shall be constructed by appending to the s type name and, for each argument its name, followed by its normalized value, separated ele underscore (_). The sequences shall also be joined using single underscores.                                                                                                                                                                                                                                                                                     | 25 |
|                                                                   |                                                     | type                                             | e_name{(_param_name_normalized_value)}*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 55 |
|                                                                   | Noı<br>valı                                         | maliz<br>ie as                                   | zed values shall be derived from the argument's type and from its resolved expression's follows.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |
|                                                                   | 1)                                                  | Sca                                              | lar values shall be rendered using their hexadecimal representation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 40 |
|                                                                   | 2)                                                  | Boo                                              | lean values shall be rendered using either t for <b>true</b> or f for <b>false</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 10 |
|                                                                   | 3)                                                  | Stri<br>Alg                                      | ng values shall be rendered using the first eight characters of their md5 (Message-Digest orithm) checksum.                                                                                                                                                                                                                                                                                                                                                                                                                                          |    |
|                                                                   | 4)                                                  | Enu                                              | m values shall be rendered using their enumerator literal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 45 |
|                                                                   | 5)                                                  | Arr                                              | ays shall be rendered by:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 43 |
|                                                                   |                                                     | i)                                               | generating the normalized values of its elements,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |
|                                                                   |                                                     | ii)                                              | joining these elements with single underscores (_) into a single character sequence, and                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |
|                                                                   |                                                     | iii)                                             | using the first eight characters of the md5 checksum of this character sequence                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 50 |
|                                                                   |                                                     |                                                  | which can be semi-formalized as:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |
|                                                                   | 0                                                   | <b>C</b> 4                                       | subsequence( md5( join( normalized_values, '_' ), 0, 8 )                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |
|                                                                   | 6)                                                  | Stru                                             | icts shall be rendered by:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |    |
|                                                                   |                                                     |                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 55 |

Component instance references shall not be used as parameter values (either directly or as part of an

| 1  | i) generating the normalized value of each member,                                                                                                                                                                                                                                                                     |
|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | <ul><li>ii) joining each member's name with its normalized value, separated by a single underscore (_),</li></ul>                                                                                                                                                                                                      |
| 5  | iii) joining the member character sequences with single underscores,                                                                                                                                                                                                                                                   |
|    | iv) using the first eight characters of the md5 checksum of this character sequence                                                                                                                                                                                                                                    |
|    | which can be semi-formalized as:                                                                                                                                                                                                                                                                                       |
| 10 | member_normalization = concat( member_name, '_', normalized_member_value )                                                                                                                                                                                                                                             |
|    | subsequence(md5(join(apply(struct_members, member_normalization)), 0, 8)                                                                                                                                                                                                                                               |
|    | 5.1.2 Instantiating components                                                                                                                                                                                                                                                                                         |
| 15 | In a similar fashion to defining components, SystemRDL components can be instantiated in two ways.                                                                                                                                                                                                                     |
|    | a) A <i>definitively defined component</i> is instantiated in a separate statement, as follows.                                                                                                                                                                                                                        |
|    | type_name [ <mark>#(</mark> parameter_instance [, parameter_instance]*)]<br>instance_element [, instance_element]* ;                                                                                                                                                                                                   |
| 20 | where                                                                                                                                                                                                                                                                                                                  |
|    | 1) <i>type_name</i> is the user-specified name for the component.                                                                                                                                                                                                                                                      |
|    | 2) <i>parameter_instance</i> is specified as                                                                                                                                                                                                                                                                           |
|    | .param_name(param_val)                                                                                                                                                                                                                                                                                                 |
| 25 | where <i>param_name</i> is the name of the parameter defined with the component and <i>param_val</i> is an expression whose result is the value of the parameter for this instance.                                                                                                                                    |
| •  | 3) instance_element is specified as follows.<br>instance_name [{[constant_expression]}*   [constant_expression : constant_expression]]<br>[addr_alloc]                                                                                                                                                                 |
| 30 | i) <i>instance_name</i> is the user-specified name for instantiation of the component.                                                                                                                                                                                                                                 |
|    | ii) <i>constant_expression</i> is an expression that resolves to a longint unsigned.                                                                                                                                                                                                                                   |
| 35 | iii) [ <i>constant_expression</i> ] specifies the size of the instantiated component array (optionally multidimensional) if the component is an <b>addrmap</b> , a <b>regfile</b> , a <b>reg</b> , or a <b>mem</b> ; or the instantiated component's bit width if the component is a <b>field</b> or a <b>signal</b> . |
|    | iv) [ <i>constant_expression</i> : <i>constant_expression</i> ] specifies the bit boundaries of the instanti-<br>ated component. This form of instantiation can only be used for <b>field</b> or <b>signal</b> compo-<br>nents (see <u>Clause 10</u> and <u>Clause 8</u> ).                                            |
| 40 | v) <i>addr_alloc</i> is an address allocation operator (see <u>5.1.2.3</u> ). These operators shall only be used when instantiating <b>addrmap</b> , <b>regfile</b> , <b>reg</b> , or <b>mem</b> components.                                                                                                           |
|    | vi) When using multiple-dimensions, the last subscript increments the fastest.                                                                                                                                                                                                                                         |
|    | b) An <i>anonymously defined component</i> is instantiated in the statement that defines it (see also $5.1.1$ ).                                                                                                                                                                                                       |
| 45 | Components need to be defined before they can be instantiated. In some cases, the order of instantiation impacts the structural implementation, e.g., for the assigning of bit positions of fields in registers (see Clause 6 — Clause 15).                                                                            |
| 50 | The following code fragment shows a simple scalar <b>field</b> component instantiation.                                                                                                                                                                                                                                |
|    | <pre>field {} myField; // single bit field instance named "myField"</pre>                                                                                                                                                                                                                                              |
|    | The following code fragment shows a simple array <b>field</b> component instantiation.                                                                                                                                                                                                                                 |
| 55 | <pre>field {} myField[8]; // 8 bit field instance named "myField"</pre>                                                                                                                                                                                                                                                |

| 5.1.2.1 Specifying instance parameters                                                                                                                                                                                                                                                                                                                                                                                             | 1  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|--|--|--|
| SystemRDL components defined with parameters (see $5.1.1.1$ ) may have those parameters overridden or defined during non-anonymous instantiation.                                                                                                                                                                                                                                                                                  | 5  |  |  |  |
| Parameters are assigned by name, which explicitly links the parameter name and its new value. The name of the parameter shall be the name specified in the instantiated component. It is not necessary to assign values to all of the parameters within a component, only parameters that are assigned new values need to be specified. Parameter values are assigned using Verilog-style syntax, as defined in <u>5.1.2 a 2</u> . |    |  |  |  |
| 5.1.2.1.1 Parameter instance example                                                                                                                                                                                                                                                                                                                                                                                               |    |  |  |  |
| <pre>reg myReg #(longint unsigned SIZE = 32, boolean SHARED = true) {    regwidth = SIZE;    shared = SHARED;    field {} data[SIZE - 1]; }</pre>                                                                                                                                                                                                                                                                                  | 15 |  |  |  |
| <pre>}; addrmap myAmap {     myReg reg32;     myReg reg32_arr[8];     myReg #(.SIZE(16)) reg16;     myReg #(.SIZE(8), .SHARED(false)) reg8; };</pre>                                                                                                                                                                                                                                                                               | 20 |  |  |  |
| 5.1.2.1.2 Parameter dependence                                                                                                                                                                                                                                                                                                                                                                                                     | 25 |  |  |  |
| <ul> <li>a) A parameter (e.g., memory_size) can be defined with an expression containing another parameter (e.g., word_size).</li> <li>b) Overriding a parameter effectively replaces the parameter definition with the new expression.</li> </ul>                                                                                                                                                                                 | 30 |  |  |  |
| c) Parameters are evaluated following the order in which they are defined in the component definition.<br>Because memory_size depends on the value of word_size, a modification of word_size changes the value of memory_size.                                                                                                                                                                                                     |    |  |  |  |
| For example, in the following parameter declaration, an update of word_size in an instantiation statement for the component that defined these parameters automatically updates memory_size. If memory_size is defined in an instantiation statement, however, it will take on that value, regardless of the value of word_size.                                                                                                   | 35 |  |  |  |
| <pre>mem fixed_mem #(longint unsigned word_size = 32,</pre>                                                                                                                                                                                                                                                                                                                                                                        | 40 |  |  |  |

### 5.1.2.2 Instance address allocation

} ;

The offset of an instance within an object is always relative to its parent object. If an instance is not explicitly assigned an address allocation operator (see <u>Table 4</u>), the compiler assigns the address according to the **alignment** (see <u>5.1.2.2.1</u>) and *addressing mode* (see <u>5.1.2.2.2</u>). The address of an instance from the top level addrmap is calculated by adding the instance offset and the offset of all its parent objects.

## 5.1.2.2.1 Instance alignment

The **alignment** property defines the byte value of which the container's instance addresses shall be a multiple. This property can be set for **addrmaps** (see <u>Table 26</u>) and **regfiles** (see <u>Table 25</u>), and its value

17

45

50

shall be a power of two (1, 2, 4, etc.). Its value is inherited by all of the container's non-addrmap children. By default, instantiated objects shall be aligned to a multiple of their width (e.g., the address of a 64-bit register is aligned to the next 8-byte boundary).

#### 5.1.2.2.2 Addressing modes

There are three *addressing modes* defined in SystemRDL: **compact**, **regalign** (the default), and **fullalign**. These addressing modes are set using the **addressing** address map property (see <u>Table 26</u>).

#### a) compact

Specifies the components are packed tightly together while still being aligned to the **accesswidth** parameter (see <u>Table 23</u>).

15 Example 1

1

5

10

20

25

30

35

40

45

Sets accesswidth=32.

```
addrmap some_map {
     accesswidth=32;
     addressing=compact;
     reg { field {} a; } a;
                                          // Address 0
     reg { regwidth=64; field {} a; } b; // Address 4
     reg { field {} a; } c[20];
                                          // Address 0xC - Element 0
                                       // Address 0x10 - Element 1
                                       // Address 0x14 - Element 2
   };
Example 2
Sets accesswidth=64.
   addrmap some_map {
     accesswidth=64;
     addressing=compact;
     reg { field {} a; } a;
                                          // Address 0
     reg { regwidth=64; field {} a; } b; // Address 8
     reg { field {} a; } c[20];
                                          // Address 0x10 - Element 0
                                       // Address 0x14 - Element 1
                                       // Address 0x18 - Element 2
   };
```

b) regalign

Specifies the components are packed so each component's start address is a multiple of its size (in bytes). Array elements are aligned according to the individual element's size (this results in no gaps between the array elements). This generally results in simpler address decode logic.

#### Example 3

```
50 Uses the default accesswidth of 32.
```

```
addrmap some_map {
    addressing = regalign;

55
    reg { field {} a; } a;    // Address 0
    reg { regwidth=64; field {} a; } b; // Address 8
```

```
reg { field {} a; } c[20];
                                    // Address 0x10
                                  // Address 0x14 - Element 1
                                  // Address 0x18 - Element 2
```

};

#### c) fullalign

The assigning of addresses is similar regalign, except for arrays. The alignment value for the first element in an array is the size in bytes of the whole array (i.e., the size of an array element multiplied by the number of elements), rounded up to nearest power of two. The second and subsequent elements are aligned according to their individual size (so there are no gaps between the array elements).

#### Example 4

Uses the default accesswidth of 32.

```
addrmap some_map {
  addressing = fullalign;
                                                                                       20
  reg { field {} a; } a;
                                      // Address 0
  reg { regwidth=64; field {} a; } b; // Address 8
  reg { field {} a; } c[20];
                                      // Address 0x80 - Element 0
                                    // Address 0x84 - Element 1
                                    // Address 0x88 - Element 2
                                                                                       25
};
```

#### 5.1.2.3 Address allocation operators

When instantiating regs, regfiles, mems, or addrmaps, the address may be assigned using one of the address allocation (addr\_alloc) operators in Table 4.

| Property       | Implementation/Application                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| (a) expression | Specifies a specific address for the component instance. This expression resolves to a longint unsigned.                                                                                                                                                                                                                                                                                                                                                                                                                  | 35 |
| += expression  | pressionSpecifies the address stride when instantiating an array of components (controls the<br>spacing of the components). The address stride is relative to the previous instance's<br>address. This expression resolves to a longint unsigned.xpressionSpecifies the alignment of the next address when instantiating a component (con-<br>trols the alignment of the components). The initial address alignment is relative to<br>the previous instance's address. This expression resolves to a longint<br>unsigned. |    |
| %= expression  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |    |

#### Table 4—Address allocation operators

#### 5.1.2.4 Semantics

- Addresses in SystemRDL are always byte addresses. a)
- b) Addresses are assigned in incrementing order.
- The operator %= is a more localized version of the **alignment** property (see <u>Table 25</u>). c)
- Only a longint unsigned may be used for address specification. d)
- e) The += operator is only used when instantiating arrayed addrmap, regfile, reg, or mem components.
- f) The (a) and %= operators are mutually exclusive per instance.

5

1

10

15

30

50

5

10

g) The alignment of an array instance specifies the alignment of the start of the array and the increment specifies the offset from one array element to the next array element.

#### 5.1.2.5 Examples

The following set of examples demonstrate the usage of the operators defined in <u>Table 4</u>. The final addresses (as indicated in the comments in the example) are valid for an addressing mode called **regalign**, which is the default addressing mode (see <u>Clause 13</u>), with the default **regwidth=**32. The **regfile** component is defined in <u>Clause 12</u>.

Example 1

Using the *a* operator.

```
15
                addrmap top {
                   regfile example {
                      reg some_reg { field {} a; };
                      some_reg a
                                    @0x0;
                                    @0x4;
                      some_reg b
20
                      some_reg c; // Implies address of 8
                                    // Address 0xC is not implemented or specified
                       some_reg d
                                    @0x10;
                   };
               };
25
            Example 2
            Using the += operator.
30
               addrmap top {
                   regfile example {
                      reg some_reg { field {} a; };
                      some_reg a[10]; // So these will consume 40 bytes
                                        // Address 0,4,8,C....
35
                       some_reg b[10] @0x100 += 0x10; // These consume 160-12 bytes of space
                                                 // Address 0x100 to 0x103, 0x110 to 0x113,....
                   };
                };
40
            Example 3
            Using the \%= operator.
               addrmap top {
45
                   regfile example {
                      reg some_reg { field {} a; };
                      some_reg a[10]; // So these will consume 40 bytes
                                        // Address 0,4,8,C....
                       some_reg b[10] @0x100 += 0x10; // These consume 160-12 bytes of space
                                                 // Address 0x100 to 0x103, 0x110 to 0x113,....
50
                       some_reg c %=0x80; // This means ((address % 0x80) == 0))
                                        // So this would imply an address of 0x180 since
                                        // that is the first address satisfying address>=0x134
                                        // and ((address % 0x80) == 0)
                   };
55
               };
```

| 5.1.3 Specifying component properties                                                                                                                                                                                                                                                                                                                                                                       | 1  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| Each property is associated with at least one data type defined in <u>Clause 6</u> (and summarized in <u>Table 7</u> ).<br>Property types include primitive types and aggregate types.                                                                                                                                                                                                                      | 5  |
| 5.1.3.1 Property assignment                                                                                                                                                                                                                                                                                                                                                                                 | 5  |
| Each component type has its own set of pre-defined properties. Properties may be assigned in any order. User-defined properties can also be specified to add additional properties to a component that are not pre-defined by the SystemRDL specification (see <u>Clause 15</u> ). A specific property shall only be set once per scope (see $5.1.4$ ). All component property assignments are optional.    | 10 |
| A property assignment appears as follows.                                                                                                                                                                                                                                                                                                                                                                   |    |
| property_name [= expression];                                                                                                                                                                                                                                                                                                                                                                               | 15 |
| The descriptions for the data types of <i>expression</i> results that are legal for each <i>property_name</i> (and exceptions to those rules) are explained in the corresponding clause for each individual component (see Clause 8 — Clause 14).                                                                                                                                                           | 20 |
| When <i>expression</i> is not specified, it is presumed the <i>property_name</i> is of type <b>boolean</b> and the default value is set to <b>true</b> .                                                                                                                                                                                                                                                    | 20 |
| Example                                                                                                                                                                                                                                                                                                                                                                                                     | 25 |
|                                                                                                                                                                                                                                                                                                                                                                                                             | 25 |
| <pre>field myField {   rclr;</pre>                                                                                                                                                                                                                                                                                                                                                                          | 30 |
| 5.1.3.2 Assigning default values                                                                                                                                                                                                                                                                                                                                                                            |    |
| Default values for a given property can be set within the current or any enclosing lexical scope (see $5.1.4$ ). Any components defined in the same or enclosed lexical scope as the default property assignment shall use the default values for properties in the component not explicitly assigned in a component definition. A specific property <b>default</b> value shall only be set once per scope. | 35 |
| A default property assignment opposes as follows                                                                                                                                                                                                                                                                                                                                                            | 40 |
| default property_name [= value];                                                                                                                                                                                                                                                                                                                                                                            |    |
| The descriptions for the types of <i>values</i> that are legal for each <i>property_name</i> (and exceptions to those rules) are explained in the corresponding clause for each individual component (see <u>Clause 8</u> — <u>Clause 14</u> ).                                                                                                                                                             | 45 |
| When the <i>value</i> is not specified, the property shall be assigned the boolean value <b>true</b> .                                                                                                                                                                                                                                                                                                      |    |
| Example                                                                                                                                                                                                                                                                                                                                                                                                     |    |
| <pre>field {} outer_field ; reg {    default name = "default name";</pre>                                                                                                                                                                                                                                                                                                                                   | 50 |
| <pre>field {} f1; // assumes the name "default name" from above field { name = "new name"; } f2; // name assignment overrides "default name" outer_field f3; // name is undefined, since outer_field is not defined in the</pre>                                                                                                                                                                            | 55 |
| Copyright © 2015 - 2017 Accellera. All rights reserved. 21                                                                                                                                                                                                                                                                                                                                                  |    |

// scope of the default name

} some\_reg;

#### 5.1.3.3 Dynamic assignment

Some properties may have their values assigned or overridden on a per-instance basis. When a property is assigned after the component is instantiated, the assignment itself is referred to as a *dynamic assignment*. Properties of a referenced instance shall be accessed via the arrow operator (->).

A dynamic assignment appears as follows.

instance\_name -> property\_name [= value];

## 15 where

1

5

10

20

25

30

35

40

- instance\_name is a previously instantiated component (see 5.1.2). a) b) When *value* is not specified, it is presumed the *property\_name* is of type **boolean** and the value is set to true. The dynamically assignable properties for each component type are explained in the corresponding c) clause for each individual component (see Clause 8 — Clause 14). d) In the case where *instance\_name* is an array, the following possible dynamic assignment scenarios exist. If the component type is **field** or **signal**, the fact the component is an array does not matter—the 1) assignment is treated as if the component were a not an array. If the component type is reg, regfile, mem, or addrmap 2)
  - 2) If the component type is reg, regine, mem, or addrinap
    - i) The user can dynamically assign the property for all elements of the array by eliminating the square brackets ([]) and the array index from the dynamic assignment.

array\_instance\_name -> property\_name [= value];

ii) The user can dynamically assign the property for an individual index of the array by using square brackets ([]) and specifying the index to be assigned within the square brackets.

array\_instance\_name {[index]}\* -> property\_name [= value];

Example 1

This example assigns a simple scalar.

reg {
 field {} f1;
 f1->name = "New name for Field 1";
} some\_reg;

#### 45 Example 2

This example assigns an array.

```
50 reg {
50 field {} f1;
f1->name = "New name for Field 1";
} some_reg[8];
some_reg->name = "This value is applied to all elements in the array";
55 some_reg[3]->name = "This value is only applied to the 4th item in the
array of 8";
```

| 5.1.3.4 Property assignment precedence                                                                                                                                                                                                                        | 1  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| There are several ways to set values on properties. The precedence for resolving them is (from highest to lowest priority):                                                                                                                                   |    |
| a) dynamic assignment (see <u>5.1.3.3</u> )                                                                                                                                                                                                                   | 5  |
| b) property assignment (see 5.1.3.1)                                                                                                                                                                                                                          |    |
| c) default property assignment (see 5.1.3.2)                                                                                                                                                                                                                  |    |
| d) SystemRDL default value for property type (see Table 7)                                                                                                                                                                                                    | 10 |
|                                                                                                                                                                                                                                                               |    |
| Example                                                                                                                                                                                                                                                       |    |
| reg {                                                                                                                                                                                                                                                         |    |
| <pre>default name ="def name";</pre>                                                                                                                                                                                                                          | 15 |
| <pre>field f_type { name = "other name"; }; field {} f1:</pre>                                                                                                                                                                                                |    |
| field { name = "property assigned name"; } f2;                                                                                                                                                                                                                |    |
| f_type f3;                                                                                                                                                                                                                                                    |    |
| f2 > nome - "Dracomia Accientment":                                                                                                                                                                                                                           | 20 |
| } some_req;                                                                                                                                                                                                                                                   |    |
| ,                                                                                                                                                                                                                                                             |    |
| Results                                                                                                                                                                                                                                                       |    |
| // Final Values of all fields                                                                                                                                                                                                                                 | 25 |
| // fl name is "def name"                                                                                                                                                                                                                                      |    |
| // f2 name is "property assigned name"                                                                                                                                                                                                                        |    |
| // f3 name is "dynamic assignment"                                                                                                                                                                                                                            |    |
| 5.1.4 Scoping and namespaces                                                                                                                                                                                                                                  | 30 |
| A <i>scope</i> defines the conditions in which an identifier may be associated with an entity. SystemRDL is a statically (or lexically) scoped language.                                                                                                      |    |
| The body of a component (or <b>struct</b> ) definition defines a <i>local scope</i> . A valid SystemRDL description is, therefore, an aggregation of nested local scopes, ultimately nested into the outermost <i>global</i> (or <i>root</i> ) <i>scope</i> . | 35 |
| Each local scope contains two independent namespaces, to which different scoping rules apply:                                                                                                                                                                 |    |
| — Type names (component definitions, enum types, and struct types);                                                                                                                                                                                           | 10 |
| — Element (e.g., reg and field instantiations; struct members) names and parameter names.                                                                                                                                                                     | 40 |
|                                                                                                                                                                                                                                                               |    |
| Identifiers shall be unique within a namespace in a scope. <i>Namespaces</i> are differentiated implicitly by syntax. There are no namespace operators or limiters.                                                                                           |    |
| The root scope contains a third namespace for property names. All property references (standard and user-<br>defined) shall be resolved by searching this namespace.                                                                                          | 45 |
| Example 1                                                                                                                                                                                                                                                     |    |
|                                                                                                                                                                                                                                                               | 50 |
| property foo {     component = field :                                                                                                                                                                                                                        |    |
| type = string;                                                                                                                                                                                                                                                |    |
| };                                                                                                                                                                                                                                                            |    |
| reg foo {                                                                                                                                                                                                                                                     | 55 |
| ττετα (                                                                                                                                                                                                                                                       | 20 |

5

10

15

20

30

35

40

45

| foo     | =  | "abc"  | ;       |        |         |       |        |        |          |          |          |       |
|---------|----|--------|---------|--------|---------|-------|--------|--------|----------|----------|----------|-------|
| } foo   | ;  |        |         |        |         |       |        |        |          |          |          |       |
| } ;     |    |        |         |        |         |       |        |        |          |          |          |       |
| foo foo | ;  | // ins | stantia | ate re | g type  | foo t | o gen  | erate  | instan   | ce calle | ed foo   |       |
| foo.foo | -> | foo =  | "xyz"   | ; // p | propert | y foo | of fie | eld fo | o of reg | g foo ge | ts value | "xyz" |
|         |    |        |         |        |         |       |        |        |          |          |          |       |

The root scope shall only contain component type and **struct** type definitions and signal instantiations. No other component instantiations shall be allowed in the root scope. The root(s) of an **addrmap** hierarchy are those **addrmap**s that are defined, but not subsequently instantiated.

By definition, a *component scope* contains component type and **struct** type definitions, as well as element references. A *struct scope* only contains member declarations. All type names shall be unique in the type namespace and all element names shall be unique within the element namespace. However, there can be a type and element with the same name in the same scope. Additionally, types shall be defined and elements declared before they are referenced in the sequence of statements.

Type references are resolved from the local scope up the enclosing lexical scope to the global scope.

- a) Elements referenced in the left-hand side of an expression shall be declared in the local scope.
- b) Elements referenced in the right-hand side of an expression shall be declared in the local scope or up in the enclosing lexical scope if the referenced element is a **signal**.
- c) If two types (or elements) in different scopes share the same name, the type (respectively, element) name from the scope that is lexically closest to the local scope shall take precedence.
- 25 Children elements—as elements contained in the local scope of the parent scope's type—may be referenced via the dot operator (.).

A element reference appears as follows.

element\_name [. child\_element\_name]\*

#### where

- a) *element\_name* is a previously declared element in the current scope (see <u>5.1.2</u>).
- b) the first use of *child\_element\_name* shall exist in *element\_name*'s local type scope.
- c) for all other *child\_element\_names*, any subsequent *child\_element\_name* shall exist in the previous *child\_element\_name*'s local type scope.

Element references from an assignment located in a **constraint** body are resolved from the **constraint** body's enclosing lexical scope, then up the lexical scope. Such an element reference may either be a direct **field** reference, or use the dot operator (.) to navigate down the referenced element's instance hierarchy to target a field instance.

```
Example 2
```

```
regfile foo {
    reg {
        field {} a ;
        constraint {
            a < 0xc ; // direct field reference
        } const1 ;
        } regA ;
        constraint {
            regA.a > 0x4 ; // indirect field reference
        } const2 ;
        };
    }
```

5

30

45

50

55

Dynamic assignments can be layered in SystemRDL from the innermost to the outermost scope; i.e., dynamic assignments that are specified at an outer scope override those that are specified at an inner scope. No more than one assignment of a property per scope is allowed in SystemRDL.

#### Example 3

```
regfile foo_rf {
   reg some_reg_r {
                                                                                       10
      field {} a[2]=2'b00;// End of field: a
       a->reset = 2'b01;// Dynamic Assignment overriding reset val
       field {} b[23:16]=8'hFF; // End of field: b
   };
                                                                                       15
   some_reg_r rega;
   some_reg_r regb;
   rega.a->reset = 2'b10; // This overrides the other dynamic assign
   rega.b->reset = 8'h00;
   rega.b->reset = 8'h5C; // Error two assigns from the same scope
                                                                                       20
};
                                                           // End addrmap: foo
addrmap bar {
   foo_rf foo;
   foo.rega.a->reset = 2'b11;
   // Override the reset value again at the outermost scope
                                                                                       25
};
                                                           // End addrmap: bar
```

Any reference to an element in the right-hand side of an assignment shall be resolved statically, i.e., by considering the elements visible from the assignment's local scope.

#### Example 4

#### 5.2 General component properties

This subclause details properties that generally apply to SystemRDL components.

#### 5.2.1 Universal properties

The **name** and **desc** properties can be used to add descriptive information to the SystemRDL code. The use of these properties encourages creating descriptions that help generate rich documentation. All components have a instance name already specified in SystemRDL; **name** can provide a more descriptive name and **desc** can specify detailed documentation for that component.

#### 1 <u>Table 5</u> lists and describes the universal SystemRDL component properties.

Table 5—Universal component properties

| Property | Derty Implementation/Application                                |        | Dynamic <sup>a</sup> |
|----------|-----------------------------------------------------------------|--------|----------------------|
| name     | Specifies a more descriptive name (for documentation purposes). | string | Yes                  |
| desc     | Describes the component's purpose.                              | string | Yes                  |

5

```
10
```

15

30

35

40

45

50

55

<sup>a</sup>Indicates whether a property can be assigned dynamically.

#### 5.2.1.1 Semantics

If **name** is undefined, it is presumed to be the instance name.

#### 5.2.1.2 Example

This example shows usage of the name and desc properties.

```
20
reg {
    field {
        name="Interface Communication Control";
        // If name is not specified its implied to be ICC
        desc="This field is used [...] desired low power state.";
        } ICC[4];
    } ICC_REG; // End of Reg: ICC_REG
```

#### 5.2.2 Structural properties

Table 6 lists and describes the structural component properties.

#### Table 6—Structural component properties

| Property         | Туре                                                                                                                           | Dynamic <sup>a</sup>     |     |  |
|------------------|--------------------------------------------------------------------------------------------------------------------------------|--------------------------|-----|--|
| donttest         | This testing property indicates the component is not included in struc-<br>tural testing.                                      | <i>boolean</i> or<br>bit | Yes |  |
| dontcom-<br>pare | This is testing property indicates the components read data shall be dis-<br>carded and not compared against expected results. | <i>boolean</i> or<br>bit | Yes |  |

<sup>a</sup>Indicates whether a property can be assigned dynamically.

#### 5.2.2.1 Semantics

- a) These properties can be applied as a *boolean* or a bit mask (*bit*) to a **field** component. A mask shall have the same *width* as the **field**. Masked bits (bits set to 1) are not tested (**donttest**) or compared (**dontcompare**).
- b) They can also be applied to reg, regfile, and addrmap components, but only as a *boolean*.

c) donttest and dontcompare

- 1) cannot both be set to **true**,
- 2) cannot have one **true** and the other non-zero, and
- 3) the bitwise AND of their masks shall be zero (0) for a particular component (i.e., donttest & dontcompare = 0).
15

20

25

30

35

45

50

# 5.2.2.2 Example

This example shows usage of the **donttest** and **dontcompare** properties.

# 5.3 Content deprecation

The **ispresent** universal property can be used to configure the activation of SystemRDL component instances. Setting **ispresent** to **false** causes the given component instance to be removed from the final specification.

# 5.3.1 Semantics

- a) **ispresent** is a universal property on all component instances (**addrmap**, **reg**, **signal**, etc.) other than **enums**.
- b) The default value of **ispresent** is **true**.
- c) Instance names shall be unique within a scope even before the values of **ispresent** are resolved. This feature does not enable replacement of instances.
- d) **ispresent** values may not be dependent on values contained in SystemRDL constructs. No reference values are allowed. Otherwise, the rules of expressions apply.
- e) Setting ispresent to false removes the instance.
- f) Setting a property on an element that is removed due to **ispresent** does not constitute an error, e.g., if an instance belong to a removed **addrmap**, modifications to the instance are acceptable.
- g) Instance positions are computed presuming all instances are present. Removing an instance can introduce a hole.
- h) The use of **ispresent** does not imply any new component definitions. If a component is instantiated twice, setting **ispresent** within one of them does not trigger the creation of new hardware.
- i) If a present instance includes references (e.g., signals), the referred objects need to also be present.
- j) If a present instance is an alias register (see <u>10.5</u>), the primary register needs to also be present. Conversely, if a register acting as a primary register is not present, then all the alias registers that refer to it shall not be present either.
- k) Component instances shall not be empty. Setting **ispresent** on all children of a parent instance to **false** shall be an error.

# 5.3.2 Examples

Some examples are shown highlighting simple, complex, and corner case usage.

# 5.3.2.1 Simple example

```
addrmap submap {
  reg { field {} a[32] ; } rega, regb, ahb_specific ;
};
```

```
1 addrmap bridge {
    bridge ;
    submap ahb ;
    submap axi ;
5 axi.ahb_specific -> ispresent = false ;
};
```

# 5.3.2.2 Complex example

```
10
    reg some_reg #(boolean RESERVED = false) {
        ispresent = !RESERVED ;
        field {} a, b, c ;
        b -> ispresent = false ;
        field { ispresent = false ; } d ;
        // the default bitfield layout should be: a[0:0], c[2:2]
        };
        some_reg #(.RESERVED(true)) reserved_reg ;
        some_reg not_reserved_reg ;
        some_reg not_reserved_reg ;
        not_reserved_reg ;
        not_reserved_reg.b -> ispresent = true ;
    }
```

not\_reserved\_reg.d -> ispresent = true ;

# 5.3.2.3 Corner case

```
25
```

30

```
35
```

40

45

50

6. Data types

6.1 Overview

otherwise.

1

# 5

10

45

50

55

<u>Table 7</u> summarizes all the data types discussed in this document.

| Туре               | Parameter or<br>struct member<br>type name | Definition                                                                                                              | Default     |  |
|--------------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|-------------|--|
| boolean            | boolean                                    | true or false.                                                                                                          | false       |  |
| string             | string                                     | See <u>4.5</u> and <u>6.2.2</u> .                                                                                       |             |  |
| bit                | bit                                        | An unsigned integer with the value of 0 or a Ver-<br>ilog-style number, see $4.6$ ( <u>c</u> - <u>e</u> ) and $6.2.1$ . | Undefined   |  |
| longint unsized    | longint unsigned                           | A 64-bit unsigned long integer, see $4.6$ (a and b) and $6.2.1$ .                                                       | Undefined   |  |
| accesstype         | accesstype                                 | One of <b>rw</b> , <b>wr</b> , <b>r</b> , <b>w</b> , <b>rw1</b> , <b>w1</b> , or <b>na</b> . See <u>9.4</u> .           | rw          |  |
| addressingtype     | addressingtype                             | One of <b>compact</b> , <b>regalign</b> , or <b>fullalign</b> . See <u>13.4</u> .                                       | regalign    |  |
| onreadtype         | onreadtype                                 | One of <b>rclr</b> , <b>rset</b> , or <b>ruser</b> . See <u>9.6</u> .                                                   | Undefined   |  |
| onwritetype        | onwritetype                                | One of woset, woclr, wot, wzs, wzc, wzt, wclr, wset, or wuser. See <u>9.6</u> .                                         | Undefined   |  |
| precedencetype     |                                            | One of <b>hw</b> or <b>sw</b> . Cannot be used as a parameter or struct member type. See $9.4$ .                        | SW          |  |
| struct             | struct reference                           | A reference to a struct.                                                                                                | Undefined   |  |
| array              | array reference                            | A reference to an array.                                                                                                | Empty array |  |
| enum               | enum reference                             | A reference to a user-defined enumeration.                                                                              | Undefined   |  |
| instance reference | ref                                        | A reference to a component instance, component instance property, parameter, or struct instance member.                 | Undefined   |  |

# Table 7—Data types

This section presents all the data primary and aggregate data types used in SystemRDL. While some data types, such as **boolean** or **onreadtype**, are specific to SystemRDL, the data types and its associated type system are consistent with SystemVerilog semantics as specified in IEEE Std 1800-2012, unless noted

# 6.2 Primary data types

A subset of the SystemVerilog data types are used by the SystemRDL Expression Language, namely **bit**, **longint unsigned**, and **string** (with some changes).

Complex, user-defined, and time data types shall not be supported in SystemRDL. Unknown (x) and high impedance (z) values shall not be supported either.

# 6.2.1 Signed and unsigned data types

All SystemRDL number types are integral and unsigned. In order to maintain direct compatibility with the SystemRDL Expression Language, SystemRDL only supports **bit** and **longint unsigned**. Expressions

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change.

# 5 6.2.2 String data type

10

20

25

30

35

40

45

50

55

The SystemRDL Expression Language **string** data type is not a direct equivalent of the SystemVerilog **string** data type. The SystemRDL Expression Language **string** data type supports UTF-8 encoding to allow for non-English documentation.

A SystemRDL **string** can be seen as an immutable, unsized object, for which only the binary equality, concatenation, and replication operators are supported (see <u>Table 9</u>).

# 15 6.2.3 Boolean data type

The additional type **boolean** is introduced as a result type for logical operations, as well as for compatibility with previous SystemRDL versions. Boolean values shall be cast to the single bit values 1'b1 and 1'b0 (from true and false, respectively) for preserving sufficient compatibility with the SystemVerilog Expression Language, as defined in <u>Clause 7</u>.

# 6.2.4 Reserved enumeration types

The additional types: **accesstype**, **onreadtype**, **onwritetype**, and **addressingtype** shall be considered as reserved enumerations with no associated integral values for all purposes.

Reserved enumeration types only support binary equality operations.

# 6.2.5 Enumerations

An *enumerated type* encloses a set of constant named integral values into the enumeration's scope. There are no properties for the **enum** component beyond the universal properties defined in 5.2.1.

# 6.2.5.1 Defining enumerations

Unlike other SystemRDL components, enumerations are not instantiated and can only be defined definitively (i.e., anonymous definitions are not allowed). Enumerated types can either be assigned to a field's **encode** property (see <u>9.10</u>) or their enumerators can be referenced in expressions. Enumerator references shall be prefixed with their enumerated type name and two colons (::), e.g., MyEnumeration::MyValue.

An enum component definition appears as follows.

```
enum enum_name { encoding; [encoding;]* };
```

# where

- a) *enum\_name* is a user-defined name for the enumeration
- b) *encoding* is specified as follows

mnemonic\_name [= value [{{universal\_property;}\*}];

where

- 1) *mnemonic\_name* is a user-defined name for a specific *value*. This name shall be unique within a given **enum**.
- 2) *value* shall be of an integral type.

This is an example of bit-field encoding.

enum myBitFieldEncoding {

second\_entry = 8'hcd {
 name = "second entry";

third\_entry = 8'hef {

first\_encoding\_entry = 8'hab;

fourth\_entry = 8'b10010011;

encode = myBitFieldEncoding;

3)

4)

};

};

field {

} a[8];

};

Example

1

5

10

15

20

25

30

40

45

50

6.2.5.2 Automatically assigned enumerator values

All values shall be unique, even if the value is automatically assigned.

universal property is as defined in 5.2.1.

name = "third entry, just like others";

desc = "this value has a special documentation";

When the first enumerator value is unspecified, it is assigned 0. Other enumerator values are incremented by 1, based on the value of the previous enumerator. Automatically assigned values cannot break the unique value constraint when automatically assigning all the values of an enumeration using **longint unsigned** values.

# Examples

These are several examples of valid and incorrect enumeration definitions.

| enum myAutoEnum { first_value ; second_value ; third_value ; } ;<br>// first_value = 0, second_value = 1, third_value = 2 | 35 |
|---------------------------------------------------------------------------------------------------------------------------|----|
| enum myPartiallyAssignedEnum { a ; b ; c = 8'h6 ; d ; e = 8'h12 ; f ; } ;<br>// a = 8'h0, b = 8'h2, d = 8'h7, f = 8'h13   |    |

# 6.2.5.3 Type consistency

Enumerated types are strongly typed, therefore user-defined properties, struct members, or parameters of a given enumerated type are type-checked when used in assignments or with relational operators. In other expression contexts, enumerators are automatically cast to their integral values.

# Example

The example below illustrates the use of enumerated types in operations and assignments.

```
enum FirstEnum {
    VAL1 = 3'h0 ;
    VAL2 = 3'h1 ;
    VAL3 = 3'h2 ;
} ;
```

55

```
1
                 enum SecondEnum {
                   VAL1 = 3'h0;
                   VAL2 = 3'h1;
                   VAL3 = 3'h2;
                 };
 5
                property MyUDP { component = addrmap ; type = FirstEnum ; } ;
                 addrmap top {
10
                   reg some_reg { field {} a[3] ; } ;
                   addrmap {
                     MyUDP = FirstEnum::VAL1 ; // Allowed
                     some_reg regA ;
15
                     regA.a -> reset = FirstEnum::VAL2 + SecondEnum::VAL3 ; // Enumerators are
                    cast to their integer value and added
                   } submap1 ;
                   addrmap {
20
                     reg {
                        shared = longint'(FirstEnum::VAL1) == longint'(SecondEnum::VAL2) ; //
                    Allowed since we're first casting the enumerators to their underlying
                    integral values
                       field {} b ;
25
                     } other_shared_reg ;
                   } submap2 ;
                 } ;
             6.2.6 Identifier references
30
             SystemRDL struct members, parameters, and component instances that are in the scope of a SystemRDL
             statement in which the expression is defined can be referenced from the expression.
             In addition, the SystemRDL rules for escaped identifiers, (see 4.3) shall apply to references inside the
35
             SystemRDL Expression Language.
             Hierarchical struct members and component instances are referenced using a dot delimiter (.) (see 5.1.4).
             Example
40
                 struct inner_struct {
                   string foo ;
                 } ;
45
                 struct my_struct {
                   inner struct inner ;
                 };
                 addrmap top {
                   regfile some_regfile #( my_struct arg ) {
50
                     req {
                       desc = arg.inner.foo ;
                       field {} a ;
                     } regA ;
                   } ;
55
```

15

25

30

35

40

```
some_regfile #( .arg( my_struct'{ inner: inner_struct'{ foo: "reg desc" } } 1
) ) regFA[2];
regFA[0].regA.a -> desc = "field desc from regFA[0]";
regFA[1].regA.a -> desc = "field desc from regFA[1]";
};
```

# 6.3 Aggregate data types

# 6.3.1 Arrays

A SystemRDL array describes an ordered collection of elements. Each array element shall be identified with a unique array index. Arrays may be used as **struct** members, or in **property** or parameter declarations.

a) An array shall be declared as follows:

array\_type declaration []

where

- array\_type specifies the type allowed for each array element. All the types defined in <u>Table 7</u>, as well as any user-defined **enum** types, but excepting array types, may be used as array types. Effectively, multi-dimensional arrays are not supported. This limitation may be circumvented by defining arrays of structs containing arrays.
- 2) *declaration* may be a **struct** member or a parameter name.

For example:

```
reg some_reg #( string NAME_AND_DESC[] ) {
  field {} a ;
} ;
```

b) A user-defined property array shall be declared as follows:

array\_type

where

*array\_type* specifies the type allowed for each array element. All the types defined in <u>Table 31</u> may be used as user-defined property array types.

For example:

```
property myUDP { component = field ; type = longint unsigned[] ; } ;
```

An array may be assigned a sequence of values as follows:

```
left_hand_side = '{ [expr [, expr]*]? }
```

where

c)

- 1) *left\_hand\_side* corresponds to the **struct** member, parameter, or **property** to which the array is being assigned.
- 2) *expr* is an expression whose resolved type shall be assignment compatible with the type of the array (see 6.4). 45

For example:

some\_reg #(.NAME\_AND\_DESC( '{ "hello", "world" } ) regA ;

d) An empty array may be declared as follows:

```
left_hand_side = '{}
```

 Array elements may be used in expressions by referencing their position in the array, as follows: *array\_reference* [*index*] where

55

50

| 1  | <ol> <li><i>array_reference</i> is a reference to the array containing the array element.</li> <li><i>index</i> is an expression that shall resolve to a <b>longint unsigned</b>.</li> </ol> |
|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5  | <pre>For example:     regA -&gt; name = NAME_AND_DESC[0] ;</pre>                                                                                                                             |
|    | 6.3.1.1 Semantics                                                                                                                                                                            |
| 10 | a) Array indices are 0-based and strictly sequential.                                                                                                                                        |
|    | b) Arrays are immutable and can only be modified by recreating an array (i.e., single values cannot be reassigned).                                                                          |
| 15 | c) SystemRDL arrays are not constrained with respect to their sizes: a given array may be reassigned with a new array of a different size.                                                   |
|    | d) An array element cannot reference another element from the same array.                                                                                                                    |
|    | e) An out of bound array reference shall raise an error.                                                                                                                                     |
| 20 | 6.3.1.2 Examples                                                                                                                                                                             |
|    | 6.3.1.2.1 User-defined property with array type                                                                                                                                              |
| 25 | <pre>property MyUDP { component = reg ;     type = longint unsigned[] ;     default = '{1, 2} ; } ;</pre>                                                                                    |
| 30 | reg some_reg {<br>MyUDP = '{ 2, 34, 73 } ;<br>} ;                                                                                                                                            |
|    | 6.3.1.2.2 User-defined property with aggregate type array type                                                                                                                               |
| 35 | <pre>struct mystruct { string foo; longint unsigned bar ; } ; property MyUDP { component = all ;     type = mystruct[] ; } ;</pre>                                                           |
|    | <pre>reg some_reg {    MyUDP = '{ 'mystruct { foo: "hello", bar: 23 },         'mystruct{ foo: "world", bar: 42 } };</pre>                                                                   |
| 40 | };                                                                                                                                                                                           |
|    | 6.3.1.2.3 User-defined property with enum type array type                                                                                                                                    |
| 45 | <pre>enum Location { Mem = 0, PCI = 1, DMA = 2 } ; property MyUDP { component = reg ; type = Location[] ; } ;</pre>                                                                          |
|    | <pre>reg some_reg {     MyUDP = '{ Location::Mem, Location::Mem, Location::PCI } ; } ;</pre>                                                                                                 |
| 50 | 6.3.1.2.4 Struct defining an array type member                                                                                                                                               |
|    | <pre>struct mystruct { string[] foo } ; property StructUDP { component = all ; type = mystruct ; } ;</pre>                                                                                   |
| 55 |                                                                                                                                                                                              |

| r<br>}          | eg other_reg {<br>StructUDP = 'mystruct { foo: '{ "hello", "world"} } ;<br>;                                                                                                                                                                       | 1  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 6.3.1.          | 2.5 Array element reference                                                                                                                                                                                                                        | 5  |
| f.<br>}         | <pre>ield some_field #( string NAME_AND_DESC[] ) {   name = NAME_AND_DESC[0] ;   desc = NAME_AND_DESC[1] ;   ;</pre>                                                                                                                               | 10 |
| 6.3.2           | Structures                                                                                                                                                                                                                                         |    |
| Struct          | s enable the creation of structured properties for more complex extension of component types.                                                                                                                                                      | 15 |
| 6.3.2.          | 1 Defining structures                                                                                                                                                                                                                              |    |
| 6.3.2.          | 1.1 struct definition                                                                                                                                                                                                                              |    |
| A strı          | <pre>tet definition appears as follows. [abstract] struct_name [: base_struct_name] {{member_type member_name;}*};</pre>                                                                                                                           | 20 |
| where           |                                                                                                                                                                                                                                                    | 25 |
| a)              | abstract optionally defines the struct as an abstract struct.                                                                                                                                                                                      |    |
| b)              | struct_name specifies the new struct type name.                                                                                                                                                                                                    |    |
| d)              | <i>member_type</i> is the type of the composed value                                                                                                                                                                                               | 30 |
| e)              | <i>member_name</i> is the name of the value. Member names shall be unique within a <b>struct</b> and its base class, recursively.                                                                                                                  |    |
| 6.3.2.          | 1.2 Semantics for defined structs                                                                                                                                                                                                                  | 35 |
| a)              | A struct can be used within user-defined property definitions, parameters, arrays, and other structs.                                                                                                                                              |    |
| b)              | The name of the struct is added to the type name namespace. Struct type names shall be unique.                                                                                                                                                     |    |
| c)              | Structs may include all of the types defined in <u>Table 7</u> .                                                                                                                                                                                   | 10 |
| d)              | Structs may not include items that directly or indirectly refer to the <b>struct</b> being defined (i.e., no circular dependencies).                                                                                                               | 40 |
| e)              | A <b>struct</b> may be declared as <b>abstract</b> , which specifies that it cannot be directly instantiated. Struct types derived from an <b>abstract struct</b> are not abstract, unless specified explicitly using the <b>abstract</b> keyword. | 45 |
| 6.3.2.          | 2 Deriving structures                                                                                                                                                                                                                              | 10 |
| 6.3.2.          | 2.1 struct derivation                                                                                                                                                                                                                              |    |
| A stru<br>e.g., | <b>act</b> declaration may <i>derive</i> from another <b>struct</b> by specifying the base <b>struct</b> 's name after a colon (:),                                                                                                                | 50 |
| S               | truct base_struct {                                                                                                                                                                                                                                |    |

```
struct base_struct {
   bit foo ;
};
```

15

20

25

30

35

40

45

```
struct derived_struct : base_struct {
    longint unsigned bar ;
};

struct final_struct : derived_struct {
    // final_struct's members are foo, bar, and baz.
    string baz ;
};
```

# 6.3.2.2.2 Semantics for derived structs

- a) A *derived* struct inherits all its base's members, recursively.
- b) Any member declared in the *derived* struct shall be unique, relative to both the *derived* struct and its base, recursively.
- c) Parameters and user-defined properties declaring a struct type may be initialized using any *derived*, non-abstract, struct instance in their assignment's right-hand side (i.e., derived types are considered as *assignment compatible* with all their base types, following the definition from <u>6.4</u>). Derived struct instances passed in this way shall preserve all their member values (for code generation purposes), even though only the members from the declared struct type shall be visible from the SystemRDL code.

### 6.3.2.3 Instantiating structures

# 6.3.2.3.1 struct instantiation

A struct is instantiated as follows:

struct\_name '{ [member\_name : member\_value {, member\_name : member\_value }\*] }

### where

- a) *struct\_name* is the name of the **struct** type that is being instantiated.
- b) *member\_name* is the name of a member as specified in the **struct**'s definition.
- c) *member\_value* is the value being assigned.

# 6.3.2.3.2 Semantics for instantiated structs

- a) Struct assignments are always by value.
- b) When defining struct member values, unassigned members shall receive a default value depending on their type, when available, as defined in <u>Table 7</u>.
  - c) All the members from a struct instance shall be assigned a value, either explicitly or by default. Undefined struct members shall raise an error.

### 6.3.2.4 Examples

Example 1

50 This example defines a simple **struct** and uses it in a user-defined property.

```
struct struct1 {
    bool abool;
    string astring;
};
```

5

10

25

| property pl {                                    |  |
|--------------------------------------------------|--|
| component = field;                               |  |
| type = struct1;                                  |  |
| default = struct1'{abool:true, astring:"hello"}; |  |
| };                                               |  |

Example 2

This example defines a **struct** that declares a member which is also **struct**.

Example 3

This example defines and derives an abstract struct.

```
abstract struct absstruct {
    string astring;
    30
};
struct substruct:absstruct {
    bool abool;
};
property p3 {
    component = field;
    type = absstruct ;
    default =substruct'{abool:false, astring:"foo"};
};
40
```

# 6.4 Type compatibility

As SystemRDL uses only a subset of the data types defined in the SystemVerilog, only three levels of type compatibility shall effectively be used when resolving SystemRDL expressions: *matching*, *assignment compatible*, and *incompatible*. All three levels match their SystemVerilog equivalent. Type coercion, as happens in the context of assignments (i.e., between assignment compatible types), is detailed in <u>6.5</u>.

In the context of assignments, if the left hand-side expects a given **abstract struct** type, all *derived* **struct** types shall be considered as compatible.

50

45

# 6.5 Casting

| SystemRDL only supports static (i.e., type-based) and constant expression (i.e., bit length-based) casts from |  |
|---------------------------------------------------------------------------------------------------------------|--|
| SystemVerilog. The additional types introduced in SystemRDL are bound by the casting rules in Table 8.        |  |

Supported static types are: **boolean**, **bit**, **longint unsigned**, **string**, **accesstype**, **addressingtype**, **onreadtype**, and **onwritetype**. <u>Table 8</u> defines which expression types are compatible with static type casts (*x* corresponds to a conversion that is *assignment compatible* — and, thus, also *cast compatible*).

5

10

15

20

# Table 8—Allowed cast operations (cast and assignment compatible types)

| Туре                | boolean | bit | longint<br>unsigned | string | access<br>type | addressing<br>type | onread<br>type | onwrite<br>type |
|---------------------|---------|-----|---------------------|--------|----------------|--------------------|----------------|-----------------|
| boolean             | x       | x   | x                   |        |                |                    |                |                 |
| bit                 | x       | x   | x                   |        |                |                    |                |                 |
| longint<br>unsigned | x       | x   | x                   |        |                |                    |                |                 |
| string              |         |     |                     | x      |                |                    |                |                 |
| accesstype          |         |     |                     |        | x              |                    |                |                 |
| addressing<br>type  |         |     |                     |        |                | x                  |                |                 |
| onreadtype          |         |     |                     |        |                |                    | x              |                 |
| onwritetype         |         |     |                     |        |                |                    |                | x               |

25

30

35

Static cast operations shall be resolved according to the following rules.

- a) All types can be cast to themselves.
- b) When casting boolean to sizedNumeric or unsizedNumeric, true shall be converted to 1'bl and false to 1'b0.
- c) When casting a sizedNumeric, if the bit width of the target type does not match, this results in the upper bit zero-extension or truncation of the most significant bits.
- d) When casting sizedNumeric or unsizedNumeric to boolean, zero (0) shall be converted to false, any other value shall be converted to true.

40

45

7. Expressions

1

5

10

15

20

25

# 7.1 Overview The SystemRDL Expression Language is based on the SystemVerilog Expression Language as specified in IEEE Std 1800-2012. The goal of the SystemRDL Expression Language is for it to be a strict subset of SystemVerilog, i.e., the expressions defined in SystemRDL should be easily ported-to or incorporated-into a SystemVerilog file and interpreted by any SystemVerilog processor.

In order to represent and manipulate types and concepts proper to SystemRDL, the SystemVerilog Expression Language has been functionally limited and changes introduced.

# 7.2 Operators

Table 9 gives an overview of the SystemVerilog operators and how SystemRDL supports them (or not).

| Operator<br>token | Name                                          | Operand data type                                |
|-------------------|-----------------------------------------------|--------------------------------------------------|
| =                 | Binary assignment operator                    | Only supported for specific cases (see $7.2.1$ ) |
| += _= /= *=       | Binary arithmetic assignment operators        | Assignments are not supported                    |
| °⁄0=              | Binary arithmetic modulus assignment operator | Assignments are not supported                    |
| &=  = ^=          | Binary bit-wise assignment operator           | Assignments are not supported                    |
| >>= <<=           | Binary logical shift assignment operators     | Assignments are not supported                    |
| >>>= <<<=         | Binary arithmetic shift assignment operators  | Assignments are not supported                    |
| :                 | Conditional operator                          | First operand: boolean, other operands: any      |
| -                 | Unary arithmetic operator                     | Integral                                         |
| +                 | Unary decrement/increment operators           | Assignments are not supported                    |
|                   | Unary logical negation operator               | Integral                                         |
|                   | Unary bitwise negation operator               | Integral                                         |
| ~&  ~ ^~~^        | Unary reduction operators                     | Integral                                         |
| - * / **          | Binary arithmetic operators                   | Integral                                         |
| )                 | Binary modulus operator                       | Integral                                         |
| ^ ~^ ^~           | Binary bitwise operators                      | Integral                                         |
| • <<              | Binary logical shift operators                | Integral                                         |
| »» <<<            | Binary arithmetic shift operators             | Not supported                                    |
| x&                | Binary logical operators                      | Integral                                         |

# Table 9—SystemVerilog operators

|  | -1 |  |
|--|----|--|
|  |    |  |
|  |    |  |
|  |    |  |

# 10

# 15

# Table 9—SystemVerilog operators (Continued)

| Operator<br>token | Name                                   | Operand data type                                  |
|-------------------|----------------------------------------|----------------------------------------------------|
| < <= > >=         | Binary relational operators            | Integral, user-defined enums                       |
| !                 | Binary logical equality operators      | Any, except structural instance references         |
| !                 | Binary case equality operators         | Unknown or high-impedance values are not supported |
| ==? !=?           | Binary wildcard equality operators     | Unknown or high-impedance values are not supported |
| inside            | Binary set membership operator         | Only used within top level of constraints          |
| dist              | Binary distribution operator           | Randomization is not supported                     |
| 8 {8}             | Concatenation and replication operator | Integral, string, boolean, reserved enums          |
| {<<{}} {>>{}}     | Stream operators                       | Not supported                                      |

# 20

25

30

35

Additional support considerations for SystemVerilog operators are detailed below.

# 7.2.1 Assignment operators

Since the SystemRDL Expression Language does not allow using variables, it only supports single value assignments for which the left-hand side is a property, a parameter (in the context of a parameter declaration), or a struct member reference (in the context of a post-property assignment). All other assignment operators are not supported.

# 7.2.2 Logical operators

The result of the evaluation of one of the supported SystemVerilog logical operators (i.e., AND (&&) and OR (| | )) shall be one of the **boolean** values true or false.

Similarly, the unary *logical negation operator* (!) converts a true value into false and a false value into true.

40 Also, the binary *logical equality operators* (== and !=), aggregate types may be compared for equality by comparing the values of their individual members, recursively. Primary type members are compared by applying the default type and value equality rules.

# 45 **7.3 Expression evaluation rules**

Due to the data types supported by SystemRDL, the rules for determining expression types and evaluating expressions are more restrictive than those defined in IEEE Std 1800-2012, <u>subclause 11.8</u>.

# 50 **7.3.1 Rules for determining expression types**

The following rules shall be applied for determining the resulting type of an expression.

- Expression type depends only on the operands. It does not depend on the left-hand side (if any).
- All numbers and expression results are unsigned.

40

| <ul> <li>The size of any self-determined operand is determined by the operand itself and independent of the remainder of the expression.</li> <li>Any expression that would result in an unknown (x) value shall instead raise an error.</li> </ul>                    | 1  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 7.3.2 Rules for evaluating expressions                                                                                                                                                                                                                                 | 5  |
| All expressions are evaluated in a <i>self-determined context</i> , as specified in IEEE Std 1800-2012, <u>subclause</u> <u>11.6.1</u> , which implies that the left-hand side of a property assignment is never taken into consideration when evaluating expressions. | 10 |
|                                                                                                                                                                                                                                                                        | 15 |
|                                                                                                                                                                                                                                                                        | 20 |

```
25
```

| 1  |  |  |  |
|----|--|--|--|
| 5  |  |  |  |
| 10 |  |  |  |
| 15 |  |  |  |
| 20 |  |  |  |
| 25 |  |  |  |
| 30 |  |  |  |
| 35 |  |  |  |
| 40 |  |  |  |
| 45 |  |  |  |
| 50 |  |  |  |
| 55 |  |  |  |

5

10

15

20

25

30

35

40

45

|             | Table Te—Olgital properties                                                                                                                                                                                            |                     |                      |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----------------------|
| Property    | Implementation/Application                                                                                                                                                                                             | Туре                | Dynamic <sup>a</sup> |
| signalwidth | Width of the signal.                                                                                                                                                                                                   | longint<br>unsigned | No                   |
| sync        | Signal is synchronous to the clock of the component.                                                                                                                                                                   | boolean             | Yes                  |
| async       | Signal is asynchronous to the clock of the component.                                                                                                                                                                  | boolean             | Yes                  |
| cpuif_reset | Default signal to use for resetting the software interface logic. If <b>cpuif_reset</b> is not defined, this reverts to the default reset signal. This parameter only controls the CPU interface of a generated slave. | boolean             | Yes                  |
| field_reset | Default signal to use for resetting field implementations. If <b>field_reset</b> is not defined, this reverts to the default reset signal.                                                                             | boolean             | Yes                  |
| activelow   | Signal is active low (state of 0 means ON).                                                                                                                                                                            | boolean             | Yes                  |
| activehigh  | Signal is active high (state of 1 means ON).                                                                                                                                                                           | boolean             | Yes                  |

# 8.1 Introduction

<u>17.1</u>.

8. Signals

<u>Table 10</u> shows the **signal** properties.

8.2 Signal properties

# Table 10—Signal properties

A *signal* is a non-structural component used to define and instantiate wires (as additional inputs and/or outputs). Signals create named external ports on an implementation and can connect certain internal component design properties to the external world. *Signal definitions* have the same definition and

instantiation as other SystemRDL components; see 5.1. To use signals to control resets in SystemRDL, see

<sup>a</sup>Indicates whether a property can be assigned dynamically.

# 8.2.1 Semantics

- a) sync and async shall not be set to true on the same signal.
- b) A signal that does not specify **sync** or **async** is considered **sync**. A **signal** may not be both **sync** and **async**.
- c) activelow and active high shall not be set to true on the same signal.
- d) A signal that does specify active high or active low has no formal specified active state.
- e) **field\_reset** and **cpuif\_reset** follow the rules of application as defined in <u>17.1</u>.
- f) **cpuif\_reset** property can only be set **true** for one instantiated signal within a lexical scope.
- g) field reset property can only be set to true for one instantiated signal within a lexical scope.
- h) If **signalwidth** is specified in a **signal** component definition, the width specified by an instantiation 50 shall match.

# 8.2.2 Example

See the example in 8.3.2.

55

5

10

15

20

# 8.3 Signal definition and instantiation

In addition to the general rules for component definition and instantiation (see 5.1), the following rules also apply.

# 8.3.1 Semantics

- a) If **signalwidth** (see <u>8.2</u>) is not defined, signal instances may be declared as single-bit or multi-bit signals, as defined in (<u>5.1.2</u>).
- b) If **signalwidth** is not predefined in the component definition, a **signal** type may be instantiated as any width.
- c) If **signalwidth** is predefined during **signal** definition, any specified signal width shall match the predefined width.

# 8.3.2 Example

This example defines an 8-bit field and connects it to a **signal** so the reset value for this field is supplied externally.

30

25

35

40

45

50

5

10

15

20

25

30

35

40

45

50

# 9. Field component

# 9.1 Introduction

The field component is the lowest-level structural component in SystemRDL. No other structural component can be defined within a field component; however, **signal**, enumeration (**enum**), and **constraint** components can be defined within a **field** component. The *field component* is also the most varied component in SystemRDL because it is an abstraction representing different types of storage element structures. *Field definitions* have the same definition and instantiation as other SystemRDL components; see <u>5.1</u>.

Typically, a **field** component describes a flip-flop or wire/bus, along with the logic to set and sample its value for each instantiated field in the design. Properties specified for a field serve multiple purposes, from determining the nature of the behavior that is implied for a field to naming and describing a field. Storage elements accessed by software may contain a single entity or a number of bit-fields each with its own meaning and purpose. In SystemRDL, each entity in a software read or write is termed a *field*.

# 9.2 Defining and instantiating fields

Since a **field** component describes the lowest-level components within SystemRDL, it cannot contain other fields. Fields are instantiated in a register (**reg**) component (see <u>Clause 10</u>). Fields are defined and instantiated as described in 5.1, with the following additional semantics. See also 9.3.

- a) No other types of structural components shall be defined within a **field** component.
- b) Fields shall be instantiated only within a register component.
- c) Unless bit allocation is explicitly defined, fields shall be positioned sequentially in the order they are instantiated in a register, starting with the least significant bit. **lsb0** mode defines 0 as the least significant bit, which is the default, and **msb0** defines regwidth-1 as the least significant bit.
- d) In the default mode lsb0, unless bit allocation is explicitly defined, fields shall be positioned sequentially in the order they are instantiated in a register, starting at bit 0 with no padding between fields. (Each subsequent field's least significant bit (LSB) shall be made equal to one (1) greater than the most significant bit (MSB) of the previous field.)
- e) In the mode **msb0**, unless bit allocation is explicitly defined, fields shall be positioned sequentially in the order they are instantiated in a register, starting at bit regwidth-1 with no padding between fields. (Each subsequent field's least significant bit (LSB) shall be made equal to one (1) less than the most significant bit (MSB) of the previous field.)
- f) The exact bit position of instantiated fields in a register may determined by the SystemRDL compiler as described in <u>d</u> or specified explicitly by using exact indices (see <u>Clause 10</u>).
- g) The **msb0** and **lsb0** properties shall only be applied to an address map component (see <u>Clause 13</u>).
- h) A field instantiation which is not followed by a specific size or index contained square brackets ([]) defaults to size of the field definition's **fieldwidth** parameter. If the definition is anonymous, the default **fieldwidth** is 1.

# 9.3 Using field instances

Fields can be instantiated as single or multiple bits. Fields shall be instantiated in a register component and the field's bit position can be derived implicitly by a compiler or specified explicitly by a user. For the **field** component only, the field's bit position can be implicitly or explicitly specified. This notation is of the form

55

| 1  | a) for <i>definitive field instantiation</i>                                                                                                                                                                           |
|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | field_type [#(field_parameter_instance [, field_parameter_instance]*)] field_instance_element [, field_instance_element]*;                                                                                             |
| 5  | where                                                                                                                                                                                                                  |
|    | 1) <i>field_type</i> is the user-specified name for a previous definitively defined component of type field.                                                                                                           |
| 10 | 2) <i>field_parameter_instance</i> is specified as                                                                                                                                                                     |
|    | .field_param_name(field_param_val)                                                                                                                                                                                     |
| 15 | where <i>field_param_name</i> is the name of the parameter defined with the field and <i>field_param_val</i> is an expression whose result is the value of the parameter for this instance (see $5.1.2$ a).            |
|    | b) for anonymous field instantiation                                                                                                                                                                                   |
|    | <pre>field {field_body} field_instance_element [, field_instance_element]*;</pre>                                                                                                                                      |
|    | where                                                                                                                                                                                                                  |
| 20 | <i>field_body</i> is as described in $5.1.1$ , subject to limitations for a <i>definitive field instantiation</i> (see <u>a</u> ).                                                                                     |
|    | c) For both field instantiation types, <i>field_instance_element</i> is defined as                                                                                                                                     |
| 25 | field_instance_name [[constant_expression]   [constant_expression : constant_expression]]<br>[= constant_expression ]                                                                                                  |
|    | where                                                                                                                                                                                                                  |
|    | i) <i>field_instance_name</i> is the user-specified name for instantiation of the component.                                                                                                                           |
| 30 | ii) <i>constant_expression</i> is an expression that resolves to a longint unsigned.                                                                                                                                   |
| 50 | [constant_expression] specifies the instantiated field's bit width.                                                                                                                                                    |
|    | [constant_expression : constant_expression] is termed a range and defines the msb and lsb of the <b>field</b> within the context of the register within which it is instantiated.                                      |
| 35 | = $constant_expression$ specifies the field instance's reset value (see <u>9.5</u> ).                                                                                                                                  |
|    | Examples                                                                                                                                                                                                               |
|    | These are examples of the anonymous form.                                                                                                                                                                              |
| 40 |                                                                                                                                                                                                                        |
|    | <pre>field {} singlebitfield; // 1 bit wide, not explicit about position</pre>                                                                                                                                         |
|    | field {} somefield[4]; // 4 bits wide, not explicit about position                                                                                                                                                     |
| 45 | field {} somefield3[15:8]; // an 8 bit field with explicit indices                                                                                                                                                     |
| 5  | field {} somefield4[0:31]; // a 32 bit field with explicit indices                                                                                                                                                     |
| 50 | How the compiler resolves bit positions for implicit fields is detailed in <u>10.1</u> , which describes the register component. Single element arrays may be treated by a SystemRDL compiler as a scalar or an array. |
|    |                                                                                                                                                                                                                        |

# 9.4 Field access properties

The combination of field access properties specified for a **field** component determines the component's behavior. <u>Table 11</u> lists the available field access properties and describes how they are implemented.

| Property | Behavior/Application                                | Туре           | Dynamic <sup>a</sup> | 4  |
|----------|-----------------------------------------------------|----------------|----------------------|----|
| hw       | Design's ability to sample/update a <b>field</b> .  | access<br>type | No                   | -  |
| SW       | Programmer's ability to read/write a <b>field</b> . | access<br>type | Yes                  | 10 |

Table 11—Field access properties

<sup>a</sup>Indicates whether a property can be assigned dynamically.

# 9.4.1 Semantics

- All fields are given full access (read and write) by default. a)
- b)  $\mathbf{rw}$  (and  $\mathbf{wr}$ ) signify a field is both read and write;  $\mathbf{r}$  indicates read-only;  $\mathbf{w}$  indicates write-only; and na specifies no read/write access is allowed.
- All hardware-writable fields shall be continuously assigned unless a write enable is specified. c)
- When a field is writable by software and write-only by hardware (but not write-enabled), all softd) ware writes shall be lost on the next clock cycle. This shall reported as an error.
- After a reset occurs, a field with rw1 or w1 software access, that field can only be written once by e) software. All subsequent software writes are then ignored until the field is reset again.
- The standard implementation behavior is based on the combination of read and write properties f) shown in Table 12.

| Software | Hardware | Code sample                               | Implementation                    |
|----------|----------|-------------------------------------------|-----------------------------------|
| R+W      | R+W      | field f { sw = rw; hw = rw; };            | Storage element                   |
| R+W      | R        | <pre>field f { sw = rw; hw = r; };</pre>  | Storage element                   |
| R+W      | W        | <pre>field f { sw = rw; hw = w; };</pre>  | Storage element                   |
| R+W      | -        | <pre>field f { sw = rw; hw = na; };</pre> | Storage element                   |
| R        | R+W      | <pre>field f { sw = r; hw = rw; };</pre>  | Storage element                   |
| R        | R        | <pre>field f { sw = r; hw = r; };</pre>   | Wire/Bus – constant value         |
| R        | W        | <pre>field f { sw = r; hw = w; };</pre>   | Wire/Bus – hardware assigns value |
| R        | -        | <pre>field f { sw = r; hw = na; };</pre>  | Wire/Bus – constant value         |
| W        | R+W      | <pre>field f { sw = w; hw = rw; };</pre>  | Storage element                   |
| W        | R        | <pre>field f { sw = w; hw = r; };</pre>   | Storage element                   |
| W        | W        | field f { sw = w; hw = w; };              | Error – meaningless               |
| W        | -        | <pre>field f { sw = w; hw = na; };</pre>  | Error – meaningless               |
| -        | R+W      | <pre>field f { sw = na; hw =rw; };</pre>  | Undefined                         |
| -        | R        | field f { sw = na; hw = r; };             | Undefined                         |
| -        | W        | field f { sw = na; hw = w; };             | Error – unloaded net              |
| -        | -        | field f { sw = na; hw = na; };            | Error – nonexistent net           |

# Table 12—Field behavior based on properties

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change. 47

15

20

1 NOTE—Any hardware-writable **field** is inherently volatile, which is important for verification and test purposes.

### 9.4.2 Example

5 See <u>Table 12</u>.

10

15

25

30

35

40

45

# 9.5 Hardware signal properties

While all of the hardware signal properties can be set within a **field** definition, typically they are assigned after instantiation as these properties refer to items external to the field itself. By default, the reset value of fields shall be unknown, e.g., x in Verilog. A specification can use static or dynamic reset values; however, only static reset values shall be specified during field instantiation. The *reset value*, which is considered a property in SystemRDL, shall follow an equal sign (=) after the instance name and the eventual size or MSB/LSB information.

For the syntax for specifying reset values, see 9.3.

20 <u>Table 13</u> defines the hardware signal properties.

# Table 13—Hardware signal properties

| Property    | Behavior/Application                                                       | Туре                  | Dynamic <sup>a</sup> |
|-------------|----------------------------------------------------------------------------|-----------------------|----------------------|
| next        | The next value of the <b>field</b> ; the D-input for flip-flops.           | reference             | Yes                  |
| reset       | The reset value for the <b>field</b> when <b>resetsignal</b> is asserted.  | bit or ref-<br>erence | Yes                  |
| resetsignal | Reference to the signal used to reset the <b>field</b> (see <u>17.1</u> ). | reference             | Yes                  |

<sup>&</sup>lt;sup>a</sup>Indicates whether a property can be assigned dynamically.

# 9.5.1 Semantics

- a) Any integral value can be used to specify the reset value of a field.
- b) When a **field** has access properties of **sw=r** and **hw=w** without having a write enable, the existence of a reset value shall implement a storage element and the reset value only holds until the **reset** is deasserted.
- c) The reset value cannot be larger than can fit in the **field** or an error shall be reported.
- d) When **reset** is a reference, it shall reference another field of the same size. Upon reset, the **field** is reset to the current value of the referenced **field**.
  - e) **next** and **reset** cannot be self-referencing.
  - f) reset always has priority over next when resetsignal is asserted.
- g) If no reset value given, the field is not reset, even if it has a resetsignal.

# 9.5.2 Example

This example shows different types of hardware signal properties set during **field** instantiations.

```
55 signal {} some_reset;
field { reset = 1'b1; } a;
field {} b=0;
field {} c=0;
c->resetsignal = some_reset;
field {} d=0x0;
```

woclr and woset.

field {} e[23:21]=3'b101;

9.6 Software access properties

October 16, 2017

1

5

10

15

20

The software access field properties provide a means of specifying commonly used software modifiers on register fields. All the software properties which are defined as *boolean* values have a default value of **false**. Some of these properties perform operations that directly effect the value of a field (**rclr**, **woset**, and **woclr**), others allow the surrounding logic to effect software operations (**swwe** and **swwel**), and still others allow software operations effecting the surrounding logic (**swmod** and **swacc**). The **onread** property enables setting values equivalent to **rclr** and **rset**, while the **onwrite** property enables setting values equivalent to

b->reset = 3'bl; // Override the default reset value of e from 101 to 001

d->next = a; // d gets the value of a. D lags a by 1 clock.

<u>Table 14</u> defines the software access properties and uses pseudo-code snippets to define the behaviors. The pseudo-code is of Verilog style and should be interpreted as such. The exact behavior of these properties depends upon the semantics of the HDL generated by a particular SystemRDL implementation, together with the execution environment (e.g., simulator) for that HDL.

| Property    | <b>Behavior/Application</b>                                                                                                                              | Туре                               | Dynamic <sup>a</sup> |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|----------------------|
| rclr        | Clear on read (field = 0).                                                                                                                               | boolean                            | Yes                  |
| rset        | Set on read (field = all 1's).                                                                                                                           | boolean                            | Yes                  |
| onread      | Read side-effect. See <u>Table 15</u> .                                                                                                                  | onread-<br>type                    | Yes                  |
| woset       | Write one to set (field = field   write_data).                                                                                                           | boolean                            | Yes                  |
| woclr       | Write one to clear (field = field & ~write_data).                                                                                                        | boolean                            | Yes                  |
| onwrite     | Write function. See <u>Table 16</u> .                                                                                                                    | onwrite-<br>type                   | Yes                  |
| swwe        | Software write-enable active high (field = swwe ? new : cur-<br>rent).                                                                                   | <i>boolean</i> or <i>reference</i> | Yes                  |
| swwel       | Software write-enable active low (field = swwel ? current : new).                                                                                        | <i>boolean</i> or<br>reference     | Yes                  |
| swmod       | Assert when field is software written or cleared.                                                                                                        | boolean                            | Yes                  |
| swacc       | Assert when field is software accessed.                                                                                                                  | boolean                            | Yes                  |
| singlepulse | The field asserts for one cycle when written 1 and then clears back to 0 on the next cycle. This creates a single-cycle pulse on the hardware interface. | boolean                            | Yes                  |

# Table 14—Software access properties

<sup>a</sup>Indicates whether a property can be assigned dynamically.

50

55

5

10

15

20

25

30

35

40

45

50

55

| onread<br>property<br>value | Behavior/Application                                                                           |
|-----------------------------|------------------------------------------------------------------------------------------------|
| rclr                        | All the bits of the field are cleared on read (field = 0).                                     |
| rset                        | All the bits of the field are set on read (field = all 1's).                                   |
| ruser                       | The read modifies the field in a way which does not match the other defined read side-effects. |

# Table 15—Software read side-effect onread value

| onwrite<br>property<br>value | Behavior/Application                                                                                                                      |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| woset                        | Bitwise write one to set (field = field   write_data).                                                                                    |
| woclr                        | Bitwise write one to clear (field = field & ~write_data).                                                                                 |
| wot                          | Bitwise write one to toggle (field = field ^ write_data).                                                                                 |
| WZS                          | Bitwise write zero to set (field = field   ~write_data).                                                                                  |
| wzc                          | Bitwise write zero to clear (field = field & write_data).                                                                                 |
| wzt                          | Bitwise write zero to toggle (field = field ~^ write_data).                                                                               |
| wclr                         | All bits of the field are cleared on write (field = 0).                                                                                   |
| wset                         | All bits of the field are set on write (field = `1).                                                                                      |
| wuser                        | The write modifies the field in a way which does not match the other defined write functions and is not a write without a write function. |

# Table 16—Software write function onwrite values

# 9.6.1 Semantics

| a) | swmod indicates a generated output signal shall notify hardware when this field is modified by soft- |
|----|------------------------------------------------------------------------------------------------------|
|    | ware. The precise name of the generated output signal is beyond the scope of this document. Addi-    |
|    | tionally, this property may be used on the right-hand side of an assignment to another property.     |

NOTE—Since **rclr**, **rset**, and **onread** modify the field value with a software read transaction, the implementation of properties like **swmod** are asserted during software reads when **rclr** or **rset** are **true** or **onread** has a value.

- b) **swacc** indicates a generated output signal shall notify hardware when this field is accessed by software. The precise name of the generated output signal is beyond the scope of this document. Additionally, this property may be used on the right-hand side of an assignment to another property.
- c) Fields specified with software access properties in <u>Table 14</u> need to consider how they effect the behavior defined in <u>Table 12</u>. For example, if a field is **rclr**, this results in a storage element regardless of whether or not the field is writable by software.
  - d) swwe and swwel have precedence over the software access property in determining its current access state, e.g., if a field is declared as sw=rw, has a swwe property, and the value is currently false, the effective software access property is sw=r.
  - e) **swwe** and **swwel** are mutually exclusive.
  - f) When specified, **rclr** resets a field to 0 and not its default value.
- g) singlepulse fields shall be instantiated with a width of 1 and the reset value shall be specified as 0.
- h) **onread, rclr and rset** are mutually exclusive; only one can be set per field.

| d with an <b>onwrite</b> property shall have software write access. | 5                                                                           |
|---------------------------------------------------------------------|-----------------------------------------------------------------------------|
| d with an an an initially exclusive; only one can be set per field  |                                                                             |
| it<br>d                                                             | te, woclr, and woset are mutually exclusive; only one can be set per field. |

This example applies software properties using implicit and explicit methods of setting the properties.

```
field {
   rclr; // Implicitly set the rclr property to true
   swwe = true; // Explicitly set the swwe property to true
} a;
```

Example 2

This example uses the **default** keyword with these software properties and then overrides them.

```
reg example2 {
                                                                                      25
   default woclr = true; // Explicitly set default of woclr to true
   default swmod;
                          // Implicitly set default of swmod to true
   field {} a;
                           // Assumes defaults
   field {} b;
                           // Assumes defaults
   b->rclr=false; // Dynamic Assignment to false
                                                                                      30
   field {rclr = false; } c;// Overrides rclr default
   field {swmod = false; } d;// Overrides swmod default
   field {rclr = false; swmod = false; } e;// Overrides both defaults
   d->next = b->swmod;
      // next value of d will be field b's 1-bit software mod flag generated
                                                                                      35
      // by SystemRDL
```

```
};
```

# 9.7 Hardware access properties

Hardware access properties can be applied to fields to determine when hardware can update a hardware writable field (we and wel), generate input pins which allow designers to clear or set the field (hwclr and hwset) by asserting a single pin, or generate output pins which are useful for designers (anded, ored, and xored).

Write-enable is critical for certain software-writable fields. The clear on read feature (rclr, see Table 14) returns the **next** value (see 9.5) to software before clearing the field. When not write-enabled, the current value is used instead since the "next" value is the current value. In the case of counters, the write-enable is used to determine when a counter can be incremented.

The hwenable and hwmask properties can specify a bus showing which bits may be updated after any write-enables, hardware-clears/-sets or counter-increment has been performed. The hwenable and hwmask properties are similar to we and wel, but each has unique functionality. The we and wel act as write enables to an entire field for a single bit or multiple bits. The hwmask and hwenable are essentially write enables or write masks, but are applied on a bit basis. The priority of assignments a SystemRDL compiler should use is 50

40

45

15

- 1 shown in <u>Table 17</u>, which depicts a flow of information from left to right showing the stages that happen when updating a field from its current value to determine its next state value.
- A field's width is typically determined when it is instantiated; however, there are times when specifying a field's width up-front is critical. If specified, the **fieldwidth** property forces all instances of the field to be a specified width. If a field is instantiated without a specified width, the field shall be **fieldwidth** bits wide. It shall be an error if the field is instantiated with an explicitly specified width that differs from the **fieldwidth**.
- 10

| Table | 17—Assignme | nt priority |
|-------|-------------|-------------|
|-------|-------------|-------------|

| Event stage ->                     | Hardware next stage ->      | Field next stage -> | Register assign stage |
|------------------------------------|-----------------------------|---------------------|-----------------------|
| we/wel/intr edge logic             | counter incr / counter decr | SW/HW selection     | wire / dff assign     |
| counter load / counter<br>we logic | hwset / hwclr               |                     |                       |
|                                    | intr mask/en/sticky         |                     |                       |

20

25

30

35

40

45

50

55

Table 18 defines the hardware access properties.

| Property   | <b>Behavior/Application</b>                                                                                                                                                     | Туре                           | Dynamic <sup>a</sup> |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|----------------------|
| we         | Write-enable (active high).                                                                                                                                                     | boolean or<br>reference        | Yes                  |
| wel        | Write-enable (active low).                                                                                                                                                      | <i>boolean</i> or<br>reference | Yes                  |
| anded      | Logical AND of all bits in <b>field</b> .                                                                                                                                       | boolean                        | Yes                  |
| ored       | Logical OR of all bits in <b>field</b> .                                                                                                                                        | boolean                        | Yes                  |
| xored      | Logical XOR of all bits in <b>field</b> .                                                                                                                                       | boolean                        | Yes                  |
| fieldwidth | Determines the width of all instances of the <b>field</b> . This number shall be a numeric. The default value of <b>fieldwidth</b> is undefined.                                | longint<br>unsigned            | No                   |
| hwclr      | Hardware clear. This <b>field</b> need not be declared as hardware-writable.                                                                                                    | <i>boolean</i> or<br>reference | Yes                  |
| hwset      | Hardware set. This <b>field</b> need not be declared as hardware-writable.                                                                                                      | <i>boolean</i> or<br>reference | Yes                  |
| hwenable   | Determines which bits may be updated after any write enables, hard-<br>ware clears/sets or counter increment has been performed. Bits that are<br>set to 1 will be updated.     | reference                      | Yes                  |
| hwmask     | Determines which bits may be updated after any write enables, hard-<br>ware clears/sets or counter increment has been performed. Bits that are<br>set to 1 will not be updated. | reference                      | Yes                  |

# Table 18—Hardware access properties

"lr

<sup>a</sup>Indicates whether a property can be assigned dynamically.

# 9.7.1 Semantics

a) we determines this field is hardware-writable when set, resulting in a generated input which enables hardware access.

| b)     | wel determines this field is hardware-writable when not set, resulting in a generated input which enables hardware access.                                                               | 1  |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| c)     | we and wel are mutually exclusive.                                                                                                                                                       |    |
| d)     | hwenable and hwmask are mutually exclusive.                                                                                                                                              | 5  |
| 9.7.2  | Example                                                                                                                                                                                  |    |
| This e | example shows the application of a write-enable and the <i>boolean</i> anded.                                                                                                            | 10 |
| r      | <pre>reg example {     default sw = r;</pre>                                                                                                                                             |    |
|        | field { anded;} a[4]=0; // This field will update its value every clock<br>// cycle. hw=rw by default. This field will also have<br>// an output ANDing the 4 bits of the field together | 15 |

// where the we is asserted. The name of the we signal is

```
};
```

# 20

25

30

35

40

45

# 9.8 Counter properties

SystemRDL defines several special purpose fields, including counters. A *counter* is a special purpose field which can be incremented or decremented by constants or dynamically specified values. Additionally, counters can have properties that allow them to be cleared, set, and indicate various status conditions like **overflow** and **underflow**.

field { we; } b=0;// This field will only update on clock cycles

// a function of the SystemRDL Compiler.

# 9.8.1 Counter incrementing and decrementing

When a **field** is defined as a **counter**, the value stored by the field is the counter's current value. There is an implication of an additional input which shall increment/decrement the counter when asserted. Counter incrementing and decrementing in SystemRDL are controlled via the counters **incrvalue/decrvalue** and **incrwidth/decrwidth** properties. The **incrvalue/decrvalue** property defaults to a value of 1, but can be set to any constant that can be represented by the width of the counter. Additionally, the **incrvalue/decrvalue** can be assigned to any **signal** or other **field** in the current address map scope so counters can increment using dynamic or variable values. The **incrwidth/decrwidth** properties can be used as an alternative to **incrvalue/decrvalue** so an external interface can be used to control the **incrvalue/decrvalue** externally from SystemRDL. A SystemRDL compiler shall imply the nature of a counter as a up counter, a down counter, or an up/down counter by the properties specified for that counter field.

By default, counters are incremented/decremented by one (1), but another static or dynamic increment/ decrement value can be specified. The increment/decrement value shall be equal to or smaller than the field's width.

*Dynamic values* may be another field instance in the address map of the same or smaller width, or another signal in the design. If an externally defined signal is used for dynamic incrementing, its input is inferred to have the same width as the counter.

Additionally, the properties **incr** and **decr** can be used to control the increment and decrement events of a counter. These do not control the increment or decrement values, as **incrvalue** and **decrvalue**, but the actual increment of the counter (as shown in *Example 2*). These properties can be only be assigned as references to another component.

| 1  | Example 1                                                                                                                                                            |
|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | This shows counter incrementing and decrementing.                                                                                                                    |
| 5  | <pre>field counter_f { counter; };</pre>                                                                                                                             |
| 10 | <pre>counter_f count1[4]; // Define a 4 bit counter from 3 to 0 count1-&gt;incrvalue=4'3; // Increment the counter by 3 when incrementing</pre>                      |
| 15 | <pre>counter_f count2[3]; // Define a 3 bit counter from 6:4   count2-&gt;decrwidth=2; // provide 2 bit interface for a user to decide the decr</pre>                |
| 20 | <pre>field {} count4_incr[8] = 8'h0f; // define a field to control the incr</pre>                                                                                    |
| 25 | <pre>counter_f count4[8]=0;<br/>count4-&gt;incrvalue = count4_incr; // Counter is incremented by the value of</pre>                                                  |
|    | This example uses <b>incr</b> to connect two 16-bit counters together to create a 32-bit counter.                                                                    |
| 30 | <pre>field some_counter {    counter;    we;</pre>                                                                                                                   |
|    | <pre>}; // End of Reg: some_counter</pre>                                                                                                                            |
| 35 | <pre>reg some_counter_reg {     regwidth=16;     some_counter count[16]=0; // Create 16 bit counter POR to 0 }; // End of Reg:</pre>                                 |
| 40 | <pre>// Example 32 bit up counter some_counter_reg count1_low; some_counter_reg count1_high;</pre>                                                                   |
| 45 | <pre>count1_high.count-&gt;incr = count1_low.count-&gt;overflow; // Daisy chain the counters together to create a 32 bit counter from the 2 // 16 bit counters</pre> |

# 9.8.2 Counter saturation and threshold

50 Counters are unsaturated by default, e.g., a 4-bit counter with a value of 0xf that is incremented by 1 has the value 0x0. This is referred to as *rolling over*. The value of a increaturate saturating counter shall never exceed the increment saturation value and the value of a decreaturate saturating counter shall never be less than the decrement saturation value. By default, the increment saturation value is the maximum value that the counter can hold and the decrement saturation value is zero (0). Assigning a static or dynamic saturated value is similar to assigning increment/decrement values, see <u>9.8.1</u>.

| Counters in SystemRDL may have an optional (static or dynamic) threshold value. The <b>threshold</b> property does not cap the value of a counter in the way <b>saturate</b> does; instead, threshold counters are inferred to contain an output which designates whether the counter's value exceeds the threshold. See also <u>9.8.1</u> .                                                              | 1  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| saturate and threshold counters may be used individually and specified in any order.                                                                                                                                                                                                                                                                                                                      | 5  |
| Example 1                                                                                                                                                                                                                                                                                                                                                                                                 |    |
| This shows counter saturation and thresholds.                                                                                                                                                                                                                                                                                                                                                             | 10 |
| <pre>field counter_f { counter; }; counter_f count1[4]; // Define a 4 bit counter from 3 to 0 count1-&gt;incrsaturate=4'hf; // keeps the counter from counting past 4'hf</pre>                                                                                                                                                                                                                            | 15 |
| <pre>counter_f count2[3]; // Define a 3 bit counter from 6:4 count2-&gt;decrthreshold=3'h2; // provide assertion when count hits 2</pre>                                                                                                                                                                                                                                                                  | 15 |
| <pre>counter_f count3[5]=0; // Defines a 5 bit counter from 11 to 7<br/>count3-&gt;incrsaturate;// Implies 5'h1F by default<br/>count3-&gt;decrsaturate; // Implies 5'h00 by default<br/>count3-&gt;decrthreshold=5'h3;</pre>                                                                                                                                                                             | 20 |
| <pre>field {} count4_sat[4] = 4'h2; // define a field to control the saturate value</pre>                                                                                                                                                                                                                                                                                                                 | 25 |
| <pre>counter_f count4[4]=0; // This counters saturate and threshold are both dynamic<br/>count4-&gt;incrthreshold = count4_thresh;<br/>count4-&gt;incrsaturate = count4_sat;</pre>                                                                                                                                                                                                                        | 20 |
| Besides assigning values or references to the <b>saturate</b> or <b>threshold</b> properties on the left-hand side of an assignment in SystemRDL, these properties can also be referenced on the right-hand side of an expression to indicate the threshold has been crossed or the counter has saturated. This is often useful for generating an interrupt indicating a specific condition has occurred. | 30 |
| Example 2                                                                                                                                                                                                                                                                                                                                                                                                 | 35 |
| This shows right-hand side usage of <b>saturate</b> and <b>threshold</b> .                                                                                                                                                                                                                                                                                                                                |    |
| <pre>field {} count4_sat[4] = 4'h2; // define a field to control the saturate value</pre>                                                                                                                                                                                                                                                                                                                 | 40 |
| <pre>field {} count4_thresh[4] =4'ha;<br/>field {} is_at_threshold=0;<br/>field {} is_saturated=0;</pre>                                                                                                                                                                                                                                                                                                  |    |
| <pre>counter_f count4[4]=0; // This counters saturate and threshold are both dynamic<br/>count4-&gt;incrthreshold = count4_thresh;<br/>count4-&gt;incrsaturate = count4_sat;</pre>                                                                                                                                                                                                                        | 45 |
| <pre>// Single-bit result of threshold comparison assigned to is_at_threshold field is_at_threshold-&gt;next = count4-&gt;incrthreshold; is_saturated-&gt;next = count4-&gt;incrsaturate;</pre>                                                                                                                                                                                                           | 50 |
| Counters can also use the properties <b>underflow</b> and <b>overflow</b> to indicate the counter has wrapped (either decrementing when 0 for <b>decrsaturate</b> or incrementing when all 1s for <b>incrsaturate</b> ). These are useful for many applications such as generating an interrupt based on a counter overflow/underflow.                                                                    | 55 |

# 1 Example 3

This shows overflow and underflow counter properties.

```
5 field counter_f { counter; };
field {} has_overflowed;
counter_f count1[5]=0; // Defines a 5 bit counter from 6 to 1
count1->incrthreshold=5'hF;
```

```
has_overflowed->next = count1->overflow;
```

Table 19 defines the counter field properties.

15

|    | Property           | <b>Behavior/Application</b>                                                                                                                                                             | Туре                               | Dynamic <sup>a</sup> |
|----|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|----------------------|
|    | counter            | Field implemented as a counter.                                                                                                                                                         | boolean                            | Yes                  |
| 20 | threshold          | This is an alias of <b>incrthreshold</b> .                                                                                                                                              | boolean,<br>bit, or ref-<br>erence | Yes                  |
| 25 | saturate           | This is an alias of <b>incrsaturate</b> .                                                                                                                                               | boolean,<br>bit, or ref-<br>erence | Yes                  |
|    | incrthresh-<br>old | Indicates the counter has a threshold in the incrementing direction. A comparison value or the result of a comparison. See also: <u>9.8.2.1</u> .                                       | boolean,<br>bit, or ref-<br>erence | Yes                  |
| 30 | incrsaturate       | Indicates the counter saturates in the incrementing direction. A comparison value or the result of a comparison. See also: $9.8.2.1$ .                                                  | boolean,<br>bit, or ref-<br>erence | Yes                  |
|    | overflow           | Overflow signal asserted when counter overflows or wraps.                                                                                                                               | boolean                            | Yes                  |
|    | underflow          | Underflow signal asserted when counter underflows or wraps.                                                                                                                             | boolean                            | Yes                  |
| 35 | incrvalue          | Increment counter by specified value.                                                                                                                                                   | bit or ref-<br>erence              | Yes                  |
| 40 | incr               | References the <b>counter</b> 's increment signal. Use to actually increment the counter, i.e, the actual counter increment is controlled by another component or signal (active high). | reference                          | Yes                  |
| -  | incrwidth          | Width of the interface to hardware to control incrementing the counter externally.                                                                                                      | longint<br>unsigned                | Yes                  |
| 45 | decrvalue          | Decrement counter by specified value.                                                                                                                                                   | bit or ref-<br>erence              | Yes                  |
| 45 | decr               | References the <b>counter</b> 's decrement signal. Use to actually decrement the counter, i.e, the actual counter decrement is controlled by another component or signal (active high). | reference                          | Yes                  |
| 50 | decrwidth          | Width of the interface to hardware to control decrementing the counter externally.                                                                                                      | longint<br>unsigned                | Yes                  |

55

| Property Behavior/Application |                                                                                                                                              | Туре                               | Dynamic <sup>a</sup> |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|----------------------|
| decrsatu-<br>rate             | Indicates the counter saturates in the decrementing direction. A comparison value or the result of a comparison. See also: $9.8.2.1$ .       | boolean,<br>bit, or ref-<br>erence | Yes                  |
| decrthresh-<br>old            | Indicates the counter has a threshold in the decrementing direction. A comparison value or the result of a comparison. See also: $9.8.2.1$ . | boolean,<br>bit, or ref-<br>erence | Yes                  |

# Table 19—Counter field properties (Continued)

<sup>a</sup>Indicates whether a property can be assigned dynamically.

# 9.8.2.1 Semantics

- a) incrwidth and incrvalue are mutually exclusive (per counter).
- b) **decrwidth** and **decrvalue** are mutually exclusive (per **counter**).
- c) When **incrsaturate** has the Boolean value true, the incrementing saturate value is the *maximum* value (2<sup>(number of counter bits) -1) of the counter. When **incrsaturate** has the Boolean value false, the counter does not saturate in the incrementing direction.</sup>
- d) When **incrthreshold** has the Boolean value true, the incrementing threshold value is the *maximum* value (2^(number of counter bits) -1) of the counter. When **incrthreshold** has the Boolean value false, the counter does not have a threshold in the incrementing direction.
- e) When **decrsaturate** has the Boolean value true, the decrementing saturate value is 0. When **decrsaturate** has the Boolean value false, the counter does not saturate in the decrementing direction.
- f) When decrthreshold has the Boolean value true, the decrementing threshold value is 0. When decrthreshold has the Boolean value false, the counter does not have a threshold in the decrementing direction.
- g) **incrthreshold/decrthreshold** used on the left-hand side of an assignment in SystemRDL assigns the counter's threshold to the number or reference specified in the right-hand side of the assignment.
- h) **incrsaturate/decrsaturate** used on the left-hand side of an assignment in SystemRDL assigns the counter's saturation property to the number or reference specified in the right-hand side of the assignment.
- i) **incrthreshold/decrthreshold** used on the right-hand side of an assignment in SystemRDL is referencing the counter's threshold output, which is a single bit value indicating whether the threshold has been crossed. This value shall only be asserted to 1 when the value is greater than or equal to **incrthreshold/threshold** or is less than or equal to **decrthreshold**.
- j) incrsaturate/decrsaturate used on the right-hand side of an assignment in SystemRDL is referenc ing the counter's saturate output, which is a single bit value indicating whether the saturation has occurred. This value shall only be asserted to 1 when the value of the counter meets or exceeds the saturation value specified.
- k) All static values used in <u>Table 19</u> shall fit within the width of the field. All references need to be the same width.

# 9.8.2.2 Example

See *Examples 1 - 3* in <u>9.8.2</u>.

55

50

1

5

10

15

20

25

30

35

# 9.9 Interrupt properties

1

5

10

25

30

35

45

50

Designs often have a need for interrupt signals for various reasons, e.g., so software can disable or enable various blocks of logic when errors occur. *Interrupts* are unlike most **field** properties in that they operate on both the register level and the field level. Any register which instantiates an interrupt field (a field with the **intr** property specified) is considered an interrupt register. Each *interrupt register* has an associated interrupt signal which is the logical OR of all interrupt fields in the register (post-masked/enabled if the fields are masked or enabled). By default, this interrupt signal is inferred as an output; however, register files and/or address maps can be used to further aggregate these interrupts (see <u>Clause 12</u>, <u>Clause 13</u>, and the hierarchical interrupt example in <u>17.2</u>). Interrupts may be masked, or enabled by other **fields** or externally defined **signals**—they have an easy way of being turned on and off by software if desired.

By default, all interrupt fields have the **stickybit** property; this can be suppressed (using **nonsticky**) or changed to **sticky**. The **stickybit** and **sticky** properties are similar as they both define a field as *sticky*, meaning once hardware or software has written a one (1) into any bit of the field, the value is stuck until software clears the value (using a write or clear on read). The difference between **stickybit** and **sticky** is each bit in a **stickybit** field is handled individually, whereas **sticky** applies a sticky state to all bits in an instantiated field (which is useful when designers need to store a multi-bit value, such as an address). For single-bit fields, there is no difference between **stickybit** and **sticky**.

> By default, all interrupts are level-triggered, i.e., the interrupt is triggered at the positive edge of the clock if the **next** value of the interrupt field is asserted. Since interrupts are typically **stickybit**, the value is latched and held until software clears the interrupt. The edge-interrupt triggering mechanisms (**posedge**, **negedge**, and **bothedge**), like level-triggered interrupts, are synchronous.

A **nonsticky** interrupt is typically used for hierarchical interrupts, e.g., a design has a number of interrupt registers (meaning a number of registers with one or more interrupt fields instantiated within). Rather than promoting a number of interrupt signals, the developer can specify an aggregate interrupt register (typically unmasked, though a **mask/enable** may be specified) containing the same number of fields as there are interrupt signals to aggregate. Each field is defined as a **nonsticky** interrupt and the **next** value of each interrupt is directly assigned an interrupt pin for each interrupt register to be aggregated. Interrupt types are defined with modifiers to the **intr** property. These modifiers are not *booleans* and are only valid in conjunction with the **intr** property. The **nonsticky** modifier can be used in conjunction with **posedge**, **negedge**, **bothedge**, and **level**.

The syntax for a interrupt property modifiers appears as follows.

[nonsticky] [posedge | negedge | bothedge | level] intr;

40  $\underline{\text{Table 20}}$  lists and describes the available interrupt types.

| Interrupt                                          | Description                                                                                                                                                                                 |  |
|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| posedge Interrupt when next goes from low to high. |                                                                                                                                                                                             |  |
| negedge                                            | Interrupt when next goes from high to low.                                                                                                                                                  |  |
| bothedge                                           | Interrupt when next changes value.                                                                                                                                                          |  |
| level                                              | Interrupt while the next value is asserted and main-<br>tained (the default).                                                                                                               |  |
| nonsticky                                          | Defines a non-sticky (hierarchical) interrupt; the associ-<br>ated interrupt field shall not be locked. This modifier can<br>be specified in conjunction with the other interrupt<br>types. |  |

# Table 20—Interrupt types

5

10

15

Furthermore, there are additional interrupt properties that can be used to mask or enable an interrupt. The **enable**, **mask**, **haltenable**, and **haltmask** properties (see <u>Table 21</u>) are all properties of type *reference* that are used to point to other fields or signals in the SystemRDL description. The **mask** and **haltmask** properties can be assigned to **fields** and used to control the propagation of an interrupt. If an interrupt bit is set and connected to a **mask/enable**, the interrupt's final value is gated by the **mask/enable**. The logical description of this operation is

final interrupt value = interrupt value & enable; final interrupt value = interrupt value & !mask; final halt interrupt value = interrupt value & haltenable; final halt interrupt value = interrupt value & !haltmask. //Further information on interrupts and their behavior as well a more complete //example can be found in <u>17.2</u>.

```
Example
```

```
addrmap top {
  reg block_int_r {
    name = "Example Block Interrupt Register";
                                                                                       20
    desc = "This is an example of an IP Block with 3 int events. 2
            of these events are non fatal
            and the third event multi_bit_ecc_error is fatal";
    default hw=w; // HW can Set int only
    default sw=rw; // SW can clear
                                                                                       25
    default woclr; // Clear is via writing a 1
    field {
      desc = "A Packet with a CRC Error has been received";
      level intr;
                                                                                       30
    \} crc_error = 0x0;
    field {
      desc = "A Packet with an invalid length has been received";
      level intr;
    } len_error = 0x0;
                                                                                       35
    field {
      desc="An uncorrectable multi-bit ECC error has been received";
      level intr;
    } multi_bit_ecc_error = 0 ;
  }; // End of Reg: block_int
                                                                                       40
  reg block_int_en_r {
    name = "Example Block Interrupt Enable Register";
    desc = "This is an example of an IP Block with 3 int events";
    default hw=na; // HW can't access the enables
                                                                                       45
    default sw=rw; // SW can control them
    field {
      desc = "Enable: A Packet with a CRC Error has been received";
    } crc_error = 0x1;
                                                                                       50
    field {
      desc = "Enable: A Packet with an invalid length has been
              received";
    } len_error = 0x1;
```

| 1  | field {                                                                     |
|----|-----------------------------------------------------------------------------|
|    | desc = "Enable: A Packet with an invalid length has been received";/        |
|    | $\frac{1}{1000}$ multi bit ecc error = 0x0;                                 |
| 5  | }; // End of Reg: block_int_en_r                                            |
|    | req block halt_en_r {                                                       |
|    | name = "Example Block Halt Enable Register";                                |
| 10 | <pre>desc = "This is an example of an IP Block with 3 int events";</pre>    |
|    | default hw=na; // HW can't access the enables                               |
|    | default sw=rw; // SW can control them                                       |
| 15 | field {                                                                     |
| 10 | <pre>desc = "Enable: A Packet with a CRC Error has been received";</pre>    |
|    | } crc_error = 0x0; // not a fatal error do not halt                         |
|    | desc = "Enable: A Packet with an invalid length has been received";         |
|    | } len_error = 0x0; // not a fatal error do not halt                         |
| 20 | field {                                                                     |
|    | desc = "Enable: A Packet with an invalid length has been received";         |
|    | <pre>} multi_bit_ecc_error = 0x1; // fatal error that will </pre>           |
|    | Cause device to mait                                                        |
| 25 | J/ // End of Keg. block_natt_en_i                                           |
|    | // Block A Registers                                                        |
|    | block_int_r block_a_int; // Instance the Leaf Int Register                  |
| 30 | <pre>block_int_en_r block_a_int_en; // Instance the corresponding Int</pre> |
| 30 | block halt en r block a halt en; // Instance the corresponding halt         |
|    | // enable register                                                          |
|    | // This block connects the int bits to their corresponding int enables and  |
| 35 | // halt enables                                                             |
|    | <pre>block_a_int.crc_error-&gt;enable = block_a_int_en.crc_error;</pre>     |
|    | <pre>block_a_int.len_error-&gt;enable = block_a_int_en.len_error;</pre>     |
|    | block_a_int.multi_bit_ecc_error->enable =                                   |
|    | plock_a_int_en.multi_plt_ecc_error;                                         |
| 40 | block a int len error->haltenable = block a halt en len error;              |
|    | block a int.multi bit ecc error->haltenable =                               |
|    | block_a_halt_en.multi_bit_ecc_error;                                        |
|    | } ;                                                                         |

Table 21 defines the interrupt properties.

| Table 21—Field | access | interrupt | properties |
|----------------|--------|-----------|------------|
|----------------|--------|-----------|------------|

| Property | Behavior/Application                                                                                                                   | Туре      | Dynamic <sup>a</sup> |
|----------|----------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------------|
| intr     | Interrupt, part of interrupt logic for a register.                                                                                     | boolean   | Yes                  |
| enable   | Defines an interrupt enable (the inverse of <b>mask</b> ); i.e., which bits in an interrupt field are used to assert an interrupt.     | reference | Yes                  |
| mask     | Defines an interrupt mask (the inverse of <b>enable</b> ); i.e., which bits in an interrupt field are not used to assert an interrupt. | reference | Yes                  |

45

50

5

10

15

| Property   | <b>Behavior/Application</b>                                                                                                                                                                                    | Туре      | Dynamic <sup>a</sup> |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------------|
| haltenable | Defines a halt enable (the inverse of <b>haltmask</b> ); i.e., which bits in an interrupt field are set to de-assert the halt out.                                                                             | reference | Yes                  |
| haltmask   | Defines a halt mask (the inverse of <b>haltenable</b> ); i.e., which bits in an interrupt field are set to assert the halt out.                                                                                | reference | Yes                  |
| sticky     | Defines the entire field as sticky; i.e., the value of the associated inter-<br>rupt field shall be locked until cleared by software (write or clear on<br>read).                                              | boolean   | Yes                  |
| stickybit  | Defines each bit in a field as sticky (the default); i.e., the value of each bit in the associated interrupt field shall be locked until the individual bits are cleared by software (write or clear on read). | boolean   | Yes                  |

| Table 21—Field access | s interrupt properties | (Continued) |
|-----------------------|------------------------|-------------|
|-----------------------|------------------------|-------------|

<sup>a</sup>Indicates whether a property can be assigned dynamically.

# 9.9.1 Semantics

|                |                                                                                                                                                                                                                       | 20 |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| a)             | enable and mask are mutually exclusive.                                                                                                                                                                               | 20 |
| b)             | haltenable and haltmask are mutually exclusive.                                                                                                                                                                       |    |
| c)             | nonsticky, sticky, and stickybit are mutually exclusive.                                                                                                                                                              |    |
| d)             | The <b>sticky</b> and <b>stickybit</b> properties are normally used in the context of interrupts, but may be used in other contexts as well.                                                                          | 25 |
| e)             | Assignments of <b>signals</b> or <b>fields</b> to the <b>enable</b> , <b>mask</b> , <b>haltenable</b> , and <b>haltmask</b> properties shall be of the same bit width as the <b>field</b> .                           |    |
| f)             | <b>posedge</b> , <b>negedge</b> , <b>bothedge</b> , and <b>level</b> are only valid if <b>intr</b> is true and can only be specified as modifiers to the <b>intr</b> property—they cannot be specified by themselves. | 30 |
| g)             | posedge, negedge, bothedge, and level are mutually exclusive.                                                                                                                                                         |    |
| 9.9.2          | Example                                                                                                                                                                                                               | 25 |
| This e         | example illustrates the use of <b>sticky</b> and <b>stickybit</b> interrupts.                                                                                                                                         | 55 |
| f:<br>f:<br>f: | <pre>ield { level intr; } some_int=0;<br/>ield {} some_mask = 1'b1;<br/>ield {} some_enable = 1'b1;</pre>                                                                                                             | 40 |
| 50<br>50       | ome_int->mask = some_mask;<br>ome_int->haltenable = some_enable;                                                                                                                                                      | 40 |
| f:<br>//       | ield { level intr; rclr;} a_multibut_int[4]=0;<br>/ Individual bits being set 1 will<br>/ Accumulate as this is stickybit by default                                                                                  | 45 |
| f:<br>//       | ield { posedge intr; sticky; woclr; } some_multibit_int[4]=0;<br>/ This field will hold the first value written to it until its cleared by<br>/ writing ones                                                          | 50 |

# 9.10 Miscellaneous field properties

There are additional properties for **fields** which do not fall into any of the previous categories. This subclause describes these additional miscellaneous properties.

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change. 61

- a) The **encode** property enumerates a **field** definition for additional clarification purposes. **encode** can only be applied to a validly scoped component of type **enum**.
  - b) The **precedence** property specifies how contention issues are resolved during field updates, e.g., a field which has **hw=rw** and **sw=rw**.
    - precedence = sw (the default) indicates software takes precedence over hardware on accessing registers (over the hardware updates of type we, wel, incr, decr, hwset, and hwclr). This is a field-only property and does not affect the other fields in the register.
- 2) precedence = hw indicates hardware takes precedence over software on accessing registers (on the hardware updates of type we, wel, incr, decr, hwset, and hwclr). This is a field-only property and does not affect the other fields in the register.
  - 3) In some cases of collisions between hardware and software, both operations can be satisfied, but this is beyond the scope of this document and such behavior is undefined.
- c) The **paritycheck** property can be applied to a **field** to indicate it should be covered and checked by parity.
  - 1) The default is **false** (no check occurs).
  - 2) Not all fields in a register need to have the same **paritycheck** property value.
  - 3) Parity is calculated each cycle on the next value of every qualifying bit and the result is stored.
  - 4) Parity is checked each cycle by comparing the generated parity on the current value of each qualifying bit with the stored parity result. A parity\_error output for the addrmap is set to 1 when the generated value and stored parity do not match.
- 25 <u>Table 22</u> details the miscellaneous field properties.

# Table 22—Miscellaneous properties

| Property    | Behavior/Application                                                                                  | Туре                               | Dynamic <sup>a</sup> |
|-------------|-------------------------------------------------------------------------------------------------------|------------------------------------|----------------------|
| encode      | Binds an enumeration to a field.                                                                      | <i>reference</i><br>to <i>enum</i> | Yes                  |
| precedence  | Controls whether precedence is granted to hardware $(hw)$ or software when contention occurs $(sw)$ . | prece-<br>dencetype                | Yes                  |
| paritycheck | Indicates whether this field is to be checked by parity.                                              | boolean                            | No                   |

<sup>a</sup>Indicates whether a property can be assigned dynamically.

# 9.10.1 Semantics

40

45

1

5

10

15

20

30

35

- a) An encode property shall be assigned to an enum type.
- b) The enumeration's values shall fit inside the field width.

# 9.10.2 Example

This example shows **paritycheck**, **precedence**, and **encode**. Here hdrPreamble is covered by and checked by parity, while hdrType is not.

```
enum cfg_header_type_enum {
    normal = 7'h00 { desc = "Type 0 Configuration Space Header"; };
    pci_bridge = 7'h01 { desc = "PCI to PCI Bridge"; };
    cardbus_bridge = 7'h10 { desc = "PCI to CardBus Bridge"; };
    };

field {
    hw = rw; sw = rw;
```
| precedence = sw;                   |  |
|------------------------------------|--|
| encode = ctg_header_type_enum;     |  |
| } hdrType [6:0]=0;                 |  |
| field {                            |  |
| hw = rw; sw = rw;                  |  |
| paritycheck;                       |  |
| <pre>} hdrPreamble [15:8]=0;</pre> |  |

| 1  |  |  |  |
|----|--|--|--|
| 5  |  |  |  |
| 10 |  |  |  |
| 15 |  |  |  |
| 20 |  |  |  |
| 25 |  |  |  |
| 30 |  |  |  |
| 35 |  |  |  |
| 40 |  |  |  |
| 45 |  |  |  |
| 50 |  |  |  |
| 55 |  |  |  |

| 10. Register component                                                                                                                                                                                                                                                                                                                                                                          | 1  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| In SystemRDL, a <i>register</i> is defined as a set of one or more SystemRDL field instances that are atomically accessible by software at a given address. A register definition specifies its width and the types and sizes of the fields that fit within that width (the register file and address map components determine address allocation; see <u>Clause 12</u> and <u>Clause 13</u> ). | 5  |
| Registers can be instantiated in three forms.                                                                                                                                                                                                                                                                                                                                                   | 10 |
| <ul> <li>internal implies all register logic is created by the SystemRDL compiler for the instantiation (the default form).</li> </ul>                                                                                                                                                                                                                                                          | 10 |
| <ul> <li>external signifies the register/memory is implemented by the designer and the interface is inferred<br/>from instantiation.</li> </ul>                                                                                                                                                                                                                                                 |    |
| alias allows software to access another register with different properties (i.e., read, write, woclr, etc.). Alias registers are used where designers want to allow alternate software access to registers and memories. SystemRDL allows designers to specify alias registers for internal or external registers.                                                                              | 15 |
| 10.1 Defining and instantiating registers                                                                                                                                                                                                                                                                                                                                                       | 20 |
| Register components ( <b>reg</b> ) have the same definition and instantiation syntax as other SystemRDL components; see <u>5.1</u> . The following semantics apply for all registers.                                                                                                                                                                                                           |    |
| a) Within a register, the only components that can be instantiated are <b>field</b> components, <b>signal</b> s, and <b>constraint</b> s.                                                                                                                                                                                                                                                       | 25 |
| b) Within a register, the only components that can be defined are <b>field</b> components, <b>enum</b> s, <b>constraint</b> s and <b>signal</b> s.                                                                                                                                                                                                                                              |    |
| c) At least one <b>field</b> shall be instantiated within a register.                                                                                                                                                                                                                                                                                                                           | 30 |
| d) Two field instances shall not occupy overlapping bit positions within a register unless one field is read-only and the other field is write-only.                                                                                                                                                                                                                                            |    |
| e) Field instances shall not occupy a bit position exceeding the MSB of the register. The default width of a register ( <b>regwidth</b> ) is 32 bits.                                                                                                                                                                                                                                           | 25 |
| f) All registers shall have a width = $2^N$ , where $N \ge 3$ .                                                                                                                                                                                                                                                                                                                                 | 55 |
| g) Field instances that do not have explicit bit positions specified are automatically inferred based on the <b>addrmap</b> mode of <b>lsb0</b> (the default) or <b>msb0</b> .                                                                                                                                                                                                                  |    |
| <ul> <li>Registers shall not overlap, unless one contains read-only fields and the other contains only write-<br/>only or write-once-only fields.</li> </ul>                                                                                                                                                                                                                                    | 40 |
| 10.2 Instantiating registers                                                                                                                                                                                                                                                                                                                                                                    |    |
| All register instantiations follow the same syntax and semantics, with minor differences depending on the instantiated register's <b>internal</b> or <b>external</b> state. Unless specified as <b>external</b> (see <u>10.4</u> ), registers are, by default, <b>internal</b> .                                                                                                                | 45 |
| a) A <i>definitive</i> register instantiation appears as follows.                                                                                                                                                                                                                                                                                                                               |    |
| [external] reg_name [#(parameter_instance [, parameter_instance]*)]<br>reg_instance_element [, reg_instance_element]*;                                                                                                                                                                                                                                                                          | 50 |
| where                                                                                                                                                                                                                                                                                                                                                                                           |    |
| 1) <i>reg_name</i> is the user-specified register name.                                                                                                                                                                                                                                                                                                                                         |    |
| 2) <i>parameter_instance</i> is specified as follows (see $5.1.2$ <u>a</u> ).                                                                                                                                                                                                                                                                                                                   |    |
| .param_name(param_val)                                                                                                                                                                                                                                                                                                                                                                          | 55 |

SystemRDL 2.0 / D9

| 1  | 3) <i>reg_instance_element</i> is defined as follows.                                                                                                                                                                                                                                                                                                                                                                                                    |
|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | reg_instance_name [{[constant_expression]}* [addr_alloc]                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5  | where                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5  | i) <i>reg_instance_name</i> is the user-specified name for instantiation of the register.                                                                                                                                                                                                                                                                                                                                                                |
|    | ii) <i>constant_expression</i> is an expression that resolves to a longint unsigned.                                                                                                                                                                                                                                                                                                                                                                     |
| 10 | iii) [ <i>constant_expression</i> ] specifies the size of the instantiated <b>reg</b> array (optionally multidimensional).                                                                                                                                                                                                                                                                                                                               |
|    | iv) $addr_alloc$ is an address allocation operator (see <u>5.1.2.3</u> ).                                                                                                                                                                                                                                                                                                                                                                                |
|    | v) When using multiple-dimensions, the last subscript increments the fastest.                                                                                                                                                                                                                                                                                                                                                                            |
| 15 | b) An <i>anonymous definition</i> (and instantiation) of a register appears as follows.                                                                                                                                                                                                                                                                                                                                                                  |
| 15 | <pre>reg {[reg_body]} [external] reg_instance_element [, reg_instance_element]*;</pre>                                                                                                                                                                                                                                                                                                                                                                   |
|    | where                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|    | 1) $reg_body$ is as described in <u>5.1.1</u> , subject to the following limitations.                                                                                                                                                                                                                                                                                                                                                                    |
| 20 | i) Component definitions are limited to <b>field</b> , <b>constraint</b> , <b>signal</b> , and <b>enum</b> components.                                                                                                                                                                                                                                                                                                                                   |
|    | ii) Component instantiations are limited to <b>field</b> , <b>constraint</b> , and <b>signal</b> instances.                                                                                                                                                                                                                                                                                                                                              |
|    | <ol> <li>reg_instance_element is the description of the register instantiation attributes, as defined in 10.2 a 3.</li> </ol>                                                                                                                                                                                                                                                                                                                            |
| 25 | 10.3 Instantiating internal registers                                                                                                                                                                                                                                                                                                                                                                                                                    |
|    | Registers whose implementation can be built by a SystemRDL compiler are called internal registers.                                                                                                                                                                                                                                                                                                                                                       |
| 30 | Example                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|    | This example illustrates the definition and instantiation of <b>internal</b> registers.                                                                                                                                                                                                                                                                                                                                                                  |
| 35 | <pre>reg myReg { field {} data[31:0]; }; myReg intReg; // single internal register myReg intAugur[22]; // integral register</pre>                                                                                                                                                                                                                                                                                                                        |
|    | mykeg intArray[32]; // internal register array of size 32                                                                                                                                                                                                                                                                                                                                                                                                |
| 40 | 10.4 Instantiating external registers                                                                                                                                                                                                                                                                                                                                                                                                                    |
|    | SystemRDL can describe a register's implementation as external, which is applicable for large arrays of registers and provides an alternate implementation to what a SystemRDL compiler might provide. <i>External registers</i> are identical to internal registers, except the actual implementation of the register is not created by the compiler and the fields of an external register are not inferred to be implemented as wires and flip-flops. |
| 45 | Registers shall be instantiated as external registers by placing the keyword <b>external</b> before the register type name or by instantiating the component as described in <u>10.2</u> .                                                                                                                                                                                                                                                               |
| 50 | Example                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|    | This example illustrates the definition and instantiation of <b>external</b> registers.                                                                                                                                                                                                                                                                                                                                                                  |
| 55 | <pre>reg myReg { field {} data[31:0]; };<br/>external myReg extReg; // single external register<br/>external myReg extArray[32]; // external register array of size 32</pre>                                                                                                                                                                                                                                                                             |

| 10.5 Instantiating alias registers                                                                                                                                                                                                                                                                                                                                                                                                           | 1    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| An <i>alias register</i> is a register that appears in multiple locations of the same address map. It is physically implemented as a single register such that a modification of the register at one address location appears at all the locations within the address map. The accessibility of this register may be different in each location of the address block.                                                                        | 5    |
| Alias registers are allocated addresses like physical registers and are decoded like physical registers, but<br>they perform these operations on a previously instantiated register (called the <i>primary register</i> ). Since alias<br>registers are not physical, hardware access and other hardware operation properties are not used. Software<br>access properties for the alias register can be different from the primary register. | 10   |
| 10.5.1 Semantics                                                                                                                                                                                                                                                                                                                                                                                                                             | 15   |
| <ul><li>Registers shall be instantiated as alias registers by placing the keyword alias before the register type name.</li><li>a) An instantiation of an alias register appears as follows.</li></ul>                                                                                                                                                                                                                                        | 15   |
| <pre>reg_name reg_primary_inst;<br/>alias reg_primary_inst reg_name reg_instance;<br/>where</pre>                                                                                                                                                                                                                                                                                                                                            | 20   |
| <ol> <li>reg_name is the user-specified register name.</li> <li>reg_instance is the user-specified name for instantiation of the component.</li> <li>reg_primary_inst is the primary register to which the alias is bound</li> <li>Every field in the alias register needs to have the same instance name as a field in the primary register</li> </ol>                                                                                      | 25   |
| <ul> <li>ter (though the field type may differ) and the two fields shall have the same position and size in each (corresponding) register.</li> <li>c) The alias register is not required to have all the fields from the primary register.</li> <li>d) The alias register shall have the same width as the primary register.</li> <li>e) Only the following SystemBDL properties may be different in an alias: desc name onread</li> </ul>  | 30   |
| <ul> <li>onwrite, rclr, rset, sw, woclr, woset, and any user-defined properties.</li> <li>f) If the alias instance type (internal or external) is specified, it shall match the primary register instance type. If the alias instance type not specified, it uses the primary register instance type.</li> </ul>                                                                                                                             | . 35 |
| 10.5.2 Example                                                                                                                                                                                                                                                                                                                                                                                                                               |      |
| This example shows the usage of register aliasing and how the primary register and its alias can have different properties.                                                                                                                                                                                                                                                                                                                  | 40   |
| <pre>reg some_intr_r { field { level intr; hw=w; sw=r; woclr; } some_event; }; reg some_intr_rw { field { level intr; hw=w; sw=rw; } some_event; }; addrmap foo {     some_intr_r event1;     // Create an alias for the DV team to use and modify its properties     // so that DV can for interrupt events and allow more rigorous structural</pre>                                                                                        | 45   |
| <pre>// testing of the interrupt.<br/>alias event1 some_intr_r event1_for_dv;<br/>event1_for_dv.some_event-&gt;sw=rw;<br/>event1_for_dv.some_event-&gt;woclr = false;<br/>};</pre>                                                                                                                                                                                                                                                           | 50   |
| The alias above could be done with a different register type as well, without dynamic assigns.                                                                                                                                                                                                                                                                                                                                               |      |

alias event1 some\_intr\_rw event1\_for\_dv;

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change. 67

# 10.6 Register properties

Table 23 lists and describes the register properties.

10

15

20

30

35

40

1

| Property    | Implementation/Application                                                                                                                                                                     | Туре                | Dynamic <sup>a</sup> |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----------------------|
| regwidth    | Specifies the bit-width of the register (power of two).                                                                                                                                        | longint<br>unsigned | No                   |
| accesswidth | Specifies the minimum software access width (power of two) operation that may be performed on the register.                                                                                    | longint<br>unsigned | Yes                  |
| errextbus   | The associated register has error input.                                                                                                                                                       | boolean             | No                   |
| intr        | Represents the inclusive OR of all the interrupt bits in a register after<br>any <b>field enable</b> and/or <b>field mask</b> logic has been applied.                                          | N/A                 | No                   |
| halt        | Represents the inclusive OR of all the interrupt bits in a register after<br>any <b>field haltenable</b> and/or <b>field haltmask</b> logic has been applied.                                  | N/A                 | No                   |
| shared      | Defines a register as being shared in different address maps. This is only valid for register components and shall only be applied to shared components. See <u>13.5</u> for more information. | boolean             | No                   |

#### Table 23—Register properties

<sup>a</sup>Indicates whether a property can be assigned dynamically.

# 25 **10.6.1 Semantics**

- a) All registers shall have a **regwidth** =  $2^N$ , where  $N \ge 3$ .
- b) All registers shall have a **accesswidth** =  $2^N$ , where N >= 3.
- c) The value of the **accesswidth** property shall not exceed the value of the **regwidth** property.
- d) The default value of the **accesswidth** property shall be identical to the width of the register.
- e) Partial software reads of all fields without read side-effects are valid.
- f) Any field that is software-writable or clear on read shall not span multiple software accessible subwords (e.g., a 64-bit register with a 32-bit access width may not have a writable field with bits in both the upper and lower half of the register).
- g) If a register instance is not explicitly assigned an address, a compiler needs to automatically assign the address (see <u>13.4</u>). Addressing is inherited from the enclosing lexical scope and applies to any direct child instances.
- h) **errextbus** is only valid for external registers. It specifies an external register implementation indicating that a transaction terminated with an error. This error status is incorporated in the **addrmap** implementation transaction error indication.

# 45 **10.6.2 Example**

These are examples of using register properties.

| 10.7                                      | Und                                       | erstanding field ordering in registers                                                                                                                                                                                                                                                                                                                | 1  |
|-------------------------------------------|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| Users<br><b>msb0</b><br>fields<br>orderin | can s<br>and <b>l</b><br>in reg<br>ng scl | pecify bit ordering implicitly and explicitly in two different ways. These approaches are called <b>sb0</b> in SystemRDL (see <u>Table 26</u> ). Users who explicitly specify bit indexes when instantiating isters do not need to specify one of these attributes, as the explicit indexes imply one of these bit nemes. See also <u>Clause 17</u> . | 5  |
| a)                                        | The                                       | syntax:                                                                                                                                                                                                                                                                                                                                               |    |
|                                           |                                           | <i>field_type field_instance [high:low]</i><br>implies the use of <b>lsb0</b> ordering (the default)                                                                                                                                                                                                                                                  | 10 |
| b)                                        | Alte                                      | ernately:                                                                                                                                                                                                                                                                                                                                             |    |
|                                           |                                           | <i>field_type field_instance [low:high]</i><br>implies the use of <b>msb0</b> ordering                                                                                                                                                                                                                                                                | 15 |
|                                           | whe                                       | re                                                                                                                                                                                                                                                                                                                                                    | 15 |
|                                           | 1)                                        | low and high are unsizedNumerics;                                                                                                                                                                                                                                                                                                                     |    |
|                                           | 2)                                        | <i>low</i> == <i>high</i> implies a single bit field at the specified location;                                                                                                                                                                                                                                                                       |    |
|                                           | 3)                                        | for multi-bit fields, <i>low</i> < <i>high</i> .                                                                                                                                                                                                                                                                                                      | 20 |
|                                           | 4)                                        | The left-value is the index of the most significant bit of the field; the right-value is the index of is the least significant bit of the field.                                                                                                                                                                                                      | 20 |
| If a fo<br>at inde                        | rm sp<br>ex 0 f                           | ecifying only a field's size is used, then any fields are packed contiguously, end-to-end, starting or <b>lsb0</b> registers and starting at index regwidth-1 for <b>msb0</b> registers.                                                                                                                                                              | 25 |
| 10.7.1                                    | l Ser                                     | nantics                                                                                                                                                                                                                                                                                                                                               |    |
| a)                                        | Bot<br>sam                                | h the [low:high] and [high:low] bit specification forms shall not be used together in the e register.                                                                                                                                                                                                                                                 | 30 |
| b)                                        | As l<br>proj                              | ong as all the registers in an address map are consistently <b>msb0</b> or <b>lsb0</b> , no explicit <b>msb0</b> or <b>lsb0</b> oerty needs to be defined.                                                                                                                                                                                            |    |
| c)                                        | Sett                                      | ing lsb0=true implies msb0=false; setting msb0=true implies lsb0=false.                                                                                                                                                                                                                                                                               |    |
| 10.7.2                                    | 2 Exa                                     | mples                                                                                                                                                                                                                                                                                                                                                 | 35 |
| This e                                    | xamp                                      | le shows how fields are packed when using <b>lsb0</b> bit ordering.                                                                                                                                                                                                                                                                                   |    |
| l:<br>re                                  | sb0;<br>∋g {                              |                                                                                                                                                                                                                                                                                                                                                       | 40 |
|                                           |                                           | field {} A; // Single bit from 0 to 0<br>field {} B[3]; // 3 bits from 3:1                                                                                                                                                                                                                                                                            |    |
| ł                                         | regi                                      | // 4 bits from 7 to 4 are reserved and unused<br>field {} C[15:8]; // 8 Bits from 15 to 8<br>field {} C[5]; // 5 Bits from 20 to 16<br>A;                                                                                                                                                                                                             | 45 |
| J                                         | 91                                        |                                                                                                                                                                                                                                                                                                                                                       |    |
| This e                                    | xamp                                      | le shows how fields are packed when using <b>msb0</b> bit ordering.                                                                                                                                                                                                                                                                                   | 50 |
| m:<br>re                                  | sb0;<br>∋g {                              | field [] D. (( Gingle bit from 21 to 21                                                                                                                                                                                                                                                                                                               |    |
|                                           |                                           | field {} B[3]; // 3 bits from 28 to 30                                                                                                                                                                                                                                                                                                                |    |
|                                           |                                           | // 12 bits from 16 to 27 are reserved and unused field {} C[8:15]; // 8 Bits from 8 to 15                                                                                                                                                                                                                                                             | 55 |

- 1 field {} C[5]; // 5 Bits from 3 to 7
  } regA;
- 5

15

20

25

30

# 10.8 Understanding interrupt registers

As discussed in <u>9.9</u>, the field property **intr** also affects registers. Any register that contains an interrupt field has two implied properties: **intr** and **halt**. These properties are outputs of the register. The **intr** register property represents the inclusive OR of all the interrupt bits in a register after any **field enable** and/or **field mask** logic has been applied. The **halt** register property represents the inclusive OR of all the interrupt bits in a register after any **field haltenable** and/or **field haltmask** logic has been applied.

## 10.8.1 Semantics

- a) The **intr** and **halt** register properties are outputs; they should only occur on the right-hand side of an assignment in SystemRDL.
- b) The intr property shall always be present on a intr register even if no mask or enables are specified.
- c) The **halt** property shall only be present if **haltmask** or **haltenable** is specified on at least one **field** in the register.

## 10.8.2 Example

This example connects an implicit intr output property to another field.

```
reg {
  field { intr; } some_intr;
  field { intr; } some_other_intr;
  } some_intr_reg;
reg {
   field {} a;
  } some_status_reg;
some_status_reg.a->next = some_intr_reg->intr;
```

35

45

| 11. N                                                  | /lem                                      | ory component                                                                                                                                                                                                                                                                                                                                                                                                               | 1  |
|--------------------------------------------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| A <i>men</i><br>impler<br>are vir<br>the me<br>virtual | nory<br>menta<br>tual i<br>emory<br>field | s an array of storage consisting of a number of entries of a given bit width. The physical memory<br>tion is technology dependent and memories shall be <b>external</b> . Child instance within a memory<br>nstances. A virtual instance does not have a physical implementation, but, it is a software view of<br>data. A memory can contain instances of virtual registers and fields within a virtual register are<br>s. | 5  |
| 11.1                                                   | Defi                                      | ning and instantiating memories                                                                                                                                                                                                                                                                                                                                                                                             | 10 |
| Memo<br>introdu<br>operation on byt                    | ory co<br>uce t<br>ors an<br>e add        | omponents have the same definition as other SystemRDL components; see <u>5.1.1</u> . Memories he concepts of address allocation and their supporting operators. These address allocation re applied after the instance name of the component. All addressing in SystemRDL is done based resses.                                                                                                                             | 15 |
| a)                                                     | Αa                                        | efinitive definition of a memory instantiation appears as follows.                                                                                                                                                                                                                                                                                                                                                          |    |
|                                                        |                                           | [external] mem_name [#(parameter_instance [, parameter_instance]*)]<br>mem_instance_element [, mem_instance_element]*;                                                                                                                                                                                                                                                                                                      | 20 |
|                                                        | wh                                        | ere                                                                                                                                                                                                                                                                                                                                                                                                                         | 20 |
|                                                        | 1)                                        | <i>mem_name</i> is the user-specified memory name.                                                                                                                                                                                                                                                                                                                                                                          |    |
|                                                        | 2)                                        | parameter_instance is specified as follows (see 5.1.2 a).                                                                                                                                                                                                                                                                                                                                                                   |    |
|                                                        |                                           | .param_name(param_val)                                                                                                                                                                                                                                                                                                                                                                                                      | 25 |
|                                                        | 3)                                        | mem_instance_element is defined as follows.                                                                                                                                                                                                                                                                                                                                                                                 |    |
|                                                        |                                           | mem_instance_element [{[constant_expression]}* [addr_alloc]                                                                                                                                                                                                                                                                                                                                                                 |    |
|                                                        | wh                                        | ere                                                                                                                                                                                                                                                                                                                                                                                                                         | 20 |
|                                                        |                                           | i) <i>mem_instance_element</i> is the user-specified name for instantiation of the memory.                                                                                                                                                                                                                                                                                                                                  | 30 |
|                                                        |                                           | ii) constant_expression is an expression that resolves to a longint unsigned.                                                                                                                                                                                                                                                                                                                                               |    |
|                                                        |                                           | iii) [ <i>constant_expression</i> ] specifies the size of the instantiated <b>mem</b> array (optionally multidimensional).                                                                                                                                                                                                                                                                                                  |    |
|                                                        |                                           | iv) $addr_alloc$ is an address allocation operator (see <u>5.1.2.3</u> ).                                                                                                                                                                                                                                                                                                                                                   | 35 |
|                                                        |                                           | v) When using multiple-dimensions, the last subscript increments the fastest.                                                                                                                                                                                                                                                                                                                                               |    |
| b)                                                     | An                                        | anonymous definition (and instantiation) of a memory appears as follows.                                                                                                                                                                                                                                                                                                                                                    |    |
|                                                        |                                           | <pre>mem {[mem_body]} external mem_instance_element [, mem_instance_element]*;</pre>                                                                                                                                                                                                                                                                                                                                        |    |
|                                                        | wh                                        | ere                                                                                                                                                                                                                                                                                                                                                                                                                         | 40 |
|                                                        | 1)                                        | <i>mem_body</i> is as described in $5.1.1$ , subject to the following limitations.                                                                                                                                                                                                                                                                                                                                          |    |
|                                                        |                                           | i) Component definitions are limited to <b>field</b> , <b>reg</b> , <b>constraint</b> , and <b>enum</b> components.                                                                                                                                                                                                                                                                                                         |    |
|                                                        |                                           | ii) Component instantiations are limited to <b>reg</b> and <b>constraint</b> instances.                                                                                                                                                                                                                                                                                                                                     |    |
|                                                        | 2)                                        | <i>mem_instance_element</i> is the description of the memory instantiation attributes, as defined in $11.1 \text{ a } 3$ .                                                                                                                                                                                                                                                                                                  | 45 |
| 11.2                                                   | Sem                                       | antics                                                                                                                                                                                                                                                                                                                                                                                                                      |    |

| a)  | All mem instances shall have an external instance type specified. | 50 |
|-----|-------------------------------------------------------------------|----|
| • • |                                                                   |    |

- b) Addresses in SystemRDL are always byte addresses.
- c) Within a memory, the only components that can be instantiated shall be virtual register components.
- d) Memories can contain reg instances. Instances of reg instances within a memory are virtual registers.

5

15

20

- e) Virtual register width is limited to the minimum power of two bytes, which can contain the memory width, and all the virtual fields shall fit within the memory width.
  - f) Virtual registers, register files, and fields shall have the same software access (sw property value) as the parent memory.
- g) Virtual register and fields cannot have hardware properties.
- h) Virtual fields cannot have software properties other sw.
- i) The address space occupied by virtual registers shall be less than or equal to the address space provided by the memory.
  - j) Virtual registers cannot overlap.
  - k) Virtual register instances are optional.
  - 1) A mem cannot be prefixed by alias.

## **11.3 Memory properties**

Table 24 lists and describes the memory properties.

## Table 24—Memory properties

| 25 | Property   | Implementation/Application                   | Туре                | Dynamic <sup>a</sup> |
|----|------------|----------------------------------------------|---------------------|----------------------|
| -  | mementries | The number of memory entries.                | longint<br>unsigned | No                   |
| 20 | memwidth   | The memory entry bit width.                  | longint<br>unsigned | No                   |
| 30 | SW         | Programmer's ability to read/write a memory. | access<br>type      | Yes                  |

<sup>a</sup>Indicates whether a property can be assigned dynamically.

# <sup>35</sup> **11.3.1 Semantics**

- a) **mementries** shall be greater than 0.
- b) mementries defaults to 1.
- c) memwidth shall be greater than 0.
- d) memwidth defaults to regwidth.

# 45 **11.3.2 Example**

This example shows an application of memory component properties.

55

| 12. F                                     | Regi                                                         | ster                               | file component                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1  |
|-------------------------------------------|--------------------------------------------------------------|------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| A regiprovid<br>only d<br>is an<br>define | <i>ister f</i><br>les ad<br>liffere<br><b>addr</b> i<br>a im | file is<br>Idress<br>once b<br>map | as a logical grouping of one or more register and register file instances;. The register file<br>allocation support, which is useful for introducing an address gap between registers. The<br>between the register file component ( <b>regfile</b> ) and the <b>addrmap</b> component (see <u>Clause 13</u> )<br>defines an RTL implementation boundary where the <b>regfile</b> does not. Since <b>addrmap</b> s<br>inentation block boundary, there are some specific properties that are only specified for | 5  |
| addres                                    | s maj                                                        | ps (se                             | e <u>Clause 13</u> ) and not specified for <b>regfile</b> s.                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 10 |
| 12.1                                      | Defi                                                         | ning                               | and instantiating register files                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |
| Regist<br>files in<br>operat<br>on byt    | er fil<br>ntrodu<br>ors ar<br>e add                          | e cor<br>uce th<br>re app<br>resse | nponents have the same definition as other SystemRDL components; see $5.1.1$ . Register ne concepts of address allocation and their supporting operators. These address allocation olied after the instance name of the component. All addressing in SystemRDL is done based s.                                                                                                                                                                                                                                | 15 |
| a)                                        | A d                                                          | lefinit                            | <i>ive</i> register file instantiation appears as follows.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |
|                                           |                                                              | [ <mark>ext</mark><br>regj         | <pre>sernal   internal] regfile_name [#(parameter_instance [, parameter_instance]*)] file_instance_element [, regfile_instance_element]*;</pre>                                                                                                                                                                                                                                                                                                                                                                | 20 |
|                                           | whe                                                          | ere                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |
|                                           | 1)                                                           | reg                                | <i>file_name</i> is the user-specified <b>regfile</b> name.                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 25 |
|                                           | 2)                                                           | par                                | <i>ameter_instance</i> is specified as follows (see <u>5.1.2</u> <u>a</u> ).                                                                                                                                                                                                                                                                                                                                                                                                                                   | 25 |
|                                           |                                                              | .pai                               | am_name(param_val)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |
|                                           | 3)                                                           | reg                                | file_instance_element is defined as follows.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
|                                           |                                                              | 1                                  | regfile_instance_name [{[constant_expression]}* [addr_alloc]                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 30 |
|                                           | whe                                                          | ere                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |
|                                           |                                                              | i)                                 | <i>regfile_instance_name</i> is the user-specified name for instantiation of the register file.                                                                                                                                                                                                                                                                                                                                                                                                                |    |
|                                           |                                                              | ii)                                | <i>constant_expression</i> is an expression that resolves to a longint unsigned.                                                                                                                                                                                                                                                                                                                                                                                                                               | 35 |
|                                           |                                                              | iii)                               | [constant_expression] specifies the size of the instantiated <b>regfile</b> array (optionally multi-<br>dimensional).                                                                                                                                                                                                                                                                                                                                                                                          |    |
|                                           |                                                              | iv)                                | $addr_alloc$ is an address allocation operator (see <u>5.1.2.3</u> ).                                                                                                                                                                                                                                                                                                                                                                                                                                          |    |
|                                           |                                                              | v)                                 | When using multiple-dimensions, the last subscript increments the fastest.                                                                                                                                                                                                                                                                                                                                                                                                                                     | 40 |
| b)                                        | An                                                           | anon                               | ymous definition (and instantiation) of a register file appears as follows.                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |
|                                           |                                                              | reg<br>regj                        | <pre>file {[regfile_body]} [external   internal] file_instance_element [, regfile_instance_element]*;</pre>                                                                                                                                                                                                                                                                                                                                                                                                    |    |
|                                           | whe                                                          | ere                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 45 |
|                                           | 1)                                                           | reg                                | <i>file_body</i> is as described in <u>5.1.1</u> , subject to the following limitations.                                                                                                                                                                                                                                                                                                                                                                                                                       |    |
|                                           |                                                              | i)                                 | Component definitions are limited to field, reg, regfile, signal, constraint, and enum components.                                                                                                                                                                                                                                                                                                                                                                                                             |    |

- ii) Component instantiations are limited to reg, regfile, constraint, and signal instances.
- 2) regfile\_instance\_element is the description of the register file instantiation attributes, as defined in <u>12.1 a</u> <u>3</u>.

50

## 1 12.2 Semantics

5

10

15

20

25

30

35

40

45

50

55

- a) Addresses in SystemRDL are always byte addresses.
- b) Within a register file, the only components that can be instantiated shall be a register file, a register, and/or signal components.
- c) At least one reg or regfile shall be instantiated within a regfile.
- d) A regfile may contain heterogeneous internal, external, and alias registers.
- e) A regfile cannot be prefixed by alias. Only individual registers can be aliased.
- f) If a regfile is declared internal, all registers in it are coerced to be internal, regardless of any internal or external declaration on the register instantiations. Similarly, if the regfile is declared external, all registers are coerced to be external; in this case, aliased registers need to be handled externally as well. If the regfile is not declared as either, the register instances are internal, alias, or external according to their individual declarations.

# 12.3 Register file properties

Table 25 lists and describes the register file properties.

## Table 25—Register file properties

| Property          | Implementation/Application                                                               | Туре                | Dynamic <sup>a</sup> |
|-------------------|------------------------------------------------------------------------------------------|---------------------|----------------------|
| alignment         | Specifies alignment of all instantiated components in the associated reg-<br>ister file. | longint<br>unsigned | No                   |
| sharedext-<br>bus | Forces all external registers to share a common bus.                                     | boolean             | No                   |
| errextbus         | For an external <b>regfile</b> , the associated <b>regfile</b> has an error input.       | boolean             | No                   |

<sup>a</sup>Indicates whether a property can be assigned dynamically.

## 12.3.1 Semantics

- a) All **alignment** values shall be a power of two (1, 2, 4, etc.) and shall be in units of bytes.
- b) The default for **alignment** is the address (of the register file) aligned to the width of the component being instantiated (e.g., the address of a 64-bit register is aligned to the next 8-byte boundary).
- c) The **sharedextbus** property is only relevant when dealing with multiple external components.
  - 1) It creates a single set of control signals for entire regfile, instead of per register.
  - 2) Write data is common to all, with max MSB and min LSB from all registers, and populated based on each register's field positions.
  - 3) Read data is common to all, with max MSB and min LSB from all registers, and extracted based on each register's field positions.
  - 4) For **regfiles** without an instance type, selects for each external register or **regfile** accompany the common control signals.
  - 5) For external **regfiles**, an address bus with an offset relative to the beginning of the regfile is provided.
  - d) The **errextbus** property is only considered for external **regfiles** and, when nested, only the outermost external **regfile**. **errextbus** specifies an external **regfile** implementation indicating a transaction terminated with an error. This error status is incorporated in the top addrmap implementation transaction error indication.

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change. e) If a register file instance is not explicitly assigned an address, an application needs to automatically assign the address.

#### 12.3.2 Example

This example shows an application of register file component properties.

1

5

30

35

40

| 1  |  |  |  |
|----|--|--|--|
| 5  |  |  |  |
| 10 |  |  |  |
| 15 |  |  |  |
| 20 |  |  |  |
| 25 |  |  |  |
| 30 |  |  |  |
| 35 |  |  |  |
| 40 |  |  |  |
| 45 |  |  |  |
| 50 |  |  |  |
| 55 |  |  |  |

| 13. Address map component                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| An address component map ( <b>addrmap</b> ) contains registers, register files, memories, and/or other address maps and assigns a virtual address or final addresses; this map defines the boundaries of an implementation (e.g., RTL). A <i>virtual address</i> is used on an address map that is intended to be used as a component in a higher-level, or hierarchical, address map. A <i>final address</i> is used for the top-level address map (one that is not contained in any other address maps). There is no difference in how addresses are specified. All | 5  |
| addresses are virtual until the root of the tree is reached.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 10 |
| 13.1 Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |
| During generation, the address map can be converted into an HDL module. All registers and fields instantiated within an address map file shall be generated within this module. Therefore, some properties are only valid for <b>addrmaps</b> and not for <b>regfiles</b> . Other than these properties and their suggested behavior, there is no difference between address maps and register files.                                                                                                                                                                 | 15 |
| 13.2 Defining and instantiating address maps                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 20 |
| Address map components have the same definition and instantiation syntax as other SystemRDL components; see <u>5.1</u> . The address allocation operators are shown in <u>5.1.2.3</u> .                                                                                                                                                                                                                                                                                                                                                                               |    |
| 13.3 Semantics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 25 |
| a) The components instantiated within an address map shall be registers, register files, memories, address maps., or signals.                                                                                                                                                                                                                                                                                                                                                                                                                                         |    |
| b) At least one register, register file, memory, or address map shall be instantiated within an address                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 30 |

# 13.4 Address map properties

map.

A compiler generating an implementation based on SystemRDL has to create an external interface for each external component created. The **sharedextbus** property can be used to combine multiple external components into a single interface.

The other critical aspect to understand about address maps is how the global *addressing modes* work. There are three addressing modes defined in SystemRDL: **compact**, **regalign**, and **fullalign**. See <u>5.1.2.2.2</u>.

Table 26 describes the address map properties.

| able 26—A | Address map | properties |
|-----------|-------------|------------|
|-----------|-------------|------------|

| Property          | Implementation/Application                                             | Туре                | Dynamic <sup>a</sup> |
|-------------------|------------------------------------------------------------------------|---------------------|----------------------|
| alignment         | Specifies alignment of all instantiated components in the address map. | longint<br>unsigned | No                   |
| sharedext-<br>bus | Forces all external registers to share a common bus.                   | boolean             | No                   |
| errextbus         | The associated addrmap instance has an error input.                    | boolean             | No                   |
| bigendian         | Uses big-endian architecture in the address map.                       | boolean             | Yes                  |
| littleendian      | Uses little-endian architecture in the address map.                    | boolean             | Yes                  |

40

| 1 |
|---|
|   |
|   |
| - |

|  | 4 |   |
|--|---|---|
|  |   | ٠ |

15

25

30

35

40

45

50

55

## Table 26—Address map properties (Continued)

| Property   | Implementation/Application                                                                                                                                    | Туре                | Dynamic <sup>a</sup> |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|----------------------|
| addressing | Controls how addresses are computed in an address map.                                                                                                        | address-<br>ingtype | No                   |
| rsvdset    | The read value of all fields not explicitly defined is set to 1 if <b>rsvdset</b> is <i>True</i> ; otherwise, it is set to 0.                                 | boolean             | No                   |
| rsvdsetX   | The read value of all fields not explicitly defined is unknown if <b>rsvd-setX</b> is <i>True</i> . <b>rsvdsetX</b> takes precedence over <b>rsvdset</b> .    | boolean             | No                   |
| msb0       | Specifies register bit-fields in an address map are defined as 0:N versus N:0. This property affects all fields in an address map.                            | boolean             | No                   |
| lsb0       | Specifies register bit-fields in an address map are defined as $N: 0$ versus $0:N$ . This property affects all fields in an address map. This is the default. | boolean             | No                   |

<sup>a</sup>Indicates whether a property can be assigned dynamically.

## 20 **13.4.1 Semantics**

- a) The default for the **alignment** shall be the address is aligned to the width of the component being instantiated (e.g., the address of a 64-bit register is aligned to the next 8-byte boundary).
- b) All **alignment** values shall be a power of two (1, 2, 4, etc.) and shall be in units of bytes.
- c) The **sharedextbus** property is only relevant when the **addrmap** contains external component instances.
  - 1) **sharedextbus** creates a single set of control signals for the entire **addrmap**, instead of per external reg, regfile, or mem instance.
    - 2) Any outgoing data is common to all direct external instances.
    - 3) Any incoming data is common to all direct external instances.
  - 4) addrmap instances are always considered external. An address with offset relative to the beginning of the addrmap instance is provided.
  - 5) If **errextbus** exists for an addrmap instance, an error input shall exist for that addrmap instance in the parent addrmap.
- d) **errextbus** specifies an addrmap implementation indicating a transaction terminated with an error. This error status is incorporated in the top addrmap implementation transaction error indication.
- e) regalign is identical to compact, except when dealing with mems, regfiles, or addrmaps. If an array of components is 256 items deep and 8 bytes wide, then the next address is (addr[2:0] == 0) and it is only aligned to the size of the regfile, not the total size of the array.
- f) fullalign is identical to compact, except when dealing with mems, regfiles, or addrmaps. If an array of components is 256 items deep and 8 bytes wide, then the next address is aligned to 256\*8 or 2048.
  - g) **rsvdsetX** does not affect SystemRDL generated implementations; it can be used to verify legacy designs which do not have consistent data values for reserved fields.
  - h) **rsvdset** and **rsvdsetX** are mutually exclusive.
  - i) **msb0** and **lsb0** are mutually exclusive.
  - j) The **bigendian** and **littleendian** properties are used for controlling byte ordering and have no effect on bit ordering.

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change.

# 13.4.2 Example 1 See the examples shown in 5.1.2.2.2. 13.5 Defining bridges or multiple view address maps 5 A bridge addrmap is a container for address maps which can be accessed by multiple masters. Table 27 lists

10

15

20

25

| Property | Implementation/Application                                                                                                                                             | Туре    | Dynamic <sup>a</sup> |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|----------------------|
| bridge   | Defines the parent address map as being a bridge. This shall only be<br>applied to the root address map which contains the different views of<br>the sub address maps. | boolean | No                   |

Table 27—Bridge properties

<sup>a</sup>Indicates whether a property can be assigned dynamically.

and describes these address map bridge properties.

#### 13.5.1 Semantics

To create a bridge, use a parent address map with a **bridge** property which contains two or more sub address maps representing the different views.

## 13.5.2 Example

This example below shows a bridge between two bus protocols.

```
addrmap some_bridge { // Define a Bridge Device
   desc="overlapping address maps with both shared register space and
                                                                                       30
   orthogonal register space";
   bridge; // This tells the compiler the top level map contains other maps
  reg status {// Define at least 1 register for the bridge
              // Shared property tells compiler this register
   shared;
              // will be shared by multiple addrmaps
                                                                                       35
   field {
     hw=rw;
      sw=r;
   } stat1 = 1'b0;
  };
                                                                                       40
  reg some_axi_reg {
   field {
     desc="credits on the AXI interface";
    } credits[4] = 4'h7;
                                                           // End of field: {}
 };
                                                    // End of Reg: some_axi_reg
                                                                                       45
  reg some_ahb_reg {
   field {
      desc="credits on the AHB Interface";
    } credits[8] = 8'b00000011 ;
                                                                                       50
  };
   addrmap {
      littleendian;
```

| 1<br>5 | <pre>some_ahb_reg ahb_credits; // Implies addr = 0 status ahb_stat @0x20; // explicitly at address=20 ahb_stat.statl-&gt;desc = "bar"; // Overload the registers property in</pre>                                                                                                                                      |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10     | <pre>addrmap { // Define the Map for the AXI Side of the bridge<br/>bigendian; // This map is big endian<br/>some_axi_reg axi_credits; // Implies addr = 0<br/>status axi_stat @0x40; // explicitly at address=40<br/>axi_stat.stat1-&gt;desc = "foo"; // Overload the registers property<br/>// in this instance</pre> |
| 15     | <pre>} axi; }; // Ends addrmap bridge</pre>                                                                                                                                                                                                                                                                             |
| 20     |                                                                                                                                                                                                                                                                                                                         |
| 25     |                                                                                                                                                                                                                                                                                                                         |
| 30     |                                                                                                                                                                                                                                                                                                                         |
| 35     |                                                                                                                                                                                                                                                                                                                         |
| 40     |                                                                                                                                                                                                                                                                                                                         |
| 50     |                                                                                                                                                                                                                                                                                                                         |
| 55     |                                                                                                                                                                                                                                                                                                                         |

| 14. Verification constructs                                                                                                                                                                                                                                                                                                                                                                                                                  | 1  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| This clause describes certain special constructs which are specifically used for creating verification models from the SystemRDLspecification.                                                                                                                                                                                                                                                                                               | 5  |
| 14.1 HDL path                                                                                                                                                                                                                                                                                                                                                                                                                                |    |
| An <i>HDL path</i> specifies the hierarchical path of the design storage element corresponding to the address map, register, register field, or memory. By specifying an HDL path, the verification environment can have direct access to memory, register, and field implementation nets in a Design Under Test (DUT). The complete HDL path of a component is the concatenation of all HDL paths from the top-level down to the component. | 10 |
| An hdl_path_slice or hdl_path_gate_slice can be put on a field or mem component. It can be used when the corresponding RTL or gate-level netlist is not contiguous. The property value is an array of hdl_path strings, each pointing to the corresponding element in the RTL or gate-level netlist.                                                                                                                                         | 15 |
| 14.1.1 Assigning HDL path                                                                                                                                                                                                                                                                                                                                                                                                                    | 20 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |

An HDL path can be assigned using property **hdl\_path** or **hdl\_path\_gate**. <u>Table 28</u> lists and describes the HDL path properties.

| Property                | Implementation/Application                                                                      | Туре      | Dynamic <sup>a</sup> |
|-------------------------|-------------------------------------------------------------------------------------------------|-----------|----------------------|
| hdl_path                | Assigns the RTL hdl_path for an <b>addrmap</b> , <b>reg</b> , or <b>regfile</b> .               | string    | Yes                  |
| hdl_path_<br>slice      | Assigns a list of RTL <b>hdl_path</b> for a <b>field</b> or <b>mem</b> .                        | string [] | Yes                  |
| hdl_path_<br>gate       | Assigns the gate-level <b>hdl_path</b> for an <b>addrmap</b> , <b>reg</b> , or <b>regfile</b> . | string    | Yes                  |
| hdl_path_<br>gate_slice | Assigns a list of gate-level hdl_path for a <b>field</b> or <b>mem</b> .                        | string [] | Yes                  |

# Table 28—HDL path properties

<sup>a</sup>Indicates whether a property can be assigned dynamically.

# 14.1.1.1 hdl\_path and hdl\_path\_gate

hdl\_path and hdl\_path\_gate are properties which contain a string-based path to the storage in an RTL or gate-level netlist.

hdl\_path = "path"; hdl\_path\_gate = "path";

where

path is the path specified as an argument to the method calls in IEEE 1800.2, subclause 19.6.

The RHS value of **hdl\_path** can contain a bit slice, which is specified by using [:], e.g., "reg1[31:12]".

# 14.1.1.2 hdl\_path\_slice and hdl\_path\_gate\_slice

hdl\_path\_slice and hdl\_path\_gate\_slice are properties which contain an array of string-based paths to the storage in an RTL or gate-level netlist.

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change. 81

25

30

35

40

45

50

```
1
                   hdl path slice = '{"path" [, "path"]*};
                   hdl path gate slice = '{"path" [, "path"]*};
             hdl path slice's shall be used when the component has multiple storage elements in the RTL or gate.
 5
             14.1.2 Examples
             Example 1
10
             The corresponding (TOP) diagram for this example is shown in Figure 1.
                 addrmap block_def #( string ext_hdl_path = "ext_block") {
                   hdl_path = "int_block" ;
15
                   reg {
                     hdl_path = { ext_hdl_path, ".externl_reg" } ;
                     field {
                       hdl_path_sice = '{ "field1" } ;
                     } f1 ;
20
                   } external external_reg ;
                   reg {
                     hdl_path = "int_reg" ;
                     field {
25
                       hdl_path_slice = '{ "field1" } ;
                     } f1 ;
                   } internal_reg ;
                 } ;
                 addrmap top {
30
                   hdl_path = "TOP" ;
                   block_def #( .ext_hdl_path("ext_block0")) int_block0 ;
                   int_block0 -> hdl_path = "int0" ;
                   block_def #( .ext_hdl_path("ext_block1")) int_block1 ;
                   int_block1 -> hdl_path = "int1" ;
35
                 } ;
```

45



Figure 1—TOP diagram

```
Example 2
```

```
addrmap top{
    reg {
        field {
            hdl_path_slice = `{"rtl_f1_1", "rtl_f1_0"};
        } f1[1:0];
        field {
            hdl_path_slice = `{"rtl_f2"};
        } f2[5:3];
    } Reg1 ;
    Reg1.f2 -> hdl_path_slice = `{"rt1_f2_5_4", "rt1_f2_3"};
        // the hdl_path for Reg1.f2 has been overridden dynamically
};
        40
```

# 14.2 Constraints

A *constraint* is a value-based condition on one or more components; e.g., constraint-driven test generation allows users to automatically generate tests for functional verification. Constraints can be instantiated within all structural components.

## 14.2.1 Describing constraints

Constraints can be assigned using a **constraint** component. A **constraint** component can contain one or more constraint expressions. A *constraint expression* is a value-based condition on one or more **fields** visible from the scope in which the **constraint** component is defined. The field references may only be to a field instance and not a property of the **field**. Fields can also be specified using the hierarchical operator (.) (see 5.1.4). If the constraint is instantiated inside a field, the **this** keyword can be used to reference the enclosing field.

83

25

45

50

15

- Note that the **this** keyword is legal only in the context of expressions defined in **constraint** components. Expressions defined in **constraint** components are not evaluated by SystemRDL compilers and should be transferred as written for runtime evaluation, except when translating **field** and **enum** type references.
- 5 A **field** can be limited to values in a set using the **inside** keyword and the set operator ({}). Values in a set can be specified separated by commas (,) or a range can be specified using the [:] syntax. The right-hand side of an **inside** can also be an **enum** type reference. When translating enum type references to SystemVerilog, the reference shall be replaced by the list of enumerators defined in the **enum** type.

Any constraint can be disabled by setting the constraint's **constraint\_disable** property (see <u>Table 29</u>) to true.

## 14.2.2 Constraint component

|    | <i>a</i> ) | Definitive definition                                                                                                |
|----|------------|----------------------------------------------------------------------------------------------------------------------|
|    |            | <pre>constraint constraint_component_name {[constraint_body]};</pre>                                                 |
|    |            | constraint_component_name constraint_inst;                                                                           |
| 20 |            | where                                                                                                                |
|    |            | 1) constraint_component_name is the user-specified constraint name.                                                  |
|    |            | 2) <i>constraint_body</i> can contain one of more of the following.                                                  |
|    |            | i) LHS operator RHS                                                                                                  |
| 25 |            | where                                                                                                                |
|    |            | LHS can be a <i>field name reference</i> or the <b>this</b> keyword.                                                 |
|    |            | operator can be any relational operator (see <u>Table 7</u> ).                                                       |
|    |            | RHS can be any valid SystemRDL expression.                                                                           |
| 30 |            | ii) LHS inside {open_range_list}                                                                                     |
|    |            | where                                                                                                                |
|    |            | LHS can be a <i>field name reference</i> or the <b>this</b> keyword.                                                 |
|    |            | open_range_list is defined as follows                                                                                |
| 35 |            | constraint_value [, constraint_value]*                                                                               |
|    |            | and <i>constraint_value</i> is defined as either an expression or a range, as follows.                               |
|    |            | constant_expression   [constant_expression : constant_expression]                                                    |
|    |            | iii) LHS inside enum_type_ref                                                                                        |
| 40 |            | where                                                                                                                |
|    |            | LHS can be a <i>field name reference</i> or the <b>this</b> keyword.                                                 |
|    |            | <i>enum_type_ref</i> is an enum type reference.                                                                      |
|    |            | iv) An assignment to a universal property (see <u>Table 5</u> ) or <b>constraint_disable</b> (see <u>Table 29</u> ). |
| 45 |            | 3) <i>constraint_inst</i> is the user-specified name for instantiation of the component.                             |
|    | b)         | Anonymous definition                                                                                                 |
|    |            | <pre>constraint {[constraint_body]} constraint_component_name;</pre>                                                 |
|    |            | where                                                                                                                |
| 50 |            | 1) <i>constraint_body</i> can contain one of more of the following.                                                  |
|    |            | i) LHS operator RHS                                                                                                  |
|    |            | where                                                                                                                |
|    |            | LHS can be a <i>field name reference</i> or the <b>this</b> keyword.                                                 |
| 22 |            | <i>operator</i> can be any relational operator (see <u>Table 7</u> ).                                                |
|    |            |                                                                                                                      |

|    |      | RHS can be any valid SystemRDL expression.                                                                       | 1  |
|----|------|------------------------------------------------------------------------------------------------------------------|----|
|    | ii)  | LHS inside {open_range_list}                                                                                     |    |
|    | whe  | re                                                                                                               |    |
|    |      | LHS can be a <i>field name reference</i> or the <b>this</b> keyword.                                             | 5  |
|    |      | open_range_list is defined as follows                                                                            |    |
|    |      | constraint_value [, constraint_value]*                                                                           |    |
|    |      | and <i>constraint_value</i> is defined as either an expression or a range, as follows.                           | 10 |
|    |      | constant_expression   [constant_expression : constant_expression]                                                |    |
|    | iii) | LHS inside enum_type_ref                                                                                         |    |
|    | whe  | re                                                                                                               |    |
|    |      | LHS can be a <i>field name reference</i> or the <b>this</b> keyword.                                             | 15 |
|    |      | <i>enum_type_ref</i> is an enum type reference.                                                                  |    |
|    | iv)  | An assignment to a universal property (see <u>Table 5</u> ) or <b>constraint_disable</b> (see <u>Table 29</u> ). |    |
| 2) | con  | straint_component_name is the user-specified constraint name.                                                    |    |
|    |      |                                                                                                                  | 20 |

Table 29 lists and describes the constraint properties.

Table 29—Constraint properties

| Property               | Implementation/Application                                         | Туре    | Dynamic <sup>a</sup> | 25 |
|------------------------|--------------------------------------------------------------------|---------|----------------------|----|
| constraint_<br>disable | Specifies whether to disable (true) or enable (false) constraints. | boolean | Yes                  | 25 |

<sup>a</sup>Indicates whether a property can be assigned dynamically.

## 14.2.3 Example

```
constraint not_valid { this != 0; };
                                                   //definitive constraint
constraint max_value { this < 256; };</pre>
reg example_reg {
                                                                                       35
   field {
      hw=rw; sw=rw;
      not_valid not0; // instantiate not_valid constraint,
                        // where "this" resolve to current field value.
      max_value max0;
                                                                                       40
   } f3 [17:31]=1;
};
enum color {
   red = 0 { desc = " color red ";};
                                                                                       45
   green = 1 { desc = " color green ";};
   blue = 2 { desc = " color blue ";};
};
reg register1 {
                                                                                       50
   field { hw = rw; sw = rw; }limit[0:2]=0;
   field {
      hw = rw; sw = rw;
      max_value max1; // another instance.
   } f1 [3:9]=3;
```

30

```
1
                   constraint { f1 > limit; } min;
                                                                 //anonymous constraint
                   field {
                      hw = rw; sw = rw; encode=color;
 5
                      constraint { this == red || this == green; } rg1;
                      constraint { this inside {red, green}; } rg2;
                      constraint { this inside color; } rgb; // full range of encode
10
                   } f2 [10:31];
               };
               struct RGB {
15
                 longint unsigned red1;
                 longint unsigned green1;
                 longint unsigned blue1;
               };
20
               reg regfoo {
                   RGB pixelvalue;
               };
25
               addrmap constraint_component_example {
                   example_reg reg1;
                   example_reg reg2;
30
                   register1 r1;
                   register1 r2;
                   constraint {
35
                      reg1.f3 inside {5,8,[9:12],3}; // adding a new constraint by
                                                     // hierarchically referring to a field
               } cont1;
40
               r1.f1.min->constraint_disable = true; // disable a particular constraint
               // disable all constraints on f2 individually
               r2.f2.rg1->constraint_disable = true;
               r2.f2.rg2->constraint_disable = true;
45
               r2.f2.rgb->constraint_disable = true;
               regfoo my_struct;
                   constraint {
50
                      my_struct.pixelvalue.blue1 == my_struct.pixelvalue.red1;
                   } limit;
               };
55
```

| 15. User-defined properties                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| User-defined properties enable the creation of custom properties that extend the structural component types in a SystemRDL design. A <i>user-defined property</i> specifies one or more structural <b>component</b> types (e.g., <b>reg</b> ) to which it can be bound, has a single value-type (e.g., <b>ref</b> ), and (optionally) a <b>default</b> value. Unlike built-in properties, user-defined properties are not automatically bound to every instance of the specified component's type; instead they need to be bound per instance and/or component definition. | 5  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 10 |
| 15.1 Defining user-defined properties                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |
| A user-defined property definition appears as follows.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |
| <pre>property property_name {attribute; [attribute;]*};</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 15 |
| where                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |
| a) <i>property_name</i> specifies the new property.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |
| b) attributes are specified as attribute=value pairs, e.g., type=number (see 5.1.3.1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 20 |
| Component attribute values can also be combined by using the symbol.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 20 |
| c) <i>attributes</i> may be specified in any order.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |
| Table 30 specifies which attributes can be set in a user-defined property.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 25 |

| Attribute  | Description                                                                                                                                                                                                              | Allowable values                                                                                                                                                                            | Required |    |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----|
| component  | The structural component type with which<br>the property is associated. This attribute<br>shall be one or more of the allowable val-<br>ues. If more than one value is specified the<br>operator (inclusive OR) is used. | field, reg, regfile, addrmap, mem,<br>signal, constraint, or all.                                                                                                                           | Yes      | 3( |
| type       | The type of the property.<br>This may also be arrayed by adding []<br>after the <b>type</b> 's name.                                                                                                                     | See <u>Table 31</u> .                                                                                                                                                                       | Yes      | 35 |
| default    | The default value for the property.                                                                                                                                                                                      | Optional; needs to match the <b>type</b> of the property. Properties of <b>type ref</b> or any component type shall not reference an instance of a parameterized type as a <b>default</b> . | No       | 40 |
| constraint | Additional constraints on the property's value. Currently limited to <b>compo-nentwidth</b> for type <b>bit</b> . The assigned value may not have 1 value for a <b>bit</b> beyond the width of the <b>field</b> .        | componentwidth.                                                                                                                                                                             | No       | 45 |

Table 30—Attributes for user-defined properties

Table 31 details each of the possible user-defined property types.

# Table 31—User-defined types

| Type Description |                                                                          | Example        |    |  |  |  |
|------------------|--------------------------------------------------------------------------|----------------|----|--|--|--|
| number           | A bit value (see <u>Table 7</u> ). Used for backward compat-<br>ibility. | 0x10 or 8 'h8c |    |  |  |  |
| string           | Any valid string (see <u>Table 7</u> ).                                  | "Some String"  | 55 |  |  |  |

| 1 |
|---|
|   |
| 1 |

| 5 |
|---|

15

20

25

30

35

45

|                                           | Table 31—User-defined types (Continued)                                                      |                                                                     |  |  |  |  |
|-------------------------------------------|----------------------------------------------------------------------------------------------|---------------------------------------------------------------------|--|--|--|--|
| Туре                                      | Description                                                                                  | Example                                                             |  |  |  |  |
| boolean                                   | A two-state value (see <u>Table 7</u> ).                                                     | true or false                                                       |  |  |  |  |
| ref                                       | A reference to a component instance (see <u>Table 7</u> ).                                   | chip.block.reg.field                                                |  |  |  |  |
| bit                                       | An unsigned integer with the value of 0 or a Verilog-<br>style number (see <u>Table 7</u> ). | 8'h8c, 4'b1010                                                      |  |  |  |  |
| longint<br>unsigned                       | A 64-bit unsigned long integer (see <u>Table 7</u> ).                                        | 0x10, 256                                                           |  |  |  |  |
| enumerator                                | An enumerator from a user-defined enumeration.                                               | myEnum::VAL_2                                                       |  |  |  |  |
| struct literal                            | A <b>struct</b> instance consistent with the given type (see <u>Table 7</u> ).               | <pre>'myStruct{foo: 8'h10,     bar: '{"hello",     "world"} }</pre> |  |  |  |  |
| type[]                                    | An array of values whose type shall be picked from this table, excepting array.              | '{ 8'h80, 8'h8F, 8'h08,<br>8'h0F }                                  |  |  |  |  |
| addrmap, reg-<br>file, reg, mem,<br>field | A specialization of the <b>ref</b> keyword to instances of given type.                       | submap or submap.regA                                               |  |  |  |  |

## 15.1.1 Semantics

| a) | User-defined | properties are | global an | nd defined in | the root scope. |
|----|--------------|----------------|-----------|---------------|-----------------|
|----|--------------|----------------|-----------|---------------|-----------------|

- b) A user-defined property definition shall include the **component** property specification.
- c) A user-defined property definition shall include its *type* definition (see <u>Table 31</u>).
- d) The **default** attribute can result in some inconsistencies relative to the behavior of built-in properties to the language, especially relating to **boolean** properties. Built-in *booleans* in SystemRDL are inherently defaulted to **false**. With user-defined **boolean** properties, the **default** can be specified to be **true** or **false**. A **default** of **true** creates an inconsistency with respect to SystemRDL property assignments.
- e) The **default** value shall be *assignment compatible* with the property **type**, as defined in 6.4.
- f) Field values shall not require more bits than are available in the field.

## 40 **15.1.2 Example**

This example defines several user-defined properties.

property a\_map\_p { type = string; component = addrmap | regfile; };
property some\_bool\_p { type = boolean; component = field; default = false; };

# 15.2 Assigning (and binding) user-defined properties

| 50 |              |            |        |          |             |            |          |                   |
|----|--------------|------------|--------|----------|-------------|------------|----------|-------------------|
|    | User-defined | properties | may be | assigned | like genera | al propert | ies (see | e <u>5.1.3</u> ). |

A user-defined property is bound when it is instantiated within a component definition or assigned a value.

| 15.2.1 Semantics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| <ul> <li>a) User-defined properties can be dynamically assigned to any component in its component attribute.</li> <li>b) It shall be an error if there is an attempt to assign a user-defined property in a component that is not specified in its component attribute.</li> <li>c) User-defined properties can be bound to a component without setting a value.</li> <li>d) If a user-defined property has an enumeration type, any value assignment to the property shall be one of the named enumerators of that enumeration type.</li> </ul> | 5<br>10 |
| 15.2.2 Examples                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |
| These examples show the definition and assignment of several user-defined properties.<br><i>Example 1</i>                                                                                                                                                                                                                                                                                                                                                                                                                                        | 15      |
| <pre>property a_map_p { type = string; component = addrmap   regfile; };<br/>property some_bool_p { type = boolean; component = field; default = false; };<br/>property some_ref_p { type = reference; component = all; };<br/>property some_num_p { type = number; default = 0x10; component = field   reg</pre>                                                                                                                                                                                                                                | 20      |
| addrmap foo {<br>reg{<br>field { some_bool_p; } field1; // Attach some_bool_p to the field<br>// with a value of false;                                                                                                                                                                                                                                                                                                                                                                                                                          | 25      |
| <pre>field { some_bool_p = true; some_num_p; } field2; // Attach some_bool_p to the field with a value of true; field1-&gt;some_ref_p = field2; // create a reference some_num_p = 0x20; // Assign this property to the reg and give it value } bar;</pre>                                                                                                                                                                                                                                                                                       | 30      |
| <pre>a_map_p; // The property has been bound to the map but it has not been</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 35      |
| Example 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         |
| <pre>enum myEncoding {     alpha = 1'b0;     beta = 1'b1; };</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 40      |
| <pre>property my_enc_prop {    type = myEncoding;    component = field;    default = beta; };</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                              | 45      |
| addrmap top {                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 50      |

| 1  |  |  |  |  |
|----|--|--|--|--|
| 5  |  |  |  |  |
| 10 |  |  |  |  |
| 15 |  |  |  |  |
| 20 |  |  |  |  |
| 25 |  |  |  |  |
| 30 |  |  |  |  |
| 35 |  |  |  |  |
| 40 |  |  |  |  |
| 45 |  |  |  |  |
| 50 |  |  |  |  |
| 55 |  |  |  |  |

| 16. Preprocessor directives                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| SystemRDL provides for file inclusion and text substitution through the use of preprocessor directives. There are two phases of preprocessing in SystemRDL: embedded Perl preprocessing and a more traditional Verilog-style preprocessor. The embedded Perl preprocessing is handled first and the resulting substituted code is passed through a traditional Verilog-style preprocessor.                                                                                                                                        | 5  |
| 16.1 Embedded Perl preprocessing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 10 |
| The SystemRDL preprocessor provides more power than traditional macro-based preprocessing without the dangers of unexpected text substitution. Instead of macros, SystemRDL allows designers to embed snippets of Perl code into the source.                                                                                                                                                                                                                                                                                      |    |
| 16.1.1 Semantics                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 15 |
| a) Perl snippets shall begin with <% and be terminated by %>; between these markers any valid Perl syntax may be used.                                                                                                                                                                                                                                                                                                                                                                                                            |    |
| b) Any SystemRDL code outside of the Perl snippet markers is equivalent to the Perl print 'RDL code' and the resulting code is printed directly to the post-processed output.                                                                                                                                                                                                                                                                                                                                                     | 20 |
| c) <%=\$VARIABLE%> (no whitespace is allowed) is equivalent to the Perlprint \$VARIABLE.                                                                                                                                                                                                                                                                                                                                                                                                                                          |    |
| d) The resulting Perl code is interpreted and the result is sent to the traditional Verilog-style preproces-<br>sor.                                                                                                                                                                                                                                                                                                                                                                                                              | 25 |
| 16.1.2 Example                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |
| This example shows the use of the SystemRDL preprocessor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |    |
| // An example of Apache's ASP standard for embedding Perl<br>reg myReg {                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 30 |
| <pre>&lt;% for( \$i = 0; \$i &lt; 6; \$i += 2 ) { %&gt; myField data&lt;%=\$i%&gt; [&lt;%=\$i+1%&gt;:&lt;%=\$i%&gt;];</pre>                                                                                                                                                                                                                                                                                                                                                                                                       | 35 |
| When processed, this is replaced by the following.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |    |
| // Code resulting from embedded Perl script<br>reg myReg {                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 40 |
| myField data0 [1:0];<br>myField data2 [3:2];                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |
| <pre>myField data4 [5:4]; };</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 45 |
| 16.2 Verilog-style preprocessor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
| SystemRDL also provides for file inclusion and text substitution through the use of Verilog-style preprocessor directives. A SystemRDL file containing <i>file inclusion directives</i> shall be equivalent with one containing each included file in-lined at the place of its inclusion directive. A SystemRDL file containing a <i>text substitution directive</i> shall be equivalent to one containing the text resolved according to the text substitution directive in-lined at the place of the text inclusion directive. | 50 |
| The Verilog-style preprocessing always takes any embedded Perl preprocessing output as its source.                                                                                                                                                                                                                                                                                                                                                                                                                                | 55 |

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change.

## 1 16.2.1 Verilog-style preprocessor directives

These directives are a subset of those defined by the SystemVerilog (IEEE Std 1800<sup>™</sup>) and Verilog (IEEE Std 1364<sup>™</sup>) standards to allow SystemRDL source files to include other files and provide protection from definition collisions due to the multiple inclusions of a file. The text macro define directives are defined by the SystemVerilog standard and the other directives are defined by the Verilog standard.

Table 32 shows which preprocessor are included in SystemRDL.

| Directive | Defining standard | Description                |  |
|-----------|-------------------|----------------------------|--|
| `define   | SystemVerilog     | Text macro definition      |  |
| `if       | Verilog           | Conditional compilation    |  |
| `else     | Verilog           | Conditional compilation    |  |
| `elsif    | Verilog           | Conditional compilation    |  |
| `ifdef    | Verilog           | Conditional compilation    |  |
| `ifndef   | Verilog           | Conditional compilation    |  |
| `include  | Verilog           | File inclusion             |  |
| `line     | Verilog           | Source filename and number |  |
| `undef    | Verilog           | Undefine text macro        |  |

## Table 32—Verilog-style preprocessor directives

30

35

40

25

5

10

15

20

All other directives defined by the SystemVerilog and Verilog standards are removed during preprocessing, i.e., 'begin\_keywords, 'celldefine, 'default\_nettype, 'end\_keywords, 'endcelldefine, 'nounconnected\_drive, 'pragma, 'resetall, 'timescale, and 'unconnecteded\_drive.

SystemRDL does not support the SystemVerilog predefined include files or the SystemVerilog or Verilog languages beyond the directives given in <u>Table 32</u>.

## 16.2.2 Limitations on nested file inclusion

Nested includes are allowed, although the following restrictions are placed on this.

- a) The number of nesting levels for include files shall be bounded.
- b) Implementations may limit the maximum number of levels to which include files can be nested, but the limit shall be at least 15 levels.

50

10

15

20

25

30

35

40

45

50

55

The concept of signals was introduced in <u>Clause 8</u> and the signal properties were described in <u>8.2</u>. Signals, in addition to providing a means of interconnecting components in SystemRDL, have a very critical role in controlling resets for generated hardware. This clause explains the advanced signal properties (see <u>Table 10</u>) 5 and their application.

# 17.1 Application of signals for reset

17. Advanced topics in SystemRDL

There are many ways to do resets in hardware and this is where the advanced use of signals applies. Signal components have properties, such as **sync**, **async**, **activelow**, and **activehigh**, which are used to describe the use behavior of the signal, but when that signal is specified as a reference to the **resetsignal** property of a field then they affect the field's reset behavior as well. A signal does not become a reset signal until a signal instance is referenced by a field's **resetsignal** property. The following signal properties can also be used to accommodate more complex scenarios.

- a) The field\_reset property specifies all fields in the address map shall be reset by the signal to which this property is attached unless the field instance has a resetsignal property specified. This property cannot be specified on more than one signal instance in an address map and the address map's non-address map instances. This does not mean, however, that all fields then have to be reset by this signal. The user can still use the resetsignal property to override the default for specific fields. See <u>c</u> for priority and propagation rules.
- b) The cpuif\_reset property specifies the reset for the CPU interface to which the registers are connected. The designer may wish to be able to reset the CPU interface/bus while retaining the values of the registers. In the default case, the fields and the CPU interface/bus are both reset by the default signal. This property gives the designer the ability to customize such behavior. This property cannot be specified on more than one signal instance in an address map and its address maps non-address map instances.

cpuif\_reset is inherited from the enclosing lexical scope.

- c) The value of a field component with a specified reset value is updated to this value or a field with write-once access is returned to a writable state when the field component reset signal is asserted. The field component reset signal is specified with the following priority.
  - 1) The dynamic assignment to the field instance **resetsignal** property.
  - 2) The **resetsignal** property assignment within the **field** component declaration.
  - 3) The default **resetsignal** property assignment inherited from the **field** component declaration's enclosing scope.
  - 4) The **signal** component with the **field\_reset** property within the same scope as the **field** type definition.
  - 5) The **signal** component with the **field\_reset** property following the scoping rules from the field instantiation.
  - 6) The implementation port specified by the CPU interface bus protocol as the reset signal.
  - 7) An implementation-dependent port or net.

The following examples highlight two different ways to customize reset behavior.

# Example 1

This example shows usage of **resetsignal**.

```
addrmap top{
    signal { activelow; async; } reset_l; // Define a single bit signal
    reg {
```

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change.

Here the **resetsignal** property is used to customize the reset behavior. Although this approach is always valid, it can be cumbersome if a user wishes to vary from the default significantly with a large number of fields. In those cases, **field\_reset** and **cpuif\_reset** can be used to accommodate those more complex scenarios, as shown in *Example 2*.

# 15 Example 2

This example shows usage of **cpuif\_reset** and **field\_reset** from the PCI Type 0 Config Header.

```
signal
                       {
20
                    name="PCI Soft Reset";
                    desc="This signal is used to issue a soft reset to the PCI(E) device";
                                 // Define this signal is active low
                    activelow;
                                 // define this reset type is asynchronous
                    asvnc;
                    field_reset; // define this signal to reset the fields by default
25
                    // This signal will be hooked to registers PCI defines as NOT Sticky.
                    // This means they will be reset by this signal.
               } pci_soft_reset;
                 signal {
30
                    name="PCI Hard Reset";
                    desc="This signal the primary hard reset signal for the PCI(E) device";
                    async;
                                 // define this reset type is asynchronous
                    activelow;
                                 // Define this signal as active low
                    cpuif_reset; // This signal will be or'd with the PCI Soft Reset Signal
35
                                  // to form the master hard reset which will reset all flops.
                                 // The soft reset signal above will not reset flops that PCI
                                  // defines as STICKY.
                 } pci_hard_reset;
               reg {
                                                                          // PCIE_REG_BIST
40
                   name = "BIST";
                   desc = "This optional register is used for control and status of BIST.
                           Devices that do not support BIST always returns a value of 0
                           (i.e., treat it as a reserved register). A device whose
                          BIST is invoked shall not prevent normal operation of the PCI bus.
45
                           Figure 6-4 shows the register layout and Table 6-3 describes the
                           bits in the register.";
                   regwidth = 8;
                   field {
                     name = "cplCode";
50
                    desc = "A value of 0 means the device has passed its test. Non-zero values
                          mean the device failed. Device-specific failure codes can be encoded
                              in the non-zero value.";
                     hw = rw; sw = r;
                     fieldwidth = 4;
55
                  } cplCode [3:0];// since this signal has no resetsignal property it defaults
```

```
1
                    // to using the signal with field reset which is
                    // the pci_soft_reset signal
                                                                                        5
    field {
      name = "start";
      desc = "Write a 1 to invoke BIST. Device resets the bit when BIST is
             complete. Software should fail the device if BIST is not complete
                                                                                        10
              after 2 seconds.";
      hw = rw; sw = rw;
      fieldwidth = 1;
    } start [6:6]; // resetsignal is also pci_soft_reset
                                                                                       15
    field {
      name = "capable";
desc = "Return 1 if device supports BIST. Return 0 if the device is not BIST
              capable.";
                                                                                       20
      hw = rw; sw = rw;
      fieldwidth = 1;
      resetsignal = pci_hard_reset;
   } capable [7:7]=0; // resetsignal is explicitly specified as pci_hard_reset
                                                                                       25
  } PCIE_REG_BIST;
```

## 17.2 Understanding hierarchical interrupts in SystemRDL

SystemRDL also provides the capability to create a hierarchy of interrupts. This can be useful for describing 30 a complete interrupt tree of a design (see Figure 2).



Figure 2—Hierarchical interrupt structure

Within each level of the hierarchical description, interrupt registers and enable registers can be used to gate the propagation of interrupts. The detailed diagram for a block depicted in the hierarchy shown in <u>Figure 2</u> is represented by the example shown in <u>Figure 3</u>.

55



Figure 3—Block interrupt example

<sup>25</sup> Multiple levels of hierarchy are needed to effectively demonstrate this interrupt tree. The example shown in the following subclauses is quite long (and broken into multiple code segments), but tries to show the use of the interrupt constructs in a practical application.

# 30 17.2.1 Example structure and perspective

The (example) SystemRDL code needed to match the hierarchical interrupt structure shown in Figure 2 needs to contain four leaf blocks. Each of these leaf blocks needs to contain three interrupt events. These lowest level events are **stickybit** and the OR of the three interrupts propagates that interrupt to the next level in the tree. This OR'd output indicates some block in the design actually has a interrupt pending. Finally, the four blocks are aggregated to create a single interrupt pin. Enables are used throughout this example, but it could just as easily be a mask instead.

40 This example is broken into sections to make it more readable. The previous description and example are built from a bottom-up perspective.

Considering this example from a software driver's viewpoint (from the top down), there are two top-level signals that are emitted to software: one indicates a interrupt of some priority has occurred; the other indicates an interrupt of another priority has occurred. These could map to fatal and non-fatal interrupts or anything else the user desires. For each level on the tree, there is enabling so the software can easily **disable**/ **enable** these interrupts at each level of the tree.

So the software begins the process by seeing if an **intr** or **halt** is set in the top-level register. Once that has been determined, the software needs to read the master interrupt register and determine in which block(s) the interrupt has occurred. Once that has been determined, the leaf interrupt for that block can be read to determine which specific interrupt bits have been set. The software can then address the leaf interrupts and clear them when appropriate. Since the master level and global level are defined as **nonsticky** in this example, the software only needs to clear the leaf and then the next two levels of the tree will clear themselves automatically.

> Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change.

35

| 17.2.2 Code snippet 1                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| The first code snippet section defines a basic block's interrupt register, which contains three single-bit interrupts. It also has a single multi-bit <b>sticky</b> field used for capturing the cause of the multi-bit error correcting code interrupt. These interrupt events are created by hardware and cleared by software. The software then needs to do a write one to clear. Notice how the <b>default</b> keyword is used to reduce the size of the code. | 5  |
| //<br>// Block Level Interrupt Register<br>//                                                                                                                                                                                                                                                                                                                                                                                                                      | 10 |
| <pre>reg block_int_r {    name = "Example Block Interrupt Register";    desc = "This is an example of an IP Block with 3 int events. 2 of these         are non-fatal and the third event multi_bit_ecc_error is fatal";</pre>                                                                                                                                                                                                                                     | 15 |
| default hw=w; // HW can Set int only<br>default sw=rw; // SW can clear<br>default woclr; // Clear is via writing a 1                                                                                                                                                                                                                                                                                                                                               | 20 |
| <pre>field {    desc = "A Packet with a CRC Error has been received";    level intr; } crc_error = 0x0;</pre>                                                                                                                                                                                                                                                                                                                                                      | 25 |
| <pre>field {   desc = "A Packet with an invalid length has been received";</pre>                                                                                                                                                                                                                                                                                                                                                                                   |    |
| <pre>field {   desc="An uncorrectable multi-bit ECC error has been received";   level intr; } multi bit ecc error = 0;</pre>                                                                                                                                                                                                                                                                                                                                       | 30 |
| <pre>field {    desc="Master who was active when ECC Error Occurred";    sticky;</pre>                                                                                                                                                                                                                                                                                                                                                                             | 35 |
| <pre>} active_ecc_master[7:4] = 0; // Example of multi-bit sticky field</pre>                                                                                                                                                                                                                                                                                                                                                                                      | 40 |

# 17.2.3 Code snippet 2

This next code snippet only defines the enable register associated with the interrupt register from 17.2.2—it does not instantiate the register or connect it up at this point. 45

```
reg block_int_en_r {
  name = "Example Block Interrupt Enable Register";
  desc = "This is an example of an IP Block with 3 int events";
  default hw=na; // HW can't access the enables
  default sw=rw; // SW can control them
  field {
    desc = "Enable: A Packet with a CRC Error has been received";
    } crc_error = 0x1;
    55
}
```

15

35

40

```
field {
    desc = "Enable: A Packet with an invalid length has been received";
    len_error = 0x1;

    field {
        desc = "Enable: A multi-bit error has been detected";
        lmulti_bit_ecc_error = 0x0;
    }; // End of Reg: block_int_en_r
```

#### 17.2.4 Code snippet 3

This next code snippet only defines a second-priority enable register associated with the interrupt register from 17.2.2—it does not instantiate the register or connect it up at this point.

```
reg block_halt_en_r {
                 name = "Example Block Halt Enable Register";
                 desc = "This is an example of an IP Block with 3 int events";
                 default hw=na; // HW can't access the enables
20
                 default sw=rw; // SW can control them
                 field {
                   desc = "Enable: A Packet with a CRC Error has been received";
                 } crc_error = 0x0; // not a fatal error do not halt
25
                 field {
                   desc = "Enable: A Packet with an invalid length has been received";
                 } len_error = 0x0; // not a fatal error do not halt
30
                 field {
                   desc = "Enable: A Packet with an invalid length has been received";
                 } multi_bit_ecc_error = 0x1; // fatal error that will
                                               // cause device to halt
               }; // End of Reg: block_halt_en_r
```

#### 17.2.5 Code snippet 4

This next code snippet defines the next level up interrupt register (called the *master interrupt register*). Each of the outputs of the leaf block's interrupt registers will connect into this block later. This section is made **nonsticky**, so the leaf interrupts are automatically cleared by this register.

```
//-----
             // Master Interrupt Status Register
             //-----
45
             reg master_int_r {
               name = "Master Interrupt Status Register";
               desc = "This register contains the status of the 4 lower Module interrupts.
                      Also an interrupt signal (myMasterInt) is generated which is the 'OR'
                      of the four Module interrupts. A Halt signal is also generated which
                      represents the bitwise or the masked/enabled halt bits";
50
               default nonsticky intr; // Unless we want to have to clear this separately
                                    // from the leaf intr this should be non sticky
               default hw=w; // HW normally won't want to access this but it could
               default sw=r; // Software can just read this. It clears the leaf intr's
55
                           // to clear this
```
```
1
  field {
   desc = "An interrupt has occurred with ModuleD.
            Software must read the ModuleD Master Interrupt Register
            in order to determine the source of the interrupt.";
                                                                                        5
  } module_d_int[3:3] = 0x0;
  field {
    desc = "An interrupt has occurred with ModuleC.
                                                                                       10
            Software must read the ModuleC Master Interrupt Register
            in order to determine the source of the interrupt.";
  } module_c_int[2:2] = 0x0;
  field {
                                                                                       15
   desc = "An interrupt has occurred with ModuleB.
            Software must read the ModuleB Interrupt Register
            in order to determine the source of the interrupt.";
} module_b_int[1:1] = 0x0;
field {
                                                                                       20
 desc = "An interrupt has occurred with ModuleA.
          Software must read the ModuleA Master Interrupt Register
          in order to determine the source of the interrupt.";
  } module_a_int[0:0] = 0x0;
};
                                                                                       25
```

#### 17.2.6 Code snippet 5

This next code snippet defines the enable register for the master interrupt register set in 17.2.5.

```
30
11
// The following is the accompanying enable register. Since the combinatorial
// logic for processing the interrupt is internal to the generated verilog,
// there's no need for an external port - which is realized by assigning "na"
// to the hw attribute of the specific field. This could have been defined as
// a mask register just as easily...
                                                                             35
11
//-----
// Interrupt Enable Register
//-----
                                                                             40
reg master_int_en_r {
 name = "Master Interrupt Enable Register";
 desc = "Configurable register used in order to enable the corresponding
        interrupts found in myMasterInt register.";
                                                                             45
 default hw = na;
 default sw = rw;
 field {
   desc = "Interrupt enable for ModuleD Interrupts. 1 = enable, 0 = disable";
                                                                             50
 } module_d_int_en[3:3] = 0x0;
 field {
   desc = "Interrupt enable for ModuleC Interrupts. 1 = enable, 0 = disable";
 } module_c_int_en[2:2] = 0x0;
```

```
1 field {
    desc = "Interrupt enable for ModuleB Interrupts. 1 = enable, 0 = disable";
    module_b_int_en[1:1] = 0x0;
5 field {
    desc = "Interrupt enable for ModuleA Interrupts. 1 = enable, 0 = disable";
    module_a_int_en[0:0] = 0x0;
    };
```

# <sup>10</sup> 17.2.7 Code snippet 6

This next code snippet defines an alternate enable register for the master interrupt register set in 17.2.5.

```
//-----
15
              // Halt Enable Register
              //-----
              // The halt en is another enable or mask that could be used to generate an
              // alternate signal like a halt that represents a fatal error in the system or
              // some other event NOTE: It does not have to mean fatal as the name implies
20
              // its just another priority level for interrupts...
              reg master_halt_en_r {
                name = "Master Halt Enable Register";
                desc = "Configurable register used in order to enable the corresponding
25
                       interrupts found in myMasterInt register.";
                default hw = na;
                default sw = rw;
30
                field {
                 desc = "Halt enable for ModuleD Interrupts. 1 = enable, 0 = disable";
                } module_d_halt_en[3:3] = 0x0;
                field {
                 desc = "Halt enable for ModuleC Interrupts. 1 = enable, 0 = disable";
35
                } module_c_halt_en[2:2] = 0x0;
                field {
                 desc = "Halt enable for ModuleB Interrupts. 1 = enable, 0 = disable";
                } module_b_halt_en[1:1] = 0x0;
40
                field {
                 desc = "Halt enable for ModuelA Interrupts. 1 = enable, 0 = disable";
                } module_a_halt_en[0:0] = 0x0;
              };
45
```

#### 17.2.8 Code snippet 7

Now, the third level up from the leaf in the interrupt tree needs to be addressed (called the *global interrupt register*). This register distills down the fact there is an interrupt present in at least one of the four blocks into a single **intr** signal and a single **halt** signal.

55

```
1
   // This takes the block int which feeds the master int and then distills it
   // down one more level so we end up with a single bit intr and single bit halt...
   //-----
   // Global Interrupt/Halt Enable Register
                                                                                    5
   //-----
   reg final_en_r {
    name = "My Final Enable Register";
                                                                                   10
    desc = "This enable allows all interrupts/halts to be suppressed
            with a single bit";
    default hw = na;
    default sw = rw;
                                                                                   15
    field {
      desc = "Global Interrupt Enable. 1 = enable, 0 = disable";
    } global_int_en = 0x0;
    field {
                                                                                   20
      desc = "Global Halt Enable. 1 = enable, 0 = disable";
    } global_halt_en = 0x0;
  };
                                                                                   25
   reg final_int_r {
    name = "My Final Int/Halt Register";
    desc = "This distills a lower level interrupts into a final bit than can be
            masked";
    default sw = r; // sw does not need to clear global_int
                   // (global_int is of type final_int_r)
                                                                                   30
                   // instead it clears itself when all master int intr
                   // bits get serviced
    default nonsticky intr;
    default hw = w; // w needed since dyn assign below implies interconnect to hw
                                                                                   35
                   11
                        global_int.global_int->next = master_int->intr;
    field {
      desc = "Global Interrupt";
    } global_int = 0x0;
                                                                                   40
    field {
      desc = "Global Halt";
     } global_halt = 0x0;
   };
                                                                                   45
17.2.9 Code snippet 8
```

Once all the components for the three-level interrupt tree have been defined, an address map needs to be defined and any previously defined components need to be instantiated and interconnected. This section does all this—it is the most critical part of the example to understand.

```
addrmap int_map_m {
    name = "Sample ASIC Interrupt Registers";
    desc = "This register map is designed how one can use interrupt concepts
    effectively in SystemRDL";
```

50

| 1  | // Leaf Interrupts                                                                                                                                                                                                                                                                       |
|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | // Block A Registers                                                                                                                                                                                                                                                                     |
| 5  | <pre>block_int_r block_a_int; // Instance the Leaf Int Register<br/>block_int_en_r block_a_int_en; // Instance the corresponding Int Enable</pre>                                                                                                                                        |
| 10 | block_halt_en_r block_a_halt_en; // Instance the corresponding halt enable<br>// register                                                                                                                                                                                                |
| 15 | <pre>// This block connects the int bits to their corresponding // int enables and halt enables // block_a_int.crc_error-&gt;enable = block_a_int_en.crc_error; block_a_int.len_error-&gt;enable = block_a_int_en.len_error; block_a_int.multi_bit_ecc_error-&gt;enable =</pre>          |
| 20 | <pre>block_a_int_en.multi_bit_ecc_error;<br/>block_a_int.crc_error-&gt;haltenable = block_a_halt_en.crc_error;<br/>block_a_int.len_error-&gt;haltenable = block_a_halt_en.len_error;<br/>block_a_int.multi_bit_ecc_error-&gt;haltenable =<br/>block_a_halt_en.multi_bit_ecc_error;</pre> |
|    | 17.2.10 Code snippet 9                                                                                                                                                                                                                                                                   |
| 25 |                                                                                                                                                                                                                                                                                          |

<u>17.2.9</u> instances the leaf interrupt, instances its enable and halt enable, and assigns **enable** and **haltenable** properties to reference the respective enable registers. This code snippet repeats this process three more times: one each for blocks b, c, and d.

// Block B Registers

```
block_int_r block_b_int @0x100;
block_int_en_r block_b_int_en;
block_halt_en_r block_b_halt_en;
```

```
block_b_int.crc_error->enable = block_b_int_en.crc_error;
block_b_int.len_error->enable = block_b_int_en.len_error;
block_b_int.multi_bit_ecc_error->enable =
block_b_int_en.multi_bit_ecc_error;
```

```
40 block_b_int.crc_error->haltenable = block_b_halt_en.crc_error;
block_b_int.len_error->haltenable = block_b_halt_en.len_error;
block_b_int.multi_bit_ecc_error->haltenable =
block_b_halt_en.multi_bit_ecc_error;
```

45 // Block C Registers

```
block_int_r block_c_int @0x200;
block_int_en_r block_c_int_en;
block_halt_en_r block_c_halt_en;
```

```
block_c_int.crc_error->enable = block_c_int_en.crc_error;
block_c_int.len_error->enable = block_c_int_en.len_error;
block_c_int.multi_bit_ecc_error->enable =
block_c_int_en.multi_bit_ecc_error;
```

```
55
```

50

30

```
1
block_c_int.crc_error->haltenable = block_c_halt_en.crc_error;
block_c_int.len_error->haltenable = block_c_halt_en.len_error;
block_c_int.multi_bit_ecc_error->haltenable =
 block_c_halt_en.multi_bit_ecc_error;
                                                                                     5
// Block D Registers
block_int_r
                block_d_int @0x300;
block_int_en_r block_d_int_en;
                                                                                    10
block_halt_en_r block_d_halt_en;
block_d_int.crc_error->enable = block_d_int_en.crc_error;
block_d_int.len_error->enable = block_d_int_en.len_error;
block_d_int.multi_bit_ecc_error->enable =
                                                                                    15
 block_d_int_en.multi_bit_ecc_error;
block_d_int.crc_error->haltenable = block_d_halt_en.crc_error;
block_d_int.len_error->haltenable = block_d_halt_en.len_error;
block_d_int.multi_bit_ecc_error->haltenable =
 block_d_halt_en.multi_bit_ecc_error;
                                                                                    20
```

#### 17.2.11 Code snippet 10

This code snippet instances the master interrupt register and its associated enables. The interesting part of this section is how the leaf register's **intr** property (which represents the OR of all the interrupts in the leaf register) are connected together.

```
11
// Master Interrupts
11
                                                                                    30
                                                    @0x01000;
master int r
                           master_int
                           master_halt
master_int_r
                                                             ;
master_int_en_r
                           master_int_en
                                                             ;
master_halt_en_r
                           master_halt_en
                                                             ;
                                                                                    35
// Associate the INT's with the EN's
master_int.module_d_int->enable = master_int_en.module_d_int_en;
master_int.module_c_int->enable = master_int_en.module_c_int_en;
master_int.module_b_int->enable = master_int_en.module_b_int_en;
master_int.module a int->enable = master int_en.module a int_en;
                                                                                    40
// Associate the HALT's with the EN's
master_halt.module_d_int->haltenable = master_halt_en.module_d_halt_en;
master_halt.module_c_int->haltenable = master_halt_en.module_c_halt_en;
master_halt.module_b_int->haltenable = master_halt_en.module_b_halt_en;
master_halt.module_a_int->haltenable = master_halt_en.module_a_halt_en;
                                                                                    45
// Now hook the lower level leaf interrupts to the higher level interrupts
// This connects the Implicit Or from Block A's INT reg after
// masking/enable to the next level up (master)
master_int.module_a_int->next = block_a_int->intr;
                                                                                    50
// This connects the Implicit Or from Block B's INT reg after
// masking/enable to the next level up (master)
master_int.module_b_int->next = block_b_int->intr;
                                                                                    55
```

103

| 1  | <pre>// This connects the Implicit Or from Block C's INT reg after // masking/enable to the next level up (master) master_int.module_c_int-&gt;next = block_c_int-&gt;intr;</pre>   |
|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5  | <pre>// This connects the Implicit Or from Block D's INT reg after // masking/enable to the next level up (master) master_int.module_d_int-&gt;next = block_d_int-&gt;intr;</pre>   |
| 10 | <pre>// This connects the Implicit Or from Block A's HALT reg after // masking/enable to the next level up (master) master_halt.module_a_int-&gt;next = block_a_int-&gt;halt;</pre> |
| 15 | <pre>// This connects the Implicit Or from Block B's HALT reg after // masking/enable to the next level up (master) master_halt.module_b_int-&gt;next = block_b_int-&gt;halt;</pre> |
|    | <pre>// This connects the Implicit Or from Block C's HALT reg after // masking/enable to the next level up (master) master_halt.module_c_int-&gt;next = block_c_int-&gt;halt;</pre> |
| 20 | <pre>// This connects the Implicit Or from Block D's HALT reg after // masking/enable to the next level up (master) master halt.module d int-&gt;next = block d int-&gt;halt;</pre> |

#### 17.2.12 Code snippet 11

25

55

This final section of the example instantiates a single top-level interrupt register containing a single **intr** and a single **halt** signal. This constitutes the final resolved interrupt that has been fully masked/enabled throughout the tree.

```
30
                 final_int_r
                                 global_int
                                                @0x1010;
                 // Inst the global int/halt register
                 final_en_r
                                  global_int_en @0x1014;
                 // Inst the global int/halt enable register
35
                 global_int.global_int->enable = global_int_en.global_int_en;
                 // Associate the INT with the EN
                 global_int.global_halt->haltenable = global_int_en.global_halt_en;
                 // Associate the HALT with the EN
40
                 global_int.global_int->next = master_int->intr;
                 // Take the or of the 4 blocks in the master
                 // Int and create one final interrupt
45
                 global_int.global_halt->next = master_halt->halt;
                 // Take the or of the 4 blocks in the master
                 // Int and create one final halt
               };
50
```

#### 17.3 Understanding bit ordering and byte ordering in SystemRDL

Bit ordering and byte ordering are common source of confusion for many engineers. This subclause discusses the bit ordering and byte ordering rules in SystemRDL and also illustrates their use with some examples.

| 17.3.1 Bit ordering                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| The most common bit ordering is called <b>lsb0</b> . This is demonstrated in the scheme below, where the least significant bit is 0.                                                                                                                                                                                                                                                                                                                       |    |
| Bit: 76543210                                                                                                                                                                                                                                                                                                                                                                                                                                              | 5  |
| Value: 10010110 (decimal 150)                                                                                                                                                                                                                                                                                                                                                                                                                              |    |
| The alternative scheme is called <b>msb0</b> . This is demonstrated in the scheme below, where the least significant bit is 7.                                                                                                                                                                                                                                                                                                                             | 10 |
| Bit: 01234567                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |
| Value: 10010110 (decimal 150)                                                                                                                                                                                                                                                                                                                                                                                                                              |    |
| In SystemRDL, a user can define address maps using both conventions, but a single <b>addrmap</b> needs to have homogeneous <b>lsb0</b> or <b>msb0</b> descriptions. The compiler shall determine <b>lsb0</b> and <b>msb0</b> when explicit indices for a register are defined, e.g., [0:7], but it is not possible to determine the bit order when the first field uses implicit indices and leaves the choice of assigning final indexes to the compiler. | 15 |
| Example 1                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 20 |
| In this case, the first field is explicit and defines the map as <b>msb0</b> , therefore no <b>explicit</b> keyword is needed.                                                                                                                                                                                                                                                                                                                             |    |
| addrmap some_map {<br>reg {<br>field {}f1[12:19] = 8'b10010110;                                                                                                                                                                                                                                                                                                                                                                                            | 25 |
| <pre>// In this example its clear the compiler should use // msb0 mode as the first field infers this by its // use of explicit indices. Register bit 12 is reset to a 1.</pre>                                                                                                                                                                                                                                                                            | 20 |
| <pre>field {}f2[4] = 4'b1010;     // f2 is from register bits 8 to 11     // reset value of bit 8 is 1 bit 9 is 0</pre>                                                                                                                                                                                                                                                                                                                                    | 30 |
| // bit 10 is 1, and bit 11 is 0                                                                                                                                                                                                                                                                                                                                                                                                                            |    |
| <pre>} reg1; };</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                      | 35 |
| Example 2                                                                                                                                                                                                                                                                                                                                                                                                                                                  |    |
| In this case, the first field is implicit and the compiler needs to see a keyword to decide bit ordering.                                                                                                                                                                                                                                                                                                                                                  | 40 |
| addrmap some_map {     lsb0;                                                                                                                                                                                                                                                                                                                                                                                                                               |    |
| <pre>reg {   field {}f1[8] = 8'b10010110;   // In this example the compiler can't tell if it's [7:0] or [0:7]   // without the lsb0 keyword above.   // It could be either bit order.</pre>                                                                                                                                                                                                                                                                | 45 |
| // Here register bit 0 is reset to a 0.                                                                                                                                                                                                                                                                                                                                                                                                                    |    |

} reg1;

field {}f2[4] = 4'b1010;

// f2 is from register bits 11 to 8
// reset value of bit 8 is 0, bit 9 is 1,

// bit 10 is 0, and bit 11 is 1  $\,$ 

105

50

#### 1 Example 3

In this case, the first field is implicit and the compiler needs to see a keyword to decide bit ordering.

| 0  | addrmap some_map {                                                  |
|----|---------------------------------------------------------------------|
|    | msb0;                                                               |
|    | reg {                                                               |
| 10 | field {}f1[8] = 8'b10010110;                                        |
|    | // In this example the compiler can't tell if it's [7:0] or [24:31] |
|    | // without the msb0 keyword above.                                  |
|    | // The msb0 keyword implies it's from 24 to 31.                     |
| 15 | // Here register bit 24 is reset to a 1.                            |
|    | field {}f2[4] = 4'b1010;                                            |
|    | // f2 is from register bits 20 to 23                                |
|    | // reset value of bit 20 is 1, bit 21 is 0,                         |
| 20 | // bit 22 is 1, and bit 23 is 0                                     |
|    | } regl;                                                             |
|    | };                                                                  |

#### 17.3.2 Byte ordering

Byte ordering is another common source of confusion. Byte order is often called *endianness* (see [B2]). In SystemRDL, two properties are defined for dealing with this: **bigendian** and **littleendian**. These properties do nothing related to the structure of SystemRDL, but they provide information to back-end generators which are generating bus interfaces. Therefore, these properties are only attached to **addrmap** blocks since they define the boundary of a generatable RTL module. SystemRDL's smallest endian or atomic unit is a byte and the data unit on which the endianness is performed is controlled by the **accesswidth** property. The following example uses a 64-bit register with a 32-bit accesswidth, where the words are ordered in a big endian fashion (per convention) and the bytes are ordered as shown.

Example

If 0x0123456789ABCDEF is assigned a base address of 0x800,

40 a **bigendian** bus would address the bytes as:

800 801 802 803 804 805 806 807 01 23 45 67 89 AB CD EF

a littleendian bus would address the bytes as:

800 801 802 803 804 805 806 807 67 45 23 01 EF CD AB 89

Thus, these two properties do not affect bit ordering in a SystemRDL file; instead, they correspond to byte ordering on output generators.

25

30

35

45

| Annex A                                                                                                                                                         | 1  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| (informative)                                                                                                                                                   |    |
| Bibliography                                                                                                                                                    | 5  |
| [B1] IEEE 100, <i>The Authoritative Dictionary of IEEE Standards Terms</i> , Seventh Edition. New York: Institute of Electrical and Electronics Engineers, Inc. | 10 |
| [B2] <i>Endianness References</i> , see <u>http://en.wikipedia.org/wiki/Endianness</u> and <u>http://3bc.bertrand-blanc.com/endianness05.pdf</u> .              |    |
|                                                                                                                                                                 | 15 |
|                                                                                                                                                                 |    |
|                                                                                                                                                                 | 20 |
|                                                                                                                                                                 |    |
|                                                                                                                                                                 | 25 |
|                                                                                                                                                                 |    |
|                                                                                                                                                                 | 30 |
|                                                                                                                                                                 |    |
|                                                                                                                                                                 | 35 |
|                                                                                                                                                                 |    |
|                                                                                                                                                                 | 40 |
|                                                                                                                                                                 |    |
|                                                                                                                                                                 | 45 |
|                                                                                                                                                                 |    |
|                                                                                                                                                                 | 50 |
|                                                                                                                                                                 | 50 |

| 1  |  |  |  |
|----|--|--|--|
| 5  |  |  |  |
| 10 |  |  |  |
| 15 |  |  |  |
| 20 |  |  |  |
| 25 |  |  |  |
| 30 |  |  |  |
| 35 |  |  |  |
| 40 |  |  |  |
| 45 |  |  |  |
| 50 |  |  |  |
| 55 |  |  |  |

| Annex B                                                                                                                                                                                                                                                                                                                     | 1  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| (normative)                                                                                                                                                                                                                                                                                                                 | -  |
| Grammar                                                                                                                                                                                                                                                                                                                     | 5  |
| The formal syntax of SystemRDL is described using Backus-Naur Form (BNF). The syntax of SystemRDL source is derived from the starting symbol root. If there is a conflict between a grammar element shown anywhere in this Standard and the material in this annex, the material shown in this annex shall take precedence. | 10 |

The full syntax and semantics of SystemRDL are not described solely using BNF. The normative text description contained within the clauses and annexes of this standard provide additional details on the syntax and semantics described in this BNF.

# **B.1 SystemRDL source text**

| <pre>root ::= { description }</pre> |    |
|-------------------------------------|----|
| description ::=                     |    |
| component_def                       |    |
| enum_def                            | 25 |
| property_definition                 | 25 |
| struct_def                          |    |
| constraint_def                      |    |
| explicit_component_inst             |    |
| property_assignment                 | 20 |
|                                     | 30 |

# **B.2 User-defined properties**

| <pre>property_definition ::= property id { property_body } ; property_body ::= property_attribute { property_attribute } property attribute ::=</pre> | 35 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| property_usage                                                                                                                                        |    |
| property default                                                                                                                                      |    |
| property_constraint                                                                                                                                   | 40 |
| <pre>property_type ::= type = property_data_type [ array_type ] ;</pre>                                                                               |    |
| <pre>property_data_type ::=</pre>                                                                                                                     |    |
| component_primary_type                                                                                                                                |    |
| ref                                                                                                                                                   |    |
| number                                                                                                                                                | 45 |
| basic_data_type                                                                                                                                       |    |
| <pre>property_usage ::= component = property_comp_types ;</pre>                                                                                       |    |
| <pre>property_comp_types ::= property_comp_type {    property_comp_type }</pre>                                                                       |    |
| <pre>property_comp_type ::=</pre>                                                                                                                     |    |
| component_type                                                                                                                                        | 50 |
| constraint                                                                                                                                            |    |
| all                                                                                                                                                   |    |
| <pre>property_default ::= default = constant_expression ;</pre>                                                                                       |    |
| <pre>property_constraint::= constraint = property_constraint_type ;</pre>                                                                             |    |
| <pre>property_constraint_type::= componentwidth</pre>                                                                                                 | 55 |

## 1 B.3 Component definition

|    | component_def ::=                                                            |
|----|------------------------------------------------------------------------------|
|    | <pre>component_named_def component_inst_type component_insts ;</pre>         |
| 5  | <pre>component_anon_def component_inst_type component_insts ;</pre>          |
|    | <pre>component_named_def [ component_insts ];</pre>                          |
| 10 | <pre>component_anon_def component_insts ;</pre>                              |
|    | <pre>component_inst_type component_named_def component_insts ;</pre>         |
|    | <pre>component_inst_type component_anon_def component_insts ;</pre>          |
|    | component_named_def::= component_type id [ param_def ] component_body        |
|    | component_anon_def::= component_type component_body                          |
|    | component_body ::= { { component_body_elem } }                               |
|    | <pre>component_body_elem ::=</pre>                                           |
| 15 | component_def                                                                |
|    | enum_def                                                                     |
|    | struct_def                                                                   |
|    | constraint_def                                                               |
|    | property aggignment                                                          |
| 20 | component type ::-                                                           |
|    | component primary type                                                       |
|    | signal                                                                       |
|    | component primary type ::= addrman   regfile   reg   field   mem             |
|    | explicit component inst ::= [ component inst type ] [ component inst alias ] |
| 25 | id component_insts ;                                                         |
|    | component_insts ::= [ param_inst ] component_inst { , component_inst }       |
|    | component_inst ::=                                                           |
|    | id [ component_inst_array_or_range ]                                         |
|    | [ EQ constant_expression ]                                                   |
| 30 | [ AT constant_expression ]                                                   |
|    | [ INC constant_expression ]                                                  |
|    | [ ALIGN constant_expression ]                                                |
|    | component_inst_alias ::= alias id                                            |
|    | component_inst_type ::= external   internal                                  |
| 35 | component_inst_array_or_range ::=                                            |
|    | array { array }                                                              |
|    | range                                                                        |

#### B.4 Struct definitions

#### B.5 Constraints

```
constraint_def ::=
    constraint constraint_def_exp ;
    | constraint constraint_def_anon ;
    constraint_def_exp ::= id constraint_body [ constraint_insts ]
    constraint_def_anon ::= constraint_body constraint_insts
```

40

45

50

```
1
constraint_insts ::= id { , id }
constraint_body ::= { { constraint_elem ; } }
constraint_prop_assignment ::= id = constant_expression
constraint_elem ::=
                                                                                       5
   constant_expression
  constraint_prop_assignment
  constraint_lhs inside { constraint_values }
  | constraint_lhs inside id
constraint_values ::= constraint_value { , constraint_value }
                                                                                       10
constraint_value ::=
   constant_expression
  constant_expression : constant_expression
constraint_lhs ::=
   this
                                                                                      15
  | instance ref
```

#### **B.6 Parameters**

| param_def ::= # ( param_def_elem { , param_def_elem } )                  |
|--------------------------------------------------------------------------|
| param_def_elem ::= data_type id [ array_type ] [ = constant_expression ] |
| param_inst ::= # ( param_elem { , param_elem } )                         |
| param_elem ::= . id ( param_value )                                      |
| param_value ::= constant_expression                                      |

# **B.7 Enums**

```
enum_def ::= enum id enum_body ; 30
enum_body ::= { enum_entry { enum_entry } }
enum_entry ::= id [ = constant_expression ] [ enum_property_assignment ] ;
enum_property_assignment ::= { { explicit_prop_assignment ; } }
```

# **B.8 Property assignment**

```
property_assignment ::=
   explicit_or_default_prop_assignment
                                                                                       40
  post_prop_assignment
explicit_or_default_prop_assignment ::=
    [ default ] explicit_prop_modifier ;
  [ [ default ] explicit_prop_assignment ;
explicit_prop_modifier ::= prop_mod id
explicit_encode_assignment ::= encode = id
                                                                                       45
explicit_prop_assignment ::=
   prop_assignment_lhs [ = prop_assignment_rhs ]
  explicit_encode_assignment
post_encode_assignment ::= instance_ref -> encode = id
post_prop_assignment ::=
                                                                                       50
   prop_ref [ = prop_assignment_rhs ];
  post_encode_assignment ;
prop_mod ::= posedge | negedge | bothedge | level | nonsticky
prop_assignment_lhs ::=
   prop_keyword
                                                                                       55
  | id
```

111

20

25

#### **B.9 Struct literal**

```
10 struct_literal ::= id '{ struct_literal_body }
struct_literal_body ::= [ struct_literal_elem { , struct_literal_elem } ]
struct_literal_elem ::= id : constant_expression
```

#### 15 **B.10 Array literal**

```
array_literal ::= '{ array_literal_body }
array_literal_body ::= constant_expression { , constant_expression }
```

```
20
```

25

30

35

5

#### **B.11 Reference**

```
instance_ref ::= instance_ref_element { . instance_ref_element }
prop_ref ::=
    instance_ref -> prop_keyword
    instance_ref -> id
    instance_ref -> prop_keyword
    instance_ref -> id
    instance_ref -> id
    instance_ref
instance_ref
```

#### B.12 Array and range

```
range ::= [ constant_expression : constant_expression ]
array ::= [ constant_expression ]
array_type ::= [ ]
```

#### 40

45

# **B.13 Concatenation**

```
constant_concatenation ::= { constant_expression { , constant_expression } }
constant_multiple_concatenation ::=
    { constant_expression constant_concatenation }
```

#### B.14 Data types

```
50
integer_type ::=
integer_vector_type
| integer_atom_type
integer_atom_type ::= longint
integer_vector_type ::= bit
simple_type ::= integer_type
```

| signing ::= unsigned                                                          | 1   |
|-------------------------------------------------------------------------------|-----|
| basic_data_type ::=                                                           |     |
| simple_type [ signing ]                                                       |     |
| string                                                                        |     |
| Boolean                                                                       | 5   |
| lid                                                                           | -   |
| data type ::=                                                                 |     |
| basic data type                                                               |     |
|                                                                               | 10  |
| addressingtyne                                                                | 10  |
|                                                                               |     |
|                                                                               |     |
| onwritetype                                                                   |     |
|                                                                               |     |
|                                                                               | 15  |
| B.15 Literals                                                                 |     |
|                                                                               |     |
| boolean literal ::= <b>true</b>   <b>false</b>                                |     |
| number $::=$ number as specified in 4.6                                       |     |
| string literal ::= <i>string</i> as specified in 4.5                          | 20  |
| enumerator literal ::= id :: id                                               | 20  |
| accessive literal ::= $n_1   r_w   wr   r   w   rw1   w1$                     |     |
| $accesses pc_{1}$                                                             |     |
| onreadtype_riteral ··- fen   ist   iuser                                      |     |
| onwritetype_literal ::= woset   wocir   wot   wzs   wzt   wcir   wset   wuser |     |
| addressingtype_literal ::= compact   regalign   fullalign                     | 25  |
| precedencetype_literal ::= <b>hw</b>   <b>sw</b>                              |     |
|                                                                               |     |
| B.16 Expressions                                                              | 30  |
| constant_primary                                                              |     |
| unary_operator constant_primary                                               |     |
| constant_expression binary_operator constant_expression                       |     |
| constant_expression : constant_expression : constant_expression               | 35  |
| constant_primary ::=                                                          |     |
| primary_literal                                                               |     |
| constant_concatenation                                                        |     |
| constant_multiple_concatenation                                               |     |
| ( constant_expression )                                                       | 40  |
| constant_cast                                                                 | .0  |
| instance_or_prop_rei                                                          |     |
| struct_literal                                                                |     |
| array_literal                                                                 |     |
| primary_literal ::=                                                           | 4.5 |
| number                                                                        | 45  |
| string_literal                                                                |     |
| boolean_literal                                                               |     |
| accesstype_literal                                                            |     |
| onreadtype_literal                                                            |     |
| onwritetype_literal                                                           | 50  |
| addressingtype_literal                                                        | - • |
| enumerator_literal                                                            |     |
| this                                                                          |     |
| binary_operator ::=                                                           |     |
| &&        <   >   <=   >=   ==   !=   >>   <<                                 |     |
| &       ^   ~^  ^~   *   /   %   +   -   **                                   | 55  |

| 1  | unary_operator :<br>$  +   -   \sim   \&   \sim \&       \sim     ^   \sim   ^ \sim$<br>constant cast ::= casting type ' ( constant expression ) |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 5  | casting_type ::= simple_type   constant_primary   boolean                                                                                        |
|    | B.17 Identifiers                                                                                                                                 |
| 10 | id ::= <i>identifier</i> as specified in $4.3$                                                                                                   |
| 15 |                                                                                                                                                  |
| 20 |                                                                                                                                                  |
| 25 |                                                                                                                                                  |
| 30 |                                                                                                                                                  |
| 35 |                                                                                                                                                  |
| 40 |                                                                                                                                                  |
| 45 |                                                                                                                                                  |
| 50 |                                                                                                                                                  |
| 55 |                                                                                                                                                  |

**Backward compatibility** 

Annex C

(informative)

C.1 Keywords

#### 1

5

10

15

# 20

| 2 | 5 |
|---|---|
| 4 | ) |

| Feature                 | Keywords added                                                                                     |  |
|-------------------------|----------------------------------------------------------------------------------------------------|--|
| Structs                 | abstract, struct                                                                                   |  |
| Casting                 | accesstype, addressingtype, onreadtype, onwritetype                                                |  |
| Data types              | bit, boolean, longint, ruser, rw1, string, unsigned, w1, wclr, wot, wr, wset, wuser, wzc, wzs, wzt |  |
| User-defined properties | component, componentwidth, number, ref, type                                                       |  |
| Constraints             | constraint, inside, this                                                                           |  |
| Memories                | mem                                                                                                |  |

#### Table C1—New keywords added in SystemRDL 2.0

One of the main goals for this update to the SystemRDL specification was to maintain backward

compatibility. However, in some cases, this was just not possible to achieve what needed to be done or when there were mistakes in the original SystemRDL 1.0 specification. Where the SystemRDL 2.0 grammar and the SystemRDL 1.0 specification differ, it is unclear with which to maintain compatibility. Below are known

Some of the new features require additional keywords (see <u>Table C1</u>). If these keywords are used in legacy code as instance names, there will now be a conflict. Refer to <u>Table 2</u> for the current keyword list and

Annex D for additional reserved words. Where instances in legacy code use one of these keywords or

reserved words, the name either needs to be changed or escaped (by using a  $\setminus$ , see also 4.3).

areas of incompatibility with an explanation of why and possible workarounds.

Many of the previously defined keywords are now properties (see <u>Table C2</u>) or obsolete (see <u>Table C3</u>).

#### Table C2—Keywords in SystemRDL 1.0 now changed to properties

accesswidth activehigh activelow addressing alignment anded bigendian bridge async counter cpuif\_reset decr desc decrsaturate decrthreshold decrvalue decrwidth dontcompare donttest errextbus fieldwidth enable encode field\_reset halt haltenable haltmask hwclr hwenable hwmask incrsaturate incr incrthreshold incrwidth hwset incrvalue

115

45

55

#### 5

# 10

#### 15

25

30

35

40

45

## Table C2—Keywords in SystemRDL 1.0 now changed to properties

| intr        | littleendian | lsb0     | mask       | msb0      | name         |
|-------------|--------------|----------|------------|-----------|--------------|
| next        | ored         | overflow | precedence | regwidth  | reset        |
| resetsignal | rsvdset      | rsvdsetX | saturate   | shared    | sharedextbus |
| signalwidth | singlepulse  | sticky   | stickybit  | swacc     | swmod        |
| swwe        | swwel        | sync     | threshold  | underflow | we           |
| wel         | xored        |          |            |           |              |

# Table C3—Keywords in SystemRDL 1.0 now obsolete

| arbiter | clock |  |  |
|---------|-------|--|--|
|         |       |  |  |

# <sup>20</sup> **C.2 next**

The SystemRDL 1.0 specification showed examples with invalid syntax for the **next** property, where a field without -> implied ->next, but did not specify it. This was also allowed by the grammar, but is no longer supportable. In section <u>7.8.2</u> of the SystemRDL 1.0 specification, within Example 3:

```
field counter_f { counter; };
field {} has_overflowed;
counter_f count1[5]=0; // Defines a 5 bit counter from 6 to 1
count1->incrthreshold=5'hF;
has_overflowed = count1->overflow;
```

the last line should instead be:

has\_overflowed->next = countl->overflow;

SystemRDL 2.0 does not support implied ->next.

# C.3 Use of 0 size

The SystemRDL 1.0 specification was silent on the meaning of a 0 size field or register array. This is no longer a valid syntax. A single positive integer size (or for fields a legal range) shall be specified.

# C.4 Range for register arrays

The SystemRDL 1.0 specification was silent on allowing a **range** for a register array. This is no longer a valid syntax. A single positive integer size shall be specified.

#### 50

55

# C.5 decrsaturate

The SystemRDL 1.0 specification specified the default value for **decrsaturate** as 1. This is incorrect. The SystemRDL 2.0 specification correctly lists the default as 0.

| C.6 enum                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| The SystemRDL 1.0 grammar allowed for enumeration types to have no <b>enum</b> erators. For SystemRDL 2.0, enumeration types are required to specify at least one <b>enum</b> erator.                                                                                                                                                                                                                                                                                                                      | 5  |
| C.7 alias                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |    |
| The SystemRDL 1.0 specification was unclear regarding the <b>alias</b> register type. SystemRDL 2.0 clarifies that an <b>alias</b> shall be of the same type ( <b>internal</b> or <b>external</b> ) as the primary register. Since this is done by default, alias registers do not need to specify a register type.                                                                                                                                                                                        | 10 |
| C.8 hwenable and hwmask                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 15 |
| These two properties are mentioned in SystemRDL 1.0 as <i>sizedNumeric</i> or <i>boolean</i> . In reality, these are references, to allow another element to specify the enable or mask value. This has been corrected in SystemRDL 2.0                                                                                                                                                                                                                                                                    |    |
| System KDL 2.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 20 |
| C.9 threshold, incrthreshold, and decrtheshold                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |
| The <i>threshold</i> properties are not clearly defined in SystemRDL 1.0. In one place, a threshold occurs when the field value exceeds the threshold value. In another place, it says the field "exactly matches" the value. In SystemRDL 2.0, this has been clarified: Threshold is set for <b>threshold</b> and <b>incrthreshold</b> when the field value is greater than or equal to the property value and for <b>decrthreshold</b> when the field value is less than or equal to the property value. | 25 |

35

40

45

50

| 1  |  |  |  |
|----|--|--|--|
| 5  |  |  |  |
| 10 |  |  |  |
| 15 |  |  |  |
| 20 |  |  |  |
| 25 |  |  |  |
| 30 |  |  |  |
| 35 |  |  |  |
| 40 |  |  |  |
| 45 |  |  |  |
| 50 |  |  |  |
| 55 |  |  |  |

# Annex D (normative)

# **Reserved words**

*Reserved words* have a similar effect as keywords; reserved words are explicitly reserved for future use. The reserved words are listed in <u>Table D1</u>.

#### Table D1—SystemRDL reserved words

| alternate | byte      | int    | precedencetype | real   |
|-----------|-----------|--------|----------------|--------|
| shortint  | shortreal | signed | with           | within |

See also <u>4.4</u>.

20

1

5

10

25

30

35

40

45

50

| 1  |  |  |  |
|----|--|--|--|
| 5  |  |  |  |
| 10 |  |  |  |
| 15 |  |  |  |
| 20 |  |  |  |
| 25 |  |  |  |
| 30 |  |  |  |
| 35 |  |  |  |
| 40 |  |  |  |
| 45 |  |  |  |
| 50 |  |  |  |
| 55 |  |  |  |

# Annex E

(normative)

# Access modes

IEEE 1685-2014 IP-XACT inherited the access modes from SystemRDL, but, several more were added in addition to those from SystemRDL. UVM also inherited a subset of the IP-XACT access modes. Supporting all the IP-XACT access modes supports all of the UVM access modes; however, many of the SystemRDL and IP-XACT access mode combinations still map to the UVM User-defined access mode.

Table E1 shows the access combinations between SystemRDL and the UVM and IP-XACT Standards.

| Access         | Read<br>effect | Write<br>function | IP-XACT<br>IEEE 1685-2014                                 | UVM<br>(1.2) | System<br>RDL 1.0 | SystemRDL<br>2.0          |
|----------------|----------------|-------------------|-----------------------------------------------------------|--------------|-------------------|---------------------------|
| No<br>Access   |                |                   | -                                                         | -            | sw=na             | sw=na                     |
| Read-only      |                |                   | access=read-only                                          | RO           | sw=r              | sw=r<br>onread=r          |
| Read-only      | clear          |                   | access=read-only<br>readAction=clear                      | RC           | sw=r<br>rclr      | sw=r<br>onread =rclr      |
| Read-only      | set            |                   | access=read-only<br>readAction=set                        | RS           | sw=r<br>rset      | sw=r<br>onread =rset      |
| Read-only      | other          |                   | access=read-only<br>readAction=modify                     | -            | -                 | sw=r<br>onread =ruser     |
| Write-<br>only |                |                   | access=write-only                                         | WO           | sw=w              | sw=w<br>onwrite =w        |
| Write-<br>only |                | One-clear         | access=write-only<br>modifiedWriteValue=oneToClear        | -            | sw=w<br>woclr     | sw=w<br>onwrite =woclr    |
| Write-<br>only |                | One-set           | access=write-only<br>modifiedWriteValue=oneToSet          | -            | sw=w<br>woset     | sw=w<br>onwrite<br>=woset |
| Write-<br>only |                | One-toggle        | access=write-only<br>modifiedWriteValue=oneToTog-<br>gle  | -            | -                 | sw=w<br>onwrite =wot      |
| Write-<br>only |                | Zero-clear        | access=write-only<br>modifiedWriteValue=zeroToClear       | -            | -                 | sw=w<br>onwrite =wzc      |
| Write-<br>only |                | Zero-set          | access=write-only<br>modifiedWriteValue=zeroToSet         | -            | -                 | sw=w<br>onwrite =wzs      |
| Write-<br>only |                | Zero-tog-<br>gle  | access=write-only<br>modifiedWriteValue=zeroToTog-<br>gle | -            | -                 | sw=w<br>onwrite =wzt      |
| Write-<br>only |                | Clear             | access=write-only<br>modifiedWriteValue=clear             | WOC          | -                 | sw=w<br>onwrite =wclr     |

#### Table E1—Access combinations

1

5

10

15

| 5  | Access              | Read<br>effect | Write<br>function | IP-XACT<br>IEEE 1685-2014                                 | UVM<br>(1.2) | System<br>RDL 1.0 | SystemRDL<br>2.0                        |
|----|---------------------|----------------|-------------------|-----------------------------------------------------------|--------------|-------------------|-----------------------------------------|
| 5  | Write-<br>only      |                | Set               | access=write-only<br>modifiedWriteValue=set               | WOS          | -                 | sw=w<br>onwrite =wset                   |
| 10 | Write-<br>only      |                | Other             | access=write-only<br>modifiedWriteValue=modify            | -            | -                 | sw=w<br>onwrite<br>=wuser               |
|    | Write-<br>only-once |                |                   | access=writeOnce                                          | WO1          | -                 | sw=w1<br>onwrite =w                     |
| 15 | Write-<br>only-once |                | One-clear         | access=writeOnce<br>modifiedWriteValue=oneToClear         | -            | -                 | sw=w1<br>onwrite =woclr                 |
|    | Write-<br>only-once |                | One-set           | access= writeOnce<br>modifiedWriteValue=oneToSet          | -            | -                 | sw=w1<br>onwrite<br>=woset              |
| 20 | Write-<br>only-once |                | One-toggle        | access= writeOnce<br>modifiedWriteValue=oneToTog-<br>gle  | -            | -                 | sw=w1<br>onwrite =wot                   |
| 25 | Write-<br>only-once |                | Zero-clear        | access= writeOnce<br>modifiedWriteValue=zeroToClear       | -            | -                 | sw=w1<br>onwrite =wzc                   |
| 25 | Write-<br>only-once |                | Zero-set          | access= writeOnce<br>modifiedWriteValue=zeroToSet         | -            | -                 | sw=w1<br>onwrite =wzs                   |
| 30 | Write-<br>only-one  |                | Zero-tog-<br>gle  | access= writeOnce<br>modifiedWriteValue=zeroToTog-<br>gle | -            | -                 | sw=w1<br>onwrite =wzt                   |
|    | Write-<br>only-once |                | Clear             | access= writeOnce<br>modifiedWriteValue=clear             | -            | -                 | sw=w1<br>onwrite =wclr                  |
| 35 | Write-<br>only-once |                | Set               | access= writeOnce<br>modifiedWriteValue=set               | -            | -                 | sw=w1<br>onwrite =wset                  |
|    | Write-<br>only-once |                | Other             | access= writeOnce<br>modifiedWriteValue=modify            | -            | -                 | sw=w1<br>onwrite<br>=wuser              |
| 40 | Read-<br>write      |                |                   | access=read-write                                         | RW           | sw=rw             | sw=rw<br>onread =r<br>onwrite =w        |
|    | Read-<br>write      |                | One-clear         | access= read-write<br>modifiedWriteValue=oneToClear       | W1C          | sw=rw<br>woclr    | sw=rw<br>onread =r<br>onwrite =woclr    |
| 45 | Read-<br>write      |                | One-set           | access= read-write<br>modifiedWriteValue=oneToSet         | W1S          | sw=rw<br>woset    | sw=rw<br>onread =r<br>onwrite<br>=woset |
| 50 | Read-<br>write      |                | One-toggle        | access= read-write<br>modifiedWriteValue=oneToTog-<br>gle | W1T          | -                 | sw=rw<br>onread =r<br>onwrite =wot      |
| 55 | Read-<br>write      |                | Zero-clear        | access= read-write<br>modifiedWriteValue=zeroToClear      | W0C          | -                 | sw=rw<br>onread =r<br>onwrite =wzc      |

# Table E1—Access combinations (Continued)

| Access         | Read<br>effect | Write<br>function | IP-XACT<br>IEEE 1685-2014                                                      | UVM<br>(1.2) | System<br>RDL 1.0      | SystemRDL<br>2.0                           |
|----------------|----------------|-------------------|--------------------------------------------------------------------------------|--------------|------------------------|--------------------------------------------|
| Read-<br>write |                | Zero-set          | access= read-write<br>modifiedWriteValue=zeroToSet                             | W0S          | -                      | sw=rw<br>onread =r<br>onwrite =wzs         |
| Read-<br>write |                | Zero-tog-<br>gle  | access= read-write<br>modifiedWriteValue=zeroToTog-<br>gle                     | W0T          | -                      | sw=rw<br>onread =r<br>onwrite =wzt         |
| Read-<br>write |                | Clear             | access= read-write<br>modifiedWriteValue=clear                                 | WC           | -                      | sw=rw<br>onread =r<br>onwrite =wclr        |
| Read-<br>write |                | Set               | access= read-write<br>modifiedWriteValue=set                                   | WS           | -                      | sw=rw<br>onread =r<br>onwrite =wset        |
| Read-<br>write |                | Other             | access= read-write<br>modifiedWriteValue=modify                                | -            | -                      | sw=rw<br>onread =r<br>onwrite<br>=wuser    |
| Read-<br>write | clear          |                   | access=read-write<br>readAction=clear                                          | WRC          | sw=rw<br>rclr          | sw=rw<br>onread =rclr<br>onwrite =w        |
| Read-<br>write | clear          | One-clear         | access= read-write<br>readAction=clear<br>modifiedWriteValue=oneToClear        | -            | sw=rw<br>rclr<br>woclr | sw=rw<br>onread =rclr<br>onwrite =woclr    |
| Read-<br>write | clear          | One-set           | access= read-write<br>readAction=clear<br>modifiedWriteValue=oneToSet          | W1SR<br>C    | sw=rw<br>rclr<br>woset | sw=rw<br>onread =rclr<br>onwrite<br>=woset |
| Read-<br>write | clear          | One-toggle        | access= read-write<br>readAction=clear<br>modifiedWriteValue=oneToTog-<br>gle  | -            | -                      | sw=rw<br>onread =rclr<br>onwrite =wot      |
| Read-<br>write | clear          | Zero-clear        | access= read-write<br>readAction=clear<br>modifiedWriteValue=zeroToClear       | -            | -                      | sw=rw<br>onread =rclr<br>onwrite =wzc      |
| Read-<br>write | clear          | Zero-set          | access= read-write<br>readAction=clear<br>modifiedWriteValue=zeroToSet         | W0SR<br>C    | -                      | sw=rw<br>onread =rclr<br>onwrite =wzs      |
| Read-<br>write | clear          | Zero-tog-<br>gle  | access= read-write<br>readAction=clear<br>modifiedWriteValue=zeroToTog-<br>gle | -            | -                      | sw=rw<br>onread =rclr<br>onwrite =wzt      |
| Read-<br>write | clear          | Clear             | access= read-write<br>readAction=clear<br>modifiedWriteValue=clear             | -            | -                      | sw=rw<br>onread =rclr<br>onwrite =wclr     |
| Read-<br>write | clear          | Set               | access= read-write<br>readAction=clear<br>modifiedWriteValue=set               | WSR<br>C     | -                      | sw=rw<br>onread =rclr<br>onwrite =wset     |

# Table E1—Access combinations (Continued)

| 5  | Access         | Read<br>effect | Write<br>function | IP-XACT<br>IEEE 1685-2014                                                     | UVM<br>(1.2) | System<br>RDL 1.0      | SystemRDL<br>2.0                             |
|----|----------------|----------------|-------------------|-------------------------------------------------------------------------------|--------------|------------------------|----------------------------------------------|
| 10 | Read-<br>write | clear          | Other             | access= read-write<br>readAction=clear<br>modifiedWriteValue=modify           | -            | -                      | sw=rw<br>onread =rclr<br>onwrite<br>=wuser   |
| 10 | Read-<br>write | set            |                   | access=read-write<br>readAction=set                                           | WRS          | sw=rw<br>rset          | sw=rw<br>onread = rset<br>onwrite =w         |
| 15 | Read-<br>write | set            | One-clear         | access= read-write<br>readAction=set<br>modifiedWriteValue=oneToClear         | W1C<br>RS    | sw=rw<br>rset<br>woclr | sw=rw<br>onread = rset<br>onwrite =woclr     |
| 20 | Read-<br>write | set            | One-set           | access= read-write<br>readAction=set<br>modifiedWriteValue=oneToSet           | -            | sw=rw<br>rset<br>woset | sw=rw<br>onread = rset<br>onwrite<br>=woset  |
|    | Read-<br>write | set            | One-toggle        | access= read-write<br>readAction= set<br>modifiedWriteValue=oneToTog-<br>gle  | -            | -                      | sw=rw<br>onread = rset<br>onwrite =wot       |
| 25 | Read-<br>write | set            | Zero-clear        | access= read-write<br>readAction= set<br>modifiedWriteValue=zeroToClear       | W0C<br>RS    | -                      | sw=rw<br>onread = rset<br>onwrite =wzc       |
| 30 | Read-<br>write | set            | Zero-set          | access= read-write<br>readAction= set<br>modifiedWriteValue=zeroToSet         | -            | -                      | sw=rw<br>onread = rset<br>onwrite =wzs       |
| 25 | Read-<br>write | set            | Zero-tog-<br>gle  | access= read-write<br>readAction= set<br>modifiedWriteValue=zeroToTog-<br>gle | -            | -                      | sw=rw<br>onread = rset<br>onwrite =wzt       |
| 35 | Read-<br>write | set            | Clear             | access= read-write<br>readAction= set<br>modifiedWriteValue=clear             | WCR<br>S     | -                      | sw=rw<br>onread = rset<br>onwrite =wclr      |
| 40 | Read-<br>write | set            | Set               | access= read-write<br>readAction= set<br>modifiedWriteValue=set               | -            | -                      | sw=rw<br>onread = rset<br>onwrite =wset      |
| 15 | Read-<br>write | set            | Other             | access= read-write<br>readAction= set<br>modifiedWriteValue=modify            | -            | -                      | sw=rw<br>onread =rset<br>onwrite<br>=wuser   |
| +5 | Read-<br>write | other          |                   | access=read-write<br>readAction= modify                                       | -            | -                      | sw=rw<br>onread = ruser<br>onwrite =w        |
| 50 | Read-<br>write | other          | One-clear         | access= read-write<br>readAction=modify<br>modifiedWriteValue=oneToClear      | -            | -                      | sw=rw<br>onread = ruser<br>onwrite =woclr    |
| 55 | Read-<br>write | other          | One-set           | access= read-write<br>readAction=modify<br>modifiedWriteValue=oneToSet        | -            | -                      | sw=rw<br>onread = ruser<br>onwrite<br>=woset |
|    |                |                |                   |                                                                               |              |                        |                                              |

# Table E1—Access combinations (Continued)

| Access                  | Read<br>effect | Write<br>function | IP-XACT<br>IEEE 1685-2014                                                        | UVM<br>(1.2) | System<br>RDL 1.0 | SystemRDL<br>2.0                             | 5  |
|-------------------------|----------------|-------------------|----------------------------------------------------------------------------------|--------------|-------------------|----------------------------------------------|----|
| Read-<br>write          | other          | One-toggle        | access= read-write<br>readAction= modify<br>modifiedWriteValue=oneToTog-<br>gle  | -            | -                 | sw=rw<br>onread = ruser<br>onwrite =wot      | 10 |
| Read-<br>write          | other          | Zero-clear        | access= read-write<br>readAction= modify<br>modifiedWriteValue=zeroToClear       | -            | -                 | sw=rw<br>onread = ruser<br>onwrite =wzc      |    |
| Read-<br>write          | other          | Zero-set          | access= read-write<br>readAction= modify<br>modifiedWriteValue=zeroToSet         | -            | -                 | sw=rw<br>onread = ruser<br>onwrite =wzs      | 15 |
| Read-<br>write          | other          | Zero-tog-<br>gle  | access= read-write<br>readAction= modify<br>modifiedWriteValue=zeroToTog-<br>gle | -            | -                 | sw=rw<br>onread = ruser<br>onwrite =wzt      | 20 |
| Read-<br>write          | other          | Clear             | access= read-write<br>readAction= modify<br>modifiedWriteValue=clear             | -            | -                 | sw=rw<br>onread = ruser<br>onwrite =wclr     |    |
| Read-<br>write          | other          | Set               | access= read-write<br>readAction= modify<br>modifiedWriteValue=set               | -            | -                 | sw=rw<br>onread = ruser<br>onwrite =wset     | 25 |
| Read-<br>write          | other          | Other             | access= read-write<br>readAction= modify<br>modifiedWriteValue=modify            | -            | -                 | sw=rw<br>onread = ruser<br>onwrite<br>=wuser | 30 |
| Read-<br>write-<br>once |                |                   | access=read-writeOnce                                                            | W1           | -                 | sw=rw1<br>onread =r<br>onwrite =w            |    |
| Read-<br>write-<br>once |                | One-clear         | access= read-writeOnce<br>modifiedWriteValue=oneToClear                          | -            | -                 | sw=rw1<br>onread =r<br>onwrite =woclr        | 35 |
| Read-<br>write-<br>once |                | One-set           | access= read-writeOnce<br>modifiedWriteValue=oneToSet                            | -            | -                 | sw=rw1<br>onread =r<br>onwrite<br>=woset     | 40 |
| Read-<br>write-<br>once |                | One-toggle        | access= read-writeOnce<br>modifiedWriteValue=oneToTog-<br>gle                    | -            | -                 | sw=rw1<br>onread =r<br>onwrite =wot          |    |
| Read-<br>write-<br>once |                | Zero-clear        | access= read-writeOnce<br>modifiedWriteValue=zeroToClear                         | -            | -                 | sw=rw1<br>onread =r<br>onwrite =wzc          | 45 |
| Read-<br>write-<br>once |                | Zero-set          | access= read-writeOnce<br>modifiedWriteValue=zeroToSet                           | -            | -                 | sw=rw1<br>onread =r<br>onwrite =wzs          | 50 |
| Read-<br>write-<br>once |                | Zero-tog-<br>gle  | access= read-writeOnce<br>modifiedWriteValue=zeroToTog-<br>gle                   | -            | -                 | sw=rw1<br>onread =r<br>onwrite =wzt          |    |

# Table E1—Access combinations (Continued)

| 1  |                         | Table E1—Access combinations (Continued) |                   |                                                                                    |              |                   |                                             |  |  |
|----|-------------------------|------------------------------------------|-------------------|------------------------------------------------------------------------------------|--------------|-------------------|---------------------------------------------|--|--|
| 5  | Access                  | Read<br>effect                           | Write<br>function | IP-XACT<br>IEEE 1685-2014                                                          | UVM<br>(1.2) | System<br>RDL 1.0 | SystemRDL<br>2.0                            |  |  |
| 5  | Read-<br>write-<br>once |                                          | Clear             | access= read-writeOnce<br>modifiedWriteValue=clear                                 | -            | -                 | sw=rw1<br>onread =r<br>onwrite =wclr        |  |  |
| 10 | Read-<br>write-<br>once |                                          | Set               | access= read-writeOnce<br>modifiedWriteValue=set                                   | -            | -                 | sw=rw1<br>onread =r<br>onwrite =wset        |  |  |
| 15 | Read-<br>write-<br>once |                                          | Other             | access= read-writeOnce<br>modifiedWriteValue=modify                                | -            | -                 | sw=rw1<br>onread =r<br>onwrite<br>=wuser    |  |  |
|    | Read-<br>write-<br>once | clear                                    |                   | access=read-writeOnce<br>readAction=clear                                          | -            | -                 | sw=rw1<br>readeffect=rclr<br>onwrite =w     |  |  |
| 20 | Read-<br>write-<br>once | clear                                    | One-clear         | access= read-writeOnce<br>readAction=clear<br>modifiedWriteValue=oneToClear        | -            | -                 | sw=rw1<br>onread =rclr<br>onwrite =woclr    |  |  |
| 25 | Read-<br>write-<br>once | clear                                    | One-set           | access= read-writeOnce<br>readAction=clear<br>modifiedWriteValue=oneToSet          | -            | -                 | sw=rw1<br>onread =rclr<br>onwrite<br>=woset |  |  |
| 30 | Read-<br>write-<br>once | clear                                    | One-toggle        | access= read-writeOnce<br>readAction=clear<br>modifiedWriteValue=oneToTog-<br>gle  | -            | -                 | sw=rw1<br>onread =rclr<br>onwrite =wot      |  |  |
|    | Read-<br>write-<br>once | clear                                    | Zero-clear        | access= read-writeOnce<br>readAction=clear<br>modifiedWriteValue=zeroToClear       | -            | -                 | sw=rw1<br>onread =rclr<br>onwrite =wzc      |  |  |
| 35 | Read-<br>write-<br>once | clear                                    | Zero-set          | access= read-writeOnce<br>readAction=clear<br>modifiedWriteValue=zeroToSet         | -            | -                 | sw=rw1<br>onread =rclr<br>onwrite =wzs      |  |  |
| 40 | Read-<br>write-<br>once | clear                                    | Zero-tog-<br>gle  | access= read-writeOnce<br>readAction=clear<br>modifiedWriteValue=zeroToTog-<br>gle | -            | -                 | sw=rw1<br>onread =rclr<br>onwrite =wzt      |  |  |
|    | Read-<br>write-<br>once | clear                                    | Clear             | access= read-writeOnce<br>readAction=clear<br>modifiedWriteValue=clear             | -            | -                 | sw=rw<br>onread =rclr<br>onwrite =wclr      |  |  |
| 45 | Read-<br>write-<br>once | clear                                    | Set               | access= read-writeOnce<br>readAction=clear<br>modifiedWriteValue=set               | -            | -                 | sw=rw1<br>onread =rclr<br>onwrite =wset     |  |  |
| 50 | Read-<br>write-<br>once | clear                                    | Other             | access= read-writeOnce<br>readAction=clear<br>modifiedWriteValue=modify            | -            | -                 | sw=rw1<br>onread =rclr<br>onwrite<br>=wuser |  |  |
|    | Read-<br>write-<br>once | set                                      |                   | access=read-writeOnce<br>readAction=set                                            | -            | -                 | sw=rw1<br>onread = rset<br>onwrite =w       |  |  |
| 55 |                         |                                          |                   |                                                                                    |              |                   |                                             |  |  |

# Table F1—Access combinations (Continued)

| Access                  | Read<br>effect | Write<br>function | IP-XACT<br>IEEE 1685-2014                                                           | UVM<br>(1.2) | System<br>RDL 1.0 | SystemRDL<br>2.0                                  |    |
|-------------------------|----------------|-------------------|-------------------------------------------------------------------------------------|--------------|-------------------|---------------------------------------------------|----|
| Read-<br>write-<br>once | set            | One-clear         | access= read-writeOnce<br>readAction=set<br>modifiedWriteValue=oneToClear           | -            | -                 | sw=rw1<br>onread = rset<br>onwrite =woclr         |    |
| Read-<br>write-<br>once | set            | One-set           | access= read-writeOnce<br>readAction=set<br>modifiedWriteValue=oneToSet             | -            | -                 | sw=rw1<br>onread = rset<br>onwrite<br>=woset      | 10 |
| Read-<br>write-<br>once | set            | One-toggle        | access= read-writeOnce<br>readAction= set<br>modifiedWriteValue=oneToTog-<br>gle    | -            | -                 | sw=rw1<br>readeffect=<br>rset<br>onwrite =wot     | 1: |
| Read-<br>write-<br>once | set            | Zero-clear        | access= read-writeOnce<br>readAction= set<br>modifiedWriteValue=zeroToClear         | -            | -                 | sw=rw1<br>onread = rset<br>onwrite =wzc           | 20 |
| Read-<br>write-<br>once | set            | Zero-set          | access= read-writeOnce<br>readAction= set<br>modifiedWriteValue=zeroToSet           | -            | -                 | sw=rw1<br>onread = rset<br>onwrite =wzs           |    |
| Read-<br>write-<br>once | set            | Zero-tog-<br>gle  | access= read-writeOnce<br>readAction= set<br>modifiedWriteValue=zeroToTog-<br>gle   | -            | -                 | sw=rw1<br>onread = rset<br>writefunc-<br>tion=wzt | 2: |
| Read-<br>write-<br>once | set            | Clear             | access= read-writeOnce<br>readAction= set<br>modifiedWriteValue=clear               | -            | -                 | sw=rw1<br>onread = rset<br>onwrite =wclr          | 30 |
| Read-<br>write-<br>once | set            | Set               | access= read-writeOnce<br>readAction= set<br>modifiedWriteValue=set                 | -            | -                 | sw=rw1<br>onread = rset<br>onwrite =wset          |    |
| Read-<br>write-<br>once | set            | Other             | access= read-writeOnce<br>readAction= set<br>modifiedWriteValue=modify              | -            | -                 | sw=rw1<br>onread =rset<br>onwrite<br>=wuser       | 3: |
| Read-<br>write-<br>once | other          |                   | access=read-writeOnce<br>readAction= modify                                         | -            | -                 | sw=rw1<br>onread = ruser<br>onwrite =w            | 40 |
| Read-<br>write-<br>once | other          | One-clear         | access= read-writeOnce<br>readAction=modify<br>modifiedWriteValue=oneToClear        | -            | -                 | sw=rw1<br>onread = ruser<br>onwrite =woclr        |    |
| Read-<br>write-<br>once | other          | One-set           | access= read-writeOnce<br>readAction=clear<br>modifiedWriteValue=oneToSet           | -            | -                 | sw=rw1<br>onread = ruser<br>onwrite<br>=woset     | 4: |
| Read-<br>write-<br>once | other          | One-toggle        | access= read-writeOnce<br>readAction= modify<br>modifiedWriteValue=oneToTog-<br>gle | -            | -                 | sw=rw1<br>onread = ruser<br>onwrite =wot          | 50 |
| Read-<br>write-<br>once | other          | Zero-clear        | access= read-writeOnce<br>readAction= modify<br>modifiedWriteValue=zeroToClear      | -            | -                 | sw=rw1<br>onread = ruser<br>onwrite =wzc          | 5: |

| i  |                         |                |                   |                                                                                      |              | 1                 |                                               |
|----|-------------------------|----------------|-------------------|--------------------------------------------------------------------------------------|--------------|-------------------|-----------------------------------------------|
| 5  | Access                  | Read<br>effect | Write<br>function | IP-XACT<br>IEEE 1685-2014                                                            | UVM<br>(1.2) | System<br>RDL 1.0 | SystemRDL<br>2.0                              |
| -  | Read-<br>write-<br>once | other          | Zero-set          | access= read-writeOnce<br>readAction= modify<br>modifiedWriteValue=zeroToSet         | -            | -                 | sw=rw1<br>onread = ruser<br>onwrite =wzs      |
| 10 | Read-<br>write-<br>once | other          | Zero-tog-<br>gle  | access= read-writeOnce<br>readAction= modify<br>modifiedWriteValue=zeroToTog-<br>gle | -            | -                 | sw=rw1<br>onread = ruser<br>onwrite =wzt      |
| 15 | Read-<br>write-<br>once | other          | Clear             | access= read-writeOnce<br>readAction= modify<br>modifiedWriteValue=clear             | -            | -                 | sw=rw1<br>onread = ruser<br>onwrite =wclr     |
|    | Read-<br>write-<br>once | other          | Set               | access= read-writeOnce<br>readAction= modify<br>modifiedWriteValue=set               | -            | -                 | sw=rw1<br>onread = ruser<br>onwrite =wset     |
| 20 | Read-<br>write-<br>once | other          | Other             | access= read-writeOnce<br>readAction= modify<br>modifiedWriteValue=modify            | -            | -                 | sw=rw1<br>onread = ruser<br>onwrite=<br>wuser |

# Table E1—Access combinations (Continued)

Annex F

(informative)

#### 1

5

10

15

20

25

Formatting text strings

SystemRDL has a set of tags which can be used to format text strings. These tags are based on the phpBB code formatting tags, which are extended for use with SystemRDL and referred to as *RDLFormatCode*. The RDLFormatCode tags shall be interpreted by the SystemRDL compiler and rendered in the generated output. The set of tags specified below is the complete set and is not extensible like phpBB code. These tags are only interpreted within the **name** and **desc** properties in SystemRDL (see <u>Table 5</u>). If a SystemRDL compiler encounters an unknown tag, this tag shall be ignored by the compiler and passed through as is.

The concept of phpBB code takes its origin from the HTML 4.01 standard; for additional information on using phpBB tags, see <u>https://www.phpbb.com/community/faq.php?mode=bbcode</u> (which suggests a formatted section illustrating the results of such usage).

# F.1 Well-formed RDLFormatCode constructs

A well-formed tag also has an end-tag. For nesting well-formed tags, the innermost shall be closed before the outmost one is.

| [b]Text[/b]                                                                                                                           | Bold                                                                                                                                                   |    |
|---------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| [i]Text[/i]                                                                                                                           | Italic                                                                                                                                                 |    |
| [u]Text[/u]                                                                                                                           | Underline                                                                                                                                              | 30 |
| [color= <i>color</i> Value]Text[/color                                                                                                | ] Color See F.3 for colorValues                                                                                                                        |    |
| [size= <i>size</i> ]Text[/size]                                                                                                       | Font size where size is a valid HTML size                                                                                                              | 25 |
| [url]Text[/url]                                                                                                                       | URL reference                                                                                                                                          | 55 |
| URL references can specified                                                                                                          | in two forms.                                                                                                                                          |    |
| <ol> <li>[url]http://www.accellera.<br/>generated code.</li> <li>[url=http://www.accellera.<br/>Accellera but links the UR</li> </ol> | org[/url] which places the target link the<br>org]Accellera[/url] Which displays the text<br>RL provided.                                              | 40 |
| [email]Text[/email]                                                                                                                   | Email address in the form of user@domain                                                                                                               | 45 |
| [img]image reference[/img]<br>can be relative pathname of<br>valid path rules for the t                                               | Insert image reference here. Image reference<br>r absolute path name. Its up to the user to follow<br>target system that they are generating code for. | 15 |
| <pre>[code]Text[/code] [list], [list=1]</pre>                                                                                         | Anything that requires a fixed width<br>with a Courier-type font                                                                                       | 50 |
| or [list=a]<br>[*] list element<br>[*] list element<br>[*] list element                                                               | <pre> Listing directives, un-ordered or<br/>ordered (numbered: list=1,</pre>                                                                           | 55 |

#### Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change.

| 1  | [/list]            |                                                                                                                                                                                                                                                                        |
|----|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5  | [quote]text[/quo   | ote] Replaces with ". useful for putting<br>"'s inside a name or desc field.                                                                                                                                                                                           |
|    | F.2 Single-tag RD  | LFormatCode constructs                                                                                                                                                                                                                                                 |
| 10 | [br]               | Line break                                                                                                                                                                                                                                                             |
|    | [1b]               | Left bracket ([)                                                                                                                                                                                                                                                       |
| 15 | [rb]               | Right bracket (])                                                                                                                                                                                                                                                      |
|    | [q]                | Paragraph begin                                                                                                                                                                                                                                                        |
| 20 | [sp]               | White Space (equivalent to an HTML  )                                                                                                                                                                                                                                  |
| 25 | [index]            | Replaced by the index # of the individual component<br>instance when instantiated as an array. When representing<br>an individual array element this substitutes the index and<br>for an entire array it substitutes the range.                                        |
| 30 | [index_parent]     | Replaced by the index # of the individual component<br>parent instance when the parent is instantiated as an<br>array (extends phpBB).When representing an individual<br>array element this substitutes the index and for an entire<br>array it substitutes the range. |
| 35 |                    |                                                                                                                                                                                                                                                                        |
|    | [name]             | Replaced by the descriptive name of the component<br>(extends phpBB). This tag is undefined when used inside<br>the value of the name property.                                                                                                                        |
| 40 | [desc]             | Replaced by the component's description (extends phpBB).                                                                                                                                                                                                               |
|    | [instname]         | Replaced by the instance name (extends phpBB).                                                                                                                                                                                                                         |
| 45 | F.3 colorValues fo | or the color tag                                                                                                                                                                                                                                                       |

The RDLFormatCode color can accept two forms of arguments for color: enumerated values specified by the HTML 4.01 or CSS specifications and RGB #'s.

Who is afraid of [color=red]red[/color], [color=#eeaa00]yellow[/color]

and [color=#30f]blue[/color]?

Example

55

|  | 1 |  |
|--|---|--|
|  | 1 |  |
|  |   |  |

40

45

50

55

|               | HTML 4.01 & CSS2 Colors |                       |                 |        |  |  |  |
|---------------|-------------------------|-----------------------|-----------------|--------|--|--|--|
| Color<br>Name | Hex 6                   | RGB                   | RGB%            | Sample |  |  |  |
|               |                         |                       | 0%,0%,0         |        |  |  |  |
| black         | #000000                 | 0,0,0                 | %               |        |  |  |  |
|               |                         |                       | 75%,75%,        |        |  |  |  |
| silver        | #C0C0C0                 | ########              | 75%             |        |  |  |  |
|               |                         |                       | 50%,50%,        |        |  |  |  |
| gray          | #808080                 | ########              | 50%             |        |  |  |  |
|               | "                       |                       | 100%,100        |        |  |  |  |
| white         | #FFFFF                  | <del>#######</del> ## | %,100%          |        |  |  |  |
|               |                         | 100.0.0               | 50%,0%,0        |        |  |  |  |
| maroon        | #800000                 | 128,0,0               | %<br>100% 0%    |        |  |  |  |
| rad           | #550000                 | 255 0 0               | 100%,0%,        |        |  |  |  |
| Teu           | #FF0000                 | 200,0,0               | 0 %<br>50% 0% 5 |        |  |  |  |
| nurnle        | #80,008,0               | 128 0 128             | 0%              |        |  |  |  |
| puipie        | #800080                 | 120,0,120             | 100% 0%         |        |  |  |  |
| fuchsia       | #FEODEE                 | 255 0 255             | 100 %,0 %,      |        |  |  |  |
| luonolu       |                         | 200,0,200             | 0% 50% 0        |        |  |  |  |
| areen         | #008000                 | 0.128.0               | %               |        |  |  |  |
| 9.0011        |                         | 0,120,0               | 0% 100%         |        |  |  |  |
| lime          | #00FF00                 | 0.255.0               | 0%              |        |  |  |  |
|               |                         | -,,_                  | 50%,50%,        |        |  |  |  |
| olive         | #808000                 | 128,128,0             | 0%              |        |  |  |  |
|               |                         |                       | 100%,100        |        |  |  |  |
| yellow        | #FFFF00                 | 255,255,0             | %,0%            |        |  |  |  |
| -             |                         |                       | 0%,0%,50        |        |  |  |  |
| navy          | #000080                 | 0,0,128               | %               |        |  |  |  |
|               |                         |                       | 0%,0%,10        |        |  |  |  |
| blue          | #0000FF                 | 0,0,255               | 0%              |        |  |  |  |
|               |                         |                       | 0%,50%,5        |        |  |  |  |
| teal          | #008080                 | 0,128,128             | 0%              |        |  |  |  |
|               |                         |                       | 0%,100%,        |        |  |  |  |
| aqua          | #00FFFF                 | 0,255,255             | 100%            |        |  |  |  |

# F.4 Example

The following code sample demonstrates some simple uses of RDLFormatCode.

```
addrmap top {
 name = "RDLCode Example";
  // desc = "Please refer to [quote]the[/quote] specification [url]http://
   www.yahoo.com]here[/url] for details.";
 reg {
   name = "Register my index = [index] my [b]parents index = [index_parent]
   my instname = [instname] [index][/b]";
   desc = "Please [b][u]refer[index] to the [index] specification[/u][/b]
   [url=http://www.yahoo.com]here[/url] for details.";
   field {
```

| 1  | <pre>name = "START [test] [br] [b]Some bold text for [instname][lb][index][rb][/b],</pre>       |
|----|-------------------------------------------------------------------------------------------------|
|    | <pre>[i]italic[/i], [u]underline[/u], [email]tcook@denali.com[/email],</pre>                    |
|    | [img]some_image.gif[/img]<br>[m][galer=#ff2266]Some_Galer[(galer][/n]                           |
| 5  | [p][COIOF=#II3306]Some COIOF[/COIOF][/p]<br>[code]echo This is some code;[/code]                |
|    | [size=18][color=red][b]LOOK AT ME![/b][/color][/size]                                           |
|    | [list]                                                                                          |
| 10 | [*][color=red]Red[/color]                                                                       |
| 10 | [*][color=blue]Blue[/color]                                                                     |
|    | [*][color=green]Green[/color]                                                                   |
|    | [/1150]<br>[]ist=1]                                                                             |
|    | [*]Red                                                                                          |
| 15 | [*]Blue                                                                                         |
|    | [*]Yellow                                                                                       |
|    | [/list]                                                                                         |
|    | [list=a]                                                                                        |
|    | [*]]Red<br>[*]]B]]Je                                                                            |
| 20 | [*]Yellow                                                                                       |
|    | [/list]                                                                                         |
|    | ";                                                                                              |
|    | deca - "Diecas (come unknown teal refer to [list-1] [t]Ded [t]Creen [/                          |
| 25 | list the specification [url=http://www.google.com]here[/url] for                                |
| 20 | details.";                                                                                      |
|    | } f1;                                                                                           |
|    | } r1 [10];                                                                                      |
|    | };                                                                                              |
| 30 | The complete SystemRDL source and sample output from this example can be found in the SystemRDL |
|    | release in the examples/rdl code directory.                                                     |
|    |                                                                                                 |
|    | the compiler, its arguments, or supporting style sheets.                                        |
| 35 |                                                                                                 |
| 55 |                                                                                                 |
|    |                                                                                                 |
|    |                                                                                                 |
|    |                                                                                                 |
| 40 |                                                                                                 |
|    |                                                                                                 |
|    |                                                                                                 |
|    |                                                                                                 |
| 45 |                                                                                                 |
| 10 |                                                                                                 |
|    |                                                                                                 |
|    |                                                                                                 |
|    |                                                                                                 |
| 50 |                                                                                                 |
|    |                                                                                                 |
|    |                                                                                                 |
|    |                                                                                                 |
|    |                                                                                                 |

# Annex G

(informative)

# **Component-property relationships**

<u>Table G1</u> lists all properties defined in SystemRDL. For each property, <u>Table G1</u> specifies which component types allow the property and gives references to the tables (or section) where the property is defined (e.g., <u>Table 23</u> for the property **accesswidth** (within the **reg** component description)). The **Mutual exclude** column designates groups of properties which are mutually exclusive (e.g., group A shows **activehigh** and **activelow** are mutually exclusive). Each mutual exclusion group is given a letter (e.g., A), which is shown next to all members of that group. <u>Table G1</u> also shows the type for each property, what side of an assignment is may appear on, and if it can be dynamically assigned (**Dyn assign**). The **Ref target** column indicates if a property may be a reference target if the column value is 'x' or 'y'. When the **Ref target** column contains a 'y', the implementation of the target needs to have the referenced net available due to an inherited or an assigned property value.

| Table G1—Property | cross-reference |
|-------------------|-----------------|
|-------------------|-----------------|

| Property           | Property Mutual<br>exclude Cor |                     | See also             | Туре                                | Ref<br>target | Dyn<br>assign | Notes                                         |  |
|--------------------|--------------------------------|---------------------|----------------------|-------------------------------------|---------------|---------------|-----------------------------------------------|--|
| accesswidth        |                                | reg                 | Table 23             | longint unsigned                    |               | х             |                                               |  |
| activehigh         | А                              | signal              | <u>Table 10</u>      | boolean                             |               | х             |                                               |  |
| activelow          | А                              | signal              | <u>Table 10</u>      | boolean                             |               | х             |                                               |  |
| addressing         |                                | addrmap             | <u>Table 26</u>      | addressingtype                      |               |               | <b>compact, regalign,</b> or <b>fullalign</b> |  |
| alignment          |                                | addrmap,<br>regfile | Table 26<br>Table 25 | longint unsigned                    |               |               |                                               |  |
| anded              |                                | field               | Table 18             | boolean                             |               | х             |                                               |  |
| anded              |                                | field               | Table 18             | N/A                                 | х             |               | Reduction AND of field value                  |  |
| async              | N                              | signal              | Table 10             | boolean                             |               | х             |                                               |  |
| bigendian          | L                              | addrmap             | Table 26             | boolean                             |               | х             |                                               |  |
| bothedge           | н                              | field               | Table 20             | N/A                                 |               |               | intr modifier                                 |  |
| bridge             |                                | addrmap             | Table 27             | boolean                             |               |               |                                               |  |
| constraint_disable |                                | constraint          | Table 29             | boolean                             |               | х             |                                               |  |
| counter            | E                              | field               | <u>Table 19</u>      | boolean                             |               | х             |                                               |  |
| cpuif_reset        |                                | signal              | <u>Table 10</u>      | boolean                             |               | х             |                                               |  |
| decr               |                                | field               | <u>Table 19</u>      | instance reference                  | у             | х             |                                               |  |
| decrsaturate       |                                | field               | Table 19             | boolean, bit,<br>instance reference |               | x             | Decrementing counter saturate value           |  |
| decrsaturate       |                                | field               | <u>Table 19</u>      | N/A                                 | у             |               | Decrementing counter saturate reached         |  |

Copyright © 2015 - 2017 Accellera. All rights reserved. This is an unapproved Accellera Standards Draft, subject to change. 5

10

15



1

Г

| Property            | Mutual<br>exclude | Components                                                        | See also                         | Туре                                | Ref<br>target | Dyn<br>assign | Notes                                                                               |
|---------------------|-------------------|-------------------------------------------------------------------|----------------------------------|-------------------------------------|---------------|---------------|-------------------------------------------------------------------------------------|
| decrthreshold       |                   | field                                                             | Table 19                         | boolean, bit,<br>instance reference |               | x             | Decrementing counter<br>threshold value                                             |
| decrthreshold       |                   | field                                                             | <u>Table 19</u>                  | N/A                                 | у             |               | Decrementing counter<br>threshold reached                                           |
| decrvalue           | G                 | field                                                             | <u>Table 19</u>                  | bit,<br>instance reference          | у             | x             |                                                                                     |
| decrwidth           | G                 | field                                                             | Table 19                         | longint unsigned                    |               | х             |                                                                                     |
| desc                |                   | addrmap,<br>constraint,<br>field, mem,<br>reg, regfile,<br>signal | <u>Table 5</u>                   | string                              |               | X             | Also used in <b>enum</b> er-<br>ation ( <u>Table 5</u> )                            |
| dontcompare         | 0                 | field                                                             | <u>Table 6</u>                   | boolean, bit                        |               | х             |                                                                                     |
| dontcompare         | 0                 | addrmap,<br>reg, regfile                                          | <u>Table 6</u>                   | boolean                             |               | х             |                                                                                     |
| donttest            | 0                 | field                                                             | <u>Table 6</u>                   | boolean, bit                        |               | х             |                                                                                     |
| donttest            | 0                 | addrmap,<br>reg, regfile                                          | <u>Table 6</u>                   | boolean                             |               | х             |                                                                                     |
| enable              | J                 | field                                                             | <u>Table 21</u>                  | instance reference                  | У             | х             |                                                                                     |
| encode              |                   | field                                                             | <u>Table 22</u>                  | enum type<br>reference              |               | Х             | <b>enum</b> eration object reference                                                |
| errextbus           |                   | addrmap,<br>reg,<br>regfile                                       | Table 26<br>Table 23<br>Table 25 | boolean                             |               |               |                                                                                     |
| field_reset         |                   | signal                                                            | <u>Table 10</u>                  | boolean                             |               | х             |                                                                                     |
| fieldwidth          |                   | field                                                             | <u>Table 18</u>                  | longint unsigned                    |               |               |                                                                                     |
| halt                |                   | reg                                                               | <u>Table 23</u>                  | N/A                                 | у             |               | Reduction OR of halt<br>Reference target<br>needs to contain fields<br>with halt    |
| haltenable          | K                 | field                                                             | <u>Table 21</u>                  | instance reference                  | У             | х             |                                                                                     |
| haltmask            | К                 | field                                                             | Table 21                         | instance reference                  | У             | x             |                                                                                     |
| hdl_path            |                   | addrmap,<br>reg, regfile                                          | Table 28                         | string                              |               | Х             |                                                                                     |
| hdl_path_gate       |                   | addrmap,<br>reg, regfile                                          | <u>Table 28</u>                  | string                              |               | х             |                                                                                     |
| hdl_path_gate_slice |                   | field, mem                                                        | Table 28                         | string[]                            |               | х             |                                                                                     |
| hdl_path_slice      |                   | field, mem                                                        | Table 28                         | string[]                            |               | х             |                                                                                     |
| hw                  |                   | field                                                             | <u>Table 11</u>                  | accesstype                          |               |               | <b>r</b> , <b>w</b> , <b>rw</b> , <b>wr</b> , <b>w1</b> , <b>rw1</b> , or <b>na</b> |

# Table G1—Property cross-reference (Continued)
r

1

| Property      | Mutual<br>exclude | Components                                                        | See also        | Туре                                | Ref<br>target           | Dyn<br>assign | Notes                                                      |
|---------------|-------------------|-------------------------------------------------------------------|-----------------|-------------------------------------|-------------------------|---------------|------------------------------------------------------------|
| hwclr         |                   | field                                                             | Table 18        | boolean,<br>instance reference      | an, y x<br>ce reference |               |                                                            |
| hwenable      | D                 | field                                                             | Table 18        | instance reference                  | у                       | х             |                                                            |
| hwmask        | D                 | field                                                             | <u>Table 18</u> | instance reference                  | у                       | х             |                                                            |
| hwset         |                   | field                                                             | <u>Table 18</u> | boolean,<br>instance reference      | у                       | x             |                                                            |
| incr          |                   | field                                                             | <u>Table 19</u> | instance reference                  | у                       | х             |                                                            |
| incrsaturate  |                   | field                                                             | <u>Table 19</u> | boolean, bit,<br>instance reference |                         | X             | Incrementing counter saturate value                        |
| incrsaturate  |                   | field                                                             | <u>Table 19</u> | N/A                                 | у                       |               | Incrementing counter saturate reached                      |
| incrthreshold |                   | field                                                             | <u>Table 19</u> | boolean, bit,<br>instance reference |                         | x             | Incrementing counter<br>threshold value                    |
| incrthreshold |                   | field                                                             | <u>Table 19</u> | N/A                                 | у                       |               | Incrementing counter<br>threshold reached                  |
| incrvalue     | F                 | field                                                             | <u>Table 19</u> | bit,<br>instance reference          | у                       | x             |                                                            |
| incrwidth     | F                 | field                                                             | <u>Table 19</u> | longint unsigned                    |                         | х             |                                                            |
| intr          | Е                 | field                                                             | <u>Table 21</u> | boolean                             |                         | х             |                                                            |
| intr          |                   | reg                                                               | Table 23        | N/A                                 | у                       |               | Reference target<br>needs to contain inter-<br>rupt fields |
| ispresent     |                   | addrmap,<br>constraint,<br>field, mem,<br>reg, regfile,<br>signal | See <u>5.3</u>  | boolean                             |                         | x             |                                                            |
| level         | Н                 | field                                                             | <u>Table 20</u> | N/A                                 |                         |               | intr modifier                                              |
| littleendian  | L                 | addrmap                                                           | Table 26        | boolean                             |                         | х             |                                                            |
| lsb0          | М                 | addrmap                                                           | Table 26        | boolean                             |                         |               |                                                            |
| mask          | J                 | field                                                             | Table 21        | instance reference                  | у                       | х             |                                                            |
| mementries    |                   | mem                                                               | Table 24        | longint unsigned                    |                         |               |                                                            |
| memwidth      |                   | mem                                                               | Table 24        | longint unsigned                    |                         |               |                                                            |
| msb0          | М                 | addrmap                                                           | Table 26        | boolean                             |                         |               |                                                            |
| name          |                   | addrmap,<br>constraint,<br>field, mem,<br>reg, regfile,<br>signal | Table 5         | string                              |                         | x             | Also used in <b>enum</b> er-<br>ation ( <u>Table 5</u> )   |
| negedge       | Н                 | field                                                             | <u>Table 20</u> | N/A                                 |                         |               | intr modifier                                              |

## Table G1—Property cross-reference (Continued)

55

1

| 5  | Property     | Mutual<br>exclude | Components          | See also                           | Туре                                | Ref<br>target | Dyn<br>assign | Notes                                                                               |
|----|--------------|-------------------|---------------------|------------------------------------|-------------------------------------|---------------|---------------|-------------------------------------------------------------------------------------|
| C  | next         |                   | field               | Table 13                           | instance reference                  | у             | х             |                                                                                     |
| 10 | nonsticky    | I                 | field               | Table 20                           | N/A                                 |               |               | intr modifier                                                                       |
|    | onread       | Р                 | field               | Table 14                           | onreadtype                          |               | х             |                                                                                     |
|    | onwrite      | В                 | field               | Table 14                           | onwritetype                         |               | х             |                                                                                     |
| 15 | ored         |                   | field               | Table 18                           | boolean                             |               | х             |                                                                                     |
|    | ored         |                   | field               | <u>Table 18</u>                    | N/A                                 | х             |               | Reduction OR of field value                                                         |
|    | overflow     |                   | field               | <u>Table 19</u>                    | boolean                             |               | х             |                                                                                     |
|    | overflow     |                   | field               | <u>Table 19</u>                    | N/A                                 | у             |               | Counter overflow                                                                    |
| 20 | paritycheck  |                   | field               | <u>Table 22</u>                    | boolean                             |               |               |                                                                                     |
|    | posedge      | н                 | field               | <u>Table 20</u>                    | N/A                                 |               |               | intr modifier                                                                       |
|    | precedence   |                   | field               | <u>Table 22</u>                    | precedencetype                      |               | х             | hw or sw                                                                            |
| 25 | rclr         | Р                 | field               | <u>Table 14</u>                    | boolean                             |               | х             |                                                                                     |
|    | regwidth     |                   | reg                 | Table 23                           | longint unsigned                    |               |               |                                                                                     |
|    | reset        |                   | field               | Table 13                           | bit,<br>instance reference          | у             | Х             |                                                                                     |
| 30 | resetsignal  |                   | field               | Table 13                           | instance reference                  | у             | х             |                                                                                     |
|    | rset         | P                 | field               | <u>Table 14</u>                    | boolean                             |               | х             |                                                                                     |
|    | rsvdset      | Q                 | addrmap             | <u>Table 26</u>                    | boolean                             |               |               |                                                                                     |
| 35 | rsvdsetX     | Q                 | addrmap             | <u>Table 26</u>                    | boolean                             |               |               |                                                                                     |
| 35 | saturate     |                   | field               | <u>Table 19</u>                    | boolean, bit,<br>instance reference |               | x             | Incrementing counter saturate value                                                 |
|    | saturate     |                   | field               | <u>Table 19</u>                    | N/A                                 | у             |               | Incrementing counter saturate reached                                               |
| 40 | shared       |                   | reg                 | Table 23                           | boolean                             |               |               |                                                                                     |
|    | sharedextbus |                   | addrmap,<br>regfile | <u>Table 26</u><br><u>Table 25</u> | boolean                             |               |               |                                                                                     |
| 45 | signalwidth  |                   | signal              | <u>Table 10</u>                    | longint unsigned                    |               |               |                                                                                     |
|    | singlepulse  |                   | field               | <u>Table 14</u>                    | boolean                             |               | х             |                                                                                     |
| 50 | sticky       | I                 | field               | <u>Table 21</u>                    | boolean                             |               | х             |                                                                                     |
|    | stickybit    | I                 | field               | <u>Table 21</u>                    | boolean                             |               | х             |                                                                                     |
|    | SW           |                   | field,<br>mem       | <u>Table 11</u><br><u>Table 24</u> | accesstype                          |               | X             | <b>r</b> , <b>w</b> , <b>rw</b> , <b>wr</b> , <b>w1</b> , <b>rw1</b> , or <b>na</b> |
|    | swacc        |                   | field               | Table 14                           | boolean                             |               | x             |                                                                                     |
| 55 | swacc        |                   | field               | Table 14                           | N/A                                 | х             |               | Accessed by software                                                                |

## Table G1—Property cross-reference (Continued)

55

| Property  | Mutual<br>exclude | Components | See also        | Туре                                | Ref<br>target | Dyn<br>assign | Notes                                     |
|-----------|-------------------|------------|-----------------|-------------------------------------|---------------|---------------|-------------------------------------------|
| swmod     |                   | field      | Table 14        | boolean                             |               | х             |                                           |
| swmod     |                   | field      | Table 14        | N/A                                 | х             |               | Modified by software                      |
| swwe      | R                 | field      | Table 14        | boolean,<br>instance reference      | у             | X             |                                           |
| swwel     | R                 | field      | <u>Table 14</u> | boolean,<br>instance reference      | у             | X             |                                           |
| sync      | N                 | signal     | <u>Table 10</u> | boolean                             |               | х             |                                           |
| threshold |                   | field      | Table 19        | boolean, bit,<br>instance reference |               | X             | Incrementing counter<br>threshold value   |
| threshold |                   | field      | <u>Table 19</u> | N/A                                 | у             |               | Incrementing counter<br>threshold reached |
| underflow |                   | field      | <u>Table 19</u> | boolean                             |               | х             |                                           |
| underflow |                   | field      | Table 19        | N/A                                 | у             |               |                                           |
| we        | С                 | field      | Table 18        | boolean,<br>instance reference      | у             | x             |                                           |
| wel       | С                 | field      | Table 18        | boolean,<br>instance reference      | у             | X             |                                           |
| woclr     | В                 | field      | Table 14        | boolean                             |               | х             |                                           |
| woset     | В                 | field      | Table 14        | boolean                             |               | x             |                                           |
| xored     |                   | field      | Table 18        | boolean                             |               | x             |                                           |
| xored     |                   | field      | Table 18        | N/A                                 | x             |               | Reduction XOR of field value              |

## Table G1—Property cross-reference (Continued)

35

40

50

45

This is an unapproved Accellera Standards Draft, subject to change.

1

55

137

| 1  |  |  |  |
|----|--|--|--|
| 5  |  |  |  |
| 10 |  |  |  |
| 15 |  |  |  |
| 20 |  |  |  |
| 25 |  |  |  |
| 30 |  |  |  |
| 35 |  |  |  |
| 40 |  |  |  |
| 45 |  |  |  |
| 50 |  |  |  |
| 55 |  |  |  |