| version 1.1.1.1, 2003/10/16 17:58:00 | version 1.4, 2004/01/13 05:30:58 | 
| Line 7 | Line 7 | 
 | #include        "fmboard.h" | #include        "fmboard.h" | 
 |  |  | 
 |  |  | 
 |  | // どうも 8253C-2は 4MHz/16らすい? | 
 |  | // とりあえず 1996800/8を入力してみる... (ver0.71) | 
 |  |  | 
 |  |  | 
 |  | // ---- 8253C-2 | 
 |  |  | 
 |  | static UINT pit3_latch(void) { | 
 |  |  | 
 |  | SINT32  clock; | 
 |  |  | 
 |  | clock = nevent_getremain(NEVENT_MUSICGEN); | 
 |  | if (clock >= 0) { | 
 |  | clock /= pccore.multiple; | 
 |  | clock /= 8; | 
 |  | if (pccore.baseclock == PCBASECLOCK25) { | 
 |  | clock = clock * 13 / 16; | 
 |  | } | 
 |  | return(clock); | 
 |  | } | 
 |  | return(0); | 
 |  | } | 
 |  |  | 
 |  | static void pit3_setflag(REG8 value) { | 
 |  |  | 
 |  | pit.flag[3] = 0; | 
 |  | if (value & 0x30) { | 
 |  | pit.mode[3] = value; | 
 |  | } | 
 |  | else { | 
 |  | pit.mode[3] &= ~0x30; | 
 |  | pit.latch[3] = pit3_latch(); | 
 |  | } | 
 |  | } | 
 |  |  | 
 |  | static BOOL pit3_setcount(REG8 value) { | 
 |  |  | 
 |  | switch(pit.mode[3] & 0x30) { | 
 |  | case 0x10:              // access low | 
 |  | pit.value[3] = value; | 
 |  | break; | 
 |  |  | 
 |  | case 0x20:              // access high | 
 |  | pit.value[3] = value << 8; | 
 |  | break; | 
 |  |  | 
 |  | case 0x30:              // access word | 
 |  | if (!(pit.flag[3] & 2)) { | 
 |  | pit.value[3] &= 0xff00; | 
 |  | pit.value[3] += value; | 
 |  | pit.flag[3] ^= 2; | 
 |  | return(TRUE); | 
 |  | } | 
 |  | pit.value[3] &= 0x00ff; | 
 |  | pit.value[3] += value << 8; | 
 |  | pit.flag[3] ^= 2; | 
 |  | break; | 
 |  | } | 
 |  | return(FALSE); | 
 |  | } | 
 |  |  | 
 |  | static REG8 pit3_getcount(void) { | 
 |  |  | 
 |  | REG8    ret; | 
 |  | REG16   w; | 
 |  |  | 
 |  | if (!(pit.mode[3] & 0x30)) { | 
 |  | w = pit.latch[3]; | 
 |  | } | 
 |  | else { | 
 |  | w = pit3_latch(); | 
 |  | } | 
 |  | switch(pit.mode[3] & 0x30) { | 
 |  | case 0x10:                                              // access low | 
 |  | return((UINT8)w); | 
 |  |  | 
 |  | case 0x20:                                              // access high | 
 |  | return((UINT8)(w >> 8)); | 
 |  | } | 
 |  | // access word | 
 |  | if (!(pit.flag[3] & 1)) { | 
 |  | ret = (UINT8)w; | 
 |  | } | 
 |  | else { | 
 |  | ret = (UINT8)(w >> 8); | 
 |  | } | 
 |  | pit.flag[3] ^= 1; | 
 |  | return(ret); | 
 |  | } | 
 |  |  | 
 |  |  | 
 | // ---- intr | // ---- intr | 
 |  |  | 
 | static void setmusicgenevent(BOOL absolute) { | static void setmusicgenevent(BOOL absolute) { | 
 |  |  | 
 | SINT32  cnt; | SINT32  cnt; | 
 |  |  | 
| if (pit.value[3].w > 8) {                                               // 根拠なし | if (pit.value[3] > 4) {                                         // 根拠なし | 
| cnt = pc.multiple * pit.value[3].w; | cnt = pccore.multiple * pit.value[3]; | 
 | } | } | 
 | else { | else { | 
| cnt = pc.multiple << 16; | cnt = pccore.multiple << 16; | 
 | } | } | 
 |  | if (pccore.baseclock == PCBASECLOCK25) { | 
 |  | cnt = cnt * 16 / 13;                                    // cnt * 2457600 / 1996800 | 
 |  | } | 
 |  | cnt *= 8; | 
 | nevent_set(NEVENT_MUSICGEN, cnt, musicgenint, absolute); | nevent_set(NEVENT_MUSICGEN, cnt, musicgenint, absolute); | 
 | } | } | 
 |  |  | 
