Files
test2/source/blender/gpu/intern/gpu_init_exit.cc
Miguel Pozo a5ed5dc4bf GPU: Support deferred compilation in ShaderCompilerGeneric
Update the `ShaderCompilerGeneric` to support deferred compilation
using the batch compilation API, so we can get rid of
`drw_manager_shader`.
This approach also allows supporting non-blocking compilation
for static shaders.

This shouldn't cause any behavior changes at the moment, since batch
compilation is not yet used when parallel compilation is disabled.

This adds a `GPUWorker` and a `GPUSecondaryContext` as an easy to use
wrapper for managing secondary GPU contexts.

(Part of #133674)
Pull Request: https://projects.blender.org/blender/blender/pulls/136518
2025-04-07 15:26:25 +02:00

60 lines
1.1 KiB
C++

/* SPDX-FileCopyrightText: 2013 Blender Authors
*
* SPDX-License-Identifier: GPL-2.0-or-later */
/** \file
* \ingroup gpu
*/
#include "GPU_init_exit.hh" /* interface */
#include "GPU_batch.hh"
#include "intern/gpu_codegen.hh"
#include "intern/gpu_private.hh"
#include "intern/gpu_shader_create_info_private.hh"
#include "intern/gpu_shader_dependency_private.hh"
/**
* although the order of initialization and shutdown should not matter
* (except for the extensions), I chose alphabetical and reverse alphabetical order
*/
static bool initialized = false;
void GPU_init()
{
/* can't avoid calling this multiple times, see wm_window_ghostwindow_add */
if (initialized) {
return;
}
initialized = true;
gpu_backend_init_resources();
gpu_shader_dependency_init();
gpu_shader_create_info_init();
gpu_codegen_init();
gpu_batch_init();
}
void GPU_exit()
{
gpu_batch_exit();
gpu_codegen_exit();
gpu_shader_dependency_exit();
gpu_shader_create_info_exit();
gpu_backend_delete_resources();
initialized = false;
}
bool GPU_is_init()
{
return initialized;
}