/* ----------------------------------------------------------------------- *
*
* Copyright 2009 Erwan Velu - All Rights Reserved
*
* Permission is hereby granted, free of charge, to any person
* obtaining a copy of this software and associated documentation
* files (the "Software"), to deal in the Software without
* restriction, including without limitation the rights to use,
* copy, modify, merge, publish, distribute, sublicense, and/or
* sell copies of the Software, and to permit persons to whom
* the Software is furnished to do so, subject to the following
* conditions:
*
* The above copyright notice and this permission notice shall
* be included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*
* -----------------------------------------------------------------------
*/
#ifndef DEFINE_HDT_COMMON_H
#define DEFINE_HDT_COMMON_H
#include <stdio.h>
#include <syslinux/pxe.h>
#include <console.h>
#include <consoles.h>
#include <syslinux/vesacon.h>
#include "sys/pci.h"
#include <disk/bootloaders.h>
#include <disk/errno_disk.h>
#include <disk/error.h>
#include <disk/geom.h>
#include <disk/mbrs.h>
#include <disk/msdos.h>
#include <disk/partition.h>
#include <disk/swsusp.h>
#include <disk/read.h>
#include "cpuid.h"
#include "dmi/dmi.h"
#include "hdt-ata.h"
#include <lib/sys/vesa/vesa.h>
#include <vpd/vpd.h>
#include <libansi.h>
#include <acpi/acpi.h>
#include <libupload/upload_backend.h>
/* This two values are used for switching for the menu to the CLI mode */
#define HDT_SWITCH_TO_CLI "hdt_switch_to_cli"
#define HDT_DUMP "hdt_dump"
#define HDT_RETURN_TO_CLI 100
#define MAX_VESA_MODES 255
/* This value is used for rebooting from the menu mode */
#define HDT_REBOOT "hdt_reboot"
/* The maximum number of commands we can process */
#define MAX_NB_AUTO_COMMANDS 255
/* The maximum size of a command */
#define AUTO_COMMAND_SIZE 255
/* The char that separate two commands */
#define AUTO_SEPARATOR ";"
/* The char that surround the list of commands */
#define AUTO_DELIMITER '\''
/* Graphic to load in background when using the vesa mode */
#define CLI_DEFAULT_BACKGROUND "backgnd.png"
/* The maximum number of lines */
#define MAX_CLI_LINES 20
#define MAX_VESA_CLI_LINES 24
struct upload_backend *upload;
/* Defines if the cli is quiet*/
bool quiet;
/* Defines if the cli is totally silent*/
bool silent;
/* Defines if we must use the vesa mode */
bool vesamode;
/* Defines if we must use the menu mode */
bool menumode;
/* Defines if we are running the auto mode */
bool automode;
/* Defines the number of lines in the console
* Default is 20 for a std console */
extern int max_console_lines;
extern int display_line_nb;
extern bool disable_more_printf;
#define pause_printf() do {\
printf("--More--");\
get_key(stdin, 0);\
printf("\033[2K\033[1G\033[1F\n");\
} while (0);
/* The brokeness of that macro is that
* it assumes that __VA_ARGS__ contains
* one \n (and only one)
*/
#define more_printf(...) do {\
if (__likely(!silent)) {\
if (__likely(!disable_more_printf)) {\
if (display_line_nb == max_console_lines) {\
display_line_nb=0;\
printf("\n--More--");\
get_key(stdin, 0);\
printf("\033[2K\033[1G\033[1F");\
}\
display_line_nb++;\
}\
printf(__VA_ARGS__);\
}\
} while (0);
/* Display CPU registers for debugging purposes */
static inline void printregs(const com32sys_t * r)
{
printf("eflags = %08x ds = %04x es = %04x fs = %04x gs = %04x\n"
"eax = %08x ebx = %08x ecx = %08x edx = %08x\n"
"ebp = %08x esi = %08x edi = %08x esp = %08x\n",
r->eflags.l, r->ds, r->es, r->fs, r->gs,
r->eax.l, r->ebx.l, r->ecx.l, r->edx.l,
r->ebp.l, r->esi.l, r->edi.l, r->_unused_esp.l);
}
struct s_pxe {
uint16_t vendor_id;
uint16_t product_id;
uint16_t subvendor_id;
uint16_t subproduct_id;
uint8_t rev;
uint8_t pci_bus;
uint8_t pci_dev;
uint8_t pci_func;
uint8_t base_class;
uint8_t sub_class;
uint8_t prog_intf;
uint8_t nictype;
char mac_addr[18]; /* The current mac address */
uint8_t ip_addr[4];
pxe_bootp_t dhcpdata; /* The dhcp answer */
struct pci_device *pci_device; /* The matching pci device */
uint8_t pci_device_pos; /* It position in our pci sorted list */
};
struct s_vesa_mode_info {
struct vesa_mode_info mi;
uint16_t mode;
};
struct s_vesa {
uint8_t major_version;
uint8_t minor_version;
struct s_vesa_mode_info vmi[MAX_VESA_MODES];
uint8_t vmi_count;
uint16_t total_memory;
char vendor[256];
char product[256];
char product_revision[256];
uint16_t software_rev;
};
struct s_hardware {
s_dmi dmi; /* DMI table */
s_cpu cpu; /* CPU information */
uint8_t physical_cpu_count; /* Number of physical cpu */
s_vpd vpd; /* VPD information */
s_acpi acpi;
struct pci_domain *pci_domain; /* PCI Devices */
struct driveinfo disk_info[256]; /* Disk Information */
uint32_t mbr_ids[256]; /* MBR ids */
int disks_count; /* Number of detected disks */
struct s_pxe pxe;
struct s_vesa vesa;
unsigned long detected_memory_size; /* The detected memory size (in KB) */
int pci_ids_return_code;
int modules_pcimap_return_code;
int modules_alias_return_code;
int nb_pci_devices;
bool is_dmi_valid;
bool is_pxe_valid;
bool is_vesa_valid;
bool is_vpd_valid;
bool is_acpi_valid;
bool dmi_detection; /* Does the dmi stuff has already been detected? */
bool pci_detection; /* Does the pci stuff has already been detected? */
bool cpu_detection; /* Does the cpu stuff has already been detected? */
bool disk_detection; /* Does the disk stuff has already been detected? */
bool pxe_detection; /* Does the pxe stuff has already been detected? */
bool vesa_detection; /* Does the vesa sutff have been already detected? */
bool vpd_detection; /* Does the vpd stuff has already been detected? */
bool memory_detection; /* Does the memory size got detected ?*/
bool acpi_detection; /* Does the acpi got detected ?*/
char syslinux_fs[22];
const struct syslinux_version *sv;
char modules_pcimap_path[255];
char modules_alias_path[255];
char pciids_path[255];
char dump_path[255]; /* Dump path on the tftp server */
char dump_filename[255]; /* Dump filename on the tftp server */
char tftp_ip[255]; /* IP address of tftp server (dump mode) */
char memtest_label[255];
char auto_label[AUTO_COMMAND_SIZE];
char vesa_background[255];
char postexec[255];
};
void reset_more_printf(void);
const char *find_argument(const char **argv, const char *argument);
char *remove_spaces(char *p);
char *remove_trailing_lf(char *p);
char *skip_spaces(char *p);
char *del_multi_spaces(char *p);
int detect_dmi(struct s_hardware *hardware);
int detect_vpd(struct s_hardware *hardware);
void detect_disks(struct s_hardware *hardware);
void detect_pci(struct s_hardware *hardware);
void cpu_detect(struct s_hardware *hardware);
int detect_pxe(struct s_hardware *hardware);
void init_hardware(struct s_hardware *hardware);
void clear_screen(void);
void detect_syslinux(struct s_hardware *hardware);
int detect_acpi(struct s_hardware *hardware);
void detect_parameters(const int argc, const char *argv[],
struct s_hardware *hardware);
int detect_vesa(struct s_hardware *hardware);
void detect_memory(struct s_hardware *hardware);
void init_console(struct s_hardware *hardware);
void detect_hardware(struct s_hardware *hardware);
void dump(struct s_hardware *hardware);
#endif