INTEGRATED CIRCUITS



Preliminary specification File under Integrated Circuits, IC14 1996 Jan 08



#### **Preliminary specification**

## Microcontroller for monitor OSD and auto-sync applications

#### CONTENTS

| 1            | FEATURES                                                                   | 12.1         |
|--------------|----------------------------------------------------------------------------|--------------|
| 1.1          | General                                                                    | 12.2<br>12.3 |
| 1.2          | Special                                                                    | 12.4         |
| 1.3          | OSD                                                                        | 12.5         |
| 2            | GENERAL DESCRIPTION                                                        | 12.6         |
| 3            | ORDERING INFORMATION                                                       | 12.7         |
| 4            | BLOCK DIAGRAM                                                              | 13           |
| 5            | PINNING INFORMATION                                                        | 13.1         |
| 5.1          | Pinning                                                                    | 13.2<br>13.3 |
| 5.2          | Pin description                                                            | 15.0         |
| 6            | RESET                                                                      | 14           |
| 6.1          | Reset trip level                                                           | 15           |
| 6.2          | Reset status                                                               | 16           |
| 7            | ANALOG (DC) CONTROL                                                        | 16.1         |
| 7.1          | 6 and 7-bit PWM outputs                                                    | 17           |
| 7.2          | 14-bit PWM output                                                          | 18           |
| 7.3          | A typical PWM output application                                           |              |
| 8            | ANALOG-TO-DIGITAL CONVERTER (ADC)                                          | 19           |
| 8.1<br>8.2   | Conversion algorithm                                                       | 20           |
| -            | Typical ADC application                                                    | 21           |
| 9            | ON SCREEN DISPLAY (OSD)                                                    | 22           |
| 9.1<br>9.2   | Horizontal starting position control<br>Vertical starting position control | 23           |
| 9.3          | Vertical jumping cancelling                                                | 23.1         |
| 9.4          | On-chip clock generator                                                    | 23.2<br>23.3 |
| 10           | DISPLAY RAM ORGANIZATION                                                   | 23.0         |
| 10.1         | Description of display RAM codes                                           | 24<br>25     |
| 10.2         | Default values of OSD after Power-on-reset                                 |              |
| 10.3         | Loading character data into display RAM                                    | 26           |
| 10.4         | Writing character data into display RAM                                    |              |
| 11           |                                                                            |              |
| 11.1<br>11.2 | Character ROM address map<br>Character ROM organization                    |              |
| 11.2         |                                                                            |              |

Combination of character font cells

| 12           | OSD CONTROL REGISTERS                                         |
|--------------|---------------------------------------------------------------|
| 12.1         | Derivative Register 22                                        |
| 12.2         | Derivative Register 23                                        |
| 12.3         | Derivative Register 33                                        |
| 12.4<br>12.5 | Derivative Register 34                                        |
| 12.5         | Derivative Register 35<br>Derivative Register 36              |
| 12.7         | Derivative Register 37                                        |
| 13           | TO FORMAT THE OSD                                             |
| 13.1         | Number of characters per row                                  |
| 13.2         | Number of rows per frame                                      |
| 13.3         | Character size selection for different display<br>resolutions |
| 14           | I <sup>2</sup> C-BUS INTERFACE                                |
| 15           | 8-BIT COUNTER (T3)                                            |
| 16           | OUTPUT PORTS                                                  |
| 16.1         | Mask options                                                  |
| 17           | DERIVATIVE REGISTERS                                          |
| 18           | LIMITING VALUES                                               |
| 19           | DC CHARACTERISTICS                                            |
| 20           | AC CHARACTERISTICS                                            |
| 21           | DEVELOPMENT SUPPORT                                           |
| 22           | PACKAGE OUTLINE                                               |
| 23           | SOLDERING                                                     |
| 23.1         | Introduction                                                  |
| 23.2         | Soldering by dipping or by wave                               |
| 23.3         | Repairing soldered joints                                     |
| 24           | DEFINITIONS                                                   |
| 25           | LIFE SUPPORT APPLICATIONS                                     |
| 26           | PURCHASE OF PHILIPS I <sup>2</sup> C COMPONENTS               |

BUS

11.3

### PCE84C882

#### 1 FEATURES

#### 1.1 General

- CMOS 8-bit CPU (enhanced 8048 CPU) with 8 kbytes system ROM and 192 bytes system RAM
- One 8-bit timer/event counter (T1) and one 8-bit counter triggered by external input (T3)
- Four single level vectored interrupt sources: external (INTN), counter/timer, I<sup>2</sup>C-bus and VSYNCN
- 2 directly testable inputs T0 and T1
- On-chip oscillator clock frequency: 1 to 10 MHz
- · On-chip Power-on-reset with low power detector
- Twelve quasi-bidirectional I/O lines, configuration of each I/O line individually selected by mask option
- Idle and Stop modes for reduced power consumption
- Operating temperature: -25 to +85 °C
- Operating voltage: 4.5 to 5.5 V
- Package: SDIP42.

#### 1.2 Special

- Master-slave I<sup>2</sup>C-bus interface
- Three 6-bit Pulse Width Modulated outputs (PWM4; PWM6 and PWM7)
- Four 7-bit Pulse Width Modulated outputs (PWM0 to PWM3)
- One 14-bit Pulse Width Modulated output (PWM8)
- One 4-bit ADC channel
- 14 derivative I/O ports.

#### 1.3 OSD

- Maximum dot frequency (f<sub>OSD</sub>): 20 MHz (see Section 20 for details)
- Display RAM: 64 × 10 bits
- Display character fonts: 62 + 2 special reserved codes
- Character matrix: 12 × 18 (no spacing between characters)
- 4 character sizes: 1H/1V, 1H/2V, 1H/3V and 1H/4V
- 64 Horizontal starting positions (4 dots for each step)
- 64 Vertical starting positions (4 scan lines for each step)
- Vertical jumping cancelling circuit
- Spacing between character rows: 0, 4, 8 and 12 scan lines
- Foreground colours: 8 on a character-by-character basis

- · Background colours: 8 on a word-by-word basis
- Background/shadowing modes: 4 modes available, No background, North shadowing, Box shadowing and Frame shadowing (raster blanking) on a frame basis
- On-chip Phase-Locked Loop (PLL) oscillator (auto-sync with Hsync) with programmable oscillator for On Screen Display (OSD) function
- Character blinking frequency: programmable using f<sub>Vsync</sub> divisors of 16, 32, 64 and 128; on a frame basis
- Character blinking ratios: 1:1,1:3 and 3:1
- Programmable active level polarities of VSYNCN, HSYNCN, R, G, B and FB
- Flexible display format by using Carriage Return Code
- Auto display RAM address (DCRAR) incremented after write operation to the Character Data Register (DCRCR)
- VSYNCN generates an interrupt (enabled by software) when VIEN is active.

#### 2 GENERAL DESCRIPTION

The PCE84C882 is the enhanced version of the PCE84C886 having all the features of this device but in addition provides:

- Two dedicated power pins for the PLL oscillator circuit
- A choice of two mask-programmable prescaler values for the PLL oscillator
- · A higher frequency OSD clock up to 20 MHz
- An improved edge-sensitive counter (T3).

Differences between the PCE84C882 and the PCE84C886 are shown in Table 1 and also highlighted throughout the document.

The PCE84C882 is a member of the 84CXXX CMOS microcontroller family. It is suitable for use with auto-sync monitors handling mode detection, digital and DPMS control and has an enhanced OSD facility for menu driving applications. The device uses the PCE84CXX processor core and has 8 kbytes of ROM and 192 bytes of RAM. I/O requirements are catered for with 12 general purpose bidirectional I/O lines plus 14 derivative I/O lines. 8 PWM analog outputs are available for analog control purposes and one 4-bit ADC. The device has an 8-bit counter, for use in pulse counting applications; an 8-bit timer/counter with programmable clock and an on-chip programmable PLL oscillator that generates the OSD clock. A master-slave I<sup>2</sup>C-bus interface and 2 directly testable lines are also available. The block diagram of the PCE84C882 is shown in Fig.1.

#### Preliminary specification

# Microcontroller for monitor OSD and auto-sync applications

### PCE84C882

| Table 1 | Differences between the PCE84C882 and the PCE84C886 |
|---------|-----------------------------------------------------|
|         |                                                     |

| FEATURE                                   | PCE84C882        | PCE84C886       |
|-------------------------------------------|------------------|-----------------|
| Maximum dot frequency (f <sub>OSD</sub> ) | 20 MHz           | 14 MHz          |
| Maximum Hsync frequency                   | 90 kHz           | 64 kHz          |
| PLL prescaler value                       | 2 or 4           | 2               |
| Digital to Analogue Converter             | 1 channel        | 3 channels      |
| Pulse Width Modulated outputs             | 8 channels       | 9 channels      |
| Derivative I/O pins                       | 14               | 16              |
| Counter T3 input edge sensitivity         | 0.4 μs           | 1 μs            |
| Pin assignment                            |                  |                 |
| Pin 21                                    | V <sub>SSP</sub> | V <sub>SS</sub> |
| Pin 22                                    | С                | DP07/PWM7       |
| Pin 23                                    | V <sub>DDP</sub> | DP06/PWM6       |
| Pin 24                                    | DP05             | DP05/PWM5       |
| Pin 30                                    | V <sub>SS</sub>  | TEST/EMU        |
| Pin 37                                    | DP07/PWM7        | DP11/ADC1       |
| Pin 38                                    | DP06/PWM6        | DP10/ADC0       |
| Pin 41                                    | TEST/EMU         | С               |

#### **3 ORDERING INFORMATION**

| TYPE NUMBER |        | PACKAGE                                                 |          |  |  |  |
|-------------|--------|---------------------------------------------------------|----------|--|--|--|
| ITPE NUMBER | NAME   | DESCRIPTION                                             | VERSION  |  |  |  |
| PCE84C882   | SDIP42 | plastic shrink dual in-line package; 42 leads (600 mil) | SOT270-1 |  |  |  |

### Microcontroller for monitor OSD and auto-sync applications

#### 4 BLOCK DIAGRAM



### Microcontroller for monitor OSD and auto-sync applications

#### 5 PINNING INFORMATION

#### 5.1 Pinning



### 5.2 Pin description

### Table 2 SDIP42 package

| SYMBOL                 | PIN                               | DESCRIPTION                                                                     |
|------------------------|-----------------------------------|---------------------------------------------------------------------------------|
| FB                     | 1                                 | Video Fast Blanking output.                                                     |
| VOW2                   | 2                                 | Video character output VOW2.                                                    |
| VOW1/DP22              | 3                                 | Video character output VOW1 or Derivative Port line DP22.                       |
| VOW0/DP23              | 4                                 | Video character output VOW0 or Derivative Port line DP23.                       |
| VSYNCN                 | 5                                 | Vertical synchronization signal input.                                          |
| HSYNCN                 | 6                                 | Horizontal synchronization signal input.                                        |
| P10                    | 7                                 | Port line 10 or emulation input DXWR.                                           |
| P11                    | 8                                 | Port line 11 or emulation input DXRD.                                           |
| DP13/PWM8              | 9                                 | Derivative I/O port or PWM8 output.                                             |
| P12                    | 10                                | Port line 12 or emulation input DXALE.                                          |
| Т3                     | 11                                | Secondary 8-bit counter input (Schmitt trigger).                                |
| P14                    | 12                                | Port line 14 or emulation output DXINT.                                         |
| P00 to P07             | 13 to 20                          | General I/O port lines.                                                         |
| V <sub>SSP</sub>       | 21                                | Ground pin of PLL circuit.                                                      |
| С                      | 22                                | External low-pass filter for on-chip PLL OSD oscillator.                        |
| V <sub>DDP</sub>       | 23                                | Power supply pin of PLL circuit.                                                |
| DP00/PWM0 to DP07/PWM7 | 29, 28, 27, 26,<br>25, 24, 38, 37 | Derivative I/O ports or PWM outputs. Note that DP05 has no derivative function. |
| V <sub>SS</sub>        | 30                                | Ground pin.                                                                     |
| XTAL1 (IN)             | 31                                | Oscillator input pin for system clock.                                          |
| XTAL2 (OUT)            | 32                                | Oscillator output pin for system clock.                                         |
| RESET                  | 33                                | Reset input; active LOW input initializes device.                               |
| T1                     | 34                                | Direct testable pin or event counter input.                                     |
| INTN/T0                | 35                                | External interrupt or direct testable pin.                                      |
| DP12/ADC2              | 36                                | Derivative I/O port or ADC Channel 2 input.                                     |
| DP21/SCL               | 39                                | Derivative port line or I <sup>2</sup> C-bus clock input.                       |
| DP20/SDA               | 40                                | Derivative port line or I <sup>2</sup> C-bus data input.                        |
| TEST/EMU               | 41                                | Control input for testing and emulation mode, normally LOW.                     |
| V <sub>DD</sub>        | 42                                | Power supply.                                                                   |

#### 6 RESET

The  $\overline{\text{RESET}}$  pin may be used as an active LOW input to initialize the microcontroller to a defined state.

An active reset can be generated by driving the  $\overline{\text{RESET}}$  pin from an external logic device. Such an active reset pulse should not fall off before V<sub>DD</sub> has reached its f<sub>xtal</sub>-dependent minimum operating voltage.

A Power-on-reset can be generated using an external RC circuit. To avoid overload of the internal diode, an external diode should be added in parallel if  $C_{RESET} \ge 2.2 \ \mu F$ . The RC circuit is shown in Fig.3.

#### 6.1 Reset trip level

The RESET trip voltage level for the PCE84C882 is in the range 0.7 to 1.9 V.

If any input (for example Hsync) goes HIGH before  $V_{DD}$  is applied, latch-up may occur and in this situation the PCE84C882 cannot be reset. The cause and effect of latch-up is shown in Fig.4.

#### 6.2 Reset status

- Derivative Registers reset status; see Table 38 for details
- Program Counter 00H
- Memory Bank 0
- Register Bank 0
- Stack Pointer 00H
- All interrupts disabled
- Timer/event counter 1 stopped and cleared
- Timer pre-scaler modulo-32 (PS = 0)
- Timer flag cleared
- Serial I/O interface disabled (ESO = 0) and in slave receiver mode
- Idle and Stop mode cleared.









#### 7 ANALOG (DC) CONTROL

The PCE84C882 has eight Pulse Width Modulated (PWM) outputs for analog control purposes e.g. brightness, contrast, H-shift, V-shift, H-width, V-size, E-W, R (or G or B) gain control etc. Each PWM output generates a pulse pattern with a programmable duty cycle.

The eight PWM outputs are specified below:

- 3 PWM outputs with 6-bit resolution (PWM4, 6 and 7)
- 4 PWM outputs with 7-bit resolution (PWM0 to PWM3)
- 1 PWM output with 14-bit resolution (PWM8).

The 6 and 7-bit PWM outputs are described in Section 7.1; the 14-bit PWM output is described in Section 7.2 and a typical PWM output application is described in Section 7.3.

#### 7.1 6 and 7-bit PWM outputs

PWM outputs PWM0 to PWM4, PWM6 and PWM7, share the same pins as Derivative Port lines DP00 to DP04, DP06 and DP07, respectively. Selection of the pin function as either a PWM output or a Derivative Port line is achieved using the appropriate PWMnE bit in Register 21 (see Table 38).

The polarity of the PWM outputs is programmable and is selected by the P7LVL or the P6LVL bit in Register 23 (see Section 12.2). The state of the P7LVL bit determines the polarity of the 7-bit PWMs; the state of the P6LVL bit determines the polarity of the 6-bit PWMs.

The duty cycle of each PWM output is dependent upon the programmable contents of its associated data latch (Registers 10 to 17 respectively, Register 15 is not used as there is no PWM5 output). As the clock frequency of each PWM circuit is  $\frac{1}{3} \times f_{xtal}$ , the pulse width of the pulse generated can be calculated as shown below.

Pulse width = 
$$\frac{3 \times (PWMn)}{f_{xtal}}$$

Where (PWMn) is the decimal value held in the data latch.

The maximum repetition frequency  $(f_{PWM})$  of the 6 and 7-bit PWM outputs is shown below.

For the 6-bit PWM outputs: 
$$f_{PWM} = \frac{f_{xtal}}{192}$$

For the 7-bit PWM outputs:  $f_{PWM} = \frac{f_{xtal}}{384}$ 

The block diagram for the 6 and 7-bit PWM outputs is shown in Fig.5.





### Microcontroller for monitor OSD and auto-sync applications

#### 7.2 14-bit PWM output

PWM8 shares the same pin as Derivative Port line DP13. Selection of the pin function as either a PWM output or as a Derivative Port line is achieved using the PWM8E bit in Register 22 (see Section 12.1).

The block diagram for the 14-bit PWM output is shown in Fig.7 and comprises:

- Two 7-bit latches: PWM8L (Register 18) and PWM8H (Register 19)
- 14-bit data latch (PWMREG)
- 14-bit counter
- · Coarse pulse controller
- · Fine pulse controller
- Mixer.

Data is loaded into the 14-bit data latch (PWMREG) from the two 7-bit data latches (PWM8H and PWM8L) when either of these data latches is written to. The upper seven bits of PWMREG are used by the coarse pulse controller and determine the coarse pulse width; the lower seven bits are used by the fine pulse controller and determine in which subperiods fine pulses will be added. The outputs OUT1 and OUT2 of the coarse and fine pulse controllers are 'ORED' in the mixer to give the PWM8 output. The polarity of the PWM8 output is programmable and is selected by the P8LVL bit in Register 23, this is described in Section 12.2.

As the 14-bit counter is clocked by  $\frac{1}{3} \times f_{xtal}$ , the repetition times of the coarse and fine pulse controllers may be calculated as shown below.

Coarse controller repetition time:  $t_{sub} = \frac{384}{f_{xtal}}$ 

Fine controller repetition time:  $t_r = \frac{49152}{f_{xtal}}$ 

Figure 8 shows typical PWM8 outputs, with coarse adjustment only, for different values held in PWM8H. Figure 9 shows typical PWM8 outputs, with coarse and fine adjustment, after the coarse and fine pulse controller outputs have been 'ORED' by the mixer.

#### 7.2.1 COARSE ADJUSTMENT

An active HIGH pulse is generated in every subperiod; the pulse width being determined by the contents of PWM8H. The coarse output (OUT1) is LOW at the start of each subperiod and will remain LOW until the time

 $[3/f_{xtal} \times (PWM8H + 1)]$  has elapsed. The output will

then go HIGH and remain HIGH until the start of the next subperiod. The coarse pulse width may be calculated as shown below.

Pulse duration =  $(127 - PWM8H) \times \frac{3}{f_{xtal}}$ 

#### 7.2.2 FINE ADJUSTMENT

Fine adjustment is achieved by generating an additional pulse in specific subperiods. The pulse is added at the start of the selected subperiod and has a pulse width of  $3/f_{xtal}$ . The contents of PWM8L determine in which subperiods a fine pulse will be added. It is the logic 0 state of the value held in PWM8L that actually selects the subperiods. When more than one bit is a logic 0 then the subperiods selected will be a combination of those subperiods specified in Table 3. For example, if PWM8L = 111 1010 then this is a combination of:

- PWM8L = 111 1110: subperiod 64 and
- PWM8L = 111 1011: subperiods 16, 48, 80 and 112.

Pulses will be added in subperiods 16, 48, 64, 80 and 112. This example is illustrated in Fig.10.

When PWM8L holds 111 1111 fine adjustment is inhibited and the PWM8 output is determined only by the contents of PWM8H.

Table 3 Additional pulse distribution

| PWM8L    | ADDITIONAL PULSE IN SUBPERIOD            |
|----------|------------------------------------------|
| 111 1110 | 64                                       |
| 111 1101 | 32 and 96                                |
| 111 1011 | 16, 48, 80 and 112                       |
| 111 0111 | 8, 24, 40, 56, 72, 88, 104 and 120       |
| 110 1111 | 4, 12, 20, 28, 36, 44, 52116 and 124     |
| 101 1111 | 2, 6, 10, 14, 18, 22, 26, 30122 and 126  |
| 011 1111 | 1, 3, 5, 7, 9, 11, 13, 15, 17125 and 127 |









#### 7.3 A typical PWM output application

A typical PWM application is shown in Fig.11. The buffer is used to reduce jitter on the OSD. R1 and C1 form the integration network the time constant of which should be at least 5 times greater than the repetition period of the PWM output pattern. In order to smooth a changing PWM output a high value of C1 should be chosen. The value of C1 will normally be in the range 1 to  $10 \,\mu$ F. The potential divider chain formed by R2 and R3 is used only when the output voltage is to be offset. The output voltages for this application are calculated using Equations (1) and (2).

$$V_{max} = \frac{R3 \times supply voltage}{R3 + \frac{R1 \times R2}{R1 + R2}}$$
(1)

$$V_{min} = \frac{\frac{R1 \times R3}{R1 + R3} \times \text{supply voltage}}{R2 + \frac{R1 \times R3}{R1 + R3}}$$
(2)

The loop from the PWM pin through R1 and C1 to V<sub>SS</sub> will radiate high frequency energy pulses. In order to limit the effect of this unwanted radiation source, the loop should be kept short and a high value of R1 selected. The value of R1 will normally be in the range 3.3 to 100 k $\Omega$ . It is good practice to avoid sharing V<sub>SS</sub> (pin 30) with the return leads of other sensitive signals.



#### 8 ANALOG-TO-DIGITAL CONVERTER (ADC)

The single channel ADC comprises a 4-bit Digital-to-Analog Converter (DAC); a comparator; an analog channel selector and control circuitry. As the digital input to the 4-bit DAC is loaded by software (a subroutine in the program), it is known as a software ADC. The block diagram is shown in Fig.12.

The ADC input ADC2, shares the same pin as Derivative Port line DP12. Selection of the pin function as either an ADC input or as a Derivative Port line is achieved using bit ADCE2 in Register 22. When ADCE2 = 1, the ADC function is enabled (see Section 12.1).

The ADC channel selector is controlled by the ADCS1 and ADCS0 bits in Register 20. As the PCE84C882 provides only one ADC channel, ADCS1 bit must be set to a logic 1 and ADCS0 bit must be set to a logic 0. All other settings are invalid.

The 4-bit DAC analog output voltage (V<sub>ref</sub>) is determined by the decimal value of the data held in bits DAC0 to DAC3 of Register 20. V<sub>ref</sub> is calculated as shown in Equation (3) and Table 4 lists the V<sub>ref</sub> values assuming V<sub>DD</sub> = 5 V.

$$V_{ref} = \frac{V_{DD}}{16} \times (DAC \text{ value} + 1)$$
 (3)

When the analog input voltage is higher than  $V_{ref}$ , the COMP bit in Register 20 will be HIGH.

| DAC3 | DAC2 | DAC1 | DAC0 | V <sub>ref</sub> (V) |
|------|------|------|------|----------------------|
| 0    | 0    | 0    | 0    | 0.3125               |
| 0    | 0    | 0    | 1    | 0.6250               |
| 0    | 0    | 1    | 0    | 0.9375               |
| 0    | 0    | 1    | 1    | 1.2500               |
| 0    | 1    | 0    | 0    | 1.5625               |
| 0    | 1    | 0    | 1    | 1.8750               |
| 0    | 1    | 1    | 0    | 2.1875               |
| 0    | 1    | 1    | 1    | 2.5000               |
| 1    | 0    | 0    | 0    | 2.8125               |
| 1    | 0    | 0    | 1    | 3.1250               |
| 1    | 0    | 1    | 0    | 3.4375               |
| 1    | 0    | 1    | 1    | 3.7500               |
| 1    | 1    | 0    | 0    | 4.0625               |
| 1    | 1    | 0    | 1    | 4.3750               |
| 1    | 1    | 1    | 0    | 4.6875               |
| 1    | 1    | 1    | 1    | 5.0000               |

Table 4 Selection of V<sub>ref</sub>

#### 8.1 Conversion algorithm

There are many algorithms available to achieve the ADC conversion. The algorithm described below and shown in Fig.13 uses an iteration process.

- Enable and then select the ADC2 channel for conversion. Channel selection is achieved using bits ADCS1 and ADCS0 in Register 20.
- 2. Set the digital input to the DAC to 1000. The digital input to the DAC is selected using bits DAC3 to DAC0 in Register 20.
- 3. Determine the result of the compare operation. This is achieved by reading the COMP bit in Register 20 using the instruction MOV A, D20. If COMP = 1; the analog input voltage is higher than the reference voltage ( $V_{ref}$ ). If COMP = 0; the analog input voltage is lower than the reference voltage ( $V_{ref}$ ).
- 4. If COMP = 1; then the analog input voltage is higher than the reference voltage ( $V_{ref}$ ) and therefore the digital input to the DAC needs to be increased. Set the input to the DAC to 1100.
- 5. If COMP = 0; then the analog input voltage is lower than the reference voltage ( $V_{ref}$ ) and therefore the digital input to the DAC needs to be decreased. Set the input to the DAC to 0100.
- 6. Determine the result of the compare operation by reading the COMP bit in Register 20.
- 7. For the DAC = 1100 case

If COMP = 1; then the analog input voltage is still greater than  $V_{ref}$  and therefore the digital input to the DAC needs to be increased again. Set the input to the DAC to 1110.

If COMP = 0; then the analog input voltage is now less than  $V_{ref}$  and therefore the digital input to the DAC needs to be decreased. Set the input to the DAC to 1010

8. For the DAC = 0100 case

If COMP = 1; then the analog input voltage is now greater than  $V_{ref}$  and therefore the digital input to the DAC needs to be increased. Set the input to the DAC to 0110.

If COMP = 0; then the analog input voltage is still lower than  $V_{ref}$  and therefore the digital input to the DAC needs to be decreased again. Set the input to the DAC to 0010.

9. The operations detailed in 6, 7 and 8 above are repeated and each time the digital input to the DAC is changed accordingly; as dictated by the state of the COMP bit. The complete process is shown in Fig.13. Each time the DAC input is changed the number of values which the analog input can take is reduced by half. In this manner the actual analog value is honed into. The value of the analog input (V<sub>A</sub>) is determined using Equation (4):

$$V_{A} = \frac{V_{DD}}{16} \times (DAC \text{ value } + 1)$$
 (4)

As the conversion time of each compare operation is greater than 6  $\mu s$  but less than 9  $\mu s$ ; a NOP instruction is recommended to be used in between the instructions that change the value of V<sub>ref</sub>; select the ADC channel and read the COMP bit.





#### 0000 € ш Value = 0001COMP = LL. Value = 00100001 COMP = 0010 ... Value = 0011COMP = ш Value = 01000011 COMP = 0100 Value = 0101COMP = 1 Fig.13 Example of converting algorithm for software ADC. ⊢ Value =0110 0101 COMP = 0110 Value = 0111COMP = ш 0111 Value = 1000COMP = 1ы 1000 Value = 1001COMP = Value = 10101001 COMP = 1010 Value = 1011COMP = ш Value = 1100 1011 COMP = 11100 Value = 1101 COMP = F Value = 11101101 COMP = 1110 Value = 1111 COMP = **≯**[

#### 1996 Jan 08

#### 8.2 Typical ADC application

The ADC2 channel of the PCE84C882 can be used in keypad applications to detect and identify the operation of individual keys. The circuit for a 14-key application is shown in Fig.14.

When no key is depressed the input voltage at the DP12/ADC2 pin will be greater than  ${}^{15}\!\!/_{16} \times V_{DD}$  and if the DAC value selected is 1110 then the COMP bit will be HIGH. When any key is depressed the input voltage at the DP12/ADC2 pin will change, and as each key will generate its own unique input voltage, this can be measured by the ADC2 channel and the actual key depressed can then be identified.

The input voltage generated by the operation of any key (ignoring the effect of the 100 k $\Omega$  resistor) can be calculated as follows:

$$V_{ADCn} = \left[\frac{(n-0.5)}{16}\right] \times V_{DD}$$

Where n is the key number and can take any integer value in the range 1 to 14.

The input voltage at the ADC input will be influenced by the tolerance of the resistors and the length of the cable connecting the keypad to the monitor. In the worse case situation this may reduce the number of keys that can be uniquely detected and identified.



Fig.14 A typical ADC application for keypad detection.

#### 9 ON SCREEN DISPLAY (OSD)

The OSD feature of the PCE84C882 enables the user to display information on the monitor screen. Display information can be created using 62 customer designed characters, a space character and a carriage return code. The OSD block diagram is shown in Fig.15.

#### 9.1 Horizontal starting position control

The horizontal starting position counter is incremented every OSD clock after Hsync becomes inactive and is reset when Hsync becomes active. The horizontal starting position of the display row is determined by the contents of Register 36; 1 of 64 positions may be selected as explained in Section 12.6.

The polarity of the active state of the HSYNCN input is programmable and is determined by the Hp bit in Register 34; see Section 12.4. The active HIGH and active LOW states as selected by the Hp bit are shown in Fig.16.

#### 9.2 Vertical starting position control

The vertical starting position counter is incremented every Hsync cycle and is reset when Vsync becomes active. The vertical starting position of the display row is determined by the contents of Register 35; 1 of 64 positions may be selected as explained in Section 12.5.

To achieve the same starting position with different display resolutions, only the contents of Register 35 need to be changed, the contents of Register 36 remain the same. The lowest vertical starting position that can be selected, is located on the 256th scan-line. However, lower positions may be achieved using the Carriage Return Code.

When the selected horizontal and vertical starting positions are reached on screen; the OSD is enabled. The character selected in display RAM is then displayed.

The polarity of the active state of the VSYNCN input is programmable and is determined by the Vp bit in Register 34; see Section 12.4. The active HIGH and active LOW states as selected by the Vp bit are shown in Fig.16.

#### 9.3 Vertical jumping cancelling

If the H-shift of the monitor is altered then vertical jumping of the OSD may occur if the rising or falling edges of the Hsync and Vsync signals are too close. The PCE84C882 has on-chip vertical cancelling circuitry that prevents this from happening.

#### 9.4 On-chip clock generator

The on-chip oscillator generates an OSD clock that is auto-sync with Hsync. The frequency of the OSD clock is programmable and is determined by the contents of the 7-bit counter (Register 25) and also the prescaler value selected by mask option (a prescaler value of 2 or 4 can be selected). For 31 to 64 kHz auto-sync monitors, a prescaler value of 4 is selected; for 31 to 90 kHz auto-sync monitors a prescaler value of 2 or 4 can be selected.

The OSD clock frequency is calculated as follows:

$$f_{OSD} = f_{Hsvnc} \times (2 \text{ or } 4) \times (Register 25)$$

Where (Register 25) denotes the decimal value held in Register 25.

The block diagram of the OSD clock is shown in Fig.17. The internal reference frequency is connected to Hsync, and if the frequency of Hsync changes the output frequency ( $f_{OSD}$ ) will be changed linearly. The internal Hsync signal is designed active HIGH, consequently  $f_{PLL}$  is synchronized with the falling edge of this signal (end of back-tracing period).

The OSD clock is enabled/disabled by the state of the EN bit in Register 34; see Section 12.4. When the OSD clock is disabled the oscillator remains active, therefore the transient time from the OSD clock start-up to locking into the external Hsync signal is reduced. To ensure that the OSD clock is stable and in-phase with Hsync before the display is enabled, the End bit of the Space Code can be used to enable the OSD feature; the procedure is as follows.

- 1. Write a Space Code to address 00H of display RAM, the End bit value is logic 1.
- 2. Set the EN bit in Register 34 to logic 0.
- 3. Write a Space Code to address 00H of display RAM, the End bit value is logic 0.

Two dedicated power pins:  $V_{DDP}$  and  $V_{SSP}$ , isolate the oscillator supplies from other circuits thus reducing any radiated noise that might effect the Voltage Controlled Oscillator. Radiated noise is further reduced because as the oscillator is always active after power-on when the OSD clock is enabled no large currents will flow (as in the case of RC or LC oscillators).



PCE84C882

-11-Ŕ

 $\mathbb{R}_2$ 

ŧ





#### 10 DISPLAY RAM ORGANIZATION

The display RAM is organized as  $64 \times 10$  bits. The general format of each RAM location is as follows. Bits <9-4> hold character data (62 customer designed character fonts plus two reserved codes). Bits <3-0> contain the attributes of the character font, for example colour, character size, blinking etc.

Display RAM is updated during the vertical back-tracing period (Vsync will generate an interrupt when it becomes active).

10.1 Description of display RAM codes

There are three data formats for display RAM code:

- 1. Character Font Code
- 2. Carriage Return Code
- 3. Space Code.

The three data formats are shown in Tables 5, 6 and 7.

| 9  | 8                               | 7  | 6  | 5  | 4  | 3  | 2           | 1   | 0     |
|----|---------------------------------|----|----|----|----|----|-------------|-----|-------|
| C5 | C4                              | C3 | C2 | C1 | C0 | Т3 | T2          | T1  | T0    |
|    | Character Font Code (00H - 3DH) |    |    |    |    |    | eground col | our | Blink |

#### Table 6 Format of Carriage Return Code

| 9  | 8                          | 7  | 6  | 5  | 4  | 3  | 2        | 1      | 0      |
|----|----------------------------|----|----|----|----|----|----------|--------|--------|
| C5 | C4                         | C3 | C2 | C1 | C0 | T3 | T2       | T1     | T0     |
|    | Carriage Return Code (3EH) |    |    |    |    |    | ter size | Line S | pacing |

#### Table 7 Format of Space Code

| 9                | 8  | 7  | 6  | 5  | 4  | 3   | 2          | 1    | 0   |
|------------------|----|----|----|----|----|-----|------------|------|-----|
| C5               | C4 | C3 | C2 | C1 | C0 | T3  | T2         | T1   | Т0  |
| Space Code (3FH) |    |    |    |    |    | Bac | kground co | lour | End |

## Microcontroller for monitor OSD and auto-sync applications

#### 10.1.1 CHARACTER FONT CODE

If bits <9-4> are in the range (00H to 3DH), then this is a Character Font Code and 1 from 62 customer designed character fonts can be selected. Bits <3-1> determine the colour of the character, a choice of 8 colours being available. Bit <0> determines whether the character blinks or not. The blinking duty cycle and frequency are controlled by Derivative Register 33, see Section 12.3.

The format of the Character Font Code is shown in Table 5.

| T3<br>(RED) | T2<br>(GREEN) | T1<br>(BLUE) | COLOUR  |
|-------------|---------------|--------------|---------|
| 0           | 0             | 0            | black   |
| 0           | 0             | 1            | blue    |
| 0           | 1             | 0            | green   |
| 0           | 1             | 1            | cyan    |
| 1           | 0             | 0            | red     |
| 1           | 0             | 1            | magenta |
| 1           | 1             | 0            | yellow  |
| 1           | 1             | 1            | white   |

 Table 8
 Selection of Foreground colour

#### Table 9 Selection of Blinking function

| ТО | BLINKING |
|----|----------|
| 0  | OFF      |
| 1  | ON       |

#### 10.1.2 CARRIAGE RETURN CODE

If bits <9-4> hold 3EH, then this is the Carriage Return Code. The current display line is terminated (a transparent pattern appears on the screen) and the next character will be displayed at the beginning of the next line. Bits <3-2> select the size of the of the character to be displayed on the next line. Bits <1-0> determine the spacing between lines of displayed characters. Spacing is a multiple of the number of horizontal scan lines. The format of the Carriage Return Code is shown in Table 6.

#### Table 10 Selection of character size

| Т3 | T2 | CHARACTER DOT SIZE <sup>(1)</sup> |
|----|----|-----------------------------------|
| 0  | 0  | 1H/1V                             |
| 0  | 1  | 1H/2V                             |
| 1  | 0  | 1H/3V                             |
| 1  | 1  | 1H/4V                             |

#### Note

1. H is the OSD clock period; V is the number of horizontal scan lines per dot.

| Table 11 | Selection | of line | spacing |
|----------|-----------|---------|---------|
|----------|-----------|---------|---------|

| T1 | Т0 | LINE SPACING |
|----|----|--------------|
| 0  | 0  | 0H line      |
| 0  | 1  | 4H line      |
| 1  | 0  | 8H line      |
| 1  | 1  | 12H line     |

#### 10.1.3 SPACE CODE

If bits <9-4> hold 3FH, then this is the Space Code. A transparent pattern, equal to one character width, will be displayed on the screen. Bits <3-1> determine the background colour of the characters including the Space Code in Box shadowing mode, but following the Space Code in North shadowing mode. See Sections 12.4 and 12.3.1 for more details. Background colour selection is the same as foreground colour selection. Bit <0> is the End-of-Display bit and indicates the end of display of the current screen before exhaustion of display RAM (i.e. before the 64th RAM location). The format of the Space Code is shown in Table 7.

#### Table 12 End of display control

| то | DISPLAY CONTROL                                                      |
|----|----------------------------------------------------------------------|
| 0  | continue display of next character; this is also the default setting |
| 1  | end of display                                                       |

### Microcontroller for monitor OSD and auto-sync applications

#### 10.2 Default values of OSD after Power-on-reset

- Frequency of OSD clock: undefined, must be programmed
- Background/Shadowing mode: No background mode
- Background/Shadowing colour: blue
- Character size: 1H/1V
- OSD disabled
- Full 64 display RAM displayed (End of display bit = 0)
- VOW1E and VOW0E disabled
- Horizontal starting position: 5th dot
- Vertical starting position: 256th scan-line
- Polarity of HSYNCN: active LOW
- Polarity of VSYNCN: active LOW
- Output polarities of FB, VOW0 to VOW2: active HIGH
- Blinking ratio: 3 : 1
- Blinking frequency:  $\frac{1}{128} \times f_{Vsync}$
- Frame background colour: blue.

After a Power-on-reset, the OSD can be set-up as required by selecting the Space Code as the first character (address 0) and the Carriage Return Code as the next character (address 1). This procedure allows the user to select the initial background colour; character size and inter-line spacing.

#### 10.3 Loading character data into display RAM

Three Derivative Registers are used to address and load data into the display RAM. These registers are described below.

#### 10.3.1 DCR ADDRESS REGISTER (DCRAR)

This is Derivative Register 30 and holds the address of the location in display RAM to which the data held in registers DCRTR and DCRCR will be written to. 1 of 64 locations can be addressed. Bits 7 and 6 are reserved. The contents of this register are automatically incremented after each write operation to a RAM address, and become zero on overflow.

#### Table 13 DCR Address Register (DCRAR)

| 7 | 6 | 5  | 4  | 3  | 2  | 1  | 0  |
|---|---|----|----|----|----|----|----|
| - | - | A5 | A4 | A3 | A2 | A1 | A0 |

#### 10.3.2 DCR ATTRIBUTE REGISTER (DCRTR)

This is Derivative Register 31 and holds the character font attribute data. The data will be loaded into bits <3-0> of the location in RAM pointed to by the contents of DCRAR. Bits 7 to 4 are reserved.

#### Table 14 DCR Attribute Register (DCRTR)

| 7 | 6 | 5 | 4 | 3  | 2  | 1  | 0  |
|---|---|---|---|----|----|----|----|
| - | _ | _ | _ | T3 | T2 | T1 | T0 |

#### 10.3.3 DCR CHARACTER REGISTER (DCRCR)

This is Derivative Register 32 and holds the character data that will be loaded into bits <9-4> of the location in RAM addressed by the contents of DCRAR. Bits 7 and 6 are reserved.

#### Table 15 DCR Character Register (DCRCR)

| 7 | 6 | 5  | 4  | 3  | 2  | 1  | 0  |
|---|---|----|----|----|----|----|----|
| - | - | C5 | C4 | C3 | C2 | C1 | C0 |

#### 10.4 Writing character data into display RAM

The procedure for writing character data into the display RAM is as follows:

- 1. Select the start address in display RAM. The start address is stored in DCRAR and can take any value between 0 and 63.
- 2. Load the character attributes into DCRTR. If the attributes of a series of displayed characters are the same, only DCRCR needs to be updated.
- 3. Load the character data into DCRCR. The character data will specify either a Character Font Code, the Carriage Return Code or the Space Code. This operation loads the selected RAM location with the data held in registers DCRTR and DCRCR. The address held in DCRAR is then incremented by '1' pointing to the next RAM location in anticipation of the next operation.

After a master reset the contents of DCRAR, DCRTR and DCRCR are zero.

#### **11 CHARACTER ROM**

64 character fonts may be held in ROM; 62 customer selected character fonts plus the Carriage Return Code and the Space Code. Customer selected fonts are mask programmable. Each character font is stored in a  $12 \times 19$ dot matrix. However, only elements in Rows 1 to 18 can be selected as visible dots on the screen. Row 0 is only used for the combination of two characters in a vertical direction when North shadowing mode is selected.

#### 11.1 Character ROM address map

Figure 18 shows the ROM address map. Addresses 3EH and 3FH hold the reserved codes for carriage return and space functions, respectively. Addresses (00H to 3DH) hold the customer selected character font codes.

#### 11.2 Character ROM organization

ROM is divided into two parts: ROM1 and ROM2. The organization of the bit patterns stored in ROM 1 and ROM 2 and also the file format to submit to Philips for customized character sets is shown in Fig.19. Regarding Fig.19 the following points should be noted.

- 1. Row 0 of each font is reserved for vertical combination of two fonts.
- 2. Binary 1 denotes visual dots.
- ROM1 and ROM2 data files are in INTEL hex format on a byte basis. Each byte is structured high nibble followed by low nibble.
- 4. The unused last byte of each font in ROM1 must be filled with FFH.
- 5. The unused last  $2\frac{1}{2}$  bytes in ROM2 must be filled with the same data as held in the corresponding address in ROM1.
- 6. The data bytes of the last 2 reserved fonts (Carriage Return and Space Codes) should be filled with 00H.
- 7. CS denotes Checksum.

A software package (OSDGEM) that assists in the design of character fonts on-screen and that also automatically generates the bit pattern HEX files is available on request. The package is run under the MS-DOS environment for IBM compatible PCs.

#### 11.3 Combination of character font cells

Two (or more) character font cells may be combined in a horizontal or vertical direction to create a new higher resolution pattern.

The combination of two cells in a horizontal direction is straight forward and requires no special precautions to be taken. When combining character cells in this manner all 4 Background/Shadowing modes are available. An example of combining two character font cells in a horizontal direction is shown in Fig.20.

However, the combination of two character font cells in a vertical direction is more difficult and care must be taken; otherwise, the new pattern may be created with gaps in its shadowing. An example of a character pattern with gaps is shown in Fig.21. Providing the steps listed below are followed no problems with shadowing will occur.

- The line spacing between two rows of characters must be programmed to 0H. This procedure is explained in Section 10.1.2.
- If the North shadowing mode is selected then when combining two character cells in a vertical direction Row 0 must contain the same bit pattern as held in Row 18 of the character directly above it. This is shown in Fig.22.
- If North shadowing is not required then Row 0 should contain all zeros.







## Microcontroller for monitor OSD and auto-sync applications



## Microcontroller for monitor OSD and auto-sync applications



## Microcontroller for monitor OSD and auto-sync applications



#### 12 OSD CONTROL REGISTERS

The functions of the OSD are controlled by Derivative Registers 22, 23, 33, 34, 35, 36 and 37. An overview of the function of each register is given in Table 16. A full description of each register is given in Sections 12.1 to 12.7.

| REGISTER<br>NAME | REGISTER NUMBER        | ADDRESS<br>(HEX) | FUNCTION                                                                                                                                                                                    |
|------------------|------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CON1             | Derivative Register 22 | 22               | This register is used to enable PWM8; the I <sup>2</sup> C-bus lines; the ADC channel and the VOW0 and VOW1 lines.                                                                          |
| CON2             | Derivative Register 23 | 23               | This register selects the output polarity of the PWM outputs and also enables and selects the VSYNCN interrupt.                                                                             |
| CON3             | Derivative Register 33 | 33               | This register selects the blinking frequency and the active ratio of the blinking frequency for the OSD.                                                                                    |
| CON4             | Derivative Register 34 | 34               | This register selects the 4 display modes; the active state of HSYNCN and VSYNCN inputs and the output polarity of the FB and VOW0 to VOW2 outputs. It also enables/disables the OSD clock. |
| VPOS             | Derivative Register 35 | 35               | This register selects the vertical starting position of the display row.                                                                                                                    |
| HPOS             | Derivative Register 36 | 36               | This register selects the horizontal starting position of the display row.                                                                                                                  |
| FRC              | Derivative Register 37 | 37               | This register selects the background colour in Frame shadowing mode.                                                                                                                        |

 Table 16 OSD Control Registers overview

### PCE84C882

#### 12.1 Derivative Register 22

This register is used to enable PWM8; the I<sup>2</sup>C-bus lines; the ADC2 input and the VOW0 and VOW1 lines.

Table 17 Derivative Register 22

| 7     | 6    | 5    | 4     | 3     | 2     | 1     | 0     |
|-------|------|------|-------|-------|-------|-------|-------|
| PWM8E | SCLE | SDAE | ADC2E | ADC1E | ADC0E | VOW1E | VOW0E |

Table 18 Description of Derivative Register 22 bits

| BIT | SYMBOL | DESCRIPTION                                                                                                                                                                                                                           |
|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | PWM8E  | Pulse Width Modulated output PWM8 enable bit. When PWM8E = 1; pin 9 is selected as an output for PWM8. When PWM8E = 0; pin 9 is selected as Derivative Port line DP13 and the PWM function is disabled.                               |
| 6   | SCLE   | $I^2$ C-bus clock enable bit. When SCLE = 1; pin 39 is selected as the $I^2$ C-bus clock line.<br>When SCLE = 0; pin 39 is selected as Derivative Port line DP21 and the $I^2$ C-bus function is disabled.                            |
| 5   | SDAE   | I <sup>2</sup> C-bus data enable bit. When SDAE = 1; pin 40 is selected as the I <sup>2</sup> C-bus data line. When SDAE = 0; pin 40 is selected as Derivative Port line DP20 and the I <sup>2</sup> C-bus function is disabled.      |
| 4   | ADC2E  | ADC Channel 2 enable bit. The state of this bit determines whether pin 36 functions as an ADC input or as Derivative Port line. When $ADC2E = 1$ ; ADC channel 2 is enabled. When $ADC2E = 0$ ; Derivative Port line DP12 is enabled. |
| 3   | ADC1E  | As the PCE84C882 has only one ADC channel, these channel select bits are not used                                                                                                                                                     |
| 2   | ADC0E  | and both must be set to a logic 1.                                                                                                                                                                                                    |
| 1   | VOW1E  | VOW1E enable bit, When VOW1E = 1; pin 3 is selected as the VOW1 output. When VOW1E = 0; pin 3 is selected as Derivative Port line DP22 and the VOW function is disabled.                                                              |
| 0   | VOW0E  | VOW0E enable bit, When VOW0E = 1; pin 4 is selected as the VOW0 output. When VOW0E = 0; pin 4 is selected as Derivative Port line DP23 and the VOW function is disabled.                                                              |

### PCE84C882

#### 12.2 Derivative Register 23

This register selects the output polarity of the PWM outputs and also enables and selects the VSYNCN interrupt.

#### Table 19 Derivative Register 23

| 7    | 6    | 5 | 4 | 3 | 2     | 1     | 0     |
|------|------|---|---|---|-------|-------|-------|
| VINT | VIEN | — | - | — | P8LVL | P7LVL | P6LVL |

#### Table 20 Description of Derivative Register 23 bits

| BIT | SYMBOL | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | VINT   | VSYNCN/SIO interrupt indication bit. This bit indicates which of the two possible interrupt sources, the Vsync signal (at the VSYNCN pin) or the SIO, generated the interrupt. The interrupt causes the program to jump to the $I^2C$ interrupt subroutine at address 05H. If VINT = 1; then the interrupt was generated by Vsync. If VINT = 0; then the $I^2C$ -bus generated the interrupt. This bit must be reset after the interrupt has been serviced, otherwise additional unwanted interrupts will be generated.                                              |
| 6   | VIEN   | VSYNCN interrupt enable bit. When the SIO interrupt is enabled and VIEN = 1; the Vsync signal (at the VSYNCN pin) will generate an interrupt to the CPU. The VSYNCN interrupt is edge-triggered and can be selected to become active, using the Vp bit in Register 34, on the rising or falling edge of the Vsync signal. In order to generate a VSYNCN interrupt at the start of the vertical back tracing period, the Vp bit must be set correctly; see Section 12.4. The VSYNCN interrupt and the I <sup>2</sup> C-bus interrupt share the same interrupt vector. |
| 5   | _      | These three bits are reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 4   | _      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3   | _      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2   | P8LVL  | Polarity select bit for output PWM8. When $P8LVL = 0$ ; the PWM8 output is not inverted. When $P8VL = 1$ ; the PWM8 output is inverted.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1   | P7LVL  | Polarity select bit for outputs PWM0 to PWM3. When $P7LVL = 0$ ; the PWM outputs are not inverted. When $P8LVL = 1$ ; the PWM outputs are inverted.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0   | P6LVL  | Polarity select bit for outputs PWM4 to PWM7. When P6LVL = 0; the PWM outputs are not inverted. When P6LVL = 1; the PWM outputs are inverted.                                                                                                                                                                                                                                                                                                                                                                                                                        |

## Microcontroller for monitor OSD and auto-sync applications

#### 12.3 Derivative Register 33

Derivative Register 33 controls the character blinking functions.

#### Table 21 Derivative Register 33

| 7 | 6 | 5 | 4 | 3   | 2   | 1   | 0   |
|---|---|---|---|-----|-----|-----|-----|
| _ | _ | _ | - | BR1 | BR0 | BF1 | BF0 |

#### Table 22 Description of Derivative Register 33 bits

| BIT | SYMBOL | DESCRIPTION                                                                               |
|-----|--------|-------------------------------------------------------------------------------------------|
| 7   | _      | These 4 bits are reserved.                                                                |
| 6   | —      |                                                                                           |
| 5   | —      |                                                                                           |
| 4   | —      |                                                                                           |
| 3   | BR1    | Blinking active ratio select bits. These two bits allow one from a choice of three active |
| 2   | BR0    | blinking ratios to be selected; see Table 23.                                             |
| 1   | BF1    | Blinking frequency select bits. These two bits allow one from a choice of four blinking   |
| 0   | BF0    | frequencies to be selected; see Table 24.                                                 |

#### Table 23 Selection of Blinking active ratio

| BR1 | BR0 | ACTIVE RATIO                             |  |  |
|-----|-----|------------------------------------------|--|--|
| 0   | 0   | 3 : 1; this is also the default setting. |  |  |
| 0   | 1   | 1:1                                      |  |  |
| 1   | 0   | 1:3                                      |  |  |
| 1   | 1   | reserved                                 |  |  |

#### Table 24 Selection of Blinking frequency

| BF1 | BF0 | BLINKING FREQUENCY (Hz)                                     |
|-----|-----|-------------------------------------------------------------|
| 0   | 0   | f <sub>Vsync</sub><br>16                                    |
| 0   | 1   | f <sub>Vsync</sub><br>32                                    |
| 1   | 0   | f <sub>Vsync</sub> 64                                       |
| 1   | 1   | $\frac{f_{Vsync}}{128}$ ; this is also the default setting. |

#### 12.3.1 THE DISPLAY OF SPACE AND CARRIAGE RETURN CHARACTERS IN THE 4 DISPLAY MODES

Figures 23 to 26 show the display of Space and Carriage Return Characters in the 4 display modes, with the Blinking function ON and OFF.

- Mode 0: No background mode. Both the Space Code and the Carriage Return Code are displayed as transparent (no bit) patterns, with the video signal as the background. This is shown in Fig.23.
- Mode 1: North shadowing mode. Both codes are displayed in the same manner as for Mode 0. This is shown in Fig.24.
- In Mode 2: Box shadowing mode. The Space Code is displayed as a transparent pattern with selected background colour. This will also be the background colour of the character following the Space Code. However, when the Space Code is used as an end bit, it will be displayed as a transparent pattern superimposed on the video (see Fig.30). The Carriage Return Code in Mode 2 is also displayed as a transparent pattern superimposed on the video signal.
- Mode 3: Frame shadowing mode. The Space Code and the Carriage Return Code are both displayed as transparent patterns with background colour (see Fig.26).









#### 12.4 Derivative Register 34

This register selects the 4 display modes; the active state of signal at the HSYNCN and VSYNCN inputs and the output polarity of the FB and VOW0 to VOW2 outputs. It also enables/disables the OSD clock.

#### Table 25 Derivative Register 34

| 7 | 6 | 5  | 4  | 3  | 2  | 1  | 0  |
|---|---|----|----|----|----|----|----|
| — | — | S1 | S0 | Нр | Vp | Вр | EN |

#### Table 26 Description of Derivative Register 34 bits

| BIT | SYMBOL | DESCRIPTION                                                                                                                                                                                                                            |
|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | -      | These two bits are reserved.                                                                                                                                                                                                           |
| 6   | -      |                                                                                                                                                                                                                                        |
| 5   | S1     | Display mode select bits; see Table 27.                                                                                                                                                                                                |
| 4   | S0     |                                                                                                                                                                                                                                        |
| 3   | Нр     | HSYNCN signal polarity control bit. When $Hp = 0$ , the active level of the signal at the HSYNCN input is LOW; this is also the default state. When $Hp = 1$ , the active level of the signal at the HSYNCN input is HIGH. See Fig.16. |
| 2   | Vp     | VSYNCN signal polarity control bit. When $Vp = 0$ , the active level of the signal at the VSYNCN input is LOW; this is also the default state. When $Vp = 1$ , the active level of the signal at the VSYNCN input is HIGH. See Fig.16. |
| 1   | Вр     | Output polarity control bit for FB, VOW0, VOW1 and VOW2. When Bp = 1; these outputs are active HIGH; this is also the default state. When Bp = 0; these outputs are active LOW.                                                        |
| 0   | EN     | OSD clock enable/disable bit. When EN = 1; the OSD clock is enabled. When EN = 0; the OSD clock is disabled.                                                                                                                           |

#### Table 27 Selection of Display Modes

| S1 | S0 | DISPLAY MODE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----|----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0  | 0  | Mode 0: No background (superimpose) mode. The OSD characters are superimposed on the monitor video signals. See Fig.27.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0  | 1  | Mode 1: North shadowing mode. The characters' shadows are generated as if a light source was placed North of the character (see Fig.28). Character shadowing only appears within the cell boundary. Consequently, if Row 18 contains a bit pattern then North shadowing will not be shown on the screen (see Fig.20). The depth of shadow displayed is dependent upon the character size; characters with sizes of 1H/1V; 1H/2V and 1H/3V have a depth of shadow equivalent to 1 scan line whereas a character of size 1H/4V has a depth of shadow equivalent to 2 scan lines. Examples of characters with North shadowing, for the 4 character size, are shown in Fig.29. |
| 1  | 0  | Mode 2: Box shadowing mode. A background dot matrix of $12 \times 18$ bits surrounds the character font; where there is no foreground dot a background dot is displayed (see Fig.30).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1  | 1  | Mode 3: Frame shadowing mode. A background colour fills the whole screen when no bit patterns are being displayed (see Fig.31). 1 of 8 background colours can be selected using Derivative Register 37; the default background colour is blue.                                                                                                                                                                                                                                                                                                                                                                                                                             |













PCE84C882

# Microcontroller for monitor OSD and auto-sync applications

#### 12.5 Derivative Register 35

Derivative Register 35 selects the vertical starting position of the display row.

#### Table 28 Derivative Register 35

| 7 | 6 | 5  | 4  | 3  | 2  | 1  | 0  |
|---|---|----|----|----|----|----|----|
| - | - | V5 | V4 | V3 | V2 | V1 | V0 |

#### Table 29 Description of Derivative Register 35 bits.

| BIT | SYMBOL | DESCRIPTION                                                                                                      |
|-----|--------|------------------------------------------------------------------------------------------------------------------|
| 7   | _      | These 2 bits are reserved.                                                                                       |
| 6   | _      |                                                                                                                  |
| 5   | V5     | These 6 bits enable 1 of 64 vertical start positions to be selected for the display row.                         |
| 4   | V4     | The vertical starting position is calculated as follows:                                                         |
| 3   | V3     | $VP = [4 \times (V5 \rightarrow V0)] \times horizontal scan lines$                                               |
| 2   | V2     | Where (V5 $\rightarrow$ V0) is the decimal value of the contents of Register 35; (V5 $\rightarrow$ V0) $\geq$ 0. |
| 1   | V1     |                                                                                                                  |
| 0   | V0     |                                                                                                                  |

#### 12.6 Derivative Register 36

Derivative Register 36 selects the horizontal starting position of the display row.

#### Table 30 Derivative Register 36

| 7 | 6 | 5  | 4  | 3  | 2  | 1  | 0  |
|---|---|----|----|----|----|----|----|
| _ | _ | H5 | H4 | H3 | H2 | H1 | HO |

#### Table 31 Description of Derivative Register 36 bits

| BIT | SYMBOL | DESCRIPTION                                                                                                      |
|-----|--------|------------------------------------------------------------------------------------------------------------------|
| 7   | _      | These 2 bits are reserved.                                                                                       |
| 6   | _      |                                                                                                                  |
| 5   | H5     | These 6 bits enable 1 of 64 horizontal start positions to be selected for the display row.                       |
| 4   | H4     | The horizontal starting position is calculated as follows:                                                       |
| 3   | H3     | $HP = [4 \times (H5 \rightarrow H0) + 5] \times OSD \ clock$                                                     |
| 2   | H2     | Where (H5 $\rightarrow$ H0) is the decimal value of the contents of Register 36; (H5 $\rightarrow$ H0) $\geq$ 2. |
| 1   | H1     |                                                                                                                  |
| 0   | H0     |                                                                                                                  |

PCE84C882

## Microcontroller for monitor OSD and auto-sync applications

#### 12.7 Derivative Register 37

Derivative Register 37 selects the background colour when the OSD is in Frame shadowing mode.

#### Table 32 Derivative Register 37

| 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0   |
|---|---|---|---|---|-----|-----|-----|
| _ | _ | _ | _ | _ | FRR | FRG | FRB |

#### Table 33 Description of Derivative Register 37 bits

| BIT | SYMBOL | DESCRIPTION                                                                        |
|-----|--------|------------------------------------------------------------------------------------|
| 7   | _      | These 5 bits are reserved.                                                         |
| 6   | —      |                                                                                    |
| 5   | _      |                                                                                    |
| 4   | —      |                                                                                    |
| 3   | —      |                                                                                    |
| 2   | FRR    | These three bits are used to select the background colour in Frame shadowing mode; |
| 1   | FRG    | see Table 34. The default colour is blue.                                          |
| 0   | FRB    |                                                                                    |

#### Table 34 Selection of Background colour

| FRR<br>(RED) | FRG<br>(GREEN) | FRB<br>(BLUE) | COLOUR  |
|--------------|----------------|---------------|---------|
| 0            | 0              | 0             | black   |
| 0            | 0              | 1             | blue    |
| 0            | 1              | 0             | green   |
| 0            | 1              | 1             | cyan    |
| 1            | 0              | 0             | red     |
| 1            | 0              | 1             | magenta |
| 1            | 1              | 0             | yellow  |
| 1            | 1              | 1             | white   |

#### 13 TO FORMAT THE OSD

#### 13.1 Number of characters per row

The number of characters per row is a function of character width. The width of the character displayed is only dependent upon the value held in the 7-bit programmable counter (PLLCN) and is not affected by a change in horizontal resolution (any change in  $f_{Hsync}$  will be reflected by a linear change in the frequency of the OSD clock).

The maximum number of characters per row can be determined by calculating the number of OSD clock pulses that occur during the Hsync active period and dividing the result by the number of horizontal dots in the character matrix (which is 12). If Hsync is assumed to be active for 85% of its cycle period then the maximum number of characters per row (N) can be calculated as follows:

$$N = \frac{0.85 \times f_{OSD}}{12 \times f_{Hsvnc}}$$

#### 13.2 Number of rows per frame

The number of rows per frame is a function of character height and the spacing between the rows of characters.

The height of a character displayed on the screen is determined by the number of visible scan lines per frame and the character size. The number of scan lines is dependent upon the resolution of the monitor; character size is selected by the user (see Section 10.1.2). The PCE84C882 also provides a choice of four inter-line spaces: 0H, 4H, 8H and 12H (see Section 10.1.2).

If the inter-line spacing is assumed to be zero then the number of rows per frame (R) can be calculated by dividing the number of visible scan lines (SL) by the character size (CS) and dividing the result by the number of vertical dots in the character matrix (which is 18). This can be expressed mathematically as follows:

$$\mathsf{R} = \frac{\mathsf{SL}}{18 \times \mathsf{CS}}$$

Table 35 shows the number of rows per frame for different horizontal resolutions.

### 13.3 Character size selection for different display resolutions

To cater for the variable display resolutions (i.e. 640 x 400,  $640 \times 480$ ,  $800 \times 600$ ,  $1024 \times 768$  and  $1280 \times 1024$ ) of auto-sync monitors, the PCE84C882 offers a choice of 4 different character sizes: 1H/1V, 1H/2V, 1H/3V and 1H/4V. This allows the height of displayed characters to be of similar size even when the monitors resolution is changed (see Table 35).

| RESOLUTION     | CHARACTER<br>SIZE | ROWS/FRAME |
|----------------|-------------------|------------|
| 640 × 400      | 1H/2V             | 11         |
| 640 × 480      | 1H/3V             | 13         |
| 800 × 600      | 1H/3V             | 11         |
| 1024 	imes 768 | 1H/4V             | 10         |
| 1280×1024      | 1H/4V             | 14         |

#### Table 35 Recommended character size selection for different display resolutions

#### 14 I<sup>2</sup>C-BUS INTERFACE

The PCE84C882 has an on-chip  $I^2$ C-bus interface that can be used in master or slave mode. Full details of the  $I^2$ C-bus are given in the document *"The I<sup>2</sup>C-bus and how to use it"*. This document may be ordered using the code 9398 393 40011.

The  $l^2$ C-bus interface lines SDA and SCL share the same pins as Derivative Port lines DP20 and DP21 respectively. Selection of the pin function as either an  $l^2$ C-bus line or a Derivative Port line is achieved using the SDAE and SCLE bits in Derivative Register 22 (see Section 12.1). Only port Option 2 is available for both of these pins.

### PCE84C882

Preliminary specification

#### 15 8-BIT COUNTER (T3)

One application for this counter is in the frequency measurement of the Hsync signal.

The block diagram of the 8-bit counter is shown in Fig.33. A Schmitt trigger is used at the input for noise rejection and also to shape the input signal into a square wave. The T3 input is sampled at a frequency of  $1/_3 \times f_{osc}$  by the sample clock which synchronizes the internal T3 clock and the read operation of Derivative Register 24. The rising edge of the input increments the ripple counter by 1.

The contents of T3 may be read using the instruction MOV A, D24 (where D24 is Derivative Register 24). As soon as the data is read, the counter is reset to zero. A counter overflow or Power-on-reset also resets the counter contents to zero.

If the rising and falling edges of the input pulse are less than 30 ns then the minimum pulse width that the T3 input will recognise is  $3/f_{osc} + 100$  ns. If the system clock is 10 MHz then the minimum pulse width is 400 ns. In some display modes, the active pulse width of the Hsync signal can be less than 400 ns. In this situation, extra hardware circuitry may be necessary.





#### **16 OUTPUT PORTS**

Each I/O port line may be individually configured using one of three mask options. The three I/O mask options are specified below:

- Option 1 Standard input/output with switched pull-up current source; this is shown in Fig.34.
- Option 2 Input/output with Open drain output; this is shown in Fig.35.
- Option 3 Push-pull output; this is shown in Fig.36.

The state of each output port after a Power-on-reset can also be selected using the mask options. All port mask options are given in Section 16.1.







### PCE84C882

#### 16.1 Mask options

Table 36 lists the port mask options for the PCE84C882. Table 37 is intended for customer use when ordering the device.

#### Table 36 Port options

| DODT | PIN | OPT           | ION         |
|------|-----|---------------|-------------|
| PORT |     | CONFIGURATION | RESET STATE |
| P00  | 13  | 1, 2 or 3     | HIGH or LOW |
| P01  | 14  | 1, 2 or 3     | HIGH or LOW |
| P02  | 15  | 1, 2 or 3     | HIGH or LOW |
| P03  | 16  | 1, 2 or 3     | HIGH or LOW |
| P04  | 17  | 1, 2 or 3     | HIGH or LOW |
| P05  | 18  | 1, 2 or 3     | HIGH or LOW |
| P06  | 19  | 1, 2 or 3     | HIGH or LOW |
| P07  | 20  | 1, 2 or 3     | HIGH or LOW |
| P10  | 7   | 1, 2 or 3     | HIGH or LOW |
| P11  | 8   | 1, 2 or 3     | HIGH or LOW |
| P12  | 10  | 1, 2 or 3     | HIGH or LOW |
| P14  | 12  | 1, 2 or 3     | HIGH or LOW |
| DP00 | 29  | 1, 2 or 3     | HIGH or LOW |
| DP01 | 28  | 1, 2 or 3     | HIGH or LOW |
| DP02 | 27  | 1, 2 or 3     | HIGH or LOW |
| DP03 | 26  | 1, 2 or 3     | HIGH or LOW |
| DP04 | 25  | 1, 2 or 3     | HIGH or LOW |
| DP05 | 24  | 1, 2 or 3     | HIGH or LOW |
| DP06 | 38  | 1, 2 or 3     | HIGH or LOW |
| DP07 | 37  | 1, 2 or 3     | HIGH or LOW |
| DP12 | 36  | 1, 2 or 3     | HIGH or LOW |
| DP13 | 9   | 1, 2 or 3     | HIGH or LOW |
| DP20 | 40  | 2             | HIGH        |
| DP21 | 39  | 2             | HIGH        |
| DP22 | 3   | 1, 2 or 3     | HIGH or LOW |
| DP23 | 4   | 1, 2 or 3     | HIGH or LOW |
| FB   | 1   | 2 or 3        | HIGH or LOW |
| VOW2 | 2   | 2 or 3        | HIGH or LOW |

#### Table 37 Customer selected mask options

| DODT |     | OPTION        |             |  |  |  |  |  |
|------|-----|---------------|-------------|--|--|--|--|--|
| PORT | PIN | CONFIGURATION | RESET STATE |  |  |  |  |  |
| P00  | 13  |               |             |  |  |  |  |  |
| P01  | 14  |               |             |  |  |  |  |  |
| P02  | 15  |               |             |  |  |  |  |  |
| P03  | 16  |               |             |  |  |  |  |  |
| P04  | 17  |               |             |  |  |  |  |  |
| P05  | 18  |               |             |  |  |  |  |  |
| P06  | 19  |               |             |  |  |  |  |  |
| P07  | 20  |               |             |  |  |  |  |  |
| P10  | 7   |               |             |  |  |  |  |  |
| P11  | 8   |               |             |  |  |  |  |  |
| P12  | 10  |               |             |  |  |  |  |  |
| P14  | 12  |               |             |  |  |  |  |  |
| DP00 | 29  |               |             |  |  |  |  |  |
| DP01 | 28  |               |             |  |  |  |  |  |
| DP02 | 27  |               |             |  |  |  |  |  |
| DP03 | 26  |               |             |  |  |  |  |  |
| DP04 | 25  |               |             |  |  |  |  |  |
| DP05 | 24  |               |             |  |  |  |  |  |
| DP06 | 38  |               |             |  |  |  |  |  |
| DP07 | 37  |               |             |  |  |  |  |  |
| DP12 | 36  |               |             |  |  |  |  |  |
| DP13 | 9   |               |             |  |  |  |  |  |
| DP20 | 40  | 2             | S           |  |  |  |  |  |
| DP21 | 39  | 2             | S           |  |  |  |  |  |
| DP22 | 3   |               |             |  |  |  |  |  |
| DP23 | 4   |               |             |  |  |  |  |  |
| FB   | 1   |               |             |  |  |  |  |  |
| VOW2 | 2   |               |             |  |  |  |  |  |

#### **17 DERIVATIVE REGISTERS**

The PCE84C882 has 29 Derivative Registers. The Derivative Port I/O registers are located at addresses 00 to 05H. When DP0TR, DP1TR and DP2TR are read the data is read directly from the pin. However, when DP0R, DP1R and DP2R are read the data is read from the port latch (see Figs 34 to 36 for the port configuration).

As the PCE84C882 has no PWM5 output the corresponding enable bit (PWM5E) in the PWME Register (address 21H) must be set to a logic 0.

As the PCE84C882 has only one ADC channel the channel select bits (ADCS1 and ADCS0) in the ADCCN Register (address 20H) and the pin function enable bits (ADCE1 and ADCE0) in the CON1 Register (address 22H) must be set to the values specified in Chapter 8.

| ADDR<br>(HEX) | REG   | 7           | 6             | 5             | 4             | 3             | 2             | 1             | 0                          | R/W |
|---------------|-------|-------------|---------------|---------------|---------------|---------------|---------------|---------------|----------------------------|-----|
| 00            | DP0TR | DP07<br>(X) | DP06<br>(X)   | DP05<br>(X)   | DP04<br>(X)   | DP03<br>(X)   | DP02<br>(X)   | DP01<br>(X)   | DP00<br>(X)                | R   |
| 01            | DP1TR | –<br>(X)    | -<br>(X)      | -<br>(X)      | _<br>(X)      | DP13<br>(X)   | DP12<br>(X)   | _             | _                          | R   |
| 02            | DP2TR | -<br>(X)    | -<br>(X)      | -<br>(X)      | -<br>(X)      | DP23<br>(X)   | DP22<br>(X)   | DP21<br>(X)   | DP20<br>(X)                | R   |
| 03            | DP0R  | DP07<br>(1) | DP06<br>(1)   | DP05<br>(1)   | DP04<br>(1)   | DP03<br>(1)   | DP02<br>(1)   | DP01<br>(1)   | DP00<br>(1)                | RW  |
| 04            | DP1R  | -<br>(X)    | -<br>(X)      | -<br>(X)      | -<br>(X)      | DP13<br>(1)   | DP12<br>(1)   | DP11<br>(1)   | DP10<br>(1)                | RW  |
| 05            | DP2R  | -<br>(X)    | -<br>(X)      | -<br>(X)      | -<br>(X)      | DP23<br>(1)   | DP22<br>(1)   | DP21<br>(1)   | DP20<br>(1)                | RW  |
| 10            | PWM0  | -<br>(X)    | PWM06<br>(0)  | PWM05<br>(0)  | PWM04<br>(0)  | PWM03<br>(0)  | PWM02<br>(0)  | PWM01<br>(0)  | PWM00<br>(0)               | RW  |
| 11            | PWM1  | -<br>(X)    | PWM16<br>(0)  | PWM15<br>(0)  | PWM14<br>(0)  | PWM13<br>(0)  | PWM12<br>(0)  | PWM11<br>(0)  | PWM10<br>(0)               | RW  |
| 12            | PWM2  | -<br>(X)    | PWM26<br>(0)  | PWM25<br>(0)  | PWM24<br>(0)  | PWM23<br>(0)  | PWM22<br>(0)  | PWM21<br>(0)  | PWM20<br>(0)               | RW  |
| 13            | PWM3  | -<br>(X)    | PWM36<br>(0)  | PWM35<br>(0)  | PWM34<br>(0)  | PWM33<br>(0)  | PWM32<br>(0)  | PWM31<br>(0)  | PWM30<br>(0)               | RW  |
| 14            | PWM4  | -<br>(X)    | -<br>(X)      | PWM45<br>(0)  | PWM44<br>(0)  | PWM43<br>(0)  | PWM42<br>(0)  | PWM41<br>(0)  | PWM40<br>(0)               | RW  |
| 16            | PWM6  | -<br>(X)    | -<br>(X)      | PWM65<br>(0)  | PWM64<br>(0)  | PWM63<br>(0)  | PWM62<br>(0)  | PWM61<br>(0)  | PWM60<br>(0)               | RW  |
| 17            | PWM7  | -<br>(X)    | -<br>(X)      | PWM75<br>(0)  | PWM74<br>(0)  | PWM73<br>(0)  | PWM72<br>(0)  | PWM71<br>(0)  | PWM70<br>(0)               | RW  |
| 18            | PWM8L | -<br>(X)    | PWM86L<br>(0) | PWM85L<br>(0) | PWM84L<br>(0) | PWM83L<br>(0) | PWM82L<br>(0) | PWM81L<br>(0) | PWM80L<br>(0)              | RW  |
| 19            | PWM8H | -<br>(X)    | PWM86H<br>(0) | PWM85H<br>(0) | PWM84H<br>(0) | PWM83H<br>(0) | PWM82H<br>(0) | PWM81H<br>(0) | PWM80H<br>(0)              | RW  |
| 20            | ADCCN | -<br>(X)    | ADCS1<br>(0)  | ADCS0<br>(0)  | DAC3<br>(0)   | DAC2<br>(0)   | DAC1<br>(0)   | DAC0<br>(0)   | COMP <sup>(2)</sup><br>(0) | RW  |

