LIVM/xcase.c

436 lines
23 KiB
C
Raw Permalink Normal View History

2022-02-15 21:55:22 +03:00
/*
(C) M. Æ.
*/
2022-02-14 15:18:13 +03:00
// control
case 0: break;
2022-02-15 21:55:22 +03:00
case 1: ip = args[0]; break;
case 2: ip = cmp * args[0]; break;
case 3: ip = cmp * args[0] + (1 - cmp) * args[1]; break;
case 4: ip = (1 - cmp) * args[0]; break;
case 5: uram64[args[0]] = ip; break;
case 6: sp = uram64[args[0]]; break;
2022-04-09 00:20:48 +03:00
case 7: uram64[args[0]] = sp; break;
case 8: dp = uram64[args[0]]; ram = (void*)((uint64_t*)raw_ram + dp); break;
case 9: uram64[args[0]] = dp; break;
case 10: goto end; break;
case 11: uram64[sp + (++uram64[sp])] = (uint64_t)uram64[args[0]];
case 12: uram64[sp + (++uram64[sp])] = (uint64_t)ram64[args[0]];
case 13: uram64[sp + (++uram64[sp])] = (uint64_t)ramd[args[0]];
case 14: uram64[sp + (++uram64[sp])] = (uint64_t)uram32[args[0]];
case 15: uram64[sp + (++uram64[sp])] = (uint64_t)ram32[args[0]];
case 16: uram64[sp + (++uram64[sp])] = (uint64_t)ramf[args[0]];
case 17: uram64[sp + (++uram64[sp])] = (uint64_t)uram16[args[0]];
case 18: uram64[sp + (++uram64[sp])] = (uint64_t)ram16[args[0]];
case 19: uram64[sp + (++uram64[sp])] = (uint64_t)uram8[args[0]];
case 20: uram64[sp + (++uram64[sp])] = (uint64_t)ram8[args[0]];
case 21: uram64[args[0]] = (uint64_t)uram64[sp + (uram64[sp]--)];
case 22: ram64[args[0]] = (int64_t)uram64[sp + (uram64[sp]--)];
case 23: ramd[args[0]] = (double)uram64[sp + (uram64[sp]--)];
case 24: uram32[args[0]] = (uint32_t)uram64[sp + (uram64[sp]--)];
case 25: ram32[args[0]] = (int32_t)uram64[sp + (uram64[sp]--)];
case 26: ramf[args[0]] = (float)uram64[sp + (uram64[sp]--)];
case 27: uram16[args[0]] = (uint16_t)uram64[sp + (uram64[sp]--)];
case 28: ram16[args[0]] = (int16_t)uram64[sp + (uram64[sp]--)];
case 29: uram8[args[0]] = (uint8_t)uram64[sp + (uram64[sp]--)];
case 30: ram8[args[0]] = (int8_t)uram64[sp + (uram64[sp]--)];
2022-02-14 15:18:13 +03:00
// math
// u64
2022-04-09 00:20:48 +03:00
case 31: uram64[args[0]] += uram64[args[1]]; break;
case 32: uram64[args[0]] -= uram64[args[1]]; break;
case 33: uram64[args[0]] *= uram64[args[1]]; break;
case 34: uram64[args[0]] /= uram64[args[1]]; break;
case 35: uram64[args[0]] %= uram64[args[1]]; break;
case 36: uram64[args[0]] |= uram64[args[1]]; break;
case 37: uram64[args[0]] &= uram64[args[1]]; break;
case 38: uram64[args[0]] = uram64[args[1]] + uram64[args[2]]; break;
case 39: uram64[args[0]] = uram64[args[1]] - uram64[args[2]]; break;
case 40: uram64[args[0]] = uram64[args[1]] * uram64[args[2]]; break;
case 41: uram64[args[0]] = uram64[args[1]] / uram64[args[2]]; break;
case 42: uram64[args[0]] = uram64[args[1]] % uram64[args[2]]; break;
case 43: uram64[args[0]] = uram64[args[1]] | uram64[args[2]]; break;
case 44: uram64[args[0]] = uram64[args[1]] & uram64[args[2]]; break;
case 45: uram64[args[0]] = !uram64[args[1]]; break;
2022-02-14 15:18:13 +03:00
// 64
2022-04-09 00:20:48 +03:00
case 46: ram64[args[0]] += ram64[args[1]]; break;
case 47: ram64[args[0]] -= ram64[args[1]]; break;
case 48: ram64[args[0]] *= ram64[args[1]]; break;
case 49: ram64[args[0]] /= ram64[args[1]]; break;
case 50: ram64[args[0]] %= ram64[args[1]]; break;
case 51: ram64[args[0]] |= ram64[args[1]]; break;
case 52: ram64[args[0]] &= ram64[args[1]]; break;
case 53: ram64[args[0]] = ram64[args[1]] + ram64[args[2]]; break;
case 54: ram64[args[0]] = ram64[args[1]] - ram64[args[2]]; break;
case 55: ram64[args[0]] = ram64[args[1]] * ram64[args[2]]; break;
case 56: ram64[args[0]] = ram64[args[1]] / ram64[args[2]]; break;
case 57: ram64[args[0]] = ram64[args[1]] % ram64[args[2]]; break;
case 58: ram64[args[0]] = ram64[args[1]] | ram64[args[2]]; break;
case 59: ram64[args[0]] = ram64[args[1]] & ram64[args[2]]; break;
case 60: ram64[args[0]] = !ram64[args[1]]; break;
2022-02-14 15:18:13 +03:00
// d
2022-04-09 00:20:48 +03:00
case 61: ramd[args[0]] += ramd[args[1]]; break;
case 62: ramd[args[0]] -= ramd[args[1]]; break;
case 63: ramd[args[0]] *= ramd[args[1]]; break;
case 64: ramd[args[0]] /= ramd[args[1]]; break;
case 65: ramd[args[0]] = ramd[args[1]] + ramd[args[2]]; break;
case 66: ramd[args[0]] = ramd[args[1]] - ramd[args[2]]; break;
case 67: ramd[args[0]] = ramd[args[1]] * ramd[args[2]]; break;
case 68: ramd[args[0]] = ramd[args[1]] / ramd[args[2]]; break;
case 69: ramd[args[0]] = !ramd[args[1]]; break;
2022-02-14 15:18:13 +03:00
// u32
2022-04-09 00:20:48 +03:00
case 70: uram32[args[0]] += uram32[args[1]]; break;
case 71: uram32[args[0]] -= uram32[args[1]]; break;
case 72: uram32[args[0]] *= uram32[args[1]]; break;
case 73: uram32[args[0]] /= uram32[args[1]]; break;
case 74: uram32[args[0]] %= uram32[args[1]]; break;
case 75: uram32[args[0]] |= uram32[args[1]]; break;
case 76: uram32[args[0]] &= uram32[args[1]]; break;
case 77: uram32[args[0]] = uram32[args[1]] + uram32[args[2]]; break;
case 78: uram32[args[0]] = uram32[args[1]] - uram32[args[2]]; break;
case 79: uram32[args[0]] = uram32[args[1]] * uram32[args[2]]; break;
case 80: uram32[args[0]] = uram32[args[1]] / uram32[args[2]]; break;
case 81: uram32[args[0]] = uram32[args[1]] % uram32[args[2]]; break;
case 82: uram32[args[0]] = uram32[args[1]] | uram32[args[2]]; break;
case 83: uram32[args[0]] = uram32[args[1]] & uram32[args[2]]; break;
case 84: uram32[args[0]] = !uram32[args[1]]; break;
2022-02-14 15:18:13 +03:00
// 32
2022-04-09 00:20:48 +03:00
case 85: ram32[args[0]] += ram32[args[1]]; break;
case 86: ram32[args[0]] -= ram32[args[1]]; break;
case 87: ram32[args[0]] *= ram32[args[1]]; break;
case 88: ram32[args[0]] /= ram32[args[1]]; break;
case 89: ram32[args[0]] %= ram32[args[1]]; break;
case 90: ram32[args[0]] |= ram32[args[1]]; break;
case 91: ram32[args[0]] &= ram32[args[1]]; break;
case 92: ram32[args[0]] = ram32[args[1]] + ram32[args[2]]; break;
case 93: ram32[args[0]] = ram32[args[1]] - ram32[args[2]]; break;
case 94: ram32[args[0]] = ram32[args[1]] * ram32[args[2]]; break;
case 95: ram32[args[0]] = ram32[args[1]] / ram32[args[2]]; break;
case 96: ram32[args[0]] = ram32[args[1]] % ram32[args[2]]; break;
case 97: ram32[args[0]] = ram32[args[1]] | ram32[args[2]]; break;
case 98: ram32[args[0]] = ram32[args[1]] & ram32[args[2]]; break;
case 99: ram32[args[0]] = !ram32[args[1]]; break;
2022-02-14 15:18:13 +03:00
// f
2022-04-09 00:20:48 +03:00
case 100: ramf[args[0]] += ramf[args[1]]; break;
case 101: ramf[args[0]] -= ramf[args[1]]; break;
case 102: ramf[args[0]] *= ramf[args[1]]; break;
case 103: ramf[args[0]] /= ramf[args[1]]; break;
case 104: ramf[args[0]] = ramf[args[1]] + ramf[args[2]]; break;
case 105: ramf[args[0]] = ramf[args[1]] - ramf[args[2]]; break;
case 106: ramf[args[0]] = ramf[args[1]] * ramf[args[2]]; break;
case 107: ramf[args[0]] = ramf[args[1]] / ramf[args[2]]; break;
case 108: ramf[args[0]] = !ramf[args[1]]; break;
2022-02-14 15:18:13 +03:00
// u16
2022-04-09 00:20:48 +03:00
case 109: uram16[args[0]] += uram16[args[1]]; break;
case 110: uram16[args[0]] -= uram16[args[1]]; break;
case 111: uram16[args[0]] *= uram16[args[1]]; break;
case 112: uram16[args[0]] /= uram16[args[1]]; break;
case 113: uram16[args[0]] %= uram16[args[1]]; break;
case 114: uram16[args[0]] |= uram16[args[1]]; break;
case 115: uram16[args[0]] &= uram16[args[1]]; break;
case 116: uram16[args[0]] = uram16[args[1]] + uram16[args[2]]; break;
case 117: uram16[args[0]] = uram16[args[1]] - uram16[args[2]]; break;
case 118: uram16[args[0]] = uram16[args[1]] * uram16[args[2]]; break;
case 119: uram16[args[0]] = uram16[args[1]] / uram16[args[2]]; break;
case 120: uram16[args[0]] = uram16[args[1]] % uram16[args[2]]; break;
case 121: uram16[args[0]] = uram16[args[1]] | uram16[args[2]]; break;
case 122: uram16[args[0]] = uram16[args[1]] & uram16[args[2]]; break;
case 123: uram16[args[0]] = !uram16[args[1]]; break;
2022-02-14 15:18:13 +03:00
// 16
2022-04-09 00:20:48 +03:00
case 124: ram16[args[0]] += ram16[args[1]]; break;
case 125: ram16[args[0]] -= ram16[args[1]]; break;
case 126: ram16[args[0]] *= ram16[args[1]]; break;
case 127: ram16[args[0]] /= ram16[args[1]]; break;
case 128: ram16[args[0]] %= ram16[args[1]]; break;
case 129: ram16[args[0]] |= ram16[args[1]]; break;
case 130: ram16[args[0]] &= ram16[args[1]]; break;
case 131: ram16[args[0]] = ram16[args[1]] + ram16[args[2]]; break;
case 132: ram16[args[0]] = ram16[args[1]] - ram16[args[2]]; break;
case 133: ram16[args[0]] = ram16[args[1]] * ram16[args[2]]; break;
case 134: ram16[args[0]] = ram16[args[1]] / ram16[args[2]]; break;
case 135: ram16[args[0]] = ram16[args[1]] % ram16[args[2]]; break;
case 136: ram16[args[0]] = ram16[args[1]] | ram16[args[2]]; break;
case 137: ram16[args[0]] = ram16[args[1]] & ram16[args[2]]; break;
case 138: ram16[args[0]] = !ram16[args[1]]; break;
2022-02-14 15:18:13 +03:00
// u8
2022-04-09 00:20:48 +03:00
case 139: uram8[args[0]] += uram8[args[1]]; break;
case 140: uram8[args[0]] -= uram8[args[1]]; break;
case 141: uram8[args[0]] *= uram8[args[1]]; break;
case 142: uram8[args[0]] /= uram8[args[1]]; break;
case 143: uram8[args[0]] %= uram8[args[1]]; break;
case 144: uram8[args[0]] |= uram8[args[1]]; break;
case 145: uram8[args[0]] &= uram8[args[1]]; break;
case 146: uram8[args[0]] = uram8[args[1]] + uram8[args[2]]; break;
case 147: uram8[args[0]] = uram8[args[1]] - uram8[args[2]]; break;
case 148: uram8[args[0]] = uram8[args[1]] * uram8[args[2]]; break;
case 149: uram8[args[0]] = uram8[args[1]] / uram8[args[2]]; break;
case 150: uram8[args[0]] = uram8[args[1]] % uram8[args[2]]; break;
case 151: uram8[args[0]] = uram8[args[1]] | uram8[args[2]]; break;
case 152: uram8[args[0]] = uram8[args[1]] & uram8[args[2]]; break;
case 153: uram8[args[0]] = !uram8[args[1]]; break;
2022-02-14 15:18:13 +03:00
// 8
2022-04-09 00:20:48 +03:00
case 154: ram8[args[0]] += ram8[args[1]]; break;
case 155: ram8[args[0]] -= ram8[args[1]]; break;
case 156: ram8[args[0]] *= ram8[args[1]]; break;
case 157: ram8[args[0]] /= ram8[args[1]]; break;
case 158: ram8[args[0]] %= ram8[args[1]]; break;
case 159: ram8[args[0]] |= ram8[args[1]]; break;
case 160: ram8[args[0]] &= ram8[args[1]]; break;
case 161: ram8[args[0]] = ram8[args[1]] + ram8[args[2]]; break;
case 162: ram8[args[0]] = ram8[args[1]] - ram8[args[2]]; break;
case 163: ram8[args[0]] = ram8[args[1]] * ram8[args[2]]; break;
case 164: ram8[args[0]] = ram8[args[1]] / ram8[args[2]]; break;
case 165: ram8[args[0]] = ram8[args[1]] % ram8[args[2]]; break;
case 166: ram8[args[0]] = ram8[args[1]] | ram8[args[2]]; break;
case 167: ram8[args[0]] = ram8[args[1]] & ram8[args[2]]; break;
case 168: ram8[args[0]] = !ram8[args[1]]; break;
2022-02-14 15:18:13 +03:00
// ==
2022-04-09 00:20:48 +03:00
case 169: cmp = uram64[args[0]] == uram64[args[1]]; break;
case 170: cmp = ram64[args[0]] == ram64[args[1]]; break;
case 171: cmp = ramd[args[0]] == ramd[args[1]]; break;
case 172: cmp = uram32[args[0]] == uram32[args[1]]; break;
case 173: cmp = ram32[args[0]] == ram32[args[1]]; break;
case 174: cmp = ramf[args[0]] == ramf[args[1]]; break;
case 175: cmp = uram16[args[0]] == uram16[args[1]]; break;
case 176: cmp = ram16[args[0]] == ram16[args[1]]; break;
case 177: cmp = uram8[args[0]] == uram8[args[1]]; break;
case 178: cmp = ram8[args[0]] == ram8[args[1]]; break;
2022-02-14 15:18:13 +03:00
// !=
2022-04-09 00:20:48 +03:00
case 179: cmp = uram64[args[0]] != uram64[args[1]]; break;
case 180: cmp = ram64[args[0]] != ram64[args[1]]; break;
case 181: cmp = ramd[args[0]] != ramd[args[1]]; break;
case 182: cmp = uram32[args[0]] != uram32[args[1]]; break;
case 183: cmp = ram32[args[0]] != ram32[args[1]]; break;
case 184: cmp = ramf[args[0]] != ramf[args[1]]; break;
case 185: cmp = uram16[args[0]] != uram16[args[1]]; break;
case 186: cmp = ram16[args[0]] != ram16[args[1]]; break;
case 187: cmp = uram8[args[0]] != uram8[args[1]]; break;
case 188: cmp = ram8[args[0]] != ram8[args[1]]; break;
2022-02-14 15:18:13 +03:00
// >
2022-04-09 00:20:48 +03:00
case 189: cmp = uram64[args[0]] > uram64[args[1]]; break;
case 190: cmp = ram64[args[0]] > ram64[args[1]]; break;
case 191: cmp = ramd[args[0]] > ramd[args[1]]; break;
case 192: cmp = uram32[args[0]] > uram32[args[1]]; break;
case 193: cmp = ram32[args[0]] > ram32[args[1]]; break;
case 194: cmp = ramf[args[0]] > ramf[args[1]]; break;
case 195: cmp = uram16[args[0]] > uram16[args[1]]; break;
case 196: cmp = ram16[args[0]] > ram16[args[1]]; break;
case 197: cmp = uram8[args[0]] > uram8[args[1]]; break;
case 198: cmp = ram8[args[0]] > ram8[args[1]]; break;
2022-02-14 15:18:13 +03:00
// <
2022-04-09 00:20:48 +03:00
case 199: cmp = uram64[args[0]] < uram64[args[1]]; break;
case 200: cmp = ram64[args[0]] < ram64[args[1]]; break;
case 201: cmp = ramd[args[0]] < ramd[args[1]]; break;
case 202: cmp = uram32[args[0]] < uram32[args[1]]; break;
case 203: cmp = ram32[args[0]] < ram32[args[1]]; break;
case 204: cmp = ramf[args[0]] < ramf[args[1]]; break;
case 205: cmp = uram16[args[0]] < uram16[args[1]]; break;
case 206: cmp = ram16[args[0]] < ram16[args[1]]; break;
case 207: cmp = uram8[args[0]] < uram8[args[1]]; break;
case 208: cmp = ram8[args[0]] < ram8[args[1]]; break;
2022-02-14 15:18:13 +03:00
// >=
2022-04-09 00:20:48 +03:00
case 209: cmp = uram64[args[0]] >= uram64[args[1]]; break;
case 210: cmp = ram64[args[0]] >= ram64[args[1]]; break;
case 211: cmp = ramd[args[0]] >= ramd[args[1]]; break;
case 212: cmp = uram32[args[0]] >= uram32[args[1]]; break;
case 213: cmp = ram32[args[0]] >= ram32[args[1]]; break;
case 214: cmp = ramf[args[0]] >= ramf[args[1]]; break;
case 215: cmp = uram16[args[0]] >= uram16[args[1]]; break;
case 216: cmp = ram16[args[0]] >= ram16[args[1]]; break;
case 217: cmp = uram8[args[0]] >= uram8[args[1]]; break;
case 218: cmp = ram8[args[0]] >= ram8[args[1]]; break;
2022-02-14 15:18:13 +03:00
// <=
2022-04-09 00:20:48 +03:00
case 219: cmp = uram64[args[0]] <= uram64[args[1]]; break;
case 220: cmp = ram64[args[0]] <= ram64[args[1]]; break;
case 221: cmp = ramd[args[0]] <= ramd[args[1]]; break;
case 222: cmp = uram32[args[0]] <= uram32[args[1]]; break;
case 223: cmp = ram32[args[0]] <= ram32[args[1]]; break;
case 224: cmp = ramf[args[0]] <= ramf[args[1]]; break;
case 225: cmp = uram16[args[0]] <= uram16[args[1]]; break;
case 226: cmp = ram16[args[0]] <= ram16[args[1]]; break;
case 227: cmp = uram8[args[0]] <= uram8[args[1]]; break;
case 228: cmp = ram8[args[0]] <= ram8[args[1]]; break;
2022-02-14 15:18:13 +03:00
// ++
2022-04-09 00:20:48 +03:00
case 229: uram64[args[0]]++; break;
case 230: ram64[args[0]]++; break;
case 231: ramd[args[0]]++; break;
case 232: uram32[args[0]]++; break;
case 233: ram32[args[0]]++; break;
case 234: ramf[args[0]]++; break;
case 235: uram16[args[0]]++; break;
case 236: ram16[args[0]]++; break;
case 237: uram8[args[0]]++; break;
case 238: ram8[args[0]]++; break;
2022-02-14 15:18:13 +03:00
// --
2022-04-09 00:20:48 +03:00
case 239: uram64[args[0]]--; break;
case 240: ram64[args[0]]--; break;
case 241: ramd[args[0]]--; break;
case 242: uram32[args[0]]--; break;
case 243: ram32[args[0]]--; break;
case 244: ramf[args[0]]--; break;
case 245: uram16[args[0]]--; break;
case 246: ram16[args[0]]--; break;
case 247: uram8[args[0]]--; break;
case 248: ram8[args[0]]--; break;
2022-02-14 15:18:13 +03:00
// a = b
2022-04-09 00:20:48 +03:00
case 249: uram64[args[0]] = (uint64_t)args[1]; break;
case 250: ram64[args[0]] = (int64_t)args[1]; break;
case 251: ramd[args[0]] = (int64_t)args[1]; break;
case 252: uram32[args[0]] = (uint32_t)args[1]; break;
case 253: ram32[args[0]] = (int32_t)args[1]; break;
case 254: ramf[args[0]] = (int32_t)args[1]; break;
case 255: uram16[args[0]] = (uint16_t)args[1]; break;
case 256: ram16[args[0]] = (int16_t)args[1]; break;
case 257: uram8[args[0]] = (uint8_t)args[1]; break;
case 258: ram8[args[0]] = (int8_t)args[1]; break;
2022-02-14 15:18:13 +03:00
// a = *b
2022-04-09 00:20:48 +03:00
case 259: uram64[args[0]] = uram64[args[1]]; break;
case 260: ram64[args[0]] = ram64[args[1]]; break;
case 261: ramd[args[0]] = ramd[args[1]]; break;
case 262: uram32[args[0]] = uram32[args[1]]; break;
case 263: ram32[args[0]] = ram32[args[1]]; break;
case 264: ramf[args[0]] = ramf[args[1]]; break;
case 265: uram16[args[0]] = uram16[args[1]]; break;
case 266: ram16[args[0]] = ram16[args[1]]; break;
case 267: uram8[args[0]] = uram8[args[1]]; break;
case 268: ram8[args[0]] = ram8[args[1]]; break;
2022-02-14 15:18:13 +03:00
// a = **b
2022-04-09 00:20:48 +03:00
case 269: uram64[args[0]] = uram64[uram64[args[1]]]; break;
case 270: ram64[args[0]] = ram64[uram64[args[1]]]; break;
case 271: ramd[args[0]] = ramd[uram64[args[1]]]; break;
case 272: uram32[args[0]] = uram32[uram64[args[1]]]; break;
case 273: ram32[args[0]] = ram32[uram64[args[1]]]; break;
case 274: ramf[args[0]] = ramf[uram64[args[1]]]; break;
case 275: uram16[args[0]] = uram16[uram64[args[1]]]; break;
case 276: ram16[args[0]] = ram16[uram64[args[1]]]; break;
case 277: uram8[args[0]] = uram8[uram64[args[1]]]; break;
case 278: ram8[args[0]] = ram8[uram64[args[1]]]; break;
// *a = b
2022-04-09 00:20:48 +03:00
case 279: uram64[uram64[args[0]]] = (uint64_t) args[1]; break;
case 280: ram64[uram64[args[0]]] = (int64_t) args[1]; break;
case 281: ramd[uram64[args[0]]] = (double) args[1]; break;
case 282: uram32[uram64[args[0]]] = (uint32_t) args[1]; break;
case 283: ram32[uram64[args[0]]] = (int32_t) args[1]; break;
case 284: ramf[uram64[args[0]]] = (float) args[1]; break;
case 285: uram16[uram64[args[0]]] = (uint16_t) args[1]; break;
case 286: ram16[uram64[args[0]]] = (int16_t) args[1]; break;
case 287: uram8[uram64[args[0]]] = (uint8_t) args[1]; break;
case 288: ram8[uram64[args[0]]] = (int8_t) args[1]; break;
// *a = *b
2022-04-09 00:20:48 +03:00
case 289: uram64[uram64[args[0]]] = uram64[args[1]]; break;
case 290: ram64[uram64[args[0]]] = ram64[args[1]]; break;
case 291: ramd[uram64[args[0]]] = ramd[args[1]]; break;
case 292: uram32[uram64[args[0]]] = uram32[args[1]]; break;
case 293: ram32[uram64[args[0]]] = ram32[args[1]]; break;
case 294: ramf[uram64[args[0]]] = ramf[args[1]]; break;
case 295: uram16[uram64[args[0]]] = uram16[args[1]]; break;
case 296: ram16[uram64[args[0]]] = ram16[args[1]]; break;
case 297: uram8[uram64[args[0]]] = uram8[args[1]]; break;
case 298: ram8[uram64[args[0]]] = ram8[args[1]]; break;
// *a = **b
2022-04-09 00:20:48 +03:00
case 299: uram64[uram64[args[0]]] = uram64[uram64[args[1]]]; break;
case 300: ram64[uram64[args[0]]] = ram64[uram64[args[1]]]; break;
case 301: ramd[uram64[args[0]]] = ramd[uram64[args[1]]]; break;
case 302: uram32[uram64[args[0]]] = uram32[uram64[args[1]]]; break;
case 303: ram32[uram64[args[0]]] = ram32[uram64[args[1]]]; break;
case 304: ramf[uram64[args[0]]] = ramf[uram64[args[1]]]; break;
case 305: uram16[uram64[args[0]]] = uram16[uram64[args[1]]]; break;
case 306: ram16[uram64[args[0]]] = ram16[uram64[args[1]]]; break;
case 307: uram8[uram64[args[0]]] = uram8[uram64[args[1]]]; break;
case 308: ram8[uram64[args[0]]] = ram8[uram64[args[1]]]; break;
2022-02-14 15:18:13 +03:00
// cast
2022-04-09 00:20:48 +03:00
case 309: uram64[args[0]] = (uint64_t)ram64[args[1]]; break;
case 310: uram64[args[0]] = (uint64_t)ramd[args[1]]; break;
case 311: uram64[args[0]] = (uint64_t)uram32[args[1]]; break;
case 312: uram64[args[0]] = (uint64_t)ram32[args[1]]; break;
case 313: uram64[args[0]] = (uint64_t)ramf[args[1]]; break;
case 314: uram64[args[0]] = (uint64_t)uram16[args[1]]; break;
case 315: uram64[args[0]] = (uint64_t)ram16[args[1]]; break;
case 316: uram64[args[0]] = (uint64_t)uram8[args[1]]; break;
case 317: uram64[args[0]] = (uint64_t)ram8[args[1]]; break;
case 318: ram64[args[0]] = (int64_t)uram64[args[1]]; break;
case 319: ram64[args[0]] = (int64_t)ramd[args[1]]; break;
case 320: ram64[args[0]] = (int64_t)uram32[args[1]]; break;
case 321: ram64[args[0]] = (int64_t)ram32[args[1]]; break;
case 322: ram64[args[0]] = (int64_t)ramf[args[1]]; break;
case 323: ram64[args[0]] = (int64_t)uram16[args[1]]; break;
case 324: ram64[args[0]] = (int64_t)ram16[args[1]]; break;
case 325: ram64[args[0]] = (int64_t)uram8[args[1]]; break;
case 326: ram64[args[0]] = (int64_t)ram8[args[1]]; break;
case 327: ramd[args[0]] = (double)uram64[args[1]]; break;
case 328: ramd[args[0]] = (double)ram64[args[1]]; break;
case 329: ramd[args[0]] = (double)uram32[args[1]]; break;
case 330: ramd[args[0]] = (double)ram32[args[1]]; break;
case 331: ramd[args[0]] = (double)ramf[args[1]]; break;
case 332: ramd[args[0]] = (double)uram16[args[1]]; break;
case 333: ramd[args[0]] = (double)ram16[args[1]]; break;
case 334: ramd[args[0]] = (double)uram8[args[1]]; break;
case 335: ramd[args[0]] = (double)ram8[args[1]]; break;
case 336: uram32[args[0]] = (uint32_t)uram64[args[1]]; break;
case 337: uram32[args[0]] = (uint32_t)ram64[args[1]]; break;
case 338: uram32[args[0]] = (uint32_t)ramd[args[1]]; break;
case 339: uram32[args[0]] = (uint32_t)ram32[args[1]]; break;
case 340: uram32[args[0]] = (uint32_t)ramf[args[1]]; break;
case 341: uram32[args[0]] = (uint32_t)uram16[args[1]]; break;
case 342: uram32[args[0]] = (uint32_t)ram16[args[1]]; break;
case 343: uram32[args[0]] = (uint32_t)uram8[args[1]]; break;
case 344: uram32[args[0]] = (uint32_t)ram8[args[1]]; break;
case 345: ram32[args[0]] = (int32_t)uram64[args[1]]; break;
case 346: ram32[args[0]] = (int32_t)ram64[args[1]]; break;
case 347: ram32[args[0]] = (int32_t)ramd[args[1]]; break;
case 348: ram32[args[0]] = (int32_t)uram32[args[1]]; break;
case 349: ram32[args[0]] = (int32_t)ramf[args[1]]; break;
case 350: ram32[args[0]] = (int32_t)uram16[args[1]]; break;
case 351: ram32[args[0]] = (int32_t)ram16[args[1]]; break;
case 352: ram32[args[0]] = (int32_t)uram8[args[1]]; break;
case 353: ram32[args[0]] = (int32_t)ram8[args[1]]; break;
case 354: ramf[args[0]] = (float)uram64[args[1]]; break;
case 355: ramf[args[0]] = (float)ram64[args[1]]; break;
case 356: ramf[args[0]] = (float)ramd[args[1]]; break;
case 357: ramf[args[0]] = (float)uram32[args[1]]; break;
case 358: ramf[args[0]] = (float)ram32[args[1]]; break;
case 359: ramf[args[0]] = (float)uram16[args[1]]; break;
case 360: ramf[args[0]] = (float)ram16[args[1]]; break;
case 361: ramf[args[0]] = (float)uram8[args[1]]; break;
case 362: ramf[args[0]] = (float)ram8[args[1]]; break;
case 363: uram16[args[0]] = (uint16_t)uram64[args[1]]; break;
case 364: uram16[args[0]] = (uint16_t)ram64[args[1]]; break;
case 365: uram16[args[0]] = (uint16_t)ramd[args[1]]; break;
case 366: uram16[args[0]] = (uint16_t)uram32[args[1]]; break;
case 367: uram16[args[0]] = (uint16_t)ram32[args[1]]; break;
case 368: uram16[args[0]] = (uint16_t)ramf[args[1]]; break;
case 369: uram16[args[0]] = (uint16_t)ram16[args[1]]; break;
case 370: uram16[args[0]] = (uint16_t)uram8[args[1]]; break;
case 371: uram16[args[0]] = (uint16_t)ram8[args[1]]; break;
case 372: ram16[args[0]] = (int16_t)uram64[args[1]]; break;
case 373: ram16[args[0]] = (int16_t)ram64[args[1]]; break;
case 374: ram16[args[0]] = (int16_t)ramd[args[1]]; break;
case 375: ram16[args[0]] = (int16_t)uram32[args[1]]; break;
case 376: ram16[args[0]] = (int16_t)ram32[args[1]]; break;
case 377: ram16[args[0]] = (int16_t)ramf[args[1]]; break;
case 378: ram16[args[0]] = (int16_t)uram16[args[1]]; break;
case 379: ram16[args[0]] = (int16_t)uram8[args[1]]; break;
case 380: ram16[args[0]] = (int16_t)ram8[args[1]]; break;
case 381: uram8[args[0]] = (uint8_t)uram64[args[1]]; break;
case 382: uram8[args[0]] = (uint8_t)ram64[args[1]]; break;
case 383: uram8[args[0]] = (uint8_t)ramd[args[1]]; break;
case 384: uram8[args[0]] = (uint8_t)uram32[args[1]]; break;
case 385: uram8[args[0]] = (uint8_t)ram32[args[1]]; break;
case 386: uram8[args[0]] = (uint8_t)ramf[args[1]]; break;
case 387: uram8[args[0]] = (uint8_t)uram16[args[1]]; break;
case 388: uram8[args[0]] = (uint8_t)ram16[args[1]]; break;
case 389: uram8[args[0]] = (int8_t)ram8[args[1]]; break;
case 390: ram8[args[0]] = (int8_t)uram64[args[1]]; break;
case 391: ram8[args[0]] = (int8_t)ram64[args[1]]; break;
case 392: ram8[args[0]] = (int8_t)ramd[args[1]]; break;
case 393: ram8[args[0]] = (int8_t)uram32[args[1]]; break;
case 394: ram8[args[0]] = (int8_t)ram32[args[1]]; break;
case 395: ram8[args[0]] = (int8_t)ramf[args[1]]; break;
case 396: ram8[args[0]] = (int8_t)uram16[args[1]]; break;
case 397: ram8[args[0]] = (int8_t)ram16[args[1]]; break;
case 398: ram8[args[0]] = (int8_t)uram8[args[1]]; break;
2022-02-15 21:55:22 +03:00
// io dev
2022-04-09 00:20:48 +03:00
case 399: devices[args[0]].write(vm, uram8 + args[1] * 8, uram64[args[2]]); break;
case 400: devices[args[0]].out(vm); break;
case 401: devices[args[0]].read(vm, uram8 + args[1] * 8, args[2], args[3]); break;
case 402: devices[args[0]].wait(vm, uram64[args[1]]); break;