Macintosh.
diff --git a/package b/package
index 5b1a8a4..ba13507 100755
--- a/package
+++ b/package
@@ -2,18 +2,8 @@
 
 rm -rf ../9tmp
 mkdir ../9tmp
-mkdir ../9pkg
 cp -R * ../9tmp
 cd ../9tmp
 rm -rf `find . -name CVS`
-rm lib/*
-rm */*.o
-rm */*.a
-rm mk/mk
-rm sam/sam
-rm man/*/*
-for i in libfmt libbio lib9 libthread libutf libregexp sam mk 
-do
-	tar cf - $i |gzip >../9pkg/$i.tar.gz
-done
-tar cf - . | gzip > ../9pkg/all.tar.gz
+make nuke
+tar cf - . | gzip >~/public_html/9src.tar.gz
diff --git a/src/Makefile b/src/Makefile
index 30ff19e..19326a0 100644
--- a/src/Makefile
+++ b/src/Makefile
@@ -13,8 +13,8 @@
 	sam\
 	samterm\
 
-clean all install nuke:
-	for i in $(LIBS) $(DIRS); \
+all clean install nuke:
+	for i in $(LIBS) $(CMDS); \
 	do \
 		(echo $$i; cd $$i; $(MAKE) $@); \
 	done
diff --git a/src/Makeone b/src/Makeone
index 6229285..4f8e948 100644
--- a/src/Makeone
+++ b/src/Makeone
@@ -4,6 +4,7 @@
 	$(CC) -o $(TARG) $(OFILES) $(LDFLAGS)
 
 CLEANFILES+=$(TARG)
+NUKEFILES+=$(9SRC)/bin/$(TARG)
 
 include $(9SRC)/Makecommon
 
diff --git a/src/lib9/getcallerpc-PowerMacintosh.s b/src/lib9/getcallerpc-PowerMacintosh.s
new file mode 100644
index 0000000..3571b74
--- /dev/null
+++ b/src/lib9/getcallerpc-PowerMacintosh.s
@@ -0,0 +1,5 @@
+.text
+.globl _getcallerpc
+_getcallerpc:
+	mflr	r3
+	blr
diff --git a/src/lib9/tas-PowerMacintosh.c b/src/lib9/tas-PowerMacintosh.c
new file mode 100644
index 0000000..29928ce
--- /dev/null
+++ b/src/lib9/tas-PowerMacintosh.c
@@ -0,0 +1,42 @@
+#include "u.h"
+#include "libc.h"
+
+/*
+ * first argument (l) is in r3 at entry.
+ * r3 contains return value upon return.
+ */
+int
+_tas(void *x)
+{
+	int     v;
+	/*
+	 * this __asm__ works with gcc 2.95.2 (mac os x 10.1).
+	 * this assembly language destroys r0 (0), some other register (v),
+	 * r4 (x) and r5 (temp).
+	 */
+	__asm__("\n	sync\n"
+	"	li	r0,0\n"
+	"	mr	r4,%1		/* &l->val */\n"
+	"	lis	r5,0xdead	/* assemble constant 0xdeaddead */\n"
+	"	ori	r5,r5,0xdead	/* \" */\n"
+	"tas1:\n"
+	"	dcbf	r4,r0	/* cache flush; \"fix for 603x bug\" */\n"
+	"	lwarx	%0,r4,r0	/* v = l->val with reservation */\n"
+	"	cmp	cr0,0,%0,r0	/* v == 0 */\n"
+	"	bne	tas0\n"
+	"	stwcx.	r5,r4,r0   /* if (l->val same) l->val = 0xdeaddead */\n"
+	"	bne	tas1\n"
+	"tas0:\n"
+	"	sync\n"
+	"	isync\n"
+	: "=r" (v)
+	: "r"  (x)
+	: "cc", "memory", "r0", "r4", "r5"
+	);
+	switch(v) {
+	case 0:		return 0;
+	case 0xdeaddead: return 1;
+	default:	print("tas: corrupted 0x%lux\n", v);
+	}
+	return 0;
+}
diff --git a/src/libdraw/x11-draw.c b/src/libdraw/x11-draw.c
index 33b92c8..ee91791 100644
--- a/src/libdraw/x11-draw.c
+++ b/src/libdraw/x11-draw.c
@@ -17,14 +17,12 @@
 memimagedraw(Memimage *dst, Rectangle r, Memimage *src, Point sp,
 	Memimage *mask, Point mp, int op)
 {
+	int drew;
 	Memdrawparam *par;
 
 	if((par = _memimagedrawsetup(dst, r, src, sp, mask, mp, op)) == nil)
 		return;
 
-	if(xdraw(par))
-		return;
-
 	/* only fetch dst data if we need it */
 	if((par->state&(Simplemask|Fullmask)) != (Simplemask|Fullmask))
 		xgetxdata(dst, par->r);
@@ -36,6 +34,9 @@
 	/* now can run memimagedraw on the in-memory bits */
 	_memimagedraw(par);
 
+	if(xdraw(par))
+		return;
+
 	/* put bits back on x server */
 	xputxdata(dst, par->r);
 }
@@ -67,7 +68,7 @@
 	m = Simplesrc|Simplemask|Fullmask;
 	if((state&m) == m){
 		xfillcolor(dst, r, par->sdval);
-		xdirtyxdata(dst, r);
+	//	xdirtyxdata(dst, r);
 		return 1;
 	}
 
@@ -86,7 +87,7 @@
 
 		XCopyArea(_x.display, xsrc->pixmap, xdst->pixmap, gc,
 			sp.x, sp.y, Dx(r), Dy(r), dp.x, dp.y);
-		xdirtyxdata(dst, r);
+	//	xdirtyxdata(dst, r);
 		return 1;
 	}
 
@@ -131,7 +132,7 @@
 		XSetTSOrigin(_x.display, gc, mp.x, mp.y);
 		XFillRectangle(_x.display, xdst->pixmap, gc, dp.x, dp.y,
 			Dx(r), Dy(r));
-		xdirtyxdata(dst, r);
+	//	xdirtyxdata(dst, r);
 		return 1;
 	}
 
diff --git a/src/libdraw/x11-get.c b/src/libdraw/x11-get.c
index feed46c..a6d4b12 100644
--- a/src/libdraw/x11-get.c
+++ b/src/libdraw/x11-get.c
@@ -30,6 +30,8 @@
 	if(xm->dirty == 0)
 		return xm->xi;
 
+	abort();	/* should never call this now */
+
 	r = xm->dirtyr;
 	if(Dx(r)==0 || Dy(r)==0)
 		return xm->xi;
@@ -102,6 +104,7 @@
 	xm = m->X;
 	if(xm == nil)
 		return;
+
 	xm->dirty = 1;
 	addrect(&xm->dirtyr, r);
 }