Table 38 Register map (see note 1)

### PCE84C882

| ADDR<br>(HEX) | REG   | 7            | 6            | 5            | 4            | 3            | 2            | 1            | 0            | R/W |
|---------------|-------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|-----|
| 21            | PWME  | PWM7E<br>(0) | PWM6E<br>(0) | PWM5E<br>(0) | PWM4E<br>(0) | PWM3E<br>(0) | PWM2E<br>(0) | PWM1E<br>(0) | PWM0E<br>(0) | RW  |
| 22            | CON1  | PWM8E<br>(0) | SCLE<br>(0)  | SDAE<br>(0)  | ADCE2<br>(0) | ADCE1<br>(0) | ADCE0<br>(0) | VOW1E<br>(0) | VOW0E<br>(0) | RW  |
| 23            | CON2  | VINT<br>(0)  | VIEN<br>(0)  | -<br>(X)     | -<br>(X)     | -<br>(X)     | P8LVL<br>(0) | P7LVL<br>(0) | P6LVL<br>(0) | RW  |
| 24            | T3CON | T3B7<br>(0)  | T3B6<br>(0)  | T3B5<br>(0)  | T3B4<br>(0)  | T3B3<br>(0)  | T3B2<br>(0)  | T3B1<br>(0)  | T3B0<br>(0)  | R   |
| 25            | PLLCN | -<br>(X)     | PLL6<br>(0)  | PLL5<br>(0)  | PLL4<br>(0)  | PLL3<br>(0)  | PLL2<br>(0)  | PLL1<br>(0)  | PLL0<br>(0)  | RW  |
| 30            | DCRAR | -<br>(X)     | -<br>(X)     | DCRA5<br>(0) | DCRA4<br>(0) | DCRA3<br>(0) | DCRA2<br>(0) | DCRA1<br>(0) | DCRA0<br>(0) | RW  |
| 31            | DCRTR | -<br>(X)     | -<br>(X)     | -<br>(X)     | -<br>(X)     | DCRT3<br>(1) | DCRT2<br>(1) | DCRT1<br>(1) | DCRT0<br>(1) | W   |
| 32            | DCRCR | -<br>(X)     | -<br>(X)     | DCRC5<br>(1) | DCRC4<br>(1) | DCRC3<br>(1) | DCRC2<br>(1) | DCRC1<br>(1) | DCRC0<br>(1) | W   |
| 33            | CON3  | -<br>(X)     | -<br>(X)     | -<br>(X)     | -<br>(X)     | BR1<br>(0)   | BR0<br>(0)   | BF1<br>(1)   | BF0<br>(1)   | RW  |
| 34            | CON4  | -<br>(X)     | -<br>(X)     | S1<br>(0)    | S0<br>(0)    | Hp<br>(0)    | Vp<br>(0)    | Вр<br>(1)    | EN<br>(0)    | RW  |
| 35            | VPOS  | -<br>(X)     | -<br>(X)     | V5<br>(1)    | V4<br>(1)    | V3<br>(1)    | V2<br>(1)    | V1<br>(1)    | V0<br>(1)    | W   |
| 36            | HPOS  | -<br>(X)     | -<br>(X)     | H5<br>(0)    | H4<br>(0)    | H3<br>(0)    | H2<br>(0)    | H1<br>(0)    | H0<br>(0)    | W   |
| 37            | FRC   | -<br>(X)     | -<br>(X)     | -<br>(X)     | -<br>(X)     | -<br>(X)     | FRR<br>(0)   | FRG<br>(0)   | FRB<br>(1)   | W   |

#### Notes

1. Values within parethesis show the bit state after a reset operation. 'X' denotes an undefined state.

2. This bit is Read only.

#### **18 LIMITING VALUES**

In accordance with the Absolute Maximum Rating System (IEC 34)

| SYMBOL           | PARAMETER                                                          |      | MAX.                  | UNIT |
|------------------|--------------------------------------------------------------------|------|-----------------------|------|
| V <sub>DD</sub>  | supply voltage                                                     | -0.3 | +8.0                  | V    |
| VI               | input voltage on any pin with respect to ground (V <sub>SS</sub> ) | -0.3 | V <sub>DD</sub> + 0.3 | V    |
| I <sub>OH</sub>  | maximum source current for all port lines                          | -    | -10.0                 | mA   |
| I <sub>OL</sub>  | maximum sink current for all port lines                            | -    | 30.0                  | mA   |
| P <sub>tot</sub> | total power dissipation                                            | -    | 1                     | W    |
| T <sub>amb</sub> | operating ambient temperature                                      | -25  | +85                   | °C   |
| T <sub>stg</sub> | storage temperature                                                | -55  | +125                  | °C   |

### PCE84C882

### **19 DC CHARACTERISTICS**

 $V_{DD} = 5 \text{ V} \pm 10\%; \text{ V}_{SS} = 0 \text{ V}; \text{ T}_{amb} = -25 \text{ to } +85 \text{ °C}; \text{ all voltages with respect to } \text{V}_{SS}; \text{ unless otherwise specified.}$ 

| SYMBOL           | PARAMETER                                  | CONDITIONS                                              | MIN.               | TYP. | MAX.               | UNIT |
|------------------|--------------------------------------------|---------------------------------------------------------|--------------------|------|--------------------|------|
| Supply           |                                            |                                                         | 1                  | 1    | 1                  |      |
| V <sub>DD</sub>  | operating supply voltage                   |                                                         | 4.5                | 5.0  | 5.5                | V    |
| I <sub>DD</sub>  | operating supply current                   | $f_{OSD} = f_{xtal} = 10 \text{ MHz}$                   | _                  | 5    | 10                 | mA   |
|                  |                                            | $f_{OSD} = f_{xtal} = 6 \text{ MHz}$                    | _                  | 3.5  | 7                  | mA   |
|                  |                                            | f <sub>OSD</sub> = Stop; f <sub>xtal</sub> = 10 MHz     | _                  | 3    | 6                  | mA   |
|                  |                                            | $f_{OSD} = Stop; f_{xtal} = 6 MHz$                      | _                  | 1.5  | 4                  | mA   |
| I <sub>LU</sub>  | latch-up current for all pins              |                                                         | 50                 | -    | -                  | mA   |
| V <sub>POR</sub> | Power-on-reset voltage level               |                                                         | 0.7                | 1.3  | 1.9                | V    |
| Ports P0,        | P1, DP0, DP1 and DP2 inputs                |                                                         |                    |      |                    |      |
| V <sub>IL</sub>  | LOW level input voltage                    |                                                         | 0                  | -    | 0.3V <sub>DD</sub> | V    |
| V <sub>IH</sub>  | HIGH level input voltage                   |                                                         | 0.7V <sub>DD</sub> | -    | V <sub>DD</sub>    | V    |
| ILI              | input leakage current                      | $V_{SS} < V_I < V_{DD}$                                 | _                  | _    | ±10                | μA   |
| Port P0 ou       | utputs                                     |                                                         |                    |      |                    |      |
| V <sub>OL</sub>  | LOW level output voltage                   | V <sub>DD</sub> = 5 V; I <sub>OL</sub> = 10 mA          | _                  | _    | 1.2                | V    |
| I <sub>OH1</sub> | HIGH level pull-up output source current   | $V_{DD} = 5 V; V_{O} = 0.7 V_{DD}$                      | -40                | -100 | _                  | μA   |
|                  |                                            | V <sub>DD</sub> = 5 V; V <sub>O</sub> = V <sub>SS</sub> | -                  | -140 | -400               | μA   |
| I <sub>OH2</sub> | HIGH level push-pull output source current | $V_{DD} = 5 \text{ V}; V_{O} = V_{DD} - 0.4 \text{ V}$  | -3.0               | -7.0 | _                  | mA   |
| DP00/PWI         | M0 to DP07/PWM7 as derivative ports        |                                                         |                    |      |                    |      |
| I <sub>OL</sub>  | LOW level output sink current              | V <sub>DD</sub> = 5 V; V <sub>OL</sub> = 0.4 V          | 5.0                | 12.0 | _                  | mA   |
| I <sub>OH1</sub> | HIGH level pull-up output source current   | $V_{DD} = 5 V; V_{O} = 0.7 V_{DD}$                      | -40                | -100 | _                  | μA   |
|                  |                                            | $V_{DD} = 5 V; V_O = V_{SS}$                            | -                  | -140 | -400               | μA   |
| I <sub>OH2</sub> | HIGH level push-pull output source current | $V_{DD} = 5 \text{ V}; V_{O} = V_{DD} - 0.4 \text{ V}$  | -3.0               | -7.0 | -                  | mA   |
| DP00/PWI         | M0 to DP07/PWM7 as PWM outputs             |                                                         | •                  |      |                    |      |
| I <sub>OL</sub>  | LOW level output sink current              | V <sub>DD</sub> = 5 V; V <sub>OL</sub> = 0.4 V          | 0.7                | 1.5  | _                  | mA   |
| I <sub>OH1</sub> | HIGH level pull-up output source current   | $V_{DD} = 5 V; V_{O} = 0.7 V_{DD}$                      | -40                | -100 | _                  | μA   |
|                  |                                            | $V_{DD} = 5 V; V_O = V_{SS}$                            | _                  | -140 | -400               | μA   |
| I <sub>OH2</sub> | HIGH level push-pull output source current | $V_{DD} = 5 \text{ V}; V_{O} = V_{DD} - 0.4 \text{ V}$  | -0.7               | -1.5 | -                  | mA   |
| P10 to P12       | 2 and P14 outputs                          |                                                         |                    |      |                    |      |
| I <sub>OL</sub>  | LOW level output sink current              | V <sub>DD</sub> = 5 V; V <sub>OL</sub> = 0.4 V          | 5.0                | 12.0 | _                  | mA   |
| I <sub>OH1</sub> | HIGH level pull-up output source current   | $V_{DD} = 5 V; V_{O} = 0.7 V_{DD}$                      | -40                | -100 | _                  | μA   |
|                  |                                            | $V_{DD} = 5 \text{ V}; V_O = V_{SS}$                    | _                  | -140 | -400               | μA   |
| I <sub>OH2</sub> | HIGH level push-pull output source current | $V_{DD} = 5 \text{ V}; V_{O} = V_{DD} - 0.4 \text{ V}$  | -3.0               | -7.0 | -                  | mA   |
| DP20/SDA         | A and DP21/SCL outputs                     |                                                         |                    |      |                    |      |
| I <sub>OL</sub>  | LOW level output sink current              | V <sub>DD</sub> = 5 V; V <sub>OL</sub> = 0.4 V          | 3.0                | _    | _                  | mA   |
| I <sub>OH1</sub> | HIGH level pull-up output source current   | $V_{DD} = 5 \text{ V}; V_{O} = 0.7 \text{V}_{DD}$       | -40                | -100 | _                  | μA   |
|                  |                                            | $V_{DD} = 5 \text{ V}; V_O = V_{SS}$                    | _                  | -140 | -400               | μΑ   |
| I <sub>OH2</sub> | HIGH level push-pull output source current |                                                         | _                  | -7.0 | _                  | mA   |

