GENESIS
SOFTWARE MANUAL
SEGA ENTERPRISES
Copyright 1989 Sega of Japan

This manual may not, in whole or part, be copied, photocopied, reproduced, or translated
without prior written consent from Sega Enterprises.
GENESIS:

68000 @8MHz
- Main CPU
- 1 MByte (8 Mbit) ROM Area
- 64 KByte RAM Area

VDP (Video Display Processor)
- Dedicated video display processor
  - Controls playfield and sprites
  - Capable of DMA
  - Horizontal and vertical interrupts

Z80 @4MHz
- Controls PSG (Programmable Sound Generator) & FM Chips
- 8 KBytes of dedicated Sound RAM

VIDEO:

- NOTE: Playfield and Sprites are character-based

- Display Area (visual)
  - 40 Chars wide x 26 chars high
  - Each char is 8 x 8 pixels
  - Pixel resolution = 320 x 224

- 3 Planes
  - 2 Scrolling playfields
  - 1 Sprite plane
  - Definable priorities between planes

- Playfields:
  - 5 Different sizes
  - 1 Playfield can have a "fixed" window
  - Playfield map
    - Each char position takes 2 bytes, that includes:
      - Char name (10 bits); points to char definition
      - Horizontal flip
      - Vertical flip
      - Color palette (2 bits); index into CRAM
      - Priority
• Scrolling:
  - 1 Pixel scrolling resolution
  - Horizontal:
    • Whole playfield as unit
    • Each character line
    • Each scan line
  - Vertical
    • Whole playfield as unit
    • 2 Char wide columns
• Sprites:
  • 1 x 1 Char up to 4 x 4 chars
  • Up to 80 sprites can be defined
  • Up to 20 sprites displayed on a scan line
  • Sprite priorities
• Character Definitions
  • 4 bits/pixel: points to color register
  • 4 bytes/scanline of char
  • 32 bytes for complete char definition
  • Playfield and sprite chars are the same

COLOR:

• Uses CRAM (part of the VDP)
  - 64 9-bit wide color registers
    • 64 colors out of 512 possible colors
      - 3 bits of Red
      - 3 bits of Green
      - 3 bits of Blue
    • 4 palettes of 16 colors
      • 0th color (of each palette) is always transparent

OTHER:

• DMA
  - Removes the 68000 from the BUS
  - Can move 205 bytes/scanline during VBLANK
• There are 36 scanlines during VBLANK
• DMA can move 7360 bytes during VBLANK
• Horizontal & Vertical Interrupts

SOUND:

• Z80 Controls:
  - PSG (TI 76489 chip)
  - FM chip (Yamaha YM 2612)
    • 6-Channel stereo
  - Z80 can access ROM data
  - 8 KBytes RAM
HARDWARE:

- 2 Controllers
  - Joypad
  - 3 Buttons
  - Start button
- 1 External port
- 2 Video-outs (RF & RGB)
- Audio jack (stereo)
- Volume control (for audio jack)
# TABLE OF CONTENTS

## I. MEMORY MAP

A. Mega Drive 16 Bit Mode

1. 68K MEMORY MAP ................................................. 1
2. Z80 MEMORY MAP ................................................ 2
3. 68000 ACCESS TO Z80 MEMORY ................................. 2
4. I/O AREA .......................................................... 3
5. CONTROL AREA .................................................... 3
6. VDP AREA .......................................................... 4

## II. VDP 315-5313

A. TERMINOLOGY ....................................................... 6
B. DISPLAY SPECIFICATION ........................................... 6
C. VDP STRUCTURE ..................................................... 8
1. CTRL ................................................................. 8
2. VRAM ............................................................... 8
3. CRAM ............................................................... 8
4. VSRAM ............................................................. 8
5. DMA ............................................................... 8
D. INTERRUPT ......................................................... 9
1. VERTICAL INTERRUPT (V-INT) ................................. 9
2. HORIZONTAL INTERRUPT (H-INT) .............................. 9
3. EXTERNAL INTERRUPT (EX-INT) ............................. 10
E. VDP PORT ............................................................ 10
1. $C0000000 (DATA PORT) ....................................... 10
2. $C0000004 (CONTROL PORT) ................................. 11
3. $C0000008 (HV COUNTER) .................................... 12
F. VDP REGISTER ....................................................... 13
1. MODE SET REGISTER NO.1 ....................................... 13
2. MODE SET REGISTER NO.2 ....................................... 13
3. PATTERN NAME TABLE BASE ADDRESS FOR SCROLL A .... 13
4. PATTERN NAME TABLE BASE ADDRESS FOR WINDOW .... 13
5. PATTERN NAME TABLE BASE ADDRESS FOR SCROLL B .... 14
6. SPRITE ATTRIBUTE TABLE BASE ADDRESS ................. 14
7. BACKGROUND COLOR ............................................. 14
8. H INTERRUPT REGISTER ........................................ 14
9. MODE SET REGISTER NO. 3 ...................................... 15
10. MODE SET REGISTER NO. 4 ..................................... 15
11. H SCROLL DATA TABLE BASE ADDRESS .................... 16
12. AUTO INCREMENT DATA ......................................... 16
13. SCROLL SIZE .................................................... 16
14. WINDOW H POSITION ........................................... 16
15. WINDOW V POSITION ........................................... 17
16. DMA LENGTH COUNTER LOW .................................. 17
17. DMA LENGTH COUNTER HIGH ............................... 17
IV. SYSTEM I/O .................................................. 72

A. VERSION NUMBER ........................................... 72
B. I/O PORT ..................................................... 72
C. MEMORY MODE ............................................... 76
D. Z80 CONTROL .................................................. 76
   1. Z80 BusReq ................................................. 76
   2. Z80 Reset .................................................. 76
E. Z80 AREA ..................................................... 77

V. VRAM MAPPING .................................................. 79

VI. SOUND SOFTWARE MANUAL

A. Z80 MAPPING .................................................. 79
B. 68K CONTROL OF Z80 ........................................ 79
C. FM SOUND CONTROL .......................................... 79
D. PSG CONTROL .................................................. 79
E. D/A CONTROL ................................................... 79

VII. APPENDIX
I. MEMORY MAP

A. Mega Drive 16 Bit Mode (as distinct from Master System Compatibility Mode)

1. 68K MEMORY MAP

- $000000 - ROM CARTRIDGE
- $200000 - SEGA RESERVED
- $400000
- $600000 - SEGA RESERVED
- $800000 - CONTROL
- $900000
- $A00000
- $B00000 - SYSTEM I/O
- $C00000 - SEGA RESERVED
- $D00000 - VDP
- $E00000
- $F00000 - WORK RAM

- $A00000 - Z80
- $A10000 - I/O
- $A11000
- $A12000 - SEGA RESERVED
- $E00000 - ACCESS PROHIBITED
- $FF0000
- $FFFFFF - WORK RAM
2. Z80 MEMORY MAP

<table>
<thead>
<tr>
<th>0000H</th>
<th>SOUND RAM</th>
</tr>
</thead>
<tbody>
<tr>
<td>2000H</td>
<td>SEG A REServed</td>
</tr>
<tr>
<td>4000H</td>
<td>SOUND CHIP (YM2612)</td>
</tr>
<tr>
<td>6000H</td>
<td>MISCELLANEOUS</td>
</tr>
<tr>
<td>8000H</td>
<td>68000 BANK</td>
</tr>
<tr>
<td>FFFFH</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>04000H</th>
<th>YM2612 A0</th>
</tr>
</thead>
<tbody>
<tr>
<td>04001H</td>
<td>DO</td>
</tr>
<tr>
<td>04002H</td>
<td></td>
</tr>
<tr>
<td>04003H</td>
<td>A1</td>
</tr>
<tr>
<td>04004H</td>
<td>D1</td>
</tr>
<tr>
<td>06000H</td>
<td>ACCESS PROHIBITED</td>
</tr>
<tr>
<td>06001H</td>
<td>BANK REGISTER</td>
</tr>
<tr>
<td>07F11H</td>
<td>ACCESS PROHIBITED</td>
</tr>
<tr>
<td>07F12H</td>
<td>PSG 76469</td>
</tr>
<tr>
<td></td>
<td>ACCESS PROHIBITED</td>
</tr>
</tbody>
</table>

3. 68000 ACCESS TO Z80 MEMORY

<table>
<thead>
<tr>
<th>$A00000</th>
<th>SOUND RAM</th>
</tr>
</thead>
<tbody>
<tr>
<td>$A02000</td>
<td>SEG A REServed</td>
</tr>
<tr>
<td>$A04000</td>
<td>SOUND CHIP (YM2612)</td>
</tr>
<tr>
<td>$A06000</td>
<td>BANK REGISTER</td>
</tr>
<tr>
<td>$A08000</td>
<td>ACCESS PROHIBITED</td>
</tr>
<tr>
<td>$A0FFFF</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>$A04000</th>
<th>YM2612 A0</th>
</tr>
</thead>
<tbody>
<tr>
<td>$A04022</td>
<td>DO</td>
</tr>
<tr>
<td>$A04044</td>
<td>A1</td>
</tr>
<tr>
<td>$A04004</td>
<td>D1</td>
</tr>
<tr>
<td>$A06000</td>
<td>ACCESS PROHIBITED</td>
</tr>
<tr>
<td>$A06002</td>
<td>BANK</td>
</tr>
<tr>
<td>$A0FFFF</td>
<td>ACCESS PROHIBITED</td>
</tr>
</tbody>
</table>
### 4. I/O AREA

<table>
<thead>
<tr>
<th>Address</th>
<th>Description</th>
<th>Version No.</th>
</tr>
</thead>
<tbody>
<tr>
<td>$A10000</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$A10002</td>
<td>DATA (CTRL 1)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>DATA (CTRL 2)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>DATA (EXP)</td>
<td></td>
</tr>
<tr>
<td>$A10008</td>
<td>CONTROL (1)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>CONTROL (2)</td>
<td></td>
</tr>
<tr>
<td></td>
<td>CONTROL (E)</td>
<td></td>
</tr>
<tr>
<td>$A10014</td>
<td>TX DATA</td>
<td>(1)</td>
</tr>
<tr>
<td></td>
<td>RX DATA</td>
<td></td>
</tr>
<tr>
<td></td>
<td>S - MODE</td>
<td></td>
</tr>
<tr>
<td>$A1001A</td>
<td>TX DATA</td>
<td>(2)</td>
</tr>
<tr>
<td></td>
<td>RX DATA</td>
<td></td>
</tr>
<tr>
<td></td>
<td>S - MODE</td>
<td></td>
</tr>
<tr>
<td>$A10020</td>
<td>TX DATA</td>
<td>(E)</td>
</tr>
<tr>
<td></td>
<td>RX DATA</td>
<td></td>
</tr>
<tr>
<td></td>
<td>S - MODE</td>
<td></td>
</tr>
<tr>
<td></td>
<td>ACCESS PROHIBITED</td>
<td></td>
</tr>
</tbody>
</table>

---

### 5. CONTROL AREA

<table>
<thead>
<tr>
<th>Address</th>
<th>Description</th>
<th>Mode</th>
<th>Version No.</th>
</tr>
</thead>
<tbody>
<tr>
<td>$A11000</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$A11002</td>
<td>MEMORY MODE</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$A11100</td>
<td>ACCESS</td>
<td>PROHIBITED</td>
<td></td>
</tr>
<tr>
<td>$A11102</td>
<td>Z80 BUSREQ</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$A11200</td>
<td>ACCESS</td>
<td>PROHIBITED</td>
<td></td>
</tr>
<tr>
<td>$A11202</td>
<td>Z80 RESET</td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>ACCESS</td>
<td>PROHIBITED</td>
<td></td>
</tr>
</tbody>
</table>

---

*Confidential*
<table>
<thead>
<tr>
<th>Offset</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>$C00000</td>
<td>DATA</td>
</tr>
<tr>
<td>$C00004</td>
<td>CONTROL</td>
</tr>
<tr>
<td>$C00008</td>
<td>HV COUNTER</td>
</tr>
<tr>
<td>$C0000A</td>
<td>ACCESS PROHIBITED</td>
</tr>
<tr>
<td>$C00010</td>
<td>ACCESS PROHIBITED</td>
</tr>
<tr>
<td>$C00012</td>
<td>ACCESS PROHIBITED</td>
</tr>
<tr>
<td>$DFFFFFF</td>
<td></td>
</tr>
</tbody>
</table>
II. VDP 315-5313
(Video Display Processor)

The VDP controls screen display. VDP has graphic Modes IV and V, where Mode IV is for compatibility with the MASTER SYSTEM and V is for the new Mega drive functions. There are no advantages to using Mode IV, so it is assumed that all Mega drive development will use Mode V. In Mode V, the VDP display has 4 planes: SPRITE, SCROLLA/WINDOW, SCROLLB, and BACKGROUND.
A. TERMINOLOGY

1. A unit of position on X, Y coordinates is called a DOT.
2. A minimum unit of display is called a PIXEL.
3. CELL means an 8 x 8 pixel pattern.
4. SCROLL indicates a repositionable screen-spanning play field.
5. CPU usually indicates the 68000.
6. VDP stands for Video Display Processor.
7. CTRL stands for Control.
8. VRAM stands for VDP RAM, the 64K bytes area of RAM accessible only through the VDP.
9. CRAM stands for Color RAM, 64 9 bit words inside the VDP chip.
10. VSRAM stands for Vertical Scroll RAM, 40 10 bit words inside the VDP chip.
11. DMA stands for Direct Memory Access, the process by which the VDP performs high speed fills or memory copies.
12. PSG stands for Programmable Sound Generator, a class of low capability sound chips. The Mega drive contains a Texas Instruments 76488 PSG chip.
13. FM stands for Frequency Modulation, a class of high capability sound chip. The Mega drive contains a Yamaha 2612 FM chip.

B. DISPLAY SPECIFICATION

DISPLAY SPECIFICATION OUTLINE

<table>
<thead>
<tr>
<th>DISPLAY SIZE</th>
<th>THERE ARE TWO MODES:</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>32 * 28 CELL 256 * 224 PIXEL</td>
</tr>
<tr>
<td></td>
<td>40 * 28 CELL 320 * 224 PIXEL</td>
</tr>
<tr>
<td>CHARACTER GENERATOR</td>
<td>8 * 8 CELLS 1900-1800 depending on general system configuration.</td>
</tr>
<tr>
<td>SCROLL PLAYFIELDS</td>
<td>Two scrolling play fields whose size in cells is selectable from:</td>
</tr>
<tr>
<td></td>
<td>32 * 32, 32 * 64, 32 * 128</td>
</tr>
<tr>
<td></td>
<td>64 * 32, 64 * 64</td>
</tr>
<tr>
<td></td>
<td>128 * 32</td>
</tr>
<tr>
<td>SPRITE</td>
<td>Sprite size is programmable on a sprite by sprite basis, with the following choices:</td>
</tr>
<tr>
<td></td>
<td>8 * 8, 8 * 16, 8 * 24, 8 * 32</td>
</tr>
<tr>
<td></td>
<td>16 * 8, 16 * 16, 16 * 24, 16 * 32</td>
</tr>
<tr>
<td></td>
<td>24 * 8, 24 * 16, 24 * 24, 24 * 32</td>
</tr>
<tr>
<td></td>
<td>32 * 8, 32 * 16, 32 * 24, 32 * 32</td>
</tr>
<tr>
<td></td>
<td>There are 64 sprites available when the screen is in 32 cell wide mode, or 80 when the screen is in 40 cell wide mode.</td>
</tr>
<tr>
<td>WINDOW</td>
<td>1 window associated with the Scroll A play field.</td>
</tr>
<tr>
<td>COLORS</td>
<td>64 colors/512 possibilities.</td>
</tr>
</tbody>
</table>

For PAL (the European television 50 Hz standard), a vertical size of 30 cells (240 dots) is selectable.
The VDP supports both NTSC and PAL television standards. In both cases, the screen is divided into active scan, where the picture is displayed, and vertical retrace (or vertical blanking) where the monitor prepares for the next display.

Numbers of rasters in a screen are as follows:

<table>
<thead>
<tr>
<th>LINES/SCREEN</th>
<th>VCELL NO.</th>
<th>LINE NO. (DISPLAY)</th>
<th>LINE NO. (RETRACE)</th>
</tr>
</thead>
<tbody>
<tr>
<td>NTSC</td>
<td>262</td>
<td>28</td>
<td>224 RASTER</td>
</tr>
<tr>
<td>PAL</td>
<td>312</td>
<td>28</td>
<td>224 RASTER</td>
</tr>
<tr>
<td></td>
<td></td>
<td>30</td>
<td>240 RASTER</td>
</tr>
</tbody>
</table>
C. VDP STRUCTURE

The CPU controls the VDP by special I/O memory locations.

1. CTRL (control)
   This controls REGISTER, VRAM, CRAM, VSRAM, DMA DISPLAY, etc.

2. VRAM (VDP RAM)
   General purpose storage area for display data.

3. CRAM (COLOR RAM)
   64 colors divided into 4 palettes of 16 colors each.

4. VSRAM (Vertical Scroll RAM)
   Up to 20 different vertical scroll values each for scrolling play fields A and B.

5. DMA (Direct Memory Access)
   The VDP may move data at high speed from CPU memory to VRAM, CRAM, and VSRAM
   instead of the CPU, by taking the 68000 off the bus and doing DMA itself.

   The VDP can also fill the VRAM with a constant, or copy from VRAM to VRAM without
   disturbing the 68000.
D. INTERRUPT

There are three interrupts, Vertical, Horizontal, and External. You can control each interrupt by the IEO, IE1, and IE2 bits in the VDP registers. The interrupts use the AUTO-VVECTOR mode of the 68000 and are at levels 6, 4, and 2 respectively; the level 6 vertical interrupt having the highest priority.

IEO V Interrupt (LEVEL 6)
IE1 H Interrupt (LEVEL 4)
IE2 External Interrupt (LEVEL 2)

1: Enable
0: Disable

1. VERTICAL INTERRUPT (V-INT)
The vertical interrupt occurs just after V retrace.

2. HORIZONTAL INTERRUPT (H-INT)
The horizontal interrupt occurs just before H retrace.

The VDP loads the required display information, including all required register values, for the line in about 36 clocks, thus the CPU can control the display of the next line but not the line on which the interrupt occurs.

The horizontal interrupt is controlled by a line counter in register #10.

If this line counter is changed at each interrupt, the desired spacing of interrupts may be achieved.

Thus: If register #10 equals 00h, then the interrupt occurs every line.
      If register #10 equals 01h, then the interrupt occurs every other line.
      If register #10 equals 02h, then the interrupt occurs every third line.
3. EXTERNAL INTERRUPT (EX-INT)

The external interrupt is generated by a peripheral device (gun, modem) and stops the H, V counter for later examination by the CPU.

```
HL INPUT PIN

\[\text{INTERRUPT HAPPEN (COUNTER RATCHED)}\]
```

Please see other sections of this manual for information about the H, V counter and the initialization of the external interrupt.

E. VDP PORT

The VDP ports are at location 68000 in the 68000 memory space.

<table>
<thead>
<tr>
<th>UPPER BYTE</th>
<th>LOWER BYTE</th>
</tr>
</thead>
<tbody>
<tr>
<td>$C00000</td>
<td>DATA PORT</td>
</tr>
<tr>
<td>$C00002</td>
<td></td>
</tr>
<tr>
<td>$C00004</td>
<td>CONTROL PORT</td>
</tr>
<tr>
<td>$C00006</td>
<td></td>
</tr>
<tr>
<td>$C00008</td>
<td>HV COUNTER</td>
</tr>
<tr>
<td>$C0000A</td>
<td>PROHIBITED</td>
</tr>
<tr>
<td>$C0000C</td>
<td>PROHIBITED</td>
</tr>
<tr>
<td>$C0000E</td>
<td>PROHIBITED</td>
</tr>
<tr>
<td>$C00010</td>
<td>PROHIBITED</td>
</tr>
</tbody>
</table>

1. $C000000 (DATA PORT)

READ/WRITE: VRAM, VSRAM, CGRAM

```
\[
\begin{array}{cccccccc}
\text{DT15} & \text{DT14} & \text{DT13} & \text{DT12} & \text{DT11} & \text{DT10} & \text{DT9} & \text{DT8} \\
\hline
\text{DT7} & \text{DT6} & \text{DT5} & \text{DT4} & \text{DT3} & \text{DT2} & \text{DT1} & \text{DT0} \\
\end{array}
\]
```

* $C00000 and $C00002 are functionally equivalent.
2. $C00004 (CONTROL PORT)

READ: STATUS REGISTER

<table>
<thead>
<tr>
<th>$C00004</th>
<th>F</th>
<th>SOVR</th>
<th>C</th>
<th>ODD</th>
<th>VB</th>
<th>HB</th>
<th>DMA</th>
<th>PAL</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

(D15-D8)

(D7-D0)

* NO USE

- **EMPT**... 1: WRITE FIFO EMPTY
  0:

- **FULL**... 1: WRITE FIFO FULL
  0:

- **F**... 1: V interrupt happened
  0:

- **SOVR**... 1: Sprites overflow occurred, too many in line.
  Over 17 in 32 cell mode.
  Over 21 in 40 cell mode.
  0:

- **C**... 1: Collision happened between non-zero pixels in two sprites
  0:

- **ODD**... 1: Odd frame in interlace mode.
  0:

- **VB**... 1: During V blanking
  0:

- **HB**... 1: During H blanking
  0:

- **DMA**... 1: DMA BUSY
  0:

- **PAL**... 1: PAL MODE
  0: NTSC MODE

WRITE: REGISTER SET

<table>
<thead>
<tr>
<th>$C00004</th>
<th>D7</th>
<th>D6</th>
<th>D5</th>
<th>D4</th>
<th>D3</th>
<th>D2</th>
<th>D1</th>
<th>D0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

(D15-D8)

(D7-D0)

* $C00004$ and $C00006$ are functionally equivalent.

- RS4 = RS0: Register No.
- D7 ~ D0: Data

* You must use word or long word access to the VDP ports when setting the registers. Long word access is equivalent to two word accesses, with D31 ~ D16 written first.
WRITE2: ADDRESS SET

<table>
<thead>
<tr>
<th>1st</th>
<th>CD1</th>
<th>CD0</th>
<th>A13</th>
<th>A12</th>
<th>A11</th>
<th>A10</th>
<th>A9</th>
<th>A8</th>
<th>(D15–D8)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>A7</td>
<td>A6</td>
<td>A5</td>
<td>A4</td>
<td>A3</td>
<td>A2</td>
<td>A1</td>
<td>A0</td>
<td>(D7–D0)</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>2nd</th>
<th>CD5</th>
<th>CD4</th>
<th>CD3</th>
<th>CD2</th>
<th>CD1</th>
<th>CD0</th>
<th>(D15–D8)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>----------</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>----------</td>
</tr>
</tbody>
</table>

CD5 ~ CD0: ID CODE
A15 ~ A0: DESTINATION RAM ADDRESS

<table>
<thead>
<tr>
<th>ACCESS MODE</th>
<th>CD5</th>
<th>CD4</th>
<th>CD3</th>
<th>CD2</th>
<th>CD1</th>
<th>CD0</th>
</tr>
</thead>
<tbody>
<tr>
<td>VRAM WRITE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>CRAM WRITE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>VSRAM WRITE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>VRAM READ</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>CRAM READ</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>VSRAM READ</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

* You must use word or long word when performing these operations.

3. $C00008 (HY COUNTER)

NON INTERLACE MODE

INTERLACE MODE

HC8 ~ HC1: H COUNTER
VC8 ~ VC0: V COUNTER
F. VDP REGISTER

VDP has write only register No. 0-No. 23 and read only status register totalling 25 register. There are two modes for register setting; one is mode 4, the other mode 5. We tell you about mode 5 in this section and about mode 4 in MARK III section.

If you change mode in one frame you can get various effects.

1. MODE SET REGISTER NO.1

<table>
<thead>
<tr>
<th>REG. #0</th>
<th>MSB</th>
<th>LSB</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>IE1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>M3</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

IE1...... 1: Enable H interrupt (68000 LEVEL 4)
0: Disable H interrupt (REG #10)

M3...... 1: H, V counter stop
0: Enable read, H, V counter

2. MODE SET REGISTER NO.2

<table>
<thead>
<tr>
<th>REG. #1</th>
<th>MSB</th>
<th>LSB</th>
</tr>
</thead>
<tbody>
<tr>
<td>DISP</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>IEO</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>M1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>M2</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

DISP..... 1: Enable Display
0: Disable Display

IE0...... 1: Enable V interrupt (68000 LEVEL 6)
0: Disable V interrupt

M1...... 1: DMA Enable
0: DMA Disable

M2...... 1: V 30 cell mode (PAL mode)
0: V 28 cell mode (PAL mode; always 0 in NTSC mode)

3. PATTERN NAME TABLE BASE ADDRESS FOR SCROLL A

<table>
<thead>
<tr>
<th>REG. #2</th>
<th>MSB</th>
<th>LSB</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>SA15</td>
<td>SA14</td>
</tr>
<tr>
<td></td>
<td>SA13</td>
<td>0</td>
</tr>
</tbody>
</table>

VRAM ADDR %XXX0_0000_0000_0000

4. PATTERN NAME TABLE BASE ADDRESS FOR WINDOW

<table>
<thead>
<tr>
<th>REG. #3</th>
<th>MSB</th>
<th>LSB</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td></td>
<td>WD15</td>
<td>WD14</td>
</tr>
<tr>
<td></td>
<td>WD13</td>
<td>WD12</td>
</tr>
<tr>
<td></td>
<td>WD11</td>
<td>0</td>
</tr>
</tbody>
</table>

WD11 should be 0 in H40 cell mode
VRAM ADDR %XXXX_X000_0000_0000 (H32 cell mode)
VRAM ADDR %XXXX_0000_0000_0000 (H40 cell mode)
5. PATTERN NAME TABLE BASE ADDRESS FOR SCROLL B

<table>
<thead>
<tr>
<th>MSB</th>
<th>LSB</th>
</tr>
</thead>
<tbody>
<tr>
<td>REG. #4</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>SB15</td>
</tr>
<tr>
<td>SB14</td>
<td>SB13</td>
</tr>
</tbody>
</table>

VRAM ADDR %XXX0_0000_0000_0000

6. SPRITE ATTRIBUTE TABLE BASE ADDRESS

<table>
<thead>
<tr>
<th>MSB</th>
<th>LSB</th>
</tr>
</thead>
<tbody>
<tr>
<td>REG. #5</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>AT15</td>
</tr>
<tr>
<td>AT14</td>
<td>AT13</td>
</tr>
<tr>
<td>AT12</td>
<td>AT11</td>
</tr>
<tr>
<td>AT10</td>
<td>AT9</td>
</tr>
</tbody>
</table>

AT9 should be 0 in H40 cell mode
VRAM ADDR %XXXX_XX00_0000_0000 (32 cell)
VRAM ADDR %XXXX_XX00_0000_0000 (40 cell)

<table>
<thead>
<tr>
<th>MSB</th>
<th>LSB</th>
</tr>
</thead>
<tbody>
<tr>
<td>REG. #8</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

7. BACKGROUND COLOR

<table>
<thead>
<tr>
<th>MSB</th>
<th>LSB</th>
</tr>
</thead>
<tbody>
<tr>
<td>REG. #7</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>CPT1</td>
<td>CPT0</td>
</tr>
<tr>
<td>COL3</td>
<td>COL2</td>
</tr>
<tr>
<td>COL1</td>
<td>COL0</td>
</tr>
</tbody>
</table>

CPT 1-0: COLOR PALLET
COL 3-0: COLOR CODE

<table>
<thead>
<tr>
<th>MSB</th>
<th>LSB</th>
</tr>
</thead>
<tbody>
<tr>
<td>REG. #8</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>MSB</th>
<th>LSB</th>
</tr>
</thead>
<tbody>
<tr>
<td>REG. #9</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>

8. H INTERRUPT REGISTER

<table>
<thead>
<tr>
<th>MSB</th>
<th>LSB</th>
</tr>
</thead>
<tbody>
<tr>
<td>REG. #10</td>
<td></td>
</tr>
<tr>
<td>HIT7</td>
<td>HIT6</td>
</tr>
<tr>
<td>HIT5</td>
<td>HIT4</td>
</tr>
<tr>
<td>HIT3</td>
<td>HIT2</td>
</tr>
<tr>
<td>HIT1</td>
<td>HIT0</td>
</tr>
</tbody>
</table>

This register makes H interrupt timing by number of faster.
H interrupt is enabled by IE = 1.
9. MODE SET REGISTER NO. 3

<table>
<thead>
<tr>
<th>MSB</th>
<th>LSB</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>IE2</td>
<td>VSCR</td>
</tr>
<tr>
<td>HSCR</td>
<td>LSCR</td>
</tr>
</tbody>
</table>

IE2: 
1: Enable external interrupt (88000 LEVEL 2)
2: Disable external interrupt

* See INTERRUPT and SYSTEM I/O

** VSCR: V scroll mode **

<table>
<thead>
<tr>
<th>VSCR</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>FULL SCROLL</td>
</tr>
<tr>
<td>1</td>
<td>EACH 2CELL SCROLL</td>
</tr>
</tbody>
</table>

** HSCR, LSCR: H scroll mode **

<table>
<thead>
<tr>
<th>HSCR</th>
<th>LSCR</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>FULL SCROLL</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>PROHIBITED</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>EACH 1CELL SCROLL</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>EACH 1LINE SCROLL</td>
</tr>
</tbody>
</table>

* BOTH SCROLL A and B

10. MODE SET REGISTER NO. 4

<table>
<thead>
<tr>
<th>MSB</th>
<th>LSB</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>0</td>
<td>S/TE</td>
</tr>
<tr>
<td>LSM1</td>
<td>LSM0</td>
</tr>
<tr>
<td>RS1</td>
<td></td>
</tr>
</tbody>
</table>

RSo: ... 0: HORIZONTAL 32 CELL MODE
1: HORIZONTAL 40 CELL MODE

RS1: ... 0: HORIZONTAL 32 CELL MODE
1: HORIZONTAL 40 CELL MODE

* You should set same No. in RSo, RS1.

32 cell 0000 XXX0
40 cell 1000 XXX1

S/TE: ... 1: Enable SHADOW and HILIGHT
0: Disable SHADOW and HILIGHT

<table>
<thead>
<tr>
<th>LSM1</th>
<th>LSM0</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>NO INTERLACE</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>INTERLACE</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>PROHIBITED</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>INTERLACE (DOUBLE RESOLUTION)</td>
</tr>
</tbody>
</table>
11. H SCROLL DATA TABLE BASE ADDRESS

MSB
REG. #13
0 0 HS15 HS14 HS13 HS12 HS11 HS10

VRAM ADDR %XXXX_XX00_0000_0000

MSB
REG. #14
0 0 0 0 0 0 0 0

12. AUTO INCREMENT DATA

This register controls bias number of increment data.

MSB
REG. #15
INC7 INC6 INC5 INC4 INC3 INC2 INC1 INC0

INC7~0: Bias number (0~$FF)
This number is added automatically after RAM access.

13. SCROLL SIZE

MSB
REG. #16
0 0 VSZ1 VSZ2 0 0 HSZ1 HSZ0

VSZ1, 0: VSIZE

<table>
<thead>
<tr>
<th>VSZ1</th>
<th>VSZ0</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>V 32 cell</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>V 64 cell</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>PROHIBITED</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>V 128 cell</td>
</tr>
</tbody>
</table>

HSZ1, 0: HSIZE

<table>
<thead>
<tr>
<th>HSZ1</th>
<th>HSZ0</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>H 32 cell</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>H 64 cell</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>PROHIBITED</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>H 128 cell</td>
</tr>
</tbody>
</table>

* Both of scroll A and B

14. WINDOW H POSITION

MSB
REG. #17
RIGT 0 0 WHP5 WHP4 WHP3 WHP2 WHP1

RIGT... 0: Window is in left side from base point.
1: Window is in right side from base point.

WHP5~1 Base pointer 0 = Left side
1 = 1 cell right
2...
15. WINDOW V POSITION

MSB

REG. #18

| DOWN | 0 | 0 | WVP4 | WVP3 | WVP2 | WVP1 | WVP0 |

DOWN ... 0: Window is in upper side from base point.
1: Window is in lower side from base point.

WPV4 ~0 Base pointer
0 = Upper side
1 = 1 cell down
2 ...

16. DMA LENGTH COUNTER LOW

MSB

REG. #19

| LG7 | LG6 | LG5 | LG4 | LG3 | LG2 | LG1 | LG0 |

17. DMA LENGTH COUNTER HIGH

MSB

REG. #20

| LG15 | LG14 | LG13 | LG12 | LG11 | LG10 | LG9 | LG8 |

LG15 ~0: DMA LENGTH COUNTER

18. DMA SOURCE ADDRESS LOW

MSB

REG. #21

| SA8 | SA7 | SA6 | SA5 | SA4 | SA3 | SA2 | SA1 |

19. DMA SOURCE ADDRESS MID

MSB

REG. #22

| SA15 | SA14 | SA13 | SA12 | SA11 | SA10 | SA9 |

20. DMA SOURCE ADDRESS HIGH

MSB

REG. #23

| DMD1 | DMD0 | SA22 | SA21 | SA20 | SA19 | SA18 | SA17 |

SA22 ~1: DMA SOURCE ADDRESS

DMD1, 0: DMA MODE

<table>
<thead>
<tr>
<th>DMD1</th>
<th>DMD0</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SA23</td>
<td>MEMORY TO VRAM</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>VRAM FILL</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>VRAM COPY</td>
</tr>
</tbody>
</table>
G. ACCESS VDP RAM

1. RAM ADDRESS SETTING

You can access VRAM, CRAM and VSRAM after writing 32 bits of control data to $C00004 or $C00006.

You have to use word or long word when addressing. If you use long word D31~D16 is 1st, D15~D0 2nd.

<table>
<thead>
<tr>
<th>1st</th>
<th>CD1</th>
<th>CD0</th>
<th>A13</th>
<th>A12</th>
<th>A11</th>
<th>A10</th>
<th>A9</th>
<th>A8</th>
<th>(D15~D8)</th>
<th>(D7~D6)</th>
</tr>
</thead>
<tbody>
<tr>
<td>$C00004</td>
<td>A7</td>
<td>A6</td>
<td>A5</td>
<td>A4</td>
<td>A3</td>
<td>A2</td>
<td>A1</td>
<td>A0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>2nd</th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th>(D15~D8)</th>
<th>(D7~D6)</th>
</tr>
</thead>
<tbody>
<tr>
<td>$C00004</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

CD5=CD0: ID CODE
A15~A0: DESTINATION RAM ADDRESS

<table>
<thead>
<tr>
<th></th>
<th>CD5</th>
<th>CD4</th>
<th>CD3</th>
<th>CD2</th>
<th>CD1</th>
<th>CD0</th>
</tr>
</thead>
<tbody>
<tr>
<td>VRAM WRITE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>CRAM WRITE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>VSRAM WRITE</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>VRAM READ</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>CRAM READ</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>VSRAM READ</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
2. VRAM ACCESS

VRAM address range from 0 to OFFFFH, 64K bytes total.

VRAM access addressing is as follows when writing:

<table>
<thead>
<tr>
<th>1st</th>
<th>0</th>
<th>1</th>
<th>A13</th>
<th>A12</th>
<th>A11</th>
<th>A10</th>
<th>A9</th>
<th>A8</th>
<th>(D15-D8)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>A7</td>
<td>A6</td>
<td>A5</td>
<td>A4</td>
<td>A3</td>
<td>A2</td>
<td>A1</td>
<td>A0</td>
<td>(D7-D0)</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>2nd</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>(D15-D8)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>A15</td>
<td>A14</td>
</tr>
</tbody>
</table>

A15-A0: VRAM address

Data

<table>
<thead>
<tr>
<th></th>
<th>D15</th>
<th>D14</th>
<th>D13</th>
<th>D12</th>
<th>D11</th>
<th>D10</th>
<th>D9</th>
<th>D8</th>
</tr>
</thead>
<tbody>
<tr>
<td>$C000004</td>
<td>D7</td>
<td>D6</td>
<td>D5</td>
<td>D4</td>
<td>D3</td>
<td>D2</td>
<td>D1</td>
<td>D0</td>
</tr>
</tbody>
</table>

D15-D0: VRAM data

When you use long word D31-D16 is 1st, D15-D0 is 2nd. When you do byte writing, data is D7-D0, and may be written to $C000000 or $C00004.

VRAM address is increased by the value of REGISTER #15, independent data size. VRAM address A0 is used in the calculation of the address increment, but is ignored during address decoding.

VRAM addressing and decoding are as follows: the VRAM address decode uses A15-A1, and A0 specifies the data write format. Write data cannot cross a word boundary, high and low bytes are exchanged if A0=1.
<table>
<thead>
<tr>
<th>ADDRESS: 0</th>
<th>BYTE</th>
<th>WORD</th>
<th>LONG WORD</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>1st</td>
<td>D7-D0</td>
<td>1st</td>
</tr>
<tr>
<td></td>
<td>2nd</td>
<td>D7-D0</td>
<td>2nd</td>
</tr>
<tr>
<td></td>
<td>3rd</td>
<td>D7-D0</td>
<td>3rd</td>
</tr>
<tr>
<td></td>
<td>4th</td>
<td>D7-D0</td>
<td>4th</td>
</tr>
<tr>
<td></td>
<td>5th</td>
<td>D7-D0</td>
<td>5th</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>ADDRESS: 0</th>
<th>BYTE</th>
<th>WORD</th>
<th>LONG WORD</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>1st</td>
<td>D7-D0</td>
<td>1st</td>
</tr>
<tr>
<td></td>
<td>2nd</td>
<td>D7-D0</td>
<td>2nd</td>
</tr>
<tr>
<td></td>
<td>3rd</td>
<td>D7-D0</td>
<td>3rd</td>
</tr>
<tr>
<td></td>
<td>4th</td>
<td>D7-D0</td>
<td>4th</td>
</tr>
<tr>
<td></td>
<td>5th</td>
<td>D7-D0</td>
<td>5th</td>
</tr>
</tbody>
</table>

S/W GENERIS MANUAL
Rev. 02/1992
CONFIDENTIAL #106 PROPERTY OF SEGA
### START ADDRESS: 1 REG. #15=2

<table>
<thead>
<tr>
<th>ADDRESS: 0</th>
<th>BYTE</th>
<th>WORD</th>
<th>LONG WORD</th>
</tr>
</thead>
<tbody>
<tr>
<td>1st</td>
<td>D7~D0</td>
<td>1st</td>
<td>D7~D0</td>
</tr>
<tr>
<td>2nd</td>
<td>D7~D0</td>
<td>2nd</td>
<td>D7~D0</td>
</tr>
<tr>
<td>3rd</td>
<td>D7~D0</td>
<td>3rd</td>
<td>D7~D0</td>
</tr>
<tr>
<td>4th</td>
<td>D7~D0</td>
<td>4th</td>
<td>D7~D0</td>
</tr>
<tr>
<td>5th</td>
<td>D7~D0</td>
<td>5th</td>
<td>D7~D0</td>
</tr>
</tbody>
</table>

### START ADDRESS: 1 REG. #15=1

<table>
<thead>
<tr>
<th>ADDRESS: 0</th>
<th>BYTE</th>
<th>WORD</th>
<th>LONG WORD</th>
</tr>
</thead>
<tbody>
<tr>
<td>1st</td>
<td>D7~D7</td>
<td>1st</td>
<td>D7~D0</td>
</tr>
<tr>
<td>2nd</td>
<td>D7~D7</td>
<td>2nd</td>
<td>D7~D0</td>
</tr>
<tr>
<td>3rd</td>
<td>D7~D7</td>
<td>3rd</td>
<td>D7~D0</td>
</tr>
<tr>
<td>4th</td>
<td>D7~D7</td>
<td>4th</td>
<td>D7~D0</td>
</tr>
<tr>
<td>5th</td>
<td>D7~D7</td>
<td>5th</td>
<td>D7~D0</td>
</tr>
<tr>
<td>6th</td>
<td>D7~D7</td>
<td>6th</td>
<td>D7~D0</td>
</tr>
<tr>
<td>7th</td>
<td>D7~D7</td>
<td>7th</td>
<td>D7~D0</td>
</tr>
<tr>
<td>8th</td>
<td>D7~D7</td>
<td>8th</td>
<td>D7~D0</td>
</tr>
</tbody>
</table>
VRAM READ

1st

<table>
<thead>
<tr>
<th>0</th>
<th>0</th>
<th>A13</th>
<th>A12</th>
<th>A11</th>
<th>A10</th>
<th>A9</th>
<th>A8</th>
</tr>
</thead>
<tbody>
<tr>
<td>A7</td>
<td>A6</td>
<td>A5</td>
<td>A4</td>
<td>A3</td>
<td>A2</td>
<td>A1</td>
<td>A0</td>
</tr>
</tbody>
</table>

(D15-D6)
(D7-D0)

2nd

<table>
<thead>
<tr>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>A15</td>
<td>A14</td>
</tr>
</tbody>
</table>

(D15-D6)
(D7-D0)

A15-A0: VRAM ADDRESS

Data

<table>
<thead>
<tr>
<th>D15</th>
<th>D14</th>
<th>D13</th>
<th>D12</th>
<th>D11</th>
<th>D10</th>
<th>D9</th>
<th>D8</th>
</tr>
</thead>
<tbody>
<tr>
<td>D7</td>
<td>D6</td>
<td>D5</td>
<td>D4</td>
<td>D3</td>
<td>D2</td>
<td>D1</td>
<td>D0</td>
</tr>
</tbody>
</table>

(D15-D6)
(D7-D0)

D15-D0: VRAM DATA

The data is always read in word units. A0 is ignored during the reading; no swap of bytes occurs if A0=1.

Subsequent reads are from address incremented by REGISTER #15. A0 is used in calculation of the next address.

3. CRAM ACCESS

The CRAM contains 128 bytes, addresses 0 to 7FH. For word wide writes to the CRAM, use:

1st

<table>
<thead>
<tr>
<th>1</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>A6</td>
<td>A5</td>
<td>A4</td>
<td>A3</td>
<td>A2</td>
<td>A1</td>
<td>A0</td>
</tr>
</tbody>
</table>

(D15-D6)
(D7-D0)

2nd

<table>
<thead>
<tr>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>A15</td>
<td>A14</td>
</tr>
</tbody>
</table>

(D15-D6)
(D7-D0)

A6-A0: CRAM ADDRESS

Data

<table>
<thead>
<tr>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>B2</th>
<th>B1</th>
<th>B0</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>C2</td>
<td>G1</td>
<td>G0</td>
<td>0</td>
<td>R2</td>
<td>R1</td>
<td>R0</td>
<td>0</td>
</tr>
</tbody>
</table>

(D15-D6)
(D7-D0)

D15-D0 are valid when we use word for data set. If the writes are byte wide, write the high byte to $C00000 and the low byte to $C00001.
A long word wide access is equivalent to two sequential word wide accesses. Place the first data in D31 - D16, and the second data in D15 - D0.

The data may be written sequentially; the address is incremented by the value of REGISTER #15 after every write, independent of whether the width is byte or word.

Note that A0 is used in the increment, but not in address decoding, resulting in some interesting side effects if writes are attempted at odd addresses.

For word wide reads from the CRAM, use:

4. VSRAM ACCESS

The VSRAM contains 80 bytes, addresses 0 to 4FH. For word wide writes to the VSRAM, use:
5. ACCESS TIMING

The CPU and VDP access VRAM, CRAM and VSRAM using timesharing. Because the VDP is very busy during the active scan, the CPU accesses are limited. However, during vertical blanking, the CPU may access the VDP continuously.

The number of permitted accesses by the CPU additionally depends on whether the screen is in 32 cell mode or 40 cell mode. Additionally, the access size depends on the RAM type; a VRAM access is byte wide, but CRAM and VSRAM are word wide.

For example, in 32 Cell mode, the CPU may access the VRAM 16 times during horizontal scan in a single line. Each access is a byte write, so this amounts to 8 words. However, CRAM and VSRAM, though sharing the 16 time limit, are word accesses so that 16 words may be written in a single line.

Although there is a four-word FIFO, if writes are done in a tight loop during active scan, the FIFO will fill up and the CPU will eventually end up waiting to write.

The maximum wait times are:

<table>
<thead>
<tr>
<th>Display Mode</th>
<th>Maximum Waiting Time</th>
</tr>
</thead>
<tbody>
<tr>
<td>H32 cell</td>
<td>Approximately 5.96 μ sec</td>
</tr>
<tr>
<td>H40 cell</td>
<td>Approximately 4.77 μ sec</td>
</tr>
</tbody>
</table>

As the CPU has unlimited access to the RAMs during vertical blanking, the wait case never arises.
6. HV COUNTER

The HV Counter's function is to give the horizontal and vertical location of the television beam. If the "M3" Bit of Register #0 is set, the HV Counter will then freeze when trigger signal HL goes high, as well as triggering a level 2 interrupt.

<table>
<thead>
<tr>
<th>M3</th>
<th>Counter Latch Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Counter is not latched by trigger signal</td>
</tr>
<tr>
<td>1</td>
<td>Counter is latched by trigger signal</td>
</tr>
</tbody>
</table>

### M3: Register #0

#### Non-Interface Mode

<table>
<thead>
<tr>
<th>VC7</th>
<th>VC6</th>
<th>VC5</th>
<th>VC4</th>
<th>VC3</th>
<th>VC2</th>
<th>VC1</th>
<th>VC0</th>
<th>(D15 ~ D8)</th>
</tr>
</thead>
<tbody>
<tr>
<td>HC8</td>
<td>HC7</td>
<td>HC6</td>
<td>HC5</td>
<td>HC4</td>
<td>HC3</td>
<td>HC2</td>
<td>HC1</td>
<td>(D7 ~ D0)</td>
</tr>
</tbody>
</table>

#### Interface Mode

<table>
<thead>
<tr>
<th>VC7</th>
<th>VC6</th>
<th>VC5</th>
<th>VC4</th>
<th>VC3</th>
<th>VC2</th>
<th>VC1</th>
<th>VC0</th>
<th>(D15 ~ D8)</th>
</tr>
</thead>
<tbody>
<tr>
<td>HC8</td>
<td>HC7</td>
<td>HC6</td>
<td>HC5</td>
<td>HC4</td>
<td>HC3</td>
<td>HC2</td>
<td>HC1</td>
<td>(D7 ~ D0)</td>
</tr>
</tbody>
</table>

#### V-Counter: VC7 ~ VC0

#### H-Counter: HC8 ~ HC1

<table>
<thead>
<tr>
<th>Display Mode</th>
<th>Counter Data</th>
</tr>
</thead>
<tbody>
<tr>
<td>V 28 Cell</td>
<td>0 ~ DFH</td>
</tr>
<tr>
<td>V 30 Cell</td>
<td>0 ~ EFH</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Display Mode</th>
<th>Counter Data</th>
</tr>
</thead>
<tbody>
<tr>
<td>H 32 Cell</td>
<td>0 ~ 7FH</td>
</tr>
<tr>
<td>H 40 Cell</td>
<td>0 ~ 9FH</td>
</tr>
</tbody>
</table>

The counter only has eight bits each for H and V, so Interface Mode and 40 Cell (320 dot) modes present some problems. During Interface Mode, the LSB of the vertical position is replaced by the new MSB. The horizontal resolution problem is solved by always dropping the LSB.

**Caution:**

As the HV Counter's value is not valid during vertical blanking, check to be sure that it is active scan before using the value.
H. DMA TRANSFER

DMA (Direct Memory Access) is a high-speed technique for memory access to the VRAM, CRAM, and VSRAM. During DMA, VRAM, CRAM and VSRAM occur at the fastest possible rate (refer to the section on Access Timing). There are three modes of DMA access, as can be seen below, all of which may be done to VRAM or CRAM or VSRAM. The 68K is stopped during memory to VRAM/CRAM/VSRAM DMA, but the 280 continues to run as long as it does not attempt access to the 68K memory space.

The DMA is quite fast during VBLANK (about double the tightest possible 68K loop's speed), but during active scan the speed is the same as a 68K loop.

Please note that after this point, VRAM is used as a generic term for VRAM/CRAM/VSRAM.

<table>
<thead>
<tr>
<th>DMD1</th>
<th>DMD0</th>
<th>DMA Mode</th>
<th>Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>SA23</td>
<td>A. Memory to VRAM</td>
<td>Word to Byte (H) &amp; (L)</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>B. VRAM Fill</td>
<td>Byte to Byte</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>C. VRAM Copy</td>
<td>Byte to Byte</td>
</tr>
</tbody>
</table>

DMD1, DMD0: Reg. #23  * DMD0 = SA23

Source address are $000000-$3FFFFFF (ROM) and $FF0000-$FFFF0000 (RAM) for memory to VRAM transfers. In the case of ROM to VRAM transfers, a hardware feature causes occasional failure of DMA unless the following two conditions are observed:

- The destination address write (to address $C00004) must be a word write.
- The final write must use the work RAM. There are two ways to accomplish this: (1) by copying the DMA program into RAM, or (2) by doing a final "move W RAM address, $C00004".

1. MEMORY TO VRAM

This function transfers data from 68K memory to VRAM, CRAM or VSRAM. During this DMA all 68K processing stops. The source address is $000000-$3FFFFFF for ROM or $FF0000-$FFFF0000 for RAM. The DMA reads are word-wide, writes are byte-wide for VRAM and word-wide for CRAM and VSRAM. The destination is specified by:

<table>
<thead>
<tr>
<th>CD2</th>
<th>CD1</th>
<th>CD0</th>
<th>Memory Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>VRAM</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>CRAM</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>VSRAM</td>
</tr>
</tbody>
</table>
Setting of DMA

A. M1 (Register #1) = 1 : DMA ENABLE.
B. Increment number set to Register #15 (normally #2).
C. Transfer word number set to Registers #19, #20.
D. Source address and DMA mode set into Registers #21, #22 and #23.
E. Set the destination address.
F. *VDP gets the CPU bus.
G. *DMA start.
H. *VDP releases the CPU bus.
I. M1 has to be 0 after confirmation of DMA finish : DMA DISENABLE.

DMA starts after Step E.

You must set M1=1 only during DMA; otherwise, we cannot guarantee the operation.
Source addresses were increased with +2 and destination address increased with content of Register #15.

Content of Register. Register #1 has another bit:

<table>
<thead>
<tr>
<th>Register #15</th>
<th>INC7</th>
<th>INC6</th>
<th>INC5</th>
<th>INC4</th>
<th>INC3</th>
<th>INC2</th>
<th>INC1</th>
<th>INC0</th>
</tr>
</thead>
<tbody>
<tr>
<td>INC7 ~ INC0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Register #15</th>
<th>DISP</th>
<th>IEC</th>
<th>M1</th>
<th>M2</th>
<th>1</th>
<th>0</th>
<th>0</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Register #19</th>
<th>LG7</th>
<th>LG6</th>
<th>LG5</th>
<th>LG4</th>
<th>LG3</th>
<th>LG2</th>
<th>LG1</th>
<th>LG0</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Register #20</th>
<th>LG15</th>
<th>LG14</th>
<th>LG13</th>
<th>LG12</th>
<th>LG11</th>
<th>LG10</th>
<th>LG9</th>
<th>LG8</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Register #21</th>
<th>SA8</th>
<th>SA7</th>
<th>SA6</th>
<th>SA5</th>
<th>SA4</th>
<th>SA3</th>
<th>SA2</th>
<th>SA1</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Register #22</th>
<th>SA16</th>
<th>SA15</th>
<th>SA14</th>
<th>SA13</th>
<th>SA12</th>
<th>SA11</th>
<th>SA10</th>
<th>SA9</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Register #23</th>
<th>0</th>
<th>SA23</th>
<th>SA22</th>
<th>SA21</th>
<th>SA20</th>
<th>SA19</th>
<th>SA18</th>
<th>SA17</th>
</tr>
</thead>
</table>
2. VRAM FILL

FILL mode fills with same data from free even VRAM address. FILL for only VRAM.

How to set FILL (DMA):

A. M1 (Register #1) - 1 : DMA ENABLE

B. Increment number set to #15 (normally #1)

C. Fill size set to #19, #20.

D. DMA mode set to #23.

E. Destination address and FILL data set.

F. *DMA start.

G. M1=0 after confirmation of finishing : DMA DIENABLE

DMA starts after Step E.

M1 should be 1 in the DMA transfer; otherwise, we cannot guarantee the operation.

Destination address is incremented with Register #15. VDP does not ask but open for CPU but CPU cannot access VDP without PSG, HV counter, and status. You can realize end of DMA by DMA bit in status register.
Register Setting. Register #1 has another bit.

Register #15

<table>
<thead>
<tr>
<th>INC15</th>
<th>INC14</th>
<th>INC13</th>
<th>INC12</th>
<th>INC11</th>
<th>INC10</th>
<th>INC9</th>
<th>INC8</th>
</tr>
</thead>
</table>

INC7 ~ INC0: Increment number

Status

<table>
<thead>
<tr>
<th>F</th>
<th>SCVR</th>
<th>C</th>
<th>ODD</th>
<th>VB</th>
<th>HB</th>
<th>DMA</th>
<th>PAL</th>
</tr>
</thead>
</table>

DMA: 1: DMA Busy
*: Not care

Register #1

| 0 | DISP | IEO | M1 | M2 | 1 | 0 | 0 |

Register #19

| LG7 | LG6 | LG5 | LG4 | LG3 | LG2 | LG1 | LG0 |

Register #20

| LG15 | LG14 | LG13 | LG12 | LG11 | LG10 | LG9 | LG8 |

Register #23

| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

1st $C00004

| 0 | 1 | DA10 | DA11 | DA12 | DA13 | DA9 | DA8 |

| DA7 | DA6 | DA5 | DA4 | DA3 | DA2 | DA1 | DA0 |

| (D15 ~ D8) | (D7 ~ D0) |

2nd $C00004

| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| 1 | 0 | 0 | 0 | 0 | 0 | DA15 | DA14 |

| (D15 ~ D8) | (D7 ~ D0) |

$C00000

| FD15 | FD14 | FD13 | FD12 | FD11 | FD10 | FD9 | FD8 |

| FD7 | FD6 | FD5 | FD4 | FD3 | FD2 | FD1 | FD0 |

| (D15 ~ D8) | (D7 ~ D0) |

LG15 ~ LG0: Fill byte number
DA15 ~ DA0: Destination address
FD15 ~ FD0: FILL data

When setting first and second by long word, first will be D31-D16 and second will be D15-D0.
Example 1 Fill data are word. Register #15 - 1.

1. V-RAM address is even.
   A. First, low side of Fill data are written in V-RAM address.
   B. Second, upper side of Fill data are written in V-RAM + 1.
   C. V-RAM address is added register #15, written upper side Fill data in V-RAM at next each step.

2. V-RAM address is odd.
   D. First, upper side of FILL data are written in V-RAM address - 1.
   E. Second, low side of FILL data are written in V-RAM.
   F. Same as (C)

You must rewrite data (C) into ADD + 1 after write data (B).
Example 2  Fill data are word. Register #15 = 2.

<table>
<thead>
<tr>
<th>VRAM address = even</th>
<th>VRAM address = odd</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADD  (A) lower</td>
<td>Even ADD -1 (D) upper</td>
</tr>
<tr>
<td>ADD + 1 (B) upper</td>
<td>Odd ADD + 1 (E) lower</td>
</tr>
<tr>
<td>ADD + 2 (C) lower</td>
<td>ADD + 1 (F) upper</td>
</tr>
<tr>
<td>ADD + 3 upper</td>
<td>ADD + 2 (F) upper</td>
</tr>
<tr>
<td>ADD + 4 (C) lower</td>
<td>ADD + 3 lower</td>
</tr>
<tr>
<td>ADD + 5 upper</td>
<td>ADD + 4 (F) upper</td>
</tr>
<tr>
<td>ADD + 6 (C) lower</td>
<td>ADD + 5 lower</td>
</tr>
<tr>
<td>ADD + 7 upper</td>
<td>ADD + 6 (F) upper</td>
</tr>
</tbody>
</table>

Example 3  Fill data are byte.

1. V-RAM address is even
   \( (A) - (B) - (C) = \text{BYTE DATA} \)

2. V-RAM address is odd
   \( (D) = (E) = (F) = \text{BYTE DATA} \)

3. VRAM COPY

   This function copies from source address to destination address by number of Copy byte.

   DMA Setting

   A. M1 (Register #1) = 1 : DMA ENABLE.
   B. Number of copy bytes in #19, #20
   C. Source address and DMA mode in #23.
   D. Destination address set.
   E. "DMA transfer.
   F. After confirming DMA finish: M1 = 0 : DMA DISABLE
DMA starts when (D) above is finished. Apply M1 = 1 only during DMA transfer. In other cases, if M1 = 1 is set, there is no guarantee that it will function correctly. At the time of DMA transfer, the destination address is incremented by the set value of Register #15. During DMA transfer, although the VDP does not require CPU to make a bus available, no access is possible from CPU to VDP except for PSG, HV counter, Status Read. DMA transfer finish can be recognized by referring to the Status Register's DMA bit.

Example  With Transfer byte = 3 at the time of VRAM Copy

<table>
<thead>
<tr>
<th>Source Address</th>
<th>Register #15 = 1 Destination Address</th>
<th>Register #15 = 2 Destination Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>DATA 1</td>
<td>DATA 1</td>
<td>DATA 1</td>
</tr>
<tr>
<td>DATA 2</td>
<td>DATA 2</td>
<td>DATA 2</td>
</tr>
<tr>
<td>DATA 3</td>
<td>DATA 3</td>
<td>DATA 3</td>
</tr>
<tr>
<td>DATA 4</td>
<td></td>
<td></td>
</tr>
<tr>
<td>DATA 5</td>
<td></td>
<td></td>
</tr>
<tr>
<td>DATA 6</td>
<td></td>
<td></td>
</tr>
<tr>
<td>DATA 7</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Caution

In the case of VRAM Copy, "read from VRAM" and "write to VRAM" are repeated per byte. Therefore, when the Source Area and Transfer Area are overlapped, the transfer may not be performed correctly.
Registers are as follows. Register #1 includes bits set for purposes other than DMA. Therefore, pay careful attention in this regard.

<table>
<thead>
<tr>
<th>Register #15</th>
<th>INC7</th>
<th>INC6</th>
<th>INC5</th>
<th>INC4</th>
<th>INC3</th>
<th>INC2</th>
<th>INC1</th>
<th>INC0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Status</td>
<td>*</td>
<td>*</td>
<td>*</td>
<td>*</td>
<td>*</td>
<td>*</td>
<td>EMPT</td>
<td>FULL</td>
</tr>
<tr>
<td></td>
<td>F</td>
<td>SOVR</td>
<td>C</td>
<td>ODD</td>
<td>VB</td>
<td>HB</td>
<td>DMA</td>
<td>PAL</td>
</tr>
</tbody>
</table>

DMA: 1: DMA Busy

<table>
<thead>
<tr>
<th>Register #1</th>
<th>0</th>
<th>DISP</th>
<th>IEO</th>
<th>M1</th>
<th>M2</th>
<th>1</th>
<th>0</th>
<th>0</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Register #19</th>
<th>LG7</th>
<th>LG6</th>
<th>LG5</th>
<th>LG4</th>
<th>LG3</th>
<th>LG2</th>
<th>LG1</th>
<th>LG0</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Register #20</th>
<th>LG15</th>
<th>LG14</th>
<th>LG13</th>
<th>LG12</th>
<th>LG11</th>
<th>LG10</th>
<th>LG9</th>
<th>LG8</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Register #21</th>
<th>SA7</th>
<th>SA6</th>
<th>SA5</th>
<th>SA4</th>
<th>SA3</th>
<th>SA2</th>
<th>SA1</th>
<th>SA0</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Register #22</th>
<th>SA15</th>
<th>SA14</th>
<th>SA13</th>
<th>SA12</th>
<th>SA11</th>
<th>SA10</th>
<th>SA9</th>
<th>SA8</th>
</tr>
</thead>
</table>

<table>
<thead>
<tr>
<th>Register #23</th>
<th>1</th>
<th>1</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
</tr>
</thead>
</table>

1st $C00004

<table>
<thead>
<tr>
<th></th>
<th>0</th>
<th>0</th>
<th>DA13</th>
<th>DA12</th>
<th>DA11</th>
<th>DA10</th>
<th>DA9</th>
<th>DA8</th>
</tr>
</thead>
</table>

2nd $C00004

<table>
<thead>
<tr>
<th></th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
</tr>
</thead>
</table>

1st $C00004

<table>
<thead>
<tr>
<th></th>
<th>DA7</th>
<th>DA6</th>
<th>DA5</th>
<th>DA4</th>
<th>DA3</th>
<th>DA2</th>
<th>DA1</th>
<th>DA0</th>
</tr>
</thead>
</table>

2nd $C00004

<table>
<thead>
<tr>
<th></th>
<th>1</th>
<th>1</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>DA15</th>
<th>DA14</th>
</tr>
</thead>
</table>

LG15 ~ LG0: Number of copy byte
SA15 ~ SA0: Source address
DA15 ~ DA0: Destination address

When setting first and second by long word, first will be D31~D16 and second will be D15~D0.
4. DMA TRANSFER CAPACITY

Transfer quantity varies, depending on the Display Mode as follows:

<table>
<thead>
<tr>
<th>DMA Mode</th>
<th>Display Mode</th>
<th>Screen Scanning</th>
<th>Transfer bytes per line</th>
</tr>
</thead>
<tbody>
<tr>
<td>MEMORY TC VRAM</td>
<td>H32 Cell</td>
<td>During effective screen During V Blank</td>
<td>16 bytes 167 bytes</td>
</tr>
<tr>
<td></td>
<td>H40 Cell</td>
<td>During effective screen During V Blank</td>
<td>18 bytes 205 bytes</td>
</tr>
<tr>
<td>VRAM FILL</td>
<td>H32 Cell</td>
<td>During effective screen During V Blank</td>
<td>15 bytes 166 bytes</td>
</tr>
<tr>
<td></td>
<td>H40 Cell</td>
<td>During effective screen During V Blank</td>
<td>17 bytes 204 bytes</td>
</tr>
<tr>
<td>VRAM COPY</td>
<td>H32 Cell</td>
<td>During effective screen During V Blank</td>
<td>8 bytes 80 bytes</td>
</tr>
<tr>
<td></td>
<td>H40 Cell</td>
<td>During effective screen During V Blank</td>
<td>9 bytes 102 bytes</td>
</tr>
</tbody>
</table>

In the Memory to VRAM, in the case where CRAM and VSRAM are the destinations, number of words (not bytes) should apply. One line during V Blank allows for data transfer to all the addresses of CRAM and VSRAM.

Note that when calculating, the transfer quantity in one screen (1/60 sec) varies depending on the number of lines during V Blank (refer to Display Mode) in the case of NTSC (video signal) and PAL systems.

<table>
<thead>
<tr>
<th>Display Mode</th>
<th>No. of Horizontal Lines</th>
</tr>
</thead>
<tbody>
<tr>
<td>V26 Cell (NTSC)</td>
<td>36</td>
</tr>
<tr>
<td>V26 Cell (PAL)</td>
<td>87</td>
</tr>
<tr>
<td>V30 Cell (PAL)</td>
<td>71</td>
</tr>
</tbody>
</table>

Where Register #1 DISP=0, i.e., when on-screen display is not made, the Transfer quantity is the same as Transfer Bytes Per Line during Blanking.
I. SCROLLING SCREEN

There are two different scroll screens, A and B, which separately can scroll vertically and horizontally on a basis of a one-dot unit. In the horizontal direction, scrolling overall or based on a one cell unit or one line unit can be selected, and in the vertical direction, scrolling overall or in a two cell unit can be selected. Also, the scroll screen size can be changed on a basis of a 32 cell unit.
For the scrolling screen display, the following register setting and VRAM are required:

**Scroll "A" Pattern Name Table Base Address**

Register #2

<table>
<thead>
<tr>
<th></th>
<th></th>
<th>SA15</th>
<th>SA14</th>
<th>SA13</th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
</table>

**Scroll "B" Pattern Name Table Base Address**

Register #4

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th>SB15</th>
<th>SB14</th>
<th>SB13</th>
</tr>
</thead>
</table>

**Mode Set Register #3**

Register #11

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th>IE2</th>
<th>VSCR</th>
<th>HSCR</th>
<th>LSCR</th>
</tr>
</thead>
</table>

**Mode Set Register #4**

Register #12

<table>
<thead>
<tr>
<th>RS0</th>
<th></th>
<th></th>
<th></th>
<th></th>
<th>S/TE</th>
<th>LSM1</th>
<th>LSM0</th>
<th>RS1</th>
</tr>
</thead>
</table>

**H Scroll Data Table Base Address**

Register #13

<table>
<thead>
<tr>
<th></th>
<th></th>
<th>HS15</th>
<th>HS14</th>
<th>RS13</th>
<th>HS12</th>
<th>HS11</th>
<th>HS10</th>
</tr>
</thead>
</table>

**Scroll Size**

Register #16

<table>
<thead>
<tr>
<th></th>
<th></th>
<th>VSZ1</th>
<th>VSZ0</th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
</table>

**VRAM**

- Scroll "A" Pattern Name Table: Max 8 Kbyte
- Scroll "B" Pattern Name Table: Max 8 Kbyte
- H Scroll Data Table: Max 960 byte

**VSRAM**

- V Scroll Data Table: Max 80 byte
1. SCROLLING SCREEN SIZE

The screen size can be set by VSZ1, VSZ0, HSZ1, and HSZ0 (Register #16). The following six kinds can be set for both Scroll Screens A and B.

32*32/32*64/32*128
64*32/64*64
128*32

<table>
<thead>
<tr>
<th>VSZ1</th>
<th>VSZ0</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>V 32 cell</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>V 64 cell</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Prohibited</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>V 128 cell</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>HSZ1</th>
<th>HSZ0</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>H 32 cell</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>H 64 cell</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Prohibited</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>H 128 cell</td>
</tr>
</tbody>
</table>

Scroll Screen's Pattern Name Table Address exits in the VRAM and is designated by Registers #2 and #4. Depending VRAM and Scroll Screen correspond to each other differently.

Example

Register #16 = 00H: 32*32 cell

```
  0  1  32 CELL  30  31
  0  0000  0002  ~  003c  003e
  1  0040  0042  ~  007c  007e

  32 cell

  30  0780  0782  ~  07bc  07be
  31  07c0  07c2  ~  07c  07fe
```
Example

Register #16 = 11H: 64*64 cell

<table>
<thead>
<tr>
<th></th>
<th>0000</th>
<th>0002</th>
<th></th>
<th></th>
<th>007c</th>
<th>007e</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0080</td>
<td>0082</td>
<td></td>
<td></td>
<td>00fc</td>
<td>00fe</td>
</tr>
</tbody>
</table>

64 cell

<table>
<thead>
<tr>
<th></th>
<th>1000</th>
<th>1002</th>
<th></th>
<th></th>
<th>1f7c</th>
<th>1f7e</th>
</tr>
</thead>
<tbody>
<tr>
<td>62</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>63</td>
<td>1f00</td>
<td>1f02</td>
<td></td>
<td></td>
<td>1ffc</td>
<td>1ffe</td>
</tr>
</tbody>
</table>

Example

Register #16 = 03H: 32*128 cell

<table>
<thead>
<tr>
<th></th>
<th>0000</th>
<th>0002</th>
<th></th>
<th></th>
<th>00fc</th>
<th>00fe</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0100</td>
<td>0102</td>
<td></td>
<td></td>
<td>01fc</td>
<td>01fe</td>
</tr>
</tbody>
</table>

32 cell

<table>
<thead>
<tr>
<th></th>
<th>1e00</th>
<th>1e02</th>
<th></th>
<th></th>
<th>10fc</th>
<th>10fe</th>
</tr>
</thead>
<tbody>
<tr>
<td>30</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>31</td>
<td>1f00</td>
<td>1f02</td>
<td></td>
<td></td>
<td>1ffc</td>
<td>1ffe</td>
</tr>
</tbody>
</table>

A value shown in a frame indicates an offset from the Pattern Name Table Base Address.
2. HORIZONTAL SCROLLING

The Display Screen allows for scrolling overall or based on one cell unit, or on a dot by dot basis in one line unit. Either one of the above scrolling can be selected by HSCR and LSCR (Register #11). A setting applies to both Scroll Screens A and B.

<table>
<thead>
<tr>
<th>HSCR</th>
<th>LSCR</th>
<th>FUNCTION</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Overall Scrolling</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Prohibited</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Scroll in one cell unit</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Scroll in one line unit</td>
</tr>
</tbody>
</table>

HSCR, LSCR: Register #11
The effective scroll quantity is equivalent to 10 bits (COOH - 3FFFH).

Taking the Display Screen as standard, the scroll direction will be as follows:

Horizontally scrolling quantity setting area:

H Scroll Data Table is in VRAM. From the base address which was set by Register #13, set the scrolling quantity of Screens A and B alternately. Also, the scrolling quantity data setting position varies depending on the following mode (overall, 1 cell or 1 line).

<table>
<thead>
<tr>
<th>Mode</th>
<th>Setting Position</th>
</tr>
</thead>
<tbody>
<tr>
<td>Overall</td>
<td>Line 0</td>
</tr>
<tr>
<td>1 cell</td>
<td>Every 8th line starting from line 0</td>
</tr>
<tr>
<td>1 line</td>
<td>All lines</td>
</tr>
<tr>
<td>00</td>
<td>A - Scrolling Quantity of Screen A</td>
</tr>
<tr>
<td>02</td>
<td>B - Scrolling Quantity of Screen B</td>
</tr>
<tr>
<td>04</td>
<td>A - Scrolling Quantity of Screen A</td>
</tr>
<tr>
<td>06</td>
<td>B - Scrolling Quantity of Screen B</td>
</tr>
<tr>
<td>08</td>
<td>A - Scrolling Quantity of Screen A</td>
</tr>
<tr>
<td>0A</td>
<td>B - Scrolling Quantity of Screen B</td>
</tr>
<tr>
<td>1C</td>
<td>A - Scrolling Quantity of Screen A</td>
</tr>
<tr>
<td>1E</td>
<td>B - Scrolling Quantity of Screen B</td>
</tr>
<tr>
<td>20</td>
<td>A - Scrolling Quantity of Screen A</td>
</tr>
<tr>
<td>22</td>
<td>B - Scrolling Quantity of Screen B</td>
</tr>
<tr>
<td>3FC</td>
<td>A - Scrolling Quantity of Screen A</td>
</tr>
<tr>
<td>3FE</td>
<td>B - Scrolling Quantity of Screen B</td>
</tr>
</tbody>
</table>

D15-D10 can be freely utilized for program software.
3. VERTICAL SCROLLING

The Display Screen allows for scrolling overall or every 2 cells in a dot unit. The setting can be done by VSCR (Register #11). A setting applies to both Scroll Screens A and B.

<table>
<thead>
<tr>
<th>VSCR</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Overall Scroll</td>
</tr>
<tr>
<td>1</td>
<td>2-Cell Unit Scroll</td>
</tr>
</tbody>
</table>

VSCR: Register #11

The scrolling quantity is equivalent to 11 bits (000H - 7FFH). However, it will be as shown below in the Interface Mode.

Non-Interface: The effective scrolling quantity is equivalent to 10 bits.

Interface 1: Same as above.

Interface 2: The effective scrolling quantity is equivalent to 11 bits.

Taking the Display Screen as standard, the scrolling direction will be as follows:

<table>
<thead>
<tr>
<th>Display Screen</th>
<th>Moving Direction</th>
<th>Scroll Quantity</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Moving Quantity</td>
<td></td>
</tr>
</tbody>
</table>

Set the V-Scroll quantity by VSRAM.

Alternately set the scroll quantity of Screens A and B. Depending on the Scroll Mode, the Data setting positions differ.

<table>
<thead>
<tr>
<th>Mode</th>
<th>Setting Position</th>
</tr>
</thead>
<tbody>
<tr>
<td>Overall</td>
<td>Only at the beginning</td>
</tr>
<tr>
<td>2 cell</td>
<td>Set to all</td>
</tr>
</tbody>
</table>
### 4. SCROLL PATTERN NAME

The Scroll Screen's name table is in VRAM and set by Registers #2 and #4. The Pattern Name requires 2 bytes (1 word) per cell the Scroll Screen. Depending on the Scroll Screen's size, VRAM and Scroll Screen correspond with each other differently. Refer to Scroll Screen Size.

<table>
<thead>
<tr>
<th>pri</th>
<th>cp1</th>
<th>cp0</th>
<th>vl</th>
<th>hf</th>
<th>pt10</th>
<th>pt9</th>
<th>pt8</th>
</tr>
</thead>
<tbody>
<tr>
<td>pt7</td>
<td>pt6</td>
<td>pt5</td>
<td>pt4</td>
<td>pt3</td>
<td>pt2</td>
<td>pt1</td>
<td>pt0</td>
</tr>
</tbody>
</table>

**pri**: Refer to Priority  
**cp1**: Color palette selection bit (see Color Palette)  
**cp0**: Color palette selection bit (see Color Palette)  
**vl**: V Reverse Bit 1: Reverse  
**hf**: H Reverse Bit 1: Reverse  
**pt10 ~ pt0**: Pattern Generator Number

D15-D11 is indefinite.
Reverse bits $vf$ and $hf$ allow for H and V reverse on cell unit basis.

- $vf = 0$
  - $hf = 0$

- $vf = 1$
  - $hf = 0$

- $vf = 0$
  - $hf = 1$

- $vf = 1$
  - $hf = 1$
5. PATTERN GENERATOR

Pattern Generator has VRAM 0000H as base address, and a pattern is expressed on an 8 x 8 dot basis. To define a pattern, 32 bytes are required. Starting from 0000H, it proceeds in the sequence of Pattern Generator 0, 1, 2, etc. The relationship between the display pattern and memory is as follows:

```
  1 2 3 4 5 6 7 8
  a b c d e f g h
```

```
0 00 a1 a2 a3 a4 a5 a6 a7 a8
04 b1 b2 b3 b4 b5 b6 b7 b8
08 c1 c2 c3 c4 c5 c6 c7 c8
0C d1 d2 d3 d4 d5 d6 d7 d8
10 e1 e2 e3 e4 e5 e6 e7 e8
14 f1 f2 f3 f4 f5 f6 f7 f8
18 g1 g2 g3 g4 g5 g6 g7 g8
1C h1 h2 h3 h4 h5 h6 h7 h8
```

The display colors and memory relationship is as follows:

```
D7  D6  D5  D4  D3  D2  D1  D0
   COL3 COL2 COL1 COL0 COL3 COL2 COL1 COL0
```
In Interface Mode 2, one cell consists of 8 x 16 dots and therefore 64 bytes (16 long words) are required.

```
<p>| | | | | | | | |</p>
<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>2</td>
<td>3</td>
<td>4</td>
<td>5</td>
<td>6</td>
<td>7</td>
<td>8</td>
</tr>
<tr>
<td>a</td>
<td>b</td>
<td>c</td>
<td>d</td>
<td>e</td>
<td>f</td>
<td>g</td>
<td>h</td>
</tr>
<tr>
<td>i</td>
<td>j</td>
<td>k</td>
<td>l</td>
<td>m</td>
<td>n</td>
<td>o</td>
<td>p</td>
</tr>
</tbody>
</table>
```

<table>
<thead>
<tr>
<th>D7</th>
<th>D0 D7</th>
<th>D0 D7</th>
<th>D0 D7</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>a1</td>
<td>a2</td>
<td>a3</td>
</tr>
<tr>
<td>04</td>
<td>b1</td>
<td>b2</td>
<td>b3</td>
</tr>
<tr>
<td>08</td>
<td>c1</td>
<td>c2</td>
<td>c3</td>
</tr>
<tr>
<td>0C</td>
<td>d1</td>
<td>d2</td>
<td>d3</td>
</tr>
<tr>
<td>10</td>
<td>e1</td>
<td>e2</td>
<td>e3</td>
</tr>
<tr>
<td>14</td>
<td>f1</td>
<td>f2</td>
<td>f3</td>
</tr>
<tr>
<td>18</td>
<td>g1</td>
<td>g2</td>
<td>g3</td>
</tr>
<tr>
<td>1C</td>
<td>h1</td>
<td>h2</td>
<td>h3</td>
</tr>
<tr>
<td>20</td>
<td>i1</td>
<td>i2</td>
<td>i3</td>
</tr>
<tr>
<td>24</td>
<td>j1</td>
<td>j2</td>
<td>j3</td>
</tr>
<tr>
<td>28</td>
<td>k1</td>
<td>k2</td>
<td>k3</td>
</tr>
<tr>
<td>2C</td>
<td>l1</td>
<td>l2</td>
<td>l3</td>
</tr>
<tr>
<td>30</td>
<td>m1</td>
<td>m2</td>
<td>m3</td>
</tr>
<tr>
<td>34</td>
<td>n1</td>
<td>n2</td>
<td>n3</td>
</tr>
<tr>
<td>38</td>
<td>o1</td>
<td>o2</td>
<td>o3</td>
</tr>
<tr>
<td>3C</td>
<td>p1</td>
<td>p2</td>
<td>p3</td>
</tr>
</tbody>
</table>
J. WINDOW

For Window display, the following registers setting and VRAM areas are required.

Window Pattern Name Table and Base Address

| Register #3 | 0 | 0 | WD15 | WD14 | WD13 | WD12 | WD11 | 0 |

Mode Set Register Number 4

| Register #12 | RS0 | 0 | 0 | 0 | S/TE | LSM1 | LSM0 | RS1 |

Window H Position

| Register #17 | RIGT | 0 | 0 | WH/P5 | WH/P4 | WH/P3 | WH/P2 | WH/P1 |

Window V Position

| Register #18 | DOWN | 0 | 0 | WVP4 | WVP3 | WVP2 | WVP1 | WVPO |

VRAM: Window Pattern Name Table Maximum 4 Kbytes.

1. DISPLAY POSITION

The Window Display Position is designated by Registers #17 and #18. Screen display can be divided on a unit basis of H2 cells and V1 cell. The dividing position varies depending on resolution.

```
0 1 2 3 4 5 34 35 36 37 38 39
0
1
2
```

H 40 cells / V 28 cells mode
<table>
<thead>
<tr>
<th>Register #17</th>
<th>Right (RI)</th>
<th>0</th>
<th>0</th>
<th>WHP5</th>
<th>WHP4</th>
<th>WHP3</th>
<th>WHP2</th>
<th>WHP1</th>
</tr>
</thead>
<tbody>
<tr>
<td>Register #18</td>
<td>Down (DO)</td>
<td>0</td>
<td>0</td>
<td>WVP4</td>
<td>WVP3</td>
<td>WVP2</td>
<td>WVP1</td>
<td>WVP0</td>
</tr>
<tr>
<td>RIGT:</td>
<td>0</td>
<td>Displays Window from the left to H dividing position</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>Displays Window from the H dividing position to the right end.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>DOWN:</td>
<td>0</td>
<td>Displays Window from the top end to the V dividing position.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>1</td>
<td>Displays Window from the V dividing position to the bottom end.</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

WHP5 ~ WHP1: H dividing position  
WVP4 ~ WVP0: V dividing position

**H Resolution** | Dividing Position (WHP)  
--- | ---  
32 cell | 0 ~ 16 (0 ~ 32 cell)  
40 cell | 0 ~ 20 (0 ~ 40 cell)  

**V Resolution** | Dividing Position (WVP)  
--- | ---  
28 cell | 0 ~ 28  
32 cell | 0 ~ 32
Setting Example

Register #17: 000H+01H Window from the left end to the second cell
Register #18: 000H+10H Window from the top end to the 16th cell

Register #17: 80H+02H Window from the left end 4th cell to the right end
Register #18: 80H+01H Window from the 2nd cell to the bottom end
Register #17: 80H+01H  Window from the 4th cell to the right end
Register #18: 00H+10H  Window from the top end to the 16th cell

Display Screen: 40 x 28 Cell Mode

Register #17: 00H+02H  Window to the 4th cell from the left
Register #18: 80H+01H  Window from the 2nd cell to the bottom end

Display Screen: 40 x 28 Cell Mode
2. WINDOW PRIORITY

Window Priority is handled in the same way as in Scroll A. Scroll A is not displayed in the area where Window is displayed. Also, only when Window is set to the left and Scroll A is moved in H direction, the character corresponding to two cells on the right side of the boundary between Window and Scroll A will be disfigured.

There will be no malfunctioning when Window is set to the left side and Scroll A is moved only in the V direction; also when Window is set to the right side.

Display of this portion will be disfigured. Therefore, mask Scroll A by using high priority.
3. WINDOW PATTERN NAME

Window Pattern Name Table is on VRAM, and the base address is designated by Register #13. The Pattern Name, the same as in Scroll Screen, requires 2 bytes (1 word) per cell.

<table>
<thead>
<tr>
<th>Pattern Name</th>
<th>pri</th>
<th>cp1</th>
<th>cp0</th>
<th>vf</th>
<th>hf</th>
<th>pt10</th>
<th>pt9</th>
<th>pt8</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>pt7</td>
<td>pt6</td>
<td>pt5</td>
<td>pt4</td>
<td>pt3</td>
<td>pt2</td>
<td>pt1</td>
<td>pt0</td>
</tr>
</tbody>
</table>

| pri:          | Refer to Priority |
| cp1:          | Color palette selection bit |
| cp0:          | Color palette selection bit |
| vf:           | V reverse Bit 1: Reverse |
| hf:           | H Reverse Bit 1: Reverse |
| pt10~pt0:     | Pattern Generator Number |

Pattern Name and VRAM relation varies depending on H 32 cell/40 cell mode. Pay careful attention to this point.

### H 32 Cell Mode

```
<table>
<thead>
<tr>
<th></th>
<th>0000</th>
<th>0002</th>
<th>0030</th>
<th>0031</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0040</td>
<td>0042</td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td></td>
<td></td>
<td>0760</td>
<td>0762</td>
</tr>
<tr>
<td>31</td>
<td></td>
<td></td>
<td>07C0</td>
<td>07C2</td>
</tr>
</tbody>
</table>
```

- 0030
- 0031
- 007c
- 007e
- 07bc
- 07be
- 07fc
- 07fe
### H 40 Cell Mode

<table>
<thead>
<tr>
<th></th>
<th>0</th>
<th>1</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0000</td>
<td>0002</td>
</tr>
<tr>
<td>1</td>
<td>0080</td>
<td>0082</td>
</tr>
<tr>
<td></td>
<td>004e</td>
<td>0050</td>
</tr>
<tr>
<td></td>
<td>00dc</td>
<td>00e0</td>
</tr>
<tr>
<td>32 cell</td>
<td></td>
<td></td>
</tr>
<tr>
<td>30</td>
<td>0f00</td>
<td>0f02</td>
</tr>
<tr>
<td>31</td>
<td>0fe0</td>
<td>0fe0</td>
</tr>
</tbody>
</table>

Values shown are offset from the Base Address.

In the H40 Cell Mode, there exists the area for H64 cells. However, there will be no display from the 41st cell in the H direction.

In the V28 Cell Mode, there will be no display from the V29th cell, and in the 30th Cell Mode, there will be no display from the 31st cell.

### K. SPRITE

For Sprite Display, the following register setting and VRAM area are required.

**Sprite Attribute Table and Base Address**

<table>
<thead>
<tr>
<th>Register #5</th>
<th>AT 15</th>
<th>AT 14</th>
<th>AT 13</th>
<th>AT 12</th>
<th>AT 11</th>
<th>AT 10</th>
<th>AT 9</th>
</tr>
</thead>
</table>

**Mode Setting Register #4**

<table>
<thead>
<tr>
<th>Register #12</th>
<th>RS0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>S/TE</th>
<th>LSM1</th>
<th>LSM0</th>
<th>RS1</th>
</tr>
</thead>
</table>

**VRAM**: Sprite Attribute Table Maximum 640 Bytes
1. DISPLAY POSITION

Sprite Position and Display Screen are as follows: When Sprite H position is 0, this is in a special mode. Therefore, pay careful attention to this point.

<table>
<thead>
<tr>
<th>Resolution</th>
<th>H Position</th>
<th>Display Area</th>
</tr>
</thead>
<tbody>
<tr>
<td>H32 Cell</td>
<td>001 - 1FFH</td>
<td>080 - 17FH</td>
</tr>
<tr>
<td>H40 Cell</td>
<td>080 - 13FH</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Resolution</th>
<th>V Position</th>
<th>Display Area</th>
</tr>
</thead>
<tbody>
<tr>
<td>V25 Cell</td>
<td>Non-interface</td>
<td>000 - 1FFH</td>
</tr>
<tr>
<td></td>
<td>Interface 1</td>
<td>000 - 3FFH</td>
</tr>
<tr>
<td>V30 Cell</td>
<td>Non-interface</td>
<td>000 - 1FFH</td>
</tr>
<tr>
<td></td>
<td>Interface 1</td>
<td>000 - 3FFH</td>
</tr>
</tbody>
</table>
When 0 is set to the SPRITE H POSITION, a low priority sprite on the same line will not be displayed.

SPRITE PRIORITY: B > A > C > D
2. **SPRITE ATTRIBUTE**

Sprite Attribute Table is on VRAM and the Base Address is designated by Register #5. Attribute requires 8 bytes (4 words) per Sprite, and indicates Display Position, Priority, Sprite Generator Number, and Attribute.

Starting from the beginning of the Attribute Table, numbers are given in the sequence of Sprite 0, Sprite 1, Sprite 2, Sprite 3, etc. Priority between Sprites is not determined by the sequence of Sprite number, but by each Sprite's Link Data, and thus becomes programmable.

\[
\begin{array}{cccccccc}
1st & & & & & & vp9 & vp8 & \text{(D15 - D8)} \\
 & vp7 & vp6 & vp5 & vp4 & vp3 & vp2 & vp1 & \text{(D7 - DC)} \\
2nd & & & \text{hs1} & \text{hs0} & \text{vs1} & \text{vs0} & & \text{(D15 - D8)} \\
 & \text{1d6} & \text{1d5} & \text{1d4} & \text{1d3} & \text{1d2} & \text{1d1} & \text{1d0} & \text{(D7 - D0)} \\
3rd & \text{pri} & \text{cp1} & \text{cp0} & \text{vl} & \text{hf} & \text{sn10} & \text{sn9} & \text{sn8} & \text{(D15 - D8)} \\
 & \text{sn7} & \text{sn6} & \text{sn5} & \text{sn4} & \text{sn3} & \text{sn2} & \text{sn1} & \text{sn0} & \text{(D7 - D0)} \\
4th & & & & & hp9 & hp8 & & \text{hp7} & hp6 & hp5 & hp4 & hp3 & hp2 & hp1 & hp0 & \text{(D7 - DC)} \\
\end{array}
\]

Blank portions can be utilized freely for software.

- **vp9** ~ **vp0**: V position
- **hp8** ~ **hp0**: H position
- **hs1**, **hs0**: Sprite's H Size
- **vs1**, **vs0**: Sprite's V Size
- **1d6** ~ **1d0**: Link Data
- **pri**: Priority Bit (see Priority)
- **cp1**, **cp0**: Color palette selection bit (see Color Palette)
- **vl**: V Reverse Bit 1: Reverse
- **hf**: H Reverse Bit 1: Reverse
- **sn10** ~ **sn0**: Sprite Pattern Generator Number

By using Reverse Bit **vf**, **hf**, V and H Reverse per Sprite is possible.
### 3. SPRITE SIZE

Per Sprite dot number can be set on a cell unit basis, by using vs1, vs0, hs1, and hs0.

<table>
<thead>
<tr>
<th>V</th>
<th>vs1</th>
<th>vs0</th>
<th>Number of cell</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1 (8 dots)</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>2</td>
<td>16 dots</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>3</td>
<td>24 dots</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>4</td>
<td>32 dots</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>H</th>
<th>hs1</th>
<th>hs0</th>
<th>Number of cell</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1 (8 dots)</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>2</td>
<td>16 dots</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>3</td>
<td>24 dots</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>4</td>
<td>32 dots</td>
</tr>
</tbody>
</table>

However, in Interface Mode 2, one cell is comprised of 8 x 16 dots, therefore, the number of V dots is two times (as compared to Interface Mode 1).
4. SPRITE'S DISPLAY CAPACITY

The number of Sprite's maximum display varies depending on H resolution setting.

<table>
<thead>
<tr>
<th>Resolution</th>
<th>No. of Display</th>
<th>No. of Display per Line</th>
<th>Display Dot per Line</th>
</tr>
</thead>
<tbody>
<tr>
<td>H32 cell</td>
<td>Max. 64 Sprites</td>
<td>Max. 16 Sprites</td>
<td>Max. 256 dots</td>
</tr>
<tr>
<td>H40 cell</td>
<td>Max. 80 Sprites</td>
<td>Max. 20 Sprites</td>
<td>Max. 320 dots</td>
</tr>
</tbody>
</table>

Sprite is displayed in the sequential order of Priority.

Example

- With H size 1 cell, when 30 Sprites are intended to be displayed on the same line, up to 16 Sprites counting from the one having highest priority (in the H32 cell mode) and 20 Sprites in the H40 cell mode can be displayed, due to the limitation of display per line.

- With H size 4 cells, when 16 Sprites are intended to be displayed on the same line, up to 8 Sprites, counting from the one having the highest priority (in the H32 cell mode) and 10 Sprites in the H40 cell mode can be displayed, due to the limitation of Display dots.

- With H size 3 cells, when 16 Sprites are intended to be displayed in the same line, 11 Sprites, counting from the one having the highest priority (as for 11th one, however, only for 16 dots from the left end) in the H40 cell mode can be displayed, due to the limitation of the display dots.
5. PRIORITY BETWEEN SPRITES

Priority between Sprites is designated by each Sprite's Link Data.

With Sprite 0 being Priority No. 1, the Sprite No. 2 written in the Link Data there will be Priority No. 2. Priority No. 2 Sprite's Link Data shows Priority No. 3 Sprite. Priority No. 3 Sprite's Link Data shows Priority No. 4 Sprite.

In this way, Priority is sequentially designated by each Sprite's Link Data and thus it is in List form. The value that can be set in the Link Data is 0~ (number of maximum Display on one screen minus one). Be sure to set 0 to the lowest priority Sprite's Link Data.

When 0 is given to the Sprite Link Data, List ends at that Sprite and the Priority will become the lowest. Even in the case that the number of Sprites linked to List is less than the maximum display quantity (64 or 80), the remaining Sprites not linked to Sprite will not be displayed.

When value other than those specified is set to Link Data, or 0 is not set to the lowest Priority Sprite Link Data, ordinary functioning is not guaranteed.
### Setting Example

<table>
<thead>
<tr>
<th>Sprite</th>
<th>Link Data</th>
</tr>
</thead>
<tbody>
<tr>
<td>Sprite 0</td>
<td>2</td>
</tr>
<tr>
<td>Sprite 1</td>
<td>10</td>
</tr>
<tr>
<td>Sprite 2</td>
<td>1</td>
</tr>
<tr>
<td>Sprite 3</td>
<td>4</td>
</tr>
<tr>
<td>Sprite 4</td>
<td>5</td>
</tr>
<tr>
<td>Sprite 5</td>
<td>15</td>
</tr>
<tr>
<td>Sprite 6</td>
<td>—</td>
</tr>
<tr>
<td>Sprite 7</td>
<td>0</td>
</tr>
<tr>
<td>Sprite 8</td>
<td>—</td>
</tr>
<tr>
<td>Sprite 9</td>
<td>—</td>
</tr>
<tr>
<td>Sprite 10</td>
<td>11</td>
</tr>
<tr>
<td>Sprite 11</td>
<td>13</td>
</tr>
<tr>
<td>Sprite 12</td>
<td>—</td>
</tr>
<tr>
<td>Sprite 13</td>
<td>3</td>
</tr>
<tr>
<td>Sprite 14</td>
<td>—</td>
</tr>
<tr>
<td>Sprite 15</td>
<td>7</td>
</tr>
<tr>
<td>Sprite 16</td>
<td>—</td>
</tr>
</tbody>
</table>

The 11 Sprites shown in the Display Priority are displayed on the screen. Sprites No. 6, 8, 9, 12, 14, and 16 onward are not displayed because they are not linked with Link Data List.
6. SPRITE PATTERN GENERATOR

The Sprite Pattern Generator with VRAM 0000H as Base Address expresses one pattern on a basis of 8x8 dots. 32 bytes are required to define one pattern. Every 32 bytes, one pattern is expressed in the sequence of Pattern Generator 0, 1, 2, etc. The relationship of Display Pattern and Memory is the same as in Pattern Generator. Also, Sprite Size and Pattern Generator relationship is as follows:

\[
\begin{array}{|c|c|}
\hline
V1 cell & H1 cell \\
\hline
0 & 1 \\
\hline
V2 cell & H2 cell \\
\hline
0 & 2 \\
1 & 3 \\
\hline
V3 cell & H3 cell \\
\hline
0 & 3 \\
1 & 4 \\
2 & 5 \\
\hline
V4 cell & H4 cell \\
\hline
0 & 4 \\
1 & 5 \\
2 & 6 \\
3 & 7 \\
\hline
\end{array}
\]

4 bytes x 8 rows = 32 bytes/char

\[
\begin{array}{|c|c|}
\hline
V1 cell & H1 cell \\
\hline
0 & 1 \\
\hline
V2 cell & H2 cell \\
\hline
0 & 2 \\
1 & 3 \\
\hline
V3 cell & H3 cell \\
\hline
0 & 3 \\
1 & 4 \\
2 & 5 \\
\hline
V4 cell & H4 cell \\
\hline
0 & 4 \\
1 & 5 \\
2 & 6 \\
3 & 7 \\
\hline
\end{array}
\]

4 bytes x 8 rows = 32 bytes/char

\[
\begin{array}{|c|c|}
\hline
V1 cell & H1 cell \\
\hline
0 & 1 \\
\hline
V2 cell & H2 cell \\
\hline
0 & 2 \\
1 & 3 \\
\hline
V3 cell & H3 cell \\
\hline
0 & 3 \\
1 & 4 \\
2 & 5 \\
\hline
V4 cell & H4 cell \\
\hline
0 & 4 \\
1 & 5 \\
2 & 6 \\
3 & 7 \\
\hline
\end{array}
\]

4 bytes x 8 rows = 32 bytes/char

\[
\begin{array}{|c|c|}
\hline
V1 cell & H1 cell \\
\hline
0 & 1 \\
\hline
V2 cell & H2 cell \\
\hline
0 & 2 \\
1 & 3 \\
\hline
V3 cell & H3 cell \\
\hline
0 & 3 \\
1 & 4 \\
2 & 5 \\
\hline
V4 cell & H4 cell \\
\hline
0 & 4 \\
1 & 5 \\
2 & 6 \\
3 & 7 \\
\hline
\end{array}
\]

4 bytes x 8 rows = 32 bytes/char

\[
\begin{array}{|c|c|}
\hline
V1 cell & H1 cell \\
\hline
0 & 1 \\
\hline
V2 cell & H2 cell \\
\hline
0 & 2 \\
1 & 3 \\
\hline
V3 cell & H3 cell \\
\hline
0 & 3 \\
1 & 4 \\
2 & 5 \\
\hline
V4 cell & H4 cell \\
\hline
0 & 4 \\
1 & 5 \\
2 & 6 \\
3 & 7 \\
\hline
\end{array}
\]

4 bytes x 8 rows = 32 bytes/char

\[
\begin{array}{|c|c|}
\hline
V1 cell & H1 cell \\
\hline
0 & 1 \\
\hline
V2 cell & H2 cell \\
\hline
0 & 2 \\
1 & 3 \\
\hline
V3 cell & H3 cell \\
\hline
0 & 3 \\
1 & 4 \\
2 & 5 \\
\hline
V4 cell & H4 cell \\
\hline
0 & 4 \\
1 & 5 \\
2 & 6 \\
3 & 7 \\
\hline
\end{array}
\]

4 bytes x 8 rows = 32 bytes/char

\[
\begin{array}{|c|c|}
\hline
V1 cell & H1 cell \\
\hline
0 & 1 \\
\hline
V2 cell & H2 cell \\
\hline
0 & 2 \\
1 & 3 \\
\hline
V3 cell & H3 cell \\
\hline
0 & 3 \\
1 & 4 \\
2 & 5 \\
\hline
V4 cell & H4 cell \\
\hline
0 & 4 \\
1 & 5 \\
2 & 6 \\
3 & 7 \\
\hline
\end{array}
\]

4 bytes x 8 rows = 32 bytes/char

\[
\begin{array}{|c|c|}
\hline
V1 cell & H1 cell \\
\hline
0 & 1 \\
\hline
V2 cell & H2 cell \\
\hline
0 & 2 \\
1 & 3 \\
\hline
V3 cell & H3 cell \\
\hline
0 & 3 \\
1 & 4 \\
2 & 5 \\
\hline
V4 cell & H4 cell \\
\hline
0 & 4 \\
1 & 5 \\
2 & 6 \\
3 & 7 \\
\hline
\end{array}
\]

4 bytes x 8 rows = 32 bytes/char

\[
\begin{array}{|c|c|}
\hline
V1 cell & H1 cell \\
\hline
0 & 1 \\
\hline
V2 cell & H2 cell \\
\hline
0 & 2 \\
1 & 3 \\
\hline
V3 cell & H3 cell \\
\hline
0 & 3 \\
1 & 4 \\
2 & 5 \\
\hline
V4 cell & H4 cell \\
\hline
0 & 4 \\
1 & 5 \\
2 & 6 \\
3 & 7 \\
\hline
\end{array}
\]

4 bytes x 8 rows = 32 bytes/char

\[
\begin{array}{|c|c|}
\hline
V1 cell & H1 cell \\
\hline
0 & 1 \\
\hline
V2 cell & H2 cell \\
\hline
0 & 2 \\
1 & 3 \\
\hline
V3 cell & H3 cell \\
\hline
0 & 3 \\
1 & 4 \\
2 & 5 \\
\hline
V4 cell & H4 cell \\
\hline
0 & 4 \\
1 & 5 \\
2 & 6 \\
3 & 7 \\
\hline
\end{array}
\]
L. PRIORITY

Priority between Sprite, Scroll A, and Scroll B can be designated.

Priority can be designated by each Pattern Name and Attribute Priority bit. It will be set for the Scroll Screen on a cell unit basis and for each Sprite. By combining each priority bit, Priority will be as follows, however, the Background Priority is always the lowest.

<table>
<thead>
<tr>
<th>S pri</th>
<th>A pri</th>
<th>B pri</th>
<th>Priority</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>S&gt;A&gt;B&gt;G</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>S&gt;A&gt;B&gt;G</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>A&gt;S&gt;B&gt;G</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>S&gt;A&gt;B&gt;G</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>B&gt;S&gt;A&gt;G</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>S&gt;B&gt;A&gt;G</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>A&gt;B&gt;S&gt;G</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>S&gt;A&gt;B&gt;G</td>
</tr>
</tbody>
</table>

S: Sprite
A: Scroll A
B: Scroll B
G: Background

Also, by combining S/TeN (Register #12) and the above priority, Shadow-Highlight effect function can be utilized.
The above shows Priority situation of Sprite, Scroll A, Scroll B and Background. The dot to which Color Code 0 is designated is transparent. Therefore, either one of Scroll Screen A, Scroll Screen B, or Background (the priority of which is one step lower than the transparent one) will appear.
S/TEN = 1

Sprite Color Palette 0 ~ 3, Color Code 0 ~ 15
Color Palette 3, Color Code 0 ~ 13

STATUS OF SHADOW

Where S/TEN = 1, when the Priority bit of both Scroll A and Scroll B is 0, there will be Shadow. For the color status, refer to the color palette.
S/TEN = 1

Sprite Color Palette 3, Color Code 15

STATUS OF SHADOW

The dots for the Sprite Color Code 15 work as a Shadow operator on the screen, the Priority of which is lower than the Sprite.

Since Sprite dot works as an operator, this will not be displayed.
S/TEN = 1

Sprite Color Palette 3, Color Code 14

The dots of Sprite Color Code 15 work as an operator on the screen, the priority of which is lower than Sprite.

Since Sprite dots work as an operator, this will not be displayed.
When SPRITE is not related to PRIORITY, the following PRIORITY applies:

\[ S/TEN = 0 \]

\[
\begin{array}{c}
\text{A = 0} \\
\text{B = 0}
\end{array}
\]

\[
\begin{array}{c}
\text{A = 0} \\
\text{B = 1}
\end{array}
\]

\[
\begin{array}{c}
\text{A = 1} \\
\text{B = 0}
\end{array}
\]

\[
\begin{array}{c}
\text{A = 1} \\
\text{B = 1}
\end{array}
\]

\[ S/TEN = 1 \]

\[
\begin{array}{c}
\text{A = 0} \\
\text{B = 0}
\end{array}
\]

\[
\begin{array}{c}
\text{A = 0} \\
\text{B = 1}
\end{array}
\]

\[
\begin{array}{c}
\text{A = 1} \\
\text{B = 0}
\end{array}
\]

\[
\begin{array}{c}
\text{A = 0} \\
\text{B = 1}
\end{array}
\]

\text{STATUS OF SHADOW}
M. COLOR PALETTE

One dot is comprised of 4 bits and can designate the 0-15 colors. Also, 0-3 color palette can be designated by Scroll screen on a cell basis and by each Sprite. CRAM data are as follows. Since each of R, G and B has 3 bits, colors can be freely selected out of 512 colors.

```
<table>
<thead>
<tr>
<th>DATA</th>
<th>(D15-D6)</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>G2 G1 G0 O</td>
</tr>
<tr>
<td></td>
<td>(D7-D0)</td>
</tr>
</tbody>
</table>
```

The relationships between CRAM address, palette, and color code are as follows. However, in the case of each palette's color code 0, the color for the Scroll A, Scroll B, Window, and Sprite is See Through irrespective of RGB designation.

<table>
<thead>
<tr>
<th>ADDRESS</th>
<th>BLUE</th>
<th>GREEN</th>
<th>RED</th>
<th>PALETTE</th>
<th>CODE</th>
<th>REMARKS</th>
</tr>
</thead>
<tbody>
<tr>
<td>00H</td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>02H</td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>04H</td>
<td></td>
<td></td>
<td></td>
<td>2</td>
<td>2</td>
<td>The 0-15 colors designated by RGB will be displayed</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1AH</td>
<td></td>
<td></td>
<td></td>
<td>3</td>
<td>13</td>
<td></td>
</tr>
<tr>
<td>1CH</td>
<td></td>
<td></td>
<td></td>
<td>4</td>
<td>14</td>
<td></td>
</tr>
<tr>
<td>1EH</td>
<td></td>
<td></td>
<td></td>
<td>5</td>
<td>15</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>20H</td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>Same as Palette 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>3EH</td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td>15</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>40H</td>
<td></td>
<td></td>
<td></td>
<td>2</td>
<td>0</td>
<td>Same as Palette 0</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5EH</td>
<td></td>
<td></td>
<td></td>
<td>3</td>
<td>15</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>60H</td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>Same as Palette 0</td>
</tr>
<tr>
<td>62H</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7AH</td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td>13</td>
<td>For 14 and 15, refer to Priority</td>
</tr>
<tr>
<td>7CH</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>7EH</td>
<td></td>
<td></td>
<td></td>
<td>2</td>
<td>14</td>
<td></td>
</tr>
</tbody>
</table>

CONFIDENTIAL # 106 PROPERTY OF SEGA
RGB bit and display are as follows:

R OUTPUT
(G & B are the same as R)

STATUS OF SHADOW

STATUS OF HIGHLIGHT

R OUTPUT
(G & B are the same as R)
N. INTERLACE MODE

Raster Scan Mode can be changed by setting LSM0 and LSM1 (RGB #12).

<table>
<thead>
<tr>
<th>LSM1</th>
<th>LSM0</th>
<th>Raster Scan Mode</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Non-Interface mode</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>In the non-interface mode, the same pattern is displayed on the rasters of even and odd numbered files. (Interface 1)</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>In the interface mode, the different pattern is displayed on the rasters of even and odd numbered files. (Interface 2)</td>
</tr>
</tbody>
</table>

In the interface mode and Interface 1, one cell is defined by 8x8 dots and in Interface 2, 8x16 dots. For Display, one cell consists of 8x8 dots in the non-interface mode, and in the interface mode, 8x16 dots.

In any case, number of cells in one screen are the same.

Depending on the type of display, in the case of interface display, there may occur a serious blur in the vertical direction. Therefore, when using the display, pay careful attention in this regard.
III. BACKWARD COMPATIBILITY MODE

In the case of Backward Compatibility Mode, the Mega Drive differs from the original Mark III and Master System in the following points:

A. MARK III (MS-Japan)

**OS-ROM is not incorporated**

ROM cartridge/card selections are made by hardware in the same manner as in the case of Mark III. Start-up slot number is not written in 0C000H. Start-up SEGA logo is not displayed.

**FM sound source is not incorporated**

FM sound is incorporated in MS-Japan (standard) and Mark III (optional) (OPLL), however, Mega Drive has no option for that, although connection is possible.

Consider the Mega Drive's Japanese specifications as that of Mark III with MS-Japan's Joystick Port, or as MS-Japan without FM sound source and OS-ROM.

B. MASTER SYSTEM

**OS-ROM is not incorporated**

0C000H-0DFFFH RAM is not clear on power-up. RAM 0C000 has no meaningful value. Start-up Sega logo is not displayed.

**FM sound source is not incorporated**

FM sound source is incorporated in MS by option (OPLL). However, Mega Drive has no option, although connection is possible. Please regard the Mega Drive overseas version as a Master System without an Operating System ROM.

C. RAM BOARD

In the Mega Drive's Mark III and Master System backward compatibility mode, the RAM board for development (for which D-RAM was used) cannot be used due to the problem of Refresh. The other boards for development (which utilize S-RAM) can be used without any problem.
IV. SYSTEM I/O

Mega Drive System I/O area assignment starts from $A00000$, with the Z80 sub-CPU's memory area.

A. VERSION NUMBER

Indicates the Mega Drive's hardware version.

<table>
<thead>
<tr>
<th>MODE</th>
<th>VMOD</th>
<th>DISK</th>
<th>RSV</th>
<th>VER3</th>
<th>VER2</th>
<th>VER1</th>
<th>VER0</th>
</tr>
</thead>
</table>
| Mode  (R ) | 0: Domestic Model  
1: Overseas Model  
VMOD (R ) | 0: NTSC CPU clock 7.67 MHz  
1: PAL CPU clock 7.60 MHz  
Disk (R ) | 0: FDD unit connected  
1: FDD unit not connected  
RSV (R ) | Currently not used  
VER 3~0 (R ) Mega Drive version is indicated by $30$-$3F$. The present hardware version is indicated by $30$.

B. I/O PORT

The Mega Drive has the three general purpose I/O ports: Ctrl 1, Ctrl 2, and Exp. Although each port differs from the others in physical shape, it functions in the same manner. Each port has the following five registers for control:

- **Data** (Parallel data) R/W
- **Ctrl** (Parallel control) R/W
- **S-Ctrl** (Serial control) R/W
- **TxData** (Txd data) R/W
- **RxData** (Rxd data) R
The relationship between REGISTERS is as follows:

I/O : I/O change
P/S : PARALLEL/Serial MODE change
INT : INTERRUPT CONTROL
S>P : SERIAL-PARALLEL CONVERSION
P>S : PARALLEL-Serial CONVERSION
Mapping is as follows:

$\$A10003 : Data 1 (Ctrl 1)
$\$A10005 : Data 2 (Ctrl 2)
$\$A10007 : Data 3 (Exp)
$\$A10009 : Ctrl 1
$\$A1000B : Ctrl 2
$\$A1000D : Ctrl 3
$\$A1000F : TxData 1
$\$A10011 : RxData 1
$\$A10013 : S-Ctrl 1
$\$A10015 : TxData 2
$\$A10017 : RxData 2
$\$A10019 : S-Ctrl 2
$\$A1001B : TxData 3
$\$A1001D : RxData 3
$\$A1001F : S-Ctrl 3

Both Byte and Word access are possible. However, in the case of Word access, only the lower byte is meaningful.

Data shows the status of each port. The I/O direction of each bit is set by Ctrl and S-Ctrl.

<table>
<thead>
<tr>
<th>DATA</th>
<th>PD7</th>
<th>PD6</th>
<th>PD5</th>
<th>PD4</th>
<th>PD3</th>
<th>PD2</th>
<th>PD1</th>
<th>PD0</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>(RW)</td>
<td>(RW)</td>
<td>(RW)</td>
<td>(RW)</td>
<td>(RW)</td>
<td>(RW)</td>
<td>(RW)</td>
<td>(RW)</td>
</tr>
<tr>
<td></td>
<td>TH</td>
<td>PD2</td>
<td>PD1</td>
<td>PD0</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>TR</td>
<td>PD1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>TL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
**CTRL**

<table>
<thead>
<tr>
<th>CTRL</th>
<th>INT</th>
<th>PC6</th>
<th>PC5</th>
<th>PC4</th>
<th>PC3</th>
<th>PC2</th>
<th>PC1</th>
<th>PC0</th>
</tr>
</thead>
<tbody>
<tr>
<td>INT</td>
<td>(RW)</td>
<td>0: TH-INT Prohibited</td>
<td>1: TH-INT Allowed</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PC6</td>
<td>(RW)</td>
<td>0: PD6 Input Mode</td>
<td>1: PD6 Output Mode</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PC5</td>
<td>(RW)</td>
<td>0: PD5 Input Mode</td>
<td>1: PD5 Output Mode</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PC4</td>
<td>(RW)</td>
<td>0: PD4 Input Mode</td>
<td>1: PD4 Output Mode</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PC3</td>
<td>(RW)</td>
<td>0: PD3 Input Mode</td>
<td>1: PD3 Output Mode</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PC2</td>
<td>(RW)</td>
<td>0: PD2 Input Mode</td>
<td>1: PD2 Output Mode</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PC1</td>
<td>(RW)</td>
<td>0: PD1 Input Mode</td>
<td>1: PD1 Output Mode</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PC0</td>
<td>(RW)</td>
<td>0: PD0 Input Mode</td>
<td>1: PD0 Output Mode</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

S-CTRL is for the status, etc. of each port’s mode change, baud rate, and serial.

**S-CTRL**

<table>
<thead>
<tr>
<th>S-CTRL</th>
<th>BPS1</th>
<th>BPS0</th>
<th>SIN</th>
<th>SOUT</th>
<th>RINT</th>
<th>RERR</th>
<th>RRDY</th>
<th>TFUL</th>
</tr>
</thead>
<tbody>
<tr>
<td>SIN</td>
<td>(RW)</td>
<td>0: TR - Parallel Mode</td>
<td>1: TR - Serial In</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>SOUT</td>
<td>(RW)</td>
<td>0: TL - Parallel Mode</td>
<td>1: TL - Serial Out</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RINT</td>
<td>(RW)</td>
<td>0: Rxd Ready - Interrupt Prohibited</td>
<td>1: Rxd Ready - Interrupt Allowed</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RERR</td>
<td>(R)</td>
<td>0:</td>
<td>1: RxdError</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RRDY</td>
<td>(R)</td>
<td>0:</td>
<td>1: RxdReady</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>TFUL</td>
<td>(R)</td>
<td>0:</td>
<td>1: TxdFull</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>BPS1</th>
<th>BPS0</th>
<th>bps</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>4800</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>2400</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1200</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>300</td>
</tr>
</tbody>
</table>
C. MEMORY MODE

The Mega Drive is able to generate internally the Refresh signal for the D-RAM development cartridge. When using the development cartridge, set to D-RAM mode. In the case of a production cartridge, set to ROM mode.

Only D8 of address $A11000 is effective and for Write only.

$A11000 D8 ( W) 0: ROM mode
1: D-RAM mode

Access to $A11000 can be based on byte.

D. Z80 CONTROL

1. Z80 BusReq

When accessing the Z80 memory from the 68000, first stop the Z80 by using BusReq. At the time of power on reset, the 68000 has access to the Z80 bus.

$A11100 D8 ( W) 0: BusReq cancel
1: BusReq request
(R ) 0: CPU function stop, accessible
1: Functioning

Access to Z80 area in the following manner.

a. Write $0100 in $A11100 by using a Word access.
b. Check to see that D8 of $A11100 becomes 0.
c. Access to Z80 area.
d. Write $0000 in $A11100 by using a Word access.

Access to $A11100 can also be based on byte.

2. Z80 Reset

The 68000 may also reset the Z80. The Z80 is automatically reset during the Mega Drive hardware's power on reset sequence.

$A11200 D8 ( W) 0: Reset request
1: Reset cancel

Access to $A11100 can also be based on byte.
E. Z80 AREA

Mapping is performed starting from $A00000 for Z80, a sub-CPU. As viewed from 68000, the memory map will be as follows:

<table>
<thead>
<tr>
<th>Address</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>$A00000</td>
<td>Sound RAM</td>
</tr>
<tr>
<td>$A02000</td>
<td>Prohibited</td>
</tr>
<tr>
<td>$A04000</td>
<td>Sound Chip</td>
</tr>
<tr>
<td>$A04004</td>
<td>Prohibited</td>
</tr>
<tr>
<td>$A06000</td>
<td>Bank Register</td>
</tr>
<tr>
<td>$A06002</td>
<td>Prohibited</td>
</tr>
<tr>
<td>$A08000</td>
<td>Prohibited</td>
</tr>
</tbody>
</table>

1. Sound RAM
   This is for the Z80 program. Access from 68000 by byte.

2. Sound Chip
   This is the mapping area for FM sound source (YM2612). When accessing from 68000, use byte, due to timing problem.

3. Bank Register
   Access to the 68000-side Memory Area from Z80 will be based on a 32 K byte unit. At this time, this register sets which bank is to be accessed. Registering from 68000 can be set, however, do not access to Z80 Bank Memory Area by 68000.
Setting Method

When accessing to the 68000 side addresses from Z80 side, all the addresses can be classified into Banks. Bank can be set by writing 9 times in 0 bit of 6000 (Z80 address). The 9 bits correspond to 68000 address 15-23 as shown below:
v. VRAM MAPPING

In VRAM, there are various tables and pattern generators as stated below. Among those, the base address of Pattern Generator Table and Sprite Generator Table are 0000H and fixed. However, the other base addresses can be freely assigned in VRAM by setting VDP Register. Also, Area can be overlapped, therefore, Table can be commonly used by Scroll screen and Window, for example.

- Scroll A Pattern Name Table, maximum 8 K byte
  Base address designated by Register #2.
- Scroll B Pattern Name Table, maximum 8 K byte
  Base address designated by Register #4.
- Window Pattern Name Table, varies by H resolution
  Base address designated by Register #3.
- H Scroll Data Table, 1 K byte
  Base address designated by Register #13.
- Sprite Attribute Table, varies by H resolution
  Base address designated by Register #5.
- Pattern Generator Table
  Base address is 0000H (fixed).
- Sprite Generator Table
  Base address is 0000H (fixed).

There are 1 K bytes for H Scroll Table, however, as for display 896 bytes in V28 Cell Mode and 960 bytes in V30 Cell Mode. There are 2 K bytes for Window Pattern Name Table in H32 Cell Mode, and 4 K byte area in H40 Cell Mode. For details, refer to Window. There are 512 bytes for Sprite Attribute Table in H32 Cell and 1 K byte area in H40 Cell Mode. However, as for display, there are 640 bytes in H40 Cell Mode.

Setting examples

H32 Cell Mode

- Scroll A Pattern Name Table
  8 K bytes from 0C000H: Register #2 = $30
- Scroll B Pattern Name Table
  8 K bytes from 0E000H: Register #4 = $07
- Window Pattern Name Table
  2 K bytes from 08000H: Register #3 = $2C
- H Scroll Data Table
  1 K byte from 0B800H: Register #13 = $2E
- Sprite Attribute Table
  512 bytes from 0BE00H: Register #5 = $5F
Unoccupied area is used as Pattern Generator and Sprite Generator.

<table>
<thead>
<tr>
<th>Address</th>
</tr>
</thead>
<tbody>
<tr>
<td>00000H</td>
</tr>
</tbody>
</table>
| 0B000H  | WINDOW
| 0B800H  | H SCROLL
| 0BE00H  | SPRITE ATTRIBUTE
| 0C000H  | SCROLL A
| 0E000H  | SCROLL B
H40 Cell Mode

- Scroll A Pattern Name Table
  8 K bytes from 0C000H: Register #2 = $30

- Scroll B Pattern Name Table
  8 K bytes from 0E000H: Register #4 = $07

- Window Pattern Name Table
  4 K bytes from 0B000H: Register #3 = $2C

- H Scroll Data Table
  2 K bytes from 0AC00H: Register #13 = $2B

- Sprite Attribute Table
  1 K byte from 0A800H: Register #5 = $54

Unoccupied area is used as Pattern Generator and Sprite Generator.
Precautions for M5 Software Programming

When programming the M5 software, pay attention to the following:

1. The program code DMA (RAM, ROM→VRAM, CRAM, VSRAM) should be resident in RAM or it should be as in LIST1 for example. However, in either one of the above two cases, a long word access is not possible as regards the last VRAM address set.

2. ID should be as in the next page.

3. Put LIST2 at your program's start. This is the U.S. security software.

LIST 1

DMA-RAM:

lea
; vdp_cmd = $c00000
; An = Address Register

; Set source Address to VDP Register
; Set Data Length to VDP Register
move.1 xx,ram0
; xx: Destination Address
; ram0: Work RAM
move.w ram0, (An)
move.w ram0+2, (An)

; Pay careful attention to the sequential order of
1st word and 2nd word.
Destination Address should be set by Word and
not by Long Word.

LIST 2

move.b $a10001.d0
andi.b #$01,d0
beq.b ?0
move.1 #$'SEGA'$, $a14000

?0:

; Get version number
; If not version #0
; Output ASCII
ROM Cartridge Data For Mega Drive

Write in ROM's 100H-1FFH

100H: 'SEGA MEGA DRIVE ' 1
110H: '(C) SEGA 1988.JUL' 2
120H: Game Name (domestic) 3
150H: Game Name (overseas) 4
180H: 'GM XXXXXXX-XX' 5
18EH: $XXXX 6
190H: Control Data 7
1A0H: $000000, $XXXXXX 8
1AH: $FF0000, $FFFFFF 9
1B0H: External RAM Data 10
1BCH: Mode Data 11
1CH: Memo 12
1FOH: Country in which the product can be released 13

1: SEGA, system name and Title in common with all ROMs.
2: Copyright notice and year/month of release (firm name in ASCII, 4 character).
3: Game name for domestic (JIS KANJI Code o.k.).
4: Game name for overseas market (JIS KANJI Code o.k.).
5: Type of cartridge and products, number, version number:
   Type     Game: GM
   Education: A
   Number     Product No.
   Version Data varies depending on the type of ROM or software version

6. Check Sum

7. I/O use support data
   Joystick for MS  : 0
   Joystick       : J
   Keyboard       : K
   Serial (RS232C) : R
   Printer        : P
   Tablet         : T
   Control Ball   : B
   Paddle Controller : V
   FDD            : F
   CDROM          : C

8. ROM Capacity  Start Address, End Address

9. RAM Capacity  Start Address, End Address
10. When no external RAM is mounted, fill the address by a space code; when it is mounted, do the following:

$1B0H$: dc.b 'RA',%1x1yz000,%00100000

$x$ 1 for Backup and 0 if not Backup

$yz$ 10 if even address only, 11 if odd address only

$1B4H$: dc.1 RAM start address, RAM end address

11. If corresponding to modem, fill it by space code; if not, do the following:

$1BCH$: dc.b 'MO',xxxx',yy.z'

$xxxx$ Firm name, the same as in 2

$yy$ Modem number

$z$ Version

13. Data on the countries in which the product can be released:

Japan : J

USA : U

Europe : E

Be sure to input a space code in the unoccupied 1-7, 9-13 space.
How to Obtain a Check Sum

The Check Sum obtaining program is shown as follows. The program starts with 0FF8000H, RAM space.

First, fill game capacity by -1 (OFFH) and then load all of the programs. Next, load the Check Sum program and run the program from 0FF8000H.

After a while, stop running the program. At this time, the lower Word of Data Register 0 (d0) is the Check Sum value. Note that Break in Memory should be cancelled in advance.

Also, when burn-ins to ROM, first fill the game capacity by -1 (OFFH).

```
end_addr equ $1a4
org -$8000

start:
move,1 (a0),d1
addq,1 #$1,d1
movea,1 #200,a0
sub,1 a0,d1
asl,1 #1,d1 ; counter
move d1,d2
subq,w #$1,d2
swap d1
moveq #$0,d0

?12:
add (a0)+,d0
dbra d2,?12
dbra d1,?12
nop
nop
nop
nop
nop
nop
nop
nop

?1e:
nop
nop
bra.b ?1e
```
Memory Mapping for Emulation

For the 68000 Emulation

All address should be disabled initially: 0 to 0FFFFFF

Required areas should then be enabled as follows:

1. Program and Data are in 0 to 007FFFF
2. S-RAM is for Z80 in 0A00000 to 0A01FFF
3. FM sound chip interface is in 0A04000 to 0A04FFF
4. I/O and Z80 control port are in 0A10000 to 0A11FFF
5. VDP and sound control port are in 0C00000 to 0C00FFF
6. Scratch RAM is in 0FF0000 to 0FFFFFF

RAM Card (No. 171-5642-02)

This board has two memory areas:

Main Memory (D-RAM) $000000 - $0FFFFF
Backup Memory (S-RAM) $200000 - $203FFF

1. Initialize
   Write 0100H into $0A1000
   Write 1 into $0A130F0
   (Green LED light up)

2. Write Protect
   Write 3 into $0A130F0
   (Red LED light up)

3. Read/Write
   Write 1 into $0A130F0
   (Red LED turns off)

4. Note: Emulator access to these ports should be enabled before the writes, then disabled after words.
### Mega Drive Registers Fixed Bits (40 Cell and NTSC Mode)

<table>
<thead>
<tr>
<th>RO</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>0</th>
<th>1</th>
<th>0</th>
<th>0</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>3</td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>4</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>6</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>0</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>9</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>10</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>11</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>12</td>
<td>1</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>1</td>
</tr>
<tr>
<td>13</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>14</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>15</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>16</td>
<td>0</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>17</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>18</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>19</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>20</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>21</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>22</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>23</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

* DMA cannot be performed emulated ROM or RAM on most ICEs.
GENESIS

SOUND SOFTWARE MANUAL
INDEX

I. Z80 MAPPING
   A. Z80 Memory Map
   B. Interrupt

II. 68K CONTROL OF Z-80
   A. Z80 Start-up
   B. Z80 Handshake

III. FM SOUND CONTROL
     A. 68K Access FM Chip
     B. Z80 Access FM Chip

IV. PSG CONTROL

V. D/A CONTROL

This manual explains memory mapping and way of accessing especially. FM sound generation and PSG are explained in another manual.
SUPPLEMENTARY INDEX

I. FM AUDIO – YM2612
   A. Overview
   B. A little bit about operators
   C. Register Overview
   D. Envelope Specification
   E. Part 1 Memory Map
   F. Test Program

II. PROGRAMMABLE SOUND GENERATOR (PSG)
    A. Tone Generator Frequency
    B. Noise Generator Control
    C. Attenuators
I. Z80 MAPPING

A. Z80 Map
   We show the memory at right.
   I/O is contained in memory map.

1. Program Area
   Program, data and scratch are in 0 to 1FFFFH in S-RAM.

2. BANK
   From 8000H-FFFFH is window of 68K memory. Z-80 can access
   all of 68K memory by BANK switching. BANK select data
   create 68K address from A15 to A23. You must write these
   9 bits one at a time into 6000H serially, byte units, 7F11
   using the LSB.

3. I/O
   4000H  FM1 register select (Channel 1-3)
   4001H  FM1 DATA
   4002H  FM2 register select (Channel 4-6)
   4003H  FM2 DATA
   FSG address is in 7F11H.

B. Interrupt
   Z-80 gets the only VIDEO vertical interrupt. This interrupt is generated 16ms period and
   64ms length.
II. 68K CONTROL OF Z-80

A. Z80 Start-Up

Z-80 Operation Sequence:
1. BUS REQ ON
2. BUS RESET OFF
3. 68K copies program into Z-80 S-RAM
4. BUS RESET ON
5. BUS REQ OFF
6. BUS RESET OFF

---

**BUS REQUEST**

- BUS REQ ON
  DATA 100H (WORD) → $A1100

- BUS REQ OFF
  DATA 0H (WORD) → $A1100

---

**RESET Z-80**

- RESET ON
  DATA 0H (WORD) → $A11200

- RESET OFF
  DATA 100H (WORD) → $A11200

  This period requires 25ms.
  Also FM sound source is cleared at the same time.

---

**CONFIRMATION OF BUS STATUS**

This information is in $A11000, bit 0.

0 - Z-80 is using
1 - 68K can access
B. Z80 Handshake
If you access the HANDSHAKE area (A00000 - A07FFF) you must use BUS REQ. 68K
has to access the Z-80 S-RAM by byte.

III. FM SOUND CONTROL
A. 68K Accesses the FM Source
68K needs BUS REQ when accessing the FM source, because this memory is controlled
by Z-80.

B. Z80 Accesses the FM Source
Z-80 normally controls the FM (4000H - 4003H).

IV. PSG CONTROL
PSG accepts access of 68K and Z-80 any time, but you have to coordinate 68K and Z-80
accesses.

PSG is in $C00011 from 68K and in 7F11H from Z-80.
OVERVIEW

The Yamaha 2612 Frequency Modulation (FM) sound synthesis IC resembles the Yamaha 2151 (used in SEGA's coin-operated machines) and the chips used in Yamaha's synthesizers.

Its capabilities include:
- 6 channels of FM sound
- An 8-bit Digitized Audio channel (as replacement for one of the FM channels)
- Stereo output capability
- One LFO (low frequency oscillator) to distort the FM sounds
- 2 timers, for use by software.

To define these terms more carefully, an FM channel is capable of expressing, with a high degree of realism, a single note in almost any instrument's voice. Chords are generally created by using multiple FM channels.

The standard FM channels each have a single overall frequency and data for how to turn this frequency into the complex final waveform (the voice). This conversion process uses four dedicated channel components called "operators," each possessing a frequency (a variant of the overall frequency), an envelope, and the capability to modulate its input using the frequency and envelope. The operator frequencies are offsets of integral multiples of the overall frequency.

There are two sets of three FM channels, named channels 1 to 3 and 4 to 6, respectively. Channels 3 and 6, the last in each set, have the capability to use a totally separate frequency for each operator rather than offsets of integral multiples. This works well (we believe) for percussion instruments, which have harmonics at odd multiples such as 1.4 or 1.7 of the fundamental.

The 8-bit Digitized Audio Channel (DAC) exists as a replacement of FM channel 6, meaning that turning on the DAC turns off FM channel 6. Unfortunately, all timing must be done by software — meaning that unless the software has been very cleverly constructed, it is impossible to use any of the FM channels at the same time as the DAC.

Stereo output capability means that any of the sounds, FM or DAC, may be directed to the left, the right, or both outputs. The stereo is output only through the headphone jack.

The LFO, or Low Frequency Oscillator, allows for amplitude and/or frequency distortions of the FM sounds. Each channel decides the degree to which it will be distorted by the LFO, if at all. This could be used, for example, in a guitar solo.

Finally, the system has two software timers which may be used as an alternative to the 780 VBLANK interrupt. Unfortunately, these two timers do not cause interrupts — they must be read by the software to determine if they have finished counting.
A LITTLE BIT ABOUT OPERATORS

There are four dedicated operators assigned to every channel, with the following properties:

- An operator has an input, a frequency and an envelope (with which to modify the input), and an output.

- The operators have two types: those whose outputs feed into another operator, and those that are summed to form the final waveform. The latter are called "slots."

- The slots may be independently enabled, although Sega's software always enables or disables them all simultaneously.

- Operator one may feed back into itself, resulting in a more complex waveform.

These operators may be arranged in eight different configurations, called "algorithms." Following is a diagram of the algorithms.
SLOTS ARE INDICATED BY SHADING

Algorithm 0 - distortion, guitar, "high hat-chopper" (?) bass
Algorithm 1 - harp, PSG (Programmable Sound Generator) sound
Algorithm 2 - Bass, electric guitar, brass, piano, woods
Algorithm 3 - strings, folk guitar, chimes
Algorithm 4 - flute, bells, chorus, bass drum, snare drum, tom-tom
Algorithm 5 - brass, organ
Algorithm 6 - xylophone, tom-tom, organ, vibraphone, snare drum, base drum
Algorithm 7 - pipe organ
REGISTER OVERVIEW

The system is controlled by means of a large number of registers. General system registers are:

- timer values and status, software use
- LFO enable and frequency, to distort the FM channels
- DAC enable and amplitude
- output enables for each of the six FM channels
- number of frequencies to be used in FM channels 3 and 6.

Usually, an FM channel has only one overall frequency, but if so elected, FM channels 3 and 6 use four separate frequencies, one for each operator.

The remainder of the registers apply to a single FM channel, or to an operator in that channel. Registers that refer to the channel as a whole are:

- frequency number (in the standard case)
- algorithm number
- extent of self-feedback in operator 1
- output type, to L, R, or both speakers. This can only be heard if headphones are used.
- the extent to which the channel is distorted by the LFO.

Registers that refer to each operator make up the remainder. The four operators' connections are determined by the algorithm used, but the envelope is always specified individually for each operator. In the case of FM channels 3 and 6, the frequency may be specified individually for each operator.
ENVELOPE SPECIFICATION

The sound starts when the key is depressed, a process called "key on." The sound has an attack, a strong primary decay, followed by a slow secondary decay. The sound continues this secondary decay until the key is released, a process called "key off." The sound then begins a rapid final decay, representing, for example, a piano note, after the key has been released and the damper has come down on the strings.

The envelope is represented by the above amplitudes and angles, and a few supplementary registers. Used in the above diagram are:

- **TL** — Total level, the highest amplitude of waveform.
- **AR** — Attack rate, the angle of initial amplitude increase. This can be made very steep if desired. The problem with slow attack rates is that if the notes are short, the release (called "key off") occurs before the note has reached a reasonable level.
- **DIR** — The angle of initial amplitude decrease.
- **T1L** — The amplitude at which the slower amplitude decrease starts.
- **D2R** — The angle of secondary amplitude decrease. This will continue indefinitely unless "key off" occurs.
- **RR** — The final angle of amplitude decrease, after "key off."

Additional registers are:

- **RS** — Rate scaling, the degree to which envelopes become shorter as frequencies become higher. For example, high notes on a piano fade much more quickly than low notes.
AM — Amplitude Modulation enable, whether or not this operator will allow itself to be modified by the LFO. Changing the amplitude of the slots changes the loudness of the note; changing the amplitude of the other operators changes its flavor.

SSG-EG — A proprietary register whose usage is unknown. It should be set to zero.

The FM-2612 may be accessed from either the 68000 or the Z-80. In both cases, however, the bus is only 8 bits wide.

The FM-2612 is accessed through memory locations 4000H - 4033H in the Z80 case, or A04000H - A04033H in the 68000 case. These will be referred to as 4000 to 4003.

The internal registers of the FM-2612 are divided as follows:

```
PART I
21H  LFO TIMERS
2CH  KEY ON/OFF
30H  DAC
B6H  FM CHANNELS
     1-3

PART II
30H  FM CHANNELS
B6H  4-6
```

To write to Part I, write the 8-bit address to 4000 and the data to 4001. To write to Part II, write the 8-bit address to 4002 and the data to 4003.

Caution: Before writing, read from any address to determine if the YM-2612 I/O is still busy from the last write. Delay until Bit 7 returns to 0.

Caution: In the case of registers that are "ganged together" to form a longer number — for example the 10-bit Timer I value or the 14-bit frequencies — write the high register first.

READ DATA: Reading from any of the four locations.

```
<table>
<thead>
<tr>
<th>DT</th>
<th>D0</th>
</tr>
</thead>
<tbody>
<tr>
<td>BUSY</td>
<td>X</td>
</tr>
</tbody>
</table>
```

BUSY — 1 if busy, 0 if ready for new data.
OVERFLOW — 1 if the timer has counted up and overflowed. See Register 27H.
PART I MEMORY MAP

<table>
<thead>
<tr>
<th>22H</th>
<th>24H</th>
<th>25H</th>
<th>26H</th>
<th>27H</th>
<th>28H</th>
<th>29H</th>
</tr>
</thead>
<tbody>
<tr>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>LFO EN</td>
<td>LFO FREQ</td>
<td>TIMER A</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>TIMER B</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>CH3</td>
<td>RESET</td>
<td>ENABLE</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>MODE</td>
<td>B</td>
<td>A</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td>OPERATOR</td>
<td>X</td>
<td>CHANNEL</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>2BH</td>
<td>2BH</td>
<td>2BH</td>
<td>2BH</td>
<td>2BH</td>
<td>2BH</td>
<td>2BH</td>
</tr>
<tr>
<td>DAC EN</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>30H+</th>
<th>31H+</th>
<th>32H+</th>
<th>33H+</th>
<th>34H+</th>
<th>35H+</th>
<th>36H+</th>
<th>37H+</th>
<th>38H+</th>
<th>39H+</th>
<th>3AH+</th>
<th>3BH+</th>
<th>3CH+</th>
<th>3DH+</th>
<th>3EH+</th>
</tr>
</thead>
<tbody>
<tr>
<td>X</td>
<td>DT1</td>
<td>MUL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>X</td>
<td>TL</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RS</td>
<td>X</td>
<td>AR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AM</td>
<td>X</td>
<td>X</td>
<td>D1R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>X</td>
<td>X</td>
<td>X</td>
<td>D2R</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td>D1L</td>
<td></td>
<td>RR</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>X</td>
<td>X</td>
<td>X</td>
<td>X</td>
<td>AGG EQ</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Each of 30H-90H has twelve entries, three channels x four operators.

Channels 1-3 become channels 4-6 in Part II.

PART I MEMORY MAP (cont.)

<table>
<thead>
<tr>
<th>40H+</th>
<th>41H+</th>
<th>42H+</th>
<th>43H+</th>
<th>44H+</th>
<th>45H+</th>
<th>46H+</th>
<th>47H+</th>
<th>48H+</th>
<th>49H+</th>
<th>4AH+</th>
<th>4BH+</th>
<th>4CH+</th>
<th>4DH+</th>
<th>4EH+</th>
</tr>
</thead>
<tbody>
<tr>
<td>X</td>
<td>X</td>
<td>BLOCK</td>
<td>FREQ. NUM</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CH 3 SUPPLEMENTARY FREQ. NUM</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CH 3 SUPP</td>
<td>FREQ NUM</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CH 3 SUPP BLOCK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>CH 3 SUPP FREQ NUM</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>FEEDBACK</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>ALGORITHM</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>AMS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>X</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>FMS</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Each of the above has three entries. All follow the pattern

<table>
<thead>
<tr>
<th>A0H</th>
<th>CH1</th>
</tr>
</thead>
<tbody>
<tr>
<td>A1H</td>
<td>CH2</td>
</tr>
<tr>
<td>A2H</td>
<td>CH3</td>
</tr>
</tbody>
</table>

with the exception that A8H and ACH follow the pattern

<table>
<thead>
<tr>
<th>A8H</th>
<th>CH3, OP2</th>
</tr>
</thead>
<tbody>
<tr>
<td>A9H</td>
<td>CH5, OP3</td>
</tr>
<tr>
<td>AAH</td>
<td>CH3, OP4</td>
</tr>
</tbody>
</table>

"PART II" is a duplication of 30H-B4H, where channels 1-3 are replaced by 4-6.

The Registers:

| 22H | X | X | X | X | LFO EN | LFO FREQ |

LFO EN — 1 is enabled, 0 disabled.

LFO FREQ

<table>
<thead>
<tr>
<th></th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
</tr>
</thead>
<tbody>
<tr>
<td>Hz</td>
<td>3.98</td>
<td>5.56</td>
<td>6.02</td>
<td>6.83</td>
<td>6.88</td>
<td>9.63</td>
<td>48.1</td>
<td>72.2</td>
</tr>
</tbody>
</table>

The LFO (Low Frequency Oscillator) is used to distort the FM sounds' amplitude and phase. It is triply enabled, as there is:

a. a global enable in Register 22H
b. a sensitivity enable on a channel by channel basis, in Registers B4H-B6H
c. an amplitude enable on an operator by operator basis in Registers 60H-6EH.

If the LFO is desired, enable it by Register 22H. Next, select which channels will be affected by the LFO, to what degree, and whether their amplitude or frequency is affected, by setting Registers B4H-B6H. Finally, if a channel's amplitude is affected, make sure that it is only the "slots" that are affected by setting Registers 60H-6EH.

<table>
<thead>
<tr>
<th>24H</th>
<th>TIMER A MS8s</th>
</tr>
</thead>
</table>

| 25H | X | X | X | X | X | X | X | TIMER A LSB8s |

Genesis Sound Software Manual
February 21, 1992

CONFIDENTIAL # 106 PROPERTY OF SEGA
Registers 24H and 25H are ganged together to form 10-bit TIMER A, with Register 25H containing the least significant bits. They should be set in the order 24H, 25H. The timer lasts

18° (1024 - TIMER) microseconds

TIMER A = all 1's → 8µs = 0.108 ms
TIMER A = all 0's → 8,400µs = 8.4 ms

8-bit TIMER B lasts

256 * (256 - TIMER B) microseconds

TIMER B = all 1's = 0.268 ms
TIMER B = all 0's = 0.44 ms

<table>
<thead>
<tr>
<th>CH3 MODE</th>
<th>RESET</th>
<th>ENABLE</th>
<th>LOAD</th>
</tr>
</thead>
<tbody>
<tr>
<td>B A</td>
<td>B A</td>
<td>B A</td>
<td></td>
</tr>
</tbody>
</table>

Register 27H controls the software timers and the Channel 3 (and 5) mode, two entirely separate items.

<table>
<thead>
<tr>
<th>CH3 MODE</th>
<th>D7</th>
<th>D6</th>
</tr>
</thead>
<tbody>
<tr>
<td>NORMAL</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>SPECIAL</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>ILLEGAL</td>
<td>1</td>
<td>X</td>
</tr>
</tbody>
</table>

A normal channel’s operators use offsets of integral multiples of a single frequency. In SPECIAL mode, each operator has an entirely separate frequency. Channel 3 operator 1’s frequency is in Registers A2 and A6. Operators 2 and 4 are in Registers A8 and AC, A9 and AD, and AA and AE, respectively.

No one at Sega has used the timer feature, but the Japanese manual says:

LOAD 1 starts the timer, 0 stops it.

ENABLE 1 causes timer overflow to set the read register flag. 0 means the timer keeps cycling without setting the flag.

RESET writing a 1 clears the read register flag, writing a 0 has no effect.
This register is used for "key on" and "key off." "Key on" is the depression of the synthesizer key. "Key off" is its release. The sequence of operations is: set parameters, key on, wait, key off. When key off occurs, the FM channel stops its slow decline and starts the rapid decline specified by "RR", the release rate.

In a single write to Register 28H, one sets the status of all operators for a single channel. Sega always sets them to the same value, on (1) or off (0). Using a special channel 3, I believe it is possible to have each operator be a separate note, so there is possible justification for turning them on and off separately.

<table>
<thead>
<tr>
<th>OPERATOR</th>
<th>X</th>
<th>CHANNEL</th>
</tr>
</thead>
<tbody>
<tr>
<td>4</td>
<td>3</td>
<td>2</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>D2</th>
<th>D1</th>
<th>D0</th>
<th>Channel</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>Channel 1</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>2</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>3</td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>Channel 4</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>5</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>6</td>
</tr>
</tbody>
</table>

2AH  
DAC DATA

Register 2AH contains 8 bit DAC data.

2BH  
DAC EN  

X  X  X  X  X  X  X

If the DAC enable is 1, the DAC data is output as a replacement for channel 6. The only channel 6 register that affects the DAC is the stereo output portion of Register B4H.

Registers 30H-90H are all single-operator registers. Please see page 8 for how the twelve channel-operator combinations are arranged.

30H+  
DT1  MUL

Both DT1 (Detune) and MUL (multiple) relate the operator's frequency to the overall frequency.

MUL ranges from 0 to 15, and multiplies the overall frequency, with the exception that 0 results in multiplication by 1/2. That is, MUL = 0 to 15 gives x 1/2, x 1, x 2, ... x 15.

DT1 gives small variations from the overall frequency x MUL. The MSB of DT1 is a primitive sign bit, and the two LSBs are magnitude bits. See the next page for a diagram.
### Table: Multiplicative Effect

<table>
<thead>
<tr>
<th>D6</th>
<th>D5</th>
<th>D4</th>
<th>Multiplicative Effect</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>No change</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>x (1 + E)</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>x (1 + 2E)</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>x (1 + 3E)</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>No change</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>x (1 - E)</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>x (1 - 2E)</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>x (1 - 3E)</td>
</tr>
</tbody>
</table>

where E is a small number.

TL (total level) represents the envelope's highest amplitude, with 0 being the largest and 127 the smallest. A change of one unit is about 0.75 dB.

To make a note softer, only change the TL of the slots (the output operators). Changing the other operators will affect the flavor of the note.

50H: \[ \text{RS} \times \text{AR} \]

Register 50H contains RS (rate scaling) and AR (attack rate). AR is the steepness of the initial amplitude rise, shown on page 4.

RS affects AR, D1R, D2R, and RR in the same way. RS is the degree to which the envelope becomes narrower as the frequency becomes high.
The frequency's top five bits (3 octave bits and 2 note bits) are called KC (key code) in the following rate formulas:

RS=0 \ \Rightarrow \ \text{Final Rate} = 2 \ \times \ \text{Rate} + (\text{KC}/8)
RS=1 \ \Rightarrow \ \text{Final Rate} = 2 \ \times \ \text{Rate} + (\text{KC}/4)
RS=2 \ \Rightarrow \ \text{Final Rate} = 2 \ \times \ \text{Rate} + (\text{KC}/2)
RS=3 \ \Rightarrow \ \text{Final Rate} = 2 \ \times \ \text{Rate} + \text{KC}**

** Always rounded down.

As rate ranges from 0-31, this means that the RS influence ranges from small (at 0-3) to very large (at 0-31).

```
60H+ AM X X D1R
```

D1R (first decay rate) is the initial step amplitude decay rate (see page 4). It is, like all rates, 0-31 in value and affected by RS.

AM is the amplitude modulation enable, whether or not this operator will be subject to amplitude modulation by the LFO. This bit is not relevant unless both the LFO is enabled and Register B4's AMS (amplitude modulation sensitivity) is non-zero.

```
70H+ X X X D2R
```

D2R (secondary decay rate) is the long tailoff of the sound that continues as long as the key is depressed.

```
90H+ X X X X SSG-EG
```

This register is proprietary and should be set to zero.

The final registers relate mostly to a single channel. Each register is tripled, please see the diagram on page 9.

```
AOH+ FREQ NUM
```

```
A4H+ X X BLOCK FREQ NUM
```

```
A8H+ CH 3 SUPP FREQ NUM
```

```
ACH+ X X CH 3 SUPP BLOCK CH 3 SUPP FREQ NUM
```
Channel 1's frequency is in A0 and A4H.
Channel 2's frequency is in A1 and A5H.
Channel 3, if it is in normal mode (please see page 12) is in A2 and A6H.

If channel 3 is in special mode:
Operator 1's frequency is in A2 and A6H
Operator 2's frequency is in A8 and ACH
Operator 3's frequency is in A9 and ADH
Operator 4's frequency is in AA and AEH.

The frequency is a 14-bit number that should be set high byte, low byte (e.g., A4H then A0H). The highest 3 bits, called the "block," give the octave. The next 10 bits give position in the octave, and a possible 12-tone sequence is:

<table>
<thead>
<tr>
<th>Low</th>
<th>617</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>653</td>
</tr>
<tr>
<td></td>
<td>692</td>
</tr>
<tr>
<td></td>
<td>733</td>
</tr>
<tr>
<td></td>
<td>777A10</td>
</tr>
<tr>
<td></td>
<td>823</td>
</tr>
<tr>
<td></td>
<td>872</td>
</tr>
<tr>
<td></td>
<td>924</td>
</tr>
<tr>
<td></td>
<td>979</td>
</tr>
<tr>
<td></td>
<td>1037</td>
</tr>
<tr>
<td></td>
<td>1099</td>
</tr>
<tr>
<td>High</td>
<td>1164</td>
</tr>
</tbody>
</table>

This sequence should be used inside each octave.

<table>
<thead>
<tr>
<th>B4H+</th>
<th>X</th>
<th>FEEDBACK</th>
<th>ALGORITHM</th>
</tr>
</thead>
</table>

Feedback is the degree to which operator 1 feeds back into itself. In the voice library, self feedback is represented as this:

The ALGORITHM is the type of inter-operator connection used. Please see the list of the eight operators on page 3.

<table>
<thead>
<tr>
<th>B4H+</th>
<th>L</th>
<th>R</th>
<th>AMX</th>
<th>X</th>
<th>FMS</th>
</tr>
</thead>
</table>

Register B4H contains stereo output control and LFO sensitivity control.

L — Left output, 1 is on, 0 is off
R — Right output, 1 is on 0 is off

Note: The stereo may only be heard by headphones.
AMS (amplitude modulation sensitivity) and FMS (frequency modulation sensitivity) are the degree to which the channel is affected by the LFO. If the LFO is disabled, this register need not be set. Additionally, amplitude modulation is also enabled on an operator-by-operator level.

<table>
<thead>
<tr>
<th>AMS</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
</tr>
</thead>
<tbody>
<tr>
<td>dB</td>
<td>0</td>
<td>1.4</td>
<td>5.9</td>
<td>11.8</td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>FMS</th>
<th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
</tr>
</thead>
<tbody>
<tr>
<td>% of a halftone</td>
<td>0</td>
<td>± 3.4</td>
<td>± 6.7</td>
<td>± 10</td>
<td>± 14</td>
<td>± 20</td>
<td>± 40</td>
<td>± 80</td>
</tr>
</tbody>
</table>

**TEST PROGRAM**

Here a tested power-on initialization and sample note in the "Grand Piano" voice (page 27).

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>2H</td>
<td>0</td>
<td>LFO off</td>
</tr>
<tr>
<td>27H</td>
<td>0</td>
<td>Channel 3 mode normal</td>
</tr>
<tr>
<td>28H</td>
<td>0</td>
<td>Off</td>
</tr>
<tr>
<td>28H</td>
<td>1</td>
<td>Off</td>
</tr>
<tr>
<td>28H</td>
<td>2</td>
<td>Off</td>
</tr>
<tr>
<td>28H</td>
<td>4</td>
<td>Off</td>
</tr>
<tr>
<td>28H</td>
<td>5</td>
<td>Off</td>
</tr>
<tr>
<td>28H</td>
<td>6</td>
<td>Off</td>
</tr>
<tr>
<td>28H</td>
<td>0</td>
<td>DAC off</td>
</tr>
<tr>
<td>30H</td>
<td>71H</td>
<td>DT1/MUL</td>
</tr>
<tr>
<td>34H</td>
<td>0DH</td>
<td></td>
</tr>
<tr>
<td>38H</td>
<td>33H</td>
<td></td>
</tr>
<tr>
<td>3CH</td>
<td>01H</td>
<td></td>
</tr>
<tr>
<td>40H</td>
<td>23H</td>
<td>Total Level</td>
</tr>
<tr>
<td>44H</td>
<td>2DH</td>
<td></td>
</tr>
<tr>
<td>48H</td>
<td>26H</td>
<td></td>
</tr>
<tr>
<td>4CH</td>
<td>00H</td>
<td></td>
</tr>
<tr>
<td>50H</td>
<td>5FH</td>
<td>RS/AR</td>
</tr>
<tr>
<td>54H</td>
<td>99H</td>
<td></td>
</tr>
<tr>
<td>58H</td>
<td>5FH</td>
<td></td>
</tr>
<tr>
<td>5CH</td>
<td>94H</td>
<td></td>
</tr>
<tr>
<td>60H</td>
<td>5</td>
<td>AM/D1R</td>
</tr>
<tr>
<td>64H</td>
<td>5</td>
<td></td>
</tr>
<tr>
<td>68H</td>
<td>5</td>
<td></td>
</tr>
<tr>
<td>6CH</td>
<td>7</td>
<td></td>
</tr>
<tr>
<td>70H</td>
<td>2</td>
<td>D2R</td>
</tr>
<tr>
<td>74H</td>
<td>2</td>
<td></td>
</tr>
<tr>
<td>78H</td>
<td>2</td>
<td></td>
</tr>
<tr>
<td>7CH</td>
<td>2</td>
<td></td>
</tr>
</tbody>
</table>

<table>
<thead>
<tr>
<th>Register</th>
<th>Value</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>80H</td>
<td>11H</td>
<td>D1L/RR</td>
</tr>
<tr>
<td>84H</td>
<td>11H</td>
<td></td>
</tr>
<tr>
<td>88H</td>
<td>11H</td>
<td></td>
</tr>
<tr>
<td>8CH</td>
<td>46H</td>
<td></td>
</tr>
<tr>
<td>90H</td>
<td>0</td>
<td>Proprietary</td>
</tr>
<tr>
<td>94H</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>98H</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>9CH</td>
<td>0</td>
<td></td>
</tr>
<tr>
<td>B0H</td>
<td>32H</td>
<td>Feedback/Algorithm</td>
</tr>
<tr>
<td>B4H</td>
<td>00H</td>
<td>Both speakers on</td>
</tr>
<tr>
<td>A4H</td>
<td>22H</td>
<td>Set frequency</td>
</tr>
<tr>
<td>A0H</td>
<td>69H</td>
<td></td>
</tr>
<tr>
<td>28H</td>
<td>F0H</td>
<td>Key on</td>
</tr>
<tr>
<td>&lt;wait&gt;</td>
<td></td>
<td></td>
</tr>
<tr>
<td>28H</td>
<td>00H</td>
<td>Key off</td>
</tr>
</tbody>
</table>

Notes:
1. Write address then data.
2. Loop until read register D7 becomes 0.
3. Follow MSB/LSB sequence.
Programmable Sound Generator (PSG)

The PSG contains four sound channels, consisting of three tone generators and a noise generator. Each of the four channels has an independent volume control (attenuator). The PSG is controlled through output port $7F.

**Tone Generator Frequency**

The frequency (pitch) of a tone generator is set by a 10-bit value. This value is counted down until it reaches zero, at which time the tone output toggles and the 10-bit value is reloaded into the counter. Thus, higher 10-bit numbers produce lower frequencies.

To load a new frequency value into one of the tone generators, you write a pair of bytes to I/O location $7F according to the following format:

<table>
<thead>
<tr>
<th>First Byte</th>
<th>R2</th>
<th>R1</th>
<th>R0</th>
<th>d3</th>
<th>d2</th>
<th>d1</th>
<th>d0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Second Byte</td>
<td>0</td>
<td>0</td>
<td>d9</td>
<td>d8</td>
<td>d7</td>
<td>d6</td>
<td>d5</td>
</tr>
</tbody>
</table>

The R2:R1:R0 field selects the tone channel as follows:

- **R2 R1 R0** Tone Channel
  - 0 0 0 #1
  - 0 1 0 #2
  - 1 0 0 #3

10-bit data is: (msb) d9 d8 d7 d6 d5 d4 d3 d2 d1 d0 (lsb)

**Noise Generator Control**

The noise generator uses three control bits to select the "character" of the noise sound. A bit called "FB" (Feedback) produces periodic noises or "white" noise:

<table>
<thead>
<tr>
<th>FB</th>
<th>Noise Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>Periodic (like low-frequency tone)</td>
</tr>
<tr>
<td>1</td>
<td>White (hiss)</td>
</tr>
</tbody>
</table>
The frequency of the noise is selected by two bits NF1:NF0 according to the following table:

<table>
<thead>
<tr>
<th>NF1</th>
<th>NF0</th>
<th>Noise Generator Clock Source</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Clock/2 (higher pitch, &quot;less coarse&quot;)</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Clock/4</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Clock/8 (lower pitch, &quot;more coarse&quot;)</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Tone Generator #3</td>
</tr>
</tbody>
</table>

Note: *Clock* is fixed in frequency. It is a crystal controlled oscillator signal connected to the PSG.

When NF1:NF0 is 11, Tone Generator #3 supplies the noise clock source. This allows the noise to be "swept" in frequency. This effect might be used for a jet engine rundown, for example.

To load these noise generator control bits, write the following byte to I/O port $7F:

```
Out ($7F): 1 1 1 0 0 FB NF1 NF0
```

**Attenuators**

Four noise attenuators adjust the volume of the three tone generators and the noise channel. Four bits A3:A2:A1:A0 control the attenuation as follows:

<table>
<thead>
<tr>
<th>A3</th>
<th>A2</th>
<th>A1</th>
<th>A0</th>
<th>Attenuation</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0 dB (maximum volume)</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>2 dB Note: a higher attenuation results in a quieter sound</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>4 dB</td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>6 dB</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>8 dB</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>10 dB</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>12 dB</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>14 dB</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>16 dB</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>18 dB</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>20 dB</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>22 dB</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>24 dB</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>26 dB</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>28 dB</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>-Off-</td>
</tr>
</tbody>
</table>
The attenuators are set for the four channels by writing the following bytes to I/O location $7F:

<table>
<thead>
<tr>
<th>Tone Generator #1:</th>
<th>1</th>
<th>0</th>
<th>0</th>
<th>1</th>
<th>A3</th>
<th>A2</th>
<th>A1</th>
<th>A0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Tone Generator #2:</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>A3</td>
<td>A2</td>
<td>A1</td>
<td>A0</td>
</tr>
<tr>
<td>Tone Generator #3:</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>A3</td>
<td>A2</td>
<td>A1</td>
<td>A0</td>
</tr>
<tr>
<td>Noise Generator:</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>A3</td>
<td>A2</td>
<td>A1</td>
<td>A0</td>
</tr>
</tbody>
</table>

**EXAMPLE**

When the Mk3 is powered on, the following code is executed:

```assembly
LD HL,CLRTB ; clear table
LD C,PSG_PRT ; psg port is $7F
LD B,4 ; load four bytes
OTIR
(etc.)

CLRTB defb $3F, $3F, $DF, $FF
```

This code turns the four sound channels off. It's a good idea to also execute this code when the PAUSE button is pressed, so that the sound does not stay on continuously for the pause interval.
GENESIS TECHNICAL BULLETIN #0

To: Developers and Third Parties
From: Mac Senour, Technical Support Specialist
Date: 3/13/91
Re: Genesis Technical Bulletins

The following bulletins were written to address certain areas of Genesis game development that required correction or clarification. Please replace all previous bulletins with the attached pages.

These Technical Bulletins may not, in whole or part, be copied photocopied, reproduced, or translated without prior written consent from Sega of America, Inc.

If you have any questions, comments or have a problem that you like to have addressed in the future, please contact:

Mac Senour, Technical Support Specialist
Sega of America
573 Forbes Blvd.
San Francisco, CA 94080
(415) 796-9300 ext 352
To: Developers and Third Parties

From: Mac Senour, Technical Support

Date: 3/13/91

Re: Errors within the Microtec examples

There are three errors in examples that are provided. Please make the changes as noted.

In TESTC68K.bat:
The asm68k commands end with a semicolon, remove it and the file will assemble correctly.

The link command is incorrect. It should be:
LNK68K -c sieve.cmd -o sieve sieve

The C compiler documentation refers to a command line option of 'STRINGINTEXT' for allocating string in code segment rather than data segment. The correct spelling for this option is 'STRINTEXT'.
To: Genesis Developers and Genesis Third Parties
From: Steve Hanawa
Date: June 19, 1990
Re: Genesis Loader Board

In order to prevent loading errors, please have the following modification on Genesis Loader Board. You need to have:

2 Resister 4.7kΩ 1/8W
1 Jumper Wire

Please call me if you have any questions or special arrangements.

Remove the solder resister before soldering.

1) Place 4.7k resister between centronics connector pin #32 and +5V.

2) Place 4.7k resister between centronics connector pin #13 and +5V.

3) Place jumper wire between centronics connector pin #12 and ICI 74HC74 pin #7 (GND).
GENESIS TECHNICAL BULLETIN #3

To: Developers and Third Parties
From: Mac Senour, Technical Support
Date: August 2, 1990
Re: Precaution when accessing the Z80 bus from a 68000 main (non-interrupt) routine.

If the following routine was executed and an interrupt occurred between step 2 and 3, a data error would occur IF the interrupt also access the Z80 bus.

1) Send Z80 bus request
2) Check acknowledge
3) Writing data to Z80 bus
4) Release Z80 bus

Essentially the main routine sends a bus request but before it can conduct it's data transfer the interrupt sends it's own bus request. When the interrupt completes, it releases the Z80 bus, as it should. Unfortunately the main routine expects the bus to be available, thus an error occurs. When this error occurs the Z80 RAM is corrupted. One symptom of this error is a sound is SOMETIMES interrupted.

The solution is really quite simple, before step one above, disable interrupts. & re-enable when done.
GENESIS TECHNICAL BULLETIN #4

To: Developers and Third Parties
From: Mac Senour, R&D/Technical Support
Date: September 7, 1990
Re: Reading the controller pads

When reading a location within the range of $A10000-$A100FF, which includes the controller pads, the Z80 must have a bus request. If not the wait state will change from 250ns to 110ns. The shorter time will cause the Z80 to misread ALL further data. Once the ports have been read the Z80 may be released.

Included with this bulletin is a reprint of the routine that reads the control pads in the Logo Demo program. As you can see, this routine sends a bus request, reads the pads, then releases the Z80.
; sw_data1+1 is the address for edge data of port 1.

**sw:**

```
z80_diw
bsr.b rs_sub
z80_ei
rts

rs_sub:
lea sw_data1,a5
lea port_1,a6
bsr ??rs_0
addq.w #2,a6

??rs_0:
mov.b #$0,(a6)
nop
nop
mov.b (a6),d7
asl.b #2,d7
mov.b #$40,(a6)
andi.w #1100000b,d7
mov.b (a6),d6
andi.w #0011111b,d6
or.b d6,d7
not.b d7
mov.b (a5),d6
eor.b d7,d6
mov.b d7,(a5)+
and.b d7,d6
mov.b d6,(a5)+
```

; set busreq

; switch data store address
; port for p1
; a6 = port_2
; set TH = 0
; wait
; input data when TH = 0
; chane data when TH = 0 & wait
; set TH = 1
; chane data when TH = 0 & wait
; input data when TH = 1

; port initial

**sw_init:**

```
mov.eq #$40,d7
mov.b d7,cont_1
mov.b d7,cont_2
mov.b d7,cont_3
rts
```

; port initial
; set TH out

---

**input**

a6.1 = controller port address

output
d7.b = $00 Modem
; $0d Mega Drive Joy Stick
; $0e Ran Disk
; $0f ETC. or None

use d0,a0

---

**cont**

set $0006

---

**port**

movem.1 d1-d2/a5,-(sp)
; register push
dis
z80_diw
lea ??and_data(pc),a5
move.b (a5).cont(a6)
mov.eq,#0,d7
mov.eq,#500,d1
; data table address set
; Th bit set output
; capture register initial
; counter set
GENESIS TECHNICAL BULLETIN #5

To: Project Managers, Developers and Third Parties
From: Mac Senour, Technical Support Specialist
Date: November 26, 1990
Re: Cartridge identification

Every product must have, at location 100h, an IDTABLE. The table is slightly different for each type of developer. The difference is small, affecting the product code and the copyright, both important for product approval. Please replace the following pages in your Sega Software Manual.
check_sum equ $0000
ORG $0100

;--------------------------------------------------------------
dc.b 'SEGA GENESIS' ;100
dc.b '(C)SEGA 199X.XXX' ;110 release year.month
dc.b 'your game title' ;120 Japan title
dc.b '' ;130
dc.b '' ;140
dc.b 'your game title' ;150 US title
dc.b '' ;160
dc.b '' ;170
dc.b 'GM MK-XXXX -XX' ;180 product #, version
dc.w check_sum ;18E check sum
dc.b 'T' ;190 controller
dc.l $00000000,$000fffff,$00ff0000,$00ffff00 ;1a0
dc.b '' ;1b0
dc.b '' ;1c0
dc.b '' ;1d0
dc.b '' ;1e0
dc.b 'U' ;1f0
;--------------------------------------------------------------
check_sum equ $0000
ORG $0100

;---------------------
dc.b 'SEGA GENESIS' ;100
dc.b '(C)T-XX 199X.XXX' ;110 release year.month
dc.b 'your game title' ;120 title
dc.b ' ' ;130
dc.b ' ' ;140
dc.b 'your game title' ;150 title
dc.b ' ' ;160
dc.b ' ' ;170
dc.b 'GM T-XXXXXX XX' ;180 product f, version
dc.w check_sum ;18E check sum
dc.b 'J' ;190 controller
dc.l $00000000, $0007fff, $00ff0000, $00ffffff ;1a0
dc.b ' ' ;1B0
dc.b ' ' ;1C0
dc.b ' ' ;1D0
dc.b ' ' ;1E0
dc.b 'U' ;1F0

;---------------------
To: Developers and Third Parties
From: Mac Senour, Technical Support
Date: 4/2/91
Re: Impossible values read from the controller pads

It is possible for a well used controller pad to yield incorrect values. Specifically: up AND down, left AND right. This is due to the small piece of rubber wearing out inside the pad. Your routine that handles the values read should be written so that if the number is NOT one of the expected values, it should re-read the pad to obtain a correct value.
As always, please call if you have any questions or comments.
GENESIS TECHNICAL BULLETIN #11

To: Developers and Third Parties
From: Mac Senour, Technical Support
Date: 9/9/91
Re: Problems during sound access

Sound output stops during a game.

Problem:
The busy flag was read in the FM sound generator YM2616 like this (address 4001h)

(CS,RD,WR,A1,A0) = (0,0,1,0,1)

However, in the case of the YM2612, it's output is not regulated according to the conditions set above. This results in the device being read as "not busy" and as a consequence, ends up outputing sound.

Fix:
When the FM sound generator's busy flag is read, do not access anything else other than:

(A1,A0) = (0,0) (address 4000h)
SEGA
SEGA OF AMERICA, INC.
Consumer Products Division

GENESIS TECHNICAL BULLETIN #12

To: Developers and Third Parties
From: Mac Senour, Technical Support
Date: 9/9/91
Re: Problems with repeated resets

The software seems to go out of control when resets are repeated.

The Problem:
When the reset occurs the CPU is reset, however the VDP is not. When the reset occurs during a DMA the VDP continues the DMA. The VDP is accessed right after the reset. If this is done while the VDP is executing a DMA then this access is ineffective.

The Fix:
Before accessing the VDP after the initialization program (ICD BLK4), check the DMA BUSY status register. If a DMA is being executed, do not attempt to access the VDP.

If the problem persists, ensure that you are not executing a DMA right after a reset.
To: Developers and Third Parties
From: Mac Senour, Technical Support
Date: 9/9/91
Re: Corrections to the Genesis Software Manual

When discussing VRAM, CRAM and VSRAM access, the manual states in pages 22-27 that byte access is possible. This is incorrect. Access is limited to word or long word.

On page 77 it implies that the 68000 may set the bank switches. The bank switches MUST be set by the Z80.

These changes affect version 1.0 of the manual, later versions will reflect this correction.
To: Developers and Third Parties
From: Mac Senour, Technical Support
Date: 9/5/91
Re: ROM splitting

As we all know Genesis products must be split into 128k odd & even pieces. Sega expects the ROM images to be in the following format:

<table>
<thead>
<tr>
<th>0:Even</th>
<th>1:Odd</th>
</tr>
</thead>
<tbody>
<tr>
<td>2:Even</td>
<td>3:Odd</td>
</tr>
<tr>
<td>...</td>
<td>...</td>
</tr>
</tbody>
</table>

For larger products, continue the above pattern. We would appreciate it if all products would conform to this method of splitting. Please request the utility to split ROMs, M2B or Split4, if your current tool can't output files in this manner.
GENESIS TECHNICAL BULLETIN #27

To: SEGA & Third Party Developers
From: Technical Support Group
Date: January 24, 1994
Re: Genesis Technical Information

The following tech note contains information on Genesis peripheral devices.
1. Warning regarding control pad data reads

For both the 3 and 6 button pads, the pad data is determined 2μsec after TH is modified. Therefore, as shown in the sample below, read data from the pad 2μsec (4 nop's) after TH is modified.

**Joypad Reads**

Pad data from the 3 and 6 button controllers are read 2μsec after TH is modified. The wait is necessary because the data in the chip needs time to stabilize after TH is modified. If data is read without this wait, there is no guarantee that the data will be correct.

Moreover, the 2μsec time is equivalent to 4 nop, including the 68000's prefetch.

Z80BusReq equ $A11100
Z80Reset  equ $A11200

; ****************************
; _JSID  joystick id get.
; This routine essentially performs connection check of the Genesis I/O
; ports. Figures out if some kind of controller is attached to I/O port and
; distinguishes between different classes (regular vs handshaking)
; controllers. This identification scheme is based on Addendum #1 in the
; Genesis Software Manual
; in:  d1.w  :  port number (0...2)
; out: d0.l== ID
; $0d  MD FP6B(six button) or MD 3button
; $03  SOA/SOJ mouse
; $07  SEGA TEAM PLAYER
; $ff  input error(passed incorrect port number)
; $0f  unknown or nothing connected
; ****************************

_JSID:

    cmp.b  #3,d1
    blt   _JSID_10
    moveq  #-1,d0
    rts

_JSID_10:

    movem.l d2-d3/a0,-(sp)
    move.w #$100,Z80BusReq ;Z80 bus request
    move.w #$100,Z80Reset ;Z80 reset line high
    btst.b #0,Z80BusReq ;Z80 bus grant acknowledge
    bne.s  -*8 ;wait until bus granted
    move.l #$00a10003,a0

(YN 1/11/94)
moveq     #0,d0
move.b    d1,d0
add.l     d0,d0
adda.l    d0,a0
moveq     #0,d0
move.l    d0,d1
move.l    6(a0),d3 ;save original status of control port
swap      d3
move.b    (a0),d3 ;original status of I/O port
move.b    #%01000000,6(a0) ;I/O control: TH (PD6) output
nop
nop
nop
nop
move.b    #%01000000,(a0) ;set TH=1 (high)
nop
nop
nop
mov.e    (a0),d0
move.b    #%00000000,(a0) ;set TH=0 (low)
nop
nop
nop
nop
move.b    (a0),d1
move.b    #%01000000,(a0) ;set TH=1 (high)
move.w    d0,d2
lsr.b     #1,d0
ror.w     #1,d0
lsr.b     #1,d0
rol.w     #1,d0
ror.w     #1,d2
lsr.b     #1,d2
rol.w     #1,d2
or.b      d2,d0 ;ID2=(PD6=1) & (PD1 OR PD0)
and.w     #$03,d0
lsr.b     #2,d0
move.w    d1,d2
lsr.b     #1,d1
ror.w     #1,d1
lsr.b     #1,d1
rol.w     #1,d1
ror.w     #1,d2
lsr.b     #1,d2
2. Warning regarding Sega Mouse data requests

After the 10th data read, always issue an END DATA command. Set both TH & TR bit high to issue an END DATA command(see example below). Abnormal operation may occur if data beyond the 11th state is read.

**************************************************************************
* MOUSE_GET mouse/tablet driver
* THIS DRIVER READS THE SEGA MOUSE
* Access this routine from within the V_INT.
* The Z80 Enable/Disable code is provided as a safety check, to
* prevent unfavorable bus access.
*
* in d1.w : port number ( 0..2 )
* out: d0.1 & d2.1
* d0.1 contains connection status and reserved bits
* d2.1 contains MOUSE bits
*
* d0.1 = xxxx|xxxx|xxxx|xxxx|t1 m1 1 1 1 1 1 1 1 1
* If mouse is connected, value returned in d0.1 is as follows:
* d0.1 = xxxx|xxxx|xxxx|xxxx| 1 1 1 1 1 1 1 1 1
* if mouse connected, bit t1 = 1 m1 =0
* if tablet connected, bit t1=0 m1 =1
* note bits t1 and m1 cannot simultaneously be zero.
*
* In case of error(nothing connected,other device, or incorrect port value)
* the driver returns 0 in register d0.1. If mouse/tablet is actually
* connected, the value in d0.1 cannot be zero.
*
* In case of timeout, the driver sets bit 31 in d2.1, and returns 0 in d0.1
* MOUSE DATA is returned in register d2.1 as follows:
* d2.1 = 0xxx|xxx|YoXoYsXs|CMRL|X7X6X5X4|X3X2X1X0|Y7Y6Y5Y4|Y3Y2Y1Y0

(YN 1/11/94)
* x denotes don't care bits
* Yo (Yover) 1 when Y data exceeds 255(ffh)
* Xo (Xover) 1 when X data exceeds 255(ffh)
* Ys (Ysign) 0 when Y data is positive, 1 when negative
* Xs (Xsign) 0 when X data is positive, 1 when negative
* C Center button (START/PAUSE)
* M Middle button (TRG-B)
* R Right button (TRG-C to CANCEL)
* L Left button (TRG-A to SELECT)
* X7-X0 absolute values of movement in X direction
* Y7-Y0 absolute values of movement in Y direction
* REGISTERS: register d1 is exclusively used for input to the routine.
  * register d0 & d2 is used for output

*****************************************************************************

MOUSE_GET:

    movem.l   d1/d3/d4/d7/a0,-(sp)
    move.w    #$100,Z80BusReq
    move.w    #$100,Z80Reset
    bts.t.b    #0,Z80BusReq
    bne    *_.8
    moveq    #0,d0                     * error flag
    cmp.w    #$0002,d1
    bhi    MOUSE_EXIT
    add.w    d1,d1
    move.l    #$00a10003,a0

MOUSE_CONNECT:

    move.b    #$60,6(a0,d1.w)
    nop
    nop
    move.b    #$60,(a0,d1.w)          * TH,TR=11 (END DATA command)
    moveq    #0,d2
    moveq    #0,d3

mouse_rdy_lp:

    bts.t.b    #4,(a0,d1.w)
    beq.b    mouse_rdy_lp
    move.b    (a0,d1.w),d4            * d4.b=? 11100000
    and.b    #$0f,d4
    tst.b    d4
    bne    MOUSE_EXIT               * nothing connected/different controller
    move.b    #$20,(a0,d1.w)          * select t1 m1 11
    move.w    #$fe,d7                 * timeout parameter

mouse lp1:

    bts.t.b    #4,(a0,d1.w)
bne.b MOUSE_10
dbra d7.mouse_lp1
bra MOUSE_ERR

MOUSE_10:
move.b (a0,d1.w),d0
lsl.w #8,d0
move.b #$00,(a0,d1.w)
nop
mouse_lp2:
btst.b #4,(a0,d1.w)
beq.b MOUSE_20
* bne.b MOUSE_20
dbra d7.mouse_lp2
bra MOUSE_ERR

MOUSE_20:
move.b (a0,d1.w),d3
move.b #$20,(a0,d1.w)
lsl.w #8,d3
mouse_lp3:
btst.b #4,(a0,d1.w)
beq.b MOUSE_30
dbra d7.mouse_lp3
bra MOUSE_ERR

MOUSE_30:
move.b (a0,d1.w),d3
lsl.b #4,d3
lsr.w #4,d3
move.b #$00,(a0,d1.w)
or.w d3,d0
moveq #0,d3
mouse_lp4:
btst.b #4,(a0,d1.w)
beq.b MOUSE_40
dbra d7.mouse_lp4
bra MOUSE_ERR

MOUSE_40:
move.b (a0,d1.w),d2
move.b #$20,(a0,d1.w)
lslw #8,d2
mouse_lp5:
btst.b #4,(a0,d1.w)
bne.b    MOUSE_50
        d7,mouse_lp5
bra       MOUSE_ERR

MOUSE_50:
        move.b   (a0,d1.w),d2   * d2 = xxx|Yo Xo Ys Xs|xxx|C M R L
        move.b   #$00,(a0,d1.w)  * select X high X7 X6 X5 X4
        lsl.b     #4,d2
        lsl.w     #4,d2   * d2 = Yo Xo Ys Xs|C M R L|xxx|xxx
mouse_lp6:
        btst.b    #4,(a0,d1.w)
        beq.b     MOUSE_60
        dbra     d7,mouse_lp6
bra       MOUSE_ERR

MOUSE_60:
        move.b   (a0,d1.w),d2   * d2 = Yo Xo Ys Xs|C M R L|xxx|X7 X6 X5 X4
        move.b   #$20,(a0,d1.w)  * select X low X3 X2 X1 X0
        lsl.b     #4,d2
        lsl.w     #4,d2   * d2 = xxx|Yo Xo Ys|C M R L|X7 X6 X5 X4|xxx|xxx
mouse_lp7:
        btst.b    #4,(a0,d1.w)
        bne.b     MOUSE_70
        dbra     d7,mouse_lp7
bra       MOUSE_ERR

MOUSE_70:
        move.b   (a0,d1.w),d2   * d2 = YoXoYsXs|CMRL|X7X6X5X4|xxx|X3X2X1X0
        move.b   #$00,(a0,d1.w)  * select Y High Y7 Y6 Y5 Y4
        lsl.b     #4,d2
        lsl.w     #4,d2   * d2 = YoXoYsXs|CMRL|X7X6X5X4|X3X2X1X0|xxx|xxx
mouse_lp8:
        btst.b    #4,(a0,d1.w)
        beq.b     MOUSE_80
        dbra     d7,mouse_lp8
bra       MOUSE_ERR

MOUSE_80:
        move.b   (a0,d1.w),d2
* d2 = YoXoYsXs|CMRL|X7X6X5X4|X3X2X1X0|xxx|Y7Y6Y5Y4
        move.b   #$20,(a0,d1.w)  * select Y Low Y3 Y2 Y1 Y0
        lsl.b     #4,d2
        lsl.w     #4,d2   * d2 = YoXoYsXs|CMRL|X7X6X5X4|X3X2X1X0|Y7Y6Y5Y4|xxx|xxx
mouse LP9:
  btst.b #4,(a0,d1.w)
  beq.b MOUSE_90
  dbra d7,mouse LP9
  bra MOUSE_ERR

MOUSE_90:
  move.b (a0,d1.w),d2
  *d2=YoXoYsXs|CMRL|X7X6X5X4|X3X2X1X0|Y7Y6Y5Y4|xxxx|Y3Y2Y1Y0
  move.b #$60,(a0,d1.w)  * TH TR =1 l(END DATA command) and exit
  slt.b #4,d2
  lsr.l #4,d2
  *d2= xxxx|xxxx|YoXoYsXs|CMRL|X7X6X5X4|X3X2X1X0|Y7Y6Y5Y4|Y3Y2Y1Y0
mouse LP10:
  btst.b #4,(a0,d1.w)
  beq.b mouse LP10
  ori.l #$00000000,d2

MOUSE_EXIT:
  move.w #0,Z80BusReq
  movem.l (sp)+,d1/d3/d4/d7/a0
  rts

MOUSE_ERR:
  move.b #$60,(a0,d1.w)
  nop
  nop
mouse ERPL:
  btst.b #4,(a0,d1.w)
  beq.b mouse ERPL
  or.l #$80000000,d2
  moveq #0,d0
  move.w #0,Z80BusReq
  movem.l (sp)+,d1/d3/d4/d7/a0
  rts

(YN 1/11/84)
3. Warning regarding the Sega infrared 6 button cordless pad

The following software issues were discovered prior to the release of the Mega Drive infrared 6 button cordless pad. Detailed technical specifications regarding the infrared pad will follow at a later date.

- **Change in the method to switch between the Fighting Pad 6B and the 3B Pad.**
  The mode switch is made by the operation described below. Do not implement the following button combinations in game controls.

  1. After installing the infrared 6 button pad receiver on the Mega Drive, turn on power to the Mega Drive.
  2. When the receiver has power, push the MODE, X and C buttons on the cordless 6 button pad simultaneously.
  3. The controller is now in 3 button mode.

4. Warning regarding Fighting Pad 6B (hereafter FP6B) data

The shaded data in the table below is used for expansion uses. The data is not currently used by the FP6B. The data there is invalid, therefore, please do not use them.

<table>
<thead>
<tr>
<th>TH(bit5)</th>
<th>TR(bit5)</th>
<th>TL(bit4)</th>
<th>R(bit3)</th>
<th>L(bit2)</th>
<th>D(bit1)</th>
<th>U(bit0)</th>
<th>Comments</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>Hi</td>
<td>TRG-C</td>
<td>TRG-B</td>
<td>RIGHT</td>
<td>LEFT</td>
<td>DOWN</td>
<td>UP</td>
</tr>
<tr>
<td>2</td>
<td>Low</td>
<td>START</td>
<td>TRG-A</td>
<td>0</td>
<td>0</td>
<td>DOWN</td>
<td>UP</td>
</tr>
<tr>
<td>3</td>
<td>Hi</td>
<td>TRG-C</td>
<td>TRG-B</td>
<td>RIGHT</td>
<td>LEFT</td>
<td>DOWN</td>
<td>UP</td>
</tr>
<tr>
<td>4</td>
<td>Low</td>
<td>START</td>
<td>TRG-A</td>
<td>0</td>
<td>0</td>
<td>DOWN</td>
<td>UP</td>
</tr>
<tr>
<td>5</td>
<td>Hi</td>
<td>TRG-C</td>
<td>TRG-B</td>
<td>RIGHT</td>
<td>LEFT</td>
<td>DOWN</td>
<td>UP</td>
</tr>
<tr>
<td>6</td>
<td>Low</td>
<td>START</td>
<td>TRG-A</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>7</td>
<td>Hi</td>
<td>TRG-C</td>
<td>TRG-B</td>
<td>MODE</td>
<td>TRG-X</td>
<td>TRG-Y</td>
<td>TRG-Z</td>
</tr>
<tr>
<td>8</td>
<td>Low</td>
<td>START</td>
<td>TRG-A</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>9</td>
<td>Hi</td>
<td>TRG-C</td>
<td>TRG-B</td>
<td>----</td>
<td>----</td>
<td>----</td>
<td>----</td>
</tr>
</tbody>
</table>

Fighting Pad 6B Data Table
5. Cartridge Information (Corrections and Additions to Genesis Technical Bulletin #26, Sec. 3.)

The data "-yy" entered in cartridge information ID 18Bh-18Dh is the version number of the game. In some games however, the data suffix "-zz" as shown in numbers 2) and 5) below denotes the sales territory for the cartridge. Please make sure not to confuse the two.

Explanation

There are currently 5 product number types.

1) T-xxxxx ; third party brand <Japan>
2) T-xxxxx-zz ; third party brand <international>
3) G-ffff ; Sega brand <Japan>
4) MK-oooo ; Sega brand <US>
5) MK-oooo-zz ; Sega brand <international other than US>

