28b7eabfafe67c53e83387f0ad37463385ce0b20
[rpld.git] / config.c
1 /*************************************************
2 *     rpld - an IBM style RIPL server            *
3 *************************************************/
4
5 /* Copyright (c) 1999,2000, James McKenzie.
6  *                      All rights reserved
7  * Copyright (c) 1998,2000, Christopher Lightfoot.
8  *                      All rights reserved
9  *
10  * By using this file, you agree to the terms and conditions set
11  * forth in the LICENCE file which can be found at the top level of
12  * the rpld distribution.
13  *
14  * IBM is a trademark of IBM corp.
15  *
16  */
17
18
19 static char rcsid[] =
20   "$Id: config.c,v 1.13 2000/07/29 23:25:25 root Exp root $";
21
22 /*
23  * $Log: config.c,v $
24  * Revision 1.13  2000/07/29 23:25:25  root
25  * #
26  *
27  * Revision 1.12  2000/07/23 19:14:19  root
28  * #
29  *
30  * Revision 1.11  2000/07/23 19:07:49  root
31  * #
32  *
33  * Revision 1.10  2000/07/17 10:49:20  root
34  * #
35  *
36  * Revision 1.9  2000/07/17 10:45:38  root
37  * #
38  *
39  * Revision 1.8  2000/07/17 10:43:54  root
40  * #
41  *
42  * Revision 1.7  2000/07/17 10:43:34  root
43  * #
44  *
45  * Revision 1.6  2000/07/16 14:05:28  root
46  * #
47  *
48  * Revision 1.5  2000/07/16 13:18:10  root
49  * #
50  *
51  * Revision 1.1  2000/07/16 13:16:33  root
52  * #
53  *
54  * Revision 1.4  1999/09/13 11:17:35  root
55  * \#
56  *
57  * Revision 1.3  1999/09/13 11:08:34  root
58  * \#
59  *
60  * Revision 1.2  1999/09/13 11:05:27  root
61  * \#
62  *
63  * Revision 1.1  1999/09/13 11:04:13  root
64  * \#
65  *
66  */
67
68 #include "project.h"
69
70 #include "rpld_conf.tab.h"
71
72 extern FILE *yyin;
73
74 void
75 do_linux_kernel (struct client *c, struct clfile *f)
76 {
77   struct clfile *bootsect, *kernel;
78   int loaderlen;
79
80 #define VMLINUZ_LOADLEN_OFFSET 497
81
82 /* The book says we should load top downwards so 
83  * we init bottom upwards ie fr is the second stage 
84  * bootloader at 0x92000 */
85
86 /* Firstly we need to load the bootsector to work out stuff */
87   bootsect = (struct clfile *) malloc (sizeof (struct clfile));
88   bzero (bootsect, sizeof (struct clfile));
89
90   bootsect->path = strdup (f->path);
91   bootsect->offset = 0;
92   bootsect->length = 0x200;
93   bootsect->load_addr = 0x90000;
94
95   cache_locally (bootsect);
96
97   if (!bootsect->data)
98     {
99       fprintf (stderr, "Couldn't open %s for reading\n", f->path);
100       exit (1);
101     }
102   if (bootsect->length < 0x200)
103     {
104       fprintf (stderr, "Only read %d bytes from %s\n", bootsect->length,
105                f->path);
106       exit (1);
107     }
108
109   /* FIXME: here we should add a pointer to the kernel parameter string */
110   /* and allocate a clfile structure to hold it */
111
112   loaderlen = (bootsect->data[VMLINUZ_LOADLEN_OFFSET]) ?
113     (0x200 * (bootsect->data[VMLINUZ_LOADLEN_OFFSET])) : 0x800;
114
115
116   kernel = (struct clfile *) malloc (sizeof (struct clfile));
117   bzero (kernel, sizeof (struct clfile));
118
119   kernel->path = strdup (f->path);
120   kernel->offset = loaderlen + 0x200;
121   kernel->length = -1;
122   kernel->load_addr = 0x10000;
123
124   kernel->next = c->files;
125   c->files = kernel;
126
127   /* Tag in the bootsector */
128   bootsect->next = kernel;
129   c->files = bootsect;
130
131
132   /* Now set up f the secondary bootloader */
133
134   f->offset = 0x200;
135   f->length = loaderlen;
136   f->load_addr = 0x90200;
137
138 }
139
140
141 void
142 parse_config ()
143 {
144   FILE *file;
145
146   file = fopen (CONFIG_FILE, "r");
147
148   if (!file)
149     {
150       fprintf (stderr, "Cannot open config file %s\n", CONFIG_FILE);
151       exit (1);
152     }
153
154   yyin = file;
155
156   yyparse ();
157
158   fclose (file);
159
160
161 }