1 //===- ARMRelocationFunction.h --------------------------------------------===//
2 //
3 //                     The MCLinker Project
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 
10 #define DECL_ARM_APPLY_RELOC_FUNC(Name) \
11 static ARMRelocator::Result Name    (Relocation& pEntry, \
12                                      ARMRelocator& pParent);
13 
14 #define DECL_ARM_APPLY_RELOC_FUNCS \
15 DECL_ARM_APPLY_RELOC_FUNC(none)             \
16 DECL_ARM_APPLY_RELOC_FUNC(abs32)            \
17 DECL_ARM_APPLY_RELOC_FUNC(rel32)            \
18 DECL_ARM_APPLY_RELOC_FUNC(gotoff32)         \
19 DECL_ARM_APPLY_RELOC_FUNC(base_prel)        \
20 DECL_ARM_APPLY_RELOC_FUNC(got_brel)         \
21 DECL_ARM_APPLY_RELOC_FUNC(call)             \
22 DECL_ARM_APPLY_RELOC_FUNC(thm_call)         \
23 DECL_ARM_APPLY_RELOC_FUNC(movw_prel_nc)     \
24 DECL_ARM_APPLY_RELOC_FUNC(movw_abs_nc)      \
25 DECL_ARM_APPLY_RELOC_FUNC(movt_abs)         \
26 DECL_ARM_APPLY_RELOC_FUNC(movt_prel)        \
27 DECL_ARM_APPLY_RELOC_FUNC(thm_movw_abs_nc)  \
28 DECL_ARM_APPLY_RELOC_FUNC(thm_movw_prel_nc) \
29 DECL_ARM_APPLY_RELOC_FUNC(thm_movw_brel)    \
30 DECL_ARM_APPLY_RELOC_FUNC(thm_movt_abs)     \
31 DECL_ARM_APPLY_RELOC_FUNC(thm_movt_prel)    \
32 DECL_ARM_APPLY_RELOC_FUNC(prel31)           \
33 DECL_ARM_APPLY_RELOC_FUNC(got_prel)         \
34 DECL_ARM_APPLY_RELOC_FUNC(tls)              \
35 DECL_ARM_APPLY_RELOC_FUNC(thm_jump8)        \
36 DECL_ARM_APPLY_RELOC_FUNC(thm_jump11)       \
37 DECL_ARM_APPLY_RELOC_FUNC(thm_jump19)       \
38 DECL_ARM_APPLY_RELOC_FUNC(unsupport)
39 
40 
41 #define DECL_ARM_APPLY_RELOC_FUNC_PTRS \
42   { &none,               0, "R_ARM_NONE"              },  \
43   { &call,               1, "R_ARM_PC24"              },  \
44   { &abs32,              2, "R_ARM_ABS32"             },  \
45   { &rel32,              3, "R_ARM_REL32"             },  \
46   { &unsupport,          4, "R_ARM_LDR_PC_G0"         },  \
47   { &unsupport,          5, "R_ARM_ABS16"             },  \
48   { &unsupport,          6, "R_ARM_ABS12"             },  \
49   { &unsupport,          7, "R_ARM_THM_ABS5"          },  \
50   { &unsupport,          8, "R_ARM_ABS8"              },  \
51   { &unsupport,          9, "R_ARM_SBREL32"           },  \
52   { &thm_call,          10, "R_ARM_THM_CALL"          },  \
53   { &unsupport,         11, "R_ARM_THM_PC8"           },  \
54   { &unsupport,         12, "R_ARM_BREL_ADJ"          },  \
55   { &unsupport,         13, "R_ARM_TLS_DESC"          },  \
56   { &unsupport,         14, "R_ARM_THM_SWI8"          },  \
57   { &unsupport,         15, "R_ARM_XPC25"             },  \
58   { &unsupport,         16, "R_ARM_THM_XPC22"         },  \
59   { &unsupport,         17, "R_ARM_TLS_DTPMOD32"      },  \
60   { &unsupport,         18, "R_ARM_TLS_DTPOFF32"      },  \
61   { &unsupport,         19, "R_ARM_TLS_TPOFF32"       },  \
62   { &unsupport,         20, "R_ARM_COPY"              },  \
63   { &unsupport,         21, "R_ARM_GLOB_DAT"          },  \
64   { &unsupport,         22, "R_ARM_JUMP_SLOT"         },  \
65   { &unsupport,         23, "R_ARM_RELATIVE"          },  \
66   { &gotoff32,          24, "R_ARM_GOTOFF32"          },  \
67   { &base_prel,         25, "R_ARM_BASE_PREL"         },  \
68   { &got_brel,          26, "R_ARM_GOT_BREL"          },  \
69   { &call,              27, "R_ARM_PLT32"             },  \
70   { &call,              28, "R_ARM_CALL"              },  \
71   { &call,              29, "R_ARM_JUMP24"            },  \
72   { &thm_call,          30, "R_ARM_THM_JUMP24"        },  \
73   { &unsupport,         31, "R_ARM_BASE_ABS"          },  \
74   { &unsupport,         32, "R_ARM_ALU_PCREL_7_0"     },  \
75   { &unsupport,         33, "R_ARM_ALU_PCREL_15_8"    },  \
76   { &unsupport,         34, "R_ARM_ALU_PCREL_23_15"   },  \
77   { &unsupport,         35, "R_ARM_LDR_SBREL_11_0_NC" },  \
78   { &unsupport,         36, "R_ARM_ALU_SBREL_19_12_NC"},  \
79   { &unsupport,         37, "R_ARM_ALU_SBREL_27_20_CK"},  \
80   { &abs32,             38, "R_ARM_TARGET1"           },  \
81   { &unsupport,         39, "R_ARM_SBREL31"           },  \
82   { &none,              40, "R_ARM_V4BX"              },  \
83   { &got_prel,          41, "R_ARM_TARGET2"           },  \
84   { &prel31,            42, "R_ARM_PREL31"            },  \
85   { &movw_abs_nc,       43, "R_ARM_MOVW_ABS_NC"       },  \
86   { &movt_abs,          44, "R_ARM_MOVT_ABS"          },  \
87   { &movw_prel_nc,      45, "R_ARM_MOVW_PREL_NC"      },  \
88   { &movt_prel,         46, "R_ARM_MOVT_PREL"         },  \
89   { &thm_movw_abs_nc,   47, "R_ARM_THM_MOVW_ABS_NC"   },  \
90   { &thm_movt_abs,      48, "R_ARM_THM_MOVT_ABS"      },  \
91   { &thm_movw_prel_nc,  49, "R_ARM_THM_MOVW_PREL_NC"  },  \
92   { &thm_movt_prel,     50, "R_ARM_THM_MOVT_PREL"     },  \
93   { &thm_jump19,        51, "R_ARM_THM_JUMP19"        },  \
94   { &unsupport,         52, "R_ARM_THM_JUMP6"         },  \
95   { &unsupport,         53, "R_ARM_THM_ALU_PREL_11_0" },  \
96   { &unsupport,         54, "R_ARM_THM_PC12"          },  \
97   { &unsupport,         55, "R_ARM_ABS32_NOI"         },  \
98   { &unsupport,         56, "R_ARM_REL32_NOI"         },  \
99   { &unsupport,         57, "R_ARM_ALU_PC_G0_NC"      },  \
100   { &unsupport,         58, "R_ARM_ALU_PC_G0"         },  \
101   { &unsupport,         59, "R_ARM_ALU_PC_G1_NC"      },  \
102   { &unsupport,         60, "R_ARM_ALU_PC_G1"         },  \
103   { &unsupport,         61, "R_ARM_ALU_PC_G2"         },  \
104   { &unsupport,         62, "R_ARM_LDR_PC_G1"         },  \
105   { &unsupport,         63, "R_ARM_LDR_PC_G2"         },  \
106   { &unsupport,         64, "R_ARM_LDRS_PC_G0"        },  \
107   { &unsupport,         65, "R_ARM_LDRS_PC_G1"        },  \
108   { &unsupport,         66, "R_ARM_LDRS_PC_G2"        },  \
109   { &unsupport,         67, "R_ARM_LDC_PC_G0"         },  \
110   { &unsupport,         68, "R_ARM_LDC_PC_G1"         },  \
111   { &unsupport,         69, "R_ARM_LDC_PC_G2"         },  \
112   { &unsupport,         70, "R_ARM_ALU_SB_G0_NC"      },  \
113   { &unsupport,         71, "R_ARM_ALU_SB_G0"         },  \
114   { &unsupport,         72, "R_ARM_ALU_SB_G1_NC"      },  \
115   { &unsupport,         73, "R_ARM_ALU_SB_G1"         },  \
116   { &unsupport,         74, "R_ARM_ALU_SB_G2"         },  \
117   { &unsupport,         75, "R_ARM_LDR_SB_G0"         },  \
118   { &unsupport,         76, "R_ARM_LDR_SB_G1"         },  \
119   { &unsupport,         77, "R_ARM_LDR_SB_G2"         },  \
120   { &unsupport,         78, "R_ARM_LDRS_SB_G0"        },  \
121   { &unsupport,         79, "R_ARM_LDRS_SB_G1"        },  \
122   { &unsupport,         80, "R_ARM_LDRS_SB_G2"        },  \
123   { &unsupport,         81, "R_ARM_LDC_SB_G0"         },  \
124   { &unsupport,         82, "R_ARM_LDC_SB_G1"         },  \
125   { &unsupport,         83, "R_ARM_LDC_SB_G2"         },  \
126   { &unsupport,         84, "R_ARM_MOVW_BREL_NC"      },  \
127   { &unsupport,         85, "R_ARM_MOVT_BREL"         },  \
128   { &unsupport,         86, "R_ARM_MOVW_BREL"         },  \
129   { &thm_movw_brel,     87, "R_ARM_THM_MOVW_BREL_NC"  },  \
130   { &thm_movt_prel,     88, "R_ARM_THM_MOVT_BREL"     },  \
131   { &thm_movw_brel,     89, "R_ARM_THM_MOVW_BREL"     },  \
132   { &unsupport,         90, "R_ARM_TLS_GOTDESC"       },  \
133   { &unsupport,         91, "R_ARM_TLS_CALL"          },  \
134   { &unsupport,         92, "R_ARM_TLS_DESCSEQ"       },  \
135   { &unsupport,         93, "R_ARM_THM_TLS_CALL"      },  \
136   { &unsupport,         94, "R_ARM_PLT32_ABS"         },  \
137   { &unsupport,         95, "R_ARM_GOT_ABS"           },  \
138   { &got_prel,          96, "R_ARM_GOT_PREL"          },  \
139   { &unsupport,         97, "R_ARM_GOT_PREL12"        },  \
140   { &unsupport,         98, "R_ARM_GOTOFF12"          },  \
141   { &unsupport,         99, "R_ARM_GOTRELAX"          },  \
142   { &unsupport,        100, "R_ARM_GNU_VTENTRY"       },  \
143   { &unsupport,        101, "R_ARM_GNU_VTINERIT"      },  \
144   { &thm_jump11,       102, "R_ARM_THM_JUMP11"        },  \
145   { &thm_jump8,        103, "R_ARM_THM_JUMP8"         },  \
146   { &tls,              104, "R_ARM_TLS_GD32"          },  \
147   { &unsupport,        105, "R_ARM_TLS_LDM32"         },  \
148   { &unsupport,        106, "R_ARM_TLS_LDO32"         },  \
149   { &tls,              107, "R_ARM_TLS_IE32"          },  \
150   { &tls,              108, "R_ARM_TLS_LE32"          },  \
151   { &unsupport,        109, "R_ARM_TLS_LDO12"         },  \
152   { &unsupport,        110, "R_ARM_TLS_LE12"          },  \
153   { &unsupport,        111, "R_ARM_TLS_IE12GP"        },  \
154   { &unsupport,        112, "R_ARM_PRIVATE_0"         },  \
155   { &unsupport,        113, "R_ARM_PRIVATE_1"         },  \
156   { &unsupport,        114, "R_ARM_PRIVATE_2"         },  \
157   { &unsupport,        115, "R_ARM_PRIVATE_3"         },  \
158   { &unsupport,        116, "R_ARM_PRIVATE_4"         },  \
159   { &unsupport,        117, "R_ARM_PRIVATE_5"         },  \
160   { &unsupport,        118, "R_ARM_PRIVATE_6"         },  \
161   { &unsupport,        119, "R_ARM_PRIVATE_7"         },  \
162   { &unsupport,        120, "R_ARM_PRIVATE_8"         },  \
163   { &unsupport,        121, "R_ARM_PRIVATE_9"         },  \
164   { &unsupport,        122, "R_ARM_PRIVATE_10"        },  \
165   { &unsupport,        123, "R_ARM_PRIVATE_11"        },  \
166   { &unsupport,        124, "R_ARM_PRIVATE_12"        },  \
167   { &unsupport,        125, "R_ARM_PRIVATE_13"        },  \
168   { &unsupport,        126, "R_ARM_PRIVATE_14"        },  \
169   { &unsupport,        127, "R_ARM_PRIVATE_15"        },  \
170   { &unsupport,        128, "R_ARM_ME_TOO"            },  \
171   { &unsupport,        129, "R_ARM_THM_TLS_DESCSEQ16" },  \
172   { &unsupport,        130, "R_ARM_THM_TLS_DESCSEQ32" }
173