|  | /* | 
|  | * Copyright (C) 2019 The Android Open Source Project | 
|  | * | 
|  | * Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | * you may not use this file except in compliance with the License. | 
|  | * You may obtain a copy of the License at | 
|  | * | 
|  | *      http://www.apache.org/licenses/LICENSE-2.0 | 
|  | * | 
|  | * Unless required by applicable law or agreed to in writing, software | 
|  | * distributed under the License is distributed on an "AS IS" BASIS, | 
|  | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | * See the License for the specific language governing permissions and | 
|  | * limitations under the License. | 
|  | */ | 
|  |  | 
|  | #include "src/kernel_utils/syscall_table.h" | 
|  |  | 
|  | #include "test/gtest_and_gmock.h" | 
|  |  | 
|  | namespace perfetto { | 
|  | namespace { | 
|  |  | 
|  | TEST(SyscallTableTest, Arm64) { | 
|  | SyscallTable t(Architecture::kArm64); | 
|  | EXPECT_STREQ(t.GetById(0), "sys_io_setup"); | 
|  | EXPECT_EQ(t.GetByName("sys_io_setup"), 0u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(1), "sys_io_destroy"); | 
|  | EXPECT_EQ(t.GetByName("sys_io_destroy"), 1u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(220), "sys_clone"); | 
|  | EXPECT_EQ(t.GetByName("sys_clone"), 220u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(293), "sys_rseq"); | 
|  | EXPECT_EQ(t.GetByName("sys_rseq"), 293u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(457), nullptr); | 
|  | EXPECT_STREQ(t.GetById(kMaxSyscalls), nullptr); | 
|  |  | 
|  | EXPECT_EQ(t.GetByName("sys_non_existent"), std::nullopt); | 
|  | } | 
|  |  | 
|  | TEST(SyscallTableTest, Arm32) { | 
|  | SyscallTable t(Architecture::kArm32); | 
|  | EXPECT_STREQ(t.GetById(0), "sys_restart_syscall"); | 
|  | EXPECT_EQ(t.GetByName("sys_restart_syscall"), 0u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(1), "sys_exit"); | 
|  | EXPECT_EQ(t.GetByName("sys_exit"), 1u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(190), "sys_vfork"); | 
|  | EXPECT_EQ(t.GetByName("sys_vfork"), 190u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(399), "sys_io_pgetevents"); | 
|  | EXPECT_EQ(t.GetByName("sys_io_pgetevents"), 399u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(457), nullptr); | 
|  | EXPECT_STREQ(t.GetById(kMaxSyscalls), nullptr); | 
|  |  | 
|  | EXPECT_EQ(t.GetByName("sys_non_existent"), std::nullopt); | 
|  | } | 
|  |  | 
|  | TEST(SyscallTableTest, X86_64) { | 
|  | SyscallTable t(Architecture::kX86_64); | 
|  | EXPECT_STREQ(t.GetById(0), "sys_read"); | 
|  | EXPECT_EQ(t.GetByName("sys_read"), 0u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(1), "sys_write"); | 
|  | EXPECT_EQ(t.GetByName("sys_write"), 1u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(58), "sys_vfork"); | 
|  | EXPECT_EQ(t.GetByName("sys_vfork"), 58u); | 
|  |  | 
|  | // sys_pwritev2 shows up in two slots, 328 and 547 (which is really | 
|  | // compat_sys_pwritev64v2). Ensure we can lookup both. | 
|  | EXPECT_STREQ(t.GetById(547), "sys_pwritev2"); | 
|  | EXPECT_STREQ(t.GetById(328), "sys_pwritev2"); | 
|  | EXPECT_EQ(t.GetByName("sys_pwritev2"), 328u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(335), ""); | 
|  | EXPECT_STREQ(t.GetById(511), ""); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(548), nullptr); | 
|  | EXPECT_STREQ(t.GetById(kMaxSyscalls), nullptr); | 
|  | EXPECT_EQ(t.GetByName("sys_non_existent"), std::nullopt); | 
|  | } | 
|  |  | 
|  | TEST(SyscallTableTest, X86) { | 
|  | SyscallTable t(Architecture::kX86); | 
|  | EXPECT_STREQ(t.GetById(0), "sys_restart_syscall"); | 
|  | EXPECT_EQ(t.GetByName("sys_restart_syscall"), 0u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(1), "sys_exit"); | 
|  | EXPECT_EQ(t.GetByName("sys_exit"), 1u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(190), "sys_vfork"); | 
|  | EXPECT_EQ(t.GetByName("sys_vfork"), 190u); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(386), "sys_rseq"); | 
|  | EXPECT_EQ(t.GetByName("sys_rseq"), 386); | 
|  |  | 
|  | EXPECT_STREQ(t.GetById(457), nullptr); | 
|  | EXPECT_STREQ(t.GetById(kMaxSyscalls), nullptr); | 
|  | EXPECT_EQ(t.GetByName("sys_non_existent"), std::nullopt); | 
|  | } | 
|  |  | 
|  | }  // namespace | 
|  | }  // namespace perfetto |