Merge pull request #31105 from akien-mga/vulkan
RID_Alloc: Fix locking in getornull and free early returns
This commit is contained in:
commit
994e8c5779
1 changed files with 19 additions and 3 deletions
|
@ -109,6 +109,9 @@ public:
|
||||||
uint64_t id = p_rid.get_id();
|
uint64_t id = p_rid.get_id();
|
||||||
uint32_t idx = uint32_t(id & 0xFFFFFFFF);
|
uint32_t idx = uint32_t(id & 0xFFFFFFFF);
|
||||||
if (unlikely(idx >= max_alloc)) {
|
if (unlikely(idx >= max_alloc)) {
|
||||||
|
if (THREAD_SAFE) {
|
||||||
|
spin_lock.unlock();
|
||||||
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -116,7 +119,10 @@ public:
|
||||||
uint32_t idx_element = idx % elements_in_chunk;
|
uint32_t idx_element = idx % elements_in_chunk;
|
||||||
|
|
||||||
uint32_t validator = uint32_t(id >> 32);
|
uint32_t validator = uint32_t(id >> 32);
|
||||||
if (validator_chunks[idx_chunk][idx_element] != validator) {
|
if (unlikely(validator_chunks[idx_chunk][idx_element] != validator)) {
|
||||||
|
if (THREAD_SAFE) {
|
||||||
|
spin_lock.unlock();
|
||||||
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -166,13 +172,23 @@ public:
|
||||||
|
|
||||||
uint64_t id = p_rid.get_id();
|
uint64_t id = p_rid.get_id();
|
||||||
uint32_t idx = uint32_t(id & 0xFFFFFFFF);
|
uint32_t idx = uint32_t(id & 0xFFFFFFFF);
|
||||||
ERR_FAIL_COND(idx >= max_alloc);
|
if (unlikely(idx >= max_alloc)) {
|
||||||
|
if (THREAD_SAFE) {
|
||||||
|
spin_lock.unlock();
|
||||||
|
}
|
||||||
|
ERR_FAIL();
|
||||||
|
}
|
||||||
|
|
||||||
uint32_t idx_chunk = idx / elements_in_chunk;
|
uint32_t idx_chunk = idx / elements_in_chunk;
|
||||||
uint32_t idx_element = idx % elements_in_chunk;
|
uint32_t idx_element = idx % elements_in_chunk;
|
||||||
|
|
||||||
uint32_t validator = uint32_t(id >> 32);
|
uint32_t validator = uint32_t(id >> 32);
|
||||||
ERR_FAIL_COND(validator_chunks[idx_chunk][idx_element] != validator);
|
if (unlikely(validator_chunks[idx_chunk][idx_element] != validator)) {
|
||||||
|
if (THREAD_SAFE) {
|
||||||
|
spin_lock.unlock();
|
||||||
|
}
|
||||||
|
ERR_FAIL();
|
||||||
|
}
|
||||||
|
|
||||||
chunks[idx_chunk][idx_element].~T();
|
chunks[idx_chunk][idx_element].~T();
|
||||||
validator_chunks[idx_chunk][idx_element] = 0xFFFFFFFF; // go invalid
|
validator_chunks[idx_chunk][idx_element] = 0xFFFFFFFF; // go invalid
|
||||||
|
|
Loading…
Reference in a new issue