commit b610a88083629da3b5dda6fa0ebc1ca4a72cf0ac
parent 23203381a745b59a68a2dc759507033dc21d277f
Author: neauoire <aliceffekt@gmail.com>
Date: Wed, 9 Aug 2023 19:31:33 -0700
(uxn.c) Faster SET() macro
Diffstat:
1 file changed, 14 insertions(+), 15 deletions(-)
diff --git a/src/uxn.c b/src/uxn.c
@@ -17,34 +17,33 @@ WITH REGARD TO THIS SOFTWARE.
[ L2 ][ N2 ][ T2 ] <
*/
-#define T *sp
-#define N *(sp-1)
-#define L *(sp-2)
-#define T2 PEEK2((sp-1))
-#define H2 PEEK2((sp-2))
-#define N2 PEEK2((sp-3))
-#define L2 PEEK2((sp-5))
+#define T *ptr
+#define N *(ptr-1)
+#define L *(ptr-2)
+#define T2 PEEK2((ptr-1))
+#define H2 PEEK2((ptr-2))
+#define N2 PEEK2((ptr-3))
+#define L2 PEEK2((ptr-5))
#define HALT(c) { return emu_halt(u, ins, c, pc - 1); }
#define FLIP { s = ins & 0x40 ? &u->wst : &u->rst; }
-#define SET(x, y) { if(x > s->ptr) HALT(1) tmp = (x & k) + y + s->ptr; if(tmp > 254) HALT(2) s->ptr = tmp; sp = s->dat + tmp - 1; }
-#define PUT1(o, v) { *(sp - o) = v; }
-#define PUT2(o, v) { tmp = (v); POKE2(sp - 1 - o, tmp); }
+#define SET(x, y) { r = s->ptr; if(x > r) HALT(1) r += (x & k) + y; if(r > 254) HALT(2) ptr = s->dat + r - 1; s->ptr = r; }
+#define PUT1(o, v) { *(ptr - o) = v; }
+#define PUT2(o, v) { r = (v); POKE2(ptr - 1 - o, r); }
int
uxn_eval(Uxn *u, Uint16 pc)
{
- int t, n, l, k, tmp, ins, opc;
- Uint8 *ram = u->ram, *sp;
+ int t, n, l, k, r;
+ Uint8 *ram = u->ram, *ptr, ins;
Stack *s;
if(!pc || u->dev[0x0f]) return 0;
for(;;) {
ins = ram[pc++];
k = ins & 0x80 ? 0xff : 0;
s = ins & 0x40 ? &u->rst : &u->wst;
- sp = s->dat + s->ptr - 1;
- opc = !(ins & 0x1f) ? (0 - (ins >> 5)) & 0xff : ins & 0x3f;
- switch(opc) {
+ ptr = s->dat + s->ptr - 1;
+ switch(!(ins & 0x1f) ? (0 - (ins >> 5)) & 0xff : ins & 0x3f) {
/* IMM */
case 0x00: /* BRK */ return 1;
case 0xff: /* JCI */ if(!s->dat[--s->ptr]) { pc += 2; break; }