### 1. TRSF4A0XXA/B General Descriptions TRSF4A0XXA/B series are 4bit micro-controller which could play 4 channel melody or 4 channel ADPCM with PWM direct drive circuit. PWM resolution is 12 bits. They includes a low cost, high performance CMOS micro-processor. The clock frequency of this up is typically 13.1072 (±3%) MHz. This chip operates over a wide voltage range of 1.8V~5.5V. It contains program ROM and data ROM inside. The maximum program ROM is 8K word and data ROM size is 32K ~ 124K byte depending on PROM density. The maximum working SRAM is (512+2) nibbles. It provides with total 4 software programmable I/O Ports. #### 2. TRSF4A0XXA/B Features - Operating voltage: 1.8V to 5.5V - Internal HROSC: 65.536 MHz, LRCOSC 32K Hz - ☐ MCU Operation frequency: 13.1072 MHz - Memory Size - ☐ Flash Program Memory capacity: 2KX12, 4KX12, 6KX12 or 8KX12 bits selected by option. - ☐ Flash Data ROM capacity: 32Kx8 ~ 124KX8 bits depending on PROM density. - □ SRAM size: 512X4 bits - □ User register: 2X4 bits - Wakeup function for power-down mode - ☐ HALT mode wakeup source: Port A, PWM and RTC wakeup can wake-up from HALT mode to NORMAL mode and executing wake-up sub-routine program. - 4 input/output pins: Port A can be defined as input or output port bit by bit. - Three reset condition - □ Low voltage reset (LVR = 1.7V) - □ Power on reset - □ Watch dog timer overflow - One internal interrupt sources - □ PWM interrupt - WDT - □ Watch dog timer, can enabled/disabled by option - $\square$ WDT period is 0.23 sec (Clock source by LRCOSC = 32.000K Hz ± 50%). - Audio output - □ Support 8/10/12 bits PWM - Support option set for pull down resistor 1M/(50K or 220K), low voltage reset...etc. - Oscillator fuse option ±3%, temperature & voltage compensation - Support security option (1 bit) to protect user code. - Low voltage detect (LVD) - 12 sign x 8 unsigned multiplication - Support indirect jump instruction JMPX, JMPPMA. - Support direct call instruction CALLX, CALLPMA. - Up to 8 level stacks for call sub-routing. - TOUCH function: 4 I/O - WKRTC - ☐ Real-time clock in halt mode, can enabled/disabled by option - □ wakeup period is 16/32/64/128 ms select by user code. - Only operating on Halt mode. - ( Clock source by LRCOSC = 32.000K Hz± 50%) ### 2.1 TRSF4A0XXA/B series selection table | Part No. | DROM Size | IO Keep High with halt mode | IO Keep High<br>with Deep Sleep | |------------|-----------------|-----------------------------|---------------------------------| | TRSF4A010A | 32Kx8 ~ 44Kx8 | With Hait mode | V | | TRSF4A020A | 64Kx8 ~ 76Kx8 | | V | | TRSF4A030A | 96Kx8 ~ 108Kx8 | | V | | TRSF4A040A | 112Kx8 ~ 124Kx8 | | V | | TRSF4A010B | 32Kx8 ~ 44Kx8 | V | V | | TRSF4A020B | 64Kx8 ~ 76Kx8 | V | V | | TRSF4A030B | 96Kx8 ~ 108Kx8 | V | V | | TRSF4A040B | 112Kx8 ~ 124Kx8 | V | V | Table 1. Selection table ## 3. TRSF4A0XXA/B Packaging and Pads Information ### 3.1 Pads | PAD Name | Туре | State<br>After<br>Reset | Description | | | | |-------------------|------|-------------------------|------------------------------------------------------------------------------|--|--|--| | Reset, Power Inp | ut | | | | | | | VCC | Р | High | Power input of I/O port | | | | | VSS | Р | Low | Ground input except PWM block power. It could be double bonded with VPS pad. | | | | | General I/O ports | ; | | | | | | | PA0~PA3 | 1/0 | XXXX | Port A is a programmable Input /Output port. | | | | | Audio output pad | ds | | | | | | | PWMP | 0 | Low | Audio output PWM(+). | | | | | PWMN | 0 | Low | Audio output PWM(-). | | | | Table 2. Pad Description ## 3.2 Block Diagram Figure 1. Block diagram ## 3.3 Package TRSF4A0XXA/B series provides SOP8 Figure 2. SOP8 Package ## 4. TRSF4A0XXA/B ELECTRICAL CHARACTERISTICS ### 4.1 Absolute Maximum Ratings | Parameters | Symbol | Value | Unit | |-----------------------------|--------|-----------------|--------------| | DC Supply Voltage | Vcc | -0.5 to 6.0 | V | | Input Voltage | Vin | -0.5 to Vcc+0.5 | V | | Operating Temperature Range | Ta | 0 to +75 | $^{\circ}$ C | | Storage Temperature Range | Tstg | -25 to +85 | $^{\circ}$ | Table 3. Absolute Maximum Ratings ### 4.2 DC Characteristics VCC=3.0V, Ta=25℃ unless otherwise noted | Parameters | Symbol | Minimum | Typical | Maximum | Condition | |----------------------------------------------------|--------------------|----------|----------|---------|--------------------------------------------------------------------------------| | power supply range | Vcc | 1.8 V | - | 5.5 V | | | Flash Programming Power | Vpp | 4.9V | 5.0 V | 5.1V | VCC = 3.3V | | Supply current | lop | | 1.5mA | | System clock 13.1072MHz<br>PWM disabled | | Stand-by Current (normal) | Istop <sub>1</sub> | 47- | 4uA | | VCC=5.0V, MCU halt<br>System clock off | | Stand-by Current (Deep) | Istop <sub>2</sub> | $X_{A}$ | 0.9uA | | VCC=5.0V, MCU halt<br>System clock off | | input high voltage | Vih | 7/ / | 0.5* VCC | | | | input low voltage | Vil | | 0.5* VCC | | | | input leakage<br>current | llk | | 0.1 uA | | | | output high voltage | Voh | 0.95 VCC | | | no load | | output low voltage | Vol | | | 0.05 V | no load | | output high current in high source capacity mode | loh0 | | 20mA | | Vout=2.0 all ports High source capacity No corresponding mask ROM type product | | output low current in high sink capacity mode | lol0 | | -20mA | | Vout=1.0 all ports High sink capacity No corresponding mask ROM type product | | output high current in normal source capacity mode | loh1 | | 5mA | | Vout=2.0 all ports<br>Normal source capacity | | output low current in normal sink capacity mode | lol1 | | -5mA | | Vout=1.0 all ports<br>Normal sink capacity | | PWM output load | | - | | 8 ohm | Speaker impedance | | pull-down resistance | Rpd1 | | 50K ohm | | Pins with pull-down PA and PE, Vin=3.0V | | pull-down resistance | Rpd2 | | 220Kohm | | Pins with pull-down PA and PE, Vin=3.0V | | pull-down resistance | Rpd3 | | 1Mohm | | Pins with pull-down<br>PA and PE, Vin=3.0V | | threshold voltage of low<br>voltage reset circuit | VIvr | | 1.7V | | Low voltage reset circuit can<br>not be disabled<br>1.8V@Ta=0℃, 1.6V@Ta=85℃ | Table 4. DC Characteristics #### 4.3 AC Characteristics VCC=3.0V, Ta=25°C unless otherwise noted | Parameters | Symbol | Minimum | Typical | Maximum | |-------------------------------|--------|-----------|------------|-----------| | Operating Frequency (HROSC/5) | Fsys | 12.714MHz | 13.1072MHz | 13.500MHz | | LRCOSC | Flrc | 16K Hz | 32K Hz | 48K Hz | | RC reset time-constant | Trrc | - | 10 us | - | | Program ROM data ready time | Tprr | - | - | 2/Fsys | | Data ROM data ready time | Tdrr | - | - | 2/Fsys | Table 5. AC Characteristics ### 5. TRSF4A0XXA/B FUNCTIONAL DESCRIPTION This chapter describes the function of MCU. ### 5.1 Flash Program Memory (PROM) The flash program memory has a capacity of 2/4/6/8K X12-bit (0000H $\sim$ 1FFFH). The last 256 location of effective PROM is reserved area for testing program. The user shall not use this area in any case. Assembler shall check user program on this limit. Hardware does not need to check this restriction. There is one option "OTPREV" to reserve unused area of PROM. If all unused area of PROM need to fill with "0XFFF", the option "OTPREV" on the IDE tool must be enabled. Otherwise, they will fill with "0x000". | | PROM 23 | PROM 43 | PROM (3 | PROM 83 | |---------------------|-------------|-------------|---------------|---------------| | user area | 0x000~0x6EF | 0x000~0xEEF | 0x0000~0x16EF | 0x0000~0x1EEF | | Reserve | 0x6F0~0x6FB | 0xEF0~0xEFB | 0x16F0~0x16FB | 0x1EF0~0x1EFB | | serial number | 0x6FC~0x6FF | 0xEFC~0xEFF | 0x16FC~0x16FF | 0x1EFC~0x1EFF | | system testing area | 0x700~0x7FF | 0xF00~0xFFF | 0x1700~0x17FF | 0x1F00~0x1FFF | Table 6. Memory Map of PROM ### 5.2 Flash Data ROM (DROM) The Flash Data ROM has a capacity of 32KX8 ~ 124KX8 bit, It stores the 8 bits wide data for ADPCM or melody data ...etc. The last 64 location is a reserved area. The user shall not use this area in any case. Assembler shall check user data ROM on this limit. Hardware does not need to check this restriction. | lali check user dai | | TRSF4A010A | | | | | | | | | |--------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|--|--|--|--|--|--| | DROM Addess | PROM 8K | PROM 6K | PROM 4K | PROM 2K | | | | | | | | 0000 ~ 0FFF<br><br>7F00 ~ 7FBF | user area | | | | | | | | | | | 7FC0 ~ 7FFF | system area,<br>last 64 location<br>(don't use) | user area | user area | | | | | | | | | 8FC0 ~ 8FFF | | system area,<br>last 64 location<br>(don't use) | | user area | | | | | | | | | | | | | | | | | | | | 9FC0 ~ 9FFF | | | system area,<br>last 64 location<br>(don't use) | | | | | | | | | | | | | | | | | | | | | AFC0 ~ AFFF | | | | system area,<br>last 64 location<br>(don't use) | | | | | | | Table 7. TRSF4A010A Memory Map of DROM | DDOM Addess | TRSF4A020A | | | | | | | | | | |---------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|--|--|--|--|--|--| | DROM Addess | PROM 8K | PROM 6K | PROM 4K | PROM 2K | | | | | | | | 00000 ~ 00FFF | | | | | | | | | | | | 01000 ~ 01FFF | user area | | | | | | | | | | | | usor area | | | | | | | | | | | 0FF00 ~ 0FFBF | | user area | | | | | | | | | | 0FFC0 ~ 0FFFF | system area,<br>last 64 location<br>(don't use) | 350. a. 5a | user area | | | | | | | | | | | | | user area | | | | | | | | 10FC0 ~ 10FFF | | system area,<br>last 64 location<br>(don't use) | | door dred | | | | | | | | | | | | | | | | | | | | 11FC0 ~ 11FFF | | | system area,<br>last 64 location<br>(don't use) | 7 | | | | | | | | | | | | | | | | | | | | 12FC0 ~ 12FFF | | | | system area,<br>last 64 location<br>(don't use) | | | | | | | Table 8. TRSF4A020A Memory Map of DROM | DROM Addess | TRSF4A030A | | | | | | | | | | |-------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|--|--|--|--|--|--| | DhOW Addess | PROM 8K | PROM 6K | PROM 4K | PROM 2K | | | | | | | | 00000 ~ 00FFF | | | | | | | | | | | | 01000 ~ 01FFF | user area | | | | | | | | | | | <br>0FF00 ~ 0FFBF | user area | | | | | | | | | | | 17FC0 ~ 17FFF | system area,<br>last 64 location<br>(don't use) | user area | user area | | | | | | | | | | | | | user area | | | | | | | | 18FC0 ~ 18FFF | | system area,<br>last 64 location<br>(don't use) | | user area | | | | | | | | | | | | | | | | | | | | 19FC0 ~ 19FFF | | | system area,<br>last 64 location<br>(don't use) | | | | | | | | | | | | | | | | | | | | | 1AFC0 ~ 1AFFF | | | | system area,<br>last 64 location<br>(don't use) | | | | | | | Table 9. TRSF4A030A Memory Map of DROM | DDOM Addess | TRSF4A040A | | | | | | | | | | |-------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|--|--|--|--|--|--| | DROM Addess | PROM 8K | PROM 4K | PROM 2K | | | | | | | | | 00000 ~ 00FFF | | | | | | | | | | | | 01000 ~ 01FFF | user area | | | | | | | | | | | <br>0FF00 ~ 0FFBF | | user area | | | | | | | | | | 1BFC0 ~ 1BFFF | system area,<br>last 64 location<br>(don't use) | user area | user area | | | | | | | | | | | | | user area | | | | | | | | 1CFC0 ~ 1CFFF | | system area,<br>last 64 location<br>(don't use) | | ager area | | | | | | | | | | | | | | | | | | | | 1DFC0 ~ 1DFFF | | | system area,<br>last 64 location<br>(don't use) | 7 | | | | | | | | | | | | | | | | | | | | 1EFC0 ~ 1EFFF | | | | system area,<br>last 64 location<br>(don't use) | | | | | | | Table 10. TRSF4A040A Memory Map of DROM DROM is addressed by five registers DMA4, DMA3, DMA2, DMA1 and DMA0. After these registers are specified by software, the data need enough delay time, Tdrr in the table of "AC Characteristics". After this delay time, the data can be read from data register (DMDL & DMDH). Otherwise, the data you read will be unknown. | DMA0 | 18H | R/W | XXXX | DMA0.3 | DMA0.2 | DMA0.1 | DMA0.0 | DMA0~4, five register built a 18 bit addressing space | |--------|-----|-----|------|--------|--------|--------|--------|-------------------------------------------------------| | DMA1 | 19H | R/W | XXXX | DMA1.3 | DMA1.2 | | | for read DROM 8 bits data, DMA0 is lowest nibble, | | DMA2 | 1AH | R/W | XXXX | DMA2.3 | DMA2.2 | DMA2.1 | DMA2.0 | DMA4 is highest nibble of DROM address | | DMA3 | 1BH | R/W | XXXX | DMA3.3 | DMA3.2 | DMA3.1 | DMA3.0 | | | DMDL | 1CH | R/W | XXXX | DMDL.3 | DMDL.2 | DMDL.1 | DMDL.0 | Low nibble of DROM data read from this address. | | DIVIDL | | | | | | | | Write this register means DMA add one. | | DMDH | 1DH | R/W | XXXX | DMDH.3 | DMDH.2 | DMDH.1 | DMDH.0 | High nibble of DROM data read from this address | | DMA4 | 1EH | R/W | XX | - | - | - | DMA4.0 | DMA4 is highest nibble of DROM address | | | | | | | | | | DMA4[3:1] is not implemented. | Table 11. SFRs about DROM **Extended Common registers:** | Extended Confinion registers: | | | | | | | | | |-------------------------------|-----|-----|------|------|------|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WFLASHEN | 0ВН | R/W | 0000 | WDEN | EDEN | 0 | 0 | WDEN: 0: Don't care. Auto cleared by hardware. 1: Flash DROM writing start. EDEN: 0: Don't care. Auto cleared by hardware. 1: Flash DROM erasing start. | | WEDROMCTL | осн | R/W | 0000 | 0 | 0 | INT3EN | INT3FG | INT3EN: 0: Write or Erase DROM int. disabled. 1: Write or Erase DROM int. enabled. INT3FG: 0: No erasing or writing DROM has been finished. 1: It will be set high after erasing or writing DROM has been finished. | Table 12. Flash DROM operation register ### Reading Data from the Flash DROM DROM is addressed by five registers DMA4, DMA3, DMA2, DMA1 and DMA0. After these registers are specified by software, the data can be read from DMDL and DMDH register. #### Writing Data to the Flash DROM Figure 3. Write Flash DATA DROM block diagram #### Notice: # When erasing or writing Flash DROM, the DROM address assigned by DMA4~DMA0 registers must be legal address. Otherwise, PROM data may be corrupted. The width of Flash DROM is 8 bits, but it's really implement by 16 bit width. So, to write two bytes data(16 bits) to Flash DROM in one time is must. A 16-bit Write Buffer is used to store these two bytes data temporarily and it can be stored by writing data to DMDH and DMDL twice. Single byte write isn't supported on this device. Note that writing the 16 bit Writer Buffer must follow the sequence of writing DMDH first, and then DMDL, DMDH and DMDL register. It's not recommended to change the DMDH and DMDL writing sequence mention above. The DROM's address (DMA4~DMA0) have a hardware adder to mange it, and it will increase by one after writing DMDL register automatically. Base on physically Flash DROM structure, to initial a write cycle the address of DROM should be an even number. The Flash DROM address of the data to be written must first be placed in the DMA4~DMA0 registers, DMDH and DMDL registers. To write data to the Flash DROM, the write enable bit WDEN must be set to high to enable the write function. The WDEN register will be cleared to low after set high automatically by hardware. Writing cycle takes about Twr (47us)time to write a data to DROM after WDEN set high, the INT3FG flag will be set high after writing cycle finished. During writing cycle, MCU will not execute any instruction until INT3FG set high. Programmer must clear INT3FG to "0" before next erasing or writing. The WDEN set high is not allowed by hardware when INT3FG keeps high. #### Flash DROM structure | . 10011 2 1 1 0 111 0 1 | BI (CW strattare | | | | | | | | |-------------------------|------------------|----------------|------------------------|--|--|--|--|--| | Sector | DMA4~DM | A0 Address | R/W function | | | | | | | Sector 0 | 0x00001(8 bit) | 0x00000(8bit) | | | | | | | | (512 bytes) | i | .: | | | | | | | | (STZ Dytes) | 0x001FF(8 bit) | 0x001FE(8 bit) | | | | | | | | Costor 1 | 0x00201(8 bit) | 0x00200(8 bit) | | | | | | | | Sector 1<br>(512 bytes) | | | Erasable/Writable | | | | | | | (STZ Dytes) | 0x003FF | 0x003FE | by application program | | | | | | | | | ••• | | | | | | | | | | | | | | | | | | Sector 248 | 0x1EE01 | 0x1EE00 | | | | | | | | (512 bytes) | ••• | ••• | | | | | | | | (312 Dytes) | 0x1EFFF | 0x1EFFE | | | | | | | Table 13. Memory Map of DROM E-mail: Sales@ChipSourceTek.com Tony.Wang@ChipSourceTek.com For example, write Data to DROM Address 0x01000 ~0x01001 ``` A, #0H LD LD (DMA4), A A, #0H LD LD (DMA3), A LD A, #FH LD (DMA2), A LD A, #FH LD (DMA1), A LD A, #EH // set DMA address 0x00FFE LD (DMA0), A LDPCH WRITE DROM CALL WRITE_DROM WRITE DROM: LD A. (20H) // store high nibble to reg. for 0x01000 (DMDH), A LD LD A, (21H) LD (DMDL), A // store low nibble to reg. for 0x01000, then DMA+1, DMA = 0x00FFF A, (22H) LD LD (DMDH), A // store high nibble to reg. for 0x01001 LD A, (23H) LD (DMDL), A // store low nibble to reg. for 0x01001, then DMA+1, DMA = 0x01000 LD A, #0000B EXIO(WEDROMFG), A LD LD A, #1000B LD EXIO(WEDROMEN), A // write Data from reg. to FLASH, DMA = 0x01001 and 0x01000 WRFG_LOOP: LD A, EXIO(WEDROMEN) AND A, #1000B CMP A, #1000B JΖ WRFG LOOP LD A, EXIO(WEDROMFG) AND A, #0001B CMP A, #0001B JNZ WRFG LOOP RETS ``` #### **Erasing Data on the Flash DROM** Flash DROM Data can be erased by user program on a sector-by-sector basis. The sector architecture is based on sector size of 512 Bytes. There is only one the necessary sector will be erased, and the sector is assigned by DMA4~DMA0 register. The Flash DROM address of the data to be erased must first be placed in the DMA4~DMA0 registers. To erase data on the Flash DROM, the erase enable bit EDEN must be set to high to enable the erase function. The EDEN register will be cleared to low after set high automatically by hardware. Easing cycle takes about Ter (3ms) time to erase a sector on DROM after EDEN set high, the INT3FG flag will be set high after erasing cycle finished. During erasing cycle, MCU will not execute any instruction until E-mail: Sales@ChipSourceTek.com Tony.Wang@ChipSourceTek.com INT3FG set high. Programmer must clear INT3FG to "0" before next erasing or writing. The EDEN set high is not allowed by hardware when INT3FG keeps high. ``` For example, Erase DROM Address 0x01000 ~0x011ff LD A, #0H LD (DMA4), A LD A, #1H LD (DMA3), A LD A, #0H LD (DMA2), A LD A, #0H LD (DMA1), A LD A, #0H LD (DMA0), A // set DMA address 0x01000 LDPCH ERASE DROM CALL ERASE DROM . . . . ERASE DROM: LD A, #0000B LD EXIO(WEDROMFG), A LD A, #0100B LD EXIO(WEDROMEN), A ERFG LOOP: A, EXIO(WEDROMEN) LD A, #0100B AND CMP A, #0100B JΖ ERFG LOOP A, EXIO(WEDROMFG) LD AND A, #0001B CMP A, #0001B JNZ ERFG_LOOP RETS ``` #### 5.3 SRAM and Special Function Register There are two kinds of SRAM addressing mode, describe below: #### 1. Direct addressing mode: There are 512 nibbles SRAM in this chip. The SRAM and I/O memory map is divided into several pages by setting MAH register (3 bits wide). The initial value of MAH is unknown and must be defined by instruction "LDMAH" before you utilize SRAM. The extra 2 SRAM nibbles in the specifications and hardware manuals of relative mask ROM products are not SRAM in fact. They are USER1 and USER2 of SFRs. | Direct Addre | ssing | SRAM MAP | |--------------|---------|-----------------------------------------| | MAH=XH | 00H~1FH | SFR(special function register) register | | MAH=0H | 20H~3FH | | | MAH=1H | 20H~3FH | USER SRAM | | ~ | 20H~3FH | USER SRAW | | MAH=15H | 20H~3FH | | Table 14. Memory Map of SFRs The first 32-nibble, $00H \sim 1FH$ , are defined as a common block. Some I/O and user register is arranged in this common block for easy data operations. The other regions, $20H\sim3FH$ , are employed as SRAM. The user must notice that the initial content of SRAM is unknown. #### 2. Index addressing mode: In this mode, the IXAN2, IXAN1 and IXAN0 use 2-bit, 4-bit and 4-bit registers, respectively. A 10-bit register pair IXA = (IXAN2, IXAN1, IXAN0) constructs the indirect SRAM addressing pointer, and can access the whole SRAM address (00H ~ 3FFH) without using MAH. In addition, the IXA register also provide the auto-post-increment function. These registers are shown in below: SFRs for Interrupt control: | Symbol | Addr | R/W | Reset | D3 | D2 | D1 | D0 | Description | |--------|------|-----|-------|--------|--------|--------|--------|-----------------------------| | IXA | 15H | R/W | XXXX | IXA_3 | IXA_2 | IXA_1 | IXA_0 | Read SRAM | | IXA++ | 16H | R/W | XXXX | IXA++3 | IXA++2 | IXA++1 | IXA++0 | Read SRAM and ADR = ADR + 1 | #### EXIO reg. for Interrupt control: | IXAN0 | 16H | R/W | XXXX | IXA3 | IXA2 | IXA1 | IXA0 | IXA.N0 is SRAM Index Register | |-------|-----|-----|------|------|------|------|------|-------------------------------| | IXAN1 | 17H | R/W | XXXX | IXA7 | IXA6 | IXA5 | IXA4 | IXA.N1 is SRAM Index Register | | IXAN2 | 1FH | R/W | XXXX | 0 | 0 | IXA9 | IXA8 | IXA.N2 is SRAM Index Register | Table 15. Registers of IXA The SRAM related instructions are described as follows: - (2a) LD IXANx, A: The 1st(low, x=0), 2nd and 3rd(high, x=2) nibble of IXA register can be individually specified by A register, where $x=0\sim 2$ indicates the nibble position of IXA register. - (2b) LD A, IXANx: This instruction can individually read the 1st, 2nd and 3rd nibble of IXA register to A register. - (2c) "ALU\_OP A, (IXA)", "OP (IXA)", "SET #D,(IXA)", "CLR #D,(IXA)", "LD A, (IXA)" or "LD (IXA), A": When access this IXA register, SRAM that pointed by IXA will be read or written. The ALU\_OP represents ADC, SBC, CMP, OR, AND and XOR instructions. The OP represents INC, DEC and ADR instructions. - 52#6"ALU\_OP A, (IXA++)", "OP (IXA++)", "SET #D,(IXA++)", "CLR #D,(IXA++)", "LD A, (IXA++)" or "LD (IXA++), A": When access this IXA++ register, SRAM that pointed by IXA will be read or written, and IXA will be incremented by one (auto-post-increment). The ALU\_OP and OP are described as above. For example, assume that C = 1, SRAM (115H) = 2H and SRAM (116H) = 7H. LD A, #1 LD IXAN2, A LD IXAN1, A LD A, #5 LD IXANO, A ; IXA = 115H LD A, (IXA) ; A = SRAM (115H) = 2H ADC A, (IXA++); A = A + SRAM(115H) + C = 5H, and then IXA = IXA + 1 = 116H INC (IXA++); SRAM (116H) = SRAM (116H) + 1 = 8H, IXA = IXA + 1 = 117H E-mail: Sales@ChipSourceTek.com Tony.Wang@ChipSourceTek.com ### 5.3.1 Special Function Registers The special function register consists of common I/O and extended I/O special register. A special function register supports LD/ADC/SBC/OR/AND/XOR/INC/DEC/RLC/RRC/CMP/ADR operation. Bit set/clear can only be operated on the address range from 00H to 0FH, except indirect operation is used. | The following Symbol | | | Reset | D3 | D2 | D1 | D0 | Description | |----------------------|-----|-----|-------|----------|----------|------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | STATUS | 00H | R/W | 00xx | INTRET | PWFG | CF | ZF | Status Register DMA_INTRET: DMA data from Interrupt backup. CF: Carry ZF: Zero PWFG: PWM interrupt flag | | | 01H | | | | | | | Reserved | | IOC_PA | 02H | R/W | 0000 | IOCA3 | IOCA2 | IOCA1 | IOCA0 | "1" = output, "0" = input of related PA bit | | DATA_PA | 03H | R/W | xxxx | DPA3 | DPA2 | DPA1 | DPA0 | Read data from input port and write data to output port | | | 04H | | | | | | | Reserved | | | 05H | | | | | | | Reserved | | | 06H | | | | | $\Lambda J \leq$ | | Reserved | | USER1 | 07H | R/W | XXXX | USER1.3 | USER1.2 | USER1.1 | USER1.0 | General purpose user register | | AUD_DLL | 08H | W | XXXX | AUD_D.3 | AUD_D.2 | AUD_D.1 | AUD_D.0 | AUD_DLL: the bit3~0 of 12 bits PWM. | | PWM_CTRL | 09Н | R/W | X0xx | | DSEN | ENINT | ENPWM | ENPWM: 1: enable PWM 0: disable PWM ENINT: 1: enable Audio interrupt. 0: disable Audio interrupt. DSEN: (W): Deep Sleep Enable. 1: Enable. Store IO function. 0: Disable. (R): Deep Sleep Flag 1: Wake up from Deep Sleep. 0: Wake up from halt or power on. | | AUD_DL | 0AH | W | xxxx | AUD_D.7 | AUD_D.6 | AUD_D.5 | AUD_D.4 | AUD_DL: the bit7~4 of 12 bits PWM | | AUD_DH | 0BH | W | XXXX | AUD_D.11 | AUD_D.10 | AUD_D.9 | AUD_D.8 | AUD_DH: the bit11~8 of 12 bits PWM | | USER2 | 0FH | R/W | xxxx | USER2.3 | USER2.2 | USER2.1 | USER2.0 | General purpose user register | | IADJ | 10H | R/W | 0000 | | 5.3 | ADJ1 | ADJ0 | ADJ[1:0]: Adjust the frequency, when Enable option "OPTADJ". ADJ[1:0] Frequency % 00 -4% 01 -2% 10 2% 11 4% | | BZPWEN | 11H | R/W | 0000 | BZPWEN1 | - | S2S | - | BZPWEN1:PA0 buzzer wakeup and PWMN speaker wakeup control. 1: enable buzzer and speaker wakeup 0: disable buzzer and speaker wakeup S2S: PWM input Data format 1: Inverting Audio Data without sign bit. AUD_D.11 is sign bit. 0: Normal Audio Data format | PWMWKFG:PWMN speaker wakeup flag 1: PWMN speaker wakeup occurred 0: no PWMN speaker wakeup CLAPSEL[1:0]: Sensitivity of Speaker wakeup or Buzzer wakeup. CLAPSEL[1:0] Sensitivity PWMWK 12H R/W 0000 PWMWKFG CLAPSEL1 CLAPSEL0 PWMWKEN Page 14 2\*2)-\*+-22 | | ed X:u<br>Addr | nknov<br>R/W | vn value<br>Reset | e R/W<br>D3 | : readable<br><b>D2</b> | & writeat | | able only W: writeable only Description | |---------------|----------------|--------------|-------------------|-------------|-------------------------|-----------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Symbol<br>MAH | 00H | R/W | 0000 | MAH.3 | MAH.2 | MAH.1 | MAH.0 | SRAM MAH | | WKRTC | 01H | R/W | 0000 | RTCFG | INTVEB | RTCS1 | RTCS0 | RTCFG: HRTC overflow flag 0: HRTC overflow not occurred. 1: HRTC overflow occurred, it could be cleared by software. INTVEB: 0: The Interrupt Vector Keeps last set value, default value 0x008 1: Interrupt Vector will load from PMA3~PMA0 registers RTCS1, RTCS0: HRTC wake up period selection. RTCS1 RTCS0 WKRTC period (±50%) 0 0 16ms 0 1 32ms 1 0 64ms 1 1 128ms | | | 02H~<br>03H | R/W | 0000 | | | X | | Reserved | | LVD_CTL2 | 04H | R/W | 0000 | LVDEN | LVDFG<br>(Read<br>only) | D2ENB | LVDS4 | LVDEN: LVD enable control 1: enabled 0: disabled | | LVD_CTL1 | 05H | w | 0000 | LVDS3 | LVDS2 | LVDS1 | LVDS0 | LVDFG: Low voltage detector flag 0: no low voltage occurred 1: VDD lower than LVD level LVDS[4:0]: LVD level selection D2ENB = '0':Vd = 1.8 + 1.1*(VLVD/31) D2ENB = '1':Vd = 2.7 + 1.7*((VLVD/31) | | | 06H~<br>08H | R/W | 0000 | | | | | Reserved | | TCTRL | 09H | R/W | 0000 | 0 | TCHEN | TCHLS | TCHO<br>(Read only) | TOUCHEN: '1' = Touch function Enable. '0' = Touch function Disable. TCHLS: Touch Level Select '1' = 1.7 v '0' = 0.87 v TOUCHO: Touch CMP output | | TCSEL | OAH | R/W | 0000 | 0 | TCHSEL2 | TCHSEL1 | TCHSEL0 | Touch PAD Select Table TCHSEL[2:0] PAD Selection 000 - 001 - 010 - 011 - 100 PADA0 101 PADA1 110 PADA2 111 PADA3 | | WFLASHEN | ОВН | R/W | 0000 | WDEN | EDEN | 0 | 0 | WDEN: 0: Don't care. Auto cleared by hardware. 1: Flash DROM writing start. EDEN: 0: Don't care. Auto cleared by hardware. 1: Flash DROM erasing start. | | WEDROMCTL | 0CH | R/W | 0000 | 0 | 0 | INT3EN | INT3FG | INT3EN: 0: Write or Erase DROM int. disabled. 1: Write or Erase DROM int. enabled. INT3FG: 0: No erasing or writing DROM has been finished. 1: It will be set high after erasing or writing DROM has been finished. | | | 0DH | R/W | 0000 | | | | | Reserved | |------------|--------|---------------|------|------------|------------|------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | HUU | H/VV | 0000 | | | | | | | MUL_AL | 0EH | R/W | xxxx | MAI3<br>P3 | MAI2<br>P2 | MAI1<br>P1 | MAI0<br>P0 | 12 x8 bits Multiplication registers Multiplier is 12 bits MAI11~MAI0 Multiplicand is 8 bits MBI7~MBI0 Multiplication product is 20 bits P19~P0 W: multiplier low nibble MAI3~MAI0 R: multiplication product P3~P0 | | MUL_AM | 0FH | R/W | xxxx | MAI7 | MAI6 | MAI5 | MAI4 | W : multiplier middle nibble | | IVIOL_AIVI | 0111 | Π/ <b>V V</b> | *** | P7 | P6 | P5 | P4 | R: multiplication product P7~P4 | | MUL_BL | 11H | R/W | xxxx | MBI3 | MBI2 | MBI1 | MBI0 | W :12 bits multiplicand low nibble | | WOL_BL | 1 1111 | 11/ / / | **** | P15 | P14 | P13 | P12 | R: multiplication product P15~P12 | | MUL_BH | 12H | R/W | xxxx | MBI7 | MBI6 | MBI5 | MBI4 | W :12 bits multiplicand middle nibble | | oL_B. | 1211 | 10,00 | ХХХХ | P19 | P18 | P17 | P16 | R : multiplication product P19~P16 | | SATV | 13H | R/W | xxxx | SATV.3 | SATV.2 | SATV.1 | SATV.0 | SATV register is used to shape PWM data, input format is 16 bit and output is 12 bit. Writing SATV register four times configure 16-bit SATV input data, and reading SATV 12 bit data by three times. | | | 14H | | | | | | | | | | 15H | | | | | | | | | IXAN0 | 16H | R/W | XXXX | IXA3 | IXA2 | IXA1 | IXA0 | IXA.N0 is SRAM Index Register | | IXAN1 | 17H | R/W | XXXX | IXA7 | IXA6 | IXA5 | IXA4 | IXA.N1 is SRAM Index Register | | PMA0 | 18H | R/W | XXXX | PMA0.3 | PMA0.2 | PMA0.1 | PMA0.0 | PMA0~3 four registers built a 14 bit | | PMA1 | 19H | R/W | XXXX | PMA1.3 | PMA1.2 | PMA1.1 | PMA1.0 | address for read PROM 12 bits data, | | PMA2 | 1AH | R/W | XXXX | PMA2.3 | PMA2.2 | PMA2.1 | PMA2.0 | PMA0 is lowest nibble, PMA3 is highest | | PMA3 | 1BH | R/W | 000x | 0 | 0 | PMA3.1 | PMA3.0 | nibble of PROM address | | PMDL | 1CH | Rbi | | | | | | | Page 16 2\*2)-\*+-22 Ve1./o! ).2 | PWMWKS | 13H | R/W | 0001 | PWMWKS | BZPWEN2 | DETEN | GINTEN: 1: Global interrupt enable. | |--------|-----|-----|------|--------|---------|-------|-------------------------------------| | | | | | | | | 0: Global interrupt disable. | #### EXIO reg. for Interrupt control: | Symbol | Addr | R/W | Reset | D3 | D2 | D1 | D0 | Description | |--------|------|-----|-------|-------|--------|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WKRTC | 01H | R/W | 0000 | RTCFG | INTVEB | RTCS1 | RTCS0 | INTVEB: 0: Interrupt Vector keeps last value from PMA, or default value is 0x008 if INTVEB never set high after power up. 1: Interrupt Vector will load from PMA3~ PMA0 registers | | | 14H | R/W | | | | | | XX | Table 19: Interrupt control registers There are two interrupt control register GINTEN and INTEN must be set high before using PWM interrupt. If an interrupt request (PWFG=1) occurred, then interrupt will be accepted on next clock. On that instant, current (next) program counter, PCDH, MAH and C/Z will be stored in special hardware registers, and program counter will be loaded with entry address of that interrupt. All these are done in one clock. Interrupt enable bit will be cleared too. As long as program enters interrupt service, interrupt enable bit is cleared. It's no need to clear interrupt enable flag in interrupt routine. But hardware will not clear interrupt request flag (PWFG). Software is required to clear it. When interrupt service routine is done, an RETI shall be executed. This instruction will restore stored program counter, PCDH, MAH and C/Z, will set interrupt enable bit=1 also. (Note that RETI is different from RETS.) Interrupt request can be accepted only when enable bit be set. Note that only one level of INT routine can be used. The interrupt vector can be customized by programmers. To enable this function, programmer should place the new vector to PAM3~PAM0 registers and set INTVEB to high then cleared to low before enabling interrupt. Customized interrupt vector operating procedure as shown below: - 1. Assign new interrupt vector to PMA3~PMA0 registers. - 2. Set INTVEB to high means to store PMAx registers to Interrupt Vector register. - Clear INTVEB to low means to release PMAx registers and PMAx registers are available for another function. - 4. To enable interrupt Customized interrupt vector example program LD A, #INV\_EXP.N3 LD EXIO(PMA3), A LD A, #INV EXP.N2 LD EXIO(PMA2), A LD A, #INV EXP.N1 EXIO(PMA1), A LD A, #INV EXP.N0 LD LD EXIO(PMA0), A // Set PMA = 0x0123 LD A, EXIO(WKRTC) OR A, #0100B // Setting Interrupt Vector to address 0x0123 LD EXIO(WKRTC), A AND A, #1011B LD EXIO(WKRTC), A // Keep last value from PMA, Interrupt Vector is address 0x0123 ORG 0X0123 INV\_EXP: ### 5.6 Operation Mode There are two operation modes in this chip. The state diagram of three MCU operation modes is shown below. - 1. NORMAL Mode: In normal mode, system clock oscillator is running, and MCU clock source is come from main oscillator. In NORMAL mode, MCU will go to halt mode after HALT instruction executed. - **2. HALT Mode Mode**: In HALT mode, the MCU clock stops, users can't change the operation mode when in halt mode. It will go back to NORMAL mode (Program counter=004) when I/O wakeup or reset occurred. Please refer to the section of" Halt Mode & Wake up" for the detailed HALT mode description. Figure 4. Operation Mode #### 5.6.1 Deep Sleep Mode In Deep Sleep Mode, the IC will cut off power except I/O wakeup function, so user must backup data to DROM by user code before into Deep Sleep mode. Users can't change the operation mode when in Deep Sleep mode. When "DEEP\_SIG" be set: - 1. I/O status cannot be changed. - 2. I/O step will remain ready to enter Deep Sleep mode. When "DEEP\_SIG" be clear: 1. I/O status can be changed after 1ms when clear DEEP\_SIG. User can polling DEEP\_SIG to check it. | PWM_CTRL | 09H I | R/W | X0xx | | DEEP_SIG | ENINT | ENPWM | ENPWM: 1: enable PWM 0: disable PWM ENINT: 1: enable Audio interrupt. 0: disable Audio interrupt. DEEP_SIG: DEEP Signal 0: Wakeup from Halt mode or power on. 1: Wakeup from Deep sleep. | |----------|-------|-----|------|--|----------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| |----------|-------|-----|------|--|----------|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| #### 5.7 Halt Mode & Wake up After the system enters the HALT mode it can be woken up from one of various source listed as below: - (1) An external I/O pin rising edge. - (2) A HRTC overflow - (3) A RC wakeup - (4) A buzzer wakeup - (5) A speaker wakeup The MCU will go into HALT mode (program counter and system clock stop) when HALT instruction executed. It provides a power saving mode for those applications requiring a very low stand-by current. #### 5.7.1 I/O wake up Each pin on PA[3:0] or PE[3:0] can be setup using the correspond option(WAKEUPBA3~0, WAKEUPBE3~0) to permit positive transition on the pin to wake up the system. The program counter will be 08H when HALT instruction executed immediately, then program counter will go to next address after 64 stable clock(system because reset is first priority when in HALT mode, so program counter will from 04h to 00h, program counter goes to next address after 64 stable clock cycles. Furthermore, the SRAM will keep their previous data without changing in this mode. ### 5.7.2 HRTC(HALT mode RTC) wake up HALT mode RTC (HRTC) works on HALT mode only if RTC\_EN option is enabled. The HRTC period has four kinds of period shown as below. BTCFG register set high indicates HRTC wake up occurred. | i <u>oai itiilao</u> | <u> </u> | onioa oni | O *** : : C | AC DOION | <u> </u> | a regiotei | oot mgm | maioatoo m | itte wate ap eccarroa. | |----------------------|----------|-----------|-------------|----------|----------|------------|---------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------| | WKRTC | | 01H | R/W | 0000 | RTCFG | INTVEB | RTCS1 | | RTCS1, RTCS0: HRTC wake up period selection. RTCFG: WKRTC overflow flag 0: HRTC overflow not occurred. 1:HRTC overflow occurred, it could be cleared by software. | Table 20. HRTC control register HTRC wake up period selection. | RTCS1 | RTCS0 | HRTC Period<br>(± 50%) | |-------|-------|------------------------| | 0 | 0 | 16ms | | 0 | 1 | 32ms | | 1 | 0 | 64ms | | 1 | 1 | 128ms | Table 21. HTRC wake up period selection ### 5.7.3 Special wakeup ( PA0 RC, PA0 buzzer, PWMN speaker ) There are three wakeup called special wakeup. They are PA0 RC wakeup, PA0 buzzer wakeup and PWMN speaker wakeup. Common I/O register | Symbol | Addr | R/W | Reset | D3 | D2 | D1 | D0 | Description | Description | | | | |--------|------|-----|-------|------------------------|----------|----------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|--|--|--| | BZPWEN | 11H | R/W | 0000 | BZPWEN1 | - | | | BZPWEN1:PA0 buzzer wakeup and<br>PWMN speaker wakeup control<br>1: enable buzzer and speaker wakeup<br>0: disable buzzer and speaker wakeup | | | | | | PWMWK | 12H | R/W | 0000 | PWMWKFG | CLAPSEL1 | CLAPSEL0 | PWMWKEN | PWMWKFG:PWMN speaker wakeup flag 1: PWMN speaker wakeup occurred 0: no PWMN speaker wakeup CLAPSEL[1:0]: Sensitivity of Speaker wakeup or Buzzer wakeup. CLAPSEL[1:0] Sensitivity 00 level1(high sen.) 01 level 2 10 level 3 11 level 4 PWMWKEN: PWMN speaker wakeup control 1: enable 0: disable | | | | | | PWMWKS | 13H | R/W | 0001 | PWMWKS<br>( read only) | BZPWEN2 | DETEN | GINTEN | PWMWKS: Read external PWMN pin status to confirm PWMN wakeup signal. BZPWEN2: PA0 buzzer wakeup and PWMN speaker wakeup control 1: enable buzzer and speaker wakeup 0: disable buzzer and speaker wakeup | | | | | Table 22 Special wakeup control registers #### PA0 RC wakeup It provides a PA0 RC wakeup function.PA0 supports an analog input buffer with schmitt input circuit, it is enabled by RCWK option and supports low power consumption in halt mode, if PA0 analog signal keep about 0.5VCC, so this function is suitable for recycle wakeup MCU by external RC time constant, external RC time constant is easy built by VCC connected to R and serial with C to VSS. The block diagram and electrical characteristic of PA0 analog input buffer shown below. It takes about 5uA when PA0 input signal is 2.5v @VCC=5V in halt mode, otherwise, it takes about 500uA current if RCWK option is disabled. This block function is enabled when RCWK option enabled and set IOC\_PA=0000B by hardware after power on reset. Figure 5. PA0 RC wakeup block diagram Figure 6. PA0 input signal and PA0 register data ### PA0 buzzer wakeup Figure 7. PA0 buzzer wake up block diagram TEL: +86-0755-27595155 27595165 FAX: +86-0755-27594792 WEB:Http://www.ChipSourceTek.com F-mail: Sales@ChipSourceTek.com MCU can be wakeup by a small signal on PA0 PIN which connected a buzzer to VSS. It built-in an OP amplifier for wakeup trigger, the pull down 1M and 50k resistor will be disabled by hardware circuit when "BZWK" option is enabled automatically. To enable this function, please set BZPWEN1 and BZPWEN2 to "1" and set BZWK option enabled on IDE tool. PA0 Buzzer wakeup control register and Option | BZWK Option | BZPWEN1 | BZPWEN2 | PA0 buzzer wakeup function | |-------------|---------|----------|----------------------------| | 0 | 0 | 0 | Disabled | | 1 | 1 | 1 | Enabled | | | Others | Disabled | | Table 23. PA0 Buzzer wakeup control There are 4 sensitivity level for speaker wakeup and buzzer wakeup control. Sensitivity selection CLAPSEL[1:0] | Sensitivity 00 | PWMWKEN | BZPWEN1 | BZPWEN2 | Speaker wake up function | |---------|---------|----------|--------------------------| | 0 | 0 | 0 | Disabled | | 1 | 1 | 1 | Enabled | | | Others | Disabled | | Table 25. PWM wakeup control PWMN speaker wakeup example program LD A, #0001B LD (PWMWK), A ; assign PWMWKEN=1 and sensitivity level CLAPSEL[1:0] = 00 LD À, #1000B LD (BZPWEN), A ; assign BZPWEN1 =1 LD A, #0101B LD (PWMWKS), A ; assign BZPWEN2 = 1 ... **HALT** ### 5.8 Watch Dog Timer Reset (WDT) The watch dog timer (WDT) is used to reset whole chip when detect unexpected execution sequence caused by accident condition, avoiding dead lock of MCU program. WDT will be reset when wake-up from halt, after reset or software clears it. The watch dog timer is a simple counter. WDT period is about 0.13 sec. (Clock source by LRCOSC = $32.000K Hz \pm 50\%$ ) Software must run a "clear watch dog timer" (write to WDT) instruction before this timer time out when WDT enabled. It will generate a reset signal to reset whole system when WDT over flow. Assembler will check user program about the "reset watch dog" instructions. If more than one "reset watch dog" is found in program, assembler will generate a warning (program code will still be generated). "HALT" instruction will reset watch dog timer. The reset watch dog timer sequence is strongly recommended as: WATCHDOG: LD (17H), A LDPCH WATCHDOG LDMAH#n #### 5.9 8/10/12 bits PWM One is 8 bit output, the sec. is 10 bit output, and Page 22 2\*2)-\*+-22 Ve1./o! ).2 Writing SATV register four times configure 16-bit SATV input data, and reading SATV 12 bit data by reading SATV register three times. #### Common I/O | Symbol | Addr | R/W | Reset | D3 | D2 | D1 | D0 | Description | |----------|------|-----|-------|----------|----------|---------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | STATUS | 00H | R/W | 00xx | INTRET | PWFG | CF | ZF | PWFG: PWM interrupt flag | | AUD_DLL | 08H | W | XXXX | AUD_D.3 | AUD_D.2 | AUD_D.1 | AUD_D.0 | AUD_DLL: the bit3~0 of 12 bits PWM. | | PWM_CTRL | 09H | R/W | xxxx | | | ENINT | ENPWM | ENPWM: 1: enable PWM 0: disable PWM ENINT: 1: enable Audio interrupt. 0: disable Audio interrupt. | | AUD_DL | 0AH | W | XXXX | AUD_D.7 | AUD_D.6 | AUD_D.5 | AUD_D.4 | AUD_DL: the bit7~4 of 12 bits PWM | | AUD_DH | 0BH | W | XXXX | AUD_D.11 | AUD_D.10 | AUD_D.9 | AUD_D.8 | AUD_DH: the bit11~8 of 12 bits PWM | | BZPWEN | 11H | W/R | 0000 | BZPWEN1 | / | \$2\$ | X | BZPWEN1:PA0 buzzer wakeup and PWMN speaker wakeup control. 1: enable buzzer and speaker wakeup 0: disable buzzer and speaker wakeup S2S: PWM input Data format 1: Inverting Audio Data without sign bit. AUD_D.11 is sign bit. 0: Normal Audio Data format. | #### Extended IO | Symbol | Addr | R/W | Reset | D3 | D2 | D1 | D0 | Description | |--------|------|-----|-------|--------|--------|--------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SATV | 13H | R/W | xxxx | SATV.3 | SATV.2 | SATV.1 | SATV.0 | SATV register is used to shape PWM data, input format is 16 bit and output is 12 bit. Writing SATV register four times configure 16-bit SATV input data, and reading SATV 12 bit data by three times. | Table 26. PWM control registers When an interrupt request happened, PWM interrupt flag bit PWFG of STATUS register will be "1". The PWM will load previously-written-data into actual conversion port on end of a PWM code output. So program can write data into PWM data store safely at beginning of an interrupt service routine. (A PWM interrupt means PWM data loaded, next data is expected). This timing shall be controlled carefully such that data writing in the beginning of interrupt service routine is safe. If data is not changed during a conversion, previous data will be used. This PWM output can drive 8 ohm speaker. PWM can be enabled or disabled by setting/clearing ENPWM of PWM\_CTRL. When disabled, the PWMP, PWMN pins are all '0'. "HALT" instruction will disable PWM (clear ENPWM of PWM CTRL) and the PWMP and PWMN pins will be tri-state. #### 5.10 Reset Figure 10. Reset structure The system reset comes from three signals which are power on reset, low voltage reset(LVR), external RESETB pin and WDT overflow reset. For normal operation of this chip, a good reset is needed. The operation frequency of MCU will go back to NORMAL mode when reset occurred in HALT mode. #### 5.11 System Clock Oscillator This chip MCU is typically operated on 13.1072MHz which is generated from internal RC oscillator 65.536MHz. #### 5.12 I/O Ports There is one I/O port, PA0~PA3, whose input/output direction are defined by IOC\_PA. The wake-up functions of PA0~PA3 are enabled or disabled by option. Their 1M/50k pull down resistors are optional. In order to achieve touch function, TRSF4A0XXA/B series support 220k pull down resistors. These resistors can be enabled by using 50k pull down resistor registers after "PD220K" is enabled. The 220K resistance value is almost fixed value when VCC change from 2.4V to 5.5V. All I/O ports provides rising or falling edge wake up function. This double edge wake up function can be enabled by "BIWK" option. #### 5.12.1 Port PA (input/output) The Port A are 4-bit bidirectional I/O ports. Their directions can be defined by IOC\_PA bit by bit. The following table describe the SFRs associated with Port A. | Symbol | Addr | R/W | Reset D3 | D2 | D1 | D0 | Description | |--------|------|-----|----------|----|----|----|-------------| | IOC_PA | 02H | R/W | 0000 | | | | | Page 24 2\*2)-\*+-22 pointer. X indirect pointer combines with PMA3~PAM0 registers, PMA3 is high nibble and PMA0 is low nibble. The JMPX instruction procedure as shown below: - 1. Select a X indirect pointer and assign PMA3~ PMA0 registers. - 2. Decide a physical address 13 bit (A12~A0) you want to jump. - 3. Assign MSB(A12) of physical address by load LDPCH to accumulator. - Assign physical address (A11~A0) 12 bits to PROM by PDW instruction, and this address is pointed by PMA3~PMA0. - 5. Jump to the physical address by JMPX instruction. The following example shows how to use JMPX instruction. Assume program needs jump to physical address 0700h by JMPX instruction. X indirect pointer is assigned in \$0F80h. So the content of \$0F80h is 700h. Due to physical address MSB is "0", so the label LDPCH to load must be located at the lower 4 K address in PROM. LD A.#0h ; assign X indirect pointer address LD (PMA0),A LD A,#8h LD (PMA1),A LD A,#Fh LD (PMA2),A LD A.#0h LD (PMA3),A **LDPCH** MSB 0 ; Assign MSB of physical address to "0", MSB(A12)=0 **JMPX** ; Jump to address \$700h **ORG 0700H** ; Assign MSB of physical address to "1", MSB(A12)=1 LDPCH MSB\_1 **JMPX** Jump to address \$1700h **ORG 1700H** LD A, #0H **ORG 0123H** ; the lower 4 K address in PROM for MSB(A12) set to "1" MSB 0: **ORG 1123H** MSB\_1: ; the upper 4 K address in PROM for MSB(A12) set to "0" ; X indirect pointer address ORG 0F80H PDW 700H ; Assign lower physical address 12 bits (A11~A0) ### 5.13.2 Direct Jump Instruction (JMPPMA) JMPPMA instruction provides a direct jump to the physical address. The physical address 13 bits consists of PMA3~PAM0 registers. The JMPPMA instruction procedure as shown below: E-mail: Sales@ChipSourceTek.com Tony.Wang@ChipSourceTek.com LDPCH MSB\_1 ; Assign MSB of physical address to "1", MSB(A12)=1 CALLX ; Call to address \$1600h **ORG 0600H** • • • RETS ; CALL RETRUN **ORG 1600H** • • • RETS ; CALL RETRUN ORG 0123H MSB 0: ; the lower 4 K address in PROM for MSB(A12) set to "1" • • • • ORG 1123H MSB\_1: ; the upper 4 K address in PROM for MSB(A12) set to "0" • • • • • ORG 0ABCH ; X indirect pointer address PDW 600H ; Assign lower physical address 12 bits (A11~A0) = 600h ### 5.13.4 Direct call Instruction (CALLPMA) CALLPMA instruction provides a direct CALL to the physical address. The physical address 13 bits consists of PMA3 ~ PAM0 registers. The CALLPMA instruction procedure as shown below: 1. Decide a absolute address you need to jump and assign PMA3~ PMA0 registers . 2. CALL to the absolute address by CALLPMA instruction. The following example shows how to use CALLPMA instruction. LD A.#Eh ; assign call address LD (PMA0),A LD A,#Dh LD (PMA1),A LD A,#Ch LD (PMA2),A LD A,#0h LD (PMA3),A CALLPMA ; call TABLE\_Y , address \$0CDEh LD (BMA2) LD (PMA3),A CALLPMA ; call TABLE\_Y1, address \$1CDEh • • • ORG 0CDEH TABLE Y: E-mail: Sales@ChipSourceTek.com Tony.Wang@ChipSourceTek.com **RETS** ; CALL RETRUN **ORG 1CDEH** TABLE\_Y1: **RETS** ; CALL RETRUN ### 5.14 12Bit X 8Bit Multiplier (signed x unsigned) An 12 bit x 8 bit (signed x unsigned) multiplier is provided for data processing. This multiplier contains 5 nibble registers, two nibble MUL\_AL and MUL\_AH are for input A register, three nibbles MUL\_BL, MUL\_BM and MUL\_BH are for input B register. The product is a 20 bits data stored in P19 ~ P0. This multiplication starts as long as high nibble(MUL BH) of B is stored. Note that the content of A and B registers will be destroyed during multiplication procedure. | Symbol | Addr. | R/W | Reset | D3 | D2 | D1 | D0 | Description | |--------|-------|-----|-------|--------------|--------------|-------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | MUL_AL | 0EH | R/W | xxxx | MAI3<br>P3 | MAI2<br>P2 | MAI1<br>P1 | MAI0<br>P0 | 12 x8 bits Multiplication registers Multiplier is 12 bits MAI11~MAI0 Multiplicand is 8 bits MBI7~MBI0 Multiplication product is 20 bits P19~P0 W: multiplier low nibble MAI3~MAI0 R: multiplication product P3~P0 | | MUL_AM | 0FH | R/W | xxxx | MAI7<br>P7 | MAI6<br>P6 | MAI5<br>P5 | MAI4<br>P4 | W : multiplier middle nibble R : multiplication product P7~P4 | | MUL_AH | 10H | R/W | xxxx | MAI11<br>P11 | MAI10<br>P10 | MAI9<br>P9 | MAI8<br>P8 | W: multiplier high nibble R: multiplication product P11~P8 Multiplication will go start after write data to MUL_AH register automatically | | MUL_BL | 11H | R/W | xxxx | MBI3<br>P15 | MBI2<br>P14 | MBI1<br>P13 | MBI0<br>P12 | W :12 bits multiplicand low nibble R : multiplication product P15~P12 | | MUL_BH | 12H | R/W | xxxx | MBI7<br>P19 | MBI6<br>P18 | MBI5<br>P17 | MBI4<br>P16 | W :12 bits multiplicand middle nibble R : multiplication product P19~P16 | Table 28. SFR of Multiplier ## 6. TRSF4A0XXA/B The Application Circuit Note: Substrate must be connected to VSS Figure 11. SOP8 Application #### Notice: 1. C1:10 uF ~ 100 uF(depends on applications), C2: 0.1 uF (high ESD protection). TEL: +86-0755-27595155 27595165 FAX: +86-0755-27594792 WEB:Http://www.ChipSourceTek.com E-mail: Sales@ChipSourceTek.com Tony.Wang@ChipSourceTek.com ## 7. TRSF4A0XXA/B Package Information ### 7.1 SOP8 ## 8. TRSF4A0XXA/B Option Registers table | Option Name | Function Description | | | | | |------------------------|------------------------------------------------------------|--|--|--|--| | PROM2K | PROM size selection 2K | | | | | | PROM4K | PROM size selection 4K | | | | | | PROM6K | PROM size selection 6K | | | | | | PROM8K | PROM size selection 8K | | | | | | RCWK | PA0 RC wakeup function. | | | | | | BZWK | Buzzer wakeup function. | | | | | | WAKEBA | Wake-up enable for PA3~PA0 respectively. | | | | | | | double edge wake up function | | | | | | BIWK (TRSF4A0XXB only) | Enable = double edge | | | | | | DD 501/DA | Disable = rising edge | | | | | | PD50KPA | 50K Ohm pull down resistor for PA3~PA0 respectively. | | | | | | PD1MPA | 1M Ohm pull down resistor for PA3~PA0 respectively. | | | | | | PD220K | Change 50K Ohm pull down resistor to 220K Ohm | | | | | | | Enable=220K Ohm, Disable=50K Ohm. | | | | | | WDGENB | Watch dog timer function. | | | | | | WDHEN | Watch dog timer in halt mode function. | | | | | | OTPLOCK | Security control, Disable = Insecurity, Enable = Security. | | | | | | OPTADJ | OSCADJ select function | | | | | | | Driving capacity of output port, | | | | | | HDEN | Enable = 20mA sink and source capacity. | | | | | | | Disable = 4mA sink and source capacity. | | | | | | | Interrupt mask | | | | | | INTMASK | Enable = Into Interrupt, set ENPWM and ENINT both. | | | | | | | Disable = Into Interrupt, set ENINT only. | | | | | | RTC_EN | Enable RTC in halt mode function | | | | | | F38K | PA3 built-in a 38KHz modulator function | | | | | | OTPREV | Fill the unused PROM with 0xFFF | | | | | | DIMMONICALC | Enable = interrupt period is 64000Hz | | | | | | PWM64K | Disable = interrupt period is 32000Hz | | | | | | DEEPSLEEP | Deep Sleep function. | | | | | Table 29. Option Registers table ## 9. TRSF4A0XXA/B The Revision History | Version | Description | Page | Date | | |---------|-------------------------------------------------------|-------------|------------|--| | 1.0 | Established | | 2021-05-05 | | | 4.4 | Edit voltage range | 1 | 0001 05 01 | | | 1.1 | Edit Table 17 Extended I/O Special Function Registers | 16 | 2021-05-21 | | | | Edit TRSF4A0XXA/B series selection table. | 2 | | | | | Rename Registers Symbol: AUD_DL → AUD_DLL. | 13, 22, 23 | | | | 1.2 | Rename Registers Symbol: AUD_DM → AUD_DL. | 13, 22, 23 | 2021-09-22 | | | 1.2 | Rename Registers Symbol: SYS0 → PWM_CTRL. | 13,16,18,22 | 2021-09-22 | | | | Rename Registers Symbol: WDT → WATCH. | 14 | | | | | Added Option Registers table | 32 | | | Table 29. Revision History