| Renesas Technology Confidential USR-SLD-09008 Rev. 1.01 |                                    | 1/27 |  |
|---------------------------------------------------------|------------------------------------|------|--|
| Verification Environment Generator Guide                | e Verification Environment Phase 2 |      |  |

## **Verification Environment Generator Guide**

# System C Verification Environment : Verification Environment Generator Guide (ver 1.01)

Summary

The purpose of this designer manual is to describe the method to generate Verification Environment

## **Table of Contents**

| 1.Introduction_                                              | 4  |
|--------------------------------------------------------------|----|
| 2.Two kinds of Verification Environment                      |    |
| 2.1.Stimulus Environment                                     |    |
| 2.2.SH4A Environment                                         | 6  |
| 2.3.Unsupported functionality                                |    |
| 3. Verification-Environment-Generation Environment.          | 7  |
| 4.Two steps to generate verification environment             | 9  |
| 4.1.Step 1 – Preparing configuration files                   |    |
| 4.1.1.System Configuration file for verification environment | 9  |
| 4.1.2.Configuration file for Stimulus model                  |    |
| 4.2.Step 2 – Running gen env.pl script                       | 15 |
| 4.2.1.Block chart                                            | 15 |
| 4.2.2.Supported functions of gen_env.pl                      |    |
| 4.2.3.Error messages                                         | 18 |
| 4.2.4.Usage                                                  | 22 |
| 4.2.5.Example                                                |    |
|                                                              |    |

| Renesas Technology Confidential USR-SLD-09008 Rev. 1.01 |                                  | 3/27 |  |  |
|---------------------------------------------------------|----------------------------------|------|--|--|
| Verification Environment Generator Guide                | Verification Environment Phase 2 |      |  |  |

## **Index of Tables**

| Table 3.1: The description of verification-environment-generation environment                 | 8  |
|-----------------------------------------------------------------------------------------------|----|
| Table 4.1: List of keywords in SCI file                                                       |    |
| Table 4.2: Supported functions of gen_env.pl                                                  |    |
| Table 4.3: Error message of gen_env.pl                                                        |    |
| Table 4.4: Options of gen_env.pl                                                              |    |
| Index of Figures                                                                              |    |
| Figure 1.1: Scope of this guide in model verification task                                    | 4  |
| Figure 2.1: Stimulus Environment                                                              |    |
| Figure 2.2: SH4A Environment                                                                  | 6  |
| Figure 4.1: Structures of SCI file                                                            | 9  |
| Figure 4.2: A example of creating SCI file for verification environment                       | 13 |
| Figure 4.3: An example of SCI file for SH4A environment                                       | 14 |
| Figure 4.4: Example SCI file of stimulus model (stimulusSCI.txt)                              | 15 |
| Figure 4.5: Stage 1 of the running flow of gen_env.pl                                         | 15 |
| Figure 4.6: Stage 2 of the running flow of gen_env.pl                                         | 16 |
| Figure 4.7: Stage 3 of the running flow of gen_env.pl                                         | 16 |
| Figure 4.8: The working directory of the verification environment before executing gen_env.pl | 23 |
| Figure 4.9: System Configuration file for Stimulus Environment                                | 24 |
| Figure 4.10: Configuration file for Stimulus model                                            | 24 |
| Figure 4.11: The env_rvc_set.csh script                                                       | 25 |
| Figure 4.12: The working directory of the verification environment after executing gen_env.pl | 26 |

| Renesas Technology Confidential          | USR-SLD-09008                      | Rev. | 1.01 | 4/27 |
|------------------------------------------|------------------------------------|------|------|------|
| Verification Environment Generator Guide | e Verification Environment Phase 2 |      |      |      |

#### 1. Introduction

Model verification is very important in model development because the quality of each model is based on the quality of verification. Primarily, the environment creation is a decisive step in a way that it affects the all next verification steps.

This document describe environment generator script that help tester or verifier create verification environment automatically and create Address\_map\_info.txt file.

The position of this guide in verification task is described in below:



Figure 1.1: Scope of this guide in model verification task

| Renesas Technology Confidential          | USR-SLD-09008                      | Rev. | 1.01 | 5/27 |
|------------------------------------------|------------------------------------|------|------|------|
| Verification Environment Generator Guide | e Verification Environment Phase 2 |      |      |      |

#### 1. Two kinds of Verification Environment

The environment generator help users create two types of environment

#### 1.1.Stimulus Environment



Figure 1.1: Stimulus Environment

Stimulus Environment includes three kinds of model:

- Initiator model is Stimulus model
- Bus model is simple bus connecting between Initiator and target models
- · Target models are Memory model and DUT (Design Under Test)

All models are connected together according to Loosely-timed TLM interface

| Renesas Technology Confidential          | USR-SLD-09008                      | Rev. | 1.01 | 6/27 |
|------------------------------------------|------------------------------------|------|------|------|
| Verification Environment Generator Guide | e Verification Environment Phase 2 |      |      |      |

#### 1.1.SH4A Environment



Figure 1.2: SH4A Environment

SH4A Environment includes three kinds of model:

- · Initiator model is CPU model
- Bus model is simple bus connecting between Initiator and target models
- Target models are Memory model and DUT (Design Under Test)

All models are also connected together according to Loosely-timed TLM interface. Particularly, the environment uses Cedar Forest Library to execute SH4A functionalities.

## 1.1. Unsupported functionality

- Verification Environment supports for only Loosely-Timed TLM protocol, NOT Approximately-Timed TLM
- For SH4A Environment, Interrupt model is not supported
- For Stimulus Environment, Stimulus model supports for processing interrupts of only one DUT

| Renesas Technology Confidential          | USR-SLD-09008                      | Rev. | 1.01 | 7/27 |
|------------------------------------------|------------------------------------|------|------|------|
| Verification Environment Generator Guide | e Verification Environment Phase 2 |      |      |      |

## 1. Verification-Environment-Generation Environment

This part describes the environment (mandatory file and folders) of generating verification environment so that users are able to check whether or not the file and folders are sufficient before using the environment generation script.

| File/Folder                                                                                                                        | Explanation                                                                                                                                                                                                 |
|------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1. TLMForest folder                                                                                                                | This folder includes all mandatory source and header files together with the script files, make files, skeleton files, and text files which are necessary to generate the expected verification environment |
| 1.1 Model files                                                                                                                    |                                                                                                                                                                                                             |
| address_map.h                                                                                                                      | Caddress_map class is used for processing address between bus, initiator and target model                                                                                                                   |
| simple_memory.h                                                                                                                    | Csimple_memory class is memory model                                                                                                                                                                        |
| simple_bus_lt.h                                                                                                                    | Csimple_bus_lt class is implemented as Loosely-time TLM Bus model                                                                                                                                           |
| sitmulus.h                                                                                                                         | Cstimulus class is stimulus model                                                                                                                                                                           |
| tlm_if.h<br>tlm_tgt_if.h<br>tlm_ini_if.h                                                                                           | These files implement TLM common classes                                                                                                                                                                    |
| reg_super.h re_register.h re_register.cpp                                                                                          | These files implement Register common classes                                                                                                                                                               |
| cpu.h cpu.cpp cpu_utility.cpp cpu_command.cpp forest_utility.h cedar_forest_api.h memory_body.h memory_body.cpp cedar_forest_api.h | All models are used to execute SH4A functions                                                                                                                                                               |
| 1.2 Skeleton files                                                                                                                 |                                                                                                                                                                                                             |
| tlmforest.skl                                                                                                                      | Skeleton file of tlmforest.h                                                                                                                                                                                |
| main_with_sm.skl                                                                                                                   | Skeleton file of forest_main.cpp in Stimulus environment                                                                                                                                                    |
| main_with_cpu.skl                                                                                                                  | Skeleton file of forest_main.cpp in SH4A environment                                                                                                                                                        |
| 1.3 Text files                                                                                                                     |                                                                                                                                                                                                             |
| tlmforest_SCI.txt                                                                                                                  | System Configuration file includes environment settings                                                                                                                                                     |
| stimulusSCI.txt                                                                                                                    | The text file includes settings for Stimulus model                                                                                                                                                          |
| 1.4 Makefile files                                                                                                                 |                                                                                                                                                                                                             |
| Makefile                                                                                                                           | The files include primary compilation settings                                                                                                                                                              |

| Renesas Technology Confidential USR-SLD-09008 Rev. 1.01 |                                    | 8/27 |  |
|---------------------------------------------------------|------------------------------------|------|--|
| Verification Environment Generator Guide                | e Verification Environment Phase 2 |      |  |

| File/Folder       | Explanation                                                                                         |
|-------------------|-----------------------------------------------------------------------------------------------------|
| Makefile.defs     |                                                                                                     |
| 1.5 Script files  |                                                                                                     |
| gen_env.pl        | Environment generation script                                                                       |
| env_set.csh       | The script setting environment variables according to whether complication machine is in RTC or RVC |
| env_rvc_set.csh   | The script setting environment variables in RVC is called by env_set.csh                            |
| env_rtc_set.csh   | The script setting environment variables in RTC is called by env_set.csh                            |
| makelink.bat      | The script makes links to cedar_forest_api.h and Cedar Forest library in CedarX3 folder             |
| 2. CedarX3 folder | The folder includes all necessary files to build Cedar Forest library                               |

Table 1.1: The description of verification-environment-generation environment

| Renesas Technology Confidential          | USR-SLD-09008                      | Rev. | 1.01 | 9/27 |
|------------------------------------------|------------------------------------|------|------|------|
| Verification Environment Generator Guide | e Verification Environment Phase 2 |      |      |      |

## 2. Two steps to generate verification environment

This part describes how to generate verification environment and Address\_map\_info.txt by using gen\_env.pl.

- Step 1: Preparing Configuration files
- Step 2: Running gen env.pl script

#### 2.1. Step 1 - Preparing configuration files

#### 2.1.1. System Configuration file for verification environment

SCI (system configuration) file is used to describe all settings of verification environment which must be defined before the other step. This file includes two parts:

- Part 1: Environment description defines common information for all the environment.
- Part 2: Bus description defines information for each bus. If more than 1 bus are used, this part will be
   written many times with different information from each other.

The structure of System Configuration file is described as the following:



Figure 2.1: Structures of SCI file.

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 10/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

All information is marked by keywords which are written in SCI file regardless of Mandatory or Optional .

The meaning of keywords in this file is described in table 2.1.

| Keyword           | Meaning                                                                                      | Note      |
|-------------------|----------------------------------------------------------------------------------------------|-----------|
| %ENV_INFO         | Information of environment: environment with cpu or stimulus, LT or AT                       | Mandatory |
| %CLOCK_RATIO      | Clock ratio: name, cycle, duty cycle, start time, positive first or negative first           | Mandatory |
| %CHANNEL_SYS      | Signals information: signal's name, bit width, signal or port in or port out, type           | Mandatory |
| %INTERRUPT_INFO   | Interrupt general information                                                                | Mandatory |
| %SECTION          | Section address is used to check result                                                      | Optional  |
| %MEMORY_INFO      | Address range of memory model                                                                | Mandatory |
| %BASE_ADDRESS     | Base address of each model that has registers                                                | Optional  |
| %OFFSET_ADDRESS   | Offset address of registers of DUT                                                           | Optional  |
| %BUS_INFO         | Information of bus: bus identifier, bus width                                                | Mandatory |
| %TOP_MODULE_PARAM | System top level parameters                                                                  | Mandatory |
| %TOP_MODULE_LIST  | List informations of all modules: file name, class name, instance name, VC identifier.       | Mandatory |
| %VC_SPECIFIC_SYS  | Specific system of each module: its names and its signal names.                              | Mandatory |
| %ADDRESS_MAP      | Memory range of target model. It includes: start address, end address and module identifier. | Optional  |
| %END              | End of configuration file                                                                    | Mandatory |
| #                 | Commented part                                                                               | Optional  |

Mandatory:

There must be at least one information line (Not

commend line) after these keywords

There doesn't have to be at least one information line (Not commend line) after these

Optional: Information keywords

Table 2.1: List of keywords in SCI file

#### 2.1.1.1. Detailed description

- %ENV\_INFO: There is only one next line:

#### <Environment\_id> <TLM\_coding\_style>

- <Environment\_id>: Integer number to choose verification environment with stimulus or bus
  - 0: SH4A verification environment
  - 1: Stimulus verification environment
- <TLM\_coding\_style>: String to choose TLM/LT or TLM/AT coding style.

LT: TLM/LT (Loosely-Timed) Environment

**AT**: TLM/AT (Approximately-Timed) Environment. This style is not supported in this project.

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 11/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

- %CLOCK\_RATIO: There are many lines. Each line is described as followings

<clock\_name> <period> <duty\_cycle> <start\_time> <positive\_first>

<clock\_name> : String to define name of a clock

<period> : Real number to define period of that clock

<duty\_cycle> : Real number to define duty cycle of that clock

• <start\_time> : Real number to define the starting time to activate of the defined clocks

<positive\_first>: String to define whether the defined clocks are positive or negative at the first time
 they are activated. This information has 2 values only:

true: Positive

false: Negative

- %CHANNEL SYS: There are many lines. Each line is described as followings

<signal\_name> <bit\_width> <signal/port in/port out> <class\_name\_of\_data\_type>

- <signal\_name>: String to define name of a signal
- <bit\_width> : Integer number to define bit width of that signal
- <signal/port in/port out> : String to define type of signal. The information has only 4 values:

in : port in

out: port out

inout: port in/out

signal: signal

- <class\_name\_of\_data\_type>: String to define class name of data type.
- %INTERRUPT\_INFO: The next line is an integer number that indicate the width of interrupt signal of DUT
- %SECTION: There are many lines. Each line is described as followings

<section\_name> <section\_address>

- <section\_name>: String to define name of a section. The usual values are: PASS, FAIL, REST
- <section address>: Hex number to define address of that section.
- %BUS\_INFO: There are many lines. Each line is described as followings

<header\_file> <class\_name> <instance\_name> <bus\_id> <bus\_width>

<header\_file> : String to define name of header file of a bus

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 12/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

- <class\_name> : String to define name of bus class
- <instance\_name> : String to define instance name of that bus

<bus\_id>: Integer number to define the index of that bus

<bus\_width> : Integer number to define the bus width

- %TOP\_MODULE\_PARAM: The content of this part is the next two lines:

NUM\_OF\_INT < initiator\_number>

NUM\_OF\_TGT < target\_number>

- <initiator\_number> : Integer number to define the number of initiators connected to this bus
- <target\_number> : Integer number to define the number of targets connected to this bus
- %TOP\_MODULE\_LIST: There are many lines. Each line is described as followings

<header\_file> <class\_name> <instance\_name> <VC\_id> <socket\_name> <initiator\_or\_target>

- <header file> : String to define name of header file of a module
- <class name>: String to define name of class module
- <instance\_name> : String to define instance name of that module
- <VC\_id>: Integer number to define the index of module. This number will be started by "0" number for initiators VC and targets VC. For example: there are 2 modules: initiator module A and target module B, the index of these 2 modules will be 0, not 0 and 1.
- <socket\_name> : String to define the socket name of that module
- <initiator\_or\_target> : String to define whether module is initiator module or target module. This part
  has two values:

INI: Initiator module

TGT: Target module

- %VC SPECIFIC LIST: There are many lines. Each line is described as followings

<instance\_name> <port\_name> <signal\_name>

- <instance\_name>: String to define instance name of a module
- <port\_name>: String to define name of port of that module
- <signal\_name>: String to define name of signal that are connected to port of that module. For example: "reset"
- %MEMORY\_INFO: The content of this part is only one line that defines address range of memory model <start\_address> <end\_address>

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 13/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

- <start\_address>: Hex number (started by "0x") to define the start address of memory model
- <end address>: Hex number (started by "0x") to define the end address of memory model
- %ADDRESS\_MAP: There are many lines. Each line is described as followings

#### <start\_address> <end\_address> <target\_id>

- <start\_address>: Hex number (started by "0x") to define the start address of memory model
- <end address>: Hex number (started by "0x") to define the end address of memory model
- <target\_id>: Integer number to define the index of target VC
- %BASE\_ADDRESS: There are many lines. Each line is described as followings

#### <base\_address> <offset\_mask> <model\_id>

- <base address> : Hex number (started by "0x") to define the base address of each model
- <offset mask> : Mask of offset address of each model
- <model\_id>: Integer number to define the index of each model
- %OFFSET\_ADDRESS: There are many lines. Each line is described as followings

#### <register\_name> <offset\_address> <model\_id>

- <register\_name> : String to define name of a register of a module.
- <base\_address> : Hex number (started by "0x") to define the offset address of that register.
- <model id>: Integer number to define the index of each model.

The **%BASE\_ADDRESS** and **%OFFSET\_ADDRESS** information are used to create address information that will be used for TM generator.

#### 2.1.1.1.Example

Supposing that the following verification environment are built

- Two buses
- One memory model
- One CPU model
- One interrupt model
- One bridge model
- One DUT (TMU) model



Figure 2.2: A example of creating SCI file for verification environment

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 14/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

Configuratio " ' %ENV\_INFO 0 LT #CPU %CLOCK\_RATIO clock name period duty\_cycle start time positive\_first 0.5 0 sclk 5 true pclk 30 0.5 0 %CHANNEL\_SYS signal\_name bits\_width port\_in/out\_from\_VC class\_name in bool 1 inout bool reset intr signal sc\_uint %INTERRUPT\_INFO # INTR\_WIDTH %SECTION section\_name section\_address PASS 0x0C700000 FAIL 0x0C700100 REST 0x0C700200 %BUS\_INFO ########Bus 1 class\_name instance\_name bus\_id bus\_width # header file 0 32 bus.h bus bus\_1 %TOP\_MODULE\_PARAM NUM\_OF\_INI 2 # number of initiator VCs NUM\_OF\_TGT 3 # number of target VCs %TOP\_MODULE\_LIST head\_file class\_name instance\_name VC\_indx Socket\_name ini/tgt INI cpu.h cpu cpu 0 cpu\_ini tmu.h tmu tmu tmu\_ini 0 tmu.h tmu tmu tmu\_tgt TGT TGT memory.h memory mem mem\_tgt 2 bridge.h bridge bridge bridge\_tgt TGT %VC\_SPECIFIC\_SYS signal\_name # instance\_name port\_name stim reset reset pclk pclk %MEMORY\_INFO # start\_address end\_address 0x20000000 0x2FFFFFF %ADDRESS MAP # initial addr end addr tgt\_VC\_indx 0x00000000 0x0FFFFFF 2 # bridge 0x10000000 0x13FFFFFF 0 #tmu1 %BASE\_ADDRESS address offset\_mask 0xFE410000 0x0000FFFF 1 %OFFSET\_ADDRESS # reg\_name address base\_address\_id 0x0004 1 TMU TSTR TMU\_TCOR\_0 0x0008 %BUS\_INFO #######Bus 2 1 32 bus bus 2 %TOP\_MODULE\_PARAM NUM\_OF\_INI 1 # number of initiator VCs NUM\_OF\_TGT 1 # number of target VCs %TOP\_MODULE\_LIST bridge.h bridge bridge intc.h intc intc 0 bridge\_ini 0 TGT intc\_tgt %VC\_SPECIFIC\_SYS reset %ADDRESS\_MAP 0x14000000 0x16FFFFFF 0 #intc %BASE\_ADDRESS 0x10000000 0x0000FFFF %OFFSET\_ADDRESS INTC\_NMMI 0x0004 0 %END %END

Figure 2.3: An example of SCI file for SH4A environment

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 15/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

Configuration file of stimulus model defines the input text pattern file and the maximum transaction

// Stimulus model

// Instance name Parameter name Parameter value

stimulus\_module TM\_file\_name TM.txt

stimulus\_module max\_transaction 1000

Figure 2.4: Example SCI file of stimulus model (stimulusSCI.txt)

Instance name must be defined as instance name of stimulus model which was defined in System Configuration file of Verification Environmen

**TM\_file\_name** [Test pattern name] : Define which input text pattern file will be processed **max\_transaction** [Number of maximum transaction]: Define number of maximum transactions

#### 2.1.Step 2 - Running gen\_env.pl script

#### 2.1.1.Block chart

The running flow of script gen\_env.pl comprises three stages described as the three following block charts



Figure 2.5: Stage 1 of the running flow of gen\_env.pl

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 16/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |



Figure 2.6: Stage 2 of the running flow of gen\_env.pl



Figure 2.7: Stage 3 of the running flow of gen\_env.pl

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 17/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

## 2.1.2. Supported functions of gen\_env.pl

| Туре        | Content                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Script name | gen_env.pl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Language    | Perl version 5.8.5 or later                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Purpose     | - Build TLM/LT verification environment with CPU or Stimulus model - Create Address_map_info.txt file                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Input file  | All input files are described in Table 3.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Output file | - Executable file <i>tlmforest.ext</i> - Address_map_info.txt file                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Usage       | perl gen_env.pl [option]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Option      | [option] -i <directory path="">: the path to the directory storing the skeleton and design of models. Default value: current directoryoforest <directory path="">: the destination storing the output tlmforest.exe. Default value: current directoryoaddress <directory path="">: the destination storing the output Address_map_info.txt. Default value: current directorysci <sci file="" name=""> : the name of input sci file. Default value: tlmforest_SCI.txt in the current directorybuild_cedar: build the CedarX3. Default value: Not build -help: print this helpful message.</sci></directory></directory></directory> |

Table 2.2: Supported functions of gen\_env.pl

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 18/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

## 2.1.3.Error messages

| No. | Severity | Error Message                                                                                                     | Explanation                                                                |
|-----|----------|-------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|
| 1   | Error    | [gen_env.pl] Error: Can't open Env SCI file: < sci_file_name>                                                     | System configuration file for verification environment doesn't exist       |
| 2   | Error    | [gen_env.pl] Error: Unknown argument : <argument> Please run again with option -help for the direction</argument> | Specified options of gen_env.pl is wrong                                   |
| 3   | Error    | [gen_env.pl] Error: Unknown command <command/>                                                                    | A command beginning with "%" symbol is wrong                               |
| 4   | Error    | [gen_env.pl] Error: Can't open skeleton file: < design_directory > /tlmforest.skl                                 | The skeleton file tlmforest.skl doesn't exist in < design_directory>       |
| 5   | Error    | [gen_env.pl] Error: Can't open skeleton file of forest_main                                                       | The skeleton file to create forest_main.cpp doesn't exist                  |
| 6   | Error    | [gen_env.pl] Error: Can't create forest_main.cpp                                                                  | The forest_main.cpp can not be created                                     |
| 7   | Error    | [gen_env.pl] Error: Can't create<br>Address_map_info.txt                                                          | The Address_map_info.txt can not be created                                |
| 8   | Error    | [gen_env.pl] Error: Repeated models are declared in %BASE_ADDRESS                                                 | At least one model is described two times in %BASE_ADDRESS                 |
| 9   | Error    | [gen_env.pl] Error: Offset address defined isn't equivalent to base addess: <offset_address></offset_address>     | The model index is not equivalent between base address and offset adress   |
| 10  | Error    | [gen_env.pl] Error: Cannot create temp file to build environment                                                  | The temporary Shell script used to build Environment can not be created    |
| 11  | Error    | [gen_env.pl] Error: tlmforest.exe is not created! Compilation fails                                               | Building verification environment is failed                                |
| 12  | Error    | [gen_env.pl] Error: Can't open old file: <design_directory>/tlmforest.old</design_directory>                      | The tlmforest.old which is a copy of the current tlmforest.h doesn't exist |
| 13  | Error    | [gen_env.pl] Error: Duplicated bus instance name: <instance_name></instance_name>                                 | At least one instance name of one model is described two times             |
| 14  | Error    | [gen_env.pl] Error: Duplicated ports or signals: <port></port>                                                    | At least one port of one model is described two times                      |
| 15  | Error    | [gen_env.pl] Error: Unknown ports or signals: <port></port>                                                       | At least one port of one model is not described                            |
| 16  | Error    | [gen_env.pl] Error: Lack of NUM_OF_INI information                                                                | NUM_OF_INI information is not described                                    |
| 17  | Error    | [gen_env.pl] Error: Redundant NUM_OF_INI information                                                              | NUM_OF_INI information is described more than 1 time                       |
| 18  | Error    | [gen_env.pl] Error: Lack of NUM_OF_TGT information                                                                | NUM_OF_TGT information is not described                                    |
| 19  | Error    | [gen_env.pl] Error: Redundant NUM_OF_TGT information                                                              | NUM_OF_TGT information is described more than 1 time                       |

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 19/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

