-
Notifications
You must be signed in to change notification settings - Fork 20
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
PATCHOPENSSL needs to be updated for 64 bit AM2R 1.6 #56
Comments
@peeley can you look into this? Maybe we'll need some hash check on whether we have the old runner before running patchelf on it. Not sure. |
Also just to make sure, @SuperSamus can you patch this without the OPENSSL flag to ensure it's actually a problem of what we do with patchelf, rather than your local dependencies? As the 1.6 requires a few different ones. |
Without the All of this using the same dependencies I was using before (but 64 bit instead of 32 bit). |
and just as double confirmation, if you LD_LIBRARY_PATH those libs with the |
Exactly. |
Sure, I'll take a look. There's no README for that repo, so I assumed that all I needed to do was unzip the release I'm able to reproduce the issue as well, although I haven't tried the |
Alternatively to
Where inside the profile you put a lib folder with the 64 bit libraries Seriously, this is horrible... |
Sorry, I completely forgot to provide installations instructions <-< |
Thanks, I was able to do that and observe the same behavior. The game crashes and complains about a missing symbol for OpenSSL.
Yeah, I hate it too :(. Unfortunately, there seems like no other realistic workaround other than AppImage (which is not an option for distros like NixOS). I've made a branch of the launcher that depends on another branch of the patcher as a rough proof of concept, that does just this. I'm able to start the launcher, add 1.6 beta as a mod, install, and start the game. Let me know if it also works on your machines, and if it's a viable path forward. Apologies if there's any glaring errors, btw - I'm fairly ill at the moment. |
For what it's worth, the wrapper we're using for 1.6 is a few versions behind the theoretical maximum version number to which we could climb. It is possible, though by no means guaranteed, that the theoretical maximum could be using a newer version of openssl. It's on my list to go see if I can find a clean set of game wrappers for that maximum version number, but 1.6 development has stalled for the moment due to higher priority items in my day-to-day. |
That would be super nice. Even a relatively small bump up to OpenSSL 1.1 would make things much easier when it comes to packaging. |
Unless we can absolutely not find a workaround, I would very much try to avoid this as much as possible. I would try to see if maybe one has to provide different patchelf arguments. I know the previous version of the runner didnt use curl/openssl at all, I'm not sure if this is still the case here. I'll go see if i can reach Ivar, she was the one who initially pushed this forward. |
Huh, I was just able to launch the 1.6 beta after tweaking the
The I have a branch for the launcher that's working so far. If it checks out for you all as well, I can make a PR. |
I'm not entirely sold on just removing that symbol without further context since we want to ensure that the multiplayer mods can update to 1.6 as well. Base AM2R may not touch any part of GameMaker that uses that function, but given that it's OpenSSL I would anticipate that the network functions may do so. Any idea what operations the function in question is being used for? |
It's not actually removing the symbol in question, it's just removing the version information from it. That being said, since we're already patching OpenSSL 1.0.0 with libcurl, I can't vouch that it still functions 1:1. I can only guess what the function does without reading the source, but it looks like it's something to do with allocating/deallocating C structs from memory that represent X509 certificates for SSL/TLS connections (docs). |
Ah, thank you for the clarification. Intriguing that there's a call to free this structure but not one to instantiate the same structure under this specific version... I'll leave the final call up to Miepee, as this is much more his realm of expertise, but that all sounds reasonable enough to me for now. |
Tested the branch on both 32 bit and 64 bit AM2R, game launches on both. |
Ayyy, nice. Based on SuperSamus' description above, sounds like you dont even need to check for different runners. So I don't mind if you'd open a PR for both the linux patcher and from that launcher branch. Altho i do wonder if this is actually true now:
I did look at it in ghidra aaages ago. Based on DMs with Johnny, it seems that openssl is only used if a game maker game uses the http functions (https_request, http_get, https_get_file, http_post_string). Current multitroid to my knwoedge doesn't use these, and neither some other network based GM games like metroid planets do AFAIK. as these functions are only useful for interacting with a webserver. |
Downloaded the server release, unzipped it, and ran:
It was able to launch and run without a hitch. I also downloaded Multitroid as a mod, and got it to launch and run. I was able to get two clients (one on the same machine as the server, I don't have three different Linux machines to test from unfortunately) connected and playing in multiplayer as expected. I hadn't played Multitroid before; I'm actually pretty surprised how simple it was to set up and how seamless the experience was. All I needed to do was edit the server IP and the display name in each client, and it was smooth sailing. |
Have been experimenting with a 64bit version of multitroid, had not much success, so will document the process here.
To patch the server:
This will give you a patched game.unx file. At this point, I am able to run both the server and the client. however, attempting to connect to the server, just times out. Looking at wireshark, it does capture two packets, but I'm currently not knowledgeable enough to figure out what the packets exactly do: out of curiosity, I also tried running your patchelf command on it, but then i just got hit with:
I don't think I have missing dependencies (got both (lib32-)openssl-1.1 and openssl-1.0 from the AUR), especially since it works without patchelf. But y'all are probably able to judge it better. |
Hmm, I'm getting a weird crash on launch with the 1.4 version of the server. Whether unpatched or patched for 64-bit using the directions above, it seems like the server opens a window and then immediately crashes. Not sure if it means anything, but it seems to be consistently segfault before the
I'm guessing this might be an issue with symbol versioning information. Some distros strip version info from packaged Also - might we move the multiplayer discussion to a separate issue? It seems like the original problem with running the 1.6 beta has been more or less solved. |
opened an issue at PG64, lets continue the multitroid specific discussion there |
Describe the bug
PATCHOPENSSL
is an option meant for Linux distributions that don't offer OpenSSL 1.0.0 (because it's old and insecure). 5d8b7d9When using the new 64 bit AM2R 1.6 beta, however, the executable is patched incorrectly.
EDIT: Forgot to specify that I'm also using
NOAPPIMAGE
.Expected behavior
The executable is patched correctly, and can be launched.
To Reproduce
Steps to reproduce the behavior:
PATCHOPENSSL
Platform
Log file
When the runner is launched, it logs (to gather the logs, I launched it outside the launcher):
The text was updated successfully, but these errors were encountered: