# RENESAS

How to Create Customized Code (Full Adder) SLG47910V

### Abstract

This application shows how to combine multiple custom modules and implement it using the SLG47910 FPGA. This application is demonstrated with the help of a Full Adder example. The functionality of the full adder is verified by creating a Testbench and observing the output waveforms on the inbuilt GTKWave Software. This application note comes complete with design files which can be found in the References section.

### Contents

| 1. Terms and Definitions       1         2. References       1         3. Introduction       2         4. Ingredients       2         5. Verilog Code       2         6. Test Bench       2         7. Design Steps       3         8. Conclusion       5         9. Revision History       6 | Abs | tract                 | 1 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------------------|---|
| 3.       Introduction       2         4.       Ingredients       2         5.       Verilog Code       2         6.       Test Bench       2         7.       Design Steps       3         8.       Conclusion       5                                                                        | 1.  | Terms and Definitions | 1 |
| <ul> <li>4. Ingredients</li></ul>                                                                                                                                                                                                                                                             | 2.  | References            | 1 |
| <ul> <li>5. Verilog Code</li></ul>                                                                                                                                                                                                                                                            | 3.  | Introduction          | 2 |
| <ul> <li>5. Verilog Code</li></ul>                                                                                                                                                                                                                                                            | 4.  | Ingredients           | 2 |
| 7. Design Steps    3      8. Conclusion    5                                                                                                                                                                                                                                                  |     |                       |   |
| 8. Conclusion                                                                                                                                                                                                                                                                                 | 6.  | Test Bench            | 2 |
|                                                                                                                                                                                                                                                                                               | 7.  | Design Steps          | 3 |
| 9. Revision History                                                                                                                                                                                                                                                                           | 8.  | Conclusion            | 5 |
|                                                                                                                                                                                                                                                                                               | 9.  | Revision History      | 6 |

### 1. Terms and Definitions

| CLB                       | Configuration Logic Block                                    |
|---------------------------|--------------------------------------------------------------|
| HDL                       | Editor Workspace where Verilog code is entered               |
| FPGA                      | Field Programmable Gate Array                                |
| FPGA Editor               | Main FPGA design and simulation window                       |
| Go Configure Software Hub | Main window for device selection                             |
| ForgeFPGA                 | Window Main FPGA project window for debug and IO programming |

### 2. References

For related documents and software, please visit: <u>https://www.dialog-semiconductor.com/products/greenpak/low-power-low-cost-forgefpga</u>. Download our free ForgeFPGA<sup>™</sup> Designer software [1] to open the <u>.ffpga design</u> files [2] and view the proposed circuit design.

[1] ForgeFPGA Designer Software, Software Download and User Guide

[2] <u>AN-FG-002 How to Create Customized Code (Full Adder).ffpga</u>, ForgeFPGA Design File, Renesas Electronics

[3] ForgeFPGA SLG47910 Datasheet, Renesas Electronics

#### 3. Introduction

A Full Adder module is created with the help of 2 Half Adder modules and an OR Gate module mapped together.

Structural modelling can be implemented in ForgeFPGA Workshop by defining the topmost module with the keywork (\*top\*). This ensures that the software knows the difference between the topmost module and the modules mapped to it using port mapping syntax. The functionality of the Full Adder can be verified by creating a Test Bench and providing simulation within it. The simulation can be visualized using GTKWave Software within the ForgeFPGA software. This Application is designed to understand the different aspects of the software without the need of programming the part to check functionality.



Figure 1: System Diagram

### 4. Ingredients

Latest Revision of ForgeFPGA Workshop software

### 5. Verilog Code

Shown below is the (\*top\*) module called Full\_Adder. The Verilog code displays how to connect different modules under one top module using synchronous style of Verilog coding.

