Fix 'Attempted to remove invalid ID' errors
This commit is contained in:
parent
f2efa6f4f3
commit
e8877806ec
4 changed files with 18 additions and 18 deletions
18
.github/workflows/linux_builds.yml
vendored
18
.github/workflows/linux_builds.yml
vendored
|
@ -70,12 +70,12 @@ jobs:
|
||||||
run: |
|
run: |
|
||||||
./bin/godot.linuxbsd.opt.tools.64 --test
|
./bin/godot.linuxbsd.opt.tools.64 --test
|
||||||
|
|
||||||
# Download, unzip and setup SwiftShader library [d4550ab8d3f]
|
# Download, unzip and setup SwiftShader library [4466040]
|
||||||
- name: Download SwiftShader
|
- name: Download SwiftShader
|
||||||
run: |
|
run: |
|
||||||
wget https://github.com/qarmin/gtk_library_store/releases/download/3.24.0/swiftshader.zip
|
wget https://github.com/qarmin/gtk_library_store/releases/download/3.24.0/swiftshader2.zip
|
||||||
unzip swiftshader.zip
|
unzip swiftshader2.zip
|
||||||
rm swiftshader.zip
|
rm swiftshader2.zip
|
||||||
curr="$(pwd)/libvk_swiftshader.so"
|
curr="$(pwd)/libvk_swiftshader.so"
|
||||||
sed -i "s|PATH_TO_CHANGE|$curr|" vk_swiftshader_icd.json
|
sed -i "s|PATH_TO_CHANGE|$curr|" vk_swiftshader_icd.json
|
||||||
|
|
||||||
|
@ -144,12 +144,10 @@ jobs:
|
||||||
scons --version
|
scons --version
|
||||||
|
|
||||||
# We should always be explicit with our flags usage here since it's gonna be sure to always set those flags
|
# We should always be explicit with our flags usage here since it's gonna be sure to always set those flags
|
||||||
# [Workaround] SwiftShader doesn't support tessellation, so we skip Godot check about it
|
|
||||||
- name: Compilation
|
- name: Compilation
|
||||||
env:
|
env:
|
||||||
SCONS_CACHE: ${{github.workspace}}/.scons_cache/
|
SCONS_CACHE: ${{github.workspace}}/.scons_cache/
|
||||||
run: |
|
run: |
|
||||||
sed -i "s|ERR_FAIL_COND_V(p_rasterization_state.patch_control_points|//ERR_FAIL_COND_V(p_rasterization_state.patch_control_points|" drivers/vulkan/rendering_device_vulkan.cpp
|
|
||||||
scons tools=yes tests=yes target=debug debug_symbols=no use_asan=yes use_ubsan=yes
|
scons tools=yes tests=yes target=debug debug_symbols=no use_asan=yes use_ubsan=yes
|
||||||
ls -l bin/
|
ls -l bin/
|
||||||
|
|
||||||
|
@ -158,12 +156,12 @@ jobs:
|
||||||
run: |
|
run: |
|
||||||
./bin/godot.linuxbsd.tools.64s --test
|
./bin/godot.linuxbsd.tools.64s --test
|
||||||
|
|
||||||
# Download, unzip and setup SwiftShader library [d4550ab8d3f]
|
# Download, unzip and setup SwiftShader library [4466040]
|
||||||
- name: Download SwiftShader
|
- name: Download SwiftShader
|
||||||
run: |
|
run: |
|
||||||
wget https://github.com/qarmin/gtk_library_store/releases/download/3.24.0/swiftshader.zip
|
wget https://github.com/qarmin/gtk_library_store/releases/download/3.24.0/swiftshader2.zip
|
||||||
unzip swiftshader.zip
|
unzip swiftshader2.zip
|
||||||
rm swiftshader.zip
|
rm swiftshader2.zip
|
||||||
curr="$(pwd)/libvk_swiftshader.so"
|
curr="$(pwd)/libvk_swiftshader.so"
|
||||||
sed -i "s|PATH_TO_CHANGE|$curr|" vk_swiftshader_icd.json
|
sed -i "s|PATH_TO_CHANGE|$curr|" vk_swiftshader_icd.json
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@ import sys
|
||||||
|
|
||||||
if len(sys.argv) < 2:
|
if len(sys.argv) < 2:
|
||||||
print("ERROR: You must run program with file name as argument.")
|
print("ERROR: You must run program with file name as argument.")
|
||||||
sys.exit(1)
|
sys.exit(50)
|
||||||
|
|
||||||
fname = sys.argv[1]
|
fname = sys.argv[1]
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ file_contents = fileread.read()
|
||||||
|
|
||||||
if file_contents.find("ERROR: AddressSanitizer:") != -1:
|
if file_contents.find("ERROR: AddressSanitizer:") != -1:
|
||||||
print("FATAL ERROR: An incorrectly used memory was found.")
|
print("FATAL ERROR: An incorrectly used memory was found.")
|
||||||
sys.exit(1)
|
sys.exit(51)
|
||||||
|
|
||||||
# There is also possible, that program crashed with or without backtrace.
|
# There is also possible, that program crashed with or without backtrace.
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@ if (
|
||||||
or file_contents.find("Segmentation fault (core dumped)") != -1
|
or file_contents.find("Segmentation fault (core dumped)") != -1
|
||||||
):
|
):
|
||||||
print("FATAL ERROR: Godot has been crashed.")
|
print("FATAL ERROR: Godot has been crashed.")
|
||||||
sys.exit(1)
|
sys.exit(52)
|
||||||
|
|
||||||
# Finding memory leaks in Godot is quite difficult, because we need to take into
|
# Finding memory leaks in Godot is quite difficult, because we need to take into
|
||||||
# account leaks also in external libraries. They are usually provided without
|
# account leaks also in external libraries. They are usually provided without
|
||||||
|
@ -38,7 +38,7 @@ if (
|
||||||
if file_contents.find("ERROR: LeakSanitizer:") != -1:
|
if file_contents.find("ERROR: LeakSanitizer:") != -1:
|
||||||
if file_contents.find("#4 0x") != -1:
|
if file_contents.find("#4 0x") != -1:
|
||||||
print("ERROR: Memory leak was found")
|
print("ERROR: Memory leak was found")
|
||||||
sys.exit(1)
|
sys.exit(53)
|
||||||
|
|
||||||
# It may happen that Godot detects leaking nodes/resources and removes them, so
|
# It may happen that Godot detects leaking nodes/resources and removes them, so
|
||||||
# this possibility should also be handled as a potential error, even if
|
# this possibility should also be handled as a potential error, even if
|
||||||
|
@ -46,7 +46,7 @@ if file_contents.find("ERROR: LeakSanitizer:") != -1:
|
||||||
|
|
||||||
if file_contents.find("ObjectDB instances leaked at exit") != -1:
|
if file_contents.find("ObjectDB instances leaked at exit") != -1:
|
||||||
print("ERROR: Memory leak was found")
|
print("ERROR: Memory leak was found")
|
||||||
sys.exit(1)
|
sys.exit(54)
|
||||||
|
|
||||||
# In test project may be put several assert functions which will control if
|
# In test project may be put several assert functions which will control if
|
||||||
# project is executed with right parameters etc. which normally will not stop
|
# project is executed with right parameters etc. which normally will not stop
|
||||||
|
@ -54,7 +54,7 @@ if file_contents.find("ObjectDB instances leaked at exit") != -1:
|
||||||
|
|
||||||
if file_contents.find("Assertion failed") != -1:
|
if file_contents.find("Assertion failed") != -1:
|
||||||
print("ERROR: Assertion failed in project, check execution log for more info")
|
print("ERROR: Assertion failed in project, check execution log for more info")
|
||||||
sys.exit(1)
|
sys.exit(55)
|
||||||
|
|
||||||
# For now Godot leaks a lot of rendering stuff so for now we just show info
|
# For now Godot leaks a lot of rendering stuff so for now we just show info
|
||||||
# about it and this needs to be re-enabled after fixing this memory leaks.
|
# about it and this needs to be re-enabled after fixing this memory leaks.
|
||||||
|
|
|
@ -222,7 +222,7 @@ void RendererCompositorRD::set_boot_image(const Ref<Image> &p_image, const Color
|
||||||
|
|
||||||
RD::get_singleton()->swap_buffers();
|
RD::get_singleton()->swap_buffers();
|
||||||
|
|
||||||
RD::get_singleton()->free(texture);
|
storage->free(texture);
|
||||||
}
|
}
|
||||||
|
|
||||||
RendererCompositorRD *RendererCompositorRD::singleton = nullptr;
|
RendererCompositorRD *RendererCompositorRD::singleton = nullptr;
|
||||||
|
|
|
@ -146,8 +146,10 @@ void ShaderRD::_clear_version(Version *p_version) {
|
||||||
//clear versions if they exist
|
//clear versions if they exist
|
||||||
if (p_version->variants) {
|
if (p_version->variants) {
|
||||||
for (int i = 0; i < variant_defines.size(); i++) {
|
for (int i = 0; i < variant_defines.size(); i++) {
|
||||||
|
if (variants_enabled[i]) {
|
||||||
RD::get_singleton()->free(p_version->variants[i]);
|
RD::get_singleton()->free(p_version->variants[i]);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
memdelete_arr(p_version->variants);
|
memdelete_arr(p_version->variants);
|
||||||
if (p_version->variant_data) {
|
if (p_version->variant_data) {
|
||||||
|
|
Loading…
Reference in a new issue