Commit fca08f32 authored by Wang Nan's avatar Wang Nan Committed by Jon Medhurst

ARM: probes: move all probe code to dedicate directory

In discussion on LKML (https://lkml.org/lkml/2014/11/28/158), Russell
King suggests to move all probe related code to arch/arm/probes. This
patch does the work. Due to dependency on 'arch/arm/kernel/patch.h', this
patch also moves patch.h to 'arch/arm/include/asm/patch.h', and related
'#include' directives are also midified to '#include <asm/patch.h>'.

Following is an overview of this patch:

 ./arch/arm/kernel/               ./arch/arm/probes/
 |-- Makefile                     |-- Makefile
 |-- probes-arm.c          ==>    |-- decode-arm.c
 |-- probes-arm.h          ==>    |-- decode-arm.h
 |-- probes-thumb.c        ==>    |-- decode-thumb.c
 |-- probes-thumb.h        ==>    |-- decode-thumb.h
 |-- probes.c              ==>    |-- decode.c
 |-- probes.h              ==>    |-- decode.h
 |                                |-- kprobes
 |                                |   |-- Makefile
 |-- kprobes-arm.c         ==>    |   |-- actions-arm.c
 |-- kprobes-common.c      ==>    |   |-- actions-common.c
 |-- kprobes-thumb.c       ==>    |   |-- actions-thumb.c
 |-- kprobes.c             ==>    |   |-- core.c
 |-- kprobes.h             ==>    |   |-- core.h
 |-- kprobes-test-arm.c    ==>    |   |-- test-arm.c
 |-- kprobes-test.c        ==>    |   |-- test-core.c
 |-- kprobes-test.h        ==>    |   |-- test-core.h
 |-- kprobes-test-thumb.c  ==>    |   `-- test-thumb.c
 |                                `-- uprobes
 |                                    |-- Makefile
 |-- uprobes-arm.c         ==>        |-- actions-arm.c
 |-- uprobes.c             ==>        |-- core.c
 |-- uprobes.h             ==>        `-- core.h
 |
 `-- patch.h               ==>    arch/arm/include/asm/patch.h
Signed-off-by: default avatarWang Nan <wangnan0@huawei.com>
Acked-by: default avatarMasami Hiramatsu <masami.hiramatsu.pt@hitachi.com>
Signed-off-by: default avatarJon Medhurst <tixy@linaro.org>
parent b1940cd2
...@@ -266,6 +266,7 @@ core-$(CONFIG_KVM_ARM_HOST) += arch/arm/kvm/ ...@@ -266,6 +266,7 @@ core-$(CONFIG_KVM_ARM_HOST) += arch/arm/kvm/
# If we have a machine-specific directory, then include it in the build. # If we have a machine-specific directory, then include it in the build.
core-y += arch/arm/kernel/ arch/arm/mm/ arch/arm/common/ core-y += arch/arm/kernel/ arch/arm/mm/ arch/arm/common/
core-y += arch/arm/probes/
core-y += arch/arm/net/ core-y += arch/arm/net/
core-y += arch/arm/crypto/ core-y += arch/arm/crypto/
core-y += arch/arm/firmware/ core-y += arch/arm/firmware/
......
...@@ -51,20 +51,8 @@ obj-$(CONFIG_DYNAMIC_FTRACE) += ftrace.o insn.o ...@@ -51,20 +51,8 @@ obj-$(CONFIG_DYNAMIC_FTRACE) += ftrace.o insn.o
obj-$(CONFIG_FUNCTION_GRAPH_TRACER) += ftrace.o insn.o obj-$(CONFIG_FUNCTION_GRAPH_TRACER) += ftrace.o insn.o
obj-$(CONFIG_JUMP_LABEL) += jump_label.o insn.o patch.o obj-$(CONFIG_JUMP_LABEL) += jump_label.o insn.o patch.o
obj-$(CONFIG_KEXEC) += machine_kexec.o relocate_kernel.o obj-$(CONFIG_KEXEC) += machine_kexec.o relocate_kernel.o
obj-$(CONFIG_UPROBES) += probes.o probes-arm.o uprobes.o uprobes-arm.o # Main staffs in KPROBES are in arch/arm/probes/ .
obj-$(CONFIG_KPROBES) += probes.o kprobes.o kprobes-common.o patch.o obj-$(CONFIG_KPROBES) += patch.o
ifdef CONFIG_THUMB2_KERNEL
obj-$(CONFIG_KPROBES) += kprobes-thumb.o probes-thumb.o
else
obj-$(CONFIG_KPROBES) += kprobes-arm.o probes-arm.o
endif
obj-$(CONFIG_ARM_KPROBES_TEST) += test-kprobes.o
test-kprobes-objs := kprobes-test.o
ifdef CONFIG_THUMB2_KERNEL
test-kprobes-objs += kprobes-test-thumb.o
else
test-kprobes-objs += kprobes-test-arm.o
endif
obj-$(CONFIG_OABI_COMPAT) += sys_oabi-compat.o obj-$(CONFIG_OABI_COMPAT) += sys_oabi-compat.o
obj-$(CONFIG_ARM_THUMBEE) += thumbee.o obj-$(CONFIG_ARM_THUMBEE) += thumbee.o
obj-$(CONFIG_KGDB) += kgdb.o patch.o obj-$(CONFIG_KGDB) += kgdb.o patch.o
......
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/jump_label.h> #include <linux/jump_label.h>
#include <asm/patch.h>
#include "insn.h" #include "insn.h"
#include "patch.h"
#ifdef HAVE_JUMP_LABEL #ifdef HAVE_JUMP_LABEL
......
...@@ -14,10 +14,9 @@ ...@@ -14,10 +14,9 @@
#include <linux/kgdb.h> #include <linux/kgdb.h>
#include <linux/uaccess.h> #include <linux/uaccess.h>
#include <asm/patch.h>
#include <asm/traps.h> #include <asm/traps.h>
#include "patch.h"
struct dbg_reg_def_t dbg_reg_def[DBG_MAX_REG_NUM] = struct dbg_reg_def_t dbg_reg_def[DBG_MAX_REG_NUM] =
{ {
{ "r0", 4, offsetof(struct pt_regs, ARM_r0)}, { "r0", 4, offsetof(struct pt_regs, ARM_r0)},
......
...@@ -8,8 +8,7 @@ ...@@ -8,8 +8,7 @@
#include <asm/fixmap.h> #include <asm/fixmap.h>
#include <asm/smp_plat.h> #include <asm/smp_plat.h>
#include <asm/opcodes.h> #include <asm/opcodes.h>
#include <asm/patch.h>
#include "patch.h"
struct patch { struct patch {
void *addr; void *addr;
......
obj-$(CONFIG_UPROBES) += decode.o decode-arm.o uprobes/
obj-$(CONFIG_KPROBES) += decode.o kprobes/
ifdef CONFIG_THUMB2_KERNEL
obj-$(CONFIG_KPROBES) += decode-thumb.o
else
obj-$(CONFIG_KPROBES) += decode-arm.o
endif
/* /*
* arch/arm/kernel/probes-arm.c *
* arch/arm/probes/decode-arm.c
* *
* Some code moved here from arch/arm/kernel/kprobes-arm.c * Some code moved here from arch/arm/kernel/kprobes-arm.c
* *
...@@ -20,8 +21,8 @@ ...@@ -20,8 +21,8 @@
#include <linux/stddef.h> #include <linux/stddef.h>
#include <linux/ptrace.h> #include <linux/ptrace.h>
#include "probes.h" #include "decode.h"
#include "probes-arm.h" #include "decode-arm.h"
#define sign_extend(x, signbit) ((x) | (0 - ((x) & (1 << (signbit))))) #define sign_extend(x, signbit) ((x) | (0 - ((x) & (1 << (signbit)))))
......
/* /*
* arch/arm/kernel/probes-arm.h * arch/arm/probes/decode-arm.h
* *
* Copyright 2013 Linaro Ltd. * Copyright 2013 Linaro Ltd.
* Written by: David A. Long * Written by: David A. Long
...@@ -15,6 +15,8 @@ ...@@ -15,6 +15,8 @@
#ifndef _ARM_KERNEL_PROBES_ARM_H #ifndef _ARM_KERNEL_PROBES_ARM_H
#define _ARM_KERNEL_PROBES_ARM_H #define _ARM_KERNEL_PROBES_ARM_H
#include "decode.h"
enum probes_arm_action { enum probes_arm_action {
PROBES_EMULATE_NONE, PROBES_EMULATE_NONE,
PROBES_SIMULATE_NOP, PROBES_SIMULATE_NOP,
......
/* /*
* arch/arm/kernel/probes-thumb.c * arch/arm/probes/decode-thumb.c
* *
* Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>. * Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>.
* *
...@@ -12,8 +12,8 @@ ...@@ -12,8 +12,8 @@
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/module.h> #include <linux/module.h>
#include "probes.h" #include "decode.h"
#include "probes-thumb.h" #include "decode-thumb.h"
static const union decode_item t32_table_1110_100x_x0xx[] = { static const union decode_item t32_table_1110_100x_x0xx[] = {
......
/* /*
* arch/arm/kernel/probes-thumb.h * arch/arm/probes/decode-thumb.h
* *
* Copyright 2013 Linaro Ltd. * Copyright 2013 Linaro Ltd.
* Written by: David A. Long * Written by: David A. Long
...@@ -15,6 +15,8 @@ ...@@ -15,6 +15,8 @@
#ifndef _ARM_KERNEL_PROBES_THUMB_H #ifndef _ARM_KERNEL_PROBES_THUMB_H
#define _ARM_KERNEL_PROBES_THUMB_H #define _ARM_KERNEL_PROBES_THUMB_H
#include "decode.h"
/* /*
* True if current instruction is in an IT block. * True if current instruction is in an IT block.
*/ */
......
/* /*
* arch/arm/kernel/probes.c * arch/arm/probes/decode.c
* *
* Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>. * Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>.
* *
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
#include <asm/ptrace.h> #include <asm/ptrace.h>
#include <linux/bug.h> #include <linux/bug.h>
#include "probes.h" #include "decode.h"
#ifndef find_str_pc_offset #ifndef find_str_pc_offset
......
/* /*
* arch/arm/kernel/probes.h * arch/arm/probes/decode.h
* *
* Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>. * Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>.
* *
......
obj-$(CONFIG_KPROBES) += core.o actions-common.o
obj-$(CONFIG_ARM_KPROBES_TEST) += test-kprobes.o
test-kprobes-objs := test-core.o
ifdef CONFIG_THUMB2_KERNEL
obj-$(CONFIG_KPROBES) += actions-thumb.o
test-kprobes-objs += test-thumb.o
else
obj-$(CONFIG_KPROBES) += actions-arm.o
test-kprobes-objs += test-arm.o
endif
/* /*
* arch/arm/kernel/kprobes-decode.c * arch/arm/probes/kprobes/actions-arm.c
* *
* Copyright (C) 2006, 2007 Motorola Inc. * Copyright (C) 2006, 2007 Motorola Inc.
* *
...@@ -62,8 +62,8 @@ ...@@ -62,8 +62,8 @@
#include <linux/kprobes.h> #include <linux/kprobes.h>
#include <linux/ptrace.h> #include <linux/ptrace.h>
#include "kprobes.h" #include "../decode-arm.h"
#include "probes-arm.h" #include "core.h"
#if __LINUX_ARM_ARCH__ >= 6 #if __LINUX_ARM_ARCH__ >= 6
#define BLX(reg) "blx "reg" \n\t" #define BLX(reg) "blx "reg" \n\t"
......
/* /*
* arch/arm/kernel/kprobes-common.c * arch/arm/probes/kprobes/actions-common.c
* *
* Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>. * Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>.
* *
...@@ -15,7 +15,7 @@ ...@@ -15,7 +15,7 @@
#include <linux/kprobes.h> #include <linux/kprobes.h>
#include <asm/opcodes.h> #include <asm/opcodes.h>
#include "kprobes.h" #include "core.h"
static void __kprobes simulate_ldm1stm1(probes_opcode_t insn, static void __kprobes simulate_ldm1stm1(probes_opcode_t insn,
......
/* /*
* arch/arm/kernel/kprobes-thumb.c * arch/arm/probes/kprobes/actions-thumb.c
* *
* Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>. * Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>.
* *
...@@ -13,8 +13,8 @@ ...@@ -13,8 +13,8 @@
#include <linux/ptrace.h> #include <linux/ptrace.h>
#include <linux/kprobes.h> #include <linux/kprobes.h>
#include "kprobes.h" #include "../decode-thumb.h"
#include "probes-thumb.h" #include "core.h"
/* These emulation encodings are functionally equivalent... */ /* These emulation encodings are functionally equivalent... */
#define t32_emulate_rd8rn16rm0ra12_noflags \ #define t32_emulate_rd8rn16rm0ra12_noflags \
......
...@@ -30,11 +30,11 @@ ...@@ -30,11 +30,11 @@
#include <asm/cacheflush.h> #include <asm/cacheflush.h>
#include <linux/percpu.h> #include <linux/percpu.h>
#include <linux/bug.h> #include <linux/bug.h>
#include <asm/patch.h>
#include "kprobes.h" #include "../decode-arm.h"
#include "probes-arm.h" #include "../decode-thumb.h"
#include "probes-thumb.h" #include "core.h"
#include "patch.h"
#define MIN_STACK_SIZE(addr) \ #define MIN_STACK_SIZE(addr) \
min((unsigned long)MAX_STACK_SIZE, \ min((unsigned long)MAX_STACK_SIZE, \
......
...@@ -19,7 +19,8 @@ ...@@ -19,7 +19,8 @@
#ifndef _ARM_KERNEL_KPROBES_H #ifndef _ARM_KERNEL_KPROBES_H
#define _ARM_KERNEL_KPROBES_H #define _ARM_KERNEL_KPROBES_H
#include "probes.h" #include <asm/kprobes.h>
#include "../decode.h"
/* /*
* These undefined instructions must be unique and * These undefined instructions must be unique and
......
...@@ -13,7 +13,7 @@ ...@@ -13,7 +13,7 @@
#include <asm/system_info.h> #include <asm/system_info.h>
#include <asm/opcodes.h> #include <asm/opcodes.h>
#include "kprobes-test.h" #include "test-core.h"
#define TEST_ISA "32" #define TEST_ISA "32"
......
...@@ -209,10 +209,10 @@ ...@@ -209,10 +209,10 @@
#include <linux/bug.h> #include <linux/bug.h>
#include <asm/opcodes.h> #include <asm/opcodes.h>
#include "kprobes.h" #include "core.h"
#include "probes-arm.h" #include "test-core.h"
#include "probes-thumb.h" #include "../decode-arm.h"
#include "kprobes-test.h" #include "../decode-thumb.h"
#define BENCHMARKING 1 #define BENCHMARKING 1
......
/* /*
* arch/arm/kernel/kprobes-test.h * arch/arm/probes/kprobes/test-core.h
* *
* Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>. * Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>.
* *
......
/* /*
* arch/arm/kernel/kprobes-test-thumb.c * arch/arm/probes/kprobes/test-thumb.c
* *
* Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>. * Copyright (C) 2011 Jon Medhurst <tixy@yxit.co.uk>.
* *
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
#include <linux/module.h> #include <linux/module.h>
#include <asm/opcodes.h> #include <asm/opcodes.h>
#include "kprobes-test.h" #include "test-core.h"
#define TEST_ISA "16" #define TEST_ISA "16"
......
obj-$(CONFIG_UPROBES) += core.o actions-arm.o
...@@ -13,9 +13,9 @@ ...@@ -13,9 +13,9 @@
#include <linux/uprobes.h> #include <linux/uprobes.h>
#include <linux/module.h> #include <linux/module.h>
#include "probes.h" #include "../decode.h"
#include "probes-arm.h" #include "../decode-arm.h"
#include "uprobes.h" #include "core.h"
static int uprobes_substitute_pc(unsigned long *pinsn, u32 oregs) static int uprobes_substitute_pc(unsigned long *pinsn, u32 oregs)
{ {
......
...@@ -17,9 +17,9 @@ ...@@ -17,9 +17,9 @@
#include <asm/opcodes.h> #include <asm/opcodes.h>
#include <asm/traps.h> #include <asm/traps.h>
#include "probes.h" #include "../decode.h"
#include "probes-arm.h" #include "../decode-arm.h"
#include "uprobes.h" #include "core.h"
#define UPROBE_TRAP_NR UINT_MAX #define UPROBE_TRAP_NR UINT_MAX
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment