Commit 7d11924c authored by Ken Thompson's avatar Ken Thompson

middle dot as alpha package separator

SVN=124419
parent 206daeab
...@@ -380,6 +380,7 @@ agen_inter(Node *n, Node *res) ...@@ -380,6 +380,7 @@ agen_inter(Node *n, Node *res)
if(!n->left->addable) { if(!n->left->addable) {
agen(n->left, &nodr); agen(n->left, &nodr);
gmove(&nodr, &nodo); gmove(&nodr, &nodo);
dump("xxx", n->left);
fatal("agen_inter i2s"); fatal("agen_inter i2s");
} else { } else {
cgen(n->left, &nodo); cgen(n->left, &nodo);
......
...@@ -165,6 +165,13 @@ return; ...@@ -165,6 +165,13 @@ return;
Bterm(bout); Bterm(bout);
} }
Bputdot(Biobuf *b)
{
// put out middle dot ·
Bputc(b, 0xc2);
Bputc(b, 0xb7);
}
void void
zname(Biobuf *b, Sym *s, int t) zname(Biobuf *b, Sym *s, int t)
{ {
...@@ -177,7 +184,7 @@ zname(Biobuf *b, Sym *s, int t) ...@@ -177,7 +184,7 @@ zname(Biobuf *b, Sym *s, int t)
for(n=s->opackage; *n; n++) for(n=s->opackage; *n; n++)
Bputc(b, *n); Bputc(b, *n);
Bputc(b, '_'); Bputdot(b);
for(n=s->name; *n; n++) for(n=s->name; *n; n++)
Bputc(b, *n); Bputc(b, *n);
Bputc(b, 0); Bputc(b, 0);
......
...@@ -232,6 +232,16 @@ lookup(void) ...@@ -232,6 +232,16 @@ lookup(void)
return s; return s;
} }
int
ISALPHA(int c)
{
if(isalpha(c))
return 1;
if(c >= Runeself)
return 1;
return 0;
}
long long
yylex(void) yylex(void)
{ {
...@@ -259,7 +269,7 @@ l1: ...@@ -259,7 +269,7 @@ l1:
} }
goto l0; goto l0;
} }
if(isalpha(c)) if(ISALPHA(c))
goto talph; goto talph;
if(isdigit(c)) if(isdigit(c))
goto tnum; goto tnum;
...@@ -275,7 +285,7 @@ l1: ...@@ -275,7 +285,7 @@ l1:
case '.': case '.':
c = GETC(); c = GETC();
if(isalpha(c)) { if(ISALPHA(c)) {
cp = symb; cp = symb;
*cp++ = '.'; *cp++ = '.';
goto aloop; goto aloop;
...@@ -296,7 +306,7 @@ l1: ...@@ -296,7 +306,7 @@ l1:
aloop: aloop:
*cp++ = c; *cp++ = c;
c = GETC(); c = GETC();
if(isalpha(c) || isdigit(c) || c == '_' || c == '$') if(ISALPHA(c) || isdigit(c) || c == '_' || c == '$')
goto aloop; goto aloop;
*cp = 0; *cp = 0;
peekc = c; peekc = c;
......
...@@ -1789,14 +1789,7 @@ badt: ...@@ -1789,14 +1789,7 @@ badt:
return nl; return nl;
} }
Node* /*
reorder1(Node *n)
{
Iter save;
Node *l, *r, *f, *a, *g;
int c, t;
/*
* from ascompat[te] * from ascompat[te]
* evaluating actual function arguments. * evaluating actual function arguments.
* f(a,b) * f(a,b)
...@@ -1804,6 +1797,12 @@ reorder1(Node *n) ...@@ -1804,6 +1797,12 @@ reorder1(Node *n)
* then it is done first. otherwise must * then it is done first. otherwise must
* make temp variables * make temp variables
*/ */
Node*
reorder1(Node *n)
{
Iter save;
Node *l, *r, *f, *a, *g;
int c, t;
l = listfirst(&save, &n); l = listfirst(&save, &n);
c = 0; // function calls c = 0; // function calls
...@@ -1874,20 +1873,19 @@ more: ...@@ -1874,20 +1873,19 @@ more:
goto loop2; goto loop2;
} }
Node* /*
reorder2(Node *n)
{
Iter save;
Node *l;
int c;
/*
* from ascompat[et] * from ascompat[et]
* a,b = f() * a,b = f()
* return of a multi. * return of a multi.
* there can be no function calls at all, * there can be no function calls at all,
* or they will over-write the return values. * or they will over-write the return values.
*/ */
Node*
reorder2(Node *n)
{
Iter save;
Node *l;
int c;
l = listfirst(&save, &n); l = listfirst(&save, &n);
c = 0; c = 0;
...@@ -1907,15 +1905,44 @@ loop1: ...@@ -1907,15 +1905,44 @@ loop1:
goto loop1; goto loop1;
} }
Node* /*
reorder3(Node *n)
{
/*
* from ascompat[ee] * from ascompat[ee]
* a,b = c,d * a,b = c,d
* simultaneous assignment. there can be * simultaneous assignment. there can be
* later use of an earlier lvalue. * later use of an earlier lvalue.
*/ */
int
vmatch(Node *l, Node *r)
{
dump("l", l);
dump("r", r);
return 0;
}
Node*
reorder3(Node *n)
{
Iter save1, save2;
Node *l1, *l2;
int c1, c2;
l1 = listfirst(&save1, &n);
c1 = 0;
while(l1 != N) {
l2 = listfirst(&save1, &n);
c2 = 0;
while(l2 != N) {
if(c2 > c1) {
if(vmatch(l1->left, l2->right)) {
}
}
l2 = listnext(&save1);
c2++;
}
l1 = listnext(&save1);
c1++;
}
return n; return n;
} }
......
...@@ -31,7 +31,7 @@ done: ...@@ -31,7 +31,7 @@ done:
ADDQ $16, SP ADDQ $16, SP
CALL check(SB) CALL check(SB)
CALL main_main(SB) CALL main_main(SB)
CALL sys_exit(SB) CALL sys·exit(SB)
CALL notok(SB) CALL notok(SB)
POPQ AX POPQ AX
RET RET
...@@ -39,7 +39,7 @@ done: ...@@ -39,7 +39,7 @@ done:
TEXT FLUSH(SB),1,$-8 TEXT FLUSH(SB),1,$-8
RET RET
TEXT sys_exit(SB),1,$-8 TEXT sys·exit(SB),1,$-8
MOVL 8(SP), DI // arg 1 exit status MOVL 8(SP), DI // arg 1 exit status
MOVL $(0x2000000+1), AX MOVL $(0x2000000+1), AX
SYSCALL SYSCALL
...@@ -47,7 +47,7 @@ TEXT sys_exit(SB),1,$-8 ...@@ -47,7 +47,7 @@ TEXT sys_exit(SB),1,$-8
CALL notok(SB) CALL notok(SB)
RET RET
TEXT sys_write(SB),1,$-8 TEXT sys·write(SB),1,$-8
MOVL 8(SP), DI // arg 1 fid MOVL 8(SP), DI // arg 1 fid
MOVQ 16(SP), SI // arg 2 buf MOVQ 16(SP), SI // arg 2 buf
MOVL 24(SP), DX // arg 3 count MOVL 24(SP), DX // arg 3 count
...@@ -57,7 +57,7 @@ TEXT sys_write(SB),1,$-8 ...@@ -57,7 +57,7 @@ TEXT sys_write(SB),1,$-8
CALL notok(SB) CALL notok(SB)
RET RET
TEXT sys_sigaction(SB),1,$-8 TEXT sys·sigaction(SB),1,$-8
MOVL 8(SP), DI // arg 1 sig MOVL 8(SP), DI // arg 1 sig
MOVQ 16(SP), SI // arg 2 act MOVQ 16(SP), SI // arg 2 act
MOVQ 24(SP), DX // arg 3 oact MOVQ 24(SP), DX // arg 3 oact
...@@ -76,11 +76,11 @@ TEXT sigtramp(SB),1,$24 ...@@ -76,11 +76,11 @@ TEXT sigtramp(SB),1,$24
CALL sighandler(SB) CALL sighandler(SB)
RET RET
TEXT sys_breakpoint(SB),1,$-8 TEXT sys·breakpoint(SB),1,$-8
BYTE $0xcc BYTE $0xcc
RET RET
TEXT sys_mmap(SB),1,$-8 TEXT sys·mmap(SB),1,$-8
MOVQ 8(SP), DI // arg 1 addr MOVQ 8(SP), DI // arg 1 addr
MOVL 16(SP), SI // arg 2 len MOVL 16(SP), SI // arg 2 len
MOVL 20(SP), DX // arg 3 prot MOVL 20(SP), DX // arg 3 prot
...@@ -98,7 +98,7 @@ TEXT notok(SB),1,$-8 ...@@ -98,7 +98,7 @@ TEXT notok(SB),1,$-8
MOVQ BP, (BP) MOVQ BP, (BP)
RET RET
TEXT sys_memclr(SB),1,$-8 TEXT sys·memclr(SB),1,$-8
MOVQ 8(SP), DI // arg 1 addr MOVQ 8(SP), DI // arg 1 addr
MOVL 16(SP), CX // arg 2 count MOVL 16(SP), CX // arg 2 count
ADDL $7, CX ADDL $7, CX
...@@ -109,7 +109,7 @@ TEXT sys_memclr(SB),1,$-8 ...@@ -109,7 +109,7 @@ TEXT sys_memclr(SB),1,$-8
STOSQ STOSQ
RET RET
TEXT sys_getcallerpc+0(SB),0,$0 TEXT sys·getcallerpc+0(SB),0,$0
MOVQ x+0(FP),AX MOVQ x+0(FP),AX
MOVQ -8(AX),AX MOVQ -8(AX),AX
RET RET
...@@ -25,8 +25,8 @@ loop: ...@@ -25,8 +25,8 @@ loop:
done: done:
ADDQ $8, CX ADDQ $8, CX
CALL check(SB) CALL check(SB)
CALL main_main(SB) CALL main·main(SB)
CALL sys_exit(SB) CALL sys·exit(SB)
CALL notok(SB) CALL notok(SB)
POPQ AX POPQ AX
RET RET
...@@ -34,7 +34,7 @@ done: ...@@ -34,7 +34,7 @@ done:
TEXT FLUSH(SB),1,$-8 TEXT FLUSH(SB),1,$-8
RET RET
TEXT sys_exit(SB),1,$-8 TEXT sys·exit(SB),1,$-8
MOVL 8(SP), DI MOVL 8(SP), DI
MOVL $60, AX MOVL $60, AX
SYSCALL SYSCALL
...@@ -42,7 +42,7 @@ TEXT sys_exit(SB),1,$-8 ...@@ -42,7 +42,7 @@ TEXT sys_exit(SB),1,$-8
CALL notok(SB) CALL notok(SB)
RET RET
TEXT sys_write(SB),1,$-8 TEXT sys·write(SB),1,$-8
MOVL 8(SP), DI MOVL 8(SP), DI
MOVQ 16(SP), SI MOVQ 16(SP), SI
MOVL 24(SP), DX MOVL 24(SP), DX
...@@ -52,7 +52,7 @@ TEXT sys_write(SB),1,$-8 ...@@ -52,7 +52,7 @@ TEXT sys_write(SB),1,$-8
CALL notok(SB) CALL notok(SB)
RET RET
TEXT sys_rt_sigaction(SB),1,$-8 TEXT sys·rt_sigaction(SB),1,$-8
MOVL 8(SP), DI MOVL 8(SP), DI
MOVQ 16(SP), SI MOVQ 16(SP), SI
MOVQ 24(SP), DX MOVQ 24(SP), DX
...@@ -71,11 +71,11 @@ TEXT sigtramp(SB),1,$24 ...@@ -71,11 +71,11 @@ TEXT sigtramp(SB),1,$24
CALL sighandler(SB) CALL sighandler(SB)
RET RET
TEXT sys_breakpoint(SB),1,$-8 TEXT sys·breakpoint(SB),1,$-8
BYTE $0xcc BYTE $0xcc
RET RET
TEXT sys_mmap(SB),1,$-8 TEXT sys·mmap(SB),1,$-8
MOVQ 8(SP), DI MOVQ 8(SP), DI
MOVL 16(SP), SI MOVL 16(SP), SI
MOVL 20(SP), DX MOVL 20(SP), DX
...@@ -103,7 +103,7 @@ TEXT notok(SB),1,$-8 ...@@ -103,7 +103,7 @@ TEXT notok(SB),1,$-8
MOVQ BP, (BP) MOVQ BP, (BP)
RET RET
TEXT sys_memclr(SB),1,$-8 TEXT sys·memclr(SB),1,$-8
MOVQ 8(SP), DI // arg 1 addr MOVQ 8(SP), DI // arg 1 addr
MOVL 16(SP), CX // arg 2 count MOVL 16(SP), CX // arg 2 count
ADDL $7, CX ADDL $7, CX
...@@ -114,7 +114,7 @@ TEXT sys_memclr(SB),1,$-8 ...@@ -114,7 +114,7 @@ TEXT sys_memclr(SB),1,$-8
STOSQ STOSQ
RET RET
TEXT sys_getcallerpc+0(SB),0,$0 TEXT sys·getcallerpc+0(SB),0,$0
MOVQ x+0(FP),AX MOVQ x+0(FP),AX
MOVQ -8(AX),AX MOVQ -8(AX),AX
RET RET
...@@ -39,27 +39,27 @@ _STRUCT_X86_THREAD_STATE64 ...@@ -39,27 +39,27 @@ _STRUCT_X86_THREAD_STATE64
void void
print_thread_state(_STRUCT_X86_THREAD_STATE64* ss) print_thread_state(_STRUCT_X86_THREAD_STATE64* ss)
{ {
prints("\nrax 0x"); sys_printpointer((void*)ss->__rax); prints("\nrax 0x"); sys·printpointer((void*)ss->__rax);
prints("\nrbx 0x"); sys_printpointer((void*)ss->__rbx); prints("\nrbx 0x"); sys·printpointer((void*)ss->__rbx);
prints("\nrcx 0x"); sys_printpointer((void*)ss->__rcx); prints("\nrcx 0x"); sys·printpointer((void*)ss->__rcx);
prints("\nrdx 0x"); sys_printpointer((void*)ss->__rdx); prints("\nrdx 0x"); sys·printpointer((void*)ss->__rdx);
prints("\nrdi 0x"); sys_printpointer((void*)ss->__rdi); prints("\nrdi 0x"); sys·printpointer((void*)ss->__rdi);
prints("\nrsi 0x"); sys_printpointer((void*)ss->__rsi); prints("\nrsi 0x"); sys·printpointer((void*)ss->__rsi);
prints("\nrbp 0x"); sys_printpointer((void*)ss->__rbp); prints("\nrbp 0x"); sys·printpointer((void*)ss->__rbp);
prints("\nrsp 0x"); sys_printpointer((void*)ss->__rsp); prints("\nrsp 0x"); sys·printpointer((void*)ss->__rsp);
prints("\nr8 0x"); sys_printpointer((void*)ss->__r8 ); prints("\nr8 0x"); sys·printpointer((void*)ss->__r8 );
prints("\nr9 0x"); sys_printpointer((void*)ss->__r9 ); prints("\nr9 0x"); sys·printpointer((void*)ss->__r9 );
prints("\nr10 0x"); sys_printpointer((void*)ss->__r10); prints("\nr10 0x"); sys·printpointer((void*)ss->__r10);
prints("\nr11 0x"); sys_printpointer((void*)ss->__r11); prints("\nr11 0x"); sys·printpointer((void*)ss->__r11);
prints("\nr12 0x"); sys_printpointer((void*)ss->__r12); prints("\nr12 0x"); sys·printpointer((void*)ss->__r12);
prints("\nr13 0x"); sys_printpointer((void*)ss->__r13); prints("\nr13 0x"); sys·printpointer((void*)ss->__r13);
prints("\nr14 0x"); sys_printpointer((void*)ss->__r14); prints("\nr14 0x"); sys·printpointer((void*)ss->__r14);
prints("\nr15 0x"); sys_printpointer((void*)ss->__r15); prints("\nr15 0x"); sys·printpointer((void*)ss->__r15);
prints("\nrip 0x"); sys_printpointer((void*)ss->__rip); prints("\nrip 0x"); sys·printpointer((void*)ss->__rip);
prints("\nrflags 0x"); sys_printpointer((void*)ss->__rflags); prints("\nrflags 0x"); sys·printpointer((void*)ss->__rflags);
prints("\ncs 0x"); sys_printpointer((void*)ss->__cs); prints("\ncs 0x"); sys·printpointer((void*)ss->__cs);
prints("\nfs 0x"); sys_printpointer((void*)ss->__fs); prints("\nfs 0x"); sys·printpointer((void*)ss->__fs);
prints("\ngs 0x"); sys_printpointer((void*)ss->__gs); prints("\ngs 0x"); sys·printpointer((void*)ss->__gs);
prints("\n"); prints("\n");
} }
...@@ -134,7 +134,7 @@ sighandler(int32 sig, siginfo *info, void *context) ...@@ -134,7 +134,7 @@ sighandler(int32 sig, siginfo *info, void *context)
{ {
if(sig < 0 || sig >= NSIG){ if(sig < 0 || sig >= NSIG){
prints("Signal "); prints("Signal ");
sys_printint(sig); sys·printint(sig);
}else{ }else{
prints(sigtab[sig].name); prints(sigtab[sig].name);
} }
...@@ -142,14 +142,14 @@ sighandler(int32 sig, siginfo *info, void *context) ...@@ -142,14 +142,14 @@ sighandler(int32 sig, siginfo *info, void *context)
_STRUCT_MCONTEXT64 *uc_mcontext = get_uc_mcontext(context); _STRUCT_MCONTEXT64 *uc_mcontext = get_uc_mcontext(context);
_STRUCT_X86_THREAD_STATE64 *ss = get___ss(uc_mcontext); _STRUCT_X86_THREAD_STATE64 *ss = get___ss(uc_mcontext);
prints("\nFaulting address: 0x"); sys_printpointer(info->si_addr); prints("\nFaulting address: 0x"); sys·printpointer(info->si_addr);
prints("\npc: 0x"); sys_printpointer((void *)ss->__rip); prints("\npc: 0x"); sys·printpointer((void *)ss->__rip);
prints("\n\n"); prints("\n\n");
traceback((void *)ss->__rip, (void *)ss->__rsp); traceback((void *)ss->__rip, (void *)ss->__rsp);
print_thread_state(ss); print_thread_state(ss);
sys_exit(2); sys·exit(2);
} }
sigaction a; sigaction a;
...@@ -167,6 +167,6 @@ initsig(void) ...@@ -167,6 +167,6 @@ initsig(void)
for(i = 0; i <NSIG; i++) for(i = 0; i <NSIG; i++)
if(sigtab[i].catch){ if(sigtab[i].catch){
sys_sigaction(i, &a, (void*)0); sys·sigaction(i, &a, (void*)0);
} }
} }
...@@ -40,20 +40,20 @@ sighandler(int32 sig, siginfo* info, void** context) { ...@@ -40,20 +40,20 @@ sighandler(int32 sig, siginfo* info, void** context) {
if(sig < 0 || sig >= NSIG){ if(sig < 0 || sig >= NSIG){
prints("Signal "); prints("Signal ");
sys_printint(sig); sys·printint(sig);
}else{ }else{
prints(sigtab[sig].name); prints(sigtab[sig].name);
} }
prints("\nFaulting address: 0x"); prints("\nFaulting address: 0x");
sys_printpointer(info->si_addr); sys·printpointer(info->si_addr);
prints("\nPC: 0x"); prints("\nPC: 0x");
sys_printpointer(context[21]); sys·printpointer(context[21]);
prints("\nSP: 0x"); prints("\nSP: 0x");
sys_printpointer(context[20]); sys·printpointer(context[20]);
prints("\n"); prints("\n");
traceback(context[21], context[20]); /* empirically discovered locations */ traceback(context[21], context[20]); /* empirically discovered locations */
sys_breakpoint(); sys·breakpoint();
sys_exit(2); sys·exit(2);
} }
sigaction a; sigaction a;
...@@ -69,6 +69,6 @@ initsig(void) ...@@ -69,6 +69,6 @@ initsig(void)
for(i = 0; i <NSIG; i++) for(i = 0; i <NSIG; i++)
if(sigtab[i].catch){ if(sigtab[i].catch){
sys_rt_sigaction(i, &a, (void*)0, 8); sys·rt_sigaction(i, &a, (void*)0, 8);
} }
} }
...@@ -22,7 +22,7 @@ traceback(uint8 *pc, uint8 *sp) ...@@ -22,7 +22,7 @@ traceback(uint8 *pc, uint8 *sp)
name = "panic"; name = "panic";
for(;;){ for(;;){
prints("0x"); prints("0x");
sys_printpointer(pc); sys·printpointer(pc);
prints("?zi\n"); prints("?zi\n");
/* find SP offset by stepping back through instructions to SP offset marker */ /* find SP offset by stepping back through instructions to SP offset marker */
while(pc > (uint8*)0x1000+sizeof spmark-1) { while(pc > (uint8*)0x1000+sizeof spmark-1) {
...@@ -50,7 +50,7 @@ traceback(uint8 *pc, uint8 *sp) ...@@ -50,7 +50,7 @@ traceback(uint8 *pc, uint8 *sp)
for(i = 0; i < 3; i++){ for(i = 0; i < 3; i++){
if(i != 0) if(i != 0)
prints(", "); prints(", ");
sys_printint(((uint32*)sp)[i]); sys·printint(((uint32*)sp)[i]);
} }
prints(", ...)\n"); prints(", ...)\n");
prints("\t"); prints("\t");
...@@ -60,7 +60,7 @@ traceback(uint8 *pc, uint8 *sp) ...@@ -60,7 +60,7 @@ traceback(uint8 *pc, uint8 *sp)
if(i != 0) if(i != 0)
prints(", "); prints(", ");
prints("0x"); prints("0x");
sys_printpointer(((void**)sp)[i]); sys·printpointer(((void**)sp)[i]);
} }
prints(", ...)\n"); prints(", ...)\n");
/* print pc for next frame */ /* print pc for next frame */
......
...@@ -10,23 +10,23 @@ static int32 empty = 0; ...@@ -10,23 +10,23 @@ static int32 empty = 0;
static string emptystring = (string)&empty; static string emptystring = (string)&empty;
void void
sys_printbool(bool v) sys·printbool(bool v)
{ {
if(v) { if(v) {
sys_write(1, (byte*)"true", 4); sys·write(1, (byte*)"true", 4);
return; return;
} }
sys_write(1, (byte*)"false", 5); sys·write(1, (byte*)"false", 5);
} }
void void
sys_printfloat(float64 v) sys·printfloat(float64 v)
{ {
sys_write(1, "printfloat", 10); sys·write(1, "printfloat", 10);
} }
void void
sys_printint(int64 v) sys·printint(int64 v)
{ {
byte buf[100]; byte buf[100];
int32 i, s; int32 i, s;
...@@ -36,7 +36,7 @@ sys_printint(int64 v) ...@@ -36,7 +36,7 @@ sys_printint(int64 v)
v = -v; v = -v;
s = 1; s = 1;
if(v < 0) { if(v < 0) {
sys_write(1, (byte*)"-oo", 3); sys·write(1, (byte*)"-oo", 3);
return; return;
} }
} }
...@@ -51,11 +51,11 @@ sys_printint(int64 v) ...@@ -51,11 +51,11 @@ sys_printint(int64 v)
i--; i--;
buf[i] = '-'; buf[i] = '-';
} }
sys_write(1, buf+i, nelem(buf)-i); sys·write(1, buf+i, nelem(buf)-i);
} }
void void
sys_printpointer(void *p) sys·printpointer(void *p)
{ {
uint64 v; uint64 v;
byte buf[100]; byte buf[100];
...@@ -70,14 +70,14 @@ sys_printpointer(void *p) ...@@ -70,14 +70,14 @@ sys_printpointer(void *p)
break; break;
v = v/16; v = v/16;
} }
sys_write(1, buf+i, nelem(buf)-i); sys·write(1, buf+i, nelem(buf)-i);
} }
void void
sys_printstring(string v) sys·printstring(string v)
{ {
if(v != nil) if(v != nil)
sys_write(1, v->str, v->len); sys·write(1, v->str, v->len);
} }
int32 int32
...@@ -93,31 +93,31 @@ findnull(int8 *s) ...@@ -93,31 +93,31 @@ findnull(int8 *s)
void void
prints(int8 *s) prints(int8 *s)
{ {
sys_write(1, s, findnull(s)); sys·write(1, s, findnull(s));
} }
void void
sys_printpc(void *p) sys·printpc(void *p)
{ {
prints("PC=0x"); prints("PC=0x");
sys_printpointer(sys_getcallerpc(p)); sys·printpointer(sys·getcallerpc(p));
} }
/*BUG: move traceback code to architecture-dependent runtime */ /*BUG: move traceback code to architecture-dependent runtime */
void void
sys_panicl(int32 lno) sys·panicl(int32 lno)
{ {
uint8 *sp; uint8 *sp;
prints("\npanic on line "); prints("\npanic on line ");
sys_printint(lno); sys·printint(lno);
prints(" "); prints(" ");
sys_printpc(&lno); sys·printpc(&lno);
prints("\n"); prints("\n");
sp = (uint8*)&lno; sp = (uint8*)&lno;
traceback(sys_getcallerpc(&lno), sp); traceback(sys·getcallerpc(&lno), sp);
sys_breakpoint(); sys·breakpoint();
sys_exit(2); sys·exit(2);
} }
dump(byte *p, int32 n) dump(byte *p, int32 n)
...@@ -126,8 +126,8 @@ dump(byte *p, int32 n) ...@@ -126,8 +126,8 @@ dump(byte *p, int32 n)
int32 i; int32 i;
for(i=0; i<n; i++) { for(i=0; i<n; i++) {
sys_printpointer((byte*)(p[i]>>4)); sys·printpointer((byte*)(p[i]>>4));
sys_printpointer((byte*)(p[i]&0xf)); sys·printpointer((byte*)(p[i]&0xf));
if((i&15) == 15) if((i&15) == 15)
prints("\n"); prints("\n");
else else
...@@ -163,7 +163,8 @@ throw(int8 *s) ...@@ -163,7 +163,8 @@ throw(int8 *s)
prints("throw: "); prints("throw: ");
prints(s); prints(s);
prints("\n"); prints("\n");
sys_exit(1); *(int32*)0 = 0;
sys·exit(1);
} }
void void
...@@ -182,8 +183,8 @@ brk(uint32 n) ...@@ -182,8 +183,8 @@ brk(uint32 n)
{ {
byte* v; byte* v;
v = sys_mmap(nil, NHUNK, PROT_READ|PROT_WRITE, MAP_ANON|MAP_PRIVATE, 0, 0); v = sys·mmap(nil, NHUNK, PROT_READ|PROT_WRITE, MAP_ANON|MAP_PRIVATE, 0, 0);
sys_memclr(v, n); sys·memclr(v, n);
nmmap += n; nmmap += n;
return v; return v;
} }
...@@ -248,14 +249,14 @@ cmpstring(string s1, string s2) ...@@ -248,14 +249,14 @@ cmpstring(string s1, string s2)
} }
void void
sys_mal(uint32 n, uint8 *ret) sys·mal(uint32 n, uint8 *ret)
{ {
ret = mal(n); ret = mal(n);
FLUSH(&ret); FLUSH(&ret);
} }
void void
sys_catstring(string s1, string s2, string s3) sys·catstring(string s1, string s2, string s3)
{ {
uint32 l; uint32 l;
...@@ -280,7 +281,7 @@ out: ...@@ -280,7 +281,7 @@ out:
} }
void void
sys_cmpstring(string s1, string s2, int32 v) sys·cmpstring(string s1, string s2, int32 v)
{ {
v = cmpstring(s1, s2); v = cmpstring(s1, s2);
FLUSH(&v); FLUSH(&v);
...@@ -311,17 +312,17 @@ prbounds(int8* s, int32 a, int32 b, int32 c) ...@@ -311,17 +312,17 @@ prbounds(int8* s, int32 a, int32 b, int32 c)
prints(s); prints(s);
prints(" "); prints(" ");
sys_printint(a); sys·printint(a);
prints("<"); prints("<");
sys_printint(b); sys·printint(b);
prints(">"); prints(">");
sys_printint(c); sys·printint(c);
prints("\n"); prints("\n");
throw("bounds"); throw("bounds");
} }
void void
sys_slicestring(string si, int32 lindex, int32 hindex, string so) sys·slicestring(string si, int32 lindex, int32 hindex, string so)
{ {
string s, str; string s, str;
int32 l; int32 l;
...@@ -331,7 +332,7 @@ sys_slicestring(string si, int32 lindex, int32 hindex, string so) ...@@ -331,7 +332,7 @@ sys_slicestring(string si, int32 lindex, int32 hindex, string so)
if(lindex < 0 || lindex > si->len || if(lindex < 0 || lindex > si->len ||
hindex < lindex || hindex > si->len) { hindex < lindex || hindex > si->len) {
sys_printpc(&si); sys·printpc(&si);
prints(" "); prints(" ");
prbounds("slice", lindex, si->len, hindex); prbounds("slice", lindex, si->len, hindex);
} }
...@@ -344,13 +345,13 @@ sys_slicestring(string si, int32 lindex, int32 hindex, string so) ...@@ -344,13 +345,13 @@ sys_slicestring(string si, int32 lindex, int32 hindex, string so)
} }
void void
sys_indexstring(string s, int32 i, byte b) sys·indexstring(string s, int32 i, byte b)
{ {
if(s == nil) if(s == nil)
s = emptystring; s = emptystring;
if(i < 0 || i >= s->len) { if(i < 0 || i >= s->len) {
sys_printpc(&s); sys·printpc(&s);
prints(" "); prints(" ");
prbounds("index", 0, i, s->len); prbounds("index", 0, i, s->len);
} }
...@@ -409,7 +410,7 @@ runetochar(byte *str, uint32 c) ...@@ -409,7 +410,7 @@ runetochar(byte *str, uint32 c)
} }
void void
sys_intstring(int64 v, string s) sys·intstring(int64 v, string s)
{ {
int32 l; int32 l;
...@@ -419,7 +420,7 @@ sys_intstring(int64 v, string s) ...@@ -419,7 +420,7 @@ sys_intstring(int64 v, string s)
} }
void void
sys_byteastring(byte *a, int32 l, string s) sys·byteastring(byte *a, int32 l, string s)
{ {
s = mal(sizeof(s->len)+l); s = mal(sizeof(s->len)+l);
s->len = l; s->len = l;
...@@ -494,16 +495,16 @@ loop2: ...@@ -494,16 +495,16 @@ loop2:
} }
void void
sys_ifaces2i(Sigi *si, Sigs *ss, Map *m, void *s) sys·ifaces2i(Sigi *si, Sigs *ss, Map *m, void *s)
{ {
if(debug) { if(debug) {
prints("s2i sigi="); prints("s2i sigi=");
sys_printpointer(si); sys·printpointer(si);
prints(" sigs="); prints(" sigs=");
sys_printpointer(ss); sys·printpointer(ss);
prints(" s="); prints(" s=");
sys_printpointer(s); sys·printpointer(s);
} }
if(s == nil) { if(s == nil) {
...@@ -517,9 +518,9 @@ sys_ifaces2i(Sigi *si, Sigs *ss, Map *m, void *s) ...@@ -517,9 +518,9 @@ sys_ifaces2i(Sigi *si, Sigs *ss, Map *m, void *s)
if(debug) { if(debug) {
prints(" returning m="); prints(" returning m=");
sys_printpointer(m); sys·printpointer(m);
prints(" s="); prints(" s=");
sys_printpointer(s); sys·printpointer(s);
prints("\n"); prints("\n");
dump((byte*)m, 64); dump((byte*)m, 64);
} }
...@@ -528,16 +529,16 @@ sys_ifaces2i(Sigi *si, Sigs *ss, Map *m, void *s) ...@@ -528,16 +529,16 @@ sys_ifaces2i(Sigi *si, Sigs *ss, Map *m, void *s)
} }
void void
sys_ifacei2i(Sigi *si, Map *m, void *s) sys·ifacei2i(Sigi *si, Map *m, void *s)
{ {
if(debug) { if(debug) {
prints("i2i sigi="); prints("i2i sigi=");
sys_printpointer(si); sys·printpointer(si);
prints(" m="); prints(" m=");
sys_printpointer(m); sys·printpointer(m);
prints(" s="); prints(" s=");
sys_printpointer(s); sys·printpointer(s);
} }
if(m == nil) { if(m == nil) {
...@@ -559,23 +560,23 @@ sys_ifacei2i(Sigi *si, Map *m, void *s) ...@@ -559,23 +560,23 @@ sys_ifacei2i(Sigi *si, Map *m, void *s)
if(debug) { if(debug) {
prints(" returning m="); prints(" returning m=");
sys_printpointer(m); sys·printpointer(m);
prints(" s="); prints(" s=");
sys_printpointer(s); sys·printpointer(s);
prints("\n"); prints("\n");
dump((byte*)m, 64); dump((byte*)m, 64);
} }
} }
void void
sys_ifacei2s(Sigs *ss, Map *m, void *s) sys·ifacei2s(Sigs *ss, Map *m, void *s)
{ {
if(debug) { if(debug) {
prints("i2s m="); prints("i2s m=");
sys_printpointer(m); sys·printpointer(m);
prints(" s="); prints(" s=");
sys_printpointer(s); sys·printpointer(s);
prints("\n"); prints("\n");
} }
...@@ -727,7 +728,7 @@ modf(float64 d, float64 *ip) ...@@ -727,7 +728,7 @@ modf(float64 d, float64 *ip)
// func frexp(float64) (int32, float64); // break fp into exp,fract // func frexp(float64) (int32, float64); // break fp into exp,fract
void void
sys_frexp(float64 din, int32 iou, float64 dou) sys·frexp(float64 din, int32 iou, float64 dou)
{ {
dou = frexp(din, &iou); dou = frexp(din, &iou);
FLUSH(&dou); FLUSH(&dou);
...@@ -735,7 +736,7 @@ sys_frexp(float64 din, int32 iou, float64 dou) ...@@ -735,7 +736,7 @@ sys_frexp(float64 din, int32 iou, float64 dou)
//func ldexp(int32, float64) float64; // make fp from exp,fract //func ldexp(int32, float64) float64; // make fp from exp,fract
void void
sys_ldexp(float64 din, int32 ein, float64 dou) sys·ldexp(float64 din, int32 ein, float64 dou)
{ {
dou = ldexp(din, ein); dou = ldexp(din, ein);
FLUSH(&dou); FLUSH(&dou);
...@@ -743,7 +744,7 @@ sys_ldexp(float64 din, int32 ein, float64 dou) ...@@ -743,7 +744,7 @@ sys_ldexp(float64 din, int32 ein, float64 dou)
//func modf(float64) (float64, float64); // break fp into double+double //func modf(float64) (float64, float64); // break fp into double+double
float64 float64
sys_modf(float64 din, float64 dou1, float64 dou2) sys·modf(float64 din, float64 dou1, float64 dou2)
{ {
dou1 = modf(din, &dou2); dou1 = modf(din, &dou2);
FLUSH(&dou2); FLUSH(&dou2);
...@@ -854,7 +855,7 @@ memprint(uint32 s, void *a) ...@@ -854,7 +855,7 @@ memprint(uint32 s, void *a)
v = *(uint64*)a; v = *(uint64*)a;
break; break;
} }
sys_printint(v); sys·printint(v);
} }
static void static void
...@@ -890,7 +891,7 @@ stringequal(uint32 s, string *a, string *b) ...@@ -890,7 +891,7 @@ stringequal(uint32 s, string *a, string *b)
static void static void
stringprint(uint32 s, string *a) stringprint(uint32 s, string *a)
{ {
sys_printstring(*a); sys·printstring(*a);
} }
static void static void
...@@ -925,7 +926,7 @@ algarray[] = ...@@ -925,7 +926,7 @@ algarray[] =
// keyalg uint32, valalg uint32, // keyalg uint32, valalg uint32,
// hint uint32) (hmap *map[any]any); // hint uint32) (hmap *map[any]any);
void void
sys_newmap(uint32 keysize, uint32 valsize, sys·newmap(uint32 keysize, uint32 valsize,
uint32 keyalg, uint32 valalg, uint32 hint, uint32 keyalg, uint32 valalg, uint32 hint,
Hmap* ret) Hmap* ret)
{ {
...@@ -934,16 +935,16 @@ sys_newmap(uint32 keysize, uint32 valsize, ...@@ -934,16 +935,16 @@ sys_newmap(uint32 keysize, uint32 valsize,
if(keyalg >= nelem(algarray) || if(keyalg >= nelem(algarray) ||
valalg >= nelem(algarray)) { valalg >= nelem(algarray)) {
prints("0<="); prints("0<=");
sys_printint(keyalg); sys·printint(keyalg);
prints("<"); prints("<");
sys_printint(nelem(algarray)); sys·printint(nelem(algarray));
prints("\n0<="); prints("\n0<=");
sys_printint(valalg); sys·printint(valalg);
prints("<"); prints("<");
sys_printint(nelem(algarray)); sys·printint(nelem(algarray));
prints("\n"); prints("\n");
throw("sys_newmap: key/val algorithm out of range"); throw("sys·newmap: key/val algorithm out of range");
} }
m = mal(sizeof(*m)); m = mal(sizeof(*m));
...@@ -966,30 +967,30 @@ sys_newmap(uint32 keysize, uint32 valsize, ...@@ -966,30 +967,30 @@ sys_newmap(uint32 keysize, uint32 valsize,
if(debug) { if(debug) {
prints("newmap: map="); prints("newmap: map=");
sys_printpointer(m); sys·printpointer(m);
prints("; keysize="); prints("; keysize=");
sys_printint(keysize); sys·printint(keysize);
prints("; valsize="); prints("; valsize=");
sys_printint(valsize); sys·printint(valsize);
prints("; keyalg="); prints("; keyalg=");
sys_printint(keyalg); sys·printint(keyalg);
prints("; valalg="); prints("; valalg=");
sys_printint(valalg); sys·printint(valalg);
prints("; valoffset="); prints("; valoffset=");
sys_printint(m->valoffset); sys·printint(m->valoffset);
prints("; ko="); prints("; ko=");
sys_printint(m->ko); sys·printint(m->ko);
prints("; vo="); prints("; vo=");
sys_printint(m->vo); sys·printint(m->vo);
prints("; po="); prints("; po=");
sys_printint(m->po); sys·printint(m->po);
prints("\n"); prints("\n");
} }
} }
// mapaccess1(hmap *map[any]any, key any) (val any); // mapaccess1(hmap *map[any]any, key any) (val any);
void void
sys_mapaccess1(Hmap *m, ...) sys·mapaccess1(Hmap *m, ...)
{ {
Link *l; Link *l;
byte *ak, *av; byte *ak, *av;
...@@ -1008,8 +1009,8 @@ sys_mapaccess1(Hmap *m, ...) ...@@ -1008,8 +1009,8 @@ sys_mapaccess1(Hmap *m, ...)
out: out:
if(debug) { if(debug) {
prints("sys_mapaccess1: map="); prints("sys·mapaccess1: map=");
sys_printpointer(m); sys·printpointer(m);
prints("; key="); prints("; key=");
m->keyalg->print(m->keysize, ak); m->keyalg->print(m->keysize, ak);
prints("; val="); prints("; val=");
...@@ -1020,7 +1021,7 @@ out: ...@@ -1020,7 +1021,7 @@ out:
// mapaccess2(hmap *map[any]any, key any) (val any, pres bool); // mapaccess2(hmap *map[any]any, key any) (val any, pres bool);
void void
sys_mapaccess2(Hmap *m, ...) sys·mapaccess2(Hmap *m, ...)
{ {
Link *l; Link *l;
byte *ak, *av, *ap; byte *ak, *av, *ap;
...@@ -1042,20 +1043,20 @@ sys_mapaccess2(Hmap *m, ...) ...@@ -1042,20 +1043,20 @@ sys_mapaccess2(Hmap *m, ...)
out: out:
if(debug) { if(debug) {
prints("sys_mapaccess2: map="); prints("sys·mapaccess2: map=");
sys_printpointer(m); sys·printpointer(m);
prints("; key="); prints("; key=");
m->keyalg->print(m->keysize, ak); m->keyalg->print(m->keysize, ak);
prints("; val="); prints("; val=");
m->valalg->print(m->valsize, av); m->valalg->print(m->valsize, av);
prints("; pres="); prints("; pres=");
sys_printbool(*ap); sys·printbool(*ap);
prints("\n"); prints("\n");
} }
} }
static void static void
sys_mapassign(Hmap *m, byte *ak, byte *av) sys·mapassign(Hmap *m, byte *ak, byte *av)
{ {
Link *l; Link *l;
...@@ -1077,7 +1078,7 @@ out: ...@@ -1077,7 +1078,7 @@ out:
if(debug) { if(debug) {
prints("mapassign: map="); prints("mapassign: map=");
sys_printpointer(m); sys·printpointer(m);
prints("; key="); prints("; key=");
m->keyalg->print(m->keysize, ak); m->keyalg->print(m->keysize, ak);
prints("; val="); prints("; val=");
...@@ -1088,7 +1089,7 @@ out: ...@@ -1088,7 +1089,7 @@ out:
// mapassign1(hmap *map[any]any, key any, val any); // mapassign1(hmap *map[any]any, key any, val any);
void void
sys_mapassign1(Hmap *m, ...) sys·mapassign1(Hmap *m, ...)
{ {
Link **ll; Link **ll;
byte *ak, *av; byte *ak, *av;
...@@ -1096,12 +1097,12 @@ sys_mapassign1(Hmap *m, ...) ...@@ -1096,12 +1097,12 @@ sys_mapassign1(Hmap *m, ...)
ak = (byte*)&m + m->ko; ak = (byte*)&m + m->ko;
av = (byte*)&m + m->vo; av = (byte*)&m + m->vo;
sys_mapassign(m, ak, av); sys·mapassign(m, ak, av);
} }
// mapassign2(hmap *map[any]any, key any, val any, pres bool); // mapassign2(hmap *map[any]any, key any, val any, pres bool);
void void
sys_mapassign2(Hmap *m, ...) sys·mapassign2(Hmap *m, ...)
{ {
Link **ll; Link **ll;
byte *ak, *av, *ap; byte *ak, *av, *ap;
...@@ -1112,7 +1113,7 @@ sys_mapassign2(Hmap *m, ...) ...@@ -1112,7 +1113,7 @@ sys_mapassign2(Hmap *m, ...)
if(*ap == true) { if(*ap == true) {
// assign // assign
sys_mapassign(m, ak, av); sys·mapassign(m, ak, av);
return; return;
} }
...@@ -1124,7 +1125,7 @@ sys_mapassign2(Hmap *m, ...) ...@@ -1124,7 +1125,7 @@ sys_mapassign2(Hmap *m, ...)
m->len--; m->len--;
if(debug) { if(debug) {
prints("mapdelete (found): map="); prints("mapdelete (found): map=");
sys_printpointer(m); sys·printpointer(m);
prints("; key="); prints("; key=");
m->keyalg->print(m->keysize, ak); m->keyalg->print(m->keysize, ak);
prints("\n"); prints("\n");
...@@ -1135,7 +1136,7 @@ sys_mapassign2(Hmap *m, ...) ...@@ -1135,7 +1136,7 @@ sys_mapassign2(Hmap *m, ...)
if(debug) { if(debug) {
prints("mapdelete (not found): map="); prints("mapdelete (not found): map=");
sys_printpointer(m); sys·printpointer(m);
prints("; key="); prints("; key=");
m->keyalg->print(m->keysize, ak); m->keyalg->print(m->keysize, ak);
prints(" *** not found\n"); prints(" *** not found\n");
......
...@@ -90,7 +90,8 @@ void* mal(uint32); ...@@ -90,7 +90,8 @@ void* mal(uint32);
uint32 cmpstring(string, string); uint32 cmpstring(string, string);
void initsig(void); void initsig(void);
void traceback(uint8 *pc, uint8 *sp); void traceback(uint8 *pc, uint8 *sp);
struct SigTab { struct SigTab
{
int32 catch; int32 catch;
int8 *name; int8 *name;
}; };
...@@ -98,28 +99,28 @@ struct SigTab { ...@@ -98,28 +99,28 @@ struct SigTab {
/* /*
* low level go -called * low level go -called
*/ */
void sys_exit(int32); void sys·exit(int32);
void sys_write(int32, void*, int32); void sys·write(int32, void*, int32);
void sys_breakpoint(void); void sys·breakpoint(void);
uint8* sys_mmap(byte*, uint32, int32, int32, int32, uint32); uint8* sys·mmap(byte*, uint32, int32, int32, int32, uint32);
void sys_memclr(byte*, uint32); void sys·memclr(byte*, uint32);
void* sys_getcallerpc(void*); void* sys·getcallerpc(void*);
void sys_sigaction(int64, void*, void*); void sys·sigaction(int64, void*, void*);
void sys_rt_sigaction(int64, void*, void*, uint64); void sys·rt_sigaction(int64, void*, void*, uint64);
/* /*
* runtime go-called * runtime go-called
*/ */
void sys_printbool(bool); void sys·printbool(bool);
void sys_printfloat(float64); void sys·printfloat(float64);
void sys_printint(int64); void sys·printint(int64);
void sys_printstring(string); void sys·printstring(string);
void sys_printpointer(void*); void sys·printpointer(void*);
void sys_catstring(string, string, string); void sys·catstring(string, string, string);
void sys_cmpstring(string, string, int32); void sys·cmpstring(string, string, int32);
void sys_slicestring(string, int32, int32, string); void sys·slicestring(string, int32, int32, string);
void sys_indexstring(string, int32, byte); void sys·indexstring(string, int32, byte);
void sys_intstring(int64, string); void sys·intstring(int64, string);
void sys_ifaces2i(Sigi*, Sigs*, Map*, void*); void sys·ifaces2i(Sigi*, Sigs*, Map*, void*);
void sys_ifacei2i(Sigi*, Map*, void*); void sys·ifacei2i(Sigi*, Map*, void*);
void sys_ifacei2s(Sigs*, Map*, void*); void sys·ifacei2s(Sigs*, Map*, void*);
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment