1
0
mirror of https://gitea.tendokyu.moe/Dniel97/segatools.git synced 2025-01-07 06:51:32 +01:00

board/sg-reader.c: Streamline further

Remove remaining pointless boilerplate, turn it into a free-
standing hook, since its aimeio.dll dependency forces it to be a
singleton anyway.
This commit is contained in:
Tau 2019-05-03 17:21:38 -04:00
parent 8158d01ed9
commit b172c22322
14 changed files with 50 additions and 209 deletions

View File

@ -17,18 +17,14 @@
#include "util/dprintf.h" #include "util/dprintf.h"
#include "util/dump.h" #include "util/dump.h"
static HRESULT sg_reader_handle_irp_locked( static HRESULT sg_reader_handle_irp(struct irp *irp);
struct sg_reader *reader, static HRESULT sg_reader_handle_irp_locked(struct irp *irp);
struct irp *irp);
static HRESULT sg_reader_mifare_poll(void *ctx, uint32_t *uid); static HRESULT sg_reader_mifare_poll(void *ctx, uint32_t *uid);
static HRESULT sg_reader_mifare_read_luid( static HRESULT sg_reader_mifare_read_luid(
void *ctx, void *ctx,
uint32_t uid, uint32_t uid,
uint8_t *luid, uint8_t *luid,
size_t luid_size); size_t luid_size);
static void sg_reader_led_set_color(void *ctx, uint8_t r, uint8_t g, uint8_t b); static void sg_reader_led_set_color(void *ctx, uint8_t r, uint8_t g, uint8_t b);
static const struct sg_nfc_ops sg_reader_nfc_ops = { static const struct sg_nfc_ops sg_reader_nfc_ops = {
@ -40,59 +36,55 @@ static const struct sg_led_ops sg_reader_led_ops = {
.set_color = sg_reader_led_set_color, .set_color = sg_reader_led_set_color,
}; };
HRESULT sg_reader_init( static CRITICAL_SECTION sg_reader_lock;
struct sg_reader *reader, static struct uart sg_reader_uart;
unsigned int port_no) static uint8_t sg_reader_written_bytes[520];
static uint8_t sg_reader_readable_bytes[520];
static struct sg_nfc sg_reader_nfc;
static struct sg_led sg_reader_led;
HRESULT sg_reader_hook_init(unsigned int port_no)
{ {
HRESULT hr; HRESULT hr;
assert(reader != NULL);
hr = aime_io_init(); hr = aime_io_init();
if (FAILED(hr)) { if (FAILED(hr)) {
return hr; return hr;
} }
sg_nfc_init(&reader->nfc, 0x00, &sg_reader_nfc_ops, reader); sg_nfc_init(&sg_reader_nfc, 0x00, &sg_reader_nfc_ops, NULL);
sg_led_init(&reader->led, 0x08, &sg_reader_led_ops, reader); sg_led_init(&sg_reader_led, 0x08, &sg_reader_led_ops, NULL);
InitializeCriticalSection(&reader->lock); InitializeCriticalSection(&sg_reader_lock);
uart_init(&reader->uart, port_no); uart_init(&sg_reader_uart, port_no);
reader->uart.written.bytes = reader->written_bytes; sg_reader_uart.written.bytes = sg_reader_written_bytes;
reader->uart.written.nbytes = sizeof(reader->written_bytes); sg_reader_uart.written.nbytes = sizeof(sg_reader_written_bytes);
reader->uart.readable.bytes = reader->readable_bytes; sg_reader_uart.readable.bytes = sg_reader_readable_bytes;
reader->uart.readable.nbytes = sizeof(reader->readable_bytes); sg_reader_uart.readable.nbytes = sizeof(sg_reader_readable_bytes);
return S_OK; return iohook_push_handler(sg_reader_handle_irp);
} }
bool sg_reader_match_irp(const struct sg_reader *reader, const struct irp *irp) static HRESULT sg_reader_handle_irp(struct irp *irp)
{
assert(reader != NULL);
assert(irp != NULL);
return uart_match_irp(&reader->uart, irp);
}
HRESULT sg_reader_handle_irp(struct sg_reader *reader, struct irp *irp)
{ {
HRESULT hr; HRESULT hr;
assert(reader != NULL);
assert(irp != NULL); assert(irp != NULL);
EnterCriticalSection(&reader->lock); if (!uart_match_irp(&sg_reader_uart, irp)) {
hr = sg_reader_handle_irp_locked(reader, irp); return iohook_invoke_next(irp);
LeaveCriticalSection(&reader->lock); }
EnterCriticalSection(&sg_reader_lock);
hr = sg_reader_handle_irp_locked(irp);
LeaveCriticalSection(&sg_reader_lock);
return hr; return hr;
} }
static HRESULT sg_reader_handle_irp_locked( static HRESULT sg_reader_handle_irp_locked(struct irp *irp)
struct sg_reader *reader,
struct irp *irp)
{ {
HRESULT hr; HRESULT hr;
@ -106,29 +98,29 @@ static HRESULT sg_reader_handle_irp_locked(
#if 0 #if 0
if (irp->op == IRP_OP_READ) { if (irp->op == IRP_OP_READ) {
dprintf("READ:\n"); dprintf("READ:\n");
dump_iobuf(&reader->uart.readable); dump_iobuf(&sg_reader_uart.readable);
} }
#endif #endif
hr = uart_handle_irp(&reader->uart, irp); hr = uart_handle_irp(&sg_reader_uart, irp);
if (FAILED(hr) || irp->op != IRP_OP_WRITE) { if (FAILED(hr) || irp->op != IRP_OP_WRITE) {
return hr; return hr;
} }
sg_nfc_transact( sg_nfc_transact(
&reader->nfc, &sg_reader_nfc,
&reader->uart.readable, &sg_reader_uart.readable,
reader->uart.written.bytes, sg_reader_uart.written.bytes,
reader->uart.written.pos); sg_reader_uart.written.pos);
sg_led_transact( sg_led_transact(
&reader->led, &sg_reader_led,
&reader->uart.readable, &sg_reader_uart.readable,
reader->uart.written.bytes, sg_reader_uart.written.bytes,
reader->uart.written.pos); sg_reader_uart.written.pos);
reader->uart.written.pos = 0; sg_reader_uart.written.pos = 0;
return hr; return hr;
} }

View File

@ -2,27 +2,4 @@
#include <windows.h> #include <windows.h>
#include <stdbool.h> HRESULT sg_reader_hook_init(unsigned int port_no);
#include <stdint.h>
#include "board/sg-led.h"
#include "board/sg-nfc.h"
#include "hooklib/uart.h"
struct sg_reader {
CRITICAL_SECTION lock;
struct uart uart;
uint8_t written_bytes[520];
uint8_t readable_bytes[520];
struct sg_nfc nfc;
struct sg_led led;
};
HRESULT sg_reader_init(
struct sg_reader *reader,
unsigned int port_no);
bool sg_reader_match_irp(const struct sg_reader *reader, const struct irp *irp);
HRESULT sg_reader_handle_irp(struct sg_reader *reader, struct irp *irp);

View File

@ -1,37 +0,0 @@
#include <windows.h>
#include <assert.h>
#include "board/sg-reader.h"
#include "cardhook/_com12.h"
#include "hook/iohook.h"
static HRESULT com12_handle_irp(struct irp *irp);
static struct sg_reader com12_reader;
HRESULT com12_hook_init(void)
{
HRESULT hr;
hr = sg_reader_init(&com12_reader, 12);
if (FAILED(hr)) {
return hr;
}
return iohook_push_handler(com12_handle_irp);
}
static HRESULT com12_handle_irp(struct irp *irp)
{
assert(irp != NULL);
if (!sg_reader_match_irp(&com12_reader, irp)) {
return iohook_invoke_next(irp);
}
return sg_reader_handle_irp(&com12_reader, irp);
}

View File

@ -1,5 +0,0 @@
#pragma once
#include <windows.h>
HRESULT com12_hook_init(void);

View File

@ -1,6 +1,6 @@
#include <windows.h> #include <windows.h>
#include "cardhook/_com12.h" #include "board/sg-reader.h"
#include "hook/process.h" #include "hook/process.h"
@ -15,9 +15,10 @@ static DWORD CALLBACK app_pre_startup(void)
{ {
dprintf("--- Begin %s ---\n", __func__); dprintf("--- Begin %s ---\n", __func__);
serial_hook_init();
spike_hook_init("cardspike.txt"); spike_hook_init("cardspike.txt");
com12_hook_init();
serial_hook_init();
sg_reader_hook_init(12);
dprintf("--- End %s ---\n", __func__); dprintf("--- End %s ---\n", __func__);

View File

@ -14,7 +14,6 @@ shared_library(
util_lib, util_lib,
], ],
sources : [ sources : [
'_com12.c',
'dllmain.c', 'dllmain.c',
], ],
) )

View File

@ -1,38 +0,0 @@
#include <windows.h>
#include <assert.h>
#include <stdint.h>
#include "board/sg-reader.h"
#include "divahook/_com10.h"
#include "hook/iohook.h"
static HRESULT com10_handle_irp(struct irp *irp);
static struct sg_reader com10_reader;
HRESULT com10_hook_init(void)
{
HRESULT hr;
hr = sg_reader_init(&com10_reader, 10);
if (FAILED(hr)) {
return hr;
}
return iohook_push_handler(com10_handle_irp);
}
static HRESULT com10_handle_irp(struct irp *irp)
{
assert(irp != NULL);
if (!sg_reader_match_irp(&com10_reader, irp)) {
return iohook_invoke_next(irp);
}
return sg_reader_handle_irp(&com10_reader, irp);
}

View File

@ -1,5 +0,0 @@
#pragma once
#include <windows.h>
HRESULT com10_hook_init(void);

View File

@ -9,7 +9,8 @@
#include "amex/jvs.h" #include "amex/jvs.h"
#include "amex/sram.h" #include "amex/sram.h"
#include "divahook/_com10.h" #include "board/sg-reader.h"
#include "divahook/jvs.h" #include "divahook/jvs.h"
#include "divahook/slider.h" #include "divahook/slider.h"
@ -51,8 +52,8 @@ static DWORD CALLBACK diva_pre_startup(void)
/* Initialize Project Diva I/O board emulation */ /* Initialize Project Diva I/O board emulation */
com10_hook_init();
diva_jvs_init(); diva_jvs_init();
sg_reader_hook_init(10);
slider_hook_init(); slider_hook_init();
/* Initialize debug helpers */ /* Initialize debug helpers */

View File

@ -19,7 +19,6 @@ shared_library(
util_lib, util_lib,
], ],
sources : [ sources : [
'_com10.c',
'dllmain.c', 'dllmain.c',
'jvs.c', 'jvs.c',
'jvs.h', 'jvs.h',

View File

@ -1,38 +0,0 @@
#include <windows.h>
#include <assert.h>
#include <stdint.h>
#include "board/sg-reader.h"
#include "hook/iohook.h"
#include "idzhook/_com10.h"
static HRESULT com10_handle_irp(struct irp *irp);
static struct sg_reader com10_reader;
HRESULT com10_hook_init(void)
{
HRESULT hr;
hr = sg_reader_init(&com10_reader, 10);
if (FAILED(hr)) {
return hr;
}
return iohook_push_handler(com10_handle_irp);
}
static HRESULT com10_handle_irp(struct irp *irp)
{
assert(irp != NULL);
if (!sg_reader_match_irp(&com10_reader, irp)) {
return iohook_invoke_next(irp);
}
return sg_reader_handle_irp(&com10_reader, irp);
}

View File

@ -1,5 +0,0 @@
#pragma once
#include <windows.h>
HRESULT com10_hook_init(void);

View File

@ -9,11 +9,12 @@
#include "amex/jvs.h" #include "amex/jvs.h"
#include "amex/sram.h" #include "amex/sram.h"
#include "board/sg-reader.h"
#include "hook/process.h" #include "hook/process.h"
#include "hooklib/serial.h" #include "hooklib/serial.h"
#include "idzhook/_com10.h"
#include "idzhook/jvs.h" #include "idzhook/jvs.h"
#include "platform/hwmon.h" #include "platform/hwmon.h"
@ -50,8 +51,8 @@ static DWORD CALLBACK idz_pre_startup(void)
/* Initialize Initial D Zero I/O board emulation */ /* Initialize Initial D Zero I/O board emulation */
com10_hook_init();
idz_jvs_init(); idz_jvs_init();
sg_reader_hook_init(10);
/* Initialize debug helpers */ /* Initialize debug helpers */

View File

@ -19,7 +19,6 @@ shared_library(
util_lib, util_lib,
], ],
sources : [ sources : [
'_com10.c',
'dllmain.c', 'dllmain.c',
'jvs.c', 'jvs.c',
'jvs.h', 'jvs.h',