C instance creation

This commit is contained in:
Greg Wells
2025-05-20 22:35:51 -04:00
parent a4166ae5c2
commit fa58a2f2d6
12 changed files with 150 additions and 112 deletions

View File

@@ -1,6 +1,6 @@
#pragma once #pragma once
#include <platform/gryphn_platform_include.h> #include <platform/gryphn_platform_include.h>
#include <core/init/gryphn_init.h> #include <core/instance/init/gryphn_init.h>
#include <core/instance/gryphn_instance.h> #include <core/instance/gryphn_instance.h>
// #pragma once // #pragma once

View File

@@ -17,4 +17,4 @@
// typedef float gnFloat; // typedef float gnFloat;
// typedef size_t gnSize; // typedef size_t gnSize;
// #define GN_EXPORT extern "C" #define GN_EXPORT extern "C"

View File

@@ -1,4 +1,5 @@
set(CMAKE_EXPORT_COMPILE_COMMANDS on) set(CMAKE_EXPORT_COMPILE_COMMANDS on)
set(CMAKE_CXX_STANDARD 17)
project(GryphnMetalImpl) project(GryphnMetalImpl)
file(GLOB_RECURSE SOURCE_FILES CONFIGURE_DEPENDS file(GLOB_RECURSE SOURCE_FILES CONFIGURE_DEPENDS

View File

@@ -0,0 +1,19 @@
#include <gryphn/gryphn.h>
#include <gryphn/gryphn_utils.h>
// #include "bridge/metal_bridge.h"
#include "metal_instance.h"
GN_EXPORT gnReturnCode gnCreateInstanceFn(gnInstance* instance) {
if (instance->instance == nullptr) instance->instance = new gnPlatformInstance();
return GN_SUCCESS;
}
GN_EXPORT void gnDestroyInstanceFn(gnInstance& instance) {
}
GN_EXPORT gnReturnCode gnCreateMacOSWindowSurfaceFn(gnInstance& instance, NS::Window* window, NS::View* view) {
if (instance.instance == nullptr) instance.instance = new gnPlatformInstance();
instance.instance->metalContentView = view;
return GN_SUCCESS;
}

View File

@@ -0,0 +1,10 @@
#pragma once
#include <Metal/Metal.hpp>
#include <AppKit/AppKit.hpp>
struct GLFWwindow;
struct gnPlatformInstance {
NS::View* metalContentView;
MTL::RenderPipelineState* framebufferRenderer, *testSquareRenderer;
};

View File

@@ -1,3 +1,4 @@
#include "utils/gryphn_bool.h"
#include <core/gryphn_support.h> #include <core/gryphn_support.h>
GN_EXPORT gnBool gnAPISupportsFn(gnFeature feature) { GN_EXPORT gnBool gnAPISupportsFn(gnFeature feature) {

View File

@@ -1,25 +1,24 @@
#include "gryphn/gryphn_utils.h" #include "gryphn/gryphn_utils.h"
#include "vector" #include "vector"
#include <cstring> #include <cstring>
#include "debugger/vulkan_debugger.h" // #include "debugger/vulkan_debugger.h"
#include "vulkan_instance.h" #include "vulkan_instance.h"
// now I gotta do some shit to setup debug layers // now I gotta do some shit to setup debug layers
bool checkValidationLayerSupport(gnList<gnString> layers_to_validate) { bool checkValidationLayerSupport(std::vector<std::string> layers_to_validate) {
uint32_t layerCount; uint32_t layerCount;
vkEnumerateInstanceLayerProperties(&layerCount, nullptr); vkEnumerateInstanceLayerProperties(&layerCount, nullptr);
std::vector<VkLayerProperties> availableLayers(layerCount); std::vector<VkLayerProperties> availableLayers(layerCount);
vkEnumerateInstanceLayerProperties(&layerCount, availableLayers.data()); vkEnumerateInstanceLayerProperties(&layerCount, availableLayers.data());
for (int i = 0; i < gnListLength(layers_to_validate); i++) { for (int i = 0; i < layers_to_validate.size(); i++) {
gnString layerName = layers_to_validate[i];
bool layerFound = false; bool layerFound = false;
for (const auto& layerProperties : availableLayers) { for (const auto& layerProperties : availableLayers) {
if (strcmp(gnToCString(layerName), layerProperties.layerName) == 0) { if (strcmp(layers_to_validate[i].c_str(), layerProperties.layerName) == 0) {
layerFound = true; layerFound = true;
break; break;
} }
@@ -32,24 +31,26 @@ bool checkValidationLayerSupport(gnList<gnString> layers_to_validate) {
return true; return true;
} }
void gnInstanceSetAppInfoFn(gnInstance& instance, gnAppInfo& info) { // void gnInstanceSetAppInfoFn(gnInstance& instance, gnInstanceInfo& info) {
if (instance.instance == nullptr) instance.instance = new gnPlatformInstanceData(); // if (instance.instance == nullptr) instance.instance = new gnPlatformInstanceData();
instance.AppInfo = info; // instance.AppInfo = info;
instance.instance->appInfo = {}; // instance.instance->appInfo = {};
instance.instance->appInfo.sType = VK_STRUCTURE_TYPE_APPLICATION_INFO; // instance.instance->appInfo.sType = VK_STRUCTURE_TYPE_APPLICATION_INFO;
instance.instance->appInfo.pApplicationName = "Hello Triangle"; // instance.instance->appInfo.pApplicationName = "Hello Triangle";
instance.instance->appInfo.applicationVersion = VK_MAKE_VERSION(1, 0, 0); // instance.instance->appInfo.applicationVersion = VK_MAKE_VERSION(1, 0, 0);
instance.instance->appInfo.pEngineName = "No Engine"; // instance.instance->appInfo.pEngineName = "No Engine";
instance.instance->appInfo.engineVersion = VK_MAKE_VERSION(1, 0, 0); // instance.instance->appInfo.engineVersion = VK_MAKE_VERSION(1, 0, 0);
instance.instance->appInfo.apiVersion = VK_API_VERSION_1_3; // instance.instance->appInfo.apiVersion = VK_API_VERSION_1_3;
} // }
GN_EXPORT gnReturnCode gnCreateInstanceFn(gnInstance* instance) { GN_EXPORT gnReturnCode gnCreateInstanceFn(gnInstance* instance, gnInstanceInfo instanceInfo) {
if (instance->debugger != nullptr && !checkValidationLayerSupport(instance->debugger->debug_layers)) { instance->instance = new gnPlatformInstance();
return gnReturnError(GN_FAILED_CREATE_INSTANCE, "validation layers requested, but not available!");
} // if (instance->debugger != nullptr && !checkValidationLayerSupport(instance->debugger->debug_layers)) {
gnInstanceSetAppInfoFn(*instance, instance->AppInfo); // return gnReturnError(GN_FAILED_CREATE_INSTANCE, "validation layers requested, but not available!");
// }
// gnInstanceSetAppInfoFn(*instance, instance->AppInfo);
instance->valid = true; instance->valid = true;
@@ -72,46 +73,50 @@ GN_EXPORT gnReturnCode gnCreateInstanceFn(gnInstance* instance) {
instance->instance->extensions.push_back("VK_KHR_surface"); instance->instance->extensions.push_back("VK_KHR_surface");
if (instance->debugger) // if (instance->debugger)
instance->instance->extensions.push_back(VK_EXT_DEBUG_UTILS_EXTENSION_NAME); // instance->instance->extensions.push_back(VK_EXT_DEBUG_UTILS_EXTENSION_NAME);
VkInstanceCreateInfo createInfo{}; VkApplicationInfo appInfo = {
.sType = VK_STRUCTURE_TYPE_APPLICATION_INFO,
.pApplicationName = gnToCString(instanceInfo.applicationName),
.applicationVersion = instanceInfo.applicationVersion,
.pEngineName = gnToCString(instanceInfo.engineName),
.engineVersion = instanceInfo.engineVersion,
.apiVersion = VK_API_VERSION_1_3,
};
VkInstanceCreateInfo createInfo = {};
createInfo.sType = VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO; createInfo.sType = VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO;
createInfo.pApplicationInfo = &instance->instance->appInfo; createInfo.pApplicationInfo = &appInfo;
createInfo.flags = VK_INSTANCE_CREATE_ENUMERATE_PORTABILITY_BIT_KHR; createInfo.flags = VK_INSTANCE_CREATE_ENUMERATE_PORTABILITY_BIT_KHR;
// auto extensions = getRequiredExtensions(instance->debugger); // auto extensions = getRequiredExtensions(instance->debugger);
createInfo.enabledExtensionCount = static_cast<uint32_t>(instance->instance->extensions.size());; createInfo.enabledExtensionCount = static_cast<uint32_t>(instance->instance->extensions.size());;
createInfo.ppEnabledExtensionNames = instance->instance->extensions.data(); createInfo.ppEnabledExtensionNames = instance->instance->extensions.data();
VkDebugUtilsMessengerCreateInfoEXT debugCreateInfo{}; // VkDebugUtilsMessengerCreateInfoEXT debugCreateInfo{};
if (instance->debugger != nullptr) { // if (instance->debugger != nullptr) {
auto validation_layers = instance->debugger->debug_layers; // auto validation_layers = instance->debugger->debug_layers;
gnList<const char*> validation_layers_c = gnCreateList<const char*>(); // gnList<const char*> validation_layers_c = gnCreateList<const char*>();
for (int i = 0; i < gnListLength(validation_layers); i++) // for (int i = 0; i < gnListLength(validation_layers); i++)
gnListAdd(validation_layers_c, gnToCString(validation_layers[i])); // gnListAdd(validation_layers_c, gnToCString(validation_layers[i]));
createInfo.enabledLayerCount = static_cast<uint32_t>(gnListLength(validation_layers_c)); // createInfo.enabledLayerCount = static_cast<uint32_t>(gnListLength(validation_layers_c));
createInfo.ppEnabledLayerNames = gnListData(validation_layers_c); // createInfo.ppEnabledLayerNames = gnListData(validation_layers_c);
populateDebugMessengerCreateInfo(debugCreateInfo); // populateDebugMessengerCreateInfo(debugCreateInfo);
createInfo.pNext = (VkDebugUtilsMessengerCreateInfoEXT*) &debugCreateInfo; // createInfo.pNext = (VkDebugUtilsMessengerCreateInfoEXT*) &debugCreateInfo;
} else { // } else {
createInfo.enabledLayerCount = 0; createInfo.enabledLayerCount = 0;
} // }
if (vkCreateInstance(&createInfo, nullptr, &instance->instance->vk_instance) != VK_SUCCESS) { if (vkCreateInstance(&createInfo, nullptr, &instance->instance->vk_instance) != VK_SUCCESS) {
return gnReturnError(GN_FAILED_CREATE_INSTANCE, "im to lazy to query vulkan why"); return GN_FAILED_CREATE_INSTANCE;
} }
uint32_t deviceCount; // if (instance->debugger->debugger == nullptr) instance->debugger->debugger = new gnPlatformDebugger();
vkEnumeratePhysicalDevices(instance->instance->vk_instance, &deviceCount, nullptr); // instance->debugger->debugger->instance = &instance->instance->vk_instance;
if (deviceCount == 0)
return gnReturnError(GN_FAILED_CREATE_INSTANCE, "no devices support vulkan");
if (instance->debugger->debugger == nullptr) instance->debugger->debugger = new gnPlatformDebugger();
instance->debugger->debugger->instance = &instance->instance->vk_instance;
return GN_SUCCESS; return GN_SUCCESS;
} }

View File

@@ -4,8 +4,9 @@
#ifdef GN_PLATFORM_MACOS #ifdef GN_PLATFORM_MACOS
#include "vulkan_macos_bridge.h" #include "vulkan_macos_bridge.h"
#endif #endif
#include "vector"
struct gnPlatformInstanceData { struct gnPlatformInstance {
VkInstance vk_instance; VkInstance vk_instance;
VkApplicationInfo appInfo; VkApplicationInfo appInfo;
VkSurfaceKHR window_surface; VkSurfaceKHR window_surface;

View File

@@ -1,70 +1,70 @@
#include "vulkan_instance.h" // #include "vulkan_instance.h"
#ifdef GN_PLATFORM_LINUX // #ifdef GN_PLATFORM_LINUX
#ifdef GN_WINDOW_X11 // #ifdef GN_WINDOW_X11
#include <vulkan/vulkan_xlib.h> // #include <vulkan/vulkan_xlib.h>
#include <X11/Xlib.h> // #include <X11/Xlib.h>
GN_EXPORT gnReturnCode gnCreateX11WindowSurfaceFn(gnInstance& instance, Display* display, Window* window) { // GN_EXPORT gnReturnCode gnCreateX11WindowSurfaceFn(gnInstance& instance, Display* display, Window* window) {
VkXlibSurfaceCreateInfoKHR info{}; // VkXlibSurfaceCreateInfoKHR info{};
info.sType = VK_STRUCTURE_TYPE_XLIB_SURFACE_CREATE_INFO_KHR; // info.sType = VK_STRUCTURE_TYPE_XLIB_SURFACE_CREATE_INFO_KHR;
info.dpy = display; // info.dpy = display;
info.window = window; // info.window = window;
VkResult result = vkCreateXlibSurfaceKHR(instance.instance->vk_instance, &info, nullptr, &instance.instance->window_surface); // VkResult result = vkCreateXlibSurfaceKHR(instance.instance->vk_instance, &info, nullptr, &instance.instance->window_surface);
if (result != VK_SUCCESS) // if (result != VK_SUCCESS)
return gnReturnError(GN_FAILED_TO_ATTACH_WINDOW, result); // return gnReturnError(GN_FAILED_TO_ATTACH_WINDOW, result);
return GN_SUCCESS; // return GN_SUCCESS;
} // }
#endif // #endif
#ifdef GN_WINFDOW_WAYLAND // #ifdef GN_WINFDOW_WAYLAND
#include <vulkan/vulkan_wayland.h> // #include <vulkan/vulkan_wayland.h>
#include <wayland-client.h> // #include <wayland-client.h>
GN_EXPORT gnReturnCode gnCreateWaylandWindowSurfaceFn(gnInstance& instance, wl_display* display, wl_surface* surface) { // GN_EXPORT gnReturnCode gnCreateWaylandWindowSurfaceFn(gnInstance& instance, wl_display* display, wl_surface* surface) {
VkWaylandSurfaceCreateInfoKHR info{}; // VkWaylandSurfaceCreateInfoKHR info{};
info.sType = VK_STRUCTURE_TYPE_WAYLAND_SURFACE_CREATE_INFO_KHR; // info.sType = VK_STRUCTURE_TYPE_WAYLAND_SURFACE_CREATE_INFO_KHR;
info.display = display; // info.display = display;
info.surface = surface; // info.surface = surface;
VkSurfaceKHR surface; // VkSurfaceKHR surface;
VkResult result = vkCreateWaylandSurfaceKHR(instance.instance->vk_instance, &info, nullptr, &instance.instance->window_surface); // VkResult result = vkCreateWaylandSurfaceKHR(instance.instance->vk_instance, &info, nullptr, &instance.instance->window_surface);
if (result != VK_SUCCESS) // if (result != VK_SUCCESS)
return gnReturnError(GN_FAILED_TO_ATTACH_WINDOW, result); // return gnReturnError(GN_FAILED_TO_ATTACH_WINDOW, result);
return GN_SUCCESS; // return GN_SUCCESS;
} // }
#endif // #endif
#endif // #endif
#ifdef GN_PLATFORM_WINDOWS // #ifdef GN_PLATFORM_WINDOWS
#include "vulkan/vulkan_win32.h" // #include "vulkan/vulkan_win32.h"
GN_EXPORT gnReturnCode gnCreateWindowsWindowSurfaceFn(gnInstance& instance, HWND* window, HINSTANCE* instance) { // GN_EXPORT gnReturnCode gnCreateWindowsWindowSurfaceFn(gnInstance& instance, HWND* window, HINSTANCE* instance) {
VkWin32SurfaceCreateInfoKHR info{}; // VkWin32SurfaceCreateInfoKHR info{};
info.sType = VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR; // info.sType = VK_STRUCTURE_TYPE_WIN32_SURFACE_CREATE_INFO_KHR;
info.hwnd = window; // info.hwnd = window;
info.hinstance = instance; // info.hinstance = instance;
VkSurfaceKHR surface; // VkSurfaceKHR surface;
VkResult result = vkCreateWin32SurfaceKHR(instance.instance->vk_instance, &info, nullptr, &instance.instance->window_surface); // VkResult result = vkCreateWin32SurfaceKHR(instance.instance->vk_instance, &info, nullptr, &instance.instance->window_surface);
if (result != VK_SUCCESS) // if (result != VK_SUCCESS)
return gnReturnError(GN_FAILED_TO_ATTACH_WINDOW, result); // return gnReturnError(GN_FAILED_TO_ATTACH_WINDOW, result);
return GN_SUCCESS; // return GN_SUCCESS;
} // }
#endif // #endif
#include "vulkan/vulkan_metal.h" // #include "vulkan/vulkan_metal.h"
#ifdef GN_PLATFORM_MACOS // #ifdef GN_PLATFORM_MACOS
GN_EXPORT gnReturnCode gnCreateMacOSWindowSurfaceFn(gnInstance& instance, NS::Window* window, NS::View* view) { // GN_EXPORT gnReturnCode gnCreateMacOSWindowSurfaceFn(gnInstance& instance, NS::Window* window, NS::View* view) {
VkMetalSurfaceCreateInfoEXT surfaceCreateInfo = {}; // VkMetalSurfaceCreateInfoEXT surfaceCreateInfo = {};
surfaceCreateInfo.sType = VK_STRUCTURE_TYPE_METAL_SURFACE_CREATE_INFO_EXT; // surfaceCreateInfo.sType = VK_STRUCTURE_TYPE_METAL_SURFACE_CREATE_INFO_EXT;
surfaceCreateInfo.pNext = nullptr; // surfaceCreateInfo.pNext = nullptr;
surfaceCreateInfo.flags = 0; // surfaceCreateInfo.flags = 0;
surfaceCreateInfo.pLayer = macosBridge(window, view); // surfaceCreateInfo.pLayer = macosBridge(window, view);
VkSurfaceKHR surface; // VkSurfaceKHR surface;
VkResult result = vkCreateMetalSurfaceEXT(instance.instance->vk_instance, &surfaceCreateInfo, nullptr, &instance.instance->window_surface); // VkResult result = vkCreateMetalSurfaceEXT(instance.instance->vk_instance, &surfaceCreateInfo, nullptr, &instance.instance->window_surface);
if (result != VK_SUCCESS) // if (result != VK_SUCCESS)
return gnReturnError(GN_FAILED_TO_ATTACH_WINDOW, result); // return gnReturnError(GN_FAILED_TO_ATTACH_WINDOW, result);
return GN_SUCCESS; // return GN_SUCCESS;
} // }
#endif // #endif

View File

@@ -6,6 +6,7 @@ gnReturnCode gnCreateInstance(gnInstance* instance, struct gnInstanceInfo_t info
if (!gnIsAPISupported(info.renderingAPI)) return GN_UNSUPPORTED_RENDERING_API; if (!gnIsAPISupported(info.renderingAPI)) return GN_UNSUPPORTED_RENDERING_API;
instance->dynamicLib = gnLoadRenderingDLL(info.renderingAPI); instance->dynamicLib = gnLoadRenderingDLL(info.renderingAPI);
if (instance->dynamicLib == NULL) return GN_UNABLE_TO_LOAD_DYNAMIC_LIBARRY; if (instance->dynamicLib == NULL) return GN_UNABLE_TO_LOAD_DYNAMIC_LIBARRY;
instance->functions = malloc(sizeof(struct gnFunctions_t));
gnLoadFunctions(instance->dynamicLib, instance->functions); gnLoadFunctions(instance->dynamicLib, instance->functions);
return instance->functions->_gnCreateInstance(instance, info); return instance->functions->_gnCreateInstance(instance, info);

View File

@@ -18,7 +18,7 @@ gnRenderingAPI* gnGetSupportedRenderingAPIs(int* count) {
struct gnDynamicLibrary_t* gnLoadDynamicLibrary(const gnString path) { struct gnDynamicLibrary_t* gnLoadDynamicLibrary(const gnString path) {
struct gnDynamicLibrary_t* dll = malloc(sizeof(struct gnDynamicLibrary_t)); struct gnDynamicLibrary_t* dll = malloc(sizeof(struct gnDynamicLibrary_t));
dll->dllPtr = dlopen(gnToCString(gnCombineStrings(path, ".dylib")), RTLD_LAZY), dll->dllPtr = dlopen(gnToCString(gnCombineStrings(path, ".dylib")), RTLD_LAZY),
dll->isValid = true dll->isValid = true;
if (dll->dllPtr == NULL) dll->isValid = false; if (dll->dllPtr == NULL) dll->isValid = false;
return dll; return dll;
} }

View File

@@ -4,7 +4,8 @@ typedef enum gnReturnCode_t {
GN_SUCCESS, GN_SUCCESS,
GN_UNKNOWN_RENDERINGAPI, GN_UNKNOWN_RENDERINGAPI,
GN_UNSUPPORTED_RENDERING_API, GN_UNSUPPORTED_RENDERING_API,
GN_UNABLE_TO_LOAD_DYNAMIC_LIBARRY GN_UNABLE_TO_LOAD_DYNAMIC_LIBARRY,
GN_FAILED_CREATE_INSTANCE
// GN_UNKNOWN_ERROR, // GN_UNKNOWN_ERROR,
// GN_UNKNOWN_FRAMEBUFFER_ATTACHMENT, // GN_UNKNOWN_FRAMEBUFFER_ATTACHMENT,
@@ -19,7 +20,6 @@ typedef enum gnReturnCode_t {
// GN_FAILED_CREATE_PRESENTATION_QUEUE, // GN_FAILED_CREATE_PRESENTATION_QUEUE,
// GN_FAILED_TO_CREATE_FRAMEBUFFER, // GN_FAILED_TO_CREATE_FRAMEBUFFER,
// GN_FAILED_CREATE_RENDERPASS, // GN_FAILED_CREATE_RENDERPASS,
// GN_FAILED_CREATE_INSTANCE,
// GN_FAILED_TO_ATTACH_WINDOW, // GN_FAILED_TO_ATTACH_WINDOW,
// GN_FAILED_TO_CREATE_IMAGE // GN_FAILED_TO_CREATE_IMAGE
} gnReturnCode; } gnReturnCode;