Subversion Repositories shark

Rev

Rev 1688 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
2 pj 1
/* Project:     OSLib
2
 * Description: The OS Construction Kit
3
 * Date:                1.6.2000
4
 * Idea by:             Luca Abeni & Gerardo Lamastra
5
 *
6
 * OSLib is an SO project aimed at developing a common, easy-to-use
7
 * low-level infrastructure for developing OS kernels and Embedded
8
 * Applications; it partially derives from the HARTIK project but it
9
 * currently is independently developed.
10
 *
11
 * OSLib is distributed under GPL License, and some of its code has
12
 * been derived from the Linux kernel source; also some important
13
 * ideas come from studying the DJGPP go32 extender.
14
 *
15
 * We acknowledge the Linux Community, Free Software Foundation,
16
 * D.J. Delorie and all the other developers who believe in the
17
 * freedom of software and ideas.
18
 *
19
 * For legalese, check out the included GPL license.
20
 */
21
 
22
/* File: X1.C       */
23
/* Startup code:        */
24
/* Build parameters list & make info accessible */
25
 
1621 fabio 26
#include <arch/stdlib.h>
2 pj 27
#include <ll/i386/hw-func.h>
28
#include <ll/i386/cons.h>
29
#include <ll/i386/mb-info.h>
30
 
31
#include <ll/i386/mem.h>
32
 
33
FILE(X1);
34
 
35
/* #define __DUMP_MEM__  */
36
 
37
/* We need to copy from X address space to the application space  */
38
/* the info structure to allow pointer access using flat model    */
39
/* Remember that flat model is similar to small model also if we  */
40
/* can see the whole memory, because it has no explicit far       */
41
/* pointers; then if we pass into _args[] the address of the      */
42
/* string of the n-th argument it could not be correctly accessed */
43
/* because it lies in a memory zone unseen from PM application.   */
44
/* This is due to the ELF format which has no relocation info     */
45
/* since the file is already relocated starting from address 0!   */
46
/* Then the PM application cannot see a real flat memory (segment */
47
/* with 0 base) but CS,DS & SS MUST have the base correctly set.  */
48
/* Refer to this figure:                      */
49
/*                                */
50
/* DOS Memory <- X is there                   */
51
/*                                        */
52
/* EXTENDED Memory -----[                     */
53
/*          [                     */
54
/*  Address  xxxx   [ <- Application code is here!        */
55
/*          [                     */
56
/*  Address  yyyy   [ <- Application Data & Stack!        */
57
/*                                */
58
/* Then CS has xxxx base while DS & SS have yyyy base!        */
59
 
60
/* Stack base address; use this to check stack overflow!    */
61
/* With Flat model I do not think we can use 386 protection     */
62
/* to detect a stack overflow; anyway Watcom C use a standard   */
63
/* function __CHK to detect it! The compiler place it whenever  */
64
/* it calls a function to detect overflow           */
65
 
40 pj 66
DWORD _stkbase;
2 pj 67
DWORD _stktop;
68
 
69
/* This is some extra stuff we need to compile with argument    */
70
/* passing and math extensions                  */
71
DWORD _argc = 0;
72
typedef char *charp;
73
charp _argv[100];
74
 
1688 fabio 75
extern void __kernel_init__(int argc, char *argv[]);
2 pj 76
extern void bios_save(void);
77
extern void bios_restore(void);
78
 
79
/* This is used in GNU-C to implement C++ constructors/destructors */
80
/* See the lib sources for more details                */
81
void __main(int argc, char **argv)
82
{
83
}
84
 
85
 
40 pj 86
struct multiboot_info * mbi_address(void)
2 pj 87
{
40 pj 88
  /* This is declared in [wc32/gnu]\x0.[asm/s] */
89
  extern struct multiboot_info *mbi;
2 pj 90
 
40 pj 91
  return (mbi);
2 pj 92
}
93
 
94
void _startup(void)
95
{
40 pj 96
  register int i = 0;
94 giacomo 97
  char temp[1000];
40 pj 98
  struct multiboot_info *mbi = mbi_address();
99
  char *cmdline = (char *)(mbi->cmdline);
2 pj 100
 
40 pj 101
  if (!(mbi->flags & MB_INFO_MEMORY)) {
102
    cputs("X/Runtime library error!!! Unable to find memory information!\n");
103
    l1_exit(-1);
104
  }
94 giacomo 105
 
40 pj 106
  if (mbi->flags & MB_INFO_CMDLINE) {
107
    /* Build parameter list, up to 100 parms... */
94 giacomo 108
    while (cmdline[i] != 0 && i < 1000) {
109
      temp[i] = cmdline[i];
110
      _argv[_argc] = &(temp[i]);
111
      while (cmdline[i] != ' ' && cmdline[i] != 0 && i < 1000) {
112
        temp[i] = cmdline[i];
113
        i++;
114
      }
40 pj 115
      if (cmdline[i] == ' ') {
94 giacomo 116
        temp[i] = 0; i++; _argc++;
40 pj 117
      }
2 pj 118
    }
94 giacomo 119
    temp[i] = 0;
40 pj 120
    _argc++;
121
  }
122
 
123
  bios_save();
124
  /* Call main procedure using standard C convention   */
125
  /* Remember you cannot call any console I/O function */
126
  /* if you do not call bios_save()            */
94 giacomo 127
 
128
 
2 pj 129
#ifdef __DUMP_MEM__
40 pj 130
  message("X/MEM   : %u\n",mbi->mem_upper);
131
  message("DOS/MEM : %u\n",mbi->mem_lower);
132
  message("x_bios Size : %u\n",sizeof(X_BIOSCALL));
133
  message("mbi Size : %u\n",sizeof(struct multiboot_info));
134
  message("Cmdline : %s\n",mbi->cmdline);
94 giacomo 135
  message("Argc : %u\n",_argc);
136
  message("Argv[0] : %s\n",_argv[0]);
40 pj 137
  message("Argv[1] : %s\n",_argv[1]);
138
  message("Argv[2] : %s\n",_argv[2]);
139
  message("Argv[3] : %s\n",_argv[3]);
2 pj 140
#endif
1688 fabio 141
  __kernel_init__(_argc,_argv);
40 pj 142
  bios_restore();
2 pj 143
}