2015-08-21 14:05:32 +00:00
|
|
|
/*
|
|
|
|
* Tracepoint definitions for s390
|
|
|
|
*
|
|
|
|
* Copyright IBM Corp. 2015
|
|
|
|
* Author(s): Martin Schwidefsky <schwidefsky@de.ibm.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/percpu.h>
|
|
|
|
#define CREATE_TRACE_POINTS
|
|
|
|
#include <asm/trace/diag.h>
|
|
|
|
|
2015-11-05 12:50:04 +00:00
|
|
|
EXPORT_TRACEPOINT_SYMBOL(s390_diagnose);
|
2015-08-21 14:05:32 +00:00
|
|
|
|
|
|
|
static DEFINE_PER_CPU(unsigned int, diagnose_trace_depth);
|
|
|
|
|
2015-11-05 12:50:04 +00:00
|
|
|
void trace_s390_diagnose_norecursion(int diag_nr)
|
2015-08-21 14:05:32 +00:00
|
|
|
{
|
|
|
|
unsigned long flags;
|
|
|
|
unsigned int *depth;
|
|
|
|
|
2016-02-10 13:13:24 +00:00
|
|
|
/* Avoid lockdep recursion. */
|
|
|
|
if (IS_ENABLED(CONFIG_LOCKDEP))
|
|
|
|
return;
|
2015-08-21 14:05:32 +00:00
|
|
|
local_irq_save(flags);
|
|
|
|
depth = this_cpu_ptr(&diagnose_trace_depth);
|
|
|
|
if (*depth == 0) {
|
|
|
|
(*depth)++;
|
2015-11-05 12:50:04 +00:00
|
|
|
trace_s390_diagnose(diag_nr);
|
2015-08-21 14:05:32 +00:00
|
|
|
(*depth)--;
|
|
|
|
}
|
|
|
|
local_irq_restore(flags);
|
|
|
|
}
|