2012-11-02 19:26:30 +01:00
|
|
|
/** @file
|
|
|
|
|
2013-02-14 20:21:12 +01:00
|
|
|
Copyright (c) 2011 - 2013, Intel Corporation. All rights reserved.<BR>
|
2019-04-04 01:06:33 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2012-11-02 19:26:30 +01:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __LINUX_BZIMAGE_H__
|
|
|
|
#define __LINUX_BZIMAGE_H__
|
|
|
|
|
|
|
|
#define BOOTSIG 0x1FE
|
|
|
|
#define SETUP_HDR 0x53726448 /* 0x53726448 == "HdrS" */
|
|
|
|
|
|
|
|
#define E820_RAM 1
|
|
|
|
#define E820_RESERVED 2
|
|
|
|
#define E820_ACPI 3
|
|
|
|
#define E820_NVS 4
|
|
|
|
#define E820_UNUSABLE 5
|
|
|
|
|
|
|
|
#pragma pack(1)
|
|
|
|
|
|
|
|
struct setup_header {
|
|
|
|
UINT8 setup_secs; /* Sectors for setup code */
|
|
|
|
UINT16 root_flags;
|
|
|
|
UINT32 sys_size;
|
|
|
|
UINT16 ram_size;
|
|
|
|
UINT16 video_mode;
|
|
|
|
UINT16 root_dev;
|
|
|
|
UINT16 signature; /* Boot signature */
|
|
|
|
UINT16 jump;
|
|
|
|
UINT32 header;
|
|
|
|
UINT16 version;
|
|
|
|
UINT16 su_switch;
|
|
|
|
UINT16 setup_seg;
|
|
|
|
UINT16 start_sys;
|
|
|
|
UINT16 kernel_ver;
|
|
|
|
UINT8 loader_id;
|
|
|
|
UINT8 load_flags;
|
|
|
|
UINT16 movesize;
|
|
|
|
UINT32 code32_start; /* Start of code loaded high */
|
|
|
|
UINT32 ramdisk_start; /* Start of initial ramdisk */
|
2016-09-13 10:33:20 +02:00
|
|
|
UINT32 ramdisk_len; /* Length of initial ramdisk */
|
2012-11-02 19:26:30 +01:00
|
|
|
UINT32 bootsect_kludge;
|
|
|
|
UINT16 heap_end;
|
|
|
|
UINT8 ext_loader_ver; /* Extended boot loader version */
|
|
|
|
UINT8 ext_loader_type; /* Extended boot loader ID */
|
|
|
|
UINT32 cmd_line_ptr; /* 32-bit pointer to the kernel command line */
|
|
|
|
UINT32 ramdisk_max; /* Highest legal initrd address */
|
|
|
|
UINT32 kernel_alignment; /* Physical addr alignment required for kernel */
|
|
|
|
UINT8 relocatable_kernel; /* Whether kernel is relocatable or not */
|
2013-02-14 20:21:12 +01:00
|
|
|
UINT8 min_alignment;
|
|
|
|
UINT16 xloadflags;
|
2012-11-02 19:26:30 +01:00
|
|
|
UINT32 cmdline_size;
|
|
|
|
UINT32 hardware_subarch;
|
|
|
|
UINT64 hardware_subarch_data;
|
|
|
|
UINT32 payload_offset;
|
|
|
|
UINT32 payload_length;
|
|
|
|
UINT64 setup_data;
|
|
|
|
UINT64 pref_address;
|
|
|
|
UINT32 init_size;
|
|
|
|
UINT32 handover_offset;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct efi_info {
|
|
|
|
UINT32 efi_loader_signature;
|
|
|
|
UINT32 efi_systab;
|
|
|
|
UINT32 efi_memdesc_size;
|
|
|
|
UINT32 efi_memdesc_version;
|
|
|
|
UINT32 efi_memmap;
|
|
|
|
UINT32 efi_memmap_size;
|
|
|
|
UINT32 efi_systab_hi;
|
|
|
|
UINT32 efi_memmap_hi;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct e820_entry {
|
|
|
|
UINT64 addr; /* start of memory segment */
|
|
|
|
UINT64 size; /* size of memory segment */
|
|
|
|
UINT32 type; /* type of memory segment */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct screen_info {
|
|
|
|
UINT8 orig_x; /* 0x00 */
|
|
|
|
UINT8 orig_y; /* 0x01 */
|
|
|
|
UINT16 ext_mem_k; /* 0x02 */
|
|
|
|
UINT16 orig_video_page; /* 0x04 */
|
|
|
|
UINT8 orig_video_mode; /* 0x06 */
|
|
|
|
UINT8 orig_video_cols; /* 0x07 */
|
|
|
|
UINT8 flags; /* 0x08 */
|
|
|
|
UINT8 unused2; /* 0x09 */
|
|
|
|
UINT16 orig_video_ega_bx; /* 0x0a */
|
|
|
|
UINT16 unused3; /* 0x0c */
|
|
|
|
UINT8 orig_video_lines; /* 0x0e */
|
|
|
|
UINT8 orig_video_isVGA; /* 0x0f */
|
|
|
|
UINT16 orig_video_points; /* 0x10 */
|
2021-12-05 23:54:09 +01:00
|
|
|
|
2012-11-02 19:26:30 +01:00
|
|
|
/* VESA graphic mode -- linear frame buffer */
|
|
|
|
UINT16 lfb_width; /* 0x12 */
|
|
|
|
UINT16 lfb_height; /* 0x14 */
|
|
|
|
UINT16 lfb_depth; /* 0x16 */
|
|
|
|
UINT32 lfb_base; /* 0x18 */
|
|
|
|
UINT32 lfb_size; /* 0x1c */
|
|
|
|
UINT16 cl_magic, cl_offset; /* 0x20 */
|
|
|
|
UINT16 lfb_linelength; /* 0x24 */
|
|
|
|
UINT8 red_size; /* 0x26 */
|
|
|
|
UINT8 red_pos; /* 0x27 */
|
|
|
|
UINT8 green_size; /* 0x28 */
|
|
|
|
UINT8 green_pos; /* 0x29 */
|
|
|
|
UINT8 blue_size; /* 0x2a */
|
|
|
|
UINT8 blue_pos; /* 0x2b */
|
|
|
|
UINT8 rsvd_size; /* 0x2c */
|
|
|
|
UINT8 rsvd_pos; /* 0x2d */
|
|
|
|
UINT16 vesapm_seg; /* 0x2e */
|
|
|
|
UINT16 vesapm_off; /* 0x30 */
|
|
|
|
UINT16 pages; /* 0x32 */
|
|
|
|
UINT16 vesa_attributes; /* 0x34 */
|
|
|
|
UINT32 capabilities; /* 0x36 */
|
|
|
|
UINT8 _reserved[6]; /* 0x3a */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct boot_params {
|
|
|
|
struct screen_info screen_info;
|
|
|
|
UINT8 apm_bios_info[0x14];
|
|
|
|
UINT8 _pad2[4];
|
|
|
|
UINT64 tboot_addr;
|
|
|
|
UINT8 ist_info[0x10];
|
|
|
|
UINT8 _pad3[16];
|
|
|
|
UINT8 hd0_info[16];
|
|
|
|
UINT8 hd1_info[16];
|
|
|
|
UINT8 sys_desc_table[0x10];
|
|
|
|
UINT8 olpc_ofw_header[0x10];
|
|
|
|
UINT8 _pad4[128];
|
|
|
|
UINT8 edid_info[0x80];
|
|
|
|
struct efi_info efi_info;
|
|
|
|
UINT32 alt_mem_k;
|
|
|
|
UINT32 scratch;
|
|
|
|
UINT8 e820_entries;
|
|
|
|
UINT8 eddbuf_entries;
|
|
|
|
UINT8 edd_mbr_sig_buf_entries;
|
|
|
|
UINT8 _pad6[6];
|
|
|
|
struct setup_header hdr;
|
|
|
|
UINT8 _pad7[0x290-0x1f1-sizeof (struct setup_header)];
|
|
|
|
UINT32 edd_mbr_sig_buffer[16];
|
|
|
|
struct e820_entry e820_map[128];
|
|
|
|
UINT8 _pad8[48];
|
|
|
|
UINT8 eddbuf[0x1ec];
|
|
|
|
UINT8 _pad9[276];
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
UINT16 limit;
|
|
|
|
UINT64 *base;
|
|
|
|
} dt_addr_t;
|
|
|
|
|
|
|
|
#pragma pack()
|
|
|
|
|
|
|
|
extern EFI_STATUS
|
|
|
|
setup_graphics (
|
|
|
|
struct boot_params *buf
|
|
|
|
);
|
|
|
|
|
|
|
|
#endif /* __LINUX_BZIMAGE_H__ */
|