ILogger.cs 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. using Ryujinx.Common.Logging;
  2. using Ryujinx.HLE.HOS.Ipc;
  3. using System.Collections.Generic;
  4. using System.IO;
  5. using System.Text;
  6. namespace Ryujinx.HLE.HOS.Services.Lm
  7. {
  8. class ILogger : IpcService
  9. {
  10. private Dictionary<int, ServiceProcessRequest> m_Commands;
  11. public override IReadOnlyDictionary<int, ServiceProcessRequest> Commands => m_Commands;
  12. public ILogger()
  13. {
  14. m_Commands = new Dictionary<int, ServiceProcessRequest>()
  15. {
  16. { 0, Log }
  17. };
  18. }
  19. public long Log(ServiceCtx Context)
  20. {
  21. (long BufPos, long BufSize) = Context.Request.GetBufferType0x21();
  22. byte[] LogBuffer = Context.Memory.ReadBytes(BufPos, BufSize);
  23. using (MemoryStream MS = new MemoryStream(LogBuffer))
  24. {
  25. BinaryReader Reader = new BinaryReader(MS);
  26. long Pid = Reader.ReadInt64();
  27. long ThreadContext = Reader.ReadInt64();
  28. short Flags = Reader.ReadInt16();
  29. byte Level = Reader.ReadByte();
  30. byte Verbosity = Reader.ReadByte();
  31. int PayloadLength = Reader.ReadInt32();
  32. StringBuilder SB = new StringBuilder();
  33. SB.AppendLine("Guest log:");
  34. while (MS.Position < MS.Length)
  35. {
  36. byte Type = Reader.ReadByte();
  37. byte Size = Reader.ReadByte();
  38. LmLogField Field = (LmLogField)Type;
  39. string FieldStr = string.Empty;
  40. if (Field == LmLogField.Start)
  41. {
  42. Reader.ReadBytes(Size);
  43. continue;
  44. }
  45. else if (Field == LmLogField.Stop)
  46. {
  47. break;
  48. }
  49. else if (Field == LmLogField.Line)
  50. {
  51. FieldStr = Field + ": " + Reader.ReadInt32();
  52. }
  53. else if (Field == LmLogField.DropCount)
  54. {
  55. FieldStr = Field + ": " + Reader.ReadInt64();
  56. }
  57. else if (Field == LmLogField.Time)
  58. {
  59. FieldStr = Field + ": " + Reader.ReadInt64() + "s";
  60. }
  61. else if (Field < LmLogField.Count)
  62. {
  63. FieldStr = Field + ": \"" + Encoding.UTF8.GetString(Reader.ReadBytes(Size)) + "\"";
  64. }
  65. else
  66. {
  67. FieldStr = "Field" + Field + ": \"" + Encoding.UTF8.GetString(Reader.ReadBytes(Size)) + "\"";
  68. }
  69. SB.AppendLine(" " + FieldStr);
  70. }
  71. string Text = SB.ToString();
  72. switch((LmLogLevel)Level)
  73. {
  74. case LmLogLevel.Trace: Logger.PrintDebug (LogClass.ServiceLm, Text); break;
  75. case LmLogLevel.Info: Logger.PrintInfo (LogClass.ServiceLm, Text); break;
  76. case LmLogLevel.Warning: Logger.PrintWarning(LogClass.ServiceLm, Text); break;
  77. case LmLogLevel.Error: Logger.PrintError (LogClass.ServiceLm, Text); break;
  78. case LmLogLevel.Critical: Logger.PrintError (LogClass.ServiceLm, Text); break;
  79. }
  80. }
  81. return 0;
  82. }
  83. }
  84. }