blob: 1e5b9bb9227066a498c6d6edb6dfe238e53d6c99 [file] [log] [blame]
David A. Longb2531dd2014-03-06 17:53:34 -05001/*
2 * arch/arm/include/asm/probes.h
3 *
4 * Original contents copied from arch/arm/include/asm/kprobes.h
5 * which contains the following notice...
6 *
7 * Copyright (C) 2006, 2007 Motorola Inc.
8 *
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License version 2 as
11 * published by the Free Software Foundation.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * General Public License for more details.
17 */
18
19#ifndef _ASM_PROBES_H
20#define _ASM_PROBES_H
21
Wang Nana0266c22015-01-05 19:29:25 +080022#ifndef __ASSEMBLY__
23
David A. Longf145d662014-03-05 21:17:23 -050024typedef u32 probes_opcode_t;
David A. Longc18377c2014-03-07 11:16:10 -050025
David A. Longb4cd6052014-03-05 21:41:29 -050026struct arch_probes_insn;
David A. Long47e190f2014-03-06 18:12:07 -050027typedef void (probes_insn_handler_t)(probes_opcode_t,
David A. Longb4cd6052014-03-05 21:41:29 -050028 struct arch_probes_insn *,
David A. Long7579f4b32014-03-07 11:19:32 -050029 struct pt_regs *);
David A. Longf145d662014-03-05 21:17:23 -050030typedef unsigned long (probes_check_cc)(unsigned long);
David A. Long47e190f2014-03-06 18:12:07 -050031typedef void (probes_insn_singlestep_t)(probes_opcode_t,
David A. Longb4cd6052014-03-05 21:41:29 -050032 struct arch_probes_insn *,
David A. Long7579f4b32014-03-07 11:19:32 -050033 struct pt_regs *);
David A. Long47e190f2014-03-06 18:12:07 -050034typedef void (probes_insn_fn_t)(void);
David A. Longb2531dd2014-03-06 17:53:34 -050035
36/* Architecture specific copy of original instruction. */
David A. Longb4cd6052014-03-05 21:41:29 -050037struct arch_probes_insn {
David A. Longf145d662014-03-05 21:17:23 -050038 probes_opcode_t *insn;
David A. Long47e190f2014-03-06 18:12:07 -050039 probes_insn_handler_t *insn_handler;
David A. Longf145d662014-03-05 21:17:23 -050040 probes_check_cc *insn_check_cc;
David A. Long47e190f2014-03-06 18:12:07 -050041 probes_insn_singlestep_t *insn_singlestep;
42 probes_insn_fn_t *insn_fn;
Wang Nan6624cf62015-01-05 19:29:21 +080043 int stack_space;
Wang Nan28a18992015-01-05 19:29:44 +080044 unsigned long register_usage_flags;
Wang Nanbfc96572015-01-05 19:34:47 +080045 bool kprobe_direct_exec;
David A. Longb2531dd2014-03-06 17:53:34 -050046};
47
Wang Nana0266c22015-01-05 19:29:25 +080048#endif /* __ASSEMBLY__ */
49
50/*
51 * We assume one instruction can consume at most 64 bytes stack, which is
52 * 'push {r0-r15}'. Instructions consume more or unknown stack space like
53 * 'str r0, [sp, #-80]' and 'str r0, [sp, r1]' should be prohibit to probe.
54 * Both kprobe and jprobe use this macro.
55 */
56#define MAX_STACK_SIZE 64
57
David A. Longb2531dd2014-03-06 17:53:34 -050058#endif