| /linux/arch/powerpc/kernel/trace/ |
| H A D | ftrace_64_pg.c | 135 unsigned long entry, ptr, tramp; in __ftrace_make_nop() local 158 tramp = find_bl_target(ip, op); in __ftrace_make_nop() 160 pr_devel("ip:%lx jumps to %lx", ip, tramp); in __ftrace_make_nop() 162 if (module_trampoline_target(mod, tramp, &ptr)) { in __ftrace_make_nop() 257 static int add_ftrace_tramp(unsigned long tramp) in add_ftrace_tramp() argument 263 ftrace_tramps[i] = tramp; in add_ftrace_tramp() 276 static int setup_mcount_compiler_tramp(unsigned long tramp) in setup_mcount_compiler_tramp() argument 284 if (ftrace_tramps[i] == tramp) in setup_mcount_compiler_tramp() 288 if (copy_inst_from_kernel_nofault(&op, (void *)tramp)) { in setup_mcount_compiler_tramp() 300 ptr = find_bl_target(tramp, op); in setup_mcount_compiler_tramp() [all …]
|
| H A D | ftrace.c | 141 return (addr == (unsigned long)ftrace_caller ? mod->arch.tramp : mod->arch.tramp_regs); in ftrace_lookup_module_stub() 278 mod->arch.tramp, 1); in ftrace_init_ool_stub() 598 static void __init add_ftrace_tramp(unsigned long tramp) in add_ftrace_tramp() argument 604 ftrace_tramps[i] = tramp; in add_ftrace_tramp() 611 unsigned int *tramp[] = { ftrace_tramp_text, ftrace_tramp_init }; in ftrace_dyn_arch_init() local 638 reladdr = addr - (unsigned long)tramp[i]; in ftrace_dyn_arch_init() 646 memcpy(tramp[i], stub_insns, sizeof(stub_insns)); in ftrace_dyn_arch_init() 647 tramp[i][0] |= IMM_H18(reladdr); in ftrace_dyn_arch_init() 648 tramp[i][1] |= IMM_L(reladdr); in ftrace_dyn_arch_init() 649 add_ftrace_tramp((unsigned long)tramp[i]); in ftrace_dyn_arch_init() [all …]
|
| /linux/arch/powerpc/kernel/ |
| H A D | static_call.c | 7 void arch_static_call_transform(void *site, void *tramp, void *func, bool tail) in arch_static_call_transform() argument 11 unsigned long _tramp = (unsigned long)tramp; in arch_static_call_transform() 14 bool is_short = is_offset_in_branch_range((long)func - (long)(site ? : tramp)); in arch_static_call_transform() 25 else if (tramp) in arch_static_call_transform() 36 else if (tramp) in arch_static_call_transform() 40 } else if (tramp) { in arch_static_call_transform() 42 err = patch_ulong(tramp + PPC_SCT_DATA, _func); in arch_static_call_transform() 48 err = patch_instruction(tramp, ppc_inst(PPC_RAW_BLR())); in arch_static_call_transform() 50 err = patch_branch(tramp, _ret0, 0); in arch_static_call_transform() 52 err = patch_branch(tramp, _func, 0); in arch_static_call_transform() [all …]
|
| H A D | signal_64.c | 61 unsigned int tramp[TRAMP_SIZE]; member 624 static long setup_trampoline(unsigned int syscall, unsigned int __user *tramp) in setup_trampoline() argument 630 err |= __put_user(PPC_RAW_BCTRL(), &tramp[0]); in setup_trampoline() 631 err |= __put_user(PPC_RAW_ADDI(_R1, _R1, __SIGNAL_FRAMESIZE), &tramp[1]); in setup_trampoline() 633 err |= __put_user(PPC_RAW_LI(_R0, syscall), &tramp[2]); in setup_trampoline() 634 err |= __put_user(PPC_RAW_SC(), &tramp[3]); in setup_trampoline() 638 err |= __put_user(0, &tramp[i]); in setup_trampoline() 641 flush_icache_range((unsigned long) &tramp[0], in setup_trampoline() 642 (unsigned long) &tramp[TRAMP_SIZE]); in setup_trampoline() 927 err |= setup_trampoline(__NR_rt_sigreturn, &frame->tramp[0]); in handle_rt_signal64() [all …]
|
| H A D | signal_32.c | 743 unsigned long tramp; in handle_rt_signal32() local 786 tramp = VDSO32_SYMBOL(tsk->mm->context.vdso, sigtramp_rt32); in handle_rt_signal32() 788 tramp = (unsigned long)mctx->mc_pad; in handle_rt_signal32() 800 regs->link = tramp; in handle_rt_signal32() 843 unsigned long tramp; in handle_signal32() local 882 tramp = VDSO32_SYMBOL(tsk->mm->context.vdso, sigtramp32); in handle_signal32() 884 tramp = (unsigned long)mctx->mc_pad; in handle_signal32() 891 regs->link = tramp; in handle_signal32()
|
| /linux/arch/x86/kernel/ |
| H A D | static_call.c | 122 static void __static_call_validate(u8 *insn, bool tail, bool tramp) in __static_call_validate() argument 126 if (tramp && memcmp(insn+5, tramp_ud, 3)) { in __static_call_validate() 166 void arch_static_call_transform(void *site, void *tramp, void *func, bool tail) in arch_static_call_transform() argument 170 if (tramp && !site) { in arch_static_call_transform() 171 __static_call_validate(tramp, true, true); in arch_static_call_transform() 172 __static_call_transform(tramp, __sc_insn(!func, true), func, false); in arch_static_call_transform() 184 noinstr void __static_call_update_early(void *tramp, void *func) in __static_call_update_early() argument 188 __text_gen_insn(tramp, JMP32_INSN_OPCODE, tramp, func, JMP32_INSN_SIZE); in __static_call_update_early() 204 bool __static_call_fixup(void *tramp, u8 op, void *dest) in __static_call_fixup() argument 206 unsigned long addr = (unsigned long)tramp; in __static_call_fixup() [all …]
|
| H A D | uprobes.c | 368 static unsigned long trampoline_check_ip(unsigned long tramp) in trampoline_check_ip() argument 370 return tramp + (uretprobe_syscall_check - uretprobe_trampoline_entry); in trampoline_check_ip() 377 unsigned long err, ip, sp, tramp; in SYSCALL_DEFINE0() local 380 tramp = uprobe_get_trampoline_vaddr(); in SYSCALL_DEFINE0() 381 if (unlikely(tramp == UPROBE_NO_TRAMPOLINE_VADDR)) in SYSCALL_DEFINE0() 385 if (unlikely(regs->ip != trampoline_check_ip(tramp))) in SYSCALL_DEFINE0() 689 struct uprobe_trampoline *tramp; in create_uprobe_trampoline() local 699 tramp = kzalloc_obj(*tramp); in create_uprobe_trampoline() 700 if (unlikely(!tramp)) in create_uprobe_trampoline() 703 tramp->vaddr = vaddr; in create_uprobe_trampoline() [all …]
|
| /linux/arch/arm64/kernel/ |
| H A D | static_call.c | 6 void arch_static_call_transform(void *site, void *tramp, void *func, bool tail) in arch_static_call_transform() argument 15 literal = ALIGN_DOWN((u64)tramp + 4, SZ_4K) + in arch_static_call_transform() 16 aarch64_insn_adrp_get_offset(le32_to_cpup(tramp + 4)) + in arch_static_call_transform() 18 le32_to_cpup(tramp + 8)); in arch_static_call_transform()
|
| H A D | module-plts.c | 286 Elf_Shdr *pltsec, *tramp = NULL, *init_tramp = NULL; in module_frob_arch_sections() local 300 tramp = sechdrs + i; in module_frob_arch_sections() 362 if (tramp) { in module_frob_arch_sections() 363 tramp->sh_type = SHT_NOBITS; in module_frob_arch_sections() 364 tramp->sh_flags = SHF_EXECINSTR | SHF_ALLOC; in module_frob_arch_sections() 365 tramp->sh_addralign = __alignof__(struct plt_entry); in module_frob_arch_sections() 366 tramp->sh_size = NR_FTRACE_PLTS * sizeof(struct plt_entry); in module_frob_arch_sections()
|
| H A D | vmlinux.lds.S | 128 *(.entry.tramp.text) \ 131 *(.entry.tramp.rodata)
|
| /linux/arch/x86/hyperv/ |
| H A D | hv_crash.c | 453 struct hv_crash_tramp_data *tramp; in hv_crash_setup_trampdata() local 475 tramp = (struct hv_crash_tramp_data *)dest; in hv_crash_setup_trampdata() 480 tramp->tramp32_cr3 = __sme_pa(hv_crash_ptpgs[0]); in hv_crash_setup_trampdata() 483 tramp->kernel_cr3 = __sme_pa(init_mm.pgd); in hv_crash_setup_trampdata() 485 tramp->gdtr32.limit = sizeof(struct hv_crash_tramp_gdt); in hv_crash_setup_trampdata() 486 tramp->gdtr32.address = trampoline_pa + in hv_crash_setup_trampdata() 487 (ulong)&tramp->tramp_gdt - trampoline_va; in hv_crash_setup_trampdata() 490 tramp->tramp_gdt.cs64 = 0x00af9a000000ffff; in hv_crash_setup_trampdata() 492 tramp->cs_jmptgt.csval = 0x8; in hv_crash_setup_trampdata() 494 tramp->cs_jmptgt.address = trampoline_pa + offs; in hv_crash_setup_trampdata() [all …]
|
| /linux/include/linux/ |
| H A D | static_call.h | 144 extern void arch_static_call_transform(void *site, void *tramp, void *func, bool tail); 177 s32 tramp; member 181 extern void __static_call_update(struct static_call_key *key, void *tramp, void *func); 258 void __static_call_update(struct static_call_key *key, void *tramp, void *func) in __static_call_update() argument 262 arch_static_call_transform(NULL, tramp, func, false); in __static_call_update() 337 void __static_call_update(struct static_call_key *key, void *tramp, void *func) in __static_call_update() argument
|
| /linux/arch/loongarch/kernel/ |
| H A D | module-sections.c | 109 Elf_Shdr *got_sec, *plt_sec, *plt_idx_sec, *tramp = NULL; in module_frob_arch_sections() local 122 tramp = sechdrs + i; in module_frob_arch_sections() 178 if (tramp) { in module_frob_arch_sections() 179 tramp->sh_type = SHT_NOBITS; in module_frob_arch_sections() 180 tramp->sh_flags = SHF_EXECINSTR | SHF_ALLOC; in module_frob_arch_sections() 181 tramp->sh_addralign = __alignof__(struct plt_entry); in module_frob_arch_sections() 182 tramp->sh_size = NR_FTRACE_PLTS * sizeof(struct plt_entry); in module_frob_arch_sections()
|
| /linux/arch/microblaze/kernel/ |
| H A D | signal.c | 48 unsigned long tramp[2]; /* signal trampoline */ member 54 unsigned long tramp[2]; /* signal trampoline */ member 184 frame->tramp + 0); in setup_rt_frame() 186 err |= __put_user(0xb9cc0008, frame->tramp + 1); in setup_rt_frame() 190 regs->r15 = ((unsigned long)frame->tramp)-8; in setup_rt_frame() 192 address = ((unsigned long)frame->tramp); in setup_rt_frame() 200 address += ((unsigned long)frame->tramp) & ~PAGE_MASK; in setup_rt_frame()
|
| /linux/kernel/ |
| H A D | static_call_inline.c | 134 void __static_call_update(struct static_call_key *key, void *tramp, void *func) in __static_call_update() argument 147 arch_static_call_transform(NULL, tramp, func, false); in __static_call_update() 209 arch_static_call_transform(site_addr, tramp, func, in __static_call_update() 353 unsigned long tramp; in tramp_key_lookup() local 355 tramp = (long)tramp_key->tramp + (long)&tramp_key->tramp; in tramp_key_lookup() 356 if (tramp == addr) in tramp_key_lookup()
|
| /linux/tools/testing/selftests/bpf/prog_tests/ |
| H A D | uprobe_syscall.c | 413 void *tramp = NULL; in check_attach() local 424 tramp = (void *) (call + 1) + call->raddr; in check_attach() 426 ASSERT_OK(find_uprobes_trampoline(tramp), "uprobes_trampoline"); in check_attach() 428 return tramp; in check_attach() 431 static void check_detach(void *addr, void *tramp) in check_detach() argument 434 ASSERT_OK(find_uprobes_trampoline(tramp), "uprobes_trampoline"); in check_detach() 441 void *tramp; in check() local 443 tramp = check_attach(skel, trigger, addr, executed); in check() 445 check_detach(addr, tramp); in check()
|
| /linux/arch/parisc/kernel/ |
| H A D | ftrace.c | 116 u32 *tramp; in ftrace_make_call() local 160 tramp = ftrace_trampoline; in ftrace_make_call() 165 tramp = ftrace_trampoline_unaligned; in ftrace_make_call() 180 __patch_text_multiple(ip, tramp, size); in ftrace_make_call()
|
| H A D | signal32.h | 40 unsigned int tramp[2]; /* holds original return address */ member
|
| /linux/arch/x86/include/asm/ |
| H A D | static_call.h | 66 extern bool __static_call_fixup(void *tramp, u8 op, void *dest); 68 extern void __static_call_update_early(void *tramp, void *func);
|
| /linux/arch/powerpc/tools/ |
| H A D | ftrace-gen-ool-stubs.sh | 35 .pushsection .tramp.ftrace.text,"aw" 45 .pushsection .tramp.ftrace.init,"aw"
|
| /linux/arch/powerpc/perf/ |
| H A D | callchain_64.c | 33 unsigned int tramp[6]; member 42 if (nip == fp + offsetof(struct signal_frame_64, tramp)) in is_sigreturn_64_address()
|
| /linux/arch/hexagon/kernel/ |
| H A D | signal.c | 22 unsigned long tramp[2]; member 114 err |= __put_user(0x7800d166, &frame->tramp[0]); in setup_rt_frame() 115 err |= __put_user(0x5400c004, &frame->tramp[1]); in setup_rt_frame()
|
| /linux/arch/parisc/include/asm/ |
| H A D | rt_sigframe.h | 6 unsigned int tramp[2]; /* holds original return address */ member
|
| /linux/arch/x86/platform/efi/ |
| H A D | efi_64.c | 181 unsigned long pfn, text, pf, rodata, tramp; in efi_setup_page_tables() local 259 tramp = __pa(__efi64_thunk_ret_tramp); in efi_setup_page_tables() 260 pfn = tramp >> PAGE_SHIFT; in efi_setup_page_tables() 263 if (kernel_map_pages_in_pgd(pgd, pfn, tramp, 1, pf)) { in efi_setup_page_tables()
|
| /linux/arch/powerpc/include/asm/ |
| H A D | module.h | 51 unsigned long tramp; member
|