-
Notifications
You must be signed in to change notification settings - Fork 181
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
Builds of RSDKv4 Crash with -Wp,-D_FORTIFY_SOURCE=3
crash when loading Modded Content
#440
Comments
All decomps are actually kinda broken when |
I did actually try applying #439 , something on boot however is tripping ASan nonetheless. Will report back later. Am extremely sleepy. I haven't had the chance to check what it is yet (because I was testing with PKGBUILD and that was stripping symbols). |
No worries, I'll do some research on my end as well. |
On RSDKv4 the engine actually crashes during script parsing, for example in S314P:
On this line: StrCopy(scriptFunctionList[scriptFunctionCount++].name, funcName); The function name is to blame, it's apparently too long for the script compiler to handle (original code limitation): struct ScriptFunction {
byte access;
#if RETRO_USE_COMPILER
char name[0x20];
#endif
ScriptPtr ptr;
}; My guess as to why it doesn't completely break when |
I just woke up, and oh, I can actually answer this (from my phone, even). You're on the money. See the log:
It says On a 64-bit system I would expect the struct layout to be the following:
ScriptPtr are two In this case because the string length is 33, it writes into the first byte of the padding between name and Hopefully this should align with what you're thinking. |
This is exactly what happens yes, you can easily test this by editing the script file to extend We've double checked on Sonic Origins and the behavior is identical, so this isn't technically a decomp specific bug, but rather an undocumented script limitation that some mods don't adhere to. |
What would be the following steps for a bug lile this then. Don't know the standard procedures for the repo. Would you be extending the limit when the I imagine in any case, mod authors should be warned when they make names that are too long. Most important thing I imagine is showing a MessageBox with the error details, but I'm not sure that would be the best approach given all the external forks that aren't X11/Wayland/Win32 etc. I would imagine an in-game message may be more annoying to show. But it may also be fine on the other hand to just MessageBox, not too many people writing scripts directly on homebrewed consoles. |
We won't be extending the limit, since we want to keep parity with the official engine/Origins, but it may be worth adding a check for the function name length when that flag is disabled instead.
As seen above, there's already a system for in-game script error messages, so it wouldn't be that annoying. |
Ah, I see. I was more worried in an edge case where scripts may be loaded before the person making the mods could get into the Dev Menu itself; but I don't know the exact internals of how RSDK works. Specifically if a user were to enable a mod, close the game, and reopen it. If the script kicks and causes an overflow before the user can get into Dev Menu to see the error, that'd be problematic. |
Depends. In that particular case this bug is accurate to the original, but can cause issues if the name is >=35 chars long.
The screenshot above is basically as close as we can get from a cross platform message box, and is actually what we implemented in the past here. We could definitely do something like this. |
Let's wait until SHC is over before breaking stuff 😅 |
I think there's also another caveat to mention here. An end user loading a mod should expect it to 'just work', regardless of when the mod was made.
The common element here, is mods within these categories may not be updated anymore. In other words, mods in those categories rely on the fact that the name buffer can be <=34 chars long rather than the intended <= 32 chars. Regardless of whether it is technically implementation detail due to compiler inserted padding; it worked in past official builds, so it's now considered part of the 'API contract' so to speak. |
This is what my fix proposal aimed to do, but we're very lucky that it can be done here. We're sometimes forced to make breaking changes for the sake of accuracy (supporting Origins updates or just genuine inaccuracies like script syntax being different than the original) and general stability (undefined behaviors, non big-endian friendly code...). It's also not feasible to maintain For fixes that can easily be backwards compatible like this one though? Goes without saying. |
Before opening this issue, I ensure that...
Expected Behavior
Loading a stage with mod(s) enabled should not crash the process.
Actual Behavior
Loading a stage with mod(s) enabled crashes the process.
Steps to Reproduce
For convenience, I provide a sample
PKGBUILD
for Arch based distros below:[On other Distros you can use CLI as usual]
This can be used with any Arch based distro with
makepkg -si
, ormakepkg -siCf
to force a clean rebuild.In this PKGBUILD I specifically set the
CFLAGS
,CXXFLAGS
andLDFLAGS
explicitly for testing purposes.I set them to the default values you would encounter in
/etc/makepkg.conf
on any Arch based distro.When building with
-Wp,-D_FORTIFY_SOURCE=3
the Application crashes.This is likely indicative of a buffer overrun somewhere in RSDKv4 decomp.
I don't currently know where; my experience with C stuff is very little and
I'm kind of in a rush to get SHC2024 entry evals done. 😅
Running with AddressSanitizer/asan, there's an unrelated buffer overrun on boot,
so I haven't gotten around to catching the actual issue (yet).
Reproduction Steps:
S314P can be used for testing, but I've experienced this in just about every mod.
Screenshots
No response
Log File
No response
Decompilation Version
1.3.2
Game
Sonic 2
Game Version
Mobile (Pre-Sega Forever)
Game Revision
No response
Platform
Linux x64 (Linux 6.11.0-5-cachyos-lto, x86-64-v3)
Additional Comments
No response
The text was updated successfully, but these errors were encountered: