ref: 1ce4662c613bd407ef91ed8a782d7ed25bbc9d9b
parent: 2810cc5d0c01b06e678b50995edb724c739b8eed
author: cinap_lenrek <[email protected]>
date: Tue Jul 4 19:53:01 EDT 2023
7c: dont replace SXTW instruction following MOVW $const, r All the MOVW instructions sign extend to full register size, but "MOVW $cosnt, R" is the exception, being equivalent to "MOVWU $const, R" (for historical reasons?). This fixes hjfs regression.
--- a/sys/src/cmd/7c/peep.c
+++ b/sys/src/cmd/7c/peep.c
@@ -252,11 +252,14 @@
if((r1 = findset(r, &p->from)) != R){
p1 = r1->prog;
switch(p1->as){
+ case AMOVW:
+ /* MOVW $const,r; does not sign extend */
+ if(p1->from.type == D_CONST && (p1->from.offset & 0x80000000) != 0)
+ break;
case AMOVB:
- case AMOVBU:
case AMOVH:
+ case AMOVBU:
case AMOVHU:
- case AMOVW:
if(p1->to.type == p->from.type && p1->to.reg == p->from.reg)
p->as = AMOVW;
break;