summaryrefslogtreecommitdiff
path: root/Tests/Kernel/TestSharedInodeVMObject.cpp
blob: 485824a0e5a096982ee0cfa5035ccce407cd6532 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
/*
 * Copyright (c) 2022, Liav A. <liavalb@hotmail.co.il>
 *
 * SPDX-License-Identifier: BSD-2-Clause
 */

#include <LibTest/TestCase.h>
#include <errno.h>
#include <fcntl.h>
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/mman.h>
#include <unistd.h>

static u8* shared_ptr = nullptr;

static void shared_non_empty_inode_vmobject_sync_signal_handler(int)
{
    auto rc = msync(shared_ptr, 0x1000, MS_ASYNC);
    EXPECT(rc == 0);
    rc = munmap(shared_ptr, 0x1000);
    EXPECT(rc == 0);
    exit(0);
}

TEST_CASE(shared_non_empty_inode_vmobject_sync)
{
    {
        struct sigaction new_action {
            { shared_non_empty_inode_vmobject_sync_signal_handler }, 0, 0
        };
        int rc = sigaction(SIGBUS, &new_action, nullptr);
        VERIFY(rc == 0);
    }
    u8 buf[0x1000];
    memset(buf, 0, sizeof(buf));
    int fd = open("/tmp/shared_non_empty_msync_test", O_RDWR | O_CREAT, 0644);
    VERIFY(fd >= 0);
    auto rc = write(fd, buf, sizeof(buf));
    VERIFY(rc == sizeof(buf));
    shared_ptr = (u8*)mmap(nullptr, 0x2000, PROT_READ | PROT_WRITE, MAP_FILE | MAP_SHARED, fd, 0);
    EXPECT(shared_ptr != MAP_FAILED);
    rc = msync(shared_ptr, 0x2000, MS_ASYNC);
    EXPECT(rc == 0);
    shared_ptr[0x1001] = 0x1;
    VERIFY_NOT_REACHED();
}