# **Verilog Generator**

**User Guide** 

version 1.02 June 12, 2023

### **Important Notice**

#### Freely available under the terms of the 3-Clause BSD License

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

- 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
- 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
- 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)

HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

## **Document Revision History**

| Doc Revision<br>Number | Date                                                  | Description                                                                      |
|------------------------|-------------------------------------------------------|----------------------------------------------------------------------------------|
| 1.02                   | June 12, 2023                                         | add default clock, add vfunctions (\$LOG2, \$RANGE, \$DEMUX_BY_EN, \$MULTICYCLE) |
| 1.01                   | June 8, 2023 add interface:set_top_uppercase function |                                                                                  |
| 1.00                   | May 8, 2023                                           | Initial relase                                                                   |

## **Table of Contents**

| 1. | INTRODUCTION                            | 9  |
|----|-----------------------------------------|----|
|    | 1.1 Main functions                      | 9  |
|    | 1.2 Verilog automation creation process |    |
|    | 1.3 How to run                          |    |
|    | 1.4 license grant                       |    |
| 2. | FAST FOLLOW                             | 11 |
|    | 2.1 Step #1 : Creation of module        |    |
|    | 2.2 Step #2 : module interconnections   |    |
|    | 2.3 Step #3 : Verilog code insertion    |    |
| 3. | MACRO FUNCTIONS                         | 23 |
|    | 3.1 V macro                             | 24 |
|    | 3.2 vfunction macro                     |    |
|    | 3.3 \$LOG2 function                     |    |
|    | 3.4 \$DEMUX BY EN function              |    |
|    | 3.5 \$MULTICYCLE function               |    |
| 4. | CLASS AND METHOD                        | 30 |
|    | 4.1 clock                               | 31 |
|    | 4.1.1 clock:new                         |    |
|    | 4.1.2 clock:set_reset                   |    |
|    | 4.1.3 clock:get_reset                   |    |
|    | 4.1.4 clock:set_speed                   |    |
|    | 4.1.5 clock:set default                 |    |
|    | 4.1.6 clock.find                        |    |
|    | 4.1.7 clock.is_valid                    |    |
|    | 4.1.8 clock.get_default                 |    |
|    | 4.2 interface                           |    |
|    | 4.2.1 interface:new                     | 42 |
|    | 4.2.2 new_signal                        | 43 |
|    | 4.2.3 interface.find                    | 44 |
|    | 4.2.4 interface.is_valid                | 45 |
|    | 4.2.5 interface:set_clock               |    |
|    | 4.2.6 interface:get_clock               |    |
|    | 4.2.7 interface:set_signal              |    |
|    | 4.2.8 interface:signal_count            |    |
|    | 4.2.9 interface:set_param               |    |
|    | 4.2.10 interface:get_param              |    |
|    | 4.2.11 interface:set_modport            |    |
|    | 4.2.12 interface:add_modport            |    |
|    | 4.2.13 interface:get_modport            |    |
|    | 4.2.14 interface:set_prefix             |    |
|    | 4.2.15 interface:set_bared              |    |
|    | 4.2.16 interface:set_top_uppercase      |    |
|    | 4.2.17 interface_i:set_port             |    |
|    | 4.2.18 interface_i:set_desc             |    |
|    | 4.2.19 interface_i:set_prefix           |    |
|    | 4.2.20 interface_i:get_prefix           |    |
|    | 4.3 module                              | 63 |

|            | 4.3.1 module:new                    | 64 |
|------------|-------------------------------------|----|
|            | 4.3.2 module:make_code              | 65 |
|            | 4.3.3 module:set_inception          |    |
|            | 4.3.4 module:get inception          |    |
|            | 4.3.5 module:set_title              | 69 |
|            | 4.3.6 module:set author             |    |
|            | 4.3.7 module:set param              | 71 |
|            | 4.3.8 module:get_param              |    |
|            | 4.3.9 module:add interface          |    |
|            | 4.3.10 module:add clock             |    |
|            | 4.3.11 module:get interface         |    |
|            | 4.3.12 module:get_port              |    |
|            | 4.3.13 module:add_module            |    |
|            | 4.3.14 module:get_module            |    |
|            | 4.3.15 module:add code              |    |
|            | 4.3.16 module find                  | 80 |
|            | 4.3.17 module.is_valid              | 81 |
|            | 4.3.18 module.apply_code            |    |
|            | 4.3.19 module_i:set_param           |    |
|            | 4.3.20 module_i:get_param           | 84 |
|            | 4.3.21 module_i:set_port            | 85 |
|            | 4.3.22 module_i:get_port            | 86 |
|            | 4.3.23 module_i.is_valid            |    |
| 5.         | APPENDIX                            | 88 |
| <b>J</b> . | 5.1 Appendix : test_definition.lua  |    |
|            | u.   Appendix : test_delinition.ida |    |

## **List of Tables**

| Table                                          | Title | Page |
|------------------------------------------------|-------|------|
| Table 3-1. Macro function summary              |       | 23   |
| Table 3-2. List of predefined vfunctions       |       |      |
| Table 4-1. clock object summary                |       |      |
| Table 4-2. interface object summary            |       |      |
| Table 4-3. interface i object summary          |       |      |
| Table 4-4. module object summary               |       |      |
| Table 4-5. module i(sub module) object summary |       |      |

## **List of Figures**

| Figure                               | Title | Page |
|--------------------------------------|-------|------|
| Figure 2-1. Step #1 Hierarchy Diagra | m     | 12   |
|                                      | m     |      |
|                                      | m     |      |

## **List of Terms**

| List      | Description                                                                                                                              |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------|
| TestDrive | TestDrive Profiling Master ( <a href="https://testdrive-profiling-master.github.io/">https://testdrive-profiling-master.github.io/</a> ) |
| Lua       | Lua script language (Wiki, Homepage)                                                                                                     |

UserGuide BSD License.

### 1. Introduction

"Performance can't beat convenience."

When designing with the verilog of a large-scale project, one of the most problematic parts is that it takes a lot of time and effort to configure the control path between modules. In addition, if you need to modify some of the control paths of a design that has been completed with a lot of time and effort, or if you need a major change, you have to be more careful. Otherwise, it may introduce new errors or require the same amount of effort as recreating the design from scratch.

Therefore, I made a verigen tool that creates control paths with minimal design. This tool makes it easy and quick to build a control path programmatically with minimal effort, and has a function that allows you to check the structured control path as a design hierarchy at a glance. It can also allow for faster design changes and sharing of designs with other team members.

NOTE: If you have a new feature to suggest, or find improvements or bugs, please contact me (clonextop@gmail.com).

#### 1.1 Main functions

verigen was created using codegen of TestDrive Profiling Master. This tool runs code written in lua, builds a verilog design, includes all codegen functionality, and generates the following files.

- Automatically generate verilog design (.sv, .f)
- Automatic creation of constraint (.xdc)
- Automatic creation of hierarchy diagram (.svg), HTML highlited source code (.html)

#### 1.2 Verilog automation creation process

Creating a project through verigen proceeds in the following steps.

- 1. Write Lua scripts
  - 1). Create modules
  - 2). Connect modules
  - 3). Declaring parameters and interface to the module (option)
- 2. Write verilog codes
  - 1). Declaring parameters and interface to the module (option)
  - 2). Write Verilog additional code or write Lua mixed code
- 3. Run verigen to generate verilog code

#### 1.3 How to run

To run verigen, run the following command.

#### 1 Introduction

output\_path output path default : ./output

NOTE: Command: verigen INPUT\_LUA\_FILE OUTPUT\_PATH

A Lua script corresponding to INPUT\_LUA\_FILE is created and executed. If OUTPUT\_PATH is not specified, the result is created in the default "./output" folder.

#### 1.4 license grant

The source implemented in verigen complies with the BSD license, and the user's individual scripts used to create verilog or derivative works such as verilog are wholly owned by the user.

UserGuide BSD License.

### 2. Fast follow

This section is a quick, example-oriented explanation. To check the class and method in dictionary format, see the next step 'Class and Method'.

The example below describes the implementation at <u>github example</u>. You can achieve the same result by running do test.bat in that folder.

#### 2.1 Step #1 : Creation of module

Generate and run the script code as shown below.

#### [main.lua file]

```
1: -- modules
2: core_wrapper = module:new("test_wrapper") -- top
3: core = {}
4: core.top = module:new("test_core")
5: core.slave_ctrl = module:new("slave_ctrl")
6: core.core_if = module:new("core_if")
7: core.core_ex = module:new("core_ex")
8: core.core_wb = module:new("core_wb")
9: core.mem_ctrl = module:new("mem_ctrl")
10: core.reg_ctrl = module:new("reg_ctrl")
11:
12: -- make code
13: core_wrapper:make_code()
```

It was created by putting the core wrapper module and core related modules in lua table.

#### [Run command]

```
> verigen main.lua
*I: Build TOP design : test_wrapper.sv
*W: Empty port module : 'test_wrapper' module
*I: Build contraint : test_wrapper_constraint.xdc
*I: Make design hierarchy : test_wrapper_hierarchy.svg
*I: Make common defines : test_wrapper_defines.vh
*I: Make design file list : test_wrapper.f
```

Briefly declare the modules to be used through the module:new method. And the last module:make\_code method generates the actual verilog code, constraint files and hierarchy diagram.

Currently, we have declared several modules, but since there is no module associated with core\_wrapper, verilog design only creates one test\_wrapper.sv file.

The rest of the test wrapper constraint.xdc, test wrapper defines.vh, etc. are empty.

#### [Result : test\_wrapper.sv]

```
`include "test_wrapper_defines.vh"

module test_wrapper ();
```

UserGuide BSD License.

#### endmodule

The resulting design is literally an empty module file, and the hierarchy diagram(test\_wrapper\_hierarchy.svg) is also empty.

#### [Result : test\_wrapper\_hierarchy.svg]



Figure 2-1. Step #1 Hierarchy Diagram

#### 2.2 Step #2: module interconnections

Modify and run the Lua script as shown below.

#### [main.lua file]

```
1: RunScript("test_definition.lua")
3: -- modules
4: core_wrapper = module:new("test_wrapper")
                                                       -- top
5: core
                 = {}
6: core.top = module:new("test_core")
7: core.slave_ctrl = module:new("slave_ctrl")
8: core.core_if = module:new("core_if")
9: core.core_ex = module:new("core_ex")
10: core.core_wb = module:new("core_wb")
11: core.mem_ctrl = module:new("mem_ctrl")
12: core.reg_ctrl = module:new("reg_ctrl")
13: core.busy_ctrl = module:new("busy_ctrl")
14:
15: -- module connection
16: core_wrapper:add_module(core.mem_ctrl)
17: core_wrapper:add_module(core.slave_ctrl)
18:
19: core.top:add_module(core.core_if)
20: core.top:add_module(core.core_ex)
21: core.top:add_module(core.core_wb)
22:
23: core.slave_ctrl:add_module(core.reg_ctrl)
25: -- multi-core genration
26: core.inst = \{\}
27: for i = 1, config.core_size, 1 do
      core.inst[i] = core_wrapper:add_module(core.top)
```

```
29: end
30:
31: -- make code
32: core_wrapper:make_code()
```

Now, in the added lines 15 to 29, each module is connected with the module:add\_module function, and four modules are also created and connected to the core. Include "Appendix: test\_definition.lua" at the top (line #1) to use the predefined config.core size value.

#### [Run command]

```
> verigen main.lua
*I: Build sub design : mem_ctrl.sv
*W: Empty port module : 'mem ctrl' module
*I: Build sub design : reg_ctrl.sv
*W: Empty port module : 'reg_ctrl' module
*I: Build sub design : slave_ctrl.sv
*W: Empty port module : 'slave_ctrl' module
*I: Build sub design : core ex.sv
*W: Empty port module : 'core_ex' module
*I: Build sub design : core_if.sv
*W: Empty port module : 'core_if' module
*I: Build sub design : core_wb.sv
*W: Empty port module : 'core_wb' module
*I: Build sub design : test_core.sv
*W: Empty port module : 'test_core' module
*I: Build TOP design : test_wrapper.sv
*W: Empty port module : 'test_wrapper' module
*I: Build contraint : test_wrapper_constraint.xdc
*I: Make common defines: test_wrapper_defines.vh
*I: Make design hierarchy: test_wrapper_hierarchy.svg
*I: Make design file list : test_wrapper.f
```

In the execution result, other files included in addition to the test\_wrapper.sv file are automatically created, and if you look at the top design, only the module is added and the port is not described, so a warning is generated, but each submodule is automatically You can see what has been added.

#### [Result: test\_wrapper.sv]

```
`include "test_wrapper_defines.vh"

module test_wrapper ();

/* no ports module. (commented out for DRC.)

mem_ctrl mem_ctrl (
);*/

/* no ports module. (commented out for DRC.)

slave_ctrl slave_ctrl (
);*/

/* no ports module. (commented out for DRC.)

test_core test_core_0 (
);*/
```

```
/* no ports module. (commented out for DRC.)
test_core test_core_1 (
);*/

/* no ports module. (commented out for DRC.)
test_core test_core_2 (
);*/

/* no ports module. (commented out for DRC.)
test_core test_core_3 (
);*/
endmodule
```

**NOTE:** In the code above, since the submodule has no input/output at all, it is commented out to avoid 'DRC (Design Rule Check)' errors.

#### [Result : test\_wrapper\_hierarchy.svg]



Figure 2-2. Step #2 Hierarchy Diagram

In addition to test\_wrapper.sv, other slave\_ctrl.sv and test\_core.sv also contain submodules, as seen in Figure 2-2.

#### 2.3 Step #3: Verilog code insertion

Modify and run the Lua script as shown below.

#### [main.lua file]

```
1: RunScript("test_definition.lua")
2:
3: -- modules
4: core_wrapper = module:new("test_wrapper") -- top
5: core = {}
6: core.top = module:new("test_core")
7: core.slave_ctrl = module:new("slave_ctrl")
8: core.core_if = module:new("core_if")
```

```
9: core.core ex
                    = module:new("core_ex")
                    = module:new("core_wb")
10: core.core_wb
11: core.mem_ctrl = module:new("mem_ctrl")
                   = module:new("reg_ctrl")
12: core.reg_ctrl
13: core.busy_ctrl = module:new("busy_ctrl")
14:
15: -- add master bus
16: bus.maxi4:set_param("DATA_WIDTH", 512)
17: bus.maxi4:set_param("ADDR_WIDTH", 36)
18: bus.maxi4:set_prefix("M#")
19:
20: -- add busy
                    = new_signal("core_busy")
21: core_busy
22:
23: -- module connection
24: core_wrapper:add_module(core.mem_ctrl)
25: core_wrapper:add_module(core.slave_ctrl)
27: core.top:add_module(core.core_if)
28: core.top:add_module(core.core_ex)
29: core.top:add_module(core.core wb)
30:
31: core.slave_ctrl:add_module(core.reg_ctrl)
32:
33: -- multi-core genration
34: core.inst = \{\}
35: for i = 1, config.core_size, 1 do
      core.inst[i] = core_wrapper:add_module(core.top)
37: end
38:
39: -- add verilog codes
40: for entry in Ifs.dir("src/") do
       local s = String(entry)
41:
        if s:CompareBack(".sv") then
43:
            module.apply_code("src/" .. entry)
44:
        end
45: end
46:
47: -- make code
48: core_wrapper:make_code()
```

The code added to the existing Lua script is line #15~21 and #39~45.

The first changes the bit width of data and address of axi4, and the second one adds the two files below through the module.apply\_code() function to all \*.sv files in the subfolder "./src".

#### [src/\_\_wrapper.sv]

```
5: :core if
6: $set_param("CORE_ID", "0")
7: $add_interface(core_i.inst, "if_inst", "m")
8: $add_interface(core_busy, nil, "m")
9:
10: assign core_busy = 1'b0;
11:
12:
13: :--
14: :core ex
15: $add_interface(core_i.inst, "if_inst", "s")
16: $add_interface(core_i.inst, "ex_inst", "m")
17:
18:
19: :----
20: :core wb
21: $add_interface(core_i.inst, "ex_inst", "s")
```

**NOTE:** As above, by declaring 'modport' paired with the name of the same type of interface through the \$add\_interface() function, the same interfaces declared in two different modules are automatically connected.

#### [src/ wrapper.sv]

```
1: :----
 2: :test_wrapper
            $RANGE(config.core_size) core_busy_all;
3: wire
4:
5: ${
 6:
        for i = 1, config.core_size, 1 do
           core.inst[i]:set_param("CORE_ID", i)
 7:
           core.inst[i]:set_port("core_busy", "core_busy_all[" .. (i-1) .. "]")
8:
9:
        end
10:
        __m:get_module("slave_ctrl"):set_port("core_busy", "|core_busy_all")
11:
12: }
13:
14: :----
15: :slave_ctrl
16: $set_param("BASE_ADDR", "32'h10000000")
17: $add_interface(bus.apb, "s_apb", "m")
18: $add_interface(bus.apb, "s_apb_0", "m")
19:
20: :----
21: :mem ctrl
22: $add_interface(bus.maxi4, "maxi", "m")
23:
24: :----
25: :reg_ctrl
26: $add_interface(core_busy, nil, "s")
```

**NOTE:** You can connect directly through the "module\_i:set\_param()" and "module\_i:set\_port()" functions without automatically connecting interfaces or parameters.

After declaring ":>module\_name>" in the added .sv file, the file can be described using both Verilog and Lua grammars. You can either declare I/O via @set\_param() function and @module:add\_interface() function, respectively, or use Verilog syntax directly.

In addition, if you want to directly access a Lua variable or function, you can access it with \$(\*), or you can execute a Lua statement by describing it with \${\*}.

#### [Result : test\_wrapper\_hierarchy.svg]



Figure 2-3. Step #3 Hierarchy Diagram

Below is the output of the top design.

#### [Final result : test\_wrapper.sv]

```
`include "test_wrapper_defines.vh"
module test_wrapper #(
    parameter BASE_ADDR
                                = 32 h10000000
    // clock & reset
                                              // AXI clock
    input
                                ACLK,
                                CLK,
                                              // main clock
    input
                                PCLK,
                                              // APB clock
    input
                                              // reset of 'PCLK' (active low)
    input
                                PRESETn,
                                              // default global reset (active low)
    input
                                nRST,
    // maxi
    input
                                M_AWREADY,
    input
                                M_WREADY,
    input
                                M_BVALID,
           [1:0]
    input
                                M_BRESP,
    input
           [3:0]
                                M_BID,
    input
                                M ARREADY,
    input
                                M_RVALID,
           [511:0]
                                M_RDATA,
    input
           [1:0]
    input
                                M_RRESP,
    input [3:0]
                                M_RID,
```

```
input [3:0]
                                M_ARQOS,
    input [3:0]
                                M_ARREGION,
                                M_AWVALID,
    output
                                M_AWADDR,
    output [35:0]
    output [2:0]
                                M_AWSIZE,
    output [1:0]
                                M_AWBURST,
    output [3:0]
                                M_AWCACHE,
    output [2:0]
                                M_AWPROT,
    output [3:0]
                                M_AWID,
    output [7:0]
                                M AWLEN,
    output
                                M_AWLOCK,
                                M_WVALID,
    output
    output
                                M_WLAST,
    output [511:0]
                                M_WDATA,
    output [63:0]
                                M_WSTRB,
    output [3:0]
                                M_WID,
    output
                                M_BREADY,
    output
                                M_ARVALID,
    output [35:0]
                                M_ARADDR,
    output [2:0]
                                M_ARSIZE,
    output [1:0]
                                M_ARBURST,
    output [3:0]
                                M_ARCACHE,
    output [2:0]
                                M_ARPROT,
    output [3:0]
                                M_ARID,
    output [7:0]
                                M_ARLEN,
                                M_ARLOCK,
    output
                                M_RREADY,
    output
    output
                                M_RLAST,
    output [3:0]
                                M_AWQOS,
    output [3:0]
                                M_AWREGION,
    // s_apb
                                SO_PREADY,
    input
    input [31:0]
                                SO_PRDATA,
                                SO_PSLVERR,
    input
    output [1:0]
                                SO_PSEL,
    output
                                SO_PENABLE,
    output
                                SO_PWRITE,
    output [15:0]
                                SO_PADDR,
    output [31:0]
                                SO_PWDATA,
    // s_apb_0
    input
                                S1_PREADY,
    input [31:0]
                                S1_PRDATA,
                                S1_PSLVERR,
    input
    output [1:0]
                                S1_PSEL,
    output
                                S1_PENABLE,
    output
                                S1_PWRITE,
    output [15:0]
                                S1_PADDR,
    output [31:0]
                                S1_PWDATA
);
```

```
// synopsys template
// interface : maxi
i_maxi4
                       maxi();
                               = M_AWREADY;
