perf trace: Beautify 'fsconfig' arguments
authorArnaldo Carvalho de Melo <acme@redhat.com>
Tue, 21 May 2019 18:36:44 +0000 (15:36 -0300)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Tue, 28 May 2019 21:37:43 +0000 (18:37 -0300)
commitdcc6fd64f2e9448ccc1c3e1ccd46a9ff5286b861
tree5a814921aab0f7381ff4fa5f2ba74fd6340fe883
parentd35293004a5e40c330ae5bf3667d716e702fe94a
perf trace: Beautify 'fsconfig' arguments

Use existing beautifiers for the first arg, fd, assigned using the
heuristic that looks for syscall arg names and associates SCA_FD with
'fd' named argumes, and wire up the recently introduced fsconfig cmd
table generator.

Now it should be possible to just use:

   perf trace -e fsconfig

As root and see all fsconfig syscalls with its args beautified, more
work needed to look at the command and according to it handle the 'key',
'value' and 'aux' args, using the 'fcntl' and 'futex' beautifiers as a
starting point to see how to suppress sets of these last three args that
may not be used by the 'cmd' arg, etc.

  # cat sys_fsconfig.c
  #define _GNU_SOURCE         /* See feature_test_macros(7) */
  #include <unistd.h>
  #include <sys/syscall.h>   /* For SYS_xxx definitions */
  #include <fcntl.h>

  #define __NR_fsconfig 431

  enum fsconfig_command {
   FSCONFIG_SET_FLAG = 0, /* Set parameter, supplying no value */
   FSCONFIG_SET_STRING = 1, /* Set parameter, supplying a string value */
   FSCONFIG_SET_BINARY = 2, /* Set parameter, supplying a binary blob value */
   FSCONFIG_SET_PATH = 3, /* Set parameter, supplying an object by path */
   FSCONFIG_SET_PATH_EMPTY = 4, /* Set parameter, supplying an object by (empty) path */
   FSCONFIG_SET_FD = 5, /* Set parameter, supplying an object by fd */
   FSCONFIG_CMD_CREATE = 6, /* Invoke superblock creation */
   FSCONFIG_CMD_RECONFIGURE = 7, /* Invoke superblock reconfiguration */
  };

  static inline int sys_fsconfig(int fd, int cmd, const char *key, const void *value, int aux)
  {
   syscall(__NR_fsconfig, fd, cmd, key, value, aux);
  }

  int main(int argc, char *argv[])
  {
   int fd = 0, aux = 0;

   open("/foo", 0);
   sys_fsconfig(fd++, FSCONFIG_SET_FLAG,      "/foo1", "/bar1", aux++);
   sys_fsconfig(fd++, FSCONFIG_SET_STRING,      "/foo2", "/bar2", aux++);
   sys_fsconfig(fd++, FSCONFIG_SET_BINARY,      "/foo3", "/bar3", aux++);
   sys_fsconfig(fd++, FSCONFIG_SET_PATH,      "/foo4", "/bar4", aux++);
   sys_fsconfig(fd++, FSCONFIG_SET_PATH_EMPTY,  "/foo5", "/bar5", aux++);
   sys_fsconfig(fd++, FSCONFIG_SET_FD,      "/foo6", "/bar6", aux++);
   sys_fsconfig(fd++, FSCONFIG_CMD_CREATE,      "/foo7", "/bar7", aux++);
   sys_fsconfig(fd++, FSCONFIG_CMD_RECONFIGURE, "/foo8", "/bar8", aux++);
   return 0;
  }
  # trace -e fsconfig ./sys_fsconfig
  fsconfig(0, FSCONFIG_SET_FLAG, 0x40201b, 0x402015, 0) = -1 EINVAL (Invalid argument)
  fsconfig(1, FSCONFIG_SET_STRING, 0x402027, 0x402021, 1) = -1 EINVAL (Invalid argument)
  fsconfig(2, FSCONFIG_SET_BINARY, 0x402033, 0x40202d, 2) = -1 EINVAL (Invalid argument)
  fsconfig(3, FSCONFIG_SET_PATH, 0x40203f, 0x402039, 3) = -1 EBADF (Bad file descriptor)
  fsconfig(4, FSCONFIG_SET_PATH_EMPTY, 0x40204b, 0x402045, 4) = -1 EBADF (Bad file descriptor)
  fsconfig(5, FSCONFIG_SET_FD, 0x402057, 0x402051, 5) = -1 EINVAL (Invalid argument)
  fsconfig(6, FSCONFIG_CMD_CREATE, 0x402063, 0x40205d, 6) = -1 EINVAL (Invalid argument)
  fsconfig(7, FSCONFIG_CMD_RECONFIGURE, 0x40206f, 0x402069, 7) = -1 EINVAL (Invalid argument)
  #

Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Cc: Brendan Gregg <brendan.d.gregg@gmail.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Luis Cláudio Gonçalves <lclaudio@redhat.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Link: https://lkml.kernel.org/n/tip-fb04b76cm59zfuv1wzu40uxy@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/Makefile.perf
tools/perf/builtin-trace.c