Re: [BUG] Oops: EIP is at sysfs_release+0x34/0x80

From: Andrew Morton
Date: Fri Jul 08 2005 - 16:59:53 EST


Nathan Boyle <nboyle@xxxxxxxxxxxxxxx> wrote:
>
> EIP is at sysfs_release+0x34/0x80
> eax: 00000001 ebx: dc7c2000 ecx: d1979860 edx: 00000001
> esi: 762f7373 edi: d5ba26a0 ebp: d9368544 esp: dc7c3f80
> ds: 007b es: 007b ss: 0068
> Process udev (pid: 31802, threadinfo=dc7c2000 task=c7c19040)
> Stack: df468c40 df798140 dffe4140 c0153c08 d5a9edbc df468c40 df798140
> 00000000
> dc7c2000 c01523d3 00000000 00000003 080ac568 00000003 c0103101
> 00000003
> 080ac568 00000004 080ac568 00000003 08057198 00000006 0000007b
> 0000007b
> Call Trace:
> [<c0153c08>] __fput+0xf8/0x110
> [<c01523d3>] filp_close+0x43/0x70
> [<c0103101>] syscall_call+0x7/0xb
> Code: 8b 41 0c 8b 40 48 8b 58 14 8b 41 48 8b 40 14 85 db 8b 70 04 74 07
> 89 d8 e8 9a 11 02 00 85 f6 74 1f bb 00 e0 ff ff 21 e3 ff 43 14 <ff> 8e
> 00 01 00 00 83 3e 02 74 32 8b 43 08 ff 4b 14 a8 08 75 21
> <6>note: udev[31802] exited with preempt_count 1

Gee we get a lot of these, and no idea which sysfs file caused it.

How about we record the most-recently-opened sysfs file and display that at
oops time? (-mm only)

--- 25/fs/sysfs/file.c~sysfs-crash-debugging Fri Jul 8 14:33:11 2005
+++ 25-akpm/fs/sysfs/file.c Fri Jul 8 14:47:38 2005
@@ -6,6 +6,8 @@
#include <linux/dnotify.h>
#include <linux/kobject.h>
#include <linux/namei.h>
+#include <linux/limits.h>
+
#include <asm/uaccess.h>
#include <asm/semaphore.h>

@@ -324,8 +326,13 @@ static int check_perm(struct inode * ino
return error;
}

+char last_sysfs_file[PATH_MAX];
+
static int sysfs_open_file(struct inode * inode, struct file * filp)
{
+ d_path(filp->f_dentry, sysfs_mount, last_sysfs_file,
+ sizeof(last_sysfs_file));
+
return check_perm(inode,filp);
}

diff -puN arch/i386/kernel/traps.c~sysfs-crash-debugging arch/i386/kernel/traps.c
--- 25/arch/i386/kernel/traps.c~sysfs-crash-debugging Fri Jul 8 14:36:15 2005
+++ 25-akpm/arch/i386/kernel/traps.c Fri Jul 8 14:37:01 2005
@@ -337,6 +337,12 @@ void die(const char * str, struct pt_reg
#endif
if (nl)
printk("\n");
+ {
+ extern char last_sysfs_name[];
+
+ printk(KERN_ALERT "last sysfs file: %s\n",
+ last_sysfs_name);
+ }
notify_die(DIE_OOPS, (char *)str, regs, err, 255, SIGSEGV);
show_registers(regs);
} else
_

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/