assign maxi.AWREADY
assign maxi.WREADY
                               = M_WREADY;
                               = M_BVALID;
assign maxi.BVALID
assign maxi.BRESP
                               = M BRESP;
assign maxi.BID
                               = M_BID;
assign maxi.ARREADY
                               = M_ARREADY;
assign maxi.RVALID
                               = M RVALID;
assign maxi.RDATA
                               = M_RDATA;
assign maxi.RRESP
                               = M_RRESP;
assign maxi.RID
                               = M_RID;
assign maxi.ARQOS
                               = M_ARQOS;
assign maxi.ARREGION
                               = M_ARREGION;
assign M_AWVALID
                               = maxi.AWVALID;
assign M_AWADDR
                               = maxi.AWADDR;
assign M_AWSIZE
                               = maxi.AWSIZE;
assign M_AWBURST
                               = maxi.AWBURST;
assign M_AWCACHE
                               = maxi.AWCACHE;
assign M AWPROT
                               = maxi.AWPROT;
assign M_AWID
                               = maxi.AWID;
assign M_AWLEN
                               = maxi.AWLEN;
assign M_AWLOCK
                                = maxi.AWLOCK;
                               = maxi.WVALID;
assign M_WVALID
assign M_WLAST
                               = maxi.WLAST;
assign M_WDATA
                                = maxi.WDATA;
assign M_WSTRB
                               = maxi.WSTRB;
assign M_WID
                               = maxi.WID;
assign M_BREADY
                               = maxi.BREADY;
assign M_ARVALID
                               = maxi.ARVALID;
assign M_ARADDR
                               = maxi.ARADDR;
assign M_ARSIZE
                               = maxi.ARSIZE;
assign M_ARBURST
                               = maxi.ARBURST;
assign M_ARCACHE
                               = maxi.ARCACHE;
                               = maxi.ARPROT;
assign M_ARPROT
assign M_ARID
                               = maxi.ARID;
assign M_ARLEN
                               = maxi.ARLEN;
assign M_ARLOCK
                               = maxi.ARLOCK;
assign M_RREADY
                               = maxi.RREADY;
assign M_RLAST
                               = maxi.RLAST;
assign M_AWQOS
                               = maxi.AWQOS;
assign M_AWREGION
                               = maxi.AWREGION;
// interface : s_apb
i_apb
                       s_apb();
assign s_apb.PREADY
                               = SO_PREADY;
assign s_apb.PRDATA
                               = SO PRDATA;
                               = SO_PSLVERR;
assign s_apb.PSLVERR
assign SO_PSEL
                               = s_apb.PSEL;
assign S0_PENABLE
                               = s_apb.PENABLE;
assign SO_PWRITE
                                = s_apb.PWRITE;
```

```
assign SO_PADDR
                                 = s_apb.PADDR;
assign SO_PWDATA
                                 = s_apb.PWDATA;
// interface : s_apb_0
i_apb
                        s_apb_0();
assign s_apb_0.PREADY
                                = S1_PREADY;
                                = S1_PRDATA;
assign s_apb_0.PRDATA
                                = S1_PSLVERR;
assign s_apb_0.PSLVERR
assign S1_PSEL
                                = s_apb_0.PSEL;
assign S1_PENABLE
                                = s_apb_0.PENABLE;
assign S1_PWRITE
                                = s_apb_0.PWRITE;
assign S1_PADDR
                                = s_apb_0.PADDR;
assign S1_PWDATA
                                = s_apb_0.PWDATA;
mem_ctrl mem_ctrl (
    . ACLK
                          (ACLK),
    .nRST
                          (nRST),
                          (maxi)
    .maxi
);
slave_ctrl #(
    .BASE_ADDR
                          (BASE_ADDR)
) slave_ctrl (
    . PCLK
                          (PCLK),
    . PRESETn
                          (PRESETn),
    .core_busy
                          (|core_busy_all),
                          (s_apb),
    .s_apb
                          (s_apb_0)
    .s_apb_0
);
test_core #(
    .CORE_ID
                          (1)
) test_core_0 (
    . CLK
                          (CLK),
    .nRST
                          (nRST),
                          (core_busy_all[0])
    .core_busy
);
test_core #(
                          (2)
    .CORE_ID
) test_core_1 (
    .CLK
                          (CLK),
    . nRST
                          (nRST),
                          (core_busy_all[1])
    .core_busy
);
test_core #(
                          (3)
    .CORE_ID
) test_core_2 (
    . CLK
                          (CLK),
    . nRST
                          (nRST),
                          (core_busy_all[2])
    .core_busy
);
```

#### [Final result : test\_core.sv]

```
`include "test_wrapper_defines.vh"
module test_core #(
    parameter CORE_ID
                               = 0
) (
    // clock & reset
                                           // main clock
                               CLK,
    input
    input
                               nRST,
                                           // default global reset (active low)
    // core_busy
   output logic
                             core_busy
);
// synopsys template
// interface : ex_inst
i_inst
                       ex_inst();
// interface : if_inst
i_inst
                       if_inst();
core_ex core_ex (
   . CLK
                         (CLK),
    .nRST
                         (nRST),
                         (ex_inst),
   .ex_inst
    .if_inst
                         (if_inst)
);
core_if #(
    .CORE_ID
                         (CORE_ID)
) core_if (
    .CLK
                         (CLK),
    .nRST
                         (nRST),
                         (core_busy),
    .core_busy
   .if_inst
                         (if_inst)
);
```

#### 2 Fast follow

```
core_wb core_wb (
                         (CLK),
   . CLK
                         (nRST),
   . nRST
                         (ex_inst)
   .ex_inst
endmodule
```

BSD License. UserGuide 22 v1.02

## **Macro functions**

Provides macro functions useful for organizing your code.

Table 3-1. Macro function summary

| Macro     | Type     | Description                      |
|-----------|----------|----------------------------------|
| _V        | function | string expansion manipulation    |
| vfunction | function | Declaring a function for verilog |

The functions below are predefined functions as vfunction available in verilog. It can be used as "\$function\_name(~)".

Table 3-2. List of predefined vfunctions

| vfunction       | Туре     | Description                          |
|-----------------|----------|--------------------------------------|
| \$LOG2          | function | log2(X) function                     |
| \$RANGE         | function | verilog bitwidth range template      |
| \$DEMUX_BY_EN   | function | demux design template                |
| \$MULTICYCLE    | function | multicycle design template           |
| \$add_clock     | function | Refer to 4.3.10. module:add_clock    |
| \$add_interface | function | Refer to 4.3.9. module:add_interface |
| \$set_param     | function | Refer to 4.3.7. module:set_param     |
| \$set_inception | function | Refer to 4.3.3. module:set_inception |
| \$set_author    | function | Refer to 4.3.6. module:set_author    |
| \$_V            | function | Refer to 3.1V macro                  |

UserGuide **BSD** License.

### 3.1 \_V macro

| Type         | Description                                                                                                                                                                                                                     |  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Prototype    | function _V(s, [start], [end], [step])                                                                                                                                                                                          |  |
| Return value | string                                                                                                                                                                                                                          |  |
|              | Extends a statement by incrementing it by a step from start to end.                                                                                                                                                             |  |
| Remarks      | If there is a part of the statement implemented with \$(), only that part is expanded. If there is none, the entire sentence is expanded, and the '#' character in the sentence is assigned a repeated value from start to end. |  |
| start        | start value                                                                                                                                                                                                                     |  |
| end          | end value (If omitted, it is treated the same as the start value.)                                                                                                                                                              |  |
| step         | increase value (If omitted, it increases or decreases by 1 or -1. according to the sign of the end-start value.)                                                                                                                |  |

#### ex) \_V macro example

```
print(_V("assign A = {$(B[#],)};", 0, 3))
 [Result]
```

**assign**  $A = \{B[0], B[1], B[2], B[3]\};$ 

UserGuide **BSD** License.

#### 3.2 vfunction macro

| Type         | Description                                                         |
|--------------|---------------------------------------------------------------------|
| Prototype    | function vfunction(name, func)                                      |
| Return value | -                                                                   |
| Remarks      | You can call lua functions from within verilog with "\$function()". |
| name         | Function name to use within verilog                                 |
| func         | lua function to use in verilog                                      |

**NOTE:** By default, the "\_V" macro is declared as vfunction, so you can use the \$\_V(...) function equivalently within verilog.

ex) vfunction macro example

```
vfunction("RANGE", function(size,step)
    return ("[" .. ((size*(step+1))-1) .. ":" .. (size*step) .. "]")
end)
[Source input]
wire
        $RANGE(32,1)
                        Τ;
[Result]
wire
        [63:32]
```

UserGuide **BSD** License.

25

#### 3.3 \$LOG2 function

| Type         | Description                                                                                                                                                         |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Prototype    | \$LOG2(val, [bOverflow])                                                                                                                                            |
| Return value | number                                                                                                                                                              |
| Remarks      | Returns log2(val) value.                                                                                                                                            |
| val          | log2 input value                                                                                                                                                    |
| bOverflow    | val must be an integer equal to 2^N .  If not, return an error.  Set this value to true to force rounding up on the resulting value.  If omitted, false is assumed. |

