summaryrefslogtreecommitdiff
path: root/sys/src/ape/lib/fmt/dofmt.c
diff options
context:
space:
mode:
authorcinap_lenrek <cinap_lenrek@felloff.net>2016-01-07 19:04:12 +0100
committercinap_lenrek <cinap_lenrek@felloff.net>2016-01-07 19:04:12 +0100
commit4308f6e7e6586e3a27aa46c4d54c434b8533b16d (patch)
tree5a0229a80dd8dd900a9dbec809481c8538a80161 /sys/src/ape/lib/fmt/dofmt.c
parent772afbe98c7e74be35e7e5318967ce594e4d93e8 (diff)
ape/fmt: %p and %z format for amd64
Diffstat (limited to 'sys/src/ape/lib/fmt/dofmt.c')
-rw-r--r--sys/src/ape/lib/fmt/dofmt.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/sys/src/ape/lib/fmt/dofmt.c b/sys/src/ape/lib/fmt/dofmt.c
index 7f314e93e..3422e62cd 100644
--- a/sys/src/ape/lib/fmt/dofmt.c
+++ b/sys/src/ape/lib/fmt/dofmt.c
@@ -348,7 +348,11 @@ __ifmt(Fmt *f)
break;
}
if(f->r == 'p'){
- u = (ulong)va_arg(f->args, void*);
+ if(sizeof(void*) == sizeof(uvlong)){
+ isv = 1;
+ vu = (uvlong)va_arg(f->args, void*);
+ } else
+ u = (ulong)va_arg(f->args, void*);
f->r = 'x';
fl |= FmtUnsigned;
}else if(fl & FmtVLong){
@@ -538,6 +542,11 @@ __flagfmt(Fmt *f)
f->flags |= FmtVLong;
f->flags |= FmtLong;
break;
+ case 'z':
+ f->flags |= FmtLong;
+ if(sizeof(void*) == sizeof(vlong))
+ f->flags |= FmtVLong;
+ break;
}
return 1;
}