mirror of
https://git.naxdy.org/Mirror/Ryujinx.git
synced 2025-01-19 00:40:32 +00:00
ngct: Fix services and stub calls (#1756)
This commit is contained in:
parent
c9b6be1ef8
commit
c0b9ac6653
5 changed files with 139 additions and 9 deletions
|
@ -37,6 +37,7 @@ namespace Ryujinx.Common.Logging
|
||||||
ServiceLm,
|
ServiceLm,
|
||||||
ServiceMm,
|
ServiceMm,
|
||||||
ServiceNfp,
|
ServiceNfp,
|
||||||
|
ServiceNgct,
|
||||||
ServiceNifm,
|
ServiceNifm,
|
||||||
ServiceNim,
|
ServiceNim,
|
||||||
ServiceNs,
|
ServiceNs,
|
||||||
|
|
24
Ryujinx.HLE/HOS/Services/Ngct/IService.cs
Normal file
24
Ryujinx.HLE/HOS/Services/Ngct/IService.cs
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
using System.Text;
|
||||||
|
|
||||||
|
namespace Ryujinx.HLE.HOS.Services.Ngct
|
||||||
|
{
|
||||||
|
[Service("ngct:u")] // 9.0.0+
|
||||||
|
class IService : IpcService
|
||||||
|
{
|
||||||
|
public IService(ServiceCtx context) { }
|
||||||
|
|
||||||
|
[Command(0)]
|
||||||
|
// Match(buffer<string, 9>) -> b8
|
||||||
|
public ResultCode Match(ServiceCtx context)
|
||||||
|
{
|
||||||
|
return NgctServer.Match(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Command(1)]
|
||||||
|
// Filter(buffer<string, 9>) -> buffer<filtered_string, 10>
|
||||||
|
public ResultCode Filter(ServiceCtx context)
|
||||||
|
{
|
||||||
|
return NgctServer.Filter(context);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
22
Ryujinx.HLE/HOS/Services/Ngct/IServiceWithManagementApi.cs
Normal file
22
Ryujinx.HLE/HOS/Services/Ngct/IServiceWithManagementApi.cs
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
namespace Ryujinx.HLE.HOS.Services.Ngct
|
||||||
|
{
|
||||||
|
[Service("ngct:s")] // 9.0.0+
|
||||||
|
class IServiceWithManagementApi : IpcService
|
||||||
|
{
|
||||||
|
public IServiceWithManagementApi(ServiceCtx context) { }
|
||||||
|
|
||||||
|
[Command(0)]
|
||||||
|
// Match(buffer<string, 9>) -> b8
|
||||||
|
public ResultCode Match(ServiceCtx context)
|
||||||
|
{
|
||||||
|
return NgctServer.Match(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
[Command(1)]
|
||||||
|
// Filter(buffer<string, 9>) -> buffer<filtered_string, 10>
|
||||||
|
public ResultCode Filter(ServiceCtx context)
|
||||||
|
{
|
||||||
|
return NgctServer.Filter(context);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,9 +0,0 @@
|
||||||
namespace Ryujinx.HLE.HOS.Services.Ngct
|
|
||||||
{
|
|
||||||
[Service("ngct:s")] // 9.0.0+
|
|
||||||
[Service("ngct:u")] // 9.0.0+
|
|
||||||
class IUnknown1 : IpcService
|
|
||||||
{
|
|
||||||
public IUnknown1(ServiceCtx context) { }
|
|
||||||
}
|
|
||||||
}
|
|
92
Ryujinx.HLE/HOS/Services/Ngct/NgctServer.cs
Normal file
92
Ryujinx.HLE/HOS/Services/Ngct/NgctServer.cs
Normal file
|
@ -0,0 +1,92 @@
|
||||||
|
using Ryujinx.Common.Logging;
|
||||||
|
using System.Text;
|
||||||
|
|
||||||
|
namespace Ryujinx.HLE.HOS.Services.Ngct
|
||||||
|
{
|
||||||
|
static class NgctServer
|
||||||
|
{
|
||||||
|
public static ResultCode Match(ServiceCtx context)
|
||||||
|
{
|
||||||
|
// NOTE: Service load the values of sys:set ngc.t!functionality_override_enabled and ngc.t!auto_reload_enabled in internal fields.
|
||||||
|
// Then it checks if ngc.t!functionality_override_enabled is enabled and if sys:set GetT is == 2.
|
||||||
|
// If both conditions are true, it does this following code. Since we currently stub it, it's fine to don't check settings service values.
|
||||||
|
|
||||||
|
long bufferPosition = context.Request.PtrBuff[0].Position;
|
||||||
|
long bufferSize = context.Request.PtrBuff[0].Size;
|
||||||
|
|
||||||
|
bool isMatch = false;
|
||||||
|
string text = "";
|
||||||
|
|
||||||
|
if (bufferSize != 0)
|
||||||
|
{
|
||||||
|
if (bufferSize > 1024)
|
||||||
|
{
|
||||||
|
isMatch = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
byte[] buffer = new byte[bufferSize];
|
||||||
|
|
||||||
|
context.Memory.Read((ulong)bufferPosition, buffer);
|
||||||
|
|
||||||
|
text = Encoding.ASCII.GetString(buffer);
|
||||||
|
|
||||||
|
// NOTE: Ngct use the archive 0100000000001034 which contains a words table. This is pushed on Chinese Switchs using Bcat service.
|
||||||
|
// This call check if the string match with entries in the table and return the result if there is one (or more).
|
||||||
|
// Since we don't want to hide bad words. It's fine to returns false here.
|
||||||
|
|
||||||
|
isMatch = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Logger.Stub?.PrintStub(LogClass.ServiceNgct, new { isMatch, text });
|
||||||
|
|
||||||
|
context.ResponseData.Write(isMatch);
|
||||||
|
|
||||||
|
return ResultCode.Success;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ResultCode Filter(ServiceCtx context)
|
||||||
|
{
|
||||||
|
// NOTE: Service load the values of sys:set ngc.t!functionality_override_enabled and ngc.t!auto_reload_enabled in internal fields.
|
||||||
|
// Then it checks if ngc.t!functionality_override_enabled is enabled and if sys:set GetT is == 2.
|
||||||
|
// If both conditions are true, it does this following code. Since we currently stub it, it's fine to don't check settings service values.
|
||||||
|
|
||||||
|
long bufferPosition = context.Request.PtrBuff[0].Position;
|
||||||
|
long bufferSize = context.Request.PtrBuff[0].Size;
|
||||||
|
|
||||||
|
long bufferFilteredPosition = context.Request.RecvListBuff[0].Position;
|
||||||
|
|
||||||
|
string text = "";
|
||||||
|
string textFiltered = "";
|
||||||
|
|
||||||
|
if (bufferSize != 0)
|
||||||
|
{
|
||||||
|
if (bufferSize > 1024)
|
||||||
|
{
|
||||||
|
textFiltered = new string('*', text.Length);
|
||||||
|
|
||||||
|
context.Memory.Write((ulong)bufferFilteredPosition, Encoding.ASCII.GetBytes(textFiltered));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
byte[] buffer = new byte[bufferSize];
|
||||||
|
|
||||||
|
context.Memory.Read((ulong)bufferPosition, buffer);
|
||||||
|
|
||||||
|
// NOTE: Ngct use the archive 0100000000001034 which contains a words table. This is pushed on Chinese Switchs using Bcat service.
|
||||||
|
// This call check if the string contains words which are in the table then returns the same string with each matched words replaced by '*'.
|
||||||
|
// Since we don't want to hide bad words. It's fine to returns the same string.
|
||||||
|
|
||||||
|
textFiltered = text = Encoding.ASCII.GetString(buffer);
|
||||||
|
|
||||||
|
context.Memory.Write((ulong)bufferFilteredPosition, buffer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Logger.Stub?.PrintStub(LogClass.ServiceNgct, new { text, textFiltered });
|
||||||
|
|
||||||
|
return ResultCode.Success;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue