Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/kdump Decode futex op codes.



details:   https://anonhg.NetBSD.org/src/rev/152f22820ad1
branches:  trunk
changeset: 1009677:152f22820ad1
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Thu Apr 30 12:17:01 2020 +0000

description:
Decode futex op codes.

diffstat:

 usr.bin/kdump/kdump.c |  77 +++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 75 insertions(+), 2 deletions(-)

diffs (112 lines):

diff -r a96d749e3daf -r 152f22820ad1 usr.bin/kdump/kdump.c
--- a/usr.bin/kdump/kdump.c     Thu Apr 30 12:13:39 2020 +0000
+++ b/usr.bin/kdump/kdump.c     Thu Apr 30 12:17:01 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: kdump.c,v 1.137 2020/04/20 00:35:41 christos Exp $     */
+/*     $NetBSD: kdump.c,v 1.138 2020/04/30 12:17:01 thorpej Exp $      */
 
 /*-
  * Copyright (c) 1988, 1993
@@ -39,7 +39,7 @@
 #if 0
 static char sccsid[] = "@(#)kdump.c    8.4 (Berkeley) 4/28/95";
 #else
-__RCSID("$NetBSD: kdump.c,v 1.137 2020/04/20 00:35:41 christos Exp $");
+__RCSID("$NetBSD: kdump.c,v 1.138 2020/04/30 12:17:01 thorpej Exp $");
 #endif
 #endif /* not lint */
 
@@ -55,6 +55,7 @@
 #include <sys/ioctl.h>
 #include <sys/ptrace.h>
 #include <sys/socket.h>
+#include <sys/futex.h>
 
 #include <ctype.h>
 #include <err.h>
@@ -629,6 +630,59 @@
        }
 }
 
+static const char *
+futex_op_name(u_long op)
+{
+#define        FUTEXCASE(a)    case a: return # a
+       switch (op & FUTEX_CMD_MASK) {
+       FUTEXCASE(FUTEX_WAIT);
+       FUTEXCASE(FUTEX_WAKE);
+       FUTEXCASE(FUTEX_FD);
+       FUTEXCASE(FUTEX_REQUEUE);
+       FUTEXCASE(FUTEX_CMP_REQUEUE);
+       FUTEXCASE(FUTEX_WAKE_OP);
+       FUTEXCASE(FUTEX_LOCK_PI);
+       FUTEXCASE(FUTEX_UNLOCK_PI);
+       FUTEXCASE(FUTEX_TRYLOCK_PI);
+       FUTEXCASE(FUTEX_WAIT_BITSET);
+       FUTEXCASE(FUTEX_WAKE_BITSET);
+       FUTEXCASE(FUTEX_WAIT_REQUEUE_PI);
+       FUTEXCASE(FUTEX_CMP_REQUEUE_PI);
+       default:
+               return NULL;
+       }
+#undef FUTEXCASE
+}
+
+static void
+futexput(u_long op)
+{
+       const char *opname = futex_op_name(op);
+       const char *s = "";
+
+       if (opname == NULL) {
+               printf("%#lx", op & FUTEX_CMD_MASK);
+       } else {
+               fputs(opname, stdout);
+       }
+       op &= ~FUTEX_CMD_MASK;
+
+       if (op & FUTEX_PRIVATE_FLAG) {
+               fputs("_PRIVATE", stdout);
+               op &= ~FUTEX_PRIVATE_FLAG;
+       }
+
+       if (op & FUTEX_CLOCK_REALTIME) {
+               printf("%sFUTEX_CLOCK_REALTIME", s);
+               op &= ~FUTEX_CLOCK_REALTIME;
+               s = "|";
+       }
+
+       if (op) {
+               printf("%s%#lx", s, op);
+       }
+}
+
 static void
 ktrsyscall(struct ktr_syscall *ktr)
 {
@@ -699,6 +753,25 @@
                        ap++;
                        argcount--;
                        c = ',';
+
+                       /*
+                        * Linux name is "futex".
+                        * Native name is "__futex".
+                        * Both have the same op argument.
+                        */
+               } else if ((strcmp(sys_name, "futex") == 0 ||
+                           strcmp(sys_name, "__futex") == 0) &&
+                          argcount > 2) {
+                       (void)putchar('(');
+                       output_long((long)*ap, 1);
+                       (void)putchar(',');
+                       ap++;
+                       argcount--;
+                       futexput(*ap);
+                       ap++;
+                       argcount--;
+                       c = ',';
+
                } else if ((strstr(sys_name, "sigaction") != NULL ||
                    strstr(sys_name, "sigvec") != NULL) && argcount >= 1) {
                        (void)printf("(SIG%s", signame(ap[0], 1));



Home | Main Index | Thread Index | Old Index