[PATCH] printk: Fix alignment of buf causing crash on ARM EABI

Greg KH gregkh at linuxfoundation.org
Tue Jun 5 02:59:18 EDT 2012


On Tue, Jun 05, 2012 at 08:52:34AM +0200, Andrew Lunn wrote:
> Commit 7ff9554bb578ba02166071d2d487b7fc7d860d62, printk: convert
> byte-buffer to variable-length record buffer, causes systems using
> EABI to crash very early in the boot cycle. The first entry in struct
> log is a u64, which for EABI must be 8 byte aligned.
> 
> Make use of __alignof__() so the compiler to decide the alignment, but
> allow it to be overridden using CONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS,
> for systems which can perform unaligned access and want to save
> a few bytes of space.
> 
> Tested on Orion5x and Kirkwood.
> 
> Signed-off-by: Andrew Lunn <andrew at lunn.ch>
> ---
>  kernel/printk.c |    4 ++--
>  1 file changed, 2 insertions(+), 2 deletions(-)

Thanks, I think I have a patch in my to-apply queue that fixes this in a
bit different way.  I'll dig that up and compare them in the next few
days as I work my way through my pending patch queue.

greg k-h



More information about the linux-arm-kernel mailing list