mirror of
https://git.ryujinx.app/ryubing/ryujinx.git
synced 2025-05-01 12:07:42 +02:00

* dotnet format style --severity info Some changes were manually reverted. * dotnet format analyzers --serverity info Some changes have been minimally adapted. * Restore a few unused methods and variables * Silence dotnet format IDE0060 warnings * Silence dotnet format IDE0052 warnings * Address or silence dotnet format IDE1006 warnings * Address dotnet format CA1816 warnings * Address or silence dotnet format CA2208 warnings * Address or silence dotnet format CA1806 and a few CA1854 warnings * Address dotnet format CA2211 warnings * Address dotnet format CA1822 warnings * Address or silence dotnet format CA1069 warnings * Make dotnet format succeed in style mode * Address or silence dotnet format CA2211 warnings * Address review comments * Address dotnet format CA2208 warnings properly * Make ProcessResult readonly * Address most dotnet format whitespace warnings * Apply dotnet format whitespace formatting A few of them have been manually reverted and the corresponding warning was silenced * Add previously silenced warnings back I have no clue how these disappeared * Revert formatting changes for while and for-loops * Format if-blocks correctly * Run dotnet format style after rebase * Run dotnet format whitespace after rebase * Run dotnet format style after rebase * Run dotnet format analyzers after rebase * Run dotnet format after rebase and remove unused usings - analyzers - style - whitespace * Disable 'prefer switch expression' rule * Add comments to disabled warnings * Fix a few disabled warnings * Fix naming rule violation, Convert shader properties to auto-property and convert values to const * Simplify properties and array initialization, Use const when possible, Remove trailing commas * Start working on disabled warnings * Fix and silence a few dotnet-format warnings again * Run dotnet format after rebase * Use using declaration instead of block syntax * Address IDE0251 warnings * Address a few disabled IDE0060 warnings * Silence IDE0060 in .editorconfig * Revert "Simplify properties and array initialization, Use const when possible, Remove trailing commas" This reverts commit 9462e4136c0a2100dc28b20cf9542e06790aa67e. * dotnet format whitespace after rebase * First dotnet format pass * Fix naming rule violations * Fix typo * Add trailing commas, use targeted new and use array initializer * Fix build issues * Fix remaining build issues * Remove SuppressMessage for CA1069 where possible * Address dotnet format issues * Address formatting issues Co-authored-by: Ac_K <acoustik666@gmail.com> * Add GetHashCode implementation for RenderingSurfaceInfo * Explicitly silence CA1822 for every affected method in Syscall * Address formatting issues in Demangler.cs * Address review feedback Co-authored-by: Ac_K <acoustik666@gmail.com> * Revert marking service methods as static * Next dotnet format pass * Address review feedback --------- Co-authored-by: Ac_K <acoustik666@gmail.com>
127 lines
4.9 KiB
C#
127 lines
4.9 KiB
C#
using Ryujinx.Common.Logging;
|
|
using Ryujinx.HLE.HOS.Services.Ssl.SslService;
|
|
using Ryujinx.HLE.HOS.Services.Ssl.Types;
|
|
using Ryujinx.Memory;
|
|
using System;
|
|
using System.Runtime.CompilerServices;
|
|
using System.Runtime.InteropServices;
|
|
|
|
namespace Ryujinx.HLE.HOS.Services.Ssl
|
|
{
|
|
[Service("ssl")]
|
|
class ISslService : IpcService
|
|
{
|
|
// NOTE: The SSL service is used by games to connect it to various official online services, which we do not intend to support.
|
|
// In this case it is acceptable to stub all calls of the service.
|
|
public ISslService(ServiceCtx context) { }
|
|
|
|
[CommandCmif(0)]
|
|
// CreateContext(nn::ssl::sf::SslVersion, u64, pid) -> object<nn::ssl::sf::ISslContext>
|
|
public ResultCode CreateContext(ServiceCtx context)
|
|
{
|
|
SslVersion sslVersion = (SslVersion)context.RequestData.ReadUInt32();
|
|
#pragma warning disable IDE0059 // Remove unnecessary value assignment
|
|
ulong pidPlaceholder = context.RequestData.ReadUInt64();
|
|
#pragma warning restore IDE0059
|
|
|
|
MakeObject(context, new ISslContext(context.Request.HandleDesc.PId, sslVersion));
|
|
|
|
Logger.Stub?.PrintStub(LogClass.ServiceSsl, new { sslVersion });
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[CommandCmif(2)]
|
|
// GetCertificates(buffer<CaCertificateId, 5> ids) -> (u32 certificates_count, buffer<bytes, 6> certificates)
|
|
public ResultCode GetCertificates(ServiceCtx context)
|
|
{
|
|
ReadOnlySpan<CaCertificateId> ids = MemoryMarshal.Cast<byte, CaCertificateId>(context.Memory.GetSpan(context.Request.SendBuff[0].Position, (int)context.Request.SendBuff[0].Size));
|
|
|
|
if (!BuiltInCertificateManager.Instance.TryGetCertificates(
|
|
ids,
|
|
out BuiltInCertificateManager.CertStoreEntry[] entries,
|
|
out bool hasAllCertificates,
|
|
out int requiredSize))
|
|
{
|
|
throw new InvalidOperationException();
|
|
}
|
|
|
|
if ((uint)requiredSize > (uint)context.Request.ReceiveBuff[0].Size)
|
|
{
|
|
return ResultCode.InvalidCertBufSize;
|
|
}
|
|
|
|
int infosCount = entries.Length;
|
|
|
|
if (hasAllCertificates)
|
|
{
|
|
infosCount++;
|
|
}
|
|
|
|
using (WritableRegion region = context.Memory.GetWritableRegion(context.Request.ReceiveBuff[0].Position, (int)context.Request.ReceiveBuff[0].Size))
|
|
{
|
|
Span<byte> rawData = region.Memory.Span;
|
|
Span<BuiltInCertificateInfo> infos = MemoryMarshal.Cast<byte, BuiltInCertificateInfo>(rawData)[..infosCount];
|
|
Span<byte> certificatesData = rawData[(Unsafe.SizeOf<BuiltInCertificateInfo>() * infosCount)..];
|
|
|
|
for (int i = 0; i < entries.Length; i++)
|
|
{
|
|
entries[i].Data.CopyTo(certificatesData);
|
|
|
|
infos[i] = new BuiltInCertificateInfo
|
|
{
|
|
Id = entries[i].Id,
|
|
Status = entries[i].Status,
|
|
CertificateDataSize = (ulong)entries[i].Data.Length,
|
|
CertificateDataOffset = (ulong)(rawData.Length - certificatesData.Length),
|
|
};
|
|
|
|
certificatesData = certificatesData[entries[i].Data.Length..];
|
|
}
|
|
|
|
if (hasAllCertificates)
|
|
{
|
|
infos[entries.Length] = new BuiltInCertificateInfo
|
|
{
|
|
Id = CaCertificateId.All,
|
|
Status = TrustedCertStatus.Invalid,
|
|
CertificateDataSize = 0,
|
|
CertificateDataOffset = 0,
|
|
};
|
|
}
|
|
}
|
|
|
|
context.ResponseData.Write(entries.Length);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[CommandCmif(3)]
|
|
// GetCertificateBufSize(buffer<CaCertificateId, 5> ids) -> u32 buffer_size;
|
|
public ResultCode GetCertificateBufSize(ServiceCtx context)
|
|
{
|
|
ReadOnlySpan<CaCertificateId> ids = MemoryMarshal.Cast<byte, CaCertificateId>(context.Memory.GetSpan(context.Request.SendBuff[0].Position, (int)context.Request.SendBuff[0].Size));
|
|
|
|
if (!BuiltInCertificateManager.Instance.TryGetCertificates(ids, out _, out _, out int requiredSize))
|
|
{
|
|
throw new InvalidOperationException();
|
|
}
|
|
|
|
context.ResponseData.Write(requiredSize);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
[CommandCmif(5)]
|
|
// SetInterfaceVersion(u32)
|
|
public ResultCode SetInterfaceVersion(ServiceCtx context)
|
|
{
|
|
// 1 = 3.0.0+, 2 = 5.0.0+, 3 = 6.0.0+
|
|
uint interfaceVersion = context.RequestData.ReadUInt32();
|
|
|
|
Logger.Stub?.PrintStub(LogClass.ServiceSsl, new { interfaceVersion });
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
}
|
|
}
|