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