1 /* -*- linux-c -*- ------------------------------------------------------- *
 
   3  *   Copyright (C) 1991, 1992 Linus Torvalds
 
   4  *   Copyright 2007 rPath, Inc. - All Rights Reserved
 
   6  *   This file is part of the Linux kernel, and is made available under
 
   7  *   the terms of the GNU General Public License version 2.
 
   9  * ----------------------------------------------------------------------- */
 
  12  * arch/i386/boot/main.c
 
  14  * Main module for the real-mode kernel code
 
  19 struct boot_params boot_params __attribute__((aligned(16)));
 
  22 char *heap_end = _end;          /* Default end of heap = no heap */
 
  25  * Copy the header into the boot parameter block.  Since this
 
  26  * screws up the old-style command line protocol, adjust by
 
  27  * filling in the new-style command line pointer instead.
 
  29 #define OLD_CL_MAGIC    0xA33F
 
  30 #define OLD_CL_ADDRESS  0x20
 
  32 static void copy_boot_params(void)
 
  38         const struct old_cmdline * const oldcmd =
 
  39                 (const struct old_cmdline *)OLD_CL_ADDRESS;
 
  41         BUILD_BUG_ON(sizeof boot_params != 4096);
 
  42         memcpy(&boot_params.hdr, &hdr, sizeof hdr);
 
  44         if (!boot_params.hdr.cmd_line_ptr &&
 
  45             oldcmd->cl_magic == OLD_CL_MAGIC) {
 
  46                 /* Old-style command line protocol. */
 
  49                 /* Figure out if the command line falls in the region
 
  50                    of memory that an old kernel would have copied up
 
  52                 if (oldcmd->cl_offset < boot_params.hdr.setup_move_size)
 
  57                 boot_params.hdr.cmd_line_ptr =
 
  58                         (cmdline_seg << 4) + oldcmd->cl_offset;
 
  63  * Set the keyboard repeat rate to maximum.  Unclear why this
 
  64  * is done here; this might be possible to kill off as stale code.
 
  66 static void keyboard_set_repeat(void)
 
  70         asm volatile("int $0x16"
 
  71                      : "+a" (ax), "+b" (bx)
 
  72                      : : "ecx", "edx", "esi", "edi");
 
  76  * Get Intel SpeedStep IST information.
 
  78 static void query_speedstep_ist(void)
 
  81             : "=a" (boot_params.speedstep_info[0]),
 
  82               "=b" (boot_params.speedstep_info[1]),
 
  83               "=c" (boot_params.speedstep_info[2]),
 
  84               "=d" (boot_params.speedstep_info[3])
 
  85             : "a" (0x0000e980),  /* IST Support */
 
  86               "d" (0x47534943)); /* Request value */
 
  90  * Tell the BIOS what CPU mode we intend to run in.
 
  92 static void set_bios_mode(void)
 
  99         asm volatile("int $0x15"
 
 100                      : "+a" (eax), "+b" (ebx)
 
 101                      : : "ecx", "edx", "esi", "edi");
 
 107         /* First, copy the boot header into the "zeropage" */
 
 110         /* End of heap check */
 
 111         if (boot_params.hdr.loadflags & CAN_USE_HEAP) {
 
 112                 heap_end = (char *)(boot_params.hdr.heap_end_ptr
 
 115                 /* Boot protocol 2.00 only, no heap available */
 
 116                 puts("WARNING: Ancient bootloader, some functionality "
 
 117                      "may be limited!\n");
 
 120         /* Make sure we have all the proper CPU support */
 
 121         if (validate_cpu()) {
 
 122                 puts("Unable to boot - please use a kernel appropriate "
 
 127         /* Tell the BIOS what CPU mode we intend to run in. */
 
 130         /* Detect memory layout */
 
 133         /* Set keyboard repeat rate (why?) */
 
 134         keyboard_set_repeat();
 
 136         /* Set the video mode */
 
 139         /* Query MCA information */
 
 143 #ifdef CONFIG_X86_VOYAGER
 
 147         /* Query SpeedStep IST information */
 
 148         query_speedstep_ist();
 
 150         /* Query APM information */
 
 151 #if defined(CONFIG_APM) || defined(CONFIG_APM_MODULE)
 
 155         /* Query EDD information */
 
 156 #if defined(CONFIG_EDD) || defined(CONFIG_EDD_MODULE)
 
 159         /* Do the last things and invoke protected mode */
 
 160         go_to_protected_mode();