summaryrefslogtreecommitdiffstats
path: root/src/core/hle/kernel/k_code_memory.h
blob: a7f7d749bb417b921c8132d8dd4e9f3d5825920c (plain) (blame)
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
#pragma once

#include "core/core.h"
#include "core/core_timing.h"
#include "core/hle/kernel/k_client_port.h"
#include "core/hle/kernel/k_client_session.h"
#include "core/hle/kernel/k_event.h"
#include "core/hle/kernel/k_handle_table.h"
#include "core/hle/kernel/k_memory_block.h"
#include "core/hle/kernel/k_memory_layout.h"
#include "core/hle/kernel/k_page_table.h"
#include "core/hle/kernel/k_process.h"
#include "core/hle/kernel/k_readable_event.h"
#include "core/hle/kernel/k_resource_limit.h"
#include "core/hle/kernel/k_scheduler.h"
#include "core/hle/kernel/k_scoped_resource_reservation.h"
#include "core/hle/kernel/k_shared_memory.h"
#include "core/hle/kernel/k_synchronization_object.h"
#include "core/hle/kernel/k_thread.h"
#include "core/hle/kernel/k_transfer_memory.h"
#include "core/hle/kernel/k_writable_event.h"
#include "core/hle/kernel/kernel.h"
#include "core/hle/kernel/physical_core.h"
#include "core/hle/kernel/svc.h"
#include "core/hle/kernel/svc_results.h"
#include "core/hle/kernel/svc_types.h"
#include "core/hle/kernel/svc_wrap.h"
#include "core/hle/lock.h"
#include "core/hle/result.h"
#include "core/memory.h"
#include "core/reporter.h"

namespace Kernel {

enum class CodeMemoryOperation : u32 { Map = 0, MapToOwner = 1, Unmap = 2, UnmapFromOwner = 3 };

class KCodeMemory final
    : public KAutoObjectWithSlabHeapAndContainer<KCodeMemory, KAutoObjectWithList> {
    KERNEL_AUTOOBJECT_TRAITS(KCodeMemory, KAutoObject);

private:
    KPageLinkedList m_page_group;
    KProcess* m_owner;
    VAddr m_address;
    KLightLock m_lock;
    bool m_is_initialized;
    bool m_is_owner_mapped;
    bool m_is_mapped;

public:
    explicit KCodeMemory(KernelCore& kernel_);

    ResultCode Initialize(Core::DeviceMemory& device_memory, VAddr address, size_t size);
    void Finalize();

    ResultCode Map(VAddr address, size_t size);
    ResultCode Unmap(VAddr address, size_t size);
    ResultCode MapToOwner(VAddr address, size_t size, Svc::MemoryPermission perm);
    ResultCode UnmapFromOwner(VAddr address, size_t size);

    bool IsInitialized() const {
        return m_is_initialized;
    }
    static void PostDestroy([[maybe_unused]] uintptr_t arg) {}

    KProcess* GetOwner() const {
        return m_owner;
    }
    VAddr GetSourceAddress() {
        return m_address;
    }
    size_t GetSize() const {
        return m_is_initialized ? m_page_group.GetNumPages() * PageSize : 0;
    }
};
} // namespace Kernel