Delete deps/timing-scripts directory
diff --git a/deps/timing-scripts/Dockerfile b/deps/timing-scripts/Dockerfile
deleted file mode 100644
index 4696aff..0000000
--- a/deps/timing-scripts/Dockerfile
+++ /dev/null
@@ -1,6 +0,0 @@
-from fedora:36
-
-RUN yum install -y yosys python3-pip && \
-    pip3 install click pyverilog && \
-    yum clean all && \
-    rm -rf /var/cache/yum
diff --git a/deps/timing-scripts/README.md b/deps/timing-scripts/README.md
deleted file mode 100644
index ffa6900..0000000
--- a/deps/timing-scripts/README.md
+++ /dev/null
@@ -1,91 +0,0 @@
-# Timing scripts
-
-A set of scripts for rcx and sta for caravel top level 
-
-## Dependencies
-- Docker
-
-In case of not using the docker image:
-- `yosys`
-- Python modules:
-    - `click`
-
-
-## Prerequisites
-
-A set of exports are needed:
-```bash
-export CARAVEL_ROOT=${HOME}/caravel/
-export MCW_ROOT=${HOME}/caravel_mgmt_soc_litex/
-export CUP_ROOT=${HOME}/caravel_user_project/
-export TIMING_ROOT=${HOME}/timing-scripts/
-export PDK_ROOT=${HOME}/pdk/
-export PDK=sky130A
-export OPENLANE_IMAGE_NAME=efabless/openlane:4476a58407d670d251aa0be6a55e5391bb181c4e-amd64
-```
-
-> This is just an example. Please export your own paths and a recent version of openlane
-
-## Usage
-
-### caravel_user_project
-
-1. After exporting the prerequisites, run:
-
-    ```
-    make -f timing.mk list-rcx
-    ```
-    You should get `rcx-user_project_wrapper` amongst others such as: 
-
-    ```
-    rcx-buff_flash_clkrst
-    rcx-caravel
-    rcx-caravel_clocking
-    rcx-constant_block
-    rcx-digital_pll
-    rcx-gpio_control_block
-    rcx-gpio_defaults_block
-    rcx-gpio_logic_high
-    rcx-gpio_signal_buffering
-    rcx-gpio_signal_buffering_alt
-    rcx-housekeeping
-    rcx-mgmt_protect
-    rcx-mprj2_logic_high
-    rcx-mprj_logic_high
-    rcx-spare_logic_block
-    rcx-RAM256
-    rcx-mgmt_core_wrapper
-    rcx-user_proj_example
-    rcx-user_project_wrapper
-    ```
-
-2. extract multicorner spefs for `user_project_wrapper` and any other blocks inside:
-
-    ```
-    make -f timing.mk rcx-user_project_wrapper
-    make -f timing.mk rcx-user_proj_example
-    ```
-3. generate spef mapping file for caravel_user_project:
-
-    ```
-    python3 ./scripts/generate_spef_mapping \
-        -i ${CUP_ROOT}/verilog/gl/user_project_wrapper.v \
-        -o ${CUP_ROOT}/env/spef-mapping.tcl \
-        --project-root '$::env(CUP_ROOT)' \
-        --pdk-path "${PDK_ROOT}/${PDK}"
-    ```
-
-4. run sta:
-
-    ```
-    make -f timing.mk caravel-timing-typ
-    make -f timing.mk caravel-timing-slow
-    make -f timing.mk caravel-timing-fast
-    ```
-
-## Limitations
-
-- Makefile
-- Makefile
-- Assumes a fixed folder structure for the exported directories
-- Probably a lot of corner cases that weren't considered
diff --git a/deps/timing-scripts/env/caravel_spef_mapping-mpw2-calibre.tcl b/deps/timing-scripts/env/caravel_spef_mapping-mpw2-calibre.tcl
deleted file mode 100644
index 87eeb62..0000000
--- a/deps/timing-scripts/env/caravel_spef_mapping-mpw2-calibre.tcl
+++ /dev/null
@@ -1,101 +0,0 @@
-set spef_mapping(rstb_level)                         $::env(CARAVEL_ROOT)/spef/xres_buf.spef
-set spef_mapping(mgmt_buffers/powergood_check)       $::env(CARAVEL_ROOT)/spef/mgmt_protect_hv.spef
-set spef_mapping(padframe)                           $::env(CARAVEL_ROOT)/spef/chip_io.spef
-set spef_mapping(mgmt_buffers/mprj2_logic_high_inst) $::env(CARAVEL_ROOT)/spef/mprj2_logic_high.spef
-set spef_mapping(mgmt_buffers/mprj_logic_high_inst)  $::env(CARAVEL_ROOT)/spef/mprj_logic_high.spef
-
-#set spef_mapping(por)                                $::env(CARAVEL_ROOT)/spef/simple_por.spef
-
-# error in rcx extraction for the section/paragraph below
-# [ERROR ODB-0299] Via via3_320_320 has only 2 shapes and must have at least three.
-
-set spef_mapping(gpio_defaults_block_0)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_1803.spef
-set spef_mapping(gpio_defaults_block_1)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_1803.spef
-set spef_mapping(gpio_defaults_block_2)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_0403.spef
-set spef_mapping(gpio_defaults_block_3)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_0403.spef
-set spef_mapping(gpio_defaults_block_4)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_0403.spef
-
-set spef_mapping(gpio_defaults_block_10)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_11)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_12)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_13)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_14)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_15)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_16)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_17)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_18)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_19)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_20)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_21)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_22)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_23)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_24)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_25)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_26)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_27)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_28)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_29)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_30)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_31)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_32)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_33)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_34)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_35)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_36)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_37)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_5)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_6)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_7)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_8)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_9)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_control_bidir_1[0]) $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_bidir_1[1]) $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_bidir_2[0]) $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_bidir_2[1]) $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_bidir_2[2]) $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[0])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[10])   $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[1])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[2])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[3])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[4])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[5])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[6])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[7])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[8])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[9])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1a[0])   $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1a[1])   $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1a[2])   $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1a[3])   $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1a[4])   $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1a[5])   $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[0])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[10])   $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[11])   $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[12])   $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[13])   $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[14])   $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[15])   $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[1])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[2])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[3])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[4])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[5])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[6])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[7])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[8])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[9])    $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(housekeeping)            $::env(CARAVEL_ROOT)/spef/housekeeping.spef
-set spef_mapping(mgmt_buffers)            $::env(CARAVEL_ROOT)/spef/mgmt_protect.spef
-set spef_mapping(pll)                     $::env(CARAVEL_ROOT)/spef/digital_pll.spef
-set spef_mapping(spare_logic[0])          $::env(CARAVEL_ROOT)/spef/spare_logic_block.spef
-set spef_mapping(spare_logic[1])          $::env(CARAVEL_ROOT)/spef/spare_logic_block.spef
-set spef_mapping(spare_logic[2])          $::env(CARAVEL_ROOT)/spef/spare_logic_block.spef
-set spef_mapping(spare_logic[3])          $::env(CARAVEL_ROOT)/spef/spare_logic_block.spef
-
-set spef_mapping(clocking) $::env(CARAVEL_ROOT)/spef/caravel_clocking.spef
-
-set spef_mapping(soc)                     $::env(MCW_ROOT)/spef/mgmt_core_wrapper.spef
-set spef_mapping(soc/DFFRAM_0)            $::env(MCW_ROOT)/spef/DFFRAM.spef
-set spef_mapping(soc/core)                $::env(MCW_ROOT)/spef/mgmt_core.spef
diff --git a/deps/timing-scripts/env/caravel_spef_mapping-mpw2.tcl b/deps/timing-scripts/env/caravel_spef_mapping-mpw2.tcl
deleted file mode 100644
index fade71c..0000000
--- a/deps/timing-scripts/env/caravel_spef_mapping-mpw2.tcl
+++ /dev/null
@@ -1,99 +0,0 @@
-set spef_mapping(rstb_level)                         $::env(CARAVEL_ROOT)/spef/xres_buf.spef
-set spef_mapping(mgmt_buffers/powergood_check)       $::env(CARAVEL_ROOT)/spef/mgmt_protect_hv.spef
-set spef_mapping(padframe)                           $::env(CARAVEL_ROOT)/spef/chip_io.spef
-set spef_mapping(mgmt_buffers/mprj2_logic_high_inst) $::env(CARAVEL_ROOT)/spef/mprj2_logic_high.spef
-set spef_mapping(mgmt_buffers/mprj_logic_high_inst)  $::env(CARAVEL_ROOT)/spef/mprj_logic_high.spef
-
-#set spef_mapping(por)                                $::env(CARAVEL_ROOT)/spef/simple_por.spef
-
-# error in rcx extraction for the section/paragraph below
-# [ERROR ODB-0299] Via via3_320_320 has only 2 shapes and must have at least three.
-
-set spef_mapping(gpio_defaults_block_0)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_1803.spef
-set spef_mapping(gpio_defaults_block_1)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_1803.spef
-set spef_mapping(gpio_defaults_block_2)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_0403.spef
-set spef_mapping(gpio_defaults_block_3)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_0403.spef
-set spef_mapping(gpio_defaults_block_4)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_0403.spef
-
-set spef_mapping(gpio_defaults_block_10)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_11)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_12)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_13)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_14)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_15)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_16)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_17)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_18)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_19)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_20)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_21)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_22)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_23)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_24)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_25)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_26)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_27)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_28)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_29)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_30)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_31)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_32)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_33)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_34)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_35)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_36)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_37)  $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_5)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_6)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_7)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_8)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_9)   $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_bidir_1[0]) $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_bidir_1[1]) $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_bidir_2[0]) $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_bidir_2[1]) $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_bidir_2[2]) $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[0])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[10])   $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[1])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[2])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[3])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[4])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[5])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[6])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[7])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[8])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[9])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1a[0])   $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1a[1])   $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1a[2])   $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1a[3])   $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1a[4])   $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1a[5])   $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[0])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[10])   $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[11])   $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[12])   $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[13])   $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[14])   $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[15])   $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[1])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[2])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[3])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[4])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[5])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[6])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[7])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[8])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[9])    $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(housekeeping)            $::env(CARAVEL_ROOT)/spef/housekeeping_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(mgmt_buffers)            $::env(CARAVEL_ROOT)/spef/mgmt_protect_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(pll)                     $::env(CARAVEL_ROOT)/spef/digital_pll_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(spare_logic[0])          $::env(CARAVEL_ROOT)/spef/spare_logic_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(spare_logic[1])          $::env(CARAVEL_ROOT)/spef/spare_logic_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(spare_logic[2])          $::env(CARAVEL_ROOT)/spef/spare_logic_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(spare_logic[3])          $::env(CARAVEL_ROOT)/spef/spare_logic_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-
-set spef_mapping(soc)                     $::env(MCW_ROOT)/spef/mgmt_core_wrapper_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(soc/DFFRAM_0)            $::env(MCW_ROOT)/spef/DFFRAM_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(soc/core)                $::env(MCW_ROOT)/spef/mgmt_core_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
diff --git a/deps/timing-scripts/env/caravel_spef_mapping-mpw5-calibre.tcl b/deps/timing-scripts/env/caravel_spef_mapping-mpw5-calibre.tcl
deleted file mode 100644
index c6c8a54..0000000
--- a/deps/timing-scripts/env/caravel_spef_mapping-mpw5-calibre.tcl
+++ /dev/null
@@ -1,90 +0,0 @@
-set spef_mapping(rstb_level)                         $::env(CARAVEL_ROOT)/spef/xres_buf.spef
-set spef_mapping(mgmt_buffers/powergood_check)       $::env(CARAVEL_ROOT)/spef/mgmt_protect_hv.spef
-set spef_mapping(padframe)                           $::env(CARAVEL_ROOT)/spef/chip_io.spef
-
-# should double check this
-set spef_mapping(gpio_defaults_block_0[0])           $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_1803.spef
-set spef_mapping(gpio_defaults_block_0[1])           $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_1803.spef
-set spef_mapping(gpio_defaults_block_2[0])           $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_0403.spef
-set spef_mapping(gpio_defaults_block_2[1])           $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_0403.spef
-set spef_mapping(gpio_defaults_block_2[2])           $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_0403.spef
-
-set spef_mapping(soc/DFFRAM_0)                       $::env(MCW_ROOT)/spef/DFFRAM.spef
-set spef_mapping(soc/core)                           $::env(MCW_ROOT)/spef/mgmt_core.spef
-set spef_mapping(soc)                                $::env(MCW_ROOT)/spef/mgmt_core_wrapper.spef
-set spef_mapping(pll)                                $::env(CARAVEL_ROOT)/spef/digital_pll.spef
-set spef_mapping(housekeeping)                       $::env(CARAVEL_ROOT)/spef/housekeeping.spef
-set spef_mapping(mgmt_buffers/mprj_logic_high_inst)  $::env(CARAVEL_ROOT)/spef/mprj_logic_high.spef
-set spef_mapping(mgmt_buffers/mprj2_logic_high_inst) $::env(CARAVEL_ROOT)/spef/mprj2_logic_high.spef
-set spef_mapping(mgmt_buffers)                       $::env(CARAVEL_ROOT)/spef/mgmt_protect.spef
-set spef_mapping(gpio_control_bidir_1[0])            $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_bidir_1[1])            $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_bidir_2[1])            $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_bidir_2[2])            $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[0])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[10])              $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[1])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[2])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[3])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[4])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[5])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[6])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[7])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[8])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1[9])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1a[0])              $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1a[1])              $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1a[2])              $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1a[3])              $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1a[4])              $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_1a[5])              $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[0])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[10])              $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[11])              $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[12])              $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[13])              $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[14])              $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[15])              $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[1])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[2])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[3])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[4])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[5])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[6])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[7])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[8])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_control_in_2[9])               $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-set spef_mapping(gpio_defaults_block_5)              $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_6)              $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_7)              $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_8)              $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_9)              $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_10)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_11)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_12)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_13)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_14)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_15)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_16)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_17)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_18)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_19)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_20)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_21)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_22)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_23)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_24)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_25)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_26)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_27)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_28)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_29)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_30)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_31)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_32)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_33)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_34)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_35)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_36)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-set spef_mapping(gpio_defaults_block_37)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block.spef
-
diff --git a/deps/timing-scripts/env/caravel_spef_mapping-mpw7.tcl b/deps/timing-scripts/env/caravel_spef_mapping-mpw7.tcl
deleted file mode 100644
index e12e189..0000000
--- a/deps/timing-scripts/env/caravel_spef_mapping-mpw7.tcl
+++ /dev/null
@@ -1,136 +0,0 @@
-set SPEF_MAPPING_POSTFIX ".$::env(RCX_CORNER).spef"
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/gpio_control_block/openlane-signoff/spef/"
-set spef_mapping(\gpio_control_bidir_1[0]) ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_bidir_1[1]) ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_bidir_2[0]) ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_bidir_2[1]) ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_bidir_2[2]) ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1[0])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1[10])   ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1[1])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1[2])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1[3])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1[4])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1[5])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1[6])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1[7])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1[8])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1[9])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1a[0])   ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1a[1])   ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1a[2])   ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1a[3])   ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1a[4])   ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_1a[5])   ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[0])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[10])   ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[11])   ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[12])   ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[13])   ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[14])   ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[15])   ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[1])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[2])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[3])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[4])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[5])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[6])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[7])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[8])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\gpio_control_in_2[9])    ${SPEF_MAPPING_PREFIX}gpio_control_block${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/spare_logic_block/openlane-signoff/spef/"
-set spef_mapping(\spare_logic[0])          ${SPEF_MAPPING_PREFIX}spare_logic_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\spare_logic[1])          ${SPEF_MAPPING_PREFIX}spare_logic_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\spare_logic[2])          ${SPEF_MAPPING_PREFIX}spare_logic_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(\spare_logic[3])          ${SPEF_MAPPING_PREFIX}spare_logic_block${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/caravel_clocking/openlane-signoff/spef/"
-set spef_mapping(clock_ctrl)               ${SPEF_MAPPING_PREFIX}caravel_clocking${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/buff_flash_clkrst/openlane-signoff/spef/"
-set spef_mapping(flash_clkrst_buffers)     ${SPEF_MAPPING_PREFIX}buff_flash_clkrst${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/gpio_defaults_block/openlane-signoff/spef/"
-set spef_mapping(gpio_defaults_block_0)    ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_1)    ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_2)    ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_3)    ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_4)    ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_5)    ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_6)    ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_7)    ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_8)    ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_9)    ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_10)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_11)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_12)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_13)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_14)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_15)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_16)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_17)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_18)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_19)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_20)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_21)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_22)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_23)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_24)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_25)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_26)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_27)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_28)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_29)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_30)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_31)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_32)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_33)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_34)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_35)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_36)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(gpio_defaults_block_37)   ${SPEF_MAPPING_PREFIX}gpio_defaults_block${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/housekeeping/openlane-signoff/spef/"
-set spef_mapping(housekeeping)             ${SPEF_MAPPING_PREFIX}housekeeping${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/mgmt_protect/openlane-signoff/spef/"
-set spef_mapping(mgmt_buffers)             ${SPEF_MAPPING_PREFIX}mgmt_protect${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CUP_ROOT)/signoff/user_project_wrapper/openlane-signoff/spef/"
-set spef_mapping(mprj)                     ${SPEF_MAPPING_PREFIX}user_project_wrapper${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/chip_io/openlane-signoff/spef/"
-set spef_mapping(padframe)                 ${SPEF_MAPPING_PREFIX}chip_io${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/digital_pll/openlane-signoff/spef/"
-set spef_mapping(pll)                      ${SPEF_MAPPING_PREFIX}digital_pll${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/simple_por/openlane-signoff/spef/"
-set spef_mapping(por)                      ${SPEF_MAPPING_PREFIX}simple_por${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/xres_buf/openlane-signoff/spef/"
-set spef_mapping(rstb_level)               ${SPEF_MAPPING_PREFIX}xres_buf${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/gpio_signal_buffering/openlane-signoff/spef/"
-set spef_mapping(sigbuf)                   ${SPEF_MAPPING_PREFIX}gpio_signal_buffering${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/user_id_programming/openlane-signoff/spef/"
-set spef_mapping(user_id_value)            ${SPEF_MAPPING_PREFIX}user_id_programming${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(MCW_ROOT)/signoff/mgmt_core_wrapper/openlane-signoff/spef/"
-set spef_mapping(soc)                      ${SPEF_MAPPING_PREFIX}mgmt_core_wrapper${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(CARAVEL_ROOT)/signoff/constant_block/openlane-signoff/spef/"
-set spef_mapping(padframe/\constant_value_inst[0])         ${SPEF_MAPPING_PREFIX}constant_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(padframe/\constant_value_inst[1])         ${SPEF_MAPPING_PREFIX}constant_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(padframe/\constant_value_inst[2])         ${SPEF_MAPPING_PREFIX}constant_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(padframe/\constant_value_inst[3])         ${SPEF_MAPPING_PREFIX}constant_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(padframe/\constant_value_inst[4])         ${SPEF_MAPPING_PREFIX}constant_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(padframe/\constant_value_inst[5])         ${SPEF_MAPPING_PREFIX}constant_block${SPEF_MAPPING_POSTFIX}
-set spef_mapping(padframe/\constant_value_inst[6])         ${SPEF_MAPPING_PREFIX}constant_block${SPEF_MAPPING_POSTFIX}
-
-set SPEF_MAPPING_PREFIX "$::env(MCW_ROOT)/signoff/RAM256/openlane-signoff/spef/"
-set spef_mapping(soc/\core.RAM256)                         ${SPEF_MAPPING_PREFIX}RAM256${SPEF_MAPPING_POSTFIX}
-set SPEF_MAPPING_PREFIX "$::env(MCW_ROOT)/signoff/RAM128/openlane-signoff/spef/"
-set spef_mapping(soc/\core.RAM128)                         ${SPEF_MAPPING_PREFIX}RAM128${SPEF_MAPPING_POSTFIX}
diff --git a/deps/timing-scripts/env/caravel_spef_mapping.tcl b/deps/timing-scripts/env/caravel_spef_mapping.tcl
deleted file mode 100644
index f287952..0000000
--- a/deps/timing-scripts/env/caravel_spef_mapping.tcl
+++ /dev/null
@@ -1,90 +0,0 @@
-set spef_mapping(rstb_level)                         $::env(CARAVEL_ROOT)/spef/xres_buf.spef
-set spef_mapping(mgmt_buffers/powergood_check)       $::env(CARAVEL_ROOT)/spef/mgmt_protect_hv.spef
-set spef_mapping(padframe)                           $::env(CARAVEL_ROOT)/spef/chip_io.spef
-
-# should double check this
-set spef_mapping(gpio_defaults_block_0[0])           $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_1803.spef
-set spef_mapping(gpio_defaults_block_0[1])           $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_1803.spef
-set spef_mapping(gpio_defaults_block_2[0])           $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_0403.spef
-set spef_mapping(gpio_defaults_block_2[1])           $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_0403.spef
-set spef_mapping(gpio_defaults_block_2[2])           $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_0403.spef
-
-set spef_mapping(soc/DFFRAM_0)                       $::env(MCW_ROOT)/spef/DFFRAM_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(soc/core)                           $::env(MCW_ROOT)/spef/mgmt_core_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(soc)                                $::env(MCW_ROOT)/spef/mgmt_core_wrapper_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(pll)                                $::env(CARAVEL_ROOT)/spef/digital_pll_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(housekeeping)                       $::env(CARAVEL_ROOT)/spef/housekeeping_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(mgmt_buffers/mprj_logic_high_inst)  $::env(CARAVEL_ROOT)/spef/mprj_logic_high_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(mgmt_buffers/mprj2_logic_high_inst) $::env(CARAVEL_ROOT)/spef/mprj2_logic_high_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(mgmt_buffers)                       $::env(CARAVEL_ROOT)/spef/mgmt_protect_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_bidir_1[0])            $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_bidir_1[1])            $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_bidir_2[1])            $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_bidir_2[2])            $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[0])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[10])              $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[1])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[2])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[3])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[4])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[5])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[6])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[7])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[8])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1[9])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1a[0])              $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1a[1])              $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1a[2])              $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1a[3])              $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1a[4])              $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_1a[5])              $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[0])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[10])              $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[11])              $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[12])              $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[13])              $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[14])              $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[15])              $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[1])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[2])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[3])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[4])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[5])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[6])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[7])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[8])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_control_in_2[9])               $::env(CARAVEL_ROOT)/spef/gpio_control_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_5)              $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_6)              $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_7)              $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_8)              $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_9)              $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_10)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_11)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_12)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_13)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_14)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_15)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_16)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_17)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_18)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_19)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_20)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_21)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_22)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_23)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_24)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_25)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_26)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_27)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_28)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_29)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_30)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_31)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_32)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_33)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_34)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_35)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_36)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-set spef_mapping(gpio_defaults_block_37)             $::env(CARAVEL_ROOT)/spef/gpio_defaults_block_$::env(RCX_CORNER)_$::env(LIB_CORNER).spef
-
diff --git a/deps/timing-scripts/env/common.tcl b/deps/timing-scripts/env/common.tcl
deleted file mode 100644
index b06a6f7..0000000
--- a/deps/timing-scripts/env/common.tcl
+++ /dev/null
@@ -1,134 +0,0 @@
-set std_cell_library        "sky130_fd_sc_hd"
-set special_voltage_library "sky130_fd_sc_hvl"
-set io_library              "sky130_fd_io"
-set primitives_library      "sky130_fd_pr"
-set ef_io_library           "sky130_ef_io"
-set ef_cell_library           "sky130_ef_sc_hd"
-
-set signal_layer            "met2"
-set clock_layer             "met5"
-
-set extra_lefs "
-[glob $::env(CARAVEL_ROOT)/lef/*.lef]
-[glob $::env(MCW_ROOT)/lef/*.lef]
-[glob $::env(CUP_ROOT)/lef/*.lef]"
-
-set tech_lef $::env(PDK_REF_PATH)/$std_cell_library/techlef/${std_cell_library}__$::env(RCX_CORNER).tlef
-set cells_lef $::env(PDK_REF_PATH)/$std_cell_library/lef/$std_cell_library.lef
-set io_lef $::env(PDK_REF_PATH)/$io_library/lef/$io_library.lef
-set ef_io_lef $::env(PDK_REF_PATH)/$io_library/lef/$ef_io_library.lef
-set ef_cells_lef $::env(PDK_REF_PATH)/$std_cell_library/lef/$ef_cell_library.lef
-
-set lefs [list \
-    $tech_lef \
-    $cells_lef \
-    $io_lef \
-    $ef_cells_lef \
-    $ef_io_lef
-]
-# search order:
-# cup -> mcw -> caravel
-
-# file mkdir $::env(CUP_ROOT)/spef/
-# file mkdir $::env(CARAVEL_ROOT)/spef/
-# file mkdir $::env(MCW_ROOT)/spef/
-
-set def $::env(CUP_ROOT)/def/$::env(BLOCK).def
-set spef $::env(CUP_ROOT)/signoff/$::env(BLOCK)/openlane-signoff/spef/$::env(BLOCK).$::env(RCX_CORNER).spef
-set sdc $::env(CUP_ROOT)/sdc/$::env(BLOCK).sdc
-set sdf $::env(CUP_ROOT)/signoff/$::env(BLOCK)/openlane-signoff/sdf/$::env(RCX_CORNER)/$::env(BLOCK).$::env(LIB_CORNER)$::env(LIB_CORNER).$::env(RCX_CORNER).sdf
-if { ![file exists $def] } {
-    set def $::env(MCW_ROOT)/def/$::env(BLOCK).def
-    set spef $::env(MCW_ROOT)/signoff/$::env(BLOCK)/openlane-signoff/spef/$::env(BLOCK).$::env(RCX_CORNER).spef
-    set sdc $::env(MCW_ROOT)/sdc/$::env(BLOCK).sdc
-    set sdf $::env(MCW_ROOT)/signoff/$::env(BLOCK)/openlane-signoff/sdf/$::env(RCX_CORNER)/$::env(BLOCK).$::env(LIB_CORNER)$::env(LIB_CORNER).$::env(RCX_CORNER).sdf
-}
-if { ![file exists $def] } {
-    set def $::env(CARAVEL_ROOT)/def/$::env(BLOCK).def
-    set spef $::env(CARAVEL_ROOT)/signoff/$::env(BLOCK)/openlane-signoff/spef/$::env(BLOCK).$::env(RCX_CORNER).spef
-    set sdc $::env(CARAVEL_ROOT)/sdc/$::env(BLOCK).sdc
-    set sdf $::env(CARAVEL_ROOT)/signoff/$::env(BLOCK)/openlane-signoff/sdf/$::env(RCX_CORNER)/$::env(BLOCK).$::env(LIB_CORNER)$::env(LIB_CORNER).$::env(RCX_CORNER).sdf
-}
-
-file mkdir [file dirname $spef]
-file mkdir [file dirname $sdf]
-set block $::env(BLOCK)
-if { $::env(PDK) == "sky130A" } {
-    set rcx_rules_file $::env(PDK_TECH_PATH)/openlane/rules.openrcx.$::env(PDK).$::env(RCX_CORNER).calibre
-} elseif { $::env(PDK) == "sky130B" } {
-    set rcx_rules_file $::env(PDK_TECH_PATH)/openlane/rules.openrcx.$::env(PDK).$::env(RCX_CORNER).spef_extractor
-} else {
-    puts "no extraction rules file set for $::env(PDK) exiting.."
-    exit 1
-}
-set merged_lef $::env(CARAVEL_ROOT)/tmp/merged_lef-$::env(RCX_CORNER).lef
-
-set sram_lef $::env(PDK_REF_PATH)/sky130_sram_macros/lef/sky130_sram_2kbyte_1rw1r_32x512_8.lef
-
-# order matter
-set caravel_root "[file normalize $::env(CARAVEL_ROOT)]"
-set mcw_root "[file normalize $::env(MCW_ROOT)]"
-set cup_root "[file normalize $::env(CUP_ROOT)]"
-set verilogs "
-[glob $mcw_root/verilog/gl/*]
-[glob $caravel_root/verilog/gl/*]
-[glob $cup_root/verilog/gl/*]
-"
-
-set verilog_exceptions [list \
-    "$caravel_root/verilog/gl/__user_analog_project_wrapper.v" \
-    "$caravel_root/verilog/gl/caravel-signoff.v" \
-    "$caravel_root/verilog/gl/caravan-signoff.v" \
-    "$caravel_root/verilog/gl/__user_project_wrapper.v" \
-    ]
-
-foreach verilog_exception $verilog_exceptions {
-    puts "verilog exception: $verilog_exception"
-    set verilogs [regsub "$verilog_exception" "$verilogs" " "]
-}
-
-proc puts_list {arg} {
-    foreach element $arg {
-        puts $element
-    }
-}
-
-proc read_libs {arg} {
-    set libs [split [regexp -all -inline {\S+} $arg]]
-    foreach liberty $libs {
-        puts $liberty
-        read_liberty $liberty
-    }
-}
-
-proc read_verilogs {arg} {
-    set verilogs [split [regexp -all -inline {\S+} $arg]]
-    foreach verilog $verilogs {
-        puts $verilog
-        read_verilog $verilog
-    }
-}
-
-proc read_spefs {} {
-    global spef_mapping
-    foreach key [array names spef_mapping] {
-        puts "read_spef -path $key $spef_mapping($key)"
-        read_spef -path $key $spef_mapping($key)
-    }
-}
-
-proc run_puts {arg} {
-    puts "exec> $arg"
-    eval "{*}$arg"
-}
-
-proc run_puts_logs {arg log} {
-    set output [open "$log" w+]    
-    puts $output "exec> $arg"
-    puts $output "design: $::env(BLOCK)"
-    set timestr [exec date]
-    puts $output "time: $timestr\n"
-    close $output
-    puts "exec> $arg >> $log"
-    eval "{*}$arg >> $log"
-}
diff --git a/deps/timing-scripts/env/f.tcl b/deps/timing-scripts/env/f.tcl
deleted file mode 100644
index 867427b..0000000
--- a/deps/timing-scripts/env/f.tcl
+++ /dev/null
@@ -1,20 +0,0 @@
-set libs "
-    $::env(PDK_REF_PATH)/${std_cell_library}/lib/${std_cell_library}__ff_n40C_1v95.lib
-    $::env(PDK_REF_PATH)/${special_voltage_library}/lib/${special_voltage_library}__ff_n40C_5v50.lib
-    $::env(PDK_REF_PATH)/${special_voltage_library}/lib/${special_voltage_library}__ff_n40C_4v40_lv1v95.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_gpiov2_ff_ff_n40C_1v95_5v50.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_ground_hvc_wpad_ff_n40C_1v95_5v50_5v50.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_ground_lvc_wpad_ff_n40C_1v95_5v50.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_power_lvc_wpad_ff_n40C_1v95_5v50_5v50.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_xres4v2_ff_ff_n40C_1v95_5v50.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__gpiov2_pad_wrapped_ff_ff_n40C_1v95_5v50.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vccd_lvc_clamped_pad_ff_n40C_1v95_5v50_5v50.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vdda_hvc_clamped_pad_ff_n40C_1v95_5v50_5v50.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vssa_hvc_clamped_pad_ff_n40C_1v95_5v50_5v50.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vddio_hvc_clamped_pad_ff_n40C_1v95_5v50_5v50.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vssio_hvc_clamped_pad_ff_n40C_1v95_5v50_5v50.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vssd_lvc_clamped3_pad_ff_n40C_1v95_5v50.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vccd_lvc_clamped3_pad_ff_n40C_1v95_5v50_5v50.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vssd_lvc_clamped_pad_ff_n40C_1v95_5v50.lib
-    $::env(PDK_REF_PATH)/sky130_sram_macros/lib/sky130_sram_2kbyte_1rw1r_32x512_8_TT_1p8V_25C.lib
-"
diff --git a/deps/timing-scripts/env/s.tcl b/deps/timing-scripts/env/s.tcl
deleted file mode 100644
index 9b61eeb..0000000
--- a/deps/timing-scripts/env/s.tcl
+++ /dev/null
@@ -1,21 +0,0 @@
-set libs "
-    $::env(PDK_REF_PATH)/${std_cell_library}/lib/${std_cell_library}__ss_100C_1v60.lib
-    $::env(PDK_REF_PATH)/${special_voltage_library}/lib/${special_voltage_library}__ss_100C_1v65.lib
-    $::env(PDK_REF_PATH)/${special_voltage_library}/lib/${special_voltage_library}__ss_100C_1v65_lv1v60.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_gpiov2_ss_ss_100C_1v60_3v00.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_ground_hvc_wpad_ss_100C_1v60_3v00_3v00.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_ground_lvc_wpad_ss_100C_1v60_3v00.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_power_lvc_wpad_ss_100C_1v60_3v00_3v00.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_xres4v2_ss_ss_100C_1v60_3v00.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__gpiov2_pad_wrapped_ss_ss_100C_1v60_3v00.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vccd_lvc_clamped_pad_ss_100C_1v60_3v00_3v00.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vdda_hvc_clamped_pad_ss_100C_1v60_3v00_3v00.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vssa_hvc_clamped_pad_ss_100C_1v60_3v00_3v00.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vddio_hvc_clamped_pad_ss_100C_1v60_3v00_3v00.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vssio_hvc_clamped_pad_ss_100C_1v60_3v00_3v00.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vssd_lvc_clamped3_pad_ss_100C_1v60_3v00.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vccd_lvc_clamped3_pad_ss_100C_1v60_3v00_3v00.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vssd_lvc_clamped_pad_ss_100C_1v60_3v00.lib
-    $::env(PDK_REF_PATH)/sky130_sram_macros/lib/sky130_sram_2kbyte_1rw1r_32x512_8_TT_1p8V_25C.lib
-"
-
diff --git a/deps/timing-scripts/env/t.tcl b/deps/timing-scripts/env/t.tcl
deleted file mode 100644
index c9eea15..0000000
--- a/deps/timing-scripts/env/t.tcl
+++ /dev/null
@@ -1,21 +0,0 @@
-set libs "
-    $::env(PDK_REF_PATH)/${std_cell_library}/lib/${std_cell_library}__tt_025C_1v80.lib
-    $::env(PDK_REF_PATH)/${special_voltage_library}/lib/${special_voltage_library}__tt_025C_3v30.lib
-    $::env(PDK_REF_PATH)/${special_voltage_library}/lib/${special_voltage_library}__tt_025C_3v30_lv1v80.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_gpiov2_tt_tt_025C_1v80_3v30.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_ground_hvc_wpad_tt_025C_1v80_3v30_3v30.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_ground_lvc_wpad_tt_025C_1v80_3v30.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_power_lvc_wpad_tt_025C_1v80_3v30_3v30.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_fd_io__top_xres4v2_tt_tt_025C_1v80_3v30.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__gpiov2_pad_tt_tt_025C_1v80_3v30.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vccd_lvc_clamped_pad_tt_025C_1v80_3v30_3v30.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vdda_hvc_clamped_pad_tt_025C_1v80_3v30_3v30.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vssa_hvc_clamped_pad_tt_025C_1v80_3v30_3v30.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vddio_hvc_clamped_pad_tt_025C_1v80_3v30_3v30.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vssio_hvc_clamped_pad_tt_025C_1v80_3v30_3v30.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vssd_lvc_clamped3_pad_tt_025C_1v80_3v30.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vccd_lvc_clamped3_pad_tt_025C_1v80_3v30_3v30.lib
-    $::env(PDK_REF_PATH)/${io_library}/lib/sky130_ef_io__vssd_lvc_clamped_pad_tt_025C_1v80_3v30.lib
-    $::env(PDK_REF_PATH)/sky130_sram_macros/lib/sky130_sram_2kbyte_1rw1r_32x512_8_TT_1p8V_25C.lib
-"
-
diff --git a/deps/timing-scripts/requirements.txt b/deps/timing-scripts/requirements.txt
deleted file mode 100644
index dca9a90..0000000
--- a/deps/timing-scripts/requirements.txt
+++ /dev/null
@@ -1 +0,0 @@
-click
diff --git a/deps/timing-scripts/scripts/compare_reports.py b/deps/timing-scripts/scripts/compare_reports.py
deleted file mode 100644
index 1276473..0000000
--- a/deps/timing-scripts/scripts/compare_reports.py
+++ /dev/null
@@ -1,85 +0,0 @@
-#!/usr/bin/env python3
-import click
-
-from report import Report
-
-
-@click.command(
-    help="""
-               attempts to compare two sta reports 
-               """
-)
-@click.option("--first", "-f", required=True, type=str)
-@click.option("--first-label", default="first", type=str)
-@click.option("--second-label", default="second", type=str)
-@click.option("--second", "-s", required=True, type=str)
-@click.option("--output", "-o", required=True, type=str)
-def main(first, second, output, first_label, second_label):
-    first_report = Report(first)
-    second_report = Report(second)
-
-    print(f"{first_label} {len(first_report.paths)}")
-    print(f"{second_label} {len(second_report.paths)}")
-    f_output = open(output, "w+")
-    f_first_diff = open(f"{first}.diff", "w+")
-    f_second_diff = open(f"{second}.diff", "w+")
-    header = (
-        f"start,end,group,type,{first_label},{second_label},"
-        f"required_first,required_second,first-second,percent"
-    )
-    f_output.write(f"{header}\n")
-
-    matches_count = 0
-    b = 0
-    c = 0
-
-    for first_path in first_report.paths:
-        if first_path in second_report.paths:
-            matches = [
-                element for element in second_report.paths if first_path == element
-            ]
-            if len(matches) == 1:
-                matches_count += 1
-                second_path = matches[0]
-                delta = first_path.slack - second_path.slack
-                percent = delta / first_path.slack * 100.0
-                path_summary = (
-                    f"{first_path.start_point},{first_path.end_point},"
-                    f"{first_path.path_group},"
-                    f"{first_path.path_type},"
-                    f"{first_path.slack:.4f},"
-                    f"{second_path.slack:.4f},"
-                    f"{first_path.required_time:.4f},"
-                    f"{second_path.required_time:.4f},"
-                    f"{delta:.4f},{percent:.2f}%"
-                )
-                f_output.write(f"{path_summary}\n")
-
-                f_first_diff.write(f"{first_path.start_point}\n")
-                f_first_diff.write(f"{first_path.end_point}\n")
-                f_first_diff.write(f"{first_path.path}\n")
-                f_second_diff.write(f"------------\n")
-
-                f_second_diff.write(f"{second_path.start_point}\n")
-                f_second_diff.write(f"{second_path.end_point}\n")
-                f_second_diff.write(f"{second_path.path}\n")
-                f_second_diff.write(f"------------\n")
-            elif len(matches) > 1:
-                b += 1
-            # print(
-            # f"{path.start_point},{path.end_point},{path.path_group},{path.path_type},{path.slack}"
-            # )
-        else:
-            c += 1
-
-    f_output.close()
-    f_first_diff.close()
-    f_second_diff.close()
-    print("matches:", matches_count)
-    print("non unique matches:", b)
-    print("unmatched:", c)
-    print("done")
-
-
-if __name__ == "__main__":
-    main()
diff --git a/deps/timing-scripts/scripts/generate_spef_mapping.py b/deps/timing-scripts/scripts/generate_spef_mapping.py
deleted file mode 100644
index 0094c7b..0000000
--- a/deps/timing-scripts/scripts/generate_spef_mapping.py
+++ /dev/null
@@ -1,120 +0,0 @@
-from pathlib import Path
-from verilog_parser import VerilogParser
-from pdk_helpers import get_macros, get_pdk_lefs_paths
-import click
-import logging
-
-
-@click.command(
-    help="""parses a verilog gatelevel netlist and creates a
-               spef mapping file for non pdk macros. the file is used
-               along with the other scripts in the repo for proper parasitics annotation 
-               during sta"""
-)
-@click.option(
-    "--input",
-    "-i",
-    required=True,
-    type=click.Path(exists=True, dir_okay=False),
-    help="input verilog netlist",
-)
-@click.option(
-    "--project-root",
-    required=True,
-    type=click.Path(exists=True, file_okay=False),
-    help="path of the project that will be used in the output spef mapping file and finding verilog modules",
-)
-@click.option(
-    "--output", "-o", required=True, type=str, help="spef mapping tcl output file"
-)
-@click.option(
-    "--pdk-path", required=True, type=click.Path(exists=True, file_okay=False)
-)
-@click.option(
-    "--macro-parent",
-    required=False,
-    type=str,
-    default="",
-    help="optional name of the parent of the macro",
-)
-@click.option("--debug", is_flag=True)
-def main(input, project_root, output, pdk_path, macro_parent, debug=False):
-    """
-    Parse a verilog netlist
-    """
-    output_path = Path(output)
-    output_path.parents[0].mkdir(parents=True, exist_ok=True)
-    logging.basicConfig(format="%(asctime)s | %(module)s | %(levelname)s | %(message)s")
-    logger = logging.getLogger()
-    if debug:
-        logger.setLevel(logging.DEBUG)
-    else:
-        logger.setLevel(logging.INFO)
-
-    logger.info(f"using project_root {project_root}")
-
-    pdk_macros = []
-    logger.info("getting pdk macros ..")
-    lef_paths = get_pdk_lefs_paths(pdk_path)
-    for lef in lef_paths:
-        pdk_macros = pdk_macros + get_macros(lef)
-    logger.debug(f"pdk has {len(pdk_macros)} macros")
-
-    with open(output_path, "w") as f:
-        for mapping in run(input, project_root, pdk_macros, logger, macro_parent):
-            logging.debug(mapping)
-            f.write(mapping)
-
-    logger.info(f"wrote to {output_path}")
-
-
-def run(input, project_root, pdk_macros, logger, macro_parent=""):
-    logger.info(f"parsing netlist {input} ..")
-    parsed = VerilogParser(input, logger)
-    logger.info("comparing macros against pdk macros ..")
-    postfix = ".$::env(RCX_CORNER).spef"
-
-    mappings = []
-    non_pdk_instance = []
-    for instance in parsed.instances:
-        macro = parsed.instances[instance]
-        if macro not in pdk_macros:
-            logging.debug(f"{macro} not found in pdk_macros")
-            non_pdk_instance.append(instance)
-
-    logging.debug(f"# of non pdk instances {len(non_pdk_instance)}")
-    # recursion will break if above is zero
-    for instance in non_pdk_instance:
-        macro = parsed.instances[instance]
-        mapping_key = instance
-        hier_separator = "/"
-        if macro_parent != "":
-            mapping_key = f"{macro_parent}{hier_separator}{instance}"
-
-        existing_netlist = list(
-            (Path(project_root) / "verilog" / "gl").rglob(f"{macro}.v")
-        )
-        if len(existing_netlist) == 1:
-            logging.info(f"found netlist {str(existing_netlist[0])} for macro {macro}")
-            mappings += run(
-                input=str(existing_netlist[0]),
-                project_root=project_root,
-                pdk_macros=pdk_macros,
-                logger=logger,
-                macro_parent=mapping_key,
-            )
-
-        spef_dir = Path(project_root) / "signoff" / "not-found"
-        for macro_spef_file in (Path(project_root) / "signoff").rglob(f"{macro}*.spef"):
-            spef_dir = macro_spef_file.parent
-            logging.debug(f"found {macro_spef_file} for {macro}")
-        spef_rel_dir = spef_dir.relative_to(project_root)
-        macro_spef = f"$::env(PROJECT_ROOT)/{spef_rel_dir}/{macro}{postfix}"
-        mappings.append(f'set spef_mapping({mapping_key}) "{macro_spef}"\n')
-
-    return mappings
-
-
-# sys.path.insert(0, os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
-if __name__ == "__main__":
-    main()
diff --git a/deps/timing-scripts/scripts/get_macros.py b/deps/timing-scripts/scripts/get_macros.py
deleted file mode 100644
index f6abdf9..0000000
--- a/deps/timing-scripts/scripts/get_macros.py
+++ /dev/null
@@ -1,121 +0,0 @@
-from __future__ import absolute_import
-from __future__ import print_function
-from pathlib import Path
-from verilog_parser import VerilogParser
-from pdk_helpers import get_pdk_lefs_paths, get_macros
-import click
-import logging
-import os
-import sys
-
-
-@click.command(
-    help="""parses a verilog gatelevel netlist and
-               prints the non scl instance names
-               """
-)
-@click.option(
-    "--input",
-    "-i",
-    required=True,
-    type=click.Path(exists=True, dir_okay=False),
-    help="input verilog netlist",
-)
-@click.option(
-    "--pdk-path", required=True, type=click.Path(exists=True, file_okay=False)
-)
-@click.option(
-    "--output",
-    "-o",
-    required=True,
-    type=str,
-    help="output file in the format each line <instance_name> <instance_type>",
-)
-@click.option(
-    "--project-root",
-    required=True,
-    type=click.Path(exists=True, file_okay=False),
-    help="path of the project that will be used in the finding verilog modules",
-)
-@click.option(
-    "--macro-parent",
-    required=False,
-    type=str,
-    default="",
-    help="optional name of the parent of the macro",
-)
-@click.option("--debug", is_flag=True)
-def main(input, output, pdk_path, project_root, macro_parent, debug=False):
-    """
-    Parse a verilog netlist
-    """
-    logging.basicConfig(format="%(asctime)s | %(module)15s | %(levelname)6s | %(message)s")
-    logger = logging.getLogger()
-    if debug:
-        logger.setLevel(logging.DEBUG)
-    else:
-        logger.setLevel(logging.INFO)
-
-    output_path = Path(output)
-    output_path.parents[0].mkdir(parents=True, exist_ok=True)
-
-    pdk_macros = []
-    logger.info("getting pdk macros..")
-    lef_paths = get_pdk_lefs_paths(pdk_path)
-    for lef in lef_paths:
-        pdk_macros = pdk_macros + get_macros(lef)
-    logger.debug(pdk_macros)
-
-
-    with open(output_path, "w") as f:
-        for macro in run(input, project_root, pdk_macros, logger, macro_parent):
-            f.write(macro)
-
-    logger.info("done.")
-
-def run(input, project_root, pdk_macros, logger, macro_parent=""):
-    logger.info(f"parsing netlist {input} ..")
-    parsed = VerilogParser(input, logger)
-    logger.info("comparing macros against pdk macros ..")
-
-    macros = []
-    non_pdk_instance = []
-    for instance in parsed.instances:
-        macro = parsed.instances[instance]
-        if macro not in pdk_macros:
-            logging.debug(f"{macro} not found in pdk_macros")
-            non_pdk_instance.append(instance)
-
-    logging.debug(f"# of non pdk instances {len(non_pdk_instance)}")
-    # recursion will break if above is zero
-    for instance in non_pdk_instance:
-        macro = parsed.instances[instance]
-        mapping_key = instance
-        hier_separator = "/"
-        if macro_parent != "":
-            mapping_key = f"{macro_parent}{hier_separator}{instance}"
-
-        search_path = (Path(project_root) / "verilog" / "gl")
-        logging.debug(f"searching for {macro} netlist in {search_path}")
-        existing_netlist = list(
-            search_path.rglob(f"{macro}.v")
-        )
-        logging.debug(f"found {len(existing_netlist)} matches.")
-        if len(existing_netlist) == 1:
-            logging.info(f"found netlist {str(existing_netlist[0])} for macro {macro}")
-            macros += run(
-                input=str(existing_netlist[0]),
-                project_root=project_root,
-                pdk_macros=pdk_macros,
-                logger=logger,
-                macro_parent=mapping_key,
-            )
-
-        macros.append(f'{instance} {macro}\n')
-
-    return macros
-
-
-sys.path.insert(0, os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
-if __name__ == "__main__":
-    main()
diff --git a/deps/timing-scripts/scripts/openroad/rcx.tcl b/deps/timing-scripts/scripts/openroad/rcx.tcl
deleted file mode 100644
index dfe3e9c..0000000
--- a/deps/timing-scripts/scripts/openroad/rcx.tcl
+++ /dev/null
@@ -1,35 +0,0 @@
-source $::env(TIMING_ROOT)/env/common.tcl
-source $::env(TIMING_ROOT)/env/$::env(LIB_CORNER).tcl
-
-set libs [split [regexp -all -inline {\S+} $libs]]
-set extra_lefs [split [regexp -all -inline {\S+} $extra_lefs]]
-
-foreach liberty $libs {
-  run_puts "read_liberty $liberty"
-}
-foreach lef $lefs {
-  run_puts "read_lef $lef"
-}
-run_puts "read_lef $sram_lef"
-
-foreach lef_file $extra_lefs {		
-  run_puts "read_lef $lef_file"
-}
-
-run_puts "read_def $def"
-# don't think we need to read sdc
-
-run_puts "define_process_corner -ext_model_index 0 X"
-run_puts "extract_parasitics \
-    -ext_model_file $rcx_rules_file \
-    -lef_res"
-
-run_puts "write_spef $spef"
-run_puts "read_spef $spef"
-
-puts "spef: $spef"
-puts "def: $def"
-puts "rcx: $rcx_rules_file"
-puts "rcx-corner: $::env(RCX_CORNER)"
-puts "lib-corner: $::env(TIMING_ROOT)/env/$::env(LIB_CORNER).tcl"
-puts "tech_lef: $tech_lef"
diff --git a/deps/timing-scripts/scripts/openroad/sdf.tcl b/deps/timing-scripts/scripts/openroad/sdf.tcl
deleted file mode 100644
index 382ef89..0000000
--- a/deps/timing-scripts/scripts/openroad/sdf.tcl
+++ /dev/null
@@ -1,60 +0,0 @@
-source $::env(TIMING_ROOT)/env/common.tcl
-source $::env(TIMING_ROOT)/env/$::env(LIB_CORNER).tcl
-
-set libs [split [regexp -all -inline {\S+} $libs]]
-set verilogs [split [regexp -all -inline {\S+} $verilogs]]
-
-
-foreach lef $lefs {
-    if {[catch {read_lef $lef} errmsg]} {
-        puts stderr $errmsg
-        exit 1
-    }
-}
-
-if {[catch {read_lef $sram_lef} errmsg]} {
-    puts stderr $errmsg
-    exit 1
-}
-
-foreach lef_file $extra_lefs {		
-    if {[catch {read_lef $lef_file} errmsg]} {
-        puts stderr $errmsg
-        exit 1
-    }	
-}
-
-foreach liberty $libs {
-    read_liberty $liberty
-}
-
-#foreach verilog $verilogs {
-#    puts "reading veriolg: $verilog"
-#    read_verilog $verilog
-#}
-
-set verilog $::env(CUP_ROOT)/verilog/gl/$::env(BLOCK).v
-if { ![file exists $verilog] } {
-    set verilog $::env(MCW_ROOT)/verilog/gl/$::env(BLOCK).v
-}
-if { ![file exists $verilog] } {
-    set verilog $::env(CARAVEL_ROOT)/verilog/gl/$::env(BLOCK).v
-}
-
-read_verilog $verilog
-
-
-link_design $block
-
-puts "read_spef $spef"
-read_spef $spef
-#read_sdc $sdc
-write_sdf $sdf -divider . -include_typ
-
-puts "block: $block"
-puts "spef: $spef"
-puts "verilog: $verilog"
-puts "sdf: $sdf"
-puts "sdc: $sdc"
-puts "rcx-corner: $::env(RCX_CORNER)"
-puts "lib-corner: $::env(TIMING_ROOT)/env/$::env(LIB_CORNER).tcl"
diff --git a/deps/timing-scripts/scripts/openroad/sta-gpio_control_block.tcl b/deps/timing-scripts/scripts/openroad/sta-gpio_control_block.tcl
deleted file mode 100644
index e224905..0000000
--- a/deps/timing-scripts/scripts/openroad/sta-gpio_control_block.tcl
+++ /dev/null
@@ -1,42 +0,0 @@
-source $::env(TIMING_ROOT)/env/common.tcl
-source $::env(TIMING_ROOT)/env/$::env(LIB_CORNER).tcl
-
-set libs [split [regexp -all -inline {\S+} $libs]]
-
-foreach liberty $libs {
-    read_liberty $liberty
-}
-
-
-set verilogs [list \
-    $::env(CARAVEL_ROOT)/verilog/gl/gpio_logic_high.v \
-    $::env(CARAVEL_ROOT)/verilog/gl/gpio_control_block.v \
-]
-foreach verilog $verilogs {
-    puts "read_verilog $verilog"
-    read_verilog $verilog
-}
-
-link_design $block
-
-set spef $::env(CARAVEL_ROOT)/spef/gpio_control_block.spef
-puts "read_spef $spef"
-read_spef $spef
-
-puts "read_spef -path gpio_logic_high $::env(CARAVEL_ROOT)/spef/gpio_logic_high.spef"
-read_spef -path gpio_logic_high $::env(CARAVEL_ROOT)/spef/gpio_logic_high.spef
-
-read_sdc -echo $sdc
-
-report_checks -path_delay min -fields {slew cap input nets fanout} -format full_clock_expanded -group_count 50
-
-report_worst_slack -max 
-report_worst_slack -min 
-
-puts "block: $block"
-puts "spef: $spef"
-puts "verilog: $verilog"
-puts "sdf: $sdf"
-puts "sdc: $sdc"
-puts "rcx-corner: $::env(RCX_CORNER)"
-puts "lib-corner: $::env(TIMING_ROOT)/env/$::env(LIB_CORNER).tcl"
diff --git a/deps/timing-scripts/scripts/openroad/timing_top.tcl b/deps/timing-scripts/scripts/openroad/timing_top.tcl
deleted file mode 100644
index 02390ed..0000000
--- a/deps/timing-scripts/scripts/openroad/timing_top.tcl
+++ /dev/null
@@ -1,289 +0,0 @@
-source $::env(TIMING_ROOT)/env/common.tcl
-source $::env(TIMING_ROOT)/env/caravel_spef_mapping-mpw7.tcl
-
-if { [file exists $::env(CUP_ROOT)/env/spef-mapping.tcl] } {
-    source $::env(CUP_ROOT)/env/spef-mapping.tcl
-} else {
-    puts "WARNING no user project spef mapping file found"
-}
-
-source $::env(TIMING_ROOT)/env/$::env(LIB_CORNER).tcl
-
-set libs [split [regexp -all -inline {\S+} $libs]]
-set verilogs [split [regexp -all -inline {\S+} $verilogs]]
-
-
-foreach liberty $libs {
-}
-
-foreach liberty $libs {
-    run_puts "read_liberty $liberty"
-}
-
-foreach verilog $verilogs {
-    run_puts "read_verilog $verilog"
-}
-
-run_puts "link_design caravel"
-
-if { $::env(SPEF_OVERWRITE) ne "" } {
-    puts "overwriting spef from "
-    puts "$spef to"
-    puts "$::env(SPEF_OVERWRITE)"
-    eval set spef $::env(SPEF_OVERWRITE)
-}
-
-set missing_spefs 0
-set missing_spefs_list ""
-run_puts "read_spef $spef"
-foreach key [array names spef_mapping] {
-    set spef_file $spef_mapping($key)
-    if { [file exists $spef_file] } {
-        run_puts "read_spef -path $key $spef_mapping($key)"
-    } else {
-        set missing_spefs 1
-        set missing_spefs_list "$missing_spefs_list $key"
-        puts "$spef_file not found"
-        if { $::env(ALLOW_MISSING_SPEF) } {
-            puts "WARNING ALLOW_MISSING_SPEF set to 1. continuing"
-        } else {
-            exit 1
-        }
-    }
-}
-
-set sdc $::env(CARAVEL_ROOT)/signoff/caravel/caravel.sdc
-run_puts "read_sdc -echo $sdc"
-
-set logs_path "$::env(PROJECT_ROOT)/signoff/caravel/openlane-signoff/timing/$::env(RCX_CORNER)/$::env(LIB_CORNER)"
-file mkdir [file dirname $logs_path]
-
-
-run_puts_logs "report_check_types \\
-    -max_delay \\
-    -min_delay \\
-    -max_slew \\
-    -max_capacitance \\
-    -clock_gating_setup \\
-    -clock_gating_hold \\
-    -format end \\
-    -violators" \
-    "${logs_path}-summary.rpt"
-
-
-set max_delay_result "met"
-set min_delay_result "met"
-set max_slew_result "met"
-set max_cap_result "met"
-set missing_spefs_result "incomplete"
-
-set report ${logs_path}-summary.rpt
-
-set max_cap_value "[exec bash -c "grep 'max cap' $report -A 4 | tail -n1 | awk -F '  *' '{print \$4}'"]"
-set worst_hold "[exec bash -c "grep 'min_delay\/hold' $report -A 10 | grep VIOLATED | head -n1 | awk -F '  *' '{print \$5}'"]"
-set worst_setup "[exec bash -c "grep 'max_delay\/setup' $report -A 10 | grep VIOLATED | head -n1 | awk -F '  *' '{print \$5}'"]"
-set max_slew_value "[exec bash -c "grep 'max slew' $report -A 4 | tail -n1 | awk -F '  *' '{print \$4}'"]"
-
-set table_format "%7s| %15s |%15s |%15s |%15s |%15s"
-set header [format "$table_format" "corner" "max cap" "max slew" "min delay" "max delay" "spefs"]
-if {![catch {exec grep -q {max cap} $report} err]} {
-    set max_cap_result "vio($max_cap_value)"
-}
-
-if {![catch {exec grep -q {max slew} $report} err]} {
-    set max_slew_result "vio($max_slew_value)"
-}
-
-if {![catch {exec grep -q {min_delay\/hold} $report} err]} {
-    set min_delay_result "vio($worst_hold)"
-}
-
-if {![catch {exec grep -q {max_delay\/setup} $report} err]} {
-    set max_delay_result "vio($worst_setup)"
-}
-
-if { !$missing_spefs } {
-    set missing_spefs_result "complete"
-}
-
-set summary [format "$table_format" "$::env(LIB_CORNER)-$::env(RCX_CORNER)"\
-    "$max_cap_result" \
-    "$max_slew_result" \
-    "$min_delay_result"\
-    "$max_delay_result"\
-    "$missing_spefs_result"]
-
-exec echo "$header" >> "${logs_path}-summary.rpt"
-exec echo "$summary" >> "${logs_path}-summary.rpt"
-
-
-run_puts_logs "report_checks \\
-    -path_delay min \\
-    -format full_clock_expanded \\
-    -fields {slew cap input_pins nets fanout} \\
-    -no_line_splits \\
-    -group_count 10000 \\
-    -slack_max 10 \\
-    -digits 4 \\
-    -endpoint_count 10 \\
-    -unique_paths_to_endpoint \\
-    "\
-    "${logs_path}-min.rpt"
-
-run_puts_logs "report_checks \\
-    -path_delay max \\
-    -format full_clock_expanded \\
-    -fields {slew cap input_pins nets fanout} \\
-    -no_line_splits \\
-    -group_count 10000 \\
-    -slack_max 10 \\
-    -digits 4 \\
-    -endpoint_count 10 \\
-    -unique_paths_to_endpoint \\
-    "\
-    "${logs_path}-max.rpt"
-
-run_puts_logs "report_checks \\
-    -path_delay min \\
-    -format full_clock_expanded \\
-    -fields {slew cap input_pins nets fanout} \\
-    -no_line_splits \\
-    -path_group hk_serial_clk \\
-    -group_count 1000 \\
-    -slack_max 10 \\
-    -digits 4 \\
-    -unique_paths_to_endpoint \\
-    "\
-    "${logs_path}-hk_serial_clk-min.rpt"
-
-
-run_puts_logs "report_checks \\
-    -path_delay max \\
-    -format full_clock_expanded \\
-    -fields {slew cap input_pins nets fanout} \\
-    -no_line_splits \\
-    -path_group hk_serial_clk \\
-    -group_count 1000 \\
-    -slack_max 10 \\
-    -digits 4 \\
-    -unique_paths_to_endpoint \\
-    "\
-    "${logs_path}-hk_serial_clk-max.rpt"
-
-run_puts_logs "report_checks \\
-    -path_delay max \\
-    -format full_clock_expanded \\
-    -fields {slew cap input_pins nets fanout} \\
-    -no_line_splits \\
-    -path_group hkspi_clk \\
-    -group_count 1000 \\
-    -slack_max 10 \\
-    -digits 4 \\
-    -unique_paths_to_endpoint \\
-    "\
-    "${logs_path}-hkspi_clk-max.rpt"
-
-run_puts_logs "report_checks \\
-    -path_delay min \\
-    -format full_clock_expanded \\
-    -fields {slew cap input_pins nets fanout} \\
-    -no_line_splits \\
-    -path_group hkspi_clk \\
-    -group_count 1000 \\
-    -slack_max 10 \\
-    -digits 4 \\
-    -unique_paths_to_endpoint \\
-    "\
-    "${logs_path}-hkspi_clk-min.rpt"
-
-run_puts_logs "report_checks \\
-    -path_delay min \\
-    -format full_clock_expanded \\
-    -fields {slew cap input_pins nets fanout} \\
-    -no_line_splits \\
-    -path_group clk \\
-    -group_count 1000 \\
-    -slack_max 10 \\
-    -digits 4 \\
-    -unique_paths_to_endpoint \\
-    "\
-    "${logs_path}-clk-min.rpt"
-        
-run_puts_logs "report_checks \\
-    -path_delay max \\
-    -format full_clock_expanded \\
-    -fields {slew cap input_pins nets fanout} \\
-    -no_line_splits \\
-    -path_group clk \\
-    -group_count 1000 \\
-    -slack_max 10 \\
-    -digits 4 \\
-    -unique_paths_to_endpoint \\
-    "\
-    "${logs_path}-clk-max.rpt"
-
-run_puts_logs "report_checks \\
-    -path_delay min \\
-    -through [get_cells soc] \\
-    -format full_clock_expanded \\
-    -fields {slew cap input_pins nets fanout} \\
-    -no_line_splits \\
-    -group_count 1000 \\
-    -slack_max 10 \\
-    -digits 4 \\
-    -unique_paths_to_endpoint \\
-    "\
-    "${logs_path}-soc-min.rpt"
-
-run_puts_logs "report_checks \\
-    -path_delay max \\
-    -through [get_cells soc] \\
-    -format full_clock_expanded \\
-    -fields {slew cap input_pins nets fanout} \\
-    -no_line_splits \\
-    -group_count 1000 \\
-    -slack_max 10 \\
-    -digits 4 \\
-    -unique_paths_to_endpoint \\
-    "\
-    "${logs_path}-soc-max.rpt"
-
-run_puts_logs "report_checks \\
-    -path_delay min \\
-    -through [get_cells mprj] \\
-    -format full_clock_expanded \\
-    -fields {slew cap input_pins nets fanout} \\
-    -no_line_splits \\
-    -group_count 1000 \\
-    -slack_max 40 \\
-    -digits 4 \\
-    -unique_paths_to_endpoint \\
-    "\
-    "${logs_path}-mprj-min.rpt"
-
-run_puts_logs "report_checks \\
-    -path_delay max \\
-    -through [get_cells mprj] \\
-    -format full_clock_expanded \\
-    -fields {slew cap input_pins nets fanout} \\
-    -no_line_splits \\
-    -group_count 1000 \\
-    -slack_max 40 \\
-    -digits 4 \\
-    -unique_paths_to_endpoint \\
-    "\
-    "${logs_path}-mprj-max.rpt"
-
-run_puts "report_parasitic_annotation -report_unannotated > ${logs_path}-unannotated.log"
-if { $missing_spefs } {
-    puts "there are missing spefs. check the log for ALLOW_MISSING_SPEF"
-    puts "the following macros don't have spefs"
-    foreach spef $missing_spefs_list {
-        puts "$spef"
-    }
-}
-report_parasitic_annotation 
-
-
-puts "you may want to edit sdc: $sdc to change i/o constraints"
-puts "check $logs_path"
diff --git a/deps/timing-scripts/scripts/pdk_helpers.py b/deps/timing-scripts/scripts/pdk_helpers.py
deleted file mode 100644
index 6536e9b..0000000
--- a/deps/timing-scripts/scripts/pdk_helpers.py
+++ /dev/null
@@ -1,21 +0,0 @@
-from typing import List
-import os
-
-def get_pdk_lefs_paths(pdk_path: str) -> List[str]:
-    lef_paths = []
-    for root, dirs, files in os.walk(pdk_path):
-        for file in files:
-            filename, file_extension = os.path.splitext(f"{file}")
-            if file_extension == ".lef":
-                lef_paths.append(f"{root}/{file}")
-    return lef_paths
-
-
-def get_macros(lef_file: str) -> List[str]:
-    macros = []
-    with open(lef_file) as f:
-        for line in f.readlines():
-            if "MACRO" in line:
-                macro_name = line.split()[1]
-                macros.append(macro_name)
-    return macros
diff --git a/deps/timing-scripts/scripts/report.py b/deps/timing-scripts/scripts/report.py
deleted file mode 100644
index 1b96505..0000000
--- a/deps/timing-scripts/scripts/report.py
+++ /dev/null
@@ -1,83 +0,0 @@
-from timing_path import TimingPath
-
-
-class Report:
-    def __init__(self, report_file):
-        self.report_file = report_file
-        self.paths = []
-        self.input_output_paths = []
-        self.input_flipflop_paths = []
-        self.flipflop_flipflop_paths = []
-        self.flipflop_output_paths = []
-        self.build_db()
-        self.classify_paths()
-
-    def classify_paths(self):
-        for path in self.paths:
-            path_category = path.category
-            if path_category == "input-output":
-                self.input_output_paths.append(path)
-            elif path_category == "input-flipflop":
-                self.input_flipflop_paths.append(path)
-            elif path_category == "flipflop-flipflop":
-                self.flipflop_flipflop_paths.append(path)
-            elif path_category == "flipflop-output":
-                self.flipflop_output_paths.append(path)
-
-    def build_db(self):
-        file = open(self.report_file)
-        start_point = end_point = path_group = path_values = ""
-
-        line = file.readline()
-        while line != "":
-            line = line.strip()
-            if "Startpoint" in line:
-                x = file.tell()
-                start_point = " ".join(line.split(" ")[1:])
-                line2 = file.readline()
-                if "Endpoint" not in line2:
-                    start_point += line2
-                else:
-                    file.seek(x)
-            elif "Endpoint" in line:
-                x = file.tell()
-                end_point = " ".join(line.split(" ")[1:])
-                line2 = file.readline()
-                if "Path Group" not in line2:
-                    end_point += line2
-                else:
-                    file.seek(x)
-            elif "Path Group" in line:
-                path_group = line.split(" ")[2]
-            elif "Path Type" in line:
-                path_type = line.split(" ")[2]
-
-                path_line = file.readline()
-                while path_line != "":
-                    if "Startpoint" in path_line:
-                        path_object = TimingPath(
-                            start_point=start_point.rstrip(),
-                            end_point=end_point.rstrip(),
-                            path_group=path_group.rstrip(),
-                            path_type=path_type,
-                            path=path_values,
-                        )
-                        self.paths.append(path_object)
-
-                        path_line = path_line.strip()
-                        start_point = " ".join(path_line.split(" ")[1:])
-                        x = file.tell()
-                        line2 = file.readline()
-                        if "Endpoint" not in line2:
-                            start_point += line2
-                        else:
-                            file.seek(x)
-
-                        path_values = ""
-                        break
-                    else:
-                        path_values += path_line
-                    path_line = file.readline()
-            line = file.readline()
-
-        file.close()
diff --git a/deps/timing-scripts/scripts/summarize_report.py b/deps/timing-scripts/scripts/summarize_report.py
deleted file mode 100644
index efc0317..0000000
--- a/deps/timing-scripts/scripts/summarize_report.py
+++ /dev/null
@@ -1,44 +0,0 @@
-#!/usr/bin/env python3
-
-import argparse
-from report import Report
-from timing_path import TimingPath
-
-parser = argparse.ArgumentParser(
-    description="summarizes sta reports. tested on pt and opensta"
-)
-parser.add_argument("--input", "-i", required=True)
-parser.add_argument("--output", "-o", required=True)
-
-args = parser.parse_args()
-report_file = args.input
-output_file = args.output
-
-report = Report(report_file)
-
-output_files_stream = open(f"{output_file}", "w")
-
-output_files_stream.write(
-    f"--------------input-flipflop_paths#{len(report.input_flipflop_paths)}-------------------\n"
-)
-output_files_stream.write(TimingPath.get_header())
-for path in report.input_flipflop_paths:
-    output_files_stream.write(path.summarize())
-output_files_stream.write(
-    f"--------------input-output_paths#{len(report.input_output_paths)}---------------------\n"
-)
-output_files_stream.write(TimingPath.get_header())
-for path in report.input_output_paths:
-    output_files_stream.write(path.summarize())
-output_files_stream.write(
-    f"--------------flipflop-flipflop_paths#{len(report.flipflop_flipflop_paths)}----------------\n"
-)
-output_files_stream.write(TimingPath.get_header())
-for path in report.flipflop_flipflop_paths:
-    output_files_stream.write(path.summarize())
-output_files_stream.write(
-    f"--------------flipflop-output_paths#{len(report.flipflop_output_paths)}------------------\n"
-)
-output_files_stream.write(TimingPath.get_header())
-for path in report.flipflop_output_paths:
-    output_files_stream.write(path.summarize())
diff --git a/deps/timing-scripts/scripts/timing_path.py b/deps/timing-scripts/scripts/timing_path.py
deleted file mode 100644
index c77a624..0000000
--- a/deps/timing-scripts/scripts/timing_path.py
+++ /dev/null
@@ -1,112 +0,0 @@
-import textwrap
-import re
-
-
-class TimingPath:
-    def __init__(self, start_point, end_point, path_group, path_type, path):
-        self.start_point = start_point
-        self.end_point = end_point
-        self.path_group = path_group
-        self.path_type = path_type
-        self.path = path
-        self.category = ""
-        self.slack = None
-        self.edges = ""
-        self.required_time = None
-        self.arrival_time = None
-        self.find_category()
-        self.simplify_points()
-        self.find_slack()
-        self.find_required()
-        self.find_arrival()
-        self.id = self.start_point + self.end_point + self.path_group + self.path_type
-
-    def find_required(self):
-        for line in self.path.split("\n"):
-            if "required time" in line:
-                self.required_time = float(re.findall(
-                    r"[+-]? *(?:\d+(?:\.\d*)?|\.\d+)(?:[eE][+-]?\d+)?", line
-                )[0].strip())
-                break
-
-    def find_arrival(self):
-        for line in self.path:
-            if "arrival time" in line:
-                self.arrival_time = float(re.findall(
-                    r"[+-]? *(?:\d+(?:\.\d*)?|\.\d+)(?:[eE][+-]?\d+)?", line
-                )[0].strip())
-                break
-
-    def find_edges(self):
-        split_path = self.path.split("\n")
-        edge = "f"
-        for line in split_path:
-            if "^" in line or " r" in line:
-                edge = "r"
-                self.edges = self.edges + edge
-            elif "v" in line or " f" in line:
-                edge = "f"
-                self.edges = self.edges + edge
-            elif "data arrival time" in line:
-                break
-
-    def simplify_points(self):
-        if len(self.start_point.split()) > 1:
-            self.start_point = self.start_point.split()[0]
-        if len(self.end_point.split()) > 1:
-            self.end_point = self.end_point.split()[0]
-
-    @classmethod
-    def get_header(cls):
-        start_point = "start_point"
-        end_point = "end_point"
-        group = "group"
-        type = "type"
-        slack = "slack"
-        return f"{start_point},{end_point},{group},{type},{slack}\n"
-
-    def find_slack(self):
-        slack = ""
-        for line in self.path.splitlines():
-            if "slack" in line:
-                slack = textwrap.dedent(line)
-                break
-        self.slack = re.findall(
-            r"[+-]? *(?:\d+(?:\.\d*)?|\.\d+)(?:[eE][+-]?\d+)?", slack
-        )[0].strip()
-        self.slack = float(self.slack)
-
-    def summarize(self):
-        slack_value = self.slack
-        group = self.path_group
-        type = self.path_type
-        start_point = self.start_point
-        end_point = self.end_point
-        return f"{start_point},{end_point},{group},{type},{slack_value:.4f}\n"
-
-    def find_category(self):
-        start = ""
-        end = ""
-        if "input" in self.start_point:
-            start = "input"
-        else:
-            start = "flipflop"
-        if "output" in self.end_point:
-            end = "output"
-        else:
-            end = "flipflop"
-
-        self.category = f"{start}-{end}"
-
-    def __eq__(self, other):
-        return self.id == other.id
-
-    def __str__(self):
-        return f"""
-Startpoint: {self.start_point}
-Endpoint: {self.end_point}
-Path group: {self.path_group}
-Path type: {self.path_type}
-Path:
-{self.path}
-"""
diff --git a/deps/timing-scripts/scripts/verilog_parser.py b/deps/timing-scripts/scripts/verilog_parser.py
deleted file mode 100644
index 3bb15fd..0000000
--- a/deps/timing-scripts/scripts/verilog_parser.py
+++ /dev/null
@@ -1,40 +0,0 @@
-import subprocess
-import os
-import json
-
-
-class VerilogParser:
-    def __init__(self, verilog_netlist, logger):
-        self.verilog_netlist = verilog_netlist
-        self.instances = {}
-        self.logger = logger
-        self.yosys_to_json()
-
-    # self.instances[instance.name] = instance.module
-
-    def yosys_to_json(self):
-        yosys_env = os.environ.copy()
-        script_path = os.path.dirname(os.path.abspath(__file__))
-        yosys_env["YOSYS_VERILOG_IN"] = self.verilog_netlist
-        yosys_env["YOSYS_JSON_OUT"] = "./tmp.json"
-        self.logger.debug("running yosys ..")
-        process = subprocess.run(
-            f"yosys -c {script_path}/yosys/to-json.tcl".split(),
-            env=yosys_env,
-            stdout=subprocess.PIPE,
-            stderr=subprocess.STDOUT,
-        )
-        if process.returncode:
-            self.logger.error(process.stdout.decode("utf-8"))
-
-        self.logger.debug("reading json ..")
-        f = open("./tmp.json")
-        data = json.load(f)
-        f.close()
-        os.remove("./tmp.json")
-        module_name = os.path.basename(self.verilog_netlist)
-        module_name = os.path.splitext(module_name)[0]
-        self.logger.debug("parsing json ..")
-        full_cells = data["modules"][module_name]["cells"]
-        for cell in full_cells:
-            self.instances[cell] = full_cells[cell]["type"]
diff --git a/deps/timing-scripts/scripts/yosys/to-json.tcl b/deps/timing-scripts/scripts/yosys/to-json.tcl
deleted file mode 100644
index 47c1529..0000000
--- a/deps/timing-scripts/scripts/yosys/to-json.tcl
+++ /dev/null
@@ -1,4 +0,0 @@
-yosys -import
-
-read_verilog $::env(YOSYS_VERILOG_IN)
-json -o $::env(YOSYS_JSON_OUT)
diff --git a/deps/timing-scripts/timing.mk b/deps/timing-scripts/timing.mk
deleted file mode 100644
index 148b384..0000000
--- a/deps/timing-scripts/timing.mk
+++ /dev/null
@@ -1,307 +0,0 @@
-OPENLANE_TAG ?=  2022.02.23_02.50.41
-OPENLANE_IMAGE_NAME ?=  efabless/openlane:$(OPENLANE_TAG)
-export PDK ?= sky130A
-export RCX_CORNER ?= nom
-export LIB_CORNER ?= t
-export ALLOW_MISSING_SPEF ?= 1
-export PDK_REF_PATH = $(PDK_ROOT)/$(PDK)/libs.ref/
-export PDK_TECH_PATH = $(PDK_ROOT)/$(PDK)/libs.tech/
-export PROJECT_ROOT ?= $(CARAVEL_ROOT)
-
-logs-dir = $(PROJECT_ROOT)/logs
-logs = $(logs-dir)/rcx $(logs-dir)/sdf $(logs-dir)/top $(logs-dir)/sta
-$(logs):
-	mkdir -p $@
-
-SPEF_OVERWRITE ?= ""
-define docker_run_base
-	docker run \
-		--rm \
-		-e PROJECT_ROOT=$(PROJECT_ROOT) \
-		-e BLOCK=$1 \
-		-e PDK=$(PDK) \
-		-e LIB_CORNER=$(LIB_CORNER) \
-		-e RCX_CORNER=$(RCX_CORNER) \
-		-e MCW_ROOT=$(MCW_ROOT) \
-		-e SPEF_OVERWRITE=$(SPEF_OVERWRITE) \
-		-e CUP_ROOT=$(CUP_ROOT) \
-		-e CARAVEL_ROOT=$(CARAVEL_ROOT) \
-		-e TIMING_ROOT=$(TIMING_ROOT) \
-		-e PDK_REF_PATH=$(PDK_ROOT)/$(PDK)/libs.ref/ \
-		-e PDK_TECH_PATH=$(PDK_ROOT)/$(PDK)/libs.tech/ \
-		-e ALLOW_MISSING_SPEF=$(ALLOW_MISSING_SPEF) \
-		-v $(PDK_ROOT):$(PDK_ROOT) \
-		-v $(CUP_ROOT):$(CUP_ROOT) \
-		-v $(MCW_ROOT):$(MCW_ROOT) \
-		-v $(TIMING_ROOT):$(TIMING_ROOT) \
-		-v $(CARAVEL_ROOT):$(CARAVEL_ROOT) \
-		-v $(HOME):$(HOME) \
-		-u $(shell id -u $(USER)):$(shell id -g $(USER)) \
-		$(OPENLANE_IMAGE_NAME)
-endef
-
-
-define docker_run_sta
-	$(call docker_run_base,$1) \
-		bash -c "set -eo pipefail && sta -exit $(TIMING_ROOT)/scripts/openroad/sta-$*.tcl \
-			|& tee $(logs-dir)/sta/$*-$(RCX_CORNER)-$(LIB_CORNER).log"
-	@echo "logged to $(logs-dir)/sta/$*-$(RCX_CORNER)-$(LIB_CORNER).log"
-endef
-
-define docker_run_sdf
-	$(call docker_run_base,$1) \
-		bash -c "set -eo pipefail && openroad -exit $(TIMING_ROOT)/scripts/openroad/sdf.tcl \
-			|& tee $(logs-dir)/sdf/$*-$(RCX_CORNER)-$(LIB_CORNER).log"
-	@echo "logged to $(logs-dir)/sdf/$*-$(RCX_CORNER)-$(LIB_CORNER).log"
-endef
-
-define docker_run_rcx
-	$(call docker_run_base,$1) \
-		bash -c "set -eo pipefail && openroad -exit $(TIMING_ROOT)/scripts/openroad/rcx.tcl \
-			|& tee $(logs-dir)/rcx/$*-$(RCX_CORNER)-$(LIB_CORNER).log"
-	@echo "logged to $(logs-dir)/rcx/$*-$(RCX_CORNER)-$(LIB_CORNER).log"
-endef
-
-blocks  = $(shell cd $(CARAVEL_ROOT)/openlane && find * -maxdepth 0 -type d)
-blocks := $(subst user_project_wrapper,,$(blocks))
-ifneq ($(CARAVEL_ROOT),$(MCW_ROOT))
-blocks += $(shell cd $(MCW_ROOT)/openlane && find * -maxdepth 0 -type d)
-endif
-ifneq ($(CARAVEL_ROOT),$(CUP_ROOT))
-blocks += $(shell cd $(CUP_ROOT)/openlane && find * -maxdepth 0 -type d)
-endif
-
-# we don't have user_id_programming.def)
-# mgmt_protect_hvl use hvl library which we don't handle yet
-blocks := $(subst mgmt_protect_hvl,,$(blocks))
-blocks := $(subst chip_io_alt,,$(blocks))
-blocks := $(subst user_id_programming,,$(blocks))
-blocks := $(subst user_analog_project_wrapper,,$(blocks))
-blocks := $(subst caravan,,$(blocks))
-
-defs  = $(shell cd $(CARAVEL_ROOT)/def && find *.def -maxdepth 0 -type f ! -name 'user_project_wrapper.def') 
-ifneq ($(CARAVEL_ROOT),$(MCW_ROOT))
-defs += $(shell cd $(MCW_ROOT)/def && find *.def -maxdepth 0 -type f)
-endif
-ifneq ($(CARAVEL_ROOT),$(CUP_ROOT))
-defs += $(shell cd $(CUP_ROOT)/def && find *.def -maxdepth 0 -type f)
-endif
-
-rcx-blocks     = $(defs:%.def=rcx-%)
-rcx-blocks-nom = $(blocks:%=rcx-%-nom)
-rcx-blocks-max = $(blocks:%=rcx-%-max)
-rcx-blocks-min = $(blocks:%=rcx-%-min)
-rcx-blocks-t = $(blocks:%=rcx-%-t)
-rcx-blocks-f = $(blocks:%=rcx-%-f)
-rcx-blocks-s = $(blocks:%=rcx-%-s)
-
-sdf-blocks = $(blocks:%=sdf-%)
-sdf-blocks-t = $(blocks:%=sdf-%-t)
-sdf-blocks-f = $(blocks:%=sdf-%-f)
-sdf-blocks-s = $(blocks:%=sdf-%-s)
-sdf-blocks-nom = $(blocks:%=sdf-%-nom)
-sdf-blocks-min = $(blocks:%=sdf-%-min)
-sdf-blocks-max = $(blocks:%=sdf-%-max)
-
-$(sdf-blocks): sdf-%: 
-	$(MAKE) -f timing.mk sdf-$*-nom
-	$(MAKE) -f timing.mk sdf-$*-min
-	$(MAKE) -f timing.mk sdf-$*-max
-
-$(sdf-blocks-nom): export RCX_CORNER = nom
-$(sdf-blocks-min): export RCX_CORNER = min
-$(sdf-blocks-max): export RCX_CORNER = max
-$(sdf-blocks-nom): sdf-%-nom: sdf-%-t sdf-%-f sdf-%-s
-$(sdf-blocks-min): sdf-%-min: sdf-%-t sdf-%-f sdf-%-s
-$(sdf-blocks-max): sdf-%-max: sdf-%-t sdf-%-f sdf-%-s
-
-$(sdf-blocks-t): export LIB_CORNER = t
-$(sdf-blocks-s): export LIB_CORNER = s
-$(sdf-blocks-f): export LIB_CORNER = f
-$(sdf-blocks-t): sdf-%-t:
-	$(call docker_run_sdf,$*)
-$(sdf-blocks-s): sdf-%-s:
-	$(call docker_run_sdf,$*)
-$(sdf-blocks-f): sdf-%-f:
-	$(call docker_run_sdf,$*)
-
-
-sta-blocks = $(blocks:%=sta-%)
-sta-blocks-t = $(blocks:%=sta-%-t)
-sta-blocks-f = $(blocks:%=sta-%-f)
-sta-blocks-s = $(blocks:%=sta-%-s)
-sta-blocks-nom = $(blocks:%=sta-%-nom)
-sta-blocks-min = $(blocks:%=sta-%-min)
-sta-blocks-max = $(blocks:%=sta-%-max)
-
-$(sta-blocks): sta-%:
-	$(MAKE) -f timing.mk sta-$*-nom
-	$(MAKE) -f timing.mk sta-$*-min
-	$(MAKE) -f timing.mk sta-$*-max
-
-$(sta-blocks-nom): export RCX_CORNER = nom
-$(sta-blocks-min): export RCX_CORNER = min
-$(sta-blocks-max): export RCX_CORNER = max
-$(sta-blocks-nom): sta-%-nom: sta-%-t sta-%-f sta-%-s
-$(sta-blocks-min): sta-%-min: sta-%-t sta-%-f sta-%-s
-$(sta-blocks-max): sta-%-max: sta-%-t sta-%-f sta-%-s
-
-$(sta-blocks-t): export LIB_CORNER = t
-$(sta-blocks-s): export LIB_CORNER = s
-$(sta-blocks-f): export LIB_CORNER = f
-$(sta-blocks-t): sta-%-t: $(logs-dir)/sta
-	$(call docker_run_sta,$*)
-$(sta-blocks-s): sta-%-s:
-	$(call docker_run_sta,$*)
-$(sta-blocks-f): sta-%-f:
-	$(call docker_run_sta,$*)
-
-
-$(rcx-blocks): rcx-%: $(rcx-requirements)
-	$(MAKE) -f timing.mk rcx-$*-nom &
-	$(MAKE) -f timing.mk rcx-$*-min &
-	$(MAKE) -f timing.mk rcx-$*-max
-
-$(rcx-blocks-nom): export RCX_CORNER = nom
-$(rcx-blocks-min): export RCX_CORNER = min
-$(rcx-blocks-max): export RCX_CORNER = max
-$(rcx-blocks-nom): rcx-%-nom: rcx-%-t
-$(rcx-blocks-min): rcx-%-min: rcx-%-t
-$(rcx-blocks-max): rcx-%-max: rcx-%-t
-
-$(rcx-blocks-t): export LIB_CORNER = t
-$(rcx-blocks-s): export LIB_CORNER = s
-$(rcx-blocks-f): export LIB_CORNER = f
-$(rcx-blocks-t): rcx-%-t: $(logs-dir)/rcx
-	$(call docker_run_rcx,$*)
-$(rcx-blocks-s): rcx-%-s:
-	$(call docker_run_rcx,$*)
-$(rcx-blocks-f): rcx-%-f:
-	$(call docker_run_rcx,$*)
-
-
-define docker_run_caravel_timing
-	$(call docker_run_base,caravel) \
-		bash -c "set -eo pipefail && sta -no_splash -exit $(TIMING_ROOT)/scripts/openroad/timing_top.tcl |& tee \
-			$(logs-dir)/top/caravel-timing-$$(basename $(LIB_CORNER))-$(RCX_CORNER).log"
-	@echo "logged to $(logs-dir)/top/caravel-timing-$$(basename $(LIB_CORNER))-$(RCX_CORNER).log"
-endef
-
-
-caravel-timing-typ-targets  = caravel-timing-typ-nom
-caravel-timing-typ-targets += caravel-timing-typ-min
-caravel-timing-typ-targets += caravel-timing-typ-max
-
-caravel-timing-slow-targets  = caravel-timing-slow-nom
-caravel-timing-slow-targets += caravel-timing-slow-min
-caravel-timing-slow-targets += caravel-timing-slow-max
-
-caravel-timing-fast-targets  = caravel-timing-fast-nom
-caravel-timing-fast-targets += caravel-timing-fast-min
-caravel-timing-fast-targets += caravel-timing-fast-max
-
-caravel-timing-targets  = $(caravel-timing-slow-targets)
-caravel-timing-targets += $(caravel-timing-fast-targets)
-caravel-timing-targets += $(caravel-timing-typ-targets)
-
-.PHONY: caravel-timing-typ
-$(caravel-timing-typ-targets): export LIB_CORNER = t
-caravel-timing-typ: caravel-timing-typ-nom caravel-timing-typ-min caravel-timing-typ-max
-
-.PHONY: caravel-timing-typ-nom
-.PHONY: caravel-timing-typ-min
-.PHONY: caravel-timing-typ-max
-caravel-timing-typ-nom: export RCX_CORNER = nom
-caravel-timing-typ-min: export RCX_CORNER = min
-caravel-timing-typ-max: export RCX_CORNER = max
-
-.PHONY: caravel-timing-slow
-$(caravel-timing-slow-targets): export LIB_CORNER = s
-caravel-timing-slow: caravel-timing-slow-nom caravel-timing-slow-min caravel-timing-slow-max
-
-.PHONY: caravel-timing-slow-nom
-.PHONY: caravel-timing-slow-min
-.PHONY: caravel-timing-slow-max
-caravel-timing-slow-nom: export RCX_CORNER = nom
-caravel-timing-slow-min: export RCX_CORNER = min
-caravel-timing-slow-max: export RCX_CORNER = max
-
-.PHONY: caravel-timing-fast
-$(caravel-timing-fast-targets): export LIB_CORNER = f
-caravel-timing-fast: caravel-timing-fast-nom caravel-timing-fast-min caravel-timing-fast-max
-
-.PHONY: caravel-timing-fast-nom
-.PHONY: caravel-timing-fast-min
-.PHONY: caravel-timing-fast-max
-caravel-timing-fast-nom: export RCX_CORNER = nom
-caravel-timing-fast-min: export RCX_CORNER = min
-caravel-timing-fast-max: export RCX_CORNER = max
-
-$(caravel-timing-targets): $(logs-dir)/top
-	$(call docker_run_caravel_timing)
-
-
-# some useful dev double checking
-#
-rcx-requirements  = $(CARAVEL_ROOT)/def/%.def
-rcx-requirements += $(CARAVEL_ROOT)/lef/%.lef
-rcx-requirements += $(CARAVEL_ROOT)/sdc/%.sdc
-rcx-requirements += $(CARAVEL_ROOT)/verilog/gl/%.v
-
-exceptions  = $(MCW_ROOT)/lef/caravel.lef
-exceptions += $(MCW_ROOT)/lef/caravan.lef
-# lets ignore these for now
-exceptions += $(MCW_ROOT)/sdc/user_analog_project_wrapper.sdc
-exceptions += $(MCW_ROOT)/sdc/user_project_wrapper.sdc
-exceptions += $(MCW_ROOT)/verilog/gl/user_analog_project_wrapper.v
-exceptions += $(MCW_ROOT)/verilog/gl/user_project_wrapper.v
-
-.PHONY: list-rcx
-.PHONY: list-sdf
-.PHONY: rcx-all
-list-rcx:
-	@blocks="$(rcx-blocks)";\
-		for block in $${blocks}; do echo "$$block"; done
-list-sdf:
-	@echo $(sdf-blocks)
-list-sta:
-	@echo $(sta-blocks)
-rcx-all: $(rcx-blocks)
-
-$(exceptions):
-	$(warning we don't need lefs for $@ but take note anyway)
-
-$(CARAVEL_ROOT)/def/%.def: $(MCW_ROOT)/def/%.def ;
-$(MCW_ROOT)/def/%.def: $(CUP_ROOT)/def/%.def ;
-$(CUP_ROOT)/def/%.def:
-	$(error error if you are here it probably means that $@.def is mising from mcw and caravel)
-
-$(CARAVEL_ROOT)/lef/%.lef: $(MCW_ROOT)/lef/%.lef ;
-$(MCW_ROOT)/lef/%.lef: $(CUP_ROOT)/lef/%.lef ;
-$(CUP_ROOT)/lef/%.lef:
-	$(error error if you are here it probably means that $@.lef is mising from mcw and caravel)
-
-$(CARAVEL_ROOT)/sdc/%.sdc: $(MCW_ROOT)/sdc/%.sdc ;
-$(MCW_ROOT)/sdc/%.sdc: $(CUP_ROOT)/sdc/%.sdc ;
-$(CUP_ROOT)/sdc/%.sdc:
-	$(error error if you are here it probably means that $@.sdc is mising from mcw and caravel)
-
-$(CARAVEL_ROOT)/verilog/gl/%.v: $(MCW_ROOT)/verilog/gl/%.v ;
-$(MCW_ROOT)/verilog/gl/%.v: $(CUP_ROOT)/verilog/gl/%.v ;
-$(CUP_ROOT)/verilog/gl/%.v:
-	$(error error if you are here it probably means that gl/$@.v is mising from mcw and caravel)
-
-check_defined = \
-    $(strip $(foreach 1,$1, \
-        $(call __check_defined,$1,$(strip $(value 2)))))
-__check_defined = \
-    $(if $(value $1),, \
-      $(error Undefined $1$(if $2, ($2))))
-
-$(call check_defined, \
-	MCW_ROOT \
-	CUP_ROOT \
-	PDK_ROOT \
-	CARAVEL_ROOT \
-	TIMING_ROOT \
-)