# DATA BULLETIN

**CMX989** 

CDPD MAC and DATA PUMP Processor

#### ADVANCE INFORMATION

## **Features**

- Reed-Solomon Encoder, Decoder and Error Correction
- MAC and Physical Layer Functions:
   Minimize Host µController Burden and Power
- Tx and Rx Byte-Wide CDPD Frame FIFOs
- Encapsulates/De-Encapsulates CDPD Frames to/from Over-Air Baseband Signals
- Parallel Bus Hardware Interface to Host CPU
- 2.7V to 5.5V Supply, 28-Pin TSSOP Package

# **Applications**

- CDPD (Cellular Digital Packet Data)
   Terminals
- PCMCIA/PC-Card Wireless Modem Modules
- Wireless Internet Terminals
- Portable and Mobile Wireless Data Terminals
- Line Power/Battery Applications
- 19.2kbps (BT = 0.5) Full Duplex GMSK Data Modems



The highly integrated CMX989 CDPD MAC and Data Pump Processor integrates complex CDPD MAC and physical layer functions to serve as a core engine for high performance, low power CDPD terminal designs. MAC layer functions decouple the host CPU from the CDPD airlink to simplify and reduce CDPD protocol stack programming, free CPU capacity for applications, eliminate interface components, and allow CPU sleep time for power savings. Physical layer functions mate MAC layer to baseband radio signals with minimal host involvement. MAC and physical layer functions are intelligently coupled to meet airlink timing requirements. For example: Tx emissions automatically start in synchronization with Forward Channel busy/idle status. The Rx CDPD frame FIFO is automatically managed to wait for valid synchronization to occur when first started and after lost signal recovery.

The radio interface supports simple, low cost, VCO-based RF modulators and discriminator-based receivers. Independent, programmable gain Tx outputs are provided for software trimming and balancing of modulating signals.

The host CPU interface is FIFO based and organized in CDPD frames, to provide a simple programming interface with low service latency requirements. Over-the-air frames are automatically encapsulated and deencapsulated and include complete Reed-Solomon encoding, decoding and error correction, color code insertion and related functions. Device status bits are accessible and may be individually configured to interrupt the host via the parallel hardware interface. The CMX989 operates from a 2.7V to 5.5V supply over 40 to 85°C and comes in a 28-pin TSSOP package (CMX989E1)

Section

Dago

# **CONTENTS**

