diff options
| author | Heiko Carstens <[email protected]> | 2015-02-28 11:35:26 +0100 | 
|---|---|---|
| committer | Martin Schwidefsky <[email protected]> | 2015-03-02 11:35:53 -0800 | 
| commit | a9ca8eb7afb4f1c90d8e43092e94c4e86785efbc (patch) | |
| tree | 0e728829761cb824e4e470e1429d7144027a4c6c /lib/mpi/mpi-inline.h | |
| parent | d94260832d0d78aba398de361c0416a93cabc046 (diff) | |
s390/ftrace: fix crashes when switching tracers / add notrace to cpu_relax()
With git commit 4d92f50249eb ("s390: reintroduce diag 44 calls for
cpu_relax()") I reintroduced a non-trivial cpu_relax() variant on s390.
The difference to the previous variant however is that the new version is
an out-of-line function, which will be traced if function tracing is enabled.
Switching to different tracers includes instruction patching. Therefore this
is done within stop_machine() "context" to prevent that any function tracing
is going on while instructions are being patched.
With the new out-of-line variant of cpu_relax() this is not true anymore,
since cpu_relax() gets called in a busy loop by all waiting cpus within
stop_machine() until function patching is finished.
Therefore cpu_relax() must be marked notrace.
This fixes kernel crashes when frequently switching between "function" and
"function_graph" tracers.
Moving cpu_relax() to a header file again, doesn't work because of header
include order dependencies.
Signed-off-by: Heiko Carstens <[email protected]>
Signed-off-by: Martin Schwidefsky <[email protected]>
Diffstat (limited to 'lib/mpi/mpi-inline.h')
0 files changed, 0 insertions, 0 deletions