#### ex) \$LOG2 example

```
val_a = 16
 [Source input]
localparam
                         = $L0G2(val_a);
                 BITS
 [Result]
                         = 4;
localparam
                 BITS
```

#### 3.4 \$DEMUX\_BY\_EN function

| Type          | Description                                                       |
|---------------|-------------------------------------------------------------------|
| Prototype     | \$DEMUX_BY_EN(width, channel_count, en, data_in, data_out)        |
| Return value  | string                                                            |
| Remarks       | Implement demux using demux_by_enable module.                     |
| width         | bitwidth per data                                                 |
| channel_count | Number of input channels                                          |
| en            | input enable signal (string)                                      |
| data_in       | Input data (as many as the total number of channel_count, string) |
| data_out      | output data (string)                                              |

#### ex) \$DEMUX\_BY\_EN example

#### [Source input]

```
wire
     [31:0]
                   a,b,c,d;
wire
       [3:0]
                   en;
       [31:0]
wire
                   odata;
$DEMUX_BY_EN(32, 4, "en", "{a,b,c,d}", "odata")
```

#### [Result]

```
wire
     [31:0]
                    a,b,c,d;
wire
        [3:0]
                    en;
wire
        [31:0]
                    odata;
demux_by_enable #(
    .WIDTH
                        (32),
    . CHANNELS
                        (4),
    .TRISTATE
                        (1)
) demux_en_pc (
    .EN_BUS
                        (en),
    .DIN_BUS
                        ({a,b,c,d}),
    .DOUT
                        (odata)
);
```

#### 3.5 \$MULTICYCLE function

| Type                 | Description                                                                                                                                           |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Prototype            | \$MULTICYCLE(module_inst_name, if_name, cycle_count, [instance_count], [clk])                                                                         |
| Return value         | string                                                                                                                                                |
| Remarks              | Multicycle Implementation Using the template "MultiCyclePath" module or "MultiCyclePathEx", a module with one interface is implemented as multicycle. |
| module_inst_n<br>ame | Module name included as a child of the current module                                                                                                 |
| if_name              | Specifies the interface instance name corresponding to the module of module_inst_name.                                                                |
| cycle_count          | cycle count (2 ≤ cycle_count ≤ 12)                                                                                                                    |
| instance_coun<br>t   | Number of instances of submodules (1 ≤ instance_count ≤ cycle_count)  If omitted, it is regarded as the same number as cycle_count.                   |
| clk                  | Clock to use for multicycle implementation  If omitted, the default clock is used. (see clock:set_default() function)                                 |

#### ex) \$MULTICYCLE example

[Source input]

```
$MULTICYCLE("MTSP_Synchronize", "mtsp_sync", 2, 1)
```

[Result]

```
genvar i;
// multicycle design for MTSP_Synchronize
i_mtsp_sync mtsp_sync();
wire
        mtsp_sync_ie, mtsp_sync_oe, mtsp_sync_iready;
generate
wire
        [7:0]
                pipe_i;
        [1:0]
wire
                pipe_o;
wire
        [1:0]
                __o;
MultiCyclePathEx #(
    . IWIDTH
                (8),
    .OWIDTH
                (2),
    . CYCLE
                (2),
    . COUNT
                (1)
) multi_pipe (
    .CLK
                (MCLK),
    .nRST
                (nRST),
    . IE
                (mtsp_sync_ie),
    . IDATA
                ({mtsp_sync.sync, mtsp_sync.eop}),
    . IREADY
                ({mtsp_sync_iready}),
    .PIPE_I
                (pipe_i),
                (pipe_o),
    .PIPE_0
    .0E
                (mtsp_sync_oe),
    . ODATA
                 (__o)
);
```

```
assign {mtsp_sync.awake, mtsp_sync.done} = __o;
for(i=0; i<1; i=i+1) begin</pre>
   i_mtsp_sync __temp;
   assign {__temp.sync, __temp.eop} = pipe_i[`BUS_RANGE(8, i)];
   assign pipe_o[`BUS_RANGE(2,i)] = {__temp.awake, __temp.done};
   MTSP_Synchronize MTSP_Synchronize (
                     (<u>__temp</u>)
       .mtsp_sync
   );
end
endgenerate
```

## 4. Class and Method

There are three object types as shown below.

- clock
  - You can generate clocks and assign them to interfaces. When the corresponding interface is used, the automatically assigned clock and reset matching the clock are declared to the port. If reset is not declared, the default reset nRST signal is automatically generated.
- interface
  - Create an interface to be used in the module. Interfaces can be created by inheriting from other interfaces. Instances requested by add\_interface to a module can only call interface\_i:\* functions.
- module
  - You can create a module, include other submodules via the module:add\_module function, or call module:add\_interface to create an interface instance.

#### 4.1 clock

Generates or manages clocks to be assigned to interfaces. The assigned clock is automatically declared according to the port of the module when the corresponding interface is used.

In addition, the speed of the corresponding clock is defined in the contraint, and false\_path is automatically designated for registers between heterogeneous clocks and reset set for the clock.

Table 4-1. clock object summary

| Member       | Туре     | Description           |
|--------------|----------|-----------------------|
| .name        | string   | clock 이름              |
| :new         | function | clock 생성              |
| :set_reset   | function | clock에 reset 설정       |
| :get_reset   | function | clock에 할당된 reset 을 반환 |
| :set_speed   | function | clock에 동작속도 설정        |
| :set_default | function | 현 클럭을 기본 클럭으로 설정한다.   |
| .find        | function | clock 찾기              |
| .is_valid    | function | clock 여부 확인           |
| .get_default | function | 기본 클럭을 얻는다.           |

#### 4.1.1 clock:new

| 구분    | 표현식                              |
|-------|----------------------------------|
| 함수 원형 | function clock:new(name, [desc]) |
| 반환값   | clock                            |
| 설명    | name 이름을 가지는 clock을 생성합니다.       |
| name  | clock 이름.                        |
| desc  | clock 설명, 주석에 사용된다.(생략 가능)       |

#### ex) creation example

#### 4.1.2 clock:set\_reset

| 구분    | 표현식                                                                                             |
|-------|-------------------------------------------------------------------------------------------------|
| 함수 원형 | function clock:set_reset(name)                                                                  |
| 반환값   | -                                                                                               |
| 설명    | clock에 name 이름의 reset 을 생성합니다.<br>이 함수를 사용하여 reset 을 생성하지 않을 경우, 기본 리셋 'nRST' 신호가 자동으로<br>사용된다. |
| name  | reset 이름. (active low)                                                                          |

#### ex) Example of specifying reset

#### 4.1.3 clock:get\_reset

| 구분    | 표현식                                 |
|-------|-------------------------------------|
| 함수 원형 | function clock:get_reset()          |
| 반환값   | string                              |
| 설명    | clock에 할당된 reset을 반환한다.             |
|       | 할당된 reset 이 없다면, 기본 reset 신호가 반환된다. |

UserGuide **BSD** License. 34 v1.02

#### 4.1.4 clock:set\_speed

| 구분    | 표현식                                          |
|-------|----------------------------------------------|
| 함수 원형 | function clock:set_speed(mhz)                |
| 반환값   | -                                            |
| 설명    | clock의 동작속도를 지정합니다.                          |
|       | 이 함수를 사용하여 지정하지 않을 경우, 기본 클럭 100MHz 가 설정됩니다. |
| mhz   | 지정할 동작 속도 값. (MHz 단위)                        |

#### ex) Example of motion speed designation

#### 4.1.5 clock:set\_default

| 구분    | 표현식                                                            |
|-------|----------------------------------------------------------------|
| 함수 원형 | function clock:set_default()                                   |
| 반환값   | -                                                              |
|       | 현재 클럭을 기본 클럭으로 설정한다.                                           |
| 설명    | 처음 생성하는 클럭을 기본 클럭으로 설정하며, 별도로 특정 클럭을 명시적으로 클럭으로<br>설정할 때 사용한다. |

#### ex) Basic clock setting example

```
aclock = clock:new("MCLK")
aclock:set_default()
```

UserGuide **BSD** License.

### 4.1.6 clock.find

| 구분    | 표현식                                    |  |
|-------|----------------------------------------|--|
| 함수 원형 | function clock.find(name)              |  |
| 반환값   | clock                                  |  |
| 설명    | clock을 찾습니다.<br>찾지 못할 경우 nil 값을 반환합니다. |  |
| name  | 찾을 clock 이름.                           |  |

# ex) clock find example

# 4.1.7 clock.is\_valid

| 구분    | 표현식                          |
|-------|------------------------------|
| 함수 원형 | function clock.is_valid(obj) |
| 반환값   | boolean                      |
| 설명    | clock 객체가 맞는지 확인합니다.         |
| obj   | 확인할 clock 객체.                |

# ex) Example of checking the clock object

```
aclock = clock:new("ACLK")
if clock.is_valid(aclock) then
   LOGI("aclock is clock object.")
                                      -- clock object is correct.
end
```

UserGuide **BSD** License.

# 4.1.8 clock.get\_default

| 구분    | 표현식                          |
|-------|------------------------------|
| 함수 원형 | function clock.get_default() |
| 반환값   | clock                        |
| 설명    | 기본 클럭을 반환한다.                 |

UserGuide **BSD** License. 39 v1.02

#### 4.2 interface

The interface object works identically to system verilog's interface technology. If you look at the interface syntax of systemverilog, it is as follows.

#### [systemverilog interface 선언]

```
interface my_intface;
   logic
   logic
         [3:0] b;
   // modport example
   modport s (input a, output b); // slave modport
   modport m (input a, input b);
                                      // master modport
endinterface
```

NOTE: A detailed description of the systemverilog interface can be found in external links. See systemverilog modport description.

Among them, port configuration is attempted using the modport function that can be synthesized, and it is largely divided into the interface\_i object created through add\_interface to the interface object, which is the basic object, and the module object.

| Member        | Туре     | Description                |
|---------------|----------|----------------------------|
| .name         | string   | 인테페이스 이름                   |
| :new          | function | 인테페이스 생성                   |
| new_signal    | function | 단일 시그널 형태의 인터페이스 생성        |
| .find         | function | 인터페이스 찾기                   |
| .is_valid     | function | 인터페이스 여부 확인                |
| :set_clock    | function | 클럭 할당                      |
| :get_clock    | function | 클럭 얻기                      |
| :set_signal   | function | 신호 추가                      |
| :signal_count | function | 신호 개수 얻기                   |
| :set_param    | function | parameter 추가               |
| :get_param    | function | parameter 검색               |
| :set_modport  | function | modport 설정                 |
| :add_modport  | function | modport 에 추가               |
| :get_modport  | function | modport 찾기                 |
| :set_prefix   | function | port 출력시 prefix 지정         |
| :set_bared    | function | interface 를 signal로 풀어서 적용 |

UserGuide **BSD** License.

v1.02

40

Table 4-3. interface\_i object summary

| :set_port   | function | 인스턴스를 port로 지정  |
|-------------|----------|-----------------|
| :set_desc   | function | 인스턴스의 설명 추가     |
| :set_prefix | function | 인스턴스의 prefix 지정 |
| :get_prefix | function | 인스턴스의 prefix 얻기 |

#### 4.2.1 interface:new

| 구분    | 표현식                                           |  |  |
|-------|-----------------------------------------------|--|--|
| 함수 원형 | function interface:new(name)                  |  |  |
| 반환값   | interface                                     |  |  |
| 설명    | name 이름을 가지는 interface를 생성합니다.                |  |  |
|       | 생성할 때 기본 prefix 는 ('name 대문자' + '#') 로 지정됩니다. |  |  |
| name  | interface 이름.                                 |  |  |

# ex) Example of interface creation

```
i_apb = interface:new("APB") -- APB interface creation
i_apb:set_signal("RARDDR", 32)
```

#### 4.2.2 new\_signal

| 구분    | 표현식                                  |  |
|-------|--------------------------------------|--|
| 함수 원형 | function new_signal(name, [width])   |  |
| 반환값   | interface                            |  |
| 설명    | name 이름을 가지는 bared interface를 생성합니다. |  |
| name  | signal 이름.                           |  |
| width | 시그널 bitwidth. 생략할 경우 1로 지정됩니다.       |  |

The actual implementation inside creates a bared interface as shown below, setting modport 's' to input and modport 'm' to output. Also, because it is a bared interface, it is not even logged as an interface in the [top\_module]\_include.vh header.

```
function new_signal(name, width)
           signal = interface:new(name)
    if width == nil then
        width = 1
    end
    signal:set_param("WIDTH", width)
    signal:set_signal(name, "WIDTH")
    signal:set_modport("s", {["input"] = {name}})
signal:set_modport("m", {["output"] = {name}})
    signal:set_prefix() -- none prefix
                              -- bared signals
    signal:set_bared()
    return signal
end
```

ex) signal creation example