| SYMBOL           | PARAMETER                                  | CONDITIONS                                                 | MIN.        | TYP. | MAX.               | UNIT |
|------------------|--------------------------------------------|------------------------------------------------------------|-------------|------|--------------------|------|
| VOW1/DP          | 22; VOW0/DP23 and DP13/PWM8 as derive      | ative output ports                                         |             | 1    | I                  | 1    |
| I <sub>OL</sub>  | LOW level output sink current              | V <sub>DD</sub> = 5 V; V <sub>OL</sub> = 0.4 V             | 5.0         | 12.0 | -                  | mA   |
| I <sub>OH1</sub> | HIGH level pull-up output source current   | $V_{DD} = 5 \text{ V}; V_{O} = 0.7 \text{V}_{DD}$          | -40         | -100 | -                  | μA   |
|                  |                                            | $V_{DD} = 5 \text{ V}; V_O = V_{SS}$                       | -           | -140 | -400               | μA   |
| I <sub>OH2</sub> | HIGH level push-pull output source current | $V_{DD} = 5 \text{ V}; V_{O} = V_{DD} - 0.4 \text{ V}$     | -3.0        | -7.0 | _                  | mA   |
| VOW1/DP          | 22 and VOW0/DP23 as VOW outputs            |                                                            |             |      |                    |      |
| I <sub>OL</sub>  | LOW level output sink current              | V <sub>DD</sub> = 5 V; V <sub>OL</sub> = 0.4 V             | 1.4         | 3.0  | _                  | mA   |
| I <sub>OH1</sub> | HIGH level pull-up output source current   | $V_{DD} = 5 \text{ V}; V_{O} = 0.7 V_{DD}$                 | -40         | -100 | -                  | μA   |
|                  |                                            | $V_{DD} = 5 \text{ V}; V_O = V_{SS}$                       | -           | -140 | -400               | μA   |
| I <sub>OH2</sub> | HIGH level push-pull output source current | $V_{DD} = 5 \text{ V}; V_{O} = V_{DD} - 0.4 \text{ V}$     | -1.4        | -3.0 | -                  | mA   |
| DP13/PWI         | M8 as PWM8 output                          |                                                            |             |      |                    |      |
| I <sub>OL</sub>  | LOW level output sink current              | V <sub>DD</sub> = 5 V; V <sub>OL</sub> = 0.4 V             | 1.4         | 3.0  | _                  | mA   |
| I <sub>OH1</sub> | HIGH level pull-up output source current   | $V_{DD} = 5 \text{ V}; V_{O} = 0.7 \text{V}_{DD}$          | -40         | -100 | -                  | μA   |
|                  |                                            | $V_{DD} = 5 \text{ V}; V_O = V_{SS}$                       | -           | -140 | -400               | μA   |
| I <sub>OH2</sub> | HIGH level push-pull output source current | $V_{DD} = 5 \text{ V}; V_{O} = V_{DD} - 0.4 \text{ V}$     | -1.4        | -3.0 | -                  | mA   |
| Outputs F        | B and VOW2                                 |                                                            |             |      |                    |      |
| I <sub>OL</sub>  | LOW level output sink current              | V <sub>DD</sub> = 5 V; V <sub>OL</sub> = 0.4 V             | 1.4         | 3.0  | _                  | mA   |
| I <sub>OH1</sub> | HIGH level pull-up output source current   | $V_{DD} = 5 \text{ V}; V_{O} = 0.7 V_{DD}$                 | -40         | -100 | -                  | μA   |
|                  |                                            | $V_{DD}$ = 5 V; $V_{O}$ = $V_{SS}$                         | -           | -140 | -400               | μA   |
| I <sub>OH2</sub> | HIGH level push-pull output source current | $V_{DD} = 5 \text{ V}; V_{O} = V_{DD} - 0.4 \text{ V}$     | -1.4        | -3.0 | -                  | mA   |
| DP12/ADC         | C2 as derivative output port               |                                                            |             |      |                    |      |
| I <sub>OL</sub>  | LOW level output sink current              | V <sub>DD</sub> = 5 V; V <sub>OL</sub> = 0.4 V             | 5.0         | 12.0 | _                  | mA   |
| I <sub>OH1</sub> | HIGH level pull-up output source current   | V <sub>DD</sub> = 5 V; V <sub>O</sub> = 0.7V <sub>DD</sub> | -40         | -100 | _                  | μA   |
|                  |                                            | $V_{DD} = 5 V; V_O = V_{SS}$                               | _           | -140 | -400               | μA   |
| I <sub>OH2</sub> | HIGH level push-pull output source current | $V_{DD} = 5 \text{ V}; V_{O} = V_{DD} - 0.4 \text{ V}$     | -3.0        | -7.0 | _                  | mA   |
| TEST/EMU         | J; RESET; INTN/T0; T1; HSYNCN; VSYNCM      | N and T3                                                   |             |      |                    |      |
| VIL              | LOW level input voltage                    |                                                            | 0           | -    | 0.3V <sub>DD</sub> | V    |
| V <sub>IH</sub>  | HIGH level input voltage                   |                                                            | $0.7V_{DD}$ | -    | V <sub>DD</sub>    | V    |
| ILI              | input leakage current                      | $V_{SS} < V_I < V_{DD}$                                    | -1.0        | -    | +1.0               | μA   |
|                  |                                            |                                                            |             |      |                    |      |

### PCE84C882

#### 20 AC CHARACTERISTICS

| SYMBOL             | PARAMETER                                                                                 | CONDITIONS                                                                     | MIN.            | TYP. | MAX.            | UNIT |
|--------------------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|-----------------|------|-----------------|------|
| f <sub>xtal</sub>  | Crystal oscillator frequency                                                              | $V_{DD} = 5 \text{ V}; \text{ T}_{amb} = -25 \text{ to } +85 ^{\circ}\text{C}$ |                 |      |                 |      |
|                    | Option 1: g <sub>m</sub> = 0.4 mS                                                         |                                                                                | 1               | _    | 6               | MHz  |
|                    | Option 2: $g_m = 1.2 \text{ mS}$                                                          |                                                                                | 4               | -    | 10              | MHz  |
| f <sub>PXE</sub>   | PXE resonator frequency                                                                   |                                                                                |                 |      |                 |      |
|                    | Option 2: $g_m = 1.2 \text{ mS}$                                                          |                                                                                | 1               | -    | 5               | MHz  |
| f <sub>OSD</sub>   | OSD clock frequency                                                                       | V <sub>DD</sub> = 4.75 V; T <sub>amb</sub> = +70 °C                            | 6.0             | -    | 20              | MHz  |
| f <sub>Hsync</sub> | Hsync frequency                                                                           | duty cycle = 10 : 90                                                           | 30              | -    | 90              | kHz  |
| f <sub>Vsync</sub> | Vsync frequency                                                                           | duty cycle = 10 : 90                                                           | 50              | -    | 120             | Hz   |
| C <sub>OSD</sub>   | external capacitance at pin C                                                             |                                                                                | -               | 0.33 | -               | μF   |
| C <sub>xtal1</sub> | external capacitance at XTAL1 (IN)<br>pin (PXE resonator)                                 |                                                                                | -               | 30   | 100             | pF   |
| C <sub>xtal2</sub> | external capacitance at XTAL2 (OUT) pin (PXE resonator)                                   |                                                                                | -               | 30   | 100             | pF   |
| t <sub>T3</sub>    | minimum pulse width period at T3 input                                                    | rising or falling edge of T3<br>pulse < 30 ns                                  | 0.4             | -    | -               | μs   |
| Analog-to          | -Digital (software) Converter                                                             | •                                                                              | •               |      |                 |      |
| V <sub>AI</sub>    | ADC2 comparator analog input voltage                                                      |                                                                                | V <sub>SS</sub> | -    | V <sub>DD</sub> | V    |
| V <sub>AE</sub>    | conversion error range                                                                    |                                                                                | -               | -    | ±1/2            | LSB  |
| T <sub>AFC</sub>   | conversion time (from any change in<br>ADC input i.e. voltage level or<br>enable/disable) |                                                                                | _               | _    | 7               | μs   |

#### 21 DEVELOPMENT SUPPORT

Table 39 details the hardware items available for development support and Table 40 lists the development support documentation.

#### Table 39 Hardware

| ТҮРЕ                    | ORDER NUMBER   |  |  |
|-------------------------|----------------|--|--|
| LCDS Development System |                |  |  |
| OM1025                  | 9339 931 50112 |  |  |
| OM4835                  | 9350 861 10112 |  |  |
|                         |                |  |  |
| _                       | 9350 872 50112 |  |  |
|                         | OM1025         |  |  |

#### Table 40 Documentation

| DOCUMENT NAME                                                                             | REPORT NUMBER |  |  |
|-------------------------------------------------------------------------------------------|---------------|--|--|
| OM4873 Demo-Board Using PCE84C882 OSD microcontroller in Auto-Sync<br>Monitor Application | AN94049       |  |  |

PCE84C882

95-02-04

### Microcontroller for monitor OSD and auto-sync applications

#### 22 PACKAGE OUTLINE





SOT270-1

#### 23 SOLDERING

#### 23.1 Introduction

There is no soldering method that is ideal for all IC packages. Wave soldering is often preferred when through-hole and surface mounted components are mixed on one printed-circuit board. However, wave soldering is not always suitable for surface mounted ICs, or for printed-circuits with high population densities. In these situations reflow soldering is often used.

This text gives a very brief insight to a complex technology. A more in-depth account of soldering ICs can be found in our *"IC Package Databook"* (order code 9398 652 90011).

#### 23.2 Soldering by dipping or by wave

The maximum permissible temperature of the solder is 260 °C; solder at this temperature must not be in contact with the joint for more than 5 seconds. The total contact time of successive solder waves must not exceed 5 seconds.

The device may be mounted up to the seating plane, but the temperature of the plastic body must not exceed the specified maximum storage temperature ( $T_{stg\,max}$ ). If the printed-circuit board has been pre-heated, forced cooling may be necessary immediately after soldering to keep the temperature within the permissible limit.

#### 23.3 Repairing soldered joints

Apply a low voltage soldering iron (less than 24 V) to the lead(s) of the package, below the seating plane or not more than 2 mm above it. If the temperature of the soldering iron bit is less than 300 °C it may remain in contact for up to 10 seconds. If the bit temperature is between 300 and 400 °C, contact may be up to 5 seconds.

#### 24 DEFINITIONS

| Data sheet status                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                       |  |  |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--|--|--|--|
| Objective specification                                                                                                                                                                                                                                                                                                                                                                                                                                   | This data sheet contains target or goal specifications for product development.       |  |  |  |  |
| Preliminary specification                                                                                                                                                                                                                                                                                                                                                                                                                                 | This data sheet contains preliminary data; supplementary data may be published later. |  |  |  |  |
| Product specification                                                                                                                                                                                                                                                                                                                                                                                                                                     | This data sheet contains final product specifications.                                |  |  |  |  |
| Limiting values                                                                                                                                                                                                                                                                                                                                                                                                                                           | Limiting values                                                                       |  |  |  |  |
| Limiting values given are in accordance with the Absolute Maximum Rating System (IEC 134). Stress above one or more of the limiting values may cause permanent damage to the device. These are stress ratings only and operation of the device at these or at any other conditions above those given in the Characteristics sections of the specification is not implied. Exposure to limiting values for extended periods may affect device reliability. |                                                                                       |  |  |  |  |
| Application information                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                       |  |  |  |  |

Where application information is given, it is advisory and does not form part of the specification.

#### 25 LIFE SUPPORT APPLICATIONS

These products are not designed for use in life support appliances, devices, or systems where malfunction of these products can reasonably be expected to result in personal injury. Philips customers using or selling these products for use in such applications do so at their own risk and agree to fully indemnify Philips for any damages resulting from such improper use or sale.

#### 26 PURCHASE OF PHILIPS I<sup>2</sup>C COMPONENTS



Purchase of Philips I<sup>2</sup>C components conveys a license under the Philips' I<sup>2</sup>C patent to use the components in the I<sup>2</sup>C system provided the system conforms to the I<sup>2</sup>C specification defined by Philips. This specification can be ordered using the code 9398 393 40011.

PCE84C882

NOTES

PCE84C882

NOTES