| 20 | Error | [gen_env.pl] Error: < command> is not declare                                           | The < command> is not described in SCI file                       |
|----|-------|-----------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| 21 | Error | [gen_env.pl] Error: [%ENV_INFO] Lack of Environment information                         | The environment information is not described in %ENV_INFO command |
| 22 | Error | [gen_env.pl] Error: [%ENV_INFO] Wrong Environment mode                                  | The environment information is described as not 0 and 1           |
| 23 | Error | [gen_env.pl] Error: [%ENV_INFO] Wrong Environment Interface                             | The environment interface is described as not LT and AT           |
| 24 | Error | [gen_env.pl] Error: [%ENV_INFO] No support AT Interface                                 | AT environment interface is not supported                         |
| 25 | Error | [gen_env.pl] Error: [%CLOCK_RATIO] Lack of clock information                            | Clock information is not described in %CLOCK_RATIO command        |
| 26 | Error | [gen_env.pl] Error: [%CLOCK_RATIO] Wrong clock name                                     | Clock information is described wrongly                            |
| 27 | Error | [gen_env.pl] Error: [%CLOCK_RATIO] Wrong period value                                   | Period value of a clock is described wrongly                      |
| 28 | Error | [gen_env.pl] Error: [%CLOCK_RATIO] Wrong duty cycle                                     | Duty cycle of a clock is described wrongly                        |
| 29 | Error | [gen_env.pl] Error: [%CLOCK_RATIO]  Duty cycle is bigger than 1                         | Duty cycle of a clock is described as bigger than 1               |
| 30 | Error | [gen_env.pl] Error: [%CLOCK_RATIO] Wrong start time                                     | Starting time of a clock is described wrongly                     |
| 31 | Error | [gen_env.pl] Error: [%CLOCK_RATIO] Wrong positive first value. It must be true or false | Wrong positive/negative value of a clock is described wrongly     |
| 32 | Error | [gen_env.pl] Error: [%INTERRUPT_INFO] Lack of Interrupt information                     | Interrupt information is not described in %INTERRUPT_INFO command |
| 33 | Error | [gen_env.pl] Error: [%INTERRUPT_INFO]The Interrupt index must be number                 | Interrupt information is not an integer number                    |
| 34 | Error | [gen_env.pl] Error: [%SECTION]Lack of Section information                               | Section information is not described in %SECTION command          |
| 35 | Error | [gen_env.pl] Error: [%SECTION]Section address is wrong format                           | Section information is not described wrongly                      |
| 36 | Error | [gen_env.pl] Error: [%BUS_INFO]Lack of Bus info parameter                               | Bus information is not described in %BUS_INFO command             |
| 37 | Error | [gen_env.pl] Error: [%BUS_INFO]Wrong bus id                                             | Bus ID is described wrongly                                       |
| 38 | Error | [gen_env.pl] Error: [%BUS_INFO]Wrong bus width                                          | Bus width is described wrongly                                    |
| 39 | Error | [gen_env.pl] Error: [%TOP_MODULE_PARAM]Lack of System top level parameter               | System top level parameter is not described in %TOP_MODULE_PARAM  |

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 20/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

