blob: 94931f4d1998114117857a653c4f6f1905039872 [file] [log] [blame]
roman3017d42ed622022-12-10 09:14:06 -08001.. raw:: html
2
3 <!---
4 # SPDX-FileCopyrightText: 2020 Efabless Corporation
5 #
6 # Licensed under the Apache License, Version 2.0 (the "License");
7 # you may not use this file except in compliance with the License.
8 # You may obtain a copy of the License at
9 #
10 # http://www.apache.org/licenses/LICENSE-2.0
11 #
12 # Unless required by applicable law or agreed to in writing, software
13 # distributed under the License is distributed on an "AS IS" BASIS,
14 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 # See the License for the specific language governing permissions and
16 # limitations under the License.
17 #
18 # SPDX-License-Identifier: Apache-2.0
19 -->
20
21Caravel User Project
22====================
23
24|License| |User CI| |Caravel Build|
25
26Table of contents
27=================
28
29- `Overview <#overview>`__
30- `Quickstart <#quickstart>`__
31- `Caravel Integration <#caravel-integration>`__
32
33 - `Repo Integration <#repo-integration>`__
34 - `Verilog Integration <#verilog-integration>`__
35 - `GPIO Configuration <#gpio-configuration>`__
36 - `Layout Integration <#layout-integration>`__
37
38- `Running Full Chip Simulation <#running-full-chip-simulation>`__
39- `User Project Wrapper Requirements <#user-project-wrapper-requirements>`__
40- `Hardening the User Project using
41 Openlane <#hardening-the-user-project-using-openlane>`__
42- `Running Timing Analysis on Existing Projects <#running-timing-analysis-on-existing-projects>`__
43- `Checklist for Open-MPW
44 Submission <#checklist-for-open-mpw-submission>`__
45
46Overview
47========
48
49This repo contains a sample user project that utilizes the
50`caravel <https://github.com/efabless/caravel.git>`__ chip user space.
51The user project is a simple counter that showcases how to make use of
52`caravel's <https://github.com/efabless/caravel.git>`__ user space
53utilities like IO pads, logic analyzer probes, and wishbone port. The
54repo also demonstrates the recommended structure for the open-mpw
55shuttle projects.
56
57Prerequisites
58=============
59
60- Docker: `Linux <https://hub.docker.com/search?q=&type=edition&offering=community&operating_system=linux&utm_source=docker&utm_medium=webreferral&utm_campaign=dd-smartbutton&utm_location=header>`_ || `Windows <https://desktop.docker.com/win/main/amd64/Docker%20Desktop%20Installer.exe?utm_source=docker&utm_medium=webreferral&utm_campaign=dd-smartbutton&utm_location=header>`_ || `Mac with Intel Chip <https://desktop.docker.com/mac/main/amd64/Docker.dmg?utm_source=docker&utm_medium=webreferral&utm_campaign=dd-smartbutton&utm_location=header>`_ || `Mac with M1 Chip <https://desktop.docker.com/mac/main/arm64/Docker.dmg?utm_source=docker&utm_medium=webreferral&utm_campaign=dd-smartbutton&utm_location=header>`_
61
62- Python 3.6+ with PIP
63
64
65Quickstart
66===========
67
68---------------------
69Starting your project
70---------------------
71
72#. To start the project you first need to create a new repository based on the `caravel_user_project <https://github.com/efabless/caravel_user_project/>`_ template and make sure your repo is public and includes a README.
73
74 * Follow https://github.com/efabless/caravel_user_project/generate to create a new repository.
75 * Clone the reposity using the following command:
76
77 .. code:: bash
78
79 git clone <your github repo URL>
80
81#. To setup your local environment run:
82
83 .. code:: bash
84
85 cd <project_name> # project_name is the name of your repo
86
87 mkdir dependencies
88
89 export OPENLANE_ROOT=$(pwd)/dependencies/openlane_src # you need to export this whenever you start a new shell
90
91 export PDK_ROOT=$(pwd)/dependencies/pdks # you need to export this whenever you start a new shell
92
93 # export the PDK variant depending on your shuttle, if you don't know leave it to the default
94
95 # for sky130 MPW shuttles....
96 export PDK=sky130A
97
98 # for the gf180 GFMPW shuttles...
99 export PDK=gf180mcuC
100
101
102
103 make setup
104
105* This command will setup your environment by installing the following
106
107 - caravel_lite (a lite version of caravel)
108 - management core for simulation
109 - openlane to harden your design
110 - pdk
111
112
113#. Now you can start hardening your design
114
115 * To start hardening you project you need
116 - RTL verilog model for your design for OpenLane to harden
117 - A subdirectory for each macro in your project under ``openlane/`` directory, each subdirectory should include openlane configuration files for the macro
118
119 .. code:: bash
120
121 make <module_name>
122 ..
123
124 For an example of hardening a project please refer to `Hardening the User Project using OpenLane`_. .
125
126#. Integrate modules into the user_project_wrapper
127
128 * Change the environment variables ``VERILOG_FILES_BLACKBOX``, ``EXTRA_LEFS`` and ``EXTRA_GDS_FILES`` in ``openlane/user_project_wrapper/config.tcl`` to point to your module
129 * Instantiate your module(s) in ``verilog/rtl/user_project_wrapper.v``
130 * Harden the user_project_wrapper including your module(s), using this command:
131
132 .. code:: bash
133
134 make user_project_wrapper
135
136#. Run simulation on your design
137
138 * You need to include your rtl/gl/gl+sdf files in ``verilog/includes/includes.<rtl/gl/gl+sdf>.caravel_user_project``
139
140 **NOTE:** You shouldn't include the files inside the verilog code
141
142 .. code:: bash
143
144 # you can then run RTL simulations using
145 make verify-<testbench-name>-rtl
146
147 # OR GL simulation using
148 make verify-<testbench-name>-gl
149
150 # OR for GL+SDF simulation using
151 # sdf annotated simulation is slow
152 make verify-<testbench-name>-gl-sdf
153
154 # for example
155 make verify-io_ports-rtl
156
157#. Run opensta on your design
158
159 * Extract spefs for ``user_project_wrapper`` and macros inside it:
160
161 .. code:: bash
162
163 make extract-parasitics
164
165 * Create spef mapping file that maps instance names to spef files:
166
167 .. code:: bash
168
169 make create-spef-mapping
170
171 * Run opensta:
172
173 .. code:: bash
174
175 make caravel-sta
176
177 **NOTE:** To update timing scripts run ``make setup-timing-scripts``
178
179#. Run the precheck locally
180
181 .. code:: bash
182
183 make precheck
184 make run-precheck
185
186#. You are done! now go to https://efabless.com/open_shuttle_program/ to submit your project!
187
188
189Caravel Integration
190===================
191
192----------------
193Repo Integration
194----------------
195
196Caravel files are kept separate from the user project by having caravel
197as submodule. The submodule commit should point to the latest of
198caravel/caravel-lite master/main branch. The following files should have a symbolic
199link to `caravel's <https://github.com/efabless/caravel.git>`__
200corresponding files:
201
202- `Openlane Makefile <../../openlane/Makefile>`__: This provides an easier
203 way for running openlane to harden your macros. Refer to `Hardening
204 the User Project Macro using
205 Openlane <#hardening-the-user-project-using-openlane>`__. Also,
206 the makefile retains the openlane summary reports under the signoff
207 directory.
208
209- `Pin order <../../openlane/user_project_wrapper/pin_order.cfg>`__ file for
210 the user wrapper: The hardened user project wrapper macro must have
211 the same pin order specified in caravel's repo. Failing to adhere to
212 the same order will fail the gds integration of the macro with
213 caravel's back-end.
214
215The symbolic links are automatically set when you run ``make install``.
216
217-------------------
218Verilog Integration
219-------------------
220
221You need to create a wrapper around your macro that adheres to the
222template at
223`user\_project\_wrapper <https://github.com/efabless/caravel/blob/master/verilog/rtl/__user_project_wrapper.v>`__.
224The wrapper top module must be named ``user_project_wrapper`` and must
225have the same input and output ports as the golden wrapper `template <https://github.com/efabless/caravel/blob/master/verilog/rtl/__user_project_wrapper.v>`__. The wrapper gives access to the
226user space utilities provided by caravel like IO ports, logic analyzer
227probes, and wishbone bus connection to the management SoC.
228
229For this sample project, the user macro makes use of:
230
231- The IO ports for displaying the count register values on the IO pads.
232
233- The LA probes for supplying an optional reset and clock signals and
234 for setting an initial value for the count register.
235
236- The wishbone port for reading/writing the count value through the
237 management SoC.
238
239Refer to `user\_project\_wrapper <../../verilog/rtl/user_project_wrapper.v>`__
240for more information.
241
242.. raw:: html
243
244 <p align="center">
245 <img src="./_static/counter_32.png" width="50%" height="50%">
246 </p>
247
248.. raw:: html
249
250 </p>
251
252-------------------
253GPIO Configuration
254-------------------
255
256You are required to specify the power-on default configuration for each GPIO in Caravel. The default configuration provide the state the GPIO will come up on power up. The configuration can be changed by the management SoC during firmware execution.
257
258Configuration settings define whether the GPIO is configured to connect to the user project area or the managment SoC. They also determine whether IOs are inputs or outputs, digital or analog, as well as whether pull-up or pull-down resistors are configured for inputs.
259
260GPIOs are configured by assigning predefined values for each IO in the file `verilog/rtl/user_defines.v <https://github.com/efabless/caravel_user_project/blob/main/verilog/rtl/user_defines.v>`_ in your project.
261
262You need to assigned configuration values for GPIO[5] thru GPIO[37].
263
264GPIO[0] thru GPIO[4] are preset and cannot be changed.
265
266The following values are redefined for assigning to GPIOs.
267
268
269- GPIO_MODE_MGMT_STD_INPUT_NOPULL
270- GPIO_MODE_MGMT_STD_INPUT_PULLDOWN
271- GPIO_MODE_MGMT_STD_INPUT_PULLUP
272- GPIO_MODE_MGMT_STD_OUTPUT
273- GPIO_MODE_MGMT_STD_BIDIRECTIONAL
274- GPIO_MODE_MGMT_STD_ANALOG
275
276- GPIO_MODE_USER_STD_INPUT_NOPULL
277- GPIO_MODE_USER_STD_INPUT_PULLDOWN
278- GPIO_MODE_USER_STD_INPUT_PULLUP
279- GPIO_MODE_USER_STD_OUTPUT
280- GPIO_MODE_USER_STD_BIDIRECTIONAL
281- GPIO_MODE_USER_STD_OUT_MONITORED
282- GPIO_MODE_USER_STD_ANALOG
283
284
285MPW_Prececk includes a check to confirm each GPIO is assigned a valid value.
286
287-------------------
288Layout Integration
289-------------------
290
291The caravel layout is pre-designed with an empty golden wrapper in the user space. You only need to provide us with a valid ``user_project_wrapper`` GDS file. And, as part of the tapeout process, your hardened ``user_project_wrapper`` will be inserted into a vanilla caravel layout to get the final layout shipped for fabrication.
292
293.. raw:: html
294
295 <p align="center">
296 <img src="./_static/layout.png" width="80%" height="80%">
297 </p>
298
299To make sure that this integration process goes smoothly without having any DRC or LVS issues, your hardened ``user_project_wrapper`` must adhere to a number of requirements listed at `User Project Wrapper Requirements <#user-project-wrapper-requirements>`__ .
300
301
302Running Full Chip Simulation
303============================
304
305First, you will need to install the simulation environment, by
306
307.. code:: bash
308
309 make simenv
310
311This will pull a docker image with the needed tools installed.
312
313Then, run the RTL simulation by
314
315.. code:: bash
316
317 export PDK_ROOT=<pdk-installation-path>
318 make verify-<testbench-name>-rtl
319
320 # For example
321 make verify-io_ports-rtl
322
323Once you have the physical implementation done and you have the gate-level netlists ready, it is crucial to run full gate-level simulations to make sure that your design works as intended after running the physical implementation.
324
325Run the gate-level simulation by:
326
327.. code:: bash
328
329 export PDK_ROOT=<pdk-installation-path>
330 make verify-<testbench-name>-gl
331
332 # For example
333 make verify-io_ports-gl
334
335To make sure that your design is timing clean, one way is running sdf annotated gate-level simulation
336Run the sdf annotated gate-level simulation by:
337
338.. code:: bash
339
340 export PDK_ROOT=<pdk-installation-path>
341 make verify-<testbench-name>-gl-sdf
342
343 # For example
344 make verify-io_ports-gl-sdf
345
346This sample project comes with four example testbenches to test the IO port connection, wishbone interface, and logic analyzer. The test-benches are under the
347`verilog/dv <https://github.com/efabless/caravel_user_project/tree/main/verilog/dv>`__ directory. For more information on setting up the
348simulation environment and the available testbenches for this sample
349project, refer to `README <https://github.com/efabless/caravel_user_project/blob/main/verilog/dv/README.md>`__.
350
351
352User Project Wrapper Requirements
353=================================
354
355Your hardened ``user_project_wrapper`` must match the `golden user_project_wrapper <https://github.com/efabless/caravel/blob/master/gds/user_project_wrapper_empty.gds.gz>`__ in the following:
356
357- Area ``(2.920um x 3.520um)``
358- Top module name ``"user_project_wrapper"``
359- Pin Placement
360- Pin Sizes
361- Core Rings Width and Offset
362- PDN Vertical and Horizontal Straps Width
363
364
365.. raw:: html
366
367 <p align="center">
368 <img src="./_static/empty.png" width="40%" height="40%">
369 </p>
370
371You are allowed to change the following if you need to:
372
373- PDN Vertical and Horizontal Pitch & Offset
374
375.. raw:: html
376
377 <p align="center">
378 <img src="./_static/pitch.png" width="30%" height="30%">
379 </p>
380
381To make sure that you adhere to these requirements, we run an exclusive-or (XOR) check between your hardened ``user_project_wrapper`` GDS and the golden wrapper GDS after processing both layouts to include only the boundary (pins and core rings). This check is done as part of the `mpw-precheck <https://github.com/efabless/mpw_precheck>`__ tool.
382
383
384Hardening the User Project using OpenLane
385==========================================
386
387---------------------
388OpenLane Installation
389---------------------
390
391You will need to install openlane by running the following
392
393.. code:: bash
394
395 export OPENLANE_ROOT=<openlane-installation-path>
396
397 # you can optionally specify the openlane tag to use
398 # by running: export OPENLANE_TAG=<openlane-tag>
399 # if you do not set the tag, it defaults to the last verfied tag tested for this project
400
401 make openlane
402
403For detailed instructions on the openlane and the pdk installation refer
404to
405`README <https://github.com/The-OpenROAD-Project/OpenLane#setting-up-openlane>`__.
406
407-----------------
408Hardening Options
409-----------------
410
411There are three options for hardening the user project macro using
412openlane:
413
414+--------------------------------------------------------------+--------------------------------------------+--------------------------------------------+
415| Option 1 | Option 2 | Option 3 |
416+--------------------------------------------------------------+--------------------------------------------+--------------------------------------------+
417| Hardening the user macro(s) first, then inserting it in the | Flattening the user macro(s) with the | Placing multiple macros in the wrapper |
418| user project wrapper with no standard cells on the top level | user_project_wrapper | along with standard cells on the top level |
419+==============================================================+============================================+============================================+
420| |pic1| | |pic2| | |pic3| |
421| | | |
422+--------------------------------------------------------------+--------------------------------------------+--------------------------------------------+
423| ex: |link1| | | ex: |link2| |
424+--------------------------------------------------------------+--------------------------------------------+--------------------------------------------+
425
426.. |link1| replace:: `caravel_user_project <https://github.com/efabless/caravel_user_project>`__
427
428.. |link2| replace:: `caravel_ibex <https://github.com/efabless/caravel_ibex>`__
429
430
431.. |pic1| image:: ./_static/option1.png
432 :width: 48%
433
434.. |pic2| image:: ./_static/option2.png
435 :width: 140%
436
437.. |pic3| image:: ./_static/option3.png
438 :width: 72%
439
440For more details on hardening macros using openlane, refer to `README <https://github.com/The-OpenROAD-Project/OpenLane/blob/master/docs/source/hardening_macros.md>`__.
441
442-----------------
443Running OpenLane
444-----------------
445
446For this sample project, we went for the first option where the user
447macro is hardened first, then it is inserted in the user project
448wrapper without having any standard cells on the top level.
449
450.. raw:: html
451
452 <p align="center">
453 <img src="./_static/wrapper.png" width="30%" height="30%">
454 </p>
455
456.. raw:: html
457
458 </p>
459
460To reproduce hardening this project, run the following:
461
462.. code:: bash
463
464 # DO NOT cd into openlane
465
466 # Run openlane to harden user_proj_example
467 make user_proj_example
468 # Run openlane to harden user_project_wrapper
469 make user_project_wrapper
470
471
472For more information on the openlane flow, check `README <https://github.com/The-OpenROAD-Project/OpenLane#readme>`__.
473
474Running MPW Precheck Locally
475=================================
476
477You can install the `mpw-precheck <https://github.com/efabless/mpw_precheck>`__ by running
478
479.. code:: bash
480
481 # By default, this install the precheck in your home directory
482 # To change the installtion path, run "export PRECHECK_ROOT=<precheck installation path>"
483 make precheck
484
485This will clone the precheck repo and pull the latest precheck docker image.
486
487
488Then, you can run the precheck by running
489
490.. code:: bash
491
492 make run-precheck
493
494This will run all the precheck checks on your project and will produce the logs under the ``checks`` directory.
495
496Running Timing Analysis on Existing Projects
497========================================================
498
499Start by updating the Makefile for your project. Starting in the project root...
500
501.. code:: bash
502
503 curl -k https://raw.githubusercontent.com/efabless/caravel_user_project/main/Makefile > Makefile
504
505 make setup-timing-scripts
506
507 make install
508
509 make install_mcw
510
511
512This will update Caravel design files and install the scripts for running timing.
513
514
515Then, you can run then run timing by the following...
516
517.. code:: bash
518
519 make extract-parasitics
520
521 make create-spef-mapping
522
523 make caravel-sta
524
525
526A summary of timing results is provided at the end of the flow.
527
528
529Other Miscellaneous Targets
530============================
531
532The makefile provides a number of useful that targets that can run LVS, DRC, and XOR checks on your hardened design outside of openlane's flow.
533
534Run ``make help`` to display available targets.
535
536Run lvs on the mag view,
537
538.. code:: bash
539
540 make lvs-<macro_name>
541
542Run lvs on the gds,
543
544.. code:: bash
545
546 make lvs-gds-<macro_name>
547
548Run lvs on the maglef,
549
550.. code:: bash
551
552 make lvs-maglef-<macro_name>
553
554Run drc using magic,
555
556.. code:: bash
557
558 make drc-<macro_name>
559
560Run antenna check using magic,
561
562.. code:: bash
563
564 make antenna-<macro_name>
565
566Run XOR check,
567
568.. code:: bash
569
570 make xor-wrapper
571
572
573
574
575Checklist for Open-MPW Submission
576=================================
577
578- ✔️ The project repo adheres to the same directory structure in this
579 repo.
580- ✔️ The project repo contain info.yaml at the project root.
581- ✔️ Top level macro is named ``user_project_wrapper``.
582- ✔️ Full Chip Simulation passes for RTL and GL (gate-level)
583- ✔️ The hardened Macros are LVS and DRC clean
584- ✔️ The project contains a gate-level netlist for ``user_project_wrapper`` at verilog/gl/user_project_wrapper.v
585- ✔️ The hardened ``user_project_wrapper`` adheres to the same pin
586 order specified at
587 `pin\_order <https://github.com/efabless/caravel/blob/master/openlane/user_project_wrapper_empty/pin_order.cfg>`__
588- ✔️ The hardened ``user_project_wrapper`` adheres to the fixed wrapper configuration specified at `fixed_wrapper_cfgs <https://github.com/efabless/caravel/blob/master/openlane/user_project_wrapper_empty/fixed_wrapper_cfgs.tcl>`__
589- ✔️ XOR check passes with zero total difference.
590- ✔️ Openlane summary reports are retained under ./signoff/
591- ✔️ The design passes the `mpw-precheck <https://github.com/efabless/mpw_precheck>`__
592
593.. |License| image:: https://img.shields.io/badge/License-Apache%202.0-blue.svg
594 :target: https://opensource.org/licenses/Apache-2.0
595.. |User CI| image:: https://github.com/efabless/caravel_project_example/actions/workflows/user_project_ci.yml/badge.svg
596 :target: https://github.com/efabless/caravel_project_example/actions/workflows/user_project_ci.yml
597.. |Caravel Build| image:: https://github.com/efabless/caravel_project_example/actions/workflows/caravel_build.yml/badge.svg
598 :target: https://github.com/efabless/caravel_project_example/actions/workflows/caravel_build.yml