ILogger.cs 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. using Ryujinx.Common.Logging;
  2. using System.IO;
  3. using System.Text;
  4. namespace Ryujinx.HLE.HOS.Services.Lm.LogService
  5. {
  6. class ILogger : IpcService
  7. {
  8. public ILogger() { }
  9. [CommandHipc(0)]
  10. // Log(buffer<unknown, 0x21>)
  11. public ResultCode Log(ServiceCtx context)
  12. {
  13. Logger.Guest?.Print(LogClass.ServiceLm, LogImpl(context));
  14. return ResultCode.Success;
  15. }
  16. private string LogImpl(ServiceCtx context)
  17. {
  18. (ulong bufPos, ulong bufSize) = context.Request.GetBufferType0x21();
  19. byte[] logBuffer = new byte[bufSize];
  20. context.Memory.Read(bufPos, logBuffer);
  21. using MemoryStream ms = new MemoryStream(logBuffer);
  22. BinaryReader reader = new BinaryReader(ms);
  23. long pid = reader.ReadInt64();
  24. long threadContext = reader.ReadInt64();
  25. short flags = reader.ReadInt16();
  26. byte level = reader.ReadByte();
  27. byte verbosity = reader.ReadByte();
  28. int payloadLength = reader.ReadInt32();
  29. StringBuilder sb = new StringBuilder();
  30. sb.AppendLine($"Guest Log:\n Log level: {(LmLogLevel)level}");
  31. while (ms.Position < ms.Length)
  32. {
  33. int type = ReadEncodedInt(reader);
  34. int size = ReadEncodedInt(reader);
  35. LmLogField field = (LmLogField)type;
  36. string fieldStr = string.Empty;
  37. if (field == LmLogField.Start)
  38. {
  39. reader.ReadBytes(size);
  40. continue;
  41. }
  42. else if (field == LmLogField.Stop)
  43. {
  44. break;
  45. }
  46. else if (field == LmLogField.Line)
  47. {
  48. fieldStr = $"{field}: {reader.ReadInt32()}";
  49. }
  50. else if (field == LmLogField.DropCount)
  51. {
  52. fieldStr = $"{field}: {reader.ReadInt64()}";
  53. }
  54. else if (field == LmLogField.Time)
  55. {
  56. fieldStr = $"{field}: {reader.ReadInt64()}s";
  57. }
  58. else if (field < LmLogField.Count)
  59. {
  60. fieldStr = $"{field}: '{Encoding.UTF8.GetString(reader.ReadBytes(size)).TrimEnd()}'";
  61. }
  62. else
  63. {
  64. fieldStr = $"Field{field}: '{Encoding.UTF8.GetString(reader.ReadBytes(size)).TrimEnd()}'";
  65. }
  66. sb.AppendLine($" {fieldStr}");
  67. }
  68. return sb.ToString();
  69. }
  70. private static int ReadEncodedInt(BinaryReader reader)
  71. {
  72. int result = 0;
  73. int position = 0;
  74. byte encoded;
  75. do
  76. {
  77. encoded = reader.ReadByte();
  78. result += (encoded & 0x7F) << (7 * position);
  79. position++;
  80. } while ((encoded & 0x80) != 0);
  81. return result;
  82. }
  83. }
  84. }