blob: 3087ea9c5f2e86dfcf9c596258a3d1df6f22bc90 [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;
Oleg Nesterov8a8de662013-11-04 20:27:13 +010038 union {
39 u8 insn[MAX_UINSN_BYTES];
40 u8 ixol[MAX_UINSN_BYTES];
41 };
Srikar Dronamraju2b144492012-02-09 14:56:42 +053042#ifdef CONFIG_X86_64
Ingo Molnar7b2d81d2012-02-17 09:27:41 +010043 unsigned long rip_rela_target_address;
Srikar Dronamraju2b144492012-02-09 14:56:42 +053044#endif
45};
46
Srikar Dronamraju0326f5a2012-03-13 23:30:11 +053047struct arch_uprobe_task {
Srikar Dronamraju0326f5a2012-03-13 23:30:11 +053048#ifdef CONFIG_X86_64
49 unsigned long saved_scratch_register;
50#endif
Oleg Nesterovbaedbf02012-09-03 17:02:16 +020051 unsigned int saved_trap_nr;
Oleg Nesterov3a4664a2012-09-03 16:05:10 +020052 unsigned int saved_tf;
Srikar Dronamraju0326f5a2012-03-13 23:30:11 +053053};
54
Srikar Dronamraju2b144492012-02-09 14:56:42 +053055#endif /* _ASM_UPROBES_H */