patches/strace/4.5.19/150-undef-syscall.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Tue Dec 13 23:32:39 2011 +0100 (2011-12-13)
branch1.13
changeset 2847 c0bf2319af08
permissions -rw-r--r--
scripts: fix dumping execution backtrace

Dumping the backtrace has been broken since changeset #652e56d6d35a:
scripts: execute each steps in a subshell

We can spawn sub-sub-shells in some cases.

The way the fault handler works is to dump the backtrace, but to avoid
printing it once for every sub-shell (which could get quite confusing),
it simply exits when it detects that it is being run in a sub-shell,
leaving to the top-level shell the work to dump the backtrace.

Because each step is executed in its own sub-shell, the variable arrays
that contain the step name, the source file and line number, are lost
when exiting the per-step sub-shell.

Hence, the backtrace is currently limited to printing only the top-level
main procedure of the shell.

Fix this thus:
- when dumping the bckatraces for the steps & the functions, remember
it was dumped, and only dump it if it was not already dumped
- at the top-level shell, print the hints

Also, rename the top-level step label.

Reported-by: Benoît Thébaudeau <benoit.thebaudeau@advansee.com>
Signed-off-by: "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
(transplanted from 4193d6e6a17430a177fa88c287879c2c35e319f3)
yann@1613
     1
diff -durN strace-4.5.19.orig/linux/syscallent.h strace-4.5.19/linux/syscallent.h
yann@1613
     2
--- strace-4.5.19.orig/linux/syscallent.h	2009-09-01 21:53:29.000000000 +0200
yann@1613
     3
+++ strace-4.5.19/linux/syscallent.h	2009-10-28 18:47:18.000000000 +0100
yann@1613
     4
@@ -130,7 +130,11 @@
yann@1613
     5
 	{ 2,	TF,	sys_statfs,		"statfs"	}, /* 99 */
yann@1613
     6
 	{ 2,	TD,	sys_fstatfs,		"fstatfs"	}, /* 100 */
yann@1613
     7
 	{ 3,	0,	sys_ioperm,		"ioperm"	}, /* 101 */
yann@1613
     8
-	{ 2,	TD,	sys_socketcall,		"socketcall", SYS_socketcall }, /* 102 */
yann@1613
     9
+	{ 2,	TD,	sys_socketcall,		"socketcall"
yann@1613
    10
+#ifdef __NR_socketcall
yann@1613
    11
+	    , SYS_socketcall
yann@1613
    12
+#endif
yann@1613
    13
+								}, /* 102 */
yann@1613
    14
 	{ 3,	0,	sys_syslog,		"syslog"	}, /* 103 */
yann@1613
    15
 	{ 3,	0,	sys_setitimer,		"setitimer"	}, /* 104 */
yann@1613
    16
 	{ 2,	0,	sys_getitimer,		"getitimer"	}, /* 105 */
yann@1613
    17
@@ -145,7 +149,11 @@
yann@1613
    18
 	{ 4,	TP,	sys_wait4,		"wait4", SYS_wait4 }, /* 114 */
yann@1613
    19
 	{ 1,	0,	sys_swapoff,		"swapoff"	}, /* 115 */
yann@1613
    20
 	{ 1,	0,	sys_sysinfo,		"sysinfo"	}, /* 116 */
yann@1613
    21
-	{ 6,	0,	sys_ipc,		"ipc", SYS_ipc }, /* 117 */
yann@1613
    22
+	{ 6,	0,	sys_ipc,		"ipc"
yann@1613
    23
+#ifdef __NR_ipc
yann@1613
    24
+	    , SYS_ipc
yann@1613
    25
+#endif
yann@1613
    26
+								}, /* 117 */
yann@1613
    27
 	{ 1,	TD,	sys_fsync,		"fsync"		}, /* 118 */
yann@1613
    28
 	{ 1,	TS,	sys_sigreturn,		"sigreturn"	}, /* 119 */
yann@1613
    29
 	{ 5,	TP,	sys_clone,		"clone", SYS_clone }, /* 120 */
yann@1613
    30
@@ -282,7 +290,11 @@
yann@1613
    31
 	{ 3,	0,	sys_io_cancel,		"io_cancel"	}, /* 249 */
yann@1613
    32
 	{ 5,	0,	sys_fadvise64,		"fadvise64"	}, /* 250 */
yann@1613
    33
 	{ 5,	0,	printargs,		"SYS_251"	}, /* 251 */
yann@1613
    34
-	{ 1,	TP,	sys_exit,		"exit_group", __NR_exit_group }, /* 252 */
yann@1613
    35
+	{ 1,	TP,	sys_exit,		"exit_group"
yann@1613
    36
+#ifdef __NR_exit_group
yann@1613
    37
+	    , __NR_exit_group
yann@1613
    38
+#endif
yann@1613
    39
+								}, /* 252 */
yann@1613
    40
 	{ 4,	0,	printargs,		"lookup_dcookie"}, /* 253 */
yann@1613
    41
 	{ 1,	0,	sys_epoll_create,	"epoll_create"	}, /* 254 */
yann@1613
    42
 	{ 4,	TD,	sys_epoll_ctl,		"epoll_ctl"	}, /* 255 */