For European third party products, the product number is "T-xxxxx-50" (zz=50). Only "T-xxxxx" is necessary when the information is entered in the cartridge (-50 is unnecessary).

Example

If the product number is "T-12345-50" (European version), the cartridge information is as follows:

Incorrect
180h:"GM T-12345 -50xx" *Disk kind, good number, ver no. checksum

Correct
180h:"GM T-12345 -00xx" *Disk kind, good number, ver no. checksum

Note: The information contained here is not included in any previously released documentation.
GENESIS TECHNICAL BULLETIN #28

To: SEGA & Third Party Developers

From: Technical Support Group

Date: January 31, 1994

Re: Genesis Technical Information

=================================================================

1. In accordance with an increased number of Mega Drive peripheral devices, I/O port usage data is added at 190H of the cartridge ID.
   For more information on I/O port usage data, please see Page 1 of the "GENESIS SOFTWARE DEVELOPMENT MANUAL COMPLEMENT."

   **Items added**

   - Sega mouse "M"
   - Fighting pad 6B "6"
   - Multi-tap "4"

   **Setting Conditions**

   - Fighting Pad 6B
     Only when the XYZ buttons are effective. For the rest, enter "J" in the usual manner.

   - Multi-tap
     When multi-tap multi-switch is on.
     (When data can be read with multi-switch turned on even if it is not geared for the multi-play.)
Multi-Tap Supplement

- Multi-tap switching setup has the following functions:
  
  A→D : Terminal selectors (any one terminal can be selected)
  MULTI: Used with games designed for more than 3 players

2. For the country information to be added at 1FOH of the Mega Drive cartridge ID, please input such data in accordance with A10001H of the I/O port.

BIT 7 0: Domestic } Input as "J."
BIT 6 0: NTSC } Japan/Korea/Taiwan sales hardware

BIT 7 1: Overseas } Input as "U."
BIT 6 0: NTSC } US/Canada sales hardware

BIT 7 1: Overseas } Input as "E."
BIT 6 1: PAL } Europe/Hong Kong sales hardware

Note: For the above I/O port, see Page 72 of the "GENESIS SOFTWARE MANUAL."
GENESIS TECHNICAL BULLETIN #29

To: SEGA & Third Party Developers

From: Technical Support Group

Date: March 10, 1994

Re: Genesis Technical Information

The information on the bottom of page 2 of the Genesis Sound Software Manual is incorrect. It should be changed to:

CONFIRMATION OF BUS STATUS:

This information is in $A11100, bit 8. (not bit 0 as stated in the manual)

0 = Z80 is inactive, 68k can access
1 = Z80 is active

(Please note that this is reversed from what is in the manual.)
GENESIS TECHNICAL BULLETIN #29A

