

# ISD61S00 ChipCorder Telephony Feature Chip Design Guide

©2008 Nuvoton Technology Corporation America all rights reserved.

#### **Important Notice**

Nuvoton products are not designed, intended, authorized or warranted for use as components in systems or equipment intended for surgical implantation, atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, or for other applications intended to support or sustain life. Further more, Nuvoton products are not intended for applications wherein failure of Nuvoton products could result or lead to a situation wherein personal injury, death or severe property or environmental damage could occur.

Nuvoton customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Nuvoton for any damages resulting from such improper use or sales.

### nuvoTon

### **Table of Contents**

| 1.  | GENERA            | AL DESCRIPTION                         | 10 |  |  |  |
|-----|-------------------|----------------------------------------|----|--|--|--|
| 2.  | FEATURES          |                                        |    |  |  |  |
| 3.  | PIN CONFIGURATION |                                        |    |  |  |  |
| 4.  | PIN DES           | CRIPTION                               | 13 |  |  |  |
| 5.  | BLOCK [           | DIAGRAM                                | 16 |  |  |  |
| 6.  | CONFIG            | URATION REGISTER MAP                   | 17 |  |  |  |
| 6.1 |                   | onfiguration Register Groups           |    |  |  |  |
| 6.2 |                   | egister Map                            |    |  |  |  |
| 7.  |                   | STATUS                                 |    |  |  |  |
| 7.1 |                   | evice Status Register                  |    |  |  |  |
| 8.  |                   | ONAL DESCRIPTION                       |    |  |  |  |
| 8.1 |                   | PI Interface                           |    |  |  |  |
| 8.2 |                   | ecord and Playback Control             |    |  |  |  |
| 0.2 | 8.2.1             | COMP_CFG – Compression Configuration   |    |  |  |  |
|     | 8.2.2             | COMP_CTRL - Compression Control        |    |  |  |  |
|     | 8.2.3             | COMP_SRC – Compression Source          |    |  |  |  |
|     | 8.2.4             | CLK CTRL – Clock Control               |    |  |  |  |
|     | 8.2.5             | CFG17 – Update Mode                    |    |  |  |  |
| 8.3 | С                 | lock Generation and PLL                | 40 |  |  |  |
|     | 8.3.1             | Phase Locked Loop (PLL) Design Example | 41 |  |  |  |
|     | 8.3.2             | PLL_CLK                                | 42 |  |  |  |
|     | 8.3.3             | PLL_FRAC                               | 43 |  |  |  |
|     | 8.3.4             | PLL_CTRL                               | 43 |  |  |  |
| 8.4 | D                 | igital Audio Interface Control         | 43 |  |  |  |
|     | 8.4.1             | PCM_CFG                                | 44 |  |  |  |
|     | 8.4.2             | PCM_TSLOTL                             | 45 |  |  |  |
|     | 8.4.3             | PCM_TSLOTR                             |    |  |  |  |
|     | 8.4.4             | PCM_COMP0                              |    |  |  |  |
|     | 8.4.5             | PCM_TSLOTL1                            |    |  |  |  |
|     | 8.4.6             | PCM_TSLOTR1                            |    |  |  |  |
|     | 8.4.7             | PCM_COMP1                              |    |  |  |  |
|     | 8.4.8             | PCM_TX_SEL                             |    |  |  |  |
| ٥.  | 8.4.9             | PCM_RX_SEL                             |    |  |  |  |
| 8.5 |                   | PIO and Interrupt Configuration        |    |  |  |  |
|     | 8.5.1             | PORT_UF                                |    |  |  |  |
|     | 8.5.2<br>8.5.3    | PORTx_IE                               |    |  |  |  |
|     | 8.5.3<br>8.5.4    | IE1                                    |    |  |  |  |
|     | 0.3.4             | IET                                    | 50 |  |  |  |

# nuvoTon

|      | 8.5.5   | PORTA DO                                     | 50 |
|------|---------|----------------------------------------------|----|
|      | 8.5.6   | PORTA OE                                     |    |
|      | 8.5.7   | PORTA_PE                                     |    |
|      | 8.5.8   | PORTA DI                                     |    |
|      | 8.5.9   | PORTA PS                                     |    |
|      | 8.5.10  | PORTA DS                                     |    |
|      | 8.5.11  | PORTA_AF                                     | 51 |
| 8.6  |         | 16 bit Indirect Index register R0-R7         |    |
| 8.7  |         | Microphone interface and Auxiliary Interface |    |
|      | 8.7.1   | MIC_CTRL                                     |    |
|      | 8.7.2   | MIC BIAS                                     |    |
| 8.8  |         | PSTN Analog Input                            | 60 |
|      | 8.8.1   | TI GAIN                                      |    |
|      | 8.8.2   | TI_CTRL                                      | 61 |
| 8.9  |         | Analog Outputs                               |    |
|      | 8.9.1   | ANA OUT                                      |    |
|      | 8.9.2   | ANA CTRL                                     |    |
| 8.10 |         | DTMF Detection                               | 65 |
|      | 8.10.1  | DTMF CTRL                                    |    |
|      | 8.10.2  | DTMF FIFO CTRL                               |    |
|      | 8.10.3  | DTMF FIFO                                    |    |
|      | 8.10.4  | DTMF FIFO STATUS                             | 68 |
|      | 8.10.5  | DTMF THRES                                   |    |
|      | 8.10.6  | DTMF PDT                                     |    |
|      | 8.10.7  | DTMF ADT                                     | 70 |
|      | 8.10.8  | DTMF_ACCT                                    | 70 |
|      | 8.10.9  | 70                                           |    |
|      | 8.10.10 | DTMF_RX_DATA                                 | 70 |
|      | 8.10.11 | DTMF_ROW_FREQ                                | 71 |
|      | 8.10.12 | DTMF_COL_FREQ                                | 71 |
|      | 8.10.13 | Tip & Tricks                                 | 71 |
| 8.11 |         | DTMF and Arbitrary Tone Generation           | 72 |
|      | 8.11.1  | TONE_CTRL                                    | 73 |
|      | 8.11.2  | TONE_FREQ_A                                  | 73 |
|      | 8.11.3  | TONE_FREQ_B                                  | 74 |
|      | 8.11.4  | TONE_LEVEL_A                                 | 74 |
|      | 8.11.5  | TONE_LEVEL_B                                 | 74 |
|      | 8.11.6  | TONE_ON_TIME                                 | 74 |
|      | 8.11.7  | TONE_OFF_TIME                                | 75 |
|      | 8.11.8  | TONE_LENGTH                                  | 75 |
|      | 8.11.9  | 75                                           |    |
|      | 8.11.10 | TONE_INDEX_0 ~ TONE_INDEX_A                  | 76 |
| 8.12 |         | FSK Generation                               | 76 |
|      | Q 12 1  | ESKE CTRL1                                   | 78 |

|      | 8.12.2  | FSKE CTRL2                                  | 78  |
|------|---------|---------------------------------------------|-----|
|      | 8.12.3  | FSKE TX DATA                                |     |
|      | 8.12.4  | FSKE STATUS                                 |     |
|      | 8.12.5  | FSKE_GAIN                                   |     |
|      | 8.12.6  | FSKE PROG                                   |     |
|      | 8.12.7  | FSKE BAUD (SW MODE = 1)                     | 80  |
|      | 8.12.8  | FSKE_MARK_FREQ (SW_MODE = 1)                |     |
|      | 8.12.9  | FSKE_SPACE_FREQ (SW_MODE = 1)               |     |
|      | 8.12.10 | FSKE_TEST                                   |     |
|      | 8.12.11 | 81                                          |     |
|      | 8.12.12 | Example FSK Generator Usage                 | 81  |
| 8.13 | FSK     | Detection                                   | 85  |
|      | 8.13.1  | FSKD CTRL                                   |     |
|      | 8.13.2  | FSKD_MODE                                   |     |
|      | 8.13.3  | FSKD ADJUST                                 |     |
|      | 8.13.4  | FSKD_STATUS                                 | 89  |
|      | 8.13.5  | FSKD THRES                                  | 89  |
|      | 8.13.6  | FSKD JUDGE                                  | 90  |
|      | 8.13.7  | FSKD_SYNC                                   | 90  |
|      | 8.13.8  | FSKD_CDET                                   | 90  |
|      | 8.13.9  | FSKD_FIFO_CTRL                              | 91  |
|      | 8.13.10 | FSKD_FIFO_DOUT                              | 92  |
|      | 8.13.11 | FSKD_FIFO_STATUS                            | 92  |
|      | 8.13.12 | FSKD_ENERGY_HIGH_TH                         | 92  |
|      | 8.13.13 | FSKD_ENERGY_LOW_TH                          | 93  |
|      | 8.13.14 | FSKD_ENERGY_TC                              | 93  |
|      | 8.13.15 | 93                                          |     |
|      | 8.13.16 | FSKD_CDB_FREQ_LOW_CNT                       | 93  |
|      | 8.13.17 | FSKD_CDB_FREQ_HIGH_CNT                      | 94  |
|      | 8.13.18 | FSKD_LIMIT_TH                               | 94  |
|      | 8.13.19 | Example FSK Detector Usage                  | 95  |
| 8.14 | CAS     | and Arbitrary Tone (ATD) Detector           | 99  |
|      | 8.14.1  | CAS_CTRL                                    | 101 |
|      | 8.14.2  | CAS_THRES_LOW - CAS detector low threshold  |     |
|      | 8.14.3  | CAS_MULT                                    | 102 |
|      | 8.14.4  | CAS_PRESENT                                 | 103 |
|      | 8.14.5  | CAS_ABSENT                                  | 104 |
|      | 8.14.6  | CAS_STATUS                                  | 104 |
|      | 8.14.7  | CAS_MODE - Arbitrary Tone Detection Mode    | 104 |
|      | 8.14.8  | ATD_MAX_HFC (ATD_MODE = 1)                  | 105 |
|      | 8.14.9  | ATD_MIN_HFC (ATD_MODE = 1)                  | 105 |
|      | 8.14.10 | ATD_MAX_LFC (ATD_MODE = 1)                  | 106 |
|      | 8.14.11 | ATD_MIN_LFC (ATD_MODE = 1)                  | 106 |
|      | 8 14 12 | External Dual-IIR Coefficient (ATD_MODE= 1) | 106 |

|      | 8.14.13 | FSK_COEFF - FSK Encoder Coefficient RAM Data         | 107 |
|------|---------|------------------------------------------------------|-----|
|      | 8.14.14 | FSK_COEFF_ADDR - FSK Encoder Coefficient RAM Address |     |
|      | 8.14.15 | CAS_MAX_HFC (FINE_TUNE = 1)                          |     |
|      | 8.14.16 | CAS_MIN_HFC (FINE_TUNE = 1)                          |     |
|      | 8.14.17 | CAS_MAX_LFC (FINE_TUNE = 1)                          |     |
|      | 8.14.18 | CAS_MIN_LFC (FINE_TUNE = 1)                          |     |
|      | 8.14.19 | 110                                                  |     |
|      | 8.14.20 | 110                                                  |     |
|      | 8.14.21 | Arbitrary Tone Detector Example                      | 110 |
| 8.15 |         | ice Energy Detection (Speech Energy Detection)       |     |
|      | 8.15.1  | VD_CTRL                                              |     |
|      | 8.15.2  | VD STATUS                                            |     |
|      | 8.15.3  | VD_THRES                                             |     |
|      | 8.15.4  | VD ENERGY                                            |     |
| 8.16 | Cal     | Il Progress Tone Detector                            |     |
|      | 8.16.1  | CPT CTRL                                             |     |
|      | 8.16.2  | CPT STATUS                                           |     |
|      | 8.16.3  | CPT THRES H                                          |     |
|      | 8.16.4  | CPT THRES L                                          |     |
|      | 8.16.5  | CPT ENERGY                                           |     |
| 8.17 | Rin     | g Detection and Pulse / Period Width Measurement     |     |
|      | 8.17.1  | RNG CTRL                                             |     |
|      | 8.17.2  | RNG STATE                                            |     |
|      | 8.17.3  | RNG CNTR                                             |     |
|      | 8.17.4  | RNG LATCH                                            | 123 |
|      | 8.17.5  | 123                                                  |     |
| 8.18 | Tim     | ner                                                  | 123 |
|      | 8.18.1  | 123                                                  |     |
|      | 8.18.2  | TIME_TARG                                            | 124 |
|      | 8.18.3  | TIME_CNT                                             | 124 |
| 8.19 | Ga      | in Stage and Mixer                                   | 124 |
|      | 8.19.1  | GS_CTRL                                              | 128 |
|      | 8.19.2  | CODEC EC Gain Stages                                 | 129 |
|      | 8.19.3  | AECin Path Mixing Gain Control                       |     |
|      | 8.19.4  | LECin Path Mixing Gain Control                       | 130 |
|      | 8.19.5  | REC Path Mixing Gain Control Registers               | 131 |
|      | 8.19.6  | I2SLin Path Mixing Gain Control Registers            | 132 |
|      | 8.19.7  | I2SRin Path Mixing Gain Control Registers            | 132 |
|      | 8.19.8  | Mixer Source Enable Registers                        | 133 |
| 8.20 | Air     | and Line CODEC                                       | 133 |
|      | 8.20.1  | AC_EN, LC_EN – Air /Line CODEC Enable Register       | 134 |
|      | 8.20.2  | AC_CTRL, LC_CTRL - Air /Line CODEC Dither Control    | 135 |
|      | 8.20.3  | AC_ADCG, LC_ADCG - Air/Line CODEC ADC Gain           | 135 |
|      | 8.20.4  | AC_DACG, LC_DACG - Air/Line CODEC DAC Gain           | 135 |

|      | 8.20.5 | 136                                    |     |
|------|--------|----------------------------------------|-----|
|      | 8.20.6 | 136                                    |     |
| 8.21 |        | RINGER TONE GENERATOR                  |     |
|      | 8.21.1 | PWM Clock                              | 137 |
|      | 8.21.2 |                                        |     |
|      | 8.21.3 | (102)                                  |     |
|      | 8.21.4 |                                        |     |
|      | 8.21.5 | PWM Tone2 Frequency                    | 139 |
| 9.   | ACOL   | JSTIC PROCESSING BLOCK                 | 139 |
| 9.1  |        | Full/Half AEC Block Diagram            | 139 |
| 9.2  |        | Control Register Memory Map            | 141 |
|      | 9.2.1  | Threshold and Power Calculation        | 145 |
| 9.3  |        | Control Registers                      | 145 |
|      | 9.3.1  | CONFIG                                 |     |
|      | 9.3.2  | RESET                                  | 146 |
|      | 9.3.3  | EC_BELTA                               | 147 |
|      | 9.3.4  | AS_COEFF                               | 148 |
| 9.4  |        | Double Talk Detector Control Registers | 148 |
|      | 9.4.1  | Function                               | 149 |
|      | 9.4.2  | DT_LONG_TC                             | 149 |
|      | 9.4.3  | DT_SHORT_TC                            | 149 |
|      | 9.4.4  | Double Talk Detector Parameters        | 150 |
|      | 9.4.5  | DIVERGENCE                             | 150 |
| 9.5  |        | Voice Detector Control Registers       | 151 |
|      | 9.5.1  | Function                               | 151 |
|      | 9.5.2  | VD_LONG_TC                             | 151 |
|      | 9.5.3  | VD_SHORT_TC                            | 151 |
|      | 9.5.4  | Voice Detector Parameters              | 151 |
|      | VD_A\  | /E_TC 152                              |     |
|      | 9.5.5  | VD_AVE_THRESH                          | 153 |
| 9.6  |        | AS1 & AS2 Control Registers            | 153 |
|      | 9.6.1  | Function                               | 153 |
|      | 9.6.2  | AS1_BUILD_UP_TIME                      | 153 |
|      | 9.6.3  | AS1_MAX_ATTEN                          | 153 |
|      | 9.6.4  | AS2_BUILD_UP_TIME                      | 154 |
|      | 9.6.5  | AS2_MAX_ATTEN                          | 154 |
| 9.7  |        | Noise Suppressor Registers             | 154 |
|      | 9.7.1  | Function                               | 154 |
|      | 9.7.2  | NS_POWER_ATTACK_TC                     | 155 |
|      | 9.7.3  | NS_ATTEN _TC                           | 155 |
|      | 9.7.4  | NS_ACTIVE_THRESHOLD                    | 155 |
| 9.8  |        | 155                                    |     |
| 99   |        | Soft Clin (SC) Control Registers       | 156 |

# nuvoTon

|      | 9.9.1   | Functional Description                                         | 156 |
|------|---------|----------------------------------------------------------------|-----|
|      | 9.9.2   | SC_CTRL                                                        | 156 |
|      | 9.9.3   | SC_NORMAL_INDEX                                                | 157 |
|      | 9.9.4   | SC_LOW_INDEX                                                   |     |
|      | 9.9.5   | SC_THRESH                                                      | 158 |
|      | 9.9.6   | SC_POWER_ATTACK_TC                                             | 158 |
|      | 9.9.7   | SC_GAIN_TC                                                     | 159 |
| 9.10 | Sta     | ate Read back Registers                                        |     |
|      | 9.10.1  | Functional Description                                         |     |
|      | 9.10.2  | Power Monitor                                                  | 159 |
|      | 9.10.3  | Signal Monitor                                                 | 160 |
| 9.11 | 160     |                                                                |     |
| 9.12 | Au      | tomatic Gain Control                                           | 161 |
|      | 9.12.1  | AGC_CTRL                                                       |     |
|      | 9.12.2  | AGC INIT GAIN                                                  |     |
|      | 9.12.3  | AGC GAIN HOLD                                                  |     |
|      | 9.12.4  | AGC INC DEC                                                    |     |
|      | 9.12.5  | AGC ATK DCY                                                    |     |
|      | 9.12.6  | AGC_GAIN_READ                                                  |     |
|      | 9.12.7  | AGC STATE                                                      |     |
|      | 9.12.8  | AGC PWR TC                                                     |     |
|      | 9.12.9  | AGC PK TC                                                      |     |
|      | 9.12.10 | AGC PK                                                         |     |
|      | 9.12.11 | AGC TARGETS                                                    |     |
|      | 9.12.12 | AGC NOISE PARAMETERS                                           |     |
| 10.  | SPI COM | MANDS                                                          |     |
| 10.1 |         | dio Play and Record Commands                                   |     |
|      | 10.1.1  | Play Voice Prompt                                              |     |
|      | 10.1.2  | Play Voice Prompt @Rn, n = 0 ~ 7                               |     |
|      | 10.1.3  | Play Voice Prompt, Loop                                        |     |
|      | 10.1.4  | Play Voice Prompt, Loop, @Rn, n = 0 ~ 7                        |     |
|      | 10.1.5  | Stop Loop-Play Command                                         |     |
|      | 10.1.6  | Execute Voice Macro                                            |     |
|      | 10.1.7  | Execute Voice Macro @Rn, n = 0 ~ 7                             |     |
|      | 10.1.8  | Record Message                                                 |     |
|      | 10.1.9  | Record Message at Address                                      |     |
|      | 10.1.10 | Play Message at Address                                        |     |
|      | 10.1.11 | Play Silence                                                   |     |
|      | 10.1.12 | Stop Command                                                   |     |
|      | 10.1.12 | Erase Message at Address                                       |     |
|      | 10.1.14 | SPI Send Audio Data                                            |     |
|      | 10.1.15 | SPI Receive Audio Data                                         |     |
|      | 10 1 16 | SPI Send Compressed Audio Data for direct programming to flash | 179 |

|      | 10.1.17              | SPI Receive previous REC_MSG or REC_MSG@ compress | ed Audio Data stored in flash |
|------|----------------------|---------------------------------------------------|-------------------------------|
|      | 10.1.18              | SPI Send Compressed Data to Decode                | 181                           |
|      | 10.1.19              | SPI Receive Encoded Data                          |                               |
| 10.2 | De                   | evice Status Commands                             |                               |
|      | 10.2.1               | Read Status                                       |                               |
|      | 10.2.2               | Read Interrupt                                    | 183                           |
|      | 10.2.3               | Read Recorded Message Address Details             | 183                           |
|      | 10.2.4               | Read Message Length                               | 184                           |
|      | 10.2.5               | Read ISD61S00 ID                                  |                               |
| 10.3 | Dig                  | gital Memory Commands                             | 185                           |
|      | 10.3.1               | Digital Read                                      | 185                           |
|      | 10.3.2               | Digital Write                                     | 185                           |
|      | 10.3.3               | Erase Memory                                      | 186                           |
|      | 10.3.4               | Chip Erase                                        | 186                           |
|      | 10.3.5               | CHECKSUM                                          | 187                           |
| 10.4 | De                   | evice Configuration Commands                      | 187                           |
|      | 10.4.1               | PWR_UP – Power up                                 | 188                           |
|      | 10.4.2               | PWR_DN – Power Down                               | 188                           |
|      | 10.4.3               | WR_CFG_REG – Write Configuration Register         |                               |
|      | 10.4.4               | RD_CFG_REG - Read Configuration Register          |                               |
| 10.5 | De                   | evice Power Up Sequence                           | 189                           |
| 11.  | ISD61S00             | ) MEMORY MANAGEMENT                               | 189                           |
| 11.1 | ISI                  | D61S00 Memory Format                              | 189                           |
| 11.2 | Me                   | essage Management                                 | 190                           |
|      | 11.2.1               | Voice Prompts                                     | 191                           |
|      | 11.2.2               | Voice Macros                                      | 191                           |
|      | 11.2.3               | User Data                                         | 192                           |
|      | 11.2.4               | Reserved Sectors                                  | 192                           |
|      | 11.2.5               | Message Recordings                                | 192                           |
| 11.3 | Me                   | emory and Message Headers                         | 193                           |
|      | 11.3.1               | Memory Header                                     | 193                           |
|      | 11.3.2               | Message Header                                    |                               |
| 11.4 | 271.1.1              | gital Access of Memory                            |                               |
| 11.5 | De                   | evice Erase Commands                              | 195                           |
| 11.6 | Me                   | emory Contents Protection                         | 195                           |
| 12.  | DEVICE I             | NITIALIZATION                                     | 195                           |
| 13.  | APPLICA <sup>*</sup> | TION REFERENCE SCHEMATICS                         | 196                           |
| 13.1 | PC                   | CB Layout Guidelines                              | 196                           |
| 14.  | PACKAGI              | E SPECIFICATION                                   | 199                           |
| 14.1 | LC                   | QFP48L (7x7x1.4mm footprint 2.0mm)                | 199                           |
| 15.  |                      | CAL CHARACTERISTICS                               |                               |
| 15 1 |                      | scalute Maximum Detings                           | 200                           |

| 15.2  |        | Operating Conditions                                                     | 200 |
|-------|--------|--------------------------------------------------------------------------|-----|
| 15.3  |        | DC Parameters                                                            | 201 |
| 15.4  |        | Analog Transmission Characteristics                                      | 202 |
| 15.5  |        | Analog Distortion and Noise Parameters                                   | 202 |
|       | 15.5.1 | 8kHz sampling                                                            |     |
|       | 15.5.2 | 16kHz sampling                                                           | 203 |
| 15.6  |        | SPI Timing                                                               | 203 |
| 15.7  |        | Recommended Clock/Crystal Specification                                  | 204 |
| 15.8  |        | Dual Tone Alert Signal (CAS)                                             | 205 |
| 15.9  |        | FSK Detection – 1200baud Bell 202, ITU V.23, 300 baud Bell 103, ITU V.21 | 206 |
| 15.10 |        | FSK Transmitter – Bell 202, ITU-V.23, Bell 103, ITU-V.21                 | 208 |
| 15.11 |        | DTMF Detection                                                           | 209 |
| 16.   | ORDE   | RING INFORMATION                                                         | 210 |
| 17.   | REVIS  | SION HISTORY                                                             | 211 |

#### 1. GENERAL DESCRIPTION

The ISD61S00 is a feature chip for the security and telephony industry. The device incorporates audio storage with a powerful macro scripting ability to facilitate audio prompting in a multi-language environment and simple address-free recording and playback. It utilizes external serial flash memory for audio data storage. In addition, the device includes circuitry to perform telephony based data communications including DTMF detection and generation, FSK modem functions from 75-1200 baud, CAS and CPT (Call Progress Tone) detection and ring detection. The audio path of the device is designed to interface to both the air side and line side of a PSTN system. The air side includes a flexible microphone interface incorporating a bias generator and gain control and a differential analog output for driving a speaker or power amplifier. The line side incorporates a line driver to drive PSTN loads and two variable gain differential inputs. The audio path includes full and half-duplex acoustic and line echo cancellation to implement full and half-duplex speakerphone functions. The digital audio interface can be configured to I<sup>2</sup>S or PCM mode for digital serial audio communication. Control, monitoring and device programming is performed via a SPI interface. The device package is LQFP-48L.

#### 2. FEATURES

- External Memory:
  - o The ISD61S00 supports the following flash:

| Manufacturer | Winbond  |          | Numonyx  |          |          | MXIC      |
|--------------|----------|----------|----------|----------|----------|-----------|
| Family       | 25X      | 25Q      | 25P      | 25PX     | 25PE     | 25L / 25V |
| JEDEC ID     | EF 30 1X | EF 40 1X | 20 20 1X | 20 71 1X | 20 80 1X | C2 20 1X  |

- The addressing ability of ISD61S00 is up to 128Mbit, which is 64-minute record/playback time based on 8kHz/4bit ADPCM.
- Fast pre-recording: Recording is limited by the write rate of the attached external flash.
- Operating voltage: 2.7-3.6V.
- Sampling frequency: Recording and playback sampling frequencies of 4, 5.3, 6.4, 8, 10.6, 12.8 and 16 kHz.
- Compression algorithm:
  - For record and playback:
  - o ADPCM compression at 2, 3, 4 or 5 bits per sample.
  - μ-Law companding at 6, 7 or 8 bits per sample.
  - O Differential μ-Law encoding at 6, 7 or 8 bits per sample.
  - o PCM encoding at 8, 10 or 12 bits per sample.
- For pre-recorded audio playback (Voice prompts) additionally:
  - Enhanced ADPCM compression at 2, 3, 4 or 5 bits per sample.
  - Multi-Bit rate optimized compression. This allows best possible compression given a metric of SNR and background noise levels.
- Message Management:
  - Simple address free real-time recording.
  - Flexible Voice Prompt message management and Voice Macro scripting for pre-recorded messages.
- External serial flash memory interface: Support up to 128Mbit for audio and digital data storage, equivalent to 64 minutes based on 8khz 4bit ADPCM.
- Digital access to flash memory: Memory can be reserved on a 4Kbyte sector basis for use as

#### nuvoton

conventional digital memory by host.

- Telephony/Modem/Data Features at 8KHz CODEC sampling rate:
  - o DTMF encoder with 20 digit dial string buffer.
  - o DTMF detector.
  - FSK generation at 75/110/150/300/1200 baud for Bell 103, Bell 202, V.21 or V.23 modem standards. Transmit FIFO to reduce host interaction.
  - FSK detector at 75/110/150/300/1200 baud for Bell 103, Bell 202, V.21 or V.23 modem standards with receive FIFO.
  - o Ring Detector.
  - o Call Progress Tone (CPT) detector for detecting dial tones, busy tones etc.
  - CAS detector for caller ID type I, type II implementation.
  - Arbitrary dual tone generator.
  - Arbitrary tone detector.
- Acoustic Echo Cancellation (AEC), Line Echo Cancellation (LEC) and Automatic Gain Control (AGC) for on-chip speakerphone support.
- Up to 17 GPIO pins accessible through the SPI interface.
- Audio Input:
  - o TI1 and TI2: Differential Analog inputs for PSTN interface (on-hook and off-hook).
  - o MIC+/-: Analog interface to microphone.
- Audio Output:
  - PO: Differential Analog output for PSTN interface.
  - SPK: Differential output buffer for speaker driver.
- I/O:
- SPI interface: MISO, MOSI, SCLK, SS for commands and digital audio data.

- 11 -

- o INT and R/B signal for signaling and flow control.
- Package: Green LQFP-48L
- Temperature: -40°C to 85°C

Publication Release Date: March 10, 2011

Revision 2.7

#### 3. PIN CONFIGURATION



Figure 3-1 ISD61S00 48-Lead LQFP Pin Configuration.



#### 4. PIN DESCRIPTION

| T. 1 111      | DESCRIPTION   |      |                                                                                                                     |        |
|---------------|---------------|------|---------------------------------------------------------------------------------------------------------------------|--------|
| Pin<br>Number | Pin Name      | I/O  | Function                                                                                                            | Drive  |
| 1             | RESET         | I    | Raising this pin to VCC will reset the chip.                                                                        | N/A    |
| 2             | INTB          | 0    | Active low interrupt request pin. This pin has an open drain output.                                                | 4/8mA  |
| 3             | GPIO<14>/RDET | I/O* | General Purpose IO Pin or the Ring Detect input (RDET).                                                             | 4/8mA  |
| 4             | VSSD          | G    | Digital Ground.                                                                                                     | N/A    |
| 5             | XTALOUT       | 0    | Crystal Interface output pin.                                                                                       | N/A    |
| 6             | XTALIN        | ı    | Crystal interface input pin. It can also be used to provide an external clock to the device.                        | N/A    |
| 7             | VDDL          | 0    | This pin has a nominal 1.8V output to supply the internal logic. A 2.2nF capacitor should be connected to this pin. | N/A    |
| 8             | VCCD          | Р    | Digital power supply pin                                                                                            | N/A    |
| 9             | VSSD          | G    | Digital Ground.                                                                                                     | N/A    |
| 10            | GPIO<13>/RDET | I/O* | General Purpose IO Pin.                                                                                             | 4/8mA  |
| 11            | DO/GPIO<0>    | I/O  | Flash interface data out. Alternatively General Purpose IO Pin.                                                     | 4/8mA  |
| 12            | CLK/GPIO<1>   | I/O  | Flash interface clock. Alternatively General Purpose IO Pin.                                                        | 4/8mA  |
| 13            | CSB           | 0    | Flash interface chip select bar.                                                                                    | 4/8mA  |
| 14            | DI            | I    | Flash interface data in.                                                                                            | 4/8mA  |
| 15            | GPIO<4>/SDO   | I/O* | General Purpose IO Pin. Serial Data Out for the I2S interface.                                                      | 8/16mA |
| 16            | GPIO<5>/WS    | I/O* | General Purpose IO Pin. Word Select (WS) output for the I2S Interface                                               | 8/16mA |
| 17            | GPIO<6>/SCK   | I/O* | General Purpose IO Pin. Serial Clock output for the I2S Interface                                                   | 8/16mA |
| 18            | GPIO<7>/SDI   | I/O* | General Purpose IO Pin. Serial Data Input (SDI) input pin for the I2S Interface.                                    | 8/16mA |
| 19            | GPIO<8>/SDO1  | I/O* | General Purpose IO Pin. Secondary Serial Data Out for the I2S interface.                                            | 4/8mA  |
| 20            | GPIO<9>SDI1   | I/O* | General Purpose IO Pin. Secondary Serial Data Input (SDI) input pin for the I2S Interface.                          | 4/8mA  |

# nuvoTon

| 21 | GPIO<10>      | I/O* | General Purpose IO Pin.                                                                                                          | 4/8mA |
|----|---------------|------|----------------------------------------------------------------------------------------------------------------------------------|-------|
| 22 | GPIO<11>      | I/O* | General Purpose IO Pin or the Ring Detect input (RDET).                                                                          | 4/8mA |
| 23 | GPIO<12>      | I/O* | General Purpose IO Pin.                                                                                                          | 4/8mA |
| 24 | AUXOUT        | 0    | Auxiliary output from PSTN or SPEAKER DAC.                                                                                       | N/A   |
| 25 | VSSA          | G    | Analog Ground Pin                                                                                                                | N/A   |
| 26 | SPKN          | 0    | Negative speaker driver output                                                                                                   | N/A   |
| 27 | PO-           | 0    | Negative line driver output                                                                                                      | N/A   |
| 28 | VCCA          | Р    | Analog Power Pin                                                                                                                 | N/A   |
| 29 | PO+           | 0    | Positive line driver output                                                                                                      | N/A   |
| 30 | SPKP          | 0    | Positive speaker driver output                                                                                                   | N/A   |
| 31 | VSSA          | G    | Analog Ground Pin                                                                                                                | N/A   |
| 32 | MCGND         | I    | Analog ground pin for MIC. This pin should be connected to a quiet VSSA and used as the return for microphones connected to MCP. | N/A   |
| 33 | MCO           | I/O  | MIC feedback signal                                                                                                              | N/A   |
| 34 | MCP           | I    | Positive MIC signal input.                                                                                                       | N/A   |
| 35 | VBG           | I/O  | Voltage reference, a 100nF capacitor should be connected to this pin.                                                            | N/A   |
| 36 | VMID          | I/O  | Voltage reference, a 4.7uF capacitor should be connected to this pin.                                                            | N/A   |
| 37 | TI1P          | I    | PSTN Line #1 positive input                                                                                                      | N/A   |
| 38 | TI1N          | I    | PSTN Line #1 negative input                                                                                                      | N/A   |
| 39 | TI2P          | I    | PSTN Line #2 positive input                                                                                                      | N/A   |
| 40 | TI2N          | I    | PSTN Line #2 negative input                                                                                                      | N/A   |
| 41 | GPIO<15>/RDET | I/O* | General Purpose IO Pin. Can be configured as Ring Detect (RDET) input.                                                           | 4/8mA |
| 42 | GPIO<16>/RDET | I/O* | General Purpose IO Pin. Can be configured as Ring Detect (RDET) input.                                                           | 4/8mA |
| 43 | MISO          | 0    | SPI slave serial data output from the ISD61S00 to the host. This pin is tri-stated when SSB=1.                                   | 4/8mA |
| 44 | SCLK          | I    | SPI serial Clock input to the ISD61S00 from the host.                                                                            | N/A   |
| 45 | SSB           | I    | Slave select input to the ISD61S00 from the host                                                                                 | N/A   |
| 46 | MOSI          | I    | SPI slave serial data input to the ISD61S00 from the host.                                                                       | 4/8mA |
|    |               | P    | 1                                                                                                                                |       |



| 47 | RDY/BSYB | 0 | This pin is at VCCD when the chip is ready to accept a new command/data and is at VSSD when device is busy. |  |
|----|----------|---|-------------------------------------------------------------------------------------------------------------|--|
| 48 | NC       |   | Gh -                                                                                                        |  |

<sup>\*</sup> Default state for digital I/O pins is input with internal pull-up [38Kohms to 83Kohms] to VCCD supply

Publication Release Date: March 10, 2011 Revision 2.7

- 15 -

#### 5. BLOCK DIAGRAM



Figure 5-1 ISD61S00 Block Diagram



#### 6. CONFIGURATION REGISTER MAP

# 6.1 Configuration Register Groups

|                                          |  | •      |                                        |
|------------------------------------------|--|--------|----------------------------------------|
| Data memory address Size (Byte) Usage AL |  | (Byte) | Function                               |
|                                          |  | ALL    | T diletion                             |
| 0x000 ~ 0x0FF                            |  | 256    | Device Control Registers               |
| 0x110 ~ 0x13F                            |  | 32     | Gain stage and Mixer Control Registers |
| 0x140 ~ 0x14F                            |  | 16     | Air CODEC Control                      |
| 0x150 ~ 0x15F                            |  | 16     | Line CODEC Control                     |
| 0x160 ~ 0x17F                            |  | 32     | FSK Encoder Control                    |
| 0x180 ~ 0x19F                            |  | 32     | FSK Decoder Control                    |
| 0x1A0 ~ 0x1AF                            |  | 16     | Ringer Tone(PWM) Control Registers     |
| 0x1B0 ~ 0x1BF                            |  | 16     | Ring Detection PPM Control             |
| 0x1CO ~ 0x1DF                            |  | 32     | DTMF and Tone Generation               |
| 0x1E0 ~ 0x1EF                            |  | 16     | DTMF Detection Control                 |
| 0x1F0 ~ 0x1FF                            |  | 16     | Voice Energy Detection Control         |
| 0x200 ~ 0x27F                            |  | 128    | CAS Detection Control                  |
| 0x280 ~ 0x28F                            |  | 16     | CPT Detector Control                   |
| 0x290 ~ 0x29F                            |  | 16     | Timer Control                          |
| 0x300 ~ 0x3FF                            |  | 256    | AEC/LEC Control                        |

### 6.2 Register Map

| Addr. | Name     | Mode | Value<br>At<br>Reset | Function                |              |
|-------|----------|------|----------------------|-------------------------|--------------|
| 0x000 | AUD      | R/W  | 0x64                 | Compression & SR ctrl   | <u>8.2.1</u> |
| 0x001 | REG1     | R/W  | 0x00                 | Compression Control     | 8.2.2        |
| 0x002 | REG2     | R/W  | 0x00                 | Compression Source      | 8.2.3        |
| 0x003 | REG3     | R/W  | 0x03                 | Clock Control           | <u>8.2.4</u> |
| 0x004 | TI_GAIN  | R/W  | 0x00                 | Input Amplifier Gain    | <u>8.8.1</u> |
| 0x005 | TI_CTRL  | R/W  | 0x00                 | Input Amplifier Control | 8.8.2        |
| 0x006 | MIC_CTRL | R/W  | 0x00                 | MIC Interface Control   | <u>8.7.1</u> |

# nuvoTon

| Addr. | Name         | Mode | Value<br>At<br>Reset | Function                  |               |
|-------|--------------|------|----------------------|---------------------------|---------------|
| 0x007 | MIC_BIAS     | R/W  | 0x00                 | MIC Interface Bias        | 8.7.2         |
| 0x008 | ANA_OUT      | R/W  | 0x00                 | Analog Output Control     | <u>8.9.1</u>  |
| 0x009 | ANA_CTRL     | R/W  | 0x10                 | Analog Control            | 8.8.2         |
| 0x00A | ID_OVR       | R/W  | 0x00                 | Memory Control            |               |
| 0x00B | PORT_CFG     | R/W  | 0x00                 | GPIO INT Ctrl             | 8.5.1         |
| 0x00C | PORTA_IE     | R/W  | 0x00                 | Port A INT Enable         | 8.5.2         |
| 0x00D | PORTB_IE     | R/W  | 0x00                 | Port B INT Enable         | 8.5.2         |
| 0x00E | PORTC_IE     | R/W  | 0x00                 | Port C INT Enable         | 8.5.2         |
| 0x00F | DPLL Control | R/W  | 0x00                 | Digital PLL Control       | 8.5.2         |
| 0x014 | IE0          | R/W  | 0xFF                 | INT Enable 0              | 8.5.3         |
| 0x015 | IE1          | R/W  | 0xFF                 | INT Enable 1              | 8.5.4         |
| 0x017 | UPDATE_MD    | R/W  | 0x01                 | Update Ctrl               | 8.2.5         |
| 0x018 | CHK_SUM_CTRL | R/W  | 0x01                 | Check sum control         | (((           |
| 0x019 | PORTA_DO     | R/W  | 0x00                 | Port A Dout               | <u>8.5.5</u>  |
| 0x01A | PORTA_OE     | R/W  | 0x00                 | Port A Output Enable      | <u>8.5.6</u>  |
| 0x01B | PORTA_PE     | R/W  | 0xFF                 | Port A Pull Enable        | 8.5.7         |
| 0x01C | PORTA_DI     | R    | NA                   | Port A Din                | <u>8.5.8</u>  |
| 0x01D | PORTA_PS     | R/W  | 0xFF                 | Port A pull Select        | <u>8.5.9</u>  |
| 0x01E | PORTA_DS     | R/W  | 0x00                 | Port A Drive Strength     | <u>8.5.10</u> |
| 0x01F | PORTA_AF     | R/W  | 0x03                 | Port A Alternate Function | <u>8.5.11</u> |
| 0x020 | R0_LSB       | R/W  | 0x00                 | Indirect reg R0 LSB       | <u>8.6</u>    |
| 0x021 | R0           | R/W  | 0x00                 | Indirect reg R0           | 8.6           |
| 0x022 | R1_LSB       | R/W  | 0x00                 | Indirect reg R1 LSB       | <u>8.6</u>    |
| 0x023 | R1           | R/W  | 0x00                 | Indirect reg R1           | 8.6           |
| 0x024 | R2_LSB       | R/W  | 0x00                 | Indirect reg R2 LSB       | <u>8.6</u>    |
| 0x025 | R2           | R/W  | 0x00                 | Indirect reg R2           | 8.6           |
| 0x026 | R3_LSB       | R/W  | 0x00                 | Indirect reg R3 LSB       | <u>8.6</u>    |
| 0x027 | R3           | R/W  | 0x00                 | Indirect reg R3           | <u>8.6</u>    |
| 0x028 | R4_LSB       | R/W  | 0x00                 | Indirect reg R4 LSB       | 8.6           |
| 0x029 | R4           | R/W  | 0x00                 | Indirect reg R4           | 8.6           |
| 0x02A | R5_LSB       | R/W  | 0x00                 | Indirect reg R5 LSB       | <u>8.6</u>    |
| 0x02B | R5           | R/W  | 0x00                 | Indirect reg R5           | 8.6           |
| 0x02C | R6_LSB       | R/W  | 0x00                 | Indirect reg R6 LSB       | 8.6           |
| 0x02D | R6           | R/W  | 0x00                 | Indirect reg R6           | 8.6           |

# nuvoTon

| Addr. | Name            | Mode | Value<br>At<br>Reset | Function                     |               |
|-------|-----------------|------|----------------------|------------------------------|---------------|
| 0x02E | R7_LSB          | R/W  | 0x00                 | Indirect reg R7 LSB          | <u>8.6</u>    |
| 0x02F | R7              | R/W  | 0x00                 | Indirect reg R7              | <u>8.6</u>    |
| 0x030 | PORTB_DO        | R/W  | 0x00                 | Port B Dout                  | <u>8.5</u>    |
| 0x031 | PORTB_OE        | R/W  | 0x00                 | Port B Output Enable         | <u>8.5</u>    |
| 0x032 | PORTB_PE        | R/W  | 0xFF                 | Port B Pull Enable           | <u>8.5</u>    |
| 0x033 | PORTB_DI        | R    | NA                   | Port B Din                   | <u>8.5</u>    |
| 0x034 | PORTB_PS        | R/W  | 0xFF                 | Port B pull Select           | <u>8.5</u>    |
| 0x035 | PORTB_DS        | R/W  | 0x00                 | Port B Drive Strength        | <u>8.5</u>    |
| 0x036 | PORTB_AF        | R/W  | 0x00                 | Port B Alternate Function    | <u>8.5.11</u> |
| 0x037 | PORTC_DO        | R/W  | 0x00                 | Port C Dout                  | 8.5           |
| 0x038 | PORTC_OE        | R/W  | 0x00                 | Port C Output Enable         | <u>8.5</u>    |
| 0x039 | PORTC_PE        | R/W  | 0xFF                 | Port C Pull Enable           | <u>8.5</u>    |
| 0x03A | PORTC_DI        | R    | NA                   | Port C Din                   | 8.5           |
| 0x03B | PORTC_PS        | R/W  | 0xFF                 | Port C pull Select           | 8.5           |
| 0x03C | PORTC_DS        | R/W  | 0x00                 | Port C Drive Strength        | 8.5           |
| 0x03D | PORTC_AF        | R/W  | 0xFC                 | Port C Alternate Function    | 8.5           |
| 0x040 | PLL_CLK         | R/W  | 0x20                 | PLL Clock Control            | 8.3.2         |
| 0x041 | PLL_K2          | R/W  | 0x00                 | PLL Fraction MSB             | 8.3.3         |
| 0x042 | PLL_K1          | R/W  | 0x00                 | PLL Fraction byte 1          | 8.3.3         |
| 0x043 | PLL_K0          | R/W  | 0x00                 | PLL Fraction LSB             | 8.3.3         |
| 0x044 | PLL_CTRL        | R/W  | 0x88                 | PLL Control Register         | 8.3.4         |
| 0x050 | PCM_CFG         | R/W  | 0x00                 | PCM Configuration            | 8.4.1         |
| 0x051 | PCM_TSLOTL      | R/W  | 0x01                 | Left Channel PCM MSB start   | 8.4.2         |
| 0x052 | PCM_TSLOTR      | R/W  | 0x11                 | Right Channel PCM MSB start  | 8.4.3         |
| 0x053 | PCM_COMP0       | R/W  | 0x00                 | PCM0 Compression             | 8.4.4         |
| 0x054 | PCM_TSLOTL1     | R/W  | 0x01                 | Left Channel PCM1 MSB start  | 8.4.5         |
| 0x055 | PCM_TSLOTR1     | R/W  | 0x11                 | Right Channel PCM1 MSB start | 8.4.6         |
| 0x056 | PCM_COMP1       | R/W  | 0x00                 | PCM1 Compression             | 8.4.7         |
| 0x057 | PCM_TX_SEL      | R/W  | 0x00                 | PCM Transmission Select      | 8.4.8         |
| 0x058 | PCM_RX_SEL      | R/W  | 0x00                 | PCM Receive Select           | 8.4.9         |
| 0x059 | CHKSUM SUM1 LSB | R    | 0x00                 | Chksum1[7:0]                 |               |
| 0x05A | CHKSUM SUM1     | R    | 0x00                 | Chksum1[15:8]                |               |
| 0x05B | CHKSUM SUM2 LSB | R    | 0x00                 | Chksum2[7:0]                 |               |
| 0x05C | CHKSUM SUM2     | R    | 0x00                 | Chksum2[15:8]                |               |

# nuvoTon

| Addr. | Name            | Mode | Value<br>At<br>Reset | Function                         |   |
|-------|-----------------|------|----------------------|----------------------------------|---|
| 0x05D | REC_MSG_LEN LSB | R/W  | 0x00                 | REC Message Sector Length [7:0]  |   |
| 0x05E | REC_MSG_LEN     | R/W  | 0x00                 | REC Message Sector Length [15:8] |   |
| 0x110 | GS_CTRL         | R/W  | 0x00                 | GS Control                       |   |
| 0x111 | GS_ACST         | R/W  | 0x40                 | Air CODEC Side tone              |   |
| 0x112 | GS_ACIG         | R/W  | 0x00                 | Air CODEC input Gain             |   |
| 0x113 | GS_ACOG         | R/W  | 0x00                 | Air CODEC output Gain            |   |
| 0x114 | GS_AEOG         | R/W  | 0x00                 | AEC Output Gain                  |   |
| 0x115 | GS_AEIG         | R/W  | 0x00                 | AEC Input Gain                   |   |
| 0x116 | GS_LCIG         | R/W  | 0x00                 | Line CODEC input Gain            |   |
| 0x117 | GS_LCOG         | R/W  | 0x00                 | Line CODEC output Gain           |   |
| 0x118 | GS_LEOG         | R/W  | 0x00                 | LEC Output Gain                  |   |
| 0x119 | GS_LEIG         | R/W  | 0x00                 | LEC Input Gain                   |   |
| 0x11A | GS_AOAI         | R/W  | 0x00                 | AEC out - AEC in Gain            | ) |
| 0x11B | GS_LOAI         | R/W  | 0x00                 | LEC out - AEC in Gain            |   |
| 0x11C | GS_PLAI         | R/W  | 0x00                 | PLAY - AEC in Gain               |   |
| 0x11D | GS_ILAI         | R/W  | 0x00                 | I2SL - AEC in                    |   |
| 0x11E | GS_IRAI         | R/W  | 0x00                 | I2SR - AEC in                    |   |
| 0x11F | GS_AOLI         | R/W  | 0x00                 | AEC out - LEC in Gain            |   |
| 0x120 | GS_LOLI         | R/W  | 0x00                 | LEC out - LEC in Gain            |   |
| 0x121 | GS_PLLI         | R/W  | 0x00                 | PLAY - LEC in Gain               |   |
| 0x122 | GS_ILLI         | R/W  | 0x00                 | I2SL - LEC in                    |   |
| 0x123 | GS_IRLI         | R/W  | 0x00                 | I2SR - LEC in                    |   |
| 0x124 | GS_AORI         | R/W  | 0x00                 | AEC out - REC in Gain            |   |
| 0x125 | GS_LORI         | R/W  | 0x00                 | LEC out - REC in Gain            |   |
| 0x126 | GS_PLRI         | R/W  | 0x00                 | PLAY - REC in Gain               |   |
| 0x127 | GS_ILRI         | R/W  | 0x00                 | I2SL - REC in                    |   |
| 0x128 | GS_IRRI         | R/W  | 0x00                 | I2SR - REC in                    |   |
| 0x129 | GS_AOIL         | R/W  | 0x00                 | AEC out - I2SL in Gain           |   |
| 0x12A | GS_LOIL         | R/W  | 0x00                 | LEC out - I2SL in Gain           |   |
| 0x12B | GS_PLIL         | R/W  | 0x00                 | PLAY - I2SL in Gain              |   |
| 0x12C | GS_ILIL         | R/W  | 0x00                 | 12SL - 12SL in                   |   |
| 0x12D | GS_IRIL         | R/W  | 0x00                 | I2SR - I2SL in                   |   |
| 0x12E | GS_AOIR         | R/W  | 0x00                 | AEC out - I2SR in Gain           |   |
| 0x12F | GS_LOIR         | R/W  | 0x00                 | LEC out - I2SR in Gain           | - |

# nuvoTon

| Addr. | Name         | Mode | Value<br>At<br>Reset | Function            |        |
|-------|--------------|------|----------------------|---------------------|--------|
| 0x130 | GS_PLIR      | R/W  | 0x00                 | PLAY - I2SR in Gain |        |
| 0x131 | GS_ILIR      | R/W  | 0x00                 | I2SL - I2SR in      |        |
| 0x132 | GS_IRIR      | R/W  | 0x00                 | I2SR - I2SR in      |        |
| 0x13B | MX_AEC       | R/W  | 0x00                 | AEC Mix Ctrl        |        |
| 0x13C | MX_LEC       | R/W  | 0x00                 | LEC Mix Ctrl        |        |
| 0x13D | MX_REC       | R/W  | 0x00                 | REC Mix Ctrl        |        |
| 0x13E | MX_ISL       | R/W  | 0x00                 | I2S_L Mix Ctrl      |        |
| 0x13F | MX_ISR       | R/W  | 0x00                 | I2S_R Mix Ctrl      |        |
| 0x140 | AC_EN        | R/W  | 0x20                 | Air CODEC Enable    |        |
| 0x141 | AC_CTRL      | R/W  | 0x07                 | Air CODEC Control   |        |
| 0x142 | AC_ADCG_MSB  | R/W  | 0x04                 | Air ADC Gain MSB    |        |
| 0x143 | AC_ADCG_LSB  | R/W  | 0x00                 | Air ADC Gain LSB    | )      |
| 0x144 | AC_DACG_MSB  | R/W  | 0x04                 | Air DAC Gain MSB    | (0)    |
| 0x145 | AC_DACG_LSB  | R/W  | 0x00                 | Air DAC Gain LSB    |        |
| 0x146 | AC_ADOUT_MSB | R    | NA                   | Air ADC Output MSB  |        |
| 0x147 | AC_ADOUT_LSB | R    | NA                   | Air ADC Output LSB  |        |
| 0x148 | AC_DAOUT_MSB | R    | NA                   | Air DAC Output MSB  |        |
| 0x149 | AC_DAOUT_LSB | R    | NA                   | Air DAC Output MSB  |        |
|       |              |      |                      |                     |        |
| 0x150 | LC_EN        | R/W  | 0x20                 | Line CODEC Enable   |        |
| 0x151 | LC_CTRL      | R/W  | 0x07                 | Line CODEC Control  |        |
| 0x152 | LC_ADCG_MSB  | R/W  | 0x04                 | Line ADC Gain MSB   |        |
| 0x153 | LC_ADCG_LSB  | R/W  | 0x00                 | Line ADC Gain LSB   |        |
| 0x154 | LC_DACG_MSB  | R/W  | 0x04                 | Line DAC Gain MSB   |        |
| 0x155 | LC_DACG_LSB  | R/W  | 0x00                 | Line DAC Gain LSB   |        |
| 0x156 | LC_ADOUT_MSB | R    | 0x00                 | Line ADC Dout       |        |
| 0x157 | LC_ADOUT_LSB | R    | 0x00                 | Line ADC Dout LSB   |        |
| 0x158 | LC_DAOUT_MSB | R    | 0x00                 | Line DAC Dout MSB   |        |
| 0x159 | LC_DAOUT_LSB | R    | 0x00                 | Line DAC Dout LSB   |        |
|       | SK C         |      |                      |                     |        |
| 0x160 | FSKE_CTRL1   | R/W  | 0x00                 | FSK Encoder Control | 8.12.1 |
| 0x161 | FSKE_CTRL2   | R/W  | 0x23                 | FSK Encoder Control | 8.12.2 |

# nuvoTon

| Addr. | Name                       | Mode | Value<br>At<br>Reset | Function                             |         |
|-------|----------------------------|------|----------------------|--------------------------------------|---------|
| 0x162 | FSKE_FIFO_W                | V    | NA                   | FSK Encoder FIFO input               | 8.12.3  |
| 0x163 | FSKE_STATUS                | R    | 0x20                 | FSK Encoder Status                   | 8.12.4  |
| 0x164 | FSKE_GAIN                  | R/W  | 0x39                 | FSK Encoder Signal Gain              | 8.12.5  |
| 0x165 | FSKE_PROG                  | R/W  | 0x00                 | FSK Encoder Programmable mode        | 8.12.6  |
| 0x166 | FSKE_BAUD_2                | R/W  | 0x00                 | FSK Encoder Baud Rate                | 8.12.7  |
| 0x167 | FSKE_BAUD_1                | R/W  | 0x00                 | FSK Encoder Baud Rate                | 8.12.7  |
| 0x168 | FSKE_BAUD_0                | R/W  | 0x00                 | FSK Encoder Baud Rate                | 8.12.7  |
| 0x169 | FSKE_MARK_1                | R/W  | 0x00                 | FSK Encoder Mark Freq                | 8.12.8  |
| 0x16A | FSKE_MARK_0                | R/W  | 0x00                 | FSK Encoder Mark Freq                | 8.12.8  |
| 0x16B | FSKE_SPACE_1               | R/W  | 0x00                 | FSK Encoder Space Freq               | 8.12.9  |
| 0x16C | FSKE_SPACE_0               | R/W  | 0x00                 | FSK Encoder Space Freq               | 8.12.9  |
|       |                            |      |                      | 2 1 1 1 C                            | )       |
|       |                            |      |                      | 42                                   | 99)     |
| 0x180 | FSKD_CTRL                  | R/W  | 0x00                 | FSK Decoder Control                  | 8.13.1  |
| 0x181 | FSKD_MODE                  | R/W  | 0x04                 | FSK Decoder Mode                     | 8.13.2  |
| 0x182 | FSKD_ADJUST                | R/W  | 0xC0                 | FSK Decoder Spec Adjustment          | 8.13.3  |
| 0x183 | FSKD_STATUS                | R    | 0x02                 | FSK Decoder Status                   | 8.13.4  |
| 0x184 | FSKD_THRES_MSB             | R/W  | 0x00                 | FSK Decoder Hysteresis MSB           | 8.13.5  |
| 0x185 | FSKD_THRES_LSB             | R/W  | 0x80                 | FSK Decoder Hysteresis LSB           | 8.13.5  |
| 0x186 | FSKD_JUDGE                 | R/W  | 0x04                 | FSK Decoder judge threshold          | 8.13.6  |
| 0x187 | FSKD_SYNC                  | R/W  | 0x02                 | FSK Decoder Sync                     | 8.13.7  |
| 0x188 | FSKD_CDET                  | R/W  | 0x03                 | FSK Decoder Carrier Detect           | 8.13.8  |
| 0x189 | FSKD_FIFO_CTRL             | R/W  | 0x00                 | FSK Decoder FIFO control             | 8.13.9  |
| 0x18A | FSKD_FIFO_DOUT             | V    | NA                   | FSK Decoder FIFO Data                | 8.13.10 |
| 0x18B | FSKD_FIFO_STATUS           | R    | 0x01                 | FSK Decoder FIFO Status              | 8.13.11 |
| 0x18C | FSKD_ENERGY_HI_TH          | R/W  | 0x0C                 | FSK Decoder Carrier Energy Threshold | 8.13.12 |
| 0x18D | FSKD_ENERGY_LO_TH          | R/W  | 0x06                 | FSK Decoder Carrier Energy Threshold | 8.13.13 |
| 0x18E | FSKD_ENERGY_TC             | R/W  | 0x40                 | FSK Decoder Energy time constant     | 8.13.14 |
|       | G3/ 72.                    |      |                      |                                      |         |
| 0x190 | FSKD_CDB_FREQ_LOW_CNT      | R/W  | 0x2F                 | FSK Carrier Detect Frequency Adjust  | 8.13.16 |
| 0x191 | FSKD_CDB_FREQ_LOW_CNT_LSB  | R/W  | 0x14                 | FSK Carrier Detect Frequency Adjust  | 8.13.16 |
| 0x192 | FSKD_CDB_FREQ_HIGH_CNT     | R/W  | 0x23                 | FSK Carrier Detect Frequency Adjust  | 8.13.17 |
| 0x193 | FSKD_CDB_FREQ_HIGH_CNT_LSB | R/W  | 0xF5                 | FSK Carrier Detect Frequency Adjust  | 8.13.17 |
| 0x194 | FSKD_LIMIT_TH              | R/W  | 0xFF                 | FSK Signal Clamp Threshold           | 8.13.18 |

# nuvoTon

|           | Function                                       | Value<br>At<br>Reset | Mode | Name                | Addr.           |
|-----------|------------------------------------------------|----------------------|------|---------------------|-----------------|
| 8.21.1    | PWM Operation Clock Enable                     | 0x00                 | R/W  | PWM Clock           | 0x1A0           |
| 8.21.2    | PWM Tone1 Control                              | 0x00                 | R/W  | PWM Tone1 Control   | 0x1A2           |
| 8.21.3    | PWM Tone1 Frequency                            | 0x00                 | R/W  | PWM Tone1 Frequency | 0x1A3           |
| 8.21.4    | PWM Tone2 Control                              | 0x00                 | R/W  | PWM Tone2 Control   | 0x1A4           |
| 8.21.5    | PWM Tone2 Frequency                            | 0x00                 | R/W  | PWM Tone2 Frequency | 0x1A5           |
| 8.17.1    | Ring Det. Control                              | 0x00                 | R/W  | RNG_CTRL            | 0x1B0           |
| 8.17.2    | Ring Det. State                                | 0x00                 | R    | RNG_STATE           | 0x1B1           |
| 8.17.3    | Ring Det. Counter                              | 0x00                 | R    | RNG_CNTR_MSB        | 0x1B2           |
| 8.17.3    | Ring Det. Counter                              | 0x00                 | R    | RNG_CNTR_LSB        | 0x1B3           |
| 8.17.4    | Ring Det. Counter latch control                | 0x00                 | R/W  | RNG_LATCH           | 0x1B4           |
| 8.11.1    | Tone Generator Control                         | 0x00                 | R/W  | TONE CTRL           | 0x1C0           |
| 8.11.2    | Tone Frequency A                               | 0x00                 | R/W  | TONE_FREQ_A_MSB     | 0x1C1           |
| 8.11.2    | Tone Frequency A                               | 0x00                 | R/W  | TONE FREQ A LSB     | 0x1C2           |
| 8.11.3    | Tone Frequency B                               | 0x00                 | R/W  | TONE_FREQ_B_MSB     | 0x1C3           |
| 8.11.3    | Tone Frequency B                               | 0x00                 | R/W  | TONE_FREQ_B_LSB     | 0x1C4           |
| 8.11.4    | Tone Level A                                   | 0x00                 | R/W  | TONE_LEVEL_A        | 0x1C5           |
| 8.11.5    | Tone Level B                                   | 0x00                 | R/W  | TONE_LEVEL_B        | 0x1C6           |
| 8.11.6    | Present (on) time of each tone.                | 0x00                 | R/W  | TONE_ON_TIME        | 0x1C7           |
| 8.11.7    | Absent (off) time of each tone.                | 0x00                 | R/W  | TONE_OFF_TIME       | 0x1C8           |
| to 8.11.8 | The number of DTMF digits or tones to generate | 0x00                 | R/W  | TONE_BUF_LEN        | 0x1C9           |
|           |                                                |                      |      |                     | 3               |
| 8.11.10   | Tone Buffer 0x1D0-0x1DB                        | 0x00                 | R/W  | TONE_BUFFER         | 0x1D0-<br>0x1DB |
| 8.10.1    | DTMF Det. Control                              | 0x00                 | R/W  | DTMF_CTRL           | 0x1E0           |
| 8.10.2    | DTMF Det. FIFO Control                         | 0x40                 | R/W  | DTMF_FIFO_CTRL      | 0x1E1           |
| 8.10.3    | DTMF Det. FIFO Information                     | 0x00                 | R    | DTMF_FIFO           | 0x1E2           |
| 8.10.4    | DTMF Det. FIFO Status                          | 0x01                 | R/W  | DTMF_FIFO_STATUS    | 0x1E3           |
| 8.10.5    | DTMF Det. Threshold MSB                        | 0x01                 | R/W  | DTMF_THRES_MSB      | 0x1E4           |
| 8.10.5    | DTMF Det. Threshold LSB                        | 0x00                 | R/W  | DTMF_THRES_LSB      | 0x1E5           |
| 8.10.6    | DTMF Det. Present Detect Time                  | 0x00                 | R/W  | DTMF_PDT            | 0x1E6           |
| 8.10.7    | DTMF Det. Absent Detect Time                   | 0x00                 | R/W  | DTMF_ADT            | 0x1E7           |
| 8.10.8    | DTMF Det. Accept Time                          | 0x00                 | R/W  | DTMF_ACCT           | 0x1E8           |

# nuvoTon

| Addr.           | Name              | Mode | Value<br>At<br>Reset | Function                                       |         |
|-----------------|-------------------|------|----------------------|------------------------------------------------|---------|
| 0x1EA           | DTMF_RX_DATA      | R    | 0x00                 | DTMF Det. Received Data                        | 8.10.10 |
| 0x1EB           | DTMF_RFREQ_MSB    | R    | 0x00                 | DTMF Det. Row Frequency MSB                    | 8.10.11 |
| 0x1EC           | DTMF_RFREQ_LSB    | R    | 0x00                 | DTMF Det. Row Frequency LSB                    | 8.10.11 |
| 0x1ED           | DTMF_CFREQ_MSB    | R    | 0x00                 | DTMF Det. Column Frequency MSB                 | 8.10.12 |
| 0x1EE           | DTMF_CFREQ_LSB    | R    | 0x00                 | DTMF Det. Column Frequency LSB                 |         |
| 0x1F0           | VD_CTRL           | R/W  | 0x00                 | Voice Det. Control                             |         |
| 0x1F1           | VD_STATUS         | R    | 0x00                 | Voice Det. Status                              |         |
| 0x1F2           | VD_THRES_MSB      | R/W  | 0x01                 | Voice Det. Threshold MSB                       |         |
| 0x1F3           | VD_THRES_LSB      | R/W  | 0x00                 | Voice Det. Threshold LSB                       |         |
| 0x1F4           | VD_ENERGY_MSB     | R    | 0x00                 | Voice Det. Energy MSB                          |         |
| 0x1F5           | VD_ENERGY_LSB     | R    | 0x00                 | Voice Det. Energy LSB                          |         |
| 0x200           | CAS_CTRL          | R/W  | 0x40                 | CAS Control                                    |         |
| 0x201           | CAS_THRES_LOW     | R/W  | 0x00                 | CAS Low Threshold                              | 3)      |
| 0x202           | CAS_THRES_LOW_LSB | R/W  | 0x00                 | CAS Low Threshold                              |         |
| 0x203           | CAS_MULT          | R/W  | 0x11                 | CAS High Threshold Multiplier                  |         |
| 0x204           | CAS_PRESENT       | R/W  | 0x40                 | CAS Present Time                               |         |
| 0x205           | CAS_ABSENT        | R/W  | 0x20                 | CAS Absent Time                                |         |
| 0x206           | CAS_STATUS        | R    | 0x00                 | CAS Status                                     |         |
| 0x207           | CAS_MODE          | R/W  | 0x10                 | CAS or Arbitrary Tone Detection Mode           |         |
| 0x208           | ATD_MAX_HFC       | R/W  | 0x01                 | ATD Max High Frequency Cnt                     |         |
| 0x209           | ATD_MAX_HFC_LSB   | R/W  | 0x10                 | ATD Max High Frequency Cnt                     |         |
| 0x20A           | ATD_MIN_HFC       | R/W  | 0x01                 | ATD Min High Frequency Cnt                     |         |
| 0x20B           | ATD_MIN_HFC_LSB   | R/W  | 0x20                 | ATD Min High Frequency Cnt                     |         |
| 0x20C           | ATD_MAX_LFC       | R/W  | 0x01                 | ATD Max Low Frequency Cnt                      |         |
| 0x20D           | ATD_MAX_LFC_LSB   | R/W  | 0x61                 | ATD Max Low Frequency Cnt                      |         |
| 0x20E           | ATD_MIN_LFC       | R/W  | 0x01                 | ATD Min Low Frequency Cnt                      |         |
| 0x20F           | ATD_MIN_LFC_LSB   | R/W  | 0x6F                 | ATD Min Low Frequency Cnt                      |         |
| 0x210-<br>0x241 | ATD_HF_COEFF      | R/W  | 0x00                 | ATD High Frequency IIR coefficient 0x210~0x241 |         |
| 0x242-<br>0x273 | ATD_LF_COEFF      | R/W  | 0x00                 | ATD Low Frequency IIR coefficient 0x242~0x273  |         |
| 0x274           | FSK_COEFF         | R/W  | 0x00                 | FSK IIR Coefficient                            |         |
| 0x275           | FSK_COEFF_ADDR    | R/W  | 0x00                 | FSK IIR Coefficient Address                    |         |
| 0x276           | CAS_MAX_HFC       | R/W  | 0x01                 | CAS Max High Frequency Cnt                     |         |
| 0x277           | CAS_MAX_HFC_LSB   | R/W  | 0x0E                 | CAS Max High Frequency Cnt                     |         |

# nuvoTon

| Addr. | Name                     | Mode | Value<br>At<br>Reset | Function                                 |     |
|-------|--------------------------|------|----------------------|------------------------------------------|-----|
| 0x278 | CAS_MIN_HFC              | R/W  | 0x01                 | CAS Min High Frequency Cnt               |     |
| 0x279 | CAS_MIN_HFC_LSB          | R/W  | 0x21                 | CAS Min High Frequency Cnt               |     |
| 0x27A | CAS_MAX_LFC              | R/W  | 0x01                 | CAS Max Low Frequency Cnt                |     |
| 0x27B | CAS_MAX_LFC_LSB          | R/W  | 0x5D                 | CAS Max Low Frequency Cnt                |     |
| 0x27C | CAS_MIN_LFC              | R/W  | 0x01                 | CAS Min Low Frequency Cnt                |     |
| 0x27D | CAS_MIN_LFC_LSB          | R/W  | 0x75                 | CAS Min Low Frequency Cnt                |     |
|       |                          |      |                      | 90.40                                    |     |
|       |                          |      |                      |                                          |     |
| 0x280 | CPT_CTRL                 | R/W  | 0x07                 | CPT Control                              |     |
| 0x281 | CPT_STATUS               | R    | 0x00                 | CPT Status                               |     |
| 0x282 | CPT_THRES_H_MSB          | R/W  | 0x24                 | CPT High Threshold MSB                   |     |
| 0x283 | CPT_THRES_H_LSB          | R/W  | 0x00                 | CPT High Threshold LSB                   | 2   |
| 0x284 | CPT_THRES_L_MSB          | R/W  | 0x1A                 | CPT Low Threshold MSB                    | 2)) |
| 0x285 | CPT_THRES_L_LSB          | R/W  | 0x00                 | CPT Low Threshold LSB                    |     |
| 0x286 | CPT_ENERGY_MSB           | R    | 0x00                 | CPT Energy MSB                           |     |
| 0x287 | CPT_ENERGY_LSB           | R    | 0x00                 | CPT Energy LSB                           |     |
| 0x290 | TIME_CTRL                | R/W  | 0x00                 | Timer Control                            |     |
| 0x292 | TIME_TARG_MSB            | R/W  | 0x00                 | Timer Target Counter MSB                 |     |
| 0x293 | TIME_TARG_LSB            | R/W  | 0x00                 | Timer Target Counter LSB                 |     |
| 0x294 | TIME_CNT_MSB             | R    | 0x00                 | Timer Current Counter MSB                |     |
| 0x295 | TIME_CNT_LSB             | R    | 0x00                 | Timer Current Counter LSB                |     |
| 0x300 | AEC_CONFIG               | R/W  | 0x96                 | AEC Configuration                        |     |
| 0x301 | AEC_RESET                | R/W  | 0xE8                 | AEC Reset                                |     |
| 0x302 | AEC_EC_BELTA             | R/W  | 0x03                 | AEC EC BELTA                             |     |
| 0x303 | AEC_AS_COEFF             | R/W  | 0x14                 | AEC AS Coefficient                       |     |
| 0x305 | AEC_DT_LONG_TC           | R/W  | 0x09                 | AEC Double Talk long term time constant  |     |
| 0x306 | AEC_DT_SHORT_TC          | R/W  | 0xBB                 | AEC Double Talk short term time constant |     |
| 0x307 | AEC_DT_HANGOVER_TIME_MSB | R/W  | 0x00                 | AEC Double Talk Detector Parameters      |     |
| 0x308 | AEC_DT_HANGOVER_TIME_LSB | R/W  | 0x20                 | AEC Double Talk Detector Parameters      |     |
| 0x309 | AEC_DT_DV_THRESH_MSB     | R/W  | 0x19                 | AEC Double Talk Detector Parameters      |     |
| 0x30A | AEC_DT_DV_THRESH_LSB     | R/W  | 0x98                 | AEC Double Talk Detector Parameters      |     |
| 0x30B | AEC_DT_LONG_THRESH_MSB   | R/W  | 0x00                 | AEC Double Talk Detector Parameters      |     |
| 0x30C | AEC_DT_LONG_THRESH_LSB   | R/W  | 0x00                 | AEC Double Talk Detector Parameters      |     |
| 0x30D | AEC_DT_SHORT_THRESH_MSB  | R/W  | 0x10                 | AEC Double Talk Detector Parameters      |     |

# nuvoTon

| Addr. | Name                        | Mode | Value<br>At<br>Reset | Function                                        |     |
|-------|-----------------------------|------|----------------------|-------------------------------------------------|-----|
| 0x30E | AEC_DT_SHORT_THRESH_LSB     | R/W  | 0x10                 | AEC Double Talk Detector Parameters             |     |
| 0x30F | AEC_DIVERGENCE              | R/W  | 0x0F                 | AEC DIVERGENCE THRESHOLD                        |     |
| 0x310 | AEC_VD_LONG_TC              | R/W  | 0x09                 | AEC Voice Detect Long Time Constant             |     |
| 0x311 | AEC_VD_SHORT_TC             | R/W  | 0xBB                 | AEC Voice Detect Short Time Constant            |     |
| 0x312 | AEC_VD_HANGOVER_TIME_MSB    | R/W  | 0x00                 | AEC Voice Detect Parameters                     |     |
| 0x313 | AEC_VD_HANGOVER_TIME_LSB    | R/W  | 0x09                 | AEC Voice Detect Parameters                     |     |
| 0x314 | AEC_VD_DEV_THRESHOLD_MSB    | R/W  | 0x19                 | AEC Voice Detect Parameters                     |     |
| 0x315 | AEC_VD_DEV_THRESHOLD_LSB    | R/W  | 0x98                 | AEC Voice Detect Parameters                     |     |
| 0x316 | AEC_VD_LONG_THRESH_MSB      | R/W  | 0x19                 | AEC Voice Detect Parameters                     |     |
| 0x317 | AEC_VD_LONG_THRESH_LSB      | R/W  | 0x98                 | AEC Voice Detect Parameters                     |     |
| 0x318 | AEC_VD_SHORT_THRESH_MSB     | R/W  | 0x0B                 | AEC Voice Detect Parameters                     |     |
| 0x319 | AEC_VD_SHORT_THRESH_LSB     | R/W  | 0x38                 | AEC Voice Detect Parameters                     | )   |
| 0x31A | AEC_CUT_OFF_POWER_MSB       | R/W  | 0x19                 | AEC Voice Detect Parameters                     | (0) |
| 0x31B | AEC_CUT_OFF_POWER_LSB       | R/W  | 0x98                 | AEC Voice Detect Parameters                     |     |
| 0x31D | AEC_VD_AVE_TC               | R/W  | 0x0B                 | AEC VD Average Time Constant                    |     |
| 0x31E | AEC_VD_AVE_THRESH_MSB       | R/W  | 0x00                 | AEC VD Average Threshold                        |     |
| 0x31F | AEC_VD_AVE_THRESH_LSB       | R/W  | 0x00                 | AEC VD Average Threshold                        |     |
| 0x320 | AEC_AS1_BUILD_UP_TIME       | R/W  | 0x77                 | AEC AS1 Built Up Time                           |     |
| 0x321 | AEC_AS1_MAX_ATTEN_MSB       | R/W  | 0x1C                 | AEC AS1 Max Attenuation value(MSB)              |     |
| 0x322 | AEC_AS1_MAX_ATTEN_LSB       | R/W  | 0xA8                 | AEC AS1 Max Attenuation value(LSB)              |     |
| 0x323 | AEC_AS2_BUILD_UP_TIME       | R/W  | 0x77                 | AEC AS2 Built Up Time                           |     |
| 0x324 | AEC_AS2_MAX_ATTEN_MSB       | R/W  | 0x1C                 | AEC AS2 Max Attenuation value(MSB)              |     |
| 0x325 | AEC_AS2_MAX_ATTEN_LSB       | R/W  | 0xAB                 | AEC AS2 Max Attenuation value(LSB)              |     |
| 0x328 | AEC_NS_POWER_ATTACK_TC      | R/W  | 0xBB                 | AEC Noise Suppressor power attack time constant |     |
| 0x329 | AEC_NS_ATTEN_TC             | R/W  | 0xBB                 | AEC NS Attenuation Time Constant                |     |
| 0x32A | AEC_NS_ACTIVE_THRESHOLD_MSB | R/W  | 0x03                 | AEC NS Active threshold (MSB)                   |     |
| 0x32B | AEC_NS_ACTIVE_THRESHOLD_LSB | R/W  | 0xE8                 | AEC NS Active threshold (LSB)                   |     |
| 0x32C | AEC_NO_VOICE_THRESH_MSB     | R/W  | 0x14                 | AEC NO Voice Threshold MSB                      |     |
| 0x32D | AEC_NO_VOICE_THRESH_LSB     | R/W  | 0x08                 | AEC NO Voice Threshold LSB                      |     |
|       | 40_40_                      |      |                      |                                                 |     |
|       |                             |      |                      |                                                 |     |
| 0x330 | AGC_THRES_MSB               | R/W  | 0x20                 | AGC THRESHOLD MSB                               |     |
| 0x331 | AGC_THRES_LSB               | R/W  | 0x00                 | AGC THRESHOLD LSB                               |     |

# nuvoTon

| Addr. | Name                        | Mode | Value<br>At<br>Reset | Function                             |  |
|-------|-----------------------------|------|----------------------|--------------------------------------|--|
| 0x332 | AGC_NOISE_THRES_MSB         | R/W  | 0x03                 | AGC NOISE THRESHOLD MSB              |  |
| 0x333 | AGC_NOISE_THRES_LSB         | R/W  | 0x20                 | AGC NOISE THRESHOLD LSB              |  |
| 0x334 | AGC_MAX_SG                  | R/W  | 0x02                 | AGC MAX SG                           |  |
| 0x335 | AGC_LATK_TC                 | R/W  | 0xbb                 | AGC LATK TC Constant                 |  |
| 0x336 | AGC_SATK_TC                 | R/W  | 0x09                 | AGC SATK Time Constant               |  |
| 0x338 | AEC_VD_SC_CTRL              | R/W  | 0x00                 | AEC VD SC Control                    |  |
| 0x339 | AEC_VD_SC_NORMAL_INDEX      | R/W  | 0x00                 | AEC VD SC NORMAL INDEX               |  |
| 0x33A | AEC_VD_SC_LOW_INDEX         | R/W  | 0x00                 | AEC VD SC LOW INDEX                  |  |
| 0x33B | AEC_VD_SC_THRESH_MSB        | R/W  | 0x10                 | AEC VD SC Threshold MSB              |  |
| 0x33C | AEC_VD_SC_THRESH_LSB        | R/W  | 0x00                 | AEC VD SC Threshold LSB              |  |
| 0x33D | AEC_VD_SC_POWER_ATTACK_TC   | R/W  | 0x07                 | AEC VD SC Power Attack Time Constant |  |
| 0x33E | AEC_VD_SC_GAIN_TC           | R/W  | 0x07                 | AEC VD SC GAIN Time Constant         |  |
| 0x340 | AEC_DT_SHORT_TERM_POWER_MSB | R    | NA                   | AEC DT Short Term Power MSB          |  |
| 0x341 | AEC_DT_SHORT_TERM_POWER_LSB | R    | NA                   | AEC DT Short Term Power LSB          |  |
| 0x342 | AEC_DT_LONG_TERM_POWER_MSB  | R    | NA                   | AEC DT Long Term Power MSB           |  |
| 0x343 | AEC_DT_LONG_TERM_POWER_LSB  | R    | NA                   | AEC DT Long Term Power LSB           |  |
| 0x344 | AEC_DT_POWER_DEVIATION_MSB  | R    | NA                   | AEC DT POWER Deviation MSB           |  |
| 0x345 | AEC_DT_POWER_DEVIATION_LSB  | R    | NA                   | AEC DT POWER Deviation LSB           |  |
| 0x346 | AEC_DT_ACTIVE               | R    | NA                   | AEC DT Active                        |  |
| 0x348 | AEC_VD_SHORT_TERM_POWER_MSB | R    | NA                   | AEC VD Short Term Power MSB          |  |
| 0x349 | AEC_VD_SHORT_TERM_POWER_LSB | R    | NA                   | AEC VD Short Term Power LSB          |  |
| 0x34A | AEC_VD_LONG_TERM_POWER_MSB  | R    | NA                   | AEC VD Long Term Power MSB           |  |
| 0x34B | AEC_VD_LONG_TERM_POWER_LSB  | R    | NA                   | AEC VD Long Term Power LSB           |  |
| 0x34C | AEC_VD_POWER_DEVIATION_MSB  | R    | NA                   | AEC VD Power Deviation MSB           |  |
| 0x34D | AEC_VD_POWER_DEVIATION_LSB  | R    | NA                   | AEC VD Power Deviation LSB           |  |
| 0x34E | AEC_VD_ACTIVE               | R    | NA                   | AEC VD Active                        |  |
| 0x350 | AEC_LRIN[15:8]              | R    | NA                   | AEC LRIN MSB                         |  |
| 0x351 | AEC_LRIN[7:0]               | R    | NA                   | AEC LRIN LSB                         |  |
| 0x352 | AEC_EOUT[15:8]              | R    | NA                   | AEC EOUT MSB                         |  |
| 0x353 | AEC_EOUT[7:0]               | R    | NA                   | AEC EOUT LSB                         |  |
| 0x354 | AEC_ASOUT15:8]              | R    | NA                   | AEC ASOUT MSB                        |  |
| 0x355 | AEC_ASOUT[7:0]              | R    | NA                   | AEC ASOUT LSB                        |  |
| 0x356 | AEC_ASIN[15:8]              | R    | NA                   | AEC ASIN MSB                         |  |
| 0x357 | AEC_ASIN[7:0]               | R    | NA                   | AEC ASIN LSB                         |  |

# nuvoTon

| Addr. | r. Name              |     | Value<br>At<br>Reset | Function                |  |
|-------|----------------------|-----|----------------------|-------------------------|--|
| 0x358 | AEC_LSOUT[15:8]      | R   | NA                   | AEC LSOUT MSB           |  |
| 0x359 | AEC_LSOUT[7:0]       | R   | NA                   | AEC LSOUT LSB           |  |
|       |                      |     | 1                    | 20 704                  |  |
| 0x35C | AEC_MACRO_ADDR[15:8] | R/W | 0x00                 | AEC Macro Address MSB   |  |
| 0x35D | AEC_MACRO_ADDR[7:0]  | R/W | 0x00                 | AEC Macro Address LSB   |  |
| 0x35E | AEC_MACRO_DATA[15:8] | R/W | NA                   | AEC Macro Data MSB      |  |
| 0x35F | AEC_MACRO_DATA[7:0]  | R/W | NA                   | AEC Macro Data LSB      |  |
| 0x360 | AGC_CTRL             | R/W | 0x00                 | AGC Control             |  |
| 0x361 | AGC_INIT_GAIN        | R/W | 0x88                 | AGC Initial Gain        |  |
| 0x362 | AGC_GAIN_HOLD        | R/W | 0x00                 | AGC Gain Hold           |  |
| 0x363 | AGC_INC_DEC          | R/W | 0x00                 | AGC INC and DEC         |  |
| 0x364 | AGC_ATK_DCY          | R/W | 0x00                 | AGC ATK DCY             |  |
| 0x365 | AGC_GAIN_READ        | R   | NA                   | AGC Gain Read           |  |
| 0x366 | AGC_STATE            | R   | NA                   | AGC State               |  |
| 0x367 | AGC_PWR_TC           | R/W | 0x99                 | AGC Power Time Constant |  |
| 0x368 | AGC_PK_TC            | R/W | 0x00                 | AGC PK Time Constant    |  |
| 0x369 | AGC_PK_MSB           | R   | 0x00                 | AGC PK MSB              |  |
| 0x36A | AGC_PK_LSB           | R   | 0x00                 | AGC PK LSB              |  |
| 0x370 | AGC_TARG_CLIP        | R/W | 0x73                 | AGC Target Clip MSB     |  |
| 0x371 | AGC_TARG_CLIP_LSB    | R/W | 0x33                 | AGC Target Clip LSB     |  |
| 0x372 | AGC_TARG_HI          | R/W | 0x68                 | AGC Target High MSB     |  |
| 0x373 | AGC_TARG_HI_LSB      | R/W | 0x00                 | AGC Target High LSB     |  |
| 0x374 | AGC_TARG_LO          | R/W | 0x66                 | AGC Target Low MSB      |  |
| 0x375 | AGC_TARG_LO_LSB      | R/W | 0x66                 | AGC Target Low LSB      |  |
| 0x376 | AGC_TARG_RB          | R   | 0x00                 | AGC Target RB LSB       |  |
| 0x377 | AGC_TARG_RB_LSB      | R   | 0x00                 | AGC Target RB LSB       |  |
| 0x378 | AGC_NOISE_BIAS       | R/W | 0x00                 | AGC Noise Bias          |  |
| 0x379 | AGC_NOISE_HI         | R/W | 0x00                 | AGC Noise High MSB      |  |
| 0x37A | AGC_NOISE_HI_LSB     | R/W | 0x00                 | AGC Noise High LSB      |  |
| 0x37B | AGC_NOISE_LO         | R/W | 0x00                 | AGC Noise Low MSB       |  |
| 0x37C | AGC_NOISE_LO_LSB     | R/W | 0x00                 | AGC Noise Low LSB       |  |
| 0x37D | AGC_NOISE_RB         | R   | 0x00                 | AGC Noise [23:16]       |  |
| 0x37E | AGC_NOISE_RB_2SB     | R   | 0x00                 | AGC Noise [15:8]        |  |
| 0x37F | AGC_NOISE_RB_LSB     | R   | 0x00                 | AGC Noise [7:0]         |  |

# nuvoTon

| Addr. | Name                     | Mode | Value<br>At<br>Reset | Function                                 |     |
|-------|--------------------------|------|----------------------|------------------------------------------|-----|
| 0x380 | LEC_CONFIG               | R/W  | 0x96                 | LEC Configuration                        |     |
| 0x381 | LEC_RESET                | R/W  | 0xA8                 | LEC Reset                                |     |
| 0x382 | LEC_EC_BELTA             | R/W  | 0x03                 | LEC EC BELTA                             |     |
| 0x383 | LEC_AS_COEFF             | R/W  | 0x04                 | LEC AS Coefficient                       |     |
| 0x385 | LEC_DT_LONG_TC           | R/W  | 0x09                 | LEC Double Talk long term time constant  |     |
| 0x386 | LEC_DT_SHORT_TC          | R/W  | 0xBB                 | LEC Double Talk short term time constant |     |
| 0x387 | LEC_DT_HANGOVER_TIME_MSB | R/W  | 0x00                 | LEC Double Talk Detector Parameters      |     |
| 0x388 | LEC_DT_HANGOVER_TIME_LSB | R/W  | 0x20                 | LEC Double Talk Detector Parameters      |     |
| 0x389 | LEC_DT_DV_THRESH_MSB     | R/W  | 0x19                 | LEC Double Talk Detector Parameters      |     |
| 0x38A | LEC_DT_DV_THRESH_LSB     | R/W  | 0x98                 | LEC Double Talk Detector Parameters      |     |
| 0x38B | LEC_DT_LONG_THRESH_MSB   | R/W  | 0x00                 | LEC Double Talk Detector Parameters      |     |
| 0x38C | LEC_DT_LONG_THRESH_LSB   | R/W  | 0x00                 | LEC Double Talk Detector Parameters      | 2   |
| 0x38D | LEC_DT_SHORT_THRESH_MSB  | R/W  | 0x10                 | LEC Double Talk Detector Parameters      | 2)) |
| 0x38E | LEC_DT_SHORT_THRESH_LSB  | R/W  | 0x10                 | LEC Double Talk Detector Parameters      |     |
| 0x38F | LEC_DIVERGENCE           | R/W  | 0x0F                 | LEC DIVERGENCE THRESHOLD                 |     |
| 0x390 | LEC_VD_LONG_TC           | R/W  | 0x09                 | LEC Voice Detect Long Time Constant      |     |
| 0x391 | LEC_VD_SHORT_TC          | R/W  | 0xBB                 | LEC Voice Detect Short Time Constant     |     |
| 0x392 | LEC_VD_HANGOVER_TIME_MSB | R/W  | 0x00                 | LEC Voice Detect Parameters              |     |
| 0x393 | LEC_VD_HANGOVER_TIME_LSB | R/W  | 0x09                 | LEC Voice Detect Parameters              |     |
| 0x394 | LEC_VD_DEV_THRESHOLD_MSB | R/W  | 0x19                 | LEC Voice Detect Parameters              |     |
| 0x395 | LEC_VD_DEV_THRESHOLD_LSB | R/W  | 0x98                 | LEC Voice Detect Parameters              |     |
| 0x396 | LEC_VD_LONG_THRESH_MSB   | R/W  | 0x19                 | LEC Voice Detect Parameters              |     |
| 0x397 | LEC_VD_LONG_THRESH_LSB   | R/W  | 0x98                 | LEC Voice Detect Parameters              |     |
| 0x398 | LEC_VD_SHORT_THRESH_MSB  | R/W  | 0x10                 | LEC Voice Detect Parameters              |     |
| 0x399 | LEC_VD_SHORT_THRESH_LSB  | R/W  | 0x38                 | LEC Voice Detect Parameters              |     |
| 0x39A | LEC_CUT_OFF_POWER_MSB    | R/W  | 0x19                 | LEC Voice Detect Parameters              |     |
| 0x39B | LEC_CUT_OFF_POWER_LSB    | R/W  | 0x98                 | LEC Voice Detect Parameters              |     |
| 0x39D | LEC_VD_AVE_TC            | R/W  | 0x0B                 | LEC VD Average Time Constant             |     |
| 0x39E | LEC_VD_AVE_THRESH_MSB    | R/W  | 0x00                 | LEC VD Average Threshold MSB             |     |
| 0x39F | LEC_VD_AVE_THRESH_LSB    | R/W  | 0x00                 | LEC VD Average Threshold LSB             |     |
| 0x3A0 | LEC_AS1_BUILD_UP_TIME    | R/W  | 0x77                 | LEC AS1 Built Up Time                    |     |
| 0x3A1 | LEC_AS1_MAX_ATTEN_MSB    | R/W  | 0x1C                 | LEC AS1 Max Attenuation value(MSB)       |     |
| 0x3A2 | LEC_AS1_MAX_ATTEN_LSB    | R/W  | 0xA8                 | LEC AS1 Max Attenuation value(LSB)       |     |
| 0x3A3 | LEC_AS2_BUILD_UP_TIME    | R/W  | 0x77                 | LEC AS2 Built Up Time                    |     |

# nuvoTon

| Addr. | Name                        |     | Value<br>At<br>Reset | Function                                        |  |
|-------|-----------------------------|-----|----------------------|-------------------------------------------------|--|
| 0x3A4 | LEC_AS2_MAX_ATTEN_MSB       | R/W | 0x1C                 | LEC AS2 Max Attenuation value(MSB)              |  |
| 0x3A5 | LEC_AS2_MAX_ATTEN_LSB       | R/W | 0xA8                 | LEC AS2 Max Attenuation value(LSB)              |  |
| 0x3A8 | LEC_NS_POWER_ATTACK_TC      | R/W | 0xBB                 | LEC Noise Suppressor power attack time constant |  |
| 0x3A9 | LEC_NS_ATTEN_TC             | R/W | 0xBB                 | LEC NS Attenuation Time Constant                |  |
| 0x3AA | LEC_NS_ACTIVE_THRESHOLD_MSB | R/W | 0x03                 | LEC NS Active threshold (MSB)                   |  |
| 0x3AB | LEC_NS_ACTIVE_THRESHOLD_LSB | R/W | 0xE8                 | LEC NS Active threshold (LSB)                   |  |
|       |                             |     |                      | 56 0                                            |  |
| 0x3B0 | LEC DT SC CTRL              | R/W | 0x00                 | LEC DT SC Control                               |  |
| 0x3B1 | LEC DT SC NORMAL INDEX      | R/W | 0x00                 | LEC DT SC NORMAL INDEX                          |  |
| 0x3B2 | LEC_DT_SC_LOW_INDEX         | R/W | 0x00                 | LEC DT SC Low INDEX                             |  |
| 0x3B3 | LEC DT SC THRESH MSB        | R/W | 0x10                 | LEC DT SC Threshold MSB                         |  |
| 0x3B4 | LEC DT SC THRESH LSB        | R/W | 0x00                 | LEC DT SC Threshold LSB                         |  |
| 0x3B5 | LEC_DT_SC_POWER_ATTACK_TC   | R/W | 0x07                 | LEC DT SC Power Attack Time Constant            |  |
| 0x3B6 | LEC_DT_SC_GAIN_TC           | R/W | 0x07                 | LEC DT SC GAIN Time Constant                    |  |
| 0x3B8 | LEC_VD_SC_CTRL              | R/W | 0x00                 | LEC VD SC Control                               |  |
| 0x3B9 | LEC_VD_SC_NORMAL_INDEX      | R/W | 0x00                 | LEC VD SC NORMAL INDEX                          |  |
| 0x3BA | LEC_VD_SC_LOW_INDEX         | R/W | 0x00                 | LEC VD SC LOW INDEX                             |  |
| 0x3BB | LEC_VD_SC_THRESH_MSB        | R/W | 0x10                 | LEC VD SC Threshold MSB                         |  |
| 0x3BC | LEC_VD_SC_THRESH_LSB        | R/W | 0x00                 | LEC VD SC Threshold LSB                         |  |
| 0x3BD | LEC_VD_SC_POWER_ATTACK_TC   | R/W | 0x07                 | LEC VD SC Power Attack Time Constant            |  |
| 0x3BE | LEC_VD_SC_GAIN_TC           | R/W | 0x07                 | LEC VD SC GAIN Time Constant                    |  |
| 0x3C0 | LEC_DT_SHORT_TERM_POWER_MSB | R   | NA                   | LEC DT Short Term Power MSB                     |  |
| 0x3C1 | LEC_DT_SHORT_TERM_POWER_LSB | R   | NA                   | LEC DT Short Term Power LSB                     |  |
| 0x3C2 | LEC_DT_LONG_TERM_POWER_MSB  | R   | NA                   | LEC DT Long Term Power MSB                      |  |
| 0x3C3 | LEC_DT_LONG_TERM_POWER_LSB  | R   | NA                   | LEC DT Long Term Power LSB                      |  |
| 0x3C4 | LEC_DT_POWER_DEVIATION_MSB  | R   | NA                   | LEC DT POWER Deviation MSB                      |  |
| 0x3C5 | LEC_DT_POWER_DEVIATION_LSB  | R   | NA                   | LEC DT POWER Deviation LSB                      |  |
| 0x3C6 | LEC_DT_ACTIVE               | R   | NA                   | LEC DT Active                                   |  |
| 0x3C8 | LEC_VD_SHORT_TERM_POWER_MSB | R   | NA                   | LEC VD Short Term Power MSB                     |  |
| 0x3C9 | LEC_VD_SHORT_TERM_POWER_LSB | R   | NA                   | LEC VD Short Term Power LSB                     |  |
| 0x3CA | LEC_VD_LONG_TERM_POWER_MSB  | R   | NA                   | LEC VD Long Term Power MSB                      |  |
| 0x3CB | LEC_VD_LONG_TERM_POWER_LSB  | R   | NA                   | LEC VD Long Term Power LSB                      |  |

#### nuvoTon

| Addr. | Name                       | Mode | Value<br>At<br>Reset | Function                   |
|-------|----------------------------|------|----------------------|----------------------------|
| 0x3CC | LEC_VD_POWER_DEVIATION_MSB | R    | NA                   | LEC VD Power Deviation MSB |
| 0x3CD | LEC_VD_POWER_DEVIATION_LSB | R    | NA                   | LEC VD Power Deviation LSB |
| 0x3CE | LEC_VD_ACTIVE              | R    | NA                   | LEC VD Active              |
| 0x3D0 | LEC_LRIN[15:8]             | R    | NA                   | LEC LRIN MSB               |
| 0x3D1 | LEC_LRIN[7:0]              | R    | NA                   | LEC LRIN LSB               |
| 0x3D2 | LEC_EOUT[15:8]             | R    | NA                   | LEC EOUT MSB               |
| 0x3D3 | LEC_EOUT[7:0]              | R    | NA                   | LEC EOUT LSB               |
| 0x3D4 | LEC_ASOUT15:8]             | R    | NA                   | LEC ASOUT MSB              |
| 0x3D5 | LEC_ASOUT[7:0]             | R    | NA                   | LEC ASOUT LSB              |
| 0x3D6 | LEC_ASIN[15:8]             | R    | NA                   | LEC ASIN MSB               |
| 0x3D7 | LEC_ASIN[7:0]              | R    | NA                   | LEC ASIN LSB               |
| 0x3D8 | LEC_LSOUT[15:8]            | R    | NA                   | LEC LSOUT MSB              |
| 0x3D9 | LEC_LSOUT[7:0]             | R    | NA                   | LEC LSOUT LSB              |
|       |                            |      |                      | - CDP -                    |
| 0x3DC | LEC_MACRO_ADDR[15:8]       | R/W  | 0x00                 | LEC Macro Address MSB      |
| 0x3DD | LEC_MACRO_ADDR[7:0]        | R/W  | 0x00                 | LEC Macro Address LSB      |
| 0x3DE | LEC_MACRO_DATA[15:8]       | R/W  | NA                   | LEC Macro Data MSB         |
| 0x3DF | LEC_MACRO_DATA[7:0]        | R/W  | NA                   | LEC Macro Data LSB         |

Publication Release Date: March 10, 2011 Revision 2.7

- 31 -

#### 7. DEVICE STATUS

#### 7.1 Device Status Register

Whenever the ISD61S00 receives an SPI command it also returns its current status via MISO. The details of the status byte are shown below. For commands that are not reading digital data from the device this status byte is sent via MISO for every byte of data sent to the ISD61S00.

|             |          |       |        |       |        | // ///   |         |  |  |  |
|-------------|----------|-------|--------|-------|--------|----------|---------|--|--|--|
| Status Byte |          |       |        |       |        |          |         |  |  |  |
| Bit 7       | Bit 6    | Bit 5 | Bit 4  | Bit 3 | Bit 2  | Bit 1    | Bit 0   |  |  |  |
| PD          | DBUF_RDY | INT   | RM_FUL | -     | VM_BSY | CBUF_FUL | CMD_BSY |  |  |  |

Table 7-1 Status Register Description

The individual bits of the status register refer to the following conditions:

- **PD** If this bit is high then the device is powered down. The DBUF\_RDY bit will be low, but all device output pins will be high impedance. When PD is high only the READ\_STATUS, READ\_INT and PWR\_UP commands are accepted. If any other command is sent, it is ignored and no interrupt for an error is generated.
- **DBUF\_RDY** in PD this bit is low indicating the device can only accept a PWR\_UP (power up) command. When PD is low this bit reflects the state of the RDY/BSY pin.
- **INT** an interrupt has been generated. The interrupt is cleared by the READ\_INT command. Interrupt type can be determined by the bits of the Interrupt Status Byte.
- RM\_FUL Recording Memory is full. This bit will be set if a record command fills the memory. This bit is reset by an ERASE\_MSG@, ERASE\_MEM, or CHIP\_ERASE operation.
- VM\_BSY indicates the device is processing a voice macro. The device will not respond to a new audio command until this bit returns low.
- **CBUF\_FUL** indicates that the command buffer is full. No more commands can be queued for execution until this bit returns low.
- CMD\_BSY indicates the device is processing a command. Device will not respond to a new command until this bit returns low. If CMD\_BSY=1 and CBUF\_FUL=0 and VM\_BSY=0, a new command will go into the command buffer and execute when the current command finishes. If CMD\_BSY=1 and CBUF\_FUL=1 or VM\_BSY=1 any new audio command will be ignored and generate a command error. For device erase commands such as ERASE\_MSG@, ERASE\_MEM and CHIP\_ERASE, the user can to poll this bit determine if the erasure is complete.

Whenever the ISD61S00 generates an interrupt the Interrupt Status registers hold flags that indicate what type of interrupt was generated. These flags will remain set until a READ\_INT command clears them and the hardware interrupt pin (INTB). The interrupt enable registers IE0, IE1 (see section 8.5.3 8.5.4) mask whether internal functions generate interrupt events or not. Some interrupts require further servicing to remove the condition generating the interrupt, for instance a FIFO full or empty interrupt. If the condition is not serviced before a READ\_INT, the device will immediately generate a new interrupt. The procedure to respond to an interrupt is the following:

- 1. READ\_STATUS to determine what interrupt flags are set.
- 2. Service the interrupt appropriately,

#### nuvoTon

3. READ\_INT and check whether any new interrupts have occurred during the service routines. If new interrupt detected go to step 2. The READ\_INT will clear the interrupt status.

Table 7-2 Interrupt Status Register Description

| Interrupt Status Byte 1             |         |        |         |         |         |          |          |  |  |
|-------------------------------------|---------|--------|---------|---------|---------|----------|----------|--|--|
| Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 |         |        |         |         | Bit 1   | Bit 0    |          |  |  |
| GPIO_INT                            | MPT_ERR | WR_FIN | CMD_ERR | OVF_ERR | CMD_FIN | ADDR_ERR | FULL_ERR |  |  |

The individual bits of the status register refer to the following conditions:

| GPIO_INT | GPIO interrupt has occurred. A GPIO pin configured to produce an interrupt has toggled state.                                                                                                                                                     |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MPT_ERR  | Indicates a memory protection error. Digital access attempted for protected memory.                                                                                                                                                               |
| WR_FIN   | Indicates a digital write command has finished writing to the flash memory.                                                                                                                                                                       |
| CMD_ERR  | An invalid command was sent to the device. Command was ignored because the command buffer was full, a voice macro was active or the device was not ready to respond to an erase command.                                                          |
| OVF_ERR  | This error is generated if host illegally tries to read or write data while RDY/BSYB is low. It is also generated if a digital read or write attempts to read or write past the end of memory.                                                    |
| CMD_FIN  | This bit indicates an interrupt was generated because a command finished executing. A CMD_FIN interrupt will be generated each time an audio play, record or voice macro finishes.                                                                |
| ADDR_ERR | Indicates an address error. This bit will be set to one if a PLAY_MSG@ command is sent at a non-valid header, a REC_MSG@ is sent at a non-blank memory location or an ERASE_MSG command is sent to a sector that is not the beginning of message. |
| FULL_ERR | Record Block is full. This bit will be set and an interrupt generated if a record command fills the memory.                                                                                                                                       |

Table 7-3 Interrupt Status Register Description

| Interrupt Status Byte 2 |         |       |       |          |          |         |        |  |  |
|-------------------------|---------|-------|-------|----------|----------|---------|--------|--|--|
| Bit 7                   | Bit 6   | Bit 5 | Bit 4 | Bit 3    | Bit 2    | Bit 1   | Bit 0  |  |  |
| RNG_INT                 | CAS_INT | FSK_D | FSK_E | TONE_INT | DTMF_INT | CPT_INT | VD_INT |  |  |

VD\_INT Voice Detection interrupt

CPT\_INT Call Progress Tone detector interrupt

DTMF\_INT The DTMF detector has generated an interrupt. This corresponds to a FIFO

condition configured by the user.

#### nuvoton

TONE INT The tone or DTMF generator has generated an interrupt.

FSK E The FSK Encoder has generated an interrupt for either half empty or empty

condition of FIFO.

FSK D The FSK Decoder has generated an interrupt for a FIFO condition or parity error.

CAS\_INT The CAS/Arbitrary Tone detector has detected a valid tone.

RNG INT The Ring Detect block has generated an interrupt.

Table 7-4 Timer interrupt and operation status

| Timer interrupt and additional status |       |       |           |       |          |        |       |  |  |
|---------------------------------------|-------|-------|-----------|-------|----------|--------|-------|--|--|
| Bit 7                                 | Bit 6 | Bit 5 | Bit 4     | Bit 3 | Bit 2    | Bit 1  | Bit 0 |  |  |
| TIMER_INT                             |       |       | DPLL_LOCK |       | PLL_LOCK | DECODE | COMP  |  |  |

TIMER\_INT Timer block has generated an interrupt.

DPLL\_LOCK Indicates lock of digital PLL for PCM slave mode synchronization.

PLL\_LOCK Status bit indicating that PLL is locked and valid clock is available.

DECODE Status bit indicating that compressor is 1: decoding, 0: encoding

COMP Status bit indicating that compressor is active.

#### 8. FUNCTIONAL DESCRIPTION

ISD61S00 is a device targeted at applications requiring voice storage while interfacing to a PSTN telephony network. It provides high quality audio storage for record and playback and offers features of pre-recorded voice prompting and voice macros.

The acoustic side interface provides analog buffers to a microphone and audio output and incorporates on-chip acoustic echo cancellation to allow speakerphone functionality. Network side provides interface to the PSTN and includes a line echo cancellation network.

PCM data enters a mixer matrix whereby signals can be digitally gain controlled, mixed and passed between inputs and outputs. Additionally paths can be selected to monitor input for DTMF or FSK data.

All control and configuration is mapped into SPI accessible configuration registers. In addition these registers can be set from within Voice Macros allowing device to self configure from flash memory.

#### 8.1 SPI Interface

Control of the ISD61S00 is via a four-wire SPI interface. This consists of an active low slave-select (SSB) signal to select the device, a serial clock (SCLK) a data input (Master Out Slave In - MOSI), and a data output (Master In Slave Out - MISO). In addition to the standard four wire interface a RDY/BSYB (ready, busy-bar) signal is supplied for data flow control needed in some transactions.

A SPI transaction begins on the falling edge of SSB and takes the form of the example below:



Figure 8-1 SPI Data Transaction

A command transaction begins with sending a command byte (C7-C0). The most significant bit (MSB – C7) is sent in first. During the shift in of the command byte, device status (S7-S0) is sent out MISO. After the command byte, depending upon the command sent, one or more bytes of data may follow. See Section 7.26 for details of SPI commands and data expected.

For a data writing commands RDY/BSYB is used to handshake data into the device. RDY/BSYB will change state after the rising edge of SCLK of the LSB of a byte transmission. When this occurs SCLK should be held high and data transmission paused until RDY/BSYB returns high indicating that device is ready to receive further data. The timing of this is shown in Figure 8-2 R/B Timing for SPI Writing Transactions



Figure 8-2 R/B Timing for SPI Writing Transactions

If host violates the request from RDY/BSYB, then the RDY bit of the status register for the next byte will reflect the state of RDY/BSYB. If host detects that the RDY bit of status is zero then the current byte of

#### nuvoton

data was not accepted by the ISD61S00. No further data will be accepted and the host must terminate the SPI transaction. For commands that read data from the part (for instance DIG\_READ and SPI\_READ) it is not possible to monitor the RDY bit of status so the RDY/BSYB signal must be monitored to know status. If RDY/BSYB is violated an interrupt is also generated to inform user that data was not accepted. The INT pin will go low shortly after the first violating edge of SCLK. In a data read operation, monitoring this interrupt is the only way of knowing that a RDY/BSYB violation has occurred apart from monitoring RDY/BSYB itself. Using this technique it is possible for a host that is IO limited to operate without monitoring RDY/BSYB.



Figure 8-3 SPI Transaction Ignoring RDY/BSYB

#### 8.2 Record and Playback Control

The ISD61S00 contains a compression and decompression engine that record and playback audio from internal flash memory. During recording, audio is re-sampled from the sample rate of the active audio path to the sample rate desired for storage. During playback audio data from the de-compression engine is re-sampled to that of the audio path.

#### 8.2.1 COMP CFG - Compression Configuration

The COMP\_CFG register controls the sample rate and compression algorithm during message record operations. It can also override sample rate setting for playback by setting bit 0 of CFG1 high. SR[2:0]=COMP\_CFG[7:5] controls the sample rate and CMP[4:0]=COMP\_CFG[4:0] controls the compression. An explanation of these follows below.

| Address | Address Access Mode |       | Value At Res | set      |       |       |       |  |
|---------|---------------------|-------|--------------|----------|-------|-------|-------|--|
| 0x000   | R/                  | W     | 0x64         |          |       |       | _     |  |
| Bit 7   | Bit 6               | Bit 5 | Bit 4 Bit 3  |          | Bit 2 | Bit 1 | Bit 0 |  |
|         | SR[2:0]             |       |              | CMP[4:0] |       |       |       |  |

Publication Release Date: March 10, 2011

### nuvoton

CMP[4:0] Controls the compression algorithm used for recording. Details in Table 8-1.

SR[2:0] Controls the sample rate used for recording. Can also override the playback sample rate. Details in Table 8-2

Table 8-1 COMP\_CFG Register Compression Type.

|             |               |       | 7. 5. 1. 5. |
|-------------|---------------|-------|-------------|
| Compression | Bit rate      | CMP   | [4:0]       |
| Туре        | (bits/sample) | (Dec) | (Hex)       |
| ADPCM       | 2             | 2     | 0x02        |
| ADPCM       | 3             | 3     | 0x03        |
| ADPCM       | 4             | 4     | 0x04        |
| ADPCM       | 5             | 5     | 0x05        |
| μ-Law       | 6             | 16    | 0x10        |
| μ-Law       | 7             | 17    | 0x11        |
| μ-Law       | 8             | 18    | 0x12        |
| Dμ-Law      | 6             | 20    | 0x14        |
| Dμ-Law      | 7             | 21    | 0x15        |
| Dμ-Law      | 8             | 22    | 0x16        |
| PCM         | 8             | 24    | 0x18        |
| PCM         | 10            | 25    | 0x19        |
| PCM         | 12            | 27    | 0x1B        |

Table 8-2 CFG0 Sample Rate Control

| Sample Rate (kHz) | Code    | COMP  | _CFG[7:0] |
|-------------------|---------|-------|-----------|
|                   | SR[2:0] | (Dec) | (Hex)     |
| 4                 | 0       | 0     | 0x00      |
| 5.333             | 1       | 32    | 0x20      |
| 6.4               | 2       | 64    | 0x40      |
| 8                 | 3       | 96    | 0x60      |
| 10.6              | 4       | 128   | 08x0      |
| 12.8              | 5       | 160   | 0xA0      |
| 16                | 6       | 192   | 0xC0      |

The current operational mode of the ISD61S00 can also be queried by setting CFG1[4] and reading COMP\_CFG. Under this condition, rather than reading back the configuration register, the result will be current audio path sample rate and compression scheme.

Publication Release Date: March 10, 2011 Revision 2.7

- 37 -



#### 8.2.2 COMP CTRL - Compression Control

| Address           |   | Access Mode  |     | Value At Reset |           |       |       |       |       |
|-------------------|---|--------------|-----|----------------|-----------|-------|-------|-------|-------|
| 0x001             |   | R            | W   |                | 0x00      | 200   | 0     |       |       |
| Bit 7             | В | Bit 6        | Bit | 5              | Bit 4     | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| FIFO Over-<br>run |   | Under-<br>un | LRM | ΙΡ             | CFG0_READ | PAUSE | NRMP  | SRSIL | SRCFG |

Configuration register CFG1 controls how compressed audio is treated by the compression block:

SRCFG Forces the sample rate to be set by the COMP\_CFG register. By setting this bit to one

sample rate contained in the recorded audio header is overridden.

SRSIL Under normal circumstances, whenever a change in sample rate is detected between two

consecutive messages a period of silence is automatically inserted. This is to prevent any transients in the signal path occurring as filter coefficients are changed. To turn off this

silence insertion set this bit to one.

NRMP Under normal conditions, if an audio playback finishes at a non-zero level the input to the

signal path will be ramped to zero. This prevents a DC offset appearing on the output. To turn this feature off, for instance if a small audio sample is being looped, set this bit to

one. Please note that **NRMP** and **LRMP** should not be set at the same time.

PAUSE When this bit is set, Record or Playback operation will be paused. Clear this bit to

resume the operation

When this bit is set, a read of COMP\_CFG will result in the current operation mode of compression and sample rate rather than the setting of the COMP\_CFG register. A write to COMP\_CFG will still result in setting the register, but the

contents of the register cannot be read back until CFG0\_READ is set to zero.

LRMP Set this bit to 1, the input to the signal path will not be ramped during the loop-play, but will be ramped to zero when the playback finishes or being stopped by a STOP or

STOP LP command. Please note that **NRMP** and **LRMP** should not be set at the same

time.

FIFO Under-

run

CFG0 READ

This is a read only register, that when high indicates that the audio FIFO has under-run, that is audio data was not present when required by the signal path. This is a normal condition at the end of a play command when compression is active. It can be used during a SPI\_DAC operation to check whether data sent to ISD61S00 was corrupted. This signal is latched and is reset by writing a 1 followed by a 0 to CEC1[7], the FIEO Over run bit

followed by a 0 to CFG1[7], the FIFO Over-run bit.

When read, a high indicates that the audio FIFO has over-run, that is audio data from the signal path could not be processed fast enough to keep audio integrity and data was lost.

This is a normal condition at the end of a record command when compression has finished. It can be used during a SPI\_ADC operation to check whether data received from the ISD161S00 was corrupted. This signal is latched and is reset by writing a 1 followed

by a 0 to the register.

Publication Release Date: March 10, 2011 Revision 2.7

- 38 -



#### 8.2.3 COMP SRC - Compression Source

| Address  |    | Access | Mode  | Value At Rese |          | et       |          |        |         |
|----------|----|--------|-------|---------------|----------|----------|----------|--------|---------|
| 0x002    |    | R/     | W     |               | 0x00     | 200      |          |        |         |
| Bit 7    | Е  | 3it 6  | Bit ! | 5             | Bit 4    | Bit 3    | Bit 2    | Bit 1  | Bit 0   |
| Reserved | DE | CODE   | SPI_  | IN            | Reserved | Reserved | Reserved | ENCODE | SPI_OUT |

Output signal data to SPI. SPI\_OUT and ENCODE cannot be both on at the same time. If DECODE is selected, the signal path is bypassed and ISD161S00 is ready for SPI playback operation. If DECODE is not set then the signal source is the audio path and a SPI ADC operation is selected. Use the SPI\_RCV\_AUD command to read the audio data out the SPI interface.

SPI\_IN Input data from SPI. SPI\_IN and DECODE cannot be both on at the same time. If ENCODE is set, then an SPI record operation is selected. If no audio data is sent to the signal path for a SPI DAC operation. Use the SPI\_SND\_AUD command to send audio data to the ISD61S00 from the SPI interface.

ENCODE Used in conjunction with a record operation. When selected, signal data is routed to the Audio compressor for compression. If SPI\_IN is also selected, the signal path is bypassed and becomes ready for an SPI record operation using the SPI\_SND\_AUDIO command.

DECODE Used in conjunction with a play operation. When selected the signal path picks up data from the compressor and plays it to the corresponding outputs selected.

#### 8.2.4 CLK CTRL - Clock Control

| Addre | SS   | Access | Access Mode |                 | Value At Res | et    |           |                   |  |  |
|-------|------|--------|-------------|-----------------|--------------|-------|-----------|-------------------|--|--|
| 0x00  | 3    | R/W    |             | 0x03            |              |       |           | _                 |  |  |
| Bit 7 |      | Bit 6  | Bit         | 5               | Bit 4        | Bit 3 | Bit 2     | Bit 2 Bit 1 Bit 0 |  |  |
|       | DPLL | _RANGE |             | DPLL_EN CODEC_F |              | S     | BCLK_RATE |                   |  |  |

BCLK RATE Determines the bit clock rate of the I2S interface in master mode.

0: 8.192MHz 1: 4.096MHz 2: 2.048MHz 3: 1.024MHz 4: 512kHz

5: 256kHz 6: 128kHz 7: 64kHz

CODEC\_FS Determines the master sample rate of the audio CODEC. 0: 8kHz 1: 16kHz

DPLL\_EN 1: Enable Digital PLL. Used when PCM interface in slave mode to synchronize master clock rate to an external frame sync sample rate on WS pin. To use this mode PLL must also be active.

- 39 -

DPLL\_RANGE Lock-in range of digital PLL. Use smallest value that achieves locking. Range is

approximately 0: 10ps, 1: 20ps, 3: 40ps, 7:120ps.



#### 8.2.5 CFG17 - Update Mode

| Address  | ;  | Access | Mode     | Value At Res | set   |          |        |       |
|----------|----|--------|----------|--------------|-------|----------|--------|-------|
| 0x017    |    | R/     | W        | 0x01         | 200   | 0        |        | _     |
| Bit 7    |    | Bit 6  | Bit 5    | Bit 4        | Bit 3 | Bit 2    | Bit 1  | Bit 0 |
| PLL_LOCK | RI | B_SPI  | Reserved | Reserved     | DEC   | COMPRESS | UPDATE | IMM   |

IMM Immediate update mode. Registers 0x000-0x016 are double buffered. If IMM bit is set

register values are active as soon as written.

UPDATE If IMM bit is not set then registers 0x000-0x016 do not take effect until a 1 is written to this

register

COMPRESS Read only bit indicating that compression engine is active

DEC Read only bit indicating that compression engine is 1: decoding 0: encoding

RB\_SPI This bit is set if users wish to monitor the RDY/BSYB handshake through SPI status

rather than the hardware pin. When set it ensures that when conducting DIG\_WRITE, SPI SND AUD and SPI SND DEC commands that the RDY bit of the status register is

latched on SPI byte boundaries for correct read back.

PLL\_LOCK Read only status indicating that PLL is locked.

#### 8.3 Clock Generation and PLL

The PLL may be used to multiply an external input clock reference frequency by a high resolution fractional number. To enable the use of the widest possible range of external reference clocks, the PLL block includes an optional divide-by-two prescaler for the input clock, a fixed divide-by-four scaler on the PLL output, and an additional programmable integer divider that is the Master Clock Prescaler.

Publication Release Date: March 10, 2011 Revision 2.7

- 40 -

## nuvoton



Figure 8-4 Clock Generation Block Diagram

The high resolution fraction for the PLL is the ratio of the desired PLL oscillator frequency and the reference frequency at the PLL input. This can be represented as  $R = f_2/f_1$ , with R in the form of a decimal number: xy.abcdefgh. To program the ISD61S00, this value is separated into an integer portion ("xy"), and a fractional portion. The fractional portion of the multiplier ("abcdefgh") is a value that when represented as a 24-bit binary number, most closely matches the exact desired multiplier factor.

To keep the PLL within its proper operating range, the integer portion of the decimal number ("xy"), must be any of the following decimal values: 6, 7, 8, 9, 10, 11, or 12. The input and output dividers outside of the PLL are used to scale frequencies as needed to keep the "xv" value within the required range.

Thus, for any given design, choose

 $R = f_2/f_1 = xy.abcdefgh decimal value$ 

N = xy truncated to only the integer portion of the R value and N limited to decimal value 6, 7, 8, 9, 10, 11, or 12

 $K = (2^{24})(0.abcdefgh)$ , rounded to the nearest whole integer value, then converted to hexadecimal 24-bit value

REG44[3:0] is set with the whole number integer portion (N) of the multiplier

REG41-REG43 is set collectively with the 24-bit fractional portion (K) of the multiplier

REG44[4] PLL Prescaler set as necessary

REG40[4:2] Master Clock Prescaler and BCLK Output Scaler set as necessary

#### 8.3.1 Phase Locked Loop (PLL) Design Example

The target IMCLK rate is always 24.576MHz, which implies a PLL frequency f<sub>2</sub> of 98.304MHz.

In this example system design, there is already an available 12.000MHz clock from the USB subsystem. To reduce system cost, this clock will also be used for audio. Therefore, to use the 12MHz clock for



audio, the desired fractional multiplier ratio would be R = 98.304/12.000 = 8.192. This value meets the requirement that the "xy" whole number portion of the multiplier be in the range between 6 and 12.

To complete this portion of the design example, the integer portion of the multiplier is truncated to the value, 8. The fractional portion is multiplied by  $2^{24}$ , as to create the needed 24-bit binary fractional value. The calculation for this is:  $(2^{24})(0.192) = 3221225.472$ . It is best to round this value to the nearest whole value of 3221225, or hexadecimal 0x3126E9. Thus, the values to be programmed to set the PLL multiplier whole number integer and fraction are:

R44 0xnm8 ; integer portion of fraction, (nm represents other settings in R44)

R41 0x31 ; highest order 8-bits of 24-bit fraction R42 0x26 ; middle 8-bits of 24-bit fraction R43 0xE9 ; lowest order 8-bits of 24-bit fraction

Below are additional examples of results for this calculation applied to commonly available clock frequencies.

| MCLK<br>(MHz) | PLL<br>oscillator<br>f <sub>2</sub> (MHz) | PLL<br>Prescaler<br>divider | Master Clock<br>divider | Fractional Multiplier $R = f_2/f_1$ | Integer<br>Portion<br>N (Hex) | Fractional Portion K (Hex) |
|---------------|-------------------------------------------|-----------------------------|-------------------------|-------------------------------------|-------------------------------|----------------------------|
| 12.0          | 98.3040                                   | 1                           | 1                       | 8.192000                            | 8                             | 3126E9                     |
| 14.4          | 98.3040                                   | 1                           | 1                       | 6.826667                            | 6                             | D3A06D                     |
| 19.2          | 98.3040                                   | 2                           | 1                       | 10.240000                           | Α                             | 3D70A3                     |
| 19.8          | 98.3040                                   | 2                           | 1                       | 9.929697                            | 9                             | EE009E                     |
| 24.0          | 98.3040                                   | 2                           | 1                       | 8.192000                            | 8                             | 3126E9                     |
| 26.0          | 98.3040                                   | 2                           | 1                       | 7.561846                            | 7                             | 8FD526                     |

Table 8-3: PLL Frequency Examples

#### 8.3.2 PLL CLK

| 9 | Address  |     | Access | s Mode |   | Value At Res | et     |    |       |       |       |
|---|----------|-----|--------|--------|---|--------------|--------|----|-------|-------|-------|
| - | 0x040    |     | R/     | W      |   | 0x20         |        |    |       |       |       |
|   | Bit 7    | Е   | 3it 6  | Bit    | 5 | Bit 4        | Bit 3  |    | Bit 2 | Bit 1 | Bit 0 |
| 3 | Reserved | MIC | C_CLK  | OSI    | 7 |              | MCLK_D | IV |       | OPCL  | K_DIV |

OPCLK DIV Divisor of MCLK for optional GPIO clock output. f<sub>OPCLK</sub> = f<sub>PLL</sub> / (OPCLK DIV+1).

MCLK DIV Master clock scaler. Used to adjust clock to 24.576MHz for correct operation. Divisors

are: 000=1, 001=1.5, 010=2, 011=3, 100=4, 101=6, 110=8, and 111=12.

OSR Oversampling rate of DAC. 1: OSR = high (lower out of band noise), 0: OSR = low.

MIC CLK Microphone sampling clock frequency. 1: 64kHz, 0: 32kHz.

#### 8.3.3 PLL FRAC

|    | Address   | S              | Access Mode  | Value At Reset     | Nominal Value |      |      |   |
|----|-----------|----------------|--------------|--------------------|---------------|------|------|---|
|    | 0x041-0x0 | x041-0x043 R/W |              | 0x043 R/W 0x000000 |               |      |      | _ |
|    | Bit7      | Bit6           | Bit5         | Bit4               | Bit3 Bit2     | Bit1 | Bit0 |   |
| 41 |           |                | <del>-</del> | PLL_FRAC           | 23:16]        | -    | •    |   |
| 42 |           |                |              | PLL_FRAC           | [15:8]        |      |      |   |
| 43 |           |                | [7:0]        |                    |               |      |      |   |

PLL\_FRAC The PLL fractional divider. This 24 bit number represents the fractional part of the PLL divider ratio R. Value of fractional part is PLL\_FRAC ÷ 2<sup>24</sup>

#### 8.3.4 PLL CTRL

| Address |      | Access I    | Mode     | Value At Reset    |       |   |       |       |       |
|---------|------|-------------|----------|-------------------|-------|---|-------|-------|-------|
| 0x044   |      | R/W         | ı        | 0x88              |       |   |       | 8     |       |
| Bit 7   |      | Bit 6 Bit 5 |          | Bit 4             | Bit 3 |   | Bit 2 | Bit 1 | Bit 0 |
| PLL_EN  | PLL_ | BYPASS      | Reserved | PLL_PRESC<br>ALER |       | _ | PLL_[ | DIV_N | •     |

PLL\_EN Enable PLL

PLL\_BYPASS Bypass PLL and apply XTALIN clock directly to CLKM

PLL\_PRESCALER PLL Prescaler. 0: f<sub>1</sub> = XTALIN, 1: f<sub>1</sub> = XTALIN/2

PLL\_DIV\_N Integer portion of PLL divisor ratio R. Must be in the range 6-12.

\*To disable PLL\_EN, first set (REG0x03) DPLL\_EN = 0 and (REG0x44) PLL\_BYPASS = 1. DPLL\_EN cannot be enabled while PLL is disabled.

### 8.4 Digital Audio Interface Control

The ISD61S00 has a flexible digital audio interface to enable communication of digital serial audio. Communication is controlled by a bit clock and frame synchronization signal. The ISD61S00 has two physical transmit/receive channels, each capable of carrying two audio channels, to allow connection to multiple digital audio sources. Both these channels share common clock and synchronization. The clock and frame sync can be configured as outputs (ISD61S00 is master and generates clock and frame sync) or inputs (ISD61S00 is slave and accepts clock and frame sync). In slave mode the master clock input must either be synchronous to the frame sync signal or the internal digital PLL must be enabled to allow data synchronization.



The audio path of the ISD61S00 can generate/accept two channels of audio data. These can be routed to either PCM interface. In addition data can be looped from one PCM interface to the other.

The interface has a variety of modes. In I2S mode, PCM interface conforms to the I2S digital audio interface convention where left channel data is active when frame sync is low (WS=0) and right channel when frame sync is high (WS=1). In PCM mode data transfer is synchronized to the rising edge of the frame synch (WS) signal. Where data is placed for each channel is configurable through time slot control registers.

#### **PCM CFG** 8.4.1

| Address |    | Access | Mode  |    | Value At Res | et    |       |       |       |
|---------|----|--------|-------|----|--------------|-------|-------|-------|-------|
| 0x050   |    | R/     | W     |    | 0x00         |       | -(1)  | 2     |       |
| Bit 7   | Е  | Bit 6  | Bit 5 | 5  | Bit 4        | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| SCK_INV | TR | II_EN  | PCM_I | 2S | PCM_MODE     | PCM1L | PCM1R | PCML  | PCMR  |

**PCMR** Enable PCM/I2S data out on right channel. **PCML** Enable PCM/I2S data out on left channel. PCM1R Enable PCM/I2S data out on right channel of PCM1 interface PCM1L Enable PCM/I2S data out on left channel of PCM1 interface 0: Master Mode, ISD61S00 generates SCK and WS. 1: Slave Mode, ISD61S00 accepts PCM MODE WS and SCK from host. PCM I2S 0: I2S mode, 1: PCM mode, TRI EN Tristates the PCM bus after second half of LSB. SCK INV 0: Data clocks on rising edge of SCK. 1: data clocks on falling edge of SCK

The PCM/I2S bus uses GPIO pins 4-9 as listed below and is enabled by setting the PORTA AF and PORTB AF registers to enable the alternate functions of these pins. SCK frequency in master mode is controlled by CLK CTRL (0x003) register (Section 8.2.4).

| GPIO Port | GPIO Pin | I2S<br>Name | Description      | PCM<br>Name | Master<br>mode<br>Direction | Slave Mode<br>Direction |
|-----------|----------|-------------|------------------|-------------|-----------------------------|-------------------------|
| PORTA<4>  | GPIO<4>  | SDO         | Serial Data Out  | TX          | 0                           | 0                       |
| PORTA<5>  | GPIO<5>  | WS          | WS/Frame Sync    | FS          | 0                           | I                       |
| PORTA<6>  | GPIO<6>  | SCK         | Serial Bit Clock | BCLK        | 0                           | I                       |
| PORTA<7>  | GPIO<7>  | SDI         | Serial Data In   | RX          | I                           | I                       |
| PORTB<0>  | GPIO<8>  | SDO1        | Serial Data Out1 | TX1         | 0                           | 0                       |
| PORTB<1>  | GPIO<9>  | SDI1        | Serial Data In1  | RX1         | I                           | I                       |

In addition to I2S mode the interface can be configured into a generic PCM interface with control of where and how data is transmitted/received.

Publication Release Date: March 10, 2011

- 44 -



#### 8.4.2 PCM\_TSLOTL

| Address |           | Access Mode |      | Value At Reset |             |         |       |       |       |
|---------|-----------|-------------|------|----------------|-------------|---------|-------|-------|-------|
| 0x051   | 0x051 R/W |             | 0x01 |                |             | 20      |       | _     |       |
| Bit 7   | В         | Bit 6 Bit   |      | 5              | Bit 4 Bit 3 |         | Bit 2 | Bit 1 | Bit 0 |
|         |           |             |      |                | TSLO        | TL[7:0] | . Ak  |       |       |

TSLOTL[9:0] Left channel PCM data starts TSLOTL clocks after WS rising edge. Bits 9:8 are in PCM\_COMP0 register.

#### 8.4.3 PCM\_TSLOTR

| Address | Address Access Mode 0x052 R/W |             | Mode | Value At Reset |             |  |  |       |         |       |
|---------|-------------------------------|-------------|------|----------------|-------------|--|--|-------|---------|-------|
| 0x052   |                               |             | W    | 0x11           |             |  |  |       | ~ (6 Kg | 3)    |
| Bit 7   | Bi                            | Bit 6 Bit 5 |      | 5              | Bit 4 Bit 3 |  |  | Bit 2 | Bit 1   | Bit 0 |
|         | TSLOTR[7:0]                   |             |      |                |             |  |  |       |         |       |

TSLOTR[9:0] Right channel PCM data starts TSLOTR clocks after WS rising edge. Bits 9:8 are in PCM\_MODE register.

#### 8.4.4 PCM COMP0

| Address Access Mod |   | Mode      | Value At Reset |               |         |         |         |         |       |
|--------------------|---|-----------|----------------|---------------|---------|---------|---------|---------|-------|
| 0x053 F            |   | R/        | /W 0x00        |               |         |         |         |         |       |
| Bit 7              | Е | Bit 6 Bit |                | 5 Bit 4 Bit 3 |         | Bit 3   | Bit 2   | Bit 1   | Bit 0 |
| TSLOTR[9:8]        |   | T         | SLO            | TL[9:8]       | RX_COMP | RX_ULAW | TX_COMP | TX_ULAW |       |

RX\_COMP 1: Enable receive companding. 0: disable

RX\_ULAW 1: Rx aLaw companding. 0: Rx uLaw companding.

TX\_COMP 1: Enable transmit companding. 0: disable

TX\_ULAW 1: Tx aLaw companding. 0: Tx uLaw companding.

#### 8.4.5 PCM TSLOTL1

| Address | Acces        | s Mode | Value At Res | et    |       |       |       |  |  |  |
|---------|--------------|--------|--------------|-------|-------|-------|-------|--|--|--|
| 0x054   | R/W          |        | 0x01         |       |       |       |       |  |  |  |
| Bit 7   | Bit 6        | Bit 5  | Bit 4        | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|         | TSLOTL1[7:0] |        |              |       |       |       |       |  |  |  |

- 45 -



TSLOTL1[9:0] Left channel PCM1 data starts TSLOTL clocks after WS rising edge. Bits 9:8 are in PCM\_COMP0 register.

#### 8.4.6 PCM TSLOTR1

| Address   | Address Access Mode |             | Mode | Value At Reset |             |  |       |       |       |
|-----------|---------------------|-------------|------|----------------|-------------|--|-------|-------|-------|
| 0x055 R/W |                     | W           | 0x11 |                | - N. O.     |  |       |       |       |
| Bit 7     | Е                   | Bit 6 Bit 5 |      | 5              | Bit 4 Bit 3 |  | Bit 2 | Bit 1 | Bit 0 |
|           |                     |             |      | TSLOT          | R1[7:0]     |  | 2     |       |       |

TSLOTR1[9:0] Right channel PCM1 data starts TSLOTR clocks after WS rising edge. Bits 9:8 are in PCM\_MODE register.

#### 8.4.7 PCM COMP1

| Address      | Address Access Mode |       | Mode  | Value At Reset |         |            |          |          |       |
|--------------|---------------------|-------|-------|----------------|---------|------------|----------|----------|-------|
| 0x056        | 0x056 R/W           |       | W     | 0x00           |         |            |          |          | 5     |
| Bit 7        | Е                   | 3it 6 | Bit 5 |                | Bit 4   | Bit 3      | Bit 2    | Bit 1    | Bit 0 |
| TSLOTR1[9:8] |                     | T     | SLOT  | L1[9:8]        | RX_COMP | 1 RX_ULAW1 | TX_COMP1 | TX_ULAW1 |       |

RX\_COMP1 1: Enable receive companding. 0: disable (PCM1)

RX ULAW1 1: Rx aLaw companding. 0: Rx uLaw companding. (PCM1)

TX COMP1 1: Enable transmit companding. 0: disable (PCM1)

TX\_ULAW1 1: Tx aLaw companding. 0: Tx uLaw companding. (PCM1)

The following diagram illustrates the various signals that can be routed to the PCM/I2S interfaces.

### nuvoton



Figure 8-5 PMC/I2S signal routing

#### 8.4.8 PCM\_TX\_SEL

| Address | Address Access |   | Mode Value At Reset |     |         |       |       |
|---------|----------------|---|---------------------|-----|---------|-------|-------|
| 0x057   | R              | W | 0x00                |     |         |       |       |
| Bit 7   | Bit 7 Bit 6    |   | Bit 5 Bit 4         |     | Bit 2   | Bit 1 | Bit 0 |
| TX_R1   | TX_R1_SEL      |   | 1_SEL               | TX_ | _R0_SEL | TX_L  | D_SEL |

TX\_L0\_SEL Select what audio to send on left channel of PCM bus



TX\_R0\_SEL Select what audio to send on right channel of PCM busTX\_L1\_SEL Select what audio to send on left channel of PCM1 busTX\_R1\_SEL Select what audio to send on right channel of PCM1 bus

#### 8.4.9 PCM RX SEL

| Address Acces |             | s Mode Value At Rese |      | et          |          |       |          |       |       |
|---------------|-------------|----------------------|------|-------------|----------|-------|----------|-------|-------|
| 0x058 F       |             | R/                   | W    | 0x00        |          |       | 100 00   |       |       |
| Bit 7         | Bit 7 Bit 6 |                      | Bit  | Bit 5 Bit 4 |          | Bit 3 | Bit 2    | Bit 1 | Bit 0 |
| Reserved      |             |                      | Rese | erved       | RX_R_SEL |       | RX_L_SEL |       |       |

RX\_L\_SEL Select what audio to send to left channel signal path.

RX\_R\_SEL Select what audio to send to right channel of signal path

|   | TX_L0_SEL | TX_R0_SEL | TX_L1_SEL | TX_R1_SEL | RX_R_SEL | RX_L_SEL |
|---|-----------|-----------|-----------|-----------|----------|----------|
| 0 | TX_L      | TX_R      | TX_L      | TX_R      | RX_R0    | RX_L0    |
| 1 | TX_R      | TX_L      | TX_R      | TX_L      | RX_L0    | RX_R0    |
| 2 | RX_L1     | RX_R1     | RX_L0     | RX_R0     | RX_R1    | RX_L1    |
| 3 | MUTE      | MUTE      | MUTE      | MUTE      | MUTE     | MUTE     |

#### 8.5 GPIO and Interrupt Configuration

The ISD61S00 contains up to 17 GPIO pins. These pins can be configured as inputs or outputs, have configurable drive strength and pull-up pull-down capability. Some GPIO pins have an alternate optional function, such as I2S interface or ring detector input. The GPIO are divided into three ports: A, B and C. PORTA consists of GPIO<7:0>, PORTB consists of GPIO<15:8> and PORTC consists of GPIO<16>. The port functionality is controlled by the following configuration registers. Transitions on the GPIO pins can generate a GPIO\_INT interrupt and also be configured to wake the chip up from a power-down state. The user must be aware that some GPIO pins have default alternate functions that must be enabled for correct operation (for internal memory devices these include PORTC[7:1] and for external memory devices PORTA[1:0] are used for memory access).

#### 8.5.1 PORT\_CFG

| Ad   | lress A | Access Mode | Value At Res | et Nomin    | al Value    |             |             |
|------|---------|-------------|--------------|-------------|-------------|-------------|-------------|
| 0x   | 00B     | R/W         | 0x00         |             |             |             |             |
| Bit7 | Bit6    | Bit5        | Bit4         | Bit4 Bit3   |             | Bit1        | Bit0        |
| F    | DET_IN  | PORTC_H_INT | PORTC_L_INT  | PORTB_H_INT | PORTB_L_INT | PORTA_H_INT | PORTA_L_INT |

### nuvoton

If this bit is set, and the corresponding PORTA IE bit, then transitions on PORTA L INT PORTA[3:0] will generate a GPIO wakeup interrupt. If this bit is set, and the corresponding PORTA IE bit, then transitions on PORTA H INT PORTA[7:4] will generate a GPIO wakeup interrupt. If this bit is set, and the corresponding PORTB IE bit, then transitions on PORTB L INT PORTB[3:0] will generate a GPIO wakeup interrupt. If this bit is set, and the corresponding PORTB\_IE bit, then transitions on PORTB H INT PORTB[7:4] will generate a GPIO wakeup interrupt. If this bit is set, and the corresponding PORTC IE bit, then transitions on PORTC\_L\_INT PORTC[3:0] will generate a GPIO wakeup interrupt. Not used - set to zero. PORTC H INT These bits determine which GPIO port is used as the ring detector input. 0: RDET\_IN[1:0] GPIO<13>, 1: GPIO<14>, 2: GPIO<15>, 3: GPIO<16>

When the ISD61S00 goes into a power-down state the status of the GPIO ports are latched. If a GPIO pin, that has its interrupt enabled and wake-up enabled, toggles the chip will execute a wake-up event. The device will automatically execute Voice Macro 2 if present or, if this voice macro is blank, it will enter the power-up idle state and generate an interrupt to the host.

#### 8.5.2 PORTx IE

| Addres   | s              | Ac  | cess Mode | Value At Res | et   | Nomin     | al Value |      |      |  |
|----------|----------------|-----|-----------|--------------|------|-----------|----------|------|------|--|
| 0x00C-0x | 00E            | R/W |           | 0x00         |      |           |          |      |      |  |
| Bit7     | Bit7 Bit6 Bit5 |     |           | Bit4         |      | Bit3 Bit2 |          | Bit1 | Bit0 |  |
|          | PORTA_IE       |     |           |              |      |           |          |      |      |  |
|          |                |     |           | PORT         | B_IE |           |          |      |      |  |
|          | PORTC_IE       |     |           |              |      |           |          |      |      |  |

PORTA\_IE

This register is the interrupt enable mask for PORTA. If the bit is set then that GPIO can generate a GPIO\_INT event. Similarly for PORTB\_IE and PORTC\_IE

#### 8.5.3 IE0

| Addres   | ss Ac   | ccess Mode | Value At Rese | et Nomin | al Value |          |          |
|----------|---------|------------|---------------|----------|----------|----------|----------|
| 0x014    | 500     | R/W        | 0xFF          |          |          |          | _        |
| Bit7     | Bit6    | Bit5       | Bit4          | Bit3     | Bit2     | Bit1     | Bit0     |
| GPIO_INT | MPT_ERR | WR_FIN     | CMD_ERR       | OVF_ERR  | CMD_FIN  | ADDR_ERR | FULL_ERR |

The IEO register enables the interrupt associated with the bit mask and corresponds to the interrupt status bits in STATUS REG[1].



#### 8.5.4 IE1

| Addres  | s     | Ac  | ccess Mode | Value At Res | et Nomin | al Value |         |                      |
|---------|-------|-----|------------|--------------|----------|----------|---------|----------------------|
| 0x015   |       |     | R/W        | 0xFF         |          |          |         |                      |
| Bit7    | Bit6  | 5   | Bit5       | Bit4         | Bit3     | Bit2     | Bit1    | Bit0                 |
| RNG_INT | CAS_I | INT | FSK_D      | FSK_E        | TONE_INT | DTMF_INT | CPT_INT | VD_INT<br>/TIMER_INT |

The IE1 register enables the interrupt associated with the bit mask and corresponds to the interrupt status bits in STATUS\_REG[2].

#### 8.5.5 PORTA DO

| Address | Address Ac |      | Value At Rese | et Nomir | nal Value |      |      |  |  |  |
|---------|------------|------|---------------|----------|-----------|------|------|--|--|--|
| 0x019   |            | R/W  | 0x00          |          |           |      | 25 6 |  |  |  |
| Bit7    | Bit6       | Bit5 | Bit4          | Bit3     | Bit2      | Bit1 | Bit0 |  |  |  |
|         | PORTA_DO   |      |               |          |           |      |      |  |  |  |

PORTA\_DO

This register contains the data to be written out the GPIO pins of PORTA. Data will propagate to the pin if the corresponding PORTA\_OE bit is enabled.

#### 8.5.6 PORTA OE

| Address | s        | Access Mode |      | Value At Reset |  | Nominal Value |      |      |      |
|---------|----------|-------------|------|----------------|--|---------------|------|------|------|
| 0x01A   |          |             | R/W  | 0x00           |  |               |      |      | -    |
| Bit7    | Bit6     | )           | Bit5 | Bit4           |  | Bit3          | Bit2 | Bit1 | Bit0 |
|         | PORTA_OE |             |      |                |  |               |      |      |      |

This register contains output enable mask for the GPIO pins of PORTA. If a PORTA\_OE bit is high data in the PORTA\_DO register will propagate to the pin. If low the driver of the pin is in a tri-state condition.

### 8.5.7 PORTA PE

| Address | s Ac     | ccess Mode | Value At Res | et 1 | Nominal Value |      |      |  |  |
|---------|----------|------------|--------------|------|---------------|------|------|--|--|
| 0x01B   | 18/2     | R/W        | 0xFF         |      |               |      |      |  |  |
| Bit7    | Bit6     | Bit5       | Bit4         | Bit3 | Bit2          | Bit1 | Bit0 |  |  |
|         | PORTA_PE |            |              |      |               |      |      |  |  |

PORTA\_PE

This register contains the pull enable mask for the GPIO pins of PORTA. If a PORTA\_PE bit is high then a pull-up or pull-down is connected to the pin depending



on the state of PORTA PS.

#### 8.5.8 PORTA DI

| Address | s A      | Access Mode | Value At Rese | et Nomii | nal Value |      |      |  |  |  |
|---------|----------|-------------|---------------|----------|-----------|------|------|--|--|--|
| 0x01C   |          | R           | 0xFF          |          | 2         | 13.  |      |  |  |  |
| Bit7    | Bit6     | Bit5        | Bit4          | Bit3     | Bit2      | Bit1 | Bit0 |  |  |  |
|         | PORTA_DI |             |               |          |           |      |      |  |  |  |

PORTA DI This read only register reflects the state of the GPIO pins of PORTA.

## 8.5.9 PORTA\_PS

| Address | Address Acces |   | cess Mode | Value At Reset |  | Nominal Value |      |      |      |  |
|---------|---------------|---|-----------|----------------|--|---------------|------|------|------|--|
| 0x01D   |               |   | R/W       | 0xFF           |  |               |      |      | 93   |  |
| Bit7    | Bit6          | 1 | Bit5      | Bit4           |  | Bit3          | Bit2 | Bit1 | Bit0 |  |
|         | PORTA_PS      |   |           |                |  |               |      |      |      |  |

PORTA\_PS

This register contains the pull select mask for the GPIO pins of PORTA. If a PORTA PS bit is high then a pull-up is selected or if low a pull-down.

### 8.5.10 PORTA\_DS

|   | Address | 3        | Ac | cess Mode | Value At Rese | et | Nominal Value |      |      |      |
|---|---------|----------|----|-----------|---------------|----|---------------|------|------|------|
|   | 0x01E   |          |    | R/W       | 0x00          |    |               |      |      |      |
| 5 | Bit7    | Bite     | 6  | Bit5      | Bit4          |    | Bit3          | Bit2 | Bit1 | Bit0 |
|   |         | PORTA_DS |    |           |               |    |               |      |      |      |

PORTA\_DS This register selects the drive strength of PORTA pins. A high selects high drive a low configures a normal drive capability. Refer to Section 3 for drive value.

#### 8.5.11 PORTA AF

| Addre | ess  | Access Mode | Value At Rese | t Nomin | al Value |      |      |
|-------|------|-------------|---------------|---------|----------|------|------|
| 0x01  | F    | R/W         | 0x03          |         |          |      |      |
| Bit7  | Bit6 | Bit5        | Bit4          | Bit3    | Bit2     | Bit1 | Bit0 |
|       | 63   | 7 6         | PORTA         | A_AF    |          |      |      |



PORTA AF This register selects the alternate function of the GPIO pin.

The ports B and C have similar control registers with the following addresses:

| Register | Address (HEX) |
|----------|---------------|
| PORTA_DO | 019           |
| PORTA_OE | 01A           |
| PORTA_PE | 01B           |
| PORTA_DI | 01C           |
| PORTA_PS | 01D           |
| PORTA_DS | 01E           |
| PORTA_AF | 01F           |
| PORTB_DO | 030           |
| PORTB_OE | 031           |
| PORTB_PE | 032           |
| PORTB_DI | 033           |

| Register | Address (HEX) |
|----------|---------------|
| PORTB_PS | 034           |
| PORTB_DS | 035           |
| PORTB_AF | 036           |
| PORTC_DO | 037           |
| PORTC_OE | 038           |
| PORTC_PE | 039           |
| PORTC_DI | 03A           |
| PORTC_PS | 03B           |
| PORTC_DS | 03C           |
| PORTC_AF | 03D           |
|          |               |



The following ports have alternate functions:

| Port     | GPIO Pin | Alternate Function | Description                        |
|----------|----------|--------------------|------------------------------------|
| PORTA<0> | GPIO<0>  | DO                 | DO pin for external memory access  |
| PORTA<1> | GPIO<1>  | CLK                | CLK pin for external memory access |
| PORTA<4> | GPIO<4>  | SDO                | I2S Serial Data Out                |
| PORTA<5> | GPIO<5>  | WS                 | 12S WS                             |
| PORTA<6> | GPIO<6>  | SCK                | I2S Serial Clock                   |
| PORTA<7> | GPIO<7>  | SDI                | I2S Serial Data In                 |
| PORTB<0> | GPIO<8>  | SDO1               | PCM1 Tx Data                       |
| PORTB<1> | GPIO<9>  | SDI1               | PCM1 Rx Data                       |
|          |          |                    | 000                                |

### 8.6 16 bit Indirect Index register R0-R7

- 16 bit R0 ~ R7 register store the VP/VM indexes for the indirect playback commands. Indirect Playback commands include:
  - o PLAY VP@Rn
  - o PLAY VP LP@Rn
  - o EXE VM@Rn

For example: If R0=0x0020, then a PLAY\_VP@R0 command will actually play VP @ index 0x0020; a - EXE\_VM@R0 command will actually execute VM @ index 0x0020

|        | R0-R7 Register Mapping |       |       |                   |       |       |       |  |  |  |  |
|--------|------------------------|-------|-------|-------------------|-------|-------|-------|--|--|--|--|
| Bit 7  | Bit 6                  | Bit 5 | Bit 4 | Bit 3             | Bit 2 | Bit 1 | Bit 0 |  |  |  |  |
|        | <b>CFG20</b> R0[7:0]   |       |       |                   |       |       |       |  |  |  |  |
| V      | <b>CFG21</b> R0[15:8]  |       |       |                   |       |       |       |  |  |  |  |
|        |                        |       | CFG2  | 22 R1[7:0]        |       |       |       |  |  |  |  |
| Illih. |                        |       | CFG2  | <b>3</b> R1[15:8] |       |       |       |  |  |  |  |
| 2 The  |                        |       | CFG2  | 24 R2[7:0]        |       |       |       |  |  |  |  |
| KAX.   | X.                     |       | CFG2  | <b>5</b> R2[15:8] |       |       |       |  |  |  |  |
| 1000   | 37,5                   |       | CFG2  | <b>26</b> R3[7:0] |       |       |       |  |  |  |  |
| - C/V  | ,00                    |       | CFG2  | <b>7</b> R3[15:8] |       |       |       |  |  |  |  |
| C      | 5-40                   |       | CFG2  | 28 R4[7:0]        |       |       |       |  |  |  |  |
|        | W                      | 1     | CFG2  | <b>9</b> R4[15:8] |       |       |       |  |  |  |  |
|        | (67)                   | 6     | CFG2  | <b>PA</b> R5[7:0] |       |       |       |  |  |  |  |
|        | W.                     | 2002  | CFG2  | <b>B</b> R5[15:8] |       |       |       |  |  |  |  |



| <b>CFG2C</b> R6[7:0]  |  |
|-----------------------|--|
| <b>CFG2D</b> R6[15:8] |  |
| <b>CFG2E</b> R7[7:0]  |  |
| <b>CFG2F</b> R7[15:8] |  |

### 8.7 Microphone interface and Auxiliary Interface

The ISD61S00 contains a fully integrated programmable microphone interface. No external components other than the microphone are required to operate the circuit. The microphone interface can operate in three modes: 1) Microphone Voltage gain mode; 2) Microphone Current gain mode; 3) Auxiliary input mode. For the Current gain mode an internal or external resistor can be selected to determine the gain. For the Auxiliary input mode it is recommended external resistors are used, though optionally the internal gain resistor can be selected.

The interface modes above can be selected with register MIC\_MODE[2:0] of register MIC\_CTRL. The microphone block is powered down until MIC\_EN bit of MIC\_CTRL is set to one.

In order to minimize the audible pops and clicks, it is not advised to change the MIC\_GAIN[7:4] in real time but preferably mute the digital signal path prior to any gain changes.

#### 8.7.1 MIC CTRL

| Address | Address  |       | Access Mode |   | Value At Reset |       |       |          |       |
|---------|----------|-------|-------------|---|----------------|-------|-------|----------|-------|
| 0x006   | 0x006    |       | R/W         |   | 0x00           |       |       |          |       |
| Bit 7   | Е        | Bit 6 | Bit         | 5 | Bit 4          | Bit 3 | Bit 2 | Bit 1    | Bit 0 |
|         | MIC_GAIN |       |             |   |                |       |       | MIC_MODE |       |

MIC\_MODE[2:0] Sets AC input amplifier mode of operation (voltage mode, current mode, external resistor, internal resistor)

Table 8-4 Microphone and Auxiliary mode settings

| MIC_MODE[2:0] | Operation mode                                           |
|---------------|----------------------------------------------------------|
| 000           | Microphone Voltage-gain mode with internal gain resistor |
| 001           | Not allowed                                              |
| 010           | Microphone Current-gain mode with internal gain resistor |
| 011           | Microphone Current-gain mode with external gain resistor |
| 100           | Auxiliary input mode with internal gain resistor         |
| 101           | Auxiliary input mode with external gain resistor         |

# nuvoTon

MIC\_GAIN[7:4] Set microphone gain in voltage-gain mode. Adjustable voltage gain range: 14dB~37.6dB, 16 steps linear in dB with step size of approximately 1.5dB.

Table 8-5 Microphone Gain settings

| MIC_GAIN[7:4] | Gain(dB) | Boosted | MIC_GAIN[7:4] | Gain(dB) | Boosted |
|---------------|----------|---------|---------------|----------|---------|
| 0000          | 37.65    | 43.1    | 1000          | 24.80    | 30.5    |
| 0001          | 35.98    | 41.5    | 1001          | 23.17    | 28.7    |
| 0010          | 34.33    | 40      | 1010          | 21.53    | 27.05   |
| 0011          | 32.70    | 38.2    | 1011          | 19.95    | 25.5    |
| 0100          | 31.06    | 36.6    | 1100          | 18.54    | 24.2    |
| 0101          | 29.47    | 35.05   | 1101          | 16.86    | 22.4    |
| 0110          | 27.89    | 33.5    | 1110          | 15.52    | 21.2    |
| 0111          | 26.38    | 31.88   | 1111          | 13.95    | 19.5    |

#### 8.7.2 MIC\_BIAS

| Address |         | Access | Mode | Value At Reset |       |       |       |          |       |
|---------|---------|--------|------|----------------|-------|-------|-------|----------|-------|
| 0x007   |         | R/     | W    |                | 0x00  |       |       |          |       |
| Bit 7   | В       | Bit 6  | Bit  | 5              | Bit 4 | Bit 3 | Bit 2 | Bit 1    | Bit 0 |
|         | MIC_RES |        |      |                |       | BOOST |       | MIC_BIAS |       |

BOOST Boost microphone voltage gain.

MIC\_BIAS[2:0] Set microphone bias voltage reference

Table 8-6 Microphone Bias settings

| MIC_BIAS[2:0] | Vref (V) |
|---------------|----------|
| 000           | 1.992    |
| 001           | 2.191    |
| 010           | 2.434    |
| 011           | 2.738    |
| 100           | 1.218    |
| 101           | 1.253    |
| 110           | 1.512    |
| 111           | 1.754    |

### nuvoton

#### MIC RES[7:4] Set microphone bias resistor

Table 8-7 Microphone Resistor settings

| MIC_RES[7:4] | RL (kΩ) | Code | RL (kΩ) |
|--------------|---------|------|---------|
| 0100         | Open    | 1100 | 1.25    |
| 0101         | 10      | 1101 | 1.11    |
| 0110         | 5       | 1110 | 1 220   |
| 0111         | 3.33    | 1111 | 0.91    |
| 0000         | 2.5     | 1000 | 0.83    |
| 0001         | 2       | 1001 | 0.77    |
| 0010         | 1.67    | 1010 | 0.71    |
| 0011         | 1.42    | 1011 | 0.67    |

The basic operation of the voltage gain mode is shown in Figure 8-6 Microphone Voltage Gain Mode

. The microphone is connected to the pins MCP and MCGND. The pin MCO is connected to the output of the microphone amplifier and can be used for monitoring the AC level. The voltage gain is set by register MIC\_GAIN[7:4]. This register provides a gain range from 14dB to 38dB. In addition the BOOST bit of MIC\_BIAS[3] can be enabled to add an additional 6dB voltage gain. The gain is set by a ratio of internal resistors, providing accurate gain control. The pin MCP also supplies the bias reference for the microphone. The bias consists of a programmable resistor and a programmable low noise voltage reference. The programmable resistor is set by register MIC\_RES[7:4] and can be set to open and 670 Ohm to 10kOhm. The programmable voltage reference is set by register MIC\_BIAS[2:0] and can be set from 1.22Volt to 2.74Volt.





Figure 8-6 Microphone Voltage Gain Mode

For higher gain configurations, the **current gain mode** can be used. Figure 8-7 Microphone Current Gain Mode

shows how the current gain mode is used. The current gain mode uses the same programmable microphone bias voltage and resistor as the voltage gain mode. The gain is set by either the internal gain resistor or an external resistor, depending on the MIC\_MODE setting. Since the current gain mode is using a single resistor, the gain accuracy is limited. However, large gain can be achieved. Note that a 250Ohm ESD protection resistor is connected to the MCO pin. This resistor should be considered when calculating the gain.



Figure 8-7 Microphone Current Gain Mode

The value of  $R_2$  feedback resistor for mode 010 is shown below. It fixes the transimpedance gain. The resistor accuracy is  $\pm 1.15\%$ .

| MIC_GAIN[7:4] | $R_2(k\Omega)$ |
|---------------|----------------|
| 0             | 300            |
| 1             | 247            |
| 2             | 203            |
| 3             | 167            |
| 4             | 137            |
| 5             | 113            |
| 6             | 93             |
| 7             | 76             |
| 8             | 63             |
| 9             | 52             |
| 10            | 42             |
| 11            | 35             |
| 12            | 29             |



| 13 | 24 |
|----|----|
| 14 | 19 |
| 15 | 16 |

The voltage gain from MCP to MCO can be expected in the range of 29 to 55dB with a standard electret microphone and a microphone bias resistor set to 10K Ohm (MIC RES[7:4]=0x05)

The voltage gain from MCP to MCO can be expected in the range of 26 to 49dB with a standard electret microphone and a microphone bias resistor set to 0.67K Ohm (MIC RES[7:4]=0x0B)

One should note that the gain depends on the microphone internal characteristics and part number.

The following figure is an example and should not be taken as an exact list of gains.



Figure 8-8 Current Mode Gain with Electret MIC model

For non-microphone applications one or more Auxiliary inputs can be connected to the MCP pin as shown in Figure 8-9 Auxiliary Input Mode

below. The MIC\_RES register should be set to open in order to disconnect the microphone bias. For the gain setting it is advised to use external gain resistors only for optimal matching and accuracy. The 250Ohm ESD protection resistor should be considered again when calculating the gain. Note that for this mode the MCGND pin is tied to the external supply ground. A clean ground reference should be used for this.



Figure 8-9 Auxiliary Input Mode

#### 8.8 PSTN Analog Input

The PSTN analog input consists of two multiplexed pins to allow on-hook CID snooping along with normal off-hook operation. Input amplifier consists of two stages with independently settable gains as described in Table 8-8.

The input source of each stage is controlled by a multiplexor set by registers described in Table 8-9. Stage one input can be selected from the TI1 input, the TI2 input or a loop-back of the PO output. Stage two inputs can be stage one allowing cascading of gains, or stage one can be bypassed and inputs of TI1, TI2 or TI3 can be selected. Note that TI3 is not necessary available as described in the Pin Configuration (section 3). The two gain stages together can provide gains from 0dB to 42dB. In addition, power control for this amplifier is controlled by the TI\_EN bit of the TI\_CTRL register.

Inputs should be capacitively coupled into the TIxN and TIxP pins. The gain stage feeds the Line ADC which has a full scale range of  $Avdd/(2*1.41)V_{rms}$  or  $Avdd/2V_p$ .

## nuvoTon



Figure 8-10 TI Input Amplifier

### 8.8.1 TI\_GAIN

| Address | A        | Access | Mode  |   | Value At Reset |       |       |       |       |  |
|---------|----------|--------|-------|---|----------------|-------|-------|-------|-------|--|
| 0x004   |          | R/V    | N     |   | 0x00           |       |       | 92    | 95    |  |
| Bit 7   | Bit 6    | 6      | Bit ! | 5 | Bit 4          | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|         | RESERVED |        |       |   | TI_G2          | -     | TI_   | _G1   |       |  |

TI\_G1[1:0] Set stage 1 TI amplifier gain.

TI\_G2[2:0] Set stage 2 TI amplifier gain.

### 8.8.2 TI\_CTRL

| Address |   | Access   | Mode  |  | et    |       |     |       |       |       |
|---------|---|----------|-------|--|-------|-------|-----|-------|-------|-------|
| 0x005   |   | R/       | W     |  | 0x00  |       |     |       |       | _     |
| Bit 7   | Е | Bit 6    | Bit 5 |  | Bit 4 | Bit 3 |     | Bit 2 | Bit 1 | Bit 0 |
| TI_EN   |   | RESERVED |       |  |       |       | TI_ | _S2   | TI_   | _S1   |

TI\_S1[1:0] Select input of stage 1 TI amplifier.

TI\_S2[1:0] Select input of stage 2 TI amplifier.

TI\_EN Enable (power up) TI amplifier.



#### First stage selection

| TI_S1[1] | TI_S1[0] | input selected | 100             |
|----------|----------|----------------|-----------------|
| 0        | 0        | none           | Don't use       |
| 0        | 1        | TI1            | Select TI1 pins |
| 1        | 0        | TI2            | Select TI2 pins |
| 1        | 1        | PO*            | Select PO pins  |

### Second stage selection

| TI_S2[1] | TI_S2[0] | input selected    | 4000            |
|----------|----------|-------------------|-----------------|
| 0        | 0        | Output of stage 1 | default         |
| 0        | 1        | TI1               | Select TI1 pins |
| 1        | 0        | TI2               | Select TI2 pins |
| 1        | 1        | TI3               | Select TI3 pins |

<sup>\*</sup> When this mode is selected the PO+ PO- pins are internally connected to the input of the PSTN analog interface.

#### First stage gain settings

| TI_G1[1] | TI_G1[0] | gain | unit |
|----------|----------|------|------|
| 0        | 0        | 0    | dB   |
| 0        | 1        | 6    | dB   |
| 1        | 0        | 12   | dB   |
| 1        | 1        | 18   | dB   |

#### Second stage gain settings

| TI_G2[2] | TI_G2[1] | TI_G2[0] | gain | unit |
|----------|----------|----------|------|------|
| 0        | 0        | 0        | 0    | dB   |
| 0        | 0        | 1        | 6    | dB   |
| 0        | 1        | 0        | 12   | dB   |
| 0        | 1        | 1        | 18   | dB   |
| 1        | 0        | 0        | 24   | dB   |

|      |        |           |      | W pro  |           |
|------|--------|-----------|------|--------|-----------|
| TI_G | 1[1:0] |           | TI_G | 2[2:0] |           |
| Bin  | Hex    | Gain [dB] | Bin  | Hex    | Gain [dB] |
| 00   | 0      | 0 dB      | 000  | 0      | 0 dB      |
| 01   | 1      | 6 dB      | 001  | 1      | 6 dB      |
| 10   | 2      | 12 dB     | 010  | 2      | 12 dB     |
| 11   | 3      | 18 dB     | 011  | 3      | 18 dB     |
|      |        |           | 100  | 4      | 24 dB     |

Table 8-8 TI Gain Settings

Table 8-9 TI MUX Settings

| TI_S | 1[1:0] |       | TI_S: | 2[1:0] | 20    |  |
|------|--------|-------|-------|--------|-------|--|
| Bin  | Hex    | Input | Bin   | Hex    | Input |  |
| 00   | 0      | None  | 00    | 0      | STG1  |  |
| 01   | 1      | TI1   | 01    | 1      | TI1   |  |
| 10   | 2      | TI2   | 10    | 2      | TI2   |  |
| 11   | 3      | PO    | 11    | 3      | TI3   |  |

### 8.9 Analog Outputs

Analog outputs consist of a differential speaker driver capable of driving  $8\Omega$  and a differential line driver for the PSTN interface capable of driving  $120\Omega$ . These buffers are connected to the two DAC paths incorporating digital gain control. The ANA\_OUT register controls the analog function of these two drivers allowing power control via SPK\_EN and PO\_EN and gain setting (including MUTE) via PO\_GAIN and SPK\_GAIN. In addition a single-ended AUX output capable of driving a load of 1uF plus  $47K\Omega$  in series is available. The AUX driver full scale output voltage is half the one of the PO and SPK drivers.

When the PO and SPK drivers are power down their outputs are tri-stated. When the AUX driver is power down tri-state is achieved by setting the register TRI\_STATE to 1.

When enabled, the DC level on the analog outputs is typically AVDD/2.



Figure 8-11 Analog Output



### 8.9.1 ANA\_OUT

| Address   |   | Access Mode |     | Value At Reset |       | et     |       |          |       |
|-----------|---|-------------|-----|----------------|-------|--------|-------|----------|-------|
| 0x008 R/W |   | 0x00        |     |                |       |        |       |          |       |
| Bit 7     | Е | Bit 6       | Bit | 5              | Bit 4 | Bit 3  | Bit 2 | Bit 1    | Bit 0 |
| PO_EN     |   | PO_GAIN     |     |                |       | SPK_EN |       | SPK_GAIN |       |

SPK\_GAIN Set speaker driver gain

SPK\_EN = 0 Disable (power down) speaker DAC

= 1 Enable speaker DAC

PO\_GAIN Set line driver gain

PO\_EN = 0 Disable (power down) line DAC

= 1 Enable line DAC

| SPK_GAIN[2:0] | Gain(dB) |
|---------------|----------|
| 0XX           | MUTE     |
| 100           | 0        |
| 101           | 0        |
| 110           | 3        |
| 111           | -3       |

| PO_GAIN[5:4] | Gain(dB) |
|--------------|----------|
| 0XX          | MUTE     |
| 100          | 0        |
| 101          | 0        |
| 110          | 3        |
| 111          | -3       |

#### 8.9.2 ANA\_CTRL

| Address |         | Access | s Mode | Value At Reset |           |       |     |       |        |          |
|---------|---------|--------|--------|----------------|-----------|-------|-----|-------|--------|----------|
| 0x009   | 009 R/W |        | w      | 0x00           |           |       |     |       |        |          |
| Bit 7   | Е       | Bit 6  | Bit 5  |                | Bit 4     | Bit 3 |     | Bit 2 | Bit 1  | Bit 0    |
| PU_PO   | PU      | _SPK   | AUX_SI | EL             | TRI_STATE | Re    | ese | erved | PU_AUX | MUTE_AUX |

MUTE\_AUX = 0 Mute auxiliary buffer

= 1 Un-mute auxiliary buffer.

 $PU\_AUX = 0$  power down

= 1 power up

TRI\_STATE = 0 Default

= 1 Disconnect any impedances from the AUXOUT output

- 64 -

AUX\_SEL = 0 PSTN DAC is selected (default)

= 1 SPEAKER DAC is selected

### nuvoton

PU\_SPK = 0 power down

= 1 power up

PU PO = 0 power down

= 1 power up

#### 8.10 DTMF Detection

Dual Tone Multi Frequency (DTMF) signals consist of a sum of two tones: a low tone of 697Hz, 770Hz, 852Hz or 941Hz (row tone) and a high tone of 1209Hz, 1336Hz, 1477Hz or 1633Hz (column tone) as shown in Table 8-10. The DTMF detector filters the incoming signal and separates it into row and column tones, as shown in Figure 8-12. When valid data is detected, the resulting decoded data is pushed onto a FIFO which can be read by the host through the SPI interface.

When DTMF detection is enabled channel data is scanned for DTMF tones. Three programmable timer registers – Present Detect Time (DTMF\_PDT), Acceptance Time (DTMF\_ACCT), and Absent Detect Time (DTMF\_ADT) – and the frequency deviation (DTMF\_FREQ\_DEV) and threshold (DTMF\_THRES) registers allow the user to configure the sensitivity of the DTMF detector, as shown in Figure 8-13 and described below.

The DTMF detector performs a frequency estimation calculation to determine the frequencies present in the channel data input. Once the input signal has been determined to carry energy exceeding DTMF\_THRES at one of the row (column) frequencies for DTMF\_PDT within the error tolerance specified by DTMF\_FREQ\_DEV, the row (column) detect flag is asserted.

When both the row and column detect flags have been asserted, the DTMF\_STATE goes to 1. Once the DTMF\_STATE has been high for DTMF\_ACCT, the signal is determined to be a valid DTMF signal. At this point, DTMF\_RDY is asserted and the received data is decoded from the row and column frequencies and pushed onto the FIFO. The DTMF\_STATE and DTMF\_RDY status flags may be read from the DTMF\_RX\_DATA status register.

When the tone is outside of the tolerance specified by DTMF\_FREQ\_DEV for DTMF\_ADT, the row (column) detect flag is de-asserted.

When a DTMF tone is detected the ISD61S00 can be configured to generate an interrupt to the host processor for service.

DTMF detection is available with the 8KHz sampling rate.



Figure 8-12 DTMF Detector - Functional Block Diagram





Figure 8-13 DTMF Detector Acquisition Timing

Table 8-10 DTMF Tone Decoding

|                  |         |                     | Column frequency    |                     |                     |  |  |  |  |
|------------------|---------|---------------------|---------------------|---------------------|---------------------|--|--|--|--|
|                  |         | 1209 Hz             | 1336 Hz             | 1477 Hz             | 1633 Hz             |  |  |  |  |
|                  | 697 Hz  | 0x01 <sub>hex</sub> | 0x02 <sub>hex</sub> | 0x03 <sub>hex</sub> | 0x0D <sub>hex</sub> |  |  |  |  |
|                  | 037 112 | 1                   | 2                   | 3                   | Α                   |  |  |  |  |
| Dow              | 770 Hz  | 0x04 hex            | 0x05 hex            | 0x06 hex            | 0x0E <sub>hex</sub> |  |  |  |  |
| Row<br>Frequency | 770112  | 4                   | 5                   | 6                   | В                   |  |  |  |  |
| ,                | 852 Hz  | 0x07 hex            | 0x08 hex            | 0x09 hex            | 0x0F <sub>hex</sub> |  |  |  |  |
|                  | 032 112 | 7                   | 8                   | 9                   | С                   |  |  |  |  |
|                  | 941 Hz  | 0x0B hex            | 0x0A hex            | 0x0C hex            | 0x00 hex            |  |  |  |  |
|                  | V-1 112 | *                   | 0                   | #                   | D                   |  |  |  |  |

A detailed description of the DTMF Decoder control registers follows:



#### 8.10.1 DTMF CTRL

| Address | ess Ac  |    | cess Mode | Value At Rese | et N | ominal Value |       |      |
|---------|---------|----|-----------|---------------|------|--------------|-------|------|
| 0x1E0   |         |    | R/W       | 0x00          |      |              |       | _    |
| Bit7    | Bit6    |    | Bit5      | Bit4          | Bit3 | Bit2         | Bit1  | Bit0 |
| DTMF_EN | Reserve | ed | DTMF_F    | REQ_DEV       |      | DT           | MF_TC |      |

DTMF\_TC Sets the time constant used for DTMF signal energy level estimation. The

DTMF\_TC constant controls the speed at which the energy converges. Smaller values of DTMF\_TC cause faster convergence at the expense of lower precision. Higher values of DTMF\_TC will provide a more precise

estimate of the energy while trading off a slower convergence time.

DTMF\_FREQ\_DEV The allowable frequency deviation of DTMF tone detector. As given in Table

8-11

DTMF\_EN Enable DTMF detection block.

Table 8-11 DTMF Frequency Deviation Register

| DTMF_FREQ_DEV | Frequency Deviation |
|---------------|---------------------|
| 0             | 2.0%                |
| 1             | 2.5%                |
| 2             | 3.0%                |
| 3             | 3.5%                |

#### 8.10.2 DTMF\_FIFO\_CTRL

|   | Address  | s     | Ac | ccess Mode | Value At Res | et   | Nomin   | al Value |          |          |
|---|----------|-------|----|------------|--------------|------|---------|----------|----------|----------|
|   | 0x1E1    | 0x1E1 |    | R/W        | 0x40         |      |         |          |          | _        |
| ì | Bit7     | Bit6  |    | Bit5       | Bit4         | Bit3 |         | Bit2     | Bit1     | Bit0     |
| - | Reserved |       |    | FIFO_LEN   |              | Re   | eserved | Reserved | Reserved | FIFO_CLR |

FIFO\_LEN Sets the FIFO level at which the DTMF detector generates an interrupt to the host.

Interrupt is generated when FIFO\_LEN+1 tones have been received.

FIFO\_CLR Resets FIFO to empty and clear the content of the FIFO.



#### **8.10.3 DTMF FIFO**

| Addres | s    | Ac     | cess Mode | Value At Rese | et | Nomin | al Value |       |      |      |
|--------|------|--------|-----------|---------------|----|-------|----------|-------|------|------|
| 0x1E2  |      | R      |           | 0x00          |    |       |          |       |      |      |
| Bit7   | Bit6 | 6 Bit5 |           | Bit5 Bit4     |    | Bit   | 3        | Bit2  | Bit1 | Bit0 |
|        | F    | IFO_I  | DEPTH     |               |    |       | FIFO     | _DATA |      |      |

FIFO\_DATA A read to this register reads back the head of the FIFO and increments read

pointer to next address.

FIFO\_DEPTH Is the number of entries remaining in the FIFO **before** the current read operation.

#### 8.10.4 DTMF\_FIFO\_STATUS

| Addres | s A  | access Mode | Value At Res | et Nomin | al Value |           |          |
|--------|------|-------------|--------------|----------|----------|-----------|----------|
| 0x1E3  |      | R/W         | 0x01         |          |          |           | 12 C     |
| Bit7   | Bit6 | Bit5        | Bit4         | Bit3     | Bit2     | Bit1      | Bit0     |
|        | FIFO | _DEPTH      |              | Reserved | Reserved | FIFO_FULL | FIFO_EMP |

FIFO\_DEPTH Indicates the number of entries present in the DTMF FIFO, same value as

FIFO DEPTH of previous register

FIFO\_FULL Read only active high bit indicating when FIFO is full. Any data received while this

bit is high is lost. Total depth of the DTMF FIFO is 8.

FIFO\_EMP Read only active high bit indicating when FIFO is empty.

#### 8.10.5 DTMF\_THRES

| Address         | S    | Access Mode | Value At Res | et Nomin   | al Value |      |      |  |
|-----------------|------|-------------|--------------|------------|----------|------|------|--|
| 0x1E4~0x        | 1E5  | R/W         | 0x0100       |            |          |      | _    |  |
| Bit7            | Bit6 | Bit5        | Bit4         | Bit3       | Bit2     | Bit1 | Bit0 |  |
| A.              |      |             | DTMF_TH      | IRES[15:8] |          |      |      |  |
| DTMF_THRES[7:0] |      |             |              |            |          |      |      |  |

DTMF THRES

DTMF Threshold, signal level required to qualify as a valid DTMF signal. The threshold in dB is given by 10  $^*$  log<sub>10</sub> (DTMF\_THRES  $^*$  2<sup>-22</sup>). The DTMF threshold ranges from -12 dB to -66 dB, and the default is -42 dB. If the signal level is below DTMF\_THRES, the results of the frequency estimator are ignored and the signal will not be detected as a valid DTMF signal.



## 8.10.6 DTMF\_PDT

| Addres | s    | Acce    | ess Mode | Value At Rese | et Non | ninal Value |      |      |
|--------|------|---------|----------|---------------|--------|-------------|------|------|
| 0x1E6  |      | R/W     |          | 0x00          |        |             |      | _    |
| Bit7   | Bit6 |         | Bit5     | Bit4          | Bit3   | Bit2        | Bit1 | Bit0 |
|        |      | COLVE ! | 200      |               |        |             |      |      |

DTMF\_PDT

This is the Present Detect Time, the time for which a tone must be present to be qualified as a valid DTMF tone. Units are 0.5ms, range is 0-127.5ms.

Publication Release Date: March 10, 2011 Revision 2.7

- 69 -



#### 8.10.7 DTMF ADT

| Address | S    | Ac   | cess Mode | Value At Rese | et Nomi | nal Value |      |      |
|---------|------|------|-----------|---------------|---------|-----------|------|------|
| 0x1E7   |      | R/W  |           | 0x00          |         |           |      |      |
| Bit7    | Bit6 | 1    | Bit5      | Bit4          | Bit3    | Bit2      | Bit1 | Bit0 |
|         |      | W. 7 | (I)       |               |         |           |      |      |

DTMF\_ADT This is the Absent Detect Time, the time for which a tone must be absent before a signal is considered a new DTMF tone. Units are 0.5ms, range is 0-127.5ms.

#### 8.10.8 DTMF\_ACCT

| Addres | s         | Ac | cess Mode | Value At Res | et No | ominal Value | 0    |        |  |  |
|--------|-----------|----|-----------|--------------|-------|--------------|------|--------|--|--|
| 0x1E8  | 0x1E8     |    | R/W       | 0x00         |       |              |      | 337 (0 |  |  |
| Bit7   | Bit6      |    | Bit5      | Bit4         | Bit3  | Bit2         | Bit1 | Bit0   |  |  |
|        | DTMF_ACCT |    |           |              |       |              |      |        |  |  |

DTMF ACCT

This is the Accept Time, (DTMF\_ACCT + 1) \* 0.5ms, the time for which a tone must be stable to be qualified as a correct tone. Units are 0.5ms, range is 0.5-128ms. This guard time improves detection performance by rejecting detected signals with insufficient duration and by masking momentary detection dropout.

8.10.9

#### 8.10.10DTMF RX DATA

| Ado      | dress      | A        | ccess Mode |              | Va        | lue At Reset | Nominal Val | ue   |
|----------|------------|----------|------------|--------------|-----------|--------------|-------------|------|
| 0x       | 1EA        |          | 0x00       |              |           |              |             |      |
| Bit7     | Bit7 Bit6  |          | Bit4       | Bit          | Bit3 Bit2 |              | Bit1        | Bit0 |
| DTMF_RDY | DTMF_STATE | RESERVED | RESERVED   | DTMF_RX_DATA |           |              |             |      |

DTMF\_RX\_DATA

DTMF Detector received data. This register can be used as an alternative to the FIFO. This data is valid when DTMF\_RDY is active.

DTMF STATE

Indicates whether a valid DTMF tone is currently being detected and present

time (PDT) is qualified.

DTMF\_RDY

Indicates that a valid DTMF tone has been present for required hold time (ACCT).

Publication Release Date: March 10, 2011 Revision 2.7

- 70 -



#### 8.10.11DTMF ROW FREQ

|    | Address            | S                        | Ac | cess Mode | Value At Rese | et l | Nominal Va | lue  |      |      |
|----|--------------------|--------------------------|----|-----------|---------------|------|------------|------|------|------|
|    | 0x1EB-0x1EC        |                          | R  |           | 0x0000        |      |            |      |      | -    |
|    | Bit7 Bite          |                          | 5  | Bit5      | Bit4          | Bit3 | 3          | Bit2 | Bit1 | Bit0 |
| EB | DTMF Row Frequency |                          |    |           |               |      | 15:8]      |      |      |      |
| EC |                    | DTMF Row Frequency [7:0] |    |           |               |      |            |      |      |      |

DTMF Row Frequency DTMF\_ROW\_FREQ[15:3] is the integer part of the DTMF Row frequency, DTMF\_ROW\_FREQ[2:0] is the decimal fraction part of the DTMF Row frequency (13.3 format). These two bytes are for debug mode, and display the DTMF Row frequency directly.

#### 8.10.12DTMF\_COL\_FREQ

|    | Address     | s                           | Ac | cess Mode | Value At Rese | et | Nomin | al Value |      |        |
|----|-------------|-----------------------------|----|-----------|---------------|----|-------|----------|------|--------|
|    | 0x1ED-0x1EE |                             | R  |           | 0x0000        |    | _     |          |      | J. (1) |
|    | Bit7 Bit    |                             | 5  | Bit5      | Bit4          |    | Bit3  | Bit2     | Bit1 | Bit0   |
| ED |             | DTMF Column Frequency[15:8] |    |           |               |    |       |          |      |        |
| EE |             | DTMF Column Frequency[7:0]  |    |           |               |    |       |          |      |        |

DTMF Column Frequency DTMF\_COL\_FREQ[15:3] is the integer part of the DTMF Column frequency, DTMF\_COL\_FREQ[2:0] is the decimal fraction part of the DTMF Column frequency (13.3 format). These two bytes are for debug mode, and display the DTMF Column frequency directly.

### 8.10.13Tip & Tricks

Below is an example of an interrupt service routine for the DTMF detector interrupt.

```
unsigned char ucVal;

ucVal = ReadRegister ( CFG_DTMF_FIFO_STATUS );
if( !(ucVal & 0x01)) {
    do{
        // FIFO not empty - get it
        ucVal = ReadRegister ( CFG_DTMF_FIFO );
        // Store data in a FIFO for processing
        dtmfFIFO.data[dtmfFIFO.w_ptr++] = ucVal & 0x0F;
    } while( ((ucVal>>4) & 0xf)>1 );
}
```



### 8.11 DTMF and Arbitrary Tone Generation.

The ISD61S00 has two independently programmable voice-band oscillators for DTMF and FSK tone generation. The tone generators can be controlled by individual registers or automatically by the DTMF or FSK generation sub-systems.



Figure 8-14 Tone Generator Block Diagram

The tone generator block operates in three different modes:

- 1. DTMF Mode: in this mode DTMF digits are generated from data read from a FIFO for a register-specified on and off time time.
- 2. Programmable Mode: This mode generates a user-defined tone for a register-specified on and time time.
- 3. Continuous Mode: This mode generates a user-defined tone continuously until the user intervenes to stop generation.

In Dual Tone Multi Frequency (DTMF) mode two tones are used to generate a DTMF digit. One tone is chosen from four possible row tones, while the other tone is chosen from four possible column tones. The sum of these tones constitutes one of 16 possible DTMF digits as shown in Table 8-13. Tones are generated according to the data written in the TONE\_INDEX\_X registers. Up to twenty four DTMF digits can be loaded into these registers for transmission. The register TONE\_LENGTH determines how many of these DTMF digits will be generated.

For example, to generate the DTMF string 4085442222, TONE\_LENGTH is set to 10, the number of digits to transmit, TONE\_INDEX\_0 is loaded with 0x40, TONE\_INDEX\_1 is loaded with 0x85 etc.. To generate the tones, DTMF\_MODE, GEN\_EN and CLK\_EN are all set high in the TONE\_CTRL register. When digits have been generated GEN\_EN will be self-cleared indicating operation has finished.

In programmable mode the TONE\_LENGTH register sets the number of tones to generate. Tones have a duration of TONE\_ON\_TIME and are spaced TONE\_OFF\_TIME apart. To generate a single tone of longer than 255ms the TONE\_OFF\_TIME can be set to zero and a tone of TONE\_LENGTH\*TONE\_ON\_TIME ms can be generated.

Continuous mode is entered by setting TONE\_ON\_TIME, TONE\_OFF\_TIME, and TONE\_LENGTH all to 0. The user may then set the frequency and level for tones A and/or B, which will then be generated continuously as long as GEN EN and CLK EN are set high.

Configuration for the three modes is listed below.

Table 8-12 Tone Generation Mode Setup

| Mode | TONE_FREQ_A |              | TONE_ON_TIME | TONE_OFF_TIME | TONE_LENGTH | INDEX_n |
|------|-------------|--------------|--------------|---------------|-------------|---------|
|      | TONE_FREQ_B | TONE_LEVEL_B |              |               |             |         |



| Continuous<br>Mode   | User defined | User defined | Set : 0      | Set : 0      | Set : 0                                   | Don't care     |
|----------------------|--------------|--------------|--------------|--------------|-------------------------------------------|----------------|
| DTMF Mode            | Don't care   | User defined | User defined | User defined | Number of digits in tone index registers. | Digits to send |
| Programmable<br>Mode | User defined | User defined | User defined | User defined | Number of tones to generate.              | Don't care     |

### 8.11.1 TONE\_CTRL

| Address | 3     | Access Mode       |       | ess Mode Value At Reset |          | Value   |             |        |
|---------|-------|-------------------|-------|-------------------------|----------|---------|-------------|--------|
| 0x1C0   |       | R/W               |       | 0x00                    |          |         | 90 × 6      | 2 2    |
| Bit 7   | Bit   | 6                 | Bit 5 | Bit 4                   | Bit 3    | Bit 2   | Bit 1       | Bit 0  |
| CLK_EN  | Reser | Reserved Reserved |       | Reserved                | Reserved | Reserve | d DTMF_MODE | GEN_EN |

GEN\_EN 1: Start tone generation. 0: Write a zero to stop tone generation. GEN\_EN will self-clear after

completion of tone generation in DTMF mode or in programmable mode.

DTMF\_MODE 1: DTMF mode. 0: Programmable tone mode.

CLK\_EN 1: Enable clk. 0: Disable clk. To minimize power consumed by the tone generator, clock

should be disabled when not in use.

## 8.11.2 TONE\_FREQ\_A

C1

| Address          | S         | Ac                | cess Mode | Value At Reset |      | Nominal Value |      |      |   |
|------------------|-----------|-------------------|-----------|----------------|------|---------------|------|------|---|
| 0x1C1-0x         | 1C2       | R/W               |           | 0x0000         |      |               |      |      | _ |
| Bit7             | Bit6 Bit5 |                   | Bit4      |                | Bit3 | Bit2          | Bit1 | Bit0 |   |
| Reserved         |           | TONE_FREQ_A[14:8] |           |                |      |               |      |      |   |
| TONE_FREQ_A[7:0] |           |                   |           |                |      |               |      |      |   |

TONE\_FREQ\_A Sets the frequency of tone A to TONE\_FREQ\_A \* 2.5 Hz. If set to zero, tone A is disabled. Register is ignored in DTMF mode. Valid range for this register is 0x0000 – 0x0640 (4 kHz).

- 73 -



#### 8.11.3 TONE FREQ B

C3 C4

| Address  | Address          |     | cess Mode | Value At Rese | t Nomir     | nal Value |      |  |  |  |
|----------|------------------|-----|-----------|---------------|-------------|-----------|------|--|--|--|
| 0x1C3-0x | 1C4              | R/W |           | 0x0000        |             |           |      |  |  |  |
| Bit7     | Bit6 Bit5        |     | Bit4      | Bit3          | Bit2        | Bit1      | Bit0 |  |  |  |
| Reserved |                  |     |           | TON           | IE_FREQ_B[1 | 4:8]      | 8    |  |  |  |
|          | TONE_FREQ_B[7:0] |     |           |               |             |           |      |  |  |  |

TONE\_FREQ\_B Sets the frequency of tone B to TONE\_FREQ\_B \* 2.5 Hz. If set to zero, tone B is disabled. Register is ignored in DTMF mode. Valid range for this register is 0x0000 – 0x0640 (4 kHz).

## 8.11.4 TONE\_LEVEL\_A

| Address |     |             | ess Mode   | Value At Reset | Nominal | Value |       |       |  |
|---------|-----|-------------|------------|----------------|---------|-------|-------|-------|--|
| 0x1C5   |     |             | R/W        | 0x00           |         |       |       | 40    |  |
| Bit 7   | Bit | Bit 6 Bit 5 |            | Bit 4          | Bit 3   | Bit 2 | Bit 1 | Bit 0 |  |
|         |     |             | TONE_LEV_A |                |         |       |       |       |  |

TONE LEV A Sets the level of tone A relative to full scale. Level (dBFS) = (TONE LEV A-63)/2

#### 8.11.5 TONE LEVEL B

| Address |     |           | ess Mode | Value At Reset | Nominal | Value |       |       |
|---------|-----|-----------|----------|----------------|---------|-------|-------|-------|
| 0x1C6   |     |           | R/W      | 0x00           |         |       |       |       |
| Bit 7   | Bit | t 6 Bit 5 |          | Bit 4          | Bit 3   | Bit 2 | Bit 1 | Bit 0 |
|         |     |           |          | <u> </u>       | TONE_   | LEV_B | -     |       |

TONE\_LEV\_A Sets the level of tone A relative to full scale. Level (dBFS) = (TONE\_LEV\_A-63)/2

### 8.11.6 TONE\_ON\_TIME

| Address | Acc          | ess Mode | Value At Reset | t Nomina | al Value    |  |       |       |  |  |
|---------|--------------|----------|----------------|----------|-------------|--|-------|-------|--|--|
| 0x1C7   | 30%          | R/W      | 0x00           |          |             |  |       |       |  |  |
| Bit 7   | Bit 6        | Bit 5    | Bit 4          | Bit 3    | Bit 3 Bit 2 |  | Bit 1 | Bit 0 |  |  |
|         | TONE_ON_TIME |          |                |          |             |  |       |       |  |  |

TONE\_ON\_TIME Sets the present (on) time of each tone to TONE\_ON\_TIME \* 1ms. Set to zero for continuous mode.



#### 8.11.7 TONE\_OFF\_TIME

| Address | ddress Access Mode |       | ess Mode | Value At Reset | Nominal | Value |       |       |  |
|---------|--------------------|-------|----------|----------------|---------|-------|-------|-------|--|
| 0x1C8   |                    | R/W   |          | 0x00           |         |       |       | _     |  |
| Bit 7   | Bit                | Bit 6 |          | Bit 4          | Bit 3   | Bit 2 | Bit 1 | Bit 0 |  |
|         | TONE_OFF_TIME      |       |          |                |         |       |       |       |  |

TONE\_OFF\_TIME It sets the absent (off) time between each tone to TONE\_OFF\_TIME \* 1ms. Set to zero for continuous mode.

### 8.11.8 TONE\_LENGTH

| Address  | 3    | Acc         | ess Mode | Value At Reset | t Non | Nominal Value |             |       |       |
|----------|------|-------------|----------|----------------|-------|---------------|-------------|-------|-------|
| 0x1C9    |      | R/W         |          | 0x00           |       |               |             | 17.01 | Lline |
| Bit 7    | Bit  | Bit 6 Bit 5 |          | Bit 4          | Bit 3 |               | Bit 2       | Bit 1 | Bit 0 |
| Reserved | Rese | rved        | Reserved |                |       |               | TONE_LENGTH | +     |       |

TONE\_LENGTH This register determines the number of DTMF digits to be sent in DTMF mode. Digits are stored, two per byte, in the TONE\_INDEX\_X registers. The maximum number of DTMF digits is 24.

In programmable tone mode, the tone length sets the number of tones to generate, maximum number is 24.

For continuous mode, TONE LENGTH must be set to 0.

8.11.9



### 8.11.10TONE\_INDEX\_0 ~ TONE\_INDEX\_A

|    | Address<br>0x1D0-0x1 |      | Access Mode<br>R/W | Value At Reset | Nomina   | al Value |      |      |  |  |  |
|----|----------------------|------|--------------------|----------------|----------|----------|------|------|--|--|--|
|    | Bit7                 | Bit6 | Bit5               | Bit4           | Bit3     | Bit2     | Bit1 | Bit0 |  |  |  |
| D0 | •                    | D    | igit 0             |                | Digit 1  |          |      |      |  |  |  |
| D1 |                      | D    | igit 2             |                | Digit 3  |          |      |      |  |  |  |
| D2 |                      | D    | igit 4             |                |          | Dig      | it 5 |      |  |  |  |
| D3 |                      | D    | igit 6             |                | Digit 7  |          |      |      |  |  |  |
| D4 |                      | D    | igit 8             |                |          | Dig      | it 9 |      |  |  |  |
| D5 |                      | Di   | git 10             |                | Digit 11 |          |      |      |  |  |  |
| D6 |                      | Di   | git 12             |                | Digit 13 |          |      |      |  |  |  |
| D7 |                      | Di   | git 14             |                |          | Digi     | t 15 |      |  |  |  |
| D8 |                      | Di   | git 16             |                |          | Digi     | t 17 |      |  |  |  |
| D9 |                      | Di   | git 18             |                | Digit 19 |          |      |      |  |  |  |
| DA |                      | Di   | git 20             |                | Digit 21 |          |      |      |  |  |  |
| DB |                      | Di   | git 22             |                |          | Digi     | t 23 |      |  |  |  |

Digit 0 ~ 23 These registers can be loaded with up to 24 DTMF digits. The DTMF generator will send the fall TONE\_LENGTH digits in this register bank sequentially. The frequencies generated by each nibble are defined in Table 8-13.

Table 8-13 DTMF Frequency Mapping.

|                  |         |                     | Column f            | requency            |                     |
|------------------|---------|---------------------|---------------------|---------------------|---------------------|
|                  |         | 1209 Hz             | 1336 Hz             | 1477 Hz             | 1633 Hz             |
|                  | 697 Hz  | 0x01 hex            | 0x02 <sub>hex</sub> | 0x03 hex            | 0x0D hex            |
|                  | 037 112 | 1                   | 2                   | 3                   | Α                   |
| Dow.             | 770 Hz  | 0x04 hex            | 0x05 hex            | 0x06 hex            | 0x0E <sub>hex</sub> |
| Row<br>Frequency | 770112  | 4                   | 5                   | 6                   | В                   |
| S                | 852 Hz  | 0x07 hex            | 0x08 hex            | 0x09 hex            | 0x0F <sub>hex</sub> |
| Azı              | 002 112 | 7                   | 8                   | 9                   | С                   |
| 200              | 941 Hz  | 0x0B <sub>hex</sub> | 0x0A hex            | 0x0C <sub>hex</sub> | 0x00 hex            |
| 500              | V-1 112 | *                   | 0                   | #                   | D                   |

## 8.12 FSK Generation

### nuvoton

The ISD61XX provides an FSK generator supporting Bell 202, Bell 103, ITU-T V.23 and ITU-T V.21 standard FSK. The FSK Generator controls the tone generator to generate phase continuous tones at the appropriate frequency and baud rate. The generator can be configured to package bytes with selectable start and stop bits and a parity bit. Alternatively, the user may enable software mode (SW\_MODE) and configure mark and space frequencies and baud rate generate arbitrary FSK waveforms.

The block diagram of the FSK generator is shown below. Data to be transmitted is loaded into the 8 deep FIFO. The interface can be configured to generate interrupts to the host when this FIFO is empty or less than half full. The protocol for transmission is selected by the control registers FSKE\_CTRL1 and FSK\_CTRL2. Bits in these registers allow the user to configure the baud rate, mark and space frequencies, parity bit generation and START and STOP bit generation.

FSK transmission is initiated by asserting FSK\_EN bit. The FSK transmit data is clocked serially out of the FIFO one byte at a time beginning with the LSB. If package mode (PACKAGE\_EN) is enabled, a 'start bit' (Space) will automatically be added to the head of the FSK transmit data. Furthermore, one or two 'stop bits' (Mark) are added to the end of the FSK transmit data, depending on the setting of STOP\_SEL. If package mode is not enabled the FSK transmit data is transmitted as it appears in the FSK FIFO.



Figure 8-15 Architecture of Linear FSK Waveform Generator



#### 8.12.1 FSKE CTRL1

| Address | Access     | Mode Value At  |      | t Reset | No | minal Value |       |         |       |
|---------|------------|----------------|------|---------|----|-------------|-------|---------|-------|
| 0x160   | 0x160 R/V  |                | 0x00 |         |    |             |       |         |       |
| Bit 7   | Bit 6      | Bit 6 Bit 5    |      | Bit 4   |    | Bit 3       | Bit 2 | Bit 1   | Bit 0 |
| FSK_EN  | PACKAGE_EN | CKAGE_EN HALF_ |      | FSK_TX  | ON | STOP_SEL    |       | RESERVE | D     |

FSK\_EN 1: Enable FSK encoder. 0: Power down FSK encoder.

PACKAGE\_EN 1: Package mode. 0: Normal mode. In package mode data byte will be packaged as follows:

A start bit at SPACE frequency.

• The data byte.

A parity bit as determined by FSKE CTRL2

• One or two stop bits at MARK frequency depending on STOP SEL bit.

HALF FIFO INT Enables interrupt when FIFO depth changes from 5 to 4 (half empty condition). The FIFO

also generates an interrupt when FSK TX ON is enabled and the FIFO is empty.

FSK\_TX\_ON When set FSK Encoder will transmit data from transmit shift register. Also when set

encoder will generate an interrupt when FIFO is empty.

STOP SEL 1: Two STOP bits generated. 0: One STOP bit generated.

#### **8.12.2 FSKE CTRL2**

| Address   | Address     |  | ess Mode | Value At Reset | Nominal  | Value |          |       |
|-----------|-------------|--|----------|----------------|----------|-------|----------|-------|
| 0x161     | 0x161       |  | R/W      | 0x23           |          |       |          | _     |
| Bit 7     | Bit 6       |  | Bit 5    | Bit 4          | Bit 3    | Bit 2 | Bit 1    | Bit 0 |
| PARITY_EN | PARITY_TYPE |  | IIR_EN   | RESERVED       | BAUD_110 |       | SPEC_SEL |       |

PARITY EN 1: Enable parity generation. 0: Disable parity generation.

PARITY\_TYPE 1: Even parity. 0: Odd parity.

IIR EN Enable IIR filter for FSK power mask specification. (Default on)

BAUD\_110 When set generate FSK at 110 baud if Bell 103 selected.

SPEC\_SEL Determines the FSK specification that is generated according to Table 8-14.

Table 8-14 FSK Encoder Specification Selection.

| SPEC_SEL | 000  | 001  | 010         | 011      | 100      | 101      | 110  | 111  |
|----------|------|------|-------------|----------|----------|----------|------|------|
| Spec.    | V.23 | V.23 | Bell<br>202 | Bell 202 | Bell 103 | Bell 103 | V.21 | V.21 |



| Baud | 0            | 75    | 1200   | 150   | 1200   | 300 bps | 300 bps | 300 bps | 300 bps |
|------|--------------|-------|--------|-------|--------|---------|---------|---------|---------|
| Rate | 1            | bps   | bps    | bps   | bps    | 110 bps | 110 bps | 300 pps | 300 bps |
| Mark | <b>(</b> '1' | 390Hz | 1300Hz | 387Hz | 1200Hz | 1270Hz  | 2225Hz  | 980Hz   | 1650Hz  |
| Spac | e '0'        | 450Hz | 2100Hz | 487Hz | 2200Hz | 1070Hz  | 2025Hz  | 1180Hz  | 1850Hz  |

### 8.12.3 FSKE\_TX\_DATA

| Address | 5     | Acce | Access Mode Value At Reset Nominal Value |       | l Value |       |       |       |
|---------|-------|------|------------------------------------------|-------|---------|-------|-------|-------|
| 0x162   |       | w    |                                          | 0x00  |         | a.    | 100   |       |
| Bit 7   | Bit 6 |      | Bit 5                                    | Bit 4 | Bit 3   | Bit 2 | Bit 1 | Bit 0 |
|         |       | 7    | 40 M                                     | _     |         |       |       |       |

FSK\_TX\_DATA A write to this register pushes the data onto the Tx FIFO.

### 8.12.4 FSKE\_STATUS

| Address  | Address A |      | ess Mode | Value At Reset | Nominal | Value  |       |       |
|----------|-----------|------|----------|----------------|---------|--------|-------|-------|
| 0x163    | 0x163     |      | R        | 0x00           |         |        |       | 02    |
| Bit 7    | Bit 6     |      | Bit 5    | Bit 4          | Bit 3   | Bit 2  | Bit 1 | Bit 0 |
| RESERVED | RESE      | RVED | FIFO_EMP | FIFO_FULL      |         | FIFO_I | DEPTH |       |

FIFO\_DEPTH Returns the current number of entries in the Tx FIFO.

FIFO\_FULL Set when Tx FIFO is full.

FIFO\_EMP Set when Tx FIFO is empty.

### 8.12.5 FSKE\_GAIN

| , | Address           | Address A |      | ess Mode | Value At Reset | t | Nominal | Value |   |       |       |
|---|-------------------|-----------|------|----------|----------------|---|---------|-------|---|-------|-------|
|   | 0x164             |           |      | R/W      | 0x39           |   |         |       |   |       | _     |
|   | Bit 7             | 7 Bit 6   |      | Bit 5    | Bit 4          |   | Bit 3   | Bit 2 | 2 | Bit 1 | Bit 0 |
| Š | RESERVED RESERVED |           | RVED | FSK_GAIN |                |   |         |       |   |       |       |

**FSK GAIN** 

This register controls the gain of the generated FSK waveform relative to full scale. Gain (dBFS) =  $(FSK\_GAIN-63)/2.0$  Gain range is 0 to -31.5dBFS

### 8.12.6 FSKE\_PROG

| Address | Address Acc |       | Value At Reset | Nominal | Value |       |       |
|---------|-------------|-------|----------------|---------|-------|-------|-------|
| 0x165   | 47%         | R/W   | 0x00           |         |       |       | _     |
| Bit 7   | Bit 6       | Bit 5 | Bit 4          | Bit 3   | Bit 2 | Bit 1 | Bit 0 |

- 79 -



| Address | S    | Acc  | ess Mode | Value At Reset | t Nominal | Value    |          |        |
|---------|------|------|----------|----------------|-----------|----------|----------|--------|
| SW_MODE | RESE | RVED | RESERVE  | D RESERVED     | RESERVED  | RESERVED | RESERVED | SW_FLT |

SW MODE When set, SPEC SEL is ignored and the FSK encoder frequencies and baud rate are

controlled by FSKE\_MARK\_FREQ, FSKE\_SPACE\_FREQ, and FSKE\_BAUD described

below.

SW\_FLT This register controls the specification for the filter controlled by IIR\_EN (0x23.5)

0: use built in filter coefficients.

1: use software programmable filter coefficients. These coefficients are stored in the

CAS/ATD tone detector RAM accessible through registers 0x274~0x275

#### 8.12.7 FSKE BAUD (SW MODE = 1)

| Address            |                     | Access Mode |               | Value At Rese | t  | Nominal | Value |     |           |             |  |
|--------------------|---------------------|-------------|---------------|---------------|----|---------|-------|-----|-----------|-------------|--|
| 0x166~0x           | 6~0x168             |             | R/W           | 0x00000       |    |         |       |     | 2         | 6           |  |
| Bit 7              | Bit 6               |             | 6 Bit 5 Bit 4 |               |    | Bit 3   | Bit   | 2   | Bit 1     | Bit 0       |  |
| RESERVED           | D RESERVED F        |             | RESERVED      | RESERVED      | RI | ESERVED | RESER | VED | BAUD_RATE | _CNT[17:16] |  |
|                    | BAUD_RATE_CNT[15:8] |             |               |               |    |         |       |     |           |             |  |
| BAUD_RATE_CNT[7:0] |                     |             |               |               |    |         |       |     |           |             |  |

BAUD\_RATE\_CNT In SW\_MODE these registers determine the baud rate of generated FSK. Each bit is generated for BAUD\_RATE\_CNT \* 81.38ns.

Baud rate = 1/( BAUD\_RATE\_CNT \* 81.38e-9)
BAUD RATE CNT = 12,288,000/baud rate

#### 8.12.8 FSKE MARK FREQ (SW MODE = 1)

|                | Address     |           | Access Mode Value At |       | Value At Reset | Nominal     | Value |  |       |       |
|----------------|-------------|-----------|----------------------|-------|----------------|-------------|-------|--|-------|-------|
|                | 0x169~0x16A |           | R/W                  |       | 0x00           |             |       |  |       |       |
|                | Bit 7       | Bit 6 Bit |                      | Bit 5 | Bit 4          | Bit 3       | Bit 2 |  | Bit 1 | Bit 0 |
| R              | RESERVED    |           |                      |       | М              | ARK_FREQ[14 | :8]   |  |       |       |
| MARK_FREQ[7:0] |             |           |                      |       |                |             |       |  |       |       |

MARK\_FREQ In SW\_MODE these registers determine the mark frequency of the generated FSK. Frequency is given by MARK FREQ \* 2.5Hz.

- 80 -



## 8.12.9 FSKE\_SPACE\_FREQ (SW\_MODE = 1)

| Address  | S               | Access Mode |       | Value At Reset | Nominal     | Value |       |       |  |  |
|----------|-----------------|-------------|-------|----------------|-------------|-------|-------|-------|--|--|
| 0x16B~0x | 16C             | R/W         |       | 0x00           |             | 100   |       |       |  |  |
| Bit 7    | Bit 6           |             | Bit 5 | Bit 4          | Bit 3       | Bit 2 | Bit 1 | Bit 0 |  |  |
| RESERVED |                 |             |       | SP             | ACE_FREQ[14 | :8]   |       |       |  |  |
|          | SPACE_FREQ[7:0] |             |       |                |             |       |       |       |  |  |

SPACE\_FREQ In SW\_MODE these registers determine the space frequency of the generated FSK. Frequency is given by SPACE\_FREQ \* 2.5Hz.

#### 8.12.10 FSKE\_TEST

| Address  | Address A |      | ess Mode | Value At Reset | Nominal  | Value    |          |          |
|----------|-----------|------|----------|----------------|----------|----------|----------|----------|
| 0x16D    |           |      | R/W      | 0x00           |          |          |          | 16.0     |
| Bit 7    | Bit 6     |      | Bit 5    | Bit 4          | Bit 3    | Bit 2    | Bit 1    | Bit 0    |
| RESERVED | RESE      | RVED | RESERVED | RESERVED       | AUTO_GEN | RESERVED | RESERVED | RESERVED |

AUTO\_GEN Setting AUTO\_GEN will implicitly set FSK\_EN, FSK\_TX\_ON, PACKAGE\_EN, and STOP SEL. The FSK FIFO will be fed random data generated by LFSR.

### 8.12.11

#### 8.12.12 Example FSK Generator Usage

Below is an example of an interrupt service state machine to service the FSK generation interrupt. The general configuration of the encoder and path is assumed to be setup and a 10ms timer tick interrupt also enabled. The routine will send out carrier synchronization signal along with data loaded into a transmit FIFO.

```
PUBLIC void vFSKGenFSM(void)
{
    static byte byCounter;
    byte i, tmp;
```

### nuvoTon

```
byte bNumChanSeizeBytes = NUM SEIZE;
byte bNumMarkBytes = NUM MARK;
switch (byFSKGenState)
       case FSKG IDLE:
       if(bUsbCtrl[0] & USB CTRL0 FSK GEN START)
               byFSKGenState = FSKG CHANNEL SEIZURE;
       break;
       case FSKG CHANNEL SEIZURE:
       // The assumption here is that the FSK encoder block
       // general configuration has been setup already now
       // we just turn off package mode and send channel seizure
        // signal.
        tmp = ReadRegister(CFG FSKE CTRL1);
        tmp &= ~CFG FSKE CTRL1 PACKAGE EN;
        tmp |= CFG_FSKE_CTRL1__FSK_TX_ON | CFG_FSKE_CTRL1__FSK_EN
| CFG_FSKE_CTRL1__HALF_FIFO_INT;
       writeCfgReg(CFG_FSKE_CTRL1,tmp);
       tmp = ReadRegister(CFG FSKE CTRL2);
        tmp &= ~CFG FSKE CTRL2 PARITY EN;
       writeCfgReg(CFG FSKE CTRL2,tmp);
       if(bNumChanSeizeBytes > 8)
               // Load first 8 bytes into FSK FIFO
               for (i=0; i<8; i++)
                       writeCfgReg(CFG FSKE FIFO W,0x55);
               byFSKGenState = FSKG CHANNEL SEIZURE2;
               bNumChanSeizeBytes -=8;
       else if(bNumChanSeizeBytes != 0)
        // Load bytes into FSK FIFO
               for (i=0;i< bNumChanSeizeBytes;i++)</pre>
                       writeCfgReg(CFG FSKE FIFO W,0x55);
               byFSKGenState = FSKG CARRIER GEN;
               bNumChanSeizeBytes = 0;
                // No Channel Seizure. Add MARK and go to carrier gen.
               writeCfgReg(CFG FSKE FIFO W, 0xFF);
               byFSKGenState = FSKG CARRIER GEN;
```

#### nuvoton

```
bvCounter = 0;
break;
case FSKG CHANNEL SEIZURE2:
if(DevStatus[2] & STATUS2 FSK E)
       // We get here FIFO interrupt has occurred. There is space for
       // at least 4 bytes (half interrupt set)
       if(bNumChanSeizeBytes > 3)
       // Load 4 bytes into FSK FIFO
               for (i=0; i<4; i++)
                       writeCfgReg(CFG FSKE FIFO W, 0x55);
               byFSKGenState = FSKG CHANNEL SEIZURE2;
               bNumChanSeizeBytes -=4;
       else
       // Load bytes into FSK FIFO
               for (i=0;i< bNumChanSeizeBytes;i++)</pre>
                       writeCfgReg(CFG FSKE FIFO W,0x55);
               writeCfgReg(CFG FSKE FIFO W, 0xFF);
               byFSKGenState = FSKG CARRIER GEN;
               bNumChanSeizeBytes = 0;
break;
case FSKG CARRIER GEN:
// Getting here means we have finished loading sych signal
// but does not mean that FIFO is empty. Next we need to wait
// a certain number of ms before sending first data. This can be
// achieved by sending 0xFF.
if(DevStatus[2] & STATUS2 FSK E)
       // We get here FIFO interrupt has occurred. There is space for
       // at least 4 bytes (half interrupt set)
       if(bNumMarkBytes > 3)
        // Load 4 bytes into FSK FIFO
               for (i=0; i<4; i++)
                       writeCfgReg(CFG FSKE FIFO W,0xFF);
               byFSKGenState = FSKG CARRIER GEN;
               bNumMarkBytes -=4;
```

## nuvoton

```
// Load bytes into FSK FIFO
                               for (i=0;i< bNumMarkBytes;i++)</pre>
                                       writeCfgReg(CFG FSKE FIFO W,0xFF);
                               writeCfgReg(CFG FSKE FIFO W, 0xFF);
                               // Ensure that next INT is for FIFO empty
                               tmp = ReadRegister(CFG FSKE CTRL1);
                               tmp &= ~CFG FSKE CTRL1 HALF FIFO INT;
                               writeCfgReg(CFG FSKE CTRL1,tmp);
                               byCounter = 0;
                               byFSKGenState = FSKG DATA CONFIG;
                               bNumMarkBytes = 0;
               break;
               case FSKG DATA CONFIG:
               if(DevStatus[2] & STATUS2 FSK E)
               // Carrier phase finished set up data transfer.
                       tmp = ReadRegister(CFG FSKE CTRL1);
tmp |= CFG_FSKE_CTRL1__PACKAGE_EN | CFG_FSKE_CTRL1__FSK_TX_ON | CFG_FSKE_CTRL1__FSK_EN | CFG_FSKE_CTRL1__HALF_FIFO_INT;
                       writeCfgReg(CFG FSKE CTRL1,tmp);
                       tmp = ReadRegister(CFG FSKE CTRL2);
                       tmp |= CFG FSKE CTRL2 PARITY EN;
                       writeCfgReg(CFG FSKE CTRL2,tmp);
                       if(TxDataFifo.Depth >= 8)
                               // Load the first 8 samples
                               for (i=0; i<8; i++)
        writeCfgReg(CFG FSKE FIFO W,TxDataFifo.Fifo Buffer[(TxDataFifo.ReadIndex++ & 0x3F)]);
                               TxDataFifo.Depth -= 8;
                       byFSKGenState = FSKG DATA TX;
               break;
                case FSKG DATA TX:
                if((DevStatus[2] & STATUS2 FSK E) || (DevStatus[3] & STATUS3 TIMER INT))
                       // Get here either for a FIFO int or TIMER interrupt.
                       // Find amount of space on FIFO
                       tmp = 8 - (ReadRegister(CFG FSKE STATUS) & 0x0F);
                       if(TxDataFifo.Depth >= tmp)
                               // There are tmp available bytes to transmit
```

### nuvoton

```
for (i=0;i<tmp;i++)
writeCfgReg(CFG_FSKE_FIFO_W,TxDataFifo.Fifo_Buffer[(TxDataFifo.ReadIndex++ & 0x3F)]);
                       TxDataFifo.Depth -= tmp;
               else if(TxDataFifo.Depth)
                       // There are more bytes to {\tt Tx}
                       for (i=0;i<TxDataFifo.Depth;i++)
writeCfgReg(CFG FSKE FIFO W,TxDataFifo.Fifo Buffer[(TxDataFifo.ReadIndex++ & 0x3F)]);
                       TxDataFifo.Depth -= TxDataFifo.Depth;
               else
                       // Only get to here if TxDataFIFO is empty. Check for EOT
                      // condition which is USB CTRLO FSK GEN START set low. If so
                       // and FSK FIFO is empty we can end transmission.
                      if(((bUsbCtrl[0] & USB CTRL0 FSK GEN START)==0)
                              && (tmp == 8))
                              tmp = ReadRegister(CFG FSKE CTRL1);
                              tmp &= \sim (CFG FSKE CTRL1 FSK TX ON |CFG FSKE CTRL1 FSK EN);
                              writeCfgReg(CFG FSKE CTRL1,tmp);
                              byFSKGenState = FSKG IDLE;
       break;
       default:
       byFSKGenState = FSKG_IDLE;
       break;
```

### 8.13 FSK Detection

The ISD61XX has an FSK Detector supporting Bell 202, Bell 103, ITU-T V.21 and ITU-T V.23 standard FSK. The detector is capable of operating at baud rates of 75, 110, 150, 300, and 1200bps. The architecture of the FSK detection system is shown in Figure 8-16 Block Diagram of FSK Detector

## nuvoton

.The system consists of filtering the incoming signal followed by a match filter to extract FSK data. Additional blocks perform carrier detection and clock recovery to synchronize the data and load it into a FIFO for host processing. The match filter consists of a shift register sampling the signal at 48kHz. This sampled waveform is compared to the matching templates impulse\_L and impulse\_H for the mark and space frequencies each sample period. A peak detector determines which of the frequencies is present and outputs the result.

8-bit FSK data is packaged along with optional START, STOP and PARITY bits. The expected format of the data is configurable. Transmission of a '1' bit is called a MARK, transmission of a '0' bit is called a SPACE. MARK and SPACE frequencies are determined by the FSK standard configured. The 8-bit data is transmitted LSB first.

The match filter calculates a matching score for the SPACE (Y0) and MARK (Y1) for each sample period. The score is determined by rotating the pattern template against the input signal (FSK\_IN) and counting the number of matches to the template giving a score between 0 (no matching bits) and N (maximal matching bits). To improve detection accuracy and noise immunity, the detection can be performed over multiple samples. This is controlled by the FSKD\_JUDGE register where detection can operate between one and ten sample periods.



Figure 8-16 Block Diagram of FSK Detector

#### 8.13.1 FSKD CTRL

| Address | Address A |     | ess Mode | Value At Reset | Nominal V | 'alue |   |       |       |
|---------|-----------|-----|----------|----------------|-----------|-------|---|-------|-------|
| 0x180   |           | R/W |          | 0x00           |           |       |   |       | _     |
| Bit 7 B |           | 6   | Bit 5    | Bit 4          | Bit 3     | Bit   | 2 | Bit 1 | Bit 0 |



|                                                                                                                                                                                                                                                                                                                                                                                                     | Address | 3     | Acce   | ss Mode    | Value     | At Reset | Nominal V                    | alue          |             | _                         |   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|--------|------------|-----------|----------|------------------------------|---------------|-------------|---------------------------|---|
| I                                                                                                                                                                                                                                                                                                                                                                                                   | FSK_EN  | CDB_D | ET_MD  | MARK_DE    | r RE      | SERVED   | RESERVED                     | RESERVED      | RESERVED    | FSK_INT_MD                |   |
| 1: The FSK interrupt will only occur when a 0x55 or 0xAA byte is detected; this mode is used for detecting channel seizure signal.  0: The FSK interrupt will occur normally; this mode is used for receiving data transmission. The FSK interrupt will occur based on the FIFO_LEN parameter of register FSKD_FIFO_CTRL. The interrupt will not occur again until FSKD_FIFO_DOUT register is read. |         |       |        |            |           |          |                              |               |             |                           |   |
|                                                                                                                                                                                                                                                                                                                                                                                                     | MARK_DE | Τ     | 1: Fo  |            | D only    |          | SK session d<br>or MARK sign |               |             | eizure. Causes<br>3 mode. | S |
| CDB_DET_MD 0: Type 1 FSK detect. Channel seizure will be detected for CDB.  1: Type 2 FSK detect. Mark and space frequency will be detected for CDB.                                                                                                                                                                                                                                                |         |       |        |            |           |          |                              |               |             |                           |   |
|                                                                                                                                                                                                                                                                                                                                                                                                     | FSK EN  |       | 1: En: | able FSK o | detection | on block | . 0: FSK dete                | ction block p | owered dowr |                           |   |

Two types of FSK sessions are common. Type 1 session begins with a channel seizure phase where alternate mark and space signals are transmitted to allow channel synchronization. Type 2 FSK has no channel seizure phase but rather begins with long MARK signal. To trigger operation of the FSK detector, the circuit first determines whether an FSK carrier is present. This is reflected by the CDB (carrier detect bar) bit in FSKD STATUS. Once a carrier is detected the FSK demodulator is enabled and data is decoded. The carrier detect condition is determined by the following table:

| CDB_DET_MD | MARK_DET | Bell103, V.21                                                                      | Bell202,V.23                                                                 |  |  |
|------------|----------|------------------------------------------------------------------------------------|------------------------------------------------------------------------------|--|--|
| 0          | 0        | Detect FSK channel seizure and inband mark or space frequency. Use for Type 1 FSK. | Detect FSK channel seizure and in-band energy level. Use for Type 1 FSK.     |  |  |
| 1          | 0        | Detect FSK in-band mark or space frequency.† Use for Type 2 FSK.                   | Detect FSK in-band mark or space frequency. <sup>†</sup> Use for Type 2 FSK. |  |  |
|            | 1        | Detect FSK in-band mark or space frequency. <sup>‡</sup> Use for Type 2 FSK        | Detect FSK in-band mark frequency only.                                      |  |  |

For Bell202 and V.23, circuit will judge in-band energy level specified by FSKD ENERGY HIGH TH (0x18C) FSKD\_ENERGY\_LOW\_TH (0x18D) registers for the CDB on and off condition.

<sup>†</sup> When FSK doesn't contain channel seizure and starts with long mark, This mode only detect in-band mark and space frequency, software should check FSKD\_STATUS (0x183) register FSK\_DF\_OUT bit for determining mark duration.

<sup>&</sup>lt;sup>‡</sup> When FSK doesn't contain channel seizure and starts with long mark, This mode only detect in-band mark and space frequency, software should check FSKD\_STATUS (0x183) register FSK\_DF\_OUT bit for determining mark duration.



#### 8.13.2 FSKD MODE

| Address         |             |       | ess Mode  | Value At Reset | Nominal V | alue  |         |       |
|-----------------|-------------|-------|-----------|----------------|-----------|-------|---------|-------|
| 0x181           | 0x181       |       | R/W 0x04  |                |           |       |         | _     |
| Bit 7           | Bit 7 Bit 6 |       | Bit 5     | Bit 4          | Bit 3     | Bit 2 | Bit 1   | Bit 0 |
| Reserved Reserv |             | erved | PARITY_EN | PARITY_TYPE    |           | МС    | DE[3:0] |       |

PARITY\_EN When set decoder expects a parity bit in the received data following the 8 data bits. Parity

error status is reported in bit 3 of FSKD FIFO STATUS (0x18B).

PARITY TYPE 1: even parity, 0: odd parity

MODE[3:0] Selects the mode of FSK detection. Valid mode settings are shown in Table 8-15.

|              |         |         |          |          |          |      | CATA     | V. J. 1 |
|--------------|---------|---------|----------|----------|----------|------|----------|---------|
| FSKMode[3:0] | 0111    | 0110    | 0101     | 0100     | 0011     | 0010 | 0001     | 0000    |
| Spec.        | V.21    | V.21    | Bell 103 | Bell 103 | Bell 202 |      | V.23     |         |
| Baud Rate    | 300 bps | 300 bps | 300 bps  | 300 bps  | 1200 bps |      | 1200 bps |         |
| Mark '1'     | 1650    | 980Hz   | 2225Hz   | 1270Hz   | 1200Hz   |      | 1300Hz   |         |
| Space '0'    | 1850    | 1180Hz  | 2025Hz   | 1070Hz   | 2200Hz   |      | 2100Hz   |         |

| FSKMode[3:0] | 1111     | 1110     | 1101     | 1100     | 1011     | 1010     | 1001 | 1000 |
|--------------|----------|----------|----------|----------|----------|----------|------|------|
| Spec.        | Bell 103 |      |      |
| Baud Rate    | 75 bps   | 75 bps   | 110 bps  | 110 bps  | 150 bps  | 150 bps  |      |      |
| Mark '1'     | 2225Hz   | 1270Hz   | 2225Hz   | 1270Hz   | 2225Hz   | 1270Hz   |      |      |
| Space '0'    | 2025Hz   | 1070Hz   | 2025Hz   | 1070Hz   | 2025Hz   | 1070Hz   |      |      |

Table 8-15 FSK Detector Modes.

#### 8.13.3 FSKD\_ADJUST

| Address    | Acce       | ess Mode  | Value At Reset | Nominal V  | alue  |               |       |
|------------|------------|-----------|----------------|------------|-------|---------------|-------|
| 0x182      | 144        | R/W       | 0xC0           |            |       |               |       |
| Bit 7      | Bit 6      | Bit 5     | Bit 4          | Bit 3      | Bit 2 | Bit 1         | Bit 0 |
| DEC_MD_SEL | SYM_ADJ_MD | CF_ADJ_SW | RESERVED       | CORR_ADJ_S |       | CORR_ADJ[2:0] |       |

CORR\_ADJ[2:0] Match filter space frequency correlation adjust value.

<sup>\*</sup> CORR\_ADJ\_S and CORR\_ADJ[2:0] are used to micro tune internal match filter space correlation value. This is used to compensate systematic mark and space frequency imbalance due to line interface circuit. The space match score is original score +



CORR\_ADJ\_S Match filter space frequency correlation adjust value polarity. 0: increase space

correlation. 1: decrease space correlation.

CF\_ADJ\_SW Carrier frequency detect count for software mode. When set the default carrier detect

frequency values are over-ridden and CDB\_FREQ\_LOW\_CNT (0x190-0x191) CDB\_FREQ\_HIGH\_CNT (0x192-0x193) registers are used to determine CDB

frequency detection. When reset default values are used.

SYM\_ADJ\_MD This bit is valid only when DEC\_MD\_SEL=1.

0: Symbol adjustment from first start bit. Only supports type 1 FSK signal.

1: Symbol adjustment applies to every start bit. Supports type 1 and type 2 FSK signal.

(Default)

DEC\_MD\_SEL\* 0: Data demodulation is triggered on START bit transition and local baud rate clock is

used to decode symbol.

1: Data demodulation is triggered on START bit transition and micro adjustment is

performed in symbol. (Default)

#### 8.13.4 FSKD STATUS

| Address       | Address Ad  |      | ess Mode | Value At Reset | Nominal V | alue     |       |            |
|---------------|-------------|------|----------|----------------|-----------|----------|-------|------------|
| 0x183         |             |      | R        | 0x02           |           |          |       | 022        |
| Bit 7         | Bit 7 Bit 6 |      | Bit 5    | Bit 4          | Bit 3     | Bit 2    | Bit 1 | Bit 0      |
| RESERVED RESE |             | RVED | RESERVE  | RESERVED       | RESERVED  | RESERVED | CDB   | FSK_DF_OUT |

FSK DF OUT This bit is serial FSK data demodulated by hardware.

CDB Carrier Detect status. 1: No carrier present. 0: Carrier detected.

#### 8.13.5 FSKD THRES

|   | Addres          | S   | Ac     | cess Mode | Value At Rese | et   | Nomin | al Value |      |      |  |
|---|-----------------|-----|--------|-----------|---------------|------|-------|----------|------|------|--|
|   | 0x184-0x        | 185 |        | R/W       | 0x0080        |      |       |          |      |      |  |
|   | Bit7 Bit        |     | 6 Bit5 |           | Bit4          | Bit3 |       | Bit2     | Bit1 | Bit0 |  |
|   |                 |     |        |           | FSKD_TH       | RES[ | 15:8] |          |      |      |  |
| 2 | FSKD_THRES[7:0] |     |        |           |               |      |       |          |      |      |  |

FSKD THRES[15:0]

Sets the threshold of sensitivity for FSK signal detection. The peak level of input signal must be greater than threshold for valid detection. The threshold is given by FSKD\_THRES/ $2^{19*}$ V<sub>DD</sub>FS, where V<sub>DD</sub>FS is the full

((-1)^(CORR\_ADJ\_S))\*CORR\_ADJ[2:0]. This will affect the decoded mark and space duration in the demodulated data. If space correlation matching score is increased, the 0 duration will be longer. Use of this mode is generally not necessary. It is used to compensate for system level imperfection if twist requirements can not be met with default values.

- 89 -

<sup>\*</sup> It is recommended that SYM\_ADJ\_MD and DEC\_MD\_SEL remain at default values (1,1).



scale input peak-to-peak voltage at the ADC which is Avdd V. To refer to input voltage, adjust for the TI input gain.

### 8.13.6 FSKD\_JUDGE

| Address  | Access   | Mode    | Val | ue At Reset | Nominal Val | ue    |             |       |
|----------|----------|---------|-----|-------------|-------------|-------|-------------|-------|
| 0x0186   | R/V      | R/W     |     | 0x04        |             |       |             |       |
| Bit 7    | Bit 6    | Bit 5   |     | Bit 4       | Bit 3       | Bit 2 | Bit 1       | Bit 0 |
| Reserved | Reserved | Reserve | ed  | Reserved    | Reserved    | FS    | K_CMP_CNT[2 | 2:0]  |

FSK\_CMP\_CNT[2:0] Determines how many sample periods to examine to calculate the maximal match value.

Table 8-16 FSK\_CMP\_CNT Definition.

| FSK_ CMP_CNT [2:0] | Polynomial                    |
|--------------------|-------------------------------|
| 0x00               | Y(n)                          |
| 0x01               | Max{ Y(n), Y(n-1) }           |
| 0x02               | max{ Y(n),Y(n-1),,Y(n-3) }    |
| 0x03               | max{ Y(n),Y(n-1),,Y(n-4) }    |
| 0x04               | $\max\{Y(n),Y(n-1),,Y(n-5)\}$ |
| 0x05               | max{ Y(n),Y(n-1),,Y(n-6) }    |
| 0x06               | $\max\{Y(n),Y(n-1),,Y(n-7)\}$ |
| 0x07               | max{ Y(n),Y(n-1),,Y(n-9) }    |

## 8.13.7 FSKD\_SYNC

| Address  | Address Access I |          | ess Mode | Value At    | Reset | Nominal Va | alue |        |          |       |
|----------|------------------|----------|----------|-------------|-------|------------|------|--------|----------|-------|
| 0x187    |                  | R/W 0x02 |          |             |       |            |      | _      |          |       |
| Bit 7    | Bit 6            |          | Bit 5    | Bit 5 Bit 4 |       | Bit 3      | Bi   | t 2    | Bit 1    | Bit 0 |
| Reserved | Rese             | erved    | Reserved | Reser       | ved   |            | ,    | SYNC_N | NUM[3:0] |       |

SYNC\_NUM[3:0] Determines how many synchronization patterns (0x55) should be detected before CDB (Carrier Detect Bar) goes low.

### 8.13.8 FSKD\_CDET

| Addres   | s A      | Access Mode | Value At Reset | Nominal V | alue     |       |       |
|----------|----------|-------------|----------------|-----------|----------|-------|-------|
| 0x188    | Ed Y     | R/W         | 0x03           |           |          |       |       |
| Bit 7    | Bit 6    | Bit 5       | Bit 4          | Bit 3     | Bit 2    | Bit 1 | Bit 0 |
| Reserved | Reserved | j           |                | CDB_T     | IME[5:0] |       |       |



CDB\_TIME[5:0] Determines the time before CDB (Carrier Detect Bar) goes low. Time is given by 8\*CDB\_TIME ms.

#### Carrier Detection

The carrier detection block determines whether there is an FSK carrier present on the input signal. The circuit examines an 8ms time slice and determines whether a carrier is present. CDB (Carrier Detect Bar) will go low under either of the following situations:

- 1. Carrier is detected for CDB\_TIME\*8ms.
- 2. SYNC\_NUM synchronization bytes are detected.

#### Trecover

The Trecover block detects STOP-START bit transitions and generates bit and FIFO clocks to recover the transmitted data.



#### 8.13.9 FSKD FIFO CTRL

| Address  | 3   | Acce | ess Mode | V | alue At Reset | t Reset Nominal Value |          |          |       |
|----------|-----|------|----------|---|---------------|-----------------------|----------|----------|-------|
| 0x189    |     |      | R/W      |   | 0x00          |                       |          |          |       |
| Bit 7    | Bit | t 6  | Bit 5    |   | Bit 4         | Bit 3                 | Bit 2    | Bit 1    | Bit 0 |
| RESERVED |     |      | FIFO_LEI | N |               | RESERVED              | RESERVED | RESERVED | CLEAR |

CLEAR Setting this bit resets the FSK receive FIFO.

FIFO\_LEN Set FIFO interrupt length. Circuit will issue interrupt when (FIFO\_LEN+1) samples are present in the FIFO.



#### 8.13.10 FSKD FIFO DOUT

| Address |                   | Access Mode |   | Value At Reset |       | No    | ominal Value |  |  |  |
|---------|-------------------|-------------|---|----------------|-------|-------|--------------|--|--|--|
| 0x18A   |                   | R           |   |                | 0x00  |       |              |  |  |  |
| Bit 7   | Bit 6 Bit 5 Bit 4 |             | 4 | Bit 3          | Bit 2 | Bit 1 | Bit 0        |  |  |  |
|         | FSKD_FIFO_DOUT    |             |   |                |       |       |              |  |  |  |

FSKD FIFO DOUT

Received data stored in FIFO. The FIFO depth is 8 bytes. If FIFO is not read after a FIFO FULL condition then next data received will be lost. Reading FSKD\_FIFO\_DOUT resets the FSKD interrupt.

#### 8.13.11 FSKD FIFO STATUS

| Address | 3   | Acce   | ess Mode | Va | alue At Reset | Nominal Va | alue  |       |       |
|---------|-----|--------|----------|----|---------------|------------|-------|-------|-------|
| 0x18B   |     |        | R        |    | 0x01          |            |       |       | (62   |
| Bit 7   | Bit | 6      | Bit 5    |    | Bit 4         | Bit 3      | Bit 2 | Bit 1 | Bit 0 |
|         |     | FIFO_I | DEPTH    |    |               | PARITY_ERR | OVF   | FULL  | EMPTY |

EMPTY FIFO empty status. Set when FIFO is empty. Reset when FIFO is not empty.

FULL FIFO full status. Set when FIFO is full.

OVF FIFO overflow status bit. Set when FIFO is full and data has been lost. Reset when FIFO is

empty.

PARITY\_ERR The parity error status bit belongs to the current FIFO data. If set then current head of FIFO

has a parity error.

FIFO DEPTH FSK FIFO depth. This is the current number of samples in the FSK receive FIFO. Value lies

- 92 -

in range 0 to 8.

### 8.13.12 FSKD\_ENERGY\_HIGH\_TH

| Address                  | Ac   | ccess Mode | Value At Res | et Nomin | al Value |      |      |  |  |
|--------------------------|------|------------|--------------|----------|----------|------|------|--|--|
| 0x18C                    |      | R/W        | 0x0C         |          |          |      |      |  |  |
| Bit7                     | Bit6 | Bit5       | Bit4         | Bit3     | Bit2     | Bit1 | Bit0 |  |  |
| FSKD_ENERGY_HIGH_TH[7:0] |      |            |              |          |          |      |      |  |  |

FSKD\_ENERGY\_HIGH\_TH[7:0]

Used for Bell 202, V.23 type1 standard. Sets the FSK carrier on energy high threshold. Detector will enter carrier on condition when FSK signal power is over this level for 3\*FSKD\_ENERGY\_TC\*1/16K seconds. For default FSKD\_ENERGY\_TC = 64 this is 12ms.



#### 8.13.13 FSKD\_ENERGY\_LOW\_TH

| Addres | s    | Access  | s Mode | Value At Rese | et   | Nomina    | al Value |      |      |
|--------|------|---------|--------|---------------|------|-----------|----------|------|------|
| 0x18D  | )    | R/      | /W     | 0x06          |      |           |          |      |      |
| Bit7   | Bit6 | t6 Bit5 |        | Bit4          |      | Bit3      | Bit2     | Bit1 | Bit0 |
|        |      |         | ı      | FSKD_ENERGY   | _LOV | V_TH[7:0] | D        | 1/2  |      |

FSKD\_ENERGY\_LOW\_TH[7:0]

Used for Bell202, V.23 type1 standard. Sets the FSK carrier off energy low threshold. Detector will enter carrier off condition when FSK signal power is under this level for 2\*FSKD\_ENERGY\_TC\*1/16K seconds. For default FSKD\_ENERGY\_TC = 64 this is 8ms.

#### 8.13.14 FSKD ENERGY TC

| Address | 3                   | Access Mode Value At Reset |           | et Nomin | al Value |      |      |  |
|---------|---------------------|----------------------------|-----------|----------|----------|------|------|--|
| 0x18E   |                     | R/W                        | 0x40      |          |          |      | 90   |  |
| Bit7    | Bit6                | Bit5                       | Bit4 Bit3 |          | Bit2     | Bit1 | Bit0 |  |
|         | FSKD_ENERGY_TC[7:0] |                            |           |          |          |      |      |  |

FSKD\_ENERGY\_TC[7:0] Used for bell202, v.23 type1 standard. Sets the FSK carrier energy accumulate period. The period = FSKD\_ENERGY\_TC \* 1/16K seconds.

8.13.15

#### 8.13.16 FSKD CDB FREQ LOW CNT

| Address                    | 8    | Ac | cess Mode | Value At Res | et    | Nominal Value |      |  |      |      |
|----------------------------|------|----|-----------|--------------|-------|---------------|------|--|------|------|
| 0x190~0x                   | 191  |    | R/W       | 0x2F14       |       |               |      |  |      |      |
| Bit7                       | Bite | 6  | Bit5      | Bit4         |       | Bit3 Bit2     |      |  | Bit1 | Bit0 |
| 17.5%                      |      |    | FS        | SKD_CDB_FREC | Q_LOV | W_CNT[1       | 5:8] |  |      |      |
| FSKD_CDB_FREQ_LOW_CNT[7:0] |      |    |           |              |       |               |      |  |      |      |



#### 8.13.17 FSKD CDB FREQ HIGH CNT

|   | Address  | s    | Ac | cess Mode | Value At Rese | t Nom     | inal Value |      |      |
|---|----------|------|----|-----------|---------------|-----------|------------|------|------|
|   | 0x192~0x | 193  |    | R/W       | 0x23F5        |           |            |      |      |
|   | Bit7     | Bite | 6  | Bit5      | Bit4          | Bit3      | Bit2       | Bit1 | Bit0 |
| Ī |          |      |    | FS        | SKD_CDB_FREQ  | _HIGH_CNT | [15:8]     | S.   |      |
| Ī |          |      |    | F         | SKD_CDB_FREC  | _HIGH_CNT | [7:0]      | X    |      |

FSKD\_CDB\_FREQ\_HIGH\_CNT CDB high frequency detect count. Valid only when CF\_ADJ\_SW (0x182) is 1.

The formula for CDB FREQ CNT is:

$$CDB\_FERQ\_CNT = \frac{12288000}{FREO(1 + deviation\%)}$$

For example: Bell103 low band space frequency=1070Hz, deviation=-5%, CDB FREQ CNT=12288000/(1070\*(1-5%))  $\approx$  12088(dec) = 2F38(hex)

Note: These two counts should be carefully set, or CDB detection will not work correctly. Normally, 5% deviation is suitable. If CDB is hard to detect, loosening these two count values will make CDB detection more sensitive but less accurate.

#### 8.13.18 FSKD LIMIT TH

| Address | Address Access Mode |   | Value At Reset |      | Nominal Value |      |      |      |      |
|---------|---------------------|---|----------------|------|---------------|------|------|------|------|
| 0x194   |                     |   | R/W            | 0xFF |               |      |      |      |      |
| Bit7    | Bite                | 5 | Bit5           | Bit4 |               | Bit3 | Bit2 | Bit1 | Bit0 |
| 11      | FSKD_LIMIT_TH[7:0]  |   |                |      |               |      |      |      |      |

FSKD\_LIMIT\_TH[7:0] Apply a clamp limiter to FSK signal. Input signal will be clamped to the region specified by this value. It is recommended to leave this at default value (no clamping).

The clamp region is: {  $\{FSKD\_LIMIT\_TH[7:0],10'b0\}$ ,  $(-1)^*\{FSKD\_LIMIT\_TH[7:0],10'b0\}$ }. For example:  $FSKD\_LIMIT\_TH=0xFF$ , the clamp region is  $\{18'h3FC00, (-1)^*18'h3FC00\}$ 



Figure 8-17 band pass filter frequency response

#### 8.13.19 Example FSK Detector Usage

Usage of the FSK detector normally involves three steps:

- 1. Configure the detector.
- 2. Detect channel seizure.
- 3. Receive transmitted data.

```
// Configure Input path: Enable a TI input and set input gain. writeCfgReg(CFG_TI_GAIN,0x0a); writeCfgReg(CFG_TI_CTRL,0x82); // Enable Line CODEC writeCfgReg(CFG_LC_EN,0xa0); // Enable FSK Detector writeCfgReg(CFG_FSKD_CTRL,0x80); // Set mode to Bell 103 1270/1070Hz writeCfgReg(CFG_FSKD_MODE,0x04); // Clear FIFO set interrupt level to 1 byte. writeCfgReg(CFG_FSKD_FIFO_CTRL,0x01); // Adjust thresholds if desired, for example: writeCfgReg(CFG_FSKD_ENERGY_HI_TH,0x0C);
```

### nuvoton

writeCfgReg(CFG\_FSKD\_ENERGY\_TC,0x40);

Below is the Evaluation board interrupt service routine for reference. When triggered the state machine looks for a carrier synchronization signal then receives data to a FIFO. A 10ms timer tick is assumed in operation and correct path and specification configuration.

```
PUBLIC void vFSKDetFSM(void)
       static byte byCounter;
       byte tmp;
       switch (byFSKDetState)
               case FSKD IDLE:
               if (bUsbCtrl[0] & USB CTRLO FSK DET START)
                      byFSKDetState = FSKD CHANNEL SEIZURE;
               break;
               case FSKD CHANNEL SEIZURE:
               // The assumption here is that the FSK encoder block
               // general configuration has been setup already.
               // Here we configure for carrier detection.
               tmp = ReadRegister(CFG FSKD CTRL);
               tmp |= CFG FSKD CTRL FSK INT MD | CFG FSKD CTRL FSK EN;
               writeCfgReg(CFG FSKD CTRL,tmp);
               // Clear FIFO and set interrupt to 6 bytes.
               writeCfgReg(CFG FSKD FIFO CTRL, CFG FSKD FIFO CTRL CLEAR + 0x30);
               byCounter = 0;
               bUsbStatus[4] |= USB STATUS4 FSK WAIT;
               byFSKDetState = FSKD CHANNEL SEIZURE2;
               break;
               case FSKD CHANNEL SEIZURE2:
               if(DevStatus[2] & STATUS2 FSK D)
                      // We get here FIFO interrupt has occurred.
                      // We are in SYNC mode so just clear the FIFO
                      tmp = ReadRegister(CFG FSKD FIFO DOUT);
                      writeCfgReg(CFG FSKD FIFO CTRL,CFG FSKD FIFO CTRL CLEAR + 0x30);
                      byCounter = 0;
                      // Ensure that carrier detect has triggered
                      tmp = ReadRegister(CFG FSKD STATUS);
                       if(!(tmp & CFG FSKD STATUS CDB))
                              bUsbStatus[4] |= USB STATUS4 FSK DETECTED;
                              bUsbStatus[4] &= ~USB STATUS4 FSK WAIT;
                              // FSK INT MD interrupt only occurs once.
```

## nuvoton

```
else if((DevStatus[3] & STATUS3 TIMER INT) && (bUsbStatus[4] &
USB STATUS4 FSK DETECTED))
                      // Timer interrupt has occurred
                      tmp = ReadRegister(CFG FSKD FIFO STATUS);
                      if(!(tmp & CFG FSKD FIFO STATUS EMPTY))
                              // If FIFO is not empty
                              tmp = ReadRegister(CFG FSKD FIFO DOUT);
                              writeCfgReq(CFG FSKD FIFO CTRL, CFG FSKD FIFO CTRL CLEAR + 0x30);
                              bvCounter = 0;
                              break;
                      byCounter++;
                      // We wait 50ms without a FIFO interrupt then assume that we have
                      // finished synchronization
                      if(byCounter > 4)
                              byCounter = 0;
                              // Switch to normal interrupt mode
                              tmp = ReadRegister(CFG FSKD CTRL);
                              tmp &= ~CFG FSKD CTRL FSK INT MD;
                              writeCfgReg(CFG FSKD CTRL,tmp);
                              byFSKDetState = FSKD DATA RX;
               break;
               case FSKD DATA RX:
               // Getting here means we are in the data acquisition phase of
               // transmission.
               if(DevStatus[2] & STATUS2 FSK D)
                      // We get here FIFO interrupt has occurred. There are at
                      // least 4 bytes on FIFO.
                      byCounter = 0;
                      tmp = ReadRegister(CFG FSKD FIFO STATUS);
                      while(!(tmp & CFG FSKD FIFO STATUS EMPTY) && (RxDataFifo.Depth <
MAX FIFO SIZE))
                              if(tmp & (CFG FSKD FIFO STATUS OVF |
CFG FSKD FIFO STATUS PARITY ERR))
                                      // Set a flag here to indicate transmission error.
                                     bUsbStatus[4] |= USB STATUS4 RX ERR;
                              tmp = ReadRegister(CFG_FSKD_FIFO_DOUT);
                              RxDataFifo.Fifo Buffer[RxDataFifo.WriteIndex++ & 0x3F]= tmp;
                              RxDataFifo.Depth++;
                              tmp = ReadRegister(CFG FSKD FIFO STATUS);
```

## nuvoton

```
else if(DevStatus[3] & STATUS3 TIMER INT)
                      // We are here due to a timer tick. This means we may be finished with
                      // transmission.
                      bvCounter++;
                      // We wait 50ms without a FIFO interrupt then we may have
                      // finished data transmission
                      if(byCounter > 4)
                                      // First read off any data in FIFO
                              tmp = ReadRegister(CFG FSKD FIFO STATUS);
                              while(!(tmp & CFG FSKD FIFO STATUS EMPTY) && (RxDataFifo.Depth <
MAX FIFO SIZE))
                                      if (tmp & (CFG FSKD FIFO STATUS OVF |
CFG FSKD FIFO STATUS PARITY ERR))
                                      // Set a flag here to indicate transmission error.
                                             bUsbStatus[4] |= USB STATUS4 RX ERR;
                                      tmp = ReadRegister(CFG FSKD FIFO DOUT);
                                      RxDataFifo.Fifo Buffer[RxDataFifo.WriteIndex++ & 0x3F]= tmp;
                                      RxDataFifo.Depth++;
                                      tmp = ReadRegister(CFG FSKD FIFO STATUS);
                              if (tmp & CFG FSKD FIFO STATUS EMPTY)
                              \ensuremath{//} We have an empty FIFO. If we have lost carrier then
                              // we can exit.
                                      tmp = ReadRegister(CFG FSKD STATUS);
                                      if (tmp & CFG FSKD STATUS CDB)
                                      // No carrier
                                             byFSKDetState = FSKD WAIT IDLE;
                                      // Report back that Carrier lost
                                             bUsbStatus[4] &= ~USB STATUS4 FSK DETECTED;
               break;
               case FSKD WAIT IDLE:
               if(!(bUsbCtrl[0] & USB CTRLO FSK DET START))
                      byFSKDetState = FSKD IDLE;
                      bUsbStatus[4] &= ~(USB STATUS4 FSK WAIT | USB STATUS4 RX ERR |
USB STATUS4 FSK DETECTED);
               break;
               default:
               byFSKDetState = FSKD IDLE;
```



```
// Setup channel seizure detection
OrCfgReg(CFG_FSKD_CTRL,0x01);
AndCfgReg(CFG_FSKD_MODE,~0x20);

// Wait for INT for carrier detection.
// Read off data from FIFO of channel seizure or wait until channel seizure time has
// elapsed then reset FIFO. Channel now transmits STOP (MARK) signal for some period

// Change mode to appropriate packaged mode.
AndCfgReg(CFG_FSKD_CTRL,~0x01);
OrCfgReg(CFG_FSKD_MODE,0x20); // parity enable

// Service FIFO interrupt until desired data collected or CDB goes high indicating end
// of transmission.
```

## 8.14 CAS and Arbitrary Tone (ATD) Detector

The CAS and Arbitrary tone detector (ATD) allows detection of CAS tones and is configurable to detect arbitrary tones. CAS (CPE Alert Signal) is used to signal the CPE (Customer Premise Equipment) while off hook that the exchange wishes to send some alert signal the end user, such as call waiting. It is used only in off-hook signaling in the US Bellcore system and ETSI system, but in the UK BT system it is used for both on and off-hook signaling. Figure 8-18 shows the architecture of the CAS detector.

## nuvoton



Figure 8-18 Block Diagram of CAS Detection

The CAS detector consists of two biquad bandpass filters to extract the high and low tones of the CAS signal. The characteristics of these two filters are shown Figure 8-19 and Figure 8-20. Their frequency response is:

- High tone (2750Hz) band pass filter: 2600Hz ≤ f ≤ 3000Hz
- Low tone (2130Hz) band pass filter: 2020Hz ≤ f ≤ 2200Hz



Figure 8-19 Detector Biquad Low Tone Frequency Response



Figure 8-20 CAS Detector Biquad High Tone Frequency Response

The CAS detector can also be programmed as an arbitrary tone detector (ATD). In ATD mode coefficients for the low and high tone biquad filters are provided by the user. The frequency specifications and deviation are also programmed by the user. The ATD can be configured to detect single tonesor dual tones.

#### 8.14.1 CAS CTRL

| Address | 3    | Acc | ess Mode | Va   | lue At Reset | 1  | Nominal Value |             |       |       |
|---------|------|-----|----------|------|--------------|----|---------------|-------------|-------|-------|
| 0x200   |      |     | R/W      |      | 0x40         |    |               |             |       |       |
| Bit 7   | Bit  | 6   | Bit 5    |      | Bit 4        |    | Bit 3         | Bit 2       | Bit 1 | Bit 0 |
| CAS_EN  | IIR_ | EN  | TONE_ON  | _INT | TONE_OFF_IN  | ١T | RESERVED      | allow_noise | FRE   | Q_DEV |

CAS EN 1: CAS Detector enabled. 0: CAS detector powered down.

IIR\_EN Enable internal IIR filter. IIR\_EN must be cleared before accessing filter coefficients in

arbitrary tone detection (ATD) mode. The response of the IIR filter in CAS mode is shown

Figure 8-21 CAS Internal IIR Filter Frequency Response Figure

. The response of the filter in ATD mode is determined by the user coefficient loaded into RAM. Once filter coefficients are loaded into RAM IIR\_EN must be set active once more.

TONE\_ON\_INT 1: Enable 0: disable interrupt generation for tone present detection.

TONE\_OFF\_INT 1: Enable 0: disable interrupt generation for tone absent detection.

allow\_noise 1: Tolerating noise signal existence. 0: Not tolerating noise signal existence.

FREQ\_DEV[1:0] Controls the acceptable frequency deviation of CAS detection as per Table 8-17. Not

- 101 -

applicable in ATD mode.



Table 8-17 CAS Detector Frequency Deviation Control.

| FREQ_DEV[1:0]        | 00           | 01           | 10           | 11           |
|----------------------|--------------|--------------|--------------|--------------|
| % Dev                | 2%           | 1%           | 2%           | 3%           |
| High Tone<br>2750 Hz | 2805~2695 Hz | 2777~2722 Hz | 2805~2695 Hz | 2832~2667 Hz |
| Low Tone<br>2130 Hz  | 2176~2087 Hz | 2151~2109 Hz | 2176~2087 Hz | 2193~2066 Hz |

#### 8.14.2 CAS\_THRES\_LOW - CAS detector low threshold

|    | Address   | S           | Ac | cess Mode | Value At Rese | et   | Nomin     | al Value |      |      |
|----|-----------|-------------|----|-----------|---------------|------|-----------|----------|------|------|
|    | 0x201-0x2 | 0x201-0x202 |    | R/W       | 0x0000        |      |           |          | - 0  | 20 6 |
|    | Bit7      | Bit7 Bit6   |    | Bit5      | Bit4          |      | Bit3 Bit2 |          | Bit1 | Bit0 |
| 01 |           |             |    |           |               | S_LO | W[15:8]   |          |      |      |
| 02 |           |             |    |           | CAS_THRE      | S_LC | )W[7:0]   |          |      | 12   |

CAS\_THRES\_LOW[15:0]

Determines the low boundary hysteresis of the CAS/ATD signal detection. The value is in 2's complement 1.15 format. The value 0x7FFF corresponds to full swing input  $(1V_{pp}$  at ADC input). For example:

CAS\_THRES\_LOW = 0x020C => 0000 0010 0000 1100b  $2^{(-7)} + 2^{(-13)} + 2^{(-14)} \approx 8 \text{mV}_{nn}$ 

#### 8.14.3 CAS MULT

| Addres   | Address A     |   | ess Mode | Value At Reset | Nominal | Value |      |       |       |
|----------|---------------|---|----------|----------------|---------|-------|------|-------|-------|
| 0x203    |               |   | R/W      | 0x11           |         |       |      |       |       |
| Bit 7    | Bit           | 6 | Bit 5    | Bit 4          | Bit 3   | Bit   | 2    | Bit 1 | Bit 0 |
| Reserved | erved cas_src |   | de       | et_rsol        |         |       | MULT | [3:0] |       |

cas src

Select the source of cas input. 0: select from sinc filter. 1: select from digital filter.

det rsol

The resolution of detecting CAS signal

00: 48KHz sampling clock generated by internal counter

01: 48KHz sampling clock generated by internal counter which aligned with detected CAS signal .

10: 64KHz sampling clock generated by internal counter which aligned with detected CAS signal.

11: 96KHz sampling clock generated by internal counter which aligned with detected

- 102 -

CAS signal.

MULT [3:0]

The CAS/ATD detector processes two thresholds, CAS\_THRES\_LOW and CAS\_THRES\_HIGH. CAS\_THRES\_HIGH is calculated by CAS\_THRES\_LOW << MULT. For example above and MULT=4

CAS THRES HIGH =  $8 \text{ mV}_{DD} * 2^4 = 128 \text{ mV}_{DD}$ 

If (CAS\_THRES\_LOW << MULT)  $\geq$  0x7FFF, CAS\_THRES\_HIGH saturates to 0x7FFF.

For a valid detection the peak signal level must fall between CAS\_THRES\_LOW and CAS\_THRES\_HIGH.



Figure 8-21 CAS Internal IIR Filter Frequency Response Figure

#### 8.14.4 CAS PRESENT

| Addres | s Acc | ess Mode | Value At Reset | Nominal | Value |       |       |
|--------|-------|----------|----------------|---------|-------|-------|-------|
| 0x204  |       | R/W      | 0x40           |         |       |       |       |
| Bit 7  | Bit 6 | Bit 5    | Bit 4          | Bit 3   | Bit 2 | Bit 1 | Bit 0 |
| 163    | 7     |          | CAS_PRI        | ES_TIME |       |       |       |

CAS\_PRES\_TIME [7:0] This is the time a detected CAS/ATD tone must be present to generate a CAS interrupt. The time equals CAS\_PRES\_TIME \* 0.5ms.



#### 8.14.5 CAS\_ABSENT

| Address | Address Acc |  | ess Mode | Value At Reset | Nominal | Value |       |       |
|---------|-------------|--|----------|----------------|---------|-------|-------|-------|
| 0x205   | 0x205       |  | R/W      | 0x20           |         |       |       |       |
| Bit 7   | Bit 6       |  | Bit 5    | Bit 4          | Bit 3   | Bit 2 | Bit 1 | Bit 0 |
|         |             |  |          | CAS_ABSE       | NT_TIME | N. Ki |       |       |

CAS\_ABSENT\_TIME [7:0] This is the time a detected CAS/ATD tone must be absent before removal of CAS\_DET signal. The time equals CAS\_ABSENT\_TIME \* 0.5ms. This parameter is used to mask short drop outs of the CAS signal.

#### 8.14.6 CAS\_STATUS

| Address  | Address A  |  | ess Mode | Value At Reset | Nominal  | Value    |        |        |
|----------|------------|--|----------|----------------|----------|----------|--------|--------|
| 0x206    | 0x206      |  | R        | 0x00           |          |          | 7      | 10     |
| Bit 7    | Bit 6      |  | Bit 5    | Bit 4          | Bit 3    | Bit 2    | Bit 1  | Bit 0  |
| RESERVED | D RESERVED |  | RESERVED | RESERVED       | RESERVED | RESERVED | CAS_AI | DT_DET |

CAS\_ADT\_DET Indicates what type of tone is detected as per Table 8-18.

#### Table 8-18 CAS/ADT Detection Bits

| CAS_MODE[6:5]<br>(DET_MODE) | CAS_ADT_DET[1]   | CAS_ADT_DET[0]   |
|-----------------------------|------------------|------------------|
| 00                          | Don't Care       | Dual Tone Status |
| 01                          | Don't Care       | Low Tone Status  |
| 10                          | Don't Care       | High Tone Status |
| 11                          | High Tone Status | Low Tone Status  |

### 8.14.7 CAS\_MODE - Arbitrary Tone Detection Mode

| Address  | Acc      | ess Mode | Value At Reset | Nominal | Value |       |       |
|----------|----------|----------|----------------|---------|-------|-------|-------|
| 0x0207   | 24       | R/W      | 0x10           |         |       |       |       |
| Bit 7    | Bit 6    | Bit 5    | Bit 4          | Bit 3   | Bit 2 | Bit 1 | Bit 0 |
| ATD_MODE | DET_MODE |          |                |         | STATS |       |       |

0: CAS detection mode. 1: Arbitrary Tone Detection (ATD) mode.

ATD\_MODE In ATD\_MODE the detection and filter parameters are programmed by software to detect arbitrary tone.

Publication Release Date: March 10, 2011 Revision 2.7

- 104 -



00: dual-tone mode

DET MODE

01: detect low tone only when ATD\_MODE=1
10: detect high tone only when ATD\_MODE=1

11: detect high/low tone separately when ATD MODE=1

Number of sine wave periods to be used for frequency calculations. The more cycles the higher the frequency accuracy but the more computation time required. This value must be set to  $0x01\sim0x1E$  range.

For ATD mode, user can input the value from 1 to 1E.

For CAS mode, the STATS value is decided by det\_rsol(0x203[5:4]).

**STATS** 

| det_rsol | STATS |
|----------|-------|
| 00       | 11(h) |
| 01       | 11(h) |
| 10       | d(h)  |
| 11       | 9(h)  |

#### $8.14.8 \text{ ATD\_MAX\_HFC (ATD\_MODE} = 1)$

| Address      | Address          |  | ess Mode | Value At Reset | Nominal  | Value  |     |         |           |  |
|--------------|------------------|--|----------|----------------|----------|--------|-----|---------|-----------|--|
| 0x0208-0x209 |                  |  | R/W      | 0x0110         |          |        |     |         |           |  |
| Bit 7        | Bit 6            |  | Bit 5    | Bit 4          | Bit 3    | Bit 2  |     | Bit 1   | Bit 0     |  |
| RESERVED     | RESERVED RESERVE |  | RESERVED | RESERVED       | RESERVED | RESERV | /ED | ATD_MAX | _HFC[9:8] |  |
|              | ATD_MAX_HFC[7:0] |  |          |                |          |        |     |         |           |  |

This is the maximum frequency count for the high tone arbitrary frequency detector. A tone is detected when the frequency counter falls between ATD\_MIN\_HFC and ATD\_MAX\_HCF. The value of this register should be set to:

ATD\_MAX\_HFC

ATD\_MAX\_HFC = (SMPL\_CLK \* STATS) / (Desired\_High\_Frequency \* (1+ error%)), SMPL\_CLK is the frequency of sampling clock defined by register det\_rsol register.

#### 8.14.9 ATD MIN HFC (ATD MODE = 1)

| Address   | s /               | Access Mode | Value At Rese | t Nominal | Value    |         |           |  |  |  |
|-----------|-------------------|-------------|---------------|-----------|----------|---------|-----------|--|--|--|
| 0x020A-0x | 0x020A-0x20B      |             | 0x0120        |           |          |         |           |  |  |  |
| Bit 7     | Bit 7 Bit 6       |             | Bit 4         | Bit 3     | Bit 2    | Bit 1   | Bit 0     |  |  |  |
| RESERVED  | RESERVED RESERVED |             | RESERVED      | RESERVED  | RESERVED | ATD_MIN | _HFC[9:8] |  |  |  |
|           | ATD_MIN_HFC[7:0]  |             |               |           |          |         |           |  |  |  |

ATD\_MIN\_HFC

This is the minimum frequency count for the high tone arbitrary frequency detector. A tone is detected when the frequency counter falls between ATD\_MIN\_HFC and ATD\_MAX\_HCF. The value of this register should be set to:

ATD MIN HFC = SMPL CLK \* STATS) / (Desired High Frequency \* (1- error%)), SMPL CLK is

- 105 -



the frequency of sampling clock defined by register det rsol.

#### 8.14.10 ATD MAX LFC (ATD MODE = 1)

| Address          | 6            | Acc | ess Mode | Value At Reset | Nominal  | Value    |         |            |  |
|------------------|--------------|-----|----------|----------------|----------|----------|---------|------------|--|
| 0x020C-0x        | 0x020C-0x20D |     | R/W      | 0x0161         |          | 260      |         |            |  |
| Bit 7            | Bit 6        |     | Bit 5    | Bit 4          | Bit 3    | Bit 2    | Bit 1   | Bit 0      |  |
| RESERVED         | RESERVED RE  |     | RESERVED | RESERVED       | RESERVED | RESERVED | ATD_MAX | (_LFC[9:8] |  |
| ATD_MAX_LFC[7:0] |              |     |          |                |          |          |         |            |  |

ATD\_MAX\_LFC

This is the maximum frequency count for the low tone arbitrary frequency detector. A tone is detected when the frequency counter falls between ATD\_MIN\_LFC and ATD\_MAX\_LCF. The value of this register should be set to:

ATD\_MAX\_LFC = (SMPL\_CLK \* STATS) / (Desired\_low\_tone\_Frequency \* (1+ error%)), SMPL CLK is the frequency of sampling clock defined by register det rsol.

#### 8.14.11 ATD MIN LFC (ATD MODE = 1)

| Address   | 3                     | Access Mode |          | Value At Reset | Value At Reset Nominal \ |     | Value |     |         |           |
|-----------|-----------------------|-------------|----------|----------------|--------------------------|-----|-------|-----|---------|-----------|
| 0x020E-0x | 0x020E-0x20F          |             | R/W      | 0x016F         |                          |     |       |     |         |           |
| Bit 7     | Bit 7 Bit             |             | Bit 5    | Bit 4          | Bit :                    | 3   | Bit 2 |     | Bit 1   | Bit 0     |
| RESERVED  | RESERVED RESERVED RES |             | RESERVED | RESERVED       | RESER                    | VED | RESEF | VED | ATD_MIN | _LFC[9:8] |
|           | ATD_MIN_LFC[7:0]      |             |          |                |                          |     |       |     |         |           |

ATD MIN LFC

This is the minimum frequency count for the high tone arbitrary frequency detector. A tone is detected when the frequency counter falls between ATD\_MIN\_HFC and ATD\_MAX\_HCF. The value of this register should be set to:

ATD\_MIN\_LFC = (SMPL\_CLK \* STATS) / (Desired\_low\_tone\_Frequency \* (1- error%)), SMPL CLK is the frequency of sampling clock defined by register det rsol.

## 8.14.12 External Dual-IIR Coefficient (ATD\_MODE= 1)

| Addres   | s Ac         | cess Mode | Value At Reset | Nominal | Value |       |       |  |  |  |
|----------|--------------|-----------|----------------|---------|-------|-------|-------|--|--|--|
| 0x0210~0 | 241          | R/W       | 0x00           |         |       |       |       |  |  |  |
| Bit 7    | Bit 6        | Bit 5     | Bit 4          | Bit 3   | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|          | ATD_HF_COEFF |           |                |         |       |       |       |  |  |  |

- 106 -



| Address      |       | Access Mode Value At Reset |       | Nominal | Value |       |       |       |  |
|--------------|-------|----------------------------|-------|---------|-------|-------|-------|-------|--|
| 0x0242~0273  |       |                            | R/W   | 0x00    |       |       |       |       |  |
| Bit 7        | Bit 6 |                            | Bit 5 | Bit 4   | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
| ATD_LF_COEFF |       |                            |       |         |       |       |       |       |  |

ATD HF COEFF IIR filter coefficients the high tone arbitrary tone detector.

ATD\_LF\_COEFF IIR filter coefficients the low tone arbitrary tone detector.

Before accessing these coefficients (both for read or write), 0x0200[6] IIR\_EN must be cleared and 0x0200[7] CAS\_EN must be set. This allows the internal IIR filter coefficients to be replaced by ones of the user's choice for arbitrary tone detection. Once loaded IIR\_EN is set active once more for operation.

The input to the CAS detector consists of two cascaded IIR filters, each of them are **5-order biquad** filters (10-order IIR filter) and operate at a **16kHz** sampling **rate**.

The user must set each biquad filter coefficient according to a specific **order b0 b1 a1 b2 a2 with** respect to the following formula:

$$y(n) = b0*x(n) + b1*x(n-1) + b2*x(n-2) - a1*y(n-1) - a2*y(n-2)$$

Each parameter is **16 bits** long in a **3.13 format**, and is stored MSB first. Thus for high tone filter, b0[15:8] is at address 0x210, b0[7:0] is at 0x211, b1[15:8] is at 0x212 etc..



Figure 8-22 FSK ATD IIR filter structure

### 8.14.13 FSK\_COEFF - FSK Encoder Coefficient RAM Data

| Addre | ss        | Access Mode | Value At Reset | Nominal | Value |       |       |  |  |  |
|-------|-----------|-------------|----------------|---------|-------|-------|-------|--|--|--|
| 0x027 | 74        | R/W         | 0x00           |         |       |       |       |  |  |  |
| Bit 7 | Bit 6     | Bit 5       | Bit 4          | Bit 3   | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|       | FSK_COEFF |             |                |         |       |       |       |  |  |  |

The FSK encoder has a built-in 8th-order IIR filter formed by cascading 4 biquad filters. There are total up to 40 bytes to be programmed and the format is the same as CAS/ATD filter.

- 107 -

## nuvoton



Figure 8-23 FSK encoder IIR filter structure

In order to program this ram, 0x0200[7] CAS\_EN must be set, and 0x0200[6] IIR\_EN must be clear The parameter is 16 bits long with 3.13 format, and user must write high byte first then low byte.

0x0275[0]=0 is the high byte, and 0x0275[0] =1 is the low byte. The RAM for these filter coefficients is accessed through register FSK\_COEFF and addressed through FSK\_COEFF\_ADDR

When software reads or writes register FSK\_COEFF (0x274), the FSK\_COEFF\_ADDR (0x275) register will automatically increment. When the address reaches 0x27 it will reset to 0x00.

User can program \_COEFF\_ADDR for choosing specific FSK encoder RAM content both for read and write.

Care must be taken that only 0x0275[0] = 1, the 16-bit coefficient data will be written into ram.

#### 8.14.14 FSK\_COEFF\_ADDR - FSK Encoder Coefficient RAM Address

| Address        |     | Access Mode |     | Value At Reset |  | Nominal | Value |       |       |  |
|----------------|-----|-------------|-----|----------------|--|---------|-------|-------|-------|--|
| 0x0275         |     |             | R/W | 0x00           |  |         |       |       |       |  |
| Bit 7          | Bit | Bit 6 Bit 5 |     | Bit 4          |  | Bit 3   | Bit 2 | Bit 1 | Bit 0 |  |
| FSK_COEFF_ADDR |     |             |     |                |  |         |       |       |       |  |

By setting this address, software can access up to 40 bytes via 0x0274.

#### 8.14.15 CAS\_MAX\_HFC (FINE\_TUNE = 1)

| Address Acc      |          | ess Mode | Value At Reset | /alue At Reset Nominal |          |         |            |  |  |  |
|------------------|----------|----------|----------------|------------------------|----------|---------|------------|--|--|--|
| 0x276-0x2        | 277      | R/W      | 0x010E         |                        |          |         |            |  |  |  |
| Bit 7            | Bit 6    | Bit 5    | Bit 4          | Bit 3                  | Bit 2    | Bit 1   | Bit 0      |  |  |  |
| RESERVED         | RESERVED | RESERVED | RESERVED       | RESERVED               | RESERVED | CAS_MAX | (_HFC[9:8] |  |  |  |
| CAS_MAX_HFC[7:0] |          |          |                |                        |          |         |            |  |  |  |



CAS MAX HFC

This is the maximum frequency count for the high tone arbitrary frequency detector. A tone is detected when the frequency counter falls between CAS\_MIN\_HFC and CAS\_MAX\_HCF. The value of this register should be set to:

CAS\_MAX\_HFC = (48000 \* 16) / (Desired\_High\_Frequency \* (1+ error%))

#### 8.14.16 CAS MIN HFC (FINE TUNE = 1)

| Address   | Address A        |             | ess Mode | Value At Reset | Nominal  | Value      |         |           |  |
|-----------|------------------|-------------|----------|----------------|----------|------------|---------|-----------|--|
| 0x278-0x2 | 279              |             | R/W      | 0x0121         |          | <u>a</u> . | 125     |           |  |
| Bit 7     | Bit              | Bit 6 Bit 5 |          | Bit 4          | Bit 3    | Bit 2      | Bit 1   | Bit 0     |  |
| RESERVED  | RESE             | RVED        | RESERVED | RESERVED       | RESERVED | RESERVED   | CAS_MIN | _HFC[9:8] |  |
|           | CAS_MIN_HFC[7:0] |             |          |                |          |            |         |           |  |

CAS MIN HFC

This is the minimum frequency count for the high tone arbitrary frequency detector. A tone is detected when the frequency counter falls between CAS\_MIN\_HFC and CAS\_MAX\_HCF. The value of this register should be set to:

CAS\_MIN\_HFC = (48000 \* 16) / (Desired\_High\_Frequency \* (1- error%))

### 8.14.17 CAS\_MAX\_LFC (FINE\_TUNE = 1)

| Address   | 6                | Access Mode |          | Value At Reset | Nominal  | Value |      |         |            |  |
|-----------|------------------|-------------|----------|----------------|----------|-------|------|---------|------------|--|
| 0x27A-0x2 | x27A-0x27B R/W   |             | R/W      | 0x015D         |          |       |      |         |            |  |
| Bit 7     | Bit              | Bit 6 Bi    |          | Bit 4          | Bit 3    | Bit   | 2    | Bit 1   | Bit 0      |  |
| RESERVED  | RESE             | RVED        | RESERVED | RESERVED       | RESERVED | RESEF | RVED | CAS_MAX | (_LFC[9:8] |  |
|           | CAS_MAX_LFC[7:0] |             |          |                |          |       |      |         |            |  |

CAS\_MAX\_LFC

This is the maximum frequency count for the low tone arbitrary frequency detector. A tone is detected when the frequency counter falls between CAS\_MIN\_LFC and CAS\_MAX\_LCF. The value of this register should be set to:

CAS\_MAX\_LFC = (48000 \* 16) / (Desired low tone Frequency \* (1+ error%))

### 8.14.18 CAS\_MIN\_LFC (FINE\_TUNE = 1)

| Address   | Address Access Mode |       | Value At Reset | Nominal  | Value    |         |            |  |  |  |
|-----------|---------------------|-------|----------------|----------|----------|---------|------------|--|--|--|
| 0x27C-0x2 | 27D                 | R/W   | 0x0175         |          |          |         |            |  |  |  |
| Bit 7     | Bit 6               | Bit 5 | Bit 4          | Bit 3    | Bit 2    | Bit 1   | Bit 0      |  |  |  |
| RESERVED  | VED RESERVED RESE   |       | RESERVED       | RESERVED | RESERVED | CAS_MIN | I_LFC[9:8] |  |  |  |
|           | CAS_MIN_LFC[7:0]    |       |                |          |          |         |            |  |  |  |

Publication Release Date: March 10, 2011 Revision 2.7

- 109 -



CAS\_MIN\_LFC

This is the minimum frequency count for the high tone arbitrary frequency detector. A tone is detected when the frequency counter falls between CAS\_MIN\_HFC and CAS\_MAX\_HCF. The value of this register should be set to:

CAS MIN LFC = (48000 \* 16) / (Desired low tone Frequency \* (1- error%))

8.14.19

8.14.20

### 8.14.21 Arbitrary Tone Detector Example

Below is an example to setup the arbitrary tone detector to detect 1400 and 2300Hz tones.

```
// Enable ARB, disable IIR
writeCfgReg(CFG CAS CTRL,0xal);
writeCfgReg(CFG CAS THRES LOW, 0x01);
writeCfgReg(CFG CAS MULT, 0x02);
// 80ms present time
writeCfgReg(CFG CAS PRESENT, 0xa0);
// 60ms absent time
writeCfgReg(CFG CAS ABSENT,0x78);
\ensuremath{//} ARB mode and both high and low detection
writeCfgReg(CFG CAS MODE, 0xf0);
// 2300Hz +/- 3%
writeCfgReg(CFG ATD MAX HFC, 0x01);
writeCfgReg(CFG ATD MAX HFC LSB, 0x44);
writeCfgReg(CFG_ATD_MIN HFC,0x01);
writeCfgReg(CFG ATD MIN HFC LSB, 0x58);
// 1400Hz +/- 3%
writeCfgReg(CFG_ATD_MAX_LFC,0x02);
```

### nuvoton

```
writeCfgReg(CFG ATD MAX LFC LSB, 0x14);
writeCfgReg(CFG ATD MIN LFC, 0x02);
writeCfgReg(CFG ATD MIN LFC LSB, 0x36);
// Biquad coefficients for 2300 and 1400Hz
writeCfqReq(0x211,0x03); writeCfqReq(0x214,0xd8); writeCfqReq(0x215,0xd8);
writeCfgReq(0x216,0xff); writeCfgReq(0x217,0xfc); writeCfgReq(0x218,0x1f);
writeCfgReg(0x219,0x39); writeCfgReg(0x21a,0x20); writeCfgReg(0x21c,0xda);
writeCfqReq(0x21d,0xf6); writeCfqReq(0x21e,0xd9); writeCfqReq(0x21f,0x61);
writeCfgReg(0x222,0x20); writeCfgReg(0x222,0x1f); writeCfgReg(0x223,0x75);
writeCfgReg(0x224,0x20); writeCfgReg(0x226,0xd5); writeCfgReg(0x227,0xf7);
writeCfqReq(0x228,0xd8); writeCfqReq(0x229,0x08); writeCfqReq(0x22a,0x1f);
writeCfgReq(0x22b,0xff); writeCfgReq(0x22c,0x1f); writeCfgReq(0x22d,0x78);
writeCfgReg(0x22e,0x20); writeCfgReg(0x230,0xda); writeCfgReg(0x231,0x08);
writeCfgReq(0x232,0xd9); writeCfgReq(0x233,0x71); writeCfgReq(0x234,0x1f);
writeCfgReq(0x235,0xff); writeCfgReq(0x236,0x1f); writeCfgReq(0x237,0xd5);
writeCfgReg(0x238,0x20); writeCfgReg(0x23a,0xd6); writeCfgReg(0x23b,0xc8);
writeCfgReg(0x23c,0xd7); writeCfgReg(0x23d,0x85); writeCfgReg(0x23e,0x20);
writeCfgReg(0x240,0x1f); writeCfgReg(0x241,0xd6); writeCfgReg(0x243,0x03);
writeCfgReq(0x246,0xca); writeCfgReq(0x247,0x14); writeCfgReq(0x248,0xff);
writeCfgReq(0x249,0xfc); writeCfgReq(0x24a,0x1f); writeCfgReq(0x24b,0x3a);
writeCfgReg(0x24c,0x20); writeCfgReg(0x24e,0xcb); writeCfgReg(0x24f,0x36);
writeCfgReq(0x250,0xca); writeCfgReq(0x251,0x56); writeCfgReq(0x252,0x20);
writeCfgReg(0x254,0x1f); writeCfgReg(0x255,0x74); writeCfgReg(0x256,0x20);
writeCfgReg(0x258,0xc7); writeCfgReg(0x259,0xe5); writeCfgReg(0x25a,0xc9);
writeCfgReg(0x25b,0x6e); writeCfgReg(0x25c,0x20); writeCfgReg(0x25e,0x1f);
writeCfgReg(0x25f,0x7a); writeCfgReg(0x260,0x20); writeCfgReg(0x262,0xca);
writeCfqReq(0x263,0x8d); writeCfqReq(0x264,0xca); writeCfqReq(0x265,0x38);
writeCfgReg(0x266,0x20); writeCfgReg(0x268,0x1f); writeCfgReg(0x269,0xd5);
writeCfgReq(0x26a,0x20); writeCfgReq(0x26c,0xc8); writeCfgReq(0x26d,0x66);
writeCfgReg(0x26e,0xc8); writeCfgReg(0x26f,0xf0); writeCfgReg(0x270,0x1f);
writeCfgReq(0x271,0xff); writeCfgReq(0x272,0x1f); writeCfgReq(0x273,0xd7);
// Enable ARB, enable IIR
writeCfgReg(CFG CAS CTRL, 0xel);
```

An example interrupt service routine to use the arbitrary tone detector and DTMF and tone generator to perform a SIA contact ID transmission is given below. It assumes that ARB configuration is done as above.

```
PUBLIC void vContactIDFSM(void)
{
    static byte byCounter;
    static XDATA byte retry;
    byte tmp, i;

    switch(byContactIDState)
    {
        case CONTID_IDLE:
        if(bUsbCtrl[0] & USB_CTRL0_CONTID_START) {
            byCounter = 0;
            retry =0;
            byContactIDState = CONTID_HANDSHAKE0;
            // Set timer to 1 second
            writeCfgReg(CFG_TIME_CTRL,0x00);
            writeCfgReg(CFG_TIME_TARG,0x03);
            writeCfgReg(CFG_TIME_TARG,0x03);
            writeCfgReg(CFG_TIME_TARG,0x07);
```

### nuvoton

```
writeCfgReg(CFG TIME CTRL,0x80);
break;
case CONTID HANDSHAKEO:
// This is first stage of detecting ContactID handshake a
// 1400Hz tone.
if(DevStatus[2] & STATUS2 CAS INT) {
       tmp = ReadRegister(CFG CAS STATUS);
       if(tmp == CFG CAS STATUS LOW TONE) {
               // Change timer to 10msec
               writeCfgReg(CFG TIME CTRL, 0x00);
               writeCfgReg(CFG TIME TARG, 0x00);
               writeCfgReg(CFG TIME TARG LSB, 0x09);
               writeCfgReg(CFG TIME CTRL,0x80);
               byCounter = 0;
               byContactIDState = CONTID HANDSHAKE1;
else if(DevStatus[3] & STATUS3 TIMER INT) {
       // Timer interrupt has occurred
       byCounter++;
       if(byCounter > 10){
               // 10 second timeout waiting for handshake tone
               byContactIDState = CONTID WAIT IDLE;
               // Change timer to default 10msec
               writeCfgReg(CFG TIME CTRL,0x00);
               writeCfgReg(CFG TIME TARG,0x00);
               writeCfgReg(CFG TIME TARG LSB,0x09);
               writeCfgReg(CFG TIME CTRL,0x80);
break:
case CONTID HANDSHAKE1:
// This is second stage of detecting ContactID handshake a
// 2300Hz tone.
if(DevStatus[2] & STATUS2 CAS INT){
       tmp = ReadRegister(CFG CAS STATUS);
       if(tmp == CFG CAS STATUS HI TONE){
               byCounter = 0;
               byContactIDState = CONTID DELAY TO TX;
else if(DevStatus[3] & STATUS3 TIMER INT){
       // Timer interrupt has occurred
       byCounter++;
       if(byCounter > 100){
               // 100 millisecond timeout waiting for handshake tone
               bUsbStatus[4] &= ~USB STATUS4 CTID STATUS;
               bUsbStatus[4] |= USB_STATUS4   CTID TIMEOUT1;
               byContactIDState = CONTID WAIT IDLE;
```

#### nuvoton

```
break;
case CONTID DELAY TO TX:
if(DevStatus[3] & STATUS3 TIMER INT) {
       // Timer interrupt has occurred
       byCounter++;
       if(byCounter > 199){
               // 200 millisecond delay until transmit
               byContactIDState = CONTID TRANSMITO;
break;
case CONTID TRANSMITO:
// If there is Contact ID data on FIFO to
// transmit, start transmission.
// The 16 digits of the CID frame are packed into
// 8 bytes of the FIFO.
if(TxDataFifo.Depth >= 8){
       // Load DTMF tone buffer
       for (i=0; i<8; i++) {
               writeCfgReg(CFG_TONE_BUFFER+i,
               TxDataFifo.Fifo Buffer[((TxDataFifo.ReadIndex + i) & 0x3F)]);
       writeCfgReg( CFG_TONE_BUF_LEN, 16);
       writeCfgReg( CFG_TONE_CTRL, CFG_TONE_CTRL__CLK_EN +
       CFG TONE CTRL DTMF MODE + CFG TONE CTRL GEN EN);
       byContactIDState = CONTID TRANSMIT1;
}else{
       // No data so finished transmission
       bUsbStatus[4] &= ~USB STATUS4 CTID STATUS;
       bUsbStatus[4] |= USB_STATUS4 CTID FINISHED;
       byContactIDState = CONTID WAIT IDLE;
break;
case CONTID TRANSMIT1:
if(DevStatus[2] & STATUS2 TONE INT){
       // DTMF transmission finished.
       byCounter=0;
       // Set timer to 250ms
       writeCfgReg(CFG TIME CTRL,0x00);
       writeCfgReg(CFG TIME TARG,0x00);
       writeCfgReg(CFG TIME TARG LSB, 0xF9);
       writeCfgReg(CFG TIME CTRL, 0x80);
       byContactIDState = CONTID KISSOFF0;
break;
case CONTID KISSOFF0:
```

## nuvoton

```
// Detecting 1400Hz Kiss-off tone.
if(DevStatus[2] & STATUS2 CAS INT){
       tmp = ReadRegister(CFG CAS STATUS);
       if(tmp == CFG CAS STATUS LOW TONE) {
               bvCounter = 0;
               // Setup to generate tone OFF interrupt
               writeCfgReg(CFG CAS CTRL, CFG CAS CTRL TONE OFF INT +
               CFG CAS CTRL IRR EN + CFG CAS CTRL CAS EN);
               byContactIDState = CONTID KISSOFF1;
else if(DevStatus[3] & STATUS3 TIMER INT)
       // Timer interrupt has occurred
       byCounter++;
       if(byCounter > 5){
               // 1.25 sec timeout waiting for handshake tone
               writeCfgReg(CFG TIME CTRL,0x00);
               writeCfgReg(CFG TIME TARG,0x00);
               writeCfgReg(CFG TIME TARG LSB,0x09);
               writeCfgReg(CFG TIME CTRL,0x80);
               if(retry < 4){
                      retry++;
                      byContactIDState = CONTID TRANSMITO;
               }else{
                      bUsbStatus[4] &= ~USB STATUS4 CTID STATUS;
                      bUsbStatus[4] |= USB STATUS4   CTID TIMEOUT2;
                      byContactIDState = CONTID WAIT IDLE;
break;
case CONTID KISSOFF1:
// Detecting end of 1400Hz Kiss-off tone.
if(DevStatus[2] & STATUS2 CAS INT)
       // Interrupt set to detect end of kiss-off tone.
       // Setup to generate tone OFF interrupt
       writeCfgReg(CFG CAS CTRL, CFG CAS CTRL TONE ON INT +
       CFG_CAS_CTRL__IRR_EN + CFG_CAS_CTRL__CAS_EN);
               // We have successfully sent the Contact ID message
               // clear data from the FIFO and go to next message.
       TxDataFifo.ReadIndex += 8;
       TxDataFifo.Depth -= 8;
       retry = 0;
               // Change timer tick to 20ms to create 400ms delay
       writeCfgReg(CFG TIME CTRL, 0x00);
       writeCfgReg(CFG TIME TARG, 0x00);
       writeCfgReg(CFG TIME TARG LSB,19);
```

## nuvoton

```
writeCfgReg(CFG_TIME_CTRL,0x80);
    byCounter = 0;
    byContactIDState = CONTID_DELAY_TO_TX;
}
break;

case CONTID_WAIT_IDLE:
    if(!(bUsbCtrl[0] & USB_CTRL0_CONTID_START)){
        byContactIDState = CONTID_IDLE;
}
break;

default:
    byContactIDState = CONTID_IDLE;
break;
}
```

### 8.15 Voice Energy Detection (Speech Energy Detection)

The voice energy detector allows measurement of signal energy in the voice band between 750Hz to 1400Hz. It is used to detect speech on the line to aid in CID functions or line in use detection. Band-pass filter frequency response of voice energy detection is in Figure 8-24.

.



Figure 8-24 Band Pass filter frequency response of voice energy detection



### 8.15.1 VD\_CTRL

| Address | s        | Access Mode | Value At Rese | t Nomii | nal Value |          |      |
|---------|----------|-------------|---------------|---------|-----------|----------|------|
| 0x1F0   |          | R/W         | 0x00          |         |           |          | _    |
| Bit7    | Bit6     | Bit5        | Bit4          | Bit3    | Bit2      | Bit1     | Bit0 |
| VD_EN   | Reserved | d Reserved  | Reserved      | ~ ~     | VD_T      | °C [3:0] |      |

VD\_TC[3:0] Voice Detect TC (time constant) determines the response of the voice detect

energy averaging. Larger values imply a larger time constant, greater stability but

less responsive to changes in energy level.

VD\_EN Enable the Voice Detection block

### 8.15.2 VD\_STATUS

| Addres   | s      | Access Mode |          | Value At Rese | et | Nomin  | al Value |          |       |
|----------|--------|-------------|----------|---------------|----|--------|----------|----------|-------|
| 0x1F1    |        | R           |          | 0x00          |    |        |          |          | 196   |
| Bit7     | Bit6   |             | Bit5     | Bit4          | ]  | Bit3   | Bit2     | Bit1     | Bit0  |
| Reserved | Reserv | ed          | Reserved | Reserved      | Re | served | Reserved | Reserved | VD_RX |

VD\_RX Voice Energy Detected. 1: Energy exceeds VD\_THRES 0: Energy less than VD THRES or VD EN=0.

### 8.15.3 VD\_THRES

F2

| Address        | Address A |                          | cess Mode | Value At Rese | et    | Nomin | al Value |  |  |  |
|----------------|-----------|--------------------------|-----------|---------------|-------|-------|----------|--|--|--|
| 0x1F2~0x       | 1F3       |                          | R/W       | 0x0100        | x0100 |       |          |  |  |  |
| Bit7           | Bite      | Bit6 Bit5 Bit4 Bit3 Bit2 |           | Bit2          | Bit1  |       | Bit0     |  |  |  |
|                |           |                          |           | VD_THR        | ES [1 | 5:8]  |          |  |  |  |
| VD_THRES [7:0] |           |                          |           |               |       |       |          |  |  |  |

VD\_THRES[15:0] This register defines the threshold of voice detection (speech energy). If the energy is greater than VD\_THRES, VD\_RX is high. The 16 bit value represents the decimal fraction of full scale in 2's complement format.

### **8.15.4 VD ENERGY**

|    | Address     | s    | Access Mode Value At Reset |         | et     | Nominal Value |      |      |      |
|----|-------------|------|----------------------------|---------|--------|---------------|------|------|------|
|    | 0x1F4~0x1F5 |      | R                          | 0x0000  |        |               |      |      | _    |
|    | Bit7        | Bit6 | Bit5                       | Bit4    |        | Bit3          | Bit2 | Bit1 | Bit0 |
| F4 |             |      |                            | VD_ENEF | RGY [1 | 15:8]         |      |      |      |
| F5 |             |      |                            | VD_ENE  | RGY [  | 7:0]          |      |      |      |

Publication Release Date: March 10, 2011 Revision 2.7

- 116 -



VD ENERGY[15:0]

This register represents the instantaneous signal power from 750Hz to 1400Hz. The value is in the range, 0x0000 to 0xFFFF, with larger value representing larger signal power.

### 8.16 Call Progress Tone Detector

The call progress tone detector is a narrow band pass filter from 300Hz to 650Hz; its detection algorithm is similar to voice energy detection. It can be used to detect call progress tones such as dial tones.



Figure 8-25 Call progress tone band-pass filter frequency response

### 8.16.1 CPT CTRL

| Addres | s      | Access Mode  |      | Value At Rese | et | Nomin | al Value |     |         |      |
|--------|--------|--------------|------|---------------|----|-------|----------|-----|---------|------|
| 0x280  |        | R/W          |      | 0x07          |    |       |          |     |         |      |
| Bit7   | Bite   | Ó            | Bit5 | Bit4          |    | Bit3  | Bit2     |     | Bit1    | Bit0 |
| CPT_EN | Reserv | ved Reserved |      | Reserved      | CI |       |          | _T( | C [3:0] |      |

CPT\_TC[3:0]

Call Progress Tone TC (time constant) determines the response of the Call Progress Tone energy averaging. Larger values imply a larger time constant, greater stability but less responsive to changes in energy level.

CPT\_EN Enable the Call Progress Tone detection block



### 8.16.2 CPT\_STATUS

| Addres   | s       | Access Mode |          | Value At Rese | et Nomin | al Value |          |        |
|----------|---------|-------------|----------|---------------|----------|----------|----------|--------|
| 0x281    |         | R           |          | 0x00          |          |          |          | _      |
| Bit7     | Bit6    | sit6 Bit5   |          | Bit4          | Bit3     | Bit2     | Bit1     | Bit0   |
| Reserved | Reservo | ed          | Reserved | Reserved      | Reserved | Reserved | Reserved | CPT_RX |

CPT\_RX Call Progress Tone Detected. 1: Energy exceeds CPT\_THRES\_H 0: Energy less than CPT\_THRES\_L or CPT\_EN=0.

### 8.16.3 CPT THRES H

|    | Addres   | Address A         |   | cess Mode | Value At Res | et   | Nomin  | al Value |      |       |  |
|----|----------|-------------------|---|-----------|--------------|------|--------|----------|------|-------|--|
|    | 0x282~0x | 283               |   | R/W       | 0x2400       |      |        |          |      | 137 ( |  |
|    | Bit7     | Bite              | 5 | Bit5      | Bit4         |      | Bit3   | Bit2     | Bit1 | Bit0  |  |
| 82 |          |                   |   |           | CPT_THRE     | ES_H | [15:8] |          |      | - 7   |  |
| 83 |          | CPT_THRES_H [7:0] |   |           |              |      |        |          |      |       |  |

CPT\_THRES\_H[15:0] This register defines the on/high threshold of the Call Progress Tone detection. If the energy is greater than CPT\_THRES\_H, CPT\_RX will be set. The 16 bit value represents the decimal fraction of full scale in 2's complement format.

### 8.16.4 CPT\_THRES\_L

| Addres            | Address Access Mode |  | cess Mode | Value At Reset |      | Nomin  | al Value |      |  |
|-------------------|---------------------|--|-----------|----------------|------|--------|----------|------|--|
| 0x284~0x          | 285                 |  | R/W       | 0x1A00         |      |        |          |      |  |
| Bit7              | Bit7 Bit6 Bit5      |  | Bit4      |                | Bit3 | Bit2   | Bit1     | Bit0 |  |
|                   | I                   |  |           |                | ES_L | [15:8] |          |      |  |
| CPT_THRES_L [7:0] |                     |  |           |                |      |        |          |      |  |

CPT\_THRES\_L[15:0] This register defines the off/low threshold of the Call Progress Tone detection. If the energy is less than CPT\_THRES\_L, CPT\_RX will be cleared. The 16 bit value represents the decimal fraction of full scale in 2's complement format.

Publication Release Date: March 10, 2011 Revision 2.7

- 118 -



#### 8.16.5 CPT ENERGY

| Addres           | Access Mode |      | Value At Reset | Nomi      | nal Value |      |      |      |
|------------------|-------------|------|----------------|-----------|-----------|------|------|------|
| 0x286~0x         | .86~0x287 F |      | R              | 0x0000    |           |      |      |      |
| Bit7             | Bit6        | Bit6 |                | Bit4      | Bit3      | Bit2 | Bit1 | Bit0 |
|                  |             |      |                | CPT_ENERO | Y [15:8]  |      |      |      |
| CPT_ENERGY [7:0] |             |      |                |           |           |      |      |      |

CPT ENERGY[15:0]

86

This register represents the instantaneous signal power from 300Hz to 650Hz. The value is in the range, 0x0000 to 0xFFFF, with larger value representing larger signal power.

### 8.17 Ring Detection and Pulse / Period Width Measurement

#### Schmitt trigger:

The Schmitt trigger input to the ISD61S00 has the nominal characteristics of VH=1.63 volt and VL=1.33 volt.

### Pulse / Period Width Measurement (PPM):

The interrupt occurrence could be selected to occur at falling edge or rising edge or both edges of ringing signal. For example, if the rising edge has been selected, an interrupt event will be sent at each rising edge of ringing signal. The RNG\_CTRL[1:0] is used to select the interrupt occurrence. Figure 8-26 shows the function block of ring detector and Figure 8-27 illustrates the operation of ring detector by the timing waveforms. The ringing signal goes through the Schmitt trigger. The PPM interrupt occurrence register RINGIntrptSel[1:0] is set to 0x03 in the illustration, so the RINGIN signal is then examined by the PPM interrupt generator to generate the interrupt event at the both edge transitions of RINGIN signal. To save the software computation power, PPM counter logic can report the length between consecutive interrupt events by a counter value. The counter value is stored in register RINGCNTR that is related to the PPM counter operating frequency. Depending on the time resolution to measure the length between consecutive interrupt events.

- 119 -

Publication Release Date: March 10, 2011

Revision 2.7

### nuvoton



Figure 8-26 Block diagram of ring detector



Figure 8-27 The timing of ring detector with RNG\_CTRL[1:0]=2'b11

### 8.17.1 RNG\_CTRL

| Address | S     | Acc  | ess Mode | Value At Reset | Nominal | Value |     |            |            |
|---------|-------|------|----------|----------------|---------|-------|-----|------------|------------|
| 0x01B0  |       |      | R/W      | 0x00           |         |       |     |            | _          |
| Bit 7   | Bit   | 6    | Bit 5    | Bit 4          | Bit 3   | Bit   | 2   | Bit 1      | Bit 0      |
| RING_EN | RESEF | RVED | RESERVED | RESERVED       | RES[1]  | RES   | [0] | INT_SEL[1] | INT_SEL[0] |

RING\_EN RING Operation Enable 1=Enable, 0=Disable

RES[1:0] Select the resolution of the PPM measurement. The maximum time interval

measureable is 65536 \* resolution time unit. See Table 8-19.

## nuvoton

INT\_SEL[0] =1 Generates an interrupt on falling edge.

INT\_SEL[1] =1 Generates an interrupt on rising edge.

| Interrupt Occurrence                      | Address=0x01B0 |        |  |  |  |  |
|-------------------------------------------|----------------|--------|--|--|--|--|
| interrupt Occurrence                      | Bit[1]         | Bit[0] |  |  |  |  |
| No Interrupt                              | 0              | 0      |  |  |  |  |
| Interrupt on falling edge                 | 0              | 73 L 1 |  |  |  |  |
| Interrupt on rising edge                  | 1 1            | 0      |  |  |  |  |
| Interrupt on both falling and rising edge | 1 70           | 2501   |  |  |  |  |

Table 8-19 Values of PPM Timer resolution.

| RES[1:0] | Resolution Time Unit |
|----------|----------------------|
| 0        | 1/12KHz = 83us       |
| 1        | 1/24 KHz = 41.7us    |
| 2        | 1/48 KHz = 20.8us    |
| 3        | 1/96 KHz = 10.4us    |



### 8.17.2 RNG\_STATE

| Address  | Address Ad |      | Access Mode Value A |          | At Reset Nominal Valu |          |          |            |
|----------|------------|------|---------------------|----------|-----------------------|----------|----------|------------|
| 0x01B1   |            |      | R                   | 0x00     |                       | 250      |          | _          |
| Bit 7    | Bit        | 6    | Bit 5               | Bit 4    | Bit 3                 | Bit 2    | Bit 1    | Bit 0      |
| RESERVED | RESE       | RVED | RESERVED            | RESERVED | RESERVED              | RESERVED | RESERVED | RING_STATE |

RING\_STATE This bit reflects the state of ringing signal passing through the Schmitt trigger input pad.

### 8.17.3 RNG CNTR

|    | Addres   | Address Ad     |   | cess Mode | Mode Value At Reset |  | Nominal Value |      |      |      |  |  |
|----|----------|----------------|---|-----------|---------------------|--|---------------|------|------|------|--|--|
|    | 0x1B2~0x | 1B3            |   | R         | 0x0000              |  |               |      |      | 162  |  |  |
|    | Bit7     | Bite           | 5 | Bit5      | Bit4                |  | Bit3          | Bit2 | Bit1 | Bit0 |  |  |
| B2 |          | RNG_CNTR[15:8] |   |           |                     |  |               |      |      |      |  |  |
| В3 |          | RNG_CNTR[7:0]  |   |           |                     |  |               |      |      |      |  |  |

The RNG\_CNTR register is updated with the PPM counter value as the interrupt is generated. The PPM counter is a 16-bit counter which is reset to 0 and starts to increase by 1 to maximum value 65535, when the PPM interrupt is generated. The PPM counter will saturate at the maximum value 65536 until the next interrupt occurrence.

Table 8-19 illustrates the expected counter values for detecting ringing signals according to the requirements of the BT and North American systems.

Table: 8-16 PPM counter value vs. PPM resolution for various ringing frequencies and cadences.

| PPM<br>counter    | PPM<br>counter |                |                |                | USA            |                |                |                |              |                | BT            |              |  |
|-------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|----------------|---------------|--------------|--|
|                   | resolution     |                | Freq           |                |                |                |                |                |              |                | Cadence       |              |  |
| frequency<br>(Hz) | frequency      |                | 20Hz           | 15.8<br>Hz     | 50Hz           | 68 Hz          | 69 Hz          | 70 Hz          |              |                |               |              |  |
| ()                | 2              | 100<br>ms      | 50<br>ms       | 63.29<br>ms    | 20<br>ms       | 14.7<br>ms     | 14.49<br>ms    | 14.28<br>ms    | 4 sec<br>off | 0.2 sec<br>off | 0.4 sec<br>on | 2 sec<br>off |  |
| 12K               | 0.083 ms       | 1200<br>(04B0) | 600<br>(0258)  | 759<br>(02F7)  | 240<br>(00F0)  | 176<br>(00B0)  | 173<br>(00AD)  | 171<br>(00AB)  | 48200        | 2410           | 4820          | 24100        |  |
| 24K               | 0.042ms        | 2400<br>(0960  | 1200<br>(04B0) | 1518<br>(05EE) | 480<br>(01E0)  | 352<br>(0160)  | 348<br>(15C)   | 342<br>(0156)  | 65535        | 4762           | 9524          | 47620        |  |
| 48K               | 0.021ms        | 4800<br>(12C0) | 2400<br>(0960) | 3038<br>(0BDE) | 960<br>(3C0)   | 706<br>(2C2)   | 696<br>(2B8)   | 686<br>(2AE)   | 65535        | 9524           | 19047         | 65535        |  |
| 96K               | 0.01ms         | 9600<br>(2580) | 4800<br>(12C0) | 6076<br>(17BC) | 1920<br>(0780) | 1412<br>(0584) | 1392<br>(0570) | 1372<br>(055C) | 65535        | 20000          | 40000         | 65535        |  |

Publication Release Date: March 10, 2011 Revision 2.7

- 122 -



PPM counter, max (16 bit counter)=65535 ( PPM counter value= PPM counter operating frequency / Frequency)

#### **8.17.4 RNG LATCH**

| Address  | 3    | Acc  | ess Mode | Value At Reset | Nominal  | Value    |          |       |
|----------|------|------|----------|----------------|----------|----------|----------|-------|
| 0x1B4    |      |      | R/W      | 0x00           |          |          | P        |       |
| Bit 7    | Bit  | 6    | Bit 5    | Bit 4          | Bit 3    | Bit 2    | Bit 1    | Bit 0 |
| RESERVED | RESE | RVED | RESERVED | RESERVED       | RESERVED | RESERVED | RESERVED | LATCH |

#### **LATCH**

- 0: RNG\_CNTR is updated each interrupt occurrence regardless of whether interrupt has been serviced.
- 1: The RNG\_CNTR value is latched until RNG\_LATCH is written again. This prevents noise on ring signal or slow interrupt servicing causing missed measurements. With LATCH=1, to service interrupt read RNG\_CNTR, then write RNG\_LATCH. Once written, next interrupt will update RNG\_CNTR to a new value. If RNG\_LATCH is not written, new interrupts will continue to be generated but RNG\_CNTR will not be updated.

#### 8.17.5

#### **8.18 Timer**

The ISD61S00 incorporates a programmable 1-millisecond resolution timer. It can be programmed to generate a pulse in the range 1  $\sim$  65536 milliseconds (1 millisecond spacing). When the timer is enabled by writing to TIME\_CTRL[7]=1 the 1 ms timer will start to count until the current timer count (TIME\_CNT) is equal to the target count (TIME\_TARG) at which time an interrupt event is generated. A write of the timer control register (TIME\_CTRL) will force timer to reset/clear. The interval between timer interrupts will be TIME\_TARG+1ms.

8.18.1



#### **8.18.2 TIME TARG**

|    | Addres   | s    | Acc | ess Mode | Value At Rese | t Nom    | inal Value |      |      |
|----|----------|------|-----|----------|---------------|----------|------------|------|------|
|    | 0x292~0x | 293  |     | R/W      | 0x0000        |          |            |      | _    |
|    | Bit7     | Bite | 6   | Bit5     | Bit4          | Bit3     | Bit2       | Bit1 | Bit0 |
| 2  |          |      |     |          | TIME_TAI      | RG[15:8] | 30 M 73    | N.   |      |
| 93 |          |      |     |          | TIME_TA       | RG[7:0]  | V(1) 13    | y    |      |

TIME TARG[15:0]

TIME TARG+1 ms timer target count, maximum count 65536 ms.

#### 8.18.3 TIME CNT

|   | Addres         | ddress F |         | cess Mode | Value At Reset |      | Nominal Value |      |      |        |  |
|---|----------------|----------|---------|-----------|----------------|------|---------------|------|------|--------|--|
|   | 0x294~0x       | 295 R    |         | R         | 0x0000         |      |               |      |      | Z9) (C |  |
|   | Bit7           | Bite     | t6 Bit5 |           | Bit4           | Bit3 |               | Bit2 | Bit1 | Bit0   |  |
| Ī | TIME_CNT[15:8] |          |         |           |                |      |               |      |      |        |  |
|   | TIME_CNT[7:0]  |          |         |           |                |      |               |      |      |        |  |

TIME\_CNT[15:0]

94 95

Current timer count number. Unit: ms.

### 8.19 Gain Stage and Mixer

The Gain stage and Mixer block allows routing of PCM signals between various blocks. There are five gain- mixer channels allowing mixes for:

- 1. AEC Input (to air CODEC)
- 2. LEC Input (to PSTN CODEC)
- 3. Record (to audio compression block).
- 4. I2S Left Channel.
- 5. I2S Right Channel.

Each of the mixers has five variable gain inputs along with inputs from the tone generator and FSK encoder. The five variable gain inputs are:

- 1. MIC output from air CODEC.
- 2. PLAY output from audio decompression.
- 3. TI output from PSTN CODEC.
- 4. I2S L input from I2S left channel.
- 5. I2S\_R input from I2S right channel.

The block diagram of a single mixer channel is shown in Figure 8-28.



Figure 8-28 Gain/Mixer Channel

In addition to the mixers there are also gain stages associated with each of the CODECs and echo cancellers that allow input and output gain control along with side tone insertion.



Figure 8-29 CODEC/EC Gain Stages

Each gain stage is controlled by seven bits of a configuration register. The gain is configurable from +24dB to -31.5dB in 0.5dB steps. The gain is a seven bit two's complement number with 0x40

### nuvoTon

corresponding to a total MUTE of the signal as shown in Table 8-20. The list of mixer gain registers and their associated path is given in Table 8-21.

Table 8-20 Gain Stage Control value Mapping.

| Index | Gain (dB) |
|-------|-----------|-------|-----------|-------|-----------|-------|-----------|
| 0x00  | 0.0       | 0x20  | 16.0      | 0x7F  | -0.5      | 0x5F  | -16.5     |
| 0x01  | 0.5       | 0x21  | 16.5      | 0x7E  | -1.0      | 0x5E  | -17.0     |
| 0x02  | 1.0       | 0x22  | 17.0      | 0x7D  | -1.5      | 0x5D  | -17.5     |
| 0x03  | 1.5       | 0x23  | 17.5      | 0x7C  | -2.0      | 0x5C  | -18.0     |
| 0x04  | 2.0       | 0x24  | 18.0      | 0x7B  | -2.5      | 0x5B  | -18.5     |
| 0x05  | 2.5       | 0x25  | 18.5      | 0x7A  | -3.0      | 0x5A  | -19.0     |
| 0x06  | 3.0       | 0x26  | 19.0      | 0x79  | -3.5      | 0x59  | -19.5     |
| 0x07  | 3.5       | 0x27  | 19.5      | 0x78  | -4.0      | 0x58  | -20.0     |
| 0x08  | 4.0       | 0x28  | 20.0      | 0x77  | -4.5      | 0x57  | -20.5     |
| 0x09  | 4.5       | 0x29  | 20.5      | 0x76  | -5.0      | 0x56  | -21.0     |
| 0x0A  | 5.0       | 0x2A  | 21.0      | 0x75  | -5.5      | 0x55  | -21.5     |
| 0x0B  | 5.5       | 0x2B  | 21.5      | 0x74  | -6.0      | 0x54  | -22.0     |
| 0x0C  | 6.0       | 0x2C  | 22.0      | 0x73  | -6.5      | 0x53  | -22.5     |
| 0x0D  | 6.5       | 0x2D  | 22.5      | 0x72  | -7.0      | 0x52  | -23.0     |
| 0x0E  | 7.0       | 0x2E  | 23.0      | 0x71  | -7.5      | 0x51  | -23.5     |
| 0x0F  | 7.5       | 0x2F  | 23.5      | 0x70  | -8.0      | 0x50  | -24.0     |
| 0x10  | 8.0       | 0x30  | 24.0      | 0x6F  | -8.5      | 0x4F  | -24.5     |
| 0x11  | 8.5       | 0x31  | 24.0      | 0x6E  | -9.0      | 0x4E  | -25.0     |
| 0x12  | 9.0       | 0x32  | 24.0      | 0x6D  | -9.5      | 0x4D  | -25.5     |
| 0x13  | 9.5       | 0x33  | 24.0      | 0x6C  | -10.0     | 0x4C  | -26.0     |
| 0x14  | 10.0      | 0x34  | 24.0      | 0x6B  | -10.5     | 0x4B  | -26.5     |
| 0x15  | 10.5      | 0x35  | 24.0      | 0x6A  | -11.0     | 0x4A  | -27.0     |
| 0x16  | 11.0      | 0x36  | 24.0      | 0x69  | -11.5     | 0x49  | -27.5     |
| 0x17  | 11.5      | 0x37  | 24.0      | 0x68  | -12.0     | 0x48  | -28.0     |
| 0x18  | 12.0      | 0x38  | 24.0      | 0x67  | -12.5     | 0x47  | -28.5     |
| 0x19  | 12.5      | 0x39  | 24.0      | 0x66  | -13.0     | 0x46  | -29.0     |
| 0x1A  | 13.0      | 0x3A  | 24.0      | 0x65  | -13.5     | 0x45  | -29.5     |
| 0x1B  | 13.5      | 0x3B  | 24.0      | 0x64  | -14.0     | 0x44  | -30.0     |
| 0x1C  | 14.0      | 0x3C  | 24.0      | 0x63  | -14.5     | 0x43  | -30.5     |
| 0x1D  | 14.5      | 0x3D  | 24.0      | 0x62  | -15.0     | 0x42  | -31.0     |
| 0x1E  | 15.0      | 0x3E  | 24.0      | 0x61  | -15.5     | 0x41  | -31.5     |
| 0x1F  | 15.5      | 0x3F  | 24.0      | 0x60  | -16.0     | 0x40  | Mute      |

The registers that control each gain stage are listed in Table 8-21 and their position is indicated by their address in Table 8-21.



Table 8-21 Mixer Gain Registers.

|          | •                      |         |
|----------|------------------------|---------|
| Register | Description            | Address |
| GS_ACST  | Air CODEC Side tone    | 111     |
| GS_ACIG  | Air CODEC input Gain   | 112     |
| GS_ACOG  | Air CODEC output Gain  | 113     |
| GS_AEOG  | AEC Output Gain        | 114     |
| GS_AEIG  | AEC Input Gain         | 115     |
| GS_LCIG  | Line CODEC input Gain  | 116     |
| GS_LCOG  | Line CODEC output Gain | 117     |
| GS_LEOG  | LEC Output Gain        | 118     |
| GS_LEIG  | LEC Input Gain         | 119     |
| GS_AOAI  | AEC out - AEC in Gain  | 11A     |
| GS_LOAI  | LEC out - AEC in Gain  | 11B     |
| GS_PLAI  | PLAY - AEC in Gain     | 11C     |
| GS_ILAI  | I2SL - AEC in          | 11D     |
| GS_IRAI  | I2SR - AEC in          | 11E     |
| GS_AOLI  | AEC out - LEC in Gain  | 11F     |
| GS_LOLI  | LEC out - LEC in Gain  | 120     |
| GS_PLLI  | PLAY - LEC in Gain     | 121     |

| Register | Description            | Address |
|----------|------------------------|---------|
| GS_ILLI  | I2SL - LEC in          | 122     |
| GS_IRLI  | I2SR - LEC in          | 123     |
| GS_AORI  | AEC out - REC in Gain  | 124     |
| GS_LORI  | LEC out - REC in Gain  | 125     |
| GS_PLRI  | PLAY - REC in Gain     | 126     |
| GS_ILRI  | I2SL - REC in          | 127     |
| GS_IRRI  | I2SR - REC in          | 128     |
| GS_AOIL  | AEC out - I2SL in Gain | 129     |
| GS_LOIL  | LEC out - I2SL in Gain | 12A     |
| GS_PLIL  | PLAY - I2SL in Gain    | 12B     |
| GS_ILIL  | I2SL - I2SL in         | 12C     |
| GS_IRIL  | I2SR - I2SL in         | 12D     |
| GS_AOIR  | AEC out - I2SR in Gain | 12E     |
| GS_LOIR  | LEC out - I2SR in Gain | 12F     |
| GS_PLIR  | PLAY - I2SR in Gain    | 130     |
| GS_ILIR  | I2SL - I2SR in         | 131     |
| GS_IRIR  | I2SR - I2SR in         | 132     |

### nuvoton



Figure 8-30 Gain Stages and Mixer with Control Addresses

### 8.19.1 GS CTRL

| Address  | s Ac | ccess Mode | Value At Res | et Nomin | al Value |      |      |
|----------|------|------------|--------------|----------|----------|------|------|
| 0x110    |      | R/W        | 0x00         |          |          |      | _    |
| Bit7     | Bit6 | Bit5       | Bit4         | Bit3     | Bit2     | Bit1 | Bit0 |
| GSMIX_EN |      | -          | -            | -        | -        | -    | •    |

GSMIX\_EN Enable the Mixer Gain Stage.



### 8.19.2 CODEC EC Gain Stages

| Address 0x111-0x11 | 9        | Access Mo<br>R/W | de     | Value At Reset 0x00               | Nominal Value     |     |       |       |       |  |  |  |  |
|--------------------|----------|------------------|--------|-----------------------------------|-------------------|-----|-------|-------|-------|--|--|--|--|
| Address            |          | Bit 7            | Bit 6  | Bit 5                             | Bit 4 Bit         | t 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |  |
| 0x111              | POSITION |                  | G1: A  | r CODEC Sid                       | e-Tone Gain [6:0] |     |       |       |       |  |  |  |  |
| 0x112              | Reserved |                  | G2: A  | r ADC To AE(                      | C Gain [6:0]      |     |       |       |       |  |  |  |  |
| 0x113              | Reserved |                  | G3: A  | G3: AEC To Air DAC Gain [6:0]     |                   |     |       |       |       |  |  |  |  |
| 0x114              | Reserved |                  | G4: A  | G4: AEC To MIC Gain [6:0]         |                   |     |       |       |       |  |  |  |  |
| 0x115              | R        | eserved          | G5: A  | G5: AECin Mixer To AEC Gain [6:0] |                   |     |       |       |       |  |  |  |  |
| 0x116              | R        | eserved          | G6: Li | ne ADC To LE                      | EC Gain [6:0]     |     |       |       |       |  |  |  |  |
| 0x117              | R        | eserved          | G7: LI | EC To Line DA                     | AC Gain [6:0]     |     |       |       |       |  |  |  |  |
| 0x118              | R        | eserved          | G8: Li | C To TI Gain                      | [6:0]             |     |       |       |       |  |  |  |  |
| 0x119              | R        | eserved          | G9: LI | Cin Mixer To                      | LEC Gain [6:0]    |     |       |       |       |  |  |  |  |

Side-tone gain (2's complement).

Air CODEC Side-Tone Gain [6:0]

--- Operation range: -0.5 dB ~ -31.5 dB, 0.5 dB per step.

Operation range: +24 dB ~ -31.5 dB, 0.5 dB per step.

--- 0x40 means mute/disable this path.

Determines whether the side tone insertion is before or after the

echo cancellation block.

POSITION 0: After AEC as per Figure 8-30.

1: Before - immediately after DAC/ADC.

Gain in 2's complement format, G\*0.5dB.

Air ADC To AEC Gain [6:0]

AEC To Air DAC Gain [6:0]

AEC To MIC Gain [6:0]

AEC To MIC Gain [6:0]

CODEC To LEC Gain [6:0]

LEC To CODEC Gain [6:0]

LEC To Mixer Gain [6:0] Mixer To LEC Gain [6:0] 0x40 mutes gain stage.

Note: As per Table 8-20



### 8.19.3 AECin Path Mixing Gain Control

| Address    |          | Access Mo | ode V                                          | alue At Reset                                 | Nominal Value  | 6         |       |   |   |  |  |  |  |  |  |
|------------|----------|-----------|------------------------------------------------|-----------------------------------------------|----------------|-----------|-------|---|---|--|--|--|--|--|--|
| 0x11A-0x11 | .E       | R/W       | 0x00                                           |                                               | - V-/23 B      |           |       | ı | ı |  |  |  |  |  |  |
| Address    | Bit 7    |           | Bit 6                                          | Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1           |                |           |       |   |   |  |  |  |  |  |  |
| 0x11A      | Reserved |           | GA: A                                          | GA: AEC to AECin Path Mixer Gain Index [6:0]  |                |           |       |   |   |  |  |  |  |  |  |
| 0x11B      | R        | eserved   | GB: L                                          | GB: LEC to AECin Path Mixer Gain Index [6:0]  |                |           |       |   |   |  |  |  |  |  |  |
| 0x11C      | R        | eserved   | GC: P                                          | GC: PLAY to AECin Path Mixer Gain Index [6:0] |                |           |       |   |   |  |  |  |  |  |  |
| 0x11D      | R        | eserved   | GD: I2                                         | S L to AECi                                   | n Path Mixer G | ain Index | [6:0] |   |   |  |  |  |  |  |  |
| 0x11E      | Reserved |           | GE: I2S R to AECin Path Mixer Gain Index [6:0] |                                               |                |           |       |   |   |  |  |  |  |  |  |

AEC to AECin Path Mixer Gain Index [6:0] LEC to AECin Path Mixer Gain Index [6:0] PLAY to AECin Path Gain Index [6:0] I2S L to AECin Path Mixer Gain Index [6:0] I2S R to AECin Path Mixer Gain Index [6:0] Gain in 2's complement format, G\*0.5dB.

- Operation range: +24 dB ~ -31.5 dB, 0.5 dB per step.
- 0x40 mutes gain stage.

Note: As per Table 8-20

### 8.19.4 LECin Path Mixing Gain Control

|   | Address     |          | Access Mo | ode |                                                | At Reset | N     | ominal Value | :  |           |        |       |       |
|---|-------------|----------|-----------|-----|------------------------------------------------|----------|-------|--------------|----|-----------|--------|-------|-------|
| L | 0x11F-0x123 | 3        | R/W       |     | (                                              | 0x00     |       |              |    |           |        |       |       |
|   | Address     |          | Bit 7     | В   | Bit 6 Bit 5 Bit 4 Bit 3                        |          |       |              |    |           | Bit 2  | Bit 1 | Bit 0 |
|   | 0x11F       | Reserved |           | GF  | GF : AEC to LECin Path Mixer Gain Index [6:0]  |          |       |              |    |           |        |       |       |
|   | 0x120       | Reserved |           | G1  | G10: LEC to LECin Path Mixer Gain Index [6:0]  |          |       |              |    |           |        |       |       |
|   | 0x121       | R        | eserved   | G1  | G11: PLAY to LECin Path Mixer Gain Index [6:0] |          |       |              |    |           |        |       |       |
|   | 0x122       | Reserved |           | G1  | 2: I2S                                         | L to LEC | in P  | ath Mixer    | Ga | ain Index | [6:0]  |       |       |
|   | 0x123       | R        | eserved   | G1  | 3: I2S                                         | R to LEC | Cin F | Path Mixe    | G  | ain Index | ([6:0] |       |       |

AEC to LECin Path Mixer Gain Index [6:0] LEC to LECin Path Mixer Gain Index [6:0] Gain in 2's complement format, G\*0.5dB.

- Operation range: +24 dB ~ -31.5 dB, 0.5 dB per step.
- 0x40 mutes gain stage.



PLAY to LECin Path Gain Index [6:0]
I2S L to LECin Path Mixer Gain Index [6:0]
I2S R to LECin Path Mixer Gain Index [6:0]

Note: As per Table 8-20

### 8.19.5 REC Path Mixing Gain Control Registers

| Address    |          | Access Mo | ode | Value                                        | At Reset  | Nominal Value | 305       |       |       |       |  |
|------------|----------|-----------|-----|----------------------------------------------|-----------|---------------|-----------|-------|-------|-------|--|
| 0x124-0x12 | 8        | R/W       |     | (                                            | 0x00      |               | - Y(Q)\   | 152   |       |       |  |
| Address    | Bit 7    |           | Bit | 6                                            | Bit 5     | Bit 4         | Bit 3     | Bit 2 | Bit 1 | Bit 0 |  |
| 0x124      | Reserved |           | G14 | G14 : AEC to REC Path Mixer Gain Index [6:0] |           |               |           |       |       |       |  |
| 0x125      | Reserved |           | G15 | G15: LEC to REC Path Mixer Gain Index [6:0]  |           |               |           |       |       |       |  |
| 0x126      | R        | eserved   | G16 | : PLA                                        | AY to REC | Path Mixer G  | ain Index | [6:0] |       |       |  |
| 0x127      | Reserved |           | G17 | : I2S                                        | L to REC  | Path Mixer G  | ain Index | [6:0] |       |       |  |
| 0x128      | Reserved |           | G18 | G18: I2S R to REC Path Mixer Gair            |           |               |           | [6:0] |       |       |  |

AEC to REC Path Mixer Gain Index [6:0] LEC to REC Path Mixer Gain Index [6:0] PLAY to REC Path Gain Index [6:0] I2S L to REC Path Mixer Gain Index [6:0] I2S R to REC Path Mixer Gain Index [6:0] Gain in 2's complement format, G\*0.5dB.

- Operation range: +24 dB ~ -31.5 dB, 0.5 dB per step.
- 0x40 mutes gain stage.

Note: As per Table 8-20



### 8.19.6 I2SLin Path Mixing Gain Control Registers

| Address    |          |         |                                                  | ode Value At Reset Nominal Val                  |               |           |         |       |       |  |  |  |  |  |
|------------|----------|---------|--------------------------------------------------|-------------------------------------------------|---------------|-----------|---------|-------|-------|--|--|--|--|--|
| 0x129-0x12 | D        | R/W     |                                                  | 0x00                                            |               | 6         |         |       |       |  |  |  |  |  |
| Address    |          | Bit 7   | Bit 6                                            | Bit 5                                           | Bit 4         | Bit 3     | Bit 2   | Bit 1 | Bit 0 |  |  |  |  |  |
| 0x129      | Reserved |         | G19 : A                                          | G19 : AEC to I2SLin Path Mixer Gain Index [6:0] |               |           |         |       |       |  |  |  |  |  |
| 0x12A      | Reserved |         | G1A: LE                                          | G1A: LEC to I2SLin Path Mixer Gain Index [6:0]  |               |           |         |       |       |  |  |  |  |  |
| 0x12B      | R        | eserved | G1B: PI                                          | G1B: PLAY to I2SLin Path Mixer Gain Index [6:0] |               |           |         |       |       |  |  |  |  |  |
| 0x12C      | Reserved |         | G1C: I2                                          | S L to I2SL                                     | in Path Mixer | Gain Inde | x [6:0] |       |       |  |  |  |  |  |
| 0x12D      | Reserved |         | G1D: I2S R to I2SLin Path Mixer Gain Index [6:0] |                                                 |               |           |         |       |       |  |  |  |  |  |

AEC to I2SLin Path Mixer Gain Index [6:0] LEC to I2SLin Path Mixer Gain Index [6:0] PLAY to I2SLin Path Gain Index [6:0] I2S L to I2SLin Path Mixer Gain Index [6:0] I2S R to I2SLin Path Mixer Gain Index [6:0] Gain in 2's complement format, G\*0.5dB.

- Operation range: +24 dB ~ -31.5 dB, 0.5 dB per step.
- 0x40 mutes gain stage.

Note: As per Table 8-20

### 8.19.7 I2SRin Path Mixing Gain Control Registers

| Address    |          | Access Mo | ode               | Value                                           | At Reset  | Nominal Val  | ue   | 1         |         |       |       |  |  |
|------------|----------|-----------|-------------------|-------------------------------------------------|-----------|--------------|------|-----------|---------|-------|-------|--|--|
| 0x12E-0x13 | 2        | R/W       |                   | (                                               | 0x00      |              |      |           |         |       |       |  |  |
| Address    |          | Bit 7     | Bit 6 Bit 5 Bit 4 |                                                 |           |              |      | Bit 3     | Bit 2   | Bit 1 | Bit 0 |  |  |
| 0x12E      | Reserved |           | G1                | G1E : AEC to I2SRin Path Mixer Gain Index [6:0] |           |              |      |           |         |       |       |  |  |
| 0x12F      | Reserved |           | G1                | G1F: LEC to I2SRin Path Mixer Gain Index [6:0]  |           |              |      |           |         |       |       |  |  |
| 0x130      | R        | eserved   | G2                | G20: PLAY to I2SRin Path Mixer Gain Index [6:0] |           |              |      |           |         |       |       |  |  |
| 0x131      | R        | Reserved  |                   | 1: I2S                                          | L to I2SF | Rin Path Mix | er G | ain Inde  | c [6:0] |       |       |  |  |
| 0x132      | R        | eserved   | G2:               | 2: I2S                                          | R to I2SF | Rin Path Mix | er C | Gain Inde | x [6:0] |       |       |  |  |



AEC to I2SRin Path Mixer Gain Index [6:0] LEC to I2SRin Path Mixer Gain Index [6:0] PLAY to I2SRin Path Gain Index [6:0] I2S L to I2SRin Path Mixer Gain Index [6:0] I2S R to I2SRin Path Mixer Gain Index [6:0] Gain in 2's complement format, G\*0.5dB.

- Operation range: +24 dB ~ -31.5 dB, 0.5 dB per step.
- 0x40 mutes gain stage.

Note: As per Table 8-20

### 8.19.8 Mixer Source Enable Registers

| Address    |     | Acce  | ss Mode                           | Value At Reset | Nominal Va  | alue        |             |       |       |
|------------|-----|-------|-----------------------------------|----------------|-------------|-------------|-------------|-------|-------|
| 0x13B-0x13 | F   | F     | R/W                               | 0x00           |             | 40          | 20 (0)      |       |       |
| Address    | В   | it 7  | Bit 6                             | Bit 5          | Bit 4       | Bit 3       | Bit 2       | Bit 1 | Bit 0 |
|            | Res | erved | FSK_GEN TONE_GEN I2S_R I2S_L I15K |                |             |             | 115K        | TL.   | MIC   |
| 0x13B      | Res | erved |                                   |                | AECin Mixe  | r Source E  | nable [6:0] |       | -     |
| 0x13C      | Res | erved |                                   |                | LECin Mixe  | r Source E  | nable [6:0] |       |       |
| 0x13D      | Res | erved |                                   |                | REC Mixer   | Source En   | able [6:0]  |       |       |
| 0x13E      | Res | erved |                                   |                | I2SLin Mixe | r Source E  | nable [6:0] |       |       |
| 0x13F      | Res | erved |                                   |                | I2SRin Mixe | er Source E | nable [6:0] |       |       |

AECin Mixer Source Enable [6:0] LECin Mixer Source Enable [6:0] REC Mixer Source Enable [6:0] I2SLin Mixer Source Enable [6:0] I2SRin Mixer Source Enable [6:0] These registers determine which of the input sources to the mixers are enabled. 1 = Source Enable, 0 = Source Disable

For example if bit 6 of AECin register (0x13B) is set then output of the FSK generator will be mixed to the output. If bit 1 is set then the TI input will be mixed to the output.

Note: The Mixing operation is performed after Mixer Gain.

#### Mixer Example:

```
--- 0x 013B = 0x 01,AEC out = AEC in *GA (Loop Back)
```

--- 0x 013C = 0x 12, LEC out = I2S\_R in \*G12 + LEC in\*G10

--- 0x 013D = 0x 23, I15K out = DTMF\_GEN in + LEC in \*G15 + AEC in \*G14

--- 0x 013E = 0x 37, I2S\_L out = DTMF\_GEN in + I2S\_R in \*G1D + I15K in \*G1B + LEC in \*G1A + AEC in \*G19

- 133 -

#### 8.20 Air and Line CODEC



The ISD61S00 contains two channels of A/D and D/A conversion for the air side interface and the line side interface.

### 8.20.1 AC\_EN, LC\_EN - Air /Line CODEC Enable Register

| Address                    | ss Access      |       | ss Mode Value At Rese |               |             | eset  |            |       |       |
|----------------------------|----------------|-------|-----------------------|---------------|-------------|-------|------------|-------|-------|
| 0x140 (Air)<br>0x150 (Line | - ( )          |       | W                     | V 0x          |             | - Y   | CAY JE     |       |       |
| Bit 7                      | Е              | Bit 6 | t 6 Bit               |               | Bit 5 Bit 4 |       | Bit 2      | Bit 1 | Bit 0 |
| CODEC_EN                   | EC_EN Reserved |       | IMAGE_                | GE_FIL SAT_ON |             | HPF_I | FREQ [3:2] |       | -     |

CODEC\_EN CODEC Digital Path Enable. 1 = Enable, 0 = Disable (Power Down).

IMAGE FIL Enable image filter. The image IIR filter may be used to remove aliased image

of signal resulting from down-sampling. This filter is available for use in 8kHz mode on the line side and/or the air side, and in 16kHz mode on the air side

only.

SAT ON Enable MACC saturation control. It is recommended that this is enabled.

HPF\_FREQ [3:2] Control for high pass filter cut-off frequency.

For 16kHz sampling the cut-off frequencies are:

00 = 6.7Hz Cutoff

01 = 81.7Hz Cutoff

10 = 204Hz Cutoff

11 = Reserved.

For 8kHz sampling the cut-off frequencies are:

00 = 3.3Hz Cutoff

01 = 40.8Hz Cutoff

10 = 102Hz Cutoff

11 = Reserved.

To ensure the correct reset and initial conditions of the CODEC the following sequence should be observed for power up and down of the CODEC.

CODEC power up sequence:

- 1. Begin at state 0x00 (CODEC\_EN=0, IMAGE\_FIL=0, SAT\_ON=0)
- 2. Enable CODEC 0x80 (CODEC\_EN=1, IMAGE\_FIL=0, SAT\_ON=0)
- 3. Enable image filter (if applicable) 0xB0 (CODEC\_EN=1, IMAGE\_FIL=1, SAT\_ON=1)

CODEC power down sequence:

• Set to state 0x00 (CODEC EN=0, IMAGE FIL=0, SAT ON=0).



### 8.20.2 AC\_CTRL, LC\_CTRL - Air /Line CODEC Dither Control

| Address  | Address Access Mode          |  |         |          | Value At Res | et           |               |       |       |
|----------|------------------------------|--|---------|----------|--------------|--------------|---------------|-------|-------|
| •        | 0x141 (Air) F<br>0x151(Line) |  | W       |          | 0x07         | 200          |               |       |       |
| Bit 7    | Bit 6                        |  | 6 Bit 5 |          | Bit 4        | Bit 3        | Bit 2         | Bit 1 | Bit 0 |
| Reserved | Reserved Reserved Res        |  | erved   | Reserved | Dither_sign  | Dither_level | Dither_enable |       |       |

Dither\_enable = 1: Enable dither;

4 5 Dither\_level = 1: 17bits dither; 0: 16bits dither;

Dither sign =0: Additional random noise is both positive and negative.

=1: Additional random noise is only positive.

### 8.20.3 AC\_ADCG, LC\_ADCG - Air/Line CODEC ADC Gain.

|   | Addres                                  | Address A |  |      | Value At Res | et    | Nomin  | al Value |              |      |
|---|-----------------------------------------|-----------|--|------|--------------|-------|--------|----------|--------------|------|
|   | 0x142~0x143 (Air)<br>0x152~0x153 (Line) |           |  | R/W  | 0x0400       |       |        |          |              |      |
|   | Bit7                                    | it7 Bit6  |  | Bit5 | Bit4         |       | Bit3   | Bit2     | Bit1         | Bit0 |
| 2 |                                         |           |  |      |              |       |        | ADC_DI   | G_GAIN[11:8] |      |
| 3 |                                         |           |  |      | ADC_DIG_     | _GAIN | N[7:0] |          |              |      |

ADC\_DIG\_GAIN [11:0] Digital ADC Path Gain. (Default = 12'h400, unity gain)

Format: 2's complements number with format = 2.10

Example:

--- ADC\_DIG\_GAIN [11:0] = 12'h5A6, Gain = + 3 dB

--- ADC DIG GAIN [11:0] = 12'h400, Gain = 0 dB

--- ADC\_DIG\_GAIN [11:0] = 12'h2D6, Gain = - 3 dB

### 8.20.4 AC\_DACG, LC\_DACG - Air/Line CODEC DAC Gain.

| Addres                    | S    | Access Mode | Value At Res | et   | Nomin  | al Value |              |      |
|---------------------------|------|-------------|--------------|------|--------|----------|--------------|------|
| 0x144~0x14<br>0x154~0x155 | , ,  | R/W         | 0x0400       |      |        |          |              |      |
| Bit7                      | Bit6 | Bit5        | Bit4         |      | Bit3   | Bit2     | Bit1         | Bit0 |
|                           | 50   | (O)         |              |      |        | DAC_D    | G_GAIN[11:8] |      |
|                           | 10   | 0, 6        | DAC_DIG_     | _GAI | N[7:0] |          |              |      |

Publication Release Date: March 10, 2011 Revision 2.7

- 135 -



DAC\_DIG\_GAIN [11:0] Digital DAC Path Gain. (Default = 12'h400, unity gain)

Format: 2's complements number with format = 2.10

Example:

--- DAC\_DIG\_GAIN [11:0] = 12'h5A6, Gain = + 3 dB --- DAC\_DIG\_GAIN [11:0] = 12'h400, Gain = 0 dB --- DAC\_DIG\_GAIN [11:0] = 12'h2D6, Gain = - 3 dB

8.20.5

8.20.6

#### **8.21 RINGER TONE GENERATOR**

The ringer tone will be generated while an incoming call occurred. There are two tone signals can be mixed to the speakerphone driver output. This subsection describes the Ringer Tone Generator with the PWM (Pulse Width Modulation) format.

### Ringer tone generator (PWM) specification:

- Tone Channel Number = 2
- Tone Volume Step = 32
- Tone Frequency Range = 93Hz~24KHz

$$Frequency = \frac{12.288M}{16 \times N \times 32} Hz \qquad N = 1 \sim 256$$

The tone frequency/volume control signal path is shown as Figure 8-31 Ringer Tone Generator Block



Figure 8-31 Ringer Tone Generator Block

#### **8.21.1 PWM Clock**

|   | Address   | dress Access |      | ess Mode | Value At Reset |    | Nominal Value |       |     |          |          |
|---|-----------|--------------|------|----------|----------------|----|---------------|-------|-----|----------|----------|
|   | 0x1A0     |              | R/W  | 0x00     |                |    |               |       |     | _        |          |
|   | Bit 7     | Bit          | 6    | Bit 5    | Bit 4          |    | Bit 3         | Bit   | 2   | Bit 1    | Bit 0    |
| F | WM CLK ON | Rese         | rved | Reserved | Reserved       | Re | served        | Reser | ved | Reserved | Reserved |

**PWM CLK ON** 

PWM Operation Clock Enable. 1 = Enable 0 = Disable

--- Set this bit will enable PWM operation clock.

Note: Before disable this bit, the tone\_on1 (0x1A2: BIT [7]) and

tone\_on2 (0x1A4 BIT [7]) must be disable first.

### 8.21.2 PWM Tone1 Control



| Address   |       | Acc  | ess Mode | Value At Rese       | t No  | Nominal Value |  |       |       |
|-----------|-------|------|----------|---------------------|-------|---------------|--|-------|-------|
| 0x1A2     |       |      | R/W      | 0x00                | 149   | R.            |  |       | _     |
| Bit 7     | Bit 6 |      | Bit 5    | Bit 4               | Bit 3 | Bit 3 Bit 2   |  | Bit 1 | Bit 0 |
| TONE ON 1 | Rese  | rved | Reserved | TONE_VOLUME_1 [4:0] |       |               |  |       |       |

TONE\_VOLUME\_1 [4:0] TONE 1 Volume setting.

--- There have 32 stage volume of the Tone generator.

--- Set this volume zero will force output mute.

TONE ON 1 TONE 1 Enable. 1 = Enable, 0 = Disable

Note: This bit can be updated only while PWM CLK ON (0x1A0 BIT [7]) is active. Besides, if the Ringer what to on/off with a full frequency cycle, the suggest way is to play one "Zero" volume cycle

before disable the TONE ON.

### 8.21.3 PWM Tone1 Frequency

| Address A          |             | Acc | ess Mode | Value At Reset |       | Nominal Value |             |  |   |       |       |
|--------------------|-------------|-----|----------|----------------|-------|---------------|-------------|--|---|-------|-------|
| 0x1A3              |             |     | R/W      |                | 0x00  |               |             |  |   |       |       |
| Bit 7              | Bit 6 Bit 5 |     | Bit 5    | i              | Bit 4 |               | Bit 3 Bit 2 |  | 2 | Bit 1 | Bit 0 |
| TONE_FREQ_1 [ 7:0] |             |     |          |                |       |               |             |  |   |       |       |

TONE FREQ 1 [7:0] TONE 1 Frequency setting.

--The Ringer Tone Frequency = 768 / [32\*(TONE FREQ 1+ 1)] KHz

EX: If the TONE\_FREQ\_1 = 0x4A, then the Ringer Tone 1 output frequency

will be 768 / [32 \* (74+1)] = 320 Hz

#### 8.21.4 PWM Tone2 Control

| Address   | Address Acc |          | Value At Reset | Nominal | Value     |       |       |
|-----------|-------------|----------|----------------|---------|-----------|-------|-------|
| 0x1A4     | X.          | R/W      | 0x00           |         |           |       | _     |
| Bit 7     | Bit 6       | Bit 5    | Bit 4          | Bit 3   | Bit 2     | Bit 1 | Bit 0 |
| TONE ON 2 | Reserved    | Reserved |                | TONE_   | _VOLUME_2 | [4:0] |       |

TONE\_VOLUME\_2 [4:0]

TONE 2 Volume setting.

- --- There have 32 stage volume of the Tone generator.
- --- Set this volume zero will force output mute.

- 138 -



TONE ON 2

TONE 2 Enable. 1 = Enable, 0 = Disable

Note: This bit can be updated only while PWM CLK ON (0x1A0 BIT [7]) is active. Besides, if the Ringer what to on/off with a full frequency cycle, the suggest way is to play one "Zero" volume cycle before disable the TONE ON.

#### 8.21.5 PWM Tone2 Frequency

| Address |                    | Acc | ess Mode | Value At Rese | t Nor | Nominal Value |  |       |       |
|---------|--------------------|-----|----------|---------------|-------|---------------|--|-------|-------|
| 0x1A5   |                    |     | R/W      | 0x00          |       |               |  | 10/10 | 1     |
| Bit 7   | Bit 6 Bit 5        |     | Bit 5    | Bit 4         | Bit 3 | 3 Bit 2       |  | Bit 1 | Bit 0 |
|         | TONE_FREQ_2 [ 7:0] |     |          |               |       |               |  |       |       |

TONE\_FREQ\_2 [7:0]

TONE 2 Frequency setting.

---The Ringer Tone Frequency =  $750/[32*(TONE\_FREQ\_2 + 1)]$  KHz EX: If the TONE\_FREQ\_2 = 0x4A, then the Ringer Tone 2 output frequency will be 768/[32\*(74+1)] = 320 Hz

#### 9. ACOUSTIC PROCESSING BLOCK

The Acoustic possessing block performs a variety of functions to implement the full or half duplex echo cancellation. The ISD61S00 incorporates an Acoustic Echo Cancellation (AEC) block for the microphone and speaker CODEC and a Line Echo Cancellation (LEC) block for the PSTN interface. These blocks are very similar, with the main differences being that the AEC includes an AGC function and has a greater echo cancellation length.

The functions performed by the acoustic processing blocks include:

**Echo Cancellation**: This is an adaptive estimation of the characteristics of the echo path to cancel echo introduced by speaker/microphone acoustic coupling and echo return paths from the environment.

**Voice Detection (VD)**: Decides whether input signal from the far end is an active voice signal by estimating the signal power.

**Double Talk (DT) Detection**: Decides whether input signal from the near end is an active voice signal by estimating the signal power.

**AGC**: Automatic gain control to provide an optimal level from the microphone input.

Soft Clipping: limits the input signal path to prevent hard saturation of the output.

Acoustic Suppression: Used in half duplex to suppress voice either from the near end or the far end.

Noise Suppression: Detects and suppresses noise.

### 9.1 Full/Half AEC Block Diagram

### nuvoton

Full acoustic echo cancellation unit removes the echo signal inserted by the speaker coupling and space reflections. Half duplex AEC smoothly transitions the acoustic suppressors from one direction to the other based on the power estimations of the voice and double talk detectors. Figure 9-1 illustrates the block diagram of the Full/Half Acoustic Echo Canceller. The line echo cancellation block is similar though has the AGC block replaced by an additional soft clipping gain block (Figure 9-2).



Figure 9-1: Signal flow through the Acoustic Echo Canceller (AEC) in the speech Processor.



Figure 9-2: Signal flow through the Line Echo Canceller (LEC) in the speech Processor.



## 9.2 Control Register Memory Map

The AEC/LEC block is controlled via configuration registers from that enable control and tuning of the echo cancellation parameters. A summary of the registers is presented in Table 9-1. Read only registers are highlighted in red fill.

Table 9-1 AEC/LEC Control Register Map

| AEC                  | LEC                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Name                 | Address                                                                                                                                                                                                                                                                                                     | Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| AEC_CONFIG           | 0x0380                                                                                                                                                                                                                                                                                                      | LEC_CONFIG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| AEC_RESET            | 0x0381                                                                                                                                                                                                                                                                                                      | LEC_RESET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| AEC_EC_BELTA         | 0x0382                                                                                                                                                                                                                                                                                                      | LEC_EC_BELTA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| AEC_AS_COEFF         | 0x0383                                                                                                                                                                                                                                                                                                      | LEC_AS_COEFF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| Reserved             | 0x0384                                                                                                                                                                                                                                                                                                      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| Double Ta            | lk Detector                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| AEC_DT_LONG_TC       | 0x0385                                                                                                                                                                                                                                                                                                      | LEC_DT_LONG_TC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| AEC_DT_SHORT_TC      | 0x0386                                                                                                                                                                                                                                                                                                      | LEC_DT_SHORT_TC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| AEC_DT_HANGOVER_TIME | 0x0387~<br>0x0388                                                                                                                                                                                                                                                                                           | LEC_DT_HANGOVER_TIME                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| AEC_DT_DV_THRESH     | 0x0389~<br>0x038A                                                                                                                                                                                                                                                                                           | LEC_DT_DV_THRESH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
| AEC_DT_LONG_THRESH   | 0x038B~<br>0x038C                                                                                                                                                                                                                                                                                           | LEC_DT_LONG_THRESH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| AEC_DT_SHORT_THRESH  | 0x038D~<br>0x038E                                                                                                                                                                                                                                                                                           | LEC_DT_SHORT_THRESH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| AEC_DIVERGENCE       | 0x038F                                                                                                                                                                                                                                                                                                      | LEC_DIVERGENCE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| Voice D              | etector                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| AEC_VD_LONG_TC       | 0x0390                                                                                                                                                                                                                                                                                                      | LEC_VD_LONG_TC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| AEC_VD_SHORT_TC      | 0x0391                                                                                                                                                                                                                                                                                                      | LEC_VD_SHORT_TC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| AEC_VD_HANGOVER_TIME | 0x0392~<br>0x0393                                                                                                                                                                                                                                                                                           | LEC_VD_HANGOVER_TIME                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| AEC_VD_DEV_THRESHOLD | 0x0394~<br>0x0395                                                                                                                                                                                                                                                                                           | LEC_VD_DEV_THRESHOLD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| AEC_VD_LONG_THRESH   | 0x0396~<br>0x0397                                                                                                                                                                                                                                                                                           | LEC_VD_LONG_THRESH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|                      | Name  AEC_CONFIG  AEC_RESET  AEC_EC_BELTA  AEC_AS_COEFF  Reserved  Double Tale  AEC_DT_LONG_TC  AEC_DT_SHORT_TC  AEC_DT_HANGOVER_TIME  AEC_DT_LONG_THRESH  AEC_DT_SHORT_THRESH  AEC_DT_SHORT_THRESH  AEC_DT_SHORT_THRESH  AEC_DT_SHORT_THRESH  AEC_DVERGENCE  Voice D  AEC_VD_LONG_TC  AEC_VD_HANGOVER_TIME | Name         Address           AEC_CONFIG         0x0380           AEC_RESET         0x0381           AEC_EC_BELTA         0x0382           AEC_AS_COEFF         0x0383           Reserved         0x0384           Double Talk Detector           AEC_DT_LONG_TC         0x0385           AEC_DT_SHORT_TC         0x0386           AEC_DT_SHORT_TC         0x0387~           0x0388         0x0389~           0x0389~         0x0388~           0x038A         0x038A           AEC_DT_LONG_THRESH         0x038D~           0x038E         0x038E           AEC_DIVERGENCE         0x038F           Voice Detector           AEC_VD_LONG_TC         0x0390           AEC_VD_SHORT_TC         0x0391           AEC_VD_HANGOVER_TIME         0x0392~           0x0393         0x0394~           0x0395         0x0396~ |  |  |  |

# nuvoTon

|                   | AEC                     | LEC               |                          |  |  |  |
|-------------------|-------------------------|-------------------|--------------------------|--|--|--|
| Address           | Name                    | Address           | Name                     |  |  |  |
| 0x0318~<br>0x0319 | AEC_VD_SHORT_THRESH     | 0x0398~<br>0x0399 | LEC_VD_SHORT_THRESH      |  |  |  |
| 0x031A~<br>0x031B | AEC_CUT_OFF_PWR         | 0x039A~<br>0x039B | LEC_CUT_OFF_PWR          |  |  |  |
| 0x31C             | Reserved                | 0x39C             | Reserved                 |  |  |  |
| 0x031D            | AEC_VD_AVE_TC           | 0x039D            | LEC_VD_AVE_TC            |  |  |  |
| 0x031E~<br>0x031F | AEC_VD_AVE_THRESH       | 0x039E~<br>0x039F | LEC_VD_AVE_THRESH        |  |  |  |
|                   | Acoustic Suppressor     |                   | Line Suppressor          |  |  |  |
| 0x0320            | AEC_AS1_BUILD_UP_TIME   | 0x03A0            | LEC_AS1_BUILD_UP_TIME    |  |  |  |
| 0x0321-<br>0x0322 | AEC_AS1_MAX_ATTEN       | 0x03A1~<br>0x03A2 | LEC_AS1_MAX_ATTEN        |  |  |  |
| 0x0323            | AEC_AS2_BUILD_UP_TIME   | 0x03A3            | LEC_AS2_BUILD_UP_TIME    |  |  |  |
| 0x0324~<br>0x0325 | AEC_AS2_MAX_ATTEN       | 0x03A4~<br>0x03A5 | LEC_AS2_MAX_ATTEN        |  |  |  |
| 0x0326~<br>0x0327 | Reserved                | 0x03A6~<br>0x03A7 | Reserved                 |  |  |  |
|                   | Noise Su                | ppressor          |                          |  |  |  |
| 0x0328            | AEC_NS_POWER_ATTACK_TC  | 0x03A8            | LEC_NS_POWER_ATTACK_TC   |  |  |  |
| 0x0329            | AEC_NS_ATTEN_TC         | 0x03A9            | LEC_NS_ATTEN_TC          |  |  |  |
| 0x032A~<br>0x032B | AEC_NS_ACTIVE_THRESHOLD | 0x03AA~<br>0x03AB | LEC_NS_ACTIVE_THRESHOLD  |  |  |  |
| 0x032C~<br>0x032D | Reserved                | 0x03AC~<br>0x03AD | Reserved                 |  |  |  |
|                   |                         | -                 |                          |  |  |  |
|                   |                         |                   |                          |  |  |  |
|                   |                         |                   |                          |  |  |  |
|                   |                         |                   | Soft Clipping on DT Side |  |  |  |
| 0x0330            | Reserved                | 0x03B0            | LEC_DT_SC_CTRL           |  |  |  |
| 0x0331            | Reserved                | 0x03B1            | LEC_DT_SC_NORMAL_INDEX   |  |  |  |
| 0x0332            | Reserved                | 0x03B2            | LEC_DT_SC_LOW_INDEX      |  |  |  |
| 0x0333~<br>0x0334 | Reserved                | 0x03B3~<br>0x03B4 | LEC_DT_SC_THRESH         |  |  |  |

# nuvoTon

|                       | AEC                       | LEC               |                           |  |  |  |  |  |
|-----------------------|---------------------------|-------------------|---------------------------|--|--|--|--|--|
| Address               | Name                      | Address           | Name                      |  |  |  |  |  |
| 0x0335                | Reserved                  | 0x03B5            | LEC_DT_SC_POWER_ATTACK_TC |  |  |  |  |  |
| 0x0336                | Reserved                  | 0x03B6            | LEC_DT_SC_GAIN_TC         |  |  |  |  |  |
| 0x0337                | Reserved                  | 0x03B7            | Reserved                  |  |  |  |  |  |
|                       | Soft Clipping             | g on VD Side      |                           |  |  |  |  |  |
| 0x0338                | AEC_VD_SC_CTRL            | 0x03B8            | LEC_VD_SC_CTRL            |  |  |  |  |  |
| 0x0339                | AEC_VD_SC_NORMAL_INDEX    | 0x03B9            | LEC_VD_SC_NORMAL_INDEX    |  |  |  |  |  |
| 0x033A                | AEC_VD_SC_LOW_INDEX       | 0x03BA            | LEC_VD_SC_LOW_INDEX       |  |  |  |  |  |
| 0x033B~<br>0x033C     | AEC_VD_SC_THRESH          | 0x03BB~<br>0x03BC | LEC_VD_SC_THRESH          |  |  |  |  |  |
| 0x033D                | AEC_VD_SC_POWER_ATTACK_TC | 0x03BD            | LEC_VD_SC_POWER_ATTACK_TC |  |  |  |  |  |
| 0x033E                | AEC_VD_SC_GAIN_TC         | 0x03BE            | LEC_VD_SC_GAIN_TC         |  |  |  |  |  |
| 0x033F                | Reserved                  | 0x03BF            | Reserved                  |  |  |  |  |  |
| DT Side Power Monitor |                           |                   |                           |  |  |  |  |  |
| 0x0340~<br>0x0341     | AEC_DT_SHORT_TERM_POWER   | 0x03C0~<br>0x03C1 | LEC_DT_SHORT_TERM_POWER   |  |  |  |  |  |
| 0x0342~<br>0x0343     | AEC_DT_LONG_TERM_POWER    | 0x03C2~<br>0x03C3 | LEC_DT_LONG_TERM_POWER    |  |  |  |  |  |
| 0x0344~<br>0x0345     | AEC_DT_POWER_DEVIATION    | 0x03C4~<br>0x03C5 | LEC_DT_POWER_DEVIATION    |  |  |  |  |  |
| 0x0346                | AEC_DT_ACTIVE             | 0x03C6            | LEC_DT_ACTIVE             |  |  |  |  |  |
| 0x0347                | Reserved                  | 0x03C7            | Reserved                  |  |  |  |  |  |
|                       | VD Side Po                | wer Monitor       |                           |  |  |  |  |  |
| 0x0348~<br>0x0349     | AEC_VD_SHORT_TERM_POWER   | 0x03C8~<br>0x03C9 | LEC_VD_SHORT_TERM_POWER   |  |  |  |  |  |
| 0x034A~<br>0x034B     | AEC_VD_LONG_TERM_POWER    | 0x03CA~<br>0x03CB | LEC_VD_LONG_TERM_POWER    |  |  |  |  |  |
| 0x034C~<br>0x034D     | AEC_VD_POWER_DEVIATION    | 0x03CC~<br>0x03CD | LEC_VD_POWER_DEVIATION    |  |  |  |  |  |
| 0x034E                | AEC_VD_ACTIVE             | 0x03CE            | LEC_VD_ACTIVE             |  |  |  |  |  |
| 0x034F                | Reserved                  | 0x03CF            | Reserved                  |  |  |  |  |  |
| 17                    | Signal                    | Monitor           |                           |  |  |  |  |  |
| 0x0350~<br>0x0351     | AEC_LRIN                  | 0x03D0~<br>0x03D1 | LEC_LRIN                  |  |  |  |  |  |

# nuvoTon

|                   | AEC           | LEC               |            |  |  |
|-------------------|---------------|-------------------|------------|--|--|
| Address           | Name          | Address           | Name       |  |  |
| 0x0352~<br>0x0353 | AEC_EOUT      | 0x03D2~<br>0x03D3 | LEC_EOUT   |  |  |
| 0x0354~<br>0x0355 | AEC_ASOUT     | 0x03D4~<br>0x03D5 | LEC_ ASOUT |  |  |
| 0x0356~<br>0x0357 | AEC_ARIN      | 0x03D6~<br>0x03D7 | LEC_ ARIN  |  |  |
| 0x0358~<br>0x0359 | AEC_LSOUT     | 0x03D8~<br>0x03D9 | LEC_LSOUT  |  |  |
|                   |               | _                 | 3076       |  |  |
| 0x035B            |               |                   |            |  |  |
| 0x035C~<br>0x035D |               |                   |            |  |  |
| 0x035E~<br>0x035F |               |                   |            |  |  |
|                   | AGC Function  |                   |            |  |  |
| 0x0360            | AGC_CTRL      | 0x03E0            | Reserved   |  |  |
| 0x0361            | AGC_INIT_GAIN | 0x03E1            | Reserved   |  |  |
| 0x0362            | AGC_GAIN_HOLD | 0x03E2            | Reserved   |  |  |
| 0x0363            | AGC_INC_DEC   | 0x03E3            | Reserved   |  |  |
| 0x0364            | AGC_ATK_DCY   | 0x03E4            | Reserved   |  |  |
| 0x0365            | AGC_GAIN_READ | 0x03E5            | Reserved   |  |  |
| 0x0366            | AGC_STATE     | 0x03E6            | Reserved   |  |  |
| 0x0367            | AGC_POWER_TC  | 0x03E7            | Reserved   |  |  |
| 0x0368            | AGC_PK_TC     | 0x03E8            | Reserved   |  |  |
| 0x0369~<br>0x036A | AGC_PK        | 0x03E9~<br>0x03EA | Reserved   |  |  |
| 0x036B~<br>0x036F | Reserved      | 0x03EB~<br>0x03EF | Reserved   |  |  |
| 0x0370~<br>0x0371 | AGC_TARG_CLIP | 0x03F0~<br>0x03F1 | Reserved   |  |  |
| 0x0372~<br>0x0373 | AGC_TARG_HI   | 0x03F2~<br>0x03F3 | Reserved   |  |  |
| 0x0374~<br>0x0375 | AGC_TARG_LO   | 0x03F4~<br>0x03F5 | Reserved   |  |  |



|                   | AEC            | LEC               |          |  |  |
|-------------------|----------------|-------------------|----------|--|--|
| Address           | Name           | Address           | Name     |  |  |
| 0x0376~<br>0x0377 | AGC_TARG_RB    | 0x03F6~<br>0x03F7 | Reserved |  |  |
| 0x0378            | AGC_NOISE_BIAS | 0x03F8            | Reserved |  |  |
| 0x0379~<br>0x037A | AGC_NOISE_HI   | 0x03F9~<br>0x03FA | Reserved |  |  |
| 0x037B~<br>0x037C | AGC_NOISE_LO   | 0x03FB~<br>0x03FC | Reserved |  |  |
| 0x037D~<br>0x037F | AGC_NOISE_RB   | 0x037D~<br>0x037F | Reserved |  |  |

### 9.2.1 Threshold and Power Calculation

Many registers in this section are used for setting signal threshold power. Threshold powers are measured in dBFS scale (dB relative to a full scale signal) hence a full scale signal will have a power value of 0dBFS, and all signal levels are referenced to this value. A signal that is half the power of the full scale signal will have a power value of  $20x\log(1/2) = -6.02dBFS$ .

To convert register value to actual dBFS value, follow the scheme below:

If register is 1 byte (0x1B), actual power =  $20\log(0x1B / 0x7F)$  dBFS

If register is 2 bytes (0x1BAD), actual power = 20log(0x1BAD / 0x7FFF) dBFS

If register is 3 bytes (0x1BADBE), actual power = 20log(0x1BAD BE/ 0x7FFFFF) dBFS

If register is 4 bytes (0x1BADBEEF), actual power = 20log(0x1BADBEEF / 0x7FFFFFFF) dBFS

To convert power (in dBFS) into register value, do the following:

If register is 1 byte, Register value =  $[10 \land (power / 20)] * 0x7F$ 

If register is 2 bytes, Register value = [10 ^ (power / 20)] \* 0x7FFF

If register is 3 bytes, Register value = [10 \(^{\text{power}} / 20)\) \(^{\text{power}} \) 0x7FFFF

If register is 4 bytes, Register value = [10 ^ (power / 20)] \* 0x7FFFFFFF

For example, in a 2 bytes register, 0x7FFF corresponds to 0dBFS, 0x3FFF corresponds to -6.02dBFS.

# 9.3 Control Registers



### 9.3.1 **CONFIG**

| Address       |                            | Access Mode | Value At Rese     | et Nominal | Value |        |             |
|---------------|----------------------------|-------------|-------------------|------------|-------|--------|-------------|
| 0x300 (AEC) 0 | (300 (AEC) 0x380 (LEC) R/W |             | 0x96              |            |       |        |             |
| Bit 7         | Bit 6                      | Bit 5       | Bit 4             | Bit 3      | Bit 2 | Bit 1  | Bit 0       |
| -             | Reserved                   | DT_NO_ECHO  | CUT_THRES_<br>DIR | NO_UPDATE  | EC_EN | AS1_EN | AS_PRIORITY |

AEC\_CONFIG and LEC\_CONFIG are general purpose configuration registers for the echo cancellation unit. Various major functions may be enabled or disabled, depending on the state of each flag. Note that echo cancellation may be disabled, yet the updating process for the filter coefficients may remain enabled.

In half duplex and relative mode, when both VD and DT paths are active, determines

which signal path has priority.

AS\_PRIORITY =1, VD\_Active has first priority and AS1 will be active.

=0, DT Active has first priority and AS2 will be active.

AS1\_EN =1, the acoustic suppression 1 (AS1) function will be enabled.

=0, disable

Note: Acoustic suppressor AS2 only active in half duplex mode (EC BELTA[5]=1)

EC\_EN Enables adaptive filter echo cancellation. =1, enable =0, disable

NO\_UPDATE =1, the echo cancellation filter parameters will not be updated

=0, echo cancellation parameters continuously adapt.

CUT THRES DIR Cut-off threshold direction:

=1, the cut off power is applied on the DT side.=0, the cut off power is applied on the VD side.

Cut off power is used for power estimation algorithm, defined at reg0x31A and

reg0x38A

DT NO ECHO =1, double talk power estimation is based on output power after echo cancellation

=0, double talk power estimation detection based on power before echo cancellation

### 9.3.2 **RESET**

| 1/1 | Addre                   | ess             | Access Mode | Value At Reset  | Nominal       | Value            |                |                |
|-----|-------------------------|-----------------|-------------|-----------------|---------------|------------------|----------------|----------------|
|     | 0x301 (AEC) 0x381 (LEC) |                 | R/W         | R/W 0xE8 / 0xA8 |               |                  |                |                |
| X   | Bit 7                   | Bit 6           | Bit 5       | Bit 4           | Bit 3         | Bit 2            | Bit 1          | Bit 0          |
| 301 | BYPASS                  | SP              | EEDUP       | EDUP ALEC RESET |               | RES_COEFF<br>MEM | RES_POW<br>MEM | RES_AIR<br>MEM |
| 381 | BYPASS                  | RESET_FII<br>SH | LEC_8MS     | Reserved        | POWER<br>DOWN | RES_COEFF<br>MEM | RES_POW<br>MEM | RES_AIR<br>MEM |

RES AIR MEM

Resets the voice sample memory used in Echo Canceller.

**RES POW MEM** 

Reset the power (channel model error history) memory used in Echo

Canceller.

Flushing the power and voice sample memories will remove the

- 146 -



| Address       | Access Mode   | Value At Reset                                              | Nominal Value     |
|---------------|---------------|-------------------------------------------------------------|-------------------|
|               | conversation  | history.                                                    |                   |
| RES_COEFF MEM | conversation  | FIR coefficient (c<br>history and wil<br>be recalculated fr | prompt the file   |
| POWER DOWN    |               | C / LEC clock wi<br>Speech signal will                      |                   |
| ALEC RESET    | While progra  | mmed with "1", A                                            | EC / LEC will re  |
| SPEEDUP       | Sets AEC co   | efficient update s                                          | peed.             |
|               | = 00, sets AE | C tail length to 3                                          | 2ms with norma    |
|               | = 01, sets AE | C tail length to 6                                          | 4ms with norma    |
|               | = 10, sets AE | C tail length to 3                                          | 2ms with fast up  |
|               | = 11, sets AE | C tail length to 3                                          | 2ms and automa    |
| BYPASS        | When progra   | mmed with "1", s                                            | peech signal will |
| LEC_8MS       | = 1, sets LEC | tail length to 8m                                           | s.                |
|               | = 0, sets LEC | tail length to 4m                                           | S.                |
| RESET FINISH  |               | Nill go high afte                                           |                   |

# 9.3.3 EC BELTA Addrocc

**ABSOLUTE** 

| Addre        | ess                                                                               | Access Mode | Value At Rese | t Nominal | Value |       |       |  |  |  |  |
|--------------|-----------------------------------------------------------------------------------|-------------|---------------|-----------|-------|-------|-------|--|--|--|--|
| 0x302(AEC) 0 | )x382(LEC)                                                                        | R/W         | 0x03          |           |       |       |       |  |  |  |  |
| Bit 7        | Bit 6                                                                             | Bit 5       | Bit 4         | Bit 3     | Bit 2 | Bit 1 | Bit 0 |  |  |  |  |
| NS_ENABLE    | _ENABLE DT_VD_IDLE HALF DUPLEX ABSOLUTE EC_BELTA                                  |             |               |           |       |       |       |  |  |  |  |
| EC_BELTA     | EC_BELTA EC_BELTA is the echo cancellation update gain and is used to control the |             |               |           |       |       |       |  |  |  |  |

rate of change of the echo cancellation filter coefficients. Lowering the value of this configurable constant will increase the inertial delay present in the channel modeling logic. Raising the value of this constant will reduce this inertial delay. Values significantly different from the nominal value for this field will cause the channel modeling algorithm to exhibit instability. In such a situation any echo present in the channel will not be removed.

=1, Absolute mode: the Double Talk detection algorithm is based on absolute value of power on the DT side.

=0, Relative mode: the Double Talk detection algorithm is based on difference of signal power between the DT side and the VD side depending

on the setting of DT COMPARE DB register in 0x303.

HALF DUPLEX =1, EC will enter half-duplex mode and acoustic suppressor2 (AS2) will be enabled.

- 147 -

=0, EC will enter full-duplex mode and acoustic suppressor2 (AS2) disabled.

DT\_VD\_IDLE =1, AS2 will be active when no energy is detected in DT and VD channels.



| Address Access Mode Value At Reset Nominal Value |
|--------------------------------------------------|
|--------------------------------------------------|

PS: This function is only applicable to half-duplex mode.

NS\_ENABLE =1, the noise suppressor is enabled

=0, bypass the noise suppressor

### 9.3.4 AS COEFF

|     | Addre                 | ess /          | Access Mode Value At Reset |               | Nominal | Nominal Value |         |       |  |  |  |
|-----|-----------------------|----------------|----------------------------|---------------|---------|---------------|---------|-------|--|--|--|
|     | 0x303(AEC) 0x383(LEC) |                | R/W 0x14, 0x04             |               |         | 35%           | To      |       |  |  |  |
|     | Bit 7                 | Bit 6          | Bit 5                      | Bit 4         | Bit 3   | Bit 2         | Bit 1   | Bit 0 |  |  |  |
| 303 | SH_PWR_SE<br>L        | AVE_PWR_S<br>E | SH_PWR_EN<br>B             | DT_BUF_ENB    |         | DT_COM        | PARE_DB |       |  |  |  |
| 383 | SH_PWR_SE<br>L        | AVE_PWR_S      | SH_PWR_EN<br>B             | BOTH_MOD<br>E |         | DT_COMPARE_DB |         |       |  |  |  |

SH\_PWR\_SEL Selects Air power calculation for echo cancellation algorithm

1: Echo cancellation uses Short Term Air Power to calculate input power.

0: Echo cancellation uses Average Air Power to calculate input power.

AVE\_PWR\_SE 1: Average Air Power calculation uses zero extension.

0: Average Air Power calculation uses sign extension.

SH\_PWR\_ENB 1: Disables exponential calculation for Short Term Air Power.

0: Default exponential calculation for Short Term Air Power.

DT BUF ENB 1: AEC DT relative mode compares Line power with previous 32 samples

from VD. LEC DT relative mode compares Line power with previous 8

samples from VD.

0: DT relative mode compares Line power with 1 sample from VD.

DT\_COMPARE\_DB In relative mode, if (line power) > (air power x RATIO) then DT is active.

0000: RATIO = 0.000

0001: RATIO = 0.125 (-18dB) 0010: RATIO = 0.250 (-12dB) 0011: RATIO = 0.375 (-8.5dB) 0100: RATIO = 0.500 (-6dB)

..

1111: RATIO = 1.875 (5.46dB)

BOTH\_MODE 1: AEC and LEC DT detector only active when BOTH absolute mode and

relative mode detection conditions are met.

0: AEC and LEC DT detector uses either absolute mode or relative mode

- 148 -

algorithm. (Reg 0x302, 382)

# 9.4 Double Talk Detector Control Registers



### 9.4.1 Function

Double talk detector is used to decide whether the signal from the near end is an active voice signal by estimating its signal power. Signal is deemed active if the short term acoustic power exceeds a predetermined threshold or if the short term acoustic power exhibits sudden variations under "absolute" mode, or the relative signal level compared with the signal from far end site in non-absolute mode.

The echo cancellation algorithm will stop adapting to the acoustic characteristics when voice is detected on the near end. If speech is being carried over both near end and far end then the double talk condition occurs. In this situation the acoustic interface signal can exhibit echo-like characteristics and acoustic modeling must be halted.

# 9.4.2 DT LONG TC

| Addre        | ess        | Access Mode | Value At Reset | Nominal    | Value |        |       |  |  |
|--------------|------------|-------------|----------------|------------|-------|--------|-------|--|--|
| 0x305(AEC) 0 | )x385(LEC) | R/W         | 0x09           |            |       | 1) (9) | Llow  |  |  |
| Bit 7        | Bit 6      | Bit 5       | Bit 4          | Bit 3      | Bit 2 | Bit 1  | Bit 0 |  |  |
| Reserved     | Reserved   | Reserved    | Reserved       | DT_LONG_TC |       |        |       |  |  |

DT\_LONG\_TC

The DT (Double Talk) long term power estimation's attacking time constant. This field defines the inertial delay utilized for the long term power estimation at DT side. Raising the value of this field reduces the inertia and will make the estimation more responsive while lowering the field will cause the power estimation algorithm to be less responsive to bursts of energy on the acoustic side.

### 9.4.3 DT\_SHORT\_TC

| Addre        | ess         | Access Mode | Value At Reset | Nominal | Value  |         |       |
|--------------|-------------|-------------|----------------|---------|--------|---------|-------|
| 0x306(AEC) 0 | x386(LEC)   | R/W         | 0xBB           |         |        |         |       |
| Bit 7        | Bit 6 Bit 5 |             | Bit 4          | Bit 3   | Bit 2  | Bit 1   | Bit 0 |
|              | DT_SI       | HORT_TC_H   |                |         | DT_SHO | RT_TC_L |       |

DT\_SHORT\_TC

The DT (Double Talk) short term power estimation's attacking time constant. This field defines the inertial delay utilized for the short term power estimation at DT side. Raising the value of this field reduces the inertia and will make the estimation more responsive while lowering the field will cause the power estimation algorithm to be less responsive to bursts of energy on the acoustic side.

DT\_SHORT\_TC\_H

When input signal power is higher than the estimated short term power, DT SHORT TC H is used for the subsequent power estimation.

DT\_SHORT\_TC\_L

When input signal power is lower or equal to the estimated short term power, DT SHORT TC L is used for the subsequent power estimation.



### 9.4.4 Double Talk Detector Parameters

|   | Addre                    | ess                    | Access Mode | Value At Reset | Nominal     | Value |       |       |  |  |  |  |  |
|---|--------------------------|------------------------|-------------|----------------|-------------|-------|-------|-------|--|--|--|--|--|
|   | 0x307-0x30<br>0x387-0x38 |                        | R/W         | See Below      | 8           |       |       |       |  |  |  |  |  |
|   | Bit 7                    | Bit 6                  | Bit 5       | Bit 4          | Bit 3       | Bit 2 | Bit 1 | Bit 0 |  |  |  |  |  |
| 7 |                          | DT_HANGOVER_TIME[15:8] |             |                |             |       |       |       |  |  |  |  |  |
| 8 |                          | DT_HANGOVER_TIME[7:0]  |             |                |             |       |       |       |  |  |  |  |  |
| 9 | DT_DV_THRES[15:8]        |                        |             |                |             |       |       |       |  |  |  |  |  |
| Α |                          |                        |             | DT_DV_TH       | IRES[7:0]   | 40    | 2000  |       |  |  |  |  |  |
| В |                          |                        |             | DT_LONG_TH     | IRESH[15:8] |       | 56    | 26    |  |  |  |  |  |
| С |                          | DT_LONG_THRESH[7:0]    |             |                |             |       |       |       |  |  |  |  |  |
| D |                          | DT_SHORT_THRESH[15:8]  |             |                |             |       |       |       |  |  |  |  |  |
| Ε |                          | DT_SHORT_THRESH[7:0]   |             |                |             |       |       |       |  |  |  |  |  |

DT\_HANGOVER\_TIME (Default 0x0020)

This field defines the inertial delay of the double talk detection algorithm. This delay (in units of 125us) is applied after the loss of double talk detection. If double talk does not reappear during this time then the echo cancellation unit will revert back to acoustic training mode.

DT\_DV\_THRESH \* (Default 0x1998)

Defines the deviation power threshold of double talk detector. This value is used to determine the DT active/inactive condition.

is used to determine the DT active/inactive co

DT\_LONG\_THRESH \* (Default 0x0000)

Minimum power level that constitutes speech over the DT side, as

measured by the long term power estimation algorithm.

DT\_SHORT\_THRESH \* (Default 0x1010)

Minimum power level that constitutes speech over the DT side, as measured by the short term power estimation algorithm.

### 9.4.5 DIVERGENCE

|   | Addre        | ldress A           |   | ccess Mode Value At Reset |  |       |  | Nominal Value |       |  |     |     |       |   |
|---|--------------|--------------------|---|---------------------------|--|-------|--|---------------|-------|--|-----|-----|-------|---|
| 1 | 0x30F(AEC) 0 | DF(AEC) 0x38F(LEC) |   | R/W                       |  | 0x0F  |  |               |       |  |     |     |       |   |
|   | Bit 7        | Bit 6              |   | Bit 5                     |  | Bit 4 |  | Bit 3         | Bit 2 |  | Bit | : 1 | Bit 0 | ) |
| Š | DIVERGENCE   | Reserved           | 1 | DIVERGENCE THRESHOLD      |  |       |  |               |       |  |     |     |       |   |

DIVERGENCE THRESHOLD When the signal power ratio Eout/Lrin > DIVERGENCE\_THRESHOLD (see Figure 9-1), a divergence condition is detected. When a divergence condition is detected, echo cancellation coefficients are cleared and adaptation starts over again. DIVERGENCE\_THRESHOLD is an unsigned hexadecimal value, hence 0x3F is the maximum value (representing decimal 63) and 0x00 is the minimum value (representing decimal 0)

**DIVERGENCE** 

Once a divergence condition is detected, this bit stays high, until a write of any value occurs on this register.

<sup>\*</sup> See 9.2.1Threshold and Power Calculation



# 9.5 Voice Detector Control Registers

# 9.5.1 Function

The acoustic modeling algorithm requires a measure of the instantaneous speech power on the Far End of the echo canceller (this is termed the VD Voice Detect side). To detect the double talk condition an estimate of the long term average power of the VD side is also required.

# 9.5.2 VD LONG TC

| Address      |           | Access Mode | Value At Reset |   | Nominal Value |       |    |         |       |
|--------------|-----------|-------------|----------------|---|---------------|-------|----|---------|-------|
| 0x310(AEC) 0 | x390(LEC) | R/W         | 0x09           |   |               |       | 90 | (m, 47) | · ·   |
| Bit 7        | Bit 6     | Bit 5       | Bit 4          | _ | Bit 3         | Bit 2 |    | Bit 1   | Bit 0 |
| Reserved     | Reserved  | Reserved    | Reserved       |   | VD_L          |       |    | NG_TC   |       |

VD LONG TC

VD long term average power estimation's attacking time constant. This field defines the inertial delay utilized for the long term power estimation of VD. Raising the value of this field reduces the inertia and will make the estimation more responsive whilst lowering the field will cause the power estimation algorithm to be less responsive to bursts of energy on the VD side.

### 9.5.3 VD SHORT TC

| Addre                 | ess   | Access Mode | Value At Reset | Nomi  | Nominal Value |      |         |       |
|-----------------------|-------|-------------|----------------|-------|---------------|------|---------|-------|
| 0x311(AEC) 0x391(LEC) |       | R/W         | 0xBB           |       |               |      |         |       |
| Bit 7                 | Bit 6 | Bit 5       | Bit 4          | Bit 3 | Bit           | 2    | Bit 1   | Bit 0 |
|                       | VD_SF | HORT_TC_H   |                |       | VI            | _SHO | RT_TC_L |       |

VD SHORT TC

VD short term power average estimation attacking time constant. This field defines the inertial delay utilized for the short term power estimation of VD. Raising the value of this field reduces the inertia and will make the estimation more responsive whilst lowering the field will cause the power estimation algorithm to be less responsive to bursts of energy on the VD side.

VD\_SHORT\_TC\_H

When input signal power is higher than the estimated short term power, VD\_SHORT\_TC\_H is used for the subsequent power estimation.

VD\_SHORT\_TC\_L

2

When input signal power is lower or equal to the estimated short term power, VD\_SHORT\_TC\_L is used for the subsequent power estimation.

# 9.5.4 Voice Detector Parameters

| Addre                    | ess   | Access Mode Value At Reset |             | Nominal      | Value |       |       |
|--------------------------|-------|----------------------------|-------------|--------------|-------|-------|-------|
| 0x312-0x31<br>0x392-0x39 |       | R/W                        | See Below   |              |       |       | _     |
| Bit 7                    | Bit 6 | Bit 5                      | Bit 4       | Bit 3        | Bit 2 | Bit 1 | Bit 0 |
|                          |       | (O) ~ ()                   | VD_HANGOVEF | R_TIME[15:8] |       |       |       |

Publication Release Date: March 10, 2011

- 151 -

Revision 2.7



|   | Address | Access Mode           | Value At Reset | Nominal Value |  |  |  |  |  |  |  |  |
|---|---------|-----------------------|----------------|---------------|--|--|--|--|--|--|--|--|
| 3 |         |                       | VD_HANGOVER_1  | FIME[7:0]     |  |  |  |  |  |  |  |  |
| 4 |         |                       | VD_DEV_THRESH  | OLD[15:8]     |  |  |  |  |  |  |  |  |
| 5 |         | VD_DEV_THRESHOLD[7:0] |                |               |  |  |  |  |  |  |  |  |
| 6 |         | VD_LONG_THRESH[15:8]  |                |               |  |  |  |  |  |  |  |  |
| 7 |         |                       | VD_LONG_THRE   | SH[7:0]       |  |  |  |  |  |  |  |  |
| 8 |         |                       | VD_SHORT_THRE  | SH[15:8]      |  |  |  |  |  |  |  |  |
| 9 |         |                       | VD_SHORT_THRI  | ESH[7:0]      |  |  |  |  |  |  |  |  |
| Α |         | CUT_OFF_POWER[15:8]   |                |               |  |  |  |  |  |  |  |  |
| В |         | CUT_OFF_POWER[7:0]    |                |               |  |  |  |  |  |  |  |  |

VD HANGOVER TIME (Default 0x0009)

This field defines the inertial delay of the voice detection algorithm for VD side. Following the detection of the speech on the VD side there is a programmable inertial delay (in units of 125us) following the disappearance of the speech signal. For the duration of this delay period the speech is assumed to remain. If speech does not reappear during this window then the echo cancellation unit will revert back to acoustic training mode.

VD DEV THRESHOLD \* (Default 0x1998)

Defines the deviation power threshold of VD. This value is used to determine VD active/inactive condition.

VD LONG THRESH \* (Default 0x1998)

Defines the minimum power level that constitutes speech over the VD side, as measured by the long term power estimation algorithm.

VD SHORT THRESH \* (Default 0x1038)

Minimum power level that constitutes speech over the VD side, as measured by the short term power estimation algorithm.

CUT OFF POWER\* Configurable bias registers for power estimation. This field defines the

zero reference for the power estimation algorithm.

# VD\_AVE\_TC

(Default 0x1998)

| Address      |           | Access Mode | Value At Reset | t Nominal | Value  |        |       |
|--------------|-----------|-------------|----------------|-----------|--------|--------|-------|
| 0x31D(AEC) 0 | x39D(LEC) | R/W         | 0x0B           |           |        |        |       |
| Bit 7        | Bit 6     | Bit 5       | Bit 4          | Bit 3     | Bit 2  | Bit 1  | Bit 0 |
| Reserved     | Reserved  | Reserved    | Reserved       |           | AVE_SH | ORT_TC | •     |

AVE SHORT TC

Average short term power estimation attacking time constant. This field defines the inertial delay utilized for the average short term power estimation. Raising the value of this field reduces the inertia and will make the estimation more responsive whilst lowering the field will cause the power estimation algorithm to be less responsive to bursts of energy.

See 9.2.1Threshold and Power Calculation



### 9.5.5 VD\_AVE\_THRESH

|   | Ado                   | dress                  | Access Mode | Value At Reset | Nominal   | Value |       |       |
|---|-----------------------|------------------------|-------------|----------------|-----------|-------|-------|-------|
|   | 0x31E-0x31F(<br>0x39F | (AEC) 0x39E-<br>F(LEC) | R/W         | See Below      | 0         |       |       |       |
|   | Bit 7 Bit 6           |                        | Bit 5       | Bit 4          | Bit 3     | Bit 2 | Bit 1 | Bit 0 |
| : |                       |                        |             | VD_AVE_THRE    | ESH[15:8] | TO.   |       |       |
|   |                       |                        |             | VD_AVE_THR     | ESH[7:0]  | ( ) X | 5.    |       |

VD\_AVE\_THRESH \* Minimum average power level that constitutes speech over the VD side, as measured by the short term power estimation algorithm.

# 9.6 AS1 & AS2 Control Registers

### 9.6.1 Function

E F

The acoustic suppression (AS1& AS2) units will insert configurable attenuation factors into the voice path. The attenuation will switch between a maximum and minimum value depending on the presence or absence of speech on the voice path. When speech is present the attenuation will converge towards the minimum value. When speech is absent the attenuation will converge towards the maximum value. Whether speech is present is decided by the Double Talk Detector (DT) and the Voice Detector (VD). The attenuation factor will not switch abruptly between these two factors but will exponentially converge from one to the other. The suppression units are used in half-duplex mode.

### 9.6.2 AS1 BUILD UP TIME

| Addre        | ess         | Access Mode  | Value At Reset | Nominal | Value       |             |       |
|--------------|-------------|--------------|----------------|---------|-------------|-------------|-------|
| 0x320(AEC) 0 | x3A0(LEC)   | R/W          | 0x77           |         |             |             |       |
| Bit 7        | Bit 6 Bit 5 |              | Bit 4          | Bit 3   | Bit 2       | Bit 1       | Bit 0 |
|              | AS1_BUILD   | _UP_TIME_POS | 3              |         | AS1_BUILD_U | IP_TIME_NEG |       |

Time constant determining how fast AS1 gain ramps from max to min gain (AS1\_BUILD\_UP\_TIME\_POS) and from min to max gain (AS1\_BUILD\_UP\_TIME\_NEG). Smaller time constant represents faster change in gain.

### 9.6.3 AS1 MAX ATTEN

|   | Addre                                | ss | Access Mode Value At Reset |           | Nominal    | Value |       |       |
|---|--------------------------------------|----|----------------------------|-----------|------------|-------|-------|-------|
|   | 0x321-0x322(AEC)<br>0x3A1-0x3A2(LEC) |    | R/W                        | 0x1CA8    |            |       |       |       |
|   | Bit 7 Bit 6                          |    | Bit 5                      | Bit 4     | Bit 3      | Bit 2 | Bit 1 | Bit 0 |
| 1 |                                      | 49 | 6                          | AS1_MAX_A | TTEN[15:8] |       |       |       |
| 2 |                                      |    |                            |           |            |       |       |       |

<sup>\*</sup> See 9.2.1Threshold and Power Calculation



Maximum attenuation value will be utilized by the acoustic suppression algorithm. Actual maximum attenuation =  $20 \times \log (AS1\_MAX\_ATTEN / 0xFFFF)$  (dB). The maximum value of this field (0xFFFF) provides an attenuation factor of 1 (0dB – no attenuation). The minimum (0x0000) value provides an attenuation factor of 0.

# 9.6.4 AS2 BUILD UP TIME

| Addre        | ess       | Access Mode   | Value At Reset | Nominal | Value       |             |       |
|--------------|-----------|---------------|----------------|---------|-------------|-------------|-------|
| 0x323(AEC) 0 | x3A3(LEC) | R/W           | 0x77           |         | à           | 1902        |       |
| Bit 7        | Bit 6     | Bit 5         | Bit 4          | Bit 3   | Bit 2       | Bit 1       | Bit 0 |
|              | AS2_BUILE | D_UP_TIME_POS | 3              |         | AS2_BUILD_U | JP_TIME_NEG |       |

Time constant determining how fast AS2 gain (towards target) ramps from max to min gain (AS2\_BUILD\_UP\_TIME\_POS) and from min to max gain (AS2\_BUILD\_UP\_TIME\_NEG). Smaller time constant represents faster change in gain.

### 9.6.5 AS2 MAX ATTEN

|   | Addre                   | ess                | Access Mode | Mode Value At Reset |       | l Value |       |       |  |  |  |
|---|-------------------------|--------------------|-------------|---------------------|-------|---------|-------|-------|--|--|--|
|   | 0x324-0x32<br>0x3A4-0x3 |                    | R/W         | 0x1CA8              |       |         |       |       |  |  |  |
|   | Bit 7                   | Bit 6              | Bit 5       | Bit 4               | Bit 3 | Bit 2   | Bit 1 | Bit 0 |  |  |  |
| 1 |                         |                    |             |                     |       |         |       |       |  |  |  |
| 2 |                         | AS1_MAX_ATTEN[7:0] |             |                     |       |         |       |       |  |  |  |

Maximum attenuation value will be utilized by the acoustic suppression algorithm. Actual maximum attenuation =  $20 \times \log (AS1\_MAX\_ATTEN / 0xFFFF)$  (dB). The maximum value of this field (0xFFFF) provides an attenuation factor of 1 (0dB - no attenuation). The minimum (0x0000) value provides an attenuation factor of 0.

# 9.7 Noise Suppressor Registers

### 9.7.1 Function

Noise suppressor is used to attenuate noise from microphone/line to reduce residue echo from the near end. If power of near-end noise ( $P_{NS}$ ) < NS\_ACTIVE\_THRESHOLD, then Noise Suppressor will attenuate near-end signal by (NS\_INDEX+1) dB. The parameters NS\_FALL\_TC and NS\_RISE\_TC control gain attack and release speeds.



### 9.7.2 NS POWER ATTACK TC

| Addre        | Address Acc    |            | s Mode | Value At Reset |  | Nominal Value |      |       |       |       |
|--------------|----------------|------------|--------|----------------|--|---------------|------|-------|-------|-------|
| 0x328(AEC) 0 | EC) 0x3A8(LEC) |            | R/W    | 0xBB           |  |               |      |       |       |       |
| Bit 7        | Bit 6          |            | Bit 5  | Bit 4          |  | Bit 3         | Bit  | 2     | Bit 1 | Bit 0 |
|              | NS_POV         | CK_TC[3:0] |        |                |  | NS_I          | NDEX | [3:0] |       |       |

NS INDEX

Defines the gain of the noise suppressor Gain = (NS INDEX+1)dB.

NS\_POWER\_ATTACK\_TC

This field defines the time constant of the power estimation of signal that enters the nose suppressor module. Noise suppression is active if noise power is less than noise threshold. Raising the value of this field reduces the inertia and will make the estimation more responsive whilst lowering the field will cause the power estimation algorithm to be less responsive to bursts of energy on the input of the noise suppressor.

### 9.7.3 NS ATTEN TC

| Address |                          |             | Access Mode Value At Reset |       |  | Nominal Value |    |       |           |       |
|---------|--------------------------|-------------|----------------------------|-------|--|---------------|----|-------|-----------|-------|
|         | 0x329(AEC)<br>0x3A9(LEC) |             | R/W                        | 0xBB  |  |               |    |       |           |       |
| Bit 7   | Bit                      | Bit 6 Bit 5 |                            | Bit 4 |  | Bit 3 Bit     |    | 2     | Bit 1     | Bit 0 |
|         | NS_FALL_TC [3:0]         |             |                            |       |  |               | NS | _RISE | _TC [3:0] |       |

NS RISE TC[3:0]

Define the time constant of noise suppressor gain transition from the gain specified by NS INDEX to 0dB. Larger value results in faster transition.

NS FALL TC[3:0]

Define the time constant of Noise suppressor gain transition from 0dB to the gain specified by NS\_INDEX. Larger value results in faster transition.

# 9.7.4 NS ACTIVE THRESHOLD

|   | Address                              | S | Acc    | ess Mode  | Value At R | eset       | Nominal    | Value |       |       |  |
|---|--------------------------------------|---|--------|-----------|------------|------------|------------|-------|-------|-------|--|
|   | 0x32A-0x32B(AEC)<br>0x3AA-0x3AB(LEC) |   |        | R/W       | 0x03E8     |            |            |       |       |       |  |
| Š | Bit 15 Bit 14                        |   | Bit 13 | Bit 12    |            | Bit 11     | Bit 1      | 0     | Bit 9 | Bit 8 |  |
| A | The state                            |   |        | NS_ACTIVE | _THRE      | SHOLD[15:8 | 3]         |       |       |       |  |
| 3 | 10 12                                |   |        |           | NS_ACTIVE  | _THRI      | ESHOLD[7:0 | ]     |       |       |  |

When signal energy is less than NS\_ACTIVE\_THRESHOLD the noise suppressor function will activate. See 9.2.1Threshold and Power Calculation

9.8

# 9.9 Soft Clip (SC) Control Registers

### 9.9.1 Functional Description

The echo cancellation cannot operate effectively on non-linear clipped signals. To reduce non-linearity due to signal clipping, a soft clipping function is available. Soft clipping control is available in both signal path directions on the LEC and on the output path of the AEC. Soft Clip gain is control by SC\_NORMAL\_INDEX and SC\_LOW\_INDEX. Normal Soft Clip gain is SC\_NORMAL\_INDEX. If input signal level is greater than SC\_THRESHOLD the SC gain is changed to SC\_LOW\_INDEX for reducing



clipping distortion.

# 9.9.2 SC CTRL

| 7           | Address                                          |      | Acc  | ess Mode | Value At Reset | Nominal  | Value    |                    |       |
|-------------|--------------------------------------------------|------|------|----------|----------------|----------|----------|--------------------|-------|
| Q           | 0x338 (AEC VD)<br>0x3B0(LEC DT)<br>0x3B8(LEC VD) |      | R/W  |          | 0x00           |          |          |                    |       |
|             | Bit 7                                            | Bit  | 6    | Bit 5    | Bit 4          | Bit 3    | Bit 2    | Bit 1              | Bit 0 |
| 338,<br>3B8 | Reserved                                         | Rese | rved | Reserved | Reserved       | Reserved | Reserved | ADAPTIVE_TH<br>RES | SC_EN |
| 3B0         | Reserved                                         | Rese | rved | Reserved | Reserved       | Reserved | Reserved | Reserved           | SC_EN |

SC EN

- =1, Enable the soft clipping function.
- =0, Disable the soft clipping function.



| Address | Access Mode | Value At Reset | Nominal Value |
|---------|-------------|----------------|---------------|

ADAPTIVE\_THRES

=1, If DT long term line power > DT short term threshold, DT short term threshold automatically increases to same level as DT long term line power.

# 9.9.3 SC NORMAL INDEX

| Address                              | Address |   | ess Mode | Value At Reset | Nominal        | Value |       |       |
|--------------------------------------|---------|---|----------|----------------|----------------|-------|-------|-------|
| 0x339 (AEC<br>0x3B1(LEC<br>0x3B9(LEC | DT)     |   | R/W      | 0x00           |                | 9)    | S. O. |       |
| Bit 7                                | Bit     | 6 | Bit 5    | Bit 4          | Bit 3          | Bit 2 | Bit 1 | Bit 0 |
| Reserved                             |         |   |          | G              | GAIN_INDEX[6:0 | )]    | 12/20 | 16    |

GAIN\_INDEX[6:0]

This value sets the gain in the normal gain region of the soft clip transfer function. Gain selection range is shown in Table 9-2.

Table 9-2 SC Gain Table

| GAIN_INDEX[6:0]<br>HEX Value | Gain           | GAIN_INDEX[6:0]<br>HEX Value | Gain      |
|------------------------------|----------------|------------------------------|-----------|
| 0x00                         | 0 dB (default) | 0x7F                         | - 0.5 dB  |
| 0x01                         | 0.5 dB         | 0x7E                         | - 1.0 dB  |
| 0x02                         | 1.0 dB         | 0x7D                         | - 1.5 dB  |
| 0x03                         | 1.5 dB         | 0x7C                         | - 2.0 dB  |
| 0x04                         | 2.0 dB         | 0x7B                         | - 2.5 dB  |
| 0x05                         | 2.5 dB         | 0x7A                         | - 3.0 dB  |
| 0x06                         | 3.0 dB         | 0x79                         | - 3.5 dB  |
| 0x07                         | 3.5 dB         | 0x78                         | - 4.0 dB  |
| 0x08                         | 4.0 dB         | 0x77                         | - 4.5 dB  |
| 0x09                         | 4.5 dB         | 0x76                         | - 5.0 dB  |
| 0x0A                         | 5.0 dB         | 0x75                         | - 5.5 dB  |
| 0x0B                         | 5.5 dB         | 0x74                         | - 6.0 dB  |
| 0x0C                         | 6.0 dB         | 0x73                         | - 6.5 dB  |
| 0x0D                         | 6.5 dB         | 0x72                         | - 7.0 dB  |
| 0x0E                         | 7.0 dB         | 0x71                         | - 7.5 dB  |
| 0x0F                         | 7.5 dB         | 0x70                         | - 8.0 dB  |
| 0x10                         | 8.0 dB         | 0x6F                         | - 8.5 dB  |
| 0x11                         | 8.5 dB         | 0x6E                         | - 9.0 dB  |
| 0x12                         | 9.0 dB         | 0x6D                         | - 9.5 dB  |
| 0x13                         | 9.5 dB         | 0x6C                         | - 10.0 dB |
| 0x14                         | 10.0 dB        | 0x6B                         | - 10.5 dB |
| 0x15                         | 10.5 dB        | 0x6A                         | - 11.0 dB |
| 0x16                         | 11.0 dB        | 0x69                         | - 11.5 dB |

Publication Release Date: March 10, 2011 Revision 2.7

- 157 -



| 0x17 | 11.5 dB | 0x68 | - 12.0 dB |
|------|---------|------|-----------|
| 0x18 | 12.0 dB | 0x40 | Mute      |

# 9.9.4 SC\_LOW\_INDEX

| Address                              | Address |     | ess Mode | Value At Reset | Nomina      | l Value |         |       |
|--------------------------------------|---------|-----|----------|----------------|-------------|---------|---------|-------|
| 0x33A (AEC<br>0x3B2(LEC<br>0x3BA(LEC | DT)     | R/W |          | 0x00           |             |         | × 2,5/8 |       |
| Bit 7                                | Bit     | 6   | Bit 5    | Bit 4          | Bit 3       | Bit 2   | Bit 1   | Bit 0 |
| Reserved                             |         |     |          | G              | AIN_INDEX[6 | :0]     | 900 G   | 22    |

GAIN\_INDEX[6:0]

This value sets the gain in the low gain region of the soft clip transfer function. Gain selection range is shown in Table 9-2.

# 9.9.5 SC\_THRESH

B C

|   | Address                                                           |  | Access Mode Value At Reset |          | et Nomina  | l Value |       |       |  |  |  |
|---|-------------------------------------------------------------------|--|----------------------------|----------|------------|---------|-------|-------|--|--|--|
|   | 0x33B-0x33C(AEC VD)<br>0x3B3-0x3B4(LEC DT)<br>0x3BB-0x3BC(LEC DT) |  | R/W                        | 0x1000   |            |         |       | -02   |  |  |  |
|   | Bit 15 Bit 14                                                     |  | Bit 13                     | Bit 12   | Bit 11     | Bit 10  | Bit 9 | Bit 8 |  |  |  |
| 3 |                                                                   |  |                            | SC_THRES | HOLD[15:8] |         |       |       |  |  |  |
| • | SC_THRESHOLD[7:0]                                                 |  |                            |          |            |         |       |       |  |  |  |

SC\_THRESHOLD is used to determine the selection of Soft Clip gain. When the input power is larger than SC\_THRESHOLD, SC\_LOW\_INDEX is used to set gain, otherwise SC\_NORMAL\_INDEX is used. See 9.2.1Threshold and Power Calculation

# 9.9.6 SC\_POWER\_ATTACK\_TC

| Address                                         |     | Acc  | ess Mode | Value At Reset |  | Nominal | Value |     |       |       |
|-------------------------------------------------|-----|------|----------|----------------|--|---------|-------|-----|-------|-------|
| 0x33D(AEC VD)<br>0x3B5(LEC DT)<br>0x3BD(LEC VD) |     | R/W  |          | 0x07           |  |         |       |     |       |       |
| Bit 7                                           | Bit | : 6  | Bit 5    | Bit 4          |  | Bit 3   | Bit : | 2   | Bit 1 | Bit 0 |
| Reserved Rese                                   |     | rved | Reserved | Reserved       |  |         |       | TC[ | 3:0]  |       |

This time constant is used to calculate the short term power estimation for soft clipping threshold comparison. Raising the value of this field reduces the inertia and will make the estimation more responsive whilst lowering the field will cause the power estimation algorithm to be less responsive to bursts of energy.



# 9.9.7 SC\_GAIN\_TC

| Address       |                                                 | Acc  | ess Mode | Value At Reset | t | Nominal | Value |       |       |
|---------------|-------------------------------------------------|------|----------|----------------|---|---------|-------|-------|-------|
| 0x3B6(LEC     | 0x33E(AEC VD)<br>0x3B6(LEC DT)<br>0x3BE(LEC VD) |      | R/W      | 0x07           |   |         |       |       |       |
| Bit 7         | Bit                                             | 6    | Bit 5    | Bit 4          |   | Bit 3   | Bit 2 | Bit 1 | Bit 0 |
| Reserved Rese |                                                 | rved | Reserved | Reserved       |   | X       | т     | [3:0] |       |

When the soft clip gain is switched between normal and low gains, an embedded smoothing function is applied to the gain transition. This time constant controls the smoothing. Larger time constant results in slower transition.

# 9.10 State Read back Registers

# 9.10.1 Functional Description

The following registers allow read back of internal parameter measurements to facilitate configuration of echo cancellation blocks.

# 9.10.2 Power Monitor

|   | Addre                     | Address |       |    | Value At Reset | Nominal        | Value |   |       |           |
|---|---------------------------|---------|-------|----|----------------|----------------|-------|---|-------|-----------|
|   | 0x340-0x34<br>0x3C0-0x30  |         | R     |    | See Below      |                |       |   |       |           |
|   | Bit 7                     | Bit 6   | Bit 5 |    | Bit 4          | Bit 3          | Bit 2 | 2 | Bit 1 | Bit 0     |
| 0 |                           |         |       | DT | _SHORT_TER     | M_POWER[15:    | 8]    |   |       |           |
| 1 | DT_SHORT_TERM_POWER [7:0] |         |       |    |                |                |       |   |       |           |
| 2 |                           |         |       | DI | T_LONG_TERM    | 1_POWER [15:8  | 3]    |   |       |           |
| 3 |                           |         |       | D  | T_LONG_TERM    | M_POWER [7:0   | ]     |   |       |           |
| 4 |                           |         |       | D  | T_POWER_DE     | VIATION [15:8] | ]     |   |       |           |
| 5 |                           |         |       |    | DT_POWER_D     | EVIATION [7:0] |       |   |       |           |
| 6 |                           |         |       |    | reserved       |                |       |   |       | DT_ACTIVE |
| 7 |                           |         |       |    | reser          | ved            |       |   |       |           |
| 8 |                           |         |       | VD | _SHORT_TER     | M_POWER[15:    | 8]    |   |       |           |
| 9 |                           |         |       | VE | _SHORT_TER     | M_POWER [7:    | 0]    |   |       |           |
| Α |                           |         |       | VE | D_LONG_TERM    | 1_POWER [15:8  | 8]    |   |       |           |
| В |                           |         |       | V  | D_LONG_TERM    | M_POWER [7:0   | ]     |   |       |           |
| С |                           |         |       | V  | D_POWER_DE     | VIATION [15:8  | ]     |   |       |           |



|   | Address | Access Mode | Value At Reset | Nominal Value |           |
|---|---------|-------------|----------------|---------------|-----------|
| D |         |             | VD_POWER_DEVI  | ATION [7:0]   |           |
| Ε |         |             | reserved       |               | VD_ACTIVE |

SHORT\_TERM\_POWER Short term power estimate on DT/VD side LONG\_TERM\_POWER Long term power estimate on DT/VD side. POWER\_DEVIATION Power deviation estimation on DT/VD side.

DT\_ACTIVE 1: Double-talk activity

VD ACTIVE 1: Voice Detection activity.

# 9.10.3 Signal Monitor

|   | Address                  |                    | Access Mode | Value At Reset    | Nominal | Value |       |       |  |  |
|---|--------------------------|--------------------|-------------|-------------------|---------|-------|-------|-------|--|--|
|   | 0x350-0x35<br>0x3D0-0x3l | 59(AEC)<br>D9(LEC) | R           | See Below         |         |       | 7     |       |  |  |
|   | Bit 7                    | Bit 6              | Bit 5       | Bit 4             | Bit 3   | Bit 2 | Bit 1 | Bit 0 |  |  |
| 0 |                          |                    |             | LRIN[             | 15:8]   |       |       |       |  |  |
| 1 |                          |                    |             | LRIN              | [7:0]   |       |       |       |  |  |
| 2 |                          |                    |             | EOUT              | [15:8]  |       |       |       |  |  |
| 3 |                          |                    |             | EOUT              | [7:0]   |       |       |       |  |  |
| 4 |                          |                    |             | ASOUT             | [15:8]  |       |       |       |  |  |
| 5 |                          |                    |             | ASOU <sup>*</sup> | T[7:0]  |       |       |       |  |  |
| 6 |                          |                    |             | ARIN[             | 15:8]   |       |       |       |  |  |
| 7 | ARIN[7:0]                |                    |             |                   |         |       |       |       |  |  |
| 8 |                          |                    |             | LSOUT             | [15:8]  |       |       |       |  |  |
| 9 | LSOUT[7:0]               |                    |             |                   |         |       |       |       |  |  |

LRIN Signal PCM value at Lrin
EOUT Signal PCM value at Eout
ASOUT Signal PCM value at Asout
ARIN Signal PCM value at Arin
LSOUT Signal PCM value at Lsout

See Figure 9-1: Signal flow through the Acoustic Echo Canceller (AEC) in the speech Processor.

9.11



### 9.12 Automatic Gain Control

AGC function will automatically adjust the gain to the target voice level specified by the parameters AGC\_TARG\_HI and AGC\_TARG\_LO. The actions of the AGC out of the target range are tuned by the parameters AGC\_NOISE\_HI, AGC\_NOISE\_LO, GAIN\_MAX, GAIN\_MIN and the time constant parameters. The operation of the AGC is shown in the figure below.



Figure 9-3 AGC Operation regions.

The AGC is activated when the signal short term energy increases above AGC\_NOISE\_HI. It stays active until the signal short term power drops below AGC\_NOISE\_LO.

Once activated, the AGC enters the Increasing Region 1. This region increases the gain with a time constant AGC\_INC until either signal enters the target region or GAIN\_MAX gain is reached. The goal of this region is to provide a guick reaction to voice energy and supply some gain.

Once into the target region, the gain is incremented with a time constant AGC\_DCY to a maximum gain of GAIN\_MAX, goal of this region is for slower response to keep the signal in target region. If signal amplitude goes above AGC\_TARG\_HI, the AGC goes into Decreasing Region 2.

In Decreasing Region 2, gain is gradually decreased with a time constant of AGC\_ATK to pull signal back into the target region.

If a large signal is applied suddenly, the AGC signal could shoot above AGC\_TARG\_CLIP. In this case the AGC will enter fast decreasing region to quickly reduce its gain.

If the signal is small enough that it is below the AGC\_NOISE\_LO, the AGC treats the signal as noise and will not try to gain it up. The AGC will stay in decreasing region 1 and gain will be gradually decremented by with a time constant of AGC\_DEC down to the initial gain.



Access Mode

In addition to the above, the gain changing action of the AGC can be controlled by the HOLD time. The hold timer is reset whenever the AGC moves from the Decreasing region to the Target region. If a hold time is selected, no gain changes will occur until after this until target time is reached. This has the effect of keeping the gain constant rather than "hunting" for an ideal gain.

Nominal Value

Value At Reset

# 9.12.1 AGC\_CTRL Address

| 0x0360   |          | R/W                                                                                                            | 0x00                                                                                                              |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1902                                                      |                                        |  |  |  |
|----------|----------|----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|----------------------------------------|--|--|--|
| Bit 7    | Bit 6    | Bit 5                                                                                                          | Bit 4                                                                                                             | Bit 3                                                                                                                                                                                                                                     | Bit 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Bit 1                                                     | Bit 0                                  |  |  |  |
| AGC_EN   | AGC_ONLY |                                                                                                                | GAIN_MIN                                                                                                          |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | GAIN_MAX                                                  | 2                                      |  |  |  |
| AGC_EN   |          | Set 1: Ena                                                                                                     | able AGC. S                                                                                                       | Set 0: Disable                                                                                                                                                                                                                            | AGC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | W.                                                        | 9/1                                    |  |  |  |
| AGC_ONLY |          | Set 1: The AEC block is bypassed and AGC operates from AEC input.                                              |                                                                                                                   |                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                           |                                        |  |  |  |
| GAIN_MIN |          | and greate<br>gain will in<br>000: The I<br>001: The I<br>010: The I<br>100: The I<br>101: The I<br>110: The I |                                                                                                                   | NOISE_HI, t<br>GAIN_MIN<br>*log1.25 <sup>2</sup> , wh<br>*log1.50 <sup>2</sup> , wh<br>*log2.75 <sup>2</sup> , wh<br>*log2.25 <sup>2</sup> , wh<br>*log2.25 <sup>2</sup> , wh<br>*log2.50 <sup>2</sup> , wh<br>*log2.75 <sup>2</sup> , wh | he AGC is in the high is 3.9dE high is 7.0dE high is 9.7dE high is 12.0dhigh is 14.1dhigh is 15.9dhigh is 17.6dhigh is 17. | n Increasing  <br>B.<br>B.<br>B.<br>BB.<br>BB.            | than AGC_TAF<br>Region 1. The <i>F</i> |  |  |  |
| GAIN_MAX |          | greater the<br>increase to<br>000: The I<br>001: The I<br>011: The I<br>100: The I                             | an AGC_TAF up to GAIN_M nigh gain is 2 | AG_LO, the AIAX.<br>0*log1.25 <sup>2</sup> , w<br>0*log1.50 <sup>2</sup> , w<br>0*log1.75 <sup>2</sup> , w<br>0*log2.00 <sup>2</sup> , w<br>0*log2.25 <sup>2</sup> , w                                                                    | GC is in Ta<br>thich is 3.9d<br>thich is 7.0d<br>thich is 9.7d<br>thich is 12.0<br>thich is 14.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | rget Region. <sup>·</sup><br>B.<br>B.<br>B.<br>dB.<br>dB. | an AGC_TARG<br>The AGC gain            |  |  |  |
|          |          | 101: The I                                                                                                     | nigh gain is 2                                                                                                    | u~iog2.50 <sup>-</sup> , w                                                                                                                                                                                                                | nich is 15.9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | aB.                                                       |                                        |  |  |  |

The purpose of having Increasing Region 1 and Target Region is to have different converge rates for different levels of input signal.

110: The high gain is 20\*log2.75<sup>2</sup>, which is 17.6dB. 111: The high gain is 20\*log3.00<sup>2</sup>, which is 19.1dB.



# 9.12.2 AGC\_INIT\_GAIN

| Address | Address |                               | ess Mode | Value At Reset | Value At Reset |       | Value |  |  |
|---------|---------|-------------------------------|----------|----------------|----------------|-------|-------|--|--|
| 0x0361  |         |                               | R/W      | 0x88           |                |       |       |  |  |
| Bit 7   | Bit     | Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 |          | Bit 2          | Bit 1          | Bit 0 |       |  |  |
| IG      |         | AGC_INITIAL_GAIN              |          |                |                |       |       |  |  |

AGC\_INITIAL\_GAIN Determines initial gain when the AGC is enabled. In unsigned 4.3 format.

Thus actual initial gain =  $20 \times \log (AGC_INITIAL_GAIN / 0x08) dB$ .

IG Initial Gain bit: if set to 1 then AGC when disabled resets to

AGC INITIAL GAIN

# 9.12.3 AGC GAIN HOLD

| Address | ress Access Mode |                           | Value At Reset | Nominal | Value |             |       |     |
|---------|------------------|---------------------------|----------------|---------|-------|-------------|-------|-----|
| 0x0362  | 0x0362 R/W       |                           | 0x00           |         |       | ~~~         | 9 (0) |     |
| Bit 7   | Bit              | 6 Bit 5 Bit 4 Bit 3 Bit 2 |                | Bit 2   | Bit 1 | Bit 0       |       |     |
|         | AGC_HOLD         |                           |                |         | ,     | AGC_HOLD_CN | IT    | 200 |

AGC\_HOLD The unit of hold time = (2^AGC\_HOLD) \* 1 ms.

AGC\_HOLD\_CNT Together with AGC\_HOLD determines how long the AGC will hold gain

constant after entering target region before increasing gain.

The hold time is AGC HOLD \* AGC HOLD CNT.

### 9.12.4 AGC INC DEC

| Address  | Address Acc |   | ccess Mode Value At Reset |       | Nominal  | Value |         |       |
|----------|-------------|---|---------------------------|-------|----------|-------|---------|-------|
| 0x0363   | R           |   | R/W                       | 0x00  |          |       |         |       |
| Bit 7    | Bit         | 6 | Bit 5                     | Bit 4 | Bit 3    | Bit 2 | Bit 1   | Bit 0 |
| Reserved | AGC_INC     |   |                           |       | Reserved |       | AGC_DEC |       |

AGC INC Determines the time constant at which gain increases when AGC is in

Increasing Region 1.

The increase time is (2^AGC\_INC) \* 4us.

AGC DEC Determines the time constant at which the gain reduces when AGC is in

Decreasing Region 1.

The decrease time is (2^AGC DEC) \* 4us.

# 9.12.5 AGC ATK DCY

| Address  | Address Acce |         | Value At Reset | Nominal  | Value |         |       |
|----------|--------------|---------|----------------|----------|-------|---------|-------|
| 0x0364   | 177          | R/W     | 0x00           |          |       |         |       |
| Bit 7    | Bit 6        | Bit 5   | Bit 4          | Bit 3    | Bit 2 | Bit 1   | Bit 0 |
| Reserved |              | AGC_DCY |                | Reserved |       | AGC_ATK |       |

AGC DCY Controls the decay time constant: that is how fast the gain increases when

AGC is in Target Region.

The DCY time is (2^AGC\_DCY) \* 16us per gain step.

AGC\_ATK Controls the attack time constant: that is how fast the gain decreases when



Address Access Mode Value At Reset Nominal Value

AGC is in Decreasing Region 2.

The ATK time is (2^AGC ATK) \* 16us per gain step.

# 9.12.6 AGC GAIN READ

| Address | Access N      |        | ess Mode | ode Value At Reset |       | nal Value |       |       |  |  |
|---------|---------------|--------|----------|--------------------|-------|-----------|-------|-------|--|--|
| 0x0365  |               | R 0x00 |          |                    | 8 "   | 385       |       |       |  |  |
| Bit 7   | Bit           | 6      | Bit 5    | Bit 4              | Bit 3 | Bit 2     | Bit 1 | Bit 0 |  |  |
|         | AGC_GAIN_READ |        |          |                    |       |           |       |       |  |  |

AGC\_GAIN\_READ Returns the current AGC gain in unsigned 4.4 format. Actual gain = 20 x log (AGC\_GAIN\_READ / 0x10) dB

### **9.12.7 AGC STATE**

| Address         |          | Access Mode |        | Value At Reset | Nominal | Nominal Value |       |       |
|-----------------|----------|-------------|--------|----------------|---------|---------------|-------|-------|
| 0x0366          |          |             | R      | 0x00           |         |               |       | 18.0  |
| Bit 7           | Bit      | 6 Bit 5     |        | Bit 4          | Bit 3   | Bit 2         | Bit 1 | Bit 0 |
| VOICE<br>ACTIVE | HOLD_END |             | LT_MAX | FAST_DEC       | INC     | DCY           | DEC   | ATK   |

VOICE ACTIVE Signal Energy level is higher than AGC NOISE H.

HOLD\_END Indicates AGC hold time has reached 0.
LT\_MAX Indicates AGC gain is less than GAIN\_MAX.
INC Gain is increasing. AGC is in Increasing Region 1.
DCY Gain is increasing. AGC is in Target Region.

DEC Gain is decreasing to unit gain. AGC is in Decreasing Region 1.

ATK Gain is decreasing. AGC is in Decreasing Region 2. FAST DEC Gain is decreasing. AGC is in Fast Decreasing Region.

# 9.12.8 AGC PWR TC

| Address | Address |        | ess Mode | Value At Reset | Nominal | Value    |          |       |
|---------|---------|--------|----------|----------------|---------|----------|----------|-------|
| 0x0367  | 367     |        | R/W      | 0x00           |         |          |          |       |
| Bit 7   | Bit     | 6      | Bit 5    | Bit 4          | Bit 3   | Bit 2    | Bit 1    | Bit 0 |
|         | AGO     | C_ST_F | WR_TC_H  |                |         | AGC_ST_F | PWR_TC_L |       |

AGC\_ST\_PWR\_TC

Determines the time constant for calculating the short term noise energy

used in the AGC block. The short term noise energy is used to determine whether the AGC should be active. Larger time constant makes short term

noise energy responds faster to signal change.

AGC\_ST\_PWR\_TC\_H When input signal power is higher than the estimated short term energy,

AGC ST PWR TC H is used for the subsequent energy estimation.

AGC\_ST\_PWR\_TC\_L When input signal power is lower or equal to the estimated short term

- 164 -

energy, AGC\_ST\_PWR\_TC\_L is used for the subsequent energy estimation.

# 9.12.9 AGC\_PK\_TC

| Address | dress Acc |      | ess Mode | Value At Reset | Nominal  | Value    |       |          |
|---------|-----------|------|----------|----------------|----------|----------|-------|----------|
| 0x0368  | 3         |      | R/W      | 0x00           |          |          |       |          |
| Bit 7   | Bit       | 6    | Bit 5    | Bit 4          | Bit 3    | Bit 2    | Bit 1 | Bit 0    |
| -       | Rese      | rved | Reserved | Reserved       | Reserved | Reserved | AGC_F | PEAK_REL |

AGC\_PEAK\_REL

Determines the release time of peak detector. Peak detector is used to detect the peak of AGC output signal and decide which region the AGC should operate in. The REL time is (2^AGC\_PEAK\_REL) \* 4us.

# 9.12.10AGC PK

|    | Addre       | ess   | Access Mode  | cess Mode Value At Reset |       | Value |       |       |  |  |  |  |
|----|-------------|-------|--------------|--------------------------|-------|-------|-------|-------|--|--|--|--|
|    | 0x369-0x36A |       | R            | 0x00                     |       |       |       | 10    |  |  |  |  |
|    | Bit 7       | Bit 6 | Bit 5        | Bit 4                    | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |  |
| 69 | Reserved    |       | AGC_PK[14:8] |                          |       |       |       |       |  |  |  |  |
| 6A |             |       | AGC_PK[7:0]  |                          |       |       |       |       |  |  |  |  |

AGC PK

Read back for monitoring peak detector value. See 9.2.1Threshold and Power Calculation

# 9.12.11AGC TARGETS

|   | Address    |                   | Acc | ess Mode | Value At Reset | Nominal      | Value |       |       |  |  |  |
|---|------------|-------------------|-----|----------|----------------|--------------|-------|-------|-------|--|--|--|
|   | 0x0370-0x0 | 377               |     | R/W      | 0x00           |              |       |       |       |  |  |  |
|   | Bit 7      | Bit               | 6   | Bit 5    | Bit 4          | Bit 3        | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|   |            |                   |     |          | AGC_TARG       | i_CLIP[15:8] |       |       |       |  |  |  |
| 1 |            |                   |     |          | AGC_TARC       | G_CLIP [7:0] |       |       |       |  |  |  |
|   |            | AGC_TARG_HI[15:8] |     |          |                |              |       |       |       |  |  |  |
| Г |            |                   |     |          | AGC_TAF        | IG_HI [7:0]  |       |       |       |  |  |  |
|   |            |                   |     |          | AGC_TAR        | G_LO[15:8]   |       |       |       |  |  |  |
| Г |            |                   |     |          | AGC_TAR        | G_LO [7:0]   |       |       |       |  |  |  |
|   |            |                   |     |          | AGC_TAR        | G_RB[15:8]   |       |       |       |  |  |  |
|   |            |                   |     |          | AGC_TAR        | G_RB [7:0]   |       |       |       |  |  |  |

AGC\_TARG\_CLIP \*

Sets the very high limit of target region. It is in 0.16 format representing decimal ratio of full scale.

AGC\_TARG\_HI\*

Sets the high limit of target region. It is in 0.16 format representing decimal ratio of full scale.

- 165 -



AGC\_TARG\_LO \* Sets the low limit of target region. It is in 0.16 format representing

decimal ratio of full scale.

AGC\_TARG\_RB \* Read only for monitoring current AGC output signal level.

### 9.12.12AGC NOISE PARAMETERS

|    | Address            | ; / /               | Access Mode | Value At Reset | Nominal   | Value |       |       |  |  |  |
|----|--------------------|---------------------|-------------|----------------|-----------|-------|-------|-------|--|--|--|
|    | 0x0378-0x0         | 37D                 | R/W         | 0x00           |           | à     | 200   |       |  |  |  |
|    | Bit 7              | Bit 6               | Bit 5       | Bit 4          | Bit 3     | Bit 2 | Bit 1 | Bit 0 |  |  |  |
| 78 |                    | AGC_NOISE_BIAS[7:0] |             |                |           |       |       |       |  |  |  |
| 79 |                    | AGC_NOISE_HI[15:8]  |             |                |           |       |       |       |  |  |  |
| 7A |                    | AGC_NOISE_HI[7:0]   |             |                |           |       |       |       |  |  |  |
| 7B |                    |                     |             | AGC_NOISE      | _LO[15:8] |       |       |       |  |  |  |
| 7C |                    |                     |             | AGC_NOIS       | E_LO[7:0] |       |       |       |  |  |  |
| 7D |                    | AGC_NOISE_RB[23:16] |             |                |           |       |       |       |  |  |  |
| 7E |                    |                     |             | AGC_NOISE      | _RB[15:8] |       |       |       |  |  |  |
| 7F | AGC_NOISE_RB [7:0] |                     |             |                |           |       |       |       |  |  |  |

| AGC_NOISE_THD_BIAS | Sets the bias for AGC_NOISE_HI and AGC_NOISE_LO. See below.                 |
|--------------------|-----------------------------------------------------------------------------|
| AGC_NOISE_HI *     | Sets the high limit of noise region, biased by AGC_NOISE_THD_BIAS. The      |
|                    | actual noise high limit is AGC_NOISE_THD_BIAS[7:0] x 2 <sup>-8</sup> +      |
|                    | AGC_NOISE_HI[15:0] x 2 <sup>-24</sup> of the full scale signal.             |
| AGC_NOISE_LO *     | Sets the low limit of noise region, biased by AGC_NOISE_THD_BIAS The        |
|                    | actual noise low limit is AGC_NOISE_THD_BIAS[7:0] x 2 <sup>-8</sup> +       |
|                    | AGC NOISE LO[15:0] x 2 <sup>-24</sup> of the full scale signal.             |
| AGC_NOISE_RB *     | Read only for monitoring current noise power estimate. It is in 0.24 format |

representing decimal ratio of full scale.

# 10. SPI COMMANDS

The ISD61S00 provides SPI commands including: audio play and record commands, device status commands, digital commands, and device configuration commands.

The following section contains a list of all SPI commands and their function.

Table 10-1 SPI Commands

| Instructions | Byte 0 | Byte 1          | Byte 2     | Byte 3 | Byte 4 Byte n | Description             |
|--------------|--------|-----------------|------------|--------|---------------|-------------------------|
| PLAY_VP      | 0xA6   | Index[15:<br>8] | Index[7:0] |        |               | Play Voice Prompt Index |

- 166 -

<sup>\*</sup> See 9.2.1Threshold and Power Calculation

<sup>\*</sup> See 9.2.1Threshold and Power Calculation



| Instructions      | Byte 0 | Byte 1          | Byte 2            | Byte 3            | Byte 4 Byte n            | Description                                                                                                    |
|-------------------|--------|-----------------|-------------------|-------------------|--------------------------|----------------------------------------------------------------------------------------------------------------|
| PLAY_VP@Rn        | 0xAE   | N=07            |                   |                   |                          | Play Voice Prompt; Index @ Rn                                                                                  |
| PLAY_VP_LP        | 0xA4   | Index[15:<br>8] | Index[7:0]        | LoopCnt[1<br>5:8] | LoopCnt[7:0]             | Loop Play Voice Prompt Index                                                                                   |
| PLAY_VP_LP@<br>Rn | 0xB2   | N=07            | LoopCnt[1<br>5:8] | LoopCnt[7:<br>0]  |                          | Loop Play Voice Prompt; Index<br>@ Rn                                                                          |
| STOP_LP           | 0x2E   |                 |                   |                   |                          | Stop the active PLAY_VP_LP or PLAY_VP_LP@Rn                                                                    |
| EXE_VM            | 0xB0   | Index[15:<br>8] | Index[7:0]        |                   |                          | Execute voice macro Index                                                                                      |
| EXE_VM@Rn         | 0xBC   | N=07            |                   |                   |                          | Execute voice macro Index @ Rn                                                                                 |
| REC_MSG           | 0x38   |                 |                   |                   |                          | Record message                                                                                                 |
| REC_MSG@          | 0x3A   | A[23:16]        | A[15:8]           | A[7:0]            |                          | Record message starting at address A.                                                                          |
| PLAY_MSG@         | 0x3C   | A[23:16]        | A[15:8]           | A[7:0]            | Off[15:8], Off[7:0]      | Play message starting at address A offset by OFF sectors.                                                      |
| PLAY_SIL          | 0xA8   | LEN[7:0]        |                   |                   |                          | Play silence for LEN*32ms                                                                                      |
| STOP              | 0x2A   |                 |                   |                   |                          | STOP current playback or record operation.                                                                     |
| ERASE_MSG@        | 0x3E   | A[23:16]        | A[15:8]           | A[7:0]            |                          | Erase message starting at address A.                                                                           |
| SPI_SND_AUD       | 0xAA   | D0[7:0]         | D0[15:8]          | D1[7:0]           | D1[15:8]Dn[7:0] Dn[15:8] | Send 16 bit PCM audio data [low-<br>byte, high-byte] to ISD61S00 via<br>SPI interface when doing<br>REC_MGS    |
| SPI_RCV_AUD       | 0xAC   | D0[7:0]         | D0[15:8]          | D1[7:0]           | D1[15:8]Dn[7:0] Dn[15:8] | Receive 16 bit PCM audio data [low-byte, high-byte] from ISD61S00 via SPI interface when doing PLAY_MSG        |
| SPI_SND_CMP<br>R  | 0xDC   | D0[7:0]         | D1[7:0]           | D2[7:0]           | D3[7:0]Dn[7:0]           | Send compressed audio data to ISD61S00 via SPI interface to direct write to flash while doing REC_MSG/REC_MSG@ |
| SPI_RCV_CMP<br>R  | 0xBE   | D0[7:0]         | D0[15:8]          | D1[7:0]           | D3[7:0]Dn[7:0]           | Direct read compressed audio<br>data in ISD61S00 flash via SPI<br>interface while doing<br>PLAY_MSG@           |
| SPI_SND_DEC       | 0xC0   | D0[7:0]         | D1[7:0]           | D2[7:0]           | D3[7:0]Dn[7:0]           | Send compressed audio data to ISD61S00 via SPI interface for decoding.                                         |
| SPI_RCV_ENC       | 0xC2   | D0[7:0]         | D1[7:0]           | D2[7:0]           | D3[7:0]Dn[7:0]           | Receive compressed (encoded) audio data from ISD61S00 via SPI interface.                                       |



| Instructions | Byte 0             | Byte 1        | Byte 2          | Byte 3  | Byte 4 Byte n                | Description                                                                                           |
|--------------|--------------------|---------------|-----------------|---------|------------------------------|-------------------------------------------------------------------------------------------------------|
| READ_STATUS  | 0x40               | XX            | XX              | XX      | XX                           | Query status of ISD61S00.                                                                             |
| READ_INT     | 0x46               | XX            | XX              | XX      | xx                           | Query status and clear interrupt flags of ISD61S00.                                                   |
| RD_MSG_ADD   | 0x42               | XX            | XX              | xx      | XX, XX                       | Query message address details of audio record. Returns start address A and current sector length LEN. |
| RD_MSG_LEN   | 0x44               | XX            | XX              |         |                              | Query current sector length LEN of current playback or record operation.                              |
| READ_ID      | 0x48               | XX            | XX              | XX      | XX                           | Read device ID of ISD61S00.                                                                           |
| DIG_READ     | 0xA2               | A[23:16]      | A[15:8]         | A[7:0]  | XX, XX                       | Read digital data from address A.                                                                     |
| DIG_WRITE    | 0xA0               | A[23:16]      | A[15:8]         | A[7:0], | D0[7:0], Dn[7:0]             | Write digital data from address A.                                                                    |
| ERASE_MEM    | 0x24               | SA[23:16<br>] | SA[15:8]        | SA[7:0] | EA[23:16], EA[15:8], EA[7:0] | Erase sectors of memory from sector containing SA to sector containing EA.                            |
| CHIP_ERASE   | 0x26               | 0x01          |                 |         |                              | Initiate a mass erase of memory                                                                       |
| CHECKSUM     | 0xF2               | EA[23:16<br>] | EA[15:8]        | EA[7:0] |                              | Calculate checksum from very beginning to the specified end address.                                  |
| PWR_UP       | 0x10               |               |                 |         |                              | Power up ISD61S00                                                                                     |
| PWR_DN       | 0x12               |               |                 |         |                              | Power down ISD61S00                                                                                   |
| WR_CFG_REG   | 0x80 +<br>REG[9:8] | REG[7:0]      | D0[7:0],Dn[7:0] |         |                              | Write data D0Dn to configuration register(s) starting at configuration register REG.                  |
| RD_CFG_REG   | 0x90 +<br>REG[9:8] | REG[7:0]      | XX,XX           |         |                              | Read configuration register(s) starting at configuration register REG.                                |

Each command will be accepted if certain conditions are met as in the following table, or a CMD\_ERR interrupt will be generated and the command ignored.

Table 10-2 Commands vs. Status

|              |         | Bit 7 | Bit 6    | Bit 5 | Bit 4  | Bit 3 | Bit 2  | Bit 1    | Bit 0   |
|--------------|---------|-------|----------|-------|--------|-------|--------|----------|---------|
| Instructions | Op Code | PD    | DBUF_RDY | INT   | RM_FUL | -     | VM_BSY | CBUF_FUL | CMD_BSY |
| PLAY_VP      | 0xA6    | 0     | 1        | Х     | Х      | -     | 0      | 0        | Х       |
| PLAY_VP@Rn   | 0xAE    | 0     | 1        | X     | Х      | -     | 0      | 0        | Х       |
| PLAY_VP_LP   | 0xA4    | 0     | 1        | Х     | Х      | -     | 0      | 0        | Х       |



| PLAY_VP_LP@Rn   0xB2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |     | -    | Y | V    | 1 | 1 N I | RnI∩∨R2 | 101 AV VD ID@D* |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|------|---|------|---|-------|---------|-----------------|
| EXE_VM  0xB0  0  1  x  x  - 0  0  0  EXE_VM@Rn  0xBC  0  1  x  x  - 0  0  0  0  0  EXE_VM@Rn  0xBC  0  1  x  x  - 0  0  0  0  0  REC_MSG  0x38  0  1  x  0  - 0  0  x  REC_MSG@  0x3A  0  1  x  0  - 0  0  x  PLAY_MSG@  0x3C  0  1  x  x  - 0  0  x  PLAY_SIL  0xA8  0  1  x  x  - 0  0  x  FLAY_SIL  0xA8  0  1  x  x  - 0  0  x  STOP  0x2A  0  1  x  x  - x  x  x  ERASE_MSG@  0x3E  0  1  x  x  - x  x  x  SPI_SND_AUD  0xAA  0  1  x  x  - x  x  x  SPI_RCV_AUD  0xAC  0  1  x  x  - x  x  x  SPI_RCV_CMPR  0xBE  0  1  x  x  - x  x  x  SPI_RCV_CMPR  0xBE  0  1  x  x  - x  x  x  SPI_SND_DEC  0xC0  0  1  x  x  - x  x  x  x  SPI_SND_DEC  0xC0  0  1  x  x  - x  x  x  x  SPI_SND_DEC  0xC0  0  1  x  x  - x  x  x  x  SPI_RCV_ENC  0xC2  0  1  x  x  x  x  x  x  READ_INT  0x46  x  x  x  x                                                                                                                                                                                                                                                                                                                                                                                                                        | X X X |     | 1    | Α | 4475 |   |       |         |                 |
| EXE_VM@Rn         0xBC         0         1         x         x         -         0         0         0           REC_MSG         0x38         0         1         x         0         -         0         0         x           REC_MSG@         0x3A         0         1         x         0         -         0         0         x           PLAY_MSG@         0x3C         0         1         x         x         -         0         0         x           PLAY_SIL         0xA8         0         1         x         x         -         0         0         x           STOP         0x2A         0         1         x         x         -         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x                                                                                                                                      | 1 1   |     | -    | X | X    |   |       | 0x2E    | STOP_LP         |
| REC_MSG         0x38         0         1         x         0         -         0         0         x           REC_MSG@         0x3A         0         1         x         0         -         0         0         x           PLAY_MSG@         0x3C         0         1         x         x         -         0         0         x           PLAY_SIL         0xA8         0         1         x         x         -         0         0         x           STOP         0x2A         0         1         x         x         -         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x                                                                                                                               | 0 0 0 | 0   | -    | X | X    | 1 | 0     | 0xB0    | EXE_VM          |
| REC_MSG@ 0x3A 0 1 x 0 - 0 0 x PLAY_MSG@ 0x3C 0 1 x x - 0 0 0 x PLAY_SIL 0xA8 0 1 x x - 0 0 0 x STOP 0x2A 0 1 x x - 0 0 0 x ERASE_MSG@ 0x3E 0 1 x x - 0 0 0 0 SPI_SND_AUD 0xAA 0 1 x x - x x x x SPI_RCV_AUD 0xAC 0 1 x x - x x x x SPI_SND_CMPR 0xDC 0 1 x x - x x x x SPI_SND_CMPR 0xBE 0 1 x x - x x x x SPI_SND_DEC 0xC0 0 1 x x - x x x x SPI_SND_DEC 0xC0 0 1 x x - x x x x SPI_RCV_ENC 0xC2 0 1 x x - 0 0 0 0 READ_STATUS 0x40 x x x x x x READ_INT 0x46 x x x x x x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0 0 0 | 0   | -    | X | X    | 1 | 0     | 0xBC    | EXE_VM@Rn       |
| PLAY_MSG@         0x3C         0         1         x         x         -         0         0         x           PLAY_SIL         0xA8         0         1         x         x         -         0         0         x           STOP         0x2A         0         1         x         x         -         x         x         x           ERASE_MSG@         0x3E         0         1         x         x         -         x         x         x           ERASE_MSG@         0x3E         0         1         x         x         -         0         0         0           SPI_SND_AUD         0xAA         0         1         x         x         -         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x<                                                                                                                              | 0 0 x | 0   | 17   | 0 | X    | 1 | 0     | 0x38    | REC_MSG         |
| PLAY_SIL         0xA8         0         1         x         x         -         0         0         x           STOP         0x2A         0         1         x         x         -         x         x         x           ERASE_MSG@         0x3E         0         1         x         x         -         x         x         x           ERASE_MSG@         0x3E         0         1         x         x         -         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                             | 0 0 x | 0   | ×- , | 0 | X    | 1 | 0     | 0x3A    | REC_MSG@        |
| STOP         0x2A         0         1         x         x         -         x         x           ERASE_MSG@         0x3E         0         1         x         x         -         0         0         0           SPI_SND_AUD         0xAA         0         1         x         x         -         x         x         x           SPI_RCV_AUD         0xAC         0         1         x         x         -         x         x         x           SPI_SND_CMPR         0xDC         0         1         x         x         -         x         x         x           SPI_RCV_CMPR         0xBE         0         1         x         x         -         x         x         x           SPI_RCV_ENC         0xC2         0         1         x         x         -         0         0         0           SPI_RCV_ENC         0xC2         0         1         x         x         -         x         x         x         x           READ_INT         0x46         x         x         x         x         x         x         x         x         x         x         x                                                                                                                                         | 0 0 x | 0   | 1.00 | X | X    | 1 | 0     | 0x3C    | PLAY_MSG@       |
| ERASE_MSG@         0x3E         0         1         x         x         -         0         0         0           SPI_SND_AUD         0xAA         0         1         x         x         -         x         x         x           SPI_RCV_AUD         0xAC         0         1         x         x         -         x         x         x           SPI_SND_CMPR         0xDC         0         1         x         x         -         x         x         x           SPI_RCV_CMPR         0xBE         0         1         x         x         -         x         x         x           SPI_SND_DEC         0xC0         0         1         x         x         -         0         0         0           SPI_RCV_ENC         0xC2         0         1         x         x         -         0         0         0           READ_STATUS         0x40         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x <td< th=""><td>0 0 x</td><td>0</td><td>2</td><td>X</td><td>X</td><td>1</td><td>0</td><td>0xA8</td><td>PLAY_SIL</td></td<>          | 0 0 x | 0   | 2    | X | X    | 1 | 0     | 0xA8    | PLAY_SIL        |
| SPI_SND_AUD         0xAA         0         1         x         x         -         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x                                                                                                                      | x x x | X   | 0    | Х | X    | 1 | 0     | 0x2A    | STOP            |
| SPI_RCV_AUD         0xAC         0         1         x         x         -         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x                                                                                                                      | 0 0 0 | Ø 0 | -3   | Х | X    | 1 | 0     | 0x3E    | ERASE_MSG@      |
| SPI_SND_CMPR         0xDC         0         1         x         x         -         x         x         x           SPI_RCV_CMPR         0xBE         0         1         x         x         -         x         x         x           SPI_SND_DEC         0xC0         0         1         x         x         -         0         0         0           SPI_RCV_ENC         0xC2         0         1         x         x         -         0         0         0           READ_STATUS         0x40         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x <td< th=""><td>x x x</td><td>X</td><td>-</td><td>Х</td><td>X</td><td>1</td><td>0</td><td>0xAA</td><td>SPI_SND_AUD</td></td<> | x x x | X   | -    | Х | X    | 1 | 0     | 0xAA    | SPI_SND_AUD     |
| SPI_RCV_CMPR         0xBE         0         1         x         x         -         x         x           SPI_SND_DEC         0xC0         0         1         x         x         -         0         0         0           SPI_RCV_ENC         0xC2         0         1         x         x         -         0         0         0           READ_STATUS         0x40         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x                                                                                                                          | x x x | X   | -    | Х | X    | 1 | 0     | 0xAC    | SPI_RCV_AUD     |
| SPI_SND_DEC         0xC0         0         1         x         x         -         0         0         0           SPI_RCV_ENC         0xC2         0         1         x         x         -         0         0         0           READ_STATUS         0x40         x         x         x         x         -         x         x         x           READ_INT         0x46         x         x         x         x         x         x         x         x           RD_MSG_ADD         0x42         0         1         x         x         -         x         x         x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | x x x | X   | -    | Х | X    | 1 | 0     | 0xDC    | SPI_SND_CMPR    |
| SPI_RCV_ENC         0xC2         0         1         x         x         -         0         0         0           READ_STATUS         0x40         x         x         x         x         -         x         x         x           READ_INT         0x46         x         x         x         x         -         x         x         x           RD_MSG_ADD         0x42         0         1         x         x         -         x         x         x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | x x x | Х   | -    | Х | Х    | 1 | 0     | 0xBE    | SPI_RCV_CMPR    |
| READ_STATUS         0x40         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x         x                                                                                                                      | 0 0 0 | 0   | -    | Х | X    | 1 | 0     | 0xC0    | SPI_SND_DEC     |
| READ_INT         0x46         x         x         x         x         -         x         x         x           RD_MSG_ADD         0x42         0         1         x         x         -         x         x         x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0 0 0 | 0   | -    | Х | X    | 1 | 0     | 0xC2    | SPI_RCV_ENC     |
| RD_MSG_ADD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | x x x | Х   | -    | Х | Х    | Х | Х     | 0x40    | READ_STATUS     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | x x x | Х   | -    | Х | Х    | Х | Х     | 0x46    | READ_INT        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | x x x | X   | -    | Х | X    | 1 | 0     | 0x42    | RD_MSG_ADD      |
| RD_MSG_LEN   0 x44   0   1   x   x   -   x   x   x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | x x x | X   | -    | Х | X    | 1 | 0     | 0x44    | RD_MSG_LEN      |
| <b>READ_ID</b> 0x48 0 <b>1</b> x x - x x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | x x x | X   | -    | Х | Х    | 1 | 0     | 0x48    | READ_ID         |
| DIG_READ         0xA2         0         1         x         x         -         x         x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | x x x | Х   | -    | Х | Х    | 1 | 0     | 0xA2    | DIG_READ        |
| <b>DIG_WRITE</b> 0xA0 0 1 x x - x x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | x x x | X   | -    | Х | Х    | 1 | 0     | 0xA0    | DIG_WRITE       |
| CHECK_SUM         0xF2         0         1         x         x         0         0         0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0 0 0 | 0   |      | Х | Х    | 1 | 0     | 0xF2    | CHECK_SUM       |
| <b>ERASE_MEM</b> 0x24 0 1 x x - 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0 0 0 | 0   | -    | X | Х    | 1 | 0     | 0x24    | ERASE_MEM       |
| CHIP_ERASE 0x26 0 1 x x - 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0 0 0 | 0   | -    | Х | Х    | 1 | 0     | 0x26    | CHIP_ERASE      |
| PWR_UP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | X X X | х   | -    | Х | Х    | 0 | 1     | 0x10    | PWR_UP          |
| PWR_DN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | X X X | Х   | -    | Х | Х    | 1 | 0     | 0x12    | PWR_DN          |
| WR_CFG_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | X X X | X   | -    | Х | Х    | 1 | 0     | 0x80    | WR_CFG_REG      |
| RD_CFG_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | x x x | X   | -    | Х | Х    | 1 | 0     | 0x90    | RD_CFG_REG      |

# 10.1 Audio Play and Record Commands

This section describes the audio commands that can be sent to the device.



# 10.1.1 Play Voice Prompt

| PLAY_VP                  |                     | - 光             | 8                      |             |
|--------------------------|---------------------|-----------------|------------------------|-------------|
| Byte Sequence:           | Host controller     | 0xA6            | Index[15:8]            | Index[7:0]  |
|                          | ISD61S00            | Status Byte     | Status Byte            | Status Byte |
| Description:             | Play Voice Prompt I | Index           | The The                |             |
| Interrupt<br>Generation: | CMD_ERR if not ac   | cepted. CMD_FIN | when playback is finis | shed.       |

This command initiates a play of a pre-recorded voice-prompt. Before execution of command a valid signal path must be set up and the device must have space in the audio command buffer. After completion of playback, the device will generate an interrupt. The command will be accepted if status bits PD=0, DBUF\_RDY=1, VM\_BSY=0 and CBUF\_FUL=0. If any of these conditions are not met then a CMD\_ERR interrupt will be generated and the command ignored. If command is terminated after the command byte is sent no interrupt will be generated. Once playback is finished a CMD\_FIN interrupt will be generated.

## 10.1.2 Play Voice Prompt @Rn, n = 0 ~ 7

| PLAY_VP@Rn               |                    |                    |                       | 0    |
|--------------------------|--------------------|--------------------|-----------------------|------|
| Byte Sequence:           | Host controller    | 0xAE               | n = 0 ~ 7             | 92.0 |
|                          | ISD61S00           | Status Byte        | Status Byte           |      |
| Description:             | Play Voice Prompt, | Index@Rn           |                       |      |
| Interrupt<br>Generation: | CMD_ERR if not ac  | ccepted. CMD_FIN w | hen playback is finis | hed. |

This command is same as PlayVP except that the 16bit index is stored in Rn,  $n = 0 \sim 7$ .

- R0[7:0] = CFG20, R0[15:8] = CFG21
- R1[7:0] = CFG22, R1[15:8] = CFG23
- R2[7:0] = CFG24, R2[15:8] = CFG25
- R3[7:0] = CFG26, R3[15:8] = CFG27
- R4[7:0] = CFG28, R4[15:8] = CFG29
- R5[7:0] = CFG2A, R5[15:8] = CFG2B
- R6[7:0] = CFG2C, R6[15:8] = CFG2D
- R7[7:0] = CFG2E, R7[15:8] = CFG2F

# 10.1.3 Play Voice Prompt, Loop

| PLAY_VP_LP     | 10 G            |      |             |            |                |               |
|----------------|-----------------|------|-------------|------------|----------------|---------------|
| Byte Sequence: | Host controller | 0xA4 | Index[15:8] | Index[7:0] | LoopCnt[15 :8] | LoopCnt[7: 0] |

- 170 -

# nuvoton

|                          | ISD61S00      | Status Byte                   | Status Byte | Status Byte     | Status Byte | Status Byte |  |
|--------------------------|---------------|-------------------------------|-------------|-----------------|-------------|-------------|--|
| Description:             | Play Voice Pr | Play Voice Prompt Index, Loop |             |                 |             |             |  |
| Interrupt<br>Generation: | CMD_ERR if    | not accepted.                 | CMD_FIN whe | n playback is f | inished.    |             |  |

This command initiates a loop-play of a pre-recorded voice-prompt. Number of play-loops is specified in LoopCnt[15:0]. Setting LoopCnt to 0 makes an endless play, which can only be ended by a STOP or STOP\_LP command. Before execution of command a valid signal path must be set up, and the device must have space in the audio command buffer. After completion of playback, the device will generate an interrupt. The command will be accepted if status bits PD=0, DBUF\_RDY=1, VM\_BSY=0 and CBUF\_FUL=0. If any of these conditions are not met then a CMD\_ERR interrupt will be generated and the command ignored. If command is terminated after the command byte is sent no interrupt will be generated. Once playback is finished a CMD\_FIN interrupt will be generated.

Publication Release Date: March 10, 2011

- 171 - Revision 2.7

# 10.1.4 Play Voice Prompt, Loop, @Rn, n = 0 ~ 7

| PLAY_VP_LP@Rn            |                 | 10.5                   |                |                    |              |
|--------------------------|-----------------|------------------------|----------------|--------------------|--------------|
| Byte Sequence:           | Host controller | 0xB2                   | n = 0 ~ 7      | LoopCnt[15:8       | LoopCnt[7:0] |
|                          | ISD61S00        | Status Byte            | Status Byte    | Status Byte        | Status Byte  |
| Description:             | Play Voice Pro  | mpt, Loop, <i>Inde</i> | ex@Rn          | XX                 |              |
| Interrupt<br>Generation: | CMD_ERR if n    | ot accepted. CN        | MD_FIN when pl | ayback is finished | d.           |

This command is same as Play\_VP\_LP except that the 16bit index is stored in Rn,  $n = 0 \sim 7$ .

- R0[7:0] = CFG20, R0[15:8] = CFG21
- R1[7:0] = CFG22, R1[15:8] = CFG23
- R2[7:0] = CFG24, R2[15:8] = CFG25
- R3[7:0] = CFG26, R3[15:8] = CFG27
- R4[7:0] = CFG28, R4[15:8] = CFG29
- R5[7:0] = CFG2A, R5[15:8] = CFG2B
- R6[7:0] = CFG2C, R6[15:8] = CFG2D
- R7[7:0] = CFG2E, R7[15:8] = CFG2F

### 10.1.5 Stop Loop-Play Command

| STOP_LP                  |                             |                      |                       |                    |
|--------------------------|-----------------------------|----------------------|-----------------------|--------------------|
| Byte Sequence:           | Host controller             | 0x2E                 |                       |                    |
|                          | ISD61S00                    | Status Byte          |                       |                    |
| Description:             | Stop current loop-pl        | ay command           |                       |                    |
| Interrupt<br>Generation: | Command itself do stopping. | es not generate inte | errupt, only those co | ommands that it is |

This command stops any current PLAY\_VP\_LP or PLAY\_VP\_LP@Rn command active in the ISD61S00. The STOP\_LP command does not flush the audio command buffer; that is, any command queued in the buffer when a STOP\_LP is issued will be executed thereafter. When device has finished the active command a CMD\_FIN interrupt will be generated. If there is no active PLAY\_VP\_LP or PLAY\_VP\_LP@Rn command then STOP\_LP will have no effect.

### 10.1.6 Execute Voice Macro

| EXE_VM         |                  |             |             |             |
|----------------|------------------|-------------|-------------|-------------|
| Byte Sequence: | Host controller  | 0xB0        | Index[15:8] | Index[7:0]  |
|                | ISD61S00         | Status Byte | Status Byte | Status Byte |
| Description:   | Play voice macro | Index       |             |             |

- 172 -



| Interrupt   | CMD_ERR if not accepted. CMD_FIN when playback is finished. |
|-------------|-------------------------------------------------------------|
| Generation: |                                                             |

This command initiates the execution of a pre-recorded voice group. After completion of the voice macro the device will generate a CMD\_FIN interrupt. The command will be accepted if status bits PD=0, DBUF\_RDY=1, VM\_BSY=0, CBUF\_FUL=0 and CMD\_BSY=0. If any of these conditions are not met then a CMD\_ERR interrupt will be generated and the command ignored. If command is terminated after the command byte is sent no interrupt will be generated. Once voice macro execution is finished a CMD\_FIN interrupt will be generated.

# 10.1.7 Execute Voice Macro @Rn, n = 0 ~ 7

| EXE_VM@Rn                |                     |                           | 7                    |           |  |  |  |
|--------------------------|---------------------|---------------------------|----------------------|-----------|--|--|--|
| Byte Sequence:           | Host controller     | 0xBC                      | n = 0 ~ 7            |           |  |  |  |
|                          | ISD61S00            | Status Byte               | Status Byte          | 39 ON     |  |  |  |
| Description:             | Play voice macro II | Play voice macro Index@Rn |                      |           |  |  |  |
| Interrupt<br>Generation: | CMD_ERR if not ac   | ccepted. CMD_FIN          | N when playback is t | finished. |  |  |  |

This command is same as EXE\_VM except that the 16bit index is stored in Rn,  $n = 0 \sim 7$ .

- R0[7:0] = CFG20, R0[15:8] = CFG21
- R1[7:0] = CFG22, R1[15:8] = CFG23
- R2[7:0] = CFG24, R2[15:8] = CFG25
- R3[7:0] = CFG26, R3[15:8] = CFG27
- R4[7:0] = CFG28, R4[15:8] = CFG29
- R5[7:0] = CFG2A, R5[15:8] = CFG2B
- R6[7:0] = CFG2C, R6[15:8] = CFG2D
- R7[7:0] = CFG2E, R7[15:8] = CFG2F

# 10.1.8 Record Message

| REC_MSG                  |                                        |                                   |                       |                  |
|--------------------------|----------------------------------------|-----------------------------------|-----------------------|------------------|
| Byte Sequence:           | Host controller                        | 0x38                              |                       |                  |
| NO 26 18                 | ISD61S00                               | Status Byte                       |                       |                  |
| Description:             | Initiates a managed                    | record at first availab           | le location in memory | /.               |
| Interrupt<br>Generation: | CMD_ERR if not a when device fills ava | accepted. CMD_FIN ailable memory. | when recording co     | mplete. FULL_ERR |

This command initiates a record operation. Before execution of command a valid signal path must be set up and the device must have space in the audio command buffer. If device is or becomes full, an interrupt is generated and the FULL\_ERR bit of the interrupt status register is set. Recording is terminated by



issuing a STOP command. After the operation is complete the begin address of the message can be read, along with the number of sectors recorded, with the READ MSG ADDR command.

The command will be accepted if status bits PD=0, DBUF\_RDY=1, VM\_BSY=0 and CBUF\_FUL=0. If any of these conditions are not met then a CMD\_ERR interrupt will be generated and the command ignored. If memory becomes full while recording a FULL\_ERR interrupt will be generated. If device was full before the record was sent then a FULL\_ERR interrupt will be generated and READ\_MSG\_ADDR will return a length of zero. When a record is terminated by a stop command a CMD\_FIN interrupt will be generated once the recording process is complete.

Note, if REC\_MSG\_SEC\_LENGTH[15:0] is 0 (CFG\_REG5E= REC\_MSG\_SEC\_LENGTH[15:8]; CFG\_REG5D= REC\_MSG\_SEC\_LENGTH[7:0]), the REC\_MSG will need CMD STOP to end. If REC\_MSG\_SEC\_LENGTH[15:0] is NOT 0, the REC\_MSG command will automatically end after the number of sectors which set by REC\_MSG\_SEC\_LENGTH[15:0] have been programmed

## 10.1.9 Record Message at Address

| REC_MSG@                 |                                                                                             |                   |                | 32          | ,05         |  |
|--------------------------|---------------------------------------------------------------------------------------------|-------------------|----------------|-------------|-------------|--|
| Byte Sequence:           | Host controller                                                                             | 0x3A              | A[23:16]       | A[15:8]     | A[7:0]      |  |
|                          | ISD61S00                                                                                    | Status Byte       | Status Byte    | Status Byte | Status Byte |  |
| Description:             | Initiate a managed re                                                                       | ecord starting at | sector address | s A/4096    | 18 9        |  |
| Interrupt<br>Generation: | CMD_ERR if not accepted. CMD_FIN when recording complete. ADDR_ERR if invalid address sent. |                   |                |             |             |  |

This command initiates a record operation starting at a specified address. Before execution of command a valid signal path must be set up and the device must have space in the audio command buffer. If device is or becomes full, the RM\_FULL bit of the status register is set. Recording is terminated by issuing a STOP command. After the operation is complete the begin address of the message can be read, along with the number of sectors recorded out with the READ MSG ADDR command.

The command will be accepted if status bits PD=0, DBUF\_RDY=1, VM\_BSY=0 and CBUF\_FUL=0. If any of these conditions are not met then a CMD\_ERR interrupt will be generated and the command ignored. If command is terminated after the command byte is sent no interrupt will be generated. If memory becomes full while recording a FULL\_ERR interrupt will be generated. If device was full before the record was sent then a FULL\_ERR interrupt will be generated and READ\_MSG\_ADDR will return a length of zero. If the address sent is not a blank sector then an ADDR\_ERR interrupt is generated. When a record is terminated by a stop command a CMD\_FIN interrupt will be generated once the recording process is complete.

Note, if REC\_MSG\_SEC\_LENGTH[15:0] is 0 (CFG\_REG5E= REC\_MSG\_SEC\_LENGTH[15:8]; CFG\_REG5D= REC\_MSG\_SEC\_LENGTH[7:0]), the REC\_MSG will need CMD STOP to end. If REC\_MSG\_SEC\_LENGTH[15:0] is NOT 0, the REC\_MSG command will automatically end after the number of sectors which set by REC\_MSG\_SEC\_LENGTH[15:0] have been programmed.

### 10.1.10Play Message at Address

| PLAY_MSG@ | 10 6            |      |          |         |        |           |          |
|-----------|-----------------|------|----------|---------|--------|-----------|----------|
| Byte      | Host controller | 0x3C | A[23:16] | A[15:8] | A[7:0] | OFF[15:8] | OFF[7:0] |



| Sequence:                | ISD61S00                     | Status<br>Byte                                                    | Status<br>Byte | Status<br>Byte | Status<br>Byte | Status Byte  | Status<br>Byte |  |
|--------------------------|------------------------------|-------------------------------------------------------------------|----------------|----------------|----------------|--------------|----------------|--|
| Description:             | Initiate a manage            | Initiate a managed record starting at sector address A/4096 + OFF |                |                |                |              |                |  |
| Interrupt<br>Generation: | CMD_ERR if not address sent. | accepted                                                          | . CMD_FIN      | when playba    | ck comple      | ete. ADDR_ER | R if invalid   |  |

This command initiates a play of a recorded message starting at a specified address, with a specified sector offset. Before execution of command a valid signal path must be set up and the device must have space in the audio command buffer. If an address is sent that is not a valid message an error interrupt is generated with the ADDR\_ERR bit set. Playback can be terminated by issuing a STOP command. After completion of playback, the device will generate an interrupt. This command can be used to randomly access a message at any 4K sector boundary by sending the appropriate offset. The bottom 12 bits of the start address are ignored as messages must begin at a 4Kbyte sector boundary. If command is sent with less than five bytes of data the command is ignored.

The command will be accepted if status bits PD=0, DBUF\_RDY=1, VM\_BSY=0 and CBUF\_FUL=0. If any of these conditions are not met then a CMD\_ERR interrupt will be generated and the command ignored. If command is terminated after the command byte is sent no interrupt will be generated. Once playback is finished a CMD\_FIN interrupt will be generated. If the address sent is not a beginning of message sector then an ADDR\_ERR interrupt will be generated. If the offset is greater than the message length then an ADDR\_ERR interrupt will be generated.

# 10.1.11Play Silence

| PLAY_SIL                 |                      |                                                                  |                  |  |  |  |
|--------------------------|----------------------|------------------------------------------------------------------|------------------|--|--|--|
| Byte Sequence:           | Host controller      | 0xA8                                                             | <i>LEN</i> [7:0] |  |  |  |
|                          | ISD61S00             | Status Byte 0                                                    | Status Byte 0    |  |  |  |
| Description:             | Play silence for LEN | Play silence for LEN*32ms                                        |                  |  |  |  |
| Interrupt<br>Generation: | CMD_ERR if not ac    | CMD_ERR if not accepted. CMD_FIN when silence playback complete. |                  |  |  |  |

This command plays a period of silence to the signal path. Before execution of command a valid signal path must be set up and the device must have space in the audio command buffer. After completion, the device will generate an interrupt. The length of silence played is determined by the data byte, LEN, sent. Silence is played in 32ms increments (at signal path sampling frequency of 32 kHz), total silence played is LEN\*32ms.

The command will be accepted if status bits PD=0, DBUF\_RDY=1, VM\_BSY=0 and CBUF\_FUL=0. If any of these conditions are not met then a CMD\_ERR interrupt will be generated and the command ignored. If command is terminated after the command byte is sent no interrupt will be generated. Once silence play is finished a CMD\_FIN interrupt will be generated.

# 10.1.12Stop Command

| STOP           |                 |             |  |
|----------------|-----------------|-------------|--|
| Byte Sequence: | Host controller | 0x2A        |  |
| 17             | ISD61S00        | Status Byte |  |

- 175 -



| Description:             | Stop current audio command and flush command buffer.                                 |  |  |  |  |
|--------------------------|--------------------------------------------------------------------------------------|--|--|--|--|
| Interrupt<br>Generation: | Command itself does not generate interrupt, only those commands that it is stopping. |  |  |  |  |

This command stops any current audio command active in the ISD61S00. If a PLAY\_MSG@, PLAY\_VP, EXE\_VM or PLAY\_SIL command is active playback is stopped immediately. If a REC\_MSG command is active recording is stopped at the next available byte boundary. The STOP command flushes the audio command buffer, that is any command queued in the buffer when a STOP is issued will not be executed. When device has finished the active command a CMD\_FIN interrupt will be generated. STOP will not stop an ERASE\_MSG or ERASE\_MEM operation. If there is no active command then STOP will have no effect.

# 10.1.13Erase Message at Address

| ERASE_MSG@               |                                                                                         |                                                 |             | (67         |             |  |  |
|--------------------------|-----------------------------------------------------------------------------------------|-------------------------------------------------|-------------|-------------|-------------|--|--|
| Byte Sequence:           | Host controller                                                                         | 0x3E                                            | A[23:16]    | A[15:8]     | A[7:0]      |  |  |
|                          | ISD61S00                                                                                | Status Byte                                     | Status Byte | Status Byte | Status Byte |  |  |
| Description:             | Erase message st                                                                        | Erase message starting at sector address A/4096 |             |             |             |  |  |
| Interrupt<br>Generation: | CMD_ERR if not accepted. CMD_FIN when erase complete. ADDR_ERR if invalid address sent. |                                                 |             |             |             |  |  |

This command erases the message starting at the specified address. The command will be accepted if status bits PD=0, DBUF\_RDY=1, VM\_BSY=0, CBUF\_FUL=0 and CMD\_BSY=0. If any of these conditions are not met then a CMD\_ERR interrupt will be generated and the command ignored. If address sent is not a beginning of message sector an ADDR\_ERR interrupt is generated. Upon completion of command CMD\_FIN interrupt is generated. While the device is erasing no other commands will execute. If a PLAY or REC is sent it is queued in the command buffer and will not execute until the erase is finished. If a DIG\_RD or DIG\_WR command is sent to the device, RDY/BSYB will hold off any data transfer until the ERASE MSG@ has completed.

### 10.1.14SPI Send Audio Data

| SPI_SND_AUD              |                  |                                     |         |          |  |         |          |
|--------------------------|------------------|-------------------------------------|---------|----------|--|---------|----------|
| Byte                     | Host controller  | 0Xaa                                | D0[7:0] | D0[15:8] |  | Dn[7:0] | Dn[15:8] |
| Sequence:                | ISD61S00         | Status Byte                         |         |          |  |         |          |
| Description:             | Write audio data | Write audio data via SPI interface. |         |          |  |         |          |
| Interrupt<br>Generation: | OVF_ERR if RD    | Y/BSY violated.                     |         |          |  |         |          |

This command allows the user to send audio data, in 16bit PCM format, down the SPI interface for feed-through or recording. Before execution of command a valid signal path must be set up.

If recording data (SPI record), then: a signal path must be set up for SPI input to the compressor. A valid record command is then sent followed by the SPI\_SND\_AUD command. Multiple SPI\_SND\_AUD commands can be issued to write data to the ISD61S00. To finish recording a STOP command is sent and device will respond with a CMD\_FIN interrupt. If a memory overflow occurs during the operation a



FULL\_ERR interrupt will be generated and no more data will be accepted. RDY/BSYB will handshake dataflow if device cannot compress and write data at the rate sent down the SPI interface.



Figure 10-1 SPI Record

If sending audio data to the analog outputs (SPI feed-through), then: (1) the path must be set up for SPI input to the signal path. (2) A SPI\_SND\_AUD command is then sent. Multiple SPI\_SND\_AUD commands can be issued to write data to the ISD61S00. (3) To finish sending audio data a STOP command is sent and device will respond with a CMD\_FIN interrupt. RDY/BSYB will handshake dataflow to the sample rate set by the audio configuration register. If host cannot keep up with data rate audio will be corrupt. Once audio data is sent, raise SSB high and device will continue to play zero samples out the signal path until reconfigured or more data is sent.



Figure 10-2 SPI Feed-through

The RDY/BSYB signal will go low whenever the internal FIFO is full. If no path or record operation is set up then RDY/BSYB will not return high until command is terminated. If RDY/BSYB is ignored then an OVF ERR interrupt is generated.

# 10.1.15 SPI Receive Audio Data

SPI RCV AUD



| Byte Sequence:           | Host controller                    | 0xAC            | -26-    |          |  |         |          |
|--------------------------|------------------------------------|-----------------|---------|----------|--|---------|----------|
|                          | ISD61S00                           | Status Byte     | D0[7:0] | D0[15:8] |  | Dn[7:0] | Dn[15:8] |
| Description:             | Read audio data via SPI interface. |                 |         |          |  |         |          |
| Interrupt<br>Generation: | OVF_ERR if RD                      | Y/BSY violated. |         | lla "H   |  |         |          |

This command allows the user to receive audio data, in 16bit PCM format, from the SPI interface for feed-through or playback. Before execution of command a valid signal path must be set up.

If receiving recorded audio data (SPI playback), then: a signal path must be set up for SPI output from the compressor. A valid play command is then sent followed by the SPI\_RCV\_AUD command. Multiple SPI\_RCV\_AUD commands can be sent. To finish receiving data a STOP command is sent and device will generate a CMD\_FIN interrupt. When the end of message is reached a CMD\_FIN interrupt will be generated and zero will be sent as data.



Figure 10-3 SPI Playback

If reading audio data from the analog inputs (feed-through SPI) then: (1) the path must be set up for SPI output from the signal path. (2) A SPI\_RCV\_AUD command is then sent. Multiple SPI\_RCV\_AUD commands can be sent. (3) To finish receiving data a STOP command is sent and device will generate a CMD\_FIN interrupt. RDY/BSYB will handshake dataflow to the sample rate set by the audio configuration register. If host cannot keep up with data rate, audio will be corrupt.



Figure 10-4 Feed-through SPI

The RDY/BSYB signal will go low whenever the internal FIFO is empty. If no path or playback operation is set up then RDY/BSYB will be low until command is terminated. If RDY/BSYB is ignored then an OVF ERR interrupt is generated.

## 10.1.16SPI Send Compressed Audio Data for direct programming to flash

| SPI_SND_CM<br>PR         |                                                                                                                           |                 |         |          |  |         |          |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------|-----------------|---------|----------|--|---------|----------|
| Byte<br>Sequence:        | Host controller                                                                                                           | 0XDC            | D0[7:0] | D0[15:8] |  | Dn[7:0] | Dn[15:8] |
|                          | ISD61S00                                                                                                                  | Status Byte     |         |          |  |         |          |
| Description:             | During REC_MSG or REC_MSG@, Write compressed data via SPI interface to direct program the compressed data to flash memory |                 |         |          |  |         |          |
| Interrupt<br>Generation: | OVF_ERR if RD                                                                                                             | Y/BSY violated. |         |          |  |         |          |

This command allows the user to send compressed audio data, down the SPI interface for recording. Before execution of command make sure CFG\_REG2=0x00 (ENC, DEC, SPI\_IN, SPI\_OUT should be all 0)

A valid REC\_MSG or REC\_MSG@ command is then sent followed by the SPI\_SND\_CMPR command. Multiple SPI\_SND\_CMPR commands can be issued to write data to the ISD61S00. To finish recording a STOP command is sent and device will respond with a CMD\_FIN interrupt. If a memory overflow occurs during the operation a FULL\_ERR interrupt will be generated and no more data will be accepted. RDY/BSYB will handshake dataflow.

# Sample Sequence:

- 1. Make sure CFG REG2=0x00
- 2. Issue REC MSG or REC MSG@ command



- 3. Issue SPI SND CMPR with compressed data
- 4. STOP

# 10.1.17SPI Receive previous REC MSG or REC MSG@ compressed Audio Data stored in

| SPI_RCV_CMP              | The state of the s |                 |         |          |   |         |          |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------|----------|---|---------|----------|
| Byte Sequence:           | Host controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0xBE            |         | (V)      | 0 | 3       |          |
|                          | ISD61S00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Status Byte     | D0[7:0] | D0[15:8] |   | Dn[7:0] | Dn[15:8] |
| Description:             | During PLAY_MSG or PLAY_MSG@, read previous REC_MSG or REC_MSG@ compressed Audio data stored in flash via SPI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |         |          |   |         |          |
| Interrupt<br>Generation: | OVF_ERR if RD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Y/BSY violated. |         |          |   | 10      | (O)Z     |

This command allows the user receiving previous REC\_MSG or REC\_MSG@ compressed Audio Data stored in flash through SPI interface. Before execution of command make sure CFG REG2=0x00 (ENC, DEC, SPI IN, SPI OUT should be all 0)

A valid PLAY MSG@ command is then sent followed by the SPI\_RCV\_CMPR command. Multiple SPI RCV CMPR commands can be sent. To finish receiving data a STOP command is sent and device will generate a CMD FIN interrupt. When the end of message is reached a CMD FIN interrupt will be generated.

# Sample Sequence:

- 1. Make sure CFG REG2=0x00
- 2. Issue PLAY MSG@ command with correct start address
- 3. Issue SPI\_RCV\_CMPR and read compressed data from MISO
- 4. STOP or wait CMD FIN interrupt

Publication Release Date: March 10, 2011

- 180 -

| 10.1.18 | SPI Send | Compressed | Data to | o Decode |
|---------|----------|------------|---------|----------|
|---------|----------|------------|---------|----------|

| SPI_SND_DEC              |                                                |                |         |         |   |         |
|--------------------------|------------------------------------------------|----------------|---------|---------|---|---------|
|                          | Host controller                                | 0xC0           | D0[7:0] | D1[7:0] |   | Dn[7:0] |
| Byte Sequence:           | ISD61S00                                       | Status<br>Byte |         | 23      |   |         |
| Description:             | Write compressed audio data via SPI interface. |                |         |         |   |         |
| Interrupt<br>Generation: | OVF_ERR if RDY/B                               | SYB violate    | d.      | C. C.   | 3 |         |

This command allows the user to send compressed audio data, in a byte formatted bit stream, down the SPI interface to the de-compressor and signal path. Before execution of command a valid signal path must be set up. Valid paths are similar to a standard playback. Multiple SPI\_SND\_DEC commands can be issued to send data to the ISD61S00. To finish decoding a STOP command is sent and device will respond with a CMD\_FIN interrupt. RDY/BSYB will handshake dataflow if device cannot accept any further data for decompression. If host cannot keep up with data rate audio output will be corrupted.



Figure 10-5 SPI Send Compressed Data to Decode

The RDY/BSYB signal will go low whenever the internal FIFO is full. If no path set up to accept audio data then RDY/BSYB will not return high until command is terminated. If RDY/BSYB is ignored then an OVF\_ERR interrupt is generated. The SPI\_SND\_DEC command is accepted if no current play or record operation is active. If command is not accepted a CMD\_ERR interrupt will be generated. It is possible to perform digital memory operations between SPI\_SND\_DEC operations; however care must be taken to maintain the required data rate to avoid audio corruption.

| 10 1 10 | SDI | Receive | Encode | d Data |
|---------|-----|---------|--------|--------|
| 10.1.19 | SPI | neceive | Encode | u Dala |

| SPI_RCV_ENC              |                               | Q.                                            | h -     |         |  |         |
|--------------------------|-------------------------------|-----------------------------------------------|---------|---------|--|---------|
| Duta Caguanaa            | Host controller               | 0xC2                                          |         | 2       |  |         |
| Byte Sequence:           | ISD61S00                      | Status Byte                                   | D0[7:0] | D1[7:0] |  | Dn[7:0] |
| Description:             | Read compressed               | Read compressed audio data via SPI interface. |         |         |  |         |
| Interrupt<br>Generation: | OVF_ERR if RDY/BSYB violated. |                                               |         |         |  |         |

This command allows the user to receive compressed audio data, in a byte formatted bit stream, from the SPI interface for use or storage outside the ISD61S00. Before execution of command a valid recording signal path must be set up such that compressor is active. Multiple SPI\_RCV\_ENC commands can be sent to receive compressed data from the ISD61S00. To finish receiving data a STOP command is sent and device will generate a CMD\_FIN interrupt.



Figure 10-6 SPI Received Encoded Data

RDY/BSYB will handshake dataflow to the sample rate and compression bit rate set by the audio configuration register. If host cannot keep up with data rate compressed audio will be corrupt.

The RDY/BSYB signal will go low whenever the internal FIFO is empty. If no path is set up then RDY/BSYB will be low until command is terminated. If RDY/BSYB is ignored then an OVF\_ERR interrupt is generated. The SPI\_RCV\_ENC command is accepted if no current play or record operation is active. If command is not accepted a CMD\_ERR interrupt will be generated. It is possible to perform digital memory operations between SPI\_RCV\_ENC operations; however care must be taken to maintain the required data rate to avoid audio corruption.



#### 10.2 Device Status Commands.

#### 10.2.1 Read Status

#### Powered up:

| READ_STATUS    |              |                | 1                          |                            |                            |
|----------------|--------------|----------------|----------------------------|----------------------------|----------------------------|
|                | Host         | 0x40           | 0xXX                       | 0xXX                       | 0xXX                       |
| Byte Sequence: | ISD61S00     | Status<br>Byte | Interrupt Status<br>Byte 1 | Interrupt Status<br>Byte 2 | Interrupt Status<br>Byte 3 |
| Description:   | Query device | ce status.     |                            | 5%                         | (C)                        |

#### Powered down:

| READ_STATUS    |                      |                 |      |
|----------------|----------------------|-----------------|------|
| Puto Coguenos  | Host controller      | 0x40            | 0xXX |
| Byte Sequence: | ISD61S00             | Status Byte 80h | 00h  |
| Description:   | Query device status. | •               |      |

This command queries the ISD61S00 device status. For details of device status see Section 7.1. If device is powered up, the four status bytes will be repeated for each four dummy bytes sent to the SPI interface. If device is powered down, only one status byte 80h shows up to the SPI interface at the same time the command is sent. This command is always accepted.

#### 10.2.2 Read Interrupt

| READ_INT       |                                                |                |                            |                            |                            |
|----------------|------------------------------------------------|----------------|----------------------------|----------------------------|----------------------------|
|                | Host                                           | 0x46           | 0xXX                       | 0xXX                       | 0xXX                       |
| Byte Sequence: | ISD61S00                                       | Status<br>Byte | Interrupt Status<br>Byte 1 | Interrupt Status<br>Byte 2 | Interrupt Status<br>Byte 3 |
| Description:   | Query device status and clear interrupt flags. |                |                            |                            |                            |

This command queries the ISD61S00 device status and clears any pending interrupts. After this command the hardware interrupt line will return inactive. The INT bit of the status register along with any status error bits will return inactive. This command is accepted whenever device is powered up.

#### 10.2.3 Read Recorded Message Address Details

| RD_MSG_ADD   | 2)2                                                                                           |         |          |         |        |           |          |
|--------------|-----------------------------------------------------------------------------------------------|---------|----------|---------|--------|-----------|----------|
| Byte         | Host                                                                                          | 0x42    | Χ        | Х       | X      | X         | Χ        |
| Sequence:    | ISD61S00                                                                                      | STATUS0 | A[23:16] | A[15:8] | A[7:0] | LEN[15:8] | LEN[7:0] |
| Description: | Reports the start sector address A/4096 of current message and length, LEN, in 4kByte sectors |         |          |         |        |           |          |

- 183 -



This interrogates the status of the last or current audio record command. It returns the start address so that the user can address a message for playback and also returns the number of sectors that the message has used. It should be issued immediately after a record is initiated to correctly get retrieve the message start address and current length of message. After a STOP command or overflow condition, data is valid for final message length after CMD\_BSY has returned low and before a subsequent audio command is issued.

#### 10.2.4 Read Message Length

| RD_MSG_LEN     |                                                        |             | 90        | 33/ 1/20 |
|----------------|--------------------------------------------------------|-------------|-----------|----------|
| Byte Sequence: | Host controller                                        | 0x44        | 0xXX      | 0xXX     |
|                | ISD61S00                                               | Status Byte | LEN[15:8] | LEN[7:0] |
| Description:   | Read number of sectors played by current PLAY command. |             |           |          |

This command returns the number of sectors played by the current PLAY\_MSG@ command, or recorded by the current REC\_MSG command. This command is used to determine the offset position of the currently playing/recording message. It can be used to resume the playback of a message at a particular sector. For instance, if a PLAY\_MSG(SA, 0) command was sent to start playback of a message from SA then a STOP was sent during playback of the third sector of the message, then RD\_MSG\_LEN would return LEN=3. A subsequent PLAY\_MSG(SA,2) command would restart the playback from the beginning of the sector where playback was stopped; that is send PLAY\_MSG(SA, LEN-1). Now, if a STOP was issued after an additional three sectors of playback (message is now playing the sixth sector), RD\_MSG\_LEN would return LEN=6.

#### 10.2.5 Read ISD61S00 ID

| READ_ID      |                                     |             |         |        |          |        |
|--------------|-------------------------------------|-------------|---------|--------|----------|--------|
| Byte         | Host controller                     | 0x48        | 0xXX    | 0xXX   | 0xXX     | 0xXX   |
| Sequence:    | ISD61S00                            | Status Byte | PART_ID | MAN_ID | MEM_TYPE | DEV_ID |
| Description: | Return memory ID of internal memory |             |         |        |          |        |

This command queries the ISD61S00 to returns four bytes to indicate the ISD61S00 family member and the manufacturer, size and type of internal memory of the device. The four bytes returned are:

PART ID - Identifies which ISD61S00 family member.

MAN ID - Manufacturer ID, which is 0xEF for Winbond.

MEM TYPE - Memory type, which is 0x30.

DEV ID - Device ID indicates the memory size as the table below.

| Capacity | Value |
|----------|-------|
| 4Mb      | 13    |
| 8Mb      | 14    |
| 16Mb     | 15    |



| 32Mb | 16 |
|------|----|
| 64Mb | 17 |

#### 10.3 Digital Memory Commands.

This section describes the 4 digital data commands that can be sent to the device. Digital commands are ones that read, write or erase data directly in the flash memory through a separate interface than the audio data command interface. Digital memory commands other than erase, can occur simultaneously with audio memory commands.

#### 10.3.1 Digital Read

| DIG_READ                 |                             |            |              |           |             | 8 2    |        | 2        |
|--------------------------|-----------------------------|------------|--------------|-----------|-------------|--------|--------|----------|
| Byte                     | Host controller             | 0xA2       | A[23:16]     | A[15:8]   | A[7:0]      | 0xXX   | ···    | 0xXX     |
| Sequence:                | ISD61S00                    | Status     | Status       | Status    | Status      | D0     | (n)    | Dn       |
| Description:             | Initiates a digital         | read of me | emory from a | ddress A[ | 23:0].      |        | J.     | O.Y      |
| Interrupt<br>Generation: | ADDR_ERR if m end of array. | emory pro  | tected or RD | Y/BSYB v  | violated. C | VF_ERI | R if r | ead past |

This command initiates a read of flash memory from address A[23:0]. Following the three address bytes, data can be read out of memory in a sequential manner. The RDY/BSYB signal is used to control flow of data. If RDY/BSYB goes low, transfer must be paused until RDY/BSYB returns high. The user should check RDY/BSYB before every byte is sent/read including the command and address bytes. As many bytes of data as required can be read, command is terminated by raising SSB high, finishing the SPI transaction. If an attempt is made to read past the end of memory, status byte will be read back.

The command will always be accepted and RDY/BSYB will go low until any active digital memory command is complete. If a digital read is attempted in read protected memory, status byte will be read back and an ADDR\_ERR interrupt will be generated. If a read past the end of memory is attempted an OVF\_ERR interrupt will be generated. If RDY/BSYB is violated then zero data will be read back and an ADDR\_ERR interrupt will be generated.

### 10.3.2 Digital Write

| DIG_WRITE                | 2                       |            |              |            |             |          |         |          |
|--------------------------|-------------------------|------------|--------------|------------|-------------|----------|---------|----------|
| Byte                     | Host controller         | 0xA0       | A[23:16]     | A[15:8]    | A[7:0]      | D0       |         | Dn       |
| Sequence:                | ISD61S00                | Status     | Status       | Status     | Status      | Status   |         | Status   |
| Description:             | Initiates a digital     | write to m | emory from a | address A[ | 23:0].      |          |         |          |
| Interrupt<br>Generation: | ADDR_ERR if m of array. | nemory pro | tected or RD | DY/BSYB v  | riolated. O | VF_ERR i | f write | past end |



This command initiates a write to flash memory from address A[23:0]. Following the three address bytes, data can be written to memory in a sequential manner. The RDY/BSYB signal is used to control flow of data. If RDY/BSYB goes low, transfer must be paused until RDY/BSYB returns high. The user should check RDY/BSYB before every byte is sent including the command and address bytes. As many bytes of data as required can be written, command is terminated by raising SSB high, finishing the SPI transaction.

The command will always be accepted and RDY/BSYB will go low until any active digital memory command is complete. If a digital write is attempted in write protected memory, data will be ignored and an ADDR\_ERR interrupt will be generated. If a write is attempted past the end of memory an OVF\_ERR interrupt will be generated. If RDY/BSYB is violated then data will ignored and an ADDR\_ERR interrupt will be generated. Once the SPI transaction has ended the ISD61S00 will finish the flash write operation. When this operation is complete the ISD61S00 will generate a WR\_FIN interrupt. While device is actively writing to flash memory the CMD\_BSY bit will be active.

#### 10.3.3 Erase Memory

| ERASE_MEM                |                 |                                                                                               |               |            |            |             |          | 1 W     |
|--------------------------|-----------------|-----------------------------------------------------------------------------------------------|---------------|------------|------------|-------------|----------|---------|
| Byte<br>Sequence:        | Host controller | 0x24                                                                                          | SA[23:16]     | SA[15:8]   | SA[7:0]    | EA[23:16]   | EA[15:8] | EA[7:0] |
|                          | ISD61S00        | Status                                                                                        | Status        | Status     | Status     | Status      | Status   | Status  |
| Description:             | Erases men      | nory from                                                                                     | sector contai | ning SA to | sector con | taining EA. |          |         |
| Interrupt<br>Generation: | _               | DDR_ERR if memory protected. CMD_ERR if device is busy. CMD_FIN when erase peration complete. |               |            |            |             |          |         |

This erases memory from the sector containing start address SA to the sector containing end address EA. The minimum erase block of internal memory is a 4kByte sector.

The command will be accepted if status bits PD=0, DBUF\_RDY=1, VM\_BSY=0, CBUF\_FUL=0 and CMD\_BSY=0. If any of these conditions are not met then a CMD\_ERR interrupt will be generated and the command ignored. If memory is write protected an ADDR\_ERR interrupt is generated. Upon completion of erase a CMD\_FIN interrupt is generated.

While the device is erasing no other commands will execute. If a PLAY or REC is sent it is queued in the command buffer and will not execute until the erase is finished. If a DIG\_RD or DIG\_WR command is sent to the device, RDY/BSYB will hold off any data transfer until the ERASE\_MEM has completed.

When ERASE\_MEM is in progress, the Status bit 0 CMD\_BSY goes high. Users could poll the status to see if the erasing is done.

#### 10.3.4 Chip Erase

| CHIP_ERASE     | 2)                  |                |             |
|----------------|---------------------|----------------|-------------|
| Byte Sequence: | Host controller     | 0x26           | 0x01        |
| 12             | ISD61S00            | Status Byte    | Status Byte |
| Description:   | Initiate a mass era | ase of memory. |             |



| Interrupt   | CMD_ERR if device is busy and cannot accept command. CMD_FIN when |
|-------------|-------------------------------------------------------------------|
| Generation: | erase operation complete.                                         |

This erases the entire contents of the internal memory.

The command will be accepted if status bits PD=0, DBUF\_RDY=1, VM\_BSY=0, CBUF\_FUL=0 and CMD\_BSY=0. If any of these conditions are not met then a CMD\_ERR interrupt will be generated and the command ignored. If memory is mass erase protected an ADDR\_ERR interrupt is generated. Upon completion of erase a CMD\_FIN interrupt is generated.

While the device is erasing no other commands will execute. If a PLAY or REC is sent it is queued in the command buffer and will not execute until the erase is finished. If a DIG\_RD or DIG\_WR command is sent to the device, RDY/BSYB will hold off any data transfer until the CHIP\_ERASE has completed.

When CHIP\_ERASE is in progress, the Status bit 0 CMD\_BSY goes high. Users could poll the status to see if the erasing is done.

#### 10.3.5 CHECKSUM

| CHECKSUM                 |                            |                |                |               | - 40° (C     |
|--------------------------|----------------------------|----------------|----------------|---------------|--------------|
| Byte Sequence:           | Host controller            | 0xF2           | EA[23:16]      | EA[15:8]      | EA[7:0]      |
|                          | ISD61S00                   | Status Byte    | Status         | Status        | Status       |
| Description:             | Initiate a check           | sum of memory. |                |               |              |
| Interrupt<br>Generation: | CMD_ERR if erase operation |                | and cannot acc | cept command. | CMD_FIN when |

This initiates a 4-byte checksum calculation from the very beginning to the specified end address. The calculated checksum is stored in register 0x59[7:0] 0x5A[15:8] 0x5B[23:16] 0x5C[31:24]. To re-calculate the checksum with a different end address, users have to set register 0x18 bit-0 to clear the registers  $0x59 \sim 0x5C$ .

The command will be accepted if status bits PD=0, DBUF\_RDY=1, VM\_BSY=0, CBUF\_FUL=0 and CMD\_BSY=0

When CHECKSUM is in progress, the Status bit 0 CMD\_BSY goes high. Users could poll the status to see if the CHECK SUM is done.

#### 10.4 Device Configuration Commands.

This section describes commands used to configure the ISD61S00. These commands are used to:

- Set up the clocking regime of the device including clock source and setting the master sample rate.
- Configure the audio signal path.
- Control other processing blocks within the device.
- Configure the compression and sample rate for message recording.



#### 10.4.1 PWR UP - Power up

| PWR_UP         |                  |               | ***              |        |
|----------------|------------------|---------------|------------------|--------|
| Byte Sequence: | Host controller  | 0x10          | 27               |        |
|                | ISD61S00         | Status        |                  |        |
| Description:   | Powers up device | and initiates | the power up seq | uence. |

This command powers up the device. If device already powered up this command has no effect. If powered down, then the internal power up sequence is initiated. If the PU voice macro is present this is executed, otherwise the device defaults to previous clock configuration values or the default values following a reset condition. When power up is complete the PD bit of the status register will go low and the RDY bit high. Until this event no other commands will be accepted by the ISD61S00.

A formal power-up procedure is as follows:

- Send PWR UP command.
- Poll Status until bit-6 DBUF RDY goes high, indicates device is ready to accept commands.
- Poll Status until bit-2 VM\_BSY goes low, indicates voice macro 1 is finished.

#### 10.4.2 PWR\_DN - Power Down

| PWR_DN         |                 |                |                   |            |
|----------------|-----------------|----------------|-------------------|------------|
| Byte Sequence: | Host controller | 0x12           |                   |            |
|                | ISD61S00        | Status         |                   |            |
| Description:   | Powers down the | device after a | any active comman | nds finish |

This command powers down the device. If the device is currently executing a command the device will powers down when the command finishes. If sent while recording, without a STOP command sent first, then device will record until full then power down. If playing or executing a voice macro, device will power down after playback is finished. The PWR\_DN command will not generate an interrupt. PWR\_DN has executed when PD bit of status goes high.

#### 10.4.3 WR CFG REG - Write Configuration Register

| WR_CFG_REG     |                 |                                            |          |    |           |
|----------------|-----------------|--------------------------------------------|----------|----|-----------|
| Byte Sequence: | Host controller | 0x80   REG[9:8]                            | REG[7:0] | D0 | <br>Dn    |
| 2              | ISD61S00        | STATUS0                                    |          |    |           |
| Description:   |                 | tion register CFG[R<br>i[REG+1] with D1 to |          |    | .n can be |

This command loads configuration registers starting at the address specified. If multiple data bytes are sent, additional configuration registers are loaded. See Section 8 for details on configuration registers.

#### 10.4.4 RD CFG REG - Read Configuration Register

|  | RD_CFG_RE | G |
|--|-----------|---|
|--|-----------|---|



| Byte Sequence: | Host controller | 0x90   REG[9:8]                               | REG[7:0] | Χ  | <br>X  |
|----------------|-----------------|-----------------------------------------------|----------|----|--------|
|                | ISD61S00        | STATUS0                                       |          | D0 | <br>Dn |
| Description:   |                 | ation register CFG[F<br>e read sequentially f |          |    |        |

This command reads the configuration register starting at the address specified. If multiple data bytes are sent, additional configuration registers are read. See Section 8 for details on configuration registers.

#### 10.5 Device Power Up Sequence

It is important to sequence the power up configuration of the device to prevent unwanted transients from occurring on audio outputs of the device. A general guideline to achieve this is:

- 4. Send PWR UP command and wait until device ready.
- 5. Send correct clock configuration if not using default values or if not set in PU voice macro.
- 6. Power up CODEC.
- 7. Set mixer path with DAC/ADC muted.
- 8. Power up analog path: power up drivers and DAC with outputs muted, then unmute outputs.
- 9. Unmute DAC/ADC.

A general power down sequence is the reverse of above.

#### 11. ISD61S00 MEMORY MANAGEMENT

The ISD61S00 employs several memory management techniques to make audio recording and playback transparent to the host controller. The address space of the ISD61S00 starts at address zero of the internal memory. This internal memory size can range from 2M to 64M with an erasable sector size of 4kBytes. The following sections will describe the ISD61S00 memory management architecture and the message management functions.

#### 11.1 ISD61S00 Memory Format

The Recording Memory Pointer (RMP) divides the ISD61S00 memory address space into two blocks, Reserved Memory and Recording Memory. The RMP is a two-byte address pointer pointing to a 4kByte memory sector which is the first sector available to users for recording messages. Memory between address zero and the RMP pointer is considered the Reserved Memory for pre-recorded audio (Voice Prompts), pre-programmed macro scripts (Voice Macros), digital read/write access for other applications (User Data) and memory sectors reserved for the first sector of the message recordings and re-recordable pre-recorded messages (Reserved Sectors). The memory between the RMP and the end of memory is considered the Recording Memory allocated for recording messages (Message Recordings).

Figure 11-1 illustrates the memory format with the RMP set at address 4000h or sector 4. Section 11.3 will provide more detail regarding the setting of the RMP.



Figure 11-1 ISD61S00 Memory Format

#### 11.2 Message Management

The message management schemes implemented on the ISD61S00 are:

- Voice Prompts: A collection of pre-recorded audio that can be played back using the PLAY\_VP SPI command or Voice Macros.
- 2. Voice Macros: A powerful voice script allowing users to create custom macros to play Voice Prompts, play message recordings, insert silence and configure the device. Voice Macros are executed with a single SPI command.
- 3. User Data: Memory sectors defined and allocated by the users for use in other applications
- 4. Reserved Sectors: Memory sectors reserved for the first sector of the message recordings (Empty Message) and re-recordable pre-recorded messages (Re-recordable Message).
- 5. Message Recordings: Messages recorded, played and erased "on the fly" by the users.



#### 11.2.1 Voice Prompts

Voice prompts are pre-recorded audio of any length, from short words, phrases or sound effects to long passages of music. These Voice Prompts can be played back in any order as determined by the users and applications. A Voice Prompt consists of two components:

- 1. An index pointing to the pre-recorded audio
- 2. Pre-recorded audio

To play a Voice Prompt, the ISD61S00 use the index of the Voice Prompt to locate and play the prerecorded audio. This approach allows users to easily manage the pre-recorded audio without the need to update the code on the host controller. In addition, the users can store a multitude of pre-recorded audio without the overhead of maintaining a complicated lookup table. To assist customers in creating the Voice Prompts, a software tool, the ISD61S00 Voice Prompt Editor and writer are available for development purposes.

#### 11.2.2 Voice Macros

Voice Macros are a powerful voice script that allows users to customize their own play patterns such as play Voice Prompts, play message, insert silence, change the master sample clock, power-down the device and configure the signal path, including gain and volume control. Voice Macros are executed using a single SPI command and are accessed using the same index structure as Voice Prompts. This means that a Voice Macro (or Voice Prompt) can be updated on the ISD61S00 without the need to update code on the host micro-controller since absolute addresses are not needed.

The following locations have been reserved for three special Voice Macros:

Index 0: Power-On Initialization (POI)

Index 1: Power-Up (PU)
Index 2: GPIO WakeUp

These Voice Macros allow the users to customize the ISD61S00 power-on and power-up procedures and are executed automatically when utilized. The built-in voice macros will be used when they are not utilized. Please see Section 12 for details.

Here is an example to illustrate the usage of the PU Voice Macro.

- WR CFG REG(0x05,0x01)
- WR CFG REG (0x06,0x02)
- FINISH

The above PU Voice Macro will perform the following:

Set up a feed-through path from ANAIN to AUDOUT

The following is the complete list of the commands for Voice Macro:

- WR\_CFG\_REG(reg, n) Set configuration register reg to value n.
- PWR DN Power down the ISD61S00.
- PLAY VP(i) Play Voice Prompt index i.
- PLAY VP@Rn Play Voice Prompt at the index i contained in Register n.
- PLAY VP LP(I) Play Voice Prompt index I with looping
- PLAY VP@Rn LP Play Voice Prompt at the index i contained in Register n with looping
- PLAY\_MSG@(sec-addr) Play message starting at sector address sec-addr

#### nuvoton

- PLAY SIL(n) Play silence for n units. A unit is 32ms at master sampling rate of 32 kHz.
- WAIT\_INT Wait until current play command finishes before executing next macro instruction.
- EXE\_VM Put EXE\_VM in a Voice Macro will force to jump to this VM
- EXE VM@Rn Put EXE VM@Rn in a Macro will force to jump to this VM@Rn
- FINISH Finish the voice macro and exit.

#### 11.2.3 User Data

User Data consist of 4kByte chunks of erasable sectors defined and allocated by the users for use in other applications. The users have the freedom not to allocate or reserve any memory sectors. A software tool, the ISD61S00 Voice Prompt Editor is available to assist customers in allocating such memory.

#### 11.2.4 Reserved Sectors

Reserved sectors consist of 4kByte chunks of erasable sectors reserved for the Empty Messages and Re-recordable Messages. The Empty Message is an empty sector made of a 4kByte memory sector reserved for message recordings. A SPI record command pointing to the Empty Message starts the message recording into the Empty Message and will continue to record messages in the free memory located in Recording Memory if the message recording is over 4kBytes. The users can send a play, erase or record command pointing to the Empty Message to play, erase the entire message or re-record a brand new message.

The Re-recordable Message, a 4kByte memory sector contains message recordings and a sector address pointer (see Section 11.3 for details) pointing to the message sector located in Recording Memory. Unlike the Empty Message where no message has been recorded, the users can play back a complete message by issuing a SPI play command pointing to the Re-recordable Message. The users can also send an erase or record command pointing to the Re-recordable Message to erase the entire message or re-record a brand new message.

#### 11.2.5 Message Recordings

Message Recordings are messages that can be recorded, played and erased "on the fly" by the users. These messages are recorded in 4kByte chunks of erasable sectors with each message—sector containing a header pointing to the next message sector. The ISD61S00's unique message management architecture allows users to record messages without specifying an address. The ISD61S00 will start recording at the first available sector in Recording Memory and continue to record into free memory until memory is full or a STOP command is issued. Upon completion of the record operation, the users need to read back the message sector start address for subsequent playback.

To playback the message recordings, the users need to send a play command pointing to the message sector start address. For partial message playback, the users can send a play command with a sector offset.

To erase the message recordings, the users need to send an erase command pointing to the message sector start address.

A list of commands for Message Recordings are detailed below:

- REC MSG starts a record operation.
- STOP stops current record operation.
- READ\_STATUS wait until record operation is finished as indicated by the CMD\_FIN bit.
- READ\_INT clear the interrupt.

#### nuvoton

- READ\_MSG\_ADD This command returns a three byte starting address (A) of the message along with a two byte sector length. Use A to address the message in subsequent playback operations.
- PLAY MSG@(A) Play back the message.
- READ STATUS poll status until CMD FIN bit is set indicating play has finished.
- READ INT clear the interrupt.
- ERASE MSG@(A) erase the message.
- READ\_STATUS poll status until CMD\_FIN bit is set indicating erase has finished.
- READ\_INT clear the interrupt.

#### 11.3 Memory and Message Headers

The Memory and Message headers are located at the initial bytes of the 4kByte memory sector used to determine the format or function of the memory. The Memory Header stores users' configurable information including the memory protection scheme, the RMP and PMP pointers and the index table including POI, PU and other Voice Macros defined by the users. The Message Header located in both Reserved Sectors and Recording Memory stores the information for the device to determine what memory is available for recording and where the subsequent messages are stored.

#### 11.3.1 Memory Header

Table 11-1 Memory Header

|       | Initial Bytes of the Memory Header |          |           |            |           |           |  |  |  |  |  |
|-------|------------------------------------|----------|-----------|------------|-----------|-----------|--|--|--|--|--|
| Byte0 | Byte1-2                            | Byte3-4  | Bytes5-10 | Bytes11-16 | Byte17-22 | Byte23-28 |  |  |  |  |  |
|       |                                    |          |           |            | GPIO_WA   |           |  |  |  |  |  |
| 0xCX  | RMP[7:0]                           | PMP[7:0] | POI_VM    | PU_VM      | KEUP      | VM/VP[3]  |  |  |  |  |  |

The Memory Header contains at least seventeen bytes located at the beginning of the memory space. Byte0 determines whether or not the memory contains a Reserved Memory block as well as the memory protection scheme is used. Byte1-2 and Byte3-4 store the RMP and PMP pointers respectively. After the PMP, it is the start of the Voice Prompt/Voice Macro index table defined by the users. This table consists of six byte entries that are the start and end address of Voice Prompt or Voice Macro. Byte5-10, Byte11-15 & Byte 17-22 are reserved for the POI, PU and GPIO\_WAKEUP Voice Macro which are the first three entries in this table (index 0, index 1 and index 2) to be executed on power-on initialization, power-up and GPIO\_WAKEUP respectively. If this function is not desired, these entries should be left erased (0xFFFFFF,0xFFFFFF). When a PLAY\_VP(i) or EXE\_VM(i) command is sent to the ISD61S00, it reads the index table entry at address 6i+5 and executes the VP or VM at the address present in the table.

If the first byte Byte0 of the memory header is 0xFF, it means that no Reserved Memory is allocated, no memory protection is enabled and the whole memory will be available for record and playback only. To allocate the Reserve Memory, the bit4 of the Byte0 has to be set to zero. When Reserved Memory is allocated and memory protection is enabled upon users' definition, the both RMP (Recording Memory Pointer) and PMP (Protected Memory Pointer) will then created and stored at Byte1-2 and Byte3-4 of the Memory Header respectively. The ISD61S00 will not attempt to use memory before the RMP for

### nuvoton

message recordings. This memory thus can be used for Voice Prompts, Voice Macros, User Data and Reserved Sectors. The PMP points to the boundary of protected memory and is used in conjunction with the RP, WP and CEP bits to set memory protection indicated below (also see Section 11.6 for details).

Table 11-2 The first byte of the Memory Header

| Memory Header Byte |   |   |   |   |    |    |     |  |  |  |
|--------------------|---|---|---|---|----|----|-----|--|--|--|
| Bit 7              |   |   |   |   |    |    |     |  |  |  |
| 1                  | 1 | 0 | 0 | 1 | RP | WP | CEP |  |  |  |

#### 11.3.2 Message Header

Table 11-3 Message Header

| Message Header Byte                             |     |      |   |   |   |   |     |  |  |
|-------------------------------------------------|-----|------|---|---|---|---|-----|--|--|
| Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 |     |      |   |   |   |   |     |  |  |
| ВОМ                                             | EOM | RSVD | - | - | - | - | - 7 |  |  |

The ISD61S00 adopts a sector-based message management scheme that treats each 4kByte sector as a message frame. Each sector has a header indicating the state of the frame:

- BOM: "0" indicates that this sector is the beginning of a message.
- EOM: "0" indicates that this sector is the end of a message.
- RSVD: "0" indicates that there is a message recorded in this sector or this sector has been reserved for User Data.

Thus the number of the BOMs counted by scanning the Message Header of the Recording Memory will tell the number of the messages recorded in the ISD61S00.

When a sector is not an EOM sector, the next two bytes in the frame are the sector address pointing to the subsequent message. Thus the whole message can be re-composed by tracing sector address until an EOM is found.

It is not recommended to reserve the User Data inside the Recording Memory. However, for those instances where User Data needs to be allocated inside the Recording Memory, it is imperative that the RVSD has set and maintained at "0". Otherwise, there is a risk that the User Data may be over-written by subsequent recordings.

## 11.4 Digital Access of Memory

ISD61S00 memory can be accessed as conventional digital memory using the DIG\_READ and DIG WRTIE SPI commands. This allows the user to:

- Reserve areas of memory for use as digital non-volatile memory as User Data
- Update Voice Prompts and macros (pre-recorded audio) in system.
- Read and verify Voice Prompt memory.
- Read sector headers of memory to determine memory usage.



The digital read and write commands can be issued even while an audio record or playback is in progress. The RDY/BSYB pin governs the flow control for all digital operations.

#### 11.5 Device Erase Commands

ISD61S00 provides several ways to erase the flash memory. The flash memory has a minimum erasable sector size of 4kBvtes. The sector erase command is sent with a start and stop sector address. The ISD61S00 also has commands to mass erase the memory.

#### 11.6 Memory Contents Protection

Under certain circumstances, it is desirable for the users to protect portions of the internal memory from write/erase or interrogation (read). The ISD61S00 provides a method to achieve this by setting a protection memory pointer (PMP) that allows the users to protect internal memory for an address range from the beginning of memory to this sector where PMP is pointed. The type of protection is set by three bits in the memory header byte.

- The CEP (Chip Erase Protect) bit set to zero enables chip erase protection. This prevents a mass erase function, allowing the device to be configured as a write-once part. With the CEP bit set to one, even with write protection enabled, the part can be mass erased. After mass erasure, the initial sector byte defaults to no protection so the device can be re-programmed.
- The WP (Write Protect) bit set to zero enables write protection of the internal memory below the sector pointed to by the PMP. Write protection means that digital write or erase commands will not function in this memory area. This can be used to ensure that audio or data is not inadvertently erased or overwritten. The WP bit does not stop the execution of a REC MSG@ or ERASE MSG@ to messages with BOM headers in this memory.
- The RP (Read Protect) bit set to zero enables read protection of the internal memory below the sector pointed to by the PMP. Read protection means that digital read or audio playback commands through SPI or I<sup>2</sup>S will not function in this memory area. This can be used to ensure that internal memory contents cannot be digitally copied or read.

Memory protection is activated on power-up of the chip. Therefore, each time the user changes the setting of memory protection, the new setting will not be effective until the chip is reset.

#### 12. DEVICE INITIALIZATION

Whenever the ISD61S00 detect as power-on reset condition or a high on the RESET pin of the device it begins a power-on initialization (POI) sequence. Whenever the ISD61S00 receives a power up command (PU) when it is in a power down state, it begins a power-up initialization (PU) sequence. Voice Macros VM(0) and VM(1) are reserved for POI and PU initialization routines. If no reserved memory exists or if the vectors VM(0) or VM(1) are not set, then a default routine is executed. The default sequence for POI is to power-down the ISD61S00. The default PU sequence is to power up and go to IDLE state. 





Figure 12-1 POI and PU Initialization Flowcharts

#### 13. APPLICATION REFERENCE SCHEMATICS

The bottom part of Figure 13-1 shows a reference design for a PSTN interface to the ISD61S00. Two analog signal paths are provided for monitoring audio signals on TIP and RING. The Type 1 CID is for monitoring TIP and RING in an on-hook state to receive CID information. The Type II CID and speech interface is through a balanced configuration along with the output driver for use when the signal path is off-hook. Also included are optional circuits for line detection, ring detection and pulse dialing.

The Figure 13-2 illustrates a reference design for connecting the ISD61S00 to an integrated silicon DAA.

#### 13.1 PCB Layout Guidelines

To gain maximum performance from the ISD61S00 it is important to provide clean analog supplies to the device. Separate Vcca and Vssa returns to the board low impedance point are essential for noise isolation. Good quality low ESR decoupliling capacitors on the supplies along with filter capacitors on Vbg and Vmid are also important for optimal performance. Care in shielding MIC connections from noise sources is imperative, these connections should be as short as possible and shielded with Vssa. The speaker and PO connections carry high currents and should be made as wide as possible. The TI inputs are differential and should be run as a pair and shielded with Vsaa. The flash SPI bus is a high speed serial bus and connections should be routed to the flash device in equal and short traces.

## nuvoton



Figure 13-1 Application Reference Schematic with discrete DAA





Figure 13-2 Application Reference Schematic with integrated Clare DAA

## nuvoton

#### 14. PACKAGE SPECIFICATION

## 14.1 LQFP48L (7x7x1.4mm footprint 2.0mm)





#### 15. ELECTRICAL CHARACTERISTICS

### 15.1 Absolute Maximum Ratings

| Condition                                      | Value                                  |
|------------------------------------------------|----------------------------------------|
| Junction temperature                           | 150°C                                  |
| Storage temperature range                      | -65°C to +150°C                        |
| Lead temperature (soldering – 10 seconds)      | 300°C                                  |
| LQFP-48L Thermal Resistance, typical           | 76 C/W (ASE)<br>60C/W (Greatek) TBD    |
| Voltage applied to any pin                     | $(V_{SS} - 0.3V)$ to $(V_{DD} + 0.3V)$ |
| Input current applied to any digital input pin | +/- 10 mA                              |
| ESD (Human Body Model)                         | 2000 V                                 |
| V <sub>DD</sub> - V <sub>SS</sub>              | -0.5V to +3.63V                        |
| V <sub>DDL</sub> - V <sub>SS</sub>             | -0.5V to + 1.98V                       |
| Device Power Dissipation                       | 0.18 Watt (TBC)                        |

<sup>•</sup> Stresses above those listed may cause permanent damage to the device. Exposure to the absolute maximum ratings may affect device reliability. Functional operation is not implied at these conditions.

### 15.2 Operating Conditions

#### **OPERATING CONDITIONS (INDUSTRIAL PACKAGED PARTS)**

| CONDITIONS                                     | VALUES                                             |
|------------------------------------------------|----------------------------------------------------|
| Operating temperature range (Case temperature) | -40°C to +85°C                                     |
| Supply voltage (V <sub>DD</sub> ) [1]          | +2.7V to +3.6V                                     |
| Ground voltage (V <sub>SS</sub> ) [2]          | 0V                                                 |
| Input voltage (V <sub>DD</sub> ) [1]           | 0V to 3.6V                                         |
| Voltage applied to any pins                    | (V <sub>SS</sub> -0.3V) to (V <sub>DD</sub> +0.3V) |

NOTES:

 $^{[1]}V_{DD}=V_{CCA}=V_{CCD}$   $^{[2]}V_{SS}=V_{SSA}=V_{SSD}$ 



### 15.3 DC Parameters

| PARAMETER                                                   | SYMBOL              | MIN                  | TYP [1]            | MAX          | UNITS | CONDITIONS                                                                                        |
|-------------------------------------------------------------|---------------------|----------------------|--------------------|--------------|-------|---------------------------------------------------------------------------------------------------|
| Supply Voltage                                              | $V_{DD}$            | 2.7                  | 400                | 3.6          | V     |                                                                                                   |
| Input Low Voltage                                           | V <sub>IL</sub>     | V <sub>SS</sub> -0.3 | - 7                | $0.3xV_{DD}$ | V     |                                                                                                   |
| Input High Voltage                                          | V <sub>IH</sub>     | $0.7xV_{DD}$         |                    | $V_{DD}$     | V     |                                                                                                   |
| Schmitt trig. Low to High threshold point                   | VT+                 | 1.49                 | 1.54               | 1.58         | V     | \<br>\(\rightarrow\)                                                                              |
| Schmitt trig. high to low threshold point                   | VT-                 | 1.24                 | 1.29               | 1.34         | V     |                                                                                                   |
| Pull-up resistor                                            | R <sub>PU</sub>     | 38                   | 54                 | 83           | kΩ    | 16                                                                                                |
| Pull-down resistor                                          | $R_{PD}$            | 25                   | 49                 | 110          | kΩ    | SO (0)                                                                                            |
| Output Low Voltage                                          | V <sub>OL</sub>     |                      |                    | 0.4          | V     | $I_{OL} = 3\mu A$                                                                                 |
| INTB Output Low Voltage                                     | $V_{OL1}$           |                      |                    | 0.4          | V     | ST (0)                                                                                            |
| Output High Voltage                                         | V <sub>OH</sub>     | 2.4                  |                    |              | V     | $I_{OH} = -10\mu A$                                                                               |
| Internal logic supply                                       | $V_{DDL}$           | 1.65                 | 1.8                | 1.95         | V     | 200                                                                                               |
| Analog outputs DC level                                     | $V_{DC}$            |                      | AV <sub>DD</sub> / |              | V     | @ +27C                                                                                            |
| Half supply reference                                       | $V_{MIB}$           |                      | 1.65               |              | V     | AV <sub>DD</sub> = 3.3V @ +27C                                                                    |
| Bandgap reference                                           | $V_{BG}$            |                      | 1.218              |              | V     | AV <sub>DD</sub> = 3.3V @ +27C                                                                    |
| Operating Current<br>(outputs loaded: 8 Ohm<br>120 Ohm)     | I <sub>DD_MAX</sub> |                      | 150                |              | mA    | AV <sub>DD</sub> = 3.6V, Loaded,<br>Sampling freq = 8 kHz,<br>all blocks enabled, full<br>scale.  |
| Operating Current<br>(outputs not loaded: 8<br>Ohm 120 Ohm) | I <sub>DD_MAX</sub> |                      | 45                 |              | mA    | AV <sub>DD</sub> = 3.6V, No load,<br>Sampling freq = 8 kHz,<br>all blocks enabled, full<br>scale. |
| Standby Current                                             | I <sub>SB</sub>     |                      | 11                 | 20           | μΑ    | AV <sub>DD</sub> = 3.6V @ +27C                                                                    |
| Input Leakage Current                                       | I <sub>IL</sub>     |                      |                    | ±10          | μΑ    | Force AV <sub>DD</sub>                                                                            |

Notes: [1] Conditions V<sub>DD</sub>=3.3V, T<sub>A</sub>=25°C unless otherwise stated



### 15.4 Analog Transmission Characteristics

AVDD=3.3V ;  $V_{SS}=0V$ ;  $T_A=+27^{\circ}C$ ; All ADC tests using Auxiliary input mode @ 0dB gain

| PARAMETER                                   | PARAMETER SYM CONDITION |                                                              | TYP                 | TRANSMIT<br>(ADC) |       | REC<br>(D/  | UNIT  |        |
|---------------------------------------------|-------------------------|--------------------------------------------------------------|---------------------|-------------------|-------|-------------|-------|--------|
|                                             |                         |                                                              |                     | MIN               | MAX   | MIN         | MAX   |        |
| DC level                                    | V <sub>DC</sub>         | DC level on the outputs SPP – SPN; POP - PON                 | AV <sub>DD</sub> /2 |                   | 177-  | 1.35        | 1.8   | ٧      |
| Full Scale Level                            | T <sub>XMAX</sub>       | ADC (single ended) DAC (differential)                        | 1.35<br>2.7         | 1.05<br>2.1       |       | 1.05<br>2.1 |       | $V_PK$ |
| Absolute Gain                               | G <sub>ABS</sub>        | -3dBFS @ 1020 Hz,<br>AVDD =3.3V; T <sub>A</sub> =+25°C;      | 0                   | -0.40             | +0.40 | -0.40       | +0.40 | dB     |
| Absolute Gain variation with Supply Voltage | G <sub>ABSS</sub>       | AVDD=3.13V - 3.47V; - 3dBFS @ 1020 Hz; T <sub>A</sub> =+25°C | 0                   | -0.50             | +0.50 | -0.50       | +0.50 | dB     |

### 15.5 Analog Distortion and Noise Parameters

All ADC tests using Auxiliary input mode @ 0dB gain

#### 15.5.1 8kHz sampling

AVDD=3.3V;  $V_{SS}$ =0V;  $T_A$ =+27°C; 8kHz sampling, high OSR selected (0x040[5]=1'b1), dither turned off (0x151[0]=1'b0, 0x141[0]=1'b0)

| PARAMETER                    | SYM               | CONDITION                                                 | TRA | NSMIT ( | A/D) | RECEIVE (D/A) |      | UNIT |      |
|------------------------------|-------------------|-----------------------------------------------------------|-----|---------|------|---------------|------|------|------|
| PANAMETER                    | STIVI             | CONDITION                                                 | MIN | TYP     | MAX  | MIN           | TYP  | MAX  | ONLI |
| Signal to Noise<br>Ratio     | SNR               | Idle channel<br>A-weighted                                | 80  | 90      |      | 80            | 90   |      | dB   |
| Total Harmonic<br>Distortion | THD               | -3dBFS @ 1020 Hz,<br>8Ohm speaker load<br>A-weighted      |     | -80     | -75  |               | -70  | -60  | dB   |
| Frequency<br>Response        | F <sub>low</sub>  | -3dB Low pass cut-off                                     |     | 3.36    |      |               | 3.36 |      | kHz  |
| Power Supply<br>Rejection    | PSRR <sub>A</sub> | V <sub>CCA</sub> ; 35mVrms DC to<br>3.4 kHz<br>A-weighted |     | 50      |      |               | 50   |      | dB   |

Publication Release Date: March 10, 2011 Revision 2.7

- 202 -



#### 15.5.2 16kHz sampling

AVDD=3.3V;  $V_{SS}=0V$ ;  $T_A=+27^{\circ}C$ ; 8kHz sampling, high OSR selected (0x040[5]=1'b1), dither turned off (0x151[0]=1'b0, 0x141[0]=1'b0)

| PARAMETER                    | SYM               | CONDITION                                                 | TRA | NSMIT ( | A/D) | RECEIVE (D/A) |      |     | UNIT |
|------------------------------|-------------------|-----------------------------------------------------------|-----|---------|------|---------------|------|-----|------|
| PARAMETER                    | STIVI             | CONDITION                                                 | MIN | TYP     | MAX  | MIN           | TYP  | MAX | UNIT |
| Signal to Noise<br>Ratio     | SNR               | Idle channel A-weighted                                   | 80  | 90      | 57   | 80            | 90   |     | dB   |
| Total Harmonic<br>Distortion | THD               | -3dBFS @ 1020 Hz,<br>8Ohm speaker load<br>A-weighted      | 1   | -80     | -75  |               | -70  | -60 | dB   |
| Frequency<br>Response        | F <sub>low</sub>  | -3dB Low pass cut-off                                     |     | 6.73    |      |               | 6.73 |     | kHz  |
| Power Supply<br>Rejection    | PSRR <sub>A</sub> | V <sub>CCA</sub> ; 35mVrms<br>DC to 6.8 kHz<br>A-weighted | 1   | 50      |      | 1             | 50   |     | dB   |

## 15.6 SPI Timing



Figure 15-1 SPI Timing



| SYMBOL             | DESCRIPTION                                                      | MIN | TYP | МАХ | UNIT |
|--------------------|------------------------------------------------------------------|-----|-----|-----|------|
| T <sub>SCK</sub>   | SCLK Cycle Time                                                  | 100 |     |     | ns   |
| T <sub>SCKH</sub>  | SCLK High Pulse Width                                            | 45  |     |     | ns   |
| T <sub>SCKL</sub>  | SCLK Low Pulse Width                                             | 45  |     |     | ns   |
| T <sub>RISE</sub>  | Rise Time for All Digital Signals                                | 5-3 | 75- | 10  | ns   |
| T <sub>FALL</sub>  | Fall Time for All Digital Signals                                | 27  | 10  | 10  | ns   |
| T <sub>SSBS</sub>  | SSB Falling Edge to 1 <sup>st</sup> SCLK Falling Edge Setup Time | 60  | 100 | (J) | ns   |
| T <sub>SSBH</sub>  | Last SCLK Rising Edge to SSB Rising Edge Hold Time               | 30  | 2   | 3   | ns   |
| T <sub>SSBHI</sub> | SSB High Time between SSB Lows                                   | 50  |     | (e) | ns   |
| T <sub>MOS</sub>   | MOSI to SCLK Rising Edge Setup Time                              | 45  |     |     | ns   |
| T <sub>MOH</sub>   | SCLK Rising Edge to MOSI Hold Time                               | 15  |     |     | ns   |
| $T_{ZMID}$         | Delay Time from SSB Falling Edge to MISO Active                  |     |     | 12  | ns   |
| T <sub>MIZD</sub>  | Delay Time from SSB Rising Edge to MISO Tri-state                |     |     | 12  | ns   |
| T <sub>MID</sub>   | Delay Time from SCLK Falling Edge to MISO                        |     |     | 40  | ns   |
| T <sub>CRBD</sub>  | Delay Time from SCLK Rising Edge to RBB Falling Edge             |     |     | 12  | ns   |
| T <sub>RBCD</sub>  | Delay Time from RBB Rising Edge to SCLK Falling Edge             | 0   |     |     | ns   |

## 15.7 Recommended Clock/Crystal Specification

The following crystal or external master clock specifications are recommended for a correct operation.

| William Province          |      | Limit valu | ies    | TT94 | C 1'4'           |
|---------------------------|------|------------|--------|------|------------------|
| Parameter                 | Min. | Typ.       | Max.   | Unit | Condition        |
| Frequency                 | 7.56 | 12.288     | 32.768 | MHz  | Fundamental mode |
| Load capacitance          |      | 18         |        | pF   |                  |
| Dynamic capacitance Cc    |      | 22.12      |        | fF   |                  |
| Resonance resistance Rc   |      | 40         |        | Ω    |                  |
| Electrostatic capacitance |      | 5.1        |        | pF   |                  |





#### 15.8 Dual Tone Alert Signal (CAS)

AC Electrical Characteristics – Dual Tone Alert Signal Detection

| DESCRIPTION                        | SYM.           | MIN           | TYP  | MAX           | UNITS      | NO<br>TEST        |
|------------------------------------|----------------|---------------|------|---------------|------------|-------------------|
| Low tone frequency                 | $f_L$          | 900           | 2130 |               | Hz         |                   |
| High tone frequency                | f <sub>H</sub> | ~             | 2750 | il.           | Hz         |                   |
| Frequency deviation acceptation    |                | ± 1.0         | 6.2  | ± 3.0         | %          | 1                 |
| Frequency deviation rejection      |                | ± 3.5         | 11/0 | 15/20         | %          | 2                 |
| Accept signal level per tone       |                | -40<br>-37.78 | )~   | -2<br>0.22    | dBV<br>dBm | S/N=20<br>3, 5, 7 |
| Reject signal level per tone       |                |               |      | -46<br>-43.78 | dBV<br>dBm | S/N=20<br>4, 5, 7 |
| Positive and negative Twist accept |                | -10           |      | 10            | dB         | S/N=20<br>6, 7    |
| Signal to Noise Ratio              |                | 20            |      |               | dB         | 5, 6, 7           |

#### NOTES:

- 1. The range within which tones are accepted.
- 2. The range outside of which tones are rejected.
- 3. This applies BT specification that has covered the requirements of Bell core.
- 4. This applies MITEL MT8843 specification. Winbond W91030A: -44 dBm, newave NW6006: -47 dBV and CLI CMX602A: -46 dBV.
- 5. These characteristics are for AVDD=3.3V and 25°C.
- 6. Both tones have the same amplitude and at the nominal frequencies.

$$Twist = 20 log \left( \frac{f_{_H} amplitude}{f_{_L} amplitude} \right)$$

6. Band limited random noise 300~3400 Hz. Measurement valid only when the tone is present.

AC Timing Characteristics – Dual Tone Alert Signal Detection

| Symb<br>ol         | DESCRIPTION                      | MIN | TYP  | MAX | UNITS | NOTES |
|--------------------|----------------------------------|-----|------|-----|-------|-------|
| t <sub>CASDP</sub> | Alert signal present detect time | 0.5 | 1.88 | 10  | ms    | 1     |
| t <sub>CASDA</sub> | Alert signal absent detect time  | 0.5 | 1.46 | 10  | ms    | 2     |

#### NOTES:

- 1.  $t_{CASDP}\ \ \,$  Typical time corresponding to 4 cycles of low tone
- 2.  $t_{CASDA}$  Typical time corresponding to 4 cycles of high tone



## 15.9 FSK Detection - 1200baud Bell 202, ITU V.23, 300 baud Bell 103, ITU V.21

AC Electrical Characteristics – FSK Detection

| DESCRIPTION                                     | SYM.        | MIN              | TYP          | MAX              | UNITS      | NOTES         |
|-------------------------------------------------|-------------|------------------|--------------|------------------|------------|---------------|
| Input frequency detection                       |             |                  |              | Dr. T            |            |               |
| Bell 202 '1' (Mark)                             | $f_{MARK}$  | 1188             | 1200         | 1212             | Hz         |               |
| Bell 202 '0' (Space)                            | $f_{SPACE}$ | 2178             | 2200         | 2222             | 25.        |               |
| ITU-T V.23 '1' (Mark)<br>ITU-T V.23 '0' (Space) |             | 1280.5<br>2068.5 | 1300<br>2100 | 1319.5<br>2131.5 | de.        |               |
| Transmission Rate                               |             |                  | 1200         | 19               | Baud       | ± 1%          |
|                                                 |             |                  | 150          |                  | Baud       | ± 1%          |
|                                                 |             |                  | 75           |                  | Baud       | ± 1%          |
| Input detection level per tone                  |             | -40<br>-37.78    |              | -6.2<br>-4.0     | dBV<br>dBm | S/N=20<br>1,3 |
| Reject signal level per tone                    |             |                  |              | -48<br>-45.78    | dBV<br>dBm | S/N=20<br>1,3 |
| Positive and negative Twist accept              |             | -10              |              | 10               | dB         | S/N=20<br>2,3 |
| Signal to Noise Ratio                           |             | 20               |              |                  | dB         | S/N=20<br>3   |

| DESCRIPTION                        | SYM.                            | MIN    | TYP  | MAX    | UNITS | NOTES  |
|------------------------------------|---------------------------------|--------|------|--------|-------|--------|
| Input frequency detection          |                                 |        |      |        |       |        |
| Bell 103 '1' (Mark), high band     | $f_{MARK}$                      | 2213   | 2225 | 2237   | Hz    |        |
| Bell 103 '0' (Space), high band    | $\boldsymbol{f}_{\text{SPACE}}$ | 2013   | 2025 | 2037   | Hz    |        |
| Bell 103 '1' (Mark), low band      | $f_{MARK}$                      | 1258   | 1270 | 1282   | Hz    |        |
| Bell 103 '0' (Space), low band     | $\boldsymbol{f}_{\text{SPACE}}$ | 1058   | 1070 | 1082   | Hz    |        |
| ITU-T V.21 '1' (Mark), high band   | $f_{\mbox{MARK}}$               | 1638   | 1650 | 1662   | Hz    |        |
| ITU-T V.21 '0' (Space), high band  | $\boldsymbol{f}_{\text{SPACE}}$ | 1838   | 1850 | 1862   | Hz    |        |
| ITU-T V.21 '1' (Mark), low band    | $f_{MARK}$                      | 968    | 980  | 992    | Hz    |        |
| ITU-T V.21 '0' (Space), low band   | $\boldsymbol{f}_{SPACE}$        | 1168   | 1180 | 1192   | Hz    |        |
| Transmission Rate                  |                                 |        | 300  |        | Baud  | ± 1%   |
| Charles Control                    |                                 |        | 110  |        | Baud  | ± 1%   |
| Input datastica laval non tana     |                                 | -40    |      | -6.2   | dBV   | S/N=20 |
| Input detection level per tone     |                                 | -37.78 |      | -4.0   | dBm   | 1,3    |
| Reject signal level per tone       |                                 |        |      | -48    | dBV   | S/N=20 |
|                                    | 7                               |        |      | -45.78 | dBm   | 1,3    |
| Positive and negative Twist accept |                                 | -10    |      | 10     | dB    | S/N=20 |



|                       |    | 100                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    | 2,3         |
|-----------------------|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-------------|
| Signal to Noise Ratio | 20 | A STATE OF THE STA | dB | S/N=20<br>3 |

#### NOTES:

- 1. These characteristics are for AVDD=+3.3V and 25°C.
- 2. Both mark and space have the same amplitude and at the nominal frequencies.

$$Twist = 20 log \left( \frac{amplitude of f_{MARK}}{amplitude of f_{SPACE}} \right)$$

 Band limited random noise (200~3400 Hz). Measurement is valid only when the FSK signal is present. Note that the BT band is 300~3400 Hz, while the Bellcore band is 0~4K Hz.

> Publication Release Date: March 10, 2011 Revision 2.7

- 207 -



### 15.10 FSK Transmitter - Bell 202, ITU-V.23, Bell 103, ITU-V.21

Modulation rates and characteristic frequencies for the forward data-transmission channel

| DESCRIPTION | SYM                  | MIN  | TYP  | MAX  | UNITS | NOTES     |
|-------------|----------------------|------|------|------|-------|-----------|
| Twist       |                      | -0.5 | 0    | 0.5  | %     |           |
| Baud Rate   |                      |      | 1200 | 20L  | Baud  | ± 1%      |
| Bell 202    |                      |      | 7.6  | N N  | 16    |           |
| "1" (Mark)  | $f_{\it MARK}$       | 1197 | 1200 | 1203 | 2     | $\pm 3Hz$ |
| "0" (Space) | $f_{\mathit{SPACE}}$ | 2197 | 2200 | 2203 | 1200  | $\pm 3Hz$ |
| V.23        |                      |      |      | - 1  | ( )   |           |
| "1" (Mark)  | $f_{\it MARK}$       | 1297 | 1300 | 1303 |       | $\pm 3Hz$ |
| "0" (Space) | $f_{\mathit{SPACE}}$ | 2097 | 2100 | 2103 | 70    | $\pm 3Hz$ |

| DESCRIPTION            | SYM                  | MIN  | TYP  | MAX  | UNITS | NOTES     |
|------------------------|----------------------|------|------|------|-------|-----------|
| Twist                  |                      | -0.5 | 0    | 0.5  | %     | "COL      |
| Baud Rate              |                      |      | 300  |      | Baud  | ± 1%      |
|                        |                      |      | 110  |      | Baud  | ± 1%      |
| Bell 103               |                      |      |      |      |       |           |
| "1" (Mark), high band  | $f_{\mathit{MARK}}$  | 2222 | 2225 | 2228 |       | $\pm 3Hz$ |
| "0" (Space), high band | $f_{\mathit{SPACE}}$ | 2022 | 2025 | 2028 |       | $\pm 3Hz$ |
| "1" (Mark), high band  | $f_{\mathit{MARK}}$  | 1267 | 1270 | 1273 |       | ±3Hz      |
| "0" (Space), high band | $f_{SPACE}$          | 1067 | 1070 | 1073 |       | ±3Hz      |
| V.21                   |                      |      |      |      |       |           |
| "1" (Mark), high band  | $f_{\mathit{MARK}}$  | 1647 | 1650 | 1653 |       | ±3Hz      |
| "0" (Space), high band | $f_{\mathit{SPACE}}$ | 1847 | 1850 | 1853 |       | ±3Hz      |
| "1" (Mark), low band   | $f_{\mathit{MARK}}$  | 977  | 980  | 983  |       | ±3Hz      |
| "0" (Space), low band  | $f_{SPACE}$          | 1177 | 1180 | 1183 |       | $\pm 3Hz$ |

<sup>\*</sup>Tx signal % baud or bit rate accuracy is the same as XTAL/CLOCK % frequency accuracy.



#### 15.11 DTMF Detection

AC Electrical Characteristics – DTMF detection

| Description                        | Sym | Min  | Тур | Max   | Units | Notes  |
|------------------------------------|-----|------|-----|-------|-------|--------|
| Frequency Deviation Acceptation    |     | 1.5  | 770 | ±2.0  | %     |        |
| Frequency Deviation Rejection      |     | ±3.5 | X   | J. 14 | %     |        |
| Accept signal level per tone       |     | -36  | 10  | -6    | dBm   |        |
| Reject signal per tone             |     |      | - 1 | -46   | dBm   |        |
| Positive and negative Twist accept |     |      |     | 10    | dB    | S/N=20 |
| Signal to Noise Ratio              |     | 20   |     | 50    | dB    | N.     |

#### **16. ORDERING INFORMATION**





#### 17. REVISION HISTORY

| VERSI<br>ON | DATE                               | PAGE | DESCRIPTION                                                                                                                                      |
|-------------|------------------------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 2.00        | November 28,<br>2008               |      | Release as Design Guide.                                                                                                                         |
| 2.01        | October 2009 –<br>not yet released |      | <ul> <li>Update AGC parameters.</li> <li>Update AGC description.</li> <li>Description in READ_STATUS command, number of status bytes.</li> </ul> |
| 2.5         | May 5 <sup>th</sup> , 2010         |      | <ul><li>Update pin-out diagram.</li><li>Update block diagram.</li></ul>                                                                          |
| 2.6         | Oct 22 <sup>nd</sup> , 2010        |      | <ul> <li>Add table of supported serial flash memory.</li> </ul>                                                                                  |
| 2.7         | Mar 10, 2011                       |      | Update SPI timing.                                                                                                                               |

### **Important Notice**

Nuvoton products are not designed, intended, authorized or warranted for use as components in systems or equipment intended for surgical implantation, atomic energy control instruments, airplane or spaceship instruments, transportation instruments, traffic signal instruments, combustion control instruments, or for other applications intended to support or sustain life. Furthermore, Nuvoton products are not intended for applications wherein failure of Nuvoton products could result or lead to a situation wherein personal injury, death or severe property or environmental damage could occur.

Nuvoton customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Nuvoton for any damages resulting from such improper use or sales.

Please note that all data and specifications are subject to change without notice.

All the trademarks of products and companies mentioned in this datasheet belong to their respective owners.

| Figure 3-1 ISD61S00 48-Lead LQFP Pin Configuration                                        | 12  |
|-------------------------------------------------------------------------------------------|-----|
| Figure 8-1 SPI Data Transaction                                                           | 35  |
| Figure 8-2 R/B Timing for SPI Writing Transactions                                        | 35  |
| Figure 8-3 SPI Transaction Ignoring RDY/BSYB                                              | 36  |
| Figure 8-4 Clock Generation Block Diagram                                                 | 41  |
| Figure 8-5 PMC/I2S signal routing                                                         | 47  |
| Figure 8-6 Microphone Voltage Gain Mode                                                   | 57  |
| Figure 8-7 Microphone Current Gain Mode                                                   | 58  |
| Figure 8-8 Current Mode Gain with Electret MIC model                                      | 59  |
| Figure 8-9 Auxiliary Input Mode                                                           | 60  |
| Figure 8-10 TI Input Amplifier                                                            | 61  |
| Figure 8-11 Analog Output                                                                 | 63  |
| Figure 8-12 DTMF Detector - Functional Block Diagram                                      | 65  |
| Figure 8-13 DTMF Detector Acquisition Timing                                              | 66  |
| Figure 8-15 Tone Generator Block Diagram                                                  | 72  |
| Figure 8-16 Architecture of Linear FSK Waveform Generator                                 | 77  |
| Figure 8-17 Block Diagram of FSK Detector                                                 | 86  |
| Figure 8-18 band pass filter frequency response                                           | 95  |
| Figure 8-19 Block Diagram of CAS Detection                                                | 100 |
| Figure 8-20 Detector Biquad Low Tone Frequency Response                                   | 100 |
| Figure 8-21 CAS Detector Biquad High Tone Frequency Response                              | 101 |
| Figure 8-22 CAS Internal IIR Filter Frequency Response Figure                             | 103 |
| Figure 8-23 FSK ATD IIR filter structure                                                  | 107 |
| Figure 8-24 FSK encoder IIR filter structure                                              | 108 |
| Figure 8-25 Band Pass filter frequency response of voice energy detection                 | 115 |
| Figure 8-26 Call progress tone band-pass filter frequency response                        | 117 |
| Figure 8-27 Block diagram of ring detector                                                | 120 |
| Figure 8-28 The timing of ring detector with RNG_CTRL[1:0]=2'b11                          | 120 |
| Figure 8-29 Gain/Mixer Channel                                                            | 125 |
| Figure 8-30 CODEC/EC Gain Stages                                                          | 125 |
| Figure 8-31 Gain Stages and Mixer with Control Addresses                                  | 128 |
| Figure 8-33 Ringer Tone Generator Block                                                   | 137 |
| Figure 9-1: Signal flow through the Acoustic Echo Canceller (AEC) in the speech Processor | 140 |
| Figure 9-2: Signal flow through the Line Echo Canceller (LEC) in the speech Processor     | 140 |
| Figure 9-3 AGC Operation regions.                                                         | 161 |
| Figure 10.1 SPI Pecced                                                                    | 177 |

## nuvoton

| Figure 10-2 SPI Feed-through                                          | 177 |
|-----------------------------------------------------------------------|-----|
| Figure 10-3 SPI Playback                                              | 178 |
| Figure 10-4 Feed-through SPI                                          | 179 |
| Figure 10-5 SPI Send Compressed Data to Decode                        | 181 |
| Figure 10-6 SPI Received Encoded Data                                 | 182 |
| Figure 11-1 ISD61S00 Memory Format                                    | 190 |
| Figure 12-1 POI and PU Initialization Flowcharts                      | 196 |
| Figure 13-1 Application Reference Schematic with discrete DAA         | 197 |
| Figure 13-2 Application Reference Schematic with integrated Clare DAA | 198 |
| Figure 15-1 SPI Timing                                                | 203 |

### nuvoton

| Table 7-1 Status Register Description               | 32  |
|-----------------------------------------------------|-----|
| Table 7-2 Interrupt Status Register Description     | 33  |
| Table 7-3 Interrupt Status Register Description     | 33  |
| Table 7-4 Timer interrupt and operation status      | 34  |
| Table 8-1 COMP_CFG Register Compression Type.       | 37  |
| Table 8-2 CFG0 Sample Rate Control                  | 37  |
| Table 8-3: PLL Frequency Examples                   | 42  |
| Table 8-4 Microphone and Auxiliary mode settings    | 54  |
| Table 8-5 Microphone Gain settings                  | 55  |
| Table 8-6 Microphone Bias settings                  | 55  |
| Table 8-7 Microphone Resistor settings              | 56  |
| Table 8-8 TI Gain Settings                          | 63  |
| Table 8-9 TI MUX Settings                           | 63  |
| Table 8-11 DTMF Frequency Deviation Register        | 67  |
| Table 8-12 Tone Generation Mode Setup               | 72  |
| Table 8-13 DTMF Frequency Mapping                   | 76  |
| Table 8-14 FSK Encoder Specification Selection      | 78  |
| Table 8-15 FSK Detector Modes.                      | 88  |
| Table 8-16 FSK_CMP_CNT Definition.                  | 90  |
| Table 8-17 CAS Detector Frequency Deviation Control | 102 |
| Table 8-18 CAS/ADT Detection Bits                   | 104 |
| Table 8-21 Mixer Gain Registers                     | 127 |
| Table 9-1 AEC/LEC Control Register Map              | 141 |
| Table 9-2 SC Gain Table                             | 157 |
| Table 10-1 SPI Commands                             | 166 |
| Table 10-2 Commands vs. Status                      | 168 |
| Table 11-1 Memory Header                            | 193 |
| Table 11-2 The first byte of the Memory Header      | 194 |
| Table 11-3 Message Header                           | 194 |