[PATCH v5 10/13] x86, boot: add fields to support load bzImage and ramdisk above 4G
ext_ramdisk_image/size will record high 32bits for ramdisk info. xloadflags bit0 will be set if relocatable with 64bit. Let get_ramdisk_image/size to use ext_ramdisk_image/size to get right positon for ramdisk. bootloader will fill value to ext_ramdisk_image/size when it load ramdisk above 4G. Also bootloader will check if xloadflags bit0 is set to decicde if it could load ramdisk high above 4G. xloadflags bit15 is used for bootloader to notify kernel if new added ext_* in boot_params could be used or not. Update header version to 2.12. -v2: add ext_cmd_line_ptr for above 4G support. -v3: update to xloadflags from HPA. -v4: use fields from bootparam instead setup_header accoring to HPA. -v5: add checking for USE_EXT_BOOT_PARAMS Signed-off-by: Yinghai Lu Cc: Rob Landley Cc: Matt Fleming --- Documentation/x86/boot.txt | 19 ++- Documentation/x86/zero-page.txt|3 +++ arch/x86/boot/compressed/cmdline.c |3 +++ arch/x86/boot/header.S | 12 ++-- arch/x86/include/asm/bootparam.h | 10 -- arch/x86/kernel/head64.c |3 +++ arch/x86/kernel/setup.c|6 ++ 7 files changed, 51 insertions(+), 5 deletions(-) diff --git a/Documentation/x86/boot.txt b/Documentation/x86/boot.txt index 9efceff..51954d7 100644 --- a/Documentation/x86/boot.txt +++ b/Documentation/x86/boot.txt @@ -57,6 +57,9 @@ Protocol 2.10:(Kernel 2.6.31) Added a protocol for relaxed alignment Protocol 2.11: (Kernel 3.6) Added a field for offset of EFI handover protocol entry point. +Protocol 2.12: (Kernel 3.9) Added three fields for loading bzImage and +ramdisk above 4G with 64bit in bootparam. + MEMORY LAYOUT The traditional memory map for the kernel loader, used for Image or @@ -182,7 +185,7 @@ Offset Proto NameMeaning 0230/4 2.05+ kernel_alignment Physical addr alignment required for kernel 0234/1 2.05+ relocatable_kernel Whether kernel is relocatable or not 0235/1 2.10+ min_alignment Minimum alignment, as a power of two -0236/2 N/A pad3Unused +0236/2 2.12+ xloadflags Boot protocol option flags 0238/4 2.06+ cmdline_sizeMaximum size of the kernel command line 023C/4 2.07+ hardware_subarch Hardware subarchitecture 0240/8 2.07+ hardware_subarch_data Subarchitecture-specific data @@ -581,6 +584,20 @@ Protocol: 2.10+ misaligned kernel. Therefore, a loader should typically try each power-of-two alignment from kernel_alignment down to this alignment. +Field name: xloadflags +Type: modify (obligatory) +Offset/size:0x236/2 +Protocol: 2.12+ + + This field is a bitmask. + + Bit 0 (read): CAN_BE_LOADED_ABOVE_4G +- If 1, kernel/boot_params/cmdline/ramdisk can be above 4g, + + Bit 15 (write): USE_EXT_BOOT_PARAMS + - If 1, set by bootloader, and kernel could check new fields + in boot_params that are added from 2.12 safely. + Field name:cmdline_size Type: read Offset/size: 0x238/4 diff --git a/Documentation/x86/zero-page.txt b/Documentation/x86/zero-page.txt index cf5437d..0e19657 100644 --- a/Documentation/x86/zero-page.txt +++ b/Documentation/x86/zero-page.txt @@ -19,6 +19,9 @@ OffsetProto NameMeaning 090/010ALL hd1_infohd1 disk parameter, OBSOLETE!! 0A0/010ALL sys_desc_table System description table (struct sys_desc_table) 0B0/010ALL olpc_ofw_header OLPC's OpenFirmware CIF and friends +0C0/004 ALLext_ramdisk_image ramdisk_image high 32bits +0C4/004 ALLext_ramdisk_size ramdisk_size high 32bits +0C8/004 ALLext_cmd_line_ptr cmd_line_ptr high 32bits 140/080ALL edid_info Video mode setup (struct edid_info) 1C0/020ALL efi_infoEFI 32 information (struct efi_info) 1E0/004ALL alk_mem_k Alternative mem check, in KB diff --git a/arch/x86/boot/compressed/cmdline.c b/arch/x86/boot/compressed/cmdline.c index b4c913c..43e4ec7 100644 --- a/arch/x86/boot/compressed/cmdline.c +++ b/arch/x86/boot/compressed/cmdline.c @@ -17,6 +17,9 @@ static unsigned long get_cmd_line_ptr(void) { unsigned long cmd_line_ptr = real_mode->hdr.cmd_line_ptr; + if (real_mode->hdr.xloadflags & USE_EXT_BOOT_PARAMS) + cmd_line_ptr |= (u64)real_mode->ext_cmd_line_ptr << 32; + return cmd_line_ptr; } int cmdline_find_option(const char *option, char *buffer, int bufsize) diff --git a/arch/x86/boot/header.S b/arch/x86/boot/header.S index 2a01744..156f664 100644 --- a/arch/x86/boot/header.S +++ b/arch/x86/boot/header.S @@ -279,7 +279,7 @@ _start: # Part 2 of the header, from the old setup.S .ascii "HdrS" # header signature - .word 0x020b # header version number (>= 0x0105) + .word 0x020c # header version number (>= 0x0105)
[PATCH v5 10/13] x86, boot: add fields to support load bzImage and ramdisk above 4G
ext_ramdisk_image/size will record high 32bits for ramdisk info. xloadflags bit0 will be set if relocatable with 64bit. Let get_ramdisk_image/size to use ext_ramdisk_image/size to get right positon for ramdisk. bootloader will fill value to ext_ramdisk_image/size when it load ramdisk above 4G. Also bootloader will check if xloadflags bit0 is set to decicde if it could load ramdisk high above 4G. xloadflags bit15 is used for bootloader to notify kernel if new added ext_* in boot_params could be used or not. Update header version to 2.12. -v2: add ext_cmd_line_ptr for above 4G support. -v3: update to xloadflags from HPA. -v4: use fields from bootparam instead setup_header accoring to HPA. -v5: add checking for USE_EXT_BOOT_PARAMS Signed-off-by: Yinghai Lu ying...@kernel.org Cc: Rob Landley r...@landley.net Cc: Matt Fleming matt.flem...@intel.com --- Documentation/x86/boot.txt | 19 ++- Documentation/x86/zero-page.txt|3 +++ arch/x86/boot/compressed/cmdline.c |3 +++ arch/x86/boot/header.S | 12 ++-- arch/x86/include/asm/bootparam.h | 10 -- arch/x86/kernel/head64.c |3 +++ arch/x86/kernel/setup.c|6 ++ 7 files changed, 51 insertions(+), 5 deletions(-) diff --git a/Documentation/x86/boot.txt b/Documentation/x86/boot.txt index 9efceff..51954d7 100644 --- a/Documentation/x86/boot.txt +++ b/Documentation/x86/boot.txt @@ -57,6 +57,9 @@ Protocol 2.10:(Kernel 2.6.31) Added a protocol for relaxed alignment Protocol 2.11: (Kernel 3.6) Added a field for offset of EFI handover protocol entry point. +Protocol 2.12: (Kernel 3.9) Added three fields for loading bzImage and +ramdisk above 4G with 64bit in bootparam. + MEMORY LAYOUT The traditional memory map for the kernel loader, used for Image or @@ -182,7 +185,7 @@ Offset Proto NameMeaning 0230/4 2.05+ kernel_alignment Physical addr alignment required for kernel 0234/1 2.05+ relocatable_kernel Whether kernel is relocatable or not 0235/1 2.10+ min_alignment Minimum alignment, as a power of two -0236/2 N/A pad3Unused +0236/2 2.12+ xloadflags Boot protocol option flags 0238/4 2.06+ cmdline_sizeMaximum size of the kernel command line 023C/4 2.07+ hardware_subarch Hardware subarchitecture 0240/8 2.07+ hardware_subarch_data Subarchitecture-specific data @@ -581,6 +584,20 @@ Protocol: 2.10+ misaligned kernel. Therefore, a loader should typically try each power-of-two alignment from kernel_alignment down to this alignment. +Field name: xloadflags +Type: modify (obligatory) +Offset/size:0x236/2 +Protocol: 2.12+ + + This field is a bitmask. + + Bit 0 (read): CAN_BE_LOADED_ABOVE_4G +- If 1, kernel/boot_params/cmdline/ramdisk can be above 4g, + + Bit 15 (write): USE_EXT_BOOT_PARAMS + - If 1, set by bootloader, and kernel could check new fields + in boot_params that are added from 2.12 safely. + Field name:cmdline_size Type: read Offset/size: 0x238/4 diff --git a/Documentation/x86/zero-page.txt b/Documentation/x86/zero-page.txt index cf5437d..0e19657 100644 --- a/Documentation/x86/zero-page.txt +++ b/Documentation/x86/zero-page.txt @@ -19,6 +19,9 @@ OffsetProto NameMeaning 090/010ALL hd1_infohd1 disk parameter, OBSOLETE!! 0A0/010ALL sys_desc_table System description table (struct sys_desc_table) 0B0/010ALL olpc_ofw_header OLPC's OpenFirmware CIF and friends +0C0/004 ALLext_ramdisk_image ramdisk_image high 32bits +0C4/004 ALLext_ramdisk_size ramdisk_size high 32bits +0C8/004 ALLext_cmd_line_ptr cmd_line_ptr high 32bits 140/080ALL edid_info Video mode setup (struct edid_info) 1C0/020ALL efi_infoEFI 32 information (struct efi_info) 1E0/004ALL alk_mem_k Alternative mem check, in KB diff --git a/arch/x86/boot/compressed/cmdline.c b/arch/x86/boot/compressed/cmdline.c index b4c913c..43e4ec7 100644 --- a/arch/x86/boot/compressed/cmdline.c +++ b/arch/x86/boot/compressed/cmdline.c @@ -17,6 +17,9 @@ static unsigned long get_cmd_line_ptr(void) { unsigned long cmd_line_ptr = real_mode-hdr.cmd_line_ptr; + if (real_mode-hdr.xloadflags USE_EXT_BOOT_PARAMS) + cmd_line_ptr |= (u64)real_mode-ext_cmd_line_ptr 32; + return cmd_line_ptr; } int cmdline_find_option(const char *option, char *buffer, int bufsize) diff --git a/arch/x86/boot/header.S b/arch/x86/boot/header.S index 2a01744..156f664 100644 --- a/arch/x86/boot/header.S +++ b/arch/x86/boot/header.S @@ -279,7 +279,7 @@ _start: # Part 2 of the header, from the old setup.S .ascii HdrS # header signature - .word 0x020b # header version number (= 0x0105) + .word 0x020c #