-
Notifications
You must be signed in to change notification settings - Fork 273
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Harmonize ports and parameters #153
Comments
RFC CC @zarubaf @fabianschuiki @WRoenninger |
Thanks for putting this together. This looks very, very promising. There is currently only one thing which came to my mind: Regarding the interface wrapper for multiple slave or master ports this is essentially an unpacked type where the style guide recommends big-endianess. So I would recommend: axi_if.slv_port slv_ports [NumSlvPorts],
axi_if.mst_port mst_ports [NumMstPorts], or axi_if.slv_port slv_ports [0:NumSlvPorts-1],
axi_if.mst_port mst_ports [0:NumMstPorts-1], |
Good point, thanks! I am adding it. To precisely follow the style guide, let us omit the space between the signal name and the array. |
Thanks for defining these. They look very well thought out. I will update my PRs #116 #115 and #33 accordingly when these harmonization guidelines are finalized. I could do the flattening of the One question regarding #33. There the LLC has a master and slave port with AXI4+ATOP and an AXI4 Lite cfg slave port. So the names should be therefore: // Slave Port facing CPU
input slv_port_axi_req_t slv_port_req_i,
output slv_port_axi_rsp_t slv_port_rsp_o,
// Master Port facing Memory
output mst_port_axi_req_t mst_port_req_o,
input mst_port_axi_rsp_t mst_port_rsp_i,
// Configuration Lite Slave port
input axi_lite_req_t cfg_slv_port_req_i,
output axi_lite_rsp_t cfg_slv_port_rsp_o, Also #33 would require some additional work from my part as the LLC submodules use a cfg struct to propagate the LLC configuration. |
Great, thanks!
I am fine with flattening the parameters of the XBAR in the same PR as adding the docstrings, but please do not mix this up with the crossbar-internal pipeline change. The crossbar pipeline change is complex enough in itself, and I would like to keep it separate for now. (The changes for pipelining the crossbar need careful reviewing to make sure we still guarantee deadlock freedom. Reviewing that is not high priority for me at the moment, because when a crossbar complex enough that it needs to be pipelined inside, it has many master and slave ports, and internal pipelining would add a lot of area -- which again has implications on timing. So I do not think there is urgent need for making the crossbar internally pipelineable.) You do not have to keep the
I agree except for the configuration port, which would be input cfg_slv_port_axi_lite_req_t cfg_slv_port_req_i,
output cfg_slv_port_axi_lite_rsp_t cfg_slv_port_rsp_o, because "If a parameter only applies to one port, it MUST start with the prefix of the port [...]". I realize this is a bit bulky to write, but it helps preventing type collisions.
Yes. |
Thank you for the clarification. Just a heads up, the changes for the |
I see, thanks for clarifying this. This gives the changes to |
Should the req/rsp type in this case not be singular on the port part? // Slave Ports
input slv_port_axi_req_t [NumSlvPorts-1:0] slv_ports_req_i,
output slv_port_axi_rsp_t [NumSlvPorts-1:0] slv_ports_rsp_o,
// Master Ports
output mst_port_axi_req_t [NumMstPorts-1:0] mst_ports_req_o,
input mst_port_axi_rsp_t [NumMstPorts-1:0] mst_ports_rsp_i, Dropping the s from the parameterized type, however keep it in the port name. Consequentially: *_ports_axi_req_t would be the type with the array included: typedef slv_port_axi_req_t [NumSlvPorts-1:0] slv_ports_req_t; |
I agree that it is more intuitive to use a singular name for the type for an array port. However, I am not convinced that the additional complexity of the type naming rule is worth the gained intuitiveness. Currently, the rule is
Should we change that to "If a
|
Updated! 👍 |
Any other change requests or objections? If not, I would add this to our Contribution Guidelines and start accepting PRs that implement these changes. |
Would it make sense to use Lines 118 to 125 in 20311e7
|
The rationale for
|
Let us collect the changes required to harmonize ports and parameters and to minimize incompatibilities with EDA tools. Those changes will be breaking (as in "backwards-incompatible"), so let us make sure we get them right.
This is currently a draft and contributors are kindly asked to comment. Upon agreement, this information will be added to the Contribution Guidelines.
Preamble: The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in BCP 14 [RFC2119] [RFC8174] when, and only when, they appear in all capitals, as shown here.
Parameters
Legal Types
Every
parameter
of a synthesizablemodule
MUST be either:(a) a
type
, or(b) a (vector of) one of the following SystemVerilog types:
bit
orlogic
, which MAY besigned
(but are by default implicitlyunsigned
), orbyte
,shortint
,int
, orlongint
, which MUST be followed byunsigned
orsigned
, or(c) a
typedef
ed type of one of the types in (b).In particular,
struct
s andstring
s MUST NOT be used asparameter
of a synthesizablemodule
.Rationale: Many tools do not properly implement complex types for
parameter
s.For non-synthesizable
module
s andclass
es, the key words MUST and MUST NOT in this section are relaxed to SHOULD and SHOULD NOT, respectively. (In particular, testbenchmodule
s MAY usetime
andstring
parameters.)Signedness
If an integer parameter (i.e.,
byte
,shortint
,int
, orlongint
) is not supposed to take negative values, it MUST be declaredunsigned
instead ofsigned
.Default Value
Every
parameter
MUST have a default value.If possible, the default value SHOULD be a null value that is outside the legal range of the parameter (e.g., a signal width of zero). In this case, the
module
SHOULD contain an assertion to ensure that the parameter is set to a value other than the null value at instantiation.Rationale: Many tools require
parameter
s to have a default value, but in many cases aparameter
that is not set at instantiation indicates an error that should be detected.Derived Parameters
The parameter list of a
module
MUST NOT containlocalparam
s. Rationale: Unsupported by some tools.Instead, if the value of a parameter is derived from another parameter and should not be overridden at instantiation, the line above the derived parameter SHOULD be as follows:
/// Dependent parameter, DO NOT OVERRIDE!
Names
type
parameter
MUST be inUpperCamelCase
.Rationale: style guide.
type
parameter
MUST be inlower_snake_case
and end with_t
.Rationale: style guide.
type
parameter
MUST NOT be prefixed withAxi
.Example: A
module
with a parametrizable data width has aparameter
namedDataWidth
, not.AxiDataWidth
Rationale: Every
module
name starts withaxi_
and prefixingparameter
s withAxi
is redundant.parameter
only applies to one port, its name MUST start with the prefix of the port (converted to the casing dictated above and to singular if the port is an array) or withNum
(see below) followed by the prefix of the port.Example: For a crossbar, the ID width of each of its slave ports (part of an array prefixed
slv_ports_
) would be given by aparameter
namedSlvPortIdWidth
, and the request type of each of its slave ports would be given by aparameter
namedslv_port_axi_req_t
.parameter
applies to more than one port, its name MUST NOT start with the prefix of one of the ports.type
parameter
does not have a port-specific prefix, it MUST be prefixed withaxi_
.Rationale: Some tools do not properly scope type definitions, and adding a topic-specific prefix reduces the chance of type name collisions.
parameter
defines the number of bits in a signal, its name SHOULD end withWidth
.parameter
defines a quantity other than bits in a signal, its name SHOULD containNum
followed by a noun in plural.No
MUST NOT be used to denote a quantityparameter
. (Rationale: easily mistaken for negation, e.g., "no registers").parameter
defines the maximum value of a quantity, its name SHOULD containMax
followed by a noun in plural.parameter
of a testbenchmodule
MUST start withTb
ortb_
. The name of anyparameter
of a non-testbenchmodule
MUST NOT start withTb
ortb_
.Rationale: The name of each
parameter
of a top-levelmodule
that is to be assigned a value when the simulator is invoked must be unique among all simulatedmodule
s; see test: Prefix top-level TB parameters #152 (comment).Examples
A crossbar with multiple
slv_ports
andmst_ports
could have the following among its parameters:Ports
_i
(or_ni
if it is active-low)._o
(or_no
if it is active-low).slv_port_
(orslv_ports_
if the port is an array).mst_port_
(ormst_ports_
if the port is an array)._req
directly before the input/output suffix._rsp
directly before the input/output suffix.Examples
A module with a single AXI-Lite slave port could contain in its
input
s andoutput
s:A CDC from a
src_clk_i
to adst_clk_i
would contain in itsinput
s andoutput
s:A crossbar with multiple slave and master ports would contain in its
input
s andoutput
s:A protocol converter from AXI to AXI-Lite would contain in its
input
s andoutput
s:Channel and Request/Response Types
In this section,
X
MUST be eitheraxi
oraxi_lite
in accordance with whether the type is part of full AXI or AXI-Lite.X_Y_t
, whereY
is one ofaw
,w
,b
,ar
, orr
and MUST correspond to the channel type.X_req_t
.X_rsp_t
.Interfaces
interface
s:axi_if
,axi_dv_if
,axi_lite_if
, andaxi_lite_dv_if
.Rationale for naming: compliant with Google Verible's
interface-name-style
and consistent with the name of types in the style guide we follow (which does not have rules for naming interfaces).modport
s are namedslv_port
(for a slave portmodport
),mst_port
(for a master portmodport
), andmon_port
(for an all-input
monitormodport
).Rationale: consistent with the naming of non-
interface
ports.dv
interfaces MUST be synthesizable. Thedv
interface
s are used for design verification and MAY contain non-synthesizable code.parameter
s in aninterface
MUST obey the rules in the above Parameters section.interface
MUST containslv_port
(orslv_ports
if theinterface
port is an array).interface
MUST containmst_port
(ormst_ports
if theinterface
port is an array).interface
s MUST be unpacked (i.e., dimensions after identifier). The dimensions MUST be in big-endian notation (e.g.,[0:N-1]
). Dimensions SHOULD be zero-based unless there are strong reasons against it. Zero-based dimensions SHOULD use the short[N]
notation. There MUST NOT be a space between identifier and dimensions.Examples
A crossbar (or rather, its
_intf
variant) with multiple slave and master ports would contain in its port list:The text was updated successfully, but these errors were encountered: