

# Solo-1<sup>™</sup> PCI *Audio*Drive<sup>®</sup> Solution Data Sheet

## DESCRIPTION

The Solo-1<sup>™</sup> PCI *Audio*Drive<sup>®</sup> solution implements a singlechip PCI audio solution, providing high-quality audio processing while maintaining full legacy DOS game compatibility. With a dynamic range over 80 dB, the Solo-1 complies with the Microsoft<sup>®</sup> PC 97/PC 98 specifications and meets WHQL audio requirements. The Solo-1 forms a complete audio subsystem on a single chip for both add-in card and motherboard platforms.

The Solo-1 incorporates a microcontroller, ESFM™ music synthesizer, 3-D stereo effects processor, 16-bit stereo wave ADC and DAC, 16-bit stereo music DAC, MPU-401 UART mode serial port, dual game port, hardware master volume control, a serial port interface to external wavetable music synthesizer, DMA control logic with FIFO, and PCI bus interface logic. There are three stereo inputs (typically line-in, CD audio, and auxiliary line) and a mono microphone input.

The Solo-1 integrates ESS' field-proven hardware design for DOS game compatibility with hardware FM synthesis (ESFM) and three methods for legacy audio control interface: PC/PCI, Distributed DMA, and Transparent DMA. Transparent DMA requires no sideband signals from PC core logic chipsets in addition to the standard PCI 2.1 bus. TDMA is compatible with Pentium<sup>®</sup>, Pentium Pro<sup>®</sup>, and Pentium<sup>®</sup> II chipsets as well as standard PCI add-in cards.

The Solo-1 can record, compress, and play back voice, sound, and music with built-in mixer controls. It supports stereo full-duplex operation for simultaneous record and playback. The ESFM synthesizer has extended capabilities within native mode operation providing superior sound and power-down capabilities.

The integrated 3-D audio effects processor uses technology from *Spatializer*<sup>®</sup> Audio Laboratories, Inc. and expands the sound field emitted by two speakers to create a resonant 3-D sound environment.

The Solo-1 is compliant with Advanced Configuration and Power Interface (ACPI) standards.

It is available in an industry-standard 100-pin Thin Quad Flat Pack (TQFP) package.

## FEATURES

- Single, high-performance, mixed-signal, 16-bit stereo VLSI chip
- PCI bus specification, revision 2.1
- Full native DOS games compatibility, via three technologies:
  - TDMA
  - DDMA
  - PC/PCI
- High-Quality ESFM music synthesizer
- Dynamic range (SNR) over 80 dB
- Integrated Spatializer® 3-D audio effects processor

#### Record and Playback Features

- Record, compress, and play back voice, sound, and music
- 16-Bit stereo ADC and DAC
- Programmable independent sample rates from 4 kHz up to 48 kHz for record and playback
- Full-Duplex operation for simultaneous record and playback
- · 2-Wire hardware volume control for up, down, and mute

#### Inputs and Outputs

- Stereo inputs for line-in, auxiliary A (CD audio), and auxiliary B, and a mono input for microphone
- MPU-401 (UART mode) interface for wavetable synthesizers and MIDI devices
- Integrated dual game port
- Separate mono input (MONO\_IN) and mono output (MONO\_OUT) for speakerphone

#### Mixer Features

- 8-Channel mixer with stereo inputs for line, CD audio, auxiliary line, music synthesizer, digital audio (wave files), and mono inputs for microphone and speakerphone
- Programmable 6-bit logarithmic master volume control

#### Power

- · Advanced power management meets ACPI standards
- Supports 5.0 V operation

#### Compatibility

- Supports PC games and applications for Sound Blaster™ and Sound Blaster™ Pro
- Supports Microsoft<sup>®</sup> Windows<sup>™</sup> Sound System<sup>®</sup>
- Meets PC 97/PC 98 and WHQL specifications



PCI Bus 78L05 Regulato -WV Ţ +5 V VDDA VDDD ۰ Ŀ GND GNDA GNDD ₹ Ŷ Ŷ PRSTB AUXA\_L CD In Left PCLK AUXA\_R CD In Right GNTB AUXB\_L ⟨ AuxB In Left IDSEL AUXB\_R AuxB In Right FRAMEB LINE\_L CLine In Left TRDYB LINE\_R ✓ Line In Right STOPB MONO\_IN (Mono In PAR < Mic In MIC LOCKB REQB DEVSELB AOUT\_L AOUT\_R IRDYB To Stereo Amplifier 32 AD[31:0] MONO\_OUT PCSPKO 4 CEB[3:0]B -W CLKRUNB г н IRQ5/INTAB T FOUT\_L ╢┝┥ Ļ ш CIN\_L ī. ⋚ FOUT\_R IRQ5 1 IRQ7 CIN\_R 1 IRQ7 IRQ9 1 IRQ9 SIRQ 1 IRQ10/SIRQ DB15S PCPCIGNTB MSI W . PCPCIREQB Ŵ MSO 1 Т ₹ ₹ ₹  $\leq$ Т Sideband Connector 1 SWA 1 SWB Motherboard Implementation SWC SWD VOLUP Τ DOWN Hardware Volume VOLDN ΤA -WW-From Timer Chip ΤВ PCSPKI -WWтс -WW-14.31818 MHz TD XI -₩ŀ Ī Ī Ţ Ē хо Ī ₹ |  $\leq$  $\leq$ ≶ CMR CAP3D

Solo-1

Figure 1 Typical Application

CONTENTS



## CONTENTS

| DESCRIPTION                                      | . 1 |
|--------------------------------------------------|-----|
| FEATURES                                         | . 1 |
| PINOUT                                           | . 5 |
| PIN DESCRIPTION                                  | . 6 |
| FUNCTIONAL DESCRIPTION                           |     |
| Digital Subsystems                               |     |
| Analog Subsystems                                |     |
| MIXER SCHEMATIC BLOCK DIAGRAM                    |     |
| BUS INTERFACING                                  |     |
| DIGITAL AUDIO                                    |     |
| Data Formats                                     |     |
| Audio 1 DMA Transfers in SB Compatibility Mode . |     |
| Audio 1 DMA Transfers in Extended Mode           |     |
| Audio 1 DMA Transfers in Latended Mode           |     |
| Data Transfers Using the Second Audio Channel .  |     |
| First DMA Channel CODEC                          |     |
| INTERRUPTS                                       |     |
|                                                  |     |
| Interrupt Status Register                        |     |
| Interrupt Mask Register                          |     |
| PERIPHERAL INTERFACING                           |     |
| Wavetable Interface                              |     |
| Joystick / MPU-401 Interface                     |     |
| MPU-401 UART Mode                                |     |
| Joystick / MIDI External Interface               |     |
| MONO_IN and MONO_OUT                             |     |
| Spatializer Audio Processor                      |     |
| Hardware and Master Volume Control               |     |
| PC Speaker                                       |     |
| PC Speaker Volume Control                        | 18  |
| ANALOG DESIGN CONSIDERATIONS                     |     |
| Game Port                                        | 19  |
| Reference Generator                              | 19  |
| Switched-Capacitor Filter                        | 19  |
| Audio Inputs and Outputs                         | 19  |
| PCI CONFIGURATION REGISTERS                      | 20  |
| Register Summary                                 | 20  |
| Register Descriptions                            |     |
| I/O PORTS                                        | 27  |
| Port Summary                                     | 27  |
| Port Descriptions                                |     |
| IO Device                                        |     |
| Audio/FM Device                                  |     |
| MPU-401 Device                                   |     |
| Game Port Device                                 | -   |
|                                                  | -   |
| PROGRAMMING THE SOLO-1                           | -   |
| Identifying the Solo-1                           |     |
| Resetting and Initializing the Solo-1            | 33  |
| Programming for DOS Game Compatibility           |     |
| Selecting DMA/IRQ Policy                         |     |
| Programming for Native PCI Audio                 |     |
| Configuring Audio 1 in Native Mode               | 35  |
|                                                  | 30  |

| Configuring Audio 2 in Native Mode                                             |
|--------------------------------------------------------------------------------|
| Modes of Operation                                                             |
| Compatibility Mode Description                                                 |
| Extended Mode Description                                                      |
| Mixing Modes Not Recommended                                                   |
| Data Formats                                                                   |
| Compressed Data Formats                                                        |
| Sound Blaster Pro Compatible Data Formats 36                                   |
| Stereo DMA Transfers in Compatibility Mode 36                                  |
| Solo-1 Data Formats (Extended Mode and Audio 2) 37                             |
| Sending Commands During DMA Operations 37                                      |
| Compatibility Mode Programming                                                 |
| Compatibility Mode DAC Operation                                               |
| Compatibility Mode ADC Operation                                               |
| Extended Mode Programming                                                      |
| Commanding Solo-1 Controller Registers                                         |
| Solo-1 Command/Data Handshaking Protocol 39                                    |
| Extended Mode Audio 1 DAC Operation40                                          |
| Extended Mode Audio 1 ADC Operation41                                          |
| Extended Mode Programmed I/O Operation 43                                      |
| Second Audio Channel DAC Operation                                             |
| Programming the Solo-1 Mixer                                                   |
| Writing and Reading Data from the Mixer Registers 45                           |
| Resetting the Mixer Registers45                                                |
| Extended Access to SB Pro Mixer Volume Controls 46                             |
| Extended Access to Mic Mix Volume                                              |
| Extended Access to ADC Source Select                                           |
| Sound Blaster Pro Volume Emulation                                             |
| Record and Playback Mixer                                                      |
| REGISTERS                                                                      |
| Register Types                                                                 |
| Types of Register Access                                                       |
| Mixer Registers                                                                |
| Controller Registers                                                           |
| Controller Register Descriptions                                               |
| AUDIO MICROCONTROLLER COMMAND SUMMARY 63                                       |
| POWER MANAGEMENT                                                               |
| CLKRUN Protocol                                                                |
| PCI Power Management Interface (PPMI)65<br>ELECTRICAL CHARACTERISTICS66        |
|                                                                                |
| Absolute Maximum Ratings                                                       |
|                                                                                |
| Operating Conditions                                                           |
| TIMING DIAGRAMS                                                                |
| TIMING DIAGRAMS                                                                |
| MECHANICAL DIMENSIONS                                                          |
| APPENDIX A: ES689/ES69X DIGITAL SERIAL INTERFACE 71                            |
| APPENDIX A: ES009/ES09X DIGITAL SERIAL INTERFACE / T<br>APPENDIX B: SCHEMATICS |
| APPENDIX B. SCHEMATICS                                                         |
| APPENDIX D: LAYOUT GUIDELINES                                                  |
| THE LIVEN D. LIVE OUT OUDELINED                                                |



## FIGURES

| Figure 1 Typical Application2                   |
|-------------------------------------------------|
| Figure 2 Solo-1 Pinout                          |
| Figure 3 Solo-1 Block Diagram                   |
| Figure 4 Solo-1 Mixer Schematic Block Diagram10 |
| Figure 5 Data Transfer Modes                    |
| Figure 6 Dual Joystick/MIDI Connector           |
| Figure 7 MIDI Serial Interface                  |
| Figure 8 PC Speaker Volume Circuitry            |
| Figure 9 Reference Generator Pin Diagram        |
| Figure 10 Switched-Capacitor Filter Pin Diagram |
| Figure 11 Command Transfer Timing               |

| Figure 12 | PCLK Timing                                     |
|-----------|-------------------------------------------------|
| Figure 13 | PRST Timing                                     |
| Figure 14 | PCI Signal Timing                               |
| Figure 15 | Solo-1 Mechanical Dimensions 70                 |
| Figure 16 | Solo-1 Schematic                                |
| Figure 17 | ES692 Schematic                                 |
| Figure 18 | Amplifier                                       |
| Figure 19 | PC Interface                                    |
| Figure 20 | Analog Components on One Side of the PCB 78     |
| Figure 21 | Analog Components on Both Sides of the PCB . 78 |
|           |                                                 |

## TABLES

| Table 1 PCI Bus Interface Pins         11                      |
|----------------------------------------------------------------|
| Table 2 Extended Mode Audio 1 Controller Registers        13   |
| Table 3 Audio 2 Related Mixer Registers    14                  |
| Table 4 Solo-1 Interrupt Sources    15                         |
| Table 5 Interrupt Status Bits in IOBase+7h         15          |
| Table 6 Wavetable Interface Pins    16                         |
| Table 7 PCI Configuration Registers Summary                    |
| Table 8 Supported Legacy Audio Addresses                       |
| Table 9 I/O Port Summary    27                                 |
| Table 10 Hardware and Software Reset Initializations        33 |
| Table 11         ISA DMA Policy Bits for Add-On Cards          |
| Table 12         ISA DMA Policy Bits for Motherboards          |
| Table 13 ISA IRQ Emulation Policy Bits                         |
| Table 14 Comparison of Operation Modes                         |
| Table 15 Uncompressed DAC Transfer Modes                       |
| Table 16 Uncompressed ADC Transfer Modes                       |
|                                                                |

| Table 17 | Command Sequences for DMA Playback 41           |
|----------|-------------------------------------------------|
| Table 18 | Command Sequence for DMA Record 42              |
| Table 19 | Sound Blaster Pro/Extended Access Registers 46  |
| Table 20 | SB Pro Read Volume Emulation 47                 |
| Table 21 | SB Pro Write Volume Emulation 47                |
| Table 22 | Extended Access Mixer Volume Values             |
| Table 23 | Mixer Input Volume Registers 48                 |
| Table 24 | Sound Blaster Compatibility Register Summary 49 |
| Table 25 | ESS Mixer Registers Summary 50                  |
| Table 26 | ESS Controller Registers Summary 58             |
| Table 27 | Command Summary 63                              |
| Table 28 | Digital Characteristics                         |
| Table 29 | Analog Characteristics                          |
|          | Timing Characteristics                          |
| Table 31 | Solo-1 Bill of Materials (BOM) 76               |

PINOUT



### PINOUT



Figure 2 Solo-1 Pinout



## **PIN DESCRIPTION**

| Name      | Number                            | I/O | Description                                                                                                                                                |
|-----------|-----------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VDDD      | 1,17,64,80                        | I   | Digital supply voltage, 5 V.                                                                                                                               |
| AD[31:0]  | 69:76,79,82:88,<br>98:99,2:7,9:16 | I/O | Address and data lines from the PCI bus.                                                                                                                   |
| CBE[3:0]B | 77,89,97,8                        | I/O | PCI command/byte enable.                                                                                                                                   |
| ХО        | 18                                | 0   | Oscillator output. Connect to external 14.318 MHz crystal.                                                                                                 |
| XI        | 19                                | I   | Oscillator/external clock input. Connect to external 14.318 MHz crystal or clock source (must be CMOS levels).                                             |
| VOLDN     | 20                                | I   | Active-low volume decrease button input with internal pull-up.                                                                                             |
| VOLUP     | 21                                | I   | Active-low volume increase button input with internal pull-up.                                                                                             |
| MCLK      | 22                                | Ι   | Input with internal pull-down. Music serial clock from external wavetable music synthesizer (ES689/ES69x).                                                 |
| MSD       | 23                                | I   | Input with internal pull-down. Music serial data from external wavetable music synthesizer (ES689/ES69x).                                                  |
| GNDD      | 24,52,81,100                      | Ι   | Digital ground.                                                                                                                                            |
| MONO_OUT  | 25                                | 0   | Mono output with source select and volume control (including mute). This pin can drive an external 5k AC load.                                             |
| MONO_IN   | 26                                | Ι   | Mono input to mixer and ADC. This pin has an internal pull-up to CMR.                                                                                      |
| T(A-D)    | 30:27                             | I/O | Joystick timer pins. These pins connect to the X-Y positioning variable resistors for the two joysticks.                                                   |
| SW(A-D)   | 34:31                             | Ι   | Active-low joystick switch setting inputs. These SW pins have an internal pull-up resistor.                                                                |
| AUXB_L    | 35                                | I   | Auxiliary B input left. AUXB_L has an internal pull-up resistor to CMR.                                                                                    |
| AUXB_R    | 36                                | Ι   | Auxiliary B input right. AUXB_R has an internal pull-up resistor to CMR.                                                                                   |
| AUXA_L    | 37                                | I   | Auxiliary A input left. AUXA_L has an internal pull-up resistor to CMR. Normally intended for connection to an internal or external CD-ROM analog output.  |
| AUXA_R    | 38                                | I   | Auxiliary A input right. AUXA_R has an internal pull-up resistor to CMR. Normally intended for connection to an internal or external CD-ROM analog output. |
| CMR       | 39                                | 0   | Common mode reference voltage (2.25 V $\pm$ 5%). Bypass this pin to analog ground with 47 $\mu$ F electrolytic in parallel with a .1 $\mu$ F capacitor.    |
| MIC       | 40                                | Ι   | Microphone input. MIC has an internal pull-up resistor to CMR.                                                                                             |
| GNDA      | 41                                | I   | Analog ground.                                                                                                                                             |
| CAP3D     | 42                                | Ι   | Bypass capacitor to analog ground for 3-D effects.                                                                                                         |
| VDDA      | 43                                | Ι   | Analog supply voltage (5 V $\pm$ 5%). Must be greater than or equal to VDDD-0.3 V.                                                                         |
| FOUT_R    | 44                                | 0   | Filter output right. AC-coupled externally to CIN_R to remove DC offsets.                                                                                  |
| FOUT_L    | 45                                | 0   | Filter output left. AC-coupled externally to CIN_L to remove DC offsets.                                                                                   |
| CIN_L     | 46                                | I   | ADC and first channel DAC mixer input. This pin has an internal 50k pull-up resistor to CMR.                                                               |
| CIN_R     | 47                                | I   | ADC and first channel DAC mixer input. This pin has an internal 50k pull-up resistor to CMR.                                                               |
| LINE_L    | 48                                | Ι   | Line input left. LINE_L has an internal pull-up resistor to CMR.                                                                                           |
| LINE_R    | 49                                | I   | Line input right. LINE_R has an internal pull-up resistor to CMR.                                                                                          |
| AOUT_L    | 50                                | 0   | Line-level stereo output left. This pin can drive a 5k ohm AC load.                                                                                        |
| AOUT_R    | 51                                | 0   | Line-level stereo output right. This pin can drive a 5k ohm AC load.                                                                                       |



PIN DESCRIPTION

| Name      | Number | I/O | Description                                                                                                                                         |
|-----------|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| PCSPKO    | 53     | 0   | Analog output of PCSPKI with volume control.                                                                                                        |
| PCSPKI    | 54     | I   | Normally low digital PC speaker signal input. This signal is converted to an analog signal with volume control and appears on analog output PCSPKO. |
| MSO       | 55     | 0   | MIDI serial data output.                                                                                                                            |
| MSI       | 56     | I   | MIDI serial input. Schmitt trigger input with internal pull-up resistor. Either MPU-401 or Sound Blaster formats.                                   |
| IRQ10     | 57     | 0   | Active-high ISA interrupt request.                                                                                                                  |
| SIRQ      |        | I/O | Serialized IRQ.                                                                                                                                     |
| IRQ[7,9]  | 59,58  | 0   | Active-high ISA interrupt requests.                                                                                                                 |
| IRQ5      | 60     | 0   | Active-high ISA interrupt request.                                                                                                                  |
| INTAB     |        | 0   | PCI interrupt request.                                                                                                                              |
| PCPCIREQB | 61     | 0   | PC/PCI serialized DREQ output. (Motherboard implementation.)                                                                                        |
| PCPCIGNTB | 62     | I   | PC/PCI serialized DACK input. (Motherboard implementation.)                                                                                         |
| CLKRUNB   | 63     | I/O | PCI clock state for power management.                                                                                                               |
| PRSTB     | 65     | I   | PCI reset.                                                                                                                                          |
| PCLK      | 66     | I   | PCI clock. This clock times all PCI transactions.                                                                                                   |
| GNTB      | 67     | I   | PCI busmaster grant.                                                                                                                                |
| REQB      | 68     | 0   | PCI busmaster request, tristate output.                                                                                                             |
| IDSEL     | 78     | I   | PCI device select for configuration.                                                                                                                |
| FRAMEB    | 90     | I/O | PCI cycle frame.                                                                                                                                    |
| IRDYB     | 91     | I/O | PCI initiator ready.                                                                                                                                |
| TRDYB     | 92     | I/O | PCI target ready.                                                                                                                                   |
| DEVSELB   | 93     | I/O | PCI device select.                                                                                                                                  |
| STOPB     | 94     | I/O | PCI stop transaction.                                                                                                                               |
| LOCKB     | 95     | I/O | PCI lock.                                                                                                                                           |
| PAR       | 96     | I/O | PCI parity.                                                                                                                                         |



## FUNCTIONAL DESCRIPTION

This section shows the overall structure of the Solo-1 and discusses its major functional subunits.

The major subunits of the Solo-1 are shown in Figure 3 and described briefly in the following paragraphs.



Figure 3 Solo-1 Block Diagram

FUNCTIONAL DESCRIPTION



### **Digital Subsystems**

- RISC microcontroller game-compatible audio functions are performed by an embedded microcontroller.
- Oscillator circuitry to support an external crystal.
- **ROM and RAM** firmware ROM and data RAM to the embedded microcontroller.
- **FIFO** RAM for a 256-byte FIFO data buffer for use with the first audio channel and RAM for a 64-byte FIFO data buffer for use with the second audio channel.
- PCI bus interface provides interface to PCI bus signals. The PCI 2.1 compliant interface supports bus master/slave.
- **Dual game port** integrated dual game port for two joysticks.
- MPU-401 serial port asynchronous serial port for MIDI devices such as a wavetable synthesizer or a music keyboard input.
- Wavetable serial port serial port connection from the output of an ES689 or ES69x that eliminates the requirements for an external DAC.
- **ESFM music synthesizer** high-quality, OPL3 superset FM synthesizer with 20 voices.
- Hardware volume control 2 pushbutton inputs with internal pull-up devices for up/down/mute that can be used to adjust the master volume control.

The mute input is defined as the state when both up and down inputs are low simultaneously.

### Analog Subsystems

- Record and Playback Mixers seven input stereo mixers. Each input has independent left and right 4-bit volume control:
  - Line In
  - Mic In
  - Aux A (CD-audio)
  - Aux B
  - Digitized audio (wave files)
  - FM/ES689/ES69x
  - MONO\_IN/MONO\_OUT
- **16-Bit stereo CODEC** for audio record and playback of the first audio channel.
- 16-Bit stereo system DAC for audio playback of the second audio channel.
- **16-Bit stereo music DAC** for ESFM or external wavetable synthesizer.
- 1-Bit DAC for PC speaker digital input.
- 3-D Processor 3-D audio effects processor.
- Record source and input volume control input source and volume control for recording. The recording source can be selected from one of four choices:
  - Line In
  - Mic In
  - Aux A (CD-audio)
  - Mixer (playback or record)
- **Mixer source** determines which mixer is used for the record source, either the playback or record mixer.
- **Output volume and mute control** The master volume is controlled either by programmed I/O or by volume control switch inputs. The master volume supports 6 bits per channel.
- Reference generator analog reference voltage generator.
- PC speaker volume control The PC speaker is supported with a 1-bit DAC with volume control. The analog output pin PCSPKO is intended to be externally mixed at the external amplifier.
- Filter switched capacitor low-pass filter.
- Pre-amp 26 dB microphone pre-amplifier.

MIXER SCHEMATIC BLOCK DIAGRAM

## MIXER SCHEMATIC BLOCK DIAGRAM



Figure 4 Solo-1 Mixer Schematic Block Diagram

BUS INTERFACING

## **BUS INTERFACING**

The Solo-1 is compliant with PCI parallel bus interface, version 2.1. This section discusses interfacing to the PC bus, and items relating to configuration for the bus.

Table 1 shows the pins used to interface the Solo-1 to the PCI bus.

| Table 1 PCI Bus Interface Pins |                                                             |  |  |
|--------------------------------|-------------------------------------------------------------|--|--|
| Pins                           | Descriptions                                                |  |  |
| AD[31:0]                       | Address and data lines from the PCI bus.                    |  |  |
| CBE[3:0]B                      | PCI command/byte enable.                                    |  |  |
| CLKRUNB                        | PCI clock state for power management. (optional).           |  |  |
| DEVSELB                        | PCI device select.                                          |  |  |
| FRAMEB                         | PCI cycle frame.                                            |  |  |
| GNTB                           | PCI busmaster grant.                                        |  |  |
| IDSEL                          | PCI device select for configuration.                        |  |  |
| INTAB                          | PCI interrupt request.                                      |  |  |
| IRDYB                          | PCI initiator ready.                                        |  |  |
| LOCKB                          | PCI lock.                                                   |  |  |
| PAR                            | PCI parity.                                                 |  |  |
| PCLK                           | PCI clock. This clock times all PCI transactions.           |  |  |
| PCPCIGNTB                      | PC/PCI serialized DACK input. (Motherboard implementation). |  |  |
| PCPCIREQB                      | PC/PCI serialized DREQ output (Motherboard implementation). |  |  |
| PRSTB                          | PCI reset.                                                  |  |  |
| REQB                           | PCI busmaster request, tristate output.                     |  |  |
| STOPB                          | PCI stop transaction.                                       |  |  |
| TRDYB                          | PCI target ready.                                           |  |  |





## **DIGITAL AUDIO**

The Solo-1 incorporates two digital audio channels.

Audio 1 The first audio channel. This channel is used for Sound Blaster Pro compatible DMA, Extended mode DMA, and programmed I/O. It can be used for either record or playback.

In DOS mode, this channel uses TDMA, DDMA, or PCPCI to emulate ISA DMA on the PCI bus. Since most DOS games default to DMA channel 1, the first audio channel should ideally be assigned to ISA channel 1. However, it is possible to map audio 1 to one of three DMA channels (0,1,3) through the PCI configuration registers.

In Windows mode, this channel can use PCI Bus Master DMA.

Audio 2 The second audio channel. This channel is used for audio playback in full-duplex mode. Audio 2 uses PCI Bus Mastering with burst transfers to minimize PCI bus access.





### **Data Formats**

See "Data Formats" on page 36.

#### Audio 1 DMA Transfers in SB Compatibility Mode

The first audio channel is programmed using standard Sound Blaster compatible commands. These commands are written to the chip through port SBBase+Ch.

When programming the first audio channel for transfers, one of the following modes can be used:

- Direct mode
- DMA modes
  - Normal
  - Auto-Initialize

In addition, both DMA Normal mode and DMA Auto-Initialize mode can use a special High-Speed mode.

#### **Direct Mode**

In Direct mode, timing for DMA transfers is handled by the application program. For example, the system timer can be reprogrammed to generate interrupts at the desired sample rate. At each system timer interrupt, the command 10h, 11h, 20h, or 21h is issued followed by the sample. Polling of the Write-Buffer-Available flag (SBBase+Ch [bit 7]) is required before writing the command and between writing the command and the data.

**NOTE:** The switched capacitor filter is initialized by reset for an intended sample rate of 8 kHz. In Direct mode, the application may wish to adjust this filter appropriate to the actual sample rate. Do this by programming the timer with command 40h just as if the application were using DMA mode.

#### DMA Modes

In DMA mode, the programmable timer in the Solo-1 controls the rate at which samples are sent to the CODEC. The timer is programmed using command 40h, which also sets up the programmable filters inside the Solo-1. The Solo-1 firmware maintains an internal FIFO (32 levels for 16-bit transfers, 64 levels for 8-bit transfers) that is filled by DMA transfers and emptied by timed transfers to the DAC.

Before a DMA transfer, the application first programs the DMA controller for the desired transfer size and address, then programs the Solo-1 with the same size information. At the end of the transfer, the Solo-1 generates an interrupt request, indicating that the current block transfer is complete. The FIFO gives the application program sufficient time to respond to the interrupt and initiate the next block transfer.

The Solo-1 supports both Normal DMA mode and Auto-Initialize DMA mode.

#### Normal DMA Mode

In Normal mode DMA transfers, the DMA controller must be initialized and the Solo-1 commanded for every block that is transferred.

#### Auto-Initialize DMA Mode

In Auto-Initialize mode, the DMA transfer is continuous, in a circular buffer, and the Solo-1 generates an interrupt for the transition between buffer halves. In this mode the DMA controller and Solo-1 only need to be set up once.

#### SOLO-1 DATA SHEET



#### DIGITAL AUDIO

#### High-Speed Mode

The Solo-1 supports mono 8-bit DMA transfers at a rate up to 44 kHz. Mono 16-bit transfers are supported up to a rate of 22 kHz.

The special "High-Speed mode" allows 8-bit sampling up to 44 kHz for ADC, using commands 98h (auto-initialize) and 99h (normal). No automatic gain control (AGC) is performed. The input volume is controlled with command DDh.

#### Audio 1 DMA Transfers in Extended Mode

The first audio channel is programmed using the controller registers internal to the Solo-1. The commands written to the controller registers are written to the chip through port SBBase+Ch.

When programming the first audio channel for transfers, one of the following modes can be used:

- Programmed I/O
- DMA modes
  - Normal (Single or Demand transfer)
  - Auto-Initialize (Single or Demand transfer)

In addition, both DMA normal mode and DMA autoinitialize mode use Single transfer or Demand transfer modes.

#### Programmed I/O

For some applications, DMA mode is not suitable or available for data transfer, and it is not possible to take exclusive control of the system for DAC and ADC transfers. In these situations, use I/O block transfers within an interrupt handler. The REP OUTSB instruction of the 80x86 family transfers data from memory to an I/O port specified by the DX register. The REP INSB instruction is the complementary function. Use Solo-1 port SBBase+Fh for block transfers.

I/O transfers to FIFO are nearly identical to the DMA process, except that an I/O access to port SBBase+Fh replaces the DMA cycle. For details about programmed I/O operation see "Extended Mode Programmed I/O Operation" on page 43.

#### DMA Modes

Extended mode DMA supports both Normal and Auto-Initialize mode. In addition Normal mode and Auto-Initialize mode both support Single and Demand transfer modes.

#### Single Transfer

One byte is transferred per DMA request.

#### Demand Transfer

To reduce the number of DMA requests necessary to make a transfer, two or four bytes are transferred per DMA request (DRQ). Using Demand transfer enables multiple DMA acknowledges for each DMA request.

For a description of DMA mode including Normal DMA mode and Auto-Initialize DMA mode see "DMA Modes" on page 12.

#### Extended Mode Audio 1 Controller Registers

The following registers control operation of the first audio channel in Extended mode:

Table 2 Extended Mode Audio 1 Controller Registers

| Address | Name                                               |
|---------|----------------------------------------------------|
| A1h     | Audio 1 Sample Rate Generator register             |
| A2h     | Audio 1 Filter Clock Divider register              |
| A4h     | Audio 1 Transfer Count Reload register – low byte  |
| A5h     | Audio 1 Transfer Count Reload register – high byte |
| B1h     | Legacy Audio Interrupt Control register            |
| B2h     | Audio 1 DRQ Control register                       |
| B4h     | Input Volume Control register                      |
| B5h     | Audio 1 DAC Direct Access register – low byte      |
| B6h     | Audio 1 DAC Direct Access register – high byte     |
| B7h     | Audio 1 Control 1 register                         |
| B8h     | Audio 1 Control 2 register                         |
| B9h     | Audio 1 Transfer Type register                     |

#### Audio 1 DMA Transfers in Native PCI Mode

Unlike DOS game environments, the Solo-1 can be completely controlled by drivers. This way the Solo-1 can perform Bus Master DMA for first channel audio data transfers under Windows (or other operating systems).

#### Data Transfers Using the Second Audio Channel

The second audio channel is programmed using mixer registers 70h through 7Ch. The commands written to the mixer registers are written to the chip through ports SBBase+4h and SBBase+5h.

The second audio channel always uses PCI Bus Master transfers instead of ISA-like DMA. IOBase+0h – IOBase+6h control Audio 2 Bus Master DMA. Both normal and auto-initialize modes are available, as in ISA-DMA. DMA counts for Audio 2 must be in multiples of 16 bytes, so that the Solo-1 can performs 4 DWord burst transfers.



#### Audio 2 Related Mixer Registers

The following registers control DMA operations for the second audio channel:

Table 3 Audio 2 Related Mixer Registers

| Address | lame                                               |  |  |
|---------|----------------------------------------------------|--|--|
| 70h     | Audio 2 Sample Rate register                       |  |  |
| 71h     | Audio 2 Mode register                              |  |  |
| 72h     | Audio 2 Filter Clock Rate register                 |  |  |
| 74h     | Audio 2 Transfer Count Reload register - low byte  |  |  |
| 76h     | Audio 2 Transfer Count Reload register – high byte |  |  |
| 78h     | Audio 2 Control 1 register                         |  |  |
| 7Ah     | Audio 2 Control 2 register                         |  |  |
| 7Ch     | Audio 2 DAC Volume Control register                |  |  |

#### First DMA Channel CODEC

The CODEC of the first audio channel cannot perform stereo DAC and ADC simultaneously. It can either be a stereo DAC or a stereo ADC. After reset, the CODEC is set up for DAC operations. Any ADC command causes a switch to the ADC "direction," and any subsequent DAC command switches the converter back to the DAC "direction."

The DAC output is filtered and sent to the mixer. After reset, input to the mixer from the first audio channel DAC is muted to prevent pops. The Solo-1 maintains a status flag to determine if the input to the mixer from the first audio channel DAC is enabled or disabled. Command D8h returns the status of the flag (0h=disabled and FFh=enabled). Use command D1h to enable input to the mixer from the first audio channel DAC and command D3h to disable the input.

To play a new sound without resetting beforehand, when the status of the analog circuits is not clear, mute the input to the mixer with command D3h, then set up DAC direction and level using the direct-to-DAC command:

10h, 80h

Wait 25 milliseconds for the analog circuitry to settle before enabling the voice channel with command D1h.

Pop sounds may still occur if the DAC level was left at a value other than mid-level (code 80h on an 8-bit scale) by the previous play operation. To prevent this, always finish a DAC transfer with a command to set the DAC level to mid-range:

10h, 80h

INTERRUPTS



## **INTERRUPTS**

There are four interrupt sources in the Solo-1, shown in Table 4.

Table 4 Solo-1 Interrupt Sources

| Interrupt Source | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Audio 1          | An interrupt used for the first DMA channel (Sound Blaster compatible DMA, Extended mode DMA, and Extended mode programmed I/O), as well as Sound Blaster-compatible MIDI receive. Controller register B1h controls use of this interrupt for Extended mode DMA and programmed I/O. This interrupt request is cleared by hardware or software reset, or an I/O read from port SBBase+0Eh. The interrupt request can be polled by reading from port SBBase+0Ch. |
| Audio 2          | An optional interrupt for the second DMA channel. The Solo-1 can operate in full-duplex mode using two DMA channels. However, since the second DMA channel must share the same sample rate as the first DMA channel, it is not necessary to use a separate interrupt for the second DMA channel. The Audio 2 interrupt is masked by bit 6 of mixer register 7Ah. It can be polled and cleared by reading or writing bit 7 of register 7Ah.                     |
| Hardware Volume  | Hardware volume activity interrupt. This interrupt occurs when one of the three hardware volume controls changes state. Bit 1 of mixer register 64h is the mask bit for this interrupt. The interrupt request can be polled by reading bit 3 of register 64h. The interrupt request is cleared by writing any value to register 66h. Typically this interrupt, if used, is shared with an audio interrupt.                                                     |
| MPU-401          | The MPU-401 interrupt occurs when a MIDI byte is received. It goes low when a byte is read from the MIDI FIFO and goes high again quickly if there are additional bytes in the FIFO. The interrupt status is the same as the Read-Data-Available status flag in the MPU-401 status register. The MPU-401 interrupt is masked by bit 6 of mixer register 64h.                                                                                                   |

#### **Interrupt Status Register**

Port IOBase+7h of the configuration device can be read to quickly find out which Solo-1 interrupt sources are active. The bits are:

|     | -                                                                         |
|-----|---------------------------------------------------------------------------|
| Bit | Description                                                               |
| 4   | Audio 1 interrupt request                                                 |
| 5   | Audio 2 interrupt request AND'ed with bit 6 of mixer register 7Ah         |
| 6   | Hardware volume interrupt request AND'ed with bit 1 of mixer register 64h |
| 7   | MPU-401 receive interrupt request AND'ed with bit 6 of mixer register 64h |

Table 5 Interrupt Status Bits in IOBase+7h

#### Interrupt Mask Register

Port IOBase+7h can be used to mask any of the four interrupt sources, with the exception of the Audio 1 interrupt. The Audio 1 interrupt request can be enabled by bit 4 of IOBase+7h, or when bit 15 of PCI Configuration register 40h (Legacy Audio Control register) is 0.

The mask bits can be used to force the interrupt source to be zero, without putting the interrupt pin in a highimpedance state. Each bit is AND'ed with the corresponding interrupt source. This register is set to all zeros by hardware reset. The Interrupt Status register (ISR) is not affected by the state of the Interrupt Mask register (IMR). That is, the ISR reflects the status of the interrupt request lines before being masked by the IMR.

The IMR is useful because the Solo-1 shares interrupts. For example, assume that Audio 1, Audio 2, Hardware Volume, and MPU-401 all share the same interrupt in Windows. When returning from Windows to DOS, the Hardware Volume, MPU-401, and Audio 2 interrupts can be masked by setting the appropriate bits to 0.

A second use is within an interrupt handler. The first thing the interrupt handler can do is mask all the interrupt sources mapped to the interrupt handler. Then, the ISR can be polled to decide which sources to process. Just before exiting the interrupt handler, the IMR can be restored. If an unprocessed interrupt remains active, it generates an interrupt request because the interrupt pin was deasserted during the masked period and then was asserted when the interrupt sources were unmasked. Also, while the interrupts are masked, the individual interrupt sources can change state any number of times without generating a false interrupt request.



## PERIPHERAL INTERFACING

#### Wavetable Interface

The Solo-1 contains a synchronous serial interface for connection to an ES689/ES69x wavetable music synthesizer. Table 6 identifies pins in the wavetable interface.

Table 6Wavetable Interface Pins

| Pin  | Description                                                                                                                                                                                                                                                  |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MCLK | Serial clock from external ES689/ES69x music syn-<br>thesizer (2.75 MHz).                                                                                                                                                                                    |
| MSD  | Serial data from external ES689/ES69x music syn-<br>thesizer. When both MCLK and MSD are active, the<br>stereo DACs that are normally used by the FM syn-<br>thesizer are acquired for use by the external ES689/<br>ES69x. The normal FM output is blocked. |

#### Joystick / MPU-401 Interface

#### MPU-401 UART Mode

There is one MIDI interface in the Solo-1, an MPU-401 "UART mode" compatible serial port. MPU-401 is a superior method of MIDI serial I/O because it does not interfere with DAC or ADC Sound Blaster commands.

MPU-401 requires an interrupt channel for MIDI receive. This interrupt should be selected using mixer register 64h. It should be different than the interrupt selected for audio DMA interrupts.

#### **Joystick / MIDI External Interface**

The joystick portion of the Solo-1 reference design is identical to that on a standard PC game control adaptor or game port. The PC compatible joystick can be connected to a 15-pin D-sub connector. It supports all standard PC joystick-compatible software. If the system already has a game card or port, remove the game card.

If multiple joysticks are required, use a joystick conversion cable. This cable uses a 15-pin D-sub male connector on one end, and two 15-pin D-sub female connectors on the other end. All signals on this cable have direct pin-to-pin connection, except for pins 12 and 15. On the male connector, pins 12 and 15 should be left without connected to pin 8, and pin 12 is internally connected to pin 4. The dual joystick and MIDI port take up only one slot in the system, leaving room for other cards. Figure 6 shows the dual joystick/MIDI connector configuration.



Figure 7 shows the MIDI serial interface adaptor from the joystick/MIDI connector.

#### PERIPHERAL INTERFACING



MONO\_IN and MONO\_OUT

MONO\_IN is a line-level analog input. It has an input pullup resistor to CMR with a value of approximately 40 kohms. MONO\_IN is an input to the playback mixer and the record mixer. The mixer volumes are controlled by mixer registers 6Dh (playback) and 6Fh (record).

Alternately, MONO\_IN can be mixed with AOUT\_L and AOUT\_R after the mixer, Spatializer, and master volume stages. Bit 0 of mixer register 7Dh, when high, enables MONO\_IN to be mixed directly (unity gain) with AOUT\_L and AOUT\_R.

MONO\_OUT is a line-level mono output that can drive an external 5 kohm load. During power-down or during opamp calibration, MONO\_OUT is held at CMR (as are AOUT\_L and AOUT\_R) by an internal, high-impedance resistor divider. MONO\_OUT can be selected from among four sources by bits 2 and 1 of mixer register 7Dh.

| Mixer Reg | gister 7Dh | MONO_OUT Source                                     |
|-----------|------------|-----------------------------------------------------|
| Bit 2     | Bit 1      |                                                     |
| 0         | 0          | Mute (CMR)                                          |
| 0         | 1          | First channel filter output<br>(actually CIN_R pin) |
| 1         | 0          | Second channel DAC, right channel                   |
| 1         | 1          | Mono mix of record level stage outputs              |

Normally bits 2:1 are both zero, so that MONO\_OUT is muted.

When bit 2 is 0 and bit 1 is 1, MONO\_OUT is a buffered version of input pin CIN\_R. CIN\_R is typically the right channel DAC output, filtered by the first channel switched-capacitor filter. If the right channel is used for ADC, CIN\_R will be the right channel ADC input. MONO\_OUT can be used in this application as digitized audio playback through the first channel DMA, right channel DAC.

When bit 2 is 1 and bit 1 is 0, MONO\_OUT is a buffered version of the second channel, right channel DAC. In this case, the second channel DMA can play digitized audio through MONO\_OUT.

When bit 2 is 1 and bit 1 is 1, MONO\_OUT is a buffered version of a mono mix of the record level stage left and right outputs. This gives the utmost flexibility in the source or sources of MONO\_OUT. The record source select and record levels can be programmed to generate any combination of sources and volumes for MONO\_OUT.

#### Spatializer Audio Processor

The Solo-1 contains an embedded Spatializer audio processor positioned between the output of the playback mixer and the master volume controls. The Spatializer produces a wider perceived stereo effect and also has a mode that generates a stereo effect given a mono input.

The amount of effect is controlled by directly programming Spatializer Level register 52h.



#### Hardware and Master Volume Control

Two external pins, VOLUP and VOLDN, can be connected to external momentary switches to ground to implement hardware master volume controls. Pressing one of these buttons produces a low signal to one of the inputs and thereby changes the master volume.

MUTE is emulated by the state where both VOLUP and VOLDN inputs are low simultaneously.

The up and down buttons produce a single step change in volume when they are first pressed. If these buttons are held down, they enter a fast-scrolling mode. The single step change can be either one volume unit (.75 dB) or three volume units (2.25 dB). In scrolling mode, the step change is always one volume unit.

The two inputs have debounce circuitry within the Solo-1. Hold each input low for 40 milliseconds or more for it to be recognized as a valid button press. Hold each input high for 40 milliseconds or more between button presses. A software option allows the debounce time to be reduced from 40 milliseconds to 10 microseconds.

Normally the hardware volume controls directly change the master volume registers and produce an interrupt at each change. However, the Solo-1 can be programmed so that the hardware volume controls do not directly change the master volume registers. This is called "split mode", in which the hardware volume control counters are split from the master volume registers. Pressing a hardware volume control button changes the hardware volume counters and produces an interrupt. The host software can read the hardware volume counters and update the master volume registers as needed. Split mode is enabled by bit 7 of mixer register 64h.

For support of mixer master volume control, a write to mixer registers 22h or 32h translates automatically into writes to the master volume registers. Since register 22h only has 3-bit resolution per channel, and register 32h only has 4-bit resolution per channel, a translation circuit is included in the Solo-1 that translates 3- or 4-bit volume values into the 6-bit volume + mute that is used in the master volume registers. Support of these mixer registers can be defeated under software control.

Reading master volume registers 22h or 32h also requires a translation circuit to translate 6-bit + mute master volumes into 3- or 4-bit master volume numbers for registers 22h or 32h.

#### PC Speaker

The PC Speaker is supported with a 1-bit DAC with volume control. The analog output pin PCSPKO is intended to be externally mixed at the external amplifier.

#### PC Speaker Volume Control

When the PCSPKI signal is high, a resistive path to analog power is enabled. The value of the resistor is selected from among 7 choices to control the amplitude of the output signal.



Figure 8 PC Speaker Volume Circuitry

With the external circuit shown in Figure 8, the amplitude of a square wave output on pin PCSPKO should be approximately VDDD/2 for maximum volume, i.e., the internal resistor is approximately 500 ohms ( $\pm$  30%). The other levels are relative to this amplitude as follows:

off, -18dB, -15dB, -12dB, -9dB, -6dB, -3dB, +0dB

The purpose of the circuit, beyond volume control of the speaker, is to prevent digital noise from the PC speaker signal being mixed into the analog signal. This circuit provides a clean analog signal. The output can be either mixed with the AOUT\_L and AOUT\_R pins externally or it can be used to drive a simple transistor amplifier to drive an 8 ohm speaker dedicated to producing beeps.



ANALOG DESIGN CONSIDERATIONS

## ANALOG DESIGN CONSIDERATIONS

This section describes design considerations related to inputs and outputs of analog signals and related pins on the chip.

#### Game Port

The game port address GPBase+1h is decoded for timer pins TA, TB, TC, and TD, and switch pins SWA, SWB, SWC, and SWD. The MIDI serial input and output also come from the game port connector in most applications.

#### **Reference Generator**

Reference generator pin CMR is shown bypassed to analog ground.



Figure 9 Reference Generator Pin Diagram

#### Switched-Capacitor Filter

The outputs of the FOUT\_L and FOUT\_R filters must be AC-coupled to the inputs CIN\_L and CIN\_R. This provides for DC blocking and an opportunity for low-pass filtering with capacitors to analog ground at these inputs.



Figure 10 Switched-Capacitor Filter Pin Diagram

#### Audio Inputs and Outputs

Analog inputs MIC, LINE\_L, LINE\_R, AUXA\_L, and AUXA\_R should be capacitively coupled to their respective input signals. All have pull-up resistors to CMR.

Solo-1 analog outputs AOUT\_L and AOUT\_R should be AC-coupled to an amplifier, volume control potentiometer, or line-level outputs.



## **PCI CONFIGURATION REGISTERS**

## **Register Summary**

## Table 7 PCI Configuration Registers Summary

| 31 16 15          |                                                |                                            |                         |     |  |  |  |  |  |
|-------------------|------------------------------------------------|--------------------------------------------|-------------------------|-----|--|--|--|--|--|
| Devi              | ce ID                                          | Vend                                       | or ID                   | 00h |  |  |  |  |  |
| Device            | e status                                       | Comr                                       | mand                    | 04h |  |  |  |  |  |
| Base class code   | Sub-class code                                 | Programming interface                      | Revision ID             | 08h |  |  |  |  |  |
| Reserved          | Header type                                    | Master latency timer                       | Reserved                | 0Ch |  |  |  |  |  |
|                   | I/O space b                                    | ase address                                |                         | 10h |  |  |  |  |  |
|                   | SB I/O space base address for native PCI audio |                                            |                         |     |  |  |  |  |  |
|                   | VC I/O space base addr                         | ess for native PCI audio                   |                         | 18h |  |  |  |  |  |
|                   | MPU-401 I/O space base a                       | ddress for native PCI audio                |                         | 1Ch |  |  |  |  |  |
|                   | Game port I/O space base a                     | address for native PCI audio               |                         | 20h |  |  |  |  |  |
|                   | Rese                                           | erved                                      |                         | 24h |  |  |  |  |  |
|                   | Reserved                                       |                                            |                         |     |  |  |  |  |  |
| Subsystem ID (rea | ad/write-protected)                            | Subsystem vendor ID (read/write-protected) |                         |     |  |  |  |  |  |
|                   | Rese                                           | erved                                      |                         | 30h |  |  |  |  |  |
|                   | Reserved Capability pointer                    |                                            |                         |     |  |  |  |  |  |
|                   | Rese                                           | erved                                      |                         | 38h |  |  |  |  |  |
| Maximum latency   | Minimum grant                                  | Interrupt pin                              | Interrupt line          | 3Ch |  |  |  |  |  |
| Rese              | erved                                          | Legacy au                                  | dio control             | 40h |  |  |  |  |  |
|                   | Rese                                           | erved                                      |                         | 44h |  |  |  |  |  |
|                   | Rese                                           | erved                                      |                         | 48h |  |  |  |  |  |
|                   | Rese                                           | erved                                      |                         | 4Ch |  |  |  |  |  |
|                   | Solo-1 cor                                     | nfiguration                                |                         | 50h |  |  |  |  |  |
|                   | Rese                                           | erved                                      |                         | 54h |  |  |  |  |  |
|                   | Rese                                           | erved                                      |                         | 58h |  |  |  |  |  |
|                   | Rese                                           | erved                                      |                         | 5Ch |  |  |  |  |  |
| Rese              | erved                                          | Distributed [                              | Distributed DMA control |     |  |  |  |  |  |
| Power-Manager     | ment capabilities                              | Next-Item pointer                          | Capability ID           | C0h |  |  |  |  |  |
| Rese              | erved                                          | Power-Management control/status            |                         |     |  |  |  |  |  |

All reserved locations are read-only with a default value of zero.

#### SOLO-1 DATA SHEET

PCI CONFIGURATION REGISTERS

PRELIMINARY

(00h, 01h, R)



#### **Register Descriptions**

#### Vendor ID

|    |    |    |    |    |    |   | Vend | dor II | D |   |   |   |   |   |   |
|----|----|----|----|----|----|---|------|--------|---|---|---|---|---|---|---|
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8    | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

#### **Bit Definitions:**

#### Bits Name Description

15:0 Vendor ID The default value after reset is 125Dh, indicating ESS as the manufacturer of this device.

| Device ID |           | (02h, 03h, R) |
|-----------|-----------|---------------|
|           | Desize ID |               |

|    |    |    |    |    |    |   | Dev | ice II | 2 |   |   |   |   |   |   |
|----|----|----|----|----|----|---|-----|--------|---|---|---|---|---|---|---|
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8   | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

#### **Bit Definitions:**

| Bits Name      | Description                                                                         |
|----------------|-------------------------------------------------------------------------------------|
| 15:0 Device ID | The default value after reset is 1969h, identi-<br>fying the Solo-1 as this device. |
|                |                                                                                     |

| Co | Command |    |    |    |    |   |   |   |   |   | ( | 04h | n, 05ł | n, R | : <b>/W)</b> |
|----|---------|----|----|----|----|---|---|---|---|---|---|-----|--------|------|--------------|
| 0  | 0       | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0   | BME    | 0    | IOS          |
| 15 | 14      | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3   | 2      | 1    | 0            |

The default value after reset is 0000h.

#### **Bit Definitions:**

| <u>Bits</u> Name | Description                    |
|------------------|--------------------------------|
| 15:3 –           | Reserved. Returns 0 when read. |
| 2 BME            | Bus Master enable.             |
| 1 –              | Reserved. Returns 0 when read. |
| 0 IOS            | I/O Space access enable.       |

# Device Status (06h, 07h, R/WC)

| 0  | 0  | MAS | RTA | STA | D  | Г | DPE | FBC | UDF | 66M | ACPI | 0 | 0 | 0 | 0 |
|----|----|-----|-----|-----|----|---|-----|-----|-----|-----|------|---|---|---|---|
| 15 | 14 | 13  | 12  | 11  | 10 | 9 | 8   | 7   | 6   | 5   | 4    | 3 | 2 | 1 | 0 |

The default value after reset is 0290h. Writing 1 clears a bit; writing 0 has no effect on a bit.

## Bit Definitions:

| <u>Bits</u> | <u>Name</u> | Description                                      |
|-------------|-------------|--------------------------------------------------|
| 15:14       | -           | Reserved. Returns 0 when read.                   |
| 13          | MAS         | Master abort status (read/write-clear).          |
| 12          | RTA         | Received target abort status (read/write-clear). |
| 11          | STA         | Signaled target abort (read-only: 0).            |
| 10:9        | DT          | DEVSEL timing (read-only: 01 = medium).          |
| 8           | DPE         | Data parity error detected (read-only: 0).       |
| 7           | FBC         | Fast back-to-back capable (read-only: 1).        |
| 6           | UDF         | UDF supported (read-only: 0).                    |
| 5           | 66M         | 66 MHz capable (read-only: 0).                   |
| 4           | ACPI        | ACPI capable (read-only: 1).                     |
| 3:0         | _           | Reserved. Returns 0 when read.                   |

#### .0 – Reserved. Returns 0 when read.

| Revision ID (08h, R) |   |   |      |         |   |   |   |  |  |
|----------------------|---|---|------|---------|---|---|---|--|--|
|                      |   |   | Revi | sion ID |   |   |   |  |  |
| 7                    | 6 | 5 | 4    | 3       | 2 | 1 | 0 |  |  |

#### **Bit Definitions:**

| <u>Bits</u> | Name | <u>)</u> | Des | script | <u>tion</u> |  |
|-------------|------|----------|-----|--------|-------------|--|
|             |      |          |     |        |             |  |

7:0 Revision ID Identifies the revision of this device. The default value after reset is 00h.

# Programming Interface (09h, R)

| Programming interface |   |   |   |   |   |   |   |  |
|-----------------------|---|---|---|---|---|---|---|--|
| 7                     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |

#### **Bit Definitions:**

Bits Name Description

7:0 PI Identifies the programming interface of this device. The default value after reset is 00h.

#### Sub-Class Code

| (0Ah, | R) |
|-------|----|
|-------|----|

|   |   |   | Sub-Cl | ass code | ) |   |   |
|---|---|---|--------|----------|---|---|---|
| 7 | 6 | 5 | 4      | 3        | 2 | 1 | 0 |

#### **Bit Definitions:**

Bits Name Description

7:0 SCC The default value after reset (assigned by the PCI-SIG) is 01h, indicating an audio device with a multimedia base class.



#### PRELIMINARY

PCI CONFIGURATION REGISTERS

| Base Class Code   (0Bh, R) |   |   |        |           |   |   |   |     |
|----------------------------|---|---|--------|-----------|---|---|---|-----|
|                            |   |   | Base c | lass code | ; |   |   | ] [ |
| 7                          | 6 | 5 | 4      | 3         | 2 | 1 | 0 |     |

#### **Bit Definitions:**

Bits Name Description

7:0 BCC The default value after reset (assigned by the PCI-SIG) is 04h, indicating a multimedia device.

#### Master Latency Timer

| Maste  | Master Latency Timer (0Dh, R/W) |           |          |   |   |   |   |  |  |
|--------|---------------------------------|-----------|----------|---|---|---|---|--|--|
| Master | r latency t                     | imer coui | nt value | 0 | 0 | 0 | 0 |  |  |
| 7      | 6                               | 5         | 4        | 3 | 2 | 1 | 0 |  |  |

The default value after reset is 00h.

#### **Bit Definitions:**

| Bits Name | Description                       |
|-----------|-----------------------------------|
| 7:4 MLTCV | Master latency timer count value. |
| 3:0 –     | Reserved. Returns 0 when read.    |

## Header Type

|   |   |   | Heade | er type |   |   |   |
|---|---|---|-------|---------|---|---|---|
| 7 | 6 | 5 | 4     | 3       | 2 | 1 | 0 |

#### **Bit Definitions:**

| <u>Bits</u> | <u>Name</u> | <b>Description</b> |      |
|-------------|-------------|--------------------|------|
| 7.0         |             | Hoodor type        | Δ. γ |

7:0 HEDT Header type. A value of 00h indicates a singlefunction PCI device.

| I/O         | Bas | se |    |    |    |    |    |     |    |    | (10 | )h – | 13 | h, R | R/W) |
|-------------|-----|----|----|----|----|----|----|-----|----|----|-----|------|----|------|------|
| 0           | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0   | 0    | 0  | 0    | 0    |
| 31          | 30  | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20  | 19   | 18 | 17   | 16   |
| IOSB 0 0 15 |     |    |    |    |    |    |    | ISI |    |    |     |      |    |      |      |
| 15          | 14  | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6  | 5  | 4   | 3    | 2  | 1    | 0    |

#### The default value after reset is 000xxx1h.

#### **Bit Definitions:**

| <u>Bits</u> <u>Name</u> | Description                                                     |
|-------------------------|-----------------------------------------------------------------|
| 31:16 –                 | Hardwired to 0000h.                                             |
| 15:4 IOSB               | I/O space base address. The Solo-1 claims 16 bytes of IO space. |
| 3:1 –                   | Hardwired to 00h.                                               |
| 0 ISI                   | I/O space indicator. Hardwired to 1.                            |

| SB Base for Native-PCI-Audio (14h – 17h, R/W |    |    |    |    |    |    |    |    | R/W) |    |    |    |    |    |     |
|----------------------------------------------|----|----|----|----|----|----|----|----|------|----|----|----|----|----|-----|
| 0                                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0  | 0  | 0  | 0   |
| 31                                           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22   | 21 | 20 | 19 | 18 | 17 | 16  |
|                                              |    |    |    |    | SB | SB |    |    |      |    |    | 0  | 0  | 0  | ISI |
| 15                                           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6    | 5  | 4  | 3  | 2  | 1  | 0   |

The default value after reset is 000xxx1h.

## **Bit Definitions:**

| <u>Bits</u> <u>Name</u> | Description                                                                                             |
|-------------------------|---------------------------------------------------------------------------------------------------------|
| 31:16 –                 | Hardwired to 000h.                                                                                      |
| 15:4 SBSB               | SB space base address for native PCI audio.<br>The Solo-1 claims 16 bytes of Sound Blaster<br>IO space. |
| 3:1 –                   | Hardwired to 00h.                                                                                       |
| 0 ISI                   | I/O space indicator. Hardwired to 1.                                                                    |

### VC Base for Native-PCI-Audio

(18h – 1Bh, R/W)

| 0  | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   |
|----|------|----|----|----|----|----|----|----|----|----|----|----|----|-----|-----|
| 31 | 30   | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  |
|    | VCSB |    |    |    |    |    |    |    |    |    | Δ  | Δ  | 0  | 101 |     |
|    |      |    |    |    | .0 | UD |    |    |    |    |    | 0  | 0  | 0   | 101 |

The default value after reset is 000xxx1h.

#### **Bit Definitions:**

(0Eh, R)

| <u>Bits</u> <u>Name</u> | Description                                                                                                                                                          |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 –                 | Hardwired to 000h.                                                                                                                                                   |
| 15:4 VCSB               | VC space base address for native PCI audio.<br>The Solo-1 claims 16 bytes of driver IO<br>space. The driver can use allocated IO ports<br>for the DDMA base address. |
| 3:1 –                   | Hardwired to 00h.                                                                                                                                                    |
| 0 ISI                   | I/O space indicator. Hardwired to 1.                                                                                                                                 |

#### **MPU Base for Native-PCI-Audio** (1Ch - 1Fh, R/W)

|       |    |    |    |    |    |    |    |    |    |     | -  |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|-----|----|----|----|----|----|
| 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  | 0  | 0  | 0  | 0  |
| 31    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21  | 20 | 19 | 18 | 17 | 16 |
| MPUSB |    |    |    |    |    |    |    |    | 0  | ISI |    |    |    |    |    |
|       |    |    |    |    |    |    |    |    |    |     |    |    |    |    |    |

The default value after reset is 000xxx1h.

#### **Bit Definitions:**

| <u>Bits</u> | <u>Name</u> | Description                                                                                 |
|-------------|-------------|---------------------------------------------------------------------------------------------|
| 31:16       | -           | Hardwired to 000h.                                                                          |
| 15:2        | MPUSB       | MPU space base address for native PCI audio. The Solo-1 claims 4 bytes of MPU-401 IO space. |
| 1           | -           | Hardwired to 0.                                                                             |
| 0           | ISI         | I/O space indicator. Hardwired to 1.                                                        |

#### SOLO-1 DATA SHEET

PCI CONFIGURATION REGISTERS

| GP Base for Na                      | tive-PCI-Audio                                                          | (20h – 23h, R/W)                   | Interrupt L            |
|-------------------------------------|-------------------------------------------------------------------------|------------------------------------|------------------------|
| 0 0 0 0 0                           |                                                                         | 0 0 0 0 0                          |                        |
| 31 30 29 28 2                       | 7 26 25 24 23 22 21                                                     | 20 19 18 17 16                     | 7 6                    |
|                                     | GPSB                                                                    | 0 ISI                              |                        |
| 15 14 13 12 1                       | 1 10 9 8 7 6 5                                                          | 4 3 2 1 0                          | Bit Definition         |
|                                     |                                                                         |                                    | <u>Bits</u> <u>Nam</u> |
| The default value                   | e after reset is 000xxx                                                 | :1h.                               | 7:0 IL                 |
| Bit Definitions:                    |                                                                         |                                    |                        |
| Bits Name                           | Description                                                             |                                    | Interrupt F            |
| 31:16 –                             | Hardwired to 000h.                                                      |                                    |                        |
| 15:2 GPSB                           | GP space base address                                                   | s for native PCI audio.            | 7 6                    |
|                                     | The Solo-1 claims 4 by                                                  | tes of game port IO                | 7 6                    |
|                                     | space.                                                                  |                                    | Bit Definitio          |
| 1 –                                 | Hardwired to 0.                                                         |                                    | Bits Name              |
| 0 ISI                               | I/O space indicator. Ha                                                 | rdwired to 1.                      | 7:0 IP                 |
| • • • •                             |                                                                         |                                    | -                      |
| Subsystem Ven                       | dor ID                                                                  | (2Ch, 2Dh, R)                      |                        |
|                                     | Subsystem vendor ID                                                     |                                    | Minimum                |
| 15 14 13 12 11                      | 1098765                                                                 | 4 3 2 1 0                          |                        |
| Bit Definitions:                    |                                                                         |                                    | 7 6                    |
|                                     | Description                                                             |                                    | Dit Dafinitia          |
|                                     | <u>Description</u><br>Writable when the Solo- <sup>,</sup>              | 1 Configuration radio              | Bit Definitio          |
|                                     | er (50h–53h) bit 0 is 1.                                                | r Configuration regis-             | <u>Bits</u> Nam        |
|                                     |                                                                         |                                    | 7:0 MG                 |
| Subsystem ID                        |                                                                         | (2Eh, 2Fh, R)                      |                        |
|                                     | Subsystem ID                                                            |                                    | Maximum                |
| 15 14 13 12 11                      | I 10 9 8 7 6 5                                                          | 4 3 2 1 0                          |                        |
|                                     |                                                                         |                                    |                        |
|                                     |                                                                         |                                    | 7 6                    |
| Bit Definitions:                    |                                                                         |                                    | 7 6                    |
| Bits Name                           | Description                                                             |                                    | 7 e                    |
| <u>Bits</u> <u>Name</u><br>15:0 SID | Writable when the Solo-                                                 | 1 Configuration regis-             |                        |
| <u>Bits</u> <u>Name</u><br>15:0 SID |                                                                         | 1 Configuration regis-             | Bit Definitio          |
| <u>Bits</u> <u>Name</u><br>15:0 SID | Writable when the Solo-<br>er (50h–53h) bit 0 is 1.                     |                                    | Bit Definition         |
| <u>Bits</u> <u>Name</u><br>15:0 SID | Writable when the Solo-<br>er (50h–53h) bit 0 is 1.<br>7 <b>Pointer</b> | 1 Configuration regis-<br>(34h, R) | Bit Definition         |
| <u>Bits</u> <u>Name</u><br>15:0 SID | Writable when the Solo-<br>er (50h–53h) bit 0 is 1.                     |                                    | Bit Definition         |

#### **Bit Definitions:**

Bits Name Description

7:0 ACPICP ACPI Cap\_Ptr. The default value is C0h.

## Line



#### ons:

ne Description

Interrupt line. Valid values are 0 - 15, 255. The default value is 255.

#### Pin

|   |               |   |   |   |   | • | , | <i>'</i> |  |
|---|---------------|---|---|---|---|---|---|----------|--|
|   | Interrupt pin |   |   |   |   |   |   |          |  |
|   |               |   |   |   |   |   |   |          |  |
| 7 | 6             | 5 | 4 | 3 | 2 | 1 | 0 |          |  |

#### ions:

- e Description
- Interrupt pin. The default value is 01h, indicating INTA.

#### Grant

| linimum Grant (3Eh, R) |   |   |   |   |   |   |   |  |  |
|------------------------|---|---|---|---|---|---|---|--|--|
| Minimum grant          |   |   |   |   |   |   |   |  |  |
| 7                      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |

#### ions:

- ne Description
- Min\_Gnt. The default value is 02h, corresponding to 500 ns.

| Maximum Latency (3Fh, R) |   |   |   |   |   |   |   |  |  |
|--------------------------|---|---|---|---|---|---|---|--|--|
| Maximum latency          |   |   |   |   |   |   |   |  |  |
| 7                        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |

#### ions:

- ne Description
- Max\_Lat. The default value is 18h, corresponding to 6 ms.



(3Ch, R/W)

(3Dh, R)

PRELIMINARY



#### PCI CONFIGURATION REGISTERS

| Legac       | Legacy Audio Control (40h, 41h, R/W) |                                                                                        |  |  |  |  |  |  |  |
|-------------|--------------------------------------|----------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| LA SI       | R MIDIIRO                            | SBIRQ DMACH IA MQ MI GP FM SB                                                          |  |  |  |  |  |  |  |
| 15 14       | 13 12                                | 11 10 9 8 7 6 5 4 3 2 1 0                                                              |  |  |  |  |  |  |  |
|             |                                      | lue after reset is 907Fh. This is also a<br>in PCI mode.                               |  |  |  |  |  |  |  |
| Bit De      | finitions:                           |                                                                                        |  |  |  |  |  |  |  |
| <u>Bits</u> | <u>Name</u>                          | Description                                                                            |  |  |  |  |  |  |  |
| 15          | LA                                   | Legacy audio address decode disable.                                                   |  |  |  |  |  |  |  |
|             |                                      | <ul><li>1 = Disable legacy audio (default).</li><li>0 = Enable legacy audio.</li></ul> |  |  |  |  |  |  |  |
| 14          | SIR                                  | Serial IRQ enable.                                                                     |  |  |  |  |  |  |  |
|             |                                      | 1 = Enable serial IRQ<br>(point-to-point IRQ is disabled).                             |  |  |  |  |  |  |  |
|             |                                      | 0 = Disable serial IRQ                                                                 |  |  |  |  |  |  |  |
|             |                                      | (point-to-point IRQ is enabled) (default).                                             |  |  |  |  |  |  |  |
| 13:11       | MIDIIRQ                              | MIDI IRQ select.<br>Bit 13 Bit 12 Bit 11 IRQ Selection                                 |  |  |  |  |  |  |  |
|             |                                      | 0 0 0 IRQ5                                                                             |  |  |  |  |  |  |  |
|             |                                      | 0 0 1 IRQ7<br>0 1 0 IRQ9 (default)                                                     |  |  |  |  |  |  |  |
|             |                                      | 0 1 1 IRQ10                                                                            |  |  |  |  |  |  |  |
|             |                                      | 1 x x IRQ[14:11]<br>(serialized IRQ only)                                              |  |  |  |  |  |  |  |
| 10:8        | SBIRQ                                | Sound Blaster IRQ select.                                                              |  |  |  |  |  |  |  |
|             |                                      | Bit 10 Bit 9 Bit 8 IRQ Selection                                                       |  |  |  |  |  |  |  |
|             |                                      | 0 0 0 IRQ5 (default)<br>0 0 1 IRQ7                                                     |  |  |  |  |  |  |  |
|             |                                      | 0 1 0 IRQ9                                                                             |  |  |  |  |  |  |  |
|             |                                      | 0 1 1 IRQ10<br>1 x x IRQ[14:11                                                         |  |  |  |  |  |  |  |
|             |                                      | (serialized IRQ only)                                                                  |  |  |  |  |  |  |  |
| 7:6         | DMACH                                | Sound Blaster DMA channel select.                                                      |  |  |  |  |  |  |  |
|             |                                      | Bit 7 Bit 6 DMA Channel Selection<br>0 0 Channel 0                                     |  |  |  |  |  |  |  |
|             |                                      | 0 1 Channel 1 (default)                                                                |  |  |  |  |  |  |  |
|             |                                      | 1 0 Reserved<br>1 1 Channel 3                                                          |  |  |  |  |  |  |  |
| 5           | IA                                   | I/O address aliasing control.                                                          |  |  |  |  |  |  |  |
| -           |                                      | 1 = 10-Bit I/O address (default).                                                      |  |  |  |  |  |  |  |
|             |                                      | 0 = 16-Bit I/O address.                                                                |  |  |  |  |  |  |  |
| 4           | MQ                                   | MPU-401 IRQ enable/mask.<br>1 = Enable MPU-401 IRQ (default).                          |  |  |  |  |  |  |  |
|             |                                      | 0 = Disable MPU-401 IRQ.                                                               |  |  |  |  |  |  |  |
| 3           | MI                                   | MPU-401 I/O enable.                                                                    |  |  |  |  |  |  |  |
|             |                                      | 1 = Enable MPU-401 I/O (default).<br>0 = Disable MPU-401 I/O.                          |  |  |  |  |  |  |  |
| 2           | GP                                   | Game port enable.                                                                      |  |  |  |  |  |  |  |
|             |                                      | 1 = Enable game port (default).                                                        |  |  |  |  |  |  |  |
| 1           | FM                                   | 0 = Disable game port.<br>FM synthesis enable.                                         |  |  |  |  |  |  |  |
|             |                                      | 1 = Enable FM synthesis (default).                                                     |  |  |  |  |  |  |  |
|             |                                      | 0 = Disable FM synthesis.                                                              |  |  |  |  |  |  |  |
|             |                                      |                                                                                        |  |  |  |  |  |  |  |

| <u>Bits</u> | <u>Name</u> | <u>Description</u> |
|-------------|-------------|--------------------|
| 0           | SB          | Sound Blaster      |

Sound Blaster enable. 1 = Enable Sound Blaster channel (default).

0 = Disable Sound Blaster channel.

#### Legacy Audio Support

The Solo-1 supports the following legacy audio addresses.

| Table o Supported Legacy Audio Audiesses | Table 8 | Supported Legacy Audio Addresses |
|------------------------------------------|---------|----------------------------------|
|------------------------------------------|---------|----------------------------------|

| Legacy Audio Resources | I/O Address Base                    |
|------------------------|-------------------------------------|
| Sound Blaster Pro      | 220h/240h                           |
| FM synthesis           | 388h                                |
| MPU-401                | 300h/320h/330h/340h                 |
| DMA                    | Channel 0, 1, 3                     |
| IRQ                    | 5, 7, 9, 10,11–14 (serial IRQ only) |
| Joystick               | 201h                                |

24

#### **SOLO-1 DATA SHEET**

PCI CONFIGURATION REGISTERS

(50h - 53h, R/W) R CPE Reserved ISAIRQ 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 IRQP R DMAP R 0 0 MPUBA SBBA R S(V)ID 14 13 12 11 10 9 7 6 5 3 2 8 4 1 0 The default value after reset is 0000000h. **Bit Definitions:** Bits Name **Description** 31 Reserved. \_ 30 CPE CLKRUN protocol enable. 29:17 Reserved. \_ ISAIRQ ISA IRQ enable. 16 C Point-to-point or serialized IRQ. 15 Reserved. ISA IRQ emulation policy. 14:13 IRQP Bit 14 Bit 13 IRQ Policy 0 0 Emulation is disabled. PCI IRQ is one of IRQ5/7/9/10. 0 1 0 PCI IRQ is not one of IRQ5/7/9/10. 1 Reserved. 1 1 12:11 Reserved. 10:8 DMAP DMA policy. Bit 8 **DMA Policy** Bit 10 Bit 9 0 0 0 Distributed DMA 0 0 Transparent DMA 1 PC/PCI DMA 0 1 0 0 Reserved 1 1 WBDMA 1 х х Reserved. Write 0. 6:5 Reserved. Returns 0 when read. \_ MPU base address select. 4:3 M4D Bit 4 Bit 3 MPU-401 I/O 0 0 330h 0 300h 1 320h 1 0 340h 1 1 S2 SB base address select. 0 = Sound Blaster decode is 220h. 1 = Sound Blaster decode is 240h.

#### 1 Reserved. Write 0.

PCI subsystem ID (SID) and subsystem vendor SID 0 ID (SVID) write-enable bit. 0 = Read-only (default). 1 = Read/write.

#### ESS Technology, Inc.

| Distributed DMA Control | (60h, 61h, R/W) |
|-------------------------|-----------------|
|                         | (•••, •,,       |

|    |    |    |    |    | DIOS | SB |   |   |   |   |   | 0 | 0 | 0 | DE |  |
|----|----|----|----|----|------|----|---|---|---|---|---|---|---|---|----|--|
| 15 | 14 | 13 | 12 | 11 | 10   | 9  | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0  |  |

The default value after reset is 0000h.

#### Bit Definitions:

| <u>Bits</u> | <u>Name</u> | Description                                                                            |
|-------------|-------------|----------------------------------------------------------------------------------------|
| 15:4        | DIOSB       | Distributed DMA base address.                                                          |
| 3:1         | -           | Reserved. Always write 0.                                                              |
| 0           | DE          | Distributed DMA enable.<br>1 = Enable distributed DMA.<br>0 = Disable distributed DMA. |

| Capability ID |   |   |       |          |   | (C | :0h, R) |
|---------------|---|---|-------|----------|---|----|---------|
|               |   |   | Capab | ility ID |   |    |         |
| 7             | 6 | 5 | 4     | 3        | 2 | 1  | 0       |

**Bit Definitions:** 

Description Bits Name

7:0 CID

This register identifies the linked list item as the register for PCI power management. The default value (assigned by the PCI-SIG) is 01h, indicating the unique ID for the PCI location of the capabilities pointer and the value.

#### **Next-Item Pointer**

| Next-Item pointer |   |   |   |   |   |   |   |
|-------------------|---|---|---|---|---|---|---|
| 7                 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

#### **Bit Definitions:**

Description Bits Name

7:0 NIP The default value is 00h, indicating that there are no more items in the linked list of the PCI power management capabilities.

(C1h, R)



#### PRELIMINARY

## **Solo-1 Configuration**

31

R

15

7

2



PCI CONFIGURATION REGISTERS

|               | agement Capabilities (C2h, C3h, R                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ) Power-Managemer       |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| 0 0 0 0       | 0 1 1 0 0 0 1 0 0 0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0 0 0 0 0 0             |
| 15 14 13 12   | 11 10 9 8 7 6 5 4 3 2 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 15 14 13 12 11 10       |
| The default   | value after reset is 0621h.                                                                                                                                                                                                                                                                                                                                                                                                                                                               | The default value af    |
| Bit Definitio | ns:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Bit Definitions:        |
|               | <u>e</u> <u>Description</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <u>Bits Name Descri</u> |
| 15:11         | PME Support. This five-bit field indicates the power states in which the function may assert                                                                                                                                                                                                                                                                                                                                                                                              | 15:2 – Reser            |
|               | PME. A value of 0 for any bit indicates that the function is not capable of asserting the PCE signal while in that power state.<br>Bit [15] = 0. PME# cannot be asserted from $D3_{cold}$<br>Bit [14] = 0. PME# cannot be asserted from $D3_{ho}$<br>Bit [13] = 0. PME# cannot be asserted from D2.<br>Bit [12] = 0. PME# cannot be asserted from D1.<br>Bit [11] = 0. PME# cannot be asserted from D1.<br>Bit [11] = 0. PME# cannot be asserted from D0.<br>Value of bits 15:11 = 00000. | 0                       |
| 10            | D2 Support. This bit indicates that this function supports the D2 power management state. Value of bit 10 = 1.                                                                                                                                                                                                                                                                                                                                                                            |                         |
| 9             | D1 Support. This bit indicates that this function supports the D1 power management state. Value of bit 9 = 1.                                                                                                                                                                                                                                                                                                                                                                             |                         |
| 8:6 –         | Reserved.<br>Value of bits 8:6 = 000.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                         |
| 5             | DSI. The Device Specific Initialization bit indi-<br>cates whether special initialization of this function<br>is required (beyond the standard PCI configura-<br>tion header) before the generic class device<br>driver is able to use it.<br>Value of bit $5 = 1$ .                                                                                                                                                                                                                      |                         |
| 4             | Auxiliary power source.<br>Value of bit 4 = 0.                                                                                                                                                                                                                                                                                                                                                                                                                                            |                         |
| 3             | PME clock. This bit indicates that no PCI clock is required for the function to generate PME. Value of bit $3 = 0$ .                                                                                                                                                                                                                                                                                                                                                                      |                         |
| 2:0           | Version. This 3-bit field indicates that this function<br>complies with Revision 1.0 of the PCI Power<br>Management Interface specification.                                                                                                                                                                                                                                                                                                                                              |                         |

#### ent Control/Status (C4h, C5h, R/W)

| 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | PS |   |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----|---|
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0 |

after reset is 0000h.

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

- erved. Returns 0 when read.
  - er state. This 2-bit field is used both to mine the current power state of a function, to set the function into a new power state.
    - Bit 0 Power State 0
    - Normal mode 1 Microcontroller halted
    - 0 Microcontroller halted and analog off
    - Microcontroller halted, analog, and 1 oscillator off

I/O PORTS



## I/O PORTS

## Port Summary

Table 9 I/O Port Summary

| Port                    | Read/<br>Write | Function                                                                                                                           |
|-------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------|
| IO Device               |                |                                                                                                                                    |
| IOBase+0h–IOBase+3h     | Read/write     | Audio 2 base/current DMA address.                                                                                                  |
| IOBase+4h–IOBase+5h     | Read/write     | Audio 2 base/current DMA count.                                                                                                    |
| IOBase+6h               | Read/write     | Solo-1 mode register.                                                                                                              |
| IOBase+7h               | Read/write     | IRQ control register.                                                                                                              |
| Audio/FM Device         |                |                                                                                                                                    |
| SBBase+0h-SBBase+3h     | Read/write     | 20-voice FM synthesizer. Address and data registers.                                                                               |
| SBBase+4h               | Read/write     | Mixer Address register (port for address of mixer controller registers).                                                           |
| SBBase+5h               | Read/write     | Mixer Data register (port for data to/from mixer controller registers).                                                            |
| SBBase+6h               | Read/write     | Audio reset and status flags.                                                                                                      |
| SBBase+7h               | Read/write     | Power Management register. Suspend request and FM reset.                                                                           |
| SBBase+8h–SBBase+9h     | Read/write     | 11-voice FM synthesizer. Address and data registers.                                                                               |
| SBBase+Ah               | Read-only      | Input data from read buffer for command/data I/O. Poll bit 7 of port SBBase+Eh to test whether the read buffer contents are valid. |
| SBBase+Ch               | Read/write     | Output data to write buffer for command/data I/O. Read embedded processor status.                                                  |
| SBBase+Eh               | Read-only      | Data available flag from embedded processor.                                                                                       |
| SBBase+Fh               | Read/write     | Address for I/O access to FIFO in Extended mode.                                                                                   |
| MPU-401 Device          |                |                                                                                                                                    |
| MPUBase+0h-MPUBase+1h   | Read/write     | MPU-401 port (x=0,1,2, or 3) if enabled.                                                                                           |
| Game Port Device        |                |                                                                                                                                    |
| GPBase+1h               | Read/write     | Joystick.                                                                                                                          |
| DMAC Device             |                |                                                                                                                                    |
| DDMABase+0h-DDMABase+2h | Read/write     | DMA current/base address.                                                                                                          |
| DDMABase+4h-DDMABase+5h | Read/write     | DMA current/base count.                                                                                                            |
| DDMABase+8h             | Read/write     | DMA command/status.                                                                                                                |
| DDMABase+9h             | Write          | DMA request.                                                                                                                       |
| DDMABase+Bh             | Write          | DMA mode.                                                                                                                          |
| DDMABase+Dh             | Write          | DMA master clear.                                                                                                                  |
| DDMABase+Fh             | Read/write     | DMA mask.                                                                                                                          |



#### **Port Descriptions**

**IO Device** 

#### Audio 2 Base/Current DMA Address

(IOBase+0h - IOBase+3h, R/W)

|                                     | A2DMAA (high word) |  |  |  |  |  |  |  |  |    |    |    |    |    |   |
|-------------------------------------|--------------------|--|--|--|--|--|--|--|--|----|----|----|----|----|---|
| 31 30 29 28 27 26 25 24 23 22 21 20 |                    |  |  |  |  |  |  |  |  | 20 | 19 | 18 | 17 | 16 |   |
|                                     | A2DMAA (low word)  |  |  |  |  |  |  |  |  |    |    | 0  | 0  | 0  | 0 |
| 15 14 13 12 11 10 9 8 7 6 5 4       |                    |  |  |  |  |  |  |  |  |    | 3  | 2  | 1  | 0  |   |

The default value is xxxxxx0h.

NOTE: The internal counter counts bits [19:0], then concatenates that with the upper bits of the base register.

#### **Bit Definitions:**

| <u>Bits</u> | <u>Name</u> | Description                |
|-------------|-------------|----------------------------|
| 31:4        | A2DMAA      | Audio 2 DMA address.       |
|             |             | Write to base address.     |
|             |             | Read from current address. |
| 3:0         | _           | Hardwired to 0h.           |

#### Audio 2 Base/Current DMA Count (IOBase+4h - IOBase+5h, R/W)

|    |    |    |    |    | A2DI | МАС |   |   |   |   |   | 0 | 0 | 0 | 0 |
|----|----|----|----|----|------|-----|---|---|---|---|---|---|---|---|---|
| 15 | 14 | 13 | 12 | 11 | 10   | 9   | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

The default value is xxx0h.

NOTE: The ISA DMAC (8237) sets N-1 to the count register. But this register needs N.

#### **Bit Definitions:**

| <u>Bits</u> | <u>Name</u> | Description              |
|-------------|-------------|--------------------------|
| 15:4        | A2DMAC      | Audio 2 DMA count.       |
|             |             | Write to base count.     |
|             |             | Read from current count. |
| 3:0         | _           | Hardwired to 0h.         |

#### Mode (IOBase+6h, R/W) 0 Auto-Init en BCLK sel DMA en DIR Ο 0 0 0

| J | 0 | 0 | 0 | Auto-Init en | DULK SEI | DIVIA en |  |
|---|---|---|---|--------------|----------|----------|--|
| 7 | 6 | 5 | 4 | 3            | 2        | 1        |  |

The default value is 00h.

#### Bit Definitions:

| <u>Bits</u> | <u>Name</u>  | Description                                                                                                    |
|-------------|--------------|----------------------------------------------------------------------------------------------------------------|
| 7:4         | -            | Reserved. Always write 0.                                                                                      |
| 3           | Auto-Init en | Auto-Initialize enable for Audio 2 DMA.<br>1 = Enable auto-initialization.<br>0 = Disable auto-initialization. |
| 2           | BCLK sel     | BCLK select.<br>1 = PCPCICLK/3.<br>0 = PCPCICLK/4.                                                             |
| 1           | DMA en       | Audio 2 DMA enable.<br>1 = Enable DMA.<br>0 = Disable DMA.                                                     |
| 0           | DIR          | Audio 2 DMA Direction. 0 = Memory to DAC. Read-only.                                                           |

| IRQ co |       |       |       |   |   | (IOBase+7h, R/W) |   |  |  |
|--------|-------|-------|-------|---|---|------------------|---|--|--|
| MPUIRQ | HVIRQ | A2IRQ | A1IRQ | 0 | 0 | 0                | 0 |  |  |
| 7      | 6     | 5     | 4     | 3 | 2 | 1                | 0 |  |  |

The default value is 00h.

#### Bit Definitions:

| <u>Bits</u> | <u>Name</u> | Description                              |
|-------------|-------------|------------------------------------------|
| 7           | MPUIRQ      | IRQ mask/status for MPU-401 IRQ.         |
| 6           | HVIRQ       | IRQ mask/status for hardware volume IRQ. |
| 5           | A2IRQ       | IRQ mask/status for audio 2 IRQ.         |
| 4           | A1IRQ       | IRQ mask/status for audio 1 IRQ.         |
| 3:0         | _           | Reserved. Always write 0.                |
|             |             |                                          |

#### Audio/FM Device

The FM synthesizer operates in two different modes: Emulation mode and Native mode. In Emulation mode the FM synthesizer is fully compatible with the OPL3 FM synthesizer. In Native mode the FM synthesizer has increased capabilities and performance for more realistic music. The following register descriptions are for Emulation mode only.

| FM Sta | M Status           IRQ         FT1         FT2         0 |     |   |   | (SBBase+0 |   |   |  |  |
|--------|----------------------------------------------------------|-----|---|---|-----------|---|---|--|--|
| IRQ    | FT1                                                      | FT2 | 0 | 0 | 0         | 0 | 0 |  |  |
| 7      | 6                                                        | 5   | 4 | 3 | 2         | 1 | 0 |  |  |

Reading this register returns the overflow flags for timers 1 and 2 and the "interrupt request" from these timers (this is not a real interrupt request but is supported as a status flag for backward compatibility with the OPL3 FM synthesizer).

28

I/O PORTS

PRELIMINARY

(SBBase+0h. W)



#### **FM Low Bank Address**

| Ī | A7 | A6 | A5 | A4 | A3 | A2 | A1 | A0 |
|---|----|----|----|----|----|----|----|----|
|   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

Low bank register address.

**NOTE:** Any write to this register will also put the FM synthesizer in Emulation mode if it is currently in Native mode.

| F | M Low Bank Data Write           D7         D6         D5         D4           7         6         5         4 |    | /rite |    | (SBBase+1h, W) |    |    |    |
|---|---------------------------------------------------------------------------------------------------------------|----|-------|----|----------------|----|----|----|
| Ī | D7                                                                                                            | D6 | D5    | D4 | D3             | D2 | D1 | D0 |
|   | 7                                                                                                             | 6  | 5     | 4  | 3              | 2  | 1  | 0  |

FM register write. The data written to SBBase+1h is written to the current address FM register. Note that register writes must follow the timing requirements of the OPL3 FM synthesizer.

|   | FM Hig | M High Bank Address           A7         A6         A5         A4 |    | SS |    | (SBBase+2h, W) |    |    |  |
|---|--------|-------------------------------------------------------------------|----|----|----|----------------|----|----|--|
| Ī | A7     | A6                                                                | A5 | A4 | A3 | A2             | A1 | A0 |  |
|   | 7      | 6                                                                 | 5  | 4  | 3  | 2              | 1  | 0  |  |

High bank register address.

| FM | M High Bank Data WriteD7D6D5D4 |    |    |    |    | (SBBase+3h, W) |    |    |  |
|----|--------------------------------|----|----|----|----|----------------|----|----|--|
| C  | )7                             | D6 | D5 | D4 | D3 | D2             | D1 | D0 |  |
|    | 7                              | 6  | 5  | 4  | 3  | 2              | 1  | 0  |  |

FM register write. Writing to this register in Emulation mode is the same as writing to register SBBase+1h.

| Mixe | r Addre | ss Reg | ister |    | (SBB | ase+4h | n, R/W) |
|------|---------|--------|-------|----|------|--------|---------|
| 0    | A6      | A5     | A4    | A3 | A2   | A1     | A0      |
| 7    | 6       | 5      | 4     | 3  | 2    | 1      | 0       |

The Solo-1 provides a means to read back the Mixer Address register. Reading back this register is useful for a "hot-key" application that needs to change the mixer while preserving the address register.

| Mixer | r Data F | Registe | r  |    | (SBB | ase+5h | n, R/W) |
|-------|----------|---------|----|----|------|--------|---------|
| D7    | D6       | D5      | D4 | D3 | D2   | D1     | D0      |
| 7     | 6        | 5       | 4  | 3  | 2    | 1      | 0       |

| Rese | t |   | (SI | BBase+ | •6h, W) |               |             |
|------|---|---|-----|--------|---------|---------------|-------------|
| 0    | 0 | 0 | 0   | 0      | 0       | FIFO<br>reset | SW<br>reset |
| 7    | 6 | 5 | 4   | 3      | 2       | 1             | 0           |

Bit Definitions:

| <u>Bits</u> | <u>Name</u> | Description                                                                          |
|-------------|-------------|--------------------------------------------------------------------------------------|
| 7:2         | _           | Reserved. Always write 0.                                                            |
| 1           | FIFO        | 1 = Hold Solo-1 FIFO in reset.                                                       |
|             | reset       | 0 = Release Solo-1 FIFO from reset.<br>Bit 1 has no function for Compatibility mode. |
| 0           | SW reset    | 1 = Hold Solo-1 in reset.<br>0 = Release Solo-1 from reset.                          |

| Statu | s Flags       | 5             |                 |   | (S            | BBase-        | ⊦6h, R)     |
|-------|---------------|---------------|-----------------|---|---------------|---------------|-------------|
| 0     | Act flag<br>1 | Act flag<br>0 | Serial act flag | R | MIDI<br>modes | FIFO<br>reset | SW<br>reset |
| 7     | 6             | 5             | 4               | 3 | 2             | 1             | 0           |

Bits 6:4 of port SBBase+6h can be used to monitor I/O activity to the Solo-1.

Bits 6:5 are set high after any read from port SBBase+6h. Then specific I/O activity can set these bits low. When port SBBase+6h is read at a later time, these bits will indicate whether I/O activity has occurred between the reads from SBBase+6h.

In addition, bit 4 can be used to indicate if the ES689/ ES69x serial interface is in use. Bit 4 is set high if bit 7 or bit 5 of mixer register 48h is high (software serial enable or serial reset). It is also set high if the ES689/ES69x serial interface is active, which is a combination of bit 4 of mixer register 48h set high and MCLK (ES689/ES69x serial bit clock) being high periodically.

#### **Bit Definitions:**

| Bits Name Descri | ption |
|------------------|-------|
|------------------|-------|

- 7 Reserved. Returns 0 when read.
- 6 Act flag1 Set low by I/O reads/writes to audio ports SBBase+4h and SBBase+5h.
- 5 Act flag 0 Set low by I/O writes to audio ports SBBase+0h–SBBase+3h, SBBase+6h, and SBBase+Ch. Set low by I/O reads from audio ports SBBase+0h–SBBase+3h, and SBBase+Ah. Also set low by DMA accesses to Solo-1.
- 4 Serial act 1 = Serial activity flag. High if an external flag ES689/ES69x is using MCLK/MSD to drive the FM DAC.
- 3 Reserved.

| <u>Bits</u> | <u>Name</u>   | Description                                                                                                                                                                                                                                            |
|-------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2           | MIDI<br>mode  | 1 = The Solo-1 is processing a controller com-<br>mand 30h, 31h, 34h, or 35h and is waiting for<br>the command to complete. Powering-down<br>may cause a loss of data.<br>The Solo-1 does not automatically wake up on<br>serial input on the MSI pin. |
| 1           | FIFO<br>reset | FIFO Reset bit.                                                                                                                                                                                                                                        |
| 0           | SW reset      | Software reset bit.                                                                                                                                                                                                                                    |

#### Power Management Register (SBBase+7h, R/W)

| Suspend<br>request | GPI | FM<br>synth<br>reset | 0 | R | R | R | R |
|--------------------|-----|----------------------|---|---|---|---|---|
| 7                  | 6   | 5                    | 4 | 3 | 2 | 1 | 0 |

#### **Bit Definitions:**

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

- 7 Suspend Pulse high, then low to request suspend. request
- 6 GPI VOLUP pin status. VOLUP pin can be used as GPI.
- 5 FM synth 1 = Hold FM synthesizer in reset. reset 0 = Release FM synthesizer from reset.
- 4 Reserved. Always write 0.
- 3:0 Reserved.

| Read | Data R | egister | ,  |    | (S | BBase+ | Ah, R) |
|------|--------|---------|----|----|----|--------|--------|
| D7   | D6     | D5      | D4 | D3 | D2 | D1     | D0     |
| 7    | 6      | 5       | 4  | 3  | 2  | 1      | 0      |

Read data from embedded audio processor. Poll bit 7 of port SBBase+Eh to test whether the register contents are valid.

| Write | Data R | egister |    |    | (SE | Base+ | Ch, W) |
|-------|--------|---------|----|----|-----|-------|--------|
| D7    | D6     | D5      | D4 | D3 | D2  | D1    | D0     |
| 7     | 6      | 5       | 4  | 3  | 2   | 1     | 0      |

Write data to embedded audio processor. Sets bit 7 of port SBBase+Ch high (write buffer not available) until data is processed by the Solo-1. This register cannot be written when SBBase+Ch bit 7 is high.

#### **Read Status Register**

(SBBase+Ch, R)

| BUSY<br>flag | WDAV | FIFO full | FIFO<br>empty | FIFO<br>half | IRQ<br>flag2 | IRQ<br>flag1 | IRQ<br>flag0 |
|--------------|------|-----------|---------------|--------------|--------------|--------------|--------------|
| 7            | 6    | 5         | 4             | 3            | 2            | 1            | 0            |

#### **Bit Definitions:**

#### Bits Name Description

| 7 | BUSY | 1 = Write buffer not available or Solo-1 busy. |
|---|------|------------------------------------------------|
|   | flag | 0 = Write buffer available or Solo-1 not busy. |

- 6 WDAV 1 = Data available in read buffer.
   0 = Data not available in read buffer.
   This flag is reset by a read from port SBBase+Ah.
- 5 FIFO 1 = Extended mode FIFO Full (256 bytes full loaded).
- 4 FIFO 1 = Extended mode FIFO Empty (0 bytes empty loaded).
- 3 FIFO 1 = FIFO Half Empty, Extended mode flag. half
- 2 IRQ 1 = Solo-1 processor generated an interrupt flag2 request (e.g., from Compatibility mode DMA complete).
- 1 IRQ 1 = Interrupt request generated by FIFO Half flag1 Empty flag change. Used by programmed I/O interface to FIFO in Extended mode.
- 0 IRQ 1 = Interrupt request generated by DMA flag0 counter overflow in Extended mode.

#### **Read Buffer Status Register**

ter (SBBase+Eh, R)

| RDAV |   |   |   | Reserved | eserved |   |   |  |  |  |
|------|---|---|---|----------|---------|---|---|--|--|--|
| 7    | 6 | 5 | 4 | 3        | 2       | 1 | 0 |  |  |  |

A read from port SBBase+Eh will reset any interrupt request.

#### **Bit Definitions:**

| <u>Bits</u> | <u>Name</u> | Description                                                                  |
|-------------|-------------|------------------------------------------------------------------------------|
| 7           | RDAV        | 1 = Data available in read buffer.<br>0 = Data not available in read buffer. |
|             |             | This flag is reset by a read from port<br>SBBase+Ah.                         |
| 6:0         | _           | Reserved.                                                                    |

### Programmed I/O Access to FIFO Register

|    |    |    |    |    | (288 | ase+Fr | 1, R/W) |
|----|----|----|----|----|------|--------|---------|
| D7 | D6 | D5 | D4 | D3 | D2   | D1     | D0      |
| 7  | 6  | 5  | 4  | 3  | 2    | 1      | 0       |

This port can be used to replace Extended mode DMA with programmed I/O.

D / A /

I/O PORTS

#### MPU-401 Device

| MPU-40 | 01 Data | 1  |    | (  | MPUBa | ase+0h | , <b>R/W)</b> |
|--------|---------|----|----|----|-------|--------|---------------|
| D7     | D6      | D5 | D4 | D3 | D2    | D1     | D0            |
| 7      | 6       | 5  | 4  | 3  | 2     | 1      | 0             |

This register is used to read data from the MPU-401 receive FIFO or a command acknowledge byte (0FEh). This register is also used to write data to the MPU-401 transmit FIFO.

| ļ | MPU-40 | )1 Com | nmand |    |    | (MPU | Base+ | 1h, W) |
|---|--------|--------|-------|----|----|------|-------|--------|
| Ī | D7     | D6     | D5    | D4 | D3 | D2   | D1    | D0     |
|   | 7      | 6      | 5     | 4  | 3  | 2    | 1     | 0      |

The MPU-401 device accepts only two commands:

- FFh Reset/return to Smart mode. This command generates an acknowledge byte if received when already in Smart mode.
- 3Fh Go to UART mode. This command generates an acknowledge byte if received while in Smart mode. It is ignored if the device is already in UART mode.

|   | MPU-40 | 01 Stat | us |   |   | (MPU | JBase | -1h, R) |
|---|--------|---------|----|---|---|------|-------|---------|
| - | -RR    | -TR     | Х  | Х | Х | Х    | Х     | Х       |
|   | 7      | 6       | 5  | 4 | 3 | 2    | 1     | 0       |

#### **Bit Definitions:**

| <u>Bits</u> | <u>Name</u> | Description                                                                                       |
|-------------|-------------|---------------------------------------------------------------------------------------------------|
| 7           | -RR         | 0 = read data available in the receive FIFO, or<br>pending acknowledge byte to be read<br>(0FEh). |
| 6           | -TR         | 0 = there is room in the transmit FIFO to accept another byte.                                    |

#### **Game Port Device**

The joystick device uses only a single I/O port. The device can function in one of two modes: Analog mode or Digital mode. The use of this I/O port is different depending on the mode. This section describes Analog mode.

| J | oystic                            | k |   |   |   | (GF | Base | ⊦1h W) |
|---|-----------------------------------|---|---|---|---|-----|------|--------|
|   | X X                               |   | Х | Х | Х | Х   | Х    | Х      |
|   | X         X           7         6 |   | 5 | 4 | 3 | 2   | 1    | 0      |

Any value written to the GPBase+1h port will restart the timing sequence. This should be done before reading the timer status flags.

| , | Joystic | k   |     |     |    | (GF | Base | -1h, R) |   |
|---|---------|-----|-----|-----|----|-----|------|---------|---|
|   | SWD     | SWC | SWB | SWA | TD | TC  | TB   | TA      | Ī |
|   | 7       | 6   | 5   | 4   | 3  | 2   | 1    | 0       | - |

SW(A-D) return the current state of the joystick switch inputs. T(A-D) return the current state of the four one-shot timers connected to the X and Y resistors of the dual joysticks.



I/O PORTS

**DMAC Device** 

#### DDMA Current/Base Address (DDMABase+0h – DDMABase+2h, R/W)

|             |    |    |    |    |    |   |   | 23 | 22  | 21    | 20 | 19 | 18 | 17 | 16 |
|-------------|----|----|----|----|----|---|---|----|-----|-------|----|----|----|----|----|
| DMA current |    |    |    |    |    |   |   |    | add | lress |    |    |    |    |    |
| 15          | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7  | 6   | 5     | 4  | 3  | 2  | 1  | 0  |

Write to the DMA base address register, read from the DMA current address register. The current address is automatically copied from the base register when DMA starts. The current address is then incremented or decremented according to bit 5 of DDMABase+Bh.

#### DDMA Current/Base Count (DDMABase+4h – DDMABase+5h, R/W)

|    |    |    |    |    | DM | A cı | irren | t/bas | e co | unt |   |   |   |   |   |
|----|----|----|----|----|----|------|-------|-------|------|-----|---|---|---|---|---|
| 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8     | 7     | 6    | 5   | 4 | 3 | 2 | 1 | 0 |

Write to the DMA base count register, read from the DMA current count register. The current count is automatically copied from the base register when DMA starts. The current count is then decremented for each byte transferred.

| DMA Command (DDMABase+8 |         |   |   |   |    |   | 8h, W) |
|-------------------------|---------|---|---|---|----|---|--------|
| DACKPOL                 | DREQPOL | 0 | 0 | 0 | EN | 0 | 0      |
| 7                       | 6       | 5 | 4 | 3 | 2  | 1 | 0      |

#### **Bit Definitions:**

| <u>Bits</u> Name | Description               |
|------------------|---------------------------|
| 7 DACKPOL        | DACK signal polarity.     |
| 6 DREQPOL        | DREQ signal polarity.     |
| 5:3 –            | Reserved. Always write 0. |
| 2 EN             | Controller enable.        |
| 1:0 –            | Reserved. Always write 0. |

#### DMA Status

| ( | DD | MA | Ba | se+ | 8h, | R) |
|---|----|----|----|-----|-----|----|
|---|----|----|----|-----|-----|----|



#### **Bit Definitions:**

| Bits Name | Description                                                           |
|-----------|-----------------------------------------------------------------------|
| 7:4 RQ    | 0000 = DREQ is asserted.<br>1111 = DREQ is negated.                   |
| 3:0 TC    | 0000 = Has not reached terminal count (TC).<br>1111 = Has reached TC. |

| DMA Mode |     |     | (DDMABase+Bh, |   | Bh, W) | 1 |
|----------|-----|-----|---------------|---|--------|---|
|          | סוס | A I | TTVDE         | 0 | 0      | Ī |

| TM | ODE | DIR | AI | TT۱ | /PE | 0 | 0 |
|----|-----|-----|----|-----|-----|---|---|
| 7  | 6   | 5   | 4  | 3   | 2   | 1 | 0 |

#### Bit Definitions:

| <u>Bits</u> | <u>Name</u> | Desc                             | ription                   |                                                                                      |
|-------------|-------------|----------------------------------|---------------------------|--------------------------------------------------------------------------------------|
| 7:6         | TMODE       | 0                                | 0                         | <u>Transfer Mode</u><br>Demand transfer                                              |
|             |             | 0<br>1<br>1                      | 1<br>0<br>1               | Single transfer<br>Block tranfer<br>Reserved                                         |
| 5           | DIR         | 1 = A                            | ddres                     | rection.<br>s decrement.<br>s increment.                                             |
| 4           | AI          | Auto-                            | Initiali                  | ze.                                                                                  |
| 3:2         | TTYPE       | <u>Bit 3</u><br>0<br>0<br>1<br>1 | Bit 2<br>0<br>1<br>0<br>1 | <u>Transfer Type</u><br>Verify transfer<br>Write transfer<br>Read tranfer<br>Illegal |

| DMA M | aster C          | Clear |   |   | (DDMA | Base+ | Dh, W) |  |
|-------|------------------|-------|---|---|-------|-------|--------|--|
|       | DMA master clear |       |   |   |       |       |        |  |
| 7     | 6                | 5     | 4 | 3 | 2     | 1     | 0      |  |

Write any value to this register to reset DMAC.

| DMA Mask |   |   |   |   | (D | DMABa | ase+Fł | n, R/W) |
|----------|---|---|---|---|----|-------|--------|---------|
| ſ        | 0 | 0 | 0 | 0 | 0  | 0     | 0      | Mask    |
|          | 7 | 6 | 5 | 4 | 3  | 2     | 1      | 0       |

#### **Bit Definitions:**

| <u>Bits</u> <u>Name</u> | Description               |
|-------------------------|---------------------------|
| 7:1 –                   | Reserved. Always write 0. |
| 0 Mask                  | Mask the DREQ.            |



## **PROGRAMMING THE SOLO-1**

#### Identifying the Solo-1

The Solo-1 device can be identified using the PCI standard configuration register. Offset 0h contains the registered Vendor ID (VID), which for ESS is 125Dh. Offset 2h contains the assigned Device ID (DID), which for the Solo-1 is 1969h.

In addition, the Solo-1 has a Subsystem Vendor ID (SVID) and Subsystem ID (SID). These two registers default to 125Dh and 1818h respectively at power-on. If the Solo-1 is mounted on the motherboard, the BIOS can program these two registers at startup. Note that warm reset does not reset these registers.

#### **Resetting and Initializing the Solo-1**

The Solo-1 chip can be reset in one of two ways: hardware or software reset.

The hardware reset signal comes from the PCI bus and it initializes:

- · PCI configuration registers
- the microcontroller
- internal FIFOs

#### Table 10 Hardware and Software Reset Initializations

- the ESFM synthesizer
- · the mixer registers
- · the analog mixer
- CODECs

A cold reset also initializes SID/SVID (Subsystem ID and Subsystem Vendor ID) registers.

The software reset is controlled by bit 0 of port SBBase+6h and it initializes:

- the microcontroller
- the ESFM synthesizer
- the analog mixer
- the CODEC

To reset the Solo-1 by software:

- 1. Set bit 0 of SBBAase+6h.
- 2. Delay a short period by reading back SBBase+6h.
- 3. Clear bit 0 of SBBase+6h.
- In a loop lasting at least 1 millisecond, poll port SBBase+Eh bit 7 for Read Data Available. Exit the loop only if bit 7 is high and SBBase+Ah returns 0AAh.

| Initialization                                            | Hardware Reset | Software Reset  |
|-----------------------------------------------------------|----------------|-----------------|
| Disable Extended Mode                                     | Yes            | Yes             |
| Reset the timer divider and filter for 8 kHz              | Yes            | Yes             |
| Stop any DMA transactions in progress                     | Yes            | Yes             |
| Clear any active interrupt requests                       | Yes            | Yes             |
| Disable voice input of mixer                              | Yes            | Yes             |
| Compatibility/Extended mode DMA counters to 2048 ytes     | Yes            | Yes             |
| Set audio 1 CODEC direction to DAC                        | Yes            | Yes             |
| Set DAC volumes to mid-level                              | Yes            | Yes             |
| Set input volume for 8-bit recording with AGC to maximum  | Yes            | Yes             |
| All other mixer registers to default values               | Yes            | No              |
| Internal FIFO in extended mode                            | Yes            | No <sup>2</sup> |
| PCI Configuration registers, except SID/SVID <sup>1</sup> | Yes            | No              |
| 1. SID/SVID can be initialized by power-up.               |                | 1               |

2. Bit 1 of SBBase+6h can reset internal FIFOs.

After the system powers up, the PCI BIOS initializes the header portion (00h–3Fh) of the PCI configuration space. The PCI BIOS can also program the SID and SVID registers.

After the PCI BIOS initializes the device, the Solo-1 is in native mode. All of the PCI Configuration registers should be set up properly before the Solo-1 accesses any other registers.



#### Programming for DOS Game Compatibility

The Solo-1 can be 99% compatible to legacy Sound Blaster Pro. To achieve high compatibility to a legacy ISA device on the PCI bus, two major issues need to be addressed. The first issue concerns ISA DMA, and the second issue concerns ISA IRQ.

To emulate ISA DMA on the PCI bus, the Solo-1 can employ three different protocols. Transparent DMA (TDMA) is a chipset-independent mechanism, Distributed DMA (DDMA) and PC to PCI DMA (PC/PCI DMA) need to be supported by the PCI chip set.

In TDMA, the Solo-1 snoops PCI bus transactions to legacy DMA controller device (like the 8237, which is usually embedded in the PCI chip set), then performs a PCI bus master transaction to complete DMA. Legacy DMAC does not receive a DRQ signal from Solo-1.

In DDMA, the central resource (PCI chip set) includes a DMA remap engine. All transactions to legacy DMAC are remapped to each client (such as the Solo-1) by the remap engine. The Solo-1 then performs a PCI bus master transaction.

In PC/PCI DMA, the central resource (PCI chip set) performs PC/PCI cycles, which use sideband signals to the standard PCI bus. The Solo-1 then acts as a slave device during DMA.

Once one of the three DMA protocols is set up, the Solo-1 is detected as an ISA device.

The second issue concerns ISA IRQ. The ISA IRQ is edge triggered while PCI IRQ is level sensitive. By setting up the IRQ policy bits in PCI Configuration register 50h, the Solo-1 can emulate ISA IRQ.

Setting bit 15 of Legacy Audio Control Rregister (LACR, PCI Configuration register 40h) to 0, allows the Solo-1 to decode legacy audio addresses.

#### Selecting DMA/IRQ Policy

Because PCI chip sets do not all support the same DMA protocols, DMA policy should be selected according to the chip set in use. Table 11 and Table 12 list the recommended DMA policys for Intel chip sets for add-on cards and motherboards respectively. To find out which DMA policy to use with non-Intel chip set, contact your ESS FAE. DMA policy is configured in PCI Configuration register 50h, bits [10:8].

| Table 11 ISA DMA Policy Bits for Add-On Cards |          |            |       |       |  |  |  |
|-----------------------------------------------|----------|------------|-------|-------|--|--|--|
| Chip Set                                      | Protocol | DMA Policy |       |       |  |  |  |
| Chip Set                                      | FIOLOCOI | Bit 10     | Bit 9 | Bit 8 |  |  |  |
| Intel 430FX (Triton)                          | TDMA     | 0          | 0     | 1     |  |  |  |
| Intel 430HX (Triton-2)                        | TDMA     | 0          | 0     | 1     |  |  |  |
| Intel 430VX (Triton-3)                        | TDMA     | 0          | 0     | 1     |  |  |  |
| Intel 430TX                                   | DDMA     | 0          | 0     | 0     |  |  |  |
| Intel 440LX                                   | TDMA'    | 1          | 0     | 1     |  |  |  |
| Intel 440BX                                   | DDMA     | 0          | 0     | 0     |  |  |  |

Table 12 ISA DMA Policy Bits for Motherboards

| Chip Set               | Protocol | DMA Policy |       |       |
|------------------------|----------|------------|-------|-------|
|                        |          | Bit 10     | Bit 9 | Bit 8 |
| Intel 430FX (Triton)   | TDMA     | 0          | 0     | 1     |
| Intel 430HX (Triton-2) | TDMA     | 0          | 0     | 1     |
| Intel 430VX (Triton-3) | TDMA     | 0          | 0     | 1     |
| Intel 430TX            | DDMA     | 0          | 0     | 0     |
| Intel 440LX            | PCPCI    | 0          | 1     | 0     |
| Intel 440BX            | PCPCI    | 0          | 1     | 0     |

To emulate ISA IRQ on the PCI bus, program the IRQ emulation policy bits, unless SERIRQ is used. Table 13 lists the program IRQ Policy bits. Program the policy bits according to the IRQ level selected for the Solo-1's INTAB pin. IRQ policy is configured in PCI Configuration register 50h, bits [14:13].

#### Table 13 ISA IRQ Emulation Policy Bits

| PCI IRQ (INTAB Pin)          | IRQ Policy |        |  |
|------------------------------|------------|--------|--|
|                              | Bit 14     | Bit 13 |  |
| IRQ 5/7/9/10                 | 0          | 1      |  |
| IRQs other than IRQ 5/7/9/10 | 1          | 0      |  |

PCI Configuration register 3Ch is set by the PCI BIOS, and it indicates which IRQ the Solo-1 INTAB pin is using. PCI Configuration register 40h (Legacy Audio Control register), bits[9:8] indicate which IRQ is used by the game. **PROGRAMMING THE SOLO-1** 



### **Programming for Native PCI Audio**

When the Solo-1 is configured as a native PCI device, the audio channels must be configured properly, as shown in the procedures below. The Solo-1 is a bus master device.

#### **Configuring Audio 1 in Native Mode**

1. Set up the DDMA Control register.

The PCI BIOS reserves IO regions (16 bytes), and stores them in the VCBase register. Copy the VCBase register (PCI Configuration register 18h) to the DDMA Control register (PCI Configuration register 60h), with bit 0 set.

- Select the DMA/IRQ policy. The DMA policy should be set for DDMA (PCI Configuration register 50h, bits 10:8 = 000). The ISA IRQ emulation should be disabled (PCI Configuration register 50h, bits 14:13 = 00).
- Program the Sound Blaster compatible module. See "Extended Mode Audio 1 DAC Operation" on page 40.
- 4. Program the DMA controller. Instead of using 8237 (DMAC), the program should use the built-in DMAC inside the Solo-1. The built-in DMAC is accessed as IO address range DDMABase+0h to DDMABase+Fh. Use the following sequence to program the built-in DMAC.
  - 1. Master reset. Write any data to DDMABase+Dh.
  - 2. Mask DMA. Write 1 to DDMABase+Fh.
  - Set up DMA mode.
     Write the mode value to DDMA Base+Bh.
  - Setup DMA base address and counts. Write the base address to DDMABase+0h. Write the base count to DDMABase+4h.
  - 5. Unmask DMA. Write 0 to DDMABase+Fh.

#### **Configuring Audio 2 in Native Mode**

Unlike programming for Audio 1 in native mode, all IO spaces are allocated by PCI BIOS.

- Program the legacy ESS *Audio*Drive<sup>®</sup> controller module. See "Second Audio Channel DAC Operation" on page 43.
- Program the DMA controller. Instead of using 8237 (DMAC), the program should use the built-in DMAC inside the Solo-1. The built-in DMAC is accessed as IO address range IOBase+0h to IOBase+6h. Use the following sequence to program the built-in DMAC.
  - Disable DMA. Clear bit 1 of IOBase+2h. Preserve all other bits.
  - Set up DMA mode. Program bit 3 of IOBase+2h. Preserve all other bits.
  - Set up DMA base address and counts. Write the base address to IOBase+0h. Write the base count to IOBase+4h.
  - 4. Enable DMA. Set bit 1 of IOBase+2h. Preserve all other bits.

#### Modes of Operation

The Solo-1 can operate the first audio channel in one of two modes: Compatibility mode or Extended mode.

In both modes, a set of mixer and controller registers enables application software to control the analog mixer, record source, and output volume. Programming the Solo-1 Enhanced Mixer is described later in this document. See "Programming the Solo-1 Mixer" on page 45.

#### **Compatibility Mode Description**

The first mode, Compatibility mode, is compatible to the Sound Blaster Pro. This is the default mode after reset. In this mode, the Solo-1 microcontroller is an intermediary in all functions between the PCI bus and the CODEC. The Solo-1 microcontroller performs limited FIFO functions using 64 bytes of internal memory.

#### Extended Mode Description

The Solo-1 also supports an Extended mode of operation. In this case, a 256-byte FIFO is used as an intermediary between the PCI bus and the ADC and DAC Control registers, and various Extended mode controller registers are used for control. The Solo-1 microcontroller is mostly idle in this mode. DMA control is handled by dedicated logic. Programming for Extended mode operation requires accessing various control registers with Solo-1 commands.

#### Table 14 Comparison of Operation Modes

|                                               | Compatibility Mode<br>(Sound Blaster Pro) | Extended Mode                |
|-----------------------------------------------|-------------------------------------------|------------------------------|
| Sound Blaster Pro compatible                  | Yes                                       | No                           |
| FIFO Size                                     | 64 bytes (firmware managed)               | 256 bytes (hardware managed) |
| Mono 8-bit ADC, DAC                           | Yes, to 44 kHz                            | Yes, to 48 kHz               |
| Mono 16-bit ADC, DAC                          | Yes, to 22 kHz                            | Yes, to 48 kHz               |
| Stereo 8-bit DAC                              | Yes, to 22 kHz                            | Yes, to 48 kHz               |
| Stereo 8-bit ADC                              | Yes, to 22 kHz                            | Yes, to 48 kHz               |
| Stereo 16-bit DAC                             | Yes, to 11 kHz                            | Yes, to 48 kHz               |
| Stereo 16-bit ADC                             | No                                        | Yes, to 48 kHz               |
| Signed/Unsigned Control                       | No                                        | Yes                          |
| Automatic Gain Control during recording       | Firmware controlled, to 22 kHz, mono only | No                           |
| Programmed I/O block transfer for ADC and DAC | No                                        | Yes                          |
| FIFO status flags                             | No                                        | Yes                          |
| Auto reload DMA                               | Yes                                       | Yes                          |
| Time base for programmable timer              | 1 MHz or 1.5 MHz                          | 800 kHz or 400 kHz           |
| ADC and DAC jitter                            | ± 2 microseconds                          | Depends on XTAL              |

#### **Mixing Modes Not Recommended**

Avoid mixing Extended mode commands with Compatibility mode commands. The Audio 1 DAC Enable/ Disable commands D1h and D3h are safe to use when using Extended mode to process ADC or DAC. However, other Compatibility mode commands can cause problems. The Extended mode commands may be used to set up the DMA or IRQ channels before entering Compatibility mode.

#### **Data Formats**

This section briefly describes the different audio data formats used by the Solo-1.

#### **Compressed Data Formats**

The Solo-1 supports two types of compressed sound DAC operations: ESPCM<sup>®</sup>, which uses a variety of proprietary compression techniques developed by ESS Technology, and ADPCM, which is supported by many other sound cards but is of a lower quality.

Both ADPCM and **ESPCM**<sup>®</sup> are only transferred using DMA transfer. The first block of a multiple-block transfer uses a different command than subsequent blocks. The first byte of the first block is called the reference byte.

Use Compatibility mode when transferring compressed data.

#### Sound Blaster Pro Compatible Data Formats

There are four formats available from the combination of the following two options:

- 8-bit or 16-bit
- Mono or stereo

The 8-bit samples are unsigned, ranging from 0h to 0FFh, with the DC-levels around 80h.

16-bit samples are unsigned, ranging from 0000h to 0FFFFh, with the DC-levels around 8000h.

#### Stereo DMA Transfers in Compatibility Mode

Stereo DMA transfers are only available using DMA rather than Direct mode commands.

To perform a stereo DMA transfer, first set bit 1 of mixer register 0Eh high. Then set the timer divider to twice the per-channel sample rate.

The maximum stereo transfer rate for 8-bit data is 22 kHz per channel, so for this case program the timer divider as if it were for 44 kHz mono. The maximum stereo transfer rate for 16-bit data is 11 kHz per channel. Stereo ADC transfers for 16-bit data are not allowed in Compatibility mode.

For 8-bit data, the Solo-1 expects the first byte transferred to be for the right channel, and subsequent bytes to alternate left, right etc.



For 16-bit data, the Solo-1 expects DMA transfers to be a multiple of 4, with repeating groups in the order:

- 1. left low byte
- 2. left high byte
- 3. right low byte
- 4. right high byte

#### Solo-1 Data Formats (Extended Mode and Audio 2)

There are eight formats available from the combination of the following three options:

- Mono or stereo
- 8-bit or 16-bit
- Signed or unsigned

For stereo data, the data stream always alternates channels in successive samples: first left, then right. For 16-bit data, the low byte always precedes the high byte.

#### Sending Commands During DMA Operations

It is useful to understand the detailed operation of sending a command during DMA.

The Solo-1 uses the Audio 1 FIFO for DMA transfers to/ from the CODEC. When the FIFO is full (in the case of DAC) or empty (in the case of ADC), DMA requests are temporarily suspended and the Busy flag (bit 7 of port SBBase+Ch) is cleared. This opens a window of opportunity to send a command to the Solo-1. Commands such as D1h and D3h which control the Audio 1 DAC mixer input enable/disable status, and command D0h, which suspends or pauses DMA, are acceptable to send during this window.

The Solo-1 chip sets the Busy flag when the command window is no longer open. Application software must send a command within 13 microseconds after the Busy flag goes high or the command will be confused with DMA data. Sending a command within the command window is easy if polling is done with interrupts disabled.

As an example of sending a command during DMA, consider the case where the application wants to send command D0h in the middle of a DMA transfer. The application disables interrupts and polls the Busy flag. Because of the FIFO and the rules used for determining the command window, it is possible for the current DMA transfer to complete while waiting for the Busy flag to clear. In this event, the D0h command has no function, and a pending interrupt request from the DMA completion is generated.

The interrupt request can be cleared by reading port SBBase+Eh before enabling interrupts or having a way of signaling the interrupt handler that DMA is inactive so that it does not try to start a new DMA transfer.

Figure 11 shows timing considerations for sending a command.





#### **Compatibility Mode Programming**

This section describes Compatibility mode programming.

#### **Compatibility Mode DAC Operation**

1. Reset

Write 1h to port SBBase+6h.

To play a new sound without resetting the Solo-1 beforehand, when the status of the analog circuits is not clear, mute the input to the mixer with command D3h to prevent pops.

2. Enable stereo mode (optional).

Set bit 1 of mixer register 0Eh high. Use only DMA mode. Clear bit 1 of mixer register 0Eh after the DAC transfer.

3. Set sample rate and filter clock.

Use commands 40h or 41h to set the sample rate and filter clock divider. To set the filter clock to be independent from the sample rate, use command 42h in addition to 40h or 41h.



For stereo transfers, set the timer divider to twice the per-channel sample rate. The maximum stereo transfer rate for 8-bit data is 22 kHz per channel; so for this case, program the first timer divider as if you were transferring data at 44 kHz mono. The maximum stereo transfer rate for 16-bit data is 11 kHz per channel.

- 4. Set the block size. Only use this command (48h) with High-Speed DMA transfer modes (commands 90h and 91h).
- 5. Configure the system interrupt controller and system DMA controller.
- 6. Start DMA.

Start the DMA transfer by sending the command for the desired transfer type and data length. The uncompressed modes are shown in Table 15. See Table 27 for a description of the commands in addition to the commands for DMA transfers of compressed data.

| DAC DMA Transfer Mode    | Data Length | Command |
|--------------------------|-------------|---------|
| Direct                   | 8-bit       | 10h     |
|                          | 16-bit      | 11h     |
| DMA mode Normal          | 8-bit       | 14h     |
|                          | 16-bit      | 15h     |
| High-Speed               | 8-bit       | 91h     |
| DMA mode Auto-Initialize | 8-bit       | 1Ch     |
|                          | 16-bit      | 1Dh     |
| High-Speed               | 8-bit       | 90h     |

Table 15 Uncompressed DAC Transfer Modes

- 7. Delay approximately 300 milliseconds to allow the analog circuits to settle, then enable the Audio 1 DAC input to mixer with command D1h.
- 8. During DMA.

For Auto-Initialize mode, it is not necessary to send any commands to the Solo-1 at interrupt time, except to read SBBase+Eh to clear the interrupt request.

For Normal mode, initialize the system DMA controller with the address and count of the next block size if it changes. Use command 48h. To start the next transfer, use command D4h.

To stop DMA after the current auto-initialize block is finished, use command D0h.

Commands such as D1h and D3h, which control the Audio 1 DAC mixer input enable/disable status, and command D0h, which suspends DMA, are acceptable to send during DMA transfers. These commands can only be sent during certain windows of opportunity. See "Stereo DMA Transfers in Compatibility Mode" on page 36.

- 9. After DMA is finished, restore the system interrupt controller and DMA controller to their idle state. Monitor the FIFO Empty status flag in port SBBase+Ch to be sure that data transfer is completed. Delay 25 milliseconds to let the filter outputs settle to DC-levels, then disable the Audio 1 DAC input to the mixer with command D3h.
- 10.Issue another software reset to the Solo-1 to initialize the appropriate registers.

# **Compatibility Mode ADC Operation**

Solo-1 analog circuitry is switched from the DAC direction to the ADC direction by the first direct or DMA mode ADC command (2xh). Discard the first 25 to 100 milliseconds of samples because pops might occur in the data due to the change from the DAC to ADC direction. In the ADC direction the voice input to the mixer is automatically muted.

1. Reset

Write 1h to port SBBase+6h.

To play a new sound without resetting the Solo-1 beforehand, when the status of the analog circuits is not clear, mute the input to the mixer with command D3h to prevent pops.

2. Select the input source using register 0Ch

Sound Blaster Pro has three recording sources: microphone, line, and auxiliary A (CD). Microphone input is the default source after any reset.

The Solo-1 has four recording sources: microphone, line, auxiliary A (CD), and mixer. Use mixer register 1Ch to choose the additional source.

3. Program the input volume.

The selected source passes through an input volume stage that can be programmed with 16 levels of gain from 0 to +22.5 dB in steps of 1.5 dB. In 8-bit recordings (other than High-Speed mode), the volume stage is controlled by the Solo-1 firmware for the purposes of automatic gain control (AGC). In 16-bit recordings as well as High-Speed mode 8-bit recordings, the input volume stage is controllable from application software. Use command DDh to change the input volume level from 0 to 15. The reset default is mid-range, 8.

4. Enable stereo mode (optional).

Set bit 1 of mixer register 0Eh high. Use only DMA mode. Clear bit 1 of mixer register 0Eh after the ADC transfer.



5. Set sample rate and filter clock.

Use commands 40h or 41h to set the sample rate and filter clock divider. If you want to set the filter clock to be independent from the sample rate, use command 42h in addition to 40h or 41h.

For stereo transfers, set the timer divider to twice the per-channel sample rate. The maximum stereo transfer rate for 8-bit data is 22 kHz per channel; so for this case, program the first timer divider as if you were transferring data at 44 kHz mono. The maximum stereo transfer rate for 16-bit data is 11 kHz per channel.

- 6. Set the block size. Only use this command (48h) with High-Speed DMA transfer modes (commands 98h and 99h).
- 7. Configure the system interrupt controller and system DMA controller.
- 8. Start DMA.

Start the DMA transfer by sending the command for the desired transfer type and data length. The uncompressed modes are shown in Table 16. See Table 27 for a description of the commands in addition to the commands for DMA transfers of compressed data.

| ADC DMA Transfer Mode    | Data Length | Command |
|--------------------------|-------------|---------|
| Direct                   | 8-bit       | 20h     |
|                          | 16-bit      | 21h     |
| DMA mode Normal          | 8-bit       | 24h     |
|                          | 16-bit      | 25h     |
| High-Speed               | 8-bit       | 99h     |
| DMA mode Auto-Initialize | 8-bit       | 2Ch     |
|                          | 16-bit      | 2Dh     |
| High-Speed               | 8-bit       | 98h     |

Table 16 Uncompressed ADC Transfer Modes

9. Delay approximately 100 milliseconds to allow the analog circuits to settle, then enable the Audio 1 DAC input to mixer with command D1h.

# 10. During DMA.

For Auto-Initialize mode, it is not necessary to send any commands to the Solo-1 at interrupt time, except to read SBBase+Eh to clear the interrupt request.

For Normal mode, initialize the system DMA controller with the address and count of the next block size if it changes. Use command 48h. To start the next transfer, use command D4h. To stop DMA after the current auto-initialize block is finished, use command D0h.

Commands such as D0h, which suspends DMA, are acceptable to send during DMA transfers. These commands can only be sent during certain windows of opportunity. See "Writing Commands to Solo-1 Controller Registers" on page 40.

- 11. After DMA is finished, restore the system interrupt controller and DMA controller to their idle state. Monitor the FIFO Empty status flag in port SBBase+Ch to be sure that data transfer is completed.
- 12.Issue another software reset to the Solo-1 to initialize the appropriate registers.

The maximum sample rate for Direct mode ADC is 22 kHz.

The maximum sample rate for DMA ADC for both 8-bit and 16-bit is 22 kHz, using commands 24h, 25h, 2Ch, or 2Dh.

There is a special High-Speed mode for ADC that allows 8-bit sampling up to 44 kHz. This mode uses commands 98h (auto-initialize) and 99h (normal). No AGC is performed as the input volume is controlled with command DDh.

# Extended Mode Programming

This section describes Extended mode programming.

#### **Commanding Solo-1 Controller Registers**

Controller registers are written to and read from using commands sent to ports SBBase+Ch and SBBase+Ah.

Commands of the format Axh, Bxh, and Cxh, where x is a numeric value, are used for Extended mode programming of the first audio channel.

Commands of the format Ax and Bx are used to access the Solo-1 controller registers. For convenience, the registers are named after the commands used to access them. For example "register A4h," the Audio 1 Transfer Count Reload (low-byte) register, is written to by "command A4h."

#### Enabling Extended Mode Commands

After any reset, and before using any Extended mode commands first send command C6h to enable Extended mode commands.

#### Solo-1 Command/Data Handshaking Protocol

This section describes how to write commands to and read data from the Solo-1 controller registers.



#### Writing Commands to Solo-1 Controller Registers

Commands written to the Solo-1 enter a write buffer. Before writing the command, make sure the buffer is not busy.

Bit 7 of port SBBase+Ch is the Solo-1 Busy flag. It is set when the write buffer is full or when the Solo-1 is otherwise busy (for example, during initialization after reset or during Compatibility mode DMA requests).

To write a command or data byte to the Solo-1 microcontroller:

1. Poll bit 7 of port SBBase+Ch until it is clear.

2. Write the command/data byte to port SBBase+Ch.

The following is an example of writing to Solo-1 controller registers. To set up the Audio 1 Transfer Count Reload register to F800h, send the following command/data bytes:

A4h, 00h; register A4h = 0h

A5h, F8h; register A5h = F8h

**NOTE:** The port SBBase+Ch write buffer is shared with Compatibility mode DMA write operations. When DMA is active, the Busy flag is cleared during windows of time when a command can be received. Normally, the only commands that should be sent during DMA operations are Dxh commands such as DMA pause/continue and Audio 1 DAC enable/disable. In this situation it is recommended to disable interrupts between the time that the Busy bit is polled and the command is written. Also, minimize the time between these instructions. See "Sending Commands During DMA Operations" on page 37 for more information.

#### Reading the Read Data Buffer of the Solo-1

Command C0h is used to read the Solo-1 controller registers used for Extended mode. Send command C0h followed by the register number, Axh or Bxh. For example, to read register A4h, send the following command bytes:

COh, A4h

Then poll the Read-Data-Buffer-Status bit, bit 7 of port SBBase+Eh, before reading the register contents from port SBBase+Ah.

The Read-Data-Buffer-Status flag can be polled by reading bit 7 of port SBBase+Eh. When a byte is available, the bit is set high.

**NOTE:** Any read of port SBBase+Eh also clears any active interrupt request from the Solo-1. An alternate way of polling the Read-Data-Buffer-Status bit is through bit 6 of port SBBase+Ch, which is the same flag. The Read-Data-Buffer-Status flag is cleared automatically by reading the byte from port SBBase+Ah.

#### **Extended Mode Audio 1 DAC Operation**

Follow the steps below to program the first audio channel for Extended mode DAC operation:

1. Reset

Write 3h to port SBBase+6h, instead of 1h as in Compatibility mode. Bit 1 high specifically clears the FIFO. The remainder of the software reset is identical to Compatibility mode. Reset disables the Audio 1 DAC input to the mixer. This is intended to mask any pops created during the setup of the DMA transfer.

- 2. After the reset, send command C6h to enable Extended mode commands.
- 3. Program direction and type: registers B8h, A8h, and B9h:

Register B8h: set bit 2 low for Normal DMA mode, high for Auto-Initialize DMA mode. Leave bit 3 low for the CODEC to run in the DAC direction.

Register A8h: read this register to preserve the bits and then modify only bits 1 and 0:

Bits 1:0 10: Mono

Bits 1:0 01: Stereo

Set register B9h:

- Bits 1:0 00: Single transfer DMA.
- Bits 1:0 01: Demand Transfer DMA: 2 bytes per DMA request.
- Bits 1:0 11: Demand transfer DMA: 4 bytes per DMA request.
- Clocks and counters: registers A1h, A2h, A4h and A5h: Register A1h: Sample Rate Clock Divider Register A2h: Filter Clock Divider Registers A4h/A5h: Audio 1 Transfer Count Reload register low/high byte, two's complement
- 5. Initialize and configure DACs: registers B6h and B7h: See Table 17.

Register B6h: 80h for signed data and 00h for unsigned data. This also initializes the CODEC for DAC transfer.

Register B7h: programs the FIFO (16-bit/8-bit, signed/ unsigned, stereo/mono).



| Mono | Stereo | 8-bits | 16-bits | Unsigned | Signed | Sequence                                          |
|------|--------|--------|---------|----------|--------|---------------------------------------------------|
| Х    |        | Х      |         | Х        |        | Reg B6h = 80h,<br>Reg B7h = 51h,<br>Reg B7h = D0h |
| Х    |        | Х      |         |          | Х      | Reg B6h = 00h,<br>Reg B7h = 71h,<br>Reg B7h = F0h |
| Х    |        |        | Х       | Х        |        | Reg B6h = 80h,<br>Reg B7h = 51h,<br>Reg B7h = D4h |
| Х    |        |        | Х       |          | Х      | Reg B6h = 00h,<br>Reg B7h = 71h,<br>Reg B7h = F4h |
|      | Х      | Х      |         | Х        |        | Reg B6h = 80h,<br>Reg B7h = 51h,<br>Reg B7h = 98h |
|      | Х      | Х      |         |          | Х      | Reg B6h = 00h,<br>Reg B7h = 71h,<br>Reg B7h = B8h |
|      | Х      |        | Х       | Х        |        | Reg B6h = 80h,<br>Reg B7h = 51h,<br>Reg B7h = 9Ch |
|      | Х      |        | Х       |          | Х      | Reg B6h = 00h,<br>Reg B7h = 71h,<br>Reg B7h = BCh |

#### Table 17 Command Sequences for DMA Playback

 Enable/select DMA channel and IRQ channel, registers B1h, and B2h: Register B1h: Interrupt Configuration register.

Make sure bits 4 and 6 are high. Clear bits 7 and 5.

Register B2h: DRQ Configuration register. Make sure bits 4 and 6 are high. Clear bits 7 and 5.

- 7. Configure system interrupt controller and DMA controller.
- 8. To start DMA:

Set bit 0 of register B8h high while preserving all other bits.

9. Delay approximately 100 milliseconds to allow analog circuits to settle, then enable the Audio 1 DAC input to mixer with command D1h.

10. During DMA

For Auto-Initialize transfers, read SBBase+Eh to clear the interrupt request. Do not send any other commands to the Solo-1 at interrupt time. For Normal mode, initialize the system DMA controller with the address and count of the next block to transfer. Update the Solo-1 Transfer Count registers if the count is changed. To start the next transfer, clear bit 0 of register B8h, then set it high again.

To stop a DMA transaction in progress, clear bit 0 of register B8h. To stop a DMA transaction after the current auto-initialize block is finished, clear bit 2 of register B8h, wait for the interrupt, and then clear bit 0 of register B8h.

11. After DMA is finished:

Restore the system interrupt controller and DMA controller to their idle state. Monitor the FIFO Empty status flag in port SBBase+Ch to be sure data transfer is completed. A delay of 25 milliseconds is required to let the filter outputs settle to DC-levels, then disable the first DMA DAC input to the mixer with command D3h.

12.Finally:

Issue another software reset to the Solo-1 to initialize the appropriate registers.

#### Extended Mode Audio 1 ADC Operation

Follow the steps below to program the first audio channel for Extended mode ADC operation:

**NOTE:** In Extended mode, there is no Automatic Gain Control (AGC) performed while recording. If AGC is necessary, use 16-bit recordings and perform AGC in system software.

1. Reset

Write 3h to port SBBase+6h instead of 1h as in Compatibility mode. Bit 1 high specifically clears the FIFO. The remainder of the software reset is identical to Compatibility mode. Reset disables the Audio 1 DAC input to the mixer. This is intended to mask any pops created during the setup of the DMA transfer.

- 2. Send command C6h to enable Extended mode commands.
- 3. Select the input source:

The Solo-1 has four recording sources: microphone, line, auxiliary A, and mixer. The mixer source can be the playback mixer or the record mixer. Bits 4:3 of mixer register 7Ah selects the mixer source. The record mixer is the default. Microphone input is the default after any reset. Select the source using the mixer control register 1Ch.

4. Program input volume register B4h.



5. Program direction and type: registers B8h, and A8h:

Register B8h: set bit 3 high to program the CODEC for the ADC direction. Set bit 2 low for Normal DMA mode, high for Auto-Initialize DMA mode.

At this point the direction of the analog circuits is ADC rather than DAC. Unless the recording monitor is enabled, there will be no output from AOUT\_L or AOUT\_R until the direction is restored to DAC.

Register A8h: read this register first to preserve the bits and modify only bits 3, 1, and 0:

Bits 1:0 10: Mono

Bits 1:0 01: Stereo

Bit 3 0: Disable Record Monitor for now

Register B9h:

- Bits 1:0 00: Single Transfer DMA
- Bits 1:0 01: Demand Transfer: 2 bytes per DMA request

2 bytes per DiviA request

- Bits 1:0 11: Demand Transfer: 4 bytes per DMA request
- Clocks and counters: registers A1h, A2h, A4h and A5h: Register A1h: Sample Rate Clock Divider. Set bit 7 high for sample rates greater than 22 kHz.

Register A2h: Filter Clock Divider.

Registers A4h/A5h: Audio 1 Transfer Count Reload register low/high, two's complement

- 7. Delay 300 milliseconds to allow analog circuits to settle.
- 8. Enable Record Monitor if desired:

Register A8h bit 3 = 1: Enable Record Monitor (optional).

 Initialize and configure ADC: register B7h. See Table 18. The first command sent to register B7h initializes the DAC and prevents pops.

Register B7h: programs the FIFO (16-bit/8-bit, signed/ unsigned, stereo/mono).

| Table 18 | Command | Sequence | for | DMA | Record |
|----------|---------|----------|-----|-----|--------|
|----------|---------|----------|-----|-----|--------|

| Mono | Stereo | 8-bits | 16-bits | Unsigned | Signed | Sequence                        |
|------|--------|--------|---------|----------|--------|---------------------------------|
| Х    |        | Х      |         | Х        |        | Reg B7h = 51h,<br>Reg B7h = D0h |
| X    |        | Х      |         |          | Х      | Reg B7h = 71h,<br>Reg B7h = F0h |
| X    |        |        | Х       | Х        |        | Reg B7h = 51h,<br>Reg B7h = D4h |
| X    |        |        | Х       |          | Х      | Reg B7h = 71h,<br>Reg B7h = F4h |
|      | Х      | Х      |         | Х        |        | Reg B7h = 51h,<br>Reg B7h = 98h |
|      | Х      | Х      |         |          | Х      | Reg B7h = 71h,<br>Reg B7h = B8h |
|      | Х      |        | Х       | Х        |        | Reg B7h = 51h,<br>Reg B7h = 9Ch |
|      | Х      |        | Х       |          | Х      | Reg B7h = 71h,<br>Reg B7h = BCh |

10.Enable/select DMA channel and IRQ channel, registers B1h, and B2h:

Register B1h: Interrupt Configuration register. Verify that bits 4 and 6 are high. Clear bits 7 and 5.

Register B2h: DRQ Configuration register: Verify that bits 4 and 6 are high. Clear bits 7 and 5.

- 11. Configure system interrupt controller and DMA controller.
- 12.To start DMA:

Set bit 0 of register B8h high. Leave other bits unchanged.

13. During DMA

For Auto-Initialize transfers, do not send any commands to the Solo-1 at interrupt time, except for reading SBBase+Eh to clear the interrupt request.

For Normal mode, initialize the system DMA controller with the address and count of the next block to transfer. Update the Solo-1 Transfer Count registers if the count is changed. To start the next transfer, clear bit 0 of register B8h, then set it high again.

To stop a DMA transaction in progress, clear bit 0 of register B8h. To stop a DMA transaction after the current auto-initialize block is finished, clear bit 2 of register B8h, wait for the interrupt, and then clear bit 0 of register B8h.

14.After DMA is finished:

Restore the system interrupt controller and DMA controller to their idle state.



15. Finally:

Issue another software reset to the Solo-1 to initialize the appropriate registers. This returns the Solo-1 to the DAC direction and turns off the record monitor.

#### Extended Mode Programmed I/O Operation

The REP OUTSB instruction of the 80x86 family transfers data from memory to an I/O port specified by the DX register. The REP INSB instruction is the complementary function. Use Solo-1 port SBBase+Fh for block transfers.

I/O transfers to FIFO are nearly identical to the DMA process, except that an I/O access to port SBBase+Fh replaces the DMA cycle. Some differences are described here.

To program in this mode it is useful to understand how the FIFO Half-Empty flag generates an interrupt request. An interrupt request is generated on the rising edge of the FIFO Half-Empty flag. This flag can be polled by reading port SBBase+Ch. The meaning of this flag depends on the direction of the transfer:

DAC FIFOHE flag is set high if 0-127 bytes in FIFO

ADC FIFOHE flag is set high if 128-256 bytes in FIFO

Therefore, for DAC operations, an interrupt request is generated when the number of bytes in the FIFO changes from >= 128 to < 128. This indicates to the system processor that 128 bytes can be safely transferred without over-filling the FIFO. Before the first interrupt can be generated, the FIFO needs to be primed, or filled, with more than 128 bytes. Keep in mind that data may be taken out of the FIFO while it is being filled by the system processor. If that is the case, there may never be >= 128 bytes in the FIFO unless somewhat more than 128 bytes is transferred. Polling the Solo-1 FIFOHE flag to be sure it goes low in the interrupt handler (or when priming the FIFO) and perhaps sending a second block of 128 bytes is a solution to this problem.

For ADC, the interrupt request is generated when the number of bytes in the FIFO changes from < 128 to >= 128, indicating that the system processor can safely read 128 bytes from the FIFO. Before the first interrupt can be generated, the FIFO should be emptied (or mostly so) by reading from SBBase+Fh and polling the FIFOHE flag. It is not safe to use FIFO reset bit 1 of port SBBase+6h indiscriminately to clear the FIFO, because it may get ADC data out-of-sync.

As in DMA mode, bit 0 of register B8h enables transfers between the system and the FIFO inside the Solo-1.

**NOTE:** The Solo-1 is designed for I/O block transfer up to a ISA bus speed of 8.33 MHz.

#### Programmed I/O DAC Operation

Programmed I/O DAC operation is done just as explained under "Extended Mode Audio 1 DAC Operation" on page 40 with the following exceptions:

- In step 3, programming register B9h is unnecessary.
- In step 6, leave bits 7:5 of register B2h low. Set bit 5 of register B1h high to enable an interrupt on FIFO half-empty transitions. Keep bit 6 of register B1h low.
- In step 8, in addition to setting bit 0 of register B8h high, send the REP OUTSB command.

#### Programmed I/O ADC Operation

Programmed I/O ADC operation is done just as explained under "Extended Mode Audio 1 ADC Operation" on page 41 with the following exceptions:

- In step 3, programming register B9h is unnecessary.
- In step 6, leave bits 7:5 of register B2h low. Set bit 5 of register B1h high to enable an interrupt on FIFO half-empty transitions. Keep bit 6 of register B1h low.
- In step 8, in addition to setting bit 0 of register B8h high, send the REP OUTSB command.

#### Second Audio Channel DAC Operation

Follow the steps below to program the second audio channel for DAC operation.

1. Reset

Write 3h to port SBBase+6h, instead of 1h as in Compatibility mode. Bit 1 high specifically clears the FIFO. The remainder of the software reset is identical to Compatibility mode. On reset the playback mixer volume for the second audio channel is set to zero, register 7Ch. This masks any pops that might occur during the setup process.

2. Program transfer type: mixer register 78h:

Mixer register 78h: set bit 4 low for Normal DMA mode, high for Auto-Initialize DMA mode.

 Clocks and counters: registers 70h, 72h, 74h and 76h: Register 70h: Sample Rate Generator Register 72h: Filter Clock Divider Registers 74h/76h: Audio 2 Transfer Count Reload register low/high, two's complement



4. Initialize and configure DAC: register 7Ah. Register 7Ah:

Bit 2: set high for signed data, low for unsigned.

Bit 1: set high for stereo, low for mono.

Bit 0: set high for 16-bit samples, low for 8-bit.

 Enable IRQ channel, register 7Ah and port IOBase+7h: Register 7Ah: Audio 2 Control 2 register. Bit 6 unmasks channel 2 IRQ.

Port IOBase+7h: IRQ control register. Bit 5 unmasks channel 2 IRQ.

- 6. Program IOBase+0h, IOBase+4h, and IOBase+6h.
- 7. To start DMA:

Set bits 1:0 of register 78h high.

- Delay approximately 100 milliseconds to allow analog circuits to settle, then enable the Audio 2 DAC playback volume, register 7Ch.
- 9. During DMA

For Auto-Initialize transfers, read SBBase+Eh to clear the interrupt request. Do not send any other commands to the Solo-1 at interrupt time.

For Normal mode, initialize IOBase+0h and IOBase+4h with the address and count of the next block to transfer. Update the Solo-1 Transfer Count registers if the count is changed. To start the next transfer, clear bits 1:0 of register 78h, then set the bits high again.

To stop a DMA transaction in progress, clear bit 0 of register B8h. To stop a DMA transaction after the current auto-initialize block is finished, clear bit 4 of register 78h, wait for the interrupt, and then clear bits 1:0 of register 78h.

10. After DMA is finished:

Restore the system interrupt controller and DMA controller to their idle state. Monitor the FIFO Empty status flag in port SBBase+Ch to be sure data transfer is completed. A delay of 25 milliseconds is required to let the filter outputs settle to DC-levels, then disable the Audio 2 DAC input to the mixer.

11. Finally:

Issue another software reset to the Solo-1 to initialize the appropriate registers.

#### Full-Duplex DMA Mode

The Solo-1 supports stereo full-duplex DMA. In full-duplex (FD) mode, a second audio channel has been added to the Solo-1. The second audio channel is programmed through mixer registers.

- Program the first audio channel as in "Extended Mode Audio 1 ADC Operation" on page 41. Extended mode registers A1h and A2h define the sample rate and filter frequency for both record and playback. In other words, the record and playback must be at the same sample rate (synchronous).
- 2. Program the second audio channel. Mixer registers 74h and 76h are set to the two's complement DMA transfer count. The second audio channel supports both Auto-Initialize and Normal modes. The playback buffer in system memory does not have to be the same size as the record buffer. When the DMA transfer count rolls over to zero, it can generate an interrupt that is independent of the interrupt generated by the first audio channel.

If the record and playback buffers are the same size, then a single interrupt can be used. Program the DMA Transfer Count Reload registers (A4h, A5h, 74h, and 76h) are programmed with the same value for both channels. Enable the second audio channel before enabling the record channel. For example, assume there are two halfbuffers in a circular buffer. When the record channel completes filling the first half, it generates an interrupt. To ensure that the playback channel is not accessing the first half at the time of the interrupt, start the playback channel first. It has a 32-word FIFO that fills quickly through DMA.

The recommended method is as follows:

Program both DMA controllers for Auto-Initialize DMA within separate circular buffers of the same size, N.

To exit full-duplex mode, clear bits 0 and 1 of mixer register 78h.

1. Reset

Write 3h to port SBBase+6h, instead of 1h as in Compatibility mode. Bit 1 high specifically clears the FIFO. The remainder of the software reset is identical to Compatibility mode. Reset disables the Audio 1 DAC input to the mixer. This masks any pops created during the setup of the DMA transfer.

2. After the reset, send command C6h to enable Extended mode commands.



3. Program direction and type: registers B8h, A8h, and B9h:

Register B8h: set bit 2 high for Auto-Initialize DMA mode. Leave bit 3 low to program the CODEC for the DAC direction.

Register A8h: read this register first to preserve the bits and modify only bits 3, 1, and 0:

Bits 1:0 10: Mono

Register B9h:

- Bits 1:0 00: Single Transfer DMA
- Bits 1:0 01: Demand Transfer DMA: 2 bytes per DMA request.

Bits 1:0 10: Demand transfer DMA: 4 bytes per DMA request.

- Clocks and counters: registers A1h, A2h, A4h and A5h: Register A1h: Sample Rate Clock Divider Register A2h: Filter Clock Divider Registers A4h/A5h: DMA Counter Reload register low/high, two's complement
- 5. Initialize and configure DAC: registers B6h and B7h.

Register B6h: 80h for signed data and 00h for unsigned data. This also initializes the CODEC for DAC transfer.

Register B7h: set the data format for 16-bit mono. See Table 17, "Command Sequences for DMA Playback" on page 41.

- Program transfer type: register 78h: Register 78h: set bit 4 high for Auto-Initialize DMA mode.
- Clocks and counters: registers 70h, 72h, 74h and 76h: Set the sample rate the same as in A1h. Set the Transfer Count Reload to 64 bytes.

Register 70h: Sample Rate Generator Register 72h: Filter Clock Divider Registers 74h/76h: Second DMA Transfer Count Reload register low/high, two's complement

- Initialize and configure DAC: register 7Ah. Register 7Ah:
  - Bit 2: set high for signed data, low for unsigned.
  - Bit 1: set low for mono.
  - Bit 0: set high for 16-bit samples.

 Enable IRQ channel, registers 7Ah and B2h: Register 7Ah: Audio 2 Control 2 register. Bit 6 unmasks channel 2 IRQ.

Register B2h: DRQ Configuration register. Make sure bits 4 and 6 are high. Clear bits 7 and 5.

- 10. Set bit 0 of register 78h. Since the playback FIFO is presumably empty, the value zero is transferred to the playback DAC at each sample clock. A click or pop may be heard when full-duplex is enabled. To prevent this, use command D1h to enable the Audio 1 DAC input to the mixer after a suitable delay of 25 milliseconds.
- 11. Enable playback DMA by setting bit 1 of register 78h. After 64 bytes are transferred, bit 7 of 7Ah should go high. Poll this bit with a suitable time-out of 10 milliseconds.
- 12. After bit 7 of register 7Ah goes high, enable recording by setting bit 7 of register B7h and bit 0 of register B8h.
- 13.As usual, discard the first 50 to 100 milliseconds of recorded data until analog circuits have settled.

#### Programming the Solo-1 Mixer

The Solo-1 has a set of mixer registers that is backward compatible with the Sound Blaster Pro. However, some of the registers can be accessed in an "extended" or "alternate" way, providing for greater functionality.

#### Writing and Reading Data from the Mixer Registers

There are two I/O addresses used by the mixer: SBBase+4h is the address port; SBBase+5h is the data port. In the Sound Blaster Pro, SBBase+4h is write only, while SBBase+5h is read/write.

#### Writing Data to the Solo-1 Mixer Registers

To set a mixer register, write its address to SBBase+4h, then write the data to SBBase+5h.

#### Reading Data from the Solo-1 Mixer Registers

To read the register, write its address to SBBase+4h, then read the data from SBBase+5h.

#### **Resetting the Mixer Registers**

The mixer registers are not affected by software reset. To reset the registers to initial conditions, write any value to mixer register 00h:

- 1. Write 00h to SBBase+4h (select mixer register to 00h).
- Write 00h to SBBase+5h (write 00h to the selected mixer register).

#### Extended Access to SB Pro Mixer Volume Controls

The Sound Blaster Pro Mixer Volume controls are mostly 3 bits per channel. See the Sound Blaster Compatibility register 04h in Table 24 for details. Bits 0 and 4 are always high when read. The Solo-1 offers an alternate way to write each mixer register. Use the "extended access" registers for volume control of 4 bits per channel. If the Sound Blaster Pro compatible interface is used, bits 0 and 4 are cleared by a write and forced high on all reads. See Table 19 for a list of Sound Blaster Pro registers and the extended access counterparts.

| Table 19 | Sound Blaster Pro/Extended Access Registers |
|----------|---------------------------------------------|
|----------|---------------------------------------------|

| Register | Function        | Extended Access Register<br>for 4 bits/Channel |
|----------|-----------------|------------------------------------------------|
| 04h      | Voice volume    | 14h                                            |
| 22h      | Master volume   | 32h                                            |
| 26h      | FM volume       | 36h                                            |
| 28h      | CD (Aux) volume | 38h                                            |
| 2Eh      | Line volume     | 3Eh                                            |

For example, if you write 00h to Sound Blaster Pro register 04h, you will read back 11h because bits 0 and 4 are "stuck high" on reads. Inside the register, these bits are "stuck low," so that writing 00h is the same as writing 11h.

A write or read to address 14h instead of 04h allows direct access to all 8 bits of this mixer register.

#### **Extended Access to Mic Mix Volume**

If Sound Blaster Compatibility mode register address 0Ah is used to control Mic Mix Volume, only bits 2 and 1 are significant. Bit 0 is stuck high on reads and stuck low on writes. Since this is a mono control, panning is not supported.

For extended access, use register address 1Ah instead. Register 1Ah offers 4 bits-per-channel for pan control of the mono microphone input to the mixer.

| Mic Mix Volume      |   |   |   |   |            | (1Ah     | , R/W) |
|---------------------|---|---|---|---|------------|----------|--------|
| Mic mix volume left |   |   |   | Ν | 1ic mix vo | lume rig | ht     |
| 7                   | 6 | 5 | 4 | 3 | 2          | 1        | 0      |

Access to register 1Ah through address 0Ah is mapped as follows:

| Write to 0Ah | D2=0, D1=0                         | Mic mix volume = 00h |  |  |
|--------------|------------------------------------|----------------------|--|--|
|              | D2=0, D1=1                         | Mic mix volume = 55h |  |  |
|              | D2=1, D1=0                         | Mic mix volume = AAh |  |  |
|              | D2=1, D1=1                         | Mic mix volume = FFh |  |  |
| Read from    | D2 = Mic Mix Volume register bit 3 |                      |  |  |
| 0Ah          | D1 = Mic Mix Volume register bit 2 |                      |  |  |
|              | D0 = 1                             |                      |  |  |
|              | others are undefined.              |                      |  |  |

#### Extended Access to ADC Source Select

In Sound Blaster Compatibility mode in the Sound Blaster Pro mixer, there are three choices for recording source, set by bits 2 and 1 of mixer register 0Ch. Note that bit 0 is set to zero upon any write to 0Ch and set to one upon any read from 0Ch:

| D2 | D1 | Source Selected      |
|----|----|----------------------|
| 0  | 0  | Microphone (default) |
| 0  | 1  | CD (Aux) input       |
| 1  | 0  | Microphone           |
| 1  | 1  | Line input           |

For extended access, use register address 1Ch to select recording from the mixer as follows:

| D2 | D1 | D0 | Source Selected                                                                                                         |
|----|----|----|-------------------------------------------------------------------------------------------------------------------------|
| х  | 0  | х  | Microphone (default)                                                                                                    |
| 0  | 1  | х  | CD (Aux) input                                                                                                          |
| 1  | 1  | 0  | Line input                                                                                                              |
| 1  | 1  | 1  | Mixer * (Bits 4:3 of Mixer register 7Ah deter-<br>mine if the mixer input source is the play-<br>back or record mixer). |

#### **Sound Blaster Pro Volume Emulation**

Sound Blaster Pro emulations for master volume means that the 6-bit volume counters can be written through 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 20 | SB Pro Read Volume Emulation |  |
|----------|------------------------------|--|
|----------|------------------------------|--|

| Mute | Master Volume | Value Read<br>at 32h | Value Read<br>at 22h |
|------|---------------|----------------------|----------------------|
| 1    | xx            | 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 causes both left and right channels to be 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) causes both left and right master volume registers to be changed as follows:

Table 21 SB Pro Write Volume Emulation

| 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           |



#### **Record and Playback Mixer**

The Solo-1 has stereo mixers for playback and record. Each stereo mixer has eight input sources, each with independent 4-bit left and right volume controls. For each 4-bit volume control, level 0 is mute and level 15 is maximum volume. The Solo-1 mixers use a dual slope method for selecting volume. Each increase of one step in volume from settings 1 to 8 results in a +3 dB increase. Each increase of one step in volume from settings 8 to 15 results in a +1.5 dB increase.

|                | Volume in Decibels (dB) |                        |                   |                                    |  |  |  |
|----------------|-------------------------|------------------------|-------------------|------------------------------------|--|--|--|
| 4-Bit<br>Value | Audio 1ª<br>(Record)    | Audio 2⁵<br>(Playback) | Mic,<br>Music DAC | AuxA,<br>AuxB,<br>Line,<br>Mono-In |  |  |  |
| 15             | +1.5                    | 0                      | +10.5             | +3.0                               |  |  |  |
| 14             | 0                       | -1.5                   | +9.0              | +1.5                               |  |  |  |
| 13             | -1.5                    | -3.0                   | +7.5              | 0                                  |  |  |  |
| 12             | -3.0                    | -4.5                   | +6.0              | -1.5                               |  |  |  |
| 11             | -4.5                    | -6.0                   | +4.5              | -3.0                               |  |  |  |
| 10             | -6.0                    | -7.5                   | +3.0              | -4.5                               |  |  |  |
| 9              | -7.5                    | -9.0                   | +1.5              | -6.0                               |  |  |  |
| 8              | -9.0                    | -10.5                  | 0                 | -7.5                               |  |  |  |
| 7              | -12.0                   | -13.5                  | -3.0              | -10.5                              |  |  |  |
| 6              | -15.0                   | -16.5                  | -6.0              | -13.5                              |  |  |  |
| 5              | -18.0                   | -19.5                  | -9.0              | -16.5                              |  |  |  |
| 4              | -21.0                   | -22.5                  | -12.0             | -19.5                              |  |  |  |
| 3              | -24.0                   | -25.5                  | -15.0             | -22.5                              |  |  |  |
| 2              | -27.0                   | -28.5                  | -18.0             | -25.5                              |  |  |  |
| 1              | -30.0                   | -31.5                  | -21.0             | -28.5                              |  |  |  |
| 0              | mute                    | mute                   | mute              | mute                               |  |  |  |

a. Audio 1 DAC mixer input is gated by the Sound Blaster "Speaker On" control. This control bit is toggled by the D1 (on) and D3 (off) Sound Blaster commands.

b. In Telegaming mode (enabled by bit 0 of mixer register 48h when in Serial mode), the audio 2 DAC mixer input volume is slaved to the audio 1 DAC mixer input volume.

#### Table 23 Mixer Input Volume Registers

| Mixer Input                    | Playback Volume<br>Register | Record Volume<br>Register |
|--------------------------------|-----------------------------|---------------------------|
| Audio 1                        | 14h                         | -                         |
| Audio 2                        | 7Ch                         | 69h                       |
| Microphone                     | 1Ah                         | 68h                       |
| Music DAC (FM/<br>ES689/ES69x) | 36h                         | 6Bh                       |
| AuxA (CD)                      | 38h                         | 6Ah                       |
| AuxB                           | 3Ah                         | 6Ch                       |
| Line                           | 3Eh                         | 6Eh                       |
| Mono In                        | 6Dh                         | 6Fh                       |

REGISTERS



# REGISTERS

#### **Register Types**

#### **Types of Register Access**

There are two types of audio registers in the Solo-1:

• Mixer registers (00h – 7Fh).

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

• Controller registers (A0h – BFh).

These registers are used to control Extended mode DMA playback and record through the first audio channel. Controller registers are accessed through an extension to the Sound Blaster common interface. This interface uses I/O ports SBBase+Ah, SBBase+Ch, and SBBase+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 are fully compatible with the Sound Blaster Pro. ESS mixer registers are specific to ESS Technology, Inc. Solo-1 *Audio*Drive® chips, although many registers are shared throughout the *Audio*Drive® family of chips.

#### Sound Blaster Pro Compatible Mixer Registers

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

| Reg | D7  | D6                    | D5     | D4        | D3                     | D2                  | D1      | D0               | Description          |
|-----|-----|-----------------------|--------|-----------|------------------------|---------------------|---------|------------------|----------------------|
| 00h |     | •                     |        | Write: re | eset mixer             |                     | •       |                  | Mixer reset          |
| 04h | DA  | C play volum          | e left | Х         | DAC                    | play volume         | e right | Х                | DAC playback volume  |
| 0Ah | Х   | Х                     | Х      | Х         | Х                      | X Mic mix volume    |         | Х                | Mic mix volume       |
| 0Ch | Х   | Х                     | F1 *   | Х         | F0 *                   | F0 * ADC source     |         | Х                | See note for F0, F1. |
| 0Eh | Х   | Х                     | F2 *   | Х         | Х                      | Х                   | Stereo  | Х                | See note for F2.     |
| 22h | М   | Master volume left    |        | Х         | Mas                    | Master volume right |         | Х                | Master volume        |
| 26h |     | FM volume left        |        | Х         | FM volume right        |                     | Х       | Music DAC volume |                      |
| 28h | Aux | AuxA (CD) volume left |        | Х         | AuxA (CD) volume right |                     | Х       | AuxA (CD) volume |                      |
| 2Eh | I   | Line volume left      |        | Х         | Lir                    | ne volume rig       | ght     | Х                | Line volume          |

Table 24 Sound Blaster Compatibility Register Summary

\* Sound Blaster Filter Control bits F2, F1, and F0 have no equivalent function in the Solo-1 and are ignored.

#### **Filter Control Bits**

The Sound Blaster Pro mixer has three bits that control input and output filters. They are labeled F0, F1, and F2 in Table 24 and Table 25. They have no equivalent function in the Solo-1 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. In this case, 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 36.



#### **ESS Mixer Registers**

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

# Table 25 ESS Mixer Registers Summary

| Reg         D7         D6         D5         D4         D3         D2         D1         D0         Remark           00h         Write: reset mixer         Audio 1 play volume right         Audio 1 play volume right         Audio 1 play volume right         Mader Jplay volume right         Mader Volume         Master volume right         Master volume right         Master volume right         Master volume right         AuxA (CD) volume left         AuxA (CD) volume right         AuxA (CD) volume right         AuxA (CD) volume right         AuxA (CD) volume         AuxA (CD) volu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|
| 14h     Audio 1 play volume left     Audio 1 play volume right     Audio 1 play volume right     Audio 1 play volume right       1Ah     Mic mix volume left     Mic mix volume right     Mic mix volume right     Mic mix volume       1Ch     x     x     F1     Mute     F0     Extended record source       32h     Master volume left     Master volume right     Master volume       36h     FM volume left     AuxA (CD) volume right     AuxA (CD) volume       38h     AuxA (CD) volume left     AuxA (CD) volume right     AuxA (CD) volume       36h     FM volume left     AuxA (CD) volume right     AuxA (CD) volume       36h     AuxA (CD) volume left     AuxA (CD) volume right     AuxA (CD) volume       36h     Line volume left     Line volume right     AuxB volume       37h     Master     AuxB volume left     Line volume right     Line volume       37h     Master     Record Source Select     Record Level     Serial mode output       42h     Varme     Serial mode output select     Master volume     Serial mode output       48h     x     E Es68g/<br>ES69x     x     Serial mode output     Serial mode output       50h     0     0     0     1:Enable<br>ES68g/<br>ES69x     0:Reset     1:Mono<br>mode     0     Spatializer test                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              |
| 1Ah       Mic mix volume left       Mic mix volume right       Mic mix volume         1Ch       x       x       F1       Mute       F0       Extended record source         32h       Master volume left       Master volume right       Master volume       Master volume         36h       FM volume left       AuxA (CD) volume right       AuxA (CD) volume       FM volume         3Ah       AuxA (CD) volume left       AuxA (CD) volume right       AuxA (CD) volume       AuxA (CD) volume         3Ch       PC speaker volume       PC speaker volume       PC speaker volume       PC speaker volume         3Eh       Line volume left       Line volume right       Line volume       Errable         42h       Input<br>override       Record Source Select       Record Level       Serial mode output         44h       volume<br>override       Serial mode output select       Master volume       Serial mode output         48h       x       Enable<br>ES889/<br>ES69x       x       Serial mode output       Serial mode output         52h       0       0       0       1:Enable<br>Spatializer level       Spatializer level       Spatializer level         5Ch       L/R state<br>ffag       Signal<br>proc test<br>mode       ADC test<br>mode       1:Acc<br>mode       Reserved       Spatia                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ime          |
| 1Ch       x       x       F1       Mute       F0       Extended record source         32h       Master volume left       Master volume right       Master volume right       Master volume         38h       AuxA (CD) volume left       FM volume right       FM volume right       AuxA (CD) volume         38h       AuxA (CD) volume left       AuxA (CD) volume right       AuxA (CD) volume       AuxA (CD) volume         36h       FM volume left       AuxB volume right       AuxA (CD) volume       AuxA Volume         36h       AuxB volume left       AuxB volume right       AuxA Volume       PC speaker volume       PC speaker volume         36h       Line volume left       Line volume left       Line volume right       Line volume       Enable         42h       Input volume left       Record Source Select       Record Level       Serial mode output         44h       Waster volume       Serial mode output select       Master volume       Serial mode output         44h       Volume volume left       x       Enable ES689/<br>ES689/<br>inftc       x       Serial mode output       Serial mode output         52h       0       0       1: Acc       Reserved       Spatializer level       Spatializer level         5Ch       L/R state figag       Si                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |              |
| 32h       Master volume left       Master volume right       Master volume right       Master volume         36h       FM volume left       FM volume right       FM volume right       AuxA (CD) volume         38h       AuxA (CD) volume left       AuxA (CD) volume right       AuxA (CD) volume       AuxA (CD) volume         3Ah       AuxB volume left       AuxB volume right       AuxB volume       PC speaker volume       PC speaker volume         3Eh       Line volume left       Line volume right       Line volume       PC speaker volume       PC speaker volume         42h       Input<br>override       Record Source Select       Record Level       Serial mode input         44h       voerride       Serial mode output select       Master volume       Serial mode output select       Master volume         50h       0       0       0       0       1:Enable<br>ES689/<br>intfc       1:Anon<br>mode       0       Spatializer enable         52h       0       0       0       0       Spatializer level       Spatializer level       Spatializer level         52h       0       0       1:ACC mode       1:ACC mode       Inming       Spatializer level       Spatializer level         52h       0       1:Mute       Left master volume       Left master volu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |              |
| 36h     FM volume left     FM volume right     FM volume right       38h     AuxA (CD) volume left     AuxA (CD) volume right     AuxA (CD) volume       3Ah     AuxB volume left     AuxA (CD) volume right     AuxB volume       3Ch     PC speaker volume     PC speaker volume     PC speaker volume       3Eh     Input<br>override     Record Source Select     Record Level     Serial mode input<br>volume       42h     Input<br>override     Serial mode output select     Master volume     Serial mode output<br>Serial mode output<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689 |              |
| 38h       AuxA (CD) volume left       AuxA (CD) volume right       AuxA (CD) volume         3Ah       AuxB volume left       AuxB volume right       AuxB volume         3Ch       PC speaker volume       PC speaker volume       PC speaker volume         3Eh       Line volume left       Line volume right       Line volume       PC speaker volume         42h       Input<br>override       Record Source Select       Record Level       Serial mode output         44h       volume<br>override       Serial mode output select       Master volume       Serial mode output         48h       x       Es689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>ES689/<br>E                                                                                                                                                                   |              |
| 3Ah     AuxB volume left     AuxB volume right     AuxB volume       3Ch     PC speaker volume     PC speaker volume     PC speaker volume       3Eh     Line volume left     Line volume right     Line volume       42h     override<br>override     Record Source Select     Record Level     Serial mode output       44h     Master<br>volume<br>override     Serial mode output select     Master volume     Serial mode output       48h     X     Enable<br>ES689/<br>ES698/<br>intfc     X     Serial mode output       50h     0     0     0     1:Enable<br>Spatializer     0:Reset     1:Mono<br>mode     0     Spatializer enable<br>control       52h     0     0     0     1:Enable<br>proc test<br>mode     1:Acc<br>mode     0:Reset     1:Mono<br>mode     0     Spatializer level       5Ch     L/R state<br>flag     Signal<br>proc test<br>mode     ADC test<br>mode     1:Acc<br>timing     Reserved     Spatializer test of<br>control     Spatializer test of<br>control       61h     0     1:Mute     Left master volume<br>Right master volume counter     Right master volume<br>counter     Right master volume<br>counter       63h     0     1:Mute     Read-only<br>Hardware volum<br>counter     Master volum<br>counter     Opamp cal-<br>libration     Opamp cal-<br>pro master<br>vol control     Opamp cal-<br>libration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 10           |
| 3Ch       PC speaker volume       PC speaker volume       PC speaker volume         3Eh       Line volume left       Line volume right       Line volume         42h       Input<br>override       Record Source Select       Record Level       Serial mode input<br>serial mode output select         44h       volume<br>override       Serial mode output select       Master volume       Serial mode output<br>serial mode output<br>ES689/<br>ES689/<br>initic       x       Serial mode output<br>Serial mode cont         50h       0       0       0       0       1:Enable<br>Spatializer       v       Serial mode cont         50h       0       0       0       0       Spatializer       0:Reset       1:Mono<br>mode       0       Spatializer level         52h       0       0       0       Spatializer level       Spatializer level       Spatializer level       Spatializer level         5Ch       L/R state<br>flag       Signal<br>proc test<br>mode       ADC test<br>mode       1: Acc<br>timing       Reserved       Spatializer test of<br>counter       Spatializer test of<br>counter         62h       0       1:Mute       Left master volume counter       Left master volume       Hardware volum<br>counter         63h       0       1:Mute       Read-only<br>HMV int<br>mode       Mode       HMV<br>int mask       Disable SB<br>Pro master<br>v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |              |
| 3Eh       Line volume left       Line volume right       Line volume right       Line volume         42h       Input<br>override       Record Source Select       Record Level       Serial mode input         44h       Waster<br>volume<br>override       Serial mode output select       Master volume       Serial mode output         48h       x       Enable<br>ES689/<br>ES69x       x       Serial mode output       Serial mode output         50h       0       0       0       0       Serial mode output       Serial mode output         50h       0       0       0       1:Enable<br>Spatializer       v       Serial mode output         52h       0       0       0       Spatializer       0:Reset       1:Mono<br>mode       0       Spatializer level         52h       0       0       1:ACC<br>mode       1:Acc<br>timing       Reserved       Spatializer level       Spatializer level         52h       0       1:Mute       Left volume counter       Spatializer level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | me           |
| 42h       Input<br>override       Record Source Select       Record Level       Serial mode input         44h       Master<br>volume<br>override       Serial mode output select       Master volume       Serial mode output         48h       X       Enable<br>ES689/<br>ES689/<br>Shift       X       Serial mode output       Serial mode output         50h       0       0       0       0       Spatializer       0:Reset       1:Mono<br>mode       0       Spatializer level         52h       0       0       0       0       Spatializer       0:Reset       1:Mono<br>mode       0       Spatializer level         52h       0       0       1:Acc<br>mode       Spatializer level       Spatializer level </td <td></td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |              |
| 44h       volume<br>override       Serial mode output select       Master volume       Serial mode output         48h       X       X       Enable<br>ES689/<br>ES69x       X       Serial mode output         50h       0       0       0       0       Spatializer       0:Reset       1:Mono<br>mode       0       Spatializer level       Spatializer level         52h       0       0       0       0       1:Enable<br>Spatializer       0:Reset       1:Mono<br>mode       0       Spatializer level       Spatializer level         5Ch       L/R state<br>flag       Signal<br>proc test<br>mode       ADC test<br>mode       1: Acc<br>timing       Reserved       Spatializer test of<br>Spatializer test of<br>Left master volume       Spatializer test of<br>counter       Spatializer test of<br>counter       Spatializer test of<br>counter         61h       0       1:Mute       Left volume counter       Right master volume<br>counter       Right master volume<br>counter       Right master volume<br>counter       Right master volume<br>counter         63h       0       1:Mute       1:Count<br>mode       Read-only<br>HMV int<br>request       Mode       HMV<br>int mask       Disable SB<br>Pro master<br>vol control<br>ibration       Master volume<br>counter         63h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | t control    |
| 48h $\cdot$ x $ES689/ES69x$<br>inffcxSerial mode consistence50h0000 $1$ :Enable<br>Spatializer $0:Reset$ $1:Monomode0Spatializer enablecontrol52h00001:EnableSpatializer level0:Reset1:Monomode0Spatializer enablecontrol52h0001:EnableSpatializer level0:Reset1:Monomode0Spatializer level5ChL/R stateflagSignalproc testmodeADC testmode1:AcctimingReservedSpatializer testSpatializer test5Eh     -Spatializer testSpatializer test60h01:Mute     -Spatializer test62h01:Mute      -63h01:Mute      -64h1:SplitmodeMPU-401int mask1:Countby 3      -65h          -66h         -66h        -$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | out control  |
| S0II       0       0       0       Spatializer       0.Reset       mode       0       control         52h       0       0       0       Spatializer level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | rol          |
| 5Ch       L/R state<br>flag       Signal<br>proc test<br>mode       ADC test<br>mode       1: Acc<br>timing       Reserved       Spatializer test of         5Eh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | e and mode   |
| 5Ch       L'N state<br>flag       proc test<br>mode       ADC test<br>mode       1. ACC<br>timing       Reserved       Spatializer test of<br>Spatializer test of<br>Spatialitest of<br>Spatializer test of<br>Spatializer test of<br>Spatializer test o                            |              |
| 60h       0       1:Mute       Left master volume       Left master volume         61h       0       1:Mute       Left volume counter       Hardware volum counter         62h       0       1:Mute       Right master volume       Right master volume         63h       0       1:Mute       Right master volume counter       Hardware volume counter         63h       0       1:Mute       Right volume counter       Hardware volume counter         64h       1:Split mode       MPU-401 int mask       1:Count by 3       Read-only HMV int request       Mode       HMV int mask       Disable SB Pro master vol control       Master volume counter         65h           Clear hardware volume interrupt request       Opamp calibration         66h             Opamp calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ontrol       |
| 61h       0       1:Mute       Left volume counter       Hardware volum counter         62h       0       1:Mute       Right master volume       Right master volume       Right master volume         63h       0       1:Mute       Right master volume counter       Hardware volum counter       Hardware volum counter         63h       0       1:Mute       Read-only HMV int request       Mode       HMV int mask       Disable SB Pro master vol control       Master volume counter         64h       1:Split mode       MPU-401 int mask       1:Count by 3       Read-only HMV int request       Mode       HMV int mask       Disable SB Pro master vol control       Master volume control         65h       Image: Clear hardware volume interrupt request       Image: Clear hardware volume interrupt request       Write-only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ata          |
| 61n       0       1:Mute       Left volume counter       counter         62h       0       1:Mute       Right master volume       Right master volume         63h       0       1:Mute       Right volume counter       Hardware volum counter         63h       0       1:Mute       Right volume counter       Hardware volum counter         64h       1:Split mode       MPU-401 int mask       1:Count by 3       Read-only HMV int request       Mode       HMV int mask       Disable SB Pro master vol control       Master volume counter         65h       65h       Clear hardware volume interrupt request       Opamp calibration       Opamp calibration       Opamp calibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ne and mute  |
| 63h       0       1:Mute       Read-only       Hardware volume counter       Hardware volume counter         64h       1:Split mode       MPU-401 int mask       1:Count by 3       Read-only       Mode       HMV int mask       Disable SB Pro master volume counter       Master volume counter         65h       65h       Image: Clear hardware volume interrupt request       Opamp cal-ibration       Opamp cal-ibration       Opamp cal-ibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | e control    |
| 63h     0     1:Mute     Right volume counter     counter       64h     1:Split<br>mode     MPU-401<br>int mask     1:Count<br>by 3     Read-only<br>HMV int<br>request     Mode     HMV<br>int mask     Disable SB<br>Pro master<br>vol control     Master volume of<br>Opamp cal-<br>ibration       65h     66h     Clear hardware volume interrupt request     Vite-only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ume and mute |
| 64h     T:Split<br>mode     MPO-401<br>int mask     T:Count<br>by 3     HMV int<br>request     Mode     HMV<br>int mask     Pro master<br>vol control     Master volume of<br>Master volume of<br>ibration       65h     66h     Clear hardware volume interrupt request     Opamp cal-<br>ibration     Opamp cal-<br>ibration     Opamp cal-<br>ibration     Opamp cal-<br>ibration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | e control    |
| 66h     Clear hardware volume interrupt request     Write-only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ontrol       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | n control    |
| 68h Mic record volume left Mic record volume right Mic record volum                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ie           |
| 69h         Audio 2 record volume left         Audio 2 record volume right         Audio 2 record v                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | olume        |
| 6Ah AuxA (CD) record volume left AuxA (CD) record volume right AuxA (CD) record volume right                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              |
| 6Bh Music DAC record volume left Music DAC record volume right Music DAC reco                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | d volume     |
| 6Ch AuxB record volume left AuxB record volume right AuxB record volume                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ime          |
| 6Dh Left Mono_In play mix Right Mono_In play mix Mono_In play mi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | x            |
| 6Eh Line record volume left Line record volume right Line record volume                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ne           |
| 6Fh Mono_In record volume left Mono_In record volume right Mono_In record                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | volume       |
| 70h     Master<br>clock     Two's complement rate divider     Audio 2 sample                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ate          |
| 71h     0     0     1:New reg<br>A1h     1:4x mode     1:SCF2<br>bypass     1:SCF1     1:Async<br>mode     1:FM mix     Audio 2 mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |              |
| 72h         Two's complement filter rate divider         Audio 2 filter close                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | k rate       |

REGISTERS



# Table 25 ESS Mixer Registers Summary (Continued)

| Reg | D7                   | D6       | D5                                  | D4                     | D3                          | D2                                            | D1                                 | D0                                  | Remark               |
|-----|----------------------|----------|-------------------------------------|------------------------|-----------------------------|-----------------------------------------------|------------------------------------|-------------------------------------|----------------------|
| 74h |                      |          | Audio 2 transfer count reload       |                        |                             |                                               |                                    |                                     |                      |
| 76h |                      |          | Two's co                            | mplement tra           | insfer count -              | - high byte                                   |                                    |                                     |                      |
| 78h | 0                    | 0        | 0                                   | 1: Auto-<br>initialize | 0                           | 0                                             | Enable<br>second<br>channel<br>DMA | Enable<br>FIFO to 2nd<br>chan DAC   | Audio 2 control 1    |
| 7Ah | 2nd chan-<br>nel IRQ | IRQ mask | 0                                   | 0                      | 0                           | Data sign                                     | Stereo<br>/Mono                    | 16-bit<br>/8-bit                    | Audio 2 control 2    |
| 7Ch | Left channel volume  |          |                                     |                        | Right char                  | nel volume                                    | Audio 2 DAC mixer volume           |                                     |                      |
| 7Dh | 0                    | 0        | 0                                   | 0                      | Enable<br>+26 dB<br>mic amp | 6 dB Mono_Out source Mono_In<br>select mix w/ |                                    | Mic preamp, Mono_In and<br>Mono_Out |                      |
| 7Fh |                      | Reserved | Reserved Music<br>digital<br>record |                        |                             | x                                             |                                    |                                     | Music digital record |



REGISTERS

# Wite: reset mixer (00h, W) 7 6 5 4 3 2 1 0

| Audio | 1 Play V    | Volume | 9    |     |            | (14)   | h, R <b>/W)</b> |
|-------|-------------|--------|------|-----|------------|--------|-----------------|
| Au    | idio 1 play | volume | left | Aud | dio 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 Miz | x Volun    | ne        |    |                      |   | (1AI | h, <b>R/W)</b> |
|---------|------------|-----------|----|----------------------|---|------|----------------|
| ١       | Mic mix vo | olume lef | ťt | Mic mix volume right |   |      |                |
| 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.

