## W529XX Application Note

## ADPCM/PCM VOICE SYNTHESIZER (PowerSpeech ${ }^{\text {TM }}$ II)

## GENERAL DESCRIPTION

Fabricated using Winbond's advanced CMOS process, the W529XX PowerSpeech ${ }^{\mathrm{TM}}$ II series of voice synthesizers now offers more power than ever. The PowerSpeech ${ }^{\text {TM }}$ II series includes the following range of ICs with different built-in ROM memory capacities:

| BODY | W52902 | W52904 | W52905 | W52906 | W52910 | W52915 | W52920 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| *Second | 6 sec. | 12 sec. | 20 sec. | 30 sec. | 40 sec. | 60 sec. | 80 sec. |

*Note: All playback lengths are estimated for typical applications.

## FEATURES

- Programmable speech synthesizer
- Wide operating voltage range: 2.4-5.5 volts
- Both 4-bit ADPCM and 8-bit PCM synthesis technique can be used
- Four trigger pins with separate control of falling/rising edge
- Two trigger input debounce times can be set: Long/ Short
- Eight multiplexed pins can be set as SCAN, LED(or FTEST), STOP, and INPUT
- Supports ALU operations, including
- Branch decisions
- Logic operations
- Binary addition and subtraction
- Data move
- Bit operand
- Eight general purpose registers: R0 ~ R7
- Four special registers: EN, MODEn (n:1,2), OUTPUT, and ACC
- A maximum of 32 matrix keys can be defined by H/W or S/W
- Random number generation (H/W)
- Section control for each GO instruction
- Variable frequency: $4.8 / 6 / 8 / 12 \mathrm{KHz}$
- LED: ON/OFF
- Three LED flash types: 3Hz/ Circular/ Random
- System clock: 1.5 MHz
- Instruction cycle time: 200uS
- A total of 256 label entries available for programming


## 3. BLOCK DIAGRAM


*: These pins exist only on the W52900 demo chip.

PAD DIAGRAM

*: These pins exist only on the W52900 demo chip.

## PIN CONFIGURATION

The 24-pin P-DIP skinny package is used for evaluation purposes

*: These pins exist only on the W52900 demo chip.

## PIN DESCRIPTION

## W529XX Application Note

| No. | Name | I/O | Description |
| :---: | :---: | :---: | :--- |
| 1 | *WRP | O | Write clock output for serial interface |
| 2 | NC | - | Not connected |
| 3 | NC | - | Not connected |
| 4 | TEST | I | Test pin, internally pulled low |
| 5 | TG1 | I | Direct trigger input 1, internally pulled high |
| 6 | TG2 | I | Direct trigger input 2, internally pulled high |
| 7 | TG3 | I | Direct trigger input 3, internally pulled high |
| 8 | TG4 | I | Direct trigger input 4, internally pulled high |
| 9 | IO1 | I/O | SCAN/LED/STOP/INPUT multiplexed pin 1 |
| 10 | IO2 | I/O | SCAN/LED/STOP/INPUT multiplexed pin 2 |
| 11 | IO3 | I/O | SCAN/LED/STOP/INPUT multiplexed pin 3 |
| 12 | IO4 | I/O | SCAN/LED/STOP/INPUT multiplexed pin 4 |
| 13 | IO5 | I/O | SCAN/LED/STOP/INPUT multiplexed pin 5 |
| 14 | IO6 | I/O | SCAN/LED/STOP/INPUT multiplexed pin 6 |
| 15 | IO7 | I/O | SCAN/LED/STOP/INPUT multiplexed pin 7 |
| 16 | IO8 | I/O | FTEST/LED/STOP/INPUT multiplexed pin 8 |
| 17 | VSS | - | Negative power supply |
| 18 | /RESET | I | Reset all; functions as POR, internally pulled high |
| 19 | SPK | O | Current type output for speaker |
| 20 | VDD | - | Positive power supply |
| 21 | OSC | I | Oscillator input, connect with Rosc to VDD |
| 22 | *VSS | - | Negative power supply |
| 23 | *RDP | O | Read clock output for serial interface |
| 24 | *DATA | I/O | Bi-directional data for serial interface |

*: These pins exist only on the W52900 demo chip.

## 1. TG1 - TG4

TG1 through TG4 are direct trigger input pins with internal pull high resistance of around $1 \mathrm{M} \Omega$. After a 45 mS or $350 \mu$ S debounce time (determined by the MODE1 register chosen long or short debounce time), these direct trigger inputs execute their corresponding voice groups. These groups are 0/2/4/6 for falling edge triggers and groups $1 / 3 / 5 / 7$ for rising edge triggers TG1 - TG4, respectively. Priority is set by internal H/W as TG1F > TG1R $>$ TG2F > TG2R > TG3F > TG3R > TG4F > TG4R (F: Falling edge, R: Rising edge).

## W529XX Application Note

For keypad matrix applications, these four direct trigger inputs can be used together with VSS and pins IO1~IO7 pins to obtain a 32 key matrix.

## 2. SPK

The SPK pin is a current-type voice output, connected to the internal D/A converter output. The full scale output of the D/A converter is 5 mA . This output when amplified with a low-power NPN transistor with a $\beta$ of around $120-160$ is able to drive an external $8-\Omega$ speaker.

The SPK output application circuit is shown as follows,


The shunt resistor Rs in the figure above is used to adjust the input base current of the NPN transistor in order to drive the external speaker without distortion. Distortion results from two factors: one is due to saturation of the transistor due to a large base current, and the other is the through the introduction of Rs which can cut small signals out of the original waveform. The value of the shunt resistor Rs, can be adjusted to get the desired voice. A value of around $310 \Omega-750 \Omega$ is recommended. Note that the smaller the resistance, the smaller the input current to the transistor.

Capacitor C in the figure above is used for low-pass filtering of unwanted high-frequency noise generated from the D/A converter during sample transitions. Users may adjust the value of C to improve sound quality. Note that this capacitor can also be omitted without having a major affect on the voice quality.

## 3. 101-108

The eight I/O pins can have four functions: SCAN, LED, STOP, and INPUT. All these functions are defined by the MODE1 and MODE2 registers according to the following I/O function table.

| Group | 108 | IO7 | 106 | 105 | $\mathbf{1 0 4}$ | IO3 | IO2 | IO1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | INPUT/STOP |  | INPUT/LED |  |  |  |  |  |
| 1 | FTEST/LED | SCAN/LED | SCAN/LED |  |  |  |  |  |
| 2 | INPUT/LED |  | SCAN/STOP |  |  |  |  |  |
| 3 | LED/STOP |  | LED/STOP |  |  |  |  |  |

The MODE1 register selects the group ( $0 \sim 3$ ), and the MODE2 register defines the function of each selected I/O pin. A " 0 " for one of these bits selects the first pair of modes indicated; a "1" selects the second pair.

## W529XX Application Note

To select a SCAN output, the selected output signal is initially set to " 0 " for keypad scan purposes. After a key is depressed and debounced successfully, the SCAN outputs return to the "1" state. A low pulse will then start to ripple according to a pre-defined H/W pattern to identify which key is being pressed. For more information, see the FUNCTIONAL DESCRIPTION section.

For an LED output, the selected pin flashes with a frequency of 3 Hz or flashes with circular/random effects. See the FUNCTIONAL DESCRIPTION section for more details.

For a STOP output, the user may define different STOP outputs at certain timing slots by programming the PowerSpeech ${ }^{\text {TM }}$ synthesizer *.out files. After compilation, the STOP signals will be controlled by the internal OUTPUT register. The OUTPUT register can be manipulated through register operations. The STOP signals are typically used to drive external components.

For INPUT purposes, the status of the selected input pins are latched into the designated register by masking unselected pins to zeros. In this way, customers may then decide what to do depending on the port status of the input pins. Actions are invoked through bit manipulation commands like the JP N@reg.m=1 instruction (i.e. This instruction says that O if the mth bit of the register is equal to 1 , then jump to voice group N to execute program.).

Those IO pins that are declared as INPUT pins could be connected to "1", " 0 ", or just left floating. The floating INPUT pins will be recognized as "0" by the W529XX. The W529XX latches the input status only at the execution time of the command "MV erg, IPORT" and tri-states the input port elsewhere.

Pin IO8 can also be selected as a frequency test pin (FTEST), provided for some customers to facilitate the back-end sample rate test at the factory site. The nominal output frequency, FTEST, is fixed at 6 KHz on the condition that the oscillation frequency is equal to 1.5 MHz .

## 4. OSC

The OSC pin is connected with an Rosc resistor to VDD.

## 5. TEST

The TEST pin is used solely for test purposes.

## 6. /RESET

Active low reset input with an internal pull-high resistance of $500 \mathrm{~K} \Omega$. A falling edge on the /RESET pin will fully reset the W529XX in the same way as a power on reset (POR). The /RESET pin was originally used as a last resort to reset the W529XX in situations where the internal POR circuit of the W529XX does not operate properly. If customers fail to discharge the VDD to ground and repower up the W529XX, the chip may function abnormally, causing unpredictable operations. Users may then reset the W529XX by sending a pulse through the /RESET pin.

## 7. VDD

Positive power supply.

# W529XX Application Note 

## 8. VSS

Negative power supply.

## 9. WRP/RDP/DATA (Provided only on W52900)

These three pins provide a serial interface to external memory devices, like serial SRAM and Flash EPROM. For customer evaluation purposes, the ROM file can be put into any of the serial memory devices mentioned above to get the effect of "what you see is what you get", without the need of mask tooling procedures. Of course, customers may request volume production after a successful evaluation based on Winbond's coding environment. The WRP pin is used to send out addresses to the serial memory devices for accessing data. The RDP pin is used to read back this data from the addressed memory space. The DATA pin is bidirectional: an input pin during read operation, and an output pin during address writing.

## FUNCTIONAL DESCRIPTION

The W529XX family is a derivative of Winbond's PowerSpeech ${ }^{\top M}$ synthesizers, devices which are prevailing in the consumer market, especially for toy applications. The W529XX family adopts the same architecture of the PowerSpeech ${ }^{\mathrm{TM}}$ synthesizers, while enhancing its power by expanding the command set, providing a keypad matrix of up to 32 keys, PCM/ADPCM synthesis selection, etc.

The command set of the W529XX family is expanded from simply Jump (JP) and Load (LD) commands into four kinds of commands: ALU, Data Move, Branch, and others. In addition, the general-purpose registers are expanded from just one, R0, to eight, R0-R7. The addition of these extra commands enables users to produce more efficienct code.

To allow for the needs of more flexible applications, IO1 - IO8 can be selected to have a SCAN, LED, STOP or INPUT function. The IO1-IO8 pins have to be first configured by the customer for their particular applications by programming the MODE1 and MODE2 registers before operating.

In order to smoothly connect different voice reproductions synthesized by the ADPCM algorithm, a new mechanism is used to generate the ramp up (i.e., the head, H4) and the ramp down (i.e., the tail, T4) automatically by H/W to eliminate the needs of H 4 and T4 in previous coding for the W528x series. Users do not have to consider H4/T4 in the programming of the *.out file for the W529XX.

Owing to the increased complexity of the *.out file, the need for a label-based symbolic compiler for the W529XX is increasing. This sort of symbolic compiler supports label addressing instead of group numbering, constant definition for special usages, etc.

The W529XX enters the POI (Power On Initialization) process when powering up. The voice group 64 is allocated for this special event and its priority is above all, i.e., no triggers can override the POI process if they all happen simultaneously. If more than two events happen simultaneously, the priority that is set by the internal H/W is: $\mathrm{POI}>$ TG1F $>$ TG1R $>$ TG2F $>$ TG2R $>$ TG3F $>$ TG3R $>$ TG4F $>$ TG4R $>$ JP commands.

## W529XX Application Note

## 1. POWER ON INITIALIZATION

The W529XX will automatically execute the POI (Power On Initialization) process upon power up or depression of the RESET pin. The voice group dedicated for POI is allocated at "64".

Upon power up, the W529XX resets itself to initial values by internally generating a POR (Power On Reset) pulse to start the POI process.

During the POI process, certain triggers can override to take over if the EN register is set to properly enable those triggers. Take the following example (for reference only); after the MODE1 \& MODE2 registers are set to their appropriate values according to the customers' configuration, the EN register is set to enable the fallingedge triggers of TG1 and TG2. Therefore, during the reproduction of voice segments, like Voice1, Voice2, Voice3, and Voice4, triggers TG1F and TG2F may terminate the normal operation of the POI process and start a new trigger later on.

```
W52906
    FREQ2
    LED1
POI:
    LD MODE1, 0x03
    LD MODE2, 0xF2
    LD EN, 0x03 ;Enable TG1 and TG2 falling edge
    LD OUTPUT, 0xC5
    Voice1 + 2*Voice2 + 8*Voice3
    JP EXIT @TG3_L
    Voice4
EXIT:
    END
```

See also "Register definition and control" for default settings during a power up.

## 2. GROUP NUMBER ALLOCATION

For direct trigger inputs, there are 8 voice groups allocated to four TG pins: voice groups $0,2,4$, and 6 are for falling edge triggers, and voice groups $1,3,5$, and 7 are used for the rising edge triggers.

| Voice Group | Description |
| :---: | :---: |
| 0 | TG1F |
| 1 | TG1R |
| 2 | TG2F |
| 3 | TG2R |
| 4 | TG3F |
| 5 | TG3R |
| 6 | TG4F |
| 7 | TG4R |
| $2 N, 0 \leq N \leq 31$ | Keypad matrix for falling edges |
| $2 N+1,4 \leq N \leq 31$ | User defined groups |
| 64 | POI |
| $65-255$ | User defined groups |

For a keypad scan matrix, the voice groups are listed in the following table for quick reference. Each key is composed of the connection of a trigger (TG1-TG4) and a ground source (VSS, IO1-IO7). Upon depression of a key, the trigger input senses a low pulse during a H/W scan period to determine which key is pressed. In order to avoid possible ambiguities during multiple key depressions, only falling edge triggers are allocated for keypad applications. Rising edge triggers are only available for direct trigger pins, i.e. TG1-TG4.

| Keypad | TG1 | TG2 | TG3 | TG4 |
| :---: | :---: | :---: | :---: | :---: |
| VSS | $0(1)$ | $2(3)$ | $4(5)$ | $6(7)$ |
| IO1 | $8(N A)$ | $10(N A)$ | $12(N A)$ | $14(N A)$ |
| IO2 | $16(N A)$ | $18(N A)$ | $20(N A)$ | $22(N A)$ |
| IO3 | $24(N A)$ | $26(N A)$ | $28(N A)$ | $30(N A)$ |
| 104 | $32(N A)$ | $34(N A)$ | $36(N A)$ | $38(N A)$ |
| IO5 | $40(N A)$ | $42(N A)$ | $44(N A)$ | $46(N A)$ |
| 106 | $48(N A)$ | $50(N A)$ | $52(N A)$ | $54(N A)$ |
| IO7 | $56(N A)$ | $58(N A)$ | $60(N A)$ | $62(N A)$ |

Note: The number in parenthesis ( n ) stands for the voice group of the rising edges, which are Not Available (NA) except for direct triggers to avoid possible ambiguities in keypad scan applications by H/W.

## W529XX Application Note

## 3. GLOBAL REPEAT

The W529XX family provides a maximum four times global repeat that can give the user more programming convenience for repetitious playback effects. An example (for reference only) is shown below,

Label: 4
LD MODE1, 0x07
LD EN, 0x34
voice1 + voice2
END
The above example demonstrates the usage of global repeat. The voice group that is indicated by "Label" will be executed for 4 times.

## 4. SECTION CONTROL

## Variable Frequency Section Control

The W529XX provides four sampling frequencies, $4.8 \mathrm{KHz}, 6 \mathrm{KHz}, 8 \mathrm{KHz}$, and 12 KHz , which can be set by the section control function in the speech equations. These sampling frequencies are suitable for both ADPCM and PCM synthesis.

| Sample Rate (KHz) | FREQ |
| :---: | :---: |
| 4.8 | 0 |
| 6 | 1 |
| 8 | 2 |
| 12 | 3 |

## LED ON/OFF Section Control

The LED section control allows the user set the LED output state, On or Off as shown in the following table, after the LED mode ( $3-\mathrm{Hz}$, circular, or random) has been defined.

| ON/OFF | LED |
| :---: | :---: |
| OFF | 0 |
| ON | 1 |

## 5. KEYPAD MATRIX SCAN

In order to minimize programming effort to detect keys in keypad matrix applications, the W529XX provides customers with another alternative for a H/W automatic scan, other than the previous (W528X) S/W programming approach. Customers may select the H/W approach by configuring the IO pins to be scan outputs.

## W529XX Application Note

For the H/W automatic scan mechanism, the internal H/W starts to scan the defined keypad matrix with the priority of $\mathrm{VSS}>\mathrm{IO} 1>\mathrm{IO}>\mathrm{IO}>\mathrm{IO}>\mathrm{IO}>\mathrm{IO}>\mathrm{IO}$ after any TG pin is debounced successfully. During the H/W scan, the W529XX ripples a low pulse through the scan outputs IO1-IO7, causing the depressed key to be detected within a period of no longer than 1 mS . Owing to the priority setting in the H/W scan mechanism, the time used to detect a depressed key may vary somewhat depending on which column it belongs to. To avoid possible ambiguities, all TG pins used for keypad scan purposes should be disabled for their corresponding rising edges by software programming. The trigger debounce time must be set to a long time (around 45 mS ).

For a S/W controlled keypad scan, customers may program their own scan patterns for specific purposes. In order for the W529XX to correctly detect a depressed key, the *. out file should be programmed based on the JP N @TG_status commands with the IO pins being configured as STOP outputs.

A typical example for a 12-key keypad is as follows: (for reference only)

## W52906

LED1
FREQ1 ; Sample rate is 6 KHz
POI:
LD MODE1, 0x03 ; 45mS debounce time must be selected for keypad scan
LD MODE2, 0xFF
LD EN, 0x0F
LD OUTPUT, 0x00 ; Reset OUTPUT to arm keys for triggering.
END
TG1F:
; For TG1F edge
LD OUTPUT, 0xFF
JP key1 @TG1_L
LD OUTPUT, 0xFE
JP key5 @TG1_L
LD OUTPUT, 0xFD
JP key9 @TG1_L
END

TG2F:
LD OUTPUT, 0xFF
JP key2 @TG2_L
LD OUTPUT, 0xFE
JP key6 @TG2_L
LD OUTPUT, 0xFD
JP key10 @TG2_L
END
TG3F:
LD OUTPUT, 0xFF
JP key3 @TG3_L
; For TG3F edge
;For TG2F edge

## W529XX Application Note

```
    LD OUTPUT, 0xFE
    JP key7 @TG3_L
    LD OUTPUT, 0xFD
    JP key11 @TG3_L
    END
TG4F: ; For TG4F edge
    LD OUTPUT, 0xFF
    JP key4 @TG4_L
    LD OUTPUT, 0xFE
    JP key8 @TG4_L
    LD OUTPUT, 0xFD
    JP key12 @TG4_L
    END
key1:
key2:
    ...
key12:
END
```

For saving the extra bits needed for assigning multiplexing selections for the 101 - IO8 pins, the W529XX imposes some restrictions on the possible combinations: two bits in the MODE1 register are first decoded into four possible groups, then the 8-bit MODE2 register is used to further decode the 101 - IO8 for their corresponding selections.

See also IO1-IO8 of Pin Description for further details.

## 6. REGISTER DEFINITION AND CONTROL

The register file of the W529XX is composed of 13 registers, designed for various operations. Each register can be arithmetically operated on with immediate data or with any register, be bit-manipulated by logical operations, like AND, OR and XOR or can be modified by LD or MV commands.

All the 13 registers share the common 8 -bit wide bus for data exchange and command execution control. The related register information is shown in the following table.

| Name | Purpose | Bit definition <br> B7, B6, B5, B4, <br> B3, B2, B1, B0 | Initial value <br> upon power up |
| :---: | :--- | :---: | :---: |
| EN | To hold enable/disable <br> control bits for TG1- TG4 | TG4R, TG3R, TG2R, TG1R, <br> TG4F, TG3F, TG2F, TG1F | 11111111 |
| R0 - R7 | General purpose registers | - | 01000000 |
| MODE1 | To hold various mode <br> controlled bits for different <br> configurations | Debounce time, reserved, LED <br> source, LED type, LED clock 1, <br> LED clock 0, IO group 1, IO <br> group 0 | 00000000 |
| MODE2 | To hold various mode <br> controlled bits for different <br> configurations | IO8, IO7, IO6, IO5, <br> IO4, IO3, IO2, IO1 | 00000000 |
| ACC | Accumulator | - | 00000000 |
| OUTPUT | To hold output values that <br> are reflected at IO1 - IO8 <br> pads, or initial values for <br> LED effects | - | 00000000 |

## MODE1

| Bit | Name | $\mathbf{0}$ | $\mathbf{1}$ |
| :---: | :---: | :---: | :---: |
| 0 | IO group selection 0 | ${ }^{*} 00:$ group 0 | ${ }^{*} 01:$ group 1 |
| 1 | IO group selection 1 | ${ }^{*} 10:$ group 2 | ${ }^{*} 11:$ group 3 |
| 2 | LED clock 0 | ${ }^{* *} 00: 1.5 \mathrm{~Hz}$ | ${ }^{* *} 01: 3 \mathrm{~Hz}$ |
| 3 | LED clock 1 | ${ }^{* *} 10: 6 \mathrm{~Hz}$ | ${ }^{* *} 11: 12 \mathrm{~Hz}$ |
| 4 | LED type | synchronous or circular | alternate or random |
| 5 | LED source | 3 Hz | OUTPUT |
| 6 | Reserved | - | - |
| 7 | Debounce time | Long (arround 45 mS ) | Short (arround $350 \mu \mathrm{~S}$ ) |

Note: " *" bit1 and bit0. The first bit defined as bit1 and the second bit defined as bit0.
" ** " bit3 and bit2. The first bit defined as bit3 and the second bit defined as bit2.

Example1:

a. The debounce time of the trigger inputs is set as a short time. (around $350 \mu \mathrm{~S}$ )
b. The operation of the LEDs is circular with a 1.5 Hz frequency; from bit2 to bit5 definitons.
c. Bit1 and bit0 define the group0 for IO1-IO8 pins option.

## Example2:

LD MODE1, $\underline{\underline{00000111 B}}$


MODE1: Long

a. The debounce time of the trigger inputs is set as a long time. (around 45 mS )
b. The operation of the LEDs is synchronous with a frequency of 3 Hz ; from bit4 and bit5 definitons.
c. Bit1 and bit0 define the group3 for IO1-IO8 pins option.

The group selection for the IO pins are defined by bit 1 and bit 0 altogether. See IO1-IO8 of Pin Description for more details.

## MODE2

The MODE2 register is dedicated for IO configuration definition after group selection, which is defined in the MODE1 register. There are two options that can be selected for each bit of the MODE2 register. A "0" selects the former option, while a "1" picks the latter option. See also Pin Description for further details.

## W529XX Application Note

## EN

A "1" means "enabled", while a "0" means "disabled" for that edge of the particular TG pin. For example, the command "LD EN, 0x0F" enables all the falling edge triggers of TG1-TG4, while disabling the rising edge triggers of TG1 - TG4. Users may modify the EN register during operation of the W529XX to achieve various kinds of trigger functions, like retriggerable or not, one shot or level hold play modes, etc.

In other words the user may change the contents of the EN register during synthesis to determine which TG is to be enabled/disabled and triggered on its falling/rising edge.

## ACC

This is the register that is called the accumulator. For ALU operations (e.g., ADD, AND, OR, and XOR), the ACC is modified implicitly with the same result of the destination register. For example, assume R6 equals 5(Dec), the command "ADD R6, 12" when executed gives R6 and ACC the same result of 17(Dec) at the end of command processing.

## OUTPUT

The OUTPUT register is used to control the status of the IO1-IO8 pins. These can be configured to be STOP outputs by setting the proper bits in the MODE1/MODE2 registers. For example, if the $1 O 2$ pin is selected as a STOP output, the corresponding bit, that is bit 1 of the OUTPUT register is set to drive the output buffer, an inverted stage, to show its logic status.

This register is also used as a shift register for LED circular/random effects. See also LED Operation for more details.

## R0-R7

These eight registers function as general purpose registers. They can be used to hold group numbers, values for number counting, event flags, etc.

## IPORT

The IPORT is not a physical register in the W529XX, but rather a register-mapped input port that shares the 8bit bus with other registers to facilitate reading of the port status. Pins IO1-IO8 can be selected to act as an input port, provided the proper settings are made to the MODE1 and MODE2 registers. Unselected bits of the IPORT register are masked as zeros. Only one command " MV Rn, IPORT" ( n : $0-7$ ) can be used in programming.

## 7. PORT READING

At most, 8 bits can be acquired on the data bus if the IO pins are all configured as INPUTs. The command "MV reg, IPORT" will put the status of the port into the register "reg" for further processing. The user has to first configure the MODE1 and MODE2 registers for the required IO selections before the proper port status can be acquired. The following example (for reference only) shows how the port status can be manipulated.

## W529XX Application Note

FREQ1
POI:

| LD MODE1, $0 \times 00$ | $; 1 O$ group 0 selected |
| :--- | :--- |
| LD MODE2, $0 \times 87$ | $; 1 O 1-1 O 3->$ LED, $104-1 O 7->$ INPUT, $108->$ STOP |
| END |  |

port:

| MV R2, IPORT | ; To move port status into register R2 |
| :--- | :--- |
| JP case1 @R2.3=1 | ; If bit3 of R2 register is equal to 1 , jump to case1 voice group. |
| JP case2 @R2.5=1 | ; If bit5 of R2 register is equal to 1, jump to case2 voice group. |
| END |  |



Only those bits that are declared as INPUT pins can be acquired by the "MV reg, IPORT" command. Others bits, which are not INPUT pins, are masked by zeros. For example, the above program selects IO group 0 and chooses IO4-IO7 as the INPUT pins. Assuming that the status of 4 external bits is "1101", after completion of the command "MV R2, IPORT", R2 holds the result of $01101000(\mathrm{~B})$.

## 8. SYMBOLIC COMPILER

In order to reduce the workload of the *.out programming for the W529XX, a symbolic compiler has been designed. This accepts not only the commonly used group numbers, but also the symbolic labels that are adopted in most commercial $\mu \mathrm{P}$ compilers.

## 9. DIRECT TRIGGER

The W529XX provides a total of 4 trigger inputs to interface directly with the outside world. After debouncing, the W529XX responds to each edge of a valid trigger with a voice group, provided that the associated enable flag of that particular edge has been previously set. The triggered input then starts to execute the voice group by overwriting current operations, if any.

## 10. D/A CONVERTER

When a voice GO instruction is executed, the D/A converter is activated until an "END" or "PSAVE" instruction is encountered. The W529XX provides a unique instruction "PSAVE" to turn off the D/A converter for power
saving purposes. The role that the "PSAVE" plays in the W529XX will be described in more detail in the following section.

## 11. RAMP UP/DOWN

In the past Winbond's speech synthesizers will encode a "head" and "tail" during code preparations to avoid the pop sounds that may occur at the start or end of a voice. The following example is a typical ${ }^{*}$.out file for previous PowerSpeech ${ }^{\text {™ }}$ products:

```
W5282
LED1
FREQ2
LED1_S_CTRL
0:2
    H4 + voice1 + 2 * voice2 + T4
    END
1:
    H4 + Voice3 + T4
    END
```

In the W529XX, a new H/W mechanism automatically inserts the head (H4) and tail (T4), to eliminate the pop sounds. The D/A converter is disabled and the PCM value and quantization pointer of the ADPCM stage are reset to 0 . This initial status will not be changed until a voice GO instruction is executed. Both the head (H4) and the tail (T4) periods are 10.67 mS .

A special point concerning power consumption and use of the "PSAVE" instruction should be mentioned. As the "PSAVE" instruction turns off the D/A converter, it can be used to disable the output of the D/A converter when running the "Command" instructions. With the new mechanism for ramp up/down, it is now possible to control the playing voice with more flexibility than before. For example, if we want two voices to be played more continuously between their connection point, we only need to omit the "PSAVE" instruction between them. Doing this will ensure no insertion of "head" and "tail", which may take about 21.34 ms between these two voices. If voice continuity is more important than power consumption, then it is possible that no "PSAVE" instructions are written into the program.

## 12. ADPCM/PCM SYNTHESIS

The W529XX offers an alternative to the ADPCM algorithm for voice reproduction, direct 8-bit PCM coding. This PCM direct coding may be used for better reproductions especially for applications using high quality music sources.

The following voice combinations show the mixing of ADPCM and PCM synthesis.

```
W52905
```

LED1
FREQ2

## W529XX Application Note

Synthesis: 3

$$
\begin{aligned}
& \text { Voice1 + Voice2 + Voice3 } \\
& \text { END }
\end{aligned}
$$

Voice1 and Voice3 are ADPCM converted files with *.WAM extensions, while Voice2 is a direct PCM format with an *.SRC extension. The source (*.SRC) files, which can be acquired from Winbond's sound card or transformed from *.WAV files, have to be converted into ADPCM format before compilation can proceed. During compilation, the W529XX compiler will first check for the existence of Voice1.WAM, before checking if Voice1.SRC exists. In either case, the compiler can proceed normally with ADPCM/PCM synthesis. The same check procedures continue for the Voice2 and Voice3 files. The compiler will show an error message if both the *.WAM and *.SRC files do not exist.

## 13. LED OPERATION

The LED pins, selected from IO1 - IO8 by configuring the MODE1/MODE2 registers, can be used to enhance the product's attractiveness. The LEDs for the W529XX may have the following possible selections: 3 Hz synchronous or alternate flashing, flashing circularly or randomly. The LEDs can also be section-controlled by each GO instruction, together with the frequency control feature.

## FLASH WITH 3 Hz

The 3 Hz clock is phase divided into two LED sources, which are $180^{\circ}$ out of phase, in order to facilitate the synchronous/alternate features.


The $\phi 1$ clock is applied to the LED1, LED3, LED5, and LED7 output pins. For synchronous flashing of the LEDs, the $\phi 1$ clock is connected to LED2, LED4, LED6, and LED8. For alternate flashing, the $\phi 2$ clock is connected to LED2, LED4, LED6, and LED8. In other words, all the LED outputs flash synchronously with the $\phi 1$ clock or flash alternately in two groups, one is LED1/3/5/7 with $\phi 1$ and the other is LED2/4/6/8 with $\phi 2$.

## CIRCULAR/RANDOM OPERATION

The W529XX provides special LED circular and random flashing functions.

## W529XX Application Note



The basic operating principles are described below:
a. The W529XX provides only 6 or 8 LEDs for circular/random operations. If the user uses 6 LEDs, then the two MSBs are left unchanged during operations. Under such conditions only LD commands can be used to modify bit7/bit6. During circular/random operations, the LD command receives a higher priority than the shifting clock. The user can therefore always modify the LED patterns without problems.

| OUTPUT register | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IO1 - IO8 | *IO8 | *IO7 | IO6 | IO5 | IO4 | IO3 | IO2 | IO1 |
| **LD OUTPUT, 00111000b | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 |
| LED on/off | on | on | off | off | off | on | on | on |

* If the 6 LEDs are defined for the circular/random function, the IO8 and IO7 will not shift during operation. The IO8 and IO7 will be fixed in low.
** "LD OUTPUT,00111000b " defines the initial value for circular or random
b. For circular/random LED operation to take effect, the MODE1 register has to be configured properly: MODE1.5 should be defined as an OUTPUT. Then the LED type, circular or random, should be selected by resetting or setting MODE1.4, respectively. The LED clock can be defined as $12 / 6 / 3 / 1.5 \mathrm{~Hz}$ by configuring (MODE1.3, MODE1.2) to be $(1,1) /(1,0) /(0,1) /(0,0)$ respectively. When MODE1.5 is defined as an OUTPUT for the LED source, the LED clock starts to shift out the OUTPUT register as long as the chip is operating. To stop its shift operation, just re-program the value of MODE1.5 to 0 for the selection of $3-\mathrm{Hz}$ source.


## W529XX Application Note

## 8 LEDs circular operation:

LD mode1, 00100011b ; IO group3, LED source: output
; LED type:circular, LED clock: 1.5 Hz
LD mode2, 00000000b ; IO1-IO8 as LEDs
LD output, 00111000 b ; for random initial value

| 108101 | " T " means delay $1 / 1.5 \mathrm{sec}$. <br> " 0 ": LED on <br> " 1 ": LED off |
| :---: | :---: |
| $\begin{gathered} 00111000 \\ \downarrow \end{gathered}$ |  |
| 01110000 |  |
| 1 T |  |
| 11100000 |  |
| $\downarrow$ T |  |
| 11000001 |  |
| $\downarrow$ T |  |
| 10000011 |  |
| 1 T |  |
| $00000111$ |  |
| $\dagger T$ |  |
| 00001110 |  |
| 1 T |  |
| 00011100 |  |
| T |  |

## 8 LEDs random operation:

LD mode1, 00110011b ; IO group3, LED source: output

$$
\text { ; LED̆ type:random, LED clock: } 1.5 \mathrm{~Hz}
$$

LD mode2, 00000000b; IO1-IO8 as LEDs
LD output, 00111000b ; for random initial value


## 6 LEDs circular operation:

LD mode1, 00101011b ; IO group3, LED source: output
; LED type:circular, LED clock: 6 Hz
LD mode2, 11000000b ; IO1-IO6 as LEDs, IO7 and IO8 as STOPs
LD output, 00111000 b ; for circular initial value


## 6 LEDs random operation:

LD mode1, $00111011 b$; IO group3, LED source: output
; LED type:random, LED clock: 6 Hz
LD mode2, 11000000b ; IO1-IO6 as LEDs, IO7 and IO8 as STOPs
LD output, 00111000b ; for circular initial value


## W529XX Application Note

c. To achieve the circular/random operation, the W529XX has some constraints.

1> Those selections with a different number of LEDs, which are other than 6 or 8, may suffer from the drawbacks of discontinuity of LED flashes, disruption of STOP outputs, etc.
2> The H/W key matrix scan mode cannot be used as it will produce abnormal operation; i.e. the IO pins cannot be chosen as the "SCAN" for circular/random functions.
The user has to take into consideration these limitations.
The following example (for reference only) shows a program which displays powerful LED effects for the W529XX.

W52906
LED1 ; LED section control is ON as default.
FREQ2 $\quad ; \mathrm{SR}=8 \mathrm{KHz}$.
POI:
LD MODE1, 00000011b ; IO group 3, LED source: 3 Hz , LED clock: 1.5 Hz , ; LED type: synchronous.
LD MODE2, 11000000b ; 2 STOP outputs and 6 LEDs. IO8/7: STOP, IO6 ; IO1: LED.
END
Demo0:
JP 3Hz_Syn ; To setup MODE1 register
Demo1:
Voice1 + Voice2_20 + Voice3 ; LED is OFF during Voice2 playback
JP 3Hz_Alt ; To setup MODE1 register
Demo2:
Voice4 + Voice5
JP Circular1 ; To setup MODE1 \& OUTPUT registers
Demo3:
Voice6
JP Circular2 ; To setup MODE1 register
Demo4:
Voice6
JP Circular3 ; To setup MODE1 register
Demo5:
Voice6
JP Circular4 ; To setup MODE1 register
Demo6:
Voice6
JP Random ; To setup MODE1 \& OUTPUT registers
Demo7:
Voice7
END
3 Hz _Syn:
CLRB MODE1.5
; LED source: 3 Hz

## W529XX Application Note

CLRB MODE1.4
JP Demo1
3Hz_Alt:
CLRB MODE1.5
SETB MODE1.4
JP Demo2
Circular1:
LD OUTPUT, 11000001b
SETB MODE1.5
CLRB MODE1.4
SETB MODE1.3
SETB MODE1.2
JP Demo3
Circular2:
SETB MODE1.5
CLRB MODE1.4
SETB MODE1.3
CLRB MODE1.2
JP Demo4
Circular3:
SETB MODE1.5
CLRB MODE1.4
CLRB MODE1.3
SETB MODE1.2
JP Demo5
Circular4:
SETB MODE1.5
CLRB MODE1.4
CLRB MODE1.3
CLRB MODE1.2
JP Demo6
Random:
LD OUTPUT, 11000010b
SETB MODE1.5
SETB MODE1.4
SETB MODE1.3
CLRB MODE1.2
JP Demo7
; LED type: synchronous
; LED source: 3 Hz
; LED type: Alternate
; Load 00_0001 for circular operation.
; LED source: OUTPUT
; LED type: circular
; LED clock: 12 Hz
: LED source: OUTPUT
: LED type: circular
; LED clock: 6 Hz
; LED source: OUTPUT
; LED type: circular
; LED clock: 3 Hz
; LED source: OUTPUT
; LED type: circular
; LED clock: 1.5 Hz
; operation.
; LED source: OUTPUT
; LED type: random
; LED clock: 6 Hz

## 14. SAMPLE RATE

The sample rate for voice reproductions can be determined by two methods. One method adjusts the external resistor Rosc, and the other method changes the control bits for variable frequency effects. The former method
adjusts the master frequency of the whole chip, while the latter method divides the master frequency by different divisors to get the different $4.8 / 6 / 8 / 12 \mathrm{KHz}$ sample rate clocks for the typical condition of FOSC $=1.5 \mathrm{MHz}$.

Normally, the user has to reproduce the voices at the same sample rate as recordings in order to get the original voice outputs. The maximum sample rate allowed for the W529XX is 12 KHz , a limitation that is mainly due to the access time of the ROM production chips.

During the development phase of application code, the user may use Winbond's speech download board or OTP chip to evaluate the functions and voice quality. However it should be noted that the sample rate cannot be set above 12 KHz , which is the maximum limitation of the W529XX, even though in practice it can work normally. This is due to a fundamental difference of ROM structure between the evaluation tools and real chips.

## 15. W529XX PROGRAM FORMAT

The W529XX PowerSpeech ${ }^{\text {TM }}$ II enables users to define the functions of their products using the W529XX PowerSpeech ${ }^{\text {T }}$ programming language. An example of the W529XX PowerSpeech ${ }^{\text {™ }}$ program format is shown below. (Explanatory notes follow the example.)

$(2) \rightleftharpoons \begin{array}{ll}\text { DEFINE scanM1 00000001b } & \begin{array}{l}\text {; define constant scanM1=1 } \\ \text { DEFINE scanM2 0000000b } \\ \text {; define constant scanM2=0 } \\ \text {; all of IO1-IO7 are for scan }\end{array}\end{array}$

## macro random register

Idr register,2 ; 0,2
Idracc, $7 \quad ; 0-7$
add register, acc ; 0-9
endm - (6)
$(4) \longrightarrow$
macro chk_keyin label0, label1, label2
mv acc,r6
jp label0 @r6=0 ; The first key_in
mv acc,r6
sub acc, 1
jp label1 @r6=0 ; The second key_in
mv acc,r6
sub acc,2
jp label2 @r6=0 ; The third key_in
jp keyin_over ; key_in more than 3 times, try again endm

[^0]
## W529XX Application Note


(1) Bodies: The user must first define the W529XX body to be used, or else an error message will appear during compiling. The W529XX bodies include the following: W52902, W52903, W52904, W52905, W52906, W52910, W52915 and W52920
(2) Define: The user can define constants in order to ease programming. Both upper and lower case are considered the same by the compiler, in other words "A" and "a" are the same after compilation. Hexadecimal ( $0 \times 00$ or Offh), binary ( 11010101 b ) or decimal ( $0,100 .$. ) can be used as parameter types. So the following examples are the same:
define cycle 16
DEFINE Cycle Ofh
Define Cycle 0x0f
Define CYCLE 00001111b
The format of the "define" statement is shown below:

| first item | second item | third item |
| :---: | :---: | :---: |
| Define | constant | parameter |

Space must be inserted between these three items in order to divide them.
(3) Note: A semicolon " ; " is used to distinguish characters that are not part of the program. Character written to the right of the semicolon are not considered part of the program contents.
(4) Macro: If the program possesses many repetitive sections, a "Macro" may be used to provide a more efficient structure. In a macro program, the "label:" is illegal because it isn't a subroutine. After compilation the macro will be extended and inserted into the main program. So although a macro can offer more convenience in program editing it cannot reduce ROM size. It is also possible to call a macro within another macro program. Eight levels of depth can be used in programming. Note that all of the unknown parameters must be transferred from the main program. The "ENDM" command will end the macro program.

Illegal writing:

```
macro chk_keyin label0, label1, label2
    mv acc,r6
    jp label0 @r6=0
    mv acc,r6
    sub acc,1
lagelo:
endm
```

macro name: chk_keyin
transmitted paramàters: label0, label1, label2
(5) Macro begin line: This includes the keyword "Macro" to declare "macro start", a user given name for the macro and the transmitted parameters. The format is as follows:

| first item | second item | next |
| :---: | :---: | :---: |
| Macro | Name | parameters |

The individual transmitted parameters have a " , " between them.
(6) Macro end line: "endm" must be added at the end of the macro.
(7) Declarations: The output frequency and LED on/off state.

LED on/off:
--LED0: LED off (default)
--LED1: LED on
Output frequency:
--FREQ0: 4.8 KHz
--FREQ1: 6 KHz (default)
--FREQ2: 8 KHz
--FREQ3: 12 KHz
(8) program body: Write application program and speech operations, including the following:

