mirror of
https://github.com/moonlight-stream/moonlight-qt
synced 2025-01-24 08:35:01 +00:00
Fix a few minor Vulkan renderer bugs
This commit is contained in:
parent
8f2db99406
commit
d75663052d
1 changed files with 8 additions and 4 deletions
|
@ -137,7 +137,7 @@ PlVkRenderer::~PlVkRenderer()
|
||||||
}
|
}
|
||||||
|
|
||||||
#define POPULATE_FUNCTION(name) \
|
#define POPULATE_FUNCTION(name) \
|
||||||
fn_##name = (PFN_##name)vkInstParams.get_proc_addr(m_PlVkInstance->instance, #name); \
|
fn_##name = (PFN_##name)m_PlVkInstance->get_proc_addr(m_PlVkInstance->instance, #name); \
|
||||||
if (fn_##name == nullptr) { \
|
if (fn_##name == nullptr) { \
|
||||||
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, \
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, \
|
||||||
"Missing required Vulkan function: " #name); \
|
"Missing required Vulkan function: " #name); \
|
||||||
|
@ -218,7 +218,7 @@ bool PlVkRenderer::initialize(PDECODER_PARAMETERS params)
|
||||||
else {
|
else {
|
||||||
// We want immediate mode for V-Sync disabled if possible
|
// We want immediate mode for V-Sync disabled if possible
|
||||||
if (isPresentModeSupported(VK_PRESENT_MODE_IMMEDIATE_KHR)) {
|
if (isPresentModeSupported(VK_PRESENT_MODE_IMMEDIATE_KHR)) {
|
||||||
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,
|
SDL_LogInfo(SDL_LOG_CATEGORY_APPLICATION,
|
||||||
"Using Immediate present mode with V-Sync disabled");
|
"Using Immediate present mode with V-Sync disabled");
|
||||||
presentMode = VK_PRESENT_MODE_IMMEDIATE_KHR;
|
presentMode = VK_PRESENT_MODE_IMMEDIATE_KHR;
|
||||||
}
|
}
|
||||||
|
@ -470,7 +470,7 @@ void PlVkRenderer::renderFrame(AVFrame *frame)
|
||||||
if (i == Overlay::OverlayStatusUpdate) {
|
if (i == Overlay::OverlayStatusUpdate) {
|
||||||
// Bottom Left
|
// Bottom Left
|
||||||
overlayParts[i].dst.x0 = 0;
|
overlayParts[i].dst.x0 = 0;
|
||||||
overlayParts[i].dst.y0 = SDL_min(0, targetFrame.crop.y1 - overlayParts[i].src.y1);
|
overlayParts[i].dst.y0 = SDL_max(0, targetFrame.crop.y1 - overlayParts[i].src.y1);
|
||||||
}
|
}
|
||||||
else if (i == Overlay::OverlayDebug) {
|
else if (i == Overlay::OverlayDebug) {
|
||||||
// Top left
|
// Top left
|
||||||
|
@ -597,6 +597,8 @@ void PlVkRenderer::notifyOverlayUpdated(Overlay::OverlayType type)
|
||||||
texParams.blit_src = !!(texFormat->caps & PL_FMT_CAP_BLITTABLE);
|
texParams.blit_src = !!(texFormat->caps & PL_FMT_CAP_BLITTABLE);
|
||||||
texParams.debug_tag = PL_DEBUG_TAG;
|
texParams.debug_tag = PL_DEBUG_TAG;
|
||||||
if (!pl_tex_recreate(m_Vulkan->gpu, &m_Overlays[type].stagingOverlay.tex, &texParams)) {
|
if (!pl_tex_recreate(m_Vulkan->gpu, &m_Overlays[type].stagingOverlay.tex, &texParams)) {
|
||||||
|
pl_tex_destroy(m_Vulkan->gpu, &m_Overlays[type].stagingOverlay.tex);
|
||||||
|
SDL_zero(m_Overlays[type].stagingOverlay);
|
||||||
SDL_FreeSurface(newSurface);
|
SDL_FreeSurface(newSurface);
|
||||||
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,
|
||||||
"pl_tex_recreate() failed");
|
"pl_tex_recreate() failed");
|
||||||
|
@ -612,6 +614,8 @@ void PlVkRenderer::notifyOverlayUpdated(Overlay::OverlayType type)
|
||||||
xferParams.callback = overlayUploadComplete;
|
xferParams.callback = overlayUploadComplete;
|
||||||
xferParams.priv = newSurface;
|
xferParams.priv = newSurface;
|
||||||
if (!pl_tex_upload(m_Vulkan->gpu, &xferParams)) {
|
if (!pl_tex_upload(m_Vulkan->gpu, &xferParams)) {
|
||||||
|
pl_tex_destroy(m_Vulkan->gpu, &m_Overlays[type].stagingOverlay.tex);
|
||||||
|
SDL_zero(m_Overlays[type].stagingOverlay);
|
||||||
SDL_FreeSurface(newSurface);
|
SDL_FreeSurface(newSurface);
|
||||||
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION,
|
||||||
"pl_tex_upload() failed");
|
"pl_tex_upload() failed");
|
||||||
|
|
Loading…
Reference in a new issue