Skip to content

Commit

Permalink
[hw,pwm,racl] Add RACL support to PWM
Browse files Browse the repository at this point in the history
Signed-off-by: Robert Schilling <[email protected]>
  • Loading branch information
Razer6 committed Dec 27, 2024
1 parent e242b29 commit 6b1e47c
Show file tree
Hide file tree
Showing 8 changed files with 316 additions and 83 deletions.
33 changes: 32 additions & 1 deletion hw/ip/pwm/data/pwm.hjson
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@
{clock: "clk_core_i", reset: "rst_core_ni"}
]
bus_interfaces: [
{ protocol: "tlul", direction: "device" }
{ protocol: "tlul", direction: "device", racl_support: true }
],
regwidth: "32",
param_list: [
Expand Down Expand Up @@ -87,6 +87,37 @@
desc: "End-to-end bus integrity scheme."
}
]
inter_signal_list: [
{ struct: "racl_policy_vec",
type: "uni",
name: "racl_policies",
act: "rcv",
package: "top_racl_pkg",
desc: '''
Policy vector distributed to the subscribing RACL IPs.
'''
}
{ struct: "logic",
type: "uni",
name: "racl_error",
act: "req",
width : "1",
desc: '''
RACL error indication signal.
If 1, the error log contains valid information.
'''
}
{ struct: "racl_error_log",
type: "uni",
name: "racl_error_log",
act: "req",
width: "1"
package: "top_racl_pkg",
desc: '''
RACL error log information of this module.
'''
}
],
registers: [
{ name: "REGWEN",
desc: "Register write enable for all control registers",
Expand Down
9 changes: 6 additions & 3 deletions hw/ip/pwm/doc/interfaces.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,9 +16,12 @@ Referring to the [Comportable guideline for peripheral device functionality](htt

## [Inter-Module Signals](https://opentitan.org/book/doc/contributing/hw/comportability/index.html#inter-signal-handling)

| Port Name | Package::Struct | Type | Act | Width | Description |
|:------------|:------------------|:--------|:------|--------:|:--------------|
| tl | tlul_pkg::tl | req_rsp | rsp | 1 | |
| Port Name | Package::Struct | Type | Act | Width | Description |
|:---------------|:------------------------------|:--------|:------|--------:|:------------------------------------------------------------------------------|
| racl_policies | top_racl_pkg::racl_policy_vec | uni | rcv | 1 | Policy vector distributed to the subscribing RACL IPs. |
| racl_error | logic | uni | req | 1 | RACL error indication signal. If 1, the error log contains valid information. |
| racl_error_log | top_racl_pkg::racl_error_log | uni | req | 1 | RACL error log information of this module. |
| tl | tlul_pkg::tl | req_rsp | rsp | 1 | |

## Security Alerts

Expand Down
6 changes: 6 additions & 0 deletions hw/ip/pwm/lint/pwm.vbl
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
# Copyright lowRISC contributors (OpenTitan project).
# Licensed under the Apache License, Version 2.0, see LICENSE for details.
# SPDX-License-Identifier: Apache-2.0

# These lines are too long due to generated code
waive --rule=line-length --location="pwm_reg_top.sv"
3 changes: 3 additions & 0 deletions hw/ip/pwm/pwm.core
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,9 @@ filesets:
# common waivers
- lowrisc:lint:common
- lowrisc:lint:comportable
files:
- lint/pwm.vbl
file_type: veribleLintWaiver

parameters:
SYNTHESIS:
Expand Down
31 changes: 23 additions & 8 deletions hw/ip/pwm/rtl/pwm.sv
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,12 @@
module pwm
import pwm_reg_pkg::*;
#(
parameter logic [NumAlerts-1:0] AlertAsyncOn = {NumAlerts{1'b1}},
parameter int PhaseCntDw = 16,
parameter int BeatCntDw = 27
parameter logic [NumAlerts-1:0] AlertAsyncOn = {NumAlerts{1'b1}},
parameter bit EnableRacl = 1'b0,
parameter bit RaclErrorRsp = 1'b1,
parameter int unsigned RaclPolicySelVec[23] = '{23{0}},
parameter int PhaseCntDw = 16,
parameter int BeatCntDw = 27
) (
input clk_i,
input rst_ni,
Expand All @@ -23,23 +26,35 @@ module pwm
input prim_alert_pkg::alert_rx_t [NumAlerts-1:0] alert_rx_i,
output prim_alert_pkg::alert_tx_t [NumAlerts-1:0] alert_tx_o,

// RACL interface
input top_racl_pkg::racl_policy_vec_t racl_policies_i,
output logic racl_error_o,
output top_racl_pkg::racl_error_log_t racl_error_log_o,

output logic [NOutputs-1:0] cio_pwm_o,
output logic [NOutputs-1:0] cio_pwm_en_o
);

pwm_reg_pkg::pwm_reg2hw_t reg2hw;
logic [NumAlerts-1:0] alert_test, alerts;

pwm_reg_top u_reg (
pwm_reg_top #(
.EnableRacl(EnableRacl),
.RaclErrorRsp(RaclErrorRsp),
.RaclPolicySelVec(RaclPolicySelVec)
) u_reg (
.clk_i,
.rst_ni,
.clk_core_i,
.rst_core_ni,
.tl_i (tl_i),
.tl_o (tl_o),
.reg2hw (reg2hw),
.tl_i (tl_i),
.tl_o (tl_o),
.reg2hw (reg2hw),
.racl_policies_i (racl_policies_i),
.racl_error_o (racl_error_o),
.racl_error_log_o (racl_error_log_o),
// SEC_CM: BUS.INTEGRITY
.intg_err_o (alerts[0])
.intg_err_o (alerts[0])
);

assign alert_test = {
Expand Down
Loading

0 comments on commit 6b1e47c

Please sign in to comment.