mirror of
https://github.com/shadps4-emu/shadPS4.git
synced 2025-01-04 06:06:00 +00:00
fixed some silly issues
This commit is contained in:
parent
0859964888
commit
12382ddac4
|
@ -1,11 +1,13 @@
|
||||||
#include "vulkan_util.h"
|
#include "vulkan_util.h"
|
||||||
#include <algorithm>
|
|
||||||
#include <SDL_vulkan.h>
|
#include <SDL_vulkan.h>
|
||||||
|
#include <Util/Singleton.h>
|
||||||
#include <Util/log.h>
|
#include <Util/log.h>
|
||||||
#include <debug.h>
|
#include <debug.h>
|
||||||
#include <vulkan/vk_enum_string_helper.h>
|
#include <vulkan/vk_enum_string_helper.h>
|
||||||
#include <vulkan/vulkan_core.h>
|
#include <vulkan/vulkan_core.h>
|
||||||
#include <Util/Singleton.h>
|
|
||||||
|
#include <algorithm>
|
||||||
|
|
||||||
constexpr bool log_file_vulkanutil = true; // disable it to disable logging
|
constexpr bool log_file_vulkanutil = true; // disable it to disable logging
|
||||||
|
|
||||||
|
@ -76,20 +78,20 @@ void Graphics::Vulkan::vulkanCreate(Emulator::WindowCtx* ctx) {
|
||||||
ctx->swapchain = vulkanCreateSwapchain(&ctx->m_graphic_ctx, 2);
|
ctx->swapchain = vulkanCreateSwapchain(&ctx->m_graphic_ctx, 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
Emulator::VulkanSwapchain* vulkanCreateSwapchain(HLE::Libs::Graphics::GraphicCtx* ctx, u32 image_count) {
|
Emulator::VulkanSwapchain* Graphics::Vulkan::vulkanCreateSwapchain(HLE::Libs::Graphics::GraphicCtx* ctx, u32 image_count) {
|
||||||
auto* window_ctx = Singleton<Emulator::WindowCtx>::Instance();
|
auto* window_ctx = Singleton<Emulator::WindowCtx>::Instance();
|
||||||
Lib::LockMutexGuard lock(window_ctx->m_mutex);
|
Lib::LockMutexGuard lock(window_ctx->m_mutex);
|
||||||
|
|
||||||
auto* s = new Emulator::VulkanSwapchain;
|
auto* s = new Emulator::VulkanSwapchain;
|
||||||
|
|
||||||
VkExtent2D extent{};
|
VkExtent2D extent{};
|
||||||
extent.width = std::clamp(ctx->screen_width, window_ctx->m_surface_capabilities->capabilities.minImageExtent.width,
|
extent.width = clamp(ctx->screen_width, window_ctx->m_surface_capabilities->capabilities.minImageExtent.width,
|
||||||
window_ctx->m_surface_capabilities->capabilities.maxImageExtent.width);
|
window_ctx->m_surface_capabilities->capabilities.maxImageExtent.width);
|
||||||
extent.height = std::clamp(ctx->screen_height, window_ctx->m_surface_capabilities->capabilities.minImageExtent.height,
|
extent.height = clamp(ctx->screen_height, window_ctx->m_surface_capabilities->capabilities.minImageExtent.height,
|
||||||
window_ctx->m_surface_capabilities->capabilities.maxImageExtent.height);
|
window_ctx->m_surface_capabilities->capabilities.maxImageExtent.height);
|
||||||
|
|
||||||
image_count = std::clamp(image_count, window_ctx->m_surface_capabilities->capabilities.minImageCount,
|
image_count = clamp(image_count, window_ctx->m_surface_capabilities->capabilities.minImageCount,
|
||||||
window_ctx->m_surface_capabilities->capabilities.maxImageCount);
|
window_ctx->m_surface_capabilities->capabilities.maxImageCount);
|
||||||
|
|
||||||
VkSwapchainCreateInfoKHR create_info{};
|
VkSwapchainCreateInfoKHR create_info{};
|
||||||
create_info.sType = VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR;
|
create_info.sType = VK_STRUCTURE_TYPE_SWAPCHAIN_CREATE_INFO_KHR;
|
||||||
|
@ -124,14 +126,12 @@ Emulator::VulkanSwapchain* vulkanCreateSwapchain(HLE::Libs::Graphics::GraphicCtx
|
||||||
s->swapchain_format = create_info.imageFormat;
|
s->swapchain_format = create_info.imageFormat;
|
||||||
s->swapchain_extent = extent;
|
s->swapchain_extent = extent;
|
||||||
|
|
||||||
VkSwapchainKHR swapchain = nullptr;
|
vkCreateSwapchainKHR(ctx->m_device, &create_info, nullptr, &s->swapchain);
|
||||||
|
|
||||||
vkCreateSwapchainKHR(ctx->m_device, &create_info, nullptr, &swapchain);
|
vkGetSwapchainImagesKHR(ctx->m_device, s->swapchain, &s->swapchain_images_count, nullptr);
|
||||||
|
|
||||||
vkGetSwapchainImagesKHR(ctx->m_device, swapchain, &s->swapchain_images_count, nullptr);
|
|
||||||
|
|
||||||
s->swapchain_images = new VkImage[s->swapchain_images_count];
|
s->swapchain_images = new VkImage[s->swapchain_images_count];
|
||||||
vkGetSwapchainImagesKHR(ctx->m_device, swapchain, &s->swapchain_images_count, s->swapchain_images);
|
vkGetSwapchainImagesKHR(ctx->m_device, s->swapchain, &s->swapchain_images_count, s->swapchain_images);
|
||||||
|
|
||||||
s->swapchain_image_views = new VkImageView[s->swapchain_images_count];
|
s->swapchain_image_views = new VkImageView[s->swapchain_images_count];
|
||||||
for (uint32_t i = 0; i < s->swapchain_images_count; i++) {
|
for (uint32_t i = 0; i < s->swapchain_images_count; i++) {
|
||||||
|
@ -180,7 +180,6 @@ Emulator::VulkanSwapchain* vulkanCreateSwapchain(HLE::Libs::Graphics::GraphicCtx
|
||||||
}
|
}
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
|
|
||||||
}
|
}
|
||||||
void Graphics::Vulkan::vulkanCreateQueues(HLE::Libs::Graphics::GraphicCtx* ctx, const Emulator::VulkanQueues& queues) {
|
void Graphics::Vulkan::vulkanCreateQueues(HLE::Libs::Graphics::GraphicCtx* ctx, const Emulator::VulkanQueues& queues) {
|
||||||
auto get_queue = [ctx](int id, const Emulator::VulkanQueueInfo& info, bool with_mutex = false) {
|
auto get_queue = [ctx](int id, const Emulator::VulkanQueueInfo& info, bool with_mutex = false) {
|
||||||
|
|
|
@ -18,6 +18,12 @@ constexpr int VULKAN_QUEUE_GFX = 8;
|
||||||
constexpr int VULKAN_QUEUE_UTIL = 9;
|
constexpr int VULKAN_QUEUE_UTIL = 9;
|
||||||
constexpr int VULKAN_QUEUE_PRESENT = 10;
|
constexpr int VULKAN_QUEUE_PRESENT = 10;
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
const T& clamp(const T& x, const T& min, const T& max) {
|
||||||
|
if (x < min) return min;
|
||||||
|
if (x > max) return max;
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
|
||||||
void vulkanCreate(Emulator::WindowCtx* ctx);
|
void vulkanCreate(Emulator::WindowCtx* ctx);
|
||||||
void vulkanGetInstanceExtensions(Emulator::VulkanExt* ext);
|
void vulkanGetInstanceExtensions(Emulator::VulkanExt* ext);
|
||||||
|
|
Loading…
Reference in a new issue