#include "all.h" #include "mem.h" #include "io.h" #include "ureg.h" #include "../pc/dosfs.h" /* * setting this to zero permits the use of discs of different sizes, but * can make jukeinit() quite slow while the robotics work through each disc * twice (once per side). */ int FIXEDSIZE = 1; #ifndef DATE #define DATE 1094098624L #endif Timet mktime = DATE; /* set by mkfile */ Startsb startsb[] = { /* "main", 2, */ "main", 810988, /* discontinuity before sb @ 696262 */ 0 }; Dos dos; static struct { char *name; Off (*read)(int, void*, long); Devsize (*seek)(int, Devsize); Off (*write)(int, void*, long); int (*part)(int, char*); } nvrdevs[] = { { "fd", floppyread, floppyseek, floppywrite, 0, }, { "hd", ataread, ataseek, atawrite, setatapart, }, /* { "sd", scsiread, scsiseek, scsiwrite, setscsipart, }, */ { 0, }, }; void apcinit(void); void otherinit(void) { int dev, i, nfd, nhd, s; char *p, *q, buf[sizeof(nvrfile)+8]; kbdinit(); printcpufreq(); etherinit(); scsiinit(); apcinit(); s = spllo(); nhd = atainit(); nfd = floppyinit(); dev = 0; if(p = getconf("nvr")){ strncpy(buf, p, sizeof(buf)-2); buf[sizeof(buf)-1] = 0; p = strchr(buf, '!'); q = strrchr(buf, '!'); if(p == 0 || q == 0 || strchr(p+1, '!') != q) panic("malformed nvrfile: %s\n", buf); *p++ = 0; *q++ = 0; dev = strtoul(p, 0, 0); strcpy(nvrfile, q); p = buf; } else if(p = getconf("bootfile")){ strncpy(buf, p, sizeof(buf)-2); buf[sizeof(buf)-1] = 0; p = strchr(buf, '!'); q = strrchr(buf, '!'); if(p == 0 || q == 0 || strchr(p+1, '!') != q) panic("malformed bootfile: %s\n", buf); *p++ = 0; *q = 0; dev = strtoul(p, 0, 0); p = buf; } else if(nfd) p = "fd"; else if(nhd) p = "hd"; else p = "sd"; for(i = 0; nvrdevs[i].name; i++){ if(strcmp(p, nvrdevs[i].name) == 0){ dos.dev = dev; if(nvrdevs[i].part && (*nvrdevs[i].part)(dos.dev, "disk") == 0) break; dos.read = nvrdevs[i].read; dos.seek = nvrdevs[i].seek; dos.write = nvrdevs[i].write; break; } } if(dos.read == 0) panic("no device for nvram\n"); if(dosinit(&dos) < 0) panic("can't init dos dosfs on %s\n", p); splx(s); } void touser(void) { int i; settime(rtctime()); boottime = time(); print("sysinit\n"); sysinit(); userinit(floppyproc, 0, "floppyproc"); /* * Ethernet i/o processes */ etherstart(); /* * read ahead processes */ userinit(rahead, 0, "rah"); /* * server processes */ for(i=0; itext = "scp"; synccopy(); } void localconfinit(void) { /* conf.nfile = 60000; */ /* from emelie */ conf.nodump = 0; conf.dumpreread = 1; if (0) conf.idedma = 0; /* for old machines */ conf.firstsb = 0; /* time- & jukebox-dependent optimisation */ conf.recovsb = 0; /* 971531 is 24 june 2003, before w3 died */ conf.ripoff = 1; conf.nlgmsg = 1100; /* @8576 bytes, for packets */ conf.nsmmsg = 500; /* @128 bytes */ conf.minuteswest = 8*60; conf.dsttime = 1; } int (*fsprotocol[])(Msgbuf*) = { serve9p1, /* do we still need 9P1? */ serve9p2, nil, };