mirror of
https://github.com/Silicon1602/srdl2sv.git
synced 2025-01-09 20:38:40 +00:00
Logger should always lazy evaluate variables
This commit is contained in:
parent
49d1b598f0
commit
7c55cfaa8e
srdl2sv
@ -72,8 +72,7 @@ class AddrMap(Component):
|
|||||||
obj=child,
|
obj=child,
|
||||||
parents_dimensions=None,
|
parents_dimensions=None,
|
||||||
parents_strides=None,
|
parents_strides=None,
|
||||||
config=config,
|
config=config)
|
||||||
glbl_settings=glbl_settings)
|
|
||||||
new_child.sanity_checks()
|
new_child.sanity_checks()
|
||||||
self.mems[child.inst_name] = new_child
|
self.mems[child.inst_name] = new_child
|
||||||
elif isinstance(child, node.RegNode):
|
elif isinstance(child, node.RegNode):
|
||||||
@ -100,7 +99,7 @@ class AddrMap(Component):
|
|||||||
pass
|
pass
|
||||||
|
|
||||||
self.logger.info(
|
self.logger.info(
|
||||||
f"Detected maximum register width of whole addrmap to be '{self.regwidth}'")
|
"Detected maximum register width of whole addrmap to be '%i'", self.regwidth)
|
||||||
|
|
||||||
# Add registers to children. This must be done in a last step
|
# Add registers to children. This must be done in a last step
|
||||||
# to account for all possible alias combinations
|
# to account for all possible alias combinations
|
||||||
@ -351,15 +350,19 @@ class AddrMap(Component):
|
|||||||
enum_members[var[0]] = "::".join([self.name, key])
|
enum_members[var[0]] = "::".join([self.name, key])
|
||||||
else:
|
else:
|
||||||
self.logger.fatal(
|
self.logger.fatal(
|
||||||
f"Enum member '{var[0]}' was found at multiple locations in the same "\
|
"Enum member '%s' was found at multiple locations in the same "\
|
||||||
"main scope: \n"\
|
"main scope: \n"\
|
||||||
f" -- 1st occurance: '{enum_members[var[0]]}'\n"\
|
" -- 1st occurance: '%s'\n"\
|
||||||
f" -- 2nd occurance: '{'::'.join([self.name, key])}'\n\n"\
|
" -- 2nd occurance: '%s'\n\n"\
|
||||||
"This is not legal because all these enums will be defined "\
|
"This is not legal because all these enums will be defined "\
|
||||||
"in the same SystemVerilog scope. To share the same enum among "\
|
"in the same SystemVerilog scope. To share the same enum among "\
|
||||||
"different registers, define them on a higher level in the "\
|
"different registers, define them on a higher level in the "\
|
||||||
"hierarchy.\n\n"\
|
"hierarchy.\n\n"\
|
||||||
"Exiting...")
|
"Exiting...",
|
||||||
|
var[0],
|
||||||
|
enum_members[var[0]],
|
||||||
|
'::'.join([self.name, key])
|
||||||
|
)
|
||||||
|
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
@ -331,9 +331,9 @@ class Field(Component):
|
|||||||
|
|
||||||
if obj_incr_value.width > self.obj.width:
|
if obj_incr_value.width > self.obj.width:
|
||||||
self.logger.error(
|
self.logger.error(
|
||||||
f"Width of 'incr_value' signal '{obj_incr_value.get_path()}' is "
|
"Width of 'incr_value' signal '%s' is wider than current counter"
|
||||||
"wider than current counter field. This could potentiall cause "
|
"field. This could potentiall cause ugly errors.",
|
||||||
"ugly errors.")
|
obj_incr_value.get_path())
|
||||||
|
|
||||||
if obj_incr_width:
|
if obj_incr_width:
|
||||||
self.logger.error(
|
self.logger.error(
|
||||||
@ -399,9 +399,9 @@ class Field(Component):
|
|||||||
|
|
||||||
if obj_decr_value.width > self.obj.width:
|
if obj_decr_value.width > self.obj.width:
|
||||||
self.logger.error(
|
self.logger.error(
|
||||||
f"Width of 'decr_value' signal '{obj_decr_value.get_path()}' is "
|
"Width of 'decr_value' signal '%s' is wider than current counter"
|
||||||
"wider than current counter field. This could potentiall cause "
|
"field. This could potentiall cause ugly errors.",
|
||||||
"ugly errors.")
|
obj_decr_value.get_path())
|
||||||
|
|
||||||
if obj_decr_width:
|
if obj_decr_width:
|
||||||
self.logger.error(
|
self.logger.error(
|
||||||
@ -457,9 +457,9 @@ class Field(Component):
|
|||||||
try:
|
try:
|
||||||
if incr.width > 0:
|
if incr.width > 0:
|
||||||
self.logger.error(
|
self.logger.error(
|
||||||
f"Increment signal '{incr.inst_name}' is wider than "
|
"Increment signal '%s' is wider than 1 bit. This might"
|
||||||
"1 bit. This might result in unwanted behavior and "
|
"result in unwanted behavior and will also cause Lint-errors.",
|
||||||
"will also cause Lint-errors.")
|
incr.inst_name)
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
# 'PropRef_overflow' object has no attribute 'width'
|
# 'PropRef_overflow' object has no attribute 'width'
|
||||||
pass
|
pass
|
||||||
@ -498,9 +498,9 @@ class Field(Component):
|
|||||||
try:
|
try:
|
||||||
if decr.width > 0:
|
if decr.width > 0:
|
||||||
self.logger.error(
|
self.logger.error(
|
||||||
f"Decrement signal '{decr.inst_name}' is wider than "
|
"Decrement signal '%s' is wider than 1 bit. This might"
|
||||||
"1 bit. This might result in unwanted behavior and "
|
"result in unwanted behavior and will also cause Lint-errors.",
|
||||||
"will also cause Lint-errors.")
|
decr.decr_name)
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
# 'PropRef_underflow' object has no attribute 'width'
|
# 'PropRef_underflow' object has no attribute 'width'
|
||||||
pass
|
pass
|
||||||
@ -783,11 +783,13 @@ class Field(Component):
|
|||||||
InterruptType.bothedge):
|
InterruptType.bothedge):
|
||||||
|
|
||||||
self.logger.info(
|
self.logger.info(
|
||||||
f"Found '{intr_type}' property for interrupt field that is "\
|
"Found '%s' property for interrupt field that is "\
|
||||||
"wider than 1-bit and has the sticky (rather than the "\
|
"wider than 1-bit and has the sticky (rather than the "\
|
||||||
"stickybit property. In this case, the value will be "\
|
"stickybit property. In this case, the value will be "\
|
||||||
"latched if _any_ bit in the signal changes according to "\
|
"latched if _any_ bit in the signal changes according to "\
|
||||||
"'{intr_type}'"
|
"'%s'",
|
||||||
|
intr_type,
|
||||||
|
intr_type
|
||||||
)
|
)
|
||||||
|
|
||||||
if intr_type != InterruptType.level:
|
if intr_type != InterruptType.level:
|
||||||
@ -905,7 +907,7 @@ class Field(Component):
|
|||||||
sticky, _ = self.__add_sticky(latch_signal = InterruptType.level)
|
sticky, _ = self.__add_sticky(latch_signal = InterruptType.level)
|
||||||
|
|
||||||
if sticky:
|
if sticky:
|
||||||
self.logger.info(f"Found {sticky} property.")
|
self.logger.info("Found '%s' property.", sticky)
|
||||||
elif self.obj.get_property('counter'):
|
elif self.obj.get_property('counter'):
|
||||||
self.access_rtl['hw_write'] = ([
|
self.access_rtl['hw_write'] = ([
|
||||||
self._process_yaml(
|
self._process_yaml(
|
||||||
@ -1185,7 +1187,7 @@ class Field(Component):
|
|||||||
# kill the try block in most cases
|
# kill the try block in most cases
|
||||||
parent_scope = enum.get_parent_scope()
|
parent_scope = enum.get_parent_scope()
|
||||||
|
|
||||||
self.logger.debug(f"Starting to parse '{enum}'")
|
self.logger.debug("Starting to parse '%s'", enum)
|
||||||
|
|
||||||
if isinstance(parent_scope, Reg):
|
if isinstance(parent_scope, Reg):
|
||||||
enum_name = '__'.join([enum.get_scope_path().split('::')[-1], enum.__name__])
|
enum_name = '__'.join([enum.get_scope_path().split('::')[-1], enum.__name__])
|
||||||
@ -1221,7 +1223,7 @@ class Field(Component):
|
|||||||
self.field_type =\
|
self.field_type =\
|
||||||
'::'.join(['_'.join([scope, 'pkg']), enum_name])
|
'::'.join(['_'.join([scope, 'pkg']), enum_name])
|
||||||
|
|
||||||
self.logger.info(f"Parsed enum '{enum_name}'")
|
self.logger.info("Parsed enum '%s'", enum_name)
|
||||||
|
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
# In case of an AttributeError, the encode property is None. Hence,
|
# In case of an AttributeError, the encode property is None. Hence,
|
||||||
|
@ -101,8 +101,8 @@ class Memory(Component):
|
|||||||
|
|
||||||
def sanity_checks(self):
|
def sanity_checks(self):
|
||||||
if not math.log2(self.memwidth).is_integer():
|
if not math.log2(self.memwidth).is_integer():
|
||||||
self.logger.fatal( "The defined memory width must be a power of 2. "\
|
self.logger.fatal("The defined memory width must be a power of 2. "\
|
||||||
f"it is now defined as '{self.memwidth}'")
|
"it is now defined as '%s'", self.memwidth)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
# Determine dimensions of register
|
# Determine dimensions of register
|
||||||
@ -112,12 +112,15 @@ class Memory(Component):
|
|||||||
"handles this outside of the memory block.")
|
"handles this outside of the memory block.")
|
||||||
|
|
||||||
if self.obj.array_stride != int(self.mementries * self.memwidth / 8):
|
if self.obj.array_stride != int(self.mementries * self.memwidth / 8):
|
||||||
self.logger.warning(f"The memory's stride ({self.obj.array_stride}) "\
|
self.logger.warning("The memory's stride (%i) is unequal to the depth "\
|
||||||
f"is unequal to the depth of the memory ({self.mementries} "\
|
"of the memory (%i * %i / 8 = %i). This must be "\
|
||||||
f"* {self.memwidth} / 8 = "\
|
"kept in mind when hooking up the memory interface "\
|
||||||
f"{int(self.mementries * self.memwidth / 8)}). This must be "\
|
"to an external memory block.",
|
||||||
"kept in mind when hooking up the memory interface to an "\
|
self.obj.array_stride,
|
||||||
"external memory block.")
|
self.mementries,
|
||||||
|
self.memwidth,
|
||||||
|
int(self.mementries * self.memwidth / 8)
|
||||||
|
)
|
||||||
|
|
||||||
def __add_sw_mux_assignments(self):
|
def __add_sw_mux_assignments(self):
|
||||||
# Create list of mux-inputs to later be picked up by carrying addrmap
|
# Create list of mux-inputs to later be picked up by carrying addrmap
|
||||||
|
@ -1,12 +1,9 @@
|
|||||||
import importlib.resources as pkg_resources
|
import importlib.resources as pkg_resources
|
||||||
import sys
|
import sys
|
||||||
import math
|
from typing import Optional
|
||||||
import yaml
|
import yaml
|
||||||
|
|
||||||
from typing import Optional
|
|
||||||
|
|
||||||
from systemrdl import node
|
from systemrdl import node
|
||||||
from systemrdl.node import FieldNode
|
|
||||||
|
|
||||||
# Local packages
|
# Local packages
|
||||||
from srdl2sv.components.component import Component
|
from srdl2sv.components.component import Component
|
||||||
@ -97,7 +94,8 @@ class RegFile(Component):
|
|||||||
self.children = {**self.regfiles, **self.registers}
|
self.children = {**self.regfiles, **self.registers}
|
||||||
|
|
||||||
# Create RTL of all registers
|
# Create RTL of all registers
|
||||||
[x.create_rtl() for x in self.registers.values()]
|
for register in self.registers.values():
|
||||||
|
register.create_rtl()
|
||||||
|
|
||||||
self.logger.info("Done generating all child-regfiles/registers")
|
self.logger.info("Done generating all child-regfiles/registers")
|
||||||
|
|
||||||
@ -199,15 +197,19 @@ class RegFile(Component):
|
|||||||
enum_members[var[0]] = "::".join([self.name, key])
|
enum_members[var[0]] = "::".join([self.name, key])
|
||||||
else:
|
else:
|
||||||
self.logger.fatal(
|
self.logger.fatal(
|
||||||
f"Enum member '{var[0]}' was found at multiple locations in the same "\
|
"Enum member '%s' was found at multiple locations in the same "\
|
||||||
"main scope: \n"\
|
"main scope: \n"\
|
||||||
f" -- 1st occurance: '{enum_members[var[0]]}'\n"\
|
" -- 1st occurance: '%s'\n"\
|
||||||
f" -- 2nd occurance: '{'::'.join([self.name, key])}'\n\n"\
|
" -- 2nd occurance: '%s'\n\n"\
|
||||||
"This is not legal because all these enums will be defined "\
|
"This is not legal because all these enums will be defined "\
|
||||||
"in the same SystemVerilog scope. To share the same enum among "\
|
"in the same SystemVerilog scope. To share the same enum among "\
|
||||||
"different registers, define them on a higher level in the "\
|
"different registers, define them on a higher level in the "\
|
||||||
"hierarchy.\n\n"\
|
"hierarchy.\n\n"\
|
||||||
"Exiting...")
|
"Exiting...",
|
||||||
|
var[0],
|
||||||
|
enum_members[var[0]],
|
||||||
|
'::'.join([self.name, key])
|
||||||
|
)
|
||||||
|
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
@ -477,10 +477,13 @@ class Register(Component):
|
|||||||
self.children[field_range].add_sw_access(field, alias=True)
|
self.children[field_range].add_sw_access(field, alias=True)
|
||||||
except KeyError:
|
except KeyError:
|
||||||
self.logger.fatal(
|
self.logger.fatal(
|
||||||
f"Range of field '{field.inst_name}' in alias register "
|
"Range of field '%s' in alias register "
|
||||||
f"'{obj.inst_name}' does not correspond to range of field "
|
"'%s' does not correspond to range of field "
|
||||||
f"in original register '{self.name}'. This is illegal "
|
"in original register '%s'. This is illegal "
|
||||||
"according to 10.5.1 b) of the SystemRDL 2.0 LRM.")
|
"according to 10.5.1 b) of the SystemRDL 2.0 LRM.",
|
||||||
|
field.inst_name,
|
||||||
|
obj.inst_name,
|
||||||
|
self.name)
|
||||||
|
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
@ -523,8 +526,8 @@ class Register(Component):
|
|||||||
genvars_sum.pop()
|
genvars_sum.pop()
|
||||||
|
|
||||||
self.logger.debug(
|
self.logger.debug(
|
||||||
f"Multidimensional with dimensions '{self.total_array_dimensions}' "
|
"Multidimensional with dimensions '%s' and stride '%s'",
|
||||||
f"and stride '{self.total_stride}'")
|
self.total_array_dimensions, self.total_stride)
|
||||||
|
|
||||||
except TypeError:
|
except TypeError:
|
||||||
self.logger.debug(
|
self.logger.debug(
|
||||||
|
@ -41,7 +41,7 @@ def main():
|
|||||||
except RDLCompileError:
|
except RDLCompileError:
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
except FileNotFoundError:
|
except FileNotFoundError:
|
||||||
logger.fatal(f"Could not find '{input_file}'")
|
logger.fatal("Could not find '%s'", input_file)
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
addrmap = AddrMap(root.top, config)
|
addrmap = AddrMap(root.top, config)
|
||||||
@ -59,7 +59,7 @@ def main():
|
|||||||
file=file
|
file=file
|
||||||
)
|
)
|
||||||
|
|
||||||
logger.info(f"Succesfully created '{out_addrmap_file}'")
|
logger.info("Succesfully created '%s'", out_addrmap_file)
|
||||||
|
|
||||||
# Start grabbing packages. This returns a dictionary for the main addrmap
|
# Start grabbing packages. This returns a dictionary for the main addrmap
|
||||||
# and all it's child regfiles/addrmaps
|
# and all it's child regfiles/addrmaps
|
||||||
@ -79,7 +79,7 @@ def main():
|
|||||||
with open(out_widget_file, 'w', encoding="UTF-8") as file:
|
with open(out_widget_file, 'w', encoding="UTF-8") as file:
|
||||||
print(widget_rtl, file=file)
|
print(widget_rtl, file=file)
|
||||||
|
|
||||||
logger.info(f"Selected, implemented, and copied '{config['bus']}' widget")
|
logger.info("Selected, implemented, and copied '%s' widget", config['bus'])
|
||||||
|
|
||||||
# Copy over generic srdl2sv_interface_pkg
|
# Copy over generic srdl2sv_interface_pkg
|
||||||
widget_if_rtl = pkg_resources.read_text(widgets, 'srdl2sv_if_pkg.sv')
|
widget_if_rtl = pkg_resources.read_text(widgets, 'srdl2sv_if_pkg.sv')
|
||||||
|
Loading…
Reference in New Issue
Block a user