| Line 37  void musicgenint(NEVENTITEM item) { | Line 131  void musicgenint(NEVENTITEM item) { | 
 |  |  | 
 | // ---- I/O | // ---- I/O | 
 |  |  | 
| static void IOOUTCALL musicgen_o088(UINT port, BYTE dat) { | static void IOOUTCALL musicgen_o088(UINT port, REG8 dat) { | 
 |  |  | 
 | musicgen.porta = dat; | musicgen.porta = dat; | 
 | (void)port; | (void)port; | 
 | } | } | 
 |  |  | 
| static void IOOUTCALL musicgen_o08a(UINT port, BYTE dat) { | static void IOOUTCALL musicgen_o08a(UINT port, REG8 dat) { | 
 |  |  | 
 | musicgen.portb = dat; | musicgen.portb = dat; | 
 | (void)port; | (void)port; | 
 | } | } | 
 |  |  | 
| static void IOOUTCALL musicgen_o08c(UINT port, BYTE dat) { | static void IOOUTCALL musicgen_o08c(UINT port, REG8 dat) { | 
 |  |  | 
 | if (dat & 0x80) { | if (dat & 0x80) { | 
 | if (!(musicgen.portc & 0x80)) { | if (!(musicgen.portc & 0x80)) { | 
| Line 60  static void IOOUTCALL musicgen_o08c(UINT | Line 154  static void IOOUTCALL musicgen_o08c(UINT | 
 | musicgen.sync = 0; | musicgen.sync = 0; | 
 | sound_sync(); | sound_sync(); | 
 | musicgen.key[musicgen.ch] = dat; | musicgen.key[musicgen.ch] = dat; | 
| tms3631_setkey(&tms3631, (BYTE)musicgen.ch, dat); | tms3631_setkey(&tms3631, (REG8)musicgen.ch, dat); | 
 | } | } | 
 | else if ((!(dat & 0x40)) && (musicgen.portc & 0x40)) { | else if ((!(dat & 0x40)) && (musicgen.portc & 0x40)) { | 
 | musicgen.sync = 1; | musicgen.sync = 1; | 
| Line 71  static void IOOUTCALL musicgen_o08c(UINT | Line 165  static void IOOUTCALL musicgen_o08c(UINT | 
 | (void)port; | (void)port; | 
 | } | } | 
 |  |  | 
| static void IOOUTCALL musicgen_o188(UINT port, BYTE dat) { | static void IOOUTCALL musicgen_o188(UINT port, REG8 dat) { | 
 |  |  | 
 | sound_sync(); | sound_sync(); | 
 | musicgen.mask = dat; | musicgen.mask = dat; | 
| Line 79  static void IOOUTCALL musicgen_o188(UINT | Line 173  static void IOOUTCALL musicgen_o188(UINT | 
 | (void)port; | (void)port; | 
 | } | } | 
 |  |  | 
| static void IOOUTCALL musicgen_o18c(UINT port, BYTE dat) { | static void IOOUTCALL musicgen_o18c(UINT port, REG8 dat) { | 
 |  |  | 
| itimer_setcount(3, dat); | if (!pit3_setcount(dat)) { | 
| setmusicgenevent(NEVENT_ABSOLUTE); | setmusicgenevent(NEVENT_ABSOLUTE); | 
|  | } | 
 | (void)port; | (void)port; | 
 | } | } | 
 |  |  | 
| static void IOOUTCALL musicgen_o18e(UINT port, BYTE dat) { | static void IOOUTCALL musicgen_o18e(UINT port, REG8 dat) { | 
 |  |  | 
| itimer_setflag(3, dat); | pit3_setflag(dat); | 
 | (void)port; | (void)port; | 
 | } | } | 
 |  |  | 
| static BYTE IOINPCALL musicgen_i088(UINT port) { | static REG8 IOINPCALL musicgen_i088(UINT port) { | 
 |  |  | 
 | (void)port; | (void)port; | 
 | return(musicgen.porta); | return(musicgen.porta); | 
 | } | } | 
 |  |  | 
| static BYTE IOINPCALL musicgen_i08a(UINT port) { | static REG8 IOINPCALL musicgen_i08a(UINT port) { | 
 |  |  | 
 | (void)port; | (void)port; | 
 | return(musicgen.portb); | return(musicgen.portb); | 
 | } | } | 
 |  |  | 
| static BYTE IOINPCALL musicgen_i08c(UINT port) { | static REG8 IOINPCALL musicgen_i08c(UINT port) { | 
 |  |  | 
 | (void)port; | (void)port; | 
 | return(musicgen.portc); | return(musicgen.portc); | 
 | } | } | 
 |  |  | 
| static BYTE IOINPCALL musicgen_i08e(UINT port) { | static REG8 IOINPCALL musicgen_i08e(UINT port) { | 
 |  |  | 
 | (void)port; | (void)port; | 
 | return(0x08); | return(0x08); | 
 | } | } | 
 |  |  | 
| static BYTE IOINPCALL musicgen_i188(UINT port) { | static REG8 IOINPCALL musicgen_i188(UINT port) { | 
 |  |  | 
 | (void)port; | (void)port; | 
 | return(musicgen.mask); | return(musicgen.mask); | 
 | } | } | 
 |  |  | 
| static BYTE IOINPCALL musicgen_i18c(UINT port) { | static REG8 IOINPCALL musicgen_i18c(UINT port) { | 
 |  |  | 
 | (void)port; | (void)port; | 
| return(itimer_getcount(3)); | return(pit3_getcount()); | 
 | } | } | 
 |  |  | 
| static BYTE IOINPCALL musicgen_i18e(UINT port) { | static REG8 IOINPCALL musicgen_i18e(UINT port) { | 
 |  |  | 
 | (void)port; | (void)port; | 
 |  | #if 1 | 
 |  | return(0x80);                                   // INT-5 | 
 |  | #else | 
 | return(0x40);                                   // INT-5 | return(0x40);                                   // INT-5 | 
 |  | #endif | 
 | } | } | 
 |  |  | 
 |  |  | 
| Line 165  void board14_bind(void) { | Line 264  void board14_bind(void) { | 
 |  |  | 
 | void board14_allkeymake(void) { | void board14_allkeymake(void) { | 
 |  |  | 
| int             i; | REG8    i; | 
 |  |  | 
 | for (i=0; i<8; i++) { | for (i=0; i<8; i++) { | 
| tms3631_setkey(&tms3631, (BYTE)i, musicgen.key[i]); | tms3631_setkey(&tms3631, i, musicgen.key[i]); | 
 | } | } | 
 | } | } | 
 |  |  |