coreblocks.func_blocks.fu package
Subpackages
- coreblocks.func_blocks.fu.fpu package
- coreblocks.func_blocks.fu.lsu package
- coreblocks.func_blocks.fu.unsigned_multiplication package
- Submodules
- coreblocks.func_blocks.fu.unsigned_multiplication.common module
- coreblocks.func_blocks.fu.unsigned_multiplication.fast_recursive module
- coreblocks.func_blocks.fu.unsigned_multiplication.pipelined module
- coreblocks.func_blocks.fu.unsigned_multiplication.sequence module
- coreblocks.func_blocks.fu.unsigned_multiplication.shift module
- Module contents
Submodules
coreblocks.func_blocks.fu.alu module
- class coreblocks.func_blocks.fu.alu.ALUComponent
Bases:
FunctionalComponentParams
- __init__(zba_enable=False, zbb_enable=False, zicond_enable=False)
- get_optypes() set[coreblocks.arch.optypes.OpType]
coreblocks.func_blocks.fu.div_unit module
- class coreblocks.func_blocks.fu.div_unit.DivComponent
Bases:
FunctionalComponentParams
- div_fn = <coreblocks.func_blocks.fu.div_unit.DivFn object>
- get_optypes() set[coreblocks.arch.optypes.OpType]
- class coreblocks.func_blocks.fu.div_unit.DivFn
Bases:
DecoderManager
- class coreblocks.func_blocks.fu.div_unit.DivUnit
Bases:
FuncUnit
,Elaboratable
- __init__(gen_params: ~coreblocks.params.genparams.GenParams, ipc: int = 4, div_fn=<coreblocks.func_blocks.fu.div_unit.DivFn object>)
- coreblocks.func_blocks.fu.div_unit.get_input(arg: View) tuple[amaranth.hdl._ast.Value, amaranth.hdl._ast.Value]
coreblocks.func_blocks.fu.exception module
- class coreblocks.func_blocks.fu.exception.ExceptionFuncUnit
Bases:
FuncUnit
,Elaboratable
- __init__(gen_params: ~coreblocks.params.genparams.GenParams, unit_fn=<coreblocks.func_blocks.fu.exception.ExceptionUnitFn object>)
- class coreblocks.func_blocks.fu.exception.ExceptionUnitComponent
Bases:
FunctionalComponentParams
- __init__()
- get_optypes() set[coreblocks.arch.optypes.OpType]
coreblocks.func_blocks.fu.jumpbranch module
- class coreblocks.func_blocks.fu.jumpbranch.JumpBranchFuncUnit
Bases:
FuncUnit
,Elaboratable
- __init__(gen_params: ~coreblocks.params.genparams.GenParams, jb_fn=<coreblocks.func_blocks.fu.jumpbranch.JumpBranchFn object>)
- class coreblocks.func_blocks.fu.jumpbranch.JumpComponent
Bases:
FunctionalComponentParams
- __init__()
- get_optypes() set[coreblocks.arch.optypes.OpType]
coreblocks.func_blocks.fu.mul_unit module
- class coreblocks.func_blocks.fu.mul_unit.MulComponent
Bases:
FunctionalComponentParams
- get_optypes() set[coreblocks.arch.optypes.OpType]
- mul_fn = <coreblocks.func_blocks.fu.mul_unit.MulFn object>
- class coreblocks.func_blocks.fu.mul_unit.MulFn
Bases:
DecoderManager
Hot wire enum of 5 different multiplication operations.
- class coreblocks.func_blocks.fu.mul_unit.MulType
Bases:
IntEnum
Enum of different multiplication units types
- RECURSIVE_MUL = 2
Fastest way of multiplying using only one cycle, but costly in terms of resources.
- SEQUENCE_MUL = 1
Uses single DSP unit for multiplication, which makes balance between performance and cost.
- SHIFT_MUL = 0
The cheapest multiplication unit in terms of resources, it uses Russian Peasants Algorithm.
- __new__(value)
- class coreblocks.func_blocks.fu.mul_unit.MulUnit
Bases:
FuncUnit
,Elaboratable
Module responsible for handling every kind of multiplication based on selected unsigned integer multiplication module. It uses standard FuncUnitLayout.
- Attributes
- issue: Method(i=gen.get(FuncUnitLayouts).issue)
Method used for requesting computation.
- accept: Method(i=gen.get(FuncUnitLayouts).accept)
Method used for getting result of requested computation.
- __init__(gen_params: ~coreblocks.params.genparams.GenParams, mul_type: ~coreblocks.func_blocks.fu.mul_unit.MulType, dsp_width: int = 32, mul_fn=<coreblocks.func_blocks.fu.mul_unit.MulFn object>)
- Parameters
- gen_params: GenParams
Core generation parameters.
coreblocks.func_blocks.fu.priv module
- class coreblocks.func_blocks.fu.priv.PrivilegedFn
Bases:
DecoderManager
- class coreblocks.func_blocks.fu.priv.PrivilegedFuncUnit
Bases:
Elaboratable
- class coreblocks.func_blocks.fu.priv.PrivilegedUnitComponent
Bases:
FunctionalComponentParams
- get_optypes() set[coreblocks.arch.optypes.OpType]
coreblocks.func_blocks.fu.shift_unit module
- class coreblocks.func_blocks.fu.shift_unit.ShiftFuncUnit
Bases:
FuncUnit
,Elaboratable
- __init__(gen_params: ~coreblocks.params.genparams.GenParams, shift_unit_fn=<coreblocks.func_blocks.fu.shift_unit.ShiftUnitFn object>)
- class coreblocks.func_blocks.fu.shift_unit.ShiftUnitComponent
Bases:
FunctionalComponentParams
- __init__(zbb_enable=False)
- get_optypes() set[coreblocks.arch.optypes.OpType]
coreblocks.func_blocks.fu.zbc module
- class coreblocks.func_blocks.fu.zbc.ClMultiplier
Bases:
Elaboratable
Module for computing carry-less product
- Attributes
- i1: Signal(unsigned(n)), in
First factor.
- i2: Signal(unsigned(n)), in
Second factor.
- result: Signal(unsigned(n * 2)), out
Result.
- reset: Signal(1), in
Setting this signal to 1 will start a new computation with provided inputs
- busy: Signal(1), out
Set to 1 while a computation is in progress
- __init__(bit_width: int, recursion_depth: int)
- Parameters
- bit_width: int
Bit width of inputs
- recursion_depth: int
Depth of recursive submodules for parallel computation (assumes bit_width to be a power of 2)
- iterative_module()
- recursive_module()
- class coreblocks.func_blocks.fu.zbc.ZbcComponent
Bases:
FunctionalComponentParams
- get_optypes() set[coreblocks.arch.optypes.OpType]
- zbc_fn = <coreblocks.func_blocks.fu.zbc.ZbcFn object>
- class coreblocks.func_blocks.fu.zbc.ZbcFn
Bases:
DecoderManager
- class coreblocks.func_blocks.fu.zbc.ZbcUnit
Bases:
Elaboratable
Module responsible for executing Zbc instructions (carry-less multiplication)
- Attributes
- issue: Method(i=FuncUnitLayouts.issue)
Method used for requesting computation.
- accept: Method(i=FuncUnitLayouts.accept)
Method used for getting result of requested computation.
coreblocks.func_blocks.fu.zbs module
- class coreblocks.func_blocks.fu.zbs.Zbs
Bases:
Elaboratable
Module responsible for executing Zbs instructions.
- Attributes
- function: ZbsFunction, in
Function to be executed.
- in1: Signal(xlen), in
First input.
- in2: Signal(xlen), in
Second input.
- __init__(gen_params: ~coreblocks.params.genparams.GenParams, function=<coreblocks.func_blocks.fu.zbs.ZbsFunction object>)
- Parameters
- gen_paramsGenParams
Core generation parameters.
- functionZbsFunction
Decoder manager to decode instruction.
- class coreblocks.func_blocks.fu.zbs.ZbsComponent
Bases:
FunctionalComponentParams
- __init__()
- get_optypes() set[coreblocks.arch.optypes.OpType]
- class coreblocks.func_blocks.fu.zbs.ZbsFunction
Bases:
DecoderManager
Enum of Zbs functions.
- class coreblocks.func_blocks.fu.zbs.ZbsUnit
Bases:
FuncUnit
,Elaboratable
Module responsible for executing Zbs instructions.
- Attributes
- issue: Method(i=FuncUnitLayouts.issue)
Method used for requesting computation.
- accept: Method(i=FuncUnitLayouts.accept)
Method used for getting result of requested computation.
- __init__(gen_params: ~coreblocks.params.genparams.GenParams, zbs_fn=<coreblocks.func_blocks.fu.zbs.ZbsFunction object>)