Fig. 3 PSG REGISTER ARRAY =

| REGIS | TER                          | 87                           | В6    | B5    | B4    | Вз         | B2      | B1       | В0   |
|-------|------------------------------|------------------------------|-------|-------|-------|------------|---------|----------|------|
| RO    |                              | 8-BIT Fine Tune A            |       |       |       |            |         |          |      |
| R1    | Channel A Tone Period        | 4-BIT Coarse Tune A          |       |       |       |            |         |          |      |
| R2    | Character D. Trans. Business | 8-BIT Fine Tune B            |       |       |       |            |         |          |      |
| R3    | Channel B Tone Period        | 7////                        | ///// | ///// | ///// | 4-         | BIT Coa | rse Tun  | еВ   |
| R4    | Character C Toron Davids     | 8-BIT Fine Tune C            |       |       |       |            |         |          |      |
| R5    | Channel C Tone Period        | 7////                        | ///// | 7//// | 7//// | 4-         | BIT Coa | rse Tune | e C  |
| R6    | Noise Period                 | 5-BIT Period Control         |       |       |       |            |         |          |      |
| B7    | Enable                       | ĪÑ/OUT                       |       |       | Noise | Noise Tone |         |          |      |
| HZ    | сларіе                       | IOB                          | IOA   | С     | В     | A          | C       | - 8      | A    |
| R10   | Channel A Amplitude          |                              |       |       | M     | L3         | L2      | L1       | LO   |
| R11   | Channel B Amplitude          | hannel B Amplitude           |       |       | M     | L3         | L2      | L1       | 1.0  |
| R12   | Channel C Amplitude          |                              |       |       | М     | L3         | L2      | L1       | LO   |
| R13   | Envelope Desired             | B-BIT Fine Tune E            |       |       |       |            |         |          |      |
| R14   | Envelope Period              | 8-BIT Coarse Tune E          |       |       |       |            |         |          |      |
| R15   | Envelope Shape/Cycle         |                              |       |       |       | CONT.      | ATT.    | ALT.     | HOLD |
| R16   | I/O Port A Data Store        | 8-BIT PARALLEL I/O on Port A |       |       |       |            |         |          |      |
| B17   | I/O Port B Data Store        | 8-BIT PARALLEL I/O Port B    |       |       |       |            |         |          |      |

# 2.2 Pin Assignments

The AY-3-8910 is supplied in a 40 lead dual in-line package with the pin assignments as shown in Fig. 4. The AY-3-8912 is supplied in a 28 lead dual in-line package with the pin assignments as shown in Fig. 5.

Fig. 4 AY-3-8910 PIN ASSIGNMENTS \*



Fig. 5 AY-3-8912 PIN ASSIGNMENTS =



### 2.3 Pin Functions

DA7--DA0 (input/output/high impedance): pins 30--37 (AY-3-8910)
Data/Address 7--0: pins 21--28 (AY-3-8912)

These 8 lines comprise the 8-bit bidirectional bus used by the microprocessor to send both data and addresses to the PSG and to receive data from the PSG. In the data mode, DA7--DA0 correspond to Register Array bits B7--B0. In the address mode, DA3--DA0 select the register # (0--17<sub>8</sub>) and DA7--DA4 in conjunction with address inputs A9 and A8 form the high order address (chip select).

A8 (input): pin 25 (AY-3-8910)

pin 17 (AY-3-8912)

A9 (input): pin 24 (AY-3-8910)

(not provided on AY-3-8912)

#### Address 9, Address 8

These "extra" address bits are made available to enable the positioning of the PSG (assigning a 16 word memory space) in a total 1,024 word memory area rather than in a 256 word memory area as defined by address bits DA7—DA0 alone. If the memory size does not require the use of these extra address lines they may be left unconnected as each is provided with either an on-chip pull down ( $\overline{A9}$ ) or pull-up (A8) resistor. In "noisy" environments, however, it is recommended that  $\overline{A9}$  and A8 be tied to an external ground and +5V, respectively, if they are not to be used.

RESET (input): pin 23 (AY-3-8910) pin 16 (AY-3-8912)

For initialization/power-on purposes, applying a logic "0" (ground) to the Reset pin will reset all registers to "0". The Reset pin is provided with an on-chip pull-up resistor.

CLOCK (input): pin 22 (AY-3-8910) pin 15 (AY-3-8912)

This TTL-compatible input supplies the timing reference for the Tone, Noise and Envelope Generators.

BDIR, BC2, BC1 (inputs): pins 27,28,29 (AY-3-8910) pins 18,19,20 (AY-3-8912)

#### **Bus DIRection, Bus Control 2,1**

These bus control signals are generated directly by GI's CP1600 series of microprocessors to control all external and internal bus operations in the PSG. When using a processor other than the CP1600, these signals can be provided either by comparable bus signals or by simulating the signals on I/O lines of the processor. The PSG decodes these signals as illustrated in the following:

# 2.3 Pin Functions (cont.)

| BDIR | BC2 | BC1 | CP1600<br>FUNCTION | PSG<br>FUNCTION                                                                                                                                                      |
|------|-----|-----|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 0   | 0   | NACT               | INACTIVE, See 010 (IAB) below.                                                                                                                                       |
| 0    | 0   | 1   | ADAR               | LATCH ADDRESS. See 111 (INTAK) below.                                                                                                                                |
| 0    | 1   | 0   | IAB                | INACTIVE. The PSG/CPU bus is inactive. DA7DA0 are in a high impedance state.                                                                                         |
| 0    | 1   | 1   | DTB                | READ FROM PSG. This signal causes the contents of the register which is currently addressed to appear on the PSG/CPU bus. DA7DA0 are in the output mode.             |
| 1    | 0   | 0   | BAR                | LATCH ADDRESS. See 111 (INTAK) below.                                                                                                                                |
| 1    | 0   | 1   | DW                 | INACTIVE. See 010 (IAB) above.                                                                                                                                       |
| 1    | 1   | 0   | DWS                | WRITE TO PSG. This signal indicates that the bus contains register data which should be latched into the currently addressed register. DA7DA0 are in the input mode. |
| 1    | 1   | 1   | INTAK              | LATCH ADDRESS. This signal indicates that the bus contains a register address which should be latched in the PSG. DA7DA0 are in the input mode.                      |

While interfacing to a processor other than the CP1600 would simply require simulating the above decoding, the redundancies in the PSG functions vs. bus control signals can be used to advantage in that only four of the eight possible decoded bus functions are required by the PSG. This could simplify the programming of the bus control signals to the following, which would only require that the processor generate two bus control signals (BDIR and BC1, with BC2 tied to +5V):



ANALOG CHANNEL A, B, C (outputs): pins 4, 3, 38 (AY-3-8910) pins 5, 4, 1 (AY-3-8912)

Each of these signals is the output of its corresponding D/A Converter, and provides an up to 1V peak-peak signal representing the complex sound waveshape generated by the PSG.

IOA7--IOA0 (input/output): pins 14--21 (AY-3-8910) pins 7--14 (AY-3-8912) IOB7--IOB0 (input/output): pins 6--13 (AY-3-8910) (not provided on AY-3-8912)

#### Input/Output A7--A0, B7--B0

Each of these two parallel input/output ports provides 8 bits of parallel data to/from the PSG/CPU bus from/to any external devices connected to the IOA or IOB pins. Each pin is provided with an on-chip pull-up resistor, so that when in the "input" mode, all pins will read normally high. Therefore, the recommended method for scanning external switches, for example, would be to ground the input bit.

TEST 1: pin 39 (AY-3-8910)

pin 2 (AY-3-8912)

TEST 2: pin 26 (AY-3-8910)

(not connected on AY-3-8912)

These pins are for GI test purposes only and should be left open—<u>do</u> not use as tie-points.

V<sub>cc</sub>: pin 40 (AY-3-8910) pin 3 (AY-3-8912)

Nominal +5Volt power supply to the PSG.

V<sub>ss</sub>: pin 1 (AY-3-8910) pin 6 (AY-3-8912)

Ground reference for the PSG.

## 2.4 Bus Timing

Since the PSG functions are controlled by commands from the system processor, the common data/address bus (DA7--DA0) requires definition as to its function at any particular time. This is accomplished by the processor issuing bus control signals, previously described, defining the state of the bus; the PSG then decodes these signals to perform the requested task.

The conditioning of these bus control signals by the processor is the same as if the processor were interacting with RAM: (1) the processor outputs a memory address; and (2) the processor either outputs or inputs data to/from the memory. The "memory" in this case is the PSG's array of 16 read/write control registers.

The timing relationships in issuing the bus control signals relative to the data or address signals on the bus are reviewed in general in the following section, and in detail in Section 7, Electrical Specifications.

## 2.5 State Timing

While the state flow for many microprocessors can be somewhat involved for certain operations, the sequence of events necessary to control the PSG is simple and straightforward. Each of the three major state sequences (Latch Address, Write to PSG, and Read from PSG) consists of several operations (indicated below by rectangular blocks), defined by the pattern of bus control signals (BDIR, BC2, BC1).



The functional operation and relative timing of the PSG control sequences are described in the following paragraphs (in all examples, BC2 has been assumed to be tied to logic "1", +5V).

#### 2.5.1 ADDRESS PSG REGISTER SEQUENCE

The "Latch Address" sequence is normally an integral part of the write or read sequences, but for simplicity is illustrated here as an individual sequence. Depending on the processor used the program sequence will normally require four principal microstates: (1) send NACT (inactive); (2) send INTAK (latch address); (3) put address on bus; (4) send NACT (inactive). [Note: within the timing constraints detailed in Section 7, steps (2) and (3) may be interchanged.]



#### 2.5.2 WRITE DATA TO PSG SEQUENCE

The "Write to PSG" sequence, which would normally follow immediately after an address sequence, requires four principal microstates: (1) send NACT (inactive); (2) put data on bus; (3) send DWS (write to PSG); (4) send NACT (inactive).



#### 2.5.3 READ DATA FROM PSG SEQUENCE

As with the "Write to PSG" sequence, the "Read from PSG" sequence would also normally follow immediately after an address sequence. The four principal microstates of the read sequence are: (1) send NACT (inactive); (2) send DTB (read from PSG); (3) read data on bus; (4) send NACT (inactive).



#### 2.5.4 WRITE TO/READ FROM I/O PORT SEQUENCE

Since the two I/O Ports (A and B) each have an 8-bit register assigned as a data store, writing to or reading from either port is identical to writing or reading to any other register. Hence, the state sequences are exactly the same as described in the preceding paragraphs.

# 3 OPERATION

Since all functions of the PSG are controlled by the host processor via a series of register loads, a detailed description of the PSG operation can best be accomplished by relating each PSG function to the control of its corresponding register. The function of creating or programming a specific sound or sound effect logically follows the control sequence listed:

| Section | Operation                     | Registers | Function                                                |
|---------|-------------------------------|-----------|---------------------------------------------------------|
| 3.1     | Tone Generator Control        | R0R5      | Program tone periods.                                   |
| 3.2     | Noise Generator Control       | R6        | Program noise period.                                   |
| 3.3     | Mixer Control                 | R7        | Enable tone and/or noise<br>on selected channels.       |
| 3.4     | Amplitude Control             | R10R12    | Select "fixed" or "envelope-<br>variable" amplitudes.   |
| 3.5     | Envelope Generator<br>Control | R13R15    | Program envelope period<br>and select envelope pattern. |

# Control

(Registers RO, R1, R2, R3, R4, R5)

The frequency of each square wave generated by the three Tone Generators (one each for Channels A, B, and C) is obtained in the Tone Generator PSG by first counting down the input clock by 16, then by further counting down the result by the programmed 12-bit Tone Period value. Each 12-bit value is obtained in the PSG by combining the contents of the relative Coarse and Fine Tune registers, as illustrated in the following:





12-bit Tone Period (TP) to Tone Generator

Note that the 12-bit value programmed in the combined Coarse and Fine Tune registers is a period value—the higher the value in the registers, the lower the resultant tone frequency.

Note also that due to the design technique used in the Tone Period count-down, the lowest period value is 00000000001 (divide by 1) and the highest period value is 11111111111 (divide by 4,09510).

The equations describing the relationship between the desired output tone frequency and the input clock frequency and Tone Period value are:

(a) 
$$f_T = \frac{f_{CLOCK}}{16TP_{10}}$$
 (b)  $TP_{10} = 256CT_{10} + FT_{10}$ 

Where:  $f_T =$  desired tone frequency
 $f_{CLOCK} =$  input clock frequency
 $TP_{10} =$  decimal equivalent of the Tone Per

TP<sub>10</sub> = decimal equivalent of the Tone Period bits TP11--TP0.

CT<sub>10</sub> = decimal equivalent of the Coarse Tune register bits B3--B0 (TP11--TP8)

FT<sub>10</sub>= decimal equivalent of the Fine Tune register bits B7--B0 (TP7--TP0)

From the above equations it can be seen that the tone frequency can range from a low of  $\frac{f_{0.028}}{65,520}$  (wherein:  $TP_{10}$ =4,095<sub>10</sub>) to a high of  $\frac{f_{0.028}}{16}$  (wherein:  $TP_{10}$ =1). Using a 2 MHz input clock, for example, would produce a range of tone frequencies from 30.5 Hz to 125 kHz.

To calculate the values for the contents of the Tone Period Coarse and Fine Tune registers, given the input clock and the desired output tone frequencies, we simply rearrange the above equations, yielding:

(a) 
$$TP_{10} = \frac{f_{OLOCK}}{16f_T}$$
 (b)  $CT_{10} + \frac{FT_{10}}{256} = \frac{TP_{10}}{256}$ 

Example 1: 
$$f_T = 1kHz$$
  
 $f_{CLOCK} = 2MHz$   
 $TP_{10} = \frac{2x10^6}{16(1x10^3)} = 125$ 

Substituting this result into equation (b):

$$CT_{10} + \frac{FT_{10}}{256} = \frac{125}{256}$$
  
 $\therefore CT_{10} = 0 = 0000 (B3--B0)$   
 $FT_{10} = 125_{10} = 01111101 (B7--B0)$ 

Example 2: 
$$f_T = 100 Hz$$
  
 $f_{GLOCK} = 2 MHz$   
 $TP_{10} = \frac{2 \times 10^6}{16 (1 \times 10^2)} = 1250$ 

Substituting this result into equation (b):

$$\begin{array}{lll} CT_{10} + \dfrac{FT_{10}}{256} = \dfrac{1250}{256} = 4 + \dfrac{226}{256} \\ . \cdot . CT_{10} = 4_{10} = 0100 \ (B3--B0) \\ FT_{10} = 226_{10} = 11100010 \ (B7--B0) \end{array}$$

## 3.2 Noise Generator Control

The frequency of the noise source is obtained in the PSG by first counting down the input clock by 16, then by further counting down the result by the programmed 5-bit Noise Period value. This 5-bit value consists of the lower 5 bits (B4--B0) of register R6, as illustrated in the following:

(Register R6)



Note that the 5-bit value in R11 is a <u>period</u> value—the higher the value in the register, the lower the resultant noise frequency. Note also that, as with the Tone Period, the <u>lowest</u> period value is 00001 (divide by 1); the <u>highest</u> period value is 11111 (divide by 31<sub>10</sub>).

The noise frequency equation is:

$$\begin{split} f_N &= \frac{f_{\text{CLOCK}}}{16 \text{ NP}_{10}} \\ &\text{Where:} \quad f_N \!=\! \text{desired noise frequency} \\ &f_{\text{CLOCK}} \!=\! \text{input clock frequency} \\ &\text{NP}_{10} \!=\! \text{decimal equivalent of the Noise Period} \\ &\text{register bits B4--B0.} \end{split}$$

From the above equation it can be seen that the noise frequency can range from a low of  $\frac{f_{0.000}}{496}$  (wherein: NP<sub>10</sub> = 31<sub>10</sub>) to a high of  $\frac{f_{0.000}}{16}$  (wherein: NP<sub>10</sub> = 1). Using a 2 MHz input clock, for example, would produce a range of noise frequencies from 4 kHz to 125 kHz.

To calculate the value for the contents of the Noise Period register, given the input clock and the desired output noise frequencies, we simply rearrange the above equation, yielding:

$$NP_{10} = \frac{f_{CLOCK}}{16 f_N}$$