## Hardware Reference Manual for the SEGA Game Gear Console ## Table of Contents | 1. | Precautions for Hardware 1. CPU clock 2. Memory area unusable area 3. VDP initialization 4. Interrupt | 3<br>3 | |----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------| | 2. | System control port ① I/O port 00H (Read Only) START/PAUSE button, region setting ② I/O port 01H (Read/Write) EXT connector ③ I/O port 02H (Read/Write) NMI ④ I/O port 03H (Read/Write) Serial communications send data ⑤ I/O port 04H (Read Only) Serial communications receive data ⑥ I/O port 05H (Read/Write) Serial communications mode setting ⑦ I/O port 06H (Write Only) Left-right distribution of sound ⑧ I/O port 30H, 31H (Read Only) Loader access (development board only) ⑨ I/O port DCH, DDH (Read Only) JOYSTICK board | 4 4 5 5 6 | | 3. | Material: Using the ROM bank switching and backup RAM A. When the memory capacity is 1 Megabit B. If the capacity is 2 MBytes or more, or a backup RAM is provided. ① Bank control register (FFFCH) ② Bank register 0 (FFFDH) ③ Bank register 1 (FFFEH) ④ Bank register 2 (FFFFH) | 8<br>8<br>9 | | 4. | Material: MAPPING MEMORY MAP, I/O MAP | 10<br>10 | | 5. | Supplementary description for manual A. System control port | 11 11 11 11 12 12 12 | | 6. | VDP Manual (1) GAME GEAR FEATURES. (2) Effective area and LCD display area. (3) Image display. ① Access to VDP. a. Reading the status register. b. Writing to VDP registers (#0 to #10). d. Reading from VRAM. e. VRAM special access. f. Writing to the color RAM. ② VDP register (write only). a. Register #0, register #1 (VDP control) b. Register #2 (pattern name table). c. Register #3. d. Register #4 | 15<br>15<br>16<br>16<br>18<br>19<br>20<br>21<br>21 | | | e. Register #5 (sprite attribute table) | 22 | |----|-----------------------------------------------------------------|----------| | | f. Register #6 (sprite generator table) | 23 | | | g. Register #7 (backdrop color) | 23 | | | h. Register #8 (horizontal scroll) | 24 | | | i. Register #9 (vertical scroll) | 24 | | | j. Register #10 (interrupt) | 24 | | | 3 Standard VRAM mapping | 26 | | | 4 Scroll screen display | 27 | | | a. Pattern name table | 27 | | | b. Pattern generator table | 28 | | | c. Color RAM | 30 | | | ⑤ Displaying sprites | 31 | | | a. Sprite attribute table | 31 | | | b. Sprite generator table | | | | c. Color RAM | 31 | | | d. Sprite coordinates | 32 | | | e. SIZE bit | 32 | | | f. Sprite display limits | 32 | | | 6 H counter, V counter | 33 | | | a. H counter | 33 | | | b. V counter | 34 | | _ | | ٥٦ | | 1. | PSG Manual | 35 | | | [1] Tone generator | | | | (1) Method of calculating the 10-bit frequency division ratio n | | | | (2) Tone frequency setting | | | | (3) Example of frequency setting | | | | a. Calculation of frequency division ratio n | | | | b. Data sent to PSG | | | | (4) Tone level setting | | | | [2] Noise generator | | | | (1) Noise generator circuit control | | | | a. Synchronous noise (FB = 0) | | | | b. White Noise (FB = 1) | | | | (2) Noise level setting | | | | [3] Register address feed | | | | [4] Correlation between the sound elements and PSG | | | | Relation between musical interval and frequency division ratio | 39<br>12 | | | Synchronous noise mode | 47 | ## Precautions for Hardware - 1. CPU clock The CPU clock is 3.579545 MHz. - 2. Memory area unusable area - O DFFOH to DFFFH When a ROM of 1 M or greater is used, the area for bank switching, and so on, is located between FFFOH and FFFH. This area is used for reading (using images) bank data, so do not use it as a normal work area. For this reason, it is necessary to set the stack pointer in such a way that the stack does not use this area. Example: LD SP, ODFFOH - © E000H to FFFFH (excluding the area for bank switching, and so on) This area contains the C000H to DFFFH RAM image. Do not access an image from this area but from the C000H to DFFFH area instead. - 3. VDP initialization Sometimes, when the power is switched ON, the reset of the CPU is canceled while the VDP remains reset. In order to prevent this, confirm that the value of the V counter in the VDP has become BOH and then access the data. Example: INIWAIT: IN A,(O7EH); READ V-COUNTER CP OBOH JP NZ,INIWAIT RET ### 4. Interrupt An interrupt is synchronized with the video timing (at the completion of the effective area or at an arbitrary vertical position). This interrupt uses the Z80 mode 1 interrupt, hence "IM 1" is executed at the beginning of the program. A return from an interrupt routine is "RET". ## System control port ☆ Indicates the state after a power-on reset. ① I/O port OOH (Read Only) Meaningless O STT This is an input from the START/PAUSE button. 0: Switch ON 1: Switch OFF O NJAP 0: This is the domestic (Japan) mode. 1: This is the overseas mode. O NNTS 0: This is the NTSC mode. 1: This is the PAL mode. ② I/O port O1H (Read/Write) This port is used to read/write data when the EXT connector is used as a 7-bit input/output port. (The value after a power-on reset is indeterminate.) ③ I/O port O2H (Read/Write) O DPC6 to DPC0 0: PCx becomes the output. ☆ 1: PCx becomes the input. O NINT 0: When PC6 is input, an NMI is generated at the fall of PC6. $\triangle$ 1: The above operation is disabled. \*\*Be sure to set the status of this port to "1". When using this value, first, set the status to "1" after the first NMI is generated, then subsequently set it to "0". If you fail to do this, the next NMI will not be generated. ④ I/O port 03H (Read/Write) O TD7 to TD0 Used to set the send data during serial communications. ⑤ I/O port O4H (Read Only) | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 | |-----|-----|-----|-----|-----|-----|-----|-----| | RD7 | RD6 | RD5 | RD4 | RD3 | RD2 | RD1 | RD0 | O RD7 to RD0 The receive data is set during serial communications. ⑥ I/O port O5H (Read/Write) Serial communications mode setting | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 | |-----|-----|-----|-----|-----|------|------|------| | BS1 | BS0 | RON | TON | INT | FRER | RXRD | TXFL | - O TXFL (Read) - $\triangle$ 0: The next send data is written. 1: The send data cannot be written yet. - O RXRD (Read) 1: There is receive data. - O FRER (Read) - $\Delta$ 0: There is no framing error. 1: There is a framing error. - O INT (Read/Write) - $^{\star}$ 0: The following operation is disabled. - 1: An NMI is generated when data is received. - $\bigcirc$ An operation such as that of I/O port O2H is unnecessary. - O TON (Read/Write) - ☆ 0: Sending is disabled. - 1: Sending is enabled. (PC4 is forcibly made the output.) - O RON (Read/Write) - ☆ 0: Receive disable. - 1: Receive enable. (PC5 is forcibly made the input.) - O BS1, BS0 Baud rate setting | | B S 1 | BS0 | Baud rate (bps) | |---|---------|---------|----------------------------------------| | ☆ | 0 0 1 1 | 0 1 0 1 | 4 8 0 0<br>2 4 0 0<br>1 2 0 0<br>3 0 0 | | 7 | | -right | | ibutio | n of s | | 5.0 | 5.4 | 5.0 | | |---------------------|------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|--------------------------|------------------------------------------| | | ſ | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 | | | | Į | NOSL | TN3L | TN2L | TN1L | NOSR | TN3R | TN2R | TN1R | | | | 1: TI TN2I 0: TI 1: TI TN3I 0: TI 1: TI NOSI 0: TI 1: TI TN1I 0: TI 1: TI TN2I 0: TI 1: TI TN2I 0: TI 1: TI TN3I 0: TI | ne out L | put of | TONE TONE TONE TONE NOISE NOISE TONE TONE TONE TONE TONE | 1 to t 1 to t 2 to t 2 to t 3 to t 3 to t 1 to t 1 to t 2 to t 3 to t 3 to t 4 to t 6 to t 7 to t 8 to t 9 to t 9 to t | he righe righe righe righe righe lef | ht is ht is ht is ht is ht is t is d t is ettis | enable disable nable isable nabled isable nabled isable | d. ed. d. d. d. d. d. d. | | | o<br>⇔ | NOSI | L | | | 3 to t | | | | | | | ☆ | | | | | to the to | | | | | | | 8 1 | Loadei | r acce<br>D 7 | ss (de<br>D6 | velopm<br>D5 | nent bo<br>D 4 | ard on<br>D3 | lly)<br>D2 | D 1 | D 0 | | | | | LD7 | LD6 | LD5 | LD4 | LD3 | LD2 | LD1 | LD0 | I/O port 30H (Read) | | 0 | | - LDO<br>t data<br>D 7 | which D 6 | is re<br>D 5 | ad fro<br>D 4<br>O | m the<br>D3 | printe<br>D 2<br>CLR | r port<br>D 1<br>BUSY | D O<br>NSTB | I/O port 31H (Read) | | O<br>O<br>O<br>BUSY | BUSY<br>BUSY<br>CLR<br>Load<br>When | signa<br>der cl<br>this | l inpu<br>ear bu | t (act<br>tton i<br>is pr | ctive<br>live Hi<br>nput (<br>essed, | gh)<br>active | | all be | come "( | O", the ACK signal becomes High, and the | | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 | | |-----|-----|-----|-----|-----|-----|-----|-----|----------------------| | * | * | * | * | * | * | * | ACK | I/O port 30H (Write) | O ACK 0: The ACK signal becomes High. 1: The Ack signal becomes Low (active). \* When the strobe signal falls, eight bits of data are latched, and simultaneously the BUSY signal automatically becomes High. Once the data has been read, the ACK signal is made Low, then High once again. The BUSY signal automatically becomes Low. The LED lights when the BUSY signal becomes High. W UP1-1P UP switch DW1-1P DOWN switch LE1-1P LEFT switch RI1-1P RIGHT switch TL1-1P TRIGGER left button WE-EXT UP switch LEE-EXT LEFT switch RIE-EXT RIGHT switch TLE-EXT TRIGGER left button TLE-EXT TRIGGER left button WE-EXT UP switch THE-EXT TRIGGER left button TLE-EXT TRIGGER left button WE-EXT UP switch THE-EXT TRIGGER left button WE-EXT UP switch THE-EXT TRIGGER left button WE-EXT UP switch THE-EXT TRIGGER left button WE-EXT UP switch THE-EXT THE-E TRI-1P TRIGGER right button TRE-EXT TRIGGER right button THE-EXT (Same as PC6 input) One bit is read to port as "1" when either there is nothing connected to the terminal or the corresponding switch is not pressed, and is read as "0" when the switch is pressed. ## Material ## Using the ROM bank switching and backup RAM In this model, the capacity of the memory can vary between 1 and 4 Megabits by bank switching. ### Note: Area 0: 0000 to 3FFF Area 1: 4000 to 7FFF Area 2: 8000 to BFFF The size of one bank is 16 Kbyte. The banks are arranged sequentially in the ROM without overlapping. ### A. When the memory capacity is 1 Megabit Area 0 is fixed to bank 0 (first 16 KBytes of the ROM), and area 1 is fixed to bank 1. Area 2 enables the banks to be switched over by setting a value in register FFFFH. | | | | | | D 2 | | | _ | |---|---|---|---|---|-----|-----|-----|-------| | 0 | 0 | 0 | 0 | 0 | 1/0 | 1/0 | 1/0 | FFFFH | For bank 0, set 00H (same bank as for area 0). For bank 7, set 07H. - B. If the capacity is 2 MBytes or more, or a backup RAM is provided - (1) Bank control register (FFFCH) ### O Bank number offset All of the banks for areas 0 to 2 area shifted by 1 bank group (8 banks) time the value 1 to 3 is set here. If an offset number causes a bank number to exceed 1FH(31), it goes Bank 0. The value set here will become valid when it is subsequently set in one of bank registers 0 to 2. ### O Switching between ROM/external RAM When 0: The ROM (bank) is assigned to area 2. When 1: The external RAM is assigned to area 2 (when an extrenal RAM exists). ### ○ Work RAM selection If 1 is set here, normal access to the work RAM (COOOH to DFFFH) of the main body will be prevented. Be sure, therefore, to set 0. ### O WRITE PROTECT If 1 is set here when the development RAM board is used, data re-write will not take place. Set 0 in mass-production machines. ### ② Bank register 0 (FFFDH) 0000H to 03FFH of area 0 is fixed to bank 0. Bank selection of other areas can be performed by setting a value at FFFDH. | | | | | D 3 | | | | _ | |---|---|---|-----|-----|-----|-----|-----|-------| | 0 | 0 | 0 | 0/1 | 0/1 | 1/0 | 1/0 | 1/0 | FFFDH | For bank 00: Set 00H. For bank 1F: Set 1FH. ### 3 Bank register 1 (FFFEH) A bank selection can be performed in area 1 by setting a value in FFFEH. | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 | | |-----|-----|-----|-----|-----|-----|-----|-----|-------| | 0 | 0 | 0 | 0/1 | 0/1 | 1/0 | 1/0 | 1/0 | FFFEH | For bank 00: Set 00H. For bank 1F: Set 1FH. ### Bank register 2 (FFFFH) A bank selection can be performed in area 2 by setting a value in FFFFH. | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 | _ | |-----|-----|-----|-----|-----|-----|-----|-----|-------| | 0 | 0 | 0 | 0/1 | 0/1 | 1/0 | 1/0 | 1/0 | FFFFH | For bank 00: Set 00H. For bank 1F: Set 1FH. ### Caution: The above registers are not initialized when the power is switched on. For this reason, be sure to initialize them program in 0 to 3FFFH.. (The first 1 KByte is fixed for this purpose.) Sometimes, the work RAM cannot be accessed normally, hence the work RAM (and also sub-routines, ) are allowed to be used after this initialization. When using a backup RAM, do not use the first and last addresses because there is a possibility of the data being changed when the power is switched on. ### Example: | ORG | 00000H | |-----|------------| | DI | | | IM | 1 | | LD | SP,ODFFOH | | | | | LD | A,000H | | LD | (OFFFCH),A | | LD | A,000H | | LD | (OFFFDH),A | | LD | A,001H | | LD | (OFFFEH),A | | LD | A,002H | | LD | (OFFFFH),A | ## Material MAPPING | | MEMORY MAP | | I/O MAP | |---------|----------------------------|-----|--------------------------------------------------------------| | 0000 | Cartridge | 00 | 00,01,02,03,04,05 and 06<br>: Used with system control. | | 4000 | Area 0<br>Cartridge | 4 0 | 7E Read<br>: V counter<br>7F Read<br>: H counter<br>7F Write | | 8000 | Area 1<br>Cartridge | 8 0 | : PSG<br><br>BE and BF<br>: Used with VDP | | C O O O | Area 2<br>8 Kbyte work RAM | C 0 | DC and DD<br>: Used as JOYSTICK inputs. | | E000 | Top image | FF | | Never access data using an image address. ## Supplementary description for manual - A. System control port - ③ I/O port O2H (Read/Write) - \* Normally, be sure to make the status of this port "1". When using this value, first, set the status to "1" after the first NMI is generated, then subsequently set it to "0". If you fail to do this, the next NMI will not be generated. ### Addition: An NMI is enabled after the execution of one command from when the port is set to "0". This is to prevent the NMI from becoming active once again in the NMI routine. Normally, therefore, perform the following processing. ### ; An NMI is enabled after this command. - B. System control port - ⑥ I/O port 05H (Read/Write) Mode setting for serial communications - \* INT - \* There is no need to perform an operation such as that of I/O port 02H. ### Addition: When using this function (serial communications NMI), set NINT of I/0 port 02H to the disable state ("1"). An NMI will be generated at the fall of the pulse at the NMI terminal. If, however, a serial communications NMI is generated, the NMI terminal will go LOW, preventing the next NMI from becoming active. The NMI terminal is made HIGH as a result of reading the data of I/0 port 04H, so read the data each time an NMI is generated. If it is conceivable that the NMI terminal may already be LOW at the start of the communications, perform a "dummy" read operation once. - C. System control port - 7 I/O port O6H (Write Only) Left-right distribution of sound Supplementary explanation. When the headphones are plugged in, the output from the speaker is cut off and instead the sound will be heard in stereo from the headphones. When the earphones are not plugged in, the sound will be heard from the speaker in monaural. In the latter case, the distribution of the sound from all channels (three tones & noise) will be enabled. If the output from the left and right channels was disabled not by attenuator control but by distribution, the sound will not be heard from the headphones but will be heard from the speaker. To turn off both the left and right channels of the speaker, use the PSG, by PSG side control. ### D. Communications ① Connecting the communications cable Cross-connect the game gear communications cable as shown below. ### Communications connector | 1 | P C O | <br>To opposite side PC2 | |-----|-------|--------------------------| | 2 | PC1 | <br>To opposite side PC3 | | 3 | PC2 | <br>To opposite side PCO | | 4 | PC3 | <br>To opposite side PC1 | | 5 | + 5 V | | | 6 | P C 4 | <br>To opposite side PC5 | | 7 | PC6 | <br>To opposite side PC6 | | 8 | GND | <br>To opposite side GND | | 9 | PC5 | <br>To opposite side PC4 | | 1 0 | NC | | ### 2 Parallel communications PCO to PC6 can be set to an arbitrary input or output by means of the control register of the I/O port. Be sure to set the connecting terminals so that the terminal on one side is the output, and that on the opposite side is the input. (Never make the terminals on both sides the output.) In the case of parallel communications, control the exchange of data either by polling using software (check the data), or by applying an interrupt (NMI) using PC6. When applying an NMI using PC6, however, it is necessary to take noise into account because an NMI will be generated by a momentary change in PC6. ### ③ Serial communications Serial communications can be performed in one of two single directions, from PC4 (output from one's own side) $\rightarrow$ PC5 (input to opposite side), or from PC5 (input to one's own side) $\leftarrow$ PC4 (output from opposite side). Serial and parallel conversion and interrupt (NMI) generation (when data is received) accompanying the receiving or sending of data take place automatically when the hardware is connected to these terminals. To perform serial communications, set TON and RON of I/O port 05H to "1". By doing this, PC4 will automatically become the output, and PC5 the input. These settings will take priority over the PC4 and PC5 input/output settings. Bits other than those of PC4 and PC5 will become the settings of I/O port 02H. (Like (2), never make both terminals the output.) When performing serial communications only, be sure to set NINT of I/O port 02H to prevent PC6 from generating an NMI. ### 4 Coexistence of parallel and serial communications When performing serial communications, PC4 and PC5 are used to send and receive serial data. Parallel communications can be performed using the bits other than these. An NMI can be generated by PC6 and also by receiving of serial data. In the former case, care must be taken because PC6 does not have a data receiving flag such as the serial RXRD. The blocks of the circuit used to generate these NMI are shown below. Flip-flop for serial communication An NMI is generated when one of the two reset flip-flops is set. (This is because an NMI is generated not when the pulse level is LOW but when the pulse falls.) It should be appreciated that it is necessary to reset the set flip-flop so that the next NMI can be generated. ## VDP Manual - (1) GAME GEAR FEATURES - \* 16-kbyte VRAM - \* Scroll SCREEN: Horizontal 20 cells x vertical 18 cells (one cell = 8 x 8 dots) The virtual area is 32 cells in the horizontal direction x 28 cells in the vertical direction, permitting smooth scrolling in the horizontal and vertical directions. - \* The scroll screen can be left-right reversed, and up-down reversed, and also its priority with respect to sprites can be selected. - \* 64 colors out of a total of 4096 colors can be displayed for each dot of the scroll surface. By designating a palette for each cell, two kinds of 16-color groups can be selected. - \* Sixteen sprites (movable objects) can be displayed on a single screen. Up to eight sprites of either $8 \times 8$ dots or $8 \times 16$ dots (vertical) in size can be selected on the same horizontal line. - \* Sixteen colors out of a total of 4096 can be displayed for each dot of a sprite. - \* The maximum number of character pattern definitions (8 $\times$ 8 dots) is 448 for both the scroll surface and sprites (256 of these are used for sprites, however this is reduced to 128 for 8 $\times$ 16 sprites). ### (2) Effective area and LCD display area This VDP was initially designed on the basis of a TV (NTSC) format, hence only a portion of the picture created by the VDP is displayed on the LCD. This relationship is shown in the figure below. Consequently, when a developing board or TV adapter is installed, the LCD display part will appear on part of the screen, and the backdrop color will be displayed on the remaining part. (Set to a color approaching that of a game screen.) When the screen is ON and timing is in the effective area, the VDP will generate an image, hence (even for a part which is not displayed on the LCD) if timing is within this area, the game program will be subjected to various restrictions (wait condition, etc.). ### (3) Image display Note: In the following description, there are bits that are fixed at "0" or "1", and should remain in this default position. ### Access to VDP It is necessary to set data in the VDP register, color RAM, VRAM, and so on, in order to display an image on the screen. This is because data cannot be accessed directly from the CPU, and must be accessed instead via the VDP assigned to the I/O port. ### a. Reading the status register The status register indicates various states of the VDP. It can read the CPU by reading the I/O port BFH. This register can read the CPU at any time without any need to take account of the VDP delay. ### O Interrupt flag (F) This flag is "1" when the effective area is completed. If, at this time, the IE bit of the VDP register #1 is set to "1", the interrupt line from the VDP to the CPU will become Low, causing an interrupt to be applied (generally called a V interrupt). If the program leaves the interrupt routine in this state, the interrupt will be applied again immediately (an interrupt of Z80 will not occur at the edge of plus, hence the status register will be read at the beginning of the interrupt routine and the flag will be reset. ### Example: ORG 00038H PUSH AF IN A,(OBFH) ; RESET STATUS FLAG ; POP AF EI RET \* This flag is not set in the case of an interrupt (normally called an H interrupt) at an arbitrary vertical position, hence by checking this flag it is possible to identify two kinds of interrupts. A Z80 interrupt uses mode 1, hence "IM 1" is implemented. ### O 9th sprite (9S) If the 9th and higher sprites exist on the same horizontal line (in the effective area), and the interrupt flag (F) is "0", the 9S bit will be set to "1". (within the effective area) ### O Collision flag (C) This flag is set to "1" if dots of color codes other than 0, of two or more sprites collide (coincide). —In the effective area \* The above flags are reset by a power-on reset and a status register read-out, and are renewed each frame. Once a flag is set, it will not be reset again apart from a power-on reset, so long as the status register is not read. For example, if sprites overlap each other, the collision flag will be set, however if the status register is not read, the flag will remain set even if the sprites subsequently seperate from each other. ### b. Writing to VDP registers (#0 to #10) A selection of the display mode or other functions and also data for each base address setting are written to the VDP registers (write-only registers). Data transfer from the CPU takes place in the following format. Data can be written to these registers without any need to take account of VDP delay. | | b7 | b6 | b5 | b 4 | b3 | b 2 | b1 | b0 | |-----------------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----| | First byte: Data set in the register (I/O port BFH) | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | 0 0 | | Second byte: Register Selection (I/O port BFH) | 1 | 0 | 0 | 0 | R 3 | R 2 | R 1 | RΟ | To set data in a VDP register, the data is inputted in the first byte. The second byte is used to indicate the register where the data is to be transferred. The bottom four bits (R3 to R0) of the second byte designate the data transfer destination registers (#0 to #10). b7 must be "1" and b6 to b4 must be "0". Never attempt to access registers that do not exist (#11 to #15). Example: When setting EOH in register #1 [IN A,(OBFH)] ; INITIALIZE LD A,0E0H OUT (OBFH),A ; DATA LD A,081H OUT (OBFH),A ; REGISTER NO. \* The logic inside the VDP determines whether data sent to the VDP is the first byte or the second byte. This internal logic is set to receive the first byte in the following cases. - O After a power-on reset - O After the status register has been read - After the second byte has been written - I/O port BEH write or read (VRAM or color RAM access) Consequently, if data is written in the correct sequence, [IN A, (OBFH)] in the previous example can be omitted. Here, it is necessary to take steps to prevent the CPU from accepting an interrupt while data is being written to a register or VRAM address setting is being carried out (described later). If an interrupt is applied after the first byte has been sent, the data will fail to be transferred correctly if the status register is read during the interrupt (the second byte written after the program leaves the interrupt routine will be received as the first byte. ### d. Reading from VRAM The CPU reads data from the VRAM via the VDP. The addresses are auto-incremented. (See sub-section "Writing to VRAM".) | | b7 | b 6 | b 5 | b 4 | b 3 | b 2 | b1 | b0 | |-----------------------------------------------------------------------------|-----|-----|------|------|------|------|-----|-----| | First byte: Address set-up (I/O port BFH) | A 7 | A 6 | A 5 | A 4 | A 3 | A 2 | A 1 | A 0 | | Second byte: Address set-up (I/O port BFH) | 0 | 0 | A 13 | A 12 | A 11 | A 10 | A 9 | A 8 | | Third byte: Write Data<br>(I/O port BEH)<br>Necessary number of repetitions | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 | The bottom eight bits of the VRAM address are set up by the first byte. The top six bits are set up by the second byte. Be sure to set b7 and b6 to "0". The data is read by the third byte. Once the address register has been set up, the data will be incremented automatically each time the third byte data is transferred. O A delay time is necessary for the CPU to read data from the VRAM. A wait of at least 28 clock pulses is necessary during the first third-byte transfer after the completion of address setting prior to a read operation (this is slightly different to the case of a write operation to the VRAM). Insert the same wait for reading the subsequent third bytes. This applies only to cases where the VDP displays a picture (effective area). In the following two cases, there is no need for any wait whatever. (This is the same as for a write operation to the VRAM.) - O When the blank bits of the VDP register #1 are set to "0" and the screen is turned OFF. - O During the interval of 4.3 m from when an interrupt occurs upon completion of the effective area until the commencement of the next effective area. Example: Write two addresses continuously from VRAM address 0000H. (effective area & screen ON) LD A,000H OUT (OBFH),ALD A,000H OUT (OBFH),A; WAIT 15 CLOCK PUSH ΙX P<sub>0</sub>P TOTAL 29 CLOCK ΙX ; WAIT 14 CLOCK A,(OBEH) IN PUSH ΙX ; WAIT POP ; WAIT ΙX ΙN A,(OBEH)**PUSH** ΙX ; WAIT POP ΙX ; WAIT ### e. VRAM special access If data is written to a VRAM using address auto increment, it will be written to a continuous address. Data can be written to discrete addresses by dummy reading it. Observe the wait conditions while a screen is being displayed in the effective area. Example: Write 256 bytes 01H to each address from VRAM address 3800H. ``` (effective area & screen ON) LD A,000H OUT (OBFH),A LD A,078H OUT (OBFH),A LD B,000H LOOP: LD A,001H 7 CLOCK TOTAL 41 CLOCK OUT (OBEH),A 11 CLOCK ; WAIT 15 CLOCK PUSH ΙX POP ΙX ; WAIT 14 CLOCK TOTAL 29 CLOCK A,(OBEH) ΙN PUSH 11 CLOCK ΑF POP ΑF 10 CLOCK DJNZ LOOP 13 CLOCK ``` O Do not perform irregular access to VRAM (e.g. setting read addresses and writing data to them, or vice-versa). Also, do not use the above method to write data to a color RAM. ### f. Writing to the color RAM The VDP contains a 12-bit x 32-word color RAM. This color RAM is a write-only RAM. The CPU transfers data to the color RAM via the VDP, using an auto increment address register. | | b7 | b6 | b 5 | b 4 | b 3 | b 2 | b1 | b0 | |-----------------------------------------------------------|-----------|---------------|--------------|-----|-----|-----|-----|-----| | First byte: Address set-up (I/O port BFH) | 0 | 0 | A 5 | A 4 | А3 | A 2 | A 1 | ΑО | | Second byte: OCOH set-up (I/O port BFH) | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | Third byte: Write Data (I/O port BEH) Repetition of write | | even a<br>G 2 | | | R 3 | R 2 | R 1 | R O | | necessary number of times | (For<br>O | odd ac<br>O | ldresse<br>O | | В3 | B 2 | B 1 | В 0 | The first byte sets up five bits of the color RAM address. The second byte always sets COH. The third byte transfers data. Once the address register is set up, it is automatically incremented each time the third byte of data is transferred. The color RAM has two addresses (even and odd addresses) which comprise a single color (12 bits). Normally, therefore, the even address is set up, then the R & G data and B data are set in that sequence. Actual writing of data to the color RAM takes place when data is set in the odd address (12 bits of data are written). Note, however, that when the odd address is set up and B data written, the R & G data previously set will be written. O The delay time conditions when the CPU writes data to the color RAM are exactly the same as those for writing data to the VRAM. ### Example: Write OFH & OOH (bright red) and FOH & OOH (bright green) from color RAM address O4H. (effective area & screen ON) ``` LD A,004H OUT (OBFH),A LD A,OCOH OUT (OBFH),A LD A,00FH OUT (OBEH),A ; WAIT 11 CLOCK PUSH ΑF ; WAIT P<sub>0</sub>P ΑF 10 CLOCK LD A,000H 7 CLOCK TOTAL 28 CLOCK OUT (OBEH),A PUSH ΑF ; WAIT POP ΑF ; WAIT A,OFOH LD OUT (OBEH),A PUSH AF ; WAIT POP AF ; WAIT LD A,000H OUT (OBEH),A PUSH ; WAIT 15 CLOCK ΙX ; WAIT 14 CLOCK POP ΙX TOTAL 29 CLOCK ``` O If data is written to the color RAM when a TV scan is on the screen (including the border), the screen will flicker. This cannot be avoided even by setting the BLANK bit to "0" to turn the screen OFF. For this reason, write data to the color RAM during V blanking. - ② VDP register (write only) - a. Register #0, register #1 (These two registers are reset to "0" at power switch-on.) Register #0 | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 | |-----|-----|-----|-----|-----|-----|-----|-----| | MVS | 0 | 0 | IE1 | ЕC | 1 | 1 | 0 | Register #1 | <br>D 7 | | | | | D 2 | | | |---------|-------|----|---|---|-----|------|---| | 1 | BLANK | ΙE | 0 | 0 | 0 | SIZE | 0 | - O EC (Early Clock) - 0: Normal - 1: The horizontal position of all sprites shifts eight dots to the left. - IE, IE1 (Interrupt Enable) - IE is an interrupt enable bit used at the completion of the effective area. - 0: Disable - 1: Enable - IE1 is an interrupt enable bit used at an arbitrary vertical position. - 0: Disable - 1: Enable - O MVS - 0: Normal - 1: The two cells at the right end of the LCD screen are not scrolled in the vertical direction. - A horizontal scroll is not disabled. - O SIZE - 0: Normal - 1: The sprite size becomes $8 \times 16$ dots. In this case, the top seven bits of the character No. are enabled (number of definitions = 128 kinds). - O BLANK - 0: Nothing is displayed on the screen. In this case, the backdrop color is displayed, and the wait used for VDP access is unnecessary. - 1: An image is displayed on the screen. - X The screen display can be turned ON and OFF at any time. #### b. Register #2 (This register is not reset at power switch-on, hence its contents are indeterminate.) This register determines the base address (starting address) of the pattern name table in the V RAM. The pattern name table requires 32 cells (horizontal) x 28 cells (vertical) x 2 bytes = 1792 (700H) bytes. The relation between the set data and the base address is shown below. $((Data) - F1H) \times 400H = Base address$ | Set data | | Base address | |----------|-------------------------------------------------------------|------------------------------------------------------------------------------------------------------| | | F 1 H<br>F 3 H<br>F 5 H<br>F 7 H<br>F 9 H<br>F D H<br>F F H | 0 0 0 0 H<br>0 8 0 0 H<br>1 0 0 0 H<br>1 8 0 0 H<br>2 0 0 0 H<br>2 8 0 0 H<br>3 0 0 0 H<br>3 8 0 0 H | \* Normally FFH is set and the pattern name table started from 3800H. #### С. Register #3 (This register is not reset at power switch-on, hence its contents are indeterminate.) \* Be sure to set FFH in this register with a program. #### d. Register #4 (This register is not reset at power switch-on, hence its contents are indeterminate.) \* Be sure to set FFH in this register with a program. #### Register #5 е. (This register is not reset at power switch-on, hence its contents are indeterminate.) This register determinates the base address of the sprite attribute table in the VRAM. The sprite attribute table consists of 256 (100H) bytes. The relation between the set data and the base address is shown below. ### $((Data) - 81H) \times 80H = Base address$ | Data | Base addr | Data | Base addr | Data | Base addr | Data | Base addr | |-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8 1 H<br>8 3 H<br>8 5 H<br>8 8 7 H<br>8 8 B H<br>8 B D H<br>9 3 5 H<br>9 9 7 H<br>9 9 B H<br>9 9 F<br>9 9 F | 0000H<br>0100H<br>0200H<br>0300H<br>0400H<br>0500H<br>0600H<br>0700H<br>0800H<br>0800H<br>0800H<br>0C00H<br>0C00H<br>0C00H | A 1 H<br>A 3 H<br>A 5 H<br>A 7 H<br>A B H<br>A D H<br>B 1 H<br>B 5 7 H<br>B B B H<br>B B B H<br>B B H | 1000H<br>1100H<br>1200H<br>1300H<br>1400H<br>1500H<br>1600H<br>1700H<br>1800H<br>1800H<br>1B00H<br>1C00H<br>1C00H<br>1E00H | C 1 H<br>C 3 H<br>C 5 H<br>C 7 H<br>C B H<br>C D H<br>C F H<br>D 1 H<br>D 5 H<br>D 7 H<br>D D B H<br>D D F H | 2000H<br>2100H<br>2200H<br>2300H<br>2400H<br>2500H<br>2600H<br>2700H<br>2800H<br>2900H<br>2800H<br>2800H<br>2000H<br>2E00H<br>2F00H | E 1 H<br>E 3 H<br>E 5 H<br>E 7 H<br>E B D H<br>F 1 H<br>F 7 H<br>F 7 H<br>F B H<br>F F D H | 3 0 0 H<br>3 1 0 0 H<br>3 2 0 0 H<br>3 2 0 0 H<br>3 3 0 0 H<br>3 5 0 0 H<br>3 6 0 0 H<br>3 7 0 0 H<br>3 8 | W Normally FFH is set and the sprite attribute table started from 3F00H. ### f. Register #6 (This register is not reset at power switch-on, hence its contents are indeterminate.) This register determines the base address of the sprite generator table. The relation between the set data and the base address is shown below. $((Data) - FBH) \times 800H = Base address$ | Set data | Base address | |----------|--------------| | F B H | 0 0 0 0 H | | F F H | 2 0 0 0 H | ### g. Register #7 (This register is set to "0" at power switch-on.) They are used to set the backdrop color. | D 7 | D 6 | D 5 | D 4 | D 3 | D 2 | D 1 | D 0 | |-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | С3 | C 2 | C 1 | C 0 | There are 40H addresses in the color RAM. Of the 16 sets of color data in addresses 20H to 3FH (palette 1 side), the sets designated by the bottom four bits (C3 to C0) of this register constitute the backdrop color. ### h. Register #8 (This register is set to "0" at power switch-on.) It is used to set the horizontal scroll.) | | | | | | | | D 0 | |-------|-----|-------|-------|-------|-------|-------|-----| | H S 7 | HS6 | H S 5 | H S 4 | H S 3 | H S 2 | H S 1 | HS0 | Each time a value of 1 is set in this register, the scroll screen moves one dot to the right in the horizontal direction. The number of dots in the horizontal direction in the virtual area is 256. Consequently, if a value of -1 (FFH) is set, the screen will move one dot to the left in the horizontal direction. This register is effective only for the scroll screen. It has no effect on sprites. The value written to this register is latched at the timing of the H counter F4H (see "(5) H counter, V counter"), then becomes active. Consequently, horizontal scrolling can be performed one line at a time by using an interrupt at an arbitrary vertical position to re-write the data. ### i. Register #9 (This register is set to "0" at power switch-on.) It is used to set the vertical scroll.) | | | | | | | | D 0 | |-------|-------|-------|-------|-------|-------|-------|-----| | V S 7 | V S 6 | V S 5 | V S 4 | V S 3 | V S 2 | V S 1 | VS0 | Each time a value of 1 is set in this register, the scroll screen moves one dot in the upward direction. The number of dots in the vertical direction in the virtual area is 224. Consequently, if a value of 224 or more is set, the screen will scroll in the upward direction by an amount corres ponding to that value minus 224. Also, the value that was set in this register immediately in front of the effective area (for line 511) will become effective during that frame, preventing the vertical scroll from being changed while display timing. ### j. Register #10 (This register is set to "1" at power switch-on.) It is used to control an interrupt at an arbitrary vertical position. | | | | | | D 2 | | | |-------|-----|-------|-------|-------|-------|-------|-------| | V C 7 | VC6 | V C 5 | V C 4 | V C 3 | V C 2 | V C 1 | V C O | The value set in this register is loaded in the down counter in the VDP. This counter counts down each line. When the count is 0, an interrupt is generated. A count-down takes place only for the line in the effective area and the line immediately preceding it (line 511). For other lines, the down counter simply continues to load the value written to this register without counting down or generating an interrupt. This interrupt is generated during H blanking (H counter F4H), and the value in the register at this time is loaded once again to the down counter. When 00H is set in the register, an interrupt is generated at every line, and when 01H is set in the register, an interrupt is generated at every second line. As an example, consider a method of horizontal scrolling as shown in the figure below. - 1) After completion of the effective area, set "1" in IE1 of register #0, and set OBH in register #10. These values continue to be loaded in the down counter until line 511 appears. - 2) An interrupt is generated after line 10 has been scanned. OBH will be loaded in the down counter once again. The status register is read and the interrupt cleared (this takes place each time), and 00H is set in register #10. - 3) An interrupt is generated after line 22 has been scanned. 00H is loaded in the down counter. 03H is set in register #8 as the horizontal scroll. (It becomes effective for the first time when the next H counter F4H arrives.) - 4) An interrupt is generated after line 23 has been scanned. 00H is loaded in the down counter once again. The interrupt is generated at the timing of the H counter F4H, hence the horizontal scroll 02H set in 3) is also effective at this time. 05H is set in register #8 as the horizontal scroll. - 5) An interrupt is applied after line 24 has been scanned by the horizontal scroll 03H. 00H is loaded in the down counter. The horizontal scroll 05H is effective. 07H is set in register #8, and 5CH (92) is set in register #10. - 6) An interrupt is applied after line 25 has been scanned by the horizontal scroll 05H. A horizontal scroll of 07H is effective, and 5CH is loaded in the down counter. 00H is set in register #10. - 7) The next interrupt is applied after line 118 has been scanned. 00H is loaded in the down counter, then an interrupt is applied at each line. 09H is set in register #8. - 8) An interrupt is applied after line 119, and horizontal scroll 09H becomes effective. The horizontal scroll up to now is 07H. 0BH is set in register #8. Subsequently, "0" is set in IE1 and the interrupt is disabled. - \* The value of register #8 (horizontal scroll) becomes effective after H counter F4H (delayed by one line). Note that in this case the down counter is re-loaded when an interrupt occurs at an arbitrary vertical position. Horizontal scroll between line 26 and line 119: 07H Horizontal scroll between line 121 and line 167: OBH Line 24 horizontal scroll: 03H Line 25 horizontal scroll: 05H Line 120 horizontal scroll: 09H Line 167 lpha Line 24 and line 167 are equivalent to the top and bottom lines, respectively, on the LCD screen. ### 3 Standard VRAM mapping Example: Setting the register HL, TBLREG LD LD B,11 C,080H LD LOOP: LD A,(HL)INC HL (OBFH),A OUT LD A,C INC C OUT (OBFH),A DJNZ L<sub>00</sub>P RET TBLREG: DEFB 036H,0E0H,0FFH,0FFH,0FFH,0FFH,000H DEFB 003H,006H,001H 0000 Pattern generator table The pattern generator table is ( to 37FFH ) the area for defining the characters that are displayed on the scroll screen. 20H is used per character, hence the characters from character 0, character 1, character 2, etc., are located at intervals of 20H from address 0000H. The sprite generator table is the area for defining the characters that are displayed as sprites. Like the pattern generator table, 20H is used per character, hence the characters from character 0, character 1, etc., are located at intervals 2000 of 20H from address 2000H. The part of the VRAM after 2000H is shared, hence character 0 Sprite generator table ( to 37FFH ) of the sprite is the same as character 256 on the scroll screen. Normally, the scroll screen uses color palette 0 Shared part (color RAM addresses 00H to 1FH). and the sprites use palette 1 (10H to 3FH). The program can be displayed in the same color by setting the color palette select bits (CPT) in the pattern name table. The pattern name table corresponds to the cells in the scroll screen. 3800 Pattern name table: It contains in the scroll screen. 32 (horizontal) $\times$ 28 (vertical) $\times$ 2 = 1792 bytes. This is the sprite control area. Two bytes per cell Sprite attribute table 3 F 0 0 3 F F F - 4 Scroll screen display - a. Pattern name table The pattern name table starts from the position determined by register #2. Two bytes correspond to one cell of the scroll screen. These bytes are arranged in the sequence byte 1, byte 2. A pattern name table consisting of $32 \times 28 \times 2 = 1792$ (700H) bytes is used for the virtual area. Part of this is used for the LCD. A description is given below of the contents of the two bytes which correspond to each cell. Byte 1 - O CHO to CH8 - Set the No. of the character to be displayed on the cell, in these nine bits. - O RVH Byte 1 - 0: Normal - 1: The cell character pattern is left-right reversed. - O RVV - 0: Normal - 1: The cell character pattern is up-down reversed. - O CPT - This is the color palette select bit. - 0: Selects color palette 0 (color RAM addresses 00H to 1FH) - 1: Selects color palette 1 (color RAM addresses 20H to 3FH) - O PRI - 0: Normal (The sprites are displayed at the over of the scroll screen.) - 1: When the color code setting for the scroll-screen dots is other than 0, the scroll screen is prioritized over sprites. O D7 to D5 of byte 2 The data in this part is not used in the hardware, hence it can be used in software, such as for flags. ### b. Pattern generator table The pattern generator table always starts from address 0000H. Eight dots in the horizontal direction are represented by four bytes, and one character is represented by $4 \times 8 = 32$ (20H) bytes. 32 bytes correspond to the color code pattern of the characters, as shown in the example below. (Please be aware that the respective dots constitute a color code which is represented by the four bits C3 to C0.) ### Example: In other words, if an address consisting of 32 bytes is divided as follows, Group 0: 0, 4, 8, 12, 16, 20, 24, 28 Group 1: 1, 5, 9, 13, 17, 21, 25, 29 Group 2: 2, 6, 10, 14, 18, 22, 26, 30 Group 3: 3, 7, 11, 15, 19, 23, 27, 31 A pattern will be obtained in which Group 0 corresponds to the 0th bit of the color code, Group 1 to the 1st bit, Group 2 to the 2nd bit, and Group 3 to the 3rd bit. (These groups can be considered to correspond to four planes.) Example: Character color code pattern assuming that the following data was input from address 0000H, the pattern of the color code of character 0 will change as follows. | Data | | | | | | ode pattern<br>eft | from character 0<br>Right | |-------------------------------------------------------------------------------------------------|-------------------------------|----------------------------|----------------------------------------------|----------------------------------------------|---------------------------------|----------------------------------------------------------------------------|-------------------------------------------------------------| | ADDRESS<br>0 0 0 0<br>0 0 0 4<br>0 0 0 8<br>0 0 0 C<br>0 0 1 0<br>0 0 1 4<br>0 0 1 8<br>0 0 1 C | + 0<br>A 0 1 0<br>O 0 0 5 5 1 | +1<br>C 2 2 0<br>F 1 0 6 2 | +2<br>F0<br>04<br>40<br>F0<br>80<br>F8<br>B4 | +3<br>F0<br>08<br>80<br>F0<br>00<br>80<br>78 | 0<br>1<br>2<br>3<br>4<br>5<br>6 | F E D C 3<br>0 0 0 0 8<br>8 4 2 1 0<br>C C C C 3<br>6 0 0 0 0<br>4 4 5 5 1 | 2 1 0<br>4 2 1<br>0 0 0<br>3 3 3<br>0 0 2<br>1 1 1<br>3 2 1 | ### c. Color RAM When the color code pattern is determined by the pattern generator table, RGB data will be read from the corresponding color RAM, resulting in a character color pattern. The color RAM has a capacity of 12 bits x 32 words, and the color code expresses A4 to A1 of the color RAM addresses. A5 is determined by the palette. In the case of a scroll screen character, it is determined by the CPT bit of the second byte in the pattern name table. Four bits each of the 12-bit data are assigned to R, G and B, respectively, enabling a total of 4096 colors to be displayed. Thirty two colors from these 4096 colors are set and displayed with the palettes and color codes. | DAT | lette | Λ | |-----|--------|----| | rai | тетте. | () | | ١. | arette u | | | | arette i | | |----|----------|-------------|----------------|---------|----------|--------------| | | | Color code | Color RAM data | | | Color | | | | | | | | | | | Address | C3 C2 C1 CO | Component | | Address | C3 C2 | | | 0 O H | 0 0 0 0 | Red & Green | | 2 0 H | 0 0 | | | 0 1 H | | Blue | | 2 1 H | | | | | | | | | <br> -<br> - | | | | | | 1 1 1 1 | | | | | 1 E H | 1 1 1 1 | Red & Green | | 3 E H | | | | 1 F H | | Blue | | 3 F H | 1 1 | Palette 1 | | | i | | | | |---------|-------------|----------------|--|--|--| | | Color code | Color RAM data | | | | | | | | | | | | Address | C3 C2 C1 CO | Component | | | | | 2 O H | 0 0 0 0 | Red & Green | | | | | 2 1 H | 0 0 0 0 | Blue | | | | | | | | | | | | | | | | | | | | | | | | | | 3 E H | 1 1 1 1 | Red & Green | | | | | 3 F H | 1 1 1 1 | Blue | | | | The relationship between the color RAM data and color is shown below. Odd addresses : Color Even addresses 00H 00H Black 0FH 00H Bright red 00H F0H Bright green 0FH Bright blue 00H FFH 0FH White ### ⑤ Displaying sprites ### a. Sprite attribute table A maximum of 64 sprites, each defined by vertical position, horizontal position and character No., can be displayed, hence the sprite attribute table uses $3 \times 64 = 192$ bytes. An actual sprite attribute table consists of an area of 256 bytes, 64 bytes of which are unused. At a vertical position, DOH has the meaning of an end code, hence if DOH is written to a vertical position, the display of all subsequent sprites will be disabled. To prevent a particular sprite from being displayed, set EOH in the corresponding vertical position. When the base address of the sprite attribute table is address 3F00H X Do not use the unused 64 bytes as a character generator table. ### b. Sprite generator table The base address of the sprite generator table is determined by register #6. Apart from this, the sprite generator functions in the same way as the pattern generator table. Here too, each 20H is allocated to one sprite character. ### c. Color RAM The color RAM is treated in exactly the same way as the scroll screen except for the fact that the palette on the 1 side is always selected. The part corresponding to color code 0 is transparent, even if color data is set in it. ### d. Sprite coordinates The coordinate system of a sprite is as shown in the figure at left. It is displayed so that the dot at the top left of the sprite is located at the top (horizontal position, vertical position). This also applies for a size of $8 \times 16$ dots. When the horizontal position is outside the range 30H to CFH, the sprite exists in the effective area. Also, in the case of the vertical position, the sprite exists in the effective area so long as it is in the range FFH to 16H and A7 to RFH ### e. SIZE bit If "1" is set in the SIZE bit, an 8 $\times$ 16 dot (vertical length) sprite will be displayed. In this case, the top seven bits of the character No. set in the sprite attribute table will be effective. If the number of character No. is b7b6b5b4b3b2b10 (or b7b6b5b4b3b2b11; b0 is ineffective), the character b7b6b5b4b3b2b10 will be displayed in the position of A, and the character of b7b6b5b4b3b2b11 in the position of B. ### f. Sprite display limits O Up to eight sprites can be displayed on the same horizontal line. This limit also applies if there are sprites in the left and right effective areas, even if they are not displayed in the LCD display area. O Sprite 0 has the highest priority, and sprite 63 the lowest priority. O If two sprites overlap each other, the sprite with the higher priority will be displayed. Also, if there are nine or more sprites on the same horizontal line, the eight sprites with the highest priority will be displayed, and the ninth and higher sprites will not be displayed. This judgment of priority display is made for each line. The shaded areas become transparent, and the background pattern is displayed. ### 6 H counter, V counter The VDP displays an image based on the H counter and the V counter. The H and V counter values can also be read from the CPU. The value of the H counter is effective only when a special clock pulse. The H counter corresponds to dots, and the V counter corresponds to lines. Both are 9-bit counters. The CPU reads the top eight bits of the H counter, and reads the bottom eight bits of the V counter. These data can be read at any time. ### a. H counter Reads I/O port 7FH (PSG control in the case of a write operation). Two dots are equivalent to one count, and three counts are equivalent to four CPU clock pulses. (1H = 342 dots = 171 counts = 228 CPU clock pulses) X The generation of an interrupt at an arbitrary vertical position and the count-up of the V counter take place in the case of F4H. # V counterReads I/O port 7EHOne line is equivalent to one count. $\divideontimes$ The interrupt for the completion of the effective area is generated by COH (and F4H in the case of the H counter). The FFH line is line 511 described before. VDP manual END ## PSG Manual The PSG (Programmable Sound Generator) contains three tone generators and one noise generator. Each of the tone and noise generators can be distrubuted left and right, enabling a pseudo stereo effect to be generated. (See "System Control Port".) Control of the PSG itself, which is described below, is performed by means of the write operation to I/O area 7FH. The basic clock is 3.579545 MHz. The data to be sent from the CPU is immediately latched in the PSG, hence there is no need for a wait. The sound output goes OFF in the case of a power-on reset. Design the software so that the output goes OFF at the beginning of the program as well. ### [1] Tone generator Each tone generator consists of a frequency setting section (programmable counter) and a level setting section (programmable attenuator). ### (1) Method of calculating the 10-bit frequency division ratio n At the frequency setting section, the basic clock is frequency-divided to 1/32. This is further frequency divided by the tone counter set by the 10 bits F9 (MSB: top bit) to F0 (LSB: bottom bit). Consequently, the basic clock frequency is divided by 32, then the desired frequency can be output by setting the value obtained by dividing the frequency-divided clock by the desired frequency in F9 to F0. $$n = N/(32 \times f)$$ Where n = 10-bit frequency division ratio (F9 to F0) N = Basic clock f = Desired frequency ### (2) Tone frequency setting Set the 10-bit frequency division ratio (F9 to F0) in the tone counter in order to obtain the desired frequency. The 1st and 2nd bytes are identified by means of the top bit. 1st byte | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | |----|-----|------|-----|----|----|----|----|--| | * | REG | . AD | DR. | n | | | | | | 1 | R2 | R1 | R0 | F3 | F2 | F1 | F0 | | ### 2nd byte | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----------|----|----|----|----|----|-----|----| | <b>+</b> | | | | n | | | | | 0 | × | F9 | F8 | F7 | F6 | F.5 | F4 | | R2 | R1 | R0 | Control register allocation | 1st | |----|----|----|-----------------------------|------------| | 0 | 0 | 0 | Tone generator 1 | 8 × | | 0 | 1 | 0 | Tone generator 2 | $A \times$ | | 1 | 0 | 0 | Tone generator 3 | $C \times$ | Frequency division ratio with respect to the output frequency ### (3) Example of frequency setting Consider an example in which the basic clock frequency is 3.579545 MHz and the desired frequency of 440 Hz is output from TONE 1. (corresponding to "A" on the musical scale) a. Calculation of frequency division ratio n $n = N/(32 \times f)$ $= 3579545/(32 \times 440)$ **÷** 254.229 n is a 10-bit integer, hence the nearest integral value is 254. Consequently, the frequency actually output is $f = N/(32 \times n)$ $= 3579545/(32 \times 254)$ **÷** 440.397 (Hz) Here, the pitch error $\triangle C$ is obtained according to the following equation. $\triangle C = \{(f' - f)/f\}/(\frac{1200}{2}-1)$ $= \{(440.397-440)/440\}/(\frac{1200}{2}-1)$ $\pm (0.397/440)/0.000578 \pm 1.56$ f: True frequency f': Actual frequency $^{1\,2\,0\,0}\sqrt{\,2}$ ### b. Data sent to PSG n = 254 = 0011111110B ### 1st byte | * | REG | . AD | DR. | n | | | | |----|-----|------|-----|----|----|----|----| | 1 | R2 | R1 | R0 | F3 | F2 | F1 | F0 | | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO | | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | ### 2nd byte | * | | | | n | | | | |----|----|----|----|----|----|----|----| | 0 | × | F9 | F8 | F7 | F6 | F5 | F4 | | | | | | | | | | | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | 0 | × | 0 | 0 | 1 | 1 | 1 | 1 | ### (4) Tone level setting The frequency set by the tone generator is sent to the level setting section where the volume level is set. The level setting section is a programmable attenuator which enables the volume level to be set in 16 steps from 0 dB to 0FF according to a 4-bit attenuation value. 1st byte only | | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | | |--|----|----|----|----|-----------|----|----|----|--| | | | | | | | | | | | | | | | | | ATT. DATA | | | | | | | 1 | R2 | R1 | R0 | A3 | A2 | A1 | A0 | | | R2 | R1 | R0 | Control register allocation | HEX | |----|----|----|-----------------------------|-----| | 0 | 0 | 1 | Tone 1 attenuation | 9 × | | 0 | 1 | 1 | Tone 2 attenuation | Вх | | 1 | 0 | 1 | Tone 3 attenuation | D× | ### Attenuation | [db] | A3 A2 A1 A0 | HEX | [db] | A3 A2 A1 A0 | HEX | |------|-------------|-----|------|-------------|-----| | 0 | 0 0 0 0 | × O | 1 6 | 1 0 0 0 | × 8 | | 2 | 0 0 0 1 | × 1 | 1 8 | 1 0 0 1 | × 9 | | 4 | 0 0 1 0 | × 2 | 2 0 | 1 0 1 0 | ×A | | 6 | 0 0 1 1 | × 3 | 2 2 | 1 0 1 1 | ×В | | 8 | 0 1 0 0 | × 4 | 2 4 | 1 1 0 0 | ×C | | 1 0 | 0 1 0 1 | × 5 | 2 6 | 1 1 0 1 | × D | | 1 2 | 0 1 1 0 | × 6 | 2 8 | 1 1 1 0 | ×Ε | | 1 4 | 0 1 1 1 | × 7 | OFF | 1 1 1 1 | ×F | ### [2] Noise generator The noise generator consists of a noise generator circuit and a level setting section. The source of the noise supplied from the noise generator circuit is a shift register with EX-OR feedback. Each time the noise control register changes, the shift register is cleared. The shift clock of this shift register is determined by four modes that are in turn determined by NFO and NF1. If NFO = NF1 = 0, for example, the shift clock becomes (N/32)/16. In this case, if FB = 0, this shift clock will be frequency-divided by 16, resulting in synchronous noise of a frequency of $N/(32 \times 16 \times 16)$ . If FB = 1, the shift register will be driven by this shift clock with EX-OR feedback, resulting in the generation of white noise. ### (1) Noise generator circuit control 1st byte only | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |----|--------------|----|----|----|----|-------|-----| | * | * REG. ADDR. | | | | | SHIFT | | | 1 | 1 | 1 | 0 | × | FB | NF1 | NF0 | | FB | Noise<br>Generation | |----|----------------------| | 0 | Synchronous<br>Noise | | 1 | White noise | | NF1 | NF0 | Shift clock | k | |-----|-----|------------------|-----| | 0 | 0 | (N/32)/k | 1 6 | | 0 | 1 | (N/32)/k | 3 2 | | 1 | 0 | (N/32)/k | 6 4 | | 1 | 1 | Tone generator 3 | —A+ | N: Basic clock At this time, the tone of the noise can be varied continuously a. Synchronous noise (FB = 0) When NF0 = NF1 = Value other than 1 \* The noise frequency is $(N/(32 \times k))/16 = N/(32 \times k \times 16)$ When NF0 = NF1 = 1 (Control by tone 3) - \* The noise frequency is (frequency TONE 3)/16 = $N/(32 \times n \times 16)$ - b. White Noise (FB = 1) Spectrum when NFO = 0 NF1 = 1 n=1 (2) Noise level setting 1st byte only | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | |--------------|----|----|----|-----|------|----|----| | * REG. ADDR. | | | | ATT | . DA | TA | | | 1 | 1 | 1 | 1 | А3 | A2 | A1 | Α0 | \* The attenuation control is the same as for "Tone". ### [3] Register address feed PSG uses the three bits R2 to R0 of the 1st byte to judge which control register the data has been sent from. | R2 | R1 | R0 | Control register allocation | 1st | |----|----|----|---------------------------------|-----| | 0 | 0 | 0 | Tone 1 frequency division ratio | 8 × | | 0 | 0 | 1 | Tone 1 attenuation | 9 × | | 0 | 1 | 0 | Tone 2 frequency division ratio | Α× | | 0 | 1 | 1 | Tone 2 attenuation | В× | | 1 | 0 | 0 | Tone 3 frequency division ratio | C× | | 1 | 0 | 1 | Tone 3 attenuation | D× | | 1 | 1 | 0 | Noise generator circuit control | Ε× | | 1 | 1 | 1 | Noise attenuation | F× | ### [4] Correlation between the sound elements and PSG | Sound element | Physical element | Correlation with PSG | | | |--------------------------------------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | Pitch of sound | Frequency | [1] - (2) Tone frequency setting,<br>[2] - (1) Noise generator circuit control | | | | Tone | Harmonic<br>components | This is mainly related to wave length. In the tone generation mode, the PSG can output three frequencies simultaneously from only a 50% duty pulse waveform. Consequently, by combining attenuation control with this mode, the harmonic components can be controlled. In the synchronous noise mode, a 6.25% duty pulse waveform. | | | | Strength<br>of tone | Amplitude | As described in [1] - (3) and [2] - (2), the attenuation of the three tones and noise can be controlled by 4-bit data. | | | | Way<br>in which sound<br>is emitted. | Envelope | The wave length at left can be realized by using external data to control each attenuation. This can be done in the range where the 4-bit attenuation data is rewritten and envelope sequence control performed at each step. The tone and noise frequencies can be controlled by the range in which component control can be performed. | | | ### (next page) Relation between musical interval and frequency division ratio for scale divided equally into 12 parts (basic clock: 3.579545 MHz) | Musical<br>interval | Frequency | equency HEX division | | PSG output | Actual frequency | | |-------------------------------------------|---------------------------------------------------------------------------|-----------------------------------------------------|---------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | interval | ratio | 1 st | 2 nd | [Hz] | [Hz] | | | 22233333333333333333444444444444455555555 | 1 9 9 8 8 7 7 6 6 6 5 5 5 4 4 4 4 3 3 3 3 3 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 | 90A77AF71DBBC05C4D830EDDE026AE4A07F7F81B5FA50C730C9 | FC852FCA8531FECA97654210FFEDCBBAA9887776655554444333333322222221111111111110000000000 | $\begin{array}{c} 127239984044494474885350507705720511405449912466793\\ 92263197419903944774885350505077057205114054499124666793\\ 9.548675758993943589276099499861640997223889916506247\\ 9.6.3.6.7.57589951099388579544899861640997223889916506247\\ 9.6.3.8.6.7.7.2.6.8.5.7.9.5.4489902344567990250.6.7.7.409459499124687.7.2.6.8.5.5834\\ 1.1111111111111222222222233333344455556667788990111233456789912479911111111111111111111111111111111$ | $\begin{array}{c} 0 & 1 & 1 & 3 & 1 & 2 & 3 & 4 & 4 & 7 & 8 & 2 & 0 & 2 & 2 & 6 & 3 & 5 & 7 & 8 & 8 & 4 & 5 & 5 & 0 & 4 & 5 & 6 & 9 & 1 & 9 & 0 & 8 & 2 & 2 & 9 & 9 & 0 & 0 & 6 & 8 & 5 & 6 & 6 & 2 & 2 & 2 & 9 & 9 & 0 & 0 & 6 & 8 & 5 & 6 & 6 & 0 & 2 & 6 & 0 & 3 & 5 & 5 & 5 & 8 & 9 & 9 & 0 & 0 & 2 & 6 & 0 & 3 & 5 & 5 & 6 & 6 & 6 & 6 & 6 & 6 & 6 & 6$ | | - \* f = $3579545/(32 \times n)$ n: 10-bit frequency division Maximum frequency is n = 1 - \* In the previous table, musical interval was calculated on the basis of 440 Hz as concert pitch. - \* Regarding HEX, the X part is as follows: If a frequency of no greater than that generated by the tone generator is output, the outputs shown in the table below will be obtained due to the synchronous noise mode of the noise generator section. (Basic clock: 3.579545 MHz) | Musical<br>interval | Frequency<br>division | HEX | (TONE3) | PSG output | Actual frequency | |---------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|-----------------------------------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | interval | ratio | 1st | 2 nd | [Hz] | [Hz] | | O O O O O O O O O O O O O O O O O D E F F G G A A B C C D D E F F G G G A A B C C D D E F F G G G | 4 2 4 4 3 8 6 9 9 0 2 5 9 4 0 6 4 2 2 2 2 2 2 2 2 2 2 3 5 7 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | C4D830EDDE026AE4A07F7F81B5FA50C73 | 197654210FFEDCBBAA9887776655554444 | 550038010505006156000701091311198<br>305224539923371994290985673298599964<br>3.334681595196678163870283298599964<br>67.8901396678163870283298599964<br>112222333333344445556667722794<br>14368159372794<br>15815937727184 | 16. 3244<br>16. 3544<br>16. 3544<br>16. 3554<br>16. 3550<br>16. 3550<br>16. 3550<br>16. 3550<br>16. 3604<br>16. 36 | <sup>\*</sup> Set E3H for control of the noise generator circuit (synchronous noise mode). f = TONE 3 frequency/16 = $3579545/(32 \times n \times 16)$ PSG Manual END