Define entry point of speech group.
Determine number of global repeats.
Describe speech equations.

## W529XX Application Note

Define the register values and command sets.
Call macro ... etc.
The maximum program memory size of the W529XX is 256 K bits. Each GO instruction occupies 48 bits, and each group entry ( $0-255$ ) occupies 16 bits. A total of around $5,400 \mathrm{GO}$ instructions can therefore be used in the program. The GO instruction includes the following contents:
(1) command set with one GO instruction: ADD, OR, XOR, AND, LD, LDR, MV, JP, JPR, NOP, END, INS, DEC, SETB, CLRB, NOT
(2) command set with two GO instructions: COMP, DJNZ
(3) command set with three GO instructions: CJNE, CJE
(4) Each ADPCM and PCM file of the speech equation with one GO instruction: For example in the speech equation: A+B_21+C+[300]+D, there are a total of 5 GO instructions, including A, B_21, C, [300] and D. The above example (for reference only) will be compiled and extended as follows:


In the above program, there are a total of 18 GO instructions and 3 group entries.
(9) Group name: Define the voice group entry point. This is different from the previous PowerSpeech ${ }^{\top} \mathrm{M}$ W525XX and W528X devices which had to use a number to define the group name. In the W529XX, a label can be used to define the group name, as in the above program which used "start", "again", "keyin 00 ",...etc. Note that the W529XX can also use a number to define the group name, but reserved words can't be used as normal labels. These reserved words are listed in the last page. Only letters and numbers can be used as the group name. Symbols such as "~", " \#", " - ", ...etc are forbidden with the exception of the underline "_".
(10) Global repeat: The global repeat instruction is " n " which is from 1 to 4 . This instruction must be placed on the same line as the group name.

## W529XX Application Note

(11) Speech equation: The program can accept ADPCM ( ${ }^{*}$.WAM) files or PCM (*.SRC) files during compiliation and it will first look for ADPCM files. Therefore, if PCM files are used for better sound quality the "*.WAM" file should not exist in the same directory. See the above description. In the speech equation, using "*" for the local repeat and using " + " for combinative voices occupy around $160 \mu$ S each.
(12) Call macro: To call a macro within the program, the macro name and the transmitted parameters must be in the same line and the number of the transmitted parameters must be equal. See the following example:


The "chk_keyin" is the macro name, keyin00, keyin01 and keyin02 are the transmitted parameters.
During compilation, the statement below the "tg1" label will call a macro "chk_keyin keyin00, keyin01, keyin02" which will be extended and placed in the macro contents. When extending the macro "chk_keyin", "label0" is equal to "keyin00", "label1" is equal to "keyin01", and "label2" is equal to "keyin02". So the "chk_keyin keyin00, keyin01, keyin02" will be compiled to:

$$
\begin{aligned}
& \hline \text { mv acc, r6 } \\
& \text { jp keyin00 @r6=0 } \\
& \text { mv acc, r6 } \\
& \text { sub acc, } 1 \\
& \text { jp keyin01 @r6=0 } \\
& \text { mv acc, r6 } \\
& \text { sub acc, } 2 \\
& \text { jp keyin02 @r6=0 } \\
& \text { jp keyin_over }
\end{aligned}
$$

Macros do not reduce the program size.
(13) Blank: A voice group name must be followed by one full blank line without any instructions or speech equations.
(14) Silence: In this regard, the W529XX is different from the other PowerSpeech ${ }^{\text {TM }}$ ICs such as the W525XX, W528X, W523X and W581XX. The silence length in the W529XX will be automatically left shifted by 4 bits. The silence length of the [123] in the W529XX will be equal to [1230] in the other PowerSpeech ${ }^{\text {TM }}$ ICs. So in the above example, [500] is equal to [5000] in others ICs and its period is about 0.853 sec . (sample rate is 6 kHz ). The maximum silence in the W529XX is [FFFF] and its period is about 43.69 sec . (sample rate is 6 khz )

## W529XX Application Note

## COMMAND SET

In the W528x and other predecessors, the PowerSpeech ${ }^{\text {TM }}$ synthesizers simply provide customers with two types of commands: LD \& JP, which are actually SIL in previous products. In the W529XX, more effort has been given to greatly expand the particular role of SIL into different kinds of commands, like ALU, move, subroutine call, etc.

During command execution, the internal sample rate selection will be set to 12 KHz by means of H/W \& compiler maneuvering in order to reduce the cycle time. Each command will be executed within one cycle, which is defined to be less than $200 \mu \mathrm{~S}$, except for those pseudo mnemonics that may require more than one cycle for the sake of user friendliness.

## 1. CONDITION CODE (~@cc)

## @Trigger status

Upon execution of the command with such a condition, the W529XX will check the pad status of the specified TG1 - TG4 right at the execution time and then decide whether the command is to be executed, depending on whether the condition is met or not.

There are eight trigger status that are associated with the four TG pins as follows,
@TG1_H or @TG1_HIGH
@TG1_L or @TG1_LOW
@TG2_H or @TG2_HIGH
@TG2_L or @TG2_LOW
@TG3_H or @TG3_HIGH
@TG3_L or @TG3_LOW
@TG4_H or @TG4_HIGH
@TG4_L or @TG4_LOW

## @LAST (Last global play time)

The maximum global repeat time of W529xx is four times. The condition @LAST is met only if the W529XX is running its last global repeat for a certain voice group.

## @Flag

The @Flag includes four conditions: @ZERO, @~ZERO, @CARRY, @~CARRY.

- @ZERO (The condition when the result is zero.)
- @~ZERO (The condition when the result is not zero.)

The zero flag is modified accordingly upon execution of an ALU command. It is set to "1" when the result equals to zero, otherwise it is set to " 0 ". For other conditions, such as data move commands, where the result may also equal zero, the zero flag is NOT affected.
Commands that will affect the zero flag are ADD, OR, XOR, AND, INC, DEC, SUB, SETB, CLRB, COMP, NOT, DJNZ, CJNE, and CJE.

- @CARRY (The condition when the carry flag is 1. .)
- @~CARRY (The condition when the carry flag is not 1.)

When the ALU operation overflows, the CARRY flag will be set to "1". The carry flag is modified accordingly upon the execution of ADD, INC, DEC, SUB, and DJNZ commands.

| Command | Flags affected <br>  <br>  <br> Carry |  |
| :---: | :---: | :---: |
|  |  |  |
| ADD | $\checkmark$ | $\checkmark$ |
| OR | - | $\sqrt{ }$ |
| XOR | - | $\checkmark$ |
| AND | - | $\checkmark$ |
| INC | $\checkmark$ | $\checkmark$ |
| $D E C$ | $\checkmark$ | $\checkmark$ |
| SUB | $\checkmark$ | $\checkmark$ |
| SETB | - | $\checkmark$ |
| CLRB | - | $\checkmark$ |
| COMP | - | $\checkmark$ |
| NOT | - | $\checkmark$ |
| DJNZ | $\checkmark$ | $\checkmark$ |
| CJNE | - | $\checkmark$ |
| CJE | - | $\checkmark$ |

Table: Relationship between ALU commands and processor flags
The processor's flags can only be modified by ALU commands, which are listed above, other commands will not modify the status of these flags. For example, the command "LD ACC, 0x00" also causes the result to become zero after the completion of command execution, but fails to alter the content of the ZERO flag.

## @reg.n = 1:

This condition represents bitn of the register equal to 1 .

## @reg.n = 0 :

This condition represents bitn of the register equal to 0 .
$@ r e g=0:$
This condition represents the value of the register equal to 0 .
@reg! = 0:
This condition represents the value of the register not equal to 0 .

### 8.2 INSTRUCTION DESCRIPTION

### 8.2.1 ALU

| Instruction Set | Description | Example |  |
| :---: | :---: | :---: | :---: |
| ADD reg, n [@cc] | ACC, reg $\leftarrow r e g+n$, if cc met <br> Add a constant " n " to register "reg" [if condition is met]. The result is kept in "reg" and ACC. <br> Flag affected: CF, ZF | ADD R0, 00101011b | $\begin{aligned} & \frac{\text { After exec. }}{00101011 \mathrm{~b}} \\ & \text { AAh } \\ & \text { AAh } \end{aligned}$ |
| ADD reg2, reg1 [@cc] | $A C C$, reg $2 \leftarrow$ reg $2+$ reg1, if cc met <br> Add contents of register "reg1" to register "reg2" [if condition is met]. The result will be kept in "reg2" and ACC. <br> Flag affected: CF, ZF | ADD R0, R1 | $\begin{gathered} \text { After exec. } \\ \hline 1 \\ 5 \\ 5 \end{gathered}$ |
| OR reg, n [@cc] | ACC, $r e g \leftarrow r e g / n$, if $c c$ met <br> Bitwise OR operation of register "reg" and immediate value "n" [if condition is met]. The result will be placed in destination "reg" and also in ACC. <br> Flag affected: ZF | OR OUTPUT, 10101010b  <br>   <br> $\frac{\text { Memory. }}{}$ $\frac{\text { Before exec. }}{10101010 \mathrm{~b}}$ <br> n  <br> OUTPUT 01010101 b <br> ACC --- | After exec. $\frac{1010 ~ 1010 b}{}$ 11111111 b 11111111 b |
| OR reg2, reg1 [@cc] | ACC, reg $2 \leftarrow$ reg 2 \| reg1, if cc met <br> Bitwise OR operation of register2 "reg2" and register1 "reg1" [if condition is met]. The result will be placed in destination "reg2" and ACC. <br> Flag affected: ZF | OR R0, R2  <br> Memory.  <br> $\frac{B e f o r e ~ e x e c . ~}{l}$  <br> R2 0 Ah <br> RO AOh <br> ACC --- | After exec. <br> 0Ah <br> AAh <br> AAh |
| XOR reg, n [@cc] | ACC, $r e g \leftarrow r e g \wedge n$, if cc met <br> Bitwise XOR operation of register "reg" and value "n" [if condition is met]. The result will be placed in destination "reg" and ACC. <br> Flag affected: ZF |  | After exec. $\frac{00111010 \mathrm{~b}}{} \mathbf{0 1 0 0 1 1 0 1 \mathrm { b }}$ 01001101 b |

## W529XX Application Note

| XOR reg2, reg1 [@cc] | $A C C, r e g 2 \leftarrow r e g 2^{\wedge} \text { reg1, if cc met }$ <br> Bitwise XOR operation of register2 "reg2" and register1 "reg1" [if condition is met]. The result will be placed in destination "reg2" and ACC. <br> Flag affected: ZF | XOR R4, R5 | $\begin{aligned} & \frac{\text { After exec. }}{55 \mathrm{~h}} \\ & \text { FFh } \\ & \text { FFh } \end{aligned}$ |
| :---: | :---: | :---: | :---: |
| AND reg, n [@cc] | $A C C, r e g \leftarrow r e g \& n, \text { if } c c \text { met }$ <br> Bitwise AND operation of register "reg" and value " $n$ " [if condition is met]. The result will be placed in destination "reg" and ACC. <br> Flag affected: ZF | AND R2, 5EH | After exec. 0011 1010b 0100 0100b 0100 0100b |
| AND reg2, reg1 [@cc] | $A C C, \text { reg } 2 \leftarrow \text { reg } 2 \& r e g 1, \text { if cc met }$ <br> Bitwise AND operation of register2 "reg2" and register1 "reg1" [if condition is met]. The result will be placed in destination "reg2" and ACC. <br> Flag affected: ZF | AND R4, R5 | $\frac{\text { After exec. }}{55 \mathrm{~h}}$ 00 h 00 h |

## W529XX Application Note

inbond
Electronics Corp.

### 8.2.2 DATA MOVE

| Instruction Set | Description | Example |
| :---: | :---: | :---: |
| LD reg, n [@cc] | $r e g \leftarrow n$, if cc met <br> Load register "reg" with immediate value " n " [if condition is met]. <br> Flag affected: none | LD OUTPUT, 01011100b |
| LDR reg, RND [@cc] | $r e g \leftarrow$ random, if cc met <br> Load register "reg" with a random number, which is determined by the following formula: <br> reg $_{i}=r \cdot$ random $_{i}, \quad 0 \leq i \leq 3$. <br> $\mathrm{reg}_{\mathrm{i}}=0$, $4 \leq i \leq 7 .$ <br> where <br> reg $_{\mathrm{i}}=$ bit i of register "reg" in binary representation, $r=$ random bit(0 or <br> 1), which is generated by H/W, random $_{\mathrm{i}}=$ bit i of "random"(4 bit, 0 15) in binary representation. <br> Flag affected: none | LDR R2, 7 <br> $r$ : random bit (0 or 1), which is generated by H/W. |
| MV reg2, reg1 [@cc] | reg $2 \leftarrow$ reg1, if cc met <br> Move the contents of register1 to register2 [if condition is met]. <br> Flag affected: none | MV R2, IPORT   <br>    <br> Memory. Before exec. $\frac{\text { After exec. }}{\text { IPORT }}$$\frac{01001110 \mathrm{~b}}{01001110 \mathrm{~b}}$   <br> R2 --- 01001110 b |

### 8.2.3 BRANCH

| Instruction Set | Description | Example |
| :---: | :---: | :---: |
| JP label (or group no.) [@cc] [@cc] | VECTOR $\leftarrow$ group no., if cc met <br> Direct jump to the label entry or group no entry point [if condition is met], $0 \leq$ Group No $\leq 255$. <br> Flag affected: none | JP EXIT |
| JP reg [@cc] | $\text { VECTOR } \leftarrow \text { [regl., if cc met }$ <br> Indirect jump to the entry value that is stored in the register [if condition is met]. <br> Flag affected: none | JP R7 |
| JP reg+pointer [@cc] | $\underline{\text { VECTOR } \leftarrow[r e g]+\text { pointer, if cc met }}$ <br> Indirect jump to a location that is relative to immediate value "pointer" by [reg] [if condition is met]. <br> Flag affected: none | JP R3+128 |
| JP reg2+reg1 [@cc] | $\text { VECTOR } \leftarrow[r e g 2]+[r e g 1] \text {, if cc met }$ <br> Indirect Jump to a location that is relative to [reg1] [if condition is met]. <br> Flag affected: none | JP R3+R5   <br> Memory.   <br>  Before exec.  <br> R5   <br> R3 22 22 <br> VECTOR 36 36 <br>  --- 58 |
| JPR page, RND [@cc] | VECTOR $\leftarrow$ page.random, if cc met <br> Jump to a random location, which is jointly determined by one of a total of 16 pages and hardware generation. <br> (see description below) <br> Flag affected: none | JPR 3,7 <br> The random number will be generated randomly between the range of voice group 00110000b ~ 00110111b, that is 48~55 group entry. |

More information about the JPR page, random [@cc] instruction:

## W529XX Application Note

This instruction can let the user direct Jump to a 1-out-of- $2^{i}$ random locations [if condition is met], under the range of $0 \leq \mathrm{i} \leq 4$. The randomness, which is controlled by non-predictable $\mathrm{H} / \mathrm{W}$ nodes, for this kind of command supports from 1 to $1 / 16$. The page, defined by four MSB bits, is used to confine the range of random locations and it can be $0-15$. The randomness, defined by four LSB bits, is used to generate a random number by hardware located on the corresponding page. The pages list and corresponding voice groups are shown as following table.

| Page | Voice Group |
| :---: | :---: |
| 0 | $0-15$ |
| 1 | $16-31$ |
| 2 | $32-47$ |
| 3 | $48-63$ |
| 4 | $64-79$ |
| 5 | $80-95$ |
| 6 | $96-111$ |
| 7 | $112-127$ |
| 8 | $128-143$ |
| 9 | $144-159$ |
| 10 | $160-175$ |
| 11 | $176-191$ |
| 12 | $192-207$ |
| 13 | $208-223$ |
| 14 | $224-239$ |
| 15 | $240-255$ |

### 8.2.4 OTHERS

| Instruction Set | Description | Example |
| :--- | :--- | :--- |
| NOP [@cc] | No operation [if condition is met]. <br> This command can be used to slow <br> down the W529XX as a delay. | NOP |
| END [@cc] | The W529XX stops immediately <br> and enters into a standby state [if <br> condition is met], provided there are <br> no more global repeats. Otherwise, <br> the W529XX will repeat the whole <br> voice group again. |  |
| PSAVE | Ramp down and D/A converter off. | PSAVE |

W529XX Application Note
inbond
Electronics Corp.

| DEC reg [@cc] | $A C C, \text { reg } \leftarrow[r e g 2]-1, \text { if cc met }$ <br> Decrement register by 1 [if condition is met]. <br> Flag affected: $\mathrm{ZF}, \mathrm{CF}$ | DEC R2 | $\frac{\text { After exec. }}{4}$ |
| :---: | :---: | :---: | :---: |
| INC reg [@cc] | ACC, reg $\leftarrow$ [reg] +1 , if cc met <br> Increment register by 1 [if condition is met]. <br> Flag affected: ZF, CF | INC R2 | $\begin{gathered} \frac{\text { After exec. }}{6} \\ 6 \end{gathered}$ |
| SUB reg, n [@cc] | $A C C, r e g \leftarrow[r e g]-n, \text { if } c c \text { met }$ <br> Subtract immediate data n from the register [if condition is met]. <br> Flag affected: ZF, CF | SUB R1, 25  <br>   <br> Memory. Before exec. <br>  25 <br> R2 <br> ACC 56 <br>  --- | After exec. <br> 25 <br> 31 <br> 31 |
| SETB reg.bit [@cc] | ACC, [regli $\leftarrow 1$, if cc met <br> Set one of the register bits to 1 without altering the values of other bits [if condition is met]. <br> Flag affected: ZF, CF | SETB R4.5 | After exec. <br> 01101100 b <br> 01101100 b |
| CLRB reg.bit [@cc] | ACC, [reg]i $\leftarrow 0$, if cc met <br> Set one of the register bits to 0 without altering the values of other bits [if condition is met]. <br> Flag affected: ZF, CF | SETB R4.3 | $\frac{\text { After exec. }}{01000100 \mathrm{~b}}$ 01000100 b |
| COMP reg, n [@cc] | If fregl equal to $n, A C C \leftarrow 0$, if $c c$ met <br> Compare the data and place the result in ACC, but do not change the value stored in the register [if condition is met]. <br> Flag affected: ZF, CF | COMP R4, 54  <br>   <br> Memory. Before exec. <br> $n$ 54 <br> R4 54 <br> ACC --- | $\begin{gathered} \text { After exec. } \\ \hline 54 \\ 54 \\ 0 \end{gathered}$ |


| COMP reg2, reg1 <br> [@cc]   | If [reg2] $=$ [reg1], $A C C \leftarrow 0$, if $c c$ met <br> Compare the data between two registers and place the result in ACC, but do not change the value stored in the register [if condition is met]. <br> Flag affected: ZF, CF | COMP R4, 54 | After exec. <br> 54 <br> 54 <br> 0 |
| :---: | :---: | :---: | :---: |
| NOT reg [@cc] | ACC, reg $\leftarrow$ [reg $\left.\right\|^{1}$, if cc met <br> Performs 1's complement of the register's contents "reg" [if condition is met]. <br> Flag affected: ZF, CF | NOT R7 | $\frac{\text { After exec. }}{10001101 \mathrm{~b}}$ |
| DJNZ reg, group no | $\text { ACC, reg } \leftarrow \text { [reg]-1,í if } \sim Z E R O=1$ $\text { then VECTOR } \leftarrow \text { group no. }$ <br> Decrement register by 1 , then jump to the group number if the Not Zero flag is 1 . <br> Flag affected: ZF, CF | DJNZ R6, start | After exec. <br> 25 <br> 3 <br> 3 <br> 25 |
| DJNZ reg2, reg1 | $\begin{aligned} & \text { ACC, reg2 } \leftarrow \text { [reg2]-1, if } \sim Z E R O=1 \\ & \text { then VECTOR } \leftarrow \text { [reg1] } \end{aligned}$ <br> Decrement register2 by 1, then jump to the voice group entry contained in the contents of register1, if the Not Zero flag is 1. <br> Flag affected: ZF, CF | DJNZ R6, R0 | After exec. <br> 43 <br> 6 <br> 6 <br> 43 |
| CJNE reg, n, group no. | If lregl not equal to $n$, then $V E C T O R \leftarrow$ group no. <br> Compare the register value with the immediate data $n$, if not equal then jump to the voice group number. <br> Flag affected: --- | CJNE RO, 10, 20 | After exec. <br> 10 <br> 15 <br> 20 <br> 5 |


| CJNE reg1, reg2, group no | If [reg1] not equal to [reg2], then VECTOR $\leftarrow$ group number <br> Compare the register1 value with the register2 value, if not equal then jump to the voice group number. <br> Flag affected: --- | CJNE RO, R1, 20 | After exec. <br> 10 <br> 15 <br> 20 <br> 5 |
| :---: | :---: | :---: | :---: |
| CJNE reg1, n, reg2 | $\begin{aligned} & \text { If [reg1] not equal to } n \text {, then } \\ & \begin{array}{l} \text { VECTOR } \leftarrow \text { [reg2] } \end{array} \\ & \hline \end{aligned}$ <br> Compare the register1 value with the immediate value $n$, if not equal then jump to the voice group number contained in register2. <br> Flag affected: --- | CJNE R0, 10, R1 | After exec. <br> 10 <br> 15 <br> 20 <br> 20 <br> 5 |
| CJNE reg1, reg2, reg3 | $\begin{aligned} & \text { If [reg1] not equal to [reg2], then } \\ & \text { VECTOR } \leftarrow \text { [reg3] } \end{aligned}$ <br> Compare the register1 value with the value of register2, if not equal then jump to the voice group number contained in register3. <br> Flag affected: --- | CJNE R0, R1, R2 | After exec. <br> 10 <br> 15 <br> 20 <br> 20 <br> 5 |
| CJE reg, n, group no. | If fregl equal to $n$, then VECTOR $\leftarrow$ group no. <br> Compare the register value with the immediate data $n$, if equal then jump to the voice group number. <br> Flag affected: --- | CJE RO, 10, 20 | After exec. <br> 10 <br> 10 <br> 20 <br> 0 |


| CJE reg1, reg2, group no | If [reg1] equal to [reg2], then $\underline{V E C T O R} \leftarrow$ group number <br> Compare the register1 value with the register2 value, if equal then jump to the voice group number. <br> Flag affected: --- | CJE RO, R1, 20 | After exec. <br> 10 <br> 10 <br> 20 <br> 0 |
| :---: | :---: | :---: | :---: |
| CJE reg1, n, reg2 | If [reg1] equal to $n$, then VECTOR $\leftarrow\lceil r e g 2]$ <br> Compare the register1 value with the immediate value n , if equal then jump to the voice group number that is contained in register2. <br> Flag affected: --- | CJE RO, 10, R1 | After exec. <br> 10 <br> 10 <br> 20 <br> 20 <br> 0 |
| CJE reg1, reg2, reg3 | If [reg1] equal to [reg2], then $\underline{V E C T O R} \leftarrow[r e g 3]$ <br> Compare the register1 value with the value of register2, if equal then jump to the voice group number that is contained in register3. <br> Flag affected: --- | CJE R0, R1, R2 | After exec. <br> 10 <br> 10 <br> 20 <br> 20 <br> 0 |

### 8.3 RESERVED WORDS

There are several reserved words for the W529xx that should not be used as a normal label names. The following tables lists them.

| ALU | ADD, OR, XOR, AND, SUB, DEC, INC, NOT, SETB, CLRB, COMP |
| :--- | :--- |
| Data Move | LD, LDR, MV |
| Branch | JP, JPR, DJNZ, CJE, CJNE |
| Other Instructions | NOP, END, PSAVE, DEFINE, MACRO, ENDM |

$\left.\begin{array}{|l|l|}\hline \text { Register } & \text { R0, R1, R2, R3, R4, R5, R6, R7, ACC, MODE1, MODE2, OUTPUT, EN } \\ \hline \text { Keypad } & \begin{array}{l}\text { POI, TG1F, TG1R, TG2F, TG2R, TG3F, TG3R, TG4F, TG4R } \\ \text { KEY10, KEY11, KEY12, KEY13, KEY14, KEY15, KEY16, KEY17 } \\ \text { KEY20, KEY21, KEY22, KEY23, KEY24, KEY25, KEY26, KEY27 } \\ \text { KEY30, KEY31, KEY32, KEY33, KEY34, KEY35, KEY36, KEY37 } \\ \text { KEY40, KEY41, KEY42, KEY43, KEY44, KEY45, KEY46, KEY47 }\end{array} \\ \text { (i.e., The KEYmn means that this matrix tey is composed of the Trigger_m } \\ \text { and the IO_n.) }\end{array}\right\}$


[^0]:    $(7) \rightleftharpoons \begin{array}{ll}\text { LED0 } & ; \text { (default)/ [LED1] } \\ \text { FREQ1 } & ; \text { (default)/ [FREQ0, FREQ2, FREQ3 ] }\end{array}$

