19762338dSopenharmony_ci/* 29762338dSopenharmony_ci * Copyright (C) 2024 HiHope Open Source Organization. 39762338dSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 49762338dSopenharmony_ci * you may not use this file except in compliance with the License. 59762338dSopenharmony_ci * You may obtain a copy of the License at 69762338dSopenharmony_ci * 79762338dSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 89762338dSopenharmony_ci * 99762338dSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 109762338dSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 119762338dSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 129762338dSopenharmony_ci * See the License for the specific language governing permissions and 139762338dSopenharmony_ci * limitations under the License. 149762338dSopenharmony_ci */ 159762338dSopenharmony_ci 169762338dSopenharmony_ci#include <cerrno> 179762338dSopenharmony_ci#include <cstdio> 189762338dSopenharmony_ci#include <cstdlib> 199762338dSopenharmony_ci#include <csignal> 209762338dSopenharmony_ci#include <string> 219762338dSopenharmony_ci#include <vector> 229762338dSopenharmony_ci#include <fcntl.h> 239762338dSopenharmony_ci#include <unistd.h> 249762338dSopenharmony_ci#include <malloc.h> 259762338dSopenharmony_ci#include <arpa/inet.h> 269762338dSopenharmony_ci#include <gtest/gtest.h> 279762338dSopenharmony_ci#include <netinet/in.h> 289762338dSopenharmony_ci#include <sys/stat.h> 299762338dSopenharmony_ci#include <sys/mman.h> 309762338dSopenharmony_ci#include <sys/socket.h> 319762338dSopenharmony_ci#include <sys/types.h> 329762338dSopenharmony_ci#include "securec.h" 339762338dSopenharmony_ci 349762338dSopenharmony_ciusing namespace testing::ext; 359762338dSopenharmony_ci 369762338dSopenharmony_cistatic const int SIZE_1M = 1024 * 1024; 379762338dSopenharmony_cistatic const int SIZE_1G = 1024 * 1024 * 1024; 389762338dSopenharmony_cistatic const char *TEST_FILE = "/data/local/tmp/mmap_test"; 399762338dSopenharmony_ci 409762338dSopenharmony_ciclass HatsMmapSyscallTest : public testing::Test { 419762338dSopenharmony_cipublic: 429762338dSopenharmony_ci static void SetUpTestCase(); 439762338dSopenharmony_ci static void TearDownTestCase(); 449762338dSopenharmony_ci void SetUp(); 459762338dSopenharmony_ci void TearDown(); 469762338dSopenharmony_ciprivate: 479762338dSopenharmony_ci}; 489762338dSopenharmony_civoid HatsMmapSyscallTest::SetUp() 499762338dSopenharmony_ci{ 509762338dSopenharmony_ci} 519762338dSopenharmony_ci 529762338dSopenharmony_civoid HatsMmapSyscallTest::TearDown() 539762338dSopenharmony_ci{ 549762338dSopenharmony_ci} 559762338dSopenharmony_ci 569762338dSopenharmony_civoid HatsMmapSyscallTest::SetUpTestCase() 579762338dSopenharmony_ci{ 589762338dSopenharmony_ci} 599762338dSopenharmony_ci 609762338dSopenharmony_civoid HatsMmapSyscallTest::TearDownTestCase() 619762338dSopenharmony_ci{ 629762338dSopenharmony_ci} 639762338dSopenharmony_ci 649762338dSopenharmony_ci/* 659762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_MMAPSYSCALL_0100 669762338dSopenharmony_ci * @tc.name : MmapSyscallPortTestSuccess_0001 679762338dSopenharmony_ci * @tc.desc : Mmap sets prot PROT_READ/PROT_WRITE/PROT_EXEC/PROT_NONE test successfully. 689762338dSopenharmony_ci * @tc.size : MediumTest 699762338dSopenharmony_ci * @tc.type : Function 709762338dSopenharmony_ci * @tc.level : Level 1 719762338dSopenharmony_ci */ 729762338dSopenharmony_ciHWTEST_F(HatsMmapSyscallTest, MmapSyscallPortTestSuccess_0001, Function | MediumTest | Level1) 739762338dSopenharmony_ci{ 749762338dSopenharmony_ci size_t size = SIZE_1M; 759762338dSopenharmony_ci void *va = mmap(nullptr, size, PROT_READ, MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 769762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 779762338dSopenharmony_ci 789762338dSopenharmony_ci int ret = munmap(va, size); 799762338dSopenharmony_ci EXPECT_EQ(ret, 0); 809762338dSopenharmony_ci 819762338dSopenharmony_ci va = mmap(nullptr, size, PROT_WRITE, MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 829762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 839762338dSopenharmony_ci 849762338dSopenharmony_ci ret = munmap(va, size); 859762338dSopenharmony_ci EXPECT_EQ(ret, 0); 869762338dSopenharmony_ci 879762338dSopenharmony_ci va = mmap(nullptr, size, PROT_EXEC, MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 889762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 899762338dSopenharmony_ci 909762338dSopenharmony_ci ret = munmap(va, size); 919762338dSopenharmony_ci EXPECT_EQ(ret, 0); 929762338dSopenharmony_ci 939762338dSopenharmony_ci va = mmap(nullptr, size, PROT_NONE, MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 949762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 959762338dSopenharmony_ci 969762338dSopenharmony_ci ret = munmap(va, size); 979762338dSopenharmony_ci EXPECT_EQ(ret, 0); 989762338dSopenharmony_ci} 999762338dSopenharmony_ci 1009762338dSopenharmony_ci/* 1019762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_MMAPSYSCALL_0200 1029762338dSopenharmony_ci * @tc.name : MmapFlagTestSuccess_0002 1039762338dSopenharmony_ci * @tc.desc : Mmap sets flag MAP_SHARED/MAP_PRIVATE/MAP_FIXED/MAP_ANONYMOUS test successfully. 1049762338dSopenharmony_ci * @tc.size : MediumTest 1059762338dSopenharmony_ci * @tc.type : Function 1069762338dSopenharmony_ci * @tc.level : Level 1 1079762338dSopenharmony_ci */ 1089762338dSopenharmony_ciHWTEST_F(HatsMmapSyscallTest, MmapFlagTestSuccess_0002, Function | MediumTest | Level1) 1099762338dSopenharmony_ci{ 1109762338dSopenharmony_ci size_t size = SIZE_1M; 1119762338dSopenharmony_ci int fd = open(TEST_FILE, O_CREAT | O_RDWR, 0664); 1129762338dSopenharmony_ci 1139762338dSopenharmony_ci // flag MAP_SHARED and MAP_PRIVATE test 1149762338dSopenharmony_ci void *va = mmap(nullptr, size, PROT_READ | PROT_WRITE, MAP_SHARED | MAP_ANONYMOUS, fd, 0); 1159762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 1169762338dSopenharmony_ci 1179762338dSopenharmony_ci int ret = munmap(va, size); 1189762338dSopenharmony_ci EXPECT_EQ(ret, 0); 1199762338dSopenharmony_ci close(fd); 1209762338dSopenharmony_ci 1219762338dSopenharmony_ci // flag MAP_FIXED and MAP_ANONYMOUS test 1229762338dSopenharmony_ci void *addr = reinterpret_cast<void *>(0x200000); 1239762338dSopenharmony_ci va = mmap(addr, size, PROT_READ | PROT_WRITE, MAP_FIXED | MAP_PRIVATE | MAP_ANONYMOUS, -1, 0); 1249762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 1259762338dSopenharmony_ci 1269762338dSopenharmony_ci ret = munmap(va, size); 1279762338dSopenharmony_ci EXPECT_EQ(ret, 0); 1289762338dSopenharmony_ci} 1299762338dSopenharmony_ci 1309762338dSopenharmony_ci/* 1319762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_MMAPSYSCALL_0300 1329762338dSopenharmony_ci * @tc.name : MmapFlagTestSuccess_0003 1339762338dSopenharmony_ci * @tc.desc : Mmap sets flag MAP_LOCKED/MAP_NORESERVE/MAP_POPULATE/MAP_STACK test successfully. 1349762338dSopenharmony_ci * @tc.size : MediumTest 1359762338dSopenharmony_ci * @tc.type : Function 1369762338dSopenharmony_ci * @tc.level : Level 1 1379762338dSopenharmony_ci */ 1389762338dSopenharmony_ciHWTEST_F(HatsMmapSyscallTest, MmapFlagTestSuccess_0003, Function | MediumTest | Level1) 1399762338dSopenharmony_ci{ 1409762338dSopenharmony_ci size_t size = SIZE_1M; 1419762338dSopenharmony_ci 1429762338dSopenharmony_ci // flag MAP_LOCKED test 1439762338dSopenharmony_ci void *va = mmap(nullptr, size, PROT_READ | PROT_WRITE, MAP_LOCKED | MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 1449762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 1459762338dSopenharmony_ci 1469762338dSopenharmony_ci int ret = munmap(va, size); 1479762338dSopenharmony_ci EXPECT_EQ(ret, 0); 1489762338dSopenharmony_ci 1499762338dSopenharmony_ci // flag MAP_NORESERVE test 1509762338dSopenharmony_ci va = mmap(nullptr, size, PROT_READ | PROT_WRITE, MAP_NORESERVE | MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 1519762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 1529762338dSopenharmony_ci 1539762338dSopenharmony_ci ret = munmap(va, size); 1549762338dSopenharmony_ci EXPECT_EQ(ret, 0); 1559762338dSopenharmony_ci 1569762338dSopenharmony_ci // flag MAP_POPULATE test 1579762338dSopenharmony_ci va = mmap(nullptr, size, PROT_READ | PROT_WRITE, MAP_POPULATE | MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 1589762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 1599762338dSopenharmony_ci 1609762338dSopenharmony_ci ret = munmap(va, size); 1619762338dSopenharmony_ci EXPECT_EQ(ret, 0); 1629762338dSopenharmony_ci 1639762338dSopenharmony_ci // flag MAP_STACK test 1649762338dSopenharmony_ci va = mmap(nullptr, size, PROT_READ | PROT_WRITE, MAP_STACK | MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 1659762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 1669762338dSopenharmony_ci 1679762338dSopenharmony_ci ret = munmap(va, size); 1689762338dSopenharmony_ci EXPECT_EQ(ret, 0); 1699762338dSopenharmony_ci} 1709762338dSopenharmony_ci 1719762338dSopenharmony_ci/* 1729762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_MMAPSYSCALL_0400 1739762338dSopenharmony_ci * @tc.name : MmapFlagTestSuccess_0004 1749762338dSopenharmony_ci * @tc.desc : Mmap sets flag MAP_FILE/MAP_HUGE_2MB/MAP_HUGE_1GB successfully. 1759762338dSopenharmony_ci * @tc.size : MediumTest 1769762338dSopenharmony_ci * @tc.type : Function 1779762338dSopenharmony_ci * @tc.level : Level 1 1789762338dSopenharmony_ci */ 1799762338dSopenharmony_ciHWTEST_F(HatsMmapSyscallTest, MmapFlagTestSuccess_0004, Function | MediumTest | Level1) 1809762338dSopenharmony_ci{ 1819762338dSopenharmony_ci size_t size = SIZE_1M; 1829762338dSopenharmony_ci int fd = open("/data/local/tmp/test_file", O_CREAT | O_RDWR, 0664); 1839762338dSopenharmony_ci ASSERT_TRUE(fd > 0); 1849762338dSopenharmony_ci 1859762338dSopenharmony_ci // flag MAP_FILE test 1869762338dSopenharmony_ci void *va = mmap(nullptr, size, PROT_READ | PROT_WRITE, MAP_FILE | MAP_SHARED, fd, 0); 1879762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 1889762338dSopenharmony_ci 1899762338dSopenharmony_ci int ret = munmap(va, size); 1909762338dSopenharmony_ci EXPECT_EQ(ret, 0); 1919762338dSopenharmony_ci close(fd); 1929762338dSopenharmony_ci 1939762338dSopenharmony_ci // flag MAP_HUGE_2MB test 1949762338dSopenharmony_ci size = SIZE_1M * 2; 1959762338dSopenharmony_ci va = mmap(nullptr, size, PROT_READ | PROT_WRITE, MAP_HUGE_2MB | MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 1969762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 1979762338dSopenharmony_ci 1989762338dSopenharmony_ci ret = munmap(va, size); 1999762338dSopenharmony_ci EXPECT_EQ(ret, 0); 2009762338dSopenharmony_ci 2019762338dSopenharmony_ci // flag MAP_HUGE_1GB test 2029762338dSopenharmony_ci size = SIZE_1G; 2039762338dSopenharmony_ci va = mmap(nullptr, size, PROT_READ | PROT_WRITE, MAP_HUGE_1GB | MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 2049762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 2059762338dSopenharmony_ci 2069762338dSopenharmony_ci ret = munmap(va, size); 2079762338dSopenharmony_ci EXPECT_EQ(ret, 0); 2089762338dSopenharmony_ci} 2099762338dSopenharmony_ci 2109762338dSopenharmony_ci/* 2119762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_MMAPSYSCALL_0500 2129762338dSopenharmony_ci * @tc.name : MmapAndMunmapInvalidSizeFailed_0005 2139762338dSopenharmony_ci * @tc.desc : Mmap map addr failed for size 0. 2149762338dSopenharmony_ci * @tc.size : MediumTest 2159762338dSopenharmony_ci * @tc.type : Function 2169762338dSopenharmony_ci * @tc.level : Level 2 2179762338dSopenharmony_ci */ 2189762338dSopenharmony_ciHWTEST_F(HatsMmapSyscallTest, MmapAndMunmapInvalidSizeFailed_0005, Function | MediumTest | Level2) 2199762338dSopenharmony_ci{ 2209762338dSopenharmony_ci size_t size = 0; 2219762338dSopenharmony_ci errno = 0; 2229762338dSopenharmony_ci void *va = mmap(nullptr, size, PROT_READ | PROT_WRITE, MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 2239762338dSopenharmony_ci EXPECT_EQ(va, MAP_FAILED); 2249762338dSopenharmony_ci EXPECT_EQ(errno, EINVAL); 2259762338dSopenharmony_ci 2269762338dSopenharmony_ci errno = 0; 2279762338dSopenharmony_ci int ret = munmap(va, size); 2289762338dSopenharmony_ci EXPECT_EQ(ret, -1); 2299762338dSopenharmony_ci EXPECT_EQ(errno, EINVAL); 2309762338dSopenharmony_ci} 2319762338dSopenharmony_ci 2329762338dSopenharmony_ci/* 2339762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_MMAPSYSCALL_0600 2349762338dSopenharmony_ci * @tc.name : MremapSyscallToLargeSuccess_0006 2359762338dSopenharmony_ci * @tc.desc : Mremap maps with flag 0 from small memory to large successfully. 2369762338dSopenharmony_ci * @tc.size : MediumTest 2379762338dSopenharmony_ci * @tc.type : Function 2389762338dSopenharmony_ci * @tc.level : Level 2 2399762338dSopenharmony_ci */ 2409762338dSopenharmony_ciHWTEST_F(HatsMmapSyscallTest, MremapSyscallToLargeSuccess_0006, Function | MediumTest | Level2) 2419762338dSopenharmony_ci{ 2429762338dSopenharmony_ci size_t size = SIZE_1M; 2439762338dSopenharmony_ci size_t newSize = 2048; 2449762338dSopenharmony_ci void *va = mmap(nullptr, size, PROT_READ | PROT_WRITE, MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 2459762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 2469762338dSopenharmony_ci 2479762338dSopenharmony_ci void* vaNew = mremap(va, size, newSize, 0); 2489762338dSopenharmony_ci EXPECT_NE(vaNew, MAP_FAILED); 2499762338dSopenharmony_ci 2509762338dSopenharmony_ci int ret = munmap(va, size); 2519762338dSopenharmony_ci EXPECT_EQ(ret, 0); 2529762338dSopenharmony_ci 2539762338dSopenharmony_ci ret = munmap(vaNew, newSize); 2549762338dSopenharmony_ci EXPECT_EQ(ret, 0); 2559762338dSopenharmony_ci} 2569762338dSopenharmony_ci 2579762338dSopenharmony_ci/* 2589762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_MMAPSYSCALL_0700 2599762338dSopenharmony_ci * @tc.name : MremapSyscallToSmallSuccess_0007 2609762338dSopenharmony_ci * @tc.desc : Mremap maps with flag 0 from large memory to small successfully. 2619762338dSopenharmony_ci * @tc.size : MediumTest 2629762338dSopenharmony_ci * @tc.type : Function 2639762338dSopenharmony_ci * @tc.level : Level 2 2649762338dSopenharmony_ci */ 2659762338dSopenharmony_ciHWTEST_F(HatsMmapSyscallTest, MremapSyscallToSmallSuccess_0007, Function | MediumTest | Level2) 2669762338dSopenharmony_ci{ 2679762338dSopenharmony_ci size_t size = 4096; 2689762338dSopenharmony_ci size_t newSize = 2048; 2699762338dSopenharmony_ci void *va = mmap(nullptr, size, PROT_READ | PROT_WRITE, MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 2709762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 2719762338dSopenharmony_ci 2729762338dSopenharmony_ci void* vaNew = mremap(va, size, newSize, 0); 2739762338dSopenharmony_ci EXPECT_NE(vaNew, MAP_FAILED); 2749762338dSopenharmony_ci 2759762338dSopenharmony_ci int ret = munmap(va, size); 2769762338dSopenharmony_ci EXPECT_EQ(ret, 0); 2779762338dSopenharmony_ci 2789762338dSopenharmony_ci ret = munmap(vaNew, newSize); 2799762338dSopenharmony_ci EXPECT_EQ(ret, 0); 2809762338dSopenharmony_ci} 2819762338dSopenharmony_ci 2829762338dSopenharmony_ci/* 2839762338dSopenharmony_ci * @tc.number : SUB_KERNEL_SYSCALL_MMAPSYSCALL_0800 2849762338dSopenharmony_ci * @tc.name : MremapSyscallMoveSuccess_0008 2859762338dSopenharmony_ci * @tc.desc : Mremap maps with flag MREMAP_MAYMOVE from small memory to large successfully. 2869762338dSopenharmony_ci * @tc.size : MediumTest 2879762338dSopenharmony_ci * @tc.type : Function 2889762338dSopenharmony_ci * @tc.level : Level 2 2899762338dSopenharmony_ci */ 2909762338dSopenharmony_ciHWTEST_F(HatsMmapSyscallTest, MremapSyscallMoveSuccess_0008, Function | MediumTest | Level2) 2919762338dSopenharmony_ci{ 2929762338dSopenharmony_ci size_t size = SIZE_1M; 2939762338dSopenharmony_ci size_t newSize = 2048; 2949762338dSopenharmony_ci void *va = mmap(nullptr, size, PROT_READ | PROT_WRITE, MAP_ANONYMOUS | MAP_PRIVATE, -1, 0); 2959762338dSopenharmony_ci EXPECT_NE(va, MAP_FAILED); 2969762338dSopenharmony_ci 2979762338dSopenharmony_ci void* vaNew = mremap(va, size, newSize, MREMAP_MAYMOVE); 2989762338dSopenharmony_ci EXPECT_NE(vaNew, MAP_FAILED); 2999762338dSopenharmony_ci 3009762338dSopenharmony_ci int ret = munmap(va, size); 3019762338dSopenharmony_ci EXPECT_EQ(ret, 0); 3029762338dSopenharmony_ci 3039762338dSopenharmony_ci ret = munmap(vaNew, newSize); 3049762338dSopenharmony_ci EXPECT_EQ(ret, 0); 3059762338dSopenharmony_ci} 306