From 7ae3ea51307836911f29f4f3dafca086aa20f217 Mon Sep 17 00:00:00 2001 From: Alexander Williams Date: Fri, 27 Dec 2024 08:33:15 -0800 Subject: [PATCH] [englishbreakfast,clkmgr,rstmgr] Fix up docs for lint Symlink all required files for shared IPs. Conditionally generate alert_handler cross-reference links for clkmgr and rstmgr, depending on whether a top actually has an alert_handler. This should fix lint failures. Signed-off-by: Alexander Williams --- hw/ip_templates/clkmgr/data/clkmgr.tpldesc.hjson | 6 ++++++ ...y_of_operation.md => theory_of_operation.md.tpl} | 13 +++++++++---- hw/ip_templates/rstmgr/data/rstmgr.tpldesc.hjson | 6 ++++++ ...y_of_operation.md => theory_of_operation.md.tpl} | 11 ++++++++--- .../data/top_darjeeling_clkmgr.ipconfig.hjson | 1 + .../ip_autogen/clkmgr/doc/theory_of_operation.md | 2 +- .../data/top_darjeeling_rstmgr.ipconfig.hjson | 1 + .../clkmgr/data/top_earlgrey_clkmgr.ipconfig.hjson | 1 + .../ip_autogen/clkmgr/doc/theory_of_operation.md | 2 +- .../rstmgr/data/top_earlgrey_rstmgr.ipconfig.hjson | 1 + hw/top_englishbreakfast/README.md | 3 +++ hw/top_englishbreakfast/ip/ast/README.md | 1 + hw/top_englishbreakfast/ip/ast/ast_regs.html | 1 + hw/top_englishbreakfast/ip/ast/data | 1 + hw/top_englishbreakfast/ip/ast/data/ast.hjson | 1 - hw/top_englishbreakfast/ip/ast/doc | 1 + hw/top_englishbreakfast/ip/sensor_ctrl/README.md | 1 + hw/top_englishbreakfast/ip/sensor_ctrl/data | 1 + .../ip/sensor_ctrl/data/sensor_ctrl.hjson | 1 - hw/top_englishbreakfast/ip/sensor_ctrl/doc | 1 + .../data/top_englishbreakfast_clkmgr.ipconfig.hjson | 1 + .../ip_autogen/clkmgr/doc/theory_of_operation.md | 7 +------ .../data/top_englishbreakfast_rstmgr.ipconfig.hjson | 1 + .../ip_autogen/rstmgr/doc/theory_of_operation.md | 5 ----- util/topgen.py | 13 +++++++++++-- 25 files changed, 59 insertions(+), 24 deletions(-) rename hw/ip_templates/clkmgr/doc/{theory_of_operation.md => theory_of_operation.md.tpl} (98%) rename hw/ip_templates/rstmgr/doc/{theory_of_operation.md => theory_of_operation.md.tpl} (99%) create mode 100644 hw/top_englishbreakfast/README.md create mode 120000 hw/top_englishbreakfast/ip/ast/README.md create mode 120000 hw/top_englishbreakfast/ip/ast/ast_regs.html create mode 120000 hw/top_englishbreakfast/ip/ast/data delete mode 120000 hw/top_englishbreakfast/ip/ast/data/ast.hjson create mode 120000 hw/top_englishbreakfast/ip/ast/doc create mode 120000 hw/top_englishbreakfast/ip/sensor_ctrl/README.md create mode 120000 hw/top_englishbreakfast/ip/sensor_ctrl/data delete mode 120000 hw/top_englishbreakfast/ip/sensor_ctrl/data/sensor_ctrl.hjson create mode 120000 hw/top_englishbreakfast/ip/sensor_ctrl/doc diff --git a/hw/ip_templates/clkmgr/data/clkmgr.tpldesc.hjson b/hw/ip_templates/clkmgr/data/clkmgr.tpldesc.hjson index 3439356a33eba..7a8d2f77fe2a4 100644 --- a/hw/ip_templates/clkmgr/data/clkmgr.tpldesc.hjson +++ b/hw/ip_templates/clkmgr/data/clkmgr.tpldesc.hjson @@ -86,5 +86,11 @@ type: "int" default: "2" } + { + name: "with_alert_handler" + desc: "Generate outputs for a clkmgr that would connect to an alert handler" + type: "bool" + default: "1" + } ] } diff --git a/hw/ip_templates/clkmgr/doc/theory_of_operation.md b/hw/ip_templates/clkmgr/doc/theory_of_operation.md.tpl similarity index 98% rename from hw/ip_templates/clkmgr/doc/theory_of_operation.md rename to hw/ip_templates/clkmgr/doc/theory_of_operation.md.tpl index 5d81a4805fda5..997e2c11e7f60 100644 --- a/hw/ip_templates/clkmgr/doc/theory_of_operation.md +++ b/hw/ip_templates/clkmgr/doc/theory_of_operation.md.tpl @@ -1,4 +1,4 @@ -# Theory of Operation +<%text filter="n"># Theory of Operation Clock management in OpenTitan is divided into groups. Each group has specific attributes and controls whether software is allowed to influence individual clocks during the active power state. @@ -98,7 +98,7 @@ The controls can also be individual to each peripheral. ## Wait-for-Interrupt (wfi) Gating -Wait-for-interrupt clock gating refers to the mechanism of using a processor’s sleep indication to actively gate off module clocks. +Wait-for-interrupt clock gating refers to the mechanism of using a processor's sleep indication to actively gate off module clocks. Of the groups enumerated, only transactional, infrastructural and peripheral groups can be influenced by `wfi`. As `wfi` is effectively a processor clock request, there are subtleties related to its use. @@ -156,12 +156,16 @@ For a detailed breakdown between `por` and `life cycle` resets, please see the [ The following diagram enhances the block diagram to illustrate the overall reset domains of the clock manager. ![Clock Manager Block Diagram](clkmgr_rst_domain.svg) -### Clock Gated Indications for Alert Handler +\ +% if with_alert_handler: +<%text filter="n">### Clock Gated Indications for Alert Handler The alert handler needs to know the status of the various clock domains in the system to avoid false alert indications due to the ping mechanism. To that end, the clock manager outputs a 4bit MuBi signal for each clock domain that indicates whether its clock is active. For more information on this mechanism, see [alert handler documentation](../../alert_handler/doc/theory_of_operation.md#low-power-management-of-alert-channels). - +\ +% endif +<%text filter="n"> ## Design Details ### Root Clock Gating and Interface with Power Manager @@ -296,3 +300,4 @@ Clock too slow is registered when the clock cycle count is less than the softwar Clock time-out is registered when the clock stops toggling and the timeout threshold is reached. As these are all software supplied values, the entire measurement control can be locked from further programming through [`MEASURE_CTRL_REGWEN`](registers.md#measure_ctrl_regwen). +\ diff --git a/hw/ip_templates/rstmgr/data/rstmgr.tpldesc.hjson b/hw/ip_templates/rstmgr/data/rstmgr.tpldesc.hjson index a661847eb669f..aa1db3ea83b4f 100644 --- a/hw/ip_templates/rstmgr/data/rstmgr.tpldesc.hjson +++ b/hw/ip_templates/rstmgr/data/rstmgr.tpldesc.hjson @@ -111,5 +111,11 @@ type: "object" default: {} } + { + name: "with_alert_handler" + desc: "Generate outputs for a rstmgr that would connect to an alert handler" + type: "bool" + default: "1" + } ] } diff --git a/hw/ip_templates/rstmgr/doc/theory_of_operation.md b/hw/ip_templates/rstmgr/doc/theory_of_operation.md.tpl similarity index 99% rename from hw/ip_templates/rstmgr/doc/theory_of_operation.md rename to hw/ip_templates/rstmgr/doc/theory_of_operation.md.tpl index 39efddb0cf423..f47cd5554d132 100644 --- a/hw/ip_templates/rstmgr/doc/theory_of_operation.md +++ b/hw/ip_templates/rstmgr/doc/theory_of_operation.md.tpl @@ -1,4 +1,4 @@ -# Theory of Operation +<%text filter="n"># Theory of Operation The OpenTitan reset topology and reset controller block diagram are shown in the diagram below. The reset controller is closely related to the [power controller](../../pwrmgr/README.md), please refer to that spec for details on how reset controller inputs are controlled. @@ -134,12 +134,16 @@ The reset manager then checks as follows: - If all reset conditions are satisfied, wait for the reset release to gracefully complete the cycle. -### Reset Indications for Alert Handler +\ +% if with_alert_handler: +<%text filter="n">### Reset Indications for Alert Handler The alert handler needs to know the status of the various reset domains in the system to avoid false alert indications due to the ping mechanism. To that end, the reset manager outputs a 4bit MuBi signal for each reset domain that indicates whether its reset is active. For more information on this mechanism, see [alert handler documentation](../../alert_handler/doc/theory_of_operation.md#low-power-management-of-alert-channels). - +\ +% endif +<%text filter="n"> ## Design Details The reset manager generates the resets required by the system by synchronizing reset tree components to appropriate output clocks. @@ -308,3 +312,4 @@ For more details on the CPU dump details, please see [crash dump](../../../../ip The [`CPU_INFO_ATTR`](registers.md#cpu_info_attr) register indicates how many 32-bit data segments must be read. Software then simply needs to write in [`CPU_INFO_CTRL.INDEX`](registers.md#cpu_info_ctrl) which segment it wishes and then read out the [`CPU_INFO`](registers.md#cpu_info) register. +\ 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 03fdcf04513b5..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 @@ -248,6 +248,7 @@ } exported_clks: {} number_of_clock_groups: 7 + with_alert_handler: true topname: darjeeling } } diff --git a/hw/top_darjeeling/ip_autogen/clkmgr/doc/theory_of_operation.md b/hw/top_darjeeling/ip_autogen/clkmgr/doc/theory_of_operation.md index 5d81a4805fda5..93101dde83505 100644 --- a/hw/top_darjeeling/ip_autogen/clkmgr/doc/theory_of_operation.md +++ b/hw/top_darjeeling/ip_autogen/clkmgr/doc/theory_of_operation.md @@ -98,7 +98,7 @@ The controls can also be individual to each peripheral. ## Wait-for-Interrupt (wfi) Gating -Wait-for-interrupt clock gating refers to the mechanism of using a processor’s sleep indication to actively gate off module clocks. +Wait-for-interrupt clock gating refers to the mechanism of using a processor's sleep indication to actively gate off module clocks. Of the groups enumerated, only transactional, infrastructural and peripheral groups can be influenced by `wfi`. As `wfi` is effectively a processor clock request, there are subtleties related to its use. 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 ebf8a8bb11340..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 @@ -543,6 +543,7 @@ ] rst_ni: lc_io_div4 export_rsts: {} + with_alert_handler: true topname: darjeeling } } 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 ed8736da69ea1..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 @@ -258,6 +258,7 @@ } exported_clks: {} number_of_clock_groups: 7 + with_alert_handler: true topname: earlgrey } } diff --git a/hw/top_earlgrey/ip_autogen/clkmgr/doc/theory_of_operation.md b/hw/top_earlgrey/ip_autogen/clkmgr/doc/theory_of_operation.md index 5d81a4805fda5..93101dde83505 100644 --- a/hw/top_earlgrey/ip_autogen/clkmgr/doc/theory_of_operation.md +++ b/hw/top_earlgrey/ip_autogen/clkmgr/doc/theory_of_operation.md @@ -98,7 +98,7 @@ The controls can also be individual to each peripheral. ## Wait-for-Interrupt (wfi) Gating -Wait-for-interrupt clock gating refers to the mechanism of using a processor’s sleep indication to actively gate off module clocks. +Wait-for-interrupt clock gating refers to the mechanism of using a processor's sleep indication to actively gate off module clocks. Of the groups enumerated, only transactional, infrastructural and peripheral groups can be influenced by `wfi`. As `wfi` is effectively a processor clock request, there are subtleties related to its use. 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 92ebd2aab70df..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 @@ -690,6 +690,7 @@ ] rst_ni: lc_io_div4 export_rsts: {} + with_alert_handler: true topname: earlgrey } } diff --git a/hw/top_englishbreakfast/README.md b/hw/top_englishbreakfast/README.md new file mode 100644 index 0000000000000..57be68e407599 --- /dev/null +++ b/hw/top_englishbreakfast/README.md @@ -0,0 +1,3 @@ +# Top Englishbreakfast + +This is an experimental top intended for SCA/FI activities. diff --git a/hw/top_englishbreakfast/ip/ast/README.md b/hw/top_englishbreakfast/ip/ast/README.md new file mode 120000 index 0000000000000..332e2c80df8cb --- /dev/null +++ b/hw/top_englishbreakfast/ip/ast/README.md @@ -0,0 +1 @@ +../../../top_earlgrey/ip/ast/README.md \ No newline at end of file diff --git a/hw/top_englishbreakfast/ip/ast/ast_regs.html b/hw/top_englishbreakfast/ip/ast/ast_regs.html new file mode 120000 index 0000000000000..0159a700f534c --- /dev/null +++ b/hw/top_englishbreakfast/ip/ast/ast_regs.html @@ -0,0 +1 @@ +../../../top_earlgrey/ip/ast/ast_regs.html \ No newline at end of file diff --git a/hw/top_englishbreakfast/ip/ast/data b/hw/top_englishbreakfast/ip/ast/data new file mode 120000 index 0000000000000..3282095af6a42 --- /dev/null +++ b/hw/top_englishbreakfast/ip/ast/data @@ -0,0 +1 @@ +../../../top_earlgrey/ip/ast/data \ No newline at end of file diff --git a/hw/top_englishbreakfast/ip/ast/data/ast.hjson b/hw/top_englishbreakfast/ip/ast/data/ast.hjson deleted file mode 120000 index e161656985461..0000000000000 --- a/hw/top_englishbreakfast/ip/ast/data/ast.hjson +++ /dev/null @@ -1 +0,0 @@ -../../../../top_earlgrey/ip/ast/data/ast.hjson \ No newline at end of file diff --git a/hw/top_englishbreakfast/ip/ast/doc b/hw/top_englishbreakfast/ip/ast/doc new file mode 120000 index 0000000000000..afc94c09c5446 --- /dev/null +++ b/hw/top_englishbreakfast/ip/ast/doc @@ -0,0 +1 @@ +../../../top_earlgrey/ip/ast/doc \ No newline at end of file diff --git a/hw/top_englishbreakfast/ip/sensor_ctrl/README.md b/hw/top_englishbreakfast/ip/sensor_ctrl/README.md new file mode 120000 index 0000000000000..34b632a501fca --- /dev/null +++ b/hw/top_englishbreakfast/ip/sensor_ctrl/README.md @@ -0,0 +1 @@ +../../../top_earlgrey/ip/sensor_ctrl/README.md \ No newline at end of file diff --git a/hw/top_englishbreakfast/ip/sensor_ctrl/data b/hw/top_englishbreakfast/ip/sensor_ctrl/data new file mode 120000 index 0000000000000..0f3079bf389d3 --- /dev/null +++ b/hw/top_englishbreakfast/ip/sensor_ctrl/data @@ -0,0 +1 @@ +../../../top_earlgrey/ip/sensor_ctrl/data \ No newline at end of file diff --git a/hw/top_englishbreakfast/ip/sensor_ctrl/data/sensor_ctrl.hjson b/hw/top_englishbreakfast/ip/sensor_ctrl/data/sensor_ctrl.hjson deleted file mode 120000 index bdbb600ff862a..0000000000000 --- a/hw/top_englishbreakfast/ip/sensor_ctrl/data/sensor_ctrl.hjson +++ /dev/null @@ -1 +0,0 @@ -../../../../top_earlgrey/ip/sensor_ctrl/data/sensor_ctrl.hjson \ No newline at end of file diff --git a/hw/top_englishbreakfast/ip/sensor_ctrl/doc b/hw/top_englishbreakfast/ip/sensor_ctrl/doc new file mode 120000 index 0000000000000..1c49b4447c085 --- /dev/null +++ b/hw/top_englishbreakfast/ip/sensor_ctrl/doc @@ -0,0 +1 @@ +../../../top_earlgrey/ip/sensor_ctrl/doc \ No newline at end of file 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 afe11fb06db57..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 @@ -235,6 +235,7 @@ } exported_clks: {} number_of_clock_groups: 8 + with_alert_handler: false topname: englishbreakfast } } diff --git a/hw/top_englishbreakfast/ip_autogen/clkmgr/doc/theory_of_operation.md b/hw/top_englishbreakfast/ip_autogen/clkmgr/doc/theory_of_operation.md index 5d81a4805fda5..ae4738dfb9261 100644 --- a/hw/top_englishbreakfast/ip_autogen/clkmgr/doc/theory_of_operation.md +++ b/hw/top_englishbreakfast/ip_autogen/clkmgr/doc/theory_of_operation.md @@ -98,7 +98,7 @@ The controls can also be individual to each peripheral. ## Wait-for-Interrupt (wfi) Gating -Wait-for-interrupt clock gating refers to the mechanism of using a processor’s sleep indication to actively gate off module clocks. +Wait-for-interrupt clock gating refers to the mechanism of using a processor's sleep indication to actively gate off module clocks. Of the groups enumerated, only transactional, infrastructural and peripheral groups can be influenced by `wfi`. As `wfi` is effectively a processor clock request, there are subtleties related to its use. @@ -156,11 +156,6 @@ For a detailed breakdown between `por` and `life cycle` resets, please see the [ The following diagram enhances the block diagram to illustrate the overall reset domains of the clock manager. ![Clock Manager Block Diagram](clkmgr_rst_domain.svg) -### Clock Gated Indications for Alert Handler - -The alert handler needs to know the status of the various clock domains in the system to avoid false alert indications due to the ping mechanism. -To that end, the clock manager outputs a 4bit MuBi signal for each clock domain that indicates whether its clock is active. -For more information on this mechanism, see [alert handler documentation](../../alert_handler/doc/theory_of_operation.md#low-power-management-of-alert-channels). ## Design Details 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 8c50f8e4f218f..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 @@ -450,6 +450,7 @@ ] rst_ni: lc_io_div4 export_rsts: {} + with_alert_handler: false topname: englishbreakfast } } diff --git a/hw/top_englishbreakfast/ip_autogen/rstmgr/doc/theory_of_operation.md b/hw/top_englishbreakfast/ip_autogen/rstmgr/doc/theory_of_operation.md index 39efddb0cf423..debdd824ff459 100644 --- a/hw/top_englishbreakfast/ip_autogen/rstmgr/doc/theory_of_operation.md +++ b/hw/top_englishbreakfast/ip_autogen/rstmgr/doc/theory_of_operation.md @@ -134,11 +134,6 @@ The reset manager then checks as follows: - If all reset conditions are satisfied, wait for the reset release to gracefully complete the cycle. -### Reset Indications for Alert Handler - -The alert handler needs to know the status of the various reset domains in the system to avoid false alert indications due to the ping mechanism. -To that end, the reset manager outputs a 4bit MuBi signal for each reset domain that indicates whether its reset is active. -For more information on this mechanism, see [alert handler documentation](../../alert_handler/doc/theory_of_operation.md#low-power-management-of-alert-channels). ## Design Details diff --git a/util/topgen.py b/util/topgen.py index a15477fbe9e36..e0adb25cb368b 100755 --- a/util/topgen.py +++ b/util/topgen.py @@ -377,6 +377,10 @@ def generate_clkmgr(topcfg: Dict[str, object], out_path: Path) -> None: ty: {nm: {"src_name": sig.src.name, "endpoint_ip": sig.endpoints[0][0]} for nm, sig in mp.items() if isinstance(sig, ClockSignal)} for ty, mp in typed_clocks._asdict().items() if isinstance(mp, dict)}) + + # Will connect to alert_handler + with_alert_handler = lib.find_module(topcfg['module'], 'alert_handler') is not None + params = { "src_clks": OrderedDict({ name: vars(obj) for name, obj in clocks.srcs.items()}), @@ -387,7 +391,8 @@ def generate_clkmgr(topcfg: Dict[str, object], out_path: Path) -> None: "hint_names": hint_names, "parent_child_clks": typed_clocks.parent_child_clks, "exported_clks": topcfg["exported_clks"], - "number_of_clock_groups": len(clocks.groups) + "number_of_clock_groups": len(clocks.groups), + "with_alert_handler": with_alert_handler, } ipgen_render("clkmgr", topname, params, out_path) @@ -428,7 +433,7 @@ def generate_pwrmgr(top: Dict[str, object], out_path: Path) -> None: "rst_reqs": top["reset_requests"], "NumRstReqs": n_rstreqs, "wait_for_external_reset": top['power']['wait_for_external_reset'], - "NumRomInputs": n_rom_ctrl + "NumRomInputs": n_rom_ctrl, } ipgen_render("pwrmgr", topname, params, out_path) @@ -468,6 +473,9 @@ def generate_rstmgr(topcfg: Dict[str, object], out_path: Path) -> None: # Number of reset requests n_rstreqs = len(topcfg["reset_requests"]["peripheral"]) + # Will connect to alert_handler + with_alert_handler = lib.find_module(topcfg['module'], 'alert_handler') is not None + params = { "clks": clks, "reqs": topcfg["reset_requests"], @@ -478,6 +486,7 @@ def generate_rstmgr(topcfg: Dict[str, object], out_path: Path) -> None: "leaf_rsts": leaf_rsts, "rst_ni": rst_ni['rst_ni']['name'], "export_rsts": topcfg["exported_rsts"], + "with_alert_handler": with_alert_handler, } ipgen_render("rstmgr", topname, params, out_path)