summaryrefslogtreecommitdiffstats
path: root/thirdparty
diff options
context:
space:
mode:
Diffstat (limited to 'thirdparty')
-rw-r--r--thirdparty/README.md2
-rw-r--r--thirdparty/enet/godot.cpp19
-rw-r--r--thirdparty/spirv-reflect/patches/1-specialization-constants.patch (renamed from thirdparty/spirv-reflect/patches/specialization-constants.patch)0
-rw-r--r--thirdparty/spirv-reflect/patches/2-zero-size-for-sc-sized-arrays.patch18
-rw-r--r--thirdparty/spirv-reflect/spirv_reflect.c7
5 files changed, 40 insertions, 6 deletions
diff --git a/thirdparty/README.md b/thirdparty/README.md
index 9a56f6baa4..47618d675b 100644
--- a/thirdparty/README.md
+++ b/thirdparty/README.md
@@ -845,7 +845,7 @@ Files extracted from upstream source:
Some downstream changes have been made and are identified by
`// -- GODOT begin --` and `// -- GODOT end --` comments.
They can be reapplied using the patches included in the `patches`
-folder.
+folder, in order.
## squish
diff --git a/thirdparty/enet/godot.cpp b/thirdparty/enet/godot.cpp
index ecf0a7e6dd..9e766e52c3 100644
--- a/thirdparty/enet/godot.cpp
+++ b/thirdparty/enet/godot.cpp
@@ -299,7 +299,12 @@ public:
Error sendto(const uint8_t *p_buffer, int p_len, int &r_sent, IPAddress p_ip, uint16_t p_port) {
String key = String(p_ip) + ":" + itos(p_port);
- ERR_FAIL_COND_V(!peers.has(key), ERR_UNAVAILABLE);
+ if (unlikely(!peers.has(key))) {
+ // The peer might have been disconnected due to a DTLS error.
+ // We need to wait for it to time out, just mark the packet as sent.
+ r_sent = p_len;
+ return OK;
+ }
Ref<PacketPeerDTLS> peer = peers[key];
Error err = peer->put_packet(p_buffer, p_len);
if (err == OK) {
@@ -307,7 +312,10 @@ public:
} else if (err == ERR_BUSY) {
r_sent = 0;
} else {
- r_sent = -1;
+ // The peer might have been disconnected due to a DTLS error.
+ // We need to wait for it to time out, just mark the packet as sent.
+ r_sent = p_len;
+ return OK;
}
return err;
}
@@ -331,7 +339,7 @@ public:
Error err = ERR_BUSY;
// TODO this needs to be fair!
- for (KeyValue<String, Ref<PacketPeerDTLS>> & E : peers) {
+ for (KeyValue<String, Ref<PacketPeerDTLS>> &E : peers) {
Ref<PacketPeerDTLS> peer = E.value;
peer->poll();
@@ -349,7 +357,8 @@ public:
if (err != OK || p_len < r_read) {
// Something wrong with this peer, removing it.
remove.push_back(E.key);
- err = FAILED;
+ err = ERR_BUSY;
+ r_read = 0;
continue;
}
@@ -549,7 +558,7 @@ int enet_socket_receive(ENetSocket socket, ENetAddress *address, ENetBuffer *buf
return read;
}
-int enet_socket_get_address (ENetSocket socket, ENetAddress * address) {
+int enet_socket_get_address(ENetSocket socket, ENetAddress *address) {
IPAddress ip;
uint16_t port;
ENetGodotSocket *sock = (ENetGodotSocket *)socket;
diff --git a/thirdparty/spirv-reflect/patches/specialization-constants.patch b/thirdparty/spirv-reflect/patches/1-specialization-constants.patch
index ff11841451..ff11841451 100644
--- a/thirdparty/spirv-reflect/patches/specialization-constants.patch
+++ b/thirdparty/spirv-reflect/patches/1-specialization-constants.patch
diff --git a/thirdparty/spirv-reflect/patches/2-zero-size-for-sc-sized-arrays.patch b/thirdparty/spirv-reflect/patches/2-zero-size-for-sc-sized-arrays.patch
new file mode 100644
index 0000000000..dbf6069d07
--- /dev/null
+++ b/thirdparty/spirv-reflect/patches/2-zero-size-for-sc-sized-arrays.patch
@@ -0,0 +1,18 @@
+diff --git a/thirdparty/spirv-reflect/spirv_reflect.c b/thirdparty/spirv-reflect/spirv_reflect.c
+index c96dd85439..2ca9c8580d 100644
+--- a/thirdparty/spirv-reflect/spirv_reflect.c
++++ b/thirdparty/spirv-reflect/spirv_reflect.c
+@@ -2692,6 +2692,13 @@ static SpvReflectResult ParseDescriptorBlockVariableSizes(SpvReflectPrvParser* p
+ // ...then array
+ uint32_t element_count = (p_member_var->array.dims_count > 0 ? 1 : 0);
+ for (uint32_t i = 0; i < p_member_var->array.dims_count; ++i) {
++// -- GODOT begin --
++ if (p_member_var->array.spec_constant_op_ids[i] != (uint32_t)INVALID_VALUE) {
++ // Force size to be reported as 0 to effectively disable buffer size validation, since
++ // the value is unreliable anyway as only valid for the default values of the SCs involved.
++ element_count = 0;
++ }
++// -- GODOT end --
+ element_count *= p_member_var->array.dims[i];
+ }
+ p_member_var->size = element_count * p_member_var->array.stride;
diff --git a/thirdparty/spirv-reflect/spirv_reflect.c b/thirdparty/spirv-reflect/spirv_reflect.c
index c96dd85439..d6c926b40a 100644
--- a/thirdparty/spirv-reflect/spirv_reflect.c
+++ b/thirdparty/spirv-reflect/spirv_reflect.c
@@ -2692,6 +2692,13 @@ static SpvReflectResult ParseDescriptorBlockVariableSizes(SpvReflectPrvParser* p
// ...then array
uint32_t element_count = (p_member_var->array.dims_count > 0 ? 1 : 0);
for (uint32_t i = 0; i < p_member_var->array.dims_count; ++i) {
+// -- GODOT begin --
+ if (p_member_var->array.spec_constant_op_ids[i] != (uint32_t)INVALID_VALUE) {
+ // Force size to be reported as 0 to effectively disable buffer size validation, since
+ // the value is unreliable anyway as only valid for the default values of the SCs involved.
+ element_count = 0;
+ }
+// -- GODOT end --
element_count *= p_member_var->array.dims[i];
}
p_member_var->size = element_count * p_member_var->array.stride;