diff --git a/Directory.Packages.props b/Directory.Packages.props
index 72d2442a35..461388511b 100644
--- a/Directory.Packages.props
+++ b/Directory.Packages.props
@@ -36,7 +36,7 @@
-
+
@@ -50,4 +50,4 @@
-
+
\ No newline at end of file
diff --git a/src/Ryujinx.HLE/HOS/Services/Sockets/Bsd/Impl/ManagedProxySocket.cs b/src/Ryujinx.HLE/HOS/Services/Sockets/Bsd/Impl/ManagedProxySocket.cs
index b2461836ae..73608c0308 100644
--- a/src/Ryujinx.HLE/HOS/Services/Sockets/Bsd/Impl/ManagedProxySocket.cs
+++ b/src/Ryujinx.HLE/HOS/Services/Sockets/Bsd/Impl/ManagedProxySocket.cs
@@ -23,13 +23,11 @@ namespace Ryujinx.HLE.HOS.Services.Sockets.Bsd.Impl
public SocksClient ProxyClient { get; }
- // TODO: Make sure Blocking is used properly
- public bool Blocking { get; set; }
+ public bool Blocking { get => ProxyClient.Blocking; set => ProxyClient.Blocking = value; }
public int RefCount { get; set; }
- // TODO: Assign LocalEndPoint and RemoteEndPoint
- public IPEndPoint RemoteEndPoint { get; private set; }
- public IPEndPoint LocalEndPoint { get; private set; }
+ public IPEndPoint RemoteEndPoint => (IPEndPoint)ProxyClient.ProxiedRemoteEndPoint;
+ public IPEndPoint LocalEndPoint => (IPEndPoint)ProxyClient.ProxiedLocalEndPoint;
public AddressFamily AddressFamily => ProxyClient.AddressFamily;
public SocketType SocketType => ProxyClient.SocketType;
@@ -70,11 +68,9 @@ namespace Ryujinx.HLE.HOS.Services.Sockets.Bsd.Impl
RefCount = 1;
}
- private ManagedProxySocket(ManagedProxySocket oldSocket, SocksClient proxyClient)
+ private ManagedProxySocket(SocksClient proxyClient)
{
ProxyClient = proxyClient;
- LocalEndPoint = oldSocket.LocalEndPoint;
- RemoteEndPoint = oldSocket.RemoteEndPoint;
_acceptedConnection = true;
RefCount = 1;
}
@@ -273,22 +269,82 @@ namespace Ryujinx.HLE.HOS.Services.Sockets.Bsd.Impl
throw new NotImplementedException();
}
+ ///
+ /// Adapted from
+ ///
public LinuxError GetSocketOption(BsdSocketOption option, SocketOptionLevel level, Span optionValue)
{
- // TODO: Call ProxyClient.GetSocketOption() when it's implemented
- throw new NotImplementedException();
+ try
+ {
+ LinuxError result = WinSockHelper.ValidateSocketOption(option, level, write: false);
+
+ if (result != LinuxError.SUCCESS)
+ {
+ Logger.Warning?.Print(LogClass.ServiceBsd, $"Invalid GetSockOpt Option: {option} Level: {level}");
+
+ return result;
+ }
+
+ if (!WinSockHelper.TryConvertSocketOption(option, level, out SocketOptionName optionName))
+ {
+ Logger.Warning?.Print(LogClass.ServiceBsd, $"Unsupported GetSockOpt Option: {option} Level: {level}");
+ optionValue.Clear();
+
+ return LinuxError.SUCCESS;
+ }
+
+ byte[] tempOptionValue = new byte[optionValue.Length];
+
+ ProxyClient.GetSocketOption(level, optionName, tempOptionValue);
+
+ tempOptionValue.AsSpan().CopyTo(optionValue);
+
+ return LinuxError.SUCCESS;
+ }
+ catch (SocketException exception)
+ {
+ return WinSockHelper.ConvertError((WsaError)exception.ErrorCode);
+ }
}
+ ///
+ /// Adapted from
+ ///
public LinuxError SetSocketOption(BsdSocketOption option, SocketOptionLevel level, ReadOnlySpan optionValue)
{
- // TODO: Call ProxyClient.SetSocketOption() when it's implemented
- throw new NotImplementedException();
+ try
+ {
+ LinuxError result = WinSockHelper.ValidateSocketOption(option, level, write: true);
+
+ if (result != LinuxError.SUCCESS)
+ {
+ Logger.Warning?.Print(LogClass.ServiceBsd, $"Invalid SetSockOpt Option: {option} Level: {level}");
+
+ return result;
+ }
+
+ if (!WinSockHelper.TryConvertSocketOption(option, level, out SocketOptionName optionName))
+ {
+ Logger.Warning?.Print(LogClass.ServiceBsd, $"Unsupported SetSockOpt Option: {option} Level: {level}");
+
+ return LinuxError.SUCCESS;
+ }
+
+ byte[] value = optionValue.ToArray();
+
+ ProxyClient.SetSocketOption(level, optionName, value);
+
+ return LinuxError.SUCCESS;
+ }
+ catch (SocketException exception)
+ {
+ return WinSockHelper.ConvertError((WsaError)exception.ErrorCode);
+ }
}
public bool Poll(int microSeconds, SelectMode mode)
{
- // TODO: Call ProxyClient.Poll() when it's implemented
- throw new NotImplementedException();
+ return ProxyClient.Poll(microSeconds, mode);
}
public LinuxError Bind(IPEndPoint localEndPoint)
@@ -370,7 +426,7 @@ namespace Ryujinx.HLE.HOS.Services.Sockets.Bsd.Impl
try
{
SocksClient newProxyClient = ProxyClient.Accept();
- newSocket = new ManagedProxySocket(this, newProxyClient);
+ newSocket = new ManagedProxySocket(newProxyClient);
}
catch (ProxyException exception)
{
@@ -391,13 +447,21 @@ namespace Ryujinx.HLE.HOS.Services.Sockets.Bsd.Impl
public void Disconnect()
{
- // TODO: Call ProxyClient.Disconnect() when it's implemented
+ ProxyClient.Disconnect();
}
public LinuxError Shutdown(BsdSocketShutdownFlags how)
{
- // TODO: Call ProxyClient.Shutdown() when it's implemented
- return LinuxError.SUCCESS;
+ try
+ {
+ ProxyClient.Shutdown((SocketShutdown)how);
+
+ return LinuxError.SUCCESS;
+ }
+ catch (SocketException exception)
+ {
+ return WinSockHelper.ConvertError((WsaError)exception.ErrorCode);
+ }
}
public void Close()