// The OS/K Team licenses this file to you under the MIT license. // See the LICENSE file in the project root for more information. #include #include #include #include #include //----------------------------------------------------------------------------// IMPL_START_0(into) { INTO(); } IMPL_END; IMPL_START_0(pause) { usleep(5000); } IMPL_END; //----------------------------------------------------------------------------// IMPL_START_0(break) { #ifndef NDEBUG trace("\nExecuting BREAK INSTR\n"); dumpregs(ctx); do_hlt(ctx); trace("Resuming execution\n"); #endif } IMPL_END; IMPL_START_0(dump) { #ifndef NDEBUG if (ctx->dumpsw) trace("0x%lX:\t...\n", rpc); else if (!ctx->dumpsw) dump_instr(ctx, ctx->cur_in, p1, p2, p3, 0, 0); ctx->dumpsw = !ctx->dumpsw; #endif } IMPL_END; //----------------------------------------------------------------------------// IMPL_START_X_NOIN(ytime) { time_t t = time(NULL); struct tm *tm = localtime(&t); v1 = tm->tm_sec + tm->tm_min * 60 + tm->tm_hour * 60 * 60 + tm->tm_mday * 60 * 60 * 24; v2 = tm->tm_mon; v3 = tm->tm_year + 1900; } IMPL_OUT_3; IMPL_START_1(utime) { struct timeval time; gettimeofday(&time, NULL); v1 = (time.tv_sec * 1000) + (time.tv_usec / 1000); } IMPL_OUT; //----------------------------------------------------------------------------// IMPL_START_0(cls) { R(RAX) = R(RBX) = R(RCX) = R(RDX) = R(RDI) = R(RSI) = R(RFX) = 0; for (int i = R10; i <= NX7; i++) R(i) = 0; } IMPL_END; //----------------------------------------------------------------------------// IMPL_START_2(bswap) { v1 = ((v2 & 0xFF00000000000000) >> 56) | ((v2 & 0x00FF000000000000) >> 40) | ((v2 & 0x0000FF0000000000) >> 24) | ((v2 & 0x000000FF00000000) >> 8) | ((v2 & 0x00000000FF000000) << 8) | ((v2 & 0x0000000000FF0000) << 24) | ((v2 & 0x000000000000FF00) << 40) | ((v2 & 0x00000000000000FF) << 56); } IMPL_OUT; IMPL_START_2(wswap) { v1 = ((v2 & 0xFFFF000000000000) >> 48) | ((v2 & 0x0000FFFF00000000) >> 16) | ((v2 & 0x00000000FFFF0000) << 16) | ((v2 & 0x000000000000FFFF) << 48); } IMPL_OUT; IMPL_START_2(dswap) { v1 = ((v2 & 0xFFFFFFFF00000000) >> 32) | ((v2 & 0x00000000FFFFFFFF) << 32); } IMPL_OUT; //----------------------------------------------------------------------------// IMPL_START_0(prn) { DECVZX(v1, p1); // Magic value? :) if (__builtin_expect(v1 == 0xC15000AF, 0)) console_clear(ctx); else { if (p1->mlen > 1) { trace("prn warning: large access size\n"); } if (v1 > 0) console_putc(ctx, (char)v1); } } IMPL_END IMPL_START_0(prns) { uchar ch = readmemzx(ctx, R(p1->reg), 1); COMPARE_SUB(ch, 0); if ((R(RFX) & ZF) == 0) { console_putc(ctx, ch); if (R(RFX) & DF) R(p1->reg)--; else R(p1->reg)++; } } IMPL_END IMPL_START_X_NOIN(scan) { v1 = console_scankeybuf(ctx); } IMPL_OUT; //----------------------------------------------------------------------------//