[PATCH] mod_devicetable.h fixes
authorAl Viro <viro@parcelfarce.linux.theplanet.co.uk>
Sun, 28 Aug 2005 02:19:14 +0000 (03:19 +0100)
committerLinus Torvalds <torvalds@g5.osdl.org>
Mon, 29 Aug 2005 17:42:39 +0000 (10:42 -0700)
commit9e2d3cd34a159948dc753a14573e16bffc04dba8
tree155627810033ac56d06734360c56b612f08b9134
parent5bbe6ab938208bb3d4e16f7a28b11fcddd4f9ff2
[PATCH] mod_devicetable.h fixes

 * ieee1394_device_id has kernel_ulong_t field after an odd number of
   __u32 ones.  Since mod_devicetable.h is included both from kernel and
   from host build helper, we may be in trouble if we are building on
   32bit host for 64bit target - userland sees unsigned long long,
   kernel sees unsigned long and while their sizes match, alignments
   might not.  Fixed by forcing alignment.  Fortunately, almost nobody
   else needs that - the rest of such fields is naturally aligned as it
   is.

 * of_device_id has void * in it.  Host userland helpers need
   kernel_ulong_t instead, since their void * might have nothing to do
   with the kernel one.  Fixed in the same way it's done for similar
   problems in pcmcia_device_id (ifdef __KERNEL__).

 * pcmcia_device_id has the same problem as ieee1394_device_id.  Fixed
   the same way.

Signed-off-by: Al Viro <viro@parcelfarce.linux.theplanet.co.uk>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
include/linux/mod_devicetable.h