CS8406 192 kHz Digital Audio Interface Transmitter Features General Description Complete EIAJ CP1201, IEC-60958, AES3, S/PDIF compatible transmitter +3.3 V Digital Supply (VD+) +3.3 V to 5 V Digital Interface (VL+) On-chip Channel Status and User bit buffer memories allow block sized updates Flexible 3-wire serial digital audio input port Up to 192 kHz frame rate Microcontroller write access to Channel Status and User bit data On-chip differential line driver Generates CRC codes and parity bits Standalone mode allows use without a microcontroller 28-pin SOIC/TSSOP package The CS8406 is a monolithic CMOS device which encodes and transmits audio data according to the AES3, IEC60958, S/PDIF, or EIAJ CP1201. The CS8406 accepts audio and digital data, which is then multiplexed, encoded and driven onto a cable. The audio data is input through a configurable, 3-wire input port. The channel status and user bit data are input through an SPI or I2C microcontroller port, and may be assembled in block sized buffers. For systems with no microcontroller, a stand alone mode allows direct access to channel status and user bit data pins. Target applications include A/V Receivers, CD-R, DVD receivers, digital mixing consoles, effects processors, set-top boxes, and computer and automotive audio systems. ORDERING INFORMATION CS8406-CS CS8406-CZ CS8406-IS CS8406-IZ 28-pin SOIC 28-pin TSSOP 28-pin SOIC 28-pin TSSOP -10 to +70C -10 to +70C -40 to +85C -40 to +85C I VD VL DGND RXP ILRCK ISCLK SDIN C & U bit Data Buffer Serial Audio Input RST Control Port & Registers U Advance Product Information http://www.cirrus.com TXP Driver TXN TCBL Misc. Control H/S AES3 S/PDIF Encoder SDA/ SCL/ AD1/ AD0/ AD2 INT CDOUT CCLK CDIN CS Output Clock Generator OMCK This document contains information for a new product. Cirrus Logic reserves the right to modify this product without notice. Copyright Cirrus Logic, Inc. 2002 (All Rights Reserved) AUG `02 DS580PP1 1 CS8406 TABLE OF CONTENTS 1. CHARACTERISTICS AND SPECIFICATIONS ........................................................................ 5 Power And Thermal Characteristics ......................................................................................... 5 Absolute Maximum Ratings ...................................................................................................... 5 Digital Characteristics ............................................................................................................... 6 Switching Characteristics.......................................................................................................... 6 Switching Characteristics - Serial Audio Ports.......................................................................... 6 Switching Characteristics - Control Port - SPI Mode ................................................................ 8 Switching Characteristics - Control Port - I2C Mode ................................................................. 9 2. TYPICAL CONNECTION DIAGRAMS ................................................................................... 10 3. GENERAL DESCRIPTION ..................................................................................................... 12 3.1 AES3 and S/PDIF Standards Documents ........................................................................ 12 4. THREE-WIRE SERIAL INPUT AUDIO PORT ........................................................................ 12 5. AES3 TRANSMITTER ............................................................................................................ 14 5.1 Transmitted Frame and Channel Status Boundary Timing .............................................. 14 5.2 TXN and TXP Drivers ...................................................................................................... 14 5.3 Mono Mode Operation ..................................................................................................... 14 6. CONTROL PORT DESCRIPTION AND TIMING .................................................................... 16 6.1 SPI Mode ......................................................................................................................... 16 6.2 I2C Mode ......................................................................................................................... 17 6.3 Interrupts .......................................................................................................................... 17 6.4 Memory Address Pointer (MAP) ...................................................................................... 18 7. CONTROL PORT REGISTER SUMMARY ............................................................................. 19 8. CONTROL PORT REGISTER BIT DEFINITIONS .................................................................. 20 8.1 Control 1 (01h) .................................................................................................................. 20 8.2 Control 2 (02h) .................................................................................................................. 21 8.3 Data Flow Control (03h).................................................................................................... 21 8.4 Clock Source Control (04h)............................................................................................... 22 8.5 Serial Audio Input Port Data Format (05h)........................................................................ 22 8.6 Interrupt 1 Status (07h) (Read Only)................................................................................. 23 8.7 Interrupt 2 Status (08h) (Read Only)................................................................................. 24 8.8 Interrupt 1 Mask (09h)....................................................................................................... 24 Contacting Cirrus Logic Support For all product questions and inquiries contact a Cirrus Logic Sales Representative. To find one nearest you go to IMPORTANT NOTICE "Preliminary" product information describes products that are in production, but for which full characterization data is not yet available. "Advance" product information describes products that are in development and subject to development changes. Cirrus Logic, Inc. and its subsidiaries ("Cirrus") believe that the information contained in this document is accurate and reliable. However, the information is subject to change without notice and is provided "AS IS" without warranty of any kind (express or implied). Customers are advised to obtain the latest version of relevant information to verify, before placing orders, that information being relied on is current and complete. All products are sold subject to the terms and conditions of sale supplied at the time of order acknowledgment, including those pertaining to warranty, patent infringement, and limitation of liability. No responsibility is assumed by Cirrus for the use of this information, including use of this information as the basis for manufacture or sale of any items, or for infringement of patents or other rights of third parties. This document is the property of Cirrus and by furnishing this information, Cirrus grants no license, express or implied under any patents, mask work rights, copyrights, trademarks, trade secrets or other intellectual property rights. Cirrus owns the copyrights of the information contained herein and gives consent for copies to be made of the information only for use within your organization with respect to Cirrus integrated circuits or other parts of Cirrus. This consent does not extend to other copying such as copying for general distribution, advertising or promotional purposes, or for creating any work for resale. An export permit needs to be obtained from the competent authorities of the Japanese Government if any of the products or technologies described in this material and controlled under the "Foreign Exchange and Foreign Trade Law" is to be exported or taken out of Japan. An export license and/or quota needs to be obtained from the competent authorities of the Chinese Government if any of the products or technologies described in this material is subject to the PRC Foreign Trade Law and is to be exported or taken out of the PRC. CERTAIN APPLICATIONS USING SEMICONDUCTOR PRODUCTS MAY INVOLVE POTENTIAL RISKS OF DEATH, PERSONAL INJURY, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE ("CRITICAL APPLICATIONS"). CIRRUS PRODUCTS ARE NOT DESIGNED, AUTHORIZED, OR WARRANTED TO BE SUITABLE FOR USE IN LIFE-SUPPORT DEVICES OR SYSTEMS OR OTHER CRITICAL APPLICATIONS. INCLUSION OF CIRRUS PRODUCTS IN SUCH APPLICATIONS IS UNDERSTOOD TO BE FULLY AT THE CUSTOMER'S RISK. Cirrus Logic, Cirrus, and the Cirrus Logic logo designs are trademarks of Cirrus Logic, Inc. All other brand and product names in this document may be trademarks or service marks of their respective owners. 2 DS580PP1 CS8406 8.9 Interrupt 1 Mode MSB (Ah) and Interrupt 1 Mode LSB (Bh)............................................. 24 8.10 Interrupt 2 Mask (0Ch).................................................................................................... 24 8.11 Interrupt 2 Mode MSB (0Dh) and Interrupt Mode 2 LSB (Eh) ........................................ 25 8.12 Channel Status Data Buffer Control (12h) ...................................................................... 25 8.13 User Data Buffer Control (13h) ....................................................................................... 26 8.14 Channel Status bit or User bit Data Buffer (20h - 37h) ................................................... 26 8.15 CS8406 I.D. and Version Register (7Fh) (Read Only) ................................................... 26 9. PIN DESCRIPTION - SOFTWARE MODE ............................................................................. 27 10. HARDWARE MODE ............................................................................................................. 29 10.1 Channel Status, User and Validity Data ........................................................................ 29 10.2 Serial Audio Port Formats ............................................................................................. 29 11. PIN DESCRIPTION - HARDWARE MODE .......................................................................... 31 12. APPLICATIONS ................................................................................................................... 33 12.1 Reset, Power Down and Start-up .................................................................................. 33 12.2 ID Code and Revision Code .......................................................................................... 33 12.3 Power Supply, Grounding, and PCB layout ................................................................... 33 12.4 Synchronization of Multiple CS8406s ............................................................................ 33 13. PACKAGE DIMENSIONS .................................................................................................. 34 14. APPENDIX A: EXTERNAL AES3/SPDIF/IEC60958 TRANSMITTER COMPONENTS ...... 36 14.1 AES3 Transmitter External Components ....................................................................... 36 14.2 Isolating Transformer Requirements ............................................................................. 36 15. APPENDIX B: CHANNEL STATUS AND USER DATA BUFFER MANAGEMENT ........... 37 15.1 AES3 Channel Status(C) Bit Management .................................................................... 37 15.1.1 Accessing the E buffer ...................................................................................... 37 15.1.2 Serial Copy Management System (SCMS) ....................................................... 38 15.1.3 Channel Status Data E Buffer Access .............................................................. 38 15.2 AES3 User (U) Bit Management .................................................................................... 38 15.2.1 Mode 1: Transmit All Zeros ............................................................................... 38 15.2.2 Mode 2: Block Mode ......................................................................................... 38 DS580PP1 3 CS8406 LIST OF FIGURES Figure 1. Audio Port Master Mode Timing....................................................................................... 7 Figure 2. Audio Port Slave Mode and Data Input Timing ................................................................ 7 Figure 3. SPI Mode timing ............................................................................................................... 8 Figure 4. I2C Mode timing ............................................................................................................... 9 Figure 5. Recommended Connection Diagram for Software Mode............................................... 10 Figure 6. Recommended Connection Diagram for Hardware Mode ............................................. 11 Figure 7. Serial Audio Input Example Formats.............................................................................. 13 Figure 8. Control Port Timing in SPI Mode.................................................................................... 16 Figure 9. Control Port Timing in I2C Mode .................................................................................... 17 Figure 10. Hardware Mode Data Flow .......................................................................................... 29 Figure 11. Professional Output Circuit (VL = 5 V) ......................................................................... 36 Figure 12. Consumer Output Circuit (VL = 5 V) ............................................................................ 36 Figure 13. TTL/CMOS Output Circuit ............................................................................................ 36 Figure 14. Channel Status Data Buffer Structure .......................................................................... 37 Figure 15. Flowchart for Writing the E Buffer ................................................................................ 37 LIST OF TABLES Table 1. Control Register Map Summary ............................................................................................ 19 Table 2. Hardware Mode COPY/C and ORIG pin functions ................................................................ 29 Table 3. Hardware Mode Serial Audio Port Format Selection ............................................................. 30 Table 4. Equivalent Register Settings of Serial Audio Input Formats Available in Hardware Mode .... 30 4 DS580PP1 CS8406 1. CHARACTERISTICS AND SPECIFICATIONS POWER AND THERMAL CHARACTERISTICS (DGND = 0 V, all voltages with respect to ground, no load on output pins) Parameter Power Supply Voltage Symbol Min Typ Max Units VD+ VL+ 3.135 3.135 3.3 3.3 to 5.0 3.465 5.5 V V Supply Current at 48 kHz frame rate VD+ VL+ = 3V VL+ = 5V - 6.3 30.1 46.5 7.8 37.6 58.1 mA mA mA Supply Current at 192 kHz frame rate (Note 1) VD+ VL+ = 3V VL+ = 5V - 6.6 44.8 76.6 - mA mA mA Reset high, VD+ Reset high, VL+ = 3V Reset high, VL+ = 5V ID IL IL - 20 0 0 - A A A Ambient Operating Temperature:CS8406-CS & -CZ (Note 2) CS8406-IS & -IZ (Note 3) TA -10 -40 25 70 85 C Supply Current in power down Notes: 1. Assumes that no inputs are left floating. It is recommended that all digital inputs be driven high or low at all times. 2. -CS' and `-CZ' parts are specified to operate over -10 C to 70 C but are tested at 25 C only. 3. `- IS' and `-IZ' parts are tested over the full -40C to 85C temperature range. ABSOLUTE MAXIMUM RATINGS (DGND = 0 V, all voltages with respect to ground) Parameter Symbol Min Max Units VD/VL+ - 6.0 V Iin - 10 mA Vin -0.3 (VL+) + 0.3 V Ambient Operating Temperature (power applied) TA -55 125 C Storage Temperature Tstg -65 150 C Power Supply Voltage Input Current, Any Pin Except Supply Input Voltage (Note 4) Notes: 4. Transient currents of up to 100 mA will not cause SCR latch-up. DS580PP1 5 CS8406 DIGITAL CHARACTERISTICS (TA = 25 C for suffixes `CS' &'CZ', TA = -40 to 85C for `IS' & `IZ' ; VD+ = 3.3 V 5%, VL+ = 3.135 V to 5.25 V) Parameter Symbol Min Typ Max Units High-Level Input Voltage VIH 2.0 - (VL+) + 0.3 V Low-Level Input Voltage VIL -0.3 - 0.8 V Input Hysteresis VIH 0.25 Low-Level Output Voltage, (Io=-3.2 mA), except TXP, TXN VOL - - 0.4 V High-Level Output Voltage, (Io=3.2 mA), except TXP, TXN VOH (VL+) - 1 - - V Iin - 1 10 A VL VL V V Input Leakage Current Output High Voltage, TXP, TXN (21mA at VL=5.0V) (15mA at VL=3.3V) Output Low Voltage, TXP, TXN (21mA at VL=5.0V) (17mA at VL=3.3V) V (VL+) - 0.7 (VL+) - 0.4 (VL+) - 0.7 (VL+) - 0.4 - 0.4 0.4 0.7 0.7 V V TXP Output Resistance VL=5.0V VL=3.3V RTXP - 26.5 33.5 - TXN Output Resistance VL=5.0V VL=3.3V RTXN - 26.5 33.5 - SWITCHING CHARACTERISTICS (TA = 25 C for suffixes `CS' &'CZ', TA = -40 to 85C for `IS' & `IZ' ; VD+ = 3.3 V 5%, VL+ = 3.135 V to 5.25 V, Inputs: Logic 0 = 0 V, Logic 1 = VL+; CL = 20 pF) Parameter Symbol Min Typ Max Units RST pin Low Pulse Width 200 - - s OMCK Frequency for OMCK = 512*Fs 4.1 - 98.4 MHz OMCK Low and High Width for OMCK = 512*Fs 4.1 - - ns OMCK Frequency for OMCK = 384*Fs 3.1 - 73.8 MHz OMCK Low and High Width for OMCK = 384*Fs 5.4 - - ns OMCK Frequency for OMCK = 256*Fs 2.0 - 49.2 MHz OMCK Low and High Width for OMCK = 256*Fs 8.1 - - ns Frame Rate 32 - 192 kHz - 200 - ps AES3 Transmitter Output Jitter SWITCHING CHARACTERISTICS - SERIAL AUDIO PORTS (TA = 25 C for suffixes `CS' &'CZ', TA = -40 to 85C for `IS' & `IZ' ; VD+ = 3.3 V 5%, VL+ = 3.135 V to 5.25 V, Inputs: Logic 0 = 0 V, Logic 1 = VL+; CL = 20 pF) Symbol Min Typ Max Units SDIN Setup Time Before ISCLK Active Edge Parameter (Note 5) tds 5 - - ns SDIN Hold Time After ISCLK Active Edge (Note 5) tdh 5 - - ns OMCK to ISCLK active edge delay (Note 5) tsmd 0 - 10 ns OMCK to ILRCK delay (Note 6) tlmd 0 - 10 ns - 50 - % Master Mode ISCLK and ILRCK Duty Cycle 6 DS580PP1 CS8406 Parameter Symbol Min Typ Max Units ISCLK Period tsckw 36 - - ns ISCLK Input Low Width tsckl 14.4 - - ns ISCLK Input High Width tsckh 14.4 - - ns Slave Mode ISCLK Active Edge to ILRCK Edge (Note 7) tlrckd 10 - - ns ILRCK Edge Setup Before ISCLK Active Edge (Note 8) tlrcks 10 - - ns Notes: 5. The active edge of ISCLK is programmable. 6. The polarity of ILRCK is programmable. 7. This delay is to prevent the previous ISCLK edge from being interpreted as the first one after ILRCK has changed. 8. This setup time ensures that this ISCLK edge is interpreted as the first one after ILRCK has changed. ILRCK (input) ISCLK (output) t lrckd t lrcks t sckh ISCLK (input) ILRCK (output) t sckw t smd t lmd OMCK (input) Figure 1. Audio Port Master Mode Timing DS580PP1 t sckl SDIN t ds t dh Figure 2. Audio Port Slave Mode and Data Input Timing 7 CS8406 SWITCHING CHARACTERISTICS - CONTROL PORT - SPI MODE (TA = 25 C for suffixes `CS' &'CZ', TA = -40 to 85C for `IS' & `IZ' ; VD+ = 3.3 V 5%, VL+ = 3.135 V to 5.25 V, Inputs: Logic 0 = 0 V, Logic 1 = VL+; CL = 20 pF) Parameter Symbol CCLK Clock Frequency (Note 9) Min Typ Max Units fsck 0 - 6.0 MHz CS High Time Between Transmissions tcsh 1.0 - - s CS Falling to CCLK Edge tcss 20 - - ns CCLK Low Time tscl 66 - - ns CCLK High Time (Note 10) tsch MAX (1/256 FS + 8, 66) ns tdsu 40 - - ns tdh 15 - - ns CCLK Falling to CDOUT Stable tpd - - 50 ns Rise Time of CDOUT tr1 - - 25 ns Fall Time of CDOUT tf1 - - 25 ns CDIN to CCLK Rising Setup Time CCLK Rising to DATA Hold Time (Note 11) Rise Time of CCLK and CDIN (Note 12) tr2 - - 100 ns Fall Time of CCLK and CDIN (Note 12) tf2 - - 100 ns Notes: 9. If Fs is lower than 51.850 kHz, the maximum CCLK frequency should be less than 115 Fs. This is dictated by the timing requirements necessary to access the Channel Status and User Bit buffer memory. Access to the control register file can be carried out at the full 6 MHz rate. 10. Tsch must be greater than the larger of the two values, either 1/256FS + 8ns, or 66Tns. 11. Data must be held for sufficient time to bridge the transition time of CCLK. 12. For fsck < 1 MHz. CS t scl t css t sch t csh CCLK t r2 t f2 CDIN t dsu t dh t pd CDOUT Figure 3. SPI Mode timing 8 DS580PP1 CS8406 SWITCHING CHARACTERISTICS - CONTROL PORT - I2C MODE (TA = 25 C for suffixes `CS' &'CZ', TA = -40 to 85C for `IS' & `IZ' ; VD+ = 3.3 V 5%, VL = 3.135 V to 5.25 V, Inputs: Logic 0 = 0 V, Logic 1 = VL+; CL = 20 pF) Parameter Symbol Min Typ Max Units SCL Clock Frequency fscl - - 100 kHz Bus Free Time Between Transmissions tbuf 4.7 - - s Start Condition Hold Time (prior to first clock pulse) thdst 4.0 - - s Clock Low Time tlow 4.7 - - s Clock High Time thigh 4.0 - - s Setup Time for Repeated Start Condition tsust 4.7 - - s SDA Hold Time from SCL Falling thdd 0 - - s SDA Setup Time to SCL Rising tsud 250 - - ns Rise Time of Both SDA and SCL Lines tr - - 25 ns Fall Time of Both SDA and SCL Lines tf - - 25 ns tsusp 4.7 - - s Setup Time for Stop Condition Stop Repeated Start Start Stop SDA t buf t t high t hdst tf hdst t susp SCL t low t hdd t sud t sust tr Figure 4. I2C Mode timing DS580PP1 9 CS8406 2. TYPICAL CONNECTION DIAGRAMS +3.3V +3.3V to +5V 0.1 F 0.1 F VD AES3 / S/PDIF Source RXP Serial Audio Source ILRCK ISCLK SDIN Clock Source and Control Microcontroller CS8406 VL TXP TXN Transmission Interface OMCK AD0 / CS AD1 / CDIN AD2 SCL / CCLK SDA / CDOUT User Data Source U 47K H/S RST INT TCBL DGND To/from other CS8406's Figure 5. Recommended Connection Diagram for Software Mode 10 DS580PP1 CS8406 +3.3V +3.3V to +5V 0.1 F 0.1 F VD Serial Audio Source Clock Source and Control C Data Source Hardware Control H/S ILRCK ISCLK SDIN OMCK VL CS8406 TXP TXN Transmission Interface COPY/C SFMT0 SFMT1 APMS TCBLD RST CEN EMPH AUDIO ORIG TCBL User Data Source U 47K Validity Source V 47K DGND To/from other CS8406's Figure 6. Recommended Connection Diagram for Hardware Mode DS580PP1 11 CS8406 3. GENERAL DESCRIPTION The CS8406 is a monolithic CMOS device which encodes and transmits audio data according to the AES3, IEC60958, S/PDIF, and EIAJ CP1201 interface standards. The CS8406 accepts audio, channel status and user data, which is then multiplexed, encoded, and driven onto a cable. The audio data is input through a configurable, 3wire input port. The channel status bits and user bit data are input through an SPI or I2C Mode microcontroller port and may be assembled in separate block sized buffers. For systems with no microcontroller, a stand alone mode allows direct access to channel status and user data input pins. Target applications include CD-R, DAT, DVD, MD and VTR equipment, mixing consoles, digital audio transmission equipment, high quality A/D converters, effects processors, set-top TV boxes, and computer audio systems. Figure 5 shows the supply and external connections to the CS8406 when configured for operation with a microcontroller. 3.1 AES3 and S/PDIF Standards Documents This data sheet assumes that the user is familiar with the AES3 and S/PDIF data formats. It is advisable to have current copies of the AES3 and IEC60958 specifications on hand for easy reference. The latest AES3 standard is available from the Audio Engineering Society or ANSI at www.aes.org or www.ansi.org. Obtain the latest IEC60958 standard from ANSI or from the International Electrotechnical Commission at www.iec.ch. The latest EIAJ CP-1201 standard is available from the Japanese Electronics Bureau. Crystal Application Note 22: Overview of Digital Audio Interface Data Structures contains a useful 12 tutorial on digital audio specifications, but it should not be considered a substitute for the standards. The paper An Understanding and Implementation of the SCMS Serial Copy Management System for Digital Audio Transmission, by Clifton Sanchez, is an excellent tutorial on SCMS. It is available from the AES as preprint 3518. 4. THREE-WIRE SERIAL INPUT AUDIO PORT A 3-wire serial audio input port is provided. The interface format can be adjusted to suit the attached device through the control registers. The following parameters are adjustable: * Master or slave * Serial clock frequency * Audio data resolution * Left or right justification of the data relative to left/right clock * Optional one-bit cell delay of the first data bit * Polarity of the bit clock * Polarity of the left/right clock. (By setting the appropriate control bits, many formats are possible). Figure 7 shows a selection of common input formats with the corresponding control bit settings. In master mode, the left/right clock and the serial bit clock are outputs, derived from the OMCK input pin master clock. In slave mode, the left/right clock and the serial bit clock are inputs. The left/right clock must be synchronous to the OMCK master clock, but the serial bit clock can be asynchronous and discontinuous if required. The left/right clock should be continuous, but the duty cycle can be less than the specified typical value of 50% if enough serial clocks are present in each phase to clock all the data bits. DS580PP1 CS8406 Right Left ILRCK Left ISCLK Justified SDIN (In) MSB I S (In) MSB Left ILRCK 2 LSB LSB MSB Right ISCLK SDIN LSB MSB Right ISCLK Justified (In) SDIN Left Justified I2S Right Justified Right Left ILRCK LSB MSB LSB MSB MSB LSB MSB LSB SIMS* SISF* SIRES[1:0]* SIJUST* SIDEL* SISPOL* SILRPOL* X X X X 00+ 00+ 0 0 0 1 0 0 0 1 X X XX 1 0 0 0 X = don't care to match format, but does need to be set to the desired setting + I2S can accept an arbitrary number of bits, determined by the number of ISCLK cycles * See Serial Input Port Data Format Register Bit Descriptions for an explanation of the meaning of each bit Figure 7. Serial Audio Input Example Formats DS580PP1 13 CS8406 5. AES3 TRANSMITTER The CS8406 includes an AES3 digital audio transmitter. A comprehensive buffering scheme provides write access to the channel status and user data. This buffering scheme is described in Appendix B: Channel Status and User Data Buffer Management. The AES3 transmitter encodes and transmits audio and digital data according to the AES3, IEC60958 (S/PDIF), and EIAJ CP-1201 interface standards. Audio and control data are multiplexed together and bi-phase mark encoded. The resulting bit stream is driven to an output connector either directly or through a transformer. The transmitter is clocked from the clock input pin, OMCK. If OMCK is asynchronous to the data source, an interrupt bit (TSLIP) is provided that will go high every time a data sample is dropped or repeated. The channel status (C) and user (U) bits in the transmitted data stream are taken from storage areas within the CS8406. The user can manually access the internal storage or configure the CS8406 to run in one of several automatic modes. Appendix B: Channel Status and User Data Buffer Management provides detailed descriptions of each automatic mode and describes methods of manually accessing the storage areas. The transmitted user bit data can optionally be input through the U pin, under the control of a control port register bit. Figure 4 shows the timing requirements for inputting U data through the U pin. 5.1 Transmitted Frame and Channel Status Boundary Timing The TCBL pin is used to control or indicate the start of transmitted channel status block boundaries and may be an input or an output. In some applications, it may be necessary to control the precise timing of the transmitted AES3 frame boundaries. This may be achieved in two ways: 14 a) With TCBL set to input, driving TCBL high for >3 OMCK clocks will cause a frame start, as well as a new channel status block start. b) If the serial audio input port is in slave mode and TCBL is set to output, the start of the A channel sub-frame will be aligned with the leading edge of ILRCK. 5.2 TXN and TXP Drivers The line drivers are low skew, low impedance, differential outputs capable of driving cables directly. Both drivers are set to ground during reset (RST = low), when no AES3 transmit clock is provided, and optionally under the control of a register bit. The CS8406 also allows immediate muting of the AES3 transmitter audio data through a control register bit. External components are used to terminate and isolate the external cable from the CS8406. These components are detailed in "Appendix A: External AES3/SPDIF/IEC60958 Transmitter Components" on page 36. 5.3 Mono Mode Operation An AES3 stream may be used in more than one way to transmit 192 kHz sample rate data. One method is to double the frame rate of the current format. This results in a stereo signal with a sample rate of 192 kHz, carried over a single twisted pair cable. An alternate method is implemented using the two sub-frames in a 96 kHz frame rate AES3 signal to carry consecutive samples of a mono signal, resulting in a 192 kHz sample rate stream. This allows older equipment, whose AES3 transmitters and receivers are not rated for 96 kHz frame rate operation, to handle 192 kHz sample rate information. In this "mono mode", two AES3 cables are needed for stereo data transfer. The CS8406 offers mono mode operation. The CS8406 is set to mono mode by the MMT control bit. In mono mode, the input port will run at the audio sample rate (Fs), while the AES3 transmitter frame DS580PP1 CS8406 rate will be at Fs/2. Consecutive left or right channel serial audio data samples may be selected for transmission on the A and B sub-frames, and the channel status block transmitted is also selectable. Using mono mode is only necessary if the incoming audio sample rate is already at 192 kHz and DS580PP1 contains both left and right audio data words. The "mono mode" AES3 output stream may also be achieved by keeping the CS8406 in normal stereo mode, and placing consecutive audio samples in the left and right positions in an incoming 96 kHz word rate data stream. 15 CS8406 6. CONTROL PORT DESCRIPTION AND TIMING Data is clocked in on the rising edge of CCLK and out on the falling edge. The control port is used to access the registers, allowing the CS8406 to be configured for the desired operational modes and formats. In addition, Channel Status and User data may be read and written through the control port. The operation of the control port may be completely asynchronous with respect to the audio sample rate. Figure 8 shows the operation of the control port in SPI mode. To write to a register, bring CS low. The first seven bits on CDIN form the chip address and must be 0010000. The eighth bit is a read/write indicator (R/W), which should be low to write. The next eight bits form the Memory Address Pointer (MAP), which is set to the address of the register that is to be updated. The next eight bits are the data which will be placed into the register designated by the MAP. During writes, the CDOUT output stays in the Hi-Z state. It may be externally pulled high or low with a 47 k resistor, if desired. The control port has two modes: SPI and I2C, with the CS8406 acting as a slave to control messages in both modes. SPI mode is selected if there is a high to low transition on the AD0/CS pin after the RST pin has been brought high. I2C mode is selected by connecting the AD0/CS pin to VL+ or DGND, thereby permanently selecting the desired AD0 bit address state. 6.1 SPI Mode In SPI mode, CS is the CS8406 chip select signal, CCLK is the control port bit clock (input into the CS8406 from the microcontroller); CDIN is the input data line from the microcontroller; and CDOUT is the output data line to the microcontroller. There is a MAP auto increment capability, enabled by the INCR bit in the MAP. See "Memory Address Pointer (MAP)" on page 18. If INCR is a zero, the MAP will stay constant for successive read or writes. If INCR is set to a 1, then the MAP will auto increment after each byte is read or written, allowing block reads or writes of successive registers. To read a register, the MAP has to be set to the correct address by executing a partial write cycle CS CCLK C H IP ADDRESS C D IN 0010000 M AP MSB R/W C H IP ADDRESS DATA b y te 1 LSB 0010000 R/W b y te n High Impedance CDOUT MSB LSB MSB LSB MAP = Memory Address Pointer, 8 bits, MSB first Figure 8. Control Port Timing in SPI Mode 16 DS580PP1 CS8406 which finishes (CS high) immediately after the MAP byte. The MAP auto increment bit (INCR) may be set or not, as desired. To begin a read, bring CS low, send out the chip address and set the read/write bit (R/W) high. The next falling edge of CCLK will clock out the MSB of the addressed register (CDOUT will leave the high impedance state). If the MAP auto increment bit is set to 1, the data for successive registers will appear consecutively. 6.2 I2C Mode In I2C Mode, SDA is a bidirectional data line. Data is clocked into and out of the part by the clock, SCL, with the clock to data relationship as shown in Figure 9. There is no CS pin. Each individual CS8406 is given a unique address. Pins AD0, AD1, and AD2 form the three least significant bits of the chip address, and should be connected to VL+ or DGND as desired. The upper four bits of the sevenbit address field are fixed at 0010. To communicate with a CS8406, the chip address field, which is the first byte sent to the CS8406, should match 0010 followed by the settings of AD2, AD1, and AD0. The eighth bit of the address is the R/W bit. If the operation is a write, the next byte is the Memory Address Pointer (MAP) which selects the register to be read or written. If the operation is a read, the Note 1 0010 SDA AD2-0 R/W contents of the register pointed to by the MAP will be output. Setting the auto increment bit in the MAP allows successive reads or writes of consecutive registers. Each byte is separated by an acknowledge bit, ACK, which is output from the CS8406 after each input byte is read. The ACK bit is input to the CS8406 from the microcontroller after each transmitted byte. 6.3 Interrupts The CS8406 has a comprehensive interrupt capability. The INT output pin is intended to drive the interrupt input pin on the host microcontroller. The INT pin may be set to be active low, active high or active low with no active pull-up transistor. This last mode is used for active low, wired-OR hookups, with multiple peripherals connected to the microcontroller interrupt input pin. Many conditions can cause an interrupt, as listed in the interrupt status register descriptions. Each source may be masked off by a bit in the mask registers. In addition, each source may be set to rising edge, falling edge, or level sensitive. Combined with the option of level sensitive or edge sensitive modes within the microcontroller, many different set-ups are possible, depending on the needs of the equipment designer. Note 2 ACK DATA7-0 ACK Note 3 DATA7-0 ACK SCL Start Stop Note 1: AD2, AD1 and AD0 are determined by the state of the corresponding pins Note 2: If operation is a write, this byte contains the Memory Address Pointer, MAP Note 3: If operation is a read, the last bit of the read should be a NACK(high) Figure 9. Control Port Timing in I2C Mode DS580PP1 17 CS8406 6.4 Memory Address Pointer (MAP) 7 INCR 6 MAP6 5 MAP5 4 MAP4 3 MAP3 2 MAP2 1 MAP1 0 MAP0 INCR - Auto Increment Address Control Bit Default = `0' 0 - Disable 1 - Enable MAP6:MAP0 - Register Address 18 DS580PP1 CS8406 7. CONTROL PORT REGISTER SUMMARY Addr (HEX) 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F-11 12 13 1D-1F 20-37 7F Function 7 6 5 4 3 2 Reserved 0 0 0 0 0 0 Control 1 0 VSET 0 MUTEAES 0 INT1 Control 2 0 0 0 0 0 MMT Data Flow Control 0 TXOFF AESBP 0 0 0 Clock Source Control 0 RUN CLK1 CLK0 0 0 Serial Input Format SIMS SISF SIRES1 SIRES0 SIJUST SIDEL Reserved 0 0 0 0 0 0 Interrupt 1 Status TSLIP 0 0 0 0 0 Interrupt 2 Status 0 0 0 0 0 EFTU Interrupt 1 Mask TSLIPM 0 0 0 0 0 Interrupt 1 Mode (MSB) TSLIP1 0 0 0 0 0 Interrupt 1 Mode (LSB) TSLIP0 0 0 0 0 0 Interrupt 2 Mask 0 0 0 0 0 EFTUM Interrupt 2 Mode (MSB) 0 0 0 0 0 EFTU1 Interrupt 2 Mode (LSB) 0 0 0 0 0 EFTU0 Reserved 0 0 0 0 0 0 CS Data Buffer Control 0 0 BSEL 0 0 EFTCI U Data Buffer Control 0 0 0 UD UBM1 UBM0 Reserved 0 0 0 0 0 0 C or U Data Buffer ID and Version ID3 ID2 ID1 ID0 VER3 VER2 1 0 0 0 INT0 TCBLD MMCST MMTLR 0 0 0 0 SISPOL SILRPOL 0 0 EFTC 0 0 0 EFTCM 0 EFTC1 0 EFTC0 0 0 0 0 0 0 0 0 0 CAM 0 0 EFTUI 0 0 VER1 VER0 Table 1. Control Register Map Summary Notes: DS580PP1 Reserved registers must not be written to during normal operation. Some reserved registers are used for test modes, which can completely alter the normal operation of the CS8406. 19 CS8406 8. CONTROL PORT REGISTER BIT DEFINITIONS 8.1 Control 1 (01h) 7 6 5 4 3 2 1 0 0 VSET 0 MUTEAES 0 INT1 INT0 TCBLD VSET - Transmitted Validity bit level Default = `0' 0 - Indicates data is valid, linear PCM audio data 1 - Indicates data is invalid or not linear PCM audio data MUTEAES - Mute control for the AES transmitter output Default = `0' 0 - Not Muted 1 - Muted INT1:INT0 - Interrupt output pin (INT) control Default = `00' 00 - Active high; high output indicates interrupt condition has occurred 01 - Active low, low output indicates an interrupt condition has occurred 10 - Open drain, active low. Requires an external pull-up resistor on the INT pin. 11 - Reserved TCBLD - Transmit Channel Status Block pin (TCBL) direction specifier Default = `0' 0 - TCBL is an input 1 - TCBL is an output 20 DS580PP1 CS8406 8.2 Control 2 (02h) 7 6 5 4 3 2 1 0 0 0 0 0 0 MMT MMTCS MMTLR MMT - Select AES3 transmitter mono or stereo operation Default = `0' 0 - Normal stereo operation 1 - Output either left or right channel inputs into consecutive subframe outputs (mono mode, left or right is determined by MMTLR bit) MMTCS - Select A or B channel status data to transmit in mono mode Default = `0' 0 - Use channel A CS data for the A subframe and use channel B CS data for the B subframe 1 - Use the same CS data for both the A and B subframe outputs. If MMTLR = 0, use the left channel CS data. If MMTLR = 1, use the right channel CS data. MMTLR - Channel Selection for AES Transmitter mono mode Default = `0' 0 - Use left channel input data for consecutive subframe outputs 1- Use right channel input data for consecutive subframe outputs 8.3 Data Flow Control (03h) 7 6 5 4 3 2 1 0 0 TXOFF AESBP 0 0 0 0 0 The Data Flow Control register configures the flow of audio data. The output data should be muted prior to changing bits in this register to avoid transients. TXOFF - AES3 Transmitter Output Driver Control Default = `0 0 - AES3 transmitter output pin drivers normal operation 1 - AES3 transmitter output pin drivers drive to 0 V. AESBP - AES3 bypass mode selection Default = `0' 0 - Normal operation 1 - Connect the AES3 transmitter driver input directly to the RXP pin, which becomes a normal TTL threshold digital input. DS580PP1 21 CS8406 8.4 Clock Source Control (04h) 7 6 5 4 3 2 1 0 0 RUN CLK1 CLK0 0 0 0 0 This register configures the clock sources of various blocks. In conjunction with the Data Flow Control register, various Receiver/Transmitter/Transceiver modes may be selected. RUN - Controls the internal clocks, allowing the CS8406 to be placed in a "powered down" low current consumption, state. Default = `0' 0 - Internal clocks are stopped. Internal state machines are reset. The fully static control port registers are operational, allowing registers to be read or changed. Reading and writing the U and C data buffers is not possible. Power consumption is low. 1 - Normal part operation. This bit must be set to 1 to allow the CS8406 to begin operation. All input clocks should be stable in frequency and phase when RUN is set to 1. CLK1:0 - Output master clock (OMCK) input frequency to output sample rate (Fs) ratio selector. If these bits are changed during normal operation, then always stop the CS8406 first (RUN = 0), write the new value, then start the CS8406 (RUN = 1). Default = `00' 00 - OMCK frequency is 256*Fs 01 - OMCK frequency is 384*Fs 10 - OMCK frequency is 512*Fs 11 - Reserved 8.5 Serial Audio Input Port Data Format (05h) 7 6 5 4 3 2 1 0 SIMS SISF SIRES1 SIRES0 SIJUST SIDEL SISPOL SILRPOL SIMS - Master/Slave Mode Selector Default = `0' 0 - Serial audio input port is in slave mode 1 - Serial audio input port is in master mode SISF - ISCLK frequency (for master mode) Default = `0' 0 - 64*Fs 1 - 128*Fs SIRES1:0 - Resolution of the input data, for right-justified formats Default = `00' 00 - 24-bit resolution 01 - 20-bit resolution 10 - 16-bit resolution 11 - Reserved 22 DS580PP1 CS8406 SIJUST - Justification of SDIN data relative to ILRCK Default = `0' 0 - Left-justified 1 - Right-justified SIDEL - Delay of SDIN data relative to ILRCK, for left-justified data formats Default = `0' 0 - MSB of SDIN data occurs in the first ISCLK period after the ILRCK edge (left justified mode) 1 - MSB of SDIN data occurs in the second ISCLK period after the ILRCK edge (I2S mode) SISPOL - ISCLK clock polarity Default = `0' 0 - SDIN sampled on rising edges of ISCLK 1 - SDIN sampled on falling edges of ISCLK SILRPOL - ILRCK clock polarity Default = `0' 0 - SDIN data is for the left channel when ILRCK is high 1 - SDIN data is for the right channel when ILRCK is high 8.6 Interrupt 1 Status (07h) (Read Only) 7 6 5 4 3 2 1 0 TSLIP 0 0 0 0 0 EFTC 0 For all bits in this register, a `1' means the associated interrupt condition has occurred at least once since the register was last read. A `0' means the associated interrupt condition has NOT occurred since the last reading of the register. Reading the register resets all bits to `0', unless the interrupt mode is set to level and the interrupt source is still true. Status bits that are masked off in the associated mask register will always be `0' in this register. This register defaults to 00h. TSLIP - AES3 transmitter source data slip interrupt In data flows where OMCK, which clocks the AES3 transmitter, is asynchronous to the data source, this bit will go high every time a data sample is dropped or repeated. When TCBL is an input, this bit will go high on receipt of a new TCBL signal. EFTC - E to F C-buffer transfer interrupt. The source for this bit is true during the E to F buffer transfer in the C bit buffer management process. DS580PP1 23 CS8406 8.7 Interrupt 2 Status (08h) (Read Only) 7 6 5 4 3 2 1 0 0 0 0 0 0 EFTU 0 0 For all bits in this register, a `1' means the associated interrupt condition has occurred at least once since the register was last read. A `0' means the associated interrupt condition has NOT occurred since the last reading of the register. Reading the register resets all bits to `0', unless the interrupt mode is set to level and the interrupt source is still true. Status bits that are masked off in the associated mask register will always be `0' in this register. This register defaults to 00h. EFTU - E to F U-buffer transfer interrupt. (Block Mode only) The source of this bit is true during the E to F buffer transfer in the U bit buffer management process. 8.8 Interrupt 1 Mask (09h) 7 6 5 4 3 2 1 0 TSLIPM 0 0 0 0 0 EFTCM 0 The bits of this register serve as a mask for the Interrupt 1 register. If a mask bit is set to 1, the error is unmasked, meaning that its occurrence will affect the INT pin and the status register. If a mask bit is set to 0, the error is masked, meaning that its occurrence will not affect the INT pin or the status register. The bit positions align with the corresponding bits in Interrupt 1 register. This register defaults to 00h. 8.9 Interrupt 1 Mode MSB (Ah) and Interrupt 1 Mode LSB (Bh) 7 6 5 4 3 2 1 0 TSLIP1 TSLIP0 0 0 0 0 0 0 0 0 0 0 EFTC1 EFTC0 0 0 The two Interrupt Mode registers form a 2-bit code for each Interrupt Register 1 function. There are three ways to set the INT pin active in accordance with the interrupt condition. In the Rising edge active mode, the INT pin becomes active on the arrival of the interrupt condition. In the Falling edge active mode, the INT pin becomes active on the removal of the interrupt condition. In Level active mode, the INT interrupt pin becomes active during the interrupt condition. Be aware that the active level (Active High or Low) only depends on the INT[1:0] bits. These registers default to 00. 00 - Rising edge active 01 - Falling edge active 10 - Level active 11 - Reserved 8.10 Interrupt 2 Mask (0Ch) 7 6 5 4 3 2 1 0 0 0 0 0 0 EFTUM 0 0 The bits of this register serve as a mask for the Interrupt 2 register. If a mask bit is set to 1, the error is unmasked, meaning that its occurrence will affect the INT pin and the status register. If a mask bit is set to 0, the error is masked, meaning that its occurrence will not affect the INT pin or the status register. The bit positions align with the corresponding bits in Interrupt 2 register. This register defaults to 00h. 24 DS580PP1 CS8406 8.11 Interrupt 2 Mode MSB (0Dh) and Interrupt Mode 2 LSB (Eh) 7 6 5 4 3 2 1 0 0 0 0 0 0 0 0 0 0 0 EFTU1 EFTU0 0 0 0 0 The two Interrupt Mode registers form a 2-bit code for each Interrupt Register 1 function. There are three ways to set the INT pin active in accordance with the interrupt condition. In the Rising edge active mode, the INT pin becomes active on the arrival of the interrupt condition. In the Falling edge active mode, the INT pin becomes active on the removal of the interrupt condition. In Level active mode, the INT interrupt pin becomes active during the interrupt condition. Be aware that the active level (Active High or Low) only depends on the INT[1:0] bits. These registers default to 00. 00 - Rising edge active 01 - Falling edge active 10 - Level active 11 - Reserved 8.12 Channel Status Data Buffer Control (12h) 7 6 5 4 3 2 1 0 0 0 BSEL 0 0 EFTCI CAM 0 BSEL - Selects the data buffer register addresses to contain User data or Channel Status data Default = `0' 0 - Data buffer address space contains Channel Status data 1 - Data buffer address space contains User data Note: There are separate complete buffers for the Channel Status and User bits. This control bit determines which buffer appears in the address space. EFTCI - E to F C-data buffer transfer inhibit bit. Default = `0' 0 - Allow C-data E to F buffer transfers 1 - Inhibit C-data E to F buffer transfers CAM - C-data buffer control port access mode bit Default = `0' 0 - One byte mode 1 - Two byte mode DS580PP1 25 CS8406 8.13 User Data Buffer Control (13h) 7 6 5 4 3 2 1 0 0 0 0 UD UBM1 UBM0 0 EFTUI UD - User bit data source specifier Default = `0' 0 - U Pin is the source of transmitted U data 1 - U data buffer is the source of transmitted U data UBM1:0 - Sets the operating mode of the AES3 User bit manager Default = `00' 00 - Transmit all zeros mode 01 - Block mode 10 - Reserved 11 - Reserved EFTUI - E to F U-data buffer transfer inhibit bit (valid in block mode only). Default = `0' 0 - Allow U-data E to F buffer transfers 1 - Inhibit U-data E to F buffer transfers 8.14 Channel Status bit or User bit Data Buffer (20h - 37h) Either the channel status data buffer E or the separate user bit data buffer E (provided UBM bits are set to block mode) is accessible through these register addresses. 8.15 CS8406 I.D. and Version Register (7Fh) (Read Only) 7 6 5 4 3 2 1 0 ID3 ID2 ID1 ID0 VER3 VER2 VER1 VER0 ID3:0 - ID code for the CS8406. Permanently set to 1110 VER3:0 - CS8406 revision level. Revision A is coded as 0001 26 DS580PP1 CS8406 9. PIN DESCRIPTION - SOFTWARE MODE D TEST TEST TEST TEST TEST TEST TEST SDA/CDOUT 1 Serial Control Data I/O (I2C Mode) / Data Out (SPI) (Input/Output) - In I2C Mode, SDA is the control I/O data line. SDA is open drain and requires an external pull-up resistor to VL+. In SPI mode, CDOUT is the output data from the control port interface on the CS8406 AD0/CS 2 Address Bit 0 (I2C Mode) / Control Port Chip Select (SPI) (Input) - A falling edge on this pin puts the CS8406 into SPI control port mode. With no falling edge, the CS8406 defaults to I2C mode. In I2C mode, AD0 is a chip address pin. In SPI mode, CS is used to enable the control port interface on the CS8406 AD2 3 Address Bit 2 (I2C Mode) (Input) - Determines the AD2 address bit for the control port in I2C mode, and should be connected to DGND or VL+. If SPI mode is used, the AD2 pin should be connected to either DGND or VL+. RXP 4 Auxiliary AES3 Receiver Port (Input) - Input for an alternate, already AES3 coded, audio data source. DGND 5 7 8 22 Digital Ground (Input) - Ground for the digital section. VD+ VL+ 6 23 Positive Digital Power (Input) - VD+ should operate at 3.3 V, VL+ may be operated at 3.3 V to 5 V RST 9 Reset (Input) - When RST is low, the CS8406 enters a low power mode and all internal states are reset. On initial power up, RST must be held low until the power supply is stable, and all input clocks are stable in frequency and phase. This is particularly true in hardware mode with multiple CS8406 devices, where synchronization between devices is important. TEST 7 8 10 11 16 17 18 Test Pins - These pins are used for test modes and should be tied to DGND. ILRCK 12 Serial Audio Input Left/Right Clock (Input/Output) - Word rate clock for the audio data on the SDIN pin. ISCLK 13 Serial Audio Bit Clock (Input/Output) - Serial bit clock for audio data on the SDIN pin. SDIN 14 Serial Audio Data Port (Input) - Audio data serial input pin. DS580PP1 27 CS8406 TCBL 15 Transmit Channel Status Block Start (Input/Output) - When operated as output, TCBL is high during the first sub-frame of a transmitted channel status block, and low at all other times. When operated as input, driving TCBL high for at least three OMCK clocks will cause the next transmitted sub-frame to be the start of a channel status block. INT 19 Interrupt (Output) - Indicates key events during the operation of the CS8406. All bits affecting INT may be unmasked through bits in the control registers. Indication of the condition(s) that initiated an interrupt are readable in the control registers. The polarity of the INT output, as well as selection of a standard or open drain output, is set through a control register. Once set true, the INT pin goes false only after the interrupt status registers have been read and the interrupt status bits have returned to zero. U 20 User Data (Input) - May optionally be used to input User data for transmission by the AES3 transmitter, see Figure 4 for timing information. If not driven, a 47 k pull-down resistor is recommended for the U pin. If the U pin is driven by a logic level output, then a 100 series resistor is recommended. OMCK 21 Master Clock (Input) - The frequency must be 256x, 384x, or 512x the sample rate. H/S 24 Hardware/Software Control Mode Select (Input) -Determines the method of controlling the operation of the CS8406, and the method of accessing Channel Status and User bit data. In software mode, device control and CS and U data access is primarily through the control port, using a microcontroller. Hardware mode provides an alternate mode of operation, and access to CS and U data is provided by dedicated pins. This pin should be permanently tied to VL+ or DGND. TXN TXP 25 26 Differential Line Drivers (Output) - Transmitting AES3 data. Drivers are pulled low while the CS8406 is in the reset state. AD1/CDIN 27 Address Bit 1 (I2C Mode) / Serial Control Data in (SPI) (Input) - In I2C mode, AD1 is a chip address pin. In SPI mode, CDIN is the input data line for the control port interface. SCL/CCLK 28 Control Port Clock (Input) - Serial control interface clock and is used to clock control data bits into and out of the CS8406. In I2C mode, SCL requires an external pull-up resistor to VL+. 28 DS580PP1 CS8406 10. HARDWARE MODE The CS8406 has a hardware mode that allows the use of the device without a microcontroller. Hardware mode is selected by connecting the H/S pin to VL+. The flexibility of the CS8406 is necessarily limited in hardware mode. Various pins change function as described in the hardware mode pin description section. The hardware mode data flow is shown in Figure 10. Audio data is input through the serial audio input port and routed to the AES3 transmitter. 10.1 Channel Status, User and Validity Data The transmitted channel status, user and validity data can be input in two methods, determined by the state of the CEN pin. Mode A is selected when the CEN pin is low. In mode A, the user bit data and the validity bit are input through the U and V pins, clocked by both edges of ILRCK. The channel status data is derived from the state of the COPY/C, ORIG, EMPH, and AUDIO pins. Table 2 shows how the COPY/C and ORIG pins map to channel status bits. In consumer mode, the transmitted category code is set to General (00h). Mode B is selected when the CEN pin is high. In mode B, the channel status, user data bits and the validity bit are input serially through the COPY/C, U and V pins. Data is clocked into these pins at both edges of ILRCK. Figure 4 shows the timing requirements. The channel status block pin (TCBL) may be an input or an output, determined by the state of the TCBLD pin. 10.2 Serial Audio Port Formats The serial audio input port data format is selected as shown in Table 3, and may be set to master or slave by the state of the APMS input pin. Table 4 describes the equivalent software mode, bit settings for each of the available formats. Timing diagrams are shown in Figure 7. COPY/C 0 0 ORIG Function 0 PRO=0, COPY=0, L=0 copyright 1 PRO=0, COPY=0, L=1 copyright, 1 0 1 1 pre-recorded PRO=0, COPY=1, L=0 non-copyright PRO=1 Table 2. Hardware Mode COPY/C and ORIG pin functions VL Output Clock Source RST H/S OMCK TCBLD ILRCK ISCLK SDIN Serial Audio Input AES3 Encoder & Tx C, U, V Data Buffer APMS SFMT1 SFMT0 TXP TXN TCBL CEN U V COPY/C ORIG EMPH AUDIO Power supply pins are omitted from this diagram. Please refer to the Typical Connection Diagram for hook-up details. Figure 10. Hardware Mode Data Flow DS580PP1 29 CS8406 SFMT1 0 0 1 1 SFMT0 Function 0 Serial Input Format IF1 - Left Justified 1 Serial Input Format IF2 - I2S 0 Serial Input Format IF3 - Right Justified, 241 bit data Serial Input Format IF4 - Right Justified, 16bit data Table 3. Hardware Mode Serial Audio Port Format Selection IF1 - Left Justified IF2 - I2S IF3 - Right Justified, 24-bit data IF4 - Right Justified, 16-bit data SISF SIRES1/0 SIJUST SIDEL SISPOL SILRPOL 0 00 0 0 0 0 0 00 0 1 0 1 0 0 00 10 1 1 0 0 0 0 0 0 Table 4. Equivalent Register Settings of Serial Audio Input Formats Available in Hardware Mode 30 DS580PP1 CS8406 11. PIN DESCRIPTION - HARDWARE MODE TEST TEST TEST TEST TEST COPY/C 1 COPY Channel Status Bit/C Bit (Input) - In hardware mode A (CEN = 0), the COPY/C and ORIG pins determine the state of the Copyright, Pro, and L Channel Status bits in the outgoing AES3 data stream, see Table 2. In hardware mode B, the COPY/C pin becomes the direct C bit input data pin, which is sampled on both edges of LRCK. VL+ VD+ 23 6 Positive Digital Power (Input) - Typically +3.3 V. VD+ must be +3.3 V, the other VL+ pins may be operated at +3.3 V to +5 V EMPH 3 Pre-Emphasis Indicator (Input) - In hardware mode A (CEN = 0), the EMPH pin low sets the 3 emphasis channel status bits to indicate 50/15 s pre-emphasis of the transmitted audio data. If EMPH is high, then the three EMPH channel status bits are set to 000, indicating no pre-emphasis. SFMT0 SFMT1 4 5 Serial Audio Data Format Select (Input) - select the serial audio input port format. See Table 3. DGND 22 Digital Ground (Input) - Ground for the digital section. RST 9 Reset (Input) - When RST is low, the CS8406 enters a low power mode and all internal states are reset. On initial power up, RST must be held low until the power supply is stable, and all input clocks are stable in frequency and phase. This is particularly true in hardware mode with multiple CS8406 devices, where synchronization between devices is important. APMS 10 Serial Audio Data Port Master/Slave Select (Input) - APMS should be connected to VL+ to set serial audio input port as a master or connected to DGND to set the port as a slave. TCBLD 11 Transmit Channel Status Block Direction (Input) - Connect TCBLD to VL+ to set TCBL as an output. Connect TCBLD to DGND to set TCBL as an input. ILRCK 12 Serial Audio Input Left/Right Clock (Input/Output) - Word rate clock for the audio data on the SDIN pin. ISCLK 13 Serial Audio Bit Clock (Input/Output) - Serial bit clock for audio data on the SDIN pin. SDIN 14 Serial Audio Data Port (Input) - Audio data serial input pin. TCBL 15 Transmit Channel Status Block Start (Input/Output) - When operated as output, TCBL is high during the first sub-frame of a transmitted channel status block, and low at all other times. When operated as input, driving TCBL high for at least three OMCK clocks will cause the next transmitted sub-frame to be the start of a channel status block. CEN 16 C Bit Enable (Input) - Determines how the channel status data bits are input. When CEN is low, hardware mode A is selected, where the COPY/C, ORIG, EMPH and AUDIO pins are used to enter selected channel status data. When CEN is high, hardware mode B is selected, where the COPY/C pin is used to enter serial channel status data. V 17 Validity Bit (Input) - In hardware modes A and B, the V pin input determines the state of the validity bit in the outgoing AES3 transmitted data. This pin is sampled on both edges of the ILRCK. DS580PP1 31 CS8406 U 18 User Data Bit (Input) - In hardware modes A and B, the U pin input determines the state of the user data bit in the outgoing AES3 transmitted data. This pin is sampled on both edges of the ILRCK. AUDIO 19 Audio Channel Status Bit (Input) - In hardware mode A (CEN = 0), the AUDIO pin determines the state of the audio/non audio Channel Status bit in the outgoing AES3 data stream. OMCK 21 Master Clock (Input) - The frequency must be only 256x the sample rate. H/S 24 Hardware/Software Control Mode Select (Input) -Determines the method of controlling the operation of the CS8406, and the method of accessing CS and U data. In software mode, device control and CS and U data access is primarily through the control port, using a microcontroller. Hardware mode provides an alternate mode of operation, and access to CS and U data is provided by dedicated pins. This pin should be permanently tied to VL+ or DGND. TXN TXP 25 26 Differential Line Drivers (Output) - Transmitting AES3 data. The drivers are pulled low while the CS8406 is in the reset state. ORIG 28 ORIG Channel Status Bit Control (Input) - In hardware mode A (CEN = 0), the ORIG and COPY/C pins determine the state of the Copyright, Pro, and L Channel Status bits in the outgoing AES3 data stream, see Table 2. TEST 2 7 8 20 27 Test Pins - These pins are used for test modes and should be tied to DGND. 32 DS580PP1 CS8406 12. APPLICATIONS 12.1 Reset, Power Down and Start-up When RST is low, the CS8406 enters a low power mode and all internal states are reset, including the control port and registers, and the outputs are disabled. When RST is high, the control port becomes operational and the desired settings should be loaded into the control registers. Writing a 1 to the RUN bit will then cause the part to leave the low power state and begin operation. 12.2 12.3 ID Code and Revision Code The CS8406 has a register that contains a four-bit code to indicate that the addressed device is a CS8406. This is useful when other CS84XX family members are resident in the same or similar systems, allowing common software modules. The CS8406 four-bit revision level code is also available. This allows the software driver for the CS8406 to identify which revision of the device is in a particular system, and modify its behavior accordingly. To allow for future revisions, it is strongly recommended that the revision code is read into a variable area within the microcontroller, and used wherever appropriate as revision details become known. DS580PP1 Power Supply, Grounding, and PCB layout The CS8406 operates from a +5V supply. It may also be operated with VD+ at +5V and the other VL+ pins at +3.3 V. Follow normal supply decoupling practices, see Figure 5. The VL+ supplies should be decoupled with a 0.1 F capacitor to DGND to minimize AES3 transmitter induced transients. Extensive use of power and ground planes, ground plane fill in unused areas and surface mount decoupling capacitors are recommended. Decoupling capacitors should be mounted on the same side of the board as the CS8406 to minimize inductance effects, and all decoupling capacitors should be as close to the CS8406 as possible. 12.4 Synchronization of Multiple CS8406s The AES3 transmitters of multiple CS8406s can be synchronized if all devices share the same master clock, TCBL, and RST signals. The TCBL pin is used to synchronize multiple CS8406 AES3 transmitters at the channel status block boundaries. One CS8406 must have its TCBL set to master; the others must be set to slave TCBL. Alternatively, TCBL can be derived from external logic, whereby all CS8406 devices should be set to slave TCBL. 33 CS8406 13. PACKAGE DIMENSIONS 28L SOIC (300 MIL BODY) PACKAGE DRAWING E H 1 b c D L SEATING PLANE A e DIM A A1 b C D E e H L A1 MIN 0.093 0.004 0.013 0.009 0.697 0.291 0.040 0.394 0.016 0 INCHES NOM 0.098 0.008 0.017 0.011 0.705 0.295 0.050 0.407 0.026 4 MAX 0.104 0.012 0.020 0.013 0.713 0.299 0.060 0.419 0.050 8 MIN 2.35 0.10 0.33 0.23 17.70 7.40 1.02 10.00 0.40 0 MILLIMETERS NOM 2.50 0.20 0.42 0.28 17.90 7.50 1.27 10.34 0.65 4 MAX 2.65 0.30 0.51 0.32 18.10 7.60 1.52 10.65 1.27 8 JEDEC #: MS-013 Controlling Dimension is Millimeters 34 DS580PP1 CS8406 28L TSSOP (4.4 mm BODY) PACKAGE DRAWING N D E11 A2 E A e b2 SIDE VIEW A1 L END VIEW SEATING PLANE 1 2 3 TOP VIEW INCHES DIM A A1 A2 b D E E1 e L MIN -0.002 0.03150 0.00748 0.378 BSC 0.248 0.169 -0.020 0 NOM -0.004 0.035 0.0096 0.382 BSC 0.2519 0.1732 0.026 BSC 0.024 4 NOTE MILLIMETERS MAX 0.47 0.006 0.04 0.012 0.386 BSC 0.256 0.177 -0.029 8 MIN -0.05 0.80 0.19 9.60 BSC 6.30 4.30 -0.50 0 NOM -0.10 0.90 0.245 9.70 BSC 6.40 4.40 0.65 BSC 0.60 4 MAX 1.20 0.15 1.00 0.30 9.80 BSC 6.50 4.50 -0.75 8 2,3 1 1 JEDEC #: MO-153 Controlling Dimension is Millimeters. Notes: 1."D" and "E1" are reference datums and do not included mold flash or protrusions, but do include mold mismatch and are measured at the parting line, mold flash or protrusions shall not exceed 0.20 mm per side. 2.Dimension "b" does not include dambar protrusion/intrusion. Allowable dambar protrusion shall be 0.13 mm total in excess of "b" dimension at maximum material condition. Dambar intrusion shall not reduce dimension "b" by more than 0.07 mm at least material condition. 3.These dimensions apply to the flat section of the lead between 0.10 and 0.25 mm from lead tips. DS580PP1 35 CS8406 grounded. If VL+ is driven from +3.3 V, use a resistor value of TBD. 14. APPENDIX A: EXTERNAL AES3/SPDIF/IEC60958 TRANSMITTER COMPONENTS This section details the external components required to interface the AES3 transmitter to cables and fiber-optic components. 14.1 AES3 Transmitter External Components The output drivers on the CS8406 are designed to drive both the professional and consumer interfaces. The AES3 specification for professional/broadcast use calls for a 110 20% source impedance and a balanced drive capability. Since the transmitter output impedance at 5 V is TBD, a 110 -TBD resistor should be placed in series with one of the transmit pins. The specifications call for a balanced output drive of 2-7 volts peak-to-peak into a 110 load with no cable attached. Using the circuit in Figure 11, the output of the transformer is shortcircuit protected, has the proper source impedance, and provides a 5 volt peak-to-peak signal into a 110 load. Lastly, the two output pins should be attached to an XLR connector with male pins and a female shell, and with pin 1 of the connector CS8406 In the case of consumer use, the IEC60958 specifications call for an unbalanced drive circuit with an output impedance of 75 20% and a output drive level of 0.5 volts peak-to-peak 20% when measured across a 75 load using no cable. The circuit shown in Figure 12 only uses the TXP pin and provides the proper output impedance and drive level using standard 1% resistors. If VL+ is driven from +3.3 V, use resistor values of 243RT Ohms and 107 Ohms. The connector for a consumer application would be an RCA phono socket. This circuit is also short circuit protected. The TXP pin may be used to drive TTL or CMOS gates as shown in Figure 13. This circuit may be used for optical connectors for digital audio since they usually have TTL or CMOS compatible inputs. This circuit is also useful when driving multiple digital audio outputs since RS422 line drivers have TTL compatible inputs. 14.2 Isolating Transformer Requirements Please refer to the application note AN134: AES and SPDIF Recommended Transformers for resources on transformer selection. CS8406 110-(RTXP +RTXN) TXP 374-RTXP TXP 90.9 XLR RCA Phono TXN TXN 1 Figure 11. Professional Output Circuit (VL = 5 V) Figure 12. Consumer Output Circuit (VL = 5 V) CS8406 TXP TTL or CMOS Gate TXN Figure 13. TTL/CMOS Output Circuit 36 DS580PP1 CS8406 15. APPENDIX B: CHANNEL STATUS AND USER DATA BUFFER MANAGEMENT The CS8406 has a comprehensive channel status (C) and user (U) data buffering scheme which allows the user to manage the C and U data through the control port. 15.1 AES3 Channel Status(C) Bit Management The CS8406 contains sufficient RAM to store a full block of C data for both A and B channels (192x2 = 384 bits), and also 384 bits of U information. The user may read from or write to these RAM buffers through the control port. The CS8406 manages the flow of channel status data at the block level, meaning that entire blocks of channel status information are buffered at the input, synchronized to the output timebase, and then transmitted. The buffering scheme involves a cascade of 2 block-sized buffers, named E and F, as shown in Figure 14. The MSB of each byte represents the first bit in the serial C data stream. For example, the MSB of byte 0 (which is at control port address 32) is the consumer/professional bit for channel status block A. The E buffer is accessible from the control port, allowing read and writing of the C data. The F buffer is used as the source of C data for the AES3 transmitter. The F buffer accepts block transfers from the E buffer. A 8 -b its 15.1.1 Accessing the E buffer The user can monitor the data being transferred by reading the E buffer, which is mapped into the register space of the CS8406, through the control port. The user can modify the data to be transmitted by writing to the E buffer. The user can configure the interrupt enable register to cause interrupts to occur whenever "E to F" buffer transfers occur. This allows determination of the allowable time periods to interact with the E buffer. Also provided is an "E to F" inhibit bit. The "E to F" buffer transfer is disabled whenever the user sets this bit. This may be used whenever "long" control port interactions are occurring. A flowchart for reading and writing to the E buffer is shown in Figure 15. For writing, the sequence starts after a E to F transfer, which is based on the output timebase. If the channel status block to transmit indicates PRO mode, then the CRCC byte is automatically calculated by the CS8406, and does not have to be written into the last byte of the block by the host microcontroller. This is also true if the channel status data is entered serially through the COPY/C pin when the part is in hardware mode. E to F interrupt occurs Optionally set E to F inhibit B 8 -b its E 24 w o rd s Write E data F To AES3 Tra nsm itte r If set, clear E to F inhibit Tra nsm it D ata Buffer Wait for E to F transfer Return C on tro l Po rt Figure 14. Channel Status Data Buffer Structure DS580PP1 Figure 15. Flowchart for Writing the E Buffer 37 CS8406 15.1.2 Serial Copy Management System (SCMS) In software mode, the CS8406 allows read/modify/write access to all the channel status bits. For consumer mode SCMS compliance, the host microcontroller needs to manipulate the Category Code, Copy bit and L bit appropriately. In hardware mode, the SCMS protocol can be followed by either using the COPY and ORIG input pins, or by using the C bit serial input pin. These options are documented in the hardware mode section of this data sheet. 15.1.3 Channel Status Data E Buffer Access The E buffer is organized as 24 x 16-bit words. For each word the MS Byte is the A channel data, and the LS Byte is the B channel data (see Figure 14). There are two methods of accessing this memory, known as one byte mode and two byte mode. The desired mode is selected through a control register bit. 15.1.3.1 One Byte mode In many applications, the channel status blocks for the A and B channels will be identical. In this situation, if the user reads a byte from one of the channel's blocks, the corresponding byte for the other channel will be the same. Similarly, if the user wrote a byte to one channel's block, it would be necessary to write the same byte to the other block. One byte mode takes advantage of the often identical nature of A and B channel status data. When reading data in one byte mode, a single byte is returned, which can be from channel A or B data, depending on a register control bit. If a write is being done, the CS8406 expects a single byte to be input to its control port. This byte will be written to both the A and B locations in the addressed word. One byte mode saves the user substantial control port access time, as it effectively accesses 2 bytes worth of information in 1 byte's worth of access time. If the control port's auto increment addressing is used in combination with this mode, multi-byte 38 accesses such as full-block reads or writes can be done especially efficiently. 15.1.3.2 Two Byte mode There are those applications in which the A and B channel status blocks will not be the same, and the user is interested in accessing both blocks. In these situations, two byte mode should be used to access the E buffer. In this mode, a read will cause the CS8406 to output two bytes from its control port. The first byte out will represent the A channel status data, and the 2nd byte will represent the B channel status data. Writing is similar, in that two bytes must now be input to the CS8406's control port. The A channel status data is first, B channel status data second. 15.2 AES3 User (U) Bit Management The CS8406 U bit manager has two operating modes: Mode 1. Transmit all zeros. Mode 2. Block mode. 15.2.1 Mode 1: Transmit All Zeros Mode 1 causes only zeros to be transmitted in the output U data, regardless of E buffer contents. This mode is intended for the user who wants the output U channel to contain no data. 15.2.2 Mode 2: Block Mode Mode 2 is very similar to the scheme used to control the C bits. Entire blocks of U data are buffered using 2 block-sized RAMs to perform the buffering. The user has access to the first buffer, denoted the E buffer, through the control port. It is the only mode in which the user can merge his own U data into the transmitted AES3 data stream. The U buffer access only operates in two byte mode, since there is no concept of A and B blocks for user data. The arrangement of the data is as followings: Bit15[A7] Bit14[B7] Bit13[A6] Bit12 [B6]...Bit1 [A0] Bit0[B0]. The arrangement of the data in the each byte is that the MSB is the first transmitted bit. The bit for the A subframe is followed by the bit for the B subframe. DS580PP1 * Notes *