From f3a07da1a5ff99091fe1223068aa07bfbb14553c Mon Sep 17 00:00:00 2001 From: Alexander Williams Date: Sat, 28 Dec 2024 18:05:52 -0800 Subject: [PATCH] [ipgen] Try out a virtual provider library for tops Signed-off-by: Alexander Williams --- .../alert_handler/alert_handler.core.tpl | 5 +++ .../dv/alert_handler_sim.core.tpl | 5 +++ .../fpv/alert_handler_esc_timer_fpv.core.tpl | 7 ++++ .../fpv/alert_handler_ping_timer_fpv.core.tpl | 7 ++++ hw/ip_templates/clkmgr/clkmgr.core.tpl | 10 ++--- .../clkmgr/data/clkmgr.tpldesc.hjson | 6 --- hw/ip_templates/clkmgr/dv/clkmgr_sim.core.tpl | 10 ++--- .../flash_ctrl/data/flash_ctrl.tpldesc.hjson | 6 --- .../flash_ctrl/dv/flash_ctrl_sim.core.tpl | 14 ++----- .../flash_ctrl/flash_ctrl.core.tpl | 10 ++--- .../pinmux/fpv/pinmux_chip_fpv.core.tpl | 7 ++++ .../pinmux/fpv/pinmux_fpv.core.tpl | 7 ++++ hw/ip_templates/pinmux/pinmux.core.tpl | 7 ++++ .../pwrmgr/data/pwrmgr.tpldesc.hjson | 12 ------ hw/ip_templates/pwrmgr/dv/pwrmgr_sim.core.tpl | 19 ++------- hw/ip_templates/pwrmgr/pwrmgr.core.tpl | 10 ++--- .../rstmgr/data/rstmgr.tpldesc.hjson | 12 ------ .../rstmgr_cnsty_chk_sim.core.tpl | 5 +++ hw/ip_templates/rstmgr/dv/rstmgr_sim.core.tpl | 20 ++-------- hw/ip_templates/rstmgr/rstmgr.core.tpl | 19 ++------- .../alert_handler/alert_handler.core | 5 +++ .../alert_handler/dv/alert_handler_sim.core | 5 +++ .../fpv/alert_handler_esc_timer_fpv.core | 7 ++++ .../fpv/alert_handler_ping_timer_fpv.core | 7 ++++ .../ip_autogen/clkmgr/clkmgr.core | 6 +-- .../data/top_darjeeling_clkmgr.ipconfig.hjson | 1 - .../ip_autogen/clkmgr/dv/clkmgr_sim.core | 6 +-- .../pinmux/fpv/pinmux_chip_fpv.core | 7 ++++ .../ip_autogen/pinmux/fpv/pinmux_fpv.core | 7 ++++ .../ip_autogen/pinmux/pinmux.core | 7 ++++ .../data/top_darjeeling_pwrmgr.ipconfig.hjson | 2 - .../ip_autogen/pwrmgr/dv/pwrmgr_sim.core | 7 ++-- .../ip_autogen/pwrmgr/pwrmgr.core | 6 +-- .../data/top_darjeeling_rstmgr.ipconfig.hjson | 2 - .../rstmgr_cnsty_chk_sim.core | 5 +++ .../ip_autogen/rstmgr/dv/rstmgr_sim.core | 8 ++-- .../ip_autogen/rstmgr/rstmgr.core | 7 ++-- .../dv/top_earlgrey_flash_ctrl_sim_top.core | 40 ------------------- .../{dv => ip/ast}/top_earlgrey_ast_top.core | 1 + .../alert_handler/alert_handler.core | 5 +++ .../alert_handler/dv/alert_handler_sim.core | 5 +++ .../fpv/alert_handler_esc_timer_fpv.core | 7 ++++ .../fpv/alert_handler_ping_timer_fpv.core | 7 ++++ hw/top_earlgrey/ip_autogen/clkmgr/clkmgr.core | 6 +-- .../data/top_earlgrey_clkmgr.ipconfig.hjson | 1 - .../ip_autogen/clkmgr/dv/clkmgr_sim.core | 6 +-- .../top_earlgrey_flash_ctrl.ipconfig.hjson | 1 - .../flash_ctrl/dv/flash_ctrl_sim.core | 8 ++-- .../ip_autogen/flash_ctrl/flash_ctrl.core | 6 +-- .../pinmux/fpv/pinmux_chip_fpv.core | 7 ++++ .../ip_autogen/pinmux/fpv/pinmux_fpv.core | 7 ++++ hw/top_earlgrey/ip_autogen/pinmux/pinmux.core | 7 ++++ .../data/top_earlgrey_pwrmgr.ipconfig.hjson | 2 - .../ip_autogen/pwrmgr/dv/pwrmgr_sim.core | 7 ++-- hw/top_earlgrey/ip_autogen/pwrmgr/pwrmgr.core | 6 +-- .../data/top_earlgrey_rstmgr.ipconfig.hjson | 2 - .../rstmgr_cnsty_chk_sim.core | 5 +++ .../ip_autogen/rstmgr/dv/rstmgr_sim.core | 8 ++-- hw/top_earlgrey/ip_autogen/rstmgr/rstmgr.core | 7 ++-- ...rlgrey_alert_handler_virtual_provider.core | 16 ++++++++ .../top_earlgrey_clkmgr_virtual_provider.core | 17 ++++++++ ..._earlgrey_flash_ctrl_virtual_provider.core | 16 ++++++++ .../top_earlgrey_pinmux_virtual_provider.core | 15 +++++++ .../top_earlgrey_pwrmgr_virtual_provider.core | 17 ++++++++ .../top_earlgrey_rstmgr_virtual_provider.core | 18 +++++++++ .../ip_autogen/clkmgr/clkmgr.core | 6 +-- ...top_englishbreakfast_clkmgr.ipconfig.hjson | 1 - .../ip_autogen/clkmgr/dv/clkmgr_sim.core | 6 +-- ...englishbreakfast_flash_ctrl.ipconfig.hjson | 1 - .../flash_ctrl/dv/flash_ctrl_sim.core | 8 ++-- .../ip_autogen/flash_ctrl/flash_ctrl.core | 6 +-- .../pinmux/fpv/pinmux_chip_fpv.core | 7 ++++ .../ip_autogen/pinmux/fpv/pinmux_fpv.core | 7 ++++ .../ip_autogen/pinmux/pinmux.core | 7 ++++ ...top_englishbreakfast_pwrmgr.ipconfig.hjson | 2 - .../ip_autogen/pwrmgr/dv/pwrmgr_sim.core | 7 ++-- .../ip_autogen/pwrmgr/pwrmgr.core | 6 +-- ...top_englishbreakfast_rstmgr.ipconfig.hjson | 1 - .../rstmgr_cnsty_chk_sim.core | 5 +++ .../ip_autogen/rstmgr/dv/rstmgr_sim.core | 7 ++-- .../ip_autogen/rstmgr/rstmgr.core | 6 +-- util/topgen.py | 9 +---- 82 files changed, 370 insertions(+), 265 deletions(-) delete mode 100644 hw/top_earlgrey/dv/top_earlgrey_flash_ctrl_sim_top.core rename hw/top_earlgrey/{dv => ip/ast}/top_earlgrey_ast_top.core (94%) create mode 100644 hw/top_earlgrey/top_earlgrey_alert_handler_virtual_provider.core create mode 100644 hw/top_earlgrey/top_earlgrey_clkmgr_virtual_provider.core create mode 100644 hw/top_earlgrey/top_earlgrey_flash_ctrl_virtual_provider.core create mode 100644 hw/top_earlgrey/top_earlgrey_pinmux_virtual_provider.core create mode 100644 hw/top_earlgrey/top_earlgrey_pwrmgr_virtual_provider.core create mode 100644 hw/top_earlgrey/top_earlgrey_rstmgr_virtual_provider.core diff --git a/hw/ip_templates/alert_handler/alert_handler.core.tpl b/hw/ip_templates/alert_handler/alert_handler.core.tpl index 9d025e2963ebc..b0caec8cfec14 100644 --- a/hw/ip_templates/alert_handler/alert_handler.core.tpl +++ b/hw/ip_templates/alert_handler/alert_handler.core.tpl @@ -13,6 +13,9 @@ filesets: - ${instance_vlnv("lowrisc:ip:alert_handler_component:0.1")} - ${instance_vlnv("lowrisc:ip_interfaces:alert_handler_reg:0.1")} file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (${instance_vlnv("lowrisc:ip:alert_handler_virtual_provider")})" parameters: SYNTHESIS: @@ -28,6 +31,8 @@ targets: lint: <<: *default_target + filesets_append: + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/ip_templates/alert_handler/dv/alert_handler_sim.core.tpl b/hw/ip_templates/alert_handler/dv/alert_handler_sim.core.tpl index 52f32902eb4c1..5dc9f75457979 100644 --- a/hw/ip_templates/alert_handler/dv/alert_handler_sim.core.tpl +++ b/hw/ip_templates/alert_handler/dv/alert_handler_sim.core.tpl @@ -18,6 +18,10 @@ filesets: - ${instance_vlnv("lowrisc:dv:alert_handler_sva:0.1")} file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (${instance_vlnv("lowrisc:ip:alert_handler_virtual_provider")})" + generate: ral: generator: ralgen @@ -31,6 +35,7 @@ targets: filesets: - files_rtl - files_dv + - files_virtual_provider generate: - ral default_tool: vcs diff --git a/hw/ip_templates/alert_handler/fpv/alert_handler_esc_timer_fpv.core.tpl b/hw/ip_templates/alert_handler/fpv/alert_handler_esc_timer_fpv.core.tpl index 57c16552887bd..d66bcd6021c0c 100644 --- a/hw/ip_templates/alert_handler/fpv/alert_handler_esc_timer_fpv.core.tpl +++ b/hw/ip_templates/alert_handler/fpv/alert_handler_esc_timer_fpv.core.tpl @@ -14,6 +14,9 @@ filesets: - tb/alert_handler_esc_timer_bind_fpv.sv - tb/alert_handler_esc_timer_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (${instance_vlnv("lowrisc:ip:alert_handler_virtual_provider")})" targets: default: &default_target @@ -26,6 +29,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/ip_templates/alert_handler/fpv/alert_handler_ping_timer_fpv.core.tpl b/hw/ip_templates/alert_handler/fpv/alert_handler_ping_timer_fpv.core.tpl index f1eab0aeac312..0346bb7e09a22 100644 --- a/hw/ip_templates/alert_handler/fpv/alert_handler_ping_timer_fpv.core.tpl +++ b/hw/ip_templates/alert_handler/fpv/alert_handler_ping_timer_fpv.core.tpl @@ -14,6 +14,9 @@ filesets: - tb/alert_handler_ping_timer_bind_fpv.sv - tb/alert_handler_ping_timer_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (${instance_vlnv("lowrisc:ip:alert_handler_virtual_provider")})" targets: default: &default_target @@ -26,6 +29,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/ip_templates/clkmgr/clkmgr.core.tpl b/hw/ip_templates/clkmgr/clkmgr.core.tpl index 48441de5ced56..6cee99aeb2e49 100644 --- a/hw/ip_templates/clkmgr/clkmgr.core.tpl +++ b/hw/ip_templates/clkmgr/clkmgr.core.tpl @@ -33,11 +33,9 @@ filesets: - rtl/clkmgr_trans.sv file_type: systemVerilogSource -% if len(pwrmgr_instance_name) > 0: - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (${instance_vlnv("lowrisc:ip:pwrmgr_pkg:0.1", pwrmgr_instance_name)})" -% endif + - "fileset_top ? (${instance_vlnv("lowrisc:ip:clkmgr_virtual_provider")})" files_verilator_waiver: depend: @@ -69,10 +67,8 @@ targets: lint: <<: *default_target -% if len(pwrmgr_instance_name) > 0: filesets_append: - - files_top_lint -% endif + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/ip_templates/clkmgr/data/clkmgr.tpldesc.hjson b/hw/ip_templates/clkmgr/data/clkmgr.tpldesc.hjson index 05b83960923c8..f194cea326ce4 100644 --- a/hw/ip_templates/clkmgr/data/clkmgr.tpldesc.hjson +++ b/hw/ip_templates/clkmgr/data/clkmgr.tpldesc.hjson @@ -92,11 +92,5 @@ type: "bool" default: "1" } - { - name: "pwrmgr_instance_name" - desc: "Instance name for the pwrmgr dependencies, if available" - type: "string" - default: "" - } ] } diff --git a/hw/ip_templates/clkmgr/dv/clkmgr_sim.core.tpl b/hw/ip_templates/clkmgr/dv/clkmgr_sim.core.tpl index 2f3c15edee79c..24ac53c0dd3c0 100644 --- a/hw/ip_templates/clkmgr/dv/clkmgr_sim.core.tpl +++ b/hw/ip_templates/clkmgr/dv/clkmgr_sim.core.tpl @@ -18,11 +18,9 @@ filesets: - cov/clkmgr_cov_bind.sv file_type: systemVerilogSource -% if len(pwrmgr_instance_name) > 0: - files_top_sim: + files_virtual_provider: depend: - - "fileset_top ? (${instance_vlnv("lowrisc:ip:pwrmgr_pkg:0.1", pwrmgr_instance_name)})" -%endif + - "fileset_top ? (${instance_vlnv("lowrisc:ip:clkmgr_virtual_provider")})" targets: sim: &sim_target @@ -30,9 +28,7 @@ targets: filesets: - files_rtl - files_dv -% if len(pwrmgr_instance_name) > 0: - - files_top_sim -% endif + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/ip_templates/flash_ctrl/data/flash_ctrl.tpldesc.hjson b/hw/ip_templates/flash_ctrl/data/flash_ctrl.tpldesc.hjson index baba9a3a9b966..273a06a4f965b 100644 --- a/hw/ip_templates/flash_ctrl/data/flash_ctrl.tpldesc.hjson +++ b/hw/ip_templates/flash_ctrl/data/flash_ctrl.tpldesc.hjson @@ -87,11 +87,5 @@ type: "int" default: "1048576" } - { - name: "pwrmgr_instance_name" - desc: "Instance name for the pwrmgr dependencies, if available" - type: "string" - default: "" - } ] } diff --git a/hw/ip_templates/flash_ctrl/dv/flash_ctrl_sim.core.tpl b/hw/ip_templates/flash_ctrl/dv/flash_ctrl_sim.core.tpl index e78fcb00a2dcf..1a9f83d4ca1ca 100644 --- a/hw/ip_templates/flash_ctrl/dv/flash_ctrl_sim.core.tpl +++ b/hw/ip_templates/flash_ctrl/dv/flash_ctrl_sim.core.tpl @@ -22,11 +22,9 @@ filesets: - tb/tb.sv file_type: systemVerilogSource -% if len(pwrmgr_instance_name) > 0: - files_top_sim: + files_virtual_provider: depend: - - "fileset_top ? (${instance_vlnv("lowrisc:ip:pwrmgr_pkg:0.1", pwrmgr_instance_name)})" -%endif + - "fileset_top ? (${instance_vlnv("lowrisc:ip:flash_ctrl_virtual_provider")})" targets: default: &default_target @@ -37,15 +35,11 @@ targets: sim: <<: *default_target -% if len(pwrmgr_instance_name) > 0: filesets_append: - - files_top_sim -% endif + - files_virtual_provider default_tool: vcs lint: <<: *default_target -% if len(pwrmgr_instance_name) > 0: filesets_append: - - files_top_sim -% endif + - files_virtual_provider diff --git a/hw/ip_templates/flash_ctrl/flash_ctrl.core.tpl b/hw/ip_templates/flash_ctrl/flash_ctrl.core.tpl index 66d5da113c9b9..f28c469001304 100644 --- a/hw/ip_templates/flash_ctrl/flash_ctrl.core.tpl +++ b/hw/ip_templates/flash_ctrl/flash_ctrl.core.tpl @@ -46,11 +46,9 @@ filesets: - rtl/flash_phy_scramble.sv file_type: systemVerilogSource -% if len(pwrmgr_instance_name) > 0: - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (${instance_vlnv("lowrisc:ip:pwrmgr_pkg:0.1", pwrmgr_instance_name)})" -% endif + - "fileset_top ? (${instance_vlnv("lowrisc:ip:flash_ctrl_virtual_provider")})" files_verilator_waiver: depend: @@ -93,10 +91,8 @@ targets: lint: <<: *default_target -% if len(pwrmgr_instance_name) > 0: filesets_append: - - files_top_lint -% endif + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/ip_templates/pinmux/fpv/pinmux_chip_fpv.core.tpl b/hw/ip_templates/pinmux/fpv/pinmux_chip_fpv.core.tpl index 53dffc0ee280f..b5a9d01a5afcc 100644 --- a/hw/ip_templates/pinmux/fpv/pinmux_chip_fpv.core.tpl +++ b/hw/ip_templates/pinmux/fpv/pinmux_chip_fpv.core.tpl @@ -20,6 +20,9 @@ filesets: files: - tb/pinmux_chip_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (${instance_vlnv("lowrisc:ip:pinmux_virtual_provider")})" generate: csr_assert_gen: @@ -38,6 +41,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/ip_templates/pinmux/fpv/pinmux_fpv.core.tpl b/hw/ip_templates/pinmux/fpv/pinmux_fpv.core.tpl index be660174056fb..ec00e1f9f851f 100644 --- a/hw/ip_templates/pinmux/fpv/pinmux_fpv.core.tpl +++ b/hw/ip_templates/pinmux/fpv/pinmux_fpv.core.tpl @@ -16,6 +16,9 @@ filesets: files: - tb/pinmux_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (${instance_vlnv("lowrisc:ip:pinmux_virtual_provider")})" generate: csr_assert_gen: @@ -34,6 +37,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/ip_templates/pinmux/pinmux.core.tpl b/hw/ip_templates/pinmux/pinmux.core.tpl index cd0a7cba9f42b..0a9958ca12a47 100644 --- a/hw/ip_templates/pinmux/pinmux.core.tpl +++ b/hw/ip_templates/pinmux/pinmux.core.tpl @@ -34,6 +34,10 @@ filesets: - rtl/pinmux.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (${instance_vlnv("lowrisc:ip:pinmux_virtual_provider")})" + files_verilator_waiver: depend: # common waivers @@ -74,6 +78,8 @@ targets: lint: <<: *default_target + filesets_append: + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true @@ -95,4 +101,5 @@ targets: formal: filesets: - files_rtl + - files_virtual_provider toplevel: pinmux_tb diff --git a/hw/ip_templates/pwrmgr/data/pwrmgr.tpldesc.hjson b/hw/ip_templates/pwrmgr/data/pwrmgr.tpldesc.hjson index f931e04e60a41..585632289279b 100644 --- a/hw/ip_templates/pwrmgr/data/pwrmgr.tpldesc.hjson +++ b/hw/ip_templates/pwrmgr/data/pwrmgr.tpldesc.hjson @@ -64,17 +64,5 @@ type: "int" default: "1" } - { - name: "alert_handler_instance_name" - desc: "Instance name for the alert_handler dependencies, if available" - type: "string" - default: "" - } - { - name: "clkmgr_instance_name" - desc: "Instance name for the clkmgr dependencies, if available" - type: "string" - default: "" - } ] } diff --git a/hw/ip_templates/pwrmgr/dv/pwrmgr_sim.core.tpl b/hw/ip_templates/pwrmgr/dv/pwrmgr_sim.core.tpl index fade73ffd5b40..34571914c15f1 100644 --- a/hw/ip_templates/pwrmgr/dv/pwrmgr_sim.core.tpl +++ b/hw/ip_templates/pwrmgr/dv/pwrmgr_sim.core.tpl @@ -17,20 +17,9 @@ filesets: - tb.sv - cov/pwrmgr_cov_bind.sv file_type: systemVerilogSource -<% - have_files_top_sim = (len(clkmgr_instance_name) > 0 or - len(alert_handler_instance_name) > 0) -%>\ -% if have_files_top_sim: - files_top_sim: + files_virtual_provider: depend: -% if len(alert_handler_instance_name) > 0: - - "fileset_top ? (${instance_vlnv("lowrisc:ip:alert_handler_pkg:0.1", alert_handler_instance_name)})" -% endif -% if len(clkmgr_instance_name) > 0: - - "fileset_top ? (${instance_vlnv("lowrisc:ip:clkmgr_pwrmgr_sva_if:0.1", clkmgr_instance_name)})" -% endif -% endif + - "fileset_top ? (${instance_vlnv("lowrisc:ip:pwrmgr_virtual_provider")})" targets: sim: &sim_target @@ -38,9 +27,7 @@ targets: filesets: - files_rtl - files_dv -% if have_files_top_sim: - - files_top_sim -% endif + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/ip_templates/pwrmgr/pwrmgr.core.tpl b/hw/ip_templates/pwrmgr/pwrmgr.core.tpl index 51ee2e7edc95a..97dfe799e20d6 100644 --- a/hw/ip_templates/pwrmgr/pwrmgr.core.tpl +++ b/hw/ip_templates/pwrmgr/pwrmgr.core.tpl @@ -15,11 +15,9 @@ filesets: - ${instance_vlnv("lowrisc:ip:pwrmgr_component:0.1")} file_type: systemVerilogSource -% if len(alert_handler_instance_name) > 0: - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (${instance_vlnv("lowrisc:ip:alert_handler_pkg:0.1", alert_handler_instance_name)})" -% endif + - "fileset_top ? (${instance_vlnv("lowrisc:ip:pwrmgr_virtual_provider")})" files_verilator_waiver: depend: @@ -62,10 +60,8 @@ targets: lint: <<: *default_target -% if len(alert_handler_instance_name) > 0: filesets_append: - - files_top_lint -% endif + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/ip_templates/rstmgr/data/rstmgr.tpldesc.hjson b/hw/ip_templates/rstmgr/data/rstmgr.tpldesc.hjson index af581f8dc7f1d..aa1db3ea83b4f 100644 --- a/hw/ip_templates/rstmgr/data/rstmgr.tpldesc.hjson +++ b/hw/ip_templates/rstmgr/data/rstmgr.tpldesc.hjson @@ -117,17 +117,5 @@ type: "bool" default: "1" } - { - name: "alert_handler_instance_name" - desc: "Instance name for the alert_handler dependencies, if available" - type: "string" - default: "" - } - { - name: "pwrmgr_instance_name" - desc: "Instance name for the pwrmgr dependencies, if available" - type: "string" - default: "" - } ] } diff --git a/hw/ip_templates/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core.tpl b/hw/ip_templates/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core.tpl index b93f30838335a..5800b1447c859 100644 --- a/hw/ip_templates/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core.tpl +++ b/hw/ip_templates/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core.tpl @@ -20,12 +20,17 @@ filesets: - tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (${instance_vlnv("lowrisc:ip:rstmgr_virtual_provider")})" + targets: sim: &sim_target toplevel: tb filesets: - files_rtl - files_dv + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/ip_templates/rstmgr/dv/rstmgr_sim.core.tpl b/hw/ip_templates/rstmgr/dv/rstmgr_sim.core.tpl index 108e1f673c480..24c8564de2ce5 100644 --- a/hw/ip_templates/rstmgr/dv/rstmgr_sim.core.tpl +++ b/hw/ip_templates/rstmgr/dv/rstmgr_sim.core.tpl @@ -17,21 +17,9 @@ filesets: - tb.sv - cov/rstmgr_cov_bind.sv file_type: systemVerilogSource -<% - have_files_top_sim = (len(alert_handler_instance_name) > 0 or - len(pwrmgr_instance_name) > 0) -%>\ -% if have_files_top_sim: - files_top_sim: + files_virtual_provider: depend: -% if len(alert_handler_instance_name) > 0: - - "fileset_top ? (${instance_vlnv("lowrisc:ip:alert_handler_pkg:0.1", alert_handler_instance_name)})" -% endif -% if len(pwrmgr_instance_name) > 0: - - "fileset_top ? (${instance_vlnv("lowrisc:ip:pwrmgr_pkg:0.1", pwrmgr_instance_name)})" - - "fileset_top ? (${instance_vlnv("lowrisc:ip:pwrmgr_rstmgr_sva_if:0.1", pwrmgr_instance_name)})" -% endif -% endif + - "fileset_top ? (${instance_vlnv("lowrisc:ip:rstmgr_virtual_provider")})" targets: sim: &sim_target @@ -39,9 +27,7 @@ targets: filesets: - files_rtl - files_dv -% if have_files_top_sim: - - files_top_sim -% endif + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/ip_templates/rstmgr/rstmgr.core.tpl b/hw/ip_templates/rstmgr/rstmgr.core.tpl index 738a7e4f3ff20..ee746f377afac 100644 --- a/hw/ip_templates/rstmgr/rstmgr.core.tpl +++ b/hw/ip_templates/rstmgr/rstmgr.core.tpl @@ -30,20 +30,9 @@ filesets: - rtl/rstmgr.sv file_type: systemVerilogSource -<% - have_files_top_lint = (len(alert_handler_instance_name) > 0 or - len(pwrmgr_instance_name) > 0) -%>\ -% if have_files_top_lint: - files_top_lint: + files_virtual_provider: depend: -% if len(alert_handler_instance_name) > 0: - - "fileset_top ? (${instance_vlnv("lowrisc:ip:alert_handler_pkg:0.1", alert_handler_instance_name)})" -% endif -% if len(pwrmgr_instance_name) > 0: - - "fileset_top ? (${instance_vlnv("lowrisc:ip:pwrmgr_pkg:0.1", pwrmgr_instance_name)})" -% endif -% endif + - "fileset_top ? (${instance_vlnv("lowrisc:ip:rstmgr_virtual_provider")})" files_verilator_waiver: depend: @@ -76,10 +65,8 @@ targets: lint: <<: *default_target -% if have_files_top_lint: filesets_append: - - files_top_lint -% endif + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/top_darjeeling/ip_autogen/alert_handler/alert_handler.core b/hw/top_darjeeling/ip_autogen/alert_handler/alert_handler.core index 4cb7db5b0d601..beba89d2141a0 100644 --- a/hw/top_darjeeling/ip_autogen/alert_handler/alert_handler.core +++ b/hw/top_darjeeling/ip_autogen/alert_handler/alert_handler.core @@ -13,6 +13,9 @@ filesets: - lowrisc:opentitan:top_darjeeling_alert_handler_component:0.1 - lowrisc:opentitan:top_darjeeling_alert_handler_reg:0.1 file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_alert_handler_virtual_provider)" parameters: SYNTHESIS: @@ -28,6 +31,8 @@ targets: lint: <<: *default_target + filesets_append: + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/top_darjeeling/ip_autogen/alert_handler/dv/alert_handler_sim.core b/hw/top_darjeeling/ip_autogen/alert_handler/dv/alert_handler_sim.core index 5149ef2a72be4..ca12b0140a193 100644 --- a/hw/top_darjeeling/ip_autogen/alert_handler/dv/alert_handler_sim.core +++ b/hw/top_darjeeling/ip_autogen/alert_handler/dv/alert_handler_sim.core @@ -18,6 +18,10 @@ filesets: - lowrisc:opentitan:top_darjeeling_alert_handler_sva:0.1 file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_alert_handler_virtual_provider)" + generate: ral: generator: ralgen @@ -31,6 +35,7 @@ targets: filesets: - files_rtl - files_dv + - files_virtual_provider generate: - ral default_tool: vcs diff --git a/hw/top_darjeeling/ip_autogen/alert_handler/fpv/alert_handler_esc_timer_fpv.core b/hw/top_darjeeling/ip_autogen/alert_handler/fpv/alert_handler_esc_timer_fpv.core index 721b801f11f0d..82d7e893a3589 100644 --- a/hw/top_darjeeling/ip_autogen/alert_handler/fpv/alert_handler_esc_timer_fpv.core +++ b/hw/top_darjeeling/ip_autogen/alert_handler/fpv/alert_handler_esc_timer_fpv.core @@ -14,6 +14,9 @@ filesets: - tb/alert_handler_esc_timer_bind_fpv.sv - tb/alert_handler_esc_timer_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_alert_handler_virtual_provider)" targets: default: &default_target @@ -26,6 +29,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/top_darjeeling/ip_autogen/alert_handler/fpv/alert_handler_ping_timer_fpv.core b/hw/top_darjeeling/ip_autogen/alert_handler/fpv/alert_handler_ping_timer_fpv.core index 60f051f50e2e1..17a9ff8c7eaf1 100644 --- a/hw/top_darjeeling/ip_autogen/alert_handler/fpv/alert_handler_ping_timer_fpv.core +++ b/hw/top_darjeeling/ip_autogen/alert_handler/fpv/alert_handler_ping_timer_fpv.core @@ -14,6 +14,9 @@ filesets: - tb/alert_handler_ping_timer_bind_fpv.sv - tb/alert_handler_ping_timer_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_alert_handler_virtual_provider)" targets: default: &default_target @@ -26,6 +29,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/top_darjeeling/ip_autogen/clkmgr/clkmgr.core b/hw/top_darjeeling/ip_autogen/clkmgr/clkmgr.core index a7f8d1ff70b39..5eb1350727b08 100644 --- a/hw/top_darjeeling/ip_autogen/clkmgr/clkmgr.core +++ b/hw/top_darjeeling/ip_autogen/clkmgr/clkmgr.core @@ -33,9 +33,9 @@ filesets: - rtl/clkmgr_trans.sv file_type: systemVerilogSource - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_darjeeling_pwrmgr_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_clkmgr_virtual_provider)" files_verilator_waiver: depend: @@ -68,7 +68,7 @@ targets: lint: <<: *default_target filesets_append: - - files_top_lint + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/top_darjeeling/ip_autogen/clkmgr/data/top_darjeeling_clkmgr.ipconfig.hjson b/hw/top_darjeeling/ip_autogen/clkmgr/data/top_darjeeling_clkmgr.ipconfig.hjson index fbd89cd3a9290..f79a83f1ce2bf 100644 --- a/hw/top_darjeeling/ip_autogen/clkmgr/data/top_darjeeling_clkmgr.ipconfig.hjson +++ b/hw/top_darjeeling/ip_autogen/clkmgr/data/top_darjeeling_clkmgr.ipconfig.hjson @@ -249,7 +249,6 @@ exported_clks: {} number_of_clock_groups: 7 with_alert_handler: true - pwrmgr_instance_name: top_darjeeling_ topname: darjeeling } } diff --git a/hw/top_darjeeling/ip_autogen/clkmgr/dv/clkmgr_sim.core b/hw/top_darjeeling/ip_autogen/clkmgr/dv/clkmgr_sim.core index bf1983886e43a..1cab575fb6cee 100644 --- a/hw/top_darjeeling/ip_autogen/clkmgr/dv/clkmgr_sim.core +++ b/hw/top_darjeeling/ip_autogen/clkmgr/dv/clkmgr_sim.core @@ -18,9 +18,9 @@ filesets: - cov/clkmgr_cov_bind.sv file_type: systemVerilogSource - files_top_sim: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_darjeeling_pwrmgr_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_clkmgr_virtual_provider)" targets: sim: &sim_target @@ -28,7 +28,7 @@ targets: filesets: - files_rtl - files_dv - - files_top_sim + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/top_darjeeling/ip_autogen/pinmux/fpv/pinmux_chip_fpv.core b/hw/top_darjeeling/ip_autogen/pinmux/fpv/pinmux_chip_fpv.core index b925f9c68c586..2fbdb04947403 100644 --- a/hw/top_darjeeling/ip_autogen/pinmux/fpv/pinmux_chip_fpv.core +++ b/hw/top_darjeeling/ip_autogen/pinmux/fpv/pinmux_chip_fpv.core @@ -20,6 +20,9 @@ filesets: files: - tb/pinmux_chip_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_pinmux_virtual_provider)" generate: csr_assert_gen: @@ -38,6 +41,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/top_darjeeling/ip_autogen/pinmux/fpv/pinmux_fpv.core b/hw/top_darjeeling/ip_autogen/pinmux/fpv/pinmux_fpv.core index b69ef24a4d80b..a375ee99ee7c3 100644 --- a/hw/top_darjeeling/ip_autogen/pinmux/fpv/pinmux_fpv.core +++ b/hw/top_darjeeling/ip_autogen/pinmux/fpv/pinmux_fpv.core @@ -16,6 +16,9 @@ filesets: files: - tb/pinmux_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_pinmux_virtual_provider)" generate: csr_assert_gen: @@ -34,6 +37,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/top_darjeeling/ip_autogen/pinmux/pinmux.core b/hw/top_darjeeling/ip_autogen/pinmux/pinmux.core index 53c06b9133499..7216c8f81751c 100644 --- a/hw/top_darjeeling/ip_autogen/pinmux/pinmux.core +++ b/hw/top_darjeeling/ip_autogen/pinmux/pinmux.core @@ -31,6 +31,10 @@ filesets: - rtl/pinmux.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_pinmux_virtual_provider)" + files_verilator_waiver: depend: # common waivers @@ -71,6 +75,8 @@ targets: lint: <<: *default_target + filesets_append: + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true @@ -92,4 +98,5 @@ targets: formal: filesets: - files_rtl + - files_virtual_provider toplevel: pinmux_tb diff --git a/hw/top_darjeeling/ip_autogen/pwrmgr/data/top_darjeeling_pwrmgr.ipconfig.hjson b/hw/top_darjeeling/ip_autogen/pwrmgr/data/top_darjeeling_pwrmgr.ipconfig.hjson index 9a7c1dc8750ee..6e9bf616f0d28 100644 --- a/hw/top_darjeeling/ip_autogen/pwrmgr/data/top_darjeeling_pwrmgr.ipconfig.hjson +++ b/hw/top_darjeeling/ip_autogen/pwrmgr/data/top_darjeeling_pwrmgr.ipconfig.hjson @@ -76,8 +76,6 @@ NumRstReqs: 2 wait_for_external_reset: true NumRomInputs: 3 - alert_handler_instance_name: top_darjeeling_ - clkmgr_instance_name: top_darjeeling_ topname: darjeeling } } diff --git a/hw/top_darjeeling/ip_autogen/pwrmgr/dv/pwrmgr_sim.core b/hw/top_darjeeling/ip_autogen/pwrmgr/dv/pwrmgr_sim.core index 6d2a139965635..8d61d3d002929 100644 --- a/hw/top_darjeeling/ip_autogen/pwrmgr/dv/pwrmgr_sim.core +++ b/hw/top_darjeeling/ip_autogen/pwrmgr/dv/pwrmgr_sim.core @@ -17,10 +17,9 @@ filesets: - tb.sv - cov/pwrmgr_cov_bind.sv file_type: systemVerilogSource - files_top_sim: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_darjeeling_alert_handler_pkg:0.1)" - - "fileset_top ? (lowrisc:opentitan:top_darjeeling_clkmgr_pwrmgr_sva_if:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_pwrmgr_virtual_provider)" targets: sim: &sim_target @@ -28,7 +27,7 @@ targets: filesets: - files_rtl - files_dv - - files_top_sim + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/top_darjeeling/ip_autogen/pwrmgr/pwrmgr.core b/hw/top_darjeeling/ip_autogen/pwrmgr/pwrmgr.core index 9792c62ab170f..9ec597bdb39d3 100644 --- a/hw/top_darjeeling/ip_autogen/pwrmgr/pwrmgr.core +++ b/hw/top_darjeeling/ip_autogen/pwrmgr/pwrmgr.core @@ -15,9 +15,9 @@ filesets: - lowrisc:opentitan:top_darjeeling_pwrmgr_component:0.1 file_type: systemVerilogSource - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_darjeeling_alert_handler_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_pwrmgr_virtual_provider)" files_verilator_waiver: depend: @@ -61,7 +61,7 @@ targets: lint: <<: *default_target filesets_append: - - files_top_lint + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/top_darjeeling/ip_autogen/rstmgr/data/top_darjeeling_rstmgr.ipconfig.hjson b/hw/top_darjeeling/ip_autogen/rstmgr/data/top_darjeeling_rstmgr.ipconfig.hjson index 5e6bfe0e4421c..e897ff3b72ef0 100644 --- a/hw/top_darjeeling/ip_autogen/rstmgr/data/top_darjeeling_rstmgr.ipconfig.hjson +++ b/hw/top_darjeeling/ip_autogen/rstmgr/data/top_darjeeling_rstmgr.ipconfig.hjson @@ -544,8 +544,6 @@ rst_ni: lc_io_div4 export_rsts: {} with_alert_handler: true - pwrmgr_instance_name: top_darjeeling_ - alert_handler_instance_name: top_darjeeling_ topname: darjeeling } } diff --git a/hw/top_darjeeling/ip_autogen/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core b/hw/top_darjeeling/ip_autogen/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core index bf67489028e83..c415c20ce2405 100644 --- a/hw/top_darjeeling/ip_autogen/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core +++ b/hw/top_darjeeling/ip_autogen/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core @@ -20,12 +20,17 @@ filesets: - tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_rstmgr_virtual_provider)" + targets: sim: &sim_target toplevel: tb filesets: - files_rtl - files_dv + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/top_darjeeling/ip_autogen/rstmgr/dv/rstmgr_sim.core b/hw/top_darjeeling/ip_autogen/rstmgr/dv/rstmgr_sim.core index 38bb1f1ee6099..0f6a7236fc070 100644 --- a/hw/top_darjeeling/ip_autogen/rstmgr/dv/rstmgr_sim.core +++ b/hw/top_darjeeling/ip_autogen/rstmgr/dv/rstmgr_sim.core @@ -17,11 +17,9 @@ filesets: - tb.sv - cov/rstmgr_cov_bind.sv file_type: systemVerilogSource - files_top_sim: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_darjeeling_alert_handler_pkg:0.1)" - - "fileset_top ? (lowrisc:opentitan:top_darjeeling_pwrmgr_pkg:0.1)" - - "fileset_top ? (lowrisc:opentitan:top_darjeeling_pwrmgr_rstmgr_sva_if:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_rstmgr_virtual_provider)" targets: sim: &sim_target @@ -29,7 +27,7 @@ targets: filesets: - files_rtl - files_dv - - files_top_sim + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/top_darjeeling/ip_autogen/rstmgr/rstmgr.core b/hw/top_darjeeling/ip_autogen/rstmgr/rstmgr.core index e14fe3d63f097..1c9b58ed78864 100644 --- a/hw/top_darjeeling/ip_autogen/rstmgr/rstmgr.core +++ b/hw/top_darjeeling/ip_autogen/rstmgr/rstmgr.core @@ -30,10 +30,9 @@ filesets: - rtl/rstmgr.sv file_type: systemVerilogSource - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_darjeeling_alert_handler_pkg:0.1)" - - "fileset_top ? (lowrisc:opentitan:top_darjeeling_pwrmgr_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_darjeeling_rstmgr_virtual_provider)" files_verilator_waiver: depend: @@ -67,7 +66,7 @@ targets: lint: <<: *default_target filesets_append: - - files_top_lint + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/top_earlgrey/dv/top_earlgrey_flash_ctrl_sim_top.core b/hw/top_earlgrey/dv/top_earlgrey_flash_ctrl_sim_top.core deleted file mode 100644 index e47a4957d018c..0000000000000 --- a/hw/top_earlgrey/dv/top_earlgrey_flash_ctrl_sim_top.core +++ /dev/null @@ -1,40 +0,0 @@ -CAPI=2: -# Copyright lowRISC contributors (OpenTitan project). -# Licensed under the Apache License, Version 2.0, see LICENSE for details. -# SPDX-License-Identifier: Apache-2.0 -name: "lowrisc:opentitan:top_earlgrey_flash_ctrl_sim_top:0.1" -description: "Pseudo top-level for Earl Grey's flash_ctrl" -filesets: - files_rtl: - depend: - - lowrisc:opentitan:top_earlgrey_pwrmgr_pkg - - lowrisc:opentitan:top_earlgrey_flash_ctrl - files_dv: - depend: - - lowrisc:opentitan:top_earlgrey_flash_ctrl_sim - -parameters: - SYNTHESIS: - datatype: bool - paramtype: vlogdefine - -targets: - lint: - toplevel: flash_ctrl - filesets: - - files_rtl - default_tool: verilator - parameters: - - SYNTHESIS=true - tools: - verilator: - mode: lint-only - verilator_options: - - "-Wall" - - sim: - toplevel: tb - filesets: - - files_rtl - - files_dv - default_tool: vcs diff --git a/hw/top_earlgrey/dv/top_earlgrey_ast_top.core b/hw/top_earlgrey/ip/ast/top_earlgrey_ast_top.core similarity index 94% rename from hw/top_earlgrey/dv/top_earlgrey_ast_top.core rename to hw/top_earlgrey/ip/ast/top_earlgrey_ast_top.core index 2591767bfc36f..f7c80f8fbfbd2 100644 --- a/hw/top_earlgrey/dv/top_earlgrey_ast_top.core +++ b/hw/top_earlgrey/ip/ast/top_earlgrey_ast_top.core @@ -11,6 +11,7 @@ filesets: - lowrisc:opentitan:top_earlgrey_clkmgr_pkg - lowrisc:opentitan:top_earlgrey_pwrmgr_pkg - lowrisc:opentitan:top_earlgrey_rstmgr_pkg + - lowrisc:opentitan:top_earlgrey_pinmux_pkg - lowrisc:systems:top_earlgrey_ast parameters: diff --git a/hw/top_earlgrey/ip_autogen/alert_handler/alert_handler.core b/hw/top_earlgrey/ip_autogen/alert_handler/alert_handler.core index 1e80faadc2023..4ea8dbbf90281 100644 --- a/hw/top_earlgrey/ip_autogen/alert_handler/alert_handler.core +++ b/hw/top_earlgrey/ip_autogen/alert_handler/alert_handler.core @@ -13,6 +13,9 @@ filesets: - lowrisc:opentitan:top_earlgrey_alert_handler_component:0.1 - lowrisc:opentitan:top_earlgrey_alert_handler_reg:0.1 file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_alert_handler_virtual_provider)" parameters: SYNTHESIS: @@ -28,6 +31,8 @@ targets: lint: <<: *default_target + filesets_append: + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/top_earlgrey/ip_autogen/alert_handler/dv/alert_handler_sim.core b/hw/top_earlgrey/ip_autogen/alert_handler/dv/alert_handler_sim.core index 3fcb58c848f13..3fbb1573f9353 100644 --- a/hw/top_earlgrey/ip_autogen/alert_handler/dv/alert_handler_sim.core +++ b/hw/top_earlgrey/ip_autogen/alert_handler/dv/alert_handler_sim.core @@ -18,6 +18,10 @@ filesets: - lowrisc:opentitan:top_earlgrey_alert_handler_sva:0.1 file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_alert_handler_virtual_provider)" + generate: ral: generator: ralgen @@ -31,6 +35,7 @@ targets: filesets: - files_rtl - files_dv + - files_virtual_provider generate: - ral default_tool: vcs diff --git a/hw/top_earlgrey/ip_autogen/alert_handler/fpv/alert_handler_esc_timer_fpv.core b/hw/top_earlgrey/ip_autogen/alert_handler/fpv/alert_handler_esc_timer_fpv.core index abdcd1f4cfd63..17ec80ec18ccd 100644 --- a/hw/top_earlgrey/ip_autogen/alert_handler/fpv/alert_handler_esc_timer_fpv.core +++ b/hw/top_earlgrey/ip_autogen/alert_handler/fpv/alert_handler_esc_timer_fpv.core @@ -14,6 +14,9 @@ filesets: - tb/alert_handler_esc_timer_bind_fpv.sv - tb/alert_handler_esc_timer_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_alert_handler_virtual_provider)" targets: default: &default_target @@ -26,6 +29,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/top_earlgrey/ip_autogen/alert_handler/fpv/alert_handler_ping_timer_fpv.core b/hw/top_earlgrey/ip_autogen/alert_handler/fpv/alert_handler_ping_timer_fpv.core index 354bd11a23cc3..6e34f285a7f34 100644 --- a/hw/top_earlgrey/ip_autogen/alert_handler/fpv/alert_handler_ping_timer_fpv.core +++ b/hw/top_earlgrey/ip_autogen/alert_handler/fpv/alert_handler_ping_timer_fpv.core @@ -14,6 +14,9 @@ filesets: - tb/alert_handler_ping_timer_bind_fpv.sv - tb/alert_handler_ping_timer_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_alert_handler_virtual_provider)" targets: default: &default_target @@ -26,6 +29,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/top_earlgrey/ip_autogen/clkmgr/clkmgr.core b/hw/top_earlgrey/ip_autogen/clkmgr/clkmgr.core index 86f43359442ae..d84de45028674 100644 --- a/hw/top_earlgrey/ip_autogen/clkmgr/clkmgr.core +++ b/hw/top_earlgrey/ip_autogen/clkmgr/clkmgr.core @@ -33,9 +33,9 @@ filesets: - rtl/clkmgr_trans.sv file_type: systemVerilogSource - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_earlgrey_pwrmgr_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_clkmgr_virtual_provider)" files_verilator_waiver: depend: @@ -68,7 +68,7 @@ targets: lint: <<: *default_target filesets_append: - - files_top_lint + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/top_earlgrey/ip_autogen/clkmgr/data/top_earlgrey_clkmgr.ipconfig.hjson b/hw/top_earlgrey/ip_autogen/clkmgr/data/top_earlgrey_clkmgr.ipconfig.hjson index 6cb9e59ffaf7d..d2ef41314064d 100644 --- a/hw/top_earlgrey/ip_autogen/clkmgr/data/top_earlgrey_clkmgr.ipconfig.hjson +++ b/hw/top_earlgrey/ip_autogen/clkmgr/data/top_earlgrey_clkmgr.ipconfig.hjson @@ -259,7 +259,6 @@ exported_clks: {} number_of_clock_groups: 7 with_alert_handler: true - pwrmgr_instance_name: top_earlgrey_ topname: earlgrey } } diff --git a/hw/top_earlgrey/ip_autogen/clkmgr/dv/clkmgr_sim.core b/hw/top_earlgrey/ip_autogen/clkmgr/dv/clkmgr_sim.core index fde2c0651f1ae..6c6a3a5403cab 100644 --- a/hw/top_earlgrey/ip_autogen/clkmgr/dv/clkmgr_sim.core +++ b/hw/top_earlgrey/ip_autogen/clkmgr/dv/clkmgr_sim.core @@ -18,9 +18,9 @@ filesets: - cov/clkmgr_cov_bind.sv file_type: systemVerilogSource - files_top_sim: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_earlgrey_pwrmgr_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_clkmgr_virtual_provider)" targets: sim: &sim_target @@ -28,7 +28,7 @@ targets: filesets: - files_rtl - files_dv - - files_top_sim + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/top_earlgrey/ip_autogen/flash_ctrl/data/top_earlgrey_flash_ctrl.ipconfig.hjson b/hw/top_earlgrey/ip_autogen/flash_ctrl/data/top_earlgrey_flash_ctrl.ipconfig.hjson index 2a109eaf2e67a..1298910a223ec 100644 --- a/hw/top_earlgrey/ip_autogen/flash_ctrl/data/top_earlgrey_flash_ctrl.ipconfig.hjson +++ b/hw/top_earlgrey/ip_autogen/flash_ctrl/data/top_earlgrey_flash_ctrl.ipconfig.hjson @@ -23,7 +23,6 @@ bytes_per_page: 2048 bytes_per_bank: 524288 size: 1048576 - pwrmgr_instance_name: top_earlgrey_ topname: earlgrey } } diff --git a/hw/top_earlgrey/ip_autogen/flash_ctrl/dv/flash_ctrl_sim.core b/hw/top_earlgrey/ip_autogen/flash_ctrl/dv/flash_ctrl_sim.core index 2ef5cf57bd6d3..7045f94f21a9f 100644 --- a/hw/top_earlgrey/ip_autogen/flash_ctrl/dv/flash_ctrl_sim.core +++ b/hw/top_earlgrey/ip_autogen/flash_ctrl/dv/flash_ctrl_sim.core @@ -22,9 +22,9 @@ filesets: - tb/tb.sv file_type: systemVerilogSource - files_top_sim: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_earlgrey_pwrmgr_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_flash_ctrl_virtual_provider)" targets: default: &default_target @@ -36,10 +36,10 @@ targets: sim: <<: *default_target filesets_append: - - files_top_sim + - files_virtual_provider default_tool: vcs lint: <<: *default_target filesets_append: - - files_top_sim + - files_virtual_provider diff --git a/hw/top_earlgrey/ip_autogen/flash_ctrl/flash_ctrl.core b/hw/top_earlgrey/ip_autogen/flash_ctrl/flash_ctrl.core index 6918ebd7426c0..e724fd61544bf 100644 --- a/hw/top_earlgrey/ip_autogen/flash_ctrl/flash_ctrl.core +++ b/hw/top_earlgrey/ip_autogen/flash_ctrl/flash_ctrl.core @@ -46,9 +46,9 @@ filesets: - rtl/flash_phy_scramble.sv file_type: systemVerilogSource - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_earlgrey_pwrmgr_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_flash_ctrl_virtual_provider)" files_verilator_waiver: depend: @@ -92,7 +92,7 @@ targets: lint: <<: *default_target filesets_append: - - files_top_lint + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/top_earlgrey/ip_autogen/pinmux/fpv/pinmux_chip_fpv.core b/hw/top_earlgrey/ip_autogen/pinmux/fpv/pinmux_chip_fpv.core index 921efb177462e..8f64a38f8cfa0 100644 --- a/hw/top_earlgrey/ip_autogen/pinmux/fpv/pinmux_chip_fpv.core +++ b/hw/top_earlgrey/ip_autogen/pinmux/fpv/pinmux_chip_fpv.core @@ -20,6 +20,9 @@ filesets: files: - tb/pinmux_chip_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_pinmux_virtual_provider)" generate: csr_assert_gen: @@ -38,6 +41,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/top_earlgrey/ip_autogen/pinmux/fpv/pinmux_fpv.core b/hw/top_earlgrey/ip_autogen/pinmux/fpv/pinmux_fpv.core index 91de43b71ffa8..bc680f30f6714 100644 --- a/hw/top_earlgrey/ip_autogen/pinmux/fpv/pinmux_fpv.core +++ b/hw/top_earlgrey/ip_autogen/pinmux/fpv/pinmux_fpv.core @@ -16,6 +16,9 @@ filesets: files: - tb/pinmux_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_pinmux_virtual_provider)" generate: csr_assert_gen: @@ -34,6 +37,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/top_earlgrey/ip_autogen/pinmux/pinmux.core b/hw/top_earlgrey/ip_autogen/pinmux/pinmux.core index a9882615b1e0a..5f2d4292634bb 100644 --- a/hw/top_earlgrey/ip_autogen/pinmux/pinmux.core +++ b/hw/top_earlgrey/ip_autogen/pinmux/pinmux.core @@ -32,6 +32,10 @@ filesets: - rtl/pinmux.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_pinmux_virtual_provider)" + files_verilator_waiver: depend: # common waivers @@ -72,6 +76,8 @@ targets: lint: <<: *default_target + filesets_append: + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true @@ -93,4 +99,5 @@ targets: formal: filesets: - files_rtl + - files_virtual_provider toplevel: pinmux_tb diff --git a/hw/top_earlgrey/ip_autogen/pwrmgr/data/top_earlgrey_pwrmgr.ipconfig.hjson b/hw/top_earlgrey/ip_autogen/pwrmgr/data/top_earlgrey_pwrmgr.ipconfig.hjson index 085dbf58bb138..d19e0f97e07ff 100644 --- a/hw/top_earlgrey/ip_autogen/pwrmgr/data/top_earlgrey_pwrmgr.ipconfig.hjson +++ b/hw/top_earlgrey/ip_autogen/pwrmgr/data/top_earlgrey_pwrmgr.ipconfig.hjson @@ -81,8 +81,6 @@ NumRstReqs: 2 wait_for_external_reset: false NumRomInputs: 1 - alert_handler_instance_name: top_earlgrey_ - clkmgr_instance_name: top_earlgrey_ topname: earlgrey } } diff --git a/hw/top_earlgrey/ip_autogen/pwrmgr/dv/pwrmgr_sim.core b/hw/top_earlgrey/ip_autogen/pwrmgr/dv/pwrmgr_sim.core index 9694595a9e5f3..c9bc62789961f 100644 --- a/hw/top_earlgrey/ip_autogen/pwrmgr/dv/pwrmgr_sim.core +++ b/hw/top_earlgrey/ip_autogen/pwrmgr/dv/pwrmgr_sim.core @@ -17,10 +17,9 @@ filesets: - tb.sv - cov/pwrmgr_cov_bind.sv file_type: systemVerilogSource - files_top_sim: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_earlgrey_alert_handler_pkg:0.1)" - - "fileset_top ? (lowrisc:opentitan:top_earlgrey_clkmgr_pwrmgr_sva_if:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_pwrmgr_virtual_provider)" targets: sim: &sim_target @@ -28,7 +27,7 @@ targets: filesets: - files_rtl - files_dv - - files_top_sim + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/top_earlgrey/ip_autogen/pwrmgr/pwrmgr.core b/hw/top_earlgrey/ip_autogen/pwrmgr/pwrmgr.core index a2c5aecad7d93..bfad87fc66f32 100644 --- a/hw/top_earlgrey/ip_autogen/pwrmgr/pwrmgr.core +++ b/hw/top_earlgrey/ip_autogen/pwrmgr/pwrmgr.core @@ -15,9 +15,9 @@ filesets: - lowrisc:opentitan:top_earlgrey_pwrmgr_component:0.1 file_type: systemVerilogSource - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_earlgrey_alert_handler_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_pwrmgr_virtual_provider)" files_verilator_waiver: depend: @@ -61,7 +61,7 @@ targets: lint: <<: *default_target filesets_append: - - files_top_lint + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/top_earlgrey/ip_autogen/rstmgr/data/top_earlgrey_rstmgr.ipconfig.hjson b/hw/top_earlgrey/ip_autogen/rstmgr/data/top_earlgrey_rstmgr.ipconfig.hjson index 9210ae5f22ed3..2a94324782441 100644 --- a/hw/top_earlgrey/ip_autogen/rstmgr/data/top_earlgrey_rstmgr.ipconfig.hjson +++ b/hw/top_earlgrey/ip_autogen/rstmgr/data/top_earlgrey_rstmgr.ipconfig.hjson @@ -691,8 +691,6 @@ rst_ni: lc_io_div4 export_rsts: {} with_alert_handler: true - pwrmgr_instance_name: top_earlgrey_ - alert_handler_instance_name: top_earlgrey_ topname: earlgrey } } diff --git a/hw/top_earlgrey/ip_autogen/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core b/hw/top_earlgrey/ip_autogen/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core index 827446a73f4c4..e0fd35939005d 100644 --- a/hw/top_earlgrey/ip_autogen/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core +++ b/hw/top_earlgrey/ip_autogen/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core @@ -20,12 +20,17 @@ filesets: - tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_rstmgr_virtual_provider)" + targets: sim: &sim_target toplevel: tb filesets: - files_rtl - files_dv + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/top_earlgrey/ip_autogen/rstmgr/dv/rstmgr_sim.core b/hw/top_earlgrey/ip_autogen/rstmgr/dv/rstmgr_sim.core index e66d672b7182d..546d3b84269b1 100644 --- a/hw/top_earlgrey/ip_autogen/rstmgr/dv/rstmgr_sim.core +++ b/hw/top_earlgrey/ip_autogen/rstmgr/dv/rstmgr_sim.core @@ -17,11 +17,9 @@ filesets: - tb.sv - cov/rstmgr_cov_bind.sv file_type: systemVerilogSource - files_top_sim: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_earlgrey_alert_handler_pkg:0.1)" - - "fileset_top ? (lowrisc:opentitan:top_earlgrey_pwrmgr_pkg:0.1)" - - "fileset_top ? (lowrisc:opentitan:top_earlgrey_pwrmgr_rstmgr_sva_if:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_rstmgr_virtual_provider)" targets: sim: &sim_target @@ -29,7 +27,7 @@ targets: filesets: - files_rtl - files_dv - - files_top_sim + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/top_earlgrey/ip_autogen/rstmgr/rstmgr.core b/hw/top_earlgrey/ip_autogen/rstmgr/rstmgr.core index 67707db194234..04a05cbf289b5 100644 --- a/hw/top_earlgrey/ip_autogen/rstmgr/rstmgr.core +++ b/hw/top_earlgrey/ip_autogen/rstmgr/rstmgr.core @@ -30,10 +30,9 @@ filesets: - rtl/rstmgr.sv file_type: systemVerilogSource - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_earlgrey_alert_handler_pkg:0.1)" - - "fileset_top ? (lowrisc:opentitan:top_earlgrey_pwrmgr_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_earlgrey_rstmgr_virtual_provider)" files_verilator_waiver: depend: @@ -67,7 +66,7 @@ targets: lint: <<: *default_target filesets_append: - - files_top_lint + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/top_earlgrey/top_earlgrey_alert_handler_virtual_provider.core b/hw/top_earlgrey/top_earlgrey_alert_handler_virtual_provider.core new file mode 100644 index 0000000000000..8a9de45f20be3 --- /dev/null +++ b/hw/top_earlgrey/top_earlgrey_alert_handler_virtual_provider.core @@ -0,0 +1,16 @@ +CAPI=2: +# Copyright lowRISC contributors (OpenTitan project). +# Licensed under the Apache License, Version 2.0, see LICENSE for details. +# SPDX-License-Identifier: Apache-2.0 +name: "lowrisc:opentitan:top_earlgrey_alert_handler_virtual_provider:0.1" +description: "Virtual core library provider for Earl Grey's alert_handler" + +filesets: + files_rtl_generic: + depend: + - lowrisc:constants:top_earlgrey_top_pkg + +targets: + default: &default_target + filesets: + - files_rtl_generic diff --git a/hw/top_earlgrey/top_earlgrey_clkmgr_virtual_provider.core b/hw/top_earlgrey/top_earlgrey_clkmgr_virtual_provider.core new file mode 100644 index 0000000000000..d767859817daa --- /dev/null +++ b/hw/top_earlgrey/top_earlgrey_clkmgr_virtual_provider.core @@ -0,0 +1,17 @@ +CAPI=2: +# Copyright lowRISC contributors (OpenTitan project). +# Licensed under the Apache License, Version 2.0, see LICENSE for details. +# SPDX-License-Identifier: Apache-2.0 +name: "lowrisc:opentitan:top_earlgrey_clkmgr_virtual_provider:0.1" +description: "Virtual core library provider for Earl Grey's clkmgr" +filesets: + files_rtl_generic: + depend: + - lowrisc:constants:top_earlgrey_top_pkg + - lowrisc:opentitan:top_earlgrey_pwrmgr_pkg + - lowrisc:opentitan:top_earlgrey_flash_ctrl + +targets: + default: &default_target + filesets: + - files_rtl_generic diff --git a/hw/top_earlgrey/top_earlgrey_flash_ctrl_virtual_provider.core b/hw/top_earlgrey/top_earlgrey_flash_ctrl_virtual_provider.core new file mode 100644 index 0000000000000..eae0ef37a6f3a --- /dev/null +++ b/hw/top_earlgrey/top_earlgrey_flash_ctrl_virtual_provider.core @@ -0,0 +1,16 @@ +CAPI=2: +# Copyright lowRISC contributors (OpenTitan project). +# Licensed under the Apache License, Version 2.0, see LICENSE for details. +# SPDX-License-Identifier: Apache-2.0 +name: "lowrisc:opentitan:top_earlgrey_flash_ctrl_virtual_provider:0.1" +description: "Virtual core library provider for Earl Grey's flash_ctrl" +filesets: + files_rtl_generic: + depend: + - lowrisc:constants:top_earlgrey_top_pkg + - lowrisc:opentitan:top_earlgrey_pwrmgr_pkg + +targets: + default: &default_target + filesets: + - files_rtl_generic diff --git a/hw/top_earlgrey/top_earlgrey_pinmux_virtual_provider.core b/hw/top_earlgrey/top_earlgrey_pinmux_virtual_provider.core new file mode 100644 index 0000000000000..073e2a4e2d369 --- /dev/null +++ b/hw/top_earlgrey/top_earlgrey_pinmux_virtual_provider.core @@ -0,0 +1,15 @@ +CAPI=2: +# Copyright lowRISC contributors (OpenTitan project). +# Licensed under the Apache License, Version 2.0, see LICENSE for details. +# SPDX-License-Identifier: Apache-2.0 +name: "lowrisc:opentitan:top_earlgrey_pinmux_virtual_provider:0.1" +description: "Virtual core library provider for Earl Grey's pinmux" +filesets: + files_rtl_generic: + depend: + - lowrisc:constants:top_earlgrey_top_pkg + +targets: + default: &default_target + filesets: + - files_rtl_generic diff --git a/hw/top_earlgrey/top_earlgrey_pwrmgr_virtual_provider.core b/hw/top_earlgrey/top_earlgrey_pwrmgr_virtual_provider.core new file mode 100644 index 0000000000000..73b13f920f861 --- /dev/null +++ b/hw/top_earlgrey/top_earlgrey_pwrmgr_virtual_provider.core @@ -0,0 +1,17 @@ +CAPI=2: +# Copyright lowRISC contributors (OpenTitan project). +# Licensed under the Apache License, Version 2.0, see LICENSE for details. +# SPDX-License-Identifier: Apache-2.0 +name: "lowrisc:opentitan:top_earlgrey_pwrmgr_virtual_provider:0.1" +description: "Virtual core library provider for Earl Grey's pwrmgr" +filesets: + files_rtl_generic: + depend: + - lowrisc:constants:top_earlgrey_top_pkg + - lowrisc:opentitan:top_earlgrey_alert_handler_pkg + - lowrisc:opentitan:top_earlgrey_clkmgr_pwrmgr_sva_if + +targets: + default: &default_target + filesets: + - files_rtl_generic diff --git a/hw/top_earlgrey/top_earlgrey_rstmgr_virtual_provider.core b/hw/top_earlgrey/top_earlgrey_rstmgr_virtual_provider.core new file mode 100644 index 0000000000000..a9d8026ef06c8 --- /dev/null +++ b/hw/top_earlgrey/top_earlgrey_rstmgr_virtual_provider.core @@ -0,0 +1,18 @@ +CAPI=2: +# Copyright lowRISC contributors (OpenTitan project). +# Licensed under the Apache License, Version 2.0, see LICENSE for details. +# SPDX-License-Identifier: Apache-2.0 +name: "lowrisc:opentitan:top_earlgrey_rstmgr_virtual_provider:0.1" +description: "Virtual core library provider for Earl Grey's rstmgr" +filesets: + files_rtl_generic: + depend: + - lowrisc:constants:top_earlgrey_top_pkg + - lowrisc:opentitan:top_earlgrey_alert_handler_pkg + - lowrisc:opentitan:top_earlgrey_pwrmgr_pkg + - lowrisc:opentitan:top_earlgrey_pwrmgr_rstmgr_sva_if + +targets: + default: &default_target + filesets: + - files_rtl_generic diff --git a/hw/top_englishbreakfast/ip_autogen/clkmgr/clkmgr.core b/hw/top_englishbreakfast/ip_autogen/clkmgr/clkmgr.core index 0588cafcce347..e4104daaa1db2 100644 --- a/hw/top_englishbreakfast/ip_autogen/clkmgr/clkmgr.core +++ b/hw/top_englishbreakfast/ip_autogen/clkmgr/clkmgr.core @@ -33,9 +33,9 @@ filesets: - rtl/clkmgr_trans.sv file_type: systemVerilogSource - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_pwrmgr_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_clkmgr_virtual_provider)" files_verilator_waiver: depend: @@ -68,7 +68,7 @@ targets: lint: <<: *default_target filesets_append: - - files_top_lint + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/top_englishbreakfast/ip_autogen/clkmgr/data/top_englishbreakfast_clkmgr.ipconfig.hjson b/hw/top_englishbreakfast/ip_autogen/clkmgr/data/top_englishbreakfast_clkmgr.ipconfig.hjson index c272dd834b45b..c8aa95e9d0a06 100644 --- a/hw/top_englishbreakfast/ip_autogen/clkmgr/data/top_englishbreakfast_clkmgr.ipconfig.hjson +++ b/hw/top_englishbreakfast/ip_autogen/clkmgr/data/top_englishbreakfast_clkmgr.ipconfig.hjson @@ -236,7 +236,6 @@ exported_clks: {} number_of_clock_groups: 8 with_alert_handler: false - pwrmgr_instance_name: top_englishbreakfast_ topname: englishbreakfast } } diff --git a/hw/top_englishbreakfast/ip_autogen/clkmgr/dv/clkmgr_sim.core b/hw/top_englishbreakfast/ip_autogen/clkmgr/dv/clkmgr_sim.core index 7cbf3b11b39a0..bf3f21c8789a3 100644 --- a/hw/top_englishbreakfast/ip_autogen/clkmgr/dv/clkmgr_sim.core +++ b/hw/top_englishbreakfast/ip_autogen/clkmgr/dv/clkmgr_sim.core @@ -18,9 +18,9 @@ filesets: - cov/clkmgr_cov_bind.sv file_type: systemVerilogSource - files_top_sim: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_pwrmgr_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_clkmgr_virtual_provider)" targets: sim: &sim_target @@ -28,7 +28,7 @@ targets: filesets: - files_rtl - files_dv - - files_top_sim + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/top_englishbreakfast/ip_autogen/flash_ctrl/data/top_englishbreakfast_flash_ctrl.ipconfig.hjson b/hw/top_englishbreakfast/ip_autogen/flash_ctrl/data/top_englishbreakfast_flash_ctrl.ipconfig.hjson index 9ff864170933b..166b6e1c02cc6 100644 --- a/hw/top_englishbreakfast/ip_autogen/flash_ctrl/data/top_englishbreakfast_flash_ctrl.ipconfig.hjson +++ b/hw/top_englishbreakfast/ip_autogen/flash_ctrl/data/top_englishbreakfast_flash_ctrl.ipconfig.hjson @@ -23,7 +23,6 @@ bytes_per_page: 2048 bytes_per_bank: 32768 size: 65536 - pwrmgr_instance_name: top_englishbreakfast_ topname: englishbreakfast } } diff --git a/hw/top_englishbreakfast/ip_autogen/flash_ctrl/dv/flash_ctrl_sim.core b/hw/top_englishbreakfast/ip_autogen/flash_ctrl/dv/flash_ctrl_sim.core index d0c35710b30a8..a67c45548ae8a 100644 --- a/hw/top_englishbreakfast/ip_autogen/flash_ctrl/dv/flash_ctrl_sim.core +++ b/hw/top_englishbreakfast/ip_autogen/flash_ctrl/dv/flash_ctrl_sim.core @@ -22,9 +22,9 @@ filesets: - tb/tb.sv file_type: systemVerilogSource - files_top_sim: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_pwrmgr_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_flash_ctrl_virtual_provider)" targets: default: &default_target @@ -36,10 +36,10 @@ targets: sim: <<: *default_target filesets_append: - - files_top_sim + - files_virtual_provider default_tool: vcs lint: <<: *default_target filesets_append: - - files_top_sim + - files_virtual_provider diff --git a/hw/top_englishbreakfast/ip_autogen/flash_ctrl/flash_ctrl.core b/hw/top_englishbreakfast/ip_autogen/flash_ctrl/flash_ctrl.core index 4dcae766ea9d9..dd713465de698 100644 --- a/hw/top_englishbreakfast/ip_autogen/flash_ctrl/flash_ctrl.core +++ b/hw/top_englishbreakfast/ip_autogen/flash_ctrl/flash_ctrl.core @@ -46,9 +46,9 @@ filesets: - rtl/flash_phy_scramble.sv file_type: systemVerilogSource - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_pwrmgr_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_flash_ctrl_virtual_provider)" files_verilator_waiver: depend: @@ -92,7 +92,7 @@ targets: lint: <<: *default_target filesets_append: - - files_top_lint + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/top_englishbreakfast/ip_autogen/pinmux/fpv/pinmux_chip_fpv.core b/hw/top_englishbreakfast/ip_autogen/pinmux/fpv/pinmux_chip_fpv.core index f28ad749376f4..5f1651a1f8429 100644 --- a/hw/top_englishbreakfast/ip_autogen/pinmux/fpv/pinmux_chip_fpv.core +++ b/hw/top_englishbreakfast/ip_autogen/pinmux/fpv/pinmux_chip_fpv.core @@ -20,6 +20,9 @@ filesets: files: - tb/pinmux_chip_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_pinmux_virtual_provider)" generate: csr_assert_gen: @@ -38,6 +41,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/top_englishbreakfast/ip_autogen/pinmux/fpv/pinmux_fpv.core b/hw/top_englishbreakfast/ip_autogen/pinmux/fpv/pinmux_fpv.core index 756b1612f68fe..72c7ef4e7bb73 100644 --- a/hw/top_englishbreakfast/ip_autogen/pinmux/fpv/pinmux_fpv.core +++ b/hw/top_englishbreakfast/ip_autogen/pinmux/fpv/pinmux_fpv.core @@ -16,6 +16,9 @@ filesets: files: - tb/pinmux_tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_pinmux_virtual_provider)" generate: csr_assert_gen: @@ -34,6 +37,10 @@ targets: formal: <<: *default_target + filesets_append: + - files_virtual_provider lint: <<: *default_target + filesets_append: + - files_virtual_provider diff --git a/hw/top_englishbreakfast/ip_autogen/pinmux/pinmux.core b/hw/top_englishbreakfast/ip_autogen/pinmux/pinmux.core index d69c381ed0a68..a97eb22cebba2 100644 --- a/hw/top_englishbreakfast/ip_autogen/pinmux/pinmux.core +++ b/hw/top_englishbreakfast/ip_autogen/pinmux/pinmux.core @@ -32,6 +32,10 @@ filesets: - rtl/pinmux.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_pinmux_virtual_provider)" + files_verilator_waiver: depend: # common waivers @@ -72,6 +76,8 @@ targets: lint: <<: *default_target + filesets_append: + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true @@ -93,4 +99,5 @@ targets: formal: filesets: - files_rtl + - files_virtual_provider toplevel: pinmux_tb diff --git a/hw/top_englishbreakfast/ip_autogen/pwrmgr/data/top_englishbreakfast_pwrmgr.ipconfig.hjson b/hw/top_englishbreakfast/ip_autogen/pwrmgr/data/top_englishbreakfast_pwrmgr.ipconfig.hjson index 0683872adda48..a69c00c1928ba 100644 --- a/hw/top_englishbreakfast/ip_autogen/pwrmgr/data/top_englishbreakfast_pwrmgr.ipconfig.hjson +++ b/hw/top_englishbreakfast/ip_autogen/pwrmgr/data/top_englishbreakfast_pwrmgr.ipconfig.hjson @@ -60,8 +60,6 @@ NumRstReqs: 1 wait_for_external_reset: false NumRomInputs: 1 - alert_handler_instance_name: top_englishbreakfast_ - clkmgr_instance_name: top_englishbreakfast_ topname: englishbreakfast } } diff --git a/hw/top_englishbreakfast/ip_autogen/pwrmgr/dv/pwrmgr_sim.core b/hw/top_englishbreakfast/ip_autogen/pwrmgr/dv/pwrmgr_sim.core index 6e7f7bfdb874b..3919f062fd63a 100644 --- a/hw/top_englishbreakfast/ip_autogen/pwrmgr/dv/pwrmgr_sim.core +++ b/hw/top_englishbreakfast/ip_autogen/pwrmgr/dv/pwrmgr_sim.core @@ -17,10 +17,9 @@ filesets: - tb.sv - cov/pwrmgr_cov_bind.sv file_type: systemVerilogSource - files_top_sim: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_alert_handler_pkg:0.1)" - - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_clkmgr_pwrmgr_sva_if:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_pwrmgr_virtual_provider)" targets: sim: &sim_target @@ -28,7 +27,7 @@ targets: filesets: - files_rtl - files_dv - - files_top_sim + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/top_englishbreakfast/ip_autogen/pwrmgr/pwrmgr.core b/hw/top_englishbreakfast/ip_autogen/pwrmgr/pwrmgr.core index 5bd6c18ebfb9e..4e830b37338fb 100644 --- a/hw/top_englishbreakfast/ip_autogen/pwrmgr/pwrmgr.core +++ b/hw/top_englishbreakfast/ip_autogen/pwrmgr/pwrmgr.core @@ -15,9 +15,9 @@ filesets: - lowrisc:opentitan:top_englishbreakfast_pwrmgr_component:0.1 file_type: systemVerilogSource - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_alert_handler_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_pwrmgr_virtual_provider)" files_verilator_waiver: depend: @@ -61,7 +61,7 @@ targets: lint: <<: *default_target filesets_append: - - files_top_lint + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/hw/top_englishbreakfast/ip_autogen/rstmgr/data/top_englishbreakfast_rstmgr.ipconfig.hjson b/hw/top_englishbreakfast/ip_autogen/rstmgr/data/top_englishbreakfast_rstmgr.ipconfig.hjson index f7bfe59d1c1d3..e4c88bb28c18d 100644 --- a/hw/top_englishbreakfast/ip_autogen/rstmgr/data/top_englishbreakfast_rstmgr.ipconfig.hjson +++ b/hw/top_englishbreakfast/ip_autogen/rstmgr/data/top_englishbreakfast_rstmgr.ipconfig.hjson @@ -451,7 +451,6 @@ rst_ni: lc_io_div4 export_rsts: {} with_alert_handler: false - pwrmgr_instance_name: top_englishbreakfast_ topname: englishbreakfast } } diff --git a/hw/top_englishbreakfast/ip_autogen/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core b/hw/top_englishbreakfast/ip_autogen/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core index d6fa3b19a7431..e079b7ac3feca 100644 --- a/hw/top_englishbreakfast/ip_autogen/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core +++ b/hw/top_englishbreakfast/ip_autogen/rstmgr/dv/rstmgr_cnsty_chk/rstmgr_cnsty_chk_sim.core @@ -20,12 +20,17 @@ filesets: - tb.sv file_type: systemVerilogSource + files_virtual_provider: + depend: + - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_rstmgr_virtual_provider)" + targets: sim: &sim_target toplevel: tb filesets: - files_rtl - files_dv + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/top_englishbreakfast/ip_autogen/rstmgr/dv/rstmgr_sim.core b/hw/top_englishbreakfast/ip_autogen/rstmgr/dv/rstmgr_sim.core index 09ce2429465a9..0d77611058e8b 100644 --- a/hw/top_englishbreakfast/ip_autogen/rstmgr/dv/rstmgr_sim.core +++ b/hw/top_englishbreakfast/ip_autogen/rstmgr/dv/rstmgr_sim.core @@ -17,10 +17,9 @@ filesets: - tb.sv - cov/rstmgr_cov_bind.sv file_type: systemVerilogSource - files_top_sim: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_pwrmgr_pkg:0.1)" - - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_pwrmgr_rstmgr_sva_if:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_rstmgr_virtual_provider)" targets: sim: &sim_target @@ -28,7 +27,7 @@ targets: filesets: - files_rtl - files_dv - - files_top_sim + - files_virtual_provider default_tool: vcs lint: diff --git a/hw/top_englishbreakfast/ip_autogen/rstmgr/rstmgr.core b/hw/top_englishbreakfast/ip_autogen/rstmgr/rstmgr.core index 0d501b043adc8..dbba735753a25 100644 --- a/hw/top_englishbreakfast/ip_autogen/rstmgr/rstmgr.core +++ b/hw/top_englishbreakfast/ip_autogen/rstmgr/rstmgr.core @@ -30,9 +30,9 @@ filesets: - rtl/rstmgr.sv file_type: systemVerilogSource - files_top_lint: + files_virtual_provider: depend: - - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_pwrmgr_pkg:0.1)" + - "fileset_top ? (lowrisc:opentitan:top_englishbreakfast_rstmgr_virtual_provider)" files_verilator_waiver: depend: @@ -66,7 +66,7 @@ targets: lint: <<: *default_target filesets_append: - - files_top_lint + - files_virtual_provider default_tool: verilator parameters: - SYNTHESIS=true diff --git a/util/topgen.py b/util/topgen.py index 8cabee966f474..5f3deb79931fe 100755 --- a/util/topgen.py +++ b/util/topgen.py @@ -356,7 +356,7 @@ def generate_pinmux(top: Dict[str, object], out_path: Path) -> None: "n_dio_periph_in": n_dio_periph_in, "n_dio_periph_out": n_dio_periph_out, "enable_usb_wakeup": pinmux['enable_usb_wakeup'], - "enable_strap_sampling": pinmux['enable_strap_sampling'] + "enable_strap_sampling": pinmux['enable_strap_sampling'], } ipgen_render("pinmux", topname, params, out_path) @@ -393,7 +393,6 @@ def generate_clkmgr(topcfg: Dict[str, object], out_path: Path) -> None: "exported_clks": topcfg["exported_clks"], "number_of_clock_groups": len(clocks.groups), "with_alert_handler": with_alert_handler, - "pwrmgr_instance_name": f"top_{topname}_", } ipgen_render("clkmgr", topname, params, out_path) @@ -435,8 +434,6 @@ def generate_pwrmgr(top: Dict[str, object], out_path: Path) -> None: "NumRstReqs": n_rstreqs, "wait_for_external_reset": top['power']['wait_for_external_reset'], "NumRomInputs": n_rom_ctrl, - "alert_handler_instance_name": f"top_{topname}_", - "clkmgr_instance_name": f"top_{topname}_", } ipgen_render("pwrmgr", topname, params, out_path) @@ -490,10 +487,7 @@ def generate_rstmgr(topcfg: Dict[str, object], out_path: Path) -> None: "rst_ni": rst_ni['rst_ni']['name'], "export_rsts": topcfg["exported_rsts"], "with_alert_handler": with_alert_handler, - "pwrmgr_instance_name": f"top_{topname}_", } - if with_alert_handler: - params.update({"alert_handler_instance_name": f"top_{topname}_"}) ipgen_render("rstmgr", topname, params, out_path) @@ -520,7 +514,6 @@ def generate_flash(topcfg: Dict[str, object], out_path: Path) -> None: "metadata_width": 12, "info_types": 3, "infos_per_bank": [10, 1, 2], - "pwrmgr_instance_name": f"top_{topname}_", }) params.pop('base_addrs', None)