aboutsummaryrefslogtreecommitdiff
path: root/src/Ryujinx.HLE/HOS/Services/Ngct
diff options
context:
space:
mode:
authorTSR Berry <20988865+TSRBerry@users.noreply.github.com>2023-04-08 01:22:00 +0200
committerMary <thog@protonmail.com>2023-04-27 23:51:14 +0200
commitcee712105850ac3385cd0091a923438167433f9f (patch)
tree4a5274b21d8b7f938c0d0ce18736d3f2993b11b1 /src/Ryujinx.HLE/HOS/Services/Ngct
parentcd124bda587ef09668a971fa1cac1c3f0cfc9f21 (diff)
Move solution and projects to src
Diffstat (limited to 'src/Ryujinx.HLE/HOS/Services/Ngct')
-rw-r--r--src/Ryujinx.HLE/HOS/Services/Ngct/IService.cs22
-rw-r--r--src/Ryujinx.HLE/HOS/Services/Ngct/IServiceWithManagementApi.cs22
-rw-r--r--src/Ryujinx.HLE/HOS/Services/Ngct/NgctServer.cs92
3 files changed, 136 insertions, 0 deletions
diff --git a/src/Ryujinx.HLE/HOS/Services/Ngct/IService.cs b/src/Ryujinx.HLE/HOS/Services/Ngct/IService.cs
new file mode 100644
index 00000000..eacf35f3
--- /dev/null
+++ b/src/Ryujinx.HLE/HOS/Services/Ngct/IService.cs
@@ -0,0 +1,22 @@
+namespace Ryujinx.HLE.HOS.Services.Ngct
+{
+ [Service("ngct:u")] // 9.0.0+
+ class IService : IpcService
+ {
+ public IService(ServiceCtx context) { }
+
+ [CommandCmif(0)]
+ // Match(buffer<string, 9>) -> b8
+ public ResultCode Match(ServiceCtx context)
+ {
+ return NgctServer.Match(context);
+ }
+
+ [CommandCmif(1)]
+ // Filter(buffer<string, 9>) -> buffer<filtered_string, 10>
+ public ResultCode Filter(ServiceCtx context)
+ {
+ return NgctServer.Filter(context);
+ }
+ }
+} \ No newline at end of file
diff --git a/src/Ryujinx.HLE/HOS/Services/Ngct/IServiceWithManagementApi.cs b/src/Ryujinx.HLE/HOS/Services/Ngct/IServiceWithManagementApi.cs
new file mode 100644
index 00000000..5ad056ba
--- /dev/null
+++ b/src/Ryujinx.HLE/HOS/Services/Ngct/IServiceWithManagementApi.cs
@@ -0,0 +1,22 @@
+namespace Ryujinx.HLE.HOS.Services.Ngct
+{
+ [Service("ngct:s")] // 9.0.0+
+ class IServiceWithManagementApi : IpcService
+ {
+ public IServiceWithManagementApi(ServiceCtx context) { }
+
+ [CommandCmif(0)]
+ // Match(buffer<string, 9>) -> b8
+ public ResultCode Match(ServiceCtx context)
+ {
+ return NgctServer.Match(context);
+ }
+
+ [CommandCmif(1)]
+ // Filter(buffer<string, 9>) -> buffer<filtered_string, 10>
+ public ResultCode Filter(ServiceCtx context)
+ {
+ return NgctServer.Filter(context);
+ }
+ }
+} \ No newline at end of file
diff --git a/src/Ryujinx.HLE/HOS/Services/Ngct/NgctServer.cs b/src/Ryujinx.HLE/HOS/Services/Ngct/NgctServer.cs
new file mode 100644
index 00000000..8d99721e
--- /dev/null
+++ b/src/Ryujinx.HLE/HOS/Services/Ngct/NgctServer.cs
@@ -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.
+
+ ulong bufferPosition = context.Request.PtrBuff[0].Position;
+ ulong 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(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.
+
+ ulong bufferPosition = context.Request.PtrBuff[0].Position;
+ ulong bufferSize = context.Request.PtrBuff[0].Size;
+
+ ulong bufferFilteredPosition = context.Request.RecvListBuff[0].Position;
+
+ string text = "";
+ string textFiltered = "";
+
+ if (bufferSize != 0)
+ {
+ if (bufferSize > 1024)
+ {
+ textFiltered = new string('*', text.Length);
+
+ context.Memory.Write(bufferFilteredPosition, Encoding.ASCII.GetBytes(textFiltered));
+ }
+ else
+ {
+ byte[] buffer = new byte[bufferSize];
+
+ context.Memory.Read(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(bufferFilteredPosition, buffer);
+ }
+ }
+
+ Logger.Stub?.PrintStub(LogClass.ServiceNgct, new { text, textFiltered });
+
+ return ResultCode.Success;
+ }
+ }
+} \ No newline at end of file