diff options
author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2008-07-15 01:44:51 -0400 |
---|---|---|
committer | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2008-07-15 01:44:51 -0400 |
commit | 43d2548bb2ef7e6d753f91468a746784041e522d (patch) | |
tree | 77d13fcd48fd998393abb825ec36e2b732684a73 /arch/powerpc | |
parent | 585583d95c5660973bc0cf64add517b040acd8a4 (diff) | |
parent | 85082fd7cbe3173198aac0eb5e85ab1edcc6352c (diff) |
Merge commit '85082fd7cbe3173198aac0eb5e85ab1edcc6352c' into test-build
Manual fixup of:
arch/powerpc/Kconfig
Diffstat (limited to 'arch/powerpc')
-rw-r--r-- | arch/powerpc/Kconfig | 4 | ||||
-rw-r--r-- | arch/powerpc/kernel/Makefile | 14 | ||||
-rw-r--r-- | arch/powerpc/kernel/entry_32.S | 127 | ||||
-rw-r--r-- | arch/powerpc/kernel/entry_64.S | 65 | ||||
-rw-r--r-- | arch/powerpc/kernel/ftrace.c | 154 | ||||
-rw-r--r-- | arch/powerpc/kernel/io.c | 3 | ||||
-rw-r--r-- | arch/powerpc/kernel/irq.c | 6 | ||||
-rw-r--r-- | arch/powerpc/kernel/ppc_ksyms.c | 5 | ||||
-rw-r--r-- | arch/powerpc/kernel/setup_32.c | 6 | ||||
-rw-r--r-- | arch/powerpc/kernel/vmlinux.lds.S | 2 | ||||
-rw-r--r-- | arch/powerpc/platforms/powermac/Makefile | 5 |
11 files changed, 381 insertions, 10 deletions
diff --git a/arch/powerpc/Kconfig b/arch/powerpc/Kconfig index 06b72771ae22..1530a41fc56d 100644 --- a/arch/powerpc/Kconfig +++ b/arch/powerpc/Kconfig | |||
@@ -108,12 +108,14 @@ config ARCH_NO_VIRT_TO_BUS | |||
108 | config PPC | 108 | config PPC |
109 | bool | 109 | bool |
110 | default y | 110 | default y |
111 | select HAVE_DYNAMIC_FTRACE | ||
112 | select HAVE_FTRACE | ||
111 | select HAVE_IDE | 113 | select HAVE_IDE |
112 | select HAVE_OPROFILE | ||
113 | select HAVE_KPROBES | 114 | select HAVE_KPROBES |
114 | select HAVE_KRETPROBES | 115 | select HAVE_KRETPROBES |
115 | select HAVE_LMB | 116 | select HAVE_LMB |
116 | select HAVE_DMA_ATTRS if PPC64 | 117 | select HAVE_DMA_ATTRS if PPC64 |
118 | select HAVE_OPROFILE | ||
117 | 119 | ||
118 | config EARLY_PRINTK | 120 | config EARLY_PRINTK |
119 | bool | 121 | bool |
diff --git a/arch/powerpc/kernel/Makefile b/arch/powerpc/kernel/Makefile index 9ebeb2406b5b..bf0b1fd0ec34 100644 --- a/arch/powerpc/kernel/Makefile +++ b/arch/powerpc/kernel/Makefile | |||
@@ -12,6 +12,18 @@ CFLAGS_prom_init.o += -fPIC | |||
12 | CFLAGS_btext.o += -fPIC | 12 | CFLAGS_btext.o += -fPIC |
13 | endif | 13 | endif |
14 | 14 | ||
15 | ifdef CONFIG_FTRACE | ||
16 | # Do not trace early boot code | ||
17 | CFLAGS_REMOVE_cputable.o = -pg | ||
18 | CFLAGS_REMOVE_prom_init.o = -pg | ||
19 | |||
20 | ifdef CONFIG_DYNAMIC_FTRACE | ||
21 | # dynamic ftrace setup. | ||
22 | CFLAGS_REMOVE_ftrace.o = -pg | ||
23 | endif | ||
24 | |||
25 | endif | ||
26 | |||
15 | obj-y := cputable.o ptrace.o syscalls.o \ | 27 | obj-y := cputable.o ptrace.o syscalls.o \ |
16 | irq.o align.o signal_32.o pmc.o vdso.o \ | 28 | irq.o align.o signal_32.o pmc.o vdso.o \ |
17 | init_task.o process.o systbl.o idle.o \ | 29 | init_task.o process.o systbl.o idle.o \ |
@@ -79,6 +91,8 @@ obj-$(CONFIG_KEXEC) += machine_kexec.o crash.o \ | |||
79 | obj-$(CONFIG_AUDIT) += audit.o | 91 | obj-$(CONFIG_AUDIT) += audit.o |
80 | obj64-$(CONFIG_AUDIT) += compat_audit.o | 92 | obj64-$(CONFIG_AUDIT) += compat_audit.o |
81 | 93 | ||
94 | obj-$(CONFIG_DYNAMIC_FTRACE) += ftrace.o | ||
95 | |||
82 | obj-$(CONFIG_8XX_MINIMAL_FPEMU) += softemu8xx.o | 96 | obj-$(CONFIG_8XX_MINIMAL_FPEMU) += softemu8xx.o |
83 | 97 | ||
84 | ifneq ($(CONFIG_PPC_INDIRECT_IO),y) | 98 | ifneq ($(CONFIG_PPC_INDIRECT_IO),y) |
diff --git a/arch/powerpc/kernel/entry_32.S b/arch/powerpc/kernel/entry_32.S index ab2d62f70b14..da52269aec1e 100644 --- a/arch/powerpc/kernel/entry_32.S +++ b/arch/powerpc/kernel/entry_32.S | |||
@@ -30,6 +30,7 @@ | |||
30 | #include <asm/ppc_asm.h> | 30 | #include <asm/ppc_asm.h> |
31 | #include <asm/asm-offsets.h> | 31 | #include <asm/asm-offsets.h> |
32 | #include <asm/unistd.h> | 32 | #include <asm/unistd.h> |
33 | #include <asm/ftrace.h> | ||
33 | 34 | ||
34 | #undef SHOW_SYSCALLS | 35 | #undef SHOW_SYSCALLS |
35 | #undef SHOW_SYSCALLS_TASK | 36 | #undef SHOW_SYSCALLS_TASK |
@@ -1151,3 +1152,129 @@ machine_check_in_rtas: | |||
1151 | /* XXX load up BATs and panic */ | 1152 | /* XXX load up BATs and panic */ |
1152 | 1153 | ||
1153 | #endif /* CONFIG_PPC_RTAS */ | 1154 | #endif /* CONFIG_PPC_RTAS */ |
1155 | |||
1156 | #ifdef CONFIG_FTRACE | ||
1157 | #ifdef CONFIG_DYNAMIC_FTRACE | ||
1158 | _GLOBAL(mcount) | ||
1159 | _GLOBAL(_mcount) | ||
1160 | stwu r1,-48(r1) | ||
1161 | stw r3, 12(r1) | ||
1162 | stw r4, 16(r1) | ||
1163 | stw r5, 20(r1) | ||
1164 | stw r6, 24(r1) | ||
1165 | mflr r3 | ||
1166 | stw r7, 28(r1) | ||
1167 | mfcr r5 | ||
1168 | stw r8, 32(r1) | ||
1169 | stw r9, 36(r1) | ||
1170 | stw r10,40(r1) | ||
1171 | stw r3, 44(r1) | ||
1172 | stw r5, 8(r1) | ||
1173 | subi r3, r3, MCOUNT_INSN_SIZE | ||
1174 | .globl mcount_call | ||
1175 | mcount_call: | ||
1176 | bl ftrace_stub | ||
1177 | nop | ||
1178 | lwz r6, 8(r1) | ||
1179 | lwz r0, 44(r1) | ||
1180 | lwz r3, 12(r1) | ||
1181 | mtctr r0 | ||
1182 | lwz r4, 16(r1) | ||
1183 | mtcr r6 | ||
1184 | lwz r5, 20(r1) | ||
1185 | lwz r6, 24(r1) | ||
1186 | lwz r0, 52(r1) | ||
1187 | lwz r7, 28(r1) | ||
1188 | lwz r8, 32(r1) | ||
1189 | mtlr r0 | ||
1190 | lwz r9, 36(r1) | ||
1191 | lwz r10,40(r1) | ||
1192 | addi r1, r1, 48 | ||
1193 | bctr | ||
1194 | |||
1195 | _GLOBAL(ftrace_caller) | ||
1196 | /* Based off of objdump optput from glibc */ | ||
1197 | stwu r1,-48(r1) | ||
1198 | stw r3, 12(r1) | ||
1199 | stw r4, 16(r1) | ||
1200 | stw r5, 20(r1) | ||
1201 | stw r6, 24(r1) | ||
1202 | mflr r3 | ||
1203 | lwz r4, 52(r1) | ||
1204 | mfcr r5 | ||
1205 | stw r7, 28(r1) | ||
1206 | stw r8, 32(r1) | ||
1207 | stw r9, 36(r1) | ||
1208 | stw r10,40(r1) | ||
1209 | stw r3, 44(r1) | ||
1210 | stw r5, 8(r1) | ||
1211 | subi r3, r3, MCOUNT_INSN_SIZE | ||
1212 | .globl ftrace_call | ||
1213 | ftrace_call: | ||
1214 | bl ftrace_stub | ||
1215 | nop | ||
1216 | lwz r6, 8(r1) | ||
1217 | lwz r0, 44(r1) | ||
1218 | lwz r3, 12(r1) | ||
1219 | mtctr r0 | ||
1220 | lwz r4, 16(r1) | ||
1221 | mtcr r6 | ||
1222 | lwz r5, 20(r1) | ||
1223 | lwz r6, 24(r1) | ||
1224 | lwz r0, 52(r1) | ||
1225 | lwz r7, 28(r1) | ||
1226 | lwz r8, 32(r1) | ||
1227 | mtlr r0 | ||
1228 | lwz r9, 36(r1) | ||
1229 | lwz r10,40(r1) | ||
1230 | addi r1, r1, 48 | ||
1231 | bctr | ||
1232 | #else | ||
1233 | _GLOBAL(mcount) | ||
1234 | _GLOBAL(_mcount) | ||
1235 | stwu r1,-48(r1) | ||
1236 | stw r3, 12(r1) | ||
1237 | stw r4, 16(r1) | ||
1238 | stw r5, 20(r1) | ||
1239 | stw r6, 24(r1) | ||
1240 | mflr r3 | ||
1241 | lwz r4, 52(r1) | ||
1242 | mfcr r5 | ||
1243 | stw r7, 28(r1) | ||
1244 | stw r8, 32(r1) | ||
1245 | stw r9, 36(r1) | ||
1246 | stw r10,40(r1) | ||
1247 | stw r3, 44(r1) | ||
1248 | stw r5, 8(r1) | ||
1249 | |||
1250 | subi r3, r3, MCOUNT_INSN_SIZE | ||
1251 | LOAD_REG_ADDR(r5, ftrace_trace_function) | ||
1252 | lwz r5,0(r5) | ||
1253 | |||
1254 | mtctr r5 | ||
1255 | bctrl | ||
1256 | |||
1257 | nop | ||
1258 | |||
1259 | lwz r6, 8(r1) | ||
1260 | lwz r0, 44(r1) | ||
1261 | lwz r3, 12(r1) | ||
1262 | mtctr r0 | ||
1263 | lwz r4, 16(r1) | ||
1264 | mtcr r6 | ||
1265 | lwz r5, 20(r1) | ||
1266 | lwz r6, 24(r1) | ||
1267 | lwz r0, 52(r1) | ||
1268 | lwz r7, 28(r1) | ||
1269 | lwz r8, 32(r1) | ||
1270 | mtlr r0 | ||
1271 | lwz r9, 36(r1) | ||
1272 | lwz r10,40(r1) | ||
1273 | addi r1, r1, 48 | ||
1274 | bctr | ||
1275 | #endif | ||
1276 | |||
1277 | _GLOBAL(ftrace_stub) | ||
1278 | blr | ||
1279 | |||
1280 | #endif /* CONFIG_MCOUNT */ | ||
diff --git a/arch/powerpc/kernel/entry_64.S b/arch/powerpc/kernel/entry_64.S index 12eb95a80ce9..d7369243ae44 100644 --- a/arch/powerpc/kernel/entry_64.S +++ b/arch/powerpc/kernel/entry_64.S | |||
@@ -31,6 +31,7 @@ | |||
31 | #include <asm/bug.h> | 31 | #include <asm/bug.h> |
32 | #include <asm/ptrace.h> | 32 | #include <asm/ptrace.h> |
33 | #include <asm/irqflags.h> | 33 | #include <asm/irqflags.h> |
34 | #include <asm/ftrace.h> | ||
34 | 35 | ||
35 | /* | 36 | /* |
36 | * System calls. | 37 | * System calls. |
@@ -875,3 +876,67 @@ _GLOBAL(enter_prom) | |||
875 | ld r0,16(r1) | 876 | ld r0,16(r1) |
876 | mtlr r0 | 877 | mtlr r0 |
877 | blr | 878 | blr |
879 | |||
880 | #ifdef CONFIG_FTRACE | ||
881 | #ifdef CONFIG_DYNAMIC_FTRACE | ||
882 | _GLOBAL(mcount) | ||
883 | _GLOBAL(_mcount) | ||
884 | /* Taken from output of objdump from lib64/glibc */ | ||
885 | mflr r3 | ||
886 | stdu r1, -112(r1) | ||
887 | std r3, 128(r1) | ||
888 | subi r3, r3, MCOUNT_INSN_SIZE | ||
889 | .globl mcount_call | ||
890 | mcount_call: | ||
891 | bl ftrace_stub | ||
892 | nop | ||
893 | ld r0, 128(r1) | ||
894 | mtlr r0 | ||
895 | addi r1, r1, 112 | ||
896 | blr | ||
897 | |||
898 | _GLOBAL(ftrace_caller) | ||
899 | /* Taken from output of objdump from lib64/glibc */ | ||
900 | mflr r3 | ||
901 | ld r11, 0(r1) | ||
902 | stdu r1, -112(r1) | ||
903 | std r3, 128(r1) | ||
904 | ld r4, 16(r11) | ||
905 | subi r3, r3, MCOUNT_INSN_SIZE | ||
906 | .globl ftrace_call | ||
907 | ftrace_call: | ||
908 | bl ftrace_stub | ||
909 | nop | ||
910 | ld r0, 128(r1) | ||
911 | mtlr r0 | ||
912 | addi r1, r1, 112 | ||
913 | _GLOBAL(ftrace_stub) | ||
914 | blr | ||
915 | #else | ||
916 | _GLOBAL(mcount) | ||
917 | blr | ||
918 | |||
919 | _GLOBAL(_mcount) | ||
920 | /* Taken from output of objdump from lib64/glibc */ | ||
921 | mflr r3 | ||
922 | ld r11, 0(r1) | ||
923 | stdu r1, -112(r1) | ||
924 | std r3, 128(r1) | ||
925 | ld r4, 16(r11) | ||
926 | |||
927 | subi r3, r3, MCOUNT_INSN_SIZE | ||
928 | LOAD_REG_ADDR(r5,ftrace_trace_function) | ||
929 | ld r5,0(r5) | ||
930 | ld r5,0(r5) | ||
931 | mtctr r5 | ||
932 | bctrl | ||
933 | |||
934 | nop | ||
935 | ld r0, 128(r1) | ||
936 | mtlr r0 | ||
937 | addi r1, r1, 112 | ||
938 | _GLOBAL(ftrace_stub) | ||
939 | blr | ||
940 | |||
941 | #endif | ||
942 | #endif | ||
diff --git a/arch/powerpc/kernel/ftrace.c b/arch/powerpc/kernel/ftrace.c new file mode 100644 index 000000000000..3855ceb937b0 --- /dev/null +++ b/arch/powerpc/kernel/ftrace.c | |||
@@ -0,0 +1,154 @@ | |||
1 | /* | ||
2 | * Code for replacing ftrace calls with jumps. | ||
3 | * | ||
4 | * Copyright (C) 2007-2008 Steven Rostedt <srostedt@redhat.com> | ||
5 | * | ||
6 | * Thanks goes out to P.A. Semi, Inc for supplying me with a PPC64 box. | ||
7 | * | ||
8 | */ | ||
9 | |||
10 | #include <linux/spinlock.h> | ||
11 | #include <linux/hardirq.h> | ||
12 | #include <linux/ftrace.h> | ||
13 | #include <linux/percpu.h> | ||
14 | #include <linux/init.h> | ||
15 | #include <linux/list.h> | ||
16 | |||
17 | #include <asm/cacheflush.h> | ||
18 | #include <asm/ftrace.h> | ||
19 | |||
20 | |||
21 | static unsigned int ftrace_nop = 0x60000000; | ||
22 | |||
23 | #ifdef CONFIG_PPC32 | ||
24 | # define GET_ADDR(addr) addr | ||
25 | #else | ||
26 | /* PowerPC64's functions are data that points to the functions */ | ||
27 | # define GET_ADDR(addr) *(unsigned long *)addr | ||
28 | #endif | ||
29 | |||
30 | |||
31 | static unsigned int notrace ftrace_calc_offset(long ip, long addr) | ||
32 | { | ||
33 | return (int)(addr - ip); | ||
34 | } | ||
35 | |||
36 | notrace unsigned char *ftrace_nop_replace(void) | ||
37 | { | ||
38 | return (char *)&ftrace_nop; | ||
39 | } | ||
40 | |||
41 | notrace unsigned char *ftrace_call_replace(unsigned long ip, unsigned long addr) | ||
42 | { | ||
43 | static unsigned int op; | ||
44 | |||
45 | /* | ||
46 | * It would be nice to just use create_function_call, but that will | ||
47 | * update the code itself. Here we need to just return the | ||
48 | * instruction that is going to be modified, without modifying the | ||
49 | * code. | ||
50 | */ | ||
51 | addr = GET_ADDR(addr); | ||
52 | |||
53 | /* Set to "bl addr" */ | ||
54 | op = 0x48000001 | (ftrace_calc_offset(ip, addr) & 0x03fffffc); | ||
55 | |||
56 | /* | ||
57 | * No locking needed, this must be called via kstop_machine | ||
58 | * which in essence is like running on a uniprocessor machine. | ||
59 | */ | ||
60 | return (unsigned char *)&op; | ||
61 | } | ||
62 | |||
63 | #ifdef CONFIG_PPC64 | ||
64 | # define _ASM_ALIGN " .align 3 " | ||
65 | # define _ASM_PTR " .llong " | ||
66 | #else | ||
67 | # define _ASM_ALIGN " .align 2 " | ||
68 | # define _ASM_PTR " .long " | ||
69 | #endif | ||
70 | |||
71 | notrace int | ||
72 | ftrace_modify_code(unsigned long ip, unsigned char *old_code, | ||
73 | unsigned char *new_code) | ||
74 | { | ||
75 | unsigned replaced; | ||
76 | unsigned old = *(unsigned *)old_code; | ||
77 | unsigned new = *(unsigned *)new_code; | ||
78 | int faulted = 0; | ||
79 | |||
80 | /* | ||
81 | * Note: Due to modules and __init, code can | ||
82 | * disappear and change, we need to protect against faulting | ||
83 | * as well as code changing. | ||
84 | * | ||
85 | * No real locking needed, this code is run through | ||
86 | * kstop_machine. | ||
87 | */ | ||
88 | asm volatile ( | ||
89 | "1: lwz %1, 0(%2)\n" | ||
90 | " cmpw %1, %5\n" | ||
91 | " bne 2f\n" | ||
92 | " stwu %3, 0(%2)\n" | ||
93 | "2:\n" | ||
94 | ".section .fixup, \"ax\"\n" | ||
95 | "3: li %0, 1\n" | ||
96 | " b 2b\n" | ||
97 | ".previous\n" | ||
98 | ".section __ex_table,\"a\"\n" | ||
99 | _ASM_ALIGN "\n" | ||
100 | _ASM_PTR "1b, 3b\n" | ||
101 | ".previous" | ||
102 | : "=r"(faulted), "=r"(replaced) | ||
103 | : "r"(ip), "r"(new), | ||
104 | "0"(faulted), "r"(old) | ||
105 | : "memory"); | ||
106 | |||
107 | if (replaced != old && replaced != new) | ||
108 | faulted = 2; | ||
109 | |||
110 | if (!faulted) | ||
111 | flush_icache_range(ip, ip + 8); | ||
112 | |||
113 | return faulted; | ||
114 | } | ||
115 | |||
116 | notrace int ftrace_update_ftrace_func(ftrace_func_t func) | ||
117 | { | ||
118 | unsigned long ip = (unsigned long)(&ftrace_call); | ||
119 | unsigned char old[MCOUNT_INSN_SIZE], *new; | ||
120 | int ret; | ||
121 | |||
122 | memcpy(old, &ftrace_call, MCOUNT_INSN_SIZE); | ||
123 | new = ftrace_call_replace(ip, (unsigned long)func); | ||
124 | ret = ftrace_modify_code(ip, old, new); | ||
125 | |||
126 | return ret; | ||
127 | } | ||
128 | |||
129 | notrace int ftrace_mcount_set(unsigned long *data) | ||
130 | { | ||
131 | unsigned long ip = (long)(&mcount_call); | ||
132 | unsigned long *addr = data; | ||
133 | unsigned char old[MCOUNT_INSN_SIZE], *new; | ||
134 | |||
135 | /* | ||
136 | * Replace the mcount stub with a pointer to the | ||
137 | * ip recorder function. | ||
138 | */ | ||
139 | memcpy(old, &mcount_call, MCOUNT_INSN_SIZE); | ||
140 | new = ftrace_call_replace(ip, *addr); | ||
141 | *addr = ftrace_modify_code(ip, old, new); | ||
142 | |||
143 | return 0; | ||
144 | } | ||
145 | |||
146 | int __init ftrace_dyn_arch_init(void *data) | ||
147 | { | ||
148 | /* This is running in kstop_machine */ | ||
149 | |||
150 | ftrace_mcount_set(data); | ||
151 | |||
152 | return 0; | ||
153 | } | ||
154 | |||
diff --git a/arch/powerpc/kernel/io.c b/arch/powerpc/kernel/io.c index e31aca9208eb..1882bf419fa6 100644 --- a/arch/powerpc/kernel/io.c +++ b/arch/powerpc/kernel/io.c | |||
@@ -120,7 +120,8 @@ EXPORT_SYMBOL(_outsl_ns); | |||
120 | 120 | ||
121 | #define IO_CHECK_ALIGN(v,a) ((((unsigned long)(v)) & ((a) - 1)) == 0) | 121 | #define IO_CHECK_ALIGN(v,a) ((((unsigned long)(v)) & ((a) - 1)) == 0) |
122 | 122 | ||
123 | void _memset_io(volatile void __iomem *addr, int c, unsigned long n) | 123 | notrace void |
124 | _memset_io(volatile void __iomem *addr, int c, unsigned long n) | ||
124 | { | 125 | { |
125 | void *p = (void __force *)addr; | 126 | void *p = (void __force *)addr; |
126 | u32 lc = c; | 127 | u32 lc = c; |
diff --git a/arch/powerpc/kernel/irq.c b/arch/powerpc/kernel/irq.c index d6df018bb584..6ac8612da3c3 100644 --- a/arch/powerpc/kernel/irq.c +++ b/arch/powerpc/kernel/irq.c | |||
@@ -98,7 +98,7 @@ EXPORT_SYMBOL(irq_desc); | |||
98 | 98 | ||
99 | int distribute_irqs = 1; | 99 | int distribute_irqs = 1; |
100 | 100 | ||
101 | static inline unsigned long get_hard_enabled(void) | 101 | static inline notrace unsigned long get_hard_enabled(void) |
102 | { | 102 | { |
103 | unsigned long enabled; | 103 | unsigned long enabled; |
104 | 104 | ||
@@ -108,13 +108,13 @@ static inline unsigned long get_hard_enabled(void) | |||
108 | return enabled; | 108 | return enabled; |
109 | } | 109 | } |
110 | 110 | ||
111 | static inline void set_soft_enabled(unsigned long enable) | 111 | static inline notrace void set_soft_enabled(unsigned long enable) |
112 | { | 112 | { |
113 | __asm__ __volatile__("stb %0,%1(13)" | 113 | __asm__ __volatile__("stb %0,%1(13)" |
114 | : : "r" (enable), "i" (offsetof(struct paca_struct, soft_enabled))); | 114 | : : "r" (enable), "i" (offsetof(struct paca_struct, soft_enabled))); |
115 | } | 115 | } |
116 | 116 | ||
117 | void raw_local_irq_restore(unsigned long en) | 117 | notrace void raw_local_irq_restore(unsigned long en) |
118 | { | 118 | { |
119 | /* | 119 | /* |
120 | * get_paca()->soft_enabled = en; | 120 | * get_paca()->soft_enabled = en; |
diff --git a/arch/powerpc/kernel/ppc_ksyms.c b/arch/powerpc/kernel/ppc_ksyms.c index 958ecb9ae7dc..e1ea4fe5cfbd 100644 --- a/arch/powerpc/kernel/ppc_ksyms.c +++ b/arch/powerpc/kernel/ppc_ksyms.c | |||
@@ -42,6 +42,7 @@ | |||
42 | #include <asm/div64.h> | 42 | #include <asm/div64.h> |
43 | #include <asm/signal.h> | 43 | #include <asm/signal.h> |
44 | #include <asm/dcr.h> | 44 | #include <asm/dcr.h> |
45 | #include <asm/ftrace.h> | ||
45 | 46 | ||
46 | #ifdef CONFIG_PPC32 | 47 | #ifdef CONFIG_PPC32 |
47 | extern void transfer_to_handler(void); | 48 | extern void transfer_to_handler(void); |
@@ -67,6 +68,10 @@ EXPORT_SYMBOL(single_step_exception); | |||
67 | EXPORT_SYMBOL(sys_sigreturn); | 68 | EXPORT_SYMBOL(sys_sigreturn); |
68 | #endif | 69 | #endif |
69 | 70 | ||
71 | #ifdef CONFIG_FTRACE | ||
72 | EXPORT_SYMBOL(_mcount); | ||
73 | #endif | ||
74 | |||
70 | EXPORT_SYMBOL(strcpy); | 75 | EXPORT_SYMBOL(strcpy); |
71 | EXPORT_SYMBOL(strncpy); | 76 | EXPORT_SYMBOL(strncpy); |
72 | EXPORT_SYMBOL(strcat); | 77 | EXPORT_SYMBOL(strcat); |
diff --git a/arch/powerpc/kernel/setup_32.c b/arch/powerpc/kernel/setup_32.c index 0109e7f0ccf9..4efebe88e64a 100644 --- a/arch/powerpc/kernel/setup_32.c +++ b/arch/powerpc/kernel/setup_32.c | |||
@@ -81,7 +81,7 @@ int ucache_bsize; | |||
81 | * from the address that it was linked at, so we must use RELOC/PTRRELOC | 81 | * from the address that it was linked at, so we must use RELOC/PTRRELOC |
82 | * to access static data (including strings). -- paulus | 82 | * to access static data (including strings). -- paulus |
83 | */ | 83 | */ |
84 | unsigned long __init early_init(unsigned long dt_ptr) | 84 | notrace unsigned long __init early_init(unsigned long dt_ptr) |
85 | { | 85 | { |
86 | unsigned long offset = reloc_offset(); | 86 | unsigned long offset = reloc_offset(); |
87 | struct cpu_spec *spec; | 87 | struct cpu_spec *spec; |
@@ -115,7 +115,7 @@ unsigned long __init early_init(unsigned long dt_ptr) | |||
115 | * This is called very early on the boot process, after a minimal | 115 | * This is called very early on the boot process, after a minimal |
116 | * MMU environment has been set up but before MMU_init is called. | 116 | * MMU environment has been set up but before MMU_init is called. |
117 | */ | 117 | */ |
118 | void __init machine_init(unsigned long dt_ptr, unsigned long phys) | 118 | notrace void __init machine_init(unsigned long dt_ptr, unsigned long phys) |
119 | { | 119 | { |
120 | /* Enable early debugging if any specified (see udbg.h) */ | 120 | /* Enable early debugging if any specified (see udbg.h) */ |
121 | udbg_early_init(); | 121 | udbg_early_init(); |
@@ -142,7 +142,7 @@ void __init machine_init(unsigned long dt_ptr, unsigned long phys) | |||
142 | 142 | ||
143 | #ifdef CONFIG_BOOKE_WDT | 143 | #ifdef CONFIG_BOOKE_WDT |
144 | /* Checks wdt=x and wdt_period=xx command-line option */ | 144 | /* Checks wdt=x and wdt_period=xx command-line option */ |
145 | int __init early_parse_wdt(char *p) | 145 | notrace int __init early_parse_wdt(char *p) |
146 | { | 146 | { |
147 | if (p && strncmp(p, "0", 1) != 0) | 147 | if (p && strncmp(p, "0", 1) != 0) |
148 | booke_wdt_enabled = 1; | 148 | booke_wdt_enabled = 1; |
diff --git a/arch/powerpc/kernel/vmlinux.lds.S b/arch/powerpc/kernel/vmlinux.lds.S index 6856f6c15727..87a72c66ce27 100644 --- a/arch/powerpc/kernel/vmlinux.lds.S +++ b/arch/powerpc/kernel/vmlinux.lds.S | |||
@@ -64,8 +64,6 @@ SECTIONS | |||
64 | 64 | ||
65 | NOTES | 65 | NOTES |
66 | 66 | ||
67 | BUG_TABLE | ||
68 | |||
69 | /* | 67 | /* |
70 | * Init sections discarded at runtime | 68 | * Init sections discarded at runtime |
71 | */ | 69 | */ |
diff --git a/arch/powerpc/platforms/powermac/Makefile b/arch/powerpc/platforms/powermac/Makefile index 4d72c8f72159..89774177b209 100644 --- a/arch/powerpc/platforms/powermac/Makefile +++ b/arch/powerpc/platforms/powermac/Makefile | |||
@@ -1,5 +1,10 @@ | |||
1 | CFLAGS_bootx_init.o += -fPIC | 1 | CFLAGS_bootx_init.o += -fPIC |
2 | 2 | ||
3 | ifdef CONFIG_FTRACE | ||
4 | # Do not trace early boot code | ||
5 | CFLAGS_REMOVE_bootx_init.o = -pg | ||
6 | endif | ||
7 | |||
3 | obj-y += pic.o setup.o time.o feature.o pci.o \ | 8 | obj-y += pic.o setup.o time.o feature.o pci.o \ |
4 | sleep.o low_i2c.o cache.o pfunc_core.o \ | 9 | sleep.o low_i2c.o cache.o pfunc_core.o \ |
5 | pfunc_base.o | 10 | pfunc_base.o |