#include <ira.h>
Field Documentation
enum reg_class target_ira::x_ira_allocno_class_translate[N_REG_CLASSES] |
Map of all register classes to corresponding allocno classes containing the given class. If given class is not a subset of an allocno class, we translate it into the cheapest allocno class.
enum reg_class target_ira::x_ira_allocno_classes[N_REG_CLASSES] |
The array containing allocno classes. Only first IRA_ALLOCNO_CLASSES_NUM elements are used for this.
int target_ira::x_ira_allocno_classes_num |
Number of allocno classes. Allocno classes are register classes which can be used for allocations of allocnos.
short target_ira::x_ira_class_hard_regs[N_REG_CLASSES][FIRST_PSEUDO_REGISTER] |
Array of number of hard registers of given class which are available for the allocation. The order is defined by the allocation order.
int target_ira::x_ira_class_hard_regs_num[N_REG_CLASSES] |
The number of elements of the above array for given register class.
short target_ira::x_ira_class_singleton[N_REG_CLASSES][MAX_MACHINE_MODE] |
If class CL has a single allocatable register of mode M, index [CL][M] gives the number of that register, otherwise it is -1.
int target_ira::x_ira_class_subset_p[N_REG_CLASSES][N_REG_CLASSES] |
Register class subset relation: TRUE if the first class is a subset of the second one considering only hard registers available for the allocation.
enum reg_class target_ira::x_ira_hard_regno_allocno_class[FIRST_PSEUDO_REGISTER] |
Map: hard register number -> allocno class it belongs to. If the corresponding class is NO_REGS, the hard register is not available for allocation.
short target_ira::x_ira_memory_move_cost[MAX_MACHINE_MODE][N_REG_CLASSES][2] |
Array analogous to target hook TARGET_MEMORY_MOVE_COST.
Function specific hard registers can not be used for the register allocation.
enum reg_class target_ira::x_ira_pressure_class_translate[N_REG_CLASSES] |
Map of all register classes to corresponding pressure classes containing the given class. If given class is not a subset of an pressure class, we translate it into the cheapest pressure class.
enum reg_class target_ira::x_ira_pressure_classes[N_REG_CLASSES] |
The array containing pressure classes. Only first IRA_PRESSURE_CLASSES_NUM elements are used for this.
int target_ira::x_ira_pressure_classes_num |
Number of pressure classes. Pressure classes are register classes for which we calculate register pressure.
unsigned char target_ira::x_ira_reg_class_max_nregs[N_REG_CLASSES][MAX_MACHINE_MODE] |
Maps: register class x machine mode -> maximal/minimal number of hard registers of given class needed to store value of given mode.
unsigned char target_ira::x_ira_reg_class_min_nregs[N_REG_CLASSES][MAX_MACHINE_MODE] |
enum reg_class target_ira::x_ira_reg_class_subset[N_REG_CLASSES][N_REG_CLASSES] |
The biggest class inside of intersection of the two classes (that is calculated taking only hard registers available for allocation into account. If the both classes contain no hard registers available for allocation, the value is calculated with taking all hard-registers including fixed ones into account.
bool target_ira::x_ira_reg_classes_intersect_p[N_REG_CLASSES][N_REG_CLASSES] |
True if the two classes (that is calculated taking only hard registers available for allocation into account; are intersected.
enum reg_class target_ira::x_ira_stack_reg_pressure_class |
Bigest pressure register class containing stack registers. NO_REGS if there are no stack registers.
The documentation for this struct was generated from the following file: