diff options
Diffstat (limited to 'arch/powerpc/platforms/pseries')
-rw-r--r-- | arch/powerpc/platforms/pseries/hvCall.S | 31 | ||||
-rw-r--r-- | arch/powerpc/platforms/pseries/hvCall_inst.c | 5 | ||||
-rw-r--r-- | arch/powerpc/platforms/pseries/lpar.c | 9 |
3 files changed, 29 insertions, 16 deletions
diff --git a/arch/powerpc/platforms/pseries/hvCall.S b/arch/powerpc/platforms/pseries/hvCall.S index 01e95ab18d35..383a5d0e9818 100644 --- a/arch/powerpc/platforms/pseries/hvCall.S +++ b/arch/powerpc/platforms/pseries/hvCall.S | |||
@@ -30,7 +30,7 @@ hcall_tracepoint_refcount: | |||
30 | * in early init (eg when populating the MMU hashtable) by using an | 30 | * in early init (eg when populating the MMU hashtable) by using an |
31 | * unconditional cpu feature. | 31 | * unconditional cpu feature. |
32 | */ | 32 | */ |
33 | #define HCALL_INST_PRECALL \ | 33 | #define HCALL_INST_PRECALL(FIRST_REG) \ |
34 | BEGIN_FTR_SECTION; \ | 34 | BEGIN_FTR_SECTION; \ |
35 | b 1f; \ | 35 | b 1f; \ |
36 | END_FTR_SECTION(0, 1); \ | 36 | END_FTR_SECTION(0, 1); \ |
@@ -47,6 +47,7 @@ END_FTR_SECTION(0, 1); \ | |||
47 | std r9,STK_PARM(r9)(r1); \ | 47 | std r9,STK_PARM(r9)(r1); \ |
48 | std r10,STK_PARM(r10)(r1); \ | 48 | std r10,STK_PARM(r10)(r1); \ |
49 | std r0,16(r1); \ | 49 | std r0,16(r1); \ |
50 | addi r4,r1,STK_PARM(FIRST_REG); \ | ||
50 | stdu r1,-STACK_FRAME_OVERHEAD(r1); \ | 51 | stdu r1,-STACK_FRAME_OVERHEAD(r1); \ |
51 | bl .__trace_hcall_entry; \ | 52 | bl .__trace_hcall_entry; \ |
52 | addi r1,r1,STACK_FRAME_OVERHEAD; \ | 53 | addi r1,r1,STACK_FRAME_OVERHEAD; \ |
@@ -68,7 +69,7 @@ END_FTR_SECTION(0, 1); \ | |||
68 | * in early init (eg when populating the MMU hashtable) by using an | 69 | * in early init (eg when populating the MMU hashtable) by using an |
69 | * unconditional cpu feature. | 70 | * unconditional cpu feature. |
70 | */ | 71 | */ |
71 | #define HCALL_INST_POSTCALL \ | 72 | #define __HCALL_INST_POSTCALL \ |
72 | BEGIN_FTR_SECTION; \ | 73 | BEGIN_FTR_SECTION; \ |
73 | b 1f; \ | 74 | b 1f; \ |
74 | END_FTR_SECTION(0, 1); \ | 75 | END_FTR_SECTION(0, 1); \ |
@@ -88,9 +89,19 @@ END_FTR_SECTION(0, 1); \ | |||
88 | ld r3,STK_PARM(r3)(r1); \ | 89 | ld r3,STK_PARM(r3)(r1); \ |
89 | mtlr r0; \ | 90 | mtlr r0; \ |
90 | 1: | 91 | 1: |
92 | |||
93 | #define HCALL_INST_POSTCALL_NORETS \ | ||
94 | li r5,0; \ | ||
95 | __HCALL_INST_POSTCALL | ||
96 | |||
97 | #define HCALL_INST_POSTCALL(BUFREG) \ | ||
98 | mr r5,BUFREG; \ | ||
99 | __HCALL_INST_POSTCALL | ||
100 | |||
91 | #else | 101 | #else |
92 | #define HCALL_INST_PRECALL | 102 | #define HCALL_INST_PRECALL(FIRST_ARG) |
93 | #define HCALL_INST_POSTCALL | 103 | #define HCALL_INST_POSTCALL_NORETS |
104 | #define HCALL_INST_POSTCALL(BUFREG) | ||
94 | #endif | 105 | #endif |
95 | 106 | ||
96 | .text | 107 | .text |
@@ -101,11 +112,11 @@ _GLOBAL(plpar_hcall_norets) | |||
101 | mfcr r0 | 112 | mfcr r0 |
102 | stw r0,8(r1) | 113 | stw r0,8(r1) |
103 | 114 | ||
104 | HCALL_INST_PRECALL | 115 | HCALL_INST_PRECALL(r4) |
105 | 116 | ||
106 | HVSC /* invoke the hypervisor */ | 117 | HVSC /* invoke the hypervisor */ |
107 | 118 | ||
108 | HCALL_INST_POSTCALL | 119 | HCALL_INST_POSTCALL_NORETS |
109 | 120 | ||
110 | lwz r0,8(r1) | 121 | lwz r0,8(r1) |
111 | mtcrf 0xff,r0 | 122 | mtcrf 0xff,r0 |
@@ -117,7 +128,7 @@ _GLOBAL(plpar_hcall) | |||
117 | mfcr r0 | 128 | mfcr r0 |
118 | stw r0,8(r1) | 129 | stw r0,8(r1) |
119 | 130 | ||
120 | HCALL_INST_PRECALL | 131 | HCALL_INST_PRECALL(r5) |
121 | 132 | ||
122 | std r4,STK_PARM(r4)(r1) /* Save ret buffer */ | 133 | std r4,STK_PARM(r4)(r1) /* Save ret buffer */ |
123 | 134 | ||
@@ -136,7 +147,7 @@ _GLOBAL(plpar_hcall) | |||
136 | std r6, 16(r12) | 147 | std r6, 16(r12) |
137 | std r7, 24(r12) | 148 | std r7, 24(r12) |
138 | 149 | ||
139 | HCALL_INST_POSTCALL | 150 | HCALL_INST_POSTCALL(r12) |
140 | 151 | ||
141 | lwz r0,8(r1) | 152 | lwz r0,8(r1) |
142 | mtcrf 0xff,r0 | 153 | mtcrf 0xff,r0 |
@@ -183,7 +194,7 @@ _GLOBAL(plpar_hcall9) | |||
183 | mfcr r0 | 194 | mfcr r0 |
184 | stw r0,8(r1) | 195 | stw r0,8(r1) |
185 | 196 | ||
186 | HCALL_INST_PRECALL | 197 | HCALL_INST_PRECALL(r5) |
187 | 198 | ||
188 | std r4,STK_PARM(r4)(r1) /* Save ret buffer */ | 199 | std r4,STK_PARM(r4)(r1) /* Save ret buffer */ |
189 | 200 | ||
@@ -211,7 +222,7 @@ _GLOBAL(plpar_hcall9) | |||
211 | std r11,56(r12) | 222 | std r11,56(r12) |
212 | std r0, 64(r12) | 223 | std r0, 64(r12) |
213 | 224 | ||
214 | HCALL_INST_POSTCALL | 225 | HCALL_INST_POSTCALL(r12) |
215 | 226 | ||
216 | lwz r0,8(r1) | 227 | lwz r0,8(r1) |
217 | mtcrf 0xff,r0 | 228 | mtcrf 0xff,r0 |
diff --git a/arch/powerpc/platforms/pseries/hvCall_inst.c b/arch/powerpc/platforms/pseries/hvCall_inst.c index e44e1035f133..2f58c71b7259 100644 --- a/arch/powerpc/platforms/pseries/hvCall_inst.c +++ b/arch/powerpc/platforms/pseries/hvCall_inst.c | |||
@@ -102,7 +102,7 @@ static const struct file_operations hcall_inst_seq_fops = { | |||
102 | #define CPU_NAME_BUF_SIZE 32 | 102 | #define CPU_NAME_BUF_SIZE 32 |
103 | 103 | ||
104 | 104 | ||
105 | static void probe_hcall_entry(unsigned long opcode) | 105 | static void probe_hcall_entry(unsigned long opcode, unsigned long *args) |
106 | { | 106 | { |
107 | struct hcall_stats *h; | 107 | struct hcall_stats *h; |
108 | 108 | ||
@@ -114,7 +114,8 @@ static void probe_hcall_entry(unsigned long opcode) | |||
114 | h->purr_start = mfspr(SPRN_PURR); | 114 | h->purr_start = mfspr(SPRN_PURR); |
115 | } | 115 | } |
116 | 116 | ||
117 | static void probe_hcall_exit(unsigned long opcode, unsigned long retval) | 117 | static void probe_hcall_exit(unsigned long opcode, unsigned long retval, |
118 | unsigned long *retbuf) | ||
118 | { | 119 | { |
119 | struct hcall_stats *h; | 120 | struct hcall_stats *h; |
120 | 121 | ||
diff --git a/arch/powerpc/platforms/pseries/lpar.c b/arch/powerpc/platforms/pseries/lpar.c index 4b7b6e8e32de..0707653612ba 100644 --- a/arch/powerpc/platforms/pseries/lpar.c +++ b/arch/powerpc/platforms/pseries/lpar.c | |||
@@ -683,13 +683,14 @@ void hcall_tracepoint_unregfunc(void) | |||
683 | hcall_tracepoint_refcount--; | 683 | hcall_tracepoint_refcount--; |
684 | } | 684 | } |
685 | 685 | ||
686 | void __trace_hcall_entry(unsigned long opcode) | 686 | void __trace_hcall_entry(unsigned long opcode, unsigned long *args) |
687 | { | 687 | { |
688 | trace_hcall_entry(opcode); | 688 | trace_hcall_entry(opcode, args); |
689 | } | 689 | } |
690 | 690 | ||
691 | void __trace_hcall_exit(long opcode, unsigned long retval) | 691 | void __trace_hcall_exit(long opcode, unsigned long retval, |
692 | unsigned long *retbuf) | ||
692 | { | 693 | { |
693 | trace_hcall_exit(opcode, retval); | 694 | trace_hcall_exit(opcode, retval, retbuf); |
694 | } | 695 | } |
695 | #endif | 696 | #endif |