2021-12-23 16:55:50 +00:00
|
|
|
using LibHac.Common;
|
2021-08-12 21:56:24 +00:00
|
|
|
using LibHac.Common.Keys;
|
2019-06-01 00:31:10 +00:00
|
|
|
using LibHac.Fs;
|
2021-08-12 21:56:24 +00:00
|
|
|
using LibHac.Fs.Shim;
|
2019-10-17 06:17:44 +00:00
|
|
|
using LibHac.FsSystem;
|
2022-01-12 11:22:19 +00:00
|
|
|
using LibHac.Tools.FsSystem;
|
2021-02-26 00:11:56 +00:00
|
|
|
using Ryujinx.Audio;
|
|
|
|
using Ryujinx.Audio.Input;
|
|
|
|
using Ryujinx.Audio.Integration;
|
|
|
|
using Ryujinx.Audio.Output;
|
2020-08-18 01:49:37 +00:00
|
|
|
using Ryujinx.Audio.Renderer.Device;
|
|
|
|
using Ryujinx.Audio.Renderer.Server;
|
2022-05-31 19:29:35 +00:00
|
|
|
using Ryujinx.Cpu;
|
2022-03-22 19:46:16 +00:00
|
|
|
using Ryujinx.HLE.FileSystem;
|
2020-05-04 03:41:29 +00:00
|
|
|
using Ryujinx.HLE.HOS.Kernel;
|
2018-12-18 05:33:36 +00:00
|
|
|
using Ryujinx.HLE.HOS.Kernel.Memory;
|
|
|
|
using Ryujinx.HLE.HOS.Kernel.Process;
|
|
|
|
using Ryujinx.HLE.HOS.Kernel.Threading;
|
2020-12-02 12:14:44 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services;
|
2021-04-13 01:16:43 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Account.Acc;
|
2020-04-23 11:59:11 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Am.AppletAE.AllSystemAppletProxiesService.SystemAppletProxy;
|
2020-11-08 20:00:54 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Apm;
|
2020-08-18 01:49:37 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Audio.AudioRenderer;
|
2021-03-26 00:16:08 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Caps;
|
2020-03-01 22:56:02 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Mii;
|
2021-06-23 23:05:40 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Nfc.Nfp.NfpManager;
|
2020-04-23 11:59:11 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Nv;
|
2020-04-19 01:25:57 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Nv.NvDrvServices.NvHostCtrl;
|
2019-10-08 03:48:49 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Pcv.Bpc;
|
2021-09-14 23:24:49 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Sdb.Pl;
|
2019-09-19 00:45:11 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Settings;
|
2019-01-18 22:26:39 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Sm;
|
2020-04-19 01:25:57 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.SurfaceFlinger;
|
2019-07-14 20:50:11 +00:00
|
|
|
using Ryujinx.HLE.HOS.Services.Time.Clock;
|
2018-08-16 23:47:36 +00:00
|
|
|
using Ryujinx.HLE.HOS.SystemState;
|
2018-06-11 00:46:42 +00:00
|
|
|
using Ryujinx.HLE.Loaders.Executables;
|
2023-03-31 19:16:46 +00:00
|
|
|
using Ryujinx.HLE.Loaders.Processes;
|
2023-01-04 22:15:45 +00:00
|
|
|
using Ryujinx.Horizon;
|
2018-02-20 20:09:23 +00:00
|
|
|
using System;
|
2021-03-18 20:40:20 +00:00
|
|
|
using System.Collections.Generic;
|
2018-02-04 23:08:20 +00:00
|
|
|
using System.IO;
|
2020-12-17 00:44:06 +00:00
|
|
|
using System.Linq;
|
2020-09-22 04:50:40 +00:00
|
|
|
using System.Threading;
|
2020-01-12 11:15:17 +00:00
|
|
|
|
2018-08-16 23:47:36 +00:00
|
|
|
namespace Ryujinx.HLE.HOS
|
2018-02-04 23:08:20 +00:00
|
|
|
{
|
2020-05-04 03:41:29 +00:00
|
|
|
using TimeServiceManager = Services.Time.TimeManager;
|
|
|
|
|
2018-03-12 04:04:52 +00:00
|
|
|
public class Horizon : IDisposable
|
2018-02-04 23:08:20 +00:00
|
|
|
{
|
2023-07-16 17:31:14 +00:00
|
|
|
internal const int HidSize = 0x40000;
|
|
|
|
internal const int FontSize = 0x1100000;
|
|
|
|
internal const int IirsSize = 0x8000;
|
|
|
|
internal const int TimeSize = 0x1000;
|
2021-06-28 18:54:45 +00:00
|
|
|
internal const int AppletCaptureBufferSize = 0x384000;
|
2018-02-04 23:08:20 +00:00
|
|
|
|
2020-05-04 03:41:29 +00:00
|
|
|
internal KernelContext KernelContext { get; }
|
2018-11-28 22:18:09 +00:00
|
|
|
|
2018-12-05 00:52:39 +00:00
|
|
|
internal Switch Device { get; private set; }
|
2018-02-04 23:08:20 +00:00
|
|
|
|
2022-05-31 19:29:35 +00:00
|
|
|
internal ITickSource TickSource { get; }
|
|
|
|
|
2020-04-22 04:10:27 +00:00
|
|
|
internal SurfaceFlinger SurfaceFlinger { get; private set; }
|
2021-02-26 00:11:56 +00:00
|
|
|
internal AudioManager AudioManager { get; private set; }
|
|
|
|
internal AudioOutputManager AudioOutputManager { get; private set; }
|
|
|
|
internal AudioInputManager AudioInputManager { get; private set; }
|
2020-08-18 01:49:37 +00:00
|
|
|
internal AudioRendererManager AudioRendererManager { get; private set; }
|
|
|
|
internal VirtualDeviceSessionRegistry AudioDeviceSessionRegistry { get; private set; }
|
2020-04-22 04:10:27 +00:00
|
|
|
|
2018-12-05 00:52:39 +00:00
|
|
|
public SystemStateMgr State { get; private set; }
|
2018-04-24 20:14:26 +00:00
|
|
|
|
2020-11-08 20:00:54 +00:00
|
|
|
internal PerformanceState PerformanceState { get; private set; }
|
|
|
|
|
2018-12-05 00:52:39 +00:00
|
|
|
internal AppletStateMgr AppletState { get; private set; }
|
2018-09-18 23:36:43 +00:00
|
|
|
|
2021-03-18 20:40:20 +00:00
|
|
|
internal List<NfpDevice> NfpDevices { get; private set; }
|
|
|
|
|
2022-05-05 18:23:30 +00:00
|
|
|
internal SmRegistry SmRegistry { get; private set; }
|
|
|
|
|
2021-06-29 17:37:13 +00:00
|
|
|
internal ServerBase SmServer { get; private set; }
|
2020-12-02 12:14:44 +00:00
|
|
|
internal ServerBase BsdServer { get; private set; }
|
|
|
|
internal ServerBase AudRenServer { get; private set; }
|
|
|
|
internal ServerBase AudOutServer { get; private set; }
|
2022-02-19 14:29:11 +00:00
|
|
|
internal ServerBase FsServer { get; private set; }
|
2020-12-02 12:14:44 +00:00
|
|
|
internal ServerBase HidServer { get; private set; }
|
|
|
|
internal ServerBase NvDrvServer { get; private set; }
|
|
|
|
internal ServerBase TimeServer { get; private set; }
|
|
|
|
internal ServerBase ViServer { get; private set; }
|
|
|
|
internal ServerBase ViServerM { get; private set; }
|
|
|
|
internal ServerBase ViServerS { get; private set; }
|
Add ldn:u implementation, INetworkClient interface and DisabledLdnClient (#5652)
* Impl first attempt to LDN
* Make this work.
- Endianness swap on all IPs.
- Use local network IP for connections, rather than 127.0.0.1. This is to be changed when tunnelling or whatever.
- Mac addresses are now randomly assigned on the server. (fixes joining lobbies)
- Fixed the "connected" handler for stations to actually find a
- Added info retrieval when connected to a station.
- Users that disconnect are now removed from rooms they were in. (still need to broadcast tho)
- The communication service does a bit better with being closed now.
- Some locking around the game instance dictionary.
* We may just be "initialized". Ignore this for now.
* Lots of WIP
* Add Disconnect packet
* Improve signalling of internal events.
* Fix scan.
* Fix some more stupid things.
* Enable NoDelay on all sockets.
* Add station accept policy, disconnect function.
* Limit max number of games.
* Split out networking stuff from HLE, so it can be swapped.
* Update logging calls.
* Missed a spot.
* Call SignalDisconnect instead of SetState
* Add comment to GetNetworkInfo
* Update configuration + UI
Now has its own tab, more options.
* Refactoring IUserLocalCommunicationService
( Expected new issues :'( )
* some cleanup
* More fix
* Correctly handle errors when connecting.
* Disable *Private call and clean symbols
* Structs cleanup
* Big cleanup
* Fix InvalidHandle (in MK8D and other games)
* Add Reject and Private Network support (v1)
RyuLdn Version bumped to 1.
* Add Initialize Packet
Allows users to keep Mac Addresses assigned by the server.
* Add SetWirelessControllerRestriction and some cleanup
* LDN-2 Initial Rebase
Make this work.
- Endianness swap on all IPs.
- Use local network IP for connections, rather than 127.0.0.1. This is to be changed when tunnelling or whatever.
- Fixed the "connected" handler for stations to actually find a
- The communication service does a bit better with being closed now.
- Some locking around the game instance dictionary.
We may just be "initialized". Ignore this for now.
Lots of WIP
Implement scan filter.
Improve signalling of internal events.
Fix scan.
Fix 0 width data, scan reply end delay removed.
Fix some more stupid things.
Enable NoDelay on all sockets.
Add station accept policy, disconnect function.
Limit max number of games.
Split out networking stuff from HLE, so it can be swapped.
Update logging calls.
Missed a spot.
SetAdvertiseData when open, don't return games that have accept policy 1
Update configuration + UI
Now has its own tab, more options.
Don't Keepalive, it causes problems.
Refactoring IUserLocalCommunicationService
( Expected new issues :'( )
some cleanup
More fix
Correctly handle errors when connecting.
Disable *Private call and clean symbols
Structs cleanup
Big cleanup
Fix InvalidHandle (in MK8D and other games)
Add Reject and Private Network support (v1)
Disable TcpNoDelay option on linux.
Add SetWirelessControllerRestriction and some cleanup
Misc cleanup, implement broadcast flag.
* Misc Changes
* Fix GetNetworkInfo
* Fix some small issues
* Implement GetNetworkInfoLatestUpdate
* Hotfix when LocalCommunicationId = 0xFFFFFFFFFFFFFFFF
* Fix ARMS Scan (and other games using wrong LocalCommunicationId
* Fix latest update when host leaves
* Revert "Fix ARMS Scan (and other games using wrong LocalCommunicationId"
This reverts commit 519c283d3993e2fdfafb8ac6b4e0a98231f6fb75.
* Fix the localCommunicationId = -1
* Don't set Connect flag for nodes already in the room before joining.
* Make IUserLocalCommunicationService disposable
* Don't dispose if there's no client.
* LDN-2-2 Rebase
Make this work.
- Endianness swap on all IPs.
- Use local network IP for connections, rather than 127.0.0.1. This is to be changed when tunnelling or whatever.
- Fixed the "connected" handler for stations to actually find a
- The communication service does a bit better with being closed now.
- Some locking around the game instance dictionary.
We may just be "initialized". Ignore this for now.
Put sockets behind an interface, so that they can be swapped for something proxyable
Lots of WIP
Implement scan filter.
Improve signalling of internal events.
Fix scan.
Fix 0 width data, scan reply end delay removed.
Fix some more stupid things.
Enable NoDelay on all sockets.
Add station accept policy, disconnect function.
Limit max number of games.
Split out networking stuff from HLE, so it can be swapped.
Update logging calls.
Missed a spot.
SetAdvertiseData when open, don't return games that have accept policy 1
Update configuration + UI
Now has its own tab, more options.
Don't Keepalive, it causes problems.
Refactoring IUserLocalCommunicationService
( Expected new issues :'( )
some cleanup
More fix
Correctly handle errors when connecting.
Disable *Private call and clean symbols
Structs cleanup
Big cleanup
Fix InvalidHandle (in MK8D and other games)
Add Reject and Private Network support (v1)
Disable TcpNoDelay option on linux.
Add SetWirelessControllerRestriction and some cleanup
Misc cleanup, implement broadcast flag.
Misc Changes
Fix GetNetworkInfo
Fix some small issues
Disable LAN by default til the config is added.
Fix Splatoon 2
- Stub nfp IUser::StartDetection / IUser::StopDetection.
- Stub ntc IEnsureNetworkClockAvailabilityService and needed calls.
Cleanup previous fixes
Stub IAudioInManager/IAudioIn for Splatoon 2 LAN
Add LAN settings to multiplayer tab
LAN Play > LAN Mode
Implement GetNetworkInfoLatestUpdate
Hotfix when LocalCommunicationId = 0xFFFFFFFFFFFFFFFF
Fix ARMS Scan (and other games using wrong LocalCommunicationId
Fix latest update when host leaves
Revert "Fix ARMS Scan (and other games using wrong LocalCommunicationId"
This reverts commit 519c283d3993e2fdfafb8ac6b4e0a98231f6fb75.
Fix the localCommunicationId = -1
Don't set Connect flag for nodes already in the room before joining.
Make IUserLocalCommunicationService disposable
Fix crash when using LAN mode on linux.
Actually use that call
Don't dispose if there's no client.
Fix the settings window crash
Fix configurationFileUpdated
* Make LDN compatible with Ryujinx/Ryujinx#3805
* Ava: Add Ldn options to SettingsNetworkTab
* Ava: Add update events for multiplayer options
* Apply formatting
* Remove LdnHelper
* ldn: Fix hardcoded /24 subnet mask
* Fix naming rule violations
* Add missing summary doc tag
* Remove NetCoreServer dependency
* Address code style issues and typos
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
* Call CloseStation/CloseAccessPoint to reduce code duplication
* Fix typo
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
* Fix missing trailing commas
* Extract AddressList from AddressEntry
* Use AcceptPolicy as a type for LdnNetworkInfo.StationAcceptPolicy
* Add Flags attribute to ScanFilterFlag
* Rename struct members for LdnNetworkInfo
* Remove extra line
Co-authored-by: Ac_K <Acoustik666@gmail.com>
* Extract NetworkErrorMessage from NetworkError
* Fix missing trailing commas
---------
Co-authored-by: Ac_K <Acoustik666@gmail.com>
Co-authored-by: riperiperi <rhy3756547@hotmail.com>
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
2023-09-25 21:50:43 +00:00
|
|
|
internal ServerBase LdnServer { get; private set; }
|
2020-12-02 12:14:44 +00:00
|
|
|
|
2023-07-16 17:31:14 +00:00
|
|
|
internal KSharedMemory HidSharedMem { get; private set; }
|
2018-12-05 00:52:39 +00:00
|
|
|
internal KSharedMemory FontSharedMem { get; private set; }
|
2019-04-20 02:23:13 +00:00
|
|
|
internal KSharedMemory IirsSharedMem { get; private set; }
|
2021-06-28 18:54:45 +00:00
|
|
|
|
|
|
|
internal KTransferMemory AppletCaptureBufferTransfer { get; private set; }
|
|
|
|
|
2021-09-14 23:24:49 +00:00
|
|
|
internal SharedFontManager SharedFontManager { get; private set; }
|
2023-07-16 17:31:14 +00:00
|
|
|
internal AccountManager AccountManager { get; private set; }
|
|
|
|
internal ContentManager ContentManager { get; private set; }
|
|
|
|
internal CaptureManager CaptureManager { get; private set; }
|
2018-11-18 19:37:41 +00:00
|
|
|
|
2018-12-05 00:52:39 +00:00
|
|
|
internal KEvent VsyncEvent { get; private set; }
|
2018-02-17 21:36:08 +00:00
|
|
|
|
2020-04-23 11:59:11 +00:00
|
|
|
internal KEvent DisplayResolutionChangeEvent { get; private set; }
|
|
|
|
|
2021-08-12 21:56:24 +00:00
|
|
|
public KeySet KeySet => Device.FileSystem.KeySet;
|
2018-09-08 18:33:27 +00:00
|
|
|
|
2020-02-06 11:38:24 +00:00
|
|
|
private bool _isDisposed;
|
2018-09-18 23:36:43 +00:00
|
|
|
|
2020-06-16 18:28:02 +00:00
|
|
|
public bool EnablePtc { get; set; }
|
2020-04-12 21:02:37 +00:00
|
|
|
|
2018-10-31 02:34:27 +00:00
|
|
|
public IntegrityCheckLevel FsIntegrityCheckLevel { get; set; }
|
2018-10-06 15:11:47 +00:00
|
|
|
|
2019-06-16 01:31:18 +00:00
|
|
|
public int GlobalAccessLogMode { get; set; }
|
|
|
|
|
POWER - Performance Optimizations With Extensive Ramifications (#2286)
* Refactoring of KMemoryManager class
* Replace some trivial uses of DRAM address with VA
* Get rid of GetDramAddressFromVa
* Abstracting more operations on derived page table class
* Run auto-format on KPageTableBase
* Managed to make TryConvertVaToPa private, few uses remains now
* Implement guest physical pages ref counting, remove manual freeing
* Make DoMmuOperation private and call new abstract methods only from the base class
* Pass pages count rather than size on Map/UnmapMemory
* Change memory managers to take host pointers
* Fix a guest memory leak and simplify KPageTable
* Expose new methods for host range query and mapping
* Some refactoring of MapPagesFromClientProcess to allow proper page ref counting and mapping without KPageLists
* Remove more uses of AddVaRangeToPageList, now only one remains (shared memory page checking)
* Add a SharedMemoryStorage class, will be useful for host mapping
* Sayonara AddVaRangeToPageList, you served us well
* Start to implement host memory mapping (WIP)
* Support memory tracking through host exception handling
* Fix some access violations from HLE service guest memory access and CPU
* Fix memory tracking
* Fix mapping list bugs, including a race and a error adding mapping ranges
* Simple page table for memory tracking
* Simple "volatile" region handle mode
* Update UBOs directly (experimental, rough)
* Fix the overlap check
* Only set non-modified buffers as volatile
* Fix some memory tracking issues
* Fix possible race in MapBufferFromClientProcess (block list updates were not locked)
* Write uniform update to memory immediately, only defer the buffer set.
* Fix some memory tracking issues
* Pass correct pages count on shared memory unmap
* Armeilleure Signal Handler v1 + Unix changes
Unix currently behaves like windows, rather than remapping physical
* Actually check if the host platform is unix
* Fix decommit on linux.
* Implement windows 10 placeholder shared memory, fix a buffer issue.
* Make PTC version something that will never match with master
* Remove testing variable for block count
* Add reference count for memory manager, fix dispose
Can still deadlock with OpenAL
* Add address validation, use page table for mapped check, add docs
Might clean up the page table traversing routines.
* Implement batched mapping/tracking.
* Move documentation, fix tests.
* Cleanup uniform buffer update stuff.
* Remove unnecessary assignment.
* Add unsafe host mapped memory switch
On by default. Would be good to turn this off for untrusted code (homebrew, exefs mods) and give the user the option to turn it on manually, though that requires some UI work.
* Remove C# exception handlers
They have issues due to current .NET limitations, so the meilleure one fully replaces them for now.
* Fix MapPhysicalMemory on the software MemoryManager.
* Null check for GetHostAddress, docs
* Add configuration for setting memory manager mode (not in UI yet)
* Add config to UI
* Fix type mismatch on Unix signal handler code emit
* Fix 6GB DRAM mode.
The size can be greater than `uint.MaxValue` when the DRAM is >4GB.
* Address some feedback.
* More detailed error if backing memory cannot be mapped.
* SetLastError on all OS functions for consistency
* Force pages dirty with UBO update instead of setting them directly.
Seems to be much faster across a few games. Need retesting.
* Rebase, configuration rework, fix mem tracking regression
* Fix race in FreePages
* Set memory managers null after decrementing ref count
* Remove readonly keyword, as this is now modified.
* Use a local variable for the signal handler rather than a register.
* Fix bug with buffer resize, and index/uniform buffer binding.
Should fix flickering in games.
* Add InvalidAccessHandler to MemoryTracking
Doesn't do anything yet
* Call invalid access handler on unmapped read/write.
Same rules as the regular memory manager.
* Make unsafe mapped memory its own MemoryManagerType
* Move FlushUboDirty into UpdateState.
* Buffer dirty cache, rather than ubo cache
Much cleaner, may be reusable for Inline2Memory updates.
* This doesn't return anything anymore.
* Add sigaction remove methods, correct a few function signatures.
* Return empty list of physical regions for size 0.
* Also on AddressSpaceManager
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
2021-05-24 20:52:44 +00:00
|
|
|
internal SharedMemoryStorage HidStorage { get; private set; }
|
2018-11-28 22:18:09 +00:00
|
|
|
|
2020-04-19 01:25:57 +00:00
|
|
|
internal NvHostSyncpt HostSyncpoint { get; private set; }
|
|
|
|
|
2021-08-12 21:56:24 +00:00
|
|
|
internal LibHacHorizonManager LibHacHorizonManager { get; private set; }
|
2020-04-30 04:58:19 +00:00
|
|
|
|
2023-01-08 12:13:39 +00:00
|
|
|
internal ServiceTable ServiceTable { get; private set; }
|
|
|
|
|
2021-09-11 20:08:25 +00:00
|
|
|
public bool IsPaused { get; private set; }
|
|
|
|
|
2021-05-16 15:12:14 +00:00
|
|
|
public Horizon(Switch device)
|
2018-02-04 23:08:20 +00:00
|
|
|
{
|
2022-05-31 19:29:35 +00:00
|
|
|
TickSource = new TickSource(KernelConstants.CounterFrequency);
|
|
|
|
|
2021-04-04 12:06:59 +00:00
|
|
|
KernelContext = new KernelContext(
|
2022-05-31 19:29:35 +00:00
|
|
|
TickSource,
|
2021-04-04 12:06:59 +00:00
|
|
|
device,
|
|
|
|
device.Memory,
|
2021-05-16 15:12:14 +00:00
|
|
|
device.Configuration.MemoryConfiguration.ToKernelMemorySize(),
|
|
|
|
device.Configuration.MemoryConfiguration.ToKernelMemoryArrange());
|
2020-05-04 03:41:29 +00:00
|
|
|
|
2018-12-06 11:16:24 +00:00
|
|
|
Device = device;
|
2018-02-04 23:08:20 +00:00
|
|
|
|
2018-08-16 23:47:36 +00:00
|
|
|
State = new SystemStateMgr();
|
2018-04-24 20:14:26 +00:00
|
|
|
|
2020-11-08 20:00:54 +00:00
|
|
|
PerformanceState = new PerformanceState();
|
|
|
|
|
2021-03-18 20:40:20 +00:00
|
|
|
NfpDevices = new List<NfpDevice>();
|
|
|
|
|
2019-07-02 02:39:22 +00:00
|
|
|
// Note: This is not really correct, but with HLE of services, the only memory
|
|
|
|
// region used that is used is Application, so we can use the other ones for anything.
|
POWER - Performance Optimizations With Extensive Ramifications (#2286)
* Refactoring of KMemoryManager class
* Replace some trivial uses of DRAM address with VA
* Get rid of GetDramAddressFromVa
* Abstracting more operations on derived page table class
* Run auto-format on KPageTableBase
* Managed to make TryConvertVaToPa private, few uses remains now
* Implement guest physical pages ref counting, remove manual freeing
* Make DoMmuOperation private and call new abstract methods only from the base class
* Pass pages count rather than size on Map/UnmapMemory
* Change memory managers to take host pointers
* Fix a guest memory leak and simplify KPageTable
* Expose new methods for host range query and mapping
* Some refactoring of MapPagesFromClientProcess to allow proper page ref counting and mapping without KPageLists
* Remove more uses of AddVaRangeToPageList, now only one remains (shared memory page checking)
* Add a SharedMemoryStorage class, will be useful for host mapping
* Sayonara AddVaRangeToPageList, you served us well
* Start to implement host memory mapping (WIP)
* Support memory tracking through host exception handling
* Fix some access violations from HLE service guest memory access and CPU
* Fix memory tracking
* Fix mapping list bugs, including a race and a error adding mapping ranges
* Simple page table for memory tracking
* Simple "volatile" region handle mode
* Update UBOs directly (experimental, rough)
* Fix the overlap check
* Only set non-modified buffers as volatile
* Fix some memory tracking issues
* Fix possible race in MapBufferFromClientProcess (block list updates were not locked)
* Write uniform update to memory immediately, only defer the buffer set.
* Fix some memory tracking issues
* Pass correct pages count on shared memory unmap
* Armeilleure Signal Handler v1 + Unix changes
Unix currently behaves like windows, rather than remapping physical
* Actually check if the host platform is unix
* Fix decommit on linux.
* Implement windows 10 placeholder shared memory, fix a buffer issue.
* Make PTC version something that will never match with master
* Remove testing variable for block count
* Add reference count for memory manager, fix dispose
Can still deadlock with OpenAL
* Add address validation, use page table for mapped check, add docs
Might clean up the page table traversing routines.
* Implement batched mapping/tracking.
* Move documentation, fix tests.
* Cleanup uniform buffer update stuff.
* Remove unnecessary assignment.
* Add unsafe host mapped memory switch
On by default. Would be good to turn this off for untrusted code (homebrew, exefs mods) and give the user the option to turn it on manually, though that requires some UI work.
* Remove C# exception handlers
They have issues due to current .NET limitations, so the meilleure one fully replaces them for now.
* Fix MapPhysicalMemory on the software MemoryManager.
* Null check for GetHostAddress, docs
* Add configuration for setting memory manager mode (not in UI yet)
* Add config to UI
* Fix type mismatch on Unix signal handler code emit
* Fix 6GB DRAM mode.
The size can be greater than `uint.MaxValue` when the DRAM is >4GB.
* Address some feedback.
* More detailed error if backing memory cannot be mapped.
* SetLastError on all OS functions for consistency
* Force pages dirty with UBO update instead of setting them directly.
Seems to be much faster across a few games. Need retesting.
* Rebase, configuration rework, fix mem tracking regression
* Fix race in FreePages
* Set memory managers null after decrementing ref count
* Remove readonly keyword, as this is now modified.
* Use a local variable for the signal handler rather than a register.
* Fix bug with buffer resize, and index/uniform buffer binding.
Should fix flickering in games.
* Add InvalidAccessHandler to MemoryTracking
Doesn't do anything yet
* Call invalid access handler on unmapped read/write.
Same rules as the regular memory manager.
* Make unsafe mapped memory its own MemoryManagerType
* Move FlushUboDirty into UpdateState.
* Buffer dirty cache, rather than ubo cache
Much cleaner, may be reusable for Inline2Memory updates.
* This doesn't return anything anymore.
* Add sigaction remove methods, correct a few function signatures.
* Return empty list of physical regions for size 0.
* Also on AddressSpaceManager
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
2021-05-24 20:52:44 +00:00
|
|
|
KMemoryRegionManager region = KernelContext.MemoryManager.MemoryRegions[(int)MemoryRegion.NvServices];
|
2018-11-28 22:18:09 +00:00
|
|
|
|
2023-07-16 17:31:14 +00:00
|
|
|
ulong hidPa = region.Address;
|
|
|
|
ulong fontPa = region.Address + HidSize;
|
|
|
|
ulong iirsPa = region.Address + HidSize + FontSize;
|
|
|
|
ulong timePa = region.Address + HidSize + FontSize + IirsSize;
|
2021-06-28 18:54:45 +00:00
|
|
|
ulong appletCaptureBufferPa = region.Address + HidSize + FontSize + IirsSize + TimeSize;
|
2018-11-28 22:18:09 +00:00
|
|
|
|
2023-07-16 17:31:14 +00:00
|
|
|
KPageList hidPageList = new();
|
|
|
|
KPageList fontPageList = new();
|
|
|
|
KPageList iirsPageList = new();
|
|
|
|
KPageList timePageList = new();
|
|
|
|
KPageList appletCaptureBufferPageList = new();
|
NvServices refactoring (#120)
* Initial implementation of NvMap/NvHostCtrl
* More work on NvHostCtrl
* Refactoring of nvservices, move GPU Vmm, make Vmm per-process, refactor most gpu devices, move Gpu to Core, fix CbBind
* Implement GetGpuTime, support CancelSynchronization, fix issue on InsertWaitingMutex, proper double buffering support (again, not working properly for commercial games, only hb)
* Try to fix perf regression reading/writing textures, moved syncpts and events to a UserCtx class, delete global state when the process exits, other minor tweaks
* Remove now unused code, add comment about probably wrong result codes
2018-05-07 18:53:23 +00:00
|
|
|
|
2021-06-28 18:54:45 +00:00
|
|
|
hidPageList.AddRange(hidPa, HidSize / KPageTableBase.PageSize);
|
POWER - Performance Optimizations With Extensive Ramifications (#2286)
* Refactoring of KMemoryManager class
* Replace some trivial uses of DRAM address with VA
* Get rid of GetDramAddressFromVa
* Abstracting more operations on derived page table class
* Run auto-format on KPageTableBase
* Managed to make TryConvertVaToPa private, few uses remains now
* Implement guest physical pages ref counting, remove manual freeing
* Make DoMmuOperation private and call new abstract methods only from the base class
* Pass pages count rather than size on Map/UnmapMemory
* Change memory managers to take host pointers
* Fix a guest memory leak and simplify KPageTable
* Expose new methods for host range query and mapping
* Some refactoring of MapPagesFromClientProcess to allow proper page ref counting and mapping without KPageLists
* Remove more uses of AddVaRangeToPageList, now only one remains (shared memory page checking)
* Add a SharedMemoryStorage class, will be useful for host mapping
* Sayonara AddVaRangeToPageList, you served us well
* Start to implement host memory mapping (WIP)
* Support memory tracking through host exception handling
* Fix some access violations from HLE service guest memory access and CPU
* Fix memory tracking
* Fix mapping list bugs, including a race and a error adding mapping ranges
* Simple page table for memory tracking
* Simple "volatile" region handle mode
* Update UBOs directly (experimental, rough)
* Fix the overlap check
* Only set non-modified buffers as volatile
* Fix some memory tracking issues
* Fix possible race in MapBufferFromClientProcess (block list updates were not locked)
* Write uniform update to memory immediately, only defer the buffer set.
* Fix some memory tracking issues
* Pass correct pages count on shared memory unmap
* Armeilleure Signal Handler v1 + Unix changes
Unix currently behaves like windows, rather than remapping physical
* Actually check if the host platform is unix
* Fix decommit on linux.
* Implement windows 10 placeholder shared memory, fix a buffer issue.
* Make PTC version something that will never match with master
* Remove testing variable for block count
* Add reference count for memory manager, fix dispose
Can still deadlock with OpenAL
* Add address validation, use page table for mapped check, add docs
Might clean up the page table traversing routines.
* Implement batched mapping/tracking.
* Move documentation, fix tests.
* Cleanup uniform buffer update stuff.
* Remove unnecessary assignment.
* Add unsafe host mapped memory switch
On by default. Would be good to turn this off for untrusted code (homebrew, exefs mods) and give the user the option to turn it on manually, though that requires some UI work.
* Remove C# exception handlers
They have issues due to current .NET limitations, so the meilleure one fully replaces them for now.
* Fix MapPhysicalMemory on the software MemoryManager.
* Null check for GetHostAddress, docs
* Add configuration for setting memory manager mode (not in UI yet)
* Add config to UI
* Fix type mismatch on Unix signal handler code emit
* Fix 6GB DRAM mode.
The size can be greater than `uint.MaxValue` when the DRAM is >4GB.
* Address some feedback.
* More detailed error if backing memory cannot be mapped.
* SetLastError on all OS functions for consistency
* Force pages dirty with UBO update instead of setting them directly.
Seems to be much faster across a few games. Need retesting.
* Rebase, configuration rework, fix mem tracking regression
* Fix race in FreePages
* Set memory managers null after decrementing ref count
* Remove readonly keyword, as this is now modified.
* Use a local variable for the signal handler rather than a register.
* Fix bug with buffer resize, and index/uniform buffer binding.
Should fix flickering in games.
* Add InvalidAccessHandler to MemoryTracking
Doesn't do anything yet
* Call invalid access handler on unmapped read/write.
Same rules as the regular memory manager.
* Make unsafe mapped memory its own MemoryManagerType
* Move FlushUboDirty into UpdateState.
* Buffer dirty cache, rather than ubo cache
Much cleaner, may be reusable for Inline2Memory updates.
* This doesn't return anything anymore.
* Add sigaction remove methods, correct a few function signatures.
* Return empty list of physical regions for size 0.
* Also on AddressSpaceManager
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
2021-05-24 20:52:44 +00:00
|
|
|
fontPageList.AddRange(fontPa, FontSize / KPageTableBase.PageSize);
|
|
|
|
iirsPageList.AddRange(iirsPa, IirsSize / KPageTableBase.PageSize);
|
|
|
|
timePageList.AddRange(timePa, TimeSize / KPageTableBase.PageSize);
|
2021-06-28 18:54:45 +00:00
|
|
|
appletCaptureBufferPageList.AddRange(appletCaptureBufferPa, AppletCaptureBufferSize / KPageTableBase.PageSize);
|
POWER - Performance Optimizations With Extensive Ramifications (#2286)
* Refactoring of KMemoryManager class
* Replace some trivial uses of DRAM address with VA
* Get rid of GetDramAddressFromVa
* Abstracting more operations on derived page table class
* Run auto-format on KPageTableBase
* Managed to make TryConvertVaToPa private, few uses remains now
* Implement guest physical pages ref counting, remove manual freeing
* Make DoMmuOperation private and call new abstract methods only from the base class
* Pass pages count rather than size on Map/UnmapMemory
* Change memory managers to take host pointers
* Fix a guest memory leak and simplify KPageTable
* Expose new methods for host range query and mapping
* Some refactoring of MapPagesFromClientProcess to allow proper page ref counting and mapping without KPageLists
* Remove more uses of AddVaRangeToPageList, now only one remains (shared memory page checking)
* Add a SharedMemoryStorage class, will be useful for host mapping
* Sayonara AddVaRangeToPageList, you served us well
* Start to implement host memory mapping (WIP)
* Support memory tracking through host exception handling
* Fix some access violations from HLE service guest memory access and CPU
* Fix memory tracking
* Fix mapping list bugs, including a race and a error adding mapping ranges
* Simple page table for memory tracking
* Simple "volatile" region handle mode
* Update UBOs directly (experimental, rough)
* Fix the overlap check
* Only set non-modified buffers as volatile
* Fix some memory tracking issues
* Fix possible race in MapBufferFromClientProcess (block list updates were not locked)
* Write uniform update to memory immediately, only defer the buffer set.
* Fix some memory tracking issues
* Pass correct pages count on shared memory unmap
* Armeilleure Signal Handler v1 + Unix changes
Unix currently behaves like windows, rather than remapping physical
* Actually check if the host platform is unix
* Fix decommit on linux.
* Implement windows 10 placeholder shared memory, fix a buffer issue.
* Make PTC version something that will never match with master
* Remove testing variable for block count
* Add reference count for memory manager, fix dispose
Can still deadlock with OpenAL
* Add address validation, use page table for mapped check, add docs
Might clean up the page table traversing routines.
* Implement batched mapping/tracking.
* Move documentation, fix tests.
* Cleanup uniform buffer update stuff.
* Remove unnecessary assignment.
* Add unsafe host mapped memory switch
On by default. Would be good to turn this off for untrusted code (homebrew, exefs mods) and give the user the option to turn it on manually, though that requires some UI work.
* Remove C# exception handlers
They have issues due to current .NET limitations, so the meilleure one fully replaces them for now.
* Fix MapPhysicalMemory on the software MemoryManager.
* Null check for GetHostAddress, docs
* Add configuration for setting memory manager mode (not in UI yet)
* Add config to UI
* Fix type mismatch on Unix signal handler code emit
* Fix 6GB DRAM mode.
The size can be greater than `uint.MaxValue` when the DRAM is >4GB.
* Address some feedback.
* More detailed error if backing memory cannot be mapped.
* SetLastError on all OS functions for consistency
* Force pages dirty with UBO update instead of setting them directly.
Seems to be much faster across a few games. Need retesting.
* Rebase, configuration rework, fix mem tracking regression
* Fix race in FreePages
* Set memory managers null after decrementing ref count
* Remove readonly keyword, as this is now modified.
* Use a local variable for the signal handler rather than a register.
* Fix bug with buffer resize, and index/uniform buffer binding.
Should fix flickering in games.
* Add InvalidAccessHandler to MemoryTracking
Doesn't do anything yet
* Call invalid access handler on unmapped read/write.
Same rules as the regular memory manager.
* Make unsafe mapped memory its own MemoryManagerType
* Move FlushUboDirty into UpdateState.
* Buffer dirty cache, rather than ubo cache
Much cleaner, may be reusable for Inline2Memory updates.
* This doesn't return anything anymore.
* Add sigaction remove methods, correct a few function signatures.
* Return empty list of physical regions for size 0.
* Also on AddressSpaceManager
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
2021-05-24 20:52:44 +00:00
|
|
|
|
|
|
|
var hidStorage = new SharedMemoryStorage(KernelContext, hidPageList);
|
|
|
|
var fontStorage = new SharedMemoryStorage(KernelContext, fontPageList);
|
|
|
|
var iirsStorage = new SharedMemoryStorage(KernelContext, iirsPageList);
|
|
|
|
var timeStorage = new SharedMemoryStorage(KernelContext, timePageList);
|
2021-06-28 18:54:45 +00:00
|
|
|
var appletCaptureBufferStorage = new SharedMemoryStorage(KernelContext, appletCaptureBufferPageList);
|
2018-11-28 22:18:09 +00:00
|
|
|
|
POWER - Performance Optimizations With Extensive Ramifications (#2286)
* Refactoring of KMemoryManager class
* Replace some trivial uses of DRAM address with VA
* Get rid of GetDramAddressFromVa
* Abstracting more operations on derived page table class
* Run auto-format on KPageTableBase
* Managed to make TryConvertVaToPa private, few uses remains now
* Implement guest physical pages ref counting, remove manual freeing
* Make DoMmuOperation private and call new abstract methods only from the base class
* Pass pages count rather than size on Map/UnmapMemory
* Change memory managers to take host pointers
* Fix a guest memory leak and simplify KPageTable
* Expose new methods for host range query and mapping
* Some refactoring of MapPagesFromClientProcess to allow proper page ref counting and mapping without KPageLists
* Remove more uses of AddVaRangeToPageList, now only one remains (shared memory page checking)
* Add a SharedMemoryStorage class, will be useful for host mapping
* Sayonara AddVaRangeToPageList, you served us well
* Start to implement host memory mapping (WIP)
* Support memory tracking through host exception handling
* Fix some access violations from HLE service guest memory access and CPU
* Fix memory tracking
* Fix mapping list bugs, including a race and a error adding mapping ranges
* Simple page table for memory tracking
* Simple "volatile" region handle mode
* Update UBOs directly (experimental, rough)
* Fix the overlap check
* Only set non-modified buffers as volatile
* Fix some memory tracking issues
* Fix possible race in MapBufferFromClientProcess (block list updates were not locked)
* Write uniform update to memory immediately, only defer the buffer set.
* Fix some memory tracking issues
* Pass correct pages count on shared memory unmap
* Armeilleure Signal Handler v1 + Unix changes
Unix currently behaves like windows, rather than remapping physical
* Actually check if the host platform is unix
* Fix decommit on linux.
* Implement windows 10 placeholder shared memory, fix a buffer issue.
* Make PTC version something that will never match with master
* Remove testing variable for block count
* Add reference count for memory manager, fix dispose
Can still deadlock with OpenAL
* Add address validation, use page table for mapped check, add docs
Might clean up the page table traversing routines.
* Implement batched mapping/tracking.
* Move documentation, fix tests.
* Cleanup uniform buffer update stuff.
* Remove unnecessary assignment.
* Add unsafe host mapped memory switch
On by default. Would be good to turn this off for untrusted code (homebrew, exefs mods) and give the user the option to turn it on manually, though that requires some UI work.
* Remove C# exception handlers
They have issues due to current .NET limitations, so the meilleure one fully replaces them for now.
* Fix MapPhysicalMemory on the software MemoryManager.
* Null check for GetHostAddress, docs
* Add configuration for setting memory manager mode (not in UI yet)
* Add config to UI
* Fix type mismatch on Unix signal handler code emit
* Fix 6GB DRAM mode.
The size can be greater than `uint.MaxValue` when the DRAM is >4GB.
* Address some feedback.
* More detailed error if backing memory cannot be mapped.
* SetLastError on all OS functions for consistency
* Force pages dirty with UBO update instead of setting them directly.
Seems to be much faster across a few games. Need retesting.
* Rebase, configuration rework, fix mem tracking regression
* Fix race in FreePages
* Set memory managers null after decrementing ref count
* Remove readonly keyword, as this is now modified.
* Use a local variable for the signal handler rather than a register.
* Fix bug with buffer resize, and index/uniform buffer binding.
Should fix flickering in games.
* Add InvalidAccessHandler to MemoryTracking
Doesn't do anything yet
* Call invalid access handler on unmapped read/write.
Same rules as the regular memory manager.
* Make unsafe mapped memory its own MemoryManagerType
* Move FlushUboDirty into UpdateState.
* Buffer dirty cache, rather than ubo cache
Much cleaner, may be reusable for Inline2Memory updates.
* This doesn't return anything anymore.
* Add sigaction remove methods, correct a few function signatures.
* Return empty list of physical regions for size 0.
* Also on AddressSpaceManager
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
2021-05-24 20:52:44 +00:00
|
|
|
HidStorage = hidStorage;
|
2019-10-08 03:48:49 +00:00
|
|
|
|
2023-07-16 17:31:14 +00:00
|
|
|
HidSharedMem = new KSharedMemory(KernelContext, hidStorage, 0, 0, KMemoryPermission.Read);
|
POWER - Performance Optimizations With Extensive Ramifications (#2286)
* Refactoring of KMemoryManager class
* Replace some trivial uses of DRAM address with VA
* Get rid of GetDramAddressFromVa
* Abstracting more operations on derived page table class
* Run auto-format on KPageTableBase
* Managed to make TryConvertVaToPa private, few uses remains now
* Implement guest physical pages ref counting, remove manual freeing
* Make DoMmuOperation private and call new abstract methods only from the base class
* Pass pages count rather than size on Map/UnmapMemory
* Change memory managers to take host pointers
* Fix a guest memory leak and simplify KPageTable
* Expose new methods for host range query and mapping
* Some refactoring of MapPagesFromClientProcess to allow proper page ref counting and mapping without KPageLists
* Remove more uses of AddVaRangeToPageList, now only one remains (shared memory page checking)
* Add a SharedMemoryStorage class, will be useful for host mapping
* Sayonara AddVaRangeToPageList, you served us well
* Start to implement host memory mapping (WIP)
* Support memory tracking through host exception handling
* Fix some access violations from HLE service guest memory access and CPU
* Fix memory tracking
* Fix mapping list bugs, including a race and a error adding mapping ranges
* Simple page table for memory tracking
* Simple "volatile" region handle mode
* Update UBOs directly (experimental, rough)
* Fix the overlap check
* Only set non-modified buffers as volatile
* Fix some memory tracking issues
* Fix possible race in MapBufferFromClientProcess (block list updates were not locked)
* Write uniform update to memory immediately, only defer the buffer set.
* Fix some memory tracking issues
* Pass correct pages count on shared memory unmap
* Armeilleure Signal Handler v1 + Unix changes
Unix currently behaves like windows, rather than remapping physical
* Actually check if the host platform is unix
* Fix decommit on linux.
* Implement windows 10 placeholder shared memory, fix a buffer issue.
* Make PTC version something that will never match with master
* Remove testing variable for block count
* Add reference count for memory manager, fix dispose
Can still deadlock with OpenAL
* Add address validation, use page table for mapped check, add docs
Might clean up the page table traversing routines.
* Implement batched mapping/tracking.
* Move documentation, fix tests.
* Cleanup uniform buffer update stuff.
* Remove unnecessary assignment.
* Add unsafe host mapped memory switch
On by default. Would be good to turn this off for untrusted code (homebrew, exefs mods) and give the user the option to turn it on manually, though that requires some UI work.
* Remove C# exception handlers
They have issues due to current .NET limitations, so the meilleure one fully replaces them for now.
* Fix MapPhysicalMemory on the software MemoryManager.
* Null check for GetHostAddress, docs
* Add configuration for setting memory manager mode (not in UI yet)
* Add config to UI
* Fix type mismatch on Unix signal handler code emit
* Fix 6GB DRAM mode.
The size can be greater than `uint.MaxValue` when the DRAM is >4GB.
* Address some feedback.
* More detailed error if backing memory cannot be mapped.
* SetLastError on all OS functions for consistency
* Force pages dirty with UBO update instead of setting them directly.
Seems to be much faster across a few games. Need retesting.
* Rebase, configuration rework, fix mem tracking regression
* Fix race in FreePages
* Set memory managers null after decrementing ref count
* Remove readonly keyword, as this is now modified.
* Use a local variable for the signal handler rather than a register.
* Fix bug with buffer resize, and index/uniform buffer binding.
Should fix flickering in games.
* Add InvalidAccessHandler to MemoryTracking
Doesn't do anything yet
* Call invalid access handler on unmapped read/write.
Same rules as the regular memory manager.
* Make unsafe mapped memory its own MemoryManagerType
* Move FlushUboDirty into UpdateState.
* Buffer dirty cache, rather than ubo cache
Much cleaner, may be reusable for Inline2Memory updates.
* This doesn't return anything anymore.
* Add sigaction remove methods, correct a few function signatures.
* Return empty list of physical regions for size 0.
* Also on AddressSpaceManager
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
2021-05-24 20:52:44 +00:00
|
|
|
FontSharedMem = new KSharedMemory(KernelContext, fontStorage, 0, 0, KMemoryPermission.Read);
|
|
|
|
IirsSharedMem = new KSharedMemory(KernelContext, iirsStorage, 0, 0, KMemoryPermission.Read);
|
2019-10-08 03:48:49 +00:00
|
|
|
|
2023-07-16 17:31:14 +00:00
|
|
|
KSharedMemory timeSharedMemory = new(KernelContext, timeStorage, 0, 0, KMemoryPermission.Read);
|
POWER - Performance Optimizations With Extensive Ramifications (#2286)
* Refactoring of KMemoryManager class
* Replace some trivial uses of DRAM address with VA
* Get rid of GetDramAddressFromVa
* Abstracting more operations on derived page table class
* Run auto-format on KPageTableBase
* Managed to make TryConvertVaToPa private, few uses remains now
* Implement guest physical pages ref counting, remove manual freeing
* Make DoMmuOperation private and call new abstract methods only from the base class
* Pass pages count rather than size on Map/UnmapMemory
* Change memory managers to take host pointers
* Fix a guest memory leak and simplify KPageTable
* Expose new methods for host range query and mapping
* Some refactoring of MapPagesFromClientProcess to allow proper page ref counting and mapping without KPageLists
* Remove more uses of AddVaRangeToPageList, now only one remains (shared memory page checking)
* Add a SharedMemoryStorage class, will be useful for host mapping
* Sayonara AddVaRangeToPageList, you served us well
* Start to implement host memory mapping (WIP)
* Support memory tracking through host exception handling
* Fix some access violations from HLE service guest memory access and CPU
* Fix memory tracking
* Fix mapping list bugs, including a race and a error adding mapping ranges
* Simple page table for memory tracking
* Simple "volatile" region handle mode
* Update UBOs directly (experimental, rough)
* Fix the overlap check
* Only set non-modified buffers as volatile
* Fix some memory tracking issues
* Fix possible race in MapBufferFromClientProcess (block list updates were not locked)
* Write uniform update to memory immediately, only defer the buffer set.
* Fix some memory tracking issues
* Pass correct pages count on shared memory unmap
* Armeilleure Signal Handler v1 + Unix changes
Unix currently behaves like windows, rather than remapping physical
* Actually check if the host platform is unix
* Fix decommit on linux.
* Implement windows 10 placeholder shared memory, fix a buffer issue.
* Make PTC version something that will never match with master
* Remove testing variable for block count
* Add reference count for memory manager, fix dispose
Can still deadlock with OpenAL
* Add address validation, use page table for mapped check, add docs
Might clean up the page table traversing routines.
* Implement batched mapping/tracking.
* Move documentation, fix tests.
* Cleanup uniform buffer update stuff.
* Remove unnecessary assignment.
* Add unsafe host mapped memory switch
On by default. Would be good to turn this off for untrusted code (homebrew, exefs mods) and give the user the option to turn it on manually, though that requires some UI work.
* Remove C# exception handlers
They have issues due to current .NET limitations, so the meilleure one fully replaces them for now.
* Fix MapPhysicalMemory on the software MemoryManager.
* Null check for GetHostAddress, docs
* Add configuration for setting memory manager mode (not in UI yet)
* Add config to UI
* Fix type mismatch on Unix signal handler code emit
* Fix 6GB DRAM mode.
The size can be greater than `uint.MaxValue` when the DRAM is >4GB.
* Address some feedback.
* More detailed error if backing memory cannot be mapped.
* SetLastError on all OS functions for consistency
* Force pages dirty with UBO update instead of setting them directly.
Seems to be much faster across a few games. Need retesting.
* Rebase, configuration rework, fix mem tracking regression
* Fix race in FreePages
* Set memory managers null after decrementing ref count
* Remove readonly keyword, as this is now modified.
* Use a local variable for the signal handler rather than a register.
* Fix bug with buffer resize, and index/uniform buffer binding.
Should fix flickering in games.
* Add InvalidAccessHandler to MemoryTracking
Doesn't do anything yet
* Call invalid access handler on unmapped read/write.
Same rules as the regular memory manager.
* Make unsafe mapped memory its own MemoryManagerType
* Move FlushUboDirty into UpdateState.
* Buffer dirty cache, rather than ubo cache
Much cleaner, may be reusable for Inline2Memory updates.
* This doesn't return anything anymore.
* Add sigaction remove methods, correct a few function signatures.
* Return empty list of physical regions for size 0.
* Also on AddressSpaceManager
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
2021-05-24 20:52:44 +00:00
|
|
|
|
|
|
|
TimeServiceManager.Instance.Initialize(device, this, timeSharedMemory, timeStorage, TimeSize);
|
2018-11-28 22:18:09 +00:00
|
|
|
|
2021-06-28 18:54:45 +00:00
|
|
|
AppletCaptureBufferTransfer = new KTransferMemory(KernelContext, appletCaptureBufferStorage);
|
|
|
|
|
2018-11-28 22:18:09 +00:00
|
|
|
AppletState = new AppletStateMgr(this);
|
|
|
|
|
|
|
|
AppletState.SetFocus(true);
|
|
|
|
|
2020-05-04 03:41:29 +00:00
|
|
|
VsyncEvent = new KEvent(KernelContext);
|
2018-09-08 18:33:27 +00:00
|
|
|
|
2020-05-04 03:41:29 +00:00
|
|
|
DisplayResolutionChangeEvent = new KEvent(KernelContext);
|
2020-04-23 11:59:11 +00:00
|
|
|
|
2021-09-14 23:24:49 +00:00
|
|
|
SharedFontManager = new SharedFontManager(device, fontStorage);
|
2023-07-16 17:31:14 +00:00
|
|
|
AccountManager = device.Configuration.AccountManager;
|
|
|
|
ContentManager = device.Configuration.ContentManager;
|
|
|
|
CaptureManager = new CaptureManager(device);
|
2019-07-14 20:50:11 +00:00
|
|
|
|
2021-08-12 21:56:24 +00:00
|
|
|
LibHacHorizonManager = device.Configuration.LibHacHorizonManager;
|
|
|
|
|
2023-05-07 22:15:58 +00:00
|
|
|
// We hardcode a clock source id to avoid it changing between each start.
|
2019-10-08 03:48:49 +00:00
|
|
|
// TODO: use set:sys (and get external clock source id from settings)
|
2019-07-15 17:52:35 +00:00
|
|
|
// TODO: use "time!standard_steady_clock_rtc_update_interval_minutes" and implement a worker thread to be accurate.
|
2023-07-16 17:31:14 +00:00
|
|
|
UInt128 clockSourceId = new(0x36a0328702ce8bc1, 0x1608eaba02333284);
|
2019-10-08 03:48:49 +00:00
|
|
|
IRtcManager.GetExternalRtcValue(out ulong rtcValue);
|
|
|
|
|
|
|
|
// We assume the rtc is system time.
|
|
|
|
TimeSpanType systemTime = TimeSpanType.FromSeconds((long)rtcValue);
|
|
|
|
|
2020-04-16 23:18:54 +00:00
|
|
|
// Configure and setup internal offset
|
2021-05-16 15:12:14 +00:00
|
|
|
TimeSpanType internalOffset = TimeSpanType.FromSeconds(device.Configuration.SystemTimeOffset);
|
2020-09-22 04:50:40 +00:00
|
|
|
|
2023-07-16 17:31:14 +00:00
|
|
|
TimeSpanType systemTimeOffset = new(systemTime.NanoSeconds + internalOffset.NanoSeconds);
|
2020-04-16 23:18:54 +00:00
|
|
|
|
|
|
|
if (systemTime.IsDaylightSavingTime() && !systemTimeOffset.IsDaylightSavingTime())
|
|
|
|
{
|
|
|
|
internalOffset = internalOffset.AddSeconds(3600L);
|
|
|
|
}
|
|
|
|
else if (!systemTime.IsDaylightSavingTime() && systemTimeOffset.IsDaylightSavingTime())
|
|
|
|
{
|
|
|
|
internalOffset = internalOffset.AddSeconds(-3600L);
|
|
|
|
}
|
|
|
|
|
2023-05-07 22:15:58 +00:00
|
|
|
systemTime = new TimeSpanType(systemTime.NanoSeconds + internalOffset.NanoSeconds);
|
2020-04-16 23:18:54 +00:00
|
|
|
|
2019-10-08 03:48:49 +00:00
|
|
|
// First init the standard steady clock
|
2023-05-07 22:15:58 +00:00
|
|
|
TimeServiceManager.Instance.SetupStandardSteadyClock(TickSource, clockSourceId, TimeSpanType.Zero, TimeSpanType.Zero, TimeSpanType.Zero, false);
|
2022-05-31 19:29:35 +00:00
|
|
|
TimeServiceManager.Instance.SetupStandardLocalSystemClock(TickSource, new SystemClockContext(), systemTime.ToSeconds());
|
2023-05-07 22:15:58 +00:00
|
|
|
TimeServiceManager.Instance.StandardLocalSystemClock.GetClockContext(TickSource, out SystemClockContext localSytemClockContext);
|
2019-07-15 17:52:35 +00:00
|
|
|
|
2019-09-19 00:45:11 +00:00
|
|
|
if (NxSettings.Settings.TryGetValue("time!standard_network_clock_sufficient_accuracy_minutes", out object standardNetworkClockSufficientAccuracyMinutes))
|
2019-07-15 17:52:35 +00:00
|
|
|
{
|
2023-07-16 17:31:14 +00:00
|
|
|
TimeSpanType standardNetworkClockSufficientAccuracy = new((int)standardNetworkClockSufficientAccuracyMinutes * 60000000000);
|
2019-07-15 17:52:35 +00:00
|
|
|
|
2020-05-20 09:35:30 +00:00
|
|
|
// The network system clock needs a valid system clock, as such we setup this system clock using the local system clock.
|
|
|
|
TimeServiceManager.Instance.SetupStandardNetworkSystemClock(localSytemClockContext, standardNetworkClockSufficientAccuracy);
|
2019-07-15 17:52:35 +00:00
|
|
|
}
|
|
|
|
|
2023-05-07 22:15:58 +00:00
|
|
|
TimeServiceManager.Instance.SetupStandardUserSystemClock(TickSource, true, localSytemClockContext.SteadyTimePoint);
|
2019-10-08 03:48:49 +00:00
|
|
|
|
2021-08-12 21:56:24 +00:00
|
|
|
// FIXME: TimeZone should be init here but it's actually done in ContentManager
|
2019-10-08 03:48:49 +00:00
|
|
|
|
|
|
|
TimeServiceManager.Instance.SetupEphemeralNetworkSystemClock();
|
2020-03-01 22:56:02 +00:00
|
|
|
|
2022-05-31 19:29:35 +00:00
|
|
|
DatabaseImpl.Instance.InitializeDatabase(TickSource, LibHacHorizonManager.SdbClient);
|
2020-04-19 01:25:57 +00:00
|
|
|
|
|
|
|
HostSyncpoint = new NvHostSyncpt(device);
|
2020-04-22 04:10:27 +00:00
|
|
|
|
|
|
|
SurfaceFlinger = new SurfaceFlinger(device);
|
2020-04-23 11:59:11 +00:00
|
|
|
|
2022-05-31 19:29:35 +00:00
|
|
|
InitializeAudioRenderer(TickSource);
|
2022-03-22 19:46:16 +00:00
|
|
|
InitializeServices();
|
2020-08-18 01:49:37 +00:00
|
|
|
}
|
|
|
|
|
2022-05-31 19:29:35 +00:00
|
|
|
private void InitializeAudioRenderer(ITickSource tickSource)
|
2020-08-18 01:49:37 +00:00
|
|
|
{
|
2021-02-26 00:11:56 +00:00
|
|
|
AudioManager = new AudioManager();
|
|
|
|
AudioOutputManager = new AudioOutputManager();
|
|
|
|
AudioInputManager = new AudioInputManager();
|
2022-05-31 19:29:35 +00:00
|
|
|
AudioRendererManager = new AudioRendererManager(tickSource);
|
2021-12-23 16:33:56 +00:00
|
|
|
AudioRendererManager.SetVolume(Device.Configuration.AudioVolume);
|
2023-05-13 07:15:16 +00:00
|
|
|
AudioDeviceSessionRegistry = new VirtualDeviceSessionRegistry(Device.AudioDeviceDriver);
|
2020-08-18 01:49:37 +00:00
|
|
|
|
2021-02-26 00:11:56 +00:00
|
|
|
IWritableEvent[] audioOutputRegisterBufferEvents = new IWritableEvent[Constants.AudioOutSessionCountMax];
|
2020-08-18 01:49:37 +00:00
|
|
|
|
2021-02-26 00:11:56 +00:00
|
|
|
for (int i = 0; i < audioOutputRegisterBufferEvents.Length; i++)
|
2020-08-18 01:49:37 +00:00
|
|
|
{
|
2023-07-16 17:31:14 +00:00
|
|
|
KEvent registerBufferEvent = new(KernelContext);
|
2020-08-18 01:49:37 +00:00
|
|
|
|
2021-02-26 00:11:56 +00:00
|
|
|
audioOutputRegisterBufferEvents[i] = new AudioKernelEvent(registerBufferEvent);
|
2020-08-18 01:49:37 +00:00
|
|
|
}
|
|
|
|
|
2021-02-26 00:11:56 +00:00
|
|
|
AudioOutputManager.Initialize(Device.AudioDeviceDriver, audioOutputRegisterBufferEvents);
|
2021-12-23 16:33:56 +00:00
|
|
|
AudioOutputManager.SetVolume(Device.Configuration.AudioVolume);
|
2021-02-26 00:11:56 +00:00
|
|
|
|
|
|
|
IWritableEvent[] audioInputRegisterBufferEvents = new IWritableEvent[Constants.AudioInSessionCountMax];
|
2020-08-18 01:49:37 +00:00
|
|
|
|
2021-02-26 00:11:56 +00:00
|
|
|
for (int i = 0; i < audioInputRegisterBufferEvents.Length; i++)
|
2020-08-18 01:49:37 +00:00
|
|
|
{
|
2023-07-16 17:31:14 +00:00
|
|
|
KEvent registerBufferEvent = new(KernelContext);
|
2021-02-26 00:11:56 +00:00
|
|
|
|
|
|
|
audioInputRegisterBufferEvents[i] = new AudioKernelEvent(registerBufferEvent);
|
2020-08-18 01:49:37 +00:00
|
|
|
}
|
|
|
|
|
2021-02-26 00:11:56 +00:00
|
|
|
AudioInputManager.Initialize(Device.AudioDeviceDriver, audioInputRegisterBufferEvents);
|
|
|
|
|
|
|
|
IWritableEvent[] systemEvents = new IWritableEvent[Constants.AudioRendererSessionCountMax];
|
|
|
|
|
|
|
|
for (int i = 0; i < systemEvents.Length; i++)
|
|
|
|
{
|
2023-07-16 17:31:14 +00:00
|
|
|
KEvent systemEvent = new(KernelContext);
|
2021-02-26 00:11:56 +00:00
|
|
|
|
|
|
|
systemEvents[i] = new AudioKernelEvent(systemEvent);
|
|
|
|
}
|
|
|
|
|
|
|
|
AudioManager.Initialize(Device.AudioDeviceDriver.GetUpdateRequiredEvent(), AudioOutputManager.Update, AudioInputManager.Update);
|
|
|
|
|
|
|
|
AudioRendererManager.Initialize(systemEvents, Device.AudioDeviceDriver);
|
|
|
|
|
|
|
|
AudioManager.Start();
|
2020-04-30 04:58:19 +00:00
|
|
|
}
|
|
|
|
|
2022-03-22 19:46:16 +00:00
|
|
|
private void InitializeServices()
|
2020-12-01 23:23:43 +00:00
|
|
|
{
|
2022-05-05 18:23:30 +00:00
|
|
|
SmRegistry = new SmRegistry();
|
|
|
|
SmServer = new ServerBase(KernelContext, "SmServer", () => new IUserInterface(KernelContext, SmRegistry));
|
2020-12-01 23:23:43 +00:00
|
|
|
|
|
|
|
// Wait until SM server thread is done with initialization,
|
|
|
|
// only then doing connections to SM is safe.
|
2021-06-29 17:37:13 +00:00
|
|
|
SmServer.InitDone.WaitOne();
|
2020-12-02 12:14:44 +00:00
|
|
|
|
2022-06-12 07:29:12 +00:00
|
|
|
BsdServer = new ServerBase(KernelContext, "BsdServer");
|
2020-12-02 12:14:44 +00:00
|
|
|
AudRenServer = new ServerBase(KernelContext, "AudioRendererServer");
|
|
|
|
AudOutServer = new ServerBase(KernelContext, "AudioOutServer");
|
2022-02-19 14:29:11 +00:00
|
|
|
FsServer = new ServerBase(KernelContext, "FsServer");
|
2020-12-02 12:14:44 +00:00
|
|
|
HidServer = new ServerBase(KernelContext, "HidServer");
|
|
|
|
NvDrvServer = new ServerBase(KernelContext, "NvservicesServer");
|
|
|
|
TimeServer = new ServerBase(KernelContext, "TimeServer");
|
|
|
|
ViServer = new ServerBase(KernelContext, "ViServerU");
|
|
|
|
ViServerM = new ServerBase(KernelContext, "ViServerM");
|
|
|
|
ViServerS = new ServerBase(KernelContext, "ViServerS");
|
Add ldn:u implementation, INetworkClient interface and DisabledLdnClient (#5652)
* Impl first attempt to LDN
* Make this work.
- Endianness swap on all IPs.
- Use local network IP for connections, rather than 127.0.0.1. This is to be changed when tunnelling or whatever.
- Mac addresses are now randomly assigned on the server. (fixes joining lobbies)
- Fixed the "connected" handler for stations to actually find a
- Added info retrieval when connected to a station.
- Users that disconnect are now removed from rooms they were in. (still need to broadcast tho)
- The communication service does a bit better with being closed now.
- Some locking around the game instance dictionary.
* We may just be "initialized". Ignore this for now.
* Lots of WIP
* Add Disconnect packet
* Improve signalling of internal events.
* Fix scan.
* Fix some more stupid things.
* Enable NoDelay on all sockets.
* Add station accept policy, disconnect function.
* Limit max number of games.
* Split out networking stuff from HLE, so it can be swapped.
* Update logging calls.
* Missed a spot.
* Call SignalDisconnect instead of SetState
* Add comment to GetNetworkInfo
* Update configuration + UI
Now has its own tab, more options.
* Refactoring IUserLocalCommunicationService
( Expected new issues :'( )
* some cleanup
* More fix
* Correctly handle errors when connecting.
* Disable *Private call and clean symbols
* Structs cleanup
* Big cleanup
* Fix InvalidHandle (in MK8D and other games)
* Add Reject and Private Network support (v1)
RyuLdn Version bumped to 1.
* Add Initialize Packet
Allows users to keep Mac Addresses assigned by the server.
* Add SetWirelessControllerRestriction and some cleanup
* LDN-2 Initial Rebase
Make this work.
- Endianness swap on all IPs.
- Use local network IP for connections, rather than 127.0.0.1. This is to be changed when tunnelling or whatever.
- Fixed the "connected" handler for stations to actually find a
- The communication service does a bit better with being closed now.
- Some locking around the game instance dictionary.
We may just be "initialized". Ignore this for now.
Lots of WIP
Implement scan filter.
Improve signalling of internal events.
Fix scan.
Fix 0 width data, scan reply end delay removed.
Fix some more stupid things.
Enable NoDelay on all sockets.
Add station accept policy, disconnect function.
Limit max number of games.
Split out networking stuff from HLE, so it can be swapped.
Update logging calls.
Missed a spot.
SetAdvertiseData when open, don't return games that have accept policy 1
Update configuration + UI
Now has its own tab, more options.
Don't Keepalive, it causes problems.
Refactoring IUserLocalCommunicationService
( Expected new issues :'( )
some cleanup
More fix
Correctly handle errors when connecting.
Disable *Private call and clean symbols
Structs cleanup
Big cleanup
Fix InvalidHandle (in MK8D and other games)
Add Reject and Private Network support (v1)
Disable TcpNoDelay option on linux.
Add SetWirelessControllerRestriction and some cleanup
Misc cleanup, implement broadcast flag.
* Misc Changes
* Fix GetNetworkInfo
* Fix some small issues
* Implement GetNetworkInfoLatestUpdate
* Hotfix when LocalCommunicationId = 0xFFFFFFFFFFFFFFFF
* Fix ARMS Scan (and other games using wrong LocalCommunicationId
* Fix latest update when host leaves
* Revert "Fix ARMS Scan (and other games using wrong LocalCommunicationId"
This reverts commit 519c283d3993e2fdfafb8ac6b4e0a98231f6fb75.
* Fix the localCommunicationId = -1
* Don't set Connect flag for nodes already in the room before joining.
* Make IUserLocalCommunicationService disposable
* Don't dispose if there's no client.
* LDN-2-2 Rebase
Make this work.
- Endianness swap on all IPs.
- Use local network IP for connections, rather than 127.0.0.1. This is to be changed when tunnelling or whatever.
- Fixed the "connected" handler for stations to actually find a
- The communication service does a bit better with being closed now.
- Some locking around the game instance dictionary.
We may just be "initialized". Ignore this for now.
Put sockets behind an interface, so that they can be swapped for something proxyable
Lots of WIP
Implement scan filter.
Improve signalling of internal events.
Fix scan.
Fix 0 width data, scan reply end delay removed.
Fix some more stupid things.
Enable NoDelay on all sockets.
Add station accept policy, disconnect function.
Limit max number of games.
Split out networking stuff from HLE, so it can be swapped.
Update logging calls.
Missed a spot.
SetAdvertiseData when open, don't return games that have accept policy 1
Update configuration + UI
Now has its own tab, more options.
Don't Keepalive, it causes problems.
Refactoring IUserLocalCommunicationService
( Expected new issues :'( )
some cleanup
More fix
Correctly handle errors when connecting.
Disable *Private call and clean symbols
Structs cleanup
Big cleanup
Fix InvalidHandle (in MK8D and other games)
Add Reject and Private Network support (v1)
Disable TcpNoDelay option on linux.
Add SetWirelessControllerRestriction and some cleanup
Misc cleanup, implement broadcast flag.
Misc Changes
Fix GetNetworkInfo
Fix some small issues
Disable LAN by default til the config is added.
Fix Splatoon 2
- Stub nfp IUser::StartDetection / IUser::StopDetection.
- Stub ntc IEnsureNetworkClockAvailabilityService and needed calls.
Cleanup previous fixes
Stub IAudioInManager/IAudioIn for Splatoon 2 LAN
Add LAN settings to multiplayer tab
LAN Play > LAN Mode
Implement GetNetworkInfoLatestUpdate
Hotfix when LocalCommunicationId = 0xFFFFFFFFFFFFFFFF
Fix ARMS Scan (and other games using wrong LocalCommunicationId
Fix latest update when host leaves
Revert "Fix ARMS Scan (and other games using wrong LocalCommunicationId"
This reverts commit 519c283d3993e2fdfafb8ac6b4e0a98231f6fb75.
Fix the localCommunicationId = -1
Don't set Connect flag for nodes already in the room before joining.
Make IUserLocalCommunicationService disposable
Fix crash when using LAN mode on linux.
Actually use that call
Don't dispose if there's no client.
Fix the settings window crash
Fix configurationFileUpdated
* Make LDN compatible with Ryujinx/Ryujinx#3805
* Ava: Add Ldn options to SettingsNetworkTab
* Ava: Add update events for multiplayer options
* Apply formatting
* Remove LdnHelper
* ldn: Fix hardcoded /24 subnet mask
* Fix naming rule violations
* Add missing summary doc tag
* Remove NetCoreServer dependency
* Address code style issues and typos
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
* Call CloseStation/CloseAccessPoint to reduce code duplication
* Fix typo
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
* Fix missing trailing commas
* Extract AddressList from AddressEntry
* Use AcceptPolicy as a type for LdnNetworkInfo.StationAcceptPolicy
* Add Flags attribute to ScanFilterFlag
* Rename struct members for LdnNetworkInfo
* Remove extra line
Co-authored-by: Ac_K <Acoustik666@gmail.com>
* Extract NetworkErrorMessage from NetworkError
* Fix missing trailing commas
---------
Co-authored-by: Ac_K <Acoustik666@gmail.com>
Co-authored-by: riperiperi <rhy3756547@hotmail.com>
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
2023-09-25 21:50:43 +00:00
|
|
|
LdnServer = new ServerBase(KernelContext, "LdnServer");
|
2023-01-04 22:15:45 +00:00
|
|
|
|
|
|
|
StartNewServices();
|
|
|
|
}
|
|
|
|
|
|
|
|
private void StartNewServices()
|
|
|
|
{
|
2023-09-27 17:21:26 +00:00
|
|
|
HorizonFsClient fsClient = new(this);
|
|
|
|
|
2023-01-08 12:13:39 +00:00
|
|
|
ServiceTable = new ServiceTable();
|
2023-09-27 17:21:26 +00:00
|
|
|
var services = ServiceTable.GetServices(new HorizonOptions(Device.Configuration.IgnoreMissingServices, LibHacHorizonManager.BcatClient, fsClient));
|
2023-01-04 22:15:45 +00:00
|
|
|
|
|
|
|
foreach (var service in services)
|
|
|
|
{
|
2023-06-27 23:18:19 +00:00
|
|
|
const ProcessCreationFlags Flags =
|
2023-01-04 22:15:45 +00:00
|
|
|
ProcessCreationFlags.EnableAslr |
|
|
|
|
ProcessCreationFlags.AddressSpace64Bit |
|
|
|
|
ProcessCreationFlags.Is64Bit |
|
|
|
|
ProcessCreationFlags.PoolPartitionSystem;
|
|
|
|
|
2023-07-16 17:31:14 +00:00
|
|
|
ProcessCreationInfo creationInfo = new("Service", 1, 0, 0x8000000, 1, Flags, 0, 0);
|
2023-01-04 22:15:45 +00:00
|
|
|
|
2023-07-16 17:31:14 +00:00
|
|
|
uint[] defaultCapabilities = {
|
2023-01-04 22:15:45 +00:00
|
|
|
0x030363F7,
|
|
|
|
0x1FFFFFCF,
|
|
|
|
0x207FFFEF,
|
|
|
|
0x47E0060F,
|
|
|
|
0x0048BFFF,
|
2023-07-16 17:31:14 +00:00
|
|
|
0x01007FFF,
|
2023-01-04 22:15:45 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// TODO:
|
|
|
|
// - Pass enough information (capabilities, process creation info, etc) on ServiceEntry for proper initialization.
|
|
|
|
// - Have the ThreadStart function take the syscall, address space and thread context parameters instead of passing them here.
|
|
|
|
KernelStatic.StartInitialProcess(KernelContext, creationInfo, defaultCapabilities, 44, () =>
|
|
|
|
{
|
|
|
|
service.Start(KernelContext.Syscall, KernelStatic.GetCurrentProcess().CpuMemory, KernelStatic.GetCurrentThread().ThreadContext);
|
|
|
|
});
|
|
|
|
}
|
2020-12-01 23:23:43 +00:00
|
|
|
}
|
|
|
|
|
2023-03-31 19:16:46 +00:00
|
|
|
public bool LoadKip(string kipPath)
|
2020-05-15 06:16:46 +00:00
|
|
|
{
|
2021-12-23 16:55:50 +00:00
|
|
|
using var kipFile = new SharedRef<IStorage>(new LocalStorage(kipPath, FileAccess.Read));
|
2020-05-15 06:16:46 +00:00
|
|
|
|
2023-03-31 19:16:46 +00:00
|
|
|
return ProcessLoaderHelper.LoadKip(KernelContext, new KipExecutable(in kipFile));
|
2020-05-15 06:16:46 +00:00
|
|
|
}
|
|
|
|
|
2021-05-16 15:12:14 +00:00
|
|
|
public void ChangeDockedModeState(bool newState)
|
2020-04-23 11:59:11 +00:00
|
|
|
{
|
2021-05-16 15:12:14 +00:00
|
|
|
if (newState != State.DockedMode)
|
2020-04-23 11:59:11 +00:00
|
|
|
{
|
2021-05-16 15:12:14 +00:00
|
|
|
State.DockedMode = newState;
|
2020-11-12 05:59:18 +00:00
|
|
|
PerformanceState.PerformanceMode = State.DockedMode ? PerformanceMode.Boost : PerformanceMode.Default;
|
2020-04-23 11:59:11 +00:00
|
|
|
|
2021-06-21 16:41:37 +00:00
|
|
|
AppletState.Messages.Enqueue(AppletMessage.OperationModeChanged);
|
|
|
|
AppletState.Messages.Enqueue(AppletMessage.PerformanceModeChanged);
|
2020-12-16 00:41:42 +00:00
|
|
|
AppletState.MessageEvent.ReadableEvent.Signal();
|
|
|
|
|
2020-04-23 11:59:11 +00:00
|
|
|
SignalDisplayResolutionChange();
|
2020-08-23 20:54:11 +00:00
|
|
|
|
2021-05-16 15:12:14 +00:00
|
|
|
Device.Configuration.RefreshInputConfig?.Invoke();
|
2020-04-23 11:59:11 +00:00
|
|
|
}
|
2018-02-04 23:08:20 +00:00
|
|
|
}
|
|
|
|
|
2021-12-23 16:33:56 +00:00
|
|
|
public void SetVolume(float volume)
|
|
|
|
{
|
|
|
|
AudioOutputManager.SetVolume(volume);
|
|
|
|
AudioRendererManager.SetVolume(volume);
|
|
|
|
}
|
|
|
|
|
|
|
|
public float GetVolume()
|
|
|
|
{
|
|
|
|
return AudioOutputManager.GetVolume() == 0 ? AudioRendererManager.GetVolume() : AudioOutputManager.GetVolume();
|
|
|
|
}
|
|
|
|
|
2021-04-17 16:57:03 +00:00
|
|
|
public void ReturnFocus()
|
|
|
|
{
|
|
|
|
AppletState.SetFocus(true);
|
|
|
|
}
|
|
|
|
|
2020-12-16 00:41:42 +00:00
|
|
|
public void SimulateWakeUpMessage()
|
|
|
|
{
|
2021-06-21 16:41:37 +00:00
|
|
|
AppletState.Messages.Enqueue(AppletMessage.Resume);
|
2020-12-16 00:41:42 +00:00
|
|
|
AppletState.MessageEvent.ReadableEvent.Signal();
|
|
|
|
}
|
|
|
|
|
2021-03-18 20:40:20 +00:00
|
|
|
public void ScanAmiibo(int nfpDeviceId, string amiiboId, bool useRandomUuid)
|
|
|
|
{
|
|
|
|
if (NfpDevices[nfpDeviceId].State == NfpDeviceState.SearchingForTag)
|
|
|
|
{
|
2021-08-12 21:56:24 +00:00
|
|
|
NfpDevices[nfpDeviceId].State = NfpDeviceState.TagFound;
|
|
|
|
NfpDevices[nfpDeviceId].AmiiboId = amiiboId;
|
2021-03-18 20:40:20 +00:00
|
|
|
NfpDevices[nfpDeviceId].UseRandomUuid = useRandomUuid;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public bool SearchingForAmiibo(out int nfpDeviceId)
|
|
|
|
{
|
|
|
|
nfpDeviceId = default;
|
|
|
|
|
|
|
|
for (int i = 0; i < NfpDevices.Count; i++)
|
|
|
|
{
|
|
|
|
if (NfpDevices[i].State == NfpDeviceState.SearchingForTag)
|
|
|
|
{
|
|
|
|
nfpDeviceId = i;
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2020-04-23 11:59:11 +00:00
|
|
|
public void SignalDisplayResolutionChange()
|
|
|
|
{
|
|
|
|
DisplayResolutionChangeEvent.ReadableEvent.Signal();
|
|
|
|
}
|
|
|
|
|
2018-09-18 23:36:43 +00:00
|
|
|
public void SignalVsync()
|
|
|
|
{
|
2018-09-23 18:11:46 +00:00
|
|
|
VsyncEvent.ReadableEvent.Signal();
|
2018-09-18 23:36:43 +00:00
|
|
|
}
|
2018-03-19 18:58:46 +00:00
|
|
|
|
2018-03-12 04:04:52 +00:00
|
|
|
public void Dispose()
|
2018-02-04 23:08:20 +00:00
|
|
|
{
|
2023-07-16 17:31:14 +00:00
|
|
|
GC.SuppressFinalize(this);
|
2018-03-12 04:04:52 +00:00
|
|
|
Dispose(true);
|
|
|
|
}
|
2018-02-04 23:08:20 +00:00
|
|
|
|
2018-12-06 11:16:24 +00:00
|
|
|
protected virtual void Dispose(bool disposing)
|
2018-03-12 04:04:52 +00:00
|
|
|
{
|
2020-02-06 11:38:24 +00:00
|
|
|
if (!_isDisposed && disposing)
|
2018-02-04 23:08:20 +00:00
|
|
|
{
|
2020-02-06 11:38:24 +00:00
|
|
|
_isDisposed = true;
|
|
|
|
|
2021-09-11 20:08:25 +00:00
|
|
|
// "Soft" stops AudioRenderer and AudioManager to avoid some sound between resume and stop.
|
2021-09-18 12:31:44 +00:00
|
|
|
if (IsPaused)
|
|
|
|
{
|
|
|
|
AudioManager.StopUpdates();
|
|
|
|
|
|
|
|
TogglePauseEmulation(false);
|
2021-09-11 20:08:25 +00:00
|
|
|
|
2021-09-18 12:31:44 +00:00
|
|
|
AudioRendererManager.StopSendingCommands();
|
|
|
|
}
|
2021-09-11 20:08:25 +00:00
|
|
|
|
2023-07-16 17:31:14 +00:00
|
|
|
KProcess terminationProcess = new(KernelContext);
|
|
|
|
KThread terminationThread = new(KernelContext);
|
2019-12-26 01:50:17 +00:00
|
|
|
|
|
|
|
terminationThread.Initialize(0, 0, 0, 3, 0, terminationProcess, ThreadType.Kernel, () =>
|
2018-03-12 04:04:52 +00:00
|
|
|
{
|
2019-12-26 01:50:17 +00:00
|
|
|
// Force all threads to exit.
|
2020-05-04 03:41:29 +00:00
|
|
|
lock (KernelContext.Processes)
|
2018-11-28 22:18:09 +00:00
|
|
|
{
|
2020-12-17 00:44:06 +00:00
|
|
|
// Terminate application.
|
2021-12-04 23:23:26 +00:00
|
|
|
foreach (KProcess process in KernelContext.Processes.Values.Where(x => x.IsApplication))
|
2020-12-17 00:44:06 +00:00
|
|
|
{
|
|
|
|
process.Terminate();
|
POWER - Performance Optimizations With Extensive Ramifications (#2286)
* Refactoring of KMemoryManager class
* Replace some trivial uses of DRAM address with VA
* Get rid of GetDramAddressFromVa
* Abstracting more operations on derived page table class
* Run auto-format on KPageTableBase
* Managed to make TryConvertVaToPa private, few uses remains now
* Implement guest physical pages ref counting, remove manual freeing
* Make DoMmuOperation private and call new abstract methods only from the base class
* Pass pages count rather than size on Map/UnmapMemory
* Change memory managers to take host pointers
* Fix a guest memory leak and simplify KPageTable
* Expose new methods for host range query and mapping
* Some refactoring of MapPagesFromClientProcess to allow proper page ref counting and mapping without KPageLists
* Remove more uses of AddVaRangeToPageList, now only one remains (shared memory page checking)
* Add a SharedMemoryStorage class, will be useful for host mapping
* Sayonara AddVaRangeToPageList, you served us well
* Start to implement host memory mapping (WIP)
* Support memory tracking through host exception handling
* Fix some access violations from HLE service guest memory access and CPU
* Fix memory tracking
* Fix mapping list bugs, including a race and a error adding mapping ranges
* Simple page table for memory tracking
* Simple "volatile" region handle mode
* Update UBOs directly (experimental, rough)
* Fix the overlap check
* Only set non-modified buffers as volatile
* Fix some memory tracking issues
* Fix possible race in MapBufferFromClientProcess (block list updates were not locked)
* Write uniform update to memory immediately, only defer the buffer set.
* Fix some memory tracking issues
* Pass correct pages count on shared memory unmap
* Armeilleure Signal Handler v1 + Unix changes
Unix currently behaves like windows, rather than remapping physical
* Actually check if the host platform is unix
* Fix decommit on linux.
* Implement windows 10 placeholder shared memory, fix a buffer issue.
* Make PTC version something that will never match with master
* Remove testing variable for block count
* Add reference count for memory manager, fix dispose
Can still deadlock with OpenAL
* Add address validation, use page table for mapped check, add docs
Might clean up the page table traversing routines.
* Implement batched mapping/tracking.
* Move documentation, fix tests.
* Cleanup uniform buffer update stuff.
* Remove unnecessary assignment.
* Add unsafe host mapped memory switch
On by default. Would be good to turn this off for untrusted code (homebrew, exefs mods) and give the user the option to turn it on manually, though that requires some UI work.
* Remove C# exception handlers
They have issues due to current .NET limitations, so the meilleure one fully replaces them for now.
* Fix MapPhysicalMemory on the software MemoryManager.
* Null check for GetHostAddress, docs
* Add configuration for setting memory manager mode (not in UI yet)
* Add config to UI
* Fix type mismatch on Unix signal handler code emit
* Fix 6GB DRAM mode.
The size can be greater than `uint.MaxValue` when the DRAM is >4GB.
* Address some feedback.
* More detailed error if backing memory cannot be mapped.
* SetLastError on all OS functions for consistency
* Force pages dirty with UBO update instead of setting them directly.
Seems to be much faster across a few games. Need retesting.
* Rebase, configuration rework, fix mem tracking regression
* Fix race in FreePages
* Set memory managers null after decrementing ref count
* Remove readonly keyword, as this is now modified.
* Use a local variable for the signal handler rather than a register.
* Fix bug with buffer resize, and index/uniform buffer binding.
Should fix flickering in games.
* Add InvalidAccessHandler to MemoryTracking
Doesn't do anything yet
* Call invalid access handler on unmapped read/write.
Same rules as the regular memory manager.
* Make unsafe mapped memory its own MemoryManagerType
* Move FlushUboDirty into UpdateState.
* Buffer dirty cache, rather than ubo cache
Much cleaner, may be reusable for Inline2Memory updates.
* This doesn't return anything anymore.
* Add sigaction remove methods, correct a few function signatures.
* Return empty list of physical regions for size 0.
* Also on AddressSpaceManager
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
2021-05-24 20:52:44 +00:00
|
|
|
process.DecrementReferenceCount();
|
2020-12-17 00:44:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// The application existed, now surface flinger can exit too.
|
|
|
|
SurfaceFlinger.Dispose();
|
|
|
|
|
|
|
|
// Terminate HLE services (must be done after the application is already terminated,
|
2021-06-29 17:37:13 +00:00
|
|
|
// otherwise the application will receive errors due to service termination).
|
2021-12-04 23:23:26 +00:00
|
|
|
foreach (KProcess process in KernelContext.Processes.Values.Where(x => !x.IsApplication))
|
2019-12-26 01:50:17 +00:00
|
|
|
{
|
|
|
|
process.Terminate();
|
POWER - Performance Optimizations With Extensive Ramifications (#2286)
* Refactoring of KMemoryManager class
* Replace some trivial uses of DRAM address with VA
* Get rid of GetDramAddressFromVa
* Abstracting more operations on derived page table class
* Run auto-format on KPageTableBase
* Managed to make TryConvertVaToPa private, few uses remains now
* Implement guest physical pages ref counting, remove manual freeing
* Make DoMmuOperation private and call new abstract methods only from the base class
* Pass pages count rather than size on Map/UnmapMemory
* Change memory managers to take host pointers
* Fix a guest memory leak and simplify KPageTable
* Expose new methods for host range query and mapping
* Some refactoring of MapPagesFromClientProcess to allow proper page ref counting and mapping without KPageLists
* Remove more uses of AddVaRangeToPageList, now only one remains (shared memory page checking)
* Add a SharedMemoryStorage class, will be useful for host mapping
* Sayonara AddVaRangeToPageList, you served us well
* Start to implement host memory mapping (WIP)
* Support memory tracking through host exception handling
* Fix some access violations from HLE service guest memory access and CPU
* Fix memory tracking
* Fix mapping list bugs, including a race and a error adding mapping ranges
* Simple page table for memory tracking
* Simple "volatile" region handle mode
* Update UBOs directly (experimental, rough)
* Fix the overlap check
* Only set non-modified buffers as volatile
* Fix some memory tracking issues
* Fix possible race in MapBufferFromClientProcess (block list updates were not locked)
* Write uniform update to memory immediately, only defer the buffer set.
* Fix some memory tracking issues
* Pass correct pages count on shared memory unmap
* Armeilleure Signal Handler v1 + Unix changes
Unix currently behaves like windows, rather than remapping physical
* Actually check if the host platform is unix
* Fix decommit on linux.
* Implement windows 10 placeholder shared memory, fix a buffer issue.
* Make PTC version something that will never match with master
* Remove testing variable for block count
* Add reference count for memory manager, fix dispose
Can still deadlock with OpenAL
* Add address validation, use page table for mapped check, add docs
Might clean up the page table traversing routines.
* Implement batched mapping/tracking.
* Move documentation, fix tests.
* Cleanup uniform buffer update stuff.
* Remove unnecessary assignment.
* Add unsafe host mapped memory switch
On by default. Would be good to turn this off for untrusted code (homebrew, exefs mods) and give the user the option to turn it on manually, though that requires some UI work.
* Remove C# exception handlers
They have issues due to current .NET limitations, so the meilleure one fully replaces them for now.
* Fix MapPhysicalMemory on the software MemoryManager.
* Null check for GetHostAddress, docs
* Add configuration for setting memory manager mode (not in UI yet)
* Add config to UI
* Fix type mismatch on Unix signal handler code emit
* Fix 6GB DRAM mode.
The size can be greater than `uint.MaxValue` when the DRAM is >4GB.
* Address some feedback.
* More detailed error if backing memory cannot be mapped.
* SetLastError on all OS functions for consistency
* Force pages dirty with UBO update instead of setting them directly.
Seems to be much faster across a few games. Need retesting.
* Rebase, configuration rework, fix mem tracking regression
* Fix race in FreePages
* Set memory managers null after decrementing ref count
* Remove readonly keyword, as this is now modified.
* Use a local variable for the signal handler rather than a register.
* Fix bug with buffer resize, and index/uniform buffer binding.
Should fix flickering in games.
* Add InvalidAccessHandler to MemoryTracking
Doesn't do anything yet
* Call invalid access handler on unmapped read/write.
Same rules as the regular memory manager.
* Make unsafe mapped memory its own MemoryManagerType
* Move FlushUboDirty into UpdateState.
* Buffer dirty cache, rather than ubo cache
Much cleaner, may be reusable for Inline2Memory updates.
* This doesn't return anything anymore.
* Add sigaction remove methods, correct a few function signatures.
* Return empty list of physical regions for size 0.
* Also on AddressSpaceManager
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
2021-05-24 20:52:44 +00:00
|
|
|
process.DecrementReferenceCount();
|
2019-12-26 01:50:17 +00:00
|
|
|
}
|
POWER - Performance Optimizations With Extensive Ramifications (#2286)
* Refactoring of KMemoryManager class
* Replace some trivial uses of DRAM address with VA
* Get rid of GetDramAddressFromVa
* Abstracting more operations on derived page table class
* Run auto-format on KPageTableBase
* Managed to make TryConvertVaToPa private, few uses remains now
* Implement guest physical pages ref counting, remove manual freeing
* Make DoMmuOperation private and call new abstract methods only from the base class
* Pass pages count rather than size on Map/UnmapMemory
* Change memory managers to take host pointers
* Fix a guest memory leak and simplify KPageTable
* Expose new methods for host range query and mapping
* Some refactoring of MapPagesFromClientProcess to allow proper page ref counting and mapping without KPageLists
* Remove more uses of AddVaRangeToPageList, now only one remains (shared memory page checking)
* Add a SharedMemoryStorage class, will be useful for host mapping
* Sayonara AddVaRangeToPageList, you served us well
* Start to implement host memory mapping (WIP)
* Support memory tracking through host exception handling
* Fix some access violations from HLE service guest memory access and CPU
* Fix memory tracking
* Fix mapping list bugs, including a race and a error adding mapping ranges
* Simple page table for memory tracking
* Simple "volatile" region handle mode
* Update UBOs directly (experimental, rough)
* Fix the overlap check
* Only set non-modified buffers as volatile
* Fix some memory tracking issues
* Fix possible race in MapBufferFromClientProcess (block list updates were not locked)
* Write uniform update to memory immediately, only defer the buffer set.
* Fix some memory tracking issues
* Pass correct pages count on shared memory unmap
* Armeilleure Signal Handler v1 + Unix changes
Unix currently behaves like windows, rather than remapping physical
* Actually check if the host platform is unix
* Fix decommit on linux.
* Implement windows 10 placeholder shared memory, fix a buffer issue.
* Make PTC version something that will never match with master
* Remove testing variable for block count
* Add reference count for memory manager, fix dispose
Can still deadlock with OpenAL
* Add address validation, use page table for mapped check, add docs
Might clean up the page table traversing routines.
* Implement batched mapping/tracking.
* Move documentation, fix tests.
* Cleanup uniform buffer update stuff.
* Remove unnecessary assignment.
* Add unsafe host mapped memory switch
On by default. Would be good to turn this off for untrusted code (homebrew, exefs mods) and give the user the option to turn it on manually, though that requires some UI work.
* Remove C# exception handlers
They have issues due to current .NET limitations, so the meilleure one fully replaces them for now.
* Fix MapPhysicalMemory on the software MemoryManager.
* Null check for GetHostAddress, docs
* Add configuration for setting memory manager mode (not in UI yet)
* Add config to UI
* Fix type mismatch on Unix signal handler code emit
* Fix 6GB DRAM mode.
The size can be greater than `uint.MaxValue` when the DRAM is >4GB.
* Address some feedback.
* More detailed error if backing memory cannot be mapped.
* SetLastError on all OS functions for consistency
* Force pages dirty with UBO update instead of setting them directly.
Seems to be much faster across a few games. Need retesting.
* Rebase, configuration rework, fix mem tracking regression
* Fix race in FreePages
* Set memory managers null after decrementing ref count
* Remove readonly keyword, as this is now modified.
* Use a local variable for the signal handler rather than a register.
* Fix bug with buffer resize, and index/uniform buffer binding.
Should fix flickering in games.
* Add InvalidAccessHandler to MemoryTracking
Doesn't do anything yet
* Call invalid access handler on unmapped read/write.
Same rules as the regular memory manager.
* Make unsafe mapped memory its own MemoryManagerType
* Move FlushUboDirty into UpdateState.
* Buffer dirty cache, rather than ubo cache
Much cleaner, may be reusable for Inline2Memory updates.
* This doesn't return anything anymore.
* Add sigaction remove methods, correct a few function signatures.
* Return empty list of physical regions for size 0.
* Also on AddressSpaceManager
Co-authored-by: gdkchan <gab.dark.100@gmail.com>
2021-05-24 20:52:44 +00:00
|
|
|
|
|
|
|
KernelContext.Processes.Clear();
|
2018-11-28 22:18:09 +00:00
|
|
|
}
|
2019-12-29 22:37:54 +00:00
|
|
|
|
|
|
|
// Exit ourself now!
|
2020-12-09 22:20:05 +00:00
|
|
|
KernelStatic.GetCurrentThread().Exit();
|
2019-12-26 01:50:17 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
terminationThread.Start();
|
|
|
|
|
2020-09-22 04:50:40 +00:00
|
|
|
// Wait until the thread is actually started.
|
|
|
|
while (terminationThread.HostThread.ThreadState == ThreadState.Unstarted)
|
|
|
|
{
|
|
|
|
Thread.Sleep(10);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Wait until the termination thread is done terminating all the other threads.
|
|
|
|
terminationThread.HostThread.Join();
|
|
|
|
|
2020-04-19 01:25:57 +00:00
|
|
|
// Destroy nvservices channels as KThread could be waiting on some user events.
|
|
|
|
// This is safe as KThread that are likely to call ioctls are going to be terminated by the post handler hook on the SVC facade.
|
|
|
|
INvDrvServices.Destroy();
|
|
|
|
|
2021-02-26 00:11:56 +00:00
|
|
|
AudioManager.Dispose();
|
|
|
|
AudioOutputManager.Dispose();
|
|
|
|
AudioInputManager.Dispose();
|
|
|
|
|
2020-08-18 01:49:37 +00:00
|
|
|
AudioRendererManager.Dispose();
|
|
|
|
|
2022-11-24 14:08:27 +00:00
|
|
|
if (LibHacHorizonManager.ApplicationClient != null)
|
|
|
|
{
|
|
|
|
LibHacHorizonManager.PmClient.Fs.UnregisterProgram(LibHacHorizonManager.ApplicationClient.Os.GetCurrentProcessId().Value).ThrowIfFailure();
|
|
|
|
}
|
2022-05-05 18:23:30 +00:00
|
|
|
|
2020-05-04 03:41:29 +00:00
|
|
|
KernelContext.Dispose();
|
2018-02-04 23:08:20 +00:00
|
|
|
}
|
|
|
|
}
|
2021-09-11 20:08:25 +00:00
|
|
|
|
|
|
|
public void TogglePauseEmulation(bool pause)
|
|
|
|
{
|
|
|
|
lock (KernelContext.Processes)
|
|
|
|
{
|
|
|
|
foreach (KProcess process in KernelContext.Processes.Values)
|
|
|
|
{
|
2021-12-04 23:23:26 +00:00
|
|
|
if (process.IsApplication)
|
2021-09-11 20:08:25 +00:00
|
|
|
{
|
|
|
|
// Only game process should be paused.
|
|
|
|
process.SetActivity(pause);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pause && !IsPaused)
|
|
|
|
{
|
|
|
|
Device.AudioDeviceDriver.GetPauseEvent().Reset();
|
2022-05-31 19:29:35 +00:00
|
|
|
TickSource.Suspend();
|
2021-09-11 20:08:25 +00:00
|
|
|
}
|
|
|
|
else if (!pause && IsPaused)
|
|
|
|
{
|
|
|
|
Device.AudioDeviceDriver.GetPauseEvent().Set();
|
2022-05-31 19:29:35 +00:00
|
|
|
TickSource.Resume();
|
2021-09-11 20:08:25 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
IsPaused = pause;
|
|
|
|
}
|
2018-02-04 23:08:20 +00:00
|
|
|
}
|
2023-06-27 23:18:19 +00:00
|
|
|
}
|