



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

#### Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Obsolete                                                                |
|----------------------------|-------------------------------------------------------------------------|
| Core Processor             | 8032                                                                    |
| Core Size                  | 8-Bit                                                                   |
| Speed                      | 24MHz                                                                   |
| Connectivity               | I <sup>2</sup> C, UART/USART                                            |
| Peripherals                | LVR, POR, PWM, WDT                                                      |
| Number of I/O              | 46                                                                      |
| Program Memory Size        | 288KB (288K x 8)                                                        |
| Program Memory Type        | FLASH                                                                   |
| EEPROM Size                | -                                                                       |
| RAM Size                   | 8K x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V                                                               |
| Data Converters            | A/D 4x8b                                                                |
| Oscillator Type            | Internal                                                                |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                       |
| Mounting Type              | Surface Mount                                                           |
| Package / Case             | 80-LQFP                                                                 |
| Supplier Device Package    | -                                                                       |
| Purchase URL               | https://www.e-xfl.com/product-detail/stmicroelectronics/upsd3234bv-24u6 |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

|    |        | 23.5.2 OMC mask register                    |
|----|--------|---------------------------------------------|
|    |        | 23.5.3 Output enable of the OMC             |
|    | 23.6   | Input macrocells (IMC) 133                  |
| 24 | I/O po | orts (PSD module)                           |
|    | 24.1   | General port architecture 134               |
|    | 24.2   | Port operating modes 135                    |
|    | 24.3   | MCU I/O mode                                |
|    | 24.4   | PLD I/O mode                                |
|    | 24.5   | Address Out mode                            |
|    | 24.6   | Peripheral I/O mode                         |
|    | 24.7   | JTAG in-system programming (ISP) 136        |
|    | 24.8   | Port configuration registers (PCR) 138      |
|    |        | 24.8.1 Control register                     |
|    |        | 24.8.2 Direction register                   |
|    |        | 24.8.3 Drive Select register                |
|    | 24.9   | Port data registers                         |
|    |        | 24.9.1 Data In                              |
|    |        | 24.9.2 Data Out register                    |
|    |        | 24.9.3 Output macrocells (OMC)              |
|    |        | 24.9.4 OMC mask register                    |
|    |        | 24.9.5 Input macrocells (IMC)               |
|    |        | 24.9.6 Enable out                           |
|    | 24.10  | Ports A and B – functionality and structure |
|    | 24.11  | Port C – functionality and structure 141    |
|    | 24.12  | Port D – functionality and structure 142    |
|    | 24.13  | External chip select                        |
| 25 | Powe   | r management                                |
|    | 25.1   | PLD power management 147                    |
|    | 25.2   | PSD chip select input (CSI, PD2) 148        |
|    | 25.3   | Input clock                                 |
|    | 25.4   | Input control signals                       |
| 26 | RESE   | T timing and device status at reset         |



### 2.2.4 Program counter

The Program Counter is a 16-bit wide which consists of two 8-bit registers, PCH and PCL. This counter indicates the address of the next instruction to be executed. In **RESET** state, the program counter has reset routine address (PCH:00h, PCL:00h).

### 2.2.5 Program status word

The Program Status Word (PSW) contains several bits that reflect the current state of the CPU and select Internal RAM (00h to 1Fh: Bank0 to Bank3). The PSW is described in *Figure 8*. It contains the Carry flag, the Auxiliary Carry flag, the Half Carry (for BCD operation), the General Purpose flag, the Register Bank Select flags, the Overflow flag, and Parity flag.

[Carry flag, CY]. This flag stores any carry or not borrow from the ALU of CPU after an arithmetic operation and is also changed by the Shift Instruction or Rotate Instruction.

[Auxiliary Carry flag, AC]. After operation, this flag is set when there is a carry from Bit 3 of ALU or there is no borrow from Bit 4 of ALU.

[Register Bank Select flags, RS0, RS1]. These flags select one of four banks (00~07H:bank0, 08~0Fh:bank1, 10~17h:bank2, 17~1Fh:bank3) in Internal RAM.

[Overflow flag, OV]. This flag is set to '1' when an overflow occurs as the result of an arithmetic operation involving signs. An overflow occurs when the result of an addition or subtraction exceeds +127 (7Fh) or -128 (80h). The CLRV instruction clears the overflow flag. There is no set instruction. When the BIT instruction is executed, Bit 6 of memory is copied to this flag.

[Parity flag, P]. This flag reflects the number of Accumulator's 1. If the number of Accumulator's 1 is odd, P=0; otherwise, P=1. The sum when adding Accumulator's 1 to P is always even.

### 2.2.6 Registers R0~R7

General purpose 8-bit registers that are locked in the lower portion of internal data area.

### 2.2.7 Data pointer register

Data Pointer Register is 16-bit wide which consists of two-8bit registers, DPH and DPL. This register is used as a data pointer for the data transmission with external data memory in the PSD module.



#### Figure 8. PSW (Program Status Word) register