```
//Full adder coding example
(*top*)module Full Adder(
 (* iopad external pin *) input A,
 (* iopad external pin *) input B,
 (* iopad external pin *) input Cin,
 (* iopad_external_pin *) output Sum,
 (* iopad external pin *) output Sum oe,
 (* iopad external pin *) output Cout oe,
 (* iopad external pin *) output Cout
);
wire n1,n2,n3;
//OE
assign Sum oe = 1;
assign Cout oe = 1;
//port mapping
             Half_Adder_1 (.x(A), .y(B), .sum(n2), .carry(n1));;
Half Adder
Half Adder
             Half Adder 2 (.sum(Sum), .carry(n3), .x(n2) , .y(Cin));
OR Gate
             OR Gate 1(.a(n1), .b(n3) ,.c(Cout));
```

endmodule

```
//Half Adder Module for Full Adder
module Half_Adder
(input x,y,
output sum,carry );
assign sum = x ^ y;
assign carry = x & y;
endmodule
//OR gate module for Full Adder
module OR_Gate(
    input a,b,
    output c );
assign c = a | b; //OR gate operation
```

#### endmodule

#### 6. Test Bench

The Test Bench is used to provide Stimulus to verify the correctness or working of our DUT, hence we must instantiate our design module. The module name must be given as to be recognized by the ForgeFPGA Studio as a testbench file (see Figure 2).

The functionality can be verified using the waveforms produced by GTKWave software inbuilt.



Figure 2: Steps to Launch Custom Testbench

### 7. Design Steps

1. Open the ForgeFPGA Workshop software in GreenPAK and select the SLG47910 device From the ForgeFPGA tool bar, select the FPGA Editor Tab (see <u>Figure 5</u>).

| ) 늘 💾         | a.e. | 1                   |           | <b>&gt;</b> | ă             | ()          | -     | *                | 1            | 5          |            |  |
|---------------|------|---------------------|-----------|-------------|---------------|-------------|-------|------------------|--------------|------------|------------|--|
| New Open Save |      | Set Wire Erase Wire | Set Label |             | Rules Checker | FPGA Editor | Debug | Project Settings | Project Info | Properties | Components |  |

#### Figure 5: ForgeFPGA Tool Bar

2. Create 3 different Custom Modules called OR\_Gate , Half\_Adder & Full\_Adder and enter the respective Verilog Codes in the HDL Editor for each module. (see <u>Figure 6</u>).

| 1944D                               | ForgeFPGA Workshop                                 |                    |             |  |  |  |  |  |  |
|-------------------------------------|----------------------------------------------------|--------------------|-------------|--|--|--|--|--|--|
| Fi                                  | le Edit Tools Window                               | Options            |             |  |  |  |  |  |  |
| Ľ                                   | Save                                               | Ctrl+S             |             |  |  |  |  |  |  |
| \$                                  | Add Block                                          |                    |             |  |  |  |  |  |  |
|                                     | New Custom Module                                  | N                  |             |  |  |  |  |  |  |
|                                     | New Custom Testbench                               | 13                 |             |  |  |  |  |  |  |
|                                     | Import                                             | >                  |             |  |  |  |  |  |  |
|                                     | Export                                             | <b>&gt;</b>        | _           |  |  |  |  |  |  |
| R New Module                        | Name                                               | ?                  | ×           |  |  |  |  |  |  |
|                                     | when the new module. This inique for this project. | name Create Cancel |             |  |  |  |  |  |  |
| OR_Gate 🛛 Half_                     | Adder 🔀 🛛 Full_Adder                               |                    |             |  |  |  |  |  |  |
| 1 //Full Adder 1<br>2 (*top*)module | Module using Half Add<br>Full_Adder(               | der module& OR     | Gate Module |  |  |  |  |  |  |

#### Figure 6: Steps to Launch Custom Module

3. Define the Full\_Adder module as (\*top\*) so that it gets recognized as the topmost module and using port mapping, map the OR\_Gate & Half\_Adder module to it and save the code using the save button in the top left corner of the FPGA Editor

4. Check for any Syntax Errors using the Synthesize Button on the lower left side of the FPGA Editor & Check logger for any issues /warnings

5. Click on Generate Bitstream button. This generates bitstream file and other build files such as Floorplan Mapping, Routing information, Netlist, Timing Analysis, Resource Utilization report used in this design. All these information can be accessed by the different tabs found at the top of the ForgeFPGA Workshop software. Check the logger and issues tab on the bottom to make sure that the bit stream was generated correctly.

| 觸 ForgeFPGA Workshop |             |                   |        |         |                |             |           |           |                 |                  |                    |
|----------------------|-------------|-------------------|--------|---------|----------------|-------------|-----------|-----------|-----------------|------------------|--------------------|
| File E               | dit Tools N | Vindow Options    |        |         |                |             |           |           |                 |                  |                    |
| <b>H</b>             | <b>\$</b>   |                   |        | Nç_     | RTL            | 460         |           | di.       | $\odot$         | <b>6</b>         | ۲                  |
| Save                 | Add Block   | New Custom Module | Logger | Netlist | Post-Synth RTL | I/O Planner | Floorplan | Resources | Timing Analysis | Macrocell Editor | Simulate Testbench |

Figure 7: ForgeFPGA Tool Bar

6. Create Test Bench module and define the different inputs you want to run the code through to verify functionality at different time intervals. Simulate the testbench through the Simulate Testbench button on the toolbar (see Figure  $\underline{7}$ ).

If there are no syntax errors on the Testbench written, then the GTKWave software should pop-up automatically provided that the naming of the module is correct.

7. Load the signals in the GTKWave software the needs to be observed. After this step, you should observe green/ red lines right side of the screen. Click 'Zoom Fit' to fir the waveforms in the selected size of the window and then click 'Reload' (see Figure 8).



Figure 8: GTKWave Simulation Waveform

8. The corresponding waveforms can be observed. Each signal value matches the value assigned in the Test Bench code. With the help of the Marker, the values of the signals can be observed at different times.

### 8. Conclusion

The procedure outlines in this application example can be applied to any circuit by creating the custom modules on the similar lines and then port mapping them to the top module to make it a whole circuit. The usage of defining a module as "top" module has been demonstrate and the functionality has been verified using the inbuild GTKWave software and testbench. This testcase is available for download. If interested, please contact the ForgeFPFA Business Support Team

## 9. Revision History

| Revision | Date         | Description                             |
|----------|--------------|-----------------------------------------|
| 1.0      | Dec 10, 2021 | Initial release.                        |
| 2.0      | Feb 20, 2024 | Revised according to BB revision        |
| 3.0      | Jul 17,2024  | Updated as per ForgeFPGA Workshop v6.43 |

#### IMPORTANT NOTICE AND DISCLAIMER

RENESAS ELECTRONICS CORPORATION AND ITS SUBSIDIARIES ("RENESAS") PROVIDES TECHNICAL SPECIFICATIONS AND RELIABILITY DATA (INCLUDING DATASHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT OF THIRD-PARTY INTELLECTUAL PROPERTY RIGHTS.

These resources are intended for developers who are designing with Renesas products. You are solely responsible for (1) selecting the appropriate products for your application, (2) designing, validating, and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, or other requirements. These resources are subject to change without notice. Renesas grants you permission to use these resources only to develop an application that uses Renesas products. Other reproduction or use of these resources is strictly prohibited. No license is granted to any other Renesas intellectual property or to any third-party intellectual property. Renesas disclaims responsibility for, and you will fully indemnify Renesas and its representatives against, any claims, damages, costs, losses, or liabilities arising from your use of these resources. Renesas' products are provided only subject to Renesas' Terms and Conditions of Sale or other applicable terms agreed to in writing. No use of any Renesas resources expands or otherwise alters any applicable warranties or warranty disclaimers for these products.

(Disclaimer Rev.1.01 Jan 2024)

#### **Corporate Headquarters**

TOYOSU FORESIA, 3-2-24 Toyosu, Koto-ku, Tokyo 135-0061, Japan www.renesas.com

#### Trademarks

Renesas and the Renesas logo are trademarks of Renesas Electronics Corporation. All trademarks and registered trademarks are the property of their respective owners.

#### **Contact Information**

For further information on a product, technology, the most up-to-date version of a document, or your nearest sales office, please visit <u>www.renesas.com/contact-us/</u>.