Commit edd3de6f authored by Peter Xu's avatar Peter Xu Committed by Paolo Bonzini

KVM: selftests: Add "-c" parameter to dirty log test

It's only used to override the existing dirty ring size/count.  If
with a bigger ring count, we test async of dirty ring.  If with a
smaller ring count, we test ring full code path.  Async is default.

It has no use for non-dirty-ring tests.
Reviewed-by: default avatarAndrew Jones <drjones@redhat.com>
Signed-off-by: default avatarPeter Xu <peterx@redhat.com>
Message-Id: <20201001012241.6208-1-peterx@redhat.com>
Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
parent 019d321a
...@@ -183,6 +183,7 @@ static enum log_mode_t host_log_mode_option = LOG_MODE_ALL; ...@@ -183,6 +183,7 @@ static enum log_mode_t host_log_mode_option = LOG_MODE_ALL;
/* Logging mode for current run */ /* Logging mode for current run */
static enum log_mode_t host_log_mode; static enum log_mode_t host_log_mode;
static pthread_t vcpu_thread; static pthread_t vcpu_thread;
static uint32_t test_dirty_ring_count = TEST_DIRTY_RING_COUNT;
static void vcpu_kick(void) static void vcpu_kick(void)
{ {
...@@ -257,7 +258,7 @@ static void dirty_ring_create_vm_done(struct kvm_vm *vm) ...@@ -257,7 +258,7 @@ static void dirty_ring_create_vm_done(struct kvm_vm *vm)
* Switch to dirty ring mode after VM creation but before any * Switch to dirty ring mode after VM creation but before any
* of the vcpu creation. * of the vcpu creation.
*/ */
vm_enable_dirty_ring(vm, TEST_DIRTY_RING_COUNT * vm_enable_dirty_ring(vm, test_dirty_ring_count *
sizeof(struct kvm_dirty_gfn)); sizeof(struct kvm_dirty_gfn));
} }
...@@ -279,7 +280,7 @@ static uint32_t dirty_ring_collect_one(struct kvm_dirty_gfn *dirty_gfns, ...@@ -279,7 +280,7 @@ static uint32_t dirty_ring_collect_one(struct kvm_dirty_gfn *dirty_gfns,
uint32_t count = 0; uint32_t count = 0;
while (true) { while (true) {
cur = &dirty_gfns[*fetch_index % TEST_DIRTY_RING_COUNT]; cur = &dirty_gfns[*fetch_index % test_dirty_ring_count];
if (!dirty_gfn_is_dirtied(cur)) if (!dirty_gfn_is_dirtied(cur))
break; break;
TEST_ASSERT(cur->slot == slot, "Slot number didn't match: " TEST_ASSERT(cur->slot == slot, "Slot number didn't match: "
...@@ -803,6 +804,9 @@ static void help(char *name) ...@@ -803,6 +804,9 @@ static void help(char *name)
printf("usage: %s [-h] [-i iterations] [-I interval] " printf("usage: %s [-h] [-i iterations] [-I interval] "
"[-p offset] [-m mode]\n", name); "[-p offset] [-m mode]\n", name);
puts(""); puts("");
printf(" -c: specify dirty ring size, in number of entries\n");
printf(" (only useful for dirty-ring test; default: %"PRIu32")\n",
TEST_DIRTY_RING_COUNT);
printf(" -i: specify iteration counts (default: %"PRIu64")\n", printf(" -i: specify iteration counts (default: %"PRIu64")\n",
TEST_HOST_LOOP_N); TEST_HOST_LOOP_N);
printf(" -I: specify interval in ms (default: %"PRIu64" ms)\n", printf(" -I: specify interval in ms (default: %"PRIu64" ms)\n",
...@@ -858,8 +862,11 @@ int main(int argc, char *argv[]) ...@@ -858,8 +862,11 @@ int main(int argc, char *argv[])
guest_mode_init(VM_MODE_P40V48_4K, true, true); guest_mode_init(VM_MODE_P40V48_4K, true, true);
#endif #endif
while ((opt = getopt(argc, argv, "hi:I:p:m:M:")) != -1) { while ((opt = getopt(argc, argv, "c:hi:I:p:m:M:")) != -1) {
switch (opt) { switch (opt) {
case 'c':
test_dirty_ring_count = strtol(optarg, NULL, 10);
break;
case 'i': case 'i':
iterations = strtol(optarg, NULL, 10); iterations = strtol(optarg, NULL, 10);
break; break;
......
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