# ISD3800 Digital ChipCorder with **Digital Audio Interface** ## nuvoton | TABLE OF CONTENTS | | |-----------------------------------------------------|----| | 1 GENERAL DESCRIPTION | 4 | | 2 FEATURES | 4 | | 3 BLOCK DIAGRAM | 6 | | 4 PINOUT CONFIGURATION | 7 | | 4.1 48L-LQFP | | | 5 PIN DESCRIPTION | 8 | | 6 SPI INTERFACE | 12 | | 7 ANALOG AND DIGITAL SIGNAL PATH | | | 7.1 Analog Signal Path | | | 7.1.1 AUX Analog Input | 16 | | 7.1.2 AUX & Class-AB BTL Analog Output | | | | | | | | | 8.1 MESSAGE MANAGEMENT | | | 8.1.2 Voice Macros | | | 8.1.3 User Data | | | 8.2 MEMORY HEADER | | | 8.3 DIGITAL ACCESS OF MEMORY | | | 8.5 MEMORY CONTENTS PROTECTION | | | 9 I <sup>2</sup> S INTERFACE | 24 | | 10 CLOCK GENERATION | 25 | | 10.1 EXTERNAL CRYSTAL OSCILLATOR | 26 | | 10.2 I <sup>2</sup> S CLOCK USAGE | | | 10.3 Internal Oscillator | 28 | | 11 INITIALIZATION & PLAY FLOWCHART | 29 | | 12 DEVICE CONFIGURATION AND STATUS | 31 | | 12.1 CLOCK CONFIGURATION | | | 12.2 DEVICE STATUS REGISTER | | | 12.3 DEVICE CONFIGURATION REGISTERS | | | 13 SPI COMMANDS | | | | | | 13.1 AUDIO PLAY COMMANDS | | | 13.1.2 Play Voice Prompt @Rn, $n = 0 \sim 7$ | | | 13.1.3 Play Voice Prompt, Loop | 52 | | 13.1.4 Play Voice Prompt, Loop, @Rn, $n = 0 \sim 7$ | | | 13.1.5 Stop Loop-Play Command | | | IJ.I.O LACCUIC VOICE MUCIO | | ## nuvoton | 13.1.7 | Execute Voice Macro @Rn, $n = 0 \sim 7$ | 54 | |----------|------------------------------------------------|--------------------| | 13.1.8 | Play Silence | | | 13.1.9 | Stop Command. | | | 13.1.10 | SPI Read PCM Data | | | 13.1.11 | SPI Send Compressed Data to Decode | | | | VICE STATUS COMMANDS. | | | 13.2.1 | Read Status | | | 13.2.2 | Read Interrupt | | | 13.2.3 | Read ISD3800 ID | 59 | | 13.3 DIC | GITAL MEMORY COMMANDS. | 59 | | 13.3.1 | Digital Read | 59 | | 13.3.2 | Digital Write | 60 | | 13.3.3 | Erase Memory | 60 | | 13.3.4 | Chip Erase | 61 | | 13.3.5 | CHECKSUM | 61 | | 13.4 DE | VICE CONFIGURATION COMMANDS | | | 13.4.1 | PWR_UP – Power up | | | 13.4.2 | PWR_DN - Power Down | | | 13.4.3 | SET_CLK_CFG - Set Clock Configuration Register | | | 13.4.4 | RD_CLK_CFG - Read Clock Configuration Register | | | 13.4.5 | WR_CFG_REG – Write Configuration Register | | | 13.4.6 | RD_CFG_REG – Read Configuration Register | 64 | | | CTRICAL CHARACTERISTICS | | | | ERATING CONDITIONS | | | | PARAMETERS | | | 14.3 AC | PARAMETERS | | | 14.3.1 | Inputs Error! Boo | kmark not defined. | | 14.3.2 | Outputs | | | 14.3.3 | DAC Frequency Responses | | | 14.3.4 | SPI Timing | | | 14.3.5 | I <sup>2</sup> S Timing | <i>75</i> | | 15 APPL | LICATION DIAGRAM | 77 | | 16 PAC | KAGE SPECIFICATION | 79 | | 16.1 48 | LEAD LQFP(7x7x1.4mm footprint 2.0mm) | 79 | | 17 ORD | ERING INFORMATION | 80 | | 18 REVI | SION HISTORY | 81 | #### 1 GENERAL DESCRIPTION The ISD3800 is a digital ChipCorder<sup>®</sup> featuring digital compression, comprehensive memory management, and integrated analog/digital audio signal paths. The ISD3800 utilizes serial flash memory to provide non-volatile audio playback for a two-chip solution. The ISD3800 provides an I<sup>2</sup>S digital audio interface, faster digital programming, higher sampling frequency, and a signal path with SNR 80dB. The ISD3800 can take digital audio data via I<sup>2</sup>S or SPI interface. When I<sup>2</sup>S input is selected, it will replace the analog audio inputs and will support sample rates of 32, 44.1 or 48 kHz depending upon clock configuration. When SPI interface is chosen, the sample rate of the audio data sent must be one of the ISD3800 supported sample rates. The ISD3800 has inbuilt analog audio inputs, analog audio line driver, and speaker driver output. The analog audio input, Aux-in, has a fixed gain configured by SPI command. Aux-in can directly feed-through to the analog outputs; it can also mix with the DAC output and then feed-through to the analog outputs. Analog outputs are available in two forms: (1) Aux-out is an analog single-ended voltage output; (2) Class-AB BTL (bridge-tied-load) is an analog differential voltage output. Class-AB BTL delivers 0.7-watt output power at $V_{CCSPK} = 4.5V$ . Class-D PWM direct-drive is also available, which delivers 0.9-watt output power at $V_{CCSPK} = 4.5V$ . #### **2 FEATURES** - External Memory: - The ISD3800 supports the following flash: | Manufacturer | Wink | ond | | MXIC | | | |--------------|----------|----------|----------|---------------|----------|----------| | Family | 25X 25Q | | 25P | 25P 25PX 25PE | | | | JEDEC ID | EF 30 1X | EF 40 1X | 20 20 1X | 20 71 1X | 20 80 1X | C2 20 1X | - The addressing ability of ISD3800 is up to 128Mbit, which is 64-minute playback time based on 8kHz/4bit ADPCM. - Inbuilt 3V voltage regulator to provide power source to the external flash memory - Fast Digital Programming - Programming rate can go up to 1Mbits/second mainly limited by the flash memory write rate. - Memory Management - Store pre-recorded audio (Voice Prompts) using high quality digital compression - Use a simple index-based command for playback - Execute pre-programmed macro scripts (Voice Macros) designed to control the configuration of the device and play back Voice Prompts sequences. - Sample Rate - Seven sampling frequencies are available for a given master sample rate. For example, the sampling frequencies of 4, 5.3, 6.4, 8, 12.8, 16 and 32kHz are available when the device is clocked at a 32kHz master sample rate. - For I<sup>2</sup>S operation, 32, 44.1 and 48kHz master sample rates are available with playback sampling frequencies scaling accordingly. - Compression Algorithms - For Pre-Recorded Voice Prompts - μ-Law: 6, 7 or 8 bits per sample - Differential μ-Law: 6, 7 or 8 bits per sample - PCM: 8, 10 or 12 bits per sample - Enhanced ADPCM: 2, 3, 4 or 5 bits per sample - Variable-bit-rate optimized compression. This allows best possible compression given a metric of SNR and background noise levels. - Oscillator - o Internal oscillator with internal reference: 2.048 MHz with ±1% deviation - Internal oscillator with external resistor: 2.048 MHz with ±2% deviation<sup>1</sup> - External crystal or clock input - Crystals support standard audio sampling rates of 2.048, 4.096, 8.192, 12.288 and 11.2896MHz - I<sup>2</sup>S bit clock input - Inputs - Aux-in: Analog input with 2-bit gain control configured by SPI command - Outputs - PWM: Class-D speaker driver to directly drive an 8Ω speaker or buzzer - Deliver 0.9-watt output power at V<sub>CCSPK</sub> = 4.5V - Aux-out: an analog single-ended voltage output - o Class-AB BTL: an analog differential voltage output - Deliver 0.7-watt output power at V<sub>CCSPK</sub> = 4.5V - Class-AB BTL can directly drive an 8Ω speaker or buzzer - Class-AB BTL can drive an 8Ω speaker or buzzer via an external amplifier - I/Os - SPI interface: MISO, MOSI, SCLK, SSB for commands and digital audio data - o I<sup>2</sup>S interface: I<sup>2</sup>S CLK, I<sup>2</sup>S WS, I<sup>2</sup>S SDI, I<sup>2</sup>S SDO for digital audio data - o 8 GPIO pins: - 4 GPIO pins share with I<sup>2</sup>S - 4 GPIO pins share with SPI Interface - GPIO pins can trigger Voice Macro for a pushbutton application - 8-bit Volume Control set by SPI command for flexible mixing - Operating Voltage: 2.7 ~ 5.5V - Standby Current: 1uA typical - Package: - Green 48L-LQFP - Temperature Options: - Industrial: -40°C to 85°C \_ <sup>&</sup>lt;sup>1</sup> With ±1% precision 80kohm external resistor. #### 3 BLOCK DIAGRAM Figure 3-1 ISD3800 Block Diagram #### **4 PINOUT CONFIGURATION** #### 4.1 48L-LQFP Figure 4-1 ISD3800 48-Lead LQFP Pin Configuration. ### **5 PIN DESCRIPTION** | Pin<br>Number<br>48L-<br>LQFP | Pin Name | I/O | Function | |-------------------------------|---------------------------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | NC | | This pin should be left unconnected. | | 2 | NC | | This pin should be left unconnected. | | 3 | NC | | This pin should be left unconnected. | | 4 | GPIO7 /<br>I <sup>2</sup> S_SDI | I/O | A GPIO pin. By default this pin is a pull-high input. Can be configured as Serial Data Input of the I <sup>2</sup> S interface. | | 5 | GPIO6 /<br>I <sup>2</sup> S_SCK | I/O | A GPIO pin. By default this pin is a pull-high input. Can be configured as Clock input in slave mode or clock output in master mode. This pin can be configured as an external clock buffer if I <sup>2</sup> S is not used. | | 6 | GPIO5 /<br>I <sup>2</sup> S_WS | I/O | A GPIO pin. By default this pin is a pull-high input. Can be configured as Word Select (WS) input in slave mode or WS output in master mode. | | 7 | GPIO4 /<br>I <sup>2</sup> S_SDO | I/O | A GPIO pin. By default this pin is a pull-high input. Can be configured as Serial Data Output of the I <sup>2</sup> S Interface. | | 8 | NC | | This pin should be left unconnected. | | 9 | NC | | This pin should be left unconnected. | | 10 | V <sub>SSD</sub> | I | Digital Ground. | | 11 | V <sub>CCD</sub> | I | Digital power supply. | | 12 | $V_{REG}$ | 0 | A 1.8V regulator to supply the internal logic. A minimum 1uF capacitor with low ESR<0.5OHM should be connected to this pin for supply decoupling and stability. | | 13 | MISO /<br>GPIO1 | Ο | Master-In-Slave-Out. Serial output from the ISD3800 to the host. This pin is in tri-state when SSB=1. Can be configured as GPIO1. After power on, by default this pin floats. | | 14 | SCLK | | Serial Clock input to the ISD3800 from the host. There is no internal pull up/down on this pin. | | 15 | SSB | 40 | Slave Select input to the ISD3800 from the host. When SSB is low device is selected and responds to commands on the SPI interface. There is no internal pull up/down on this pin. | | Pin<br>Number<br>48L-<br>LQFP | Pin Name | I/O | Function | |-------------------------------|---------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 16 | MOSI /<br>GPIO0 | _ | Master-Out-Slave-In. Serial input to the ISD3800 from the host. Can be configured as GPIO0. There is no internal pull up/down on this pin. | | 17 | V <sub>CCSPK</sub> | | In PWM mode: Digital Power for the PWM Driver. Deliver 0.9-watt output power at $V_{CCSPK} = 4.5V$ . Or, In Class-AB mode: Analog Power for the Class-AB output. Class-AB BTL delivers 0.7-watt output power at $V_{CCSPK} = 4.5V$ . | | 18 | SPK+ | 0 | PWM driver positive output. This SPK+ output, together with SPK-pin, provide a differential output to drive 8Ω speaker or buzzer. During power down this pin is in tri-state. Or, can be configured as Class-AB BTL which, together with SPK-pin, provides a differential voltage output. Or, can be configured as a Class-AB single-ended output. | | 19 | V <sub>SSSPK</sub> | I | In PWM mode: Digital Ground for the PWM Driver. Or, In Class-AB mode: Analog Ground for the Class-AB output. | | 20 | SPK- | 0 | PWM driver negative output. This SPK- output, together with SPK+ pin, provides a differential output to drive 8Ω speaker or buzzer. During power down this pin is tri-state. Or, can be configured as Class-AB BTL which, together with SPK+ pin, provides a differential voltage output. Or, can be configured as a Class-AB single-ended output. | | 21 | V <sub>CCSPK</sub> | I | In PWM mode: Digital Power for the PWM Driver. Deliver 0.9-watt output power at $V_{CCSPK} = 4.5V$ . Or, In Class-AB mode: Analog Power for the Class-AB output. Class-AB BTL delivers 0.7-watt output power at $V_{CCSPK} = 4.5V$ . | | 22 | NC | | This pin should be left unconnected. | | 23 | NC | | This pin should be left unconnected. | | 24 | NC | | This pin should be left unconnected. | | 25 | INTB /<br>GPIO3 | 0 | Active low interrupt request pin. This pin is an open-drain output. Can be configured as GPIO3. | | 26 | RDY/BSYB /<br>GPIO2 | 0 | An output pin to report the status of data transfer on the SPI interface. "High" indicates that ISD3800 is ready to accept new SPI commands or data. Can be configured as GPIO2. | | Pin<br>Number<br>48L-<br>LQFP | Pin Name | I/O | Function | | |-------------------------------|-------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | | | | When device is ready, this pin drives high. | | | 27 | RESET | I | Applying power to this pin will reset the chip. (A high pulse of 50ms or more will reset the chip.) There is no internal pull up/down on this pin. | | | 28 | FDO | 0 | Serial data output of the external serial flash interface. Connects to data input (DI) of external serial flash. | | | 29 | FCLK | 0 | Serial data CLK of the external serial flash interface. | | | 30 | FDI | I | Serial data input to external serial flash interface. Connects to data output (DO) of external flash memory. | | | 31 | FCSB | 0 | Chip Select Bar of the external serial flash interface. | | | 32 | V <sub>CCF</sub> | 0 | Digital power supply for the external flash memory. A minimum 1uF capacitor with low ESR<0.5OHM should be connected to this pin for supply decoupling and stability. Refer to the application diagram. | | | 33 | V <sub>CCF</sub> | 0 | Digital power supply for the external flash memory. A minimum 1uF capacitor with low ESR<0.5OHM should be connected to this pin for supply decoupling and stability. Refer to the application diagram. | | | 34 | V <sub>CCFS</sub> | I | Digital power supply for the inbuilt voltage regulator for the external flash memory. A 0.1uF capacitor should be connected to this pin for supply decoupling and stability. Refer to the application diagram. | | | 35 | XTALOUT | 0 | Crystal interface output pin. | | | 36 | XTALIN | I | The CLK_CFG register determines one of the following three configurations: (1) A crystal or resonator connected between the XTALOUT and XTALIN pins. (2) A resistor connected to GND as a reference current to the internal oscillator and left the XTALOUT unconnected. (3) An external clock input to the device and left the XTALOUT unconnected. | | | 37 | NC | | This pin should be left unconnected. | | | 38 | NC | | This pin should be left unconnected. | | | 39 | NC | | This pin should be left unconnected. | | | 40 | NC | | This pin should be left unconnected. | | | 41 | NC | | This pin should be left unconnected. | | | 42 | Aux-out | 0 | Aux Out. This pin is an analog voltage output. If AUXOUT is not used, this pin should be left unconnected. | | | 43 | V <sub>CCA</sub> | 1 | Analog power supply pin. | | | 44 | V <sub>SSA</sub> | The | Analog ground pin. | | | Pin<br>Number<br>48L-<br>LQFP | Pin Name | I/O | Function | |-------------------------------|------------------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 45 | V <sub>MID</sub> | 0 | Middle voltage reference for the swing of analog/digital audio outputs. A 4.7uF capacitor should be connected to this pin for supply decoupling and stability. | | 46 | NC | | This pin should be left unconnected. | | 47 | Aux-in | I | Auxiliary input with the gain set by SPI command If Aux-in is not used, this pin should be left unconnected. | | 48 | NC | | This pin should be left unconnected. | #### 6 SPIINTERFACE This is a standard four-wire interface used for communication between ISD3800 and the host. It consists of an active low slave-select (SSB), a serial clock (SCLK), a data input (Master Out Slave In - MOSI), and a data output (Master In Slave Out - MISO). In addition, for some transactions requiring data flow control, a RDY/BSYB signal (pin) is available. The ISD3800 supports SPI mode 3: (1) SCLK must be high when SPI bus is inactive, and (2) data is sampled at SCLK rising edge. A SPI transaction begins on the falling edge of SSB and its waveform is illustrated below: Figure 6-1 SPI Data Transaction. A transaction begins with sending a command byte (C7-C0) with the most significant bit (MSB – C7) sent in first. During the byte transmission, the status (S7-S0) of the device is sent out via the MISO pin. After the byte transmission, depending upon the command sent, one or more bytes of data will be sent via the MISO pin. RDY/BSYB pin is used to handshake data into or out of the device. Upon completion of a byte transmission, RDY/BSYB pin could change its state after the rising edge of the SCLK if the built-in 32-byte data buffer is either full or empty. At this point, SCLK must remain high until RDY/BSYB pin returns to high, indicating that the ISD3800 is ready for the next data transmission. See below for timing diagram. Figure 6-2 RDY/BSYB Timing for SPI Writing Transactions. If the SCLK does not remain high, RDY bit of the status register will be set to zero and be reported via the MISO pin so the host can take the necessary actions (i.e., terminate SPI transmission and retransmit the data when the RDY/BSYB pin returns to high). For commands (i.e., DIG\_READ, SPI\_PCM\_READ) that read data from ISD3800, MISO is used to read the data; therefore, the host must monitor the status via the RDY/BSYB pin and take the necessary actions. The INT pin will go low to indicate (1) data overrun/overflow when sending data to the ISD3800; or (2) invalid data from ISD3800. See Figure 6-3 for the timing diagram. Figure 6-3 SPI Transaction Ignoring RDY/BSYB #### 7 ANALOG AND DIGITAL SIGNAL PATH #### 7.1 ANALOG SIGNAL PATH Analog signal path provides a configurable Aux-in analog input and two analog outputs along with multiplexing and summation blocks to route signals between analog blocks and the digital signal path. Figure 7-1 Analog Signal Path Analog outputs consist of: - AUXOUT is a single-ended voltage output. - Class-AB BTL (bridge-tied-load) is a differential voltage output, which shares the same two pins of PWM (SPK+/SPK-). Signal source of Class-AB BTL could be either from DAC or SUM2. - Besides Class-AB BTL, SPK+ and/or SPK- can also be individually configured as a single-ended Class-AB output. The analog path consists of the following blocks: AUXIN, SUM2, AUX\_MUX, SPK+\_MUX, and SPK-\_MUX. The summation block SUM2 is able to mix two signals together. SUM2 mixes the analog input AUXIN with the digital signal path output. AUX\_MUX provides input selection into the AUXOUT block. SPK+\_MUX and SPK-\_MUX provide input selection into the SPK+ and SPK- blocks. The configuration registers, CFG5-CFG9 & CFG18, control the active path features, allow individual power control of each block and enable the muting of certain path inputs. The details of the path configuration registers are described in Section 12.3. #### 7.1.1 AUX Analog Input The AUX Analog Input amplifies input signals with a fixed gain of 0dB, 3dB, 6dB, or 9dB, selectable via SPI command. Similar to ANAIN, the gain setting should be configured so that the output signal has a 1Vpp swing. Figure 7-2 AUXIN Input Amplifier The coupling capacitor, $C_{coup}$ , like in the case of ANAIN, should be set according to the value of to allow signals above a certain frequency to pass through. The relationship repeated here is: $$f_{pass} = \frac{1}{2\pi R_{in} C_{coup}}$$ $R_{in}$ is the input impedance of the AUXIN amplifier and is dependent upon the gain setting as shown in Table 7-1 below. Table 7-1 Gain Setting Vs. Rin | Setting | Gain dB | Gain | Rin (kOhms) | |---------|---------|------|-------------| | 00 | 0 | 1.00 | 40.0 | | 01 | 3 | 1.41 | 33.2 | | 10 | 6 | 2.00 | 26.7 | | 11 | 9 | 2.82 | 21.0 | The minimum value of $R_{in}$ is approximately 20kOhms, so a $C_{coup}$ of 1 $\mu$ F will allow audio signals to pass through under all possible gain settings. #### 7.1.2 AUX & Class-AB BTL Analog Output AUXOUT is a single-ended voltage output. It needs an external amplifier to drive the speaker. AUXOUT together with the external amplifier is usually used when loud volume is needed. Class-AB BTL (bridge-tied-load) is a differential voltage output, which shares the same two pins of PWM (SPK+ and SPK-). As a differential output, Class-AB BTL is naturally better than AUXOUT in terms of noise rejection. Class-AB BTL can directly drive a speaker or drive a speaker via an external amplifier. Below is a table comparing the Class-AB BTL and AUXOUT: | | Class-AB BTL | AUXOUT | PWM | |-----------------|-----------------------------------------------------|------------------------------------------|---------------------------------| | Driving Method | Direct drive. Or, drive with an external amplifier. | Need an external amplifier. | Direct drive. | | Driving Ability | 1 W at V <sub>CCSPK</sub> = 5V. | High: depends on the external amplifier. | 1 W at V <sub>CCSPK</sub> = 5V. | | Quality | Typical 80dB with good noise rejection. | Typical 80dB. | Typical 60dB | | Cost | No extra cost. | Extra cost of the external amplifier. | No extra cost. | Table 7-2 Comparison of Class-AB BTL, AUXOUT, and PWM Signal source of Class-AB BTL could be either from DAC or SUM2. Figure 7-3 (the red line) shows an example of Class-AB BTL setting from the DAC. Besides Class-AB BTL, SPK+ and/or SPK- can also be individually configured as a single-ended Class-AB output. For detailed settings, please refer to 12.3 Device Configuration Registers, CFG18. ### nuvoTon Figure 7-3 DAC to Class-AB BTL #### 7.2 DIGITAL SIGNAL PATH The digital signal path performs filtering, sample rate conversion, mixing, volume control and decompression. A block diagram of the digital signal path is shown in Figure 7-4. The digital signal path operates at a master sample rate Fs (nominally 32kHz) set by the master clock source (see Section 10). It has the ability to up-sample or down-sample to a lower sample-rate, Fsub for playback and audio transfer to/from the SPI interface. Audio input at Fs into the signal path comes from the I²S digital audio interface. Audio at Fsub is up-sampled and can be mixed with the input and level adjusted via VOLA, VOLB and VOLC before going out on the DAC, I²S or PWM driver paths. The FIFO synchronizes audio sources at the sub-sampled bandwidth. One input and one output can be active at a time. The possible combinations are: DECOMPRESSOR → SPI\_OUT (SPI Playback) DECOMPRESSOR → UPSAMPLE (Playback) Figure 7-4 Digital Signal Path #### 8 ISD3800 MEMORY MANAGEMENT The ISD3800 employs several memory management techniques to make audio playback transparent to the host controller. The address space of the ISD3800 starts at address zero of the external serial flash memory. The external memory size can go up to 128Mbit with an erasable sector size of 4kBytes. The following sections will describe the ISD3800 memory management architecture and the message management functions. #### 8.1 MESSAGE MANAGEMENT The message management schemes implemented on the ISD3800 are: - 1. 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, 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 #### 8.1.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 ISD3800 use the index of the Voice Prompt to locate and play the pre-recorded 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 ISD3800 Voice Prompt Editor and writer are available for development purposes. #### 8.1.2 Voice Macros Voice Macros are a powerful voice script that allows users to customize their own play patterns such as play Voice Prompts, insert silence, change the master sample clock, powerdown 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 ISD3800 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 (WAKEUP) These Voice Macros allow the users to customize the ISD3800 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 11 for details. Here is an example to illustrate the usage of the PU Voice Macro. - SET CLK CFG(0x34) - WR CFG REG(0x02,0x48) - WR\_CFG\_REG(0x05,0x80) - WR\_CFG\_REG(0x18,0xAB) - FINISH The above PU Voice Macro will perform the following: - Choose internal reference as the clock source - Set up a playback path from Memory to Class-AB BTL The following is the complete list of the commands for Voice Macro: - SET\_CLK\_CFG(n) Set clock configuration register to n. - WR\_CFG\_REG(reg,n) Set configuration register reg to value n. - PWR DN Power down the ISD3800. - PLAY\_VP(i) Play Voice Prompt index i. - PLAY VP@Rn Indirect Play Voice Prompt. - PLAY VP LP(i) Loop Play Voice Prompt index i. - PLAY\_VP\_LP@Rn Indirect Loop Play Voice Prompt. - EXE VM(i) Execute Voice Macro index i. - EXE VM@Rn Indirect Execute Voice Macro. - 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. - FINISH Finish the voice macro and exit. #### 8.1.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 ISD3800 Voice Prompt Editor is available to assist customers in allocating such memory. #### 8.2 MEMORY HEADER The Memory 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 PMP pointer and the index table including POI, PU and other Voice Macros defined by the users. Table 8-1Memory Header | | Initial Bytes of the Memory Header | | | | | | | | | |-------|----------------------------------------------------------------|-----------|--------|-------|----------|----------|--|--|--| | Byte0 | Byte0 Byte1-2 Byte3-4 Bytes5-10 Bytes11-16 Byte17-22 Byte23-28 | | | | | | | | | | 0xCX | - | PMP[15:0] | POI_VM | PU_VM | VM/VP[2] | VM/VP[3] | | | | The Memory Header contains at least seventeen bytes located at the beginning of the memory space. Byte0 determines the memory protection scheme. Byte3-4 stores the PMP pointer. 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 are reserved for the POI and PU Voice Macro which are the first two entries in this table (index 0 and index 1) to be executed on power-on initialization and power-up, respectively. If this function is not desired, these entries should be left erased (0xFFFFFF,0xFFFFF). When a PLAY\_VP(i) or EXE\_VM(i) command is sent to the ISD3800, it reads the index table entry at address 6i+5 and executes the VP or VM at the address present in the table. 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 8.5 for details). Table 8-2 The first byte of the Memory Header | Memory Header Byte | | | | | | | | |-------------------------------------------------|---|---|---|---|----|----|-----| | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | 1 | 1 | 0 | 0 | 1 | RP | WP | CEP | #### 8.3 DIGITAL ACCESS OF MEMORY ISD3800 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 playback is in progress. The RDY/BSYB pin governs the flow control for all digital operations. #### 8.4 DEVICE ERASE COMMANDS ISD3800 provides several ways to erase the flash memory. The flash memory has a minimum erasable sector size of 4kBytes. The sector erase command is sent with a start and stop sector address. The ISD3800 also has commands to mass erase the memory. #### 8.5 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 ISD3800 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 **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. #### 9 I<sup>2</sup>S INTERFACE The I<sup>2</sup>S interface is a digital audio interface that allows the transfer of the audio data between other digital audio devices such as multimedia processors, audio amplifiers or DSPs. The ISD3800 acts as either a master or a slave device on an I<sup>2</sup>S bus. As a slave the ISD3800 accepts SCK and WS clock and frame signals from a bus master. In master mode the ISD3800 generates SCK and WS. It is capable of both data input and output depending upon configuration. The ISD3800 is configurable to accept data from either the left or right audio channel or a mono mix of both. It can output data to either the left, right or both channels. It is also capable of feeding through a stereo signal and mixing a playback operation into the signal. In slave mode, to synchronize data transfer, the ISD3800 must derive its master clock from the I<sup>2</sup>S SCK or be operating from a synchronous external clock source. I<sup>2</sup>S is for high bandwidth audio input/output. High bandwidth audio input comes either from the ADC path or the I<sup>2</sup>S. High bandwidth audio output goes out on the DAC, I<sup>2</sup>S or PWM driver paths. It all depends on how you configure the path. However, commanding the ISD3800 is through SPI commands. For instance, the user could configure the path, through the SPI commands, as: "I<sup>2</sup>S input -> ADPCM-4bit Compression -> Memory Control", then the user can feed the audio data from I<sup>2</sup>S. Figure 9-1 I<sup>2</sup>S Protocol #### 10 CLOCK GENERATION The ISD3800 can derive its master clock from five sources: - 1. An external crystal (or resonator) oscillator interface. - 2. An external clock input (applied to pin XTALIN and left the XTALOUT unconnected) - 3. An internal oscillator controlled by an external resistor (attached to pin XTALIN and GND). - 4. An internal oscillator with internal reference. - 5. The SCK clock of the I<sup>2</sup>S interface. Regardless of source, the selected clock is fed to a phase-locked loop (PLL) to generate the internal master clock (MCLK) of the ISD3800. Figure 10-1 PLL Clock Generation on ISD3800 The goal of clock generation is to generate a master clock rate (MCLK) at 512x the master sample rate (Fs). A table of supported master clock and sample rates is shown below. The master sample frequency can be expressed by the formula: $$F_{\mathit{MCLK}} = F_{\mathit{OSC}} \, \frac{N}{2M} \ \, \text{where} \, \, M = \{1,2,3\} \, \text{and} \, \, N = \{8,16,32\}$$ $$F_s = F_{MCLK} \frac{1}{512}$$ Table 10-1 Master Clock and Sample Rates | MCLK (MHz) | Fs (kHz) | |------------|----------| | 16.384 | 32 | | 24.576 | 48 | | 22.5792 | 44.1 | For the above master sample rates Fs, playback is available at fixed ratios of the master sample rate. | Sub- | Master S | Sample Rate | Fs (kHz) | |---------------|----------|-------------|----------| | Sampled ratio | 32 | 44.1 | 48 | | 8 | 4 | 5.5125 | 6 | | 6 | 5.333 | 7.35 | 8 | | 5 | 6.4 | 8.82 | 9.6 | | 4 | 8 | 11.025 | 12 | | 2.5 | 12.8 | 17.64 | 19.2 | | 2 | 16 | 22.05 | 24 | | 1 | 32 | 44.1 | 48 | Table 10-2 Sub-Sample Rates available. #### 10.1 EXTERNAL CRYSTAL OSCILLATOR The external circuit for attaching a quartz crystal or ceramic resonator is shown in Figure 10-2. In this circuit, Rf is several $M\Omega$ and is used to DC bias the internal amplifier. R1, C1 and C2 are chosen so as not to overdrive the crystal and to suppress oscillation at higher crystal harmonics. Figure 10-2 Crystal Oscillator Some common crystal frequencies to achieve desired Fs are shown in Table 10-3. Table 10-3 Common Crystal Frequency Settings | Xtal (MHz) | M | N | Fs (kHz) | |------------|---|----|----------| | 1.024 | 1 | 32 | 32 | | 2.048 | 2 | 32 | 32 | | 3.072 | 3 | 32 | 32 | | 4.096 | 2 | 16 | 32 | | 6.144 | 3 | 16 | 32 | | 8.192 | 2 | 8 | 32 | | 12.288 | 3 | 8 | 32 | | 1.4112 | 1 | 32 | 44.1 | | 2.8224 | 2 | 32 | 44.1 | | 4.2336 | 3 | 32 | 44.1 | | 5.6448 | 2 | 16 | 44.1 | | 8.4672 | 3 | 16 | 44.1 | | 11.2896 | 2 | 8 | 44.1 | | 16.9344 | 3 | 8 | 44.1 | | 1.536 | 1 | 32 | 48 | | 3.072 | 2 | 32 | 48 | | 4.608 | 3 | 32 | 48 | | 6.144 | 2 | 16 | 48 | | 9.216 | 3 | 16 | 48 | | 12.288 | 2 | 8 | 48 | | 18.432 | 3 | 8 | 48 | In addition to the above crystals, to achieve standard audio sampling rates, other frequencies could be used that would produce different sample rates. For instance if the user wishes to use the standard USB clock rates of 6 or 12MHz the following master sample rates could be achieved. Table 10-4 USB Crystal Master Sample Rates | Xtal (MHz) | М | N | Fs (kHz) | |------------|---|----|----------| | 12 | 2 | 8 | 46.875 | | 12 | 3 | 8 | 31.25 | | 6 | 3 | 16 | 31.25 | | 6 | 2 | 16 | 46.875 | #### 10.2 I<sup>2</sup>S CLOCK USAGE The SCK clock of the $I^2S$ interface must be used to synchronize the ISD3800 if an $I^2S$ interface is used. The ISD3800 accepts $I^2S\_SCK$ clock rates of 32xFs or 64xFs. Table 10-5 Supported I<sup>2</sup>S Clock Rates with PLL Settings | I <sup>2</sup> S_SCK (MHz) | M | N | Fs (kHz) | |----------------------------|---|----|----------| | 1.024 | 1 | 32 | 32 | | 2.048 | 2 | 32 | 32 | | 1.4112 | 1 | 32 | 44.1 | | 2.8224 | 2 | 32 | 44.1 | | 1.536 | 1 | 32 | 48 | | 3.072 | 2 | 32 | 48 | | | | | | #### 10.3 INTERNAL OSCILLATOR The ISD3800 also provides an internal oscillator that requires only an external resistor to operate. If the device is configured to use the internal oscillator, then a resistor is connected to the XTALIN pin and GND. The internal oscillator with external resistor<sup>2</sup> has an accuracy of $\pm 2\%$ and gives a master sample rate of: $$F_s = \frac{32 \times 80 \times 10^3}{R_{OSC}}$$ (kHz) for $M=2$ , $N=32$ So if the user connects an 80kohm resistor to the XTALIN and GND, a 32 kHz sample frequency is fed-through the analog path. <sup>&</sup>lt;sup>2</sup> 80kohm external resistor with ±1% precision. #### 11 INITIALIZATION & PLAY FLOWCHART Whenever the ISD3800 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 ISD3800 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 ISD3800. The default PU sequence is to select a clock configuration of internal oscillator with PLL active for Fs=32kHz. Figure 11-1 POI and PU Initialization Flowcharts Figure 11-2 Playback Flowchart #### 12 DEVICE CONFIGURATION AND STATUS #### 12.1 CLOCK CONFIGURATION The clock configuration register is accessed via the SET\_CLK\_CFG command. It configures the clock source of the ISD3800. The default state of the clock configuration register is0x34, that is internal clock with internal reference, PLL active for 32kHz sample rate and no external clock output. When PLL\_BYPASS is set, the PLL is powered down and PLL\_REF\_CLK is fed directly to MCLK. The CLK\_OUT control bits configure the I²S clock pin, SCK, as a clock output to allow the ISD3800 to provide an oscillator output to another device such as the host microcontroller. Table 12-1 Clock Configuration Register Description | | CLK_CFG | | | | | | | | |-----------------------------|---------|---------|----------|----------|----------|-------|-------|--| | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | CLK_OUT[1:0] CLK_N_DIV[1:0] | | CLK_M_I | DIV[1:0] | CLK_INP_ | SEL[1:0] | | | | | 0 | 00 11 | | 1 | 01 | | 00 | | | #### Default 0x34: - Internal clock with internal reference - PLL active for F<sub>s</sub>=32khz sample rate - No external clock output Table 12-2 Clock Configuration Source | CLK_INP_SEL | | | | | | |------------------|---------------------------------------------|--|--|--|--| | CLK_INP_SEL[1:0] | Clock Source | | | | | | 00 | Internal Oscillator with Internal Reference | | | | | | 01 | I <sup>2</sup> S SCK Clock | | | | | | 10 | Internal Oscillator with Rext | | | | | | 11 | XTAL Interface | | | | | Table 12-3 Clock PLL M & N Divisor | CLK_M_DIV | | | | | | |----------------|-----|--|--|--|--| | CLK_M_DIV[1:0] | М | | | | | | 00 | 1 | | | | | | 01 | 2 | | | | | | 10 | 3 | | | | | | 11 | N/A | | | | | | CLK_N_DIV | | | | | | | |----------------|------------|--|--|--|--|--| | CLK_N_DIV[1:0] | N | | | | | | | 00 | PLL_BYPASS | | | | | | | 01 | 8 | | | | | | | 10 | 16 | | | | | | | 11 | 32 | | | | | | Table 12-4 External Clock Output | EXT Clock | | | | | | |--------------|-------------|--|--|--|--| | CLK_OUT[1:0] | 0 | | | | | | 00 | NONE – OFF | | | | | | 01 | Fosc | | | | | | 10 | PLL_REF_CLK | | | | | | 11 | MCLK | | | | | #### 12.2 DEVICE STATUS REGISTER Whenever the ISD3800 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 ISD3800. Table 12-5 Status Register Description | Status Byte | | | | | | | | |-------------------------------------------------|----------|-----|---|--------|--------|----------|---------| | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | Bit 0 | | PD | DBUF_RDY | INT | - | TALARM | VM_BSY | CBUF_FUL | CMD_BSY | 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. - TALARM Temperature-Alarm indicates that the chip is heated up and the temperature is higher than the specified temperature threshold. Please refer to register 0x30 for details of setting temperature alarm. - 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 erasing commands like ERASE\_MEM and CHIP\_ERASE, the user has to poll this bit to see if the erasing is done. Whenever the ISD3800 generates an interrupt the Interrupt Status register holds flags that indicate what type of interrupt was generated. These flags will remain set until a READ\_INT command clears them and the interrupt pin. Table 12-6 Interrupt Status Register Description | Interrupt Status Byte | | | | | | | | | |-------------------------------------------------|--|--|--|--|--|--|--|--| | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | TALARM | | | | | | | | | The individual bits of the status register refer to the following conditions: **INT** – an interrupt has been generated. The interrupt is cleared by the READ\_INT command. - TALARM Temperature-Alarm indicates that the chip is heated up and the temperature is higher than the specified temperature threshold. Please refer to register 0x30 for details of setting temperature alarm. - 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 pin 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 or voice macro finishes. #### 12.3 DEVICE CONFIGURATION REGISTERS The configuration of the ISD3800 is achieved by configuration registers as described below. Table 12-7 CFG0 Register | CFG0 Configuration Register | | | | | | | | | |-----------------------------|---------|-------|-------|-------|----------|-------|-------|--| | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | SR[2:0] | | | | CMP[4:0] | | | | | | 011 | | | 00100 | | | | | #### Default 0x64: - 4-bit ADPCM - Ratio to Fs = 4 Configuration register CFG0 controls the sample rate and compression algorithm. It can also override sample rate setting for playback by setting bit 0 of CFG1 high. SR[2:0] = CFG0[7:5] controls the sample rate, and CMP[4:0] = CFG0[4:0] controls the compression. An explanation of these follows below. Table 12-8 CFG0 Register Compression Type. | 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 12-9 CFG0 Sample Rate Control | Ratio | Sample Rate (kHz) | Code | CFG0[7:0] | | | |-------|-------------------|---------|-----------|-------|--| | to Fs | (for Fs=32kHz) | SR[2:0] | (Dec) | (Hex) | | | 8 | 4 | 0 | 0 | 0x00 | | | 6 | 5.333 | 1 | 32 | 0x20 | | | 5 | 6.4 | 2 | 64 | 0x40 | | | 4 | 8 | 3 | 96 | 0x60 | | | 2.5 | 12.8 | 4 | 128 | 0x80 | | | 2 | 16 | 5 | 160 | 0xA0 | | | 1 | 32 | 6 | 192 | 0xC0 | | The current operational mode of the ISD3800 can also be queried by setting CFG1[4] and reading CFG0. Under this condition, rather than reading back the configuration register, the result will be current audio path sample rate and compression scheme. Table 12-10 CFG1 Register | CFG1 Configuration Register | | | | | | | | | |-------------------------------|---|------|-----------|---|------|-------|-------|--| | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 | | | | | | Bit 1 | Bit 0 | | | - | - | LRMP | CFG0_READ | - | NRMP | SRSIL | SRCFG | | #### Default 0x00: - Sample rate is set by the audio header. - Whenever a change in sample rate is detected between two consecutive messages, a period of silence is automatically inserted. - If an audio playback finishes at a non-zero level the input to the signal path will be ramped to zero. - A read of CFG0 will read the setting of the CFG0 register rather than the current operating mode of compression and sample rate. Configuration register CFG1 controls how compressed audio is treated by the compression block: - **SRCFG** Forces the sample rate to be set by the CFG0 register by setting this bit to one, overriding any sample rate contained in the audio header. - **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, set this bit to one and the input to the signal path will not be ramped. Please note that NRMP and LRMP should not be set at the same time. - CFG0\_READ When this bit is set, a read of CFG0 will result in the current operation mode of compression and sample rate rather than the setting of the CFG register. A write to CFG0 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 – 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, set this bit to one and 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. Table 12-11 CFG2 Register | CFG2 Configuration Register | | | | | | | | | |---------------------------------------------------------------------------------------------------------|--------|--------|----------------------|---------|---------|---|---------|--| | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | Bit 0 | | | I <sup>2</sup> S_IN | DECODE | SPI_IN | I <sup>2</sup> S_OUT | DAC_OUT | PWM_OUT | 1 | SPI_OUT | | #### Default 0x00: • All digital paths are disabled. Configuration register CFG2 controls how digital audio signal path is configured: The ISD3800 Voice Prompt Editor provides a graphic view of the path configuration to help users get a better understanding of the audio signal path and largely ease the path setting. - **SPI\_OUT** Output signal data to SPI. If DECODE is selected, the signal path is bypassed and ISD3800 is ready for SPI\_Playback operation. Use the SPI\_PCM\_READ command to read the audio data out the SPI interface. - PWM\_OUT Output signal to PWM. - DAC\_OUT Output signal to AUXOUT. - I<sup>2</sup>S\_OUT Output signal data to I<sup>2</sup>S interface - SPI\_IN Input data from SPI. SPI\_IN and DECODE cannot be both on at the same time. - **DECODE** Used in conjunction with a play operation. When selected the signal path picks up data from the de-compressor and plays it to the corresponding outputs selected. - I<sup>2</sup>S IN Input data from I<sup>2</sup>S. #### Table 12-12 CFG3 Register | | CFG3 Configuration Register | | | | | | | | |-------|-------------------------------------------------|--|--|--|--|--|--|--| | Bit 7 | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | A X J | VOLC[7:0] | | | | | | | | #### Default 0x00: 0 dB attenuation to the output signal volume Configuration register CFG3 sets the output signal volume. Setting 0 has 0dB attenuation. Each subsequent step provides 0.25dB of attenuation. Table 12-13 CFG5 Register | | CFG5 Configuration Register | | | | | | | | | | | | |--------|-------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--| | Bit 7 | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | | | PU_DAC | | | | | | | | | | | | | ### Default 0x00: All blocks in the analog signal path are powered off. Configuration register CFG5 controls the power up state of blocks in the analog signal path along with the gain of the AUXIN input: - AUXIN\_GAIN- Sets the gain of the AUXIN input buffer. - **PU AUXIN** Powers up the AUXIN input buffer. - PU\_OP\_SUM Powers up the output summation amplifier (SUM2). - **PU\_DAC** Powers up the digital-to-analog converter (DAC). Table 12-14 AUXIN Gain Configuration | AUXIN_GAIN | | | | | | | | | |-----------------|-----------|--|--|--|--|--|--|--| | AUXIN_GAIN[1:0] | Gain (dB) | | | | | | | | | 00 | 0 | | | | | | | | | 01 | 3 | | | | | | | | | 10 | 6 | | | | | | | | | 11 | 9 | | | | | | | | Table 12-15 CFG6 Register | | CFG6 Configuration Register | | | | | | | | | | | | |-------|--------------------------------------------------------|--|--|---|---|---|-----------|--|--|--|--|--| | Bit 7 | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | | | AUX_S | AUX_SEL[1:0] - | | | - | - | - | PU_AUXOUT | | | | | | ### Default 0x00: Configuration register CFG6 controls the analog signal path functions: - PU\_AUXOUT Powers up the AUXOUT output buffer. - AUX\_SEL Selects the input source to the AUXOUT buffer. Table 12-16 AUXOUT Source Selection | AUX_SEL | | |--------------|----------| | AUX_SEL[1:0] | Source | | 00 | 7 July . | | 01 | AUXIN | | 10 | SUM2 | | 11 | DAC | Table 12-17 CFG8 Register | | | CFG8 Configuration R | egister | | |-----------|-------|----------------------|-------------|---------| | Bit 7 - 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | - | - | MUTE_SUM2 | MUTE_AUXOUT | - (111) | ### Default 0x00: NOT mute on analog signal path. Configuration register CFG8 controls the analog signal path functions: - MUTE\_AUXOUT Mutes AUXOUT output. - MUTE\_SUM2 Mutes the SUM2\_MUX input to the SUM2 summation block. Bits 4-7 are unused and have no effect on the signal path. Table 12-18 CFG9 Register | | CFG9 Configuration Register | | | | | | | | | | |-------|-----------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--| | Bit 7 | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | 150 | PWMF[3:0] I <sup>2</sup> S_L_IN I <sup>2</sup> S_R_IN I <sup>2</sup> S_L_OUT I <sup>2</sup> S_R_OUT | | | | | | | | | | ### Default 0x00: - Disable I<sup>2</sup>S function. - PWM nominal frequency is 256 kHz when master sample rate is 32 kHz. Configuration register CFG9 controls the functionality of the I<sup>2</sup>S audio interface: - I<sup>2</sup>S\_L\_IN Enables I<sup>2</sup>S input from the left (WS=0) channel to the signal path. - I<sup>2</sup>S R IN Enables I<sup>2</sup>S input from the right (WS=1) channel to the signal path. - I<sup>2</sup>S\_L\_OUT Enables signal path output to the left (WS=0) I<sup>2</sup>S channel. - I<sup>2</sup>S\_R\_OUT Enables signal path output to the right (WS=1) I<sup>2</sup>S channel. - In addition to this basic functionality these bits are decoded to determine the whether mixing or feed-through occurs in the I<sup>2</sup>S path. See I<sup>2</sup>S section for details. - **PWMF[3:0]** Adjusts the nominal frequency of the PWM driver. This frequency is 1MHz/PWMF for all settings except 0, where frequency = 256kHz. Numbers are relative to a 32kHz master sample rate. Table 12-19 I<sup>2</sup>S Selection | | I <sup>2</sup> S Channel Selection | | | | | | | | |------------------|----------------------------------------------|--|--|--|--|--|--|--| | CFG9[3:0] | Description | | | | | | | | | 0000 | No I <sup>2</sup> S input or output selected | | | | | | | | | 1111 | Stereo Feed-through. | | | | | | | | | 10XX | Left channel in; can output to both/either | | | | | | | | | 01XX | Right channel in can output to both/either. | | | | | | | | | 1100, 1101, 1110 | Left+Right mixed for either channel output. | | | | | | | | ### Table 12-20 CFG14 Register | | CFG14 Configuration Register | | | | | | | | | | | |-------|------------------------------|--|----|---------|--|--|--|--|--|--|--| | Bit 7 | Bit 7 | | | | | | | | | | | | | | | VO | LB[7:0] | | | | | | | | #### Default 0x00: • 0 dB attenuation to the volume control coming from the decompression block. Configuration register CFG14 controls the volume level coming from the decompression block. Setting 0 has 0dB attenuation. Each subsequent step provides 0.25dB of attenuation. Table 12-21 CFG15 Register | | CFG15 Configuration Register | | | | | | | | | | | |-------|-------------------------------------------------|--|-------|------|--|--|--|--|--|--|--| | Bit 7 | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | | | | | VOLA[ | 7:0] | | | | | | | | ### Default 0x00: • 0 dB attenuation to the volume control coming from the I<sup>2</sup>S. Configuration register CFG15 controls the volume level coming from the I<sup>2</sup>S input. Setting 0 has 0dB attenuation. Each subsequent step provides 0.25dB of attenuation. ### Table 12-22 CFG17 Register | | CFG17 Configuration Register | | | | | | | | | | | |-----------------------------------------------|------------------------------|---------------------|----------------------|--------|-------------|---|---|--|--|--|--| | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit | | | | | | | | | | | | | PLL_LOCK | - | I <sup>2</sup> S_MM | I <sup>2</sup> S_ATT | DECODE | COMP_ACTIVE | - | - | | | | | #### Default 0x01: - Disable the 3dB attenuation when left and right channel are mixed. - I<sup>2</sup>S slave mode: ISD3800 accepts SCK and WS from a bus master. Configuration register CFG17 controls how the configuration registers are applied: - COMP\_ACTIVE Indicates that compression or decompression is active. (Read only). - **DECODE** Indicates that compressor is in decode mode. (Read Only) - I<sup>2</sup>S\_MM Enables I<sup>2</sup>S master mode. With this bit set to one, the device generates I<sup>2</sup>S SCK and WS at 32fs. - I<sup>2</sup>S ATT Enables 3dB of attenuation when left and right channels are mixed. - PLL\_LOCK Indicates that the PLL is locked. If this bit is zero it indicates the PLL is attempting to lock on the input clock. (Read Only) ### Table 12-23 CFG18 Register | | CFG18 Configuration Register | | | | | | | | | | | | |------------|-------------------------------------------------|--------------|-----------------|-------------|---------------|-----------------|-------------|--|--|--|--|--| | Bit 7 | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | | | ANA_<br>EN | MUTE_<br>SPK- | BTL_MO<br>DE | SPK-<br>_IN_SEL | PU_SPK<br>- | MUTE_<br>SPK+ | SPK+_IN_<br>SEL | PU_SPK<br>+ | | | | | | ### Default 0x00: PWM is selected by default. CFG18 controls the configuration of the two pins SPK+ and SPK-: - **PU SPK+** Powers up SPK+. - SPK+\_IN\_SEL - - O When ANA EN = 1 and BTL MODE = 1: - SPK+\_IN\_SEL selects the source of the Class-AB BTL output: - SPK+\_IN\_SEL = 1: the source is DAC. - SPK+ IN SEL = 0: the source is SUM2. - When ANA\_EN = 1 and BTL\_MODE = 0 (separate outputs): - SPK+\_IN\_SEL selects the source of the SPK+ output: - SPK+\_IN\_SEL = 1: the source is DAC. - SPK+\_IN\_SEL = 0: the source is SUM2. - MUTE\_SPK+ Mutes SPK+ output. - PU\_SPK- Powers up SPK-. - SPK-\_IN\_SEL - - When ANA\_EN = 1 and BTL\_MODE = 1: SPK-\_IN\_SEL is not functional. - When ANA\_EN = 1 and BTL\_MODE = 0: SPK-\_IN\_SEL selects the signal source of the SPK- pin. - When SPK-\_IN\_SEL =1: the source is SUM2. - When SPK- IN SEL =0: the source is AUXIN. - BTL\_MODE - - When ANA\_EN = 1 and BTL\_MODE = 1: the speaker driver operates in Class-AB BTL mode for driving a speaker. - When ANA\_EN = 1 and BTL\_MODE = 0: each speaker driver pin operates independently. - MUTE SPK- Mutes SPK- output. - ANA EN- - When ANA\_EN = 1: the speaker driver operates in the analog mode. - When ANA\_EN = 0: the speaker driver operates in the PWM mode. When operating in PWM mode, all remaining bits in CFG18 are not functional. The figure below shows an example of Class-AB BTL setting from the DAC. Figure 12-1 DAC to Class-AB BTL (the red line) ## Table 12-24 CFG19 Register | | CFG19 Configuration Register | | | | | | | | | | | |-------|------------------------------|-------|-------|-------|-------|-------|-------|--|--|--|--| | Bit 7 | | | | | | | | | | | | | GPIO7 | GPIO6 | GPIO5 | GPIO4 | GPIO3 | GPIO2 | GPIO1 | GPIO0 | | | | | | DOUT | | | | ## Default 0x00: This register sets the value to output to GPIO when OE is 1. # Table 12-25 CFG1A Register | CFG1A Configuration Register | | | | | | | | | | |------------------------------|-------|-------|-------|-------|-------|-------|-------|--|--| | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | GPIO7 | GPIO6 | GPIO5 | GPIO4 | GPIO3 | GPIO2 | GPIO1 | GPIO0 | | | | OE | | ### Default 0x00: • Set to input (output disabled). This register sets Output-Enable to GPIO - 1: output enabled. - 0: output disabled. ## Table 12-26 CFG1B Register | CFG1B Configuration Register | | | | | | | | | | | |------------------------------|-------|-------|-------|-------|-------|-------|-------|--|--|--| | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | | GPIO7 | GPIO6 | GPIO5 | GPIO4 | GPIO3 | GPIO2 | GPIO1 | GPIO0 | | | | | PE | | | ### Default 0xFF: pull up/down enabled. This register sets Pull-up/down-Enable to GPIO - 1: pull up/down enabled. - 0: pull up/down disabled. Table 12-27 CFG1C Register (Read Only) | CFG1C Configuration Register | | | | | | | | | | | |------------------------------|-------|-------|-------|-------|-------|-------|-------|--|--|--| | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | | GPIO7 | GPIO6 | GPIO5 | GPIO4 | GPIO3 | GPIO2 | GPIO1 | GPIO0 | | | | | DIN | | | This register monitors the GPIO input value. Table 12-28 CFG1D Register | CFG1D Configuration Register | | | | | | | | | | |------------------------------|-------|-------|-------|-------|-------|-------|-------|--|--| | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | GPIO7 | GPIO6 | GPIO5 | GPIO4 | GPIO3 | GPIO2 | GPIO1 | GPIO0 | | | | PS | | #### Default 0xFF: Set to pull-up. This register selects Pull-up or pull-down when PE is 1. • 1: pull up 0: pull down Table 12-29 CFG1E & CFG1F Register | CFG1E & CFG1F Configuration Register | | | | | | | | | | | |---------------------------------------------------------------------------------------------------------|-----------------------------------------|--|--|--|--|--|--|--|--|--| | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | | | CFG1E AF1 (GPIO Alternative Function 1) | | | | | | | | | | | | CFG1F AF0 (GPIO Alternative Function 0) | | | | | | | | | | ### CFG1E Default 0x00: #### CFG1F Default 0x0F: - GPIO 7 ~ 4: GPIO pins. - GPIO 3 ~ 0: SPI interface. ISD3800 has eight GPIO pins in total. Each GPIO pin is configurable: GPIO pins 7 $\sim$ 4 could be either I<sup>2</sup>S interface or general I/O pins. GPIO pins 3 $\sim$ 0 could be either SPI interface or general I/O pins. Regardless how the GPIO pins 0 and 1 are configured, these two pins turn into the SPI interface whenever the SSB pin goes low and resume back to their configurations when the SSB pin goes back to high. On the contrary, GPIO pins 2 and 3 don't automatically change their configurations when SSB pin goes low. Users shall especially pay attention to the GPIO2 (RDY/BSYB) as RDY/BSYB pin is required when doing the digital-read or digital-write, but GPIO2 does not automatically change to RDY/BSYB pin as mentioned above. AF1 together with AF0 configure the eight GPIO pins to one of the four possible configurations as shown in the table below. Table 12-30 | | AF0 = 0 | AF0 = 1 | |---------|---------------------------------------|--------------------------------------------------------| | AF1 = 0 | General I/O | SPI or I2S depending on which GPIO pin it is. | | AF1 = 1 | Falling edge triggers the Voice Macro | Falling and rising edges both trigger the Voice Macro. | R0 ~ R7 in the following tables serve two purposes: - R0 ~ R7 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 - When a GPIO pin is configured as a trigger to wake up the ISD3800 and runs a specified VM, the VM index is stored in Rn, n = 0 ~ 7 (corresponding to GPIO pins 0 ~ 7). Table 12-31 CFG20 & CFG21 Register | CFG20 & CFG21 Configuration Register | | | | | | | | | | | |-------------------------------------------------|----------------------|--|--|--|--|--|--|--|--|--| | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | | | <b>CFG20</b> R0[7:0] | | | | | | | | | | | <b>CFG21</b> R0[15:8] | | | | | | | | | | | ### Table 12-32 CFG22 & CFG23 Register | | CFG22 & CFG23 Configuration Register | | | | | | | | | | | |---------------------------------------------------------------------------------------------------------|--------------------------------------|--|--|--|--|--|--|--|--|--|--| | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | | | | CFG22 R1[7:0] | | | | | | | | | | | | The state | CFG23 R1[15:8] | | | | | | | | | | | # Table 12-33 CFG24 & CFG25 Register | | CFG24 & CFG25 Configuration Register | | | | | | | | | | | |-------------------------------------------------|--------------------------------------|---|-------|------------------|--|--|--|--|--|--|--| | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | | | 57 | 6 | ń | CFG2 | <b>4</b> R2[7:0] | | | | | | | | | | 100 | 5 | CFG25 | 5 R2[15:8] | | | | | | | | # Table 12-34 CFG26 & CFG27 Register | CFG26 & CFG27 Configuration Register | | | | | | | | | | | |--------------------------------------|-------|-------|-------|-------------------|-------|-------|-------|--|--|--| | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | | | | | CFG2 | <b>26</b> R3[7:0] | 100 | | | | | | | | | | CFG2 | <b>7</b> R3[15:8] | 284 | | | | | | # Table 12-35 CFG28 & CFG29 Register | CFG28 & CFG29 Configuration Register | | | | | | | | | | | |-------------------------------------------------|----------------------|--|--|--|--|--|--|--|--|--| | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | | | <b>CFG28</b> R4[7:0] | | | | | | | | | | | <b>CFG29</b> R4[15:8] | | | | | | | | | | | # Table 12-36 CFG2A & CFG2B Register | CFG2A & CFG2B Configuration Register | | | | | | | | | | | | |-------------------------------------------------|-----------------------|--|------|------------------|--|--|---|--|--|--|--| | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | | | | | | CFG2 | <b>A</b> R5[7:0] | | | 9 | | | | | | | <b>CFG2B</b> R5[15:8] | | | | | | | | | | | # Table 12-37 CFG2C & CFG2D Register | CFG2C & CFG2D Configuration Register | | | | | | | | | | | |--------------------------------------|-------------------------------------------------|--|--|--|--|--|--|--|--|--| | Bit 7 | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | | <b>CFG2C</b> R6[7:0] | | | | | | | | | | | | <b>CFG2D</b> R6[15:8] | | | | | | | | | | # Table 12-38 CFG2E & CFG2F Register | | CFG2E & CFG2F Configuration Register | | | | | | | | | | |-----------|-------------------------------------------------|--|------|------------------|--|--|--|--|--|--| | Bit 7 | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | Che Cally | 16 | | CFG2 | <b>E</b> R7[7:0] | | | | | | | | 627 | <b>CFG2F</b> R7[15:8] | | | | | | | | | | ### Table 12-39 CFG30 Register | CFG30 Configuration Register | | | | | | | | | | | |------------------------------|--------|-------|-------|-------|-------|----------|-------|--|--|--| | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | | | | | | DISCH | 11211 | RESET_ | SIL_ | | | | | TALARM | TSENSE | 0 | 1 | REG | 3 | CHECKSUM | 32_8 | | | | Default 0xD1 (users should not change bits $4 \sim 7$ ): - Silence is played in 32ms increments. - The 3V flash regulator output is not discharged on power down. ## This register controls the following: - SIL\_32\_8 when set to 1, silence is played in 32ms increments. When set to 0, silence is played in 8ms increments. - RESET\_CHECKSUM write a 1 followed a 0 to this bit to reset the CHECKSUM CFG31 ~ CFG34. - **DISCH\_REG** when this bit is set, a 500-ohm pull-down will be enabled on the 3V flash regulator output on power down to discharge the regulator. - TSENSE when this bit is set, device will issue interrupt on INTB pin when device temperature exceeds the threshold. - TALARM when this bit is set, device will shutdown itself when device temperature exceeds the threshold. Table 12-40 CFG31 ~ CFG34 Register | CFG31 ~ CFG34 Configuration Register | | | | | | | | | | | |--------------------------------------|-----------------------|--|----------|-------------|----|--|--|--|--|--| | Bit 7 | Bit 7 | | | | | | | | | | | CFG31 CHECKSUM[7:0] | | | | | | | | | | | | | | | CFG32 CH | ECKSUM[15:8 | B] | | | | | | | | CFG33 CHECKSUM[23:16] | | | | | | | | | | | | CFG34 CHECKSUM[31:24] | | | | | | | | | | ## CFG31 ~ CFG34 are read-only registers. The SPI command CHECKSUM initiates a 4-byte checksum calculation from the very beginning to the specified end address. The calculated checksum is stored in registers CFG31 $\sim$ CFG34. To recalculate the checksum with a different end address, users have to set register CFG30 bit-1 to clear the registers CFG31 $\sim$ CFG0x34. Table 12-41 CFG35 Register | <b>CFG35 Configuration</b> | Register | |----------------------------|----------| | | | | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |------------------|---------------|-------|-------|-------|-------|-------|-------| | SOFT_M<br>UTE_EN | SOFT_M<br>UTE | - | - | 1 | - | - | - | #### Default 0x00: Soft-mute block is disabled. This register soft-mutes the SPK +/-. Different from the normal-mute (CFG18 bit-2 & bit-6), soft-mute ramps the input to the signal path to zero before it mutes the output. - **SOFT\_MUTE\_EN –** Enables the soft-mute block. - SOFT MUTE soft-mute the SPK +/-. ### Table 12-42 CFG36 Register | | CFG36 Configuration Register | | | | | | | | | | |-------|-------------------------------------------------|---|---|---|-----------|--|--|--|--|--| | Bit 7 | Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 | | | | | | | | | | | - | - | - | - | - | VMID_CTRL | | | | | | ### Default 0x00: • AUTO: during power-down, $V_{MID}$ is tied to $V_{SSA}$ . Once the ISD3800 is powered up, $V_{MID}$ automatically begins to ramp to $V_{CCA}$ /2. This register controls pin 45 $V_{MID}$ , the middle voltage reference of $V_{CCA}$ . $V_{MID}$ is the analog ground reference. It is the middle of swings of analog input (Aux-in) and analog outputs (Aux-out and Class-AB). - **000** AUTO: during power-down, $V_{MID}$ is tied to $V_{SSA}$ . Once the ISD3800 is powered up, $V_{MID}$ automatically begins to ramp to $V_{CCA}$ /2. - **001** 5K: V<sub>MID</sub> ramps to V<sub>CCA</sub> /2 through a 5k-ohm resistor. - **010** 600K: V<sub>MID</sub> ramps to V<sub>CCA</sub> /2 through a 600k-ohm resistor. - **011** 600K to V<sub>SSA</sub>: V<sub>MID</sub> ramps to V<sub>SSA</sub> through a 600k-ohm pull-down resistor. - 100 Reserved. - 101 5K to V<sub>SSA</sub>: V<sub>MID</sub> ramps to V<sub>SSA</sub> through a 5k-ohm pull-down resistor. - 110 5K to V<sub>CCA</sub>: V<sub>MID</sub> ramps to V<sub>CCA</sub> through a 5k-ohm pull-high resistor. - 111 Reserved. Please note that by default $V_{MID}$ does not ramp before POI/PU Macro is finished. So, $V_{MID}$ is held low in POI and PU. If users want to use analog outputs in POI or PU users must configure $V_{MID}$ . ### 12.4 DEVICE IDENTIFICATION REGISTERS. By sending the command READ\_ID the device responds with a four-byte identification. The first byte reports the ISD3800 family version. The following three bytes are a JEDEC compliant code indicating the memory type. ### 13 SPI COMMANDS The ISD3800 provides SPI commands including: (1) 11 audio play commands, (2) 3 device status commands, (3) 5 digital commands, and (4) 6 device configuration commands. The following section contains a list of all SPI commands and their function. Table 13-1 SPI Commands | Instructions | Byte 0 | Byte 1 | Byte 2 | Byte 3 | Byte 4 Byte n | Description | |---------------|--------|-------------|-------------------|-------------------|------------------------------|-------------------------------------------------------------------------------------| | PLAY_VP | 0xA6 | Index[15:8] | Index[7:0] | | | Play Voice Prompt Index | | PLAY_VP@Rn | 0xAE | n = 07 | | | | Play Voice Prompt; Index @ Rn | | PLAY VP LP | 0xA4 | Index[15:8] | Index[7:0] | LoopCnt[1<br>5:8] | LoopCnt[7:0] | Loop Play Voice Prompt Index | | PLAY VP LP@Rn | 0xB2 | n = 07 | LoopCnt[1<br>5:8] | LoopCnt[<br>7:0] | | Loop Play Voice Prompt; Index @ Rn | | STOP_LP | 0x2E | | | | | Stop Loop Play Voice Prompt | | EXE_VM | 0xB0 | Index[15:8] | Index[7:0] | | | Execute voice macro Index | | EXE VM@Rn | 0xBC | n = 07 | | | | Execute voice macro; Index @ Rn | | PLAY SIL | 0xA8 | LEN[7:0] | | | | Play silence for LEN*32ms | | STOP | 0x2A | | | | | STOP current playback operation. | | SPI PCM READ | 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 ISD3800 via SPI interface. | | SPI SND DEC | 0xC0 | D0[7:0] | D1[7:0] | D2[7:0] | D3[7:0]Dn[7:0] | Send compressed audio data to ISD3800 via SPI interface for decoding. | | READ_STATUS | 0x40 | XX | XX | XX | | Query status of ISD3800. | | READ INT | 0x46 | XX | XX | XX | | Query status and clear interrupt flags of ISD3800. | | READ_ID | 0x48 | XX | XX | XX | XX | Read device ID of ISD3800. | | 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] | 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. | | Instructions | Byte 0 | Byte 1 | Byte 2 | Byte 3 | Byte 4 Byte n | Description | |-----------------|--------|------------------|----------|-----------------|---------------|--------------------------------------------------------------------------------------| | <u>CHECKSUM</u> | 0xF2 | EA[23:16] | EA[15:8] | EA[7:0] | | Calculate checksum from very beginning to the specified end address. | | PWR_UP | 0x10 | | | | | Power up ISD3800 | | PWR_DN | 0x12 | | | | | Power down ISD3800 | | SET CLK CFG | 0xB4 | CFG_CLK[<br>7:0] | | | | Set clock configuration register. | | RD_CLK_CFG | 0xB6 | XX | | | | Read clock configuration register. | | WR CFG REG | 0xB8 | REG[7:0] | | D0[7:0],Dn[7:0] | | Write data D0Dn to configuration register(s) starting at configuration register REG. | | RD CFG REG | 0xBA | 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 13-2 Commands vs. Status | | Op | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |---------------|------|-------|----------|-------|-------|--------|--------|----------|---------| | Instructions | Code | PD | DBUF_RDY | INT | - | TALARM | VM_BSY | CBUF_FUL | CMD_BSY | | PLAY_VP | 0xA6 | 0 | 1 | X | 1 | X | 0 | 0 | X | | PLAY VP@Rn | 0xAE | 0 | 1 | Х | - | Х | 0 | 0 | X | | PLAY_VP_LP | 0xA4 | 0 | 1 | Х | - | X | 0 | 0 | X | | PLAY_VP_LP@Rn | 0xB2 | 0 | 1 | Х | - | Х | 0 | 0 | X | | STOP_LP | 0x2E | 0 | 1 | Х | - | Х | Х | Х | X | | EXE_VM | 0xB0 | 0 | 1 | Х | - | Х | 0 | 0 | 0 | | EXE VM@Rn | 0xBC | 0 | 1 | Х | - | Х | 0 | 0 | 0 | | PLAY_SIL | 0xA8 | 0 | 1 | Х | - | X | 0 | 0 | X | | <u>STOP</u> | 0x2A | 0 | 1 | Х | - | X | X | X | X | | SPI_PCM_READ | 0xAC | 0 | 1 | Х | - | Х | Х | Х | X | | SPI_SND_DEC | 0xC0 | 0 | 1 | Х | - | Х | 0 | 0 | 0 | | READ_STATUS | 0x40 | Х | Х | Х | - | х | Х | Х | Х | | READ_INT | 0x46 | X | Х | Х | - | X | X | X | X | | READ ID | 0x48 | 0 | (A) 1 | Х | - | X | X | Х | X | | DIG_READ | 0xA2 | 0 | 1 | Х | - | Х | Х | Х | Х | | | Ор | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | |--------------|------|-------|----------|-------|-------|--------|--------|----------|---------| | Instructions | Code | PD | DBUF_RDY | INT | - | TALARM | VM_BSY | CBUF_FUL | CMD_BSY | | DIG_WRITE | 0xA0 | 0 | 1 | X | 12 | X | X | Х | Х | | ERASE_MEM | 0x24 | 0 | 1 | X | 39 | X | 0 | 0 | 0 | | CHIP ERASE | 0x26 | 0 | 1 | X | - | X | 0 | 0 | 0 | | CHECKSUM | 0xF2 | 0 | 1 | X | - | X | 0 | 0 | 0 | | PWR_UP | 0x10 | 1 | 0 | Х | - | Х | X | Х | Х | | PWR DN | 0x12 | 0 | 1 | X | - | Х | X | X | Х | | SET_CLK_CFG | 0xB4 | 0 | 1 | X | - | Х | 0 | 0 | 0 | | RD_CLK_CFG | 0xB6 | 0 | 1 | X | - | Х | X | X | Х | | WR_CFG_REG | 0xB8 | 0 | 1 | Х | - | X | Х | X | X | | RD_CFG_REG | 0xBA | 0 | 1 | X | ı | X | Х | X | X | #### 13.1 AUDIO PLAY COMMANDS This section describes the 11 audio commands that can be sent to the device. ## 13.1.1 Play Voice Prompt | PLAY_VP | | | | | | | | |--------------------------|-------------------------------------------------------------|-------------|-------------|-------------|--|--|--| | Byte Sequence: | Host controller | 0xA6 | Index[15:8] | Index[7:0] | | | | | | ISD3800 | Status Byte | Status Byte | Status Byte | | | | | Description: | Play Voice Prompt | Index | | | | | | | Interrupt<br>Generation: | CMD_ERR if not accepted. CMD_FIN when playback is finished. | | | | | | | 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. ### 13.1.2 Play Voice Prompt @Rn, $n = 0 \sim 7$ | PLAY_VP@Rn | | 100 | 9 | | | |--------------------------|-----------------------------|--------------------|----------------------------|--|--| | Byte Sequence: | Host controller | 0xAE | n = 0 ~ 7 | | | | | ISD3800 | Status Byte | Status Byte | | | | Description: | Play Voice Prompt, Index@Rn | | | | | | Interrupt<br>Generation: | CMD_ERR if not ac | ccepted. CMD_FIN v | vhen playback is finished. | | | 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 ### 13.1.3 Play Voice Prompt, Loop | PLAY_VP_LP | | | | | | | | |--------------------------|-----------------|-------------------------------------------------------------|-------------|-------------|-------------------|---------------|--| | Byte Sequence: | Host controller | 0xA4 | Index[15:8] | Index[7:0] | LoopCnt[15<br>:8] | LoopCnt[7: 0] | | | | ISD3800 | 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 | CMD_ERR if not accepted. CMD_FIN when playback is finished. | | | | | | 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. ## 13.1.4 Play Voice Prompt, Loop, @Rn, n = 0 ~ 7 | PLAY_VP_LP@Rn | | | | | | | |--------------------------|-------------------------------------------------------------|-----------------------------------|-------------|--------------|--------------|--| | Byte Sequence: | Host controller | 0xB2 | n = 0 ~ 7 | LoopCnt[15:8 | LoopCnt[7:0] | | | | ISD3800 | Status Byte | Status Byte | Status Byte | Status Byte | | | Description: | Play Voice Pro | Play Voice Prompt, Loop, Index@Rn | | | | | | Interrupt<br>Generation: | CMD_ERR if not accepted. CMD_FIN when playback is finished. | | | | | | This command is same as PlayVP\_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 ### 13.1.5 Stop Loop-Play Command | STOP_LP | | | | | | |--------------------------|--------------------------------------------------------------------------------------|-------------|--|--|--| | Byte Sequence: | Host controller | 0x2E | | | | | | ISD3800 | Status Byte | | | | | Description: | Stop current loop-play 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 PLAY\_VP\_LP or PLAY\_VP\_LP@Rn command active in the ISD3800. 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 command then STOP will have no effect. #### 13.1.6 Execute Voice Macro | EXE_VM | | | 8 | | | | |--------------------------|-------------------------------------------------------------|------------------------|-------------|-------------|--|--| | Byte Sequence: | Host controller | 0xB0 | Index[15:8] | Index[7:0] | | | | | ISD3800 | Status Byte | Status Byte | Status Byte | | | | Description: | Play voice macro II | Play voice macro Index | | | | | | Interrupt<br>Generation: | CMD_ERR if not accepted. CMD_FIN when playback is finished. | | | | | | This command initiates the execution of a pre-recorded voice macro. 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. ### 13.1.7 Execute Voice Macro @Rn, n = 0 ~ 7 | EXE_VM@Rn | | | | 450 | | | |--------------------------|-------------------------------------------------------------|---------------------------|-------------|-----|--|--| | Byte Sequence: | Host controller | 0xBC | n = 0 ~ 7 | - | | | | | ISD3800 | Status Byte | Status Byte | | | | | Description: | Play voice macro Ir | Play voice macro Index@Rn | | | | | | Interrupt<br>Generation: | CMD_ERR if not accepted. CMD_FIN when playback is 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 ### 13.1.8 Play Silence | PLAY_SIL | | 753 | | | | | |--------------------------|----------------------|---------------------------|-----------------------|-----------|--|--| | Byte Sequence: | Host controller | 0xA8 | <i>LEN</i> [7:0] | | | | | | ISD3800 | Status Byte 0 | Status Byte 0 | | | | | Description: | Play silence for LEN | Play silence for LEN*32ms | | | | | | Interrupt<br>Generation: | CMD_ERR if not ac | ccepted. 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 32kHz), 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. ### 13.1.9 Stop Command | STOP | | | | | | | |--------------------------|--------------------------------------------------------------------------------------|------------------------------------------------------|--|--|--|--| | Byte Sequence: | Host controller | 0x2A | | | | | | | ISD3800 | Status Byte | | | | | | Description: | Stop current audio | 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 ISD3800. If a PLAY\_VP, EXE\_VM or PLAY\_SIL command is active playback is stopped immediately. 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\_MEM operation. If there is no active command then STOP will have no effect. #### 13.1.10 SPI Read PCM Data | SPI_PCM_READ | | | 75 | | | | | |--------------------------|------------------------------|------------------------------------|---------|----------|--|---------|----------| | Byte Sequence: | Host controller | 0xAC | | | | | | | | ISD3800 | Status Byte | D0[7:0] | D0[15:8] | | Dn[7:0] | Dn[15:8] | | Description: | Read audio da | Read audio data via SPI interface. | | | | | | | Interrupt<br>Generation: | OVF_ERR if RDY/BSY violated. | | | | | | | 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 audio data from memory (SPI playback), then: (1) signal path must be set up for SPI output from the compressor. (2) A valid play command is then sent; valid play commands include PlayVP, PlayVP@Rn, PlayVP\_LP, PlayVP\_LP@Rn, ExeVM and ExeVM@Rn. (3) Followed by the SPI\_PCM\_READ command. Multiple SPI\_PCM\_READ commands can be sent. (4) 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. If the valid play command in step (2) is ExeVM, then a CMD FIN interrupt will be generated at the end of voice macro. Figure 13-1 SPI Playback The RDY/BSYB pin will go low whenever the internal FIFO is empty. If no path or playback operation is set up then RDY/BSYB pin will be low until command is terminated. If RDY/BSYB is ignored then an OVF ERR interrupt is generated. A COLONIANO NO PARTICIONAL PROPERTIES AND PROPERTIE | SPI_SND_DEC | | | TEX | | | | |--------------------------|------------------------------------------------|----------------|---------|---------|--|---------| | | Host controller | 0xC0 | D0[7:0] | D1[7:0] | | Dn[7:0] | | Byte Sequence: | ISD3800 | Status<br>Byte | | ** | | | | Description: | Write compressed audio data via SPI interface. | | | | | | | Interrupt<br>Generation: | OVF_ERR if RDY/BSYB violated. | | | | | | 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 (1) a valid signal path must be set up. Valid paths are similar to a standard playback. SPI\_SND\_DEC commands can be issued to send data to the ISD3800. (3) To finish decoding a STOP command is sent and device will respond with a CMD\_FIN interrupt. RDY/BSYB pin 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 13-2 SPI Send Compressed Data to Decode The RDY/BSYB pin will go low whenever the internal FIFO is full. If no path set up to accept audio data then RDY/BSYB pin 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 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. ### 13.2 DEVICE STATUS COMMANDS. This section describes the 3 status commands that can be sent to the device. #### 13.2.1 Read Status ### Powered up: | READ_STATUS | | | | |----------------|---------------------|-------------|-----------------------| | Puto Coguenco: | Host controller | 0x40 | 0xXX | | Byte Sequence: | ISD3800 | Status Byte | Interrupt Status Byte | | Description: | Query device status | | | #### Powered down: | READ_STATUS | | | 1.5 | (A) (B) | |----------------|----------------------|-----------------|------|---------| | Pyto Soguenos: | Host controller | 0x40 | 0xXX | 200 | | Byte Sequence: | ISD3800 | Status Byte 80h | 00h | 60 | | Description: | Query device status. | | | | This command queries the ISD3800 device status. For details of device status see Section 12.2. If device is powered up, the two status bytes will be repeated for each two 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. ## 13.2.2 Read Interrupt | READ_INT | | | | | | | |----------------|---------------------|------------------------------------------------|-----------------------|--|--|--| | Puto Coguenos: | Host controller | 0x46 | 0xXX | | | | | Byte Sequence: | ISD3800 | Status Byte | Interrupt Status Byte | | | | | Description: | Query device status | Query device status and clear interrupt flags. | | | | | This command queries the ISD3800 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. #### 13.2.3 Read ISD3800 ID | READ_ID | | | | | | | |--------------|-------------------------------------|-------------|---------|--------|----------|--------| | Byte | Host controller | 0x48 | 0xXX | 0xXX | 0xXX | 0xXX | | Sequence: | ISD3800 | Status Byte | PART_ID | MAN_ID | MEM_TYPE | DEV_ID | | Description: | Return memory ID of internal memory | | | | | | This command queries the ISD3800 to returns four bytes to indicate the ISD3800 family member and the manufacturer, size and type of internal memory of the device. The four bytes returned are: - One byte ISD3800 Family ID, which is 0x04. - Three bytes Flash JEDEC ID. #### 13.3 DIGITAL MEMORY COMMANDS. This section describes the 5 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. 13.3.1 Digital Read | DIG_READ | | | | | | | | | |--------------------------|-----------------------------|---------------------------------------------------------------------------------------|--------------|-----------|--------|------|--|------| | Byte | Host controller | 0xA2 | A[23:16] | A[15:8] | A[7:0] | 0xXX | | 0xXX | | Sequence: | ISD3800 | Status | Status | Status | Status | D0 | | Dn | | Description: | Initiates a digital | read of me | emory from a | ddress A[ | 23:0]. | | | | | Interrupt<br>Generation: | ADDR_ERR if m end of array. | ADDR_ERR if memory protected or RDY/BSYB violated. OVF_ERR if read past end of array. | | | | | | | 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 pin is used to control flow of data. If RDY/BSYB pin goes low, transfer must be paused until RDY/BSYB pin returns high. The user should check RDY/BSYB pin 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 pin 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. ### 13.3.2 Digital Write | DIG_WRITE | | | , a | | | | | | |--------------------------|-------------------------|------------|--------------|-----------|-------------|--------|----------|----------| | Byte | Host controller | 0xA0 | A[23:16] | A[15:8] | A[7:0] | D0 | | Dn | | Sequence: | ISD3800 | Status | Status | Status | Status | Status | | Status | | Description: | Initiates a digital | write to m | emory from | address A | [23:0]. | | | | | Interrupt<br>Generation: | ADDR_ERR if m of array. | emory pro | tected or RI | DY/BSYB v | /iolated. C | VF_ERR | if 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 pin is used to control flow of data. If RDY/BSYB pin goes low, transfer must be paused until RDY/BSYB pin returns high. The user should check RDY/BSYB pin 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 pin 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 ISD3800 will finish the flash write operation. When this operation is complete the ISD3800 will generate a WR\_FIN interrupt. While device is actively writing to flash memory the CMD\_BSY bit will be active. ### 13.3.3 Erase Memory | ERASE_MEM | | | | | | | | | |--------------------------|-----------------|-------------------------------------------------------------------------------------------------|---------------|------------|------------|-------------|----------|---------| | Byte<br>Sequence: | Host controller | 0x24 | SA[23:16] | SA[15:8] | SA[7:0] | EA[23:16] | EA[15:8] | EA[7:0] | | 2 | ISD3800 | Status | Description: | Erases men | nory from | sector contai | ning SA to | sector con | taining EA. | | | | Interrupt<br>Generation: | _ | ADDR_ERR if memory protected. CMD_ERR if device is busy. CMD_FIN when erase operation 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 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 pin 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. ### 13.3.4 Chip Erase | CHIP_ERASE | | | KO X X | |--------------------------|---------------------------------------|---------------|-------------------------------------| | Byte Sequence: | Host controller | 0x26 | 0x01 | | | ISD3800 | Status Byte | Status Byte | | Description: | Initiate a mass eras | se of memory. | | | Interrupt<br>Generation: | CMD_ERR if device erase operation cor | | cannot accept command. CMD_FIN when | 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 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 pin 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. ### **13.3.5 CHECKSUM** | CHECKSUM | | | | | | |--------------------------|----------------------------|----------------|----------------|---------------|--------------| | Byte Sequence: | Host controller | 0xF2 | EA[23:16] | EA[15:8] | EA[7:0] | | 700 | ISD3800 | 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 0x31[7:0] 0x32[15:8] 0x33[23:16] 0x34[31:24]. To recalculate the checksum with a different end address, users have to set register 0x30 bit-1 to clear the registers $0x31 \sim 0x34$ . 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. When CHECKSUM is in progress, the Status bit 0 CMD\_BSY goes high. Users could poll the status to see if the erasing is done. #### 13.4 DEVICE CONFIGURATION COMMANDS. This section describes 6 commands used to configure the ISD3800. 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. The signal path, compression and sample rate configuration are controlled by forty-eight bytes of configuration register. These forty-eight bytes can be written individually or in a continuous sequential manner. These configuration registers are double buffered such that a new configuration can be loaded and only set active when the user desires. ### 13.4.1 PWR\_UP - Power up | PWR_UP | | | | | | |----------------|-------------------------------------------------------|--------|--|--|--| | Byte Sequence: | Host controller | 0x10 | | | | | | ISD3800 | Status | | | | | Description: | Powers up device and initiates the power up sequence. | | | | | 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 power up the internal oscillator. 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 ISD3800. A formal power-up procedure is as follows: - Send PWR UP command. - Poll Status until bit-6 DBUF RDY goes high, which means ready. - Poll Status until bit-2 VM\_BSY goes low, which means voice macro 1 finishes. #### 13.4.2 PWR\_DN - Power Down | PWR_DN | | | - TEN | | | | |----------------|-----------------|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Byte Sequence: | Host controller | 0x12 | Dr. A | | | | | | ISD3800 | Status | CONTRACTOR OF THE PARTY | | | | | Description: | Powers down the | Powers down the device after any active commands 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 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. ### 13.4.3 SET\_CLK\_CFG - Set Clock Configuration Register | SET_CLK_CFG | | | | 400 | |----------------|-----------------|-------------------|--------------|-----| | Byte Sequence: | Host controller | 0xB4 | CFG_CLK[7:0] | 200 | | | ISD3800 | Status Byte | Status Byte | | | Description: | Loads clock co | nfiguration regis | ter. | | This sets the clock configuration register. The part reconfigures the clock and PLL configuration and waits for stable clock conditions before accepting new commands. When the configuration is changed, CMD\_BSY will go high until clock configuration is complete. No new commands should be sent until the device status shows device not busy. This command does not generate an interrupt. ### 13.4.4 RD\_CLK\_CFG - Read Clock Configuration Register This reads the clock configuration register. | RD_CLK_CFG | | | | | |----------------|-------------------|--------------------|--------------|--| | Byte Sequence: | Host controller | 0xB6 | 0xXX | | | n die | ISD3800 | Status Byte | CFG_CLK[7:0] | | | Description: | Reads clock confi | iguration register | | | ### 13.4.5 WR\_CFG\_REG - Write Configuration Register | WR_CFG_REG | | | | | | |----------------|---------------------------------------|---------|-------------|----|-----------| | Byte Sequence: | Host controller | 0xB8 | REG[7:0] | D0 | <br>Dn | | | ISD3800 | STATUS0 | 74 1 Jun 17 | | | | Description: | Loads configuration sent to load CFG[ | | | | .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 12.3 for details on configuration registers. There are forty-eight configuration registers in the ISD3800, REG0 – REG2F. ## 13.4.6 RD\_CFG\_REG - Read Configuration Register | RD_CFG_REG | | | | | \ | 50° | |----------------|-----------------------------------|---------|----------|----|---|-----| | Byte Sequence: | Host controller | 0xBA | REG[7:0] | Χ | | X | | | ISD3800 | STATUS0 | | D0 | | Dn | | Description: | Reads configurati bytes 1n can be | | | | | | This command reads the configuration register starting at the address specified. If multiple data bytes are sent, additional configuration registers are read. See Section 12.3 for details on configuration registers. ### 14 ELECTRICAL CHARACTERISTICS ### 14.1 OPERATING CONDITIONS # **OPERATING CONDITIONS (INDUSTRIAL PACKAGED PARTS)** | CONDITIONS | VALUES | |-------------------------------------------------------------------------------------|-----------------| | Operating temperature range (Case temperature) | -40°C to +85°C | | Digital Supply voltage (V <sub>CCD</sub> ) [1] | +2.7V to +5.5V | | Digital Ground voltage (V <sub>SSD</sub> ) [2] | 0V | | Analog Supply voltage (V <sub>CCA</sub> ) [3] | +2.7V to +5.5V | | Analog Ground voltage (V <sub>SSA</sub> ) [2] | 0V | | Speaker Supply voltage (V <sub>CCSPK</sub> ) [3] | +2.7V to +5.5V | | Speaker Ground voltage (V <sub>SSSPK</sub> ) [2] | 0V | | Flash Source Supply voltage (V <sub>CCFS</sub> ) [4] – to regulate V <sub>CCF</sub> | +2.7V to +5.5V | | Flash Source Supply voltage (V <sub>CCFS</sub> ) [4] – tied to V <sub>CCF</sub> | +2.25V to +3.6V | | Flash Supply voltage - (V <sub>CCF</sub> ) [4] – regulated from V <sub>CCFS</sub> | +2.4V to +3.0V | | Flash Supply voltage - (V <sub>CCF</sub> ) [4] - tied to V <sub>CCFS</sub> | +2.25V to +3.6V | ### NOTES: $<sup>^{[4]}</sup>$ If $V_{CCFS}$ is guaranteed to be below 3.6V (or upper flash supply limit), then $V_{CCF}$ should be tied to $V_{CCFS}$ . Figure 14-1 $V_{\text{CCF}}$ vs. $V_{\text{CCFS}} - V_{\text{CCF}}$ is regulated internally from $V_{\text{CCFS}}^{[4]}$ $<sup>^{[1]}</sup>V_{\text{CCD}}$ 2.7 ~ 5.5V; No restrictions with respect to $V_{\text{CCA}}$ and $V_{\text{CCSPK}}.$ $<sup>^{[2]}</sup>V_{SSD} = V_{SSA} = V_{SSSPK}$ <sup>&</sup>lt;sup>[3]</sup> In Class-AB mode: $V_{CCSPK}$ must equal $V_{CCA}$ . Otherwise: $V_{CCSPK} \ge V_{CCA}$ . ### 14.2 DC PARAMETERS | PARAMETER | SYMBOL | MIN | TYP<br>[1] | MAX | UNIT<br>S | CONDITIONS | |---------------------------------------------|--------------------------|-----------------------|---------------------------|----------------------|-----------|--------------------------------------------------------------| | Digital Supply Voltage | V <sub>CCD</sub> | 2.7 | 93 | 5.5 | V | | | Analog Supply Voltage | $V_{CCA}$ | 2.7 | | 5.5 | V | | | Speaker Supply Voltage | V <sub>CCSPK</sub> | 2.7 | | 5.5 | V | | | Flash Source Supply | \/ | 2.7 | | 5.5 | V | to regulate V <sub>CCF</sub> | | Voltage | V <sub>CCFS</sub> | 2.25 | | 3.6 | V | tied to V <sub>CCF</sub> | | | | | V <sub>CCFS</sub><br>-0.3 | | 8 | regulated from $V_{CCFS}$<br>$V_{CCFS} = 2.7 \sim 3.3V$ | | Flash Supply Voltage (refer to Figure 14-1) | V <sub>CCF</sub> | | 3.0 | | V | regulated from V <sub>CCFS</sub> $V_{CCFS} = 3.3 \sim 5.5 V$ | | | | 2.25 | | 3.6 | | tied to V <sub>CCFS</sub> | | Input Low Voltage | V <sub>IL</sub> | V <sub>SSD</sub> -0.3 | | 0.3xV <sub>CCD</sub> | V | (0) | | Input High Voltage | V <sub>IH</sub> | 0.7xV <sub>CCD</sub> | | V <sub>CCD</sub> | V | 16.0 5 | | Output Low Voltage | V <sub>OL</sub> | V <sub>SSD</sub> -0.3 | | 0.3xV <sub>CCD</sub> | V | I <sub>OL</sub> = 1mA | | Output High Voltage | V <sub>OH</sub> | 0.7xV <sub>CCD</sub> | | V <sub>CCD</sub> | V | I <sub>OH</sub> = -1mA | | INTB Output Low Voltage | V <sub>OH1</sub> | | | 0.4 | V | | | Playback Current | I <sub>DD_Playback</sub> | | | 30 | mA | | | Standby Current | I <sub>SB</sub> | | 1 | 10 | μA | | | Input Leakage Current | I <sub>IL</sub> | | ±1 | | μΑ | Force V <sub>CCD</sub> | Notes: [1] Conditions V<sub>CCD</sub>=V<sub>CCA</sub>=V<sub>CCSPK</sub>=V<sub>CCFS</sub>=3V, T<sub>A</sub>=25°C unless otherwise stated ### 14.3 AC PARAMETERS ### 14.3.1 Internal Oscillator | Parameter | Symbol | Min | Тур | Max | Units | CONDITIONS | |---------------------------------------------|------------------|-----|-----------|-----|-------|------------------------------------------------------------------------------------| | Internal oscillator with internal reference | FINT | -1% | 2.048 MHz | +1% | MHz | V <sub>CCD</sub> = 3.3V.<br>At room temperature. | | Internal oscillator with external reference | F <sub>ЕХТ</sub> | -2% | 2.048 MHz | +2% | MHz | With ±1% precision resistor, 80kohm. V <sub>CCD</sub> = 3.3V. At room temperature. | # 14.3.2 Inputs ### **AUX-IN:** Conditions: $V_{CCD} = 3.3V$ , $V_{CCA} = V_{CCSPK} = 5V$ , MCLK = 16.384MHz, $T_A = +25$ °C, 1kHz signal | Parameter | Symbol | Comments/Conditions | Min | Тур | Max | Units | |---------------------------------|----------------------|-----------------------------------------------------------------------------------------------------------|--------|----------------------|--------|----------------------| | Auxiliary Analog Inputs (AU) | (IN) | | | | 10% | 1 | | Full scale input signal 1 | | Gain = 0dB | | 1.0 | U | Vrms | | | | | | 0 | 17.5 | dBV | | AUX Programmable gain | | | 0 | | 9 | dB | | AUX programmable gain step size | | Guaranteed Monotonic | | 3 | | dB | | Input resistance | | Aux direct-to-out path, only Input gain = +9.0dB Input gain = +6.0dB Input gain = +3.0dB Input gain = 0dB | | 21<br>27<br>33<br>40 | | kΩ<br>kΩ<br>kΩ<br>kΩ | | Aux-in Gain Accuracy | A <sub>AUX(GA)</sub> | | -0.5dB | | +0.5dB | dB | Conditions: $V_{CCD} = 3.3V$ , $V_{CCA} = V_{CCSPK} = 3.3V$ , MCLK = 16.384MHz, $T_A = +25$ °C, 1kHz signal | Parameter | Symbol | Comments/Conditions | Min | Тур | Max | Units | |---------------------------------|---------|-------------------------|-----|-----|-----|-------| | Auxiliary Analog Inputs (AUX | KIN) | | | | | | | Full scale input signal 1 | | Gain = 0dB | | 1.0 | | Vrms | | | | | | 0 | | dBV | | AUX Programmable gain | | | 0 | | 9 | dB | | AUX programmable gain step size | | Guaranteed Monotonic | | 3 | | dB | | Input resistance | Raux_in | Aux direct-to-out path, | | | | | | (6.2 | 3/6 | only | | 21 | | kΩ | | 400 | -// | Input gain = +9.0dB | | 27 | | kΩ | | Parameter | Symbol | Comments/Conditions | Min | Тур | Max | Units | |----------------------|----------------------|---------------------|--------|-----|--------|-------| | | | Input gain = +6.0dB | | 33 | | kΩ | | | | Input gain = +3.0dB | | 40 | | kΩ | | | | Input gain = 0dB | | | | | | Aux-in Gain Accuracy | A <sub>AUX(GA)</sub> | -(/)// IIII | -0.5dB | | +0.5dB | dB | ## 14.3.3 **Outputs** ## **Aux-out** Conditions: $V_{CCD} = 3.3V$ , $V_{CCA} = V_{CCSPK} = 5V$ , MCLK = 16.384MHz, $T_A = +25$ °C, 1kHz signal | Parameter | Symbol | Comments/Conditions | Min Typ Max | | | Units | | | |----------------------------------------|-------------|-------------------------------------------------|------------------------|----------|----|-----------|--|--| | Digital to Analog Converter | (DAC) drivi | ng AUXOUT with $5k\Omega/10$ | 00pF load | 0pF load | | | | | | Full-scale output | | Gain paths all at 0dB gain | V <sub>CCA</sub> / 3.3 | | | $V_{rms}$ | | | | Signal-to-noise ratio | SNR | A-weighted | (1) | 85 | | dB | | | | Total harmonic distortion <sup>2</sup> | THD+N | $R_L = 5k\Omega$ ; full-scale signal A-weighted | | -80 | 26 | dB | | | Conditions: $V_{CCD} = 3.3V$ , $V_{CCA} = V_{CCSPK} = 3.3V$ , MCLK = 16.384MHz, $T_A = +25$ °C, 1kHz signal | Parameter | Symbol | Comments/Conditions | Min | Тур | Max | Units | | |----------------------------------------|------------|-------------------------------------------------|-----------|------------------------|-----|-----------|--| | Digital to Analog Converter ( | DAC) drivi | ng AUXOUT with $5k\Omega$ / 10 | 00pF load | | | | | | Full-scale output | | Gain paths all at 0dB gain | | V <sub>CCA</sub> / 3.3 | | $V_{rms}$ | | | Signal-to-noise ratio | SNR | A-weighted | | 80 | 184 | dB | | | Total harmonic distortion <sup>2</sup> | THD+N | $R_L = 5k\Omega$ ; full-scale signal A-weighted | | -77 | | dB | | ### **PWM OUTPUT** Conditions: $V_{CCD} = 3.3V$ , $V_{CCA} = V_{CCSPK} = 5V$ , MCLK = 16.384MHz, $T_A = +25^{\circ}C$ , 1kHz signal | Parameter | Symbol | Comments/Conditions | Min | Тур | Max | Units | |----------------------------------------|------------------|--------------------------------------------------|------------|-----|-----|-------| | Speaker PWM Output (SPK_ | PLUS / SPK | C_MINUS with 8Ω bridge- | tied-load) | ) | | | | Signal-to-noise ratio <sup>3</sup> | SNR | A-weighted + Class D<br>Filter | | 65 | | dB | | Total harmonic distortion <sup>2</sup> | THD | P <sub>o</sub> = 1W, A-weighted + Class D Filter | | -40 | | dB | | Efficiency | E <sub>PWM</sub> | $8\Omega$ bridge-tied-load<br>Pout > 0.2W | | 85 | | % | Conditions: $V_{CCD} = 3.3V$ , $V_{CCA} = V_{CCSPK} = 3.3V$ , MCLK = 16.384MHz, $T_A = +25$ °C, 1kHz signal | Parameter | Symbol | Comments/Conditions | Min | Тур | Max | Units | |----------------------------------------|------------|--------------------------------|------------|-----|-----|-------| | Speaker PWM Output (SPK_ | PLUS / SPI | K_MINUS with 8Ω bridge- | tied-load) | | | | | Signal-to-noise ratio <sup>3</sup> | SNR | A-weighted + Class D<br>Filter | | 65 | | dB | | Total harmonic distortion <sup>2</sup> | THD | A-weighted + Class D | | -40 | | dB | | Parameter | Symbol | Comments/Conditions | Min | Тур | Max | Units | |------------|------------------|---------------------|-----|-----|-----|-------| | | | Filter | | | | | | Efficiency | E <sub>PWM</sub> | 8Ω bridge-tied-load | | 80 | | % | | | | Pout > 0.2W | | | | | ## **CLASS-AB BTL OUTPUT** Conditions: V<sub>CCD</sub> = 3.3V, V<sub>CCA</sub> = V<sub>CCSPK</sub> = 5V, MCLK = 16.384MHz, T<sub>A</sub> = +25°C, 1kHz signal | Parameter | Symbol | Comments/Conditions | Min | Тур | Max | Units | | | |----------------------------------------|-----------------------------------------------------------------------------|---------------------------------|-----|-----------------------|-----|-----------|--|--| | Speaker CLASS-AB BTL Out | Speaker CLASS-AB BTL Output (SPK_PLUS / SPK_MINUS with 8Ω bridge-tied-load) | | | | | | | | | Full scale output | | Gain paths all at 0dB gain | É | V <sub>CCA</sub> / 3. | 3 | $V_{rms}$ | | | | Signal-to-noise ratio | SNR | A-weighted | | 90 | -72 | dB | | | | Total harmonic distortion <sup>2</sup> | THD | P <sub>o</sub> = 1W, A-weighted | | -60 | 5 | dB | | | | Efficiency | E <sub>AB</sub> | 8Ω bridge-tied-load | | 50 | 26 | % | | | | | | Pout > 0.7W | | J | 2 | | | | Conditions: $V_{CCD} = 3.3V$ , $V_{CCA} = V_{CCSPK} = 3.3V$ , MCLK = 16.384MHz, $T_A = +25$ °C, 1kHz signal | 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 | | , | | 3 | 100 | | |-----------------------------------------------------------------------------|-----------------|----------------------------|-----|------------------------|-----|------------------| | Parameter | Symbol | Comments/Conditions | Min | Тур | Max | Units | | Speaker CLASS-AB BTL Output (SPK_PLUS / SPK_MINUS with 8Ω bridge-tied-load) | | | | | | | | Full scale output | | Gain paths all at 0dB gain | | V <sub>CCA</sub> / 3.3 | 1 | V <sub>rms</sub> | | Signal-to-noise ratio | SNR | A-weighted | | 84 | | dB | | Total harmonic distortion <sup>2</sup> | THD | A-weighted | | -60 | | dB | | Efficiency | E <sub>AB</sub> | 8Ω bridge-tied-load | | 50 | | % | | | | Pout > 0.4W | | | | | ### Notes - 1. Full Scale is relative to the magnitude of VCCA and can be calculated as FS = VCCA/3.3. - 2. Distortion is measured in the standard way as the combined quantity of distortion products plus noise. The signal level for distortion measurements is at 3dB below full scale, unless otherwise noted. - 3. SNR measured with a -100dbFS signal at input. ### 14.3.4 DAC Frequency Responses The following graphs show the frequency responses of the signal path for analog or digital audio inputs. The data presented is for a master sample rate Fs=32kHz. For other values of Fs, Fsub scales accordingly. There is a built-in high-pass filter with cutoff 200Hz following the ADC filter. The graphs below show a combined effect. ### Playback Frequency Response Fs = 32kHz, Fsub = 4kHz ## Playback Frequency Response Fs = 32kHz, Fsub = 5.33kHz Playback Frequency Response Fs = 32kHz, Fsub = 6.4kHz ## Playback Frequency Response Fs = 32kHz, Fsub = 8kHz ### Playback Frequency Response Fs = 32kHz, Fsub = 12.8kHz Playback Frequency Response Fs = 32kHz, Fsub = 16kHz ## Playback Frequency Response Fs = 32kHz, Fsub = 32kHz # 14.3.5 SPI Timing Figure 14-2 SPI Timing | SYMBOL | DESCRIPTION | MIN | TYP | MAX | UNIT | |--------------------|------------------------------------------------------------------|------|-----|------|------| | T <sub>SCK</sub> | SCLK Cycle Time | 60 | | | ns | | T <sub>SCKH</sub> | SCLK High Pulse Width | 25 | | | ns | | T <sub>SCKL</sub> | SCLK Low Pulse Width | 25 | | | ns | | T <sub>RISE</sub> | Rise Time for All Digital Signals | | | 10 | ns | | T <sub>FALL</sub> | Fall Time for All Digital Signals | | | 10 | ns | | T <sub>SSBS</sub> | SSB Falling Edge to 1 <sup>st</sup> SCLK Falling Edge Setup Time | 30 | | | ns | | T <sub>SSBH</sub> | Last SCLK Rising Edge to SSB Rising Edge Hold Time | 30ns | | 50us | | | T <sub>SSBHI</sub> | SSB High Time between SSB Lows | | | | ns | | T <sub>MOS</sub> | MOSI to SCLK Rising Edge Setup Time | | | | ns | | T <sub>MOH</sub> | SCLK Rising Edge to MOSI Hold Time | | | | ns | | T <sub>ZMID</sub> | 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 | | SYMBOL | DESCRIPTION | MIN | TYP | MAX | UNIT | |-------------------|-----------------------------------------------------------|-----|-----|-----|------| | T <sub>MID</sub> | Delay Time from SCLK Falling Edge to MISO | | | 12 | ns | | T <sub>CRBD</sub> | Delay Time from SCLK Rising Edge to RDY/BSYB Falling Edge | | | 12 | ns | | T <sub>RBCD</sub> | Delay Time from RDY/BSYB Rising Edge to SCLK Falling Edge | 0 | | | ns | # 14.3.6 I<sup>2</sup>S Timing Figure 14-3 I<sup>2</sup>S Timing | SYMBOL | DESCRIPTION | | TYP | MAX | UNIT | |-------------------|-----------------------------------|----|-----|-----|------| | T <sub>SCK</sub> | IS_SCK Cycle Time | 60 | | | ns | | T <sub>SCKH</sub> | IS_SCK High Pulse Width | 25 | | | ns | | T <sub>SCKL</sub> | IS_SCK Low Pulse Width | 25 | | | ns | | T <sub>RISE</sub> | Rise Time for All Digital Signals | | | 10 | ns | | T <sub>FALL</sub> | Fall Time for All Digital Signals | | | 10 | ns | | SYMBOL | DESCRIPTION | MIN | TYP | MAX | UNIT | |-------------------|------------------------------------------------|-----|-----|-----|------| | T <sub>WSS</sub> | WS to IS_SCK Rising Edge Setup Time | 20 | | | ns | | T <sub>WSH</sub> | IS_SCK Rising Edge to IS_WS Hold Time | 20 | | | ns | | T <sub>SDIS</sub> | IS_SDI to IS_SCK Rising Edge Setup Time | 15 | | | ns | | T <sub>SDIH</sub> | IS_SCK Rising Edge to IS_SDI Hold Time | 15 | | | ns | | T <sub>SDOD</sub> | Delay Time from IS_SCLK Falling Edge to IS_SDO | 23 | 199 | 12 | ns | ## 15 APPLICATION DIAGRAM Figure 15-1 ISD3800 Application Diagram – $V_{\text{CCF}}$ is regulated internally from $V_{\text{CCFS}}$ # nuvoton Figure 15-2 ISD3800 Application Diagram – $V_{\text{CCF}}$ is tied to $V_{\text{CCFS}}$ The above application examples are for references only. It makes no representation or warranty that such applications shall be suitable for the use specified. Each design has to be optimized in its own system for the best performance on voice quality, current consumption, functionalities and etc. ## 16 PACKAGE SPECIFICATION ## 16.1 48 LEAD LQFP(7x7x1.4MM FOOTPRINT 2.0MM) # 17 ORDERING INFORMATION # **18 REVISION HISTORY** | Version | Date | Description | | | | |---------|--------------|------------------------------------------------------------------|--|--|--| | 0.28 | Oct 16, 2009 | Initially released as the Preliminary Design Guide. | | | | | 0.29 | Nov 3, 2009 | Update: | | | | | | | <ul> <li>Section 12.3 Device Configuration Registers.</li> </ul> | | | | | | | <ul> <li>Section 14.3 AC Parameters.</li> </ul> | | | | | 0.35 | Feb 8, 2010 | Update block diagram. | | | | | 0.40 | July 1, 2010 | Update crystal configuration. | | | | | 0.50 | Aug 12, 2010 | Update PWM spec. | | | | | 0.60 | Sep 22, 2010 | Update ordering information. | | | | | 0.64 | Sep 06, 2011 | Update package information. | | | | | | | Update Reg 0x30 description, and pin description. | | | | | 1.0 | Aug 23, 2013 | Add internal oscillator characteristics. | | | | | 1.1 | Mar 11, 2015 | Fix oscillator description. | | | | 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. The contents of this document are provided only as a guide for the applications of Nuvoton products. Nuvoton makes no representation or warranties with respect to the accuracy or completeness of the contents of this publication and reserves the right to discontinue or make changes to specifications and product descriptions at any time without notice. No license, whether express or implied, to any intellectual property or other right of Nuvoton or others is granted by this publication. Except as set forth in Nuvoton's Standard Terms and Conditions of Sale, Nuvoton assumes no liability whatsoever and disclaims any express or implied warranty of merchantability, fitness for a particular purpose or infringement of any Intellectual property. The contents of this document are provided "AS IS", and Nuvoton assumes no liability whatsoever and disclaims any express or implied warranty of merchantability, fitness for a particular purpose or infringement of any Intellectual property. In no event, shall Nuvoton be liable for any damages whatsoever (including, without limitation, damages for loss of profits, business interruption, loss of information) arising out of the use of or inability to use the contents of this documents, even if Nuvoton has been advised of the possibility of such damages. Application examples and alternative uses of any integrated circuit contained in this publication are for illustration only and Nuvoton makes no representation or warranty that such applications shall be suitable for the use specified. The 100-year retention and 100K record cycle projections are based upon accelerated reliability tests, as published in the Nuvoton Reliability Report, and are neither warranted nor guaranteed by Nuvoton. This datasheet and any future addendum to this datasheet is(are) the complete and controlling ISD® ChipCorder® product specifications. In the event any inconsistencies exist between the information in this and other product documentation, or in the event that other product documentation contains information in addition to the information in this, the information contained herein supersedes and governs such other information in its entirety. This datasheet is subject to change without notice. Copyright<sup>®</sup> 2005, Nuvoton Technology Corporation. All rights reserved. ChipCorder<sup>®</sup> and ISD<sup>®</sup> are trademarks of Nuvoton Electronics Corporation. All other trademarks are properties of their respective owners. ### Headquarters No. 4, Creation Rd. III Science-Based Industrial Park, Hsinchu, Taiwan TEL: 886-3-5770066 FAX: 886-3-5665577 http://www.nuvoton.com.tw/ #### **Taipei Office** 9F, No. 480, Pueiguang Rd. Neihu District Taipei, 114 Taiwan TEL: 886-2-81777168 FAX: 886-2-87153579 ### **Nuvoton Technology Corporation America** 2727 North First Street, San Jose, CA 95134, U.S.A. TEL: 1-408-943666 FAX: 1-408-5441797 http://www.nuvoton-usa.com/ #### **Nuvoton Technology Corporation Japan** 7F Daini-ueno BLDG. 3-7-18 Shinyokohama Kohokuku, Yokohama, 222-0033 TEL: 81-45-4781881 FAX: 81-45-4781800 ### Nuvoton Technology (Shanghai) Ltd. 27F, 299 Yan An W. Rd. Shanghai, 200336 China TEL: 86-21-62365999 FAX: 86-21-62356998 #### Nuvoton Technology (H.K.) Ltd. Unit 9-15, 22F, Millennium City, No. 378 Kwun Tong Rd., Kowloon, Hong Kong TEL: 852-27513100 FAX: 852-27552064 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.