To: SEGA & Third Party Developers

From: Technical Support Group

Date: April 11, 1994

Re: Genesis Technical Information

=================================

This is a clarification on Genesis Technical Bulletin #29.

The information on the bottom of page 2 of the Genesis Sound Software Manual is incorrect. It should be changed to:

CONFIRMATION OF BUS STATUS:

This information is in $A11100, bit 8 when accessed by WORD and bit 0 by BYTE.

0 = Z80 is inactive, 68k can access
1 = Z80 is active

(Please note that this is reversed from what is in the manual.)
GENESIS TECHNICAL BULLETIN #31

To: Sega and Third Party Developers
From: Developer Technical Support
Date: November 22, 1994
Re: Genesis ID table update

1. Changes to cartridge data (ID) specifications
   Please note that the specifications below also apply to the Genesis 32X.

The following changes have been made to the code entered in 1FOh.

- Old: Country code data
- New: 1 byte ASCII hardware enable code in 1FOh.
  1F1h to 1FFh are filled with the "space" character code (20h).
- Explanation
  The hardware enable code is used when the application reads the hardware data information in $A10001 in order to perform territory lockout. The code is used by SEGA to check hardware and software compatibility.

<table>
<thead>
<tr>
<th>$A10001</th>
<th>Main Sales Territories</th>
<th>Hardware Enable Code (numbers from 0 to F below)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Bit 7</td>
<td>Bit 6</td>
<td></td>
</tr>
<tr>
<td>0</td>
<td>0</td>
<td>Japan, NTSC, Japan, S. Korea, Taiwan</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Japan, PAL</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Overseas, NTSC, N. America, Brazil</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Overseas, PAL, Europe, Hong Kong</td>
</tr>
</tbody>
</table>

↑ Example 2
Example 1 ↑

 o: Enable    x: Disable

Ex. 1) The hardware enable code "F" is entered in applications that do not limit hardware compatibility (i.e., a universal compatibility ROM). As can be seen in the table above, the hardware enable code "F" is compatible with all hardware types.

Ex. 2) For applications that are compatible only with the US version of the Genesis, the hardware enable code "4" is used. The application is compatible only with hardware that shows Bit 7 = 1 and Bit 6 = 0 at $A10001.

<table>
<thead>
<tr>
<th>Address</th>
<th>Hardware Enable Code</th>
<th>1F0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
<th>6</th>
<th>7</th>
<th>8</th>
<th>9</th>
<th>A</th>
<th>B</th>
<th>C</th>
<th>D</th>
<th>E</th>
<th>F</th>
</tr>
</thead>
<tbody>
<tr>
<td>ASCII</td>
<td>Code</td>
<td>0 1</td>
<td>2</td>
<td>3</td>
<td>4</td>
<td>5</td>
<td>6</td>
<td>7</td>
<td>8</td>
<td>9</td>
<td>A</td>
<td>B</td>
<td>C</td>
<td>D</td>
<td>E</td>
<td>F</td>
<td></td>
</tr>
<tr>
<td>34</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td>20</td>
<td></td>
</tr>
</tbody>
</table>

