5 /* arg is a primitive number */
7 /* arg is a literal table index, holding an array pair (symbol/dll) */
9 /* a pointer to a compiled word reference */
11 /* a word or quotation's general entry point */
13 /* a word's PIC entry point */
15 /* a word's tail-call PIC entry point */
19 /* current code block */
21 /* data heap literal */
23 /* address of ctx var */
25 /* untagged fixnum literal */
27 /* address of megamorphic_cache_hits var */
28 RT_MEGAMORPHIC_CACHE_HITS,
29 /* address of vm object */
31 /* value of vm->cards_offset */
33 /* value of vm->decks_offset */
37 enum relocation_class {
38 /* absolute address in a 64-bit location */
40 /* absolute address in a 32-bit location */
42 /* relative address in a 32-bit location */
44 /* absolute address in a PowerPC LIS/ORI sequence */
46 /* absolute address in a PowerPC LWZ instruction */
48 /* relative address in a PowerPC LWZ/STW/BC instruction */
50 /* relative address in a PowerPC B/BL instruction */
52 /* relative address in an ARM B/BL instruction */
54 /* pointer to address in an ARM LDR/STR instruction */
56 /* pointer to address in an ARM LDR/STR instruction offset by 8 bytes */
58 /* absolute address in a 16-bit location */
62 static const cell rel_absolute_ppc_2_mask = 0xffff;
63 static const cell rel_relative_ppc_2_mask = 0xfffc;
64 static const cell rel_relative_ppc_3_mask = 0x3fffffc;
65 static const cell rel_indirect_arm_mask = 0xfff;
66 static const cell rel_relative_arm_3_mask = 0xffffff;
68 /* code relocation table consists of a table of entries for each fixup */
69 struct relocation_entry {
72 explicit relocation_entry(u32 value_) : value(value_) {}
74 relocation_entry(relocation_type rel_type,
75 relocation_class rel_class,
78 value = (rel_type << 28) | (rel_class << 24) | offset;
81 relocation_type rel_type()
83 return (relocation_type)((value & 0xf0000000) >> 28);
86 relocation_class rel_class()
88 return (relocation_class)((value & 0x0f000000) >> 24);
93 return (value & 0x00ffffff);
96 int number_of_parameters()
113 case RT_MEGAMORPHIC_CACHE_HITS:
114 case RT_CARDS_OFFSET:
115 case RT_DECKS_OFFSET:
118 critical_error("Bad rel type",rel_type());
119 return -1; /* Can't happen */
124 struct instruction_operand {
125 relocation_entry rel;
126 code_block *compiled;
130 instruction_operand(relocation_entry rel_, code_block *compiled_, cell index_);
132 relocation_type rel_type()
134 return rel.rel_type();
139 return rel.rel_offset();
142 cell parameter_index()
147 code_block *parent_code_block()
152 fixnum load_value_2_2();
153 fixnum load_value_masked(cell mask, cell bits, cell shift);
154 fixnum load_value(cell relative_to);
156 code_block *load_code_block(cell relative_to);
157 code_block *load_code_block();
159 void store_value_2_2(fixnum value);
160 void store_value_masked(fixnum value, cell mask, cell shift);
161 void store_value(fixnum value);
162 void store_code_block(code_block *compiled);