Merge pull request #98391 from RandomShaper/rd_thread_switch

Implement thread ownership change for RenderingDevice
This commit is contained in:
Clay John 2024-10-22 13:10:32 -07:00 committed by GitHub
commit 533c616cb8
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 8 additions and 0 deletions

View file

@ -7260,6 +7260,10 @@ void RenderingDevice::_bind_methods() {
BIND_ENUM_CONSTANT(DEBUG_PASS); BIND_ENUM_CONSTANT(DEBUG_PASS);
} }
void RenderingDevice::make_current() {
render_thread_id = Thread::get_caller_id();
}
RenderingDevice::~RenderingDevice() { RenderingDevice::~RenderingDevice() {
finalize(); finalize();

View file

@ -1496,6 +1496,8 @@ public:
static RenderingDevice *get_singleton(); static RenderingDevice *get_singleton();
void make_current();
RenderingDevice(); RenderingDevice();
~RenderingDevice(); ~RenderingDevice();

View file

@ -370,6 +370,8 @@ Size2i RenderingServerDefault::get_maximum_viewport_size() const {
void RenderingServerDefault::_assign_mt_ids(WorkerThreadPool::TaskID p_pump_task_id) { void RenderingServerDefault::_assign_mt_ids(WorkerThreadPool::TaskID p_pump_task_id) {
server_thread = Thread::get_caller_id(); server_thread = Thread::get_caller_id();
server_task_id = p_pump_task_id; server_task_id = p_pump_task_id;
// This is needed because the main RD is created on the main thread.
RenderingDevice::get_singleton()->make_current();
} }
void RenderingServerDefault::_thread_exit() { void RenderingServerDefault::_thread_exit() {