microprobe.code.benchmark.MultiThreadedBenchmark

class MultiThreadedBenchmark(num_threads=1)[source]

Bases: microprobe.code.benchmark.Benchmark

__init__(num_threads=1)[source]

Methods

__init__([num_threads])
add_fini(finis) Appends the specified list of instructions to the finalization list
add_info(message) Add an information message to the building block.
add_init(inits) Appends the specified list of instructions to initialization list
add_instructions(instrs[, after, before]) Adds the given instruction to the building block.
add_pass_info(message) Add an pass information message to the building block.
add_requirement(message) Add an requirement message to the building block.
add_warning(message) Add a warning message to the building block.
register_var(var, context) Registers the given variable as a global variable.
registered_global_vars() Returns the list of registered global variables.
rm_init(inits) Removes from the initialization list the specified instructions.
set_cfg(cfg) Sets the benchmarks control flow graph.
set_context(context) Set the execution context of the building block.
set_current_thread(idx)

Attributes

cfg Returns the benchmark control flow graph.
code_size Return benchmark’s size
context Return benchmark’s context
fini Finalization instructions (list of Instruction)
info List of information messages of the building block (list of str)
init Initialization instructions
labels Return the a list of the current defined labels and symbols
pass_info List of information pass messages of the building block (list of str)
requirements List of requirement messages of the building block (list of str)
warnings List of warnings of the building block



add_fini(finis)

Appends the specified list of instructions to the finalization list

Parameters:finis (list of Instruction) – List of instructions to be added
add_info(message)

Add an information message to the building block.

Parameters:message (str) – Information message
add_init(inits)

Appends the specified list of instructions to initialization list

Parameters:inits (list of Instruction) – List of instructions to be added
add_instructions(instrs, after=None, before=None)

Adds the given instruction to the building block.

Adds the given instructions right after the specified instruction and before the specified one. If the condition can not be fulfilled an specification exception is raised.

Parameters:
  • instrs (list of Instruction) – Instruction to add
  • after (Instruction) – Instruction after which to add the new instruction (Default value = None)
  • before (Instruction) – Instruction before which to add the new instruction (Default value = None)
add_pass_info(message)

Add an pass information message to the building block.

Parameters:message (str) – Information pass message
add_requirement(message)

Add an requirement message to the building block.

Parameters:message (str) – Requirement message
add_warning(message)

Add a warning message to the building block.

Parameters:message (str) – Warning message
cfg

Returns the benchmark control flow graph.

code_size

Return benchmark’s size

context

Return benchmark’s context

fini

Finalization instructions (list of Instruction)

info

List of information messages of the building block (list of str)

init

Initialization instructions

Initialization instructions (list of Instruction)

labels

Return the a list of the current defined labels and symbols

pass_info

List of information pass messages of the building block (list of str)

register_var(var, context)

Registers the given variable as a global variable.

Parameters:var (Variable) – Variable to register
registered_global_vars()

Returns the list of registered global variables.

requirements

List of requirement messages of the building block (list of str)

rm_init(inits)

Removes from the initialization list the specified instructions.

Parameters:inits (list of Instruction) – List of instructions to be removed
set_cfg(cfg)

Sets the benchmarks control flow graph.

Parameters:cfg (Cfg) – Control flow graph
set_context(context)

Set the execution context of the building block.

Parameters:context (Context) – Execution context
set_current_thread(idx)
warnings

List of warnings of the building block

List of warnings of the building block (list of str)