2018-11-08 21:12:20 +00:00
|
|
|
#include <windows.h>
|
|
|
|
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
2019-05-04 16:04:53 +00:00
|
|
|
#include "amex/amex.h"
|
2019-03-04 22:22:38 +00:00
|
|
|
|
2019-11-03 20:38:15 +00:00
|
|
|
#include "board/sg-reader.h"
|
|
|
|
|
2019-05-18 03:35:53 +00:00
|
|
|
#include "chunihook/config.h"
|
2018-11-08 21:12:20 +00:00
|
|
|
#include "chunihook/jvs.h"
|
2019-05-03 19:59:23 +00:00
|
|
|
#include "chunihook/slider.h"
|
2018-11-08 21:12:20 +00:00
|
|
|
|
2019-05-03 02:12:06 +00:00
|
|
|
#include "chuniio/chuniio.h"
|
|
|
|
|
2018-11-08 21:12:20 +00:00
|
|
|
#include "hook/process.h"
|
|
|
|
|
2019-05-14 15:15:20 +00:00
|
|
|
#include "hooklib/gfx.h"
|
2018-11-08 21:12:20 +00:00
|
|
|
#include "hooklib/serial.h"
|
2019-05-14 15:15:20 +00:00
|
|
|
#include "hooklib/spike.h"
|
2018-11-08 21:12:20 +00:00
|
|
|
|
2019-05-18 03:10:09 +00:00
|
|
|
#include "platform/platform.h"
|
2018-11-08 21:12:20 +00:00
|
|
|
|
|
|
|
#include "util/dprintf.h"
|
|
|
|
|
2019-05-18 03:10:09 +00:00
|
|
|
static HMODULE chuni_hook_mod;
|
2018-11-08 21:12:20 +00:00
|
|
|
static process_entry_t chuni_startup;
|
2019-05-18 03:35:53 +00:00
|
|
|
static struct chuni_hook_config chuni_hook_cfg;
|
2018-11-08 21:12:20 +00:00
|
|
|
|
|
|
|
static DWORD CALLBACK chuni_pre_startup(void)
|
|
|
|
{
|
|
|
|
HMODULE d3dc;
|
2021-02-09 02:18:37 +00:00
|
|
|
HMODULE dbghelp;
|
2019-11-05 23:03:24 +00:00
|
|
|
HRESULT hr;
|
2018-11-08 21:12:20 +00:00
|
|
|
|
|
|
|
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");
|
|
|
|
}
|
|
|
|
|
2021-02-09 02:18:37 +00:00
|
|
|
/* 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");
|
|
|
|
}
|
|
|
|
|
2019-05-18 03:35:53 +00:00
|
|
|
/* Config load */
|
|
|
|
|
|
|
|
chuni_hook_config_load(&chuni_hook_cfg, L".\\segatools.ini");
|
|
|
|
|
2018-11-08 21:12:20 +00:00
|
|
|
/* Hook Win32 APIs */
|
|
|
|
|
2019-10-19 21:04:34 +00:00
|
|
|
gfx_hook_init(&chuni_hook_cfg.gfx);
|
2018-11-08 21:12:20 +00:00
|
|
|
serial_hook_init();
|
|
|
|
|
2019-05-18 03:35:53 +00:00
|
|
|
/* Initialize emulation hooks */
|
2018-11-08 21:12:20 +00:00
|
|
|
|
2019-11-05 23:03:24 +00:00
|
|
|
hr = platform_hook_init(
|
2019-11-03 14:52:33 +00:00
|
|
|
&chuni_hook_cfg.platform,
|
|
|
|
"SDBT",
|
|
|
|
"AAV1",
|
|
|
|
chuni_hook_mod);
|
|
|
|
|
2019-11-05 23:03:24 +00:00
|
|
|
if (FAILED(hr)) {
|
|
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
hr = amex_hook_init(&chuni_hook_cfg.amex, chunithm_jvs_init);
|
|
|
|
|
|
|
|
if (FAILED(hr)) {
|
|
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
hr = slider_hook_init(&chuni_hook_cfg.slider);
|
|
|
|
|
|
|
|
if (FAILED(hr)) {
|
|
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
hr = sg_reader_hook_init(&chuni_hook_cfg.aime, 12);
|
|
|
|
|
|
|
|
if (FAILED(hr)) {
|
|
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
2018-11-08 21:12:20 +00:00
|
|
|
|
|
|
|
/* Initialize debug helpers */
|
|
|
|
|
2019-10-19 20:15:14 +00:00
|
|
|
spike_hook_init(L".\\segatools.ini");
|
2018-11-08 21:12:20 +00:00
|
|
|
|
|
|
|
dprintf("--- End chuni_pre_startup ---\n");
|
|
|
|
|
|
|
|
/* Jump to EXE start address */
|
|
|
|
|
|
|
|
return chuni_startup();
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOL WINAPI DllMain(HMODULE mod, DWORD cause, void *ctx)
|
|
|
|
{
|
|
|
|
HRESULT hr;
|
|
|
|
|
|
|
|
if (cause != DLL_PROCESS_ATTACH) {
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2019-05-18 03:10:09 +00:00
|
|
|
chuni_hook_mod = mod;
|
|
|
|
|
2018-11-08 21:12:20 +00:00
|
|
|
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);
|
|
|
|
}
|