diff options
Diffstat (limited to 'arch/x86/lib')
| -rw-r--r-- | arch/x86/lib/bootm.c | 6 | ||||
| -rw-r--r-- | arch/x86/lib/zimage.c | 1 | 
2 files changed, 6 insertions, 1 deletions
| diff --git a/arch/x86/lib/bootm.c b/arch/x86/lib/bootm.c index 0f79a5d5495..0cf3824d203 100644 --- a/arch/x86/lib/bootm.c +++ b/arch/x86/lib/bootm.c @@ -189,6 +189,12 @@ int boot_linux_kernel(ulong setup_base, ulong entry, bool image_64bit)  		if (CONFIG_IS_ENABLED(X86_64)) {  			typedef void (*h_func)(ulong zero, ulong setup);  			h_func func; +			struct setup_header *hdr = &(((struct boot_params *)(setup_base))->hdr); + +			/* Handle kernel with legacy 64-bit entry point at 0x200 */ +			if (hdr->xloadflags & XLF_KERNEL_64) { +				entry += 0x200; +			}  			/* jump to Linux with rdi=0, rsi=setup_base */  			func = (h_func)entry; diff --git a/arch/x86/lib/zimage.c b/arch/x86/lib/zimage.c index 73a21bc8f03..2eece34a073 100644 --- a/arch/x86/lib/zimage.c +++ b/arch/x86/lib/zimage.c @@ -426,7 +426,6 @@ int zboot_go(void)  	image_64bit = false;  	if (IS_ENABLED(CONFIG_X86_RUN_64BIT) &&  	    (hdr->xloadflags & XLF_KERNEL_64)) { -		entry += 0x200;  		image_64bit = true;  	} | 
