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