2023-03-31 19:16:46 +00:00
|
|
|
|
using LibHac.Loader;
|
|
|
|
|
using LibHac.Ns;
|
|
|
|
|
using Ryujinx.Common.Logging;
|
|
|
|
|
using Ryujinx.Cpu;
|
2023-04-05 01:34:21 +00:00
|
|
|
|
using Ryujinx.HLE.HOS.SystemState;
|
2023-03-31 19:16:46 +00:00
|
|
|
|
using Ryujinx.HLE.Loaders.Processes.Extensions;
|
|
|
|
|
using Ryujinx.Horizon.Common;
|
2023-04-12 01:09:47 +00:00
|
|
|
|
using System.Linq;
|
2023-03-31 19:16:46 +00:00
|
|
|
|
|
|
|
|
|
namespace Ryujinx.HLE.Loaders.Processes
|
|
|
|
|
{
|
|
|
|
|
public struct ProcessResult
|
|
|
|
|
{
|
2023-04-05 01:34:21 +00:00
|
|
|
|
public static ProcessResult Failed => new(null, new ApplicationControlProperty(), false, false, null, 0, 0, 0, TitleLanguage.AmericanEnglish);
|
2023-03-31 19:16:46 +00:00
|
|
|
|
|
|
|
|
|
private readonly byte _mainThreadPriority;
|
|
|
|
|
private readonly uint _mainThreadStackSize;
|
|
|
|
|
|
|
|
|
|
public readonly IDiskCacheLoadState DiskCacheLoadState;
|
|
|
|
|
|
|
|
|
|
public readonly MetaLoader MetaLoader;
|
|
|
|
|
public readonly ApplicationControlProperty ApplicationControlProperties;
|
|
|
|
|
|
|
|
|
|
public readonly ulong ProcessId;
|
2023-04-12 01:09:47 +00:00
|
|
|
|
public readonly string Name;
|
|
|
|
|
public readonly string DisplayVersion;
|
|
|
|
|
public readonly ulong ProgramId;
|
2023-03-31 19:16:46 +00:00
|
|
|
|
public readonly string ProgramIdText;
|
|
|
|
|
public readonly bool Is64Bit;
|
|
|
|
|
public readonly bool DiskCacheEnabled;
|
|
|
|
|
public readonly bool AllowCodeMemoryForJit;
|
|
|
|
|
|
|
|
|
|
public ProcessResult(
|
|
|
|
|
MetaLoader metaLoader,
|
|
|
|
|
ApplicationControlProperty applicationControlProperties,
|
|
|
|
|
bool diskCacheEnabled,
|
|
|
|
|
bool allowCodeMemoryForJit,
|
|
|
|
|
IDiskCacheLoadState diskCacheLoadState,
|
|
|
|
|
ulong pid,
|
|
|
|
|
byte mainThreadPriority,
|
2023-04-05 01:34:21 +00:00
|
|
|
|
uint mainThreadStackSize,
|
|
|
|
|
TitleLanguage titleLanguage)
|
2023-03-31 19:16:46 +00:00
|
|
|
|
{
|
|
|
|
|
_mainThreadPriority = mainThreadPriority;
|
|
|
|
|
_mainThreadStackSize = mainThreadStackSize;
|
|
|
|
|
|
|
|
|
|
DiskCacheLoadState = diskCacheLoadState;
|
|
|
|
|
ProcessId = pid;
|
|
|
|
|
|
|
|
|
|
MetaLoader = metaLoader;
|
|
|
|
|
ApplicationControlProperties = applicationControlProperties;
|
|
|
|
|
|
|
|
|
|
if (metaLoader is not null)
|
|
|
|
|
{
|
|
|
|
|
ulong programId = metaLoader.GetProgramId();
|
|
|
|
|
|
2023-04-12 01:09:47 +00:00
|
|
|
|
Name = ApplicationControlProperties.Title[(int)titleLanguage].NameString.ToString();
|
2023-04-05 01:34:21 +00:00
|
|
|
|
|
2023-04-12 01:09:47 +00:00
|
|
|
|
if (string.IsNullOrWhiteSpace(Name))
|
2023-04-05 01:34:21 +00:00
|
|
|
|
{
|
2023-04-12 01:09:47 +00:00
|
|
|
|
Name = ApplicationControlProperties.Title.ItemsRo.ToArray().FirstOrDefault(x => x.Name[0] != 0).NameString.ToString();
|
2023-04-05 01:34:21 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-04-12 01:09:47 +00:00
|
|
|
|
DisplayVersion = ApplicationControlProperties.DisplayVersionString.ToString();
|
|
|
|
|
ProgramId = programId;
|
|
|
|
|
ProgramIdText = $"{programId:x16}";
|
|
|
|
|
Is64Bit = metaLoader.IsProgram64Bit();
|
2023-03-31 19:16:46 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
DiskCacheEnabled = diskCacheEnabled;
|
|
|
|
|
AllowCodeMemoryForJit = allowCodeMemoryForJit;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public bool Start(Switch device)
|
|
|
|
|
{
|
|
|
|
|
device.Configuration.ContentManager.LoadEntries(device);
|
|
|
|
|
|
|
|
|
|
Result result = device.System.KernelContext.Processes[ProcessId].Start(_mainThreadPriority, _mainThreadStackSize);
|
|
|
|
|
if (result != Result.Success)
|
|
|
|
|
{
|
|
|
|
|
Logger.Error?.Print(LogClass.Loader, $"Process start returned error \"{result}\".");
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// TODO: LibHac npdm currently doesn't support version field.
|
2023-04-12 01:09:47 +00:00
|
|
|
|
string version = ProgramId > 0x0100000000007FFF ? DisplayVersion : device.System.ContentManager.GetCurrentFirmwareVersion()?.VersionString ?? "?";
|
2023-03-31 19:16:46 +00:00
|
|
|
|
|
|
|
|
|
Logger.Info?.Print(LogClass.Loader, $"Application Loaded: {Name} v{version} [{ProgramIdText}] [{(Is64Bit ? "64-bit" : "32-bit")}]");
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-04-12 01:09:47 +00:00
|
|
|
|
}
|