On 10/11/13 at 09:41am, Borislav Petkov wrote: > On Fri, Oct 11, 2013 at 02:24:37PM +0800, Dave Young wrote: > > But for current implementation from Boris, getting same mapping > > between diffrent kernel depends on same md order (same start and > > size for each one) How about using this mapping solution but at the > > same time for kexec kernel we also pass the virtual mappings via > > setup_data, only thing diffrent is we only need map the non boot > > region and just use the boot region size to ensure the other regions > > are mapped with same virtual address. > > Actually, as hpa suggested, we will need to be passing the explicit > virtual addresses to the kexec kernel in case we change the mapping > algorithm in the future. So all should go through setup_data. > > > OTOH, if we only passing ioremapped data without Boris's current patch > > the problem I worry about is how can we ensure the addresses are not > > used by other code before we mapping the in 2nd kernel efi_init. > > Right, the old method of mapping EFI runtime regions used ioremap and > was mapping the regions in the same address space. Now we have reserved > a 64G in the VA space ending at -4G (i.e. 0xffff_ffff_0000_0000) which > is reserved only for EFI RT usage.
Boris: For the boot service region overlapping problem I have another idea, how about modify your mapping code to always mapping the RUNTIME region (non boot service region) firstly from the efi_va, then mapping other regions in order, in this way kexec 2nd kernel will be happy because it does not call SetVirtualAddressMap and it does not need the boot service area at all. Thanks Dave -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/