| 40 | Error | [gen_env.pl] Error: [%TOP_MODULE_PARAM] Parameter name of top module is not correct     | Name of top module is described wrongly                             |
|----|-------|-----------------------------------------------------------------------------------------|---------------------------------------------------------------------|
| 41 | Error | [gen_env.pl] Error: [%TOP_MODULE_PARAM]The index of top module parameter must be number | Name of top module is described wrongly                             |
| 42 | Error | [gen_env.pl] Error: [%TOP_MODULE_LIST]Wrong filename of header file                     | The file name of header file is described wrongly                   |
| 43 | Error | [gen_env.pl] Error: [%TOP_MODULE_LIST]Wrong class name of module                        | The class name is described wrongly                                 |
| 44 | Error | [gen_env.pl] Error: [%TOP_MODULE_LIST]Wrong instance name of module                     | The instance name is described wrongly                              |
| 45 | Error | [gen_env.pl] Error: [%TOP_MODULE_LIST]Wrong module id                                   | The module ID is described wrongly                                  |
| 46 | Error | [gen_env.pl] Error: [%TOP_MODULE_LIST]Wrong socket name of module                       | The socket name is described wrongly                                |
| 47 | Error | [gen_env.pl] Error: [%TOP_MODULE_LIST]Wrong type of module. It must be INI or TGT       | The type of module is described wrongly                             |
| 48 | Error | [gen_env.pl] Error: [%VC_SPECIFIC_SYS]Lack of information of systemc signal             | The signal information is not described in %VC_SPECIFIC_SYS command |
| 49 | Error | [gen_env.pl] Error: [%MEMORY_INFO]Lack of memory information                            | The memory information is not described in %MEMORY_INFO command     |
| 50 | Error | [gen_env.pl] Error: [%MEMORY_INFO]The address of memory information is wrong format     | The address of memory information is wrong format                   |
| 51 | Error | [gen_env.pl] Error: [%MEMORY_INFO]The end address must be bigger than start address     | The ending address is smaller than the stating address              |
| 52 | Error | [gen_env.pl] Error: [%ADDRESS_MAP]Lack of memory map information                        | The memory map information is not described in %ADDRESS_MAP command |
| 53 | Error | [gen_env.pl] Error: [%ADDRESS_MAP]The address of memory map information is wrong format | The address of memory map information is wrong format               |
| 54 | Error | [gen_env.pl] Error: [%ADDRESS_MAP]The target VC index must be number                    | The target VC index is not a number                                 |

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 21/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

| 55 | [gen_env.pl] Error: [%ADDRESS_MAP]The end address must be bigger than initial address      | The ending address is smaller than the initial address             |
|----|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
| 56 | [gen_env.pl] Error: [%BASE_ADDRESS]Lack of base address information                        | Base address information is not described in %BASE_ADDRESS command |
| 57 | [gen_env.pl] Error: [%BASE_ADDRESS]The address of base address information is wrong format | The address of base address information is wrong format            |
| 58 | [gen_env.pl] Error: [%BASE_ADDRESS]The model id must be number                             | The model ID is not a number                                       |
| 59 | [gen_env.pl] Error: [%OFFSET_ADDRESS]Lack information                                      | Information is not described in %OFFSET_ADDRESS command            |
| 60 | [gen_env.pl] Error: [%OFFSET_ADDRESS]Wrong register name                                   | The register name is described wrongly                             |
| 61 | [gen_env.pl] Error: [%OFFSET_ADDRESS]Wrong format of offset address                        | The format of offset address is described wrongly                  |
| 62 | [gen_env.pl] Error: [%OFFSET_ADDRESS]Wrong model id                                        | The model ID is described wrongly                                  |

Table 2.3: Error message of gen\_env.pl

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 22/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

#### 2.1.4.Usage

As mentioned in <u>4.2.1. Block chart</u>, there are three stages in the running flow of gen\_env.pl script. This part describes how to use gen\_env.pl script

#### (1) Preparing the necessary files

- The first step, the most important step, is to prepare the necessary files because gen\_env.pl script
  can not run successfully without one of these file. All necessary folders and files are described
  detailedly in 3.Verification-Environment-Generation Environment
- Users have to prepare carefully System Configuration file for the verification environment and configuration file for Stimulus model, in case of Stimulus environment, because these files decide how the environment verification is generated.
- Users are recommended prepare the structure of folders and files which is the same as described in this document. Or else, users have to execute gen\_env.pl with its options carefully.

#### (1) Setting environment variables

- The next step is to set environment variables which are necessary for compilation in the next step by executing env\_set.csh script
- env\_set.csh script calls env\_rtc\_set.csh or env\_rvc\_set.csh according to whether users' machines are in RTC or RVC
- Users are recommended checking env\_rtc\_set.csh and env\_rvc\_set.csh and modify them if any
  existing settings in these files are not suitable.

#### (1) Executing gen\_env.pl script

- The final step is to execute gen env.pl with its options which users have to choose carefully:

| Option                                  | Notes to use                                                                                                                     |  |  |  |  |
|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| -i <dir_path></dir_path>                | This option indicates the path to the directory storing the skeleton and design on nodels. Default value: current directory.     |  |  |  |  |
|                                         | - Users must remember that CedarX3 folder must placed at the same folder structure with <dir_path></dir_path>                    |  |  |  |  |
|                                         | Example: If <dir_path> is /common/work/Verification_Environment, the CedarX3</dir_path>                                          |  |  |  |  |
|                                         | /common/work/                                                                                                                    |  |  |  |  |
|                                         | Verification_Environment                                                                                                         |  |  |  |  |
|                                         | CedarX3                                                                                                                          |  |  |  |  |
|                                         | must be placed as the following                                                                                                  |  |  |  |  |
| -oforest<br><dir_path></dir_path>       | The destination folder storing the output <i>tlmforest.exe</i> . Default value: current directory                                |  |  |  |  |
| -oaddress<br><dir_path></dir_path>      | The destination folder storing the output Address_map_info.txt. Default value: current directory                                 |  |  |  |  |
| -sci<br><sci_file_name></sci_file_name> | The name of System configuration file of the verification environment. Default value: tlmforest_SCI.txt in the current directory |  |  |  |  |
| -build_cedar                            | Build the CedarX3. Default value: Not build  Users are recommended choosing the option in the first time run gen_env.pl          |  |  |  |  |

