| /linux/tools/objtool/include/objtool/ |
| H A D | elf.h | 55 struct reloc *relocs; 93 struct reloc *relocs; 99 struct reloc { 158 struct reloc *elf_create_reloc(struct elf *elf, struct section *sec, in has_multiple_files() 162 struct reloc *elf_init_reloc(struct elf *elf, struct section *rsec, in elf_addr_size() 166 struct reloc *elf_init_reloc_text_sym(struct elf *elf, struct section *sec, in elf_rela_size() 172 struct reloc *elf_init_reloc_data_sym(struct elf *elf, struct section *sec, in elf_data_rela_type() 191 struct reloc *find_reloc_by_dest(const struct elf *elf, struct section *sec, unsigned long offset); in mark_sec_changed() 192 struct reloc *find_reloc_by_dest_range(const struct elf *elf, struct section *sec, in mark_sec_changed() 313 static inline unsigned int reloc_idx(struct reloc *relo in set_jump_table() 79 struct reloc { global() struct 83 _sym_next_relocreloc global() argument 203 reloc_idx(struct reloc * reloc) reloc_idx() argument 208 reloc_rel(struct reloc * reloc) reloc_rel() argument 215 is_32bit_reloc(struct reloc * reloc) is_32bit_reloc() argument 226 __get_reloc_field(reloc,field) global() argument 233 __set_reloc_field(reloc,field,val) global() argument 241 reloc_offset(struct reloc * reloc) reloc_offset() argument 246 set_reloc_offset(struct elf * elf,struct reloc * reloc,u64 offset) set_reloc_offset() argument 252 reloc_addend(struct reloc * reloc) reloc_addend() argument 257 set_reloc_addend(struct elf * elf,struct reloc * reloc,s64 addend) set_reloc_addend() argument 264 reloc_sym(struct reloc * reloc) reloc_sym() argument 273 reloc_type(struct reloc * reloc) reloc_type() argument 282 set_reloc_sym(struct elf * elf,struct reloc * reloc,unsigned int sym) set_reloc_sym() argument 292 set_reloc_type(struct elf * elf,struct reloc * reloc,unsigned int type) set_reloc_type() argument 306 is_jump_table(struct reloc * reloc) is_jump_table() argument 311 set_jump_table(struct reloc * reloc) set_jump_table() argument 316 sym_next_reloc(struct reloc * reloc) sym_next_reloc() argument 321 set_sym_next_reloc(struct reloc * reloc,struct reloc * next) set_sym_next_reloc() argument 340 for_each_reloc(rsec,reloc) global() argument 346 for_each_reloc_from(rsec,reloc) global() argument 375 reloc_hash(struct reloc * reloc) reloc_hash() argument [all...] |
| H A D | arch.h | 86 s64 arch_insn_adjusted_addend(struct instruction *insn, struct reloc *reloc); 87 u64 arch_adjusted_addend(struct reloc *reloc); 100 bool arch_pc_relative_reloc(struct reloc *reloc); 101 bool arch_absolute_reloc(struct elf *elf, struct reloc *reloc); 103 unsigned int arch_reloc_size(struct reloc *reloc); [all...] |
| H A D | special.h | 37 struct reloc *reloc); 38 struct reloc *arch_find_switch_table(struct objtool_file *file,
|
| /linux/tools/objtool/arch/loongarch/ |
| H A D | special.c | 8 struct reloc *reloc) in arch_support_alt_relocation() argument 24 struct reloc *reloc; in get_rodata_table_size_by_table_annotate() local 38 for_each_reloc(rsec, reloc) { in get_rodata_table_size_by_table_annotate() 39 if (reloc->sym->sec->rodata) in get_rodata_table_size_by_table_annotate() 42 if (strcmp(insn->sec->name, reloc->sym->sec->name)) in get_rodata_table_size_by_table_annotate() 51 orig_table->insn_offset = reloc->sym->offset + reloc_addend(reloc); in get_rodata_table_size_by_table_annotate() 52 reloc in get_rodata_table_size_by_table_annotate() 117 struct reloc *reloc; find_reloc_by_table_annotate() local 147 struct reloc *reloc; find_reloc_of_rodata_c_jump_table() local [all...] |
| /linux/tools/objtool/ |
| H A D | klp-diff.c | 190 struct reloc *reloc; in read_sym_checksums() local 195 reloc = find_reloc_by_dest(elf, sec, i * sizeof(*sym_checksum)); in read_sym_checksums() 196 if (!reloc) { in read_sym_checksums() 201 sym = reloc->sym; in read_sym_checksums() 754 static bool is_reloc_allowed(struct reloc *reloc) in is_reloc_allowed() argument 756 return section_reference_needed(reloc->sym->sec) == is_sec_sym(reloc->sym); in is_reloc_allowed() 826 static bool klp_reloc_needed(struct reloc *patched_reloc) in klp_reloc_needed() 867 static int convert_reloc_sym_to_secsym(struct elf *elf, struct reloc *reloc) in convert_reloc_sym_to_secsym() argument 869 struct symbol *sym = reloc->sym; in convert_reloc_sym_to_secsym() 875 reloc->sym = sec->sym; in convert_reloc_sym_to_secsym() [all …]
|
| H A D | elf.c | 319 struct reloc *find_reloc_by_dest_range(const struct elf *elf, struct section *sec, in find_reloc_by_dest_range() 322 struct reloc *reloc, *r = NULL; in find_reloc_by_dest_range() local 331 elf_hash_for_each_possible(reloc, reloc, hash, in find_reloc_by_dest_range() 333 if (reloc->sec != rsec) in find_reloc_by_dest_range() 336 if (reloc_offset(reloc) >= offset && in find_reloc_by_dest_range() 337 reloc_offset(reloc) < offset + len) { in find_reloc_by_dest_range() 338 if (!r || reloc_offset(reloc) < reloc_offset(r)) in find_reloc_by_dest_range() 339 r = reloc; in find_reloc_by_dest_range() 349 struct reloc *find_reloc_by_dest(const struct elf *elf, struct section *sec, unsigned long offset) in find_reloc_by_dest() 716 struct reloc *reloc; in elf_update_sym_relocs() local [all …]
|
| H A D | check.c | 138 static inline struct reloc *insn_jump_table(struct instruction *insn) in insn_jump_table() 558 struct reloc *reloc; in add_pv_ops() local 578 reloc = find_reloc_by_dest_range(file->elf, sym->sec, off, end - off); in add_pv_ops() 579 if (!reloc) in add_pv_ops() 582 idx = (reloc_offset(reloc) - sym->offset) / sizeof(unsigned long); in add_pv_ops() 584 func = reloc->sym; in add_pv_ops() 586 func = find_symbol_by_offset(reloc->sym->sec, in add_pv_ops() 587 reloc_addend(reloc)); in add_pv_ops() 589 ERROR_FUNC(reloc->sym->sec, reloc_addend(reloc), in add_pv_ops() 597 off = reloc_offset(reloc) + 1; in add_pv_ops() [all …]
|
| /linux/drivers/gpu/drm/radeon/ |
| H A D | r600_cs.c | 974 struct radeon_bo_list *reloc; in r600_cs_check_reg() local 1019 r = radeon_cs_packet_next_reloc(p, &reloc, 0); in r600_cs_check_reg() 1025 ib[idx] += (u32)((reloc->gpu_offset >> 8) & 0xffffffff); in r600_cs_check_reg() 1037 r = radeon_cs_packet_next_reloc(p, &reloc, r600_nomm); in r600_cs_check_reg() 1046 if (reloc->tiling_flags & RADEON_TILING_MACRO) { in r600_cs_check_reg() 1079 r = radeon_cs_packet_next_reloc(p, &reloc, r600_nomm); in r600_cs_check_reg() 1087 ib[idx] += (u32)((reloc->gpu_offset >> 8) & 0xffffffff); in r600_cs_check_reg() 1088 track->vgt_strmout_bo[tmp] = reloc->robj; in r600_cs_check_reg() 1089 track->vgt_strmout_bo_mc[tmp] = reloc->gpu_offset; in r600_cs_check_reg() 1102 r = radeon_cs_packet_next_reloc(p, &reloc, r600_nomm); in r600_cs_check_reg() [all …]
|
| H A D | evergreen_cs.c | 1098 struct radeon_bo_list *reloc; in evergreen_cs_handle_reg() local 1144 r = radeon_cs_packet_next_reloc(p, &reloc, 0); in evergreen_cs_handle_reg() 1150 ib[idx] += (u32)((reloc->gpu_offset >> 8) & 0xffffffff); in evergreen_cs_handle_reg() 1173 r = radeon_cs_packet_next_reloc(p, &reloc, 0); in evergreen_cs_handle_reg() 1181 ib[idx] |= Z_ARRAY_MODE(evergreen_cs_get_aray_mode(reloc->tiling_flags)); in evergreen_cs_handle_reg() 1182 track->db_z_info |= Z_ARRAY_MODE(evergreen_cs_get_aray_mode(reloc->tiling_flags)); in evergreen_cs_handle_reg() 1183 if (reloc->tiling_flags & RADEON_TILING_MACRO) { in evergreen_cs_handle_reg() 1186 evergreen_tiling_fields(reloc->tiling_flags, in evergreen_cs_handle_reg() 1215 r = radeon_cs_packet_next_reloc(p, &reloc, 0); in evergreen_cs_handle_reg() 1222 ib[idx] += (u32)((reloc->gpu_offset >> 8) & 0xffffffff); in evergreen_cs_handle_reg() [all …]
|
| H A D | r300.c | 631 struct radeon_bo_list *reloc; in r300_packet0_check() local 665 r = radeon_cs_packet_next_reloc(p, &reloc, 0); in r300_packet0_check() 672 track->cb[i].robj = reloc->robj; in r300_packet0_check() 675 ib[idx] = idx_value + ((u32)reloc->gpu_offset); in r300_packet0_check() 678 r = radeon_cs_packet_next_reloc(p, &reloc, 0); in r300_packet0_check() 685 track->zb.robj = reloc->robj; in r300_packet0_check() 688 ib[idx] = idx_value + ((u32)reloc->gpu_offset); in r300_packet0_check() 707 r = radeon_cs_packet_next_reloc(p, &reloc, 0); in r300_packet0_check() 717 ((idx_value & ~31) + (u32)reloc->gpu_offset); in r300_packet0_check() 719 if (reloc->tiling_flags & RADEON_TILING_MACRO) in r300_packet0_check() [all …]
|
| /linux/drivers/gpu/drm/qxl/ |
| H A D | qxl_ioctl.c | 205 struct drm_qxl_reloc reloc; in qxl_process_single_command() local 208 if (copy_from_user(&reloc, u + i, sizeof(reloc))) { in qxl_process_single_command() 215 if (reloc.reloc_type != QXL_RELOC_TYPE_BO && reloc.reloc_type != QXL_RELOC_TYPE_SURF) { in qxl_process_single_command() 216 DRM_DEBUG("unknown reloc type %d\n", reloc.reloc_type); in qxl_process_single_command() 221 reloc_info[i].type = reloc.reloc_type; in qxl_process_single_command() 223 if (reloc.dst_handle) { in qxl_process_single_command() 224 ret = qxlhw_handle_to_bo(file_priv, reloc.dst_handle, release, in qxl_process_single_command() 228 reloc_info[i].dst_offset = reloc.dst_offset; in qxl_process_single_command() 231 reloc_info[i].dst_offset = reloc.dst_offset + release->release_offset; in qxl_process_single_command() 235 if (reloc.reloc_type == QXL_RELOC_TYPE_BO || reloc.src_handle) { in qxl_process_single_command() [all …]
|
| /linux/drivers/gpu/host1x/ |
| H A D | job.c | 153 struct host1x_reloc *reloc = &job->relocs[i]; in pin_job() local 158 reloc->target.bo = host1x_bo_get(reloc->target.bo); in pin_job() 159 if (!reloc->target.bo) { in pin_job() 164 bo = reloc->target.bo; in pin_job() 166 switch (reloc->flags & mask) { in pin_job() 287 struct host1x_reloc *reloc = &job->relocs[i]; in do_relocs() local 289 reloc->target.offset) >> reloc->shift; in do_relocs() 293 if (cmdbuf != reloc->cmdbuf.bo) in do_relocs() 298 reloc->cmdbuf.offset / sizeof(u32) + in do_relocs() 312 target = cmdbuf_addr + reloc->cmdbuf.offset; in do_relocs() [all …]
|
| /linux/arch/x86/boot/compressed/ |
| H A D | misc.c | 201 int *reloc; in handle_relocations() local 252 for (reloc = output + output_len - sizeof(*reloc); *reloc; reloc--) { in handle_relocations() 253 long extended = *reloc; in handle_relocations() 263 for (reloc--; *reloc; reloc--) { in handle_relocations() 264 long extended = *reloc; in handle_relocations()
|
| /linux/arch/riscv/kernel/tests/module_test/ |
| H A D | test_uleb128.S | 23 .reloc second, R_RISCV_SET_ULEB128, second 24 .reloc second, R_RISCV_SUB_ULEB128, first 29 .reloc fourth, R_RISCV_SET_ULEB128, fourth 30 .reloc fourth, R_RISCV_SUB_ULEB128, third
|
| H A D | test_sub32.S | 18 .reloc sub32, R_RISCV_ADD32, second 19 .reloc sub32, R_RISCV_SUB32, first
|
| H A D | test_sub16.S | 18 .reloc sub16, R_RISCV_ADD16, second 19 .reloc sub16, R_RISCV_SUB16, first
|
| H A D | test_sub8.S | 18 .reloc sub8, R_RISCV_ADD8, second 19 .reloc sub8, R_RISCV_SUB8, first
|
| H A D | test_sub6.S | 18 .reloc sub6, R_RISCV_SET6, second 19 .reloc sub6, R_RISCV_SUB6, first
|
| H A D | test_sub64.S | 22 .reloc sub64, R_RISCV_ADD64, second 23 .reloc sub64, R_RISCV_SUB64, first
|
| /linux/tools/objtool/arch/powerpc/ |
| H A D | special.c | 10 struct reloc *reloc) in arch_support_alt_relocation() argument 15 struct reloc *arch_find_switch_table(struct objtool_file *file, in arch_find_switch_table()
|
| /linux/tools/objtool/arch/x86/ |
| H A D | special.c | 40 struct reloc *reloc) 85 struct reloc *arch_find_switch_table(struct objtool_file *file, in arch_find_switch_table() 89 struct reloc *text_reloc, *rodata_reloc; in arch_find_switch_table() 36 arch_support_alt_relocation(struct special_alt * special_alt,struct instruction * insn,struct reloc * reloc) arch_support_alt_relocation() argument
|
| H A D | decode.c | 90 s64 arch_insn_adjusted_addend(struct instruction *insn, struct reloc *reloc) in arch_pc_relative_reloc() 92 s64 addend = reloc_addend(reloc); in arch_pc_relative_reloc() 94 if (arch_pc_relative_reloc(reloc)) in arch_pc_relative_reloc() 95 addend += insn->offset + insn->len - reloc_offset(reloc); in arch_pc_relative_reloc() 121 u64 arch_adjusted_addend(struct reloc *reloc) 123 unsigned int type = reloc_type(reloc); 124 s64 addend = reloc_addend(reloc); 131 if (type != R_X86_64_PC32 || !is_text_sec(reloc 81 arch_pc_relative_reloc(struct reloc * reloc) arch_pc_relative_reloc() argument 871 arch_reloc_size(struct reloc * reloc) arch_reloc_size() argument 884 arch_absolute_reloc(struct elf * elf,struct reloc * reloc) arch_absolute_reloc() argument [all...] |
| /linux/arch/parisc/kernel/ |
| H A D | kexec.c | 76 void (*reloc)(unsigned long head, in machine_kexec() local 89 reloc = (void *)&desc; in machine_kexec() 92 reloc = (void *)virt; in machine_kexec() 107 reloc(image->head & PAGE_MASK, image->start, phys); in machine_kexec()
|
| /linux/scripts/ |
| H A D | check_extable.sh | 42 eval $(echo $reloc | sed 's/\([^+]\+\)+\?\(0x[0-9a-f]\+\)\?/symbol="\1"; symbol_offset="\2"/') 109 for reloc in ${suspicious_relocs}; do 112 find_symbol_and_offset_from_reloc ${reloc}
|
| /linux/fs/ |
| H A D | binfmt_flat.c | 350 ptr = (unsigned long __user *)(current->mm->start_code + r.reloc.offset); in old_reloc() 352 ptr = (unsigned long __user *)(current->mm->start_data + r.reloc.offset); in old_reloc() 358 r.reloc.offset, ptr, val, segment[r.reloc.type]); in old_reloc() 360 switch (r.reloc.type) { in old_reloc() 371 pr_err("Unknown relocation type=%x\n", r.reloc.type); in old_reloc() 413 __be32 __user *reloc; in load_flat_file() local 586 reloc = (__be32 __user *) in load_flat_file() 612 reloc = (__be32 __user *) in load_flat_file() 783 if (get_user(tmp, reloc + i)) in load_flat_file() 826 if (get_user(relval, reloc + i)) in load_flat_file()
|