summaryrefslogtreecommitdiffstats
path: root/usr
diff options
context:
space:
mode:
authorGeert Uytterhoeven <geert@linux-m68k.org>2010-10-31 05:56:23 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2010-10-31 09:35:14 -0400
commit96f935934591b72f5b05fd6923bc8cdcae92f2e5 (patch)
tree6fe1bcdc31cec5691e0b924d5349bdcb3b7c6a97 /usr
parent3985c7ce85039adacdf882904ca096f091d39346 (diff)
initramfs: Fix initramfs size for 32-bit arches
Commit ffe8018c3424 ("initramfs: fix initramfs size calculation") broke 32-bit big-endian arches like (on ARAnyM): VFS: Cannot open root device "hda1" or unknown-block(3,1) Please append a correct "root=" boot option; here are the available partitions: fe80 1059408 nfhd8 (driver?) fe81 921600 nfhd8p1 00000000-0000-0000-0000-000000000nfhd8p1 fe82 137807 nfhd8p2 00000000-0000-0000-0000-000000000nfhd8p2 0200 3280 fd0 (driver?) 0201 3280 fd1 (driver?) 0300 1059408 hda driver: ide-gd 0301 921600 hda1 00000000-0000-0000-0000-000000000hda1 0302 137807 hda2 00000000-0000-0000-0000-000000000hda2 Kernel panic - not syncing: VFS: Unable to mount root fs on unknown-block(3,1) As pointed out by Kerstin Jonsson <kerstin.jonsson@ericsson.com>, this is due to CONFIG_32BIT not being defined, so the initramfs size field is done as a 64-bit quad. On little-endian (like x86) this doesn matter, but on a big-endian machine the 32-bit reads will see the (zero) high bits. Only mips, s390, and score set CONFIG_32BIT for 32-bit builds, so fix it for all other 32-bit arches by inverting the logic and testing for CONFIG_64BIT, which should be defined on all 64-bit arches. Signed-off-by: Geert Uytterhoeven <geert@linux-m68k.org> [ I think we should just make it "u64" on all architectures and get rid of the whole #ifdef CONFIG_xxBIT - Linus ] Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'usr')
-rw-r--r--usr/initramfs_data.S6
1 files changed, 3 insertions, 3 deletions
diff --git a/usr/initramfs_data.S b/usr/initramfs_data.S
index b9efed5e35cc..792a750d9441 100644
--- a/usr/initramfs_data.S
+++ b/usr/initramfs_data.S
@@ -30,8 +30,8 @@ __irf_end:
30.section .init.ramfs.info,"a" 30.section .init.ramfs.info,"a"
31.globl __initramfs_size 31.globl __initramfs_size
32__initramfs_size: 32__initramfs_size:
33#ifdef CONFIG_32BIT 33#ifdef CONFIG_64BIT
34 .long __irf_end - __irf_start
35#else
36 .quad __irf_end - __irf_start 34 .quad __irf_end - __irf_start
35#else
36 .long __irf_end - __irf_start
37#endif 37#endif