summaryrefslogtreecommitdiffstats
path: root/servers
diff options
context:
space:
mode:
authorMatias N. Goldberg <dark_sylinc@yahoo.com.ar>2024-11-06 20:03:56 -0300
committerMatias N. Goldberg <dark_sylinc@yahoo.com.ar>2024-11-06 20:03:56 -0300
commite69a0c7d60ea4b0401558da4b48bdc2fe1e87edd (patch)
treeba2a16feeafca13664d96f4d17c147b7af01d975 /servers
parentef8d981267702de38ffc24136f9d823d31781c60 (diff)
downloadredot-engine-e69a0c7d60ea4b0401558da4b48bdc2fe1e87edd.tar.gz
Force RID::id to be always uint64_t
On Vulkan, some handles are meant to always be u64, even on 32-bit architectures such as arm32. Fixes #98654
Diffstat (limited to 'servers')
-rw-r--r--servers/rendering/rendering_device_driver.h10
1 files changed, 4 insertions, 6 deletions
diff --git a/servers/rendering/rendering_device_driver.h b/servers/rendering/rendering_device_driver.h
index 953401e9bd..7ff501a01a 100644
--- a/servers/rendering/rendering_device_driver.h
+++ b/servers/rendering/rendering_device_driver.h
@@ -120,9 +120,9 @@ struct VersatileResourceTemplate {
class RenderingDeviceDriver : public RenderingDeviceCommons {
public:
struct ID {
- size_t id = 0;
+ uint64_t id = 0;
_ALWAYS_INLINE_ ID() = default;
- _ALWAYS_INLINE_ ID(size_t p_id) :
+ _ALWAYS_INLINE_ ID(uint64_t p_id) :
id(p_id) {}
};
@@ -138,11 +138,9 @@ public:
_ALWAYS_INLINE_ bool operator!=(const m_name##ID &p_other) const { return id != p_other.id; } \
_ALWAYS_INLINE_ m_name##ID(const m_name##ID &p_other) : ID(p_other.id) {} \
_ALWAYS_INLINE_ explicit m_name##ID(uint64_t p_int) : ID(p_int) {} \
- _ALWAYS_INLINE_ explicit m_name##ID(void *p_ptr) : ID((size_t)p_ptr) {} \
+ _ALWAYS_INLINE_ explicit m_name##ID(void *p_ptr) : ID((uint64_t)p_ptr) {} \
_ALWAYS_INLINE_ m_name##ID() = default; \
- }; \
- /* Ensure type-punnable to pointer. Makes some things easier.*/ \
- static_assert(sizeof(m_name##ID) == sizeof(void *));
+ };
// Id types declared before anything else to prevent cyclic dependencies between the different concerns.
DEFINE_ID(Buffer);