shithub: riscv

Download patch

ref: 84076e37167a9329d70104a39ea398a9f676009d
parent: 3a3eb0434c3e5bc98b05a4a0a9752a1743b32512
author: Ori Bernstein <[email protected]>
date: Mon Jun 17 17:12:35 EDT 2019

Delete dead code.

	Nothing is using (or even building) bound.[ch]

--- a/sys/src/cmd/8c/bound.c
+++ /dev/null
@@ -1,1117 +1,0 @@
-#include "gc.h"
-#include "bound.h"
-
-static	BB*	bbfree;
-static	BBset*	bbsfree;
-static	int	bballoc;
-static	int	bbsalloc;
-static	BB	bbz;
-static	BBset	bbsz;
-static	BB*	firstbb;
-static	BB*	lastbb;
-static	BB*	wounded;
-static	BB*	bbaux;
-static	BBset*	recalc;
-static	BBset*	bbhash[BBHASH];
-static	BB**	ordered;
-static	int	bcount;
-static	BBset**	heap;
-static	int	heapn;
-static	int	bsize;
-static	char	bbbuff[BBBSIZE];
-static	int	bchange;
-
-#define	bdebug	(debug['v'])
-#define	dbg	0
-#define	bcheck	0
-
-static long
-Rn(Reg *r)
-{
-	if(r == R)
-		return -1;
-	return r->rpo;
-}
-
-static BB*
-bba(void)
-{
-	BB *b;
-
-	bballoc++;
-	b = bbfree;
-	if(b == nil) {
-		b = alloc(sizeof(*b));
-	} else
-		bbfree = b->link;
-
-	*b = bbz;
-	return b;
-}
-
-static void
-bfree(BB *b)
-{
-	bballoc--;
-	b->link = bbfree;
-	bbfree = b;
-}
-
-static BBset*
-bbsa(void)
-{
-	BBset *b;
-
-	bballoc++;
-	b = bbsfree;
-	if(b == nil) {
-		b = alloc(sizeof(*b));
-	} else
-		bbsfree = b->link;
-
-	*b = bbsz;
-	return b;
-}
-
-static void
-bsfree(BBset *b)
-{
-	bballoc--;
-	b->link = bbsfree;
-	bbsfree = b;
-}
-
-static void
-dumpheap(void)
-{
-	int i;
-
-	for(i = 1; i <= heapn; i++)
-		print(" %d", heap[i]->damage);
-}
-
-static void
-checkheap(void)
-{
-	int N, N2, n, c;
-
-	N = heapn;
-	N2 = N >> 1;
-	for(n = 1; n <= N2; n++) {
-		c = n << 1;
-		if((heap[c]->damage > heap[n]->damage)
-		|| ((c < N) && (heap[c + 1]->damage > heap[n]->damage))) {
-			print("bad heap (%d:%d) %d [", n, heap[n]->damage, heapn);
-			dumpheap();
-			print(" ]\n");
-			abort();
-		}
-	}
-}
-
-static void
-downheap(int n)
-{
-	int N, N2, d, c;
-	BBset *s, *t, *u;
-
-	s = heap[n];
-	d = s->damage;
-//print("down %d %d", n, d);
-	N = heapn;
-	N2 = N >> 1;
-	while(n <= N2) {
-		c = n << 1;
-		t = heap[c];
-		if(c < N) {
-			u = heap[c + 1];
-			if(t->damage < u->damage) {
-				t = u;
-				c++;
-			}
-		}
-//print(" [%d %d]", c, t->damage);
-		if(t->damage < d)
-			break;
-		heap[n] = t;
-		t->index = n;
-		n = c;
-	}
-	heap[n] = s;
-	s->index = n;
-//print("\n");
-//checkheap();
-}
-
-static void
-upheap(int n)
-{
-	int f, d;
-	BBset *s, *t;
-
-	s = heap[n];
-	d = s->damage;
-//print("up %d %d", n, d);
-	while(n > 1) {
-		f = n >> 1;
-		t = heap[f];
-//print(" [%d %d]", f, t->damage);
-		if(t->damage >= d)
-			break;
-		heap[n] = t;
-		t->index = n;
-		n = f;
-	}
-	heap[n] = s;
-	s->index = n;
-//print("\n");
-//checkheap();
-}
-
-static void
-heapremove(BBset *s)
-{
-	int x;
-	BBset *t;
-
-	x = s->index;
-	s->index = 0;
-	if(x == 0)
-		return;
-	if(x == heapn) {
-		heapn--;
-		return;
-	}
-	t = heap[heapn--];
-	heap[x] = t;
-	t->index = x;
-	if(s->damage < t->damage)
-		upheap(x);
-	else
-		downheap(x);
-}
-
-static void
-heapadd(BBset *s)
-{
-	int n;
-
-	n = heapn + 1;
-	heap[n] = s;
-	s->index = n;
-	heapn = n;
-	upheap(n);
-
-}
-
-static void
-bbsrecalc(BBset *s)
-{
-	if(s->recalc)
-		return;
-	s->recalc = 1;
-	s->link = recalc;
-	recalc = s;
-	heapremove(s);
-}
-
-static void
-bbadd(BB *b, Hval h)
-{
-	int k;
-	BBset *s;
-
-	k = h[0] & BBMASK;
-	for(s = bbhash[k]; s != nil; s = s->next) {
-		if(BBEQ(s->hash, h)) {
-			b->set = s;
-			b->link = s->ents;
-			s->ents = b;
-			bbsrecalc(s);
-			return;
-		}
-	}
-	s = bbsa();
-	s->next = bbhash[k];
-	bbhash[k] = s;
-	b->set = s;
-	b->link = nil;
-	s->ents = b;
-	BBCP(s->hash, h);
-	bbsrecalc(s);
-}
-
-static int
-hashbb(BB *b, Hval h)
-{
-	Reg *r;
-	Prog *p;
-	char *s;
-	int c, f, i, n;
-
-	r = b->first;
-	s = bbbuff;
-	i = 0;
-	n = BBBSIZE;
-	for(;;) {
-		p = r->prog;
-		if(p->as != ANOP) {
-			if(p->to.type == D_BRANCH)
-				p->to.offset = r->s2->rpo;
-			c = snprint(s, n, "%P", p);
-			s += c;
-			n -= c;
-			i++;
-		}
-		if(r == b->last)
-			break;
-		r = r->link;
-	}
-	if(n == 0)
-		return Bbig;
-	b->len = i;
-	BBMKHASH(bbbuff, BBBSIZE - n, h);
-	f = b->flags;
-	if(i == 1 && r->prog->as == AJMP && b->first->p1 == R)
-		f = Bjo;
-	else if(b->first->p1 != R)
-		f |= Bpre;
-	if(bdebug)
-		print("A %x %s %ux %ux\n", f, bbbuff, h[0], h[1]);
-	return f;
-}
-
-static void
-enterbb(BB *b)
-{
-	Hval h;
-
-	b->flags = hashbb(b, h);
-	if(b->flags != Bbig)
-		bbadd(b, h);
-}
-
-static void
-preproc(BB *b, int x)
-{
-	BB *n;
-	Reg *r;
-
-	ordered[x] = b;
-	if(b->last->rpo - b->first->rpo > BBBIG) {
-		b->flags = Bbig;
-		return;
-	}
-	if(b->first->p2 == nil) {
-		b->flags = Bdel;
-		return;
-	}
-	switch(b->last->prog->as) {
-	case ARET:
-	case AJMP:
-	case AIRETL:
-		break;
-
-	default:
-		b->flags = Bdel;
-		n = bba();
-		n->first = b->first;
-		for(r = b->last->link; r != R; r = r->link) {
-			switch(r->prog->as) {
-			case ARET:
-			case AJMP:
-			case AIRETL:
-				n->last = r;
-				n->flags = Bpin;
-				enterbb(n);
-				if(n->flags & Bpin) {
-					n->aux = bbaux;
-					bbaux = n;
-				}
-				else
-					bfree(n);
-				return;
-			}
-		}
-		bfree(n);
-		return;
-	}
-	enterbb(b);
-}
-
-static int
-p2len(Reg *r)
-{
-	int c;
-
-	c = 0;
-	for(r = r->p2; r != nil; r = r->p2link)
-		c++;
-	return c;
-}
-
-static void
-calcdamage(BBset *s)
-{
-	BB *f;
-	int d, t;
-
-	s->recalc = 0;
-	f = s->ents;
-	if(f == nil)
-		return;
-	if(f->flags & Bjo) {
-		if(bdebug)
-			print("add %ld jo\n", f->first->rpo);
-		s->damage = COSTJO;
-		heapadd(s);
-		return;
-	}
-	if(f->link == nil) {
-		if(bdebug)
-			print("solo %x %x\n", s->hash[0], s->hash[1]);
-		return;
-	}
-
-	d = 0;
-	t = 0;
-	while(f != nil) {
-		if((f->flags & (Bpre|Bpin)) == 0 && f->last->link != R) {
-			t = 1;
-			d += (f->last->rpo - f->first->rpo) >> 1;
-		}
-		d += p2len(f->first);
-		f = f->link;
-	}
-
-	if(t == 0) {
-		if(bdebug)
-			print("all pre %ld\n", s->ents->first->rpo);
-		return;
-	}
-
-	if(bdebug)
-		print("add %ld %d\n", s->ents->first->rpo, d);
-	if(d > COSTHI)
-		d = COSTHI;
-	s->damage = d;
-	heapadd(s);
-}
-
-static Reg*
-findjump(BB *b)
-{
-	Reg *r, *l;
-
-	r = b->first;
-	l = b->last;
-
-	for(;;) {
-		if(r->prog->as == AJMP)
-			break;
-		if(r == l) {
-			diag(Z, "findjump botch");
-			break;
-		}
-		r = r->link;
-	}
-	return r;
-}
-
-static BB*
-findset(int r)
-{
-	BB *s, **p;
-	int n, n2;
-
-	if(r < ordered[0]->first->rpo)
-		return nil;
-	n = bcount;
-	p = ordered;
-	while(n > 0) {
-		n2 = n >> 1;
-		s = p[n2];
-		if(r < s->first->rpo) {
-			n = n2;
-			continue;
-		}
-		if(r > s->last->rpo) {
-			n2++;
-			p += n2;
-			n -= n2;
-			continue;
-		}
-		return s;
-	}
-	diag(Z, "findset botch");
-	return nil;
-}
-
-static void
-wound(Reg *r)
-{
-	BB *b, *p, **n;
-	BBset *s;
-
-	b = findset(r->rpo);
-	if(b == nil)
-		return;
-	s = b->set;
-	if(s == nil)
-		return;
-	for(n = &s->ents; (p = *n) != nil; n = &(*n)->link) {
-		if(p == b) {
-			*n = b->link;
-			b->link = wounded;
-			wounded = b;
-			bbsrecalc(s);
-			return;
-		}
-	}
-}
-
-static void
-printbl(Reg *l)
-{
-	if(l == nil) {
-		print("Z");
-		return;
-	}
-
-	print("%ld", l->rpo);
-	while((l = l->p2link) != nil)
-		print(" %ld", l->rpo);
-}
-
-static void
-appset(Reg *e, Reg *s)
-{
-	for(;;) {
-		if(s->p2link == R) {
-			s->p2link = e;
-			return;
-		}
-		s = s->p2link;
-	}
-}
-
-static Reg*
-delset(Reg *e, Reg *s)
-{
-	Reg *c, *l;
-
-	c = s;
-	l = nil;
-	for(;;) {
-		if(e == c) {
-			if(l == nil)
-				return s->p2link;
-			l->p2link = c->p2link;
-			return s;
-		}
-		l = c;
-		c = c->p2link;
-		if(c == nil)
-			return s;
-	}
-}
-
-static void
-redest(Reg *s, Reg *d)
-{
-	while(s != R) {
-		s->s2 = d;
-		s = s->p2link;
-	}
-}
-
-static void
-changedest(Reg *s, Reg *d, int x)
-{
-	Reg *l;
-
-	if(bdebug) {
-		print("change %ld [", s->rpo);
-		printbl(s->p2);
-		print("] -> %ld [", d->rpo);
-		printbl(d->p2);
-		print("]\n");
-	}
-
-	if(s->p2 == nil) {
-//		print("deadjmp\n");
-		return;
-	}
-
-	l = s->p2;
-	for(;;) {
-		if(bdebug)
-			print("s2 %ld = %ld\n", l->rpo, d->rpo);
-		l->s2 = d;
-		wound(l);
-		if(l->p2link == nil)
-			break;
-		l = l->p2link;
-	}
-
-	if(x) {
-		l->p2link = delset(s, d->p2);
-		d->p2 = s->p2;
-	}
-	else {
-		l->p2link = d->p2;
-		d->p2 = s->p2;
-		s->p2 = nil;
-	}
-
-	if(bdebug) {
-		print("result [");
-		printbl(d->p2);
-		print("]\n");
-	}
-
-	bchange = 1;
-}
-
-static void
-bexcise(BB *b)
-{
-	Reg *r, *l;
-
-	l = b->last;
-	r = b->first;
-	if(bdebug)
-		print("excise %ld to %ld\n", r->rpo, l->rpo);
-	for(;;) {
-		r->prog->as = ANOP;
-		r->prog->to.type = D_NONE;
-		r->p2 = R;
-		if(r->s2 != R) {
-			r->s2->p2 = delset(r, r->s2->p2);
-			r->s2 = R;
-		}
-		if(r == l)
-			break;
-		r = r->link;
-	}
-}
-
-static int
-backtrack(Reg *s, Reg *d)
-{
-	int i;
-	char l[BINST], r[BINST];
-
-//print("backtrack %ld %ld\n", Rn(s), Rn(d));
-	i = 0;
-	while(s != nil && d != nil) {
-		if(snprint(l, BINST, "%P", s->prog) == BINST)
-			break;
-		if(snprint(r, BINST, "%P", d->prog) == BINST)
-			break;
-//print("%s\t%s\n", l, r);
-		if(strcmp(l, r) != 0)
-			break;
-		i++;
-		s = s->p2link;
-		d = d->p2link;
-	}
-	return i;
-}
-
-static void
-checktails(void)
-{
-	int c;
-	Reg *r;
-
-	c = 0;
-	for(r = firstr; r->link != R; r = r->link) {
-		if(r->prog->as == AJMP && r->s2 != nil)
-			c += backtrack(r->p1, r->s2->p1);
-	}
-
-	if(c > 0)
-		print("tails %s %d\n", firstr->prog->from.sym->name, c);
-}
-
-static void
-process(BBset *s)
-{
-	Reg *h;
-	BB *f, *o, *p, *t;
-
-	if(bdebug)
-		print("process %d %x %x\n", s->damage, s->hash[0], s->hash[1]);
-	f = s->ents;
-	if(f->flags & Bjo) {
-		s->ents = nil;
-		h = findjump(f)->s2;
-		o = nil;
-		while(f != nil) {
-			t = f->link;
-			if((f->flags & Bjo) != 0 && f->first->s2 != f->first) {
-				changedest(f->first, h, 1);
-				bexcise(f);
-			}
-			else {
-				f->link = o;
-				o = f;
-			}
-			f = t;
-		}
-		s->ents = o;
-	}
-	else {
-		o = nil;
-		p = nil;
-		while(f != nil) {
-			t = f->link;
-			if((f->flags & (Bpre|Bpin)) != 0 || (f->last->link == R)) {
-				f->link = p;
-				p = f;
-			}
-			else {
-				f->link = o;
-				o = f;
-			}
-			f = t;
-		}
-		if(o == nil) {
-			diag(Z, "all Bpre");
-			return;
-		}
-		if(p == nil) {
-			p = o;
-			o = p->link;
-			p->link = nil;
-			s->ents = p;
-		}
-		else
-			s->ents = p;
-
-		h = p->first;
-		// oblit o list repl with jmp to h
-		while(o != nil) {
-			changedest(o->first, h, 1);
-			bexcise(o);
-			o = o->link;
-		}
-
-		bbsrecalc(s);
-	}
-}
-
-static void
-iterate(void)
-{
-	BBset *s;
-	BB *b, *t;
-
-	heapn = 0;
-
-	for(;;) {
-		for(b = wounded; b != nil; b = t) {
-			t = b->link;
-			enterbb(b);
-		}
-		wounded = nil;
-
-		for(s = recalc; s != nil; s = s->link)
-			calcdamage(s);
-		recalc = nil;
-
-		if(heapn == 0)
-			return;
-
-		s = heap[1];
-		heapremove(s);
-		process(s);
-	}
-}
-
-static void
-cleanup(void)
-{
-	int i;
-	BB *l, *n;
-	BBset *b, *t;
-
-	for(i = 0; i < BBHASH; i++) {
-		b = bbhash[i];
-		bbhash[i] = nil;
-		while(b != nil) {
-			t = b->next;
-			bsfree(b);
-			b = t;
-		}
-	}
-	for(i = 0; i < bcount; i++)
-		bfree(ordered[i]);
-	for(l = bbaux; l != nil; l = n) {
-		n = l->aux;
-		bfree(l);
-	}
-	bbaux = nil;
-}
-
-static void
-prreg(Reg *r)
-{
-	Prog *p;
-
-	p = r->prog;
-	if(p->to.type == D_BRANCH)
-		p->to.offset = r->s2->rpo;
-	print("%ld:%P\tr %lX ", r->rpo, r->prog, r->regu);
-	print("p1 %ld p2 %ld p2l %ld s1 %ld s2 %ld link %ld",
-		Rn(r->p1), Rn(r->p2), Rn(r->p2link),
-		Rn(r->s1), Rn(r->s2), Rn(r->link));
-	if(!r->active)
-		print(" d");
-//	print(" %p %p\n", r->prog, r->prog->link);
-	print("\n");
-}
-
-static	void	prfunc(char*);
-
-static void
-checkr(int d)
-{
-	Prog *p;
-	Reg *r, *t;
-
-	for(r = firstr; r->link != R; r = r->link) {
-		for(p = r->prog->link; p != P && p != r->link->prog; p = p->link)
-			;
-		if(p == P) {
-			print("%ld: bad prog link\n", r->rpo);
-			if(d)
-				prfunc(nil);
-			abort();
-		}
-		if(r->s1 != R && (r->s1 != r->link || r->link->p1 != r)) {
-			print("%ld: bad s1 p1\n", r->rpo);
-			if(d)
-				prfunc(nil);
-			abort();
-		}
-		if(r->s2 != R && r->s2->p2 == nil) {
-			print("%ld: no p2 for s2\n", r->rpo);
-			if(d)
-				prfunc(nil);
-			abort();
-		}
-		if(r->p2 != R) {
-			t = r->p2->s2;
-			while(t != r) {
-				t = t->p2link;
-				if(t == R) {
-					print("%ld: bad s2 for p2\n", r->rpo);
-					if(d)
-						prfunc(nil);
-					abort();
-				}
-			}
-		}
-	}
-}
-
-static void
-prfunc(char *s)
-{
-	Reg *r;
-
-	if(s != nil)
-		print("%s structure %s\n", s, firstr->prog->from.sym->name);
-	for(r = firstr; r != R; r = r->link)
-		prreg(r);
-	if(s != nil) {
-		print("end\n");
-		checkr(0);
-	}
-}
-
-/* find p in r's list and replace with l */
-static void
-adjprog(Reg *r, Prog *p, Prog *l)
-{
-	Prog *t, **n;
-
-	for(n = &r->prog->link; (t = *n) != nil; n = &t->link) {
-		if(t == p) {
-			*n = l;
-			return;
-		}
-	}
-	print("adjprog botch\n");
-	abort();
-}
-
-static void
-jumptojump(void)
-{
-	Reg *r;
-
-	for(r = firstr; r != R; r = r->link) {
-		if(r->prog->as == AJMP && r->p2 != R && r->s2 != r) {
-			if(bdebug)
-				print("jump as dest %ld -> %ld\n", r->rpo, r->s2->rpo);
-			changedest(r, r->s2, 0);
-			bchange++;
-		}
-	}
-}
-
-/* drag a tail to replace a jump.  seems to be a bad idea. */
-static void
-rearrange(void)
-{
-	int i;
-	Reg *j, *t;
-	BB *b, *p, *s;
-
-	for(i = 0; i < bcount; i++) {
-		b = ordered[i];
-		if(b->flags & Bdel)
-			continue;
-		j = b->last;
-		if(j->prog->as == AJMP && j->s2->p1 == R) {
-			t = j->s2;
-			if(t == b->first)
-				continue;
-			s = findset(t->rpo);
-			if(s == nil) {
-				diag(Z, "no self");
-				continue;
-			}
-			if(s == ordered[0])
-				continue;
-			if(s->flags & Bdel)
-				continue;
-			if(s->last->link == R)
-				continue;
-			if(bdebug)
-				print("drag %ld to %ld\n", t->rpo, j->rpo);
-			p = findset(t->rpo - 1);
-			if(p == nil) {
-				diag(Z, "no predec");
-				continue;
-			}
-			if(p->last->link != t) {
-				diag(Z, "bad predec %ld %ld", p->last->rpo, t->rpo);
-				continue;
-			}
-
-			/* poison everything in sight */
-			b->flags |= Bdel;
-			s->flags |= Bdel;
-			findset(j->link->rpo)->flags |= Bdel;
-			findset(s->last->link->rpo)->flags |= Bdel;
-
-			/* remove */
-			adjprog(p->last, t->prog, s->last->link->prog);
-			p->last->link = s->last->link;
-
-			/* fix tail */
-			adjprog(s->last, s->last->link->prog, j->link->prog);
-			s->last->link = j->link;
-
-			/* fix head */
-			adjprog(j, j->link->prog, t->prog);
-			j->link = t;
-
-			/* nop the jump */
-			j->prog->as = ANOP;
-			j->prog->to.type = D_NONE;
-			j->s2 = nil;
-			j->link->p2 = delset(j, j->link->p2);
-			j->s1 = t;
-			t->p1 = j;
-			if(bcheck)
-				checkr(1);
-			bchange++;
-		}
-	}
-}
-
-void
-jumptodot(void)
-{
-	Reg *r;
-
-	for(r = firstr; r != R; r = r->link) {
-		if(r->prog->as == AJMP && r->s2 == r->link) {
-			if(debug['v'])
-				print("jump to next %ld\n", r->rpo);
-			r->prog->as = ANOP;
-			r->prog->to.type = D_NONE;
-			r->s2 = nil;
-			r->link->p2 = delset(r, r->link->p2);
-			findset(r->rpo)->flags |= Bdel;
-			findset(r->link->rpo)->flags |= Bdel;
-			bchange++;
-		}
-	}
-}
-
-void
-comtarg(void)
-{
-	int n;
-	BB *b, *c;
-	Reg *r, *l, *p, *t;
-
-loop:
-	bchange = 0;
-
-	/* excise NOPS because they just get in the way */
-	/* some have p2 because they are excised labelled moves */
-
-	if(debug['v']) {
-		n = 0;
-		for(r = firstr; r != R; r = r->link)
-			r->rpo = n++;
-		prfunc("prenop");
-	}
-
-	r = firstr;
-	l = r->link;
-	while(l != R) {
-		if(l->prog->as == ANOP) {
-			t = l->p1;
-			p = l->p2;
-if(dbg) print("nop %ld [", l->rpo);
-if(dbg) printbl(p);
-			for(;;) {
-				adjprog(r, l->prog, l->prog->link);
-				r->link = l->link;
-				l->link = freer;
-				freer = l;
-				l = r->link;
-				if(l->prog->as != ANOP)
-					break;
-if(dbg) print("] %ld [", l->rpo);
-if(dbg) printbl(l->p2);
-				if(p == R)
-					p = l->p2;
-				else if(l->p2 != nil)
-					appset(l->p2, p);
-			}
-if(dbg) print("] %ld [", l->rpo);
-if(dbg) printbl(l->p2);
-			if(p != R) {
-				redest(p, l);
-				if(l->p2 != R)
-					appset(p, l->p2);
-				else
-					l->p2 = p;
-			}
-if(dbg) print("] -> [");
-if(dbg) printbl(l->p2);
-if(dbg) print("]\n");
-			if(r->s1 != R)
-				r->s1 = l;
-			l->p1 = t;
-		}
-		r = l;
-		l = r->link;
-	}
-
-	n = 0;
-	for(r = firstr; r != R; r = r->link)
-		r->rpo = n++;
-
-	if(debug['v'])
-		prfunc("input");
-
-	firstbb = nil;
-	lastbb = nil;
-
-	if(debug['v'])
-		print("bbstart\n");
-
-	n = 0;
-	r = firstr;
-	do {
-		b = bba();
-		b->first = r;
-		for(;;) {
-			l = r;
-			r = r->link;
-			switch(l->prog->as) {
-			case ARET:
-			case AJMP:
-			case AIRETL:
-				goto out;
-			}
-			if(r->p2 != R)
-				break;
-		}
-	out:
-		b->last = l;
-		if(lastbb == nil)
-			firstbb = b;
-		else
-			lastbb->link = b;
-		lastbb = b;
-		if(bdebug)
-			print("BB %ld %ld\n", b->first->rpo, b->last->rpo);
-		n++;
-	} while(r != R);
-
-	if(debug['v'])
-		print("end\n");
-
-	if(n > bsize) {
-		bsize = n * 3 / 2;
-		if(bsize < BBINIT)
-			bsize = BBINIT;
-		ordered = alloc(bsize * sizeof(*ordered));
-		heap = alloc((bsize + 1) * sizeof(*ordered));
-	}
-
-	if(debug['v'])
-		print("preprocstart\n");
-
-	n = 0;
-	for(b = firstbb; b != nil; b = c) {
-		c = b->link;
-		preproc(b, n++);
-	}
-
-	if(debug['v'])
-		print("end\n");
-
-	bcount = n;
-
-	jumptojump();
-
-	if(debug['v'])
-		print("iteratestart\n");
-
-	iterate();
-//checktails();
-
-	if(debug['v'])
-		print("end\n");
-
-	if(debug['v'])
-		print("extrastart\n");
-
-	jumptodot();
-//	rearrange();
-
-	if(debug['v'])
-		print("end\n");
-
-	cleanup();
-	if(bballoc || bbsalloc)
-		diag(Z, "bballoc %d %d", bballoc, bbsalloc);
-
-	if(debug['v'])
-		prfunc("output");
-
-	if(1 && bchange)
-		goto loop;
-}
--- a/sys/src/cmd/8c/bound.h
+++ /dev/null
@@ -1,56 +1,0 @@
-/*
- *	Bounding Box stuff (brucee 04/03/30).
- */
-
-#include <mp.h>
-#include <libsec.h>
-
-typedef	struct	BB	BB;
-typedef	struct	BBset	BBset;
-typedef uchar		Hval[SHA1dlen];
-
-#define	BBEQ(a, b)		(memcmp((a), (b), SHA1dlen) == 0)
-#define	BBMKHASH(b, n, h)	sha1((uchar *)(b), (n), (h), nil)
-#define	BBCP(d, s)		memmove(d, s, SHA1dlen)
-
-enum
-{
-	Bpre	= 1 << 0,	/* has a flow in */
-	Bjo	= 1 << 1,	/* a jump only */
-	Bbig	= 1 << 2,	/* too big */
-	Bdel	= 1 << 3,	/* deleted or not of interest */
-	Bpin	= 1 << 4,	/* pinned by embedded labels */
-
-	BBHASH	= 64,		/* power of 2 <= 256 */
-	BBMASK	= BBHASH - 1,
-
-	BBINIT	= 128,
-	BBBIG	= 64,
-	BBBSIZE	= 8192,
-	BINST	= 128,
-
-	COSTHI	= 0x7F,
-	COSTJO	= 0xFF,
-};
-
-struct	BB
-{
-	Reg*	first;
-	Reg*	last;
-	BBset*	set;
-	BB*	link;
-	BB*	aux;
-	short	flags;
-	short	len;
-};
-
-struct	BBset
-{
-	Hval	hash;
-	BB*	ents;
-	BBset*	next;
-	BBset*	link;
-	short	index;
-	uchar	damage;
-	uchar	recalc;
-};