diff options
Diffstat (limited to 'lib/sanitizer_common/tests/sanitizer_ioctl_test.cc')
-rw-r--r-- | lib/sanitizer_common/tests/sanitizer_ioctl_test.cc | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/lib/sanitizer_common/tests/sanitizer_ioctl_test.cc b/lib/sanitizer_common/tests/sanitizer_ioctl_test.cc index 154d9860b79f..22fa5228dfbd 100644 --- a/lib/sanitizer_common/tests/sanitizer_ioctl_test.cc +++ b/lib/sanitizer_common/tests/sanitizer_ioctl_test.cc @@ -47,6 +47,7 @@ static struct IoctlInit { // Avoid unused function warnings. (void)&ioctl_common_pre; (void)&ioctl_common_post; + (void)&ioctl_decode; } } ioctl_static_initializer; @@ -74,4 +75,29 @@ TEST(SanitizerIoctl, Fixup) { EXPECT_EQ(EVIOCGKEY(0), desc->req); } +// Test decoding KVM ioctl numbers. +TEST(SanitizerIoctl, KVM_GET_MP_STATE) { + ioctl_desc desc; + bool res = ioctl_decode(0x8004ae98U, &desc); + EXPECT_TRUE(res); + EXPECT_EQ(ioctl_desc::WRITE, desc.type); + EXPECT_EQ(4U, desc.size); +} + +TEST(SanitizerIoctl, KVM_GET_LAPIC) { + ioctl_desc desc; + bool res = ioctl_decode(0x8400ae8eU, &desc); + EXPECT_TRUE(res); + EXPECT_EQ(ioctl_desc::WRITE, desc.type); + EXPECT_EQ(1024U, desc.size); +} + +TEST(SanitizerIoctl, KVM_GET_MSR_INDEX_LIST) { + ioctl_desc desc; + bool res = ioctl_decode(0xc004ae02U, &desc); + EXPECT_TRUE(res); + EXPECT_EQ(ioctl_desc::READWRITE, desc.type); + EXPECT_EQ(4U, desc.size); +} + #endif // SANITIZER_LINUX |