usr/src/grub/grub-0.97/stage2/common.c
author William Kucharski <William.Kucharski@Sun.COM>
Thu, 11 Dec 2008 21:46:13 -0700
changeset 8352 af83fb61a268
parent 8044 b3af80bbf173
permissions -rw-r--r--
6775099 GRUB: splashimage failure does not reset screen properly 6779026 GRUB: XPM color parsing code should be a little smarter 6779852 GRUB: menu.lst processing is broken
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     1
/* common.c - miscellaneous shared variables and routines */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     2
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     3
 *  GRUB  --  GRand Unified Bootloader
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     4
 *  Copyright (C) 1999,2000,2001,2002,2004  Free Software Foundation, Inc.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     5
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     6
 *  This program is free software; you can redistribute it and/or modify
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     7
 *  it under the terms of the GNU General Public License as published by
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     8
 *  the Free Software Foundation; either version 2 of the License, or
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
     9
 *  (at your option) any later version.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    10
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    11
 *  This program is distributed in the hope that it will be useful,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    12
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    13
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    14
 *  GNU General Public License for more details.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    15
 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    16
 *  You should have received a copy of the GNU General Public License
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    17
 *  along with this program; if not, write to the Free Software
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    18
 *  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    19
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    20
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    21
#include <shared.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    22
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    23
#ifdef SUPPORT_NETBOOT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    24
#include <grub.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    25
#include <bootp.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    26
#endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    27
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    28
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    29
 *  Shared BIOS/boot data.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    30
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    31
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    32
struct multiboot_info mbi;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    33
unsigned long saved_drive;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    34
unsigned long saved_partition;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    35
unsigned long cdrom_drive;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    36
#ifndef STAGE1_5
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    37
#ifdef SOLARIS_NETBOOT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    38
unsigned long dhcpack_length;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    39
unsigned long dhcpack_buf;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    40
#endif /* SOLARIS_NETBOOT */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    41
unsigned long saved_mem_upper;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    42
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    43
/* This saves the maximum size of extended memory (in KB).  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    44
unsigned long extended_memory;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    45
#endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    46
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    47
/*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    48
 *  Error code stuff.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    49
 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    50
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    51
grub_error_t errnum = ERR_NONE;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    52
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    53
#ifndef STAGE1_5
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    54
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    55
char *err_list[] =
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    56
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    57
  [ERR_NONE] = 0,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    58
  [ERR_BAD_ARGUMENT] = "Invalid argument",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    59
  [ERR_BAD_FILENAME] =
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    60
  "Filename must be either an absolute pathname or blocklist",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    61
  [ERR_BAD_FILETYPE] = "Bad file or directory type",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    62
  [ERR_BAD_GZIP_DATA] = "Bad or corrupt data while decompressing file",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    63
  [ERR_BAD_GZIP_HEADER] = "Bad or incompatible header in compressed file",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    64
  [ERR_BAD_PART_TABLE] = "Partition table invalid or corrupt",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    65
  [ERR_BAD_VERSION] = "Mismatched or corrupt version of stage1/stage2",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    66
  [ERR_BELOW_1MB] = "Loading below 1MB is not supported",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    67
  [ERR_BOOT_COMMAND] = "Kernel must be loaded before booting",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    68
  [ERR_BOOT_FAILURE] = "Unknown boot failure",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    69
  [ERR_BOOT_FEATURES] = "Unsupported Multiboot features requested",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    70
  [ERR_DEV_FORMAT] = "Unrecognized device string",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    71
  [ERR_DEV_NEED_INIT] = "Device not initialized yet",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    72
  [ERR_DEV_VALUES] = "Invalid device requested",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    73
  [ERR_EXEC_FORMAT] = "Invalid or unsupported executable format",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    74
  [ERR_FILELENGTH] =
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    75
  "Filesystem compatibility error, cannot read whole file",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    76
  [ERR_FILE_NOT_FOUND] = "File not found",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    77
  [ERR_FSYS_CORRUPT] = "Inconsistent filesystem structure",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    78
  [ERR_FSYS_MOUNT] = "Cannot mount selected partition",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    79
  [ERR_GEOM] = "Selected cylinder exceeds maximum supported by BIOS",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    80
  [ERR_NEED_LX_KERNEL] = "Linux kernel must be loaded before initrd",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    81
  [ERR_NEED_MB_KERNEL] = "Multiboot kernel must be loaded before modules",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    82
  [ERR_NO_DISK] = "Selected disk does not exist",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    83
  [ERR_NO_DISK_SPACE] = "No spare sectors on the disk",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    84
  [ERR_NO_PART] = "No such partition",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    85
  [ERR_NUMBER_OVERFLOW] = "Overflow while parsing number",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    86
  [ERR_NUMBER_PARSING] = "Error while parsing number",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    87
  [ERR_OUTSIDE_PART] = "Attempt to access block outside partition",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    88
  [ERR_PRIVILEGED] = "Must be authenticated",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    89
  [ERR_READ] = "Disk read error",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    90
  [ERR_SYMLINK_LOOP] = "Too many symbolic links",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    91
  [ERR_UNALIGNED] = "File is not sector aligned",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    92
  [ERR_UNRECOGNIZED] = "Unrecognized command",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    93
  [ERR_WONT_FIT] = "Selected item cannot fit into memory",
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
    94
  [ERR_WRITE] = "Disk write error",
3912
f6891a60bd72 PSARC 2007/083 ZFS bootable datasets
lling
parents: 2215
diff changeset
    95
  [ERR_BAD_GZIP_CRC] = "Incorrect gunzip CRC checksum",
6423
437422a29d3a PSARC 2006/370 ZFS Boot Support
gw25295
parents: 3912
diff changeset
    96
  [ERR_FILESYSTEM_NOT_FOUND] = "File System not found",
3912
f6891a60bd72 PSARC 2007/083 ZFS bootable datasets
lling
parents: 2215
diff changeset
    97
    /* this zfs file system is not found in the pool of the device */
7300
3f0c3af330d3 6667976 support booting up a snapshot root dataset
Eric Taylor <Eric.Taylor@Sun.COM>
parents: 6423
diff changeset
    98
  [ERR_NO_BOOTPATH] = "No valid boot path found in the zfs label. This may be caused by attempting to boot from an off-lined device.",
8352
af83fb61a268 6775099 GRUB: splashimage failure does not reset screen properly
William Kucharski <William.Kucharski@Sun.COM>
parents: 8044
diff changeset
    99
  [ERR_NEWER_VERSION] = "Newer on-disk pool version",
af83fb61a268 6775099 GRUB: splashimage failure does not reset screen properly
William Kucharski <William.Kucharski@Sun.COM>
parents: 8044
diff changeset
   100
  [ERR_NOTXPM] = "Image not in XPM graphics format",
af83fb61a268 6775099 GRUB: splashimage failure does not reset screen properly
William Kucharski <William.Kucharski@Sun.COM>
parents: 8044
diff changeset
   101
  [ERR_TOOMANYCOLORS] = "Image cannot use more than 14 colors",
af83fb61a268 6775099 GRUB: splashimage failure does not reset screen properly
William Kucharski <William.Kucharski@Sun.COM>
parents: 8044
diff changeset
   102
  [ERR_CORRUPTXPM] = "File contains corrupt XPM image data"
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   103
};
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   104
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   105
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   106
/* static for BIOS memory map fakery */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   107
static struct AddrRangeDesc fakemap[3] =
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   108
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   109
  {20, 0, 0, MB_ARD_MEMORY},
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   110
  {20, 0x100000, 0, MB_ARD_MEMORY},
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   111
  {20, 0x1000000, 0, MB_ARD_MEMORY}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   112
};
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   113
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   114
/* A big problem is that the memory areas aren't guaranteed to be:
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   115
   (1) contiguous, (2) sorted in ascending order, or (3) non-overlapping.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   116
   Thus this kludge.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   117
static unsigned long
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   118
mmap_avail_at (unsigned long bottom)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   119
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   120
  unsigned long long top;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   121
  unsigned long addr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   122
  int cont;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   123
  
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   124
  top = bottom;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   125
  do
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   126
    {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   127
      for (cont = 0, addr = mbi.mmap_addr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   128
	   addr < mbi.mmap_addr + mbi.mmap_length;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   129
	   addr += *((unsigned long *) addr) + 4)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   130
	{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   131
	  struct AddrRangeDesc *desc = (struct AddrRangeDesc *) addr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   132
	  
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   133
	  if (desc->Type == MB_ARD_MEMORY
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   134
	      && desc->BaseAddr <= top
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   135
	      && desc->BaseAddr + desc->Length > top)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   136
	    {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   137
	      top = desc->BaseAddr + desc->Length;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   138
	      cont++;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   139
	    }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   140
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   141
    }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   142
  while (cont);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   143
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   144
  /* For now, GRUB assumes 32bits addresses, so...  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   145
  if (top > 0xFFFFFFFF)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   146
    top = 0xFFFFFFFF;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   147
  
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   148
  return (unsigned long) top - bottom;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   149
}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   150
#endif /* ! STAGE1_5 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   151
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   152
/* This queries for BIOS information.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   153
void
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   154
init_bios_info (void)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   155
{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   156
#ifndef STAGE1_5
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   157
  unsigned long cont, memtmp, addr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   158
  int drive;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   159
#endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   160
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   161
  /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   162
   *  Get information from BIOS on installed RAM.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   163
   */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   164
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   165
  mbi.mem_lower = get_memsize (0);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   166
  mbi.mem_upper = get_memsize (1);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   167
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   168
#ifndef STAGE1_5
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   169
  /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   170
   *  We need to call this somewhere before trying to put data
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   171
   *  above 1 MB, since without calling it, address line 20 will be wired
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   172
   *  to 0.  Not too desirable.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   173
   */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   174
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   175
  gateA20 (1);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   176
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   177
  /* Store the size of extended memory in EXTENDED_MEMORY, in order to
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   178
     tell it to non-Multiboot OSes.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   179
  extended_memory = mbi.mem_upper;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   180
  
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   181
  /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   182
   *  The "mbi.mem_upper" variable only recognizes upper memory in the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   183
   *  first memory region.  If there are multiple memory regions,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   184
   *  the rest are reported to a Multiboot-compliant OS, but otherwise
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   185
   *  unused by GRUB.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   186
   */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   187
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   188
  addr = get_code_end ();
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   189
  mbi.mmap_addr = addr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   190
  mbi.mmap_length = 0;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   191
  cont = 0;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   192
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   193
  do
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   194
    {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   195
      cont = get_mmap_entry ((void *) addr, cont);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   196
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   197
      /* If the returned buffer's length is zero, quit. */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   198
      if (! *((unsigned long *) addr))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   199
	break;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   200
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   201
      mbi.mmap_length += *((unsigned long *) addr) + 4;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   202
      addr += *((unsigned long *) addr) + 4;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   203
    }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   204
  while (cont);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   205
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   206
  if (mbi.mmap_length)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   207
    {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   208
      unsigned long long max_addr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   209
      
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   210
      /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   211
       *  This is to get the lower memory, and upper memory (up to the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   212
       *  first memory hole), into the "mbi.mem_{lower,upper}"
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   213
       *  elements.  This is for OS's that don't care about the memory
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   214
       *  map, but might care about total RAM available.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   215
       */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   216
      mbi.mem_lower = mmap_avail_at (0) >> 10;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   217
      mbi.mem_upper = mmap_avail_at (0x100000) >> 10;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   218
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   219
      /* Find the maximum available address. Ignore any memory holes.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   220
      for (max_addr = 0, addr = mbi.mmap_addr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   221
	   addr < mbi.mmap_addr + mbi.mmap_length;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   222
	   addr += *((unsigned long *) addr) + 4)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   223
	{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   224
	  struct AddrRangeDesc *desc = (struct AddrRangeDesc *) addr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   225
	  
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   226
	  if (desc->Type == MB_ARD_MEMORY && desc->Length > 0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   227
	      && desc->BaseAddr + desc->Length > max_addr)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   228
	    max_addr = desc->BaseAddr + desc->Length;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   229
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   230
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   231
      extended_memory = (max_addr - 0x100000) >> 10;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   232
    }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   233
  else if ((memtmp = get_eisamemsize ()) != -1)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   234
    {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   235
      cont = memtmp & ~0xFFFF;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   236
      memtmp = memtmp & 0xFFFF;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   237
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   238
      if (cont != 0)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   239
	extended_memory = (cont >> 10) + 0x3c00;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   240
      else
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   241
	extended_memory = memtmp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   242
      
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   243
      if (!cont || (memtmp == 0x3c00))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   244
	memtmp += (cont >> 10);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   245
      else
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   246
	{
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   247
	  /* XXX should I do this at all ??? */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   248
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   249
	  mbi.mmap_addr = (unsigned long) fakemap;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   250
	  mbi.mmap_length = sizeof (fakemap);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   251
	  fakemap[0].Length = (mbi.mem_lower << 10);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   252
	  fakemap[1].Length = (memtmp << 10);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   253
	  fakemap[2].Length = cont;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   254
	}
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   255
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   256
      mbi.mem_upper = memtmp;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   257
    }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   258
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   259
  saved_mem_upper = mbi.mem_upper;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   260
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   261
#ifdef SUPPORT_NETBOOT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   262
#ifdef SOLARIS_NETBOOT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   263
  /* leave room for dhcpack_buf */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   264
  dhcpack_buf = addr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   265
  addr += sizeof (struct dhcp_t);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   266
#endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   267
#endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   268
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   269
  /* Get the drive info.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   270
  /* FIXME: This should be postponed until a Multiboot kernel actually
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   271
     requires it, because this could slow down the start-up
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   272
     unreasonably.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   273
  mbi.drives_length = 0;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   274
  mbi.drives_addr = addr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   275
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   276
  /* For now, GRUB doesn't probe floppies, since it is trivial to map
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   277
     floppy drives to BIOS drives.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   278
  for (drive = 0x80; drive < 0x88; drive++)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   279
    {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   280
      struct geometry geom;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   281
      struct drive_info *info = (struct drive_info *) addr;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   282
      unsigned short *port;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   283
      
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   284
      /* Get the geometry. This ensures that the drive is present.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   285
      if (get_diskinfo (drive, &geom))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   286
	break;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   287
      
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   288
      /* Clean out the I/O map.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   289
      grub_memset ((char *) io_map, 0,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   290
		   IO_MAP_SIZE * sizeof (unsigned short));
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   291
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   292
      /* Disable to probe I/O ports temporarily, because this doesn't
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   293
	 work with some BIOSes (maybe they are too buggy).  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   294
#if 0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   295
      /* Track the int13 handler.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   296
      track_int13 (drive);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   297
#endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   298
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   299
      /* Set the information.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   300
      info->drive_number = drive;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   301
      info->drive_mode = ((geom.flags & BIOSDISK_FLAG_LBA_EXTENSION)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   302
			  ? MB_DI_LBA_MODE : MB_DI_CHS_MODE);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   303
      info->drive_cylinders = geom.cylinders;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   304
      info->drive_heads = geom.heads;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   305
      info->drive_sectors = geom.sectors;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   306
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   307
      addr += sizeof (struct drive_info);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   308
      for (port = io_map; *port; port++, addr += sizeof (unsigned short))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   309
	*((unsigned short *) addr) = *port;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   310
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   311
      info->size = addr - (unsigned long) info;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   312
      mbi.drives_length += info->size;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   313
    }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   314
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   315
  /* Get the ROM configuration table by INT 15, AH=C0h.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   316
  mbi.config_table = get_rom_config_table ();
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   317
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   318
  /* Set the boot loader name.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   319
  mbi.boot_loader_name = (unsigned long) "GNU GRUB " VERSION;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   320
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   321
  /* Get the APM BIOS table.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   322
  get_apm_info ();
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   323
  if (apm_bios_info.version)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   324
    mbi.apm_table = (unsigned long) &apm_bios_info;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   325
  
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   326
  /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   327
   *  Initialize other Multiboot Info flags.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   328
   */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   329
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   330
  mbi.flags = (MB_INFO_MEMORY | MB_INFO_CMDLINE | MB_INFO_BOOTDEV
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   331
	       | MB_INFO_DRIVE_INFO | MB_INFO_CONFIG_TABLE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   332
	       | MB_INFO_BOOT_LOADER_NAME);
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   333
  
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   334
  if (apm_bios_info.version)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   335
    mbi.flags |= MB_INFO_APM_TABLE;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   336
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   337
#endif /* STAGE1_5 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   338
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   339
  /* Set boot drive and partition.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   340
  saved_drive = boot_drive;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   341
  saved_partition = install_partition;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   342
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   343
  /* Set cdrom drive.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   344
  {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   345
    struct geometry geom;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   346
    
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   347
    /* Get the geometry.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   348
    if (get_diskinfo (boot_drive, &geom)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   349
	|| ! (geom.flags & BIOSDISK_FLAG_CDROM))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   350
      cdrom_drive = GRUB_INVALID_DRIVE;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   351
    else
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   352
      cdrom_drive = boot_drive;
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   353
  }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   354
  
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   355
  /* Start main routine here.  */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   356
  cmain ();
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
   357
}