panic truss'ing linux ls
Kip Macy
kmacy at fsmware.com
Sun Nov 9 21:09:29 PST 2003
Linux has added, among other things, a new exit system call,
"group_exit". It tells an entire thread group to exit. I don't
believe we really support Linux's thread semantics correctly,
so I've mapped it, for the moment, to sys_exit. This allows
ls and everything else to work without dumping core. I don't know
what the ramifications of NPTL will be on Linux compatibility.
truss will still dump core when run against a linux binary, I haven't
I haven't waited for build world to complete to see if it will fix
itself. Compiling truss in its own directory fails painfully.
Linux seems to be using PAM pretty heavily these days to work around
the cripple root/everyone else security model. Is this something worth
importing for compatibility purposes?
-Kip
On Sat, 1 Nov 2003 qhwt at xxxxxxxxxxxxx wrote:
> Hello.
>
> How to reproduce:
>
> - install linux_base-8-8.0_1 from ports
> - mount /proc, because truss needs it
> - truss /compat/linux/bin/ls -l
>
> `/compat/linux/bin/ls -l' without truss dies with signal 12, not a panic. Maybe
> truss'ing on a linux process is not a good thing?
>
> Traceback:
>
> Script started on Sat Nov 1 01:48:09 2003
> GNU gdb 4.18 (FreeBSD)
> Copyright 1998 Free Software Foundation, Inc.
> GDB is free software, covered by the GNU General Public License, and you are
> welcome to change it and/or distribute copies of it under certain conditions.
> Type "show copying" to see the conditions.
> There is absolutely no warranty for GDB. Type "show warranty" for details.
> This GDB was configured as "i386-unknown-freebsd"...Deprecated bfd_read called at /home/source/dragonfly/src/gnu/usr.bin/binutils/gdb/../../../../contrib/gdb/gdb/dbxread.c line 2627 in elfstab_build_psymtabs
> Deprecated bfd_read called at /home/source/dragonfly/src/gnu/usr.bin/binutils/gdb/../../../../contrib/gdb/gdb/dbxread.c line 933 in fill_symbuf
>
> 1 cpu [ff800000,32768]
> IdlePTD at phsyical address 0x00452000
> PCB EIP=c018a3fe ESP=ce601864 EBP=ce601870
> initial pcb at physical address 0x002b8f00
> panicstr: page fault
> panic messages:
> ---
> dmesg: kvm_read:
> ---
>
> cannot read proc pointer at c0ed51f0
>
> (kgdb) bt
> #0 dumpsys () at /home/source/dragonfly/src/sys/kern/kern_shutdown.c:499
> #1 0xc018a1ec in boot (howto=256) at /home/source/dragonfly/src/sys/kern/kern_shutdown.c:332
> #2 0xc018a630 in poweroff_wait (junk=0xc02892aa, howto=-1071084402)
> at /home/source/dragonfly/src/sys/kern/kern_shutdown.c:611
> #3 0xc0237603 in trap_fatal (frame=0xce601938, eva=120)
> at /home/source/dragonfly/src/sys/i386/i386/trap.c:1116
> #4 0xc0237209 in trap_pfault (frame=0xce601938, usermode=0, eva=120)
> at /home/source/dragonfly/src/sys/i386/i386/trap.c:1005
> #5 0xc0236ea0 in trap (frame={tf_fs = -841744360, tf_es = -832569328, tf_ds = -841678832,
> tf_edi = -832562668, tf_esi = 3, tf_ebp = -832562808, tf_isp = -832562844,
> tf_ebx = -836177984, tf_edx = 0, tf_ecx = -837513336, tf_eax = 0, tf_trapno = 12,
> tf_err = 0, tf_eip = -1072214485, tf_cs = 8, tf_eflags = 66182, tf_esp = 0,
> tf_ss = -837517312}) at /home/source/dragonfly/src/sys/i386/i386/trap.c:594
> #6 0xc0174e2b in elf_putfiles (p=0xcdd5fc40, dst=0xce148000, off=0xce601a14)
> at /home/source/dragonfly/src/sys/kern/imgact_elf.c:1256
> #7 0xc0174bb3 in elf_puthdr (p=0xcdd5fc40, dst=0xce148000, off=0xce601a14, status=0xc7c91d10,
> fpregset=0xc7c91d78, psinfo=0xc7c91e28, numsegs=10)
> at /home/source/dragonfly/src/sys/kern/imgact_elf.c:1124
> #8 0xc0174aef in elf_corehdr (p=0xcdd5fc40, fp=0xc0ee5910, cred=0xc1087f20, numsegs=10,
> hdr=0xce148000, hdrsize=8192) at /home/source/dragonfly/src/sys/kern/imgact_elf.c:1084
> #9 0xc01747b5 in generic_elf_coredump (p=0xcdd5fc40, fp=0xc0ee5910, limit=9223372036854775807)
> at /home/source/dragonfly/src/sys/kern/imgact_elf.c:866
> #10 0xc01746a1 in elf_coredump (p=0xcdd5fc40, vp=0xce440e40, limit=9223372036854775807)
> at /home/source/dragonfly/src/sys/kern/imgact_elf.c:817
> #11 0xc018c4e7 in coredump (p=0xcdd5fc40) at /home/source/dragonfly/src/sys/kern/kern_sig.c:1475
> #12 0xc018bf22 in sigexit (p=0xcdd5fc40, sig=12)
> at /home/source/dragonfly/src/sys/kern/kern_sig.c:1306
> #13 0xc018bcc0 in postsig (sig=12) at /home/source/dragonfly/src/sys/kern/kern_sig.c:1222
> #14 0xc0236a0b in userret (p=0xcdd5fc40, frame=0xce601d48, oticks=0)
> at /home/source/dragonfly/src/sys/i386/i386/trap.c:278
> #15 0xc0237a1a in syscall2 (frame={tf_fs = 47, tf_es = 47, tf_ds = 47, tf_edi = 0, tf_esi = 0,
> tf_ebp = -1077937008, tf_isp = -832561804, tf_ebx = 134567056, tf_edx = 1143, tf_ecx = 11,
> tf_eax = 0, tf_trapno = 7, tf_err = 2, tf_eip = 671798508, tf_cs = 31, tf_eflags = 658,
> tf_esp = -1077937100, tf_ss = 47}) at /home/source/dragonfly/src/sys/i386/i386/trap.c:1370
> #16 0xc0229b6a in Xint0x80_syscall ()
> cannot read proc at 0
> (kgdb) fram 6
> #6 0xc0174e2b in elf_putfiles (p=0xcdd5fc40, dst=0xce148000, off=0xce601a14)
> at /home/source/dragonfly/src/sys/kern/imgact_elf.c:1256
> 1256 cfi->cfi_fh.fh_fsid = vp->v_mount->mnt_stat.f_fsid;
> (kgdb) list
> 1251 cfi = (struct ckpt_fileinfo *)((char *)dst + *off);
> 1252 cfi->cfi_index = i;
> 1253 cfi->cfi_flags = fp->f_flag;
> 1254 cfi->cfi_offset = fp->f_offset;
> 1255 vp = (struct vnode *)fp->f_data;
> 1256 cfi->cfi_fh.fh_fsid = vp->v_mount->mnt_stat.f_fsid;
> 1257 error = VFS_VPTOFH(vp, &cfi->cfi_fh.fh_fid);
> 1258 }
> 1259 *off += sizeof(struct ckpt_fileinfo);
> 1260 }
>
> (kgdb) info locals
> off = (int *) 0xce601a14
> i = 3
> cfh = (struct ckpt_filehdr *) 0xce148f60
> cfi = (struct ckpt_fileinfo *) 0x0
> fp = (struct file *) 0x0
> vp = (struct vnode *) 0x0
> (kgdb) up
> #7 0xc0174bb3 in elf_puthdr (p=0xcdd5fc40, dst=0xce148000, off=0xce601a14, status=0xc7c91d10,
> fpregset=0xc7c91d78, psinfo=0xc7c91e28, numsegs=10)
> at /home/source/dragonfly/src/sys/kern/imgact_elf.c:1124
> 1124 elf_putfiles(p, dst, off);
> (kgdb) fram 5
> #5 0xc0236ea0 in trap (frame={tf_fs = -841744360, tf_es = -832569328, tf_ds = -841678832,
> tf_edi = -832562668, tf_esi = 3, tf_ebp = -832562808, tf_isp = -832562844,
> tf_ebx = -836177984, tf_edx = 0, tf_ecx = -837513336, tf_eax = 0, tf_trapno = 12,
> tf_err = 0, tf_eip = -1072214485, tf_cs = 8, tf_eflags = 66182, tf_esp = 0,
> tf_ss = -837517312}) at /home/source/dragonfly/src/sys/i386/i386/trap.c:594
> 594 (void) trap_pfault(&frame, FALSE, eva);
> (kgdb)
> Script done on Sat Nov 1 01:49:10 2003
>
> $ uname -a
> FreeBSD gzl.local 4.8-STABLE FreeBSD 4.8-STABLE #0: Tue Oct 28 11:11:25 JST 2003 dragonfly at xxxxxxxxx:/usr/obj/home/source/dragonfly/src/sys/GZL i386
>
> Regards.
>Index: sys/emulation/linux/i386/linux_proto.h
===================================================================
RCS file: /home/dcvs/src/sys/emulation/linux/i386/linux_proto.h,v
retrieving revision 1.10
diff -a -u -B -b -r1.10 linux_proto.h
--- sys/emulation/linux/i386/linux_proto.h 21 Oct 2003 01:05:09 -0000 1.10
+++ sys/emulation/linux/i386/linux_proto.h 9 Nov 2003 20:41:42 -0000
@@ -2,8 +2,8 @@
* System call prototypes.
*
* DO NOT EDIT-- this file is automatically generated.
- * $DragonFly: src/sys/emulation/linux/i386/linux_proto.h,v 1.10 2003/10/21 01:05:09 daver Exp $
- * created from DragonFly: src/sys/emulation/linux/i386/syscalls.master,v 1.3 2003/08/07 21:17:18 dillon Exp
+ * $DragonFly$
+ * created from DragonFly: src/sys/emulation/linux/i386/syscalls.master,v 1.4 2003/10/21 01:05:09 daver Exp
*/
#ifndef _LINUX_SYSPROTO_H_
Index: sys/emulation/linux/i386/linux_syscall.h
===================================================================
RCS file: /home/dcvs/src/sys/emulation/linux/i386/linux_syscall.h,v
retrieving revision 1.10
diff -a -u -B -b -r1.10 linux_syscall.h
--- sys/emulation/linux/i386/linux_syscall.h 21 Oct 2003 01:05:09 -0000 1.10
+++ sys/emulation/linux/i386/linux_syscall.h 9 Nov 2003 20:41:42 -0000
@@ -2,8 +2,8 @@
* System call numbers.
*
* DO NOT EDIT-- this file is automatically generated.
- * $DragonFly: src/sys/emulation/linux/i386/linux_syscall.h,v 1.10 2003/10/21 01:05:09 daver Exp $
- * created from DragonFly: src/sys/emulation/linux/i386/syscalls.master,v 1.3 2003/08/07 21:17:18 dillon Exp
+ * $DragonFly$
+ * created from DragonFly: src/sys/emulation/linux/i386/syscalls.master,v 1.4 2003/10/21 01:05:09 daver Exp
*/
#define LINUX_SYS_exit 1
@@ -213,4 +213,5 @@
#define LINUX_SYS_linux_madvise 219
#define LINUX_SYS_linux_getdents64 220
#define LINUX_SYS_linux_fcntl64 221
-#define LINUX_SYS_MAXSYSCALL 222
+#define LINUX_SYS_sys_exit 252
+#define LINUX_SYS_MAXSYSCALL 253
Index: sys/emulation/linux/i386/linux_sysent.c
===================================================================
RCS file: /home/dcvs/src/sys/emulation/linux/i386/linux_sysent.c,v
retrieving revision 1.10
diff -a -u -B -b -r1.10 linux_sysent.c
--- sys/emulation/linux/i386/linux_sysent.c 21 Oct 2003 01:05:09 -0000 1.10
+++ sys/emulation/linux/i386/linux_sysent.c 9 Nov 2003 20:41:42 -0000
@@ -2,8 +2,8 @@
* System call switch table.
*
* DO NOT EDIT-- this file is automatically generated.
- * $DragonFly: src/sys/emulation/linux/i386/linux_sysent.c,v 1.10 2003/10/21 01:05:09 daver Exp $
- * created from DragonFly: src/sys/emulation/linux/i386/syscalls.master,v 1.3 2003/08/07 21:17:18 dillon Exp
+ * $DragonFly$
+ * created from DragonFly: src/sys/emulation/linux/i386/syscalls.master,v 1.4 2003/10/21 01:05:09 daver Exp
*/
#include "opt_compat.h"
@@ -239,4 +239,35 @@
{ 0, (sy_call_t *)linux_madvise }, /* 219 = linux_madvise */
{ AS(linux_getdents64_args), (sy_call_t *)linux_getdents64 }, /* 220 = linux_getdents64 */
{ AS(linux_fcntl64_args), (sy_call_t *)linux_fcntl64 }, /* 221 = linux_fcntl64 */
+ { 0, (sy_call_t *)nosys }, /* 222 = none */
+ { 0, (sy_call_t *)nosys }, /* 223 = security */
+ { 0, (sy_call_t *)nosys }, /* 224 = gettid */
+ { 0, (sy_call_t *)nosys }, /* 225 = readahead */
+ { 0, (sy_call_t *)nosys }, /* 226 = setxattr */
+ { 0, (sy_call_t *)nosys }, /* 227 = lsetxattr */
+ { 0, (sy_call_t *)nosys }, /* 228 = fsetxattr */
+ { 0, (sy_call_t *)nosys }, /* 229 = getxattr */
+ { 0, (sy_call_t *)nosys }, /* 230 = lgetxattr */
+ { 0, (sy_call_t *)nosys }, /* 231 = fgetxattr */
+ { 0, (sy_call_t *)nosys }, /* 232 = listxattr */
+ { 0, (sy_call_t *)nosys }, /* 233 = llistxattr */
+ { 0, (sy_call_t *)nosys }, /* 234 = flistxattr */
+ { 0, (sy_call_t *)nosys }, /* 235 = removexattr */
+ { 0, (sy_call_t *)nosys }, /* 236 = lremovexattr */
+ { 0, (sy_call_t *)nosys }, /* 237 = fremovexattr */
+ { 0, (sy_call_t *)nosys }, /* 238 = tkill */
+ { 0, (sy_call_t *)nosys }, /* 239 = sendfile64 */
+ { 0, (sy_call_t *)nosys }, /* 240 = futex */
+ { 0, (sy_call_t *)nosys }, /* 241 = sched_setaffinity */
+ { 0, (sy_call_t *)nosys }, /* 242 = sched_getaffinity */
+ { 0, (sy_call_t *)nosys }, /* 243 = set_thread_area */
+ { 0, (sy_call_t *)nosys }, /* 244 = get_thread_area */
+ { 0, (sy_call_t *)nosys }, /* 245 = io_setup */
+ { 0, (sy_call_t *)nosys }, /* 246 = io_destroy */
+ { 0, (sy_call_t *)nosys }, /* 247 = io_getevents */
+ { 0, (sy_call_t *)nosys }, /* 248 = io_submit */
+ { 0, (sy_call_t *)nosys }, /* 249 = io_cancel */
+ { 0, (sy_call_t *)nosys }, /* 250 = alloc_hugepages */
+ { 0, (sy_call_t *)nosys }, /* 251 = free_hugepages */
+ { AS(sys_exit_args), (sy_call_t *)sys_exit }, /* 252 = sys_exit */
};
Index: sys/emulation/linux/i386/linux_union.h
===================================================================
RCS file: /home/dcvs/src/sys/emulation/linux/i386/linux_union.h,v
retrieving revision 1.6
diff -a -u -B -b -r1.6 linux_union.h
--- sys/emulation/linux/i386/linux_union.h 21 Oct 2003 01:05:09 -0000 1.6
+++ sys/emulation/linux/i386/linux_union.h 9 Nov 2003 20:41:42 -0000
@@ -2,8 +2,8 @@
* Union of syscall args for messaging.
*
* DO NOT EDIT-- this file is automatically generated.
- * $DragonFly: src/sys/emulation/linux/i386/linux_union.h,v 1.6 2003/10/21 01:05:09 daver Exp $
- * created from DragonFly: src/sys/emulation/linux/i386/syscalls.master,v 1.3 2003/08/07 21:17:18 dillon Exp
+ * $DragonFly$
+ * created from DragonFly: src/sys/emulation/linux/i386/syscalls.master,v 1.4 2003/10/21 01:05:09 daver Exp
*/
union sysunion {
Index: sys/emulation/linux/i386/syscalls.master
===================================================================
RCS file: /home/dcvs/src/sys/emulation/linux/i386/syscalls.master,v
retrieving revision 1.4
diff -a -u -B -b -r1.4 syscalls.master
--- sys/emulation/linux/i386/syscalls.master 21 Oct 2003 01:05:09 -0000 1.4
+++ sys/emulation/linux/i386/syscalls.master 9 Nov 2003 20:55:50 -0000
@@ -339,3 +339,34 @@
l_uint count); }
221 STD LINUX { int linux_fcntl64(l_uint fd, l_uint cmd, \
l_ulong arg); }
+222 UNIMPL LINUX none
+223 UNIMPL LINUX security
+224 UNIMPL LINUX gettid
+225 UNIMPL LINUX readahead
+226 UNIMPL LINUX setxattr
+227 UNIMPL LINUX lsetxattr
+228 UNIMPL LINUX fsetxattr
+229 UNIMPL LINUX getxattr
+230 UNIMPL LINUX lgetxattr
+231 UNIMPL LINUX fgetxattr
+232 UNIMPL LINUX listxattr
+233 UNIMPL LINUX llistxattr
+234 UNIMPL LINUX flistxattr
+235 UNIMPL LINUX removexattr
+236 UNIMPL LINUX lremovexattr
+237 UNIMPL LINUX fremovexattr
+238 UNIMPL LINUX tkill
+239 UNIMPL LINUX sendfile64
+240 UNIMPL LINUX futex
+241 UNIMPL LINUX sched_setaffinity
+242 UNIMPL LINUX sched_getaffinity
+243 UNIMPL LINUX set_thread_area
+244 UNIMPL LINUX get_thread_area
+245 UNIMPL LINUX io_setup
+246 UNIMPL LINUX io_destroy
+247 UNIMPL LINUX io_getevents
+248 UNIMPL LINUX io_submit
+249 UNIMPL LINUX io_cancel
+250 UNIMPL LINUX alloc_hugepages
+251 UNIMPL LINUX free_hugepages
+252 NOPROTO LINUX { void sys_exit(struct sys_exit_args *uap); }
More information about the Bugs
mailing list