xref: /inferno-os/os/mpc/devboot.c (revision 74a4d8c26dd3c1e9febcb717cfd6cb6512991a7a)
1*74a4d8c2SCharles.Forsyth #include	"u.h"
2*74a4d8c2SCharles.Forsyth #include	"../port/lib.h"
3*74a4d8c2SCharles.Forsyth #include	"mem.h"
4*74a4d8c2SCharles.Forsyth #include	"dat.h"
5*74a4d8c2SCharles.Forsyth #include	"fns.h"
6*74a4d8c2SCharles.Forsyth #include	"../port/error.h"
7*74a4d8c2SCharles.Forsyth 
8*74a4d8c2SCharles.Forsyth enum{
9*74a4d8c2SCharles.Forsyth 	Qdir,
10*74a4d8c2SCharles.Forsyth 	Qboot,
11*74a4d8c2SCharles.Forsyth 	Qmem,
12*74a4d8c2SCharles.Forsyth };
13*74a4d8c2SCharles.Forsyth 
14*74a4d8c2SCharles.Forsyth Dirtab bootdir[]={
15*74a4d8c2SCharles.Forsyth 	".",			{Qdir,0,QTDIR},	0,	0555,
16*74a4d8c2SCharles.Forsyth 	"boot",		{Qboot},	0,	0666,
17*74a4d8c2SCharles.Forsyth 	"mem",		{Qmem},		0,	0666,
18*74a4d8c2SCharles.Forsyth };
19*74a4d8c2SCharles.Forsyth 
20*74a4d8c2SCharles.Forsyth #define	NBOOT	(sizeof bootdir/sizeof(Dirtab))
21*74a4d8c2SCharles.Forsyth 
22*74a4d8c2SCharles.Forsyth static void
bootreset(void)23*74a4d8c2SCharles.Forsyth bootreset(void)
24*74a4d8c2SCharles.Forsyth {
25*74a4d8c2SCharles.Forsyth }
26*74a4d8c2SCharles.Forsyth 
27*74a4d8c2SCharles.Forsyth static Chan*
bootattach(char * spec)28*74a4d8c2SCharles.Forsyth bootattach(char *spec)
29*74a4d8c2SCharles.Forsyth {
30*74a4d8c2SCharles.Forsyth 	return devattach('B', spec);
31*74a4d8c2SCharles.Forsyth }
32*74a4d8c2SCharles.Forsyth 
33*74a4d8c2SCharles.Forsyth static Walkqid*
bootwalk(Chan * c,Chan * nc,char ** name,int nname)34*74a4d8c2SCharles.Forsyth bootwalk(Chan *c, Chan *nc, char **name, int nname)
35*74a4d8c2SCharles.Forsyth {
36*74a4d8c2SCharles.Forsyth 	return devwalk(c, nc, name, nname, bootdir, NBOOT, devgen);
37*74a4d8c2SCharles.Forsyth }
38*74a4d8c2SCharles.Forsyth 
39*74a4d8c2SCharles.Forsyth static int
bootstat(Chan * c,uchar * dp,int n)40*74a4d8c2SCharles.Forsyth bootstat(Chan *c, uchar *dp, int n)
41*74a4d8c2SCharles.Forsyth {
42*74a4d8c2SCharles.Forsyth 	return devstat(c, dp, n, bootdir, NBOOT, devgen);
43*74a4d8c2SCharles.Forsyth }
44*74a4d8c2SCharles.Forsyth 
45*74a4d8c2SCharles.Forsyth static Chan*
bootopen(Chan * c,int omode)46*74a4d8c2SCharles.Forsyth bootopen(Chan *c, int omode)
47*74a4d8c2SCharles.Forsyth {
48*74a4d8c2SCharles.Forsyth 	return devopen(c, omode, bootdir, NBOOT, devgen);
49*74a4d8c2SCharles.Forsyth }
50*74a4d8c2SCharles.Forsyth 
51*74a4d8c2SCharles.Forsyth static void
bootclose(Chan *)52*74a4d8c2SCharles.Forsyth bootclose(Chan*)
53*74a4d8c2SCharles.Forsyth {
54*74a4d8c2SCharles.Forsyth }
55*74a4d8c2SCharles.Forsyth 
56*74a4d8c2SCharles.Forsyth static long
bootread(Chan * c,void * buf,long n,vlong off)57*74a4d8c2SCharles.Forsyth bootread(Chan *c, void *buf, long n, vlong off)
58*74a4d8c2SCharles.Forsyth {
59*74a4d8c2SCharles.Forsyth 	ulong offset = off;
60*74a4d8c2SCharles.Forsyth 
61*74a4d8c2SCharles.Forsyth 	switch((ulong)c->qid.path){
62*74a4d8c2SCharles.Forsyth 
63*74a4d8c2SCharles.Forsyth 	case Qdir:
64*74a4d8c2SCharles.Forsyth 		return devdirread(c, buf, n, bootdir, NBOOT, devgen);
65*74a4d8c2SCharles.Forsyth 
66*74a4d8c2SCharles.Forsyth 	case Qmem:
67*74a4d8c2SCharles.Forsyth 		/* kernel memory */
68*74a4d8c2SCharles.Forsyth 		if(offset>=KZERO && offset<KZERO+conf.npage*BY2PG){
69*74a4d8c2SCharles.Forsyth 			if(offset+n > KZERO+conf.npage*BY2PG)
70*74a4d8c2SCharles.Forsyth 				n = KZERO+conf.npage*BY2PG - offset;
71*74a4d8c2SCharles.Forsyth 			memmove(buf, (char*)offset, n);
72*74a4d8c2SCharles.Forsyth 			return n;
73*74a4d8c2SCharles.Forsyth 		}
74*74a4d8c2SCharles.Forsyth 		error(Ebadarg);
75*74a4d8c2SCharles.Forsyth 	}
76*74a4d8c2SCharles.Forsyth 
77*74a4d8c2SCharles.Forsyth 	error(Egreg);
78*74a4d8c2SCharles.Forsyth 	return 0;	/* not reached */
79*74a4d8c2SCharles.Forsyth }
80*74a4d8c2SCharles.Forsyth 
81*74a4d8c2SCharles.Forsyth static long
bootwrite(Chan * c,void * buf,long n,vlong off)82*74a4d8c2SCharles.Forsyth bootwrite(Chan *c, void *buf, long n, vlong off)
83*74a4d8c2SCharles.Forsyth {
84*74a4d8c2SCharles.Forsyth 	ulong offset = off;
85*74a4d8c2SCharles.Forsyth 	ulong pc;
86*74a4d8c2SCharles.Forsyth 	uchar *p;
87*74a4d8c2SCharles.Forsyth 
88*74a4d8c2SCharles.Forsyth 	switch((ulong)c->qid.path){
89*74a4d8c2SCharles.Forsyth 	case Qmem:
90*74a4d8c2SCharles.Forsyth 		/* kernel memory */
91*74a4d8c2SCharles.Forsyth 		if(offset>=KZERO && offset<KZERO+conf.npage*BY2PG){
92*74a4d8c2SCharles.Forsyth 			if(offset+n > KZERO+conf.npage*BY2PG)
93*74a4d8c2SCharles.Forsyth 				n = KZERO+conf.npage*BY2PG - offset;
94*74a4d8c2SCharles.Forsyth 			memmove((char*)offset, buf, n);
95*74a4d8c2SCharles.Forsyth 			segflush((void*)offset, n);
96*74a4d8c2SCharles.Forsyth 			return n;
97*74a4d8c2SCharles.Forsyth 		}
98*74a4d8c2SCharles.Forsyth 		error(Ebadarg);
99*74a4d8c2SCharles.Forsyth 
100*74a4d8c2SCharles.Forsyth 	case Qboot:
101*74a4d8c2SCharles.Forsyth 		p = (uchar*)buf;
102*74a4d8c2SCharles.Forsyth 		pc = (((((p[0]<<8)|p[1])<<8)|p[2])<<8)|p[3];
103*74a4d8c2SCharles.Forsyth 		if(pc < KZERO || pc >= KZERO+conf.npage*BY2PG)
104*74a4d8c2SCharles.Forsyth 			error(Ebadarg);
105*74a4d8c2SCharles.Forsyth 		splhi();
106*74a4d8c2SCharles.Forsyth 		segflush((void*)pc, 64*1024);
107*74a4d8c2SCharles.Forsyth 		gotopc(pc);
108*74a4d8c2SCharles.Forsyth 	}
109*74a4d8c2SCharles.Forsyth 	error(Ebadarg);
110*74a4d8c2SCharles.Forsyth 	return 0;	/* not reached */
111*74a4d8c2SCharles.Forsyth }
112*74a4d8c2SCharles.Forsyth 
113*74a4d8c2SCharles.Forsyth Dev bootdevtab = {
114*74a4d8c2SCharles.Forsyth 	'B',
115*74a4d8c2SCharles.Forsyth 	"boot",
116*74a4d8c2SCharles.Forsyth 
117*74a4d8c2SCharles.Forsyth 	bootreset,
118*74a4d8c2SCharles.Forsyth 	devinit,
119*74a4d8c2SCharles.Forsyth 	devshutdown,
120*74a4d8c2SCharles.Forsyth 	bootattach,
121*74a4d8c2SCharles.Forsyth 	bootwalk,
122*74a4d8c2SCharles.Forsyth 	bootstat,
123*74a4d8c2SCharles.Forsyth 	bootopen,
124*74a4d8c2SCharles.Forsyth 	devcreate,
125*74a4d8c2SCharles.Forsyth 	bootclose,
126*74a4d8c2SCharles.Forsyth 	bootread,
127*74a4d8c2SCharles.Forsyth 	devbread,
128*74a4d8c2SCharles.Forsyth 	bootwrite,
129*74a4d8c2SCharles.Forsyth 	devbwrite,
130*74a4d8c2SCharles.Forsyth 	devremove,
131*74a4d8c2SCharles.Forsyth 	devwstat,
132*74a4d8c2SCharles.Forsyth };
133