





Ulf Skutnabb, twitter: @skutis77  
Konami GX785/GX870/GX808/GX903

Sheet: /Main CPU/  
File: mcpu.kicad\_sch

Title: Twin 16 – Rev B

Size: A3 Date: 2024-03-10  
KiCad E.D.A. 8.0.4

Rev: Id: 2/20



Konami 007790

$MCOMRD = \neg(MREAD1 \& \neg MCOMCS) = MREAD1 \mid MCOMCS$   
 $SCOMRD = \neg(SREAD \& \neg SCOMCS)$   
 $SWREN = \neg(SNMMPPX \& SREAD \& \neg SCOMCS)$   
 $MWREN = \neg(SNMMPPX \& MREAD1 \& \neg MCOMCS)$   
 $CLWR = \neg(CLWR \& \neg SNMMPPX \& SREAD \& \neg SCOMCS \& \neg CPUCLK \mid \neg SNMMPPX \& MREAD1 \& \neg MCOMCS \& \neg CPUCLK)$   
 $CUWR = \neg(CUWR \& \neg SNMMPPX \& SREAD \& \neg SCOMCS \& \neg CPUCLK \mid \neg MUWR \& \neg SNMMPPX \& MREAD1 \& \neg MCOMCS \& \neg CPUCLK)$

A All AND logic can be converted to OR form. But since AND logic and inverters are used in the PAL16LB device it is kept in that form. The equations follow verilog syntax. The active low signals are not inverted, the bar is there only to show activeness.



This is from jammarcade.net

Pin 1 = SEL – changes whether the Q outputs require a rising edge clock or not.  
Pin 2 = OEY – Output enable for the Y outputs else they are inputs. Active LOW  
Pin 21 = OEQ – Output enable for the Q (clocked) outputs else they are inputs. Active LOW  
Pin 12 = CLK – Clock input

Pins 3–10 = Y outputs – normal outputs. If OEQ is LOW these pins become outputs mirroring the state of the Q input pins. SEL and CLK pins are not used in this mode.  
Pins 13–20 = Q outputs – clocked outputs. If OEQ is LOW these pins become outputs. If SEL is HIGH and CLK is HIGH these outputs will mirror the state of the Y inputs. If SEL is LOW then the outputs will only change state on a rising edge CLK.

Ulf Skutnabba, twitter: @skutis77  
Konami GX785/GX870/GX808/GX903

Sheet: /Shared Resources/  
File: shared\_resources.kicad\_sch

Title: Twin 16 – Rev B

Size: A3 Date: 2024-03-10  
KiCad E.D.A. 8.0.4

Rev: 4/20

## DMA Synchronization



Ulf Skutnabba, twitter: @skutis77  
**Konami GX785/GX870/GX808/GX903**

Sheet: /Timing/  
File: timing.kicad\_sch

**Title: Twin 16 – Rev B**

Size: A3 Date: 2024-03-10  
KiCad E.D.A. 8.0.4

Rev: Id: 5/20







## Graphics ROM and RAM





Sheet: /Sprite ROM 1/  
File: sprite\_rom\_1.kicad\_sch

**Title:**

Size: A3 Date: 2024-03-10  
KiCad E.D.A. 8.0.4

Rev:  
Id: 10/20





Konami GX785/GX870/GX808/GX903

Sheet: /Sprite ROM 2/  
File: sprite\_rom\_2.kicad\_sch

Title: Twin 16 - Rev B

Size: A3 Date: 2024-03-10  
KiCad E.D.A. 8.0.4

Rev:  
Id: 11/20







Ulf Skutnabba, twitter: @skutis77  
**Konami GX785/GX870/GX808/GX903**

Sheet: /IO/  
File: io.kicad\_sch

**Title: Twin 16 – Rev B**

Size: A3 Date: 2024-03-10  
KiCad E.D.A. 8.0.4

Rev:  
Id: 15/20





Ulf Skutnabba, twitter: @skutis77  
**Konami GX785/GX870/GX808/GX903**

Sheet: /Sound mixer/  
File: sound\_mixer.kicad\_sch

**Title: Twin 16 – Rev B**

Size: A3 Date: 2024-03-10  
KiCad EDA 8.0.4

KiCad E.D.A. 8.0.4

1 / 1



GC903  
Ulf Skutnabba, twitter: @skutis77  
**Konami GX785/GX870/GX808/GX903**  
Sheet: /Battery Powered RAM/  
File: bpram.kicad\_sch  
**Title: Twin 16 – Rev B**  
Size: A3 Date: 2024-03-10  
KiCad E.D.A. 8.0.4 Rev:  
Id: 18/20

## Horizontal signals



– The first VCNTEN is skipped after reset.  
It goes low 140ns before HSYNC goes low,  
and high again when HSYNC goes low.  
VCNTEN is active right before every second falling edge of  
HSYNC.

– CPURES goes high, and stays high, on the seventh falling edge  
of HSYNC.

## Vertical signals



C

Every 16th pulse is long.  
Every 8th pulse is long.  
Every 4th pulse is long.  
Every 2nd pulse is long.  
High period is longer

D

VBLANK High:  $7 \times 16 \times 2 = 224$ , Low:  $5 \times 4 \times 2 = 40$

Syncrldv goes low 140ns before FBREF goes low.  
Syncrldv goes high again when FBREF goes low.

Objbufclr goes low one pixel clock before the rising edge of VBLANK and high again when VBLANK goes high.

60.606Hz, oscanclr goes low for 140ns ~ One pixel clock cycle.

P256vd goes high/low one P4H cycle (8 pixels) after VSYNC goes high.

**FBREF** is measured at pin 22. At U186:3 FBREF is delayed by 22ns going high and 12ns going low.



The horizontal blanking part is shown of the composite blanking signals.

HCOUNT is bits [256H, 128H, 64H, 32H, 16H, 8H, P4H, P2H, P1H]

HSYNC =  $6.144\text{MHz} / 384 = 16\text{kHz}$

Ulf Skutnabba, twitter: @skutis77

Konami GX785/GX870/GX808/GX903

Sheet: /Timing diagrams/

File: timing\_diagrams.kicad\_sch

Title: Twin 16 – Rev B

Size: A3 Date: 2024-03-10

KiCad E.D.A. 8.0.4

Rev:

Id: 19/20