| Byte addr<br>(in hexade | ess<br>ecimal) |    |    |         |           |    |    | Byte<br>(in | address<br>decimal) |
|-------------------------|----------------|----|----|---------|-----------|----|----|-------------|---------------------|
| -                       |                |    |    |         |           |    |    |             | - [                 |
| 22h                     | 17             | 16 | 15 | 14      | 13        | 12 | 11 | 10          | 34                  |
| 21h                     | 0F             | 0E | 0D | 0C      | 0B        | 0A | 09 | 08          | 33                  |
| 20h                     | 07             | 06 | 05 | 04      | 03        | 02 | 01 | 00          | 32                  |
| 1Fh                     |                | •  |    | Degiste | r honk 0  | •  |    |             | 31                  |
| 18h                     |                |    |    | Registe | r Darik 3 |    |    |             | 24                  |
| 17h                     |                |    |    | Degiata | r honk 0  |    |    |             | 23                  |
| 10h                     |                |    |    | negisie | I Dalik 2 |    |    |             | 16                  |
| 0Fh                     |                |    |    | Pogiata | r hank 1  |    |    |             | 15                  |
| 08h                     |                |    |    | Registe | I DANK I  |    |    |             | 8                   |
| 07h                     |                |    |    | Pogiata | r book 0  |    |    |             | 7                   |
| 00h                     |                |    |    | negiste | I Dalik U |    |    |             | 0                   |

### Table 3. RAM address (continued)

### 2.9 Addressing modes

The addressing modes in UPSD323xx devices instruction set are as follows

- 1. Direct addressing
- 2. Indirect addressing
- 3. Register addressing
- 4. Register-specific addressing
- 5. Immediate constants addressing
- 6. Indexed addressing

### 2.9.1 Direct addressing

In a direct addressing the operand is specified by an 8-bit address field in the instruction. Only internal Data RAM and SFRs (80~FFH RAM) can be directly addressed.

Example:

mov A, 3EH ; A <---- RAM[3E]

### Figure 10. Direct addressing



57

Note: In UPSD323xx devices, the stack resides in on-chip RAM, and grows upwards. The PUSH instruction first increments the Stack Pointer (SP), then copies the byte into the stack. PUSH and POP use only direct addressing to identify the byte being saved or restored, but the stack itself is accessed by indirect addressing using the SP register. This means the stack can go into the Upper 128 bytes of RAM, if they are implemented, but not into SFR space.

The Data Transfer instructions include a 16-bit MOV that can be used to initialize the Data Pointer (DPTR) for look-up tables in Program Memory.

The XCH A, <byte> instruction causes the Accumulator and ad-dressed byte to exchange data. The XCHD A, @Ri instruction is similar, but only the low nibbles are involved in the exchange. To see how XCH and XCHD can be used to facilitate data manipulations, consider first the problem of shifting and 8-digit BCD number two digits to the right. *Table 8* shows how this can be done using XCH instructions. To aid in understanding how the code works, the contents of the registers that are holding the BCD number and the content of the Accumulator are shown alongside each instruction to indicate their status after the instruction has been executed.

After the routine has been executed, the Accumulator contains the two digits that were shifted out on the right. Doing the routine with direct MOVs uses 14 code bytes. The same operation with XCHs uses only 9 bytes and executes almost twice as fast. To right-shift by an odd number of digits, a one-digit must be executed. *Table 9* shows a sample of code that will right-shift a BCD number one digit, using the XCHD instruction. Again, the contents of the registers holding the number and of the accumulator are shown alongside each instruction.

| Mnomonio                      | Operation                                   |      | Addressing modes |      |      |  |  |  |  |
|-------------------------------|---------------------------------------------|------|------------------|------|------|--|--|--|--|
| Milenonic                     | Operation                                   | Dir. | Ind.             | Reg. | lmm. |  |  |  |  |
| MOV A, <src></src>            | A = <src></src>                             | Х    | Х                | Х    | Х    |  |  |  |  |
| MOV <dest>,A</dest>           | <dest> = A</dest>                           | Х    | Х                | Х    |      |  |  |  |  |
| MOV <dest>,<src></src></dest> | <dest> = <src></src></dest>                 | Х    | Х                | Х    | Х    |  |  |  |  |
| MOV DPTR,#data16              | DPTR = 16-bit immediate<br>constant         |      |                  |      | х    |  |  |  |  |
| PUSH <src></src>              | INC SP; MOV "@SP", <src></src>              | Х    |                  |      |      |  |  |  |  |
| POP <dest></dest>             | MOV <dest>,"@SP"; DEC SP</dest>             | Х    |                  |      |      |  |  |  |  |
| XCH A, <byte></byte>          | Exchange contents of A and<br><byte></byte> | х    | х                | х    |      |  |  |  |  |
| XCHD A,@Ri                    | Exchange low nibbles of A and<br>@Ri        |      | х                |      |      |  |  |  |  |

 Table 6.
 Data transfer instructions that access internal data memory space

First, pointers R1 and R0 are set up to point to the two bytes containing the last four BCD digits. Then a loop is executed which leaves the last byte, location 2EH, holding the last two digits of the shifted number. The pointers are decremented, and the loop is repeated for location 2DH. The CJNE instruction (Compare and Jump if Not equal) is a loop control that will be described later. The loop executed from LOOP to CJNE for R1 = 2EH, 2DH, 2CH, and 2BH. At that point the digit that was originally shifted out on the right has propagated to location 2AH. Since that location should be left with 0s, the lost digit is moved to the Accumulator.



|    |                     |      | •   | ,   |     |     |      |    |
|----|---------------------|------|-----|-----|-----|-----|------|----|
| 88 | TCON <sup>(1)</sup> | TMOD | TL0 | TL1 | TH0 | TH1 |      | 8F |
| 80 | P0 <sup>(1)</sup>   | SP   | DPL | DPH |     |     | PCON | 87 |

### Table 15. SFR memory map (continued)

1. Register can be bit addressing

### Table 16.List of all SFRs

| dr H | D        |       | set<br>ue | 0     |         |       |       |       |       |            |                                     |
|------|----------|-------|-----------|-------|---------|-------|-------|-------|-------|------------|-------------------------------------|
| SF   | нед мате | 7     | 6         | 5     | 4       | 3     | 2     | 1     | 0     | Res<br>Val | Comments                            |
| 80   | P0       |       |           |       |         |       |       |       |       | FF         | Port 0                              |
| 81   | SP       |       |           |       |         |       |       |       |       | 07         | Stack Ptr                           |
| 82   | DPL      |       |           |       |         |       |       |       |       | 00         | Data Ptr Low                        |
| 83   | DPH      |       |           |       |         |       |       |       |       | 00         | Data Ptr High                       |
| 87   | PCON     | SMOD  | SMOD1     | LVREN | ADSFINT | RCLK1 | TCLK1 | PD    | IDLE  | 00         | Power Ctrl                          |
| 88   | TCON     | TF1   | TR1       | TF0   | TR0     | IE1   | IT1   | IE0   | ITO   | 00         | Timer / Cntr<br>Control             |
| 89   | TMOD     | Gate  | C/T       | M1    | MO      | Gate  | C/T   | M1    | MO    | 00         | Timer / Cntr<br>mode Control        |
| 8A   | TLO      |       |           |       |         |       |       |       |       | 00         | Timer 0 Low                         |
| 8B   | TL1      |       |           |       |         |       |       |       |       | 00         | Timer 1 Low                         |
| 8C   | TH0      |       |           |       |         |       |       |       |       | 00         | Timer 0 High                        |
| 8D   | TH1      |       |           |       |         |       |       |       |       | 00         | Timer 1 High                        |
| 90   | P1       |       |           |       |         |       |       |       |       | FF         | Port 1                              |
| 91   | P1SFS    | P1S7  | P1S6      | P1S5  | P1S4    |       |       |       |       | 00         | Port 1 Select<br>Register           |
| 93   | P3SFS    | P3S7  | P3S6      |       |         |       |       |       |       | 00         | Port 3 Select<br>Register           |
| 94   | P4SFS    | P4S7  | P4S6      | P4S5  | P4S4    | P4S3  | P4S2  | P4S1  | P4S0  | 00         | Port 4 Select<br>Register           |
| 95   | ASCL     |       |           |       |         |       |       |       |       | 00         | 8-bit<br>Prescaler for<br>ADC clock |
| 96   | ADAT     | ADAT7 | ADAT6     | ADAT5 | ADAT4   | ADAT3 | ADAT2 | ADAT1 | ADAT0 | 00         | ADC Data<br>Register                |
| 97   | ACON     |       |           | ADEN  |         | ADS1  | ADS0  | ADST  | ADSF  | 00         | ADC Control<br>Register             |
| 98   | SCON     | SM0   | SM1       | SM2   | REN     | TB8   | RB8   | ТІ    | RI    | 00         | Serial Control<br>Register          |
| 99   | SBUF     |       |           |       |         |       |       |       |       | 00         | Serial Buffer                       |
| 9A   | SCON2    | SM0   | SM1       | SM2   | REN     | TB8   | RB8   | ТІ    | RI    | 00         | 2nd UART<br>Ctrl Register           |
| 9B   | SBUF2    |       |           |       |         |       |       |       |       | 00         | 2nd UART<br>Serial Buffer           |
| A0   | P2       |       |           |       |         |       |       |       |       | FF         | Port 2                              |



|        |                               |                  |               |                      | •                     |                       |                       |               |               |       |                                                |
|--------|-------------------------------|------------------|---------------|----------------------|-----------------------|-----------------------|-----------------------|---------------|---------------|-------|------------------------------------------------|
| CSIOP  | Degister nome                 |                  |               | Reset                | Commonto              |                       |                       |               |               |       |                                                |
| offset | Register name                 | 7                | 6             | 5                    | 4                     | 3                     | 2                     | 1             | 0             | value | Comments                                       |
| C0     | Primary Flash<br>Protection   | Sec7_<br>Prot    | Sec6_<br>Prot | Sec5_<br>Prot        | Sec4_<br>Prot         | Sec3_<br>Prot         | Sec2_<br>Prot         | Sec1_<br>Prot | Sec0_<br>Prot |       | Bit = 1 sector<br>is protected                 |
| C2     | Secondary Flash<br>Protection | Security<br>_Bit | *             | *                    | *                     | Sec3_<br>Prot         | Sec2_<br>Prot         | Sec1_<br>Prot | Sec0_<br>Prot |       | Security Bit =<br>1 device is<br>secured       |
| В0     | PMMR0                         | *                | *             | PLD<br>Mcells<br>clk | PLD<br>array-<br>clk  | PLD<br>Turbo          | *                     | APD<br>enable | *             | 00    | Control PLD<br>power<br>consumption            |
| B4     | PMMR2                         | *                |               | PLD<br>array<br>Ale  | PLD<br>array<br>Cntl2 | PLD<br>array<br>Cntl1 | PLD<br>array<br>Cntl0 | *             | *             | 00    | Blocking<br>inputs to PLD<br>array             |
| E0     | Page                          |                  |               |                      |                       |                       |                       |               |               | 00    | Page Register                                  |
| E2     | VM                            | Periph-<br>mode  | *             | *                    | FL_<br>data           | Boot_<br>data         | FL_<br>code           | Boot_<br>code | SR_<br>code   |       | Configure<br>8032 Program<br>and Data<br>Space |

Table 17. PSD module register address offset (continued)

(Register address = CSIOP address + address offset; where CSIOP address is defined by user in PSDsoft)
 \* indicates bit is not used and must be set to '0'.



# 6 **Power-saving mode**

Two software selectable modes of reduced power consumption are implemented.

# 6.1 Idle mode

In Idle mode, the following functions are switched Off.

• CPU (Halted)

The following functions remain Active during Idle mode:

- External Interrupts
- Timer 0, Timer 1, Timer 2
- DDC Interface
- PWM Units
- USB Interface
- USART
- 8-bit ADC
- I<sup>2</sup>C Interface

Note: Interrupt or RESET terminates the Idle mode.

# 6.2 Power-down mode

- System Clock Halted
- LVD Logic Remains Active
- SRAM content remains unchanged
- The SFRs retain their value until a RESET is asserted
- Note: The only way to exit Power-down mode is through a RESET.

### Table 25.Power-saving mode power consumption

| Mode       | Addr/data     | Ports 1,3,4   | PWM     | l <sup>2</sup> C | DDC     | USB     |
|------------|---------------|---------------|---------|------------------|---------|---------|
| Idle       | Maintain Data | Maintain Data | Active  | Active           | Active  | Active  |
| Power-down | Maintain Data | Maintain Data | Disable | Disable          | Disable | Disable |

# 6.3 Power control register

The Idle and Power-down modes are activated by software via the PCON register.

### Table 26. Pin status during Idle and Power-down mode

| SFR  | Reg  |      |       |       | Bit Registe | er Name |       |    |      | Reset | Commonto   |
|------|------|------|-------|-------|-------------|---------|-------|----|------|-------|------------|
| Addr | Name | 7    | 6     | 5     | 4           | 3       | 2     | 1  | 0    | Value | Comments   |
| 87   | PCON | SMOD | SMOD1 | LVREN | ADSFINT     | RCLK1   | TCLK1 | PD | IDLE | 00    | Power Ctrl |



57

|                 | 7                    | T2CON      |     |                     |                                     |                   |                                            | Input    | clock                 |
|-----------------|----------------------|------------|-----|---------------------|-------------------------------------|-------------------|--------------------------------------------|----------|-----------------------|
| Mode            | RxCLK<br>or<br>TxCLK | CP/R<br>L2 | TR2 | T2MOD<br>DECN       | T2CON<br>EXEN                       | P1.1<br>T2EX      | Remarks                                    | Internal | External<br>(P1.0/T2) |
|                 | 0                    | 0          | 1   | 0                   | 0                                   | х                 | Reload upon overflow                       |          |                       |
| 16-bit<br>Auto- | 0                    | 0          | 1   | 0                   | 0 1 - Reload trigger (falling edge) |                   | f <sub>OSC</sub> /12                       | MAX      |                       |
| reload          | 0                    | 0          | 1   | 1                   | x                                   | x 0 Down counting |                                            |          | 10SC/24               |
|                 | 0                    | 0          | 1   | 1 1 x 1 Up counting |                                     |                   |                                            |          |                       |
| 16-bit          | 0                    | 1          | 1   | x                   | 0                                   | x                 | 16-bit Timer/Counter<br>(only up counting) | f /12    | MAX                   |
| Capture         | 0                    | 1          | 1   | x                   | 1                                   | -                 | Capture (TH1,TL2) →<br>(RCAP2H,RCAP2L)     | IOSC/12  | f <sub>OSC</sub> /24  |
| Baud Rate       | 1                    | x          | 1   | x                   | 0                                   | x                 | No overflow interrupt<br>request (TF2)     | f/12     | MAX                   |
| Generator       | 1                    | x          | 1   | x                   | 1                                   | -                 | Extra External Interrupt<br>(Timer 2)      | IOSC/12  | f <sub>OSC</sub> /24  |
| Off             | х                    | х          | 0   | х                   | х                                   | х                 | Timer 2 stops                              | _        | _                     |

Table 42. Timer/counter2 operating modes

1.  $\downarrow$  = falling edge





# 12 Standard serial interface (UART)

The UPSD323xx devices provides two standard 8032 UART serial ports. The first port is connected to pin P3.0 (RX) and P3.1 (TX). The second port is connected to pin P1.2 (RX) and P1.3(TX). The operation of the two serial ports are the same and are controlled by the SCON and SCON2 registers.

The serial port is full duplex, meaning it can transmit and receive simultaneously. It is also receive-buffered, meaning it can commence reception of a second byte before a previously received byte has been read from the register. (However, if the first byte still has not been read by the time reception of the second byte is complete, one of the bytes will be lost.) The serial port receive and transmit registers are both accessed at Special Function Register SBUF (or SBUF2 for the second serial port). Writing to SBUF loads the transmit register, and reading SBUF accesses a physically separate receive register.

The serial port can operate in 4 modes: Mode 0, 1, 2 or 3.

#### Mode 0

Serial data enters and exits through RxD. TxD outputs the shift clock. 8 bits are transmitted/received (LSB first). The baud rate is fixed at 1/12 the f<sub>OSC</sub>.

#### Mode 1

10 bits are transmitted (through TxD) or received (through RxD): a Start bit (0), 8 data bits (LSB first), and a Stop bit (1). On receive, the Stop bit goes into RB8 in Special Function Register SCON. The baud rate is variable.

#### Mode 2

11 bits are transmitted (through TxD) or received (through RxD): Start bit (0), 8 data bits (LSB first), a programmable 9th data bit, and a Stop bit (1). On Transmit, the 9th data bit (TB8 in SCON) can be assigned the value of '0' or '1'. Or, for example, the Parity bit (P, in the PSW) could be moved into TB8. On receive, the 9th data bit goes into RB8 in Special Function Register SCON, while the Stop bit is ignored. The baud rate is programmable to either 1/32 or 1/64 the oscillator frequency.

### Mode 3

11 bits are transmitted (through TxD) or received (through RxD): a Start bit (0), 8 data bits (LSB first), a programmable 9th data bit, and a Stop bit (1). In fact, Mode 3 is the same as Mode 2 in all respects except baud rate. The baud rate in Mode 3 is variable.

In all four modes, transmission is initiated by any instruction that uses SBUF as a destination register. Reception is initiated in Mode 0 by the condition RI = 0 and REN = 1. Reception is initiated in the other modes by the incoming start bit if REN = 1.

### 12.1 Multiprocessor communications

Modes 2 and 3 have a special provision for multiprocessor communications. In these modes, 9 data bits are received. The 9th one goes into RB8. Then comes a Stop bit. The port can be programmed such that when the Stop bit is received, the serial port interrupt will



be activated only if RB8 = 1. This feature is enabled by setting Bit SM2 in SCON. A way to use this feature in multi-processor systems is as follows:

When the master processor wants to transmit a block of data to one of several slaves, it first sends out an address byte which identifies the target slave. An address byte differs from a data byte in that the 9th bit is '1' in an address byte and 0 in a data byte. With SM2 = 1, no slave will be interrupted by a data byte. An ad-dress byte, however, will interrupt all slaves, so that each slave can examine the received byte and see if it is being addressed. The addressed slave will clear its SM2 bit and prepare to receive the data bytes that will be coming. The slaves that weren't being addressed leave their SM2s set and go on about their business, ignoring the coming data bytes.

SM2 has no effect in Mode 0, and in Mode 1 can be used to check the validity of the Stop bit. In a Mode 1 reception, if SM2 = 1, the receive interrupt will not be activated unless a valid Stop bit is received.

## 12.2 Serial port control register

The serial port control and status register is the Special Function Register SCON (SCON2 for the second port), shown in *Figure 26*. This register contains not only the mode selection bits, but also the 9th data bit for transmit and receive (TB8 and RB8), and the Serial Port Interrupt bits (TI and RI).

| Table 43. | Serial | port control | reaister ( | (SCON) |  |
|-----------|--------|--------------|------------|--------|--|
|           |        |              |            |        |  |

| 7   | 6   | 5   | 4   | 3   | 2   | 1  | 0  |
|-----|-----|-----|-----|-----|-----|----|----|
| SM0 | SM1 | SM2 | REN | TB8 | RB8 | TI | RI |

#### Table 44.Description of the SCON bits

| Bit | Symbol | Function                                                                                                                                                                                                                                                                                               |
|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | SM0    | (SM1,SM0)=(0,0): Shift Register. Baud rate = f <sub>OSC</sub> /12                                                                                                                                                                                                                                      |
| 6   | SM1    | (SM1,SM0)=(1,0): 8-bit UART. Baud rate = variable<br>(SM1,SM0)=(0,1): 8-bit UART. Baud rate = f <sub>OSC</sub> /64 or f <sub>OSC</sub> /32<br>(SM1,SM0)=(1,1): 8-bit UART. Baud rate = variable                                                                                                        |
| 5   | SM2    | Enables the multiprocessor communication features in Mode 2 and 3. In<br>Mode 2 or 3, if SM2 is set to '1,' RI will not be activated if its received 8th<br>data bit (RB8) is '0.' In Mode 1, if SM2=1, RI will not be activated if a valid<br>Stop bit was not received. In Mode 0, SM2 should be '0' |
| 4   | REN    | Enables serial reception. Set by software to enable reception. Clear by software to disable reception                                                                                                                                                                                                  |
| 3   | TB8    | The 8th data bit that will be transmitted in Modes 2 and 3. Set or clear by software as desired                                                                                                                                                                                                        |
| 2   | RB8    | In Modes 2 and 3, this bit contains the 8th data bit that was received. In Mode 1, if SM2=0, RB8 is the Snap Bit that was received. In Mode 0, RB8 is not used                                                                                                                                         |



- 1. Reset DDC1 enable (by default, DDC1 enable is cleared as LOW after Power-on Reset).
- 2. Set SWENB as high (the default value is zero.)
- 3. Depending on the data size of EDID data, set EX\_DAT as LOW (128 bytes) or HIGH (256 bytes).
- 4. By using bulky moving commands (DDCADR, RAMBUF involved) to move the entire EDID data to RAM buffer.
- 5. Reset SWENB to LOW.
- 6. Reset DDCADR to 00h.
- 7. Set DDC1 enable as HIGH.

In case SWENB is set as high, interrupt service routine is finished within 133 machine cycle in 40MHz System clock.

The maximum  $V_{SYNC}$  ( $V_{CLK}$ ) frequency is 25Khz (40 $\mu s$ ). And the 9th clock of  $V_{SYNC}$  ( $V_{CLK}$ ) is interrupt period.

So the machine cycle be needed is calculated as below. For example,

- When 40MHz system clock, 40µs = 133 x (25ns x 12); 133 machine cycle.
- 12MHz system clock,  $40\mu s = 40 x$  (83.3ns x 12); 40 machine cycle.
- 8MHz system clock, 40µs = 26 x (125ns x 12); 26 machine cycle.

Note:

If EX\_DAT equals to LOW, it is meant the lower part is occupied by DDC1 operation and the upper part is still free to the system. Nevertheless, the effect of the post increment just applies to the part related to DDC1 operation. In other words, the system program is still able to address the locations from 128 to 255 in the RAM buffer through MOVX command but without the facility of the post increment. For example, the case of accessing 200 of the RAM Buffer:

MOV R0, #200, and MOVX A, @R0











# 23.5.1 Loading and Reading the Output Macrocells (OMC)

The Output Macrocells (OMC) block occupies a memory location in the MCU address space, as defined by the CSIOP block (see *Section 24: I/O ports (PSD module)*). The flip-flops in each of the 16 Output Macrocells (OMC) can be loaded from the data bus by a MCU. Loading the Output Macrocells (OMC) with data from the MCU takes priority over internal functions. As such, the preset, clear, and clock inputs to the flip-flop can be overridden by the MCU. The ability to load the flip-flops and read them back is useful in such applications as loadable counters and shift registers, mailboxes, and handshaking protocols.

Data can be loaded to the Output Macrocells (OMC) on the trailing edge of WRITE Strobe ( $\overline{WR}$ , edge loading) or during the time that WRITE Strobe ( $\overline{WR}$ ) is active (level loading). The method of loading is specified in PSDsoft Express Configuration.



Figure 59. CPLD output macrocell

### 23.5.2 OMC mask register

There is one Mask Register for each of the two groups of eight Output Macrocells (OMC). The Mask Registers can be used to block the loading of data to individual Output Macrocells (OMC). The default value for the Mask Registers is 00h, which allows loading of the Output Macrocells (OMC). When a given bit in a Mask Register is set to a '1,' the MCU is blocked from writing to the associated Output Macrocells (OMC). For example, suppose McellAB0-McellAB3 are being used for a state machine. You would not want a MCU write to McellAB to overwrite the state machine registers. Therefore, you would want to load the Mask Register for McellAB (Mask Macrocell AB) with the value 0Fh.

# 23.5.3 Output enable of the OMC

The Output Macrocells (OMC) block can be connected to an I/O port pin as a PLD output. The output enable of each port pin driver is controlled by a single product term from the



# 25 Power management

All PSD modules offer configurable power saving options. These options may be used individually or in combinations, as follows:

- The primary and secondary Flash memory, and SRAM blocks are built with power management technology. In addition to using special silicon design methodology, power management technology puts the memories into Standby mode when address/data inputs are not changing (zero DC current). As soon as a transition occurs on an input, the affected memory "wakes up," changes and latches its outputs, then goes back to standby. The designer does *not* have to do anything special to achieve Memory Standby mode when no inputs are changing—it happens automatically.
- The PLD sections can also achieve Standby mode when its inputs are not changing, as described in the sections on the Power Management mode Registers (PMMR).
- As with the Power Management mode, the Automatic Power Down (APD) block allows the PSD module to reduce to Standby current automatically. The APD Unit can also block MCU address/data signals from reaching the memories and PLDs.
- Built in logic monitors the Address Strobe of the MCU for activity. If there is no activity for a certain time period (MCU is asleep), the APD Unit initiates Power-down mode (if enabled). Once in Power-down mode, all address/data signals are blocked from reaching memory and PLDs, and the memories are deselected internally. This allows the memory and PLDs to remain in Standby mode even if the address/data signals are changing state externally (noise, other devices on the MCU bus, etc.). Keep in mind that any unblocked PLD input signals that are changing states keeps the PLD out of Standby mode, but not the memories.
- PSD Chip Select Input (CSI, PD2) can be used to disable the internal memories, placing them in Standby mode even if inputs are changing. This feature does not block any internal signals or disable the PLDs. This is a good alternative to using the APD Unit. There is a slight penalty in memory access time when PSD Chip Select Input (CSI, PD2) makes its initial transition from deselected to selected.
- The PMMRs can be written by the MCU at run-time to manage power. The PSD module supports "blocking bits" in these registers that are set to block designated signals from reaching both PLDs. Current consumption of the PLDs is directly related to the composite frequency of the changes on their inputs (see Figure *Figure 70* and *Figure 71*). Significant power savings can be achieved by blocking signals that are not used in DPLD or CPLD logic equations.

145/189

### Other power-saving options

The PSD module offers other reduced power saving options that are independent of the Power-down mode. Except for the PSD Chip Select Input ( $\overline{CSI}$ , PD2) features, they are enabled by setting bits in PMMR0 and PMMR2.





#### Table 102. Power-down mode's effect on ports

| Port Function  | Pin Level |
|----------------|-----------|
| MCU I/O        | No Change |
| PLD Out        | No Change |
| Address Out    | Undefined |
| Peripheral I/O | Tri-State |

# 25.1 PLD power management

The power and speed of the PLDs are controlled by the Turbo Bit (Bit 3) in PMMR0. By setting the bit to '1,' the Turbo mode is off and the PLDs consume the specified Standby current when the inputs are not switching for an extended time of 70 ns. The propagation delay time is increased by 10 ns (for a 5 V device) after the Turbo Bit is set to '1' (turned off) when the inputs change at a composite frequency of less than 15MHz. When the Turbo Bit is reset to '0' (turned on), the PLDs run at full power and speed. The Turbo Bit affects the PLD's DC power, AC power, and propagation delay. When the Turbo mode is off, the UPSD323xx devices' input clock frequency is reduced by 5 MHz from the maximum rated clock frequency.

Blocking MCU control signals with the bits of PMMR2 can further reduce PLD AC power consumption.



| Port Configuration | Power-On RESET                                         | Warm RESET | Power-down mode                                                   |
|--------------------|--------------------------------------------------------|------------|-------------------------------------------------------------------|
| MCU I/O            | Input mode                                             | Input mode | Unchanged                                                         |
| PLD Output         | Valid after internal PSD configuration bits are loaded | Valid      | Depends on inputs to<br>PLD (addresses are<br>blocked in PD mode) |
| Address Out        | Tri-stated                                             | Tri-stated | Not defined                                                       |
| Peripheral I/O     | Tri-stated                                             | Tri-stated | Tri-stated                                                        |

 Table 106.
 Status during Power-on RESET, Warm RESET and Power-down mode

| Register                       | Power-On RESET                                                    | Warm RESET                                                        | Power-down mode                     |
|--------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------------|-------------------------------------|
| PMMR0 and PMMR2                | Cleared to '0'                                                    | Unchanged                                                         | Unchanged                           |
| Macrocells flip-flop<br>status | Cleared to '0' by<br>internal Power-on<br>RESET                   | Depends on .re and .pr<br>equations                               | Depends on .re and .pr<br>equations |
| VM Register <sup>(1)</sup>     | Initialized, based on the selection in PSDsoft Configuration menu | Initialized, based on the selection in PSDsoft Configuration menu | Unchanged                           |
| All other registers            | Cleared to '0'                                                    | Cleared to '0'                                                    | Unchanged                           |

1. The SR\_cod and Periphmode Bits in the VM Register are always cleared to '0' on Power-on RESET or Warm RESET.



scan the status out serially using the standard JTAG channel. See Application Note *AN1153*.

TERR indicates if an error has occurred when erasing a sector or programming a byte in Flash memory. This signal goes Low (active) when an Error condition occurs, and stays Low until an "ISC\_CLEAR" command is executed or a chip Reset (RESET) pulse is received after an "ISC\_DISABLE" command.

TSTAT behaves the same as Ready/Busy described in *Section 22.2.1: Ready/Busy (PC3)*. TSTAT is High when the PSD module device is in READ mode (primary and secondary Flash memory contents can be read). TSTAT is Low when Flash memory Program or Erase cycles are in progress, and also when data is being written to the secondary Flash memory.

TSTAT and TERR can be configured as open-drain type signals during an "ISC\_ENABLE" command.

## 27.3 Security and Flash memory protection

When the Security Bit is set, the device cannot be read on a Device Programmer or through the JTAG Port. When using the JTAG Port, only a Full Chip Erase command is allowed.

All other Program, Erase and Verify commands are blocked. Full Chip Erase returns the part to a non-secured blank state. The Security Bit can be set in PSDsoft Express Configuration.

All primary and secondary Flash memory sectors can individually be sector protected against erasures. The sector protect bits can be set in PSDsoft Express Configuration.



| Symbol                                     | Parameter                                 |                         | Test conditions (in addition to those in <i>Table 113</i> ) | Min. | Тур. | Max. | Unit                 |
|--------------------------------------------|-------------------------------------------|-------------------------|-------------------------------------------------------------|------|------|------|----------------------|
| I <sub>FR</sub>                            | XTAL feedback resistor<br>current (XTAL1) |                         | XTAL1 = V <sub>CC</sub><br>XTAL2 = V <sub>SS</sub>          | -20  |      | -50  | μA                   |
| Ι <sub>LI</sub>                            | Input leakage                             | current                 | $V_{SS} < V_{IN} < V_{CC}$                                  | -1   |      | 1    | μA                   |
| I <sub>LO</sub>                            | Output leakag                             | e current               | 0.45 < V <sub>OUT</sub> < V <sub>CC</sub>                   | -10  |      | 10   | μA                   |
| I <sub>PD</sub> <sup>(1)</sup>             | Power-down mode                           |                         | V <sub>CC</sub> = 5.5 V<br>LVD logic disabled               |      |      | 250  | μA                   |
|                                            |                                           |                         | LVD logic enabled                                           |      |      | 380  | μA                   |
| ICC CPU                                    | Active (12 MHz)                           |                         | $V_{ee} = 5 V$                                              |      | 20   | 30   | mA                   |
|                                            | Idle (12 MHz)                             |                         | V <sub>CC</sub> = 5 V                                       |      | 8    | 10   | mA                   |
|                                            | Active (24 MHz)                           |                         | $\lambda = - E \lambda $                                    |      | 30   | 38   | mA                   |
| (2,3,6)                                    | Idle (24 MHz)                             |                         | $v_{CC} = 5 v$                                              |      | 15   | 20   | mA                   |
|                                            | Active (40 MHz)                           |                         | V <sub>CC</sub> = 5 V                                       |      | 40   | 62   | mA                   |
|                                            | Idle (40 MHz)                             |                         |                                                             |      | 20   | 30   | mA                   |
|                                            | Operating                                 | PLD Only                | $PLD_TURBO = Off,$<br>f = 0 MHz <sup>(4)</sup>              |      | 0    |      | μΑ/ΡΤ <sup>(5)</sup> |
| I <sub>CC PSD</sub>                        |                                           |                         | PLD_TURBO = On,<br>f = 0 MHz                                |      | 400  | 700  | µA/PT                |
| (DC) <sup>(6)</sup>                        | supply current                            | supply current<br>Flash | During Flash memory<br>WRITE/Erase Only                     |      | 15   | 30   | mA                   |
|                                            |                                           | memory                  | Read-only, f = 0 MHz                                        |      | 0    | 0    | mA                   |
|                                            |                                           | SRAM                    | f = 0 MHz                                                   |      | 0    | 0    | mA                   |
|                                            | PLD AC Base                               |                         |                                                             |      | No   | te 5 |                      |
| I <sub>CC_PSD</sub><br>(AC) <sup>(6)</sup> | Flash memory AC adder                     |                         |                                                             |      | 2.5  | 3.5  | mA/MHz               |
| (/(0))                                     | SRAM AC adder                             |                         |                                                             |      | 1.5  | 3.0  | mA/MHz               |

Table 118. DC characteristics (5 V devices) (continued)

 I<sub>PD</sub> (Power-down mode) is measured with: XTAL1=V<sub>SS</sub>; XTAL2=not connected; RESET=V<sub>CC</sub>; Port 0 =V<sub>CC</sub>; all other pins are disconnected. PLD not in Turbo mode.

 I<sub>CC\_CPU</sub> (active mode) is measured with: <u>XTAL1</u> driven with t<sub>CLCH</sub>, t<sub>CHCL</sub> = 5 ns, V<sub>IL</sub> = V<sub>SS</sub>+0.5 V, V<sub>IH</sub> = Vcc - 0.5 V, XTAL2 = not connected; <u>RESET=V<sub>SS</sub></u>; Port 0=V<sub>CC</sub>; all other pins are disconnected. I<sub>CC</sub> would be slightly higher if a crystal oscillator is used (approximately 1mA).

- 3.  $I_{CC\_CPU}$  (Idle mode) is measured with: XTAL1 driven with  $t_{CLCH}$ ,  $t_{CHCL} = 5$  ns,  $V_{IL} = V_{SS}+0.5$  V,  $V_{IH} = V_{CC}-0.5$  V, XTAL2 = not connected; Port 0 =  $V_{CC}$ ;
- 4.  $\overline{\text{RESET}}=V_{CC}$ ; all other pins are disconnected.
- 5. PLD is in non-Turbo mode and none of the inputs are switching.
- 6. See *Figure 70* for the PLD current calculation.
- 7. I/O current = 0 mA, all I/O pins are disconnected.



| Symbol                           | Parameter <sup>(1)</sup>              | 24 MHz<br>oscillator |      | Variable<br>1/t <sub>CLCL</sub> = 8 | Unit                     |    |
|----------------------------------|---------------------------------------|----------------------|------|-------------------------------------|--------------------------|----|
|                                  |                                       | Min.                 | Max. | Min.                                | Max.                     |    |
| t <sub>LHLL</sub>                | ALE pulse width                       | 43                   |      | 2 t <sub>CLCL</sub> – 40            |                          | ns |
| t <sub>AVLL</sub>                | Address set-up to ALE                 | 17                   |      | t <sub>CLCL</sub> – 25              |                          | ns |
| t <sub>LLAX</sub>                | Address hold after ALE                | 17                   |      | t <sub>CLCL</sub> – 25              |                          | ns |
| t <sub>LLIV</sub>                | ALE Low to valid instruction in       |                      | 80   |                                     | 4 t <sub>CLCL</sub> – 87 | ns |
| t <sub>LLPL</sub>                | ALE to PSEN                           | 22                   |      | t <sub>CLCL</sub> – 20              |                          | ns |
| t <sub>PLPH</sub>                | PSEN pulse width                      | 95                   |      | 3 t <sub>CLCL</sub> – 30            |                          | ns |
| t <sub>PLIV</sub>                | PSEN to valid instruction in          |                      | 60   |                                     | 3 t <sub>CLCL</sub> – 65 | ns |
| t <sub>PXIX</sub>                | Input instruction hold after<br>PSEN  | 0                    |      | 0                                   |                          | ns |
| t <sub>PXIZ</sub> <sup>(2)</sup> | Input instruction float after<br>PSEN |                      | 32   |                                     | t <sub>CLCL</sub> – 10   | ns |
| t <sub>PXAV</sub> <sup>(2)</sup> | Address valid after PSEN              | 37                   |      | t <sub>CLCL</sub> – 5               |                          | ns |
| t <sub>AVIV</sub>                | Address to valid instruction in       |                      | 148  |                                     | 5 t <sub>CLCL</sub> – 60 | ns |
| t <sub>AZPL</sub>                | Address float to PSEN                 | -10                  |      | -10                                 |                          | ns |

Table 121. External program memory AC characteristics (with the 3 V MCU module)

Conditions (in addition to those in *Table 114*, V<sub>CC</sub> = 3.0 to 3.6 V): V<sub>SS</sub> = 0 V; C<sub>L</sub> for Port 0, ALE and PSEN output is 100 pF, for 5 V devices, and 50 pF for 3 V devices; C<sub>L</sub> for other outputs is 80 pF, for 5 V devices, and 50 pF for 3 V devices)

2. Interfacing the UPSD323xx devices to devices with float times up to 35 ns is permissible. This limited bus contention does not cause any damage to Port 0 drivers.

| Symbol             | Parameter <sup>(1)</sup> | 40 MHz o | oscillator | Variable o<br>1/t <sub>CLCL</sub> = 24 | Unit                                     |    |
|--------------------|--------------------------|----------|------------|----------------------------------------|------------------------------------------|----|
|                    |                          | Min.     | Max.       | Min.                                   | Max.                                     |    |
| t <sub>RLRH</sub>  | Oscillator period        |          |            | 25                                     | 41.7                                     | ns |
| t <sub>WLWH</sub>  | High time                |          |            | 10                                     | t <sub>CLCL</sub> –<br>t <sub>CLCX</sub> | ns |
| t <sub>LLAX2</sub> | Low time                 |          |            | 10                                     | t <sub>CLCL</sub> –<br>t <sub>CLCX</sub> | ns |
| t <sub>RHDX</sub>  | Rise time                |          |            |                                        | 10                                       | ns |
| t <sub>RHDX</sub>  | Fall time                |          |            |                                        | 10                                       | ns |

1. Conditions (in addition to those in *Table 113*,  $V_{CC}$  = 4.5 to 5.5 V):  $V_{SS}$  = 0 V;  $C_L$  for Port 0, ALE and PSEN output is 100 pF;  $C_L$  for other outputs is 80 pF



| Symbol             | Parameter <sup>(1)</sup>                                          | 24 MHz oscillator |      | Variable oscillator<br>1/t <sub>CLCL</sub> = 8 to 24 MHz |                           | Unit |
|--------------------|-------------------------------------------------------------------|-------------------|------|----------------------------------------------------------|---------------------------|------|
|                    |                                                                   | Min.              | Max. | Min.                                                     | Max.                      |      |
| t <sub>RLRH</sub>  | RD pulse width                                                    | 180               |      | 6 t <sub>CLCL</sub> – 70                                 |                           | ns   |
| t <sub>WLWH</sub>  | WR pulse width                                                    | 180               |      | 6 t <sub>CLCL</sub> – 70                                 |                           | ns   |
| t <sub>LLAX2</sub> | Address hold after ALE                                            | 56                |      | 2 t <sub>CLCL</sub> – 27                                 |                           | ns   |
| t <sub>RHDX</sub>  | RD to valid data in                                               |                   | 118  |                                                          | 5 t <sub>CLCL</sub> – 90  | ns   |
| t <sub>RHDX</sub>  | Data hold after RD                                                | 0                 |      | 0                                                        |                           | ns   |
| t <sub>RHDZ</sub>  | Data float after RD                                               |                   | 63   |                                                          | 2 t <sub>CLCL</sub> – 20  | ns   |
| t <sub>LLDV</sub>  | ALE to valid data in                                              |                   | 200  |                                                          | 8 t <sub>CLCL</sub> – 133 | ns   |
| t <sub>AVDV</sub>  | Address to valid data in                                          |                   | 220  |                                                          | 9 t <sub>CLCL</sub> – 155 | ns   |
| t <sub>LLWL</sub>  | ALE to WR or RD                                                   | 75                | 175  | 3 t <sub>CLCL</sub> – 50                                 | t <sub>CLCL</sub> + 50    | ns   |
| t <sub>AVWL</sub>  | Address valid to $\overline{WR}$ or $\overline{RD}$               | 67                |      | 4 t <sub>CLCL</sub> – 97                                 |                           | ns   |
| t <sub>WHLH</sub>  | $\overline{\text{WR}}$ or $\overline{\text{RD}}$ High to ALE High | 17                | 67   | t <sub>CLCL</sub> – 25                                   | t <sub>CLCL</sub> + 25    | ns   |
| t <sub>QVWX</sub>  | Data valid to $\overline{WR}$ transition                          | 5                 |      | t <sub>CLCL</sub> – 37                                   |                           | ns   |
| t <sub>QVWH</sub>  | Data set-up before WR                                             | 170               |      | 7 t <sub>CLCL</sub> – 122                                |                           | ns   |
| t <sub>WHQX</sub>  | Data hold after WR                                                | 15                |      | t <sub>CLCL</sub> – 27                                   |                           | ns   |
| t <sub>RLAZ</sub>  | Address float after RD                                            |                   | 0    |                                                          | 0                         | ns   |

Table 125. External data memory AC characteristics (with the 3 V MCU module)

Conditions (in addition to those in *Table 114*, V<sub>CC</sub> = 3.0 to 3.6 V): V<sub>SS</sub> = 0 V; C<sub>L</sub> for Port 0, ALE and PSEN output is 100 pF, for 5 V devices, and 50 pF for 3 V devices; C<sub>L</sub> for other outputs is 80 pF, for 5 V devices, and 50 pF for 3 V devices)

