© 2002 CML Microsystems Plc

# CML Microcircuits

D/649/1 June 2002

#### Features

- Multiple Codec Modes, 16 to 128 kbps
  - Full duplex ADM and CVSD
  - Full duplex PCM: µ-law, A-law, Linear
  - **Configurable ADM time constants**
- Dual channel transcoder/decoder mode
- **High Performance Digital Architecture**
- Low Power: 1.9mA at 2.7V
- 2.7V 5.5V Supply
- **Data Clock Recovery**
- Programmable Voice Activity Detector (VAD)
  - Adjust threshold level and attack/decay time
  - Use to powersave on low signal level
  - Silence/blank low level signals
  - **Programmable Digital Scrambler**
- **Flexible Interfaces** 
  - 8 bit and 16 bit burst data with sync strobe
  - 1 bit serial data with clock
  - Host serial control/data interface

- Internal and External Sample Clocking
- **Programmable Filters** 
  - **Encoder mic input ADC anti-alias**
  - Decoder audio out DAC anti-imaging
- Low Noise Differential Mic Input Amp
- **Programmable Analog Interface Gain** Microphone in

  - **Decoder audio out**
  - Sidetone path

#### Applications

- Low Cost Digital Cordless Headset
- Personal Area Network (PAN) Voice Link
- **Digital Cordless Telephone** •
- **Wireless Digital PBX** •
- Full Duplex Digital Radio (TDD) Systems
- **Time Division Duplex Systems** •
- **Portable Digital Voice Communicator**
- **Digital Voice Delay**



#### **Brief Description** 1.

The CMX649 Adaptive Delta Modulation (ADM) Voice Codec provides full duplex ADM, µ-law, A-law, and linear PCM codec and transcoder functions for cost effective, low power, wireless voice applications. Selectable operating modes and algorithms support many applications. Robust ADM coding (e.g. CVSD) reduces host protocol and software burdens, eliminating forward error correction, framing protocols and algorithm processing. Dual transcode/decode mode supports multichannel applications.

Integrated audio filter responses adjust independently from the codec 16kbps to 128kbps data rates. Codec sample clocks are externally applied or internally generated. High performance analog interfaces and sidetone include digital gain controls. Encoder and decoder voice activity detectors support powersaving.

# **CMX649**

# **ADM Codec**

Advance Information



Section

The CMX649 ADM Voice Codec supports 2.7V to 5.5V operation and is available in 20-pin SOIC (D3) and TSSOP (E3) packages.

#### CONTENTS

# <u>Page</u>

| 1. | Brief Description1                                                                                                                                                                                                                                                                                                                                                                                         |
|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2. | Block Diagram3                                                                                                                                                                                                                                                                                                                                                                                             |
| 3. | Signal List4                                                                                                                                                                                                                                                                                                                                                                                               |
| 4. | External Components5                                                                                                                                                                                                                                                                                                                                                                                       |
| 5. | General Description.65.1Block Descriptions.65.1.1ADM Coding Engine65.1.2PCM Encoding and Decoding.75.1.3Transcoding with the Encoder and Decoder85.1.4Non-Linear Instantaneous Companding95.1.5Digitally Controlled Amplifiers.95.1.6Microphone Amplifier95.1.7Programmable Anti-alias/image SC Filters115.1.8Data Clock Recovery115.1.9Data Scrambler/De-scrambler125.1.10Voice Activity Detector (VAD)12 |
|    | 5.2       C-BUS Description       14         5.2.1       Write Only Register Description       17         5.2.2       Read Only Register Description       36                                                                                                                                                                                                                                              |
| 6. | Application Notes396.1C-BUS Operation396.2CODEC Data Interface406.3Example CODEC Setups and Application Help416.3.132kbps ADM with clock and data recovery446.3.264kbps burst mode Bluetooth CVSD45                                                                                                                                                                                                        |
| 7. | Performance Specification                                                                                                                                                                                                                                                                                                                                                                                  |

**Note:** This product is in development: Changes and additions will be made to this specification. Items marked TBD or left blank will be included in later issues.

Information in this data sheet should not be relied upon for final product design.

#### 2. Block Diagram



Figure 1 Block Diagram

<sup>© 2002</sup> CML Microsystems Plc

# 3. Signal List

| SOIC (D3)<br>Package | TSSOP (E3)<br>Package | Signal                     |                | Description                                                                                                                                         |
|----------------------|-----------------------|----------------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin No.              | Pin No.               | Name                       | Туре           |                                                                                                                                                     |
| 1                    | 1                     | STRB                       | Digital Input  | Strobe signal for 8/16 buffered serial I/O.                                                                                                         |
| 2                    | 2                     | ENC VAD                    | Digital Output | Encoder voice activity detector output.                                                                                                             |
| 3                    | 3                     | $V_{DD}$                   | Power          | Positive supply rail.                                                                                                                               |
| 4                    | 4                     | MIC OUT                    | Analog Output  | Analog output signal from microphone amplifier.                                                                                                     |
| 5                    | 5                     | MIC +                      | Analog Input   | Analog non-inverting input to microphone amplifier.                                                                                                 |
| 6                    | 6                     | MIC -                      | Analog Input   | Analog inverting input to microphone amplifier.                                                                                                     |
| 7                    | 7                     | V <sub>BIAS</sub><br>AUDIO | Analog Output  | $V_{DD}/2$ – Not suitable for external<br>applications without buffering. Pin<br>should be decoupled to V <sub>SS</sub> with a<br>capacitor (>1µF). |
| 8                    | 8                     | OUT                        | Analog Output  | Analog Output signal from decoder.                                                                                                                  |
| 9                    | 9                     | $V_{SS}$                   | Power          | Negative supply rail (Ground).                                                                                                                      |
| 10                   | 10                    | DEC VAD                    | Digital Output | Decoder voice activity detector output.                                                                                                             |
| 11                   | 11                    | RX DATA                    | Digital Input  | Received signal serial data input.                                                                                                                  |
| 12                   | 12                    | RX CLK                     | Digital I/O    | Decoder data clock.                                                                                                                                 |
| 13                   | 13                    | XTAL/CLK                   | Analog Input   | 4 – 16 MHz crystal oscillator input.                                                                                                                |
| 14                   | 14                    | IRQN                       | Digital Output | )                                                                                                                                                   |
| 15                   | 15                    | RPLY                       | Digital Output | )                                                                                                                                                   |
| 16                   | 16                    | CMD                        | Digital Input  | ) C-BUS control signals.                                                                                                                            |
| 17                   | 17                    | SCLK                       | Digital Input  | )                                                                                                                                                   |
| 18                   | 18                    | CSN                        | Digital Input  | )                                                                                                                                                   |
| 19                   | 19                    | TX CLK                     | Digital I/O    | Clock signal for encoded data out.                                                                                                                  |
| 20                   | 20                    | TX DATA                    | Digital Output | Encoded data output.                                                                                                                                |

Notes: I/O NC = Input/Output

No Connection

# 4. External Components



#### Figure 2 Recommended External Components

| R1, R2 | Note 1 | $100 k\Omega$ | ±10% | C5 | Note 2 | 33.0µF   | ±20% |
|--------|--------|---------------|------|----|--------|----------|------|
| R3, R4 | Note 1 | $100 k\Omega$ | ±10% | C6 | Note 3 | 1.0μF    | ±20% |
| C1, C3 | Note 1 | 100 pF        | ±20% | C7 | Note 4 | 1.0μF    | ±20% |
| C2, C4 | Note 1 | 0.01µF        | ±20% | X1 | Note 5 | 4.096MHz |      |

#### Notes:

- 1. C1 C4 and R1 R4 set the microphone amplifier gain and frequency response. The values shown set the gain to unity and the low and high –3 dB frequency rolloff points to approximately 150Hz and 15kHz respectively.
- DC blocking capacitor for driving a speaker from an external speaker amplifier. The value shown is based on a 32Ω impedance speaker where the highpass rolloff frequency is set to approximately 150Hz.
- 3.  $V_{DD}$  decoupling capacitor.
- 4. Bias decoupling capacitor.
- 5. A 4.096MHz Xtal/Clock input will yield exactly 16kbps/32kbps/64kbps internally generated data clock rates.
- 6. To achieve good noise performance, V<sub>DD</sub> and V<sub>BIAS</sub> decoupling and protection of the signal path from extraneous in-band signals are very important. It is recommended that the printed circuit board is laid out with a ground plane in the CMX649 area to provide a low impedance connection between the V<sub>SS</sub> pin and the V<sub>DD</sub> and V<sub>BIAS</sub> decoupling capacitors.

### 5. General Description

The CMX649 encodes and decodes analog audio signals to/from ADM, Linear PCM,  $\mu$ -law PCM or A-law PCM. It has programmable clock dividers that enable it to use a range of 4-16 MHz crystal clocks and to sample the data over a large range of data rates. Programmable current sources for all of the on-chip op-amps enable the overall power consumption to be optimised for any given supply voltage and clocking scheme, thus achieving extremely low working power levels.

Anti-Alias Image filters and gain controls are fully programmable. All the time constants and other parameters of the ADM can be programmed for optimum performance.

The CMX649 also includes a Microphone Amplifier, Data Clock Recovery, Data Scrambler/De-Scrambler and Voice Activity Detector (VAD) circuits.

All of these parameters are controlled via C-BUS.

#### 5.1 Block Descriptions

The CMX649 contains a full duplex speech codec supporting common Adaptive Delta Modulation (ADM) and non-linear PCM coding algorithms. In addition, it supports linear PCM coding for DSP interface applications. This codec offers simple interface and application, yet is configurable to support a wide variety of speech quantisation systems.

#### 5.1.1 ADM Coding Engine

ADM is a differential waveform coding technique predominantly applied to speech. Figure 3 illustrates the ADM encoder employed. The device is for speech quantising applications and is based on popular Continuously Variable Slope Delta (CVSD) encoder approaches, with optional modifications and improvements configurable through the ENCODE and DECODE ADM CONTROL Registers (\$E1 and \$D1). Optional second order integration in the feedback loop provides improved speech quality at a given bit rate or similar quality at a lower bit rate. Toll quality is achieved at bit rates much lower than for PCM. The decoder is embedded in the encoder, as is the case with most differential encoders. Note the symmetry between the encoder and decoder of Figures 3 and 4 respectively. The signal flows for ADM are shown in bold.



Figure 3 ADM Encoding



#### Figure 4 ADM Decoding

The estimator integrators (principal and second) as well as the step size decay (companding integrator) have programmable time constants. Additionally, the minimum and maximum step height and the depth of the delay register, are programmable via preset values in the DECODE and ENCODE ADM CONTROL Registers (\$D1 and \$E1) to support a wide variety of different ADM algorithms including CVSD of Bluetooth<sup>™</sup> version 1.1. The switches in Figures 3 and 4 are controlled by the ENCODER and DECODER MODE and SETUP Registers (\$E0 and \$D0). Various signal flows are possible to allow standard ADM and PCM encoding and decoding as well as transcoding either direction between ADM and PCM (e.g. Figures 7 and 8). Additionally, several summing options are possible. In the decoder a PCM and ADM input stream may be summed – note that this requires at least one of the streams to be input via C-BUS. In the encoder a PCM input stream may be summed with the ADM estimate causing the encoded ADM bit stream to represent the sum of the analog input and linear PCM stream input over C-BUS.





Figure 5 PCM Encoding

The output of the first or principal estimator integrator in Figures 3 and 4 is linear PCM. By decimating and filtering this signal it is possible to obtain a linear PCM representation, as shown in Figures 5 and 6. Employing either 8:1 or 4:1 decimation filters provides about 30dB attenuation of out of band quantisation noise prior to decimation. The ADM coding engine, which suppresses out of band noise by roughly 20dB, provides (in conjunction with the decimating filter) an overall out of band suppression of approximately 50dB. Using second order ADM at 64kbps with the 8:1 decimation filter provides better than toll quality linear speech samples. Accordingly, 8k samples/sec linear PCM encoder performance can be enhanced when the ADM codec second order integrator is enabled and the ADM codec is operated at the maximum

rate. Decoding PCM simply requires interpolation and filtering to compensate for sin(x)/x roll-off of zero holding the PCM samples. The interpolation ratio can be programmed to 4 or 8.



Figure 6 PCM Decoding

#### 5.1.3 Transcoding with the Encoder and Decoder



Figure 7 PCM to ADM transcoding with Encoder

(note that the decoder also can be configured to do this function and in this example all data is read and written via C-BUS registers \$EA (\$DA) and \$E7 (\$D7) respectively (for decoder))



Figure 8 ADM to PCM transcoding with Decoder

(note that the encoder can also be configured to do this function and in this example all data is read and written via C-BUS registers \$D6 (\$E6) and \$D8 (\$E8) respectively (for encoder))

#### 5.1.4 Non-Linear Instantaneous Companding

When using the device over its standard PCM codec style interface, instantaneous companding can be enabled to cut in half the PCM word size. Either  $\mu$ -law or A-law companding are available using their standard 16-chord piecewise linear approximations. Essentially the companded 8-bit PCM word is a simple floating-point representation with a sign bit, a 3-bit exponent and a 4-bit mantissa. This approach yields toll quality speech.

#### 5.1.5 Digitally Controlled Amplifiers

There are three Digitally Controlled Amplifiers (DCA) on-chip, which are used to set the signal levels for transmit-audio-in, side-tone-audio, and receive-audio-out (volume control). The transmit-audio DCA is adjustable in 0.5dB steps over a +7.5dB to -7.5dB range. The side-tone DCA is adjustable in 6.0dB steps over a 0dB to -21.0dB range. Side-tone audio is added to the audio output signal via an operational amplifier configured as a summing amplifier. This feeds the receive-audio DCA, which is adjustable in 1.5dB steps over a +12.0dB to -33.0dB range.

#### 5.1.6 Microphone Amplifier

The input amplifier is a high gain low-noise operational amplifier capable of interfacing with a variety of different microphones. Figure 9 is a simplified schematic showing the external components required for typical application with an electret condenser microphone. Typical values for R1, R3, C1 and C3 should be set according to microphone sensitivity requirements, those shown are for unity gain. Note also that the microphone biasing resistors (R5 and R6) are microphone specification dependent.



#### Figure 9 Electret Microphone - Input Amplifier Schematic

| R1, R3 | 100k $\Omega$ | ±10% | R5 | $100 k\Omega$ | ±10% |
|--------|---------------|------|----|---------------|------|
| R2, R4 | $100 k\Omega$ | ±10% | R6 | $100 k\Omega$ | ±10% |

| C1, C3 | 100 pF | ±20% | C6 | 1.0μF | ±20% |
|--------|--------|------|----|-------|------|
| C2, C4 | 0.01µF | ±20% | C7 | 1.0μF | ±20% |

#### 5.1.7 Programmable Anti-alias/image SC Filters

The anti-aliasing (AAF) and anti-imaging (AIF) switched capacitor (SC) filters have a programmable cutoff frequency to accommodate different input signal bandwidths. Typically, the audio filter bandwidth should be programmed to be 1/10<sup>th</sup> of the ADM bit rate (or lower) for "toll" (or better) quality audio reconstruction. For "communications" quality, the audio bandwidth may approach 1/6<sup>th</sup> of the ADM bit rate for ADM rates below 20kbps. The anti-alias/image SC filter bandwidth is programmed directly via C-BUS commands to the AAF/AIF BANDWIDTH Register (\$61). Additionally, the switched capacitor clock frequency can be altered via C-BUS commands to the CLK DIVIDER CONTROL Register (\$72). Typically, the CLK DIVIDER CONTROL Register should be programmed to provide a 256kHz SC filter clock. Altering the SC filter clock from the recommended 256kHz frequency proportionally scales the frequency axis in the plot below:



Figure 10 Anti-Alias/Image Filter Frequency Response

#### 5.1.8 Data Clock Recovery

Data from the RX DATA pin is driven into a comparator to remove amplitude variations. The output of the comparator is a logic signal that can be inverted by setting the appropriate control bit in the SCRAMBLER CONTROL Register (\$71). Using the output of the comparator, the clock recovery block can be enabled to generate a phase-locked clock equal to the CVSD data rate, which is used to clock data from the RX DATA pin into the decoder. The recovered clock frequency is controlled by the CLK DIVIDER CONTROL Register (\$72). If the clock recovery block is bypassed, data must then be applied which is synchronised to the clock on the RX CLK pin (either internally generated or externally applied).

External ADM rate bit clocks can be used for both the encoder and decoder paths and do not require use of the clock recovery PLL. Externally applied clocks act directly as the ADM sample clocks and should be generated with little jitter for best performance. Please note that the maximum usable frequency of externally applied bit clocks is 1/60<sup>th</sup> of the frequency of the output of the internal bit clock prescaler.

<sup>© 2002</sup> CML Microsystems Plc

The clock recovery circuit is normally applied to the decoder. However, it is possible to use the recovered clock for the encoder section as well. This supports systems where the base unit is using an internal clock or local external clock for transmit and clock recovery for the decoder clock. The remote unit can then be configured to use the recovered clock for both encode and decode. Internal data clocks for the encoder and decoder can also be selected for data input and output control.

#### 5.1.9 Data Scrambler/De-scrambler

The scrambler receives digital data from the encoder. It is implemented with a 10-bit programmable linear feedback shift register (LFSR) allowing a choice of various maximal length scrambling codes. The scrambler, also known as a randomizer, provides not only a level of communication security, but may also help reduce the occurrence of abnormally long strings of 1s or 0s.

The de-scrambler receives the scrambled data from the data slicer and de-scrambles it to the original data as long as the selected LFSR maximal length sequence is the same as that in the transmitting scrambler. The de-scrambler block has the same configuration as the scrambler and is self-synchronizing. Both the scrambler and de-scrambler can be bypassed.

Nine example maximal length codes are represented below through their polynomial coefficients which can be directly programmed in Bits 9-0 of the SCRAMBLER CONTROL Register (\$71):

| Length | Polynomial coefficients in hex format |
|--------|---------------------------------------|
| 2      | 0x003                                 |
| 3      | 0x006                                 |
| 4      | 0x00C                                 |
| 5      | 0x014                                 |
| 6      | 0x030                                 |
| 7      | 0x060                                 |
| 8      | 0x08E                                 |
| 9      | 0x110                                 |
| 10     | 0x240                                 |

#### 5.1.10 Voice Activity Detector (VAD)

The VAD function is implemented with an energy detector circuit. This circuit consists of an absolute value function, an integrator and a threshold detector. The threshold detector level and the integrator time constants (i.e. attack and decay time control) are user programmable via the DECODE and ENCODE VAD THRESHOLD Registers (\$D2 and \$E2) and the DECODER and ENCODER MODE AND SETUP Registers (\$D0 and \$E0). Referring to Figure 11, the input to the VAD comes from the PCM signal. The signal is rectified and averaged with a lossy integrator. The output of the integrator is compared to the VAD threshold to derive the logic signal VAD\_OUT. If VAD\_OUT is a logic one, signal energy greater than the threshold is present. If VAD\_OUT is a logic zero, signal energy is below the threshold. Attack and decay times for the decoder VAD and encoder VAD can be independently controlled via the DECODER and ENCODER MODE AND SETUP Registers (\$D0 and \$E0). Typical attack and decay times used for detecting voice activity are 5ms and 150ms, respectively. The energy levels may be read from DECODE and ENCODE VAD LEVEL OUTPUT Registers (\$D4 and \$E4) for the decoder and encoder and used to adaptively set the detector threshold value by observing the energy level of background noise.



Figure 11 VAD Block Diagram

#### 5.2 C-BUS Description

#### Address/Commands

Instructions and data are transferred, via C-BUS, in accordance with the timing information given in Figure 12.

Instruction and data transactions to and from the CMX649 consist of an Address/Command (A/C) byte followed by either:

- (i) a further instruction or data (1 or 2 bytes) or
- (ii) a status or Rx data reply (1 or 2 bytes)

| REGISTER<br>NAME              | HEX<br>ADDRESS/<br>COMMAN<br>D | BIT 7<br>(D7)                         | BIT 6<br>(D6)           | BIT 5<br>(D5)          | BIT 4<br>(D4)                | BIT3<br>(D3)               | BIT 2<br>(D2)                                             | BIT 1<br>(D1)   | BIT 0<br>(D0) |  |
|-------------------------------|--------------------------------|---------------------------------------|-------------------------|------------------------|------------------------------|----------------------------|-----------------------------------------------------------|-----------------|---------------|--|
| GENERAL<br>RESET              | \$01                           | Х                                     | Х                       | Х                      | Х                            | Х                          | Х                                                         | Х               | Х             |  |
| AAF/AIF                       | \$61                           |                                       | Anti-Ali                | as Filter              |                              |                            | Anti-Ima                                                  | ge Filter       |               |  |
| BANDWIDTH                     |                                | By-Pass                               |                         | Band-Width             | 1                            | By-Pass                    |                                                           | Band-Width      | 1             |  |
| VOLUME/SIDE-<br>TONE LEVEL    | \$62                           |                                       |                         | Volume                 |                              |                            | Side-                                                     | Tone            | ON/OFF        |  |
| AUDIO INPUT<br>LEVEL CTRL     | \$63                           | Input Level                           |                         |                        |                              |                            | 0                                                         | 0               | 0             |  |
| POWER<br>CONTROL 1            | \$64                           | Anti-Alias Current Anti-Image Current |                         |                        |                              | Enc DAC                    | Current Dec DAC Current                                   |                 | C Current     |  |
| POWER<br>CONTROL 2            | \$65                           | Mic Amp                               | Current                 | nt Audio Current Volur |                              | Volume                     | Current                                                   | Xtal<br>Current | 0             |  |
| CODEC MODE<br>CONTROL         | \$70                           | 0                                     | 0                       | 0                      | 0                            | 0                          | C                                                         | Codec Mode      | S             |  |
| SCRAMBLER                     | \$71                           | 5                                     | SCRAMBLE                | R                      | DE                           | -SCRAMBL                   | -SCRAMBLER Poly                                           |                 | nomial        |  |
| CONTROL (1)                   |                                | EN                                    | PRSEL                   | INVERT                 | EN                           | PRSEL                      | INVERT                                                    | Т9              | T8            |  |
|                               |                                |                                       |                         |                        | Polyı                        | nomial                     |                                                           |                 |               |  |
| (2)                           |                                | T7                                    | T6                      | T5                     | T4                           | Т3                         | T2                                                        | T1              | Т0            |  |
| CLK DIVIDER<br>CONTROL (1)    | \$72                           | PREN                                  | DCKEN                   | ECKEN                  | Filter P                     | re-Scaler                  | I                                                         | Filter Divide   | r             |  |
| (2)                           |                                | Bit Clock                             | Pre-Scaler              | Decod                  | er Bit Clock                 | Divider                    | Encode                                                    | er Bit Clock    | Divider       |  |
| CLK SOURCE<br>CONTROL (1)     | \$73                           | 0                                     | 0                       |                        | Phase Detect Input<br>Select |                            | 0                                                         | 0               | 0             |  |
| (2)                           |                                | PLL EN                                | Rx Bit<br>Clk<br>Select | Tx Bit Clo             | ock Select                   | Data<br>Filter By-<br>Pass | Data Filter and Data<br>Slicer Power Filter<br>Control BW |                 |               |  |
| CODEC<br>INTERRUPT<br>CONTROL | \$81                           |                                       | Encode                  | Enable                 |                              |                            | Decode                                                    | Enable          |               |  |

#### Write Only C-BUS Registers

| REGISTER<br>NAME                  | HEX<br>ADDRESS/<br>COMMAN<br>D | BIT 7<br>(D7)                                         | BIT 6<br>(D6)                                        | BIT 5<br>(D5) | BIT 4<br>(D4)  | BIT3<br>(D3)              | BIT 2<br>(D2) | BIT 1<br>(D1)                         | BIT 0<br>(D0)           |
|-----------------------------------|--------------------------------|-------------------------------------------------------|------------------------------------------------------|---------------|----------------|---------------------------|---------------|---------------------------------------|-------------------------|
| DECODER<br>MODE AND<br>SETUP (1)  | \$D0                           | DEC BY<br>4/8                                         | Select I                                             | PCM IN        | Select         | ADM IN                    |               | er Output<br>lect                     | Track<br>Offset         |
| (2)                               |                                | VAD De                                                | ecay Time C                                          | Constant      |                | ack Time<br>stant         |               | AD Output<br>urce                     | 0                       |
| DECODE ADM<br>CONTROL (1)         | \$D1                           | Syllab                                                | oic Time Co                                          | nstant        |                | Range for S<br>Integrator |               | -                                     | ding Rule               |
| (2)                               |                                |                                                       | mator Integ<br>ple Time Co                           |               |                | Estimator<br>constant     |               | tion for 2 <sup>nd</sup><br>tegration | Dec<br>Zero             |
| DECODE VAD<br>THRESHOLD<br>(1)    | \$D2                           |                                                       | Vo                                                   | bice Activity | Detector Th    | nreshold Set              | ting Bits 15  | - 8                                   |                         |
| (2)                               |                                |                                                       | Voice Activity Detector Threshold Setting Bits 7 - 0 |               |                |                           |               |                                       |                         |
| DECODE OFF-<br>SET LEVEL (1)      | \$D3                           |                                                       |                                                      | 0             | ffset Input L  | evel Bits 15              | - 8           |                                       |                         |
| (2)                               |                                | Offset Input Level Bits 7 – 0                         |                                                      |               |                |                           |               |                                       |                         |
| DECODE<br>LINEAR PCM<br>INPUT (1) | \$D7                           | Direct Write to DAC Input Bits 15 - 8                 |                                                      |               |                |                           |               |                                       |                         |
| (2)                               |                                |                                                       |                                                      | Direc         | t Write to DA  | AC Input Bit              | s 7 – 0       |                                       |                         |
| DECODE ADM<br>INPUT               | \$D8                           |                                                       |                                                      |               | Decode A       | ADM Input                 |               |                                       |                         |
| ENCODER<br>MODE AND<br>SETUP (1)  | \$E0                           | DEC BY<br>4/8                                         | Select I                                             | PCM IN        | Select         | ADM IN                    |               | Decoder<br>t Select                   | Track<br>Offset         |
| (2)                               |                                | VAD De                                                | ecay Time C                                          | Constant      |                | ack Time<br>stant         |               | AD Output<br>urce                     | ADM<br>Output<br>Select |
| ENCODE ADM<br>CONTROL (1)         | \$E1                           | Syllab                                                | oic Time Co                                          | nstant        |                | Range for S<br>Integrator |               | -                                     | ding Rule               |
| (2)                               |                                |                                                       | mator Integ<br>ble Time Co                           |               |                | Estimator<br>constant     |               | tion for 2 <sup>nd</sup><br>tegration | Dec<br>Zero             |
| ENCODE VAD<br>THRESHOLD<br>(1)    | \$E2                           | Voice Activity Detector Threshold Setting Bits 15 - 8 |                                                      |               |                |                           |               |                                       |                         |
| (2)                               |                                |                                                       | V                                                    | oice Activity | y Detector T   | hreshold Se               | tting Bits 7  | - 0                                   |                         |
| ENCODE OFF-<br>SET LEVEL (1)      | \$E3                           |                                                       |                                                      | 0             | ffset Input L  | evel Bits 15              | - 8           |                                       |                         |
| (2)                               |                                |                                                       |                                                      | С             | )ffset Input L | evel Bits 7 -             | - 0           |                                       |                         |

<sup>© 2002</sup> CML Microsystems Plc

| REGISTER<br>NAME        | HEX<br>ADDRESS/<br>COMMAN<br>D | BIT 7<br>(D7)                         | BIT 6<br>(D6) | BIT 5<br>(D5) | BIT 4<br>(D4) | BIT3<br>(D3) | BIT 2<br>(D2) | BIT 1<br>(D1) | BIT 0<br>(D0) |
|-------------------------|--------------------------------|---------------------------------------|---------------|---------------|---------------|--------------|---------------|---------------|---------------|
| ENCODE DAC<br>INPUT (1) | \$E7                           | Direct Write to DAC Input Bits 15 - 8 |               |               |               |              |               |               |               |
| (2)                     |                                | Direct Write to DAC Input Bits 7 – 0  |               |               |               |              |               |               |               |
| ENCODE ADM<br>INPUT     | \$E8                           |                                       |               |               | Encode A      | ADM Input    |               |               |               |

# Read Only C-BUS Registers

| REGISTER<br>NAME                         | HEX<br>ADDRESS/<br>COMMAN<br>D | BIT 7<br>(D7)                                    | BIT 6<br>(D6)                                    | BIT 5<br>(D5) | BIT 4<br>(D4) | BIT3<br>(D3)   | BIT 2<br>(D2) | BIT 1<br>(D1) | BIT 0<br>(D0) |
|------------------------------------------|--------------------------------|--------------------------------------------------|--------------------------------------------------|---------------|---------------|----------------|---------------|---------------|---------------|
| CODEC<br>STATUS<br>(READ)                | \$80                           |                                                  | Encode Pro                                       | ocess Status  | ;             | D              | ecode Proc    | essor Statu   | S             |
| DECODE VAD<br>LEVEL<br>OUTPUT (1)        | \$D4                           |                                                  | Voice Activity Detector Level Output Bits 15 - 8 |               |               |                |               |               |               |
| (2)                                      |                                |                                                  |                                                  | Voice Activ   | vity Detector | r Level Outp   | ut Bits 7 - 0 |               |               |
| DECODE VAD<br>OFFSET LEVEL<br>OUTPUT (1) | \$D5                           | Offset Level Output Bits 15 - 8                  |                                                  |               |               |                |               |               |               |
| (2)                                      |                                | Offset Level Output Bits 7 - 0                   |                                                  |               |               |                |               |               |               |
| DECODE<br>LINEAR PCM<br>OUTPUT (1)       | \$D6                           |                                                  |                                                  | Linear        | PCM Outpo     | ut Signal Bite | s 15 - 8      |               |               |
| (2)                                      |                                |                                                  |                                                  | Linear        | r PCM Outp    | out Signal Bit | s 7 - 0       |               |               |
| DECODE ADM<br>OUTPUT                     | \$DA                           | Decode ADM Output                                |                                                  |               |               |                |               |               |               |
| ENCODE VAD<br>LEVEL<br>OUTPUT (1)        | \$E4                           | Voice Activity Detector Level Output Bits 15 - 8 |                                                  |               |               |                |               |               |               |
| (2)                                      |                                |                                                  |                                                  | Voice Activ   | vity Detector | r Level Outp   | ut Bits 7 - 0 |               |               |

| REGISTER<br>NAME                         | HEX<br>ADDRESS/<br>COMMAN<br>D | BIT 7<br>(D7)                        | BIT 6<br>(D6) | BIT 5<br>(D5) | BIT 4<br>(D4) | BIT3<br>(D3) | BIT 2<br>(D2) | BIT 1<br>(D1) | BIT 0<br>(D0) |
|------------------------------------------|--------------------------------|--------------------------------------|---------------|---------------|---------------|--------------|---------------|---------------|---------------|
| ENCODE VAD<br>OFFSET LEVEL<br>OUTPUT (1) | \$E5                           | Offset Level Output Bits 15 - 8      |               |               |               |              |               |               |               |
| (2)                                      |                                | Offset Level Output Bits 7 - 0       |               |               |               |              |               |               |               |
| ENCODE<br>LINEAR PCM<br>OUTPUT (1)       | \$E6                           | Linear PCM Output Signal Bits 15 - 8 |               |               |               |              |               |               |               |
| (2)                                      |                                | Linear PCM Output Signal Bits 7 - 0  |               |               |               |              |               |               |               |
| ENCODE ADM<br>OUTPUT                     | \$EA                           |                                      |               |               | Encode A      | DM Output    |               |               |               |

#### 5.2.1 Write Only Register Description

#### **GENERAL RESET (\$01)**

The reset command has no data attached to it. Application of the GENERAL RESET sets all write only register bits to 0.

#### AAF/AIF BANDWIDTH Register (\$61)

AAF Bypass (Bit 7)
 AAF Bandwidth (Bits 6 - 4)
 When this bit is set to logic 1 the anti-alias filter is bypassed.
 The -3dB cutoff frequency of the anti-alias filter is controlled by bits 4 - 6. The filter shape is not altered other than to move the cutoff frequency. The transfer function is a 6<sup>th</sup> order Butterworth lowpass.

| Bit 6 | Bit 5 | Bit 4 | -3dB Frequency |
|-------|-------|-------|----------------|
| 0     | 0     | 0     | 2.9kHz         |
| 0     | 0     | 1     | 3.7kHz         |
| 0     | 1     | 0     | 5.0kHz         |
| 0     | 1     | 1     | 7.0kHz         |
| 1     | 0     | 0     | 10.0kHz        |
| 1     | 0     | 1     | 14.0kHz        |
| 1     | 1     | 0     | 14.0kHz        |
| 1     | 1     | 1     | 14.0kHz        |

**AIF Bypass** When this bit is set to a logic 1 the anti-image filter is bypassed.

(Bit 3)

when this bit is set to a logic 1 the anti-image litter is bypassed.

**AIF Bandwidth** (Bits 2-0) The -3dB cutoff frequency of the anti-image filter is controlled by bits 0-2. The filter shape is not altered other than to move the cutoff frequency. The transfer function is a 6<sup>th</sup> order Butterworth lowpass.

| Bit 6 | Bit 5 | Bit 4 | -3dB Frequency |
|-------|-------|-------|----------------|
| 0     | 0     | 0     | 2.9kHz         |
| 0     | 0     | 1     | 3.7kHz         |
| 0     | 1     | 0     | 5.0kHz         |
| 0     | 1     | 1     | 7.0kHz         |
| 1     | 0     | 0     | 10.0kHz        |
| 1     | 0     | 1     | 14.0kHz        |
| 1     | 1     | 0     | 14.0kHz        |
| 1     | 1     | 1     | 14.0kHz        |

## VOLUME/SIDETONE LEVEL Register (\$62)

Volume Level<br/>(Bits 7 - 3)The five most significant bits in this register are used to set the gain of the volume<br/>control according to the table below:

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Increment Per Step = 1.5dB<br>Steps |
|-------|-------|-------|-------|-------|-------------------------------------|
| 0     | 0     | 0     | 0     | 0     | Off                                 |
| 0     | 0     | 0     | 0     | 1     | -33.0dB                             |
| 0     | 0     | 0     | 1     | 0     | -31.5dB                             |
| 0     | 0     | 0     | 1     | 1     | -30.0dB                             |
| 0     | 0     | 1     | 0     | 0     | -28.5dB                             |
| 0     | 0     | 1     | 0     | 1     | -27.0dB                             |
| 0     | 0     | 1     | 1     | 0     | -25.5dB                             |
| 0     | 0     | 1     | 1     | 1     | -24.0dB                             |
| 0     | 1     | 0     | 0     | 0     | -22.5dB                             |
| 0     | 1     | 0     | 0     | 1     | -21.0dB                             |
| 0     | 1     | 0     | 1     | 0     | -19.5dB                             |
| 0     | 1     | 0     | 1     | 1     | -18.0dB                             |
| 0     | 1     | 1     | 0     | 0     | -16.5dB                             |
| 0     | 1     | 1     | 0     | 1     | -15.0dB                             |
| 0     | 1     | 1     | 1     | 0     | -13.5dB                             |
| 0     | 1     | 1     | 1     | 1     | -12.0dB                             |
| 1     | 0     | 0     | 0     | 0     | -10.5dB                             |
| 1     | 0     | 0     | 0     | 1     | -9.0dB                              |
| 1     | 0     | 0     | 1     | 0     | -7.5dB                              |
| 1     | 0     | 0     | 1     | 1     | -6.0dB                              |
| 1     | 0     | 1     | 0     | 0     | -4.5dB                              |
| 1     | 0     | 1     | 0     | 1     | -3.0dB                              |
| 1     | 0     | 1     | 1     | 0     | -1.5dB                              |
| 1     | 0     | 1     | 1     | 1     | 0.0dB                               |
| 1     | 1     | 0     | 0     | 0     | 1.5dB                               |
| 1     | 1     | 0     | 0     | 1     | 3.0dB                               |
| 1     | 1     | 0     | 1     | 0     | 4.5dB                               |
| 1     | 1     | 0     | 1     | 1     | 6.0dB                               |
| 1     | 1     | 1     | 0     | 0     | 7.5dB                               |
| 1     | 1     | 1     | 0     | 1     | 9.0dB                               |
| 1     | 1     | 1     | 1     | 0     | 10.5dB                              |
| 1     | 1     | 1     | 1     | 1     | 12.0dB                              |

CMX649

Sidetone Level<br/>(Bits 2 - 1)These bits control the gain of the sidetone signal coming from the AAF output to be<br/>summed in with the decode signal at the input to the AIF.

| Bit 2 | Bit 1 | Gain Setting |
|-------|-------|--------------|
| 0     | 0     | 0dB          |
| 0     | 1     | -9dB         |
| 1     | 0     | -15dB        |
| 1     | 1     | -21dB        |

**Sidetone Enable** When this bit is a logic 1 the sidetone path is enabled with the gain setting controlled as shown above. When this bit is logic 0 the sidetone path is disabled.

#### AUDIO INPUT LEVEL CONTROL Register (\$63)

Audio InputThese bits are used to set the gain of the Digitally Controlled Amplifier (DCA) at the<br/>output of the microphone amplifier.

(Bits 7 – 3)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Audio Input Gain |
|-------|-------|-------|-------|-------|------------------|
| 0     | 0     | 0     | 0     | 0     | Off              |
| 0     | 0     | 0     | 0     | 1     | -7.5dB           |
| 0     | 0     | 0     | 1     | 0     | -7.0dB           |
| 0     | 0     | 0     | 1     | 1     | -6.5dB           |
| 0     | 0     | 1     | 0     | 0     | -6.0dB           |
| 0     | 0     | 1     | 0     | 1     | -5.5dB           |
| 0     | 0     | 1     | 1     | 0     | -5.0dB           |
| 0     | 0     | 1     | 1     | 1     | -4.5dB           |
| 0     | 1     | 0     | 0     | 0     | -4.0dB           |
| 0     | 1     | 0     | 0     | 1     | -3.5dB           |
| 0     | 1     | 0     | 1     | 0     | -3.0dB           |
| 0     | 1     | 0     | 1     | 1     | -2.5dB           |
| 0     | 1     | 1     | 0     | 0     | -2.0dB           |
| 0     | 1     | 1     | 0     | 1     | -1.5dB           |
| 0     | 1     | 1     | 1     | 0     | -1.0dB           |
| 0     | 1     | 1     | 1     | 1     | -0.5dB           |
| 1     | 0     | 0     | 0     | 0     | 0.0dB            |
| 1     | 0     | 0     | 0     | 1     | 0.5dB            |
| 1     | 0     | 0     | 1     | 0     | 1.0dB            |
| 1     | 0     | 0     | 1     | 1     | 1.5dB            |
| 1     | 0     | 1     | 0     | 0     | 2.0dB            |
| 1     | 0     | 1     | 0     | 1     | 2.5dB            |
| 1     | 0     | 1     | 1     | 0     | 3.0dB            |
| 1     | 0     | 1     | 1     | 1     | 3.5dB            |
| 1     | 1     | 0     | 0     | 0     | 4.0dB            |
| 1     | 1     | 0     | 0     | 1     | 4.5dB            |
| 1     | 1     | 0     | 1     | 0     | 5.0dB            |
| 1     | 1     | 0     | 1     | 1     | 5.5dB            |
| 1     | 1     | 1     | 0     | 0     | 6.0dB            |
| 1     | 1     | 1     | 0     | 1     | 6.5dB            |
| 1     | 1     | 1     | 1     | 0     | 7.0dB            |
| 1     | 1     | 1     | 1     | 1     | 7.5dB            |

| Reserved    | These bits are reserved and should be set to a logic 0. |
|-------------|---------------------------------------------------------|
| (Bits 2– 0) |                                                         |

#### **POWER CONTROL 1 Register (\$64)**

AAF Power These bits are dedicated to power/current control for the AAF. Note: It is necessary to keep the power level set to one of the "ON" settings when the AAF is bypassed.

(Bits 7 - 6)

| Bit 7 | Bit 6 | Power Level Setting                                         |
|-------|-------|-------------------------------------------------------------|
| 0     | 0     | Power down (Off).                                           |
| 0     | 1     | Lowest power (for audio bandwidths less than 3.3kHz).       |
| 1     | 0     | Low power (for audio bandwidths between 3.3kHz and 10kHz).  |
| 1     | 1     | Normal operation (for audio bandwidths greater than 10kHz). |

AIF PowerThese bits are dedicated to power/current control for the AIF and the Sidetone DCA.ControlNote: It is necessary to keep the power level set to one of the "ON" settings when<br/>the AIF is bypassed.

| Bit 5 | Bit 4 | Power Level Setting                                   |
|-------|-------|-------------------------------------------------------|
| 0     | 0     | Power down (Off).                                     |
| 0     | 1     | Lowest power (for audio bandwidths less than 3.3kHz). |
| 1     | 0     | Low power (for audio bandwidths between 3.3kHz and    |
|       |       | 10kHz).                                               |
| 1     | 1     | Normal operation (for audio bandwidths greater than   |
|       |       | 10kHz).                                               |

Encode DAC These bits are dedicated to power/current control for the Encode DAC.

(Bits 3 – 2)

| Bit 3 | Bit 2 | Power Level Setting                                   |
|-------|-------|-------------------------------------------------------|
| 0     | 0     | Power down (Off).                                     |
| 0     | 1     | Lowest power (for bit rates less than 32kbps).        |
| 1     | 0     | Low power (for bit rates between 32kbps and 64kbps).  |
| 1     | 1     | Normal operation (for bit rates greater than 64kbps). |

Decode DACThese bits are dedicated to power/current control for the Decode DAC.Power Control

(Bits 1 – 0)

| Bit 1 | Bit 0 | Power Level Setting                                   |
|-------|-------|-------------------------------------------------------|
| 0     | 0     | Power down (Off).                                     |
| 0     | 1     | Lowest power (for bit rates less than 32kbps).        |
| 1     | 0     | Low power (for bit rates between 32kbps and 64kbps).  |
| 1     | 1     | Normal operation (for bit rates greater than 64kbps). |

#### POWER CONTROL 2 Register (\$65)

**MIC AMP** These bits are dedicated to power/current control for the Microphone Amplifier. **Power Control** 

(Bits 7 – 6)

| Bit 7 | Bit 6 | Power Level Setting                                   |
|-------|-------|-------------------------------------------------------|
| 0     | 0     | Power down (Off).                                     |
| 0     | 1     | Lowest power (for audio bandwidths less than 3.3kHz). |
| 1     | 0     | Low power (for bit rates between 3.3kHz and 10kHz).   |
| 1     | 1     | Normal operation (for audio bandwidths greater than   |
|       |       | 10kHz).                                               |

AUDIO DCA These bits are dedicated to power/current control for the Audio Input Digitally Controlled Amplfier.

(Bits 5 – 4

| Bit 5 | Bit 4 | Power Level Setting                                         |
|-------|-------|-------------------------------------------------------------|
| 0     | 0     | Power down (Off).                                           |
| 0     | 1     | Lowest power (for audio bandwidths less than 3.3kHz).       |
| 1     | 0     | Low power (for audio bandwidths between 3.3kHz and 10kHz).  |
| 1     | 1     | Normal operation (for audio bandwidths greater than 10kHz). |

VOLUME DCAThese bits are dedicated to power/current control for the Volume Digitally ControlledPower ControlAmplifier.

(Bits 3 – 2)

| Bit 3 | Bit 2 | Power Level Setting                                   |
|-------|-------|-------------------------------------------------------|
| 0     | 0     | Power down (Off).                                     |
| 0     | 1     | Lowest power (for bit rates less than 32kbps).        |
| 1     | 0     | Low power (for bit rates between 32kbps and 64kbps).  |
| 1     | 1     | Normal operation (for bit rates greater than 64kbps). |

**XTAL Power** When this bit is a logic 1 the one-pin crystal oscillator circuit is powered down. **Save** 

(Bit 1)

**ANALOG Enable** (Bit 0) When this bit is set to a logic 1 all of the analog circuitry (register \$64 and bits 7-2 of register \$65) is enabled. When this bit is set to a logic 0 all of the analog circuitry is powered down (on-chip bandgap reference is powered down). This is equivalent to setting all of the bits of register \$64 and bits 7-2 of register \$65 to a logic 0.

#### CODEC MODE CONTROL Register (\$70)

**Reserved**These bits are reserved and should be set to a logic 0.(Bits 7 - 3)

# CODEC MODE

(Bits 2 – 0)

| Bit 2 | Bit 1 | Bit 0 | CODEC Mode                    |
|-------|-------|-------|-------------------------------|
| 0     | 0     | 0     | ADM mode without buffered I/O |
| 0     | 0     | 1     | ADM mode with buffered I/O    |
| 0     | 1     | 0     | Linear PCM with buffered I/O  |
| 0     | 1     | 1     | µ-law PCM with buffered I/O   |
| 1     | 0     | 0     | A-law PCM with buffered I/O   |
| 1     | 0     | 1     | A-law PCM with buffered I/O   |
| 1     | 1     | 0     | A-law PCM with buffered I/O   |
| 1     | 1     | 1     | A-law PCM with buffered I/O   |

#### SCRAMBLER CONTROL Register (\$71)

| Scrambler<br>Enable<br>(Bit 15)                      | Setting this bit to a logic 1 enables the scrambler.                                                                                                                   |
|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Output<br>Scrambler<br>Pseudo Random<br>(Bit 14)     | Setting this bit to a logic 1 forces the scrambler to put out a pseudo-random sequence.                                                                                |
| Scrambler<br>Output Invert<br>(Bit 13)               | Setting this bit to a logic 1 inverts the scrambler output polarity.                                                                                                   |
| De-Scrambler<br>Enable<br>(Bit 12)                   | Setting this bit to a logic 1 enables the de-scrambler.                                                                                                                |
| Output De-<br>Scrambler<br>Psuedo Random<br>(Bit 11) | Setting this bit to a logic 1 forces the de-scrambler to put out a pseudo-random sequence.                                                                             |
| De-Scrambler<br>Output Invert.<br>(Bit 10)           | Setting this bit to a logic 1 inverts the de-scrambler output polarity.                                                                                                |
| LFSR Tap<br>Select<br>(Bits 9 – 0)                   | These bits directly program the polynomial for the scrambler and de-scrambler:<br>PR = $B9X^9 + B8X^8 + B7X^7 + B6X^6 + B5X^5 + B4X^4 + B3X^3 + B2X^2 + B1X^1 + B0X^0$ |

#### CLK DIVIDER CONTROL Register (\$72)

| Pre-Scaler<br>Enable<br>(Bit 15)              | Setting                                                     | this bit to | a logic 1   | enables the pre-scaler divider.    |                |  |
|-----------------------------------------------|-------------------------------------------------------------|-------------|-------------|------------------------------------|----------------|--|
| Decode Bit<br>Clock Enable<br>(Bit 14)        | Setting this bit to a logic 1 enables the decode bit clock. |             |             |                                    |                |  |
| Encode Bit<br>Clock Enable<br>(Bit 13)        | Setting                                                     | this bit to | a logic 1   | enables the encode bit clock.      |                |  |
| Filter Clock Pre-<br>Scaler<br>(Bits 12 – 11) | These b                                                     | oits contro | ol the inte | rnal switched capacitor filter clo | ck pre-scaler. |  |
|                                               |                                                             | Bit 12      | Bit 11      | Divider Ratio                      |                |  |
|                                               |                                                             | 0           | 0           | 1.0                                |                |  |
|                                               |                                                             | 0           | 1           | 2.0                                |                |  |
|                                               |                                                             | 1           | 0           | 3.0                                |                |  |
|                                               |                                                             | 1           | 1           | 4.0                                |                |  |

| Filter Clock<br>Divider<br>(Bits 10 – 8) | These bits control the internal switched capacitor filter clock divider. |
|------------------------------------------|--------------------------------------------------------------------------|

| Bit 10 | Bit 9 | Bit 8 | Divider Ratio |
|--------|-------|-------|---------------|
| 0      | 0     | 0     | 1.000         |
| 0      | 0     | 1     | 4.000         |
| 0      | 1     | 0     | 7.750         |
| 0      | 1     | 1     | 7.785         |
| 1      | 0     | 0     | 8.000         |
| 1      | 0     | 1     | 11.000        |
| 1      | 1     | 0     | 15.625        |
| 1      | 1     | 1     | 23.375        |

Bit Clock Pre-Scaler

These bits control the bit clock pre-scaler.

(Bits 7 – 6)

| Bit 7 | Bit 6 | Divider Ratio |
|-------|-------|---------------|
| 0     | 0     | 1.000         |
| 0     | 1     | 2.000         |
| 1     | 0     | 3.000         |
| 1     | 1     | 4.000         |

| Bit 5 | Bit 4 | Bit 3 | Divider Ratio |
|-------|-------|-------|---------------|
| 0     | 0     | 0     | 1.000         |
| 0     | 0     | 1     | 2.000         |
| 0     | 1     | 0     | 2.250         |
| 0     | 1     | 1     | 2.625         |
| 1     | 0     | 0     | 3.000         |
| 1     | 0     | 1     | 3.125         |
| 1     | 1     | 0     | 3.375         |
| 1     | 1     | 1     | 3.500         |

Decode Bit **Clock Divider** (Bits 5 - 3)

These bits control the decode bit clock divider.

**Clock Divider** (Bits 2 – 0)

Encode Bit

| Т | hese | bits | control | the | encod | e bit | clock | divider. |  |
|---|------|------|---------|-----|-------|-------|-------|----------|--|
|   |      |      |         |     |       |       |       |          |  |

Bit 2 Bit 1 Bit 0 **Divider Ratio** 0 0 0 1.000 0 0 1 2.000 0 1 0 2.250 0 1 1 2.625 0 0 1 3.000 1 0 1 3.125 0 3.375 1 1 1 1 1 3.500

The audio filter clock divider should be programmed to set the audio filter clock as near as possible to 256kHz, via selection of the XTAL frequency and the Filter Prescaler and Filter Divider settings.

The encoder and decoder ADM bit rate clocks should be programmed to the desired ADM bit rate or PCM sample rate, multiplied by the interpolation/decimation setting of the PCM filter. The PCM filter can be programmed to run at either 4x or 8x the PCM sample rate depending on the corresponding setting in the encode/decode processors.

The encoder and decoder ADM bit rate clocks are further divided by a constant factor of 64 (unless the PLL is enabled in which case the average is near 64 but can pull off slightly depending on the reference source).

#### CLK SOURCE CONTROL Register (\$73)

| Reserved<br>(Bit 15-14)<br>Phase Detect    | Set to                                                                                                                                                                                                                                                                                                                                                                                                               | a logic 0.               |       |                                                       |        |  |  |
|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-------|-------------------------------------------------------|--------|--|--|
| Input Select<br>(Bit 13)                   | 0 = PLL locks to external input clock<br>1 = PLL locks to external input strobe.                                                                                                                                                                                                                                                                                                                                     |                          |       |                                                       |        |  |  |
| (Bit 12)                                   |                                                                                                                                                                                                                                                                                                                                                                                                                      | L locks to<br>L locks to |       | ges.<br>I clock or strobe edges according to Bit 13 v | /alue. |  |  |
| Reserved<br>(Bit 11-8)                     | Set to                                                                                                                                                                                                                                                                                                                                                                                                               | a logic 0.               |       |                                                       |        |  |  |
| PLL Enable<br>(Bit 7)                      | Setting this bit to a logic 1 enables the phase locked loop in the clock recover circuit. When the PLL is enabled the decoder ADM bit clock adjusts its phase in increments of 1/32 of the programmed period to minimise noise due to timing jitter. Setting this bit to a logic 0 free-wheels the post divide by 64 decode clock divider and thus produces a bit clock which is synchronised to the XTAL/CLK input. |                          |       |                                                       |        |  |  |
| Decode Bit<br>Clock Select<br>(Bit 6)      | Setting this bit to a logic 1 selects the bit clock generated by the clock recovery circuit. Setting this bit to a logic 0 selects a bit clock externally applied to the RX CLK pin.                                                                                                                                                                                                                                 |                          |       |                                                       |        |  |  |
| Encode Bit<br>Clock Select<br>(Bits 5 – 4) | These bits allow for the selection of three different sources for the encode bit clock.                                                                                                                                                                                                                                                                                                                              |                          |       |                                                       |        |  |  |
|                                            |                                                                                                                                                                                                                                                                                                                                                                                                                      | Bit 5                    | Bit 4 | Encode Bit Clock                                      |        |  |  |
|                                            |                                                                                                                                                                                                                                                                                                                                                                                                                      | Х                        | 0     | External Tx Clock Pin.                                |        |  |  |

Note that a system clock or crystal is always required on the XTAL/CLK pin, in order to generate the various internal timing signals, even when Rx and Tx Clocks are recovered from the RX DATA pin.

clock.

0

1

1

1

 Data Filter
 Setting this bit to a logic 1 bypasses the data filter and inputs the RX DATA signal directly into the data slicer.

 Bypass
 These bits are dedicated to power/current control for the data filter and slicer.

 Data Filter and Slicer Power Control (Bits 2 – 1)
 Bit 2
 Bit 1
 Power Level Setting

 0
 0
 Power down (Off).
 0

|   |   | I ower Level Setting                                  |
|---|---|-------------------------------------------------------|
| 0 | 0 | Power down (Off).                                     |
| 0 | 1 | Lowest power (for bit rates less than 32kbps).        |
| 1 | 0 | Low power (for bit rates between 32kbps and 64kbps).  |
| 1 | 1 | Normal operation (for bit rates greater than 64kbps). |

When the Data Filter and Slicer are powered off, the RX DATA input pin signal must conform to logic level amplitudes. When operating the device in buffered I/O modes, the Data Filter and Slicer should be powered off.

Internally Generated encode clock.

Internally Generated from decode

Data FilterSetting this bit to a logic 1 forces the data filter to narrow mode.Bandwidth(Bit 0)

#### **CODEC INTERRUPT CONTROL Register (\$81)**

#### Encoder Control (Bits 7 – 4)

| Bit 7 | Bit | Bit 5 | Bit 4 | Encoder Setting                                    |
|-------|-----|-------|-------|----------------------------------------------------|
|       | 6   |       |       |                                                    |
| 0     | Х   | Х     | Х     | Encoder is disabled and reset.                     |
| 1     | 0   | 0     | 0     | Encoder is enabled to run without generating IRQs. |
| 1     | 1   | Х     | Х     | Encoder is enabled and will generate IRQ's to      |
|       |     |       |       | indicate VAD status changes.                       |
| 1     | Х   | 1     | Х     | Encoder is enabled and will generate periodic      |
|       |     |       |       | IRQs to indicate whether PCM data is available or  |
|       |     |       |       | needed when transcoding.                           |
| 1     | Х   | Х     | 1     | Encoder is enabled and will generate periodic      |
|       |     |       |       | IRQs to indicate whether ADM data is available or  |
|       |     |       |       | needed when transcoding.                           |

#### Decoder Control (Bits 3 – 0)

| Bit 3 | Bit 2 | Bit 1 | Bit 0 | Decoder Setting                                                                                                                    |
|-------|-------|-------|-------|------------------------------------------------------------------------------------------------------------------------------------|
| 0     | Х     | Х     | Х     | Decoder is disabled and reset.                                                                                                     |
| 1     | 0     | 0     | 0     | Decoder is enabled to run without generating IRQs.                                                                                 |
| 1     | 1     | Х     | Х     | Decoder is enabled and will generate IRQs to                                                                                       |
|       |       |       |       | indicate VAD status changes.                                                                                                       |
| 1     | Х     | 1     | Х     | Decoder is enabled and will generate periodic<br>IRQs to indicate whether the PCM data is needed<br>or available when transcoding. |
| 1     | Х     | Х     | 1     | Decoder is enabled and will generate periodic<br>IRQs to indicate whether the ADM data is needed<br>or available when transcoding. |

#### **DECODER MODE AND SETUP Register (\$D0)**

Decimation<br/>Rate (by 4/8)<br/>(Bit 15)The decoder PCM filter functions as an interpolator for the DAC when PCM words<br/>are being received by the decoder and as a decimator when the decoder is receiving<br/>delta modulation. In the case where delta modulation is received, transcoded PCM<br/>values are available in the DECODE LINEAR PCM OUTPUT Register (\$D6) at the<br/>decimation rate. When PCM is received the device can be set to transcode to an<br/>ADM stream available in the DECODE ADM OUTPUT Register (\$DA) at the<br/>interpolated rate. A logic 1 sets the interpolation (decimation) rate to 4 (1/4<sup>th</sup> the bit<br/>rate). A logic 0 sets the interpolation (decimation) rate to 8 (1/8<sup>th</sup> the bit rate).

 PCM Input
 Allows selection of the input to the PCM rate converting filter.

 Select
 Bit 14
 Bit 13
 Selected PCM Input

| Bit 14 | Bit 13 | Selected PCM Input                         |  |
|--------|--------|--------------------------------------------|--|
| 0      | Х      | PCM filter decimates ADM estimator output. |  |

|   |   | PCM words available in register \$D6.                                                                                                                                                                                                                                                                    |  |  |
|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 1 | 0 | <ul> <li>PCM filter interpolates linear PCM input from burst mode interface (RX DATA pin).</li> <li>This selection must be made in conjunction with the CODEC MODE CONTROL Register (\$70). Note that the burst interface expands μLaw or Alaw signals to linear PCM prior to the PCM filter.</li> </ul> |  |  |
| 1 | 1 | PCM filter interpolates linear PCM input from<br>C-BUS interface via the DECODE LINEAR<br>PCM INPUT Register(\$D9).                                                                                                                                                                                      |  |  |

If PCM filter interpolates, the decoder can digitally transcode a PCM signal to ADM. If PCM filter decimates, the decoder can digitally transcode an ADM signal to PCM.

| ADM Input                | Γ         | Bit 12                                                                                                                                        | Bit 11     | Selected ADM Input                                                            |  |  |  |
|--------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------|------------|-------------------------------------------------------------------------------|--|--|--|
| Select                   |           | 0                                                                                                                                             | 0          | ADM decoder input from the RX DATA pin.                                       |  |  |  |
| (Bits 12 – 11)           |           | -                                                                                                                                             | -          | (Normal mode operation).                                                      |  |  |  |
|                          |           | 0                                                                                                                                             | 1          | ADM decoder gets input from C-BUS via the                                     |  |  |  |
|                          |           |                                                                                                                                               |            | DECODE ADM INPUT Register (\$D8). This                                        |  |  |  |
|                          |           |                                                                                                                                               |            | could be used to force in an idle pattern or to                               |  |  |  |
|                          |           |                                                                                                                                               |            | play out an arbitrary stored signal.                                          |  |  |  |
|                          |           | 1                                                                                                                                             | Х          | (Alternate ADM input operation).<br>ADM input from digital feedback. When ADM |  |  |  |
|                          |           | I                                                                                                                                             | ^          | input comes from digital feedback. When ADM                                   |  |  |  |
|                          |           |                                                                                                                                               |            | transcode from PCM to ADM. PCM filter                                         |  |  |  |
|                          |           |                                                                                                                                               |            | must be set to interpolate. In this mode the                                  |  |  |  |
|                          |           |                                                                                                                                               |            | analog interface can be powered down since                                    |  |  |  |
|                          |           |                                                                                                                                               |            | all signal processing is done digitally.                                      |  |  |  |
|                          |           |                                                                                                                                               |            | (PCM to ADM transcoding input operation).                                     |  |  |  |
| Deceder Output           | Г         | D:4 40                                                                                                                                        | D:4 0      | Colorial Decoder Output                                                       |  |  |  |
| Decoder Output<br>Select | -         | <b>Bit 10</b><br>0                                                                                                                            | Bit 9      | Selected Decoder Output           ADM estimator output drives decoder output. |  |  |  |
| (Bits 10 – 9)            | -         | 0                                                                                                                                             | 0          | ADM estimator output summed with PCM                                          |  |  |  |
|                          |           | 0                                                                                                                                             | 1          | interpolation filter output drives decoder                                    |  |  |  |
|                          |           |                                                                                                                                               |            | output. The ADM and PCM signals can be                                        |  |  |  |
|                          |           |                                                                                                                                               |            | input from any combination of RX DATA pin                                     |  |  |  |
|                          |           |                                                                                                                                               |            | and C-BUS input registers.                                                    |  |  |  |
|                          | _         | 1                                                                                                                                             | 0          | Direct PCM test mode.                                                         |  |  |  |
|                          |           | 1                                                                                                                                             | 1          | Interpolated PCM output.                                                      |  |  |  |
| Track Offset             | For the D | ecoder th                                                                                                                                     | is bit sho | uld normally be set to a logic 0. When running the                            |  |  |  |
| (Bit 8)                  | decoder a | as a PCM                                                                                                                                      | to ADM t   | ranscoder this bit can be set to a logic 1 to allow the                       |  |  |  |
|                          |           |                                                                                                                                               |            | omponent in the PCM signal. A non zero DC component                           |  |  |  |
|                          |           |                                                                                                                                               |            | scoder's idle channel noise and should be removed or                          |  |  |  |
|                          |           |                                                                                                                                               |            | offset tracking ensure the decoder ADM input selection is                     |  |  |  |
|                          |           | digital feedback, the PCM filter is set to interpolate, and the DECODE OFFSET LEVEL Register (\$D3) is loaded with a small positive constant. |            |                                                                               |  |  |  |
|                          |           | egister (ø                                                                                                                                    | 03) 13 108 | aded with a small positive constant.                                          |  |  |  |
|                          | Alla      | le ettern ef                                                                                                                                  | 4 - 1/-:-  | A stinity Data star de sau time soustant                                      |  |  |  |
| Decoder VAD              | Allows se | election of                                                                                                                                   | the voice  | e Activity Detector decay time constant.                                      |  |  |  |
| Decay Time<br>Constant   |           | Bit                                                                                                                                           | 7 Bit      | 6 Bit 5 Decay Time Constant (ms),                                             |  |  |  |
| (Bits 7 – 5)             |           | 0                                                                                                                                             |            | 0 128/(Bit Rate)                                                              |  |  |  |
|                          |           | 0                                                                                                                                             | 0          | 1 256/(Bit Rate)                                                              |  |  |  |
|                          |           | 0                                                                                                                                             | 1          | 0 512/(Bit Rate)                                                              |  |  |  |
|                          |           |                                                                                                                                               |            |                                                                               |  |  |  |

| 0 | 1 | 0 | 512/(Bit Rate)   |
|---|---|---|------------------|
| 0 | 1 | 1 | 1024/(Bit Rate)  |
| 1 | 0 | 0 | 2048/(Bit Rate)  |
| 1 | 0 | 1 | 4096/(Bit Rate)  |
| 1 | 1 | 0 | 8192/(Bit Rate)  |
| 1 | 1 | 1 | 16384/(Bit Rate) |

Decoder VAD Attack Time Constant (Bits 4 - 3)

Allows selection of the Voice Activity Detector attack time constant.

| Bit 4 | Bit 3 | Attack Time Constant (ms)    |  |
|-------|-------|------------------------------|--|
| 0     | 0     | (VAD Decay Time Constant)/4  |  |
| 0     | 1     | (VAD Decay Time Constant)/8  |  |
| 1     | 0     | (VAD Decay Time Constant)/16 |  |
| 1     | 1     | (VAD Decay Time Constant)/32 |  |

| Decoder VAD   |  |  |  |  |
|---------------|--|--|--|--|
| Output Source |  |  |  |  |
| (Bits 2 – 1)  |  |  |  |  |

. .. .. . . .

| Allows selection of the Voice Activity Detector output source | ce. |
|---------------------------------------------------------------|-----|
|---------------------------------------------------------------|-----|

| Bit 2 | Bit 1 | VAD Output                           |  |
|-------|-------|--------------------------------------|--|
| 0     | 0     | Normal VAD operation.                |  |
| 0     | 1     | ADM bits are driven over VAD pin at  |  |
|       |       | the ADM bit rate (may be useful when |  |
|       |       | transcoding or verifying proper      |  |
|       |       | application of the burst interface). |  |
| 1     | 0     | VAD output driven to 0.              |  |
| 1     | 1     | VAD output driven to 1.              |  |

Reserved (Bit 0)

This bit is reserved and should be set to a logic 0.

**DECODE ADM CONTROL Register (\$D1)** 

Syllabic Time Step size integrator Loss Coefficient: allows selection of syllabic time constant.

| Constant   |     |
|------------|-----|
| (Bits 15 - | 13) |

| Bit 15 | Bit 14 | Bit 13 | Syllabic Filter Time Constant (ms)   |  |
|--------|--------|--------|--------------------------------------|--|
| 0      | 0      | 0      | 512/(3*Bit Rate)                     |  |
| 0      | 0      | 1      | 768/(3*Bit Rate)                     |  |
| 0      | 1      | 0      | 1024/(3*Bit Rate)                    |  |
| 0      | 1      | 1      | 1536/(3*Bit Rate)                    |  |
| 1      | 0      | 0      | 2048/(3*Bit Rate)                    |  |
| 1      | 0      | 1      | 3072/(3*Bit Rate)                    |  |
|        |        |        | Bluetooth compatible when running at |  |
|        |        |        | 64kbps.                              |  |
| 1      | 1      | 0      | 4096/(3*Bit Rate)                    |  |
| 1      | 1      | 1      | 6144/(3*Bit Rate)                    |  |

**Dynamic Range** for Step Size Integrator (Bits 12 - 10)

Maximum and minimum step size are based on 16-bit word length (-32768 to 32767).

| Bit 12 | Bit 11 | Bit 10 | Maximum Step | Minimum Step |
|--------|--------|--------|--------------|--------------|
| 0      | 0      | 0      | 10240        | 20           |
| 0      | 0      | 1      | 10240        | 10           |
| 0      | 1      | 0      | 5120         | 20           |
| 0      | 1      | 1      | 5120         | 10           |

| 0 | 1 | 1 | 5120 | 10                      |
|---|---|---|------|-------------------------|
| 1 | 0 | 0 | 2560 | 20                      |
| 1 | 0 | 1 | 2560 | 10                      |
| 1 | 1 | 0 | 1280 | 20                      |
| 1 | 1 | 1 | 1280 | 10                      |
|   |   |   |      | Bluetooth compatible    |
|   |   |   |      | when running at 64kbps. |

Companding<br/>RuleThis is the number of consecutive ones or zeros that must occur for the step size to<br/>be adjusted.(Bits 9 – 8)Bit 9Bit 8Companding Rule

| Bit 9 | Bit 8 | Companding Rule           |
|-------|-------|---------------------------|
| 0     | 0     | 3 of 3                    |
| 0     | 1     | 4 of 4                    |
|       |       | Bluetooth compatible when |
|       |       | running at 64kbps.        |
| 1     | 0     | 5 of 5                    |
| 1     | 1     | 6 of 6                    |

Allows selection of the estimator integrator time constant.

Estimator Integrator Time Constant (Bits 7 – 5)

| Bit 7 | Bit 6 | Bit 5 | Decay Time Constant (ms)  |
|-------|-------|-------|---------------------------|
| 0     | 0     | 0     | 16/(3*Bit Rate)           |
| 0     | 0     | 1     | 24/(3*Bit Rate)           |
| 0     | 1     | 0     | 32/(3*Bit Rate)           |
| 0     | 1     | 1     | 48/(3*Bit Rate)           |
| 1     | 0     | 0     | 64/(3*Bit Rate)           |
| 1     | 0     | 1     | 96/(3*Bit Rate)           |
|       |       |       | Bluetooth compatible when |
|       |       |       | running at 64kbps.        |
| 1     | 1     | 0     | 128/(3*Bit Rate           |
| 1     | 1     | 1     | 192/(3*Bit Rate)          |

(Estimator Time Constant)/8

Second Order Allows selection of the second order estimator time constant. **Estimator Time** Bit 4 Bit 3 Time Constant (ms), Bit Rate in kbps Constant N/A (selects first order estimator). (Bits 4 – 3) 0 0 0 1 (Estimator Time Constant)/2 0 (Estimator Time Constant)/4

1

1 1

| Bit 2 | Bit 1 | Time Constant (ms), Bit Rate in kbps    |
|-------|-------|-----------------------------------------|
| 0     | 0     | N/A (select for first order estimator). |
| 0     | 1     | 1.5/Bit Rate                            |
| 1     | 0     | 2.5/Bit Rate                            |
| 1     | 1     | 4.5/Bit Rate                            |

Zero at <sup>1</sup>/Bit When decoding ADM, a zero at (bit rate)/2 can be enabled by setting this bit to logic 1. When transcoding from PCM to ADM this bit should always be set to logic 0 Rate to avoid instability in the transcoding loop. (Bit 0)

#### **DECODE VAD THRESHOLD Register (\$D2)**

These bits directly program the threshold of detection for the Voice Activity Detector. Decode VAD The number programmed into this register can range from \$0 to \$7FFF (0 to 32767). Threshold The equation for the VAD threshold is: (Bits 15 – 0) Register Value =  $\frac{(\text{Signal Detection Threshold}) \cdot 2^{15}}{(\text{DAC Full Scale Reference Voltage})}$ 

#### **DECODE OFFSET LEVEL Register (\$D3)**

For normal Decoder operation this register does not need loading. **Decode Offset** 

Input These bits allow for an offset amount to be directly programmed. This offset amount (Bits 15 - 0) is useful in trimming out offsets that may occur in the on-chip analog circuitry. The number format is 2's complement and ranges from \$8000 through \$0000 to \$7FFF (-32768 to 32767).

The equation for the Offset value is:

(Offset Voltage)  $\cdot 2^{18}$ Register Value =  $\frac{C}{(DAC Full Scale Reference Voltage)}$ 

The programmed offset will be summed with the decoder output signal.

When offset tracking is enabled (Bit 8 of register \$D0), e.g. while transcoding PCM to ADM, this register can be loaded with a small positive constant (e.g. in the range [2-16]) to allow automatic DC nulling for best idle channel performance. This is not needed if the PCM signal already has zero DC.

#### **DECODE LINEAR PCM INPUT Register (\$D7)**

**Decode Linear** This register allows input of linear PCM via C-BUS for transcoding. The number format is 2's complement and ranges from \$8000 through \$0000 to \$7FFF (-32768 to **PCM** Input 32767). Bit 1 of the CODEC INTERRUPT CONTROL Register (\$81) can be set to a (Bits 15 - 0) logic 1 to enable interrupts informing a micro-controller when the register should be updated.

#### **DECODE ADM INPUT Register (\$D8)**

**Decoder ADM** This register allows ADM bits to be written into the decoder via C-BUS and is Input intended for transcoding. Bit 0 of the CODEC INTERRUPT CONTROL Register (\$81) can be set to a logic 1 to enable interrupts informing a micro-controller when (Bits 7 - 0) the register should be updated. Additionally this register can be loaded with an idle data pattern (\$55 or \$AA) and then selected as the input to the decoder via the DECODER MODE AND SETUP Register (\$D0)

#### ENCODER MODE AND SETUP Register (\$E0)

The encoder PCM filter functions as a decimating lowpass when the encoder is Decimation Rate (by 4/8) running. PCM values are available in the ENCODE LINEAR PCM OUTPUT Register (\$E6) at the decimation rate. A logic 1 sets the decimation rate to 4 (1/4<sup>th</sup> (Bit 15) the bit rate).

A logic 0 sets the decimation rate to 8  $(1/8^{th}$  the bit rate).

**PCM** Input Select (Bits 14 - 13) Allows selection of the input to the PCM rate converting filter.

Bit 14 Bit 13 **Selected PCM Input** 0 Х PCM filter decimates ADM estimator output PCM words available in register \$E6. PCM filter interpolates PCM input from burst 1 0 mode interface (RX DATA pin). This selection must be made in conjunction with the CODEC MODE CONTROL Register (\$70). 1 1 PCM filter interpolates PCM input from C-BUS interface via the ENCODE DAC TEST CONTROL Register (\$E9).

If PCM filter is interpolating, the encoder can transcode a PCM signal to ADM. If PCM filter is decimating, the encoder will transcode an ADM signal to PCM.

| ADM Input      |        |        |                                                                                                                                                                                                                                                                                                              |
|----------------|--------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Select         | Bit 12 | Bit 11 | Selected ADM Input                                                                                                                                                                                                                                                                                           |
| (Bits 12 – 11) | 0      | 0      | ADM encoder input from Comparator.                                                                                                                                                                                                                                                                           |
|                |        |        | (Normal mode operation).                                                                                                                                                                                                                                                                                     |
|                | 0      | 1      | ADM encoder gets input from C-BUS<br>breaking the feedback loop and allowing the<br>local decoder to digitally transcode an ADM<br>signal input via C-BUS to a PCM signal<br>output via C-BUS or the burst interface.<br>(Alternate ADM input operation).                                                    |
|                | 1      | Х      | ADM input from transcode feedback. When<br>ADM input comes from transcode feedback<br>it will transcode from PCM to ADM. The<br>PCM filter must be set to interpolate. In this<br>mode the encode analog interface can be<br>powered down since it is not used.<br>(PCM to ADM transcoding input operation). |

| Level Develop | <b>D</b> <sup>1</sup> (40) | D'' 0       |                                                                                  |
|---------------|----------------------------|-------------|----------------------------------------------------------------------------------|
| Local Decoder | Bit 10                     | Bit 9       | Selected Local Decoder Output                                                    |
| Output Select | 0                          | 0           | ADM estimator output drives local decoder                                        |
| (Bits 10 – 9) | 0                          | 4           | output.                                                                          |
|               | 0                          | 1           | ADM estimator output summed with PCM<br>interpolation filter output drives local |
|               |                            |             | decoder output.                                                                  |
|               |                            |             |                                                                                  |
|               |                            |             | For encoder, ADM output tracks sum of MIC                                        |
|               |                            |             | input analog signal plus a PCM signal input                                      |
|               |                            |             | over the C-BUS interface.                                                        |
|               | 1                          | 0           | Direct PCM test mode.                                                            |
|               | 1                          | 1           | Interpolated PCM output.                                                         |
|               |                            |             |                                                                                  |
| Track Offset  | For the E                  | ncoder th   | nis bit should normally be set to a logic 1 to allow analog offsets to           |
| (Bit 8)       | be autom                   | atically c  | ompensated. When running the encoder as a digital ADM to PCM                     |
| . ,           | transcode                  | er this bit | should be set to 0 since the local ADM decoder runs outside a                    |
|               | feedback                   | loop.       |                                                                                  |
|               |                            |             |                                                                                  |
|               |                            |             | set tracking ensure the encoder ADM input selection is either                    |
|               |                            |             | comparator or for PCM to ADM transcoding. Also load the                          |
|               |                            |             | T LEVEL Register (\$E3) with a small positive constant. And if                   |
|               | lianscoue                  | e leeubau   | ck is selected then the PCM filter must also be set to interpolate.              |
| Encoder VAD   | These bit                  | s allow s   | election of the Voice Activity Detector decay time constant.                     |
| Decay Time    |                            |             |                                                                                  |
| Constant      | Bit 7                      | Bit 6       | Bit 5 Decay Time Constant (ms), Bit Rate in kbps                                 |
| (Bits 7 – 5)  | 0                          | 0           | 0 128/(Bit Rate)                                                                 |
|               | 0                          | 0           | 1 256/(Bit Rate)                                                                 |
|               | 0                          | 1           | 0 512/(Bit Rate)                                                                 |
|               | 0                          | 1           | 1 1024/(Bit Rate)                                                                |
|               | 1                          | 0           | 0 2048/(Bit Rate)                                                                |
|               | 1                          | 0           | 1 4096/(Bit Rate)                                                                |
|               | 1                          | 1           | 0 8192/(Bit Rate)                                                                |
|               | 1                          | 1           | 1 16384/(Bit Rate)                                                               |
|               |                            |             |                                                                                  |
| Encoder VAD   | Allows se                  | election o  | f the Voice Activity Detector attack time constant.                              |
| Attack Time   |                            |             |                                                                                  |
| Constant      | Bit 4                      | Bit 3       | Attack Time Constant (ms)                                                        |
| (Bits 4 – 3)  | 0                          | 0           | (VAD Decay Time Constant)/4                                                      |
|               | 0                          | 1           | (VAD Decay Time Constant)/8                                                      |
|               | 1                          | 0           | (VAD Decay Time Constant)/16                                                     |
|               | 1                          | 1           | (VAD Decay Time Constant)/32                                                     |
| Encoder VAD   | Allows se                  | election o  | f the Voice Activity Detector output source.                                     |
| Output Source |                            |             |                                                                                  |
| (Bits 2 – 1)  | Bit 2                      | Bit 1       | VAD Output                                                                       |
|               | 0                          | 0           | Nominal VAD operation.                                                           |
|               | 0                          | 1           | ADM bits are driven over VAD pin at the ADM bit                                  |
|               |                            |             | rate (may be useful when transcoding or verifying                                |
|               | 4                          |             | proper application of the burst interface).                                      |
|               | 1                          | 0           | VAD output driven to 0.                                                          |
|               | 1                          | 1           | VAD output driven to 1.                                                          |

(Bits 15 – 13)

ADM OutputFor normal operation this bit should be set to a logic 0. Setting this bit to a logic 1Selectallows arbitrary ADM streams, written in via the ENCODE ADM INPUT Register(Bit 0)(\$E8), to be output. For example to force the encoder to output an idle pattern<br/>010101... while running, regardless of the input analog waveform, write \$55 into<br/>register \$E8 and set this bit to a logic 1.

#### ENCODE ADM CONTROL Register (\$E1)

Syllabic Time Step size integrator Loss Coefficient: allows selection of syllabic time constant. Constant

| Bit 15 | Bit 14 | Bit 13 | Syllabic Filter Time Constant (ms),  |
|--------|--------|--------|--------------------------------------|
|        |        |        | Bit Rate in kbps                     |
| 0      | 0      | 0      | 512/(3*Bit Rate)                     |
| 0      | 0      | 1      | 768/(3*Bit Rate)                     |
| 0      | 1      | 0      | 1024/(3*Bit Rate)                    |
| 0      | 1      | 1      | 1536/(3*Bit Rate)                    |
| 1      | 0      | 0      | 2048/(3*Bit Rate)                    |
| 1      | 0      | 1      | 3072/(3*Bit Rate)                    |
|        |        |        | Bluetooth compatible when running at |
|        |        |        | 64kbps.                              |
| 1      | 1      | 0      | 4096/(3*Bit Rate)                    |
| 1      | 1      | 1      | 6144/(3*Bit Rate)                    |

Dynamic Range for Step Size Integrator Step Size Integrator (Bits 12 – 10) Numbers given for maximum and minimum step size are based on 16-bit word length (-32768 to 32767).

| Bit 12 | Bit 11 | Bit 10 | Maximum Step | Minimum Step       |
|--------|--------|--------|--------------|--------------------|
| 0      | 0      | 0      | 10240        | 20                 |
| 0      | 0      | 1      | 10240        | 10                 |
| 0      | 1      | 0      | 5120         | 20                 |
| 0      | 1      | 1      | 5120         | 10                 |
| 1      | 0      | 0      | 2560         | 20                 |
| 1      | 0      | 1      | 2560         | 10                 |
| 1      | 1      | 0      | 1280         | 20                 |
| 1      | 1      | 1      | 1280         | 10                 |
|        |        |        |              | Bluetooth          |
|        |        |        |              | compatible when    |
|        |        |        |              | running at 64kbps. |

Companding Rule (Bits 9 – 8) This is the number of consecutive ones or zeros that must occur for the step size to be adjusted.

| Bit 9 | Bit 8 | Companding Rule           |
|-------|-------|---------------------------|
| 0     | 0     | 3 of 3                    |
| 0     | 1     | 4 of 4                    |
|       |       | Bluetooth compatible when |
|       |       | running at 64kbps.        |
| 1     | 0     | 5 of 5                    |
| 1     | 1     | 6 of 6                    |

Estimator

| Constant                                                                                     |              | Bit 7 Bit 6                                                     |                                                                                                                                                                                                                                        | Bit 5                                                              | Decay Time Constant (ms),                                                                                                                                                                                                                                                                  |
|----------------------------------------------------------------------------------------------|--------------|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (Bits 7 – 5)                                                                                 |              |                                                                 |                                                                                                                                                                                                                                        |                                                                    | Bit Rate in kbps                                                                                                                                                                                                                                                                           |
| ,                                                                                            |              | 0                                                               | 0                                                                                                                                                                                                                                      | 0                                                                  | 16/(3*Bit Rate)                                                                                                                                                                                                                                                                            |
|                                                                                              |              | 0                                                               | 0                                                                                                                                                                                                                                      | 1                                                                  | 24/(3*Bit Rate)                                                                                                                                                                                                                                                                            |
|                                                                                              |              | 0                                                               | 1                                                                                                                                                                                                                                      | 0                                                                  | 32/(3*Bit Rate)                                                                                                                                                                                                                                                                            |
|                                                                                              |              | 0                                                               | 1                                                                                                                                                                                                                                      | 1                                                                  | 48/(3*Bit Rate)                                                                                                                                                                                                                                                                            |
|                                                                                              |              | 1                                                               | 0                                                                                                                                                                                                                                      | 0                                                                  | 64/(3*Bit Rate)                                                                                                                                                                                                                                                                            |
|                                                                                              |              | 1                                                               | 0                                                                                                                                                                                                                                      | 1                                                                  | 96/(3*Bit Rate)                                                                                                                                                                                                                                                                            |
|                                                                                              |              |                                                                 |                                                                                                                                                                                                                                        |                                                                    | Bluetooth compatible when                                                                                                                                                                                                                                                                  |
|                                                                                              |              |                                                                 |                                                                                                                                                                                                                                        |                                                                    | running at 64kbps.                                                                                                                                                                                                                                                                         |
|                                                                                              |              | 1                                                               | 1                                                                                                                                                                                                                                      | 0                                                                  | 128/(3*Bit Rate                                                                                                                                                                                                                                                                            |
|                                                                                              |              | 1                                                               | 1                                                                                                                                                                                                                                      | 1                                                                  | 192/(3*Bit Rate)                                                                                                                                                                                                                                                                           |
| stimator Time                                                                                | Allows selec |                                                                 |                                                                                                                                                                                                                                        |                                                                    | estimator time constant.                                                                                                                                                                                                                                                                   |
|                                                                                              | Allows selec |                                                                 | e second                                                                                                                                                                                                                               | l order e                                                          |                                                                                                                                                                                                                                                                                            |
| Estimator Time<br>Constant                                                                   | Allows selec | tion of the                                                     | Bit                                                                                                                                                                                                                                    | 3                                                                  | estimator time constant.                                                                                                                                                                                                                                                                   |
| stimator Time<br>Constant                                                                    | Allows selec | tion of the                                                     | Bit 0                                                                                                                                                                                                                                  | 3<br>N/A                                                           | estimator time constant.<br>Loss Factor<br>A (selects first order estimator).                                                                                                                                                                                                              |
| Estimator Time<br>Constant                                                                   | Allows selec | tion of the                                                     | Bit 0                                                                                                                                                                                                                                  | 3<br>N/A<br>(Es                                                    | estimator time constant.<br>Loss Factor<br>A (selects first order estimator).<br>stimator Time Constant)/2                                                                                                                                                                                 |
| Estimator Time<br>Constant                                                                   | Allows selec | tion of the<br><b>Bit 4</b><br>0<br>0<br>1                      | Bit 0<br>0<br>1<br>0                                                                                                                                                                                                                   | 3<br>N/A<br>(Es                                                    | estimator time constant.<br>Loss Factor<br>(selects first order estimator).<br>stimator Time Constant)/2<br>stimator Time Constant)/4                                                                                                                                                      |
| Estimator Time<br>Constant                                                                   | Allows selec | tion of the                                                     | Bit 0                                                                                                                                                                                                                                  | 3<br>N/A<br>(Es                                                    | estimator time constant.<br>Loss Factor<br>A (selects first order estimator).<br>stimator Time Constant)/2                                                                                                                                                                                 |
| Second Order<br>Estimator Time<br>Constant<br>(Bits 4 – 3)<br>Zero Selection<br>(Bits 2 – 1) |              | tion of the                                                     | Bit 0<br>1<br>0<br>1                                                                                                                                                                                                                   | 3 N/A<br>(Es<br>(Es                                                | estimator time constant.<br>Loss Factor<br>(selects first order estimator).<br>stimator Time Constant)/2<br>stimator Time Constant)/4                                                                                                                                                      |
| Estimator Time<br>Constant<br>(Bits 4 – 3)                                                   |              | tion of the                                                     | Bit 0<br>1<br>0<br>1                                                                                                                                                                                                                   | 3  <br>(Es<br>(Es<br>(Es                                           | estimator time constant.<br>Loss Factor<br>A (selects first order estimator).<br>stimator Time Constant)/2<br>stimator Time Constant)/4<br>stimator Time Constant)/8                                                                                                                       |
| Estimator Time<br>Constant<br>(Bits 4 – 3)<br>Zero Selection                                 |              | tion of the                                                     | Bit<br>0<br>1<br>0<br>1<br>1<br>0<br>1                                                                                                                                                                                                 | 3  <br>  (Es<br>  (Es<br>  (Es<br>  n is use<br>  Time             | estimator time constant.<br>Loss Factor<br>(selects first order estimator).<br>stimator Time Constant)/2<br>stimator Time Constant)/4<br>stimator Time Constant)/8<br>d, a zero can be inserted to help                                                                                    |
| Estimator Time<br>Constant<br>Bits 4 – 3)<br>Zero Selection                                  |              | tion of the                                                     | Bit :<br>0<br>1<br>0<br>1<br>0<br>1<br>0<br>1<br>0<br>0<br>1<br>0<br>0<br>1<br>0<br>0<br>1<br>0<br>0<br>1<br>0<br>0<br>0<br>0<br>1<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 3  <br>  (Es<br>  (Es<br>  (Es<br>  n is use<br>  Time             | estimator time constant.<br>Loss Factor<br>(selects first order estimator).<br>stimator Time Constant)/2<br>stimator Time Constant)/4<br>stimator Time Constant)/8<br>d, a zero can be inserted to help<br>Constant (ms), Bit Rate in kbp<br>select for first order estimator)             |
| Estimator Time<br>Constant<br>Bits 4 – 3)<br>Zero Selection                                  |              | tion of the<br>Bit 4<br>0<br>1<br>1<br>d order in<br>Bit 2<br>0 | Bit           0           1           0           1           0           1           0           1           0           1           0           1           0                                                                        | 3  <br>  (Es<br>  (Es<br>  (Es<br>  n is use<br>  Time<br>  N/A (s | estimator time constant.<br>Loss Factor<br>A (selects first order estimator).<br>stimator Time Constant)/2<br>stimator Time Constant)/4<br>stimator Time Constant)/8<br>d, a zero can be inserted to help<br>Constant (ms), Bit Rate in kbp<br>select for first order estimator)<br>t Rate |

Allows selection of the estimator integrator time constant.

(Bit 0)

bit to logic 1. When encoding or transcoding from PCM to ADM this bit should always be set to a logic 0 to avoid instability of the ADM feedback loop.

#### **ENCODE VAD THRESHOLD Register (\$E2)**

| Encode VAD    | These bits directly program the threshold of detection for the Voice Activity Detector. |
|---------------|-----------------------------------------------------------------------------------------|
| Threshold     | The number programmed into this register can range from \$0 to \$7FFF (0 to 32767).     |
| (Bits 15 – 0) | The equation for the VAD threshold is:                                                  |
|               | (Signal Detection Threshold), $2^{15}$                                                  |

Register Value =  $\frac{(\text{Signal Detection Threshold}) \cdot 2^{15}}{(\text{DAC Full Scale Reference Voltage})}$ 

#### **ENCODE OFFSET LEVEL Register (\$E3)**

Encode Offset<br/>Input<br/>(Bits 15 - 0)These bits allow for an offset amount to be directly programmed. This offset amount<br/>is useful in trimming out offsets that may occur in the on-chip analog circuitry. The<br/>number format is 2's complement and ranges from \$8000 through \$0000 to \$7FFF<br/>(-32768 to 32767).

The equation for the direct offset value is:

Register Value =  $\frac{(\text{Offset Voltage}) \cdot 2^{18}}{(\text{DAC Full Scale Reference Voltage})}$ 

For normal Encoder operation this register should be loaded with a small positive constant as outlined below.

When offset tracking is enabled (logic 1 in Bit 8 of register \$E0), e.g. while encoding an analog input signal in any format or transcoding PCM to ADM, this register should be loaded with a small positive constant (e.g. in the range [2-16]) to allow automatic DC nulling.

Offset tracking can be suspended by loading this register with 0 while leaving Bit 8 of register \$E0 true. This holds the current offset estimate constant. The offset estimate can be read out via the ENCODE VAD OFFSET LEVEL OUTPUT Register (\$E5).

#### **ENCODE DAC INPUT Register (\$E7)**

Encode DACThis register allows direct access to the encoder DAC input. The number format is<br/>2's complement and ranges from \$8000 through \$0000 to \$7FFF (-32768 to 32767).(Bits 15 - 0)

#### **ENCODE ADM INPUT TEST Register (\$E8)**

Encoder ADMThis register allows ADM bits to be written via C-BUS for transcoding from ADM toInput Test<br/>(Bits 7 - 0)PCM. An interrupt can be enabled to inform a micro-controller when the register

<sup>© 2002</sup> CML Microsystems Plc

#### 5.2.2 Read Only Register Description

#### **PROCESSOR STATUS READ Register (\$80)**

Reading this STATUS register clears any pending IRQ. The PCM and ADM data available and data needed flags (bits 5, 4, 1 and 0 respectively) are cleared when the appropriate CBUS register is read (or written), in order to service the IRQ. The VAD detection flags (bits 6 and 2) are constantly updated to indicate the status of voice activity. Any change in state of either flag will cause an IRQ to be generated.

| Encoder Status<br>(Bits 7 – 4) | Bit 7 is permanently set to logic 0.<br>A logic 1 in Bit 6 indicates Voice Activity is detected.<br>A logic 1 in Bit 5 indicates PCM data is available (or needed when transcoding)<br>A logic 1 in Bit 4 indicates ADM samples are available (or needed when<br>transcoding). |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Decoder Status                 | Bit 3 is permanently set to logic 0.                                                                                                                                                                                                                                           |

(Bits 3 – 0)
 A logic 1 in Bit 2 indicates Voice Activity is detected.
 A logic 1 in Bit 1 indicates PCM data is needed (or available when transcoding).
 A logic 1 in Bit 0 indicates ADM samples are needed (or available when transcoding).

#### DECODE VAD LEVEL OUTPUT READ Register (\$D4)

Decode VADThese bits indicate the average amplitude of the envelope of the audio signal. This<br/>negative 2's complement number can range from \$0 to \$8000 (0 to -32768 and can<br/>be used to assist in calculating an appropriate value to be programmed into the<br/>DECODE VAD THRESHOLD Register (\$D2). The equation for the VAD level<br/>register value is:

Register Value =  $\frac{-1 \cdot (\text{Envelope voltage level}) \cdot 2^{15}}{(\text{DAC Full Scale Reference Voltage})}$ 

#### DECODE VAD OFFSET LEVEL OUTPUT READ Register (\$D5)

Decode OffsetWhen offset tracking is enabled these bits indicate the average amplitude of the<br/>estimated offset. The number format is 2's complement and ranges from \$8000<br/>through \$0000 to \$7FFF (-32768 to 32767).

The equation for the offset value is:

Register Value =  $\frac{\text{(Offset Voltage)} \cdot 2^{18}}{\text{(DAC Full Scale Reference Voltage)}}$ 

Since offset tracking is only applicable to the decoder when transcoding from PCM to ADM, this register essentially contains a value that is 8x the DC component of the input PCM signal.

When offset tracking is disabled these bits indicate the offset level as input by the user in register \$D3.

#### **DECODE LINEAR PCM OUTPUT READ Register (\$D6)**

**Decode Linear PCM Output** (Bits 15 – 0) This register contains the linear PCM equivalent of the ADM or non-linear PCM input signal. The number format is 2's complement and ranges from \$8000 through \$0000 to \$7FFF (-32768 to 32767). Bit 1 of the CODEC INTERRUPT CONTROL Register (\$81) can be set to a logic 1 to enable interrupts informing a micro-controller when the register has been updated. The equation for the PCM register value is:

Register Value =  $\frac{(PCM \text{ voltage}) \cdot 2^{15}}{(DAC \text{ Full Scale Reference Voltage})}$ 

#### **DECODE ADM OUTPUT READ Register (\$DA)**

This register allows ADM bits to be read via C-BUS and is updated every eighth bit. Decode ADM Bit 0 of the CODEC INTERRUPT CONTROL Register (\$81) can be set to a logic 1 to Output enable interrupts informing a micro-controller when the register has been updated. (Bits 7 – 0) When the decoder is set to transcode from PCM to ADM the ADM bits are available via this register.

#### **ENCODE VAD LEVEL OUTPUT READ Register (\$E4)**

Encode VAD These bits indicate the average amplitude of the envelope of the audio signal. This Level Output negative 2's complement number can range from \$0 to \$8000 (0 to -32768) and can be used to assist in calculating an appropriate value to be programmed into the (Bits 15 – 0) ENCODE VAD THRESHOLD Register (\$E2).

The equation for the VAD level register value is:

Register Value =  $\frac{-1 \cdot (\text{Envelope voltage level}) \cdot 2^{15}}{(\text{DAC Full Scale Reference Voltage})}$ 

#### **ENCODE OFFSET LEVEL OUTPUT READ Register (\$E5)**

When offset tracking is enabled these bits indicate the average amplitude of the Encode Offset measured offset. The number format is 2's complement and ranges from \$8000 Level Output through \$0000 to \$7FFF (-32768 to 32767). It can be used as an appropriate value to (Bits 15 - 0) be programmed into the ENCODE OFFSET LEVEL Register (\$E3) if offset tracking will be disabled.

The equation for the offset value is:

Register Value =  $\frac{(\text{Offset Voltage}) \cdot 2^{18}}{(\text{DAC Full Scale Reference Voltage})}$ 

When offset tracking is disabled these bits indicate the offset level as input by the user in register \$E3.

#### ENCODE LINEAR PCM OUTPUT READ Register (\$E6)

This register containes the linear PCM equivalent of the encoded ADM signal. The Encode Linear number format is 2's complement and ranges from \$8000 through \$0000 to \$7FFF **PCM** Output (-32768 to 32767). Bit 5 of the CODEC INTERRUPT CONTROL Register (\$81) can (Bits 15 – 0) be set to a logic 1 to enable interrupts informing a micro-controller when the register has been updated.

The equation for the PCM register value is:

Register Value =  $\frac{(PCM \text{ voltage}) \cdot 2^{--}}{(DAC \text{ Full Scale Reference Voltage})}$ 

© 2002 CML Microsystems Plc

# ENCODE ADM OUTPUT READ Register (\$EA)

**Encode ADM Output Test** (Bits 7 – 0) This register allows Encoder ADM bits to be read via C-BUS and is updated every eighth bit. Bit 4 of the CODEC INTERRUPT CONTROL Register (\$81) can be set to a logic 1 to enable interrupts informing a micro-controller when the register has been updated.

# 6. Application Notes

#### 6.1 C-BUS Operation

#### **C-BUS** Operation

Instructions, status and data are transferred between the CMX649 and the host  $\mu$ C over the C-BUS. The C-BUS protocol complies with the CML C-BUS Hardware Interface specification. Instruction and data transfers to and from the CMX649 consist of an Address/Command (A/C) byte followed by either:

- 1. a further instruction or
- 2. 1 or 2 bytes of data (write) or
- 3. 1 or 2 bytes of status or received data reply (read).

The number of data bytes following an A/C byte is dependent on the value of the A/C byte. The most significant bit of the address or data is sent first. The C-BUS SERIAL\_CLOCK input to the CMX649 originates from the host  $\mu$ C.

| CSN          |            |                        |           |               |          |                 |        |
|--------------|------------|------------------------|-----------|---------------|----------|-----------------|--------|
| SERIAL_CLOCK |            |                        |           |               |          |                 |        |
| CMD_DATA     | 7          | 6 5 4 3 2 1 0          | 76        | 5 4 3 2 1     | 0        | 7 6 5 4 3 2     | 1 0    |
|              | MSE<br>Ade | 3 LSE<br>dress/Command |           | First Data By | /te      | Last Data By    | rte    |
| REPLY DATA   |            | Byte                   | 76<br>MSB |               | <b>0</b> | 765432          | 1 0    |
| [            | Logic le   | vel is not important   |           | Reply Data B  | -        | Last Reply Data | a Byte |

Figure 12 C-BUS Timing Diagram

### 6.2 CODEC Data Interface

Clock generation (internal clock - Master mode) non burst mode Synchronous operation (external clock – Slave mode)

Max Frame length : limited by burst clock to bit rate ratio only Burst\_CLK frequency : 5MHz max Data word length : 8 or 16 bits SYNC Delay : 0 Burst CLKs SYNC Length : 1 – (data word length – 1 ) Burst CLKs Words (slots) per frame : 1 Slot start references (from SYNC)

| Line    | Directio<br>n | Start at<br>Clk | Data Transition<br>Edge | Transmission<br>Order | Data Word Length<br>and Byte Order |
|---------|---------------|-----------------|-------------------------|-----------------------|------------------------------------|
| TX_DATA | Output        | 1               | rise                    | msb first             | 8 or 16 bits (m.s. byte first)     |
| RX_DATA | Input         | 1               | rise                    | msb first             | 8 or 16 bits (m.s. byte first)     |

Tx and Rx clocks are tied together for burst mode. There is only one sync input.



Figure 13 Burst Interface Timing Diagram for Concatenated Byte Transfers

Notes for Figure 13:

- In this example Bit 7 is the most significant bit.
- Once started Rx and Tx data bits are continuously streaming so long as the SYNC pulse continues at the PCM sample rate.
- Configuration options support some variations of this timing diagram, e.g. data word length, without
  affecting the timing shown.
- The TX\_DATA output may be high impedance between burst frames depending on bit 9 of CLK SOURCE CONTROL Register (\$73).

# 6.3 Example CODEC Setups and Application Help

Below are tabulated some applicable settings for the CLOCK DIVIDER CONTROL Register (\$72) .

|          |              | Audio Switched      | Capacitor F | ilter Clock | Settings (cl | ock frequen | cy in kHz) |            |         |
|----------|--------------|---------------------|-------------|-------------|--------------|-------------|------------|------------|---------|
| C        | rystal vs Au | udio Filter Divider | Chart for C | MX649 Yie   | Iding the R  | ecommend    | ed ~256kH  | z SCF Cloc | k       |
|          |              | Divider values      | 4           | 7.75        | 7.875        | 8           | 11         | 15.625     | 23.375  |
|          |              | Register bits       |             |             |              |             |            |            |         |
|          |              | clk ctrl[10:8]      |             |             |              |             |            |            |         |
|          |              |                     | 001         | 010         | 011          | 100         | 101        | 110        | 111     |
| Crystal  | Prescaler    |                     |             |             |              |             |            |            |         |
| Freq MHz | Value        | clk ctrl[12:11]     |             |             |              |             |            |            |         |
| 2.048    | 1            | 00                  | 256.000     |             |              |             |            |            |         |
| 4        | 1            | 00                  |             | 258.065     | 253.968      |             |            |            |         |
| 4.032    | 1            | 00                  |             |             | 256.000      |             |            |            |         |
| 4.096    | 1            | 00                  |             |             |              | 256.000     |            |            |         |
| 8        | 1            | 00                  |             |             |              |             |            | 256.000    |         |
| 8.064    | 2            | 01                  |             |             | 256.000      |             |            |            |         |
| 8.192    | 2            | 01                  |             |             |              | 256.000     |            |            |         |
| 11.2896  | 2            | 01                  |             |             |              |             | 256.582    |            |         |
| 12       | 1            | 00                  |             |             |              |             |            |            | 256.739 |
| 12.096   | 3            | 10                  |             |             | 256.000      |             |            |            |         |
| 12.288   | 3            | 10                  |             |             |              | 256.000     |            |            |         |
| 16       | 2            | 01                  |             |             |              |             |            | 256.000    |         |
| 16.128   | 4            | 11                  |             |             | 256.000      |             |            |            |         |
| 16.384   | 4            | 11                  |             |             |              | 256.000     |            |            |         |

When selecting divider settings to arrive at a desired bit rate from a given crystal frequency, note that some power savings are realized by selecting a lower divider value in conjunction with a higher prescaler value, thus minimizing the frequency of the prescaler output.

|          |                                         | Bit Rat | te (kbps) Se | •           |             |        |        |        |        |
|----------|-----------------------------------------|---------|--------------|-------------|-------------|--------|--------|--------|--------|
|          |                                         |         | Crystal vs   | Divider cha | art for CMX | 649    |        | •      |        |
|          | Divider values                          | 1       | 2            | 2.25        | 2.625       | 3      | 3.125  | 3.375  | 3.5    |
|          | Register bits<br>clk ctrl[5:3]<br>[2:0] |         |              |             |             |        |        |        |        |
| Crystal  |                                         | 000     | 001          | 010         | 011         | 100    | 101    | 110    | 111    |
| Freq MHz | clk ctrl[7:6]                           |         |              |             |             |        |        |        |        |
| 4        | 00                                      | 62.500  | 31.250       | 27.778      | 23.810      | 20.833 | 20.000 | 18.519 | 17.857 |
| 4.032    | 00                                      | 63.000  | 31.500       | 28.000      | 24.000      | 21.000 | 20.160 | 18.667 | 18.000 |
| 4.096    | 00                                      | 64.000  | 32.000       | 28.444      | 24.381      | 21.333 | 20.480 | 18.963 | 18.286 |
| 8        | 00                                      | 125.000 | 62.500       | 55.556      | 47.619      | 41.667 | 40.000 | 37.037 | 35.714 |
| 8.064    | 00                                      | 126.000 | 63.000       | 56.000      | 48.000      | 42.000 | 40.320 | 37.333 | 36.000 |
| 8.192    | 00                                      | 128.000 | 64.000       | 56.889      | 48.762      | 42.667 | 40.960 | 37.926 | 36.571 |

|          | A                                       | pplicable B | it Rate (kb | os) Settings | with Bit R  | ate Prescal | er = 2 |        |        |
|----------|-----------------------------------------|-------------|-------------|--------------|-------------|-------------|--------|--------|--------|
|          |                                         |             | Crystal vs  | Divider cha  | art for CMX | 649         |        |        |        |
|          | Divider values                          | 1           | 2           | 2.25         | 2.625       | 3           | 3.125  | 3.375  | 3.5    |
|          | Register bits<br>clk ctrl[5:3]<br>[2:0] |             |             |              |             |             |        |        |        |
| Crystal  |                                         | 000         | 001         | 010          | 011         | 100         | 101    | 110    | 111    |
| Freq MHz | clk ctrl[7:6]                           |             |             |              |             |             |        |        |        |
| 4        | 01                                      | 31.250      | 15.625      |              |             |             |        |        |        |
| 4.032    | 01                                      | 31.500      | 15.750      |              |             |             |        |        |        |
| 4.096    | 01                                      | 32.000      | 16.000      |              |             |             |        |        |        |
| 8        | 01                                      | 62.500      | 31.250      | 27.778       | 23.810      | 20.833      | 20.000 | 18.519 | 17.857 |
| 8.064    | 01                                      | 63.000      | 31.500      | 28.000       | 24.000      | 21.000      | 20.160 | 18.667 | 18.000 |
| 8.192    | 01                                      | 64.000      | 32.000      | 28.444       | 24.381      | 21.333      | 20.480 | 18.963 | 18.286 |
| 11.2896  | 01                                      | 88.200      | 44.100      | 39.200       | 33.600      | 29.400      | 28.224 | 26.133 | 25.200 |
| 12       | 01                                      | 93.750      | 46.875      | 41.667       | 35.714      | 31.250      | 30.000 | 27.778 | 26.786 |
| 12.096   | 01                                      | 94.500      | 47.250      | 42.000       | 36.000      | 31.500      | 30.240 | 28.000 | 27.000 |
| 12.288   | 01                                      | 96.000      | 48.000      | 42.667       | 36.571      | 32.000      | 30.720 | 28.444 | 27.429 |
| 16       | 01                                      | 125.000     | 62.500      | 55.556       | 47.619      | 41.667      | 40.000 | 37.037 | 35.714 |
| 16.128   | 01                                      | 126.000     | 63.000      | 56.000       | 48.000      | 42.000      | 40.320 | 37.333 | 36.000 |
| 16.384   | 01                                      | 128.000     | 64.000      | 56.889       | 48.762      | 42.667      | 40.960 | 37.926 | 36.571 |

#### ADM Codec

|          | A              | pplicable B | it Rate (kb | os) Settings | s with Bit Ra | ate Prescal | er = 3 |        |        |
|----------|----------------|-------------|-------------|--------------|---------------|-------------|--------|--------|--------|
|          |                |             | Crystal vs  | Divider cha  | art for CMX   | 649         |        |        |        |
|          | Divider values | 1           | 2           | 2.25         | 2.625         | 3           | 3.125  | 3.375  | 3.5    |
|          | Register bits  |             |             |              |               |             |        |        |        |
|          | clk ctrl[5:3]  |             |             |              |               |             |        |        |        |
|          | [2:0]          |             | 004         |              |               | 100         | 4.9.4  |        |        |
| Crystal  |                | 000         | 001         | 010          | 011           | 100         | 101    | 110    | 111    |
| Freq MHz | clk ctrl[7:6]  |             |             |              |               |             |        |        |        |
| 4        | 10             | 20.833      |             |              |               |             |        |        |        |
| 4.032    | 10             | 21.000      |             |              |               |             |        |        |        |
| 4.096    | 10             | 21.333      |             |              |               |             |        |        |        |
| 8        | 10             | 41.667      | 20.833      | 18.519       | 15.873        |             |        |        |        |
| 8.064    | 10             | 42.000      | 21.000      | 18.667       | 16.000        |             |        |        |        |
| 8.192    | 10             | 42.667      | 21.333      | 18.963       | 16.254        |             |        |        |        |
| 11.2896  | 10             | 58.800      | 29.400      | 26.133       | 22.400        | 19.600      | 18.816 | 17.422 | 16.800 |
| 12       | 10             | 62.500      | 31.250      | 27.778       | 23.810        | 20.833      | 20.000 | 18.519 | 17.857 |
| 12.096   | 10             | 63.000      | 31.500      | 28.000       | 24.000        | 21.000      | 20.160 | 18.667 | 18.000 |
| 12.288   | 10             | 64.000      | 32.000      | 28.444       | 24.381        | 21.333      | 20.480 | 18.963 | 18.286 |
| 16       | 10             | 83.333      | 41.667      | 37.037       | 31.746        | 27.778      | 26.667 | 24.691 | 23.810 |
| 16.128   | 10             | 84.000      | 42.000      | 37.333       | 32.000        | 28.000      | 26.880 | 24.889 | 24.000 |
| 16.384   | 10             | 85.333      | 42.667      | 37.926       | 32.508        | 28.444      | 27.307 | 25.284 | 24.381 |

|                     | A                                       | pplicable B |        | os) Settings<br>Divider cha |        | ate Prescal<br>649 | er = 4 |        |        |
|---------------------|-----------------------------------------|-------------|--------|-----------------------------|--------|--------------------|--------|--------|--------|
|                     | Divider values                          | 1           | 2      | 2.25                        | 2.625  | 3                  | 3.125  | 3.375  | 3.5    |
| Crystal             | Register bits<br>clk ctrl[5:3]<br>[2:0] | 000         | 001    | 010                         | 011    | 100                | 101    | 110    | 111    |
| Crystal<br>Freq MHz | clk ctrl[7:6]                           |             |        |                             |        |                    |        |        |        |
| . 4                 | 11                                      | 15.625      |        |                             |        |                    |        |        |        |
| 4.032               | 11                                      | 15.750      |        |                             |        |                    |        |        |        |
| 4.096               | 11                                      | 16.000      |        |                             |        |                    |        |        |        |
| 8                   | 11                                      | 31.250      | 15.625 |                             |        |                    |        |        |        |
| 8.064               | 11                                      | 31.500      | 15.750 |                             |        |                    |        |        |        |
| 8.192               | 11                                      | 32.000      | 16.000 |                             |        |                    |        |        |        |
| 11.2896             | 11                                      | 44.100      | 22.050 | 19.600                      | 16.800 |                    |        |        |        |
| 12                  | 11                                      | 46.875      | 23.438 | 20.833                      | 17.857 | 15.625             | 15.000 |        |        |
| 12.096              | 11                                      | 47.250      | 23.625 | 21.000                      | 18.000 | 15.750             | 15.120 |        |        |
| 12.288              | 11                                      | 48.000      | 24.000 | 21.333                      | 18.286 | 16.000             | 15.360 |        |        |
| 16                  | 11                                      | 62.500      | 31.250 | 27.778                      | 23.810 | 20.833             | 20.000 | 18.519 | 17.857 |
| 16.128              | 11                                      | 63.000      | 31.500 | 28.000                      | 24.000 | 21.000             | 20.160 | 18.667 | 18.000 |
| 16.384              | 11                                      | 64.000      | 32.000 | 28.444                      | 24.381 | 21.333             | 20.480 | 18.963 | 18.286 |

#### 6.3.1 32kbps ADM with clock and data recovery

```
//Initialize device with general reset
\ensuremath{\prime\prime}\xspace This powers down everything excluding the xtal oscillator circuit
$01
//Setup analog section
// $61 00 filters set for 2.9kHz BW (default after reset)
// volume=0dB side_tone=-21dB and on
$62 $BF
// audio_level=0dB
$63 $80
// power_control everything on (lowest current setting)
$64 $55
$65 $55
// codec mode
// default $70 $00 ADM unbuffered (continuous bit serial mode)
// Clock Divider Control
// using 4.096MHz master clock
// filter clock prescale/=4 main divider/=4 => 256kHz SCF clock
// bit clock prescale/=2 encode and decode bit dividers/=1 since constant divider/=64 => 32kbps
$72 $F9 $40
// PLL is running with input from data pad
// internal RX and TX clocks
// RX data input acting as analog input i.e. data filter and data slicer running
$73 $00 $D2
// setup decoder
// decimate by 4
// decode adm input from RX Data
// adm estimator drives output
// vad attack tc=4ms and decay tc=128ms
// normal vad outputs
$D0 $80 $B8
// adm encode feedback from comparator, nulling for improved idle - otherwise as decoder
$E0 $81 $B8
// to enable offset nulling load small positive constant into encoder offset input req
$E3 $00 $04
// adm mode
               syllabic tc=16ms
//
               step size dynamic range 5120/10
11
               companding rule = 4 \text{ of } 4
11
               principle tc=0.33ms
11
               second order tc=0.083ms
               encoder zero tc=0.047ms decoder zero tc=N/A
//
11
               decoder zero at 16kHz i.e. bit_rate/2 enabled
$D1 $6D $51
$E1 $6D $52
// vad thresholds ~20mv
$D2 $02 $00
$E2 $02 $00
// prime idle pattern into CBUS ADM source byte regs
$D8 $AA
$E8 $AA
//Scrambler and Descrambler both on, using polynomial $14 (5 bit LFSR)
$71 $90 $14
// enable encoder and decoder with no IRQs
$81 $88
// note some useful register changes from the above settings
                                                     ($E0 $81 $B9) (requires $E8 $AA above)
// force encoder to output an idle pattern
                                                      ($D0 $88 $B8) (requires $D8 $AA above)
// force decoder to idle via idling its input
// force decoder to mute output via direct PCM out ($D0 $86 $B8) (reset default has $D7 $00 $00)
// turn Scrambler and Descrambler off
                                                      ($71 $00 $00)
```

#### 6.3.2 64kbps burst mode Bluetooth CVSD

```
//Initialize device with general reset
\ensuremath{\prime\prime}\xspace This powers down everything excluding the xtal oscillator circuit
$01
//Setup analog section
// $61 00 filters set for 2.9kHz BW (default after reset)
// volume=0dB side_tone=-21dB and on
$62 $BF
// audio_level=0dB
$63 $80
// power_control everything on (lowest current setting)
$64 $55
$65 $55
// codec mode ADM buffered (burst bytes at 1/8 bit rate mode)
$70 $01
// Clock Divider Control
// with 4.096MHz master clock
// filter clock prescale/=4 main divider/=4 => 256kHz SCF clock
// bit clock prescale/=1 main divider/=1 since constant divider/=64 always => 64kHz bit clocks
$72 $F9 $00
// PLL is not running
// internal RX and TX bit clocks both from RX bit clock
// RX data input acting as digital input for burst mode
$73 $00 $70
// setup decoder
// decimate by 9
// decode adm input from RX Data
// adm estimator drives output
// decode vad driven by adm bits at bit rate
$D0 $00 $02
// adm encode feedback from comparator, nulling for improved idle - otherwise as decoder
$E0 $01 $02
// to enable offset nulling load small positive constant into encoder offset input reg
$E3 $00 $04
// adm mode BT CVSD algorithm
11
       syllabic tc=16ms
//
       step size dynamic range 1280/10
//
       companding rule = 4 \text{ of } 4
11
       principle tc=0.5ms
11
       second order tc=N/A
//
       zero tc=N/A
11
       zero at bit_rate/2 disabled
$D1 $BD $A0
$E1 $BD $A0
// prime idle pattern into CBUS ADM source byte regs
SD8 SAA
$E8 $AA
// enable encoder and decoder with no IRQs
$81 $88
// Alternative settings for PCM format using second order ADM algorithm
       syllabic tc=16ms
11
11
       step size dynamic range 5120/10
11
       companding rule = 5 \text{ of } 5
11
       principle tc=0.5ms
       second order tc=0.0625ms
11
11
       predictor zero tc=0.0234ms for encoder
11
       zero at bit_rate/2 enabled for decoder
//$D1 $AE $A1
//$E1 $AE $BA
// codec mode 2=linear PCM buffered (3=uLaw 4=Alaw)
//$70 $02
\ensuremath{\prime\prime}\xspace decoder flow for input PCM plus transcode to ADM with offset null and output via VAD output.
//$D0 $57 $02
```

