summaryrefslogtreecommitdiff
path: root/src/core/hle/kernel/svc.h
diff options
context:
space:
mode:
authorGravatar Liam2022-10-04 20:15:40 -0400
committerGravatar Liam2023-02-04 22:37:43 -0500
commit92eb091ddb9dfd96e59a75937e185079a63626e3 (patch)
treebe79f36453a4735088d9230e02f426792077eeb4 /src/core/hle/kernel/svc.h
parentMerge pull request #9720 from SoRadGaming/discordPresenceUpdate (diff)
downloadyuzu-92eb091ddb9dfd96e59a75937e185079a63626e3.tar.gz
yuzu-92eb091ddb9dfd96e59a75937e185079a63626e3.tar.xz
yuzu-92eb091ddb9dfd96e59a75937e185079a63626e3.zip
kernel/svc: Split implementations into separate files
Diffstat (limited to 'src/core/hle/kernel/svc.h')
-rw-r--r--src/core/hle/kernel/svc.h156
1 files changed, 156 insertions, 0 deletions
diff --git a/src/core/hle/kernel/svc.h b/src/core/hle/kernel/svc.h
index 13f061b83..b599f9a3d 100644
--- a/src/core/hle/kernel/svc.h
+++ b/src/core/hle/kernel/svc.h
@@ -4,6 +4,8 @@
4#pragma once 4#pragma once
5 5
6#include "common/common_types.h" 6#include "common/common_types.h"
7#include "core/hle/kernel/svc_types.h"
8#include "core/hle/result.h"
7 9
8namespace Core { 10namespace Core {
9class System; 11class System;
@@ -13,4 +15,158 @@ namespace Kernel::Svc {
13 15
14void Call(Core::System& system, u32 immediate); 16void Call(Core::System& system, u32 immediate);
15 17
18Result SetHeapSize(Core::System& system, VAddr* out_address, u64 size);
19Result SetMemoryPermission(Core::System& system, VAddr address, u64 size, MemoryPermission perm);
20Result SetMemoryAttribute(Core::System& system, VAddr address, u64 size, u32 mask, u32 attr);
21Result MapMemory(Core::System& system, VAddr dst_addr, VAddr src_addr, u64 size);
22Result UnmapMemory(Core::System& system, VAddr dst_addr, VAddr src_addr, u64 size);
23Result QueryMemory(Core::System& system, VAddr memory_info_address, VAddr page_info_address,
24 VAddr query_address);
25void ExitProcess(Core::System& system);
26Result CreateThread(Core::System& system, Handle* out_handle, VAddr entry_point, u64 arg,
27 VAddr stack_bottom, u32 priority, s32 core_id);
28Result StartThread(Core::System& system, Handle thread_handle);
29void ExitThread(Core::System& system);
30void SleepThread(Core::System& system, s64 nanoseconds);
31Result GetThreadPriority(Core::System& system, u32* out_priority, Handle handle);
32Result SetThreadPriority(Core::System& system, Handle thread_handle, u32 priority);
33Result GetThreadCoreMask(Core::System& system, Handle thread_handle, s32* out_core_id,
34 u64* out_affinity_mask);
35Result SetThreadCoreMask(Core::System& system, Handle thread_handle, s32 core_id,
36 u64 affinity_mask);
37u32 GetCurrentProcessorNumber(Core::System& system);
38Result SignalEvent(Core::System& system, Handle event_handle);
39Result ClearEvent(Core::System& system, Handle event_handle);
40Result MapSharedMemory(Core::System& system, Handle shmem_handle, VAddr address, u64 size,
41 MemoryPermission map_perm);
42Result UnmapSharedMemory(Core::System& system, Handle shmem_handle, VAddr address, u64 size);
43Result CreateTransferMemory(Core::System& system, Handle* out, VAddr address, u64 size,
44 MemoryPermission map_perm);
45Result CloseHandle(Core::System& system, Handle handle);
46Result ResetSignal(Core::System& system, Handle handle);
47Result WaitSynchronization(Core::System& system, s32* index, VAddr handles_address, s32 num_handles,
48 s64 nano_seconds);
49Result CancelSynchronization(Core::System& system, Handle handle);
50Result ArbitrateLock(Core::System& system, Handle thread_handle, VAddr address, u32 tag);
51Result ArbitrateUnlock(Core::System& system, VAddr address);
52Result WaitProcessWideKeyAtomic(Core::System& system, VAddr address, VAddr cv_key, u32 tag,
53 s64 timeout_ns);
54void SignalProcessWideKey(Core::System& system, VAddr cv_key, s32 count);
55u64 GetSystemTick(Core::System& system);
56Result ConnectToNamedPort(Core::System& system, Handle* out, VAddr port_name_address);
57Result SendSyncRequest(Core::System& system, Handle handle);
58Result GetProcessId(Core::System& system, u64* out_process_id, Handle handle);
59Result GetThreadId(Core::System& system, u64* out_thread_id, Handle thread_handle);
60void Break(Core::System& system, u32 reason, u64 info1, u64 info2);
61void OutputDebugString(Core::System& system, VAddr address, u64 len);
62Result GetInfo(Core::System& system, u64* result, u64 info_id, Handle handle, u64 info_sub_id);
63Result MapPhysicalMemory(Core::System& system, VAddr addr, u64 size);
64Result UnmapPhysicalMemory(Core::System& system, VAddr addr, u64 size);
65Result GetResourceLimitLimitValue(Core::System& system, u64* out_limit_value,
66 Handle resource_limit_handle, LimitableResource which);
67Result GetResourceLimitCurrentValue(Core::System& system, u64* out_current_value,
68 Handle resource_limit_handle, LimitableResource which);
69Result SetThreadActivity(Core::System& system, Handle thread_handle,
70 ThreadActivity thread_activity);
71Result GetThreadContext(Core::System& system, VAddr out_context, Handle thread_handle);
72Result WaitForAddress(Core::System& system, VAddr address, ArbitrationType arb_type, s32 value,
73 s64 timeout_ns);
74Result SignalToAddress(Core::System& system, VAddr address, SignalType signal_type, s32 value,
75 s32 count);
76void SynchronizePreemptionState(Core::System& system);
77void KernelDebug(Core::System& system, u32 kernel_debug_type, u64 param1, u64 param2, u64 param3);
78void ChangeKernelTraceState(Core::System& system, u32 trace_state);
79Result CreateSession(Core::System& system, Handle* out_server, Handle* out_client, u32 is_light,
80 u64 name);
81Result ReplyAndReceive(Core::System& system, s32* out_index, Handle* handles, s32 num_handles,
82 Handle reply_target, s64 timeout_ns);
83Result CreateEvent(Core::System& system, Handle* out_write, Handle* out_read);
84Result CreateCodeMemory(Core::System& system, Handle* out, VAddr address, size_t size);
85Result ControlCodeMemory(Core::System& system, Handle code_memory_handle, u32 operation,
86 VAddr address, size_t size, MemoryPermission perm);
87Result GetProcessList(Core::System& system, u32* out_num_processes, VAddr out_process_ids,
88 u32 out_process_ids_size);
89Result GetThreadList(Core::System& system, u32* out_num_threads, VAddr out_thread_ids,
90 u32 out_thread_ids_size, Handle debug_handle);
91Result SetProcessMemoryPermission(Core::System& system, Handle process_handle, VAddr address,
92 u64 size, MemoryPermission perm);
93Result MapProcessMemory(Core::System& system, VAddr dst_address, Handle process_handle,
94 VAddr src_address, u64 size);
95Result UnmapProcessMemory(Core::System& system, VAddr dst_address, Handle process_handle,
96 VAddr src_address, u64 size);
97Result QueryProcessMemory(Core::System& system, VAddr memory_info_address, VAddr page_info_address,
98 Handle process_handle, VAddr address);
99Result MapProcessCodeMemory(Core::System& system, Handle process_handle, u64 dst_address,
100 u64 src_address, u64 size);
101Result UnmapProcessCodeMemory(Core::System& system, Handle process_handle, u64 dst_address,
102 u64 src_address, u64 size);
103Result GetProcessInfo(Core::System& system, u64* out, Handle process_handle, u32 type);
104Result CreateResourceLimit(Core::System& system, Handle* out_handle);
105Result SetResourceLimitLimitValue(Core::System& system, Handle resource_limit_handle,
106 LimitableResource which, u64 limit_value);
107
108//
109
110Result SetHeapSize32(Core::System& system, u32* heap_addr, u32 heap_size);
111Result SetMemoryAttribute32(Core::System& system, u32 address, u32 size, u32 mask, u32 attr);
112Result MapMemory32(Core::System& system, u32 dst_addr, u32 src_addr, u32 size);
113Result UnmapMemory32(Core::System& system, u32 dst_addr, u32 src_addr, u32 size);
114Result QueryMemory32(Core::System& system, u32 memory_info_address, u32 page_info_address,
115 u32 query_address);
116void ExitProcess32(Core::System& system);
117Result CreateThread32(Core::System& system, Handle* out_handle, u32 priority, u32 entry_point,
118 u32 arg, u32 stack_top, s32 processor_id);
119Result StartThread32(Core::System& system, Handle thread_handle);
120void ExitThread32(Core::System& system);
121void SleepThread32(Core::System& system, u32 nanoseconds_low, u32 nanoseconds_high);
122Result GetThreadPriority32(Core::System& system, u32* out_priority, Handle handle);
123Result SetThreadPriority32(Core::System& system, Handle thread_handle, u32 priority);
124Result GetThreadCoreMask32(Core::System& system, Handle thread_handle, s32* out_core_id,
125 u32* out_affinity_mask_low, u32* out_affinity_mask_high);
126Result SetThreadCoreMask32(Core::System& system, Handle thread_handle, s32 core_id,
127 u32 affinity_mask_low, u32 affinity_mask_high);
128u32 GetCurrentProcessorNumber32(Core::System& system);
129Result SignalEvent32(Core::System& system, Handle event_handle);
130Result ClearEvent32(Core::System& system, Handle event_handle);
131Result MapSharedMemory32(Core::System& system, Handle shmem_handle, u32 address, u32 size,
132 MemoryPermission map_perm);
133Result UnmapSharedMemory32(Core::System& system, Handle shmem_handle, u32 address, u32 size);
134Result CreateTransferMemory32(Core::System& system, Handle* out, u32 address, u32 size,
135 MemoryPermission map_perm);
136Result CloseHandle32(Core::System& system, Handle handle);
137Result ResetSignal32(Core::System& system, Handle handle);
138Result WaitSynchronization32(Core::System& system, u32 timeout_low, u32 handles_address,
139 s32 num_handles, u32 timeout_high, s32* index);
140Result CancelSynchronization32(Core::System& system, Handle handle);
141Result ArbitrateLock32(Core::System& system, Handle thread_handle, u32 address, u32 tag);
142Result ArbitrateUnlock32(Core::System& system, u32 address);
143Result WaitProcessWideKeyAtomic32(Core::System& system, u32 address, u32 cv_key, u32 tag,
144 u32 timeout_ns_low, u32 timeout_ns_high);
145void SignalProcessWideKey32(Core::System& system, u32 cv_key, s32 count);
146void GetSystemTick32(Core::System& system, u32* time_low, u32* time_high);
147Result ConnectToNamedPort32(Core::System& system, Handle* out_handle, u32 port_name_address);
148Result SendSyncRequest32(Core::System& system, Handle handle);
149Result GetProcessId32(Core::System& system, u32* out_process_id_low, u32* out_process_id_high,
150 Handle handle);
151Result GetThreadId32(Core::System& system, u32* out_thread_id_low, u32* out_thread_id_high,
152 Handle thread_handle);
153void Break32(Core::System& system, u32 reason, u32 info1, u32 info2);
154void OutputDebugString32(Core::System& system, u32 address, u32 len);
155Result GetInfo32(Core::System& system, u32* result_low, u32* result_high, u32 sub_id_low,
156 u32 info_id, u32 handle, u32 sub_id_high);
157Result MapPhysicalMemory32(Core::System& system, u32 addr, u32 size);
158Result UnmapPhysicalMemory32(Core::System& system, u32 addr, u32 size);
159Result SetThreadActivity32(Core::System& system, Handle thread_handle,
160 ThreadActivity thread_activity);
161Result GetThreadContext32(Core::System& system, u32 out_context, Handle thread_handle);
162Result WaitForAddress32(Core::System& system, u32 address, ArbitrationType arb_type, s32 value,
163 u32 timeout_ns_low, u32 timeout_ns_high);
164Result SignalToAddress32(Core::System& system, u32 address, SignalType signal_type, s32 value,
165 s32 count);
166Result CreateEvent32(Core::System& system, Handle* out_write, Handle* out_read);
167Result CreateCodeMemory32(Core::System& system, Handle* out, u32 address, u32 size);
168Result ControlCodeMemory32(Core::System& system, Handle code_memory_handle, u32 operation,
169 u64 address, u64 size, MemoryPermission perm);
170Result FlushProcessDataCache32(Core::System& system, Handle process_handle, u64 address, u64 size);
171
16} // namespace Kernel::Svc 172} // namespace Kernel::Svc