| Version 1 (modified by , 19 years ago) (diff) |
|---|
Standard usage
When using a VCI-compliant component, you must define explicitely VCI parameters:
Uses('vci_multi_ram',
cell_size = 4,
plen_size = 1,
addr_size = 32,
rerror_size = 1,
clen_size = 1,
rflag_size = 1,
srcid_size = 8,
pktid_size = 1,
trdid_size = 1,
wrplen_size = 1 )
When repeated for all components, this can be redundant and error prone (not even speaking of readability):
todo = Platform(
Uses('vci_multi_ram', cell_size = 4, plen_size = 1, addr_size = 32, rerror_size = 1,
clen_size = 1, rflag_size = 1, srcid_size = 8, pktid_size = 1, trdid_size = 1,
wrplen_size = 1 ),
Uses('vci_vgmn', cell_size = 4, plen_size = 1, addr_size = 32, rerror_size = 1,
clen_size = 1, rflag_size = 1, srcid_size = 8, pktid_size = 1, trdid_size = 1,
wrplen_size = 1 ),
Uses('vci_xcache', cell_size = 4, plen_size = 1, addr_size = 32, rerror_size = 1,
clen_size = 1, rflag_size = 1, srcid_size = 8, pktid_size = 1, trdid_size = 1,
wrplen_size = 1 ),
Uses('vci_timer', cell_size = 4, plen_size = 1, addr_size = 32, rerror_size = 1,
clen_size = 1, rflag_size = 1, srcid_size = 8, pktid_size = 1, trdid_size = 1,
wrplen_size = 1 ),
Uses('mips'),
)
So you may factor out common parameters:
vci_params = dict(
cell_size = 4,
plen_size = 1,
addr_size = 32,
rerror_size = 1,
clen_size = 1,
rflag_size = 1,
srcid_size = 8,
pktid_size = 1,
trdid_size = 1,
wrplen_size = 1
)
todo = Platform(
Uses('mips'),
Uses('vci_locks', **vci_params),
Uses('vci_multi_ram', **vci_params),
Uses('vci_multi_tty', **vci_params),
Uses('vci_timer', **vci_params),
Uses('vci_vgmn', **vci_params),
Uses('vci_xcache', **vci_params),
Source('top.cc'),
)
The **variable_name will be expanded with all the things defined in the variable, for every line, source:trunk/soclib/platforms/timer_4mips/platform_desc is a live example.
If you have some exceptionnal template parameter to add in for one component, you can specify it before the expanded one:
vci_params = dict(
cell_size = 4,
[...]
)
[...]
Uses('vci_vgmn', write_buffer_depth = 16, **vci_params),
[...]

