

AD1812 SoundPort Controller

**Technical Reference** 

You may contact the Computer Products Division in the following ways:

- By contacting your local Analog Devices Sales Representative or Authorized Distributor
- For Marketing information, call (617) 461-3881 in Norwood, Massachusetts, USA
- For Applications Engineering information, call (617) 461-3672 in Norwood, Massachusetts, USA ; applications e-mail address is as follows: dsp\_applications@analog.com
- The Norwood office may also be reached by FAX: (617) 461-3010, Telex: 924491, TWX: 710/394-6577, Cables: ANALOG NORWOODMASS
- The Computer Products Division runs a Bulletin Board Service that can be reached at speeds up to 14,400 baud, no parity, 8 bits data, 1 stop bit, by dialing (617) 461-4258. This BBS supports: V.32bis, error correction (V.42 and MNP classes 2, 3, and 4), and data compression (V.42bis and MNP class).
- The Computer Products Division runs an FTP site that can be reached by typing: ftp ftp.analog.com or ftp 137.71.23.21
- By writing to:

Analog Devices Computer Products Division One Technology Way, P.O. Box 9106 Norwood, MA 02062-9106 USA

• The Computer Products Division Technical Publications staff appreciates your comments on this and other product documentation; the publication group's e-mail address is as follows:

dsp\_techpubs@analog.com

AD1812 SoundPort Controller Technical Reference

PRELIMINARY DOCUMENTATION NOTICE: Analog Devices reserves the right to change this product without prior notice. Information furnished by Analog Devices is believed to be accurate and reliable. However, no responsibility is assumed by Analog Devices for its use; nor for any infringement of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under the patent rights of Analog Devices.

SoundPort<sup>®</sup> is trademarks of Analog Devices, Inc. Sound Blaster<sup>®</sup> is a registered trademark of Creative Labs, Ltd. MS-DOS<sup>®</sup> and Windows<sup>TM</sup> are trademarks of Microsoft, Inc. MPU-401<sup>®</sup> is a registered trademark of Roland AdLib<sup>TM</sup> is a trademark of AdLib Multimedia

© 1995 Analog Devices, Inc., ALL RIGHTS RESERVED

PRINTED IN USA Second Edition (Latest Revision : October 27, 1995)

## Contents

#### LIST OF FIGURES & TABLES

| CHAPTER 1 INTRODUCTION                                          |      |
|-----------------------------------------------------------------|------|
| 1.1 Overview                                                    |      |
| 1.2 AD1812 System Architecture                                  |      |
| 1.3 AD1812 Development                                          |      |
| 1.4 MANUAL CONVENTIONS                                          |      |
| 1.5 MANUALORGANIZATION                                          |      |
| 1.6 MANUALERRATA                                                |      |
| CHAPTER 2 AD1812 PROGRAMMING                                    |      |
| 2.1 Overview                                                    |      |
| 2.2 AD1812 PLUG & PLAY DEVICE CONFIGURATION                     |      |
| 2.3 AD1812 Non-Plug & Play Device Configuration                 |      |
| 2.4 AD1812 WINDOWS SOUND SYSTEM CODEC PROGRAMMING               |      |
| 2.4.1 Codec Data Formats & Sequencing                           |      |
| 2.4.2 Codec DMA & PIO Data Transfers                            |      |
| 2.4.3 Codec I/O Mixing, Gain, & Attenuation                     |      |
| 2.4.4 Codec Autocalibration                                     |      |
| 2.4.5 Codec Sample Rate Operations                              |      |
| 2.4.6 Codec Powerdown Operations                                |      |
| 2.4.7 Codec Comparison (AD1845 Vs. AD1812's Integrated Codec.)  |      |
| 2.5 AD1812 PROGRAMMINGSUMMARY                                   | 2-44 |
| CHAPTER 3 AD1812 REGISTERS                                      |      |
| 3.1 Overview                                                    |      |
| 3.2 AD1812 PLUG & PLAY AND NON-PLUG & PLAY REGISTERS            |      |
| 3.2.1 Plug & Play And Non-Plug & Play ISA Bus Registers (Ports) |      |
| 3.2.2 Plug & Play And Non-Plug & Play Indexed Registers         |      |
| 3.3 AD1812 WINDOWS SOUND SYSTEM REGISTERS                       |      |
| 3.3.1 Windows Sound System ISA Bus Registers (Ports.)           |      |
| 3.3.2 Windows Sound System Indexed Registers                    |      |
| 3.4 AD1812 Sound Blaster Pro ISA Bus Registers (Ports)          |      |
| 3.5 AD1812 ADLIB ISA BUS REGISTERS (PORTS)                      |      |
| 3.6 AD1812 MIDI MPU-401 ISA B/s Registers (Ports)               |      |
| 3.7 AD1812 GAME PORT                                            |      |
| 3.8 AD1812 Register Summary                                     | 3-64 |
| CHAPTER 4 AD1812 REFERENCE DESIGN                               | 4-65 |
| 4.1 Overview                                                    | 4-65 |
| 4.2 Reference Design Architecture                               |      |
| 4.3 Design Information                                          | 4-68 |

#### INDEX

# List Of Figures & Tables

| FIGURE 1.1 AD1812 SOUNDPORT CONTROLLER BLOCK DIAGRAM                         | 1-1  |
|------------------------------------------------------------------------------|------|
| FIGURE 1.2 AD1812 PC PLUG-IN CARD                                            | 1-3  |
| FIGURE 1.3 AD1812 SOUNDPORT CONTROLLER SYSTEM ARCHITECTURE                   | 1-4  |
| FIGURE 2.1 STEREO 16-BIT (LINEAR BIG & LITTLE ENDIAN) AUDIO DATA             | 2-25 |
| FIGURE 2.2 MONO 16-BIT (LINEAR BIG & LITTLE ENDIAN) AUDIO DATA               | 2-25 |
| FIGURE 2.3 STEREO 8-BIT (LINEAR, µ-LAW, & A-LAW) AUDIO DATA                  | 2-25 |
| FIGURE 2.4 MONO 8-BIT (LINEAR, µ-LAW, & A-LAW) AUDIO DATA                    | 2-26 |
| FIGURE 2.5 MONO 4-BIT (IMA-ADPCM) AUDIO DATA                                 | 2-26 |
| FIGURE 2.6 MONO 4-BIT (IMA-ADPCM) AUDIO DATA                                 | 2-26 |
| FIGURE 2.7 CODEC TRANSFERS 16-BIT INTERFACE                                  | 2-27 |
| FIGURE 2.8 CODEC TRANSFERS 16-BIT INTERFACE                                  | 2-29 |
| FIGURE 2.9 CODEC TRANSFERS 8-BIT INTERFACE                                   |      |
| FIGURE 2.10 MAP OF AD1812 INTEGRATED CODEC (WITH CONTROL REGISTERS)          | 2-36 |
| FIGURE 3.1 REGISTER DIAGRAM EXAMPLE                                          |      |
| FIGURE 3.2 AD1812 PLUG & PLAY REGISTER INDEXING                              |      |
| FIGURE 3.3 VENDOR DEFINED POWERDOWN PLUG & PLAY REGISTER                     |      |
| FIGURE 3.4 WINDOWS SOUND SYSTEM CODEC INDEX ADDRESS REGISTER                 | 3-9  |
| FIGURE 3.5 WINDOWS SOUND SYSTEM CODEC INDEXED DATA REGISTER                  | 3-12 |
| FIGURE 3.6 WINDOWS SOUND SYSTEM CODEC STATUS REGISTER                        |      |
| FIGURE 3.7 WINDOWS SOUND SYSTEM CODEC PROGRAMMEDI/O DATA REGISTER            | 3-16 |
| FIGURE 3.8 CODEC REG.—LEFT INPUT CONTROL (INDEX: 0x00)                       | 3-22 |
| FIGURE 3.9 CODEC REG.—RIGHT INPUT CONTROL (INDEX: 0x01)                      | 3-23 |
| FIGURE 3.10 CODEC REG.—LEFT AUX #1 INPUT CONTROL (INDEX: 0x02)               | 3-24 |
| FIGURE 3.11 CODEC REG.—RIGHT AUX #1 INPUT CONTROL (INDEX: 0x03)              | 3-25 |
| FIGURE 3.12 CODEC REG.—LEFT AUX #2 INPUT CONTROL (INDEX: 0x04)               | 3-26 |
| FIGURE 3.13 CODEC REG.—RIGHT AUX #2 INPUT CONTROL (INDEX: 0x05)              | 3-27 |
| FIGURE 3.14 CODEC REG.—LEFT OUTPUT CONTROL (INDEX: 0x06)                     | 3-28 |
| FIGURE 3.15 CODEC REG.—RIGHT OUTPUT CONTROL (INDEX: 0x07)                    | 3-29 |
| FIGURE 3.16 CODEC REG.—CLOCK AND DATA FORMAT (INDEX: 0x08)                   |      |
| FIGURE 3.17 CODEC REG.—INTERFACE CONFIGURATION (INDEX: 0x09)                 | 3-32 |
| FIGURE 3.18 CODEC REG.—PIN CONTROL (INDEX: 0x0A)                             | 3-35 |
| FIGURE 3.19 CODEC REG.—TEST AND INITIALIZATION (INDEX: 0x0B)                 |      |
| FIGURE 3.20 CODEC REG.—MISCELLANEOUSINFORMATION(INDEX: 0x0C)                 | 3-38 |
| FIGURE 3.21 CODEC REG.—DIGITAL MIX/ATTENUATION (INDEX: 0x0D)                 | 3-39 |
| FIGURE 3.22 CODEC REG.—UPPER BASE COUNT (INDEX: 0x0E)                        | 3-40 |
| FIGURE 3.23 CODEC REG.—LOWER BASE COUNT (INDEX: 0x0F)                        | 3-40 |
| FIGURE 3.24 CODEC REG.—ALT. FEATURE ENABLE/LEFT MIC INPUT CTRL (INDEX: 0x10) |      |
| FIGURE 3.25 CODEC REG.—MIC MIX ENABLE/RIGHT MIC INPUT CTRL (INDEX: 0x11)     | 3-43 |
| FIGURE 3.26 CODEC REG.—LEFT LINE GAIN, ATTENUATE, MUTE, MIX (INDEX: 0x12)    | 3-45 |
| FIGURE 3.27 CODEC REG.—RIGHT LINE GAIN, ATTENUATE, MUTE, MIX (INDEX: 0x13)   | 3-46 |
| FIGURE 3.28 CODEC REG.—LOWER TIMER (INDEX: 0x14)                             | 3-47 |
| FIGURE 3.29 CODEC REG.—UPPER TIMER (INDEX: 0x15)                             |      |
| FIGURE 3.30 CODEC REG.—UPPER FREQUENCY SELECT (INDEX: 0x16)                  | 3-49 |
| FIGURE 3.31 CODEC REG.—LOWER FREQUENCY SELECT (INDEX: 0x17)                  |      |
| FIGURE 3.32 CODEC REG.—CAPTURE PLAYBACK TIMER (INDEX: 0x18)                  |      |
| FIGURE 3.33 CODEC REG.—REVISION ID (INDEX: 0x19)                             |      |
| FIGURE 3.34 CODEC REG.—MONO CONTROL (INDEX: 0x1A)                            |      |
| FIGURE 3.35 CODEC REG.—POWER-DOWN CONTROL (INDEX: 0x1B)                      |      |
| FIGURE 3.36 CODEC REG.—CAPTURE DATA FORMAT CONTROL (INDEX: 0x1C)             | 3-56 |

| FIGURE 3.37 CODEC REG.—CRYSTAL, CLOCK SELECT/TOTAL POWER-DOWN (INDEX: 0x1D)       | 3-58 |
|-----------------------------------------------------------------------------------|------|
| FIGURE 3.38 CODEC REG.—CAPTURE UPPER BASE COUNT (INDEX: 0x1E)                     | 3-59 |
| FIGURE 3.39 CODEC REG.—CAPTURE LOWER BASE COUNT (INDEX: 0x1F)                     | 3-59 |
| FIGURE 3.40 MIDI DATA REGISTER                                                    | 3-62 |
| FIGURE 3.41 MIDI STATUS/COMMAND REGISTER                                          | 3-63 |
| FIGURE 3.42 REGISTER OVERVIEW                                                     | 3-64 |
| FIGURE 4.1 SOUNDPORT REFERENCE DESIGN BOARD I/O                                   | 4-66 |
| FIGURE 4.2 AD1812 REFERENCE DESIGN BOARD, SCHEMATIC PAGE 1 OF 4                   | 4-69 |
| FIGURE 4.3 AD1812 REFERENCE DESIGN BOARD, SCHEMATIC PAGE 2 OF 4                   | 4-70 |
| FIGURE 4.4 1812 REFERENCE DESIGN BOARD, SCHEMATIC PAGE 3 OF 4                     | 4-71 |
| FIGURE 4.5 AD1812 REFERENCE DESIGN BOARD, COMPONENT SIDE SILK-SCREEN              |      |
|                                                                                   |      |
| TABLE 1.1       AD1812       SoundPort Controller Features                        | 1-3  |
| TABLE 1.2    MANUAL TEXT & SYMBOL CONVENTIONS.                                    | 1-8  |
| TABLE 2.1 AD1812 LOGICAL DEVICES AND COMPATIBLE PLUG & PLAY DEVICE DRIVERS        | 2-3  |
| TABLE 2.2       PLUG & PLAY ISA BUS REGISTERS (PNP PIN ASSERTED)                  | 2-4  |
| TABLE 2.3 PLUG & PLAY AD1812 LOGICAL DEVICES-DESCRIPTORS-CONFIGURATIONS           | 2-5  |
| TABLE 2.4 NON-PLUG & PLAY ISA BUS REGISTERS (PNP PIN DE-ASSERTED)                 | 2-10 |
| TABLE 2.5 NON-PLUG & PLAY AD1812 ADDRESS REGISTER VALUES                          |      |
| TABLE 2.6 NON-PLUG & PLAY AD1812 ADDRESS REGISTER VALUES (WINDOWS SOUND SYSTEM,   |      |
| LDN==0)                                                                           | 2-12 |
| TABLE 2.7 NON-PLUG & PLAY AD1812 ADDRESS REGISTER VALUES (SOUND BLASTER, LDN==1)  | 2-15 |
| TABLE 2.8 NON-PLUG & PLAY AD1812 ADDRESS REGISTER VALUES (ADLIB MUSIC SYNTHESIS,  |      |
| LDN==2)                                                                           | 2-16 |
| TABLE 2.9 NON-PLUG & PLAY AD1812 ADDRESS REGISTER VALUES (MIDI, LDN==3)           | 2-17 |
| TABLE 2.10 NON-PLUG & PLAY AD1812 ADDRESS REGISTER VALUES (GAME PORT, LDN==4)     | 2-19 |
| TABLE 2.11 NON-PLUG & PLAY AD1812 ADDRESS REGISTER VALUES (MODEM, LDN==5)         | 2-20 |
| TABLE 2.12 CODEC TRANSFERS 16-BIT INTERFACE, NO BYTE SWAP (P/CINF8=0, P/CBSW=0)   | 2-27 |
| TABLE 2.13 CODEC TRANSFERS 16-BIT INTERFACE, WITH BYTE SWAP (P/CINF8=0, P/CBSW=1) | 2-29 |
| TABLE 2.14       CODEC TRANSFERS8-BIT INTERFACE (P/CINF8=1)                       | 2-31 |
| TABLE 2.15    POWERDOWN BITS (PLUG & PLAY VERSUS CODEC)                           | 2-40 |
| TABLE 2.16    POWER DOWN MODE SUMMARY                                             | 2-41 |
| TABLE 2.17 COMPARISON OF AD1845 Vs. AD1812'S CODEC                                | 2-42 |
| TABLE 3.1    MAP OF AD1812 ISA Bus Registers.                                     | 3-2  |
| TABLE 3.2       PLUG & PLAY ISA BUS REGISTERS (PNP PIN ASSERTED)                  |      |
| TABLE 3.3 NON-PLUG & PLAY ISA BUS REGISTERS (PNP PIN DE-ASSERTED)                 | 3-3  |
| TABLE 3.4       MAP OF AD1812       PLUG & PLAY—INDEXED REGISTERS                 |      |
| TABLE 3.5    MAP OF WINDOWS SOUND SYSTEM REGISTER BITS                            | 3-8  |
| TABLE 3.6       MAP OF AD1812       WINDOWS SOUND SYSTEM CODEC—INDEXED REGISTERS  | 3-18 |
| TABLE 3.7       MAP OF WINDOW SOUND SYSTEM INDEXED REGISTER BITS                  | 3-20 |
| TABLE 3.8    Sound Blaster Pro ISA Bus Registers                                  | 3-60 |
| TABLE 3.9    ADLIB ISA BUS REGISTERS                                              | 3-61 |
| TABLE 3.10   MIDI ISA Bus Registers                                               |      |
| TABLE 3.11    GAME PORT ISA BUS REGISTER (PORT)                                   | 3-64 |

### 1.1 Overview

The purpose of the AD1812 SoundPort Controller User's Manual is to provide an audience of programmers, engineers, and OEMs with the information required to program the chip, design PC motherboards (and plug-in boards) using the chip, and manufacture AD1812 based boards.

The AD1812 SoundPort Controller integratescodec, synthesis, and bus interface functions into a single chip audio sub-system — adding lessost 16-bit stereo audio to any ISA busequippedPC. Motherboard or PC plug-in designs using the AD1812 are compatible with virtually all applications written to measure Blaster® Pro, Ad Lib<sup>TM</sup>, MIDI MPU-401, Windows 95®, and the Microsof® Windows<sup>TM</sup> Sound System standards.



Figure 1.1 AD1812 SoundPort Controller Block Diagram

Figure 1.1 shows the AD1812 audio sub-system combines following components

- ADSP-2171 DSP with RAM & ROM
- AD1845 SoundPortStereo Codec
- Plug & Play Compatible ISA Bus Interface

This combinationprovides five Plug & Playlogical devices:

- Windows Sound System Code(application-level compatible)
- Sound BlasterPro (register level compatible
- AdLib (OPL-3 FM parameter compatible usic synthesize)
- MIDI MPU-401 Port
- Game/Joystick Port
- Modem

The AD1812 contains a register set that corresponds to those used for bound Blaster Pro Windows Sound System, MIDI MPU-401, Game/Joystick Port, and Plug Play Configuration.

All logical devices in the AD1812 are compliant with the Intel/Microsoft Plug & Play Specification.Devices (Windows Sound System, MIDI, etc. ...) are automatically configured at system start. Through the Plug & Play mechanism, the operating system can reconfigure the AD1812, avoiding conflicts with other hardware devices AD1812 also can be programmed in a non-Plug & Play environment.

The PC plug-in cardshown in Figure 1.2illustrates how few additional components are needed to build an AD1812 board. Only a power Amp and a few discrete components are needed to build an AD1812 plug-in card — even fewer are required to add an AD1812 to a motherboard design.Table 1.1 contains a summary of the controller's features.





| • | Single-Chip Integration      | - | 16-bit Stereo Codec                                       |
|---|------------------------------|---|-----------------------------------------------------------|
|   |                              | - | Music Synthesizer                                         |
|   |                              | - | 16-bit ISA Bus Interface                                  |
|   |                              | - | Power Management                                          |
|   |                              | - | Game Port                                                 |
| • | Industry StandardsCompliance | - | Sound BlasterPro <sup>TM</sup>                            |
|   |                              | - | Microsoft <sup>®</sup> Windows <sup>TM</sup> Sound System |
|   |                              | - | General MIDI & MPU-401                                    |
|   |                              | - | Plug & Play Configurable                                  |
| • | Available Software Support   | - | Microsoft <sup>®</sup> Windows <sup>TM</sup> 3.1 Drivers  |
|   |                              | - | Microsoft <sup>®</sup> Windows <sup>TM</sup> 95 Drivers   |
|   |                              | - | Windows <sup>TM</sup> Control & Diagnostic Applets        |
| • | Integrated Codec Advantages  | - | Full-Duplex Operation                                     |
|   | -                            | - | DynamicSample Rate Variation from kHz                     |
|   |                              |   | to 50 kHz (in 1 Hz increments)                            |

## 1.2 AD1812 System Architecture

As shown in Figure 1.3, the AD1812 SoundPort Controller's architecture connects a set of Plug & Play logical devices to the PC ISA bus. These devices include a Sound Blaster Pro compatible device (SB), an AdLib compatible device (ADLIB), a Windows Sound System device (WSS), a MIDI MPU-401 compatible device (MIDI), and a Game Port device (GAME). The AD 1812 also provides a Plug and Play ISA bus interface for an external modem chipset. To provide these devices, theoSindPort Controller's architecture combines a codec, digital signal processor, and **m** ISA bus interface **m** a single chip.

The AD1812's PC ISA bus interface (INTERFACE) connects the DOS games register set, Windows Sound System register setand music synthesis hardware to the ISA bus using a fully compatible Plug& Play (PnP) configurationinterface. Hardware support in the AD1812 includes address decoding for on-hip devices control & signal interpretation, DMA selection& control logic, IRQ selection& control logic, and interface configuration logic.



- The three functional units (Codec, DSP, & Interface) that make up the AD1812 controller have the following architectural features.
- Codec

A modified AD1845 stereo-audio 16-bi  $\Delta$  codec is integrated into the AD1812 controller. This codec provides support for business audio and multi-media applications withstereo audio converters, completeon-chip filtering(some external capacitors required) MPC Level-2 compliant analog mixing, programmable gas attenuation, a variable sample attenuator, and FIFO buffers.

The codec's architecture includes a stereo pair of  $\Sigma \Delta$  analog-to-digital converters (ADC) and a stereo pair of  $\Sigma \Delta$  digital-to-analog converters(DAC). You can select inputs to the ADC from four stereo pairs of analog signals: line (LINE), microphone (MIC), auxiliary line #1 (AUX1), and post-mixed DAC outpuAn analog mixerlets you mixmono (MONO\_IN), MIC, AUX1, LINE and auxiliary line #2 (AUX2) nputs with the DACs' output. Independent gain for each channel going into the ADIS available through  $\infty$ oftware-controlled programmable gain stageThis architecture also lets you digitallymix the ADCs' output with the DACs' inputAlso, the codec includes avariable samplerate frequency generatorthat lets you instantaneously change the codec's sample rate with a resolution of 1 HzCreating audio special effects (like Doppler-effect bullet-shots) without any clicks or pops is easy with this feature. The codec uses the variable sampler rate frequency generator to derive all internal clocks from a single, 14.31818 MHz clock input.

The integrated codec supports a DMA request/grant (or a Programmed I/O mode) architecture for transferring dataon the ISA bus. Dual DMA count registers in the AD1812 provide for fullduplex operation, enabling simultaneous capture and playback on separate DMA channel 8 or 16-bit).

• DSP

An ADSP-2171 Digital Signal Processor (DSP with internal ROM & RAM) is integrated into the AD1812 controller. Softwareunning on this internal signal processor provides sound effects and music synthesis by emulating the responses of the Yamaha YM262 (OPL-3)FM synthesis chip. Using this technique, the internal signal processor delivers 20voice, 11-note polyphony Music synthesized on the signal processor is converted on an additional pair of  $\Delta$  DACs and sent to the analog mixer on the codec.

• Interface

An ESC615 ISA bus interface chip (with added Plug & Play interface) is integrated into the AD1812 controller. This interface'architecture also supports Sound Blaster Pro DMA transfers (separate channel from codec).

The controller's interface complies with the Intel/Microsoft Plug & Play specification, making all onchip features automatically configurable. For compatibility withon-Plug & Play systems, you can disable the Plug & Play protocoland use a non-Plug & Play software configuration utility. In either case, the controller is completely software configurable. To provide Sound Blaster Pro, AdLib, and MIDI MPU-401 support, the interface includes registers that emulate those used by these devices.

These three architectural components (Codec, DSP, & Interface) are combined in the controller to support a broad range of PC audio conversion operations. An AD1812 based system can do the following audio operations simultaneously:

- Synthesize music and sound effects for games
- Convert compressed digital wave files into analog wave forms
- Digitize, format, and compress analog signals
- Receive and transmit MIDI MPU-401 UART information
- Communicate with an IBM compatible joystick

## 1.3 AD1812 Development

Virtually all applications developed for Sound Blaster, Windows Sound System, AdLib, and MIDI MPU-401 platforms run on the AD1812 SoundPort Controller. Follow the same development process for the controller as you would use for these other devices. This section provides information on related development kitsardware/software specifications, and reference texts.

For information on AD1812 signal timing, mechanical, and electrical specifications, see the Analog Devices:

• AD1812 SoundPort Controller Data Sheet

As the AD1812 contains Sound Blaster (compatible) and Windows Sound System logical devices, you may find the following related development kits useful when developing AD1812 applications.

- *Developer Kit for Sound Blaster Series*2nd ed. ©1993, Creative LabsInc., 1901 McCarthy Blvd., Milpitas, CA 95035
- *Microsoft Windows Sound System Driver Development Kit (CD*)Version 2.0, ©1993, Microsoft Corp., One Microsoft Way, Redmond, WA 98052

Because the AD1812 complies with the following related specificationy ou can use them as an additional reference to AD1812 operations beyond the material in this manual.

- *Plug & Play ISA Specification Version 1.0a*, ©1993,1994, Intel Corp. & Microsoft Corp., One Microsoft Way, Redmond, WA 98052
- *Multimedia PC Level 2 Specification*©1993, Multimedia PC Marketing Council, 1730 M St. NW, Suite 707, Washington, DC 20036

- *MIDI 1.0 Detailed Specification& Standard MIDI Files 1.Q* ©1994, MIDI Manufacturers Association, PO Box 3173 La Habra, CA 90632-3173
- Recommendation G.711—Pulse Code Modulation (PCM) Of Voice Frequenciep-Law & A-LawCompanding, The International Telegraph and Telephone Consultative Committee IX Plenary Assembly Blue Book, Volume III - Fascicle III.4, General Aspects Of Digital Transmission Systems; Terminal Equipments, Recommendations G.700 - G.795, (Geneva, 1988), ISBN 92-61-03341-5
- *IMA Digital Audio Doc-Pac*(IMA-ADPCM), ©1992, Interactive Multimedia Association, 48 Maryland Avenue, Suite 202, Annapolis, MD 21401-8011

The following reference texts an serve as additional sources of information on developing applications that run on the AD1812.

- S. De Furia & J. Scacciaferro, *The MIDI Implementation Book* (©1986, Third Earth, Pompton Lake)
- C. Petzold, *Programming Windows the Microsoft guide to writing applications for Windows 3.1*, 3rd. ed. (©1992, Microsoft Press, Redmond)
- K. Pohlmann, Principles of Digital Audia (©1989, Sams, Indianapolis)
- A. Stolz, *The Sound Blaster Book* (©1993, Abacaus, Grand Rapids)
- J. Strawn, Digital Audio Engineering An Anthology, (©1985, Kaufmann, Los Altos)
- T. Yamamoto, *MIDI Guidebook*, 4th. ed., (©1987, 1989, Roland Corp., Japan)

## 1.4 Manual Conventions

Table 1.2 lists the text and layout conventions used in this manual. In addition to the conventions shown, please note the following euphemisms and acronyms

- *Sound Blaster, Sound Blaster Prq AdLib,* and *Music Synthesis* refer to DSP-based emulation of these devices through a combination of DSP software and dedicated hardware.
- *Windows Sound System Codec*refers to a modified AD1845 Codec integrated into the AD1812 SoundPort Controller that (with custom driver software) supports Windows Sound System applications.
- *DSP* stands for Digital Signal Processor.

| Item             | Convention (how shown or used)                                                                                                                        |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Trademarks:      | Registered trademarks ( <sup>®</sup> ) and trademarks ( <sup>TM</sup> ) used in this document are <i>honored</i> in the front matter of this document |  |
| Registers:       | Registers are documented with a labeled figure and a bit definition table                                                                             |  |
| Bits:            | Bits are indicated as part of a range of bits from upper bit to lower bit, [15:0] indicates bits 15 through 0.                                        |  |
| Decimal base     | Decimal basenumbers are shown without a prefix: 2050                                                                                                  |  |
| Hexadecimal base | Hexadecimal base numbers are shown with a 0x prefix: 0x000F                                                                                           |  |
| Binary base      | Binary base numbers are shown with a 0b prefix: 0b1010,1010                                                                                           |  |
| Addresses:       | Addresses are shown as a hexadecimal numbers: 0x201                                                                                                   |  |
| (PC and AD1812)  | (Text with address indicates the type of address)                                                                                                     |  |
| Bold Text:       | Bold text is used to indicatevery important text                                                                                                      |  |
| Italic Text:     | Italic text is used to indicate important text                                                                                                        |  |
| Courier Text:    | Courier text is used to indicateprogram listings                                                                                                      |  |
| Tables:          | Tables are shown in grid boxes with title at top                                                                                                      |  |
| Figures:         | Figures are shown in a box with title at bottom                                                                                                       |  |
| Note:            | Notes indicate information crucial to step, operation, or options                                                                                     |  |
| Caution:         | Cautions indicate information crucial to avoiding component damag                                                                                     |  |
| Footnote:        | Footnotes indicate information that is not required to operate the part but can be of some assistance                                                 |  |

Table 1.2 Manual Text & Symbol Conventions

## 1.5 Manual Organization

This manual documents the AD1812 SoundPort Controller. Areas of particular interest to programmers and designers include the following:

- Chapter 2 AD1812 Programming
   The programming reference provides an overview of AD1812 programming, lists Plug & Play resource data for the AD1812's built-in logical devices, and describes how to configure/program the AD1812 when it is in non-Plug & Play mode. Also, this chapter includes descriptions of Windows Sound System Codec programming.
- Chapter 3 AD1812 Registers
   The register reference provides an overview of AD1812 registers with a map of all
   AD1812 registers and describes each register in detail. The manual presents register's
   descriptions in functional groupsRlug & Play, Windows Sound System, Sound
   Blaster Pro, MIDI, AdLib, and Game Port)
- Chapter 4 AD1812 Reference Design The design reference provides specifications for producing an AD1812-based PC plugin card. These specifications include a functional overview, an architectural description, and board schematics.

## 1.6 Manual Errata

This is the second edition of the AD1812 SoundPort Controller Technical Reference. Errata in this manual is documented on the Computer Products Division Bulletin Board Service which can be reached at speeds up to 14,400 baud, no parity, 8 bits data, 1 stop bit, dialing (617) 461-4258. This BBS supports: V.32bis, error correction (V.42 and MNP classes 2, 3, and 4), and data compression (V.42bis and MNP class).

### 2.1 Overview

Programming the AD1812 SoundPort Controller consists of setting the controller's configuration and programming the controller's logical devices (Windows Sound System, Sound Blaster, AdLib, MIDI MPU-401, modem, and Game Port). This chapter describes AD1812 Plug & Play mode configuration data, non-Plug & Play mode configuration process, and procedures for programming the integrated Windows Sound System codec.

For information on the Plug & Play mode configuration process, see t**Re**ug & Play ISA Specification Version 1.0a (May 5, 1994)All the AD1812's logical devices comply with Plug & Play resource definitions described in the specification.

For information on vendor specific Plug & Play registers and all Windows Sound System codec registers, see Chapter 3*AD1812 Registers* 

The next several sections use Plug & Play related terminology describe configuration and programming topics. Definitions of terms are as follows:

- *Plug & Play Logical Devices*—Devices that meet the Plug & Play specification for runtime configuration in an ISA bus PC.
- *System Boot*—Steps a PC system goes through at power up (BIOS, POST, & BOOT)
- *System Resources*—Standard PC system resources (i.e. I/O addresses, interrupt channels, and DMA channels)
- *Plug & Play Resource ROM*—Read-Only-Memory in the AD1812 containing a list of possible resource settings for the orchip logical devices.
- *Plug & Play Device IDs*—Product identifier that the system uses to find and start corresponding Plug & Play device drivers.
- *Plug & Play Resource Manager*–PC system software (Plug & Play BIOS or after Boot Plug & Play System Support) that provides runtime system configuration services.
- Active Plug & Play Devices—Active logical devices respond to all ISA bus cycles as per its normal operation. Inactive logical devices doot respond to nor drive any ISA bus signals.

- *Dependent functions*—Encoded interdependent options within a logical device's configuration resource data. The Plug & Play system software weighs these options, when configuring the system, to achieve the highest rating. Device configurations involving dependent functions can have the following ratings:
  - A) *Good Plug & Play Configuration*—Configuration that best serves the software using the device
  - B) Acceptable Plug & Play Configuration—Configuration that satisfactorily serves the software using the device
  - C) *Sub-optimal Plug & Play Configuration* Configuration that barely serves the software using the device

Note: The *Good*, *Acceptable*, and *Sub-optimal* ratings of dependent function configurations come from a variety of sources (i.e. most commonly recognizable I/O base addresses for devices, most useful DMA channel assignments, etc. ...). Not all devices have what could be considered*Good* configurations, but all devices do hav*Acceptable* configurations.

## 2.2 AD1812 Plug & Play Device Configuration

The operating system configures/re-configures AD1812 Plug & Play Logical Devices after system boot<sup>\*</sup>. To complete this configuration, the system reads resource data from the AD1812's on-chip resource ROM and from any other Plug & Play cards in the system, then arbitrates the configuration of system resources with a heuristic algorithm. The algorithm maximizes the number of *ctive* devices and the *acceptability* of their configurations.

The system considers all Plug & Play logical device resource data at the same time and makes a conflict-free assignment of resources to the devices. If the system cannot assign a conflict-free resource to a device, the system does not configure or activate the device. All configured devices are activated.

The system's Plug & Play support selects all necessary drivers, starts them, and outputs a list of system resources allocated to each logical device. Optionally, you can re-assign system resources at runtime with a Plug & Play Resource Manager. The custom setup created using the manager can be saved and used automatically on following system boots.

There are no "boot-devices" among the Plug & Play Logical Devices in the AD1812. Non-Plug & Play BIOS systems configure the AD1812's Logical Devices after boot using drivers. Depending on BIOS implementations, Plug & Play BIOS systemsnay configure the AD1812's Logical Devices before POST or after Boot. See the Plug & Play ISA Specification Version 1.0 dor more information on configuration control.

Plug & Play Device IDs(embedded in the logical device's resource data) provide the system with the information required to find and load the correct device drivers. In one case, a custom driver is required; the AD1812 Window Sound System driver from Analog Devices is required for correct operation. In all other cases (Sound Blaster, AdLib, MIDI, Game Port and modem), the Analog Devices custom driver is preferred, but the system can use generic drivers (that ship with all Plug & Play systems) if the custom driver is unavailable. Table 2.1 lists the AD1812's logical devices and compatible Plug & Play device drivers.

| Device Name         | ADI (Device ID) & Driver                                  | Compatible (Device ID) &                               |
|---------------------|-----------------------------------------------------------|--------------------------------------------------------|
|                     | Name                                                      | Driver Name                                            |
| Window Sound System | (ADS7140)                                                 | (None)                                                 |
|                     | ADS7140 Windows Sound<br>System                           | None                                                   |
| Sound Blaster Pro   | (ADS7141)                                                 | (PNPB002)                                              |
| (Compatible)        | ADS7141 Sound Blaster Pro                                 | PNPB002 Sound Blaster Pro                              |
| AdLib(Compatible)   | (ADS7142)                                                 | (PNPB020)                                              |
|                     | ADS7142 Yamaha OPL3-<br>compatible FM synthesis<br>device | PNPB020 Yamaha OPL3-<br>compatible FM synthesis device |
| MIDI (Compatible)   | (ADS7143)                                                 | (PNPB006)                                              |
|                     | ADS7143 MPU401 compatible                                 | PNPB006 MPU401 compatible                              |
| Game Port           | (ADS7144)                                                 | (PNPB02F)                                              |
|                     | ADS7144 Joystick/Game port                                | PNPB02F Joystick/Game port                             |
| Modem               | (ADS7145)                                                 | (PNP0501)                                              |
|                     | ADS7145 Modem                                             | PNP0501 Compatible COM port                            |

 Table 2.1 AD1812 Logical Devices And Compatible Plug & Play Device Drivers

When the AD1812's PnP pin is asserted, the chip is in Plug & Play mode configuration process for the logical devices on the AD1812 is described in the g & *Play ISA Specification Version 1.0a (May 5, 1994)*The specification describes how to transfer the logical devices from their startu Wait For Keystate to the Config state and how to assign I/O ranges, interrupt channels, and DMA channels.

Tables 2.2 and 2.3 list the Plug & Play ISA bus registers and configuration data for the AD1812 in Plug & Play mode. The resource data presented in these tables corresponds to data described in the AD1812 Resource ROM.

| Table 2.2 Thug & Thay 1511 Dus Register of Int philasserieu) |                                       |            |  |
|--------------------------------------------------------------|---------------------------------------|------------|--|
| Port Name                                                    | ISA Address                           | Туре       |  |
| ADDRESS                                                      | 0x279 (Printer status port)           | Write-only |  |
| WRITE_DATA                                                   | 0xA79 (Printer status port + 0x800)   | Write-only |  |
| READ_DATA                                                    | Relocatable in range<br>0x203 - 0x3FF | Read-only  |  |

 Table 2.2 Plug & Play ISA Bus Registers(PnP pin asserted)

| Device                                 | Descriptor                                          | Configuration                                                                                                                                                                                                                                                                     |
|----------------------------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Windows<br>Sound<br>System<br>(LDN==0) | I/O Port<br>Address<br>Descriptor 0<br>(0x60-0x61)  | The Windows Sound System address range is from 0x0008 to 0xFFF8 The most commonly used address is 0x530. The range is 8 bytes long and must be aligned to an 8 byte memory boundary.                                                                                              |
|                                        | Interrupt<br>Request<br>Level<br>Select 0<br>(0x70) | The Windows Sound System requires one of the following IRQ channels: 3, 4, 5, 7, 9, 10, 11, or 12.                                                                                                                                                                                |
|                                        | DMA<br>Channel                                      | The Windows Sound System equires one or two DMA channels. Possible configurations are as follows:                                                                                                                                                                                 |
|                                        | Select 0 (0x74),                                    | <i>Two 16-bit DMA channels</i> selected from channels 5, 6, or 7. This is the Plug & Play <i>Good</i> configuration.                                                                                                                                                              |
|                                        | DMA<br>Channel<br>Select 1                          | <i>One 16-bit DMA playbackchannel and one 8-bit DMA capture channel</i> , selected from 16-bit channels 5, 6, or 7 and 8-bit channels 0, 1, or 3. This is a Plug & Play <i>Acceptable</i> configuration.                                                                          |
|                                        | (0x75)                                              | <i>Two 8-bit DMA channels</i> selected from channels 0, 1, or 3. This is a Plug & PlayAcceptable configuration.                                                                                                                                                                   |
|                                        |                                                     | One 16-bit DMA channel selected from channels 5, 6, or<br>7. Because the channel is shared for capture and playback<br>operations, simultaneous playback and capture <b>is</b> ot<br>possible in this configuration. This a Plug & Play<br>Sub-optimal configuration.             |
|                                        |                                                     | <i>One 8-bit DMA channel</i> selected from channels 0, 1, or 3.<br>Because the channel is shared for capture and playback<br>operations, simultaneous playback and capture <i>isot</i><br>possible in this configuration. This a Plug & Play<br><i>Sub-optimal</i> configuration. |

Table 2.3 Plug & Play AD1812 Logical Devices-Descriptors-Configurations

## Table 2.3 Plug & Play AD1812 Logical Devices-Descriptors-Configurations (continued)

| (continued)                                |                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|--------------------------------------------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Device                                     | Descriptor                                          | Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| Sound<br>Blaster<br>Compatible<br>(LDN==1) | I/O Port<br>Address<br>Descriptor 0<br>(0x60-0x61)  | The Sound Blaster address range is from 0x010 to 0x3F0.<br>The range is 16 bytes long and must be aligned to a 16<br>byte memory boundary.<br>In Plug & Play terms, a Sound Blaster Configuration that<br>has a base address of 0x300 or 0x330 is Acceptable. The<br>configuration is Sub-optimal if using an address between<br>0x010 to 0x3F0 (other than 0x220 or 0x240) because most<br>games will not recognize these non-standard ports. |  |
|                                            | Interrupt<br>Request<br>Level<br>Select 0<br>(0x70) | The Sound Blaster requires one of the following IRQ channels: 3, 4, 5, 7, 9, 10, 11, or 12.                                                                                                                                                                                                                                                                                                                                                    |  |
|                                            | DMA<br>Channel<br>Select 0<br>(0x74)                | The Sound Blaster requires one 8-bit DMA channel.<br>Possible choices are (0,1,3).                                                                                                                                                                                                                                                                                                                                                             |  |
| AdLib<br>(LDN==2)                          | I/O Port<br>Address<br>Descriptor 0<br>(0x60-0x61)  | The AdLib address range is from 0x008 to 0x3F8. The range is 4 bytes long and must be aligned to an 8 byte memory boundary.<br>In Plug & Play terms, an AdLib Configuration that has a base address of 0x388 is Acceptable. The configuration is Sub-optimal if using an address between 0x008 to 0x3F8 (other than 0x388) because most games will not recognize these non-standard ports.                                                     |  |

| Table 2.3 | <b>B Plug &amp; Play</b> | AD1812 Logical Devices-Descriptors-Configurations |
|-----------|--------------------------|---------------------------------------------------|
|           |                          | (continued)                                       |
|           |                          |                                                   |

| Device                      | Descriptor                                          | Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------------------|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MIDI<br>MPU-401<br>(LDN==3) | I/O Port<br>Address<br>Descriptor 0<br>(0x60-0x61)  | The MIDI address range is from 0x008 to 0x3F8. The range is 4 bytes long and must be aligned to a 16 byte memory boundary.<br>In Plug & Play terms, a MIDI Configuration that has a base address of 0x300 or 0x330 is Acceptable. The configuration is Sub-optimal if using an address between 0x010 to 0x3F0 (other than 0x300 or 0x330) because most serial devices will not recognize these non-standard ports.                                                                                                                     |
|                             | Interrupt<br>Request<br>Level<br>Select 0<br>(0x70) | The MIDI requires one of the following IRQ channels: 3, 4, 5, 7, 9, 10, 11, or 12.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Game Port<br>(LDN==4)       | I/O Port<br>Address<br>Descriptor 0<br>(0x60-0x61)  | The Game Port address range is from 0x001 to 0x3FF. The range is 1 byte long. In Plug & Play terms, a Game Port Configuration that has a base address of 0x201 is <i>Acceptable</i> . The configuration is <i>Sub-optimal</i> if using an address between 0x001 to 0x3FF (other than 0x201) because most games will not recognize these non-standard ports.                                                                                                                                                                            |
| Modem<br>(LDN==5)           | I/O Port<br>Address<br>Descriptor 0<br>(0x60-0x61)  | The Modem device address range is from 0x008 to 0x3F8.<br>The range is 8 bytes long and must be aligned to an eight<br>byte memory boundary. In Plug & Play terms, a Modem<br>Configuration that has a base address of 0x3F8 (with<br>IRQ4), 0x2F8 (with IRQ3), 0x3E8 (with IRQ4), or 0x2E8<br>(with IRQ3) is <i>Acceptable</i> . The configuration is<br><i>Sub-optimal</i> if using an address between 0x008 to 0x3F8<br>(other than above combinations) because most serial<br>devices will not recognize these non-standard ports. |
|                             | Interrupt<br>Request<br>Level<br>Select 0<br>(0x70) | The Modem requires one of the following IRQ channels: 3 4, 5, 7, 9, 10, 11, or 12 (see I/O Port Address for address and interrupt combinations).                                                                                                                                                                                                                                                                                                                                                                                       |

### 2.3 AD1812 Non-Plug & Play Device Configuration

Configuring the AD1812 in non-Plug & Play mode is similar to configuring the device when it is in Plug & Play mode. In non-Plug & Play mode, the logical devices (Windows Sound System, Sound Blaster, AdLib, MIDI, & Game Port) on the AD1812 are locked in *Config* mode, ready to be assigned configuration data. Note that in non-Plug & Play mode all configuration decisions are left to your configuration routine rather than the operating system's Plug & Play configuration process.

Use the following procedure configure the AD1812 SoundPort Controller when the controller is in NonPlug & Play mode(PnP pin is deasserted).

- 1. Write the value 0x00 to the ADDRESS egister (PC I/O Address 0x234) (Sets the AD1812 register index to Set RD\_DATA port register)
  - Write the value 0x87 to the WRITE\_DATA register (PC I/O Address 0x235) (Sets the address for the READ\_DATA register to PC I/O Address 0x21F (or any valid RD I/O address). See Table 2.4 for a description of how the address value in WRITE\_DATA is calculated and address options.)
- 2. Write the value 0x02 to the ADDRESS register (PC I/O Address 0x234) (Sets the AD1812 register index to Config Control register)
  - Write the value 0x01 to the WRITE\_DATA register (PC I/O Address 0x235) (Resets all Plug & Play logical devices to power up values)
- **Note:** Each AD1812 logical device varies slightly in configurable features. The AD1812 Logical Device Number register (AD1812 register index 0x07) lets you select a device to configure. Once you have selected a device, AD1812 register indices 0x30 through 0xFF correspond to the configuration register of that device. The AD1812 register indices below 0x30 are always available because they are not indexed by the logical device register.

The series of steps that follow demonstrate the logical device selection/configuration process for the Windows Sound System. Use the data in Tables 2.4 through 2.10 (at the end of this procedure) to complete configuration steps for the other devices.

- 3. Write the value 0x07 to the ADDRESS egister (PC I/O Address 0x238) (Sets the AD1812 register index to Logical Device Number (LDN) register)
  - Write the value 0x00 to the WRITE\_DATA register (PC I/O Address 0x239) (Selects the Windows Sound System Plug & Play device to configure—Logical Device Number 0x00—other valid device numbers are 0x01 (Sound Blaster), 0x02 (AdLib), 0x03 (MIDI), and 0x04 (Game Port))
- Write the value 0x60 to the ADDRESS egister (PC I/O Address 0x238) (Sets the AD1812 register index to IO\_BASE, upper byte register for Windows Sound System)
  - Write the value 0x05 to the WRITE\_DATA register (PC I/O Address 0x239) (Sets upper byte of the IO\_BASE register [upper byte of the logical device's PC I/O address] to 0x05)
  - Write the value 0x61 to the ADDRESS register (PC I/O Address 0x238) (Sets the AD1812 register index to IO\_BASE, lower byte register for Windows Sound System)
  - Write the value 0x30 to the WRITE\_DATA register (PC I/O Address 0x239) (Sets lower byte of the IO\_BASE register [lower byte of the logical device's PC I/O address] to 0x30—Step 4 sets the Windows Sound System address to PC I/O Address 0x530. For other I/O Address range options, see Table 2.5.)
- Write the value 0x70 to the ADDRESS register (PC I/O Address 0x238) (Sets the AD1812 register index to Interrupt level select 0 register for Windows Sound System)
  - Write the value 0x0A to the WRITE\_DATA register (PC I/O Address 0x239) (Sets the interrupt level to 10—see Table 2.5 for additional Interrupt request level options)
- Write the value 0x74 to the ADDRESS egister (PC I/O Address 0x238) (Sets the AD1812 register index to DMA channel select *Cupture* register for Windows Sound System)
  - Write the value 0x05 to the WRITE\_DATA register (PC I/O Address 0x239) (Sets the DMA channel select 0 to channel 5, 16-bit DMA*apture*—see Table 2.5 for additional DMA options)

- Note: If you do not enable the *capture* DMA channel all DMA (both *capture* & *playback*) occurs on the *playback* DMA channel. Also, note that simultaneous capture and playback is *not* possible using single channel DMA mode.
- Write the value 0x75 to the ADDRESS egister (PC I/O Address 0x238) (Sets the AD1812 register index to DMA channel select *playback* register for Windows Sound System)
  - Write the value 0x06 to the WRITE\_DATA register (PC I/O Address 0x239) (Sets the DMA channel select 0 to channel 6, 16-bit DM*playback*—see Table 2.5 for additional DMA options)

At this point, you have configured the Windows Sound System device. The device is ready to be activated or an I/O port conflict check can be performed.

In Tables 2.4 through 2.10 the following acronyms describe register and bit types: (RO) Read Only, (WO) Write Only (WM) Write only Momentaryand (RW) Read/Write.

|            | s a may ion bus Registers                 | (1 III pill de disserted) |
|------------|-------------------------------------------|---------------------------|
| Port Name  | PC I/O Address                            | Туре                      |
| ADDRESS    | 0x234                                     | Write Only (WO)           |
| WRITE_DATA | 0x235                                     | Write Only (WO)           |
| READ_DATA  | Relocatable in the range<br>0x203 - 0x3FF | Read Only (RO)            |

 Table 2.4
 Non-Plug & Play ISA Bus Registers (PnP pin de-asserted)

|                  | Ŭ       | lay AD1812 ADDRESSRegister Values                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Name    | ADDRESS | Definition (value)                                                                                                                                                                                                                                                                                                                                                                                                          |
| Set RD_DATA Port | 0x00 WO | Sets the address-value of the READ_DATA port.<br>A write to this register must be performed before<br>any reads. The contents of RD_DATA (bits [7:0])<br>correspond to part of (bits [9:2]) the PC I/O<br>address of the READ_DATA port. The upper bits<br>[15:10] of the PC I/O address contain zeros and the<br>lower bits [1:0] contain ones <i>These bits are not</i><br>user accessible,shown in gray type in example. |
|                  |         | The location of READ_DATA is Relocatable in the range 0x203 to 0x3FF.                                                                                                                                                                                                                                                                                                                                                       |
|                  |         | <b>Example</b> To set the PC I/O address of the READ_DATA port to 0x21F, write 0x87 to the RD_DATA port register. The example below indicates the relationship between the bits in each register. Bit [7] of RD_DATA is set to 1 always.                                                                                                                                                                                    |
|                  |         | READ_DATA<br>Address: 0b0000,0010,0001,1111 = 0x21F                                                                                                                                                                                                                                                                                                                                                                         |
|                  |         | RD_DATA contents: $0b1000,0111 = 0x87$                                                                                                                                                                                                                                                                                                                                                                                      |
| Config Control   | 0x02 WM | Resets all logical devices.                                                                                                                                                                                                                                                                                                                                                                                                 |
|                  |         | Write (1) to bit [0:0] to reset all AD1812 logical devices.                                                                                                                                                                                                                                                                                                                                                                 |
|                  |         | The contents of the configuration registers are set<br>to power up values. Logical devices are inactive<br>and the I/O ranges are disabled (set to zero).                                                                                                                                                                                                                                                                   |
| Logical Device   | 0x07 RW | Selects the current logical device.                                                                                                                                                                                                                                                                                                                                                                                         |
| Number(LDN)      |         | All reads and writes of I/O, DMA, and interrupt configuration registers access the logical devices indexed by this register. AD1812 logical device number indices are:                                                                                                                                                                                                                                                      |
|                  |         | 0x00 (Window Sound System)                                                                                                                                                                                                                                                                                                                                                                                                  |
|                  |         | 0x01 (Sound Blaster)                                                                                                                                                                                                                                                                                                                                                                                                        |
|                  |         | 0x02 (AdLib Music synthesis)                                                                                                                                                                                                                                                                                                                                                                                                |
|                  |         | 0x03 (MIDI port)                                                                                                                                                                                                                                                                                                                                                                                                            |
|                  |         | 0x04 (Game port)                                                                                                                                                                                                                                                                                                                                                                                                            |
|                  |         | 0x05 (Modem)                                                                                                                                                                                                                                                                                                                                                                                                                |

#### Table 2.5 Non-Plug & Play AD1812 ADDRESSRegister Values

| Register Name | ADDRESS | Definition (value)                                                                           |
|---------------|---------|----------------------------------------------------------------------------------------------|
| Powerdown     | 0x20 RW | Controls powerdown operations. (For bit definitions, see Chapter 3 <i>AD1812 Registers</i> ) |

 Table 2.5
 Non-Plug & Play AD1812 ADDRESSRegister Values (continued)

## Table 2.6 Non-Plug & Play AD1812 ADDRESS Register Values (Windows Sound<br/>System, LDN==0)

| Register Name         | ADDRESS | Definition (value)                                                                                                                                                                                                                                    |
|-----------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Activate              | 0x30 RW | Activates the device on the ISA bus.                                                                                                                                                                                                                  |
|                       |         | Write (1) to bit [0] to activate the device.                                                                                                                                                                                                          |
|                       |         | Note: Do <i>not</i> enable Activate and I/O Range<br>Check at the same time. Bits [7:1] of this register<br>return (0) on reads. An inactive device doe <i>sot</i><br>respond to writes to its I/O address, interrupt<br>(IRQ), or DMA request (DRQ). |
| I/O Range Check       | 0x31 RW | Checks for I/O port conflicts with other devices on ISA bus.                                                                                                                                                                                          |
|                       |         | Write (1) to bit [0] to select 0x55 return on device reads in the programmed range.                                                                                                                                                                   |
|                       |         | Write (0) to bit [0] to select 0xAA return on device reads in the programmed range.                                                                                                                                                                   |
|                       |         | Write (1) to bit [1] to enable I/O check.                                                                                                                                                                                                             |
|                       |         | Note: Do <i>not</i> enable I/O Range Check and Activate at the same time. Bits [7:2] of this register return (0) on reads.                                                                                                                            |
| I/O port base address | 0x60 RW | Holds PC I/O base address.                                                                                                                                                                                                                            |
|                       | 0x61 RW | Write upper byte to 0x60—IO_BASE, bits [15:8]                                                                                                                                                                                                         |
|                       |         | Write lower byte to 0x61—IO_BASE, bits [7:0]                                                                                                                                                                                                          |
|                       |         | Note: The Windows Sound System address range<br>is from 0x0008 to 0xFFF8. The most commonly<br>used address is 0x530. The range is 8 bytes long<br>and must be aligned to an 8 byte memory<br>boundary.                                               |
| Interrupt request     | 0x70 RW | Holds the PC interrupt level selection.                                                                                                                                                                                                               |
| level select 0        |         | Write IRQ value to bits [3:0] to set the PC interrupt level, where valid IRQ values are: 3, 4, 5, 7, 9, 10, 11, & 12                                                                                                                                  |
|                       |         | Note: An IRQ value of 0 represents no interrupt selection. The most commonly used IRQs are 10 & 11.                                                                                                                                                   |

| Register Name     | ADDRESS | Definition (value)                                                                                                                                                                                                                                                                                      |
|-------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interrupt request | 0x71 RO | Holds the PC interrupt sensitivity selection.                                                                                                                                                                                                                                                           |
| type select 0     |         | This Read Only (RO) register contains the value 0x02, indicating that the interrupt sensitivity is set to active-high & edge-sensitive. The contents of this register cannot be changed and it is included only for Plug & Play compatibility.                                                          |
| DMA channel       | 0x74 RW | Holds the <i>capture</i> DMA channel selection.                                                                                                                                                                                                                                                         |
| select 0          |         | Write channel value to bits [2:0], where valid channel values are:                                                                                                                                                                                                                                      |
|                   |         | 0, 1, or 3 (for 8-bit DMA)                                                                                                                                                                                                                                                                              |
|                   |         | 4 (for no DMA)                                                                                                                                                                                                                                                                                          |
|                   |         | 5, 6, or 7 (for 16-bit DMA)                                                                                                                                                                                                                                                                             |
|                   |         | Note: In Plug & Play terms, a Windows Sound<br>System Configuration that includes two 16-bit<br>DMA channels is <i>Good</i> , one 16-bit & one 8-bit<br>DMA channel or two 8-bit DMA channels is<br><i>Acceptable</i> , and one 16-bit DMA channel or one 8-<br>bit DMA channel is <i>Sub-optimal</i> . |
|                   |         | If you do not enable the <i>capture</i> DMA channel all<br>DMA (both <i>capture</i> & <i>playback</i> ) occurs on the<br><i>playback</i> DMA channel. Also, note that<br>simultaneous capture and playback is <i>ot</i> possible<br>using single channel DMA mode                                       |
| DMA channel       | 0x75 RW | Holds the <i>playback</i> DMA channel selection.                                                                                                                                                                                                                                                        |
| select 1          |         | Write channel value to bits [2:0], where valid channel values are:                                                                                                                                                                                                                                      |
|                   |         | 0, 1, or 3 (for 8-bit DMA)                                                                                                                                                                                                                                                                              |
|                   |         | 4 (for no DMA)                                                                                                                                                                                                                                                                                          |
|                   |         | 5, 6, or 7 (for 16-bit DMA)                                                                                                                                                                                                                                                                             |

#### Table 2.6 Non-Plug & Play AD1812ADDRESS Register Values (Window Sound System, LDN==0) (continued)

| <b>D</b> 1 1-         |                    | LDN == 1)                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Name         | ADDRESS            | Definition (value)                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Activate              | 0x30 RW            | Activates the device on the ISA bus.                                                                                                                                                                                                                                                                                                                                                                                                  |
|                       |                    | Write (1) to bit [0] to activate the device.                                                                                                                                                                                                                                                                                                                                                                                          |
|                       |                    | Note: Do <i>not</i> enable Activate and I/O Range<br>Check at the same time. Bits [7:1] of this register<br>return (0) on reads. An inactive device does <i>ot</i><br>respond to writes to its I/O address, interrupt<br>(IRQ), or DMA request (DRQ).                                                                                                                                                                                 |
| I/O Range Check       | 0x31 RW            | Checks for I/O port conflicts with other devices on ISA bus.                                                                                                                                                                                                                                                                                                                                                                          |
|                       |                    | Write (1) to bit [0] to select 0x55 return on device reads in the programmed range.                                                                                                                                                                                                                                                                                                                                                   |
|                       |                    | Write (0) to bit [0] to select 0xAA return on device reads in the programmed range.                                                                                                                                                                                                                                                                                                                                                   |
|                       |                    | Write (1) to bit [1] to enable I/O check.                                                                                                                                                                                                                                                                                                                                                                                             |
|                       |                    | Note: Do <i>not</i> enable I/O Range Check and Activate at the same time. Bits [7:2] of this register return (0) on reads.                                                                                                                                                                                                                                                                                                            |
| I/O port base address | 0x60 RW<br>0x61 RW | Holds PC I/O base address (10-bit descriptor, bits [15:10] are zero).                                                                                                                                                                                                                                                                                                                                                                 |
|                       |                    | Write 2-bits to 0x60—IO_BASE, bits [9:8].                                                                                                                                                                                                                                                                                                                                                                                             |
|                       |                    | Write lower byte to 0x61—IO_BASE, bits [7:0].                                                                                                                                                                                                                                                                                                                                                                                         |
|                       |                    | Note: The Sound Blaster Pro address ranges<br>from 0x010 to 0x3F0. The range is 16 bytes long<br>and must be aligned to a 16 byte memory<br>boundary. In Plug & Play terms, a Sound Blaster<br>Configuration that has a base address of 0x220 or<br>0x240 is <i>Acceptable</i> and <i>Sub-optimal</i> if between<br>0x010 to 0x3F0 (other than 0x220 or 0x240)<br>because most games will not recognize these non-<br>standard ports. |

#### Table 2.7 Non-Plug & Play AD1812 ADDRESSRegister Values (Sound Blaster, LDN==1)

| (Sound Blaster, LDN==1)<br>(continued) |         |                                                                                                                                                                                                                                                                                                             |
|----------------------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Name                          | ADDRESS | Definition (value)                                                                                                                                                                                                                                                                                          |
| Interrupt request<br>level select 0    | 0x70 RW | Holds the PC interrupt level selection.<br>Write IRQ value to bits [3:0] to set the PC<br>interrupt level, where valid IRQ values are: 3, 4, 5,<br>7, 9, 10, 11, & 12.                                                                                                                                      |
|                                        |         | Note: An IRQ value of 0 represents no interrupt selection. The most commonly used IRQs are 5 & 7.                                                                                                                                                                                                           |
| Interrupt request<br>type select 0     | 0x71 RO | Holds the PC interrupt sensitivity selection.<br>This Read Only (RO) register contains the value<br>0x02, indicating that the interrupt sensitivity is set<br>to active-high & edge-sensitive. The contents of<br>this register cannot be changed and it is included<br>only for Plug & Play compatibility. |
| DMA channel<br>select 0                | 0x74 RW | <ul><li>Holds the PC DMA channel selections.</li><li>Write channel value to bits [2:0], where valid channel values are:</li><li>1, 0, or 3</li><li>4 (for no DMA)</li></ul>                                                                                                                                 |

#### Table 2.7 Non-Plug & Play AD1812ADDRESS Register Values (Sound Blaster, LDN==1) (continued)

## Table 2.8 Non-Plug & Play AD1812 ADDRESSRegister Values (AdLib Music Synthesis, LDN==2)

The most commonly used DMA channel is 1.

| Register Name | ADDRESS | Definition (value)                                                                                                                                                                                                                                                                                                                            |
|---------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Activate      | 0x30 RW | Activates the device on the ISA bus.<br>Write (1) to bit [0] to activate the device.<br>Note: Do <i>not</i> enable Activate and I/O Range<br>Check at the same time. Bits [7:1] of this register<br>return (0) on reads. An inactive device doe <i>sot</i><br>respond to writes to its I/O address, interrupt<br>(IRQ), or DMA request (DRQ). |

|                       | (continued)        |                                                                                                                                                                                                                                                                                                                                                         |  |
|-----------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Register Name         | ADDRESS            | Definition (value)                                                                                                                                                                                                                                                                                                                                      |  |
| I/O Range Check       | 0x31 RW            | Checks for I/O port conflicts with other devices on ISA bus.                                                                                                                                                                                                                                                                                            |  |
|                       |                    | Write (1) to bit [0] to select 0x55 return on device reads in the programmed range.                                                                                                                                                                                                                                                                     |  |
|                       |                    | Write (0) to bit [0] to select 0xAA return on device reads in the programmed range.                                                                                                                                                                                                                                                                     |  |
|                       |                    | Write (1) to bit [1] to enable I/O check.                                                                                                                                                                                                                                                                                                               |  |
|                       |                    | Note: Do <i>not</i> enable I/O Range Check and Activate at the same time. Bits [7:2] of this register return (0) on reads.                                                                                                                                                                                                                              |  |
| I/O port base address | 0x60 RW<br>0x61 RW | Holds PC I/O base address (10-bit descriptor, bits [15:10] are zero).                                                                                                                                                                                                                                                                                   |  |
|                       |                    | Write 2-bits to 0x60—IO_BASE, bits [9:8].                                                                                                                                                                                                                                                                                                               |  |
|                       |                    | Write lower byte to 0x61—IO_BASE, bits [7:0].                                                                                                                                                                                                                                                                                                           |  |
|                       |                    | Note: The AdLib address ranges from 0x008 to 0x3F8. The range is 4 bytes long and must be aligned to an 8 byte memory boundary. In Plug & Play terms, an AdLib Configuration that has a base address of 0x388 isAcceptable and Sub-optimal if between 0x008 to 0x3F8 (other than 0x388) because most games will not recognize these non-standard ports. |  |

#### Table 2.8 Non-Plug & Play AD1812ADDRESS Register Values (AdLib Music Synthesis, LDN==2) (continued)

#### Table 2.9 Non-Plug & Play AD1812 ADDRESSRegister Values (MIDI, LDN==3)

| Register Name | ADDRESS | Definition (value)                                                                                                                                                                                                                                                                                                                            |
|---------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Activate      | 0x30 RW | Activates the device on the ISA bus.<br>Write (1) to bit [0] to activate the device.<br>Note: Do <i>not</i> enable Activate and I/O Range<br>Check at the same time. Bits [7:1] of this register<br>return (0) on reads. An inactive device doe <i>sot</i><br>respond to writes to its I/O address, interrupt<br>(IRQ), or DMA request (DRQ). |

#### Table 2.9 Non-Plug & Play AD1812ADDRESS Register Values (MIDI, LDN==3) (continued)

| Register Name         | ADDRESS            | Definition (value)                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| I/O Range Check       | 0x31 RW            | Checks for I/O port conflicts with other devices on ISA bus.                                                                                                                                                                                                                                                                                                         |
|                       |                    | Write (1) to bit [0] to select 0x55 return on device reads in the programmed range.                                                                                                                                                                                                                                                                                  |
|                       |                    | Write (0) to bit [0] to select 0xAA return on device reads in the programmed range.                                                                                                                                                                                                                                                                                  |
|                       |                    | Write (1) to bit [1] to enable I/O check.                                                                                                                                                                                                                                                                                                                            |
|                       |                    | Note: Do <i>not</i> enable I/O Range Check and Activate at the same time. Bits [7:2] of this register return (0) on reads.                                                                                                                                                                                                                                           |
| I/O port base address | 0x60 RW<br>0x61 RW | Holds PC I/O base address (10-bit descriptor, bits [15:10] are zero).                                                                                                                                                                                                                                                                                                |
|                       |                    | Write 2-bits to 0x60—IO_BASE, bits [9:8]                                                                                                                                                                                                                                                                                                                             |
|                       |                    | Write lower byte to 0x61—IO_BASE, bits [7:0]                                                                                                                                                                                                                                                                                                                         |
|                       |                    | Note: The MIDI address rangeis from 0x008 to 0x3F8. The range is 4 bytes long and must be aligned to a 16 byte memory boundary. In Plug & Play terms, a MIDI Configuration that has a base address of 0x330 is <i>Acceptable</i> and <i>Sub-optimal</i> if between 0x010 to 0x3F0 (other than 0x330) because most games will not recognize these non-standard ports. |
| Interrupt request     | 0x70 RW            | Holds the PC interrupt level selection.                                                                                                                                                                                                                                                                                                                              |
| level select 0        |                    | Write IRQ value to bits [3:0] to set the PC interrupt level, where valid IRQ values are: 3, 4, 5, 7, 9, 10, 11, & 12                                                                                                                                                                                                                                                 |
|                       |                    | Note: An IRQ value of 0 represents no interrupt selection; IRQ 9 is the most commonly used.                                                                                                                                                                                                                                                                          |
| Interrupt request     | 0x71 RO            | Holds the PC interrupt sensitivity selection.                                                                                                                                                                                                                                                                                                                        |
| type select 0         |                    | This Read Only (RO) register contains the value 0x02, indicating that the interrupt sensitivity is set to active-high & edge-sensitive. The contents of this register cannot be changed and it is included only for Plug & Play compatibility.                                                                                                                       |

|                       |                    | LDN==4)                                                                                                                                                                                                                                                                                                                      |
|-----------------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Name         | ADDRESS            | Definition (value)                                                                                                                                                                                                                                                                                                           |
| Activate              | 0x30 RW            | Activates the device on the ISA bus.                                                                                                                                                                                                                                                                                         |
|                       |                    | Write (1) to bit [0] to activate the device.                                                                                                                                                                                                                                                                                 |
|                       |                    | Note: Do <i>not</i> enable Activate and I/O Range<br>Check at the same time. Bits [7:1] of this register<br>return (0) on reads. An inactive device does <i>ot</i><br>respond to writes to its I/O address, interrupt<br>(IRQ), or DMA request (DRQ).                                                                        |
| I/O Range Check       | 0x31 RW            | Checks for I/O port conflicts with other devices on ISA bus.                                                                                                                                                                                                                                                                 |
|                       |                    | Write (1) to bit [0] to select 0x55 return on device reads in the programmed range.                                                                                                                                                                                                                                          |
|                       |                    | Write (0) to bit [0] to select 0xAA return on device reads in the programmed range.                                                                                                                                                                                                                                          |
|                       |                    | Write (1) to bit [1] to enable I/O check.                                                                                                                                                                                                                                                                                    |
|                       |                    | Note: Do <i>not</i> enable I/O Range Check and Activate at the same time. Bits [7:2] of this register return (0) on reads.                                                                                                                                                                                                   |
| I/O port base address | 0x60 RW<br>0x61 RW | Holds PC I/O base address (10-bit descriptor, bits [15:10] are zero).                                                                                                                                                                                                                                                        |
|                       | 01101111           | Write 2-bits to 0x60—IO_BASE, bits [9:8].                                                                                                                                                                                                                                                                                    |
|                       |                    | Write lower byte to 0x61—IO_BASE, bits [7:0].                                                                                                                                                                                                                                                                                |
|                       |                    | Note: The Game Port address range is from 0x001 to 0x3FF. The rangeis 1 byte long. In Plug & Play terms, a Game Port Configuration that has a base address of 0x201 is <i>Acceptable</i> and <i>Sub-optimal</i> if between 0x001 to 0x3FF (other than 0x201) because most games will not recognize these non-standard ports. |

# Table 2.10 Non-Plug & Play AD1812 ADDRESSRegister Values (Game Port, LDN==4)

| LDN==5)               |                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|-----------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Register Name         | ADDRESS            | Definition (value)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| Activate              | 0x30 RW            | Activates the device on the ISA bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|                       |                    | Write (1) to bit [0] to activate the device.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                       |                    | Note: Do <i>not</i> enable Activate and I/O Range<br>Check at the same time. Bits [7:1] of this register<br>return (0) on reads. An inactive device doe <i>not</i><br>respond to writes to its I/O address, interrupt<br>(IRQ), or DMA request (DRQ).                                                                                                                                                                                                                                                                                             |  |
| I/O Range Check       | 0x31 RW            | Checks for I/O port conflicts with other devices on ISA bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|                       |                    | Write (1) to bit [0] to select 0x55 return on device reads in the programmed range.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|                       |                    | Write (0) to bit [0] to select 0xAA return on device reads in the programmed range.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|                       |                    | Write (1) to bit [1] to enable I/O check.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|                       |                    | Note: Do <i>not</i> enable I/O Range Check and Activate at the same time. Bits [7:2] of this register return (0) on reads.                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| I/O port base address | 0x60 RW<br>0x61 RW | Holds PC I/O base address (10-bit descriptor, bits [15:10] are zero).                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|                       |                    | Write 2-bits to 0x60—IO_BASE, bits [9:8].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
|                       |                    | Write lower byte to 0x61—IO_BASE, bits [7:0].                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|                       |                    | Note: The Modem device addressrange is from<br>0x008 to 0x3F8. The range is 8 bytes long and<br>must be aligned to an eight byte memory boundary<br>In Plug & Play terms, a Modem Configuration that<br>has a base address of 0x3F8 (with IRQ4), 0x2F8<br>(with IRQ3), 0x3E8 (with IRQ4), or 0x2E8 (with<br>IRQ3) is <i>Acceptable</i> . The configuration is<br><i>Sub-optimal</i> if using an address between 0x008 to<br>0x3F8 (other than above combinations) because<br>most serial devices will not recognize these non-<br>standard ports. |  |

## Table 2.11 Non-Plug & Play AD1812 ADDRESSRegister Values (Modem, LDN==5)

#### Table 2.11 Non-Plug & Play AD1812ADDRESS Register Values (Modem, LDN==5) (continued)

| (continued)                         |         |                                                                                                                                                                                                                                                                                                             |
|-------------------------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register Name                       | ADDRESS | Definition (value)                                                                                                                                                                                                                                                                                          |
| Interrupt request<br>level select 0 | 0x70 RW | Holds the PC interrupt level selection.<br>Write IRQ value to bits [3:0] to set the PC<br>interrupt level, where valid IRQ values are: 3, 4, 5,<br>7, 9, 10, 11, & 12 (see I/O Port Address for<br>address and interrupt combinations).                                                                     |
| Interrupt request<br>type select 0  | 0x71 RO | Holds the PC interrupt sensitivity selection.<br>This Read Only (RO) register contains the value<br>0x02, indicating that the interrupt sensitivity is set<br>to active-high & edge-sensitive. The contents of<br>this register cannot be changed and it is included<br>only for Plug & Play compatibility. |

## 2.4 AD1812 Windows Sound System Codec Programming

Programmable sample rate, gain, attenuation, muting, mixing, and companding features of the AD1812's integrated codec provide many performance options when using the part. Built-in support for Direct Memory Accessing (DMA) and Programmed I/O (PIO) also provides several options for data transfer.

This section on codec programming provides an overview of the programmable features of the codec. The codec programming topics in this section include the following:

- *Codec Data Formats & Sequencing*—This section covers the data types and data transfer sequences supported by the codec.
- *Codec DMA & PIO Transfers*—This section provides procedural overviews of DMA & PIO transfers and modes.
- *Codec I/O Mixing, Gain, & Attenuation*—This section provides an overview of the programmable controls for the codec's mixing, gain, attenuation, and mute features.
- Codec Autocalibration—This section provides a procedural overview of codec autocalibration.
- *Codec Sample Rate Operations*—This section provides a procedural overview of the codec's programmable sample rate features.
- *Codec Powerdown Operations*—This section provides a procedural overview of the codec's programmable powerdown features.

### 2.4.1 Codec Data Formats & Sequencing

This section describes the data formats supported by the AD1812's integrated codec and the order in which the data can be sent during PIO and DMA transfers. Some terthsat this section uses in describing the codec data formats and data transfer sequences are defined as follows:

- *Companding*—Compression/Decompression. The AD1812 supports µ-Law, A-Law, and IMA-ADPCM voice band audio compression/decompression.
- *Big Endian 16-Bit Signed (Two's Complement)* 16-bit Linear data format; the most significant (Upper) byte is sent first.
- *Little Endian 16-Bit Signed (Two's Complement)*–16-bit Linear data format; the least significant (Lower) byte is sent first.
- Pulse Code Modulation (PCM)-8-bit Linear data format
- μ-Law & A-Law PCM—8-bit Companded formats of PCM data (Defined by CCITT G.711 recommendation).
- Interactive Multimedia Association-Adaptive Differential Pulse Code Modulation (IMA-ADPCM)—4-bit Companded format of PCM Data

The codec supports three linear and three companded data formats. You can transfer data in any of the following formats:

- Linear, Big Endian 16-Bit Signed(Two's Complement)
- Linear, Little Endian 16-Bit Signed (Two's Complement)
- Linear, Unsigned, 8-Bit PCM
- µ-Law Companded, 8-Bit PCM
- A-Law Companded, 8-Bit PCM
- IMA-ADPCM Companded, 4-Bit PCM

Regardless of the data format used, the AD1812's codec always transfers 32-bits of data (two 16-bit words). The number of samples sent in each 32-bit packet (with no unused bits) varies with the data format (4, 8, or 16-bit, Signed, Unsigned, or Companded).

**Program the DMA counters in the AD1812's codec with the number & MPLES to be transferred.** The sample counters in the codec count the number of samples transferred, *not* the number of 32-bit packets.

Each time a 32-bit packet is transferred, the codec decrements the counters by the number of samples in the packet. To determine the number of transfers required to cause a counter underflow—indicated when the codec sets the INT bit—for a programmed sample count (Number of Samples) and data format (Samples per Packet), use the following formula:

$$Number of \ Transfers = \left\{ \begin{array}{l} TRUNC \left( \frac{Number \ of \ Samples}{\left( \frac{Number \ of \ Samples}{Packet} \right)} \right) + 1 \end{array} \right\}$$

**Note:** During playback DMA if the number of samples to be transferred*nist* evenly divisible by the number of samples in a packet*ill the unused portion of the last packet with either a mid-scale value or the value of the last sample* 

Example: If you program the transfer count to 7*f*(*r* 7 *samples*) in 8-bit mono format, how many packet transfers are required to send/receive the samples?

The codec sends/receives 4 samples in each 32-bit packet in 8-bit mono format. (For a complete list of sample to packet ratios in supported formats, see tables 2.11, 2.12, and 2.13.). From the truncated transfer count formula, you can calculate the number of packet transfers required to send the samples as follows:

Number of Transfers = 
$$\left\{ TRUNC\left(\frac{7 Samples}{\left(\frac{4 Samples}{Packet}\right)}\right) + 1 \right\} = 2$$

After two 32-bit transfers (four samples per transfer) in this casebe Current Count register underflows—and the codec generates an interrupt (sets INT bit).

Figures 2.1 through 2.6 display the relationship between 32-bit data transfers used by the codec and the number of samples per transfer sent in stereo, mono, 4-bit, 8-bit, and 16-bit modes. It is useful to compare the information displayed in these figures with data transfer sequences listed in Tables 2.12 through 2.14.

As shown in the tables, the number of samples passed in a 32-bit codec data transfer varies depending on the format of the data sent. Note that in mono mode the codec only uses the left channel.



Figure 2.1 Stereo 16-Bit (Linear Big & Little Endian) Audio Data



Figure 2.2 Mono 16-Bit (Linear Big & Little Endian) Audio Data



Figure 2.3 Stereo 8-Bit (Linear, µ-Law, & A-Law) Audio Data



Figure 2.4 Mono 8-Bit (Linear, µ-Law, & A-Law) Audio Data



Figure 2.5 Mono 4-Bit (IMA-ADPCM) Audio Data



Figure 2.6 Mono 4-Bit (IMA-ADPCM) Audio Data



Figure 2.7 Codec Transfers 16-Bit Interface

| Table 2.12 Codec Transfers 16-Bit Interface, No Byte SwapP/CINF8=0, P/CBSW=0 | <b>Table 2.12</b> | <b>Codec Transfers</b> | <b>16-Bit Interface</b> , | , No Byte | e SwapP/CINF8=0, P/CBSW=0) |
|------------------------------------------------------------------------------|-------------------|------------------------|---------------------------|-----------|----------------------------|
|------------------------------------------------------------------------------|-------------------|------------------------|---------------------------|-----------|----------------------------|

| Format                               |                                                              | Word 1                       | (16-bit)                                    |                                          | Word 0 (16-bit)                             |                                        |                                               |                                        |
|--------------------------------------|--------------------------------------------------------------|------------------------------|---------------------------------------------|------------------------------------------|---------------------------------------------|----------------------------------------|-----------------------------------------------|----------------------------------------|
|                                      | MSB                                                          |                              |                                             | LSB                                      | MSB                                         |                                        | LSB                                           |                                        |
| Mono, 16-bit<br>Little Endian        | Sam                                                          | 8-bits of<br>ple 1<br>hannel | Sam                                         | 8-bits of<br>ple 1                       | Upper 8-bits of<br>Sample 0<br>Left Channel |                                        | Lower 8-bits of<br>Sample 0<br>Left Channel   |                                        |
| Stereo, 16-bit<br>Little Endian      | Left Channel<br>Upper 8-bits of<br>Sample 0<br>Right Channel |                              | Sam                                         | 8-bits of<br>ple 0<br><sup>Channel</sup> | Upper 8-bits of<br>Sample 0<br>Left Channel |                                        |                                               |                                        |
| Mono, 8-bit                          | Sample                                                       | 3, 8-bits                    | Sample                                      | 2, 8-bits                                | Sample                                      | 1, 8-bits                              | Sample                                        | 0, 8-bits                              |
| Linear PCM<br>µ-Law PCM<br>A-Law PCM | Left Channel                                                 |                              | Left C                                      | hannel                                   | Left Channel                                |                                        | Left Channel                                  |                                        |
| Stereo, 8-bit                        | Sample 1, 8-bits                                             |                              | Sample                                      | 1, 8-bits                                | Sample 0, 8-bits                            |                                        | s Sample 0, 8-bits                            |                                        |
| Linear PCM<br>µ-Law PCM<br>A-Law PCM | Right Channel                                                |                              | Left Channel                                |                                          | Right (                                     | Channel                                | Left C                                        | hannel                                 |
| Mono, 4-bit<br>IMA-ADPCM             | Sample<br>7, 4-bits<br>Left<br>Channel                       | -                            | Sample<br>5, 4-bits<br>Left<br>Channel      | -                                        | Sample<br>3, 4-bits<br>Left<br>Channel      | Sample<br>2, 4-bits<br>Left<br>Channel | Sample<br>1, 4-bits<br>Left<br>Channel        | Sample<br>0, 4-bits<br>Left<br>Channel |
| Stereo, 4-bit<br>IMA-ADPCM           | Sample<br>3, 4-bits<br>Right<br>Channel                      | 1                            | Sample<br>2, 4-bits<br>Right<br>Channel     | 1                                        | Sample<br>1, 4-bits<br>Right<br>Channel     | Sample<br>1, 4-bits<br>Left<br>Channel | Sample<br>0, 4-bits<br>Right<br>Channel       | Sample<br>0, 4-bits<br>Left<br>Channel |
| Mono, 16-bit<br>Big Endian           | Lower 8-bits of<br>Sample 1<br>Left Channel                  |                              | Upper 8-bits of<br>Sample 1<br>Left Channel |                                          | Lower 8-bits of<br>Sample 0<br>Left Channel |                                        | f Upper 8-bits of<br>Sample 0<br>Left Channel |                                        |
| Stereo, 16-bit<br>Big Endian         |                                                              | 8-bits of<br>ple 0           |                                             | 8-bits of<br>ple 0                       |                                             | 8-bits of<br>ple 0                     |                                               |                                        |

| Format                        | Word 1                      | (16-bit)                    | Word 0 (16-bit)             |                             |  |
|-------------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|--|
|                               | MSB                         | LSB                         | MSB                         | LSB                         |  |
| Mono, 16-bit<br>Little Endian | Upper 8-bits of<br>Sample 1 | Lower 8-bits of<br>Sample 1 | Upper 8-bits of<br>Sample 0 | Lower 8-bits of<br>Sample 0 |  |
|                               | Left Channel                | Left Channel                | Left Channel                | Left Channel                |  |
|                               | Right Channel               | Right Channel               | Left Channel                | Left Channel                |  |



Figure 2.8 Codec Transfers 16-Bit Interface

| Format                                                |                                              | Word 1                                 | (16-bit)                                    |                                             | Word 0 (16-bit)                             |                                             |                                               |                                             |  |
|-------------------------------------------------------|----------------------------------------------|----------------------------------------|---------------------------------------------|---------------------------------------------|---------------------------------------------|---------------------------------------------|-----------------------------------------------|---------------------------------------------|--|
|                                                       | MSB                                          |                                        |                                             | LSB                                         | MSB                                         |                                             | LSB                                           |                                             |  |
| Mono, 16-bit<br>Little Endian                         | Sam                                          | 8-bits of<br>ple 1<br>hannel           | Sam                                         | Upper 8-bits of<br>Sample 1<br>Left Channel |                                             | Lower 8-bits of<br>Sample 0<br>Left Channel |                                               | Upper 8-bits of<br>Sample 0<br>Left Channel |  |
| Stereo, 16-bit<br>Little Endian                       | Lower 8-bits of<br>Sample 0<br>Right Channel |                                        | Sam                                         | 8-bits of<br>ple 0<br><sup>Channel</sup>    | Lower 8-bits o<br>Sample 0<br>Left Channel  |                                             | f Upper 8-bits of<br>Sample 0<br>Left Channel |                                             |  |
| Mono, 8-bit<br>Linear PCM<br>µ-Law PCM<br>A-Law PCM   | Sample 2, 8-bits<br>Left Channel             |                                        | -                                           | 3, 8-bits<br>hannel                         | Sample 0, 8-bits<br>Left Channel            |                                             | ts Sample 1, 8-bits<br>Left Channel           |                                             |  |
| Stereo, 8-bit<br>Linear PCM<br>µ-Law PCM<br>A-Law PCM | Sample 1, 8-bits<br>Left Channel             |                                        | Sample 1, 8-bits<br>Right Channel           |                                             | Sample 0, 8-bits<br>Left Channel            |                                             | s Sample 0, 8-bits<br>Right Channel           |                                             |  |
| Mono, 4-bit<br>IMA-ADPCM                              | 1                                            | Sample<br>4, 4-bits<br>Left<br>Channel | 1                                           | 1                                           | Sample<br>1, 4-bits<br>Left<br>Channel      | Sample<br>0, 4-bits<br>Left<br>Channel      | 1                                             | Sample<br>2, 4-bits<br>Left<br>Channel      |  |
| Stereo, 4-bit<br>IMA-ADPCM                            | Sample<br>2, 4-bits<br>Right<br>Channel      | 1                                      | Sample<br>3, 4-bits<br>Right<br>Channel     | Sample<br>3, 4-bits<br>Left<br>Channel      | Sample<br>0, 4-bits<br>Right<br>Channel     | 1                                           | Sample<br>1, 4-bits<br>Right<br>Channel       | Sample<br>1, 4-bits<br>Left<br>Channel      |  |
| Mono, 16-bit<br>Big Endian                            | Upper 8-bits of<br>Sample 1<br>Left Channel  |                                        | Lower 8-bits of<br>Sample 1<br>Left Channel |                                             | Upper 8-bits of<br>Sample 0<br>Left Channel |                                             | E Lower 8-bits of<br>Sample 0<br>Left Channel |                                             |  |
| Stereo, 16-bit<br>Big Endian                          |                                              | 8-bits of<br>ple 0                     |                                             | 8-bits of<br>ple 0                          |                                             |                                             | Lower 8-bits of<br>Sample 0                   |                                             |  |

| Format                        | Word 1                      | (16-bit)                    | Word 0 (16-bit)             |                             |  |
|-------------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|--|
|                               | MSB                         | LSB                         | MSB                         | LSB                         |  |
| Mono, 16-bit<br>Little Endian | Lower 8-bits of<br>Sample 1 | Upper 8-bits of<br>Sample 1 | Lower 8-bits of<br>Sample 0 | Upper 8-bits of<br>Sample 0 |  |
|                               | Left Channel                | Left Channel                | Left Channel                | Left Channel                |  |
|                               | Right Channel               | Right Channel               | Left Channel                | Left Channel                |  |



Figure 2.9 Codec Transfers 8-Bit Interface

| Table 2.14 Codec Transfers 8-Bit Interface (P/CINF8=1) |                                              |                                        |                                             |                                        |                                             |                                             |                                               |                                             |  |
|--------------------------------------------------------|----------------------------------------------|----------------------------------------|---------------------------------------------|----------------------------------------|---------------------------------------------|---------------------------------------------|-----------------------------------------------|---------------------------------------------|--|
| Format                                                 | Byte 3                                       |                                        | Byt                                         | te 2                                   | Byte 1                                      |                                             | Byte 0                                        |                                             |  |
|                                                        | MSB                                          | LSB                                    | MSB                                         | LSB                                    | MSB                                         | LSB                                         | MSB                                           | LSB                                         |  |
| Mono, 16-bit<br>Little Endian                          | Upper 8-bits of<br>Sample 1<br>Left Channel  |                                        | Lower 8-bits of<br>Sample 1<br>Left Channel |                                        | Upper 8-bits of<br>Sample 0<br>Left Channel |                                             | Lower 8-bits of<br>Sample 0<br>Left Channel   |                                             |  |
| Stereo, 16-bit<br>Little Endian                        | Upper 8-bits of<br>Sample 0<br>Right Channel |                                        | Sam                                         | ample 0 Sam                            |                                             | Upper 8-bits of<br>Sample 0<br>Left Channel |                                               | Lower 8-bits of<br>Sample 0<br>Left Channel |  |
| Mono, 8-bit                                            | Sample                                       | 3, 8-bits                              | Sample                                      | 2, 8-bits                              | Sample                                      | 1, 8-bits                                   | Sample                                        | 0, 8-bits                                   |  |
| Linear PCM<br>µ-Law PCM<br>A-Law PCM                   | Left Channel                                 |                                        | Left C                                      | hannel                                 | Left Channel                                |                                             | Left Channel                                  |                                             |  |
| Stereo, 8-bit                                          | Sample 1, 8-bits                             |                                        | Sample                                      | 1, 8-bits                              | Sample 0, 8-bits                            |                                             | s Sample 0, 8-bits                            |                                             |  |
| Linear PCM<br>µ-Law PCM<br>A-Law PCM                   | Right Channel                                |                                        | Left Channel                                |                                        | Right Channel                               |                                             | Left C                                        | Channel                                     |  |
| Mono, 4-bit<br>IMA-ADPCM                               | Sample<br>7, 4-bits<br>Left<br>Channel       | 1                                      | -                                           | -                                      | Sample<br>3, 4-bits<br>Left<br>Channel      | -                                           | -                                             | Sample<br>0, 4-bits<br>Left<br>Channel      |  |
| Stereo, 4-bit<br>IMA-ADPCM                             | Sample<br>3, 4-bits<br>Right<br>Channel      | Sample<br>3, 4-bits<br>Left<br>Channel | Sample<br>2, 4-bits<br>Right<br>Channel     | Sample<br>2, 4-bits<br>Left<br>Channel | -                                           | 1                                           | Sample<br>0, 4-bits<br>Right<br>Channel       | 1                                           |  |
| Mono, 16-bit<br>Big Endian                             | Lower 8-bits of<br>Sample 1<br>Left Channel  |                                        | Upper 8-bits of<br>Sample 1<br>Left Channel |                                        | Lower 8-bits of<br>Sample 0<br>Left Channel |                                             | f Upper 8-bits of<br>Sample 0<br>Left Channel |                                             |  |
| Stereo, 16-bit<br>Big Endian                           |                                              | 8-bits of<br>ple 0                     |                                             | 8-bits of<br>ple 0                     | -bits of Lower 8-                           |                                             |                                               | 8-bits of ople 0                            |  |

 Table 2.14
 Codec Transfers 8-Bit Interface (P/CINF8=1)

| Right Channe | el Right Channel | Left Channel | Left Channel |
|--------------|------------------|--------------|--------------|
|--------------|------------------|--------------|--------------|

#### 2.4.2 Codec DMA & PIO Data Transfers

You can transfer data to and from the AD1812's codec using the chip's built-in support for Direct Memory Accessing (DMA) and Programmed Input/Output (PIO). This section describes the order of operations for both transfer methods. Note these procedures are subject to signal timing restrictions described in the D1812 SoundPort Controller Data Sheet.

To initiate a DMA processusing the AD1812's integrated codec, usehte following steps:

- 1) Enter Mode Change Enable state by setting the MCE bit of Codec Index Address register. (You must put the codec in MCE state to modify the contents of Codec Indexed register 0x09—*except for the PEN and CEN bit*).
- 2) Select dual or single channel DMA by writing a 0 for dual or a 1 for single to the SDC bit in Codec Indexed register 0x09.

Note that if a single DMA channel is configured for the AD1812 Codec, that channel is the playback channel; all DMA transfers (playback or capture) occur on the playback channel. The codec supports single channel DMA, dual channel DMA (full-duplex capture/playback), single channel DMA/PIO (one of each at the same time) and dual channel PIO modes. Use the PIO procedure (follows this DMA procedure) to set up a PIO channel.

- 3) Use steps (a) *and/or* (b) to set up DMA channels:
  - a) Select (while the playback channel is disabled, PEN=0) the playback data format, stereo/mono, byte swapping, and interface with the PFMT, PC/L, PS/M, PBSW, and PINF8 bits in Codec Indexed register 0x08.
  - b) Select (while the capture channel is **da**bled, CPEN=0) the capture data format, stereo/mono, byte swapping, and interface with the CFMT, CC/L, CS/M, CBSW, and CINF8 bits in Codec Indexed register 0x1C.
- 4) Select the sample rate with the FU and FL bits in Codec Indexed registers 0x16 and 0x17 (FU must be loaded before FL).
- 5) Load the Lower then Upper Base Count registers (Codec Indexed registers 0x0F then 0x0E) with the number of samples to playback. For capture, load the Capture Lower then Upper Base Count registers (Codec Indexed registers 0x1ffen 0x1E).

(Continued — Notes on this step continued on next page)

(Continued — Notes on this step continued from previous page)

Note that the DMA count registers select the number of *amples* sent or received. For a description of the relationship between data formats, samples, and the 32-bit transfers used by the codec, see the previous section *Codec Data Formats & Sequencing*.

Also note that the codec only loads the current count registers when either: (1) You write to an Upper Base Count register (0x0E or 0x1E), o(2) A DMA counter interrupt occurs.

Finally, note that once DMA transfers are enabled the codec decrements by the number of samples sent or received in a 32-bit codec transfer. On the next data transfer after the number of samples in the current count is reached (underflow), the codec issues an interrupt (indicates this by setting the INHit) and automatically reloads the current count registers.

6) Enable playback (set PENbit & clear PPIObit) and/or capture (set CENbit & Clear CPIO bit) in Codec Indexed register 0x09.

Note that you can abort the DMA transfer at any point by disabling DMA (clear the PEN and/or CEN bits) without entering MCE stateSee note in step 9 on terminating a DMA process.

- 7) Start DMA by exiting Mode Change Enable state (clear the MCE bit of Codec Index Address register) with playback and/or capture control bits set (PEN and/or CEN).
- 8) Clear the codec interrupt that occurs after the DMA transfer is complete (count underflow) by writing to the Codec Status register (clearing IN Dicky bit).

Note that (*unless the TRD bit in the Codec Index Address register is s*) DMA continues whether or not you clear the INT bit. Clear the INT bit so the bit can indicate when the next batch of data is needed.

9) End the DMA process by disabling playback (clear PENt) and/or capture (clear CEN bit) in Codec Indexed register 0x09.

Note that you must service the last sample in the last 32-bit codec transfer after the DMA process is terminated to complete the process *f you disable a DMA* channel (clear the PEN or CEN bits) while the AD1812 DMA request pin is active, the last complete 32-bit codec transfer (and all the samples within that transfer) must be serviced before the AD1812 deasserts the DMA request pin.

To initiate a PIO processusing the AD1812's integrated codec, usehe followingsteps:

- Enter Mode Change Enable state by setting the MCE bit of Codec Index Address register. (You must put the codec in MCE state to modify the contents of Codec Indexed register 0x09-except for the PEN and CEN bit).
- 2) Use steps (a) *and/or* (b) to set up a PIO channel:
  - a) Select (while the playback channel is disabled, PEN=0) the playback data format, stereo/mono, byte swapping, and interface with the PFMT, PC/L, PS/M, PBSW, and PINF8 bits in Codec Indexed register 0x08.
  - b) Select (while the capture channel is disabled, CPEN=0) the capture data format, stereo/mono, byte swapping, and interface with the CFMT, CC/L, CS/M, CBSW, and CINF8 bits in Codec Indexed register 0x1C.
- Select the sample rate with the FU and FL bits in Codec Indexed registers 0x16 and 0x17 (FU must be loaded before FL).
- 4) Enable capture or playback PIO by setting either the playback bits (PE**ℝ**PIO=1) or capture bits (CEN=CPIO=1) in Codec Indexed register 0x09.

Note that the codec supports single channel PIO and single channel DMA/PIO (one of each at the same time) modes. Use the DMA procedure (precedes this PIO procedure) to set up a DMA channel.

- 5) Start PIO by exiting Mode Change Enable state (clear the MCE bit of Codec Index Address register) with playback and/or capture control bits set (PEN and/or CEN).
- 6) Poll the capture data ready (CRD¥1) or playback data ready (PRD¥1) bits in the Codec Status register. Read or write when data is ready.

Note that the codec clears the appropriate data ready bit when playback data is *valid* (just written, do*not* overwrite) and/or capture data is*fresh* (just received, *not* yet read).

Also note that the DMA counters can be used to count the number of samples sent or received during a PIO process and generate codec interrupts. Clear the IEN bit in Codec Indexed register 0x0A, if you want to inhibit codec interrupts (PC interrupts only, not the INT bit) during a PIO process.

 End the PIO process by clearing the playback and/or capture control bits (PEN and/or CEN).

### 2.4.3 Codec I/O Mixing, Gain, & Attenuation

The AD1812's integrated codec provides control for gain, attenuation, and digital mixing through a set of registers. This section provides a overview of these audio controls. For information on each of the codec registers mentioned in this section, see Chapter 3, *AD1812 Registers* 

Figure 2.10 shows a block diagram of the AD1812 controller's codec and indicates the indices of the control registers for each stage.



Figure 2.10 Map of AD1812 Integrated Codec (With Control Registers)

The following are descriptions of the control registers indicated in Figure 2.10. Use the figure and the following descriptions to correlate registers with mix, gain, and attenuate control functions:

• Left Input Control (Index 0x00)

The LMGE bit of this register controls a 0 or 20 dB gain on the L\_MIC input. The LIG bits of this register control a 0 to 22.5 dB gain on the left channel ADC input. The LSS bits of this register select the input source for the pre-ADC left channel gain stage.

• Right Input Control (Index 0x0)

The RMGE bit of this register controls a 0 or 20 dB gain on the R\_MIC input. The RIG bits of this register control a 0 to 22.5 dB gain on the right channel ADC input. The RSS bits of this register select the input source for the pre-ADC right channel gain stage.

- Left AUX1 Input Control (Index 0x02) The LMX1 bit of this register controls a mute on the L\_AUX1 input. The LX11bits of this register control a 12 to -34.5 dB gain-attenuation on the L\_AUX1 input to the L\_OUT output mixer.
- *Right AUX1 Input Control (Index 0x03* The RMX1 bit of this register controls a mute on the R\_AUX1 input. The RX1Bits of this register control a 12 to -34.5 dB gain-attenuation on the R\_AUX1 input to the R\_OUT output mixer.
- Left AUX2 Input Control (Index 0x04) The LMX2 bit of this register controls a mute on the L\_AUX2 input. The LX2Aits of this register control a 12 to -34.5 dB gain-attenuation on the L\_AUX2 input to the L\_OUT output mixer.
- *Right AUX2 Input Control (Index 0x05* The RMX2bit of this register controls a mute on the R\_AUX2 input. The RX2Aits of this register control a 12 to -34.5 dB gain-attenuation on the R\_AUX2 input to the R\_OUT output mixer.
- Left Output Control (Index 0x06) The LDM bit of this register controls a mute on the left channel DAC's output. The LDA bits of this register control a 0 to -94.5 dB attenuation on the left channel DAC's output passed to the L\_OUT output mixer.
- *Right Output Control (Index 0x07* The RDM bit of this register controls a mute on the right channel DAC's output. The RDA bits of this register control a 0 to -94.5 dB attenuation on the right channel DAC's output passed to the R\_OUT output mixer.
- *Digital Mix/Attenuation (Index 0x0D)* The DME bit of this register controls digital mixing of left and right channel ADCs output passed to left and right channel DACs input. The DMA its of this register control a 0 to -94.5 dB attenuation on the mixer's output.
- Alternate Feature Enable/Left MIC Input Control (Index 0x10) The OL bit of this register controls the analog output line level, scaling outputs for 2.8 Vpp or 2Vpp full scale signal. The LMGbits of this register control a 12 to -34.5 dB gain-attenuation on the L\_MIC input (post LIG gain) to the L\_OUT output mixer.

- *MIC Mix Enable/Right MIC Input Control (Index 0x1)* The RMME and LMME bits of this register control passing the R\_MIC and L\_MIC inputs to the R\_OUT and L\_OUT output mixers. The RMG bits of this register control a 12 to -34.5 dB gain-attenuation on the R\_MIC input (post RIG gain) to the R\_OUT output mixer.
- Left Line Gain, Attenuate, Mute, Mix (Index 0x12) The LLM bit of this register controls a mute on the L\_LINE input. The LL**G**its of this register control a 12 to -34.5 dB gain-attenuation on the L\_LINE input to the L\_OUT output mixer.
- *Right Line Gain, Attenuate, Mute, Mix (Index 0x13)* The RLM bit of this register controls a mute on the R\_LINE input. The RL**G**its of this register control a 12 to -34.5 dB gain-attenuation on the R\_LINE input to the R\_OUT output mixer.
- Mono Control (Index 0x1A) The MIM bit of this register controls a mute on the MONO\_IN input. The MOMit of this register controls a mute on the M\_OUT output. The MIAbits of this register control a 0 to -45 dB attenuation on the M\_IN input to the R\_OUT and L\_OUT output mixers.

# 2.4.4 Codec Autocalibration

Codec autocalibration of theADCs and DACsprovides greater accuracy by minimizing DC offsets. *At power on reset, the AD1812's codec always autocalibrates before you can access it and then clears the ACAL bit*. This section describes how to autocalibrate the codec, *if you determine it necessary* at some time after power on reset.

Autocalibration occurs when the code cxits Mode Change Enable state (controlled with MCE bit in Codec Index Address register) with Autocalibration Enabled (ACAL bit set in Codec Indexed register 0x09) If an autocalibration is*not* performed on exiting the Mode Change Enable state, the codec uses the ADC and DAC offset compensations retained from the most recent autocalibration.

You can monitor the completion of autocalibration by pollinfor a Low-High-Low transition of the Autocalibrate-In-Progress (ACI bit in Codec Indexed register 0x0B (Test and Initialization registe): This bit isset during autocalibration and cleared on completion As an alternative to polling, you can assume autocalibration is complete 384 sample periods after it starts.

Note that data transfers enabled during autocalibration d*not* begin until the completion of autocalibration.

To perform an autocalibration of the AD1812's integrated codec, ushet followingsteps:

- 1) Set (write-1-to) the Mode Change Enable (MC) bit in the WSS Codec Status register.
- 2) Set (write-1-to) the AutocalibrationEnable(ACAL) bit in Codex Indexed register 0x09.
- 3) Clear (write-0-to) the Mode Change Enable (MCE) bit

After you have toggled the MCE bit, the Autocalibrate-In-Progress (AQIbit transitions from LO to HI immediately This bit remains HI for 384 sample periods. Polling the ACI bit for its transitions from Low to High and then from High to Low provides a flag for completion of autocalibration.

Note that during autocalibration the codec automatically unter the left and right DAC outputs, AUX1 and AUX2 inputand disables the digital mix

Also note that while the autocalibration sequences in progress data output from the ADCs is *meaningless* and inputs to the DACs are *ignored*.

### 2.4.5 Codec Sample Rate Operations

To modify the sample rate used by the AD1812's integrated codechange the rate in the Upper and then Lower Frequency Select register (writing to codec Indexed registers 0x16 and then 0x17) This feature of the integrated codec lets you modify the sample rate selection in 1 Hz increments *on the fly* without entering MCEmode.

Note: You must write to the Lower Frequency Select register (0x17)ast when changing the frequency because writes to Codec Indexed register 0x17 force the codec to update the current sample rate (16-bit register).

# 2.4.6 Codec Powerdown Operations

Two types of registers control codec powerdown operations. The Plug & Play Powerdown register (PnP Index 0x20) controls codec and DSP powerdown. Several codec indexed registers (Powerdown Control-Index 0x1B & Total Powerdown-Index 0x1D) also control codec powerdown.

The powerdown functions that correspond between these two types of registers can be controlled from either location, but the Plug & Play registers override the codec registers. If the codec has been powered down using the Plug & Play Powerdown register's SP\_PWNDWN or TOT\_PWRDWN bits, the codec must be powered up by clearing those bits; the codec Total Powerdown register's TOTPWD bit cannot override the Plug & Play powerdown command. Table 2.15 lists the register bits that correspond.

| Plug & Play Registers                | Codec Registers                    | Description (Type)                      |
|--------------------------------------|------------------------------------|-----------------------------------------|
| N/A                                  | Codec Index 0x1B, bit 5,<br>MIXPWD | 1 Powers Codec DAC &<br>Mixer down (RW) |
| N/A                                  | Codec Index 0x1B, bit 6,<br>DACPWD | 1 Powers Codec DAC down<br>(RW)         |
| N/A                                  | Codec Index 0x1B, bit 7,<br>ADCPWD | 1 Powers Codec ADC down<br>(RW)         |
| N/A                                  | Codec Index 0x1D, bit 0,<br>TOTPWD | 1 Powers Codec down<br>(RW)             |
| PnP Index 0x20, bit 1,<br>SP_PU_RDY  | N/A                                | 1 Indicates Codec powered<br>up (RO)    |
| PnP Index 0x20, bit 2,<br>SP_PD_RDY  | N/A                                | 1 Indicates Codec powered<br>down (RO)  |
| PnP Index 0x20, bit 7,<br>TOT_PWRDWN | N/A                                | 1 Powers chip down (RW)                 |

### Table 2.15 Powerdown Bits (Plug & Play Versus Codec)

When the AD1812 is initially powered up, the RESET pin should be asserted (high). Asserting the RESET pin keeps the AD1812 in itsninimum power consumptionstate. All analog and digital sections are shut down. Theodec's parallel interface does not function; all bi-directional signal lines are in high-impedantre-state. The crystal on pins XTALI and XTALO must be powered during the RESET pulse.

Exit signal imposed powerdown by classerting the **PWRDWN** and **RESET** pins. On return from powerdown, initial power up, or reset, the AD1812's codec enters initialization, returning all registers to their initialization values. During initialization, the codec autocalibrates itself. This technique powers up all the analog amplifiers without any *clicks* and *pops*.

While initializing, the odec ignores writes and returns 0x8080 on reads. You can monitor for the end of initialization (approximately 300 ms in duration) by polling the index register for any value other than 0x8080.

The AD1812's codechas five software programmable Advanced Power Dow**m**odes. You can control thesepowerdown modes from the Powerdown Control and Total Powerdown registers. Table 2.16 provides asummary of power down modes, recovery periods, and power dissipation.

|         |       | Tuble 211 | D I UWEI D | own moue | Builling J |        |       |
|---------|-------|-----------|------------|----------|------------|--------|-------|
| Power   | TOTPW | ADCPW     | DACPW      | MIXPW    | Power-     | Power- | Power |
| Down    | D     | D         | D          | D        | Down       | Up     | Use   |
| Mode    | Bit   | Bit       | Bit        | Bit      | Delay      | Delay  |       |
| Total   | 1     | Х         | Х          | Х        | 3 ms       | 512 ms | tbd   |
| Power-  |       |           |            |          |            |        |       |
| Down    |       |           |            |          |            |        |       |
| Standby | 0     | 1         | Х          | 1        | 1/Fs       | 1/Fs   | tbd   |
|         |       |           |            |          |            |        |       |
|         |       |           |            |          |            |        |       |
| Mixer   | 0     | 0         | Х          | 1        | 1/Fs       | 1/Fs   | tbd   |
| Power-  |       |           |            |          |            |        |       |
| Down    |       |           |            |          |            |        |       |
| Mixer   | 0     | 1         | 1          | 0        | 1/Fs       | 1/Fs   | tbd   |
| Only    |       |           |            |          |            |        |       |
|         |       |           |            |          |            |        |       |
| ADC     | 0     | 1         | 0          | 0        | 1/Fs       | 1/Fs   | tbd   |
| Power-  |       |           |            |          |            |        |       |
| Down    |       |           |            |          |            |        |       |
| DAC     | 0     | 0         | 1          | 0        | 1/Fs       | 1/Fs   | tbd   |
| Power-  |       |           |            |          |            |        |       |
| Down    |       |           |            |          |            |        |       |

 Table 2.16
 Power Down Mode Summary

Note: An "X" indicates that the bit does not influence the powerdown mode

# 2.4.7 Codec Comparison (AD1845 Vs. AD1812's Integrated Codec)

The codec integrated into the AD1812 is a modified version of the Analog Devices AD1845 SoundPort codec. Table 2.17 provides programmers and hardware designers already familiar with the AD1845 with comparison information on the two codecs.

| Feature                  | AD1845                                                                                                                            | AD1812's Integrated Codec                                                                                                                                                                      |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Autocalibration          | On powerup, the ACAL bit is set,<br>but you can skip autocalibration<br>by clearing it before exiting MCE                         | On powerup, the codec always<br>autocalibrates before you have<br>access to the codec and the<br>ACAL bit is cleared.                                                                          |
| Sample Rate              | Sample rate selected with register<br>0x08 or (when the FREN bit is<br>set) with registers 0x16 and 0x17                          | Sample rate only selected with registers 0x16 and 0x17.                                                                                                                                        |
| Host Interface           | Host interface consists of four<br>8-bit registers, addressed as<br>base+0, +1, +2, & +3.                                         | Host interface consists of four 16-bit registers, addressed as base+0, $+2$ , $+4$ , & $+6$ .                                                                                                  |
|                          | All capture and playback data is passed through the 8-bit interface.                                                              | Capture and playback data can be<br>passed in 8 or 16-bit transfer<br>modes (selected by CINF8 and<br>PINF8 bits).                                                                             |
|                          |                                                                                                                                   | Control information is written to<br>or read from the lower bytes of<br>the interface registers.                                                                                               |
| Data Format<br>Selection | In Mode1, data format is selected with register 0x08.                                                                             | Because AD1812's codec is always in "Mode2":                                                                                                                                                   |
|                          | In Mode2, Playback format is selected with register 0x08.                                                                         | Playback format is selected with register 0x08.                                                                                                                                                |
|                          | In Mode2, Capture format is selected with register 0x1B.                                                                          | Capture format is selected with register 0x1B.                                                                                                                                                 |
| Data Formats             | The AD1845 supports the following playback/capture data formats:                                                                  | The AD1812's codec supports the following playback/capture data formats:                                                                                                                       |
|                          | <ul> <li>16-bit, signed Little Endian</li> <li>8-bit, unsigned PCM</li> <li>8-bit, μ-Law PCM</li> <li>8-bit, A-Law PCM</li> </ul> | <ul> <li>16-bit, signed Little Endian</li> <li>16-bit, signed Big Endian</li> <li>8-bit, unsigned PCM</li> <li>8-bit, μ-Law PCM</li> <li>8-bit, A-Law PCM</li> <li>4-bit, IMA-ADPCM</li> </ul> |

### Table 2.17 Comparison of AD1845 Vs. AD1812's Codec

| Feature         | AD1845                                                                                                                         | AD1812's Integrated Codec                                                                                                                                                                                                                  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data Transfer   | The AD1845 uses the following techniques for data transfer:                                                                    | The AD1812 uses the following techniques for data transfer:                                                                                                                                                                                |
|                 | • DMA counters are<br>programmed with the number<br>of samples to transfer.<br>Counters decrement by one<br>with each transfer | • DMA counters are<br>programmed with the number<br>of samples to transfer.<br>Counters decrement by the<br>number of samples (varies<br>with format) in each transfer.                                                                    |
|                 | • Transfer 1 sample per transfer, varying the size (number of bits) of the transfer.                                           | • Transfer 32-bits per transfer,<br>varying the number of<br>samples (based on data<br>format) in each transfer.                                                                                                                           |
|                 | • Store uncompressed data in fixed depth (16 position) FIFO buffer.                                                            | • Store compressed data in<br>FIFO buffer. Because the<br>number of samples in the<br>buffer depends on the format,<br>the number of samples in the<br>buffer varies from 16 (16bit,<br>linear, stereo) to 128 (4bit,<br>IMA-ADPCM, mono). |
| Bit Differences | AD1845 INITD Bit                                                                                                               | This bit (0x0A, [0]) is now<br>reserved. The INITD bit's<br>functionality is not needed<br>because the AD1812 does not<br>transition between Mode1 and<br>Mode2.                                                                           |
|                 | AD1845 BUF8 Bit                                                                                                                | This bit (0x0C, [5]) is now<br>reserved. The BUF8 bit's<br>functionality is now in the Plug &<br>Play powerdown register                                                                                                                   |
|                 | AD1845 MODE2 Bit                                                                                                               | This bit (0x0C, [6]) is always set (1), the AD1812 always in Mode2.                                                                                                                                                                        |
|                 | AD1845 FREN bit                                                                                                                | This bit (0x1B, [3]) is always set (1).                                                                                                                                                                                                    |

Table 2.17 Comparison of AD1845 Vs. AD1812's Codec(*ntinued*)

# 2.5 AD1812 Programming Summary

The AD1812 SoundPort Controller contains five Plug & Play logical devices (Windows Sound System, Sound Blaster Pro, AdLib, MIDI, & Game Port). Programming the logical devices on the AD1812 consists of configuring each device then sending programming information to it. You can configure these devices in Plug & Play Mod(AD1812 PnP pin asserted) or in Non-Plug & Play Mod(AD1812 PnP pin de-asserted).

Windows Sound System codec programming is also covered in this chapter. Programming procedures for data transfer, mixing, attenuation, and gain are described. The information in this chapter includes the following:

- AD1812 Programming Overview
- AD1812 Plug & Play Resource Data
- AD1812 Non-Plug & Play Configuration Procedure
- AD1812 Windows Sound System Codec Programming

The Plug & Play Logical Devices in the AD1812 comply fully with the g & Play ISA Specification Version 1.0a (May 5, 1994.)

# 3.1 Overview

The AD1812 has many direct register (PC I/O addressable) and indirect registers (indexed through the direct registers). This chapter describes all the direct registers and the set of indirect registers unique to the AD1812.

Indirect (indexed) registers not unique to the AD1812 are described in other documents. For example, the AD1812 provides similar functionality and a register set that corresponds to the Sound Blaster Pro PC plug-in card. This manual lists the PC I/O ports (registers) for the Sound Blaster Pro logical device in the AD1812, but not the indexed registers in the Sound Blaster Pro. For a description of the indexed registers in a Sound Blaster Pro, see the *Developer Kit for Sound Blaster Series* programmer's reference Sound Blaster:

Register descriptions include the following:

• Register Figure: The figure shows the register name, address (direct or indirect), bit names, and reset values for each bit (0, 1, or *X* for undetermined).



Figure 3.1 Register Diagram Example

Register Bit Table: The table lists the register's bits (in ascending order) by name and gives a usage description and bit type: (RO) Read OnlýWO) Write Only (STKY) Sticky, and (RW) Read/Write. Table3.1 lists the AD1812 registers that are directly available from the ISA Bus (PC I/O addressable ports).

|                                   | AD1812 ISA Bus Registers                             |
|-----------------------------------|------------------------------------------------------|
| Register Type—Register Name       | Register PC I/O Address                              |
| Plug & Play                       | (PnP pin asserted)                                   |
| ADDRESS                           | 0x279                                                |
| WRITE_DATA                        | 0xA79                                                |
| READ_DATA                         | Relocatable in range 0x203 - 0x3FF                   |
| Non-Plug & Play                   | (PnP pin de-asserted)                                |
| ADDRESS                           | 0x234                                                |
| WRITE_DATA                        | 0x235                                                |
| READ_DATA                         | Relocatable in range 0x203 - 0x3FF                   |
| Windows Sound System              |                                                      |
| • WSS Codec Index Address(r,w)    | 0x(WSS Base) Relocatable in range 0x0008 -<br>0xFFF8 |
| • WSS Codec Indexed Data(r,w)     | 0x(WSS Base+2)                                       |
| • WSS Codec Status (r,w)          | Ox(WSS Base+4)                                       |
| • Codec PIO Data(r,w)             | 0x(WSS Base+6)                                       |
| Sound BlasterPro                  |                                                      |
| • Music0: Address (w), Status (r) | 0x(SB Base) Relocatable in range 0x010 - 0x3F0       |
| • Music0: Data (w)                | Ox(SB Base+1)                                        |
| • Music1: Address (w)             | Ox(SB Base+2)                                        |
| • Music1: Data (w)                | Ox(SB Base+3)                                        |
| • Mixer Address(w)                | Ox(SB Base+4)                                        |
| • Mixer Data(w)                   | Ox(SB Base+5)                                        |
| • Reset (w)                       | 0x(SB Base+6)                                        |
| • Music0: Address (w)             | 0x(SB Base+8)                                        |
| • Music0: Data (w)                | 0x(SB Base+9)                                        |
| • Input Data (r)                  | Ox(SB Base+A)                                        |
| • Status (r), Output Data (w)     | Ox(SB Base+C)                                        |
| • Status (r)                      | Ox(SB Base+E)                                        |
| AdLib                             |                                                      |
| • Music0: Address (w), Status (r) | 0x(Adlib Base) Relocatable in range 0x008 -<br>0x3F8 |
| • Music0: Data (w)                | Ox(Adlib Base+1)                                     |
| • Music1: Address (w)             | Ox(Adlib Base+2)                                     |
| • Music1: Data (w)                | Ox(Adlib Base+3)                                     |
| MIDI MPU-401                      |                                                      |
| MIDI Data (r/w)                   | 0x(MIDI Base) Relocatable in range 0x008 -<br>0x3F8  |
| • MIDI Status (r), Command (w)    | Ox(MIDI Base+1)                                      |
| Game Port                         |                                                      |
| • Game Port I/O                   | 0x(Game Base) Relocatable in range 0x001 -<br>0x3FF  |

 Table 3.1 Map of AD1812 ISA Bus Registers

# 3.2 AD1812 Plug & Play AndNon-Plug & Play Registers

This section describes the Plug & Play and Non-Plug & Play registers unique to the AD1812. For descriptions of direct and indirect Plug & Play (and corresponding Non-Plug & Play) registers, see the *Plug & Play ISA Specification Version 1.0a (May 5, 1994*) from Intel and Microsoft.

#### 3.2.1 Plug & Play And Non-Plug & Play ISA Bus Registers (Ports)

The AD1812 has two configuration modes, Plug & Play (PnP pin asserted) and Non-Plug & Play (PnP pin de-asserted). Tables 3.2 and 3.3 list the Plug & Play and Non-Plug & Play ISA Bus Registers. For programming information (i.e. using Plug & Play registers to configure the AD1812), see Chapter 2*AD1812 Programming* 

| Table 3.2 | Plug & Pl | ay ISA Bu | s Registers | (PnP pin | asserted) |
|-----------|-----------|-----------|-------------|----------|-----------|
|           |           |           |             |          |           |

| Register   | Description                        |
|------------|------------------------------------|
| ADDRESS    | 0x279                              |
| WRITE_DATA | 0xA79                              |
| READ_DATA  | Relocatable in range 0x203 - 0x3FF |

| Table 3.3 Non-Plug & Play ISA Bus Registers (PnP pin de-asserted) |
|-------------------------------------------------------------------|
|-------------------------------------------------------------------|

| Register   | Description                        |
|------------|------------------------------------|
| ADDRESS    | 0x234                              |
| WRITE_DATA | 0x235                              |
| READ_DATA  | Relocatable in range 0x203 - 0x3FF |

#### 3.2.2 Plug & Play And Non-Plug & Play Indexed Registers

The AD1812 supports all required registers described in the *lug & Play ISA* Specification Version 1.0a (May 5, 1994 from Intel and Microsoft. This section contains descriptions of the AD1812's vendor defined Plug & Play registers. For descriptions of the complete set of Plug & Play registers see the Intel/Microsoft specification. As with the ISA bus registers—for programming information, see Chapter 2D1812 Programming

In Plug & Play mode (PnP pinasserted) and Non-Plug & Play mode (PnP pin deasserted), your SoundPort Controller configuration routine uses the ADDRESS WRITE\_DATA, and READ\_DATA registers (ports) to configure the chip. Writes to WRITE\_DATA and reads from READ\_DATA access the internal Plug & Play register pointed to by the address in the ADDRESS gegister (port).

|                                                 | a I lay—Indexed Registers |             |  |  |
|-------------------------------------------------|---------------------------|-------------|--|--|
| Indexed Plug & Play Register                    | Index                     | Reset State |  |  |
| Set RD_DATA Port                                | 0x00                      | 0x00        |  |  |
| Serial Isolation                                | 0x01                      | 0x00        |  |  |
| Config Control                                  | 0x02                      | 0x00        |  |  |
| Wake [CSN]                                      | 0x03                      | 0x00        |  |  |
| Resource Data                                   | 0x04                      | 0x00        |  |  |
| Status                                          | 0x05                      | 0x00        |  |  |
| Card Select Number                              | 0x06                      | 0x00        |  |  |
| Logical Device Number(LDN)                      | 0x07                      | 0x00        |  |  |
| Powerdown                                       | 0x20                      | 0x00        |  |  |
| Activate (LDN Indexed)                          | 0x30                      | 0x00        |  |  |
| I/O Range Check(LDN Indexed)                    | 0x31                      | 0x00        |  |  |
| I/O port base addressdescriptor 0 (LDN Indexed) | 0x60 - 061                | 0x00        |  |  |
| Interrupt level select0 (LDN Indexed)           | 0x70                      | 0x00        |  |  |
| Interrupt type select0 (LDN Indexed)            | 0x71                      | 0x02        |  |  |
| DMA channel select() (LDN Indexed)              | 0x74                      | 0x04        |  |  |
| DMA channel select 1 (LDN Indexed)              | 0x75                      | 0x04        |  |  |

Table 3.4 Map of AD1812 Plug & Play—Indexed Registers

For Plug & Play indexed registers with addresses of 0x30 and up, the contents of the Logical Device Number register applies a second tier of indexing. Figure 3.2 shows how the indexing scheme applies to Plug & Play register types. Table 3.4 lists the internal Plug & Play registers, their indices, and reset values.



Figure 3.2 AD1812 Plug & Play Register Indexing



| Bits       | Description (Plug & Play Indexed (0x20) Powerdown Register                                                              |
|------------|-------------------------------------------------------------------------------------------------------------------------|
| [0]        | SoundPort ISA Bus Ready                                                                                                 |
| SP_ISA_RDY | 1 Indicates SoundPort is in Windows Sound System mode.                                                                  |
| (RW)       | 0 Indicates SoundPort is in Sound Blaster mode.                                                                         |
|            | Note: Compare the contents of SP_ISA_RDY and SP_ISA_REQ (must be identical, either 0 or 1) before using the Sound Port. |
| [1]        | SoundPort Powerup Ready                                                                                                 |
| SP_PU_RDY  | 1 Indicates the 1845 is powered up.                                                                                     |
| (RO)       |                                                                                                                         |
| [2]        | SoundPort Powerdown Ready                                                                                               |
| SP_PD_RDY  | 1 Indicates the 1845 is powered down.                                                                                   |
| (RO)       |                                                                                                                         |

| Bits       | Description (Plug & Play Indexed (0x20) Powerdown Register                                                                                                     |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | (continued)                                                                                                                                                    |
| [3]        | SoundPort ISA Bus Request                                                                                                                                      |
| SP_ISA_REQ | 1 Requests the SoundPort in Windows Sound System mode                                                                                                          |
| (RW)       | 0 Requests the SoundPort in Sound Blaster mode.                                                                                                                |
|            | The codec changes modes within approximately 1 ms of writing<br>to SP_ISA_REQ and in Windows Sound System mode is<br>delivered in MCE mode with outputs muted. |
|            | Note: Compare the contents of SP_ISA_RDY and SP_ISA_REQ (must be identical, either 0 or 1) before writing to SP_ISA_RDY                                        |
| [4]        | DSP Powerup Ready                                                                                                                                              |
| DSP_PU_RDY | 1 when the DSP is powered up.                                                                                                                                  |
| (RO)       |                                                                                                                                                                |
| [5]        | DSP Powerdown Ready                                                                                                                                            |
| DSP_PD_RDY | 1 when the DSP is powered down.                                                                                                                                |
| (RO)       |                                                                                                                                                                |
| [6]        | ISA 8 mA Driver Enable                                                                                                                                         |
| ISA8MA     | Writing a 1 selects 8 mA line drivers for ISA bus signals.                                                                                                     |
| (RW)       | Writing a 0 selects 24 mA line drivers.                                                                                                                        |
| [7]        | Total Powerdown                                                                                                                                                |
| TOT_PWRDWN | Writing a 1 powers down the chip.                                                                                                                              |
| (RW)       | Writing a 0 powers up again.                                                                                                                                   |

# 3.3 AD1812 Windows Sound System Registers

This section describes the Windows Sound System's four directly accessible ISA bus registers and 32 indirectly accessible indexed registers. These registers let you transfer data to and from the codec and control mixing and gain.

# 3.3.1 Windows Sound System ISA Bus Registers (Ports)

The AD1812's Windows Sound System contains four direct accessible ISA bus registers (ports). To access these registers, you address them using their ISA bus address. Table 3.5 lists the Windows Sound System direct registers and their bit acronyms.

|                          |        |        | 1 ann  |        | viap u | 1 77 111 | uuuws | Boun  | u bysi |       | L'giste  |          |       |       |          |       |
|--------------------------|--------|--------|--------|--------|--------|----------|-------|-------|--------|-------|----------|----------|-------|-------|----------|-------|
| Direct<br>Address        | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10   | Bit 9 | Bit 8 | Bit 7  | Bit 6 | Bit 5    | Bit 4    | Bit 3 | Bit 2 | Bit 1    | Bit 0 |
| WSS Base                 | res    | res    | res    | res    | res    | res      | res   | res   | INIT   | MCE   | TRD      | IXA4     | IXA3  | IXA2  | IXA1     | IXA0  |
| WSS<br>Base+2            | res    | res    | res    | res    | res    | res      | res   | res   | IXD7   | IXD6  | IXD5     | IXD4     | IXD3  | IXD2  | IXD1     | IXD0  |
| WSS<br>Base+4            | res    | res    | res    | res    | res    | res      | res   | res   | CU/L   | CL/R  | CRD<br>Y | SOU<br>R | PU/L  | PL/R  | PRD<br>Y | INT   |
| WSS<br>Base+6<br>(read)  | CD15   | CD14   | CD13   | CD12   | CD11   | CD10     | CD9   | CD8   | CD7    | CD6   | CD5      | CD4      | CD3   | CD2   | CD1      | CD0   |
| WSS<br>Base+6<br>(write) | PD15   | PD14   | PD13   | PD12   | PD11   | PD10     | PD9   | PD8   | PD7    | PD6   | PD5      | PD4      | PD3   | PD2   | PD1      | PD0   |

 Table 3.5 Map of Windows Sound System Register Bits



After reset this register contains 0x40 (8-bit mode or 16-bit mode). During codec initialization, this register is read only and contains 0x80 (8-bit mode or 16-bit mode).

| Bits      | Description (WSS Codec Index Address—0xWSS Base))                                                                                                                                                                                                                                                         |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4:0]     | Index Address These bits holdthe index address of the Codec                                                                                                                                                                                                                                               |
| IXA [4:0] | register accessible through the Codec Indexed Data Register.                                                                                                                                                                                                                                              |
| (RW)      |                                                                                                                                                                                                                                                                                                           |
| [5]       | Transfer Request Disable                                                                                                                                                                                                                                                                                  |
| TRD       | 0 Enables codec transfers during a codec interrupt.                                                                                                                                                                                                                                                       |
| (RW)      | 1 Disables codec transfers during a codec interrupt.                                                                                                                                                                                                                                                      |
|           | This bit disables (1) or enables (0) codec DMA transfers during a codec interrupt (interrupt indicated by the WSS Codec Status register's INT bit being set (1)). (This assumes codec DMA transfers were enabled—the WSS Codec Indexed (0x09) Interface Configuration register's PENor CEN bits are set.) |
|           | Playback or capture DMA requests pending when the TRD bit is<br>set (1) are allowed to complete After completing apending<br>request, the codec processes thedata in the FIFO at the sample<br>rate.                                                                                                      |

| Bits               | Description (WSS Codec Index Address—0xWSS Base))                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | (continued)                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| (continued)<br>[5] | Note: <i>If the codec processes all the data in the FIFQ</i> (runs out of data), the codec has one of the following responses— <i>either</i> .                                                                                                                                                                                                                                                                                                                                          |
| TRD<br>(RW)        | • <i>Generates</i> mid-scale inputs for the DAC. The codec generates these inputs if the WSS Coded Indexed (0x10) Alternate Feature Enable /Left Mic Mix Gain register's DACZ bit is set.                                                                                                                                                                                                                                                                                               |
|                    | or                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                    | • <i>Repeats</i> the previous valid sample as input for the DAC. In this case, the codec's ADC output buffer retains the last valid output.                                                                                                                                                                                                                                                                                                                                             |
|                    | Resume processing ofplayback and/or capture requestby clearing (set to 0) either the TRD bit or the WSS Codec Status register's INT bit.                                                                                                                                                                                                                                                                                                                                                |
|                    | Note: The codec does not reportover-run or under-run errors while transfers are disabledduring a codec interrupt.                                                                                                                                                                                                                                                                                                                                                                       |
| [6]                | Mode Change Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| MCE                | 0 Disables changes to the codec's current functional mode.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| (RW)               | 1 Enables changes to the codec's current functional mode.                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                    | This bit enables (1) or disables (0) changes to the codec's curren<br>functional mode. To change the codec's current functional mode<br>(selected with WSS Codec Indexed (0x0,80x09, 0x1C, & 0x1D)<br>registers), you must first set (1) this bit, make the mode changes<br>in the indexed registers, and then clear (0) the bit(For noted<br>exceptions, see the indexed registers' descriptions.)                                                                                     |
|                    | The codec mutes DAC outputs while the MCE bit is set (1).<br>After the bit is cleared (0), the codec sets DAC outputs to the<br>state specified by the WSS Codec Indexed (0x06) Left DAC<br>Control register's LDAbits and WSS Codec Indexed (0x07)<br>Right DAC Control register's RDAbits. After exiting the mode<br>change state, the DACs' analog outputs mute and the ADCs<br>output mid-scale values for 128 sample cycles, allowing the<br>reference and filters time to settle. |
|                    | During the 128 cycle delay, the WSS Codec Indexed $(0x0H)$ est<br>and Initializationregister's ACI bit is set (1), providing a flag for<br>system software to poll rather than count the cycles.                                                                                                                                                                                                                                                                                        |

| Bits                              | Description (WSS Codec Index Address—0xWSS Base))<br>(continued)                                                                                                                                                                                              |
|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (continued)<br>[6]<br>MCE<br>(RW) | Note: If the WSS Codec Indexed (0x09Interface Configuration register's ACALbit is set (1) when exiting mode change state, the codec goes through an autocalibration. (For information on the autocalibration sequence, see Chapter 2AD1812 <i>Programming</i> |
| [7]                               | Codec Initialization                                                                                                                                                                                                                                          |
| INIT                              | 0 Codec can respondto parallel bus cycles.                                                                                                                                                                                                                    |
| (RO)                              | 1 Codec does not response o parallel bus cycles.                                                                                                                                                                                                              |
|                                   | This bit is set(1) by the codecwhen the codec's state dis-allows response to parallel bus cycles.                                                                                                                                                             |
| [15:8]                            | Reserved for future expansionAlways write a zero to these bits.                                                                                                                                                                                               |
| Reserved                          |                                                                                                                                                                                                                                                               |

|                                      | F            | igur | e <b>3.5</b> | Wind | lows | Soun | d Sys | tem ( | Codec | : Inde        | exed l | Data 1 | Regis | ter |   |
|--------------------------------------|--------------|------|--------------|------|------|------|-------|-------|-------|---------------|--------|--------|-------|-----|---|
| WSS Codec Indexed Data Ox(WSS Base + |              |      |              |      |      |      |       |       |       | e <b>+ 2)</b> |        |        |       |     |   |
| 15                                   | 14           | 13   | 12           | 11   | 10   | 9    | 8     | 7     | 6     | 5             | 4      | 3      | 2     | 1   | 0 |
| 0                                    | 0            | 0    | 0            | 0    | 0    | 0    | 0     | 0     | 0     | 0             | 0      | 0      | 0     | 0   | 0 |
| Reserved                             |              |      |              |      |      |      |       |       |       |               |        |        |       |     |   |
|                                      | Indexed Data |      |              |      |      |      |       |       |       |               |        |        |       |     |   |

During codec initialization, this register is read only and contains 0x80 (8-bit mode or 16-bit mode).

| Bits      | Description (WSS Codec Indexed Data—0x/WSS Base+2))                        |
|-----------|----------------------------------------------------------------------------|
| [7:0]     | Indexed DataRegister. These bits hold thecontents of the                   |
| IXD [7:0] | indexed odec register pointed to by the WSSCodec Index<br>Address register |
| (RW)      | Address register                                                           |
| [15:8]    | Reserved for future expansionAlways write a zero to these bits.            |
| Reserved  |                                                                            |



During codec initialization, this register is read only and contains 0x80 (8-bit mode) or 0x88 (16-bit mode). The register contains 0xCC after reset. Note that PRDY, CRDY, and INT bits of this register*can* change asynchronously tdSA bus accesses. Reads of these bits during bit transition will ot always return the post transition bit value. For timing information used when reading this register, see the D1812 Data Sheet

| Bits   | Description (WSS Codec Status—0x(WSS Base+4))                                                                                                                          |  |  |  |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [0]    | Codec Interrupt                                                                                                                                                        |  |  |  |
| INT    | 0 No codec interrupt.                                                                                                                                                  |  |  |  |
| (STKY) | 1 Active codec interrupt.                                                                                                                                              |  |  |  |
|        | This bit indicates that a codec interrupt is active (1) or inactive (0). The bit is <i>sticky</i> , cleared (0) whenever <i>any</i> value is written to this register. |  |  |  |
|        | Note: <i>Underflow</i> conditions generate codec interrupts. An underflow of either the DMA current count or timer registers generates a codec interrupt.              |  |  |  |

| Bits         | Description (WSS Codec Index Address—0xWSS Base+4))<br>(continued)                                                                                                                                                                                                                                                                                                                                                              |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1]          | Playback Data Ready                                                                                                                                                                                                                                                                                                                                                                                                             |
| PRDY         | 0 DAC data for playback valid.                                                                                                                                                                                                                                                                                                                                                                                                  |
| (RO)         | 1 DAC data for playback invalid.                                                                                                                                                                                                                                                                                                                                                                                                |
|              | This bit indicates that the DAC data for playback is valid (0) or invalid (1).                                                                                                                                                                                                                                                                                                                                                  |
|              | When the PRDY bit is set (1), the Windows Sound System<br>Programmed I/O Playback Data register (0xWSS Base + 6) is<br>ready for more data. When the PRDY bit is cleared (0), the data<br>in the playback register is valid and you should not overwrite the<br>data.                                                                                                                                                           |
| [2]          | Playback Left/Right Sample                                                                                                                                                                                                                                                                                                                                                                                                      |
| PL/R         | 0 Playback data needed for right channel                                                                                                                                                                                                                                                                                                                                                                                        |
| (RO)         | 1 Playback data needed for left channel or mono.                                                                                                                                                                                                                                                                                                                                                                                |
|              | This bit indicatesPIO playback data is needed for the left channel DAC (1), right channel DAC (0), or mono (1).                                                                                                                                                                                                                                                                                                                 |
| [3]          | Playback Upper/Lower Byte                                                                                                                                                                                                                                                                                                                                                                                                       |
| PU/L<br>(RO) | 0 Word 0 (if PINF8=0) or lower 8 bits (if PINF8=1) of playback data needed.                                                                                                                                                                                                                                                                                                                                                     |
| (110)        | 1 Word 1 (if PINF8 =0) or upper 8 bits (if PINF8=1) of playback data needed.                                                                                                                                                                                                                                                                                                                                                    |
|              | If using the 16 bit interface, (PINF8=1) with any format (16, 8 or 4-bit), Word 0 or Word 1 is transferred according to the order shown in Tables 2.11 and 2.12. If using the 8-bit interface (PINF8=1) with any 16 bit format, the codec transfers bytes according to the order shown in Table 2.14. Note that if using the 8-bit interface (PINF8=1) with 8 or 4-bit formats, data is only needed when PU/L=1 (always upper). |

| Bits         | Description (WSS Codec Index Address—0xWSS Base+4))<br>(continued)                                                                                                                                                                                                                                                                                                                                                             |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4]          | Sample Over/Underrun                                                                                                                                                                                                                                                                                                                                                                                                           |
| SOUR         | 0 Most recent sample was serviced in time.                                                                                                                                                                                                                                                                                                                                                                                     |
| (RO)         | 1 Most recent sample was not serviced in time.                                                                                                                                                                                                                                                                                                                                                                                 |
|              | On a sample-by-sample basis, this bit indicates that the most recent sample was (0) or was not (1) serviced in time.                                                                                                                                                                                                                                                                                                           |
|              | If the sample was not serviced in time, a capture overrun or<br>playback underrun condition occurs. The codec indicates these<br>conditions with bits in the WSS Codec Indexed (0x0B) Test and<br>Initialization register; setting (1) the CORbit on capture overruns<br>and setting (1) the PURbit on playback underruns.                                                                                                     |
| [5]          | Capture Data Ready.                                                                                                                                                                                                                                                                                                                                                                                                            |
| CRDY         | 0 ADC data is fresh.                                                                                                                                                                                                                                                                                                                                                                                                           |
| (RO)         | 1 ADC data is stale.                                                                                                                                                                                                                                                                                                                                                                                                           |
|              | Use this bit when using direct programmed I/O transfers to indicate whether the ADC data is fresh (0) or stale (1). If the data is fresh, read it. Do <i>not</i> re-read stale data.                                                                                                                                                                                                                                           |
| [6]          | Capture Left/Right Sample                                                                                                                                                                                                                                                                                                                                                                                                      |
| CL/R         | 0 PIO capture data waiting for right channel ADC.                                                                                                                                                                                                                                                                                                                                                                              |
| (RO)         | 1 PIO capture data waiting for left channel ADC or mono.                                                                                                                                                                                                                                                                                                                                                                       |
|              | This bit indicates PIO capture data is waiting for the right channe ADC (0), left channel ADC (1), or mono (1).                                                                                                                                                                                                                                                                                                                |
| [7]          | Capture Upper/Lower Byte                                                                                                                                                                                                                                                                                                                                                                                                       |
| CU/L<br>(RO) | 0 Word 0 (if PINF8=0) or lower 8 bits (if PINF8=1) of capture data is ready.                                                                                                                                                                                                                                                                                                                                                   |
| (110)        | 1 Word 1 (if PINF8 =0) or upper 8 bits (if PINF8=1) of capture data is ready.                                                                                                                                                                                                                                                                                                                                                  |
|              | If using the 16 bit interface, (PINF8=1) with any format (16, 8 or 4-bit), Word 0 or Word 1 is transferred according to the order shown in Tables 2.11 and 2.12. If using the 8-bit interface (PINF8=1) with any 16 bit format, the codec transfers bytes according to the order shown in Table 2.14. Note that if using the 8-bit interface (PINF8=1) with 8 or 4-bit formats, data is only ready when CU/L=1 (always upper). |
| [15:8]       | Reserved for future expansionAlways write a zero to these bits.                                                                                                                                                                                                                                                                                                                                                                |



During codec initialization, this register is read only and contains 0x80 (8-bit mode) or 0x88 (16-bit mode). The PIO Dataregisters are two registers mapped to the same address. Writes send data to the PIO Playback Datægister (PD[15:0]). Reads receive data from the PIO Capture Data Register (CD[15:0]).

| Bits                       | Description (WSS Codec PIO Data—0x(WSS Base+6))                                                                                                                                                                                                         |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [15:0]<br>CD [15:0]<br>(R) | <i>Capture Data</i> (R). These bits hold the capture data read during<br>Programmed I/O transfers. When you read from this register, the<br>codec increments the state machine to read from the next byte or<br>word in the sample.                     |
|                            | Note that the contents of theWSS Codec Status register indicate the identity (upper/lower byte, left/right sample) of the next byte to be read.                                                                                                         |
|                            | After all bytes in the sample are read, the codec points the state<br>machine and WSS Codec Status register to the last byte or word<br>in the sample, and until a new sample is received the register<br>returns the last byte in the sample on reads. |
|                            | When the codec receives this new sample, it points the state machine to the first byte/word in the sample. The ready bit indicates a new sample is available.                                                                                           |
| PD [15:0]<br>(W)           | <i>Playback Data</i> (W). These bits hold the playback data written during Programmed I/O transfers. When you write to this register, the codec increments the playback byte tracking state machine for the write of the next byte in the sample.       |
|                            | After all bytes in the sample are written, the codec ignores<br>subsequent writes to this register until the sample is sent to the<br>DACs; at that point the codec resets the state machine and sets<br>the ready bit in the status register.          |

## 3.3.2 Windows Sound System Indexed Registers

The AD1812's Windows Sound System contains 32 indexed registers. To access these registers, you address them through an index address register (WSS base address) and write/read data through an index data register (WSS Base address + 2). Table 3.6 lists the internal codec registers, their indices, and reset values (an "x" digit in the reset value indicates the bit is indeterminate (not set) on reset). Table 3.7 shows a map of the Index register bits. Note that you can always access the WSS Codec Status and WSS Codec PIO Data registers because these registers are directly accessible without indexing.

| Table 3.6 Map of AD1812 Windows Sound S         | system.odec— | -Indexed Registers |
|-------------------------------------------------|--------------|--------------------|
| Windows Sound System Codec Indexed Register     | Index        | Reset State        |
| Left Input Control                              | 0x00         | 0x80               |
| Right Input Control                             | 0x01         | 0x80               |
| Left Aux #1 Input Control                       | 0x02         | 0x9F               |
| Right Aux #1 Input Control                      | 0x03         | 0x9F               |
| Left Aux #2 Input Control                       | 0x04         | 0x9F               |
| Right Aux #2 Input Control                      | 0x05         | 0x9F               |
| Left Output Control                             | 0x06         | 0xBF               |
| Right Output Control                            | 0x07         | 0xBF               |
| Playback Data Format                            | 0x08         | 0x08               |
| Interface Configuration                         | 0x09         | 0x00               |
| Pin Control                                     | 0x0A         | 0x05               |
| Test and Initialization                         | 0x0B         | 0x20               |
| Miscellaneous Information                       | 0x0C         | 0xCA               |
| Digital Mix/Attenuation                         | 0x0D         | 0x00               |
| Playback Upper Base Count                       | 0x0E         | 0x00               |
| Playback Lower Base Count                       | 0x0F         | 0x00               |
| Alternate Feature Enable/Left MIC Input Control | 0x10         | 0x80               |
| MIC Mix Enable/Right MIC Input Control          | 0x11         | 0x00               |
| Left Line Gain, Attenuate, Mute, Mix            | 0x12         | 0x9F               |
| Right Line Gain, Attenuate, Mute, Mix           | 0x13         | 0x9F               |
| Lower Timer                                     | 0x14         | 0x00               |
| Upper Timer                                     | 0x15         | 0x00               |
| Upper Frequency Select                          | 0x16         | 0x2A               |
| Lower Frequency Select                          | 0x17         | 0xF8               |
| Capture Playback Timer                          | 0x18         | 0x30               |
| Revision ID                                     | 0x19         | 0x80               |
| Mono Control                                    | 0x1A         | 0xC0               |
| Power-Down Control                              | 0x1B         | 0x08               |
| Capture Data Format                             | 0x1C         | 0x50               |
| Total Power-Down                                | 0x1D         | 0x00               |
| Capture Upper Base Count                        | 0x1E         | 0x00               |

Table 3.6 Map of AD1812 Windows Sound SystemCodec—Indexed Registers

| Capture Lower Base Count | 0x1F | 0x00 |  |
|--------------------------|------|------|--|
|--------------------------|------|------|--|

|                     | Table 3.7 | Map of | Window | Sound Sy | stem mu | exeu Kegi | Stel Dits |       |
|---------------------|-----------|--------|--------|----------|---------|-----------|-----------|-------|
| Indirect<br>Address | Bit 7     | Bit 6  | Bit 5  | Bit 4    | Bit 3   | Bit 2     | Bit 1     | Bit 0 |
| 0x00                | LSS1      | LSS0   | LMGE   | res      | LIG3    | LIG2      | LIG1      | LIG0  |
| 0x01                | RSS1      | RSS0   | RMGE   | res      | RIG3    | RIG2      | RIG1      | RIG0  |
| 0x02                | LMX1      | res    | res    | LX1A4    | LX1A3   | LX1A2     | LX1A1     | LX1A0 |
| 0x03                | RMX1      | res    | res    | RX1A4    | RX1A3   | RX1A2     | RX1A1     | RX1A0 |
| 0x04                | LMX2      | res    | res    | LX2A4    | LX2A3   | LX2A2     | LX2A1     | LX2A0 |
| 0x05                | RMX2      | res    | res    | RX2A4    | RX2A3   | RX2A2     | RX2A1     | RX2A0 |
| 0x06                | LDM       | res    | LDA5   | LDA4     | LDA3    | LDA2      | LDA1      | LDA0  |
| 0x07                | RDM       | res    | RDA5   | RDA4     | RDA3    | RDA2      | RDA1      | RDA0  |
| 0x08                | PFMT1     | PFMT0  | PC/L   | PS/M     | PBSW    | PINF8     | res       | res   |
| 0x09                | CPIO      | PPIO   | res    | res      | ACAL    | SDC       | CEN       | PEN   |
| 0x0A                | XCTL1     | XCTL0  | res    | res      | res     | res       | IEN       | res   |
| 0x0B                | COR       | PUR    | ACI    | DRS      | ORR1    | ORR0      | ORL1      | ORL0  |
| 0x0C                | MID       | res    | res    | res      | ID3     | ID2       | ID1       | ID0   |
| 0x0D                | DMA5      | DMA4   | DMA3   | DMA2     | DMA1    | DMA0      | res       | DME   |
| 0x0E                | UB7       | UB6    | UB5    | UB4      | UB3     | UB2       | UB1       | UB0   |
| 0x0F                | LB7       | LB6    | LB5    | LB4      | LB3     | LB2       | LB1       | LB0   |
| 0x10                | OL        | TE     | LMG4   | LMG3     | LMG2    | LMG1      | LMG0      | DACZ  |
| 0x11                | LMME      | RMME   | RMG4   | RMG3     | RMG2    | RMG1      | RMG0      | res   |
| 0x12                | LLM       | res    | res    | LLG4     | LLG3    | LLG2      | LLG1      | LLG0  |
| 0x13                | RLM       | res    | res    | RLG4     | RLG3    | RLG2      | RLLG1     | RLG0  |
| 0x14                | TL7       | TL6    | TL5    | TL4      | TL3     | TL2       | TL1       | TL0   |
| 0x15                | TU7       | TU6    | TU5    | TU4      | TU3     | TU2       | TU1       | TU0   |
| 0x16                | FU7       | FU6    | FU5    | FU4      | FU3     | FU2       | FU1       | FU0   |
| 0x17                | FL7       | FL6    | FL5    | FL4      | FL3     | FL2       | FL1       | FL0   |
| 0x18                | res       | TI     | CI     | PI       | CU      | CO        | РО        | PU    |
| 0x19                | V2        | V1     | V0     | res      | res     | CID2      | CID1      | CID0  |
| 0x1A                | MIM       | MOM    | res    | res      | MIA3    | MIA2      | MIA1      | MIA0  |
| 0x1B                | ADCPWD    | DACPWD | MIXPWD | res      | res     | res       | res       | res   |

 Table 3.7 Map of Window Sound System Indexed Register Bits

| 0x1C | CFMT1 | CFMT0 | CC/L | CS/M | CBSW | CINF8 | res  | res    |
|------|-------|-------|------|------|------|-------|------|--------|
| 0x1D | res   | res   | res  | res  | res  | res   | res  | TOTPWD |
| 0x1E | CUB7  | CUB6  | CUB5 | CUB4 | CUB3 | CUB2  | CUB1 | CUB0   |
| 0x1F | CLB7  | CLB6  | CLB5 | CLB4 | CLB3 | CLB2  | CLB1 | CLB0   |



| Elemente 20 | Codec Reg.—Left Input Control (Index: 0x | .00) |
|-------------|------------------------------------------|------|
| rigure 5.8  | Codec Reg.—Leit Indut Control (Index: Ux | (UU) |
|             |                                          | ,    |

| Bits               | Description (Left Input Control—WSS Codec Index 0x00)                                                                                                                                                                                     |  |  |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [3:0]<br>LIG [3:0] | Left Input Gain select These bits hold the gain select for the left<br>input. Using these bits, you can select gains from 0 dB<br>(LIG=0x0) to +22.5 dB (LIG=0xF) in +1.5 dB increments.                                                  |  |  |
| (RW)               | The following equation lets you determine the value to load into LIG [3:0]: $(Gain dB) / (1.5 dB) = LIG$                                                                                                                                  |  |  |
|                    | For 18 dB gain, example: 18 dB / 1.5 dB = 12 = 0b1100 = LIG                                                                                                                                                                               |  |  |
| [4]                | Reserved for future expansion. Always write a zero to this bit.                                                                                                                                                                           |  |  |
| res                |                                                                                                                                                                                                                                           |  |  |
| [5]                | Left Input Microphone Gain Enable                                                                                                                                                                                                         |  |  |
| LMGE               | 0 Disables a 20 dB gain of the ft mic input signal.                                                                                                                                                                                       |  |  |
| (RW)               | 1 Enables a 20 dB gain of the ft mic input signal.                                                                                                                                                                                        |  |  |
|                    | This bit enables (1) or disables (0) a 20 dB gain of theft mic input signal.                                                                                                                                                              |  |  |
| [7:6]<br>LSS [1:0] | Left Input Source Select These bits hold the selection of input<br>source for the left gain stage (preceding the left ADC) according<br>to the following table:                                                                           |  |  |
| (RW)               | <ul> <li>LSS1 LSS0 Left Input Source</li> <li>0 0 Left Line Source Selected</li> <li>0 1 Left Aux #1 Source Selected</li> <li>1 0 Left Microphone Source Selected</li> <li>1 1 Left Line Post-Mixed DAC Output Source Selected</li> </ul> |  |  |



| Figure 3.9  | Codec Reg   | -Right Inpu | t Control (II | ndex: 0x01) |
|-------------|-------------|-------------|---------------|-------------|
| I Igui COI/ | Course meg. | - many mpu  |               | nucht onor  |

| Bits                       | Description (Right Input Control—WSS Codec Index 0x01)                                                                                                                                                                                                                                                                                                         |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3:0]<br>RIG [3:0]<br>(RW) | Right Input Gain select These bits hold the gain select for the<br>right input. Using these bits, you can select gains from 0 dB<br>(RIG=0x0) to +22.5 dB (RIG=0xF) in +1.5 dB increments.The following equation lets you determine the value to load into<br>RIG [3:0]: (Gain dB) / (1.5 dB) = RIGFor 18 dB gain, example: 18 dB / 1.5 dB = 12 = 0b1100 = RIG |
| [4]<br>res                 | Reserved for future expansion. Always write a zero to this bit.                                                                                                                                                                                                                                                                                                |
| [5]<br>RMGE<br>(RW)        | <ul> <li>Right Input Mic Gain Enable</li> <li>0 Disables a+20 dB gain of the right mic input signal.</li> <li>1 Enables a+20 dB gain of the right mic input signal.</li> <li>This bit enables (1) or disables (0) a+20 dB gain of the right mic input signal.</li> </ul>                                                                                       |
| [7:5]<br>RSS [1:0]<br>(RW) | Right Input Source Select These bitshold the selection of input<br>source for the right channel gain stag@preceding the right ADQ<br>according to the following table:RSS1 RSS0Right Input Source00Right Line Source Selected011010111Right Post-Mixed DAC Output Source Selected                                                                              |



Figure 3.10 Codec Reg.—Left Aux #1 Input Control (Index: 0x02)

| Bits                        | Description<br>(Left Aux Input #1 Attenuate Select—WSS Codec Index 0x02)                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4:0]<br>LX1A [4:0]<br>(RW) | Left Auxiliary Input #1 Attenuate SelectThese bits hold the<br>gain/attenuate select for the left #1 <b>a</b> uxiliaryinput. Using these<br>bits, you can select gain/attenuates from 12 dB (LX1A=0x00) to<br>-34.5 dB (LX1A=0x1F) in-1.5 dB increments.<br>The following equation lets you determine the value to load into<br>LX1A [4:0]: ((Gain <i>or</i> -Atten. dB) - 12 dB) / (-1.5 dB) = LX1A<br>For +3 dB gain, example:<br>(3dB - 12 dB) / (-1.5 dB) = 6 = 0b00110 = LX1A |
|                             | Note: For 0 dB gain, set LX1A [4:0] = 0b01000                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [6:5]                       | Reserved for future expansion. Always write zeros to these bits.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| res                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [7]                         | Left Auxiliary #1 Mute                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| LMX1                        | 0 Un-mutes the left #1 auxiliary input source.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| (RW)                        | 1 Mutes the left #1 auxiliary input source.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                             | This bit mutes (1) or un-mutes (0) the left #1 uxiliary input source.                                                                                                                                                                                                                                                                                                                                                                                                              |



|                             | Right Aux #1 Mute I<br>Right Aux Input #1 Attenuate                                                                                                                                                                                              |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits                        | Description<br>(Right Aux Input #1 Attenuate Select—WSS Codec Index 0x03)                                                                                                                                                                        |
| [4:0]<br>RX1A [4:0]<br>(RW) | Right Auxiliary Input #1 Attenuate SelectThese bits hold the gain/attenuateselect for the right #1 <b>a</b> uxiliaryinput. Using these bits, you can select gain/attenuates from 12 dB (RX1A=0x00) to -34.5 dB (RX1A=0x1F) in 1.5 dB increments. |
|                             | The following equation lets you determine the value to load into RX1A [4:0]: $((Gain or - Atten. dB) - 12 dB) / (-1.5 dB) = RX1A$<br>For +3 dB gain, example:                                                                                    |
|                             | (3dB - 12 dB) / (-1.5 dB) = 6 = 0b00110 = RX1A<br>Note: For 0 dB gain, set RX1A [4:0] = 0b01000                                                                                                                                                  |
| [6:5]<br>res                | Reserved for future expansion. Always write zeros to these bits.                                                                                                                                                                                 |
| [7]<br>RMX1<br>(RW)         | Right Auxiliary #1 Mute0Un-mutes the right #1 auxiliary input source.1Mutes the right #1 auxiliary input source                                                                                                                                  |
|                             | This bit mutes (1) or un-mutes (0)the right #1 auxiliary input source.                                                                                                                                                                           |

Figure 3.11 Codec Reg.—Right Aux #1 Input Control (Index: 0x03)



Figure 3.12 Codec Reg.—Left Aux #2 Input Control (Index: 0x04)

| Bits       | Description                                                                                                                                                                       |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | (Left Aux Input #2 Attenuate Select—WSS Codec Index 0x04)                                                                                                                         |
| [4:0]      | Left Auxiliary Input # Attenuate Select These bits hold the                                                                                                                       |
| LX2A [4:0] | gain/attenuateselect for the left #2 <b>a</b> xiliaryinput. Using these bits, you can select gain/attenuates from 12 dB (LX2A=0x00) to -34.5 dB (LX2A=0x1F) in 1.5 dB increments. |
|            | The following equation lets you determine the value to load into LX2A [4:0]: $((Gain or - Atten. dB) - 12 dB) / (-1.5 dB) = LX2A$                                                 |
|            | For +3 dB gain, example:                                                                                                                                                          |
|            | (3dB - 12 dB) / (-1.5 dB) = 6 = 0b00110 = LX2A                                                                                                                                    |
|            | Note: For 0 dB gain, set LX2A [4:0] = 0b01000                                                                                                                                     |
| [6:5]      | Reserved for future expansion. Always write zeros to these bits.                                                                                                                  |
| res        |                                                                                                                                                                                   |
| [7]        | Left Auxiliary #2 Mute                                                                                                                                                            |
| LMX2       | 0 Un-mutes the left auxiliary #2 input source.                                                                                                                                    |
|            | 1 Mutes the left auxiliary #2 input source                                                                                                                                        |
|            | This bit mutes (1) or un-mutes (0) the left auxiliary #2 input source. This bit powers up set.                                                                                    |



| Figure 2.12 | Codes Dec  | Diaht Aug #2 In | mut Control (In   | down 0-05) |
|-------------|------------|-----------------|-------------------|------------|
| Figure 5.15 | Couer Keg. | Right Aux #2 In | iput Control (III | uex. 0x03) |

| Bits                        | Description<br>(Right Aux Input #2 Attenuate Select—WSS Codec Index 0x05)                                                                                                                                                                          |
|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4:0]<br>RX2A [4:0]<br>(RW) | Right Auxiliary Input ≇ Attenuate Select These bits hold the<br>gain/attenuate select for the right #2 auxiliaryinput. Using these<br>bits, you can select gain/attenuates from 12 dB (RX2A=0x00) to<br>-34.5 dB (RX2A=0x1F) in-1.5 dB increments. |
|                             | The following equation lets you determine the value to load into RX2A [4:0]: $((Gain or - Atten. dB) - 12 dB) / (-1.5 dB) = RX2A$                                                                                                                  |
|                             | For +3 dB gain, example:                                                                                                                                                                                                                           |
|                             | (3dB - 12 dB) / (-1.5 dB) = 6 = 0b00110 = RX2A                                                                                                                                                                                                     |
|                             | Note: For 0 dB gain, set RX2A [4:0] = 0b01000                                                                                                                                                                                                      |
| [6:5]                       | Reserved for future expansion. Always write zeros to these bits.                                                                                                                                                                                   |
| res                         |                                                                                                                                                                                                                                                    |
| [7]                         | Right Auxiliary #2 Mute                                                                                                                                                                                                                            |
| RMX2                        | 0 Un-mutes the right #2 auxiliary input source.                                                                                                                                                                                                    |
| (RW)                        | 1 Mutes the right #2 auxiliary input source.                                                                                                                                                                                                       |
|                             | This bit mutes (1) or un-mutes (0)the right #2 auxiliary input source.                                                                                                                                                                             |



| Figure 3.14 | Codec Reg _ | _Left Outnu | t Control (Index | ·· 0x06) |
|-------------|-------------|-------------|------------------|----------|
| riguie 3.14 | Couel Keg   | -Len Outpu  | i Control (Indez | <b></b>  |

| Bits                       | Description<br>(Left Output Control—WSS Codec Index 0x06)                                                                                                                                             |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5:0]<br>LDA [5:0]<br>(RW) | Left Output Attenuate select. These bits hold the attenuate select for the left output. Using these bits, you can select attenuation from 0 dB (LDA=0x00) to -94.5 dB (LDA=0x3F) inl.5 dB increments. |
|                            | The following equation lets you determine the value to load into LDA [5:0]: (Attenuation dB) / $(-1.5 \text{ dB}) = \text{LDA}$                                                                       |
|                            | For -12 dB att., example: -12 dB / -1.5 dB = $8 = 0b01000 = LDA$                                                                                                                                      |
| [6]                        | Reserved for future expansion. Always write a zero to this bit.                                                                                                                                       |
| res                        |                                                                                                                                                                                                       |
| [7]                        | Left DAC Mute                                                                                                                                                                                         |
| LDM                        | 0 Un-mutes the left DAC output.                                                                                                                                                                       |
| (RW)                       | 1 Mutes the left DAC output.                                                                                                                                                                          |
|                            | This bit mutes (1) or un-mutes (0)the left DAC output.                                                                                                                                                |



#### Figure 3.15 Codec Reg.—Right Output Control (Index: 0x07)

| Bits                       | Description<br>(Right Output Control—WSS Codec Index 0x07)                                                                                                                                                |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5:0]<br>RDA [5:0]<br>(RW) | Right Output Attenuate select. These bits hold the attenuate select for the right output. Using these bits, you can select attenuation from 0 dB (RDA=0x00) to -94.5 dB (RDA=0x3F) in -1.5 dB increments. |
|                            | The following equation lets you determine the value to load into RDA [5:0]: (Attenuation dB) / (-1.5 dB) = RDA                                                                                            |
|                            | For -12 dB att., example: -12 dB / -1.5 dB = $8 = 0b01000 = RDA$                                                                                                                                          |
| [6]                        | Reserved for future expansion. Always write a zero to this bit.                                                                                                                                           |
| res                        |                                                                                                                                                                                                           |
| [7]                        | Right DAC Mute                                                                                                                                                                                            |
| RDM                        | 0 Un-mutes the right DAC output.                                                                                                                                                                          |
| (RW)                       | 1 Mutes the right DAC output.                                                                                                                                                                             |
|                            | This bit mutes (1) or un-mutes (0) theright DAC output                                                                                                                                                    |



Figure 3.16 Codec Reg.—Clock and Data Format (Index: 0x08)

NOTE: To change the bits in this register, place the codec in the Mode Change Enable (MCE) state or set PEN=0.

| Bits  | Description<br>(Playback Data Format—WSS Codec Index 0x08)                                                                                                                                                                                                              |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1:0] | Reserved for future expansion. Always write a zero to this bit.                                                                                                                                                                                                         |
| res   |                                                                                                                                                                                                                                                                         |
| [2]   | Playback 8-bit Interface                                                                                                                                                                                                                                                |
| PINF8 | 0 Playback channel is in 16-bit mode.                                                                                                                                                                                                                                   |
| (RW)  | 1 Playback channel is in 8-bit mode                                                                                                                                                                                                                                     |
|       | This bit indicates that playback channel is in8-bit (1) or 16-<br>bit (0) mode.                                                                                                                                                                                         |
|       | Note: The PFMT bits in this register select among 8-bit or 16-bit<br>interface on the codec; programming this bit's contents must be<br>coordinated with programming the Plug & Play configuration<br>registers selection of 8-bit or 16-bit transfers and DMA channels |
| [3]   | Playback Byte Swap                                                                                                                                                                                                                                                      |
| PBSW  | 0 The byte order of output words is at default.                                                                                                                                                                                                                         |
| (RW)  | 1 The byte order of output words is swapped.                                                                                                                                                                                                                            |
|       | For 16-bit interface (PINF8=0), this bit swaps (1) or leaves at default (0) the byte order of output words.                                                                                                                                                             |

| Bits                     | Description                                                                                                                                                                                                                                                   |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                          | (Clock and Data Format—WSS Codec Index 0x08)                                                                                                                                                                                                                  |
|                          | (Continued)                                                                                                                                                                                                                                                   |
| [4]                      | Playback Stereo/Mono Select                                                                                                                                                                                                                                   |
| PS/M                     | 0 Mono output audio data stream format is mono.                                                                                                                                                                                                               |
| (RW)                     | 1 Stereo output audio data stream format is stereo.                                                                                                                                                                                                           |
|                          | This bit selects stereo (1) or mono (0) formatting for the output<br>audio data streams. In stereo, the codec alternates samples<br>between channels to provide left and right channel output. For<br>mono, the codec plays the same sample on both channels. |
| [5]                      | PlaybackCompanded Select /Linear                                                                                                                                                                                                                              |
| PC/L                     | 0 Linear-digital Representation format for output data.                                                                                                                                                                                                       |
| (RW)                     | 1 Non-linear, companded format for output data.                                                                                                                                                                                                               |
|                          | Use this bit to select a linear-digital, representation format (0) or<br>a non-linear, companded format (1) for output data. The PC/L bit<br>works in concert with the PFMT bits for output format selection.                                                 |
| [7:6]                    | PlaybackFormat Select Use these bits and the PC/L bit to select                                                                                                                                                                                               |
| PFMT [1:0]               | the format for output data according to the following table.                                                                                                                                                                                                  |
| (RW)                     | PFMT1 PFMT0 PC/L Playback Audio Data Type                                                                                                                                                                                                                     |
| $(\mathbf{K}\mathbf{W})$ | 0 0 0 8-bit, unsigned PCM (Linear)                                                                                                                                                                                                                            |
|                          | 0 0 1 8-bit, $\mu$ -Law companded PCM                                                                                                                                                                                                                         |
|                          | 0 1 0 16-bit, signed Little Endian (Linear)                                                                                                                                                                                                                   |
|                          | 0 1 1 8-bit, A-Law companded PCM                                                                                                                                                                                                                              |
|                          | 1 0 0 reserved                                                                                                                                                                                                                                                |
|                          | 1 0 1 4-bit, IMA-ADPCM Companded                                                                                                                                                                                                                              |
|                          | 1 1 0 16-bit, signed Big Endian (Linear)                                                                                                                                                                                                                      |
|                          | 1 1 1 reserved                                                                                                                                                                                                                                                |



NOTE: Placing the Codec in the Mode Change Enable (MQEstate is not required when changing the CEN and PEN bits in this register.

| Bits | Description<br>(Interface Configuration—WSS Codec Index 0x09)                                                                                                                          |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0]  | Playback Enable                                                                                                                                                                        |
| PEN  | 0 Disables data playback.                                                                                                                                                              |
| (RW) | 1 Enables data playback.                                                                                                                                                               |
|      | This bit enables (1) or disables (0) data playback. If the PPIO t is set (1), PEN enables programmed I/O playback mode. If the PPIO bit is cleared (0), PEN enables DMA playback mode. |
| [1]  | Capture Enable                                                                                                                                                                         |
| CEN  | 0 Disables data capture.                                                                                                                                                               |
| (RW) | 1 Enables data capture.                                                                                                                                                                |
|      | This bit enables (1) or disables (0) data capture. If the CPIO it is set (1), CEN enables programmed I/O capture mode.flthe CPIO bit is cleared (0), CEN enables DMA capture mode.     |

| Bits         | Description<br>(Interface Configuration—WSS Codec Index 0x09)<br>(Continued)                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2]          | Single DMA Channel                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| SDC          | 0 Dual channel DMA mode selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| (RW)         | 1 Single channel DMA mode selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|              | This bit selects single channel (1) or dual channel (0) DMA mode.<br>Playback and capture DMA occur on the playback channel in<br>single channel mode. If playback and capture DMA are enabled at<br>the same time (PEN=CEN=1), the codec only performs playback<br>DMA operations. Note that in single channel mode the codec<br>cannot perform simultaneous playback and capture DMA<br>operations. When the SDC is set (1), the single DMA and/or PIO<br>channels are selected for playback and/or capture as follows: |
|              | Capture Playback SDC CPIO PPIO CEN PEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|              | off DMA 1 0 0 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              | DMA PIO 1 0 1 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              | PIO DMA 1 1 0 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              | PIO PIO 1 1 1 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              | DMA off 1 0 0 1 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              | off DMA 1 0 0 0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [3]          | Autocalibrate Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ACAL<br>(RW) | 0 Disables codec autocalibration on exiting from a mode change operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|              | 1 Enables codec autocalibration on exiting from a mode change operation.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|              | This bit enables (1) or disables (0) codec autocalibration on<br>exiting from a mode change operation (occurs whenever MCE<br>toggles from 1 to 0). Note that the codec performs an<br>autocalibration on the first exit from MCE after the RESET pin is<br>pulsed low regardless of the state of ACAL.                                                                                                                                                                                                                   |
| [5:4]        | Reserved for future expansion. Always write zeros to these bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| res          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Bits | Description<br>(Interface Configuration—WSS Codec Index 0x09)<br>(Continued)     |
|------|----------------------------------------------------------------------------------|
| [6]  | Playback PIO Enable                                                              |
| PPIO | 0 DMA mode for playback data transfer selected.                                  |
| (RW) | 1 Programmed I/O mode for playback data transfer selected                        |
|      | This bit selects Programmed I/O (1) or DMA (0) mode for playback data transfers. |
| [7]  | Capture PIO Enable                                                               |
| CPIO | 0 DMA mode for capture data transfer selected.                                   |
| (RW) | 1 Programmed I/O mode for capture data transfer selected.                        |
|      | This bit selects Programmed I/O (1) or DMA (0) mode for capture data transfers.  |



| Bits      | Description                                                                                                                                                                                                                                                                    |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | (Pin Control—WSS Codec Index 0x0A)                                                                                                                                                                                                                                             |
| [0]       | Reserved for future expansion. Always write zeros to these bits.                                                                                                                                                                                                               |
| res       |                                                                                                                                                                                                                                                                                |
| [1]       | Interrupt Enable                                                                                                                                                                                                                                                               |
| IEN       | 0 Disables codec interrupts.                                                                                                                                                                                                                                                   |
| (RW)      | 1 Enables codec interrupts.                                                                                                                                                                                                                                                    |
|           | This bit enables (1) or disables (0) codec interrupts. These<br>interrupts occur when the transfer count in the Base Count<br>register matches the number of samples to transfer. A (1) in the<br>INT bit in WSS Codec Status register indicates an active codec<br>interrupt. |
| [4:2]     | Reserved for future expansion. Always write zeros to these bits.                                                                                                                                                                                                               |
| res       |                                                                                                                                                                                                                                                                                |
| [6:5]     | External Control                                                                                                                                                                                                                                                               |
| XCTL[1:0] | 0 The XCTL[1:0] pin is at TTL logic low.                                                                                                                                                                                                                                       |
| (RW)      | 1 The XCTL[1:0] pin is at TTL logic high.                                                                                                                                                                                                                                      |
|           | This bit indicates that a TTL logic high (1) or logic low (0) in on the SoundPort Controller's XCTL[1:0] pin.                                                                                                                                                                  |



## Figure 3.19 Codec Reg.—Test and Initialization (Index: 0x0B)

| Bits               | Description<br>(Test and Initialization—WSS Codec Index 0x0B)                                                                                                                                                             |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1:0]<br>ORL [1:0] | Overrange Left Detect These bits indicate over/under range<br>detection on the current left capture channel sample according to<br>the following table:                                                                   |
| (RO)               | <ul> <li>ORL Over/Under Range Detection</li> <li>0 Less than -1 dB underrange</li> <li>1 Between -1 dB and 0 dB underrange</li> <li>2 Between 0 dB and +1 dB overrange</li> <li>3 Greater than +1 dB overrange</li> </ul> |
| [3:2]<br>ORR [1:0] | Overrange Right Detect These bits indicate over/under range<br>detection on the current right capture channel sample according to<br>the following table:                                                                 |
|                    | <ul> <li>ORR Over/Under Range Detection</li> <li>0 Less than -1 dB underrange</li> <li>1 Between -1 dB and 0 dB underrange</li> <li>2 Between 0 dB and +1 dB overrange</li> <li>3 Greater than +1 dB overrange</li> </ul> |
| [4]                | Data Request Status                                                                                                                                                                                                       |
| DRS                | 0 A DMA capture/playback request is <i>not</i> being serviced.                                                                                                                                                            |
| (RO)               | 1 A DMA capture/playback request is being serviced<br>This bit that the codec is currently servicing a DMA capture /<br>playback request (1) or that no request is being serviced (0).                                    |

| Bits | Description<br>(Test and Initialization—WSS Codec Index 0x0B)<br>(Continued)                                                                                                                                                                                                                                                                                                   |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5]  | Autocalibrate-In-Progress                                                                                                                                                                                                                                                                                                                                                      |
| ACI  | 0 Autocalibration is not in progress.                                                                                                                                                                                                                                                                                                                                          |
| (RO) | 1 Autocalibration is in progress.                                                                                                                                                                                                                                                                                                                                              |
|      | This bit indicates an autocalibration is in progress (1) or is not in progress (0). This bit is high (1) for 128 sample periods after exiting MCEmode if an autocalibration is not in progress and 384 sample periods if an autocalibration is in progress.                                                                                                                    |
| [6]  | Playback Underrun                                                                                                                                                                                                                                                                                                                                                              |
| PUR  | 0 No underrun.                                                                                                                                                                                                                                                                                                                                                                 |
| (RO) | 1 Underrun.                                                                                                                                                                                                                                                                                                                                                                    |
|      | The codec sets (1) this bit when playback data is not written<br>within 1 sample period after the playback FIFO empties. The<br>codec clears (0) this bit immediately after a four byte playback<br>sample is written. When PUR is set, the playback channel has<br>"run out" of data and either plays back a mid-scale value<br>(DACZ=1) or repeats the last sample (DACZ=0). |
| [7]  | Capture Overrun                                                                                                                                                                                                                                                                                                                                                                |
| COR  | 0 No overrun.                                                                                                                                                                                                                                                                                                                                                                  |
| (RO) | 1 Overrun.                                                                                                                                                                                                                                                                                                                                                                     |
|      | The codec sets (1) this bit when capture data is not read within 1 sample period after the capture FIFO fills. When COR is set, the FIFO is full and the codec discards any new data generate. The codec clears (0) this bit immediately after a four byte capture sample is read.                                                                                             |
|      | Note: The WSS CodecSOUR bit contains the logical OR of the COR and PUR bits                                                                                                                                                                                                                                                                                                    |

| Figure 5.20 | Coue                         | U KEZ | <b>g.</b> —.w.   | iiscei | laneu            | us m  | 101 111     | ation | (Index: 0x0C) |  |
|-------------|------------------------------|-------|------------------|--------|------------------|-------|-------------|-------|---------------|--|
|             | Miscellaneous<br>Information |       |                  |        | Codec Index 0x0C |       |             |       |               |  |
|             | 7                            | 6     | 5                | 4      | 3                | 2     | 1           | 0     |               |  |
|             | 1                            | 1     | 0                | 0      | 1                | 0     | 1           | 0     |               |  |
|             | MID                          | 1     | Rese             | erved  | 4                |       | 3:0] ·      |       |               |  |
|             | Manu                         | -     | ya = 1<br>rer ID |        | Co               | dec R | <br>levisio | on ID |               |  |

Figure 3.20 Codec Reg.—Miscellaneous Information (Index: 0x0C)

| Bits     | Description<br>(Miscellaneous Information—WSS Codec Index 0x0C) |
|----------|-----------------------------------------------------------------|
| [3:0]    | Codec Revision ID These bits indicate the revision level of the |
| ID [3:0] | codec. The initialrevision level of theodec is 0xA.             |
| (RO)     |                                                                 |
| [5:4]    | Reserved for future expansion. Always write 0's to these bits.  |
| res      |                                                                 |
| [6]      | This bit is always 1.                                           |
| 1        |                                                                 |
| [7]      | Manufacturer ID Bit This bit is set to 1.                       |
| MID      |                                                                 |



| Bits               | Description<br>(Digital Mix/Attenuation—WSS Codec Index 0x0D)                                                                                                                                                                                   |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0]                | Digital Mix Enable                                                                                                                                                                                                                              |
| DME                | 0 Mutes digital mixing.                                                                                                                                                                                                                         |
| (RW)               | 1 Un-mutes digital mixing.                                                                                                                                                                                                                      |
|                    | This bit enables (1) or mutes (0) digital mixing of the ADCs'<br>output with the DACs' input. When mixing is enabled, the codec<br>digitally mixes the data from the ADCs with the other data<br>delivered to the DACs.                         |
|                    | If a capture overrun (COR=1)occurs during capture (CEN=1) the codec uses the last sample captured before overrun for the digital mix.                                                                                                           |
|                    | If a playback underrun (PUR1) occurs during playback (PEN=1) with DACZ set (1), the codec adds a mid-scale zero to the digital mix data. If the underrun occurs with DACZ set (1), the codec repeats the last valid sample for the digital mix. |
| [1]<br>res         | Reserved for future expansion. Always write a zero to this bit.                                                                                                                                                                                 |
|                    | Disited Min Attenuation These hits held the attenuate colort for                                                                                                                                                                                |
| [7:2]<br>DMA [5:0] | Digital Mix Attenuation These bits hold the attenuate select for<br>the ADC data mixed with the DAC input. Using these bits, you                                                                                                                |
| (RW)               | can select attenuation from 0 dB (DMA=0x00) to -94.5 dB (DMA=0x3F) in-1.5 dB increments.                                                                                                                                                        |
|                    | The following equation lets you determine the value to load into DMA [5:0]: (Attenuation dB) / $(-1.5 \text{ dB}) = \text{DMA}$                                                                                                                 |
|                    | For -12 dB att., example: -12 dB / -1.5 dB = $8 = 0b01000 = DMA$                                                                                                                                                                                |



Figure 3.22 Codec Reg.—Upper Base Count (Index: 0x0E)

| Bits                       | Description<br>(Playback Upper Base Count—WSS Codec Index 0x0E)                                                                                                                                                                                                                                                                                                                   |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0]<br>PUB [7:0]<br>(RW) | Playback Upper Base Count These bits hold the upper byte of<br>the 16-bit base count (eight most significant bits Note that reads<br>from this register return the same valuewritten, <i>not</i> the current<br>count. Also note that the current count is not loaded into the<br>counter until you write the upper base count register (write<br>register 0x0F first, then 0x0E) |

# Figure 3.23 Codec Reg.—Lower Base Count (Index: 0x0F)



| Bits                       | Description<br>(Playback Lower Base Count—WSS Codec Index 0x0F)                                                                                                                                                 |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0]<br>PLB [7:0]<br>(RW) | Playback Lower Base Count These bits hold thelower byte of the 16-bit base count (eight least significant bit). Note that reads from this register return the same value written, <i>not</i> the current count. |



| E!            | Color Dec. Al  | 4 Eastern East       | L. /T 64 N/T/C T  |                 | (-10)     |
|---------------|----------------|----------------------|-------------------|-----------------|-----------|
| Fighre 5.24   | Codec Reg.—Al  | t. Feature Enab      | ie/i.eff witt.inf | MECTELLINGEX: ( | IX I () ) |
| I Igal Coll I | Couce Hege III | of i cucui e initasi |                   |                 | , <b></b> |

| Bits                       | Description<br>(Alt. Fea. Enable/Left Mic Input Ctrl—WSS Codec Index 0x10)                                                                                                                            |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0]                        | DAC Zero.                                                                                                                                                                                             |
| DACZ                       | 0 Output the previous valid sample.                                                                                                                                                                   |
| (RW)                       | 1 Output a mid-scale value.                                                                                                                                                                           |
|                            | During an underrun condition, this bit directs the DAC to output<br>a mid-scale value (1) or output the previous valid sample (0).                                                                    |
| [5:1]<br>LMG [4:0]<br>(RW) | Left Mic Gain These bits hold thegain/attenuateselect for the left microphoneinput. Using these bits, you can select gain/attenuates from 12 dB (LMG=0x00) to34.5 dB (LMG=0x1F) in-1.5 dB increments. |
|                            | The following equation lets you determine the value to load into LMG [4:0]: $((Gain or - Atten. dB) - 12 dB) / (-1.5 dB) = LMG$                                                                       |
|                            | For +3 dB gain, example:                                                                                                                                                                              |
|                            | (3dB - 12 dB) / (-1.5 dB) = 6 = 0b00110 = LMG                                                                                                                                                         |
|                            | Note: For 0 dB gain, set LMG [4:0] = 0b01000                                                                                                                                                          |

| Bits | Description<br>(Alt. Fea. Enable/Left Mic Input Ctrl—WSS Codec Index 0x10)<br>(Continued)                                                                                                                                                                           |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6]  | Timer Enable                                                                                                                                                                                                                                                        |
| ТЕ   | 0 Disables the timer.                                                                                                                                                                                                                                               |
| (RW) | 1 Enables the timer.                                                                                                                                                                                                                                                |
|      | This bit enables (1) or disables (0) the 16-bit programmable timer<br>loaded by the Upper and Lower Timer Count registers (Indices<br>0x14 & 0x15). When you enable the timer, the codec loads the<br>timer count and generates interrupts at the specified period. |
| [7]  | Output Level                                                                                                                                                                                                                                                        |
| OL   | 0 2 Vpp full scale analog output.                                                                                                                                                                                                                                   |
| (RW) | 1 2.8 Vpp full scale analog output.                                                                                                                                                                                                                                 |
|      | This bit selects the analog output level attenuation as either full scale 2.8 Vpp signal applying no attenuation (1) or full scale 2 Vpp signal applying -3 dB attenuation (0).                                                                                     |

### Figure 3.25 Codec Reg.—MIC Mix Enable/Right MIC Input Ctrl (Index: 0x11)



| Bits      | Description                                                                                                                                              |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | (Mic Mix Enable/Right Mic Input Ctrl—WSS Codec Index 0x11)                                                                                               |
| [0]       | Reserved for future expansion. Always write 0's to these bits.                                                                                           |
| res       |                                                                                                                                                          |
| [5:1]     | Right Mic Gain These bits hold thegain/attenuate select for the                                                                                          |
| RMG [4:0] | right microphoneinput. Using these bits, you can select                                                                                                  |
|           | gain/attenuates from 12 dB (RMG=0x00) to34.5 dB                                                                                                          |
| (RW)      | (RMG=0x1F) in-1.5 dB increments.                                                                                                                         |
|           | The following equation lets you determine the value to load into RMG [4:0]: $((Gain or - Atten. dB) - 12 dB) / (-1.5 dB) = RMG$                          |
|           | For +3 dB gain, example:                                                                                                                                 |
|           | (3dB - 12 dB) / (-1.5 dB) = 6 = 0b00110 = RMG                                                                                                            |
|           | Note: For 0 dB gain, set RMG [4:0] = 0b01000                                                                                                             |
| [6]       | Right Mic Mix Enable                                                                                                                                     |
| RMME      | 0 Mutes mixing of right microphone input with DAC output                                                                                                 |
| (RW)      | on the R_OUT line.                                                                                                                                       |
|           | 1 Enables mixing of right microphone input with DAC output on the R_OUT line.                                                                            |
|           | This bit enables (1) or mutes (0) mixing of right microphone input with DAC output on the R_OUT line.                                                    |
|           | Note the RMME and LMME bits mute when cleared (0) and<br>enable when set (1); these bits operate opposite of all other<br>mute/enable bits in the codec. |

| Bits         | Description<br>(Mic Mix Enable/Right Mic Input Ctrl—WSS Codec Index 0x11)<br>(Continued)                                                                 |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7]          | Left Mic Mix Enable                                                                                                                                      |
| LMME<br>(RW) | 0 Mutes mixing of left microphone input with DAC output<br>on the L_OUT line.                                                                            |
|              | 1 Enables mixing of left microphone input with DAC output<br>on the L_OUT line.                                                                          |
|              | This bit enables (1) or mutes (0) mixing of left microphone input with DAC output on the L_OUT line.                                                     |
|              | Note the RMME and LMME bits mute when cleared (0) and<br>enable when set (1); these bits operate opposite of all other<br>mute/enable bits in the codec. |

| Figure 3.26 Cod | lec Ke                                                   | g.—L | ent | ine G | ain, A | Atten  | uate, | Mute | , MIX ( | Index | : UXI | 2) |
|-----------------|----------------------------------------------------------|------|-----|-------|--------|--------|-------|------|---------|-------|-------|----|
|                 | Left Line Gain, Codec Index 0x12<br>Attenuate, Mute, Mix |      |     |       |        |        |       |      |         |       |       |    |
|                 | 7                                                        | 6    | 5   | 4     | 3      | 2      | 1     | 0    |         |       |       |    |
|                 | 1                                                        | 0    | 0   | 1     | 1      | 1      | 1     | 1    |         |       |       |    |
|                 |                                                          | Rese |     | -     |        | .G [4: |       |      |         |       |       |    |

| Bits      | Description                                                                                                                     |
|-----------|---------------------------------------------------------------------------------------------------------------------------------|
|           | (Left Line Gain, Atten., Mute, Mix—WSS Codec Index 0x12)                                                                        |
| [4:0]     | Left Line Mix Gain These bits hold thegain/attenuate select for                                                                 |
| LLG [4:0] | the left line mix gain. Using these bits, you can select gain/attenuates from 12 dB (LLG=0x00) to34.5 dB                        |
| (RW)      | (LLG=0x1F) in-1.5 dB increments.                                                                                                |
|           | The following equation lets you determine the value to load into LLG [4:0]: $((Gain or - Atten. dB) - 12 dB) / (-1.5 dB) = LLG$ |
|           | For +3 dB gain, example:                                                                                                        |
|           | (3dB - 12 dB) / (-1.5 dB) = 6 = 0b00110 = LLG                                                                                   |
|           | Note: For 0 dB gain, set LLG [4:0] = 0b01000                                                                                    |
| [6:5]     | Reserved for future expansion. Always write zeros to these bits.                                                                |
| res       |                                                                                                                                 |
| [7]       | Left Line Mute                                                                                                                  |
| LLM       | 0 Un-mutes left line input into the output mixer.                                                                               |
| (RW)      |                                                                                                                                 |
|           | 1 Mutes left line input into the output mixer.                                                                                  |
|           | This bit mutes (1) or un-mutes (0) the left line input into the                                                                 |
|           | output mixer.                                                                                                                   |

| Figure 3.27 Coc | iec Reg.                                                  | —Кі  | ght L | ine ( | fain, | Atten        | nuate, | , Mut | e, Mix | Index | : 0x13 | <b>'</b> ) |
|-----------------|-----------------------------------------------------------|------|-------|-------|-------|--------------|--------|-------|--------|-------|--------|------------|
|                 | Right Line Gain, Codec Index 0x13<br>Attenuate, Mute, Mix |      |       |       |       |              |        |       |        |       |        |            |
|                 | 7                                                         | 6    | 5     | 4     | 3     | 2            | 1      | 0     |        |       |        |            |
|                 | 1                                                         | 0    | 0     | 1     | 1     | 1            | 1      | 1     |        |       |        |            |
|                 | RLM                                                       | Rese | rved  | -     | — RI  | _G [4:       | 0] —   |       |        |       |        |            |
|                 | <br>Right                                                 | Line | Mute  | I     | Rigt  | l<br>1t Line | ə Gair | 1     |        |       |        |            |

| Figure 3.27 Codec Reg | -Right Line Gain, A | Attenuate, Mute, M | fix (Index: 0x13) |
|-----------------------|---------------------|--------------------|-------------------|
|                       |                     |                    | (,                |

| Bits      | Description                                                                                                                     |
|-----------|---------------------------------------------------------------------------------------------------------------------------------|
|           | (Right Line Gain, Atten., Mute, Mix—WSS Codec Index 0x13)                                                                       |
| [4:0]     | Right Line Mix Gain These bits hold thegain/attenuate select for                                                                |
| RLG [4:0] | the right line mix gain. Using these bits, you can select gain/attenuates from 12 dB (RLG=0x00) to34.5 dB                       |
| (RW)      | (RLG=0x1F) in-1.5 dB increments.                                                                                                |
|           | The following equation lets you determine the value to load into RLG [4:0]: $((Gain or - Atten. dB) - 12 dB) / (-1.5 dB) = RLG$ |
|           | For +3 dB gain, example:                                                                                                        |
|           | (3dB - 12 dB) / (-1.5 dB) = 6 = 0b00110 = RLG                                                                                   |
|           | Note: For 0 dB gain, set RLG [4:0] = 0b01000                                                                                    |
| [6:5]     | Reserved for future expansion. Always write zeros to these bits.                                                                |
| res       |                                                                                                                                 |
| [7]       | Right Line Mute                                                                                                                 |
| RLM       | 0 Un-mutes right line input into the output mixer.                                                                              |
| (RW)      | 1 Mutes right line input into the output mixer.                                                                                 |
|           | This bit mutes (1) or un-mutes (0) the ight line input into the output mixer.                                                   |



### Figure 3.28 Codec Reg.—Lower Timer (Index: 0x14)

| Bits                      | Description<br>(Lower Timer—WSS Codec Index 0x14)                                                                                                                                                                                                                                                                                              |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0]<br>TL [7:0]<br>(RW) | Lower Timer. These bits hold thelower byte of the 16-bit timer<br>(eight least significant bit). Note that reads from this register<br>return the same valuewritten, <i>not</i> the current count. The time<br>base is calculated from the following formula:<br>(PC system clock) / 144 = Time Base.<br>Example: 14.3818 MHz / 144 = 10.057ns |



| Bits                      | Description<br>(Upper Timer—WSS Codec Index 0x15)                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0]<br>TU [7:0]<br>(RW) | <ul> <li>Upper Timer These bits hold theupper byte of the 16-bit timer (eight most significant bit). Note that reads from this register return the same valuewritten, <i>not</i> the current count. The time base is calculated from the following formula:</li> <li>(PC system clock) / 144 = Time Base.</li> <li>Example: 14.3818 MHz / 144 = 10.057ns.</li> <li>Also note that the timer is not loaded until you write the upper timer register (write register 0x14 first, then 0x15)</li> </ul> |



| Figure 3.30 | Codec Reg | –Unner Frequei | ncy Select (Index: 0x16) |   |
|-------------|-----------|----------------|--------------------------|---|
| Figure 5.50 | Could Reg | -Opper Freques | icy Sciect (much. 0x10)  | / |

| Bits                      | Description<br>(Upper Frequency Select—WSS Codec Index 0x16)                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0]<br>FU [7:0]<br>(RW) | Upper Frequency Select These bits hold the upper byte of the 16-bit sampling frequency selection (reight most significant bit). Using these bits and the bits in the Lower Frequency Select register, you can select sampling frequencies from 5 kHz (FU [7:0] & FL [7:0] = 0x0FA0) to 50 kHz (FU[7:0] & FL [7:0] = 0xC350) in 1 kHz increments.                                                                           |
|                           | To find the value to load into FU[7:0] & FL [7:0], convert the decimal sampling frequency (between 5 to 50 kHz) to a two byte binary number. To sample a8.0 kHz for example:                                                                                                                                                                                                                                               |
|                           | 8000 = 0b0001,1111,0100,0000 = FU [7:0] & FL [7:0]<br>Some commonly used sample rates are listed below:<br>Sampling                                                                                                                                                                                                                                                                                                        |
|                           | Quality         Frequency         FU [7:0]         FL [7:0]           Voice         8.0 kHz         0001 1111         0100 0000 (default)           Radio         11.025 kHz         0010 1011         0001 0001           Tape         22.05 kHz         0101 0110         0010 0010           CD         44.1 kHz         1010 1100         0100 0100           DAT         48.0 kHz         1011 1011         1000 0000 |
|                           | Also note that the timer is not loaded until you write the upper<br>timer register (write register 0x14 first, then 0x15)<br>[Load FU <u>before</u> FL]                                                                                                                                                                                                                                                                    |



Figure 3.31 Codec Reg.—Lower Frequency Select (Index: 0x17)

| Bits     | Descript                                                                                                                                                                    | Description                                                                                                                                                                                                                                                                                    |             |                        |           |  |  |  |  |  |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------|-----------|--|--|--|--|--|
|          | (Lower H                                                                                                                                                                    | Frequency Selec                                                                                                                                                                                                                                                                                | t-WSS Codec | Index 0x17)            |           |  |  |  |  |  |
| [7:0]    | Lower Fr                                                                                                                                                                    | Lower Frequency Select These bits hold thelower byte of the                                                                                                                                                                                                                                    |             |                        |           |  |  |  |  |  |
| FL [7:0] | Using the<br>register,<br>(FU [7:0]                                                                                                                                         | 16-bit sampling frequency selectio(reight least significant bit).<br>Using these bits and the bits in the Upper Frequency Select<br>register, you can select sampling frequencies from 4 kHz<br>(FU [7:0] & FL [7:0] = 0x0FA0) to 50 kHz (FU[7:0] & FL [7:0]<br>= 0xC350) in 1 kHz increments. |             |                        |           |  |  |  |  |  |
|          |                                                                                                                                                                             | t the sample rat<br>r frequency regi                                                                                                                                                                                                                                                           |             |                        |           |  |  |  |  |  |
|          | To find the value to load into FU7:0] & FL [7:0], convert the decimal sampling frequency (between 5 to 50 kHz) to a two byte binary number. To sample a8.0 kHz for example: |                                                                                                                                                                                                                                                                                                |             |                        |           |  |  |  |  |  |
|          | 8000 = 0b0001,1111,0100,0000 = FU [7:0] & FL [7:0]                                                                                                                          |                                                                                                                                                                                                                                                                                                |             |                        |           |  |  |  |  |  |
|          | Some commonly used sample rates are listed below:                                                                                                                           |                                                                                                                                                                                                                                                                                                |             |                        |           |  |  |  |  |  |
|          |                                                                                                                                                                             | Sampling                                                                                                                                                                                                                                                                                       |             |                        |           |  |  |  |  |  |
|          | Quality                                                                                                                                                                     | Frequency                                                                                                                                                                                                                                                                                      | FU [7:0]    | FL [7:0]               |           |  |  |  |  |  |
|          | Voice                                                                                                                                                                       | 8.0 kHz                                                                                                                                                                                                                                                                                        |             | 0100 0000              | (default) |  |  |  |  |  |
|          | Radio                                                                                                                                                                       | 11.025 kHz                                                                                                                                                                                                                                                                                     |             | 0001 0001              |           |  |  |  |  |  |
|          | Tape                                                                                                                                                                        | 22.05 kHz                                                                                                                                                                                                                                                                                      |             | 0010 0010              |           |  |  |  |  |  |
|          | CD<br>DAT                                                                                                                                                                   | 44.1 kHz<br>48.0 kHz                                                                                                                                                                                                                                                                           |             | 0100 0100<br>1000 0000 |           |  |  |  |  |  |
|          |                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                |             |                        |           |  |  |  |  |  |



| Bits | Description                                                                                                                                                                                 |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | (Capture Playback Timer—WSS Codec Index 0x18)                                                                                                                                               |
| [0]  | Playback Underrun                                                                                                                                                                           |
| PU   | 0 No underrun.                                                                                                                                                                              |
| (RO) | 1 Underrun.                                                                                                                                                                                 |
|      | The codec sets (1) this bitwhen the DAC runs out of data and a sample has been missedThe codec clears (0) this bit when the DAC receives a fresh sample.                                    |
| [1]  | Playback Overrun                                                                                                                                                                            |
| РО   | 0 No overrun.                                                                                                                                                                               |
| (RO) | 1 Overrun.                                                                                                                                                                                  |
|      | The codec sets (1) this bit when a buswrite is ignored because<br>the FIFO is full. The codec clears (0) this bit when there is space<br>in the FIFO for the next write.                    |
| [2]  | Capture Overrun                                                                                                                                                                             |
| СО   | 0 No overrun.                                                                                                                                                                               |
| (RO) | 1 Overrun.                                                                                                                                                                                  |
|      | The codec sets (1) this bit when a sample from the ADC is<br>ignored because the ADC FIFO is full. The codec clears (0) this<br>bit when there is space in the ADC FIFO for the next write. |

| Bits             | Description<br>(Capture Playback Timer—WSS Codec Index 0x18)<br>(Continued)                                                                                                                  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3]              | Capture Underrun                                                                                                                                                                             |
| CU               | 0 No underrun.                                                                                                                                                                               |
| (RO)             | 1 Underrun.                                                                                                                                                                                  |
|                  | The codec sets (1) this bit when it has to repeat the last valid byte sent for a bus read from an emptyADC FIFO. The codec clears (0) this bit when the ADC FIFO has data for the next read. |
| [4]              | Playback Interrupt                                                                                                                                                                           |
| PI               | 0 No interrupt.                                                                                                                                                                              |
| (R)<br>(Write 0) | 1 Interrupt is pending from the playback DMA count registers.                                                                                                                                |
|                  | The codec sets (1) this bit to indicate that an interruptis pending from the playback DMA count registers.                                                                                   |
|                  | Clear (write 0 to) the PI bit toclear the playback DMAinterrupt.                                                                                                                             |
| [5]              | Capture Interrupt.                                                                                                                                                                           |
| CI               | 0 No interrupt.                                                                                                                                                                              |
| (R)<br>(Write 0) | 1 Interrupt is pending from the capture DMA count registers.                                                                                                                                 |
| ((()))           | The codec sets (1) this bit to indicate that an interrupt is pending from the capture DMA count registers.                                                                                   |
|                  | Clear (write 0 to) the CI bit to clear the capture DMA interrupt.                                                                                                                            |
| [6]              | Timer Interrupt                                                                                                                                                                              |
| TI               | 0 No interrupt.                                                                                                                                                                              |
| (R)              | 1 Interrupt is pending from the timer count registers.                                                                                                                                       |
| (Write 0)        | The codec sets (1) this bit to indicate that an interrupt is pending from the timer count registers.                                                                                         |
|                  | Clear (write 0 to) the TI bit to clear the timer interrupt.                                                                                                                                  |
| [7]              | Reserved for future expansion. Always write zeros to these bits.                                                                                                                             |
| res              |                                                                                                                                                                                              |

Note: You can clear all three interrupts (PI, CI & TI) by writing to the Codec Status register. The INT bit in the Codec Status register is a logical OR of these three interrupts. While you can clear (0) the PI, CI & TI bits, setting (1) these bits manually has no effect.

| Figu | ire 3.3     | 3 Co        | dec l | Reg.– | -Rev             | ision | ID (I  | ndex:        | 0x19) |  |
|------|-------------|-------------|-------|-------|------------------|-------|--------|--------------|-------|--|
|      | Revision ID |             |       |       | Codec Index 0x19 |       |        |              |       |  |
|      | 7           | 6           | 5     | 4     | з                | 2     | 1      | 0            |       |  |
|      | 1           | 0           | 0     | 0     | 0                | 0     | 0      | 0            |       |  |
|      | <b>-</b> v  | / [2:0]<br> | ] 🗕   | Rese  | rved             | C     | D [2:0 | 01           |       |  |
|      |             | ersio       | '     |       | '                |       |        | i<br>aion IC | 1     |  |

| Bits      | Description<br>(Revision ID—WSS Codec Index 0x19)                |
|-----------|------------------------------------------------------------------|
| [2:0]     | Revision ID Number                                               |
| CID [2:0] |                                                                  |
| [4:3]     | Reserved for future expansion. Always write zeros to these bits. |
| res       |                                                                  |
| [7:5]     | Version Number Indicates the version of the Codec.               |
| V [2:0]   |                                                                  |

| Tigu | 103.3 |              | ICC K | ug.— | mon  |                  |       | Inuca  |  |
|------|-------|--------------|-------|------|------|------------------|-------|--------|--|
|      | Мопо  | Mono Control |       |      | C    | Codec Index 0x1A |       |        |  |
|      | 7     | 6            | 5     | 4    | з    | 2                | 1     | 0      |  |
|      | 1     | 1            | 0     | 0    | 0    | 0                | 0     | 0      |  |
|      |       |              | Rese  |      |      | MIA              | [3:0] |        |  |
|      | Моло  | Input        | Mute  |      | Мопо | Input            | Atter | uation |  |

| Figure 3 34    | Codec Reg  | _Mono Cor | ntrol (Index   | $\cdot 0 \mathbf{v} 1 \mathbf{\Delta}$  |
|----------------|------------|-----------|----------------|-----------------------------------------|
| I Igui C J.J.F | Couce Reg. |           | III OI (IIIUCA | • • • • • • • • • • • • • • • • • • • • |

| Bits      | Description                                                                                                                        |
|-----------|------------------------------------------------------------------------------------------------------------------------------------|
|           | (Mono Control—WSS Codec Index 0x1A)                                                                                                |
| [3:0]     | Mono Input Attenuation select. These bits hold the attenuate                                                                       |
| MIA [3:0] | select for the mono input. Using these bits, you can select<br>attenuates from $0 dP (MIA - 0x0)$ to $45 dP (MIA - 0xE)$ in $2 dP$ |
| (RW)      | attenuates from 0 dB (MIA=0x0) to -45 dB (MIA=0xF) in 3 dB increments.                                                             |
|           | The following equation lets you determine the value to load into MIA [3:0]: (Attenuation dB) / (-3 dB) = MIA                       |
|           | For -9 dB attenuation, example:                                                                                                    |
|           | -9  dB / -3  dB = 3 = 0b0011 = MIA                                                                                                 |
| [5:4]     | Reserved for future expansion. Always write zeros to these bits.                                                                   |
| res       |                                                                                                                                    |
| [6]       | Mono Output Mute                                                                                                                   |
| MOM       | 0 Un-mutes Mono output signal.                                                                                                     |
| (RW)      | 1 Mutes Mono output signal.                                                                                                        |
|           | This bit mutes (1) or un-mutes (0) the mono output (M_OUT) signal.                                                                 |
| [7]       | Mono Input Mute                                                                                                                    |
| MIM       | 0 Un-mutes Mono input signal.                                                                                                      |
| (RW)      | 1 Mutes Mono input signal.                                                                                                         |
|           | This bit mutes (1) or un-mutes (0) the mono input (M_IN) signal                                                                    |



#### Figure 3.35 Codec Reg.—Power-Down Control (Index: 0x1B)

| Bits   | Description<br>(Powerdown Control—WSS Codec Index 0x1B)                          |
|--------|----------------------------------------------------------------------------------|
| [2:0]  | Reserved for future expansion. Always write zeros to these bits.                 |
| res    |                                                                                  |
| [3]    | This bit is always 1.                                                            |
| 1      |                                                                                  |
| [4]    | Reserved                                                                         |
| [5]    | DAC and Mixer Power DownSetting this bit powers the DAC                          |
| MIXPWD | and mixer down. When the DAC is powered down, the AC sample clock is turned off. |
| (RW)   | sample clock is turned on.                                                       |
| [6]    | DAC Power Down Setting this bit powers the DAC down.                             |
| DACPWD | When the DAC is powered down, the DAC sample clock is turned off.                |
| (RW)   |                                                                                  |
| [7]    | ADC Power Down Setting this bit powers the ADC down.                             |
| ADCPWD | When the ADC is powered down, the ADG ample clock is turned off.                 |
| (RW)   |                                                                                  |



NOTE: To change the bits in this register, place the codec in the Mode Change Enable (MCE) state or set CEN=0.

| Bits  | Description<br>(Capture Data Format Control—WSS Codec Index 0x1C)                                                                                                                                                                                                       |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1:0] | Reserved for future expansion. Always write zeros to these bits.                                                                                                                                                                                                        |
| res   |                                                                                                                                                                                                                                                                         |
| [2]   | Capture 8-bit Interface                                                                                                                                                                                                                                                 |
| CINF8 | 0 16-bit capture mode.                                                                                                                                                                                                                                                  |
| (RW)  | 1 8-bit capture mode.                                                                                                                                                                                                                                                   |
|       | This bit indicates that the capture channel is in 8-bit(1) or 16-bit (0) mode.                                                                                                                                                                                          |
|       | Note: The CFMT bits in this register select among 8-bit or 16-bit<br>interface on the codec; programming this bit's contents must be<br>coordinated with programming the Plug & Play configuration<br>registers selection of 8-bit or 16-bit transfers and DMA channels |
| [3]   | Capture Byte Swap.                                                                                                                                                                                                                                                      |
| CBSW  | 0 Default capture word byte order.                                                                                                                                                                                                                                      |
| (RW)  | 1 Swaps capture word byte order.                                                                                                                                                                                                                                        |
|       | For 16-bit data transfers (CINF8=0)this bit swaps (1) or leaves at default (0) the byte order of capture words.                                                                                                                                                         |

| Bits                | Description<br>(Capture Data Format Control—WSS Codec Index 0x1C)<br>(Continued)                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [4]                 | Capture Stereo/Mono Select                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| CS/M                | 0 Mono input format.                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| (RW)                | 1 Stereo input format.                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|                     | This bit selects stereo (1) or mono (0) formatting for the input<br>audio data streams. In stereo, the codec alternates samples<br>between channels to provide left and right channel input. For<br>mono, the codec captures samples on the left channel.                                                                                                                                                             |  |  |  |  |  |  |
| [5]                 | Capture Companded Select /Linear                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| CC/L                | 0 Linear-digital representation format.                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| (RW)                | 1 Non-linear, companded format.                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|                     | Use this bit to select a linear-digital, representation format (0) or<br>a non-linear, companded format (1) for input data. The CC/L bit<br>works in concert with the CFMT bits for input format selection.                                                                                                                                                                                                           |  |  |  |  |  |  |
| [7:6]<br>CFMT [1:0] | Capture Format Select Use these bits and the CC/L bit to select the format for input data according to the following table.                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|                     | CFMT1 CFMT0 CC/L Playback Audio Data Type                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|                     | $\begin{array}{ccccccc} 0 & 0 & 0 & 8\mbox{-bit, unsigned PCM (Linear)} \\ 0 & 0 & 1 & 8\mbox{-bit, }\mu\mbox{-Law companded PCM} \\ 0 & 1 & 0 & 16\mbox{-bit, signed Little Endian (Linear)} \\ 0 & 1 & 1 & 8\mbox{-bit, A-Law companded PCM} \\ 1 & 0 & 0 & reserved \\ 1 & 0 & 1 & 4\mbox{-bit, IMA-ADPCM Companded} \\ 1 & 1 & 0 & 16\mbox{-bit, signed Big Endian (Linear)} \\ 1 & 1 & 1 & reserved \end{array}$ |  |  |  |  |  |  |

#### Figure 3.37 Codec Reg.—Crystal, Clock Select/Total Power-Down (Index: 0x1D)



NOTE: To change the bits in this register, place the codec in the Mode Change Enable (MCE) state.

| Bits                  | Description<br>(Crystal, Clock Sel./Total Powerdown—WSS Codec Index 0x1D                                                                                                                                                                                                                                                 |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0]<br>TOTPWD<br>(RW) | <ul> <li>Total Power Down Setting this bit powers the DAC, ADC, and mixer down. When the DAC and ADC are powered down, the DAC and ADC sample clocks are turned off.</li> <li>Note: When the codec has set (1) this bit, <b>n</b>ly the digital interfaceon-chip remains active awaiting the power up signal.</li> </ul> |
| [7:1]<br>res          | Reserved for future expansion. Always write zeros to these bits.                                                                                                                                                                                                                                                         |



| Bits                       | Description<br>(Capture Upper Base Count—WSS Codec Index 0x1E)                                                                                                                                                                                                                                                                                                    |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0]<br>CUB [7:0]<br>(RW) | Capture Upper Base Count These bits hold the upper byte of the<br>16-bit base count (eight most significant bits Note that reads<br>from this register return the same valuewritten, <i>not</i> the current<br>count. Also note that the current counter is not loaded until you<br>write the upper base count register (write register 0x1F first,<br>then 0x1E) |

Figure 3.39 Codec Reg.—Capture Lower Base Count (Index: 0x1F)



| Bits                       | Description<br>(Capture Lower Base Count—WSS Codec Index 0x1F)                                                                                                                                                 |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0]<br>CLB [7:0]<br>(RW) | Capture Lower Base Count These bits hold thelower byte of the 16-bit base count (eight least significant bit). Note that reads from this register return the same value written, <i>not</i> the current count. |

## 3.4 AD1812 Sound Blaster Pro ISA Bus Registers (Ports)

The AD1812 contains a set of ISA Bus registers (ports) that correspond to those used by the Sound Blaster Pro audio card from Creative labs. Table 3.8 lists the ISA Bus Sound Blaster Pro registers. For complete information on using these registers, see the veloper *Kit for Sound Blaster Series* 2nd ed. ©1993, Creative LabsInc., 1901 McCarthy Blvd., Milpitas, CA 95035.

| Register Name                   | Address                                           |
|---------------------------------|---------------------------------------------------|
| Music0: Address (w), Status (r) | 0x(SB Base) Relocatable in range 0x010 -<br>0x3F0 |
| Music0: Data (w)                | 0x(SB Base+1)                                     |
| Music1: Address (w)             | 0x(SB Base+2)                                     |
| Music1: Data (w)                | 0x(SB Base+3)                                     |
| Mixer Address (w)               | 0x(SB Base+4)                                     |
| Mixer Data (w)                  | 0x(SB Base+5)                                     |
| Reset (w)                       | 0x(SB Base+6)                                     |
| Music0: Address (w)             | 0x(SB Base+8)                                     |
| Music0: Data (w)                | 0x(SB Base+9)                                     |
| Input Data (r)                  | 0x(SB Base+A)                                     |
| Status (r), Output Data (w)     | 0x(SB Base+C)                                     |
| Status (r)                      | 0x(SB Base+E)                                     |

 Table 3.8
 Sound Blaster Pro ISA Bus Registers

## 3.5 AD1812 AdLib ISA Bus Registers (Ports)

The AD1812 contains a set of ISA Bus registers (ports) that correspond to those used by the AdLibaudio card from AdLib Multimedia. Table 3.9 lists the ISA Bus AdLib registers. Because the AdLib registers are a subset of those in the Sound Blaster card, you can find complete information on using these registers in the *eveloper Kit for Sound Blaster Series*, 2nd ed. ©1993, Creative LabsInc., 1901 McCarthy Blvd., Milpitas, CA 95035.

| Register Name                   | Address                                              |  |
|---------------------------------|------------------------------------------------------|--|
| Music0: Address (w), Status (r) | 0x(Adlib Base) Relocatable in range 0x008<br>- 0x3F8 |  |
| Music0: Data (w)                | 0x(Adlib Base+1)                                     |  |
| Music1: Address (w)             | 0x(Adlib Base+2)                                     |  |
| Music1: Data (w)                | 0x(Adlib Base+3)                                     |  |

 Table 3.9 AdLib ISA Bus Registers

## 3.6 AD1812 MIDI MPU-401 ISA Bus Registers (Ports)

The AD1812 contains a set of ISA Bus registers (ports) that correspond to those used by the ISA bus MIDI audio interface cards. Table 3.10 lists the ISA Bus MIDI registers and Figures 3.39 and 3.40 show them. These registers support commands and data transfers described in the*MIDI 1.0 Detailed Specification*& *Standard MIDI Files 1.0* ©1994, MIDI Manufacturers Association, PO Box 3173 La Habra, CA 90632-3173.

|                              | 0                                                   |
|------------------------------|-----------------------------------------------------|
| Register Name                | Address                                             |
| MIDI Data (r/w)              | 0x(MIDI Base) Relocatable in range 0x008<br>- 0x3F8 |
| MIDI Status (r), Command (w) | Ox(MIDI Base+1)                                     |

 Table 3.10 MIDI ISA Bus Registers



| Bits              | Description<br>(MIDI Data—0x(MIDI Base))                                         |
|-------------------|----------------------------------------------------------------------------------|
| [7:0]<br>MD [7:0] | MIDI Data. Use these bits for reading/writing MIDI data to the MIDI MPU-401 UART |
| (RW)              |                                                                                  |



| Bits                   | Description<br>(MIDI Status/Command—0x(MIDI Base+1))                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5:0] (R)<br>res       | On reads from this register, these bits do not indicate anything; ignore them.                                                                                                                                                                                                                                                                                                                                                                                          |
| [6] (R)<br>DSR         | Data Set Ready. When read, this bit indicates that you can (0) or<br>cannot (1) write to the MIDI Data register.<br>(Full=1, Empty=0)                                                                                                                                                                                                                                                                                                                                   |
| [7] (R)<br>DRR         | Data Receive Ready When read, this bit indicates that you can<br>(0) or cannot (1) read from the MIDI Data register.<br>(Un-readable=1, Readable=0)                                                                                                                                                                                                                                                                                                                     |
| [7:0] (W)<br>CMD [7:0] | MIDI Command Write MIDI commands to this register.Note: The AD1812only supports the MIDI 0xFF (reset) and<br>0x3F (pass-through mode) commands. The controller powers up<br>set for intelligent MIDI mode, but must be put in pass-through<br>mode. To start MIDI operations, send a reset command (0xFF)<br>and then send a pass-through mode command (0x3F). The MIDI<br>data register contains an acknowledge byte (0xFE) after each<br>successful command transfer. |

## 3.7 AD1812 Game Port

The AD1812 contains a Game Port ISA Bus register that correspond to the game port described in the Plug & Play specification. Table 3.11 show the address range for the port.

| Register Name | Address                                             |  |
|---------------|-----------------------------------------------------|--|
| Game Port I/O | 0x(Game Base) Relocatable in range<br>0x001 - 0x3FF |  |

Table 3.11 Game Port ISA Bus Register (Port)

### 3.8 AD1812 Register Summary

The AD1812 SoundPort Controller contains registers that correspond to those found in Sound Blaster Pro, AdLib, MIDI, and Game Port Plug & Play devices. Figure 3.41 shows an overview of the direct and indirect registers in the controller.

This chapter provides detailed information on the vendor specific Plug & Play Powerdown register, all registers in the Windows Sound System codec, and MIDI interface registers. For detailed information on Sound Blaster and AdLib registers, see theveloper Kit for Sound Blaster Series 2nd ed. ©1993, Creative LabsInc., 1901 McCarthy Blvd., Milpitas, CA 95035.



Figure 3.42 Register Overview

# Chapter 4 AD1812 Reference Design

## 4.1 Overview

A reference design using the AD1812 provides a starting point for motherboard and PC plug-in card OEM's beginning their designs using the SoundPort Controller. The AD1812 reference design described in this chapter shows how few components are required for building an AD1812 based PC plug-in card.

The AD1812 evaluation kit (available through your Analog Devices representative) comes with the reference design board described here plus software drivers for DOS, Windows 3.1 and Windows 95 applications. To really get an idea of the AD1812's capabilities, you should participate in a demonstration with the evaluation kit.

The AD1812 reference design board's architecture supports all the controller's features. The board is a 16-bit audio plug-in card for ISA bus personal computers. The I/O features of the card include the following:

- Stereo jacks (four) provide connections for MIC IN, CD-ROM IN (external), LINE IN, and LINE OUT signals.
- Headers provide audio connections for an internal CD-ROM.
- A D-type (DB15) connector lets you connect Joystick /Game and MIDI devices
- A single jumper for selection of Plug & Play or Non-Plug & Play configuration mode, all other board configuration is performed by software.

## 4.2 Reference Design Architecture

This section provides some detail on the AD1812 reference design board's architecture. For more detailed information, examine the board's schematics in the next section *Design Information* 

AD1812 SoundPort Controller based designs (plug-in & motherboard) provide software and hardware compatibility with SoundBlaster, AdLib, Windows Sound System, MIDI, and Game Port industry standards. The controller provides these feature through a set of internal integrated device and external I/O ports. Figure 4.1 shows an overview of the reference design board's architecture.



INTERNAL CD AUDIO HEADERS

As shown in Figure 4.1 the reference design board's features include the following:

• MICROPHONE INPUT. This input contains an op-amp buffer with a gain of 4 dB and, for microphones with larger signals, you can apply a software controlled 20 dB gain block as well. You can mix this analog input with a digital signal from the ISA bus.

- CD-ROM INPUT. This input has an input impedance of approximately 1Ωkwith a maximum fullscale input level of 2 Vrms. This input jack (and internal CD audio headers) support Panasonic, Mitsumi, and Sony CD-ROMs. You can mix this analog input with a digital signal from the ISA bus.
- LINE INPUT. This input has an input impedance of approximately 100kwith a maximum fullscale input level of 2 Vrms. You can mix this analog input with a digital signal from the ISA bus.
- LINE OUTPUT. This output has a maximum full-scale output level of Irms. This outputs provide a high-quality line output for use with equipment containing line-level inputs and provides exceptional audio quality when driving speakers designed for the PC (game speakers).
- MIDI/JOYSTICK/GAME PORT. This D-type connector lets you connect a Joystick, other Game Port device, or MIDI devices to your PC.
- Mono Input Header (on-board header JP4). This header connects to the SoundPort Controller's mono input. You can mix this analog input with a digital signal from the ISA bus.
- Plug & Play / Non-Plug & Play Selection Jumper (on-board jumper JP10). This jumper selects Plug & Play mode (jumper not installed) or Non-Plug & Play mode (jumper connects pins 1 & 2). In either mode, the reference design board is completely software configurable with driver software. For more information on the configuration process, see Chapter 2, AD1812 Programming.

Two other SoundPort Controller features that could be useful on your own board are an optional Wave Blaster header and an on-board modem. The reference design would have to be modified if you wanted to include these features.

- Wave Blaster. Adding an external Wave Blaster card lets the SoundPort Controller board use the external wavetable for true instrument quality sounds.
- Modem. The AD1812 can support an external modem chipset. This chipset can provide V.34/DSVD Full Duplex Modem/Speakerphone operation.

## 4.3 Design Information

This section includes a set of schematics for the AD1812 Reference Design Board and component side silk-screen drawing. Complete production files (schematics, pcb layout, & fabrication instructions schematic) are available in Data Exchange Format (DXF) on the Analog Devices, Computer Products Division, Applications Bulletin Board Service (BBS).

To access these files (in the Development Tools section of the BBS), contact the BBS by modem at speeds up to 14,400 baud, no parity, 8 bits data, 1 stop bit by dialing (61461-4258. This BBS supports: V.32bis, error correction (V.42 and MNP classes 2, 3, and 4), and data compression (V.42bis and MNP class5).



Figure 4.2 AD1812 Reference Design Board, Schematic Page 1 of 4



Figure 4.3 AD1812 Reference Design Board, Schematic Page 2 of 4



Figure 4.4 1812 Reference Design Board, Schematic Page 3 of 4



Figure 4.5 AD1812 Reference Design Board, Component Side silk-screen

## Index

#### μ

| μ-Law companding                                            |
|-------------------------------------------------------------|
|                                                             |
| A                                                           |
|                                                             |
| ACAL bit2-36, 3-11, 3-19, 3-31                              |
| Acceptable Plug & Play Configuration,                       |
| definition2-2                                               |
| ACI bit2-35, 2-36, 3-10, 3-19, 3-35                         |
| Activate register                                           |
|                                                             |
| AD1812 Features1-3                                          |
| ADC Power Down See ADCPWD bit                               |
| ADCPWD bit2-37, 2-38, 3-19, 3-53                            |
| Address Range                                               |
| AdLib2-17                                                   |
| Game port2-19                                               |
| MIDI2-18                                                    |
| Modem                                                       |
| SoundBlaster2-15                                            |
| Windows Sound System2-13                                    |
| ADDRESS                                                     |
| register2-4, 2-8, 2-9, 2-10,                                |
|                                                             |
|                                                             |
| AdLib                                                       |
| Address range2-17                                           |
| Driver                                                      |
| Logical Device Number==22-6, 2-11, 2-16                     |
| Registers                                                   |
| Support definition                                          |
| A-Law companding                                            |
| 1-7, 2-23, 2-27, 2-28, 2-29, 3-55                           |
| Alternate Feature Enable/Left MIC Input<br>Control register |
|                                                             |
| Attenuation, overview2-33                                   |
| Autocalibrate Enable                                        |
| Autocalibrate-In-Progress                                   |
| Autocanorate-in-riogress                                    |
| В                                                           |
| Big Endian, 16-Bit Signed                                   |
|                                                             |
| Binary base                                                 |
|                                                             |

Bits

Bit Types, definitions......2-10, 3-1

| ACAL bit2-36, 3-11, 3-19, 3-3                | 31                |
|----------------------------------------------|-------------------|
| ACI bit2-35, 2-36, 3-10, 3-19, 3-3           |                   |
| ADCPWD bit2-37, 2-38, 3-19, 3-5              |                   |
| CBSW bit2-27, 2-28, 3-19, 3-5                |                   |
| CC/L bit                                     |                   |
| CD bits                                      |                   |
| CEN bit2-31, 2-32, 3-9, 3-19, 3-30, 3-37, 3- |                   |
| CFMT bits                                    |                   |
| CI bit                                       |                   |
| CID bits                                     |                   |
| CINF8 bit2-27, 2-28, 2-29, 3-19, 3-5         |                   |
|                                              |                   |
| CL/R bit                                     |                   |
| CLB bits                                     |                   |
| CMD bits                                     |                   |
| CO bit                                       | 19                |
| COR bit3-15, 3-19, 3-35, 3-3                 |                   |
| CPIO bit2-31, 2-32, 3-19, 3-30, 3-3          |                   |
| CRDY bit 2-32, 3-8, 3-13, 3-1                |                   |
| CS/M bit3-19, 3-5                            |                   |
| CU bit3-19, 3-5                              |                   |
| CU/L bit                                     |                   |
| CUB bits                                     |                   |
| DACPWD bit2-37, 2-38, 3-19, 3-5              |                   |
| DACZ bit3-10, 3-19, 3-37, 3-3                | 39                |
| DMA bits2-34, 3-19, 3-3                      | 37                |
| DME bit2-34, 3-19, 3-3                       | 37                |
| DRS bit                                      | 34                |
| DSP_PD_RDY bit                               | -7                |
| DSP_PU_RDY bit                               |                   |
| DSP PWRDWN bit                               | -7                |
| FL bits                                      | 18                |
| FU bits                                      |                   |
| ID bits                                      |                   |
| IEN bit                                      |                   |
| INIT bit                                     |                   |
| INT bit 2-31, 3-8, 3-9, 3-10, 3-13, 3-3      |                   |
| ISA8MA bit                                   |                   |
| IXA bits                                     |                   |
| IXD bits                                     |                   |
| LDA bits                                     | . <u>2</u><br>) 6 |
| LDA bits2-34, 3-10, 3-19, 3-2<br>LDM bit     | 20                |
| LDW 012-54, 5-19, 5-2                        | 20                |
| LIG Bits                                     | 20                |
| LLG bits2-35, 3-19, 3-4                      | F3<br>12          |
| LLM bit                                      |                   |
| LMG bits                                     |                   |
| LMGE bit2-33, 3-19, 3-2                      |                   |
| LMME bit2-35, 3-19, 3-4                      | 12                |

