Commit 250e138d authored by Andrew Jones's avatar Andrew Jones Committed by Sean Christopherson

KVM: selftests: Remove redundant newlines

TEST_* functions append their own newline. Remove newlines from
TEST_* callsites to avoid extra newlines in output.
Signed-off-by: default avatarAndrew Jones <ajones@ventanamicro.com>
Link: https://lore.kernel.org/r/20231206170241.82801-8-ajones@ventanamicro.comSigned-off-by: default avatarSean Christopherson <seanjc@google.com>
parent 02add85a
...@@ -45,10 +45,10 @@ static void vcpu_worker(struct memstress_vcpu_args *vcpu_args) ...@@ -45,10 +45,10 @@ static void vcpu_worker(struct memstress_vcpu_args *vcpu_args)
/* Let the guest access its memory */ /* Let the guest access its memory */
ret = _vcpu_run(vcpu); ret = _vcpu_run(vcpu);
TEST_ASSERT(ret == 0, "vcpu_run failed: %d\n", ret); TEST_ASSERT(ret == 0, "vcpu_run failed: %d", ret);
if (get_ucall(vcpu, NULL) != UCALL_SYNC) { if (get_ucall(vcpu, NULL) != UCALL_SYNC) {
TEST_ASSERT(false, TEST_ASSERT(false,
"Invalid guest sync status: exit_reason=%s\n", "Invalid guest sync status: exit_reason=%s",
exit_reason_str(run->exit_reason)); exit_reason_str(run->exit_reason));
} }
......
...@@ -88,9 +88,9 @@ static void vcpu_worker(struct memstress_vcpu_args *vcpu_args) ...@@ -88,9 +88,9 @@ static void vcpu_worker(struct memstress_vcpu_args *vcpu_args)
ret = _vcpu_run(vcpu); ret = _vcpu_run(vcpu);
ts_diff = timespec_elapsed(start); ts_diff = timespec_elapsed(start);
TEST_ASSERT(ret == 0, "vcpu_run failed: %d\n", ret); TEST_ASSERT(ret == 0, "vcpu_run failed: %d", ret);
TEST_ASSERT(get_ucall(vcpu, NULL) == UCALL_SYNC, TEST_ASSERT(get_ucall(vcpu, NULL) == UCALL_SYNC,
"Invalid guest sync status: exit_reason=%s\n", "Invalid guest sync status: exit_reason=%s",
exit_reason_str(run->exit_reason)); exit_reason_str(run->exit_reason));
pr_debug("Got sync event from vCPU %d\n", vcpu_idx); pr_debug("Got sync event from vCPU %d\n", vcpu_idx);
......
...@@ -262,7 +262,7 @@ static void default_after_vcpu_run(struct kvm_vcpu *vcpu, int ret, int err) ...@@ -262,7 +262,7 @@ static void default_after_vcpu_run(struct kvm_vcpu *vcpu, int ret, int err)
"vcpu run failed: errno=%d", err); "vcpu run failed: errno=%d", err);
TEST_ASSERT(get_ucall(vcpu, NULL) == UCALL_SYNC, TEST_ASSERT(get_ucall(vcpu, NULL) == UCALL_SYNC,
"Invalid guest sync status: exit_reason=%s\n", "Invalid guest sync status: exit_reason=%s",
exit_reason_str(run->exit_reason)); exit_reason_str(run->exit_reason));
vcpu_handle_sync_stop(); vcpu_handle_sync_stop();
...@@ -410,7 +410,7 @@ static void dirty_ring_after_vcpu_run(struct kvm_vcpu *vcpu, int ret, int err) ...@@ -410,7 +410,7 @@ static void dirty_ring_after_vcpu_run(struct kvm_vcpu *vcpu, int ret, int err)
pr_info("vcpu continues now.\n"); pr_info("vcpu continues now.\n");
} else { } else {
TEST_ASSERT(false, "Invalid guest sync status: " TEST_ASSERT(false, "Invalid guest sync status: "
"exit_reason=%s\n", "exit_reason=%s",
exit_reason_str(run->exit_reason)); exit_reason_str(run->exit_reason));
} }
} }
......
...@@ -152,7 +152,7 @@ static void check_supported(struct vcpu_reg_list *c) ...@@ -152,7 +152,7 @@ static void check_supported(struct vcpu_reg_list *c)
continue; continue;
__TEST_REQUIRE(kvm_has_cap(s->capability), __TEST_REQUIRE(kvm_has_cap(s->capability),
"%s: %s not available, skipping tests\n", "%s: %s not available, skipping tests",
config_name(c), s->name); config_name(c), s->name);
} }
} }
......
...@@ -98,7 +98,7 @@ static void ucall_abort(const char *assert_msg, const char *expected_assert_msg) ...@@ -98,7 +98,7 @@ static void ucall_abort(const char *assert_msg, const char *expected_assert_msg)
int offset = len_str - len_substr; int offset = len_str - len_substr;
TEST_ASSERT(len_substr <= len_str, TEST_ASSERT(len_substr <= len_str,
"Expected '%s' to be a substring of '%s'\n", "Expected '%s' to be a substring of '%s'",
assert_msg, expected_assert_msg); assert_msg, expected_assert_msg);
TEST_ASSERT(strcmp(&assert_msg[offset], expected_assert_msg) == 0, TEST_ASSERT(strcmp(&assert_msg[offset], expected_assert_msg) == 0,
...@@ -116,7 +116,7 @@ static void run_test(struct kvm_vcpu *vcpu, const char *expected_printf, ...@@ -116,7 +116,7 @@ static void run_test(struct kvm_vcpu *vcpu, const char *expected_printf,
vcpu_run(vcpu); vcpu_run(vcpu);
TEST_ASSERT(run->exit_reason == UCALL_EXIT_REASON, TEST_ASSERT(run->exit_reason == UCALL_EXIT_REASON,
"Unexpected exit reason: %u (%s),\n", "Unexpected exit reason: %u (%s),",
run->exit_reason, exit_reason_str(run->exit_reason)); run->exit_reason, exit_reason_str(run->exit_reason));
switch (get_ucall(vcpu, &uc)) { switch (get_ucall(vcpu, &uc)) {
...@@ -161,11 +161,11 @@ static void test_limits(void) ...@@ -161,11 +161,11 @@ static void test_limits(void)
vcpu_run(vcpu); vcpu_run(vcpu);
TEST_ASSERT(run->exit_reason == UCALL_EXIT_REASON, TEST_ASSERT(run->exit_reason == UCALL_EXIT_REASON,
"Unexpected exit reason: %u (%s),\n", "Unexpected exit reason: %u (%s),",
run->exit_reason, exit_reason_str(run->exit_reason)); run->exit_reason, exit_reason_str(run->exit_reason));
TEST_ASSERT(get_ucall(vcpu, &uc) == UCALL_ABORT, TEST_ASSERT(get_ucall(vcpu, &uc) == UCALL_ABORT,
"Unexpected ucall command: %lu, Expected: %u (UCALL_ABORT)\n", "Unexpected ucall command: %lu, Expected: %u (UCALL_ABORT)",
uc.cmd, UCALL_ABORT); uc.cmd, UCALL_ABORT);
kvm_vm_free(vm); kvm_vm_free(vm);
......
...@@ -41,7 +41,7 @@ static void *run_vcpu(void *arg) ...@@ -41,7 +41,7 @@ static void *run_vcpu(void *arg)
vcpu_run(vcpu); vcpu_run(vcpu);
TEST_ASSERT(false, "%s: exited with reason %d: %s\n", TEST_ASSERT(false, "%s: exited with reason %d: %s",
__func__, run->exit_reason, __func__, run->exit_reason,
exit_reason_str(run->exit_reason)); exit_reason_str(run->exit_reason));
pthread_exit(NULL); pthread_exit(NULL);
...@@ -55,7 +55,7 @@ static void *sleeping_thread(void *arg) ...@@ -55,7 +55,7 @@ static void *sleeping_thread(void *arg)
fd = open("/dev/null", O_RDWR); fd = open("/dev/null", O_RDWR);
close(fd); close(fd);
} }
TEST_ASSERT(false, "%s: exited\n", __func__); TEST_ASSERT(false, "%s: exited", __func__);
pthread_exit(NULL); pthread_exit(NULL);
} }
...@@ -118,7 +118,7 @@ static void run_test(uint32_t run) ...@@ -118,7 +118,7 @@ static void run_test(uint32_t run)
for (i = 0; i < VCPU_NUM; ++i) for (i = 0; i < VCPU_NUM; ++i)
check_join(threads[i], &b); check_join(threads[i], &b);
/* Should not be reached */ /* Should not be reached */
TEST_ASSERT(false, "%s: [%d] child escaped the ninja\n", __func__, run); TEST_ASSERT(false, "%s: [%d] child escaped the ninja", __func__, run);
} }
void wait_for_child_setup(pid_t pid) void wait_for_child_setup(pid_t pid)
......
...@@ -65,7 +65,7 @@ int main(int argc, char *argv[]) ...@@ -65,7 +65,7 @@ int main(int argc, char *argv[])
int r = setrlimit(RLIMIT_NOFILE, &rl); int r = setrlimit(RLIMIT_NOFILE, &rl);
__TEST_REQUIRE(r >= 0, __TEST_REQUIRE(r >= 0,
"RLIMIT_NOFILE hard limit is too low (%d, wanted %d)\n", "RLIMIT_NOFILE hard limit is too low (%d, wanted %d)",
old_rlim_max, nr_fds_wanted); old_rlim_max, nr_fds_wanted);
} else { } else {
TEST_ASSERT(!setrlimit(RLIMIT_NOFILE, &rl), "setrlimit() failed!"); TEST_ASSERT(!setrlimit(RLIMIT_NOFILE, &rl), "setrlimit() failed!");
......
...@@ -204,9 +204,9 @@ static void *vcpu_worker(void *data) ...@@ -204,9 +204,9 @@ static void *vcpu_worker(void *data)
ret = _vcpu_run(vcpu); ret = _vcpu_run(vcpu);
ts_diff = timespec_elapsed(start); ts_diff = timespec_elapsed(start);
TEST_ASSERT(ret == 0, "vcpu_run failed: %d\n", ret); TEST_ASSERT(ret == 0, "vcpu_run failed: %d", ret);
TEST_ASSERT(get_ucall(vcpu, NULL) == UCALL_SYNC, TEST_ASSERT(get_ucall(vcpu, NULL) == UCALL_SYNC,
"Invalid guest sync status: exit_reason=%s\n", "Invalid guest sync status: exit_reason=%s",
exit_reason_str(vcpu->run->exit_reason)); exit_reason_str(vcpu->run->exit_reason));
pr_debug("Got sync event from vCPU %d\n", vcpu->id); pr_debug("Got sync event from vCPU %d\n", vcpu->id);
......
...@@ -184,7 +184,7 @@ void kvm_vm_elf_load(struct kvm_vm *vm, const char *filename) ...@@ -184,7 +184,7 @@ void kvm_vm_elf_load(struct kvm_vm *vm, const char *filename)
"Seek to program segment offset failed,\n" "Seek to program segment offset failed,\n"
" program header idx: %u errno: %i\n" " program header idx: %u errno: %i\n"
" offset_rv: 0x%jx\n" " offset_rv: 0x%jx\n"
" expected: 0x%jx\n", " expected: 0x%jx",
n1, errno, (intmax_t) offset_rv, n1, errno, (intmax_t) offset_rv,
(intmax_t) phdr.p_offset); (intmax_t) phdr.p_offset);
test_read(fd, addr_gva2hva(vm, phdr.p_vaddr), test_read(fd, addr_gva2hva(vm, phdr.p_vaddr),
......
...@@ -320,7 +320,7 @@ static uint64_t vm_nr_pages_required(enum vm_guest_mode mode, ...@@ -320,7 +320,7 @@ static uint64_t vm_nr_pages_required(enum vm_guest_mode mode,
uint64_t nr_pages; uint64_t nr_pages;
TEST_ASSERT(nr_runnable_vcpus, TEST_ASSERT(nr_runnable_vcpus,
"Use vm_create_barebones() for VMs that _never_ have vCPUs\n"); "Use vm_create_barebones() for VMs that _never_ have vCPUs");
TEST_ASSERT(nr_runnable_vcpus <= kvm_check_cap(KVM_CAP_MAX_VCPUS), TEST_ASSERT(nr_runnable_vcpus <= kvm_check_cap(KVM_CAP_MAX_VCPUS),
"nr_vcpus = %d too large for host, max-vcpus = %d", "nr_vcpus = %d too large for host, max-vcpus = %d",
...@@ -491,7 +491,7 @@ void kvm_pin_this_task_to_pcpu(uint32_t pcpu) ...@@ -491,7 +491,7 @@ void kvm_pin_this_task_to_pcpu(uint32_t pcpu)
CPU_ZERO(&mask); CPU_ZERO(&mask);
CPU_SET(pcpu, &mask); CPU_SET(pcpu, &mask);
r = sched_setaffinity(0, sizeof(mask), &mask); r = sched_setaffinity(0, sizeof(mask), &mask);
TEST_ASSERT(!r, "sched_setaffinity() failed for pCPU '%u'.\n", pcpu); TEST_ASSERT(!r, "sched_setaffinity() failed for pCPU '%u'.", pcpu);
} }
static uint32_t parse_pcpu(const char *cpu_str, const cpu_set_t *allowed_mask) static uint32_t parse_pcpu(const char *cpu_str, const cpu_set_t *allowed_mask)
...@@ -499,7 +499,7 @@ static uint32_t parse_pcpu(const char *cpu_str, const cpu_set_t *allowed_mask) ...@@ -499,7 +499,7 @@ static uint32_t parse_pcpu(const char *cpu_str, const cpu_set_t *allowed_mask)
uint32_t pcpu = atoi_non_negative("CPU number", cpu_str); uint32_t pcpu = atoi_non_negative("CPU number", cpu_str);
TEST_ASSERT(CPU_ISSET(pcpu, allowed_mask), TEST_ASSERT(CPU_ISSET(pcpu, allowed_mask),
"Not allowed to run on pCPU '%d', check cgroups?\n", pcpu); "Not allowed to run on pCPU '%d', check cgroups?", pcpu);
return pcpu; return pcpu;
} }
...@@ -529,7 +529,7 @@ void kvm_parse_vcpu_pinning(const char *pcpus_string, uint32_t vcpu_to_pcpu[], ...@@ -529,7 +529,7 @@ void kvm_parse_vcpu_pinning(const char *pcpus_string, uint32_t vcpu_to_pcpu[],
int i, r; int i, r;
cpu_list = strdup(pcpus_string); cpu_list = strdup(pcpus_string);
TEST_ASSERT(cpu_list, "strdup() allocation failed.\n"); TEST_ASSERT(cpu_list, "strdup() allocation failed.");
r = sched_getaffinity(0, sizeof(allowed_mask), &allowed_mask); r = sched_getaffinity(0, sizeof(allowed_mask), &allowed_mask);
TEST_ASSERT(!r, "sched_getaffinity() failed"); TEST_ASSERT(!r, "sched_getaffinity() failed");
...@@ -538,7 +538,7 @@ void kvm_parse_vcpu_pinning(const char *pcpus_string, uint32_t vcpu_to_pcpu[], ...@@ -538,7 +538,7 @@ void kvm_parse_vcpu_pinning(const char *pcpus_string, uint32_t vcpu_to_pcpu[],
/* 1. Get all pcpus for vcpus. */ /* 1. Get all pcpus for vcpus. */
for (i = 0; i < nr_vcpus; i++) { for (i = 0; i < nr_vcpus; i++) {
TEST_ASSERT(cpu, "pCPU not provided for vCPU '%d'\n", i); TEST_ASSERT(cpu, "pCPU not provided for vCPU '%d'", i);
vcpu_to_pcpu[i] = parse_pcpu(cpu, &allowed_mask); vcpu_to_pcpu[i] = parse_pcpu(cpu, &allowed_mask);
cpu = strtok(NULL, delim); cpu = strtok(NULL, delim);
} }
...@@ -1057,7 +1057,7 @@ void vm_mem_add(struct kvm_vm *vm, enum vm_mem_backing_src_type src_type, ...@@ -1057,7 +1057,7 @@ void vm_mem_add(struct kvm_vm *vm, enum vm_mem_backing_src_type src_type,
TEST_ASSERT(ret == 0, "KVM_SET_USER_MEMORY_REGION2 IOCTL failed,\n" TEST_ASSERT(ret == 0, "KVM_SET_USER_MEMORY_REGION2 IOCTL failed,\n"
" rc: %i errno: %i\n" " rc: %i errno: %i\n"
" slot: %u flags: 0x%x\n" " slot: %u flags: 0x%x\n"
" guest_phys_addr: 0x%lx size: 0x%lx guest_memfd: %d\n", " guest_phys_addr: 0x%lx size: 0x%lx guest_memfd: %d",
ret, errno, slot, flags, ret, errno, slot, flags,
guest_paddr, (uint64_t) region->region.memory_size, guest_paddr, (uint64_t) region->region.memory_size,
region->region.guest_memfd); region->region.guest_memfd);
...@@ -1222,7 +1222,7 @@ void vm_guest_mem_fallocate(struct kvm_vm *vm, uint64_t base, uint64_t size, ...@@ -1222,7 +1222,7 @@ void vm_guest_mem_fallocate(struct kvm_vm *vm, uint64_t base, uint64_t size,
len = min_t(uint64_t, end - gpa, region->region.memory_size - offset); len = min_t(uint64_t, end - gpa, region->region.memory_size - offset);
ret = fallocate(region->region.guest_memfd, mode, fd_offset, len); ret = fallocate(region->region.guest_memfd, mode, fd_offset, len);
TEST_ASSERT(!ret, "fallocate() failed to %s at %lx (len = %lu), fd = %d, mode = %x, offset = %lx\n", TEST_ASSERT(!ret, "fallocate() failed to %s at %lx (len = %lu), fd = %d, mode = %x, offset = %lx",
punch_hole ? "punch hole" : "allocate", gpa, len, punch_hole ? "punch hole" : "allocate", gpa, len,
region->region.guest_memfd, mode, fd_offset); region->region.guest_memfd, mode, fd_offset);
} }
...@@ -1265,7 +1265,7 @@ struct kvm_vcpu *__vm_vcpu_add(struct kvm_vm *vm, uint32_t vcpu_id) ...@@ -1265,7 +1265,7 @@ struct kvm_vcpu *__vm_vcpu_add(struct kvm_vm *vm, uint32_t vcpu_id)
struct kvm_vcpu *vcpu; struct kvm_vcpu *vcpu;
/* Confirm a vcpu with the specified id doesn't already exist. */ /* Confirm a vcpu with the specified id doesn't already exist. */
TEST_ASSERT(!vcpu_exists(vm, vcpu_id), "vCPU%d already exists\n", vcpu_id); TEST_ASSERT(!vcpu_exists(vm, vcpu_id), "vCPU%d already exists", vcpu_id);
/* Allocate and initialize new vcpu structure. */ /* Allocate and initialize new vcpu structure. */
vcpu = calloc(1, sizeof(*vcpu)); vcpu = calloc(1, sizeof(*vcpu));
......
...@@ -192,7 +192,7 @@ struct kvm_vm *memstress_create_vm(enum vm_guest_mode mode, int nr_vcpus, ...@@ -192,7 +192,7 @@ struct kvm_vm *memstress_create_vm(enum vm_guest_mode mode, int nr_vcpus,
TEST_ASSERT(guest_num_pages < region_end_gfn, TEST_ASSERT(guest_num_pages < region_end_gfn,
"Requested more guest memory than address space allows.\n" "Requested more guest memory than address space allows.\n"
" guest pages: %" PRIx64 " max gfn: %" PRIx64 " guest pages: %" PRIx64 " max gfn: %" PRIx64
" nr_vcpus: %d wss: %" PRIx64 "]\n", " nr_vcpus: %d wss: %" PRIx64 "]",
guest_num_pages, region_end_gfn - 1, nr_vcpus, vcpu_memory_bytes); guest_num_pages, region_end_gfn - 1, nr_vcpus, vcpu_memory_bytes);
args->gpa = (region_end_gfn - guest_num_pages - 1) * args->guest_page_size; args->gpa = (region_end_gfn - guest_num_pages - 1) * args->guest_page_size;
......
...@@ -69,7 +69,7 @@ static void *uffd_handler_thread_fn(void *arg) ...@@ -69,7 +69,7 @@ static void *uffd_handler_thread_fn(void *arg)
if (pollfd[1].revents & POLLIN) { if (pollfd[1].revents & POLLIN) {
r = read(pollfd[1].fd, &tmp_chr, 1); r = read(pollfd[1].fd, &tmp_chr, 1);
TEST_ASSERT(r == 1, TEST_ASSERT(r == 1,
"Error reading pipefd in UFFD thread\n"); "Error reading pipefd in UFFD thread");
break; break;
} }
......
...@@ -45,7 +45,7 @@ static void vcpu_worker(struct memstress_vcpu_args *vcpu_args) ...@@ -45,7 +45,7 @@ static void vcpu_worker(struct memstress_vcpu_args *vcpu_args)
/* Let the guest access its memory until a stop signal is received */ /* Let the guest access its memory until a stop signal is received */
while (!READ_ONCE(memstress_args.stop_vcpus)) { while (!READ_ONCE(memstress_args.stop_vcpus)) {
ret = _vcpu_run(vcpu); ret = _vcpu_run(vcpu);
TEST_ASSERT(ret == 0, "vcpu_run failed: %d\n", ret); TEST_ASSERT(ret == 0, "vcpu_run failed: %d", ret);
if (get_ucall(vcpu, NULL) == UCALL_SYNC) if (get_ucall(vcpu, NULL) == UCALL_SYNC)
continue; continue;
......
...@@ -175,11 +175,11 @@ static void wait_for_vcpu(void) ...@@ -175,11 +175,11 @@ static void wait_for_vcpu(void)
struct timespec ts; struct timespec ts;
TEST_ASSERT(!clock_gettime(CLOCK_REALTIME, &ts), TEST_ASSERT(!clock_gettime(CLOCK_REALTIME, &ts),
"clock_gettime() failed: %d\n", errno); "clock_gettime() failed: %d", errno);
ts.tv_sec += 2; ts.tv_sec += 2;
TEST_ASSERT(!sem_timedwait(&vcpu_ready, &ts), TEST_ASSERT(!sem_timedwait(&vcpu_ready, &ts),
"sem_timedwait() failed: %d\n", errno); "sem_timedwait() failed: %d", errno);
} }
static void *vm_gpa2hva(struct vm_data *data, uint64_t gpa, uint64_t *rempages) static void *vm_gpa2hva(struct vm_data *data, uint64_t gpa, uint64_t *rempages)
...@@ -336,7 +336,7 @@ static bool prepare_vm(struct vm_data *data, int nslots, uint64_t *maxslots, ...@@ -336,7 +336,7 @@ static bool prepare_vm(struct vm_data *data, int nslots, uint64_t *maxslots,
gpa = vm_phy_pages_alloc(data->vm, npages, guest_addr, slot); gpa = vm_phy_pages_alloc(data->vm, npages, guest_addr, slot);
TEST_ASSERT(gpa == guest_addr, TEST_ASSERT(gpa == guest_addr,
"vm_phy_pages_alloc() failed\n"); "vm_phy_pages_alloc() failed");
data->hva_slots[slot - 1] = addr_gpa2hva(data->vm, guest_addr); data->hva_slots[slot - 1] = addr_gpa2hva(data->vm, guest_addr);
memset(data->hva_slots[slot - 1], 0, npages * guest_page_size); memset(data->hva_slots[slot - 1], 0, npages * guest_page_size);
......
...@@ -245,7 +245,7 @@ int main(int argc, char *argv[]) ...@@ -245,7 +245,7 @@ int main(int argc, char *argv[])
} while (snapshot != atomic_read(&seq_cnt)); } while (snapshot != atomic_read(&seq_cnt));
TEST_ASSERT(rseq_cpu == cpu, TEST_ASSERT(rseq_cpu == cpu,
"rseq CPU = %d, sched CPU = %d\n", rseq_cpu, cpu); "rseq CPU = %d, sched CPU = %d", rseq_cpu, cpu);
} }
/* /*
...@@ -256,7 +256,7 @@ int main(int argc, char *argv[]) ...@@ -256,7 +256,7 @@ int main(int argc, char *argv[])
* migrations given the 1us+ delay in the migration task. * migrations given the 1us+ delay in the migration task.
*/ */
TEST_ASSERT(i > (NR_TASK_MIGRATIONS / 2), TEST_ASSERT(i > (NR_TASK_MIGRATIONS / 2),
"Only performed %d KVM_RUNs, task stalled too much?\n", i); "Only performed %d KVM_RUNs, task stalled too much?", i);
pthread_join(migration_thread, NULL); pthread_join(migration_thread, NULL);
......
...@@ -98,11 +98,11 @@ static void wait_for_vcpu(void) ...@@ -98,11 +98,11 @@ static void wait_for_vcpu(void)
struct timespec ts; struct timespec ts;
TEST_ASSERT(!clock_gettime(CLOCK_REALTIME, &ts), TEST_ASSERT(!clock_gettime(CLOCK_REALTIME, &ts),
"clock_gettime() failed: %d\n", errno); "clock_gettime() failed: %d", errno);
ts.tv_sec += 2; ts.tv_sec += 2;
TEST_ASSERT(!sem_timedwait(&vcpu_ready, &ts), TEST_ASSERT(!sem_timedwait(&vcpu_ready, &ts),
"sem_timedwait() failed: %d\n", errno); "sem_timedwait() failed: %d", errno);
/* Wait for the vCPU thread to reenter the guest. */ /* Wait for the vCPU thread to reenter the guest. */
usleep(100000); usleep(100000);
...@@ -302,7 +302,7 @@ static void test_delete_memory_region(void) ...@@ -302,7 +302,7 @@ static void test_delete_memory_region(void)
if (run->exit_reason == KVM_EXIT_INTERNAL_ERROR) if (run->exit_reason == KVM_EXIT_INTERNAL_ERROR)
TEST_ASSERT(regs.rip >= final_rip_start && TEST_ASSERT(regs.rip >= final_rip_start &&
regs.rip < final_rip_end, regs.rip < final_rip_end,
"Bad rip, expected 0x%lx - 0x%lx, got 0x%llx\n", "Bad rip, expected 0x%lx - 0x%lx, got 0x%llx",
final_rip_start, final_rip_end, regs.rip); final_rip_start, final_rip_end, regs.rip);
kvm_vm_free(vm); kvm_vm_free(vm);
......
...@@ -108,7 +108,7 @@ static void enter_guest(struct kvm_vcpu *vcpu) ...@@ -108,7 +108,7 @@ static void enter_guest(struct kvm_vcpu *vcpu)
handle_abort(&uc); handle_abort(&uc);
return; return;
default: default:
TEST_ASSERT(0, "unhandled ucall %ld\n", TEST_ASSERT(0, "unhandled ucall %ld",
get_ucall(vcpu, &uc)); get_ucall(vcpu, &uc));
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment