2019-07-06 05:42:53 +00:00
|
|
|
/*
|
|
|
|
vid_render_vulkan.c
|
|
|
|
|
|
|
|
Vulkan version of the renderer
|
|
|
|
|
|
|
|
Copyright (C) 2019 Bill Currie <bill@taniwha.org>
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU General Public License
|
|
|
|
as published by the Free Software Foundation; either version 2
|
|
|
|
of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
|
|
|
|
See the GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to:
|
|
|
|
|
|
|
|
Free Software Foundation, Inc.
|
|
|
|
59 Temple Place - Suite 330
|
|
|
|
Boston, MA 02111-1307, USA
|
|
|
|
|
|
|
|
*/
|
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
# include "config.h"
|
|
|
|
#endif
|
|
|
|
|
2020-02-16 13:45:27 +00:00
|
|
|
#include <stdlib.h>
|
2022-05-31 01:56:00 +00:00
|
|
|
#include <string.h>
|
2020-02-16 13:45:27 +00:00
|
|
|
|
2021-11-29 04:40:56 +00:00
|
|
|
#include "QF/cvar.h"
|
2020-02-17 11:29:35 +00:00
|
|
|
#include "QF/darray.h"
|
2021-03-24 10:20:53 +00:00
|
|
|
#include "QF/dstring.h"
|
|
|
|
#include "QF/quakefs.h"
|
2019-07-09 07:33:44 +00:00
|
|
|
#include "QF/sys.h"
|
2021-03-24 10:20:53 +00:00
|
|
|
#include "QF/va.h"
|
2019-07-09 07:33:44 +00:00
|
|
|
|
2019-07-06 05:42:53 +00:00
|
|
|
#include "QF/plugin/general.h"
|
|
|
|
#include "QF/plugin/vid_render.h"
|
|
|
|
|
2021-01-25 15:55:45 +00:00
|
|
|
#include "QF/Vulkan/qf_alias.h"
|
2021-01-19 16:25:54 +00:00
|
|
|
#include "QF/Vulkan/qf_bsp.h"
|
2021-02-24 10:58:31 +00:00
|
|
|
#include "QF/Vulkan/qf_compose.h"
|
2021-01-10 06:52:27 +00:00
|
|
|
#include "QF/Vulkan/qf_draw.h"
|
2022-05-04 05:07:27 +00:00
|
|
|
#include "QF/Vulkan/qf_iqm.h"
|
2021-02-24 10:58:31 +00:00
|
|
|
#include "QF/Vulkan/qf_lighting.h"
|
2021-01-19 16:25:54 +00:00
|
|
|
#include "QF/Vulkan/qf_lightmap.h"
|
|
|
|
#include "QF/Vulkan/qf_main.h"
|
2021-12-08 06:28:21 +00:00
|
|
|
#include "QF/Vulkan/qf_matrices.h"
|
2022-11-22 08:47:36 +00:00
|
|
|
#include "QF/Vulkan/qf_output.h"
|
2022-11-15 00:26:17 +00:00
|
|
|
#include "QF/Vulkan/qf_palette.h"
|
2021-01-18 03:46:06 +00:00
|
|
|
#include "QF/Vulkan/qf_particles.h"
|
2022-05-30 03:10:00 +00:00
|
|
|
#include "QF/Vulkan/qf_renderpass.h"
|
2022-05-24 15:17:57 +00:00
|
|
|
#include "QF/Vulkan/qf_scene.h"
|
2021-12-14 01:02:35 +00:00
|
|
|
#include "QF/Vulkan/qf_sprite.h"
|
2021-01-20 06:11:50 +00:00
|
|
|
#include "QF/Vulkan/qf_texture.h"
|
2019-07-06 05:42:53 +00:00
|
|
|
#include "QF/Vulkan/qf_vid.h"
|
2021-03-24 10:20:53 +00:00
|
|
|
#include "QF/Vulkan/capture.h"
|
2020-02-16 13:45:27 +00:00
|
|
|
#include "QF/Vulkan/command.h"
|
2022-05-07 03:38:31 +00:00
|
|
|
#include "QF/Vulkan/debug.h"
|
2019-07-12 04:15:25 +00:00
|
|
|
#include "QF/Vulkan/device.h"
|
2020-02-17 11:29:35 +00:00
|
|
|
#include "QF/Vulkan/image.h"
|
2019-07-12 04:15:25 +00:00
|
|
|
#include "QF/Vulkan/instance.h"
|
2022-03-30 05:55:32 +00:00
|
|
|
#include "QF/Vulkan/projection.h"
|
2022-05-13 01:19:08 +00:00
|
|
|
#include "QF/Vulkan/staging.h"
|
2019-07-12 04:15:25 +00:00
|
|
|
#include "QF/Vulkan/swapchain.h"
|
2021-07-10 09:04:34 +00:00
|
|
|
#include "QF/ui/view.h"
|
2019-07-06 05:42:53 +00:00
|
|
|
|
2022-03-04 16:48:10 +00:00
|
|
|
#include "QF/scene/entity.h"
|
2022-05-05 05:41:46 +00:00
|
|
|
#include "QF/scene/scene.h"
|
2022-03-04 16:48:10 +00:00
|
|
|
|
2019-07-06 05:42:53 +00:00
|
|
|
#include "mod_internal.h"
|
|
|
|
#include "r_internal.h"
|
2019-07-08 04:40:29 +00:00
|
|
|
#include "vid_internal.h"
|
2019-07-08 16:00:47 +00:00
|
|
|
#include "vid_vulkan.h"
|
2019-07-06 05:42:53 +00:00
|
|
|
|
2019-07-09 02:54:23 +00:00
|
|
|
static vulkan_ctx_t *vulkan_ctx;
|
2019-07-08 16:00:47 +00:00
|
|
|
|
2021-12-19 05:47:25 +00:00
|
|
|
static struct psystem_s *
|
|
|
|
vulkan_ParticleSystem (void)
|
|
|
|
{
|
|
|
|
return Vulkan_ParticleSystem (vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
2019-07-10 04:16:46 +00:00
|
|
|
static void
|
|
|
|
vulkan_R_Init (void)
|
|
|
|
{
|
2021-01-10 16:24:15 +00:00
|
|
|
Vulkan_CreateStagingBuffers (vulkan_ctx);
|
2021-02-14 02:35:06 +00:00
|
|
|
Vulkan_CreateFrames (vulkan_ctx);
|
2022-09-26 00:52:14 +00:00
|
|
|
Vulkan_Texture_Init (vulkan_ctx);
|
2022-11-15 00:26:17 +00:00
|
|
|
Vulkan_Palette_Init (vulkan_ctx, vid.palette);
|
2022-09-26 00:52:14 +00:00
|
|
|
|
|
|
|
Vulkan_CreateSwapchain (vulkan_ctx);
|
2021-03-24 10:20:53 +00:00
|
|
|
Vulkan_CreateCapture (vulkan_ctx);
|
2022-11-22 08:47:36 +00:00
|
|
|
|
2022-05-30 06:58:22 +00:00
|
|
|
Vulkan_CreateRenderPasses (vulkan_ctx);
|
2022-11-22 08:47:36 +00:00
|
|
|
Vulkan_Output_Init (vulkan_ctx);
|
2021-12-02 12:58:29 +00:00
|
|
|
|
2021-12-08 06:28:21 +00:00
|
|
|
Vulkan_Matrix_Init (vulkan_ctx);
|
2022-05-24 15:17:57 +00:00
|
|
|
Vulkan_Scene_Init (vulkan_ctx);
|
2021-01-26 11:58:24 +00:00
|
|
|
Vulkan_Alias_Init (vulkan_ctx);
|
2021-01-19 16:25:54 +00:00
|
|
|
Vulkan_Bsp_Init (vulkan_ctx);
|
2022-05-07 01:08:46 +00:00
|
|
|
Vulkan_IQM_Init (vulkan_ctx);
|
2021-12-16 14:17:01 +00:00
|
|
|
Vulkan_Particles_Init (vulkan_ctx);
|
2021-12-14 16:22:05 +00:00
|
|
|
Vulkan_Sprite_Init (vulkan_ctx);
|
2021-01-10 06:52:27 +00:00
|
|
|
Vulkan_Draw_Init (vulkan_ctx);
|
2021-02-24 10:58:31 +00:00
|
|
|
Vulkan_Lighting_Init (vulkan_ctx);
|
|
|
|
Vulkan_Compose_Init (vulkan_ctx);
|
2021-12-02 12:58:29 +00:00
|
|
|
|
2021-03-19 13:53:23 +00:00
|
|
|
Skin_Init ();
|
2020-02-18 08:18:37 +00:00
|
|
|
|
2021-01-12 02:27:41 +00:00
|
|
|
SCR_Init ();
|
2020-02-16 13:45:27 +00:00
|
|
|
}
|
|
|
|
|
2021-01-18 03:46:06 +00:00
|
|
|
static void
|
|
|
|
vulkan_R_ClearState (void)
|
|
|
|
{
|
2022-05-31 01:56:00 +00:00
|
|
|
QFV_DeviceWaitIdle (vulkan_ctx->device);
|
2022-03-14 06:27:43 +00:00
|
|
|
r_refdef.worldmodel = 0;
|
2021-01-19 16:25:54 +00:00
|
|
|
R_ClearDlights ();
|
2021-12-19 04:08:39 +00:00
|
|
|
R_ClearParticles ();
|
2022-05-07 03:12:02 +00:00
|
|
|
Vulkan_LoadLights (0, vulkan_ctx);
|
2021-01-18 03:46:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_R_LoadSkys (const char *skyname)
|
|
|
|
{
|
2021-03-25 06:54:34 +00:00
|
|
|
Vulkan_LoadSkys (skyname, vulkan_ctx);
|
2021-01-18 03:46:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2022-05-05 05:41:46 +00:00
|
|
|
vulkan_R_NewScene (scene_t *scene)
|
2021-01-18 03:46:06 +00:00
|
|
|
{
|
2022-05-05 05:41:46 +00:00
|
|
|
Vulkan_NewScene (scene, vulkan_ctx);
|
2021-01-18 03:46:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2021-07-11 01:59:27 +00:00
|
|
|
vulkan_R_LineGraph (int x, int y, int *h_vals, int count, int height)
|
2021-01-18 03:46:06 +00:00
|
|
|
{
|
2022-11-10 12:19:01 +00:00
|
|
|
Vulkan_LineGraph (x, y, h_vals, count, height, vulkan_ctx);
|
2021-01-18 03:46:06 +00:00
|
|
|
}
|
|
|
|
|
2022-09-15 05:24:33 +00:00
|
|
|
static void
|
|
|
|
vulkan_Draw_CharBuffer (int x, int y, draw_charbuffer_t *buffer)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_CharBuffer (x, y, buffer, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
2022-11-13 13:23:56 +00:00
|
|
|
static void
|
|
|
|
vulkan_Draw_SetScale (int scale)
|
|
|
|
{
|
|
|
|
vulkan_ctx->twod_scale = max (1, scale);
|
|
|
|
}
|
|
|
|
|
2021-01-10 06:52:27 +00:00
|
|
|
static void
|
|
|
|
vulkan_Draw_Character (int x, int y, unsigned ch)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_Character (x, y, ch, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_String (int x, int y, const char *str)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_String (x, y, str, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_nString (int x, int y, const char *str, int count)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_nString (x, y, str, count, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_AltString (int x, int y, const char *str)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_AltString (x, y, str, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_ConsoleBackground (int lines, byte alpha)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_ConsoleBackground (lines, alpha, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_Crosshair (void)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_Crosshair (vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_CrosshairAt (int ch, int x, int y)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_CrosshairAt (ch, x, y, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_TileClear (int x, int y, int w, int h)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_TileClear (x, y, w, h, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_Fill (int x, int y, int w, int h, int c)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_Fill (x, y, w, h, c, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
2022-05-28 09:14:26 +00:00
|
|
|
static void
|
|
|
|
vulkan_Draw_Line (int x0, int y0, int x1, int y1, int c)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_Line (x0, y0, x1, y1, c, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
2021-01-10 06:52:27 +00:00
|
|
|
static void
|
|
|
|
vulkan_Draw_TextBox (int x, int y, int width, int lines, byte alpha)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_TextBox (x, y, width, lines, alpha, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_FadeScreen (void)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_FadeScreen (vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_BlendScreen (quat_t color)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_BlendScreen (color, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
2020-02-16 13:45:27 +00:00
|
|
|
static qpic_t *
|
|
|
|
vulkan_Draw_CachePic (const char *path, qboolean alpha)
|
|
|
|
{
|
2021-01-10 06:52:27 +00:00
|
|
|
return Vulkan_Draw_CachePic (path, alpha, vulkan_ctx);
|
2020-02-16 13:45:27 +00:00
|
|
|
}
|
|
|
|
|
2021-01-10 06:52:27 +00:00
|
|
|
static void
|
|
|
|
vulkan_Draw_UncachePic (const char *path)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_UncachePic (path, vulkan_ctx);
|
|
|
|
}
|
2020-02-16 13:45:27 +00:00
|
|
|
|
|
|
|
static qpic_t *
|
|
|
|
vulkan_Draw_MakePic (int width, int height, const byte *data)
|
|
|
|
{
|
2021-01-10 06:52:27 +00:00
|
|
|
return Vulkan_Draw_MakePic (width, height, data, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_DestroyPic (qpic_t *pic)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_DestroyPic (pic, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static qpic_t *
|
|
|
|
vulkan_Draw_PicFromWad (const char *name)
|
|
|
|
{
|
|
|
|
return Vulkan_Draw_PicFromWad (name, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_Pic (int x, int y, qpic_t *pic)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_Pic (x, y, pic, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_Picf (float x, float y, qpic_t *pic)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_Picf (x, y, pic, vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Draw_SubPic (int x, int y, qpic_t *pic, int srcx, int srcy, int width, int height)
|
|
|
|
{
|
|
|
|
Vulkan_Draw_SubPic (x, y, pic, srcx, srcy, width, height, vulkan_ctx);
|
2019-07-10 04:16:46 +00:00
|
|
|
}
|
|
|
|
|
2022-10-02 23:58:27 +00:00
|
|
|
static int
|
2022-08-31 10:23:30 +00:00
|
|
|
vulkan_Draw_AddFont (struct rfont_s *font)
|
|
|
|
{
|
2022-10-02 23:58:27 +00:00
|
|
|
return Vulkan_Draw_AddFont (font, vulkan_ctx);
|
2022-08-31 10:23:30 +00:00
|
|
|
}
|
|
|
|
|
2022-09-02 02:38:09 +00:00
|
|
|
static void
|
2022-10-02 23:58:27 +00:00
|
|
|
vulkan_Draw_FontString (int x, int y, int fontid, const char *str)
|
2022-09-02 02:38:09 +00:00
|
|
|
{
|
2022-10-02 23:58:27 +00:00
|
|
|
Vulkan_Draw_FontString (x, y, fontid, str, vulkan_ctx);
|
2022-09-02 02:38:09 +00:00
|
|
|
}
|
|
|
|
|
2022-03-07 14:32:44 +00:00
|
|
|
static void
|
|
|
|
vulkan_begin_frame (void)
|
|
|
|
{
|
|
|
|
uint32_t imageIndex = 0;
|
|
|
|
qfv_device_t *device = vulkan_ctx->device;
|
|
|
|
qfv_devfuncs_t *dfunc = device->funcs;
|
|
|
|
VkDevice dev = device->dev;
|
|
|
|
|
|
|
|
__auto_type frame = &vulkan_ctx->frames.a[vulkan_ctx->curFrame];
|
|
|
|
|
|
|
|
dfunc->vkWaitForFences (dev, 1, &frame->fence, VK_TRUE, 2000000000);
|
2022-09-26 04:04:56 +00:00
|
|
|
if (!QFV_AcquireNextImage (vulkan_ctx->swapchain,
|
|
|
|
frame->imageAvailableSemaphore,
|
|
|
|
0, &imageIndex)) {
|
|
|
|
QFV_DeviceWaitIdle (device);
|
|
|
|
if (vulkan_ctx->capture) {
|
|
|
|
QFV_DestroyCapture (vulkan_ctx->capture);
|
|
|
|
}
|
|
|
|
Vulkan_CreateSwapchain (vulkan_ctx);
|
|
|
|
Vulkan_CreateCapture (vulkan_ctx);
|
|
|
|
|
|
|
|
//FIXME
|
|
|
|
qfv_output_t output = {
|
|
|
|
.extent = vulkan_ctx->swapchain->extent,
|
|
|
|
.view = vulkan_ctx->swapchain->imageViews->a[0],
|
|
|
|
.format = vulkan_ctx->swapchain->format,
|
|
|
|
.view_list = vulkan_ctx->swapchain->imageViews->a,
|
|
|
|
};
|
2022-11-22 08:47:36 +00:00
|
|
|
vulkan_ctx->output_renderpass->viewport.width = output.extent.width;
|
|
|
|
vulkan_ctx->output_renderpass->viewport.height = output.extent.height;
|
|
|
|
vulkan_ctx->output_renderpass->scissor.extent = output.extent;
|
2022-09-26 04:04:56 +00:00
|
|
|
vulkan_ctx->output = output;
|
2022-11-22 08:47:36 +00:00
|
|
|
Vulkan_CreateAttachments (vulkan_ctx, vulkan_ctx->output_renderpass);
|
2022-09-26 04:04:56 +00:00
|
|
|
QFV_AcquireNextImage (vulkan_ctx->swapchain,
|
|
|
|
frame->imageAvailableSemaphore,
|
|
|
|
0, &imageIndex);
|
|
|
|
}
|
2022-03-07 14:32:44 +00:00
|
|
|
vulkan_ctx->swapImageIndex = imageIndex;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_render_view (void)
|
|
|
|
{
|
|
|
|
uint32_t imageIndex = vulkan_ctx->swapImageIndex;
|
|
|
|
|
|
|
|
for (size_t i = 0; i < vulkan_ctx->renderPasses.size; i++) {
|
|
|
|
__auto_type rp = vulkan_ctx->renderPasses.a[i];
|
|
|
|
__auto_type rpFrame = &rp->frames.a[vulkan_ctx->curFrame];
|
2022-05-31 01:56:00 +00:00
|
|
|
if (rp->framebuffers) {
|
2022-11-21 08:25:55 +00:00
|
|
|
rpFrame->framebuffer = rp->framebuffers->a[imageIndex];
|
2022-05-31 01:56:00 +00:00
|
|
|
}
|
2022-03-07 14:32:44 +00:00
|
|
|
rp->draw (rpFrame);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-17 08:50:38 +00:00
|
|
|
static void
|
|
|
|
vulkan_draw_particles (struct psystem_s *psystem)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2022-03-17 15:14:48 +00:00
|
|
|
static void
|
|
|
|
vulkan_draw_transparent (void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2022-03-24 06:45:01 +00:00
|
|
|
static void
|
|
|
|
vulkan_post_process (framebuffer_t *src)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2022-03-07 14:32:44 +00:00
|
|
|
static void
|
2022-03-15 06:42:43 +00:00
|
|
|
vulkan_set_2d (int scaled)
|
2022-03-07 14:32:44 +00:00
|
|
|
{
|
2022-03-30 05:55:32 +00:00
|
|
|
//FIXME this should not be done every frame
|
|
|
|
__auto_type mctx = vulkan_ctx->matrix_context;
|
|
|
|
__auto_type mat = &mctx->matrices;
|
2022-11-13 13:23:56 +00:00
|
|
|
int scale = vulkan_ctx->twod_scale;
|
2022-03-30 05:55:32 +00:00
|
|
|
|
2022-11-19 16:17:09 +00:00
|
|
|
float left = 0;
|
|
|
|
float top = 0;
|
2022-11-13 13:23:56 +00:00
|
|
|
float right = left + vid.width / scale;
|
|
|
|
float bottom = top + vid.height / scale;
|
2022-09-28 13:24:22 +00:00
|
|
|
QFV_Orthographic (mat->Projection2d, left, right, top, bottom, 0, 99999);
|
2022-11-22 08:47:36 +00:00
|
|
|
mat->ScreenSize = (vec2f_t) { 1.0 / vid.width, 1.0 / vid.height };
|
2022-03-30 05:55:32 +00:00
|
|
|
mctx->dirty = mctx->frames.size;
|
2022-03-07 14:32:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_end_frame (void)
|
|
|
|
{
|
|
|
|
qfv_device_t *device = vulkan_ctx->device;
|
|
|
|
VkDevice dev = device->dev;
|
|
|
|
qfv_devfuncs_t *dfunc = device->funcs;
|
|
|
|
qfv_queue_t *queue = &device->queue;
|
2022-11-21 08:25:55 +00:00
|
|
|
uint32_t curFrame = vulkan_ctx->curFrame;
|
|
|
|
__auto_type frame = &vulkan_ctx->frames.a[curFrame];
|
|
|
|
uint32_t imageIndex = vulkan_ctx->swapImageIndex;
|
2022-03-07 14:32:44 +00:00
|
|
|
|
|
|
|
VkCommandBufferBeginInfo beginInfo
|
|
|
|
= { VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO };
|
|
|
|
|
|
|
|
VkRenderPassBeginInfo renderPassInfo = {
|
|
|
|
.sType = VK_STRUCTURE_TYPE_RENDER_PASS_BEGIN_INFO,
|
|
|
|
.renderArea = { {0, 0}, vulkan_ctx->swapchain->extent },
|
|
|
|
};
|
|
|
|
|
2022-05-31 01:56:00 +00:00
|
|
|
__auto_type cmdBufs = (qfv_cmdbufferset_t) DARRAY_STATIC_INIT (4);
|
|
|
|
DARRAY_APPEND (&cmdBufs, frame->cmdBuffer);
|
|
|
|
|
2022-03-07 14:32:44 +00:00
|
|
|
dfunc->vkBeginCommandBuffer (frame->cmdBuffer, &beginInfo);
|
|
|
|
for (size_t i = 0; i < vulkan_ctx->renderPasses.size; i++) {
|
|
|
|
__auto_type rp = vulkan_ctx->renderPasses.a[i];
|
2022-11-21 08:25:55 +00:00
|
|
|
__auto_type rpFrame = &rp->frames.a[curFrame];
|
2022-03-07 14:32:44 +00:00
|
|
|
|
2022-05-31 01:56:00 +00:00
|
|
|
if (rp->primary_commands) {
|
|
|
|
for (int j = 0; j < rpFrame->subpassCount; j++) {
|
|
|
|
__auto_type cmdSet = &rpFrame->subpassCmdSets[j];
|
|
|
|
size_t base = cmdBufs.size;
|
|
|
|
DARRAY_RESIZE (&cmdBufs, base + cmdSet->size);
|
|
|
|
memcpy (&cmdBufs.a[base], cmdSet->a,
|
|
|
|
cmdSet->size * sizeof (VkCommandBuffer));
|
|
|
|
}
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2022-05-07 03:38:31 +00:00
|
|
|
QFV_CmdBeginLabel (device, frame->cmdBuffer, rp->name, rp->color);
|
2022-05-31 01:56:00 +00:00
|
|
|
if (rpFrame->renderpass && rp->renderpass) {
|
2022-11-21 08:25:55 +00:00
|
|
|
renderPassInfo.framebuffer = rp->framebuffers->a[imageIndex];
|
2022-03-07 14:32:44 +00:00
|
|
|
renderPassInfo.renderPass = rp->renderpass;
|
|
|
|
renderPassInfo.clearValueCount = rp->clearValues->size;
|
|
|
|
renderPassInfo.pClearValues = rp->clearValues->a;
|
|
|
|
|
|
|
|
dfunc->vkCmdBeginRenderPass (frame->cmdBuffer, &renderPassInfo,
|
|
|
|
rpFrame->subpassContents);
|
|
|
|
|
|
|
|
for (int j = 0; j < rpFrame->subpassCount; j++) {
|
|
|
|
__auto_type cmdSet = &rpFrame->subpassCmdSets[j];
|
|
|
|
if (cmdSet->size) {
|
2022-05-07 03:38:31 +00:00
|
|
|
QFV_CmdBeginLabel (device, frame->cmdBuffer,
|
|
|
|
rpFrame->subpassInfo[j].name,
|
|
|
|
rpFrame->subpassInfo[j].color);
|
2022-03-07 14:32:44 +00:00
|
|
|
dfunc->vkCmdExecuteCommands (frame->cmdBuffer,
|
|
|
|
cmdSet->size, cmdSet->a);
|
2022-05-07 03:38:31 +00:00
|
|
|
QFV_CmdEndLabel (device, frame->cmdBuffer);
|
2022-03-07 14:32:44 +00:00
|
|
|
}
|
|
|
|
// reset for next time around
|
|
|
|
cmdSet->size = 0;
|
|
|
|
|
|
|
|
//Regardless of whether any commands were submitted for this
|
|
|
|
//subpass, must step through each and every subpass, otherwise
|
|
|
|
//the attachments won't be transitioned correctly.
|
|
|
|
if (j < rpFrame->subpassCount - 1) {
|
|
|
|
dfunc->vkCmdNextSubpass (frame->cmdBuffer,
|
|
|
|
rpFrame->subpassContents);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
dfunc->vkCmdEndRenderPass (frame->cmdBuffer);
|
|
|
|
} else {
|
|
|
|
for (int j = 0; j < rpFrame->subpassCount; j++) {
|
|
|
|
__auto_type cmdSet = &rpFrame->subpassCmdSets[j];
|
|
|
|
if (cmdSet->size) {
|
|
|
|
dfunc->vkCmdExecuteCommands (frame->cmdBuffer,
|
|
|
|
cmdSet->size, cmdSet->a);
|
|
|
|
}
|
|
|
|
// reset for next time around
|
|
|
|
cmdSet->size = 0;
|
|
|
|
}
|
|
|
|
}
|
2022-05-07 03:38:31 +00:00
|
|
|
QFV_CmdEndLabel (device, frame->cmdBuffer);
|
2022-03-07 14:32:44 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (vulkan_ctx->capture_callback) {
|
|
|
|
VkImage srcImage = vulkan_ctx->swapchain->images->a[imageIndex];
|
|
|
|
VkCommandBuffer cmd = QFV_CaptureImage (vulkan_ctx->capture, srcImage,
|
2022-11-21 08:25:55 +00:00
|
|
|
curFrame);
|
2022-03-07 14:32:44 +00:00
|
|
|
dfunc->vkCmdExecuteCommands (frame->cmdBuffer, 1, &cmd);
|
|
|
|
}
|
|
|
|
dfunc->vkEndCommandBuffer (frame->cmdBuffer);
|
|
|
|
|
|
|
|
VkPipelineStageFlags waitStage
|
|
|
|
= VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT;
|
|
|
|
VkSubmitInfo submitInfo = {
|
|
|
|
VK_STRUCTURE_TYPE_SUBMIT_INFO, 0,
|
|
|
|
1, &frame->imageAvailableSemaphore, &waitStage,
|
2022-05-31 01:56:00 +00:00
|
|
|
cmdBufs.size, cmdBufs.a,
|
2022-03-07 14:32:44 +00:00
|
|
|
1, &frame->renderDoneSemaphore,
|
|
|
|
};
|
|
|
|
dfunc->vkResetFences (dev, 1, &frame->fence);
|
|
|
|
dfunc->vkQueueSubmit (queue->queue, 1, &submitInfo, frame->fence);
|
|
|
|
|
2022-05-31 01:56:00 +00:00
|
|
|
DARRAY_CLEAR (&cmdBufs);
|
|
|
|
|
2022-03-07 14:32:44 +00:00
|
|
|
if (vulkan_ctx->capture_callback) {
|
|
|
|
//FIXME look into "threading" this rather than waiting here
|
|
|
|
dfunc->vkWaitForFences (device->dev, 1, &frame->fence, VK_TRUE,
|
|
|
|
1000000000ull);
|
|
|
|
vulkan_ctx->capture_callback (QFV_CaptureData (vulkan_ctx->capture,
|
2022-11-21 08:25:55 +00:00
|
|
|
curFrame),
|
2022-03-07 14:32:44 +00:00
|
|
|
vulkan_ctx->capture->extent.width,
|
|
|
|
vulkan_ctx->capture->extent.height);
|
|
|
|
vulkan_ctx->capture_callback = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
VkPresentInfoKHR presentInfo = {
|
|
|
|
VK_STRUCTURE_TYPE_PRESENT_INFO_KHR, 0,
|
|
|
|
1, &frame->renderDoneSemaphore,
|
|
|
|
1, &vulkan_ctx->swapchain->swapchain, &imageIndex,
|
|
|
|
0
|
|
|
|
};
|
|
|
|
dfunc->vkQueuePresentKHR (queue->queue, &presentInfo);
|
|
|
|
|
|
|
|
vulkan_ctx->curFrame++;
|
|
|
|
vulkan_ctx->curFrame %= vulkan_ctx->frames.size;
|
|
|
|
}
|
|
|
|
|
2022-03-24 06:45:01 +00:00
|
|
|
static framebuffer_t *
|
|
|
|
vulkan_create_cube_map (int size)
|
|
|
|
{
|
2022-04-01 07:49:39 +00:00
|
|
|
return 0;
|
2022-03-24 06:45:01 +00:00
|
|
|
}
|
|
|
|
|
2022-03-24 03:22:27 +00:00
|
|
|
static framebuffer_t *
|
|
|
|
vulkan_create_frame_buffer (int width, int height)
|
|
|
|
{
|
2022-04-01 07:49:39 +00:00
|
|
|
return 0;
|
2022-03-24 03:22:27 +00:00
|
|
|
}
|
|
|
|
|
2022-09-21 14:47:14 +00:00
|
|
|
static void
|
|
|
|
vulkan_destroy_frame_buffer (framebuffer_t *framebuffer)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2022-03-24 03:22:27 +00:00
|
|
|
static void
|
|
|
|
vulkan_bind_framebuffer (framebuffer_t *framebuffer)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2022-03-25 15:29:34 +00:00
|
|
|
static void
|
|
|
|
vulkan_set_viewport (const vrect_t *view)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2022-03-30 05:55:32 +00:00
|
|
|
static void
|
|
|
|
vulkan_set_fov (float x, float y)
|
|
|
|
{
|
|
|
|
if (!vulkan_ctx || !vulkan_ctx->matrix_context) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
__auto_type mctx = vulkan_ctx->matrix_context;
|
|
|
|
__auto_type mat = &mctx->matrices;
|
|
|
|
|
|
|
|
QFV_PerspectiveTan (mat->Projection3d, x, y);
|
|
|
|
|
|
|
|
mctx->dirty = mctx->frames.size;
|
|
|
|
}
|
2022-03-31 10:07:15 +00:00
|
|
|
|
2021-03-24 10:20:53 +00:00
|
|
|
static int
|
|
|
|
is_bgr (VkFormat format)
|
|
|
|
{
|
|
|
|
return (format >= VK_FORMAT_B8G8R8A8_UNORM
|
|
|
|
&& format <= VK_FORMAT_B8G8R8A8_SRGB);
|
|
|
|
}
|
2022-03-31 10:07:15 +00:00
|
|
|
|
2021-03-24 10:20:53 +00:00
|
|
|
static void
|
|
|
|
capture_screenshot (const byte *data, int width, int height)
|
|
|
|
{
|
2022-03-31 10:07:15 +00:00
|
|
|
int count = width * height;
|
|
|
|
tex_t *tex = malloc (sizeof (tex_t) + count * 3);
|
|
|
|
|
|
|
|
if (tex) {
|
|
|
|
tex->data = (byte *) (tex + 1);
|
2022-03-31 11:00:13 +00:00
|
|
|
tex->flagbits = 0;
|
2022-03-31 10:07:15 +00:00
|
|
|
tex->width = width;
|
|
|
|
tex->height = height;
|
|
|
|
tex->format = tex_rgb;
|
|
|
|
tex->palette = 0;
|
2022-03-31 11:00:13 +00:00
|
|
|
tex->flagbits = 0;
|
|
|
|
tex->loaded = 1;
|
2022-03-31 10:07:15 +00:00
|
|
|
|
2022-09-26 06:54:20 +00:00
|
|
|
if (is_bgr (vulkan_ctx->swapchain->format)) {
|
2022-03-31 11:00:13 +00:00
|
|
|
tex->bgr = 1;
|
|
|
|
}
|
|
|
|
const byte *src = data;
|
|
|
|
byte *dst = tex->data;
|
|
|
|
for (int count = width * height; count-- > 0; ) {
|
|
|
|
*dst++ = *src++;
|
|
|
|
*dst++ = *src++;
|
|
|
|
*dst++ = *src++;
|
|
|
|
src++;
|
2021-03-24 10:20:53 +00:00
|
|
|
}
|
|
|
|
}
|
2022-03-31 10:07:15 +00:00
|
|
|
capfunc_t callback = vulkan_ctx->capture_complete;
|
|
|
|
callback (tex, vulkan_ctx->capture_complete_data);;
|
2021-03-24 10:20:53 +00:00
|
|
|
}
|
|
|
|
|
2022-03-31 10:07:15 +00:00
|
|
|
static void
|
|
|
|
vulkan_capture_screen (capfunc_t callback, void *data)
|
2021-01-18 03:46:06 +00:00
|
|
|
{
|
2021-03-24 10:20:53 +00:00
|
|
|
if (!vulkan_ctx->capture) {
|
2022-03-07 05:39:47 +00:00
|
|
|
Sys_Printf ("Capture not supported\n");
|
2022-03-31 10:07:15 +00:00
|
|
|
callback (0, data);
|
|
|
|
return;
|
2021-03-24 10:20:53 +00:00
|
|
|
}
|
|
|
|
vulkan_ctx->capture_callback = capture_screenshot;
|
2022-03-31 10:07:15 +00:00
|
|
|
vulkan_ctx->capture_complete = callback;
|
|
|
|
vulkan_ctx->capture_complete_data = data;
|
2021-01-18 03:46:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2021-02-01 05:39:00 +00:00
|
|
|
vulkan_Mod_LoadLighting (model_t *mod, bsp_t *bsp)
|
2021-01-18 03:46:06 +00:00
|
|
|
{
|
2021-02-01 05:39:00 +00:00
|
|
|
Vulkan_Mod_LoadLighting (mod, bsp, vulkan_ctx);
|
2021-01-18 03:46:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2021-02-01 05:39:00 +00:00
|
|
|
vulkan_Mod_SubdivideSurface (model_t *mod, msurface_t *fa)
|
2021-01-18 03:46:06 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2021-02-01 05:39:00 +00:00
|
|
|
vulkan_Mod_ProcessTexture (model_t *mod, texture_t *tx)
|
2021-01-18 03:46:06 +00:00
|
|
|
{
|
2021-02-01 05:39:00 +00:00
|
|
|
Vulkan_Mod_ProcessTexture (mod, tx, vulkan_ctx);
|
2021-01-18 03:46:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2021-02-01 12:11:45 +00:00
|
|
|
vulkan_Mod_MakeAliasModelDisplayLists (mod_alias_ctx_t *alias_ctx,
|
2021-01-18 03:46:06 +00:00
|
|
|
void *_m, int _s, int extra)
|
|
|
|
{
|
2021-02-01 12:11:45 +00:00
|
|
|
Vulkan_Mod_MakeAliasModelDisplayLists (alias_ctx, _m, _s, extra,
|
|
|
|
vulkan_ctx);
|
2021-01-18 03:46:06 +00:00
|
|
|
}
|
|
|
|
|
[model] Make alias skin loading a batch operation
Really, this won't make all that much difference because alias models
with more than one skin are quite rare, and those with animated skin
groups are even rarer. However, for those models that do have more than
one skin, it will allow for reduced allocation overheads, and when
supported (glsl, vulkan, maybe gl), loading all the skins into an array
texture (since all skins are the same size, though external skins may
vary), but that's not implemented yet, this just wraps the old one skin
at a time code.
2022-04-04 06:38:27 +00:00
|
|
|
static void
|
|
|
|
vulkan_Mod_LoadAllSkins (mod_alias_ctx_t *alias_ctx)
|
2021-01-18 03:46:06 +00:00
|
|
|
{
|
[model] Make alias skin loading a batch operation
Really, this won't make all that much difference because alias models
with more than one skin are quite rare, and those with animated skin
groups are even rarer. However, for those models that do have more than
one skin, it will allow for reduced allocation overheads, and when
supported (glsl, vulkan, maybe gl), loading all the skins into an array
texture (since all skins are the same size, though external skins may
vary), but that's not implemented yet, this just wraps the old one skin
at a time code.
2022-04-04 06:38:27 +00:00
|
|
|
Vulkan_Mod_LoadAllSkins (alias_ctx, vulkan_ctx);
|
2021-01-18 03:46:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2021-02-01 12:11:45 +00:00
|
|
|
vulkan_Mod_FinalizeAliasModel (mod_alias_ctx_t *alias_ctx)
|
2021-01-18 03:46:06 +00:00
|
|
|
{
|
2021-02-01 12:11:45 +00:00
|
|
|
Vulkan_Mod_FinalizeAliasModel (alias_ctx, vulkan_ctx);
|
2021-01-18 03:46:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2021-02-01 12:11:45 +00:00
|
|
|
vulkan_Mod_LoadExternalSkins (mod_alias_ctx_t *alias_ctx)
|
2021-01-18 03:46:06 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Mod_IQMFinish (model_t *mod)
|
|
|
|
{
|
2022-05-04 05:07:27 +00:00
|
|
|
Vulkan_Mod_IQMFinish (mod, vulkan_ctx);
|
2021-01-18 03:46:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2021-12-13 23:36:19 +00:00
|
|
|
vulkan_Mod_SpriteLoadFrames (mod_sprite_ctx_t *sprite_ctx)
|
2021-01-18 03:46:06 +00:00
|
|
|
{
|
2021-12-14 01:02:35 +00:00
|
|
|
Vulkan_Mod_SpriteLoadFrames (sprite_ctx, vulkan_ctx);
|
2021-01-18 03:46:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Skin_SetupSkin (struct skin_s *skin, int cmap)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Skin_ProcessTranslation (int cmap, const byte *translation)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_Skin_InitTranslations (void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2021-06-26 06:43:17 +00:00
|
|
|
static void
|
2021-07-10 15:09:41 +00:00
|
|
|
set_palette (void *data, const byte *palette)
|
2021-06-26 06:43:17 +00:00
|
|
|
{
|
2022-11-15 00:26:17 +00:00
|
|
|
if (vulkan_ctx->palette_context) {
|
|
|
|
Vulkan_Palette_Update (vulkan_ctx, palette);
|
|
|
|
}
|
2021-06-26 06:43:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2021-07-10 15:09:41 +00:00
|
|
|
vulkan_vid_render_choose_visual (void *data)
|
2021-06-26 06:43:17 +00:00
|
|
|
{
|
|
|
|
Vulkan_CreateDevice (vulkan_ctx);
|
2021-11-29 04:40:56 +00:00
|
|
|
if (!vulkan_ctx->device) {
|
|
|
|
Sys_Error ("Unable to create Vulkan device.%s",
|
[cvar] Make cvars properly typed
This is an extremely extensive patch as it hits every cvar, and every
usage of the cvars. Cvars no longer store the value they control,
instead, they use a cexpr value object to reference the value and
specify the value's type (currently, a null type is used for strings).
Non-string cvars are passed through cexpr, allowing expressions in the
cvars' settings. Also, cvars have returned to an enhanced version of the
original (id quake) registration scheme.
As a minor benefit, relevant code having direct access to the
cvar-controlled variables is probably a slight optimization as it
removed a pointer dereference, and the variables can be located for data
locality.
The static cvar descriptors are made private as an additional safety
layer, though there's nothing stopping external modification via
Cvar_FindVar (which is needed for adding listeners).
While not used yet (partly due to working out the design), cvars can
have a validation function.
Registering a cvar allows a primary listener (and its data) to be
specified: it will always be called first when the cvar is modified. The
combination of proper listeners and direct access to the controlled
variable greatly simplifies the more complex cvar interactions as much
less null checking is required, and there's no need for one cvar's
callback to call another's.
nq-x11 is known to work at least well enough for the demos. More testing
will come.
2022-04-23 03:22:45 +00:00
|
|
|
vulkan_use_validation ? ""
|
2021-11-29 04:40:56 +00:00
|
|
|
: "\nSet vulkan_use_validation for details");
|
|
|
|
}
|
2021-06-26 06:43:17 +00:00
|
|
|
vulkan_ctx->choose_visual (vulkan_ctx);
|
|
|
|
vulkan_ctx->cmdpool = QFV_CreateCommandPool (vulkan_ctx->device,
|
|
|
|
vulkan_ctx->device->queue.queueFamily,
|
|
|
|
0, 1);
|
|
|
|
Sys_MaskPrintf (SYS_vulkan, "vk choose visual %p %p %d %#zx\n",
|
|
|
|
vulkan_ctx->device->dev, vulkan_ctx->device->queue.queue,
|
|
|
|
vulkan_ctx->device->queue.queueFamily,
|
|
|
|
(size_t) vulkan_ctx->cmdpool);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2021-07-10 15:09:41 +00:00
|
|
|
vulkan_vid_render_create_context (void *data)
|
2021-06-26 06:43:17 +00:00
|
|
|
{
|
|
|
|
vulkan_ctx->create_window (vulkan_ctx);
|
|
|
|
vulkan_ctx->surface = vulkan_ctx->create_surface (vulkan_ctx);
|
2022-05-31 02:05:12 +00:00
|
|
|
Sys_MaskPrintf (SYS_vulkan, "vk create context: surface:%#zx\n",
|
2021-06-26 06:43:17 +00:00
|
|
|
(size_t) vulkan_ctx->surface);
|
|
|
|
}
|
|
|
|
|
2019-07-06 05:42:53 +00:00
|
|
|
static vid_model_funcs_t model_funcs = {
|
2022-09-25 01:18:06 +00:00
|
|
|
.texture_render_size = sizeof (vulktex_t) + 2 * sizeof (qfv_tex_t),
|
|
|
|
|
|
|
|
.Mod_LoadLighting = vulkan_Mod_LoadLighting,
|
|
|
|
.Mod_SubdivideSurface = vulkan_Mod_SubdivideSurface,
|
|
|
|
.Mod_ProcessTexture = vulkan_Mod_ProcessTexture,
|
|
|
|
|
|
|
|
.Mod_LoadIQM = Mod_LoadIQM,
|
|
|
|
.Mod_LoadAliasModel = Mod_LoadAliasModel,
|
|
|
|
.Mod_LoadSpriteModel = Mod_LoadSpriteModel,
|
|
|
|
|
|
|
|
.Mod_MakeAliasModelDisplayLists = vulkan_Mod_MakeAliasModelDisplayLists,
|
|
|
|
.Mod_LoadAllSkins = vulkan_Mod_LoadAllSkins,
|
|
|
|
.Mod_FinalizeAliasModel = vulkan_Mod_FinalizeAliasModel,
|
|
|
|
.Mod_LoadExternalSkins = vulkan_Mod_LoadExternalSkins,
|
|
|
|
.Mod_IQMFinish = vulkan_Mod_IQMFinish,
|
|
|
|
.alias_cache = 0,
|
|
|
|
.Mod_SpriteLoadFrames = vulkan_Mod_SpriteLoadFrames,
|
|
|
|
|
|
|
|
.Skin_Free = Skin_Free,
|
|
|
|
.Skin_SetColormap = Skin_SetColormap,
|
|
|
|
.Skin_SetSkin = Skin_SetSkin,
|
|
|
|
.Skin_SetupSkin = vulkan_Skin_SetupSkin,
|
|
|
|
.Skin_SetTranslation = Skin_SetTranslation,
|
|
|
|
.Skin_ProcessTranslation = vulkan_Skin_ProcessTranslation,
|
|
|
|
.Skin_InitTranslations = vulkan_Skin_InitTranslations,
|
2019-07-06 05:42:53 +00:00
|
|
|
};
|
|
|
|
|
2021-06-26 06:43:17 +00:00
|
|
|
static void
|
|
|
|
vulkan_vid_render_init (void)
|
|
|
|
{
|
|
|
|
if (!vr_data.vid->vid_internal->vulkan_context) {
|
|
|
|
Sys_Error ("Sorry, Vulkan not supported by this program.");
|
|
|
|
}
|
|
|
|
vulkan_ctx = vr_data.vid->vid_internal->vulkan_context ();
|
|
|
|
vulkan_ctx->load_vulkan (vulkan_ctx);
|
|
|
|
|
|
|
|
Vulkan_Init_Common (vulkan_ctx);
|
|
|
|
|
2021-07-10 15:09:41 +00:00
|
|
|
vr_data.vid->vid_internal->data = vulkan_ctx;
|
2021-06-26 06:43:17 +00:00
|
|
|
vr_data.vid->vid_internal->set_palette = set_palette;
|
|
|
|
vr_data.vid->vid_internal->choose_visual = vulkan_vid_render_choose_visual;
|
|
|
|
vr_data.vid->vid_internal->create_context = vulkan_vid_render_create_context;
|
|
|
|
|
|
|
|
vr_funcs = &vulkan_vid_render_funcs;
|
|
|
|
m_funcs = &model_funcs;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
vulkan_vid_render_shutdown (void)
|
|
|
|
{
|
2021-11-29 04:40:56 +00:00
|
|
|
if (!vulkan_ctx || !vulkan_ctx->device) {
|
|
|
|
return;
|
|
|
|
}
|
2021-06-26 06:43:17 +00:00
|
|
|
qfv_device_t *device = vulkan_ctx->device;
|
|
|
|
qfv_devfuncs_t *df = device->funcs;
|
|
|
|
VkDevice dev = device->dev;
|
|
|
|
QFV_DeviceWaitIdle (device);
|
2021-12-02 12:58:29 +00:00
|
|
|
|
2022-05-07 01:08:46 +00:00
|
|
|
Mod_ClearAll ();
|
|
|
|
|
2021-06-26 06:43:17 +00:00
|
|
|
Vulkan_Compose_Shutdown (vulkan_ctx);
|
|
|
|
Vulkan_Lighting_Shutdown (vulkan_ctx);
|
|
|
|
Vulkan_Draw_Shutdown (vulkan_ctx);
|
2021-12-14 16:22:05 +00:00
|
|
|
Vulkan_Sprite_Shutdown (vulkan_ctx);
|
2021-12-16 14:17:01 +00:00
|
|
|
Vulkan_Particles_Shutdown (vulkan_ctx);
|
2022-05-07 01:08:46 +00:00
|
|
|
Vulkan_IQM_Shutdown (vulkan_ctx);
|
2021-06-26 06:43:17 +00:00
|
|
|
Vulkan_Bsp_Shutdown (vulkan_ctx);
|
|
|
|
Vulkan_Alias_Shutdown (vulkan_ctx);
|
2022-05-24 15:17:57 +00:00
|
|
|
Vulkan_Scene_Shutdown (vulkan_ctx);
|
2021-12-08 06:28:21 +00:00
|
|
|
Vulkan_Matrix_Shutdown (vulkan_ctx);
|
2021-12-02 12:58:29 +00:00
|
|
|
|
2022-11-22 04:30:29 +00:00
|
|
|
Vulkan_DestroyRenderPasses (vulkan_ctx);
|
2022-11-22 08:47:36 +00:00
|
|
|
Vulkan_Output_Shutdown (vulkan_ctx);
|
2022-11-22 04:30:29 +00:00
|
|
|
|
2022-11-15 00:26:17 +00:00
|
|
|
Vulkan_Palette_Shutdown (vulkan_ctx);
|
2021-06-26 06:43:17 +00:00
|
|
|
Vulkan_Texture_Shutdown (vulkan_ctx);
|
2022-05-13 01:19:08 +00:00
|
|
|
|
|
|
|
QFV_DestroyStagingBuffer (vulkan_ctx->staging);
|
|
|
|
df->vkDestroyCommandPool (dev, vulkan_ctx->cmdpool, 0);
|
|
|
|
|
2021-06-26 06:43:17 +00:00
|
|
|
Vulkan_Shutdown_Common (vulkan_ctx);
|
|
|
|
}
|
|
|
|
|
2019-07-06 05:42:53 +00:00
|
|
|
vid_render_funcs_t vulkan_vid_render_funcs = {
|
2022-09-25 01:18:06 +00:00
|
|
|
.init = vulkan_vid_render_init,
|
|
|
|
|
|
|
|
.Draw_CharBuffer = vulkan_Draw_CharBuffer,
|
2022-11-13 13:23:56 +00:00
|
|
|
.Draw_SetScale = vulkan_Draw_SetScale,
|
2022-09-25 01:18:06 +00:00
|
|
|
.Draw_Character = vulkan_Draw_Character,
|
|
|
|
.Draw_String = vulkan_Draw_String,
|
|
|
|
.Draw_nString = vulkan_Draw_nString,
|
|
|
|
.Draw_AltString = vulkan_Draw_AltString,
|
|
|
|
.Draw_ConsoleBackground = vulkan_Draw_ConsoleBackground,
|
|
|
|
.Draw_Crosshair = vulkan_Draw_Crosshair,
|
|
|
|
.Draw_CrosshairAt = vulkan_Draw_CrosshairAt,
|
|
|
|
.Draw_TileClear = vulkan_Draw_TileClear,
|
|
|
|
.Draw_Fill = vulkan_Draw_Fill,
|
|
|
|
.Draw_Line = vulkan_Draw_Line,
|
|
|
|
.Draw_TextBox = vulkan_Draw_TextBox,
|
|
|
|
.Draw_FadeScreen = vulkan_Draw_FadeScreen,
|
|
|
|
.Draw_BlendScreen = vulkan_Draw_BlendScreen,
|
|
|
|
.Draw_CachePic = vulkan_Draw_CachePic,
|
|
|
|
.Draw_UncachePic = vulkan_Draw_UncachePic,
|
|
|
|
.Draw_MakePic = vulkan_Draw_MakePic,
|
|
|
|
.Draw_DestroyPic = vulkan_Draw_DestroyPic,
|
|
|
|
.Draw_PicFromWad = vulkan_Draw_PicFromWad,
|
|
|
|
.Draw_Pic = vulkan_Draw_Pic,
|
|
|
|
.Draw_Picf = vulkan_Draw_Picf,
|
|
|
|
.Draw_SubPic = vulkan_Draw_SubPic,
|
|
|
|
.Draw_AddFont = vulkan_Draw_AddFont,
|
|
|
|
.Draw_FontString = vulkan_Draw_FontString,
|
|
|
|
|
|
|
|
.ParticleSystem = vulkan_ParticleSystem,
|
|
|
|
.R_Init = vulkan_R_Init,
|
|
|
|
.R_ClearState = vulkan_R_ClearState,
|
|
|
|
.R_LoadSkys = vulkan_R_LoadSkys,
|
|
|
|
.R_NewScene = vulkan_R_NewScene,
|
|
|
|
.R_LineGraph = vulkan_R_LineGraph,
|
|
|
|
.begin_frame = vulkan_begin_frame,
|
|
|
|
.render_view = vulkan_render_view,
|
|
|
|
.draw_particles = vulkan_draw_particles,
|
|
|
|
.draw_transparent = vulkan_draw_transparent,
|
|
|
|
.post_process = vulkan_post_process,
|
|
|
|
.set_2d = vulkan_set_2d,
|
|
|
|
.end_frame = vulkan_end_frame,
|
|
|
|
|
|
|
|
.create_cube_map = vulkan_create_cube_map,
|
|
|
|
.create_frame_buffer = vulkan_create_frame_buffer,
|
|
|
|
.destroy_frame_buffer = vulkan_destroy_frame_buffer,
|
|
|
|
.bind_framebuffer = vulkan_bind_framebuffer,
|
|
|
|
.set_viewport = vulkan_set_viewport,
|
|
|
|
.set_fov = vulkan_set_fov,
|
|
|
|
|
|
|
|
.capture_screen = vulkan_capture_screen,
|
|
|
|
|
|
|
|
.model_funcs = &model_funcs
|
2019-07-06 05:42:53 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static general_funcs_t plugin_info_general_funcs = {
|
2021-06-26 06:43:17 +00:00
|
|
|
.shutdown = vulkan_vid_render_shutdown,
|
2019-07-06 05:42:53 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static general_data_t plugin_info_general_data;
|
|
|
|
|
|
|
|
static plugin_funcs_t plugin_info_funcs = {
|
2021-06-26 06:43:17 +00:00
|
|
|
.general = &plugin_info_general_funcs,
|
|
|
|
.vid_render = &vulkan_vid_render_funcs,
|
2019-07-06 05:42:53 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static plugin_data_t plugin_info_data = {
|
2021-06-26 06:43:17 +00:00
|
|
|
.general = &plugin_info_general_data,
|
|
|
|
.vid_render = &vid_render_data,
|
2019-07-06 05:42:53 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static plugin_t plugin_info = {
|
2019-07-07 05:57:56 +00:00
|
|
|
qfp_vid_render,
|
2019-07-06 05:42:53 +00:00
|
|
|
0,
|
|
|
|
QFPLUGIN_VERSION,
|
|
|
|
"0.1",
|
2019-07-07 05:59:20 +00:00
|
|
|
"Vulkan Renderer",
|
2022-05-04 05:39:47 +00:00
|
|
|
"Copyright (C) 2019 Bill Currie <bill@taniwha.org>\n"
|
2019-07-06 05:42:53 +00:00
|
|
|
"Please see the file \"AUTHORS\" for a list of contributors",
|
|
|
|
&plugin_info_funcs,
|
|
|
|
&plugin_info_data,
|
|
|
|
};
|
|
|
|
|
|
|
|
PLUGIN_INFO(vid_render, vulkan)
|
|
|
|
{
|
|
|
|
return &plugin_info;
|
|
|
|
}
|