ref: c67d0c699f7b52da534f75d3620776997b1e8d52
parent: 28089ee035e8502ed03225c3850070c0c2882ae6
author: cinap_lenrek <cinap_lenrek@felloff.net>
date: Sun Jan 8 12:41:10 EST 2017
6c: reverse register allocation order to avoid having to spill AX,DX and CX allocating AX,CX,DX last improves 64-bit multiplication-add chains like a*b + c*d as the multiplication does not need to save and restore AX and DX registers in most cases. reserving CX for shifts also helps.
--- a/sys/src/cmd/6c/txt.c
+++ b/sys/src/cmd/6c/txt.c
@@ -343,9 +343,12 @@
if(i >= D_AX && i <= D_R15)
goto out;
}
- for(i=D_AX; i<=D_R15; i++)
+ for(i=D_AX; i<=D_R15; i++){
+ i ^= 7;
if(reg[i] == 0 && !resvreg[i])
goto out;
+ i ^= 7;
+ }
diag(tn, "out of fixed registers");
goto err;