This repository has been archived on 2023-10-09. You can view files and clone it. You cannot open issues or pull requests or push a commit.
Files
blender-archive/source/blender/gpu/intern/gpu_init_exit.c
Brecht Van Lommel 1cf465bbc3 Fix GPU backend deleting resources without an active context
This causes an assert with libepoxy, but was wrong already regardless.

Refactor logic to work as follows:
* GPU_exit() deletes backend resources
* Destroy UI GPU resources with the context active
* Call GPU_backend_exit() after deleting the context

Ref D15291

Differential Revision: https://developer.blender.org/D15465
2022-07-15 16:31:28 +02:00

67 lines
1.2 KiB
C

/* SPDX-License-Identifier: GPL-2.0-or-later
* Copyright 2013 Blender Foundation. All rights reserved. */
/** \file
* \ingroup gpu
*/
#include "GPU_init_exit.h" /* interface */
#include "BLI_sys_types.h"
#include "GPU_batch.h"
#include "intern/gpu_codegen.h"
#include "intern/gpu_private.h"
#include "intern/gpu_shader_create_info_private.hh"
#include "intern/gpu_shader_dependency_private.h"
/**
* 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(void)
{
/* can't avoid calling this multiple times, see wm_window_ghostwindow_add */
if (initialized) {
return;
}
initialized = true;
gpu_shader_dependency_init();
gpu_shader_create_info_init();
gpu_codegen_init();
gpu_batch_init();
#ifndef GPU_STANDALONE
gpu_pbvh_init();
#endif
}
void GPU_exit(void)
{
#ifndef GPU_STANDALONE
gpu_pbvh_exit();
#endif
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(void)
{
return initialized;
}