Version 1 (modified by 18 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), [...]