2023-02-05 14:22:02 -05:00
|
|
|
// SPDX-FileCopyrightText: Copyright 2023 yuzu Emulator Project
|
2022-04-23 04:59:50 -04:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2014-04-11 18:44:21 -04:00
|
|
|
|
2023-02-05 14:22:02 -05:00
|
|
|
// This file is automatically generated using svc_generator.py.
|
2014-04-11 18:44:21 -04:00
|
|
|
|
2023-02-05 14:22:02 -05:00
|
|
|
#pragma once
|
2014-04-11 18:44:21 -04:00
|
|
|
|
2019-04-06 18:46:18 -04:00
|
|
|
namespace Core {
|
|
|
|
class System;
|
|
|
|
}
|
|
|
|
|
2023-11-28 14:30:39 -05:00
|
|
|
#include <span>
|
|
|
|
|
2023-02-05 14:22:02 -05:00
|
|
|
#include "common/common_types.h"
|
|
|
|
#include "core/hle/kernel/svc_types.h"
|
|
|
|
#include "core/hle/result.h"
|
2014-05-15 18:25:56 -04:00
|
|
|
|
2023-02-05 14:22:02 -05:00
|
|
|
namespace Kernel::Svc {
|
2014-04-11 18:44:21 -04:00
|
|
|
|
2023-02-05 14:22:02 -05:00
|
|
|
// clang-format off
|
2023-02-21 16:36:20 -05:00
|
|
|
Result SetHeapSize(Core::System& system, uint64_t* out_address, uint64_t size);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result SetMemoryPermission(Core::System& system, uint64_t address, uint64_t size, MemoryPermission perm);
|
|
|
|
Result SetMemoryAttribute(Core::System& system, uint64_t address, uint64_t size, uint32_t mask, uint32_t attr);
|
|
|
|
Result MapMemory(Core::System& system, uint64_t dst_address, uint64_t src_address, uint64_t size);
|
|
|
|
Result UnmapMemory(Core::System& system, uint64_t dst_address, uint64_t src_address, uint64_t size);
|
|
|
|
Result QueryMemory(Core::System& system, uint64_t out_memory_info, PageInfo* out_page_info, uint64_t address);
|
2022-10-04 20:15:40 -04:00
|
|
|
void ExitProcess(Core::System& system);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result CreateThread(Core::System& system, Handle* out_handle, uint64_t func, uint64_t arg, uint64_t stack_bottom, int32_t priority, int32_t core_id);
|
2022-10-04 20:15:40 -04:00
|
|
|
Result StartThread(Core::System& system, Handle thread_handle);
|
|
|
|
void ExitThread(Core::System& system);
|
2023-02-05 14:22:02 -05:00
|
|
|
void SleepThread(Core::System& system, int64_t ns);
|
|
|
|
Result GetThreadPriority(Core::System& system, int32_t* out_priority, Handle thread_handle);
|
|
|
|
Result SetThreadPriority(Core::System& system, Handle thread_handle, int32_t priority);
|
|
|
|
Result GetThreadCoreMask(Core::System& system, int32_t* out_core_id, uint64_t* out_affinity_mask, Handle thread_handle);
|
|
|
|
Result SetThreadCoreMask(Core::System& system, Handle thread_handle, int32_t core_id, uint64_t affinity_mask);
|
|
|
|
int32_t GetCurrentProcessorNumber(Core::System& system);
|
2022-10-04 20:15:40 -04:00
|
|
|
Result SignalEvent(Core::System& system, Handle event_handle);
|
|
|
|
Result ClearEvent(Core::System& system, Handle event_handle);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result MapSharedMemory(Core::System& system, Handle shmem_handle, uint64_t address, uint64_t size, MemoryPermission map_perm);
|
|
|
|
Result UnmapSharedMemory(Core::System& system, Handle shmem_handle, uint64_t address, uint64_t size);
|
|
|
|
Result CreateTransferMemory(Core::System& system, Handle* out_handle, uint64_t address, uint64_t size, MemoryPermission map_perm);
|
2022-10-04 20:15:40 -04:00
|
|
|
Result CloseHandle(Core::System& system, Handle handle);
|
|
|
|
Result ResetSignal(Core::System& system, Handle handle);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result WaitSynchronization(Core::System& system, int32_t* out_index, uint64_t handles, int32_t num_handles, int64_t timeout_ns);
|
2022-10-04 20:15:40 -04:00
|
|
|
Result CancelSynchronization(Core::System& system, Handle handle);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result ArbitrateLock(Core::System& system, Handle thread_handle, uint64_t address, uint32_t tag);
|
|
|
|
Result ArbitrateUnlock(Core::System& system, uint64_t address);
|
|
|
|
Result WaitProcessWideKeyAtomic(Core::System& system, uint64_t address, uint64_t cv_key, uint32_t tag, int64_t timeout_ns);
|
|
|
|
void SignalProcessWideKey(Core::System& system, uint64_t cv_key, int32_t count);
|
|
|
|
int64_t GetSystemTick(Core::System& system);
|
|
|
|
Result ConnectToNamedPort(Core::System& system, Handle* out_handle, uint64_t name);
|
|
|
|
Result SendSyncRequest(Core::System& system, Handle session_handle);
|
|
|
|
Result SendSyncRequestWithUserBuffer(Core::System& system, uint64_t message_buffer, uint64_t message_buffer_size, Handle session_handle);
|
|
|
|
Result SendAsyncRequestWithUserBuffer(Core::System& system, Handle* out_event_handle, uint64_t message_buffer, uint64_t message_buffer_size, Handle session_handle);
|
|
|
|
Result GetProcessId(Core::System& system, uint64_t* out_process_id, Handle process_handle);
|
|
|
|
Result GetThreadId(Core::System& system, uint64_t* out_thread_id, Handle thread_handle);
|
|
|
|
void Break(Core::System& system, BreakReason break_reason, uint64_t arg, uint64_t size);
|
|
|
|
Result OutputDebugString(Core::System& system, uint64_t debug_str, uint64_t len);
|
|
|
|
void ReturnFromException(Core::System& system, Result result);
|
|
|
|
Result GetInfo(Core::System& system, uint64_t* out, InfoType info_type, Handle handle, uint64_t info_subtype);
|
|
|
|
void FlushEntireDataCache(Core::System& system);
|
|
|
|
Result FlushDataCache(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
Result MapPhysicalMemory(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
Result UnmapPhysicalMemory(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
Result GetDebugFutureThreadInfo(Core::System& system, lp64::LastThreadContext* out_context, uint64_t* out_thread_id, Handle debug_handle, int64_t ns);
|
2023-02-21 16:36:20 -05:00
|
|
|
Result GetLastThreadInfo(Core::System& system, lp64::LastThreadContext* out_context, uint64_t* out_tls_address, uint32_t* out_flags);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result GetResourceLimitLimitValue(Core::System& system, int64_t* out_limit_value, Handle resource_limit_handle, LimitableResource which);
|
|
|
|
Result GetResourceLimitCurrentValue(Core::System& system, int64_t* out_current_value, Handle resource_limit_handle, LimitableResource which);
|
|
|
|
Result SetThreadActivity(Core::System& system, Handle thread_handle, ThreadActivity thread_activity);
|
|
|
|
Result GetThreadContext3(Core::System& system, uint64_t out_context, Handle thread_handle);
|
|
|
|
Result WaitForAddress(Core::System& system, uint64_t address, ArbitrationType arb_type, int32_t value, int64_t timeout_ns);
|
|
|
|
Result SignalToAddress(Core::System& system, uint64_t address, SignalType signal_type, int32_t value, int32_t count);
|
2022-10-04 20:15:40 -04:00
|
|
|
void SynchronizePreemptionState(Core::System& system);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result GetResourceLimitPeakValue(Core::System& system, int64_t* out_peak_value, Handle resource_limit_handle, LimitableResource which);
|
|
|
|
Result CreateIoPool(Core::System& system, Handle* out_handle, IoPoolType which);
|
|
|
|
Result CreateIoRegion(Core::System& system, Handle* out_handle, Handle io_pool, uint64_t physical_address, uint64_t size, MemoryMapping mapping, MemoryPermission perm);
|
|
|
|
void KernelDebug(Core::System& system, KernelDebugType kern_debug_type, uint64_t arg0, uint64_t arg1, uint64_t arg2);
|
|
|
|
void ChangeKernelTraceState(Core::System& system, KernelTraceState kern_trace_state);
|
|
|
|
Result CreateSession(Core::System& system, Handle* out_server_session_handle, Handle* out_client_session_handle, bool is_light, uint64_t name);
|
|
|
|
Result AcceptSession(Core::System& system, Handle* out_handle, Handle port);
|
|
|
|
Result ReplyAndReceive(Core::System& system, int32_t* out_index, uint64_t handles, int32_t num_handles, Handle reply_target, int64_t timeout_ns);
|
|
|
|
Result ReplyAndReceiveWithUserBuffer(Core::System& system, int32_t* out_index, uint64_t message_buffer, uint64_t message_buffer_size, uint64_t handles, int32_t num_handles, Handle reply_target, int64_t timeout_ns);
|
|
|
|
Result CreateEvent(Core::System& system, Handle* out_write_handle, Handle* out_read_handle);
|
|
|
|
Result MapIoRegion(Core::System& system, Handle io_region, uint64_t address, uint64_t size, MemoryPermission perm);
|
|
|
|
Result UnmapIoRegion(Core::System& system, Handle io_region, uint64_t address, uint64_t size);
|
|
|
|
Result MapPhysicalMemoryUnsafe(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
Result UnmapPhysicalMemoryUnsafe(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
Result SetUnsafeLimit(Core::System& system, uint64_t limit);
|
|
|
|
Result CreateCodeMemory(Core::System& system, Handle* out_handle, uint64_t address, uint64_t size);
|
|
|
|
Result ControlCodeMemory(Core::System& system, Handle code_memory_handle, CodeMemoryOperation operation, uint64_t address, uint64_t size, MemoryPermission perm);
|
|
|
|
void SleepSystem(Core::System& system);
|
|
|
|
Result ReadWriteRegister(Core::System& system, uint32_t* out_value, uint64_t address, uint32_t mask, uint32_t value);
|
|
|
|
Result SetProcessActivity(Core::System& system, Handle process_handle, ProcessActivity process_activity);
|
|
|
|
Result CreateSharedMemory(Core::System& system, Handle* out_handle, uint64_t size, MemoryPermission owner_perm, MemoryPermission remote_perm);
|
|
|
|
Result MapTransferMemory(Core::System& system, Handle trmem_handle, uint64_t address, uint64_t size, MemoryPermission owner_perm);
|
|
|
|
Result UnmapTransferMemory(Core::System& system, Handle trmem_handle, uint64_t address, uint64_t size);
|
|
|
|
Result CreateInterruptEvent(Core::System& system, Handle* out_read_handle, int32_t interrupt_id, InterruptType interrupt_type);
|
|
|
|
Result QueryPhysicalAddress(Core::System& system, lp64::PhysicalMemoryInfo* out_info, uint64_t address);
|
2023-02-21 16:36:20 -05:00
|
|
|
Result QueryIoMapping(Core::System& system, uint64_t* out_address, uint64_t* out_size, uint64_t physical_address, uint64_t size);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result CreateDeviceAddressSpace(Core::System& system, Handle* out_handle, uint64_t das_address, uint64_t das_size);
|
|
|
|
Result AttachDeviceAddressSpace(Core::System& system, DeviceName device_name, Handle das_handle);
|
|
|
|
Result DetachDeviceAddressSpace(Core::System& system, DeviceName device_name, Handle das_handle);
|
|
|
|
Result MapDeviceAddressSpaceByForce(Core::System& system, Handle das_handle, Handle process_handle, uint64_t process_address, uint64_t size, uint64_t device_address, uint32_t option);
|
|
|
|
Result MapDeviceAddressSpaceAligned(Core::System& system, Handle das_handle, Handle process_handle, uint64_t process_address, uint64_t size, uint64_t device_address, uint32_t option);
|
|
|
|
Result UnmapDeviceAddressSpace(Core::System& system, Handle das_handle, Handle process_handle, uint64_t process_address, uint64_t size, uint64_t device_address);
|
|
|
|
Result InvalidateProcessDataCache(Core::System& system, Handle process_handle, uint64_t address, uint64_t size);
|
|
|
|
Result StoreProcessDataCache(Core::System& system, Handle process_handle, uint64_t address, uint64_t size);
|
|
|
|
Result FlushProcessDataCache(Core::System& system, Handle process_handle, uint64_t address, uint64_t size);
|
|
|
|
Result DebugActiveProcess(Core::System& system, Handle* out_handle, uint64_t process_id);
|
|
|
|
Result BreakDebugProcess(Core::System& system, Handle debug_handle);
|
|
|
|
Result TerminateDebugProcess(Core::System& system, Handle debug_handle);
|
|
|
|
Result GetDebugEvent(Core::System& system, uint64_t out_info, Handle debug_handle);
|
|
|
|
Result ContinueDebugEvent(Core::System& system, Handle debug_handle, uint32_t flags, uint64_t thread_ids, int32_t num_thread_ids);
|
|
|
|
Result GetProcessList(Core::System& system, int32_t* out_num_processes, uint64_t out_process_ids, int32_t max_out_count);
|
|
|
|
Result GetThreadList(Core::System& system, int32_t* out_num_threads, uint64_t out_thread_ids, int32_t max_out_count, Handle debug_handle);
|
|
|
|
Result GetDebugThreadContext(Core::System& system, uint64_t out_context, Handle debug_handle, uint64_t thread_id, uint32_t context_flags);
|
|
|
|
Result SetDebugThreadContext(Core::System& system, Handle debug_handle, uint64_t thread_id, uint64_t context, uint32_t context_flags);
|
|
|
|
Result QueryDebugProcessMemory(Core::System& system, uint64_t out_memory_info, PageInfo* out_page_info, Handle process_handle, uint64_t address);
|
|
|
|
Result ReadDebugProcessMemory(Core::System& system, uint64_t buffer, Handle debug_handle, uint64_t address, uint64_t size);
|
|
|
|
Result WriteDebugProcessMemory(Core::System& system, Handle debug_handle, uint64_t buffer, uint64_t address, uint64_t size);
|
|
|
|
Result SetHardwareBreakPoint(Core::System& system, HardwareBreakPointRegisterName name, uint64_t flags, uint64_t value);
|
|
|
|
Result GetDebugThreadParam(Core::System& system, uint64_t* out_64, uint32_t* out_32, Handle debug_handle, uint64_t thread_id, DebugThreadParam param);
|
|
|
|
Result GetSystemInfo(Core::System& system, uint64_t* out, SystemInfoType info_type, Handle handle, uint64_t info_subtype);
|
|
|
|
Result CreatePort(Core::System& system, Handle* out_server_handle, Handle* out_client_handle, int32_t max_sessions, bool is_light, uint64_t name);
|
|
|
|
Result ManageNamedPort(Core::System& system, Handle* out_server_handle, uint64_t name, int32_t max_sessions);
|
|
|
|
Result ConnectToPort(Core::System& system, Handle* out_handle, Handle port);
|
|
|
|
Result SetProcessMemoryPermission(Core::System& system, Handle process_handle, uint64_t address, uint64_t size, MemoryPermission perm);
|
|
|
|
Result MapProcessMemory(Core::System& system, uint64_t dst_address, Handle process_handle, uint64_t src_address, uint64_t size);
|
|
|
|
Result UnmapProcessMemory(Core::System& system, uint64_t dst_address, Handle process_handle, uint64_t src_address, uint64_t size);
|
|
|
|
Result QueryProcessMemory(Core::System& system, uint64_t out_memory_info, PageInfo* out_page_info, Handle process_handle, uint64_t address);
|
|
|
|
Result MapProcessCodeMemory(Core::System& system, Handle process_handle, uint64_t dst_address, uint64_t src_address, uint64_t size);
|
|
|
|
Result UnmapProcessCodeMemory(Core::System& system, Handle process_handle, uint64_t dst_address, uint64_t src_address, uint64_t size);
|
|
|
|
Result CreateProcess(Core::System& system, Handle* out_handle, uint64_t parameters, uint64_t caps, int32_t num_caps);
|
|
|
|
Result StartProcess(Core::System& system, Handle process_handle, int32_t priority, int32_t core_id, uint64_t main_thread_stack_size);
|
|
|
|
Result TerminateProcess(Core::System& system, Handle process_handle);
|
|
|
|
Result GetProcessInfo(Core::System& system, int64_t* out_info, Handle process_handle, ProcessInfoType info_type);
|
2022-10-04 20:15:40 -04:00
|
|
|
Result CreateResourceLimit(Core::System& system, Handle* out_handle);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result SetResourceLimitLimitValue(Core::System& system, Handle resource_limit_handle, LimitableResource which, int64_t limit_value);
|
|
|
|
Result MapInsecureMemory(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
Result UnmapInsecureMemory(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
|
2023-02-21 16:36:20 -05:00
|
|
|
Result SetHeapSize64From32(Core::System& system, uint64_t* out_address, uint32_t size);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result SetMemoryPermission64From32(Core::System& system, uint32_t address, uint32_t size, MemoryPermission perm);
|
|
|
|
Result SetMemoryAttribute64From32(Core::System& system, uint32_t address, uint32_t size, uint32_t mask, uint32_t attr);
|
|
|
|
Result MapMemory64From32(Core::System& system, uint32_t dst_address, uint32_t src_address, uint32_t size);
|
|
|
|
Result UnmapMemory64From32(Core::System& system, uint32_t dst_address, uint32_t src_address, uint32_t size);
|
|
|
|
Result QueryMemory64From32(Core::System& system, uint32_t out_memory_info, PageInfo* out_page_info, uint32_t address);
|
|
|
|
void ExitProcess64From32(Core::System& system);
|
|
|
|
Result CreateThread64From32(Core::System& system, Handle* out_handle, uint32_t func, uint32_t arg, uint32_t stack_bottom, int32_t priority, int32_t core_id);
|
|
|
|
Result StartThread64From32(Core::System& system, Handle thread_handle);
|
|
|
|
void ExitThread64From32(Core::System& system);
|
|
|
|
void SleepThread64From32(Core::System& system, int64_t ns);
|
|
|
|
Result GetThreadPriority64From32(Core::System& system, int32_t* out_priority, Handle thread_handle);
|
|
|
|
Result SetThreadPriority64From32(Core::System& system, Handle thread_handle, int32_t priority);
|
|
|
|
Result GetThreadCoreMask64From32(Core::System& system, int32_t* out_core_id, uint64_t* out_affinity_mask, Handle thread_handle);
|
|
|
|
Result SetThreadCoreMask64From32(Core::System& system, Handle thread_handle, int32_t core_id, uint64_t affinity_mask);
|
|
|
|
int32_t GetCurrentProcessorNumber64From32(Core::System& system);
|
|
|
|
Result SignalEvent64From32(Core::System& system, Handle event_handle);
|
|
|
|
Result ClearEvent64From32(Core::System& system, Handle event_handle);
|
|
|
|
Result MapSharedMemory64From32(Core::System& system, Handle shmem_handle, uint32_t address, uint32_t size, MemoryPermission map_perm);
|
|
|
|
Result UnmapSharedMemory64From32(Core::System& system, Handle shmem_handle, uint32_t address, uint32_t size);
|
|
|
|
Result CreateTransferMemory64From32(Core::System& system, Handle* out_handle, uint32_t address, uint32_t size, MemoryPermission map_perm);
|
|
|
|
Result CloseHandle64From32(Core::System& system, Handle handle);
|
|
|
|
Result ResetSignal64From32(Core::System& system, Handle handle);
|
|
|
|
Result WaitSynchronization64From32(Core::System& system, int32_t* out_index, uint32_t handles, int32_t num_handles, int64_t timeout_ns);
|
|
|
|
Result CancelSynchronization64From32(Core::System& system, Handle handle);
|
|
|
|
Result ArbitrateLock64From32(Core::System& system, Handle thread_handle, uint32_t address, uint32_t tag);
|
|
|
|
Result ArbitrateUnlock64From32(Core::System& system, uint32_t address);
|
|
|
|
Result WaitProcessWideKeyAtomic64From32(Core::System& system, uint32_t address, uint32_t cv_key, uint32_t tag, int64_t timeout_ns);
|
|
|
|
void SignalProcessWideKey64From32(Core::System& system, uint32_t cv_key, int32_t count);
|
|
|
|
int64_t GetSystemTick64From32(Core::System& system);
|
|
|
|
Result ConnectToNamedPort64From32(Core::System& system, Handle* out_handle, uint32_t name);
|
|
|
|
Result SendSyncRequest64From32(Core::System& system, Handle session_handle);
|
|
|
|
Result SendSyncRequestWithUserBuffer64From32(Core::System& system, uint32_t message_buffer, uint32_t message_buffer_size, Handle session_handle);
|
|
|
|
Result SendAsyncRequestWithUserBuffer64From32(Core::System& system, Handle* out_event_handle, uint32_t message_buffer, uint32_t message_buffer_size, Handle session_handle);
|
|
|
|
Result GetProcessId64From32(Core::System& system, uint64_t* out_process_id, Handle process_handle);
|
|
|
|
Result GetThreadId64From32(Core::System& system, uint64_t* out_thread_id, Handle thread_handle);
|
|
|
|
void Break64From32(Core::System& system, BreakReason break_reason, uint32_t arg, uint32_t size);
|
|
|
|
Result OutputDebugString64From32(Core::System& system, uint32_t debug_str, uint32_t len);
|
|
|
|
void ReturnFromException64From32(Core::System& system, Result result);
|
|
|
|
Result GetInfo64From32(Core::System& system, uint64_t* out, InfoType info_type, Handle handle, uint64_t info_subtype);
|
|
|
|
void FlushEntireDataCache64From32(Core::System& system);
|
|
|
|
Result FlushDataCache64From32(Core::System& system, uint32_t address, uint32_t size);
|
|
|
|
Result MapPhysicalMemory64From32(Core::System& system, uint32_t address, uint32_t size);
|
|
|
|
Result UnmapPhysicalMemory64From32(Core::System& system, uint32_t address, uint32_t size);
|
|
|
|
Result GetDebugFutureThreadInfo64From32(Core::System& system, ilp32::LastThreadContext* out_context, uint64_t* out_thread_id, Handle debug_handle, int64_t ns);
|
2023-02-21 16:36:20 -05:00
|
|
|
Result GetLastThreadInfo64From32(Core::System& system, ilp32::LastThreadContext* out_context, uint64_t* out_tls_address, uint32_t* out_flags);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result GetResourceLimitLimitValue64From32(Core::System& system, int64_t* out_limit_value, Handle resource_limit_handle, LimitableResource which);
|
|
|
|
Result GetResourceLimitCurrentValue64From32(Core::System& system, int64_t* out_current_value, Handle resource_limit_handle, LimitableResource which);
|
|
|
|
Result SetThreadActivity64From32(Core::System& system, Handle thread_handle, ThreadActivity thread_activity);
|
|
|
|
Result GetThreadContext364From32(Core::System& system, uint32_t out_context, Handle thread_handle);
|
|
|
|
Result WaitForAddress64From32(Core::System& system, uint32_t address, ArbitrationType arb_type, int32_t value, int64_t timeout_ns);
|
|
|
|
Result SignalToAddress64From32(Core::System& system, uint32_t address, SignalType signal_type, int32_t value, int32_t count);
|
|
|
|
void SynchronizePreemptionState64From32(Core::System& system);
|
|
|
|
Result GetResourceLimitPeakValue64From32(Core::System& system, int64_t* out_peak_value, Handle resource_limit_handle, LimitableResource which);
|
|
|
|
Result CreateIoPool64From32(Core::System& system, Handle* out_handle, IoPoolType which);
|
|
|
|
Result CreateIoRegion64From32(Core::System& system, Handle* out_handle, Handle io_pool, uint64_t physical_address, uint32_t size, MemoryMapping mapping, MemoryPermission perm);
|
|
|
|
void KernelDebug64From32(Core::System& system, KernelDebugType kern_debug_type, uint64_t arg0, uint64_t arg1, uint64_t arg2);
|
|
|
|
void ChangeKernelTraceState64From32(Core::System& system, KernelTraceState kern_trace_state);
|
|
|
|
Result CreateSession64From32(Core::System& system, Handle* out_server_session_handle, Handle* out_client_session_handle, bool is_light, uint32_t name);
|
|
|
|
Result AcceptSession64From32(Core::System& system, Handle* out_handle, Handle port);
|
|
|
|
Result ReplyAndReceive64From32(Core::System& system, int32_t* out_index, uint32_t handles, int32_t num_handles, Handle reply_target, int64_t timeout_ns);
|
|
|
|
Result ReplyAndReceiveWithUserBuffer64From32(Core::System& system, int32_t* out_index, uint32_t message_buffer, uint32_t message_buffer_size, uint32_t handles, int32_t num_handles, Handle reply_target, int64_t timeout_ns);
|
|
|
|
Result CreateEvent64From32(Core::System& system, Handle* out_write_handle, Handle* out_read_handle);
|
|
|
|
Result MapIoRegion64From32(Core::System& system, Handle io_region, uint32_t address, uint32_t size, MemoryPermission perm);
|
|
|
|
Result UnmapIoRegion64From32(Core::System& system, Handle io_region, uint32_t address, uint32_t size);
|
|
|
|
Result MapPhysicalMemoryUnsafe64From32(Core::System& system, uint32_t address, uint32_t size);
|
|
|
|
Result UnmapPhysicalMemoryUnsafe64From32(Core::System& system, uint32_t address, uint32_t size);
|
|
|
|
Result SetUnsafeLimit64From32(Core::System& system, uint32_t limit);
|
|
|
|
Result CreateCodeMemory64From32(Core::System& system, Handle* out_handle, uint32_t address, uint32_t size);
|
|
|
|
Result ControlCodeMemory64From32(Core::System& system, Handle code_memory_handle, CodeMemoryOperation operation, uint64_t address, uint64_t size, MemoryPermission perm);
|
|
|
|
void SleepSystem64From32(Core::System& system);
|
|
|
|
Result ReadWriteRegister64From32(Core::System& system, uint32_t* out_value, uint64_t address, uint32_t mask, uint32_t value);
|
|
|
|
Result SetProcessActivity64From32(Core::System& system, Handle process_handle, ProcessActivity process_activity);
|
|
|
|
Result CreateSharedMemory64From32(Core::System& system, Handle* out_handle, uint32_t size, MemoryPermission owner_perm, MemoryPermission remote_perm);
|
|
|
|
Result MapTransferMemory64From32(Core::System& system, Handle trmem_handle, uint32_t address, uint32_t size, MemoryPermission owner_perm);
|
|
|
|
Result UnmapTransferMemory64From32(Core::System& system, Handle trmem_handle, uint32_t address, uint32_t size);
|
|
|
|
Result CreateInterruptEvent64From32(Core::System& system, Handle* out_read_handle, int32_t interrupt_id, InterruptType interrupt_type);
|
|
|
|
Result QueryPhysicalAddress64From32(Core::System& system, ilp32::PhysicalMemoryInfo* out_info, uint32_t address);
|
2023-02-21 16:36:20 -05:00
|
|
|
Result QueryIoMapping64From32(Core::System& system, uint64_t* out_address, uint64_t* out_size, uint64_t physical_address, uint32_t size);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result CreateDeviceAddressSpace64From32(Core::System& system, Handle* out_handle, uint64_t das_address, uint64_t das_size);
|
|
|
|
Result AttachDeviceAddressSpace64From32(Core::System& system, DeviceName device_name, Handle das_handle);
|
|
|
|
Result DetachDeviceAddressSpace64From32(Core::System& system, DeviceName device_name, Handle das_handle);
|
|
|
|
Result MapDeviceAddressSpaceByForce64From32(Core::System& system, Handle das_handle, Handle process_handle, uint64_t process_address, uint32_t size, uint64_t device_address, uint32_t option);
|
|
|
|
Result MapDeviceAddressSpaceAligned64From32(Core::System& system, Handle das_handle, Handle process_handle, uint64_t process_address, uint32_t size, uint64_t device_address, uint32_t option);
|
|
|
|
Result UnmapDeviceAddressSpace64From32(Core::System& system, Handle das_handle, Handle process_handle, uint64_t process_address, uint32_t size, uint64_t device_address);
|
|
|
|
Result InvalidateProcessDataCache64From32(Core::System& system, Handle process_handle, uint64_t address, uint64_t size);
|
|
|
|
Result StoreProcessDataCache64From32(Core::System& system, Handle process_handle, uint64_t address, uint64_t size);
|
|
|
|
Result FlushProcessDataCache64From32(Core::System& system, Handle process_handle, uint64_t address, uint64_t size);
|
|
|
|
Result DebugActiveProcess64From32(Core::System& system, Handle* out_handle, uint64_t process_id);
|
|
|
|
Result BreakDebugProcess64From32(Core::System& system, Handle debug_handle);
|
|
|
|
Result TerminateDebugProcess64From32(Core::System& system, Handle debug_handle);
|
|
|
|
Result GetDebugEvent64From32(Core::System& system, uint32_t out_info, Handle debug_handle);
|
|
|
|
Result ContinueDebugEvent64From32(Core::System& system, Handle debug_handle, uint32_t flags, uint32_t thread_ids, int32_t num_thread_ids);
|
|
|
|
Result GetProcessList64From32(Core::System& system, int32_t* out_num_processes, uint32_t out_process_ids, int32_t max_out_count);
|
|
|
|
Result GetThreadList64From32(Core::System& system, int32_t* out_num_threads, uint32_t out_thread_ids, int32_t max_out_count, Handle debug_handle);
|
|
|
|
Result GetDebugThreadContext64From32(Core::System& system, uint32_t out_context, Handle debug_handle, uint64_t thread_id, uint32_t context_flags);
|
|
|
|
Result SetDebugThreadContext64From32(Core::System& system, Handle debug_handle, uint64_t thread_id, uint32_t context, uint32_t context_flags);
|
|
|
|
Result QueryDebugProcessMemory64From32(Core::System& system, uint32_t out_memory_info, PageInfo* out_page_info, Handle process_handle, uint32_t address);
|
|
|
|
Result ReadDebugProcessMemory64From32(Core::System& system, uint32_t buffer, Handle debug_handle, uint32_t address, uint32_t size);
|
|
|
|
Result WriteDebugProcessMemory64From32(Core::System& system, Handle debug_handle, uint32_t buffer, uint32_t address, uint32_t size);
|
|
|
|
Result SetHardwareBreakPoint64From32(Core::System& system, HardwareBreakPointRegisterName name, uint64_t flags, uint64_t value);
|
|
|
|
Result GetDebugThreadParam64From32(Core::System& system, uint64_t* out_64, uint32_t* out_32, Handle debug_handle, uint64_t thread_id, DebugThreadParam param);
|
|
|
|
Result GetSystemInfo64From32(Core::System& system, uint64_t* out, SystemInfoType info_type, Handle handle, uint64_t info_subtype);
|
|
|
|
Result CreatePort64From32(Core::System& system, Handle* out_server_handle, Handle* out_client_handle, int32_t max_sessions, bool is_light, uint32_t name);
|
|
|
|
Result ManageNamedPort64From32(Core::System& system, Handle* out_server_handle, uint32_t name, int32_t max_sessions);
|
|
|
|
Result ConnectToPort64From32(Core::System& system, Handle* out_handle, Handle port);
|
|
|
|
Result SetProcessMemoryPermission64From32(Core::System& system, Handle process_handle, uint64_t address, uint64_t size, MemoryPermission perm);
|
|
|
|
Result MapProcessMemory64From32(Core::System& system, uint32_t dst_address, Handle process_handle, uint64_t src_address, uint32_t size);
|
|
|
|
Result UnmapProcessMemory64From32(Core::System& system, uint32_t dst_address, Handle process_handle, uint64_t src_address, uint32_t size);
|
|
|
|
Result QueryProcessMemory64From32(Core::System& system, uint32_t out_memory_info, PageInfo* out_page_info, Handle process_handle, uint64_t address);
|
|
|
|
Result MapProcessCodeMemory64From32(Core::System& system, Handle process_handle, uint64_t dst_address, uint64_t src_address, uint64_t size);
|
|
|
|
Result UnmapProcessCodeMemory64From32(Core::System& system, Handle process_handle, uint64_t dst_address, uint64_t src_address, uint64_t size);
|
|
|
|
Result CreateProcess64From32(Core::System& system, Handle* out_handle, uint32_t parameters, uint32_t caps, int32_t num_caps);
|
|
|
|
Result StartProcess64From32(Core::System& system, Handle process_handle, int32_t priority, int32_t core_id, uint64_t main_thread_stack_size);
|
|
|
|
Result TerminateProcess64From32(Core::System& system, Handle process_handle);
|
|
|
|
Result GetProcessInfo64From32(Core::System& system, int64_t* out_info, Handle process_handle, ProcessInfoType info_type);
|
|
|
|
Result CreateResourceLimit64From32(Core::System& system, Handle* out_handle);
|
|
|
|
Result SetResourceLimitLimitValue64From32(Core::System& system, Handle resource_limit_handle, LimitableResource which, int64_t limit_value);
|
|
|
|
Result MapInsecureMemory64From32(Core::System& system, uint32_t address, uint32_t size);
|
|
|
|
Result UnmapInsecureMemory64From32(Core::System& system, uint32_t address, uint32_t size);
|
|
|
|
|
2023-02-21 16:36:20 -05:00
|
|
|
Result SetHeapSize64(Core::System& system, uint64_t* out_address, uint64_t size);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result SetMemoryPermission64(Core::System& system, uint64_t address, uint64_t size, MemoryPermission perm);
|
|
|
|
Result SetMemoryAttribute64(Core::System& system, uint64_t address, uint64_t size, uint32_t mask, uint32_t attr);
|
|
|
|
Result MapMemory64(Core::System& system, uint64_t dst_address, uint64_t src_address, uint64_t size);
|
|
|
|
Result UnmapMemory64(Core::System& system, uint64_t dst_address, uint64_t src_address, uint64_t size);
|
|
|
|
Result QueryMemory64(Core::System& system, uint64_t out_memory_info, PageInfo* out_page_info, uint64_t address);
|
|
|
|
void ExitProcess64(Core::System& system);
|
|
|
|
Result CreateThread64(Core::System& system, Handle* out_handle, uint64_t func, uint64_t arg, uint64_t stack_bottom, int32_t priority, int32_t core_id);
|
|
|
|
Result StartThread64(Core::System& system, Handle thread_handle);
|
|
|
|
void ExitThread64(Core::System& system);
|
|
|
|
void SleepThread64(Core::System& system, int64_t ns);
|
|
|
|
Result GetThreadPriority64(Core::System& system, int32_t* out_priority, Handle thread_handle);
|
|
|
|
Result SetThreadPriority64(Core::System& system, Handle thread_handle, int32_t priority);
|
|
|
|
Result GetThreadCoreMask64(Core::System& system, int32_t* out_core_id, uint64_t* out_affinity_mask, Handle thread_handle);
|
|
|
|
Result SetThreadCoreMask64(Core::System& system, Handle thread_handle, int32_t core_id, uint64_t affinity_mask);
|
|
|
|
int32_t GetCurrentProcessorNumber64(Core::System& system);
|
|
|
|
Result SignalEvent64(Core::System& system, Handle event_handle);
|
|
|
|
Result ClearEvent64(Core::System& system, Handle event_handle);
|
|
|
|
Result MapSharedMemory64(Core::System& system, Handle shmem_handle, uint64_t address, uint64_t size, MemoryPermission map_perm);
|
|
|
|
Result UnmapSharedMemory64(Core::System& system, Handle shmem_handle, uint64_t address, uint64_t size);
|
|
|
|
Result CreateTransferMemory64(Core::System& system, Handle* out_handle, uint64_t address, uint64_t size, MemoryPermission map_perm);
|
|
|
|
Result CloseHandle64(Core::System& system, Handle handle);
|
|
|
|
Result ResetSignal64(Core::System& system, Handle handle);
|
|
|
|
Result WaitSynchronization64(Core::System& system, int32_t* out_index, uint64_t handles, int32_t num_handles, int64_t timeout_ns);
|
|
|
|
Result CancelSynchronization64(Core::System& system, Handle handle);
|
|
|
|
Result ArbitrateLock64(Core::System& system, Handle thread_handle, uint64_t address, uint32_t tag);
|
|
|
|
Result ArbitrateUnlock64(Core::System& system, uint64_t address);
|
|
|
|
Result WaitProcessWideKeyAtomic64(Core::System& system, uint64_t address, uint64_t cv_key, uint32_t tag, int64_t timeout_ns);
|
|
|
|
void SignalProcessWideKey64(Core::System& system, uint64_t cv_key, int32_t count);
|
|
|
|
int64_t GetSystemTick64(Core::System& system);
|
|
|
|
Result ConnectToNamedPort64(Core::System& system, Handle* out_handle, uint64_t name);
|
|
|
|
Result SendSyncRequest64(Core::System& system, Handle session_handle);
|
|
|
|
Result SendSyncRequestWithUserBuffer64(Core::System& system, uint64_t message_buffer, uint64_t message_buffer_size, Handle session_handle);
|
|
|
|
Result SendAsyncRequestWithUserBuffer64(Core::System& system, Handle* out_event_handle, uint64_t message_buffer, uint64_t message_buffer_size, Handle session_handle);
|
|
|
|
Result GetProcessId64(Core::System& system, uint64_t* out_process_id, Handle process_handle);
|
|
|
|
Result GetThreadId64(Core::System& system, uint64_t* out_thread_id, Handle thread_handle);
|
|
|
|
void Break64(Core::System& system, BreakReason break_reason, uint64_t arg, uint64_t size);
|
|
|
|
Result OutputDebugString64(Core::System& system, uint64_t debug_str, uint64_t len);
|
|
|
|
void ReturnFromException64(Core::System& system, Result result);
|
|
|
|
Result GetInfo64(Core::System& system, uint64_t* out, InfoType info_type, Handle handle, uint64_t info_subtype);
|
|
|
|
void FlushEntireDataCache64(Core::System& system);
|
|
|
|
Result FlushDataCache64(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
Result MapPhysicalMemory64(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
Result UnmapPhysicalMemory64(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
Result GetDebugFutureThreadInfo64(Core::System& system, lp64::LastThreadContext* out_context, uint64_t* out_thread_id, Handle debug_handle, int64_t ns);
|
2023-02-21 16:36:20 -05:00
|
|
|
Result GetLastThreadInfo64(Core::System& system, lp64::LastThreadContext* out_context, uint64_t* out_tls_address, uint32_t* out_flags);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result GetResourceLimitLimitValue64(Core::System& system, int64_t* out_limit_value, Handle resource_limit_handle, LimitableResource which);
|
|
|
|
Result GetResourceLimitCurrentValue64(Core::System& system, int64_t* out_current_value, Handle resource_limit_handle, LimitableResource which);
|
|
|
|
Result SetThreadActivity64(Core::System& system, Handle thread_handle, ThreadActivity thread_activity);
|
|
|
|
Result GetThreadContext364(Core::System& system, uint64_t out_context, Handle thread_handle);
|
|
|
|
Result WaitForAddress64(Core::System& system, uint64_t address, ArbitrationType arb_type, int32_t value, int64_t timeout_ns);
|
|
|
|
Result SignalToAddress64(Core::System& system, uint64_t address, SignalType signal_type, int32_t value, int32_t count);
|
|
|
|
void SynchronizePreemptionState64(Core::System& system);
|
|
|
|
Result GetResourceLimitPeakValue64(Core::System& system, int64_t* out_peak_value, Handle resource_limit_handle, LimitableResource which);
|
|
|
|
Result CreateIoPool64(Core::System& system, Handle* out_handle, IoPoolType which);
|
|
|
|
Result CreateIoRegion64(Core::System& system, Handle* out_handle, Handle io_pool, uint64_t physical_address, uint64_t size, MemoryMapping mapping, MemoryPermission perm);
|
|
|
|
void KernelDebug64(Core::System& system, KernelDebugType kern_debug_type, uint64_t arg0, uint64_t arg1, uint64_t arg2);
|
|
|
|
void ChangeKernelTraceState64(Core::System& system, KernelTraceState kern_trace_state);
|
|
|
|
Result CreateSession64(Core::System& system, Handle* out_server_session_handle, Handle* out_client_session_handle, bool is_light, uint64_t name);
|
|
|
|
Result AcceptSession64(Core::System& system, Handle* out_handle, Handle port);
|
|
|
|
Result ReplyAndReceive64(Core::System& system, int32_t* out_index, uint64_t handles, int32_t num_handles, Handle reply_target, int64_t timeout_ns);
|
|
|
|
Result ReplyAndReceiveWithUserBuffer64(Core::System& system, int32_t* out_index, uint64_t message_buffer, uint64_t message_buffer_size, uint64_t handles, int32_t num_handles, Handle reply_target, int64_t timeout_ns);
|
|
|
|
Result CreateEvent64(Core::System& system, Handle* out_write_handle, Handle* out_read_handle);
|
|
|
|
Result MapIoRegion64(Core::System& system, Handle io_region, uint64_t address, uint64_t size, MemoryPermission perm);
|
|
|
|
Result UnmapIoRegion64(Core::System& system, Handle io_region, uint64_t address, uint64_t size);
|
|
|
|
Result MapPhysicalMemoryUnsafe64(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
Result UnmapPhysicalMemoryUnsafe64(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
Result SetUnsafeLimit64(Core::System& system, uint64_t limit);
|
|
|
|
Result CreateCodeMemory64(Core::System& system, Handle* out_handle, uint64_t address, uint64_t size);
|
|
|
|
Result ControlCodeMemory64(Core::System& system, Handle code_memory_handle, CodeMemoryOperation operation, uint64_t address, uint64_t size, MemoryPermission perm);
|
|
|
|
void SleepSystem64(Core::System& system);
|
|
|
|
Result ReadWriteRegister64(Core::System& system, uint32_t* out_value, uint64_t address, uint32_t mask, uint32_t value);
|
|
|
|
Result SetProcessActivity64(Core::System& system, Handle process_handle, ProcessActivity process_activity);
|
|
|
|
Result CreateSharedMemory64(Core::System& system, Handle* out_handle, uint64_t size, MemoryPermission owner_perm, MemoryPermission remote_perm);
|
|
|
|
Result MapTransferMemory64(Core::System& system, Handle trmem_handle, uint64_t address, uint64_t size, MemoryPermission owner_perm);
|
|
|
|
Result UnmapTransferMemory64(Core::System& system, Handle trmem_handle, uint64_t address, uint64_t size);
|
|
|
|
Result CreateInterruptEvent64(Core::System& system, Handle* out_read_handle, int32_t interrupt_id, InterruptType interrupt_type);
|
|
|
|
Result QueryPhysicalAddress64(Core::System& system, lp64::PhysicalMemoryInfo* out_info, uint64_t address);
|
2023-02-21 16:36:20 -05:00
|
|
|
Result QueryIoMapping64(Core::System& system, uint64_t* out_address, uint64_t* out_size, uint64_t physical_address, uint64_t size);
|
2023-02-05 14:22:02 -05:00
|
|
|
Result CreateDeviceAddressSpace64(Core::System& system, Handle* out_handle, uint64_t das_address, uint64_t das_size);
|
|
|
|
Result AttachDeviceAddressSpace64(Core::System& system, DeviceName device_name, Handle das_handle);
|
|
|
|
Result DetachDeviceAddressSpace64(Core::System& system, DeviceName device_name, Handle das_handle);
|
|
|
|
Result MapDeviceAddressSpaceByForce64(Core::System& system, Handle das_handle, Handle process_handle, uint64_t process_address, uint64_t size, uint64_t device_address, uint32_t option);
|
|
|
|
Result MapDeviceAddressSpaceAligned64(Core::System& system, Handle das_handle, Handle process_handle, uint64_t process_address, uint64_t size, uint64_t device_address, uint32_t option);
|
|
|
|
Result UnmapDeviceAddressSpace64(Core::System& system, Handle das_handle, Handle process_handle, uint64_t process_address, uint64_t size, uint64_t device_address);
|
|
|
|
Result InvalidateProcessDataCache64(Core::System& system, Handle process_handle, uint64_t address, uint64_t size);
|
|
|
|
Result StoreProcessDataCache64(Core::System& system, Handle process_handle, uint64_t address, uint64_t size);
|
|
|
|
Result FlushProcessDataCache64(Core::System& system, Handle process_handle, uint64_t address, uint64_t size);
|
|
|
|
Result DebugActiveProcess64(Core::System& system, Handle* out_handle, uint64_t process_id);
|
|
|
|
Result BreakDebugProcess64(Core::System& system, Handle debug_handle);
|
|
|
|
Result TerminateDebugProcess64(Core::System& system, Handle debug_handle);
|
|
|
|
Result GetDebugEvent64(Core::System& system, uint64_t out_info, Handle debug_handle);
|
|
|
|
Result ContinueDebugEvent64(Core::System& system, Handle debug_handle, uint32_t flags, uint64_t thread_ids, int32_t num_thread_ids);
|
|
|
|
Result GetProcessList64(Core::System& system, int32_t* out_num_processes, uint64_t out_process_ids, int32_t max_out_count);
|
|
|
|
Result GetThreadList64(Core::System& system, int32_t* out_num_threads, uint64_t out_thread_ids, int32_t max_out_count, Handle debug_handle);
|
|
|
|
Result GetDebugThreadContext64(Core::System& system, uint64_t out_context, Handle debug_handle, uint64_t thread_id, uint32_t context_flags);
|
|
|
|
Result SetDebugThreadContext64(Core::System& system, Handle debug_handle, uint64_t thread_id, uint64_t context, uint32_t context_flags);
|
|
|
|
Result QueryDebugProcessMemory64(Core::System& system, uint64_t out_memory_info, PageInfo* out_page_info, Handle process_handle, uint64_t address);
|
|
|
|
Result ReadDebugProcessMemory64(Core::System& system, uint64_t buffer, Handle debug_handle, uint64_t address, uint64_t size);
|
|
|
|
Result WriteDebugProcessMemory64(Core::System& system, Handle debug_handle, uint64_t buffer, uint64_t address, uint64_t size);
|
|
|
|
Result SetHardwareBreakPoint64(Core::System& system, HardwareBreakPointRegisterName name, uint64_t flags, uint64_t value);
|
|
|
|
Result GetDebugThreadParam64(Core::System& system, uint64_t* out_64, uint32_t* out_32, Handle debug_handle, uint64_t thread_id, DebugThreadParam param);
|
|
|
|
Result GetSystemInfo64(Core::System& system, uint64_t* out, SystemInfoType info_type, Handle handle, uint64_t info_subtype);
|
|
|
|
Result CreatePort64(Core::System& system, Handle* out_server_handle, Handle* out_client_handle, int32_t max_sessions, bool is_light, uint64_t name);
|
|
|
|
Result ManageNamedPort64(Core::System& system, Handle* out_server_handle, uint64_t name, int32_t max_sessions);
|
|
|
|
Result ConnectToPort64(Core::System& system, Handle* out_handle, Handle port);
|
|
|
|
Result SetProcessMemoryPermission64(Core::System& system, Handle process_handle, uint64_t address, uint64_t size, MemoryPermission perm);
|
|
|
|
Result MapProcessMemory64(Core::System& system, uint64_t dst_address, Handle process_handle, uint64_t src_address, uint64_t size);
|
|
|
|
Result UnmapProcessMemory64(Core::System& system, uint64_t dst_address, Handle process_handle, uint64_t src_address, uint64_t size);
|
|
|
|
Result QueryProcessMemory64(Core::System& system, uint64_t out_memory_info, PageInfo* out_page_info, Handle process_handle, uint64_t address);
|
|
|
|
Result MapProcessCodeMemory64(Core::System& system, Handle process_handle, uint64_t dst_address, uint64_t src_address, uint64_t size);
|
|
|
|
Result UnmapProcessCodeMemory64(Core::System& system, Handle process_handle, uint64_t dst_address, uint64_t src_address, uint64_t size);
|
|
|
|
Result CreateProcess64(Core::System& system, Handle* out_handle, uint64_t parameters, uint64_t caps, int32_t num_caps);
|
|
|
|
Result StartProcess64(Core::System& system, Handle process_handle, int32_t priority, int32_t core_id, uint64_t main_thread_stack_size);
|
|
|
|
Result TerminateProcess64(Core::System& system, Handle process_handle);
|
|
|
|
Result GetProcessInfo64(Core::System& system, int64_t* out_info, Handle process_handle, ProcessInfoType info_type);
|
|
|
|
Result CreateResourceLimit64(Core::System& system, Handle* out_handle);
|
|
|
|
Result SetResourceLimitLimitValue64(Core::System& system, Handle resource_limit_handle, LimitableResource which, int64_t limit_value);
|
|
|
|
Result MapInsecureMemory64(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
Result UnmapInsecureMemory64(Core::System& system, uint64_t address, uint64_t size);
|
|
|
|
|
|
|
|
enum class SvcId : u32 {
|
|
|
|
SetHeapSize = 0x1,
|
|
|
|
SetMemoryPermission = 0x2,
|
|
|
|
SetMemoryAttribute = 0x3,
|
|
|
|
MapMemory = 0x4,
|
|
|
|
UnmapMemory = 0x5,
|
|
|
|
QueryMemory = 0x6,
|
|
|
|
ExitProcess = 0x7,
|
|
|
|
CreateThread = 0x8,
|
|
|
|
StartThread = 0x9,
|
|
|
|
ExitThread = 0xa,
|
|
|
|
SleepThread = 0xb,
|
|
|
|
GetThreadPriority = 0xc,
|
|
|
|
SetThreadPriority = 0xd,
|
|
|
|
GetThreadCoreMask = 0xe,
|
|
|
|
SetThreadCoreMask = 0xf,
|
|
|
|
GetCurrentProcessorNumber = 0x10,
|
|
|
|
SignalEvent = 0x11,
|
|
|
|
ClearEvent = 0x12,
|
|
|
|
MapSharedMemory = 0x13,
|
|
|
|
UnmapSharedMemory = 0x14,
|
|
|
|
CreateTransferMemory = 0x15,
|
|
|
|
CloseHandle = 0x16,
|
|
|
|
ResetSignal = 0x17,
|
|
|
|
WaitSynchronization = 0x18,
|
|
|
|
CancelSynchronization = 0x19,
|
|
|
|
ArbitrateLock = 0x1a,
|
|
|
|
ArbitrateUnlock = 0x1b,
|
|
|
|
WaitProcessWideKeyAtomic = 0x1c,
|
|
|
|
SignalProcessWideKey = 0x1d,
|
|
|
|
GetSystemTick = 0x1e,
|
|
|
|
ConnectToNamedPort = 0x1f,
|
|
|
|
SendSyncRequestLight = 0x20,
|
|
|
|
SendSyncRequest = 0x21,
|
|
|
|
SendSyncRequestWithUserBuffer = 0x22,
|
|
|
|
SendAsyncRequestWithUserBuffer = 0x23,
|
|
|
|
GetProcessId = 0x24,
|
|
|
|
GetThreadId = 0x25,
|
|
|
|
Break = 0x26,
|
|
|
|
OutputDebugString = 0x27,
|
|
|
|
ReturnFromException = 0x28,
|
|
|
|
GetInfo = 0x29,
|
|
|
|
FlushEntireDataCache = 0x2a,
|
|
|
|
FlushDataCache = 0x2b,
|
|
|
|
MapPhysicalMemory = 0x2c,
|
|
|
|
UnmapPhysicalMemory = 0x2d,
|
|
|
|
GetDebugFutureThreadInfo = 0x2e,
|
|
|
|
GetLastThreadInfo = 0x2f,
|
|
|
|
GetResourceLimitLimitValue = 0x30,
|
|
|
|
GetResourceLimitCurrentValue = 0x31,
|
|
|
|
SetThreadActivity = 0x32,
|
|
|
|
GetThreadContext3 = 0x33,
|
|
|
|
WaitForAddress = 0x34,
|
|
|
|
SignalToAddress = 0x35,
|
|
|
|
SynchronizePreemptionState = 0x36,
|
|
|
|
GetResourceLimitPeakValue = 0x37,
|
|
|
|
CreateIoPool = 0x39,
|
|
|
|
CreateIoRegion = 0x3a,
|
|
|
|
KernelDebug = 0x3c,
|
|
|
|
ChangeKernelTraceState = 0x3d,
|
|
|
|
CreateSession = 0x40,
|
|
|
|
AcceptSession = 0x41,
|
|
|
|
ReplyAndReceiveLight = 0x42,
|
|
|
|
ReplyAndReceive = 0x43,
|
|
|
|
ReplyAndReceiveWithUserBuffer = 0x44,
|
|
|
|
CreateEvent = 0x45,
|
|
|
|
MapIoRegion = 0x46,
|
|
|
|
UnmapIoRegion = 0x47,
|
|
|
|
MapPhysicalMemoryUnsafe = 0x48,
|
|
|
|
UnmapPhysicalMemoryUnsafe = 0x49,
|
|
|
|
SetUnsafeLimit = 0x4a,
|
|
|
|
CreateCodeMemory = 0x4b,
|
|
|
|
ControlCodeMemory = 0x4c,
|
|
|
|
SleepSystem = 0x4d,
|
|
|
|
ReadWriteRegister = 0x4e,
|
|
|
|
SetProcessActivity = 0x4f,
|
|
|
|
CreateSharedMemory = 0x50,
|
|
|
|
MapTransferMemory = 0x51,
|
|
|
|
UnmapTransferMemory = 0x52,
|
|
|
|
CreateInterruptEvent = 0x53,
|
|
|
|
QueryPhysicalAddress = 0x54,
|
|
|
|
QueryIoMapping = 0x55,
|
|
|
|
CreateDeviceAddressSpace = 0x56,
|
|
|
|
AttachDeviceAddressSpace = 0x57,
|
|
|
|
DetachDeviceAddressSpace = 0x58,
|
|
|
|
MapDeviceAddressSpaceByForce = 0x59,
|
|
|
|
MapDeviceAddressSpaceAligned = 0x5a,
|
|
|
|
UnmapDeviceAddressSpace = 0x5c,
|
|
|
|
InvalidateProcessDataCache = 0x5d,
|
|
|
|
StoreProcessDataCache = 0x5e,
|
|
|
|
FlushProcessDataCache = 0x5f,
|
|
|
|
DebugActiveProcess = 0x60,
|
|
|
|
BreakDebugProcess = 0x61,
|
|
|
|
TerminateDebugProcess = 0x62,
|
|
|
|
GetDebugEvent = 0x63,
|
|
|
|
ContinueDebugEvent = 0x64,
|
|
|
|
GetProcessList = 0x65,
|
|
|
|
GetThreadList = 0x66,
|
|
|
|
GetDebugThreadContext = 0x67,
|
|
|
|
SetDebugThreadContext = 0x68,
|
|
|
|
QueryDebugProcessMemory = 0x69,
|
|
|
|
ReadDebugProcessMemory = 0x6a,
|
|
|
|
WriteDebugProcessMemory = 0x6b,
|
|
|
|
SetHardwareBreakPoint = 0x6c,
|
|
|
|
GetDebugThreadParam = 0x6d,
|
|
|
|
GetSystemInfo = 0x6f,
|
|
|
|
CreatePort = 0x70,
|
|
|
|
ManageNamedPort = 0x71,
|
|
|
|
ConnectToPort = 0x72,
|
|
|
|
SetProcessMemoryPermission = 0x73,
|
|
|
|
MapProcessMemory = 0x74,
|
|
|
|
UnmapProcessMemory = 0x75,
|
|
|
|
QueryProcessMemory = 0x76,
|
|
|
|
MapProcessCodeMemory = 0x77,
|
|
|
|
UnmapProcessCodeMemory = 0x78,
|
|
|
|
CreateProcess = 0x79,
|
|
|
|
StartProcess = 0x7a,
|
|
|
|
TerminateProcess = 0x7b,
|
|
|
|
GetProcessInfo = 0x7c,
|
|
|
|
CreateResourceLimit = 0x7d,
|
|
|
|
SetResourceLimitLimitValue = 0x7e,
|
|
|
|
CallSecureMonitor = 0x7f,
|
|
|
|
MapInsecureMemory = 0x90,
|
|
|
|
UnmapInsecureMemory = 0x91,
|
|
|
|
};
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
// Custom ABI.
|
|
|
|
Result ReplyAndReceiveLight(Core::System& system, Handle handle, uint32_t* args);
|
|
|
|
Result ReplyAndReceiveLight64From32(Core::System& system, Handle handle, uint32_t* args);
|
|
|
|
Result ReplyAndReceiveLight64(Core::System& system, Handle handle, uint32_t* args);
|
|
|
|
|
|
|
|
Result SendSyncRequestLight(Core::System& system, Handle session_handle, uint32_t* args);
|
|
|
|
Result SendSyncRequestLight64From32(Core::System& system, Handle session_handle, uint32_t* args);
|
|
|
|
Result SendSyncRequestLight64(Core::System& system, Handle session_handle, uint32_t* args);
|
|
|
|
|
|
|
|
void CallSecureMonitor(Core::System& system, lp64::SecureMonitorArguments* args);
|
|
|
|
void CallSecureMonitor64From32(Core::System& system, ilp32::SecureMonitorArguments* args);
|
|
|
|
void CallSecureMonitor64(Core::System& system, lp64::SecureMonitorArguments* args);
|
|
|
|
|
|
|
|
// Defined in svc_light_ipc.cpp.
|
2023-11-28 14:30:39 -05:00
|
|
|
void SvcWrap_ReplyAndReceiveLight64From32(Core::System& system, std::span<uint64_t, 8> args);
|
|
|
|
void SvcWrap_ReplyAndReceiveLight64(Core::System& system, std::span<uint64_t, 8> args);
|
2023-02-05 14:22:02 -05:00
|
|
|
|
2023-11-28 14:30:39 -05:00
|
|
|
void SvcWrap_SendSyncRequestLight64From32(Core::System& system, std::span<uint64_t, 8> args);
|
|
|
|
void SvcWrap_SendSyncRequestLight64(Core::System& system, std::span<uint64_t, 8> args);
|
2023-02-05 14:22:02 -05:00
|
|
|
|
|
|
|
// Defined in svc_secure_monitor_call.cpp.
|
2023-11-28 14:30:39 -05:00
|
|
|
void SvcWrap_CallSecureMonitor64From32(Core::System& system, std::span<uint64_t, 8> args);
|
|
|
|
void SvcWrap_CallSecureMonitor64(Core::System& system, std::span<uint64_t, 8> args);
|
2023-02-05 14:22:02 -05:00
|
|
|
|
|
|
|
// Perform a supervisor call by index.
|
|
|
|
void Call(Core::System& system, u32 imm);
|
2022-10-04 20:15:40 -04:00
|
|
|
|
2020-03-26 20:00:30 -04:00
|
|
|
} // namespace Kernel::Svc
|