ucall
struct ucall uc;
struct ucall uc;
struct ucall uc;
static void handle_sync(struct kvm_vcpu *vcpu, struct ucall *uc)
struct ucall uc;
struct ucall uc;
static void handle_sync(struct kvm_vcpu *vcpu, struct ucall *uc)
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
static void kvm_inject_get_call(struct kvm_vm *vm, struct ucall *uc,
struct ucall uc;
static void kvm_inject_get_call(struct kvm_vm *vm, struct ucall *uc,
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
#define REPORT_GUEST_ASSERT(ucall) \
test_assert(false, (const char *)(ucall).args[GUEST_ERROR_STRING], \
(const char *)(ucall).args[GUEST_FILE], \
(ucall).args[GUEST_LINE], "%s", (ucall).buffer)
struct ucall *hva;
void ucall(uint64_t cmd, int nargs, ...);
uint64_t get_ucall(struct kvm_vcpu *vcpu, struct ucall *uc);
ucall(UCALL_SYNC, 6, "hello", stage, arg1, arg2, arg3, arg4)
#define GUEST_SYNC(stage) ucall(UCALL_SYNC, 2, "hello", stage)
#define GUEST_SYNC1(arg0) ucall(UCALL_SYNC, 1, arg0)
#define GUEST_SYNC2(arg0, arg1) ucall(UCALL_SYNC, 2, arg0, arg1)
ucall(UCALL_SYNC, 3, arg0, arg1, arg2)
ucall(UCALL_SYNC, 4, arg0, arg1, arg2, arg3)
ucall(UCALL_SYNC, 5, arg0, arg1, arg2, arg3, arg4)
ucall(UCALL_SYNC, 6, arg0, arg1, arg2, arg3, arg4, arg5)
#define GUEST_DONE() ucall(UCALL_DONE, 0)
#define REPORT_GUEST_PRINTF(ucall) pr_info("%s", (ucall).buffer)
ucall(UCALL_UNHANDLED, 3, vector, ec, valid_ec);
struct ucall uc;
struct ucall uc;
ucall(UCALL_UNHANDLED, 3, pc, estat, badv);
ucall(UCALL_UNHANDLED, 2, vector, ec);
struct ucall uc;
struct ucall *uc;
struct ucall *uc;
struct ucall ucalls[KVM_MAX_VCPUS];
uint64_t get_ucall(struct kvm_vcpu *vcpu, struct ucall *uc)
struct ucall ucall;
uc = &ucall;
struct ucall *uc;
static struct ucall *ucall_alloc(void)
struct ucall *uc;
static void ucall_free(struct ucall *uc)
struct ucall *uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc; \
struct ucall uc;
struct ucall uc; \
struct ucall uc;
struct ucall uc;
static void handle_sync(struct ucall *uc, uint64_t start, uint64_t end)
static void handle_abort(struct ucall *uc)
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
static void handle_sync(struct ucall *uc, struct kvm_clock_data *start,
static void handle_abort(struct ucall *uc)
static void pr_hcall(struct ucall *uc)
struct ucall uc;
#define PR_MSR(msr) ucall(UCALL_PR_MSR, 1, msr)
#define PR_HCALL(hc) ucall(UCALL_PR_HCALL, 1, hc)
static void pr_msr(struct ucall *uc)
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
#define GUEST_SLEEP(sec) ucall(UCALL_SYNC, 2, USLEEP, sec)
#define GUEST_CHECK(level, freq) ucall(UCALL_SYNC, 2, level, freq)
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc_none = {
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc = {};
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;
struct ucall uc;