Skip to main content

ChipFoundry MPW tapeout precheck tool

Project description

cf-precheck

ChipFoundry MPW tapeout precheck tool. Validates user projects before shuttle submission by running a sequence of design-rule and consistency checks.

Installation

pip install cf-precheck

External tool dependencies

Some checks invoke external EDA tools that must be available on $PATH:

  • KLayout — used by all Klayout DRC checks and the XOR check
  • Magic — used by the optional Magic DRC check and LVS
  • Netgen — used by the LVS check

Usage

cf-precheck -i <project_dir> -p <pdk_path> -c <caravel_root> [options] [check ...]

Required arguments

Flag Description
-i, --input-directory Path to the user project directory
-p, --pdk-path Path to the PDK installation (variant-specific, e.g. $PDK_ROOT/sky130A)
-c, --caravel-root Path to the golden Caravel root (or set $GOLDEN_CARAVEL)

Optional arguments

Flag Description
-o, --output-directory Output directory (default: <project>/precheck_results/<timestamp>)
--magic-drc Include the Magic DRC check (off by default)
--skip-checks check [...] Skip specific checks
-v, --verbose Show verbose/debug output
--version Print version and exit

Positional arguments

Pass one or more check names to run only those checks. If omitted, all applicable checks are run.

Example

# Run all checks
cf-precheck -i ./my_project -p $PDK_ROOT/sky130A -c ./caravel

# Run only specific checks
cf-precheck -i ./my_project -p $PDK_ROOT/sky130A -c ./caravel topcell_check gpio_defines

# Include the optional Magic DRC check
cf-precheck -i ./my_project -p $PDK_ROOT/sky130A -c ./caravel --magic-drc

# Skip certain checks
cf-precheck -i ./my_project -p $PDK_ROOT/sky130A -c ./caravel --skip-checks lvs oeb

Checks

Check Description
topcell_check Validates the top cell name in the GDS
gpio_defines Validates GPIO directives in verilog/rtl/user_defines.v
pdn Power distribution network check
metal_check Metal density check
xor XOR comparison against the golden wrapper to detect out-of-bounds edits
magic_drc Full DRC using Magic (optional, off by default)
klayout_feol Klayout Front End Of Line DRC
klayout_beol Klayout Back End Of Line DRC
klayout_offgrid Klayout off-grid violations check
klayout_metal_minimum_clear_area_density Klayout metal density check
klayout_pin_label_purposes_overlapping_drawing Klayout pin/label overlap check
klayout_zero_area Klayout zero-area cell check
spike_check Detects voltage spikes in the design
illegal_cellname_check Detects cells with illegal names
oeb Output-enable-bar signal connectivity check
lvs Layout vs. Schematic check

Results

Check results are saved to <project>/.cf/project.json under the precheck key:

{
  "precheck": {
    "version": "1.0.0",
    "timestamp": "2026-03-17T12:00:00+00:00",
    "pdk": "sky130A",
    "passed": false,
    "checks": {
      "topcell_check": { "status": "pass", "duration_s": 1.2 },
      "gpio_defines": { "status": "fail", "duration_s": 0.8, "details": "..." }
    }
  }
}

Detailed logs are written to <project>/precheck_results/<timestamp>/logs/precheck.log.

License

Apache-2.0

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

cf_precheck-1.0.0.tar.gz (3.5 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cf_precheck-1.0.0-py3-none-any.whl (3.7 MB view details)

Uploaded Python 3

File details

Details for the file cf_precheck-1.0.0.tar.gz.

File metadata

  • Download URL: cf_precheck-1.0.0.tar.gz
  • Upload date:
  • Size: 3.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for cf_precheck-1.0.0.tar.gz
Algorithm Hash digest
SHA256 5c6d1a791cffbcd07b240876083b6eea7ad54371e457db428c355502a01f070f
MD5 efd75c2dfde6ac70069316b9d3baa1a1
BLAKE2b-256 336eb828a2535e41ff67b32f59ed77e981fb4af06b3f3e3fa39ec17e718b8e25

See more details on using hashes here.

File details

Details for the file cf_precheck-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: cf_precheck-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 3.7 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for cf_precheck-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f29131d108a98fec5b2926161c079b489c05915ca22cf974646eb84981060dc4
MD5 28fbc7f5424821f28db23162119e1890
BLAKE2b-256 5041a4879008dff7226546ba199cbfeebb9e04bb698a13d0913803ff7874331d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page