Features
• MPEG I/II-Layer 3 Hardwired Decoder
– Stand-alone MP3 Decoder – 48, 44.1, 32, 24, 22.05, 16 kHz Sampling Frequency – Separated Digital Volume Control on Left and Right Channels (Software Control using 31 Steps) – Bass, Medium, and Treble Control (31 Steps) – Bass Boost Sound Effect – Ancillary Data Extraction – CRC Error and MPEG Frame Synchronization Indicators 20-bit Stereo Audio DAC – 93 dB SNR Playback Stereo Channel – 32 Ohm/ 20 mW Stereo Headset Drivers – Stereo Line Level Input, Differential Mono Auxiliary Input Programmable Audio Output for Interfacing with External Audio System – I2S Format Compatible Mono Audio Power Amplifier – 440mW on 8 Ohms Load USB Rev 1.1 Controller – Full Speed Data Transmission Built-in PLL – MP3 Audio Clocks – USB Clock MultiMediaCard® Interface, Secure Digital Card Interface Standard Full Duplex UART with Baud Rate Generator Power Management – Power-on Reset – Idle Mode, Power-down Mode Operating Conditions: – 2.7 to 3V, ±10%, 25 mA Typical Operating at 25°C – 37 mA Typical Operating at 25°C Playing Music on Earphone – Temperature Range: -40°C to +85 °C – Power Amplifier Supply 3.2V to 5.5V Packages – CTBGA 100-pin
•
• • • • • • • •
Single-Chip MP3 Decoder with Full Audio Interface AT83SND2CMP3 AT83SND2CDVX
Preliminary
•
Typical Applications
• • • • • •
MP3-Player PDA, Camera, Mobile Phone MP3 Car Audio/Multimedia MP3 Home Audio/Multimedia MP3 Toys Industrial Background Music / Ads
Rev. 7524B–MP3–05/06
Description
The AT83SND2CMP3 has been developped as a versatile remote controlled MP3 player for very fast MP3 feature implementation into most existing system. It perfectly fits features needed in mobile phones and toys, but can also be used in any portable equipment and in industrial applications. Audio files and any other data can be stored in a Nand Flash memory or in a removable Flash card such as MultiMediaCard (MMC) or Secure Digital Card (SD). Music collections are very easy to build, as data can be stored using the standard FAT12/16 and FAT32 file system. Thanks to the USB port, data can be transferred and maintained from and to any computer based on Windows®, Linux® and Mac OS®. File system is controlled by the AT83SND2CMP3 so the host controller does not have to handle it. In addition to the USB device port, the MP3 audio system can be connected to any embedded host through a low cost serial link UART. Host controller can fully remote control the MP3 decoder behaviour using a command protocol over the serial link. File system is controlled by the AT83SND2CMP3 so host controller does not have to handle it. Files can also be uploaded or dowloaded from host environment to NAND Flash or Flash Card.
2
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
1. Block Diagram
Figure 2. Block Diagram
VDD VSS UVDD UVSS
FILT X1 X2 RST
3 Clock and PLL Unit
Control Unit
Interrupt Handler Unit
INT0 INT1
3
D+ D-
USB Controller I/OPorts
X1
X2
P0-P4
MP3 Decoder Unit Keyboard Interface
DOUT DCLK DSEL SCLK KIN0
I2S/PCM Audio Interface
UART and BRG
3 3
TXD RXD
Timers 0/1 Watchdog
3 3
T0 T1
HSR HSL AUXP AUXN LINEL LINER MONOP MONON
MCLK
Audio DAC
SD / MMC Interface
MDAT
PAINP PAINN HPP HPN
Audio PA
MCMD
3 Alternate function of Port 3 4 Alternate function of Port 4
3
7524B–MP3–05/06
Pin Description
Pinouts
Figure 3. AT83SND2CMP3 100-pin BGA Package
10
NC
9
NC
8
P2.0/ A8
7
P4.1/
6
VDD
5
VSS
4
NC
3
AUXP
2
AUXN
1
NC
A B C D E F G H J K
VDD
P2.2/ A10
P2.1/ A9
P4.0/
P4.2/
MONON
MONOP
P0.0/ AD0
KIN0
NC
P2.4/ A12
P2.3/ A11
P2.5/ A13
P4.3/
P0.6/ AD6
P0.4/ AD4
P0.3/ AD3
P0.2/ AD2
P0.1/ AD1
NC
P2.6/ A14
P2.7/ A15
MCLK
NC
P0.7/ AD7
P0.5/ AD5
NC
NC
NC
NC
NC
VSS
VDD
ESDVSS
VDD
SDA
AUDVREF
SCL
HSL
AUDVDD
MCMD
MDAT
NC
P3.2/ INT0
P3.1/ TXD
VSS
FILT
PVDD
HSR
HSVDD
RST
AUDRST
SCLK
DSEL
P3.4/ T0
P3.0/ RXD
LINER
LINEL
PVSS
HSVSS
NC
VSS
DOUT
DCLK
P3.5/ T1
TST
X1
X2
INGND
AUDVSS
VDD
AUDVSS
CBP
LPHN
P3.7/ RD
P3.6/ WR
VSS
D-
D+
AUDVCM
PAINP
PAINN
HPP
AUDVBAT
HPN
AUDVSS
P3.3/ INT1
VDD
UVDD
UVSS
1. NC = Do Not Connect
4
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Signals
All the AT83SND2CMP3 signals are detailed by functionality in following tables. Table 1. Ports Signal Description
Signal Name Type Description Port 0 P0 is an 8-bit open-drain bidirectional I/O port. Port 0 pins that have 1s written to them float and can be used as high impedance inputs. To avoid any parasitic current consumption, floating P0 inputs must be polarized to VDD or VSS. Port 2 P2 is an 8-bit bidirectional I/O port with internal pull-ups. Alternate Function
P0.7:0
I/O
AD7:0
P2.7:0
I/O
A15:8 RXD TXD
P3.7:0
I/O
Port 3 P3 is an 8-bit bidirectional I/O port with internal pull-ups.
INT0 INT1 T0 T1 WR RD
P4.3:0
I/O
Port 4 P4 is an 8-bit bidirectional I/O port with internal pull-ups.
Table 2. C lock Signal Description
Signal Name Type Description Input to the on-chip inverting oscillator amplifier To use the internal oscillator, a crystal/resonator circuit is connected to this pin. If an external oscillator is used, its output is connected to this pin. X1 is the clock source for internal timing. Output of the on-chip inverting oscillator amplifier To use the internal oscillator, a crystal/resonator circuit is connected to this pin. If an external oscillator is used, leave X2 unconnected. PLL Low Pass Filter input FILT receives the RC network of the PLL low pass filter. Alternate Function
X1
I
-
X2
O
-
FILT
I
-
Table 3. Timer 0 and Timer 1 Signal Description
Signal Name Type Description Timer 0 Gate Input INT0 serves as external run control for timer 0, when selected by GATE0 bit in TCON register. INT0 I External Interrupt 0 INT0 input sets IE0 in the TCON register. If bit IT0 in this register is set, bit IE0 is set by a falling edge on INT0#. If bit IT0 is cleared, bit IE0 is set by a low level on INT0#. P3.2 Alternate Function
5
7524B–MP3–05/06
Signal Name
Type
Description Timer 1 Gate Input INT1 serves as external run control for timer 1, when selected by GATE1 bit in TCON register.
Alternate Function
INT1
I
External Interrupt 1 INT1 input sets IE1 in the TCON register. If bit IT1 in this register is set, bit IE1 is set by a falling edge on INT1#. If bit IT1 is cleared, bit IE1 is set by a low level on INT1#. Timer 0 External Clock Input When timer 0 operates as a counter, a falling edge on the T0 pin increments the count. Timer 1 External Clock Input When timer 1 operates as a counter, a falling edge on the T1 pin increments the count.
P3.3
T0
I
P3.4
T1
I
P3.5
Table 4. Audio Interface Signal Description
Signal Name DCLK DOUT DSEL Type O O O Description DAC Data Bit Clock DAC Audio Data Output DAC Channel Select Signal DSEL is the sample rate clock output. DAC System Clock SCLK is the oversampling clock synchronized to the digital audio data (DOUT) and the channel selection signal (DSEL). Alternate Function -
SCLK
O
-
Table 5. U SB Controller Signal Description
Signal Name Type Description USB Positive Data Upstream Port This pin requires an external 1.5 KΩ pull-up to VDD for full speed operation. USB Negative Data Upstream Port Alternate Function
D+
I/O
-
D-
I/O
-
Table 6. MutiMediaCard Interface Signal Description
Signal Name MCLK Type O Description MMC Clock output Data or command clock transfer. MMC Command line Bidirectional command channel used for card initialization and data transfer commands. To avoid any parasitic current consumption, unused MCMD input must be polarized to VDD or VSS. MMC Data line Bidirectional data channel. To avoid any parasitic current consumption, unused MDAT input must be polarized to VDD or VSS. Alternate Function -
MCMD
I/O
-
MDAT
I/O
-
6
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Table 7. U ART Signal Description
Signal Name Type Description Receive Serial Data RXD sends and receives data in serial I/O mode 0 and receives data in serial I/O modes 1, 2 and 3. Transmit Serial Data TXD outputs the shift clock in serial I/O mode 0 and transmits data in serial I/O modes 1, 2 and 3. Alternate Function
RXD
I/O
P3.0
TXD
O
P3.1
Table 8. Keypad Interface Signal Description
Signal Name Type Description Keypad Input Line Holding this pin high or low for 24 oscillator periods triggers a keypad interrupt. Alternate Function
KIN0
I
-
Table 9. System Signal Description
Signal Name Type Description Reset Input Holding this pin high for 64 oscillator periods while the oscillator is running resets the device. The Port pins are driven to their reset conditions when a voltage lower than VIL is applied, whether or not the oscillator is running. This pin has an internal pull-down resistor which allows the device to be reset by connecting a capacitor between this pin and VDD. Asserting RST when the chip is in Idle mode or Power-Down mode returns the chip to normal operation. Test Input Test mode entry signal. This pin must be set to VDD. Alternate Function
RST
I
-
TST
I
-
Table 10. Power Signal Description
Signal Name VDD Type PWR Description Digital Supply Voltage Connect these pins to +3V supply voltage. Circuit Ground Connect these pins to ground. PLL Supply voltage Connect this pin to +3V supply voltage. PLL Circuit Ground Connect this pin to ground. USB Supply Voltage Connect this pin to +3V supply voltage. Alternate Function -
VSS
GND
-
PVDD
PWR
-
PVSS
GND
-
UVDD
PWR
-
7
7524B–MP3–05/06
Signal Name UVSS
Type GND
Description USB Ground Connect this pin to ground.
Alternate Function -
Table 11. Audio Power Signal Description
Signal Name AUDVDD AUDVSS Type PWR GND Description Audio Digital Supply Voltage Audio Circuit Ground Connect these pins to ground. Audio Analog Circuit Ground for Electrostatic Discharge. Connect this pin to ground. Audio Voltage Reference pin for decoupling. Headset Driver Power Supply. Headset Driver Ground. Connect this pin to ground. Audio Amplifier Supply. Alternate Function -
ESDVSS AUDVREF HSVDD HSVSS AUDVBAT
GND PWR PWR GND PWR
-
Table 12. Stereo Audio Dac and Mono Power Amplifier Signal Description
Signal Name LPHN HPN HPP CBP PAINN PAINP AUDRST MONON MONOP AUXP AUXN HSL HSR LINEL LINER INGND AUDVCM Type O O O O I I I O O I I O O I I I I Description Low Power Audio Stage Output Negative Speaker Output Positivie Speaker Output Audio Amplifier Common Mode Voltage Decoupling Audio Amplifier Negative Input Audio Amplifier Positive Input Audio Reset (Active Low) Audio Negative Monaural Driver Output Audio Positive Monaural Driver Output Audio Mono Auxiliary Positive Input Audio Mono Auxiliary Negative Input Audio Left Channel Headset Driver Output Audio Right Channel Headset Driver Output Audio Left Channel Line In Audio Right Channel Line In Audio Line Signal Ground Pin for decoupling. Audio Common Mode reference for decoupling Alternate Function -
8
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Internal Pin Structure
Table 13. Detailed Internal Pin Structure
Circuit(1)
VDD
Type
Pins
RTST
Input
TST
VDD
Watchdog Output
P Input/Output
RRST
RST
VSS
2 osc periods Latch Output
VDD
VDD
VDD
P1
P2
P3 Input/Output P3 P4
N
VSS VDD
P Input/Output N
VSS VDD
P0 MCMD MDAT
P Output N
VSS
ALE SCLK DCLK DOUT DSEL MCLK
D+ D-
Input/Output
D+ D-
Notes:
1. For information on resistors value, input/output levels, and drive capability, refer to the DC Characteristics. 2. When the Two Wire controller is enabled, P3 transistors are disabled allowing pseudo open-drain structure.
9
7524B–MP3–05/06
Clock Controller
The clock controller is based on an on-chip oscillator feeding an on-chip Phase Lock Loop (PLL). All internal clocks to the peripherals and CPU core are generated by this controller. The X1 and X2 pins are the input and the output of a single-stage on-chip inverter (see Figure 4) that can be configured with off-chip components such as a Pierce oscillator (see Figure 5). Value of capacitors and crystal characteristics are detailed in the section “DC Characteristics”. The oscillator outputs three different clocks: a clock for the PLL, a clock for the CPU core, and a clock for the peripherals as shown in Figure 4. These clocks are either enabled or disabled, depending on the power reduction mode as detailed in the section. The peripheral clock is used to generate the Timer 0, Timer 1, MMC, SPI, and Port sampling clocks. Figure 4. Oscillator Block Diagram and Symbol
÷2
Oscillator
X1
0 1
Peripheral Clock CPU Core Clock
X2 X2
CKCON.0
IDL
PCON.0
PD
PCON.1
Oscillator Clock
CPU CLOCK OSC CLOCK
PER CLOCK
Peripheral Clock Symbol
CPU Core Clock Symbol
Oscillator Clock Symbol
Figure 5. Crystal Connection
X1
C1 Q C2
VSS
X2
PLL
PLL Description The PLL is used to generate internal high frequency clock (the PLL Clock) synchronized with an external low-frequency (the Oscillator Clock). The PLL clock provides the MP3 decoder, the audio interface, and the USB interface clocks. Figure 6 shows the internal structure of the PLL. The PFLD block is the Phase Frequency Comparator and Lock Detector. This block makes the comparison between the reference clock coming from the N divider and the reverse clock coming from the R divider and generates some pulses on the Up or Down signal depending on the edge position of the reverse clock. The PLLEN bit in PLLCON register is used to enable the clock generation. The CHP block is the Charge Pump that generates the voltage reference for the VCO by injecting or extracting charges from the external filter connected on PFILT pin (see
10
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
F ig u re 7 ) . Va lu e o f th e fil te r c o mp o n e n t s a r e d e t a ile d i n t h e S e ct io n “D C Characteristics”. The VCO block is the Voltage Controlled Oscillator controlled by the voltage Vref produced by the charge pump. It generates a square wave signal: the PLL clock. Figure 6. PLL Block Diagram and Symbol
PLLCON.1
PFILT
PLLEN N divider
OSC CLOCK
N6:0
Up PFLD Down PLOCK
PLLCON.0
CHP
Vref
VCO
PLL Clock
R divider R9:0
OSCclk × ( R + 1 ) PLLclk = ---------------------------------------------N+1
PLL CLOCK
PLL Clock Symbol
Figure 7. PLL Filter Connection
FILT
R C1
VSS VSS
C2
PLL Programming
The PLL is programmed using the flow shown in Figure 8. The PLL clock frequency will depend on MP3 decoder clock and audio interface clock frequencies. Figure 8. PLL Programming Flow
PLL Programming
Configure Dividers N6:0 = xxxxxxb R9:0 = xxxxxxxxxxb
Enable PLL PLLRES = 0 PLLEN = 1
PLL Locked?
PLOCK = 1?
11
7524B–MP3–05/06
MP3 Decoder
The product implements a MPEG I/II audio layer 3 decoder better known as MP3 decoder. In MPEG I (ISO 11172-3) three layers of compression have been standardized supporting three sampling frequencies: 48, 44.1, and 32 kHz. Among these layers, layer 3 allows highest compression rate of about 12:1 while still maintaining CD audio quality. For example, 3 minutes of CD audio (16-bit PCM, 44.1 kHz) data, which needs about 32M bytes of storage, can be encoded into only 2.7M bytes of MPEG I audio layer 3 data. In MPEG II (ISO 13818-3), three additional sampling frequencies: 24, 22.05, and 16 kHz are supported for low bit rates applications. The AT83SND2CMP3 can decode in real-time the MPEG I audio layer 3 encoded data into a PCM audio data, and also supports MPEG II audio layer 3 additional frequencies. Additional features are supported by the AT83SND2CMP3 MP3 decoder such as volume control, bass, medium, and treble controls, bass boost effect and ancillary data extraction.
Decoder
Description The core interfaces to the MP3 decoder through nine special function registers: MP3CON, the MP3 Control register; MP3STA, the MP3 Status register; MP3DAT, the MP3 Data register; MP3ANC, the Ancillary Data register; MP3VOL and MP3VOR, the MP3 Volume Left and Right Control registers; MP3BAS, MP3MED, and MP3TRE, the MP3 Bass, Medium, and Treble Control registers; and MPCLK, the MP3 Clock Divider register. Figure 9 shows the MP3 decoder block diagram.
Figure 9. MP3 Decoder Block Diagram
Audio Data From C51
8
1K Bytes Frame Buffer MP3DAT
Header Checker Huffman Decoder
Dequantizer
Stereo Processor
Side Information
MPxREQ
MP3 CLOCK
MP3STA1.n
ERRxxx MPFS1:0 MPVER
MP3STA.5:3 MP3STA.2:1 MP3STA.0
Ancillary Buffer MP3ANC
MPEN
MP3CON.7
Anti-Aliasing
IMDCT
Sub-band Synthesis
16
Decoded Data To Audio Interface
MPBBST
MP3CON.6
MP3VOL
MP3VOR
MP3BAS
MP3MED
MP3TRE
12
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
MP3 Data The MP3 decoder does not start any frame decoding before having a complete frame in its input buffer(1). In order to manage the load of MP3 data in the frame buffer, a hardware handshake consisting of data request and data acknowledgment is implemented. Each time the MP3 decoder needs MP3 data, it sets the MPREQ, MPFREQ and MPBREQ flags respectively in MP3STA and MP3STA1 registers. MPREQ flag can generate an interrupt if enabled as explained in Section “Interrupt”. The CPU must then load data in the buffer by writing it through MP3DAT register thus acknowledging the previous request. As shown in Figure 10, the MPFREQ flag remains set while data (i.e a frame) is requested by the decoder. It is cleared when no more data is requested and set again when new data are requested. MPBREQ flag toggles at every Byte writing.
Note: 1. The first request after enable, consists in 1024 Bytes of data to fill in the input buffer.
Figure 10. Data Timing Diagram
MPREQ Flag MPFREQ Flag MPBREQ Flag Write to MP3DAT
Cleared when Reading MP3STA
MP3 Clock
The MP3 decoder clock is generated by division of the PLL clock. The division factor is given by MPCD4:0 bits in MP3CLK register. Figure 11 shows the MP3 decoder clock generator and its calculation formula. The MP3 decoder clock frequency depends only on the incoming MP3 frames. Figure 11. MP3 Clock Generator and Symbol
MP3CLK PLL CLOCK MPCD4:0 MP3 Decoder Clock MP3 CLOCK MP3 Clock Symbol
PL Lclk M P3 clk = ---------------------------MPCD + 1
As soon as the frame header has been decoded and the MPEG version extracted, the minimum MP3 input frequency must be programmed according to Table 14. Table 14. MP3 Clock Frequency
MPEG Version I II Minimum MP3 Clock (MHz) 21 10.5
13
7524B–MP3–05/06
Audio Controls
Volume Control The MP3 decoder implements volume control on both right and left channels. The MP3VOR and MP3VOL registers allow a 32-step volume control according to Table 15. Table 15. Volume Control
VOL4:0 or VOR4:0 00000 00001 00010 11110 11111 Volume Gain (dB) Mute -33 -27 -1.5 0
Equalization Control
Sound can be adjusted using a 3-band equalizer: a bass band under 750 Hz, a medium band from 750 Hz to 3300 Hz and a treble band over 3300 Hz. The MP3BAS, MP3MED, and MP3TRE registers allow a 32-step gain control in each band according to Table 16. Table 16. Bass, Medium, Treble Control
BAS4:0 or MED4:0 or TRE4:0 00000 00001 00010 11110 11111 Gain (dB) -∞ -14 -10 +1 +1.5
14
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Frame Information
The MP3 frame header contains information on the audio data contained in the frame. These informations is made available in the MP3STA register for you information. MPVER and MPFS1:0 bits allow decoding of the sampling frequency according to Table 17. MPVER bit gives the MPEG version (2 or 1). Table 17. MP3 Frame Frequency Sampling
MPVER 0 0 0 0 1 1 1 1 MPFS1 0 0 1 1 0 0 1 1 MPFS0 0 1 0 1 0 1 0 1 Fs (kHz) 22.05 (MPEG II) 24 (MPEG II) 16 (MPEG II) Reserved 44.1 (MPEG I) 48 (MPEG I) 32 (MPEG I) Reserved
Ancillary Data
MP3 frames also contain data bits called ancillary data. These data are made available in the MP3ANC register for each frame. As shown in Figure 12, the ancillary data are available by Bytes when MPANC flag in MP3STA register is set. MPANC flag is set when the ancillary buffer is not empty (at least one ancillary data is available) and is cleared only when there is no more ancillary data in the buffer. This flag can generate an interrupt as explained in Section “Interrupt”. When set, software must read all Bytes to empty the ancillary buffer. Figure 12. Ancillary Data Block Diagram
Ancillary Data To C51
8
MP3ANC
8
7-Byte Ancillary Buffer
MPANC
MP3STA.7
15
7524B–MP3–05/06
Audio Output Interface
The product implements an audio output interface allowing the audio bitstream to be output in various formats. It is compatible with right and left justification PCM and I2S formats and thanks to the on-chip PLL (see Section “Clock Controller”, page 10) allows connection of almost all of the commercial audio DAC families available on the market. The audio bitstream can be from 2 different types: • • The MP3 decoded bitstream coming from the MP3 decoder for playing songs. The audio bitstream coming from the MCU for outputting voice or sounds.
Description
The control unit core interfaces to the audio interface through five special function registers: AUDCON0 and AUDCON1, the Audio Control registers ; AUDSTA, the Audio Status register; AUDDAT, the Audio Data register; and AUDCLK, the Audio Clock Divider register. Figure 13 shows the audio interface block diagram, blocks are detailed in the following sections.
Figure 13. Audio Interface Block Diagram
SCLK
AUD CLOCK
DCLK Clock Generator
0
AUDEN
AUDCON1.0
DSEL
1
HLR Data Ready Audio Data From MP3 Decoder Sample Request To MP3 Decoder
AUDCON0.0
DSIZ
AUDCON0.1
POL
AUDCON0.2
16
MP3 Buffer
16 16
0 1
Data Converter
DOUT
DRQEN
AUDCON1.6
JUST4:0 SRC
AUDCON1.7 AUDCON0.7:3
SREQ Audio Data From C51
8
Audio Buffer AUDDAT
AUDSTA.7
UDRN
AUDSTA.6
AUBUSY DUP1:0
AUDCON1.2:1 AUDSTA.5
16
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Clock Generator
The audio interface clock is generated by division of the PLL clock. The division factor is given by AUCD4:0 bits in CLKAUD register. Figure 14 shows the audio interface clock generator and its calculation formula. The audio interface clock frequency depends on the incoming MP3 frames and the audio DAC used. Figure 14. Audio Clock Generator and Symbol
AUDCLK
PLL CLOCK AUD CLOCK
AUCD4:0
Audio Interface Clock
PLLclk AUDclk = --------------------------AU C D + 1
Audio Clock Symbol
As soon as audio interface is enabled by setting AUDEN bit in AUDCON1 register, the master clock generated by the PLL is output on the SCLK pin which is the DAC system clock. This clock is output at 256 or 384 times the sampling frequency depending on the DAC capabilities. HLR bit in AUDCON0 register must be set according to this rate for properly generating the audio bit clock on the DCLK pin and the word selection clock on the DSEL pin. These clocks are not generated when no data is available at the data converter input. For DAC compatibility, the bit clock frequency is programmable for outputting 16 bits or 32 bits per channel using the DSIZ bit in AUDCON0 register (see Section "Data Converter", page 17), and the word selection signal is programmable for outputting left channel on low or high level according to POL bit in AUDCON0 register as shown in Figure 15. Figure 15. DSEL Output Polarity
POL = 0 POL = 1
Left Channel Left Channel Right Channel Right Channel
Data Converter
The data converter block converts the audio stream input from the 16-bit parallel format to a serial format. For accepting all PCM formats and I2 S format, JUST4:0 bits in AUDCON0 register are used to shift the data output point. As shown in Figure 16, these bits allow MSB justification by setting JUST4:0 = 00000, LSB justification by setting JUST4:0 = 10000, I2S Justification by setting JUST4:0 = 00001, and more than 16-bit LSB justification by filling the low significant bits with logic 0.
17
7524B–MP3–05/06
Figure 16. Audio Output Format
DSEL DCLK DOUT
1 2 3
Left Channel
13 14 15 16 1 2 3
Right Channel
13 14 15 16
LSB MSB B14
B1
LSB MSB B14
B1
I2S Format with DSIZ = 0 and JUST4:0 = 00001.
DSEL DCLK DOUT
1 2 3
Left Channel
17 18 32 1 2 3
Right Channel
17 18 32
MSB B14
LSB
MSB B14
LSB
I2S Format with DSIZ = 1 and JUST4:0 = 00001.
DSEL DCLK DOUT
1 2 3
Left Channel
13 14 15 16 1 2 3
Right Channel
13 14 15 16
MSB B14
B1
LSB MSB B15
B1
LSB
MSB/LSB Justified Format with DSIZ = 0 and JUST4:0 = 00000.
DSEL DCLK DOUT
1
Left Channel
16 17 18 31 32 1
Right Channel
16 17 18 31 32
MSB B14
B1
LSB
MSB B14
B1
LSB
16-bit LSB Justified Format with DSIZ = 1 and JUST4:0 = 10000.
DSEL DCLK DOUT
1
Left Channel
15 16 30 31 32 1
Right Channel
15 16 30 31 32
MSB B16
B2
B1
LSB
MSB B16
B2
B1
LSB
18-bit LSB Justified Format with DSIZ = 1 and JUST4:0 = 01110.
The data converter receives its audio stream from 2 sources selected by the SRC bit in AUDCON1 register. When cleared, the audio stream comes from the MP3 decoder (see Section “MP3 Decoder”, page 12) for song playing. When set, the audio stream is coming from the C51 core for voice or sound playing. As soon as first audio data is input to the data converter, it enables the clock generator for generating the bit and word clocks.
Audio Buffer
In voice or sound playing mode, the audio stream comes from the C51 core through an audio buffer. The data is in 8-bit format and is sampled at 8 kHz. The audio buffer adapts the sample format and rate. The sample format is extended to 16 bits by filling the LSB to 00h. Rate is adapted to the DAC rate by duplicating the data using DUP1:0 bits in AUDCON1 register according to Table 18. The audio buffer interfaces to the C51 core through three flags: the sample request flag (SREQ in AUDSTA register), the under-run flag (UNDR in AUDSTA register) and the busy flag (AUBUSY in AUDSTA register). SREQ and UNDR can generate an interrupt request as explained in Section "Interrupt Request", page 19. The buffer size is 8 Bytes large. SREQ is set when the samples number switches from 4 to 3 and reset when the samples number switches from 4 to 5; UNDR is set when the buffer becomes empty signaling that the audio interface ran out of samples; and AUBUSY is set when the buffer is full.
18
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Table 18. Sample Duplication Factor
DUP1 0 0 1 1 DUP0 0 1 0 1 Factor No sample duplication, DAC rate = 8 kHz (C51 rate). One sample duplication, DAC rate = 16 kHz (2 x C51 rate). 2 samples duplication, DAC rate = 32 kHz (4 x C51 rate). Three samples duplication, DAC rate = 48 kHz (6 x C51 rate).
MP3 Buffer
In song playing mode, the audio stream comes from the MP3 decoder through a buffer. The MP3 buffer is used to store the decoded MP3 data and interfaces to the decoder through a 16-bit data input and data request signal. This signal asks for data when the buffer has enough space to receive new data. Data request is conditioned by the DREQEN bit in AUDCON1 register. When set, the buffer requests data to the MP3 decoder. When cleared no more data is requested but data are output until the buffer is empty. This bit can be used to suspend the audio generation (pause mode). The audio interrupt request can be generated by 2 sources when in C51 audio mode: a sample request when SREQ flag in AUDSTA register is set to logic 1, and an under-run condition when UDRN flag in AUDSTA register is set to logic 1. Both sources can be enabled separately by masking one of them using the MSREQ and MUDRN bits in AUDCON1 register. A global enable of the audio interface is provided by setting the EAUD bit in IEN0 register. The interrupt is requested each time one of the 2 sources is set to one. The source flags are cleared by writing some data in the audio buffer through AUDDAT, but the global audio interrupt flag is cleared by hardware when the interrupt service routine is executed. Figure 17. Audio Interface Interrupt System
UDRN
AUDSTA.6
Interrupt Request
MUDRN
AUDCON1.4
Audio Interrupt Request EAUD
IEN0.6
SREQ
AUDSTA.7
MSREQ
AUDCON1.5
MP3 Song Playing
In MP3 song playing mode, the operations to do are to configure the PLL and the audio interface according to the DAC selected. The audio clock is programmed to generate the 256·Fs or 384·Fs as explained in Section "Clock Generator", page 17. Figure 18 shows the configuration flow of the audio interface when in MP3 song mode.
19
7524B–MP3–05/06
Figure 18. MP3 Mode Audio Configuration Flow
MP3 Mode Configuration
Enable DAC System Clock AUDEN = 1
Program Audio Clock
Configure Interface HLR = X DSIZ = X POL = X JUST4:0 = XXXXXb SRC = 0
Wait For DAC Set-up Time
Enable Data Request DRQEN = 1
20
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
DAC and PA Interface
The AT83SND2CMP3 implements a stereo Audio Digital-to-Analog Converter and Audio Power Amplifier targeted for Li-Ion or Ni-Mh battery powered devices. Figure 19. Audio Interface Block Diagram
MP3 Decoder Unit
DOUT DCLK DSEL SCLK
I2S/PCM Audio Interface
Serial Audio Interface
HSR HSL AUXP AUXN LINEL LINER MONOP MONON
Audio DAC
AUDCDIN AUDCDOUT AUDCCLK AUDCCS
PAINP PAINN HPP HPN
Audio PA
DAC
The Stereo DAC section is a complete high performance, stereo, audio digital-to-analog converter delivering 93 dB Dynamic Range. It comprises a multibit sigma-delta modulator with dither, continuous time analog filters and analog output drive circuitry. This architecture provides a high insensitivity to clock jitter. The digital interpolation filter increases the sample rate by a factor of 8 using 3 linear phase half-band filters cascaded, followed by a first order SINC interpolator with a factor of 8. This filter eliminates the images of baseband audio, remaining only the image at 64x the input sample rate, which is eliminated by the analog post filter. Optionally, a dither signal can be added that may reduce eventual noise tones at the output. However, the use of a multibit sigmadelta modulator already provides extremely low noise tones energy. Master clock is 128 up to 512 times the input data rate allowing choice of input data rate up to 50 kHz, including standard audio rates of 48, 44.1, 32, 16 and 8 kHz. The DAC section is followed by a volume and mute control and can be simultaneously played back directly through a Stereo 32Ω Headset pair of drivers. The Stereo 32Ω H eadset pair of drivers also includes a mixer of a LINEL and LINER pair of stereo inputs as well as a differential monaural auxiliary input (line level).
21
7524B–MP3–05/06
DAC Features
• 20 bit D/A Conversion • 72dB Dynamic Range, -75dB THD Stereo line-in or microphone interface with 20dB • • • • • •
amplification 93dB Dynamic Range, -80dB THD Stereo D/A conversion 74dB Dynamic Range / -65dB THD for 20mW output power over 32 Ohm loads Stereo, Mono and Reverse Stereo Mixer Left/Right speaker short-circuit detection flag Differential mono auxiliary input amplifier and PA driver Audio sampling rates (Fs): 16, 22.05, 24, 32, 44.1 and 48 kHz.
Figure 20. Stereo DAC functional diagram
Digital Signals Timing Data Interface To avoid noises at the output, the reset state is maintained until proper synchronism is achieved in the DAC serial interface: • • • • DSEL SCLK DCLK DOUT
The data interface allows three different data transfer modes: 22
AT83SND2CMP3
7524B–MP3–05/06
TUOD
KLCD
KLCS
LESD
ecafretnI lellaraP ot laireS
retliF latigiD
retliF latigiD
)Bd5.1( Bd43- ot 21 niaG kcabyalP retsaM
lortnoC emuloV
lortnoC emuloV
+
+
)Bd5.1( Bd5.64- ot 0 GOLR ,GOLL niaG tuO eniL
lortnoC emuloV
lortnoC emuloV
CAD
CAD
+
+
+
)Bd3( Bd 33- ot 21,02 niaG GILR,GILL
niaG GXUA
)Bd3( Bd6- ot 6 niaG CLO_CAD
23 VRD RKPS
23 VRD RKPS
VRDAP AGP AGP XUA
niaG AP
RSH
NXUA
RENIL
NONOM PXUA LSH LENIL
PONOM
AT83SND2CMP3
Figure 21. 20 bit I2S justified mode
SCLK
DSEL
DOUT
R1
R0
L(N-1)
L(N-2)
L(N-3)
...
L2
L1
L0
R(N-1)
R(N-2)
R(N-3)
...
R2
R1
R0
Figure 22. 20 bit MSB justified mode
SCLK
DSEL
DOUT
R0
L(N-1)
L(N-2)
L(N-3)
...
L2
L1
L0
R(N-1)
R(N-2)
R(N-3)
...
R2
R1
R0
L(N-1)
Figure 23. 20 bit LSB justified mode
SCLK
DSEL
DOUT
R0
L(N-1)
L(N-2)
...
L1
L0
R(N-1)
R(N-2)
...
R1
R0
L(N-1)
The selection between modes is done using the DINTSEL 1:0 in DAC_MISC register (Table 40.) according with the following table:
DINTSEL 1:0 00 01 1x Format I2S Justified MSB Justified LSB Justified
The data interface always works in slave mode. This means that the DSEL and the DCLK signals are provided by microcontroller audio data interface.
Serial Audio DAC Interface
The serial audio DAC interface is a Synchronous Peripheral Interface (SPI) in slave mode: • • • AUDCDIN: is used to transfer data in series from the master to the slave DAC. It is driven by the master. AUDCDOUT: is used to transfer data in series from the slave DAC to the master. It is driven by the selected slave DAC. Serial Clock (AUDCCLK): it is used to synchronize the data transmission both in and out the devices through the AUDCDIN and AUDCDOUT lines.
Refer to Table 29. for DAC SPI Interface Description
Note:
23
7524B–MP3–05/06
Figure 24. Serial Audio Interface
Serial Audio Interface
Audio DAC
AUDCDIN AUDCDOUT AUDCCLK AUDCCS
Audio PA
Protocol is as following to access DAC registers: Figure 25. Dac SPI Interface
AUDCCS
AUDCCLK
AUDCDIN
AUDCDOUT
DAC Interface SPI Protocol
On AUDCDIN, the first bit is a read/write bit. 0 indicates a write operation while 1 is for a read operation. The 7 following bits are used for the register address and the 8 last ones are the write data. For both address and data, the most significant bit is the first one. In case of a read operation, AUDCDOUT provides the contents of the read register, MSB first. The transfer is enabled by the AUDCCS signal active low. The interface is resetted at every rising edge of AUDCCS in order to come back to an idle state, even if the transfer does not succeed. The DAC Interface SPI is synchronized with the serial clock AUDC-
24
AT83SND2CMP3
7524B–MP3–05/06
0d 1d 2d 3d 4d 5d
0d 1d 2d 3d 4d 5d 6d 7d
6d
7d 0 a 1 a 2a 3a 4a 5a 6a wr
AT83SND2CMP3
CLK. Falling edge latches AUDCDIN input and rising edge shifts AUDCDOUT output bits. Note that the DLCK must run during any DAC SPI interface access (read or write). Figure 26. DAC SPI Interface Timings
AUDCCS
AUDCCLK
AUDCDIN
AUDCDOUT
Table 19. Dac SPI Interface Timings
Timing parameter Tc Twl Twh Tssen Thsen Tssdi Thsdi Tdsdo Thsdo Description AUDCCLK min period AUDCCLK min pulse width low AUDCCLK min pulse width high Setup time AUDCCS falling to AUDCCLK rising Hold time AUDCCLK falling to AUDCCS rising Setup time AUDCDIN valid to AUDCCLK falling Hold time AUDCCLK falling to AUDCDIN not valid Delay time AUDCCLK rising to AUDCDOUT valid Hold time AUDCCLK rising to AUDCDOUT not valid Min 150 ns 50 ns 50 ns 50 ns 50 ns 20 ns 20 ns 0 ns Max 20 ns -
7524B–MP3–05/06
neshT hwT
25
odshT
cT lwT idshT idssT odsdT
nessT
DAC Register Tables
Table 20. DAC Register Address
Address 00h 01h 02h 03h 04h 05h 06h 07h 08h 09h 0Ah 0Ch 0Dh 10h 11h Register DAC_CTRL DAC_LLIG DAC_RLIG DAC_LPMG DAC_RPMG DAC_LLOG DAC_RLOG DAC_OLC DAC_MC DAC_CSFC DAC_MISC DAC_PRECH DAC_AUXG DAC_RST PA_CRTL Name Dac Control Dac Left Line in Gain Dac Right Line in Gain Dac Left Master Playback Gain Dac Right Master Playback Gain Dac Left Line Out Gain Dac Right Line Out Gain Dac Output Level Control Dac Mixer Control Dac Clock and Sampling Frequency Control Dac Miscellaneous Dac Precharge Control Dac Auxilary input gain Control Dac Reset Power Amplifier Control Access Read/Write Read/Write Read/Write Read/Write Read/Write Read/Write Read/Write Read/Write Read/Write Read/Write Read/Write Read/Write Read/Write Read/Write Read/Write Reset state 00h 05h 05h 08h 08h 00h 00h 22h 09h 00h 00h 00h 05h 00h 00h
DAC Gain
The DAC implements severals gain control: line-in (Table 21.), master playback (), lineout (Table 24.).
Table 21. Line-in gain
LLIG 4:0 RLIG 4:0 00000 00001 00010 00011 00100 00101 00110 00111 01000 01001 01010 01011 01100 Gain (dB) 20 12 9 6 3 0 -3 -6 -9 -12 -15 -18 -21
26
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Table 21. Line-in gain (Continued)
01101 01110 01111 10000 10001 -24 -27 -30 -33 < -60
Table 22. Master Playback Gain
LMPG 5:0 RMPG 5:0 000000 000001 000010 000011 000100 000101 000110 000111 001000 001001 001010 001011 001100 001101 001110 001111 010000 010001 010010 010011 010100 010101 010110 010111 011000 011001 Gain (dB) 12.0 10.5 9.0 7.5 6.0 4.5 3.0 1.5 0.0 -1.5 -3.0 -4.5 -6.0 -7.5 -9.0 -10.5 -12.0 -13.5 -15.0 -16.5 -18.0 -19.5 -21.0 -22.5 -24.0 -25.5
27
7524B–MP3–05/06
Table 22. Master Playback Gain (Continued)
LMPG 5:0 RMPG 5:0 011010 011011 011100 011101 011110 011111 100000 Gain (dB) -27.0 -28.5 -30.0 -31.5 -33.0 -34.5 mute
Table 23. Line-out Gain
LLOG 5:0 RLOG 5:0 000000 000001 000010 000011 000100 000101 000110 000111 001000 001001 001010 001011 001100 001101 001110 001111 010000 010001 010010 010011 010100 010101 010110 Gain (dB) 0.0 -1.5 -3.0 -4.5 -6.0 -7.5 -9.0 -10.5 -12.0 -13.5 -15.0 -16.5 -18.0 -19.5 -21.0 -22.5 -24.0 -25.5 -27.0 -28.5 -30.0 -31.5 -33.0
28
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Table 23. Line-out Gain (Continued)
010111 011000 011001 011010 011011 011100 011101 011110 011111 100000 -34.5 -36.0 -37.5 -39.0 -40.5 -42.0 -43.5 -45.0 -46.5 mute
Table 24. DAC Output Level Control
LOLC 2:0 ROLC 2:0 000 001 010 011 100 Gain (dB) 6 3 0 -3 -6
Digital Mixer Control
The Audio DAC features a digital mixer that allows the mixing and selection of multiple input sources. The mixing / multiplexing functions are described in the following table according with the next figure:
Figure 27. Mixing / Multiplexing functions
Left channel
Volume Control
+
2
1
Volume Control
To DACs 1
From digital filters
Volume Control
+
2
Volume Control
Right channel
Note:
Whenever the two mixer inputs are selected, a –6 dB gain is applied to the output signal. Whenever only one input is selected, no gain is applied.
29
7524B–MP3–05/06
Signal LMSMIN1 LMSMIN2
Description Left Channel Mono/Stereo Mixer Left Mixed input enable – High to enable, Low to disable Left Channel Mono/Stereo Mixer Right Mixed input enable – High to enable, Low to disable Right Channel Mono/Stereo Mixer Left Mixed input enable – High to enable, Low to disable Right Channel Mono/Stereo Mixer Right Mixed input enable – High to enable, Low to disable
RMSMIN1
RMSMIN2
Note:
Refer to DAC_MC register Table 38. for signal description
Master Clock and Sampling Frequency Selection
The following table describes the different modes available for master clock and sampling frequency selection by setting OVRSEL bit in DAC_CSFC register (refer to Table 39.). Table 25. Master Clock selection
OVRSEL 0 1 Master Clock 256 x FS 384 x FS
The selection of input sample size is done using the NBITS 1:0 in DAC_MISC register (refer to Table 40.) according to Table 26. Table 26. Input Sample Size Selection
NBITS 1:0 00 01 10 Format 16 bits 18 bits 20 bits
The selection between modes is done using DINTSEL 1:0 in DAC_MISC register (refer to Table 40.) according to Table 27. Table 27. Format Selection
DINTSEL 1:0 00 01 1x Format I2S Justified MSB Justified LSB Justified
De-emphasis and dither enable
The circuit features a de-emphasis filter for the playback channel. To enable the deemphasis filtering, DEEMPEN must be set to high. Likewise, the dither option (added in the playback channel) is enabled by setting the DITHEN signal to High.
30
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Table 28. DAC Auxlilary Input Gain
AUXG 4:0 00000 00001 00010 00011 00100 00101 00110 00111 01000 01001 01010 01011 01100 01101 01110 01111 10000 10001 Gain (dB) 20 12 9 6 3 0 -3 -6 -9 -12 -15 -18 -21 -24 -27 -30 -33 Serial
CRC7 Generator
CTPTR
MMCON0.4
TX COMMAND Line Finished State Machine CFLCK
MMSTA.0
MMINT.5
EOCI MCMD
CMDEN
Command Transmitter
MMCON1.0 MMSTA.2 MMSTA.1
CRC7S Data Converter Serial -> //
RESPFS
RX Pointer
17 - Byte FIFO MMCMD Read
CRC7 and Format Checker
CRPTR
MMCON0.5
RX COMMAND Line Finished State Machine RESPEN
Command Receiver
MMINT.6
EORI
RFMT
CRCDIS
MMCON1.1 MMCON0.1 MMCON0.0
Command Transmitter
For sending a command to the card, user must load the command index (1 Byte) and argument (4 Bytes) in the command transmit FIFO using the MMCMD register. Before starting transmission by setting and clearing the CMDEN bit in MMCON1 register, user must first configure: • RESPEN bit in MMCON1 register to indicate whether a response is expected or not. • • RFMT bit in MMCON0 register to indicate the response size expected. CRCDIS bit in MMCON0 register to indicate whether the CRC7 included in the response will be computed or not. In order to avoid CRC error, CRCDIS may be set for response that do not include CRC7.
Figure 49 summarizes the command transmission flow. As soon as command transmission is enabled, the CFLCK flag in MMSTA is set indicating that write to the FIFO is locked. This mechanism is implemented to avoid command overrun. The end of the command transmission is signalled to you by the EOCI flag in MMINT register becoming set. This flag may generate an MMC interrupt request as detailed in Section "Interrupt", page 66. The end of the command transmission also resets the CFLCK flag.
58
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
User may abort command loading by setting and clearing the CTPTR bit in MMCON0 register which resets the write pointer to the transmit FIFO.
Figure 49. Command Transmission Flow
Command Transmission
Load Command in Buffer MMCMD = index MMCMD = argument
Configure Response RESPEN = X RFMT = X CRCDIS = X
Transmit Command CMDEN = 1 CMDEN = 0
Command Receiver
The end of the response reception is signalled to you by the EORI flag in MMINT register. This flag may generate an MMC interrupt request as detailed in Section "Interrupt", page 66. When this flag is set, 2 other flags in MMSTA register: RESPFS and CRC7S give a status on the response received. RESPFS indicates if the response format is correct or not: the size is the one expected (48 bits or 136 bits) and a valid End bit has been received, and CRC7S indicates if the CRC7 computation is correct or not. These Flags are cleared when a command is sent to the card and updated when the response has been received. User may abort response reading by setting and clearing the CRPTR bit in MMCON0 register which resets the read pointer to the receive FIFO. According to the MMC specification delay between a command and a response (formally NCR parameter) can not exceed 64 MMC clock periods. To avoid any locking of the MMC controller when card does not send its response (e.g. physically removed from the bus), user must launch a time-out period to exit from such situation. In case of timeout user may reset the command controller and its internal state machine by setting and clearing the CCR bit in MMCON2 register. This time-out may be disarmed when receiving the response.
59
7524B–MP3–05/06
Data Line Controller
The data line controller is based on a 16-Byte FIFO used both by the data transmitter channel and by the data receiver channel.
Figure 50. Data Line Controller Block Diagram
MMINT.0
MMINT.2
MMSTA.3
MMSTA.4
F1EI
F1FI
DATFS
CRC16S Data Converter Serial -> //
CRC16 and Format Checker 8-Byte
TX Pointer
FIFO 1 16-Byte FIFO MMDAT 8-Byte FIFO 2
MCBI
MMINT.1
CBUSY
MMSTA.5
MDAT CRC16 Generator
DTPTR
MMCON0.6
RX Pointer
Data Converter // -> Serial
DRPTR
MMCON0.7
DATA Line Finished State Machine DFMT MBLOCK
MMCON0.3
MMINT.4
EOFI
DATEN
MMCON1.2
DATDIR
BLEN3:0
F2EI
MMINT.1
F2FI
MMINT.3
MMCON0.2
MMCON1.3 MMCON1.7:4
FIFO Implementation
The 16-Byte FIFO is based on a dual 8-Byte FIFOs managed using 2 pointers and four flags indicating the status full and empty of each FIFO. Pointers are not accessible to user but can be reset at any time by setting and clearing DRPTR and DTPTR bits in MMCON0 register. Resetting the pointers is equivalent to abort the writing or reading of data. F1EI and F2EI flags in MMINT register signal when set that respectively FIFO1 and FIFO2 are empty. F1FI and F2FI flags in MMINT register signal when set that respectively FIFO1 and FIFO2 are full. These flags may generate an MMC interrupt request as detailed in Section “Interrupt”. Before sending or receiving any data, the data line controller must be configured according to the type of the data transfer considered. This is achieved using the Data Format bit: DFMT in MMCON0 register. Clearing DFMT bit enables the data stream format while setting DFMT bit enables the data block format. In data block format, user must also configure the single or multi-block mode by clearing or setting the MBLOCK bit in MMCON0 register and the block length using BLEN3:0 bits in MMCON1 according to Table 54. Figure 51 summarizes the data modes configuration flows.
Table 54. Block Length Programming
BLEN3:0 BLEN = 0000 to 1011 > 1011 Block Length (Byte) Length = 2 BLEN: 1 to 2048 Reserved: do not program BLEN3:0 > 1011
Data Configuration
60
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Figure 51. Data Controller Configuration Flows
Data Stream Configuration Data Single Block Configuration Data Multi-Block Configuration
Configure Format DFMT = 0
Configure Format DFMT = 1 MBLOCK = 0 BLEN3:0 = XXXXb
Configure Format DFMT = 1 MBLOCK = 1 BLEN3:0 = XXXXb
Data Transmitter Configuration
For transmitting data to the card user must first configure the data controller in transmission mode by setting the DATDIR bit in MMCON1 register. Figure 52 summarizes the data stream transmission flows in both polling and interrupt modes while Figure 53 summarizes the data block transmission flows in both polling and interrupt modes, these flows assume that block length is greater than 16 data.
Data Loading
Data is loaded in the FIFO by writing to MMDAT register. Number of data loaded may vary from 1 to 16 Bytes. Then if necessary (more than 16 Bytes to send) user must wait that one FIFO becomes empty (F1EI or F2EI set) before loading 8 new data. Transmission is enabled by setting and clearing DATEN bit in MMCON1 register. Data is transmitted immediately if the response has already been received, or is delayed after the response reception if its status is correct. In both cases transmission is delayed if a card sends a busy state on the data line until the end of this busy condition. According to the MMC specification, the data transfer from the host to the card may not start sooner than 2 MMC clock periods after the card response was received (formally N WR p arameter). To address all card types, this delay can be programmed using DATD1:0 bits in MMCON2 register from 3 MMC clock periods when DATD1:0 bits are cleared to 9 MMC clock periods when DATD1:0 bits are set, by step of 2 MMC clock periods.
Data Transmission
End of Transmission
The end of a data frame (block or stream) transmission is signalled to you by the EOFI flag in MMINT register. This flag may generate an MMC interrupt request as detailed in Section "Interrupt", page 66. In data stream mode, EOFI flag is set, after reception of the End bit. This assumes user has previously sent the STOP command to the card, which is the only way to stop stream transfer. In data block mode, EOFI flag is set, after reception of the CRC status token (see Figure 43). 2 other flags in MMSTA register: DATFS and CRC16S report a status on the frame sent. DATFS indicates if the CRC status token format is correct or not, and CRC16S indicates if the card has found the CRC16 of the block correct or not.
Busy Status
As shown in Figure 43 the card uses a busy token during a block write operation. This busy status is reported to you by the CBUSY flag in MMSTA register and by the MCBI flag in MMINT which is set every time CBUSY toggles, i.e. when the card enters and exits its busy state. This flag may generate an MMC interrupt request as detailed in Section "Interrupt", page 66.
61
7524B–MP3–05/06
Figure 52. Data Stream Transmission Flows
Data Stream Transmission Data Stream Initialization Data Stream Transmission ISR
FIFOs Filling write 16 data to MMDAT
FIFOs Filling write 16 data to MMDAT
FIFO Empty? F1EI or F2EI = 1?
Start Transmission DATEN = 1 DATEN = 0
Unmask FIFOs Empty F1EM = 0 F2EM = 0
FIFO Filling write 8 data to MMDAT
FIFO Empty? F1EI or F2EI = 1?
Start Transmission DATEN = 1 DATEN = 0
No More Data To Send?
FIFO Filling write 8 data to MMDAT
Mask FIFOs Empty F1EM = 1 F2EM = 1
No More Data To Send?
Send STOP Command
Send STOP Command
b. Interrupt mode
a. Polling mode
62
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Figure 53. Data Block Transmission Flows
Data Block Transmission Data Block Initialization Data Block Transmission ISR
FIFOs Filling write 16 data to MMDAT
FIFOs Filling write 16 data to MMDAT
FIFO Empty? F1EI or F2EI = 1?
Start Transmission DATEN = 1 DATEN = 0
Unmask FIFOs Empty F1EM = 0 F2EM = 0
FIFO Filling write 8 data to MMDAT
FIFO Empty? F1EI or F2EI = 1?
Start Transmission DATEN = 1 DATEN = 0
No More Data To Send?
FIFO Filling write 8 data to MMDAT
Mask FIFOs Empty F1EM = 1 F2EM = 1
No More Data To Send?
b. Interrupt mode
a. Polling mode
Data Receiver Configuration
To receive data from the card you must first configure the data controller in reception mode by clearing the DATDIR bit in MMCON1 register. Figure 54 summarizes the data stream reception flows in both polling and interrupt modes while Figure 55 summarizes the data block reception flows in both polling and interrupt modes, these flows assume that block length is greater than 16 Bytes.
Data Reception
The end of a data frame (block or stream) reception is signalled to you by the EOFI flag in MMINT register. This flag may generate an MMC interrupt request as detailed in Section "Interrupt", page 66. When this flag is set, 2 other flags in MMSTA register: DATFS and CRC16S give a status on the frame received. DATFS indicates if the frame format is correct or not: a valid End bit has been received, and CRC16S indicates if the CRC16 computation is correct or not. In case of data stream CRC16S has no meaning and stays cleared. According to the MMC specification data transmission from the card starts after the access time delay (formally NAC parameter) beginning from the End bit of the read command. To avoid any locking of the MMC controller when card does not send its data (e.g. physically removed from the bus), you must launch a time-out period to exit from such situation. In case of time-out you may reset the data controller and its internal state machine by setting and clearing the DCR bit in MMCON2 register.
63
7524B–MP3–05/06
This time-out may be disarmed after receiving 8 data (F1FI flag set) or after receiving end of frame (EOFI flag set) in case of block length less than 8 data (1, 2 or 4).
Data Reading
Data is read from the FIFO by reading to MMDAT register. Each time one FIFO becomes full (F1FI or F2FI set), user is requested to flush this FIFO by reading 8 data.
Figure 54. Data Stream Reception Flows
Data Stream Reception Data Stream Initialization Data Stream Reception ISR
FIFO Full? F1FI or F2FI = 1?
Unmask FIFOs Full F1FM = 0 F2FM = 0
FIFO Full? F1FI or F2FI = 1?
FIFO Reading read 8 data from MMDAT
FIFO Reading read 8 data from MMDAT
No More Data To Receive?
No More Data To Receive?
Send STOP Command
Mask FIFOs Full F1FM = 1 F2FM = 1
a. Polling mode
Send STOP Command
b. Interrupt mode
64
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Figure 55. Data Block Reception Flows
Data Block Reception Data Block Initialization Data Block Reception ISR
Start Transmission DATEN = 1 DATEN = 0
Unmask FIFOs Full F1FM = 0 F2FM = 0
FIFO Full? F1EI or F2EI = 1?
FIFO Full? F1EI or F2EI = 1?
Start Transmission DATEN = 1 DATEN = 0
FIFO Reading read 8 data from MMDAT
FIFO Reading read 8 data from MMDAT
No More Data To Receive?
No More Data To Receive?
Mask FIFOs Full F1FM = 1 F2FM = 1
a. Polling mode
b. Interrupt mode
Flow Control
To allow transfer at high speed without taking care of CPU oscillator frequency, the FLOWC bit in MMCON2 allows control of the data flow in both transmission and reception. During transmission, setting the FLOWC bit has the following effects: • • • • MMCLK is stopped when both FIFOs become empty: F1EI and F2EI set. MMCLK is restarted when one of the FIFOs becomes full: F1EI or F2EI cleared. MMCLK is stopped when both FIFOs become full: F1FI and F2FI set. MMCLK is restarted when one of the FIFOs becomes empty: F1FI or F2FI cleared.
During reception, setting the FLOWC bit has the following effects:
As soon as the clock is stopped, the MMC bus is frozen and remains in its state until the clock is restored by writing or reading data in MMDAT.
65
7524B–MP3–05/06
Interrupt
Description
As shown in Figure 56, the MMC controller implements eight interrupt sources reported in MCBI, EORI, EOCI, EOFI, F2FI, F1FI, and F2EI flags in MMCINT register. These flags are detailed in the previous sections. All these sources are maskable separately using MCBM, EORM, EOCM, EOFM, F2FM, F1FM, and F2EM mask bits respectively in MMMSK register. The interrupt request is generated each time an unmasked flag is set, and the global MMC controller interrupt enable bit is set (EMMC in IEN1 register). Reading the MMINT register automatically clears the interrupt flags (acknowledgment). This implies that register content must be saved and tested interrupt flag by interrupt flag to be sure not to forget any interrupts.
Figure 56. MMC Controller Interrupt System
MCBI
MMINT.7
MCBM EORI
MMINT.6 MMMSK.7
EORM EOCI
MMINT.5 MMMSK.6
EOCM EOFI
MMINT.4 MMMSK.5
EOFM F2FI
MMINT.3 MMMSK.4
MMC Interface Interrupt Request EMMC F2FM
IEN1.0 MMMSK.3
F1FI
MMINT.2
F1FM F2EI
MMINT.1 MMMSK.2
F2EM F1EI
MMINT.0 MMMSK.1
F1EM
MMMSK.0
66
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Serial I/O Port
The serial I/O port in the AT83SND2CMP3 provides both synchronous and asynchronous communication modes. It operates as a Synchronous Receiver and Transmitter in one single mode (Mode 0) and operates as an Universal Asynchronous Receiver and Transmitter (UART) in three full-duplex modes (Modes 1, 2 and 3). Asynchronous modes support framing error detection and multiprocessor communication with automatic address recognition. SM0 and SM1 bits in SCON register are used to select a mode among the single synchronous and the three asynchronous modes according to Table 55.
Table 55. Serial I/O Port Mode Selection
SM0 0 0 1 1 SM1 0 1 0 1 Mode 0 1 2 3 Description Synchronous Shift Register 8-bit UART 9-bit UART 9-bit UART Baud Rate Fixed/Variable Variable Fixed Variable
Mode Selection
Baud Rate Generator
Depending on the mode and the source selection, the baud rate can be generated from either the Timer 1 or the Internal Baud Rate Generator. The Timer 1 can be used in Modes 1 and 3 while the Internal Baud Rate Generator can be used in Modes 0, 1 and 3. The addition of the Internal Baud Rate Generator allows freeing of the Timer 1 for other purposes in the application. It is highly recommended to use the Internal Baud Rate Generator as it allows higher and more accurate baud rates than Timer 1. Baud rate formulas depend on the modes selected and are given in the following mode sections.
Timer 1
When using Timer 1, the Baud Rate is derived from the overflow of the timer. As shown in Figure 57 Timer 1 is used in its 8-bit auto-reload mode (detailed in Section "Mode 2 (8-bit Timer with Auto-Reload)", page 53). SMOD1 bit in PCON register allows doubling of the generated baud rate.
Figure 57. Timer 1 Baud Rate Generator Block Diagram
PER CLOCK ÷6 0 1
TL1 (8 bits)
Overflow
÷2
0 1
T1 C/T1#
TMOD.6
To serial Port
INT1
GATE1
TMOD.7
SMOD1
PCON.7
TH1 (8 bits)
T1 CLOCK
TR1
TCON.6
67
7524B–MP3–05/06
Internal Baud Rate Generator
When using the Internal Baud Rate Generator, the Baud Rate is derived from the overflow of the timer. As shown in Figure 58 the Internal Baud Rate Generator is an 8-bit auto-reload timer fed by the peripheral clock or by the peripheral clock divided by 6 depending on the SPD bit in BDRCON register. The Internal Baud Rate Generator is enabled by setting BBR bit in BDRCON register. SMOD1 bit in PCON register allows doubling of the generated baud rate.
Figure 58. Internal Baud Rate Generator Block Diagram
PER CLOCK ÷6 0 1
BRG (8 bits) BRR
BDRCON.4
Overflow
÷2
0 1
To serial Port
SPD
BDRCON.1
SMOD1
PCON.7
BRL (8 bits)
IBRG CLOCK
Synchronous Mode (Mode 0)
Mode 0 is a half-duplex, synchronous mode, which is commonly used to expand the I/0 capabilities of a device with shift registers. The transmit data (TXD) pin outputs a set of eight clock pulses while the receive data (RXD) pin transmits or receives a Byte of data. The 8-bit data are transmitted and received least-significant bit (LSB) first. Shifts occur at a fixed Baud Rate (see Section "Baud Rate Selection (Mode 0)", page 69). Figure 59 shows the serial port block diagram in Mode 0.
Figure 59. Serial I/O Port Block Diagram (Mode 0)
SCON.6 SCON.7
SM1
SM0 SBUF Tx SR RXD
Mode Decoder
M3 M2 M1 M0
SBUF Rx SR Mode Controller
PER CLOCK
TI
SCON.1
RI
SCON.0
BRG CLOCK
Baud Rate Controller
TXD
Transmission (Mode 0)
To start a transmission mode 0, write to SCON register clearing bits SM0, SM1. As shown in Figure 60, writing the Byte to transmit to SBUF register starts the transmission. Hardware shifts the LSB (D0) onto the RXD pin during the first clock cycle composed of a high level then low level signal on TXD. During the eighth clock cycle the MSB (D7) is on the RXD pin. Then, hardware drives the RXD pin high and asserts TI to indicate the end of the transmission.
68
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Figure 60. Transmission Waveforms (Mode 0)
TXD Write to SBUF RXD TI
D0 D1 D2 D3 D4 D5 D6 D7
Reception (Mode 0)
To start a reception in mode 0, write to SCON register clearing SM0, SM1 and RI bits and setting the REN bit. As shown in Figure 61, Clock is pulsed and the LSB (D0) is sampled on the RXD pin. The D0 bit is then shifted into the shift register. After eight samplings, the MSB (D7) is shifted into the shift register, and hardware asserts RI bit to indicate a completed reception. Software can then read the received Byte from SBUF register.
Figure 61. Reception Waveforms (Mode 0)
TXD Write to SCON RXD RI
Set REN, Clear RI D0 D1 D2 D3 D4 D5 D6 D7
Baud Rate Selection (Mode 0)
In mode 0, the baud rate can be either, fixed or variable. As shown in Figure 62, the selection is done using M0SRC bit in BDRCON register. Figure 63 gives the baud rate calculation formulas for each baud rate source.
Figure 62. Baud Rate Source Selection (mode 0)
PER CLOCK IBRG CLOCK ÷6 0
To Serial Port
1
M0SRC
BDRCON.0
Figure 63. Baud Rate Formulas (Mode 0)
Baud_Rate= Baud_Rate FPER 6 6
(1-SPD)
2SMOD1 ⋅ FPER ⋅ 32 ⋅ (256 -BRL)
a. Fixed Formula
b. Variable Formula
7524B–MP3–05/06
-
BRL= 256
6
(1-SPD)
2SMOD1 ⋅ FPER ⋅ 32 ⋅ Baud_Rate
=
69
Asynchronous Modes (Modes 1, 2 and 3)
The Serial Port has one 8-bit and 2 9-bit asynchronous modes of operation. Figure 64 shows the Serial Port block diagram in such asynchronous modes. Figure 64. Serial I/O Port Block Diagram (Modes 1, 2 and 3)
SCON.6 SCON.7 SCON.3
SM1
SM0
TB8 SBUF Tx SR TXD
Mode Decoder
M3 M2 M1 M0 T1 CLOCK IBRG CLOCK PER CLOCK
Rx SR Mode & Clock Controller SBUF Rx SM2
SCON.4
RXD
RB8
SCON.2
TI
SCON.1
RI
SCON.0
Mode 1
Mode 1 is a full-duplex, asynchronous mode. The data frame (see Figure 65) consists of 10 bits: one start, eight data bits and one stop bit. Serial data is transmitted on the TXD pin and received on the RXD pin. When a data is received, the stop bit is read in the RB8 bit in SCON register. Figure 65. Data Frame Format (Mode 1)
Mode 1
Start bit D0 D1 D2 D3 D4 D5 D6 D7 Stop bit
8-bit data
Modes 2 and 3
Modes 2 and 3 are full-duplex, asynchronous modes. The data frame (see Figure 66) consists of 11 bits: one start bit, eight data bits (transmitted and received LSB first), one programmable ninth data bit and one stop bit. Serial data is transmitted on the TXD pin and received on the RXD pin. On receive, the ninth bit is read from RB8 bit in SCON register. On transmit, the ninth data bit is written to TB8 bit in SCON register. Alternatively, you can use the ninth bit can be used as a command/data flag. Figure 66. Data Frame Format (Modes 2 and 3)
D0 Start bit D1 D2 D3 D4 9-bit data D5 D6 D7 D8 Stop bit
Transmission (Modes 1, 2 and 3)
To initiate a transmission, write to SCON register, set the SM0 and SM1 bits according to Table 55, and set the ninth bit by writing to TB8 bit. Then, writing the Byte to be transmitted to SBUF register starts the transmission. To prepare for reception, write to SCON register, set the SM0 and SM1 bits according to Table 55, and set the REN bit. The actual reception is then initiated by a detected highto-low transition on the RXD pin.
Reception (Modes 1, 2 and 3)
70
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Framing Error Detection (Modes 1, 2 and 3) Framing error detection is provided for the three asynchronous modes. To enable the framing bit error detection feature, set SMOD0 bit in PCON register as shown in Figure 67. When this feature is enabled, the receiver checks each incoming data frame for a valid stop bit. An invalid stop bit may result from noise on the serial lines or from simultaneous transmission by 2 devices. If a valid stop bit is not found, the software sets FE bit in SCON register. Software may examine FE bit after each reception to check for data errors. Once set, only software or a chip reset clear FE bit. Subsequently received frames with valid stop bits cannot clear FE bit. When the framing error detection feature is enabled, RI rises on stop bit instead of the last data bit as detailed in Figure 73. Figure 67. Framing Error Block Diagram
Framing Error Controller
FE 1
SM0/FE
0
SCON.7
SM0 SMOD0
PCON.6
Baud Rate Selection (Modes 1 and 3)
In modes 1 and 3, the Baud Rate is derived either from the Timer 1 or the Internal Baud Rate Generator and allows different baud rate in reception and transmission. As shown in Figure 68 the selection is done using RBCK and TBCK bits in BDRCON register. Figure 69 gives the baud rate calculation formulas for each baud rate source while Table 56 details Internal Baud Rate Generator configuration for different peripheral clock frequencies and giving baud rates closer to the standard baud rates. Figure 68. Baud Rate Source Selection (Modes 1 and 3)
T1 CLOCK IBRG CLOCK T1 CLOCK IBRG CLOCK
0 1
÷ 16
To Serial Rx Port
0 1
÷ 16
To Serial Tx Port
RBCK
BDRCON.2
TBCK
BDRCON.3
Figure 69. Baud Rate Formulas (Modes 1 and 3)
Baud_Rate= 2SMOD1 ⋅ FPER 6(1-SPD) ⋅ 32 ⋅ (256 -BRL) 2SMOD1 ⋅ FPER ⋅ 32 ⋅ Baud_Rate Baud_Rate= 2SMOD1 ⋅ FPER 6 ⋅ 32 ⋅ ( 256 -TH1) 2SMOD1 ⋅ FPER 192 ⋅ Baud_Rate
BRL= 256 -
6
(1-SPD)
TH1= 256 -
a. IBRG Formula
b. T1 Formula
71
7524B–MP3–05/06
Table 56. Internal Baud Rate Generator Value
FPER = 6 MHz(1) Baud Rate 115200 57600 38400 19200 9600 4800 SPD 1 1 1 1 SMOD1 1 1 1 1 BRL 246 236 217 178 Error % 2.34 2.34 0.16 0.16 SPD 1 1 1 1 1 FPER = 8 MHz(1) SMOD1 1 1 1 1 1 BRL 247 243 230 204 152 Error % 3.55 0.16 0.16 0.16 0.16 SPD 1 1 1 1 1 FPER = 10 MHz(1) SMOD1 1 1 1 1 1 BRL 245 240 223 191 126 Error % 1.36 1.73 1.36 0.16 0.16
FPER = 12 MHz(2) Baud Rate 115200 57600 38400 19200 9600 4800 SPD 1 1 1 1 1 SMOD1 1 1 1 1 1 BRL 243 236 217 178 100 Error % 0.16 2.34 0.16 0.16 0.16 SPD 1 1 1 1 1 1
FPER = 16 MHz(2) SMOD1 1 1 1 1 1 1 BRL 247 239 230 204 152 48 Error % 3.55 2.12 0.16 0.16 0.16 0.16 SPD 1 1 1 1 1 1
FPER = 20 MHz(2) SMOD1 1 1 1 1 1 0 BRL 245 234 223 191 126 126 Error % 1.36 1.36 1.36 0.16 0.16 0.16
Notes:
1. These frequencies are achieved in X1 mode, FPER = F OSC ÷ 2. 2. These frequencies are achieved in X2 mode, FPER = F OSC.
Baud Rate Selection (Mode 2)
In mode 2, the baud rate can only be programmed to 2 fixed values: 1/16 or 1/32 of the peripheral clock frequency. As shown in Figure 70 the selection is done using SMOD1 bit in PCON register. Figure 71 gives the baud rate calculation formula depending on the selection. Figure 70. Baud Rate Generator Selection (Mode 2)
PER CLOCK
÷2
0 1
÷ 16
To Serial Port
SMOD1
PCON.7
72
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Figure 71. Baud Rate Formula (Mode 2)
Baud_Rate= 2SMOD1 ⋅ FPER 32
Multiprocessor Communication (Modes 2 and 3)
Modes 2 and 3 provide a ninth-bit mode to facilitate multiprocessor communication. To enable this feature, set SM2 bit in SCON register. When the multiprocessor communication feature is enabled, the serial Port can differentiate between data frames (ninth bit clear) and address frames (ninth bit set). This allows the AT83SND2CMP3 to function as a slave processor in an environment where multiple slave processors share a single serial line. When the multiprocessor communication feature is enabled, the receiver ignores frames with the ninth bit clear. The receiver examines frames with the ninth bit set for an address match. If the received address matches the slaves address, the receiver hardware sets RB8 and RI bits in SCON register, generating an interrupt. The addressed slave’s software then clears SM2 bit in SCON register and prepares to receive the data Bytes. The other slaves are unaffected by these data Bytes because they are waiting to respond to their own addresses.
Automatic Address Recognition
The automatic address recognition feature is enabled when the multiprocessor communication feature is enabled (SM2 bit in SCON register is set). Implemented in hardware, automatic address recognition enhances the multiprocessor communication feature by allowing the Serial Port to examine the address of each incoming command frame. Only when the Serial Port recognizes its own address, the receiver sets RI bit in SCON register to generate an interrupt. This ensures that the CPU is not interrupted by command frames addressed to other devices. If desired, the automatic address recognition feature in mode 1 may be enabled. In this configuration, the stop bit takes the place of the ninth data bit. Bit RI is set only when the received command frame address matches the device’s address and is terminated by a valid stop bit. To support automatic address recognition, a device is identified by a given address and a broadcast address.
Note: The multiprocessor communication and automatic address recognition features cannot be enabled in mode 0 (i.e, setting SM2 bit in SCON register in mode 0 has no effect).
Given Address
Each device has an individual address that is specified in SADDR register; the SADEN register is a mask Byte that contains don’t care bits (defined by zeros) to form the device’s given address. The don’t care bits provide the flexibility to address one or more slaves at a time. The following example illustrates how a given address is formed. To address a device by its individual address, the SADEN mask Byte must be 1111 1111b. For example:
SADDR = 0101 0110b SADEN = 1111 1100b Given = 0101 01XXb
73
7524B–MP3–05/06
The following is an example of how to use given addresses to address different slaves:
Slave A:SADDR = 1111 0001b SADEN = 1111 1010b Given = 1111 0X0Xb Slave B:SADDR = 1111 0011b SADEN = 1111 1001b Given = 1111 0XX1b Slave C:SADDR = 1111 0011b SADEN = 1111 1101b Given = 1111 00X1b
The SADEN Byte is selected so that each slave may be addressed separately. For slave A, bit 0 (the LSB) is a don’t-care bit; for slaves B and C, bit 0 is a 1. To communicate with slave A only, the master must send an address where bit 0 is clear (e.g. 1111 0000B). For slave A, bit 1 is a 0; for slaves B and C, bit 1 is a don’t care bit. To communicate with slaves A and B, but not slave C, the master must send an address with bits 0 and 1 both set (e.g. 1111 0011B). To communicate with slaves A, B and C, the master must send an address with bit 0 set, bit 1 clear, and bit 2 clear (e.g. 1111 0001B). Broadcast Address A broadcast address is formed from the logical OR of the SADDR and SADEN registers with zeros defined as don’t-care bits, e.g.:
SADDR = 0101 0110b SADEN = 1111 1100b (SADDR | SADEN)=1111 111Xb
The use of don’t-care bits provides flexibility in defining the broadcast address, however in most applications, a broadcast address is FFh. The following is an example of using broadcast addresses:
Slave A:SADDR = 1111 0001b SADEN = 1111 1010b Given = 1111 1X11b, Slave B:SADDR = 1111 0011b SADEN = 1111 1001b Given = 1111 1X11b, Slave C:SADDR = 1111 0010b SADEN = 1111 1101b Given = 1111 1111b,
For slaves A and B, bit 2 is a don’t care bit; for slave C, bit 2 is set. To communicate with all of the slaves, the master must send the address FFh. To communicate with slaves A and B, but not slave C, the master must send the address FBh. Reset Address On reset, the SADDR and SADEN registers are initialized to 00h, i.e. the given and broadcast addresses are XXXX XXXXb (all don’t care bits). This ensures that the Serial Port is backwards compatible with the 80C51 microcontrollers that do not support automatic address recognition.
74
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Interrupt
The Serial I/O Port handles 2 interrupt sources that are the “end of reception” (RI in SCON) and “end of transmission” (TI in SCON) flags. As shown in Figure 72 these flags are combined together to appear as a single interrupt source for the C51 core. Flags must be cleared by software when executing the serial interrupt service routine. The serial interrupt is enabled by setting ES bit in IEN0 register. This assumes interrupts are globally enabled by setting EA bit in IEN0 register. Depending on the selected mode and weather the framing error detection is enabled or disabled, RI flag is set during the stop bit or during the ninth bit as detailed in Figure 73. Figure 72. Serial I/O Interrupt System
SCON.0 RI Serial I/O Interrupt Request TI SCON.1 ES IEN0.4
Figure 73. Interrupt Waveforms
a. Mode 1 RXD Start Bit RI SMOD0 = X FE SMOD0 = 1 b. Mode 2 and 3 RXD Start bit RI SMOD0 = 0 RI SMOD0 = 1 FE SMOD0 = 1 D0 D1 D2 D3 D4 9-bit data D5 D6 D7 D8 Stop bit D0 D1 D2 D3 D4 D5 D6 D7 Stop Bit
8-bit Data
75
7524B–MP3–05/06
Keyboard Interface
The AT83SND2CMP3 implement a keyboard interface allowing the connection of a keypad. It is based on one input with programmable interrupt capability on both high or low level. This input allows exit from idle and power down modes. The keyboard interfaces with the C51 core through 2 special function registers: KBCON, the keyboard control register; and KBSTA, the keyboard control and status register. An interrupt enable bit (EKB in IEN1 register) allows global enable or disable of the keyboard interrupt (see Figure 74). As detailed in Figure 75 this keyboard input has the capability to detect a programmable level according to KINL0 bit value in KBCON register. Level detection is then reported in interrupt flag KINF0 in KBSTA register. A keyboard interrupt is requested each time this flag is set. This flag can be masked by software using KINM0 bits in KBCON register and is cleared by reading KBSTA register.
Description
Figure 74. Keyboard Interface Block Diagram
KIN0
Input Circuitry EKB
IEN1.4
Keyboard Interface Interrupt Request
Figure 75. Keyboard Input Circuitry
0
KIN0
1
KINF0
KBSTA.0
KINM0 KINL0
KBCON.4 KBCON.0
Power Reduction Mode
KIN0 inputs allow exit from idle and power-down modes as detailed in section “Power Management”, page 46. To enable this feature, KPDE bit in KBSTA register must be set to logic 1. Due to the asynchronous keypad detection in power down mode (all clocks are stopped), exit may happen on parasitic key press. In this case, no key is detected and software must enter power down again.
76
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Electrical Characteristics
Absolute Maximum Rating
Storage Temperature ......................................... -65 to +150 °C Voltage on any other Pin to V SS
.................................... -0.3
*NOTICE:
to +4.0 V
IOL per I/O Pin ................................................................. 5 mA Power Dissipation ............................................................. 1 W Operating Conditions Ambient Temperature Under Bias........................ -40 to +85 °C VDD ......................................................................................................... 2.7 to 3.3V
Stressing the device beyond the “Absolute Maximum Ratings” may cause permanent damage. These are stress ratings only. Operation beyond the “operating conditions” is not recommended and extended exposure beyond the “Operating Conditions” may affect device reliability.
DC Characteristics
Digital Logic Table 57. Digital DC Characteristics VDD = 2.7 to 3.3 V, TA = -40 to +85°C
Symbol VIL VIH1(2) VIH2 VOL1 Parameter Input Low Voltage Input High Voltage (except RST, X1) Input High Voltage (RST, X1) Output Low Voltage (except P0, MCMD, MDAT, MCLK, SCLK, DCLK, DSEL, DOUT) Output Low Voltage (P0, MCMD, MDAT, MCLK, SCLK, DCLK, DSEL, DOUT) Output High Voltage (P1, P2, P3, P4 and P5) Output High Voltage (P0, P2 address mode, MCMD, MDAT, MCLK, SCLK, DCLK, DSEL, DOUT, D+, D-) Logical 0 Input Current (P1, P2, P3, P4 and P5) Input Leakage Current (P0, MCMD, MDAT, MCLK, SCLK, DCLK, DSEL, DOUT) Logical 1 to 0 Transition Current (P1, P2, P3, P4 and P5) Pull-Down Resistor Pin Capacitance VDD Data Retention Limit 50 90 10 1.8 VDD - 0.7 Min -0.5 0.2·VDD + 1.1 0.7·VDD Typ(1) Max 0.2·VDD - 0.1 VDD VDD + 0.5 0.45 Units V V V Test Conditions
V
IOL = 1.6 mA
VOL2
0.45
V
IOL = 3.2 mA
VOH1
V
IOH= -30 μA
VOH2
VDD - 0.7
V
IOH= -3.2 mA
IIL
-50
μA
VIN = 0.45 V
ILI
10
μA
0.45< VIN< VDD
ITL RRST CIO VRET IDD
-650 200
μA kΩ pF V
VIN = 2.0 V
TA= 25°C
77
7524B–MP3–05/06
Table 57. Digital DC Characteristics VDD = 2.7 to 3.3 V, TA = -40 to +85°C
Symbol Parameter Min Typ(1) Max X1 / X2 mode 7/ 11.5 9/ 14.5 10.5 / 18 X1 / X2 mode 6.3 / 9.1 7.4 / 11.3 8.5 / 14 20 500 Units Test Conditions VDD < 3.3 V mA 12 MHz 16 MHz 20 MHz VDD < 3.3 V mA 12 MHz 16 MHz 20 MHz VRET < VDD < 3.3 V
IDD
AT83SND2CMP3 Operating Current
IDL
AT83SND2CMP3 Idle Mode Current
IPD
AT83SND2CMP3 Power-Down Mode Current
μA
Notes:
1. Typical values are obtained using VDD= 3 V and TA= 25°C. They are not tested and there is no guarantee on these values.
Table 58. Typical Reference Design AT83SND2CMP3 Power Consumption
Player Mode IDD Test Conditions AT83SND2CMP3 at 16 MHz, X2 mode, VDD = 3 V No song playing. This consumption does not include AUDVBAT current. AT83SND2CMP3 at 16 MHz, X2 mode, VDD = 3 V MP3 Song with Fs= 44.1 KHz, at any bit rates (Variable Bit Rate) This consumption does not include AUDVBAT current.
Stop
10 mA
Playing
37 mA
IDD, IDL and IPD Test Conditions Figure 76. IDD Test Condition, Active Mode
VDD VDD
RST
VDD PVDD UVDD AUDVDD
IDD
(NC) Clock Signal
X2 X1 P0 VSS PVSS UVSS AUDVSS TST
VDD
VSS
All other pins are unconnected
78
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Figure 77. IDL Test Condition, Idle Mode
VDD
RST
VSS
VDD PVDD UVDD AUDVDD
IDL
(NC) Clock Signal
X2 X1 P0 VSS PVSS UVSS AUDVSS TST
VDD
VSS
All other pins are unconnected
Figure 78. IPD Test Condition, Power-Down Mode
VDD
RST
VSS
VDD PVDD UVDD AUDVDD P0 MCMD MDAT TST
IPD
VDD
(NC)
X2 X1 VSS PVSS UVSS AUDVSS
VSS
All other pins are unconnected
Oscillator & Crystal Schematic Figure 79. Crystal Connection
X1 C1 Q C2
VSS
X2
Note:
For operation with most standard crystals, no external components are needed on X1 and X2. It may be necessary to add external capacitors on X1 and X2 to ground in special cases (max 10 pF). X1 and X2 may not be used to drive other circuits.
Parameters
Table 59. Oscillator & Crystal Characteristics
79
7524B–MP3–05/06
VDD = 2.7 to 3.3 V, TA = -40 to +85°C
Symbol CX1 CX2 CL DL F RS CS Parameter Internal Capacitance (X1 - VSS) Internal Capacitance (X2 - VSS) Equivalent Load Capacitance (X1 - X2) Drive Level Crystal Frequency Crystal Series Resistance Crystal Shunt Capacitance Min Typ 10 10 5 50 20 40 6 Max Unit pF pF pF μW MHz Ω pF
Phase Lock Loop Schematic Figure 80. PLL Filter Connection
FILT R C1
VSS VSS
C2
Parameters
Table 60. PLL Filter Characteristics VDD = 2.7 to 3.3 V, TA = -40 to +85°C
Symbol R C1 C2 Filter Resistor Filter Capacitance 1 Filter Capacitance 2 Parameter Min Typ 100 10 2.2 Max Unit Ω nF nF
USB Connection Schematic Figure 81. USB Connection
VBUS D+ DGND VSS
To Power Supply RUSB
D+ D-
RUSB
Parameters
Table 61. USB Termination Characteristics VDD = 2.7 to 3.3 V, TA = -40 to +85°C
Symbol RUSB Parameter USB Termination Resistor Min Typ 27 Max Unit Ω
80
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
DAC and PA Electrical Specifications PA AUDVBAT = 3.6V, TA = 25°C unless otherwise noted. High power mode, 100nF capacitor connected between CBP and AUDVSS, 470nF input capacitors, Load = 8 ohms. Figure 82. PA Specification
Symbol AUDVBAT IDD IDDstby VCBP VOS ZIN ZLFP ZLLP CL PSRR Parameter Supply Voltage Quiescent Current Standby Current DC Reference Output differential offset Input impedance Output load Output load Capacitive load Power supply rejection ratio 200 – 2kHz Differential output 1KHz reference frequency BW Output Frequency bandwidth 3dB attenuation. 470nF input coupling capacitors tUP VN THDHP Output setup time Output noise Output distortion Off to on mode. Voltage already settled. Input capacitors precharged Max gain, A weighted High power mode, VDD = 3.2V, 1KHz, Pout=100mW, gain=0dB Low power mode, VDD = 3.2V , 1KHz, Vout= 100mVpp, Max gain, load 8 ohms in serie with 200 ohms 120 50 10 500 ms µVRMS dB 50 20000 Hz full gain Active state Full Power mode Low-Power mode Inputs shorted, no load Capacitance Conditions Min 3.2 -20 12K 6 100 Typ 6 AUDVBAT/2 0 20k 8 150 60 Max 5.5 8 2 20 30k 32 300 100 Unit V mA μA V mV W W W pF dB
THDLP GACC GSTEP
Output distortion
-
1
-
%
Overall Gain accuracy Gain Step Accuracy
-2 -0.7
0 0
2 0.7
dB dB
Figure 83. Maximum Dissipated Power Versus Power Supply
81
7524B–MP3–05/06
600 550 Dissipated Power [mW] 500 450 400 350 300 250 200 3,2 3,4 3,6 3,8 4 Supply Voltage AUDVBAT [V] 4,2 8 Ohms load 6.5 Ohms load
Figure 84. Dissipated Power vs Output Power, AUDVBAT = 3.2V
600 550 500 Dissipated Power [mW] 450 400 350 300 250 200 150 100 50 0 0 100 200 300 400 500 600 700 800 Output Power [mW] 8 Ohms load 6.5 Ohms load
D AC
AUDVDD, HSVDD = 2.8 V, Ta=25°C, typical case, unless otherwise noted All noise and distortion specifications are measured in the 20 Hz to 0.425xFs and Aweighted filtered. Full Scale levels scale proportionally with the analog supply voltage. Figure 85. Audio DAC Specification
OVERALL Operating Temperature Analog Supply Voltage (AUDVDD, HSVDD) MIN -40 2.7 TYP +25 2.8 MAX +125 3.3 UNITS °C V
82
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
OVERALL Digital Supply Voltage (VDD) Audio Amplifier Supply (AUDVBAT) DIGITAL INPUTS/OUTPUTS Resolution Logic Family Logic Coding 20 CMOS 2’s Complement Bits MIN 2.4 3.2 TYP 2.8 MAX 3.3 5.5 UNITS V V
ANALOG PERFORMANCE – DAC to Line-out/Headphone Output Output level for full scale input (for AUDVDD, HSVDD = 2.8 V) Output common mode voltage Output load resistance (on HSL, HSR) - Headphone load - Line load Output load capacitance (on HSL, HSR) - Headphone load - Line load Signal to Noise Ratio (–1dBFS @ 1kHz input and 0dB Gain) - Line and Headphone loads Total Harmonic Distortion (–1dBFS @ 1kHz input and 0dB Gain) - Line Load - Headphone Load - Headphone Load (16 Ohm) Dynamic Range (measured with -60 dBFS @ 1kHz input, extrapolated to full-scale) - Line Load - Headphone Load Interchannel mismatch Left-channel to right-channel crosstalk (@ 1kHz) Output Power Level Control Range Output Power Level Control Step PSRR - 1kHz - 20kHz Maximum output slope at power up (100 to 220F coupling capacitor) -6 1.65 0.5xHSVDD Vpp V
16
32 10
Ohm kOhm
30 30
1000 150
pF pF
87
92
dB
-80 -65 -40
-76 -60
dB dB dB
88 70
93 74 0.1 -90 3 1 -80 6
dB dB dB dB dB dB
55 50 3
dB dB V/s
ANALOG PERFORMANCE – Line-in/Microphone Input to Line-out/Headphone Output
83
7524B–MP3–05/06
OVERALL Input level for full scale output - 0dBFS Level @ AUDVDD, HSVDD = 2.8 V and 0 dB gain @ AUDVDD, HSVDD = 2.8 V and 20 dB gain
MIN
TYP
MAX
UNITS
1.65 583 0.165 58.3 0.5xAUDVD D 7 10
Vpp mVrms Vpp mVrms V kOhm
Input common mode voltage Input impedance Signal to Noise Ratio -1 dBFS @ 1kHz input and 0 dB gain -21 dBFS @ 1kHz input and 20 dB gain Dynamic Range (extrapolated to full scale level) -60 dBFS @ 1kHz input and 0 dB gain -60 dBFS @ 1kHz input and 20 dB gain Total Harmonic Distortion –1dBFS @ 1kHz input and 0 dB gain –1dBFS @ 1kHz input and 20 dB gain Interchannel mismatch Left-channel to right-channel crosstalk (@ 1kHz) ANALOG PERFORMANCE – Differential mono input amplifier Differential input level for full scale output - 0dBFS Level @ AUDVDD, HSVDD = 2.8 V and 0 dB gain
81
85 71
dB
82
86 72
dB
-80 -75 0.1 -90
-76 -68 1 -80
dB
dB dB
1.65 583 0.5xAUDVD D 7 76 10 80
Vppdif mVrms V kOhm dB
Input common mode voltage Input impedance Signal to Noise Ratio (-1 dBFS @ 1kHz input and 0 dB gain) Total Harmonic Distortion (–1dBFS @ 1kHz input and 0 dB gain) ANALOG PERFORMANCE – PA Driver Differential output level for full scale input (for AUDVDD, HSVDD = 3 V) Output common mode voltage Output load Signal to Noise Ratio (–1dBFS @ 1kHz input and 0dB Gain) Total Harmonic Distortion (–1dBFS @ 1kHz input and 0dB Gain) MASTER CLOCK Master clock Maximum Long Term Jitter
-85
-81
dB
3.3 0.5xHSVDD 10
Vppdif V kOhm pF dB
30
76
80
-75
-71
dB
1.5
nspp
84
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
OVERALL DIGITAL FILTER PERFORMANCE Frequency response (10 Hz to 20 kHz) Deviation from linear phase (10 Hz to 20 kHz) Passband 0.1 dB corner Stopband Stopband Attenuation DE-EMPHASIS FILTER PERFORMANCE (for 44.1kHz Fs) Frequency Pass band Transition band Stop Band Power Performance Current consumption from Audio Analog supply AVDD, HSVDD in power on Current consumption from Audio Analog supply AVDD, HSVDD in power down Power on Settling Time - From full Power Down to Full Power Up (AUDVREF and AUDVCM decoupling capacitors charge) - Linein amplifier (Line-in coupling capacitors charge) - Driver amplifier (out driver DC blocking capacitors charge) 9.5 mA
μA
MIN
TYP
MAX
UNITS
+/- 0.1 +/- 0.1 0.4535 0.5465 65
dB deg Fs Fs dB
Gain -1dB Logarithm decay -10.45dB
Margin 1dB 1dB 1dB
0Hz to 3180Hz 3180Hz to 10600Hz 10600Hz to 20kHz
10
500 50 500
ms ms ms
85
7524B–MP3–05/06
Digital Filters Transfer Function
Figure 86. Channel Filter
Figure 87. De-emphasis Filter
0
-2
-4
Gain (dB)
-6
-8
-10
-12 10
3
10
4
Frequency (Hz)
86
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Audio DAC and PA Connection Figure 88. DAC and PA Connection
PAINN
Audio Dac and PA Connection
VDD C17 VSS
3V from LDO
Battery
3.2V to 5.5V
AUDVSS C16
AUDVBAT
CBP AUDVSS C7 HPP
AUDVDD
3V from LDO
AUDVSS
8 Ohm Loud Speaker
HPN LPHN C15 R1 PAINP AUDVREF HSVDD
C18 AUDVSS C19
HSVSS C9
MONOP
VSS
MONON R C12 C8 LINER C3 LINEL AUDVCM
C11 AUDVSS
Stereo Line Input
L
Mono
AUDVSS
mono input (+)
AUXP
Differential Input
mono input C1 (-)
C6 C4
AUXN
32 Ohm
32 Ohm Headset or Line Out
32 Ohm C5
HSR
HSL
INGND AUDVSS AUDVSS ESDVSS C10 ESDVSS VSS VSS
87
7524B–MP3–05/06
Table 62. DAC and PA Characteristics
Symbol
C1 C3 C4 C5 C6 C7 C8 C9 C10 C11 C12 C15 C16 C17 C18 C19 R1 Capacitance Capacitance Capacitance Capacitance Capacitance Capacitance Capacitance Capacitance Capacitance Capacitance Capacitance Capacitance Capacitance Capacitance Capacitance Capacitance Resistor
Parameter
Typ
470 470 470 100 100 100 470 100n 10 10 470 470 22 100 100 100 200
Unit
nF nF nF
μF μF
nF nF
μF μF μF
nF nF
μF
nF nF nF
Ω
88
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
MMC Interface Definition of symbols Table 63. MMC Interface Timing Symbol Definitions
Signals
C D O Clock Data In Data Out H L V X
Conditions
High Low Valid No Longer Valid
Timings
Table 64. MMC Interface AC timings VDD = 2.7 to 3.3 V, TA = -40 to +85°C, CL ≤ 100pF (10 cards)
Symbol
TCHCH TCHCX TCLCX TCLCH TCHCL TDVCH TCHDX TCHOX TOVCH Clock Period Clock High Time Clock Low Time Clock Rise Time Clock Fall Time Input Data Valid to Clock High Input Data Hold after Clock High Output Data Hold after Clock High Output Data Valid to Clock High 3 3 5 5
Parameter
Min
50 10 10
Max
Unit
ns ns ns
10 10
ns ns ns ns ns ns
Waveforms
Figure 89. MMC Input-Output Waveforms
TCHCH TCHCX MCLK TCHCL TCHIX MCMD Input MDAT Input TCHOX MCMD Output MDAT Output TOVCH TCLCH TIVCH TCLCX
89
7524B–MP3–05/06
Audio Interface Definition of symbols Table 65. Audio Interface Timing Symbol Definitions
Signals
C O S Clock Data Out Data Select H L V X
Conditions
High Low Valid No Longer Valid
Timings
Table 66. Audio Interface AC timings VDD = 2.7 to 3.3 V, TA = -40 to +85°C, CL≤ 30pF
Symbol
TCHCH TCHCX TCLCX TCLCH TCHCL TCLSV TCLOV
Parameter
Clock Period Clock High Time Clock Low Time Clock Rise Time Clock Fall Time Clock Low to Select Valid Clock Low to Data Valid
Min
Max
325.5
(1)
Unit
ns ns ns
30 30 10 10 10 10
ns ns ns ns
Note:
1. 32-bit format with Fs= 48 KHz.
Waveforms
Figure 90. Audio Interface Waveforms
TCHCH TCHCX DCLK TCHCL TCLSV DSEL TCLOV DDAT Right Left TCLCH TCLCX
90
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
External Clock Drive and Logic Level References Definition of symbols Table 67. External Clock Timing Symbol Definitions
Signals
C Clock H L X
Conditions
High Low No Longer Valid
Timings
Table 68. External Clock AC Timings VDD = 2.7 to 3.3 V, TA = -40 to +85°C
Symbol
TCLCL TCHCX TCLCX TCLCH TCHCL TCR Clock Period High Time Low Time Rise Time Fall Time Cyclic Ratio in X2 mode
Parameter
Min
50 10 10 3 3 40
Max
Unit
ns ns ns ns ns
60
%
Waveforms
Figure 91. External Clock Waveform
TCLCH VDD - 0.5 0.45 V VIH1 TCLCX TCHCL TCLCL TCHCX
VIL
Figure 92. AC Testing Input/Output Waveforms
INPUTS VDD - 0.5 0.45 V 0.7 VDD 0.3 VDD OUTPUTS VIH min VIL max
Note:
1. During AC testing, all inputs are driven at VDD -0.5 V for a logic 1 and 0.45 V for a logic 0. 2. Timing measurements are made on all outputs at VIH min for a logic 1 and VIL max for a logic 0.
Figure 93. Float Waveforms
VLOAD VLOAD + 0.1 V VLOAD - 0.1 V Timing Reference Points VOH - 0.1 V VOL + 0.1 V
91
7524B–MP3–05/06
Note:
For timing purposes, a port pin is no longer floating when a 100 mV change from load voltage occurs and begins to float when a 100 mV change from the loading VOH/V OL level occurs with IOL/IOH= ±20 mA.
92
AT83SND2CMP3
7524B–MP3–05/06
AT83SND2CMP3
Ordering Information
Supply Voltage
3V 3V 3V 3V
Part Number
AT83SND2MP3-7FTIL AT83SND2MP3-7FTJL AT83SND2CDVX-7FTIL AT83SND2CDVX-7FTJL
Temperature Range
Industrial Industrial & ROHS Industrial Industrial & ROHS
Max Frequency
40 MHz 40 MHz 40 MHz 40 MHz
Package
BGA100 BGA100 BGA100 BGA100
Packing
Tray Tray Tray Tray
Product Marking
83C51SND2C-IL 83C51SND2C-JL 83C51SND2C-IL 83C51SND2C-JL
RoHS Compliant
Yes Yes Yes Yes
93
7524B–MP3–05/06
Package Information
CTBGA100
Document Revision History
Changes from 7524A07/05 to 7524B-05/06
1. Added AT83SND2CDVX part number.
94
AT83SND2CMP3
7524B–MP3–05/06
Table of Contents
Features ................................................................................................. 1 Typical Applications ............................................................................. 1 Description ............................................................................................ 2 Block Diagram....................................................................................... 3 Pin Description ...................................................................................... 4
Pinouts ................................................................................................................. 4 Signals................................................................................................................... 5 Internal Pin Structure............................................................................................ 9
Clock Controller .................................................................................. 10
Oscillator ............................................................................................................ 10 PLL ..................................................................................................................... 10
MP3 Decoder ....................................................................................... 12
Decoder .............................................................................................................. 12 Audio Controls ..................................................................................................... 14 Frame Information ............................................................................................... 15 Ancillary Data ..................................................................................................... 15
Audio Output Interface ....................................................................... 16
Description ......................................................................................................... 16 Clock Generator .................................................................................................. 17 Data Converter ................................................................................................... 17 Audio Buffer........................................................................................................ 18 MP3 Buffer ......................................................................................................... 19 Interrupt Request................................................................................................ 19 MP3 Song Playing .............................................................................................. 19
DAC and PA Interface ......................................................................... 21
DAC .................................................................................................................... 21 Power Amplifier ................................................................................................... 39 Audio Supplies and Start-up............................................................................... 40
Universal Serial Bus ........................................................................... 43
Description .......................................................................................................... 44 USB Interrupt System......................................................................................... 49
MultiMedia Card Controller ................................................................ 51
95
Card Concept...................................................................................................... 51 Bus Concept ....................................................................................................... 51 Description.......................................................................................................... 56 Clock Generator.................................................................................................. 56 Command Line Controller................................................................................... 58 Data Line Controller............................................................................................. 60 Interrupt ...............................................................................................................66
Serial I/O Port ...................................................................................... 67
Mode Selection ................................................................................................... 67 Baud Rate Generator.......................................................................................... 67 Synchronous Mode (Mode 0) ............................................................................. 68 Asynchronous Modes (Modes 1, 2 and 3) ...........................................................70 Multiprocessor Communication (Modes 2 and 3) ............................................... 73 Automatic Address Recognition.......................................................................... 73 Interrupt ...............................................................................................................75
Keyboard Interface ............................................................................. 76
Description.......................................................................................................... 76
Electrical Characteristics ................................................................... 77
Absolute Maximum Rating.................................................................................. 77 DC Characteristics.............................................................................................. 77
Ordering Information .......................................................................... 93 Package Information .......................................................................... 94
CTBGA100 ......................................................................................................... 94
Document Revision History ............................................................... 94
Changes from 7524A-07/05 to 7524B-05/06 ...................................................... 94
96
AT83SND2CMP3
7524B–MP3–05/06
Atmel Corporation
2325 Orchard Parkway San Jose, CA 95131, USA Tel: 1(408) 441-0311 Fax: 1(408) 487-2600
Atmel Operations
Memory
2325 Orchard Parkway San Jose, CA 95131, USA Tel: 1(408) 441-0311 Fax: 1(408) 436-4314
RF/Automotive
Theresienstrasse 2 Postfach 3535 74025 Heilbronn, Germany Tel: (49) 71-31-67-0 Fax: (49) 71-31-67-2340 1150 East Cheyenne Mtn. Blvd. Colorado Springs, CO 80906, USA Tel: 1(719) 576-3300 Fax: 1(719) 540-1759
Regional Headquarters
Europe
Atmel Sarl Route des Arsenaux 41 Case Postale 80 CH-1705 Fribourg Switzerland Tel: (41) 26-426-5555 Fax: (41) 26-426-5500
Microcontrollers
2325 Orchard Parkway San Jose, CA 95131, USA Tel: 1(408) 441-0311 Fax: 1(408) 436-4314 La Chantrerie BP 70602 44306 Nantes Cedex 3, France Tel: (33) 2-40-18-18-18 Fax: (33) 2-40-18-19-60
Biometrics/Imaging/Hi-Rel MPU/ High Speed Converters/RF Datacom
Avenue de Rochepleine BP 123 38521 Saint-Egreve Cedex, France Tel: (33) 4-76-58-30-00 Fax: (33) 4-76-58-34-80
Asia
Room 1219 Chinachem Golden Plaza 77 Mody Road Tsimshatsui East Kowloon Hong Kong Tel: (852) 2721-9778 Fax: (852) 2722-1369
ASIC/ASSP/Smart Cards
Zone Industrielle 13106 Rousset Cedex, France Tel: (33) 4-42-53-60-00 Fax: (33) 4-42-53-60-01 1150 East Cheyenne Mtn. Blvd. Colorado Springs, CO 80906, USA Tel: 1(719) 576-3300 Fax: 1(719) 540-1759 Scottish Enterprise Technology Park Maxwell Building East Kilbride G75 0QR, Scotland Tel: (44) 1355-803-000 Fax: (44) 1355-242-743
Japan
9F, Tonetsu Shinkawa Bldg. 1-24-8 Shinkawa Chuo-ku, Tokyo 104-0033 Japan Tel: (81) 3-3523-3551 Fax: (81) 3-3523-7581
Literature Requests
www.atmel.com/literature
Disclaimer: T he information in this document is provided in connection with Atmel products. No license, express or implied, by estoppel or otherwise, to any intellectual property right is granted by this document or in connection with the sale of Atmel products. EXCEPT AS SET FORTH IN ATMEL’S TERMS AND CONDITIONS OF SALE LOCATED ON ATMEL’S WEB SITE, ATMEL ASSUMES NO LIABILITY WHATSOEVER AND DISCLAIMS ANY EXPRESS, IMPLIED OR STATUTORY WARRANTY RELATING TO ITS PRODUCTS INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT. IN NO EVENT SHALL ATMEL BE LIABLE FOR ANY DIRECT, INDIRECT, CONSEQUENTIAL, PUNITIVE, SPECIAL OR INCIDENTAL DAMAGES (INCLUDING, WITHOUT LIMITATION, DAMAGES FOR LOSS OF PROFITS, BUSINESS INTERRUPTION, OR LOSS OF INFORMATION) ARISING OUT OF THE USE OR INABILITY TO USE THIS DOCUMENT, EVEN IF ATMEL HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. A tmel makes no representations or warranties with respect to the accuracy or completeness of the contents of this document and reserves the right to make changes to specifications and product descriptions at any time without notice. Atmel does not make any commitment to update the information contained herein. Unless specifically provided otherwise, Atmel products are not suitable for, and shall not be used in, automotive applications. Atmel’s products are not intended, authorized, or warranted for use as components in applications intended to support or sustain life.
© Atmel Corporation 2005. All rights reserved. Atmel ® , logo and combinations thereof, are registered trademarks, and Everywhere You Are® are the trademarks of Atmel Corporation or its subsidiaries. Other terms and product names may be trademarks of others.
Printed on recycled paper.
7524B–MP3–05/06