aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrsc <devnull@localhost>2003-10-03 15:33:45 +0000
committerrsc <devnull@localhost>2003-10-03 15:33:45 +0000
commit98014aa54361143450d0d9869369b6e3cb715f28 (patch)
treebc29cd0248be2804877c9ca16c3d7b878afd3506
parentd4853cf44b50f5de560cdea4530bd17659a32cb8 (diff)
downloadplan9port-98014aa54361143450d0d9869369b6e3cb715f28.tar.gz
plan9port-98014aa54361143450d0d9869369b6e3cb715f28.tar.bz2
plan9port-98014aa54361143450d0d9869369b6e3cb715f28.zip
Macintosh.
-rwxr-xr-xpackage14
-rw-r--r--src/Makefile4
-rw-r--r--src/Makeone1
-rw-r--r--src/lib9/getcallerpc-PowerMacintosh.s5
-rw-r--r--src/lib9/tas-PowerMacintosh.c42
-rw-r--r--src/libdraw/x11-draw.c13
-rw-r--r--src/libdraw/x11-get.c3
7 files changed, 62 insertions, 20 deletions
diff --git a/package b/package
index 5b1a8a4e..ba135073 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 30ff19e1..19326a0d 100644
--- a/src/Makefile
+++ b/src/Makefile
@@ -13,8 +13,8 @@ CMDS=\
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 62292855..4f8e9488 100644
--- a/src/Makeone
+++ b/src/Makeone
@@ -4,6 +4,7 @@ $(TARG): $(OFILES)
$(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 00000000..3571b744
--- /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 00000000..29928ce0
--- /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 33b92c87..ee91791d 100644
--- a/src/libdraw/x11-draw.c
+++ b/src/libdraw/x11-draw.c
@@ -17,14 +17,12 @@ void
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 @@ memimagedraw(Memimage *dst, Rectangle r, Memimage *src, Point sp,
/* 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 @@ xdraw(Memdrawparam *par)
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 @@ xdraw(Memdrawparam *par)
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 @@ xdraw(Memdrawparam *par)
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 feed46c6..a6d4b12e 100644
--- a/src/libdraw/x11-get.c
+++ b/src/libdraw/x11-get.c
@@ -30,6 +30,8 @@ xgetxdata(Memimage *m, Rectangle r)
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 @@ xdirtyxdata(Memimage *m, Rectangle r)
xm = m->X;
if(xm == nil)
return;
+
xm->dirty = 1;
addrect(&xm->dirtyr, r);
}