blob: 176fffae5b602018c9b152983f4fefc8f54ee129 [file] [log] [blame] [raw]
/* shared.h - definitions used in all GRUB-specific code */
/*
* GRUB -- GRand Unified Bootloader
* Copyright (C) 1999,2000,2001,2002,2003,2004 Free Software Foundation, Inc.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
/*
* Generic defines to use anywhere
*/
#ifndef GRUB_SHARED_HEADER
#define GRUB_SHARED_HEADER 1
#include <config.h>
/* Add an underscore to a C symbol in assembler code if needed. */
#ifdef HAVE_ASM_USCORE
# define EXT_C(sym) _ ## sym
#else
# define EXT_C(sym) sym
#endif
/* Maybe redirect memory requests through grub_scratch_mem. */
#ifdef GRUB_UTIL
extern char *grub_scratch_mem;
# define RAW_ADDR(x) ((x) + (int) grub_scratch_mem)
# define RAW_SEG(x) (RAW_ADDR ((x) << 4) >> 4)
#else
# define RAW_ADDR(x) (x)
# define RAW_SEG(x) (x)
#endif
/* ZFS will use the top 4 Meg of physical memory (below 4Gig) for sratch */
#define ZFS_SCRATCH_SIZE 0x400000
#ifndef MAXPATHLEN
#define MAXPATHLEN 1024
#endif
#define MAXNAMELEN 256
#define MIN(x, y) ((x) < (y) ? (x) : (y))
/* Boot signature related defines for the findroot command */
#define BOOTSIGN_DIR "/boot/grub/bootsign"
#define BOOTSIGN_ARGLEN (MAXNAMELEN + 10) /* (<sign>,0,d) */
#define BOOTSIGN_LEN (sizeof (BOOTSIGN_DIR) + 1 + BOOTSIGN_ARGLEN)
#define BOOTSIGN_BACKUP "/etc/bootsign"
/*
* Integer sizes
*/
#define MAXINT 0x7FFFFFFF
#define MAXUINT 0xFFFFFFFF
/* Maximum command line size. Before you blindly increase this value,
see the comment in char_io.c (get_cmdline). */
#define MAX_CMDLINE 1600
#define NEW_HEAPSIZE 1500
/* 512-byte scratch area */
#define SCRATCHADDR RAW_ADDR (0x77e00)
#define SCRATCHSEG RAW_SEG (0x77e0)
/*
* This is the location of the raw device buffer. It is 31.5K
* in size.
*/
#define BUFFERLEN 0x7e00
#define BUFFERADDR RAW_ADDR (0x70000)
#define BUFFERSEG RAW_SEG (0x7000)
#define BOOT_PART_TABLE RAW_ADDR (0x07be)
/*
* BIOS disk defines
*/
#define BIOSDISK_READ 0x0
#define BIOSDISK_WRITE 0x1
#define BIOSDISK_ERROR_GEOMETRY 0x100
#define BIOSDISK_ERROR_SHORT_IO 0x101
#define BIOSDISK_FLAG_LBA_EXTENSION 0x1
#define BIOSDISK_FLAG_CDROM 0x2
#define BIOSDISK_FLAG_BIFURCATE 0x4 /* accessibility acts differently between chs and lba */
/*
* This is the filesystem (not raw device) buffer.
* It is 32K in size, do not overrun!
*/
#define FSYS_BUFLEN 0x8000
#define FSYS_BUF RAW_ADDR (0x68000)
/* Command-line buffer for Multiboot kernels and modules. This area
includes the area into which Stage 1.5 and Stage 1 are loaded, but
that's no problem. */
#ifndef STAGE1_5
#define MB_CMDLINE_BUF RAW_ADDR (0x7000)
#define MB_CMDLINE_BUFLEN 0x1000
#else
#define MB_CMDLINE_BUF RAW_ADDR (0x2000)
#define MB_CMDLINE_BUFLEN 0x6000
#endif
/* The buffer for the password. */
#define PASSWORD_BUF RAW_ADDR (0x78000)
#define PASSWORD_BUFLEN 0x200
/* THe buffer for the filename of "/boot/grub/default". */
#define DEFAULT_FILE_BUF (PASSWORD_BUF + PASSWORD_BUFLEN)
#define DEFAULT_FILE_BUFLEN 0x60
/* The buffer for the command-line. */
#define CMDLINE_BUF (DEFAULT_FILE_BUF + DEFAULT_FILE_BUFLEN)
#define CMDLINE_BUFLEN MAX_CMDLINE
///* The kill buffer for the command-line. */
//#define KILL_BUF (CMDLINE_BUF + CMDLINE_BUFLEN)
//#define KILL_BUFLEN MAX_CMDLINE
/* The history buffer for the command-line. */
//#define HISTORY_BUF (KILL_BUF + KILL_BUFLEN)
#define HISTORY_BUF (CMDLINE_BUF + CMDLINE_BUFLEN)
#define HISTORY_SIZE 5
#define HISTORY_BUFLEN (MAX_CMDLINE * HISTORY_SIZE)
/* The buffer for the completion. */
#define COMPLETION_BUF (HISTORY_BUF + HISTORY_BUFLEN)
#define COMPLETION_BUFLEN MAX_CMDLINE
/* The buffer for the unique string. */
#define UNIQUE_BUF (COMPLETION_BUF + COMPLETION_BUFLEN)
#define UNIQUE_BUFLEN MAX_CMDLINE
/* The buffer for the menu entries. */
//#define MENU_BUF (UNIQUE_BUF + UNIQUE_BUFLEN)
//#define MENU_BUFLEN (0x8000 + PASSWORD_BUF - MENU_BUF)
/* The size of the drive map. */
#define DRIVE_MAP_SIZE 8
/* The size of the drive_map_slot struct. */
#define DRIVE_MAP_SLOT_SIZE 24
/* The size of the key map. */
#define KEY_MAP_SIZE 128
/*
* extended chainloader code address for switching to real mode
*/
#define HMA_ADDR 0x2B0000
/*
* Linux setup parameters
*/
#define LINUX_MAGIC_SIGNATURE 0x53726448 /* "HdrS" */
#define LINUX_DEFAULT_SETUP_SECTS 4
#define LINUX_FLAG_CAN_USE_HEAP 0x80
#define LINUX_INITRD_MAX_ADDRESS 0x38000000
#define LINUX_MAX_SETUP_SECTS 64
#define LINUX_BOOT_LOADER_TYPE 0x71
#define LINUX_HEAP_END_OFFSET (0x9000 - 0x200)
#define LINUX_BZIMAGE_ADDR RAW_ADDR (0x100000)
#define LINUX_ZIMAGE_ADDR RAW_ADDR (0x10000)
#define LINUX_OLD_REAL_MODE_ADDR RAW_ADDR (0x90000)
#define LINUX_SETUP_STACK 0x9000
#define LINUX_FLAG_BIG_KERNEL 0x1
/* Linux's video mode selection support. Actually I hate it! */
#define LINUX_VID_MODE_NORMAL 0xFFFF
#define LINUX_VID_MODE_EXTENDED 0xFFFE
#define LINUX_VID_MODE_ASK 0xFFFD
#define LINUX_CL_OFFSET 0x9000
#define LINUX_CL_END_OFFSET 0x93FF
#define LINUX_SETUP_MOVE_SIZE 0x9400
#define LINUX_CL_MAGIC 0xA33F
/*
* General disk stuff
*/
#define SECTOR_SIZE 0x200
#define SECTOR_BITS 9
#define BIOS_FLAG_FIXED_DISK 0x80
#define BOOTSEC_LOCATION RAW_ADDR (0x7C00)
#define BOOTSEC_SIGNATURE 0xAA55
#define BOOTSEC_BPB_OFFSET 0x3
#define BOOTSEC_BPB_LENGTH 0x3B
#define BOOTSEC_BPB_SYSTEM_ID 0x3
#define BOOTSEC_BPB_HIDDEN_SECTORS 0x1C
#define BOOTSEC_PART_OFFSET 0x1BE
#define BOOTSEC_PART_LENGTH 0x40
#define BOOTSEC_SIG_OFFSET 0x1FE
#define BOOTSEC_LISTSIZE 8
/* Not bad, perhaps. */
#define NETWORK_DRIVE 0x20
#define PXE_DRIVE 0x21
#define INITRD_DRIVE 0x22
#define FB_DRIVE 0x23
/*
* GRUB specific information
* (in LSB order)
*/
#include <stage1.h>
#define STAGE2_VER_MAJ_OFFS 0x6
#define STAGE2_INSTALLPART 0x8
#define STAGE2_SAVED_ENTRYNO 0xc
#define STAGE2_STAGE2_ID 0x10
#define STAGE2_FORCE_LBA 0x11
#define STAGE2_VER_STR_OFFS 0x12
/* Stage 2 identifiers */
#define STAGE2_ID_STAGE2 0
#define STAGE2_ID_FFS_STAGE1_5 1
#define STAGE2_ID_E2FS_STAGE1_5 2
#define STAGE2_ID_FAT_STAGE1_5 3
#define STAGE2_ID_MINIX_STAGE1_5 4
#define STAGE2_ID_REISERFS_STAGE1_5 5
#define STAGE2_ID_VSTAFS_STAGE1_5 6
#define STAGE2_ID_JFS_STAGE1_5 7
#define STAGE2_ID_XFS_STAGE1_5 8
#define STAGE2_ID_ISO9660_STAGE1_5 9
#define STAGE2_ID_UFS2_STAGE1_5 10
#define STAGE2_ID_NTFS_STAGE1_5 11
#define STAGE2_ID_UFS_STAGE1_5 12
#define STAGE2_ID_ZFS_STAGE1_5 13
#ifndef STAGE1_5
# define STAGE2_ID STAGE2_ID_STAGE2
#else
# if defined(FSYS_FFS)
# define STAGE2_ID STAGE2_ID_FFS_STAGE1_5
# elif defined(FSYS_EXT2FS)
# define STAGE2_ID STAGE2_ID_E2FS_STAGE1_5
# elif defined(FSYS_FAT)
# define STAGE2_ID STAGE2_ID_FAT_STAGE1_5
# elif defined(FSYS_NTFS)
# define STAGE2_ID STAGE2_ID_NTFS_STAGE1_5
# elif defined(FSYS_MINIX)
# define STAGE2_ID STAGE2_ID_MINIX_STAGE1_5
# elif defined(FSYS_REISERFS)
# define STAGE2_ID STAGE2_ID_REISERFS_STAGE1_5
# elif defined(FSYS_VSTAFS)
# define STAGE2_ID STAGE2_ID_VSTAFS_STAGE1_5
# elif defined(FSYS_JFS)
# define STAGE2_ID STAGE2_ID_JFS_STAGE1_5
# elif defined(FSYS_XFS)
# define STAGE2_ID STAGE2_ID_XFS_STAGE1_5
# elif defined(FSYS_ISO9660)
# define STAGE2_ID STAGE2_ID_ISO9660_STAGE1_5
# elif defined(FSYS_UFS2)
# define STAGE2_ID STAGE2_ID_UFS2_STAGE1_5
# elif defined(FSYS_UFS)
# define STAGE2_ID STAGE2_ID_UFS_STAGE1_5
# elif defined(FSYS_ZFS)
# define STAGE2_ID STAGE2_ID_ZFS_STAGE1_5
# else
# error "unknown Stage 2"
# endif
#endif
/*
* defines for use when switching between real and protected mode
*/
#define CR0_PE_ON 0x1
#define CR0_PE_OFF 0xfffffffe
#define PROT_MODE_CSEG 0x8
#define PROT_MODE_DSEG 0x10
#define PSEUDO_RM_CSEG 0x18
#define PSEUDO_RM_DSEG 0x20
#define STACKOFF MB_CMDLINE_BUF /* (0x2000 - 0x10) */
#define PROTSTACKINIT (FSYS_BUF - 0x10)
/*
* Assembly code defines
*
* "EXT_C" is assumed to be defined in the Makefile by the configure
* command.
*/
#define ENTRY(x) .globl EXT_C(x) ; EXT_C(x):
#define VARIABLE(x) ENTRY(x)
#define K_RDWR 0x60 /* keyboard data & cmds (read/write) */
#define K_STATUS 0x64 /* keyboard status */
#define K_CMD 0x64 /* keybd ctlr command (write-only) */
#define K_OBUF_FUL 0x01 /* output buffer full */
#define K_IBUF_FUL 0x02 /* input buffer full */
#define KC_CMD_WIN 0xd0 /* read output port */
#define KC_CMD_WOUT 0xd1 /* write output port */
#define KB_OUTPUT_MASK 0xdd /* enable output buffer full interrupt
enable data line
enable clock line */
#define KB_A20_ENABLE 0x02
/* Codes for getchar. */
#define ASCII_CHAR(x) ((x) & 0xFF)
#if !defined(GRUB_UTIL) || !defined(HAVE_LIBCURSES)
# define KEY_LEFT 0x4B00
# define KEY_RIGHT 0x4D00
# define KEY_UP 0x4800
# define KEY_DOWN 0x5000
# define KEY_IC 0x5200 /* insert char */
# define KEY_DC 0x5300 /* delete char */
# define KEY_BACKSPACE 0x0E08
# define KEY_HOME 0x4700
# define KEY_END 0x4F00
# define KEY_NPAGE 0x5100
# define KEY_PPAGE 0x4900
# define A_NORMAL 0x7
# define A_REVERSE 0x70
#elif defined(HAVE_NCURSES_CURSES_H)
# include <ncurses/curses.h>
#elif defined(HAVE_NCURSES_H)
# include <ncurses.h>
#elif defined(HAVE_CURSES_H)
# include <curses.h>
#endif
/* In old BSD curses, A_NORMAL and A_REVERSE are not defined, so we
define them here if they are undefined. */
#ifndef A_NORMAL
# define A_NORMAL 0
#endif /* ! A_NORMAL */
#ifndef A_REVERSE
# ifdef A_STANDOUT
# define A_REVERSE A_STANDOUT
# else /* ! A_STANDOUT */
# define A_REVERSE 0
# endif /* ! A_STANDOUT */
#endif /* ! A_REVERSE */
/* Define ACS_* ourselves, since the definitions are not consistent among
various curses implementations. */
#undef ACS_ULCORNER
#undef ACS_URCORNER
#undef ACS_LLCORNER
#undef ACS_LRCORNER
#undef ACS_HLINE
#undef ACS_VLINE
#undef ACS_LARROW
#undef ACS_RARROW
#undef ACS_UARROW
#undef ACS_DARROW
#define ACS_ULCORNER '+'
#define ACS_URCORNER '+'
#define ACS_LLCORNER '+'
#define ACS_LRCORNER '+'
#define ACS_HLINE '-'
#define ACS_VLINE '|'
#define ACS_LARROW '<'
#define ACS_RARROW '>'
#define ACS_UARROW '^'
#define ACS_DARROW 'v'
/* Special graphics characters for IBM displays. */
#define DISP_UL 218
#define DISP_UR 191
#define DISP_LL 192
#define DISP_LR 217
#define DISP_HORIZ 196
#define DISP_VERT 179
#define DISP_LEFT 0x1b
#define DISP_RIGHT 0x1a
#define DISP_UP 0x18
#define DISP_DOWN 0x19
/* Remap some libc-API-compatible function names so that we prevent
circularararity. */
#ifndef WITHOUT_LIBC_STUBS
#define memmove grub_memmove
#define memcpy grub_memmove /* we don't need a separate memcpy */
#define memset grub_memset
#undef isspace
#define isspace grub_isspace
#define printf grub_printf
#define sprintf grub_sprintf
#undef putchar
#define putchar grub_putchar
#define strncat grub_strncat
#define strstr grub_strstr
#define memcmp grub_memcmp
#define strcmp grub_strcmp
#define tolower grub_tolower
#define strlen grub_strlen
#define strcpy grub_strcpy
#endif /* WITHOUT_LIBC_STUBS */
#define PXE_TFTP_MODE 1
#define PXE_FAST_READ 1
/* see typedef gfx_data_t below */
#define gfx_ofs_v1_ok 0x00
#define gfx_ofs_v1_mem_start 0x04
#define gfx_ofs_v1_mem_cur 0x08
#define gfx_ofs_v1_mem_max 0x0c
#define gfx_ofs_v1_code_seg 0x10
#define gfx_ofs_v1_jmp_table 0x14
#define gfx_ofs_v1_sys_cfg 0x44
#define gfx_ofs_v1_cmdline 0x64
#define gfx_ofs_v1_cmdline_len 0x68
#define gfx_ofs_v1_menu_list 0x6c
#define gfx_ofs_v1_menu_default_entry 0x70
#define gfx_ofs_v1_menu_entries 0x74
#define gfx_ofs_v1_menu_entry_len 0x78
#define gfx_ofs_v1_args_list 0x7c
#define gfx_ofs_v1_args_entry_len 0x80
#define gfx_ofs_v1_timeout 0x84
#define gfx_ofs_v1_mem_file 0x88
#define gfx_ofs_v1_mem_align 0x8c
#define gfx_ofs_v2_ok 0x00
#define gfx_ofs_v2_code_seg 0x04
#define gfx_ofs_v2_jmp_table 0x08
#define gfx_ofs_v2_sys_cfg 0x38
#define gfx_ofs_v2_cmdline 0x6c
#define gfx_ofs_v2_cmdline_len 0x70
#define gfx_ofs_v2_menu_list 0x74
#define gfx_ofs_v2_menu_default_entry 0x78
#define gfx_ofs_v2_menu_entries 0x7c
#define gfx_ofs_v2_menu_entry_len 0x80
#define gfx_ofs_v2_args_list 0x84
#define gfx_ofs_v2_args_entry_len 0x88
#define gfx_ofs_v2_timeout 0x8c
#define UNDI_STACK (512 + 64) << 10
#define UNDI_STACK_SEG (UNDI_STACK >> 4) /* PXE load GRUB here */
#define UNDI_STACK_OFF (0x10000 - 0x10)
#ifndef ASM_FILE
/*
* Below this should be ONLY defines and other constructs for C code.
*/
/* multiboot stuff */
#include "mb_header.h"
#include "mb_info.h"
/* For the Linux/i386 boot protocol version 2.03. */
struct linux_kernel_header
{
char code1[0x0020];
unsigned short cl_magic; /* Magic number 0xA33F */
unsigned short cl_offset; /* The offset of command line */
char code2[0x01F1 - 0x0020 - 2 - 2];
unsigned char setup_sects; /* The size of the setup in sectors */
unsigned short root_flags; /* If the root is mounted readonly */
unsigned short syssize; /* obsolete */
unsigned short swap_dev; /* obsolete */
unsigned short ram_size; /* obsolete */
unsigned short vid_mode; /* Video mode control */
unsigned short root_dev; /* Default root device number */
unsigned short boot_flag; /* 0xAA55 magic number */
unsigned short jump; /* Jump instruction */
unsigned long header; /* Magic signature "HdrS" */
unsigned short version; /* Boot protocol version supported */
unsigned long realmode_swtch; /* Boot loader hook */
unsigned long start_sys; /* Points to kernel version string */
unsigned char type_of_loader; /* Boot loader identifier */
unsigned char loadflags; /* Boot protocol option flags */
unsigned short setup_move_size; /* Move to high memory size */
unsigned long code32_start; /* Boot loader hook */
unsigned long ramdisk_image; /* initrd load address */
unsigned long ramdisk_size; /* initrd size */
unsigned long bootsect_kludge; /* obsolete */
unsigned short heap_end_ptr; /* Free memory after setup end */
unsigned short pad1; /* Unused */
char *cmd_line_ptr; /* Points to the kernel command line */
unsigned long initrd_addr_max; /* The highest address of initrd */
} __attribute__ ((packed));
/* Memory map address range descriptor used by GET_MMAP_ENTRY. */
struct mmar_desc
{
unsigned long desc_len; /* Size of this descriptor. */
unsigned long long addr; /* Base address. */
unsigned long long length; /* Length in bytes. */
unsigned long type; /* Type of address range. */
} __attribute__ ((packed));
/* VBE controller information. */
struct vbe_controller
{
unsigned char signature[4];
unsigned short version;
unsigned long oem_string;
unsigned long capabilities;
unsigned long video_mode;
unsigned short total_memory;
unsigned short oem_software_rev;
unsigned long oem_vendor_name;
unsigned long oem_product_name;
unsigned long oem_product_rev;
unsigned char reserved[222];
unsigned char oem_data[256];
} __attribute__ ((packed));
/* VBE mode information. */
struct vbe_mode
{
unsigned short mode_attributes;
unsigned char win_a_attributes;
unsigned char win_b_attributes;
unsigned short win_granularity;
unsigned short win_size;
unsigned short win_a_segment;
unsigned short win_b_segment;
unsigned long win_func;
unsigned short bytes_per_scanline;
/* >=1.2 */
unsigned short x_resolution;
unsigned short y_resolution;
unsigned char x_char_size;
unsigned char y_char_size;
unsigned char number_of_planes;
unsigned char bits_per_pixel;
unsigned char number_of_banks;
unsigned char memory_model;
unsigned char bank_size;
unsigned char number_of_image_pages;
unsigned char reserved0;
/* direct color */
unsigned char red_mask_size;
unsigned char red_field_position;
unsigned char green_mask_size;
unsigned char green_field_position;
unsigned char blue_mask_size;
unsigned char blue_field_position;
unsigned char reserved_mask_size;
unsigned char reserved_field_position;
unsigned char direct_color_mode_info;
/* >=2.0 */
unsigned long phys_base;
unsigned long reserved1;
unsigned short reversed2;
/* >=3.0 */
unsigned short linear_bytes_per_scanline;
unsigned char banked_number_of_image_pages;
unsigned char linear_number_of_image_pages;
unsigned char linear_red_mask_size;
unsigned char linear_red_field_position;
unsigned char linear_green_mask_size;
unsigned char linear_green_field_position;
unsigned char linear_blue_mask_size;
unsigned char linear_blue_field_position;
unsigned char linear_reserved_mask_size;
unsigned char linear_reserved_field_position;
unsigned long max_pixel_clock;
unsigned char reserved3[189];
} __attribute__ ((packed));
#undef NULL
#define NULL ((void *) 0)
/* Error codes (descriptions are in common.c) */
typedef enum
{
ERR_NONE = 0,
ERR_BAD_FILENAME,
ERR_BAD_FILETYPE,
ERR_BAD_GZIP_DATA,
ERR_BAD_GZIP_HEADER,
ERR_BAD_PART_TABLE,
ERR_BAD_VERSION,
ERR_BELOW_1MB,
ERR_BOOT_COMMAND,
ERR_BOOT_FAILURE,
ERR_BOOT_FEATURES,
ERR_DEV_FORMAT,
ERR_DEV_VALUES,
ERR_EXEC_FORMAT,
ERR_FILELENGTH,
ERR_FILE_NOT_FOUND,
ERR_FSYS_CORRUPT,
ERR_FSYS_MOUNT,
ERR_GEOM,
ERR_NEED_LX_KERNEL,
ERR_NEED_MB_KERNEL,
ERR_NO_DISK,
ERR_NO_PART,
ERR_NUMBER_PARSING,
ERR_OUTSIDE_PART,
ERR_READ,
ERR_SYMLINK_LOOP,
ERR_UNRECOGNIZED,
ERR_WONT_FIT,
ERR_WRITE,
ERR_BAD_ARGUMENT,
ERR_UNALIGNED,
ERR_PRIVILEGED,
ERR_DEV_NEED_INIT,
ERR_NO_DISK_SPACE,
ERR_NUMBER_OVERFLOW,
ERR_DEFAULT_FILE,
ERR_DEL_MEM_DRIVE,
ERR_DISABLE_A20,
ERR_DOS_BACKUP,
ERR_ENABLE_A20,
ERR_EXTENDED_PARTITION,
ERR_FILENAME_FORMAT,
ERR_HD_VOL_START_0,
ERR_INT13_ON_HOOK,
ERR_INT13_OFF_HOOK,
ERR_INVALID_BOOT_CS,
ERR_INVALID_BOOT_IP,
ERR_INVALID_FLOPPIES,
ERR_INVALID_HARDDRIVES,
ERR_INVALID_HEADS,
ERR_INVALID_LOAD_LENGTH,
ERR_INVALID_LOAD_OFFSET,
ERR_INVALID_LOAD_SEGMENT,
ERR_INVALID_SECTORS,
ERR_INVALID_SKIP_LENGTH,
ERR_INVALID_RAM_DRIVE,
ERR_IN_SITU_FLOPPY,
ERR_IN_SITU_MEM,
ERR_MD_BASE,
ERR_NON_CONTIGUOUS,
ERR_NO_DRIVE_MAPPED,
ERR_NO_HEADS,
ERR_NO_SECTORS,
ERR_PARTITION_TABLE_FULL,
ERR_RD_BASE,
ERR_SPECIFY_GEOM,
ERR_SPECIFY_MEM,
ERR_SPECIFY_RESTRICTION,
// ERR_INVALID_RD_BASE,
// ERR_INVALID_RD_SIZE,
ERR_MD5_FORMAT,
ERR_WRITE_GZIP_FILE,
ERR_FUNC_CALL,
// ERR_WRITE_TO_NON_MEM_DRIVE,
ERR_BAD_GZIP_CRC,
ERR_FILESYSTEM_NOT_FOUND,
ERR_NO_BOOTPATH,
ERR_NEWER_VERSION,
ERR_NOTXPM,
ERR_TOOMANYCOLORS,
ERR_CORRUPTXPM,
MAX_ERR_NUM
} grub_error_t;
typedef enum
{
CFG_HARDCODED,
CFG_150,
CFG_MAC,
CFG_BOOTFILE
} configfile_origin_t;
extern unsigned long install_partition;
extern unsigned long boot_drive;
//extern unsigned long install_second_sector;
//extern struct apm_info apm_bios_info;
extern unsigned long boot_part_addr;
extern int saved_entryno;
extern unsigned char force_lba;
extern char version_string[];
extern char config_file[];
extern char *bootfile;
extern configfile_origin_t configfile_origin;
extern unsigned long linux_text_len;
extern char *linux_data_tmp_addr;
extern char *linux_data_real_addr;
extern int quit_print;
extern struct linux_kernel_header *linux_header;
/* If not using config file, this variable is set to zero,
otherwise non-zero. */
extern int use_config_file;
#ifdef GRUB_UTIL
/* If using the preset menu, this variable is set to non-zero,
otherwise zero. */
extern int use_preset_menu;
/* If not using curses, this variable is set to zero, otherwise non-zero. */
extern int use_curses;
/* The flag for verbose messages. */
extern int verbose;
/* The flag for read-only. */
extern int read_only;
/* The number of floppies to be probed. */
extern int floppy_disks;
/* The map between BIOS drives and UNIX device file names. */
extern char **device_map;
/* The filename which stores the information about a device map. */
extern char *device_map_file;
/* The array of geometries. */
extern struct geometry *disks;
/* Assign DRIVE to a device name DEVICE. */
extern void assign_device_name (int drive, const char *device);
#define DEBUG_SLEEP {}
#else
/* print debug message on startup if the DEBUG_KEY is pressed. */
extern int debug_boot;
extern int console_getkey (void);
extern unsigned long initrd_start_sector;
extern int disable_map_info;
extern int map_func (char *arg, int flags);
//#define SLEEP {unsigned long i;for (i=0;i<0xFFFFFFFF;i++);}
#define DEBUG_SLEEP {if (debug_boot) console_getkey ();}
#endif
extern void hexdump(unsigned long,char*,int);
#ifndef STAGE1_5
/* GUI interface variables. */
# define MAX_FALLBACK_ENTRIES 8
extern int fallback_entries[MAX_FALLBACK_ENTRIES];
extern int fallback_entryno;
extern int default_entry;
extern int current_entryno;
extern const char *preset_menu;
/*
* graphics menu stuff
*
* Note: gfx_data and all data referred to in it must lie within a 64k area.
*/
typedef struct
{
unsigned ok; /* set while we're in graphics mode */
unsigned mem_start, mem_cur, mem_max;
unsigned code_seg; /* code segment of binary graphics code */
unsigned jmp_table[12]; /* link to graphics functions */
unsigned char sys_cfg[32]; /* sys_cfg[0]: identifies boot loader (grub == 2) */
char *cmdline; /* command line returned by gfx_input() */
unsigned cmdline_len; /* length of the above */
char *menu_list; /* list of menu entries, each of fixed length (menu_entry_len) */
char *menu_default_entry; /* the default entry */
unsigned menu_entries; /* number of entries in menu_list */
unsigned menu_entry_len; /* one entry */
char *args_list; /* same structure as menu_list, menu_entries entries */
unsigned args_entry_len; /* one entry */
unsigned timeout; /* in seconds (0: no timeout) */
unsigned mem_file; /* aligned gfx file start */
unsigned mem_align; /* aligned cpio file start */
} __attribute__ ((packed)) gfx_data_v1_t;
typedef struct
{
unsigned ok; /* set while we're in graphics mode */
unsigned code_seg; /* code segment of binary graphics code */
unsigned jmp_table[12]; /* link to graphics functions */
unsigned char sys_cfg[52]; /* sys_cfg[0]: identifies boot loader (grub == 2) */
char *cmdline; /* command line returned by gfx_input() */
unsigned cmdline_len; /* length of the above */
char *menu_list; /* list of menu entries, each of fixed length (menu_entry_len) */
char *menu_default_entry; /* the default entry */
unsigned menu_entries; /* number of entries in menu_list */
unsigned menu_entry_len; /* one entry */
char *args_list; /* same structure as menu_list, menu_entries entries */
unsigned args_entry_len; /* one entry */
unsigned timeout; /* in seconds (0: no timeout) */
} __attribute__ ((packed)) gfx_data_v2_t;
#ifdef SUPPORT_GFX
/* pointer to graphics image data */
extern char graphics_file[64];
extern unsigned long gfx_drive, gfx_partition;
int gfx_init_v1(gfx_data_v1_t *gfx_data);
int gfx_done_v1(gfx_data_v1_t *gfx_data);
int gfx_input_v1(gfx_data_v1_t *gfx_data, int *menu_entry);
int gfx_setup_menu_v1(gfx_data_v1_t *gfx_data);
int gfx_init_v2(gfx_data_v2_t *gfx_data);
int gfx_done_v2(gfx_data_v2_t *gfx_data);
int gfx_input_v2(gfx_data_v2_t *gfx_data, int *menu_entry);
int gfx_setup_menu_v2(gfx_data_v2_t *gfx_data);
#endif
/* The constants for password types. */
typedef enum
{
PASSWORD_PLAIN,
PASSWORD_MD5,
PASSWORD_UNSUPPORTED
}
password_t;
extern char *password;
extern password_t password_type;
extern int auth;
extern char commands[];
/* For `more'-like feature. */
extern int max_lines;
extern int count_lines;
extern int use_pager;
#endif
#ifndef NO_DECOMPRESSION
extern int no_decompression;
extern int compressed_file;
#endif
/* instrumentation variables */
extern void (*disk_read_hook) (unsigned long, unsigned long, unsigned long);
extern void (*disk_read_func) (unsigned long, unsigned long, unsigned long);
#ifndef STAGE1_5
/* The flag for debug mode. */
extern int debug;
#endif /* STAGE1_5 */
extern unsigned long current_drive;
extern unsigned long current_partition;
extern char current_rootpool[MAXNAMELEN];
extern char current_bootfs[MAXNAMELEN];
extern unsigned long long current_bootfs_obj;
extern char current_bootpath[MAXPATHLEN];
extern char current_devid[MAXPATHLEN];
extern int is_zfs_mount;
extern unsigned long best_drive;
extern unsigned long best_part;
extern int find_best_root;
extern int fsys_type;
//extern inline unsigned long log2_tmp (unsigned long word);
static inline unsigned long
log2_tmp (unsigned long word)
{
asm volatile ("bsfl %1,%0"
: "=r" (word)
: "r" (word));
return word;
}
extern void unicode_to_utf8 (unsigned short *filename, unsigned char *utf8, unsigned long n);
/* The information for a disk geometry. The CHS information is only for
DOS/Partition table compatibility, and the real number of sectors is
stored in TOTAL_SECTORS. */
struct geometry
{
/* The number of cylinders */
unsigned long cylinders;
/* The number of heads */
unsigned long heads;
/* The number of sectors */
unsigned long sectors;
/* The total number of sectors */
unsigned long long total_sectors;
/* Device sector size */
unsigned long sector_size;
/* Flags */
unsigned long flags;
};
extern unsigned long long part_start;
extern unsigned long long part_length;
extern unsigned long current_slice;
#ifndef GRUB_UTIL
extern unsigned long force_geometry_tune;
#endif
extern int buf_drive;
#define BUF_CACHE_INVALID 0xffffffff
extern unsigned int buf_track;
extern struct geometry buf_geom;
extern struct geometry tmp_geom;
extern struct geometry fd_geom[4];
extern struct geometry hd_geom[8];
/* these are the current file position and maximum file position */
extern unsigned long long filepos;
extern unsigned long long filemax;
extern unsigned long long filesize;
extern unsigned long emu_iso_sector_size_2048;
/*
* Common BIOS/boot data.
*/
extern struct multiboot_info mbi;
extern unsigned long saved_drive;
extern unsigned long saved_partition;
extern char saved_dir[256];
extern unsigned long memdisk_raw; /* raw mode as in memdisk */
extern unsigned long a20_keep_on; /* keep a20 on after RAM drive sector access */
extern unsigned long lba_cd_boot; /* LBA of no-emulation boot image, in 2048-byte sectors */
extern unsigned long safe_mbr_hook; /* safe mbr hook flags used by Win9x */
extern unsigned long int13_scheme; /* controls disk access methods in emulation */
extern unsigned char atapi_dev_count; /* ATAPI CDROM DRIVE COUNT */
extern unsigned long *reg_base_addr_append;
extern unsigned long init_atapi(void);
extern unsigned char min_cdrom_id; /* MINIMUM ATAPI CDROM DRIVE NUMBER */
extern unsigned long cdrom_drive;
//extern unsigned long cdrom_drives[];
//#ifndef cdrom_drive
//#define cdrom_drive (*cdrom_drives)
//#endif
extern unsigned long force_cdrom_as_boot_device;
extern unsigned long ram_drive;
extern unsigned long rd_base;
extern unsigned long rd_size;
extern unsigned long saved_mem_upper;
extern unsigned long saved_mem_lower;
extern unsigned long saved_mmap_addr;
extern unsigned long saved_mmap_length;
#ifndef STAGE1_5
#ifdef SOLARIS_NETBOOT
extern unsigned long dhcpack_length;
extern unsigned long dhcpack_buf;
#endif
extern unsigned long extended_memory;
extern unsigned long init_free_mem_start;
extern int config_len;
#endif
/*
* Error variables.
*/
extern grub_error_t errnum;
extern char *err_list[];
/* don't print geeky noise */
typedef enum
{
SILENT,
VERBOSE,
DEFER_SILENT,
DEFER_VERBOSE
} silent_status;
/* one screen worth of messages 80x24 = 1920 chars -- more with newlines */
#define SCREENBUF 2000
struct silentbuf {
silent_status status;
int looped;
char buffer[SCREENBUF];
char *buffer_start;
};
extern struct silentbuf silent;
extern int reset_term;
/* Simplify declaration of entry_addr. */
typedef void (*entry_func) (int, int, int, int, int, int)
__attribute__ ((noreturn));
extern entry_func entry_addr;
/* Enter the stage1.5/stage2 C code after the stack is set up. */
void cmain (void);
/* Halt the processor (called after an unrecoverable error). */
void stop (void) __attribute__ ((noreturn));
/* Reboot the system. */
void grub_reboot (void) __attribute__ ((noreturn));
/* Halt the system, using APM if possible. If NO_APM is true, don't use
APM even if it is available. */
void grub_halt (int no_apm) __attribute__ ((noreturn));
struct drive_map_slot
{
/* Remember to update DRIVE_MAP_SLOT_SIZE once this is modified.
* The struct size must be a multiple of 4.
*/
/* X=max_sector bit 7: read only or fake write */
/* Y=to_sector bit 6: safe boot or fake write */
/* ------------------------------------------- */
/* X Y: meaning of restrictions imposed on map */
/* ------------------------------------------- */
/* 1 1: read only=0, fake write=1, safe boot=0 */
/* 1 0: read only=1, fake write=0, safe boot=0 */
/* 0 1: read only=0, fake write=0, safe boot=1 */
/* 0 0: read only=0, fake write=0, safe boot=0 */
unsigned char from_drive;
unsigned char to_drive; /* 0xFF indicates a memdrive */
unsigned char max_head;
unsigned char max_sector; /* bit 7: read only */
/* bit 6: disable lba */
unsigned short to_cylinder; /* max cylinder of the TO drive */
/* bit 15: TO drive support LBA */
/* bit 14: TO drive is CDROM(with big 2048-byte sector) */
/* bit 13: FROM drive is CDROM(with big 2048-byte sector) */
unsigned char to_head; /* max head of the TO drive */
unsigned char to_sector; /* max sector of the TO drive */
/* bit 7: in-situ */
/* bit 6: fake-write or safe-boot */
unsigned long start_sector;
unsigned long start_sector_hi; /* hi dword of the 64-bit value */
unsigned long sector_count;
unsigned long sector_count_hi; /* hi dword of the 64-bit value */
};
extern struct drive_map_slot bios_drive_map[DRIVE_MAP_SIZE + 1];
extern struct drive_map_slot hooked_drive_map[DRIVE_MAP_SIZE + 1];
/* Copy MAP to the drive map and set up int13_handler. */
void set_int13_handler (struct drive_map_slot *map);
/* Restore the original int13 handler. */
int unset_int13_handler (int check_status_only);
/* Set up int15_handler. */
void set_int15_handler (void);
/* Restore the original int15 handler. */
void unset_int15_handler (void);
/* Track the int13 handler to probe I/O address space. */
void track_int13 (int drive);
/* The key map. */
extern unsigned short bios_key_map[];
extern unsigned short ascii_key_map[];
/* calls for direct boot-loader chaining */
void chain_stage1 (unsigned long segment, unsigned long offset,
unsigned long part_table_addr)
__attribute__ ((noreturn));
void chain_stage2 (unsigned long segment, unsigned long offset,
int second_sector)
__attribute__ ((noreturn));
/* do some funky stuff, then boot linux */
void linux_boot (void) __attribute__ ((noreturn));
/* do some funky stuff, then boot bzImage linux */
void big_linux_boot (void) __attribute__ ((noreturn));
/* booting a multiboot executable */
void multi_boot (void *start, struct multiboot_info *mb_info) __attribute__ ((noreturn));
/* If LINEAR is nonzero, then set the Intel processor to linear mode.
Otherwise, bit 20 of all memory accesses is always forced to zero,
causing a wraparound effect for bugwards compatibility with the
8086 CPU. Return 0 for failure and 1 for success. */
int gateA20 (int linear);
/* memory probe routines */
int get_memsize (int type);
int get_eisamemsize (void);
/* Fetch the next entry in the memory map and return the continuation
value. DESC is a pointer to the descriptor buffer, and CONT is the
previous continuation value (0 to get the first entry in the
map). */
int get_mmap_entry (struct mmar_desc *desc, int cont);
/* Get the linear address of a ROM configuration table. Return zero,
if fails. */
unsigned long get_rom_config_table (void);
/* Get APM BIOS information. */
//void get_apm_info (void);
/* Get VBE controller information. */
int get_vbe_controller_info (struct vbe_controller *controller);
/* Get VBE mode information. */
int get_vbe_mode_info (int mode_number, struct vbe_mode *mode);
/* Set VBE mode. */
int set_vbe_mode (int mode_number);
/* Return the data area immediately following our code. */
int get_code_end (void);
/* low-level timing info */
int getrtsecs (void);
/* Get current date and time */
void get_datetime(unsigned long *date, unsigned long *time);
#ifdef GRUB_UTIL
int currticks (void);
#else
#define currticks() (*(unsigned long *)0x46C)
#endif
/* Clear the screen. */
void cls (void);
/* Turn on/off cursor. */
int setcursor (int on);
/* Get the current cursor position (where 0,0 is the top left hand
corner of the screen). Returns packed values, (RET >> 8) is x,
(RET & 0xff) is y. */
int getxy (void);
/* Set the cursor position. */
void gotoxy (int x, int y);
/* Displays an ASCII character. IBM displays will translate some
characters to special graphical ones (see the DISP_* constants). */
void grub_putchar (int c);
/* Wait for a keypress, and return its packed BIOS/ASCII key code.
Use ASCII_CHAR(ret) to extract the ASCII code. */
int getkey (void);
/* Like GETKEY, but doesn't block, and returns -1 if no keystroke is
available. */
int checkkey (void);
/* Low-level disk I/O */
extern int biosdisk_int13_extensions (int ax, int drive, void *dap);
int get_cdinfo (int drive, struct geometry *geometry);
int get_diskinfo (int drive, struct geometry *geometry);
int biosdisk (int subfunc, int drive, struct geometry *geometry,
unsigned int sector, int nsec, int segment);
void stop_floppy (void);
/* Command-line interface functions. */
#ifndef STAGE1_5
/* The flags for the builtins. */
#define BUILTIN_CMDLINE 0x1 /* Run in the command-line. */
#define BUILTIN_MENU 0x2 /* Run in the menu. */
#define BUILTIN_TITLE 0x4 /* Only for the command title. */
#define BUILTIN_SCRIPT 0x8 /* Run in the script. */
#define BUILTIN_NO_ECHO 0x10 /* Don't print command on booting. */
#define BUILTIN_HELP_LIST 0x20 /* Show help in listing. */
#define BUILTIN_BOOTING 0x40 /* The command is boot-sensitive. */
#define BUILTIN_FUNCTION_FAIL 0
#define BUILTIN_FUNCTION_SUCCESS 1
/* The table for a builtin. */
struct builtin
{
/* The command name. */
char *name;
/* The callback function. */
int (*func) (char *, int);
/* The combination of the flags defined above. */
int flags;
/* The short version of the documentation. */
char *short_doc;
/* The long version of the documentation. */
char *long_doc;
};
/* All the builtins are registered in this. */
extern struct builtin *builtin_table[];
/* The constants for kernel types. */
typedef enum
{
KERNEL_TYPE_NONE, /* None is loaded. */
KERNEL_TYPE_MULTIBOOT, /* Multiboot. */
KERNEL_TYPE_LINUX, /* Linux. */
KERNEL_TYPE_BIG_LINUX, /* Big Linux. */
KERNEL_TYPE_FREEBSD, /* FreeBSD. */
KERNEL_TYPE_NETBSD, /* NetBSD. */
KERNEL_TYPE_CHAINLOADER, /* Chainloader. */
KERNEL_TYPE_CDROM
}
kernel_t;
extern kernel_t kernel_type;
extern int show_menu;
extern int silent_hiddenmenu;
#if !defined(STAGE1_5) && !defined(GRUB_UTIL)
extern char *mbr;
#endif
extern int grub_timeout;
char *skip_to (int after_equal, char *cmdline);
struct builtin *find_command (char *command);
void print_cmdline_message (int forever);
void enter_cmdline (char *heap, int forever);
#endif
/* C library replacement functions with identical semantics. */
//void grub_printf (const char *format,...);
#define grub_printf(...) grub_sprintf(NULL, __VA_ARGS__)
int grub_sprintf (char *buffer, const char *format, ...);
int grub_tolower (int c);
int grub_isspace (int c);
int grub_strncat (char *s1, const char *s2, int n);
void *grub_memcpy (void *to, const void *from, unsigned int n);
void *grub_memmove (void *to, const void *from, int len);
void *grub_memset (void *start, int c, int len);
int grub_strncat (char *s1, const char *s2, int n);
char *grub_strstr (const char *s1, const char *s2);
int grub_memcmp (const void *s1, const void *s2, int n);
int grub_strcmp (const char *s1, const char *s2);
int grub_strncmp (const char *s1, const char *s2, int n);
int grub_strlen (const char *str);
char *grub_strcpy (char *dest, const char *src);
char *grub_strchr (char *str, char c);
void noisy_printf (const char *format,...);
#ifndef GRUB_UTIL
typedef unsigned long grub_jmp_buf[6];
#else
/* In the grub shell, use the libc jmp_buf instead. */
# include <setjmp.h>
# define grub_jmp_buf jmp_buf
#endif
#ifdef GRUB_UTIL
# define grub_setjmp setjmp
# define grub_longjmp longjmp
#else /* ! GRUB_UTIL */
int grub_setjmp (grub_jmp_buf env);
void grub_longjmp (grub_jmp_buf env, int val);
extern unsigned long configfile_opened;
#endif /* ! GRUB_UTIL */
/* The environment for restarting Stage 2. */
extern grub_jmp_buf restart_env;
/* The environment for restarting the command-line interface. */
//extern grub_jmp_buf restart_cmdline_env;
/* misc */
void init_page (void);
void print_error (void);
char *convert_to_ascii (char *buf, int c, ...);
extern char *prompt;
extern int maxlen;
extern int echo_char;
extern int readline;
int get_cmdline (char *cmdline);
int substring (const char *s1, const char *s2, int case_insensitive);
int nul_terminate (char *str);
int get_based_digit (int c, int base);
//int safe_parse_maxuint (char **str_ptr, unsigned int *myint_ptr);
//int safe_parse_maxint (char **str_ptr, int *myint_ptr);
int safe_parse_int (char **, void *, int);
#define safe_parse_maxuint(s,i) safe_parse_int(s,i,0)
#define safe_parse_maxint(s,i) safe_parse_int(s,i,1)
int parse_string (char *arg);
int memcheck (unsigned long start, unsigned long len);
void grub_putstr (const char *str);
#ifndef NO_DECOMPRESSION
/* Compression support. */
int gunzip_test_header (void);
unsigned long gunzip_read (char *buf, unsigned long len);
#endif /* NO_DECOMPRESSION */
int rawread (unsigned long drive, unsigned long sector, unsigned long byte_offset, unsigned long byte_len, char *buf, unsigned long write);
int devread (unsigned long sector, unsigned long byte_offset, unsigned long byte_len, char *buf, unsigned long write);
int rawwrite (unsigned long drive, unsigned long sector, char *buf);
int devwrite (unsigned long sector, unsigned long sector_len, char *buf);
/* Parse a device string and initialize the global parameters. */
char *set_device (char *device);
int open_device (void);
//char *setup_part (char *filename);
int real_open_partition (int flags);
int open_partition (void);
int next_partition (void);
//int next_partition (unsigned long drive, unsigned long dest,
// unsigned long *partition, int *type,
// unsigned long *start, unsigned long *len,
// unsigned long *offset, int *entry,
// unsigned long *ext_offset, char *buf);
/* Sets device to the one represented by the SAVED_* parameters. */
//int make_saved_active (int status_only);
/* Set or clear the current root partition's hidden flag. */
//int set_partition_hidden_flag (int hidden);
/* Open a file or directory on the active device, using GRUB's
internal filesystem support. */
int grub_open (char *filename);
/* Read LEN bytes into BUF from the file that was opened with
GRUB_OPEN. If LEN is -1, read all the remaining data in the file. */
unsigned long grub_read (void *buf, unsigned long len, unsigned long write);
/* Reposition a file offset. */
unsigned long grub_seek (unsigned long offset);
/* Close a file. */
void grub_close (void);
/* List the contents of the directory that was opened with GRUB_OPEN,
printing all completions. */
//int dir (char *dirname);
int set_bootdev (int hdbias);
/* Display statistics on the current active device. */
void print_fsys_type (void);
/* Display device and filename completions. */
void print_a_completion (char *filename);
int print_completions (int is_filename, int is_completion);
/* Copies the current partition data to the desired address. */
void copy_current_part_entry (char *buf);
#ifndef STAGE1_5
void bsd_boot (kernel_t type, int bootdev, char *arg)
__attribute__ ((noreturn));
/* Define flags for load_image here. */
/* Don't pass a Linux's mem option automatically. */
#define KERNEL_LOAD_NO_MEM_OPTION (1 << 0)
kernel_t load_image (char *kernel, char *arg, kernel_t suggested_type,
unsigned long load_flags);
int load_module (char *module, char *arg);
int load_initrd (char *initrd);
int check_password(char *entered, char* expected, password_t type);
#endif
void init_bios_info (void);
struct master_and_dos_boot_sector {
/* 00 */ char dummy1[0x0b]; /* at offset 0, normally there is a short JMP instuction(opcode is 0xEB) */
/* 0B */ unsigned short bytes_per_sector __attribute__ ((packed));/* seems always to be 512, so we just use 512 */
/* 0D */ unsigned char sectors_per_cluster;/* non-zero, the power of 2, i.e., 2^n */
/* 0E */ unsigned short reserved_sectors __attribute__ ((packed));/* FAT=non-zero, NTFS=0? */
/* 10 */ unsigned char number_of_fats;/* NTFS=0; FAT=1 or 2 */
/* 11 */ unsigned short root_dir_entries __attribute__ ((packed));/* FAT32=0, NTFS=0, FAT12/16=non-zero */
/* 13 */ unsigned short total_sectors_short __attribute__ ((packed));/* FAT32=0, NTFS=0, FAT12/16=any */
/* 15 */ unsigned char media_descriptor;/* range from 0xf0 to 0xff */
/* 16 */ unsigned short sectors_per_fat __attribute__ ((packed));/* FAT32=0, NTFS=0, FAT12/16=non-zero */
/* 18 */ unsigned short sectors_per_track __attribute__ ((packed));/* range from 1 to 63 */
/* 1A */ unsigned short total_heads __attribute__ ((packed));/* range from 1 to 256 */
/* 1C */ unsigned long hidden_sectors __attribute__ ((packed));/* any value */
/* 20 */ unsigned long total_sectors_long __attribute__ ((packed));/* FAT32=non-zero, NTFS=0, FAT12/16=any */
/* 24 */ unsigned long sectors_per_fat32 __attribute__ ((packed));/* FAT32=non-zero, NTFS=any, FAT12/16=any */
/* 28 */ unsigned long long total_sectors_long_long __attribute__ ((packed));/* NTFS=non-zero, FAT12/16/32=any */
/* 30 */ char dummy2[0x18e];
/* Partition Table, starting at offset 0x1BE */
/* 1BE */ struct {
/* +00 */ unsigned char boot_indicator;
/* +01 */ unsigned char start_head;
/* +02 */ unsigned short start_sector_cylinder __attribute__ ((packed));
/* +04 */ unsigned char system_indicator;
/* +05 */ unsigned char end_head;
/* +06 */ unsigned short end_sector_cylinder __attribute__ ((packed));
/* +08 */ unsigned long start_lba __attribute__ ((packed));
/* +0C */ unsigned long total_sectors __attribute__ ((packed));
/* +10 */
} P[4];
/* 1FE */ unsigned short boot_signature __attribute__ ((packed));/* 0xAA55 */
#if 0
/* This starts at offset 0x200 */
/* 200 */ unsigned long probed_total_sectors __attribute__ ((packed));
/* 204 */ unsigned long probed_heads __attribute__ ((packed));
/* 208 */ unsigned long probed_sectors_per_track __attribute__ ((packed));
/* 20C */ unsigned long probed_cylinders __attribute__ ((packed));
/* 210 */ unsigned long sectors_per_cylinder __attribute__ ((packed));
/* 214 */ char dummy3[0x0c] __attribute__ ((packed));
/* matrix of coefficients of linear equations
*
* C[n] * (H_count * S_count) + H[n] * S_count = LBA[n] - S[n] + 1
*
* where n = 1, 2, 3, 4, 5, 6, 7, 8
*/
/* This starts at offset 0x130 */
/* 220 */ long long L[9] __attribute__ ((packed)); /* L[n] == LBA[n] - S[n] + 1 */
/* 268 */ long H[9] __attribute__ ((packed));
/* 28C */ short C[9] __attribute__ ((packed));
/* 29E */ short X __attribute__ ((packed));
/* 2A0 */ short Y __attribute__ ((packed));
/* 2A2 */ short Cmax __attribute__ ((packed));
/* 2A4 */ long Hmax __attribute__ ((packed));
/* 2A8 */ unsigned long Z __attribute__ ((packed));
/* 2AC */ short Smax __attribute__ ((packed));
/* 2AE */
#endif
};
extern unsigned long probed_total_sectors;
extern unsigned long probed_heads;
extern unsigned long probed_sectors_per_track;
extern unsigned long probed_cylinders;
extern unsigned long sectors_per_cylinder;
extern int filesystem_type;
extern unsigned long bios_id; /* 1 for bochs, 0 for unknown. */
int probe_bpb (struct master_and_dos_boot_sector *BS);
int probe_mbr (struct master_and_dos_boot_sector *BS, unsigned long start_sector1, unsigned long sector_count1, unsigned long part_start1);
extern int check_int13_extensions (int drive);
struct drive_parameters
{
unsigned short size;
unsigned short flags;
unsigned long cylinders;
unsigned long heads;
unsigned long sectors;
unsigned long long total_sectors;
unsigned short bytes_per_sector;
/* ver 2.0 or higher */
unsigned long EDD_configuration_parameters;
/* ver 3.0 or higher */
unsigned short signature_dpi;
unsigned char length_dpi;
unsigned char reserved[3];
unsigned char name_of_host_bus[4];
unsigned char name_of_interface_type[8];
unsigned char interface_path[8];
unsigned char device_path[8];
unsigned char reserved2;
unsigned char checksum;
/* XXX: This is necessary, because the BIOS of Thinkpad X20
writes a garbage to the tail of drive parameters,
regardless of a size specified in a caller. */
unsigned char dummy[16];
} __attribute__ ((packed));
int check_64bit (void);
extern int is64bit;
extern int errorcheck;
extern unsigned long pxe_restart_config;
extern unsigned long saved_pxe_ip;
extern unsigned char saved_pxe_mac[6];
#ifdef FSYS_PXE
#include "pxe.h"
extern UINT8 pxe_mac_len, pxe_mac_type;
extern MAC_ADDR pxe_mac;
extern IP4 pxe_yip, pxe_sip, pxe_gip;
extern unsigned long pxe_keep;
extern BOOTPLAYER *discover_reply;
extern unsigned short pxe_basemem, pxe_freemem;
extern unsigned long pxe_entry;
extern unsigned long pxe_inited;
extern char* pxe_scan(void);
extern int pxe_detect(int, char *);
extern void pxe_unload(void);
extern int pxe_call(int func,void* data);
#if PXE_FAST_READ
extern int pxe_fast_read(void* data,int num);
#endif
int pxe_func(char* arg,int flags);
#else /* ! FSYS_PXE */
#define pxe_detect()
#endif /* FSYS_PXE */
extern unsigned long fb_status;
#endif /* ! ASM_FILE */
#endif /* ! GRUB_SHARED_HEADER */