

# 半導体製造 (TinyTapeout)に 挑戦しよう！ Sky130版

Noritsuna Imamura  
[noritsuna@ishi-kai.org](mailto:noritsuna@ishi-kai.org)



# 本日のメニュー

- 半導体製造 ≒ TinyTapeout とは？
- TinyTapeout の過去の作品例紹介
- TinyTapeout でテープアウト（半導体製造）までの工程を体験してみる



Tiny Tapeout 4 - From idea to chip design in minutes!

# TinyTapeoutとは？

デジタル・デザインを実際のチップ上で製造することを、  
これまで以上に簡単かつ安価に実現する教育プロジェクトです！

<https://tinytapeout.com/>

# Tiny Tapeout 4

From idea to chip design  
in minutes!

後で見る 共有

# デジタル・デザインとは？

Verilogで書くことも可能

## LOGIC GATES



# プロジェクト（サービス）内容

| 設計ツール（EDAツール）                                                                                                                                                                                                                                                                                      | 仕様(Pin)                                                                                                                                                                                                                                                                 | お値段                                                                                                                                                                                                                                                                                                                                    | 回数                                                                                                                                                      |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul style="list-style-type: none"><li>デジタル</li><li>OpenLANE</li><li>アナログ</li><li>回路設計<ul style="list-style-type: none"><li>xschem</li></ul></li><li>シミュレーション<ul style="list-style-type: none"><li>ngspice</li></ul></li><li>レイアウト<ul style="list-style-type: none"><li>klayout</li></ul></li></ul> | <ul style="list-style-type: none"><li>I/O(デジタル)<ul style="list-style-type: none"><li>Input 8pins</li><li>Output 8pins</li><li>In/Out 8pins</li><li>Reset</li><li>Clock 10MHz</li></ul></li><li>I/O(アナログ)<ul style="list-style-type: none"><li>8pins</li></ul></li></ul> | <ul style="list-style-type: none"><li>半導体 (区画 + Pin) + 基板(\$100) + 送料</li><li>半導体(1区画ごと)<ul style="list-style-type: none"><li>1Tile(区画) = \$50</li><li>Pin(1ピンごと)<ul style="list-style-type: none"><li>デジタル：無料</li><li>アナログ<ul style="list-style-type: none"><li>~4ピン=\$40</li><li>5~8ピン=\$100</li></ul></li></ul></li></ul></li></ul> | <ul style="list-style-type: none"><li>リードタイム<ul style="list-style-type: none"><li>約半年</li></ul></li><li>およそ2~3か月に一回</li><li>ChipIgniteのペースによる</li></ul> |

# 1区画（ユーザエリア）は？

- 1区画 : 167um x 108um
  - SkyWater130nmプロセス
  - TinyTapeout4は「**350分割**」
    - ChipIgniteのユーザエリア  
「3.2mm x 3.1mm」

Shuttle Map



で？どのくらいってこと？？？

- i4004の利用セル（ゲート）数:1071
  - 空間的には半分しか使っていない  
2000セルくらいが限界か?
    - ピンが上部にしかない（次のページ参照）
    - AutoRouterがあまり頭良くない

## Routing stats

| Utilisation (%) | Wire length (um) |
|-----------------|------------------|
| 50.586 %        | 25442            |

## Cell usage by Category

| Category    | Cells                                                                                                           | Count |
|-------------|-----------------------------------------------------------------------------------------------------------------|-------|
| Fill        | <a href="#">decap fill</a>                                                                                      | 1216  |
| Misc        | <a href="#">ebufn</a> <a href="#">dlygate4sd3</a>                                                               | 268   |
| Combo Logic | <a href="#">o21ai</a> <a href="#">a22oi</a> <a href="#">a221oi</a> <a href="#">a21o</a> <a href="#">a21oi</a>   | 177   |
| Flip Flops  | <a href="#">dfrbp</a>                                                                                           | 158   |
| NOR         | <a href="#">nor3</a> <a href="#">nor2</a> <a href="#">nor2b</a> <a href="#">nor4</a> <a href="#">xnor2</a>      | 109   |
| Buffer      | <a href="#">buf</a>                                                                                             | 103   |
| Multiplexer | <a href="#">mux2</a> <a href="#">mux4</a>                                                                       | 99    |
| NAND        | <a href="#">nand2b</a> <a href="#">nand2</a> <a href="#">nand3b</a> <a href="#">nand3</a> <a href="#">nand4</a> | 95    |
| Inverter    | <a href="#">inv</a>                                                                                             | 45    |
| AND         | <a href="#">and3</a> <a href="#">and2</a> <a href="#">and4</a>                                                  | 10    |
| OR          | <a href="#">or2</a> <a href="#">or3</a> <a href="#">xor2</a>                                                    | 7     |

1071 total cells (excluding fill and tap cells)

i4004

使用率：50%



# PCBとは？

- プリント基板：これは初期モデル
  - U1にところに作られたASICが載る
  - ユーザ用
    - 8 DIP switch inputs x 1
    - 6x2 Header Pins x 2(PMOD)
    - 7seg LED
  - システム用
    - 9 DIP switch x 1
      - IDセレクト用
    - 3x2 Header Pins x 1
      - Debug?
    - Type-C port
      - Power Supply



# Web設計ツールは？

<https://wokwi.com/projects/354858054593504257>

WOKWI SAVE SHARE Tiny Tapeout 5 Template by urish Docs S

README.md diagram.json Library Manager

1 # Tiny Tapeout 5 Template Project

2

3 TinyTapeout is an educational project that makes it easier and cheaper

4 than ever to get your digital designs manufactured on a real chip.

5

6 Wokwi provides an easy way to create digital designs for Tiny Tapeout.

7 You create a design out of individual logic gates, and simulate them

8 with Wokwi to observe the result.

9

10 When your design is ready, you can submit it for manufacturing on a

11 physical chip with Tiny Tapeout.

12

13 To learn more, follow the tutorial at [https://tinytapeout.com/digital\\_design/](https://tinytapeout.com/digital_design/)

14

15 Note: when creating your own project, please replace this text with information

16 about your projects: what it does and how to use it.

17

Simulation Description

PLAY + :

Verilogで書くことも可能

Bidirectional I/O pins

|           |           |
|-----------|-----------|
| IN OUT D0 | IN OUT D4 |
| IN OUT D1 | IN OUT D5 |
| IN OUT D2 | IN OUT D6 |
| IN OUT D3 | IN OUT D7 |

---

# 過去の 作品例

---

- こちらにリンクがあります
  - [https://tinytapeout.com/digital\\_design/](https://tinytapeout.com/digital_design/)
  - <https://tinytapeout.com/runs/>



WOKWI

SAVE ▾ SHARE ❤ Docs SIGN IN

Simulation Description

▶ + ⋮



## Simulation

## Description



⌚ 00:27.974 ⚡ 100%



This is a 12-bit basic PDP8 cpu - it doesn't have the extended arithmetic unit (so no multiply or divide). Included is an assembler (mostly for test). Bus interface is a 5-clock to get 12 bits of address and 12 bits of data though 8-bit interfaces. Address is 2 beats of 6 bits each, data is 3 beats of 4 bits each, I/O cycles have an extra beat



```
output bits
7 6 5 4 3 2 1 0
1 0 A A A A A A      address hi
1 1 A A A A A A      address lo

0 1 1 I I 4 2 1      IO cycle intro

either
0 0 0 0 - - - -    read data high nibble
0 0 1 0 - - - -    read data med nibble
0 1 0 0 - - - -    read data low nibble
or
0 0 0 1 D D D D    write data high nibble
0 0 1 1 D D D D   write data med nibble
0 1 0 1 D D D D   write data low nibble
```



## How it works

Truth table with the game logic (hidden easter egg). The inputs are the positions of the farmer, wolf, goat and cabbage. The 7-segment display shows the status of the game (won or lost).

テープアウト  
(半導体製造)  
まで体験





## 使ってみた感想

- 作業日数
  - 4日間：土日を2回
- 何を作るのか？
  - ポイント：カッコいいことは考えない！
  - PCB無しもあるので、それをダイソーのアクセサリー作成キットでキー ホルダーにするってのもあり！
  - 製造することを楽しもう！

# 1, GitHubテンプレートをforkする

- Githubのテンプレート
  - Wokwi用
    - <https://github.com/TinyTapeout/ttsky-wokwi-template>
  - HDL(Verilog)用
    - <https://github.com/TinyTapeout/ttsky-verilog-template>
  - アナログ用
    - <https://github.com/TinyTapeout/ttsky-analog-template>

※このテンプレートは、TinyTapeoutのSkyシャトル（製造）用です。  
投稿するシャトル（製造）用のをお使いください。

今回はVerilogプロジェクトとします

TinyTapeout / **ttihp-verilog-template**

Type / to search

<> **Code** ⚡ Issues 1 Pull requests Actions Projects Security Insights

**ttihp-verilog-template** Public template

Watch 2 Fork 19

Existing forks

You don't have any forks of this repository.

+ Create a new fork

main ▾ 2 Branches 0 Tags

Go to file

urish ci(gds): add pdk parameter for precheck action 976b8df · 2 weeks ago 46 Commits

.devcontainer chore: update tags for ttihp25b 3 weeks ago

.github/workflows ci(gds): add pdk parameter for precheck action 2 weeks ago

This screenshot shows a GitHub repository page for 'ttihp-verilog-template'. The repository is a public template. At the top right, there is a 'Fork' button with a count of 19, which is circled in red. Below it, a modal window titled 'Existing forks' displays the message 'You don't have any forks of this repository.' At the bottom of this modal, there is a button labeled '+ Create a new fork', also circled in red. The main repository page shows two branches: 'main' and '2 Branches', and zero tags. There are three recent commits listed: one by 'urish' adding a pdk parameter for a precheck action, another updating tags for 'ttihp25b', and a third by 'ci(gds)' adding a pdk parameter for a precheck action. The GitHub interface includes standard navigation links like 'Code', 'Issues', 'Pull requests', 'Actions', 'Projects', 'Security', and 'Insights'.

TinyTapeout / ttihp-verilog-template

Type  to search

Code Issues 1 Pull requests Actions Projects Security Insights

## Create a new fork

A fork is a copy of a repository. Forking a repository affecting the original project. [View existing forks.](#)

Required fields are marked with an asterisk (\*).

Owner \* noritsuna Repository name \* ttihp25b-tt\_um\_noritsur

ttihp25b\_tt\_um\_noritsuna\_CAN\_CTRL is available.

By default, forks are named the same as their upstream repository. You can customize the name to distinguish it further.

Description (optional) CAN Controller for Rocket.

Copy the main branch only

Contribute back to TinyTapeout/ttihp-verilog-template by adding your own branch. [Learn more.](#)

You are creating a fork in your personal account.

Create fork

プロジェクト名をつける  
ttihp25b-  
tt\_um\_[username]\_[projectname]

# 2, GitHubをlocalにcloneする

- コミット可能な形でcloneしてください



# 3-1, info.yamlを書き換える

- Title
  - プロジェクトの名前
- Author
  - 自分の名前
- Discord
  - Discord ID (運営からの連絡用)
- Description
  - プロジェクトの説明
- Language
  - “Verilog”的まで
- Clock\_hz
  - 利用したいクロック数を指定

```
# Tiny Tapeout project information

project:
  title:      ""      # Project title
  author:     ""      # Your name
  discord:    ""      # Your discord username, for communication and automatically assigning you a
  description: ""      # One line description of what your project does
  language:   "Verilog" # other examples include SystemVerilog, Amaranth, VHDL, etc
  clock_hz:   0       # Clock frequency in Hz (or 0 if not applicable)
```

## 3-2, info.yamlを書き換える

- tiles
  - 必要なサイズを選択
- Top\_module
  - ttihp25b-tt\_um\_[username]\_[projectname]のtt\_以降
- Source\_files
  - 使用するVerilogファイルをすべて列挙する（1行1ファイル）

```
# How many tiles your design occupies? A single tile is about 167x108 uM.
tiles: "1x1"          # Valid values: 1x1, 1x2, 2x2, 3x2, 4x2, 6x2 or 8x2

# Your top module name must start with "tt_um_". Make it unique by including your github username:
top_module: "tt_um_example"

# List your project's source files here.
# Source files must be in ./src and you must list each source file separately, one per line.
# Don't forget to also update `PROJECT_SOURCES` in test/Makefile.
source_files:
  - "project.v"
```

# 3-3, info.yamlを書き換える

- 入力する場合はそれぞれのピン名を入力します。
  - 空欄だとエラーとなります

```
# The pinout of your project. Leave unused pins blank. DO NOT delete or add any pins.
# This section is for the datasheet/website. Use descriptive names (e.g., RX, TX, MOSI, SCL, SEG_A, etc.).
pinout:
    # Inputs
    ui[0]: ""
    ui[1]: ""
    ui[2]: ""
    ui[3]: ""
    ui[4]: ""
    ui[5]: ""
    ui[6]: ""
    ui[7]: ""

    # Outputs
    uo[0]: ""
    uo[1]: ""
    uo[2]: ""
    uo[3]: ""
    uo[4]: ""
    uo[5]: ""
    uo[6]: ""
    uo[7]: ""

    # Bidirectional pins
    uio[0]: ""
    uio[1]: ""
    uio[2]: ""
    uio[3]: ""
    uio[4]: ""
    uio[5]: ""
    uio[6]: ""
    uio[7]: ""

# Do not change!
yaml_version: 6
```

# 4-1, GitHub Actionsを有効にする

The screenshot shows the GitHub repository settings page for the repository `noritsuna / ttihp25b-tt_um_noritsuna_CAN_CTRL`. The **Settings** tab is highlighted with a red oval. On the left, the **Pages** section is selected in the sidebar. The main area displays the **GitHub Pages** configuration.

**GitHub Pages** is designed to host your personal, organization, or project pages from a GitHub repository.

**Build and deployment**

**Source**

**Deploy from a branch**

**GitHub Actions**  
Best for using frameworks and customizing your build process

**Deploy from a branch**  
Classic Pages experience

Learn how to [add a Jekyll theme](#) to your site.

**Custom domain**  
Custom domains allow you to serve your site from a domain other than `noritsuna.github.io`. [Learn more about configuring custom domains.](#)

Save Remove

# 4-2, GitHub Actionsを有効にする

The screenshot shows a GitHub repository page for 'noritsuna / ttihp25b-tt\_um\_noritsuna\_CAN\_CTRL'. The 'Actions' tab is highlighted with a red oval. Below it, a message states: 'Workflows aren't being run on this forked repository' because workflow files were present when it was forked. It advises understanding workflows before enabling them. A green button labeled 'I understand my workflows, go ahead and enable them' is also highlighted with a red oval.

noritsuna / ttihp25b-tt\_um\_noritsuna\_CAN\_CTRL

Type / to search

Code Pull requests Actions Projects Wiki Security Insights Settings

Workflows aren't being run on this forked repository

Because this repository contained workflow files when it was forked, we have disabled them from running on this fork. Make sure you understand the configured workflows and their expected usage before enabling Actions on this repository.

I understand my workflows, go ahead and enable them

View the workflows directory

# 5, GitHub ActionsでGDSを実行する

- gdsを選択します
  - GDSが半導体製造のためのファイルとなります



noritsuna / ttihp25b-tt\_um\_noritsuna\_CAN\_CTRL

Type / to search

Code Pull requests Actions Projects Wiki Security Insights Settings

New workflow

All workflows

docs fpga gds test

Management

Caches Attestations Runners Usage metrics Performance metrics

gds

gds.yaml

Filter workflow runs

...

0 workflow runs

This workflow has a workflow\_dispatch event.

Event Status Branch Actor

Run workflow

Use workflow from

Branch: main

Run workflow

ターゲットとなる Branch名を選択する

This workflow has no runs yet.

The screenshot shows the GitHub Actions interface for a repository named 'ttihp25b-tt\_um\_noritsuna\_CAN\_CTRL'. The 'Actions' tab is selected. On the left, there's a sidebar with 'All workflows' and a list of workflow names: 'docs', 'fpga', 'gds' (which is selected and highlighted with a blue background), and 'test'. Below that is the 'Management' section with links for 'Caches', 'Attestations', 'Runners', 'Usage metrics', and 'Performance metrics'. The main area shows a workflow named 'gds' with a file named 'gds.yaml'. It displays '0 workflow runs' and a message stating 'This workflow has a workflow\_dispatch event.' There are dropdown menus for 'Event', 'Status', 'Branch', and 'Actor'. A large green button labeled 'Run workflow' is present. A red oval highlights this button, and a callout bubble with Japanese text 'ターゲットとなる Branch名を選択する' (Select the target Branch name) points to it. Another red oval highlights the 'Branch: main' dropdown menu. A small icon of a play button with a network graph is also visible. At the bottom, a message says 'This workflow has no runs yet.'

noritsuna / ttihp25b-tt\_um\_noritsuna\_CAN\_CTRL

Type / to search

Code Pull requests Actions Projects Wiki Security Insights Settings

Workflow run was successfully requested.

Actions New workflow

All workflows

docs fpga gds test

生成中はクルクル回転する

gds

gds.yaml

Filter workflow runs

... Event Status Branch Actor

Run workflow

0 workflow runs

This workflow has a `workflow_dispatch` event trigger.

gds #1: Manually run by noritsuna main now In progress ...

Management Caches Attestations

The screenshot shows a GitHub repository page for 'ttihp25b-tt\_um\_noritsuna\_CAN\_CTRL'. The 'Actions' tab is selected. A message at the top says 'Workflow run was successfully requested.' Below it, the 'Actions' section lists several workflows: 'docs', 'fpga', 'gds' (which is currently selected), and 'test'. An orange speech bubble with the Japanese text '生成中はクルクル回転する' (While generating, it spins) points to the 'gds' workflow. The 'gds' workflow card shows the file 'gds.yaml'. The workflow has 0 runs and a note: 'This workflow has a workflow\_dispatch event trigger.' A 'Run workflow' button is available. The specific run 'gds #1' is shown with status 'In progress', triggered 'now' by 'noritsuna'. The run card also includes 'main' and three dots (...).

noritsuna / ttihp25b-tt\_um\_noritsuna\_i4004

Type / to search

Code Pull requests Actions Projects Wiki Security Insights Settings

← gds

✓ gds #13 Re-run all jobs ...

Summary

Manually triggered 11 minutes ago

noritsuna -> 2195e90 main Status Success Total duration 11m 38s Artifacts 6

Jobs

- ✓ gds
- ✓ precheck
- ✓ gl\_test
- ✓ viewer

gds.yaml

on: workflow\_dispatch

```
graph LR; A[gds] -- "10m 31s" --> B[precheck]; B -- "58s" --> C[gl_test]; C -- "50s" --> D[viewer]; D -- "17s" --> E
```

Run details

Usage

Workflow file

[ ] [-] [+]

# Routing stats

| Utilisation (%) | Wire length (um) |
|-----------------|------------------|
| 50.586 %        | 25442            |

## Cell usage by Category

| Category    | Cells                                                                                                           | Count |
|-------------|-----------------------------------------------------------------------------------------------------------------|-------|
| Fill        | <a href="#">decap fill</a>                                                                                      | 1216  |
| Misc        | <a href="#">ebufn</a> <a href="#">dlygate4sd3</a>                                                               | 268   |
| Combo Logic | <a href="#">o21ai</a> <a href="#">a22oi</a> <a href="#">a221oi</a> <a href="#">a21o</a> <a href="#">a21oi</a>   | 177   |
| Flip Flops  | <a href="#">dfrbp</a>                                                                                           | 158   |
| NOR         | <a href="#">nor3</a> <a href="#">nor2</a> <a href="#">nor2b</a> <a href="#">nor4</a> <a href="#">xnor2</a>      | 109   |
| Buffer      | <a href="#">buf</a>                                                                                             | 103   |
| Multiplexer | <a href="#">mux2</a> <a href="#">mux4</a>                                                                       | 99    |
| NAND        | <a href="#">nand2b</a> <a href="#">nand2</a> <a href="#">nand3b</a> <a href="#">nand3</a> <a href="#">nand4</a> | 95    |
| Inverter    | <a href="#">inv</a>                                                                                             | 45    |
| AND         | <a href="#">and3</a> <a href="#">and2</a> <a href="#">and4</a>                                                  | 10    |
| OR          | <a href="#">or2</a> <a href="#">or3</a> <a href="#">xor2</a>                                                    | 7     |

1071 total cells (excluding fill and tap cells)



# 6, GitHub Actionsでtestを実行する

- GDSの実行ができていれば、エラーは出ません。

The screenshot shows the GitHub Actions interface for a repository named "noritsuna / ttihp25b-tt\_um\_noritsuna\_CAN\_CTRL". A specific workflow named "test" has been triggered via a push 12 minutes ago. The status is "Success" with a total duration of 35s and one artifact produced. The "test.yaml" file defines a single job named "test" which passed in 29s. The "test summary" section indicates "All tests passed" with 1 test passed. The "Artifacts" section lists a single artifact named "test-vcd" which is 892 Bytes in size and has a digest of sha256:33d98fc1e3b7b165... .

| Name     | Size      | Digest                     |
|----------|-----------|----------------------------|
| test-vcd | 892 Bytes | sha256:33d98fc1e3b7b165... |

# 7, TinyTapeoutに提出(submit)する

- TinyTapeoutのHPから提出(submit)を行う
  - <https://app.tinytapeout.com/projects/create>
  - GitHubとTinyTapeoutのアカウントを紐づけられる
  - ここで、支払いも行われます



# 8bits Counter by AI

Repo: [https://github.com/noritsuna/tt04-tt\\_um\\_8bitcounter\\_AI](https://github.com/noritsuna/tt04-tt_um_8bitcounter_AI)

Tiles: 1x1

Shuttle: [Tiny Tapeout 04](#)

You own this project.

## Submissions

Create a new submission whenever you want to push a new revision of your project's [GDS file](#) to the shuttle. Each submission creates a pull request on the [Tiny Tapeout GitHub repo](#). You can create as many submissions as you want, but only the most recent one will be used for the shuttle.

✓ Submission created successfully!

### Log:

```
↑ Creating commit on branch projects/tt_um_noritsuna_8bitcounter_AI-6097569513
Commit, hash = 00f3a253. Creating Pull Request...
Pull Request created successfully:
https://github.com/TinyTapeout/tinytapeout-04/pull/90
✓ Submission completed successfully!
```

| Time            | Commit                   | Tiles | PR                  | Status |
|-----------------|--------------------------|-------|---------------------|--------|
| Wed Sep 06 2023 | <a href="#">4ddd8a76</a> | 1x1   | <a href="#">#90</a> | Open   |

# Tiny Tapeout 04

## Your allocations

✓ You have purchased **1 tile** on Tiny Tapeout 04.

Your projects currently are using **1 tile**.

✓ You have purchased **1 copy** of the Tiny Tapeout 04 PCB.

[PREPURCHASE SPACE ON TINY TAPEOUT 04](#)

## Your projects

| Project                             | Tiles | Status    |
|-------------------------------------|-------|-----------|
| <a href="#">8bits Counter by AI</a> | 1x1   | Submitted |

[CREATE A NEW PROJECT](#)

# 8, TinyTapaoutに登録される

Tiny Tapeout

Shuttle Status: Tiny Tapeout 04

| Item  | Total | Allocated | Free | Available | Progress                                  |
|-------|-------|-----------|------|-----------|-------------------------------------------|
| Tiles | 350   | 115       | 115  | 235       | <div style="width: 32.94%;"></div> 32.94% |
| PCBs  | 200   | 67        | 67   | 133       | <div style="width: 33.5%;"></div> 33.5%   |

Shuttle Map

Projects

| Project                             | Tiles | Status                                         |
|-------------------------------------|-------|------------------------------------------------|
| scikit                              | 1x1   | Draft                                          |
| OddEvenSorter                       | 1x1   | Submitted                                      |
| The Bulls and Cows game             | 1x1   | Submitted                                      |
| Matrix Multiplier                   | 1x1   | Assigned <span style="color: orange;">▲</span> |
| WC-16-bit CPU                       | 1x2   | Submitted                                      |
| TinyTapeout 04 Factory Test         | 1x1   | Submitted                                      |
| TinyTapeout 04 Loadbank Test Module | 1x1   | Submitted                                      |

| Template                                    | 1x2 | Status    |
|---------------------------------------------|-----|-----------|
| Padlock                                     | 1x1 | Submitted |
| Barcode_Display_v1                          | 1x1 | Submitted |
| Traffic_Light                               | 1x1 | Submitted |
| Model_Railway_turntable_polarity_controller | 1x1 | Submitted |
| Kampus-Strong_Swing_Synthesis               | 2x2 | Submitted |
| Logic_Circuit_1                             | 1x1 | Draft     |
| Random_number_generator                     | 1x1 | Draft     |
| UART_character_tx                           | 1x1 | Submitted |
| Customizable_UART_string_tx                 | 1x1 | Submitted |
| <a href="#">8bit_Counter_32bit</a>          | 1x1 | Submitted |

Copyright (C) 2023, Tiny Tapeout LTD. Revision E00058 built at 2023-09-08T10:27:02.

# ローカル環境 構築手順



# 1, Local環境でGDSを生成する

- 毎回githubにアップロードして、ビルドを試すのでは開発効率が非常に悪いです。
  - そこで、ローカルでビルド（GDS生成）をする方法を解説します。
- 環境
  - WSL上のUbuntu24.04
  - Docker Desktop for Windows

# 2-1, Dockerオプションの設定



## 2-2, Dockerグループの設定

1. /etc/groupをroot権限で編集する
  1. sudo nano /etc/group
2. dockerグループに自分のユーザIDを追加する
3. WSLを再起動する

```
ishikai@NORITSUNA-2019: ~ × + |`  
utmp:x:43:  
video:x:44:ishikai  
sasl:x:45:  
plugdev:x:46:ishikai  
staff:x:50:  
games:x:60:  
users:x:100:ishikai  
nogroup:x:65534:  
systemd-journal:x:999:  
systemd-network:x:998:  
crontab:x:997:  
systemd-timesync:x:996:  
input:x:995:  
sgx:x:994:  
kvm:x:993:  
render:x:992:  
messagebus:x:101:  
syslog:x:102:  
systemd-resolve:x:991:  
uuidd:x:103:  
_ssh:x:104:  
landscape:x:105:  
polkitd:x:990:  
admin:x:106:  
netdev:x:107:ishikai  
lxd:x:1000:ubuntu  
ubuntu:x:1001:  
ishikai:x:1002:  
docker:x:1003:root,ishikai  
-- INSERT
```

# 3, Local環境でGDSを生成する

- 必要なソフトウェアをセットアップする

```
> sudo apt install python3.12-venv python3-tk librsvg2-bin pngquant make iverilog
```

# 5, Local環境でGDSを生成する

- 環境変数を設定する
  - 再起動するたびに失われます。
  - 永続化するには、`./.bashrc`に書き込むなどしてください

```
export PDK_ROOT=~/ttsetup/pdk
export PDK=sky130A
export LIBRELANE_TAG=2.4.2
```

# 6, Local環境でGDSを生成する

- 必要なプロジェクトをcloneする
  - [TT\_runname]=投稿予定のTinyTapeoutの名前（例：sky25bやgf25a）
  - [username] = 投稿者のgithubのユーザー名
  - [projectname] = 本プロジェクトの名前

```
> git clone https://github.com/[username]/tt[TT_runname]-tt_um_[username]_[projectname]  
~/tt[TT_runname]-tt_um_[username]_[projectname]  
> cd ~/tt[TT_runname]-tt_um_[username]_[projectname]  
> git clone https://github.com/TinyTapeout/tt-support-tools tt
```

# 7, Local環境でGDSを生成する

- Python環境を整備する

```
> mkdir ~/ttsetup  
> python3 -m venv ~/ttsetup/venv  
> source ~/ttsetup/venv/bin/activate  
> pip install -r ~/tt[TT_runname]-tt_um_[username]_[projectname]/tt/requirements.txt  
> pip install librelane==${LIBRELANE_TAG}
```

# 8-1, Local環境でGDSを生成する

- GDSを生成する
  - 二度目以降は環境変数の設定と下記のコマンドをすれば生成可能
    - source ~/ttsetup/venv/bin/activate
    - verilogファイルなどを追加した場合はcreate-user-configから実行すること

```
> cd ~/tt[TT_runname]-tt_um_[username]_[projectname]  
> ./tt/tt_tool.py --create-user-config
```

※Dockerが動いている必要がある

- GDSの生成  
  > ./tt/tt\_tool.py --harden
- ワーニングを出力  
  > ./tt/tt\_tool.py --print-warnings
- GDSをPNGで出力  
  > ./tt/tt\_tool.py --create-png

# 8-2, Local環境でGUIでGDSを表示する

- OpenRoadやKlayoutで実行する

```
> cd ~/tt[TT_runname]-tt_um_[username]_[projectname]
```

○ OpenRoadをGUIで実行

```
> ./tt/tt_tool.py --open-in-openroad
```

○ Klayoutで実行

```
> ./tt/tt_tool.py --open-in-klayout
```



# 9, Local環境でTestを実行する

- テスト環境の構築と実行

```
> cd ~/tt[TT_runname]-tt_um_[username]_[projectname]  
> cd test  
> pip install -r requirements.txt
```

## ○ RTLテストの実行

```
> make -B
```

## ○ ゲートレベルテストの実行

```
> TOP_MODULE=$(cd .. && ./tt_tt_tool.py --print-top-module)  
> cp ..../runs/wokwi/final/pnl/$TOP_MODULE.pnl.v gate_level_netlist.v  
> make -B GATES=yes
```