/* "Hatsune Miku Project DIVA Arcade " (diva) hook Devices JVS: 837-14572 "Type 3" I/O Board COM1: 3M Touch Systems 78-0011-2353-4 Touch Controller Board COM10: TN32MSEC003S "Gen 1" Aime Reader COM11: 837-15275 Touch Slider */ #include #include #include "amex/amex.h" #include "board/sg-reader.h" #include "divahook/config.h" #include "divahook/diva-dll.h" #include "divahook/jvs.h" #include "divahook/slider.h" #include "gfxhook/gfx.h" #include "gfxhook/gl.h" #include "hook/process.h" #include "hooklib/serial.h" #include "hooklib/spike.h" #include "platform/platform.h" #include "util/dprintf.h" static HMODULE diva_hook_mod; static process_entry_t diva_startup; static struct diva_hook_config diva_hook_cfg; static DWORD CALLBACK diva_pre_startup(void) { HRESULT hr; HMODULE dbghelp; dprintf("--- Begin diva_pre_startup ---\n"); /* Pin dbghelp so the path hooks apply to it. */ dbghelp = LoadLibraryW(L"dbghelp.dll"); if (dbghelp != NULL) { dprintf("Pinned debug helper library, hMod=%p\n", dbghelp); } else { dprintf("Failed to load debug helper library!\n"); } /* Config load */ diva_hook_config_load(&diva_hook_cfg, L".\\segatools.ini"); /* Hook Win32 APIs */ dvd_hook_init(&diva_hook_cfg.dvd, diva_hook_mod); gfx_hook_init(&diva_hook_cfg.gfx); gfx_gl_hook_init(&diva_hook_cfg.gfx, diva_hook_mod); serial_hook_init(); /* Initialize emulation hooks */ hr = platform_hook_init( &diva_hook_cfg.platform, "SBZV", "AAV0", diva_hook_mod); if (FAILED(hr)) { goto fail; } hr = diva_dll_init(&diva_hook_cfg.dll, diva_hook_mod); if (FAILED(hr)) { goto fail; } hr = amex_hook_init(&diva_hook_cfg.amex, diva_jvs_init); if (FAILED(hr)) { goto fail; } hr = sg_reader_hook_init(&diva_hook_cfg.aime, 10, 1, diva_hook_mod); if (FAILED(hr)) { goto fail; } hr = slider_hook_init(&diva_hook_cfg.slider); if (FAILED(hr)) { goto fail; } /* Initialize debug helpers */ spike_hook_init(L".\\segatools.ini"); dprintf("--- End diva_pre_startup ---\n"); /* Jump to EXE start address */ return diva_startup(); fail: ExitProcess(EXIT_FAILURE); } BOOL WINAPI DllMain(HMODULE mod, DWORD cause, void *ctx) { HRESULT hr; if (cause != DLL_PROCESS_ATTACH) { return TRUE; } diva_hook_mod = mod; hr = process_hijack_startup(diva_pre_startup, &diva_startup); if (!SUCCEEDED(hr)) { dprintf("Failed to hijack process startup: %x\n", (int) hr); } return SUCCEEDED(hr); }