Early crash (was: Re: module: show version information for built-inmodules in sysfs)

From: Geert Uytterhoeven
Date: Tue Feb 01 2011 - 15:33:38 EST


On Mon, Jan 24, 2011 at 11:59, Linux Kernel Mailing List
<linux-kernel@xxxxxxxxxxxxxxx> wrote:
> Gitweb: Â Â http://git.kernel.org/linus/e94965ed5beb23c6fabf7ed31f625e66d7ff28de

> Â Âmodule: show version information for built-in modules in sysfs
>
> Â ÂCurrently only drivers that are built as modules have their versions
> Â Âshown in /sys/module/<module_name>/version, but this information might
> Â Âalso be useful for built-in drivers as well. This especially important
> Â Âfor drivers that do not define any parameters - such drivers, if
> Â Âbuilt-in, are completely invisible from userspace.
>
> Â ÂThis patch changes MODULE_VERSION() macro so that in case when we are
> Â Âcompiling built-in module, version information is stored in a separate
> Â Âsection. Kernel then uses this data to create 'version' sysfs attribute
> Â Âin the same fashion it creates attributes for module parameters.

This commit causes the crash below on m68k (ARAnyM).
Reverting this commit and its dependency
3b90a5b292321b2acac3921f77046ae195aef53f
("module: fix linker error for MODULE_VERSION when !MODULE and CONFIG_SYSFS=n")
makes it boot again.

NET: Registered protocol family 16
Unable to handle kernel NULL pointer dereference at virtual address 0000002b
Oops: 00000000
Modules linked in:
PC: [<00141164>] kset_find_obj_hinted+0x5a/0xb6
SR: 2300 SP: 00c09ec8 a2: 00c07900
d0: 00000078 d1: 00c2ee90 d2: 00000000 d3: 00000000
d4: 00000000 d5: 00000000 a0: 00c2f700 a1: 00c2f701
Process swapper (pid: 1, task=00c07900)
Frame format=7 eff addr=0000002b ssw=0525 faddr=0000002b
wb 1 stat/addr/data: 0000 00000000 00000000
wb 2 stat/addr/data: 0000 00000000 00000000
wb 3 stat/addr/data: 0000 0000002b 00000000
push data: 00000000 00000000 00000000 00000000
Stack from 00c09f30:
0000002b 002d853a 00310dac 0031214a 002dbff8 001411d0 00c2ee90 0000002b
00000000 00310dc2 00c2ee90 0000002b 00c2ee50 00000000 002d853a 00310eb8
0000002b 00000000 00000000 003291a8 00310e6c 00c1d8b8 002e6872 00170e00
00c1d8b0 002e6872 003031f8 00000000 00000000 00303038 0031bec2 0031214a
0031bf40 00303038 00000000 003291a4 000020f8 00000000 00000000 00000000
00000000 00000000 00000000 003291a8 00002008 0031214a 0030baee 00310e6c
Call Trace: [<00310dac>] locate_module_kobject+0x0/0xc0
[<0031214a>] __alloc_bootmem+0x0/0x1a
[<001411d0>] kset_find_obj+0x10/0x18
[<00310dc2>] locate_module_kobject+0x16/0xc0
[<00310eb8>] param_sysfs_init+0x4c/0x1be
[<00310e6c>] param_sysfs_init+0x0/0x1be
[<00170e00>] vtconsole_init_device+0x3c/0x90
[<0031bec2>] vtconsole_class_init+0x0/0xda
[<0031214a>] __alloc_bootmem+0x0/0x1a
[<0031bf40>] vtconsole_class_init+0x7e/0xda
[<000020f8>] do_one_initcall+0xf0/0x186
[<00002008>] do_one_initcall+0x0/0x186
[<0031214a>] __alloc_bootmem+0x0/0x1a
[<0030baee>] kernel_init+0x96/0x136
[<00310e6c>] param_sysfs_init+0x0/0x1be
[<0030ba58>] kernel_init+0x0/0x136
[<0002794e>] printk+0x0/0x1a
[<00002b52>] kernel_thread+0x3a/0x4e

Code: b288 672c 2053 4a88 6716 2248 2c4c 1019 <b01e> 6606 4a00 66f6
6002 9026 4a00 6722 47ed fffc 2a6b 0004 41eb 0004 b288 66d4
Disabling lock debugging due to kernel taint
Kernel panic - not syncing: Attempted to kill init!
Call Trace: [<0002745c>] panic+0x5a/0x1ba
[<00028bd4>] exit_mm+0x0/0x102
[<0011dfd6>] exit_sem+0x0/0x162
[<0002f5f2>] exit_ptrace+0x0/0x106
[<0002a274>] do_exit+0x6cc/0x6ce
[<0002794e>] printk+0x0/0x1a
[<000031de>] die_if_kernel+0x4e/0x52
[<00006e8c>] send_fault_sig+0xd4/0x11e
[<00006f80>] do_page_fault+0xaa/0x1c2
[<000038b6>] buserr_c+0x192/0x6d8
[<00100100>] mnt_xdr_dec_mountres+0xa2/0xb4
[<00002542>] buserr+0x1e/0x24
[<00310dac>] locate_module_kobject+0x0/0xc0
[<0031214a>] __alloc_bootmem+0x0/0x1a
[<001411d0>] kset_find_obj+0x10/0x18
[<00310dc2>] locate_module_kobject+0x16/0xc0
[<00310eb8>] param_sysfs_init+0x4c/0x1be
[<00310e6c>] param_sysfs_init+0x0/0x1be
[<00170e00>] vtconsole_init_device+0x3c/0x90
[<0031bec2>] vtconsole_class_init+0x0/0xda
[<0031214a>] __alloc_bootmem+0x0/0x1a
[<0031bf40>] vtconsole_class_init+0x7e/0xda
[<000020f8>] do_one_initcall+0xf0/0x186
[<00002008>] do_one_initcall+0x0/0x186
[<0031214a>] __alloc_bootmem+0x0/0x1a
[<0030baee>] kernel_init+0x96/0x136
[<00310e6c>] param_sysfs_init+0x0/0x1be
[<0030ba58>] kernel_init+0x0/0x136
[<0002794e>] printk+0x0/0x1a
[<00002b52>] kernel_thread+0x3a/0x4e

Gr{oetje,eeting}s,

            Geert

--
Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@xxxxxxxxxxxxxx

In personal conversations with technical people, I call myself a hacker. But
when I'm talking to journalists I just say "programmer" or something like that.
             Â Â -- Linus Torvalds
--
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/