NOTE: Software containing errors in the code above will not be acceptable for final master ROM release purposes.
GENESIS TECHNICAL BULLETIN #32

To: Sega and Third Party Developers
From: Developer Technical Support and Catapult Entertainment
Date: 30-Jan-95
Re: Getting Games Ready For XBAND™

NOTE: This document is provided to Sega Certified Developers under the confidential terms of your Sega Developer Agreement.

1. Introduction

This document provides an introduction to the XBAND Video Game Modem and Network, and a preliminary overview of game design guidelines that will make it easier for your game to be adapted for network play. If you are developing a new multi-player game that you would like to be compatible with the XBAND Network, or if you would like the XBAND Network to be compatible with an existing multi-player game, this is the first document that you should read.

NOTE: Many of the technologies described in this document are proprietary to Catapult Entertainment, Inc. and are either patented or patent-pending.

2. How to reach XBAND

Catapult Entertainment, Inc.
c/o Developer Programs
20823 Stevens Creek Blvd.
Cupertino, CA 95014
Voice: 408.366.1735
Fax: 408.366.1729
Internet: developers@catapent.com

3. What is XBAND?

XBAND is made up of two major components: The XBAND Video Game Modem and the XBAND Network. The XBAND Video Game Modem is a device that
plugs in-between a Sega Genesis cartridge slot and a video game cartridge. The XBAND Network is an on-line system built into the XBAND Video Game Modem that automatically matches players to play video games with each other, keeps track of game statistics, provides e-mail and electronic newspapers, and much more.

As a video game developer you will be mostly concerned with the operation and programming of the XBAND Video Game Modem during the execution of your video game. The information you will need regarding this starts in Section 4.

3.1. The XBAND Video Game Modem

The XBAND Video Game Modem is more than just a modem. Physically, it plugs into a Sega Genesis cartridge slot and accepts a video game cartridge on a connector on the top. The phone line plugs into an RJ-11 jack on the side. There is also a slot to accept an ISO 7816-compliant Smart Card, whose use will be explained later, and a “pass-through” switch which allows you to play the attached cartridge in single-player mode.

The XBAND Video Game Modem has 512KBytes (4 MBits) of ROM that holds the XBAND OS (XOS) code, XOS graphics and sound data, and the XOS GameTalk routines (which can be directly called by game cartridges). The XBAND Video Game Modem also contains 64KBytes (512KBits) of battery-backed SRAM that holds the player’s personal information (X-Mail, Player List, Player ID), XOS system patches, cartridge-specific game patches, game results from the last game played, and the XBAND on-line newspapers (BANDWIDTH and XBAND News).

The XBAND Video Game Modem contains a proprietary custom chip, which provides all of the logic functions for the operation of the XBAND Video Game Modem and also the means for controlling the execution of plugged-in cartridges.

Finally, the XBAND Video Game Modem contains a special modem chip that provides low-latency, noise-tolerant communications as well as special detection mechanisms for Call Waiting and other noise events. This allows the modem to run at only 2400 bits per second, transmitting a maximum of 4 bytes per frame.

3.2. The XBAND Network

The XBAND Network is different than traditional on-line systems. If a player of a traditional on-line service wishes to play a game with another person, the player must be connected to the service’s Server for the duration of the game. With XBAND, players are only connected to the XBAND Server for a small percentage of their connect time, resulting in a lower cost and lower latency connection (typically less than 50 msec end-to-end).
When an XBAND player wishes to play against another person, the player's XBAND Video Game Modem connects to the XBAND Server. During the brief connection to the XBAND Server (typically between 10 seconds and a minute), the XBAND Video Game Modem uploads the player's phone number, any outgoing mail the player might have, and the game results from the last game played. Simultaneously, the XBAND Video Game Modem downloads the phone number of an opponent (or a number of minutes to wait for a call), any incoming mail, the two XBAND on-line newspapers, any new game patch that is needed (to be explained below), and any new system updates for the XOS.

Once the transaction is complete, the XBAND Video Game Modem hangs up the phone, and if it downloaded an opponent's phone number, it immediately dials the opponent. If it received instructions to wait for an opponent, it notifies the player of how long it expects to wait, and then waits for the telephone to ring.

Either by dialing out or by receiving an incoming call, the XBAND Video Game Modem connects with another XBAND Video Game Modem. There is a handshake where they exchange player information, then the video game cartridge is started up, the two games synchronize to each other, and the video game is played. Once the game is completed, the XBAND Video Game Modems disconnect, storing the results of the game in battery-backed up RAM, to be stored until one of the XBAND Video Game Modems connects to the XBAND Server again and uploads the data.

Since the phone lines used for XBAND are often used for voice calls or fax machines as well, it's important to gracefully deal with Call Waiting and line noise events. Such disruptions typically cause modems to lose carrier and hang up. The XBAND Video Game Modem, however, will pause the video game once disrupted, and then make every effort to wait out the noise event, restore carrier, and resume the game. Even if the modem has no choice but to hang up, it will redial the opponent and attempt to restore carrier and resume the game. This level of tenaciousness is essential when dealing with shared voice lines. We have found that about one in every three games experiences a line noise event that would have resulted in a lost connection with a conventional modem.

4. Getting Network Games to Run In Sync

The essential problem of real-time point-to-point modem game play is maintaining synchronization between the two video game machines. Although the video game hardware and cartridge software are identical on both ends of the phone line, slight variances between the systems as well as the limited timing resolution of the modem data stream creates a situation where it is quite easy for the two machines to drift out of synchronization. Once the two video games are out of sync even slightly, they will drift even further apart as game play continues, and in the end the game will likely have a different outcome.
There is no single technique that will magically maintain synchronization for all games. Catapult has found that there are about as many techniques for maintaining synchronization as there are techniques for designing main game loops. And, we have also come very quickly to the realization that it would be ludicrous to try to impose a single mechanism upon all video games developers. You need to look at the particular architecture of your game, see which issues apply in your case and which issues don’t, and make use of the tools and techniques that Catapult has developed. And if that doesn’t do the trick, we’re here to help you. Many times we’ve been told that because of this and that a game will never run synchronized over a modem. We have yet to find one that we could not get to work with XBAND.

4.1. Why Synchronization Errors Occur

One would think that two identical video game machines running the same software and fed the same controller inputs would have identical execution. Unfortunately, this is not at all the case. There are several reasons why two identical video game machines running identical software will have varying execution behavior. This list is by no means complete, but it covers the major issues that we have encountered.

To begin with, any two free-running systems will run at different speeds. That is to say, the crystal oscillator that governs the clock speed of the video game processor and the timing of the video scanning is only accurate to a certain precision. In practical terms, we have found that the worst case speed differential between two video game systems will cause one machine to get a full frame ahead of the other in about two minutes. So, if your game uses Vertical Blanking Interrupt (VBI) as a timing reference, you will find that given two free-running video game systems, you can only hope to keep both systems on the same frame for about two minutes.

[Fortunately, since VBI synchronization is essential for many games, Catapult has developed a technology (called Sync-O-Tron™) which keeps VBIs locked together for the duration of the game, despite the drift between the two crystal oscillators. This technology usually helps solve game synchronization problems, but it is not always a complete solution. It is discussed later in Section 5.5.]

Another common source of synchronization problems occurs in the critical relationship between VBI and the main game loop. One would think that given identical hardware, identical software, and identical state (e.g. the same controller input), the VBI interrupt for a given frame will occur after the exact same instruction in the main game loop in both machines. If it were the case that there were no other asynchronous events occurring in the video game machine, this indeed would be true. Unfortunately, events such as DRAM refresh and sound DMA are unpredictable and asynchronous to the CPU execution causing the two CPUs to have the same average execution speed, although not the same cycle-by-cycle execution profile. So, while it is the case that VBI will occur at
approximately the same instruction in each main game loop, on a given VBI it
might be one or two instructions off. If there is a game state decision that occurs
in one of these instructions that is affected by a variable changed during VBI, the
game execution will be different on both machines.

This same slight variation in CPU timing can also affect the number of VBI
frames per game loop. For example, if the main game loop takes almost exactly
three frames to execute, it might finish executing just before VBI on one machine
and just after VBI on the other machine. If the number of frames per game loop
affects game logic (as it often does), one game will count three frames and the
other will count four, causing the two games will exhibit different behavior.

The slight variation in CPU timing can also affect reads from hardware registers
that affect game behavior. For example, some games read the current HV counter
at various points in the game loop for use as a random number. Clearly, given
the execution variances just mentioned, the number fetched could have widely
differing values on the two machines.

DMA timing can also introduce variations in execution for many of the same
reasons. On the Sega Genesis, when graphics DMA occurs, it shuts down the
CPU completely. Normally, DMA is only used during vertical blanking, allowing
the CPU to run during active video, but sometimes when games are doing major
screen updates (e.g. between segments of the game), they activate DMA
continuously until the update is complete. If the DMA continues for more than a
frame time, an entire VBI may be missed. And if the DMA completes at
approximately the same moment as VBI, it may complete before VBI on one
machine, but after VBI on the other machine. This can create a situation where
the two machines will count a different number of VBIs resulting in differing
game execution.

The game cartridge itself can introduce variances. Many games today have
battery-backed cartridge RAM that they use for storing results from previous
games. If these results affect game play (as is often the case with sports games),
there will be varying execution between the two cartridges. It isn’t a reasonable
solution to just erase the RAM or update both with the same values. Very often
the information stored in the RAM is of great importance to the game player (e.g.
hard-earned stats, etc.). So, the game must have a mode of execution where the
RAM status is disregarded.

In some situations there is more than one release of the same game cartridge. For
example, NBA® JAM™ for Sega Genesis had two releases, and there were
significant differences in the code (e.g. one of the basketball players was changed,
and some of the timings were changed) between the two releases. A separate
Game Patch had to be developed for each version to reconcile the execution
differences so that a Rev. 1 could play against a Rev. 2 and stay in sync.

Finally, there is occasionally code that samples player reaction time so precisely
that the exact same timing cannot be reproduced on both machines. For example,
a game might enter a spin loop to count the length of time before a player presses start for the purpose of getting a random number seed. The timing resolution of a CPU spin loop is far more precise than the time resolution of a modem, so the two game machines will certainly measure the player reaction time differently, resulting in a different random number seed.

4.2. How XBAND Synchronizes Existing Game Cartridges

Multi-player Sega Genesis video games played across XBAND must be carefully designed to 1) accept controller input from the remote Sega Genesis system, 2) maintain synchronized execution between the Sega Genesis systems, and 3) have appropriate options for networked play. Clearly, games which are designed from the start with the knowledge of the XBAND Network and Video Game Modem can design in these capabilities. However, cartridges which are already out on the market require these capabilities to be added in the field. The XBAND Network and Video Game Modem work together to make these in-field extensions possible.

The process goes as follows: When someone hits the “Challenge” button to register for a match, the XOS running on the XBAND Video Game Modem dials into the XBAND Server and uploads the checksum of the cartridge that the player wants to play. The XBAND Server checks to see whether the cartridge is a supported XBAND game, and if it is, it downloads to the XBAND Video Game Modem a “Game Patch” which contains the code necessary to augment the video game cartridge to make it function properly over the modem. When the XBAND Video Game Modem connects to an opponent and the handshake is complete, control is passed to the video game cartridge. The video game cartridge executes as it would normally, except for the changes to the cartridge provided by the Game Patch. These changes route the controller reads through the modem to the remote Sega Genesis machine, resolve synchronization issues between the two systems, and record results of the game execution for later reporting to the XBAND Server. When game completes, the XBAND Video Game Modem hangs up the phone, and control returns to the XOS.

The custom chip in the XBAND Video Game Modem provides a very flexible set of capabilities for augmenting the execution of a game cartridge. The chip permits you to make any change to a cartridge ROM that is needed to make it work on XBAND.

There are a number of ways that a Game Patch is developed for an existing cartridge. Ideally, it is developed by the programmer who wrote the original game cartridge, but often this person is not available. In fact, sometimes the original source code for the game is not even available or is commented in a foreign language, rendering it unreadable. Catapult has found that given the relatively small changes required to augment a game for use on XBAND, it is quite feasible to get the game to work from the object code using reverse-
engineering techniques, and several of the Game Patches on XBAND were developed using these methods.

The following sections cover the basics of game synchronization, and give several examples. If you are designing a new game, we hope that this will cover enough of the "gotchas" to keep it "sync clean". If you are developing a Game Patch for a game that is already in the field, this should give you a starting point in understanding key places where the game must be patched.

4.3. Synchronization Approaches

There are two main communication approaches that are used between video games to maintain synchronization: Game State Communication and Controller Communication.

With the Game State approach, game state information (such as player position, number of enemies, number of lives, etc.) is transmitted between the game machines. This approach is commonly used in point-of-view games. The advantage of this approach is that the games truly free run on each machine and data is only sent when there is relevant data to send. For example, if the two players are in different rooms, only information that might affect the other player is transmitted. The disadvantage of this approach is that a great deal of information must sometimes be transmitted in real-time (e.g. if both players are shooting at each other). If you are using this approach for your game, then most of the discussion that follows does not apply to you since you are just trying to achieve identical game state (not identical execution) on both machines. Synchronization issues for Game State approach games are quite game-specific and are not addressed in this document. Please contact Catapult for more information.

With the Controller Communication approach, player game controller input is transmitted between the game machines. This approach is commonly used by games where all players are visible on the screen at the same time such as sports and fighting games. The advantage of this approach is that there is a relatively small, fixed amount of data that must be transmitted, allowing the data to be transmitted every frame time, thereby allowing real-time response. The disadvantage of this approach is that it requires identical real-time game logic execution on both game machines. The following discussions review the issues surrounding the synchronization of Controller Communication approach games.
5. Game Design Guidelines

This section provides a number of guidelines for game design that either avoid synchronization problems or suggest architectures in which the synchronization problems can be controlled.

5.1. Random Number Generators

DO:

• Implement a single random number generator routine in your code that starts from a settable seed and follows a reproducible sequence (mathematical algorithms work best). The random number generator should only be called by a single thread of execution (i.e. either the main game loop or the VBI routine, but not both). One of the game machines can determine the initial seed by any means you wish, and then it will transmit to the other game machine.

DON'T:

• Don't scatter random number functions throughout your code. Call to a central routine!

• Don't implement an irreproducible random number sequence. For example, reading the HV Counter or using whatever register DO's value happens to be upon entry to the VBI routine are both no-no's.

• Don't call the random number generator from more than one thread of execution (e.g. from both the main game loop and the VBI routine). VBI will occur at an unpredictable point in the main game loop. If the random number generator is being called (or the seed is being updated) in both threads of execution, the sequence in which it is being called will be unpredictable.

5.2. Battery-Backed Cartridge RAM Usage

DO:

• Provide a mode whereby the current contents of the battery-backed cartridge RAM on your cart are not utilized by the game logic. Careful! Make sure that in this mode none of the game logic considers the value of the RAM.

DON'T:

• Don't leave stray references to the battery-backed RAM in your code for modes that supposedly don't consider the RAM (e.g. Exhibition mode in sports games). Such stray references result in subtle synchronization bugs that only come up when one player has a particular value in the RAM and the other player does not. They are a hassle to track down.
5.3. **Sega Genesis DMA Usage**

**DO:**

- Utilize DMA as you normally would in a game, but make sure the DMA is complete and you have returned to the main game loop when the next VBI occurs.

**DON'T:**

- Don't have giant DMA operations that extend through one or more VBIs. This may result in a different number of VBIs occurring in each game machine.

- If you decide how many DMA operations you do during a VBI by checking whether vertical blanking is over or not, don't use the number of completed DMA operations in your game logic. For example, you are in the VBI routine, you are doing a number of DMA operations, and before each DMA operation you check to see whether you've run out of vertical blanking time. Because of variances in execution speed, one game machine may report that vertical blanking is over, and the other one may report the opposite. If the main game loop makes game logic decisions based on the number of completed DMA operations, the games will get out of sync.

5.4. **Controller Reads and the Main Game Loop**

**DO:**

- Ideally, read the controllers only once per game loop, before the start of the game loop. It doesn't matter whether you read the controllers during the VBI routine or in the main game loop (although Sega encourages you to read the six-button controllers and the multi-play adapter during VBI).

- Often, a game loop is so long (e.g. 3 frame times or more) that the controllers must be read more frequently than once per game loop to provide adequate responsiveness. There are two approaches to handling this situation:

  (a) sample the controllers each VBI, but create a data structure that reflects the controller behavior through the duration of the game loop (e.g. Up on 2nd frame, A and Right on 3rd frame), then feed this data structure, all at once, into the next game loop. This data structure, rather than raw controller data, will be transmitted to the other game machine, once per game loop. This is the preferred method.

  (b) sample the controllers each VBI, but only feed in the updated controller information at predictable points in the main game loop. For example, if you have 16 objects on the screen that are updated in sequence in the main game loop, and it typically takes 8 frame times to update them all, feed in each VBI's new controller value after every two objects are updated. Take
care to design your code such that the game loop is not usually held up waiting for VBI. There are a number of other subtleties that must be considered since we can't be certain that both game machines will have the same number of VBIs per game loop. Overall, this is a doable, but tricky, solution to the problem.

DON'T:

- Don’t sample the controllers asynchronously to the main game loop and feed in their values at unpredictable points. It is critical that both machines utilize the same controller data for the same game logic. Since VBI will occur at unpredictable points in the game loop, controller values that are sampled at VBI and immediately fed into the game loop may result in differing game logic between the two game machines.

5.5. Game Loop Duration and Game Logic

Game loops typically are longer than one VBI in duration. Unfortunately, it is often very difficult to predict how many VBIs of duration a particular game loop will take, and in fact, for the execution reasons mentioned above, it is quite possible that the two game machines may take a different number of VBIs to execute the same game loop code.

Also, there are situations when the game logic execution is the same on both machines, but the display code execution is vastly different. Point-of-view games, such as racing games, that are split screen when played on a single video game machine, can be full-screen on each game machine when played on XBAND. The game logic is the same, since the state of both players is updated on both machines, but the display code for each player’s point-of-view could be vastly different. Consequently, the execution time per game loop on each machine can be different.

If you can predict the number of VBIs that will elapse in your game loop easily (i.e. both machines can determine in advance the worst case number of frames per a given game loop), that simplifies the synchronization problem significantly. But if you can’t (don’t feel bad, most games can’t), and you need to consider the number of elapsed VBIs in your game logic (e.g. for animation speed regulation), Catapult has developed a synchronization technology that will maintain sync between the two machines, provided you stay within the DOs and DON'Ts guidelines.

DO:

- Ideally, create a game loop with a predictable number of VBIs. For example, if you have a list of routines you need to go through in your game loop, and you have a worst case execution time for each routine, you might be able to determine how many VBIs will pass in the game loop. If you happen to complete
the game loop sooner than worst-case, you would wait it out until the predicted number of VBIs has elapsed.

