shithub: mc

Download patch

ref: b744c317feeac6ba0b96d6d223e8acb3f2004b03
parent: 8643ac098d6c0bb5b3a29d58141f5c29a65357cb
author: Ori Bernstein <[email protected]>
date: Thu Dec 25 16:01:16 EST 2014

Get code to actually run on plan9.

    Fuckin division and misnamed registers.

--- a/6/genp9.c
+++ b/6/genp9.c
@@ -450,7 +450,9 @@
     hidden = "";
     if (fn->isexport || streq(fn->name, Symprefix "main"))
         hidden = "";
-    fprintf(fd, "TEXT %s%s+0(SB),$%zd\n", fn->name, hidden, fn->stksz);
+    /* we don't use the stack size directive: myrddin handles
+     * the stack frobbing on its own */
+    fprintf(fd, "TEXT %s%s+0(SB),$0\n", fn->name, hidden);
     for (j = 0; j < s->cfg->nbb; j++) {
         if (!s->bb[j])
             continue;
--- a/6/insns.def
+++ b/6/insns.def
@@ -103,6 +103,26 @@
     "\tDIV%T %R\n",
     Use(.l={1},.r={Reax,Redx}),
     Def(.r={Reax,Redx}))
+Insn(Iidiv,
+    "\tidiv%t %r\n",
+    "\tIDIV%T %R\n",
+    Use(.l={1},.r={Reax,Redx}),
+    Def(.r={Reax,Redx}))
+Insn(Icwd,
+    "\tcwd\n",
+    "\tCWD\n",
+    Use(.r={Reax}),
+    Def(.r={Reax,Redx}))
+Insn(Icdq,
+    "\tcdq\n",
+    "\tCDQ\n",
+    Use(.r={Reax}),
+    Def(.r={Reax,Redx}))
+Insn(Icqo,
+    "\tcqo\n",
+    "\tCQO\n",
+    Use(.r={Reax}),
+    Def(.r={Reax,Redx}))
 Insn(Ineg,
     "\tneg%t %r\n",
     "\tNEG%T %R\n",
--- a/6/isel.c
+++ b/6/isel.c
@@ -531,12 +531,23 @@
             b = newr(s, b);
             c = coreg(Reax, mode(n));
             r = locreg(a->mode);
-            if (r->mode == ModeB)
-                g(s, Ixor, eax, eax, NULL);
-            else
-                g(s, Ixor, edx, edx, NULL);
             g(s, Imov, a, c, NULL);
-            g(s, Idiv, b, NULL);
+            if (istysigned(exprtype(args[0]))) {
+                switch (r->mode) {
+                    case ModeB: break;
+                    case ModeW: g(s, Icwd, NULL);       break;
+                    case ModeL: g(s, Icdq, NULL);       break;
+                    case ModeQ: g(s, Icqo, NULL);       break;
+                    default:    die("invalid mode in division"); break;
+                }
+                g(s, Iidiv, b, NULL);
+            } else {
+                if (r->mode == ModeB)
+                    g(s, Ixor, eax, eax, NULL);
+                else
+                    g(s, Ixor, edx, edx, NULL);
+                g(s, Idiv, b, NULL);
+            }
             if (exprop(n) == Odiv)
                 d = coreg(Reax, mode(n));
             else if (r->mode != ModeB)
--- a/6/regs.def
+++ b/6/regs.def
@@ -25,9 +25,9 @@
 
 /* short regs */
 Reg(Rax,   "%ax",   "AX",  ModeW)
-Reg(Rbx,   "%bx",   "BX",  ModeW)
 Reg(Rcx,   "%cx",   "CX",  ModeW)
 Reg(Rdx,   "%dx",   "DX",  ModeW)
+Reg(Rbx,   "%bx",   "BX",  ModeW)
 Reg(Rsi,   "%si",   "SI",  ModeW)
 Reg(Rdi,   "%di",   "DI",  ModeW)
 Reg(Rsp,   "%sp",   "SP",  ModeW)
@@ -44,9 +44,9 @@
 
 /* long regs */
 Reg(Reax,  "%eax",  "AX",  ModeL)
-Reg(Recx,  "%ecx",  "BX",  ModeL)
-Reg(Redx,  "%edx",  "CX",  ModeL)
-Reg(Rebx,  "%ebx",  "DX",  ModeL)
+Reg(Recx,  "%ecx",  "CX",  ModeL)
+Reg(Redx,  "%edx",  "DX",  ModeL)
+Reg(Rebx,  "%ebx",  "BX",  ModeL)
 Reg(Resi,  "%esi",  "SI",  ModeL)
 Reg(Redi,  "%edi",  "DI",  ModeL)
 Reg(Resp,  "%esp",  "SP",  ModeL)
@@ -62,9 +62,9 @@
 
 /* quad regs */
 Reg(Rrax, "%rax", "AX",  ModeQ)
-Reg(Rrcx, "%rcx", "BX",  ModeQ)
-Reg(Rrdx, "%rdx", "CX",  ModeQ)
-Reg(Rrbx, "%rbx", "DX",  ModeQ)
+Reg(Rrcx, "%rcx", "CX",  ModeQ)
+Reg(Rrdx, "%rdx", "DX",  ModeQ)
+Reg(Rrbx, "%rbx", "BX",  ModeQ)
 Reg(Rrsi, "%rsi", "SI",  ModeQ)
 Reg(Rrdi, "%rdi", "DI",  ModeQ)
 Reg(Rrsp, "%rsp", "SP",  ModeQ)
@@ -114,4 +114,4 @@
 Reg(Rxmm14d, "%xmm14", "X14", ModeD)
 Reg(Rxmm15d, "%xmm15", "X15", ModeD)
 
-Reg(Rrip, "%rip", "PC", ModeQ)
+Reg(Rrip, "%rip", "IP", ModeQ)
--- a/libstd/syswrap+plan9-x64.myr
+++ b/libstd/syswrap+plan9-x64.myr
@@ -86,11 +86,31 @@
 const fork	= {;		-> sys.rfork(sys.Rffdg | sys.Rfrend | sys.Rfproc) castto(pid)}
 const execv	= {cmd, args;	-> sys.exec(cmd, args) castto(int64)}
 const execve	= {cmd, args, env;	-> sys.exec(cmd, args) castto(int64)}
-const exit	= {status;
+const digitchars = "0123456789"
+const exit	= {status
+	var buf : byte[32]	/* big enough for exit status numbers */
+	var n, i, idx
+	
 	if status == 0
+		sys.pwrite(1, "exit(0)ing\n", -1)
 		sys.exits("")
 	else
-		sys.exits("failure")
+		status &= 255
+		i = 100
+		n = 0
+		sys.pwrite(1, "...formatting\n", -1)
+		while i > 0
+			if i > status
+				continue
+			;;
+			idx = (status/i)
+			idx %= 10
+			buf[n++] = digitchars[idx];
+			i /= 10
+		;;
+		sys.pwrite(1, "done...", -1)
+		sys.pwrite(1, buf[:n], -1)
+		sys.exits(buf[:n])
 	;;
 }
 
--- a/libstd/util+plan9-x64.s
+++ b/libstd/util+plan9-x64.s
@@ -10,17 +10,17 @@
  */
 TEXT sys$cstring+0(SB),$0
 	/* save registers */
-	SUBQ	$48,SP
-	MOVQ	BP,40(SP)
 	MOVQ	SP,BP
-	MOVQ	R15,32(SP)
-	MOVQ	SI,24(SP)
-	MOVQ	DI,16(SP)
-	MOVQ	CX,8(SP)
+	SUBQ	$48,SP
+	MOVQ	BP,-8(BP)
+	MOVQ	R15,-16(BP)
+	MOVQ	SI,-24(BP)
+	MOVQ	DI,-32(BP)
+	MOVQ	CX,-40(BP)
 
-	MOVQ 	8(BP),R15	/* ret addr */
-	MOVQ	16(BP),SI	/* src */
-	MOVQ	24(BP),CX	/* len */
+	MOVQ 	(BP),R15	/* ret addr */
+	MOVQ	8(BP),SI	/* src */
+	MOVQ	16(BP),CX	/* len */
 
 	SUBQ	CX,SP		/* get stack */
 	SUBQ	$1,SP		/* +1 for nul */
@@ -30,29 +30,29 @@
 	ANDQ	$(~15),SP	/* align */
 
 	CLD
-	REP; MOVSB
+	REP
+        MOVSB
 	MOVB	$0,(DI)		/* terminate */
 
-	MOVQ	R15,0(SP)		/* ret addr */
-
 	/* Restore registers */
-	MOVQ	-32(BP),CX
-	MOVQ	-24(BP),DI
-	MOVQ	-16(BP),SI
-	MOVQ	-8(BP),R15
-	MOVQ	(BP),BP
+	MOVQ	R15,0(SP)	/* place ret addr */
+	MOVQ	-40(BP),CX
+	MOVQ	-32(BP),DI
+	MOVQ	-24(BP),SI
+	MOVQ	-16(BP),R15
+	MOVQ	-8(BP) ,BP
 	RET
 
 TEXT sys$alloca+0(SB),$0
 	/* save registers */
+        MOVQ    SP,BP
 	SUBQ	$32,SP
-	MOVQ	BP,24(SP)
-	MOVQ	SP,BP
-	MOVQ	R15,16(SP)
-	MOVQ	BX,8(SP)
+	MOVQ	BP,-8(BP)
+	MOVQ	R15,-16(BP)
+	MOVQ	BX,-24(SP)
 
-	MOVQ	8(BP),R15	/* ret addr */
-	MOVQ	16(BP),BX	/* len */
+	MOVQ	(BP),R15	/* ret addr */
+	MOVQ	8(BP),BX	/* len */
 
 	/* get stack space */
 	SUBQ	BX,SP		/* get stack space */
@@ -60,12 +60,11 @@
 	SUBQ	$16,SP		/* "unpop" the args for return */
 	ANDQ	$(~15),SP	/* align */
 
-	MOVQ	R15,0(SP)	/* ret addr */
-
+	MOVQ	R15,0(SP)	/* place ret addr */
 	/* restore registers */
-	MOVQ	-16(BP),BX
-	MOVQ	-8(BP),R15
-	MOVQ	(BP),BP
+	MOVQ	-16(BP),R15
+	MOVQ	-24(SP),BX
+	MOVQ	-8(BP),BP
 	RET
 
 GLOBL	sys$tosptr+0(SB),$8
--- a/test/runtest.sh
+++ b/test/runtest.sh
@@ -24,6 +24,16 @@
     NFAILED=$[$NFAILED + 1]
 }
 
+function expectstatus {
+    ./$1 $3
+    if [ $? -eq $2 ]; then
+        pass $1
+        return
+    else
+        fail $1
+    fi
+}
+
 function expectprint {
     if [ "`./$1 $3`" != "$2" ]; then
         fail $1