1
0
mirror of https://gitea.tendokyu.moe/Dniel97/segatools.git synced 2024-11-15 01:27:36 +01:00
segatools-dniel97/platform/amvideo.c

207 lines
5.1 KiB
C
Raw Normal View History

#include <windows.h>
#include <assert.h>
#include <string.h>
#include <stdlib.h>
#include "hook/table.h"
#include "hooklib/dll.h"
2019-05-15 17:10:27 +02:00
#include "hooklib/reg.h"
2019-05-18 05:10:09 +02:00
#include "platform/amvideo.h"
#include "util/dprintf.h"
/* Hook functions */
static int amDllVideoOpen(void *ctx);
static int amDllVideoClose(void *ctx);
static int amDllVideoSetResolution(void *ctx, void *param);
static int amDllVideoGetVBiosVersion(void *ctx, char *dest, size_t nchars);
2019-05-15 17:10:27 +02:00
static HRESULT amvideo_reg_read_name(void *bytes, uint32_t *nbytes);
static HRESULT amvideo_reg_read_port_X(void *bytes, uint32_t *nbytes);
static HRESULT amvideo_reg_read_resolution_1(void *bytes, uint32_t *nbytes);
static HRESULT amvideo_reg_read_setting(void *bytes, uint32_t *nbytes);
2019-05-15 17:10:27 +02:00
static HRESULT amvideo_reg_read_use_segatiming(void *bytes, uint32_t *nbytes);
static const wchar_t amvideo_dll_name[] = L"$amvideo";
static const struct reg_hook_val amvideo_reg_vals[] = {
{
.name = L"name",
.read = amvideo_reg_read_name,
.type = REG_SZ,
}
};
static const struct reg_hook_val amvideo_reg_mode_vals[] = {
{
.name = L"monitor_setting_1",
.read = amvideo_reg_read_setting,
.type = REG_SZ,
}, {
.name = L"monitor_setting_2",
.read = amvideo_reg_read_setting,
.type = REG_SZ,
}, {
2019-05-15 17:10:27 +02:00
.name = L"port_1",
.read = amvideo_reg_read_port_X,
.type = REG_DWORD
}, {
.name = L"port_2",
.read = amvideo_reg_read_port_X,
.type = REG_DWORD
}, {
.name = L"port_3",
.read = amvideo_reg_read_port_X,
.type = REG_DWORD
}, {
.name = L"port_4",
.read = amvideo_reg_read_port_X,
.type = REG_DWORD
}, {
.name = L"port_5",
.read = amvideo_reg_read_port_X,
.type = REG_DWORD
}, {
.name = L"port_6",
.read = amvideo_reg_read_port_X,
.type = REG_DWORD
}, {
.name = L"port_7",
.read = amvideo_reg_read_port_X,
.type = REG_DWORD
}, {
.name = L"port_8",
.read = amvideo_reg_read_port_X,
.type = REG_DWORD
}, {
.name = L"resolution_1",
.read = amvideo_reg_read_resolution_1,
.type = REG_SZ,
}, {
.name = L"use_segatiming",
.read = amvideo_reg_read_use_segatiming,
.type = REG_DWORD,
}
};
static const struct hook_symbol amvideo_syms[] = {
{
.ordinal = 1,
.name = "amDllVideoOpen",
.patch = amDllVideoOpen,
}, {
.ordinal = 2,
.name = "amDllVideoClose",
.patch = amDllVideoClose,
}, {
.ordinal = 3,
.name = "amDllVideoSetResolution",
.patch = amDllVideoSetResolution,
}, {
.ordinal = 4,
.name = "amDllVideoGetVBiosVersion",
.patch = amDllVideoGetVBiosVersion,
}
};
2019-05-18 05:10:09 +02:00
HRESULT amvideo_hook_init(const struct amvideo_config *cfg, HMODULE redir_mod)
{
2019-05-15 17:10:27 +02:00
HRESULT hr;
2019-05-18 05:10:09 +02:00
assert(cfg != NULL);
if (!cfg->enable) {
return S_FALSE;
}
2019-05-15 17:10:27 +02:00
hr = reg_hook_push_key(
HKEY_LOCAL_MACHINE,
L"SYSTEM\\SEGA\\SystemProperty\\amVideo",
amvideo_reg_vals,
_countof(amvideo_reg_vals));
if (FAILED(hr)) {
return hr;
}
hr = reg_hook_push_key(
HKEY_LOCAL_MACHINE,
L"SYSTEM\\SEGA\\SystemProperty\\sgsetdisplaysetting\\CurrentSetting",
amvideo_reg_mode_vals,
_countof(amvideo_reg_mode_vals));
if (FAILED(hr)) {
return hr;
}
hr = dll_hook_push(
redir_mod,
2019-05-15 17:10:27 +02:00
amvideo_dll_name,
amvideo_syms,
_countof(amvideo_syms));
2019-05-15 17:10:27 +02:00
if (FAILED(hr)) {
return hr;
}
return S_OK;
}
static int amDllVideoOpen(void *ctx)
{
dprintf("AmVideo: %s\n", __func__);
return 0;
}
static int amDllVideoClose(void *ctx)
{
dprintf("AmVideo: %s\n", __func__);
return 0;
}
static int amDllVideoSetResolution(void *ctx, void *param)
{
dprintf("AmVideo: %s\n", __func__);
return 0;
}
static int amDllVideoGetVBiosVersion(void *ctx, char *dest, size_t nchars)
{
dprintf("AmVideo: %s\n", __func__);
strcpy(dest, "01.02.03.04.05");
return 0;
}
2019-05-15 17:10:27 +02:00
static HRESULT amvideo_reg_read_name(void *bytes, uint32_t *nbytes)
{
return reg_hook_read_wstr(bytes, nbytes, amvideo_dll_name);
}
static HRESULT amvideo_reg_read_port_X(void *bytes, uint32_t *nbytes)
{
return reg_hook_read_u32(bytes, nbytes, 1);
}
static HRESULT amvideo_reg_read_resolution_1(void *bytes, uint32_t *nbytes)
{
return reg_hook_read_wstr(bytes, nbytes, L"1920x1080");
}
static HRESULT amvideo_reg_read_setting(void *bytes, uint32_t *nbytes)
{
return reg_hook_read_wstr(bytes, nbytes, L"0");
}
2019-05-15 17:10:27 +02:00
static HRESULT amvideo_reg_read_use_segatiming(void *bytes, uint32_t *nbytes)
{
return reg_hook_read_u32(bytes, nbytes, 0);
}