```
= new_signal("BUSY_ALL", 4)
s_BUSY
```

UserGuide BSD License.

v1.02

43

#### 4.2.3 interface.find

| 구분     | 표현식                           |
|--------|-------------------------------|
| 함수 원형  | function interface.find(name) |
| 반환값    | interface                     |
| <br>설명 | 생성된 interface 를 찾습니다.         |
| name   | 찾을 interface 이름               |

# ex) Example of finding an interface

```
i_APB = interface:new("APB")

if interface.find("APB") ~= nil then
    LOGI("APB interface is existed.")
end
```

# 4.2.4 interface.is\_valid

| 구분    | 표현식                              |  |
|-------|----------------------------------|--|
| 함수 원형 | function interface.is_valid(obj) |  |
| 반환값   | boolean                          |  |
| 설명    | interface 객체가 맞는지 확인합니다.         |  |
| obj   | 확인할 클럭 객체.                       |  |

# ex) Example of checking interface object

```
i_APB = interface:new("APB")
if interface.is_valid(i_APB) then
   LOGI("i_APB is interface object.")
                                           -- interface object is correct.
end
```

UserGuide **BSD** License.

### 4.2.5 interface:set\_clock

| 구분    | 표현식                               |
|-------|-----------------------------------|
| 함수 원형 | function interface:set_clock(clk) |
| 반환값   | -                                 |
| 설명    | interface에 clock을 지정합니다.          |
| clk   | clock 객체                          |

# ex) Example of setting clock on interface object

```
i_APB = interface:new("APB")

PCLK = clock:new("PCLK", "APB's clock")

PCLK:set_reset("PRSTn")

i_APB:set_clock(PCLK) -- PCLK setting
```

### 4.2.6 interface:get\_clock

| 구분    | 표현식                            |
|-------|--------------------------------|
| 함수 원형 | function interface:get_clock() |
| 반환값   | clock                          |
| 설명    | interface에서 할당된 clock을 반환합니다.  |

# ex) Example of setting clock on interface object

```
i_APB = interface:new("APB")

PCLK = clock:new("PCLK", "APB's clock")
PCLK:set_reset("PRSTn")

i_APB:set_clock(PCLK)

LOGI("APB's clock is " .. i_APB:get_clock().name) -- print clock name
```

#### 4.2.7 interface:set\_signal

| 구분        | 표현식                                                                                                                          |
|-----------|------------------------------------------------------------------------------------------------------------------------------|
| 함수 원형     | function interface:set_signal(name, [bit_width])                                                                             |
| 반환값       | -                                                                                                                            |
| 설명        | interface에 signal 을 설정 또는 변경합니다.                                                                                             |
| name      | 설정할 signal 이름                                                                                                                |
| bit_width | signal 의 bit width. 만약 설정하지 않으면 1로 간주합니다. 또한 명시적으로 0으로 설정할<br>경우 해당 시그널은 사용하지 않습니다.(상수 이외에 parameter 값이나 수식을 사용할 수<br>있습니다.) |

### ex) Example of adding signal to interface object

```
i_axi3 = interface:new("AXI3")
-- parameter 설정
i_axi3:set_param("ADDR_WIDTH", 16)
i_axi3:set_param("DATA_WIDTH", 128)
-- signal 설정
i_axi3:set_signal("AWVALID")
i_axi3:set_signal("AWREADY")
i_axi3:set_signal("AWADDR", "ADDR_WIDTH")
i_axi3:set_signal("AWSIZE", 3)
i_axi3:set_signal("AWBURST", 2)
i_axi3:set_signal("WSTRB", "DATA_WIDTH/8")
```

UserGuide BSD License.

# 4.2.8 interface:signal\_count

| 구분    | 표현식                               |
|-------|-----------------------------------|
| 함수 원형 | function interface:signal_count() |
| 반환값   | number                            |
| 설명    | interface에 정의된 signal 개수를 반환합니다.  |

**BSD** License. 49 v1.02

### 4.2.9 interface:set\_param

| 구분            | 표현식                                               |
|---------------|---------------------------------------------------|
| 함수 원형         | function interface:set_param(name, default_value) |
| 반환값           | -                                                 |
| 설명            | interface에 parameter를 추가 또는 변경합니다.                |
| name          | parameter 이름                                      |
| default_value | parameter 기본 값.(상수 또는 수식등이 포함될 수 있습니다.)           |

# ex) Example of adding parameter to interface object

```
i_axi3 = interface:new("AXI3")
-- parameter setting
i_axi3:set_param("ADDR_WIDTH", 16)
i_axi3:set_param("DATA_WIDTH", 128)
-- Modify parameter
i_axi3:set_param("DATA_WIDTH", 256)
```

UserGuide **BSD** License.

v1.02

50

### 4.2.10 interface:get\_param

| 구분    | 표현식                                |
|-------|------------------------------------|
| 함수 원형 | function interface:get_param(name) |
| 반환값   | number 또는 string                   |
| 설명    | interface에 parameter를 반환합니다.       |
| name  | parameter 이름                       |

ex) An example of getting parameters to an interface object

```
i_axi3 = interface:new("AXI3")
-- parameter setting
i_axi3:set_param("ADDR_WIDTH", 16)
i_axi3:set_param("DATA_WIDTH", 128)
-- get parameter and print
LOGI("i_axi3's data width = " .. tostring(i_axi3:get_param("DATA_WIDTH")))
```

UserGuide **BSD** License.

v1.02

51

#### 4.2.11 interface:set\_modport

| 구분      | 표현식                                                                               |
|---------|-----------------------------------------------------------------------------------|
| 함수 원형   | function interface:set_modport(name, modport)                                     |
| 반환값     | -                                                                                 |
| 설명      | interface에 modport를 추가합니다.                                                        |
| name    | modport 이름                                                                        |
| modport | modport 구성 table 구조체 이며, 아래와 같은 형태로 기술합니다.<br>{["input"]={"",}, ["output"]={"",}} |

#### ex) set\_modport example

```
-- APB bus
           = interface:new("apb")
bus_apb
bus_apb:set_param("ADDR_WIDTH", 16)
bus_apb:set_param("DATA_WIDTH", 32)
bus_apb:set_param("SEL_WIDTH", 2)
bus_apb:set_signal("PADDR", "ADDR_WIDTH")
bus_apb:set_signal("PSEL", "SEL_WIDTH")
bus_apb:set_signal("PENABLE")
bus_apb:set_signal("PWRITE")
bus_apb:set_signal("PWDATA", "DATA_WIDTH")
bus_apb:set_signal("PREADY")
bus_apb:set_signal("PRDATA", "DATA_WIDTH")
bus_apb:set_signal("PSLVERR")
bus_apb:set_modport("s", {["input"]={"PSEL", "PENABLE", "PWRITE", "PADDR", "PWDATA"},
["output"]={"PREADY", "PRDATA", "PSLVERR"}})
bus_apb:set_modport("m", {["output"]={"PSEL", "PENABLE", "PWRITE", "PADDR", "PWDATA"},
["input" ]={"PREADY", "PRDATA", "PSLVERR"}})
```

