From a626e9e635c4400e0e3a46958b31cc0ab2a74012 Mon Sep 17 00:00:00 2001 From: icex2 Date: Sun, 6 Oct 2019 21:23:01 +0200 Subject: [PATCH] iidxhook5: Refactor to use new d3d9 module --- src/main/iidxhook5/dllmain.c | 47 ++++++++++++++++++++++-------------- 1 file changed, 29 insertions(+), 18 deletions(-) diff --git a/src/main/iidxhook5/dllmain.c b/src/main/iidxhook5/dllmain.c index 05f3f75..d00bd49 100644 --- a/src/main/iidxhook5/dllmain.c +++ b/src/main/iidxhook5/dllmain.c @@ -17,6 +17,8 @@ #include "ezusb2-iidx-emu/msg.h" +#include "hook/d3d9.h" + #include "hooklib/acp.h" #include "hooklib/adapter.h" #include "hooklib/app.h" @@ -47,6 +49,32 @@ static const irp_handler_t iidxhook_handlers[] = { settings_hook_dispatch_irp, }; +static const hook_d3d9_irp_handler_t iidxhook_d3d9_handlers[] = { + iidxhook_util_d3d9_irp_handler, +}; + +static void iidxhook5_setup_d3d9_hooks(const struct iidxhook_config_gfx* config_gfx) +{ + struct iidxhook_util_d3d9_config d3d9_config; + + iidxhook_util_d3d9_init_config(&d3d9_config); + + d3d9_config.windowed = config_gfx->windowed; + d3d9_config.framed = config_gfx->framed; + d3d9_config.override_window_width = config_gfx->window_width; + d3d9_config.override_window_height = config_gfx->window_height; + d3d9_config.framerate_limit = config_gfx->frame_rate_limit; + d3d9_config.pci_vid = config_gfx->pci_id_vid; + d3d9_config.pci_pid = config_gfx->pci_id_pid; + d3d9_config.scale_back_buffer_width = config_gfx->scale_back_buffer_width; + d3d9_config.scale_back_buffer_height = config_gfx->scale_back_buffer_height; + d3d9_config.scale_back_buffer_filter = config_gfx->scale_back_buffer_filter; + + iidxhook_util_d3d9_configure(&d3d9_config); + + hook_d3d9_init(iidxhook_d3d9_handlers, lengthof(iidxhook_d3d9_handlers)); +} + static bool my_dll_entry_init(char *sidcode, struct property_node *param) { struct cconfig* config; @@ -75,23 +103,7 @@ static bool my_dll_entry_init(char *sidcode, struct property_node *param) log_info(IIDXHOOK5_INFO_HEADER); log_info("Initializing iidxhook..."); - if (config_gfx.windowed) { - d3d9_set_windowed(config_gfx.framed, config_gfx.window_width, - config_gfx.window_height); - } - - if (config_gfx.pci_id_pid != 0 && config_gfx.pci_id_vid != 0) { - d3d9_set_pci_id(config_gfx.pci_id_pid, config_gfx.pci_id_vid); - } - - if (config_gfx.frame_rate_limit > 0) { - d3d9_set_frame_rate_limit(config_gfx.frame_rate_limit); - } - - if (config_gfx.scale_back_buffer_width > 0 && config_gfx.scale_back_buffer_height > 0) { - d3d9_scale_back_buffer(config_gfx.scale_back_buffer_width, config_gfx.scale_back_buffer_height, - config_gfx.scale_back_buffer_filter); - } + iidxhook5_setup_d3d9_hooks(&config_gfx); /* Start up IIDXIO.DLL */ log_info("Starting IIDX IO backend"); @@ -167,7 +179,6 @@ BOOL WINAPI DllMain(HMODULE mod, DWORD reason, void *ctx) acp_hook_init(); adapter_hook_init(); - d3d9_hook_init(); settings_hook_init(); end: