-
-
Notifications
You must be signed in to change notification settings - Fork 21.5k
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
Error spam (and/or crash) in release template / exported builds: "slot >= slot_max" is true. Returning: nullptr
#70910
Comments
In general I feel like a lot of Godot error messages that come from the c++ code could be a bit more verbose. As far as I can tell from the code (I am not great at c++) it has something to do with signals. I have no idea what a slot is or what the slot_max value is based on. I will look into it more when I have time but if anyone has any insight in the mean time that would be appreciated. |
Looking into it further, the objects being created are subscribing to events. Is it possible that there is an issue with having too many subscriptions to the same event? If so I can work out a different way of passing these changes around. |
This appears to be fixed in beta 12. I will do some more testing and confirm |
Still happening on windows |
While attempting to get debugging working on windows, I discovered that when the client is built on a windows machine, the issue does not happen. This means that it only happens when building a windows build on a linux system. This makes the bug less urgent but also easier to reproduce. I will update the reproduction. |
When you say "built on a Linux system", do you mean exporting the project with the official pre-compiled export templates, or are you compiling custom export templates with mingw? |
exporting the project with the official pre-compiled export templates |
I tried to reproduce it by exporting from Linux with 4.0 beta 13, and running the project in Wine, but it doesn't seem to crash. (FYI for testers, the repo requires the Mono build of Godot.) As a side note, I had an error when exporting:
But it's not necessarily related. This file is missing your GitLab repo. Also had this error, which I suspect is a bug in the Mono module:
|
thanks for trying, while I was thinking about your last question it occurred to me that I started exporting in a slightly different way at around the same time this started happening. I wrote a bash script that deploys the whole project. The script includes the lines:
Is this correct? Is it possible that this is required for the reproduction? I have no idea why it is still asking for 'res://Themes/MainTheme.tres', that was removed some time ago and I can't find any remaining references to it. |
My first test seems to confirm it is the script. Is it maybe the fact that the script builds release and when I do it by hand the default is debug? |
|
I was more asking if that could be causing the crash. I suppose I need to test that for myself though. |
Yes a release export is more likely to crash than a debug export, as it does less validation checks to save performance. But it would usually point out the error in debug mode. |
I did further tests and I am able to build a debug version on linux for windows and it does not crash. I will do a test to see how the windows -> windows release build does. Edit: Ok I have confirmed that this has nothing to do with linux at all. Building a release version on windows for windows crashes in the same way. I also spent some more time trying to decipher the engine code but the best I could do is figure out that some RID is not being initialised correctly. Is there someone who knows this part of the code that could possibly shed some light on why my project and PauloVBettio's project are affected an not others? I have to assume this is not affecting everyone or it would have been noticed sooner and by more people. |
Building the game on an Windows machine gave me the same result as @Dunkhan. The game only shows the splash screen and crashes. |
I encountered a similar issue with an Android project on Godot 4 recently. No noticed problems until switching to release builds which would have lots of screen layout issues and occasional crashes, accompanied by the ‘slot_max’ error logs. I believe the error message is just a symptom of referencing an invalid object. In my case I was adding and removing Controls to Containers with GDScript but invalidly using Object.free() on the child before it was implicitly removed. Presumably, this was causing the container to read the already free’d memory with undefined results. The debug builds probably have some safety checks which result in the memory staying valid for longer. Changing my code to explicitly call Container.remove_child() and use child.queue_free() fixed the issue. |
So you have to remove the child and then free it? Why is there nothing about this in the documentation? This article specifically does not mention this. Neither does the node page. |
I am also getting spammed with
on Ubuntu when a level is being loaded with a so the main issue seems to me that this error message is entirely cryptic to users. |
I noticed I am also getting this error on linux builds, regardless of release or debug. There appear to be no symptoms in the programs behaviour though. |
According to the code comments, "This should never happen unless RID is corrupted." So it cannot really be made less cryptic, since this seems to be a critical failure causing invalid data. Would be amazing to get a small, purpose-built MRP to find the culprit. |
The stability of the last few beta releases with my project, and the amount of things that have randomly broken with no documentation or debug output, suggest to me that we should probably be testing with larger projects like this more. A small purpose built MRP is great for resolving a single issue, if the problem can be narrowed down that far, but there is no substitute for testing with scenarios that mirror real world usage. I predict that a lot of hidden bugs that only manifest in more complex use-cases are going to make the 4.0 release a real headache for a lot of people that migrate on release day. Edit: sorry if this sounds dismissive, of course I would love to help narrow down the cause of this. I just wanted to mention some general concerns I have as well. RC2 is also a lot more stable than most of the recent versions and there are some very nice fixes so things are looking good in general. |
I'd like to chime in, I'm also having this exact error when running the demo for my libsm64-godot addon on Linux every time, both in debug and release, but never on my Windows build. The addon has a GDExtension module in it which is compiled through the included GitHub action in the .github folder on a Ubuntu runner. |
I also had this error occur when building for Windows Desktop and Web, building from Windows 10 on Godot 4.0 stable. It happened when I cleared objects in a UI container with a for loop. Debug builds ran fine without errors, only release builds seem to be affected which makes it a particularly nasty bug. It's easy to reproduce, here's a quick example.
|
I am having this same error when building to linux or windows, again if I export it with DEBUG it works fine, really nasty bug and no real fix:
Edit: I was able to fix this by changing the scenes from load() to preload() and changing the scene with this code:
|
Also crashes release builds in MacOS (arm64) about once every six executions. About one in four executions report no errors, the rest report a series of The crash occassionally reports something like this:
All debug builds run perfectly and report no issues with verbose output. |
didn't fix this error for me :( |
This error occurs for me when I unloaded and loaded a bunch of new nodes into the tree, there was never a scene change involved. Fiddling with the way things were loaded sometimes helped but it appears to be populating the tree that is the issue and not scene loading directly. |
I was finally able to reproduce this bug and prevent it from happening (so far). In my case it is caused by removing children from a parent, immediately followed by adding new children to the same parent. Internally, the parent node appears very sensitive to being blocked by removing children while adding a new child is being attempted. In my case the parent is a Only this combination of steps prevents the errors:
It may also work to use a process, while or await to test that the children have been completely removed and freed prior to adding new children. If you need to handle a child after it's been added to the tree, you can use the So if the above fix is applied to the example from @sine707:
It would look like this (untested):
|
Your reproduction matches my experience very closely. As far as the solution goes I found that using multiple defers did not always solve the problem though. This might be because I am using threads in c# so I was having difficulty establishing exactly when things happen and working out how to ensure that everything happens in the right order. Hopefully this helps someone debug the internal functions though so we can make the behaviour more stable in the engine. |
I'm not sure what happened between Godot 3 and Godot 4, but I have managed to make a MRP that seems to consistently triggers the bug when exported. @YuriSizov hopefully this can be of some use. This code will trigger 2 error messages: for i in range(100):
var label = Label.new()
label.text = "%d" % i
$VBoxContainer.add_child(label)
for child in $VBoxContainer.get_children():
child.free() This code however will cause a spew of error message: for i in range(100):
var label = Label.new()
label.text = "%d" % i
$VBoxContainer.add_child(label)
for child in $VBoxContainer.get_children():
child.free()
for i in range(100):
var label = Label.new()
label.text = "-%d" % i
$VBoxContainer.add_child(label) I have currently "fixed" this by purging MRP |
I have this same exact issue, the game crashes when I have a release build for Windows and never in debug or in the editor. It's really frustrating because I have turned my project that I worked on for about 2 years inside-out just because of trying to hunt down this error... It seems to appear during run time when I change a scene.. As mentioned before by other people here, using I should probably say I'm using Godot 4.1.1.stable, and here's the error because why not: I'd love to have a fix to this, I really don't want my project of 2 years to go to waste. And this error seems to appear for quite a few people so this does seem to need fixing. |
I am getting this error too and sad to see that there is apparently no fix for it... :( |
@pshepjr In case your issue is also crashing upon scene change, see this comment from gmjosack #75422 (comment), it seems to have fixed it for me! In terms of the I read that for Godot 4.2 they'll be focusing on stability so that's nice. Hope that helps mate! |
I had a crash following this error in 4.2 dev 5, only in release builds. My code causing the crash was like this:
Changing to this (calling QueueFree() immediately instead of deferring it) seems to avoid the crash on Windows and Linux
|
I can confirm the issue in 4.2-rc1 with @Capital-EX's MRP from #70910 (comment) I can also clarify that this only happens with release templates ( Actually with that project in 4.1.3-stable Linux release template I get an endless error spam of the
I'll try to compile a release template with debug symbols to get a stacktrace. Edit: I don't reproduce the crash with a custom build with Edit 2: I moved the issue with the 4.2-specific crash to #85263 as it's not fully equivalent to the original bug report here. It's probably triggered by the same bug, but likely also by something 4.2 specific since it doesn't appear in 4.1, unlike the |
"slot >= slot_max" is true. Returning: nullptr
"slot >= slot_max" is true. Returning: nullptr
"slot >= slot_max" is true. Returning: nullptr
Godot version
4.0 beta 10
System information
Windows 10
Issue description
In my rss reader on windows, when the user switches between feed lists - that is, when a VBoxContainer has all its children removed and a new set re-added, the application crashes with:
USER ERROR: Condition "slot >= slot_max" is true. Returning: nullptr
at: get_instance (./core/object/object.h:974)
This only happens on the windows version and only when that version is built in release mode. In an earlier beta (7 or 10 I am not sure) it was happening occasionally on the linux build too, but that no longer appears to be an issue. I was not able to find any information or other bug reports about this error.
Steps to reproduce
I have no simple minimal reproduction available, but it is fairly constant in my current project. You can find the source here:
https://gitlab.com/gametheatre/poriferareader/Porifera
Because this appears to be an issue with the build system it is likely that it will be a major hassle to debug. Let me know if there is any help I can offer.
Minimal reproduction project
As mentioned above it is consistently reproducible with this (non minimal) project: https://gitlab.com/gametheatre/poriferareader/Porifera
As a temporary workaround, only creating debug builds for windows solves this.
The text was updated successfully, but these errors were encountered: