

### Sound Blaster Pro Master Volume Emulation

Sound Blaster Pro emulations for master volume means that the 6-bit volume counters can be written via the Sound Blaster Pro Mixer register 22h (or 32h). Sound Blaster Pro emulation is enabled by default, and can be disabled by setting bit 0 of Mixer register 64h.

The master volume registers 60h and 62h can always be read, regardless of whether Sound Blaster Pro volume emulation is enabled, using the Sound Blaster Pro Mixer registers 22h (and 32h). The following 6-bit to 4-bit translation table is used:

| Table 1 | SB Pro Master R | ead Volume Err                     | nulation |
|---------|-----------------|------------------------------------|----------|
| Mute    | Master Volume   | Master Volume Value Read<br>at 32h |          |
| 1       | ХХ              | 0                                  | 1        |
| 0       | 0-24            | 1                                  | 1        |
| 0       | 25-30           | 2                                  | 3        |
| 0       | 31-34           | 3                                  | 3        |
| 0       | 35-38           | 4                                  | 5        |
| 0       | 39-42           | 5                                  | 5        |
| 0       | 43-46           | 6                                  | 7        |
| 0       | 47-50           | 7                                  | 7        |
| 0       | 51-54           | 8                                  | 9        |
| 0       | 55              | 9                                  | 9        |
| 0       | 56-57           | 10                                 | 11       |
| 0       | 58              | 11                                 | 11       |
| 0       | 59-60           | 12                                 | 13       |
| 0       | 61              | 13                                 | 13       |
| 0       | 62              | 14                                 | 15       |
| 0       | 63              | 15                                 | 15       |

If Sound Blaster Pro volume emulation is enabled, then a mixer reset will cause both left and right channels to set to their power-on defaults, namely 54 (36h).

If Sound Blaster Pro volume emulation is enabled, then a write to mixer register 22h (or 32h) will cause both the left and right master volume registers to be changed as follows:

| Table 2 SB Pro Write Volume E | mulation |              |
|-------------------------------|----------|--------------|
| Value written to 22h or 32h   | Mute     | 6-bit Volume |
| 0                             | 1        | 24           |
| 1                             | 0        | 24           |
| 2                             | 0        | 30           |
| 3                             | 0        | 34           |
| 4                             | 0        | 38           |
| 5                             | 0        | 42           |
| 6                             | 0        | 46           |
| 7                             | 0        | 50           |
| 8                             | 0        | 54           |
| 9                             | 0        | 55           |
| 10                            | 0        | 56           |
| 11                            | 0        | 58           |
| 12                            | 0        | 59           |
| 13                            | 0        | 61           |
| 14                            | 0        | 62           |
| 15                            | 0        | 63           |



# REGISTERS

### **Types of Register Access**

There are two types of audio registers in the ES1887:

• Mixer registers.

These registers are accessed via I/O ports Audio\_Base+4h and Audio\_Base+5h. Audio\_base+4h is written with the register address. Then the register can be read/written via Audio\_Base+5h. These registers control many functions other than the mixer.

Controller registers

These registers are used to control Extended mode DMA playback and record through the first audio channel. Controller registers are accessed via an extension to the Sound Blaster common interface. This interface uses I/ O ports Audio\_Base+Ah, Audio\_Base+Ch, and Audio\_Base+Eh to transfer read data, write data/commands, and status respectively.

#### **Mixer Registers**

There are two types of mixer registers. Sound Blaster Pro Compatible mixer registers, as the name suggests are fully compatible with the Sound Blaster Pro. ESS mixer registers are specific to ESS Technology, Inc. ES1887 *AudioDrive®* chips; though many registers are shared throughout the *AudioDrive®* family of chips.

#### Sound Blaster Pro Compatible Mixer Registers

This section provides a summary of Sound Blaster Pro compatible mixer registers in the ES1887 and some comments on the characteristics of these registers.

| Reg | D7                 | D6                   | D5                 | D4        | D3                        | D2                  | D1       | D0                | Remark               |   |             |
|-----|--------------------|----------------------|--------------------|-----------|---------------------------|---------------------|----------|-------------------|----------------------|---|-------------|
| 00h |                    |                      |                    | Write: re | Write: reset mixer        |                     |          |                   | Mixer reset          |   |             |
| 04h | DAC                | DAC play volume left |                    |           | x DAC play volume right x |                     |          |                   | DAC playback volume  |   |             |
| 0Ah | х                  | х                    | х                  | х         | х                         | Mic mix             | k volume | х                 | Mic mix volume       |   |             |
| 0Ch | х                  | х                    | F1ª                | х         | F0ª                       | ADC                 | Source   | х                 | See note for F0, F1. |   |             |
| 0Eh | х                  | х                    | F2ª                | х         | x                         | х                   | Stereo   | х                 | See note for F2.     |   |             |
| 22h | Master volume left |                      | Master volume left |           | Mas                       | Master volume right |          | х                 | Master volume        |   |             |
| 26h | FM volume left     |                      |                    | х         | FN                        | FM volume right     |          | х                 | Music DAC volume     |   |             |
| 28h | CD (A              | AuxA) volur          | ne left            | х         | x CD (AuxA) volu          |                     |          | х                 | CD (AuxA) Volume     |   |             |
| 2Eh | Lii                | ne volume            | left               | х         | Lin                       | Line volume right x |          | Line volume right |                      | х | Line volume |

Table 3 Sound Blaster Pro Compatible Register Summary

a. Sound Blaster filter control bits F2, F1, and F0 have no function in the ES1887 and are ignored.

#### **Filter Control Bits**

The Sound Blaster Pro mixer has three bits that control input and output filters. They are labeled as F0, F1, and F2 in Table 3 and Table 4. They have no function in the ES1887 and their values are ignored.

#### **Mixer Stereo Control Bit**

Bit 1 of register 0Eh is the Mixer Stereo Control bit. It is normally zero. Set this bit high to enable Sound Blaster Pro compatible stereo DAC functions. Program the DAC sample rate to be twice the sample rate of each channel. For example, for 22 kHz stereo, program the "sample rate" to be 44 kHz using command 40h. This bit enables stereo only for DMA transfer to the DAC in Compatibility mode. It should not be used in Extended mode.

Clear this bit after completing the stereo DMA transfer, because this bit is unaffected by software reset (only mixer reset).

See also "Stereo DMA Transfers in Compatibility Mode" on page 29.



REGISTERS

#### **ESS Mixer Registers**

This section provides a summary of the ESS mixer registers followed by a detailed description of each register.

# Table 4 ESS Mixer Register Summary

| Reg | D7                                       | D6                                        | D5                 | D4                                    | D3                            | D2                                     | D1                        | D0                                   | Remark                                        |  |
|-----|------------------------------------------|-------------------------------------------|--------------------|---------------------------------------|-------------------------------|----------------------------------------|---------------------------|--------------------------------------|-----------------------------------------------|--|
| 00h |                                          |                                           |                    | Write: re                             | set mixer                     |                                        |                           |                                      | Reset mixer                                   |  |
| 14h |                                          | Audio 1 pla                               | y volume left      |                                       |                               | Audio 1 play                           | volume right              |                                      | Audio 1 play volume                           |  |
| 1Ah |                                          | Mic mix v                                 | olume left         |                                       |                               | Mic mix vo                             | olume right               |                                      | Mic mix volume                                |  |
| 1Ch | х                                        | х                                         | F1ª                | Х                                     | F0 <sup>a</sup>               |                                        | Record source             |                                      | Record source select                          |  |
| 1Eh | х                                        | х                                         | F2ª                | Х                                     | х                             | х                                      | Stereo                    | х                                    | Stereo flag                                   |  |
| 32h |                                          | Master v                                  | olume left         |                                       |                               | Master vo                              | lume right                |                                      | Master volume                                 |  |
| 36h |                                          | FM vol                                    | ume left           |                                       |                               | FM volu                                | FM volume                 |                                      |                                               |  |
| 38h |                                          | CD (AuxA)                                 | volume left        |                                       |                               | CD (AuxA)                              | volume right              |                                      | CD volume                                     |  |
| 3Ah |                                          | AuxB vo                                   | lume left          |                                       |                               | AuxB vol                               | ume right                 |                                      | AuxB volume                                   |  |
| 3Ch |                                          |                                           |                    |                                       |                               | Р                                      | PC speaker volum          | ne                                   | PC speaker volume                             |  |
| 3Eh |                                          | Line vo                                   | lume left          |                                       |                               | Line volu                              | ume right                 |                                      | Line volume                                   |  |
| 40h | MPU-40                                   | )1 enable and IR                          | Q select           | MPU-401                               | l address                     | Restart configuration                  | Joystick<br>enable        | FM enable                            | FM/Joystick/MPU-401 configuration             |  |
| 42h | Input override Preamp Input bypass Input |                                           |                    | source                                |                               | Input                                  | volume                    |                                      | Serial mode input control                     |  |
| 44h | Output over-<br>ride Output signal       |                                           |                    |                                       |                               | Output                                 | volume                    |                                      | Serial mode output control                    |  |
| 46h | Analog con-<br>trol override             | 0                                         | Left ADC           | Right ADC                             | Analog                        | Analog control FDXO enable FDXI enable |                           | FDXI enable                          | Serial mode miscellaneous analog control      |  |
| 48h | SE enable                                | Data format                               | Serial reset       | ES689/<br>ES69x inter-<br>face enable | Active low<br>sync            | DSP test<br>mode                       | Telegaming<br>mode enable | 0                                    | Serial mode miscellaneous control             |  |
| 4Ch | Filter<br>override                       |                                           | 0                  |                                       | 2's complement filter divider |                                        |                           |                                      | Serial mode filter divider control            |  |
| 4Eh | Transmi                                  | it source                                 | Transmit<br>length | Transmit<br>mode                      | Receive                       | Receive source Receive length          |                           | Receive<br>mode                      | Serial mode format/source/target con-<br>trol |  |
| 60h | 0                                        | Mute                                      |                    |                                       | Left master volume            |                                        |                           |                                      | Left master volume counter value              |  |
| 62h | 0                                        | Mute                                      |                    |                                       | Right master volume           |                                        |                           |                                      | Right master volume counter value             |  |
| 64h | HWV oper                                 | ation mode                                | Volume count       | HWV IRQ<br>flag                       | 0                             | Enable HWV<br>IRQE                     | HWV inter-<br>rupt mask   | SB Pro mas-<br>ter volume<br>disable | Master volume control                         |  |
| 66h |                                          |                                           | Write: F           | Reset hardware v                      | volume interrupt              | request                                |                           |                                      | Hardware volume interrupt request             |  |
| 68h |                                          | Mic mix v                                 | olume left         |                                       |                               | Mic mix vo                             | olume right               |                                      | Mic record volume                             |  |
| 69h |                                          | Audio 2 v                                 | olume left         |                                       |                               | Audio 2 vo                             | olume right               |                                      | Audio 2 record volume                         |  |
| 6Ah |                                          | CD (AuxA)                                 | volume left        |                                       |                               | CD (AuxA)                              | volume right              |                                      | CD (AuxA) record volume                       |  |
| 6Bh |                                          | FM vol                                    | ume left           |                                       | FM volume right               |                                        |                           |                                      | Music DAC record volume                       |  |
| 6Ch |                                          | AuxB vo                                   | lume left          |                                       | AuxB volume right             |                                        |                           |                                      | Aux B record volume                           |  |
| 6Eh |                                          | Line vo                                   | lume left          |                                       |                               | Line volu                              | ume right                 |                                      | Line record volume                            |  |
| 70h | Clock source                             |                                           |                    | S                                     | Sample rate divider           |                                        |                           |                                      | Audio 2 sample rate divider                   |  |
| 72h |                                          |                                           |                    | Filter clo                            | ck divider                    |                                        |                           |                                      | Audio 2 filter clock divider                  |  |
| 74h |                                          |                                           | 2's (              | complement tran                       | sfer count – Iow              | byte                                   |                           |                                      | Audio 2 transfer count reload                 |  |
| 76h |                                          | 2's complement transfer count – high byte |                    |                                       |                               |                                        |                           |                                      |                                               |  |

#### Table 4 ESS Mixer Register Summary (Continued)

| Reg | D7             | D6          | D5                      | D4                          | D3                             | D2                         | D1                             | D0                          | Remark                |
|-----|----------------|-------------|-------------------------|-----------------------------|--------------------------------|----------------------------|--------------------------------|-----------------------------|-----------------------|
| 78h | DMA trar       | nsfer type  | DMA transfer<br>length  | Auto-initial-<br>ize enable | Resume flag                    | Suspend flag               | Enable trans-<br>fer into FIFO | Enable trans-<br>fer to DAC | Audio 2 control 1     |
| 7Ah | IRQ latch      | IRQE enable | DRQ/<br>DACKB<br>enable | Mixer source                |                                | FIFO signed mode           | FIFO stereo<br>mode            | FIFO 16-bit<br>mode         | Audio 2 control 2     |
| 7C  |                | Audio 2 v   | olume left              |                             |                                | Audio 2 vo                 | Audio 2 playback volume        |                             |                       |
| 7Dh |                | (           | )                       |                             | FM mix<br>enable               | DRQ<br>pull-down<br>enable | DRQ/DAG                        | CKB select                  | Audio 2 Configuration |
| 7Fh | MPU-401<br>IRQ | HWV IRQ     | Audio 2 IRQ             | Audio 1 IRQ                 | Interrupt select Output enable |                            | Output<br>enable               | Interrupt Control           |                       |

a. Sound Blaster filter control bits F2, F1, and F0 have no function in the ES1887 and are ignored.

(14h, R/W)

#### **Register Detailed Descriptions**

| Reset | Mixer |   |          |           |    | (00ł | n, R/W) |
|-------|-------|---|----------|-----------|----|------|---------|
|       |       |   | Write: R | eset Mixe | er |      |         |
| 7     | 6     | 5 | 4        | 3         | 2  | 1    | 0       |

#### Audio 1 Playback Volume

|   | -          |           |      |                           |   | - | - |  |
|---|------------|-----------|------|---------------------------|---|---|---|--|
| А | udio 1 pla | ıy volume | left | Audio 1 play volume right |   |   |   |  |
| 7 | 6          | 5         | 4    | 3                         | 2 | 1 | 0 |  |

This register controls the playback volume of the first audio channel. On reset, this register assumes the value of 88h.

| Mic I | Mix Volu  | ıme       |     |   |            | <b>(1A</b> | h, <b>R/W)</b> |
|-------|-----------|-----------|-----|---|------------|------------|----------------|
|       | Mic mix v | volume le | eft | 1 | Mic mix vo | olume rigl | ht             |
| 7     | 6         | 5         | 4   | 3 | 2          | 1          | 0              |

This register controls the playback volume of the Mic input. On reset, this register assumes the value of 00h.

| ł | Reco | rd Sou | rce Sel | ect |    |    | (1       | Ch, W) |
|---|------|--------|---------|-----|----|----|----------|--------|
|   | х    | х      | F1      | х   | F0 | Re | cord Sou | irce   |
|   | 7    | 6      | 5       | 4   | 3  | 2  | 1        | 0      |

On reset, this register assumes the value of 00h.

#### Bits Definitions:

