On Wed, Dec 11, 2013 at 11:34 PM, Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> wrote: > On Wed, 11 Dec 2013 11:43:21 +0100 Geert Uytterhoeven <geert@xxxxxxxxxxxxxx> wrote: > >> Since commit e4f2dfbb5e92be4e46c0625f4f8eb101110f756f ("m68k: implement >> futex.h to support userspace robust futexes and PI mutexes"), the kernel >> crashes during boot up on MC68030: >> >> Data read fault at 0x00000000 in Super Data (pc=0x3afec) >> BAD KERNEL BUSERR >> Oops: 00000000 >> Modules linked in: >> PC: [<0003afec>] cmpxchg_futex_value_locked+0x14/0x4a >> SR: 2004 SP: 0082fed4 a2: 0082c000 >> d0: 00000000 d1: 00000001 d2: 00000018 d3: 00000000 >> d4: 00000061 d5: 00001000 a0: 00000000 a1: 0082e000 >> Process swapper (pid: 1, task=0082c000) >> Frame format=B ssw=074d isc=4a80 isb=661c daddr=00000000 dobuf=00000001 >> baddr=0003aff2 dibuf=00000000 ver=f >> Stack from 0082ff5c: >> 002b8cb8 0082ff70 00000000 00000000 00000000 00000000 00000000 000020ac >> 00000018 00000007 00000061 00001000 00000000 00000000 002cab50 00002008 >> 002b3a56 002b8ca4 0082c3f0 00000000 0082c53c 001e316a 00000000 00000000 >> 001e3172 001e316a 000025d4 00000000 00000000 00000000 00000000 00000000 >> 00000000 00000000 00000000 00000000 00000000 00000000 00000000 20000000 >> 00000000 >> Call Trace: [<002b8cb8>] futex_init+0x14/0x54 >> [<000020ac>] do_one_initcall+0xa4/0x144 >> [<00001000>] kernel_pg_dir+0x0/0x1000 >> [<00002008>] do_one_initcall+0x0/0x144 >> [<002b3a56>] kernel_init_freeable+0xca/0x152 >> [<002b8ca4>] futex_init+0x0/0x54 >> [<001e316a>] kernel_init+0x0/0xc8 >> [<001e3172>] kernel_init+0x8/0xc8 >> [<001e316a>] kernel_init+0x0/0xc8 >> [<000025d4>] ret_from_kernel_thread+0xc/0x14 >> >> This happens because the futex test in futex_init() lacks a switch to the >> USER_DS address space, while cmpxchg_futex_value_locked() and >> futex_atomic_cmpxchg_inatomic() operate on userspace pointers (albeit NULL >> for this particular test). >> >> Fix this by switching to USER_DS before running the test, and restoring the >> old address space afterwards. >> >> ... >> >> static int __init futex_init(void) >> { >> + mm_segment_t fs; >> u32 curval; >> int i; >> >> @@ -2745,8 +2747,11 @@ static int __init futex_init(void) >> * implementation, the non-functional ones will return >> * -ENOSYS. >> */ >> + fs = get_fs(); >> + set_fs(USER_DS); >> if (cmpxchg_futex_value_locked(&curval, NULL, 0, 0) == -EFAULT) >> futex_cmpxchg_enabled = 1; >> + set_fs(fs); > > hm. Are we sure that a reference to NULL will continue to fault on all > architectures when switched to USER_DS? Good question! As you queued it in -mm, we'll see in -next. FWIW, I've just tested it on: - ARM (ARMv7, cortex-a15): OK - MIPS (TX4927): OK - OpenRISC: -ENOSYS (expected, as asm-generic/futex.h doesn't implement futex_atomic_cmpxchg_inatomic() yet) Speaking about asm-generic: arch/m68k/include/asm/futex.h doesn't contain any m68k-specific code, so it's a candidate to replace include/asm-generic/futex.h. Actually I just tried that, and the above passed for OpenRISC. Unfortunately I don't have networking (yet) on my de0-nano FPGA board, so I'm not in a good position to run a full futex test suite on OpenRISC. 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 stable" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html