| Table 126         | 6. A/D analog specification                     | I                 |                    |      |                  |        |
|-------------------|-------------------------------------------------|-------------------|--------------------|------|------------------|--------|
| Symbol            | Parameter                                       | Test condition    | Min.               | Тур. | Max.             | Unit   |
| AV <sub>REF</sub> | Analog power supply input voltage range         |                   | V <sub>SS</sub>    |      | V <sub>CC</sub>  | V      |
| V <sub>AN</sub>   | Analog input voltage range                      |                   | $V_{\rm SS} - 0.3$ |      | $AV_{REF} + 0.3$ | V      |
| I <sub>AVDD</sub> | Current following between $V_{CC}$ and $V_{SS}$ |                   |                    |      | 200              | μA     |
| CA <sub>IN</sub>  | Overall accuracy                                |                   |                    |      | ±2               | l.s.b. |
| N <sub>NLE</sub>  | Non-linearity error                             |                   |                    |      | ±2               | l.s.b. |
| N <sub>DNLE</sub> | Differential non-linearity error                |                   |                    |      | ±2               | l.s.b. |
| N <sub>ZOE</sub>  | Zero-offset error                               |                   |                    |      | ±2               | l.s.b. |
| N <sub>FSE</sub>  | Full scale error                                |                   |                    |      | ±2               | l.s.b. |
| N <sub>GE</sub>   | Gain error                                      |                   |                    |      | ±2               | l.s.b. |
| t <sub>CONV</sub> | Conversion time                                 | at 8 MHz<br>clock |                    |      | 20               | μs     |

