# RENESAS

## ForgeFPGA Workshop User Guide v6.45

This user guide will help you navigate the ForgeFPGA Workshop software and understand the different built-in features of the software in detail.

## Contents

| 1. | Soft | ware Ove | erview                             | 6  |
|----|------|----------|------------------------------------|----|
| 2. | Forg | e FPGA   | Workshop                           | 8  |
|    | 2.1  | FPGA E   | Editor                             | 8  |
|    |      | 2.1.1    | Flowchart                          | 8  |
|    |      | 2.1.2    | Main Menu                          | 10 |
|    |      | 2.1.3    | Toolbar                            | 11 |
|    |      | 2.1.4    | Work Area                          | 12 |
|    |      | 2.1.5    | Design Template                    | 12 |
|    |      | 2.1.6    | Messages Panel                     | 16 |
|    |      | 2.1.7    | Control Panel                      | 16 |
|    |      | 2.1.8    | Settings                           | 17 |
|    | 2.2  | Writing  | HDL Code                           | 19 |
|    |      | 2.2.1    | Importing/Export RTL Files         | 20 |
|    | 2.3  | Module   | s Library                          | 21 |
|    | 2.4  | RTL Sy   | nthesis                            | 22 |
|    |      | 2.4.1    | Post-Synth RTL                     | 22 |
|    |      | 2.4.2    | Netlist                            | 23 |
|    |      | 2.4.3    | I/O Planner                        | 23 |
|    |      | 2.4.4    | Synthesis Report                   | 24 |
|    | 2.5  | Genera   | ting the Bitstream                 | 25 |
|    |      | 2.5.1    | Floorplan                          | 25 |
|    |      | 2.5.2    | Resources Report                   | 27 |
|    |      | 2.5.3    | Timing Analysis                    | 28 |
|    | 2.6  | Simulat  | tion                               | 29 |
|    |      | 2.6.1    | Writing a Testbench                | 29 |
|    |      | 2.6.2    | Simulating a Testbench             |    |
|    | 2.7  | PLL Ca   | alculator                          |    |
|    | 2.8  | Macroc   | ell Editor                         | 31 |
|    | 2.9  | Project  | Directory Folder                   | 32 |
| 3. | Debu | Jg       |                                    | 33 |
|    | 3.1  | -        | are Platforms                      |    |
|    |      | 3.1.1    | ForgeFPGA Deluxe Development Board | 34 |
|    |      | 3.1.2    | ForgeFPGA Evaluation Board         |    |
|    | 3.2  | Platforn | n Configuration Guide              |    |
|    | 3.3  |          | Tools                              |    |
|    |      | 3.3.1    | Configuration Button               |    |
|    |      | 3.3.2    | Synchronous Logic Generator        |    |

|    |       | 3.3.3     | Parametric Generator     | 42 |
|----|-------|-----------|--------------------------|----|
|    | 3.4   |           | nalyzer                  |    |
|    | 5.1   | 3.4.1     | Operational Controls.    |    |
|    |       | 3.4.2     | Mode                     |    |
|    |       | 3.4.3     | Triggers                 |    |
|    |       | 3.4.4     | Debugging Controls       |    |
|    |       | 3.4.5     | Presets                  |    |
|    |       | 3.4.6     | Protocol Analyzer        | 46 |
|    |       | 3.4.7     | Import/Export            | 46 |
|    |       | 3.4.8     | Plot Widget              | 47 |
|    |       | 3.4.9     | Cursors                  | 47 |
|    |       | 3.4.10    | Markers                  | 48 |
|    | 3.5   | UART T    | erminal                  | 49 |
|    | 3.6   | DAC To    | ol                       | 50 |
| 4. | Bloc  | k Proper  | ties                     | 51 |
|    | 4.1   | •         | òre                      |    |
|    | 4.2   | Phase L   | ocked Loop (PLL)         | 52 |
|    | 4.3   |           | or (OSC)                 |    |
|    | 4.4   |           | ead Access Memory (BRAM) |    |
|    | 4.5   |           | LEEP) & PWR (nRST)       |    |
|    | 4.6   | General   | Purpose Input Output Pin | 53 |
| 5. | NVM   | Viewer    |                          | 54 |
| 6. | IO PI | anner Sig | gnals                    | 56 |
| 7. | Revis | sion Hist | ory                      | 57 |
| A. | Арре  | endix: Wa | arnings                  | 58 |



## Figures

| Figure 1. Go Configure Software Hub User Interface                   | 7    |
|----------------------------------------------------------------------|------|
| Figure 2. ForgeFPGA Workshop                                         | 8    |
| Figure 3. Toolchain Flowchart                                        | 9    |
| Figure 4. ForgeFPGA Workshop User Interface                          | . 10 |
| Figure 5. ForgeFPGA Workshop Toolbar                                 | 11   |
| Figure 6. Work Area                                                  | 12   |
| Figure 7. FPGA Design Template                                       | 12   |
| Figure 8. Design Template Component Selection                        | . 13 |
| Figure 9. Design Template IO Spec Diff                               | 14   |
| Figure 10. Design Template Module Name                               | . 15 |
| Figure 11. Messages Panel                                            | 16   |
| Figure 12. Control Panel                                             | 17   |
| Figure 13. ForgeFPGA Workshop Settings                               | . 19 |
| Figure 14. Working with Verilog example                              | 20   |
| Figure 15. Importing RTL Files                                       | 20   |
| Figure 16. Exporting RTL Files                                       | 21   |
| Figure 17. Modules Library GUI                                       | 21   |
| Figure 18. Module Library GUI with Parameters                        | 22   |
| Figure 19. Post-Synth RTL                                            | 23   |
| Figure 20. Netlist                                                   | 23   |
| Figure 21. I/O Port Signal Assignment                                | 24   |
| Figure 22. Mapping I/O Ports.                                        | 24   |
| Figure 23. I/O Planner Filter selection                              | 24   |
| Figure 24. Synthesis Report                                          | 25   |
| Figure 25. Floorplan Window                                          | 26   |
| Figure 26. Place and Route Results                                   | 26   |
| Figure 27. Footer Controls                                           | 27   |
| Figure 28. Resources Utilization Report                              | 27   |
| Figure 29. Timing Analysis                                           | 28   |
| Figure 30. Custom Testbench example                                  |      |
| Figure 31. Simple Counter Testbench example from Template Design     | 30   |
| Figure 32. PLL Calculator                                            | 31   |
| Figure 33. Macrocell Editor                                          | 31   |
| Figure 34. Changing the names of Input/Output Pins                   | 32   |
| Figure 35. FPGA Project Folder Structure                             | 32   |
| Figure 36. Check Source File location                                | 33   |
| Figure 37. Development Platform Selector                             | 34   |
| Figure 38. Socket Board Adapter                                      | 34   |
| Figure 39. Assembled equipment for working with a chip in the socket | 35   |
| Figure 40. ForgeFPGA Evaluation Board v2.0                           |      |
| Figure 41. ForgeFPGA Evaluation Board v1.0                           |      |
| Figure 42. Platform Configuration Guide                              |      |
| Figure 43. Debugging Controls                                        |      |
| Figure 44. TP Map                                                    | . 38 |

| Figure 45. Debug Tool                                             |    |
|-------------------------------------------------------------------|----|
| Figure 46. NC (not connected)                                     |    |
| Figure 47. Set to VDD                                             |    |
| Figure 48. Set to GND                                             |    |
| Figure 49. Latched Button with Upper Connection as VDD            | 40 |
| Figure 50. Unlatched Button with Upper Connection as Hi-Z         | 40 |
| Figure 51. Context menu options for Configurable Button           | 40 |
| Figure 52. Synchronous Logic Generator                            | 41 |
| Figure 53. Signal Wizard for Synchronous Logic Generator          | 41 |
| Figure 54. Parametric Generator Command Editor                    |    |
| Figure 55. PWM Command Editor                                     | 42 |
| Figure 56. Clock Command Editor                                   | 42 |
| Figure 57. Clock Command Editor                                   | 43 |
| Figure 58. Logic Analyzer                                         | 43 |
| Figure 59. Trigger Parameters                                     | 44 |
| Figure 60. Trigger Conditions                                     | 44 |
| Figure 61. Trigger Configuration                                  | 44 |
| Figure 62. Debugging Controls                                     | 45 |
| Figure 63. View Options                                           | 45 |
| Figure 64. Logic Analyzer Configuration Presets                   | 45 |
| Figure 65. Protocol Analyzer Decode Options                       | 46 |
| Figure 66. Protocol Analyzer Options                              | 46 |
| Figure 67. Decoded Data                                           | 46 |
| Figure 68. Import/Export from/to CSV format                       | 46 |
| Figure 69. Plot Widget                                            | 47 |
| Figure 70. Half Period Cursor                                     | 47 |
| Figure 71. Period Cursor                                          | 47 |
| Figure 72. Adjustable Period Cursor for Measurement               | 48 |
| Figure 73. Adjustable Period Cursor Measurement between waveforms | 48 |
| Figure 74. Moving markers with context menu                       | 48 |
| Figure 75. Marker Measurements                                    | 49 |
| Figure 76. UART Terminal Tool                                     | 49 |
| Figure 77. UART Terminal Window                                   | 49 |
| Figure 78. Analog I/O Pins on ForgeFPGA Socket Adapter            | 50 |
| Figure 79. DAC Tool on the toolbar                                | 50 |
| Figure 80. DAC Tool Settings                                      | 50 |
| Figure 81. Block Property Editing                                 | 51 |
| Figure 82. FPGA Core's Properties                                 | 52 |
| Figure 83. GPIO Properties                                        | 53 |
| Figure 84. NVM Bits for GPIO7                                     | 54 |
| Figure 85. NVM Bits 0011 after the property has been modified     | 55 |

## References

For related documents and software, please visit our website: https://www.renesas.com/us/en

Download our free ForgeFPGA Designer software [1] and follow the steps in this user guide. User can reference [2] for the datasheet. Use Configuration Document to understand the different modes of configuration [3]. Renesas Electronics provides a complete library of application notes [4] featuring design examples as well as explanations of features and blocks within the Renesas IC. Please visit the <u>product</u> <u>page</u> to download the following :

- [1] Go Configure Software Hub, Software Download, Renesas Electronics
- [2] ForgeFPGA SLG47910 Datasheet, Renesas Electronics
- [3] SLG47910, Configuration Document, Renesas Electronics
- [4] Application Notes, ForgeFPGA Application Notes & Design Files, Renesas Electronics
- [5] ForgeFPGA Deluxe Development Board User Manual, Renesas Electronics
- [6] ForgeFPGA Socket Adapter User Manual, Renesas Electronics
- [7] ForgeFPGA Evaluation Board User Manual, Renesas Electronics
- [8] ForgeFPGA Software Simulation User Manual, Renesas Electronics

## 1. Software Overview

The Go Configure Software Hub is a software product used to create a design for a specific device configuration. The software provides direct access to all GreenPAK, ADCPAK, and ForgeFPGA device features and complete control over each device's routing and configuration options.

The software contains the tools that makes it possible to:

- Create an FPGA Project in HDL
- Program a chip with the created design
- Read a programmed part and import its data into the software
- Run simulations with external components

#### Getting Started:

1. Download and install Go Configure Software Hub from <a href="https://www.renesas.com/us/en/software-tool/go-configure-software-hub">https://www.renesas.com/us/en/software-tool/go-configure-software-hub</a>

Start your project from the Hub window with the following sections:

- Welcome useful info and tips for new users
- · Recent files the list of the recently opened project files
- *Develop* the chip Part Number selection. See the Details section to learn more about the selected chip.

At the bottom-right of the window, you can find the New, Open, and Close buttons, which allow you to start a new project for a selected Part Number, to open an existing project, or to close the Go Configure Software Hub. The Datasheets and User Guides buttons redirect you to the Renesas website, where you can download the corresponding files.

- Demo the list of Demo projects. You can use the specific Demo Board for project debugging
- Application Notes design examples for different purposes. An application note includes a design
  description with various Integrated Circuits (ICs) and a preconfigured circuit project, where you can
  make customized changes
- 2. Select the SLG47910 (rev BB) Part Number & open it
- 3. Specify the Project Settings like  $V_{\text{DD}},\,V_{\text{DDIO}}$  and Temperature
- 4. Write the HDL Code in the HDL Editor Window
- 5. Test the design with the Debug Tool, using the Simulation feature or any of the supported hardware development platforms.

### FPGA Workshop User Guide

