diff options
author | cinap_lenrek <cinap_lenrek@felloff.net> | 2016-07-15 21:13:35 +0200 |
---|---|---|
committer | cinap_lenrek <cinap_lenrek@felloff.net> | 2016-07-15 21:13:35 +0200 |
commit | 95524b1cdd24091d8d677d4c7a0bb8492f1a7961 (patch) | |
tree | 6bf03be41c9aedd03f5a58f270ff4d4366eb70d7 /sys/src | |
parent | de1e74abd21007b75e456a7810f923a5043ada87 (diff) |
5c: fix int -> uvlong cast bug (thanks to qwx on his patience on a the trouble session to narrowing it down)
we used to not sign extend if the destination was unsigned
uvlong, which is wrong. we have to sign extend only based
on the signedness of the source (it gets propagated to vlong)
this bug hit in hjfs in the newentry() function, causing file
creation to fail with "create -- phase error":
newentry(...)
{
uvlong sj;
int si;
...
sj = si = -1;
...
}
Diffstat (limited to 'sys/src')
-rw-r--r-- | sys/src/cmd/5c/cgen.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/sys/src/cmd/5c/cgen.c b/sys/src/cmd/5c/cgen.c index a85271565..42421f6cc 100644 --- a/sys/src/cmd/5c/cgen.c +++ b/sys/src/cmd/5c/cgen.c @@ -961,7 +961,7 @@ cgen64(Node *n, Node *nn) reg[nn->right->reg] = 0; cgen(l, &nod1); reg[nn->right->reg] = a; - if(typeu[n->type->etype] || typeu[l->type->etype]) + if(typeu[l->type->etype]) gmove(nodconst(0), nn->right); else gopcode(OASHR, nodconst(31), &nod1, nn->right); |