Integrated Circuits Inc.
A
aP89341/170/085
PLUS MAKE YOUR PRODUCTION A-PLUS
VOICE OTP IC aP89341 – 341sec aP89170 – 170sec aP89085 – 85sec
APLUS
INTEGRATED CIRCUITS INC.
Sales E-mail:
Address: 3 F-10, No. 32, Sec. 1, Chenggung Rd., Taipei, Taiwan 115, R.O.C. (115)台北市南港區成功路一段 32 號 3 樓之 10. TEL: 886-2-2782-9266 FAX: 886-2-2782-9255 WEBSITE : http: //www.aplusinc.com.tw
sales@aplusinc.com.tw
Support E-mail:
service@aplusinc.com.tw
Integrated Circuits Inc.
FEATURES
• • • • • • • • Standard CMOS process. Embedded 8M/4M/2M EPROM.
aP89341/170/085
341/170/85 sec Voice Length at 6KHz sampling and 4-bit ADPCM compression. Maximum 254 voice groups. Combination of voice blocks to extend playback duration. 7680 table entries are available for voice block combinations. User selectable PCM or ADPCM data compression Three triggering modes are available (controlled by M1 and M0 input pins): Key Trigger Mode (M1=0, M0=0) - S1 ~ S8 to trigger up to 32 voice groups; SBT to trigger up to 254 voice groups sequentially. CPU Parallel Trigger Mode (M1=0, M0=1) – S[8:1] services as 8-bits address to trigger up to 254 voice groups with SBT goes HIGH to strobe the address bits. CPU Serial Command Mode (M1=1, M0=0) – user commands are clocked serially into the chip which enable user to fully control the operation of the chip.
• • • • • • • • • •
Voice Group Trigger Options: Edge / Level; Hold / Un-hold; Retrigger / Non-retrigger. Whole Chip Options: Ramp / No-ramp; Output Options; Long / Short debounce time. Optional 16ms or 65us (@ 8KHz sampling rate) selectable debounce time RST pin set to HIGH to stop the playback at once Three user programmable outputs for STOP pulse, BUSY signal and flashing LED. Built-in oscillator to control sampling frequency with an external resistor 2.2V – 3.6V single power supply and < 5uA low stand-by current PWM Vout1 and Vout2 drive speaker directly D/A COUT pin drives speaker through an external BJT Development System support voice compilation.
DESCRIPTION
aP89341/170/085 series high performance Voice OTP is fabricated with Standard CMOS process with embedded 8M/4M/2M bits EPROM. It can store up to 341/170/85 sec voice message with 4-bit ADPCM compression at 6KHz sampling rate. 8-bit PCM is also available as user selectable option. Three trigger modes, simple Key trigger mode, Parallel CPU trigger mode and CPU serial command mode, facilitate different user interface. User selectable triggering and output signal options provide maximum flexibility to various applications. Built-in resistor controlled oscillator, 8-bit current mode D/A output and PWM direct speaker driving output minimize the number of external components. PC controlled programmer and developing software are available.
Ver 3.1
1
Oct 09, 2008
Integrated Circuits Inc.
aP89341/170/085
PIN NAMES
PIN (24-pin) 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 ~ 24
Ver 3.1
Playback Mode S7 S8 VSS VOUT1 VOUT2 VDD AVDD VPP OSC COUT AVSS OUT3 OUT2 OUT1 RST SBT M1 M0 S1~S6
OTP Program Mode IO6 IO7 VSS VDD AVDD VPP ACLK AVSS SIO OEB DCLK PGM M1 M0 IO0~IO5
Description Trigger pin (I/O pin with internal pull-down) Trigger pin (I/O pin with internal pull-down) Ground PWM output to drive speaker directly PWM output to drive speaker directly Supply voltage Analog supply voltage Supply voltage for OTP programming Oscillator input D/A current output Analog ground Programmable output (I/O pin) Programmable output (I/O pin) Programmable output (I/O pin) Reset pin (input pin with internal pull-down) Trigger pin (I/O pin with internal pull-down) Mode select pin 1 (input with internal pull-down) Mode select pin 0 (input with internal pull-down) Trigger input (I/O pin with internal pull-down)
2 Oct 09, 2008
Integrated Circuits Inc.
PIN DESCRIPTIONS
aP89341/170/085
S1 ~ S8 Input Trigger Pins: - In Key Trigger Mode, S1 to S8 is used to trigger the first 32 out of the total 254 Voice Groups . - In CPU Parallel Command Mode, S1 to S8 serve as Voice Group address inputs for 254 Voice Groups with S1 as LSB and S8 as MSB. - In CPU Serial Command Mode, S1 is Chip Select (SC) pin to initiate the command input. S2 is the Serial Clock (SCK) pin which clocks the input command and data bits into the chip. S3 is the Data In (DI) pin in which command and data bits are shifted input into the chip. - In OTP Programming Mode, S1 to S8 are used as data I/O pins. SBT Input Trigger Pin: - In Key Trigger Mode, this pin is trigger pin to trigger the playback of Voice Groups one by one sequentially. - In CPU Parallel Command Mode, this pin is used as address strobe to latch the Voice Group address input at S1 to S8 and starts the voice playback. - In OTP Programming Mode, this pin is used as PGM signal. VDD and AVDD Power Supply Pins: These two pins must be connected together to the positive power supply. VSS and AVSS Power Ground Pins: These two pins must be connected to the power ground. M0 and M1 Operating Mode Setting Pins: - M1=0, M0=0 set the chip into Key Trigger Mode - M1=0, M0=1 set the chip into CPU Parallel Command Mode - M1=1, M0=0 set the chip into CPU Serial Command Mode - M1=1, M0=1 set the chip into OTP Programming Mode VOUT1 and VOUT2 Digital PWM output pins which can drive speaker and buzzer directly for voice playback. OSC During voice playback, an external resistor is connect between this pin and the VDD pin to set the sampling frequency. In OTP Programming Mode, this is the ACLK input signal. VPP During voice playback, this pin must be connected together with VDD to the positive power supply voltage. In OTP Programming Mode, this pin is connected to a separate 6.5V power supply voltage for EPROM programming. OUT1, OUT2 and OUT3 - In Key Trigger Mode and CPU Parallel Command Mode, these pins are user programmable pins for the STOP pulse, BUSY and LED signals. - In CPU Serial Command Mode, OUT1, OUT2 and OUT3 are fixed as BUSY, POUT and FULL status output which tell the status of the chip operation. POUT can be further configurable to BUSYB, 8K, 4K, 2K, 1K, 16Hz, 1M and EMPTY (or FULLB). - During OTP programming, OUT1 serves as OEB while OUT2 serves as SIO (serial data IO). COUT Analog 8-bit current mode D/A output for voice playback RST Chip reset in playback mode or DCLK pin in OTP programming mode.
Ver 3.1 3 Oct 09, 2008
Integrated Circuits Inc.
VOICE SECTION COMBINATIONS
aP89341/170/085
Voice files created by the PC base developing system are stored in the built-in EPROM of the aP89341/170/085 chip as a number of fixed length Voice Blocks. Voice Blocks are then selected and grouped into Voice Groups for playback. Up to 254 Voice Groups are allowed. A Voice Block Table is used to store the information of combinations of Voice Blocks and then group them together to form Voice Group. Chip Memory size Max no. of Voice Block Max. no. of Voice Group No of Voice Table entries Voice Length (@ 6KHz 4-bit ADPCM) aP89341 8M bits 2016 254 7680 341 sec aP89170 4M bits 992 254 7680 170 sec aP89085 2M bits 480 254 7680 85 sec
Example of Voice Block Combination Assume here we have three voice files, they are “How are You?”, Sound Effect and Music. Each of the voice file is divided into a number of fixed length Voice Block and stored into the memory. Voice File 1 - “How are You?” is stored in Voice Block B0 to B12. Voice File 2 - Sound Effect is stored in Voice Block B13 to B15. Voice File 3 - Music is Voice Block B16 to B40. Voice Blocks are grouped together using Voice Table to form Voice Group for playback: Group no. Group 1 Group 2 Group 3 Group 4 Voice Group contents “How are You?” Sound Effect + “How are You?” “How are You?” + Music Music Voice Table Entries B0 … B12 B13 … B15 + B0 … B12 B0 … B12 + B16 … B40 B16 … B40
Voice Data Compression
Voice File data is stored in the on-chip EPROM as either 4-bit ADPCM or 8-bit PCM format. Voice data stored as 4-bit ADPCM provides 2:1 data compression which can save 50% of memory space. On the other hand, voice data are stored as 8-bit PCM format means no data compression is employed but voice playback quality will be better.
Ver 3.1
4
Oct 09, 2008
Integrated Circuits Inc.
Programmable Options
aP89341/170/085
In Key Trigger Mode (M1=0; M0=0) and CPU Parallel Trigger Mode (M1=0; M0=1), user can select different trigger functions and output signals to be sent out from the pins OUT1, OUT2 and OUT3. Options that affect all Voice Group playback are called Whole Chip Options. Options that only affect the playback of individual Voice Group are called Group Options. Whole Chip Options • Long (16ms) or short (65us) debounce time at 8KHz sampling rate. • Ramp-up-down enable or disable: When COUT is used for playback, Ramp-up-down should be enabled. This function eliminates the ‘POP’ noise at the begin and end of voice playback. When VOUT1 and VOUT2 are used to drive speaker directly, Ramp-up-down should be disabled.
Fig. 1 Ramp-up-down Enable •
Fig.2 Ramp-up-down Disable
Output Options: This option sets up the three output pins OUT1, OUT2 and OUT3 to send out different signals during voice playback. Four settings are allowed: OUT1 Option 1 Option 2 Option 3 Option 4 LED1 STOP LED1 LED1 OUT2 LED2 LED1 BUSY BUSY OUT3 BUSY LED2 STOP BUSYB
Note: BUSY can be set or reset associated with each Voice Block. Stop plus must be set to enable in order to have STOP plus to come out at the end of playback.
Fig. 3 Output waveforms
Ver 3.1
5
Oct 09, 2008
Integrated Circuits Inc.
Group Options
aP89341/170/085
User selectable options that affect each individual group are called Group Options. They are: • • • • Edge or Level trigger Unholdable or Holdable trigger Re-triggerable or non-retriggerable Stop pulse disable or enable
Fig. 4 to Fig. 9 show the voice playback with different combination of triggering mode and the relationship between outputs and voice playback.
Fig. 4 Level, Unholdable, Non-retriggerable
Fig. 5 Level Holdable
Fig. 6 SBT sequential trigger with Level Holdable and Unholdable
Ver 3.1
6
Oct 09, 2008
Integrated Circuits Inc.
aP89341/170/085
Fig. 7 Edge, Unholdable, Non-retrigger
Fig. 8 Edge, Holdable
Fig. 9 SBT sequential trigger with Edge Holdable and Unholdable
TRIGGER MODES
There are three trigger modes available for aP89341/170/085 series which are determined by setting M1 and M2 pins to logic HIGH or LOW. • • • Key Trigger Mode (M1=0; M0=0); CPU Parallel Trigger Mode (M1=0; M0=1); CPU Serial Command Mode (M1=1; M0=0);
Ver 3.1
7
Oct 09, 2008
Integrated Circuits Inc.
Key Trigger Mode (M1=0, M0=0)
aP89341/170/085
With this trigger mode, the beginning 32 Voice Groups are triggered by setting S1 to S8 to HIHG or LOW in different combinations. Each Voice Group can have its only independent trigger options (See Fig. 4, 5, 7 and 8 for trigger options definition). A maximum of 254 Voice Groups are available. The 33rd to 254th Voice Groups can only be triggered one by one sequentially with the SBT key (See Fig. 6 and 9). The setting of S1 to S8 for triggering the 1st to the 32nd Voice Groups are as follow: Voice Group 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 S1 HIGH NC NC NC NC NC NC NC HIGH NC NC NC NC NC NC HIGH HIGH NC NC NC NC NC HIGH HIGH HIGH NC NC NC NC HIGH HIGH HIGH S2 NC HIGH NC NC NC NC NC NC HIGH HIGH NC NC NC NC NC NC HIGH HIGH NC NC NC NC NC HIGH HIGH HIGH NC NC NC NC HIGH HIGH S3 NC NC HIGH NC NC NC NC NC NC HIGH HIGH NC NC NC NC NC HIGH HIGH HIGH NC NC NC NC NC HIGH HIGH HIGH NC NC NC NC HIGH S4 NC NC NC HIGH NC NC NC NC NC NC HIGH HIGH NC NC NC NC NC HIGH HIGH HIGH NC NC NC NC HIGH HIGH HIGH HIGH NC NC NC NC S5 NC NC NC NC HIGH NC NC NC NC NC NC HIGH HIGH NC NC NC NC NC HIGH HIGH HIGH NC NC NC NC HIGH HIGH HIGH HIGH NC NC NC S6 NC NC NC NC NC HIGH NC NC NC NC NC NC HIGH HIGH NC NC NC NC NC HIGH HIGH HIGH NC NC NC NC HIGH HIGH HIGH HIGH NC NC S7 NC NC NC NC NC NC HIGH NC NC NC NC NC NC HIGH HIGH NC NC NC NC NC HIGH HIGH HIGH NC NC NC NC HIGH HIGH HIGH HIGH NC S8 NC NC NC NC NC NC NC HIGH NC NC NC NC NC NC HIGH HIGH NC NC NC NC NC HIGH HIGH HIGH NC NC NC NC HIGH HIGH HIGH HIGH
Note: NC represents open or no connection
Ver 3.1 8 Oct 09, 2008
Integrated Circuits Inc.
CPU Parallel Trigger Mode (M1=0, M0=1)
aP89341/170/085
In this mode, S8 to S1 serve as 8-bit addresses input for 254 Voice Groups with S8 represents the MSB and S1 represents LSB. After Group address is set and ready, setting the SBT input pin to HIGH will trigger the corresponding Voice Group to playback. Trigger options defined in Fig. 4, 5, 7 and 8 are valid for this mode.
Fig. 10 CPU Parallel Trigger Mode Note that SBT pin cannot be used as Single Button Sequential trigger in this mode. In stead, it acts as a Strobe input to clock-in the Voice Group address set at S8 to S1 into the chip. Voice Groups are represented in Binary address format. For example: S[8:1] = 0000 0000 (00hex) for Voice Group #1 S[8:1] = 0000 0001 (01hex) for Voice Group #2 ••• S[8:1] = 0000 1000 (08 hex) for Voice Group #9 ••• S[8:1] = 1000 1000 (88 hex) for Voice Group #137 ••• S[8:1] = 1111 1101 (FD hex) for Voice Group #254
CPU Serial Command Mode (M1=1, M0=0) This trigger mode is specially designed for simple CPU interface. The aP89341/170/085 is controlled by command sent to it from the host CPU. S1 to S3 are used to input command word into the chip while OUT1 to OUT3 as output from the chip to the host CPU for feedback response. • • • • • • S1 acts as CS (Chip Select) to initiate the command word input S2 acts as SCK (Serial Clock) to clock-in the command word at rising edge. S3 acts as DI (Data-In) to input the command bits. OUT1 acts as BUSY to indicate the chip is in busy state. OUT2 acts as POUT to output user selected information. OUT3 acts as FULL signal to indicate the Voice Group address buffer is full.
Command input into the chip may contains 8-bit or 16-bit data. The first 8-bit data is command bits while the second 8-bit data (if any) is the Voice Group address data. Table 1 summarize the available commands and their functions.
Ver 3.1
9
Oct 09, 2008
Integrated Circuits Inc.
Command PUP1 (C5h) PUP2 (8Dh) PDN1 (E1h) PDN2 (A9h) STATUS (E3h) PAUSE (39h) RESUME (1Dh) PREFETCH (71h) D7 1 1 1 1 1 0 0 0 0 G7 D6 1 0 1 0 1 0 0 0 1 G6 D5 0 0 1 1 1 0 1 0 1 G5 D4 0 0 0 0 0 1 1 1 1 G4 D3 0 1 0 1 0 0 1 1 0 G3 D2 1 1 0 0 0 G2 0 1 0 G2 D1 0 0 0 0 1 G1 0 0 0 G1 D0 1 1 1 1 1 G0 1 1 1 G0
aP89341/170/085
Description
Power up the chip with NO ramp-up (suitable for VOUT direct drive) Power up the chip WITH ramp-up (suitable for COUT transistor drive) Power down the chip with NO ramp-down (suitable for VOUT direct drive) Power down the chip WITH ramp-down (suitable for COUT transistor drive) Set output status for OUT2 pin OUT2 = BUSYB (000), 8K (001), 4K, 2K, 1K, 16Hz, 1M, EMPTY (FULLB) Pause the playback and hold at current COUT value Resume playback from the previous COUT value Pre-load Voice Group address into buffer for next playback Voice Group address (G7=MSB; G0=LSB)
•
Power up with RAMP-UP (PU2-C5H) or without RAMP-UP (PU1-8DH)
Fig. 11 Power-up command timing 1. PU1 (C5H) will power-up the chip and set the COUT to 80H immediately and stay there. 2. PU2 (8DH) will Ramp-up chip and ramp-up COUT from 00H to 80H and stay there. 3. Power-up will start after 350us (at 6KHz sampling rate). 4. Voice will be playback immediately after PU1 / PU2 completes if the section buffer is filled with the PREFETCH command before power-up. 5. OUT1 (BUSY) will output logic HIGH during Ramp-up operation. 6. PDN2 (Power-down with ramp-down) will be executed correctly only if PU2 is executed before.
Ver 3.1
10
Oct 09, 2008
Integrated Circuits Inc.
•
aP89341/170/085
Power-down with RAMP-DOWN (PD2-A9H) or without RAMP-DOWN (PD1-E1H)
Fig. 12 Power-down commands timing 1. 2. 3. 4. 5. • PDN1 will power-down the chip and set the COUT data to 00H immediately. PDN2 will power-down the chip by Ramp-down the COUT from its current value to 00H. Power-down will start after 350us (at 6KHz sampling rate). The OUT1 pin (BUSY) will output logic HIGH during Ramp-down operation. PDN2 (Power-down with ramp-down) will be executed correctly only if PU2 is executed before.
Set OUT2 pin status (STATUS-E3H)
Fig. 14 Setup the status of programmable output pin, OUT2 1. Signal output from the pin, OUT2, is defined by G[3:0], as below: G[3:0] 000 001 010 011 2. 3. 4. 5. OUT2 BUSYB 8KHz 4KHz 2KHz G[3:0] 100 101 110 111 OUT2 1KHz 16Hz 1MHz FULLB
If the STATUS is not executed, default value of OUT2 is the internal Reset signal. BUSYB is the logical inversion of BUSY. EMPTY (or FULLB) is the logical inversion of FULL. Only the 1MHz clock will not be stopped by the PAUSE command.
Ver 3.1
11
Oct 09, 2008
Integrated Circuits Inc.
• Pause and Resume (PAUSE-39H; RESUME-1DH)
aP89341/170/085
Fig. 15 Pause and Resume command timing 6. In Pause state, VOUT1 and VOUT2 will stay at logic LOW while the COUT will stay at the current D/A data level (i.e. COUT is kept outputting an DC current). When Resume, the COUT data will continue at the current D/A data level. 7. The Pause state will be released by PDN1, PDN2 and RESUME commands. • Prefetch Voice Group Address (PREFETCH-71H)
Fig. 16 Prefetch next Voice Group timing 1. The PREFETCH command pre-load the next Voice Group Address into the address buffer. 2. The OUT3 output (FULL) will become logic HIHG once the Group Address is successfully loaded. 3. The Voice Group will be played once the playing of the current Voice Group is finished. 4. The FULL signal will become logic LOW once the Voice Group is played and the address buffer is released and ready for next PREFECT action. 5. Using the PREFECT make sure there is no gap between each Voice Group.
Ver 3.1
12
Oct 09, 2008
Integrated Circuits Inc.
BLOCK DIAGRAM
aP89341/170/085
Fig. 17 Block Diagram
ABSOLUTE MAXIMUM RATINGS
Symbol VDD - VSS VIN VOUT T (Operating): T (Junction) T (Storage) Rating -0.5 ~ +3.8 VSS - 0.3