| 00 | otion |          | <u> </u>                                                                            | uge  |
|----|-------|----------|-------------------------------------------------------------------------------------|------|
| 1. | Blo   | ck Dia   | gram                                                                                | 3    |
| 2. | Sig   | nal Lis  | st                                                                                  | 4    |
| 3. | Ext   | ernal (  | Components                                                                          | 5    |
|    |       |          | ·<br>Description                                                                    |      |
|    | 4.1   |          | ples of Operation                                                                   |      |
|    | 4.2   |          | led Function List                                                                   |      |
|    |       | 4.2.1    | Separate 141-byte Tx and Rx data buffers, organized as byte-wide CDPD frame FIFOs . |      |
|    |       | 4.2.2    | Encapsulates/de-encapsulates CDPD frames to/from over-air signal systems            |      |
|    |       | 4.2.3    | 19.2kbps (BT = 0.5) GMSK modem data pump                                            |      |
|    | 4.3   | Softw    | are Description                                                                     |      |
|    |       | 4.3.1    | Write Only Registers                                                                |      |
|    |       | 4.3.2    | Read Only Registers                                                                 |      |
|    |       | 4.3.3    | Write Only Register Description                                                     | 10   |
|    |       | 4.3.4    | Read Only Register Description                                                      | 14   |
| 5. | App   | olicatio | on Notes                                                                            | . 18 |
|    | 5.1   | Opera    | ation Sequence                                                                      | 18   |
|    |       | 5.1.1    | Power Up                                                                            |      |
|    |       | 5.1.2    | Acquisition of a CDPD channel                                                       | 18   |
|    |       | 5.1.3    | Receive                                                                             | 18   |
|    |       | 5.1.4    | Transmit                                                                            | 19   |
| 6. | Per   | forma    | nce Specification                                                                   | . 20 |
|    | 6.1   | Electi   | rical Performance                                                                   | 20   |
|    |       | 6.1.1    | Absolute Maximum Ratings                                                            | 20   |
|    |       | 6.1.2    | Operating Limits                                                                    | 20   |
|    |       | 6.1.3    | Operating Characteristics                                                           | 21   |
|    |       | 6.1.4    | Timing Diagrams                                                                     | 22   |
|    | 6.2   | Packa    | aging                                                                               | 24   |

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

MX-COM, Inc. reserves the right to change specifications at any time and without notice.

# 1. Block Diagram



Figure 1: Block Diagram

# 2. Signal List

| Package<br>E1 | E1              |       | Description                                                                                                                                                                                            |  |
|---------------|-----------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Pin No.       | Name            | Type  |                                                                                                                                                                                                        |  |
| 1             | XTALN           | O/P   | The output of the on-chip oscillator                                                                                                                                                                   |  |
| 2             | XTAL/CLOCK      | I/P   | The input to the on-chip oscillator, for external Xtal circuit or clock                                                                                                                                |  |
| 3             | IRQN            |       | A 'wire-ORable' output for connection to the host μController's Interrupt Request input. This output has a low impedance pull down to V <sub>SS</sub> when active and is high impedance when inactive. |  |
| 4             | D7              | BI    |                                                                                                                                                                                                        |  |
| 5             | D6              | BI    |                                                                                                                                                                                                        |  |
| 6             | D5              | BI    |                                                                                                                                                                                                        |  |
| 7             | D4              | BI    | O hit hi directional 2 atata (Controller interfere data lines                                                                                                                                          |  |
| 8             | D3              | BI    | 8-bit bi-directional 3-state µController interface data lines                                                                                                                                          |  |
| 9             | D2              | BI    |                                                                                                                                                                                                        |  |
| 10            | D1              | BI    |                                                                                                                                                                                                        |  |
| 11            | D0              | BI    |                                                                                                                                                                                                        |  |
| 12            | RDN             | I/P   | Read. An active low logic level input used to control the reading of data from the device into the host µController.                                                                                   |  |
| 13            | WRN             | I/P   | Write. An active low logic level input used to control the writing of data into the device from the host µController.                                                                                  |  |
| 14            | V <sub>SS</sub> | Power | The negative supply rail (ground).                                                                                                                                                                     |  |
| 15            | DOC 2           | O/P   | Connections to the Rx level measurement. circuitry. A capacitor                                                                                                                                        |  |
| 16            | DOC 1           | O/P   | should be connected from each pin to V <sub>SS</sub> .                                                                                                                                                 |  |
| 17            | $V_{BIAS}$      | O/P   | A bias line for the internal circuitry, held at $\frac{1}{2}$ V <sub>DD</sub> . This pin must be decoupled to V <sub>SS</sub> by a capacitor mounted close to the device pins.                         |  |
| 18            | RXFB            | O/P   | The output of the Rx input amplifier and the input to the Rx filter.                                                                                                                                   |  |
| 19            | RXIN            | I/P   | The input to the Rx input amplifier.                                                                                                                                                                   |  |
| 20            | N/C             |       | No internal connection, do not use.                                                                                                                                                                    |  |
| 21            | TXOP2           | O/P   | Two-point modulator signal output from the device. TXOP2 is in-                                                                                                                                        |  |
| 22            | TXOP1           | O/P   | phase with TXOP1.                                                                                                                                                                                      |  |
| 23            | TXRFEN          | O/P   | Tx RF enable. Control line to enable an external RF power amplifier stage. This signal is also available via the parallel µController interface.                                                       |  |
| 24            | A2              | I/P   |                                                                                                                                                                                                        |  |
| 25            | A1              | I/P   | Three logic level register select inputs.                                                                                                                                                              |  |
| 26            | A0              | I/P   |                                                                                                                                                                                                        |  |
| 27            | CSN             | I/P   | Chip Select. An active low logic level input to the device, used to enable a data read or write operation.                                                                                             |  |
| 28            | $V_{DD}$        | Power | The positive supply rail. Levels and voltages are dependent upon this supply. This pin should be decoupled to $V_{\rm SS}$ by a capacitor.                                                             |  |

### Notes:

I/P = InputO/P = Output

BI = Bidirectional 3-state Input/Output

NC = No Connection

# 3. External Components



Figure 2: Recommended External Components

#### 3.1 Typical Values:

| R1 | 1ΜΩ        | ± 5%               |
|----|------------|--------------------|
| R2 | Note 1     | ± 10%              |
| R3 | 100kΩ      | ± 10%              |
| R4 | 100kΩ      | ± 10%              |
| X1 | 4.9152 MHz | (ref. Section 6.1) |
| C1 | 0.1µF      | ± 20%              |
| C2 | 33pF       | ± 20%              |

| C3 | 33pF  | ± 20% |
|----|-------|-------|
| C4 | 0.1µF | ± 20% |
| C5 | 100pF | ± 20% |
| C6 | 6.8nF | ± 20% |
| C7 | 6.8nF | ± 20% |
| C8 | 0.1µF | ± 20% |

### Notes:

1. R2, R3, C4 and C5 form the gain components for the Rx INPUT. R2 should be chosen as required by the signal input level, using the following formula:

$$Gain = -R3/R2$$

2. Connections labeled 'N/C': No internal connection, do not use.

To achieve good noise performance it is very important to decouple  $V_{DD}$  and  $V_{BIAS}$  and to protect the receive path from extraneous in-band signals. It is recommended that the printed circuit board is laid out with a ground plane in the CMX989 area to provide a low impedance connection between the  $V_{SS}$  pin and the  $V_{DD}$  and  $V_{BIAS}$  decoupling capacitors. It is also important to provide a low impedance connection between the Xtal capacitors (C1 and C2) and the ground plane.

#### 4. **General Description**

This device performs the data encapsulation and synchronization functions of the Medium Access Control (MAC) layer part of the CDPD specification, as well as the generation of baseband signals in the physical layer, all of which are specifically for the Mobile End Station (M-ES). For details of the system requirements and telegram formats, the user is referred to "Cellular Digital Packet Data System Specification" (Release 1.1). Volumes 1 to 5, currently available from:

CDPD Industry Input Coordinator Cellular Digital Packet Data System Specification 650 Town Center Drive, Suite 820 Costa Mesa, CA 92626 United States of America

#### 4.1 **Principles of Operation**

The CMX989 functions (as shown in the block diagram of Figure 1) may be accessed and/or controlled via memory mapped 8-bit registers connected to the host µController parallel bus interface. Write registers allow the device to be set up, controlled and used for transmission of data. Read registers allow received data to be read and the status of the CMX989 to be monitored. There are several registers which can be used to assist end-product manufacture and test and related system test.

It is assumed that many applications will be assisted by the use of interrupt routines, so various functions within the device will cause a hardware interrupt, e.g.: when received data is available to be read or space is available to write data for transmission. Each hardware interrupt source may be individually disabled (masked) or enabled. The interrupt pin (IRQN) is reset high by a read of either IRQ FLAGS or IRQ FLAGS 2 registers and the bits read from these registers and the STATUS register reflect the status of the CMX989 at the time the read is performed. The IRQ FLAGS, IRQ FLAGS2 and STATUS registers can be polled (without the use of a hardware interrupt routine call) if this is preferred.

For reference, the structures of the Reverse and Forward Channel transmissions are shown in Figure 3 and Figure 4.



Figure 3: Reverse Channel Transmission Structure



Figure 4: Forward Channel Transmission Structure

#### 4.2 **Detailed Function List**

#### 4.2.1 Separate 141-byte Tx and Rx data buffers, organized as byte-wide CDPD frame FIFOs

- Large enough to hold an entire maximum length (136-byte) CDPD frame
- Decouples host CPU and CDPD airlink to provide opportunities for CPU powersave and relaxed service routine timing requirements
- Rx management automatically flushes erroneous frames and resynchronizes Rx buffer on valid frame synchronization
- Empty/full status
- Tx frames are written byte-by-byte style and separated from subsequent frames by writing to an end of frame marker
- Rx frames are read byte-by-byte with each frame boundary indicated by an IRQ and related status
- Read and write status/IRQ handshake paces each byte transferred to and from FIFOs

#### 4.2.2 Encapsulates/de-encapsulates CDPD frames to/from over-air signal systems

- Completed Reed-Solomon block encode and decode with automated 'fill' function for partially filled Tx blocks
- Color Code automatically extracted from Rx stream and inserted into Tx stream
- Pseudo-random number scrambling
- Status flags available for reading or to IRQ on: number of errors corrected in Rx Reed-Solomon block. number errors in forward sync word, Rx busy/idle, Rx Color Code, MDBS decode, etc.

### 4.2.3 19.2kbps (BT = 0.5) GMSK modem data pump

- Discriminator Rx interface
- Rx frame synchronization recognizer triggers internal 'upper layer' processing
- Intelligent Tx emission triggering:
  - · Tx emission start is synchronized to Rx Busy/Idle flag timing
  - Tx FIFO may be loaded before issuing an emission request or emission request may be issued first and remains pending until Tx FIFO is loaded with enough data to generate a Reed-Solomon block
  - Host µController and TXRFEN signals available to enable ramp-up and ramp-down control
    of external RF power amplifier stage
- Dual, independent gain controlled Tx outputs for low frequency response transmit VCO architecture

©2001 MX-COM, Inc www.mxcom.com Tel: 800 638 5577 336 744 5050 Fax: 336 744 5054 Doc. # 20480231.001 4800 Bethania Station Road, Winston-Salem, NC 27105-1201 USA All trademarks and service marks are held by their respective companies.

# 4.3 Software Description

# 4.3.1 Write Only Registers

| Regis | Register Address |    | Register Name    |                         | Function   |         |                  |        |                                             |          |          |
|-------|------------------|----|------------------|-------------------------|------------|---------|------------------|--------|---------------------------------------------|----------|----------|
| A2    | A1               | A0 | Write to Modem   | Bit 7 Bit 6 Bit 5 Bit 4 |            | Bit 3   | Bit 2            | Bit 1  | Bit 0                                       |          |          |
| 0     | 0                | 0  | TX DATA BUFFER   | Bit 7                   | Bit 6      | Bit 5   | Bit 4            | Bit 3  | Bit 2                                       | Bit 1    | Bit 0    |
| 0     | 0                | 1  | TX COLOR CODE    | Bit 7                   | Bit 6      | Bit 5   | Bit 4            | Bit 3  | Bit 2                                       | Bit 1    | Bit 0    |
| 0     | 1                | 0  | TX CONTROL       | 0                       | 0          | 0       | FORCE COLOR CODE | ENDSEQ | ENDFRM                                      | START    | ENABTX   |
| 0     | 1                | 1  | RX CONTROL       | RESET                   | 0          | 0       | ZERO POWER       | ENABRX | $\leftarrow$ SYNC ERROR LIMIT $\rightarrow$ |          | IMIT 	o  |
| 1     | 0                | 0  | RX MODEM CONTROL | 0                       | 0          |         | LEVRES           | AQLEV  | AQBC                                        | PLI      | LBW      |
| 1     | 0                | 1  | TX MODEM CONTROL |                         | ← MOD 2 GA |         | $I \rightarrow$  |        | ← MOD 1                                     | GAIN →   |          |
| 1     | 1                | 0  | IRQ MASK         | SYNCM                   | DECM       | IDLEM   | TXM              | COLORM | ERRM                                        | RXM      | RXFRMM   |
| 1     | 1                | 1  | IRQ MASK 2       | BLKRDYM                 | 0          | RXDEBUG | TXWITHNORX       | TXRFM  | RXPULSE                                     | RX Bit 1 | RX Bit 0 |

# 4.3.2 Read Only Registers

| Register Address Register Name |            |    | Function         |         |                         |       |       |        |       |          |        |
|--------------------------------|------------|----|------------------|---------|-------------------------|-------|-------|--------|-------|----------|--------|
| A2                             | <b>A</b> 1 | A0 | Read from Modem  | Bit 7   | Bit 7 Bit 6 Bit 5 Bit 4 |       |       | Bit 3  | Bit 2 | Bit 1    | Bit 0  |
| 0                              | 0          | 0  | RX DATA BUFFER   | Bit 7   | Bit 6                   | Bit 5 | Bit 4 | Bit 3  | Bit 2 | Bit 1    | Bit 0  |
| 0                              | 0          | 1  | RX COLOR CODE    | Bit 7   | Bit 6                   | Bit 5 | Bit 4 | Bit 3  | Bit 2 | Bit 1    | Bit 0  |
| 0                              | 1          | 0  | STATUS           | SYNC    | DEC                     | IDLE  | 0     | TXRFEN | ERR   | 0        | 0      |
| 0                              | 1          | 1  | IRQ FLAGS        | SYNCF   | DECF                    | IDLEF | TXF   | COLORF | ERRF  | RXF      | RXFRMF |
| 1                              | 0          | 0  | RX ERROR DATA    |         | ← CORRECTED ERRORS →    |       |       | OVER8  | ← S\  | NC ERROR | S →    |
| 1                              | 0          | 1  | IRQ FLAGS 2      | BLKRDYF | ENV                     | EOPN  | 0     | TXRFF  | 0     | 0        | 0      |
| 1                              | 1          | 0  | *** reserved *** | 0       | 0                       | 0     | 0     | 0      | 0     | 0        | 0      |
| 0                              | 1          | 1  | *** reserved *** | 0       | 0                       | 0     | 0     | 0      | 0     | 0        | 0      |

### 4.3.3 Write Only Register Description

### 4.3.3.1 TX DATA BUFFER Register (Hex address \$00)

This is a write only register of the Tx Data Buffer. It should be written in response to a TXF IRQ FLAG being set to "1". Bit 7 is the msb. The interval between TXF interrupts varies from approximately 16µs to 22ms, depending on the position within the internal data processing sequence.

### 4.3.3.2 TX COLOR CODE Register (Hex address \$01)

This is a write only register of the Tx Color Code. This value for the Tx Color Code is used when the FORCE COLOR CODE (Bit 4 of the TX CONTROL register) bit is set to "1". Bit 7 is the msb.

### 4.3.3.3 TX CONTROL Register (Hex address \$02)

| (Bits 7,6 and 5)    | Unused, set to "0"                                                                                                                                                 |  |  |  |  |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| FORCE COLOR<br>CODE | When this bit is "1" the Color Code transmitted in the first block of the Reverse Channel will be the byte defined in the TX COLOR CODE register. When this bit is |  |  |  |  |
| (Bit 4)             | "0" the Color Code transmitted will be the Color Code byte previously received on the Forward Channel and recorded in the RX COLOR CODE read-only register.        |  |  |  |  |
| ENDSEQ              | Write a "1" to this bit when the last byte of the last frame in the sequence has                                                                                   |  |  |  |  |
| (Bit 3)             | loaded.                                                                                                                                                            |  |  |  |  |
| ENDFRM              | At the end of every frame (2-136 bytes) write a "1" to this bit.                                                                                                   |  |  |  |  |
| (Bit 2)             |                                                                                                                                                                    |  |  |  |  |
| START (Bit 1)       | Write a "1" to this bit to start the transmission on the Reverse Channel at the next available slot.                                                               |  |  |  |  |
| ENABTX              | When this bit is "1" the Tx (Reverse Channel) is enabled. When this bit is "0" the Tx                                                                              |  |  |  |  |
| (Bit 0)             | (Reverse Channel) is disabled and enters a powersave condition. In this condition                                                                                  |  |  |  |  |
|                     | the TXOP1 and TXOP2 outputs are at V <sub>BIAS</sub> .                                                                                                             |  |  |  |  |

### 4.3.3.4 RX CONTROL Register (Hex address \$03)

| RESET (Bit 7)                         | Write a "1" followed by a "0" to this bit just after power up to initialize the device into a zero-power and "safe" condition.                                                                                                                                                                                                                                                                              |
|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (Bits 6 and 5)                        | Unused, set to "0".                                                                                                                                                                                                                                                                                                                                                                                         |
| ZERO POWER<br>(Bit 4)                 | When this bit is set to "0" the whole device is disabled and set to minimum power including the crystal oscillator. Allow 20ms for the crystal oscillator to stabilize when coming out of this zero-power state.                                                                                                                                                                                            |
| ENABRX (Bit 3)                        | When this bit is "1" the Rx (Forward Channel) is enabled. When this bit is "0" the Rx (Forward Channel) is disabled and enters a powersave condition.                                                                                                                                                                                                                                                       |
| SYNC ERROR LIMIT<br>(Bits 2, 1 and 0) | This 3-bit number specifies the greatest number of bits that can be in error in the synchronization word. Bit 2 is the msb. If the synchronization word is recognized with less than or equal to this number of errors, the SYNCF bit is set to "1" and the actual number of errors is loaded into SYNC ERRORS (Bits 2, 1 and 0 of the RX ERROR DATA register). The RXDATA in that block is then processed. |

# 4.3.3.5 RX MODEM CONTROL (Hex address \$04)

This register is for test purposes only and should be set to all "0s" for normal operation.

| (Bits 7 and 6)                                                                                                                           | Unused, set to "0"                                                                                                             |        |          |                                                             |                                                                                                                                                                                                                                              |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|--------|----------|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| LEVRES (Bits 5 and 4)                                                                                                                    | These two bits set the response time of the Rx signal amplitude and dc offset measuring circuits according to the table below: |        |          |                                                             |                                                                                                                                                                                                                                              |  |  |
|                                                                                                                                          |                                                                                                                                | B5     | B4       | Setting                                                     | Action                                                                                                                                                                                                                                       |  |  |
|                                                                                                                                          |                                                                                                                                | 0      | 0        | Peak Averaging                                              | Track input signal using bit peak averaging                                                                                                                                                                                                  |  |  |
|                                                                                                                                          |                                                                                                                                | 0      | 1        | Peak Detect                                                 | Track input signal using peak detect                                                                                                                                                                                                         |  |  |
|                                                                                                                                          |                                                                                                                                | 1      | 0        | Lossy Peak Detec                                            | Track input signal using lossy peak detection                                                                                                                                                                                                |  |  |
|                                                                                                                                          |                                                                                                                                | 1      | 1        | Hold                                                        | Keep current values of amplitude and offset                                                                                                                                                                                                  |  |  |
| This setting will be temp                                                                                                                | orarily o                                                                                                                      | verrid | den b    | the automatic se                                            | equencing of an AQLEV command.                                                                                                                                                                                                               |  |  |
| AQLEV                                                                                                                                    |                                                                                                                                |        |          |                                                             | 1" it initiates an automatic sequence designed to                                                                                                                                                                                            |  |  |
| (Bit 3)                                                                                                                                  |                                                                                                                                |        |          |                                                             |                                                                                                                                                                                                                                              |  |  |
|                                                                                                                                          | Setting                                                                                                                        | this I | oit to " | 0" (or changing i                                           | t from "1" to "0") has no effect.                                                                                                                                                                                                            |  |  |
| AQBC (Bit 2)  Whenever the AQBC bit is se achieve bit timing synchronize This involves setting the Phasticircuits to its widest bandwidt |                                                                                                                                |        |          | synchronization v<br>ng the Phase Loc<br>st bandwidth, ther | " it initiates an automatic sequence designed to with the received signal as quickly as possible. I ked Loop of the received bit timing extraction or gradually reducing the bandwidth as timing reaches the 'normal' value set by the PLLBW |  |  |
|                                                                                                                                          | Setting                                                                                                                        | this I | oit to " | 0" (or changing it                                          | from "1" to "0") has not effect.                                                                                                                                                                                                             |  |  |
| PLLBW<br>(Bits 1 and 0)                                                                                                                  |                                                                                                                                | two b  | its set  | , , , , , , , , , , , , , , , , , , , ,                     | the Rx clock extraction PLL circuit according to                                                                                                                                                                                             |  |  |
|                                                                                                                                          |                                                                                                                                | B1     | В0       | PLL Bandwidth                                               | Suggested Use                                                                                                                                                                                                                                |  |  |
|                                                                                                                                          |                                                                                                                                | 0      | 0        | Medium                                                      | Wide tolerance Xtals or long preamble acquisition                                                                                                                                                                                            |  |  |
|                                                                                                                                          |                                                                                                                                | 0      | 1        | Wide                                                        | Quick acquisition                                                                                                                                                                                                                            |  |  |
|                                                                                                                                          |                                                                                                                                | 1      | 0        | Narrow                                                      | ±20ppm or better Xtals                                                                                                                                                                                                                       |  |  |
|                                                                                                                                          |                                                                                                                                | 1      | 1        | Hold                                                        | Signal fades                                                                                                                                                                                                                                 |  |  |
| This setting will be temporarily overridden by the automatic sequencing of an AQBC command.                                              |                                                                                                                                |        |          |                                                             |                                                                                                                                                                                                                                              |  |  |

©2001 MX-COM, Inc www.mxcom.com Tel: 800 638 5577 336 744 5050 Fax: 336 744 5054 Doc. # 20480231.001 4800 Bethania Station Road, Winston-Salem, NC 27105-1201 USA All trademarks and service marks are held by their respective companies.

# 4.3.3.6 TX MODEM CONTROL Register (Hex address \$05)

MOD 2 GAIN (Bits 7, 6, 5 and 4) These bits control the amplitude of the TXOP2 output according to the table below.

| (Bit 7) | (Bit 6) | (Bit 5) | (Bit 4) | GAIN (dB)          |
|---------|---------|---------|---------|--------------------|
| 0       | 0       | 0       | 0       | OFF (o/p at VBIAS) |
| 0       | 0       | 0       | 1       | -5.6               |
| 0       | 0       | 1       | 0       | -5.2               |
| 0       | 0       | 1       | 1       | -4.8               |
| 0       | 1       | 0       | 0       | -4.4               |
| 0       | 1       | 0       | 1       | -4.0               |
| 0       | 1       | 1       | 0       | -3.6               |
| 0       | 1       | 1       | 1       | -3.2               |
| 1       | 0       | 0       | 0       | -2.8               |
| 1       | 0       | 0       | 1       | -2.4               |
| 1       | 0       | 1       | 0       | -2.0               |
| 1       | 0       | 1       | 1       | -1.6               |
| 1       | 1       | 0       | 0       | -1.2               |
| 1       | 1       | 0       | 1       | -0.8               |
| 1       | 1       | 1       | 0       | -0.4               |
| 1       | 1       | 1       | 1       | 0.0                |

MOD 1 GAIN

(Bits 3, 2, 1 and 0)

These bits control the amplitude of the TXOP1 output according to the table below.

| (Bit 3) | (Bit 2) | (Bit 1) | (Bit 0) | GAIN (dB)                       |
|---------|---------|---------|---------|---------------------------------|
| 0       | 0       | 0       | 0       | OFF (o/p at V <sub>BIAS</sub> ) |
| 0       | 0       | 0       | 1       | -5.6                            |
| 0       | 0       | 1       | 0       | -5.2                            |
| 0       | 0       | 1       | 1       | -4.8                            |
| 0       | 1       | 0       | 0       | -4.4                            |
| 0       | 1       | 0       | 1       | -4.0                            |
| 0       | 1       | 1       | 0       | -3.6                            |
| 0       | 1       | 1       | 1       | -3.2                            |
| 1       | 0       | 0       | 0       | -2.8                            |
| 1       | 0       | 0       | 1       | -2.4                            |
| 1       | 0       | 1       | 0       | -2.0                            |
| 1       | 0       | 1       | 1       | -1.6                            |
| 1       | 1       | 0       | 0       | -1.2                            |
| 1       | 1       | 0       | 1       | -0.8                            |
| 1       | 1       | 1       | 0       | -0.4                            |
| 1       | 1       | 1       | 1       | 0.0                             |

# 4.3.3.7 IRQ Mask Register (Hex address \$06)

These bits prevent interrupts from occurring as detailed below:

| SYNCM<br>(Bit 7)  | When this bit is set to "1" the SYNC interrupt will be gated out to the IRQN pin. When this bit is set to "0" the SYNC interrupt will be inhibited. This bit has no effect on the contents of the STATUS register.   |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DECM<br>(Bit 6)   | When this bit is set to "1" the DEC interrupt will be gated out to the IRQN pin. When this bit is set to "0" the DEC interrupt will be inhibited. This bit has no effect on the contents of the STATUS register.     |
| IDLEM<br>(Bit 5)  | When this bit is set to "1" the IDLE interrupt will be gated out to the IRQN pin. When this bit is set to "0" the IDLE interrupt will be inhibited. This bit has no effect on the contents of the STATUS register.   |
| TXM<br>(Bit 4)    | When this bit is set to "1" the TX interrupt will be gated out to the IRQN pin. When this bit is set to "0" the TX interrupt will be inhibited. This bit has no effect on the contents of the STATUS register.       |
| COLORM<br>(Bit 3) | When this bit is set to "1" the COLOR interrupt will be gated out to the IRQN pin. When this bit is set to "0" the COLOR interrupt will be inhibited. This bit has no effect on the contents of the STATUS register. |
| ERRM<br>(Bit 2)   | When this bit is set to "1" the ERR interrupt will be gated out to the IRQN pin. When this bit is set to "0" the ERR interrupt will be inhibited. This bit has no effect on the contents of the STATUS register.     |
| RXM<br>(Bit 1)    | When this bit is set to "1" the RX interrupt will be gated out to the IRQN pin. When this bit is set to "0" the RX interrupt will be inhibited. This bit has no effect on the contents of the STATUS register.       |
| RXFRMM<br>(Bit 0) | When this bit is set to "1" the RXFRM interrupt will be gated out to the IRQN pin. When this bit is set to "0" the RXFRM interrupt will be inhibited. This bit has no effect on the contents of the STATUS register. |

### 4.3.3.8 IRQ MASK 2 Register (Hex address \$07)

This register is the counterpart to IRQ FLAGS 2 register. Apart from TXRFM and possibly BLKRDYM, the bits in this register are mainly for test purposes and should be set to all "0s" for normal operation.

| BLKRDYM<br>(Bit 7)                   | When this bit is set to "1" the BLKRDY interrupt will be gated out to the IRQN pin. When this bit is set to "0" the BLKRDY interrupt will be inhibited. This bit has no effect on the contents of the STATUS register.                                                                                          |                                                                                                                                                                                                                                                                                 |   |                          |  |  |  |  |
|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------------------------|--|--|--|--|
| (Bit 6)                              | Unused, set                                                                                                                                                                                                                                                                                                     | to "0".                                                                                                                                                                                                                                                                         |   |                          |  |  |  |  |
| RXDEBUG<br>(Bit 5)                   | detecting a s<br>normally use                                                                                                                                                                                                                                                                                   | When this bit is "1" the Rx (Forward Channel) will load data every 420 bits, without detecting a sync word. When this bit is "0" the device operates normally. This bit is normally used for debugging only, but could be used in conjunction with bit error rate measurements. |   |                          |  |  |  |  |
| TXWITHNORX<br>(Bit 4)                | (Forward Ch                                                                                                                                                                                                                                                                                                     | When this bit is "1" the Tx (Reverse Channel) will transmit without waiting for the Rx (Forward Channel) to synchronize as required by the CDPD specification (Release 1.1, Part 402, Section 5.3.1, Figure 402-16). When this bit is "0" the device operates normally.         |   |                          |  |  |  |  |
| TXRFM<br>(Bit 3)                     | When this bit is set to "1" the TXRF interrupt will be gated out to the IRQN pin. When this bit is set to "0" the TXRF interrupt will be inhibited. This bit has no effect on the contents of the STATUS register.                                                                                              |                                                                                                                                                                                                                                                                                 |   |                          |  |  |  |  |
| RXPULSE<br>(Bit 2)                   | When the two bits "RX Bit 1" and "RX Bit 0" are set appropriately and this bit has "1" written to it, an internal test sequence will be clocked into the Reed-Solomon decoder and the receiver will output the bits as required by the CDPD specification (Release 1.1, Part 402, Appendix 402-A, Table 402-8). |                                                                                                                                                                                                                                                                                 |   |                          |  |  |  |  |
| RX Bit 1, RX Bit 0<br>(Bits 1 and 0) | These two bits set the internally generated test sequence for the receiver according to the table below:                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                 |   |                          |  |  |  |  |
|                                      | Bit 1 Bit 0 Function                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                 |   |                          |  |  |  |  |
|                                      | 0 0 Normal operation                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                 |   |                          |  |  |  |  |
|                                      |                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                               | 1 | Test sequence 0 errors   |  |  |  |  |
|                                      |                                                                                                                                                                                                                                                                                                                 | 1                                                                                                                                                                                                                                                                               | 0 | 0 Test sequence 8 errors |  |  |  |  |
|                                      | 1 1 Test sequence 9 errors                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                 |   |                          |  |  |  |  |

### 4.3.4 Read Only Register Description

#### 4.3.4.1 RX DATA BUFFER Register (Hex address \$00)

This is a read-only register of the receive data buffer. It should be read in response to an RXF IRQ FLAG being set to "1". Bit 7 is the msb. The interval between RXF interrupts varies from approximately 16µs to 22ms, depending on the position within the internal data processing sequence.

### 4.3.4.2 RX COLOR CODE Register (Hex address \$01)

This is a ready-only register of the Color Code on the Rx (Forward Channel). It is updated every time the SYNCF IRQ FLAG is set to "1". Bit 7 is the msb.

# 4.3.4.3 STATUS Register (Hex address \$02)

This is a read-only register that contains the status of the various functions on the device as described below:

| SYNC<br>(Bit 7)   | This bit is set to "1" if a Forward Channel synchronization word has been received successfully. (See SYNC ERRORS and SYNC ERROR LIMIT). This bit is reset to "0" when the sync word has not been detected for more than 420 bits (i.e. sync lost).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DEC (Bit 6)       | This bit indicates the decode status of the Mobile Data Base Station (MDBS) on the Forward Channel. This bit is set to "1" when the station fails to decode data successfully, and is reset to "0" when the station is successful in decoding data. This bit will only change and be valid if SYNC (Bit 7) is set to "1".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| IDLE<br>(Bit 5)   | This bit indicates the activity of the Mobile Data Base Station (MDBS) on the Forward Channel. This bit is set to "1" when the station is in an IDLE state, and reset to "0" when the station is in a BUSY state. This bit will only change and be valid if SYNC (Bit 7) is set to "1". The value of this bit is not specified if SYNC (Bit 7) is reset to "0". The IDLE bit is derived from a majority decision on the most recently received group of five consecutive busy/idle bits, as in the CDPD specification (Release 1.1, Part 402, Section 4.5, Figure 402-7).  The first block of data received in the Forward Channel will not output any data until the sync word has been found. Once this has been found, the majority decision of the most recent group of busy/idle bits will be output in the STATUS register, and the IDLEF bit will be set to "1" in the IRQ FLAGS register. |
|                   | The next six groups of busy/idle bits generate IDLE bits as they are received and, so long as the sync word remains correct, these successive IDLE bits are output as the groups of busy/idle bits are received.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| (Bit 4)           | Unused, will be set to "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| TXRFEN<br>(Bit 3) | This bit is set to "1" approximately two bits (104µs) before the dotting sequence leaves TXOP1 or TXOP2 outputs and is reset to "0" at the end of transmission from TXOP1 and TXOP2. This signal is also available as a direct output on the TXRFEN pin, where it can be used to enable an external RF power amplifier stage.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| ERR<br>(Bit 2)    | This bit indicates whether the data currently being read out from RX DATA BUFFER has any errors. If this bit is set to "1" there are errors that cannot be corrected and the host µController should discard all data in the present frame as that frame cannot be successfully completed. It will then search and re-synchronize to the next frame flag, before making any more data available. When this bit is set to "0" there are no errors in the block currently being read.  Note: Due to the CMX989's internal buffer, the data currently being read at the CMX989/µController interface may be up to 5 Reed-Solomon blocks older than                                                                                                                                                                                                                                                   |
| (Bits 1 and 0)    | the data currently being received at the CMX989/FM demodulator interface.  Unused, will be set to "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| (Dito I alla 0)   | Olidoca, will be set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

# 4.3.4.4 IRQ FLAGS Register (Hex address \$03)

This is a read-only register that contains flags to indicate the source of an interrupt, as described below:

| SYNCF<br>(Bit 7)  | This bit is set to "1" when the device has decoded the sync word on the Forward Channel. It also is set to "1" if, after detecting sync, it fails to detect it 420 bits later, indicating sync has been lost. The state of the sync can be read from the STATUS register. This bit is reset to "0" after a "read" of the IRQ FLAGS register. When this bit is set to "1" an interrupt may be generated, depending on the state of the IRQ MASK register.                                                                                                            |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DECF<br>(Bit 6)   | This bit is set to "1" when the decode status of the Mobile Data Base Station (MDBS) in the Forward Channel changes state. The decode state can be read from the STATUS register. This bit is reset to "0" after a "read" of the IRQ FLAGS register. When this bit is set to "1" an interrupt may be generated depending on the state of the IRQ MASK register.                                                                                                                                                                                                     |
| IDLEF<br>(Bit 5)  | This bit is set to "1" when the idle status of the Mobile Data Base Station (MDBS) in the Forward Channel changes state. The idle state can be read from the STATUS register. This bit is reset to "0" after a "read" of the IRQ FLAGS register. When this bit is set to "1" an interrupt may be generated depending on the state of the IRQ MASK register.                                                                                                                                                                                                         |
| TXF<br>(Bit 4)    | This bit provides handshaking flow control when writing data bytes to the Tx (Reverse Channel) data buffer. It is set to "1" whenever the buffer is not full and new data can be loaded in to the TX DATA BUFFER register. It is reset to "0" after a "write" to the TX DATA BUFFER register. When this bit is set to "1" an interrupt may be generated depending on the state of the IRQ MASK register. The interval between TXF interrupts varies from approximately 16µs to 22ms, depending on the position within the internal data processing sequence.        |
| COLORF<br>(Bit 3) | This bit is set to "1" when a color code is successfully received on the Forward Channel and placed in the RX COLOR CODE register. It is reset to "0" after a read of the IRQ FLAGS register. When this bit is set to "1" an interrupt may be generated depending on the state of the IRQ MASK register.                                                                                                                                                                                                                                                            |
| ERRF<br>(Bit 2)   | This bit is set to "1" when the ERR status changes. This bit is reset to "0" after a "read" of the IRQ FLAGS register. When this bit is set to "1" an interrupt may be generated depending on the state of the IRQ MASK register.                                                                                                                                                                                                                                                                                                                                   |
| RXF<br>(Bit 1)    | This bit provides handshaking flow control when reading data bytes from the Rx (Forward Channel) data buffer. It is set to "1" whenever the buffer is not empty and data is available to be read from the RX DATA BUFFER register. It is reset to "0" after a "read" of the RX DATA BUFFER register. When this bit is set to "1" an interrupt may be generated depending on the state of the IRQ MASK register. The interval between RXF interrupts varies from approximately 16µs to 22ms, depending on the position within the internal data processing sequence. |
| RXFRMF<br>(Bit 0) | This bit is used when reading the receiver data. It is set to "1" when the byte about to be read from the receiver data buffer is the first byte of a new frame. It is reset to "0" after a "read" of the IRQ FLAGS register. When this bit is set to "1" an interrupt may be generated depending on the state of the IRQ MASK register.                                                                                                                                                                                                                            |

# 4.3.4.5 RX ERROR DATA Register (Hex address \$04)

This is a read-only register that contains receiver performance data.

| CORRECTED<br>ERRORS<br>(Bits 7, 6, 5 and 4) | This 4-bit number indicates the number of Reed-Solomon symbol errors before error correction that are in the most recently received 63-symbol Reed-Solomon block. They are updated every time the SYNCF bit is set in the IRQ FLAGS register. Bit 7 is the msb.                                                                                                                                                          |
|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OVER8<br>(Bit 3)                            | This bit is set to "1" if the most recently received Reed-Solomon block has greater than 8 errors. i.e. the data has too many errors to enable the Reed-Solomon error correction to work. It is updated every time the SYNCF bit is set in the IRQ FLAGS register and is reset to "0" if 8 errors or fewer are encountered.                                                                                              |
| SYNC ERRORS<br>(Bits 2, 1 and 0)            | This 3-bit number indicates the number of errors in the most recently received synchronization word. It is updated whenever the synchronization word is in error less than or equal to the number specified by the SYNC ERROR LIMIT bits of the RX CONTROL register. It also implies the synchronization word has been received successfully and sets the SYNC bit to "1" (See STATUS register above). Bit 2 is the msb. |

Note: These bits all refer to the data most recently received at the Rx input and are NOT necessarily the same as previously received and buffered data which is currently being read by the CMX989's host  $\mu$ Controller.

# 4.3.4.6 IRQ FLAGS 2 Register (Hex address \$05)

Bits 5 and 6 of this register are for test purposes only and their contents should be ignored during normal operation.

| BLKRDYF<br>(Bit 7)    | This is the "Block Ready Flag" and is set to "1" when the receiver decodes the currently received Reed-Solomon block. It is reset to "0" after a read of the IRQ FLAGS 2 register. When this bit is set to "1" an interrupt may be generated depending on the state of the IRQ MASK 2 register.                                                                                                                                                                                                       |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ENV<br>(Bit 6)        | A circuit monitors the DOC voltage levels, which are an indication of the received signal amplitude envelope. If the DOC voltages are more than 6% of $V_{DD}$ apart (0.3V when $V_{DD}$ = 5.0V) then this bit will be set to "1". It is reset to "0" when the DOC voltages are less than 6% of $V_{DD}$ apart.                                                                                                                                                                                       |
|                       | Note: The ENV output will also be triggered when receiving high levels of noise or other in-band signals.                                                                                                                                                                                                                                                                                                                                                                                             |
| EOPN<br>(Bit 5)       | A circuit monitors the receive waveform. If the received signal remains close to the centre of the received data levels (as stored on the DOC capacitors) for more than approximately 3 bit-times then this bit will be set to "1". If the input signal level goes towards either of the DOC capacitor values this bit will be set to "0".  Note: When a data signal is not being received and the DOC capacitors have discharged or if there are high levels of noise then the value of the EOPN bit |
| (D) (A)               | will be unreliable and so it should be used in conjunction with the ENV bit.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| (Bit 4) TXRFF (Bit 3) | Unused, will be set to "0".  This bit is set to "1" when the Tx RF enable bit (TXRFEN) changes state. This bit is reset to "0" after a "read" of the IRQ FLAGS 2 register. When this bit is set to "1" an                                                                                                                                                                                                                                                                                             |
| ,                     | interrupt may be generated depending on the state of the IRQ MASK 2 register.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| (Bits 2, 1 and 0)     | Unused, will be set to "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

# 5. Application Notes

#### 5.1 Operation Sequence

### 5.1.1 Power Up

To initialize the registers to a safe, known state, RESET (Bit 7 of the RX CONTROL register) should be set to "1", then set to "0", then set to "1", and then to "0" again. This puts the device into the zero-power mode with all functions disabled and resets the device.

### 5.1.2 Acquisition of a CDPD channel

The first thing that the device will be required to do is to search for a CDPD Forward Channel data stream.

The sequence below describes how to do this:

- 1. The likely presence of an Rx data stream (CDPD Forward Channel modulation) may be indicated by the RSSI in a process which is separate from, and external to, the CMX989. Simultaneously, the CMX989 can search for a CDPD Forward Channel synchronization word, as follows:
- 2. Write "1" to ZERO POWER and "1" to ENABRX (Bits 4 and 3 of the RX CONTROL register) to enable the crystal and the receiver. Also set the SYNC ERROR LIMIT (Bits 2, 1 and 0 of the RX CONTROL register) to a binary value from 0 to 5, depending on the number of errors that can be tolerated in the Forward Channel synchronization word.
- 3. Write "1" to SYNCM (Bit 7 of the IRQ MASK register) to enable the detection on interrupt of the forward synchronization word.
- 4. The device will now interrupt when a CDPD Forward Channel synchronization word has been detected. An additional local timer could be set to give a timeout after which the host μController could initiate a change of RF channel to search elsewhere for a CDPD Forward Channel stream.
- 5. When the interrupt occurs, read the IRQ FLAGS register to confirm and clear the SYNCF flag and read the STATUS register to check the SYNC bit. The SYNCM bit can be left set to "1" as further interrupts would indicate that the device has lost the forward synchronization. Appropriate action should then be taken. However the user may wish to disable it, as the CDPD Reed-Solomon decoder has the ability to indicate when the data has lost its integrity. Loss of the channel or corruption of the data is indicated by errors in the synchronization word and/or errors in a Reed-Solomon decoded data block (RX ERROR DATA register).
- 6. The RX ERROR DATA register may also be used in the initial acquisition of the channel as detailed in the CDPD specification (Release 1.1, Part 402, Section 3.2.3).

#### 5.1.3 Receive

Having found a CDPD Forward Channel stream, the data can be read using the following sequence:

- 1. Write a "1" to ERRM, a "1" to RXM and a "1" to RXFRMM (Bits 2, 1 and 0 of the IRQ MASK register), to enable the Rx Error IRQ, the Rx Data IRQ and the Rx Frame Flag IRQ respectively.
- 2. An RXFRMF interrupt (Bit 0 of the IRQ FLAGS register) indicates that the next byte to be read from the RX DATA BUFFER register is the first byte of a new frame. The contents of the RX DATA BUFFER register prior to the first RXFRMF interrupt event after ENABRX is set to "1" are automatically discarded when the first RXFRMF interrupt occurs. RXF interrupts are also disabled until the first RXFRMF interrupt
- 3. Using the RXF interrupt (Bit 1 of the IRQ FLAGS register) as a handshake, data can be read from the device. RXF set to "1" indicates that another byte can be read from the RX DATA BUFFER register. When RXF remains at "0", the buffer is empty. The frame boundaries are indicated by the RXFRMF interrupt (Bit 0 of the IRQ FLAGS register). Note that the host μController should continuously read bytes from the RX DATA BUFFER register and then re-assemble the frame within the host μController's memory, rather than wait for a complete frame (indicated by the next RXFRMF interrupt) before starting data transfer. Since the frame size is not an integer multiple of the block size, overflow will eventually occur if data is only transferred on frame boundaries.
- 4. If an ERRF interrupt (Bit 2 of the IRQ FLAGS register) and ERR (Bit 2 of the STATUS register) occur, the host μController will be expected to discard the bytes that it has already read from the receiver, which are associated with the unfinished frame. It must then wait for the next Frame flag (RXFRMF) in order to continue. Any unread contents of the RX DATA BUFFER are automatically discarded and no further RXF interrupts will be generated until the next Frame flag (RXFRMF) interrupt occurs.
- 5. As the device can buffer up to 4 Reed-Solomon blocks i.e.  $4 \times 47 \times 6 = 1128$  bits = 141 bytes, in addition to the Reed-Solomon block it is currently decoding, it may be more convenient for the host  $\mu$ Controller to

- use BLKRDYF and BLKRDYM (Bit 7 of the IRQ MASK 2 register and Bit 7 of the IRQ FLAGS 2 register) as a form of counter, such that after 1, 2, 3, or 4 "Block Ready" interrupts, the host µController empties the receive buffer in one go. Since, in this case, there is no way of knowing when the buffer is empty, an external timeout or byte counter is also required.
- 6. There is no buffer full indication, so if the RX DATA BUFFER register is not sufficiently empty when the fifth block has been processed, the latest received data (i.e. the fourth block) will be overwritten by the just completed fifth block.

#### 5.1.4 Transmit

The host µController then processes the frames and decides upon a reply. Gaining access and replying on the Reverse Channel can be done as follows:

- 1. Before starting a transmission the COLORF flag (Bit 3 of the IRQ FLAGS register) should be checked to have been set to "1" to ensure the correct Color Code is used on the Reverse Channel (this could be done while also reading the STATUS register during receive).
- 2. The IDLEF flag (Bit 5 of the IRQ FLAGS register) and the IDLE bit (Bit 5 of the STATUS register) should be checked to see if the Forward Channel is free. If the IDLE bit is "1" the channel is free, if it is "0" then there is communication with another system and the host μController will enter the DEFER state according to the CDPD specification (Release 1.1, Part 402, Sections 5.3.3.1 and 5.3.3.2).
- 3. With the IDLE bit confirming a free channel, set the desired MOD1 and MOD2 output gains in the TX MODEM CONTROL register, then write "1" to TXRFM (IRQ MASK 2 register, Bit 3) and write "1" to ENABTX (TX CONTROL register, Bit 0). This will take the Tx processing circuits out of powersave, so that blocks of data can then be loaded.
- 4. Up to 4 Reed-Solomon blocks (i.e. 4 x 47 x 6 = 1128 bits = 141 bytes of data) can be loaded contiguously on a byte-by-byte basis. Before any further data is loaded, the transmission must be started. This is done by writing "1" to START (Bit 1 of the TX CONTROL register), to indicate the start of data, i.e. the dotting sequence, reverse synchronization Color Code (from the Forward Channel) and the first frame byte will automatically be sent before the data in the buffer is despatched.
- 5. Write the data into the TX DATA BUFFER register a byte at a time, using the IRQN pin and the handshaking of the TXF flag (Bit 4 of the IRQ FLAGS register). TXF set to "1" indicates that another byte can be loaded into the TX DATA BUFFER register. When TXF remains at "0", the buffer is full.
- 6. At each frame boundary write a "1" to ENDFRM (Bit 2 of the TX CONTROL register).
- 7. At the end of the transmission sequence, write "1" to ENDSEQ (Bit 3 of the TX CONTROL register). This will fill up the last Reed-Solomon block with "1"s and send it with the continuity indicator set to "0" (see the CDPD specification: Release 1.1, Part 402, Section 4.6.4).
- 8. The Tx buffer can be kept full and serviced with an interrupt routine. There is no buffer empty indication and failure to provide data after writing the START bit will cause the device to send undefined data. Transmission of data does not begin until one complete block has been loaded into the Tx buffer.
- 9. The transmission will automatically start within 8 bit-times of the last bit of an idle flag (see the CDPD specification: Release 1.1, Part 402, Section 5.3.1). Approximately two bit-times (104µs) before the transmission is present at the TXOP1 and TXOP2 pins, the TXRFEN pin will be set to "1" and the TXRFEN bit (STATUS register Bit 3) will also be set to "1". The interrupt flag TXRFF (Bit 3 of the IRQ FLAGS 2 register) will also be set to "1" and an interrupt (IRQN) will be generated if the mask has previously been enabled (TXRFM, Bit 3 of the IRQ MASK 2 register set to "1").
- 10. Completion of the last Reed-Solomon block transmission will cause the TXRFEN pin to be reset to "0" and the TXRFEN bit (STATUS register Bit 3) will also be reset to "0". The interrupt flag TXRFF (Bit 3 of the IRQ FLAGS 2 register) will be set to "1" and an interrupt (IRQN) will be generated if the mask has previously been enabled (TXRFM, Bit 3 of the IRQ MASK 2 register set to "1"). Finally, the outputs TXOP1 and TXOP2 will go to V<sub>RIAS</sub>.
  - ENABTX (Bit 0 of the TX CONTROL register) should then be reset to "0", if required.
- 11. DECF (Bit 6 of the IRQ FLAGS register) and DEC (Bit 6 of the STATUS register) should be monitored to determine whether the M-ES Reverse Channel transmitted data has been decoded correctly by the MDBS.

# 6. Performance Specification

# 6.1 Electrical Performance

# 6.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_{DD} + 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               |
| E1 Package                                                      |      |                |                  |
| Total Allowable Power Dissipation at T <sub>AMB</sub> = 25°C    |      | 400            | mW               |
| Derating above 25°C                                             |      | 5.3            | mW/°C above 25°C |
| Storage Temperature                                             | -55  | +125           | °C               |
| Operating Temperature                                           | -40  | +85            | °C               |

# 6.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    | ပ္    |
| Xtal Frequency                              |       | 4.9149 | 4.9155 | MHz   |

#### **Operating Characteristics** 6.1.3

# Details in this section represent design target values and are not currently guaranteed.

For the following conditions unless otherwise specified:

Xtal Frequency = 4.9152MHz, Bit Rate = 19.2k bits/sec, Noise Bandwidth = Bit Rate,  $V_{DD} = 3.0 \text{V}$  to 5.5V,  $T_{AMB} = -40 ^{\circ}\text{C}$  to +85°C and  $V_{DD} = 2.7 \text{V}$  at  $T_{AMB} = 25 ^{\circ}\text{C}$ .

|                                                                       | Notes | Min. | Тур. | Max. | Units            |
|-----------------------------------------------------------------------|-------|------|------|------|------------------|
| DC Parameters                                                         |       |      |      |      |                  |
| I <sub>DD</sub> (zero-power) at V <sub>DD</sub> = 3.0V                | 1     | _    | 1.0  | 10.0 | μA               |
| I <sub>DD</sub> (zero-power) at V <sub>DD</sub> = 5.0V                | 1     | _    | 1.0  | 10.0 | μA               |
| $I_{DD}$ (Rx only) at $V_{DD} = 3.0$ V                                | 1     | _    | 2.0  | TBD  | mA               |
| $I_{DD}$ (Rx only) at $V_{DD} = 5.0V$                                 | 1     | _    | 4.0  | TBD  | mA               |
| $I_{DD}$ (Tx only) at $V_{DD} = 3.0V$                                 | 1     | -    | 2.0  | TBD  | mA               |
| $I_{DD}$ (Tx only) at $V_{DD} = 5.0V$                                 | 1     | 1    | 4.0  | TBD  | mA               |
| $I_{DD}$ (Rx and Tx) at $V_{DD} = 3.0V$                               | 1     | -    | 3.5  | TBD  | mΑ               |
| $I_{DD}$ (Rx and Tx) at $V_{DD} = 5.0V$                               | 1     | 1    | 7.0  | TBD  | mΑ               |
| AC Parameters                                                         |       |      |      |      |                  |
| Tx Output                                                             |       |      |      |      |                  |
| Tx O/P impedance (powersaved)                                         | 2     | 300  | 500  | -    | kΩ               |
| Tx O/P impedance (operating)                                          | 2     | _    | 1.0  | 2.5  | kΩ               |
| Signal level                                                          | 7     | 0.9  | 1.0  | 1.1  | V <sub>P-P</sub> |
| TXF latency                                                           | 10    | TBD  | 16   | TBD  | μs               |
| Tx Processing Delay                                                   | 9     | _    | 1    | _    | Bit              |
| TXOP1 or TXOP2 dc level (transmitting "1010")                         |       | TBD  | 50%  | TBD  | $V_{DD}$         |
| (in Tx mode, MOD1 and MOD2 gain OFF)                                  |       | TBD  | 50%  | TBD  | $V_{DD}$         |
| (in Powersave - Tx mode disabled)                                     |       | TBD  | 50%  | TBD  | $V_{DD}$         |
| (in zero-power mode)                                                  |       | -    | 0    | _    | V                |
| Rx Input                                                              |       |      |      |      |                  |
| Rx I/P pin impedance (at 100Hz)                                       |       | 10   | 1    | ı    | $M\Omega$        |
| Rx I/P amp open loop voltage gain (I/P = 1mV <sub>RMS</sub> at 100Hz) |       | _    | 500  | -    | V/V              |
| Input signal level                                                    | 8     | 0.7  | 1.0  | 1.3  | V <sub>P-P</sub> |
| RXF latency                                                           | 10    | TBD  | 16   | TBD  | μs               |
| Rx Processing Delay                                                   | 9     | _    | 7    | _    | Bits             |
| Xtal/Clock Input                                                      |       |      |      |      |                  |
| 'High' pulse width                                                    | 3     | 40   | _    | _    | ns               |
| 'Low' pulse width                                                     | 3     | 40   | _    | _    | ns               |
| Input impedance (at 100Hz)                                            |       | 10   | _    | _    | $\Omega$ M       |
| Gain (I/P = 1mV <sub>RMS</sub> at 1kHz)                               |       | 20   | _    | _    | dB               |
| μC Interface                                                          |       |      |      |      |                  |
| Input logic "1" level                                                 | 4, 5  | 80%  | _    | _    | $V_{DD}$         |
| Input logic "0" level                                                 | 4, 5  | _    | _    | 20%  | $V_{DD}$         |
| Input leakage current (V <sub>IN</sub> = 0 to V <sub>DD</sub> )       | 4, 5  | -5.0 | _    | +5.0 | μΑ               |
| Input capacitance                                                     | 4, 5  | 1    | 7.5  | _    | рF               |
| Output logic "1" level (l <sub>OH</sub> = 120µA)                      | 5     | 90%  | _    | _    | $V_{DD}$         |
| Output logic "0" level (l <sub>OL</sub> = 360µA)                      | 5, 6  | _    | _    | 10%  | $V_{DD}$         |
| 'Off' state leakage current (V <sub>OUT</sub> = V <sub>DD</sub> )     | 6     | _    | 1    | 10   | μΑ               |

©2001 MX-COM, Inc www.mxcom.com Tel: 800 638 5577 336 744 5050 Fax: 336 744 5054 Doc. # 20480231.001 4800 Bethania Station Road, Winston-Salem, NC 27105-1201 USA All trademarks and service marks are held by their respective companies.

### **Operating Characteristics Notes:**

- 1. Not including any current drawn from the device pins by external circuitry
- 2. Small signal impedance
- 3. Timing for an external input to the CLOCK/XTAL pin
- 4. WRN, RDN, CSN, A0 A2 pins
- 5. D0 D7 pins
- 6. IRQN pin
- 7. Measured at TXOP1 and TXOP2 with MOD1/2 gain blocks set to 0dB
- 8. Measured at RXFB pin
- 9. Bit period =  $52\mu$ s
- 10. From the availability of the last bit in a block. This implies that the first bit in the same block will be delayed by typically 22ms.

#### **Timing Diagrams** 6.1.4

For the following conditions unless otherwise specified:

Xtal Frequency = 4.9152MHz,

 $V_{DD} = 3.0 \text{V}$  to 5.5V,  $T_{AMB} = -40 ^{\circ}\text{C}$  to +85°C and  $V_{DD} = 2.7 \text{V}$  at  $T_{AMB} = 25 ^{\circ}\text{C}$ .

|                                               |                                  | Notes | Min. | Тур. | Max. | Units        |
|-----------------------------------------------|----------------------------------|-------|------|------|------|--------------|
| μC Parallel Interface Timings (ref. Figure 5) |                                  |       |      |      |      |              |
| t <sub>ACSL</sub>                             | Address valid to CSN low time    |       | 0    | _    | _    | ns           |
| t <sub>AH</sub>                               | Address hold time                |       | 0    | _    | _    | ns           |
| t <sub>CSH</sub>                              | CSN hold time                    |       | 0    | _    | _    | ns           |
| t <sub>CSHI</sub>                             | CSN high time                    | 1     | 6    | _    | _    | clock cycles |
| t <sub>CSRWL</sub>                            | CSN to WRN or RDN low time       |       | 0    | _    | _    | ns           |
| t <sub>DHR</sub>                              | Read data hold time              |       | 0    | _    | _    | ns           |
| t <sub>DHW</sub>                              | Write data hold time             |       | 0    | _    | _    | ns           |
| t <sub>DSW</sub>                              | Write data setup time            |       | 15   | _    | _    | ns           |
| t <sub>RHCSL</sub>                            | RDN high to CSN low time (write) |       | 0    | _    | _    | ns           |
| t <sub>RACL</sub>                             | Read access time from CSN low    | 2     | _    | _    | 30   | ns           |
| t <sub>RARL</sub>                             | Read access time from RDN low    | 2     | _    | _    | 25   | ns           |
| t <sub>RL</sub>                               | RDN low time                     |       | 35   | _    | _    | ns           |
| t <sub>RX</sub>                               | RDN high to D0-D7 3-state time   |       | _    | _    | 10   | ns           |
| t <sub>WHCSL</sub>                            | WRN high to CSN low time (read)  |       | 0    |      | _    | ns           |
| t <sub>WL</sub>                               | WRN low time                     |       | 35   | _    | _    | ns           |

#### Notes:

- 1. Xtal/Clock cycles at the XTAL/CLOCK pin
- 2. With 30pF max to VSS on D0 D7 pins





Figure 5: µController Parallel Interface Timings

# 6.2 Packaging



Figure 6: 28-pin TSSOP Mechanical Outline: Order as part no. CMX989E1