| Exter       | Extended Record Source (1Ch, R/W |                                                                                              |                  |        |         |           |        |  |
|-------------|----------------------------------|----------------------------------------------------------------------------------------------|------------------|--------|---------|-----------|--------|--|
| х           | х                                | F1                                                                                           | Mute             | F0     | Extend  | ed record | source |  |
| 7           | 6                                | 5                                                                                            | 4                | 3      | 2       | 1         | 0      |  |
| Bit De      | efinitions:                      |                                                                                              |                  |        |         |           |        |  |
| <u>Bits</u> | <u>Name</u>                      | Descrip                                                                                      | otion            |        |         |           |        |  |
| 7:6         | -                                | No fund                                                                                      | ction.           |        |         |           |        |  |
| 5           | F1                               | Sound Blaster Filter Control bit F1 has no equivalent function in the Solo-1 and is ignored. |                  |        |         |           |        |  |
| 4           | Mute                             | 1 = Mutes the input to the filters for recording.<br>This does not affect MONO_OUT.          |                  |        |         |           |        |  |
| 3           | F0                               | Sound Blaster Filter Control bit F0 has no equivalent function in the Solo-1 and is ignored. |                  |        |         |           |        |  |
| 2:0         | Extended                         | <u>Bit 2 Bi</u>                                                                              | <u>t 1 Bit 0</u> | Record | d Sourc | <u>e</u>  |        |  |

| Lyrennen |   | שונ |   | Recold Source             |
|----------|---|-----|---|---------------------------|
| record   | 0 | 0   | 0 | Microphone                |
| source   | 0 | 1   | 0 | AuxA (CD)                 |
|          | 1 | 0   | 0 | Microphone                |
|          | 1 | 1   | 0 | Line                      |
|          | 0 | 0   | 1 | Left channel: microphone  |
|          |   |     |   | Right channel: Master vol |
|          |   |     |   | input (L+R)/2 *           |
|          | 0 | 1   | 1 | Left channel: AOUT_L      |
|          |   |     |   | Right channel: AOUT_R     |
|          | 1 | 0   | 1 | Record mixer              |
|          |   |     |   |                           |

1 1 1 Master volume inputs \*

#### Bits Name Description

\* The master volume inputs are the outputs of the Spatializer processor before master volume is applied. However, the design of the Solo-1 causes some attenuation due to master volume in some conditions before the Spatializer. Unless the master volume is at one of the top 7 levels (0 dB, -.75 dB..-4.5 dB), there is -5.25 dB attenuation between the output of the playback mixer and the input to the Spatializer. If the master volume is at one of the top 7 levels, the attenuation according to the master volume level is determined prior to the input of the Spatializer.

#### Master Volume Register

#### (32h, R/W)

|   |   |           | •         |   |                     |   |   |   |  |  |  |
|---|---|-----------|-----------|---|---------------------|---|---|---|--|--|--|
|   | I | Master vo | lume left |   | Master volume right |   |   |   |  |  |  |
| _ | 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 Vo | lume Re | egister |   | (36h, R/W) |         |          |   |  |
|-------|---------|---------|---|------------|---------|----------|---|--|
|       | FM volu | me left |   |            | FM volu | me right |   |  |
| 7     | 6       | 5       | 4 | 3          | 2       | 1        | 0 |  |

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

| AuxA (CD) Volume Register | (38h, R/W) |
|---------------------------|------------|
|---------------------------|------------|

| Au | xA (CD) | volume le | eft | AuxA (CD) volume right |   |   |   |  |
|----|---------|-----------|-----|------------------------|---|---|---|--|
| 7  | 6       | 5         | 4   | 3                      | 2 | 1 | 0 |  |

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

| A | luxB | Volume   | Regist   | er | (3Ah, R/W) |          |          |    |
|---|------|----------|----------|----|------------|----------|----------|----|
|   |      | AuxB vol | ume left |    |            | AuxB vol | ume righ | ıt |
| _ | 7    | 6        | 5        | 4  | 3          | 2        | 1        | 0  |

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

| PC Spe | aker V | (3Ch, R/W) |           |       |   |   |   |
|--------|--------|------------|-----------|-------|---|---|---|
|        | F      | PC sp      | beaker vo | olume |   |   |   |
| 7      | 6      | 5          | 4         | 3     | 2 | 1 | 0 |

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

| Line V | olume F   | Registe  | (3Eh, R/W) |   |           |           |   |
|--------|-----------|----------|------------|---|-----------|-----------|---|
|        | Line volu | ume left |            |   | Line volu | ume right |   |
| 7      | 6         | 5        | 4          | 3 | 2         | 1         | 0 |

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

REGISTERS

PRELIMINARY



| Serial Mode          | Input                    | Contr                                                                                                                                                                                                                                                                                              | ol                               |   |              | Serial N |   |                 |  |
|----------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|---|--------------|----------|---|-----------------|--|
| Input override       | Record                   | d source                                                                                                                                                                                                                                                                                           | select                           |   | Record level |          |   |                 |  |
| 7                    | 6                        | 5                                                                                                                                                                                                                                                                                                  | 4                                | 3 | 2            | 1        | 0 |                 |  |
| Bit Definition       | s:                       |                                                                                                                                                                                                                                                                                                    |                                  |   |              |          |   | Bit Defir       |  |
| Bits Name            | Desc                     | ription                                                                                                                                                                                                                                                                                            |                                  |   |              |          |   | <u>Bits</u> Nai |  |
| 7 Input<br>override  | e fi<br>m<br>e<br>a<br>c | <ul> <li>The record source select and record level fields take effect and override settings in mixer registers 1Ch and B4h. Serial mode is enabled when input pin DCLK is clocking and either the external pin SE is high or bit 7 of mixer register 48h is high.</li> <li>= no effect.</li> </ul> |                                  |   |              |          |   |                 |  |
| 6:4 Record<br>source | <u>Bit 6</u><br>0        |                                                                                                                                                                                                                                                                                                    | <u>it 4</u> <u>Sig</u><br>0 Line |   |              |          |   |                 |  |

| select | 0    | 0     | 1     | AuxA (CD)                    |
|--------|------|-------|-------|------------------------------|
|        | 0    | 1     | 0     | Microphone                   |
|        | 0    | 1     | 1     | Master volume inputs         |
|        | 1    | 0     | 0     | Left channel: microphone     |
|        |      |       |       | Right channel: master volume |
|        |      |       |       | (L+R)/2                      |
|        | 1    | 0     | 1     | AOUT_L/AOUT_R                |
|        | 1    | 1     | 0     | Record mixer                 |
|        | 1    | 1     | 1     | Record source is             |
|        |      |       |       | disconnected from filters    |
|        |      |       |       | (muted)                      |
|        | Reco | ord s | ource | is unchanged in Serial mode. |
|        |      |       |       |                              |

3:0 Record For microphone source, specifies record gain level from 0 to +22.5 dB in steps of 1.5 dB. For other sources, specifies record level from -6 dB to +16.5 dB in steps of 1.5 dB.

# Serial Mode Output Control

(44h, R/W)

| Master volume override | Serial | mode output | Master volume |   |   |   |   |
|------------------------|--------|-------------|---------------|---|---|---|---|
| 7                      | 6      | 5           | 4             | 3 | 2 | 1 | 0 |

#### Bit Definitions:

| <u>Bits</u> | Name                         | Desc                                                                                                                                     | riptio | n     |                                                                                            |  |  |  |  |  |
|-------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|--------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7           | Master<br>volume<br>override | <ul><li>1 = Master Volume during Serial mode is taken<br/>from this register rather than from the Master<br/>Volume registers.</li></ul> |        |       |                                                                                            |  |  |  |  |  |
| 6:4         | Serial<br>mode<br>output     | ume                                                                                                                                      | stage  | e dur | nat signal is input to the master vol-<br>ing Serial mode.<br><u>I Master Volume Input</u> |  |  |  |  |  |
|             | select                       | 0                                                                                                                                        | 0      | 0     | Mute                                                                                       |  |  |  |  |  |
|             |                              | 0                                                                                                                                        | 0      | 1     | No change from normal op                                                                   |  |  |  |  |  |
|             |                              | 0                                                                                                                                        | 1      | 0     | First audio channel DAC only -                                                             |  |  |  |  |  |
|             |                              |                                                                                                                                          |        |       | playback mixer bypassed *                                                                  |  |  |  |  |  |
|             |                              | 1 5 51                                                                                                                                   |        |       | No change from normal op                                                                   |  |  |  |  |  |
|             |                              | 1                                                                                                                                        | 0      | 0     | Playback mixer with 1st audio                                                              |  |  |  |  |  |
|             |                              |                                                                                                                                          |        |       | channel DAC set to 0 dB                                                                    |  |  |  |  |  |
|             |                              |                                                                                                                                          |        |       | attenuation *                                                                              |  |  |  |  |  |
|             |                              | 1                                                                                                                                        | 0      | 1     | Playback mixer with 1st audio                                                              |  |  |  |  |  |
|             |                              |                                                                                                                                          |        |       | channel DAC muted *                                                                        |  |  |  |  |  |
|             |                              | 1                                                                                                                                        | 1      | 0     |                                                                                            |  |  |  |  |  |
|             |                              | 1                                                                                                                                        | 1      | 1     |                                                                                            |  |  |  |  |  |
|             |                              | * Overrides record monitor and record mute                                                                                               |        |       |                                                                                            |  |  |  |  |  |
|             |                              | featu                                                                                                                                    | ires.  |       |                                                                                            |  |  |  |  |  |
| 3:0         | Master                       | Mast                                                                                                                                     | er Vo  | olume | e during Serial mode if bit 7 is high.                                                     |  |  |  |  |  |

3:0 Master Master Volume during Serial mode if bit 7 is high.volume 0 is mute and 15 is maximum (0 dB).

#### **Serial Mode Control**

(48h, R/W)

| 00110 | AT 101 | ouo |                              | •••• |   |   |   |  |
|-------|--------|-----|------------------------------|------|---|---|---|--|
| х     |        |     | Enable ES689/ES69x interface |      | х |   | 0 |  |
| 7     | 6      | 5   | 4                            | 3    | 2 | 1 | 0 |  |

#### **Bit Definitions:**

Bits Name Description

7:5 – These bits have no function.

| 4   | Enable | 1 = Enable ES689/ES69x to use music DAC      |
|-----|--------|----------------------------------------------|
|     | ES689/ | if MCLK is detected high at least once every |
|     | ES69x  | 20 µsec. Mixer volume for this DAC is        |
|     | inter- | controlled by the FM mixer volume register.  |
|     | face   | 0 = Disable ES689/ES69x serial interface.    |
| 3:1 | _      | These bits have no function.                 |

0 0 Reserved. Always write 0.

(50h. R/W)



#### Spatializer Enable and Mode

|   |   |   |   |                    |       | •         | • |  |
|---|---|---|---|--------------------|-------|-----------|---|--|
| 0 | 0 | 0 | 0 | Enable Spatializer | Reset | Mono mode | 0 |  |
| 7 | 6 | 5 | 4 | 3                  | 2     | 1         | 0 |  |

#### **Bit Definitions:**

| <u>Bits</u> Name |                       | Description                                                                                                         |  |  |  |  |  |
|------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7:4              | 0                     | Reserved. Always write 0.                                                                                           |  |  |  |  |  |
| 3                | Enable<br>Spatializer | <ul><li>1 = Enable Spatializer effect.</li><li>0 = Disable Spatializer effect<br/>(effect unit bypassed).</li></ul> |  |  |  |  |  |
| 2                | Reset                 | <ul><li>1 = Release from reset.</li><li>0 = Reset Spatializer.</li></ul>                                            |  |  |  |  |  |
| 1                | Mono<br>mode          | <ul><li>1 = Mono-in stereo-out mode.</li><li>0 = Stereo-in stereo-out mode.</li></ul>                               |  |  |  |  |  |
| 0                | 0                     | Reserved. Always write 0.                                                                                           |  |  |  |  |  |

| Spatia | lizer L | evel |   |         |            | (52 | h, <b>R/W)</b> |
|--------|---------|------|---|---------|------------|-----|----------------|
| 0      | 0       |      |   | Spatial | izer level |     |                |
| 7      | 6       | 5    | 4 | З       | 2          | 1   | 0              |

Reset to zero by hardware reset.

#### Bit Definitions:

| <u>Bits</u> Name | Description                                 |
|------------------|---------------------------------------------|
| 7:6 0            | Reserved. Always write 0.                   |
| 5:0 Spatializer  | 0 is minimum effect; 3Fh is maximum effect. |

level

| Spatialize     | er Test C                | ontrol           |            | (! | 5Ch,   | R/W) |   |
|----------------|--------------------------|------------------|------------|----|--------|------|---|
| L/R state flag | Signal proc<br>test mode | ADC test<br>mode | Acc timing |    | Reserv | red  |   |
| 7              | 6                        | 5                | 4          | 3  | 2      | 1    | 0 |

Reset to zero by hardware reset.

#### **Bit Definitions:**

| Bits Name                  | Description                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7 L/R state<br>flag        | Read-only. Left/right state flag.                                                                                                                                                                                                                                               |  |  |  |  |  |
| 6 Signal proc<br>test mode | Allows the input to the signal processing logic<br>to be written from the host for test purposes.<br>Poll bit 7 of this register to synchronize. When<br>it goes high, write to register 5Eh four times<br>successively to write left low, left high, right<br>low, right high. |  |  |  |  |  |
| 5 ADC test mode            | Poll bit 7 of this register to synchronize. then<br>read register 5Eh four times successively to<br>read left low, left high, right low, right high.                                                                                                                            |  |  |  |  |  |
| 4 Acc timing               | 1 = Accelerated timing.                                                                                                                                                                                                                                                         |  |  |  |  |  |

3:0 – Reserved.

| ; | Spatiali | zer Tes | t Data |   |   |   | (5Eh | n, R/W) |
|---|----------|---------|--------|---|---|---|------|---------|
|   |          |         |        |   |   |   |      |         |
| - | 7        | 6       | 5      | 4 | 3 | 2 | 1    | 0       |

Except in ADC test mode, this register returns the current 8-bit gain setting. In ADC test mode, it is used to read back the ADC values. In signal processor test mode, it is used to write test pattern data.

In ADC test mode or signal processor test mode, four reads or writes are needed to access all four bytes in series. The sequence is controlled by an internal 2-bit counter. This counter is incremented after every I/O read or write to mixer register 5Eh. The counter is reset by an I/O read from mixer register 5Ch.

| Left Ma                                 | (60                | h, <b>R/W)</b> |                    |                            |           |     |                |  |  |
|-----------------------------------------|--------------------|----------------|--------------------|----------------------------|-----------|-----|----------------|--|--|
| 0                                       | 1:Mute             |                | Left master volume |                            |           |     |                |  |  |
| 7                                       | 6                  | 5              | 4                  | 1                          | 0         |     |                |  |  |
| Right Master Volume and Mute (62h, R/W) |                    |                |                    |                            |           |     |                |  |  |
| Right I                                 | Master V           | Volume         | e and M            | lute                       |           | (62 | h, <b>R/W)</b> |  |  |
| Right I                                 | Master 1<br>1:Mute | Volume         |                    | l <b>ute</b><br>ight maste | er volume | •   | h, R/W)        |  |  |

Registers 60h and 62h are the actual volume values presented to the analog hardware. These registers can be modified under five circumstances:

- 1. By hardware reset each register is loaded with 36h.
- 2. Direct write to mixer address 60h or 62h.
- 3. If bit 0 of mixer register 64h is low, then writing to mixer registers 22h or 32h updates 60h and 62h.
- 4. If bit 0 of mixer register 64h is low, then a mixer reset (writing to mixer register 0h) loads these registers with 36h.
- 5. If hardware volume controls are enabled and bit 7 of mixer register 64h is low, then the hardware volume controls can directly modify the contents of these registers.

Reading mixer registers 22h or 32h actually reads a value calculated from the current contents of 60h and 62h.

REGISTERS

#### Left Hardware Volume Control Counter (61h, R/W)

| 0 | 1:Mute |   | L | eft volum | e counte | r |   |
|---|--------|---|---|-----------|----------|---|---|
| 7 | 6      | 5 | 4 | 3         | 2        | 1 | 0 |

See the explanation following the Right Hardware Volume Control Counter, mixer register 63h.

#### Right Hardware Volume Control Counter (63h, R/W)

| 0 | 1:Mute | Right volume counter |   |   |   |   |   |
|---|--------|----------------------|---|---|---|---|---|
| 7 | 6      | 5                    | 4 | 3 | 2 | 1 | 0 |

These registers only exist if bit 7 of mixer register 64h is high. If bit 7 is low, these registers are combined with registers 60h and 62h and cannot be independently written or read.

If bit 7 of mixer register 64h is high, these registers have no connection with registers 60h or 62h. They are the hardware volume counters and mute. It is the responsibility of the host software to read these registers and update the master volume registers 60h and 62h.

#### **Master Volume Control**

# ol (64h, R/W)

| Split<br>mode | MPU-401<br>int mask | Count<br>by 3 | Read-only HMV<br>int request | Мо | ode | HMV int<br>mask | Disable SB Pro master<br>vol emulation |
|---------------|---------------------|---------------|------------------------------|----|-----|-----------------|----------------------------------------|
| 7             | 6                   | 5             | 4                            | 3  | 2   | 1               | 0                                      |

#### **Bit Definitions:**

| <u>Bits</u> | <u>Name</u>                         | Desc                                                                                                                                                            | riptio                 | <u>on</u>                                                                                                                                                                                |  |  |  |  |  |  |
|-------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 7           | Split<br>mode                       | <ul><li>1 = Split counter registers from volume registers<br/>and access them independently.</li><li>0 = Slave counter and volume registers together.</li></ul> |                        |                                                                                                                                                                                          |  |  |  |  |  |  |
| 6           | MPU-<br>401 int<br>mask             | This bit is AND'ed with the MPU-401 interrup<br>request. If it is low, the MPU-401 interrupt rec<br>stays low. This bit is cleared by hardware res              |                        |                                                                                                                                                                                          |  |  |  |  |  |  |
| 5           | Count<br>by 3                       | 0 = C<br>0                                                                                                                                                      | r Do<br>oun<br>r Do    | t up and down by 3 for each push of Up<br>wn buttons.<br>t up and down by 1 for each push of Up<br>wn buttons.<br>s cleared by hardware reset.                                           |  |  |  |  |  |  |
| 4           | Read-<br>only<br>HMV int<br>request | Read<br>volun                                                                                                                                                   |                        | y interrupt request from hardware<br>vent.                                                                                                                                               |  |  |  |  |  |  |
| 3:2         | Mode                                |                                                                                                                                                                 | <u>Bit 2</u><br>0<br>1 | peration mode:<br><u>Operating Mode</u><br>Reserved<br>2-wire mode: both Up and Down inputs<br>being low together act the same as<br>Mute input low.<br>Peduced debugges (10 uses vs. 40 |  |  |  |  |  |  |
|             |                                     | Ĩ                                                                                                                                                               | 0                      | Reduced debounce (10 µsec vs. 40 msec), 2-wire mode, auto-increment                                                                                                                      |  |  |  |  |  |  |

- and decrement disabled.
- 1 1 Hardware volume control disabled

#### Bits Name Description

- 1 HMV int This bit is AND'ed with the hardware volume mask interrupt request before being OR'd with the first channel audio interrupt request. If this bit is low, the hardware volume interrupt request does not get OR'd with the first channel audio interrupt request. This bit is cleared by hardware reset.
- 0 Disable When low, a write to Sound Blaster Pro master SB Pro volume registers 22h or 32h is translated into a write to hardware master volume registers 60h and 62h. Also, if low, a mixer reset (writing to emulation to be reset to default value 36h. When high the Sound Blaster Pro master volume
  - When high, the Sound Blaster Pro master volume registers are, in effect, read-only. This bit is cleared by hardware reset.

2

1

n

# Opamp Calibration Control (65h, R/W) Opamp calibration Opamp calibration

3

In the analog circuitry of the Solo-1, operational amplifiers that require calibration go through a calibration procedure that takes about 200 milliseconds to perform. During this period the analog outputs of the chip (AOUT\_L, AOUT\_R, and MONO\_OUT) are muted.

The calibration procedure occurs automatically after hardware reset and can be started at any time thereafter by writing 1 to mixer register 65h.

#### Bit Definitions:

7

6

5

4

| Bits Name         | Description |
|-------------------|-------------|
| 0 Opam<br>calibra |             |

#### Clear Hardware Volume Interrupt Request (66h, R/W)

| Clear Hardware Master Control |   |   |   |   |   |   |   |  |  |  |
|-------------------------------|---|---|---|---|---|---|---|--|--|--|
| 7                             | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |

Any write to this register resets the hardware volume interrupt request.

# Mic Record (68h, R/W) Left Mic record Right Mic record





|--|

# PRELIMINARY

#### REGISTERS

| Audio  | 2 Reco     | ord         |         |            |             | (69h,       | (69h, R/W) Audio 2 Mode |       |            |      |      |                            |           |             | (71h                 | (71h, R/W) |           |  |
|--------|------------|-------------|---------|------------|-------------|-------------|-------------------------|-------|------------|------|------|----------------------------|-----------|-------------|----------------------|------------|-----------|--|
|        | Left Audi  | o 2 record  |         | R          | light Audi  | o 2 record  |                         | (     | )          | 0    |      | New reg                    | 4x        | SCF2        | SCF1                 | Async      | FM mix    |  |
| 7      | 6          | 5           | 4       | 3          | 2           | 1           | 0                       |       | 7          | 6    |      | A1h<br>5                   | mode<br>4 | bypass<br>3 | bypass<br>2          | mode<br>1  | 0         |  |
| AuxA   | (CD) R     | ecord       |         |            |             | (6Ah,       | R/W)                    |       |            |      |      |                            |           |             |                      |            |           |  |
|        | Left AuxA  | (CD) reco   | rd      | Riç        | ght AuxA    | (CD) recor  | d                       | This  | s regi     | ste  | r is | reset to                   | zero l    | by hard     | ware re              | eset.      |           |  |
| 7      | 6          | 5           | 4       | 3          | 2           | 1           | 0                       | Bit I | Defini     | itio | ns:  |                            |           |             |                      |            |           |  |
| Music  |            |             |         |            |             |             |                         | Bits  | <u>Nan</u> | ne   | De   | escriptior                 | <u>1</u>  |             |                      |            |           |  |
|        | DAC R      |             |         |            |             |             | R/W)                    | 7:6   | 0          |      | Re   | eserved.                   | Always    | write 0     |                      |            |           |  |
|        | _eft music |             |         |            |             | DAC recor   |                         | 5     | New        |      |      | = Registe                  |           |             |                      |            | inner a   |  |
| 7      | 6          | 5           | 4       | 3          | 2           | 1           | 0                       |       | reg        | A1h  | Ì    |                            | •         |             | ich give             |            | i de e re |  |
| AuxB   | Record     | ł           |         |            |             | (6Ch,       | R/W)                    |       |            |      |      | of 48 k                    |           | sample      | e rates th           | iat are o  | IVISOIS   |  |
|        | Left Aux   | B record    |         |            | Right Aux   | B record    |                         |       |            |      | 0 :  | = Enable                   | -         |             |                      |            | y as in   |  |
| 7      | 6          | 5           | 4       | 3          | 2           | 1           | 0                       |       |            |      |      | •                          |           |             | ve® chips            |            |           |  |
| Mono   | _In Play   | / Mix       |         |            |             | (6Dh,       | R/W)                    | 4     | 4x<br>moc  | le   |      | = 2nd ch<br>= 2nd ch       |           |             |                      | •          | •         |  |
|        | Left Mono  |             | ix      | Ric        | aht Mono    | _In play mi |                         | 3     | SCF        | 2    | 1 :  | = 2nd ch                   | annel D   | AC swi      | tched ca             | pacitor f  | ilter is  |  |
| 7      | 6          | 5           | 4       | 3          | 2           | 1           | 0                       |       | bypa       | ass  | 0 :  | bypass<br>2nd ch           | annel D   |             |                      |            |           |  |
| Line I | Record     |             |         |            |             | (6Eh,       | R/W)                    |       |            |      |      | <b>DTE:</b> t<br>rersampli |           |             | lways b              | ypassed    | d in 4    |  |
|        |            | e record    |         |            | Right Lin   | •           | ,                       | 2     | SCF        | 1    |      | = 1st cha                  | -         |             | witched              | canacit    | or filter |  |
| 7      | 6          | 5           | 4       | 3          | 2           | 1           | 0                       | 2     | bypa       |      |      | is bypa                    | assed.    |             |                      | ·          |           |  |
| Mono   | _In Rec    | ord         |         |            |             | (6Fh        | R/W)                    | 1     | Asv        | nc   |      | = 1st cha<br>= 2nd ch      |           |             |                      |            |           |  |
|        |            | o In record | 4       | R          | iaht Monc   | _In record  |                         | 1     | moc        |      |      |                            |           |             | channel              |            | uie       |  |
| 7      | 6          | 5           | 4       | 3          | 2           | 1           | 0                       |       |            |      | 0 :  | = 2nd ch<br>and filte      |           |             | laved to             |            | ple rat   |  |
| Audio  | o 2 Sam    | ple Rate    | 9       |            |             | (70h,       | R/W)                    | 0     | FM         | mix  | 1 :  | = 2nd ch                   |           |             |                      |            |           |  |
| Maste  | r clock    |             | Two's c | ompleme    | nt rate div | vider       |                         |       |            |      |      |                            |           |             | te and th<br>M synth |            |           |  |
|        | 7          | 6 5         | 5 4     | 4 3        | 2           | 1           | 0                       |       |            |      |      | argitarij                  | mixed     |             | W Oyner              | 1001201 0  | uipui.    |  |
| This r | egister i  | s reset t   | o zero  | by hard    | lware re    | set.        |                         | Auc   | lio 2      | Filt |      | Clock I                    |           |             |                      | (72h       | n, R/W    |  |
|        | finitions  |             |         | 1          |             |             |                         |       |            |      |      | Two's con                  |           |             |                      |            |           |  |
|        |            |             | ~       |            |             |             |                         | -     | 7          | 6    | 5    | 5                          | 4         | 3           | 2                    | 1          | 0         |  |
|        |            | escriptio   | _       |            | (h.         |             |                         | In A  | syna       | hro  | no   | us mode                    | a thic    | ronieto     | r datam              | nines th   | na filta  |  |
|        | Aaster S   |             | e maste | er CIOCK 1 | or the sa   | ample rate  | e gen-                  |       | •          |      |      |                            |           | -           |                      |            |           |  |

clock rate of the second channel switched capacitor filter. If used, this register is programmed in the same manner as controller register A2h.

This register is reset to zero by hardware reset.

| Audio                                      | Audio 2 Transfer Count Reload |         |        |      |           |      |         |  |  |  |  |
|--------------------------------------------|-------------------------------|---------|--------|------|-----------|------|---------|--|--|--|--|
| Two's complement transfer count – low byte |                               |         |        |      |           |      |         |  |  |  |  |
| 7                                          | 6                             | 5       | 4      | 3    | 2         | 1    | 0       |  |  |  |  |
| -                                          | Ū                             | -       |        |      |           |      |         |  |  |  |  |
| Audio                                      | 2 Trans                       | sfer Co | unt Re | load |           | (76ł | ո, R/W) |  |  |  |  |
| Audio                                      |                               |         |        |      | nt – high | •    | າ, R/W) |  |  |  |  |

clock erator:

1 = 768 kHz (used to generate 48 kHz, 32 kHz, 16 kHz, 8 kHz, and so on).

0 = 793.8 kHz (used to generate 44.1 kHz, 22.05 kHz, and so on).

6:0 Two's Two's complement divisor of master clock to procomp duce sample rate. Examples: Register 70h rate Rate divider 8000 A0h 48000 F0h 44100 6Eh

REGISTERS

PRELIMINARY



| ۹ud      | lio 2             | Cor                                                                                                                                                                                                                                | ntrol 1                                                                                                                                                                                                                                                                               | (78h, R/W)        | Audio 2 DAC Mixer Volume |                                      |                                                            |                                                                                                                                                                                                            |                                                                                                                                             |            |            | (7Ch                 | , <b>R/W</b> ) |                |                 |                          |              |
|----------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------------------------|--------------------------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|------------|------------|----------------------|----------------|----------------|-----------------|--------------------------|--------------|
| 0        | 0                 | 0                                                                                                                                                                                                                                  | Auto-initialize                                                                                                                                                                                                                                                                       | 0                 | 0                        | Enable 2nd                           | Enable FIFO to                                             |                                                                                                                                                                                                            | Let                                                                                                                                         | t cha      | nnel       | /olume               | ;              | F              | Right chai      | nnel volum               | е            |
| 7        | 6                 | 5                                                                                                                                                                                                                                  | 4                                                                                                                                                                                                                                                                                     | 3                 | 2                        | chan DMA<br>1                        | 2nd chan DAC<br>0                                          | 7                                                                                                                                                                                                          |                                                                                                                                             | 6          |            | 5                    | 4              | 3              | 2               | 1                        | 0            |
|          | Defin             | -                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                       | Ū                 | -                        | ·                                    | C C                                                        | This                                                                                                                                                                                                       | regi                                                                                                                                        | ster       | is re      | eset to              | o zer          | o by har       | dware r         | eset.                    |              |
| Bits     | Nan               | ne                                                                                                                                                                                                                                 | <b>Description</b>                                                                                                                                                                                                                                                                    |                   |                          |                                      |                                                            | Mic                                                                                                                                                                                                        | Prea                                                                                                                                        | amp        | , МС       | DNO_                 | IN a           | nd MON         | 0_0U1           | <b>(7D</b> h             | , <b>R/W</b> |
| 7:6<br>5 | 0<br>0            |                                                                                                                                                                                                                                    | Reserved. A<br>Reserved.                                                                                                                                                                                                                                                              | -                 |                          |                                      |                                                            | 0                                                                                                                                                                                                          | 0                                                                                                                                           | 0          | 0          | Ena<br>+26 dl<br>arr | Bmic           | MONO<br>source |                 | Ena<br>MONO_<br>with AOI | IN mix       |
| 4        | Auto<br>initia    | o-<br>alize                                                                                                                                                                                                                        | rolls ove<br>DMA co                                                                                                                                                                                                                                                                   | er to (<br>Intinu | 0, it i<br>ies.          | s automatica<br>The second           | transfer counter<br>ally reloaded and<br>channel interrupt | 7<br>This                                                                                                                                                                                                  | 6<br>regi                                                                                                                                   | 5<br>ister | 4<br>is re | 3<br>eset to         |                | 2<br>h by harc | 1<br>Iware re   | oeset.                   |              |
|          |                   | <ul> <li>flag will be set high.</li> <li>0 = Normal mode. After the transfer counter rolls over to 0, it is reloaded but DMA stops. Bit 1 of this register is cleared. The 2nd channel interrupt flag will be set high.</li> </ul> |                                                                                                                                                                                                                                                                                       |                   |                          |                                      |                                                            |                                                                                                                                                                                                            | Bit Definitions:         Bits       Name       Description         7:4       0       Reserved. Always write 0.                              |            |            |                      |                |                |                 |                          |              |
| 3:2<br>1 | 0<br>Ena          | blo                                                                                                                                                                                                                                | Reserved. A                                                                                                                                                                                                                                                                           | Alway             | ys w                     | rite 0.                              | r data ta ba                                               | 3 Enable +26 1 = Enable +26 dB microphone pream<br>dB mic amp 0 = Mic preamp is 0 dB.                                                                                                                      |                                                                                                                                             |            |            |                      |                |                | np gair         |                          |              |
| I        | 2nd<br>cha<br>DM  | n                                                                                                                                                                                                                                  | <ul> <li>1 = 2nd channel DMA enabled for data to be<br/>written into the 2nd channel FIFO (32 words<br/>deep).</li> <li>0 = Second channel DMA not enabled.</li> <li>This bit is cleared when the transfer counter rolls<br/>over to zero, if not in Auto-initialize mode.</li> </ul> |                   |                          |                                      |                                                            |                                                                                                                                                                                                            | 2:1 MONO_OUT <u>Bit 2 Bit 1</u><br>source select 0 0 Mute (CMR)<br>0 1 CIN_R pin (1st channel D<br>right channel playback<br>filter stage). |            |            |                      |                |                | olayback,       | after                    |              |
| 0        | 2nd<br>Cha<br>DA( | O to<br>in<br>C                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                       | I DA              | C is                     | m the FIFO t<br>enabled.<br>enabled. | (74b DAM)                                                  | <ol> <li>2nd channel DAC, right c<br/>output.</li> <li>1 1 Mono mix of left and right<br/>level stage outputs.<br/>MONO_OUT is controll<br/>record source select an<br/>record level registers.</li> </ol> |                                                                                                                                             |            |            |                      |                |                | record<br>ed by |                          |              |

| Audio 2 Co   | (7Ah, R/W) |   |   |   |        |                 |                  |  |
|--------------|------------|---|---|---|--------|-----------------|------------------|--|
| 2nd chan IRQ | IRQ mask   | 0 | 0 | 0 | Signed | stereo/<br>mono | 16-bit/<br>8-bit |  |
| 7            | 6          | 5 | 4 | 3 | 2      | 1               | 0                |  |

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

#### **Bit Definitions:**

| <u>Bits</u> | <u>Name</u>             | Description                                                                                                                                                                                        |
|-------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7           | 2nd<br>chan-<br>nel IRQ | This latch is set high when the DMA counter rolls<br>over to zero, or when a 1 is written to this bit. The<br>latch is cleared by writing a zero to this bit, or by<br>hardware or software reset. |
| 6           | IRQ<br>mask             | This bit is AND'ed with bit 7 to produce the sec-<br>ond DMA channel interrupt request.                                                                                                            |
| 5:3         | 0                       | Reserved. Always write 0.                                                                                                                                                                          |
| 2           | Signed                  | <ul><li>1 = Data is in signed, two's complement format.</li><li>0 = Unsigned data.</li></ul>                                                                                                       |
| 1           | Stereo/<br>mono         | 1 = Stereo data.<br>0 = Mono data.                                                                                                                                                                 |
| 0           | 16-bit/<br>8-bit        | <ul><li>1 = 16-bit samples.</li><li>0 = 8-bit samples.</li></ul>                                                                                                                                   |

#### Bit Definitions:

7

0 Enable

MONO\_IN

AOUT\_L/R

**Music Digital Record** 

5

mix with

Reserved

6

| <u>Bits</u> <u>Name</u><br>7:5 – | <u>Description</u><br>Reserved.                                                                                                                                                                                                                                                  |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4 Music<br>digital<br>record     | 1 = Enable direct digital recording of Music DAC<br>data (including FM or ES689/ES69x). In<br>this mode, the first DMA channel must be<br>enabled for stereo recording. The sample rate<br>is determined by the music DAC sample rate<br>rather than by controller register A1h. |
| 3:0 –                            | These bits have no function.                                                                                                                                                                                                                                                     |

Mix is unity gain.

Music digital record

4

1 = MONO\_IN is mixed with AOUT\_L and

Spatializer, and master volume stages.

3

(7Fh, R/W)

0

х

1

2

AOUT\_R after playback mixer,



#### **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 26 ESS Controller Registers Summary

| Reg | D7                                         | D6                                             | D5                                        | D4              | D3                                | D2                             | D1                    | D0                              | Description                            |  |
|-----|--------------------------------------------|------------------------------------------------|-------------------------------------------|-----------------|-----------------------------------|--------------------------------|-----------------------|---------------------------------|----------------------------------------|--|
| A1h | Clock source                               |                                                |                                           | Sample rate of  | divider                           |                                |                       |                                 |                                        |  |
| A2h |                                            |                                                | Filter c                                  | lock divider    |                                   |                                |                       |                                 | S/W reset, setup for 8<br>kHz sampling |  |
| A4h |                                            |                                                | DMA transfer cou                          | Inter reload –  | low byte                          |                                |                       |                                 |                                        |  |
| A5h |                                            |                                                | DMA transfer cou                          | nter reload – h | nigh byte                         |                                |                       |                                 |                                        |  |
| A8h | 0 0 0 1 Enable record 0 Mono/stereo select |                                                |                                           |                 |                                   |                                |                       |                                 | Analog control                         |  |
| B1h | Game<br>compatible<br>IRQ                  | Enable IRQ<br>ovf Ext mode<br>DMA cntr         | Enable IRQ for<br>FIFO1 HE status<br>edge | х               |                                   | Reser                          |                       | Legacy audio interrupt control  |                                        |  |
| B2h | Game<br>compatible<br>DRQ                  | Enable DRQ<br>for Ext mode<br>DMA              | Enable DRQ game<br>compatible DMA         |                 |                                   |                                |                       |                                 |                                        |  |
| B4h |                                            | Left Channe                                    | el Record Level                           |                 | Ri                                | ight Channel F                 | Record Lev            | /el                             | Record Level                           |  |
| B7h | Enable FIFO<br>to/from<br>CODEC            | Reserved. Set<br>opposite<br>polarity of bit 3 | Data type select                          | 1               | Stereo/<br>Mono<br>mode<br>select | 16-bit/8-bit<br>mode<br>select | 0                     | 1                               | Audio 1 control 1                      |  |
| B8h | 0                                          | 0                                              | 0                                         | 0               | Codec<br>mode                     | DMA mode                       | DMA<br>read/<br>write | Trans-<br>fer<br>enable         | Audio 1 control 2                      |  |
| B9h | 0                                          | 0                                              | 0                                         | 0               | 0                                 | 0                              | Transf                | er type                         | Audio 1 transfer type                  |  |
| BAh | Ah 0 Reserved Sign Adjust magnitude        |                                                |                                           |                 |                                   |                                |                       | Left channel ADC offset adjust  |                                        |  |
| BBh |                                            | 0                                              |                                           | Sign            |                                   | Adjust mag                     |                       | Right channel ADC offset adjust |                                        |  |

REGISTERS

PRELIMINARY



#### **Controller Register Descriptions**

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

| Clock source |   | Sample rate divider |   |   |   |   |   |  |  |  |
|--------------|---|---------------------|---|---|---|---|---|--|--|--|
| 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 clock source for the sample rate generator is 397.7 kHz if bit 7 is 0 and 795.5 kHz if bit 7 is 1.

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 7:0 of register A1h.

#### Bit Definitions:

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

| Filter [ | Divider |   |            |            |   | (A2 | h, <b>R/W)</b> |
|----------|---------|---|------------|------------|---|-----|----------------|
|          |         |   | Filter clo | ck divideı | • |     |                |
| 7        | 6       | 5 | 4          | 3          | 2 | 1   | 0              |

This register controls the low-pass frequency of the switch-capacitor filters inside the Solo-1. 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)

| DMA T | DMA Transfer Count Reload |          |           |            |            |   |   |  |  |
|-------|---------------------------|----------|-----------|------------|------------|---|---|--|--|
|       | D                         | MA trans | sfer coun | t reload - | - low byte |   |   |  |  |
| 7     | 6                         | 5        | 4         | 3          | 2          | 1 | 0 |  |  |

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

| DI | MAT | (A5l | η, R/W)  |           |            |           |   |   |
|----|-----|------|----------|-----------|------------|-----------|---|---|
|    |     | DI   | MA trans | fer count | t reload - | high byte | e |   |
|    | 7   | 6    | 5        | 4         | 3          | 2         | 1 | 0 |

On reset, this register assumes the value of F8h.

The FIFO control logic of the Solo-1 has a 16-bit counter for controlling transfers to and from the FIFO. These registers are the reload 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 is incremented after each successful byte is transferred by DMA. Since the counter counts up towards FFFFh and then overflows, the reload value is in two's complement form.

For Auto-Initialize mode DMA, the counter is used to generate interrupt requests to the system processor. In this mode, the Solo-1 allows continuous DMA. In a typical application the counter is programmed to be one-half of the DMA buffer maintained by the system processor. In this application an interrupt is generated whenever DMA switches from one half of the circular buffer to the other.

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



#### REGISTERS

|  | Ana | loa | Control |
|--|-----|-----|---------|
|--|-----|-----|---------|

#### (A8h, R/W)

(B2h, R/W)

|   | J |   |   |                          |   | <b>(</b> , | ····,          |
|---|---|---|---|--------------------------|---|------------|----------------|
| 0 | 0 | 0 | 1 | Record monitor<br>enable | 0 |            | 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.

#### **Bit Definitions:**

| <u>Bits</u> | <u>Name</u>               | Description                                                                                    |
|-------------|---------------------------|------------------------------------------------------------------------------------------------|
| 7:5         | 0                         | Reserved. Always write 0.                                                                      |
| 4           | 1                         | Reserved. Always write 1.                                                                      |
| 3           |                           | <ul><li>1 = Enable record monitor.</li><li>0 = Disable record monitor.</li></ul>               |
| 2           | 0                         | Reserved. Always write 0.                                                                      |
| 1:0         | Stereo/<br>mono<br>select | Select operation mode of first DMA converters.Bit 1Bit 0Mode00Reserved01Stereo10Mono11Reserved |

#### Legacy Audio Interrupt Control

(B1h, R/W)

| Game<br>compatible<br>IRQ | Enable IRQ ovf Ext<br>mode DMA cntr | Enable IRQ for<br>FIFO1 HE status<br>edge | x | 1 | Rese | erveo | ł |  |
|---------------------------|-------------------------------------|-------------------------------------------|---|---|------|-------|---|--|
| 7                         | 6                                   | 5                                         | 4 | 3 | 2    | 1     | 0 |  |

#### Bit Definitions:

Bits Name Description

- 7 Game com- Reserved for Compatibility mode. Leave zero patible IRQ for Extended mode.
- 6 Enable IRQ Set high to receive interrupts for each overovf Ext flow of the Solo-1 DMA counter in Extended mode DMA mode. cntr

5 Enable IRQ Set high to receive interrupts for FIFO Halffor FIFO1 Empty transitions when doing block I/O to/ HE status from the FIFO in Extended mode. edge

- 4 No function. The audio device activate bit serves the purpose of enabling the interrupt pin.
- 3:0 Reserved.

|                           |                                        |                                      |   |   | •    |       | ' |
|---------------------------|----------------------------------------|--------------------------------------|---|---|------|-------|---|
| Game<br>compatible<br>DRQ | Enable DRQ for<br>Extended mode<br>DMA | Enable DRQ<br>game compatible<br>DMA | x |   | Rese | erved |   |
| DRQ                       | DIVIA                                  | DIVIA                                |   |   |      |       |   |
| 7                         | 6                                      | 5                                    | 4 | 3 | 2    | 1     | 0 |

#### **Bit Definitions:**

**DRQ Control** 

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

- 7 Game Reserved for Compatibility mode. Leave zero compatible for Extended mode. DRQ
- 6 Enable 1 = Enable DRQ outputs and DACKB inputs DRQ for for DMA transfers in Extended mode. Extended 0 = Enable block I/O to/from the FIFO in Extended mode.
- 5 Enable Reserved for Compatibility mode. Leave zero DRQ game for Extended mode. compatible

DMA

4

- No function. The DRQ lines always drive (there is no enable). If neither bit 5 nor bit 6 are set high, the first audio DRQ is always low.
- 3:0 Reserved.

#### SOLO-1 DATA SHEET

REGISTERS

PRELIMINARY



(B7h, R/W)

#### **Record Level**

(B4h, R/W)

| Left channel record level |   |   |   | Righ | nt channe | l record | level |
|---------------------------|---|---|---|------|-----------|----------|-------|
| <br>7                     | 6 | 5 | 4 | 3    | 2         | 1        | 0     |

Register B4h allows for independent left and right record level. Each channel has 16 levels (excluding mute). The amount of gain or attenuation for each level is different for microphone than for all other sources. The record levels are listed in the following table.

| Record Level | Gain for Mic | Gain for Other<br>Sources |  |
|--------------|--------------|---------------------------|--|
| 0            | +0 dB        | -6.0 dB                   |  |
| 1            | +1.5 dB      | -4.5 dB                   |  |
| 2            | +3.0 dB      | -3.0 dB                   |  |
| 3            | +4.5 dB      | -1.5 dB                   |  |
| 4            | +6.0 dB      | 0 dB                      |  |
| 5            | +7.5 dB      | +1.5 dB                   |  |
| 6            | +9.0 dB      | +3.0 dB                   |  |
| 7            | +10.5 dB     | +4.5 dB                   |  |
| 8            | +12.0 dB     | +6.0 dB                   |  |
| 9            | +13.5 dB     | +7.5 dB                   |  |
| 10           | +15.0 dB     | +9.0 dB                   |  |
| 11           | +16.5 dB     | +10.5 dB                  |  |
| 12           | +18.0 dB     | +12.0 dB                  |  |
| 13           | +19.5 dB     | +13.5 dB                  |  |
| 14           | +21.0 dB     | +15.0 dB                  |  |
| 15           | +22.5 dB     | +16.5 dB                  |  |

#### Audio 1 Control 1

Set Enable FIFO FIFO FIFO FIFO oppo-Generate 0 to/from signed 1 stereo 16-bit load signal site bit CODEC mode mode mode 3 7 6 3 2 5 4 1 0

#### **Bit Definitions:**

| Bits | <u>Name</u>                     | Description                                                                                                                                                                                                                              |
|------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7    | Enable FIFO<br>to/from<br>CODEC | <ul> <li>1 = Enable first DMA FIFO connection to<br/>DAC or ADC. This allows transfers<br/>to/from the FIFO and the analog circuitry.</li> <li>0 = Disable first DMA FIFO connection to<br/>DAC or ADC.</li> </ul>                       |
| 6    | Set opposite bit 3              | Reserved function. This bit must be set to<br>the opposite polarity of bit 3: high for mono<br>and low for stereo.                                                                                                                       |
| 5    | FIFO signed<br>mode             | <ul><li>1 = First DMA FIFO two's complement mode<br/>(signed data).</li><li>0 = First DMA FIFO unsigned (offset 8000).</li></ul>                                                                                                         |
| 4    | 1                               | Reserved. Always write 1.                                                                                                                                                                                                                |
| 3    | FIFO stereo<br>mode             | <ul><li>1 = First DMA FIFO stereo mode.</li><li>0 = First DMA FIFO mono mode.</li><li>Bit 6 must be set at the opposite polarity of this bit: high for mono, low for stereo.</li></ul>                                                   |
| 2    | FIFO 16-bit<br>mode             | 1 = First DMA FIFO 16-bit mode.<br>0 = First DMA FIFO 8-bit mode.                                                                                                                                                                        |
| 1    | 0                               | Reserved. Always write 0.                                                                                                                                                                                                                |
| 0    | Generate<br>load signal         | Write 1. Generates a load signal that copies<br>DAC Direct Access Holding register to DAC<br>on the next sample rate clock edge (sample<br>rate is determined by Extended mode regis-<br>ter A1h). This bit is cleared after the holding |

# Audio 1 Control 2 CODEC DMA DMA read DMA transfer

| 0 | 0 | 0 | 0 | mode |   | enable | enable |  |
|---|---|---|---|------|---|--------|--------|--|
| 7 | 6 | 5 | 4 | 3    | 2 | 1      | 0      |  |

register is copied to the DAC.

#### **Bit Definitions:**

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

(B8h, R/W)



REGISTERS

| Audio 1 Transfer Type |   |   |   |   |   | (B9h, R/W |                          |
|-----------------------|---|---|---|---|---|-----------|--------------------------|
|                       | 0 | 0 | 0 | 0 | 0 | 0         | DMA transfer type select |

6 5 4 3 2 1

#### **Bit Definitions:**

| <u>Bits</u> Name    | Desc         | riptio       | <u>n</u>     |                       |
|---------------------|--------------|--------------|--------------|-----------------------|
| 7:2 0               | Rese         | erved.       | Always write | e 0.                  |
| 1:0 DMA<br>transfer | Sele<br>DMA  |              | e DMA transf | er type for the first |
| type select         | <u>Bit 1</u> | <u>Bit 0</u> | Transfer Typ | e Bytes/DMA Request   |
|                     | 0            | 0            | Single       | -                     |
|                     | 0            | 1            | Demand       | 2                     |
|                     | 1            | 0            | Demand       | 4                     |
|                     | 1            | 1            | Reserved     | _                     |

| Left Channel | ADC Offse | t Adiust |
|--------------|-----------|----------|
|              |           |          |

# (BAh, R/W)

| 0 | 0 | Disable time delay on<br>analog wake-up | Sign | A | djust m | agnitud | de |
|---|---|-----------------------------------------|------|---|---------|---------|----|
| 7 | 6 | 5                                       | 4    | 3 | 2       | 1       | 0  |

This register is reset to zero by hardware reset and is unaffected by software reset.

#### **Bit Definitions:**

| <u>Bits</u> Name                                | Description                                                                                                                                                                                                                             |
|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6 0                                           | Reserved. Always write 0.                                                                                                                                                                                                               |
| 5 Disable time<br>delay on<br>analog<br>wake-up | Normally, the AOUT_L and AOUT_R pins<br>are muted for 100 msec $\pm$ 20 msecs after<br>hardware reset or after the analog sub-<br>systems wake from power-down. Set high to<br>disable delay.<br>This bit is cleared by hardware reset. |
| 4:0 Sign/Adjust<br>magnitude                    | See the explanation for bits 4:0 following register BBh.                                                                                                                                                                                |

| Right Channel ADC Offset Adjust         (BBh, R/) |   |   |   |      |            | (BBh, R/W) |
|---------------------------------------------------|---|---|---|------|------------|------------|
|                                                   | 0 | 0 | 0 | Sign | Adjust mag | nitude     |

This register is reset to zero by hardware reset and is unaffected by software reset.

3

2

1

#### **Bit Definitions:**

6

5

7

| <u>Bits</u> Name             | Description                                 |
|------------------------------|---------------------------------------------|
| 7:5 0                        | Reserved. Always write 0.                   |
| 4:0 Sign/Adjust<br>magnitude | See the following explanation for bits 4:0. |

Bits 4 (sign) and 3:0 (adjust magnitude) of the ADC Offset Adjust registers cause a constant value to be added to the ADC converter output, as shown in the following:

| Code | Offset | Code | Offset |
|------|--------|------|--------|
| 00h  | 0      | 10h  | -64    |
| 01h  | +64    | 11h  | -128   |
| 02h  | +128   | 12h  | -192   |
| 03h  | +192   | 13h  | -256   |
| 04h  | +256   | 14h  | -320   |
| 05h  | +320   | 15h  | -384   |
| 06h  | +384   | 16h  | -448   |
| 07h  | +448   | 17h  | -512   |
| 08h  | +512   | 18h  | -576   |
| 09h  | +576   | 19h  | -640   |
| 0Ah  | +640   | 1Ah  | -704   |
| 0Bh  | +704   | 1Bh  | -768   |
| 0Ch  | +768   | 1Ch  | -832   |
| 0Dh  | +832   | 1Dh  | -896   |
| 0Eh  | +896   | 1Eh  | -960   |
| 0Fh  | +960   | 1Fh  | -1024  |

Formula:

bit 
$$4 = 0$$
: offset =  $64 *$  bits[3:0]  
bit  $4 = 1$ : offset =  $-64 *$  (bits[3:0] +1)

To calculate the offset adjust code, first measure the ADC offset for both right and left channels before adjustment by following these steps:

- 1. Program Extended mode registers BAh and BBh bits 4:0 to be zero (no digital offset).
- 2. Select a zero-amplitude (or low amplitude) recording source.
- 3. Set the recording volume to minimum by setting Extended mode register B4h to zero.
- Make a stereo 16-bit two's complement recording at 11 kHz sample rate of 2048 stereo samples (2048 stereo samples = 4096 words = 8192 bytes, which is about 190 milliseconds).
- 5. Use the last 1024 stereo samples to calculate a long term average for both left and right channels.
- 6. With this average DC offset, calculate the best digital offset to bring the sum closest to zero, using the codes and offsets listed in the table above.



AUDIO MICROCONTROLLER COMMAND SUMMARY

# AUDIO MICROCONTROLLER COMMAND SUMMARY

#### Table 27 Command Summary

| Command | Data Byte(s)<br>Write/Read | Function                                                                                                                                                                                                                                                                                                                                               |
|---------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10h     | 1 write                    | Direct write 8-bit DAC. Data is 8-bit unsigned format.                                                                                                                                                                                                                                                                                                 |
| 11h     | 2 writes                   | Direct write 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 by command DDh.                                                                                                                                                                                                                         |
| 24h     | 2 writes                   | Start Normal mode DMA for 8-bit ADC transfer. Data is transfer count - 1, least byte first. Firmware controlled input volume for AGC. Maximum sample rate is 22 kHz: use command 99h for higher 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 volume 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 by 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 SBBase+Eh. Command 31h will also generate an interrupt request for each byte received.<br>Exit MIDI input mode by executing a write to port SBBase+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 SBBase+Ch will be transmitted as MIDI serial output data. The only way to exit this mode is through 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 MHz / (256-X) X must be less than or equal to 233. For stereo DAC, program sample rate for twice the per-channel rate.                                                                                                                                                   |
| 41h     | 1 write                    | Alternate set time constant, X: rate = 1.5 MHz / (256-X)<br>This command provides more accurate timing for certain rates such as 22,050. X must be less than<br>equal to 222. For stereo DAC, program 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: rate = 7.16E6 / (256-X)<br>The relationship between the low-pass filter -3 dB point and the filter clock rate is approximately 1:82.                                                                         |
| 48h     | 2 writes                   | Set block size-1 for high speed mode and auto-init mode transfer, least byte first.                                                                                                                                                                                                                                                                    |
| 64h     | 2 writes                   | Start ESPCM <sup>®</sup> 4.3-bit (low compression) format DMA transfer to DAC. Data is transfer count - 1, least byte first.                                                                                                                                                                                                                           |



# Table 27 Command Summary (Continued)

| Command          | Data Byte(s)<br>Write/Read | Function                                                                                                                                                                                                                                         |
|------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 65h              | 2 writes                   | Same as command 64h, except with reference byte flag.                                                                                                                                                                                            |
| 66h              | 2 writes                   | Start ESPCM <sup>®</sup> 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 <sup>®</sup> 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 <sup>®</sup> 4.3-bit (low compression) format ADC, compression, and DMA transfer. Data is transfer 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 is<br>44 kHz.                                   |
| Axh, Bxh,<br>Cxh |                            | (where x = 0 to Fh) Solo-1 extension commands. Many of these commands are used to access the Solo-1's controller registers. For information on these registers, see the register descriptions.                                                   |
| C0h              | 1 write,1 read             | Read controller registers A0h to BFh. Write this command followed by the register number, then read register contents from SBBase+Ah.                                                                                                            |
| C1h              |                            | Resume after suspend.                                                                                                                                                                                                                            |
| C6h              |                            | Enable Solo-1 Extension commands Axh, Bxh. Must be issued after every reset.                                                                                                                                                                     |
| C7h              |                            | Disable Solo-1 Extension commands Axh, Bxh.                                                                                                                                                                                                      |
| D0h              |                            | Pause DMA. Internal FIFO operations 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 mixer.                                                                                                                                                                                                               |
| D3h              |                            | Disable Audio 1 DAC input to mixer.                                                                                                                                                                                                              |
| D4h              |                            | Continue DMA after command D0h.                                                                                                                                                                                                                  |
| D8h              | 1 read                     | Return Audio 1 DAC enable status:<br>0=disabled; 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.                                                                                                                              |

64

POWER MANAGEMENT



# POWER MANAGEMENT

The Solo-1 is a high-performance device with low power consumption. In addition to the low-power deep submicron CMOS mixed-signal technology used to process the Solo-1, various features are designed into the device to provide benefits from popular power-saving techniques.

#### CLKRUN Protocol

The PCI CLKRUN feature is one of the primary methods of power management on the PCI bus interface of the Solo-1 for the notebook computer. The protocol is defined in the "PCI Mobile Design Guide", published by the PCI Special Interest Group (PCISIG). To use this feature, a PCI sideband signal, CLKRUN, must be supported by the chipset. All PCI bus signals must be in leakage control state to shut down leak current at IO buffers, as specified in the "PCI Mobile Design Guide."

#### PCI Power Management Interface (PPMI)

The "PCI Bus Power Management Interface (PPMI) Specification," also published by the PCISIG, establishes the infrastructure required to let the operating system control the power of PCI functions. This is done by defining standard PCI interface and operations to manage the power of PCI functions on the bus. PCI functions can be assigned one of five power management states, and the PCI bus itself can be assigned one of four power management states. The Solo-1 (as a PCI function) supports the following five power-management states:

- D0 full power
- D1 embedded DSP is halted
- D2 D1 and analog functions are off
- D3<sub>hot</sub> D2 and oscillator are off
- D3<sub>cold</sub> power supply is off

To minimize the power consumed by the Solo-1 in  $D3_{hot}$  state, the PCI bus should be in B2 or B3 state, where the PCI clock is stopped.

All PPMI registers are located in the PCI configuration space. This allows the operating system to identify the power management capabilities of the Solo-1 without a special driver.



# **ELECTRICAL CHARACTERISTICS**

#### **Absolute Maximum Ratings**

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

**WARNING:** Stressing the device beyond the "Absolute Maximum Ratings" may cause permanent damage. These 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 Solo-1 was designed to operate at temperatures between 0°C and +85°C.

#### **Operating Conditions**

The Solo-1 digital and analog characteristics operate under the following conditions:

| VDDD | 4.75 V to 5.25 V (5   | 5 volts ± 5%) |
|------|-----------------------|---------------|
| VDDA | 4.75 V to 5.25 V (5 v | olts ± 5%)    |
| ТА   | 25 °C                 |               |

#### **Operating Current (Typical)**

| Operation | Digital | Analog |
|-----------|---------|--------|
| D0        | 40 mA   | 61 mA  |
| D1        | 15 mA   | 61 mA  |
| D2        | 14 mA   | 61 mA  |
| D3        | 400 μΑ  | 8 μΑ   |

#### Table 28 Digital Characteristics

| Parameter                                                                 | Symbol | Min    | Тур | Max      | Unit (conditions)       |
|---------------------------------------------------------------------------|--------|--------|-----|----------|-------------------------|
| Input high voltage: all inputs except<br>MSD, MCLK, SW(A-D), VOLUP, VOLDN | VIH1   | 2.0 V  |     | VDDD+0.5 | VDDD = min              |
| Input high voltage: MSD, MCLK                                             | VIH2   | 2.6 V  |     |          | VDDD = min              |
| Input high voltage: SW(A-D), VOLUP, VOLDN                                 | VIH3   | 4.1 V  |     |          | VDDD = min              |
| Input low voltage: all inputs except<br>MSD, MCLK, SW(A-D), VOLUP, VOLDN  | VIL1   | -0.5 V |     | 0.8 V    | VDDD = max              |
| Input low voltage: MSD, MCLK                                              | VIL2   |        |     | 1.2 V    | VDDD = max              |
| Input low voltage: SW(A-D), VOLUP, VOLDN                                  | VIL3   |        |     | 1.3 V    | VDDD = max              |
| Output high voltage: all outputs except IRQ[5,7,9,10]                     | VOH1   | 2.4 V  |     |          | IOH = -3 mA, VDDD = min |
| Output high voltage: IRQ[5,7,9,10]                                        | VOH2   | 2.4 V  |     |          | IOH = -8 mA, VDDD = min |
| Output low voltage: all outputs except IRQ[5,7,9,10]                      | VOL1   |        |     | 0.55 V   | IOL = 6 mA, VDDD = max  |
| Output low voltage: IRQ[5,7,9,10]                                         | VOL2   |        |     | 0.4 V    | IOL = 12 mA, VDDD = max |

#### SOLO-1 DATA SHEET

ELECTRICAL CHARACTERISTICS

PRELIMINARY



Table 29 Analog Characteristics

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



# TIMING DIAGRAMS













<sup>&</sup>lt;sup>1.</sup> PCI signals include: AD[31:0], CBE[3:0]B, PAR, FRAMEB, IRDYB, TRDYB, STOPB, IDSEL, DEVSELB, REQB, GNTB, LOCKB, CLKRUNB, PCPCIREQB, and PCPCIGNTB

TIMING CHARACTERISTICS



# **TIMING CHARACTERISTICS**

Table 30 Timing Characteristics

| Symbol          | Parameter                                     | Min  | Тур | Max  | Units          |
|-----------------|-----------------------------------------------|------|-----|------|----------------|
| t <sub>1</sub>  | PCLK cycle time                               | 30   |     | inf. | ns             |
| t <sub>2</sub>  | PCLK high time                                | 11   |     |      | ns             |
| t <sub>3</sub>  | PCLK low time                                 | 11   |     |      | ns             |
| -               | PCLK slew rate                                | 1    |     | 4    | V/ns           |
| t <sub>4</sub>  | PRST# active time after power stable          | 1    |     |      | ms             |
| t <sub>5</sub>  | PRST# active time after PCLK stable           | 1000 |     |      | t <sub>1</sub> |
| t <sub>6</sub>  | PCLK to signal valid delay (except REQB)      | 2    |     | TBD  | ns             |
| t <sub>7</sub>  | PCLK to signal valid delay (REQB)             |      |     |      | ns             |
| t <sub>8</sub>  | Float to active delay                         | 2    |     |      | ns             |
| t <sub>9</sub>  | Active to float delay                         |      |     | 28   | ns             |
| t <sub>10</sub> | Input setup time to PCLK (except IDSEL, GNTB) | 7    |     |      | ns             |
| t <sub>11</sub> | Input setup time to PCLK (IDSEL, GNTB)        | 12   |     |      | ns             |
| t <sub>12</sub> | Input hold time from PCLK                     | 0    |     |      | ns             |



# **MECHANICAL DIMENSIONS**





| Cumb al | Description               | Millimeters |       |       |  |
|---------|---------------------------|-------------|-------|-------|--|
| Symbol  | Description               | Min         | Nom   | Max   |  |
| D       | Lead to lead, X-axis      | 15.75       | 16.00 | 16.25 |  |
| D1      | Package's outside, X-axis | 13.90       | 14.00 | 14.10 |  |
| E       | Lead to lead, Y-axis      | 15.75       | 16.00 | 16.25 |  |
| E1      | Package's outside, Y-axis | 13.90       | 14.00 | 14.10 |  |
| A1      | Board standoff            | 0.05        | 0.10  | 0.15  |  |
| A2      | Package thickness         | 1.35        | 1.40  | 1.45  |  |
| b       | Lead width                | 0.17        | 0.22  | 0.27  |  |
| е       | Lead pitch                | -           | 0.50  | -     |  |
| e1      | Lead gap                  | 0.24        | -     | -     |  |
| L       | Foot length               | 0.45        | 0.60  | 0.75  |  |
| L1      | Lead length               | 0.93        | 1.00  | 1.07  |  |
| -       | Foot angle                | 0°          |       | 7°    |  |
| -       | Coplanarity               | -           | -     | 0.102 |  |
| -       | Leads in X-axis           | -           | 25    | -     |  |
| -       | Leads in Y-axis           | -           | 25    | -     |  |
| -       | Total leads               | -           | 100   | -     |  |
| -       | Package type              | -           | TQFP  | -     |  |

Figure 15 Solo-1 Mechanical Dimensions

PRELIMINARY



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 Solo-1 must be set high. When bit 4 is set high, activity on the MCLK signal causes the Solo-1 to connect the FM DAC to the ES689/ES69x. If MCLK stays low for more than a few sample periods, the Solo-1 reconnects the FM DAC to the FM synthesizer.

After reset, the ES689/ES69x transmits 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. For more information on system exclusive commands, see the appropriate ES689/ES69x Data Sheet. In this mode, the ES689/ES69x blocks the serial port output (i.e., sets MSD and MCLK low) if no MIDI input is detected on the MSI pin for a period of 5 seconds. It resumes 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 MHz                                    |
|-------------------------|---------------------------------------------|
| Sample Rate:            | 42,968.75 Hz                                |
| MCLK 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: SCHEMATICS**



APPENDIX B: SCHEMATICS





Figure 17 ES692 Schematic

C40 1.0UF

APPENDIX B: SCHEMATICS









Figure 19 PC Interface



# **APPENDIX C: BILL OF MATERIALS**

Table 31 Solo-1 Bill of Materials (BOM)

| ltem | 1  | Reference                                                                          | Part               |
|------|----|------------------------------------------------------------------------------------|--------------------|
| 1    | 1  | C1                                                                                 | 150 pF             |
| 2    | 11 | C2,C3,C4,C5,C6,C24,C25,C26,C47,C50,C52                                             | .01 µF             |
| 3    | 4  | C7,C8,C37,C39                                                                      | 10 pF              |
| 4    | 20 | C9,C12,C14,C20,C21,C22,C23,C35,C41,C42,C43,C48,C49,<br>C51,C59,C61,C62,C63,C64,C66 | .1 μF              |
| 5    | 5  | C10,C11,C58,C60,C65                                                                | 10 μF              |
| 6    | 1  | C13                                                                                | .047 μF            |
| 7    | 2  | C15,C45                                                                            | 47 μF              |
| 8    | 12 | C16,C17,C18,C19,C29,C30,C31,C32,C33,C34,C46,C56                                    | .22 μF             |
| 9    | 2  | C27,C28                                                                            | 680 pF             |
| 10   | 1  | C36                                                                                | 3.3 μF             |
| 11   | 1  | C38                                                                                | .001 μF            |
| 12   | 3  | C40,C55,C57                                                                        | 1.0 μF             |
| 13   | 1  | C44                                                                                | 100 μF             |
| 14   | 2  | C53,C54                                                                            | 470 μF             |
| 15   | 1  | J1                                                                                 | DB15S              |
| 16   | 1  | J2                                                                                 | 4x1 HEADER         |
| 17   | 1  | J3                                                                                 | 2x1 HEADER         |
| 18   | 4  | J4,J5,J8,J9                                                                        | 3.5 mm STEREO JACK |
| 19   | 2  | J6,J7                                                                              | 3x1 HEADER         |
| 20   | 1  | J10                                                                                | 3x2 HEADER         |
| 21   | 11 | L1,L2,L3,L4,L6,L7,L8,L9,L10,L11,L12                                                | FERRITE BEAD       |
| 22   | 1  | L5                                                                                 | 2.2 μΗ             |
| 23   | 1  | Q1                                                                                 | FMMT3906           |
| 24   | 10 | R1,R2,R3,R4,R5,R6,R7,R8,R15,R20                                                    | 2.2K               |
| 25   | 4  | R9,R24,R39,R40                                                                     | 10K                |
| 26   | 2  | R10,R11                                                                            | 7.5K               |
| 27   | 4  | R12,R13,R14,R19                                                                    | 1M                 |
| 28   | 3  | R16,R17,R25                                                                        | 1К                 |
| 29   | 1  | R43                                                                                | 0 ohm              |
| 30   | 1  | R22                                                                                | 47K                |
| 31   | 1  | R23                                                                                | 27K                |
| 32   | 2  | R26,R27                                                                            | 33K                |
| 33   | 4  | R28,R29,R30,R31                                                                    | 820K               |
| 34   | 2  | R32,R33                                                                            | 2.7ohm             |
| 35   | 2  | R34,R35                                                                            | 220K               |
| 36   | 2  | R37,R38                                                                            | 100K               |
| 37   | 1  | R36                                                                                | 470 ohm            |
| 38   | 2  | \$1,\$2                                                                            | PUSHBUTTON         |
| 39   | 1  | U1                                                                                 | 78L05              |
|      |    | U2                                                                                 | Solo-1             |

PRELIMINARY



APPENDIX C: BILL OF MATERIALS

# Table 31 Solo-1 Bill of Materials (BOM) (Continued)

| ltem | Quantity | Reference | Part       |
|------|----------|-----------|------------|
| 41   | 1        | U3        | LT1129-3.3 |
| 42   | 1        | U4        | ES692-100  |
| 43   | 1        | U5        | LM1877     |
| 44   | 1        | Y1        | 14.318 MHz |
| 45   | 1        | Y2        | 33.000 MHz |



# **APPENDIX D: LAYOUT GUIDELINES**

## **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, corelogic (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 20), 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 21), the analog ground planes are on both sides of the PCB, and the analog traces are shielded in the middle.



#### **Special Notes**

78

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.

APPENDIX D: LAYOUT GUIDELINES



APPENDIX D: LAYOUT GUIDELINES



ESS Technology, Inc. 48401 Fremont Blvd. Fremont, CA 94538 Tel: 510-492-1088 Fax: 510-492-1098 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.

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

All specifications are subject to change without prior notice.

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

(P) U.S. Patent 4,214,125 and others, other patents pending.

 $\textit{Audio}Drive^{\texttt{0}}$  and  $\texttt{ESPCM}^{\texttt{0}}$  are registered trademarks of ESS Technology, Inc.

Solo-1TM and  $\text{ESFM}^{\text{TM}}$  are trademarks of ESS Technology, Inc.

All other trademarks are owned by their respective holders and are used for identification purposes only.