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-11-09 19:22:43 +00:00
|
|
|
using Ryujinx.Common.Utilities;
|
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-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;
|
2021-08-12 21:56:24 +00:00
|
|
|
using TimeSpanType = Ryujinx.HLE.HOS.Services.Time.Clock.TimeSpanType;
|
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
|
|
|
{
|
2021-06-28 18:54:45 +00:00
|
|
|
internal const int HidSize = 0x40000;
|
|
|
|
internal const int FontSize = 0x1100000;
|
|
|
|
internal const int IirsSize = 0x8000;
|
|
|
|
internal const int TimeSize = 0x1000;
|
|
|
|
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; }
|
|
|
|
|
2018-12-05 00:52:39 +00:00
|
|
|
internal KSharedMemory HidSharedMem { get; private set; }
|
|
|
|
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; }
|
|
|
|
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
|
|
|
|
2021-06-28 18:54:45 +00:00
|
|
|
ulong hidPa = region.Address;
|
|
|
|
ulong fontPa = region.Address + HidSize;
|
|
|
|
ulong iirsPa = region.Address + HidSize + FontSize;
|
|
|
|
ulong timePa = region.Address + HidSize + FontSize + IirsSize;
|
|
|
|
ulong appletCaptureBufferPa = region.Address + HidSize + FontSize + IirsSize + TimeSize;
|
2018-11-28 22:18:09 +00:00
|
|
|
|
2021-06-28 18:54:45 +00:00
|
|
|
KPageList hidPageList = new KPageList();
|
|
|
|
KPageList fontPageList = new KPageList();
|
|
|
|
KPageList iirsPageList = new KPageList();
|
|
|
|
KPageList timePageList = new KPageList();
|
|
|
|
KPageList appletCaptureBufferPageList = new KPageList();
|
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
|
|
|
|
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
|
|
|
HidSharedMem = new KSharedMemory(KernelContext, hidStorage, 0, 0, KMemoryPermission.Read);
|
|
|
|
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
|
|
|
|
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
|
|
|
KSharedMemory timeSharedMemory = new KSharedMemory(KernelContext, timeStorage, 0, 0, KMemoryPermission.Read);
|
|
|
|
|
|
|
|
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);
|
|
|
|
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;
|
|
|
|
|
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.
|
2022-11-09 19:22:43 +00:00
|
|
|
UInt128 clockSourceId = UInt128Utils.CreateRandom();
|
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
|
|
|
|
2020-04-16 23:18:54 +00:00
|
|
|
TimeSpanType systemTimeOffset = new TimeSpanType(systemTime.NanoSeconds + internalOffset.NanoSeconds);
|
|
|
|
|
|
|
|
if (systemTime.IsDaylightSavingTime() && !systemTimeOffset.IsDaylightSavingTime())
|
|
|
|
{
|
|
|
|
internalOffset = internalOffset.AddSeconds(3600L);
|
|
|
|
}
|
|
|
|
else if (!systemTime.IsDaylightSavingTime() && systemTimeOffset.IsDaylightSavingTime())
|
|
|
|
{
|
|
|
|
internalOffset = internalOffset.AddSeconds(-3600L);
|
|
|
|
}
|
|
|
|
|
|
|
|
internalOffset = new TimeSpanType(-internalOffset.NanoSeconds);
|
|
|
|
|
2019-10-08 03:48:49 +00:00
|
|
|
// First init the standard steady clock
|
2022-05-31 19:29:35 +00:00
|
|
|
TimeServiceManager.Instance.SetupStandardSteadyClock(TickSource, clockSourceId, systemTime, internalOffset, TimeSpanType.Zero, false);
|
|
|
|
TimeServiceManager.Instance.SetupStandardLocalSystemClock(TickSource, new SystemClockContext(), systemTime.ToSeconds());
|
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
|
|
|
{
|
|
|
|
TimeSpanType standardNetworkClockSufficientAccuracy = new TimeSpanType((int)standardNetworkClockSufficientAccuracyMinutes * 60000000000);
|
|
|
|
|
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.
|
2022-05-31 19:29:35 +00:00
|
|
|
TimeServiceManager.Instance.StandardLocalSystemClock.GetClockContext(TickSource, out SystemClockContext localSytemClockContext);
|
2020-05-20 09:35:30 +00:00
|
|
|
TimeServiceManager.Instance.SetupStandardNetworkSystemClock(localSytemClockContext, standardNetworkClockSufficientAccuracy);
|
2019-07-15 17:52:35 +00:00
|
|
|
}
|
|
|
|
|
2022-05-31 19:29:35 +00:00
|
|
|
TimeServiceManager.Instance.SetupStandardUserSystemClock(TickSource, false, SteadyClockTimePoint.GetRandom());
|
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);
|
2020-08-18 01:49:37 +00:00
|
|
|
AudioDeviceSessionRegistry = new VirtualDeviceSessionRegistry();
|
|
|
|
|
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
|
|
|
{
|
2021-02-26 00:11:56 +00:00
|
|
|
KEvent registerBufferEvent = new KEvent(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
|
|
|
{
|
2021-02-26 00:11:56 +00:00
|
|
|
KEvent registerBufferEvent = new KEvent(KernelContext);
|
|
|
|
|
|
|
|
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++)
|
|
|
|
{
|
|
|
|
KEvent systemEvent = new KEvent(KernelContext);
|
|
|
|
|
|
|
|
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");
|
2023-01-04 22:15:45 +00:00
|
|
|
|
|
|
|
StartNewServices();
|
|
|
|
}
|
|
|
|
|
|
|
|
private void StartNewServices()
|
|
|
|
{
|
2023-01-08 12:13:39 +00:00
|
|
|
ServiceTable = new ServiceTable();
|
2023-01-04 22:15:45 +00:00
|
|
|
var services = ServiceTable.GetServices(new HorizonOptions(Device.Configuration.IgnoreMissingServices));
|
|
|
|
|
|
|
|
foreach (var service in services)
|
|
|
|
{
|
|
|
|
const ProcessCreationFlags flags =
|
|
|
|
ProcessCreationFlags.EnableAslr |
|
|
|
|
ProcessCreationFlags.AddressSpace64Bit |
|
|
|
|
ProcessCreationFlags.Is64Bit |
|
|
|
|
ProcessCreationFlags.PoolPartitionSystem;
|
|
|
|
|
|
|
|
ProcessCreationInfo creationInfo = new ProcessCreationInfo("Service", 1, 0, 0x8000000, 1, flags, 0, 0);
|
|
|
|
|
|
|
|
int[] defaultCapabilities = new int[]
|
|
|
|
{
|
|
|
|
0x030363F7,
|
|
|
|
0x1FFFFFCF,
|
|
|
|
0x207FFFEF,
|
|
|
|
0x47E0060F,
|
|
|
|
0x0048BFFF,
|
|
|
|
0x01007FFF
|
|
|
|
};
|
|
|
|
|
|
|
|
// 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
|
|
|
}
|
|
|
|
|
2020-07-09 04:31:15 +00:00
|
|
|
public void 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
|
|
|
|
2021-12-23 16:55:50 +00:00
|
|
|
ProgramLoader.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
|
|
|
{
|
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
|
|
|
|
2020-05-04 03:41:29 +00:00
|
|
|
KProcess terminationProcess = new KProcess(KernelContext);
|
|
|
|
KThread terminationThread = new KThread(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
|
|
|
}
|
2020-06-16 18:28:02 +00:00
|
|
|
}
|