# Physical Design using OpenLANE SKY130

#### **NIGIL MOHRA**

## **Installing OpenLane**

#### OpenLane Ubuntu Installation

To install the necessary tools, please refer to the link. Follow the instructions provided and run the example given to verify that the OpenLANE tools are installed correctly. Ensure that all commands are executed as the root user.

#### **Installation Errors**

During the initial make smoke test, some users might encounter the error:

```
qt.qpa.plugin: Could not load the Qt platform plugin "xcb" in "" even though it was found
```

This error indicates a problem with loading the Qt platform plugin xcb which is necessary for opening the user interface.

This issue can be resolved by running the command <code>xhost +local:\*</code> to allow local connections. This creates a workspace directory in the home directory if it doesn't already exist. This permits the root user on the local machine to connect to GUI applications. After completing the work, before closing the terminal, remember to revert the setting by running <code>xhost -local:\*</code>.

# **Pilot Design**

To get started, install a text editor like vim using the command:

```
sudo apt-get install vim
```

#### **Full Adder**

All design files with the .v extension are stored in the src folder within a directory named after the design, located inside the designs folder of the OpenLane directory. For example, the Verilog implementation of a one-bit full adder will have its files in this structure, and the GDSII file is generated using the OpenLane ASIC flow.

Create a folder named fa inside the designs folder by running the following command:

```
sudo mkdir fa
```

To create the RTL file, you can either copy and paste the file directly into this folder or use the following Linux commands to create the necessary files.

Inside the <code>OpenLane/designs/fa/src</code> folder, open the terminal and run the following command to create a file for the one-bit full adder:

```
cat > fa.v
```

After typing this command, enter the RTL code for the one-bit full adder. To save and exit the terminal-based text editor, press Ctrl + D.

Next, open the RTL file in vim with the following command:

```
vim fa.v
```

Add or modify the RTL design for the full adder as needed. To save the changes and exit vim, use the command:

:wq

## **Configuration File**

#### Creating the Configuration File

To run the one-bit full adder, a configuration file is required. To invoke the Docker container, navigate to the OpenLane directory (which contains the Makefile) and use the following command:

```
sudo make mount
```

Once the Docker container is successfully invoked, enter tel interactive mode by running the following command:

```
./flow.tcl -interactive
```

To create a <code>config.tcl</code> file in the <code>designs</code> folder, use the script below. Replace <code><design\_name></code> with the name of the main module, ensuring that it matches the module name and the file name of the RTL design:

```
./flow.tcl -design <design_name> -init_design_config -add_to_designs -config_file config.tcl
```

## Modifying the Configuration File

To modify the contents of the config.tcl file, open the file in Vim as root user.

```
sudo vim config.tcl
```

Press I to enter INSERT MODE in Vim.Update the config.tcl file with the following content:

Press  ${\tt ESC}$  to exit  ${\tt INSERT}$   ${\tt MODE}$ . To save the changes and exit  ${\tt Vim}$ , type:

```
:wq
```

If an error is encountered while saving, add an exclamation mark to force the save and exit:

```
:wq!
```

## Synthesizing the Design

To streamline the design flow and make it simpler, create the fa\_synth.tcl file using the following command:

```
cat > fa_synth.tcl
```

After entering the command, press Ctrl + D to exit. Open the fa\_synth.tcl file in Vim and enter the following contents into the file:

```
package require openlane
prep -design fa -tag run1 -overwrite
run_synthesis
run_floorplan
run_placement
run_routing
run_magic
```

Save the changes and exit.

To run the PD, enter tcl interactive mode again using the previously described steps. Then, execute the following command to run the entire design flow:

```
source fa_synth.tcl
```

If all steps are followed correctly, the complete design flow is done.

#### Results

To inspect the Floorplan, Routing, Placement, and complete GDS file, the klayout tool can be used. Use the following command to install the klayout tool:

```
sudo apt-get install klayout
```

Launch klayout . The first step is to select the process technology sky130nm. To set up the process technology, open the terminal in the openLANE folder and switch to the root user by running:

```
sudo su
```

Use the following commands to navigate and download the lyt file. Use ls to list directories and ensure accurate navigation. Note that commands to navigate and list directories are not explicitly shown here; verify directory names as needed.

| Command      | Purpose                                                           |
|--------------|-------------------------------------------------------------------|
| cd           | Change directory.                                                 |
| pwd          | Display the full pathname of the current directory.               |
| ls -a        | List all items, including hidden files, in the current directory. |
| cd .volare   | Navigate to the .volare directory.                                |
| cd sky130A   | Navigate to the sky130A directory.                                |
| cd libs.tech | Navigate to the libs.tech directory.                              |
| cd klayout   | Navigate to the klayout directory.                                |
| cd tech      | Navigate to the tech directory.                                   |

In the tech directory, three .1yt files will be present. Copy the sky130A.1yt file to the design folder.

```
cp sky130A.lyt /home/nigil/OpenLane/designs/fa/runs/
```

### **Technology Node Setup**

To set up the technology node in klayout, follow these steps:

- 1. In the menu bar, click on Tools and select Manage Technologies.
- 2. In the dialog box that appears, add the sky130A.lyt file.
- 3. Press ok to confirm and exit the dialog.

In the workspace, locate the technology node setting. Change the technology node from  $_{\tt default}$  to  $_{\tt sky130nm}$ . This will configure  $_{\tt klayout}$  to use the  $_{\tt sky130nm}$  technology node for your design files.

## **Checking the Layouts and Reports**

To check the various layout results in klayout, add the Library Exchange File (LEF) by following these steps:

- 1. In the menu bar, click on File and go to Reader Options. A dialog box will appear.
- 2. Navigate to the design folder, then to runs followed by tmp, and find the file  $design_n = min.lef$ .
- 3. Add this file to the dialog box under the LEF/DEF section.
- 4. Press OK to confirm and exit the dialog box.

Note: There may be multiple .lef files. Select the one that matches your process variation needs.

To view the results, go to File then go to Open and navigate to the results folder inside the runs directory. Open any folder within results and select a .def file to view the layout in the workspace. Similarly, the GDSII file will be located inside the signoff directory. Navigate to this directory and open the .gds file to view it.



## (Miscellaneous) Running with Constraints

To run a design with constraints, create a .sdc file. The .sdc (Synopsys Design Constraints) file, or .xdc (Xilinx Design Constraints) file, can be generated using Xilinx Vivado or an appropriate Synopsys tool. This file will specify the design constraints. Update the config.tcl File:

```
set ::env(BASE_SDC_FILE) $::env(DESIGN_DIR)/fa.sdc
set ::env(RUN_CTS) 1
```

```
set ::env(CLOCK_PERIOD) "100.000"
set ::env(CLOCK_PORT) "virtual_clk"
```

These settings will enable constraint processing, set the clock period, and specify the clock port. Follow the same procedures as before to generate the <code>GDSII</code> file. Running the design with constraints will produce detailed **Area, Timing, and Power** reports. The reports will be located in the <code>reports</code> folder inside the <code>runs</code> directory. Check this folder for the detailed reports on area, timing, and power.

# **OpenLane Flow**



#### References

- 1. OpenLANE: RTL-to-GDSII Flow Part-1
- 2. OpenLANE: RTL-to-GDSII Flow Part-2
- 3. OpenLANE Documentation

#### Copyright © 2024 Nigil

This work is created using **Obsidian** and is licensed under the **Creative Commons Attribution 4.0 International License**