blob: 6e5197910fd87b178921e3dd2ecf883ae3fb0894 [file] [log] [blame]
Srikar Dronamraju2b144492012-02-09 14:56:42 +05301#ifndef _ASM_UPROBES_H
2#define _ASM_UPROBES_H
3/*
Ingo Molnar7b2d81d2012-02-17 09:27:41 +01004 * User-space Probes (UProbes) for x86
Srikar Dronamraju2b144492012-02-09 14:56:42 +05305 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
19 *
20 * Copyright (C) IBM Corporation, 2008-2011
21 * Authors:
22 * Srikar Dronamraju
23 * Jim Keniston
24 */
25
Srikar Dronamraju0326f5a2012-03-13 23:30:11 +053026#include <linux/notifier.h>
27
Srikar Dronamraju2b144492012-02-09 14:56:42 +053028typedef u8 uprobe_opcode_t;
Srikar Dronamraju2b144492012-02-09 14:56:42 +053029
Ingo Molnar7b2d81d2012-02-17 09:27:41 +010030#define MAX_UINSN_BYTES 16
Srikar Dronamraju900771a2012-03-12 14:55:14 +053031#define UPROBE_XOL_SLOT_BYTES 128 /* to keep it cache aligned */
Ingo Molnar7b2d81d2012-02-17 09:27:41 +010032
Srikar Dronamraju5cb4ac32012-03-12 14:55:45 +053033#define UPROBE_SWBP_INSN 0xcc
34#define UPROBE_SWBP_INSN_SIZE 1
Srikar Dronamraju2b144492012-02-09 14:56:42 +053035
Srikar Dronamraju3ff54ef2012-02-22 14:46:02 +053036struct arch_uprobe {
Ingo Molnar7b2d81d2012-02-17 09:27:41 +010037 u16 fixups;
Srikar Dronamraju3ff54ef2012-02-22 14:46:02 +053038 u8 insn[MAX_UINSN_BYTES];
Srikar Dronamraju2b144492012-02-09 14:56:42 +053039#ifdef CONFIG_X86_64
Ingo Molnar7b2d81d2012-02-17 09:27:41 +010040 unsigned long rip_rela_target_address;
Srikar Dronamraju2b144492012-02-09 14:56:42 +053041#endif
42};
43
Srikar Dronamraju0326f5a2012-03-13 23:30:11 +053044struct arch_uprobe_task {
Srikar Dronamraju0326f5a2012-03-13 23:30:11 +053045#ifdef CONFIG_X86_64
46 unsigned long saved_scratch_register;
47#endif
Oleg Nesterovbaedbf02012-09-03 17:02:16 +020048 unsigned int saved_trap_nr;
Oleg Nesterov3a4664a2012-09-03 16:05:10 +020049 unsigned int saved_tf;
Srikar Dronamraju0326f5a2012-03-13 23:30:11 +053050};
51
Ananth N Mavinakayanahalli7eb9ba52012-06-08 15:02:57 +053052extern int arch_uprobe_analyze_insn(struct arch_uprobe *aup, struct mm_struct *mm, unsigned long addr);
Srikar Dronamraju0326f5a2012-03-13 23:30:11 +053053extern int arch_uprobe_pre_xol(struct arch_uprobe *aup, struct pt_regs *regs);
54extern int arch_uprobe_post_xol(struct arch_uprobe *aup, struct pt_regs *regs);
55extern bool arch_uprobe_xol_was_trapped(struct task_struct *tsk);
56extern int arch_uprobe_exception_notify(struct notifier_block *self, unsigned long val, void *data);
57extern void arch_uprobe_abort_xol(struct arch_uprobe *aup, struct pt_regs *regs);
Anton Arapov791eca12013-04-03 18:00:33 +020058extern unsigned long arch_uretprobe_hijack_return_addr(unsigned long trampoline_vaddr, struct pt_regs *regs);
Srikar Dronamraju2b144492012-02-09 14:56:42 +053059#endif /* _ASM_UPROBES_H */