(Cc'ing libc-ports and Arnd Bergmann.) On 5/17/2012 8:37 PM, H. Peter Anvin wrote: > It looks like MIPS has a private definition of struct msqid64_ds, as do > most other architectures; the MIPS one is completely broken for user > space usages as it uses CONFIG_* macros: > > #if defined(CONFIG_32BIT) && !defined(CONFIG_CPU_LITTLE_ENDIAN) > unsigned long __unused2; > #endif > __kernel_time_t msg_rtime; /* last msgrcv time */ > #if defined(CONFIG_32BIT) && defined(CONFIG_CPU_LITTLE_ENDIAN) > unsigned long __unused2; > #endif > > It looks like the only users of asm-generic here are: > > arch/microblaze/include/asm/msgbuf.h:#include <asm-generic/msgbuf.h> > arch/score/include/asm/msgbuf.h:#include <asm-generic/msgbuf.h> > arch/sh/include/asm/msgbuf.h:#include <asm-generic/msgbuf.h> > arch/x86/include/asm/msgbuf.h:#include <asm-generic/msgbuf.h> > > ... and unless I'm mistaken, x86 is the only one of those which isn't 32 > bits only, which explains the reason it "works"... Don't forget the newer architectures that use generic-y: arch/blackfin/include/asm/Kbuild:generic-y += msgbuf.h arch/c6x/include/asm/Kbuild:generic-y += msgbuf.h arch/hexagon/include/asm/Kbuild:generic-y += msgbuf.h arch/openrisc/include/asm/Kbuild:generic-y += msgbuf.h arch/tile/include/asm/Kbuild:generic-y += msgbuf.h arch/unicore32/include/asm/Kbuild:generic-y += msgbuf.h On 5/17/2012 8:22 PM, Linus Torvalds wrote: > That's why I think it's unfixable. It started out broken, and I > presume that 32-bit user land on a 64-bit MIPS/PPC thing either do not > work, or there's some compat crap (like special user-land headers) > fixing things up. Or they just don't use that buggered msqid64_ds > thing at all. Yes, it's compat crap. Each architecture defines its own compat_msqid64_ds that carefully places the padding in the same place as the corresponding native 32-bit kernel puts it, and glibc doesn't use <asm/msgbuf.h> at all, but instead provides a hand-rolled <bits/msq.h>. I added a glibc <bits/msq.h> that targets the asm-generic version of the header, so it puts the padding after the time_t, even on big-endian platforms. This is of course crazy, but it's what you need to do to use the current asm-generic header. However, now is a good time to ask whether this is the right thing to do going forward. The tile architecture is the only one that currently offers a 32-bit big-endian userspace (only in linux-next, queued for 3.5) and also uses <asm-generic> for the SysV stuff, so if someone wants to advocate for changing this, now is definitely a good time for it. We could modify asm-generic so that it puts the padding where it "ought" to go, easily enough. This would then allow three of the four big-endian 32-bit architectures (sparc, parisc, powerpc) to use the generic headers, if they wished. (The fourth one, s390, puts the padding after, like asm-generic currently does.) This might then allow us to consider making "struct compat_msqid64_ds" and friends something that is defined in <linux/compat.h> rather than per-architecture, though we'd need a hook to allow architectures like s390 to override and provide their own definition. As far as x32 goes, this should all be largely irrelevant, since it likely won't use the compat structures anyway, and since we're not proposing breaking the little-endian layout. But future x32-style compat big-endian architectures would benefit from having a msqid64_ds structure that actually lays out the same in 32- or 64-bit mode. -- Chris Metcalf, Tilera Corp. http://www.tilera.com -- To unsubscribe from this list: send the line "unsubscribe linux-arch" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html