diff options
author | Ori Bernstein <ori@eigenstate.org> | 2021-01-23 20:36:09 -0800 |
---|---|---|
committer | Ori Bernstein <ori@eigenstate.org> | 2021-01-23 20:36:09 -0800 |
commit | 5b8b5884f4eacd26b1e234c5abedd1615d895003 (patch) | |
tree | 8d439f1056e0d8e6e355b6827f8ffcc3790c2e04 | |
parent | f76e28cb71fd7f45eda35f68c89a6ba151625313 (diff) | |
download | plan9front-5b8b5884f4eacd26b1e234c5abedd1615d895003.tar.xz |
5l: fix shifts by zero
on arm32, we can do one of 4 shifts
by a constant:
reg<<(0..31)
reg>>(1..32)
((u32int)reg)>>(1..32)
reg ROT (0..31)
There's no way to encode a 0 bit right
shift, so when encoding reg>>0, flip
it to the equivalent nop reg<<0, which
can be encoded.
-rw-r--r-- | sys/src/cmd/5l/asm.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/sys/src/cmd/5l/asm.c b/sys/src/cmd/5l/asm.c index 1d3ecc68b..54f3343e1 100644 --- a/sys/src/cmd/5l/asm.c +++ b/sys/src/cmd/5l/asm.c @@ -785,7 +785,10 @@ PP = p; case 8: /* sll $c,[R],R -> mov (R<<$c),R */ aclass(&p->from); - o1 = oprrr(p->as, p->scond); + if((p->as == ASRL || p->as == ASRA) && instoffset == 0) + o1 = oprrr(ASLL, p->scond); + else + o1 = oprrr(p->as, p->scond); r = p->reg; if(r == NREG) r = p->to.reg; |