/* * This file and its contents are supplied under the terms of the * Common Development and Distribution License ("CDDL"), version 1.0. * You may only use this file in accordance with the terms of version * 1.0 of the CDDL. * * A full copy of the text of the CDDL should have accompanied this * source. A copy of the CDDL is also available via the Internet at * http://www.illumos.org/license/CDDL. */ /* * Copyright 2022 Oxide Computer Company */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include "in_guest.h" int main(int argc, char *argv[]) { const char *test_suite_name = basename(argv[0]); struct vmctx *ctx = NULL; struct vcpu *vcpu; int err; ctx = test_initialize(test_suite_name); if ((vcpu = vm_vcpu_open(ctx, 0)) == NULL) { test_fail_errno(errno, "Could not open vcpu0"); } err = test_setup_vcpu(vcpu, MEM_LOC_PAYLOAD, MEM_LOC_STACK); if (err != 0) { test_fail_errno(err, "Could not initialize vcpu0"); } struct vm_entry ventry = { 0 }; struct vm_exit vexit = { 0 }; const uint32_t expected_code = 0x01020304; do { const enum vm_exit_kind kind = test_run_vcpu(vcpu, &ventry, &vexit); switch (kind) { case VEK_REENTR: break; case VEK_UNHANDLED: /* Look for wrmsr of test value */ if (vexit.exitcode != VM_EXITCODE_RDMSR) { test_fail_vmexit(&vexit); } if (vexit.u.msr.code != expected_code) { test_fail_msg("code %08x != %08x\n", vexit.u.msr.code, expected_code); } test_pass(); break; case VEK_TEST_PASS: case VEK_TEST_FAIL: default: test_fail_vmexit(&vexit); break; } } while (true); }