| All<br>GreenPAK<br>AnalogPAK<br>HVPAK<br>Power GreenPAK<br>AutomotivePAK<br>ForgeFPGA | Part Number           SIG47004-AP           SIG51003V           SIG47003V           SIG47003V           SIG51001C           SIG4701V (Rev AA)                                                                                                                                                              | DS<br>Contact us<br>Contact us<br>Contact us<br>Contact us<br>Contact us<br>PDF<br>PDF<br>PDF<br>PDF<br>PDF<br>PDF<br>PDF<br>PDF                   | V (Rev B<br>240 to 550<br>2.80 to 500<br>2.80 to 500<br>2.40 to 550<br>2.40 to 550<br>2.30 to 550                      | VDD2 (V)<br>1.20 to 5.00<br>-<br>-<br>1.71 to 3.60<br>1.71 to 3.60<br>1.71 to 3.60<br>1.71 to 3.60<br>4.50 to 26.40                                                                                                                                      | GPI[GPO]GPIO<br>1 0 7<br>1 0 4<br>5 0 10<br>1 0 13<br>1 0 5<br>1 0 3<br>0 0 19<br>0 0 19<br>0 0 19<br>1 0 5<br>1 0 7<br>1 2 7                                                                                                                                                            | AEC-Q100<br>Grade 1<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-                                                                                                                                                                                                                                                                                                  | 2x Op Amp or 1x In-Amp; 2x Rheosta<br>3x LDO (1x HP 475 mA; 1x HV 500 mA; 1x LV<br>2x Op Amp; 2x Rheo<br>ADC (14-bit; SAR), DAC (12-bit), PGA 1x-64x,<br>Synchronized; 7x LDO (2x HP 475 mA; 3x HV<br>Synchronized; 6x LDO (1x HP 475 mA; 4x HV<br>Dense Logic Array<br>8x LDO (3x HV 500 mA; 2x HC 500 mA;<br>2x Op Amp or 1x In-Amp; 2x Rheostat; 2x. |
|---------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AnalogPAK<br>HVPAK<br>Power GreenPAK<br>AutomotivePAK                                 | SLG47004-AP     SLG51003V     SLG47003V     SLG47011V     SLG51000C     SLG51001C     SLG51001C     SLG51001C     SLG47910V (Rev AA)     SLG47910V (Rev B)     SLG47004V     SLG47004V     SLG47115V                                                                                                       | Contact us<br>Contact us<br>Contact us<br>PDF<br>PDF<br>Contact us<br>Contact us<br>PDF<br>PDF<br>PDF<br>PDF<br>PDF                                | 2.40 to 5.50<br>2.80 to 5.00<br>2.30 to 5.50<br>1.71 to 3.60<br>2.80 to 5.00<br>2.80 to 5.00<br>0.99 to 1.21<br>0.99 to 1.21<br>2.80 to 5.00<br>2.40 to 5.50<br>2.30 to 5.50                                     | 1.20 to 5.00<br>-<br>-<br>1.71 to 3.60<br>1.71 to 3.60<br>1.20 to 5.00<br>4.50 to 26.40                                                                                                                                                                  | 1 0 7<br>1 0 4<br>5 0 10<br>1 0 13<br>1 0 5<br>1 0 3<br>0 0 19<br>0 0 19<br>1 0 5<br>1 0 7                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                     | 3x LDO (1x HP 475 mA; 1x HV 500 mA; 1x LV<br>2x Op Amp; 2x Rheet<br>ADC (14-bit; SAR), DAC (12-bit), PGA 1x-64x,<br>Synchronized; 7x LDO (2x HP 475 mA; 3x HV<br>Synchronized; 6x LDO (1x HP 475 mA; 4x HV<br>Dense Logic Array<br>Barse Logic Array<br>8x LDO (3x HV 500 mA; 2x HC 500 mA;<br>2x Op Amp or 1x In-Amp; 2x Rheostat; 2x /                |
| AnalogPAK<br>HVPAK<br>Power GreenPAK<br>AutomotivePAK                                 | SLG51003V           SLG47003V           SLG47003V           SLG51000C           SLG51001C           SLG51001C           SLG51001C           SLG51002C           SLG51002C           SLG51002C           SLG51002C           SLG47910V (Rev AA)           SLG47004V           SLG47004V           SLG47115V | Contact us<br>Contact us<br>Contact us<br>PDF<br>PDF<br>Contact us<br>Contact us<br>PDF<br>PDF<br>PDF<br>PDF<br>PDF                                | 2.80 to 5.00<br>2.30 to 5.50<br>1.71 to 3.60<br>2.80 to 5.00<br>2.80 to 5.00<br>0.99 to 1.21<br>0.99 to 1.21<br>2.80 to 5.00<br>2.40 to 5.50<br>2.30 to 5.50                                                     | -<br>-<br>1.71 to 3.60<br>1.71 to 3.60<br>1.20 to 5.00<br>-<br>4.50 to 26.40                                                                                                                                                                             | 1 0 4<br>5 0 10<br>1 0 13<br>1 0 3<br>0 0 19<br>0 0 19<br>1 0 5<br>1 0 7                                                                                                                                                                                                                 | Grade 1<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-<br>-                                                                                                                                                                                                                                                                                                                                            | ADC (14-bit; SAR), DAC (12-bit), PGA 1x-64x,<br>Synchronized; 7x LDO (2x HP 475 mA; 3x HV<br>Synchronized; 6x LDO (1x HP 475 mA; 4x HV<br>Dense Logic Array<br>8x LDO (3x HV 500 mA; 2x HC 500 mA;<br>2x Op Amp or 1x In-Amp; 2x Rheostat; 2x A                                                                                                         |
| HVPAK<br>Power GreenPAK<br>AutomotivePAK                                              | SLG47003V     SLG47011V     SLG47011V     SLG51000C     SLG51001C     SLG47910V (Rev AA)     SLG47910V (Rev BB)     SLG47910V (Sev BB)     SLG47004V     SLG47105V                                                                                                                                         | Contact us<br>Contact us<br>PDF<br>PDF<br>Contact us<br>Contact us<br>PDF<br>PDF<br>PDF<br>PDF                                                     | 2.30 to 5.50<br>1.71 to 3.60<br>2.80 to 5.00<br>2.80 to 5.00<br>0.99 to 1.21<br>0.99 to 1.21<br>2.80 to 5.00<br>2.40 to 5.50<br>2.30 to 5.50                                                                     | -<br>-<br>1.71 to 3.60<br>1.71 to 3.60<br>1.20 to 5.00<br>-<br>4.50 to 26.40                                                                                                                                                                             | 5 0 10<br>1 0 13<br>1 0 5<br>1 0 3<br>0 0 19<br>0 0 19<br>1 0 5<br>1 0 7                                                                                                                                                                                                                 | -                                                                                                                                                                                                                                                                                                                                                                                                                   | 2x Op Amp; 2x Rheos<br>ADC (14-bit; SAR), DAC (12-bit), PGA 1x-64x,<br>Synchronized; 7x LDO (2x HP 475 mA; 3x HV<br>Synchronized; 6x LDO (1x HP 475 mA; 4x HV<br>Dense Logic Array<br>Back LDO (3x HV 500 mA; 2x HC 500 mA;<br>2x Op Amp or 1x In-Amp; 2x Rheostat; 2x /                                                                                |
| HVPAK<br>Power GreenPAK<br>AutomotivePAK                                              | SLG47011V     SLG51000C     SLG51001C     SLG51001C     SLG47910V (Rev AA)     SLG47910V (Rev BB)     SLG51002C     SLG47014V     SLG47115V                                                                                                                                                                | Contact us<br>PDF<br>PDF<br>Contact us<br>Contact us<br>PDF<br>PDF<br>PDF<br>PDF                                                                   | 1.71 to 3.60<br>2.80 to 5.00<br>2.80 to 5.00<br>0.99 to 1.21<br>0.99 to 1.21<br>2.80 to 5.00<br>2.40 to 5.50<br>2.30 to 5.50                                                                                     | 1.71 to 3.60<br>1.20 to 5.00<br>-<br>4.50 to 26.40                                                                                                                                                                                                       | 1 0 13<br>1 0 5<br>1 0 3<br>0 0 19<br>0 0 19<br>1 0 5<br>1 0 7                                                                                                                                                                                                                           | -                                                                                                                                                                                                                                                                                                                                                                                                                   | Dense Logic Array;<br>Dense Logic Array;<br>8x LDO (3x HV 500 mA; 2x HC 500 mA;<br>2x Op Amp or 1x In-Amp; 2x Rheostat; 2x /                                                                                                                                                                                                                            |
| Power GreenPAK<br>AutomotivePAK                                                       | <ul> <li>SLG51000C</li> <li>SLG51001C</li> <li>SLG47910V (Rev AA)</li> <li>SLG47910V (Rev BB)</li> <li>SLG51002C</li> <li>SLG47004V</li> <li>SLG47004V</li> <li>SLG47115V</li> </ul>                                                                                                                       | PDF<br>PDF<br>Contact us<br>Contact us<br>PDF<br>PDF<br>PDF<br>PDF                                                                                 | 2.80 to 5.00<br>2.80 to 5.00<br>0.99 to 1.21<br>2.80 to 5.00<br>2.40 to 5.50<br>2.30 to 5.50                                                                                                                     | 1.71 to 3.60<br>1.20 to 5.00<br>-<br>4.50 to 26.40                                                                                                                                                                                                       | 1 0 5<br>1 0 3<br>0 0 19<br>0 0 19<br>1 0 5<br>1 0 7                                                                                                                                                                                                                                     | -<br>-<br>-<br>-<br>-                                                                                                                                                                                                                                                                                                                                                                                               | Synchronized; 7x LDO (2x HP 475 mA; 3x HV<br>Synchronized; 6x LDO (1x HP 475 mA; 4x HV<br>Dense Logic Array<br>Bx LDO (3x HV 500 mA; 2x HC 500 mA;<br>2x Op Amp or 1x In-Amp; 2x Rheostat; 2x A                                                                                                                                                         |
| Power GreenPAK<br>AutomotivePAK                                                       | SLG51001C<br>SLG47910V (Rev AA)<br>SLG47910V (Rev BB)<br>SLG47910V (Rev BB)<br>SLG51002C<br>SLG47004V<br>SLG47004V                                                                                                                                                                                         | PDF<br>Contact us<br>Contact us<br>PDF<br>PDF<br>PDF                                                                                               | 2.80 to 5.00<br>0.99 to 1.21<br>2.80 to 5.00<br>2.40 to 5.50<br>2.30 to 5.50                                                                                                                                     | 1.71 to 3.60<br>1.20 to 5.00<br>-<br>4.50 to 26.40                                                                                                                                                                                                       | 1 0 3<br>0 0 19<br>0 0 19<br>1 0 5<br>1 0 7                                                                                                                                                                                                                                              | -                                                                                                                                                                                                                                                                                                                                                                                                                   | Synchronized; 6x LDO (1x HP 475 mA; 4x HV<br>Dense Logic Array;<br>Bense Logic Array;<br>8x LDO (3x HV 500 mA; 2x HC 500 mA;<br>2x Op Amp or 1x In-Amp; 2x Rheostat; 2x /                                                                                                                                                                               |
| Power GreenPAK<br>AutomotivePAK                                                       | SLG47910V (Rev AA)<br>SLG47910V (Rev BB)<br>SLG51002C<br>SLG47004V<br>SLG47115V                                                                                                                                                                                                                            | Contact us<br>Contact us<br>PDF<br>PDF<br>PDF<br>PDF                                                                                               | 0.99 to 1.21<br>0.99 to 1.21<br>2.80 to 5.00<br>2.40 to 5.50<br>2.30 to 5.50                                                                                                                                     | 1.71 to 3.60<br>1.20 to 5.00<br>-<br>4.50 to 26.40                                                                                                                                                                                                       | 0 0 19<br>0 0 19<br>1 0 5<br>1 0 7                                                                                                                                                                                                                                                       | -                                                                                                                                                                                                                                                                                                                                                                                                                   | 8x LDO (3x HV 500 mA; 2x HC 500 mA;<br>2x Op Amp or 1x In-Amp; 2x Rheostat; 2x A                                                                                                                                                                                                                                                                        |
| AutomotivePAK                                                                         | SLG47910V (Rev BB)<br>SLG51002C<br>SLG47004V<br>SLG47115V                                                                                                                                                                                                                                                  | Contact us<br>PDF<br>PDF<br>PDF<br>PDF                                                                                                             | 0.99 to 1.21<br>2.80 to 5.00<br>2.40 to 5.50<br>2.30 to 5.50                                                                                                                                                     | 1.71 to 3.60<br>1.20 to 5.00<br>-<br>4.50 to 26.40                                                                                                                                                                                                       | 0 0 19<br>1 0 5<br>1 0 7                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                     | Dense Logic Array<br>8x LDO (3x HV 500 mA; 2x HC 500 mA;<br>2x Op Amp or 1x In-Amp; 2x Rheostat; 2x A                                                                                                                                                                                                                                                   |
| AutomotivePAK                                                                         | SLG51002C<br>SLG47004V                                                                                                                                                                                                                                                                                     | PDF<br>PDF<br>PDF                                                                                                                                  | 2.80 to 5.00<br>2.40 to 5.50<br>2.30 to 5.50                                                                                                                                                                     | 1.20 to 5.00<br>-<br>4.50 to 26.40                                                                                                                                                                                                                       | 1 0 5<br>1 0 7                                                                                                                                                                                                                                                                           | -                                                                                                                                                                                                                                                                                                                                                                                                                   | 8x LDO (3x HV 500 mA; 2x HC 500 mA;<br>2x Op Amp or 1x In-Amp; 2x Rheostat; 2x A                                                                                                                                                                                                                                                                        |
|                                                                                       | SLG51002C<br>SLG47004V<br>SLG47115V                                                                                                                                                                                                                                                                        | PDF<br>PDF                                                                                                                                         | 2.40 to 5.50<br>2.30 to 5.50                                                                                                                                                                                     | -<br>4.50 to 26.40                                                                                                                                                                                                                                       | 1 0 7                                                                                                                                                                                                                                                                                    | -                                                                                                                                                                                                                                                                                                                                                                                                                   | 8x LDO (3x HV 500 mA; 2x HC 500 mA;<br>2x Op Amp or 1x In-Amp; 2x Rheostat; 2x A                                                                                                                                                                                                                                                                        |
|                                                                                       | 5LG47115V                                                                                                                                                                                                                                                                                                  | PDF                                                                                                                                                | 2.30 to 5.50                                                                                                                                                                                                     | 4.50 to 26.40                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                          | ÷                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                       |                                                                                                                                                                                                                                                                                                            |                                                                                                                                                    |                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                          | 1 2 7                                                                                                                                                                                                                                                                                    | 2                                                                                                                                                                                                                                                                                                                                                                                                                   | to 11 /De Half, Belder D. Date                                                                                                                                                                                                                                                                                                                          |
| ForgeFPGA                                                                             | III SLG47105V                                                                                                                                                                                                                                                                                              | PDF                                                                                                                                                | 2 20 4- 5 50                                                                                                                                                                                                     |                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                     | 1x H-/2x Half- Bridge; 2x PWN                                                                                                                                                                                                                                                                                                                           |
| ForgeFPGA                                                                             |                                                                                                                                                                                                                                                                                                            |                                                                                                                                                    | 2.30 10 5.50                                                                                                                                                                                                     | 3.00 to 13.20                                                                                                                                                                                                                                            | 1 4 7                                                                                                                                                                                                                                                                                    | -                                                                                                                                                                                                                                                                                                                                                                                                                   | 2x H-/4x Half- Bridge; 2x PWM;                                                                                                                                                                                                                                                                                                                          |
|                                                                                       |                                                                                                                                                                                                                                                                                                            |                                                                                                                                                    |                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                          | Details                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                       |                                                                                                                                                                                                                                                                                                            | 10                                                                                                                                                 |                                                                                                                                                                                                                  | and I Day during a series I Ar                                                                                                                                                                                                                           | oplication notes   Resource                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                     | A                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                       | Package:<br>QFN-24<br>Supported Development<br>• ForgeFPGA Advanc<br>• ForgeFPGA Evaluat                                                                                                                                                                                                                   | Platforms:<br>ed Developmen                                                                                                                        |                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                          | cket Adapter #1 (SLG4SA                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                       | (OTP) Non-Volatile Memor                                                                                                                                                                                                                                                                                   | y (NVM) to conf                                                                                                                                    | igure the interconne                                                                                                                                                                                             | ct logic, the IO pins, an                                                                                                                                                                                                                                | nd the Macrocells of the !                                                                                                                                                                                                                                                               | SLG47910V. This highl                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                       | • Equivalent<br>• 1.8 k DFFs;<br>• 5 kb distrib<br>• 32 kb BRAN                                                                                                                                                                                                                                            | to 900 4-bit LUT:<br>uted memory;<br>⁄l;                                                                                                           |                                                                                                                                                                                                                  | ;                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                         |
|                                                                                       |                                                                                                                                                                                                                                                                                                            | (OTP) Non-Volatile Memor<br>applications to be designe<br>• Dense Logic Array:<br>• Equivalent<br>• 1.8 k DFFs;<br>• 5 kb distrib<br>• 32 kb BRA). | (OTP) Non-Volatile Memory (NVM) to conf<br>applications to be designed within a very s<br>• Dense Logic Array:<br>• Equivalent to 900 4-bit LUT:<br>• 1.8 k DFFs;<br>• 5 kb distributed memory;<br>• 32 kb BRAM; | (OTP) Non-Volatile Memory (NVM) to configure the intercome<br>applications to be designed within a very small, low power inte<br>• Dense Logic Array:<br>• Equivalent to 900 4-bit LUTs;<br>• 1.8 k DFFs;<br>• 5 kb distributed memory;<br>• 32 kb BRAM; | (OTP) Non-Volatile Memory (NVM) to configure the interconnect logic, the IO pins, ar<br>applications to be designed within a very small, low power integrated circuit. The mac<br>• Dense Logic Array:<br>• Equivalent to 900 4-bit LUTs;<br>• 1.8 k DFFs;<br>• 5 kb distributed memory; | <ul> <li>(OTP) Non-Volatile Memory (NVM) to configure the interconnect logic: the IO pins, and the Macrocells of the applications to be designed within a very small, low power integrated circuit. The macrocells in the device incl         <ul> <li>Dense Logic Array:</li> <li>Equivalent to 900 4-bit LUTs;</li> <li>1.8 k DFFs;</li> <li>5 kb distributed memory;</li> <li>32 kb BRAM;</li> </ul> </li> </ul> | Equivalent to 900 4-bit LUTs;     1.8 k DFFs;     5 kb distributed memory;     32 kb BRAM;                                                                                                                                                                                                                                                              |

Figure 1. Go Configure Software Hub User Interface

## 2. Forge FPGA Workshop

The ForgeFPGA Workshop is the main window of the software. This window displays the FPGA Core and each of the special components that connect to it such as the Phase Locked Loop (PLL), Oscillator (OSC), BRAM, and the 19 GPIOs. The FPGA Editor can be launched from the middle button on the toolbar at the top in addition to navigating to Main Menu Tools  $\rightarrow$  FPGA Editor or by double-clicking the on the FPGA Core (grey square).



Figure 2. ForgeFPGA Workshop

## 2.1 FPGA Editor

The FPGA Editor is an Integrated Design Environment (IDE) tool designed to create and configure the FPGA logic. The editor allows you to create designs for Field-Programmable Gate Arrays (FPGAs) using a Hardware Description Language (HDL)\*. Before the design is programmed onto the FPGA, the editor provides an option to simulate it first and ensure it operates correctly.

In addition, the FPGA Editor makes it possible to work with external designs by importing files with the created logic mapped to the components. Find the descriptions for these and other features in the following sections.

### 2.1.1 Flowchart

A flowchart is available to provide a step-by-step guide on creating a design from start to finish. The flowchart describes all the important aspects of using the ForgeFPGA software.

#### FPGA Workshop User Guide



#### Figure 3. Toolchain Flowchart

The development software consists of the main menu, toolbar, main work area, logger panel and control panel (see Figure 4).

| HorgeFPGA Workshop *                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Save Modules Library New Custom Module  | Ng         m         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$         \$\$ </th |
| Resources Report                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Compile project to get resources report |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Sources                                 | <pre>reg [3:0] r_counter_up_down;<br/>reg [1:0] r_up_down_sync;<br/>reg [1:0] r_rst;<br/>wire w_reset;<br/>assign o_up_down_oe = 1'b0;<br/>assign o_couctrone = 4'b1111;<br/>assign o_cosc_ctrl_en = 1'b1;<br/>always @(posedge i_clk) begin<br/>r_rst[0] &lt;= i_nreset;<br/>r_rst[1] &lt;= ~r_rst[0];<br/>always @(posedge i_clk) begin<br/>if (w_reset)<br/>r_up_down_sync[0] &lt;= i_up_down;<br/>end<br/>end<br/>always @(posedge i_clk) begin<br/>if (w_reset)<br/>r_up_down_sync[1] &lt;= r_up_down_sync[0];<br/>end<br/>always @(posedge i_clk) begin<br/>if (w_reset)<br/>r_counter_up_down &lt;= 4'h0;<br/>r_counter_up_down &lt;= r_counter_up_down + 4'd1;<br/>else if (&lt;-r_up_down &lt;= r_counter_up_down &lt;= 4'd1;<br/>end</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Synthesize                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Generate Bitstream                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

Figure 4. ForgeFPGA Workshop User Interface

### 2.1.2 Main Menu

Main Menu contains controls are described below:

#### File

- └ Save save current project
- └ Save As save current project under another name
- Modules Library open IP Blocks Wizard
- New Custom Module add new module
- New Custom Testbench add new testbench
- L Import used to import an RTL code, testbench and Netlist from another software/synthesis tool
  - L Custom Module
  - L Custom Testbench
  - Netlist
- ∟ Export
  - L Custom Module
  - Library Module
  - L Testbench
- Load Design Template

- L Simple Counter
- $\ \ Close$

Edit (menu works with editable tabs)

- ∟ Undo
- ∟ Redo
- ∟ Cut
- ∟ Сору
- ∟ Paste
- └ Delete
- └ Select All

#### Tools

- Run Synthesis synthesize HDL into low-level constructs.
- Generate Bitstream compilation and mapping low-level constructs to specific device blocks.
- Floorplan
  - Load customer PnR
- └ Simulation
  - L Simulate Testbench
- L I/O Planner
  - └ Clear data
  - L Import I/O Spec
  - L Export I/O Spec
  - Import I/O Spec from CSV
  - ⊢ Export I/O Spec to CSV

#### Window

- Netlist read-only tab with a description of the connectivity of an electronic circuit
- Post-Synth RTL (register transfer layer)
- L I/O Planner
- ∟ Floorplan
- L Synthesis Report
- L Resources Report
- L Timing Analysis
- L Macrocell Editor
- └ Messages

#### Options

└ Settings

#### 2.1.3 Toolbar

The top toolbar provides quick access to a set of tools and actions. See the description of all the available tools in the next few sections.

| Ш    | <b>\$</b>       |                   |        | Nŗ.     | RTL            | 200         |           | di.              | di.              | 0               |                  | (*13)<br>6 (*<br>14 (* |                    |
|------|-----------------|-------------------|--------|---------|----------------|-------------|-----------|------------------|------------------|-----------------|------------------|------------------------|--------------------|
| Save | Modules Library | New Custom Module | Logger | Netlist | Post-Synth RTL | I/O Planner | Floorplan | Synthesis Report | Resources Report | Timing Analysis | Macrocell Editor | PLL Calculator         | Simulate Testbench |

#### Figure 5. ForgeFPGA Workshop Toolbar

#### 2.1.4 Work Area

The work area is the central white portion of the software where the user can type their desired HDL Code. The work area has a split screen option (see Figure 6) which allows the user to split the screen and work with more than one tool simultaneously. The user can choose which views appear in either of side of the split screen by clicking the tool. The user can also close the split screen when not needed.

| 💌 main.v 🛛 🔯 I/O Planner 🛛 🗷 i2c_master.v 🕄 🔥 Resources Report 🔀 🔒 Synthesis Report 🕄 💷 🚬 | 💌 main.v 🔀 🐶 I/O Planner 🔀 | 💌 i2c_master.v 🔀 |                                  |
|-------------------------------------------------------------------------------------------|----------------------------|------------------|----------------------------------|
| 1 2                                                                                       | Filter:                    | ✔ Misc ✔ BRAM ¥  | CLK ✔ GPIO ✔ OSC_ctrl ✔ PLL_ctrl |
| 3 #### Resource Utilization Report ####<br>4                                              | FUNCTION                   | DIRECTION        | PORT                             |
| 5 Top level module name: simple_counter<br>6                                              | LOGIC_AS_CLK0              | Input            |                                  |
| 7 Resource usage:                                                                         | LOGIC_AS_CLK1              | Input            |                                  |
| 8 3 Logic 6-LUT CLBs<br>9 5 CLB LUTs utilized (up to 4 per CLB)                           | OSC_CLK                    | Input            |                                  |
| 10 1 of which are dual 5-input LUTs<br>11 6 LUTs total                                    | PLL_CLK                    | Input            |                                  |
| 12 6 CLB FFs utilized (up to 4 pairs per CLB)                                             | REF_BRAM(03)_READ_CLK      | Output           |                                  |
| 13 5 of which are LUT-FF combination<br>14 6 FFs total                                    | REF_BRAM(03)_WRITE_CLK     | Output           |                                  |
| 15 7 I/O CLBs                                                                             | REF_BRAM(47)_READ_CLK      |                  |                                  |
| 16 2 Input pins<br>17 2 Input FFs utilized                                                | REF_BRAM(47)_WRITE_CLK     |                  |                                  |
| 18 10 Output pins                                                                         | BRAM4 WDATA[5]             | Output           |                                  |
| 19 4 Output FFs utilized<br>20 1 Clock                                                    |                            |                  |                                  |
| 21 Clock 0: net 7, i_clk, Fanout: 7 CLBs                                                  | BRAM4_WDATA[4]             | Output           |                                  |
| 22 need 0 DSP and 1 Logic-Memory EFLX 1K Tiles.                                           | BRAM4_RDATA[5]             | Input            |                                  |
| 24                                                                                        | BRAM4_RDATA[4]             | Input            |                                  |
| 25 #### Resource Utilization Complete ####                                                | BRAM4_WDATA[7]             | Output           |                                  |
| 27 TILE-REQ: 0 0 0 1                                                                      | BRAM4_WDATA[6]             | Output           |                                  |
| 28<br>29 ### Total EFLX resources from current floorplan: ###                             | BRAM4_RDATA[7]             | Input            |                                  |
| 30 184 IOBs                                                                               | BRAM4_RDATA[6]             | Input            |                                  |
| 31 140 Logic 6-LUT CLBs<br>32 40 CLBs support RAM/SR                                      | BRAM4_WCLKINV              | Output           |                                  |
| 33                                                                                        |                            |                  |                                  |
| 34 Usage of Logic CLBs is 2.1%.<br>35 Logic-Memory CLB for RAM/Shift-Register is 0.0%.    | BRAM4_RCLKINV              | Output           |                                  |
|                                                                                           | BRAM4_RATIO[0]             | Output           | Ŧ                                |

Figure 6. Work Area

## 2.1.5 Design Template

The Design Template offers pre-built designs that can be seamlessly integrated into your project. It can be found under *FPGA Editor*  $\rightarrow$  *File*  $\rightarrow$  *Load Design Template* (see Figure 7).

| 8 F  | orgeFPGA Worksh  | op (unt | itled2.ffpg | a]  |                           |           |          |
|------|------------------|---------|-------------|-----|---------------------------|-----------|----------|
| File | Edit Tools W     | /indow  | Options     |     |                           |           |          |
| 1    | Save             |         | Ctrl+S      |     |                           |           | <u> </u> |
|      | Save All         |         | Ctrl+Shif   | t+S |                           |           |          |
| -    | Modules Library  |         |             |     | Module                    | Messages  | ) N      |
| 34   | New Custom Mod   | ule     |             |     |                           |           |          |
|      | New Custom Test  | bench   |             |     |                           | N         | mair     |
| -    | Import           |         |             | Þ   |                           |           |          |
|      | Export           |         |             | Þ   |                           |           |          |
|      | Load Design Temp | olate   |             | Þ   | <ul> <li>Simpl</li> </ul> | e Counter |          |
|      | Close            |         | Ctrl+Q      |     |                           |           |          |
| _    |                  |         |             |     |                           |           |          |

Figure 7. FPGA Design Template

Upon selecting a design template, the Design Template Wizard will appear. It will guide you through component selection, IO Spec diff review, and module name suggestions.

Component Selection makes it possible to choose the components to proceed with:

- Verilog Module
- Verilog Testbench
- IO Spec



Figure 8. Design Template Component Selection

Select all components or individually select them as needed depending on the desired outcome for your project. The choices made at this stage determine the next steps in the process.

#### FPGA Workshop User Guide

IO Spec generates an IO Spec Diff, presenting a comparison between the existing design port records and the
ones associated with the selected template. This serves as a cautionary step as your current port
configurations could potentially be overwritten by those of the chosen template. The software highlights
conflicting entries in yellow. You can choose to focus solely on conflicts by selecting the Show Conflicts Only
option. However, if you prefer not to review the IO Specs, the software streamlines the process by skipping
the IO Spec Diff (see Figure 9). In this scenario, the tool will prompt you straight to the Module name.

| 8 | Design Template                                                              |                                        | ×                                                       |
|---|------------------------------------------------------------------------------|----------------------------------------|---------------------------------------------------------|
|   | Simple Counter<br>IO Spec Diff                                               |                                        | RENESAS                                                 |
|   | The following PORT records are used in this Design proceed with this change? | gn Template and will overwrite the exi | sting rows in the I/O Planner. Are you sure you want to |
|   | FUNCTION                                                                     | CURRENT                                | POTENTIAL                                               |
|   | FPGA_CORE_READY                                                              |                                        | i_nreset                                                |
|   | OSC_EN                                                                       |                                        | o_osc_ctrl_en                                           |
|   | [PIN 17] GPIO4_OE                                                            |                                        | o_counter_oe[3]                                         |
|   | [PIN 17] GPIO4_OUT                                                           |                                        | o_counter[3]                                            |
|   | [PIN 16] GPIO3_OE                                                            |                                        | o_counter_oe[2]                                         |
|   | [PIN 16] GPIO3_OUT                                                           |                                        | o_counter[2]                                            |
|   | [PIN 15] GPIO2_OE                                                            |                                        | o_counter_oe[1]                                         |
|   | [PIN 15] GPIO2_OUT                                                           |                                        | o_counter[1]                                            |
|   | [PIN 14] GPIO1_OE                                                            |                                        | o_counter_oe[0]                                         |
|   | [PIN 14] GPIO1_OUT                                                           |                                        | o_counter[0]                                            |
|   | [PIN 13] GPIO0_OE                                                            |                                        | o_up_down_oe                                            |
|   | [PIN 13] GPIO0_IN                                                            |                                        | i_up_down                                               |
|   | OSC_CLK                                                                      |                                        | i_clk                                                   |
|   |                                                                              |                                        |                                                         |
|   |                                                                              |                                        | < Back Next > Cancel                                    |

Figure 9. Design Template IO Spec Diff

 Module Name assigns names to your Verilog Module and/or Testbench. If you choose to skip Verilog Module and Verilog Testbench in the Component Selection window, the default names are assigned.

| 🕼 Design Template             | ×                                  |
|-------------------------------|------------------------------------|
| Simple Counter<br>Module Name | RENESAS                            |
|                               |                                    |
|                               |                                    |
|                               |                                    |
| Select Name for the Module    |                                    |
| simple_counter.v              | ٢                                  |
| Select Name for the Testbench |                                    |
| simple_counter_tb.vt          | 0                                  |
|                               |                                    |
|                               |                                    |
|                               |                                    |
|                               |                                    |
|                               |                                    |
|                               |                                    |
|                               |                                    |
|                               |                                    |
|                               | < <u>Back</u> <u>Finish</u> Cancel |

Figure 10. Design Template Module Name

Once the template setup is complete, new elements will be made available in the workspace.

The Design Template Verilog code and Testbench names will appear in the Sources list, with corresponding tabs displaying the actual code and Testbench details.

Additionally, the I/O Planner tab will reflect these changes as well, showcasing the inclusion of port records from the selected design.

Once the integration of the design template is done, you can assess its functionality by running a simulation.

#### 2.1.6 Messages Panel

Here you can see the generated messages that appear after you use Synthesize, Generate Bitstream and Simulation procedure.

- General Log shows information messages along with warnings and errors that were recorded while
  processing the design.
- Synthesis Log and Bitstream Log provides the output generated while the procedure is performed
- Issues displays the warning and error messages that are automatically generated by the software when
  required. Once you receive a syntax error, you can right-click on it and select 'Show in Editor' to highlight the
  line in your HDL code where the mistake was detected.

💭 General Log 👘 💭 Synthesis Log 👘 Bitstream Log 🔥 Issues

10/21/24 4:33 PM > Saving the state of the project.

Figure 11. Messages Panel

### 2.1.7 Control Panel

From the left control panel, you can access (see Figure 12):

- Resources Report Extracted from the resource usage report. It shows the part of available resources utilized by the design sources.
- Sources a list of all HDL sources and external netlists that are in the current project file. Here you can find the following subcategories:
  - Custom Code
  - Modules Library
  - Testbenches
  - External Netlists

The Sources list can be customized via the context menu with the options to Add, Delete, or Rename the sources.

• Synthesize and Generate Bitstream – main controls to run toolchain on your design to produce chip configuration. Hover over the icon next to the procedure button to see the status details, such as whether the procedure was successful, failed or if the Verilog file has been changed.

6 X

| Resources Report                                                                                                                                                                                                                                      |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLBs total: 3/140<br>IOBs total: 7/184<br>CLB LUTs: 6/1120<br>CLB FFs: 6/1120<br>IOB FFs: 6/736<br>Input pins: 2/368<br>Output pins: 10/368                                                                                                           |
| Sources                                                                                                                                                                                                                                               |
| <ul> <li>Project</li> <li>Project</li> <li>Spurce Code</li> <li>Custom Code</li> <li>main.v</li> <li>Modules Library</li> <li>i2c_master.v</li> <li>Testbenches</li> <li>i2c_master_tb.vt</li> <li>External Netlists</li> <li>netlist.edif</li> </ul> |
| ✓ Use external Netlist                                                                                                                                                                                                                                |
| netlist.edif -                                                                                                                                                                                                                                        |
| 🖀 Synthesize 🔘                                                                                                                                                                                                                                        |
| Generate Bitstream                                                                                                                                                                                                                                    |

Figure 12. Control Panel

#### 2.1.8 Settings

The user can access the settings from the *Main Menu*  $\rightarrow$  *Options*  $\rightarrow$  *Settings*. The user can change various settings for the project and change some user settings in this GUI.

- A. Project Settings
  - *a.* Synthesize a process where the HDL code is compiled and converts a high-level description down to lower-level description, for example logic gates.
    - *i. Flatten* Flatten design before synthesis. This option instructs the tool to fully flatten the hierarchy leaving only the top level. Cells and/or modules with the 'keep\_hierarchy' attributes set will not be flattened by this command.
    - *ii.* No DSP Do not use DSPs to implement multipliers and associated logic during the synthesis procedure.
    - *iii.* Keep Create extra KEEP nets by allowing a cell to drive multiple nets while generating the EDIF netlist.
    - *iv.* Use ABC9 Use ABV9 for technology mapping. The ABC9 pass uses much newer optimizers and mapping, for a modest improvement in optimization, and a possible big improvement in LUT mapping.

- v. Additional arguments Add additional arguments to the synthesis procedure.
- *b. Generate Bitstream* this is the final step before programming the FPGA. Under this process, Yosys performs processes such as Translation & Mapping, Place & Routing and Resource Utilization calculations. A binary file is generated that contains configuration information.
  - *i. High Density IO Packing* Allows packing of input and output los into a single IO cell. Improves I/O utilization but can worsen congestion and timing.
  - ii. *High Density Packing Logic* -Allows you to achieve higher resource utilization per CLB but can worsen congestion and timing.
  - iii. *Clock-Concurrent Optimization (CCopt)-* Enables Clock-Concurrent Optimization to further optimize timing (must disable Ideal Clock) at the expense of potentially higher clocking power.
  - iv. *Place-and-Trial-Route* Iteratively run place-and-trail-route refinement to attempt timing improvements. Iteration count is defined by the "Place-and-trail-route iteration count' option.
  - *v. Place-and-Trial-route Iteration count* Used with "Place-and-Trial-Route", sets the number of iterations for place-and-trial-route to attempt timing improvements.
  - *vi. Maximum Routing Iterations* Maximum number of routing iterations before exiting with the last clean solution with the best achievable timing.
  - *vii.* Additional arguments Add additional arguments to the Generate Bitstream procedure.
- c. Simulation User can choose to save their dumpfile produced during simulation in two formats .vcd and. fst format. The difference between both formats is how much memory the file can handle. Users can opt for. fst format when simulating a memory heavy file as it produces a compact binary format file that offers much better performance for very large dumpfiles. It's fast to write and fast to read. VCD is a test format that is easy to read, and which is supported by a lot of different software packages.

#### B. User Settings

- a. *Messages Panel* User can choose to opt for erasing the Synthesis and Bitstream log each time they run a new procedure by checking the box.
- b. Tools
  - i. *Icarus Verilog* -The path to the Icarus Verilog tool. You need to set the path to the simulation engine binary so it can be found during the simulation procedure if the system environment doesn't have the proper path set. An "Autodetect" option is available, and it will try to automatically find the path to the tool if it can.
  - ii. *GTKWave* The path to the GTKWave tool. You need to set the path to the simulation results viewer binary so it can be found after the simulation procedure if the system environment doesn't have the proper path set. An "Autodetect" option is available, and it will try to automatically find the path to the tool if it can.
- c. Text Editor Number of spaces in tab characters that are shown for all text editors.
- d. *Processing* Checking the box under this setting allows you to save all files before proceeding with the design

e. *Files* – Enables to software to add \_tb suffix to the names of newly created testbench if unspecified

**Note:** Changes made in the Project Settings category only apply to the project currently being working on. Adjustments made in the User Settings section have a global impact, ensuring consistency across all FPGA-related projects on a particular device. If you switch to another computer, these settings will either be reset to default values or adapted to the configurations of that specific computer.

Follow the instructions provided in the description of the options to avoid errors and improve your design.

| ForgeFPGA Workshop (Setting                                                                                                                                                                                                                                  | gs)                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ×   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| <ul> <li>ForgeFPGA Workshop (Setting</li> <li>Project Settings</li> <li>Synthesis</li> <li>Generate Bitstream</li> <li>Simulation</li> <li>User Settings</li> <li>Messages</li> <li>Tools</li> <li>Text Editor</li> <li>Processing</li> <li>Files</li> </ul> | Synthesis         Synthesis         Flatten         Flatten design before synthesis.         No DSP         Do not use DSPs to implement multipliers and associated logic.         Keep         Create extra KEEP nets by allowing a cell to drive mutliple nets.         Use ABC9         Use ABC9 for technology mapping.         Additional arguments         Add additional options here         Add additional arguments to the Synthesis procedure. |     |
|                                                                                                                                                                                                                                                              | OK Cancel Ap                                                                                                                                                                                                                                                                                                                                                                                                                                              | ply |

Figure 13. ForgeFPGA Workshop Settings

## 2.2 Writing HDL Code

The toolchain of the ForgeFPGA Workshop supports Verilog 2005 (IEEE Standard 1364-2005) and System Verilog Syntaxes.

There are a few special code attributes that are important to keep in mind while working with the synthesis tools:

- i. (\* top \*) the main module of your design should be marked with this attribute so the toolchain can successfully recognize which of the modules in the design is the top one.
- ii. (\* clkbuf\_inhibit \*) clock signals in the input list of the main module should be marked with this attribute to prevent clock buffer insertion by the synthesis tool, which may lead to the distortion of the clock signal name in the resulting netlist. This attribute belongs only to Synthesis, the compile process requires the customer to assign IOBs manually on the I/O Planner that are predefined clock trees.
- iii. (\*iopad\_external\_pin\*) all external pins that are used in any module need to be marked with this attribute.

| Resources Report                 |                                                                    |   |
|----------------------------------|--------------------------------------------------------------------|---|
|                                  | 🗷 simple_cou… 🔀 🖸 I/O Planner 🔀                                    |   |
| Compile project to get resources | 1 (* top *) module simple_counter(                                 | 4 |
| report                           | <pre>2 (* iopad_external_pin, clkbuf_inhibit *) input i_clk,</pre> |   |
|                                  | 3 (* iopad_external_pin *) input i_nreset,                         |   |
|                                  | <pre>4 (* iopad_external_pin *) input i_up_down,</pre>             |   |
|                                  | 5 (* iopad_external_pin *) output o_up_down_oe,                    |   |
| Sources                          | 6 (* iopad_external_pin *) output o_osc_ctrl_en,                   |   |
| 🔻 🗋 Project                      | <pre>7 (* iopad_external_pin *) output [3:0] o_counter 8 );</pre>  |   |
| 🔻 🗖 Source Code                  | 0 ) j                                                              |   |
| 🔻 🗖 Custom Code                  | <pre>10 reg [3:0] r_counter_up_down;</pre>                         |   |
| ✓ simple_counter                 | 11 reg [1:0] r_up_down_sync;                                       |   |
| 🖿 Ip Blocks                      | 12 reg [1:0] r_rst;                                                |   |
| <ul> <li>Testbenches</li> </ul>  | 13 wire w_reset;                                                   |   |
| ✓ simple_counter_tb              | 14                                                                 |   |
| 🛅 External Netlists              | 15 assign o_up_down_oe = 1'b1;                                     |   |
|                                  | 16 assign o_osc_ctrl_en = 1'b1;                                    |   |
|                                  | 17                                                                 |   |
|                                  | 18 always @(posedge i_clk) begin<br>19 r rst[0] <= i oreset:       |   |
|                                  | 19                                                                 |   |
|                                  | 20 iist[1] <= 'iist[0];                                            |   |
|                                  | 22                                                                 |   |
|                                  | 23 always @(posedge i_clk) begin                                   |   |
|                                  | 24 if (w_reset)                                                    |   |
|                                  | <pre>25 r_up_down_sync &lt;= 2'b00;</pre>                          |   |
|                                  | 26 else begin                                                      |   |
|                                  | <pre>27 r_up_down_sync[0] &lt;= i_up_down;</pre>                   |   |
|                                  | <pre>28 r_up_down_sync[1] &lt;= r_up_down_sync[0];</pre>           |   |
|                                  | 29 end<br>30 end                                                   |   |
| Synthesize                       | 30 end<br>31                                                       |   |
|                                  | 32 always @(posedge i_clk) begin                                   |   |
| 🎆 Generate Bitstream             | 33 if (wreset)                                                     |   |

Figure 14. Working with Verilog example

## 2.2.1 Importing/Export RTL Files

The ForgeFPGA Editor allows you to import external RTL files and netlist that has been created by other software. You can import a Custom Module file, Custom Testbench file or a Netlist. You can import an RTL File by navigating to *Main Menu*  $\rightarrow$ *Import*  $\rightarrow$ *Custom Module* (see Figure 15).

The software supports the following formats for importing:

- Custom Module (supported file formats \*.v, \*.vh, \*.verilog, \*.vlg, \*.vt, \*.sv)
- Custom Testbench (supported file formats \*.v, \*.vh, \*.verilog, \*.vlg, \*.vt, \*.sv)
- Netlist (supported file formats \*.edif, \*.edn)

| 🛐 ForgeFPGA Workshop   | [untitled2.ffp | ga] *      |          |
|------------------------|----------------|------------|----------|
| File Edit Tools Window | Options        |            |          |
| 💾 Save                 | Ctrl+S         | N          |          |
| 💾 Save All             | Ctrl+Shift+S   | tom Module | Messages |
| 🐐 Modules Library      |                |            |          |
| New Custom Module      |                |            |          |
| New Custom Testbench   |                |            |          |
| 🛃 Import               | Þ              | Custom Mo  | dule     |
| 👼 Export               | •              | Custom Tes | stbench  |
| Load Design Template   | ÷              | · Netlist  |          |
| Close                  | Ctrl+Q         |            |          |

#### Figure 15. Importing RTL Files

Similarly, you can export files too. You can export a custom module, library module or a testbench that you have designed using ForgeFPGA Workshop and save in your system. You can export via *Main Menu*  $\rightarrow$  *Export*  $\rightarrow$  *Custom Module* 

| File Edit Tools Window | Options      |             |        |
|------------------------|--------------|-------------|--------|
| 💾 Save                 | Ctrl+S       | N           |        |
| 💾 Save All             | Ctrl+Shift+S | tom Module  | Messag |
| Modules Library        |              |             |        |
| New Custom Module      |              |             |        |
| New Custom Testbench   |              |             |        |
| almport                | Þ            |             |        |
| 😴 Export               | Þ            | Custom Mo   | dule   |
| Load Design Template   | Þ            | Library Mod | lule   |
| Close                  | Ctrl+Q       | · Testbench | 2      |
| CLD LUIS. 01           | 1120         |             |        |

Figure 16. Exporting RTL Files

## 2.3 Modules Library

The *Modules Library* is a comprehensive repository of pre-designed and pre-verified easy-to-integrate modules. This tool provides HDL code for various hardware modules, accompanied by the testbenches to check their functionality using Simulation.

To open the *Modules Library*, click the corresponding button on the toolbar or navigate the main menu, *File*  $\rightarrow$  *Modules Library*. Choose the module, set the required configurations, and add the name to complete the module creation (see Figure 17).

Inside the *Modules Library* GUI, you can find the schematic and port information along with the description of the block selected. The GUI gives a detailed explanation of all the input and output pins of the block and allows you to change the parameters as desired. This gives you the flexibility to create the HDL code of the module needed and its associated testbench with just a few clicks.

| Search                                                                        | Module library                                   |    |
|-------------------------------------------------------------------------------|--------------------------------------------------|----|
| <ul> <li>Communications</li> </ul>                                            | Woodle library                                   |    |
| ▼ 12C                                                                         |                                                  |    |
| I2C Master                                                                    |                                                  |    |
| I2C Slave                                                                     | Ready modules:                                   |    |
| <ul> <li>12S</li> <li>12S Master Receiver</li> </ul>                          |                                                  |    |
| 12S Master Transmitter                                                        | Communications                                   |    |
| 12S Slave Receiver                                                            |                                                  |    |
| 12S Slave Transmitter                                                         | • I2C                                            |    |
| PSI                                                                           | <ul> <li>I2C Master</li> </ul>                   |    |
| ▶ SPI                                                                         | I2C Slave                                        |    |
| VART                                                                          |                                                  |    |
| UART Receiver<br>UART Transceiver                                             | • I2S                                            |    |
| UART Transceiver<br>UART Transmitter                                          | <ul> <li>I2S Master (Receiver)</li> </ul>        |    |
| <ul> <li>Mathematics</li> </ul>                                               | <ul> <li>I2S Master (Transmitter)</li> </ul>     |    |
| <ul> <li>Division</li> </ul>                                                  |                                                  |    |
| <ul> <li>Memory</li> </ul>                                                    | <ul> <li>I2S Slave (Receiver)</li> </ul>         |    |
| Synchronous FIFO                                                              | <ul> <li>I2S Slave (Transmitter)</li> </ul>      |    |
| <ul> <li>Periphery</li> </ul>                                                 | <ul> <li>Parallel to Serial Interface</li> </ul> |    |
| Keyboard Scanner                                                              |                                                  |    |
| Servo Controller                                                              | • SPI                                            | 43 |
| <ul> <li>Seven Segment Display Controller<br/>Smart LED Controller</li> </ul> | <ul> <li>SPI Master</li> </ul>                   |    |
| Stepper Motor Controller                                                      | SPI Slave                                        |    |
| <ul> <li>Signal Processing</li> </ul>                                         |                                                  |    |
| Breathing Controller                                                          | ○ UART                                           |    |
| Frequency Detector                                                            | <ul> <li>UART Receiver</li> </ul>                |    |
| PWM                                                                           | <ul> <li>UART Transceiver</li> </ul>             |    |
| Quadrature Decoder                                                            | <ul> <li>UART Transmitter</li> </ul>             |    |
| Ripple Counter<br>Wake-Sleep Controller                                       |                                                  |    |
| wake-sleep controller                                                         | Mathematics                                      |    |
|                                                                               | <ul> <li>Division</li> </ul>                     |    |

Figure 17. Modules Library GUI

| ForgeFPGA Workshop                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                 |                                                                                 |                  | -      |     | ×    |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|------------------|--------|-----|------|
| Search                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | UART Receiver p                                                                                                 | pinout:                                                                         |                  |        |     |      |
| <ul> <li>Communications         <ul> <li>I2C</li> <li>I2C Slave</li> <li>I2S Master Receiver</li> <li>I2S Master Transmitter</li> <li>I2S Slave Receiver</li> <li>UART Transmitter</li> <li>VART</li> <li>UART Receiver</li> <li>UART Transmitter</li> </ul> </li> <li>Mathematics         <ul> <li>Division</li> <li>Memory</li> <li>Synchronous FIFO</li> <li>Periphery</li> <li>Keyboard Scaner</li> <li>Serve Segment Display Controller</li> <li>Stepper Motor Controller</li> <li>Stepper Motor Controller</li> <li>Frequency Detector</li> <li>PWM</li> <li>Quadrature Decoder</li> </ul> </li> </ul> | i_clk<br>i_rst<br>i_rx<br>i_rx<br>common ports<br>i_iclk - input clock<br>i_rst - input negat<br>interface port | eceiver<br>m_ports<br>ce_port<br>m_ports<br>DATA_FRAME<br>O_TX_data<br>signal   |                  |        |     |      |
| Wake-Sleep Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Parameters                                                                                                      |                                                                                 |                  |        |     |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | DATA_FRAME<br>BAUD_RATE<br>OVERSAMPLING_MODE<br>STOP_BIT                                                        | 50_000_000<br>8<br>115_200<br>16<br>1<br>serial data transfer format LSB to MSB |                  |        |     |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                 |                                                                                 | Reset to Default | Select | Car | ncel |

Figure 18. Module Library GUI with Parameters

The user can create multiple Module Blocks simultaneously as well. All created Module Blocks and their respective testbenches can be seen listed under the sources tab in the *Control Panel*.

## 2.4 RTL Synthesis

The ForgeFPGA Editor comes with a built-in synthesis tool that takes a design as input and produces a Netlist out of it.

While performing synthesis, the input design is analyzed and converted into gate-level representation. To run synthesis on your design, you can press the **Synthesis** button on the bottom of the *Control Panel* or from the main menu *Tools*  $\rightarrow$  *Run Synthesis* 

During the process of synthesis, the software also checks for any **Syntax errors** in the written HDL code and indicates which line has the error in the *Messages Panel*. The Synthesis process will not be completed until the code is free of any syntax errors.

User can access the Synthesis Report from the Synthesis Report button in the toolbar on top after successfully synthesising the design or from *Windows*  $\rightarrow$  *Synthesis Report*.

### 2.4.1 Post-Synth RTL

At the Register-Transfer Level, the design is represented by combinational data paths and registers. RTL synthesis is easy as each circuit node element in the *Netlist* is replaced with an equivalent gate--level circuit. In Post-Synthesis RTL, the synthesized inputs are taken as a netlist. It helps in providing information about the clock and other clock-related logic in the design, which enables additional I/O planning.

You can find the Post-Synth RTL report by clicking the respective toolbar button or from the main menu, *Window*  $\rightarrow$  *Post-Synth RTL*. The report contains all the connections made within the module between the LUTs, FDREs and Carry-Chain logic.

| 2                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Resources Report   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                    | simple_cou.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| CLBs total: 3/140  | 1 /* Generated by Yosys 0.10 */                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| CLB LUTs: 6/1120   | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| CLB FFs: 6/1120    | <pre>3 i (* hdlname = "\\simple_counter" *)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Input pins: 2/368  | 4 ((* top = 1 *)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Output pins: 6/368 | <pre>5 (* src = "project_code_dump_temp_dir/simple_counter.v:1.11-44.10" *)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Input FFs: 2/368   | <pre>6 module simple_counter(i_clk, i_nreset, i_up_down, o_up_down_oe, o_osc_ctrl_en, o_counter);</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Output FFs: 4/368  | 7 (* src = "project_code_dump_temp_dir/simple_counter.v:18.3-21.6" *)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                    | 8 wire [1:0] _00_;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                    | 9 (* force_downto = 32'd1 *)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Sources            | <pre>10 (* src = "project_code_dump_temp_dir/simple_counter.v:38.28-38.52[C:\\PROGRA-1\\RENESA-1\\GCONF-1\\external\\yosys\\share\\xilinx/arith_map.v:116.23-116.25" *)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 👻 🛅 Project        | 11: (* unused_bits = "0 1 2 3" *)<br>12: wire [310] 01: :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| - D Source Code    | 12; wire [310] _01_;<br>13; (* force downto = 32'd1 *)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| - 🗖 Custom Code    | <pre>(* iotcuownic0 - 24 GL *) (* iotcuownic0 - 24 GL</pre> |
| ✓ simple_counter   | s wire [3:0] 02:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| D Io Blocks        | 16 (* force downto = 32'd1 *)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Testbenches        | 17 (* src = "project_code_dump_temp_dir/simple_counter.v:38.28-38.52 C:\\PROGRA-1\\RENESA-1\\GOCONF-1\\external\\yosys\\share\\xilinx/arith_map.v:112.26-112.27" *)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| simple counter tb  | 18 wire [3:0] _03_;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| External Netlists  | 19 (* clkbuf_inhibit = 32'd1 *)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                    | <pre>20 (* iopad_external_pin = 32'd1 *)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                    | <pre>21 (* src = "project_code_dump_temp_dir/simple_counter.v:2.50-2.55" *)</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                    | 22 input i_clk;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                    | 23 (* iopad_external_pin = 32'd1 *)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                    | 24 (* src = "project_code_dump_temp_dir/simple_counter.vt3.34-3.42" *)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                    | 25 input inneset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                    | 26 (* iopad_external_pin = 32'd1 *)<br>27 (* sr = "project code dump temp dir/simple counter.v14.34-4.43" *)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                    | <pre>2/: (* src = "project_code_dump_temp_arr/simple_counter.vi4.34-4.45" *) 28. input i un downt </pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

Figure 19. Post-Synth RTL

### 2.4.2 Netlist

The system generates a netlist file after successful synthesis of the project. It describes the components and connectivity of the source design and is required to perform the subsequent place-and-route procedure. You can access the netlist by clicking the Netlist button on the toolbar or from the main menu, *Window*  $\rightarrow$  *Netlist*.

You can also import an external netlist by selecting *File*  $\rightarrow$  *Import*  $\rightarrow$  *Netlist* from the Main Menu.



Figure 20. Netlist

### 2.4.3 I/O Planner

Each available I/O port on the FPGA has a dedicated function that can be mapped to your design using the I/O *Planner* tool to generate a special configuration file which is then used during the place-and-route procedure.

The user can access the *I/O Planner* by clicking the I/O Planner button on the toolbar or selecting it from the main menu *Windows*  $\rightarrow$  *I/O Planner*.

The I/O Planner tool is represented as a table with the following columns:

- Position the coordinates of the specific device I/O port on the FPGA.
- *Function* the dedicated function assigned to the port.
- Port editable column, where you can input ports from your HDL design, to connect them to the desired functionality. By double-clicking the desired port row, the user can choose from the list of all the ports defined in their HDL Code.

After the design has been synthesized, the signal from port list can be dedicated to the desired function by double-clicking on the white cell under corresponding port and selecting the signal from the list.

| [FIN 17] 0F104_001 | υπτρατ | o_councer[5]                       |
|--------------------|--------|------------------------------------|
| [PIN 17] GPI04_0E  | Output | o_counter_oe[3]                    |
| [PIN 17] GPI04_IN  | Input  | o_counter[3]                       |
| INT_FPGA_SLEEP     | Output | o_counter_oe[0]<br>o_counter_oe[1] |
| [PIN 18] GPI05_OUT | Output | o_counter_oe[2]                    |
| [PIN 18] GPI05_OE  | Output | o_counter_oe[3]<br>o_osc_ctrl_en   |
| [PIN 18] GPI05_IN  | Input  | o_up_down_oe                       |
| LDIN 101 CDIOS OUT | Output |                                    |

Figure 21. I/O Port Signal Assignment

**Note:** The cell will show a warning icon when the port name is invalid. Hover over the cell to trigger the info popup with more details. Correct the name to perform the procedures successfully.

| 💌 simple_cou 🔀 🔤 Post-Synth 🔀 🗱 I/O  | Planner 🔀                  |                       |
|--------------------------------------|----------------------------|-----------------------|
| Filter: Unused                       | ✔ Misc ✔ BRAM ✔ CLK ✔ GPIO | ☑ OSC_ctrl ☑ PLL_ctrl |
| POSITION                             | FUNCTION                   | PORT                  |
| CLK tile[0, 0] clk_side=W Input0     | OSC_CLK                    | i_clk                 |
| IOB tile[0, 0] coord[31, 11] Input0  | FPGA_CORE_READY            | i_nreset              |
| IOB tile[0, 0] coord[ 0, 6] Input0   | [PIN 13] GPIO0_IN          | i_up_down             |
| IOB tile[0, 0] coord[ 0, 7] Output0  | [PIN 14] GPI01_OUT         | o_counter[0]          |
| IOB tile[0, 0] coord[ 0, 8] Output0  | [PIN 15] GPI02_OUT         | o_counter[1]          |
| IOB tile[0, 0] coord[ 0, 9] Output0  | [PIN 16] GPI03_OUT         | o_counter[2]          |
| IOB tile[0, 0] coord[ 0, 10] Output0 | [PIN 17] GPI04_OUT         | o_counter[3]          |
| IOB tile[0, 0] coord[ 0, 25] Output0 | OSC_EN                     | o_osc_ctrl_en         |
| IOB tile[0, 0] coord[ 0, 6] Output1  | [PIN 13] GPIO0_OE          | o_up_down_oe          |
| CLK tile[0, 0] clk_side=E Input0     | DATA_AS_CLK0               |                       |
| CLK tile[0, 0] clk_side=E Input1     | DATA_AS_CLK1               |                       |
| CLK tile[0, 0] clk_side=W Input1     | PLL_CLK                    |                       |
| CLK tile[0, 0] clk_side=N Output0    | REF_BRAM(03)_READ_CLK      |                       |
| CLK tile[0, 0] clk_side=N Output1    | REF_BRAM(03)_WRITE_CLK     |                       |
| CLK tile[0, 0] clk_side=S Output0    | REF_BRAM(47)_READ_CLK      |                       |
| CLK tile[0, 0] clk_side=S Output1    | REF_BRAM(47)_WRITE_CLK     |                       |
| IOB tile[0, 0] coord[ 0, 0] Output0  | BRAM4_WDATA[5]             |                       |

Figure 22. Mapping I/O Ports

To make navigation easier, the I/O Planner provides several filters with checkboxes, that can show/hide groups of ports according to their functionality.

 Filter:
 Image: Misc Image: BRAM Image: Branches: B

Figure 23. I/O Planner Filter selection

The user can also clear all the data fed inside the I/O Planner by going to main menu by selecting *Tools*  $\rightarrow$  I/O *Planner*  $\rightarrow$  *Clear data* as well as import/export the port data (.txt or .csv format) via main menu by selecting *Tools*  $\rightarrow$  I/O *Planner*  $\rightarrow$  *Import* I/O *Spec*.

A detailed explanation of a few important signals in the I/O Planner is provided in IO Planner Signals.

#### 2.4.4 Synthesis Report

After performing synthesis of your current project, a new report is generated. This report shows the number of primitive objects used to represent the design in the generated netlist.

To open the synthesis report window, click the corresponding button on the toolbar or via main menu, Window  $\rightarrow$  Synthesis Report



Figure 24. Synthesis Report

## 2.5 Generating the Bitstream

To prepare your design to be programmed onto the device, the place-and-route procedure must be performed, that takes the elements of the synthesized netlist and maps its primitives to FPGA physical resources. This can be done once the *Netlist* files are successfully generated. To generate the bitstream data, click the *Generate Bitstream* button in the bottom left corner of *FPGA Editor* or, from the main menu, *Tools*  $\rightarrow$  *Generate Bitstream*.

You can check Bitstream Log tab on the Message Panel to inspect the background steps after you click Generate Bitstream. In the background, the software automatically performs technology mapping, clustering and floor planning, placement and optimization, routing, and resource calculation. If an issue occurs in any of these steps, the bitstream generation will be incomplete, and you will see outcome on the Messages Panel.

The generated bitstream is saved as a hex file which, if generated correctly, can be used for debugging your design.

After bitstream generation is completed, you can see the generated info for the tools described later in this section.

#### 2.5.1 Floorplan

To help with the visualization of your design, the results of the place-and-route procedure are visualized in the Floorplan window. Here you can check how the primitives from the netlist are placed and interconnected, as well as how I/O ports are mapped to the internal blocks and GPIOs.



Figure 25. Floorplan Window

Launch the Floorplan window by clicking the Floorplan button on the toolbar or from the main menu Windows  $\rightarrow$  Floorplan. Use the bottom toolbar controls to take a closer look and navigate within the tool.

Click the internal components to see its details in the block configuration infopanel. Also see the color scheme of the components and connections by clicking on the Legend Box icon at the bottom right.



Figure 26. Place and Route Results

Users can also load external custom Place and Route settings (.log file) to display their desired connections in the floorplan. To do so, the user can select *Tools*  $\rightarrow$  *Floorplan*  $\rightarrow$  *Load custom PnR*.

Footer Controls:

- Zoom: Zoom in/out the work area
- *Pan Mode*: click, hold and drag the cursor to move the work area (use the middle mouse button as an alternative)
- Zoom to selection: click, hold and drag a cross cursor over the element you want to zoom
- Align Vertical/Horizontal: align the macrocells relative to each other on the work area
- Snap to grid: use for precise graphic alignment of the macrocells along a grid.



Figure 27. Footer Controls

#### 2.5.2 Resources Report

After successfully performing the bitstream generation procedure, a full report of available resource usage is generated. This report shows the amount of CLBs, FFs, Pins, LUTs are being used for the synthesized design.

A summary of these resources utilized are also mentioned in the Control Panel.

The Resources Report window is launched by clicking the **Resources** button on the toolbar or selecting from the main menu *Windows*  $\rightarrow$  *Resources Report*.



Figure 28. Resources Utilization Report

### 2.5.3 Timing Analysis

This tool extracts the timing and checks for any timing violations associated with any internal registers. The results show whether each of the set-up, hold, and pulse-width times are being met.

You can find the tool on the toolbar, or by selecting Window  $\rightarrow$  Timing Analysis in the main menu.

| y si     | mple_counter.v 🔀 🛛 🕚 T                  | iming Analysis 🖂 |                                                                                                      |           |               |          |         |                       |                           |
|----------|-----------------------------------------|------------------|------------------------------------------------------------------------------------------------------|-----------|---------------|----------|---------|-----------------------|---------------------------|
| 1        | Timing Summary                          |                  |                                                                                                      |           |               |          |         |                       |                           |
| 2        |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 3        |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 4        | POST-ROUTE                              |                  |                                                                                                      |           |               |          |         |                       |                           |
| 5        |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 6        | Group No                                | o. Clocks No. (  | Clock Pairs                                                                                          | WNS(ps)   | TNS(ps) TNS E | ndpoints |         |                       |                           |
| 7        |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 8        | <udef_i_clk></udef_i_clk>               | 1                | 1                                                                                                    | -5896     | -130694       | 25       |         |                       |                           |
| 9<br>10  |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 10       |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 12       |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
|          | Clocks                                  |                  |                                                                                                      |           |               |          |         |                       |                           |
| 14       |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 15       |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 16       | Clock                                   | Clock net        | Group                                                                                                | Constrain | ed Period(ps) | Wavefor  | m(ps)   | Achievable Period(ps) | Achievable Frequency(MHz) |
| 17       |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 18       | i_clk                                   | i_clk <          | JDEF_i_clk>                                                                                          |           | (auto) 2000   | (0,      | 1000)   | 7895                  | 126.662                   |
| 19       |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 20<br>21 |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 21       |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 23       | Clock Relationships                     |                  |                                                                                                      |           |               |          |         |                       |                           |
| 24       | ======================================= |                  |                                                                                                      |           |               |          |         |                       |                           |
| 25       |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 26       | From Clock                              | To Clock         |                                                                                                      | Group     | Endpoints     | WNS(ps)  | TNS(ps) | TNS Endpoints         |                           |
| 27       |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |
| 28       | i_clk                                   | i_clk            | <ude< th=""><th>F_i_clk&gt;</th><th>25</th><th>-5896</th><th>-130694</th><th>25</th><th></th></ude<> | F_i_clk>  | 25            | -5896    | -130694 | 25                    |                           |
| 29       |                                         |                  |                                                                                                      |           |               |          |         |                       |                           |

Figure 29. Timing Analysis

Note: The Timing Analysis feature is currently under development.

## 2.6 Simulation

The most crucial step in successfully implementing any system is to verify the design and its functionality in response to different inputs without the need for physical hardware. Verifying a complex system after implementing the hardware is not a wise choice. It is ineffective in terms of money, time, and resources. Hence, in the case of FPGA, a testbench is used to test the HDL source code.

The FPGA Editor works in correspondence with 3rd party software for simulating the testbench, called Icarus Verilog, and for verifying the functionality of the design by viewing simulation results we use GTKWave. Please refer to the ForgeFPGA Simulation User Guide [8] for the installation process of the additional software and quick start guide.

## 2.6.1 Writing a Testbench

To work with the Simulation, you should have a testbench module for the FPGA design. You can add a testbench from the Modules Library or open a module from the main menu by going to *File*  $\rightarrow$  *New Custom Testbench* and saving the name of the *testbench*.



Figure 30. Custom Testbench example

To make things easy, the software opens the testbench module with a few lines of code to act as a guideline for writing the testbench. Please refer to [8] for details on how to write a testbench.

```
🗷 simple_counter.v 🔀
                   🕐 Timing Analysis 🖂
                                       simple_counter_tb.vt X
 1
   `timescale 1ns / 1ps
 2
 3
    module simple_counter_tb();
 4
      // Declare the testbench variables
 5
 6
                r clk:
      rea
 7
      reg
                r_nreset:
 8
      reg
               r_up_down;
 Q
     wire
                w_up_down_oe;
10
     wire
                w_osc_ctrl_en;
     wire [3:0] w_counter;
11
12
     wire [3:0] w_counter_oe;
13
     // Instantiate the simple_counter design and connect it with the testbench variables
14
15
     simple_counter dut(
16
       .i_clk
                     (r_clk
                                     ),
17
       .i_nreset
                     (r_nreset
                                     ),
       .i_up_down (r_up_down
18
                                     ),
19
       .o_up_down_oe (w_up_down_oe ),
20
       .o_osc_ctrl_en (w_osc_ctrl_en),
21
        .o_counter (w_counter
                                   ).
22
        .o_counter_oe (w_counter_oe )
23
     ):
24
25
      // Generate a clk that drives the design that flips value every 10ns
26
      always #10 r_clk = ~r_clk;
                                    // Frequency: 50MHz
27
28
      // The initial block forms the stimulus for the testbench
29
      initial begin
30
31
        $dumpfile ("simple_counter_tb.vcd");
                                                 // GTKWave simulation dump file
32
        $dumpvars (0, simple_counter_tb);
                                                 // Dump variable file
33
```

Figure 31. Simple Counter Testbench example from Template Design

## 2.6.2 Simulating a Testbench

After the user is satisfied with the written testbench, click the Simulate Testbench button on the toolbar to launch lcarus Verilog and the GTKWave software, or from the main menu go to *Tools*  $\rightarrow$  *Simulation*  $\rightarrow$  *Simulate Testbench*. The simulation stage is handled by lcarus Verilog in the background, while the GTKWave shows a visual representation. If the written testbench is correct and doesn't have any syntax errors, then the GTKWave software will launch automatically, otherwise check the Messages Panel for any syntax related issues in the written testbench and make any necessary changes.

The FPGA Editor ensures you can keep working from the last saved state of simulation results. Once you make the necessary configuration changes (e.g. add signals, adjust their graphical representation, etc.), save the progress in the GTKWave tool. Next time you simulate the same testbench, you will start from where you left off the previous time.

## 2.7 PLL Calculator

User can use the PLL Calculator to calculate which parameters are compatible with the SLG47910 Specifications. You can access it through the FPGA Editor  $\rightarrow$  PLL Calculator in the toolbar. The PLL Calculator uses the below equation to calculate the value of PLL\_CLK

$$PLL\_CLK = \frac{f_{reference\_clock} \times PLL\_FBDIV}{PLL\_REFDIV \times PLL\_POSTDIV1 \times PLL\_POSTDIV2}$$

| 🗷 simple_counter.v 🔀     | 21    | PLL C        | alculator 🖂 |          |                |      |                         |    |
|--------------------------|-------|--------------|-------------|----------|----------------|------|-------------------------|----|
| Clock Options            |       |              |             |          |                |      |                         |    |
| Input Frequency          | , MH  | z            | Require     | d Output | Frequency, MHz | Actu | al Output Frequency, MI | łz |
| 5.000000                 |       | \$ 50.000000 |             | 4        | 7.857143       |      |                         |    |
|                          |       |              | -^-         |          |                | 1    |                         |    |
| ✓ Allow Manual Adjustm   | ent   |              |             |          |                |      |                         |    |
| REFDIV                   |       |              | FBDIV       |          | POSTDIV1       |      | POSTDIV2                |    |
| 3                        | -     | 33           |             | ×<br>v   | 7              | ×    | 1                       | -  |
| Сору                     |       |              | Сору        |          | Сору           |      | Сору                    |    |
| Clock Information        |       |              |             |          |                |      |                         |    |
| Input Period, ns         | 200.  | 000          |             |          |                |      |                         |    |
| Actual Output Period, ns | 127.  | 273          |             |          |                |      |                         |    |
| Duty Cycle, %            | [44.2 | 2:51.6]      |             |          |                |      |                         |    |
| VCO Frequency, MHz       | 55    |              |             |          |                |      |                         |    |
| PFD Frequency, MHz       | 1.66  | 667          |             |          |                |      |                         |    |

Figure 32. PLL Calculator

The tool has two calculation modes:

- Divider auto calculation sets the Input Frequency and Required Output Frequency parameters to achieve the desired divider values (REFDIV, FBDIV, POSTDIV1, and POSTDIV2)
- Divider manual adjustment enter Input Frequency along with all four dividers to receive the Actual Output Frequency value

Note: Check Allow Manual Adjustment to enable Manual Adjustment mode

The values in the Clock Information table are based on the set data. If the user inputs a value which is outside the accepted range, then the resulting value changes to red color indicating an error (see Figure 32).

### 2.8 Macrocell Editor

Macrocell mode is a tool that allows the user to create the desired circuit in a schematic view. To launch Macrocell mode, the user can click the *Macrocell Editor button* on the toolbar, or the user can go to the main menu *Window*  $\rightarrow$  *Macrocell Editor*.



Figure 33. Macrocell Editor



The Macrocell Editor has two parts; the green screen is where the schematic of the circuit is designed by using the components on the right side of the screen which is a library of the all the *Sequential Logic* & *Combinational Logic* components. The user can simply drag and drop the desired component from the library on to the Green Screen to complete the circuit. Two components can be joined by clicking the two associated ports.

The Properties Panel show the details for the selected macrocell or connection. The Name field is editable (double-click the field or macrocell)



Figure 34. Changing the names of Input/Output Pins

## 2.9 Project Directory Folder

The software creates a folder containing the generated files as soon as any procedures are performed (synthesis, or both synthesis and bitstream generation). The folder contains the project file and a build folder (described later in this section) and will also store any the modules and netlists, which can be added or imported to the Sources tree in the FPGA Editor. The changes made to the sources will synchronize between the FPGA Editor and the file on disk.



Figure 35. FPGA Project Folder Structure

You can also use the Open Containing Folder feature in the Sources Panel to quickly locate the file on disk (see Figure 36)



Figure 36. Check Source File location

The list of generated files depends on the procedures that have been performed. The descriptions of the most important files present in the build folder are the following:

- Bitstream The folder containing the bitstream files in binary (.bin) and hexadecimal (.txt) format
  - FPGA\_bitstream\_FLASH\_MEM the bitstream sequence that can be used to program the flash
  - FPGA\_bitstream\_MCU the bitstream sequence that can be used for MCU programming
- *FPGA\_bitstream\_AXI.log* Contains the generated bitstream that represents your project's logic. This file is used while interacting with the development hardware upon performing the chip/flash procedures.
- io\_spec\_in.txt Lists the I/O ports specification added in the I/O Planner, which is created upon clicking Generate Bitstream.
- *PNR\_IO.log* I/O ports mapping file generated after successful bitstream generation procedure.
- *Netlist.edif* The result of Yosys data processing, describing the components and connectivity within the source design. You can also import an external netlist from another software/synthesis tool.
- PNR\_PACK\_PLACE.log Source data for building a floorplan.
- Post\_synth\_results.v Yosys output data in the Verilog code format
- Resource-utilization-report.log Information about the resources amount required for your design.
- Simulation Folder containing simulation results and temporary files.

## 3. Debug

The design is now ready to be tested out on the development board. The generated bitstream is automatically sent to the device which is ready to be programmed further. The user needs to now switch to the main screen of the ForgeFPGA Software.

The Debug button in the toolbar starts the *Debug Tool* in the ForgeFPGA Workshop window. The Debug tool enables electronic circuit emulation and chip programming, which uses a specific hardware platform to replicate the behavior of the chip components in the design. Before starting the emulation process, test point (TP) controls need to be added in order to configure the emulation process. The Test Point controls allow the user to configure the GPIOs in different options.

### 3.1 Hardware Platforms

After the Debug button is pressed, the Development Platform Selector and the two hardware options will be displayed (<u>See Figure 37</u>).

| Development Platform Select | or                                         |                               | × |
|-----------------------------|--------------------------------------------|-------------------------------|---|
|                             |                                            | ForgeFPGA <sup>™</sup> Deluxe |   |
| Software Simulation         | ForgeFPGA <sup>™</sup> Evaluation<br>Board | Development Platform          |   |

Figure 37. Development Platform Selector

#### 3.1.1 ForgeFPGA Deluxe Development Board

The ForgeFPGA Deluxe Development Board is a multi-functional tool that makes it possible to develop, program, and emulate FPGA designs by providing an onboard power source, digital signal generation, and logic analysis capabilities. The platform can connect additional external boards called socket adapters. The function of the socket adapter board is to implement an electrical connection between the pins of the chip under test and the ForgeFPGA Deluxe Development Board. To implement this, the platform uses a Dual PCle connector.



Figure 38. Socket Board Adapter

The board can also be used as an independent unit. The chip can be powered through the EXT PWR connector and signals can be read through the through-hole 12-pin PMOD connectors.



Figure 39. Assembled equipment for working with a chip in the socket.

To start working with the FPGA device, connect the development board to the computer via a USB Type-C cable and connect the power supply. If all the connections are correct, then the red LED (PWR) and blue LED (STS) will light up. For more information on the Deluxe Development Board and the Socket Adaptor please refer to [5][6].

### 3.1.2 ForgeFPGA Evaluation Board

ForgeFPGA Evaluation Board is a compact, easy-to-use, USB powered hardware tool. There are two versions of this platform (version 2.0 and 1.0).

ForgeFPGA Evaluation Board v2.0 provides the SLG47910 IC with hardware support for design emulation, programming, internal UART terminal options, and real-time testing. The platform mainly consists of the following blocks: programmer, socket, GPIO external connectors, and PMOD connectors. This board uses a USB Type-C connector for communications and power supply.



Figure 40. ForgeFPGA Evaluation Board v2.0

The ForgeFPGA Evaluation Board v1.0 is a simplified version of the platform and therefore, has limited functionality. Since the socket is absent, the SLG47910 is soldered directly on the board. The platform provides emulation possibilities along with access to the UART terminal.

For more information on the Evaluation Board, please refer to [7].



Figure 41. ForgeFPGA Evaluation Board v1.0

# 3.2 Platform Configuration Guide

Under the Debug tab on the main menu, the Recommended Platform Configuration guide contains information about suitable sockets, adapters, development boards, along with the device ordering information for each of the different devices. The guide is accessed by clicking on the platform's name in the Debugging controls panel (see Figure 42).



Figure 42. Platform Configuration Guide

| Debugging controls       |                   |        | Ø             | × |
|--------------------------|-------------------|--------|---------------|---|
|                          | Debugging Con     | trols  |               |   |
| ForgeFPGA De Platform    | evelopment        |        | ange platform |   |
| Emulation                | Test Mode         | Ţ      | Read          | ) |
|                          |                   |        | Program       | J |
| E                        | xternal Flash cor | ntrols |               |   |
| Read                     |                   | P      | rogram        | ] |
|                          | Generators cont   | rols   |               |   |
| Start                    | Pause             |        | Stop          |   |
|                          | TP Map            |        |               |   |
|                          |                   |        |               |   |
| PN: SLG47910C/V (0x0), D | B HW-FW: 1.2-0.   | 3      | 0             |   |

Figure 43. Debugging Controls

The Debugging Controls panel contains the UI controls for chip communication and programming. Now let's review the different parts of the Debugging Controls (Figure 43).

- a. Change platform Opens the list of development platforms that are supported
- b. Import configuration Import's the configuration of test points from another platforms.
- c. *Emulation* The current project will be loaded to the chip (but not programmed) when the control is active and will be ready for test on the hardware board.
- d. *Test Mode* Test mode is used for connecting or disconnecting the chip's I/O pads to Test Point controls, configured by the user. Also, a user can check the programmed device using the test mode without emulation. To do this, turn on Test Mode and the internal VDD button. Test mode can work without power on the chip. The user will control the power manually. Another feature of the Test Mode is that it can test with the conditions from Flash Memory.
- e. Test Mode (\*) Load data from flash to the device.
- f. Read Read the device using the hardware board or from the external flash memory.
- g. *Program* Program the device or the external with the current project. As the SLG47910 is OTP, it can be programmed only once.
- h. *External Flash Controls* Data can also be read from External Flash. The read data can be accessed from the Project Data window after the data has been read. The current bitstream can also be loaded onto the external flash by pressing the Program button under this category.
- i. *Generator Controls* During emulation, you can start all the test points together or pause them or even Stop them from running altogether.
- j. TP Map The Test Points of each pin will be shown next to their respective pin (Figure 44).
- k. PN (Part number and Versions) SLG47910 C/V (0x0), DB HW-FW: 1.2-0.3 After the Development board with the chip in the Socket Adapter Board has been connected, we can see the PN (Part Number) SLG47910 being displayed at the bottom of the Debugging Controls Dialog Box (Figure 43). The Debugging Control Window also indicates the Development Boards (DB) Hardware (HW) and Firmware (FW) version.



Figure 44. TP Map

# 3.3 Debug Tools

The *Debug Tool* controls are used to configure input signals on the inputs of external devices. There are many ways in which we can manage the device input signals.

Use the context menu on GPIOs with a right click to see the connectivity options (Figure 45).



Figure 45. Debug Tool

NC (not connected)



Figure 46. NC (not connected)

• VDD



Figure 47. Set to VDD

Figure 48. Set to GND

## 3.3.1 Configuration Button

The Configuration Button has three functions. The user can configure the button to establish the connection as VDD, GND or Hi-Z. If the user wants the GPIO to be a fixed connection to VDD, then the LATCH option should be selected. The LATCH option will make sure that the GPIO is connected to a particular signal (VDD/GND/Hi-Z). This will enable the button to be LATCHED to VDD unless it is changed (see Figure 49, Figure 50, Figure 51).

The default connection option is VDD/GND, but it can be changed to Hi-Z by selecting Hi-Z option from the Upper Connection or the Lower Connection option as needed from the context menu. In Figure 50, you can see that the Upper Connection "U" corresponds to Hi-Z, and the Bottom Connection "B" corresponds to GND.

If the configuration is set as UNLATCHED and the default connection is set as Upper Connection "U" which equals to Hi-Z and the Bottom Connection "B" to GND, whenever the button is pressed, there will be toggle in the waveform between Hi-Z and GND at that very moment with the default waveform being at Hi-Z (see Figure 50).



Figure 49. Latched Button with Upper Connection as VDD



Figure 50. Unlatched Button with Upper Connection as Hi-Z



Figure 51. Context menu options for Configurable Button

### 3.3.2 Synchronous Logic Generator

Right click on the NC of the desired GPIO and from the context menu select the Synchronous Logic Generator option. The synchronous Logic Generator is used for generating the logic pulses and waveforms for each of the GPIOs. The 'Edit' Button allows the signal to be configured.



Figure 52. Synchronous Logic Generator



Figure 53. Signal Wizard for Synchronous Logic Generator

Below are the different features in the Signal Wizard for Synchronous Logic Generator (Figure 53).

- i. Used Points: Amounts of points which are already used by patterns on all channels. Point indicates a moment when generator changes a state on at least on channel.
- ii. Used Bandwidth: Percentage of used resources needed to successfully execute generator's pattern.
- iii. *Pattern*: 0 = low, 1 = high level. We can set the pattern of pulse levels.
- iv. Repeat: One Shot / Cyclic / Custom.
- v. T / *levels*: it sets the duration of each pulse.
- vi. Insert: To insert pulse before selected position.
- vii. Remove: remove pulse from the selected position.
- viii. Invert: to invert the pattern from (For ex. '1010' to '0101').
- ix. Level Count: to insert the total number of pulses to be generated.

### 3.3.3 Parametric Generator

The parametric Generator generates logic pulses that follow different protocol sequences. It can be selected from the context menu of all GPIOs.

In the signal Wizard, a special editor shows the sequence of commands. Actions available in the command editor:

- Add or remove commands by clicking + or –
- Change command parameters
- Change the order of commands by dragging the commands to another position

|                     | Paramet   | ric Generator Setti | ngs |   |   |
|---------------------|-----------|---------------------|-----|---|---|
| Used points         | s: (7)    | 0%                  |     |   |   |
| Used bandwidth: (7) |           | 0%                  |     |   |   |
|                     |           |                     |     |   |   |
| ∐ → 1               | PWM       |                     | *   | + | - |
| <b>∦ ▶ 2</b>        | UART trar | nsmitter            | -   | + | - |
| I ≥ 3               | Clock     |                     | -   | + | - |
| <b>∐</b> → 4        | Raw       |                     | *   | + | - |
|                     |           |                     |     |   |   |
|                     |           |                     |     |   |   |
|                     |           |                     |     |   |   |
|                     |           |                     |     |   |   |
|                     |           |                     |     |   |   |
|                     |           |                     |     |   |   |
|                     |           |                     |     |   |   |

Figure 54. Parametric Generator Command Editor

The list of available commands:

- PWM (Pulse Width Modulation) the PWM command editor has three input fields:
  - Period a united duration of high and low states per repeat
  - Duty cycle the percentage of the total duration in the high state
  - *Repeats* pattern repeat count

| 1 | PWM         | <b>▼</b> [ ⊕ | -  |
|---|-------------|--------------|----|
|   | Period:     | 100us        | \$ |
|   | Freq:       | 10kHz        |    |
|   | Duty Cycle: | 60%          | \$ |
|   | Repeats:    | 2            | -  |

Figure 55. PWM Command Editor

- Clock the command generates a signal oscillating between a high and a low state. The editor has two input fields:
  - Period the united duration of high and low states per repeat
  - Repeats pattern repeat count

| <b>~ 1</b> | Clock    | ▼ 4 -   |
|------------|----------|---------|
|            | Period:  | 100us 🗘 |
|            | Freq:    | 10kHz   |
|            | Repeats: | 1       |

Figure 56. Clock Command Editor

- UART Transmitter generates signal according to the UART standard:
  - Baud rate signal's frequency
  - Data frame number of bits allocated for user input

- Data user input in hex format. In case the data frame is lower than the bits required to represent data, more significant bits are ignored
- Parity bit create parity bit for error detection
- Stop bit size duration of the stop bit
- Bit order serial data transfer format

| • | 1 | UART transmit  | ter 🔹 🖣 | - |
|---|---|----------------|---------|---|
|   |   | Baud rate:     | 9600    | • |
|   |   | Data frame:    | 8       | - |
|   |   | Data: 🗂        | 0       |   |
|   |   | Parity bit:    | ✓       |   |
|   |   | Stop bit size: | 1       | • |
|   |   | Bit order:     | MSB     | • |

Figure 57. Clock Command Editor

• *Raw* – this parent works as a typical Logic Generator

# 3.4 Logic Analyzer

The ForgeFPGA Workshop has a built-in Logic Analyzer which can be used to observe the waveforms during testing. The *Logic Analyzer* tool allows you to capture multiple signals from a digital circuit. It has advanced triggering capabilities and a protocol decoder that helps to see the timing relationship between multiple signals and decode them.

| etugging Controls                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 🜃 Logic Analyzer                              |                                                |                     |               | – o <mark>xx</mark> |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|------------------------------------------------|---------------------|---------------|---------------------|
| ekugging Controls  Emulation Emulati |                                               |                                                |                     |               | Close               |
| Enulation         Test Mode           Generators controls           Start           Start           Start           Start           Start           Start           Start           Start           Pause                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                               | ebugging Controls Presets Measurements Presets | File File           |               |                     |
| Generator controls           figger         file         file         Stop           file         1920x         \$ Samples:         8192         Image:         1920x         \$ Samples:         1920x         Image:         1920x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |                                                |                     |               | ×                   |
| Start     Puise     Stop       figer     Ime before trigger:     8192.us     \$ Samples:     8192.us       ime after trigger:     8192.us     \$ Samples:     8192.us       inger you:     Ime after trigger:     8192.us     \$ Groot (rP10)       if inger you:     Ime after trigger:     8192.us     Ime after trigger:       inger you:     Ime after trigger:     8192.us     Ime after trigger:       inger you:     Ime after trigger:     Ime after trigger:     Ime after trigger:       inger you:     Ime after trigger:     Ime after trigger:     Ime after trigger:       inger you:     Ime after trigger:     Ime after trigger:     Ime after trigger:       inger you:     Ime after trigger:     Ime after trigger:     Ime after trigger:       inger you:     Ime after trigger:     Ime after trigger:     Ime after triger: <t< td=""><td>Emulatio</td><td>n</td><td></td><td>Test Mode</td><td><b>v</b></td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Emulatio                                      | n                                              |                     | Test Mode     | <b>v</b>            |
| inger<br>ime before trigger: @1.92us \$ samples: 8192 €<br>ime after trigger: @1.92us \$ samples: 8192 €<br>inger type: Internal<br>inger mode Or<br>Norse Rising edge ♥ ● ● ● ● ● ● ● ● ● ● ● ● ● ● ● ● ● ●                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                               |                                                | Generators controls |               |                     |
| Image: 11:22.1 Sumplex       Samplex       8192         image: 11:22.1 Sumplex       Samplex       8192         inger type: Internal       Image: 11:22.1 Sumplex       Samplex         None       Rising edge       Image: 11:22.1 Sumplex       Samplex         None       Rising edge       Image: 11:22.1 Sumplex       Samplex         Image: 11:22.1 Sumplex       Samplex       Samplex       Image: 11:22.1 Sumplex         None       Rising edge       Image: 11:22.1 Sumplex       Image: 11:22.1 Sumplex       Image: 11:22.1 Sumplex         Measurements       Image: 11:22.1 Sumplex       Image: 11:22.1 Sumplex       Image: 11:22.1 Sumplex       Image: 11:22.1 Sumplex         Geno: (TP10)       Image: 11:22.1 Sumplex       Image: 11:22.1 Sumplex       Image: 11:22.1 Sumplex       Image: 11:22.1 Sumplex         Geno: (TP10)       Image: 11:22.1 Sumplex         Geno: (TP20)       Image: 11:22.1 Sumplex       Image                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Start                                         |                                                | Pause               | Stop          |                     |
| ime before trigge:       8132.1       \$ Samples:       8132.1         ime after trigge:       8132.1       \$ Samples:       8132.1         inger type:       Internal       Ime after trigge:       Ime after trigge:       Ime after trigge:         inger type:       Internal       Ime after trigge:       Ime after trigge: <td< td=""><td>Trigger 🗵</td><td>Emulation or Test Mode required.</td><td></td><td></td><td></td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Trigger 🗵                                     | Emulation or Test Mode required.               |                     |               |                     |
| ime after trigger:       1920us       Samples:       8192           irigger type:       internal               irigger type:       internal                 None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                               |                                                |                     | ▼             |                     |
| iniger type:       internal         iniger mode:       Or         None       Rising edge         Resurements       GPIO2 (TP11)         Image:       Image:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Time after trigger: 81.92us 🗘 Samples: 8192 🗘 |                                                |                     |               | <b>^</b>            |
| inigger mode:       or       or <td>Trigger type: Internal</td> <td></td> <td></td> <td></td> <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Trigger type: Internal                        |                                                |                     |               |                     |
| None       Rising edge       Image: (Tri)         Acasurements       Image: (Tri)         Image: (Tri)       Image: (Tri)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Trigger mode: Or                              |                                                |                     |               |                     |
| Aesurements       GPI04 (TP13)         · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                               |                                                |                     |               |                     |
| Aedsurements       GPI04 (TP13)       GPI05 (TP14)       GPI05 (TP14)       GPI05 (TP14)                · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                               |                                                |                     |               |                     |
| Add new analyzer       GPIOS (TP14)       GPIOS (TP13)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                               |                                                |                     |               |                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Measurements                                  |                                                |                     |               |                     |
| • • · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                               | GPIOS (TP14)                                   |                     |               |                     |
| ordiocol Analyzer       GPI07 (TP27)       GPI08 (TP28)         Add new analyzer       GPI09 (TP29)         GPI09 (TP29)       GPI09 (TP29)         GPI010 (TP30)       GPI09 (TP29)         GPI010 (TP30)       GPI010 (TP30)         GPI010 (TP30)       GPI00 (TP30)         GPI0010 (TP30)       GPI00 (TP30)         GPI0010 (TP30)       GPI00 (TP30)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | · • J. l. I. =                                | GPIO6 (TP15)                                   |                     |               |                     |
| image: control of analyzer       image: control of analyzer         Add new analyzer       image: control of analyzer         GPIO (TP20)       image: control of analyzer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                               |                                                |                     |               |                     |
| Add new analyzer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                               | J-i_x                                          |                     |               |                     |
| Add new analyzer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Protocol Analyzer                             |                                                |                     |               |                     |
| GPIO10 (TP30)<br>GPIO11 (TP31)<br>-80 us -60 us -40 us -20 us +40 us +60 us +80 us                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                               | GPIO9 (TP29)                                   |                     |               |                     |
| 「「コーコ」<br>GPI011 (TP31)<br>-80 us -60 us -40 us -20 us +40 us +60 us +80 us                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                               |                                                |                     |               |                     |
| -80 us -60 us -40 us -20 us +20 us +40 us +60 us +80 us                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                               |                                                |                     |               |                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                               | GPIO11 (TP31)                                  |                     |               |                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                               | -80 us -60 us                                  | -40 us -20 us       | +20 us +40 us | +60 us +80 us       |

#### Figure 58. Logic Analyzer

The characteristics of the Logic Analyzer are the following:

- Frequency range 500 Hz to 200 MHz
- Buffer Size 16384 samples
- SPI, I2C, Parallel and UART protocol support

### 3.4.1 Operational Controls

- Start Launch the Logic Analyzer. The Start button becomes active after Emulation or Test Mode is started.
- Sampling rate Drop down selector for the signal sampling frequency.

### 3.4.2 Mode

There are three operating modes:

- Auto mode Trigger events are ignored. The signal on the pins is shown as a continuous waveform.
- Single shot Refreshes the waveform pattern once a trigger event is detected.
- Normal mode Refreshes the waveform pattern each time when a trigger condition is met.

### 3.4.3 Triggers

Set time parameters to choose the trigger time position or a specific sample number.

| Trigger          |                               | ×  |
|------------------|-------------------------------|----|
| Time before tri  | gger: 81.92ms 🜲 Samples: 8192 | \$ |
| Time after trigg | ger: 81.92ms 🗘 Samples: 8192  | \$ |
| Trigger type:    | Internal                      | •  |
| Trigger mode:    | Or                            | •  |
| GPIO0 (TP9)      | ) ▼ Rising edge ▼ Ф           | -  |

#### Figure 59. Trigger Parameters

The trigger type can also be configured (see Figure 59):

- Hardware button the trigger is activated by pressing a physical button on the board
- Internal the trigger is activated when the trigger conditions, which is set in the trigger list is met.

The internal trigger can also be configured with the following options:

- Or any of the trigger conditions added to the trigger list are met
- And all trigger conditions added to the trigger list are met

An internal trigger must have the following settings specified:

- Channel assign the trigger to the specified channel
- Condition rising edge, falling edge, both edges, and high and low state

**Note:** set proper trigger conditions for successful sampling (e.g. Rising edge and Falling edge together with the trigger mode may result in improper trigger work).



Figure 60. Trigger Conditions

|                          |   | l I | 2 | V |  |  |
|--------------------------|---|-----|---|---|--|--|
| GPIO0 (TP9)<br>」 ー ጊ _ ユ |   |     |   |   |  |  |
| GPIO1 (TP10)             |   |     |   |   |  |  |
| GPIO2 (TP11)             |   |     |   |   |  |  |
|                          | 1 |     |   |   |  |  |

Figure 61. Trigger Configuration



### 3.4.4 Debugging Controls

The Debugging Control panel is responsible for Emulation, Test Mode, and Generator control functionality.

| gging Control | s             |           |  |
|---------------|---------------|-----------|--|
| Emulation     | 1             | Test Mode |  |
|               |               |           |  |
| C             | Generators co | ontrols   |  |

#### Figure 62. Debugging Controls

The channels in the View options panel can be shown or hidden using the buttons at the bottom.

| GPIO0 (TP9)   | GPIO1 (TP10)  | GPIO2 (TP11)  |
|---------------|---------------|---------------|
| GPIO3 (TP12)  | GPIO4 (TP13)  | GPIO5 (TP14)  |
| GPIO6 (TP15)  | GPIO7 (TP27)  | GPIO8 (TP28)  |
| GPIO9 (TP29)  | GPIO10 (TP30) | GPIO11 (TP31) |
| GPIO12 (TP32) | GPIO13 (TP33) | GPIO14 (TP34) |
| GPIO15 (TP35) | EN (TP39)     |               |

Figure 63. View Options

#### 3.4.5 Presets

The Logic Analyzer configurations can be stored in presets and restored from a previous configuration when needed.

|    | ]            |      |           |   |
|----|--------------|------|-----------|---|
|    | J            |      |           |   |
| 11 | Default      | Load | Overwrite | W |
|    | New preset   | Load | Overwrite | 8 |
| #  | New preset 1 | Load | Overwrite | 1 |

Figure 64. Logic Analyzer Configuration Presets

- New Preset Create a new preset for the current Logic Analyzer configuration
- Load load a selected preset configuration
- Overwrite overwrite preset with the current Logic Analyzer configuration
- Delete Preset remove the selected preset
- *Default* load the default preset of the Logic Analyzer window
- Autosave [time] the modified preset is saved each time the Logic Analyzer window, the Debug tool, or ForgeFPGA workshop is closed.

### 3.4.6 Protocol Analyzer

The Protocol Analyzer decodes data according to the selected protocol.



#### Figure 65. Protocol Analyzer Decode Options

To analyze captured data, click the + button and select one of the protocols.

| rotoco | ol Analyzer         |       | ×  |
|--------|---------------------|-------|----|
|        | [UART] Add name her | re 🖣  | -  |
|        | RX or TX:           | GPIO0 | •  |
|        | Baud rate:          | 9600  | -  |
|        | Data frame:         | 8     | \$ |
|        | Parity bit:         | None  | •  |
|        | Stop bit size:      | 1     | -  |
|        | Bit order:          | LSB   | -  |

Figure 66. Protocol Analyzer Options



#### Figure 67. Decoded Data

Then, choose a channel for analysis and modify the protocol settings if necessary. The decoded data will be displayed above the corresponding plot.

Data can be easily exported from the Protocol Analyzer by clicking the Save button next to the Protocol Analyzer name field. If the parameters are selected correctly, a CSV file of the data will be saved.

#### 3.4.7 Import/Export

The waveform data can be imported or exported in CSV forma. These options are grouped under the File Menu on the top toolbar.



Figure 68. Import/Export from/to CSV format



## 3.4.8 Plot Widget

The plot widget displays the waveforms in the Logic Analyzer window. The way a plot is shown can be changed via the plot context menu. Right-click on a plot area to add a marker, show or hide the time scale, change the plot height, and select the cursor width.



Figure 69. Plot Widget

The plot area can be navigated using the following controls:

- Move left/right by left click + drag left/right
- Scroll up/down by mouse wheel up/down
- Zoom in/out by CTRL + mouse wheel up/down
- Quick zoom in/out with the middle mouse button click + drag up/down
- Reorder waveforms by Drag and Drop

### 3.4.9 Cursors

A cursor is a measurement tool for calculating waveform data between the edge of one or more plots. To see the cursor, hover the mouse over a measured section of a waveform.

A Half Period cursor measures the distance between the two nearest edges at a hovered section of a waveform.



#### Figure 70. Half Period Cursor

A Period cursor measures the width of the hovered half period, the duration of a full period, and calculates the frequency and what fraction of the full period the hovered area of the period is, which is the Duty Cycle.



Figure 71. Period Cursor

To change the cursor width, open the context menu and select either the Period or Half Period option.

To measure data at a distance that exceeds one period, left click the edge you want to measure from and hover over the edge you want to measure to. This will give you the total duration of the measured section, the calculated average frequency, and the quantity of rising and falling edges well as their sum.



Figure 72. Adjustable Period Cursor for Measurement

You can also measure the width between the edges on the distinct waveforms.



Figure 73. Adjustable Period Cursor Measurement between waveforms

### 3.4.10 Markers

You can do the following actions with markers:

- Add a new marker with a CTRL + left click on the markers panel
- Set a new marker from the plot's context menu
- Remove the marker with a CTRL + right-click on the marker head
- Move the marker by a left-click + drag the mouse cursor



Figure 74. Moving markers with context menu

- Move from the context menu by a left-click on the marker's head
- Select the marker by clicking on the marker head, the selected marker has a white line on top
- Move the selected marker to the closest visible left/right line by CTRL + LEFT/RIGHT arrow key
- Move the selected marker left/right by one sample with CTRL + SHIFT + LEFT/RIGHT arrow key

#### 3.4.10.1 Marker Measurements

- Measurements Period and frequency. The frequency value is rounded to four decimals.
- Additional measurements counts the rising edges, falling edges, and all edges in the period between the markers

To calculate all measurements between two markers, select the markers and a channel in combination boxes.

| Me | asure | emen | ts |    |    |    |              | × |  |
|----|-------|------|----|----|----|----|--------------|---|--|
| :: | Т     | *    | 1  | -  |    |    | 160ms/6.25Hz | • |  |
| ** | GPIO0 |      | *  | 52 | l2 | I4 |              |   |  |
|    |       |      |    |    |    |    |              |   |  |

Figure 75. Marker Measurements

# 3.5 UART Terminal

The UART Terminal is a console tool used for serial communication between the board and an external device. While developing a project, the UART terminal helps to *read* and *write* via the UART protocol. This UART terminal is available only on the ForgeFPGA Evaluation Board.

To start working with the terminal, ensure that the Evaluation Board platform is selected. Open the UART Terminal tool on the top toolbar.

| 🗰 [SLG47910V (Rev BB)] - ForgeFPGA Workshop |              |  |  |  |  |  |  |  |
|---------------------------------------------|--------------|--|--|--|--|--|--|--|
| File Edit View Tools Options Help           |              |  |  |  |  |  |  |  |
| Rule Checker FPGA Editor                    | Comparison   |  |  |  |  |  |  |  |
| UART Terminal                               |              |  |  |  |  |  |  |  |
| Figure 76. UART Terminal T                  | ool          |  |  |  |  |  |  |  |
| UART Terminal                               | ×            |  |  |  |  |  |  |  |
| UART Terminal                               |              |  |  |  |  |  |  |  |
| 4800 baud 💌 None parity 💌 CR                | •            |  |  |  |  |  |  |  |
| 11                                          | Send         |  |  |  |  |  |  |  |
| 1f 3a 42<br>0 12 f4 a2                      |              |  |  |  |  |  |  |  |
| New line ASCII -                            | Clear output |  |  |  |  |  |  |  |

Figure 77. UART Terminal Window

- Baud rate Selects the baud rate from the list for read and write operations.
- Parity control Selects whether and how the parity control bit is used.
- Line ending Selects which character is used as a new line character. No line ending, new line (NL), Carriage Return (CR), or both New Line & Carriage Return. This option is available in ASCII mode only.
- New line Add a new line after each byte sent if set; otherwise, send the entire message at once.
- Data format Selects the data format: ASCII or Hex. For Hex, the input case is independent, and numbers are separated by a space.

The input field supports copy/paste operations. The output field only supports copying of the received data.

## 3.6 DAC Tool

The DAC Tool allows you to configure the voltage level on special analog output socket pins.



Figure 78. Analog I/O Pins on ForgeFPGA Socket Adapter

Start by selecting the appropriate development platform and opening the DAC Tool from the toolbar.



Figure 79. DAC Tool on the toolbar

All the analog I/O pins are displayed by default. Use an Analog I/O n button to enable a respective output pin and use a spin box at the right to set a desired voltage level on it (see Figure 80).

|               |         | 5.4.5.T. 1 | 6   |
|---------------|---------|------------|-----|
|               |         | DAC Tool   |     |
| Analog I/O 2  | Ø       | 2.30 V     | :   |
| Analog I/O 4  | m       | 2.30 V     | ;   |
| Analog I/O 6  | m       | 2.30 V     | ;   |
| Analog I/O 7  | m       | 2.30 V     | ;   |
| Analog I/O 18 | m       | 2.30 V     | ;   |
| Analog I/O 20 | ۵       | 2.30 V     | 4   |
| Analog I/O 22 | m       | 2.30 V     | ;   |
| Analog I/O 23 | ۵       | 2.30 V     | 4   |
| Enal          | ble all | Disable    | all |

#### Figure 80. DAC Tool Settings

Note: Setting a voltage level on analog I/O pins is enabled only if Emulation or Test Mode is activated.

# 4. Block Properties

The GoConfigure software's ForgeFPGA Workshop displays the FPGA core and its connections to the different blocks on the board such as Oscillator, PLL, BRAM, and GPIO. Each of these blocks have a set of properties that can be set by selecting the appropriate options for each parameter. To see the Properties of each block, click on the Properties tab from the top toolbar. This will open the properties section on the left side of the window. You can read more about each property for each block by clicking the info@utton



Figure 81. Block Property Editing

# 4.1 FPGA Core

The properties of the FPGA core can be viewed by simply clicking on the block in the main view. The FPGA Core is the main block that is connected to all the GPIOs, OSC, and the PLL. All connections go though this block, so the properties of FPGA Core affect the other blocks as well.

Depending on the design requirement, the user can select the different properties of different parameters from its respective dropdown option. The parameters are (see Figure 82):

- a. Wait for stable OSC/PLL:
  - *Disable*: system will not wait for a stable OSC/PLL clock during the transition from Configuration/Retention mode to Functional mode
  - *Enable*: system will wait for a stable OSC/PLL clock during the transition from Configuration/Retention mode to Functional mode
- b. Logic-As-Clock1 enabled synchronously:
  - *Disable*: Logic-As-Clock1 is enabled/disabled asynchronously
- c. Enable: Logic-As-Clock1 is enabled/disabled synchronously Loopback clk0 enabled synchronously:
  - Disable: Logic-As-Clock0 is enabled/disabled asynchronously
  - Enable: Logic-As-Clock0 is enabled/disabled synchronously
- d. Enter Sleep mode with:

- *nSLEEP*: Use EN (nSLEEP) pin to enter Sleep mode
- Core IOB: Use INT\_FPGA\_SLEEP to enter Sleep mode
- e. Reset system with:
  - *nRESET*: Use PWR (nRST) to reset the system
  - Core IOB: Use INT\_FPGA\_RESET to reset the system
- f. Use 5 µs delay to start BRAM retention:
  - Enable: 5 µs delay will used to start the RAM Retention sequence and block global clocks
  - Disable: 5 µs delay will not be used to start the BRAM Retention sequence and block global clocks
- g. GPIO Keep
  - Enable: GPIO pins keep their state when the chip is in reset
  - Disable: GPIO pins keep their state when the chip is in reset

| Properties                      |                  | × |
|---------------------------------|------------------|---|
| FF                              | PGA Core         |   |
| Wait for stable<br>OSC/PLL: 🗹   | Disable          | - |
| Logic as Clock1<br>enable sync: | Disable          | • |
| Logic as Clock0<br>enable sync: | Disable          | • |
| nSLEEP signal<br>source: 🛙      | Core IOB         | • |
| nRESET signal<br>source: 🛙      | nRESET (PWR) Pin | • |
| 5us timeout<br>enable: 🖤        | Enable           | • |
| Keep GPIO<br>State: 🖾           | Disable          | • |
| 0 5                             | Apply            |   |

Figure 82. FPGA Core's Properties

# 4.2 Phase Locked Loop (PLL)

The SLG47910 has one PLL on board which sources its reference clock either from GPIO2 externally or by the 50 MHz OSC. Under the properties tab of the PLL, there is a parameter which can enable the clock to operate asynchronously or synchronously.

# 4.3 Oscillator (OSC)

A high frequency 50 MHz oscillator on-board is used as a clock to the SLG47910. Under the properties tab for the OSC, there is a parameter which either enables the OSC to operate asynchronously or synchronously.

# 4.4 Block Read Access Memory (BRAM)

We have eight 4K BRAMs available in the SLG47910 with four BRAMs each placed on the top (North) and the bottom (South) of the FPGA Core. The BRAM has three parameters under its property tab:

- a. Memory Retention
  - Enable Enable the memory retention
  - Disable Disable the feature for the BRAM to retain the memory
- b. North BRAM Enable
  - Enable User needs to Enable this bit when using the memory from BRAM [0:3]
  - <sup>o</sup> Disable User needs to enable this bit when using the memory from BRAM [4:7]
- c. South BRAM Enable
  - Enable User needs to Enable this bit when using the memory from BRAM [4:7]
  - Disable User needs to Enable this bit when using the memory from BRAM [0:3]

# 4.5 EN (nSLEEP) & PWR (nRST)

The EN pin is used to enter the FPGA Core into retention state and is active high.

The PWR pin is used to reset the FPGA Core and is active low. All GPIOs are in a Hi-Z state when PWR = 0.

# 4.6 General Purpose Input Output Pin

The SLG47910 contains 24 pins. Of these, 19 are digital GPIOs. The remaining pins are  $V_{DD}$ ,  $V_{DDIO}$ , GND, as well as input only pins for EN (nSLEEP) and PWR (nRST).

The Following Configuration options are available for each GPIO pin:

- Input
- Output, 1x Drive Push-pull
- Output, 2x Drive Push-pull
- Output, 1x Drive Open-drain
- Output, 2x Drive Open-drain

All Input & Output options may additionally include the x1 or x2 Resistor Pull-up option.

| Properties (   |          |                        |         |        |  |  |  |  |  |  |
|----------------|----------|------------------------|---------|--------|--|--|--|--|--|--|
| GPI06 (PIN 19) |          |                        |         |        |  |  |  |  |  |  |
| I/O selection  | on:      | Digital input/outpu 💌  |         |        |  |  |  |  |  |  |
| Input mode     | :        | Digital in without S 💌 |         |        |  |  |  |  |  |  |
| Output mo      | de:      | 1x push pull 🔹         |         |        |  |  |  |  |  |  |
| Resistor:      | (        | Pull Up 💌              |         |        |  |  |  |  |  |  |
| Resistor va    | alue:    | <b>x1</b>              |         |        |  |  |  |  |  |  |
|                | Info     | rmation                |         |        |  |  |  |  |  |  |
| IO Pull-up R   | esistanc | e for sing             | le Pu   | ill-Up |  |  |  |  |  |  |
| Vddio V        | R min 0  | R typ                  | R max Ω | 2      |  |  |  |  |  |  |
| 2.5            | 39 K     | 119                    | 195 K   |        |  |  |  |  |  |  |
| 1.8            | 58.5 K   | 194                    | 291 K   |        |  |  |  |  |  |  |
|                |          |                        |         |        |  |  |  |  |  |  |
| 0              |          | 5                      | Ар      | ply    |  |  |  |  |  |  |

Figure 83. GPIO Properties



The desired configuration can be set from the properties window for each GPIO separately. Similarly, the values for  $V_{DD}$  and  $V_{DDIO}$  can also be set from under the Property tab.

# 5. NVM Viewer

In the ForgeFPGA Workshop the user can view all bits that correspond to each function in the NVM Viewer. 1s and 0s in the NVM Viewer display if a particular function is enabled or disabled.

The NVM Viewer can be viewed by clicking on the appropriate button on the toolbar. The NVM Viewer is divided into byte size addresses. In total the bits range from 0 to 479.

When a <u>block property</u> is changed, the corresponding bit to that parameter changes and it is represented by a change of color.

| NVM I  | bits viev | N       |           |          |        |         |          |          |         |        |     |     |        |          |        |         |       |
|--------|-----------|---------|-----------|----------|--------|---------|----------|----------|---------|--------|-----|-----|--------|----------|--------|---------|-------|
|        |           |         |           |          |        |         |          |          |         |        |     |     |        |          |        |         | U     |
| - HEX: | 0x22, D   | DEC: 34 | )         |          | Addres | s - 0x2 | 0 (Value | e - HEX: | 0x22, E | EC: 34 | )   |     | Addres | s - 0x1F | (Value | - HEX   | 0x22  |
| 267    | 266       | 265     | 264       | 263      | 262    | 261     | 260      | 259      | 258     | 257    | 256 | 255 | 254    | 253      | 252    | 251     | 25    |
| 0      | 0         | 1       | 0         | 0        | 0      | 1       | 0        | 0        | 0       | 1      | 0   | 0   | 0      | 1        | 0      | 0       | 0     |
| •      |           |         |           |          |        |         |          |          |         |        |     |     |        |          | 2      |         |       |
| Prope  | rties     |         |           |          |        | ×       |          |          |         |        |     |     |        |          | GPI    | 07 (Pli | V 20) |
|        |           | GPIO    | 7 (PIN    | 20)      |        |         |          |          |         |        |     |     |        |          |        |         |       |
| I/O s  | election  | n:      | Digita    | l input/ | outpu/ | •       |          |          |         |        |     |     |        |          |        |         |       |
| Input  | mode:     |         | Digita    | l in wit | hout S | •       |          |          |         |        |     |     |        |          |        |         |       |
| Outp   | ut mod    | e:      | 1x pu     | sh pull  |        | •       |          |          |         |        |     |     |        |          |        |         |       |
| Resi   | stor:     |         | Pull U    | lp       |        | •       |          |          |         |        |     |     |        |          |        |         |       |
| Resi   | stor val  | ue:     | <b>x1</b> |          |        | •       |          |          |         |        |     |     | L      |          | OSC    | E       |       |
|        |           | Inf     | ormatio   | on       |        |         |          |          |         | 00     | 107 |     |        |          |        |         |       |
| IO Pu  | ll-up Re  | sistand | ce for s  | ingle P  | ull-Up |         |          |          | o—      | GP     | 107 |     |        |          |        |         |       |
|        |           |         |           | -        | _      |         |          |          |         |        |     |     |        |          |        |         |       |

Figure 84. NVM Bits for GPIO7

If the resistor value is changed from x1 to x2, this results in the change of bits for GPIO7 from 0010 to 0011 (see Figure 85)

| NVM          | oits viev | N       |          |          |          |          |          |         |         |         |     |        |          |          |          |         |     |
|--------------|-----------|---------|----------|----------|----------|----------|----------|---------|---------|---------|-----|--------|----------|----------|----------|---------|-----|
|              |           |         |          |          |          |          |          |         |         |         |     |        |          |          |          |         |     |
| 0x22, [      | DEC: 34)  | )       |          | Addres   | s - 0x20 | ) (Value | e - HEX: | 0x22, [ | DEC: 34 | )       |     | Addres | s - 0x11 | F (Value | e - HEX: | 0x32, I | DEC |
| 266          | 265       | 264     | 263      | 262      | 261      | 260      | 259      | 258     | 257     | 256     | 255 | 254    | 253      | 252      | 251      | 250     | 2   |
| 0            | 1         | 0       | 0        | 0        | 1        | 0        | 0        | 0       | 1       | 0       | 0   | 0      | 1        | 1        | 0        | 0       |     |
|              |           |         |          |          |          |          |          |         |         |         |     |        |          |          |          |         |     |
| Properties 🛞 |           |         |          |          |          |          |          |         |         | (PIN 20 | )   |        |          |          |          |         |     |
| Fiope        | uea       | 0010    | 7 (DIN   | 00       |          |          |          |         |         |         |     |        |          |          |          |         |     |
|              |           | GPIO    | 7 (PIN   | 20)      |          |          |          |         |         |         |     |        |          |          |          |         |     |
| I/0 s        | election  | 1:      | Digita   | l input/ | outpu/   | -        |          |         |         |         |     |        |          |          |          |         |     |
|              |           |         |          |          |          | - 1      |          |         |         |         |     |        |          |          |          |         |     |
| Input        | mode:     |         | Digita   | l in wit | hout S   | -        |          |         |         |         |     |        |          |          |          |         |     |
|              |           |         |          |          |          | _        |          |         |         |         |     |        |          |          |          |         |     |
| Outp         | ut mod    | e:      | 1x pue   | sh pull  |          | -        |          |         |         |         |     |        |          |          |          |         |     |
|              |           |         |          |          |          |          |          |         |         |         |     |        |          |          |          |         |     |
| Resi         | stor:     |         | Pull U   | р        |          | -        |          |         |         |         |     |        |          |          |          |         |     |
|              |           |         |          |          |          |          |          |         |         |         |     |        |          | _        |          | _       |     |
| Resi         | stor val  | ue:     | x2       |          |          | -        |          |         |         |         |     |        | _ L      | -        | OSC      |         |     |
|              |           |         |          |          |          |          |          |         |         |         |     |        |          | _        | _        |         |     |
|              |           | Info    | ormatio  | n        |          |          |          |         | o—      | GP      | 107 |        |          |          |          |         |     |
| IO Pu        | ll-up Re  | sistand | e for si | ingle P  | ull-Up   |          |          |         |         | GP      |     |        |          |          |          |         |     |
|              |           |         |          |          |          |          |          |         |         |         |     |        |          |          |          |         |     |

Figure 85. NVM Bits 0011 after the property has been modified

The user can hover over any bit in the NVM to check which functionality is represented by those bits. A detailed representation of each bit in NVM can be found in the <u>Appendix</u> of the SLG47910's Datasheet.

# 6. IO Planner Signals

Below are few signals that are mentioned in the <u>IO Planner</u> section of the software. The table below explains the functions of a few signals.

| Signal Name             | Direction                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|-------------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| OSC_READY               | Input (to the FPGA Core)          | Indicates that Oscillator output frequency is stable; gates OSC_CLK while OSC_READY=0                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| FPGA_CORE_READY         | Input                             | Signal that indicates when FPGA Core has been configured. Goes HIGF<br>before entering Functional Mode; doesn't go LOW in Retention (Sleep<br>Mode; goes LOW during transition into Reset Mode. Can be used as rese<br>or enable signal for user logic                                                                                                                                                                                                          |  |  |  |  |  |
| FUNC_MODE               | Input                             | Signal that indicates that the device is in Functional Mode. When it goes<br>high - user clocks are ungated available for FPGA Core; when it goes<br>LOW - clocks gating is initiated. Signal goes LOW when exiting from<br>Functional Mode and transits to Retention (Sleep) or Reset Mode. This<br>signal can be used as reset or enable signal if logic requires to be reset<br>when not in Functional Mode or to be enabled only when in Functional<br>mode |  |  |  |  |  |
| INT_FPGA_SLEEP          | Output (from<br>the FPGA<br>Core) | Internal Sleep start signal - initiates transition to Retention (Sleep) mode from IOB (requires Reg [215] to be set)                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| INT_FPGA_RESET          | Output                            | Internal Reset start signal - initiates transition to Reset mode from IOB (requires Reg [216] to be set)                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| REF_LOGIC_AS_CLK0       | Output                            | Logic as Clock 0 Reference signal - output signal that is looped through LaC circuit and returned to core as clock                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| REF_LOGIC_AS_CLK1       | Output                            | Logic as Clock 1 Reference signal - output signal that is looped through LaC circuit and returned to core as clock                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| LOGIC_AS_CLK0_EN        | Output                            | Logic as Clock 0 Enable (active HIGH)                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| LOGIC_AS_CLK1_EN        | Output                            | Logic as Clock 1 Enable (active HIGH)                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| LOGIC_AS_CLK0           | Input                             | Logic as Clock 0                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| LOGIC_AS_CLK1           | Input                             | Logic as Clock 1                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| REF_BRAM (03)_READ_CLK  | Output                            | BRAM Slices 03 Read Clock                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| REF_BRAM (03)_WRITE_CLK | Output                            | BRAM Slices 03 Write Clock                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| REF_BRAM (47)_READ_CLK  | Output                            | BRAM Slices 47 Read Clock                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| REF_BRAM (47)_WRITE_CLK | Output                            | BRAM Slices 47 Write Clock                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| GPIOX_OUT               | Output                            | GPIOX Output value                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| GPIOX_OE                | Output                            | GPIOX Output Enable (active HIGH)                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| GPIOX_IN                | Input                             | GPIOX Input value                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |

# 7. Revision History

| Revision | Date         | Description                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|----------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 1.00     | May 20, 2024 | Initial release.                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| 2.00     | Oct 22, 2024 | <ul> <li>Added new sections on</li> <li>Import/Export RTL Files</li> <li>Design Template</li> <li>Synthesis Report</li> <li>Updated PLL Calculator</li> <li>Updated Project Directory Folder</li> <li>Changed Advanced Dev Board name to Deluxe Dev Board</li> <li>DAC Tool</li> <li>Updated Block Properties</li> </ul> |  |  |  |  |  |

# A. Appendix: Warnings

Below is a list of warnings & its respective meaning that the Yosys displays in the Logger section of the software after <u>Synthesis</u> and <u>Generate Bitstream</u> Process

1. The network is combinational (run "fraig" or "fraig\_sweep").

>> This is an error generated when handling a purely combinational input. It is produced by the optimization tool and can be simply ignored.

2. Bit <N> of cell port <port> driven by <D> will be left unconnected in EDIF output.

>> Port is driven by an undefined value. Connect the port to a proper driver.

3. Exporting x-bit on <N> as zero bit.

>>A port is in an undefined state. Make sure it is driven by a proper signal.

4. Cell <M> is an unmapped internal cell of type <T>.

>>After synthesis you are left with unmapped cells, make sure you use valid synthesizable Verilog.

5. Drivers conflicting with a constant <N> driver: <K>

>> A port was driven by both a constant value and a signal. Please correct your code.

6. Multiple conflicting drivers for <N>: <K>

>>Several wires were defined to drive a port. Please correct your code.

7. Wire <N> is used but has no driver.

>>No driver was assigned to a wire.

8. Wire <N> has 'init' attribute and is not driven by an FF cell.

>>A wire is set to be initialized to a certain value but is not driven by an FF.

9. I/O pin name not found! <N>

>> A port name was specified in the I/O Planner, but the match for it wasn't found in the synthesized netlist. Please make sure the names of the ports in the I/O Planner correspond to your design.

10. Input IOB port specification differs from the resulting one. Please check if all IOB ports were mapped properly.

>> Input and output I/O Planner specifications differ. Check if you've mapped the ports of your design correctly.