H. Peter Anvin | 5dcd14e | 2013-01-29 01:05:24 -0800 | [diff] [blame] | 1 | #ifndef _ASM_X86_BOOTPARAM_UTILS_H |
| 2 | #define _ASM_X86_BOOTPARAM_UTILS_H |
| 3 | |
| 4 | #include <asm/bootparam.h> |
| 5 | |
| 6 | /* |
| 7 | * This file is included from multiple environments. Do not |
| 8 | * add completing #includes to make it standalone. |
| 9 | */ |
| 10 | |
| 11 | /* |
| 12 | * Deal with bootloaders which fail to initialize unknown fields in |
| 13 | * boot_params to zero. The list fields in this list are taken from |
| 14 | * analysis of kexec-tools; if other broken bootloaders initialize a |
| 15 | * different set of fields we will need to figure out how to disambiguate. |
| 16 | * |
Josh Boyer | 2e604c0 | 2013-03-06 20:23:30 -0800 | [diff] [blame^] | 17 | * Note: efi_info is commonly left uninitialized, but that field has a |
| 18 | * private magic, so it is better to leave it unchanged. |
H. Peter Anvin | 5dcd14e | 2013-01-29 01:05:24 -0800 | [diff] [blame] | 19 | */ |
| 20 | static void sanitize_boot_params(struct boot_params *boot_params) |
| 21 | { |
| 22 | if (boot_params->sentinel) { |
| 23 | /*fields in boot_params are not valid, clear them */ |
| 24 | memset(&boot_params->olpc_ofw_header, 0, |
Josh Boyer | 2e604c0 | 2013-03-06 20:23:30 -0800 | [diff] [blame^] | 25 | (char *)&boot_params->efi_info - |
H. Peter Anvin | 5dcd14e | 2013-01-29 01:05:24 -0800 | [diff] [blame] | 26 | (char *)&boot_params->olpc_ofw_header); |
| 27 | memset(&boot_params->kbd_status, 0, |
| 28 | (char *)&boot_params->hdr - |
| 29 | (char *)&boot_params->kbd_status); |
| 30 | memset(&boot_params->_pad7[0], 0, |
| 31 | (char *)&boot_params->edd_mbr_sig_buffer[0] - |
| 32 | (char *)&boot_params->_pad7[0]); |
| 33 | memset(&boot_params->_pad8[0], 0, |
| 34 | (char *)&boot_params->eddbuf[0] - |
| 35 | (char *)&boot_params->_pad8[0]); |
| 36 | memset(&boot_params->_pad9[0], 0, sizeof(boot_params->_pad9)); |
| 37 | } |
| 38 | } |
| 39 | |
| 40 | #endif /* _ASM_X86_BOOTPARAM_UTILS_H */ |