ref: a3b95d3e567c0ef60f9f1ead26124fb706dec20d
parent: 0bc0f1cfcec73baddc58cab9a61c720bb8c15077
author: cinap_lenrek <[email protected]>
date: Sun Jun 11 09:09:44 EDT 2023
7c: implement bit rotations using ROR/EXT instruction
--- a/sys/src/cmd/7c/cgen.c
+++ b/sys/src/cmd/7c/cgen.c
@@ -199,6 +199,7 @@
case OADD:
case OAND:
case OOR:
+ case OROL:
case OLSHR:
case OASHL:
case OASHR:
--- a/sys/src/cmd/7c/peep.c
+++ b/sys/src/cmd/7c/peep.c
@@ -481,6 +481,7 @@
case ALSL:
case ALSR:
case AASR:
+ case AROR:
case AORR:
case AAND:
case AANDS:
@@ -502,6 +503,7 @@
case ALSLW:
case ALSRW:
case AASRW:
+ case ARORW:
case AORRW:
case AANDW:
case AANDSW:
@@ -1173,6 +1175,8 @@
case ALSRW:
case AASR:
case AASRW:
+ case AROR:
+ case ARORW:
case AORR:
case AORRW:
case AAND:
@@ -1331,6 +1335,8 @@
case ALSRW:
case AASR:
case AASRW:
+ case AROR:
+ case ARORW:
case AORR:
case AORRW:
case AAND:
--- a/sys/src/cmd/7c/sgen.c
+++ b/sys/src/cmd/7c/sgen.c
@@ -181,6 +181,18 @@
simplifyshift(n);
break;
+ case OOR:
+ xcom(l);
+ xcom(r);
+ switch(n->type->etype){
+ case TUINT:
+ case TULONG:
+ case TUVLONG:
+ rolor(n);
+ break;
+ }
+ break;
+
default:
if(l != Z)
xcom(l);
--- a/sys/src/cmd/7c/txt.c
+++ b/sys/src/cmd/7c/txt.c
@@ -1037,6 +1037,16 @@
a = AORR;
break;
+ case OROL:
+ if(isv(et)){
+ a = AROR;
+ f1->vconst = 64-f1->vconst;
+ } else {
+ a = ARORW;
+ f1->vconst = 32-f1->vconst;
+ }
+ break;
+
case OASAND:
case OAND:
a = AANDW;
--- a/sys/src/libmach/7db.c
+++ b/sys/src/libmach/7db.c
@@ -159,6 +159,7 @@
"1001001101000000011111nnnnnddddd", "SXTW", "R%n,R%d",
"0101001100iiiiii011111nnnnnddddd", "LSRW", "$%i,R%n,R%d",
"1101001101iiiiii111111nnnnnddddd", "LSR", "$%i,R%n,R%d",
+ "W00100111-0mmmmmiiiiiinnnnnddddd", "EXTR%W", "$%i,R%m,R%n,R%d",
"W00100110-iiiiiijjjjjjnnnnnddddd", "SBFM%W", "$%i,$%j,R%n,R%d",
"W01100110-iiiiiijjjjjjnnnnnddddd", "BFM%W", "$%i,$%j,R%n,R%d",
"W10100110-iiiiiijjjjjjnnnnnddddd", "UBFM%W", "$%i,$%j,R%n,R%d",