diff options
author | Dmitry Torokhov <dtor@vmware.com> | 2011-02-08 00:02:25 (GMT) |
---|---|---|
committer | Rusty Russell <rusty@rustcorp.com.au> | 2011-05-19 07:25:24 (GMT) |
commit | b4bc842802db3314f9a657094da0450a903ea619 (patch) | |
tree | db9cadf46624dcd7e780850e8bda34b569a229b0 /include/drm/drm_sysfs.h | |
parent | 61c4f2c81c61f73549928dfd9f3e8f26aa36a8cf (diff) | |
download | linux-b4bc842802db3314f9a657094da0450a903ea619.tar.xz |
module: deal with alignment issues in built-in module versions
On m68k natural alignment is 2-byte boundary but we are trying to
align structures in __modver section on sizeof(void *) boundary.
This causes trouble when we try to access elements in this section
in array-like fashion when create "version" attributes for built-in
modules.
Moreover, as DaveM said, we can't reliably put structures into
independent objects, put them into a special section, and then expect
array access over them (via the section boundaries) after linking the
objects together to just "work" due to variable alignment choices in
different situations. The only solution that seems to work reliably
is to make an array of plain pointers to the objects in question and
put those pointers in the special section.
Reported-by: Geert Uytterhoeven <geert@linux-m68k.org>
Signed-off-by: Dmitry Torokhov <dtor@vmware.com>
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
Diffstat (limited to 'include/drm/drm_sysfs.h')
0 files changed, 0 insertions, 0 deletions