(uxn.c) tighter switch

This commit is contained in:
neauoire 2023-11-09 14:25:12 -08:00
parent 91257363c2
commit d53473175c
3 changed files with 17 additions and 16 deletions

View File

@ -31,21 +31,22 @@ uxn_eval(Uxn *u, Uint16 pc)
Uint16 tt, a, b, c;
if(!pc || u->dev[0x0f]) return 0;
for(;;) {
Uint8 ins = ram[pc++], opc = ins & 0x1f, m2 = ins & 0x20;
Uint8 ins = ram[pc++], m2 = ins & 0x20;
Stack *s = ins & 0x40 ? &u->rst : &u->wst;
if(ins & 0x80)
kp = s->ptr, sp = &kp;
else
sp = &s->ptr;
/* Opcodes */
switch(opc ? opc : ins) {
/* Immediate */
if(ins & 0x80) kp = s->ptr, sp = &kp;
else sp = &s->ptr;
/* OPC */
switch(ins & 0x1f) {
/* IMM */
case 0x00: case 0x20:
switch(ins) {
case 0x00: /* BRK */ return 1;
case 0x20: /* JCI */ POP1(b) if(!b) { pc += 2; break; } /* else fallthrough */
case 0x20: /* JCI */ POP1(b) if(!b) { pc += 2; break; } /* fall-through */
case 0x40: /* JMI */ pc += PEEK2(ram + pc) + 2; break;
case 0x60: /* JSI */ PUSH2(pc + 2) pc += PEEK2(ram + pc) + 2; break;
case 0x80: case 0xc0: /* LIT */ PUSH1(ram[pc++]) break;
case 0xa0: case 0xe0: /* LIT2 */ PUSH1(ram[pc++]) PUSH1(ram[pc++]) break;
} break;
/* ALU */
case 0x01: /* INC */ POPx(a) PUSHx(a + 1) break;
case 0x02: /* POP */ POPx(a) break;

View File

@ -261,7 +261,7 @@ main(int argc, char **argv)
return system_error("usage", "uxn11 [-v] file.rom [args...]");
/* Read flags */
if(argv[i][0] == '-' && argv[i][1] == 'v')
return system_version("Uxn11 - Graphical Varvara Emulator", "31 Oct 2023");
return system_version("Uxn11 - Graphical Varvara Emulator", "9 Nov 2023");
if(!emu_init())
return system_error("Init", "Failed to initialize varvara.");
if(!system_init(&u, (Uint8 *)calloc(0x10000 * RAM_PAGES, sizeof(Uint8)), argv[i++]))

View File

@ -70,7 +70,7 @@ main(int argc, char **argv)
return system_error("usage", "uxncli [-v] file.rom [args..]");
/* Read flags */
if(argv[i][0] == '-' && argv[i][1] == 'v')
return system_version("Uxncli - Console Varvara Emulator", "31 Oct 2023");
return system_version("Uxncli - Console Varvara Emulator", "9 Nov 2023");
if(!system_init(&u, (Uint8 *)calloc(0x10000 * RAM_PAGES, sizeof(Uint8)), argv[i++]))
return system_error("Init", "Failed to initialize uxn.");
/* Game Loop */