//\$D3 \$00 \$04

# 7. Performance Specification

#### 7.1 Electrical Performance

### 7.1.1 Absolute Maximum Ratings

Exceeding these maximum ratings can result in damage to the device.

|                                                                 | Min. | Max.                  | Units |
|-----------------------------------------------------------------|------|-----------------------|-------|
| Supply (V <sub>DD</sub> - V <sub>SS</sub> )                     | -0.3 | 7.0                   | V     |
| Voltage on any pin to V <sub>SS</sub>                           | -0.3 | V <sub>DD</sub> + 0.3 | V     |
| Current into or out of V <sub>DD</sub> and V <sub>SS</sub> pins | -30  | +30                   | mA    |
| Current into or out of any other pin                            | -20  | +20                   | mA    |

| E3 and D3 Package                                   | Min. | Max. | Units |
|-----------------------------------------------------|------|------|-------|
| E3 Total Allowable Power Dissipation at Tamb = 25°C | _    | 300  | mW    |
| Derating above 25°C                                 | _    | 5.0  | mW/°C |
| D3 Total Allowable Power Dissipation at Tamb = 25°C | _    | 800  | mW    |
| Derating above 25°C                                 | _    | 13   | mW/°C |
| Storage Temperature                                 | -55  | +125 | °C    |
| Operating Temperature                               | -40  | +85  | °C    |

## 7.1.2 Operating Limits

Correct operation of the device outside these limits is not implied.

|                                             | Notes | Min. | Max. | Units |
|---------------------------------------------|-------|------|------|-------|
| Supply (V <sub>DD</sub> - V <sub>SS</sub> ) |       | 2.7  | 5.5  | V     |
| Operating Temperature                       |       | -40  | +85  | °C    |
| Xtal Frequency                              |       | 4.0  | 16.0 | MHz   |

### 7.1.3 Operating Characteristics

The following conditions are assumed unless otherwise specified:  $V_{DD} = 2.7V$  to 5.5V at  $T_{AMB} = -40$  to +85°C, Audio Test Frequency = 820Hz, Xtal/Clock  $f_0 = 4.096$ MHz, Data Rate = 32kbps, Audio reference level (0 dBm0) = 489mV<sub>RMS</sub>.

|                                              | N 4         |               | -    |               |       |
|----------------------------------------------|-------------|---------------|------|---------------|-------|
|                                              | Notes       | Min.          | Тур. | Max.          | Units |
| DC Parameters                                |             |               |      |               |       |
| $I_{DD}$ (powersaved) at $V_{DD} = 3.0V$     | 1           | -             | 1.0  | 10.0          | μA    |
| $I_{DD}$ (powersaved) at $V_{DD} = 5.0V$     | 1           | -             | 1.0  | 10.0          | μA    |
| $I_{DD}$ (not powersaved) at $V_{DD}$ = 3.0V | 1           | -             | 1.9  | TBD           | mA    |
| $I_{DD}$ (not powersaved) at $V_{DD}$ = 5.0V | 1           | -             | 2.5  | TBD           | mA    |
| Input logic 1                                |             | $70\%V_{DD}$  | _    | -             | V     |
| Input logic 0                                |             | -             | -    | $30\% V_{DD}$ | V     |
| Output logic 1                               |             | $80\% V_{DD}$ | -    | _             | V     |
| Output logic 0                               |             | -             | -    | $20\%V_{DD}$  | V     |
| Logic I/O Pin Input Impedance                |             | 1.0           | -    | -             | MΩ    |
| Logic Input Pins, Pull-up Resistor           |             | 300           | -    | -             | kΩ    |
| Digital Output Impedance                     |             | _             | _    | 4.0           | kΩ    |
| Analog Input Impedance                       |             | _             | 200  | _             | kΩ    |
| Analog Output Impedance                      |             | _             | _    | 200           | Ω     |
| Three State Output Leakage                   |             | _             | ±4   | _             | μA    |
| Insertion Loss                               |             | _             | 0    | -             | dB    |
| Dynamic Values                               |             |               |      |               |       |
| Encoder Analog Signal Input Levels           |             |               |      |               |       |
| $V_{DD} = 3.0 V$                             | 2           | -37           | -    | 4.0           | dB    |
| $V_{DD} = 5.0 V$                             | 2           | -37           | -    | 4.0           | dB    |
| Decoder Analog Signal Output Levels          |             |               |      |               |       |
| $V_{DD} = 3.0 V$                             | 2           | -37           | -    | 4.0           | dB    |
| $V_{DD} = 5.0 V$                             | 2           | -37           | -    | 4.0           | dB    |
| Decoder Passband (nominal)                   |             | -             | 3300 | -             | Hz    |
| Encoder/Decoder (Full Codec)                 |             |               |      |               |       |
| Passband Lowest Corner Frequency             | 3           | 2900          | -    | _             | Hz    |
| Passband Highest Corner Frequency            | 3           | -             | -    | 14000         | Hz    |
| Stopband Lowest Corner Frequency             | 3<br>3<br>3 | 6.0           | -    | -             | kHz   |
| Stopband Highest Corner Frequency            | 3           | _             | -    | 24            | kHz   |
| Stopband Attenuation                         |             | -             | 40   | -             | dB    |
| Passband Gain                                |             | -             | 0    | -             | dB    |
| Passband Ripple                              |             | -1.0          | -    | 1.0           | dB    |
| Output Noise (Input Short Circuit)           | 4           | _             | -    | -69           | dBmOp |
| Perfect Idle Channel Noise (Encode Forced)   | 4           | _             | -    | -72           | dBmOp |
|                                              |             |               |      |               |       |

#### Notes:

1. Not including any current drawn from the device by external circuits.

2. Input and output signal levels are independent of supply voltage.

3. Passband and stopband corner frequencies are programmable. Specified values are at nominal crystal frequencies of 4.096, 8.192, 12.288, or 16.384Mhz with the master clock divider configured for a divide by 1, 2, 3, or 4 respectively. For other crystal frequencies passband and stopband corner frequencies must be scaled accordingly.

4. dBmOp units imply the use of a psophometrically weighted filter that is commonly used in voice communication applications per ITU Recommendation G.223.

7.1.3 (continued) C-BUS Timing Diagram

#### If 2 bytes of data tcsoF ¥ tHIZ 0 0 tcsH ▲ troh ~ ~ 2 2 e ო 4 4 ŝ 5 ø 9 **t**NXT 2 ~ If 1 byte of data IRDS tcsh V tck tHZ 0 0 ~ ~ 2 2 RPLY ო ო SCIK 4 4 = Level not important or undefined ŝ ŝ ശ ശ 7 ~ tLoz 0 tcH tcpH **t**NXT ~ 2 ო tcDs Ŧ 4 tck ŝ tcL ശ ~ Hi - Z tcse 🔺 ¥ CMD CSN 30% V<sub>DD</sub> -CMD 70% V<sub>DD</sub><sup>\_</sup> SCLK RPLY

# Figure 14 C-BUS Timing Diagram

| C-BUS              | Timing (see Figure 14)               | Notes | Min. | Тур. | Max. | Unit |
|--------------------|--------------------------------------|-------|------|------|------|------|
| t <sub>CSE</sub>   | CSN Enable to SClk high time         |       | 100  |      |      | ns   |
| t <sub>CSH</sub>   | Last SClk high to CSN high time      |       | 100  |      |      | ns   |
| t <sub>LOZ</sub>   | SClk low to ReplyData Output Enable  |       | 0.0  |      |      | ns   |
|                    | Time                                 |       |      |      |      |      |
| t <sub>HIZ</sub>   | CSN high to ReplyData high impedance |       |      |      | 1.0  | μs   |
| t <sub>CSOFF</sub> | CSN high time between transactions   |       | 1.0  |      |      | μs   |
| t <sub>NXT</sub>   | Inter-byte time                      |       | 200  |      |      | ns   |
| t <sub>CK</sub>    | SClk cycle time                      |       | 200  |      |      | ns   |
| t <sub>CH</sub>    | SClk high time                       |       | 100  |      |      | ns   |
| t <sub>CL</sub>    | SClk low time                        |       | 100  |      |      | ns   |
| t <sub>CDS</sub>   | Command Data setup time              |       | 75   |      |      | ns   |
| t <sub>CDH</sub>   | Command Data hold time               |       | 25   |      |      | ns   |
| t <sub>RDS</sub>   | Reply Data setup time                |       | 50   |      |      | ns   |
| t <sub>RDH</sub>   | Reply Data hold time                 |       | 0    |      |      | ns   |

- **Notes:** 1. Depending on the command, 1 or 2 bytes of COMMAND DATA are transmitted to the peripheral MSB (Bit 7) first, LSB (Bit 0) last. REPLY DATA is read from the peripheral MSB (Bit 7) first, LSB (Bit 0) last.
  - 2. Data is clocked into the peripheral on the rising SERIAL\_CLOCK edge.
  - 3. Commands are acted upon at the end of each command (rising edge of CSN).
  - 4. To allow for differing μC serial interface formats C-BUS compatible ICs are able to work with SERIAL\_CLOCK pulses starting and ending at either polarity.
  - 5. Maximum 30pF load on IRQN pin and each C-BUS interface line.

These timings are for the latest version of C-BUS, and allow faster transfers than the original C-BUS timings given in CML Publication D/800/Sys/3 July 1994. The CMX649 can be used in conjunction with devices that comply with the slower timings, subject to system throughput constraints.

For codec data interface timing specifications and diagrams please refer to section 6.2.

© 2002 CML Microsystems Plc

#### 7.2 Packaging







Figure 16 20-Lead SOIC Mechanical Outline: Order as part no. CMX649D3

© 2002 CML Microsystems Plc

Handling precautions: This product includes input protection, however, precautions should be taken to prevent device damage from electro-static discharge. CML does not assume any responsibility for the use of any circuitry described. No IPR or circuit patent licences are implied. CML reserves the right at any time without notice to change the said circuitry and this product specification. CML has a policy of testing every product shipped using calibrated test equipment to ensure compliance with this product specification. Specific testing of all circuit parameters is not necessarily performed.



Oval Park - Langford - Maldon - Essex - CM9 6WG - England.

Tel: +44 (0)1621 875500 Fax: +44 (0)1621 875600 Sales: sales@cmlmicro.com Technical Support: techsupport@cmlmicro.com

# www.cmlmicro.com



4800 Bethania Station Road -Winston-Salem - NC 27105 - USA. Tel: +1 336 744 5050, 800 638 5577 Fax: +1 336 744 5054 Sales: us.sales@cmlmicro.com Technical Support: us.techsupport@cmlmicro.com



No 2 Kallang Pudding Road - 09 to 05/06 Mactech Industrial Building -Singapore 349307 Tel: +65 7450426 Fax: +65 7452917 Sales: sg.sales@cmlmicro.com Technical Support: sg.techsupport@cmlmicro.com

# 射频和天线设计培训课程推荐

易迪拓培训(www.edatop.com)由数名来自于研发第一线的资深工程师发起成立,致力并专注于微 波、射频、天线设计研发人才的培养;我们于 2006 年整合合并微波 EDA 网(www.mweda.com),现 已发展成为国内最大的微波射频和天线设计人才培养基地,成功推出多套微波射频以及天线设计经典 培训课程和 ADS、HFSS 等专业软件使用培训课程,广受客户好评;并先后与人民邮电出版社、电子 工业出版社合作出版了多本专业图书,帮助数万名工程师提升了专业技术能力。客户遍布中兴通讯、 研通高频、埃威航电、国人通信等多家国内知名公司,以及台湾工业技术研究院、永业科技、全一电 子等多家台湾地区企业。

易迪拓培训课程列表: http://www.edatop.com/peixun/rfe/129.html



### 射频工程师养成培训课程套装

该套装精选了射频专业基础培训课程、射频仿真设计培训课程和射频电 路测量培训课程三个类别共 30 门视频培训课程和 3 本图书教材; 旨在 引领学员全面学习一个射频工程师需要熟悉、理解和掌握的专业知识和 研发设计能力。通过套装的学习,能够让学员完全达到和胜任一个合格 的射频工程师的要求…

课程网址: http://www.edatop.com/peixun/rfe/110.html

### ADS 学习培训课程套装

该套装是迄今国内最全面、最权威的 ADS 培训教程,共包含 10 门 ADS 学习培训课程。课程是由具有多年 ADS 使用经验的微波射频与通信系 统设计领域资深专家讲解,并多结合设计实例,由浅入深、详细而又 全面地讲解了 ADS 在微波射频电路设计、通信系统设计和电磁仿真设 计方面的内容。能让您在最短的时间内学会使用 ADS,迅速提升个人技 术能力,把 ADS 真正应用到实际研发工作中去,成为 ADS 设计专家...



课程网址: http://www.edatop.com/peixun/ads/13.html



# HFSS 学习培训课程套装

该套课程套装包含了本站全部 HFSS 培训课程,是迄今国内最全面、最 专业的 HFSS 培训教程套装,可以帮助您从零开始,全面深入学习 HFSS 的各项功能和在多个方面的工程应用。购买套装,更可超值赠送 3 个月 免费学习答疑,随时解答您学习过程中遇到的棘手问题,让您的 HFSS 学习更加轻松顺畅…

课程网址: http://www.edatop.com/peixun/hfss/11.html

# CST 学习培训课程套装

该培训套装由易迪拓培训联合微波 EDA 网共同推出,是最全面、系统、 专业的 CST 微波工作室培训课程套装,所有课程都由经验丰富的专家授 课,视频教学,可以帮助您从零开始,全面系统地学习 CST 微波工作的 各项功能及其在微波射频、天线设计等领域的设计应用。且购买该套装, 还可超值赠送 3 个月免费学习答疑…



课程网址: http://www.edatop.com/peixun/cst/24.html



### HFSS 天线设计培训课程套装

套装包含 6 门视频课程和 1 本图书,课程从基础讲起,内容由浅入深, 理论介绍和实际操作讲解相结合,全面系统的讲解了 HFSS 天线设计的 全过程。是国内最全面、最专业的 HFSS 天线设计课程,可以帮助您快 速学习掌握如何使用 HFSS 设计天线,让天线设计不再难…

课程网址: http://www.edatop.com/peixun/hfss/122.html

## 13.56MHz NFC/RFID 线圈天线设计培训课程套装

套装包含 4 门视频培训课程,培训将 13.56MHz 线圈天线设计原理和仿 真设计实践相结合,全面系统地讲解了 13.56MHz 线圈天线的工作原理、 设计方法、设计考量以及使用 HFSS 和 CST 仿真分析线圈天线的具体 操作,同时还介绍了 13.56MHz 线圈天线匹配电路的设计和调试。通过 该套课程的学习,可以帮助您快速学习掌握 13.56MHz 线圈天线及其匹 配电路的原理、设计和调试…



详情浏览: http://www.edatop.com/peixun/antenna/116.html

#### 我们的课程优势:

- ※ 成立于 2004 年, 10 多年丰富的行业经验,
- ※ 一直致力并专注于微波射频和天线设计工程师的培养,更了解该行业对人才的要求
- ※ 经验丰富的一线资深工程师讲授,结合实际工程案例,直观、实用、易学

# 联系我们:

- ※ 易迪拓培训官网: http://www.edatop.com
- ※ 微波 EDA 网: http://www.mweda.com
- ※ 官方淘宝店: http://shop36920890.taobao.com

专注于微波、射频、大线设计人才的培养 **房迪拓培训** 官方网址: http://www.edatop.com

淘宝网店:http://shop36920890.taobao.cor