forked from TeamTofuShop/segatools
		
	added VFD toggle to config
This commit is contained in:
		| @ -8,6 +8,7 @@ | |||||||
| #include "board/aime-dll.h" | #include "board/aime-dll.h" | ||||||
| #include "board/config.h" | #include "board/config.h" | ||||||
| #include "board/sg-reader.h" | #include "board/sg-reader.h" | ||||||
|  | #include "board/vfd.h" | ||||||
|  |  | ||||||
| #include "util/dprintf.h" | #include "util/dprintf.h" | ||||||
|  |  | ||||||
| @ -82,3 +83,11 @@ void io4_config_load(struct io4_config *cfg, const wchar_t *filename) | |||||||
|  |  | ||||||
|     cfg->enable = GetPrivateProfileIntW(L"io4", L"enable", 1, filename); |     cfg->enable = GetPrivateProfileIntW(L"io4", L"enable", 1, filename); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void vfd_config_load(struct vfd_config *cfg, const wchar_t *filename) | ||||||
|  | { | ||||||
|  |     assert(cfg != NULL); | ||||||
|  |     assert(filename != NULL); | ||||||
|  |  | ||||||
|  |     cfg->enable = GetPrivateProfileIntW(L"vfd", L"enable", 1, filename); | ||||||
|  | } | ||||||
|  | |||||||
| @ -5,6 +5,8 @@ | |||||||
|  |  | ||||||
| #include "board/io4.h" | #include "board/io4.h" | ||||||
| #include "board/sg-reader.h" | #include "board/sg-reader.h" | ||||||
|  | #include "board/vfd.h" | ||||||
|  |  | ||||||
| void aime_config_load(struct aime_config *cfg, const wchar_t *filename); | void aime_config_load(struct aime_config *cfg, const wchar_t *filename); | ||||||
| void io4_config_load(struct io4_config *cfg, const wchar_t *filename); | void io4_config_load(struct io4_config *cfg, const wchar_t *filename); | ||||||
|  | void vfd_config_load(struct vfd_config *cfg, const wchar_t *filename); | ||||||
|  | |||||||
							
								
								
									
										10
									
								
								board/vfd.c
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								board/vfd.c
									
									
									
									
									
								
							| @ -27,14 +27,22 @@ static struct uart vfd_uart; | |||||||
| static uint8_t vfd_written[512]; | static uint8_t vfd_written[512]; | ||||||
| static uint8_t vfd_readable[512]; | static uint8_t vfd_readable[512]; | ||||||
|  |  | ||||||
| HRESULT vfd_hook_init(unsigned int port_no) | HRESULT vfd_hook_init(const struct vfd_config *cfg, unsigned int port_no) | ||||||
| { | { | ||||||
|  |     assert(cfg != NULL); | ||||||
|  |  | ||||||
|  |     if (!cfg->enable) { | ||||||
|  |         return S_FALSE; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     uart_init(&vfd_uart, port_no); |     uart_init(&vfd_uart, port_no); | ||||||
|     vfd_uart.written.bytes = vfd_written; |     vfd_uart.written.bytes = vfd_written; | ||||||
|     vfd_uart.written.nbytes = sizeof(vfd_written); |     vfd_uart.written.nbytes = sizeof(vfd_written); | ||||||
|     vfd_uart.readable.bytes = vfd_readable; |     vfd_uart.readable.bytes = vfd_readable; | ||||||
|     vfd_uart.readable.nbytes = sizeof(vfd_readable); |     vfd_uart.readable.nbytes = sizeof(vfd_readable); | ||||||
|  |  | ||||||
|  |     dprintf("VFD: hook enabled.\n"); | ||||||
|  |  | ||||||
|     return iohook_push_handler(vfd_handle_irp); |     return iohook_push_handler(vfd_handle_irp); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | |||||||
| @ -2,4 +2,9 @@ | |||||||
|  |  | ||||||
| #include <windows.h> | #include <windows.h> | ||||||
|  |  | ||||||
| HRESULT vfd_hook_init(unsigned int port_no); | struct vfd_config { | ||||||
|  |     bool enable; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | HRESULT vfd_hook_init(const struct vfd_config *cfg, unsigned int port_no); | ||||||
|  | |||||||
| @ -160,6 +160,7 @@ void chusan_hook_config_load( | |||||||
|     dvd_config_load(&cfg->dvd, filename); |     dvd_config_load(&cfg->dvd, filename); | ||||||
|     io4_config_load(&cfg->io4, filename); |     io4_config_load(&cfg->io4, filename); | ||||||
|     gfx_config_load(&cfg->gfx, filename); |     gfx_config_load(&cfg->gfx, filename); | ||||||
|  |     vfd_config_load(&cfg->vfd, filename); | ||||||
|     chuni_dll_config_load(&cfg->dll, filename); |     chuni_dll_config_load(&cfg->dll, filename); | ||||||
|     slider_config_load(&cfg->slider, filename); |     slider_config_load(&cfg->slider, filename); | ||||||
|     led15093_config_load(&cfg->led15093, filename); |     led15093_config_load(&cfg->led15093, filename); | ||||||
|  | |||||||
| @ -20,6 +20,7 @@ struct chusan_hook_config { | |||||||
|     struct dvd_config dvd; |     struct dvd_config dvd; | ||||||
|     struct io4_config io4; |     struct io4_config io4; | ||||||
|     struct gfx_config gfx; |     struct gfx_config gfx; | ||||||
|  |     struct vfd_config vfd; | ||||||
|     struct chuni_dll_config dll; |     struct chuni_dll_config dll; | ||||||
|     struct slider_config slider; |     struct slider_config slider; | ||||||
|     struct led15093_config led15093; |     struct led15093_config led15093; | ||||||
|  | |||||||
| @ -122,7 +122,7 @@ static DWORD CALLBACK chusan_pre_startup(void) | |||||||
|     unsigned int first_port = is_cvt ? 2 : 20; |     unsigned int first_port = is_cvt ? 2 : 20; | ||||||
|  |  | ||||||
|     if (!is_cvt) { |     if (!is_cvt) { | ||||||
|         hr = vfd_hook_init(2); |         hr = vfd_hook_init(&chusan_hook_cfg.vfd, 2); | ||||||
|  |  | ||||||
|         if (FAILED(hr)) { |         if (FAILED(hr)) { | ||||||
|             goto fail; |             goto fail; | ||||||
|  | |||||||
| @ -37,6 +37,7 @@ void cm_hook_config_load( | |||||||
|     aime_config_load(&cfg->aime, filename); |     aime_config_load(&cfg->aime, filename); | ||||||
|     dvd_config_load(&cfg->dvd, filename); |     dvd_config_load(&cfg->dvd, filename); | ||||||
|     io4_config_load(&cfg->io4, filename); |     io4_config_load(&cfg->io4, filename); | ||||||
|  |     vfd_config_load(&cfg->vfd, filename); | ||||||
|     touch_screen_config_load(&cfg->touch, filename); |     touch_screen_config_load(&cfg->touch, filename); | ||||||
|     cm_dll_config_load(&cfg->dll, filename); |     cm_dll_config_load(&cfg->dll, filename); | ||||||
| } | } | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ struct cm_hook_config { | |||||||
|     struct aime_config aime; |     struct aime_config aime; | ||||||
|     struct dvd_config dvd; |     struct dvd_config dvd; | ||||||
|     struct io4_config io4; |     struct io4_config io4; | ||||||
|  |     struct vfd_config vfd; | ||||||
|     struct cm_dll_config dll; |     struct cm_dll_config dll; | ||||||
|     struct touch_screen_config touch; |     struct touch_screen_config touch; | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -60,7 +60,7 @@ static DWORD CALLBACK cm_pre_startup(void) | |||||||
|         goto fail; |         goto fail; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     hr = vfd_hook_init(2); |     hr = vfd_hook_init(&cm_hook_cfg.vfd, 2); | ||||||
|  |  | ||||||
|     if (FAILED(hr)) { |     if (FAILED(hr)) { | ||||||
|         goto fail; |         goto fail; | ||||||
|  | |||||||
							
								
								
									
										8
									
								
								dist/chusan/segatools.ini
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								dist/chusan/segatools.ini
									
									
									
									
										vendored
									
									
								
							| @ -9,12 +9,18 @@ option= | |||||||
| appdata= | appdata= | ||||||
|  |  | ||||||
| [aime] | [aime] | ||||||
| ; Enable aime reader emulation. | ; Enable Aime card reader assembly emulation. Disable to use a real SEGA Aime | ||||||
|  | ; reader. | ||||||
| enable=1 | enable=1 | ||||||
| aimePath=DEVICE\aime.txt | aimePath=DEVICE\aime.txt | ||||||
| ; Enable high baud rate. | ; Enable high baud rate. | ||||||
| ;highBaud=1 | ;highBaud=1 | ||||||
|  |  | ||||||
|  | [vfd] | ||||||
|  | ; Enable VFD emulation (currently just stubbed). Disable to use a real VFD | ||||||
|  | ; GP1232A02A FUTABA assembly. | ||||||
|  | enable=1 | ||||||
|  |  | ||||||
| [aimeio] | [aimeio] | ||||||
| ; Uncomment this if you have custom (x64) aime implementation. | ; Uncomment this if you have custom (x64) aime implementation. | ||||||
| ; Leave empty if you want to use Segatools built-in keyboard input. | ; Leave empty if you want to use Segatools built-in keyboard input. | ||||||
|  | |||||||
							
								
								
									
										8
									
								
								dist/cm/segatools.ini
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								dist/cm/segatools.ini
									
									
									
									
										vendored
									
									
								
							| @ -9,10 +9,16 @@ option= | |||||||
| appdata= | appdata= | ||||||
|  |  | ||||||
| [aime] | [aime] | ||||||
| ; Enable aime reader emulation. | ; Enable Aime card reader assembly emulation. Disable to use a real SEGA Aime | ||||||
|  | ; reader. | ||||||
| enable=1 | enable=1 | ||||||
| aimePath=DEVICE\aime.txt | aimePath=DEVICE\aime.txt | ||||||
|  |  | ||||||
|  | [vfd] | ||||||
|  | ; Enable VFD emulation (currently just stubbed). Disable to use a real VFD | ||||||
|  | ; GP1232A02A FUTABA assembly. | ||||||
|  | enable=1 | ||||||
|  |  | ||||||
| [dns] | [dns] | ||||||
| ; Insert the hostname or IP address of the server you wish to use here. | ; Insert the hostname or IP address of the server you wish to use here. | ||||||
| ; Note that 127.0.0.1, localhost etc are specifically rejected. | ; Note that 127.0.0.1, localhost etc are specifically rejected. | ||||||
|  | |||||||
							
								
								
									
										8
									
								
								dist/fgo/segatools.ini
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								dist/fgo/segatools.ini
									
									
									
									
										vendored
									
									
								
							| @ -9,10 +9,16 @@ option= | |||||||
| appdata= | appdata= | ||||||
|  |  | ||||||
| [aime] | [aime] | ||||||
| ; Controls emulation of the Aime card reader assembly. | ; Enable Aime card reader assembly emulation. Disable to use a real SEGA Aime | ||||||
|  | ; reader. | ||||||
| enable=1 | enable=1 | ||||||
| aimePath=DEVICE\aime.txt | aimePath=DEVICE\aime.txt | ||||||
|  |  | ||||||
|  | [vfd] | ||||||
|  | ; Enable VFD emulation (currently just stubbed). Disable to use a real VFD | ||||||
|  | ; GP1232A02A FUTABA assembly. | ||||||
|  | enable=1 | ||||||
|  |  | ||||||
| [dns] | [dns] | ||||||
| ; Insert the hostname or IP address of the server you wish to use here. | ; Insert the hostname or IP address of the server you wish to use here. | ||||||
| ; Note that 127.0.0.1, localhost etc are specifically rejected. | ; Note that 127.0.0.1, localhost etc are specifically rejected. | ||||||
|  | |||||||
							
								
								
									
										8
									
								
								dist/mai2/segatools.ini
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								dist/mai2/segatools.ini
									
									
									
									
										vendored
									
									
								
							| @ -9,10 +9,16 @@ option= | |||||||
| appdata= | appdata= | ||||||
|  |  | ||||||
| [aime] | [aime] | ||||||
| ; Enable aime reader emulation. | ; Enable Aime card reader assembly emulation. Disable to use a real SEGA Aime | ||||||
|  | ; reader. | ||||||
| enable=1 | enable=1 | ||||||
| aimePath=DEVICE\aime.txt | aimePath=DEVICE\aime.txt | ||||||
|  |  | ||||||
|  | [vfd] | ||||||
|  | ; Enable VFD emulation (currently just stubbed). Disable to use a real VFD | ||||||
|  | ; GP1232A02A FUTABA assembly. | ||||||
|  | enable=1 | ||||||
|  |  | ||||||
| [dns] | [dns] | ||||||
| ; Insert the hostname or IP address of the server you wish to use here. | ; Insert the hostname or IP address of the server you wish to use here. | ||||||
| ; Note that 127.0.0.1, localhost etc are specifically rejected. | ; Note that 127.0.0.1, localhost etc are specifically rejected. | ||||||
|  | |||||||
							
								
								
									
										11
									
								
								dist/mercury/segatools.ini
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								dist/mercury/segatools.ini
									
									
									
									
										vendored
									
									
								
							| @ -7,6 +7,17 @@ amfs=amfs | |||||||
| appdata=appdata | appdata=appdata | ||||||
| option=option | option=option | ||||||
|  |  | ||||||
|  | [aime] | ||||||
|  | ; Enable Aime card reader assembly emulation. Disable to use a real SEGA Aime | ||||||
|  | ; reader. | ||||||
|  | enable=1 | ||||||
|  | aimePath=DEVICE\aime.txt | ||||||
|  |  | ||||||
|  | [vfd] | ||||||
|  | ; Enable VFD emulation (currently just stubbed). Disable to use a real VFD | ||||||
|  | ; GP1232A02A FUTABA assembly. | ||||||
|  | enable=1 | ||||||
|  |  | ||||||
| [dns] | [dns] | ||||||
| ; Insert the hostname or IP address of the server you wish to use here. | ; Insert the hostname or IP address of the server you wish to use here. | ||||||
| ; Note that 127.0.0.1, localhost etc are specifically rejected. | ; Note that 127.0.0.1, localhost etc are specifically rejected. | ||||||
|  | |||||||
							
								
								
									
										8
									
								
								dist/mu3/segatools.ini
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								dist/mu3/segatools.ini
									
									
									
									
										vendored
									
									
								
							| @ -9,10 +9,16 @@ option= | |||||||
| appdata= | appdata= | ||||||
|  |  | ||||||
| [aime] | [aime] | ||||||
| ; Controls emulation of the Aime card reader assembly. | ; Enable Aime card reader assembly emulation. Disable to use a real SEGA Aime | ||||||
|  | ; reader. | ||||||
| enable=1 | enable=1 | ||||||
| aimePath=DEVICE\aime.txt | aimePath=DEVICE\aime.txt | ||||||
|  |  | ||||||
|  | [vfd] | ||||||
|  | ; Enable VFD emulation (currently just stubbed). Disable to use a real VFD | ||||||
|  | ; GP1232A02A FUTABA assembly. | ||||||
|  | enable=1 | ||||||
|  |  | ||||||
| [dns] | [dns] | ||||||
| ; Insert the hostname or IP address of the server you wish to use here. | ; Insert the hostname or IP address of the server you wish to use here. | ||||||
| ; Note that 127.0.0.1, localhost etc are specifically rejected. | ; Note that 127.0.0.1, localhost etc are specifically rejected. | ||||||
|  | |||||||
							
								
								
									
										8
									
								
								dist/swdc/segatools.ini
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								dist/swdc/segatools.ini
									
									
									
									
										vendored
									
									
								
							| @ -9,10 +9,16 @@ option= | |||||||
| appdata=appdata | appdata=appdata | ||||||
|  |  | ||||||
| [aime] | [aime] | ||||||
| ; Controls emulation of the Aime card reader assembly. | ; Enable Aime card reader assembly emulation. Disable to use a real SEGA Aime | ||||||
|  | ; reader. | ||||||
| enable=1 | enable=1 | ||||||
| aimePath=DEVICE\aime.txt | aimePath=DEVICE\aime.txt | ||||||
|  |  | ||||||
|  | [vfd] | ||||||
|  | ; Enable VFD emulation (currently just stubbed). Disable to use a real VFD | ||||||
|  | ; GP1232A02A FUTABA assembly. | ||||||
|  | enable=1 | ||||||
|  |  | ||||||
| [dns] | [dns] | ||||||
| ; Insert the hostname or IP address of the server you wish to use here. | ; Insert the hostname or IP address of the server you wish to use here. | ||||||
| ; Note that 127.0.0.1, localhost etc are specifically rejected. | ; Note that 127.0.0.1, localhost etc are specifically rejected. | ||||||
|  | |||||||
| @ -84,6 +84,17 @@ emulates an IC card in its proximity. A variety of different IC cards can be | |||||||
| emulated; the exact choice of card that is emulated depends on the presence or | emulated; the exact choice of card that is emulated depends on the presence or | ||||||
| absence of the configured card ID files. | absence of the configured card ID files. | ||||||
|  |  | ||||||
|  | ## `[vfd]` | ||||||
|  |  | ||||||
|  | Controls emulation of the VFD GP1232A02A FUTABA assembly. | ||||||
|  |  | ||||||
|  | ### `enable` | ||||||
|  |  | ||||||
|  | Default: `1` | ||||||
|  |  | ||||||
|  | Enable VFD emulation (currently just stubbed). Disable to use a real VFD | ||||||
|  | GP1232A02A FUTABA assembly (COM port number varies by game). | ||||||
|  |  | ||||||
| ## `[amvideo]` | ## `[amvideo]` | ||||||
|  |  | ||||||
| Controls the `amvideo.dll` stub built into Segatools. This is a DLL that is | Controls the `amvideo.dll` stub built into Segatools. This is a DLL that is | ||||||
|  | |||||||
| @ -116,6 +116,7 @@ void fgo_hook_config_load( | |||||||
|     aime_config_load(&cfg->aime, filename); |     aime_config_load(&cfg->aime, filename); | ||||||
|     dvd_config_load(&cfg->dvd, filename); |     dvd_config_load(&cfg->dvd, filename); | ||||||
|     io4_config_load(&cfg->io4, filename); |     io4_config_load(&cfg->io4, filename); | ||||||
|  |     vfd_config_load(&cfg->vfd, filename); | ||||||
|     touch_screen_config_load(&cfg->touch, filename); |     touch_screen_config_load(&cfg->touch, filename); | ||||||
|     printer_config_load(&cfg->printer, filename); |     printer_config_load(&cfg->printer, filename); | ||||||
|     fgo_deck_config_load(&cfg->deck, filename); |     fgo_deck_config_load(&cfg->deck, filename); | ||||||
|  | |||||||
| @ -20,6 +20,7 @@ struct fgo_hook_config { | |||||||
|     struct aime_config aime; |     struct aime_config aime; | ||||||
|     struct dvd_config dvd; |     struct dvd_config dvd; | ||||||
|     struct io4_config io4; |     struct io4_config io4; | ||||||
|  |     struct vfd_config vfd; | ||||||
|     struct touch_screen_config touch; |     struct touch_screen_config touch; | ||||||
|     struct printer_config printer; |     struct printer_config printer; | ||||||
|     struct deck_config deck; |     struct deck_config deck; | ||||||
|  | |||||||
| @ -67,7 +67,7 @@ static DWORD CALLBACK fgo_pre_startup(void) | |||||||
|         goto fail; |         goto fail; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     hr = vfd_hook_init(1); |     hr = vfd_hook_init(&fgo_hook_cfg.vfd, 1); | ||||||
|  |  | ||||||
|     if (FAILED(hr)) { |     if (FAILED(hr)) { | ||||||
|         goto fail; |         goto fail; | ||||||
|  | |||||||
| @ -37,5 +37,6 @@ void mai2_hook_config_load( | |||||||
|     aime_config_load(&cfg->aime, filename); |     aime_config_load(&cfg->aime, filename); | ||||||
|     dvd_config_load(&cfg->dvd, filename); |     dvd_config_load(&cfg->dvd, filename); | ||||||
|     io4_config_load(&cfg->io4, filename); |     io4_config_load(&cfg->io4, filename); | ||||||
|  |     vfd_config_load(&cfg->vfd, filename); | ||||||
|     mai2_dll_config_load(&cfg->dll, filename); |     mai2_dll_config_load(&cfg->dll, filename); | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,6 +15,7 @@ struct mai2_hook_config { | |||||||
|     struct aime_config aime; |     struct aime_config aime; | ||||||
|     struct dvd_config dvd; |     struct dvd_config dvd; | ||||||
|     struct io4_config io4; |     struct io4_config io4; | ||||||
|  |     struct vfd_config vfd; | ||||||
|     struct mai2_dll_config dll; |     struct mai2_dll_config dll; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | |||||||
| @ -57,7 +57,7 @@ static DWORD CALLBACK mai2_pre_startup(void) | |||||||
|         goto fail; |         goto fail; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     hr = vfd_hook_init(2); |     hr = vfd_hook_init(&mai2_hook_cfg.vfd, 2); | ||||||
|  |  | ||||||
|     if (FAILED(hr)) { |     if (FAILED(hr)) { | ||||||
|         goto fail; |         goto fail; | ||||||
|  | |||||||
| @ -68,6 +68,7 @@ void mercury_hook_config_load( | |||||||
|     dvd_config_load(&cfg->dvd, filename); |     dvd_config_load(&cfg->dvd, filename); | ||||||
|     io4_config_load(&cfg->io4, filename); |     io4_config_load(&cfg->io4, filename); | ||||||
|     gfx_config_load(&cfg->gfx, filename); |     gfx_config_load(&cfg->gfx, filename); | ||||||
|  |     vfd_config_load(&cfg->vfd, filename); | ||||||
|     mercury_dll_config_load(&cfg->dll, filename); |     mercury_dll_config_load(&cfg->dll, filename); | ||||||
|     touch_config_load(&cfg->touch, filename); |     touch_config_load(&cfg->touch, filename); | ||||||
|     elisabeth_config_load(&cfg->elisabeth, filename); |     elisabeth_config_load(&cfg->elisabeth, filename); | ||||||
|  | |||||||
| @ -19,6 +19,7 @@ struct mercury_hook_config { | |||||||
|     struct dvd_config dvd; |     struct dvd_config dvd; | ||||||
|     struct io4_config io4; |     struct io4_config io4; | ||||||
|     struct gfx_config gfx; |     struct gfx_config gfx; | ||||||
|  |     struct vfd_config vfd; | ||||||
|     struct mercury_dll_config dll; |     struct mercury_dll_config dll; | ||||||
|     struct touch_config touch; |     struct touch_config touch; | ||||||
|     struct elisabeth_config elisabeth; |     struct elisabeth_config elisabeth; | ||||||
|  | |||||||
| @ -64,7 +64,7 @@ static DWORD CALLBACK mercury_pre_startup(void) | |||||||
|         goto fail; |         goto fail; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     hr = vfd_hook_init(2); |     hr = vfd_hook_init(&mercury_hook_cfg.vfd, 2); | ||||||
|  |  | ||||||
|     if (FAILED(hr)) { |     if (FAILED(hr)) { | ||||||
|         goto fail; |         goto fail; | ||||||
|  | |||||||
| @ -40,5 +40,6 @@ void mu3_hook_config_load( | |||||||
|     dvd_config_load(&cfg->dvd, filename); |     dvd_config_load(&cfg->dvd, filename); | ||||||
|     io4_config_load(&cfg->io4, filename); |     io4_config_load(&cfg->io4, filename); | ||||||
|     gfx_config_load(&cfg->gfx, filename); |     gfx_config_load(&cfg->gfx, filename); | ||||||
|  |     vfd_config_load(&cfg->vfd, filename); | ||||||
|     mu3_dll_config_load(&cfg->dll, filename); |     mu3_dll_config_load(&cfg->dll, filename); | ||||||
| } | } | ||||||
|  | |||||||
| @ -20,6 +20,7 @@ struct mu3_hook_config { | |||||||
|     struct io4_config io4; |     struct io4_config io4; | ||||||
|     struct gfx_config gfx; |     struct gfx_config gfx; | ||||||
|     // struct led15093_config led15093; |     // struct led15093_config led15093; | ||||||
|  |     struct vfd_config vfd; | ||||||
|     struct mu3_dll_config dll; |     struct mu3_dll_config dll; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | |||||||
| @ -76,7 +76,7 @@ static DWORD CALLBACK mu3_pre_startup(void) | |||||||
|         goto fail; |         goto fail; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     hr = vfd_hook_init(2); |     hr = vfd_hook_init(&mu3_hook_cfg.vfd, 2); | ||||||
|  |  | ||||||
|     if (FAILED(hr)) { |     if (FAILED(hr)) { | ||||||
|         goto fail; |         goto fail; | ||||||
|  | |||||||
| @ -42,6 +42,7 @@ void swdc_hook_config_load( | |||||||
|     zinput_config_load(&cfg->zinput, filename); |     zinput_config_load(&cfg->zinput, filename); | ||||||
|     dvd_config_load(&cfg->dvd, filename); |     dvd_config_load(&cfg->dvd, filename); | ||||||
|     io4_config_load(&cfg->io4, filename); |     io4_config_load(&cfg->io4, filename); | ||||||
|  |     vfd_config_load(&cfg->vfd, filename); | ||||||
| } | } | ||||||
|  |  | ||||||
| void zinput_config_load(struct zinput_config *cfg, const wchar_t *filename) | void zinput_config_load(struct zinput_config *cfg, const wchar_t *filename) | ||||||
|  | |||||||
| @ -17,6 +17,7 @@ struct swdc_hook_config { | |||||||
|     struct aime_config aime; |     struct aime_config aime; | ||||||
|     struct dvd_config dvd; |     struct dvd_config dvd; | ||||||
|     struct io4_config io4; |     struct io4_config io4; | ||||||
|  |     struct vfd_config vfd; | ||||||
|     struct swdc_dll_config dll; |     struct swdc_dll_config dll; | ||||||
|     struct zinput_config zinput; |     struct zinput_config zinput; | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -64,7 +64,7 @@ static DWORD CALLBACK swdc_pre_startup(void) | |||||||
|         goto fail; |         goto fail; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     hr = vfd_hook_init(4); |     hr = vfd_hook_init(&swdc_hook_cfg.vfd, 4); | ||||||
|  |  | ||||||
|     if (FAILED(hr)) { |     if (FAILED(hr)) { | ||||||
|         return hr; |         return hr; | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user