mirror of
https://github.com/GreemDev/Ryujinx
synced 2024-11-26 19:52:31 +01:00
a33dc2f491
* Logger class changes only Now compile-time checking is possible with the help of Nullable Value types. * Misc formatting * Manual optimizations PrintGuestLog PrintGuestStackTrace Surfaceflinger DequeueBuffer * Reduce SendVibrationXX log level to Debug * Add Notice log level This level is always enabled and used to print system info, etc... Also, rewrite LogColor to switch expression as colors are static * Unify unhandled exception event handlers * Print enabled LogLevels during init * Re-add App Exit disposes in proper order nit: switch case spacing * Revert PrintGuestStackTrace to Info logs due to #1407 PrintGuestStackTrace is now called in some critical error handlers so revert to old behavior as KThread isn't part of Guest. * Batch replace Logger statements
41 lines
1.3 KiB
C#
41 lines
1.3 KiB
C#
using Ryujinx.Common.Logging;
|
|
using Ryujinx.HLE.HOS.Kernel.Threading;
|
|
using System;
|
|
using System.Runtime.CompilerServices;
|
|
|
|
namespace Ryujinx.HLE.HOS.Services.SurfaceFlinger
|
|
{
|
|
interface IBinder
|
|
{
|
|
ResultCode AdjustRefcount(int addVal, int type);
|
|
|
|
void GetNativeHandle(uint typeId, out KReadableEvent readableEvent);
|
|
|
|
ResultCode OnTransact(uint code, uint flags, ReadOnlySpan<byte> inputParcel, Span<byte> outputParcel)
|
|
{
|
|
Parcel inputParcelReader = new Parcel(inputParcel.ToArray());
|
|
|
|
// TODO: support objects?
|
|
Parcel outputParcelWriter = new Parcel((uint)(outputParcel.Length - Unsafe.SizeOf<ParcelHeader>()), 0);
|
|
|
|
string inputInterfaceToken = inputParcelReader.ReadInterfaceToken();
|
|
|
|
if (!InterfaceToken.Equals(inputInterfaceToken))
|
|
{
|
|
Logger.Error?.Print(LogClass.SurfaceFlinger, $"Invalid interface token {inputInterfaceToken} (expected: {InterfaceToken}");
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
OnTransact(code, flags, inputParcelReader, outputParcelWriter);
|
|
|
|
outputParcelWriter.Finish().CopyTo(outputParcel);
|
|
|
|
return ResultCode.Success;
|
|
}
|
|
|
|
void OnTransact(uint code, uint flags, Parcel inputParcel, Parcel outputParcel);
|
|
|
|
string InterfaceToken { get; }
|
|
}
|
|
}
|