diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/cmd/acid/acid.h | 8 | ||||
-rw-r--r-- | src/cmd/acid/builtin.c | 6 | ||||
-rw-r--r-- | src/cmd/acid/dbg.y | 2 | ||||
-rw-r--r-- | src/cmd/acid/dot.c | 2 | ||||
-rw-r--r-- | src/cmd/acid/exec.c | 2 | ||||
-rw-r--r-- | src/cmd/acid/expr.c | 3 | ||||
-rw-r--r-- | src/cmd/acid/lex.c | 4 | ||||
-rw-r--r-- | src/cmd/acid/main.c | 2 | ||||
-rw-r--r-- | src/cmd/acid/util.c | 2 | ||||
-rw-r--r-- | src/libmach/elfcorefreebsdamd64.c | 3 | ||||
-rw-r--r-- | src/libmach/regs.c | 5 |
11 files changed, 21 insertions, 18 deletions
diff --git a/src/cmd/acid/acid.h b/src/cmd/acid/acid.h index d83d7c09..5b1339fe 100644 --- a/src/cmd/acid/acid.h +++ b/src/cmd/acid/acid.h @@ -204,7 +204,7 @@ void call(char*, Node*, Node*, Node*, Node*); void catcher(void*, char*); void checkqid(int, int); void cmd(void); -Node* con(int); +Node* con(s64int); List* construct(Node*); void ctrace(int); void decl(Node*); @@ -217,12 +217,12 @@ Lsym* enter(char*, int); void error(char*, ...); void execute(Node*); void fatal(char*, ...); -ulong findframe(ulong); +u64int findframe(u64int); void flatten(Node**, Node*); void gc(void); char* getstatus(int); void* gmalloc(long); -void indir(Map*, ulong, char, Node*); +void indir(Map*, u64int, char, Node*); void indirreg(Regs*, char*, char, Node*); void initexpr(void); void initprint(void); @@ -251,7 +251,7 @@ void pstr(String*); void pushfd(int); void pushfile(char*); void pushstr(Node*); -ulong raddr(char*); +u64int raddr(char*); void readtext(char*); void readcore(void); void restartio(void); diff --git a/src/cmd/acid/builtin.c b/src/cmd/acid/builtin.c index 1b09a4ef..ddc326a4 100644 --- a/src/cmd/acid/builtin.c +++ b/src/cmd/acid/builtin.c @@ -866,7 +866,7 @@ cvtatoi(Node *r, Node *args) r->op = OCONST; r->type = TINT; - r->store.u.ival = strtoul(res.store.u.string->string, 0, 0); + r->store.u.ival = strtoull(res.store.u.string->string, 0, 0); r->store.fmt = 'D'; } @@ -875,7 +875,7 @@ cvtitoa(Node *r, Node *args) { Node res; Node *av[Maxarg]; - int ival; + s64int ival; char buf[128], *fmt; if(args == 0) @@ -1030,7 +1030,7 @@ flatten(Node **av, Node *n) static struct { char *name; - ulong val; + u64int val; } sregs[Maxarg/2]; static int nsregs; diff --git a/src/cmd/acid/dbg.y b/src/cmd/acid/dbg.y index 3d1886c7..ca3368fa 100644 --- a/src/cmd/acid/dbg.y +++ b/src/cmd/acid/dbg.y @@ -11,7 +11,7 @@ { Node *node; Lsym *sym; - ulong ival; + u64int ival; float fval; String *string; } diff --git a/src/cmd/acid/dot.c b/src/cmd/acid/dot.c index 07b8c194..fd446492 100644 --- a/src/cmd/acid/dot.c +++ b/src/cmd/acid/dot.c @@ -28,7 +28,7 @@ odot(Node *n, Node *r) char *s; Type *t; Node res; - ulong addr; + u64int addr; s = n->sym->name; if(s == 0) diff --git a/src/cmd/acid/exec.c b/src/cmd/acid/exec.c index b173ef3b..3864cd0a 100644 --- a/src/cmd/acid/exec.c +++ b/src/cmd/acid/exec.c @@ -203,7 +203,7 @@ convflt(Node *r, char *flt) } void -indir(Map *m, ulong addr, char fmt, Node *r) +indir(Map *m, u64int addr, char fmt, Node *r) { int i; u32int ival; diff --git a/src/cmd/acid/expr.c b/src/cmd/acid/expr.c index 5d81ac58..9d657b19 100644 --- a/src/cmd/acid/expr.c +++ b/src/cmd/acid/expr.c @@ -1114,9 +1114,8 @@ acidregsrw(Regs *r, char *name, u64int *u, int isr) } addr = v->store.u.ival; /* XXX should use format to determine size */ - if(get4(cormap, addr, &u32) < 0) + if(geta(cormap, addr, u) < 0) return -1; - *u = u32; return 0; } } diff --git a/src/cmd/acid/lex.c b/src/cmd/acid/lex.c index 548b4262..19581eab 100644 --- a/src/cmd/acid/lex.c +++ b/src/cmd/acid/lex.c @@ -588,9 +588,9 @@ numsym(char first) } if(isbin) - yylval.ival = strtoul(symbol+2, 0, 2); + yylval.ival = strtoull(symbol+2, 0, 2); else - yylval.ival = strtoul(symbol, 0, 0); + yylval.ival = strtoll(symbol, 0, 0); return Tconst; } diff --git a/src/cmd/acid/main.c b/src/cmd/acid/main.c index b63bfe2b..59ae90b1 100644 --- a/src/cmd/acid/main.c +++ b/src/cmd/acid/main.c @@ -365,7 +365,7 @@ al(int t) } Node* -con(int v) +con(s64int v) { Node *n; diff --git a/src/cmd/acid/util.c b/src/cmd/acid/util.c index 7772bfdb..29db6d8b 100644 --- a/src/cmd/acid/util.c +++ b/src/cmd/acid/util.c @@ -73,7 +73,7 @@ addvarsym(Fhdr *fp) Symbol s; Lsym *l; String *file; - ulong v; + u64int v; char buf[65536]; /* Some of those C++ names are really big */ List *list, **tail, *tl; diff --git a/src/libmach/elfcorefreebsdamd64.c b/src/libmach/elfcorefreebsdamd64.c index aefed432..dd7f6f94 100644 --- a/src/libmach/elfcorefreebsdamd64.c +++ b/src/libmach/elfcorefreebsdamd64.c @@ -113,7 +113,8 @@ elfcorefreebsdamd64(Fhdr *fp, Elf *elf, ElfNote *note) u->flags = l->rflags; u->sp = l->rsp; u->ss = l->ss; - +print("core PC=%#llux SP=%#llux\n", u->ip, u->sp); + if((fp->thread = realloc(fp->thread, (1+fp->nthread)*sizeof(fp->thread[0]))) == nil){ fprint(2, "warning: out of memory saving thread info\n"); return; diff --git a/src/libmach/regs.c b/src/libmach/regs.c index 4df03cbd..07616c1f 100644 --- a/src/libmach/regs.c +++ b/src/libmach/regs.c @@ -27,7 +27,7 @@ int rget(Regs *regs, char *name, u64int *u) { if(regs == nil){ - *u = ~(ulong)0; + *u = ~(u64int)0; werrstr("registers not mapped"); return -1; } @@ -54,6 +54,9 @@ _uregrw(Regs *regs, char *name, u64int *u, int isr) case 'X': *u = mach->swap4(*(u32int*)ureg); return 0; + case 'Y': + *u = mach->swap8(*(u64int*)ureg); + return 0; } } |