Spaces:
Runtime error
Runtime error
File size: 1,670 Bytes
8df6da4 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
#!/usr/bin/env node
import path from "node:path";
import url from "node:url";
const BENCH_COLLECT_STATS = +process.env.BENCH_COLLECT_STATS;
const { V86 } = await import(BENCH_COLLECT_STATS ? "../../src/main.js" : "../../build/libv86.mjs");
const __dirname = url.fileURLToPath(new URL(".", import.meta.url));
const V86_ROOT = path.join(__dirname, "../..");
const LOG_SERIAL = true;
var emulator = new V86({
bios: { url: __dirname + "/../../bios/seabios.bin" },
vga_bios: { url: __dirname + "/../../bios/vgabios.bin" },
cdrom: { url: __dirname + "/../../images/linux3.iso" },
autostart: true,
memory_size: 1024 * 1024 * 1024,
disable_jit: +process.env.DISABLE_JIT,
log_level: 0,
});
emulator.bus.register("emulator-started", function()
{
console.log("Booting now, please stand by");
start_time = Date.now();
});
var serial_text = "";
var start_time;
emulator.add_listener("serial0-output-byte", function(byte)
{
var chr = String.fromCharCode(byte);
if(chr < " " && chr !== "\n" && chr !== "\t" || chr > "~")
{
return;
}
if(LOG_SERIAL) process.stdout.write(chr);
serial_text += chr;
if(serial_text.endsWith("~% ") || serial_text.endsWith("root@localhost:~# "))
{
console.log("Creating snapshots");
const start_time = Date.now();
for(var i = 0; i < 10; ++i) emulator.save_state();
const end_time = Date.now();
const elapsed = end_time - start_time;
console.log("Done in %dms", elapsed);
emulator.destroy();
if(BENCH_COLLECT_STATS)
{
console.log(emulator.get_instruction_stats());
}
}
});
|