- If you don’t have a predictable number of VBIs per game loop, and the number of elapsed VBIs is used as part of the game logic (e.g. for animation speed regulation), then make sure that you use a single variable that contains the elapsed VBIs of the previous game loop. This variable will be controlled by a synchronization mechanism available from Catapult to maintain synchronization between the two game machines.

DON’T:

- Don’t use the number of VBIs elapsed in the current game loop in your game logic. If you need to use elapsed VBIs for speed regulation, use the elapsed VBI count from the previous game loop, and make sure you use a single variable to store the value.

5.6. Using Sync-O-Tron™

Sync-O-Tron is a technology developed by Catapult that maintains synchronization between the VBIs of two video game systems. The technology is available for your use by your game while it is running on the XBAND Network. It provides two key advantages.

First, Sync-O-Tron often simplifies the development of synchronized game loops. Without Sync-O-Tron two free-running game machines can drift apart by an entire frame within 2 minutes. With Sync-O-Tron you are guaranteed that both game machines will always be frame synchronous to each other.

Second, Sync-O-Tron reduces communications latency. Without Sync-O-Tron there might be as much as a full frame of skew between the two game machines. To allow for this worst-case scenario it is necessary to add an additional frame of latency to the communications. With Sync-O-Tron there is always a fixed relationship between the VBIs of the two systems and minimum latency can be achieved.

Sync-O-Tron requires a very small routine that runs in VBI once per game loop.
6. User Interface Considerations

When a multi-player game is played over a telephone line by people who don't know each other (and can't talk to each other), there are a number of user interface issues that need to be considered. Although it is possible to get existing multi-player games to run "as is" on XBAND, we have found certain user interface changes are essential to avoid disputes between players and dissatisfaction with game play. These issues are discussed below:

6.1. Fair Access to Critical Controls

- Have a means for either player to gain access to critical controls without the other player interfering. Don't create a situation where one player who is faster at pushing buttons can prevent another player from accessing an important control screen.

- Have a reasonable time-out for every screen so that players don't tie up the game indefinitely. Don't create a situation where both players are required to push a button for the game to continue. One player may deliberately try to delay the game just to be obnoxious. Also, sometimes players are out of the room when the game starts up (which means they forfeit). It is fair that one player should be able to play the game from beginning to end if the other player is not there.

6.2. Tournament Mode

- Provide a tournament mode which has locked game play options (e.g. fixed game duration, secret power-up codes disabled, battery-backed cartridge RAM disabled, etc.). Don't leave it up to the players to amicably agree on settings for modem play. Decide on what is an appropriate tournament configuration, and lock it down.

- Make sure any options that should be available during a tournament should be settable by team. Don't provide options that affect both teams in tournament mode. The players will literally go back-and-forth, fighting over the option screen. If options can't be settable by team, then lock it down to a fixed setting.

6.3. Non-gameplay Features during Gameplay

- Provide reasonable limits to non-gameplay features that may delay the game (or annoy the other player). For example, if you provide an instant replay feature, you might want to limit each player to one instant replay per quarter. Don't expect the players to discipline themselves in the use non-gameplay features. When they are losing, some players will do anything to annoy the winning players.
6.4. Call Waiting and Line Noise Dialog Boxes

- Provide a means to display text during gameplay to alert the player about Call Waiting or Line Noise. The text will only be displayed when the game is frozen, so if characters need to be moved off the screen during the display of text, they can be moved back after the text has been removed from the screen. Don’t rely on players to guess what is going on when the screen freezes during a Line Noise event. Also, if you cannot display text during Call Waiting, then the game must be terminated when the Call Waiting event occurs. When the player is done with the phone call, the game must start again from the beginning.

6.5. 4-Player Controller Allocation

- Make sure that during tournament play the controllers are allocated as controllers 1 and 2 against 3 and 4. Although it is interesting to split players in different configurations, it is very confusing, and usually results in players not knowing what is going on. Don’t assume that the players can talk to each other to decide on a controller configuration.

- Make sure that all 4 players have a chance to join in the beginning, but there should be no additions after the game begins. We have found that players get very upset when a person joins in later in the match. Don’t let players join in at any arbitrary time. Limit it to a single screen and make it very clear how many players are playing.

- Ideally, you should have a tournament mode for 1-on-1 and 2-on-(1 or 2). XBAND will eventually provide special matching for people who only want to play 1-on-1.
7. Special XBAND Features for New Games

The following features can significantly add to the game play value of your games, utilizing the special capabilities of the XBAND systems. These are just a few ideas. If you have special needs or a really cool idea, let us know, and we'll see if we can code it into XBAND.

7.1. Full-screen for Point-of-View 2-Player Games

If you are currently splitting the screen in your 2-player point-of-view game, you might consider a full-screen mode when playing through XBAND.

7.2. Updated Stats Throughout the Season

If you are writing a sports game with real players, you can have the player roster updated with the latest trades, injuries, etc. whenever the player logs into the XBAND Server. Catapult is working on content relationships to provide you with this data for your sports games.

7.3. New Levels, Mazes

The XBAND Server can download new levels and mazes for RPG or DOOM-like games, within available RAM constraints.

7.4. Eight-player Games

XBAND can host 4-against-4 games for teams of players using multi-play adapter in each game machine.

7.5. Multi-Way Gaming

In the future XBAND will be able to support multi-way gaming for 10s or even 100s of simultaneous players, competing against each other in the same game.

Contact Catapult for more details if you have a game that would take advantage of this functionality.
7.6. Handicapping

Your game patch can provide information for the XBAND Network to use to handicap players. For example, you could start out a better player in a fighting game with a pre-existing "damage" level, or assign a higher point level to blows he/she receives.

7.7. Bug Fixes

Your Game Patch can include bug fixes to your game. Whether the bugs are crashers or just imperfections that should be fixed, it is trivial to use the Game Patching mechanism to fix the bugs when the cartridge is played on XBAND. Indeed, most of the games running on the XBAND network today have been patched with bug fixes.

7.8. Your Idea Here

If you’ve got a unique idea for information to store on the XBAND Server and integrate with your XBAND savvy game, we’re interested in hearing it. Contact Developer Relations at (408) 366-1735.

XBAND, BANDWIDTH and Sync-O-Tron are trademarks of Catapult Entertainment, Inc. All other trademarks are of their respective owners.
Addendum 1 - Abstract from Page 2

Joysticks/Peripherals

It is possible to connect various peripherals to the I/O port other than joysticks. Each peripheral has its own ID code and it is possible for the CPU to check the code to identify what is connected. Be aware that there are some Master System peripherals which cannot be identified by this method.

S1 ID Code

The ID code for the external ports CTRL1, CTRL2, and EXT, which correspond to the I/O port's DATA 1, 2, 3 (PD3, PD2, PD1, and PDO) are shown by a logical "or" operation. In concrete terms, setting the TH pin to output mode and outputting either 1 or 0 as data will yield the following:

\[
\begin{align*}
ID3 &= (PD6 = 1) \text{ AND } (PD3 \text{ OR } PD2) \\
ID2 &= (PD6 = 1) \text{ AND } (PD1 \text{ OR } PDO) \\
ID1 &= (PD6 = 0) \text{ AND } (PD3 \text{ OR } PD2) \\
IDO &= (PD6 = 0) \text{ AND } (PD1 \text{ OR } PDO)
\end{align*}
\]

The relationship between the ID code and the peripheral hardware is shown below:

<table>
<thead>
<tr>
<th>Device Name</th>
<th>ID3</th>
<th>ID2</th>
<th>ID1</th>
<th>ID0</th>
</tr>
</thead>
<tbody>
<tr>
<td>Old style joystick (2 trig)</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>Undefined</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>New style joystick (3 trig)</td>
<td>1</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Sega Reserved</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>Undefined</td>
<td>1</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>Undefined</td>
<td>1</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Sega Reserved</td>
<td>0</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>Sega Reserved</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Undefined</td>
<td>0</td>
<td>1</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Undefined</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>Sega Reserved</td>
<td>0</td>
<td>0</td>
<td>1</td>
<td>0</td>
</tr>
<tr>
<td>Sega Reserved</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>1</td>
</tr>
<tr>
<td>Sega Reserved</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
<tr>
<td>Sega Reserved</td>
<td>0</td>
<td>0</td>
<td>0</td>
<td>0</td>
</tr>
</tbody>
</table>
Addendum 3- Abstract From Page 1

1) When the Z80 Cannot Do a 68000 Bus Access

There are times when the Z80 cannot read or write good data in the 68000's addresses. If the the 68000's bus cycle accesses $A100XX prior to the Z80's interrupt, the bus cycle for the Z80 interrupt is shortened. When this occurs, the Z80 cannot read or write good data.

When the 68000 is accessing $A100XX

1) A BUSREQ is sent to the Z80. (Stops the Z80 bus access- $A11100= 0100H)

2) $A100XX is accessed.

3) The BUSREQ from the Z80 is cleared. (The Z80 begins bus access- $A11100= 0000H)

Change the 68000's programs to follow the steps shown above.

Miscellaneous

If the program structure uses something like V_INT for sync, there should be no problems as long as it is set up so that unfavorable bus access patterns are not created.
Addendum 3 - Abstract from Page 2

2) When Using H_INT and V_INT with a Genesis Program

When the VDP register #0's IE1=1 and register #10=00H, H_INT and V_INT are created with the timing scheme described below. However, a problem occurs during No. 224 H_INT's timing. Since the amount of time which is available before V_INT is only 14.7 μs, the acceptance of the No. 224 H_INT means that the V_INT will miss the V_INT occurrence period. As a result, V_INT is cancelled. Moreover, when the V_INT is cancelled, the No. 225 H_INT occurs instead of the V_INT.

Solution A

1) Set register #0's IE1=0 before No. 223 H_INT ends in order to prevent No. 224 from occurring.
2) Set register #0's IE1=1 before V_INT is accepted in order to make H_INT valid (i.e. No. 224 also becomes valid.)
3) Process No. 224 H_INT.

Solution B

1) Set the 68000's SR=25XX before No. 223 H_INT ends in order to prevent No. 224 from being processed.
2) Restore the 68000's SR prior to the end of V_INT processing (Enables No. 224 processing).
3) Process No. 224 H_INT.

Warning: When manipulating SR, make sure not to destroy the flag.
Diagram of the Problem Caused by a Multiplication Command

1) The MOVE command given after multiplication readies the 68000 to process H_INT.

2) The 68000 creates a VPA (INT_ACK). Since the VDP (for processing No. 224) does not see a VPA after H_INT occurs, H_INT is not processed. After V_INT occurs, the 68000 receives a VPA and mistakes this for V_INT processing. H_INT is stored.

3) Processing is executed since H_INT (No. 224) was received in part 1).

4) Given a RTE after processing H_INT, the 68000 readies to process H_INT again.

5) The 68000 creates a VPA (INT_ACK). The VDP (equivalent to No. 225) processes the stored H_INT.

6) Receiving H_INT (No. 225) in part 4), processing occurs again.
Addendum 3- Abstract from Page 4

4) The Interrupt Problem During Data Transfer

Part 2) discussed the problems encountered when using H_INT and V_INT in a program. The same kinds of problems occur during a) an INT involving H_INT data reception; and b) an INT involving V_INT and data reception (Refer back to part 2) for details).

The "INT during data reception" does not occur in sync in relation to V_INT and H_INT, therefore the solutions to the problem are different.

Solution in the Case of a)

During data reception, the receive flag is set at the same time of the INT. The receive flag is cleared when the data is read by the "INT during data reception" which does not overlap with H_INT. When H_INT occurs again, it overlaps and passes as the second "INT during data reception." After this occurs, the receive flag is left in clear status.

Solve the problem by discriminating between the "INT during data reception" and the H_INT which passes as the "INT during data reception." This can be determined by checking the status of the receive flag.

Solution in the Case of b)

Set the mode which prevents the occurrence of V_INT's and then use the VDP's V_BLK status bit to detect V-timing. Use this method to perform the same type of processing as V_INT

Miscellaneous

It is possible to differentiate H_INT and V_INT timing by using H_BLK, V_BLK, and the HV_counter.

It is possible distinguish between the "INT during data reception" and the "H and V that pass as the INT during data reception" by analyzing the receive flag.

Try to think of other solutions by using IEO, IE1, and IE2 settings within the VDP register.
Addendum 4

I. Regarding the DMA

When using DMA's other than FILL VRAM and VRAM COPY, use the following method to program.

1) Send a bus request to the Z80.
2) Base the DMA destination address set section in RAM.
3) Rewrite the one leading word of data after the end of the DMA.

1) and 2) are used in all cases except FILL VRAM and VRAM COPY.
3) is used for WRAM to VRAM, WRAM to COLOR RAM, and WRAM to VSRAM.

II. Compatibility with the MKIII Mode

VDP registers #11 through #23 cannot be written over unless bit 2 of register #1 is not set to "1."

Reasons:

- Registers #11 through 23 are masked for MKIII mode's error trapping purposes.
- MKIII uses registers #0 through #10.
- The Genesis mode is active when register #1's bit2=1.
- The registers are set to 0 on power up.

IV. Warnings Regarding Use of Back Up RAM

- The back up RAM data is unformatted when the cartridge (product) is shipped. Always make sure to initialize during power up (in most cases the back up RAM data is cleared with $FF at the factory, however, don't count on this as a matter of fact.).
- Although this does not occur frequently, there may be occasions when the data becomes garbled. Because of this possibility, make sure to check the back up data and perform reproduction/retrieval processing. Moreover, do not place critical data at leading and ending RAM addresses since one word in both addresses have a high probability of becoming garbled.
SEGA SOFTWARE DEVELOPMENT
AND GAME STANDARDS

The following Sega of America Game Standards Policy should serve as a guideline for the development of Sega licensed cartridges by defining the types of content and themes inconsistent with Sega's corporate, marketing, and product development philosophy. SOA will not approve cartridges (i.e., audio visual work, packaging and instructions manuals)

- with sexually suggestive or explicit content;
- which reflect ethnic, racial, religious, nationalistic or sexual stereotypes or language;
- which depict excessive graphic violence;
- which use profanity in any form or which incorporate language that could be offensive by prevailing public standards and tastes;
- which encourage or glamorize the use of drugs, alcohol, or tobacco;
- which make an overt political statement;
- which contain depictions of symbols or groups which are an anathema to racial, religious or ethnic groups.
- which is a potential infringement of a legally protected copyright, or trademark

It is not possible for a single document to cover every possible eventuality in an area as broad and subjective as thematic content. For this reason, these standards of guidance should be one of common sense, practicality and prevailing public taste.
GENESIS SOFTWARE DEVELOPMENT STANDARDS

Revised 01/03/91

I. INITIAL DISPLAY

A. The trademark, "SEGA TM", shall be displayed in the center of screen. Logo code will provided by SEGA.

B. Check the control pad(s) while SEGA logo is displayed. If no control pad is connected, or only the 2P control pad is connected, make the loop as follows:

SEGA logo – Title – Demo – SEGA logo

(While no button is pressed.)

If the START button on either controller is pressed, the game title should be displayed. If the Player 1 controller is connected, a button press will exit from the Logo to the title. Another press should exit the title.

II. TITLE DISPLAY

A. Display the title sequence and the text, "PUSH START BUTTON". If any button on either controller is pressed at this point, the Start/Option Select screen shall appear.

B. Copyright marking (user can exit via any button, but can not bypass altogether.)

1. Original software
   ©, the year of publication, Copyright holder,
   e.g., ©1990 SEGA

2. Licensed software
   e.g., ©1987 TEKKON
   PROGRAMMED GAME © 1990 SEGA
   (or as required by contract.)

C. After the title sequence the screen automatically proceeds to the demonstration mode within 5-10 seconds.

III. DEMONSTRATION

A. If the player does not start the game during the title screen (5-10 seconds), the screen shall proceed to the demonstration.

B. Turn on the sound. (If not already on)

C. If the START button is pressed during the demo, the Logo screen shall appear again.
D. If the START button is not pressed during the demo, the SEGA logo shall appear after a certain time.

**POWER ON**

SEGA

SEGA logo screen

When the START Button is pushed or after an interval of about 2 seconds.

CHAMPION
FINGER
WRESTLING

**PUSH START BUTTON**

©1990 SEGA

©Copyright notice

If START button pressed, go on to game screens. Otherwise in approximately 5-10 seconds

**DEMONSTRATION**

10-20 seconds
Return to SEGA logo screen. If START button is pushed, go to Logo screen.

---

**IV. START/OPTION SCREEN**

A. The Start/Option screen is required with the exception of transferred games and games which might lose their game play characteristics by having the screen.

B. Control pad maneuvers and screen display

Selection shall be made by moving D-Button upward or downward or left & right and pressing the START button.
One Player

1 PLAYER START OPTIONS

If the player selects 1 PLAYER START, he can play alone.

Two player simultaneous play

1 PLAYER START
2 PLAYER START OPTIONS

1. 1P control pad only

Although the screen indicates 2 PLAYER START, the cursor shall be controlled so that the player cannot select it. In order to make it clear (whether the player can select or not), different colors should be used.

When the player selects 1 PLAYER START, he can play alone.

2. 1P and 2P control pads

a. When the 1P control pad's START button is pressed:

1 PLAYER START
2 PLAYER START OPTIONS

The player can select all three; however, the player can only play with 1P control pad.

1 PLAYER START - the player can play alone with 1P side.

2 PLAYER START - 2 players can play simultaneously (1P control pad controls the player 1 and 2P control pad controls the player 2).
3. When the 2P control pad's START button is pressed:

**1 PLAYER START**
**2 PLAYER START**
**OPTIONS**

The player cannot select **1 PLAYER START** and he can only control the 2P control pad.

**2 PLAYER START** — 2 players can play simultaneously (1P control pad controls the player 1 and 2P control pad controls the player 2).

4. Two player alternate play (if applicable)

a. 1P control pad only

**1 PLAYER START**
**2 PLAYER START**
**OPTIONS**

The player can select all three.

**1 PLAYER START** — the player can play along with 1P side.

**2 PLAYER START** — 2 players can play alternate with 1P side control pad.

b. Option Screen

<table>
<thead>
<tr>
<th>LEVEL</th>
<th>EASY</th>
</tr>
</thead>
<tbody>
<tr>
<td>PLAYER</td>
<td>5</td>
</tr>
<tr>
<td>SOUND TEST</td>
<td>1</td>
</tr>
<tr>
<td>CONTROL</td>
<td>A JUMP B SHOT</td>
</tr>
<tr>
<td></td>
<td>C SHOT</td>
</tr>
<tr>
<td>RAPID</td>
<td>ON</td>
</tr>
<tr>
<td>EXIT</td>
<td></td>
</tr>
</tbody>
</table>

When the player selects OPTIONS on the Start/Option screen, the option screen shall appear.

The player can select items by pressing D-Button upward or downward and change by pressing D-Button sideways.
How to return to the title or option screen:
Select EXIT and press A, B, or C button or press the
START button (the placement of cursor should not
matter).

The following options shall be implemented when
applicable:

LEVEL - Difficulty setting
PLAYER - Number of players
SOUND TEST - Sound test
CONTROL - Control setting
RAPID - Continuous shooting setting

V. PASSWORD/NAME ENTRY SCREEN

A. Select a clear font so there will be no confusion.
   e.g., O, O, O, and Q, l and l

Passwords should be 12 characters or less. It is a
good idea to subgroup them and use different
colors for each. Do not use punctuation marks or BOTH
upper and lower case letters.

B. Maneuver

   PASSWORD

   1. To enter password or name, select letters by D-
      Button and enter by button C.
   2. When finished, put the cursor on END.
   3. To delete letters, hold button C and move the
cursor by the D-Button or use RTN(return) and
   PCD(proceed) function.
   4. Even if the password is wrong, the letters entered
      Shall not be erased.
   5. Movement of the cursor shall be a loop (up-down-
      left-right).

VI. RESET/PAUSE

A. When the reset button is pressed, during DEMO, the
   screen shall return to SEGA logo (the high scores, the
   option settings, and the password should not be
cleared).

B. During the play, the start button shall work as the
   pause button. During the 2 player simultaneous play,
   both control pads shall be able to pause and cancel.
C. During pause, the sound shall be silenced. The background music only shall continue immediately when the pause is released.

D. The pause function shall not work when the SEGA logo or the title logo are displayed or during the demonstration.

E. **PAUSE** shall be indicated on the screen during the pause.

**NOTE:** Adventure and role-playing games may not require the pause mode.

**VII. BASIC MANEUVERS DURING THE GAME PLAY**

A. General Maneuvers (may vary based on specific requirements of individual games)

START Button  Start/Pause.
D-Button Used to determine the directions.
Button A Special functions and rare maneuvers.
Button B Passive maneuvers such as CANCEL.
Button C Active maneuvers such as DECIDE.

B. Sample Quick Maneuvers for action and shooting games

1. 2 actions (e.g., Ghouls 'n Ghosts, Thunder Force II)

   Button A  Jump/Sub Shot
   Button B  Shot/Main Shot
   Button C  Jump/Sub Shot

2. 3 actions (e.g., Trojan, Altered Beast)

   Button A  Punch
   Button B  Kick
   Button C  Jump

C. Sample Slow Maneuvers for role-playing, simulation, and adventure games.

1. 2 actions

   Button A  Decide/Opening windows
   Button B  Cancel
   Button C  Decide/Opening windows
2. 3 actions (e.g., Phantasy Star II)

   Button A  Check Special functions
   Button B  Cancel
   Button C  Decide/Opening windows

D. Others

Even if there are two actions for the game, all buttons should be utilized. It is convenient if maneuvers can be changed in the option mode.

VIII. CONTINUE/ENDING

A. CONTINUE

It shall appear when the game is over, if appropriate. (This may not apply to sports or RPG's, etc.)

The CONTINUE shall be limited to a certain number of times.

The screen should return to the SEGA logo after 10-20 seconds.

B. The ending screen shall not be canceled, but it can be exited via the START button.

The screen shall return to the SEGA logo after the ending (after 10-20 seconds).

IX. GAME OVER

A. This shall appear for 60 seconds and then the screen shall display SEGA logo.

B. Pressing the START button while GAME OVER is indicated shall cause the screen to change and show the Sega logo.

X. CONTENTS OF THE GAME

A. For important indications such as the score, there shall be a two cell margin on the right and left side and a one cell margin on the top and the bottom of the screen (some monitors do not show these areas well). Do not put important score, text or time information in the top, bottom, leftmost or rightmost row or columns.
B. When background music composed by a third party is utilized, pay careful attention to the copyright in order to avoid any infringement therein. Copyrights shall be secured for all 3rd Party music when applicable.

C. Names which are closely related to any particular manufacturer, product, and character shall not be used.

D. Buttons shall work as soon as they are pressed, not released, unless there is a specific approved reason to violate this rule.

E. The "Start Button" shall work separately from other buttons.

F. Indication of Score and High Score

High scores and previous players shall be up-to-date scores shown on TITLE, DEMONSTRATION screens.

If 2-player game, then both scores shall be displayed simultaneously.

G. Title music shall start when the title appears and finish before the demonstration starts.

H. The title of the game and names used within the game shall not infringe upon the trademarks of Third Parties.

I. At the end of the game, any words or expressions which imply "copyright", "patent", or "invention" shall not be made during credits.

J. Developer credits may be included at the end of the game, subject to approval by SEGA.

NOTE: In the case where any question arises as regards the ITEMS set forth in the SEGA GAME SOFTWARE DEVELOPMENT STANDARDS, or matters for which no stipulation is made, the developer shall, from time to time as required, consult with the SEGA Software Department and resolve said problem subject to the outcome of such consultation.
II. Corrections to the Manual

When discussing VRAM, CRAM, VRAM access, the manual states in pages 22 through 27 that byte access is possible, however, in reality this is false. The reason for this is that after the VDP address register is set, an instruction for a CPU word access (ex. a fetch operation) causes the VDP to think during the next access that it is still a word access.

From now on, please consider the text regarding byte access in pages 22-27 as being null and void.

Corrections to Mega Drive Addendum 6, Page 3

III. About Control Pads

Although the control pad is designed and produced so that simultaneous up/down or left/right input is impossible, there are times when simultaneous input occurs due to fatigue of the internal rubber pads or force on the pads which exceed design specs. Because of this, from now on, all software should have switch read routines that can process simultaneous directional input.

Corrections to MD Manual Page 77

IV.

Although the manual states that the 68000 may set the bank registers, however, in reality, this is not the case. Please execute bank switching in the 260 from the 280.

---

Translator's note: The page numbers are from the original Japanese-language manual.
1) Software Guidelines

1) When accessing the Z80 area from within the 68000's main routine, beware of the following:

- Execute a bus request to the Z80.
- Confirm execution.
- An interrupt occurs.
- A Z80 bus request is executed within the interrupt routine (ex. for the purpose of reading the controller pad).
- The bus request is cleared within the interrupt.
- Return to main routine.

In principle, the Z80 is left with the Z80 bus request in effect, however, in this example, it is cleared in step 5).

When this occurs, the following things occur:

- The RAM of the Z80 gets damaged.
- Incorrect data is read during Z80 bank access.

2) Problems during sound access

1) Sound output stops during the game.

Diagnosis of the problem:

The busy flag was read in the FM sound generator YM2612 like this (address 4001H was accessed in the Mega Drive):

\[
(CS, RD, WR, A1, AC) = (0, 0, 1, 0, 1)
\]

However, in the case of the YM2612, its output is not regulated according to the conditions set up above. This results in the device being read as "not busy" and as a consequence, ends up outputting sound.

The fix for the problem:

When the FM sound generator's busy flag is read, do not access anything else other than

\[
(A1, AC) = (0, 0)
\]

(Mega Drive address 4000H).
3) Repeated Resets

1) The software goes out of control when resets are repeated.
   - **Diagnosis of the problem:**
     - When the reset occurs, the CPU is reset, however, the VDP is not reset.
     - When the reset occurs during DMA, the VDP continues the DMA.
     - The VDP is accessed right after the reset; if this is done while the VDP is executing a DMA, then this access becomes ineffective.
   - **The fix for the problem:**
     Before accessing the VDP after the initialization program (ICD_BLK4), check the DMA BUSY status register. If a DMA is being executed, do not attempt to access.

2) The problem still persists even after the precautions above are taken.
   - **Diagnosis of the problem:**
     The problem will occur when the reset takes place between the period of time when the CPU has finished setting the parameters to execute the DMA and the actual execution of the DMA itself.

   ![Diagram]

   - **The fix for the problem:**
     On top of the precautions taken in 1), as an example, make sure not to execute a DMA right after a reset.
MEGA DRIVE TECHNICAL MEMO #4

- WAIT during Mega Drive VRAM READ

In the Mega Drive, during VRAM READ, when the following conditions are not met, data may not be read correctly.

**During display period and H-blank**

VRAM Address Set

\[\Downarrow\]

VRAM READ

\[\Downarrow\]

WAIT exceeding 116 CPU clock cycles

\[\Downarrow\]

Next VRAM Address Set

**During V-blank**

VRAM Address Set

\[\Downarrow\]

VRAM READ

\[\Downarrow\]

Wait exceeding 12 CPU clock cycles

\[\Downarrow\]

Next VRAM Address Set

As seen above, after the last VRAM READ is completed, WAIT is required before the next VRAM address is set. With respect to VRAM READ, it can be read continuously.
• **SUPER TARGET IC 19**

When 68000 CPU accesses an illegal area, “DATA ACKNOWLEDGE” signal may not be sent back - causing “hang up” in the production unit. Depending on some ROM emulators or ICE (+SUPER TARGET), even the emulator may hang up. To avoid such hang ups, measures have been taken so that SUPER TARGET would return ACKNOWLEDGE signal to the CPU without system hang ups. This is done via IC 19. As a result, due to this IC function, for SUPER TARGET to function normally, the hang up occurs in the production unit. Please take the following steps to correct the problem:

1. Before checking the software through SUPER TARGET + CPU, remove IC 19 from the socket.

2. When using ICE (ROM emulator), IC 19 may be removed. Reinstall the IC should ICE (ROM emulator) act abnormally.

3. The above measures are common with the MEGA DRIVE and the MEGA CD.
Scot:

Here is what I discovered in the past couple of days while working with the Scaling Hardware.

Address $FF8002: Memory Mode
  Priority Mode works as follows:
  In Mode OFF all scaled pixel data is written to Image Buffer
  In Write Up mode only non-zero scaled pixel data is written to Image Buffer
  In Write Down mode non-zero data in Image Buffer is not written to by scaled data

Address $FF8058: Stamp Size
  RPT: Repeat
  This bit works exactly opposite as it is documented in the Software Manual on page 19.

Address $FF805C: Image Buffer V-Cell Size
  VCS0-4: Specifies the number of vertical cells MINUS ONE in the image buffer.
  ie. To get a buffer twelve cells tall you would store an eleven.

Trace Vector Info:
  All Vector Values have fractional parts

  Start Position: Has three bits of fractional data
  ie. The Position one is represented by a value of 8

  Deltas: Has 11 bits of fractional data.
  ie. To get a step of one pixel, $0800 would be used

Hope this helps,

Jerry Bennett

If you have any questions give me a call at (818) 774-0600