ScEpTIC.AST.elements.instructions package¶
Submodules¶
ScEpTIC.AST.elements.instructions.binary_operation module¶
-
class
ScEpTIC.AST.elements.instructions.binary_operation.
BinaryOperation
(operation_type, first_operand, second_operand, target, is_bitwise, specific_attributes)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST nodes for the LLVM Binary Instructions group https://llvm.org/docs/LangRef.html#binaryops
NB: each result is stored as SIGNED int, even if the operation is unsigned. The sign bit is an interpretation of UNSIGNED operations, which will manage that by converting the int to its unsigned equivalent.
-
get_input_lookup
()¶ Returns the input lookup data for the current operation
-
get_uses
()¶ Returns a list containing the names of the registers used by this instruction. (used by register allocation)
-
get_val
()¶ Returns the value obtained from the operation. It converts address operands (if present) to relative spaces, applies the operation and converts them back to the absolute space.
-
replace_reg_name
(old_reg_name, new_reg_name)¶ Replaces the name of a register used by the instruction with a new one. (used by register allocation)
-
resolve_memory_address_chain
(elements)¶ Returns a list of all the instructions required to get the address of the targeted element(s)
-
resolve_memory_tag
(elements)¶ Resolves and returns the memory tag of the targeted element
-
resolve_memory_tag_dependency
(elements)¶
-
ScEpTIC.AST.elements.instructions.conversion module¶
-
class
ScEpTIC.AST.elements.instructions.conversion.
ConversionOperation
(conversion_type, operand, target_type, target)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST nodes for the LLVM Bitwise Instructions group https://llvm.org/docs/LangRef.html#bitwiseops
-
get_input_lookup
()¶ Returns the input lookup data for the current operation
-
get_uses
()¶ Returns a list containing the names of the registers used by this instruction. (used by register allocation)
-
get_val
()¶ Returns the value obtained from the operation. It converts address operands (if present) to relative spaces, applies the operation and converts them back to the absolute space.
-
replace_reg_name
(old_reg_name, new_reg_name)¶ Replaces the name of a register used by the instruction with a new one. (used by register allocation)
-
resolve_memory_address_chain
(elements)¶ Returns a list of all the instructions required to get the address of the targeted element(s)
-
resolve_memory_tag
(elements)¶ Resolves and returns the memory tag of the targeted element
-
resolve_memory_tag_dependency
(elements)¶
-
ScEpTIC.AST.elements.instructions.memory_operations module¶
-
class
ScEpTIC.AST.elements.instructions.memory_operations.
AllocaOperation
(target, element_type, elements_number, align)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST node of the LLVM Memory Instructions group - Alloca Instruction https://llvm.org/docs/LangRef.html#memoryops
-
get_defs
()¶ Returns a list of registers defined by this instruction. (used by register allocation)
-
get_ignore
()¶ Returns a list of register names to be ignored by register allocation. For alloca operation it is the target register.
-
get_input_lookup
()¶ Returns the input lookup data for the current operation
-
get_uses
()¶ Returns a list containing the names of the registers used by this instruction. (used by register allocation)
-
resolve_memory_address_chain
(elements)¶ Returns a list of all the instructions required to get the address of the targeted element(s)
-
resolve_memory_tag
(elements)¶ Resolves and returns the memory tag of the targeted element
-
resolve_memory_tag_dependency
(elements)¶
-
run
()¶ Executes the operation and the target assignment.
-
-
class
ScEpTIC.AST.elements.instructions.memory_operations.
GetElementPointerOperation
(target, element, base_type, indexes, inbounds)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST node of the LLVM Memory Instructions group - GetElementPointer Instruction https://llvm.org/docs/LangRef.html#memoryops
-
get_input_lookup
()¶ Returns the input lookup data for the current operation
-
get_uses
()¶ Returns a list containing the names of the registers used by this instruction. (used by register allocation)
-
get_val
()¶ Returns the represented absolute address.
-
replace_reg_name
(old_reg_name, new_reg_name)¶ Replaces the name of a register used by the instruction with a new one. (used by register allocation)
-
resolve_memory_address_chain
(elements)¶ Returns a list of all the instructions required to get the address of the targeted element(s)
-
resolve_memory_tag
(elements)¶ Resolves and returns the memory tag of the targeted element
-
resolve_memory_tag_dependency
(elements)¶
-
-
class
ScEpTIC.AST.elements.instructions.memory_operations.
LoadOperation
(target, load_type, element, align, volatile)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST node of the LLVM Memory Instructions group - Load Instruction https://llvm.org/docs/LangRef.html#memoryops
-
get_ignore
()¶ Returns a list of register names to be ignored by register allocation. For load operation it is the target register, if the load operation is marked to be used as argument of a function call, since it will be loaded as a stack offset.
-
get_input_lookup
()¶ Returns the input lookup data for the current operation
-
get_load_address
()¶ Returns the address to be loaded.
-
get_uses
()¶ Returns a list containing the names of the registers used by this instruction. (used by register allocation)
-
get_val
()¶ Executes the operation and the target assignment.
-
replace_reg_name
(old_reg_name, new_reg_name)¶ Replaces the name of a register used by the instruction with a new one. (used by register allocation)
-
resolve_memory_address_chain
(elements)¶ Returns a list of all the instructions required to get the address of the targeted element(s)
-
resolve_memory_tag
(elements)¶ Resolves and returns the memory tag of the targeted element
-
resolve_memory_tag_dependency
(elements)¶
-
run
()¶ Executes the load operation and the target assignment.
-
-
class
ScEpTIC.AST.elements.instructions.memory_operations.
StoreOperation
(target, value, align, volatile)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST node of the LLVM Memory Instructions group - Store Instruction https://llvm.org/docs/LangRef.html#memoryops
-
get_defs
()¶ Returns a list of registers defined by this instruction. (used by register allocation)
-
get_store_address
()¶ Returns the address in which the value will be stored.
-
get_uses
()¶ Returns a list containing the names of the registers used by this instruction. (used by register allocation)
-
replace_reg_name
(old_reg_name, new_reg_name)¶ Replaces the name of a register used by the instruction with a new one. (used by register allocation)
-
resolve_memory_address_chain
(elements)¶ Returns a list of all the instructions required to get the address of the targeted element(s)
-
resolve_memory_tag
(elements)¶ Resolves and returns the memory tag of the targeted element
-
resolve_memory_tag_dependency
(elements)¶
-
run
()¶ Executes the operation and the target assignment.
-
ScEpTIC.AST.elements.instructions.other_operations module¶
-
class
ScEpTIC.AST.elements.instructions.other_operations.
CallOperation
(target, function_name, return_type, function_signature, function_args, attrs)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST node of the LLVM Other Instructions group - Call Instruction https://llvm.org/docs/LangRef.html#otherops
-
get_function_max_reg_usage
()¶ Returns the number of physical registers used by this function.
-
get_type_from_virtual_reg
(virtual_reg)¶ Returns the type of an argument given its virtual register name.
-
get_uses
()¶ Returns a list containing the names of the registers used by this instruction. (used by register allocation)
-
ignore
= []¶
-
memory_tick_count
= 2¶
-
n_memory_instructions
= 2¶
-
replace_reg_name
(old_reg_name, new_reg_name)¶ Replaces the name of a register used by the instruction with a new one. (used by register allocation)
-
run
()¶ Runs the call operation.
-
tick_count
= 4¶
-
-
class
ScEpTIC.AST.elements.instructions.other_operations.
CompareOperation
(target, first_operand, second_operand, condition, comparation_type, operation_code)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST node of the LLVM Other Instructions group - Compare Instruction https://llvm.org/docs/LangRef.html#otherops
-
get_input_lookup
()¶ Returns the input lookup data for the current operation
-
get_uses
()¶ Returns a list containing the names of the registers used by this instruction. (used by register allocation)
-
get_val
()¶ Returns the value obtained from the operation. It converts address operands (if present) to relative spaces, and applies the comparisons.
-
static
is_one_qnan
(value1, value2)¶ Returns if at least one of two values are QNAN
-
static
is_qnan
(value)¶ Returns if a value is a QNAN
-
replace_reg_name
(old_reg_name, new_reg_name)¶ Replaces the name of a register used by the instruction with a new one. (used by register allocation)
-
-
class
ScEpTIC.AST.elements.instructions.other_operations.
PhiOperation
(target, return_type, values)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST node of the LLVM Other Instructions group - Phi Instruction https://llvm.org/docs/LangRef.html#otherops
-
get_input_lookup
()¶ Returns the input lookup data for the current operation
-
get_uses
()¶ Returns a list containing the names of the registers used by this instruction. (used by register allocation)
-
get_val
()¶ Returns the value obtained from the operation.
-
replace_reg_name
(old_reg_name, new_reg_name)¶ Replaces the name of a register used by the instruction with a new one. (used by register allocation)
-
-
class
ScEpTIC.AST.elements.instructions.other_operations.
SelectOperation
(target, condition, first_operand, second_operand)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST node of the LLVM Other Instructions group - Select Instruction https://llvm.org/docs/LangRef.html#otherops
-
get_input_lookup
()¶ Returns the input lookup data for the current operation
-
get_uses
()¶ Returns a list containing the names of the registers used by this instruction. (used by register allocation)
-
get_val
()¶ Returns the result of the operation.
-
replace_reg_name
(old_reg_name, new_reg_name)¶ Replaces the name of a register used by the instruction with a new one. (used by register allocation)
-
-
class
ScEpTIC.AST.elements.instructions.other_operations.
VaArgOperation
(target, element, arg_type)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST node of the LLVM Other Instructions group - VaArg Instruction NOT SUPPORTED IN ScEpTIC https://llvm.org/docs/LangRef.html#otherops
-
run
()¶ Executes the operation and the target assignment.
-
ScEpTIC.AST.elements.instructions.termination_instructions module¶
-
class
ScEpTIC.AST.elements.instructions.termination_instructions.
BranchOperation
(condition, target_true, target_false)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST node of the LLVM Termination Instructions group - Branch Instruction https://llvm.org/docs/LangRef.html#terminators
-
get_uses
()¶ Returns a list containing the names of the registers used by this instruction. (used by register allocation)
-
replace_reg_name
(old_reg_name, new_reg_name)¶ Replaces the name of a register used by the instruction with a new one. (used by register allocation)
-
run
()¶ Executes the branch operation.
-
-
class
ScEpTIC.AST.elements.instructions.termination_instructions.
ReturnOperation
(value)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST node of the LLVM Termination Instructions group - Return Instruction https://llvm.org/docs/LangRef.html#terminators
-
get_uses
()¶ Returns a list containing the names of the registers used by this instruction. (used by register allocation)
-
memory_tick_count
= 2¶
-
n_memory_instructions
= 2¶
-
replace_reg_name
(old_reg_name, new_reg_name)¶ Replaces the name of a register used by the instruction with a new one. (used by register allocation)
-
run
()¶ Retrieves the value of the return operation and calls the return’s callback.
-
tick_count
= 6¶
-
-
class
ScEpTIC.AST.elements.instructions.termination_instructions.
SwitchOperation
(element, default_label, switch_pairs)¶ Bases:
ScEpTIC.AST.elements.instruction.Instruction
AST node of the LLVM Termination Instructions group - Switch Instruction https://llvm.org/docs/LangRef.html#terminators
-
get_uses
()¶ Returns a list containing the names of the registers used by this instruction. (used by register allocation)
-
replace_reg_name
(old_reg_name, new_reg_name)¶ Replaces the name of a register used by the instruction with a new one. (used by register allocation)
-
run
()¶ Executes the switch operation.
-