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