| LMX1 bit<br>LMX2 Bit<br>LSS bits<br>LX1A bits | .2-34, 3-19, 3-24<br>.2-33, 3-19, 3-20 |
|-----------------------------------------------|----------------------------------------|
| LX2A bits<br>MCE bit                          | .2-34, 3-19, 3-24                      |
| 2-36                                          |                                        |
|                                               |                                        |
| MD bits                                       |                                        |
| MIA bits                                      | , ,                                    |
| MID bit                                       |                                        |
| MIM bit                                       |                                        |
| MIXPWD bit2-37                                |                                        |
| MOM bit                                       | 2-35, 3-19, 3-52                       |
| OL bit                                        |                                        |
| ORL bits                                      |                                        |
| ORR bits                                      |                                        |
| PBSW bit2-27                                  |                                        |
| PC/L bit                                      |                                        |
| PD bits                                       |                                        |
| PEN                                           |                                        |
| bit2-31                                       | , , , ,                                |
|                                               | , ,                                    |
| PFMT bits                                     |                                        |
| PI bit                                        |                                        |
| PINF8 bit2-27, 2-28                           |                                        |
| PL/R bit                                      |                                        |
| PLB bits                                      |                                        |
| PO bit                                        |                                        |
| PPIO bit2-31, 2-32                            |                                        |
| PRDY bit2-3                                   |                                        |
| PS/M bit                                      |                                        |
| PU bit                                        |                                        |
| PU/L bit                                      |                                        |
| PUB bits                                      |                                        |
| PUR bit                                       |                                        |
| RDA bits2-34                                  | , 3-10, 3-19, 3-27                     |
| RDM bit                                       |                                        |
| RF bit                                        |                                        |
| RIG bits                                      |                                        |
| RLG bits                                      | 2-35, 3-19, 3-44                       |
| RLM bits                                      | .2-35, 3-19, 3-44                      |
| RMG bits                                      | .2-35, 3-19, 3-41                      |
| RMGE bit                                      |                                        |
| RMME bit                                      |                                        |
| RMX1 bit                                      |                                        |
| RMX2 bit                                      |                                        |
| RSS bits                                      |                                        |
| RX1A bits                                     |                                        |
| RX2A bits                                     |                                        |
| SDC bit                                       |                                        |
| SOUR bit                                      |                                        |
| SP_PD_RDY bit                                 |                                        |
| SP_PU_RDY bit                                 |                                        |

| SP_PWNDWN bit  |                        |
|----------------|------------------------|
| TE bit         |                        |
| TI bit         |                        |
| TL bits        |                        |
| TOT_PWRDWN bit |                        |
| TOTPWD bit     | 2-37, 2-38, 3-19, 3-56 |
| TRD bit        |                        |
| TU bits        |                        |
| V bits         |                        |
| Bold text      |                        |

#### С

| Capture                          |                  |
|----------------------------------|------------------|
| Capture 8-bit Interface          |                  |
| Capture Byte Swap                |                  |
| Capture Companded Select /Lin    |                  |
| Capture Data                     |                  |
| Capture Data Format Control      |                  |
| register3-10, 3-18, 3            | 3-19. 3-54. 3-55 |
| Capture Data Ready               |                  |
| Capture Enable                   |                  |
| Capture Format Select            |                  |
| Capture Interrupt                |                  |
| Capture Left/Right Sample        |                  |
| Capture Lower Base Count         |                  |
| Capture Lower Base Count         |                  |
| register                         | 3-18, 3-19, 3-57 |
| Capture OverrunSee CO            |                  |
| Capture PIO Enable               |                  |
| Capture Playback Timer           |                  |
| register                         | 3-19, 3-49, 3-50 |
| Capture Stereo/Mono Select       |                  |
| Capture Underrun                 |                  |
| Capture Upper Base Count         | See CUB bits     |
| Capture Upper Base Count         |                  |
| register2-30, 2                  | 3-18, 3-19, 3-57 |
| Capture Upper/Lower Byte         |                  |
| Card Select Number register      |                  |
| CBSW bit2-27, 2                  |                  |
| CC/L bit                         |                  |
| CD bits                          |                  |
| CEN bit 2-31, 2-32, 3-9, 3-19, 3 |                  |
| CFMT bits                        |                  |
| CI bit                           |                  |
| CID bits                         | 3-19, 3-51       |
| CINF8 bit2-27, 2-28, 2           |                  |
| CL/R bit                         |                  |
| CLB bits                         |                  |
| Clock and Data Format            |                  |
| register                         | 3-10, 3-18, 3-19 |
| CMD bits                         |                  |
| CO bit                           |                  |
| Codec 3-2, 3-8, 3-9, 1           |                  |
| Initialization                   |                  |

| Interrupt See INT bit                  |
|----------------------------------------|
| Revision ID                            |
| Companding1-7. See PC/L and CC/L bits  |
| Compatibility1-1                       |
| AdLib                                  |
| Device drivers                         |
| Game Port                              |
| MIDI                                   |
| Plug & Play2-1                         |
| SoundBlaster                           |
| Config Control register2-11, 3-4       |
| Configuring                            |
| Non-Plug & Play mode2-8                |
| Non-Plug & Play mode procedure         |
| Plug & Play Mode                       |
| Controller Block Diagram               |
| COR bit                                |
| Courier text                           |
| CPIO bit2-31, 2-32, 3-19, 3-30, 3-32   |
| CRDY bit2-32, 3-8, 3-13, 3-15          |
| Creative Labs1-6, 3-58, 3-59, 3-62     |
| Crystal, Clock Select/Total Power-Down |
| register2-37, 3-10, 3-18, 3-19, 3-56   |
| CS/M bit                               |
|                                        |
| CU bit                                 |
| CU/L bit                               |
| CUB bits                               |

#### D

| DAC and Mixer Power Down See MIXPWD bit |
|-----------------------------------------|
| DAC Power Down See DACPWD bit           |
| DAC Zero See DACZ bit                   |
| DACPWD bit2-37, 2-38, 3-19, 3-53        |
| DACZ bit                                |
| Data Request Status See DRS bit         |
| Decimal base1-8                         |
| Dependent functions, definition2-2      |
| Development1-6                          |
| Digital Audio Engineering1-7            |
| Digital Mix Attenuation See DMA bits    |
| Digital Mix EnableSee DME bit           |
| Digital Mix/Attenuation                 |
| register2-34, 3-18, 3-19, 3-37          |
| Direct registers, definition            |
| DMA bits2-34, 3-19, 3-37                |
| DMA capture2-5                          |
| DMA Channel                             |
| Selecting, Non-Plug & Play mode2-9      |
| SoundBlaster2-6                         |
| Windows Sound System2-5                 |
| DMA channel select registers            |
| DMA playback2-5                         |
| DMA Selection                           |
| SoundBlaster2-16                        |
|                                         |

| Windows Sound System | 2-14             |
|----------------------|------------------|
| DME bit              | 2-34, 3-19, 3-37 |
| DRS bit              |                  |
| DSP, definition      |                  |
| DSP_PD_RDY bit       |                  |
| DSP_PU_RDY bit       |                  |
| DSP_PWRDWN bit       |                  |
| DSP-based emulation  |                  |
|                      |                  |

#### E

| Enabling Non-Plug & Play mode | 2- | -8 |
|-------------------------------|----|----|
| Enabling Plug & Play mode     | 2- | -4 |

#### F

| FL bits | .3-19, | 3-47, 3-48 |
|---------|--------|------------|
| FU bits | .3-19, | 3-47, 3-48 |

#### G

| Gain, overview2-33                             |  |
|------------------------------------------------|--|
| Game Audio1-5                                  |  |
| Game Port 3-2                                  |  |
| Address range 2-7, 2-19                        |  |
| Driver                                         |  |
| Logical Device Number==4 2-7, 2-11, 2-19       |  |
| Good Plug & Play Configuration, definition 2-2 |  |

#### Η

| Hexadecimal | base | 1-8 |
|-------------|------|-----|
| Hexadecimal | base | 1-8 |

#### Ι

| I/O Port Address                   |
|------------------------------------|
| AdLib2-6                           |
| Game Port                          |
| MIDI                               |
| Modem2-7                           |
| Set RD_DATA Port2-11               |
| Setting, Non-Plug & Play mode 2-9  |
| SoundBlaster2-6                    |
| Windows Sound System 2-5           |
| I/O port base address register 3-4 |
| I/O Range Check register 3-4       |
| ID bits                            |
| IEN bit3-19, 3-33                  |
| IMA-ADPCM companding               |
|                                    |
| Index Address                      |
| register                           |
| Indexed Data                       |
| register                           |
| Indexing See Indirect registers    |
| Non-Plug & Play Devices 2-8, 2-11  |
| Plug & Play register index map 3-6 |
| Indirect registers, definition 3-1 |
| Industry Standards 1-3             |

| INIT bit                                |
|-----------------------------------------|
| Initialization values                   |
| INT bit2-31, 3-8, 3-9, 3-10, 3-13, 3-33 |
| Integration1-1, 1-3                     |
| Interface Configuration                 |
| register                                |
| Interrupt Enable                        |
| Interrupt level select register         |
| Interrupt Request Level                 |
| MIDI2-7, 2-18                           |
| SoundBlaster2-6, 2-7                    |
| Windows Sound System2-5                 |
| Interrupt Selection                     |
| Modem2-21                               |
| SoundBlaster2-16                        |
| Windows Sound System2-13                |
| Interrupt type select register          |
| Introduction1-1                         |
| ISA8MA bit                              |
| Italic text1-8                          |
| IXA bits                                |
| IXD bits                                |
|                                         |

#### L

| LDA bits2-34, 3-10, 3-19, 3-26              |
|---------------------------------------------|
| LDM bit2-34, 3-19, 3-26                     |
| Left Aux #1 Input Control                   |
| register2-34, 3-18, 3-19, 3-22              |
| Left Aux #2 Input Control                   |
| register2-34, 3-18, 3-19, 3-24              |
| Left Auxiliary #1 Mute See LMX1 bit         |
| Left Auxiliary #2 MuteSee LMX2 Bit          |
| Left Auxiliary Input #1 Attenuate Select    |
| See LX1A bits                               |
| Left Auxiliary Input #2 Attenuate Select    |
| See LX2A bits                               |
| Left DAC Mute See LDM bit                   |
| Left Input Control                          |
| register2-33, 3-18, 3-19, 3-20              |
| Left Input Gain select See LIG Bits         |
| Left Input Microphone Gain Enablee LMGE bit |
| Left Input Source SelectSee LSS bits        |
| Left Line Gain, Attenuate, Mute, Mix        |
| register2-35, 3-18, 3-19, 3-43              |
| Left Line Mix GainSee LLG bits              |
| Left Line MuteSee LLM bit                   |
| Left Mic GainSee LMG bits                   |
| Left Mic Mix Enable See LMME bit            |
| Left Output Attenuate select See LDA bits   |
| Left Output Control                         |
| register2-34, 3-18, 3-19, 3-26              |
| LIG bits2-33, 3-19, 3-20                    |
| Little Endian, 16-Bit Signed                |
|                                             |
|                                             |

| LLG bits2-35, 3-19, 3-43                  |
|-------------------------------------------|
| LLM bit2-35, 3-19, 3-43                   |
| LMG bits2-34, 3-19, 3-39                  |
| LMGE bit2-33, 3-19, 3-20                  |
| LMME bit2-35, 3-19, 3-42                  |
| LMX1 bit2-34, 3-19, 3-22                  |
| LMX2 bit2-34, 3-19, 3-24                  |
| Logical Device Number register2-11        |
| Logical Device Number registers           |
| Logical devices 1-2                       |
| Lower Base Count register3-18, 3-19, 3-38 |
|                                           |
| Lower Frequency Select                    |
| 6                                         |
| Lower Frequency Select See FL bits        |
| Lower Frequency Select                    |

#### М

| Manual                                    |
|-------------------------------------------|
| Conventions1-8                            |
| Errata 1-9                                |
| Organization1-9                           |
| Manufacturer ID BitSee MID bit            |
| Maps                                      |
| ISA Bus Registers                         |
| Plug & Play indexed registers 3-6         |
| Windows Sound System Codec Indexed        |
| registers3-18                             |
| MCE                                       |
| bit 2-36, 3-8, 3-10, 3-28, 3-30,          |
|                                           |
| MD bits3-60                               |
| MIA bits2-35, 3-19, 3-52                  |
| MIC Mix Enable/Right MIC Input Control    |
| register2-35, 3-18, 3-19, 3-41, 3-42      |
| Microsoft 1-6                             |
| MID bit3-19, 3-36                         |
| MIDI                                      |
| Address range 2-7, 2-18                   |
| Driver                                    |
| Interrupt request level 2-7, 2-18         |
| Logical Device Number==3 2-7, 2-11, 2-17  |
| Registers 3-2, 3-59                       |
| Support definition3-59                    |
| MIDI 1.0 Detailed Specification 1-7, 3-59 |
| MIDI Command See CMD bits                 |
| MIDI DataSee MD bits                      |
| MIDI Data register3-60                    |
| MIDI Guidebook 1-7                        |
| MIDI Implementation Book 1-7              |
| MIDI Status/Command register3-61          |
|                                           |

| MIM bit2-35, 3-19, 3-52                           |
|---------------------------------------------------|
| Miscellaneous Information registeß-18, 3-19, 3-36 |
| Mixer Address register                            |
| Mixer Data register                               |
| Mixing, overview2-33                              |
| MIXPWD bit2-37, 2-38, 3-19, 3-53                  |
| Mode Change Enable See MCE bit                    |
| Modem                                             |
| Address range2-7, 2-20                            |
| Driver2-3                                         |
| Interrupt selection2-21                           |
| Logical Device Number==52-7, 2-11, 2-20           |
| MOM bit2-35, 3-19, 3-52                           |
| Mono Control register2-35, 3-18, 3-19, 3-52       |
| Mono Input Attenuation selectSee MIA bits         |
| Mono Input MuteSee MIM bit                        |
| Mono Output MuteSee MOM bit                       |
| Multimedia PC Level 2 Specification1-6            |
| Music synthesis, support definition1-5            |
| Music0 register                                   |
| Music1 register                                   |
| -                                                 |

#### N

| Non-Plug & Play                |           |
|--------------------------------|-----------|
| ADDRESS Register               |           |
| Device Configuration           |           |
| Device configuration procedure |           |
| Mode                           | 2-8, 2-41 |
| Numeric base indication        | 1-8       |

#### 0

| OL bit                       | .2-34, 3-19, 3-40 |
|------------------------------|-------------------|
| ORL bits                     |                   |
| ORR bits                     |                   |
| Output Level                 | See OL bit        |
| Overrange Left Detect        | See ORL bits      |
| Overrange Right Detect       |                   |
| Overview                     |                   |
| Manual & Controller          | 1-1               |
| Non-Plug & Play resource a   | rbitration2-8     |
| Plug & Play resource arbitra | ation2-2          |
| Programming                  | 2-1               |
| Registers                    | 3-1               |
| System Architecture          | 1-4               |
|                              |                   |

#### P

| PBSW bit               | 2-27, 2-28, 3-19, 3-28   |
|------------------------|--------------------------|
| PC addresses           | 1-8                      |
| PC/L bit               |                          |
| PD bits                |                          |
| PEN bit2-31, 2-32, 3-9 | , 3-19, 3-28, 3-30, 3-37 |
| PFMT bits              |                          |
| PI bit                 |                          |
| Pin Control register   |                          |

| PINF8 bit2-27, 2-28, 2-29, 3-19, 3-28        |
|----------------------------------------------|
| PIO Data register                            |
| PL/R bit                                     |
| Playback 2-5, 2-10                           |
| Playback 8-bit InterfaceSee PINF8 bit        |
| Playback Byte SwapSee PBSW bit               |
| Playback Companded Select /LineaSee PC/L bit |
| Playback DataSee PD bits                     |
| Playback Data Format register3-28            |
| Playback Data Register ReadySee PRD bit      |
| Playback Enable                              |
| Playback Format SelectSee PFMT bits          |
| Playback Interrupt                           |
| Playback Left/Right Sample                   |
| Playback Lower Base CountSee PLB bits        |
| Playback Overrun                             |
| Playback PIO Enable                          |
| Playback Stereo/Mono SelectSee PS/M bit      |
| Playback Underrun See PU bit. See PUR bit    |
| Playback Upper Base Count                    |
| Playback Upper/Lower Byte                    |
| PLB bits                                     |
| Plug & Play                                  |
| Acceptable Configuration, definition 2-2     |
| Active Devices, definition                   |
| Device Configuration                         |
| Device IDs                                   |
| Device IDs, definition                       |
| Good Configuration, definition               |
| Indexed Registers                            |
| ISA Bus Registers                            |
| Logical Devices, definition                  |
| Mode                                         |
| Register Indexing                            |
| Resource Manager, definition                 |
| Resource ROM, definition                     |
|                                              |
| Sub-optimal Configuration, definition 2-2    |
| Plug & Play ISA Specification                |
| PNP_ENABLE pin                               |
| PO bit3-19, 3-49<br>Powerdown                |
| ADC Power DownSee ADCPWD bit                 |
| DAC and Mixer Power Down                     |
|                                              |
| See MIXPWD bit                               |
| DAC Power Down                               |
| Plug & PlaySee Powerdown register            |
| Plug & Play Vs. Codec2-37                    |
| Total Power Down                             |
| Power-Down Control register3-18, 3-19, 3-53  |
| Powerdown register                           |
| Powerdown registers                          |
| PPIO bit2-31, 2-32, 3-19, 3-30, 3-32         |
| PRDY bit 2-32, 3-8, 3-13, 3-14               |
| Principles of Digital Audio 1-7              |

| 2-1                     |
|-------------------------|
|                         |
| 1-7                     |
|                         |
|                         |
|                         |
|                         |
| .3-15, 3-19, 3-35, 3-37 |
|                         |

#### R

| RDA bits2-34, 3-10, 3-19, 3-27                   |
|--------------------------------------------------|
| RDM bit2-34, 3-19, 3-27                          |
| Read FullSee RF bit                              |
| Read Only, bit type2-10, 3-1                     |
| Read/Write                                       |
| Read/Write, bit type2-10                         |
| READ_DATA register                               |
| Reference texts1-7                               |
| Registers                                        |
| Activate register                                |
| 2-13, 2-15, 2-16, 2-17, 2-19, 2-20, 3-4          |
| ADDRESS register                                 |
| 2-4, 2-8, 2-9, 2-10, 2-11, 2-12,                 |
|                                                  |
|                                                  |
| AdLib registers                                  |
| Alternate Feature Enable/Left MIC Input          |
| Control                                          |
| register2-34, 3-10, 3-18, 3-19, 3-39, 3-40       |
| Capture Data Format Control                      |
| register3-10, 3-18, 3-19, 3-54, 3-55             |
| Capture Lower Base Count                         |
| register                                         |
| Capture Playback Timer                           |
| register                                         |
| Capture Upper Base Count                         |
| register2-30, 3-18, 3-19, 3-57                   |
| Card Select Number register3-4                   |
| Clock and Data Format                            |
| register                                         |
| Config Control register                          |
| Crystal, Clock Select/Total Power-Down           |
| register2-37, 3-10, 3-18, 3-19, 3-56             |
| Digital Mix/Attenuation                          |
| register2-34, 3-18, 3-19, 3-37                   |
| DMA Channel Select registers3-4                  |
| Game Port register3-2                            |
| I/O Port Base Address register3-4                |
| I/O Range Check register3-4                      |
| Interface Configuration registeß-18, 3-19, 3-30, |
| Interrupt Level Select register3-4               |
| Interrupt Type Select register3-4                |
| Left Aux #1 Input Control                        |
| register2-34, 3-18, 3-19, 3-22                   |

| Left Aux #2 Input Control                     |   |
|-----------------------------------------------|---|
| register2-34, 3-18, 3-19, 3-24                | 4 |
| Left Input Control                            |   |
| register2-33, 3-18, 3-19, 3-20                | 0 |
| Left Line Gain, Attenuate, Mute, Mix          |   |
| register2-35, 3-18, 3-19, 3-43                | 3 |
| Left Output Control                           |   |
| register2-34, 3-18, 3-19, 3-20                | б |
| Logical Device Number register 3-4            | 4 |
| Lower Base Count register3-18, 3-19, 3-38     | 8 |
| Lower Frequency Select                        |   |
| register2-36, 3-18, 3-19, 3-4                 | 8 |
| Lower Timer register3-18, 3-19, 3-40, 3-4     | 5 |
| Map of ISA Bus registers                      |   |
| MIC Mix Enable/Right MIC Input Control        |   |
| register2-35, 3-18, 3-19, 3-41, 3-42          | 2 |
| MIDI                                          |   |
| MIDI Data register                            |   |
| MIDI registers                                |   |
| MIDI Status/Command register                  |   |
| Miscellaneous Information register            |   |
|                                               |   |
| Mono Control register                         | U |
| e e e e e e e e e e e e e e e e e e e         | h |
|                                               |   |
| Pin Control register                          |   |
| Playback Data Format register3-22             |   |
| Plug & Play register areas                    |   |
| Power-Down Control register                   |   |
|                                               |   |
| Powerdown register                            |   |
| READ_DATA register                            |   |
| Resource Data register                        |   |
| Revision ID register                          | 1 |
| Right Aux #1 Input Control                    |   |
| register2-34, 3-18, 3-19, 3-2.                | 3 |
| Right Aux #2 Input Control                    |   |
| register2-34, 3-18, 3-19, 3-25                |   |
| Right Input Control register                  |   |
| 2-34, 3-18, 3-19, 3-2                         | 1 |
| Right Line Gain, Attenuate, Mute, Mix         |   |
| register2-35, 3-18, 3-19, 3-44                | 4 |
| Right Output Control                          |   |
| register2-34, 3-18, 3-19, 3-2'                | 7 |
| Serial Isolation register                     |   |
| Set RD_DATA Port register                     |   |
| SoundBlaster registers                        |   |
| Status register                               |   |
| Test and Initialization register              | 1 |
|                                               | 4 |
| , 3-31, 3- <b>32</b> pper Base Count register | ٣ |
|                                               | 8 |
|                                               | 0 |
| Upper Frequency Select                        | 7 |
| register2-36, 3-18, 3-19, 3-4                 |   |
| Upper Timer register3-18, 3-19, 3-40, 3-4     | υ |

| Wake [CSN] register                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WRITE_DATA register                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| WSS Codec Index Address                                                                                                                                                                                                                                               | ,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| register                                                                                                                                                                                                                                                              | 3-2 3-8 3-9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| WSS Codec Indexed Data                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| register                                                                                                                                                                                                                                                              | 3-2 3-8 3-12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| WSS Codec Indexed Registe                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| WSS Codec Indexed Registe<br>WSS Codec Indexed Status r                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| WSS Codec PIO Data registe                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Related development kits                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Related specifications                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| -                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Reset register<br>Reset values                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Resetting, Non-Plug & Play De                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| D. 112 - 21                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Resource arbitration                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Resource Data register                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Revision ID Number                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Revision ID register                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RF bit                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RIG bits                                                                                                                                                                                                                                                              | 2-34, 3-19, 3-21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Right Aux #1 Input Control                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| register2-34,                                                                                                                                                                                                                                                         | 3-18, 3-19, 3-23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Right Aux #2 Input Control                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| register2-34,                                                                                                                                                                                                                                                         | 3-18, 3-19, 3-25                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Right Auxiliary #1 Mute                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Right Auxiliary #2 Mute                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Right Auxiliary Input #1 Attenu                                                                                                                                                                                                                                       | ate Select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Right Auxiliary Input #1 Attenu                                                                                                                                                                                                                                       | ate Select<br><i>See</i> RX1A bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu                                                                                                                                                                                                    | ate Select<br><i>See</i> RX1A bits<br>ate Select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu                                                                                                                                                                                                    | ate Select<br><i>See</i> RX1A bits<br>ate Select<br><i>See</i> RX2A bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | ate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RDM bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute<br>Right Input Control register                                                                                                                                                  | ate Select<br>See RX1A bits<br>ate Select<br>See RX2A bits<br>See RDM bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute<br>Right Input Control register<br>2-34,                                                                                                                                         | ate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RDM bit<br><br>3-18, 3-19, 3-21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute<br>Right Input Control register<br>2-34,<br>Right Input Gain select                                                                                                              | ate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RDM bit<br><br>3-18, 3-19, 3-21<br>See RIG bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute<br><i>Right Input Control register</i><br>2-34,<br>Right Input Gain select<br>Right Input Mic Gain Enable                                                                        | ate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RDM bit<br>See RDM 3-21<br>See RIG bits<br>See RMGE bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | ate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RDM bit<br>See RDM 3-21<br>See RIG bits<br>See RMGE bit<br>See RSS bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute<br><i>Right Input Control register.</i><br>2-34,<br>Right Input Gain select<br>Right Input Mic Gain Enable<br>Right Input Source Select<br><i>Right Line Gain, Attenuate, Mu</i> | ate Select<br>See RX1A bits<br>ate Select<br>See RX2A bits<br>See RDM bit<br><br>3-18, 3-19, 3-21<br>See RIG bits<br>See RMGE bit<br>See RSS bits<br>te, Mix                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | ate Select<br>See RX1A bits<br>thate Select<br>See RX2A bits<br>See RDM bit<br>See RDM bit<br>See RIG bits<br>See RMGE bit<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | ate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RDM bit<br>See RDM bit<br>See RIG bits<br>See RMGE bit<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44<br>See RLG bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | ate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RDM bit<br>See RDM bit<br>See RIG bits<br>See RMGE bits<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44<br>See RLG bits<br>See RLG bits<br>See RLM bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | ate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RDM bit<br>See RDM bit<br>See RIG bits<br>See RMGE bit<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44<br>See RLG bits<br>See RLG bits<br>See RLM bits<br>See RMG bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | ate Select<br>See RX1A bits<br>thate Select<br>See RX2A bits<br>See RDM bit<br>See RDM bit<br>See RIG bits<br>See RMGE bit<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44<br>See RLG bits<br>See RLM bits<br>See RMME bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | ate Select<br>See RX1A bits<br>thate Select<br>See RX2A bits<br>See RDM bit<br>See RDM bit<br>See RIG bits<br>See RMGE bit<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44<br>See RLG bits<br>See RLM bits<br>See RMG bits<br>See RMME bit<br>See RDA bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | ate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RX2A bits<br>See RDM bit<br>See RIG bits<br>See RIG bits<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44<br>See RLG bits<br>See RLM bits<br>See RMME bit<br>See RDA bits<br>See RDA bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | ate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RDM bit<br>See RDM bit<br>See RIG bits<br>See RMGE bit<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44<br>See RLG bits<br>See RLG bits<br>See RMME bit<br>See RMME bit<br>See RDA bits<br>See RDA bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                               | tate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RX2A bits<br>See RDM bit<br>See RDM bits<br>See RIG bits<br>See RMGE bit<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44<br>See RLG bits<br>See RLG bits<br>See RMME bit<br>See RMME bit<br>See RDA bits<br>See RDA bits<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                               | tate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RX2A bits<br>See RDM bit<br>See RDM bits<br>See RIG bits<br>See RMGE bits<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44<br>See RLM bits<br>See RLM bits<br>See RMME bit<br>See RDA bits<br>See RDA bits<br>See RDA bits<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | tate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RX2A bits<br>See RDM bit<br>See RDM bits<br>See RIG bits<br>See RMGE bit<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44<br>See RLM bits<br>See RLM bits<br>See RLM bits<br>See RDA bits<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                               | tate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RX2A bits<br>See RDM bit<br>See RDM bits<br>See RIG bits<br>See RMGE bit<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44<br>See RLM bits<br>See RLM bits<br>See RLM bits<br>See RDA bits<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | tate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RX2A bits<br>See RDM bit<br>See RDM bits<br>See RIG bits<br>See RMGE bits<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44<br>See RLM bits<br>See RLM bits<br>See RMME bit<br>See RDA bits<br>See RDA bits<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | tate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RX2A bits<br>See RDM bit<br>See RDM bits<br>See RIG bits<br>See RMGE bits<br>See RLS bits<br>See RLG bits<br>See RLM bits<br>See RLM bits<br>See RMME bit<br>See RDA bits<br>See RDA bits<br>See RDA bits<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Right Auxiliary Input #1 Attenu<br>Right Auxiliary Input #2 Attenu<br>Right DAC Mute                                                                                                                                                                                  | tate Select<br>See RX1A bits<br>tate Select<br>See RX2A bits<br>See RX2A bits<br>See RDM bit<br>See RDM bits<br>See RIG bits<br>See RMGE bits<br>See RSS bits<br>te, Mix<br>3-18, 3-19, 3-44<br>See RLG bits<br>See RLM bits<br>See RLM bits<br>See RMME bit<br>See RDA bits<br>See |

| RX1A bits | 2-34, 3-19, 3-23 |
|-----------|------------------|
| RX2A bits | 2-34, 3-19, 3-25 |

#### S

| Sample Over/Underrun See SOUR bit                |
|--------------------------------------------------|
| SDC bit2-30, 3-19, 3-31                          |
| Selecting                                        |
| Logical Devices See Indexing                     |
| READ_DATA Address, Non-Plug & Play               |
| mode                                             |
| Serial Isolation register                        |
| Set RD_DATA Port register 2-11, 3-4              |
| Setting, Logical Device Index See Indexing       |
| Single channel DMA mode2-14                      |
| Single DMA Channel                               |
| Software Support                                 |
| Sound Blaster                                    |
| Support definition                               |
| Support definition                               |
|                                                  |
| Address range2-15                                |
| DMA selection2-16                                |
| Driver                                           |
| Interrupt selection2-16                          |
| Logical Device Number==1 2-6, 2-11, 2-15         |
| Registers                                        |
| Support definition 1-8                           |
| SoundBlaster Book1-7                             |
| SOUR bit 3-8, 3-15, 3-35                         |
| SP_PD_RDY bit 2-37, 3-6                          |
| SP_PU_RDY bit 2-37, 3-6                          |
| SP_PWNDWN bit 2-37, 3-6                          |
| Status register 3-2, 3-4, 3-8, 3-13              |
| Sticky, bit type                                 |
| Sub-optimal Plug & Play Configuration,           |
| definition                                       |
| System boot2-2                                   |
| System Boot, definition                          |
| System Resources, definition                     |
|                                                  |
| Τ                                                |
| ТЕ3-40, 3-61                                     |
| Terms                                            |
| Bit Types, definitions 2-10, 3-1                 |
| Codec related2-23                                |
| Euphemisms and acronyms                          |
| Plug & Play related                              |
|                                                  |
| Test and Initialization register3-18, 3-19, 3-34 |
| Text & Symbol Conventions 1-8                    |
| TI bit                                           |
| Timer Enable                                     |
| Timer Interrupt                                  |
| TL bit                                           |
| TOT_PWRDWN bit                                   |
| Total Power Down See TOTPWD bit                  |

| TOTPWD bit             | 2-37, 2-38, 3-19, 3-56 |
|------------------------|------------------------|
| Transfer Request Disat | oleSee TRD bit         |
| Transmit Enable        | See TE bit             |
| TRD bit                |                        |
| TU bits                |                        |
|                        |                        |

#### U

| Upper Base Count register                  |
|--------------------------------------------|
|                                            |
| Upper Frequency Select                     |
| Upper Frequency Select register            |
|                                            |
| Upper Timer See TU bits                    |
| Upper Timer register3-18, 3-19, 3-40, 3-46 |
| V                                          |
| V bits3-19, 3-51                           |

| Version Number | See V bits |
|----------------|------------|
| W              |            |

| Wake [CSN] register                      |  |
|------------------------------------------|--|
| Windows Sound System3-18                 |  |
| Address range                            |  |
| DMA Channel 2-5                          |  |
| Driver                                   |  |
| Interrupt Request Level 2-5              |  |
| Logical Device Number==0 2-5, 2-11       |  |
| Registers                                |  |
| Windows Sound System dependent functions |  |
|                                          |  |
| Write only Momentary, bit type2-10       |  |
| Write Only, bit type 2-10, 3-1           |  |
| WRITE_DATA register                      |  |
| WSS Codec Indexed Registers3-18          |  |