summaryrefslogtreecommitdiff
path: root/mm
diff options
context:
space:
mode:
authorJohn Sperbeck <jsperbeck@google.com>2024-03-23 08:29:34 -0700
committerAndrew Morton <akpm@linux-foundation.org>2024-04-05 11:21:30 -0700
commit8434f9aa6b7e77bc1459d75d1293c3f55bf4687b (patch)
tree10d6b92d4413126e7b6d6292873a8aa7208a7312 /mm
parent65291dcfcf8936e1b23cfd7718fdfde7cfaf7706 (diff)
downloadlwn-8434f9aa6b7e77bc1459d75d1293c3f55bf4687b.tar.gz
lwn-8434f9aa6b7e77bc1459d75d1293c3f55bf4687b.zip
init: open output files from cpio unpacking with O_LARGEFILE
If a member of a cpio archive for an initrd or initrams is larger than 2Gb, we'll eventually fail to write to that file when we get to that limit, unless O_LARGEFILE is set. The problem can be seen with this recipe, assuming that BLK_DEV_RAM is not configured: cd /tmp dd if=/dev/zero of=BIGFILE bs=1048576 count=2200 echo BIGFILE | cpio -o -H newc -R root:root > initrd.img kexec -l /boot/vmlinuz-$(uname -r) --initrd=initrd.img --reuse-cmdline kexec -e The console will show 'Initramfs unpacking failed: write error'. With the patch, the error is gone. Link: https://lkml.kernel.org/r/20240323152934.3307391-1-jsperbeck@google.com Signed-off-by: John Sperbeck <jsperbeck@google.com> Cc: Jens Axboe <axboe@kernel.dk> Cc: Nick Desaulniers <ndesaulniers@google.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Randy Dunlap <rdunlap@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Diffstat (limited to 'mm')
0 files changed, 0 insertions, 0 deletions