-
-
Notifications
You must be signed in to change notification settings - Fork 122
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Valve sockets networking #465
base: master
Are you sure you want to change the base?
Conversation
I'm not sure if this is actually going to be viable because of the imports of overloaded functions but here is a ValveSocket.cs with the DllImports mostly converted to DynDllImports |
Shows time it takes for OnAllPlayersSyncCompleted() to trigger from when a player begins joining a game when in debug mode.
@Yamashi Not sure if you want to do anything with it, however I was looking at the C# wrapper and it seems that it only supports the 1.2.x version of the native library (there is an issue confirming) while the current version of the native library is at 1.3.x . There have been lots of commits in the mean time so they might have fixed ValveSoftware/GameNetworkingSockets#198 in the mean time. On an unrelated note, (this might also interest you @PhantomGamers) there has been some talk about exposing the P2P signaling stuff through the C# wrapper, you can find more about it here |
That 1.3.0 compatibility issue seems to be only on Linux, which I'm not really worried about as DSP doesn't have a native Linux version anyway |
@PhantomGamers perhaps I didn't formulate it clearly enough, however I am fairly sure the version of the native library that is included with this PR is the 1.2 variant. My Reasoning being, the compiled dll's came from the NuGet version of the c# wrapper, which included it in this commit riina-eng/ValveSockets-CSharp@f693e2b on 27 March 2021, this predates the release of the 1.3 version of the native Lib (Released on 30 May 2021) |
Ah, I see. Well, the good news is that according to that it sounds like we can use 1.30 with the wrapper in our case as least lol |
@Yamashi or @PhantomGamers I compiled the 1.3.0 version from https://github.com/ValveSoftware/GameNetworkingSockets/releases via vcpkg and have the binaries here if one of you wants to try: |
Has this been compiled with ICE support as well? |
I did not change anything from the default config, so I guess not. Perhaps try this version first? if it works I will try to compile with that option |
|
Co-Authored-By: mmjr-x <[email protected]>
False alarm! I had loaded the wrong save because I was messing with a different one earlier, it's not actually faster >_<, but it does work lol. |
Glad it works at least! Perhaps its worth doing a build of the latest master instead of the latest release, I will try to find the time for that tomorrow :) |
This reverts commit cf984f2.
In terms of performance it appears to be faster than WebSockets, not as fast as Telepathy but this is expected considering we are very conservative with the computing power we request for polling, this could be improved or we can just wait for the issue to be solved by Valve. Possible improvements are in the following areas:
|
Ignore the edit, I wasn't sure if it would actually let me tick the checkboxes on your comment haha
Maybe ArraySegmentX would be useful for this as well, it's what Mirror uses Also before this gets merged we should remove any logging that exposes IP addresses |
I have compiled the latest master (this time through visual studio) with USE_STEAMWEBRTC (ICE Support): aesgcmtestvectors, GameNetworkingSockets.dll.manifest and libssl-1_1-x64.dll are problably not required (although I am not sure about libssl-1_1-x64.dll ) however I just included the complete build output. I build it in Release mode, however I can provide one with debug if requested :) |
- built from ValveSoftware/GameNetworkingSockets@5c793b9 - update valvesockets to support the changes made in GameNetworkingSockets WARNING: I didn't implement the changes to `SteamAPI_ISteamNetworkingUtils_GetFirstConfigValue`, I instead removed it altogether as we weren't using it anyway.
Did some testing with this today and sadly it still seems to be borked with bigger factories. If the client tries to connect to a planet with a large factory it will just hang on requesting factory data, and if a client connects to an empty planet and then travels to a larger planet the planet will never load in (and humorously the player's mecha will be tied to that planet forever, and if they try to go further than 1000 meters away the camera will disconnect from the mecha). Another note is that the size of the factory that this happens with varies from client to client. I was able to load in to a particular planet that another client was unable to. I didn't have the proper logging enabled to see what the size of the planets were at the time so this isn't super helpful but it's just something to note. |
…ckets # Conflicts: # NebulaNetwork/Client.cs # NebulaNetwork/PacketProcessors/Session/PingPacketProcessor.cs # NebulaNetwork/Server.cs # dep/websocket-sharp
This PR replaces websockets with GameNetworkingSockets by Valve.
A few caveats with this PR:
I benchmarked the library and managed to get 8.5MB/s of throughput (hard limit of GNS, will PR an increase with Valve).
It's supposed to work fine on other platforms, untested.