2024-08-26 09:58:44 +00:00
|
|
|
/*
|
|
|
|
"CHUNITHM" (chuni) hook
|
|
|
|
|
|
|
|
Devices
|
|
|
|
|
|
|
|
JVS: 837-14572 "Type 3" I/O Board
|
|
|
|
COM1: 837-15330 Ground Slider
|
|
|
|
COM10: 837-15093-06 LED Controller Board
|
|
|
|
COM11: 837-15093-06 LED Controller Board
|
|
|
|
COM12: TN32MSEC003S "Gen 1" Aime Reader
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <windows.h>
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include "amex/amex.h"
|
|
|
|
|
|
|
|
#include "board/led15093.h"
|
|
|
|
#include "board/sg-reader.h"
|
|
|
|
|
|
|
|
#include "chunihook/config.h"
|
|
|
|
#include "chunihook/jvs.h"
|
|
|
|
#include "chunihook/slider.h"
|
|
|
|
|
|
|
|
#include "chuniio/chuniio.h"
|
|
|
|
|
|
|
|
#include "gfxhook/d3d9.h"
|
|
|
|
#include "gfxhook/gfx.h"
|
|
|
|
|
|
|
|
#include "hook/process.h"
|
|
|
|
|
|
|
|
#include "hooklib/serial.h"
|
|
|
|
#include "hooklib/spike.h"
|
|
|
|
|
|
|
|
#include "platform/platform.h"
|
|
|
|
|
|
|
|
#include "util/dprintf.h"
|
|
|
|
|
|
|
|
static HMODULE chuni_hook_mod;
|
|
|
|
static process_entry_t chuni_startup;
|
|
|
|
static struct chuni_hook_config chuni_hook_cfg;
|
|
|
|
|
|
|
|
static DWORD CALLBACK chuni_pre_startup(void)
|
|
|
|
{
|
|
|
|
HMODULE d3dc;
|
|
|
|
HMODULE dbghelp;
|
|
|
|
HRESULT hr;
|
|
|
|
|
|
|
|
dprintf("--- Begin chuni_pre_startup ---\n");
|
|
|
|
|
|
|
|
/* Pin the D3D shader compiler. This makes startup much faster. */
|
|
|
|
|
|
|
|
d3dc = LoadLibraryW(L"D3DCompiler_43.dll");
|
|
|
|
|
|
|
|
if (d3dc != NULL) {
|
|
|
|
dprintf("Pinned shader compiler, hMod=%p\n", d3dc);
|
|
|
|
} else {
|
|
|
|
dprintf("Failed to load shader compiler!\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 */
|
|
|
|
|
|
|
|
chuni_hook_config_load(&chuni_hook_cfg, L".\\segatools.ini");
|
|
|
|
|
|
|
|
/* Hook Win32 APIs */
|
|
|
|
|
|
|
|
gfx_hook_init(&chuni_hook_cfg.gfx);
|
|
|
|
gfx_d3d9_hook_init(&chuni_hook_cfg.gfx, chuni_hook_mod);
|
|
|
|
serial_hook_init();
|
|
|
|
|
|
|
|
/* Initialize emulation hooks */
|
|
|
|
|
|
|
|
hr = platform_hook_init(
|
|
|
|
&chuni_hook_cfg.platform,
|
|
|
|
"SDBT",
|
|
|
|
"AAV1",
|
|
|
|
chuni_hook_mod);
|
|
|
|
|
|
|
|
if (FAILED(hr)) {
|
|
|
|
goto fail;
|
|
|
|
}
|
|
|
|
|
|
|
|
hr = chuni_dll_init(&chuni_hook_cfg.dll, chuni_hook_mod);
|
|
|
|
|
|
|
|
if (FAILED(hr)) {
|
|
|
|
goto fail;
|
|
|
|
}
|
|
|
|
|
|
|
|
hr = amex_hook_init(&chuni_hook_cfg.amex, chunithm_jvs_init);
|
|
|
|
|
|
|
|
if (FAILED(hr)) {
|
|
|
|
goto fail;
|
|
|
|
}
|
|
|
|
|
|
|
|
hr = slider_hook_init(&chuni_hook_cfg.slider);
|
|
|
|
|
|
|
|
if (FAILED(hr)) {
|
|
|
|
goto fail;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( chuni_dll.led_init == NULL || chuni_dll.led_set_leds == NULL )
|
|
|
|
{
|
|
|
|
dprintf("IO DLL doesn't support led_init/led_set_leds, cannot start LED15093 hook\n");
|
|
|
|
} else {
|
|
|
|
hr = led15093_hook_init(&chuni_hook_cfg.led15093,
|
|
|
|
chuni_dll.led_init, chuni_dll.led_set_leds, 10, 2, 2, 1);
|
|
|
|
|
|
|
|
if (FAILED(hr)) {
|
|
|
|
goto fail;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
hr = sg_reader_hook_init(&chuni_hook_cfg.aime, 12, 1, chuni_hook_mod);
|
|
|
|
|
|
|
|
if (FAILED(hr)) {
|
|
|
|
goto fail;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Initialize debug helpers */
|
|
|
|
|
|
|
|
spike_hook_init(L".\\segatools.ini");
|
|
|
|
|
|
|
|
dprintf("--- End chuni_pre_startup ---\n");
|
|
|
|
|
|
|
|
/* Jump to EXE start address */
|
|
|
|
|
|
|
|
return chuni_startup();
|
|
|
|
|
|
|
|
fail:
|
|
|
|
ExitProcess(EXIT_FAILURE);
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL WINAPI DllMain(HMODULE mod, DWORD cause, void *ctx)
|
|
|
|
{
|
|
|
|
HRESULT hr;
|
|
|
|
|
|
|
|
if (cause != DLL_PROCESS_ATTACH) {
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
chuni_hook_mod = mod;
|
|
|
|
|
|
|
|
hr = process_hijack_startup(chuni_pre_startup, &chuni_startup);
|
|
|
|
|
|
|
|
if (!SUCCEEDED(hr)) {
|
|
|
|
dprintf("Failed to hijack process startup: %x\n", (int) hr);
|
|
|
|
}
|
|
|
|
|
|
|
|
return SUCCEEDED(hr);
|
|
|
|
}
|