Plan 9 from Bell Labs’s /usr/web/sources/extra/changes/2006/0128

Copyright © 2021 Plan 9 Foundation.
Distributed under the MIT License.
Download the Plan 9 distribution.


Add troff2png for htmlroff(1).
 [rsc] --rwxrwxr-x M 1428987 rsc sys 228 Jan 28 09:00 rc/bin/troff2png

Small htmlroff fixes.
 [rsc] --rw-rw-r-- M 1428987 rsc sys 1831 Jan 27 16:07 sys/man/1/htmlroff
 [rsc] --rw-rw-r-- M 1428987 rsc sys 6608 Jan 28 09:30 sys/man/6/htmlroff
 [rsc] --rw-rw-r-- M 1428987 rsc sys 1711 Jan 28 09:22 sys/man/6/mhtml
 [rsc] --rw-rw-r-- M 1428987 rsc sys 6608 Jan 28 09:30 sys/man/6/htmlroff
	/n/sourcesdump/2006/0128/plan9/sys/man/6/htmlroff:305,317 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/6/htmlroff:305,317
	  The redirection stops on encountering the line
	  .IR stop ,
	  optionally followed by white space and extra text.
	- This is a dangerous and clusmy request, as 
	+ This is a dangerous and clumsy request, as 
	  .I htmlroff
	  stops interpreting its input during the redirection, so
	  .I stop
	  must be found in the input itself, not in a macro that
	  the input might appear to call.
	- Although clusmy,
	+ Although clumsy,
	  .B .inputpipe
	  allows input files to invoke
	  .I troff
 [rsc] --rw-rw-r-- M 1428987 rsc sys 1711 Jan 28 09:22 sys/man/6/mhtml
	/n/sourcesdump/2006/0128/plan9/sys/man/6/mhtml:48,54 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/6/mhtml:48,54
	  tag, opens and closes the
	  .B <head>
	  section, and opens
	- .B <body> .
	+ .BR <body> .
	  It invokes the
	  .B .HEAD
	  macro inside the
 [rsc] --rw-rw-r-- M 1428987 rsc sys 1625 Jan 28 09:33 sys/src/cmd/htmlroff/util.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/htmlroff/util.c:78,84 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/htmlroff/util.c:78,84
	  {
	  	va_list arg;
	  	
	- 	fprint(2, "%L: ");
	+ 	fprint(2, "htmlroff: %L: ");
	  	va_start(arg, fmt);
	  	vfprint(2, fmt, arg);
	  	va_end(arg);

Add more character sets to tcs(1).
 [rsc] --rw-rw-r-- M 1428987 rsc sys 16466 Jan 27 12:26 sys/src/cmd/tcs/8859.h
 [rsc] --rw-rw-r-- M 1428987 rsc sys 19274 Jan 27 12:26 sys/src/cmd/tcs/misc.h
 [rsc] --rw-rw-r-- M 1428987 rsc sys 44069 Jan 27 12:26 sys/src/cmd/tcs/ms.h

More changes for htmlroff.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 22383 Jan 28 09:23 sys/doc/lp.ms
	[diffs elided - too long]
	[diff -c /n/sourcesdump/2006/0128/plan9/sys/doc/lp.ms /n/sourcesdump/2006/0129/plan9/sys/doc/lp.ms]

Kernel changes:
	- add background ccloses to make all processes killable
	- move away from vlongs in timer for performance
	- new event ctl message.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 12062 Jan 28 09:29 sys/man/3/proc
	/n/sourcesdump/2006/0128/plan9/sys/man/3/proc:351,357 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/3/proc:351,363
	  perform a schedulability test and start scheduling the process as a real-time
	  process if the test succeeds.  If the test fails, the
	  .B write
	- will fail with error set to the reason for failure.  For details on real time, read on.
	+ will fail with error set to the reason for failure.  
	+ .TP 10n
	+ .B event
	+ Add a user event to the 
	+ .B /proc/trace
	+ file.
	+ .PD
	  .PP
	  Real-time processes are periodically
	  .IR released ,
 [rsc] --rw-rw-r-- M 1428987 glenda sys 34790 Jan 28 09:24 sys/src/9/port/chan.c
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/chan.c:487,492 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/chan.c:487,568
	  }
	  
	  /*
	+  * Queue a chan to be closed by one of the clunk procs.
	+  */
	+ struct {
	+ 	Chan *head;
	+ 	Chan *tail;
	+ 	int nqueued;
	+ 	int nclosed;
	+ 	Lock l;
	+ 	QLock q;
	+ 	Rendez r;
	+ } clunkq;
	+ void closeproc(void*);
	+ 
	+ void
	+ ccloseq(Chan *c)
	+ {
	+ 	if(c->flag&CFREE)
	+ 		panic("cclose %lux", getcallerpc(&c));
	+ 
	+ 	DBG("ccloseq %p name=%s ref=%ld\n", c, c->path->s, c->ref);
	+ 
	+ 	if(decref(c))
	+ 		return;
	+ 
	+ 	lock(&clunkq.l);
	+ 	clunkq.nqueued++;
	+ 	c->next = nil;
	+ 	if(clunkq.head)
	+ 		clunkq.tail->next = c;
	+ 	else
	+ 		clunkq.head = c;
	+ 	clunkq.tail = c;
	+ 	unlock(&clunkq.l);
	+ 
	+ 	if(!wakeup(&clunkq.r))
	+ 		kproc("closeproc", closeproc, nil);	
	+ }
	+ 
	+ static int
	+ clunkwork(void*)
	+ {
	+ 	return clunkq.head != nil;
	+ }
	+ 
	+ void
	+ closeproc(void*)
	+ {
	+ 	Chan *c;
	+ 
	+ 	for(;;){
	+ 		qlock(&clunkq.q);
	+ 		if(clunkq.head == nil){
	+ 			if(!waserror()){
	+ 				tsleep(&clunkq.r, clunkwork, nil, 5000);
	+ 				poperror();
	+ 			}
	+ 			if(clunkq.head == nil){
	+ 				qunlock(&clunkq.q);
	+ 				pexit("no work", 1);
	+ 			}
	+ 		}
	+ 		lock(&clunkq.l);
	+ 		c = clunkq.head;
	+ 		clunkq.head = c->next;
	+ 		clunkq.nclosed++;
	+ 		unlock(&clunkq.l);
	+ 		qunlock(&clunkq.q);
	+ 		if(!waserror()){
	+ 			devtab[c->type]->close(c);
	+ 			poperror();
	+ 		}
	+ 		chanfree(c);
	+ 	}
	+ }
	+ 
	+ /*
	   * Make sure we have the only copy of c.  (Copy on write.)
	   */
	  Chan*
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/chan.c:1691,1693 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/chan.c:1767,1770
	  		free(m);
	  	}
	  }
	+ 
 [rsc] --rw-rw-r-- M 1428987 glenda sys 14579 Jan 28 09:26 sys/src/9/port/devloopback.c
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devloopback.c:143,149 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devloopback.c:143,149
	  	lb->ref++;
	  	if(lb->ref == 1){
	  		for(chan = 0; chan < 2; chan++){
	- 			lb->link[chan].ci.mode = Tabsolute;
	+ 			lb->link[chan].ci.mode = Trelative;
	  			lb->link[chan].ci.a = &lb->link[chan];
	  			lb->link[chan].ci.f = linkintr;
	  			lb->link[chan].limit = Loopqlim;
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devloopback.c:685,691 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devloopback.c:685,691
	  	if(!tin || tin > tout && tout)
	  		tin = tout;
	  
	- 	link->ci.ns = tin;
	+ 	link->ci.ns = tin - now;
	  	if(tin){
	  		if(tin < now)
	  			panic("loopback unfinished business");
 [rsc] --rw-rw-r-- M 1428987 glenda sys 30866 Jan 28 09:23 sys/src/9/port/devsd.c
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devsd.c:636,641 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devsd.c:636,642
	  	sdev = sdgetdev(DEV(c->qid));
	  	if(sdev == nil)
	  		error(Enonexist);
	+ 
	  	unit = sdev->unit[UNIT(c->qid)];
	  
	  	switch(TYPE(c->qid)){
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devsd.c:646,651 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devsd.c:647,653
	  		c->qid.vers = unit->vers;
	  		if(tas(&unit->rawinuse) != 0){
	  			c->flag &= ~COPEN;
	+ 			decref(&sdev->r);
	  			error(Einuse);
	  		}
	  		unit->state = Rawcmd;
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devsd.c:655,660 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devsd.c:657,663
	  		if(waserror()){
	  			qunlock(&unit->ctl);
	  			c->flag &= ~COPEN;
	+ 			decref(&sdev->r);
	  			nexterror();
	  		}
	  		pp = &unit->part[PART(c->qid)];
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devsd.c:704,711 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devsd.c:707,716
	  	ulong bno, max, nb, offset;
	  
	  	sdev = sdgetdev(DEV(c->qid));
	- 	if(sdev == nil)
	+ 	if(sdev == nil){
	+ 		decref(&sdev->r);
	  		error(Enonexist);
	+ 	}
	  	unit = sdev->unit[UNIT(c->qid)];
	  	if(unit == nil)
	  		error(Enonexist);
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devsd.c:1101,1107 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devsd.c:1106,1112
	  		if(unit->sectors){
	  			if(unit->dev->ifc->rctl == nil)
	  				l += snprint(p+l, m-l,
	- 					"geometry %ld %ld\n",
	+ 					"geometry %lud %ld\n",
	  					unit->sectors, unit->secsize);
	  			pp = unit->part;
	  			for(i = 0; i < unit->npart; i++){
 [jmk] --rw-rw-r-- M 1428987 glenda sys 13489 Jan 28 13:22 sys/src/9/port/edf.c
	[diffs elided - too long]
	[diff -c /n/sourcesdump/2006/0128/plan9/sys/src/9/port/edf.c /n/sourcesdump/2006/0129/plan9/sys/src/9/port/edf.c]
 [rsc] --rw-rw-r-- M 1428987 glenda sys 4760 Jan 28 09:24 sys/src/9/port/pgrp.c
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/pgrp.c:211,223 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/pgrp.c:211,262
	  	if(decref(f) != 0)
	  		return;
	  
	+ 	/*
	+ 	 * If we get into trouble, forceclosefgrp
	+ 	 * will bail us out.
	+ 	 */
	+ 	up->closingfgrp = f;
	  	for(i = 0; i <= f->maxfd; i++)
	- 		if(c = f->fd[i])
	+ 		if(c = f->fd[i]){
	+ 			f->fd[i] = nil;
	  			cclose(c);
	+ 		}
	+ 	up->closingfgrp = nil;
	  
	  	free(f->fd);
	  	free(f);
	  }
	+ 
	+ /*
	+  * Called from sleep because up is in the middle
	+  * of closefgrp and just got a kill ctl message.
	+  * This usually means that up has wedged because
	+  * of some kind of deadly embrace with mntclose
	+  * trying to talk to itself.  To break free, hand the
	+  * unclosed channels to the close queue.  Once they
	+  * are finished, the blocked cclose that we've 
	+  * interrupted will finish by itself.
	+  */
	+ void
	+ forceclosefgrp(void)
	+ {
	+ 	int i;
	+ 	Chan *c;
	+ 	Fgrp *f;
	+ 
	+ 	if(up->procctl != Proc_exitme || up->closingfgrp == nil){
	+ 		print("bad forceclosefgrp call");
	+ 		return;
	+ 	}
	+ 
	+ 	f = up->closingfgrp;
	+ 	for(i = 0; i <= f->maxfd; i++)
	+ 		if(c = f->fd[i]){
	+ 			f->fd[i] = nil;
	+ 			ccloseq(c);
	+ 		}
	+ }
	+ 
	  
	  Mount*
	  newmount(Mhead *mh, Chan *to, int flag, char *spec)
 [rsc] --rw-rw-r-- M 1428987 glenda sys 4211 Jan 28 09:26 sys/src/9/port/portclock.c
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/portclock.c:17,23 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/portclock.c:17,23
	  ulong intrcount[MAXMACH];
	  ulong fcallcount[MAXMACH];
	  
	- static uvlong
	+ static vlong
	  tadd(Timers *tt, Timer *nt)
	  {
	  	Timer *t, **last;
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/portclock.c:29,40 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/portclock.c:29,38
	  		panic("timer");
	  		break;
	  	case Trelative:
	- 		assert(nt->tns > 0);
	+ 		if(nt->tns <= 0)
	+ 			nt->tns = 1;
	  		nt->twhen = fastticks(nil) + ns2fastticks(nt->tns);
	  		break;
	- 	case Tabsolute:
	- 		nt->twhen = tod2fastticks(nt->tns);
	- 		break;
	  	case Tperiodic:
	  		assert(nt->tns >= 100000);	/* At least 100 µs period */
	  		if(nt->twhen == 0){
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/portclock.c:94,108 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/portclock.c:92,97
	  	Timers *tt;
	  	vlong when;
	  
	- 	if (nt->tmode == Tabsolute){
	- 		when = todget(nil);
	- 		if (nt->tns <= when){
	- 	//		if (nt->tns + MS2NS(10) <= when)	/* small deviations will happen */
	- 	//			print("timeradd (%lld %lld) %lld too early 0x%lux\n",
	- 	//				when, nt->tns, when - nt->tns, getcallerpc(&nt));
	- 			nt->tns = when;
	- 		}
	- 	}
	  	/* Must lock Timer struct before Timers struct */
	  	ilock(nt);
	  	if(tt = nt->tt){
 [rsc] --rw-rw-r-- M 1428987 glenda sys 22535 Jan 28 09:26 sys/src/9/port/portdat.h
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/portdat.h:506,512 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/portdat.h:506,511
	  enum {
	  	/* Mode */
	  	Trelative,	/* timer programmed in ns from now */
	- 	Tabsolute,	/* timer programmed in ns since epoch */
	  	Tperiodic,	/* periodic timer, period in ns */
	  };
	  
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/portdat.h:630,635 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/portdat.h:629,636
	  	Egrp 	*egrp;		/* Environment group */
	  	Fgrp	*fgrp;		/* File descriptor group */
	  	Rgrp	*rgrp;		/* Rendez group */
	+ 
	+ 	Fgrp	*closingfgrp;	/* used during teardown */
	  
	  	ulong	parentpid;
	  	ulong	time[6];	/* User, Sys, Real; child U, S, R */
 [rsc] --rw-rw-r-- M 1428987 glenda sys 6279 Jan 28 09:54 sys/src/9/pc/i8253.c
 [rsc] --rw-rw-r-- M 1428987 glenda sys 5704 Jan 28 09:52 sys/src/9/port/alloc.c
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/alloc.c:95,100 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/alloc.c:95,101
	  
	  	pv = p->private;
	  	ilock(&pv->lk);
	+ 	pv->lk.pc = getcallerpc(&p);
	  	pv->msg[0] = 0;
	  }
	  
 [rsc] --rw-rw-r-- M 1428987 glenda sys 7265 Jan 28 09:50 sys/src/9/port/fault.c
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/fault.c:11,17 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/fault.c:11,17
	  	Segment *s;
	  	char *sps;
	  
	- if(up && up->nlocks.ref) print("fault nlocks %ld\n", up->nlocks.ref);
	+ if(up->nlocks.ref) print("fault nlocks %ld\n", up->nlocks.ref);
	  
	  	sps = up->psstate;
	  	up->psstate = "Fault";
 [rsc] --rw-rw-r-- M 1428987 glenda sys 5336 Jan 28 09:45 sys/src/9/port/tod.c
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/tod.c:31,43 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/tod.c:31,46
	  
	  /* frequency of the tod clock */
	  #define TODFREQ	1000000000ULL
	+ #define MicroFREQ	1000000ULL
	  
	  struct {
	  	int		init;		// true if initialized
	  	ulong	cnt;
	  	Lock;
	- 	uvlong	multiplier;	// t = off + (multiplier*ticks)>>31
	- 	uvlong	divider;	// ticks = (divider*(ticks-off))>>31
	+ 	uvlong	multiplier;	// ns = off + (multiplier*ticks)>>31
	+ 	uvlong	divider;	// ticks = (divider*(ns-off))>>31
	+ 	uvlong	umultiplier;	// µs = (µmultiplier*ticks)>>31
	+ 	uvlong	udivider;	// ticks = (µdivider*µs)>>31
	  	vlong	hz;		// frequency of fast clock
	  	vlong	last;		// last reading of fast clock
	  	vlong	off;		// offset from epoch to last
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/tod.c:72,78 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/tod.c:75,82
	  	/* calculate multiplier for time conversion */
	  	tod.multiplier = mk64fract(TODFREQ, f);
	  	tod.divider = mk64fract(f, TODFREQ);
	- 
	+ 	tod.umultiplier = mk64fract(MicroFREQ, f);
	+ 	tod.udivider = mk64fract(f, MicroFREQ);
	  	iunlock(&tod);
	  }
	  
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/tod.c:211,216 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/tod.c:215,242
	  	x = x/TODFREQ;
	  	i = x;
	  	return i;
	+ }
	+ 
	+ uvlong
	+ fastticks2us(uvlong ticks)
	+ {
	+ 	uvlong res;
	+ 
	+ 	if(!tod.init)
	+ 		todinit();
	+ 	mul64fract(&res, ticks, tod.umultiplier);
	+ 	return res;
	+ }
	+ 
	+ uvlong
	+ us2fastticks(uvlong us)
	+ {
	+ 	uvlong res;
	+ 
	+ 	if(!tod.init)
	+ 		todinit();
	+ 	mul64fract(&res, us, tod.udivider);
	+ 	return res;
	  }
	  
	  //  convert milliseconds to fast ticks
 [rsc] --rw-rw-r-- M 1428987 glenda sys 11079 Jan 28 12:32 sys/src/9/port/portfns.h
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/portfns.h:31,36 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/portfns.h:31,37
	  void		cinit(void);
	  Chan*		cclone(Chan*);
	  void		cclose(Chan*);
	+ void		ccloseq(Chan*);
	  void		closeegrp(Egrp*);
	  void		closefgrp(Fgrp*);
	  void		closepgrp(Pgrp*);
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/portfns.h:102,107 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/portfns.h:103,109
	  void		exit(int);
	  uvlong		fastticks(uvlong*);
	  uvlong		fastticks2ns(uvlong);
	+ uvlong		fastticks2us(uvlong);
	  int		fault(ulong, int);
	  void		fdclose(int, int);
	  Chan*		fdtochan(int, int, int, int);
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/portfns.h:108,113 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/portfns.h:110,116
	  int		findmount(Chan**, Mhead**, int, int, Qid);
	  int		fixfault(Segment*, ulong, int, int);
	  void		flushmmu(void);
	+ void		forceclosefgrp(void);
	  void		forkchild(Proc*, Ureg*);
	  void		forkret(void);
	  void		free(void*);
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/portfns.h:336,342 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/portfns.h:339,344
	  void		todinit(void);
	  void		todset(vlong, vlong, int);
	  Block*		trimblock(Block*, int, int);
	- void		tnsleep(Rendez*, int (*)(void*), void*, vlong);
	  void		tsleep(Rendez*, int (*)(void*), void*, ulong);
	  int		uartctl(Uart*, char*);
	  int		uartgetc(void);
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/portfns.h:351,356 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/portfns.h:353,359
	  void		uncachepage(Page*);
	  long		unionread(Chan*, void*, long);
	  void		unlock(Lock*);
	+ uvlong		us2fastticks(uvlong);
	  void		userinit(void);
	  ulong		userpc(void);
	  long		userwrite(char*, int);
 [rsc] --rw-rw-r-- M 1428987 glenda sys 28497 Jan 28 12:29 sys/src/9/port/devproc.c
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devproc.c:62,67 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devproc.c:62,68
	  	CMadmit,
	  	CMextra,
	  	CMexpel,
	+ 	CMevent,
	  };
	  
	  enum{
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devproc.c:125,130 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devproc.c:126,132
	  	CMadmit,		"admit",		1,
	  	CMextra,		"extra",		1,
	  	CMexpel,		"expel",		1,
	+ 	CMevent,		"event",		1,
	  };
	  
	  /* Segment type from portdat.h */
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devproc.c:1289,1294 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devproc.c:1291,1297
	  	Cmdtab *ct;
	  	vlong time;
	  	char *e;
	+ 	void (*pt)(Proc*, int, vlong);
	  
	  	if(p->kp)	/* no ctl requests to kprocs */
	  		error(Eperm);
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devproc.c:1317,1329 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devproc.c:1320,1332
	  			unbreak(p);
	  			break;
	  		case Stopped:
	- 			postnote(p, 0, "sys: killed", NExit);
	  			p->procctl = Proc_exitme;
	+ 			postnote(p, 0, "sys: killed", NExit);
	  			ready(p);
	  			break;
	  		default:
	- 			postnote(p, 0, "sys: killed", NExit);
	  			p->procctl = Proc_exitme;
	+ 			postnote(p, 0, "sys: killed", NExit);
	  		}
	  		break;
	  	case CMnohang:
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devproc.c:1402,1411 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devproc.c:1405,1414
	  	case CMperiod:
	  		if(p->edf == nil)
	  			edfinit(p);
	- 		if(e=parsetime(&time, cb->f[1]))
	+ 		if(e=parsetime(&time, cb->f[1]))	/* time in ns */
	  			error(e);
	  		edfstop(p);
	- 		p->edf->T = time;
	+ 		p->edf->T = time/1000;	/* Edf times are in µs */
	  		break;
	  	case CMdeadline:
	  		if(p->edf == nil)
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devproc.c:1413,1419 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devproc.c:1416,1422
	  		if(e=parsetime(&time, cb->f[1]))
	  			error(e);
	  		edfstop(p);
	- 		p->edf->D = time;
	+ 		p->edf->D = time/1000;
	  		break;
	  	case CMcost:
	  		if(p->edf == nil)
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devproc.c:1421,1427 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devproc.c:1424,1430
	  		if(e=parsetime(&time, cb->f[1]))
	  			error(e);
	  		edfstop(p);
	- 		p->edf->C = time;
	+ 		p->edf->C = time/1000;
	  		break;
	  	case CMsporadic:
	  		if(p->edf == nil)
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/devproc.c:1447,1452 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/devproc.c:1450,1460
	  	case CMexpel:
	  		if(p->edf)
	  			edfstop(p);
	+ 		break;
	+ 	case CMevent:
	+ 		pt = proctrace;
	+ 		if(up->trace && pt)
	+ 			pt(up, SUser, 0);
	  		break;
	  	}
	  
 [rsc] --rw-rw-r-- M 1428987 sape sys 1195 Jan 28 12:24 sys/src/9/port/edf.h
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/edf.h:16,44 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/edf.h:16,45
	  typedef struct Edf		Edf;
	  
	  struct Edf {
	+ 	/* All times in µs */
	  	/* time intervals */
	- 	vlong		D;			/* Deadline */
	- 	vlong		Delta;		/* Inherited deadline */
	- 	vlong		T;			/* period */
	- 	vlong		C;			/* Cost */
	- 	vlong		S;			/* Slice: time remaining in this period */
	- 	/* times */
	- 	vlong		r;			/* (this) release time */
	- 	vlong		d;			/* (this) deadline */
	- 	vlong		t;			/* Start of next period, t += T at release */
	- 	vlong		s;			/* Time at which this proc was last scheduled */
	+ 	long		D;		/* Deadline */
	+ 	long		Delta;		/* Inherited deadline */
	+ 	long		T;		/* period */
	+ 	long		C;		/* Cost */
	+ 	long		S;		/* Slice: time remaining in this period */
	+ 	/* times (only low-order bits of absolute time) */
	+ 	long		r;		/* (this) release time */
	+ 	long		d;		/* (this) deadline */
	+ 	long		t;		/* Start of next period, t += T at release */
	+ 	long		s;		/* Time at which this proc was last scheduled */
	  	/* for schedulability testing */
	- 	vlong		testDelta;
	- 	int			testtype;	/* Release or Deadline */
	- 	vlong		testtime;
	+ 	long		testDelta;
	+ 	int		testtype;	/* Release or Deadline */
	+ 	long		testtime;
	  	Proc		*testnext;
	  	/* other */
	  	ushort		flags;
	  	Timer;
	  	/* Stats */
	- 	vlong		edfused;
	- 	vlong		extraused;
	- 	vlong		aged;
	+ 	long		edfused;
	+ 	long		extraused;
	+ 	long		aged;
	  	ulong		periods;
	  	ulong		missed;
	  };
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/edf.h:45,51 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/edf.h:46,52
	  
	  extern Lock	edftestlock;	/* for atomic admitting/expelling */
	  
	- #pragma	varargck	type	"t"		vlong
	+ #pragma	varargck	type	"t"		long
	  #pragma	varargck	type	"U"		uvlong
	  
	  /* Interface: */
 [rsc] --rw-rw-r-- M 1428987 glenda sys 479 Jan 28 12:30 sys/src/9/port/master
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/master:9,15 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/master:9,14
	  D	ssl
	  E	sdp
	  F	flash
	- F	tinyfs
	  I	ip
	  K	kprof
	  L	lpt
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/master:20,26 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/master:19,24
	  U	usb
	  V	lml
	  V	tv
	- X	loopback
	  Y	pccard
	  a	tls
	  b	irq
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/master:43,49 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/master:41,46
	  w	wd
	  y	i82365
	  y	pcmcia
	- z	mntstats
	  |	pipe
	  ¤	cap
	  κ	kbmap
 [rsc] --rw-rw-r-- M 1428987 glenda sys 28053 Jan 28 12:29 sys/src/9/port/proc.c
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/proc.c:776,781 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/proc.c:776,783
	  	if(up->notepending) {
	  		up->notepending = 0;
	  		splx(s);
	+ 		if(up->procctl == Proc_exitme && up->closingfgrp)
	+ 			forceclosefgrp();
	  		error(Eintr);
	  	}
	  
	/n/sourcesdump/2006/0128/plan9/sys/src/9/port/proc.c:1320,1326 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/port/proc.c:1322,1329
	  	p->nerrlab = 0;
	  	p->slash = up->slash;
	  	p->dot = up->dot;
	- 	incref(p->dot);
	+ 	if(p->dot)
	+ 		incref(p->dot);
	  
	  	memmove(p->note, up->note, sizeof(p->note));
	  	p->nnote = up->nnote;
 [rsc] --rw-rw-r-- M 1428987 presotto sys 19884 Jan 28 12:31 sys/src/9/ppc/devflash.c
	/n/sourcesdump/2006/0128/plan9/sys/src/9/ppc/devflash.c:813,819 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/ppc/devflash.c:813,819
	   *	If someone learns better, please email me, though
	   *	I doubt it will be much faster. -  presotto@bell-labs.com
	   */
	- static ulong
	+ static long
	  ise_wbwrite(Flash *flash, Fword *p, int n, ulong off, ulong baddr, ulong *status)
	  {
	  	Fword x;
 [rsc] --rw-rw-r-- M 1428987 presotto sys 17084 Jan 28 12:31 sys/src/9/ppc/trap.c
	/n/sourcesdump/2006/0128/plan9/sys/src/9/ppc/trap.c:225,232 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/ppc/trap.c:225,234
	  		if(!user)
	  			panic("syscall in kernel: srr1 0x%4.4luX\n", ureg->srr1);
	  		syscall(ureg);
	- 		if (up->delaysched)
	+ 		if (up->delaysched){
	  			sched();
	+ 			splhi();
	+ 		}
	  		kexit(ureg);
	  		return;		/* syscall() calls notify itself, don't do it again */
	  
 [jmk] --rw-rw-r-- M 1428987 glenda sys 13489 Jan 28 13:22 sys/src/9/port/edf.c
 [jmk] --rw-rw-r-- M 1428987 glenda bitsy 5941 Jan 28 21:12 sys/src/9/bitsy/dat.h
	/n/sourcesdump/2006/0128/plan9/sys/src/9/bitsy/dat.h:32,37 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/bitsy/dat.h:32,41
	   */
	  #define AOUT_MAGIC	(E_MAGIC)
	  
	+ enum {
	+ 	Lockcycles = 0,	/* Don't measure lock latencies */
	+ };
	+ 
	  struct Lock
	  {
	  	ulong	key;
	/n/sourcesdump/2006/0128/plan9/sys/src/9/bitsy/dat.h:40,45 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/bitsy/dat.h:44,50
	  	Proc	*p;
	  	Mach	*m;
	  	ushort	isilock;
	+ 	uvlong	lockcycles;	/* Measure lock latencies */
	  };
	  
	  struct Label
 [jmk] --rw-rw-r-- M 1428987 glenda bitsy 16830 Jan 28 21:10 sys/src/9/bitsy/devflash.c
	/n/sourcesdump/2006/0128/plan9/sys/src/9/bitsy/devflash.c:728,734 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/9/bitsy/devflash.c:728,734
	   *	If someone learns better, please email me, though
	   *	I doubt it will be much faster. -  presotto@bell-labs.com
	   */
	- static ulong
	+ static int
	  ise_wbwrite(ulong *p, int n, ulong off, ulong baddr, ulong *status)
	  {
	  	ulong x, start;

Use htmlroff in doc mkfiles.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 214 Jan 28 09:41 sys/doc/8½/mkfile
	/n/sourcesdump/2006/0128/plan9/sys/doc/8½/mkfile:4,8 - 
	/n/sourcesdump/2006/0129/plan9/sys/doc/8½/mkfile:4,9
	  	{echo $FONTS; cat 8½.ms} | tbl | troff -ms -mpictures -mnihongo | lp -dstdout >8½.ps
	  	../cleanps 8½.ps
	  
	- 8½.html:D:
	- 	{echo $FONTS; cat 8½.ms} | tbl | ms2html >8½.html
	+ 8½.html:D: 8½.ms
	+ 	tbl 8½.ms | htmlroff -ms -mhtml >8½.html
	+ 
 [rsc] --rw-rw-r-- M 1428987 glenda sys 295 Jan 28 09:41 sys/doc/acme/mkfile
	/n/sourcesdump/2006/0128/plan9/sys/doc/acme/mkfile:8,12 - 
	/n/sourcesdump/2006/0129/plan9/sys/doc/acme/mkfile:8,12
	  	../cleanps acme.ps
	  
	  acme.html:D:	acme.ms
	- 	{echo $FONTS; cat acme.ms} | ms2html >acme.html
	+ 	htmlroff -ms -mhtml acme.ms >acme.html
	  
 [rsc] --rw-rw-r-- M 1428987 glenda sys 273 Jan 28 09:41 sys/doc/fs/mkfile
	/n/sourcesdump/2006/0128/plan9/sys/doc/fs/mkfile:18,21 - 
	/n/sourcesdump/2006/0129/plan9/sys/doc/fs/mkfile:18,22
	  	{echo $FONTS; cat $OBJ } | troff -ms >fs.trout
	  
	  fs.html:D:
	- 	{echo $FONTS; cat $OBJ } | ms2html >fs.html
	+ 	htmlroff -ms -mhtml $OBJ >fs.html
	+ 
 [rsc] --rw-rw-r-- M 1428987 glenda sys 206 Jan 28 09:41 sys/doc/il/mkfile
	/n/sourcesdump/2006/0128/plan9/sys/doc/il/mkfile:5,8 - 
	/n/sourcesdump/2006/0129/plan9/sys/doc/il/mkfile:5,9
	  	../cleanps il.ps
	  
	  il.html:D:	il.ms transition.pic
	- 	{echo $FONTS; cat il.ms} | pic | ms2html >il.html
	+ 	pic il.ms | htmlroff -ms -mhtml >il.html
	+ 
 [rsc] --rw-rw-r-- M 1428987 glenda sys 334 Jan 28 09:41 sys/doc/net/mkfile
	/n/sourcesdump/2006/0128/plan9/sys/doc/net/mkfile:14,17 - 
	/n/sourcesdump/2006/0129/plan9/sys/doc/net/mkfile:14,18
	  	pic tree > tree.pout
	  
	  net.html:D:	$DEPS
	- 	{ echo $FONTS; cat net.ms } | tbl | ms2html > net.html
	+ 	tbl net.ms | htmlroff -ms -mhtml >net.html
	+ 
 [rsc] --rw-rw-r-- M 1428987 glenda sys 566 Jan 28 09:41 sys/doc/sam/mkfile
	/n/sourcesdump/2006/0128/plan9/sys/doc/sam/mkfile:11,14 - 
	/n/sourcesdump/2006/0129/plan9/sys/doc/sam/mkfile:11,15
	  	troff -ms sam.tut > sam.tut.out
	  
	  sam.html:D:	sam.ms fig1.ps fig2.ps fig3.ps fig4.ps fig5.pic fig6.pic fig7.pic refs
	- 	{echo $FONTS; cat sam.ms refs} | pic | tbl | ms2html >sam.html
	+ 	pic sam.ms refs | tbl | htmlroff -ms -mhtml >sam.html
	+ 

Fix a few floating-point conversions in 8c.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 23789 Jan 28 09:53 sys/src/cmd/8c/txt.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/8c/txt.c:791,799 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/8c/txt.c:791,797
	  	case CASE(	TFLOAT,	TSHORT):
	  	case CASE(	TFLOAT,	TUSHORT):
	  	case CASE(	TFLOAT,	TINT):
	- 	case CASE(	TFLOAT,	TUINT):
	  	case CASE(	TFLOAT,	TLONG):
	- 	case CASE(	TFLOAT,	TULONG):
	  	case CASE(	TFLOAT,	TIND):
	  
	  	case CASE(	TDOUBLE,TCHAR):
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/8c/txt.c:801,820 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/8c/txt.c:799,806
	  	case CASE(	TDOUBLE,TSHORT):
	  	case CASE(	TDOUBLE,TUSHORT):
	  	case CASE(	TDOUBLE,TINT):
	- 	case CASE(	TDOUBLE,TUINT):
	  	case CASE(	TDOUBLE,TLONG):
	- 	case CASE(	TDOUBLE,TULONG):
	  	case CASE(	TDOUBLE,TIND):
	- 
	- 	case CASE(	TVLONG,	TCHAR):
	- 	case CASE(	TVLONG,	TUCHAR):
	- 	case CASE(	TVLONG,	TSHORT):
	- 	case CASE(	TVLONG,	TUSHORT):
	- 	case CASE(	TVLONG,	TINT):
	- 	case CASE(	TVLONG,	TUINT):
	- 	case CASE(	TVLONG,	TLONG):
	- 	case CASE(	TVLONG,	TULONG):
	- 	case CASE(	TVLONG,	TIND):
	  		if(fproundflg) {
	  			regsalloc(&nod, &regnode);
	  			gins(AFMOVLP, f, &nod);
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/8c/txt.c:834,846 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/8c/txt.c:820,845
	  		return;
	  
	  /*
	+  * float to ulong
	+  */
	+ 	case CASE(	TDOUBLE,	TULONG):
	+ 	case CASE(	TFLOAT,	TULONG):
	+ 	case CASE(	TDOUBLE,	TUINT):
	+ 	case CASE(	TFLOAT,	TUINT):
	+ 		regsalloc(&nod, &regnode);
	+ 		gmove(f, &fregnode0);
	+ 		gins(AFADDD, nodfconst(-2147483648.), &fregnode0);
	+ 		gins(AFMOVLP, f, &nod);
	+ 		gins(ASUBL, nodconst(-2147483648), &nod);
	+ 		gmove(&nod, t);
	+ 		return;
	+ 
	+ /*
	   * ulong to float
	   */
	  	case CASE(	TULONG,	TDOUBLE):
	- 	case CASE(	TULONG,	TVLONG):
	  	case CASE(	TULONG,	TFLOAT):
	  	case CASE(	TUINT,	TDOUBLE):
	- 	case CASE(	TUINT,	TVLONG):
	  	case CASE(	TUINT,	TFLOAT):
	  		regalloc(&nod, f, f);
	  		gmove(f, &nod);
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/8c/txt.c:873,886 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/8c/txt.c:872,877
	  	case CASE(	TINT,	TDOUBLE):
	  	case CASE(	TLONG,	TDOUBLE):
	  	case CASE(	TIND,	TDOUBLE):
	- 
	- 	case CASE(	TCHAR,	TVLONG):
	- 	case CASE(	TUCHAR,	TVLONG):
	- 	case CASE(	TSHORT,	TVLONG):
	- 	case CASE(	TUSHORT,TVLONG):
	- 	case CASE(	TINT,	TVLONG):
	- 	case CASE(	TLONG,	TVLONG):
	- 	case CASE(	TIND,	TVLONG):
	  		regsalloc(&nod, &regnode);
	  		gmove(f, &nod);
	  		gins(AFMOVL, &nod, &fregnode0);
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/8c/txt.c:891,905 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/8c/txt.c:882,890
	   */
	  	case CASE(	TFLOAT,	TFLOAT):
	  	case CASE(	TDOUBLE,TFLOAT):
	- 	case CASE(	TVLONG,	TFLOAT):
	  
	  	case CASE(	TFLOAT,	TDOUBLE):
	  	case CASE(	TDOUBLE,TDOUBLE):
	- 	case CASE(	TVLONG,	TDOUBLE):
	- 
	- 	case CASE(	TFLOAT,	TVLONG):
	- 	case CASE(	TDOUBLE,TVLONG):
	- 	case CASE(	TVLONG,	TVLONG):
	  		a = AFMOVD;	break;
	  	}
	  	if(a == AMOVL || a == AFMOVD)

Handle not having graphics better.
 [rsc] --rw-rw-r-- M 1428987 rsc sys 6066 Jan 28 09:54 sys/src/cmd/aux/statusbar.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/aux/statusbar.c:200,211 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/aux/statusbar.c:200,214
	  		textmode = 1;
	  		rbar = Rect(0, 0, 60, 1);
	  	}else{
	- 		initdraw(0, 0, "bar");
	+ 		if(initdraw(0, 0, "bar") < 0)
	+ 			exits("initdraw");
	  		initcolor();
	  		einit(Emouse|Ekeyboard);
	  		eresized(0);
	  	}
	  	bar(&b);
	+ 
	+ 	exits(0);
	  }
	  
	  

Formatting nits.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 640 Jan 28 09:53 sys/include/trace.h
	/n/sourcesdump/2006/0128/plan9/sys/include/trace.h:19,24 - 
	/n/sourcesdump/2006/0129/plan9/sys/include/trace.h:19,24
	  typedef struct Traceevent	Traceevent;
	  struct Traceevent {
	  	ulong	pid;	
	- 	ulong	etype;		/* Event type */
	- 	vlong	time;		/* time stamp  */
	+ 	ulong	etype;	/* Event type */
	+ 	vlong	time;	/* time stamp  */
	  };

Update ms2html man page.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 1252 Jan 28 09:34 sys/man/1/ms2html
	/n/sourcesdump/2006/0128/plan9/sys/man/1/ms2html:2,10 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/1/ms2html:2,22
	  .SH NAME
	  ms2html, html2ms \- convert between troff's ms macros and html
	  .SH SYNOPSIS
	- .B ms2html < input > output
	+ .B ms2html
	+ [
	+ .B -q
	+ ] [
	+ .B -b
	+ .I basename
	+ ] [
	+ .B -d
	+ .I delims
	+ ] [
	+ .B -t
	+ .I title
	+ ]
	  .br
	- .B html2ms < input > output
	+ .B html2ms
	  .SH DESCRIPTION
	  .I Ms2html
	  converts the
	/n/sourcesdump/2006/0128/plan9/sys/man/1/ms2html:28,37 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/1/ms2html:40,74
	  macro, unknown to
	  .IR ms (6),
	  and take its value.
	+ Options are:
	+ .TF q
	+ .IP q
	+ suppresses warnings about malformed input;
	+ .IP b
	+ sets the HTML base name to
	+ .IR basename ;
	+ .IP d
	+ sets the
	+ .IR eqn (1)
	+ delimiters to
	+ .IR delim ;
	+ .IP t
	+ sets the HTML title to
	+ .IR title .
	+ .PD
	+ .PP
	+ .I Html2ms
	+ reads HTML from standard input and converts it
	+ to
	+ .IR ms (6)
	+ source on standard output.
	  .SH SOURCE
	  .B /sys/src/cmd/ms2html.c
	  .br
	  .B /sys/src/cmd/html2ms.c
	+ .SH SEE ALSO
	+ .IR htmlroff (1),
	+ .IR ms (6)
	  .SH BUGS
	  .PP
	  Ms2html doesn't understand a number of troff

Update example.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 13853 Jan 28 09:55 sys/man/8/prep
	/n/sourcesdump/2006/0128/plan9/sys/man/8/prep:668,674 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/8/prep:668,675
	  Create a Plan 9 boot floppy on a previously formatted diskette:
	  .IP
	  .EX
	- disk/format -b /386/pbs -df /dev/fd0disk /386/9load /tmp/plan9.ini
	+ disk/format -b /386/pbs -df /dev/fd0disk \e
	+ 	/386/9load /tmp/plan9.ini /386/9pcf.gz
	  .EE
	  .PP
	  Initialize the blank hard disk
	/n/sourcesdump/2006/0128/plan9/sys/man/8/prep:678,684 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/8/prep:679,686
	  disk/mbr -m /386/mbr /dev/sdC0/data
	  disk/fdisk -baw /dev/sdC0/data
	  disk/prep -bw -a^(9fat fs cache swap) /dev/sdC0/plan9
	- disk/format -b /386/pbslba -d -r 2 /dev/sdC0/9fat 9load 9pcdisk plan9.ini
	+ disk/format -b /386/pbslba -d -r 2 /dev/sdC0/9fat \e
	+ 	/386/9load /386/9pcf /tmp/plan9.ini
	  .EE
	  .PP
	  .SH SOURCE

Add needstack to libthread.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 3616 Jan 28 10:48 sys/include/thread.h
	/n/sourcesdump/2006/0128/plan9/sys/include/thread.h:69,74 - 
	/n/sourcesdump/2006/0129/plan9/sys/include/thread.h:69,75
	  int		nbsend(Channel *c, void *v);
	  int		nbsendp(Channel *c, void *v);
	  int		nbsendul(Channel *c, ulong v);
	+ void		needstack(int);
	  int		proccreate(void (*f)(void *arg), void *arg, uint stacksize);
	  int		procrfork(void (*f)(void *arg), void *arg, uint stacksize, int flag);
	  void**		procdata(void);
 [rsc] --rw-rw-r-- M 1428987 glenda sys 3342 Jan 28 10:47 sys/src/libthread/sched.c
	/n/sourcesdump/2006/0128/plan9/sys/src/libthread/sched.c:78,83 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/libthread/sched.c:78,101
	  }
	  
	  void
	+ needstack(int n)
	+ {
	+ 	int x;
	+ 	Proc *p;
	+ 	Thread *t;
	+ 	
	+ 	p = _threadgetproc();
	+ 	t = p->thread;
	+ 	
	+ 	if((uchar*)&x - n < (uchar*)t->stk){
	+ 		fprint(2, "%s %d: &x=%p n=%d t->stk=%p\n",
	+ 			argv0, getpid(), &x, n, t->stk);
	+ 		fprint(2, "%s %d: stack overflow\n", argv0, getpid());
	+ 		abort();
	+ 	}
	+ }
	+ 
	+ void
	  _sched(void)
	  {
	  	Proc *p;
	/n/sourcesdump/2006/0128/plan9/sys/src/libthread/sched.c:86,93 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/libthread/sched.c:104,110
	  Resched:
	  	p = _threadgetproc();
	  	if((t = p->thread) != nil){
	- 		if((uchar*)&p < t->stk)		/* stack overflow */
	- 			abort();
	+ 		needstack(128);
	  		_threaddebug(DBGSCHED, "pausing, state=%s", psstate(t->state));
	  		if(setjmp(t->sched)==0)
	  			longjmp(p->sched, 1);

Add fpr to print floating-point registers.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 3268 Jan 28 11:01 sys/lib/acid/386
	/n/sourcesdump/2006/0128/plan9/sys/lib/acid/386:59,64 - 
	/n/sourcesdump/2006/0129/plan9/sys/lib/acid/386:59,84
	  	gpr();
	  }
	  
	+ defn fpr()
	+ {
	+ 	print("F0\t",  *fmt(F0, 'g'), "\n");
	+ 	print("F1\t",  *fmt(F1, 'g'), "\n");
	+ 	print("F2\t",  *fmt(F2, 'g'), "\n");
	+ 	print("F3\t",  *fmt(F3, 'g'), "\n");
	+ 	print("F4\t",  *fmt(F4, 'g'), "\n");
	+ 	print("F5\t",  *fmt(F5, 'g'), "\n");
	+ 	print("F6\t",  *fmt(F6, 'g'), "\n");
	+ 	print("F7\t",  *fmt(F7, 'g'), "\n");
	+ 	print("control\t", *fmt(E0, 'x'), "\n");
	+ 	print("status\t", *fmt(E1, 'x'), "\n");
	+ 	print("tag\t", *fmt(E2, 'x'), "\n");
	+ 	print("ip offset\t", *fmt(E3, 'X'), "\n");
	+ 	print("cs selector\t", *fmt(E4, 'x'), "\n");
	+ 	print("opcode\t", *fmt(E4>>8, 'x'), "\n");
	+ 	print("data operand offset\t", *fmt(E5, 'x'), "\n");
	+ 	print("operand selector\t", *fmt(E6, 'x'), "\n");
	+ }
	+ 
	  defn mmregs()
	  {
	  	print("MM0\t", *MM0, " MM1\t", *MM1, "\n");

8-bit safety in tbl.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 1414 Jan 28 10:55 sys/src/cmd/tbl/tc.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/tbl/tc.c:22,33 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/tbl/tc.c:22,39
	  				continue;
	  			s = table[ilin][icol].col;
	  			if (point(s))
	- 				while (*s)
	- 					had[*s++] = 1;
	+  				while (*s) {
	+  					if((unsigned char)*s < 128)
	+  						had[(unsigned char)*s] = 1;
	+  					s++;
	+  				}
	  			s = table[ilin][icol].rcol;
	  			if (point(s))
	- 				while (*s)
	- 					had[*s++] = 1;
	+  				while (*s) {
	+  					if((unsigned char)*s < 128)
	+  						had[(unsigned char)*s] = 1;
	+  					s++;
	+  				}
	  		}
	  	}
	  				/* choose first funny character */

Fiddling.
 [rsc] --rw-rw-r-- M 1428987 sape sys 30760 Jan 28 10:54 sys/src/games/music/jukebox/music.c
	[diffs elided - too long]
	[diff -c /n/sourcesdump/2006/0128/plan9/sys/src/games/music/jukebox/music.c /n/sourcesdump/2006/0129/plan9/sys/src/games/music/jukebox/music.c]
 [rsc] --rw-rw-r-- M 1428987 sape sys 1585 Jan 28 12:25 sys/src/games/music/playlistfs/boilerplate.c
	/n/sourcesdump/2006/0128/plan9/sys/src/games/music/playlistfs/boilerplate.c:65,71 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/games/music/playlistfs/boilerplate.c:65,71
	  	 * broadcast and putting themselves back on the
	  	 * queue before the broadcast has finished
	  	 */
	- 	marker.eventc = nil;
	+ 	marker.eventc = nil;	/* Only markers have eventc == nil */
	  	sendp(q, &marker);
	  	while((w = recvp(q)) != &marker){
	  		if(w->eventc == nil){

Don't profile getcallerpc.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 52 Jan 28 10:48 sys/src/libc/power/getcallerpc.s
	/n/sourcesdump/2006/0128/plan9/sys/src/libc/power/getcallerpc.s:1,4 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/libc/power/getcallerpc.s:1,4
	- TEXT	getcallerpc(SB), $-4
	+ TEXT	getcallerpc(SB),1,$-4
	  	MOVW	0(R1), R3
	  	RETURN
	  

Add != operator to snoopy, remove various stupid functions.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 4086 Jan 28 10:50 sys/man/8/snoopy
	/n/sourcesdump/2006/0128/plan9/sys/man/8/snoopy:64,69 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/8/snoopy:64,70
	  .EX
	  \fIexpr\fP:	  \fIprotocol\fP
	  	| \fIfield\fP '=' \fIvalue\fP
	+ 	| \fIfield\fP '!=' \fIvalue\fP
	  	| \fIprotocol\fP '(' \fIexpr\fP ')'
	  	| '(' \fIexpr\fP ')'
	  	| \fIexpr\fP '||' \fIexpr\fP
 [rsc] --rw-rw-r-- M 1428987 glenda sys 8958 Jan 28 10:49 sys/src/cmd/ip/snoopy/dhcp.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/dhcp.c:103,120 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/dhcp.c:103,108
	  	OP9auth=		129,	// plan9 auth servers
	  };
	  
	- static void
	- p_compile(Filter *f)
	- {
	- 	sysfatal("unknown bootp field: %s", f->s);
	- }
	- 
	- static int
	- p_filter(Filter *, Msg *)
	- {
	- 	return 0;
	- }
	- 
	  /*
	   *  convert a byte array to hex
	   */
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/dhcp.c:471,478 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/dhcp.c:459,466
	  Proto dhcp =
	  {
	  	"dhcp",
	- 	p_compile,
	- 	p_filter,
	+ 	nil,
	+ 	nil,
	  	p_seprint,
	  	nil,
	  	nil,
 [rsc] --rw-rw-r-- M 1428987 glenda sys 1078 Jan 28 10:49 sys/src/cmd/ip/snoopy/dump.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/dump.c:10,21 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/dump.c:10,15
	  {
	  }
	  
	- static int
	- p_filter(Filter *, Msg *)
	- {
	- 	return 0;
	- }
	- 
	  static char tohex[16] = {
	  	'0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
	  	'a', 'b', 'c', 'd', 'e', 'f'
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/dump.c:81,87 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/dump.c:75,81
	  {
	  	"dump",
	  	p_compile,
	- 	p_filter,
	+ 	nil,
	  	p_seprint,
	  	nil,
	  	nil,
 [rsc] --rw-rw-r-- M 1428987 glenda sys 1739 Jan 28 10:49 sys/src/cmd/ip/snoopy/filter.y
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/filter.y:12,17 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/filter.y:12,18
	  %term LOR
	  %term LAND
	  %term WORD
	+ %term NE
	  %right '!'
	  %left '|'
	  %left '&'
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/filter.y:27,32 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/filter.y:28,41
	  			{ $$ = $1; }
	  		| WORD '=' WORD
	  			{ $2->l = $1; $2->r = $3; $$ = $2; }
	+ 		| WORD NE WORD
	+ 			{ $2->l = newfilter();
	+ 			  $2->l->op = '=';
	+ 			  $2->l->l = $1;
	+ 			  $2->l->r = $3;
	+ 			  $2->op = '!';
	+ 			  $$ = $2;
	+ 			}
	  		| WORD '(' expr ')'
	  			{ $1->l = $3; free($2); free($4); $$ = $1; }
	  		| '(' expr ')'
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/filter.y:84,100 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/filter.y:93,110
	  	}
	  
	  	yylp++;
	- 	if(*yylp == c)
	- 		switch(c){
	- 		case '&':
	- 			c = LAND;
	- 			yylp++;
	- 			break;
	- 		case '|':
	- 			c = LOR;
	- 			yylp++;
	- 			break;
	- 		}
	+ 	if(c == '!' && *yylp == '='){
	+ 		c = NE;
	+ 		yylp++;
	+ 	}
	+ 	else if(c == '&' && *yylp == '&'){
	+ 		c = LAND;
	+ 		yylp++;
	+ 	}
	+ 	else if(c == '|' && *yylp == '|'){
	+ 		c = LOR;
	+ 		yylp++;
	+ 	}
	  	yylval->op = c;
	  	return c;
	  }
 [rsc] --rw-rw-r-- M 1428987 glenda sys 2261 Jan 28 10:49 sys/src/cmd/ip/snoopy/il.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/il.c:102,109 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/il.c:102,108
	  static char*
	  pkttype(int t)
	  {
	- 	char b[10];
	- 
	+ 	static char b[10];
	  	
	  	if(t > 6){
	  		sprint(b, "%d", t);
 [rsc] --rw-rw-r-- M 1428987 glenda sys 15607 Jan 28 10:49 sys/src/cmd/ip/snoopy/main.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/main.c:233,239 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/main.c:233,239
	  				return 0;
	  			m->needroot = 0;
	  		}else{
	- 			if(m->pr != nil && !(m->pr->filter)(f, m))
	+ 			if(m->pr && (m->pr->filter==nil || !(m->pr->filter)(f, m)))
	  				return 0;
	  		}
	  		if(f->l == nil)
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/main.c:650,657 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/main.c:650,660
	  		_compile(f->r, last);
	  		break;
	  	case WORD:
	- 		if(last != nil)
	+ 		if(last != nil){
	+ 			if(last->compile == nil)
	+ 				sysfatal("unknown %s subprotocol: %s", f->pr->name, f->s);
	  			(*last->compile)(f);
	+ 		}
	  		if(f->l)
	  			_compile(f->l, f->pr);
	  		break;
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/main.c:658,663 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/main.c:661,669
	  	case '=':
	  		if(last == nil)
	  			sysfatal("internal error: compilewalk: badly formed tree");
	+ 		
	+ 		if(last->compile == nil)
	+ 			sysfatal("unknown %s field: %s", f->pr->name, f->s);
	  		(*last->compile)(f);
	  		break;
	  	default:
 [rsc] --rw-rw-r-- M 1428987 glenda sys 879 Jan 28 10:50 sys/src/cmd/ip/snoopy/mkfile
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/mkfile:53,58 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/mkfile:53,60
	  	main.c\
	  	${POBJS:%.$O=%.c}\
	  
	+ CLEANFILES=protos.c protos.h
	+ 
	  </sys/src/cmd/mkone
	  
	  protos.h: mkfile
 [rsc] --rw-rw-r-- M 1428987 glenda sys 555 Jan 28 10:49 sys/src/cmd/ip/snoopy/ninep.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/ninep.c:5,23 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/ninep.c:5,11
	  #include "dat.h"
	  #include "protos.h"
	  
	- static void
	- p_compile(Filter *f)
	- {
	- 	sysfatal("unknown ninep field: %s", f->s);
	- }
	- 
	  static int
	- p_filter(Filter *, Msg *)
	- {
	- 	return 0;
	- }
	- 
	- static int
	  p_seprint(Msg *m)
	  {
	  	Fcall f;
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/ninep.c:44,51 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/ninep.c:32,39
	  Proto ninep =
	  {
	  	"ninep",
	- 	p_compile,
	- 	p_filter,
	+ 	nil,
	+ 	nil,
	  	p_seprint,
	  	nil,
	  	nil,
 [rsc] --rw-rw-r-- M 1428987 glenda sys 7369 Jan 28 10:49 sys/src/cmd/ip/snoopy/ospf.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/ospf.c:90,96 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/ospf.c:90,96
	  };
	  
	  char*
	- seprintospfhello(char *p, char *e, void *a, int)
	+ seprintospfhello(char *p, char *e, void *a)
	  {
	  	Ospfhello *h = a;
	  
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/ospf.c:327,344 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/ospf.c:327,332
	  	return seprint(p, e, ")");
	  }
	  
	- static void
	- p_compile(Filter *f)
	- {
	- 	sysfatal("unknown ospf field: %s", f->s);
	- }
	- 
	- static int
	- p_filter(Filter *, Msg *)
	- {
	- 	return 0;
	- }
	- 
	  int
	  p_seprint(Msg *m)
	  {
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/ospf.c:366,372 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/ospf.c:354,360
	  
	  	switch (ospf->type) {
	  	case OSPFhello:
	- 		p = seprintospfhello(p, e, ospf->data, x);
	+ 		p = seprintospfhello(p, e, ospf->data);
	  		break;
	  	case OSPFdd:
	  		p = seprintospfdatadesc(p, e, ospf->data, x);
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/ospf.c:392,399 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/ospf.c:380,387
	  Proto ospf =
	  {
	  	"ospf",
	- 	p_compile,
	- 	p_filter,
	+ 	nil,
	+ 	nil,
	  	p_seprint,
	  	nil,
	  	nil,
 [rsc] --rw-rw-r-- M 1428987 jmk sys 1818 Jan 28 10:49 sys/src/cmd/ip/snoopy/rtcp.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/rtcp.c:31,50 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/rtcp.c:31,37
	  	REPORTLEN = 24,
	  };
	  
	- 
	- static void
	- p_compile(Filter *f)
	- {
	- 	sysfatal("unknown rtcp field: %s", f->s);
	- }
	- 
	  static int
	- p_filter(Filter *, Msg *)
	- {
	- 	return 0;
	- }
	- 
	- static int
	  p_seprint(Msg *m)
	  {
	  	Hdr*h;
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/rtcp.c:86,93 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/rtcp.c:73,80
	  
	  Proto rtcp = {
	  	"rtcp",
	- 	p_compile,
	- 	p_filter,
	+ 	nil,
	+ 	nil,
	  	p_seprint,
	  	nil,
	  	nil,
 [rsc] --rw-rw-r-- M 1428987 jmk sys 1021 Jan 28 10:49 sys/src/cmd/ip/snoopy/rtp.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/rtp.c:17,36 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/rtp.c:17,23
	  	RTPLEN = 12,		// Minimum size of an RTP header
	  };
	  
	- 
	- static void
	- p_compile(Filter *f)
	- {
	- 	sysfatal("unknown rtp field: %s", f->s);
	- }
	- 
	  static int
	- p_filter(Filter *, Msg *)
	- {
	- 	return 0;
	- }
	- 
	- static int
	  p_seprint(Msg *m)
	  {
	  	Hdr*h;
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/ip/snoopy/rtp.c:65,72 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/ip/snoopy/rtp.c:52,59
	  
	  Proto rtp = {
	  	"rtp",
	- 	p_compile,
	- 	p_filter,
	+ 	nil,
	+ 	nil,
	  	p_seprint,
	  	nil,
	  	nil,

Various 64-bit fixes.
 [rsc] --rw-rw-r-- M 1428987 jmk sys 8788 Jan 28 10:53 sys/src/cmd/cc/scon.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/cc/scon.c:1,5 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/cc/scon.c:1,18
	  #include "cc.h"
	  
	+ static Node*
	+ acast(Type *t, Node *n)
	+ {
	+ 	if(n->type->etype != t->etype || n->op == OBIT) {
	+ 		n = new1(OCAST, n, Z);
	+ 		if(nocast(n->left->type, t))
	+ 			*n = *n->left;
	+ 		n->type = t;
	+ 	}
	+ 	return n;
	+ }
	+ 
	+ 
	  void
	  evconst(Node *n)
	  {
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/cc/scon.c:426,435 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/cc/scon.c:439,446
	  			if(c2 % c1)
	  				continue;
	  			r = trm[j].node;
	- 			if(r->type->etype != et) {
	- 				r = new1(OCAST, r, Z);
	- 				r->type = t;
	- 			}
	+ 			if(r->type->etype != et)
	+ 				r = acast(t, r);
	  			c2 = trm[j].mult/trm[i].mult;
	  			if(c2 != 1 && c2 != -1) {
	  				r = new1(OMUL, r, new(OCONST, Z, Z));
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/cc/scon.c:438,447 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/cc/scon.c:449,456
	  				r->right->vconst = c2;
	  			}
	  			l = trm[i].node;
	- 			if(l->type->etype != et) {
	- 				l = new1(OCAST, l, Z);
	- 				l->type = t;
	- 			}
	+ 			if(l->type->etype != et)
	+ 				l = acast(t, l);
	  			r = new1(OADD, l, r);
	  			r->type = t;
	  			if(c2 == -1)
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/cc/scon.c:468,477 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/cc/scon.c:477,484
	  		if(c1 == 0)
	  			continue;
	  		r = trm[i].node;
	- 		if(r->type->etype != et || r->op == OBIT) {
	- 			r = new1(OCAST, r, Z);
	- 			r->type = t;
	- 		}
	+ 		if(r->type->etype != et || r->op == OBIT)
	+ 			r = acast(t, r);
	  		if(c1 != 1 && c1 != -1) {
	  			r = new1(OMUL, r, new(OCONST, Z, Z));
	  			r->type = t;
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/cc/scon.c:576,582 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/cc/scon.c:583,589
	  
	  	if(n != Z)
	  	if(!typefd[n->type->etype])
	- 	if(!typev[n->type->etype])
	+ 	if(!typev[n->type->etype] || ewidth[TVLONG] == ewidth[TIND])
	  	switch(n->op) {
	  
	  	case OCAST:
 [rsc] --rw-rw-r-- M 1428987 glenda sys 34377 Jan 28 10:53 sys/src/cmd/cc/sub.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/cc/sub.c:684,690 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/cc/sub.c:684,690
	  	if(n->op == OSUB)
	  	if(i == TIND && j == TIND) {
	  		w = n->right->type->link->width;
	- 		if(w < 1)
	+ 		if(w < 1 || n->left->type->link == T || n->left->type->link->width < 1)
	  			goto bad;
	  		n->type = types[ewidth[TIND] <= ewidth[TLONG]? TLONG: TVLONG];
	  		if(1 && ewidth[TIND] > ewidth[TLONG]){

Add IP-based checking to fossil.
 [rsc] --rw-rw-r-- M 1428987 jmk sys 4438 Jan 28 11:32 sys/src/cmd/fossil/9.h
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9.h:44,57 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9.h:44,62
	  	MsgF		= 4,
	  };
	  
	+ enum {
	+ 	ConNoneAllow	= 1<<0,
	+ 	ConNoAuthCheck	= 1<<1,
	+ 	ConNoPermCheck	= 1<<2,
	+ 	ConWstatAllow	= 1<<3,
	+ 	ConIPCheck	= 1<<4,
	+ };
	  struct Con {
	  	char*	name;
	  	uchar*	data;			/* max, not negotiated */
	  	int	isconsole;		/* immutable */
	- 	int	noauth;			/* immutable */
	- 	int	noperm;			/* immutable */
	- 	int	wstatallow;		/* immutable */
	- 
	+ 	int	flags;		/* immutable */
	+ 	char		remote[128];	/* immutable */
	  	VtLock*	lock;
	  	int	state;
	  	int	fd;
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9.h:191,197 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9.h:196,202
	  /*
	   * 9proc.c
	   */
	- extern Con* conAlloc(int, char*);
	+ extern Con* conAlloc(int, char*, int);
	  extern void conInit(void);
	  extern void msgFlush(Msg*);
	  extern void msgInit(void);
 [rsc] --rw-rw-r-- M 1428987 rsc sys 3863 Jan 28 11:32 sys/src/cmd/fossil/9auth.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9auth.c:84,93 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9auth.c:84,99
	  		 * authentication.
	  		 */
	  		vtRLock(con->alock);
	- 		if(!con->isconsole &&
	- 		(strcmp(fid->uname, unamenone) != 0 || !con->aok)){
	+ 		if(con->isconsole){
	+ 			/* anything goes */
	+ 		}else if((con->flags&ConNoneAllow) || con->aok){
	+ 			consPrint("attach %s as %s: allowing as none\n", fsysGetName(fsys), fid->uname);
	+ 			vtMemFree(fid->uname);
	+ 			fid->uname = vtStrDup(unamenone);
	+ 		}else{
	  			vtRUnlock(con->alock);
	  			consPrint("attach %s as %s: connection not authenticated, not console\n", fsysGetName(fsys), fid->uname);
	+ 			vtSetError("cannot attach as none before authentication");
	  			return 0;
	  		}
	  		vtRUnlock(con->alock);
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9auth.c:94,99 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9auth.c:100,106
	  
	  		if((fid->uid = uidByUname(fid->uname)) == nil){
	  			consPrint("attach %s as %s: unknown uname\n", fsysGetName(fsys), fid->uname);
	+ 			vtSetError("unknown user");
	  			return 0;
	  		}
	  		return 1;
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9auth.c:101,106 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9auth.c:108,114
	  
	  	if((afid = fidGet(con, t->afid, 0)) == nil){
	  		consPrint("attach %s as %s: bad afid\n", fsysGetName(fsys), fid->uname);
	+ 		vtSetError("bad authentication fid");
	  		return 0;
	  	}
	  
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9auth.c:111,121 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9auth.c:119,131
	  	if(!(afid->qid.type & QTAUTH)){
	  		consPrint("attach %s as %s: afid not an auth file\n", fsysGetName(fsys), fid->uname);
	  		fidPut(afid);
	+ 		vtSetError("bad authentication fid");
	  		return 0;
	  	}
	  	if(strcmp(afid->uname, fid->uname) != 0 || afid->fsys != fsys){
	  		consPrint("attach %s as %s: afid is for %s as %s\n", fsysGetName(fsys), fid->uname, fsysGetName(afid->fsys), afid->uname);
	  		fidPut(afid);
	+ 		vtSetError("attach/auth mismatch");
	  		return 0;
	  	}
	  
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9auth.c:125,130 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9auth.c:135,141
	  			vtUnlock(afid->alock);
	  			consPrint("attach %s as %s: %R\n", fsysGetName(fsys), fid->uname);
	  			fidPut(afid);
	+ 			vtSetError("authentication protocol not finished");
	  			return 0;
	  		}
	  	}
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9auth.c:134,139 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9auth.c:145,151
	  	if((fid->uid = uidByUname(afid->cuname)) == nil){
	  		consPrint("attach %s as %s: unknown cuname %s\n", fsysGetName(fsys), fid->uname, afid->cuname);
	  		fidPut(afid);
	+ 		vtSetError("unknown user");
	  		return 0;
	  	}
	  
 [rsc] --rw-rw-r-- M 1428987 rsc sys 3024 Jan 28 12:31 sys/src/cmd/fossil/9lstn.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9lstn.c:5,10 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9lstn.c:5,11
	  typedef struct Lstn Lstn;
	  typedef struct Lstn {
	  	int	afd;
	+ 	int	flags;
	  	char*	address;
	  	char	dir[NETPATHLEN];
	  
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9lstn.c:45,51 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9lstn.c:46,52
	  	Lstn *lstn;
	  	int dfd, lfd;
	  	char newdir[NETPATHLEN];
	- 
	+ 	
	   	vtThreadSetName("listen");
	  
	  	lstn = a;
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9lstn.c:54,71 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9lstn.c:55,70
	  			fprint(2, "listen: listen '%s': %r", lstn->dir);
	  			break;
	  		}
	- 
	  		if((dfd = accept(lfd, newdir)) >= 0)
	- 			conAlloc(dfd, newdir);
	+ 			conAlloc(dfd, newdir, lstn->flags);
	  		else
	- 			fprint(2, "listen: accept '%s': %r", newdir);
	- 		close(lfd);
	+ 			fprint(2, "listen: accept %s: %r\n", newdir);
	  	}
	  	lstnFree(lstn);
	  }
	  
	  static Lstn*
	- lstnAlloc(char* address)
	+ lstnAlloc(char* address, int flags)
	  {
	  	int afd;
	  	Lstn *lstn;
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9lstn.c:89,94 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9lstn.c:88,94
	  	lstn = vtMemAllocZ(sizeof(Lstn));
	  	lstn->afd = afd;
	  	lstn->address = vtStrDup(address);
	+ 	lstn->flags = flags;
	  	memmove(lstn->dir, dir, NETPATHLEN);
	  
	  	if(lbox.tail != nil){
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9lstn.c:114,125 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9lstn.c:114,125
	  static int
	  cmdLstn(int argc, char* argv[])
	  {
	- 	int dflag;
	+ 	int dflag, flags;
	  	Lstn *lstn;
	- 	char *usage = "usage: listen [-d] [address]";
	+ 	char *usage = "usage: listen [-dIN] [address]";
	  
	  	dflag = 0;
	- 
	+ 	flags = 0;
	  	ARGBEGIN{
	  	default:
	  		return cliError(usage);
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9lstn.c:126,131 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9lstn.c:126,137
	  	case 'd':
	  		dflag = 1;
	  		break;
	+ 	case 'I':
	+ 		flags |= ConIPCheck;
	+ 		break;
	+ 	case 'N':
	+ 		flags |= ConNoneAllow;
	+ 		break;
	  	}ARGEND
	  
	  	switch(argc){
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9lstn.c:139,145 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9lstn.c:145,151
	  		break;
	  	case 1:
	  		if(!dflag){
	- 			if(lstnAlloc(argv[0]) == nil)
	+ 			if(lstnAlloc(argv[0], flags) == nil)
	  				return 0;
	  			break;
	  		}
 [rsc] --rw-rw-r-- M 1428987 rsc sys 22935 Jan 28 11:32 sys/src/cmd/fossil/9p.c
	[diffs elided - too long]
	[diff -c /n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9p.c /n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9p.c]
 [rsc] --rw-rw-r-- M 1428987 rsc sys 15148 Jan 28 12:31 sys/src/cmd/fossil/9proc.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9proc.c:63,69 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9proc.c:63,69
	  	}
	  	con->state = ConDead;
	  	con->aok = 0;
	- 	con->noauth = con->noperm = con->wstatallow = 0;
	+ 	con->flags = 0;
	  	con->isconsole = 0;
	  
	  	vtLock(cbox.alock);
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9proc.c:502,510 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9proc.c:502,512
	  }
	  
	  Con*
	- conAlloc(int fd, char* name)
	+ conAlloc(int fd, char* name, int flags)
	  {
	  	Con *con;
	+ 	char buf[128], *p;
	+ 	int rfd, n;
	  
	  	vtLock(cbox.alock);
	  	while(cbox.ahead == nil){
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9proc.c:558,565 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9proc.c:560,578
	  		con->name = vtStrDup(name);
	  	else
	  		con->name = vtStrDup("unknown");
	- 	con->aok = 0;
	- 	con->noauth = con->noperm = con->wstatallow = 0;
	+ 	con->remote[0] = 0;
	+ 	snprint(buf, sizeof buf, "%s/remote", con->name);
	+ 	if((rfd = open(buf, OREAD)) >= 0){
	+ 		n = read(rfd, buf, sizeof buf-1);
	+ 		close(rfd);
	+ 		if(n > 0){
	+ 			buf[n] = 0;
	+ 			if((p = strchr(buf, '\n')) != nil)
	+ 				*p = 0;
	+ 			strecpy(con->remote, con->remote+sizeof con->remote, buf);
	+ 		}
	+ 	}
	+ 	con->flags = flags;
	  	con->isconsole = 0;
	  	vtUnlock(cbox.alock);
	  
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9proc.c:692,698 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9proc.c:705,711
	  cmdWho(int argc, char* argv[])
	  {
	  	char *usage = "usage: who";
	- 	int i;
	+ 	int i, l1, l2, l;
	  	Con *con;
	  	Fid *fid, *last;
	  
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9proc.c:705,712 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9proc.c:718,733
	  		return cliError(usage);
	  
	  	vtRLock(cbox.clock);
	+ 	l1 = 0;
	+ 	l2 = 0;
	  	for(con=cbox.chead; con; con=con->cnext){
	- 		consPrint("\t%q:", con->name);
	+ 		if((l = strlen(con->name)) > l1)
	+ 			l1 = l;
	+ 		if((l = strlen(con->remote)) > l2)
	+ 			l2 = l;
	+ 	}
	+ 	for(con=cbox.chead; con; con=con->cnext){
	+ 		consPrint("\t%-*s %-*s", l1, con->name, l2, con->remote);
	  		vtLock(con->fidlock);
	  		last = nil;
	  		for(i=0; i<NFidHash; i++)
 [rsc] --rw-rw-r-- M 1428987 rsc sys 3956 Jan 28 11:32 sys/src/cmd/fossil/9srv.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9srv.c:131,139 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9srv.c:131,141
	  	Con *con;
	  	Srv *srv;
	  	char *usage = "usage: srv [-APWdp] [service]";
	- 	int Aflag, Pflag, Wflag, dflag, fd[2], mode, pflag, r;
	+ 	int conflags, dflag, fd[2], mode, pflag, r;
	  
	- 	Aflag = Pflag = Wflag = dflag = pflag = 0;
	+ 	dflag = 0;
	+ 	pflag = 0;
	+ 	conflags = 0;
	  	mode = 0666;
	  
	  	ARGBEGIN{
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9srv.c:140,153 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9srv.c:142,161
	  	default:
	  		return cliError(usage);
	  	case 'A':
	- 		Aflag = 1;
	+ 		conflags |= ConNoAuthCheck;
	  		break;
	+ 	case 'I':
	+ 		conflags |= ConIPCheck;
	+ 		break;
	+ 	case 'N':
	+ 		conflags |= ConNoneAllow;
	+ 		break;
	  	case 'P':
	- 		Pflag = 1;
	+ 		conflags |= ConNoPermCheck;
	  		mode = 0600;
	  		break;
	  	case 'W':
	- 		Wflag = 1;
	+ 		conflags |= ConWstatAllow;
	  		mode = 0600;
	  		break;
	  	case 'd':
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9srv.c:159,165 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9srv.c:167,173
	  		break;
	  	}ARGEND
	  
	- 	if(pflag && Pflag){
	+ 	if(pflag && (conflags&ConNoPermCheck)){
	  		vtSetError("srv: cannot use -P with -p");
	  		return 0;
	  	}
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/9srv.c:207,221 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/9srv.c:215,225
	  	if(pflag)
	  		r = consOpen(fd[1], srv->srvfd, -1);
	  	else{
	- 		con = conAlloc(fd[1], srv->mntpnt);
	+ 		con = conAlloc(fd[1], srv->mntpnt, conflags);
	  		if(con == nil)
	  			r = 0;
	- 		else{
	+ 		else
	  			r = 1;
	- 			con->noauth = Aflag;
	- 			con->noperm = Pflag;
	- 			con->wstatallow = Wflag;
	- 		}
	  	}
	  	if(r == 0){
	  		close(fd[1]);
 [rsc] --rw-rw-r-- M 1428987 rsc sys 7985 Jan 28 11:32 sys/src/cmd/fossil/Ccmd.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/fossil/Ccmd.c:446,452 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/fossil/Ccmd.c:446,452
	  
	  	if(pipe(cbox.confd) < 0)
	  		return 0;
	- 	if((cbox.con = conAlloc(cbox.confd[1], "console")) == nil){
	+ 	if((cbox.con = conAlloc(cbox.confd[1], "console", 0)) == nil){
	  		close(cbox.confd[0]);
	  		close(cbox.confd[1]);
	  		cbox.confd[0] = cbox.confd[1] = -1;
 [rsc] --rw-rw-r-- M 1428987 rsc sys 18276 Jan 28 11:37 sys/man/8/fossilcons
	/n/sourcesdump/2006/0128/plan9/sys/man/8/fossilcons:33,39 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/8/fossilcons:33,39
	  .PP
	  .B listen
	  [
	- .B -d
	+ .B -INd
	  ]
	  [
	  .I address
	/n/sourcesdump/2006/0128/plan9/sys/man/8/fossilcons:400,405 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/8/fossilcons:400,427
	  .I listen
	  to remove the listener
	  at the given address.
	+ By default, the user
	+ .I none
	+ is only allowed to attach on a connection after
	+ at least one other user has successfully attached.
	+ The
	+ .B -N
	+ flag allows connections from
	+ .I none
	+ at any time.
	+ The
	+ .B -I
	+ flag causes
	+ .I fossil
	+ to check the IP address of incoming connections
	+ against
	+ .BR /mnt/ipok ,
	+ rejecting attaches from disallowed addresses.
	+ This mechanism is not intended for general use.
	+ The server
	+ .I sources.cs.bell-labs.com
	+ uses it to comply with U.S. crytography
	+ export regulations.
	  .PP
	  .I Msg
	  prints the maximum internal 9P message queue size
 [rsc] --rw-rw-r-- M 1428987 rsc sys 3024 Jan 28 12:31 sys/src/cmd/fossil/9lstn.c
 [rsc] --rw-rw-r-- M 1428987 rsc sys 15148 Jan 28 12:31 sys/src/cmd/fossil/9proc.c

Look in /nvram.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 8809 Jan 28 12:26 sys/src/libauthsrv/readnvram.c
	/n/sourcesdump/2006/0128/plan9/sys/src/libauthsrv/readnvram.c:40,45 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/libauthsrv/readnvram.c:40,46
	  	"mips", "#r/nvram", 1024+900, sizeof(Nvrsafe),
	  	"power", "#F/flash/flash0", 0x440000, sizeof(Nvrsafe),
	  	"power", "#r/nvram", 4352, sizeof(Nvrsafe),	/* OK for MTX-604e */
	+ 	"power", "/nvram", 0, sizeof(Nvrsafe),	/* OK for Ucu */
	  	"debug", "/tmp/nvram", 0, sizeof(Nvrsafe),
	  };
	  

Add contact info.
 [rsc] --rw-rw-r-- M 1428987 rsc drawterm 1002 Jan 28 12:25 sys/src/cmd/unix/drawterm/README
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/unix/drawterm/README:19,24 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/unix/drawterm/README:19,25
	  ---------
	  See http://swtch.com/drawterm/
	  
	+ 
	  SOURCE
	  ------
	  Use CVS: cvs -d :pserver:anoncvs@cvs.pdos.csail.mit.edu:/cvs co drawterm
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/unix/drawterm/README:25,30 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/unix/drawterm/README:26,37
	  On the web at http://cvs.pdos.csail.mit.edu/cvs/drawterm
	  In the Plan 9 distribution: /sys/src/cmd/unix/drawterm
	  
	+ 
	+ HELP
	+ ----
	+ Email Russ Cox <rsc@swtch.com> with bug reports or problems.
	+ 
	+ 
	  TO DO:
	  ------
	  
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/unix/drawterm/README:34,37 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/unix/drawterm/README:41,46
	  	9term window instead.
	  
	  - Should implement /dev/label.
	+ 
	+ 
	  

Clean up _MAGIC handling.
 [jmk] --rw-rw-r-- M 1428987 glenda sys 8621 Jan 28 12:56 sys/include/mach.h
	/n/sourcesdump/2006/0128/plan9/sys/include/mach.h:217,225 - 
	/n/sourcesdump/2006/0129/plan9/sys/include/mach.h:217,226
	  typedef struct Fhdr
	  {
	  	char	*name;		/* identifier of executable */
	- 	uchar	type;		/* file type - see codes above*/
	+ 	uchar	type;		/* file type - see codes above */
	  	uchar	hdrsz;		/* header size */
	- 	uchar	spare[2];
	+ 	uchar	_magic;		/* _MAGIC() magic */
	+ 	uchar	spare;
	  	long	magic;		/* magic number */
	  	uvlong	txtaddr;	/* text address */
	  	vlong	txtoff;		/* start of text in file */

Better error messages.
 [jmk] --rw-rw-r-- M 1428987 glenda sys 4930 Jan 28 12:57 sys/src/cmd/venti/config.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/venti/config.c:113,123 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/venti/config.c:113,123
	  			config->naparts++;
	  		}else if(i == 2 && strcmp(flds[0], "index") == 0){
	  			if(!nameOk(flds[1])){
	- 				setErr(EAdmin, "illegal index name %s in config file %s", flds[1], config);
	+ 				setErr(EAdmin, "illegal index name %s in config file %s", flds[1], file);
	  				break;
	  			}
	  			if(config->index != nil){
	- 				setErr(EAdmin, "duplicate indices in config file %s", config);
	+ 				setErr(EAdmin, "duplicate indices in config file %s", file);
	  				break;
	  			}
	  			config->index = estrdup(flds[1]);
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/venti/config.c:124,134 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/venti/config.c:124,134
	  		}else if(i == 2 && strcmp(flds[0], "bcmem") == 0){
	  			if(!numOk(flds[1])){
	  				setErr(EAdmin, "illegal size %s in config file %s",
	- 					flds[1], config);
	+ 					flds[1], file);
	  				break;
	  			}
	  			if(config->bcmem != 0){
	- 				setErr(EAdmin, "duplicate bcmem lines in config file %s", config);
	+ 				setErr(EAdmin, "duplicate bcmem lines in config file %s", file);
	  				break;
	  			}
	  			config->bcmem = unittoull(flds[1]);
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/venti/config.c:135,145 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/venti/config.c:135,145
	  		}else if(i == 2 && strcmp(flds[0], "mem") == 0){
	  			if(!numOk(flds[1])){
	  				setErr(EAdmin, "illegal size %s in config file %s",
	- 					flds[1], config);
	+ 					flds[1], file);
	  				break;
	  			}
	  			if(config->mem != 0xFFFFFFFFUL){
	- 				setErr(EAdmin, "duplicate mem lines in config file %s", config);
	+ 				setErr(EAdmin, "duplicate mem lines in config file %s", file);
	  				break;
	  			}
	  			config->mem = unittoull(flds[1]);
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/venti/config.c:146,156 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/venti/config.c:146,156
	  		}else if(i == 2 && strcmp(flds[0], "icmem") == 0){
	  			if(!numOk(flds[1])){
	  				setErr(EAdmin, "illegal size %s in config file %s",
	- 					flds[1], config);
	+ 					flds[1], file);
	  				break;
	  			}
	  			if(config->icmem != 0){
	- 				setErr(EAdmin, "duplicate icmem lines in config file %s", config);
	+ 				setErr(EAdmin, "duplicate icmem lines in config file %s", file);
	  				break;
	  			}
	  			config->icmem = unittoull(flds[1]);
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/venti/config.c:158,183 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/venti/config.c:158,183
	  			config->queueWrites = 1;
	  		}else if(i == 2 && strcmp(flds[0], "httpaddr") == 0){
	  			if(!nameOk(flds[1])){
	- 				setErr(EAdmin, "illegal http address '%s' in configuration file %s", flds[1], config);
	+ 				setErr(EAdmin, "illegal http address '%s' in configuration file %s", flds[1], file);
	  				break;
	  			}
	  			if(config->haddr){
	- 				setErr(EAdmin, "duplicate httpaddr lines in configuration file %s", config);
	+ 				setErr(EAdmin, "duplicate httpaddr lines in configuration file %s", file);
	  				break;
	  			}
	  			config->haddr = estrdup(flds[1]);
	  		}else if(i == 2 && strcmp(flds[0], "addr") == 0){
	  			if(!nameOk(flds[1])){
	- 				setErr(EAdmin, "illegal venti address '%s' in configuration file %s", flds[1], config);
	+ 				setErr(EAdmin, "illegal venti address '%s' in configuration file %s", flds[1], file);
	  				break;
	  			}
	  			if(config->vaddr){
	- 				setErr(EAdmin, "duplicate addr lines in configuration file %s", config);
	+ 				setErr(EAdmin, "duplicate addr lines in configuration file %s", file);
	  				break;
	  			}
	  			config->vaddr = estrdup(flds[1]);
	  		}else{
	- 			setErr(EAdmin, "illegal line '%s' in configuration file %s", line, config);
	+ 			setErr(EAdmin, "illegal line '%s' in configuration file %s", line, file);
	  			break;
	  		}
	  		free(line);
 [jmk] --rw-rw-r-- M 1428987 glenda sys 2524 Jan 28 12:57 sys/src/cmd/venti/fmtindex.c
	/n/sourcesdump/2006/0128/plan9/sys/src/cmd/venti/fmtindex.c:43,49 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/cmd/venti/fmtindex.c:43,49
	  	file = argv[0];
	  
	  	if(!runConfig(file, &conf))
	- 		fatal("can't intialization config %s: %R", file);
	+ 		fatal("can't run config %s: %R", file);
	  	if(conf.index == nil)
	  		fatal("no index specified in %s", file);
	  	if(!nameOk(conf.index))

Handle kernel load addresses better.
 [jmk] --rw-rw-r-- M 1428987 glenda sys 2085 Jan 28 12:56 sys/src/libmach/2.c
	/n/sourcesdump/2006/0128/plan9/sys/src/libmach/2.c:76,82 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/libmach/2.c:76,82
	  	0,		/* value */
	  	0x2000,		/* page size */
	  	0x80000000ULL,	/* kernel base */
	- 	0,		/* kernel text mask */
	+ 	0x80000000ULL,	/* kernel text mask */
	  	0x7FFFFFFFULL,	/* user stack top */
	  	2,		/* quantization of pc */
	  	4,		/* szaddr */
 [jmk] --rw-rw-r-- M 1428987 glenda sys 1564 Jan 28 12:56 sys/src/libmach/5.c
	/n/sourcesdump/2006/0128/plan9/sys/src/libmach/5.c:54,60 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/libmach/5.c:54,60
	  	0,		/* static base register value */
	  	0x1000,		/* page size */
	  	0xC0000000ULL,	/* kernel base */
	- 	0,		/* kernel text mask */
	+ 	0xC0000000ULL,	/* kernel text mask */
	  	0x7FFFFFFFULL,	/* user stack top */
	  	4,		/* quantization of pc */
	  	4,		/* szaddr */
 [jmk] --rw-rw-r-- M 1428987 jmk sys 3482 Jan 28 12:56 sys/src/libmach/6.c
	/n/sourcesdump/2006/0128/plan9/sys/src/libmach/6.c:107,113 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/libmach/6.c:107,113
	  	0,			/* static base register value */
	  	0x1000,			/* page size */
	  	0xFFFFFFFF80110000ULL,	/* kernel base */
	- 	0,			/* kernel text mask */
	+ 	0xFFFF800000000000ULL,	/* kernel text mask */
	  	0x00007FFFFFFFF000ULL,	/* user stack top */
	  	1,			/* quantization of pc */
	  	8,			/* szaddr */
 [jmk] --rw-rw-r-- M 1428987 glenda sys 3310 Jan 28 12:57 sys/src/libmach/7.c
	/n/sourcesdump/2006/0128/plan9/sys/src/libmach/7.c:104,110 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/libmach/7.c:104,110
	  	0,		/* static base register value */
	  	0x2000,		/* page size */
	  	0x80000000ULL,	/* kernel base */
	- 	0,		/* kernel text mask */
	+ 	0xF0000000ULL,	/* kernel text mask */
	  	0x7FFFFFFFULL,	/* user stack top */
	  	4,		/* quantization of pc */
	  	4,		/* szaddr */
 [jmk] --rw-rw-r-- M 1428987 glenda sys 2071 Jan 28 12:57 sys/src/libmach/8.c
	/n/sourcesdump/2006/0128/plan9/sys/src/libmach/8.c:69,75 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/libmach/8.c:69,75
	  	0,		/* static base register value */
	  	0x1000,		/* page size */
	  	0x80100000ULL,	/* kernel base */
	- 	0,		/* kernel text mask */
	+ 	0xF0000000ULL,	/* kernel text mask */
	  	0x7FFFFFFFULL,	/* user stack top */
	  	1,		/* quantization of pc */
	  	4,		/* szaddr */
 [jmk] --rw-rw-r-- M 1428987 glenda sys 16006 Jan 28 12:56 sys/src/libmach/executable.c
	[diffs elided - too long]
	[diff -c /n/sourcesdump/2006/0128/plan9/sys/src/libmach/executable.c /n/sourcesdump/2006/0129/plan9/sys/src/libmach/executable.c]
 [jmk] --rw-rw-r-- M 1428987 glenda sys 3381 Jan 28 12:57 sys/src/libmach/k.c
	/n/sourcesdump/2006/0128/plan9/sys/src/libmach/k.c:108,114 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/libmach/k.c:108,114
	  	0,		/* value */
	  	0x1000,		/* page size */
	  	0xE0000000ULL,	/* kernel base */
	- 	0,		/* kernel text mask */
	+ 	0xE0000000ULL,	/* kernel text mask */
	  	0x7FFFFFFFULL,	/* user stack top */
	  	4,		/* quantization of pc */
	  	4,		/* szaddr */
 [jmk] --rw-rw-r-- M 1428987 glenda sys 26745 Jan 28 12:56 sys/src/libmach/sym.c
	/n/sourcesdump/2006/0128/plan9/sys/src/libmach/sym.c:103,109 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/libmach/sym.c:103,109
	  	nsym = 0;
	  	size = 0;
	  	for(p = symbols; size < fp->symsz; p++, nsym++) {
	- 		if(fp->magic & HDR_MAGIC){
	+ 		if(fp->_magic && (fp->magic & HDR_MAGIC)){
	  			svalsz = 8;
	  			if(Bread(&b, &vl, 8) != 8)
	  				return symerrmsg(8, "symbol");
 [jmk] --rw-rw-r-- M 1428987 jmk sys 3447 Jan 28 12:56 sys/src/libmach/u.c
	/n/sourcesdump/2006/0128/plan9/sys/src/libmach/u.c:109,115 - 
	/n/sourcesdump/2006/0129/plan9/sys/src/libmach/u.c:109,115
	  	0,		/* value */
	  	0x2000,		/* page size */
	  	0x80000000ULL,	/* kernel base */
	- 	0,		/* kernel text mask */
	+ 	0x80000000ULL,	/* kernel text mask */
	  	0x7FFFFFFFULL,	/* user stack top */
	  	4,		/* quantization of pc */
	  	4,		/* szaddr */

Clean up -c and -s.
 [rsc] --rw-rw-r-- M 1428987 glenda sys 21811 Jan 28 15:02 sys/src/cmd/replica/applylog.c
	[diffs elided - too long]
	[diff -c /n/sourcesdump/2006/0128/plan9/sys/src/cmd/replica/applylog.c /n/sourcesdump/2006/0129/plan9/sys/src/cmd/replica/applylog.c]
 [rsc] --rw-rw-r-- M 1428987 glenda sys 843 Jan 28 15:03 rc/bin/replica/defs
	/n/sourcesdump/2006/0128/plan9/rc/bin/replica/defs:19,24 - 
	/n/sourcesdump/2006/0129/plan9/rc/bin/replica/defs:19,28
	  
	  opt=()
	  while(! ~ $#* 0 && ~ $1 -*){
	+ 	if(~ $1 -s -c){	# take one argument 
	+ 		opt=($opt $1)
	+ 		shift
	+ 	}
	  	opt=($opt $1)
	  	shift
	  }
 [rsc] --rw-rw-r-- M 1428987 glenda sys 21811 Jan 28 15:02 sys/src/cmd/replica/applylog.c
 [rsc] --rwxrwxr-x M 1428987 rsc sys 272 Jan 28 15:03 usr/glenda/bin/rc/pull
	/n/sourcesdump/2006/0128/plan9/usr/glenda/bin/rc/pull:3,8 - 
	/n/sourcesdump/2006/0129/plan9/usr/glenda/bin/rc/pull:3,12
	  rfork e
	  flags=()
	  while(! ~ $#* 0 && ~ $1 -*){
	+ 	if(~ $1 -c -s){
	+ 		flags=($flags $1)
	+ 		shift
	+ 	}
	  	flags=($flags $1)
	  	shift
	  }
 [rsc] --rw-rw-r-- M 1428987 glenda sys 843 Jan 28 15:03 rc/bin/replica/defs
 [rsc] --rw-rw-r-- M 1428987 glenda sys 7209 Jan 28 15:12 sys/man/1/replica
	/n/sourcesdump/2006/0128/plan9/sys/man/1/replica:4,13 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/1/replica:4,21
	  .SH SYNOPSIS
	  .B replica/pull
	  [
	- .B -cnsv
	+ .B -nv
	  ]
	+ [
	+ .B -c
	  .I name
	+ ]...
	  [
	+ .B -s
	+ .I name
	+ ]...
	+ .I name
	+ [
	  .I path
	  ...
	  ]
	/n/sourcesdump/2006/0128/plan9/sys/man/1/replica:160,174 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/1/replica:168,184
	  .B -c
	  flag to
	  .I pull
	- causes updates to be resolved using the client's copy,
	+ specifies that conflicts for paths beginning with
	+ .I name
	+ should be resolved using the client's copy,
	  while
	  .B -s
	  specifies the server's copy.
	- Typically these flags are only used when
	- invoking
	- .I pull
	- with a specific list of files that are known
	- to be conflicting.
	+ The 
	+ .B -c
	+ and
	+ .B -s
	+ options may be repeated.
	  .PP
	  .I Replica/changes
	  prints a list of local changes made on the client
	/n/sourcesdump/2006/0128/plan9/sys/man/1/replica:283,291 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/1/replica:293,328
	  To update your system, make sure you are connected
	  to the internet and run
	  .EX
	-     disk/kfscmd allow
	      replica/pull /dist/replica/network
	-     disk/kfscmd disallow
	+ .EE
	+ If conflicts are reported (say you have made local changes to 
	+ .B /rc/bin/cpurc
	+ and
	+ .BR /rc/bin/termrc ,
	+ but only want to keep the
	+ .B cpurc
	+ changes),
	+ use
	+ .EX
	+     replica/pull -c rc/bin/cpurc -s rc/bin/termrc /dist/replica/network
	+ .EE
	+ to instruct
	+ .I pull
	+ to ignore the server's change to 
	+ .BR cpurc .
	+ .PP
	+ The script
	+ .B /usr/glenda/bin/rc/pull
	+ runs 
	+ .I pull
	+ with the
	+ .B -v
	+ flag and with
	+ .B /dist/replica/network
	+ inserted at the right point on the command line.
	+ Logged in as glenda, one can repeat the above example with:
	+ .EX
	+     pull -c rc/bin/cpurc -s rc/bin/cpurc
	  .EE
	  .PP
	  To see a list of changes made to the local file system
 [rsc] --rw-rw-r-- M 1428987 glenda sys 6383 Jan 28 15:12 sys/man/8/replica
	/n/sourcesdump/2006/0128/plan9/sys/man/8/replica:34,41 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/8/replica:34,49
	  .br
	  .B replica/applylog
	  [
	- .B -cnsuv
	+ .B -nuv
	  ]
	+ [
	+ .B -c
	+ .I name
	+ ]...
	+ [
	+ .B -s
	+ .I name
	+ ]...
	  .I clientdb
	  .I clientroot
	  .I serverroot
	/n/sourcesdump/2006/0128/plan9/sys/man/8/replica:217,230 - 
	/n/sourcesdump/2006/0129/plan9/sys/man/8/replica:225,239
	  .B -c
	  flag is given, 
	  .I applylog
	- still takes no action, but does so silently and will not
	+ still takes no action for files beginning with the given names,
	+ but does so silently and will not
	  report the conflicts in the future.
	  (The conflict is resolved in favor of the client.)
	- If the
	+ The
	  .B -s
	- flag is given,
	+ is similar but causes 
	  .I applylog
	- overwrites the local changes.
	+ to overwrite the local changes.
	  (The conflict is resolved in favor of the server.)
	  .PP
	  .I Applychanges
 [rsc] --rw-rw-r-- M 1428987 glenda sys 21811 Jan 28 15:02 sys/src/cmd/replica/applylog.c

Add for /sys/doc/mkfile
 [rsc] --rwxrwxr-x M 1428987 rsc sys 48 Jan 28 20:35 sys/doc/mkdirlist
 [rsc] --rwxrwxr-x M 1428987 rsc sys 50 Jan 28 20:35 sys/doc/mkfilelist


Bell Labs OSI certified Powered by Plan 9

(Return to Plan 9 Home Page)

Copyright © 2021 Plan 9 Foundation. All Rights Reserved.
Comments to webmaster@9p.io.