Table 2.4: Options of gen\_env.pl

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 23/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

Afterwards, users execute gen\_env.pl with the chosen options

#### 2.1.1.Example

(1) Preparing the necessary: The working directory is organized as the same as the following figure



Figure 2.8: The working directory of the verification environment before executing gen\_env.pl

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 24/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

The System Configuration file for the verification environment is tlmforest\_SCI.txt which is written as the following



Figure 2.9: System Configuration file for Stimulus Environment

Because this is Stimulus environment, the configuration file of Stimulus model is also prepared

```
// sitmulus_SCI.txt

// Instance name Parameter name Parameter value

stim TM_file_name %TM_NAME

stim max_transaction 1000
```

Figure 2.10: Configuration file for Stimulus model

| Renesas Technology Confidential          | USR-SLD-09008                                                       | Rev. | 1.01 | 25/27 |
|------------------------------------------|---------------------------------------------------------------------|------|------|-------|
| Verification Environment Generator Guide | cation Environment Generator Guide Verification Environment Phase 2 |      |      |       |

(2) Setting environment variables: Because the machine is in RVC, env\_rvc\_set.csh is called by env set.csh. The env rvc set.csh is available as the following figure

#!/bin/csh -f # CPAN environment setting set path = (/shsv/sld/Common/Lib/02 Perl/CPAN for use Spreed/ \$path) setenv PERL5LIB /shsv/sld/Common/Lib/02 Perl/CPAN for use Spreed # Toolchain directory define setenv TOOL PATH /common/appl/Renesas/shc/SHCV90200 # Source SHC source \${TOOL\_PATH}/shc.CSHRC\_9.02.00 # C++ compiler setenv CC g++ setenv TARGET\_ARCH linux setenv INCDIR "-I./include -I/shsv/sld/Common/Lib/99 Others/include" setenv LIBDIR "-L./libs/\${TARGET\_ARCH} -L/usr/local/lib -L/usr/lib -L/shsv/sld/Common/Lib/99 Others" # 32-bit machine setenv LD LIBRARY PATH "/shsv/sld/Common/Tools/gcc4.2.2 32bit srv/lib":"\$LD LIBRARY PATH" setenv PATH "/shsv/sld/Common/Tools/gcc4.2.2 32bit srv/bin":"\$PATH" # compile SystemC setenv SC TYPE systemc-2.2.0 # install directory setenv SYSTEMC /shsv/sld/Common/Lib/01 SystemC/\${SC TYPE} setenv TLM /shsv/sld/Common/Lib/04\_TLM/TLM2.0-2008-06-09 # SystemC 2.2 is used setenv SC SIGNAL WRITE CHECK DISABLE

Figure 2.11: The env\_rvc\_set.csh script

| Renesas Technology Confidential          | USR-SLD-09008     | Rev.      | 1.01    | 26/27 |
|------------------------------------------|-------------------|-----------|---------|-------|
| Verification Environment Generator Guide | Verification Envi | ronment F | Phase 2 |       |

(3) Executing gen\_env.pl: The script gen\_env.pl is executed as the following with option -build\_cedar > perl gen\_env.pl -build\_cedar

The working directory after executing gen\_env.pl is the following



Figure 2.12: The working directory of the verification environment after executing gen\_env.pl

| Renesas Technology Confidential          | USR-SLD-09008                    | Rev. | 1.01 | 27/27 |  |
|------------------------------------------|----------------------------------|------|------|-------|--|
| Verification Environment Generator Guide | Verification Environment Phase 2 |      |      |       |  |

## **Revision History**

| Rev.No | Contents                                                                                                | Approval | Checked     | Created  |
|--------|---------------------------------------------------------------------------------------------------------|----------|-------------|----------|
| 1.0    | Create new.                                                                                             |          | Chau Nguyen | Khang Le |
|        |                                                                                                         |          | 10/06/09    | 09/25/09 |
| 1.01   | - In Table 3.1, At "env_rtc_set.csh", "The script                                                       | A.Imoto  | Chau Nguyen | Khang Le |
|        | setting environment variables in <b>RVC</b> is called by env_set.csh" is changed to "The script setting | 10/14/09 | 10/13/09    | 10/09/09 |
|        | environment variables in <b>RTC</b> is called by env_set.csh"                                           |          |             |          |
|        | - In Table 4.2: Supported functions of gen_env.pl,                                                      |          |             |          |
|        | Language is changed from "Perl version 5.8.8" to                                                        |          |             |          |
|        | "Perl version 5.8.5 or later"                                                                           |          |             |          |
|        |                                                                                                         |          |             |          |