perf trace: Put syscall formatter parms into struct

So that we can add more state to formatters without having to modify
all of them.

Example is to pass a table to a generic string formatter, like for
setitimer 'which' arg.

Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: David Ahern <dsahern@gmail.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/n/tip-zyi2esmas5wfrxznh0x0fkiz@git.kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 165108a9
...@@ -33,22 +33,24 @@ ...@@ -33,22 +33,24 @@
# define MADV_UNMERGEABLE 13 # define MADV_UNMERGEABLE 13
#endif #endif
struct syscall_arg {
unsigned long val;
u8 idx;
u8 mask;
};
static size_t syscall_arg__scnprintf_hex(char *bf, size_t size, static size_t syscall_arg__scnprintf_hex(char *bf, size_t size,
unsigned long arg, struct syscall_arg *arg)
u8 arg_idx __maybe_unused,
u8 *arg_mask __maybe_unused)
{ {
return scnprintf(bf, size, "%#lx", arg); return scnprintf(bf, size, "%#lx", arg->val);
} }
#define SCA_HEX syscall_arg__scnprintf_hex #define SCA_HEX syscall_arg__scnprintf_hex
static size_t syscall_arg__scnprintf_whence(char *bf, size_t size, static size_t syscall_arg__scnprintf_whence(char *bf, size_t size,
unsigned long arg, struct syscall_arg *arg)
u8 arg_idx __maybe_unused,
u8 *arg_mask __maybe_unused)
{ {
int whence = arg; int whence = arg->val;
switch (whence) { switch (whence) {
#define P_WHENCE(n) case SEEK_##n: return scnprintf(bf, size, #n) #define P_WHENCE(n) case SEEK_##n: return scnprintf(bf, size, #n)
...@@ -71,11 +73,9 @@ static size_t syscall_arg__scnprintf_whence(char *bf, size_t size, ...@@ -71,11 +73,9 @@ static size_t syscall_arg__scnprintf_whence(char *bf, size_t size,
#define SCA_WHENCE syscall_arg__scnprintf_whence #define SCA_WHENCE syscall_arg__scnprintf_whence
static size_t syscall_arg__scnprintf_mmap_prot(char *bf, size_t size, static size_t syscall_arg__scnprintf_mmap_prot(char *bf, size_t size,
unsigned long arg, struct syscall_arg *arg)
u8 arg_idx __maybe_unused,
u8 *arg_mask __maybe_unused)
{ {
int printed = 0, prot = arg; int printed = 0, prot = arg->val;
if (prot == PROT_NONE) if (prot == PROT_NONE)
return scnprintf(bf, size, "NONE"); return scnprintf(bf, size, "NONE");
...@@ -104,10 +104,9 @@ static size_t syscall_arg__scnprintf_mmap_prot(char *bf, size_t size, ...@@ -104,10 +104,9 @@ static size_t syscall_arg__scnprintf_mmap_prot(char *bf, size_t size,
#define SCA_MMAP_PROT syscall_arg__scnprintf_mmap_prot #define SCA_MMAP_PROT syscall_arg__scnprintf_mmap_prot
static size_t syscall_arg__scnprintf_mmap_flags(char *bf, size_t size, static size_t syscall_arg__scnprintf_mmap_flags(char *bf, size_t size,
unsigned long arg, u8 arg_idx __maybe_unused, struct syscall_arg *arg)
u8 *arg_mask __maybe_unused)
{ {
int printed = 0, flags = arg; int printed = 0, flags = arg->val;
#define P_MMAP_FLAG(n) \ #define P_MMAP_FLAG(n) \
if (flags & MAP_##n) { \ if (flags & MAP_##n) { \
...@@ -148,10 +147,9 @@ static size_t syscall_arg__scnprintf_mmap_flags(char *bf, size_t size, ...@@ -148,10 +147,9 @@ static size_t syscall_arg__scnprintf_mmap_flags(char *bf, size_t size,
#define SCA_MMAP_FLAGS syscall_arg__scnprintf_mmap_flags #define SCA_MMAP_FLAGS syscall_arg__scnprintf_mmap_flags
static size_t syscall_arg__scnprintf_madvise_behavior(char *bf, size_t size, static size_t syscall_arg__scnprintf_madvise_behavior(char *bf, size_t size,
unsigned long arg, u8 arg_idx __maybe_unused, struct syscall_arg *arg)
u8 *arg_mask __maybe_unused)
{ {
int behavior = arg; int behavior = arg->val;
switch (behavior) { switch (behavior) {
#define P_MADV_BHV(n) case MADV_##n: return scnprintf(bf, size, #n) #define P_MADV_BHV(n) case MADV_##n: return scnprintf(bf, size, #n)
...@@ -190,8 +188,7 @@ static size_t syscall_arg__scnprintf_madvise_behavior(char *bf, size_t size, ...@@ -190,8 +188,7 @@ static size_t syscall_arg__scnprintf_madvise_behavior(char *bf, size_t size,
#define SCA_MADV_BHV syscall_arg__scnprintf_madvise_behavior #define SCA_MADV_BHV syscall_arg__scnprintf_madvise_behavior
static size_t syscall_arg__scnprintf_futex_op(char *bf, size_t size, unsigned long arg, static size_t syscall_arg__scnprintf_futex_op(char *bf, size_t size, struct syscall_arg *arg)
u8 arg_idx __maybe_unused, u8 *arg_mask)
{ {
enum syscall_futex_args { enum syscall_futex_args {
SCF_UADDR = (1 << 0), SCF_UADDR = (1 << 0),
...@@ -201,24 +198,24 @@ static size_t syscall_arg__scnprintf_futex_op(char *bf, size_t size, unsigned lo ...@@ -201,24 +198,24 @@ static size_t syscall_arg__scnprintf_futex_op(char *bf, size_t size, unsigned lo
SCF_UADDR2 = (1 << 4), SCF_UADDR2 = (1 << 4),
SCF_VAL3 = (1 << 5), SCF_VAL3 = (1 << 5),
}; };
int op = arg; int op = arg->val;
int cmd = op & FUTEX_CMD_MASK; int cmd = op & FUTEX_CMD_MASK;
size_t printed = 0; size_t printed = 0;
switch (cmd) { switch (cmd) {
#define P_FUTEX_OP(n) case FUTEX_##n: printed = scnprintf(bf, size, #n); #define P_FUTEX_OP(n) case FUTEX_##n: printed = scnprintf(bf, size, #n);
P_FUTEX_OP(WAIT); *arg_mask |= SCF_VAL3|SCF_UADDR2; break; P_FUTEX_OP(WAIT); arg->mask |= SCF_VAL3|SCF_UADDR2; break;
P_FUTEX_OP(WAKE); *arg_mask |= SCF_VAL3|SCF_UADDR2|SCF_TIMEOUT; break; P_FUTEX_OP(WAKE); arg->mask |= SCF_VAL3|SCF_UADDR2|SCF_TIMEOUT; break;
P_FUTEX_OP(FD); *arg_mask |= SCF_VAL3|SCF_UADDR2|SCF_TIMEOUT; break; P_FUTEX_OP(FD); arg->mask |= SCF_VAL3|SCF_UADDR2|SCF_TIMEOUT; break;
P_FUTEX_OP(REQUEUE); *arg_mask |= SCF_VAL3|SCF_TIMEOUT; break; P_FUTEX_OP(REQUEUE); arg->mask |= SCF_VAL3|SCF_TIMEOUT; break;
P_FUTEX_OP(CMP_REQUEUE); *arg_mask |= SCF_TIMEOUT; break; P_FUTEX_OP(CMP_REQUEUE); arg->mask |= SCF_TIMEOUT; break;
P_FUTEX_OP(CMP_REQUEUE_PI); *arg_mask |= SCF_TIMEOUT; break; P_FUTEX_OP(CMP_REQUEUE_PI); arg->mask |= SCF_TIMEOUT; break;
P_FUTEX_OP(WAKE_OP); break; P_FUTEX_OP(WAKE_OP); break;
P_FUTEX_OP(LOCK_PI); *arg_mask |= SCF_VAL3|SCF_UADDR2|SCF_TIMEOUT; break; P_FUTEX_OP(LOCK_PI); arg->mask |= SCF_VAL3|SCF_UADDR2|SCF_TIMEOUT; break;
P_FUTEX_OP(UNLOCK_PI); *arg_mask |= SCF_VAL3|SCF_UADDR2|SCF_TIMEOUT; break; P_FUTEX_OP(UNLOCK_PI); arg->mask |= SCF_VAL3|SCF_UADDR2|SCF_TIMEOUT; break;
P_FUTEX_OP(TRYLOCK_PI); *arg_mask |= SCF_VAL3|SCF_UADDR2; break; P_FUTEX_OP(TRYLOCK_PI); arg->mask |= SCF_VAL3|SCF_UADDR2; break;
P_FUTEX_OP(WAIT_BITSET); *arg_mask |= SCF_UADDR2; break; P_FUTEX_OP(WAIT_BITSET); arg->mask |= SCF_UADDR2; break;
P_FUTEX_OP(WAKE_BITSET); *arg_mask |= SCF_UADDR2; break; P_FUTEX_OP(WAKE_BITSET); arg->mask |= SCF_UADDR2; break;
P_FUTEX_OP(WAIT_REQUEUE_PI); break; P_FUTEX_OP(WAIT_REQUEUE_PI); break;
default: printed = scnprintf(bf, size, "%#x", cmd); break; default: printed = scnprintf(bf, size, "%#x", cmd); break;
} }
...@@ -235,13 +232,12 @@ static size_t syscall_arg__scnprintf_futex_op(char *bf, size_t size, unsigned lo ...@@ -235,13 +232,12 @@ static size_t syscall_arg__scnprintf_futex_op(char *bf, size_t size, unsigned lo
#define SCA_FUTEX_OP syscall_arg__scnprintf_futex_op #define SCA_FUTEX_OP syscall_arg__scnprintf_futex_op
static size_t syscall_arg__scnprintf_open_flags(char *bf, size_t size, static size_t syscall_arg__scnprintf_open_flags(char *bf, size_t size,
unsigned long arg, struct syscall_arg *arg)
u8 arg_idx, u8 *arg_mask)
{ {
int printed = 0, flags = arg; int printed = 0, flags = arg->val;
if (!(flags & O_CREAT)) if (!(flags & O_CREAT))
*arg_mask |= 1 << (arg_idx + 1); /* Mask the mode parm */ arg->mask |= 1 << (arg->idx + 1); /* Mask the mode parm */
if (flags == 0) if (flags == 0)
return scnprintf(bf, size, "RDONLY"); return scnprintf(bf, size, "RDONLY");
...@@ -294,7 +290,7 @@ static size_t syscall_arg__scnprintf_open_flags(char *bf, size_t size, ...@@ -294,7 +290,7 @@ static size_t syscall_arg__scnprintf_open_flags(char *bf, size_t size,
static struct syscall_fmt { static struct syscall_fmt {
const char *name; const char *name;
const char *alias; const char *alias;
size_t (*arg_scnprintf[6])(char *bf, size_t size, unsigned long arg, u8 arg_idx, u8 *arg_mask); size_t (*arg_scnprintf[6])(char *bf, size_t size, struct syscall_arg *arg);
bool errmsg; bool errmsg;
bool timeout; bool timeout;
bool hexret; bool hexret;
...@@ -364,8 +360,7 @@ struct syscall { ...@@ -364,8 +360,7 @@ struct syscall {
const char *name; const char *name;
bool filtered; bool filtered;
struct syscall_fmt *fmt; struct syscall_fmt *fmt;
size_t (**arg_scnprintf)(char *bf, size_t size, size_t (**arg_scnprintf)(char *bf, size_t size, struct syscall_arg *arg);
unsigned long arg, u8 arg_idx, u8 *args_mask);
}; };
static size_t fprintf_duration(unsigned long t, FILE *fp) static size_t fprintf_duration(unsigned long t, FILE *fp)
...@@ -605,30 +600,35 @@ static int trace__read_syscall_info(struct trace *trace, int id) ...@@ -605,30 +600,35 @@ static int trace__read_syscall_info(struct trace *trace, int id)
static size_t syscall__scnprintf_args(struct syscall *sc, char *bf, size_t size, static size_t syscall__scnprintf_args(struct syscall *sc, char *bf, size_t size,
unsigned long *args) unsigned long *args)
{ {
int i = 0;
size_t printed = 0; size_t printed = 0;
if (sc->tp_format != NULL) { if (sc->tp_format != NULL) {
struct format_field *field; struct format_field *field;
u8 mask = 0, bit = 1; u8 bit = 1;
struct syscall_arg arg = {
.idx = 0,
.mask = 0,
};
for (field = sc->tp_format->format.fields->next; field; for (field = sc->tp_format->format.fields->next; field;
field = field->next, ++i, bit <<= 1) { field = field->next, ++arg.idx, bit <<= 1) {
if (mask & bit) if (arg.mask & bit)
continue; continue;
printed += scnprintf(bf + printed, size - printed, printed += scnprintf(bf + printed, size - printed,
"%s%s: ", printed ? ", " : "", field->name); "%s%s: ", printed ? ", " : "", field->name);
if (sc->arg_scnprintf && sc->arg_scnprintf[arg.idx]) {
if (sc->arg_scnprintf && sc->arg_scnprintf[i]) { arg.val = args[arg.idx];
printed += sc->arg_scnprintf[i](bf + printed, size - printed, printed += sc->arg_scnprintf[arg.idx](bf + printed,
args[i], i, &mask); size - printed, &arg);
} else { } else {
printed += scnprintf(bf + printed, size - printed, printed += scnprintf(bf + printed, size - printed,
"%ld", args[i]); "%ld", args[arg.idx]);
} }
} }
} else { } else {
int i = 0;
while (i < 6) { while (i < 6) {
printed += scnprintf(bf + printed, size - printed, printed += scnprintf(bf + printed, size - printed,
"%sarg%d: %ld", "%sarg%d: %ld",
......
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