On Fri, 11 Jul, at 08:40:29AM, Matt Fleming wrote: > > I'm not exactly sure what's wrong with the buffer - whether it's a case > of not being able to access it properly or somehing buggy in the EFI > code for reading files. No fault occurs when reading into it, it just > doesn't contain the correct data. > > Either way, I'm going to leave your patch as-is and just ensure I fix > this before the merge window. I think it's a good idea to have whatever > workaround we come up with documented via an entirely separate patch. I spent some time playing around with this bug and it appears to be triggered by the read-a-chunk-at-a-time logic in handle_cmdline_files(), (which is itself a bug workaround) introduced here, commit 2d2da60fb40a Author: Maarten Lankhorst <m.b.lankhorst@xxxxxxxxx> Date: Fri Dec 16 13:30:58 2011 +0100 x86, efi: Break up large initrd reads The efi boot stub tries to read the entire initrd in 1 go, however some efi implementations hang if too much if asked to read too much data at the same time. After some experimentation I found out that my asrock p67 board will hang if asked to read chunks of 4MiB, so use a safe value. elilo reads in chunks of 16KiB, but since that requires many read calls I use a value of 1 MiB. hpa suggested adding individual blacklists for when systems are found where this value causes a crash. Signed-off-by: Maarten Lankhorst <m.b.lankhorst@xxxxxxxxx> Link: http://lkml.kernel.org/r/4EEB3A02.3090201@xxxxxxxxx Signed-off-by: H. Peter Anvin <hpa@xxxxxxxxxxxxxxx> Setting EFI_READ_CHUNK_SIZE to -1 (disabling the chunk workaround) allows everything to work just fine. Any chunk value smaller than the initrd file size causes the bug to trigger on my machine. Going forward, I suspect any attempts to use the EFI File Protocol are going to result in this kind of breakage, and that the only thing that can be relied upon is the Disk I/O Protocol. But doing Disk I/O would necessitate adding the in-kernel FAT driver to the EFI boot stub, which is a scary idea (though not without merit). On the flip-side, we've no infrastructure in the EFI boot stub for doing blacklisting via DMI, so there's no way currently to automatically disable the chunk-read workaround for known buggy machines. The simplest solution is to require that the user pull some kind of kernel parameter on the command line to explicitly disable the workaround, but that's a pretty lame prospect. -- Matt Fleming, Intel Open Source Technology Center -- To unsubscribe from this list: send the line "unsubscribe linux-efi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html