| <u>Bits</u> | <u>Name</u>      | Desc                                                                                                 | Description                                                                            |              |                                                      |  |  |  |  |
|-------------|------------------|------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|--------------|------------------------------------------------------|--|--|--|--|
| 7:6         | -                | No fu                                                                                                | nction                                                                                 |              |                                                      |  |  |  |  |
| 5           | F1               | Soun<br>functi                                                                                       | d Blas<br>on in t                                                                      | ter Pro      | o filter control bit. Has no<br>1887 and is ignored. |  |  |  |  |
| 4           | -                | No fu                                                                                                | nction                                                                                 |              |                                                      |  |  |  |  |
| 3           | F0               | Soun<br>functi                                                                                       | Sound Blaster Pro filter control bit. Has no<br>function in the ES1887 and is ignored. |              |                                                      |  |  |  |  |
| 2:0         | Record<br>Source | For extended access, use register address<br>1Ch to select recording from the mixer as fol-<br>lows: |                                                                                        |              |                                                      |  |  |  |  |
|             |                  | <u>bit 2</u>                                                                                         | <u>bit 1</u>                                                                           | <u>bit 0</u> | record source selected                               |  |  |  |  |
|             |                  | х                                                                                                    | 0                                                                                      | х            | Microphone (default)                                 |  |  |  |  |
|             |                  | 0                                                                                                    | 1                                                                                      | х            | CD (AuxA) input                                      |  |  |  |  |
|             |                  | 1                                                                                                    | 1                                                                                      | 0            | Line input                                           |  |  |  |  |
|             |                  | 1                                                                                                    | 1                                                                                      | 1            | Mixer                                                |  |  |  |  |
|             |                  | Bits 4                                                                                               | :3 of F                                                                                | Registe      | er 7Ah determines if mixer                           |  |  |  |  |
|             |                  | input                                                                                                | source                                                                                 | e is Re      | ecord or Playback Mixer.                             |  |  |  |  |

REGISTERS

### PRELIMINARY



#### **Stereo Flag**

(1Eh, R/W) PC Speaker Volume

(3Ch, R/W)

|   | • |    |   |   |   | •              | • |  |
|---|---|----|---|---|---|----------------|---|--|
| x | x | F2 | x | x | x | Stereo<br>flag | x |  |
| 7 | 6 | 5  | 4 | 3 | 2 | 1              | 0 |  |

On reset, this register assumes the value of 00h.

#### **Bits Definitions:**

| <u>Bits</u> | Name           | Description                                                                                                                                               |
|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6         | -              | No function.                                                                                                                                              |
| 5           | F2             | Sound Blaster Pro filter control bit. Has no function in the ES1887 and is ignored.                                                                       |
| 4:2         | -              | No function.                                                                                                                                              |
| 1           | Stereo<br>Flag | <ul> <li>1 = Enable Sound Blaster Pro compatible stereo DAC functions.</li> <li>0 = Disable Sound Blaster Pro compatible stereo DAC functions.</li> </ul> |
| 0           | _              | No function.                                                                                                                                              |

#### Master Volume

(32h, R/W)

|   | Master v | volume le | ft |   | Master vo | lume righ | nt |
|---|----------|-----------|----|---|-----------|-----------|----|
| 7 | 6        | 5         | 4  | 3 | 2         | 1         | 0  |

On reset, this register assumes the value of 88h.

This register provides backward compatible access to master volume. New applications can also use registers 60h and 62h which have more resolution.

| FM V | olume |           |   |   |         | (361     | h, <b>R/W)</b> |
|------|-------|-----------|---|---|---------|----------|----------------|
|      | FM vo | lume left |   |   | FM volu | me right |                |
| 7    | 6     | 5         | 4 | 3 | 2       | 1        | 0              |

This register controls the playback volume of the music DAC. On reset, this register assumes the value of 88h.

| CD ( | AuxA) V   | olume    |      |    |          | (38       | h, <b>R/W)</b> |
|------|-----------|----------|------|----|----------|-----------|----------------|
|      | CD (AuxA) | ) volume | left | CE | ) (AuxA) | volume ri | ght            |
| 7    | 6         | 5        | 4    | 3  | 2        | 1         | 0              |

This register controls the playback volume of the CD audio input. On reset, this register assumes the value of 00h.

| AuxB | Volum  | e         |   |   |          | (3AI      | h, <b>R/W)</b> |
|------|--------|-----------|---|---|----------|-----------|----------------|
|      | AuxB v | olume lef | t |   | AuxB vol | ume right | t              |
| 7    | 6      | 5         | 4 | 3 | 2        | 1         | 0              |

This register controls the playback volume of the auxiliary line input. On reset, this register assumes the value of 00h.

|   |   |   | - |   |      | <b>\</b>  | , . , |
|---|---|---|---|---|------|-----------|-------|
|   |   |   |   |   | PC s | peaker vo | lume  |
| 7 | 6 | 5 | 4 | 3 | 2    | 1         | 0     |

This register controls the PC speaker volume. Bits 2:0 select the attenuation level in steps of -3 dB. The maximum setting of 08h corresponds to 0 dB attenuation. On reset, this register assumes the value of 04h.

| Line | Volume  | •          |                        |   |   | (3Eł | n, R/W) |  |
|------|---------|------------|------------------------|---|---|------|---------|--|
|      | Line vo | olume left | left Line volume right |   |   |      |         |  |
| 7    | 6       | 5          | 4                      | 3 | 2 | 1    | 0       |  |

This registers controls the playback volume of the line input. On reset, this register assumes the value of 00h.

(40h, R/W)



#### FM/Joystick/MPU-401 Configuration

| MPU | l-401 enal<br>IRQ sele | ole and<br>ct | MPL<br>add | J-401<br>ress | Restart<br>configu-<br>ration | Joystick<br>enable | FM<br>enable |
|-----|------------------------|---------------|------------|---------------|-------------------------------|--------------------|--------------|
| 7   | 6                      | 5             | 4          | 3             | 2                             | 1                  | 0            |

Bits 7:3 and Bits 1:0 are cleared by hardware reset. This register is not affected by a mixer reset command (register 00h).

#### **Bits Definitions:**

address

| <u>Bits</u> | <u>Name</u>       | <u>Desc</u>  | ription      |                    |                              |
|-------------|-------------------|--------------|--------------|--------------------|------------------------------|
| 7:5         | MPU-401<br>enable | Enab<br>nel: | les MF       | PU-40 <sup>,</sup> | 1 and select interrupt chan- |
|             | and IRQ           | <u>bit 7</u> | <u>bit 6</u> | <u>bit 5</u>       | <u>function</u>              |
|             | select            | 0            | 0            | 0                  | MPU-401 disabled*            |
|             |                   | 0            | 0            | 1                  | MPU-401 enabled/No IRQ       |
|             |                   | 0            | 1            | 0                  | Share IRQ with audio         |
|             |                   | 0            | 1            | 1                  | IRQE                         |
|             |                   | 1            | 0            | 0                  | IRQA                         |
|             |                   | 1            | 0            | 1                  | IRQB                         |
|             |                   | 1            | 1            | 0                  | IRQC                         |
|             |                   | 1            | 1            | 1                  | IRQD                         |
|             |                   | *Disa        | bled is      | s MPU              | -401 hardware reset default. |

4:3 MPU-401 Selects MPU-401base address:

| <u>bit 3</u> | address                          |
|--------------|----------------------------------|
| 0            | 300h                             |
| 1            | 310h                             |
| 0            | 320h                             |
| 1            | 330h                             |
|              | <u>bit 3</u><br>0<br>1<br>0<br>1 |

2 Restart (Write Only) Used for the ES1888 Compatible configuration Read-Sequence-Key method of software address selection. In this case, writing this bit high puts the ES1887 in its disabled state in anticipation of a new read-sequence-key. The read-sequence-key is used to change the base register address. See "ES1888 Compatible Read-Sequence-Key Method" on page 22.

1 Joystick (R/W) For backward compatibility to the enable ES1888, this bit, when high, enables the decode of register address 201h for read and write to access the internal joystick port. Setting this bit high overrides enable or address selected via SCR 0 bits 5:3 of 0E1h.

0 FM (R/W) For backward compatibility to the enable ES1888, this bit, when high enables the decode of register addresses 388h-3B8h for the internal FM synthesizer. It does not affect FM synthesizer addresses. These are offsets of the base register address. Setting this bit high enables FM alias at the base address specified by SCR 0 bits 7:6 of 0E1h.

#### Serial Interface Registers

This section describes registers related to the DSP and ES689/ES69x serial interface.

|--|

| Input<br>override | Preamp<br>bypass | Input | source |   | Input v | olume |   |
|-------------------|------------------|-------|--------|---|---------|-------|---|
| 7                 | 6                | 5     | 4      | 3 | 2       | 1     | 0 |

### **Bits Definitions:**

| <u>Bits</u> | Name              | Desc                                                                                                                                                           | ription                                                                                                                                                                                                                      |              |  |  |  |  |
|-------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--|--|--|--|
| 7           | Input<br>override | 1 = Ir<br>mal v<br>when<br>0 = Ir<br>uncha                                                                                                                     | <ul> <li>1 = Input source and input volume replace normal values as programmed by the application when the ES1887 is in serial mode.</li> <li>0 = Input source and input volume are unchanged during serial mode.</li> </ul> |              |  |  |  |  |
| 6           | Preamp<br>bypass  | 1 = the 26 dB microphone preamp (if bit 7 is high) is bypassed during serial mode.                                                                             |                                                                                                                                                                                                                              |              |  |  |  |  |
| 5:4         | Input<br>source   | Input source selects the input source during<br>serial mode if bit 7 is high. The values below<br>override the normal mixer settings (register<br>OCh or 1Ch): |                                                                                                                                                                                                                              |              |  |  |  |  |
|             |                   | <u>bit 5</u>                                                                                                                                                   | bit 4                                                                                                                                                                                                                        | input source |  |  |  |  |
|             |                   | 0                                                                                                                                                              | 0                                                                                                                                                                                                                            | Line         |  |  |  |  |
|             |                   | 0                                                                                                                                                              | 1                                                                                                                                                                                                                            | CD (AuxA)    |  |  |  |  |
|             |                   | 1                                                                                                                                                              | 0                                                                                                                                                                                                                            | Microphone   |  |  |  |  |
|             |                   | 1 1 Mixer                                                                                                                                                      |                                                                                                                                                                                                                              |              |  |  |  |  |
|             |                   | Bits 4:3 of Register 7Ah determines if the mixer                                                                                                               |                                                                                                                                                                                                                              |              |  |  |  |  |
|             |                   | input source is Record or Playback Mixer.                                                                                                                      |                                                                                                                                                                                                                              |              |  |  |  |  |

3:0 Input If bit 7 is high during serial mode, this value overrides the input volume settings set via controller register B4h.

REGISTERS



#### Serial Mode Output Control

(44h, R/W)

| Output<br>override | Οι | Output signal |   |   | Output volume |   |   |  |
|--------------------|----|---------------|---|---|---------------|---|---|--|
| 7                  | 6  | 5             | 4 | 3 | 2             | 1 | 0 |  |

#### **Bits Definitions:**

- Bits Name Description
- 7 Output override
  1 = Output volume during serial mode is from this register rather than from the Mixer Master Volume register. Output signal control is always in force during serial mode regardless of the state of this bit.
  0 = Output volume is unchanged during serial mode.
  6:4 Output signal Controls the signal routed to speaker outputs AOUT\_L and AOUT\_R:
  bit 6 bit 5 bit 4 signal

| <u>bit 6</u> | <u>bit 5</u> | <u>bit 4</u> | <u>signal</u>             |
|--------------|--------------|--------------|---------------------------|
| 0            | 0            | 0            | Mute                      |
| 0            | 0            | 1            | Reserved.                 |
| 0            | 1            | 0            | Audio 1 DAC right channel |
|              |              |              | played mono left and      |
|              |              |              | right.                    |
| 0            | 1            | 1            | Reserved.                 |
| 1            | 0            | 0            | Playback mixer output     |
| 1            | 0            | 1            | Playback mixer output     |
|              |              |              | except Audio 1 DAC play-  |
|              |              |              | back.                     |
| 1            | 1            | 0            | Reserved.                 |
| 1            | 1            | 1            | Reserved.                 |
|              |              |              |                           |

3:0 Output Replaces normal master volume setting if bit 7 volume is high during serial mode.

#### Serial Mode Miscellaneous Analog Control (46h, R/W)

| Analog<br>control<br>override | 0 | Left<br>ADC | Right<br>ADC | Analog | control | FDXO<br>enable | FDXI<br>enable |
|-------------------------------|---|-------------|--------------|--------|---------|----------------|----------------|
| 7                             | 6 | 5           | 4            | 3      | 2       | 1              | 0              |

#### **Bits Definitions:**

| <u>Bits</u> | <u>Name</u>        | Description                                                                                                                                                                                                                          |  |  |  |  |  |
|-------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7           | Analog<br>override | <ul><li>1 = Bits 6:0 take effect during serial mode.</li><li>0 = Bits 6:0 do not take effect during serial mode.</li></ul>                                                                                                           |  |  |  |  |  |
| 6           | -                  | Reserved. Always write 0.                                                                                                                                                                                                            |  |  |  |  |  |
| 5           | Left ADC           | 1 = Left channel combined ADC and DAC is in ADC mode.                                                                                                                                                                                |  |  |  |  |  |
|             |                    | 0 = Left channel combined ADC and DAC is in DAC mode.                                                                                                                                                                                |  |  |  |  |  |
| 4           | Right<br>ADC       | 1 = Right channel combined ADC and DAC is in ADC mode.                                                                                                                                                                               |  |  |  |  |  |
|             |                    | 0 = Right channel combined ADC and DAC is in DAC mode.                                                                                                                                                                               |  |  |  |  |  |
| 3:2         | Analog<br>control  | These special control signals control intercon-<br>nections in the analog circuitry. They should be<br>set appropriately for the application as follows:<br><u>bit 3 bit 2 application</u>                                           |  |  |  |  |  |
|             |                    | 00Stereo wave playback or record.01Reserved.                                                                                                                                                                                         |  |  |  |  |  |
|             |                    | 1 0 Full-duplex (mono record and mono playback).                                                                                                                                                                                     |  |  |  |  |  |
|             |                    | 1 1 Mono wave playback or record.                                                                                                                                                                                                    |  |  |  |  |  |
| 1           | FDXO<br>enable     | 1 = Enables FDXO output connection to output<br>pin FOUT_R (right channel filter output).<br>0 = FDXO has 50K pull-up to CMR.                                                                                                        |  |  |  |  |  |
| 0           | FDXI<br>enable     | <ul> <li>1 = Enables FDXI input connection from left channel filter input and thus to the input of the left channel ADC.</li> <li>0 = FDXI input has 50K pull-up to CMR. The left channel filter input and ADC comes from</li> </ul> |  |  |  |  |  |

the input volume stage as usual.

ESS Technology, Inc.



#### Serial Mode Miscellaneous Control

| SE<br>enable | Data<br>format | Serial<br>reset | ES689/<br>ES69x<br>interface<br>enable | Active<br>Iow sync | DSP<br>test<br>mode | Telegaming<br>mode enable | 0 |
|--------------|----------------|-----------------|----------------------------------------|--------------------|---------------------|---------------------------|---|
| 7            | 6              | 5               | 4                                      | 3                  | 2                   | 1                         | 0 |

#### **Bits Definitions:**

# Bits Name Description

| 7 | SE<br>enable                           | <ul> <li>1 = Enable DSP serial port. This signal is synchronized with DCLK input rising edge. If</li> <li>DCLK is not running, enabling SE has no effect.</li> <li>0 = Disable DSP serial port.</li> </ul>                                                                                                                                                                                                                     |
|---|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6 | Data<br>format                         | <ul><li>1 = Data format is 2's complement (signed).</li><li>0 = Data format is unsigned (offset binary).</li></ul>                                                                                                                                                                                                                                                                                                             |
| 5 | Serial<br>reset                        | <ul> <li>1 = Reset Serial register left/right toggle flags.</li> <li>0 = Release reset.</li> <li>Serial reset also inhibits FDXO connection to<br/>FOUT_R and "zeros" all shift registers.</li> </ul>                                                                                                                                                                                                                          |
| 4 | ES689/<br>ES69x<br>interface<br>enable | 1 = Enable ES689/ES69x serial interface.<br>0 = Disable ES689/ES69x serial interface.                                                                                                                                                                                                                                                                                                                                          |
| 3 | Active<br>low sync                     | <ul><li>1 = Active-low frame sync pulse.</li><li>0 = Active-high frame sync pulse.</li></ul>                                                                                                                                                                                                                                                                                                                                   |
| 2 | DSP test<br>mode                       | 1 = Test mode: FSX, FSR, DCLK become out-<br>puts.<br>0 = Disable DSP test mode.                                                                                                                                                                                                                                                                                                                                               |
| 1 | Telegam-<br>ing mode<br>enable         | <ul> <li>1 = Enables telegaming mode. In serial mode, connect first channel DMA (otherwise known as game-compatible DMA) to the system DAC. This allows game-compatible audio to be heard when in serial mode. The system DAC gets its filter clock and volume control from the first channel.</li> <li>0 = In serial mode, the first channel DMA is not played. The second channel is connected to the system DAC.</li> </ul> |

0 – Reserved. Always write 0.

#### Serial Mode Filter Divider

#### (4Ch, R/W)

| Filter<br>override | 0 |   | 2's complement filter divider |   |   |   |   |
|--------------------|---|---|-------------------------------|---|---|---|---|
| 7                  | 6 | 5 | 4                             | 3 | 2 | 1 | 0 |

This register controls the filter clock rate during serial mode.

#### Bits Definitions:

7

| scription |
|-----------|
|           |

- Filter 1 = During serial mode, the filter clock is generoverride ated by dividing down the serial clock. 0 = During serial mode, the filter clock is generated as follows:
  - Generally, the filter roll-off should be positioned at 80% – 90% of the Sample\_Rate/2 frequency. The ratio of the roll-off frequency to the filter clock frequency is 1:82. In other words, first determine the desired roll-off frequency by taking 80% of the Sample\_Rate divided by 2, then multiply by 82 to find the desired Filter Clock frequency. Use the formula below to determine the closest divider: Filter\_Clock\_Frequency = 7.16 MHz / (256-Filter\_Divider\_Register)
- 6:4 Reserved. Always write 0.
- 3:0 2's complement These bits are a 2's complement (signed) value that divides the serial clock. The ratio of filter the filter -3 dB frequency to the filter clock is divider about 1:41.

Examples:

- 02h (-14) External Serial Clock 2.048 MHz / 14 / 41 = 3568 Hz for 8000 Hz sample rate.
- 0Eh (-2) Internal Serial Clock 1.591 MHz / 2 / 41 = 19.4 kHz for 44,100 Hz sample rate. Note that the sample rate divider is an integer multiple of the filter divider for 44,100, which gives maximum performance of DACs and ADCs.

REGISTERS

(4Eh, R/W)



#### Serial Mode Format/Source/Target

| Tra | ansmit | Transmit | Transmit | Rec | ceive | Receive | Receive |
|-----|--------|----------|----------|-----|-------|---------|---------|
| so  | ource  | length   | mode     | sou | urce  | length  | mode    |
| 7   | 6      | 5        | 4        | 3   | 2     | 1       | 0       |

#### **Bits Definitions:**

- Bits Name Description
- 7:6 Transmit Transmit register source:
  - source bit 7 bit 6 source

|   | 011 0 | <u></u>                         |
|---|-------|---------------------------------|
| 0 | 0     | None: Transmit register held at |
|   |       | "zero code.                     |
| 0 | 1     | FIFO.                           |
| 1 | 0     | Left ADC or stereo ADC trans-   |
|   |       | mission.                        |

- 1 Right ADC.
- 5 Transmit 1 = Transmit length is 16 bits, unsigned. length 0 = Transmit length is 8 bits, unsigned.
- 4 Transmit 1 = Transmit mode is stereo. Left and right mode channels alternate, with left channel data preceding right channel data. 0 = Transmit mode is mono.

#### 3:2 Receive Receive register target:

target bit 7 bit 6 target

1

| <u>n 7</u> | $\mathbf{D}\mathbf{I}\mathbf{U}$ | laigei                          |
|------------|----------------------------------|---------------------------------|
| 0          | 0                                | None: Transmit register held at |
|            |                                  | "zero code.                     |
| 0          | 1                                | FIFO.                           |
| 1          | 0                                | DAC (if mono, right channel     |
|            |                                  | receives data, left channel     |
|            |                                  | receives complement of data).   |
| 1          | 1                                | Music DAC (if mono, right chan- |
|            |                                  | nel receives data, left channel |
|            |                                  | receives complement of data).   |

- 1Receive1 = Receive length is 16 bits, unsigned.length0 = Receive length is 8 bits, unsigned.
- 0 Receive 1 = Receive mode is stereo. Left and right mode channels alternate, with left channel data preceding right channel data. 0 = Receive mode is mono.

#### Extended Mode Master Volume Control Registers

This section describes registers related to the Master Volume control in Extended mode. These registers are accessed via I/O addresses Audio\_Base+4h and Audio\_Base+5h.

| Left I | Master | Volume | and M | lute      |           | (60 | n, R/W) |
|--------|--------|--------|-------|-----------|-----------|-----|---------|
| 0      | Mute   |        |       | Left mast | er volume | •   |         |
| 7      | 6      | 5      | 4     | 3         | 2         | 1   | 0       |

This register determines the master volume level for the left channel.

When in Sound Blaster Pro Compatibility mode, writes to registers 22h or 32h are translated into writes to 60h and 62h. See "Sound Blaster Pro Master Volume Emulation" on page 1. Writes to this register when in Compatibility made run the risk of being overwritten.

On hardware reset this register is set to 36h.

#### Bits Definitions:

| <u>Bits</u> | <u>Name</u>              | Description                                                                                                            |
|-------------|--------------------------|------------------------------------------------------------------------------------------------------------------------|
| 7           | -                        | Reserved. Always write 0.                                                                                              |
| 6           | Mute                     | <ul><li>1 = Enable left channel mute.</li><li>0 = Disable left channel mute.</li></ul>                                 |
| 5:0         | Left<br>master<br>volume | Bits 5:0 select the attenuation level in steps of -1.5 dB. The maximum setting of 3Fh corresponds to 0 dB attenuation. |

#### Right Master Volume and Mute

| 5 |      |   |   |           |           | <b>\</b> - | , | ' |
|---|------|---|---|-----------|-----------|------------|---|---|
| 0 | Mute |   | F | Right mas | ter volum | е          |   |   |
| 7 | 6    | 5 | 4 | 3         | 2         | 1          | ( | ) |

This register determines the master volume level for the right channel.

When in Sound Blaster Pro Compatibility mode, writes to registers 22h or 32h are translated into writes to 60h and 62h. See "Sound Blaster Pro Master Volume Emulation" on page 1. Writes to this register when in Compatibility made run the risk of being overwritten.

On hardware reset this register is set to 36h.

#### Bits Definitions:

| <u>Bits</u> | <u>Name</u>               | Description                                                                                                            |
|-------------|---------------------------|------------------------------------------------------------------------------------------------------------------------|
| 7           | -                         | Reserved. Always write 0.                                                                                              |
| 6           | Mute                      | <ul><li>1 = Enable right channel mute.</li><li>0 = Disable right channel mute.</li></ul>                               |
| 5:0         | Right<br>master<br>volume | Bits 5:0 select the attenuation level in steps of -1.5 dB. The maximum setting of 3Fh corresponds to 0 dB attenuation. |

(62h. R/W)



# PRELIMINARY

| Mast        | ter Volur         | ne Cor          | ntrol                   |             |             | (64ł                   | n, R/W)                     | Mic F            | Record \              | /olum            | e                     |                    |                     | (68)                   | h, R/W)        |
|-------------|-------------------|-----------------|-------------------------|-------------|-------------|------------------------|-----------------------------|------------------|-----------------------|------------------|-----------------------|--------------------|---------------------|------------------------|----------------|
|             | _                 |                 |                         |             | Enable      | HWV                    | SB Pro                      |                  | Mic record            | volume           | left                  | Μ                  | ic record           | volume ri              | ght            |
| HWV<br>r    | operation<br>node | Volume<br>count | HWV<br>IRQ flag         | 0           | HWV         | interrupt<br>mask      | master<br>volume<br>disable | 7                | 6                     | 5                | 4                     | 3                  | 2                   | 1                      | 0              |
| 7           | 6                 | 5               | 4                       | 3           | 2           | 1                      | 0                           | This I<br>Set Io | registers<br>ow by ha | contro<br>rdware | ls the re<br>reset, t | cord vo<br>out not | olume fo<br>by mixe | or the Mi<br>er reset. | c input.       |
| Bits I      | Definition        | IS:             |                         |             |             |                        |                             |                  |                       |                  |                       |                    |                     | (00)                   | -              |
| <u>Bits</u> | <u>Name</u>       | Desci           | ription                 |             |             |                        |                             | Audi             | o 2 Reco              | ord Vo           | lume                  |                    |                     | (69)                   | n, R/W)        |
| 7:6         | HWV               | Seleo           | cts hard                | ware vo     | olume o     | peratior               | า                           | Au               | udio 2 reco           | rd volum         | ne left               | Aud                | lio 2 recor         | rd volume              | right          |
|             | operation         | י mode          | e:                      |             |             |                        |                             | 7                | 6                     | 5                | 4                     | 3                  | 2                   | 1                      | 0              |
|             | mode              | <u>bit 7</u>    | <u>bit 6</u>            | <u>mode</u> |             |                        |                             |                  |                       |                  |                       |                    |                     |                        |                |
|             |                   | 0               | 0                       | Norma       | al 3-wire   | mode (ha               | ardware                     | Ihis             | register              | contro           | is the re             | ecord v            | olume               | for the                | second         |
|             |                   | 0               | 4                       | reset de    | efault).    |                        |                             | audic            | channe                | I. Set lo        | bw by ha              | rdware             | reset, b            | but not b              | y mixer        |
|             |                   | 0               | 1                       | Z-WIFe      | e mode: l   | JP and L               |                             | reset            | •                     |                  |                       |                    |                     |                        |                |
|             |                   |                 |                         | MUTE        | input lov   | v                      | 15 a                        |                  |                       |                  |                       |                    |                     | (0.4.1                 | <b>D</b> // 4/ |
|             |                   | 1               | 0                       | 2-wire      | enabled     | l, debour              | nce dis-                    | CD (/            | AUXA) R               | ecora            | volume                | •                  |                     | (6AI                   | n, R/W)        |
|             |                   |                 |                         | abled,      | auto-inci   | rement/d               | ecre-                       |                  | CD record             | volume           | left                  | С                  | D record            | volume rig             | ght            |
|             |                   |                 |                         | ment d      | isabled.    |                        |                             | 7                | 6                     | 5                | 4                     | 3                  | 2                   | 1                      | 0              |
|             |                   | 1               | 1                       | Hardw       | vare volu   | ime conti              | rol dis-                    | <b></b>          |                       |                  |                       |                    |                     |                        |                |
|             |                   |                 |                         | abled.      |             |                        |                             | This             | register (            | control          | s the real            | cord vo            | lume fo             | r the Cl               | D input.       |
| 5           | Volume            | 1 = C           | ount up a               | and dow     | n by 3 fo   | or each p              | oush of                     | Set lo           | ow by ha              | rdware           | e reset, t            | out not            | by mixe             | er reset.              |                |
|             | count             | UP or           | DOWN                    | buttons     |             |                        |                             |                  |                       |                  |                       |                    |                     |                        |                |
|             |                   |                 | ount up a<br>• DOW/N    | ana aow     | vn by 1 to  | or each p              | ousn of                     | Musi             | C DAC F               | Record           | Volum                 | e                  |                     | (6BI                   | h, R/W)        |
| 4           |                   |                 |                         |             | au a at fre | an hardu               |                             |                  | FM record             | volume           | left                  | F                  | M record            | volume rig             | ght            |
| 4           | flag              |                 | -only inte<br>event     | errupt re   | questin     | om nardw               | are voi-                    | 7                | 6                     | 5                | 4                     | 3                  | 2                   | 1                      | 0              |
| З           | _                 | Rese            | rved Alw                | vave wri    | to 0        |                        |                             |                  | .,                    |                  |                       |                    |                     |                        |                |
| 5           | -<br>Enchlo       | Mhan            |                         | vays wii    |             |                        | t for the                   | Ihisi            | register o            | controls         | s the rec             | ord vol            | ume for             | the mus                | SIC DAC        |
| 2           |                   | bardw           | i nign, er<br>vare volu | iables II   | trol inter  | an output<br>rupt This | t ior the                   | (⊢M).            | Set low               | by har           | dware r               | eset, b            | ut not by           | y mixer                | reset.         |
|             | IROE              | cleare          | d by hai                | rdware r    | eset        | rupt. The              |                             |                  |                       |                  |                       |                    |                     |                        |                |
| 1           |                   | When            | high or                 | nahles th   | ne hardw    | are volu               | me con-                     | AuxE             | B Record              | d Volu           | me                    |                    |                     | (6Cl                   | h, R/W)        |
|             | interrupt         | trol to         | be shar                 | ed with     | the audio   | o interrur             | nt This                     | A                | AuxB record           | d volume         | e left                | Au                 | xB record           | d volume r             | right          |
|             | mask              | bit is          | cleared b               | by hardv    | vare rese   | ət.                    |                             | 7                | 6                     | 5                | 4                     | 3                  | 2                   | 1                      | 0              |
| 0           | SB Pro            | When            | low.av                  | vrite to t  | he SB P     | ro Maste               | r Vol-                      |                  |                       |                  |                       |                    |                     |                        |                |
| -           | master            | ume r           | egister v               | vill be tr  | anslated    | into a w               | rite to                     | This             | register              | control          | s the re              | cord v             | olume fo            | or the a               | uxiliary       |
|             | volume            | the ha          | ardware                 | master      | volume o    | counters,              | Mixer                       | line i           | nput. Se              | t low I          | by hard               | ware re            | eset, bu            | it not by              | y mixer        |
|             | disable           | regist          | ers 60h a               | and 62h     | . If high,  | the SB F               | ro Mas-                     | reset            | •                     |                  |                       |                    |                     |                        |                |
|             |                   | ter Vo          | lume reg                | gisters a   | are, in eff | ect, read              | l-only.                     |                  |                       |                  |                       |                    |                     | <i></i>                |                |
|             |                   | Inist           | DIT IS CIE2             | ared by r   | naroware    | e reset.               |                             | Line             | Record                | Volum            | ie                    |                    |                     | (6El                   | n, R/W)        |
| 110-        | huene Me          |                 |                         | 4 D         |             | /2                     |                             | I                | Line record           | d volume         | left                  | Li                 | ne record           | volume ri              | ight           |
| Hard        | ware vo           | nume I          | nterrup                 | n Kequ      | iest Ke     | set (6                 | oon, w)                     | 7                | 6                     | 5                | 4                     | 3                  | 2                   | 1                      | 0              |
|             | Write             | e: Reset        | hardware                | volume      | interrupt I | request                |                             | <b>T</b> I- 1-   | na ni sta c           |                  | a 46 c                | ام                 |                     | يراجع الم              |                |
| _           |                   |                 |                         |             |             |                        |                             |                  |                       |                  |                       |                    |                     |                        |                |

0

This register controls the record volume for the line input. Set low by hardware reset, but not by mixer reset.

# 10

7

6

5

4

interrupt request. This register is write-only.

3

Any write to this register resets the hardware volume

2

1

REGISTERS

#### Audio 2 Mixer Registers

This section describes registers related to the second audio channel. These registers are accessed via I/O addresses Audio\_Base+4h and Audio\_Base+5h.

| Audio 2 Sample Rate Generator | (70h, R/W) |
|-------------------------------|------------|
|                               |            |

| Clock<br>source |   |   | Sam | ple rate d | ivider |   |   |
|-----------------|---|---|-----|------------|--------|---|---|
| 7               | 6 | 5 | 4   | 3          | 2      | 1 | 0 |

This register should be programmed for the sample rate for all DAC operations in extended mode.

The sample rate is determined by the two's complement divider in bits 7:0.

Sample\_Rate = 397.7 kHz / (128-x) if bit 7 = 0. = 795.5 kHz / (256-x) if bit 7 = 1.

where: x = value in bits 6:0 of register 70h.

#### **Bits Definitions:**

| <u>Bits</u> | <u>Name</u> | Description                                    |
|-------------|-------------|------------------------------------------------|
| 7           | Clock       | 1 = Clock source is 795.5 kHz for sample rates |
|             | source      | higher than 22 kHz.                            |
|             |             | 0 = Clock source is 397.7 kHz. for sample      |
|             |             | rates lower than or equal to 22 kHz.           |
| 6:0         | Sample      | Signed sample rate divider.                    |

rate divider Audio 2 Filter Clock Divider

(72h, R/W)

| Filter clock divider |   |   |   |   |   |   |   |  |
|----------------------|---|---|---|---|---|---|---|--|
| 7                    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |

This register controls the low-pass frequency of the switch-capacitor filters inside the ES1887. Generally, the filter roll-off should be positioned at 80% – 90% of the Sample\_Rate/2 frequency. The ratio of the roll-off frequency to the filter clock frequency is 1:82. In other words, first determine the desired roll-off frequency by taking 80% of the Sample\_Rate divided by 2, then multiply by 82 to find the desired Filter Clock frequency. Use the formula below to determine the closest divider:

Filter\_Clock\_Frequency = 7.16 MHz / (256-Filter\_Divider\_Register)

| Audio | o 2 Trai | nsfer C    | ount Re   | eload     |            | (74) | (74h, R/W) |  |  |
|-------|----------|------------|-----------|-----------|------------|------|------------|--|--|
|       | :        | 2's comple | ement tra | nsfer cou | nt – Iow b | yte  |            |  |  |
| 7     | 6        | 5          | 4         | 3         | 2          | 1    | 0          |  |  |

**NOTE:** When suspend/resume bit is set, reading this register returns the current counter contents.

| Audio | 2 Trai | nsfer C    | ount R    | eload      |             | (76 | h, <b>R/W)</b> |
|-------|--------|------------|-----------|------------|-------------|-----|----------------|
|       | 2      | 2's comple | ement tra | nsfer cour | nt – high b | yte |                |
| 7     | 6      | F          | 4         | 2          | 2           | 1   | 0              |

**NOTE:** When suspend/resume bit is set, reading this register returns the current counter contents.

(78h, R/W)



#### Audio 2 Control 1

| DMA DM<br>transfer trans<br>type leng |   | DMA<br>transfer<br>length | Auto-initialize<br>enable | Resume<br>flag | Suspend<br>flag | Enable<br>transfer<br>into<br>FIFO | Enable<br>transfer<br>to DAC |
|---------------------------------------|---|---------------------------|---------------------------|----------------|-----------------|------------------------------------|------------------------------|
| 7                                     | 6 | 5                         | 4                         | 3              | 2               | 1                                  | 0                            |

This register is reset to all zero by hardware or software reset via bit 0 of port Audio\_Base+6h.

#### **Bits Definitions:**

| <u>Bits</u> | <u>Name</u>                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ۸.       |  |  |  |  |
|-------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--|--|--|--|
| 7:6         | DMA<br>transfer                | Selects single or demand transfer for the second audio channel:                                                                                                                                                                                                                                                                                                                                                                                                        |          |  |  |  |  |
|             | type                           | bit 7bit 6transfer typebytes/DMA request00single101demand210demand411demand8                                                                                                                                                                                                                                                                                                                                                                                           | la<br>Th |  |  |  |  |
| 5           | DMA<br>transfer<br>length      | 1 = 16-bit DMA transfer.<br>0 = 8-bit DMA transfer.                                                                                                                                                                                                                                                                                                                                                                                                                    | Bi<br>E  |  |  |  |  |
| 4           | Auto-ini-<br>tialize<br>enable | <ul> <li>1 = Auto-initialize mode. After the transfer counter rolls over to 0, it is automatically reloaded and DMA continues. The second channel interrupt flag is set high.</li> <li>0 = Normal mode. After the transfer counter rolls over to 0, it is reloaded but DMA stops. Bit</li> <li>1 of this register is cleared. The second channel channel is in the provided channel.</li> </ul>                                                                        |          |  |  |  |  |
| 3           | Resume<br>flag                 | (Read Only) If bit 2 is set high, this flag goes<br>low when a suspend request has completed. If<br>bit 2 is low, this flag goes low when the FIFO is<br>empty.                                                                                                                                                                                                                                                                                                        |          |  |  |  |  |
| 2           | Suspend<br>flag                | <ul> <li>1 = suspend alternate DMA request/hold DMA.</li> <li>If DMA is in progress, it halts at the nearest 4-<br/>byte boundary and bit 3 is cleared.</li> <li>If DMA is not in progress when this bit is set<br/>high (i.e. bit 1 is low), then setting this bit high<br/>keeps DMA requests from beginning when bit<br/>1 is also set high, until bit 2 is cleared.</li> <li>This used for resume after suspend: <ol> <li>Bit 1 is cleared.</li> </ol> </li> </ul> |          |  |  |  |  |
|             |                                | <ol> <li>Bit 2 is set.</li> <li>74h/76h are set to count-in-<br/>progress.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                  |          |  |  |  |  |
|             |                                | <ol> <li>Bit 1 is set, thereby latching count-<br/>in-progress into counter.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                |          |  |  |  |  |

- 5. 74h/76h are set to reload value.
- 6. Bit 2 is cleared, allowing DMA to continue.

| <u>Bits</u> | <u>Name</u>                     | Description                                                                                                                                                                                                                                                        |
|-------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1           | Enable<br>transfer<br>into FIFO | <ul> <li>1 = Enable DMA transfer into FIFO.</li> <li>0 = Disable DMA transfer into FIFO. This causes the DMA counter to be reloaded from the reload register.</li> <li>This bit is cleared automatically at the completion of a non-auto-init transfer.</li> </ul> |
| 0           | Enable<br>transfer<br>to DAC    | <ul><li>1 = Enable transfer from FIFO to DAC.</li><li>0 = Disable transfer from FIFO to DAC. DAC receives code 0 and FIFO is flushed.</li></ul>                                                                                                                    |

# udio 2 Control 2

(7Ah, R/W)

| IRQ<br>latch | IRQE<br>enable | DRQ/DACKB<br>enable | Mixer | source | FIFO<br>signed<br>mode | FIFO<br>stereo<br>mode | FIFO<br>16-bit<br>mode |
|--------------|----------------|---------------------|-------|--------|------------------------|------------------------|------------------------|
| 7            | 6              | 5                   | 4     | 3      | 2                      | 1                      | 0                      |

his register is reset to zero by hardware or software reset.

#### its Definitions:

| <u>Bits</u> | <u>Name</u> | <b>Description</b> |
|-------------|-------------|--------------------|
|-------------|-------------|--------------------|

| DILS | INAILIE                 | Description                                                                                                                                                                                                                     |  |  |  |
|------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 7    | IRQ latch               | Audio 2 Interrupt Request Latch. This latch is<br>set high when the DMA counter rolls over to 0,<br>or when a 1 is written to this bit. The latch is<br>cleared by writing a 0 to this bit or by hardware<br>or software reset. |  |  |  |
| 6    | IRQE<br>enable          | <ul><li>1 = enable IRQE output for Audio 2.</li><li>0 = disable IRQE output for Audio 2.</li></ul>                                                                                                                              |  |  |  |
| 5    | DRQ/<br>DACKB<br>enable | 1 = enable DRQ/DACKB output. Which of pair<br>of is pins enabled, is determined by bits 1:0 of<br>register 7Dh. DRQD/DACKBD is the default.<br>0 = disable DRQ/DACKB output.                                                    |  |  |  |
| 4:3  | Mixer<br>source         | These bits select the Mixer record source:bit 4bit 3record source00playback mixer01record mixer10(test) music DAC11(test) system DAC                                                                                            |  |  |  |
| 2    | FIFO<br>signed<br>mode  | 1 = Audio 2 FIFO 2's complement mode.<br>0 = Audio 2 FIFO unsigned (offset 8000).                                                                                                                                               |  |  |  |
| 1    | FIFO<br>stereo<br>mode  | 1 = Audio 2 FIFO stereo mode.<br>0 = Mono data.                                                                                                                                                                                 |  |  |  |
| 0    | FIFO<br>16-bit<br>mode  | 1 = Audio 2 FIFO 16-bit mode.<br>0 = Audio 2 FIFO 8-bit mode.                                                                                                                                                                   |  |  |  |

#### Audio 2 Playback Volume

(7Ch, R/W)

| _                   |   | - |   |                      |   |   | • |   |
|---------------------|---|---|---|----------------------|---|---|---|---|
| Audio 2 volume left |   |   |   | Audio 2 volume right |   |   |   |   |
|                     | 7 | 6 | 5 | 4                    | 3 | 2 | 1 | 0 |

This register controls the playback volume for the second audio channel.

REGISTERS

#### **Audio 2 Configuration**

(7Dh, R/W)

|   |   | 0 |   | FM mix<br>enable | DRQ<br>pull-down<br>enable | DRQ/DA | CKB select |
|---|---|---|---|------------------|----------------------------|--------|------------|
| 7 | 6 | 5 | 4 | 3                | 2                          | 1      | 0          |

This register is reset to 07h by hardware reset.

#### **Bits Definitions:**

| <u>Bits</u> | <u>Name</u>                 | Description                                                                                                                                                                  |
|-------------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4         | -                           | Reserved. Always write 0.                                                                                                                                                    |
| 3           | FM mix<br>enable            | <ul> <li>1 = Enable FM mix mode. In this mode the second audio channel is synchronized and added to the FM output (40612.5 Hz).</li> <li>0 = Disable FM mix mode.</li> </ul> |
| 2           | DRQ pull-<br>down<br>enable | <ul><li>1 = Enable pull-down on selected DRQ. (reset default)</li><li>0 = Disable pull-down on selected DRQ.</li></ul>                                                       |

1:0 DRQ/ Selects the DRQ/DACKB pairs:

| DACKB  | <u>bit 1</u> | <u>bit 0</u> | DRQ/DACKB   |
|--------|--------------|--------------|-------------|
| select | 0            | 0            | DRQA/DACKBA |

| 0 | 0 | DRQA/DACKBA |
|---|---|-------------|
| - |   |             |

- DRQB/DACKBB 0 1
- 0 1 DRQC/DACKBC
- 1 1 DRQD/DACKBD

#### Audio Interrupt Control and Status

Register 7Fh is used to monitor and select audio interrupts. See "Assigning Interrupt Sources" on page 14. This register is meant to replace register B1h.

### Interrupt Control and Status

| ( | 7F | h. | R/ | W) |
|---|----|----|----|----|
| • |    | ,  |    | /  |

| •              |            |                |                |                  |   | •                | , <b>,</b> |
|----------------|------------|----------------|----------------|------------------|---|------------------|------------|
| MPU-401<br>IRQ | HWV<br>IRQ | Audio 2<br>IRQ | Audio 1<br>IRQ | Interrupt select |   | Output<br>enable |            |
| 7              | 6          | 5              | 4              | 3                | 2 | 1                | 0          |

This register is reset to zero by hardware or software reset. Reading bits 7:4 is a simple way to poll the four interrupt sources.

#### **Bits Definitions:**

select

Bits Name Description

- MPU-401 (Read Only) MPU-401 Interrupt Request. 7 IRQ
- 6 HWV IRQ (Read Only) HW Volume Interrupt Request.
- Audio 2 5 (Read Only) Audio 2 Interrupt Request. IRQ
- Audio 1 (Read Only) Audio 1 Interrupt Request. 4 IRQ
- 3:1 Interrupt Interrupt select:

| <u>bit 3</u> | <u>bit 2</u> | bit 1 | interrupt             |
|--------------|--------------|-------|-----------------------|
| 0            | 0            | 0     | ES1888 interrupt mode |
| 0            | 0            | 1     | IRQA                  |
| 0            | 1            | 0     | IRQB                  |
| 0            | 1            | 1     | IRQC                  |
| 1            | 0            | 0     | IRQD                  |
| 1            | 0            | 1     | IRQE                  |
|              |              |       |                       |

- 1 1 0 Reserved.
- Reserved. 1 1 1
- Output 1 = Enable select IRQ output in new interrupt 0 enable mode.

0 = Disable select IRQ output.





### **Controller Registers**

This is a summary and description of the controller registers. These registers are written to and read from using commands of the format Axh or Bxh. To enable access to these registers send the command C6h.

Table 5 ESS Controller Registers Summary

| Reg | D7                                           | D6                                                                                                                                                                                        | D5                                         | D4                            | D3                               | D2                  | D1      | D0                                | Remark                                    |  |  |
|-----|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|-------------------------------|----------------------------------|---------------------|---------|-----------------------------------|-------------------------------------------|--|--|
| A1h | Clock source                                 |                                                                                                                                                                                           |                                            | Sample rate divider           |                                  |                     |         |                                   | S/W reset,<br>unknown                     |  |  |
| A2h |                                              |                                                                                                                                                                                           | Filte                                      | er clock divider              |                                  |                     |         |                                   | S/W reset, setup<br>for 8 kHz<br>sampling |  |  |
| A4h |                                              |                                                                                                                                                                                           | 2's complement                             | t transfer count – low by     | /te                              |                     |         |                                   |                                           |  |  |
| A5h |                                              |                                                                                                                                                                                           | 2's complement                             | transfer count - high b       | yte                              |                     |         |                                   |                                           |  |  |
| A8h |                                              | 0                                                                                                                                                                                         |                                            | 1                             | Record moni-<br>tor enable       | 0                   | Stereo/ | Mono select                       | Analog Control                            |  |  |
| A9h |                                              | -                                                                                                                                                                                         | 0                                          | -                             | Microphone<br>1 preamp<br>enable |                     | 0       |                                   | Mic preamp<br>control                     |  |  |
| B1h | Game<br>Compatible<br>IRQ                    | ame<br>patible<br>RQMask interrupt for DMA<br>transfer<br>completeMask interrupt for FIFO<br>half-empty flag transitionMask all Audio 1<br>sourcesSet to match IRQ select of<br>7F[3:1]hx |                                            |                               |                                  |                     |         | Legacy audio<br>interrupt control |                                           |  |  |
| B2h | DRQ mode                                     | DRQ enable for<br>Extended mode DMA                                                                                                                                                       | DRQ enable for Compat-<br>ibility mode DMA | Inactive DRQ pull-down enable | DRQ/DAC                          | CKB select          |         | Х                                 | Audio DRQ<br>control                      |  |  |
| B4h |                                              | Inpu                                                                                                                                                                                      | t volume right                             |                               |                                  | Input volume        | left    |                                   | Record volume                             |  |  |
| B5h |                                              |                                                                                                                                                                                           | First DMA d                                | irect access - low byte       |                                  |                     |         |                                   |                                           |  |  |
| B6h |                                              |                                                                                                                                                                                           | First DMA di                               | rect access – high byte       |                                  |                     |         |                                   |                                           |  |  |
| B7h | Enable FIFO<br>to/from<br>CODEC              | Set<br>opposite<br>bit 3.                                                                                                                                                                 | FIFO signed mode                           | 1                             | FIFO stereo<br>mode              | FIFO 16-bit<br>mode | 0       | Generate<br>load signal           | Audio 1<br>control 1                      |  |  |
| B8h | 0 CODEC mode DMA mode PMA transfer<br>enable |                                                                                                                                                                                           |                                            |                               |                                  |                     |         |                                   |                                           |  |  |
| B9h |                                              |                                                                                                                                                                                           | 0                                          |                               |                                  |                     | DMA t   | ransfer type<br>select            | Audio 1<br>transfer type                  |  |  |

#### **Controller Register Descriptions**

#### Extended Mode Sample Rate Generator (A1h, R/W)

| Clock<br>source |   |   | Sam | ple rate d | ivider |   |   |
|-----------------|---|---|-----|------------|--------|---|---|
| 7               | 6 | 5 | 4   | 3          | 2      | 1 | 0 |

This register should be programmed for the sample rate for all DAC operations in extended mode.

The sample rate is determined by the two's complement divider in bits 7:0.

Sample\_Rate = 397.7 kHz / (128-x) if bit 7 = 0.

= 795.5 kHz / (256-x) if bit 7 = 1.

where: x = value in bits 6:0 of register A1h.

#### **Bits Definitions:**

- Bits Name Description
- 7 Clock 1 = Clock source is 795.5 kHz for sample rates higher than 22 kHz.
   0 = Clock source is 397.7 kHz. for sample rates lower than or equal to 22 kHz.
- 6:0 Sample Signed sample rate divider. rate divider

REGISTERS

PRELIMINARY

(A2h, R/W)



#### **Filter Clock Divider**

| Filter clock divider |   |   |   |   |   |   |   |  |
|----------------------|---|---|---|---|---|---|---|--|
| 7                    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |

This register controls the low-pass frequency of the switch-capacitor filters inside the ES1887. Generally, the filter roll-off should be positioned at 80% – 90% of the Sample\_Rate/2 frequency. The ratio of the roll-off frequency to the filter clock frequency is 1:82. In other words, first determine the desired roll-off frequency by taking 80% of the Sample\_Rate divided by 2, then multiply by 82 to find the desired Filter Clock frequency. Use the formula below to determine the closest divider:

Filter\_Clock\_Frequency = 7.16 MHz / (256-Filter\_Divider\_Register)

| Audio | (A4I                                     | (A4h, R/W) |   |   |   |   |   |  |  |  |
|-------|------------------------------------------|------------|---|---|---|---|---|--|--|--|
|       | 2's complement transfer count – low byte |            |   |   |   |   |   |  |  |  |
| 7     | 6                                        | 5          | 4 | 3 | 2 | 1 | 0 |  |  |  |

On reset, this register assumes the value of 00h.

# Audio 1 Transfer Count Reload (A5h, R/W)

|   | 2's complement transfer count – high byte |   |   |   |   |   |   |  |  |  |  |
|---|-------------------------------------------|---|---|---|---|---|---|--|--|--|--|
| 7 | 6                                         | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |

On reset, this register assumes the value of F8h.

The FIFO control logic of the ES1887 has a 16-bit counter for controlling transfers to and from the FIFO. These registers are the re-load value for that counter which is the value that gets copied into the counter after each overflow (plus at the beginning of the initial DMA transfer). The counter will be incremented after each successful byte is transferred via DMA. Since the counter counts up towards FFFF and then overflows, the reload value is in 2's complement form.

For Auto-Initialize DMA, the counter is used to generate interrupt requests to the system processor: in this mode DMA continues indefinitely as far as the ES1887 is concerned. In a typical application the counter is programmed to be one-half of the DMA buffer maintained by the system processor. In this case an interrupt is generated whenever DMA switches from one half of the circular buffer to the other.

For Normal mode DMA, DMA requests will be halted at the time that the counter overflows, until a new DMA transfer is commanded by the system processor. Again, an interrupt request will be generated to the system processor if bit 6 of register B1 is set high.

| Analo | g Cont | rol |   |                             |   | (A8          | h, R <b>/W)</b> |
|-------|--------|-----|---|-----------------------------|---|--------------|-----------------|
|       | 0      |     | 1 | Record<br>monitor<br>enable | 0 | Stereo<br>se | o/Mono<br>lect  |
| 7     | 6      | 5   | 4 | 3                           | 2 | 1            | 0               |

When programming the FIFO for DMA playback modify only bits 1:0. When programming the FIFO for DMA Record modify only bits 3, 1, and 0. Read this register first to preserve the remaining bits.

#### **Bits Definitions:**

| <u>Bits</u> | <u>Name</u>                 | Descr                               | <u>iption</u>                                                                   |                                                                                           |  |  |  |  |  |  |
|-------------|-----------------------------|-------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 7:5         | -                           | Reser                               | ved. A                                                                          | lways write 0.                                                                            |  |  |  |  |  |  |
| 4           | -                           | Reser                               | ved. A                                                                          | lways write 1.                                                                            |  |  |  |  |  |  |
| 3           | Record<br>monitor<br>enable | 1 = Er<br>0 = Di                    | <ul><li>= Enable Record Monitor.</li><li>&gt; Disable Record Monitor.</li></ul> |                                                                                           |  |  |  |  |  |  |
| 2           | -                           | Reser                               | Reserved. Always write 0.                                                       |                                                                                           |  |  |  |  |  |  |
| 1:0         | Stereo/<br>Mono<br>select   | Select<br>bit 1<br>0<br>0<br>1<br>1 | t opera<br><u>bit 0</u><br>0<br>1<br>0<br>1                                     | tion mode of Audio 1 converters.<br><u>Mode</u><br>Reserved<br>Stereo<br>Mono<br>Reserved |  |  |  |  |  |  |

#### Mic Preamp Control

#### (A9h, R/W)

| 0 |   |   | 1 | Microphone<br>preamp enable |   | 0 |   |
|---|---|---|---|-----------------------------|---|---|---|
| 7 | 6 | 5 | 4 | 3                           | 2 | 1 | 0 |

#### **Bits Definitions:**

| <u>Bits</u> | <u>Name</u>   | Description                                  |
|-------------|---------------|----------------------------------------------|
| 7:4         | -             | Reserved. Always write 0.                    |
| 3           | -             | Reserved. Always write 1.                    |
| 2           | Mic<br>preamp | 1 = Enable +26 dB gain in microphone preamp. |
|             | enable        | 0 = Disable +26 dB gain in microphone        |
|             |               | preamp.                                      |
| 4.0         |               |                                              |

1:0 – Reserved. Always write 0.



#### ES1887 DATA SHEET

REGISTERS

| Lega             | egacy Audio I                         |                                                                                                   |                                                       | pt Control                                                                          |                                                                                   |                                                              |                                                | B1h                               | Audio                  |                                    |
|------------------|---------------------------------------|---------------------------------------------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--------------------------------------------------------------|------------------------------------------------|-----------------------------------|------------------------|------------------------------------|
|                  | 7                                     |                                                                                                   | 6                                                     | 5                                                                                   | 4                                                                                 | 3                                                            | 2                                              | 1 0                               | DRO                    | D                                  |
| G<br>Com<br>I    | ame<br>ipatible<br>RQ                 | Mask<br>for<br>tra<br>cor                                                                         | interrupt<br>DMA<br>nsfer<br>nplete                   | Maskinterrupt<br>for FIFO half-<br>empty flag<br>transition                         | Mask all<br>Audio 1<br>sources                                                    | Settom<br>IRQ se<br>of 7F[3                                  | natch<br>elect<br>3:1]h                        | x                                 | mode                   | fo<br>n                            |
| Bits [           | Definiti                              | ons:                                                                                              |                                                       |                                                                                     |                                                                                   |                                                              |                                                |                                   | On h                   | naro                               |
| <u>Bits</u><br>7 | <u>Name</u><br>Game<br>Compai         | ihle                                                                                              | $\frac{\text{Descript}}{1 = Fc}$                      | i <u>ption</u><br>or Compatibi<br>or Extended                                       | lity mode.<br>mode                                                                |                                                              |                                                |                                   | ES18<br>regis<br>activ | 387<br>ter:<br>e o                 |
| 6                | IRQ<br>Maskini<br>for DMA<br>transfer | terrupt                                                                                           | 1 = Ma<br>mode                                        | Masks the interrupt for Extended<br>ode DMA transfer complete.                      |                                                                                   |                                                              |                                                |                                   |                        |                                    |
| 5                | Complet<br>Maskini<br>for FIFC        | askinterrupt 1 = Masks the interrupt for Extended<br>r FIFO mode FIFO half-empty flag transition. |                                                       |                                                                                     |                                                                                   |                                                              |                                                |                                   | On a bits 7            | iny<br>7:5.                        |
|                  | half-em                               | npty<br>sition                                                                                    |                                                       |                                                                                     |                                                                                   | 0                                                            |                                                |                                   | Bits I                 | Def                                |
| 4                | Mask a<br>Audio<br>source             | all<br>1                                                                                          | 1 = Ma                                                | asks all au                                                                         | dio 1 sour                                                                        | ces.                                                         |                                                |                                   | <u>Bits</u><br>7       | <u>Na</u><br>Df                    |
| 3:2              | Set to<br>match<br>select<br>7F[3:1   | IRQ<br>of<br>]h                                                                                   | These<br>in New<br>progra<br>by mi<br>those<br>regist | e bits do no<br>w Interrupt<br>ammed to<br>xer register<br>programs<br>er to detern | ot select th<br>method. T<br>match the<br>r 7Fh if po<br>that might<br>mine the i | ne inte<br>They sl<br>pin se<br>ossible<br>t read<br>nterruj | rrup<br>houl<br>elect<br>, for<br>the<br>pt nu | t pin<br>d be<br>æd<br>B1h<br>um- | 6<br>5                 | Df<br>en<br>Ex<br>Df<br>en<br>Co   |
|                  |                                       |                                                                                                   | ber.<br><u>bit 1</u><br>0<br>0<br>1<br>1              | bit 0 IRQX<br>0 IRQA<br>1 IRQE<br>0 IRQE<br>1 IRQE                                  | <u>Pin Rec</u><br>A<br>3<br>C                                                     | ommer<br>IRC<br>IRC<br>IRC<br>IRC                            | n <u>ded</u><br>29<br>25<br>27<br>210          | <u>IRQ</u>                        | 4                      | ity<br>DI<br>Ina<br>DF<br>do<br>en |
| 1:0              | _                                     |                                                                                                   | No fur                                                | nction.                                                                             |                                                                                   |                                                              |                                                |                                   |                        |                                    |
|                  |                                       |                                                                                                   |                                                       |                                                                                     |                                                                                   |                                                              |                                                |                                   | 3:2                    | DF<br>DA<br>se                     |

#### Audio DRQ Control

(B2h, R/W)

| DRQ<br>mode | DRQ enable<br>for Extended<br>mode DMA | DRQ enable for<br>Compatibility<br>mode DMA | Inactive DRQ<br>pull-down<br>enable | DRQ/<br>DACKB<br>select |   | ; | ĸ |
|-------------|----------------------------------------|---------------------------------------------|-------------------------------------|-------------------------|---|---|---|
| 7           | 6                                      | 5                                           | 4                                   | 3                       | 2 | 1 | 0 |

On hardware reset, the DRQs are all disabled and the ES1887 microcontroller needs to program the select registers bits 3 and 2. The selected DRQ output is either active or inactive. It is inactive if bits 6:5 are both low.

The inactive DRQ can either be high-impedance or have an active pull-down device, as determined by the value of bit 4 of register B2h. Unless there is a specific reason not to, bit 4 should be set high.

On any reset, all DRQ sources are disabled by clearing bits 7:5.

#### Bits Definitions:

- 7 DRQ mode 1 = For Compatibility mode DRQ. 0 = For Extended mode DRQ.
- 6 DRQ 1 = Enable DRQ outputs and DACKB inputs enable for for DMA transfers in Extended mode. Extended 0 = Enable block I/O to/from the FIFO in mode DMA Extended mode.
- 5 DRQ 1 = Enable DRQ outputs and DACKB inputs enable for for DMA transfers in Compatibility mode. Compatibil- 0 = For Extended mode. ity mode DMA
- active 1 = Selected DRQ has an active pull-down device. The active pull-down device is RQ pullwn required for Compatibility mode to prevent nable false DRQ requests during the interval between the time that the application programs the system DMA controller and the time the application informs the ES1887 to proceed with DMA. The active pull-down device should be able to sink enough current to override any pull-up device on the system motherboard. It is designed to simulate a resistor < 500 ohms. 0 = Selected DRQ is high-impedance.
- RQ/ DRQ/DACKB select is interpreted as follows: ACK Suggested bit 1 bit 0 DRQx/DACKBx Audio 1 DMA elect 0 0 None N/A 0 1 DRQA/DACKBA 0 1 0 DRQB/DACKBB 1 DRQC/DACKBC 3 1 1 1:0 -No function.

(B4h, R/W)

REGISTERS

#### **Input Volume Control**

| Input volume left |   |   |   | Input volume right |   |   |   |  |
|-------------------|---|---|---|--------------------|---|---|---|--|
| 7                 | 6 | 5 | 4 | 3                  | 2 | 1 | 0 |  |

This register controls the stereo input volume controls. Each channel has 4 bits of control, with a resolution of +1.5 dB per step. For recording sources other than the microphone, the input volume varies from -6 dB to +16.5 dB. For the microphone, the input volume varies from +0 dB (no gain) to +22.5 dB. On reset, this register assumes the value of FFh.

#### First DMA DAC Direct Access

```
(B5h, R/W)
```

| First DMA DAC direct access – low byte |   |   |   |   |   |   |   |  |
|----------------------------------------|---|---|---|---|---|---|---|--|
| 7                                      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |

Low byte of DAC direct access holding register. Because the bus between the ISA bus and the FIFO is only 8-bits wide, the ES1887 has to have somewhere to hold 16-bit data. Registers B5h and B6h serve this function.

| First | First DMA DAC Direct Access |           |          |           |            |     |   |  |
|-------|-----------------------------|-----------|----------|-----------|------------|-----|---|--|
|       |                             | First DMA | DAC dire | ect acces | s – high b | yte |   |  |
| 7     | 6                           | 5         | 4        | 3         | 2          | 1   | 0 |  |

High byte of DAC direct access holding register. Because the bus between the ISA bus and the FIFO is only 8-bits wide, the ES1887 has to have somewhere to hold 16-bit data. Registers B5h and B6h serve this function.

| Audio 1 Control 1 |  |
|-------------------|--|
|-------------------|--|

| Enable<br>FIFO to/<br>from<br>CODEC | Set<br>opposite<br>bit 3. | FIFO<br>signed<br>mode | 1 | FIFO<br>stereo<br>mode | FIFO<br>16-bit<br>mode | 0 | Generate<br>load signal |
|-------------------------------------|---------------------------|------------------------|---|------------------------|------------------------|---|-------------------------|
| 7                                   | 6                         | 5                      | 4 | 3                      | 2                      | 1 | 0                       |

#### **Bits Definitions:**

Bits Name Description

- 7 Enable 1 = Enable Audio 1 FIFO connection to DAC or FIFO to/ ADC. This allow transfers to/from the FIFO and from the analog circuitry.
   CODEC 0 = Disable Audio 1 FIFO connection to DAC
  - or ADC.
- Set oppo- Reserved function. This bit must be set to the site bit 3. opposite polarity of bit 3, namely high for mono and low for stereo.
- 5 FIFO 1 = Audio 1 FIFO 2's complement mode signed (signed data).
- mode 0 = Audio 1 FIFO unsigned (offset 8000).
- 4 Reserved. Always write 1.

| FIFO   | 1 = Audio 1 FIFO stereo mode.                                                                    |
|--------|--------------------------------------------------------------------------------------------------|
| stereo | 0 = Audio 1 FIFO mono mode.                                                                      |
| mode   | Bit 6 must be set at the opposite polarity of this bit, namely low for stereo and high for mono. |
|        | FIFO<br>stereo<br>mode                                                                           |

- 2 FIFO 16- 1 = Audio 1 FIFO 16-bit mode. bit mode 0 = Audio 1 FIFO 8-bit mode.
- 1 Reserved. Always write 0.
- 0 Generate Write 1. Generate a load signal that copies load DAC Direct Access Holding register to DAC on signal the next sample rate clock edge (sample rate is determined by Extended mode register A1h). This bit is cleared after holding register is copied to the DAC.

# Audio 1 Control 2

(B8h, R/W)

| 0 |   |   | CODEC | DMA  | DMA read | DMA transfer |   |
|---|---|---|-------|------|----------|--------------|---|
|   |   |   | mode  | mode | enable   | enable       |   |
| 7 | 6 | 5 | 4     | 3    | 2        | 1            | 0 |

#### **Bits Definitions:**

| <u>Bits</u> | Name                      | Description                                                                                                      |
|-------------|---------------------------|------------------------------------------------------------------------------------------------------------------|
| 7:4         | -                         | Reserved. Always write 0.                                                                                        |
| 3           | CODEC<br>mode             | 1 = CODEC in DAC mode.<br>0 = CODEC in ADC mode.                                                                 |
| 2           | DMA<br>mode               | 1 = Auto-initialize mode.<br>0 = normal DMA mode.                                                                |
| 1           | DMA<br>read<br>enable     | 1 = Audio 1 is read (e.g., for ADC operation).<br>0 = Audio 1 is write (e.g., for DAC operation).                |
| 0           | DMA<br>transfer<br>enable | First DMA active-low reset. When low, the first DMA is held inactive. When high, first DMA is allowed to proceed |



(B7h, R/W)

(B9h, R/W)



REGISTERS

# Audio 1 Transfer Type

| 0 |   |   |   |   |   | DMA transfe | er type select |
|---|---|---|---|---|---|-------------|----------------|
| 7 | 6 | 5 | 4 | 3 | 2 | 1           | 0              |

#### **Bits Definitions:**

| <u>Bits</u> | <u>Name</u> | Description                                 |              |                 |                   |  |  |  |
|-------------|-------------|---------------------------------------------|--------------|-----------------|-------------------|--|--|--|
| 7:2         | -           | Rese                                        | rved. /      | Always write 0. |                   |  |  |  |
| 1:0         | DMA         | Selects the DMA transfer type for the first |              |                 |                   |  |  |  |
|             | transfer    | DMA                                         | :            |                 |                   |  |  |  |
|             | type        | <u>bit 1</u>                                | <u>bit 0</u> | transfer type   | bytes/DMA request |  |  |  |
|             | select      | 0                                           | 0            | Single          | -                 |  |  |  |
|             |             | 0                                           | 1            | Demand          | 2                 |  |  |  |
|             |             | 1                                           | 0            | Demand          | 4                 |  |  |  |
|             |             | 1                                           | 1            | Reserved        | _                 |  |  |  |
|             |             |                                             |              |                 |                   |  |  |  |

AUDIO MICROCONTROLLER COMMAND SUMMARY



# AUDIO MICROCONTROLLER COMMAND SUMMARY

Table 6 Command Summary

| Command | Data Byte(s)<br>Write/Read | Function                                                                                                                                                                                                                                                        |
|---------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10h     | 1 write                    | Direct mode 8-bit DAC. Data is 8-bit unsigned format.                                                                                                                                                                                                           |
| 11h     | 2 writes                   | Direct mode 16-bit DAC. Data is 16-bit unsigned format, first low byte then high byte.                                                                                                                                                                          |
| 14h     | 2 writes                   | Start normal mode DMA for 8-bit DAC transfer. Data is transfer count-1, least byte first. Stereo DAC transfer if Stereo flag is set in Mixer register 0Eh. Maximum sample rate is 44 kHz mono, 22 kHz stereo.                                                   |
| 15h     | 2 writes                   | Start normal mode DMA for 16-bit DAC transfer. Data is transfer count-1, least byte first. Stereo DAC transfer if stereo flag is set in Mixer register 0Eh. Maximum sample rate is 22 kHz mono, 11 kHz stereo.                                                  |
| 1Ch     |                            | Start auto-initialize mode DMA for 8-bit DAC transfer. Block size must be previously set by command 48h. Stereo DAC transfer if stereo flag is set in Mixer register 0Eh. Maximum sample rate is 44 kHz mono, 22 kHz stereo.                                    |
| 1Dh     |                            | Start auto-initialize mode DMA for 16-bit DAC transfer. Block size must be previously set by com-<br>mand 48h. Stereo DAC transfer if stereo flag is set in Mixer register 0Eh. Maximum sample rate is 22<br>kHz mono, 11 kHz stereo.                           |
| 20h     | 1 read                     | Direct mode 8-bit ADC. Data is 8-bit unsigned. Firmware-controlled input volume for AGC.                                                                                                                                                                        |
| 21h     | 2 reads                    | Direct mode 16-bit ADC, returns least byte first. Data is 16-bit unsigned format. Input volume con-<br>trolled via command DDh.                                                                                                                                 |
| 24h     | 2 writes                   | Start normal mode DMA for 8-bit ADC transfer. Data is transfer count-1, least byte first. Firmware-<br>controlled input volume for AGC. Maximum sample rate is 22 kHz: use command 99h for higher<br>rates up to 44 kHz.                                        |
| 25h     | 2 writes                   | Start normal mode DMA for 16-bit ADC transfer. Data is transfer count-1, least byte first. Input vol-<br>ume controlled via command DDh. Maximum sample rate is 22 kHz.                                                                                         |
| 2Ch     |                            | Start auto-initialize mode DMA for 8-bit ADC transfer. Block size must be previously set by command 48h. Firmware-controlled input volume for AGC. Maximum sample rate is 22 kHz: use command 98h for higher rates up to 44 kHz.                                |
| 2Dh     |                            | Start auto-initialize mode DMA for 16-bit ADC transfer. Block size must be previously set by com-<br>mand 48h. Input volume is controlled via command DDh. Maximum sample rate is 22 kHz.                                                                       |
| 30h/31h |                            | MIDI input mode. Detects MIDI serial input data and transfers to Data register, setting Data Available flag in register Audio_Base+Eh. Command 31h will also generate an interrupt request for each byte received.                                              |
|         |                            | Exit MIDI input mode by executing a write to port Audio_Base+Ch. The data written is ignored. A software reset will also exit this mode.                                                                                                                        |
| 34h/35h |                            | MIDI UART mode. Acts like commands 30h/31h, except that any data written to Audio_Base+Ch will be transmitted as MIDI serial output data. The only way to exit this mode is a software reset.                                                                   |
| 38h     | 1 write                    | MIDI output. Transmit one byte.                                                                                                                                                                                                                                 |
| 40h     | 1 write                    | Set time constant, x, for timer used for DMA mode DAC/ADC transfers: rate = $1 \text{ MHz} / (256-x)$ . X must be less than or equal to 233. For stereo transfers, program sample rate for twice the per-channel rate.                                          |
| 41h     | 1 write                    | Alternate set time constant, x: rate = 1.5 MHz / (256-x). This command provides more accurate tim-<br>ing for certain rates such as 22,050. X must be less than or equal to 222. For stereo transfers, pro-<br>gram sample rate for twice the per-channel rate. |
| 42h     | 1 write                    | Set filter clock independently of timer rate. (note that the filter clock is automatically set by commands 40h/41h). Filter clock rate = 7.16E6 / (256-x).                                                                                                      |
|         |                            | The relationship between the low-pass filter -3dB point and the filter clock rate is approximately 1:82.                                                                                                                                                        |
| 48h     | 2 writes                   | Set block size to -1 for high-speed mode and auto-initialize mode transfer, least byte first.                                                                                                                                                                   |



#### AUDIO MICROCONTROLLER COMMAND SUMMARY

# Table 6 Command Summary (Continued)

| Command          | Data Byte(s)<br>Write/Read | Function                                                                                                                                                                                                                                              |
|------------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 64h              | 2 writes                   | Start ESPCM 4.3-bit (low compression) format DMA transfer to DAC. Data is transfer count-1, least byte first.                                                                                                                                         |
| 65h              | 2 writes                   | Same as command 64h, except with reference byte flag.                                                                                                                                                                                                 |
| 66h              | 2 writes                   | Start ESPCM 3.4-bit (medium compression) format DMA transfer to DAC. Data is transfer count-1, least byte first.                                                                                                                                      |
| 67h              | 2 writes                   | Same as command 66h, except with reference byte flag.                                                                                                                                                                                                 |
| 6Ah              | 2 writes                   | Start ESPCM 2.5-bit (high compression) format DMA transfer to DAC. Data is transfer count-1, least byte first.                                                                                                                                        |
| 6Bh              | 2 writes                   | Same as command 6Ah, except with reference byte flag.                                                                                                                                                                                                 |
| 6Eh              | 2 writes                   | Start ESPCM 4.3-bit (low compression) format ADC, compression, and DMA transfer. Data is trans-<br>fer count-1, least byte first.                                                                                                                     |
| 6Fh              | 2 writes                   | Same as command 6Eh, except with reference byte flag.                                                                                                                                                                                                 |
| 74h              | 2 writes                   | Start ADPCM 4-bit format DMA transfer to DAC. Data is transfer count-1, least byte first.                                                                                                                                                             |
| 75h              | 2 writes                   | Same as command 74h, except with reference byte flag.                                                                                                                                                                                                 |
| 76h              | 2 writes                   | Start ADPCM 2.6-bit format DMA transfer to DAC. Data is transfer count-1, least byte first.                                                                                                                                                           |
| 77h              | 2 writes                   | Same as command 76h, except with reference byte flag.                                                                                                                                                                                                 |
| 7Ah              | 2 writes                   | Start ADPCM 2-bit format DMA transfer to DAC. Data is transfer count-1, least byte first.                                                                                                                                                             |
| 7Bh              | 2 writes                   | Same as command 7Ah, except with reference byte flag.                                                                                                                                                                                                 |
| 80h              | 2 writes                   | Generate silence period. Data is number of samples-1.                                                                                                                                                                                                 |
| 90h              |                            | Start auto-initialize, DMA 8-bit transfer to DAC. Transfer count must be previously set by command 48h.                                                                                                                                               |
| 91h              |                            | Start DMA 8-bit transfer to DAC. Transfer count must be previously set by command 48h.                                                                                                                                                                |
| 98h              |                            | Start high-speed mode, auto-initialize, DMA 8-bit transfer from ADC. Transfer count must be previously set by command 48h. There is no AGC. Input volume is controlled with command DDh. Maximum sample rate is 44 kHz.                               |
| 99h              |                            | Start high-speed mode, DMA 8-bit transfer from ADC. Transfer count must be previously set by com-<br>mand 48h. There is no AGC. Input volume is controlled with command DDh. Maximum sample rate<br>is 44 kHz.                                        |
| Axh, Bxh,<br>Cxh |                            | (where $x = 0$ to Fh) ES1887 extension commands. Many of these commands are used to access the ES1887's controller registers. For information on these registers, see the register descriptions.                                                      |
| C0h              |                            | Read controller register.                                                                                                                                                                                                                             |
| C1h              |                            | Resume after suspend.                                                                                                                                                                                                                                 |
| C6h              |                            | Enable ES1887 Extension commands Ax, Bx. Must be issued after every reset.                                                                                                                                                                            |
| C7h              |                            | Disable ES1887 Extension commands Ax, Bx.                                                                                                                                                                                                             |
| CEh              | 1 read                     | Read GPO0/1 Power Management Register.                                                                                                                                                                                                                |
| CFh              | 1 write                    | Write GPO0/1 Power Management Register.                                                                                                                                                                                                               |
| D0h              |                            | Pause DMA. Internal FIFO operations will continue until the FIFO is empty (DAC transfer) or full (ADC transfer). It is not necessary to use this command to stop DMA if the transfer is completed normally and the end-of-DMA interrupt is generated. |
| D1h              |                            | Enable Audio 1 DAC input to playback mixer.                                                                                                                                                                                                           |
| D3h              |                            | Disable Audio 1 DAC input to playback mixer.                                                                                                                                                                                                          |
| D4h              |                            | Continue DMA after command D0h.                                                                                                                                                                                                                       |

# AUDIO MICROCONTROLLER COMMAND SUMMARY



# Table 6 Command Summary (Continued)

| Command | Data Byte(s)<br>Write/Read | Function                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D8h     | 1 read                     | Return Audio 1 DAC enable status:<br>0=disabled<br>FFh=enabled                                                                                                                                                                                                                                                                                                                                |
| DCh     | 1 read                     | Return current input gain, 0-15 (valid during 16-bit ADC and 8-bit "high-speed mode" ADC).                                                                                                                                                                                                                                                                                                    |
| DDh     | 1 write                    | Write current input gain, 0-15 (valid during 16-bit ADC and 8-bit "high-speed mode" ADC).                                                                                                                                                                                                                                                                                                     |
| E1h     | 2 reads                    | Return version number high (3), followed by version number low (1). This indicates Sound Blaster Pro compatibility.                                                                                                                                                                                                                                                                           |
| E7h     | 2 reads                    | Returns Legacy ES688/ES1688 identification bytes: 68h 8xh, where x is the version code. This com-<br>mand may cause other sound card to perform an unknown function, in which case the sound card<br>should be reset after this command is used. The version code, x, is less than 8 for the ES688 and<br>greater than or equal to 8 for the ES1688. See "Identifying the ES1887" on page 28. |
| F2h     |                            | Generate an interrupt for test purposes.                                                                                                                                                                                                                                                                                                                                                      |
| FDh     |                            | Forces power-down. Software or hardware reset is required for wake-up.                                                                                                                                                                                                                                                                                                                        |



# POWER MANAGEMENT

The ES1887 has three power states:

- full power-up
- partial power-down
- full power-down

The decision to power-down partially or fully is made by the system processor. To assist the system processor, activity flags are available that can be monitored by the system processor to track I/O activity to and from the ES1887. After a predetermined idle period, the ES1887 can be commanded to power-down partially or fully.

If the oscillator clock is provided from an external circuit, automatic wake-up upon I/O activity is available. With this feature, the act of reading or writing to an ES1887 I/O port causes the chip to immediately power-up without losing context from partial or fully powered-down states.

If the oscillator clock is provided by a crystal, automatic wake-up from partial power-down is still available because the oscillator continues to run as long as the ES1887 is not fully powered-down. Once the chip is fully powered-down, however, automatic wake-up is not available with a crystal oscillator because of the start-up requirements of the crystal oscillator. It is then the responsibility of the system software to provide for a start-up period for the oscillator before returning control to the application programs that may access the ES1887. In any case, there is no loss of context.



Figure 1 Summary of power states in the ES1887

**Note 1:** after return to full power-up state from full power-down state, the AOUT L/R analog output pins will not be enabled for 48 to 64 msec. The chip should remain in the full power-up state for at least 64 msec to be sure the AOUT pins are enabled before changing to the partial power-down state. Otherwise the AOUT pins may never get enabled. For this reason it is not possible to go directly from full power-down to partial power-down and have AOUT enabled.

**Note 2:** a Low input on any of the three hardware volume control pins (VOLUP, VOLDN, or MUTE) will also act as a wake-up event.

| State | Description                                                                                                                 | Notes                                      |
|-------|-----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|
| 0     | Full power-down. Crystal oscillator<br>disabled. AOUT_L and AOUT_R held at<br>approximately CMR by high value<br>resistors. | All inputs<br>static at<br>VDDD or<br>GND. |
| 1     | Partial power-down. Joystick, MPU-401<br>are up. Audio, FM, ES689/ES69x<br>interface, and DSP serial interface are<br>down. | Digital<br>standby.                        |
| 2     | Full power-up. This is the state after hardware reset.                                                                      | Normal<br>operating<br>conditions.         |



### **Partial Power-Down**

In the partial power-down state, the power supply remains connected to the chip during power-down and the chip's analog section remains active while the digital circuits are mostly inactive.

The total current used by the ES1887 can be reduced by a factor of two or more by putting the ES1887 in a partial power-down state. The crystal oscillator, if used, continues to operate. The analog circuitry remains powered-up so that AuxA, AuxB, Line, and Mic audio sources can continue to be heard. FM and digital audio are muted. There should be no pop when returning from partial power-down to a full power-up state.

The following items are effective for partial power-down operation:

- Oscillator is enabled.
- MPU-401 operates.
- · Configuration device operates.
- H/W volume operates.
- Mixer operates.
- Analog operates.
- · Joystick operates.
- Audio device is disabled, FM disabled.
- Auto wake-up with any I/O activity to FM or audio registers except Audio\_Base+4h, Audio\_Base+5h, Audio\_Base+6h, Audio\_Base+7h.

#### **Causing Partial Power-Down**

To cause the partial power-down state, bit 3 of register Audio\_Base+7h must be high before pulsing bit 2 high, then low, and bit 3 must remain high.

Example: powering down the ES1887 using system software timer interrupt

In this example, it is assumed that the ES1887 is not using a crystal for its clock.

From a timer interrupt routine, read Audio\_Base+6h to monitor activity. After one minute of I/O inactivity, you decide to power-down the ES1887 completely, and then return from the timer interrupt. The ES1887 will wake up automatically upon any I/O access to the ES1887 by any application.

- 1. Check if the ES1887 is already powered down (bit 3 of port Audio\_Base+6h = 0). If so, there is nothing to do.
- 2. Check if the ES1887 is being held in reset by reading bit 0 of port Audio\_Base+6h. If bit 0 is high, release the reset before powering-down: Clear bit 0 of port Audio\_Base+6h, then delay 1 msec or more for the ES1887 microcontroller to complete its initialization.

- Check if the ES1887 is in MIDI mode by testing bit 2 of port address Audio\_Base+6h. While the ES1887 can power-down when in MIDI mode, it will not automatically wake-up if serial data comes in to the MSI pin, and such data will be lost.
- 4. Send a power-down request to the chip by clearing bit 3 in register Audio\_Base+7h, then pulsing bit 2 first high, then low. The other bits of this register should be preserved. The ES1887 microcontroller sees the rising edge of bit 2 of register Audio\_Base+7h as an interrupt request to power-down.

#### Waking from Partial Power-down

Any I/O activity, except Audio\_Base+6h or Audio\_Base+7h, will wake the ES1887 from a partial power-down.

### **Full Power-Down**

PRELIMINARY

Complete power-down reduces the operating current to less than 50 microamps.

The following items are indicators of a full power-down operation:

- Nothing operates, except for some programmed I/O.
- The Activity Flags from a Port Audio\_Base+6h Read are:
  - Bit 7 Activity latch Joystick, MPU-401, Config, or DMA activity.
  - Bit 6 Activity latch: Audio\_Base+4h, Audio\_Base+5h I/O.
  - Bit 5 Activity latch: Audio (except Audio\_Base+4h, Audio\_Base+5h, Audio\_Base+6h read, Audio\_Base+7h read/write), FM I/O or DMA.
  - Bit 4 DSP and ES689/ES69x serial activity status.

#### Waking from Full Power-Down

There are three main ways to wake the chip up from full power-down:

- Hardware reset
- Software reset
- I/O activity

#### Hardware or Software Reset

The chip is automatically restored to activity upon a hardware reset. Context is not preserved.

#### I/O Activity Causing Automatic Wake-up

Automatic wake-up is the method whereby the chip returns to the full power-up state, triggered by I/O activity. With automatic wake-up the context is preserved.

Any I/O access to any of the ES1887 port addresses other than Audio\_Base+6h or Audio\_Base+7h causes an automatic wake-up.



Auto wake-up is also triggered by DMA accesses. However, it is unlikely this will occur if power-down is triggered by a period of I/O inactivity, which includes DMA accesses and the I/O operations required to set up the DMA transfer.

Automatic wake-up requires that XI is driven by a stable clock. This can either be an external clock source or from a crystal. In the latter case, automatic wake-up of the ES1887 is not supported. This is because the oscillator requires some time (typically greater than 25 msec) to stabilize.

In the full power-down state the oscillator is stopped and the analog circuitry is powered-down. The AOUT\_L and AOUT\_R pins are left at approximately the reference voltage by a high-impedance resistor divider.

To wake the chip from a full power-down, set bit 3 of port Audio\_Base+7h high for 25 msec, to enter the partial power-down state. Any I/O activity, except Audio\_Base+6h or Audio\_Base+7h, will then wake the ES1887 from a partial power-down.

#### Inputs and Outputs During Power-Down

When powered-down, digital inputs that do not have pullup or pull-down devices should be driven high or low, that is, they should not be floating. Examples of such pins are A[11:0] and AEN.

Some input pins have circuitry that provides a pull-down device when the ES1887 digital circuits are powered up. During power-down, these inputs have a feedback device that latches the input state and prevents leakage current into the pin. The pull-down device is disabled.

The pins that have this feature are: AMODE, SE, DR

Output pins such as DRQx and IRQx are frozen in their state at power-down.

GPO0 and GPO1 can change state during full powerdown if so programmed (see "General-Purpose Outputs and Power-Down" on page 26).

The MSI pin has an internal pull-up device, so this pin can be left floating during power-down.

The internal inverter connected to pins XI and XO continues to operate when the digital part of the ES1887 is powered-down as long as the analog part of the ES1887 is powered-up

When the chip is fully powered-down, the inverter becomes high-impedance with a weak pull-up on the XO pin.

VREF goes low when the analog circuitry is powered-down.

CMR is pulled low by an internal transistor during analog power-down.

The AOUT\_L and AOUT\_R pins are held at approximately the idle voltage level with a high-impedance resistor divider. After return to full power-up state from full powerdown state, the AOUT analog output pins aren't enabled for 48 to 64 msec. Keep the chip in the full power-up state for at least 64 msec to be sure the AOUT pins are enabled before changing to the partial power-down state. Otherwise the AOUT pins may never get enabled. For this reason, it is not possible to go directly from full powerdown to partial power-down and have AOUT enabled.

#### Suspend/Resume

In Suspend/Resume, power is removed from the ES1887 during its suspended state. Before removing power, the entire context of the microcontroller and registers must be uploaded to the system processor and saved. After restoring power and generating a hardware reset, the opposite resume operation downloads the context.

The term "suspend" is used here to describe the process of uploading the context of the ES1887 and removing digital and analog power to the chip. The term "resume" describes the process of applying power to the ES1887 and downloading the context.

The ES1887 requires 782 bytes to store its entire context.

It is possible to suspend the ES1887 regardless of its current state. This includes suspending in the middle of a DMA transfer.

To suspend operation of the ES1887 pulse bit 7 of port address Audio\_Base+7h high, then low. This interrupts the ES1887 microcontroller and begins a sequence of upload operations.

To resume operation of the ES1887, a hardware reset is required before downloading the context. Downloading the context is initiated with command C1h. Before sending the download command send the C6h command to enable access to the Extension commands.

A sample assembly language program that implements Suspend/Resume from a TSR is available from the Applications Department of ESS Technology, Inc.

#### Pop Prevention in the External Amplifier

Normally, in order to directly drive speakers in an ES1887 design, an external stereo amplifier chip is used. There are two power management problems associated with an external amplifier:

1. The amplifier itself draws current unless it can be powered down.



2. Suspend/Resume causes pops because power is removed from the ES1887 and then re-applied.

Amplifiers such as the SGS/Thomson TDA7233 have a mute input which reduces current to 400  $\mu$ a and also reduces pops from the suspend/resume process. This part is a mono amplifier, so two are required. Connect GPO0 to the active-low MUTE input of the TDA7233. In this case the amplifier is muted after hardware reset. During start-up, program the ES1887 so that GPO0 is high when powered-up and low when fully powered-down. Program a delay of about 133 msec between power-down and power-up states, before GPO0 returns high so that the ES1887 analog circuits can settle.

#### Power Management and the FM Synthesizer

The ES1887 FM synthesizer is a fully static design. This means that the clock can be stopped to power-down the circuitry without loss of state. For suspend/resume applications, the entire context of the synthesizer can be read back.

#### Self-Timed Power-Down

The ES1887 microcontroller can be programmed to monitor I/O activity in place of the system processor, and after a programmable period of inactivity, enter either a partial or full power-down state.

In Self-Timed Power-Down mode, power is maintained as for partial or full power-down, except the decision to power-down is made by the ES1887 itself. The ES1887 microcontroller waits for a pre-programmed period of I/O inactivity between successive commands, before entering partial or full power-down state.

The ES1887 needs to use the activity flags in port Audio\_Base+6h. Therefore, if this feature is enabled, the system processor can't monitor I/O activity.

#### **Enabling Self-Timed Power-Down**

- 1. Send command C6h to enable access to the controller registers.
- 2. Send command BDh.
- Send the time out value N, where the time period is N x 8 seconds. If N is zero, self-timed power-down is disabled.
- 4. Send command C7h to disable access to the controller registers.

Whether the ES1887 enters partial or full power-down is determined by bit 3 of register Audio\_Base+7h.

Even if self-timed power-down is enabled, the ES1887 can be commanded to power-down via bit 2 of register Audio\_Base+7h. There is one limitation to this feature: the timing of inactivity only occurs between commands sent to the ES1887. It is possible for a program to leave the ES1887 in a state where timing doesn't happen. For example, if a program exits without a DMA transfer being completed. Most programs are well-behaved in this respect and leave the ES1887 in a well defined state.



#### **General-Purpose Outputs and Power-Down**

The ES1887 has the ability to have one or both of the general-purpose outputs GPO0 and GPO1 change state when the ES1887 is powered-down.

After hardware reset, this feature is disabled and the general-purpose outputs are not affected by power-down. A controller register in the ES1887 must be programmed to enable this feature. Specifically, the GPO power-down control register is set by writing the command CFh to port Audio\_Base+Ch followed by the data. To read the GRO power-down controller register write the command CEh to Audio Base+Ch and read the data from port Audio\_Base+Ah. This register should be set once by system software after system reset. This register is unaffected by soft resets. Using this register, one or both of the general-purpose outputs can be programmed to be inverted from their normal state during power-down. The normal state of each pin is set by the appropriate bits 1:0 of port Audio\_Base+7h. A further feature allows the inverted outputs to return to their normal state immediately after power-up or after a programmed delay after powerup.

#### **GPO Power-Down Register**

| Delay GPO0<br>state return<br>enable | 1: invert<br>GPO1 at<br>power-down | Delay GPO0<br>state return<br>enable | 1: invert<br>GPO0 at<br>power-down | 0 |   | Ti<br>de | ime<br>ela | e<br>y |
|--------------------------------------|------------------------------------|--------------------------------------|------------------------------------|---|---|----------|------------|--------|
| 7                                    | 6                                  | 5                                    | 4                                  | 3 | 2 |          | 1          | 0      |

On reset, this register assumes the value of 00h. This means that GPO0 and GPO1 are unaffected by the powerdown status; that is, they remain in the state programmed into port Audio\_Base+7h.

**NOTE:** "Power-down" as used in this document refers to full power-down, i.e., when both the analog and digital parts of the ES1887 are powered-down.

#### **Bits Definitions:**

| <u>Bits</u> | <u>Name</u>                                | Description                                                                                                                                                                                                                                                                         |
|-------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7           | Delay<br>GPO1<br>state<br>return<br>enable | <ul> <li>1 = Delay GPO1's return to its normal state as<br/>determined by port Audio_Base+7h bit 1. The<br/>time delay is determined by bits 2:0, described<br/>below.</li> <li>0 = Return GPO1 to its normal state immedi-<br/>ately upon wake-up from full power-down.</li> </ul> |
| 6           | GPO1<br>invert<br>enable                   | 1 = invert bit 1 of Audio_Base+7h when enter-<br>ing the full power-down state.                                                                                                                                                                                                     |
| 5           | Delay<br>GPO0<br>state<br>return<br>enable | <ul> <li>1 = Delay GPOO's return to its normal state as determined by port Audio_Base+7h bit 0. The time delay is determined by bits 2:0, described below.</li> <li>0 = Return GPO0 to its normal state immedi-</li> </ul>                                                          |
|             |                                            | ately upon wake-up from full power-down.                                                                                                                                                                                                                                            |
| 4           | GPO1<br>invert<br>enable                   | 1 = invert bit 0 of Audio_Base+7h when enter-<br>ing the full power-down state.                                                                                                                                                                                                     |
| 3           | -                                          | Reserved. Always write 0.                                                                                                                                                                                                                                                           |
| 2:0         | Time<br>delay                              | The time period is determined by bits [2:0]: A<br>16 Hz counter starts at 0 and counts until it<br>equals the 3-bit number "time delay". The max-                                                                                                                                   |

imum delay is (Time delay = 7) times (67)

msec) or about 469 msec.



# ELECTRICAL CHARACTERISTICS

### **Absolute Maximum Ratings**

| Ratings                      | Symbol | Value       | Units |
|------------------------------|--------|-------------|-------|
| Analog supply voltage range  | VDDA   | -0.3 to 7.0 | V     |
| Digital supply voltage range | VDDD   | -0.3 to 7.0 | V     |
| Input voltage                | VIN    | -0.3 to 7.0 | V     |
| Operating temperature range  | TA     | 0 to 70     | °C    |
| Storage temperature range    | TSTG   | -50 to 125  | °C    |

**WARNING:** Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. There are stress ratings only. Operation beyond the "Operating Conditions" is not recommended and extended exposure beyond the "Operating Conditions" may affect device reliability.

# **Thermal Characteristics**

The ES1887 is designed to operate at case temperatures less than  $78^{\circ}$  C.

### **Operating Conditions**

The ES1887 digital and analog characteristics operate under the following conditions:

| VDDD | 4.5V to 5.5V   |
|------|----------------|
| VDDA | 4.75V to 5.25V |
| ТА   | 25°            |

| Table 7 | Digital | Characteristics |
|---------|---------|-----------------|
|---------|---------|-----------------|

| Parameter                                                           | Symbol | Min | Max | Unit (conditions)                      |
|---------------------------------------------------------------------|--------|-----|-----|----------------------------------------|
| Input high voltage: all inputs except XI.                           | VIH1   | 2.0 |     | Volts (VDDD = min)                     |
| Input high voltage: XI.                                             | VIH2   | 3.0 |     | Volts (VDDD = min)                     |
| Input low voltage                                                   | VIL    |     | 0.8 | Volts (VDDD = max)                     |
| Output low voltage: all outputs except D[15:0], IRQ(A-E), DRQ(A-D)  | VOL1   |     | 0.4 | Volts (IOL = 4 mA, VDDD = min)         |
| Output high voltage: all outputs except D[15:0], IRQ(A-E), DRQ(A-D) | VOH1   | 2.4 |     | Volts (IOH = -3 mA, VDDD = max)        |
| Output low voltage: D[15:0], IRQ(A-E),<br>DRQ(A-D)                  | VOL2   |     | 0.4 | Volts (IOL = 16 mA, VDDD = min)        |
| Output high voltage: D[15:0], IRQ(A-E),<br>DRQ(A-D)                 | VOH2   | 2.4 |     | Volts (IOH = -12 mA, VDDD = max)       |
| Output low voltage                                                  | VOL3   |     | 0.4 | Volts (IOL = 0.8 mA)                   |
| VDDD active                                                         | ICC1   |     | 60  | mA (VDDD = max osc. rate at 14.32 MHz) |
| VDDA active                                                         | ICC2   |     | 40  | mA (VDDA = max)                        |



ELECTRICAL CHARACTERISTICS

# Table 8 Analog Characteristics

| Parameter            | Pins                                                               | Min  | Тур  | Max       | Unit (conditions)   |
|----------------------|--------------------------------------------------------------------|------|------|-----------|---------------------|
| Reference voltage    | CMR, VREF                                                          |      | 2.25 |           | volts (VDDA = 5.0V) |
| Input impedance      | LINE_L,<br>LINE_R,<br>AUXA_L,<br>AUXA_R,<br>AUXB_L,<br>AUXB_R, MIC | 30k  |      | 100k      | ohms                |
|                      | CIN_L, CIN_R                                                       | 35k  | 50k  | 65k       | ohms                |
| Output impedance     | FOUT_L,<br>FOUT_R                                                  | 3.5k | 5k   | 6.5k      | ohms                |
|                      | AOUT_L,<br>AOUT_R max<br>load for full-<br>scale output<br>range   |      | 5k   |           | ohms                |
| Input voltage range  | MIC                                                                | 10   |      | 125       | mVp-p               |
|                      | LINE_L,<br>LINE_R,<br>AUXA_L,<br>AUXA_R,<br>AUXB_L,<br>AUXB_R      | 0.5  |      | VDDA -1.0 | volts               |
| Output voltage range | AOUT_L,<br>AOUT_R<br>max load for full-<br>scale output<br>range   | 0.5  |      | VDDA -1.0 | volts               |
| Mic preamp gain      | MIC                                                                |      | 26   |           | decibels (dB)       |



# **ES1887 TIMING DIAGRAMS**















**ES1887 TIMING DIAGRAMS** 



Figure 5 Compatibility Mode DMA Write Cycle<sup>1</sup>





<sup>&</sup>lt;sup>1.</sup> In Compatibility mode DMA, the DMA request is reset by the acknowledge signal going low. In Extended mode DMA, the DMA request is reset when the acknowledge signal is low AND the correct command signal is low – either IORB (for DMA read from I/O device) or IOWB (for DMA write to I/O device). For Extended mode DMA, the time t<sub>10</sub> is relative to the later of the falling edge of the acknowledge signal or the command signal or the command signal.

PRELIMINARY

ES1887 TIMING DIAGRAMS









ES1887 TIMING DIAGRAMS



Figure 8 Serial Mode Receive Operation





TIMING CHARACTERISTICS



# TIMING CHARACTERISTICS

Table 9 Timing Characteristics

| Symbol          | Parameter                                        | Min | Тур    | Max | Units |
|-----------------|--------------------------------------------------|-----|--------|-----|-------|
| t <sub>1</sub>  | Reset pulse width                                | 300 |        |     | ns    |
| t <sub>2</sub>  | IORB, IOWB pulse width                           | 100 |        |     | ns    |
| t <sub>3</sub>  | IORB, IOWB address setup time                    | 10  |        |     | ns    |
| t <sub>4</sub>  | Read data access time                            |     |        | 70  | ns    |
| t <sub>5</sub>  | Read data hold time                              |     |        | 10  | ns    |
| t <sub>6</sub>  | Write data setup time                            | 5   |        |     | ns    |
| t <sub>7</sub>  | Write data hold time                             | 10  |        |     | ns    |
| t <sub>8</sub>  | DMA request to AEN high                          | 0   |        |     | ns    |
| t <sub>9</sub>  | DMA request to DMA ACK                           | 10  |        |     | ns    |
| t <sub>10</sub> | DMA ACK to request release <sup>a</sup>          |     |        | 30  | ns    |
| t <sub>11</sub> | DMA ACK high to AEN low                          | 0   |        |     | ns    |
| t <sub>12</sub> | DMA ACK to IOWB, IORB low                        | 0   |        |     | ns    |
| t <sub>13</sub> | IOWB, IORB to DMA ACK release                    | 20  |        |     | ns    |
| t <sub>14</sub> | Crystal frequency, XI/XO                         |     | 14.318 |     | MHz   |
| t <sub>15</sub> | AEN, A[11:0], IOWB to ENB245 low                 |     |        | 20  | ns    |
| t <sub>16</sub> | AEN, A[11:0], IOWB to ENB245 high                |     |        | 15  | ns    |
| t <sub>17</sub> | AEN, A[11:0], IORB to ENB245 low                 |     |        | 25  | ns    |
| t <sub>18</sub> | AEN, A[11:0], IORB to ENB245 high                |     |        | 25  | ns    |
| t <sub>19</sub> | AEN, A[11:0], IOWB, IORB to GPO0, GPO1<br>delays |     |        | 20  | ns    |
| t <sub>20</sub> | SE high to valid FSR, FSX edge                   | 2   |        |     | DCLK  |
| t <sub>21</sub> | SE release time to last DX, DR data bit          | 1   |        |     | DCLK  |
| t <sub>22</sub> | SE, FSX, FSR setup time to DCLK edge             | 15  |        |     | ns    |
| t <sub>23</sub> | SE, FSX, FSR, DR hold time to DCLK edge          | 10  |        |     | ns    |
| t <sub>24</sub> | DX delay time from DCLK edge                     |     |        | 20  | ns    |
| t <sub>25</sub> | DX hold time from DCLK edge                      | 10  |        |     | ns    |
| t <sub>26</sub> | FSR, FSX pulse width                             | 60  | 500    |     | ns    |
| t <sub>27</sub> | DCLK clock frequency                             |     | 2.048  |     | MHz   |

a. In Compatibility mode DMA, the DMA request is reset by the acknowledge signal going low. In Extended mode DMA, the DMA request is reset when the acknowledge signal is low AND the correct command signal is low – either IORB (for DMA read from I/O device) or IOWB (for DMA write to I/O device). For Extended mode DMA, the time t<sub>10</sub> is relative to the later of the falling edge of the acknowledge signal or the command signal.



# MECHANICAL DIMENSIONS



| Symbol | Description               | Millimeters |       |       |
|--------|---------------------------|-------------|-------|-------|
|        |                           | Min         | Nom   | Max   |
| D      | Lead to lead, X-axis      | 23.65       | 23.90 | 24.15 |
| D1     | Package's outside, X-axis | 19.90       | 20.00 | 20.10 |
| E      | Lead to lead, Y-axis      | 17.65       | 17.90 | 18.15 |
| E1     | Package's outside, Y-axis | 13.90       | 14.00 | 14.10 |
| A1     | Board standoff            | 0.10        | 0.25  | 0.36  |
| A2     | Package thickness         | 2.57        | 2.71  | 2.87  |
| b      | Lead width                | 0.20        | 0.30  | 0.40  |
| е      | Lead pitch                | -           | 0.65  | -     |
| e1     | Lead gap                  | .24         | -     | -     |
| L      | Foot length               | 0.65        | 0.80  | 0.95  |
| L1     | Lead length               | 1.88        | 1.95  | 2.02  |
| -      | Foot angle                | 0°          | -     | 7°    |
| -      | Coplanarity               | -           | -     | 0.102 |
| -      | Leads in X-axis           | -           | 30    | -     |
| -      | Leads in Y-axis           | -           | 20    | -     |
| -      | Total leads               | -           | 100   | -     |
| -      | Package type              | -           | PQFP  | -     |

Figure 10 Mechanical Dimensions



APPENDIX A: ES689/ES69X DIGITAL SERIAL INTERFACE

# APPENDIX A: ES689/ES69X DIGITAL SERIAL INTERFACE

In order for the ES689/ES69x to acquire the FM DAC, bit 4 of Mixer register 48h inside the ES1887 must be set high. When bit 4 is set high, activity on the MCLK signal will cause the FM DAC to be connected to the ES689/ ES69x. If MCLK stays low for more than a few sample periods the ES1887 will reconnect the FM DAC to the FM synthesizer.

After reset, the ES689/ES69x will transmit samples continuously. In this mode bit 4 of Mixer register 48h must be set/cleared to assign the current owner of the FM DAC.

The ES689/ES69x can be programmed to enter Activity-Detect mode using system exclusive command 4. In this mode, the ES689/ES69x will block the serial port output (i.e., set MSD and MCLK low) if no MIDI input is detected on the MSI pin for a period of 5 seconds. It will resume output of data on the serial port as soon as a MIDI input is detected on the MSI pin. This is the recommended mode of operation.



Bit Clock Rate (MCLK):2.75 MHzSample Rate:42968.75 HzMCLK Clocks per Sample:33 clocks (+ 31 missing clocks)MSD Format:16 bits, unsigned (offset 8000h), MSB first

MSD changes after rising edge of MCLK. Hold time relative to MCLK rising edge is 0-25 nanoseconds.



APPENDIX B: SCHEMATIC EXAMPLES

# APPENDIX B: SCHEMATIC EXAMPLES



#### APPENDIX B: SCHEMATIC EXAMPLES



Figure 11 ES1887



Figure 12 PC Interface

APPENDIX B: SCHEMATIC EXAMPLES



Figure 13 Amplifier Section



APPENDIX C: BILL OF MATERIALS

# APPENDIX C: BILL OF MATERIALS

Table 10 ES1887 Schematics Bill of Materials (BOM)

| Item | Quantity | Reference                                           | Part               |
|------|----------|-----------------------------------------------------|--------------------|
| 1    | 14       | C1,C2,C3,C4,C7,C8,C14, C19,C26,C27,C37,C42,C43, C51 | .1 μF C805         |
| 2    | 2        | C5,C6                                               | 22 pF C805         |
| 3    | 8        | C9,C10, C24, C25, C46, C47, C52, C53                | 10 μF .100 Radial  |
| 4    | 10       | C11,C12,C13,C15,C16,C17, C20,C21,C48,C49            | 22 pF C805         |
| 5    | 2        | C18, C45                                            | 47 μF .100 Radial  |
| 6    | 3        | C22,C23,C54                                         | .001 μF Radial     |
| 7    | 1        | C28                                                 | 150 pF C805        |
| 8    | 11       | C29,C30,C31,C32,C33,C34C35,C36,C40,C41,C50          | .01 μF C805        |
| 9    | 2        | C38,C39                                             | 470 μF .180 Radial |
| 10   | 1        | C44                                                 | 100 μF .100 Radial |
| 11   | 1        | D1                                                  | 1N4148             |
| 12   | 5        | JP1,JP2,JP3,JP4,JP5                                 | 3P SMD             |
| 13   | 1        | J1                                                  | 13x2 HEADER        |
| 14   | 1        | J2                                                  | DB15S              |
| 15   | 1        | J3                                                  | 4 HEADER           |
| 16   | 1        | J4, J5, J7, J8                                      | 3.5mm Stereo Jack  |
| 17   | 1        | J6                                                  | 2x1 HEADER         |
| 18   | 1        | J9                                                  | IBM J1             |
| 20   | 1        | J10                                                 | IBM J2             |
| 21   | 1        | Q1                                                  | Ferrite bead       |
| 22   | 2        | R1,R2                                               | 7.5k R805          |
| 23   | 10       | R3,R4,R5,R6,R7,R8,R9,R10,R11,R12                    | 2.2k R805          |
| 24   | 1        | R13                                                 | 22k R805           |
| 25   | 4        | R14,R15,R16,R17                                     | 1M R805            |
| 26   | 4        | R18,R29,R30,R35                                     | 10k Stereo Pot     |
| 27   | 2        | R19,R20                                             | 33k R805           |
| 28   | 4        | R21,R22,R23,R24                                     | 820k R805          |
| 29   | 2        | R25,R26                                             | 2.7 ohm            |
| 30   | 2        | R27,R28                                             | 15k R805           |
| 31   | 2        | R31,R32                                             | 220k R805          |
| 32   | 1        | R33                                                 | 470 ohm            |
| 33   | 1        | R34                                                 | 100k R805          |
| 34   | 3        | S1,S2,S3                                            | SW Pushbutton      |
| 35   | 1        | U1                                                  | 78L05 TO-92        |
| 36   | 1        | U2                                                  | ES1887 QFP100      |
| 37   | 1        | U3                                                  | 74LS138            |
| 38   | 1        | U4                                                  | LM1877             |
| 39   | 1        | Y1                                                  | 14.318MHz Crystal  |





# **PCB** Layout

Notebook, Motherboard, Pen-based, and PDA portable computers have the following similarity in PCB layout design:

- 1. Multi-layer (usually 4 to 8 layer).
- 2. Double-sided SMT.
- 3. CPU, core logic (chip set), system memory, VGA controller, and video memory reside in the same PCB.

This is a very noisy environment for adding an audio circuit. The following are the guidelines for PCB layout for an ESS *Audio*Drive<sup>®</sup> chip application.

#### **Component Placement**

The audio circuit-related components, including the audio I/O jack and connector, must be grouped in the same area.

There are two possible placements for these audio components:

- A grouped on one side of the PCB.
- B separated on both sides of the PCB.

In Case B, audio component grouping will take less space.

#### **Analog Ground Plane**

Audio circuits require two layers of analog ground planes for use as shielding for all analog traces.

In component placement case A (Figure 14), the first layer of analog ground plane is on the analog component side, the second analog ground plane is on the inner layer, and the analog traces are embedded between these two planes.

In component placement case B (Figure 15), the analog ground planes are on both sides of the PCB, and the analog traces are shielded in the middle.



#### **Special Notes**

The analog traces should be placed as short as possible.

The MIC-IN circuit is the most sensitive of the audio circuits, and requires proper and complete shielding.



# **COPYRIGHTS AND TRADEMARKS**

# **Copyright Notice**

Copyright © 1995–1996 by ESS Technology, Inc. All rights reserved.

No part of this publication may be reproduced, stored in a retrieval system, transmitted, or translated in any form or by any means, electronic, mechanical, manual, optical, or otherwise, without the prior written permission of ESS Technology, Inc.

### Disclaimer

ESS Technology, Inc. makes no representations or warranties regarding the content of this document.

The information and specifications contained in this document are subject to change without prior notice.

ESS Technology, Inc. assumes no responsibility for any errors contained herein.

Products in this document may be covered by U.S. Patent 4,214,125 and others; other patents pending.

### Trademarks

*Audio*Drive<sup>®</sup> and ESPCM<sup>®</sup> are registered trademarks of ESS Technology, Inc.

ESFM<sup>™</sup> is a trademark of ESS Technology, Inc.

All other brand names and product names mentioned in this document are trademarks or registered trademarks of their respective owners and are used for identification purposes only.

#### **Revision History**

| REV | Changes                   |
|-----|---------------------------|
| А   | Initial document release. |



ESS Technology, Inc. 48401 Fremont Blvd. Fremont, CA 94538 Tel: 510-492-1088 Fax: 510-492-1098