UserGuide BSD License.

#### 4.2.12 interface:add\_modport

| 함수 원형   | function interface:add_modport(name, modport)                                     |
|---------|-----------------------------------------------------------------------------------|
| 반환값     | -                                                                                 |
| 설명      | interface의 기존 modport에 signal을 추가합니다.                                             |
| name    | modport 이름                                                                        |
| modport | modport 구성 table 구조체 이며, 아래와 같은 형태로 기술합니다.<br>{["input"]={"",}, ["output"]={"",}} |

#### ex) add\_modport example

```
-- APB bus
           = interface:new("apb")
bus apb
bus_apb:set_param("ADDR_WIDTH", 16)
bus_apb:set_param("DATA_WIDTH", 32)
bus_apb:set_param("SEL_WIDTH", 2)
bus_apb:set_signal("PADDR", "ADDR_WIDTH")
bus_apb:set_signal("PSEL", "SEL_WIDTH")
bus_apb:set_signal("PENABLE")
bus_apb:set_signal("PWRITE")
bus_apb:set_signal("PWDATA", "DATA_WIDTH")
bus_apb:set_signal("PREADY")
bus_apb:set_signal("PRDATA", "DATA_WIDTH")
bus_apb:set_signal("PSLVERR")
bus_apb:set_modport("s", {["input"]={"PSEL", "PENABLE", "PWRITE"}, ["output"]={"PREADY",
"PRDATA", "PSLVERR"}})
bus_apb:set_modport("m", {["output"]={"PSEL", "PENABLE", "PWRITE"}, ["input"]={"PREADY",
"PRDATA", "PSLVERR"}})
bus_apb:add_modport('s', {["input"]={"PADDR", "PWDATA"}})
bus_apb:add_modport('m', {["output"]={"PADDR", "PWDATA"}})
```

UserGuide BSD License.

#### 4.2.13 interface:get\_modport

| 함수 원형 | function interface:get_modport(name, modport) |
|-------|-----------------------------------------------|
| 반환값   | table                                         |
| 설명    | interface의 기존 modport의 테이블을 반환합니다.            |
| name  | modport 이름                                    |

#### ex) add\_modport example

```
-- APB bus
          = interface:new("apb")
bus_apb
bus_apb:set_param("ADDR_WIDTH", 16)
bus_apb:set_param("DATA_WIDTH", 32)
bus_apb:set_param("SEL_WIDTH", 2)
bus_apb:set_signal("PADDR", "ADDR_WIDTH")
bus_apb:set_signal("PSEL", "SEL_WIDTH")
bus_apb:set_signal("PENABLE")
bus_apb:set_signal("PWRITE")
bus_apb:set_signal("PWDATA", "DATA_WIDTH")
bus_apb:set_signal("PREADY")
bus_apb:set_signal("PRDATA", "DATA_WIDTH")
bus_apb:set_signal("PSLVERR")
bus_apb:set_modport("s", {["input"]={"PSEL", "PENABLE", "PWRITE"}, ["output"]={"PREADY",
"PRDATA", "PSLVERR"}})
bus_apb:set_modport("m", {["output"]={"PSEL", "PENABLE", "PWRITE"}, ["input"]={"PREADY",
"PRDATA", "PSLVERR"}})
-- List 'input' of modeport 's'
for i, signal_name in ipairs(bus_apb:get_modport("s").input) do
    LOGI("modport 's' input : " .. signal_name)
```

UserGuide BSD License.

#### 4.2.14 interface:set\_prefix

| 함수 원형  | function interface:set_prefix(prefix)                                                                                                                                                   |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 반환값    | -                                                                                                                                                                                       |
| 설명     | interface의 port 출력시 prefix 문자열을 지정합니다.<br>여러 개의 동일 interface 가 동시에 같은 module 내 port 출력이 되어 있다면, '#' 문자를<br>prefix 에 포함하여, 숫자 0 부터 1씩 증가하도록 변경됩니다. 만약 단일 interface 라면<br>문자 '#' 는 제거됩니다. |
| prefix | prefix 문자열                                                                                                                                                                              |

#### ex) set\_prefix example

#### [execution result : top\_defines.vh]

```
1: `ifndef __TOP_DEFINES_VH__
 2: `define __TOP_DEFINES_VH__
3: `include "testdrive_system.vh"
                                   // default system defines
4:
5: //----
6: // interfaces
7: //----
8: interface i_inst;
9: logic
                            EN;
10: logic [31:0]
11: modport m (
                            INST;
12:
       output EN, INST
13: );
14:
     modport s (
       input EN, INST
15:
       );
16:
17: endinterface
19: `endif//__TOP_DEFINES_VH__
```

### [execution result : top.sv]

```
1: `include "top_defines.vh"
3: module top (
4: // inst_0
    output
output [31:0]
5:
                              IO_EN,
6:
                               10_INST,
7:
8:
      // inst_1
9:
                              I1_EN,
       output
10:
       output [31:0]
                              I1_INST
11: );
12:
13: // interface : inst_0
14: i_inst inst_0;
15: assign IO_EN
                             = inst_0.EN;
16: assign IO_INST
                              = inst_0.INST;
18: // interface : inst_1
19: i_inst
                       inst_1;
20: assign I1_EN
                       = inst_1.EN;
21: assign I1_INST
                              = inst_1.INST;
22:
23:
24: endmodule
```

### 4.2.15 interface:set\_bared

| 함수 원형 | function interface:set_bared(bared)           |
|-------|-----------------------------------------------|
| 반환값   | -                                             |
| 설명    | interface의 구조체를 풀어 적용합니다.                     |
| bared | boolean 값의 bared 여부, 지정하지 않을 경우 true 로 지정됩니다. |

Used when configuring bared signals.

### ex) set\_bared example

v1.02

```
-- interface example
inst = interface:new("inst")
inst:set_signal("EN")
inst:set_signal("INST", 32)
inst \\ \vdots \\ set\_modport(\\ "s", \\ \{["input"] \\ ] \\ = \{"EN", \\ "INST"\}\})
inst:set_modport("m", {["output"]={"EN", "INST"}})
inst:set_bared()
                                -- bared interface setting
```

UserGuide **BSD** License.

57

# 4.2.16 interface:set\_top\_uppercase

| 함수 원형 | function interface:set_top_uppercase(en)                 |
|-------|----------------------------------------------------------|
| 반환값   | -                                                        |
| 설명    | interface 의 top 의 port 출력시 강제 대문자 또는 소문자 이름으로 강제합니다.     |
| en    | uppercase 여부, true(uppercase), false(lowercase), nil(원본) |

#### 4.2.17 interface\_i:set\_port

| 함수 원형            | function interface_i:set_port(modport_name)                        |
|------------------|--------------------------------------------------------------------|
| 반환값              | -                                                                  |
| 설명               | module:add_interface 함수로 추가된 interface instance 를 port 출력으로 지정합니다. |
| modport_nam<br>e | modport 이름                                                         |

When a basic interface is added to a module, the port output (input, output, inout) is determined through this function.

### ex) interface\_i:set\_port example

```
-- interface example
inst
     = interface:new("inst")
inst:set_signal("EN")
inst:set_signal("INST", 32)
inst:set_modport("s", {["input" ]={"EN", "INST"}})
inst:set_modport("m", {["output"]={"EN", "INST"}})
           = module:new("top")
top
top:add_interface(inst):set_port("m") -- Set inst interface to top output as modport 'm'
```

UserGuide BSD License.

v1.02

#### 4.2.18 interface\_i:set\_desc

| 함수 원형 | function interface_i:set_desc(desc)                                     |
|-------|-------------------------------------------------------------------------|
| 반환값   | -                                                                       |
| 설명    | module:add_interface 함수로 추가된 interface instance 의 주석으로 쓰일 설명을<br>추가합니다. |
| desc  | 추가 설명 문자열                                                               |

#### ex) interface\_i:set\_desc example

```
-- interface example
inst = interface:new("inst")
inst:set_signal("EN")
inst:set_signal("INST", 32)
inst:set_modport("s", {["input" ]={"EN", "INST"}})
inst:set_modport("m", {["output"]={"EN", "INST"}})
           = module:new("top")
