|
|
| version 1.3, 2003/10/21 11:22:05 | version 1.4, 2003/12/08 00:55:30 |
|---|---|
| Line 8 | Line 8 |
| #include "s98.h" | #include "s98.h" |
| static void IOOUTCALL spb_o188(UINT port, BYTE dat) { | static void IOOUTCALL spb_o188(UINT port, REG8 dat) { |
| opn.opnreg = dat; | opn.opnreg = dat; |
| (void)port; | (void)port; |
| } | } |
| static void IOOUTCALL spb_o18a(UINT port, BYTE dat) { | static void IOOUTCALL spb_o18a(UINT port, REG8 dat) { |
| S98_put(NORMAL2608, opn.opnreg, dat); | S98_put(NORMAL2608, opn.opnreg, dat); |
| if (opn.opnreg < 0x10) { | if (opn.opnreg < 0x10) { |
| Line 51 static void IOOUTCALL spb_o18a(UINT port | Line 51 static void IOOUTCALL spb_o18a(UINT port |
| (void)port; | (void)port; |
| } | } |
| static void IOOUTCALL spb_o18c(UINT port, BYTE dat) { | static void IOOUTCALL spb_o18c(UINT port, REG8 dat) { |
| opn.extreg = dat; | opn.extreg = dat; |
| (void)port; | (void)port; |
| } | } |
| static void IOOUTCALL spb_o18e(UINT port, BYTE dat) { | static void IOOUTCALL spb_o18e(UINT port, REG8 dat) { |
| S98_put(EXTEND2608, opn.extreg, dat); | S98_put(EXTEND2608, opn.extreg, dat); |
| opn.reg[opn.extreg + 0x100] = dat; | opn.reg[opn.extreg + 0x100] = dat; |
| Line 71 static void IOOUTCALL spb_o18e(UINT port | Line 71 static void IOOUTCALL spb_o18e(UINT port |
| (void)port; | (void)port; |
| } | } |
| static BYTE IOINPCALL spb_i188(UINT port) { | static REG8 IOINPCALL spb_i188(UINT port) { |
| (void)port; | (void)port; |
| return((fmtimer.status & 3) | adpcm_status(&adpcm)); | return((fmtimer.status & 3) | adpcm_status(&adpcm)); |
| } | } |
| static BYTE IOINPCALL spb_i18a(UINT port) { | static REG8 IOINPCALL spb_i18a(UINT port) { |
| if (opn.opnreg == 0x0e) { | if (opn.opnreg == 0x0e) { |
| return(fmboard_getjoy(&psg1)); | return(fmboard_getjoy(&psg1)); |
| Line 89 static BYTE IOINPCALL spb_i18a(UINT port | Line 89 static BYTE IOINPCALL spb_i18a(UINT port |
| return(opn.reg[opn.opnreg]); | return(opn.reg[opn.opnreg]); |
| } | } |
| static BYTE IOINPCALL spb_i18e(UINT port) { | static REG8 IOINPCALL spb_i18e(UINT port) { |
| if (opn.extreg == 0x08) { | if (opn.extreg == 0x08) { |
| return(adpcm_readsample(&adpcm)); | return(adpcm_readsample(&adpcm)); |
| Line 101 static BYTE IOINPCALL spb_i18e(UINT port | Line 101 static BYTE IOINPCALL spb_i18e(UINT port |
| // ---- spark board | // ---- spark board |
| static void IOOUTCALL spr_o588(UINT port, BYTE dat) { | static void IOOUTCALL spr_o588(UINT port, REG8 dat) { |
| opn.opn2reg = dat; | opn.opn2reg = dat; |
| (void)port; | (void)port; |
| } | } |
| static void IOOUTCALL spr_o58a(UINT port, BYTE dat) { | static void IOOUTCALL spr_o58a(UINT port, REG8 dat) { |
| if (opn.opn2reg < 0x30) { | if (opn.opn2reg < 0x30) { |
| if (opn.opn2reg == 0x28) { | if (opn.opn2reg == 0x28) { |
| Line 132 static void IOOUTCALL spr_o58a(UINT port | Line 132 static void IOOUTCALL spr_o58a(UINT port |
| (void)port; | (void)port; |
| } | } |
| static void IOOUTCALL spr_o58c(UINT port, BYTE dat) { | static void IOOUTCALL spr_o58c(UINT port, REG8 dat) { |
| opn.ext2reg = dat; | opn.ext2reg = dat; |
| (void)port; | (void)port; |
| } | } |
| static void IOOUTCALL spr_o58e(UINT port, BYTE dat) { | static void IOOUTCALL spr_o58e(UINT port, REG8 dat) { |
| opn.reg[opn.ext2reg + 0x300] = dat; | opn.reg[opn.ext2reg + 0x300] = dat; |
| if (opn.ext2reg >= 0x30) { | if (opn.ext2reg >= 0x30) { |
| Line 148 static void IOOUTCALL spr_o58e(UINT port | Line 148 static void IOOUTCALL spr_o58e(UINT port |
| (void)port; | (void)port; |
| } | } |
| static BYTE IOINPCALL spr_i588(UINT port) { | static REG8 IOINPCALL spr_i588(UINT port) { |
| (void)port; | (void)port; |
| return(fmtimer.status); | return(fmtimer.status); |
| } | } |
| static BYTE IOINPCALL spr_i58a(UINT port) { | static REG8 IOINPCALL spr_i58a(UINT port) { |
| if (opn.opn2reg >= 0x20) { | if (opn.opn2reg >= 0x20) { |
| return(opn.reg[opn.opn2reg + 0x200]); | return(opn.reg[opn.opn2reg + 0x200]); |
| Line 163 static BYTE IOINPCALL spr_i58a(UINT port | Line 163 static BYTE IOINPCALL spr_i58a(UINT port |
| return(0xff); | return(0xff); |
| } | } |
| static BYTE IOINPCALL spr_i58c(UINT port) { | static REG8 IOINPCALL spr_i58c(UINT port) { |
| (void)port; | (void)port; |
| return(fmtimer.status & 3); | return(fmtimer.status & 3); |
| } | } |
| static BYTE IOINPCALL spr_i58e(UINT port) { | static REG8 IOINPCALL spr_i58e(UINT port) { |
| (void)port; | (void)port; |
| return(opn.reg[opn.opn2reg + 0x200]); | return(opn.reg[opn.opn2reg + 0x200]); |
| Line 187 static const IOINP spb_i[4] = { | Line 187 static const IOINP spb_i[4] = { |
| void boardspb_reset(void) { | void boardspb_reset(void) { |
| fmtimer_reset((BYTE)(np2cfg.spbopt & 0xc0)); | fmtimer_reset(np2cfg.spbopt & 0xc0); |
| opn.channels = 6; | opn.channels = 6; |
| opngen_setcfg(6, OPN_STEREO | 0x03f); | opngen_setcfg(6, OPN_STEREO | 0x03f); |
| soundrom_loadex((BYTE)(np2cfg.spbopt & 7), "SPB"); | soundrom_loadex(np2cfg.spbopt & 7, "SPB"); |
| opn.base = ((np2cfg.spbopt & 0x10)?0x000:0x100); | opn.base = ((np2cfg.spbopt & 0x10)?0x000:0x100); |
| } | } |
| Line 215 static const IOINP spr_i[4] = { | Line 215 static const IOINP spr_i[4] = { |
| void boardspr_reset(void) { | void boardspr_reset(void) { |
| fmtimer_reset((BYTE)(np2cfg.spbopt & 0xc0)); | fmtimer_reset(np2cfg.spbopt & 0xc0); |
| opn.reg[0x2ff] = 0; | opn.reg[0x2ff] = 0; |
| opn.channels = 12; | opn.channels = 12; |
| opngen_setcfg(12, OPN_STEREO | 0x03f); | opngen_setcfg(12, OPN_STEREO | 0x03f); |
| soundrom_loadex((BYTE)(np2cfg.spbopt & 7), "SPB"); | soundrom_loadex(np2cfg.spbopt & 7, "SPB"); |
| opn.base = (np2cfg.spbopt & 0x10)?0x000:0x100; | opn.base = (np2cfg.spbopt & 0x10)?0x000:0x100; |
| } | } |