Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

KVM: selftests: Add wrappers for mmap() and munmap() to assert success

Add and use wrappers for mmap() and munmap() that assert success to reduce
a significant amount of boilerplate code, to ensure all tests assert on
failure, and to provide consistent error messages on failure.

No functional change intended.

Reviewed-by: Fuad Tabba <tabba@google.com>
Tested-by: Fuad Tabba <tabba@google.com>
Reviewed-by: David Hildenbrand <david@redhat.com>
Reviewed-by: Ackerley Tng <ackerleytng@google.com>
Link: https://lore.kernel.org/r/20251003232606.4070510-10-seanjc@google.com
Signed-off-by: Sean Christopherson <seanjc@google.com>

+64 -64
+7 -14
tools/testing/selftests/kvm/guest_memfd_test.c
··· 50 50 mem = mmap(NULL, total_size, PROT_READ | PROT_WRITE, MAP_PRIVATE, fd, 0); 51 51 TEST_ASSERT(mem == MAP_FAILED, "Copy-on-write not allowed by guest_memfd."); 52 52 53 - mem = mmap(NULL, total_size, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0); 54 - TEST_ASSERT(mem != MAP_FAILED, "mmap() for guest_memfd should succeed."); 53 + mem = kvm_mmap(total_size, PROT_READ | PROT_WRITE, MAP_SHARED, fd); 55 54 56 55 memset(mem, val, total_size); 57 56 for (i = 0; i < total_size; i++) ··· 69 70 for (i = 0; i < total_size; i++) 70 71 TEST_ASSERT_EQ(READ_ONCE(mem[i]), val); 71 72 72 - ret = munmap(mem, total_size); 73 - TEST_ASSERT(!ret, "munmap() should succeed."); 73 + kvm_munmap(mem, total_size); 74 74 } 75 75 76 76 static sigjmp_buf jmpbuf; ··· 87 89 const char val = 0xaa; 88 90 char *mem; 89 91 size_t i; 90 - int ret; 91 92 92 - mem = mmap(NULL, map_size, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0); 93 - TEST_ASSERT(mem != MAP_FAILED, "mmap() for guest_memfd should succeed."); 93 + mem = kvm_mmap(map_size, PROT_READ | PROT_WRITE, MAP_SHARED, fd); 94 94 95 95 sigaction(SIGBUS, &sa_new, &sa_old); 96 96 if (sigsetjmp(jmpbuf, 1) == 0) { ··· 100 104 for (i = 0; i < total_size; i++) 101 105 TEST_ASSERT_EQ(READ_ONCE(mem[i]), val); 102 106 103 - ret = munmap(mem, map_size); 104 - TEST_ASSERT(!ret, "munmap() should succeed."); 107 + kvm_munmap(mem, map_size); 105 108 } 106 109 107 110 static void test_mmap_not_supported(int fd, size_t total_size) ··· 346 351 GUEST_MEMFD_FLAG_INIT_SHARED); 347 352 vm_set_user_memory_region2(vm, slot, KVM_MEM_GUEST_MEMFD, gpa, size, NULL, fd, 0); 348 353 349 - mem = mmap(NULL, size, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0); 350 - TEST_ASSERT(mem != MAP_FAILED, "mmap() on guest_memfd failed"); 354 + mem = kvm_mmap(size, PROT_READ | PROT_WRITE, MAP_SHARED, fd); 351 355 memset(mem, 0xaa, size); 352 - munmap(mem, size); 356 + kvm_munmap(mem, size); 353 357 354 358 virt_pg_map(vm, gpa, gpa); 355 359 vcpu_args_set(vcpu, 2, gpa, size); ··· 356 362 357 363 TEST_ASSERT_EQ(get_ucall(vcpu, NULL), UCALL_DONE); 358 364 359 - mem = mmap(NULL, size, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0); 360 - TEST_ASSERT(mem != MAP_FAILED, "mmap() on guest_memfd failed"); 365 + mem = kvm_mmap(size, PROT_READ | PROT_WRITE, MAP_SHARED, fd); 361 366 for (i = 0; i < size; i++) 362 367 TEST_ASSERT_EQ(mem[i], 0xff); 363 368
+25
tools/testing/selftests/kvm/include/kvm_util.h
··· 286 286 #define __KVM_SYSCALL_ERROR(_name, _ret) \ 287 287 "%s failed, rc: %i errno: %i (%s)", (_name), (_ret), errno, strerror(errno) 288 288 289 + static inline void *__kvm_mmap(size_t size, int prot, int flags, int fd, 290 + off_t offset) 291 + { 292 + void *mem; 293 + 294 + mem = mmap(NULL, size, prot, flags, fd, offset); 295 + TEST_ASSERT(mem != MAP_FAILED, __KVM_SYSCALL_ERROR("mmap()", 296 + (int)(unsigned long)MAP_FAILED)); 297 + 298 + return mem; 299 + } 300 + 301 + static inline void *kvm_mmap(size_t size, int prot, int flags, int fd) 302 + { 303 + return __kvm_mmap(size, prot, flags, fd, 0); 304 + } 305 + 306 + static inline void kvm_munmap(void *mem, size_t size) 307 + { 308 + int ret; 309 + 310 + ret = munmap(mem, size); 311 + TEST_ASSERT(!ret, __KVM_SYSCALL_ERROR("munmap()", ret)); 312 + } 313 + 289 314 /* 290 315 * Use the "inner", double-underscore macro when reporting errors from within 291 316 * other macros so that the name of ioctl() and not its literal numeric value
+15 -29
tools/testing/selftests/kvm/lib/kvm_util.c
··· 741 741 int ret; 742 742 743 743 if (vcpu->dirty_gfns) { 744 - ret = munmap(vcpu->dirty_gfns, vm->dirty_ring_size); 745 - TEST_ASSERT(!ret, __KVM_SYSCALL_ERROR("munmap()", ret)); 744 + kvm_munmap(vcpu->dirty_gfns, vm->dirty_ring_size); 746 745 vcpu->dirty_gfns = NULL; 747 746 } 748 747 749 - ret = munmap(vcpu->run, vcpu_mmap_sz()); 750 - TEST_ASSERT(!ret, __KVM_SYSCALL_ERROR("munmap()", ret)); 748 + kvm_munmap(vcpu->run, vcpu_mmap_sz()); 751 749 752 750 ret = close(vcpu->fd); 753 751 TEST_ASSERT(!ret, __KVM_SYSCALL_ERROR("close()", ret)); ··· 781 783 static void __vm_mem_region_delete(struct kvm_vm *vm, 782 784 struct userspace_mem_region *region) 783 785 { 784 - int ret; 785 - 786 786 rb_erase(&region->gpa_node, &vm->regions.gpa_tree); 787 787 rb_erase(&region->hva_node, &vm->regions.hva_tree); 788 788 hash_del(&region->slot_node); 789 789 790 790 sparsebit_free(&region->unused_phy_pages); 791 791 sparsebit_free(&region->protected_phy_pages); 792 - ret = munmap(region->mmap_start, region->mmap_size); 793 - TEST_ASSERT(!ret, __KVM_SYSCALL_ERROR("munmap()", ret)); 792 + kvm_munmap(region->mmap_start, region->mmap_size); 794 793 if (region->fd >= 0) { 795 794 /* There's an extra map when using shared memory. */ 796 - ret = munmap(region->mmap_alias, region->mmap_size); 797 - TEST_ASSERT(!ret, __KVM_SYSCALL_ERROR("munmap()", ret)); 795 + kvm_munmap(region->mmap_alias, region->mmap_size); 798 796 close(region->fd); 799 797 } 800 798 if (region->region.guest_memfd >= 0) ··· 1047 1053 region->fd = kvm_memfd_alloc(region->mmap_size, 1048 1054 src_type == VM_MEM_SRC_SHARED_HUGETLB); 1049 1055 1050 - region->mmap_start = mmap(NULL, region->mmap_size, 1051 - PROT_READ | PROT_WRITE, 1052 - vm_mem_backing_src_alias(src_type)->flag, 1053 - region->fd, 0); 1054 - TEST_ASSERT(region->mmap_start != MAP_FAILED, 1055 - __KVM_SYSCALL_ERROR("mmap()", (int)(unsigned long)MAP_FAILED)); 1056 + region->mmap_start = kvm_mmap(region->mmap_size, PROT_READ | PROT_WRITE, 1057 + vm_mem_backing_src_alias(src_type)->flag, 1058 + region->fd); 1056 1059 1057 1060 TEST_ASSERT(!is_backing_src_hugetlb(src_type) || 1058 1061 region->mmap_start == align_ptr_up(region->mmap_start, backing_src_pagesz), ··· 1120 1129 1121 1130 /* If shared memory, create an alias. */ 1122 1131 if (region->fd >= 0) { 1123 - region->mmap_alias = mmap(NULL, region->mmap_size, 1124 - PROT_READ | PROT_WRITE, 1125 - vm_mem_backing_src_alias(src_type)->flag, 1126 - region->fd, 0); 1127 - TEST_ASSERT(region->mmap_alias != MAP_FAILED, 1128 - __KVM_SYSCALL_ERROR("mmap()", (int)(unsigned long)MAP_FAILED)); 1132 + region->mmap_alias = kvm_mmap(region->mmap_size, 1133 + PROT_READ | PROT_WRITE, 1134 + vm_mem_backing_src_alias(src_type)->flag, 1135 + region->fd); 1129 1136 1130 1137 /* Align host alias address */ 1131 1138 region->host_alias = align_ptr_up(region->mmap_alias, alignment); ··· 1333 1344 TEST_ASSERT(vcpu_mmap_sz() >= sizeof(*vcpu->run), "vcpu mmap size " 1334 1345 "smaller than expected, vcpu_mmap_sz: %zi expected_min: %zi", 1335 1346 vcpu_mmap_sz(), sizeof(*vcpu->run)); 1336 - vcpu->run = (struct kvm_run *) mmap(NULL, vcpu_mmap_sz(), 1337 - PROT_READ | PROT_WRITE, MAP_SHARED, vcpu->fd, 0); 1338 - TEST_ASSERT(vcpu->run != MAP_FAILED, 1339 - __KVM_SYSCALL_ERROR("mmap()", (int)(unsigned long)MAP_FAILED)); 1347 + vcpu->run = kvm_mmap(vcpu_mmap_sz(), PROT_READ | PROT_WRITE, 1348 + MAP_SHARED, vcpu->fd); 1340 1349 1341 1350 if (kvm_has_cap(KVM_CAP_BINARY_STATS_FD)) 1342 1351 vcpu->stats.fd = vcpu_get_stats_fd(vcpu); ··· 1781 1794 page_size * KVM_DIRTY_LOG_PAGE_OFFSET); 1782 1795 TEST_ASSERT(addr == MAP_FAILED, "Dirty ring mapped exec"); 1783 1796 1784 - addr = mmap(NULL, size, PROT_READ | PROT_WRITE, MAP_SHARED, vcpu->fd, 1785 - page_size * KVM_DIRTY_LOG_PAGE_OFFSET); 1786 - TEST_ASSERT(addr != MAP_FAILED, "Dirty ring map failed"); 1797 + addr = __kvm_mmap(size, PROT_READ | PROT_WRITE, MAP_SHARED, vcpu->fd, 1798 + page_size * KVM_DIRTY_LOG_PAGE_OFFSET); 1787 1799 1788 1800 vcpu->dirty_gfns = addr; 1789 1801 vcpu->dirty_gfns_count = size / sizeof(struct kvm_dirty_gfn);
+2 -3
tools/testing/selftests/kvm/mmu_stress_test.c
··· 339 339 TEST_ASSERT(max_gpa > (4 * slot_size), "MAXPHYADDR <4gb "); 340 340 341 341 fd = kvm_memfd_alloc(slot_size, hugepages); 342 - mem = mmap(NULL, slot_size, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0); 343 - TEST_ASSERT(mem != MAP_FAILED, "mmap() failed"); 342 + mem = kvm_mmap(slot_size, PROT_READ | PROT_WRITE, MAP_SHARED, fd); 344 343 345 344 TEST_ASSERT(!madvise(mem, slot_size, MADV_NOHUGEPAGE), "madvise() failed"); 346 345 ··· 412 413 for (slot = (slot - 1) & ~1ull; slot >= first_slot; slot -= 2) 413 414 vm_set_user_memory_region(vm, slot, 0, 0, 0, NULL); 414 415 415 - munmap(mem, slot_size / 2); 416 + kvm_munmap(mem, slot_size / 2); 416 417 417 418 /* Sanity check that the vCPUs actually ran. */ 418 419 for (i = 0; i < nr_vcpus; i++)
+7 -9
tools/testing/selftests/kvm/s390/ucontrol_test.c
··· 142 142 self->kvm_run_size = ioctl(self->kvm_fd, KVM_GET_VCPU_MMAP_SIZE, NULL); 143 143 ASSERT_GE(self->kvm_run_size, sizeof(struct kvm_run)) 144 144 TH_LOG(KVM_IOCTL_ERROR(KVM_GET_VCPU_MMAP_SIZE, self->kvm_run_size)); 145 - self->run = (struct kvm_run *)mmap(NULL, self->kvm_run_size, 146 - PROT_READ | PROT_WRITE, MAP_SHARED, self->vcpu_fd, 0); 147 - ASSERT_NE(self->run, MAP_FAILED); 145 + self->run = kvm_mmap(self->kvm_run_size, PROT_READ | PROT_WRITE, 146 + MAP_SHARED, self->vcpu_fd); 148 147 /** 149 148 * For virtual cpus that have been created with S390 user controlled 150 149 * virtual machines, the resulting vcpu fd can be memory mapped at page 151 150 * offset KVM_S390_SIE_PAGE_OFFSET in order to obtain a memory map of 152 151 * the virtual cpu's hardware control block. 153 152 */ 154 - self->sie_block = (struct kvm_s390_sie_block *)mmap(NULL, PAGE_SIZE, 155 - PROT_READ | PROT_WRITE, MAP_SHARED, 156 - self->vcpu_fd, KVM_S390_SIE_PAGE_OFFSET << PAGE_SHIFT); 157 - ASSERT_NE(self->sie_block, MAP_FAILED); 153 + self->sie_block = __kvm_mmap(PAGE_SIZE, PROT_READ | PROT_WRITE, 154 + MAP_SHARED, self->vcpu_fd, 155 + KVM_S390_SIE_PAGE_OFFSET << PAGE_SHIFT); 158 156 159 157 TH_LOG("VM created %p %p", self->run, self->sie_block); 160 158 ··· 184 186 185 187 FIXTURE_TEARDOWN(uc_kvm) 186 188 { 187 - munmap(self->sie_block, PAGE_SIZE); 188 - munmap(self->run, self->kvm_run_size); 189 + kvm_munmap(self->sie_block, PAGE_SIZE); 190 + kvm_munmap(self->run, self->kvm_run_size); 189 191 close(self->vcpu_fd); 190 192 close(self->vm_fd); 191 193 close(self->kvm_fd);
+8 -9
tools/testing/selftests/kvm/set_memory_region_test.c
··· 433 433 pr_info("Adding slots 0..%i, each memory region with %dK size\n", 434 434 (max_mem_slots - 1), MEM_REGION_SIZE >> 10); 435 435 436 - mem = mmap(NULL, (size_t)max_mem_slots * MEM_REGION_SIZE + alignment, 437 - PROT_READ | PROT_WRITE, 438 - MAP_PRIVATE | MAP_ANONYMOUS | MAP_NORESERVE, -1, 0); 439 - TEST_ASSERT(mem != MAP_FAILED, "Failed to mmap() host"); 436 + 437 + mem = kvm_mmap((size_t)max_mem_slots * MEM_REGION_SIZE + alignment, 438 + PROT_READ | PROT_WRITE, 439 + MAP_PRIVATE | MAP_ANONYMOUS | MAP_NORESERVE, -1); 440 440 mem_aligned = (void *)(((size_t) mem + alignment - 1) & ~(alignment - 1)); 441 441 442 442 for (slot = 0; slot < max_mem_slots; slot++) ··· 446 446 mem_aligned + (uint64_t)slot * MEM_REGION_SIZE); 447 447 448 448 /* Check it cannot be added memory slots beyond the limit */ 449 - mem_extra = mmap(NULL, MEM_REGION_SIZE, PROT_READ | PROT_WRITE, 450 - MAP_PRIVATE | MAP_ANONYMOUS, -1, 0); 451 - TEST_ASSERT(mem_extra != MAP_FAILED, "Failed to mmap() host"); 449 + mem_extra = kvm_mmap(MEM_REGION_SIZE, PROT_READ | PROT_WRITE, 450 + MAP_PRIVATE | MAP_ANONYMOUS, -1); 452 451 453 452 ret = __vm_set_user_memory_region(vm, max_mem_slots, 0, 454 453 (uint64_t)max_mem_slots * MEM_REGION_SIZE, ··· 455 456 TEST_ASSERT(ret == -1 && errno == EINVAL, 456 457 "Adding one more memory slot should fail with EINVAL"); 457 458 458 - munmap(mem, (size_t)max_mem_slots * MEM_REGION_SIZE + alignment); 459 - munmap(mem_extra, MEM_REGION_SIZE); 459 + kvm_munmap(mem, (size_t)max_mem_slots * MEM_REGION_SIZE + alignment); 460 + kvm_munmap(mem_extra, MEM_REGION_SIZE); 460 461 kvm_vm_free(vm); 461 462 } 462 463