top
i_int = top:add_interface(inst)
i_int:set_port("m") -- Set inst interface to top output as modport 'm'
i_int:set_desc("main instruction") -- comment description
```

**UserGuide BSD** License.

60

#### 4.2.19 interface\_i:set\_prefix

| 함수 원형  | function interface_i:set_prefix(prefix)                                                                        |
|--------|----------------------------------------------------------------------------------------------------------------|
| 반환값    | -                                                                                                              |
| 설명     | module:add_interface 함수로 추가된 interface instance 의 prefix를 지정합니다.<br>지정되지 않았을 경우 원본 interface 의 prefix 가 사용됩니다. |
| prefix | prefix 문자열                                                                                                     |

#### ex) interface\_i:set\_prefix example

This interface instance is converted to IF\_EN, IF\_INST and output as port.

#### 4.2.20 interface\_i:get\_prefix

| 함수 원형 | function interface_i:get_prefix()                                                                                                            |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 반환값   | string                                                                                                                                       |
| 설명    | module:add_interface 함수로 추가된 interface instance 의 prefix를 반환합니다. 만약 interface instance 에서 prefix 가 지정되지 않았다면, 원본 interface 의 prefix 를 반환합니다. |

#### ex) interface\_i:get\_prefix example

#### 4.3 module

An object that matches a verilog module declaration. It is created with the module:new function, and the final result source is output through the module:make\_code function. At this time, the declaration of sub modules included in the lower level and interfaces used at least once are also made.

The port of the top module is converted into single signals in the form of input/output, not the systemverilog interface syntax, and the internal sub modules are described according to the interface syntax.

The sub module object added with the module:add\_module function is used as the module\_i interface.

Table 4-4. module object summary

| Member         | Туре     | Description                                 |
|----------------|----------|---------------------------------------------|
| .name          | string   | module name                                 |
| :new           | function | create module                               |
| :set_inception | function | Specifies the code inception file.          |
| :get_inception | function | Return code inception.                      |
| :set_title     | function | Specifies the title of the code inception.  |
| :set_author    | function | Specifies the author of the code inception. |
| :set_param     | function | Specify parameters.                         |
| :get_param     | function | Search parameter.                           |
| :add_interface | function | Add interface.                              |
| :add_clock     | function | Add clock.                                  |
| :get_interface | function | Search for added interfaces.                |
| :get_port      | function | Search ports among the added interfaces.    |
| :add_module    | function | Add sub module.                             |
| :get_module    | function | Search for sub modules.                     |
| :add_code      | function | Add a user code statement.                  |
| .find          | function | Find the module object.                     |
| .is_valid      | function | Check whether the module exists.            |
| .apply_code    | function | Apply the code file to the module.          |
| .code          | String   | Added code string object from module        |

Table 4-5. module\_i(sub module) object summary

| Member     | Туре     | Description                                           |
|------------|----------|-------------------------------------------------------|
| .name      | string   | Returns the sub module name.                          |
| :set_param | function | Specifies the value of the parameter.                 |
| :get_param | function | Returns the value of parameter.                       |
| :set_port  | function | Specifies the value of port.                          |
| :get_port  | function | Returns the value of port.                            |
| .is_valid  | function | Determines whether object is a valid module_i object. |

UserGuide BSD License.

63

### 4.3.1 module:new

| Type         | Description               |
|--------------|---------------------------|
| Prototype    | function module:new(name) |
| Return value | module                    |
| Remarks      | Create a module.          |
| name         | module name               |

ex) Module creation example

= module:new("top") -- Module creation example top

UserGuide **BSD** License.

# 4.3.2 module:make\_code

| Type         | Description                                                                                                                                                                                                                                                                                                                                            |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Prototype    | function module:make_code()                                                                                                                                                                                                                                                                                                                            |
| Return value | -                                                                                                                                                                                                                                                                                                                                                      |
| Remarks      | Generates a module into a final output file. Here is the creation list:  [top_name]_defines.vh (define and interface declarations)  [all used module names].sv (result systemverilog source files)  [top_name].f (all reference source names)  [top_name]_constraint.xdc (constraint declaration)  [top_name]_hierarchy.svg (design hierarchy diagram) |

#### 4.3.3 module:set\_inception

| Type         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Prototype    | function module:set_inception(filename)                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| Return value | -                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| Remarks      | Specifies the file in which code inception is described. You can use the meta sentences below for your code inception technique. YEAR : The current year. Ex) 2023 DATE : The current date. Example) May/08/2023 Mon TITME : The current time. Ex) 19:34:21 AUTHOR : Author specified by the module:set_author function. Default: "testdrive profiling master - verigen" TITLE : Title specified with the module:set_title function. Default: "no_title" |  |
| filename     | File name where code inception is described                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| bit_width    | The bit width of the signal. If not set, it is regarded as 1. Also, if explicitly set to 0, the corresponding signal is not used. (In addition to constants, parameter values or formulas can be used.)                                                                                                                                                                                                                                                  |  |

This inception text will be placed at the top of each .sv source. You can separately insert sentences such as license by specifying :set\_inception, :set\_title, :set\_author functions for each module separately.

If you call it with module:set\_inception, all generated modules will use the code inception of the base module unless otherwise specified.

ex) set\_inception example

```
-- code inception setting
module:set_inception("code_inception.txt")
module:set_title("some title")
module:set_author("me")

top = module:new("top")
```

#### [code\_inception.txt]

execution result

[result file: top.sv]

```
// Copyright (c) 2013 ~ 2023. HyungKi Jeong(clonextop@gmail.com)
// Freely available under the terms of the 3-Clause BSD License
// (https://opensource.org/licenses/BSD-3-Clause)
//
// Title : some title
// Rev. : May/09/2023 Tue 14:10:16 (me)
`include "top_defines.vh"
module top ();
endmodule
```

**BSD** License. v1.02

# 4.3.4 module:get\_inception

| Type         | Description                                                                                                    |
|--------------|----------------------------------------------------------------------------------------------------------------|
| Prototype    | function module:get_inception()                                                                                |
| Return value | -                                                                                                              |
| Remarks      | Returns the result of applying all meta sentences to the code inception phrase set with module:set_inception . |

# 4.3.5 module:set\_title

| Type         | Description                                                                                                             |  |  |
|--------------|-------------------------------------------------------------------------------------------------------------------------|--|--|
| Prototype    | function module:set_title(title)                                                                                        |  |  |
| Return value | -                                                                                                                       |  |  |
| Remarks      | Specifies the title of the code inception. TITLE meta sentences in code inception are converted to the specified title. |  |  |
| title        | title string                                                                                                            |  |  |

UserGuide BSD License. 69

# 4.3.6 module:set\_author

| Type         | Description                                                                                                                |  |
|--------------|----------------------------------------------------------------------------------------------------------------------------|--|
| Prototype    | function module:set_author(name)                                                                                           |  |
| Return value | -                                                                                                                          |  |
| Remarks      | Specifies the author of the code inception.  TheAUTHOR meta-sentence in code inception translates to the specified author. |  |
| name         | author string                                                                                                              |  |

UserGuide **BSD** License.

70

### 4.3.7 module:set\_param

| Type         | Description                                                                                                                      |
|--------------|----------------------------------------------------------------------------------------------------------------------------------|
| Prototype    | function module:set_param(name, value, [is_local])                                                                               |
| Return value | -                                                                                                                                |
| Remarks      | Add module parametes.                                                                                                            |
| name         | parameter name                                                                                                                   |
| value        | parameter default value                                                                                                          |
| is_local     | If it is true, it is implemented as a localparam, otherwise it is implemented as a port parameter. Defaults to false if omitted. |

# ex) module:set\_param 예시

```
top = module:new("top") -- Module creation example
-- port parameter 설정
top:set_param("DATA_WIDTH", 32)
-- local parameter 설정
top:set_param("BYTE_WIDTH", "DATA_WIDTH/8", true)
```

# 4.3.8 module:get\_param

| Type         | Description                                            |  |
|--------------|--------------------------------------------------------|--|
| Prototype    | function module:get_param(name)                        |  |
| Return value | integer or string                                      |  |
| Remarks      | Returns the default values of the module's parameters. |  |
| name         | parameter name                                         |  |

# 4.3.9 module:add\_interface

| Type         | Description                                                                                       |
|--------------|---------------------------------------------------------------------------------------------------|
| Prototype    | function module:add_interface(i, [name], [modport])                                               |
| Return value | interface_i                                                                                       |
| Remarks      | Adds an interface instance object to the module.                                                  |
| i            | interface object                                                                                  |
| name         | interface instance name If the name is not specified, the interface name is followed.             |
| modport      | The modport name, if used for internal declarations other than ports.  Do not specify this value. |

# 4.3.10 module:add\_clock

| Type         | Description                    |
|--------------|--------------------------------|
| Prototype    | function module:add_clock(clk) |
| Return value | -                              |
| Remarks      | Add a clock to the module.     |
| clk          | clock object                   |

# 4.3.11 module:get\_interface

| Type         | Description                                                              |
|--------------|--------------------------------------------------------------------------|
| Prototype    | function module:get_interface(name)                                      |
| Return value | interface_i                                                              |
| Remarks      | Retrieves and returns the interface instance object added to the module. |
| name         | interface instance object name                                           |

# 4.3.12 module:get\_port

| Type         | Description                                                                                                    |
|--------------|----------------------------------------------------------------------------------------------------------------|
| Prototype    | function module:get_port(name)                                                                                 |
| Return value | interface_i                                                                                                    |
| Remarks      | Among the interface instance objects added to the module, the object set as the port is searched and returned. |
| name         | interface instance object name                                                                                 |

UserGuide **BSD** License.

v1.02

# 4.3.13 module:add\_module

| Туре         | Description                                                                                                                                                                                                          |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Prototype    | function module:add_module(m, [name])                                                                                                                                                                                |
| Return value | -                                                                                                                                                                                                                    |
| Remarks      | Add sub module.                                                                                                                                                                                                      |
| m            | Module source to be a sub module                                                                                                                                                                                     |
| name         | Sub module name.  If omitted, it is named the same as the original module name.  If there are several omitted sub modules with the same name, put a number in the form of "_#" after each name to avoid duplication. |

UserGuide **BSD** License.

77

v1.02

# 4.3.14 module:get\_module

| Type         | Description                           |
|--------------|---------------------------------------|
| Prototype    | function module:get_module(name)      |
| Return value | module                                |
| Remarks      | Searches for and returns sub modules. |
| name         | sub module name                       |

# 4.3.15 module:add\_code

| Type         | Description                                                                                                                                                                                                                                                                                                        |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Prototype    | function module:add_code(s)                                                                                                                                                                                                                                                                                        |
| Return value | -                                                                                                                                                                                                                                                                                                                  |
| Remarks      | Add user code.  These codes are included as statements inserted at the end of each module source. It is appended to the module.code(String) object, and can be usefully used with the _V() macro function. The last character of the added code is ';' If it ends with , the enter code is automatically inserted. |
| s            | user add code                                                                                                                                                                                                                                                                                                      |

**BSD** License. 79 v1.02

### 4.3.16 module.find

| Type         | Description                |
|--------------|----------------------------|
| Prototype    | function module.find(name) |
| Return value | module                     |
| Remarks      | Find the created module.   |
| name         | module name to find        |

# 4.3.17 module.is\_valid

| Type         | Description                            |
|--------------|----------------------------------------|
| Prototype    | function module.is_valid(obj)          |
| Return value | boolean                                |
| Remarks      | Check that the object is valid module. |
| obj          | Module object to check.                |

#### 4.3.18 module.apply\_code

| Type         | Description                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Prototype    | function module.apply_code(filename)                                                                                                                                                                                                                                                                                                                                                                            |
| Return value | -                                                                                                                                                                                                                                                                                                                                                                                                               |
| Remarks      | Code is read from the code description file and inserted into each module as code.  After starting with ":module name (option)" in the code description file, the code in the module from the next line is inserted when the result of the option is true.  Option is a Lua script with a Boolean result indicating whether sub-specified codes are inserted. This option can be omitted. (default value: true) |
| filename     | code description file name                                                                                                                                                                                                                                                                                                                                                                                      |

ex) module.apply\_code example (When you want to add code to Core and ALU modules.)

```
module.apply_code("__core.sv")
```

### [\_\_core.sv]

```
:Core
                   // Core's code
assign A = B;
assign C = D;
                   // Core's code
:ALU (config.core_size > 4)
                // ALU's code
assign E = F;
assign G = H;
                   // ALU's code
       [15:0] CORE_SIZE = $(config.core_size);
```

**NOTE:** You can execute lua code by writing '\$(\*)' or '\${\*}' in the middle of verilog code. '\$(\*)' is a string or number returned code, and '\${\*}' can describe lua code execution without return.

UserGuide **BSD** License.

v1.02

82

# 4.3.19 module\_i:set\_param

| Type         | Description                                      |
|--------------|--------------------------------------------------|
| Prototype    | function module_i:set_param(name, val)           |
| Return value | -                                                |
| Remarks      | Specifies the parameter value of the sub module. |
| name         | parameter name                                   |
| val          | parameter setting value                          |

# 4.3.20 module\_i:get\_param

| Type         | Description                                                     |
|--------------|-----------------------------------------------------------------|
| Prototype    | function module_i:get_param(name)                               |
| Return value | integer or string                                               |
| Remarks      | Returns the value specified as the parameter of the sub module. |
| name         | parameter name                                                  |

# 4.3.21 module\_i:set\_port

| Type         | Description                                    |
|--------------|------------------------------------------------|
| Prototype    | function module_i:module_i:set_port(name, val) |
| Return value | -                                              |
| Remarks      | Specifies the port value of the sub module.    |
| name         | port name                                      |
| val          | port setting value                             |

# 4.3.22 module\_i:get\_port

| Type         | Description                               |
|--------------|-------------------------------------------|
| Prototype    | function module_i:get_port(name)          |
| Return value | interger or string                        |
| Remarks      | Returns the port value of the sub module. |
| name         | port name                                 |

BSD License. UserGuide 86

# 4.3.23 module\_i.is\_valid

| Type         | Description                                                    |
|--------------|----------------------------------------------------------------|
| Prototype    | function module_i.is_valid(obj)                                |
| Return value | boolean                                                        |
| Remarks      | Returns whether object is a valid module_i(sub module) object. |
| obj          | module_i object                                                |

# 5. Appendix

## 5.1 Appendix: test\_definition.lua

```
-- clock definition
clk
      = {}
clk.MCLK = clock:new("CLK", "main clock") -- for core
clk.MCLK:set_speed(1000)
clk.PCLK
            = clock:new("PCLK", "APB clock")
clk.PCLK:set_speed(100)
clk.PCLK:set_reset("PRESETn", "low")
clk.BCLK
           = clock:new("ICLK", "interconnection clock")
clk.BCLK:set_speed(1500)
            = clock:new("ACLK", "AXI clock")
clk.ACLK
clk.ACLK:set_speed(1000)
-- bus interface
bus = \{\}
-- APB bus
         = interface:new("apb")
bus.apb:set_clock(clk.PCLK)
bus.apb:set_param("ADDR_WIDTH", 16)
bus.apb:set_param("DATA_WIDTH", 32)
bus.apb:set_param("SEL_WIDTH", 2)
bus.apb:set_signal("PADDR", "ADDR_WIDTH")
bus.apb:set_signal("PSEL", "SEL_WIDTH")
bus.apb:set_signal("PENABLE")
bus.apb:set_signal("PWRITE")
bus.apb:set_signal("PWDATA", "DATA_WIDTH")
bus.apb:set_signal("PREADY")
bus.apb:set_signal("PRDATA", "DATA_WIDTH")
bus.apb:set_signal("PSLVERR")
bus.apb:set_modport("s", {["input"]={"PSEL", "PENABLE", "PWRITE", "PADDR", "PWDATA"},
["output"]={"PREADY", "PRDATA", "PSLVERR"}})
bus.apb:set_modport("m", {["output"]={"PSEL", "PENABLE", "PWRITE", "PADDR", "PWDATA"},
["input" ]={"PREADY", "PRDATA", "PSLVERR"}})
bus.apb:set_prefix("S#")
-- AXI3 master bus
```

```
bus.maxi3 = interface:new("maxi3")
bus.maxi3:set_clock(clk.ACLK)
bus.maxi3:set_param("DATA_WIDTH", 128)
bus.maxi3:set_param("ADDR_WIDTH", 32)
bus.maxi3:set_param("ID_WIDTH", 4)
-- write address
bus.maxi3:set_signal("AWVALID")
bus.maxi3:set_signal("AWREADY")
bus.maxi3:set_signal("AWADDR", "ADDR_WIDTH")
bus.maxi3:set_signal("AWSIZE", 3)
bus.maxi3:set_signal("AWBURST", 2)
bus.maxi3:set_signal("AWCACHE", 4)
bus.maxi3:set_signal("AWPROT", 3)
bus.maxi3:set_signal("AWID", "ID_WIDTH")
bus.maxi3:set_signal("AWLEN", 4)
bus.maxi3:set_signal("AWLOCK", 2)
-- write data
bus.maxi3:set_signal("WVALID")
bus.maxi3:set_signal("WREADY")
bus.maxi3:set_signal("WLAST")
bus.maxi3:set_signal("WDATA", "DATA_WIDTH")
bus.maxi3:set_signal("WSTRB", "DATA_WIDTH/8")
bus.maxi3:set_signal("WID", "ID_WIDTH")
-- write response
bus.maxi3:set_signal("BVALID")
bus.maxi3:set_signal("BREADY")
bus.maxi3:set_signal("BRESP", 2)
bus.maxi3:set_signal("BID", "ID_WIDTH")
-- read address
bus.maxi3:set_signal("ARVALID")
bus.maxi3:set_signal("ARREADY")
bus.maxi3:set_signal("ARADDR", "ADDR_WIDTH")
bus.maxi3:set_signal("ARSIZE", 3)
bus.maxi3:set_signal("ARBURST", 2)
bus.maxi3:set_signal("ARCACHE", 4)
bus.maxi3:set_signal("ARPROT", 3)
bus.maxi3:set_signal("ARID", "ID_WIDTH")
bus.maxi3:set_signal("ARLEN", 4)
bus.maxi3:set_signal("ARLOCK", 2)
-- read data
bus.maxi3:set_signal("RVALID")
bus.maxi3:set_signal("RREADY")
bus.maxi3:set_signal("RLAST")
bus.maxi3:set_signal("RDATA", "DATA_WIDTH")
bus.maxi3:set_signal("RRESP", 2)
bus.maxi3:set_signal("RID", "ID_WIDTH")
bus.maxi3:set_modport("s", {
    ["input"]={
             "AWVALID", "AWADDR", "AWSIZE", "AWBURST", "AWCACHE", "AWPROT", "AWID", "AWLEN",
"AWLOCK",
            "WVALID", "WLAST", "WDATA", "WSTRB", "WID",
```

```
"ARVALID", "ARADDR", "ARSIZE", "ARBURST", "ARCACHE", "ARPROT", "ARID", "ARLEN",
"ARLOCK",
            "RREADY", "RLAST"
   [ "output " ]={
            "AWREADY", "WREADY", "BVALID", "BRESP", "BID", "ARREADY", "RVALID", "RDATA", "RRESP",
"RID"
})
bus.maxi3:set_modport("m", {
    [ "output " ]={
            "AWVALID", "AWADDR", "AWSIZE", "AWBURST", "AWCACHE", "AWPROT", "AWID", "AWLEN",
"AWLOCK",
            "WVALID", "WLAST", "WDATA", "WSTRB", "WID",
            "BREADY",
            "ARVALID", "ARADDR", "ARSIZE", "ARBURST", "ARCACHE", "ARPROT", "ARID", "ARLEN",
"ARLOCK",
            "RREADY", "RLAST"
   ["input"]={
            "AWREADY", "WREADY", "BVALID", "BRESP", "BID", "ARREADY", "RVALID", "RDATA", "RRESP",
"RID"
            }
})
bus.maxi3:set_prefix("M#")
-- AXI4 master bus
bus.maxi4 = bus.maxi3:new("maxi4")
                                       -- modified 2bit to 1bit
bus.maxi4:set_signal("AWLOCK")
bus.maxi4:set_signal("ARLOCK")
                                       -- modified 2bit to 1bit
bus.maxi4:set_signal("AWLEN", 8)
                                       -- modified 4bit to 8bit
                                       -- modified 4bit to 8bit
bus.maxi4:set_signal("ARLEN", 8)
bus.maxi4:set_signal("AWQOS", 4)
                                       -- new on AX14
bus.maxi4:set_signal("AWREGION", 4)
                                       -- new on AXI4
bus.maxi4:set_signal("ARQOS", 4)
                                       -- new on AXI4
bus.maxi4:set_signal("ARREGION", 4)
                                       -- new on AXI4
bus.maxi4:add_modport("s", {
   })
bus.maxi4:add_modport("m", {
   ["input" ]={"ARQOS", "ARREGION"},
   ["output"]={"AWQOS", "AWREGION"}
})
bus.maxi4:set prefix("M#")
-- core interface
```

#### 5 Appendix

```
core_i = \{\}
core_i.inst = interface:new("inst")
core_i.inst:set_signal("EN")
core_i.inst:set_signal("INST", 32)
core_i.inst:set_signal("READY")
core_i.inst:set_modport("m", {
   ["output"]={"EN", "INST"},
   ["input"] ={"READY"}
})
core_i.inst:set_modport("s", {
   ["input"]={"EN", "INST"},
    ["output"] ={"READY"}
})
core_i.inst:set_clock(clk.MCLK)
-- configuration
                   = {}
config
config.core_size
                 = 4
```