# INTEGRATED CIRCUITS



Preliminary specification Supersedes data of 1999 Aug 02 File under Integrated Circuits, IC02 2000 Feb 23



### CONTENTS

| ••••         |                                         |
|--------------|-----------------------------------------|
| 1            | FEATURES                                |
| 2            | GENERAL DESCRIPTION                     |
| 3            | QUICK REFERENCE DATA                    |
| 4            | ORDERING INFORMATION                    |
| 5            | BLOCK DIAGRAM                           |
| 6            | PINNING INFORMATION                     |
| 6.1          | Pinning                                 |
| 6.2          | Pin description                         |
| 7            | MICROCONTROLLER                         |
| 7.1          | Microcontroller features                |
| 8            | MEMORY ORGANIZATION                     |
| 8.1          | ROM bank switching                      |
| 8.2          | Security bits - program and verify      |
| 8.3<br>8.4   | RAM organisation<br>Data memory         |
| 8.5          | SFR memory                              |
| 8.6          | Character set feature bits              |
| 8.7          | External (Auxiliary) memory             |
| 9            | POWER-ON RESET                          |
| 10           | REDUCED POWER MODES                     |
| 10.1         | Idle mode                               |
| 10.2         | Power-down mode                         |
| 10.3         | Standby mode                            |
| 11           | I/O FACILITY                            |
| 11.1         | I/O ports                               |
| 11.2<br>11.3 | Port type<br>Port alternative functions |
| 11.3         | LED support                             |
| 12           | INTERRUPT SYSTEM                        |
| 12.1         | Interrupt enable structure              |
| 12.2         | Interrupt enable priority               |
| 12.3         | Interrupt vector address                |
| 12.4         | Level/edge interrupt                    |
| 13           | TIMER/COUNTER                           |
| 14           | WATCHDOG TIMER                          |
| 14.1         | Watchdog Timer operation                |
| 15           | PULSE WIDTH MODULATORS                  |
| 15.1         | PWM control                             |
| 15.2         | Tuning Pulse Width Modulator (TPWM)     |
| 15.3         | Software ADC (SAD)                      |
| 16           | I <sup>2</sup> C-BUS SERIAL I/O         |
| 16.1         | I <sup>2</sup> C-bus port selection     |

| 17             | MEMORY INTERFACE                                      |
|----------------|-------------------------------------------------------|
| 17.1           | Memory structure                                      |
| 17.2           | Memory mapping                                        |
| 17.3           | Addressing memory                                     |
| 17.4           | Page clearing                                         |
| 18             | DATA CAPTURE                                          |
| 18.1           | Data Capture features                                 |
| 19             | DISPLAY                                               |
| 19.1           | Display features                                      |
| 19.2           | Display modes                                         |
| 19.3           | Display feature descriptions                          |
| 19.4           | Character and attribute coding                        |
| 19.5           | Screen and global controls                            |
| 19.6           | Screen colour                                         |
| 19.7           | Text display controls                                 |
| 19.8           | Soft scroll action                                    |
| 19.9           | Display positioning                                   |
| 19.10          | Character set                                         |
| 19.11          | ROM addressing                                        |
| 19.12          | Redefinable characters                                |
| 19.13          | Display synchronization                               |
| 19.14          | Video/data switch (Fast Blanking) polarity            |
| 19.15          | Video/Data switch adjustment                          |
| 19.16<br>19.17 | RGB brightness control<br>Contrast reduction          |
| -              |                                                       |
| 20             |                                                       |
| 21             |                                                       |
| 22             |                                                       |
| 23             | QUALITY AND RELIABILITY                               |
| 23.1           | Group A                                               |
| 23.2           | Group B                                               |
| 23.3           | Group C                                               |
| 24             |                                                       |
| 25             | EMC GUIDELINES                                        |
| 26             | REFERENCES                                            |
| 27             | PACKAGE OUTLINE                                       |
| 28             | SOLDERING                                             |
| 28.1           | Introduction to soldering through-hole mount packages |
| 28.2           | Soldering by dipping or by solder wave                |
| 28.3           | Manual soldering                                      |
| 28.4           | Suitability of through-hole mount IC packages         |
|                | for dipping and wave soldering methods                |
| 29             | DEFINITIONS                                           |
| 30             | LIFE SUPPORT APPLICATIONS                             |
| 00             |                                                       |

31 PURCHASE OF PHILIPS I<sup>2</sup>C COMPONENTS

# SAA55xx

# SAA55xx

### 1 FEATURES

- · Single-chip microcontroller with integrated OSD
- Versions available with integrated data capture
- OTP memory for both program ROM and character sets
- Single power supply: 3.0 to 3.6 V
- 5 V tolerant digital inputs and I/O
- 29 I/O ports via individual addressable controls
- Programmable I/O for push-pull, open-drain and quasi-bidirectional
- Two port lines with 8 mA sink (at <0.4 V) capability, for direct drive of LED
- Single crystal oscillator for microcontroller, OSD and data capture
- Power reduction modes: Idle, Power-down and Standby
- Byte level I<sup>2</sup>C-bus interface with dual port I/O
- 32 Dynamically Redefinable Characters for OSDs
- Special graphic characters allowing four colours per character
- Selectable character height 9, 10, 13 and 16 TV lines
- Pin compatibility throughout family
- Operating temperature: -20 to +70 °C.



### 2 GENERAL DESCRIPTION

The SAA55xx family of microcontrollers are a derivative of the Philips industry-standard 80C51 microcontroller and are intended for use as the central control mechanism in a television receiver. They provide control functions for the television system, On-Screen Display (OSD) and some versions include an integrated data capture and display function.

The data capture hardware has the capability of decoding and displaying both 525 and 625-line World System Teletext (WST), Closed Caption (CC) information, Video Programming Information (VPS) and Wide Screen Signalling (WSS) information. The same display hardware is used both for Teletext, Closed Caption and On-Screen Display, which means that the display features available give greater flexibility to differentiate the TV set.

The SAA55xx family offers a range of functionality from non-text, 16-kbyte program ROM and 256-byte RAM, to a 10 page text version, 128-kbyte program ROM and 2.25-kbyte RAM.

#### SYMBOL PARAMETER MIN. TYP. MAX. UNIT Supply any supply voltage (V<sub>DD</sub> to V<sub>SS</sub>) 3.0 3.6 V 3.3 V<sub>DDX</sub> periphery supply current 1 mΑ IDDP \_ core supply current 15 18 mΑ \_ IDDC Idle mode core supply current \_ 4.6 6 mΑ I<sub>DDC(id)</sub> \_ 0.76 1 Power-down mode core supply current mΑ IDDC(pd) 5.1 9 standby mode core supply current \_ mΑ I<sub>DDC(stb)</sub> 45 48 IDDA analog supply current \_ mΑ Idle mode analog supply current 0.87 1.0 mΑ \_ I<sub>DDA(id)</sub> standby mode analog supply current \_\_\_\_ 809 950 μΑ I<sub>DDA(stb)</sub> I<sub>DDA(pd)</sub> Power-down mode analog supply current \_ 0.45 0.7 mΑ 12 MHz crystal frequency f<sub>xtal</sub> -20 +70 °C Tamb ambient temperature \_ storage temperature -55 +125 °C T<sub>stg</sub> \_

### 3 QUICK REFERENCE DATA

# SAA55xx

### 4 ORDERING INFORMATION

| TYPE NUMBER <sup>(1)</sup> |        | PACKAGE <sup>(2)</sup>               | ROM      | RAM       | TEXT      |       |
|----------------------------|--------|--------------------------------------|----------|-----------|-----------|-------|
|                            | NAME   | DESCRIPTION                          | VERSION  | ROIVI     | KAIVI     | PAGES |
| SAA5530PS/nnnn             | SDIP52 | plastic shrink dual in-line package; | SOT247-1 | 16-kbyte  | 256-byte  | 1     |
| SAA5531PS/nnnn             |        | 52 leads (600 mil)                   |          | 32-kbyte  | 512-byte  | 1     |
| SAA5532PS/nnnn             |        |                                      |          | 48-kbyte  | 750-byte  | 1     |
| SAA5533PS/nnnn             |        |                                      |          | 64-kbyte  | 1-kbyte   | 1     |
| SAA5561PS/nnnn             |        |                                      |          | 32-kbyte  | 750-byte  | 10    |
| SAA5562PS/nnnn             |        |                                      |          | 48-kbyte  | 1-kbyte   | 10    |
| SAA5563PS/nnnn             |        |                                      |          | 64-kbyte  | 1.2-kbyte | 10    |
| SAA5564PS/nnnn             |        |                                      |          | 96-kbyte  | 1.5-kbyte | 10    |
| SAA5565PS/nnnn             |        |                                      |          | 128-kbyte | 2-kbyte   | 10    |

### Notes

1. 'nnnn' is a four digit number uniquely referencing the microcontroller program mask.

2. For details of the LQFP100 package, please contact your local regional sales office for availability.

SAA55xx

# Enhanced TV microcontrollers with On-Screen Display (OSD)

### 5 BLOCK DIAGRAM



SAA55xx

# Enhanced TV microcontrollers with On-Screen Display (OSD)

### 6 PINNING INFORMATION

### 6.1 Pinning



#### Enhanced TV microcontrollers with SAA55xx **On-Screen Display (OSD)** 100 P2.0/TPWM 98 P2.6/PWM5 P2.4/PWM3 P2.3/PWM2 P2.5/PWM4 P2.1/PWM0 P2.2/PWM1 82 P1.7/SDA0 84 P1.5/SDA1 83 P1.4/SCL1 81 P1.6/SCL0 79 P1.2/INT0 76 P1.0/INT1 ] P1.3/T1 P1.1/T0 n.c. n.c. 91 n.c. 90 n.c. 89 n.c. n.c. n.c. n.c. n.c. n.c. 66 96 95 93 92 80 97 94 88 87 86 85 77 P2.7/PWM6 1 75 V<sub>DDP</sub> P3.0/ADC0 2 74 n.c. 73 RESET n.c. 3 P3.1/ADC1 4 72 n.c. P3.2/ADC2 5 71 XTALOUT P3.3/ADC3 6 70 XTALIN 69 OSCGND n.c. [ 7 68 n.c. n.c. 8 n.c. 9 67 n.c. 66 n.c. n.c. 10 65 n.c. VSSC 11 64 n.c. V<sub>SSP</sub> 12 SAA55xx P0.5 13 63 V<sub>DDC</sub> 62 VPE\_2 n.c. 14 n.c. 15 61 n.c. P0.0 16 60 VSSP P0.1 17 59 P3.6 P0.2 18 58 n.c. 57 n.c. n.c. 19 n.c. 20 56 n.c. n.c. 21 55 VSYNC P0.3 22 54 P3.5 n.c. 23 53 HSYNC P0.4 24 52 VDS P3.7 25 51 n.c. n.c. <u>38</u> n.c. <u>39</u> P0.7 29 VSSA 30 CVBS0 31 CVBS1 32 n.c. 33 FRAME 41 VPE 42 COR 43 IREF 35 26 27 28 45 48 49 40 P3.4/PWM7 44 46 SYNC\_FILTER 34 36 47 50 37 GSA001

Fig.3 LQFP100 pin configuration.

n.c.

n.c.

n.c.

VDDA [

ш G ۲ n.c. n.c

P0.6 P0.7

n.c.

### 6.2 Pin description

Table 1 SDIP52 and LQFP100 packages

|                  |                | PIN |      | DECODIDITION                                                                                                                                 |  |  |  |
|------------------|----------------|-----|------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| SYMBOL           | SDIP52 LQFP100 |     | TYPE | DESCRIPTION                                                                                                                                  |  |  |  |
| P2.0/TPWM        | 1              | 100 | I/O  | Port 2. 8-bit programmable bidirectional port with                                                                                           |  |  |  |
| P2.1/PWM0        | 2              | 93  | I/O  | alternative functions.                                                                                                                       |  |  |  |
| P2.2/PWM1        | 3              | 94  | I/O  | P2.0/TPWM is the output for the 14-bit high                                                                                                  |  |  |  |
| P2.3/PWM2        | 4              | 95  | I/O  | precision PWM; P2.1/PWM0 to P2.7/PWM6 are the                                                                                                |  |  |  |
| P2.4/PWM3        | 5              | 96  | I/O  | outputs for the 6-bit PWMs 0 to 6.                                                                                                           |  |  |  |
| P2.5/PWM4        | 6              | 97  | I/O  |                                                                                                                                              |  |  |  |
| P2.6/PWM5        | 7              | 98  | I/O  |                                                                                                                                              |  |  |  |
| P2.7/PWM6        | 8              | 1   | I/O  |                                                                                                                                              |  |  |  |
| P3.0/ADC0        | 9              | 2   | I/O  | Port 3. 8-bit programmable bidirectional port with                                                                                           |  |  |  |
| P3.1/ADC1        | 10             | 4   | I/O  | alternative functions.                                                                                                                       |  |  |  |
| P3.2/ADC2        | 11             | 5   | I/O  | P3.0/ADC0 to P3.3/ADC3 are the inputs for the                                                                                                |  |  |  |
| P3.3/ADC3        | 12             | 6   | I/O  | software ADC facility and P3.4/PWM7 is the output                                                                                            |  |  |  |
| P3.4/PWM7        | 30             | 44  | I/O  | for the 6-bit PWM7. P3.5 to P3.7 have no alternative functions and are only available with the LQFP100                                       |  |  |  |
| P3.5             | _              | 54  | I/O  | package.                                                                                                                                     |  |  |  |
| P3.6             | _              | 59  | I/O  |                                                                                                                                              |  |  |  |
| P3.7             | _              | 25  | I/O  |                                                                                                                                              |  |  |  |
| V <sub>SSC</sub> | 13             | 11  | _    | core ground                                                                                                                                  |  |  |  |
| P0.0             | 14             | 16  | I/O  | Port 0. 8-bit programmable bidirectional port.                                                                                               |  |  |  |
| P0.1             | 15             | 17  | I/O  | P0.5 and P0.6 have 8 mA current sinking capability                                                                                           |  |  |  |
| P0.2             | 16             | 18  | I/O  | for direct drive of LEDs.                                                                                                                    |  |  |  |
| P0.3             | 17             | 22  | I/O  |                                                                                                                                              |  |  |  |
| P0.4             | 18             | 24  | I/O  |                                                                                                                                              |  |  |  |
| P0.5             | 19             | 13  | I/O  |                                                                                                                                              |  |  |  |
| P0.6             | 20             | 28  | I/O  |                                                                                                                                              |  |  |  |
| P0.7             | 21             | 29  | I/O  |                                                                                                                                              |  |  |  |
| V <sub>SSA</sub> | 22             | 30  | -    | analog ground                                                                                                                                |  |  |  |
| CVBS0            | 23             | 31  | I    | Composite video input. A positive-going 1 V (peak-to-peak) input is required.                                                                |  |  |  |
| CVBS1            | 24             | 32  |      | connected via a 100 nF capacitor                                                                                                             |  |  |  |
| SYNC_FILTER      | 25             | 34  | I    | CVBS sync filter input. This pin should be connected to $V_{SSA}$ via a 100 nF capacitor.                                                    |  |  |  |
| IREF             | 26             | 35  | I    | Reference current input for analog circuits, connected to $V_{SSA}$ via a 24 k $\Omega$ resistor.                                            |  |  |  |
| FRAME            | 27             | 41  | 0    | De-interlace output synchronized with the VSYNC pulse to produce a non-interlaced display by adjustment of the vertical deflection circuits. |  |  |  |
| VPE              | 28             | 42  | 1    | OTP programming voltage                                                                                                                      |  |  |  |

|                  |                | PIN                                                                                                                           | TVDE | DECODIDION                                                                                                                                                                                        |  |  |  |  |
|------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| SYMBOL           | SDIP52 LQFP100 |                                                                                                                               | TYPE | DESCRIPTION                                                                                                                                                                                       |  |  |  |  |
| COR              | 29             | 43                                                                                                                            | 0    | Open-drain, active LOW output which allows selective contrast reduction of the TV picture to enhance a mixed mode display.                                                                        |  |  |  |  |
| V <sub>DDA</sub> | 31             | 45                                                                                                                            | _    | +3.3 V analog power supply                                                                                                                                                                        |  |  |  |  |
| В                | 32             | 46                                                                                                                            | 0    | pixel rate output of the BLUE colour information                                                                                                                                                  |  |  |  |  |
| G                | 33             | 47                                                                                                                            | 0    | pixel rate output of the GREEN colour information                                                                                                                                                 |  |  |  |  |
| R                | 34             | 48                                                                                                                            | 0    | pixel rate output of the RED colour information                                                                                                                                                   |  |  |  |  |
| VDS              | 35             | 52                                                                                                                            | 0    | video/data switch push-pull output for dot rate fast blanking                                                                                                                                     |  |  |  |  |
| HSYNC            | 36             | 53                                                                                                                            | Ι    | Schmitt triggered input for a TTL-level version of the horizontal sync pulse; the polarity of this pulse is programmable by register bit TXT1.H POLARITY.                                         |  |  |  |  |
| VSYNC            | 37             | 55                                                                                                                            | Ι    | Schmitt triggered input for a TTL-level version of the vertical sync pulse; the polarity of this pulse is programmable by register bit TXT1.V POLARITY.                                           |  |  |  |  |
| V <sub>SSP</sub> | 38             | 12, 60                                                                                                                        | _    | periphery ground                                                                                                                                                                                  |  |  |  |  |
| V <sub>DDC</sub> | 39             | 63                                                                                                                            | 1    | +3.3 V core power supply                                                                                                                                                                          |  |  |  |  |
| OSCGND           | 40             | 69                                                                                                                            | -    | crystal oscillator ground                                                                                                                                                                         |  |  |  |  |
| XTALIN           | 41             | 70                                                                                                                            | Ι    | 12 MHz crystal oscillator input                                                                                                                                                                   |  |  |  |  |
| XTALOUT          | 42             | 71                                                                                                                            | 0    | 12 MHz crystal oscillator output                                                                                                                                                                  |  |  |  |  |
| RESET            | 43             | 73                                                                                                                            | I    | If the reset input is HIGH for at least 2 machine cycles (24 oscillator periods) while the oscillator is running, the device is reset; this pin should be connected to $V_{DDP}$ via a capacitor. |  |  |  |  |
| V <sub>DDP</sub> | 44             | 75                                                                                                                            | _    | +3.3 V periphery power supply                                                                                                                                                                     |  |  |  |  |
| P1.0/INT1        | 45             | 76                                                                                                                            | I/O  | Port 1. 8-bit programmable bidirectional port with                                                                                                                                                |  |  |  |  |
| P1.1/T0          | 46             | 78                                                                                                                            | I/O  | alternative functions.                                                                                                                                                                            |  |  |  |  |
| P1.2/INT0        | 47             | 79                                                                                                                            | I/O  | P1.0/INT1 is external interrupt 1 which can be                                                                                                                                                    |  |  |  |  |
| P1.3/T1          | 48             | 80                                                                                                                            | I/O  | triggered on the rising and falling edge of the pulse.                                                                                                                                            |  |  |  |  |
| P1.6/SCL0        | 49             | 81                                                                                                                            | I/O  | P1.1/T0 is the Counter/Timer 0. P1.2/INT0 is external interrupt 0. P1.3/T1 is the Counter/Timer 1.                                                                                                |  |  |  |  |
| P1.7/SDA0        | 50             | 82                                                                                                                            | I/O  | P1.6/SCL0 is the serial clock input for the $l^2$ C-bus                                                                                                                                           |  |  |  |  |
| P1.4/SCL1        | 51             | 83                                                                                                                            | I/O  | and P1.7/SDA0 is the serial data port for the                                                                                                                                                     |  |  |  |  |
| P1.5/SDA1        | 52             | 58                                                                                                                            | I/O  | $I^2$ C-bus. P1.4/SCL1 is the serial clock input for the $I^2$ C-bus and P1.5/SDA1 is the serial data port for the $I^2$ C-bus.                                                                   |  |  |  |  |
| VPE-2            | _              | 62                                                                                                                            | Ι    | OTP programming voltage                                                                                                                                                                           |  |  |  |  |
| n.c.             | _              | 3, 7 to 10,14, 15, 19 to 21,<br>23, 26, 27, 33, 36 to 40,<br>49 to 51, 56 to 58, 61,<br>64 to 68, 72, 74, 77,<br>85 to 92, 99 | -    | not connected                                                                                                                                                                                     |  |  |  |  |

### 7 MICROCONTROLLER

The functionality of the microcontroller used on this device is described here with reference to the industry standard 80C51 microcontroller. A full description of its functionality can be found in *"Handbook IC20, 80C51-Based 8-bit* Microcontrollers".

### 7.1 Microcontroller features

- 80C51 microcontroller core standard instruction set and timing
- 1 µs machine cycle
- Maximum 128K × 8-bit Program ROM
- Maximum of 12K × 8-bit Auxiliary RAM
- Interrupt Controller for individual enable/disable with two level priority
- Two 16-bit Timer/Counter registers
- Watchdog Timer
- Auxiliary RAM page pointer
- 16-bit Data pointer
- Idle and Power-down mode
- 29 general I/O lines
- Eight 6-bit Pulse Width Modulator (PWM) outputs for control of TV analog signals
- One 14-bit PWM for Voltage Synthesis Tuner (VST) control
- 8-bit ADC with 4 multiplexed inputs
- 2 high current outputs for directly driving LEDs etc.
- I<sup>2</sup>C byte level bus interface with dual ports.

### 8 MEMORY ORGANIZATION

The device has the capability of a maximum of 128-kbyte Program ROM and 12-kbyte Data RAM internally.

### 8.1 ROM bank switching

The 64-kbyte device has a continuous address space from 0 to 64 kbytes. The 128-kbyte memory is arranged in four banks of 32 kbytes. One of the 32-kbyte banks is common and is always addressable. The other three banks (Bank 0, Bank 1 and Bank 2) can be accessed by selecting the right bank via the SFR ROMBK bits; see Table 2.

The ROM bank switching is handled and supported by the compiler and linker development tools.

### Table 2 ROM bank selection

| ROMBK1 | ROMBK0 | 0 TO 32-kbyte | 32 TO 64-kbyte |
|--------|--------|---------------|----------------|
| 0      | 0      | common        | Bank 0         |
| 0      | 1      | common        | Bank 1         |
| 1      | 0      | common        | Bank 2         |
| 1      | 1      | reserved      | reserved       |

### 8.2 Security bits - program and verify

SAA55xx devices have a set of security bits allied with each section of the device, i.e. Program ROM, Character ROM and Packet 26 ROM. The security bits are used to prevent the ROM from being overwritten once programmed, and also the contents being verified once programmed. The security bits are one-time programmable and **cannot** be erased.

The SAA55xx memory and security bits are structured as shown in Fig.5. The SAA55xx security bits are set as shown in Fig.6 for production programmed devices and are set as shown in Fig.7 for production blank devices.

### 8.3 RAM organisation

The internal Data RAM is organised into two areas, Data memory and Special Function Registers (SFRs) as shown in Fig.8.

### 8.4 Data memory

The Data memory is  $256 \times 8$  bits and occupies the address range 00H to FFH when using indirect addressing and 00H to 7FH when using direct addressing. The SFRs occupy the address range 80H to FFH and are accessible using direct addressing only.

The lower 128 bytes of Data memory are mapped as shown in Fig.9. The lowest 24 bytes are grouped into 4 banks of 8 registers, the next 16 bytes above the register banks form a block of bit addressable memory space.

The upper 128 bytes is not allocated for any special area or functions.

| Table 3 Bank selectio | n |
|-----------------------|---|
|-----------------------|---|

| RS1 | RS0 | BANK   |
|-----|-----|--------|
| 0   | 0   | Bank 0 |
| 0   | 1   | Bank 1 |
| 1   | 0   | Bank 2 |
| 1   | 1   | Bank 3 |

# Enhanced TV microcontrollers with On-Screen Display (OSD)













### 8.5 SFR memory

\_

2000 Feb 23

The Special Function Register (SFR) space is used for port latches, timer, peripheral control, acquisition control, display control, etc. These registers can only be accessed by direct addressing. Sixteen of the addresses in the SFR space are both bit and byte addressable. The bit addressable SFRs are those whose address ends in 0H or 8H. A summary of the SFR map in address order is shown in Table 4.

A description of each of the SFR bits is shown in Table 5 which presents the SFRs in alphabetical order.

| Table 4 | SFR memory map |
|---------|----------------|
|---------|----------------|

| ADD | R/W | NAME   | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       | RESET |
|-----|-----|--------|---------|---------|---------|---------|---------|---------|---------|---------|-------|
| 80H | R/W | P0     | P07     | P06     | P05     | P04     | P03     | P02     | P01     | P00     | FFH   |
| 81H | R/W | SP     | SP7     | SP6     | SP5     | SP4     | SP3     | SP2     | SP1     | SP0     | 07H   |
| 82H | R/W | DPL    | DPL7    | DPL6    | DPL5    | DPL4    | DPL3    | DPL2    | DPL1    | DPL0    | 00H   |
| 83H | R/W | DPH    | DPH7    | DPH6    | DPH5    | DPH4    | DPH3    | DPH2    | DPH1    | DPH0    | 00H   |
| 87H | R/W | PCON   | 0       | ARD     | RFI     | WLE     | GF1     | GF0     | PD      | IDL     | 00H   |
| 88H | R/W | TCON   | TF1     | TR1     | TF0     | TR0     | IE1     | IT1     | IE0     | IT0     | 00H   |
| 89H | R/W | TMOD   | GATE    | C/T     | M1      | MO      | GATE    | C/T     | M1      | MO      | 00H   |
| 8AH | R/W | TL0    | TL07    | TL06    | TL05    | TL04    | TL03    | TL02    | TL01    | TL00    | 00H   |
| 8BH | R/W | TL1    | TL17    | TL16    | TL15    | TL14    | TL13    | TL12    | TL11    | TL10    | 00H   |
| 8CH | R/W | TH0    | TH07    | TH06    | TH05    | TH04    | TH03    | TH02    | TH01    | TH00    | 00H   |
| 8DH | R/W | TH1    | TH17    | TH16    | TH15    | TH14    | TH13    | TH12    | TH11    | TH10    | 00H   |
| 90H | R/W | P1     | P17     | P16     | P15     | P14     | P13     | P12     | P11     | P10     | FFH   |
| 96H | R/W | P0CFGA | P0CFGA7 | P0CFGA6 | P0CFGA5 | P0CFGA4 | P0CFGA3 | P0CFGA2 | P0CFGA1 | P0CFGA0 | FFH   |
| 97H | R/W | P0CFGB | P0CFGB7 | P0CFGB6 | P0CFGB5 | P0CFGB4 | P0CFGB3 | P0CFGB2 | P0CFGB1 | P0CFGB0 | 00H   |
| 98H | R/W | SADB   | 0       | 0       | 0       | DC_COMP | SAD3    | SAD2    | SAD1    | SAD0    | 00H   |
| 9EH | R/W | P1CFGA | P1CFGA7 | P1CFGA6 | P1CFGA5 | P1CFGA4 | P1CFGA3 | P1CFGA2 | P1CFGA1 | P1CFGA0 | FFH   |
| 9FH | R/W | P1CFGB | P1CFGB7 | P1CFGB6 | P1CFGB5 | P1CFGB4 | P1CFGB3 | P1CFGB2 | P1CFGB1 | P1CFGB0 | 00H   |
| A0H | R/W | P2     | P27     | P26     | P25     | P24     | P23     | P22     | P21     | P20     | FFH   |
| A6H | R/W | P2CFGA | P2CFGA7 | P2CFGA6 | P2CFGA5 | P2CFGA4 | P2CFGA3 | P2CFGA2 | P2CFGA1 | P2CFGA0 | FFH   |
| A7H | R/W | P2CFGB | P2CFGB7 | P2CFGB6 | P2CFGB5 | P2CFGB4 | P2CFGB3 | P2CFGB2 | P2CFGB1 | P2CFGB0 | 00H   |
| A8H | R/W | IE     | EA      | EBUSY   | ES2     | ECC     | ET1     | EX1     | ET0     | EX0     | 00H   |
| B0H | R/W | P3     | P37     | P36     | P35     | P34     | P33     | P32     | P31     | P30     | FFH   |

Philips Semiconductors

SAA55xx

1 4 2000 Feb 23

\_

| ADD | R/W | NAME   | 7                   | 6                       | 5             | 4                           | 3                             | 2                 | 1                       | 0                | RESET |
|-----|-----|--------|---------------------|-------------------------|---------------|-----------------------------|-------------------------------|-------------------|-------------------------|------------------|-------|
| B2H | R/W | TXT18  | NOT3                | NOT2                    | NOT1          | NOT0                        | 0                             | 0                 | BS1                     | BS0              | 00H   |
| B3H | R/W | TXT19  | TEN                 | TC2                     | TC1           | TC0                         | 0                             | 0                 | TS1                     | TS0              | 00H   |
| B4H | R/W | TXT20  | DRCS<br>ENABLE      | OSD<br>PLANES           | 0             | 0                           | OSD LANG<br>ENABLE            | OSD LAN2          | OSD LAN1                | OSD LAN0         | 00H   |
| B5H | R/W | TXT21  | DISP<br>LINES1      | DISP<br>LINES0          | CHAR SIZE1    | CHAR<br>SIZE0               | I <sup>2</sup> C PORT 1       | CC ON             | I <sup>2</sup> C PORT 0 | CC/TXT           | 02H   |
| B6H | R   | TXT22  | GPF7                | GPF6                    | GPF5          | GPF4                        | GPF3                          | GPF2              | GPF1                    | 1                | ХХН   |
| B7H | R/W | CCLIN  | 0                   | 0                       | 0             | CS4                         | CS3                           | CS2               | CS1                     | CS0              | 15H   |
| B8H | R/W | IP     | 0                   | PBUSY                   | PES2          | PCC                         | PT1                           | PX1               | PT0                     | PX0              | 00H   |
| B9H | R/W | TXT17  | 0                   | FORCE<br>ACQ1           | FORCE<br>ACQ0 | FORCE<br>DISP1              | FORCE<br>DISP0                | SCREEN<br>COL2    | SCREEN<br>COL1          | SCREEN<br>COL0   | 00H   |
| BAH | R   | WSS1   | 0                   | 0                       | 0             | WSS<3:0><br>ERROR           | WSS3                          | WSS2              | WSS1                    | WSS0             | 00H   |
| BBH | R   | WSS2   | 0                   | 0                       | 0             | WSS<7:4><br>ERROR           | WSS7                          | WSS6              | WSS5                    | WSS4             | 00H   |
| BCH | R   | WSS3   | WSS<13:11><br>ERROR | WSS13                   | WSS12         | WSS11                       | WSS<10:8><br>ERROR            | WSS10             | WSS9                    | WSS8             | 00H   |
| BEH | R/W | P3CFGA | 1                   | 1                       | 1             | P3CFGA4                     | P3CFGA3                       | P3CFGA2           | P3CFGA1                 | P3CFGA0          | FFH   |
| BFH | R/W | P3CFGB | 0                   | 0                       | 0             | P3CFGB4                     | P3CFGB3                       | P3CFGB2           | P3CFGB1                 | P3CFGB0          | 00H   |
| C0H | R/W | TXT0   | X24 POSN            | DISPLAY<br>X24          | AUTO<br>FRAME | DISABLE<br>HEADER<br>ROLL   | DISPLAY<br>STATUS<br>ROW ONLY | DISABLE<br>FRAME  | VPS ON                  | INV ON           | 00H   |
| C1H | R/W | TXT1   | EXT PKT<br>OFF      | 8-BIT                   | ACQ OFF       | X26 OFF                     | FULL<br>FIELD                 | FIELD<br>POLARITY | H<br>POLARITY           | V<br>POLARITY    | 00H   |
| C2H | R/W | TXT2   | ACQ BANK            | REQ3                    | REQ2          | REQ1                        | REQ0                          | SC2               | SC1                     | SC0              | 00H   |
| СЗН | W   | TXT3   | _                   | _                       | —             | PRD4                        | PRD3                          | PRD2              | PRD1                    | PRD0             | 00H   |
| C4H | R/W | TXT4   | OSD BANK<br>ENABLE  | QUAD<br>WIDTH<br>ENABLE | EAST/WEST     | DISABLE<br>DOUBLE<br>HEIGHT | B MESH<br>ENABLE              | C MESH<br>ENABLE  | TRANS<br>ENABLE         | SHADOW<br>ENABLE | 00H   |
| C5H | R/W | TXT5   | BKGND OUT           | BKGND IN                | COR OUT       | COR IN                      | TEXT OUT                      | TEXT IN           | PICTURE<br>ON OUT       | PICTURE<br>ON IN | 03H   |

Philips Semiconductors

Enhanced TV microcontrollers with On-Screen Display (OSD)

Preliminary specification

SAA55xx

<del>1</del>5

2000 Feb 23

\_

| ADD | R/W | NAME   | 7                       | 6                  | 5               | 4                  | 3                  | 2               | 1                 | 0                          | RESET        |
|-----|-----|--------|-------------------------|--------------------|-----------------|--------------------|--------------------|-----------------|-------------------|----------------------------|--------------|
| C6H | R/W | TXT6   | BKGND OUT               | BKGND IN           | COR OUT         | COR IN             | TEXT OUT           | TEXT IN         | PICTURE<br>ON OUT | PICTURE<br>ON IN           | 03H          |
| C7H | R/W | TXT7   | STATUS<br>ROW TOP       | CURSOR<br>ON       | REVEAL          | BOTTOM<br>/TOP     | DOUBLE<br>HEIGHT   | BOX ON 24       | BOX ON<br>1-23    | BOX ON 0                   | 00H          |
| C8H | R/W | TXT8   | (reserved)<br>0         | FLICKER<br>STOP ON | (reserved)<br>0 | DISABLE<br>SPANISH | PKT 26<br>RECEIVED | WSS<br>RECEIVED | WSS ON            | CVBS1/<br>CVBS0            | 00H          |
| C9H | R/W | TXT9   | CURSOR<br>FREEZE        | CLEAR<br>MEMORY    | A0              | R4                 | R3                 | R2              | R1                | R0                         | 00H          |
| CAH | R/W | TXT10  | 0                       | 0                  | C5              | C4                 | C3                 | C2              | C1                | C0                         | 00H          |
| CBH | R/W | TXT11  | D7                      | D6                 | D5              | D4                 | D3                 | D2              | D1                | D0                         | 00H          |
| ССН | R   | TXT12  | 525/ <u>625</u><br>SYNC | SPANISH            | ROM VER3        | ROM VER2           | ROM VER1           | ROM VER0        | 1                 | VIDEO<br>SIGNAL<br>QUALITY | XXXX<br>XX1X |
| CDH | R/W | TXT14  | 0                       | 0                  | 0               | —                  | PAGE3              | PAGE2           | PAGE1             | PAGE0                      | 00H          |
| CEH | R/W | TXT15  | 0                       | 0                  | 0               | —                  | BLOCK3             | BLOCK2          | BLOCK1            | BLOCK0                     | 00H          |
| D0H | R/W | PSW    | С                       | AC                 | F0              | RS1                | RS0                | OV              | _                 | Р                          | 00H          |
| D2H | R/W | TDACL  | TD7                     | TD6                | TD5             | TD4                | TD3                | TD2             | TD1               | TD0                        | 00H          |
| D3H | R/W | TDACH  | TPWE                    | 1                  | TD13            | TD12               | TD11               | TD10            | TD9               | TD8                        | 40H          |
| D4H | R/W | PWM7   | PW7E                    | 1                  | PW7V5           | PW7V4              | PW7V3              | PW7V2           | PW7V1             | PW7V0                      | 40H          |
| D5H | R/W | PWM0   | PW0E                    | 1                  | PW0V5           | PW0V4              | PW0V3              | PW0V2           | PW0V1             | PW0V0                      | 40H          |
| D6H | R/W | PWM1   | PW1E                    | 1                  | PW1V5           | PW1V4              | PW1V3              | PW1V2           | PW1V1             | PW1V0                      | 40H          |
| D7H | R   | CCDAT1 | CCD17                   | CCD16              | CCD15           | CCD14              | CCD13              | CCD12           | CCD11             | CCD10                      | 00H          |
| D8H | R/W | S1CON  | CR2                     | ENSI               | STA             | STO                | SI                 | AA              | CR1               | CR0                        | 00H          |
| D9H | R   | S1STA  | STAT4                   | STAT3              | STAT2           | STAT1              | STAT0              | 0               | 0                 | 0                          | F8H          |
| DAH | R/W | S1DAT  | DAT7                    | DAT6               | DAT5            | DAT4               | DAT3               | DAT2            | DAT1              | DAT0                       | 00H          |
| DBH | R/W | S1ADR  | ADR6                    | ADR5               | ADR4            | ADR3               | ADR2               | ADR1            | ADR0              | GC                         | 00H          |
| DCH | R/W | PWM3   | PW3E                    | 1                  | PW3V5           | PW3V4              | PW3V3              | PW3V2           | PW3V1             | PW3V0                      | 40H          |
| DDH | R/W | PWM4   | PW4E                    | 1                  | PW4V5           | PW4V4              | PW4V3              | PW4V2           | PW4V1             | PW4V0                      | 40H          |
| DEH | R/W | PWM5   | PW5E                    | 1                  | PW5V5           | PW5V4              | PW5V3              | PW5V2           | PW5V1             | PW5V0                      | 40H          |
| DFH | R/W | PWM6   | PW6E                    | 1                  | PW6V5           | PW6V4              | PW6V3              | PW6V2           | PW6V1             | PW6V0                      | 40H          |
| E0H | R/W | ACC    | ACC7                    | ACC6               | ACC5            | ACC4               | ACC3               | ACC2            | ACC1              | ACC0                       | 00H          |

Philips Semiconductors

Enhanced TV microcontrollers with On-Screen Display (OSD)

Preliminary specification

SAA55xx

16

Philips Semiconductors

Preliminary specification

# Enhanced TV microcontrollers with On-Screen Display (OSD)

SAA55xx

| ADD | R/W | NAME   | 7               | 6                | 5              | 4        | 3        | 2        | 1       | 0      | RESET        |
|-----|-----|--------|-----------------|------------------|----------------|----------|----------|----------|---------|--------|--------------|
| E4H | R/W | PWM2   | PW2E            | 1                | PW2V5          | PW2V4    | PW2V3    | PW2V2    | PW2V1   | PW2V0  | 40H          |
| E7H | R   | CCDAT2 | CCD27           | CCD26            | CCD25          | CCD24    | CCD23    | CCD22    | CCD21   | CCD20  | 00H          |
| E8H | R/W | SAD    | VHI             | CH1              | CH0            | ST       | SAD7     | SAD6     | SAD5    | SAD4   | 00H          |
| F0H | R/W | В      | B7              | B6               | B5             | B4       | B3       | B2       | B1      | B0     | 00H          |
| F8H | R/W | TXT13  | VPS<br>RECEIVED | PAGE<br>CLEARING | 525<br>DISPLAY | 525 TEXT | 625 TEXT | PKT 8/30 | FASTEXT | 0      | XXXX<br>XXX0 |
| FAH | R/W | XRAMP  | XRAMP7          | XRAMP6           | XRAMP5         | XRAMP4   | XRAMP3   | XRAMP2   | XRAMP1  | XRAMP0 | 00H          |
| FBH | R/W | ROMBK  | STANDBY         | 0                | 0              | 0        | 0        | 0        | ROMBK1  | ROMBK0 | 00H          |
| FEH | R   | WDTKEY | WKEY7           | WKEY6            | WKEY5          | WKEY4    | WKEY3    | WKEY2    | WKEY1   | WKEY0  | 00H          |
| FFH | R/W | WDT    | WDV7            | WDV6             | WDV5           | WDV4     | WDV3     | WDV2     | WDV1    | WDV0   | 00H          |

\_

2000 Feb 23

# Enhanced TV microcontrollers with On-Screen Display (OSD)

### **Table 5**SFR bit description

| BIT                              | FUNCTION                                                                            |
|----------------------------------|-------------------------------------------------------------------------------------|
| Accumulator (ACC)                |                                                                                     |
| ACC7 to ACC0                     | accumulator value                                                                   |
| B Register (B)                   |                                                                                     |
| B7 to B0                         | B register value                                                                    |
| CC data byte 1 (CCDAT1)          |                                                                                     |
| CCD17 to CCD10                   | closed caption first data byte                                                      |
| CC data byte 2 (CCDAT2)          |                                                                                     |
| CCD26 to CCD20                   | closed caption second data byte                                                     |
| CC line (CCLIN)                  |                                                                                     |
| CS4 to CS0                       | closed caption slice line using 525-line number                                     |
| Data Pointer High byte (DPH)     |                                                                                     |
| DPH7 to DPH0                     | data pointer high byte, used with DPL to address auxiliary memory                   |
| Data Pointer Low byte (DPL)      |                                                                                     |
| DPL7 to DPL0                     | data pointer low byte, used with DPH to address auxiliary memory                    |
| Interrupt Enable Register (IE)   |                                                                                     |
| EA                               | disable all interrupts (logic 0), or use individual interrupt enable bits (logic 1) |
| EBUSY                            | enable BUSY interrupt                                                               |
| ES2                              | enable I <sup>2</sup> C-bus interrupt                                               |
| ECC                              | enable Closed Caption interrupt                                                     |
| ET1                              | enable Timer 1 interrupt                                                            |
| EX1                              | enable external interrupt 1                                                         |
| ET0                              | enable Timer 0 interrupt                                                            |
| EX0                              | enable external interrupt 0                                                         |
| Interrupt Priority Register (IP) |                                                                                     |
| PBUSY                            | priority EBUSY interrupt                                                            |
| PES2                             | priority ES2 interrupt                                                              |
| PCC                              | priority ECC interrupt                                                              |
| PT1                              | priority Timer 1 interrupt                                                          |
| PX1                              | priority external interrupt 1                                                       |
| PT0                              | priority Timer 0 interrupt                                                          |
| PX0                              | priority external interrupt 0                                                       |
| Port 0 (P0)                      |                                                                                     |
| P07 to P00                       | Port 0 I/O register connected to external pins                                      |

SAA55xx

# Enhanced TV microcontrollers with On-Screen Display (OSD)

| BIT                            | FUNCTION                                                                                                                                                                                     |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Port 1 (P1)                    |                                                                                                                                                                                              |
| P17 to P10                     | Port 1 I/O register connected to external pins                                                                                                                                               |
| Port 2 (P2)                    |                                                                                                                                                                                              |
| P27 to P20                     | Port 2 I/O register connected to external pins                                                                                                                                               |
| Port 3 (P3)                    |                                                                                                                                                                                              |
| P37 to P30                     | Port 3 I/O register connected to external pins; P37 to P35 are only available with the LQFP100 package.                                                                                      |
| Port 0 Configuration A (P0CFGA | ) and Port 0 Configuration B (P0CFGB)                                                                                                                                                        |
| P0CFGA<7:0> and P0CFGB<7:0>    | These two registers are used to configure Port 0 pins. For example, the configuration of Port 0 pin 3 is controlled by using bit 3 in both P0CFGA and P0CFGB. P0CFGB                         |
|                                | 00 = P0.x in open-drain configuration                                                                                                                                                        |
|                                | 01 = P0.x in quasi-bidirectional configuration                                                                                                                                               |
|                                | 10 = P0.x in high-impedance configuration                                                                                                                                                    |
|                                | 11 = P0.x in push-pull configuration                                                                                                                                                         |
| Port 1 Configuration A (P1CFGA | ) and Port 1 Configuration B (P1CFGB)                                                                                                                                                        |
| P1CFGA<7:0> and P1CFGB<7:0>    | These two registers are used to configure Port 1 pins. For example, the configuration of Port 1 pin 3 is controlled by using bit 3 in both P1CFGA and P1CFGB. P1CFGB                         |
|                                | 00 = P1.x in open-drain configuration                                                                                                                                                        |
|                                | 01 = P1.x in quasi-bidirectional configuration                                                                                                                                               |
|                                | 10 = P1.x in high-impedance configuration                                                                                                                                                    |
|                                | 11 = P1.x in push-pull configuration                                                                                                                                                         |
| Port 2 Configuration A (P2CFGA | ) and Port 2 Configuration B (P2CFGB)                                                                                                                                                        |
| P2CFGA<7:0> and P2CFGB<7:0>    | These two registers are used to configure Port 2 pins. For example, the configuration of Port 2 pin 3 is controlled by using bit 3 in both P2CFGA and P2CFGB. P2CFGB< <x>/P2CFGA<x>:</x></x> |
|                                | 00 = P2.x in open-drain configuration                                                                                                                                                        |
|                                | 01 = P2.x in quasi-bidirectional configuration                                                                                                                                               |
|                                | 10 = P2.x in high-impedance configuration                                                                                                                                                    |
|                                | 11 = P2.x in push-pull configuration                                                                                                                                                         |
| Port 3 Configuration A (P3CFGA | ) and Port 3 Configuration B (P3CFGB)                                                                                                                                                        |
| P3CFGA<7:0> and P3CFGB<7:0>    | These two registers are used to configure Port 3 pins. For example, the configuration of Port 3 pin 3 is controlled by using bit 3 in both P3CFGA and P3CFGB. P3CFGB< <x>/P3CFGA<x>:</x></x> |
|                                | 00 = P3.x in open-drain configuration                                                                                                                                                        |
|                                | 01 = P3.x in quasi-bidirectional configuration                                                                                                                                               |
|                                | 10 = P3.x in high-impedance configuration                                                                                                                                                    |
|                                | 11 = P3.x in push-pull configuration                                                                                                                                                         |

| BIT                       | FUNCTION                                                                         |
|---------------------------|----------------------------------------------------------------------------------|
| Power Control Register (P | CON)                                                                             |
| ARD                       | auxiliary RAM disable bit, all MOVX instructions access the external data memory |
| RFI                       | disable ALE during internal access to reduce radio frequency interference        |
| WLE                       | Watchdog Timer enable                                                            |
| GF1                       | general purpose flag 1                                                           |
| GF0                       | general purpose flag 0                                                           |
| PD                        | Power-down mode activation bit                                                   |
| IDL                       | Idle mode activation bit                                                         |
| Program Status Word (PS)  | N)                                                                               |
| С                         | carry bit                                                                        |
| AC                        | auxiliary carry bit                                                              |
| F0                        | flag 0                                                                           |
| RS1 to RS0                | register bank selector bits RS<1:0>:                                             |
|                           | 00 = Bank 0 (00H to 07H)                                                         |
|                           | 01 = Bank 1 (08H to 0FH)                                                         |
|                           | 10 = Bank 2 (10H to 17H)                                                         |
|                           | 11 = Bank 3 (18H to 1FH)                                                         |
| OV                        | overflow flag                                                                    |
| Р                         | parity bit                                                                       |
| Pulse Width Modulator 0 C | control Register (PWM0)                                                          |
| PW0E                      | activate this PWM and take control of respective port pin (logic 1)              |
| PW0V5 to PW0V0            | pulse width modulator high time                                                  |
| Pulse Width Modulator 1 C | Control Register (PWM1)                                                          |
| PW1E                      | activate this PWM (logic 1)                                                      |
| PW1V5 to PW1V0            | pulse width modulator high time                                                  |
| Pulse Width Modulator 2 C | Control Register (PWM2)                                                          |
| PW2E                      | activate this PWM (logic 1)                                                      |
| PW2V5 to PW2V0            | pulse width modulator high time                                                  |
| Pulse Width Modulator 3 C | Control Register (PWM3)                                                          |
| PW3E                      | activate this PWM (logic 1)                                                      |
| PW3V5 to PW3V0            | pulse width modulator high time                                                  |
| Pulse Width Modulator 4 C | Control Register (PWM4)                                                          |
| PW4E                      | activate this PWM (logic 1)                                                      |
| PW4V5 to PW4V0            | pulse width modulator high time                                                  |
|                           |                                                                                  |

# Enhanced TV microcontrollers with On-Screen Display (OSD)

| BIT                                             | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|-------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Pulse Width Modulator 5 Control Register (PWM5) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| PW5E                                            | activate this PWM (logic 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| PW5V5 to PW5V0                                  | pulse width modulator high time                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| Pulse Width Modulator 6 Control Register (PWM6) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| PW6E                                            | activate this PWM (logic 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| PW6V5 to PW6V0                                  | pulse width modulator high time                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| Pulse Width Modulator 7 Cor                     | ntrol Register (PWM7)                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| PW7E                                            | activate this PWM (logic 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| PW7V5 to PW7V0                                  | pulse width modulator high time                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| ROM Bank (ROMBK)                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| ROMBK1 to ROMBK0                                | ROM Bank selection bits; ROMBK<1:0>:                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|                                                 | 00 = Bank 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|                                                 | 01 = Bank 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|                                                 | 10 = Bank 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|                                                 | 11 = reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| STANDBY                                         | standby activation bit                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| I <sup>2</sup> C-bus Slave Address Regis        | ster (S1ADR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| ADR6 to ADR0                                    | I <sup>2</sup> C-bus slave address to which the device will respond                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| GC                                              | enable I <sup>2</sup> C-bus general call address (logic 1)                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
| I <sup>2</sup> C-bus Control Register (S1       | CON)                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| CR2 to CR0                                      | clock rate bits; CR<2:0>:                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|                                                 | 000 = 100 kHz bit rate                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|                                                 | 001 = 3.75 kHz bit rate                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                                                 | 010 = 150 kHz bit rate                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|                                                 | 011 = 200 kHz bit rate                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|                                                 | 100 = 25 kHz bit rate                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|                                                 | 101 = 1.875 kHz bit rate                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|                                                 | 110 = 37.5 kHz bit rate                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                                                 | 111 = 50 kHz bit rate                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| ENSI                                            | enable I <sup>2</sup> C-bus interface (logic 1)                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| STA                                             | <b>START flag.</b> When this bit is set in slave mode, the hardware checks the I <sup>2</sup> C-bus and generates a START condition if the bus is free or after the bus becomes free. If the device operates in master mode it will generate a repeated START condition.                                                                                                                                                                                                          |  |  |  |  |
| STO                                             | <b>STOP flag.</b> If this bit is set in a master mode a STOP condition is generated.<br>A STOP condition detected on the I <sup>2</sup> C-bus clears this bit. This bit may also be set<br>in slave mode in order to recover from an error condition. In this case no STOP<br>condition is generated to the I <sup>2</sup> C-bus, but the hardware releases the SDA and<br>SCL lines and switches to the not selected receiver mode. The STOP flag is<br>cleared by the hardware. |  |  |  |  |

| BIT                                     | FUNCTION                                                                                                                                                                                         |
|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SI                                      | <b>Serial Interrupt flag.</b> This flag is set and an interrupt request is generated, after any of the following events occur:                                                                   |
|                                         | A START condition is generated in master mode                                                                                                                                                    |
|                                         | • The own slave address has been received during AA = 1                                                                                                                                          |
|                                         | • The general call address has been received while S1ADR.GC and AA = 1                                                                                                                           |
|                                         | A data byte has been received or transmitted in master mode (even if arbitration is lost)                                                                                                        |
|                                         | A data byte has been received or transmitted as selected slave                                                                                                                                   |
|                                         | • A STOP or START condition is received as selected slave receiver or transmitter. While the SI flag is set, SCL remains LOW and the serial transfer is suspended. SI must be reset by software. |
| AA                                      | <b>Assert Acknowledge flag.</b> When this bit is set, an acknowledge is returned after any one of the following conditions:                                                                      |
|                                         | Own slave address is received                                                                                                                                                                    |
|                                         | <ul> <li>General call address is received (S1ADR.GC = 1)</li> </ul>                                                                                                                              |
|                                         | • A data byte is received, while the device is programmed to be a master receiver                                                                                                                |
|                                         | • A data byte is received, while the device is selected slave receiver.                                                                                                                          |
|                                         | When the bit is reset, no acknowledge is returned. Consequently, no interrupt is requested when the own address or general call address is received.                                             |
| I <sup>2</sup> C-bus Data Register (S1I | DAT)                                                                                                                                                                                             |
| DAT7 to DAT0                            | I <sup>2</sup> C-bus data                                                                                                                                                                        |
| I <sup>2</sup> C-bus Status Register (S | 1STA)                                                                                                                                                                                            |
| STAT4 to STAT0                          | I <sup>2</sup> C-bus interface status                                                                                                                                                            |
| Software ADC Register (S                | AD)                                                                                                                                                                                              |
| VHI                                     | analog input voltage greater than DAC voltage (logic 1)                                                                                                                                          |
| CH1 to CH0                              | ADC input channel select bits; CH<1:0>:                                                                                                                                                          |
|                                         | 00 = ADC3                                                                                                                                                                                        |
|                                         | 01 = ADC0                                                                                                                                                                                        |
|                                         | 10 = ADC1                                                                                                                                                                                        |
|                                         | 11 = ADC2                                                                                                                                                                                        |
| ST <sup>(1)</sup>                       | initiate voltage comparison between ADC input channel and SAD value                                                                                                                              |
| SAD7 to SAD4                            | 4 MSBs of DAC input word                                                                                                                                                                         |
| Software ADC Control Reg                | gister (SADB)                                                                                                                                                                                    |
| DC_COMP                                 | enable DC comparator mode (logic 1)                                                                                                                                                              |
| SAD3 to SAD0                            | 4 LSBs of SAD value                                                                                                                                                                              |
| Stack Pointer (SP)                      |                                                                                                                                                                                                  |
| SP7 to SP0                              | stack pointer value                                                                                                                                                                              |
|                                         |                                                                                                                                                                                                  |

| BIT                     | FUNCTION                                                                                                                                              |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Timer/Counter Control R | egister (TCON)                                                                                                                                        |
| TF1                     | <b>Timer 1 overflow flag.</b> Set by hardware on timer/counter overflow. Cleared by hardware when processor vectors to interrupt routine.             |
| TR1                     | Timer 1 run control bit. Set/cleared by software to turn timer/counter on/off.                                                                        |
| TF0                     | <b>Timer 0 overflow flag.</b> Set by hardware on timer/counter overflow. Cleared by hardware when processor vectors to interrupt routine.             |
| TR0                     | Timer 0 run control bit. Set/cleared by software to turn timer/counter on/off.                                                                        |
| IE1                     | Interrupt 1 edge flag. Both edges generate flag. Set by hardware when external interrupt edge detected. Cleared by hardware when interrupt processed. |
| IT1                     | Interrupt 1 type control bit. Set/cleared by software to specify edge/low level triggered external interrupts.                                        |
| IEO                     | Interrupt 0 Edge I flag. Set by hardware when external interrupt edge detected.<br>Cleared by hardware when interrupt processed.                      |
| ITO                     | Interrupt 0 type flag. Set/cleared by software to specify falling edge/low level triggered external interrupts.                                       |
| 14-bit PWM MSB Registe  | er (TDACH)                                                                                                                                            |
| TPWE                    | activate this 14-bit PWM (logic 1)                                                                                                                    |
| TD13 to TD8             | 6 MSBs of 14-bit number to be output by the 14-bit PWM                                                                                                |
| 14-bit PWM LSB Registe  | r (TDACL)                                                                                                                                             |
| TD7 to TD0              | 8 LSBs of 14-bit number to be output by the 14-bit PWM                                                                                                |
| Timer 0 High byte (TH0) |                                                                                                                                                       |
| TH07 to TH00            | 8 MSBs of Timer 0 16-bit counter                                                                                                                      |
| Timer 1 High byte (TH1) |                                                                                                                                                       |
| TH17 to TH10            | 8 MSBs of Timer 1 16-bit counter                                                                                                                      |
| Timer 0 Low byte (TL0)  |                                                                                                                                                       |
| TL07 to TL00            | 8 LSBs of Timer 0 16-bit counter                                                                                                                      |
| Timer 1 Low byte (TL1)  |                                                                                                                                                       |
| TL17 to TL10            | 8 LSBs of Timer 1 16-bit counter                                                                                                                      |
| Timer/Counter Mode Co   | ntrol (TMOD)                                                                                                                                          |
| GATE                    | gating control Timer/Counter 1                                                                                                                        |
| C/T                     | Counter/Timer 1 selector                                                                                                                              |
| M1 to M0                | mode control bits timer/counter 1; M<1:0>:                                                                                                            |
|                         | 00 = 8-bit timer or 8-bit counter with divide-by-32 prescaler                                                                                         |
|                         | 01 = 16-bit time interval or event counter                                                                                                            |
|                         | 10 = 8-bit time interval or event counter with automatic reload upon overflow; reload value stored in TH1                                             |
|                         | 11 = stopped                                                                                                                                          |
| GATE                    | Gating control Timer/Counter 0                                                                                                                        |
| C/T                     | Counter/Timer 0 selector                                                                                                                              |

# Enhanced TV microcontrollers with On-Screen Display (OSD)

|          | SAA55xx |
|----------|---------|
|          |         |
| FUNCTION |         |

| BIT                     | FUNCTION                                                                                                  |
|-------------------------|-----------------------------------------------------------------------------------------------------------|
| M1 to M0                | mode control bits timer/counter 0; M<1:0>                                                                 |
|                         | 00 = 8-bit timer or 8-bit counter with divide-by-32 prescaler                                             |
|                         | 01 = 16-bit time interval or event counter                                                                |
|                         | 10 = 8-bit time interval or event counter with automatic reload upon overflow; reload value stored in TH0 |
|                         | 11 = one 8-bit time interval or event counter and one 8-bit time interval counter                         |
| Text Register 0 (TXT0)  |                                                                                                           |
| X24 POSN                | store packet 24 in extension packet memory (logic 0) or page memory (logic 1)                             |
| DISPLAY X24             | display X24 from page memory (logic 0) or extension packet memory (logic 1)                               |
| AUTO FRAME              | FRAME output switched off automatically if any video displayed (logic 1)                                  |
| DISABLE HEADER ROLL     | disable writing of rolling headers and time into memory (logic 1)                                         |
| DISPLAY STATUS ROW ONLY | display row 24 only (logic 1)                                                                             |
| DISABLE FRAME           | FRAME output always LOW (logic 1)                                                                         |
| VPS ON                  | enable capture of VPS data (logic 1)                                                                      |
| INV ON                  | enable capture of inventory page in block 8 (logic 1)                                                     |
| Text Register 1 (TXT1)  |                                                                                                           |
| EXT PKT OFF             | disable acquisition of extension packets (logic 1)                                                        |
| 8-BIT                   | disable checking of packets 0 to 24 written into memory (logic 1)                                         |
| ACQ OFF                 | disable writing of data into Display memory (logic 1)                                                     |
| X26 OFF                 | disable automatic processing of X/26 data (logic 1)                                                       |
| FULL FIELD              | acquire data on any TV line (logic 1)                                                                     |
| FIELD POLARITY          | VSYNC pulse in second half of line during even field (logic 1)                                            |
| H POLARITY              | HSYNC reference edge is negative going (logic 1)                                                          |
| V POLARITY              | VSYNC reference edge is negative going (logic 1)                                                          |
| Text Register 2 (TXT2)  |                                                                                                           |
| ACQ BANK                | select acquisition Bank 1 (logic 1)                                                                       |
| REQ3 to REQ0            | page request                                                                                              |
| SC2 to SC0              | start column of page request                                                                              |
| Text Register 3 (TXT3)  |                                                                                                           |
| PRD4 to PRD0            | page request data                                                                                         |
| Text Register 4 (TXT4)  |                                                                                                           |
| OSD BANK ENABLE         | alternate OSD location available via graphic attribute, additional 32 locations (logic 1)                 |
| QUAD WIDTH ENABLE       | enable display of quadruple width characters (logic 1)                                                    |
| EAST/WEST               | eastern language selection of character codes A0H to FFH (logic 1)                                        |
| DISABLE DOUBLE HEIGHT   | disable normal decoding of double height characters (logic 1)                                             |
| B MESH ENABLE           | enable meshing of black background (logic 1)                                                              |
| C MESH ENABLE           | enable meshing of coloured background (logic 1)                                                           |
| TRANS ENABLE            | display black background as video (logic 1)                                                               |
| SHADOW ENABLE           | display shadow/fringe (default SE black) (logic 1)                                                        |

# Enhanced TV microcontrollers with On-Screen Display (OSD)

| BIT                            | FUNCTION                                                                           |
|--------------------------------|------------------------------------------------------------------------------------|
| Text Register 5 (TXT5)         |                                                                                    |
| BKGND OUT                      | background colour displayed outside teletext boxes (logic 1)                       |
| BKGND IN                       | background colour displayed inside teletext boxes (logic 1)                        |
| COR OUT                        | COR active outside teletext and OSD boxes (logic 1)                                |
| COR IN                         | COR active inside teletext and OSD boxes (logic 1)                                 |
| TEXT OUT                       | text displayed outside teletext boxes (logic 1)                                    |
| TEXT IN                        | text displayed inside teletext boxes (logic 1)                                     |
| PICTURE ON OUT                 | video displayed outside teletext boxes (logic 1)                                   |
| PICTURE ON IN                  | video displayed inside teletext boxes (logic 1)                                    |
| Text Register 6 (TXT6)         |                                                                                    |
| BKGND OUT                      | background colour displayed outside teletext boxes (logic 1)                       |
| BKGND IN                       | background colour displayed inside teletext boxes (logic 1)                        |
| COR OUT                        | COR active outside teletext and OSD boxes (logic 1)                                |
| COR IN                         | COR active inside teletext and OSD boxes (logic 1)                                 |
| TEXT OUT                       | text displayed outside teletext boxes (logic 1)                                    |
| TEXT IN                        | text displayed inside teletext boxes (logic 1)                                     |
| PICTURE ON OUT                 | video displayed outside teletext boxes (logic 1)                                   |
| PICTURE ON IN                  | video displayed inside teletext boxes (logic 1)                                    |
| Text Register 7 (TXT7)         |                                                                                    |
| STATUS ROW TOP                 | display memory row 24 information above teletext page (on display row 0) (logic 1) |
| CURSOR ON                      | display cursor at position given by TXT9 and TXT10 (logic 1)                       |
| REVEAL                         | display characters in area with conceal attribute set (logic 1)                    |
| BOTTOM/TOP                     | display memory rows 12 to 23 when DOUBLE HEIGHT height bit is set (logic 1)        |
| DOUBLE HEIGHT                  | display each character as twice normal height (logic 1)                            |
| BOX ON 24                      | enable display of teletext boxes in memory row 24 (logic 1)                        |
| BOX ON 1 to 23                 | enable display of teletext boxes in memory row 1 to 23 (logic 1)                   |
| BOX ON 0                       | enable display of teletext boxes in memory row 0 (logic 1)                         |
| Text Register 8 (TXT8)         |                                                                                    |
| FLICKER STOP ON                | disable 'Flicker Stopper' circuitry (logic 1)                                      |
| DISABLE SPANISH                | disable special treatment of Spanish packet 26 characters (logic 1)                |
| PKT 26 RECEIVED <sup>(2)</sup> | packet 26 data has been processed (logic 1)                                        |
| WSS RECEIVED <sup>(2)</sup>    | WSS data has been processed (logic 1)                                              |
| WSS ON                         | enable acquisition of WSS data (logic 1)                                           |
| CVBS1/CVBS0                    | select CVBS1 as source for device (logic 1)                                        |

# lore with

Preliminary specification

# Enhanced TV microcontrollers with On-Screen Display (OSD)

| BIT                         | FUNCTION                                                                         |
|-----------------------------|----------------------------------------------------------------------------------|
| Text Register 9 (TXT9)      |                                                                                  |
| CURSOR FREEZE               | lock cursor at current position (logic 1)                                        |
| CLEAR MEMORY <sup>(1)</sup> | clear memory block pointed to by TXT15 (logic 1)                                 |
| A0                          | access extension packet memory (logic 1)                                         |
| R4 to R0 <sup>(3)</sup>     | current memory row value                                                         |
| Text Register 10 (TXT10)    |                                                                                  |
| C5 to C0 <sup>(4)</sup>     | current memory column value                                                      |
| Text Register 11 (TXT11)    |                                                                                  |
| D7 to D0                    | data value written or read from memory location defined by TXT9, TXT10 and TXT15 |
| Text Register 12 (TXT12)    |                                                                                  |
| 625/525 SYNC                | 525-line CVBS signal is being received (logic 1)                                 |
| SPANISH                     | Spanish character set present (logic 1)                                          |
| ROM VER3 to ROM VER0        | mask programmable identification for character set                               |
| VIDEO SIGNAL QUALITY        | acquisition can be synchronized to CVBS (logic 1)                                |
| Text Register 13 (TXT13)    |                                                                                  |
| VPS RECEIVED                | VPS data (logic 1)                                                               |
| PAGE CLEARING               | software or power-on page clear in progress (logic 1)                            |
| 525 DISPLAY                 | 525-line synchronisation for display (logic 1)                                   |
| 525 TEXT                    | 525-line WST being received (logic 1)                                            |
| 625 TEXT                    | 625-line WST being received (logic 1)                                            |
| PKT 8/30                    | packet 8/30/x(625) or packet 4/30/x(525) data detected (logic 1)                 |
| FASTEXT                     | packet x/27 data detected (logic 1)                                              |
| Text Register 14 (TXT14)    |                                                                                  |
| PAGE3 to PAGE0              | current display page                                                             |
| Text Register 15 (TXT15)    |                                                                                  |
| BLOCK3 to BLOCK0            | current micro block to be accessed by TXT9, TXT10 and TXT11                      |
| Text Register 17 (TXT17)    |                                                                                  |
| FORCE ACQ1 to FORCE ACQ0    | FORCE ACQ<1:0>:                                                                  |
|                             | 00 = automatic selection                                                         |
|                             | 01 = force 525 timing, force 525 teletext standard                               |
|                             | 10 = force 625 timing, force 625 teletext standard                               |
|                             | 11 = force 625 timing, force 525 teletext standard                               |
| FORCE DISP1 to FORCE DISP0  | FORCE DISP<1:0>:                                                                 |
|                             | 00 = automatic selection                                                         |
|                             | 01 = force display to 525 mode (9 lines per row)                                 |
|                             | 10 = force display to 625 mode (10 lines per row)                                |
|                             | 11 = not valid (default to 625)                                                  |

# Enhanced TV microcontrollers with On-Screen Display (OSD)

| BIT                        | FUNCTION                                                                                                                                     |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| SCREEN COL2 to SCREEN COL0 | Defines colour to be displayed instead of TV picture and black background; these bits are equivalent to the RGB components. SCREEN COL<2:0>: |
|                            | 000 = transparent                                                                                                                            |
|                            | 001 = CLUT entry 9                                                                                                                           |
|                            | 010 = CLUT entry 10                                                                                                                          |
|                            | 011 = CLUT entry 11                                                                                                                          |
|                            | 100 = CLUT entry 12                                                                                                                          |
|                            | 101 = CLUT entry 13                                                                                                                          |
|                            | 110 = CLUT entry 14                                                                                                                          |
|                            | 111 = CLUT entry 15                                                                                                                          |
| Text Register 18 (TXT18)   |                                                                                                                                              |
| NOT3 to NOT0               | national option table selection, maximum of 31 when used with EAST/WEST bit                                                                  |
| BS1 to BS0                 | basic character set selection                                                                                                                |
| Text Register 19 (TXT19)   |                                                                                                                                              |
| TEN                        | enable twist character set (logic 1)                                                                                                         |
| TC2 to TC0                 | language control bits (C12, C13 and C14) that has twisted character set                                                                      |
| TS1 to TS0                 | twist character set selection                                                                                                                |
| Text Register 20 (TXT20)   |                                                                                                                                              |
| DRCS ENABLE                | re-map column 9 to DRCS in TXT mode (logic 1)                                                                                                |
| OSD PLANES                 | character code columns 8 and 9 defined as double plane characters (logic 1)                                                                  |
| OSD LANG ENABLE            | enable use of OSD LAN<2:0> to define language option for display, instead of C12, C13 and C14                                                |
| OSD LAN2 to OSD LAN0       | alternative C12, C13 and C14 bits for use with OSD menus                                                                                     |
| Text Register 21 (TXT21)   |                                                                                                                                              |
| DISP LINES1 to DISP LINES0 | the number of display lines per character row; DISP LINES<1:0>:                                                                              |
|                            | 00 = 10 lines per character (defaults to 9 lines in 525 mode)                                                                                |
|                            | 01 = 13 lines per character                                                                                                                  |
|                            | 10 = 16 lines per character                                                                                                                  |
|                            | 11 = reserved                                                                                                                                |
| CHAR SIZE1 to CHAR SIZE0   | character matrix size bits; CHAR SIZE<1:0>:                                                                                                  |
|                            | $00 = 10$ lines per character (matrix $12 \times 10$ )                                                                                       |
|                            | $01 = 13$ lines per character (matrix $12 \times 13$ )                                                                                       |
|                            | $10 = 16$ lines per character (matrix $12 \times 16$ )                                                                                       |
|                            | 11 = reserved                                                                                                                                |
| I <sup>2</sup> C PORT 1    | enable I <sup>2</sup> C-bus Port 1 selection (P1.5/SDA1 and P1.4/SCL1) (logic 1)                                                             |
| CCON                       | closed caption acquisition on (logic 1)                                                                                                      |
| I <sup>2</sup> C PORT 0    | enable I <sup>2</sup> C-bus Port 0 selection (P1.7/SDA0 and P1.6/SCL0) (logic 1)                                                             |
| CC/TXT                     | display configured for CC mode (logic 1)                                                                                                     |

# Enhanced TV microcontrollers with On-Screen Display (OSD)

# SAA55xx

| BIT                           | FUNCTION                                                                                |
|-------------------------------|-----------------------------------------------------------------------------------------|
| Text Register 22 (TXT22)      |                                                                                         |
| GPF7 to GPF75                 | general purpose register, bits defined by mask programmable bits                        |
| GPF4                          | 1 to 10 pages available (logic 1)                                                       |
| GPF3                          | PWM0, PWM1, PWM2 and PWM3 outputs routed to Port 2.1 to Port 2.4 respectively (logic 1) |
| GPF2                          | closed caption acquisition available (logic 1)                                          |
| GPF1                          | text acquisition available (logic 1)                                                    |
| Watchdog Timer (WDT)          |                                                                                         |
| WDV7 to WDV0                  | Watchdog Timer period                                                                   |
| Watchdog Timer Key (WDT       | KEY)                                                                                    |
| WKEY7 to WKEY0 <sup>(5)</sup> | Watchdog Timer Key                                                                      |
| Wide Screen Signalling 1 (V   | VSS1)                                                                                   |
| WSS<3:0> ERROR                | error in WSS<3:0> (logic 1)                                                             |
| WSS3 to WSS0                  | signalling bits to define aspect ratio (group 1)                                        |
| Wide Screen Signalling 2 (V   | VSS2)                                                                                   |
| WSS<7:4> ERROR                | error in WSS<7:4> (logic 1)                                                             |
| WSS7 to WSS4                  | signalling bits to define enhanced services (group 2)                                   |
| Wide Screen Signalling 3 (V   | VSS3)                                                                                   |
| WSS<13:11> ERROR              | error in WSS<13:11> (logic 1)                                                           |
| WSS13 to WSS11                | signalling bits to define reserved elements (group 4)                                   |
| WSS<10:8> ERROR               | error in WSS<10:8> (logic 1)                                                            |
| WSS10 to WSS8                 | signalling bits to define subtitles (group 3)                                           |
| XRAMP                         |                                                                                         |
| XRAMP7 to XRAMP0              | internal RAM access upper byte address                                                  |

### Notes

- 1. This flag is set by software and reset by hardware.
- 2. This flag is set by hardware and must be reset by software.
- 3. Valid range TXT mode 0 to 24.
- 4. Valid range TXT mode 0 to 39.
- 5. Must be set to 55H to disable Watchdog Timer when active.

# Enhanced TV microcontrollers with On-Screen Display (OSD)

### 8.6 Character set feature bits

Features available on the SAA55xx devices are reflected in a specific area of the character ROM. These sections of the character ROM are mapped to two Special Function Registers: TXT22 and TXT12. Character ROM address 09FEH is mapped to SFR TXT22 as shown in Table . Character ROM address 09FFH is mapped to SFR TXT12 as shown in Table .

### Table 6 Character ROM - TXT22 mapping

U = used; X = reserved

| MAPPED ITEMS                   | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------------------------|----|----|---|---|---|---|---|---|---|---|---|---|
| Character ROM<br>address 09FEH | Х  | Х  | Х | Х | X | X | Х | U | U | U | U | Х |
| Mapped to TXT22                | -  | -  | - | _ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

### Table 7 Description of Character ROM address 09FEH bits

| BIT     | FUNCTION                                                                         |
|---------|----------------------------------------------------------------------------------|
| 0       | reserved; normally set to logic 1                                                |
| 1       | 1 = Text Acquisition available                                                   |
|         | 0 = Text Acquisition not available                                               |
| 2       | 1 = Closed Caption Acquisition available                                         |
|         | 0 = Closed Caption Acquisition not available                                     |
| 3       | 1 = PWM0, PWM1, PWM2 and PWM3 output routed to Port 2.1 to Port 2.4 respectively |
|         | 0 = PWM0, PWM1, PWM2 and PWM3 output routed to Port 3.0 to Port 3.3 respectively |
| 4       | 1 = 10 page available                                                            |
|         | 0 = 6 page available                                                             |
| 5 to 11 | reserved; normally set to logic 1                                                |

### Table 8 Character ROM - TXT12 mapping

U = used; X = reserved

| MAPPED ITEMS                   | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------------------------|----|----|---|---|---|---|---|---|---|---|---|---|
| Character ROM<br>address 09FFH | Х  | Х  | Х | X | X | X | Х | U | Х | Х | Х | Х |
| Mapped to TXT12                | _  | -  | _ | - | _ | - | _ | 6 | 5 | 4 | 3 | 2 |

### Table 9 Description of Character ROM address 09FFH bits

| BIT             | FUNCTION                              |  |  |  |
|-----------------|---------------------------------------|--|--|--|
| 4               | = Spanish character set present       |  |  |  |
|                 | ) = no Spanish character set present  |  |  |  |
| 0 to 3, 5 to 11 | reserved; normally all set to logic 1 |  |  |  |

### 8.7 External (Auxiliary) memory

The normal 80C51 external memory area has been mapped internally to the device, this means that the MOVX instruction accesses memory internal to the device.

# SAA55xx

### 8.7.1 AUXILIARY RAM PAGE SELECTION

The Auxiliary RAM page pointer is used to select one of the 256 pages within the Auxiliary RAM, not all pages are allocated; refer to Fig.11 for further detail. A page consists of 256 consecutive bytes.





### 9 POWER-ON RESET

An automatic reset can be obtained when  $V_{DD}$  is turned on by connecting the RESET pin to  $V_{DDP}$  through a 10  $\mu F$  capacitor, providing the  $V_{DD}$  rise time does not exceed 1 ms, and the oscillator start-up time does not exceed 10 ms.

To ensure correct initialisation, the RESET pin must be held HIGH long enough for the oscillator to settle following power-up, usually a few milli-seconds. Once the oscillator is stable, a further 24 clocks are required to generate the reset (two machine cycles of the microcontroller). Once the above reset condition has been detected an internal reset signal is triggered which remains active for 2048 clock cycles.

### 10 REDUCED POWER MODES

There are two power saving modes, Idle and Power-down, incorporated into the 10 page devices. There is an additional Standby mode incorporated into the 1 page devices. When utilizing any mode, power to the device ( $V_{DDP}$ ,  $V_{DDC}$  and  $V_{DDA}$ ) should be maintained, since power saving is achieved by clock gating on a section by section basis.

### 10.1 Idle mode

During Idle mode, Acquisition, Display and the CPU sections of the device are disabled. The following functions remain active:

- · Memory interface
- I<sup>2</sup>C-bus interface
- Timer/Counters
- Watchdog Timer
- Pulse Width Modulators.

To enter Idle mode the IDL bit in the PCON register must be set. The Watchdog Timer must be disabled prior to entering Idle to prevent the device being reset. Once in Idle mode, the XTAL oscillator continues to run, but the internal clock to the CPU, Acquisition and Display are gated out. However, the clocks to the Memory interface, I<sup>2</sup>C-bus interface, Timer/Counters, Watchdog Timer and Pulse Width Modulators are maintained. The CPU state is frozen along with the status of all SFRs, internal RAM contents are maintained, as are the device output pin values. Since the output values on RGB and VDS are maintained the display output must be disabled before entering this mode.

There are three methods available to recover from Idle:

- Assertion of an enabled interrupt will cause the IDL bit to be cleared by hardware, thus terminating Idle mode. The interrupt is serviced, and following the instruction RETI, the next instruction to be executed will be the one after the instruction that put the device into Idle mode.
- A second method of exiting Idle is via an interrupt generated by the SAD DC Compare circuit. When the device is configured in this mode, detection of an analog threshold at the input to the SAD may be used to trigger wake-up of the device i.e. TV Front Panel Key-press. As above, the interrupt is serviced, and following the instruction RETI, the next instruction to be executed will be the one following the instruction that put the device into Idle.

• The third method of terminating Idle mode is with an external hardware reset. Since the oscillator is running, the hardware reset need only be active for two machine cycles (24 clocks at 12 MHz) to complete the reset operation. Reset defines all SFRs and Display memory to a predefined state, but maintains all other RAM values. Code execution commences with the Program Counter set to '0000'.

#### 10.2 Power-down mode

In Power-down mode the XTAL oscillator is stopped. The contents of all SFRs and Data memory are maintained, However, the contents of the Auxiliary/Display memory are lost. The port pins maintain the values defined by their associated SFRs. Since the output values on RGB and VDS are maintained the display output must be made inactive before entering Power-down mode.

The Power-down mode is activated by setting the PD bit in the PCON register. It is advised to disable the Watchdog Timer prior to entering Power-down.

There are three methods of exiting Power-down:

- An external interrupt provides the first mechanism for waking from Power-down. Since the clock is stopped, external interrupts need to be set level sensitive prior to entering Power-down. The interrupt is serviced, and following the instruction RETI, the next instruction to be executed will be the one after the instruction that put the device into Power-down mode.
- A second method of exiting Power-down is via an interrupt generated by the SAD DC Compare circuit. When the device is configured in this mode, detection of a certain analog threshold at the input to the SAD may be used to trigger wake-up of the device i.e. TV Front Panel Key-press. As above, the interrupt is serviced, and following the instruction RETI, the next instruction to be executed will be the one following the instruction that put the device into Power-down.
- The third method of terminating the Power-down mode is with an external hardware reset. Reset defines all SFRs and Display memory, but maintains all other RAM values. Code execution commences with the Program Counter set to '0000'.

SAA55xx

# Enhanced TV microcontrollers with On-Screen Display (OSD)

### 10.3 Standby mode

This mode is only available on 1 page devices. When Standby mode is entered both Acquisition and Display sections are disabled. The following functions remain active:

- 80C51 core
- Memory interface
- I<sup>2</sup>C-bus interface
- Timer/Counters
- Watchdog Timer
- Software ADC
- Pulse Width Modulators

To enter Standby mode, the STANDBY control bit in the ROMBANK SFR (bit 7) must be set. It can be used in conjunction with either Idle or Power-down modes to switch between power saving modes. This mode enables the 80C51 core to decode either IR remote commands or receive I<sup>2</sup>C-bus commands without the device being fully powered.

The Standby state is maintained upon exit from either the Idle mode or Power-down mode. No wake-up from Standby is necessary as the 80C51 core remains operational.

Since the output values on RGB and VDS are maintained the display output must be disabled before entering this mode.

### 11 I/O FACILITY

### 11.1 I/O ports

The SAA55xx devices have 29 I/O lines, each is individually addressable, or form 3 parallel 8-bit addressable ports which are Port 0, Port 1 and Port 2. Port 3 has 5-bit parallel I/O only.

### 11.2 Port type

All individual ports can be programmed to function in one of four I/O configurations: open-drain, quasi-bidirectional, high-impedance and push-pull. The I/O configuration is selected using two associated Port Configuration Registers: PnCFGA and PnCFGB (where n = port number 0, 1, 2 or 3); see Table 5.

### 11.2.1 OPEN-DRAIN

The open-drain configuration can be used for bidirectional operation of a port. It requires an external pull-up resistor, the pull-up voltage has a maximum value of 5.5 V, to allow connection of the device into a 5 V environment.

The  $l^2C$ -bus ports (P1.4, P1.5, P1.6 and P1.7) can only be configured as open-drain.

### 11.2.2 QUASI-BIDIRECTIONAL

The quasi-bidirectional configuration is a combination of open-drain and push-pull. It requires an external pull-up resistor to  $V_{DDP}$  (normally 3.3 V). When a signal transition from LOW-to-HIGH is output from the device, the pad is put into push-pull configuration for one clock cycle (166 ns) after which the pad goes into open-drain configuration. This configuration is used to speed up the edges of signal transitions. This is the default mode of operation of the pads after reset.

### 11.2.3 HIGH-IMPEDANCE

The high-impedance configuration can be used for input only operation of the port. When using this configuration the two output transistors are turned off.

### 11.2.4 PUSH-PULL

The push-pull configuration can be used for output only. In this mode the signal is driven to either 0 V or  $V_{DDP}$ , which is nominally 3.3 V.

### 11.3 Port alternative functions

Ports 1, 2 and 3 are shared with alternative functions to enable control of external devices and circuitry. The alternative functions are enabled by setting the appropriate SFR and also writing a logic 1 to the port bit that the function occupies.

### 11.4 LED support

Port pins P0.5 and P0.6 have a 8 mA current sinking capability to enable LEDs in series with current limiting resistors to be driven directly, without the need for additional buffering circuitry.

### **12 INTERRUPT SYSTEM**

The device has 7 interrupt sources, each of which can be enabled or disabled. When enabled each interrupt can be assigned one of two priority levels. There are four interrupts that are common to the 80C51, two of these are external interrupts (EX0 and EX1) and the other two are timer interrupts (ET0 and ET1). In addition to the conventional 80C51 interrupts, two application specific interrupts are incorporated internal to the device which have following functionality:

- Closed Caption Data Ready interrupt (ECC). This interrupt is generated when the device is configured in Closed Caption Acquisition mode. The interrupt is activated at the end of the currently selected Slice Line as defined in the CCLIN SFR.
- Display Busy interrupt (EBUSY). An interrupt is generated when the display enters either a Horizontal or Vertical Blanking Period. i.e. indicates when the microcontroller can update the Display RAM without causing undesired effects on the screen. This interrupt can be configured in one of two modes using the MMR Configuration Register (address 87FFH, bit TXT/V).
  - Text Display Busy. An interrupt is generated on each active horizontal display line when the Horizontal Blanking Period is entered.
  - Vertical Display Busy. An interrupt is generated on each vertical display field when the Vertical Blanking Period is entered.

### 12.1 Interrupt enable structure

Each of the individual interrupts can be enabled or disabled by setting or clearing the relevant bit in the interrupt enable SFR(IE). All interrupt sources can also be globally disabled by clearing the EA bit (IE.7).

The interrupt structure is shown in Fig.12.

### 12.2 Interrupt enable priority

Each interrupt source can be assigned one of two priority levels. The interrupt priorities are defined by the Interrupt Priority Register (IP). A low priority interrupt can be interrupted by a high priority interrupt, but not by another low priority interrupt. A high priority interrupt can not be interrupted by any other interrupt source. If two requests of different priority levels are received simultaneously, the request with the highest priority level is serviced. If requests of the same priority level are received simultaneously, an internal polling sequence determines which request is serviced. Thus, within each priority level there is a second priority structure determined by the polling sequence as defined in Table 10.

| Table 10 | Interrupt | Priority | (within | same level) |  |
|----------|-----------|----------|---------|-------------|--|
|----------|-----------|----------|---------|-------------|--|

| SOURCE | PRIORITY<br>WITHIN LEVEL | INTERRUPT<br>VECTOR |
|--------|--------------------------|---------------------|
| EX0    | highest                  | 0003H               |
| ET0    | —                        | 000BH               |
| EX1    | —                        | 0013H               |
| ET1    | —                        | 001BH               |
| ECC    | _                        | 0023H               |
| ES2    | _                        | 002BH               |
| EBUSY  | lowest                   | 0033H               |

#### 12.3 Interrupt vector address

The processor acknowledges an interrupt request by executing a hardware generated LCALL to the appropriate servicing routine. The interrupt vector addresses for each source are shown in Table 10.

#### 12.4 Level/edge interrupt

The external interrupt can be programmed to be either level-activated or transition-activated by setting or clearing the IT0/IT1 bits in the Timer Control SFR (TCON).

| ITx | LEVEL      | EDGE                              |
|-----|------------|-----------------------------------|
| 0   | active LOW |                                   |
| 1   | -          | INTO = negative edge              |
|     |            | INTI = positive and negative edge |

The external interrupt INT1 differs from the standard 80C51 interrupt in that it is activated on both edges when in edge sensitive mode. This is to allow software pulse width measurement for handling remote control inputs.



### SAA55xx

### 13 TIMER/COUNTER

Two 16-bit timers/counters are incorporated Timer 0 and Timer 1. Both can be configured to operate as either timers or event counters.

In Timer mode, the register is incremented on every machine cycle. It is therefore counting machine cycles. Since the machine cycle consists of 12 oscillator periods, the count rate is  $\frac{1}{12}f_{osc} = 1$  MHz.

In Counter mode, the register is incremented in response to a negative transition at its corresponding external pin T0 or T1. Since the pins T0 and T1 are sampled once per machine cycle it takes two machine cycles to recognise a transition, this gives a maximum count rate of  $\frac{1}{24}f_{osc} = 0.5$  MHz.

There are six Special Function Registers used to control the timers/counters. These are: TCON, TMOD, TL0, TH0, TL1 and TH1.

The Timer/Counter function is selected by control bits C/T in the Timer Mode SFR(TMOD). These two Timer/Counters have four operating modes, which are selected by bit-pairs (M1 and M0) in TMOD. Detail of the modes of operation is given in *"Handbook IC20, 80C51-Based 8-bit* Microcontrollers".

TL0 and TH0 are the actual Timer/Counter registers for Timer 0. TL0 is the low byte and TH0 is the high byte. TL1 and TH1 are the actual Timer/Counter registers for Timer 1. TL1 is the low byte and TH1 is the high byte.

### 14 WATCHDOG TIMER

The Watchdog Timer is a counter that once in an overflow state forces the microcontroller into a reset condition. The purpose of the Watchdog Timer is to reset the microcontroller if it enters an erroneous processor state (possibly caused by electrical noise or RFI) within a reasonable period of time. When enabled, the Watchdog circuitry will generate a system reset if the user program fails to reload the Watchdog Timer within a specified length of time known as the Watchdog Interval (WI).

The Watchdog Timer consists of an 8-bit counter with an 11-bit prescaler. The prescaler is fed with a signal whose frequency is  $1_{12}f_{osc}$  (1 MHz for 12 MHz oscillator).

The 8-bit timer is incremented every 't' seconds where:

t = 
$$12 \times 2048 \times \frac{1}{f_{osc}} = 12 \times 2048 \times \frac{1}{12 \times 10^6} = 2.048 \text{ ms}$$

### 14.1 Watchdog Timer operation

The Watchdog operation is activated when the WLE bit in the Power Control SFR (PCON) is set. The Watchdog can be disabled by software by loading the value 55H into the Watchdog Timer Key SFR (WDTKEY). This must be performed before entering Idle/Power-down mode to prevent exiting the mode prematurely.

Once activated the Watchdog Timer SFR (WDT) must be reloaded before the timer overflows. The WLE bit must be set to enable loading of the WDT SFR, once loaded the WLE bit is reset by hardware, this is to prevent erroneous software from loading the WDT SFR.

The value loaded into the WDT defines the Watchdog Interval (WI).

 $WI = (256 - WDT) \times t = (256 - WDT) \times 2.048 \text{ ms}$ 

The range of intervals is from WDT = 00H which gives 524 ms to WDT = FFH which gives 2.048 ms.

### 15 PULSE WIDTH MODULATORS

The device has eight 6-bit Pulse Width Modulated (PWM) outputs for analog control of e.g. volume, balance, bass, treble, brightness, contrast, hue and saturation. The PWM outputs generate pulse patterns with a repetition rate of 21.33  $\mu$ s, with the high time equal to the PWM SFR value multiplied by 0.33  $\mu$ s. The analog value is determined by the ratio of the high time to the repetition time, a DC voltage proportional to the PWM setting is obtained by means of an external integration network (low-pass filter).

### 15.1 PWM control

The relevant PWM is enabled by setting the PWM enable bit PWxE in the PWMx Control Register (where x = 0 to 7). The high time is defined by the value PWxV<5:0>.

## 15.2 Tuning Pulse Width Modulator (TPWM)

The device has a single 14-bit PWM that can be used for Voltage Synthesis Tuning. The method of operation is similar to the normal PWM except that the repetition period is  $42.66 \ \mu s$ .

## 15.2.1 TPWM CONTROL

Two SFRs are used to control the TPWM, they are TDACL and TDACH. The TPWM is enabled by setting the TPWE bit in the TDACH SFR. The most significant bits TD<13:7> alter the high period between 0 and 42.33  $\mu$ s. The 7 least significant bits TD<6:0> extend certain pulses by a further 0.33  $\mu$ s. e.g. if TD<6:0> = 01H then 1 in 128 periods will be extended by 0.33  $\mu$ s, if TD<6:0> = 02H then 2 in 128 periods will be extended.

The TPWM will not start to output a new value until TDACH has been written to. Therefore, if the value is to be changed, TDACL should be written before TDACH.

## 15.3 Software ADC (SAD)

Four successive approximation Analog-to-Digital Converters can be implemented in software by making use of the on-board 8-bit Digital-to-Analog Converter and Analog Comparator.

## 15.3.1 SAD CONTROL

The control of the required analog input is done using the channel select bits CH<1:0> in the SAD SFR, this selects the required analog input to be passed to one of the inputs of the comparator. The second comparator input is generated by the DAC whose value is set by the bits SAD<7:0> in the SAD and SADB SFRs. A comparison between the two inputs is made when the start compare bit ST in the SAD SFR is set, this must be at least one instruction cycle after the SAD<7:0> value has been set. The result of the comparison is given on VHI one instruction cycle after the setting of ST.

## 15.3.2 SAD INPUT VOLTAGE

The external analog voltage that is used for comparison with the internally generated DAC voltage does not have the same voltage range. The DAC has a lower reference level of  $V_{SSA}$  and an upper reference level of  $V_{SSP}$ .

## SAA55xx

The resolution of the DAC voltage with a nominal value is  $^{3.3}/_{256} \approx 13$  mV. The external analog voltage has a lower value equivalent to V<sub>SSA</sub> and an upper value equivalent to  $V_{DDP} - V_{tn}$ , where  $V_{tn}$  is the threshold voltage for an NMOS transistor. The reason for this is that the input pins for the analog signals (P3.0 to P3.3) are 5 V tolerant for normal port operations, i.e. when not used as analog input. To protect the analog multiplexer and comparator circuitry from the 5 V, a series transistor is used to limit the voltage. This limiting introduces a voltage drop equivalent to V<sub>tn</sub> ( $\approx 0.6$  V) on the input voltage. The maximum value of V<sub>in</sub> is 0.75 V, therefore for worst case calculations, the maximum input to the SAD should be calculated as  $V_{DD(min)} = -0.75$  V. Therefore, for an input voltage in the range  $V_{DDP}$  to  $V_{DDP} - V_{tn}$  the SAD returns the same comparison value.

#### 15.3.3 SAD DC COMPARATOR MODE

The SAD module incorporates a DC Comparator mode which is selected using the DC\_COMP control bit in the SADB SFR. This mode enables the microcontroller to detect a threshold crossing at the input to the selected analog input pin (P3.0/ADC0, P3.1/ADC1, P3.2/ADC2 or P3.3/ADC3) of the software ADC. A level sensitive interrupt is generated when the analog input voltage level at the pin falls below the analog output level of the SAD DAC.

This mode is intended to provide the device with a wake-up mechanism from Power-down or Idle mode when a key-press on the front panel of the TV is detected.

The following software sequence should be used when utilizing this mode for Power-down or Idle mode:

- 1. Disable INT1 using the IE SFR.
- 2. Set INT1 to level sensitive using the TCON SFR.
- Set the DAC digital input level to the desired threshold level using SAD/SADB SFRs and select the required input pin (P3.0/ADC0, P3.1/ADC1, P3.2/ADC2 or P3.3/ADC3) using CH<1:0> in the SAD SFR.
- 4. Enter DC Compare mode by setting the DC\_COMP enable bit in the SADB SFR.
- 5. Enable INT1 using the IE SFR.
- 6. Enter Power-down/Idle mode. Upon wake-up the SAD should be restored to its conventional operating mode by disabling the DC\_COMP control bit.



SAA55xx

## Enhanced TV microcontrollers with On-Screen Display (OSD)

## 16 I<sup>2</sup>C-BUS SERIAL I/O

The  $I^2C$ -bus consists of a serial data line (SDA) and a serial clock line (SCL). The definition of the  $I^2C$ -bus protocol can be found in Reference 2.

The device operates in four modes

- Master transmitter
- Master receiver
- Slave transmitter
- Slave receiver.

The microcontroller peripheral is controlled by the Serial Control SFR (S1CON) and its status is indicated by the Status SFR (S1STA). Information is transmitted/received to/from the I<sup>2</sup>C-bus using the Data SFR (S1DAT) and the Slave Address SFR (S1ADR) is used to configure the slave address of the peripheral.

The byte level I<sup>2</sup>C-bus serial port is identical to the I<sup>2</sup>C-bus serial port on the P8xC558, except for the clock rate selection bits CR<2:0>. The operation of the subsystem is described in detail in the *"P8xC558 data sheet"*.

## 16.1 I<sup>2</sup>C-bus port selection

Two I<sup>2</sup>C-bus ports are available SCL0/SDA0 and SCL1/SDA1. The selection of the port is done using TXT21.I<sup>2</sup>C PORT 0 and TXT21.I<sup>2</sup>C PORT 1. When the port is enabled, any information transmitted from the device goes onto the enabled port. Any information transmitted to the device can only be acted on if the port is enabled.

If both ports are enabled then data transmitted from the device is seen on both ports, however data transmitted to the device on one port can not be seen on the other port.

## **17 MEMORY INTERFACE**

The memory interface controls access to the embedded DRAM, refreshing of the DRAM and page clearing. The DRAM is shared between Data Capture, display and microcontroller sections.

The Data Capture section uses the DRAM to store acquired information that has been requested. The display reads from the DRAM information and converts it into RGB values. The microcontroller uses the DRAM as embedded auxiliary RAM.

## 17.1 Memory structure

The memory is partitioned into two distinct areas, the dedicated Auxiliary RAM area, and the Display RAM area. The Display RAM area when not being used for Data Capture or display can be used as an extension to the Auxiliary RAM area.

## 17.1.1 AUXILIARY RAM

The Auxiliary RAM is not initialized at power-up. The application software must initialize this Auxiliary RAM. The contents of the Auxiliary RAM are maintained during Idle mode, but are lost if Power-down mode is entered.

## 17.1.2 DISPLAY RAM

The Display RAM is initialised on power-up to a value of 20H throughout. The contents of the Display RAM are maintained when entering Idle mode. If Idle mode is exited using an interrupt then the contents are unchanged, if Idle mode is exited using a RESET then the contents are initialised to 20H.

Full Closed Caption display requires display RAM from 8000H to 845FH. The memory from 846H to 84FFH (must be initialized by the application software) can be utilized as an extension to the dedicated contiguous Auxiliary RAM that occupies 0000H to 07FFH.

## 17.2 Memory mapping

The dedicated Auxiliary RAM area occupies 2 kbytes, with an address range from 0000H to 07FFH. The Display RAM occupies a maximum of 10 kbytes with an address range from 2000H to 47FFH for TXT mode and 8000H to 84FFH for CC mode (see Fig.14). The two modes although having different address ranges occupy physically the same DRAM area.

## 17.3 Addressing memory

The memory can be addressed by the microcontroller in two ways, either directly using a MOVX command, or via Special Function Registers depending on what address is required.

The dedicated Auxiliary RAM, and Display memory in the range 8000H to 84FFH, can only be accessed using the MOVX command.

The Display memory in the range 2000H to 47FFH can either be directly accessed using the MOVX, or via the Special Function Registers.

## Preliminary specification

SAA55xx

## Enhanced TV microcontrollers with On-Screen Display (OSD)

## 17.3.1 TXT DISPLAY MEMORY SFR ACCESS

The Display memory when in TXT mode (see Fig.15) is configured as 40 columns wide by 25 rows and occupies  $1K \times 8$ -bit of memory. Using TXT15.BLOCK<3:0>, the required display page can be selected to be written to. The row and column within that block is selected using TXT9.R<4:0> and TXT10.C<5:0>. The data at the selected position can be read or written using TXT11.D<7:0>.

Whenever a read or write is performed on TXT11, the row values stored in TXT9 and column value stored in TXT10 are automatically incremented. For rows 0 to 24 the column value is incremented up to a maximum of 39, at which point it resets to zero and increments the row counter value. When row 25 column 23 is reached the values of the row and column are both reset to zero.

Writing values outside of the valid range for TXT9 or TXT10 will cause undetermined operation of the auto-incrementing function for accesses to TXT11.

17.3.2 TXT DISPLAY MEMORY MOVX ACCESS

It is important for the generation of OSD displays, that use this mode of access, to understand the mapping of the MOVX address onto the display row and column value. This mapping of row and column onto address is shown in Table 12. The values shown are added onto a base address for the required memory block (see Fig.14) to give a 16-bit address.

## Table 12 Column and row to 'MOVX' address (lower 10 bits of address)

| ROW    | COL.0 |   | COL.23 |   | COL.31 | COL.32 |   | COL.39 |
|--------|-------|---|--------|---|--------|--------|---|--------|
| Row 0  | 000H  |   | 017H   |   | 01FH   | 3F8H   |   | 3FFH   |
| Row 1  | 020H  |   | 037H   |   | 03FH   | 3F0H   |   | 3F7H   |
| :      | :     | : | :      | : | :      | :      | : | :      |
| :      | :     | : | :      | : | :      | :      | : | :      |
| Row 23 | 2E0H  |   | 3F7H   |   | 2FFH   | 340H   |   | 347H   |
| Row 24 | 300H  |   | 317H   |   | 31FH   | 338H   |   | 33FH   |
| Row 25 | 320H  |   | 337H   |   |        |        |   |        |

## SAA55xx



Fig.14 DRAM memory mapping.



SAA55xx

## Enhanced TV microcontrollers with On-Screen Display (OSD)

## 17.4 Page clearing

Page clearing is performed on request from either the Data Capture block, or the microcontroller under the control of the embedded software.

At power-on and reset the whole of the page memory is cleared. The TXT13.PAGE CLEARING bit will be set while this takes place.

## 17.4.1 DATA CAPTURE PAGE CLEAR

When a page header is acquired for the first time after a new page request or a page header is acquired with the erase (C4) bit set the page memory is 'cleared' to spaces before the rest of the page arrives.

When this occurs, the space code (20H) is written into every location of rows 1 to 23 of the basic page memory, the appropriate packet 27 row of the extension packet memory and the row where teletext packet 24 is written. This last row is either row 24 of the basic page memory, if the TXT0.X24 POSN bit is set, or row 0 of the extension packet memory, if the bit is not set. Page clearing takes place before the end of the TV line in which the header arrived which initiated the page clear.

This means that the 1 field gap between the page header and the rest of the page which is necessary for many teletext decoders is not required.

## 17.4.2 SOFTWARE PAGE CLEAR

The software can also initiate a page clear, by setting the TXT9.CLEAR MEMORY bit. When it does so, every location in the memory block pointed to by TXT15.BLOCK<3:0> is cleared to a space code (20H). The CLEAR MEMORY bit is not latched so the software does not have to reset it after it has been set.

Only one page can be cleared in a TV line so if the software requests a page clear it will be carried out on the next TV line on which the Data Capture hardware does not force the page to be cleared. A flag, TXT13.PAGE CLEARING, is provided to indicate that a software requested page clear is being carried out. The flag is set when a logic 1 is written into the TXT9.CLEAR MEMORY bit and is reset when the page clear has been completed.

If TXT0.INV ON bit = 1 and a page clear is initiated on Block 8 all locations are cleared to 00H.

## 18 DATA CAPTURE

The Data Capture section takes in the analog Composite Video and Blanking Signal (CVBS), and from this extracts the required data, which is then decoded and stored in memory.

The extraction of the data is performed in the digital domain. The first stage is to convert the analog CVBS signal into a digital form. This is done using an ADC sampling at 12 MHz. The data and clock recovery is then performed by a Multi-rate Video Input Processor (MulVIP). From the recovered data and clock the following data types are extracted WST Teletext (625/525), Closed Caption, VPS and WSS. The extracted data is stored in either memory (DRAM) via the Memory interface or in SFR locations.

#### 18.1 Data Capture features

- Two CVBS inputs
- Video Signal Quality detector
- Data Capture for 625-line WST
- Data Capture for 525-line WST
- Data Capture for US Closed Caption
- Data Capture for VPS data (PDC system A)
- Data Capture for Wide Screen Signalling (WSS) bit decoding
- Automatic selection between 525 WST/625 WST
- Automatic selection between 625 WST/VPS on line 16 of Vertical Blanking Interval
- Real-time capture and decoding for WST Teletext in hardware, to enable optimized microprocessor throughput
- · Up to 10 pages stored on-chip
- Inventory of transmitted Teletext pages stored in the Transmitted Page Table (TPT) and Subtitle Page Table (SPT)
- Automatic detection of FASTEXT transmission
- Real-time packet 26 engine in hardware for processing accented, G2 and G3 characters
- Signal quality detector for WST/VPS data types
- Comprehensive Teletext language coverage
- Full Field and Vertical Blanking Interval (VBI) data capture of WST data.

## Preliminary specification

SAA55xx

# Enhanced TV microcontrollers with On-Screen Display (OSD)



## 18.1.1 CVBS SWITCH

The CVBS switch is used to select the required analog input depending on the value of TXT8.CVBS1/CVBS0.

#### 18.1.2 ANALOG-TO-DIGITAL CONVERTER

The output of the CVBS switch is passed to a Differential-to-Single-Ended Converter (DIVIS), although in this device it is used in single-ended configuration with a reference. The analog output of the DIVIS is converted into a digital representation by a full-flash ADC with a sampling rate of 12 MHz.

#### 18.1.3 MULTI-RATE VIDEO INPUT PROCESSOR

The multi-rate video input processor is a Digital Signal Processor designed to extract the data and recover the clock from a digitized CVBS signal.

#### 18.1.4 DATA STANDARDS

The data and clock standards that can be recovered are shown in Table 13.

| DATA STANDARD  | CLOCK RATE |
|----------------|------------|
| 625 WST        | 6.9375 MHz |
| 525 WST        | 5.7272 MHz |
| VPS            | 5.0 MHz    |
| WSS            | 5.0 MHz    |
| Closed Caption | 500 kHz    |

#### Table 13 Data Slicing standards

#### 18.1.5 DATA CAPTURE TIMING

The Data Capture timing section uses the synchronisation information extracted from the CVBS signal to generate the required horizontal and vertical reference timings.

The timing section automatically recognizes and selects the appropriate timings for either 625 (50 Hz) synchronisation or 525 (60 Hz) synchronisation.

A flag TXT12.VIDEO SIGNAL QUALITY is set when the timing section is locked correctly to the incoming CVBS signal. When TXT12.VIDEO SIGNAL QUALITY is set another flag TXT12.525/625 SYNC can be used to identify the standard.

#### 18.1.6 ACQUISITION

The acquisition sections extracts the relevant information from the serial stream of data from the MuIVIP and stores it in memory.

## SAA55xx

#### 18.1.6.1 Making a page request

A page is requested by writing a series of bytes into the TXT3.PRD<4:0> SFR which corresponds to the number of the page required. The bytes written into TXT3 are stored in a RAM with an auto-incrementing address. The start address for the RAM is set using the TXT2.SC<2:0> to define which part of the page request is being written, and TXT2.REQ<3:0> is used to define which of the 10 page requests is being modified. If TXT2.REQ<3:0> is greater than 09H, then data being written to TXT3 is ignored. Table 14 shows the contents of the page request RAM.

Up to 10 pages of teletext can be acquired on the 10 page device, when TXT1.EXT PKT OFF is set to logic 1, and up to 9 pages can be acquired when this bit is set to logic 0. For a 20 page device the 10 page acquisition channels are banked, the bank being selected using TXT2.ACQ BANK.

If the 'Do Care' bit for part of the page number is set logic 0 then that part of the page number is ignored when the teletext decoder is deciding whether a page being received off air should be stored or not. For example, if the Do Care bits for the four subcode digits are all set to logic 0 then every subcode version of the page will be captured.

| START<br>COLUMN | PRD4                        | PRD3 | PRD2 | PRD1 | PRD0 |
|-----------------|-----------------------------|------|------|------|------|
| 0               | DO CARE<br>Magazine         | HOLD | MAG2 | MAG1 | MAG0 |
| 1               | DO CARE<br>Page Tens        | PT3  | PT2  | PT1  | PT0  |
| 2               | DO CARE<br>Page<br>Units    | PU3  | PU2  | PU1  | PU0  |
| 3               | DO CARE<br>Hour Tens        | Х    | Х    | HT1  | HT0  |
| 4               | DO CARE<br>Hours<br>Units   | HU3  | HU2  | HU1  | HU0  |
| 5               | DO CARE<br>Minutes<br>Tens  | Х    | MT2  | MT1  | MT0  |
| 6               | DO CARE<br>Minutes<br>Units | MU3  | MU2  | MU1  | MU0  |
| 7               | Х                           | Х    | Х    | E1   | E0   |

#### Table 14 The contents of the Page request RAM

When the HOLD bit is set to a logic 0 the teletext decoder will not recognise any page as having the correct page number and no pages will be captured. In addition to providing the user requested hold function this bit should be used to prevent the inadvertent capture of an unwanted page when a new page request is being made. For example, if the previous page request was for page 100 and this was being changed to page 234, it would be possible to capture page 200 if this arrived after only the requested magazine number had been changed.

The E1 and E0 bits control the error checking which should be carried out on packets 1 to 23 when the page being requested is captured. This is described in more detail in Section 18.1.6.3.

For a multi-page device, each packet can only be written into one place in the teletext RAM so if a page matches more than one of the page requests the data is written into the area of memory corresponding to the lowest numbered matching page request.

At power-up each page request defaults to any page, hold on and error check Mode 0.

#### 18.1.6.2 Rolling headers and time

When a new page has been requested it is conventional for the decoder to turn the header row of the display green and to display each page header as it arrives until the correct page has been found.

When a page request is changed (i.e. when the TXT3 SFR is written to) a flag (PBLF) is written into bit 5, column 9, row 25 of the corresponding block of the page memory. The state of the flag for each block is updated every TV line, if it is set for the current display block, the acquisition section writes all valid page headers which arrive into the display block and automatically writes an alphanumeric green character into column 7 of row 0 of the display block every TV line.

When a requested page header is acquired for the first time, rows 1 to 23 of the relevant memory block are cleared to space, i.e. have 20H written into every column, before the rest of the page arrives. Row 24 is also cleared if the TXT0.X24 POSN bit is set. If the

TXT1.EXT PKT OFF bit is set the extension packets corresponding to the page are also cleared.

The last 8 characters of the page header are used to provide a time display and are always extracted from every valid page header as it arrives and written into the display block.

The TXT0.DISABLE HEADER ROLL bit prevents any data being written into row 0 of the page memory except when a page is acquired off air i.e. rolling headers and time are not written into the memory. The TXT1.ACQ OFF bit prevents any data being written into the memory by the teletext acquisition section.

When a parallel magazine mode transmission is being received only headers in the magazine of the page requested are considered valid for the purposes of rolling headers and time. Only one magazine is used even if don't care magazine is requested. When a serial magazine mode transmission is being received all page headers are considered to be valid.

## 18.1.6.3 Error checking

Before teletext packets are written into the page memory they are error checked. The error checking carried out depends on the packet number, the byte number, the error check mode bits in the page request data and the TXT1.8-BIT bit.

If an uncorrectable error occurs in one of the Hamming checked addressing and control bytes in the page header or in the Hamming checked bytes in packet 8/30, bit 4 of the byte written into the memory is set, to act as an error flag to the software. If uncorrectable errors are detected in any other Hamming checked data the byte is not written into the memory.

## SAA55xx

| Packet X/0                                                                                                                                                                                                                                                 |     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| '8-bit' bit = 0                                                                                                                                                                                                                                            |     |
| 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38                                                                                                                                                 | 39  |
| '8-bit' bit = 1                                                                                                                                                                                                                                            |     |
| 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38                                                                                                                                                 | 39  |
| Packet X/1-23                                                                                                                                                                                                                                              |     |
| '8-bit' bit = 0, error check mode = 0                                                                                                                                                                                                                      |     |
| 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38                                                                                                                                                 | 39  |
| '8-bit' bit = 0, error check mode = 1                                                                                                                                                                                                                      |     |
| 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38                                                                                                                                                 | 39  |
| '8-bit' bit = 0, error check mode = 2                                                                                                                                                                                                                      |     |
| 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38                                                                                                                                                 | 39  |
| '8-bit' bit = 0, error check mode = 3                                                                                                                                                                                                                      |     |
| 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38                                                                                                                                                 | 39  |
| '8-bit' bit = 1                                                                                                                                                                                                                                            |     |
| 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38                                                                                                                                                 | 39  |
| Packet X/24                                                                                                                                                                                                                                                |     |
| '8-bit' bit = 0                                                                                                                                                                                                                                            | _   |
| 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 9 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38                                                                                                                                                  | 39  |
| '8-bit' bit = 1                                                                                                                                                                                                                                            |     |
| 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 9 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38                                                                                                                                                  | 39  |
| Packet X/27/0                                                                                                                                                                                                                                              |     |
| 0 1 2 3 4 5 6 7 8 9 10111 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38                                                                                                                                                 | 39  |
|                                                                                                                                                                                                                                                            |     |
| Packet 8/30/0,1                                                                                                                                                                                                                                            |     |
| 0       1       2       3       14       15       16       17       18       19       20       21       22       23       24       25       26       27       28       29       30       31       32       33       34       35       36       37       38 | 39  |
| Packet 8/30/2,3,4-15                                                                                                                                                                                                                                       |     |
| 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38                                                                                                                                                 | 39  |
| МСК                                                                                                                                                                                                                                                        | 465 |
| 8-bit odd parity becked 8/4 Hamming checked                                                                                                                                                                                                                |     |
|                                                                                                                                                                                                                                                            |     |
|                                                                                                                                                                                                                                                            |     |
|                                                                                                                                                                                                                                                            |     |
| Fig.17 Error checking.                                                                                                                                                                                                                                     |     |

|                                 | age Blocks (0 to 8/9 |                            |        |
|---------------------------------|----------------------|----------------------------|--------|
|                                 | 0 6 7 8              |                            | 39     |
| Row 0                           | OSD only             | Packet X/0                 |        |
| 1                               |                      | Packet X/1                 |        |
| 2                               |                      | Packet X/2                 |        |
| 3                               |                      | Packet X/3                 |        |
| 4                               |                      | Packet X/4                 |        |
| 5                               |                      | Packet X/5                 |        |
| 6                               |                      | Packet X/6                 |        |
| 7                               |                      | Packet X/7                 |        |
| 8                               |                      | Packet X/8<br>Packet X/9   |        |
| 9<br>10                         |                      | Packet X/10                |        |
| 10                              |                      | Packet X/11                |        |
| 12                              |                      | Packet X/12                |        |
| 13                              |                      | Packet X/13                |        |
| 14                              |                      | Packet X/14                |        |
| 15                              |                      | Packet X/15                |        |
| 16                              |                      | Packet X/16                |        |
| 17                              |                      | Packet X/17                |        |
| 18                              |                      | Packet X/18                |        |
| 19                              |                      | Packet X/19                |        |
| 20                              |                      | Packet X/20                |        |
| 21                              |                      | Packet X/21                |        |
| 22                              |                      | Packet X/22                |        |
| 23                              |                      | Packet X/23                |        |
| 24                              |                      | Packet X/24 <sup>(1)</sup> |        |
| 25                              | Control Data         | VPS Data <sup>(2)</sup>    | GSA003 |
|                                 | 0                    | 9 10 <sup>(3)</sup> 23     |        |
|                                 |                      |                            |        |
|                                 |                      |                            |        |
| If 'X24 POSN' bit = 1.          |                      |                            |        |
| VPS data block 9, unused in blo | cks 0 to 8.          |                            |        |
| Byte 10 reserved.               |                      |                            |        |

## 18.1.6.4 Teletext memory organisation

The teletext memory is divided into 2 banks of 10 blocks. Normally, when the TXT1.EXT PKT OFF bit is logic 0, each of blocks 0 to 8 contains a teletext page arranged in the same way as the basic page memory of the page device and block 9 contains extension packets. When the TXT1.EXT PKT OFF bit is logic 1, no extension packets are captured and block 9 of the memory is used to store another page. The number of the memory block into which a page is written corresponds to the page request number which resulted in the capture of the page.

# Packet 0, the page header, is split into two parts when it is written into the text memory. The first 8 bytes of the header contain control and addressing information. They are Hamming decoded and written into columns 0 to 7 of row 25. Row 25 also contains the magazine number of the acquired page and the PLBF flag but the last 14 bytes are unused and may be used by the software, if necessary.



## 18.1.6.5 Row 25 data contents

The Hamming error flags are set if the on-board 8/4 Hamming checker detects that there has been an uncorrectable (2-bit) error in the associated byte. It is possible for the page to still be acquired if some of the page address information contains uncorrectable errors if that part of the page request was a 'Don't Care'. There is no error flag for the magazine number as an uncorrectable error in this information prevents the page being acquired.

The interrupt sequence (C9) bit is automatically dealt with by the acquisition section so that rolling headers do not contain a discontinuity in the page number sequence.

The magazine serial (C11) bit indicates whether the transmission is a serial or a parallel magazine transmission. This affects the way the acquisition section operates and is dealt with automatically.

The newsflash (C5), subtitle (C6), suppress header (C7), inhibit display (C10) and language control (C12 to 14) bits are dealt with automatically by the display section.

The update (C8) bit has no effect on the hardware. The remaining 32 bytes of the page header are parity checked and written into columns 8 to 39 of row 0. Bytes which pass the parity check have the MSB set to a logic 0 and are written into page memory. Bytes with parity errors are not written into the memory.

| 001      |       |       |       |               |       |       |       |       |
|----------|-------|-------|-------|---------------|-------|-------|-------|-------|
| COL      | BIT 7 | BIT 6 | BIT 5 | BIT 4         | BIT 3 | BIT 2 | BIT 1 | BIT 0 |
| 0        | 0     | 0     | 0     | Hamming error | PU3   | PU2   | PU1   | PU0   |
| 1        | 0     | 0     | 0     | Hamming error | PT3   | PT2   | PT1   | PT0   |
| 2        | 0     | 0     | 0     | Hamming error | MU3   | MU2   | MU1   | MU0   |
| 3        | 0     | 0     | 0     | Hamming error | C4    | MT2   | MT1   | MT0   |
| 4        | 0     | 0     | 0     | Hamming error | HU3   | HU2   | HU1   | HU0   |
| 5        | 0     | 0     | 0     | Hamming error | C6    | C5    | HT1   | HT0   |
| 6        | 0     | 0     | 0     | Hamming error | C10   | C9    | C8    | C7    |
| 7        | 0     | 0     | 0     | Hamming error | C14   | C13   | C12   | C11   |
| 8        | 0     | 0     | 0     | FOUND         | 0     | MAG2  | MAG1  | MAG0  |
| 9        | 0     | 0     | PBLF  | 0             | 0     | 0     | 0     | 0     |
| 10 to 23 | _     | _     | —     | unused        | _     | -     | -     | _     |

Table 15 The data in row 25 of the basic page memory

#### 18.1.6.6 Inventory page

If the TXT0.INV ON bit is a logic 1, memory block 8 is used as an inventory page.The inventory page consists of two tables: the Transmitted Page Table (TPT) and the Subtitle Page Table (SPT).

In each table, every possible combination of the page tens and units digit, 00H to FFH, is represented by a byte.

Each bit of these bytes corresponds to a magazine number so each page number, from 100H to 8FFH, is represented by a bit in the table. The bit for a particular page in the TPT is set when a page header is received for that page. The bit in the SPT is set when a page header for the page is received which has the 'subtitle' page header control bit (C6) set. The bit for a particular page in the TPT is set when a page header is received for that page. The bit in the SPT is set when a page header for the page is received which has the 'subtitle' page header control bit (C6) set.



SAA55xx

# Enhanced TV microcontrollers with On-Screen Display (OSD)



## 18.1.6.7 Packet 26 processing

One of the uses of packet 26 is to transmit characters which are not in the basic teletext character set. The family automatically decodes packet 26 data and, if a character corresponding to that being transmitted is available in the character set, automatically writes the appropriate character code into the correct location in the teletext memory. This is not a full implementation of the packet 26 specification allowed for in level 2 teletext, and so is often referred to as level 1.5.

By convention, the packets 26 for a page are transmitted before the normal packets. To prevent the default character data overwriting the packet 26 data the device incorporates a mechanism which prevents packet 26 data from being overwritten. The mechanism is disabled when the Spanish national option is detected as the Spanish transmission system sends even parity (i.e. incorrect) characters in the basic page locations corresponding to the characters sent via packet 26 and these will not overwrite the packet 26 characters anyway. The special treatment of Spanish national option is prevented if TXT12.ROM VER R4 is logic 0 or if the TXT8.DISABLE SPANISH is set.

Packet 26 data is processed regardless of the TXT1.EXT PKT OFF bit, but setting theTXT1.X26 OFF disables packet 26 processing.

The TXT8.PKT26 RECEIVED bit is set by the hardware whenever a character is written into the page memory by the packet 26 decoding hardware. The flag can be reset by writing a logic 0 into the SFR bit.

## 18.1.6.8 525-line World System Teletext

The 525-line format is similar to the 625-line format but the data rate is lower and there are less data bytes per packet (32 rather than 40). There are still 40 characters per display row so extra packets are sent each of which contains the last 8 characters for four rows. These packets can be identified by looking at the 'tabulation bit' (T), which replaces one of the magazine bits in 525-line teletext. When an ordinary packet with T = 1 is received, the decoder puts the data into the four rows starting with that corresponding to the packet number, but with the 2 LSBs set to logic 0. For example, a packet 9 with T = 1 (packet X/1/9) contains data for rows 8, 9, 10 and 11.

The error checking carried out on data from packets with T = 1 depends on the setting of the TXT1. 8-BIT bit and the error checking control bits in the page request data and is the same as that applied to the data written into the same memory location in the 625-line format.

The rolling time display (the last 8 characters in row 0) is taken from any packets X/1/1, 2 or 3 received. In parallel magazine mode only packets in the correct magazine are used for rolling time. Packet number X/1/0 is ignored.

The tabulation bit is also used with extension packets.

The first 8 data bytes of packet X/1/24 are used to extend the Fastext prompt row to 40 characters. These characters are written into whichever part of the memory the packet 24 is being written into (determined by the 'X24 POSN' bit).

Packets X/0/27/0 contain 5 Fastext page links and the link control byte and are captured, Hamming checked and stored in the same way as are packets X/27/0 in 625-line text. Packets X/1/27/0 are not captured.

Because there are only 2 magazine bits in 525-line text, packets with the magazine bits all set to a logic 0 are referred to as being in magazine 4. Therefore, the broadcast service data packet is packet 4/30, rather than packet 8/30. As in 625-line text, the first 20 bytes of packet 4/30 contain encoded data which is decoded in the same way as that in packet 8/30. The last 12 bytes of the packet contains half of the parity encoded status message. Packet 4/0/30 contains the first half of the message and packet 4/1/30 contains the second half. The last 4 bytes of the message are not written into memory. The first 20 bytes of the yare stored whenever either version of the packet is acquired.

In 525-line text each packet 26 only contains ten 24/18 Hamming encoded data triplets, rather than the 13 found in 625-line text. The tabulation bit is used as an extra bit (the MSB) of the designation code, allowing 32 packet 26s to be transmitted for each page. The last byte of each packet 26 is ignored.

| 0<br>Row 0 | 6 7 8<br>OSD only aw/ag | Packet X/0/0                 | 39<br>Rolling time            |
|------------|-------------------------|------------------------------|-------------------------------|
| 1          | JSD only [aw/ag]        | Packet X/0/0                 | Packet X/1/1                  |
| 2          |                         | Packet X/0/1                 | Facket // 1/1                 |
| 3          |                         | Packet X/0/2<br>Packet X/0/3 |                               |
| 4          |                         | Packet X/0/3                 | Packet X/1/4                  |
| 5          |                         | Packet X/0/5                 |                               |
| 6          |                         | Packet X/0/6                 |                               |
| 7          |                         | Packet X/0/7                 |                               |
| 8          |                         | Packet X/0/8                 | Packet X/1/8                  |
| 9          |                         | Packet X/0/9                 |                               |
| 10         |                         | Packet X/0/10                |                               |
| 11         |                         | Packet X/0/11                |                               |
| 12         |                         | Packet X/0/12                | Packet X/1/12                 |
| 13         |                         | Packet X/0/13                |                               |
| 14         |                         | Packet X/0/14                |                               |
| 15         |                         | Packet X/0/15                |                               |
| 16         |                         | Packet X/0/16                | Packet X/1/16                 |
| 17         |                         | Packet X/0/17                |                               |
| 18         |                         | Packet X/0/18                |                               |
| 19         |                         | Packet X/0/19                |                               |
| 20         |                         | Packet X/0/20                | Packet X/1/20                 |
| 21         |                         | Packet X/0/21                |                               |
| 22         |                         | Packet X/0/22                |                               |
| 23         |                         | Packet X/0/23                |                               |
| 24         |                         | Packet X/0/24 <sup>(1)</sup> | Packet X/1 /24 <sup>(1)</sup> |
| 25         | Control Data            | 9 10 <sup>(2)</sup> 23       | GSA004                        |
| 0          | (                       | a 10(2) 23                   |                               |

## 18.1.6.9 Fastext detection

When a packet 27, designation code 0 is detected, whether or not it is acquired, the TXT13.FASTEXT bit is set. If the device is receiving 525-line teletext, a packet X/0/27/0 is required to set the flag. The flag can be reset by writing a logic 0 into the SFR bit.

When a packet 8/30 is detected, or a packet 4/30 when the device is receiving a 525-line transmission, the TXT13.PKT 8/30 is set. The flag can be reset by writing a logic 0 into the SFR bit.

## 18.1.6.10 Broadcast Service Data Detection

When a packet 8/30 is detected, or a packet 4/30 when the device is receiving a 525-line transmission, the TXT13. PKT 8/30 flag is set. The flag can be reset by writing a logic 0 into the SFR bit.

## 18.1.6.11 VPS acquisition

When the TXT0.VPS ON bit is set, any VPS data present on line 16, field 0 of the CVBS signal at the input of the teletext decoder is error checked and stored in row 25, block 9 of the basic page memory. The device automatically detects whether teletext or VPS is being transmitted on this line and decodes the data appropriately.

Each VPS byte in the memory consists of 4 biphase decoded data bits (bits 0 to 3), a biphase error flag (bit 4) and three logic 0s (bits 5 to 7).

The most significant bit of the VPS data cannot be set to logic 1.

The TXT13.VPS RECEIVED bit is set by the hardware whenever VPS data is acquired.

Full details of the VPS system can be found in the specification *"Domestic Video Program Delivery Control System (PDC); EBU Tech. 3262-E".* 

## 18.1.7 WST ACQUISITION

The family is capable of acquiring Level 1.5 625-line and 525-line World System Teletext.

## 18.1.8 WSS ACQUISITION

The Wide Screen Signalling data transmitted on line 23 gives information on the aspect ratio and display position of the transmitted picture, the position of subtitles and on the camera/film mode. Some additional bits are reserved for future use. A total of 14 data bits are transmitted.

All of the available data bits transmitted by the Wide Screen Signalling signal are captured and stored in SFRs WSS1, WSS2 and WSS3. The bits are stored as groups of related bits and an error flag is provided for each group to indicate when a transmission error has been detected in one or more of the bits in the group.

Wide screen signalling data is only acquired when the TXT8.WSS ON bit is set.

The TXT8.WSS RECEIVED bit is set by the hardware whenever wide screen signalling data is acquired. The flag can be reset by writing a logic 0 into the SFR bit.



#### 18.1.9 CLOSED CAPTION ACQUISITION

The US Closed Caption data is transmitted on line 21 (525-line timings) and is used for Captioning information, Text information and Extended Data Services. Full details can be found in the document *"Recommended Practise for Line 21 Data Service EIA-608"*.

Closed Caption data is only acquired when TXT21.CC ON bit is set.

Two bytes of data are stored per field in SFRs the first bye is stored in CCDAT1 and the second byte is stored in CCDAT2. The value in the CCDAT registers are reset to 00H at the start of the Closed Caption line defined by CCLIN.CS<4:0>. At the end of the Closed Caption line an interrupt is generated if IE.ECC is active.

The processing of the Closed Caption data to convert into a displayable format is performed by software.

## 19 DISPLAY

The display section is based on the requirements for a Level 1.5 WST Teletext and US Closed Caption. There are some enhancements for use with locally generated On-Screen Displays.

The display section reads the contents of the Display memory and interprets the control/character codes.

From this information and other global settings, the display produces the required RGB signals and Video/Data (Fast Blanking) signal for a TV signal processing device.

The display is synchronized to the TV signal processing device by way of horizontal and vertical sync signals provided by external circuits (Slave Sync mode). From these signals all display timings are derived.

#### 19.1 Display features

- Teletext and Enhanced OSD modes
- Level 1.5 WST features
- US Closed Caption features
- Serial and Parallel display attributes
- Single/double/quadruple width and height for characters
- Scrolling of display region
- · Variable flash rate controlled by software
- Globally selectable scan lines per row 9/10/13/16
- Globally selectable character matrix (H  $\times$  V) 12  $\times$  9, 12  $\times$  10, 12  $\times$  13 or 12  $\times$  16
- Italics
- Soft colours using CLUT with 4096 colour palette
- Underline
- Overline
- Fringing (shadow) selectable from N-S-E-W direction
- Fringe colour selectable
- · Meshing of defined area
- · Contrast reduction of defined area
- Cursor
- Special graphics characters with two planes, allowing four colours per character
- 32 software redefinable On-Screen Display characters
- 4 WST character sets (G0/G2) in single device (e.g. Latin, Cyrillic, Greek and Arabic)
- G1 Mosaic graphics, Limited G3 Line drawing characters
- WST character sets and Closed Caption character set in single device.



#### Preliminary specification

## Enhanced TV microcontrollers with On-Screen Display (OSD)

## SAA55xx

## 19.2 Display modes

The display section has two distinct modes with different features available in each. The two modes are:

- **TXT:** This is the display configured as the WST mode with additional serial and global attributes. The display is configured as a fixed 25 rows with 40 characters per row.
- **CC:** This is the display configured as the US Closed Caption mode. The display is configured as a maximum of 16 rows with a maximum of 48 characters per row.

In both of the above modes the Character matrix, and TV lines per row can be defined. There is an option of 9, 10, 13 and 16 TV lines per display row, and a Character matrix ( $H \times V$ ) of 12 × 9, 12 × 10, 12 × 13, or 12 × 16.

Not all combinations of TV lines per row and maximum display rows give a sensible OSD display, since there is a limited number of TV scan lines available.

Special Function Register TXT21 and memory mapped registers are used to control the mode selection.

Throughout the section the features will be described and their function in each of the modes given. If the feature is different in either mode then this is stated.

19.2.1 FEATURES AVAILABLE IN EACH MODE

Table 16 shows a list of features available in each mode, and also if the setting is a serial/parallel attribute, or has a global effect on all the display.

## Table 16 Display features

| FEATURE                                   | ТХТ                                               | СС                                                              |
|-------------------------------------------|---------------------------------------------------|-----------------------------------------------------------------|
| Flash                                     | serial                                            | serial                                                          |
| Boxes                                     | Txt/OSD (serial)                                  | serial                                                          |
| Horizontal size                           | x1, x2 or x4 (serial)                             | x1 or x2 (serial)                                               |
| Vertical size                             | x1 or x2 (serial); x4 (global)                    | x1 or x2 (serial)                                               |
| Italic                                    | n/a                                               | serial                                                          |
| Foreground colours                        | 8 (serial)                                        | 8 + 8 (parallel)                                                |
| Background colours                        | 8 (serial)                                        | 16 (serial)                                                     |
| Soft colours (CLUT)                       | 16 from 4096                                      | 16 from 4096                                                    |
| Underline                                 | n/a                                               | serial                                                          |
| Overline                                  | n/a                                               | serial                                                          |
| Fringe                                    | N + S + E + W                                     | N + S + E + W                                                   |
| Fringe colour                             | 16 (global)                                       | 16 (serial)                                                     |
| Meshing of background                     | black or colour (global)                          | all (global)                                                    |
| Fast Blanking Polarity                    | yes                                               | yes                                                             |
| Screen colour                             | 16 (global)                                       | 16 (global)                                                     |
| DRCS                                      | 32 (global)                                       | 32 (global)                                                     |
| Character matrix $(H \times V)$           | $12\times9,12\times10,12\times13$ or $12\times16$ | 12 $\times$ 9, 12 $\times$ 10, 12 $\times$ 13 or 12 $\times$ 16 |
| Number of rows                            | 25                                                | 16                                                              |
| Number of columns                         | 40                                                | 48                                                              |
| Number of characters displayable          | 1000                                              | 768                                                             |
| Cursor                                    | yes                                               | yes                                                             |
| Special graphics (2 planes per character) | 16                                                | 16                                                              |
| Scroll                                    | no                                                | yes                                                             |

## 19.3 Display feature descriptions

All display features are now described in detail for both TXT and CC modes.

## 19.3.1 FLASH

Flashing causes the foreground colour pixel to be displayed as the background pixels. The flash frequency is controlled by software setting and resetting the MMR Status (see Table 34) at the appropriate interval.

**CC:** This attribute is valid from the time set (see Table 22) until the end of the row or until otherwise modified.

**TXT:** This attribute is set by the control character 'flash' (08H) (see Fig.30) and remains valid until the end of the row or until reset by the control character 'steady' (09H).

## 19.3.2 Boxes

**CC:** This attribute is valid from the time set until end of row or otherwise modified if set with Serial Mode 0. If set with Serial Mode 1, then it is set from the next character onwards.

In text mode (within CC mode) the background colour is displayed regardless of the setting of the box attribute bit. Boxes take effect only during mixed mode, where boxes are set in this mode the background colour is displayed. Character locations where boxes are not set show video/screen colour (depending on the setting in the MMR Display Control) in stead of the background colour.

**TXT:** Two types of boxes exist the teletext box and the OSD box. The teletext box is activated by the 'start box' control character (0BH). Two start box characters are required to begin a teletext box, with the box starting between the 2 characters. The box ends at the end of the line or after a 'end box' control character.

TXT mode can also use OSD boxes, they are started using size implying OSD control characters (BCH/BDH/BEH/BFH). The box starts after the control character (set after) and ends either at the end of the row or at the next size implying OSD character (set at).

The attributes flash, teletext box, conceal, separate graphics, twist and hold graphics are all reset at the start of an OSD box, as they are at the start of the row.

OSD boxes are only valid in TV mode which is defined by TXT5 = 03H and TXT6 = 03H.

## 19.3.3 SIZE

The size of the characters can be modified in both the horizontal and vertical directions.

**CC:** Two sizes are available in both the horizontal and vertical directions. The sizes available are normal ( $\times$ 1), double ( $\times$ 2) height/width and any combination of these. The attribute setting is always valid for the whole row. Mixing of sizes within a row is not possible.

**TXT:** Three horizontal sizes are available normal (×1), double (×2) and quadruple (×4). The control characters 'normal size' (0CH/BCH) enables normal size, the 'double width' or double size (0EH/BEH/0FH/BFH) enables double width characters.

Any two consecutive combination of 'double width' or 'double size' (0EH/BEH/0FH/BFH) activates quadruple width characters, provided quadruple width characters are enabled by TXT4.QUAD WIDTH ENABLE.

Three vertical sizes are available normal(x1), double (x2) and quadruple (x4). The control characters 'normal size' (0CH/BCH) enable normal size, the 'double height' or 'double size' (0DH/BDH/0FH/BFH) enable double height characters. Quadruple height character are achieved by using double height characters and setting the global attributes TXT7.DOUBLE HEIGHT (expand) and TXT7.BOTTOM/TOP.

If double height characters are used in teletext mode, single height characters in the lower row of the double height character are automatically disabled.

## 19.3.4 ITALIC

**CC:** This attribute is valid from the time set until the end of the row or otherwise modified. The attribute causes the character foreground pixels to be offset horizontally by 1 pixel per 4 scan lines (interlaced mode). The base is the bottom left character matrix pixel. The pattern of the character is indented as shown in Fig.25.

**TXT:** The Italic attribute is not available.

## SAA55xx



## 19.3.5 COLOURS

A Colour Look-Up Table (CLUT) with 16 colour entries is provided. The colours are programmable out of a palette of 4096 (4 bits per R, G and B). The CLUT is defined by writing data to a RAM that resides in the MOVX address space of the 80C51.

| Table 1 | 7 CLUT | colour | values |
|---------|--------|--------|--------|
|---------|--------|--------|--------|

| RED<3:0><br>(B11 TO B8) | GREEN<3:0<br>> (B7 TO B4) | BLUE<3:0><br>(B3 TO B0) | COLOUR<br>ENTRY |
|-------------------------|---------------------------|-------------------------|-----------------|
| 0000                    | 0000                      | 0000                    | 0               |
| 0000                    | 0000                      | 1111                    | 1               |
|                         |                           |                         |                 |
| 1111                    | 1111                      | 0000                    | 14              |
| 1111                    | 1111                      | 1111                    | 15              |

## 19.3.6 FOREGROUND COLOUR

**CC:** The foreground colour can be chosen from 8 colours on a character by character basis. Two sets of 8 colours are provided. A serial attribute switches between the banks (see Table 22 Serial Mode 1, bit 7). The colours are the CLUT entries 0 to 7 or 8 to 15.

**TXT:** The foreground colour is selected via a control character (see Fig.29). The colour control characters takes effect at the start of the next character ('Set-after') and remain valid until the end of the row, or until modified by a control character. Only 8 foreground colours are available.

The TEXT foreground control characters map to the CLUT entries as shown in Table 18.

| CONTROL<br>CODE | DEFINED<br>COLOUR | CLUT ENTRY |
|-----------------|-------------------|------------|
| 00H             | black             | 0          |
| 01H             | red               | 1          |
| 02H             | green             | 2          |
| 03H             | yellow            | 3          |
| 04H             | blue              | 4          |
| 05H             | magenta           | 5          |
| 06H             | cyan              | 6          |
| 07H             | white             | 7          |

 Table 18
 Foreground CLUT mapping

#### 19.3.7 BACKGROUND COLOUR

**CC:** This attribute is valid from the time set until end of row or otherwise modified if set with Serial Mode 0. If set with Serial Mode 1, then the colour is set from the next character onwards.

The background colour can be chosen from all 16 CLUT entries.

**TXT:** The control character 'New background' (1DH) is used to change the background colour to the current foreground colour. The selection is immediate (set at) and remains valid until the end of the row or until otherwise modified.

The TEXT background control characters map to the CLUT entries as shown in Table 19:

| Table 19 | Background | CLUT | mapping |
|----------|------------|------|---------|
|----------|------------|------|---------|

| CONTROL<br>CODE | DEFINED<br>COLOUR | CLUT ENTRY |
|-----------------|-------------------|------------|
| 00H + 1DH       | black             | 8          |
| 01H + 1DH       | red               | 9          |
| 02H + 1DH       | green             | 10         |
| 03H + 1DH       | yellow            | 11         |
| 04H + 1DH       | blue              | 12         |
| 05H + 1DH       | magenta           | 13         |
| 06H + 1DH       | cyan              | 14         |
| 07H + 1DH       | white             | 15         |

## 19.3.8 BACKGROUND DURATION

The attribute when set takes effect from the current position until the end of the text display defined in the MMR Text Area End.

**CC:** The background duration attribute (see Table 22, Serial Mode 1, bit 8) in combination with the End Of Row attribute (see Table 22, Serial Mode 1, bit 9) forces the background colour to be display on the row until the end of the text area is reached.

**TXT:** This attribute is not available.

## 19.3.9 UNDERLINE

The underline attribute causes the characters to have the bottom scan line of the character cell forced to foreground colour, including spaces. If background duration is set, then underline is set until the end of the text area.

**CC:** The underline attribute (see Table 22, Serial Mode 0/1, bit 4) is valid from the time set until end of row or otherwise modified.

**TXT:** This attribute is not available.

## 19.3.10 OVERLINE

The overline attribute causes the characters to have the top scan line of the character cell forced to foreground colour, including spaces. If background duration is set, then overline is set until the end of the text area.

**CC:** The overline attribute (see Table 22, Serial Mode 0/1, bit 5) is valid from the time set until end of row or otherwise modified. Overlining of Italic characters is not possible.

**TXT:** This attribute is not available.

## 19.3.11 END OF ROW

**CC:** The number of characters in a row is flexible and can determined by the end of row attribute (see Table 22 Serial Mode 1, bit 9). However the maximum number of character positions displayed is determined by the setting of the MMR Text Position Horizontal and MMR Text Area End.

Note that when using the end of row attribute the next character location after the attribute should always be occupied by a 'space'.

**TXT:** This attribute is not available, row length is fixed at 40 characters.

## SAA55xx

## 19.3.12 FRINGING

A fringe (shadow) can be defined around characters. The fringe direction is individually selectable in any of the North, South, East and West direction using the MMR Fringing Control. The colour of the fringe can also be defined as one of the entries in the CLUT, again using MMR Fringing Control.

**CC:** The fringe attribute (see Table 22, Serial Mode 0, bit 9) is valid from the time set until the end of the row or otherwise modified.

**TXT:** The display of fringing in TXT mode is controlled by the TXT4.SHADOW ENABLE bit.

When set all the alphanumeric characters being displayed are shadowed, graphics characters are not shadowed.

## 19.3.13 MESHING

The attribute effects the background colour being displayed. Alternate pixels are displayed as the background colour or video. The structure is offset by 1 pixel from scan line to scan line, thus achieving a checker board display of the background colour and video.

**CC:** The setting of the MSH bit in MMR Display Control has the effect of meshing any background colour.

**TXT:** There are two meshing attributes one that only affects black background colours TXT4.B MESH ENABLE and a second that only affects backgrounds other than black TXT4.C MESH ENABLE. A black background is defined as CLUT entry 8, a non-black background is defined as CLUT entry 9 to 15.

MBK973



Fig.27 Meshing and meshing/fringing (south + west).

## SAA55xx

## 19.3.14 CURSOR

The cursor operates by reversing the background and foreground colours in the character position pointed to by the active cursor position. The cursor is enabled using TXT7.CURSOR ON. When active, the row the cursor appears on is defined by TXT9.R<4:0> and the column is defined by TXT10.C<5:0>. The position of the cursor can be fixed using TXT9.CURSOR FREEZE.

**CC:** The valid range for row is 0 to 15. The valid range for column is 0 to 47. The cursor remains rectangular at all times, it's shape is not affected by italic attribute, therefore it is not advised to use the cursor with italic characters.

**TXT:** The valid range for row positioning is 0 to 24. The valid range for column is 0 to 39.

19.3.15 SPECIAL GRAPHICS CHARACTERS

**CC/TXT:** Several special characters are provided for improved OSD effects. These characters provide a choice of 4 colours within a character cell. The total number of special graphics characters is limited to 16.

They are stored in the character codes 8XH and 9XH of the character table (32 ROM characters), or in the DRCs which overlay character codes 8XH and 9XH. Each special graphics character uses two consecutive normal characters.

Fringing, underline and overline is not possible for special graphics characters. Special graphics characters are activated when TXT20.OSD PLANES = 1.

If the screen colour is transparent (implicit in mixed mode) and inside the object the box attribute is set, then the object is surrounded by video. If the box attribute is not set the background colour inside the object will also be displayed as transparent.

| Table 20 | Special | character | colour | allocation |
|----------|---------|-----------|--------|------------|
|----------|---------|-----------|--------|------------|

| PLANE 1 | PLANE 0 | COLOUR ALLOCATION |
|---------|---------|-------------------|
| 0       | 0       | background colour |
| 0       | 1       | foreground colour |
| 1       | 0       | CLUT entry 6      |
| 1       | 1       | CLUT entry 7      |





## **19.4** Character and attribute coding

This section describes the character and attribute coding for each mode.

## 19.4.1 CC MODE

Character coding is split into character oriented attributes (parallel) and character group coding (serial). The serial attributes take effect either at the position of the attribute (set at), or at the following location (set after) and remain effective until either modified by a new serial attribute or until the end of the row. A serial attribute is represented as a space (the space character itself however is not used for this purpose), the attributes that are still active,

e.g. overline and underline will be visible during the display of the space.

The default setting at the start of a row is:

- 1× size
- Flash off
- Overline off
- Underline off
- · Italics off
- Display mode = superimpose
- Fringing off
- Background colour duration = 0
- End of row = 0.

The coding is done in 12-bit words. The codes are stored sequentially in the display memory. A maximum of 768 character positions can be defined for a single display.

## 19.4.2 TXT MODE

Character coding is in a serial format, with only one attribute being changed at any single location. The serial attributes take effect either at the position of the attribute (set at), or at the following location (set after). The attribute remains effective until either modified by new serial attributes or until the end of the row.

The default settings at the start of a row are:

- Foreground colour white (CLUT address 7)
- Background colour black (CLUT address 8)
- Horizontal size ×1, vertical size ×1 (normal size)
- Alphanumeric on
- Contiguous Mosaic Graphics
- Release Mosaics
- Flash off
- Box off
- Conceal off
- Twist off.

The attributes have individual codes which are defined in the basic character table (see Fig.30).

#### 19.4.3 PARALLEL CHARACTER CODING

#### Table 21 Parallel character coding

| BITS    | DESCRIPTION                     |  |
|---------|---------------------------------|--|
| 0 to 7  | 8-bit character code            |  |
| 8 to 10 | 3 bits for 8 foreground colours |  |
| 11      | Mode bit: 0 = parallel code     |  |

## 19.4.4 SERIAL CHARACTER CODING

## Table 22 Serial character coding

|        | DESCRIPTION                      |                                  |                                      |  |  |
|--------|----------------------------------|----------------------------------|--------------------------------------|--|--|
| BITS   | SERIAL MODE 0<br>('SET AT')      | SERIAL MODE 1                    |                                      |  |  |
|        |                                  | CHAR.POS. 1 ('SET AT')           | CHAR.POS. >1 ('SET AFTER')           |  |  |
| 0 to 3 | 4 bits for 16 background colours | 4 bits for 16 background colours | 4 bits for 16 background colours     |  |  |
| 4      | Underline switch:                | Horizontal size:                 | Underline switch:                    |  |  |
|        | 0 = underline off                | 0 = normal                       | 0 = underline off                    |  |  |
|        | 1 = underline on                 | 1 = ×2                           | 1 = underline on                     |  |  |
| 5      | Overline switch:                 | Vertical size:                   | Overline switch:                     |  |  |
|        | 0 = overline off                 | 0 = normal                       | 0 = overline off                     |  |  |
|        | 1 = overline on                  | 1 = ×2                           | 1 = overline on                      |  |  |
| 6      | Display mode:                    | Display mode:                    | Display mode:                        |  |  |
|        | 0 = superimpose                  | 0 = superimpose                  | 0 = superimpose                      |  |  |
|        | 1 = boxing                       | 1 = boxing                       | 1 = boxing                           |  |  |
| 7      | Flash switch:                    | Foreground colour switch         | Foreground colour switch             |  |  |
|        | 0 = flash off                    | 0 = Bank 0 (colours 0 to 7)      | 0 = Bank  0  (colours  0  to  7)     |  |  |
|        | 1 = flash on                     | 1 = Bank 1 (colours 8 to 15)     | 1 = Bank 1 (colours 8 to 15)         |  |  |
| 8      | Italic switch:                   | Background colour duration:      | Background colour duration (set at): |  |  |
|        | 0 = italics off                  | 0 = stop BGC                     | 0 = stop BGC                         |  |  |
|        | 1 = italics on                   | 1 = set BGC to end of row        | 1 = set BGC to end of row            |  |  |
| 9      | Fringing switch:                 | End of row                       | End of row (set at):                 |  |  |
|        | 0 = fringing off                 | 0 = continue row                 | 0 = continue row                     |  |  |
|        | 1 = fringing on                  | 1 = end row                      | 1 = end row                          |  |  |
| 10     | Switch for serial coding:        | Switch for serial coding:        | Switch for serial coding:            |  |  |
|        | 0 = mode 0                       | 0 = mode 0                       | 0 = mode 0                           |  |  |
|        | 1 = mode 1                       | 1 = mode 1                       | 1 = mode 1                           |  |  |
| 11     | Mode bit:                        | Mode bit:                        | Mode bit:                            |  |  |
|        | 1 = serial code                  | 1 = serial code                  | 1 = serial code                      |  |  |

2000 Feb 23

\_

 $E/\overline{W} = 0$ 0 0 0 0 0 0 0 b-0 1 1 0 0 0 0 0 be 1 1 1 1 0 0 0 1 1 1 1 1 Ś 0 0 0 0 0 0 1 0 0 0 b5 1 1 1 1 1 1 1 b₄ —► 0 0 0 0 0 1 1 0 1 Δ 1 1 0 <sup>b</sup>3 <sup>b</sup>2 <sup>b</sup>1 b<sub>0</sub> column 0 1 2 2a 3 3a 4 5 6 6a 7 7a 8 8a 9 9a в С D Е F D Α ¥ ¥ + ć ú è Ã back-# £ graphics 0 Ρ alpha nat opt nat opt р ground black 0 0 0 0 0 OSD OSD OSD OSD black black Á ì \$ Û Ñ back ground ľ graphics red Α alpha Q a 0 0 0 1 q OSD OSD OSD OSD 1 red red ò Ũ ń back-ground green graphics 77 2 É B R Ь X alpha ٣ 0 0 1 0 2 OSD OSD OSD OSD green areen İ ù ŕ Í 3 С S back-14 graphics alpha nat opt C 12 0 0 1 1 3 5 OSD OSD OSD OSD ground yellow vellow yellow ú ä **a** back-Ó Ì À 4 d D alpha blue graphics nat opt Т t OSD OSD OSD OSD 0 1 0 0 4 ground blue blue È ë ý 34 2 back-Ú graphics % 5 E e alpha ┛ u 0 1 0 1 5 OSD OSD OSD OSD ground magenta magenta magenta ź back-ground cyan Ò f 6 8. V Ð ÷ graphics F æ alpha Y Ö 0 1 1 0 6 OSD OSD OSD OSD cvan cyan ê Ć 7 back-Æ alpha white graphics white G Ψ + 7 g W ü Ş OSD 0 1 1 1 7 OSD OSD OSD ground white ő û Ş ð Ľ X Η conceal 8 ↦ C A h х 8 1 0 0 0 flash OSD OSD OSD OSD display Ë ű â Î ↑ ç Ń i ) 9 Ι contiguous У 1 0 0 1 9 steady OSD OSD OSD OSD graphics Ö Ő î Ç Ŕ **ֿן** Ù ж separated Ζ Ø Z 1 0 1 0 Α end box OSD OSD OSD OSD graphics Ű ô ğ Ū, 1 К i Ø į +nat opt k nat opt U 1 0 1 в start box 1 twist OSD OSD OSD OSD á Â Ğ Ý þ black < normal ċ 1 normal height nat opt nat opt С size OSD 1 1 0 0 back -OSD OSD OSD OSD 2 ground ã Ê Þ Ź é double height OSD ï new M double height nat opt nat opt m D 1 1 0 1 back -OSD OSD OSD OSD ground Ϊ ñ ů å í double Ν double hold > nat opt nat opt . n OSD OSD OSD width 1 1 1 0 Е OSD width graphics ó à õ Å Ů double ? 0 double release nat opt O F OSD OSD OSD OSD 1 1 1 1 size OSD graphics size character dependent on the language of page, refer to National Option characters opt OSD customer definable On-Screen Display character

Fig.30 TXT basic character set (Pan-European).

Philips Semiconductors

Enhanced <sup>-</sup> On-Screen

Display

(OSD)

TV microcontrollers

with

 $E/\overline{W} = 1$ 

1 1

1

E F

å

Ă

ţĎ

Ţ

ą

ę

ĄŘ

ĘŠ

č

ď

ě

ľ

ňż

ř

Š

ť

ž

Č

Ĕ

Ľ

Ñ

Ť

Ž

đ

ľ

Ô

Ł

Z

MBK974

Preliminary specification

SAA55xx

66

SAA55xx

## Enhanced TV microcontrollers with On-Screen Display (OSD)

## 19.5 Screen and global controls

A number of attributes are available that affect the whole display region, and cannot be applied selectively to regions of the display.

## 19.5.1 TV SCAN LINES PER ROW

The number of TV scan lines per field used for each display row can be defined, the value is independent of the character size being used. The number of lines can be either 10, 13 or 16 per display row. The number of TV scan lines per row is defined TXT21.DISP LINES<1:0>.

A value of 9 lines per row can be achieved if the display is forced into 525-line display mode by

TXT17.FORCE DISP<1:0>, or if the device is in 10 line mode and the automatic detection circuitry within display finds 525-line display syncs.

## 19.5.2 Character matrix $(H \times V)$

There are three different character matrices available, these are  $12 \times 10$ ,  $12 \times 13$  and  $12 \times 16$ . The selection is made using TXT21.CHAR SIZE<1:0> and is independent of the number of display lines per row.

If the character matrix is less than the number of TV scan lines per row then the matrix is padded with blank lines. If the character matrix is greater than the number of TV scan lines then the character is truncated.

#### 19.5.3 DISPLAY MODES

**CC:** When attributes superimpose or boxing (see Table 22, Serial Mode 0/1, bit 6) are set, the resulting display depends on the setting of the following screen control mode bits in the MMR Display Control.

**TXT:** The display mode is controlled by the bits in the TXT5 and TXT6. There are 3 control functions - Text on, Background on and Picture on. Separate sets of bits are used inside and outside teletext boxes so that different display modes can be invoked. TXT6 is used if the newsflash (C5) or subtitle (C6) bits in row 25 of the basic page memory are set otherwise TXT5 is used. This allows the software to set up the type of display required on newsflash and subtitle pages (e.g. text inside boxes, TV picture outside) this will be invoked without any further software intervention when such a page is acquired.

When teletext box control characters are present in the display page memory, the appropriate Box control bit must be set, TXT7.BOX ON 0, TXT7.BOX ON 1 – 23 or TXT7.BOX ON 24. This allows the display mode to be different inside the teletext box compared to outside. These bits are present to allow boxes in certain areas of the screen to be disabled. The use of teletext boxes for OSD messages has been superseded in this device by the OSD box concept, but these bits remain to allow teletext boxes to be used, if required.

| MOD1 | MOD0 | DISPLAY MODE        | DESCRIPTION                                                                                                                        |
|------|------|---------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 0    | Video               | Disables all display activities, sets the RGB to true black and VDS to video.                                                      |
| 0    | 1    | Full Text           | Displays screen colour at all locations not covered by character foreground or background colour. The box attribute has no effect. |
| 1    | 0    | Mixed Screen Colour | Displays screen colour at all locations not covered by character foreground, within boxed areas or, background colour.             |
| 1    | 1    | Mixed Video         | Displays video at all locations not covered by character foreground, within boxed areas or, background colour.                     |

| Table 23 | Selection | of Display | modes |
|----------|-----------|------------|-------|
|          | OCICCUOT  | or Display | moucs |

 Table 24
 TXT display control bits

| PICTURE ON | TEXT ON | BACKGROUND ON | EFFECT                                  |
|------------|---------|---------------|-----------------------------------------|
| 0          | 0       | X             | Text mode, black screen                 |
| 0          | 1       | 0             | Text mode, background always black      |
| 0          | 1       | 1             | Text mode                               |
| 1          | 0       | Х             | Video mode                              |
| 1          | 1       | 0             | Mixed text and TV mode                  |
| 1          | 1       | 1             | Text mode, TV picture outside text area |

#### 19.6 Screen colour

Screen colour is displayed from 10.5 to 62.5 ms after the active edge of the HSYNC input and on TV lines 23 to 310 inclusive, for a 625-line display, and lines 17 to 260 inclusive for a 525-line display.

CC: The screen colour is defined by the MMR Display Control and points to a location in the CLUT table. The screen colour covers the full video width. It is visible when the Full Text or Mixed Screen Colour mode is set and no foreground or background pixels are being displayed.

TXT: The register bits TXT17.SCREEN COL<2:0> can be used to define a colour to be displayed in place of TV picture and the black background colour. If the bits are all set to zero, the screen colour is defined as 'transparent' and TV picture and background colour are displayed as normal. Otherwise the bits define CLUT entries 9 to 15.

#### 19.7 Text display controls

19.7.1 TEXT DISPLAY CONFIGURATION (CC MODE)

Two types of areas are possible. The one area is static and the other is dynamic. The dynamic area allows scrolling of a region to take place. The areas cannot cross each other. Only one scroll region is possible.

#### 19.7.2 DISPLAY MAP

The display map allows a flexible allocation of data in the memory to individual rows.

Sixteen words are provided in the display memory for this purpose. The lower 10 bits address the first word in the memory where the row data starts. This value is an offset in terms of 16-bit words from the start of Display memory (8000H). The most significant bit enables the display when not within the scroll (dynamic) area.

The display map memory is fixed at the first 16 words in the closed caption display memory.

#### Table 25 Display map bit allocation

| BIT    | FUNCTION                                                                         |
|--------|----------------------------------------------------------------------------------|
| 11     | Text display enable, valid outside Soft Scroll<br>Area. 0 = disable; 1 = enable. |
| 10     | This bit is reserved, should be set to logic 0.                                  |
| 9 to 0 | Pointer to row data.                                                             |

SAA55xx

## Enhanced TV microcontrollers with On-Screen Display (OSD)



## 19.8 Soft scroll action

The dynamic scroll region is defined by the MMR Scroll Area, MMR Scroll Range, MMR Top Scroll line and the MMR Status. The scroll area is enabled when the SCON bit is set in MMR Status.

The position of the soft scroll area window is defined using the Soft Scroll Position bits (SSP<3:0>) and the height of the window is defined using the Soft Scroll Height bits (SSH<3:0>) both are in MMR Scroll Range. The rows that are scrolled through the window are defined using the Start Scroll Row (STS<3:0>) and the Stop Scroll Row (SPS<3:0>) both are in MMR Scroll Area.

The soft scrolling function is done by modifying the Scroll Line (SCL<3:0>) in MMR Top Scroll Line and the first scroll row value SCR<3:0> in the MMR Status.

If the number of rows allocated to the scroll counter is larger than the defined visible scroll area, this allows parts of rows at the top and bottom to be displayed during the scroll function. The registers can be written throughout the field and the values are updated for display with the next field sync. Care should be taken that the register pairs are written to by the software in the same field.

Only a region that contains only single height rows or only double height rows can be scrolled.

**TXT:** The display is organised as a fixed size of 25 rows (0 to 24) of 40 columns (0 to 39). This is the standard size for teletext transmissions. The control data in row 25 is not displayed but is used to configure the display page correctly.



## Preliminary specification

## Enhanced TV microcontrollers with On-Screen Display (OSD)





## 19.9 Display positioning

The display consists of the **screen colour** covering the whole screen and the **text area** that is placed within the visible screen area.

The screen colour extends over a large vertical and horizontal range so that no offset is needed. The text area is offset in both directions relative to the vertical and horizontal sync pulses.



#### 19.9.1 SCREEN COLOUR DISPLAY AREA

This area is covered by the screen colour. The screen colour display area starts with a fixed offset of 8  $\mu$ s from the leading edge of the horizontal sync pulse in the horizontal direction. A vertical offset is not necessary.

#### Table 26 Screen colour display area

| POSITION   | 525-LINE                                                                                                   |
|------------|------------------------------------------------------------------------------------------------------------|
| Horizontal | Start at 8 $\mu$ s after leading edge of horizontal sync for 56 $\mu$ s.                                   |
| Vertical   | Line 9, Field 1 (321, Field 2) to leading<br>edge of vertical sync (line numbering<br>using 625 standard). |

#### 19.9.2 TEXT DISPLAY AREA

The text area can be defined to start with an offset in both the horizontal and vertical direction.

#### Table 27 Text display area

| POSITION   | DESCRIPTION                                                                                                                                                                         |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Horizontal | Up to 48 full sized characters per row.<br>Start position setting from 8 to 64<br>characters from the leading edge of<br>horizontal sync. Fine adjustment in<br>quarter characters. |
| Vertical   | 256 lines (nominal 41 to 297). Start<br>position setting from leading edge of<br>vertical sync, legal values are<br>4 to 64 lines (line numbering using<br>625 standard).           |

The horizontal offset is set in the MMR Text Area Start. The offset is done in full width characters using TAS<5:0> and quarter characters using HOP<1:0> for fine setting. The values 00H to 08H for TAS<5:0> will result in a corrupted display.

The value 09H should also be avoided in the MMR Text Area Start as corruption of the row 24 display can occur. Alternative values are C8H or 49H to overcome this problem.

The width of the text area is defined in the Text Area End Register by setting the end character value TAE<5:0>. This number determines where the background colour of the Text Area will end if set to extend to the end of the row. It will also terminate the character fetch process thus eliminating the necessity of a **row end** attribute. This entails however writing to all positions.

The vertical offset is set in the Text Position Vertical Register. The offset value VOL<5:0> is done in number of TV scan lines.

Note that the Text Position Vertical register should not be set to 00H as the Display Busy interrupt is not generated in these circumstances.

## 19.10 Character set

To facilitate the global nature of the device the character set has the ability to accommodate a large number of characters, which can be stored in different matrices.

#### 19.10.1 CHARACTER MATRICES

The character matrices that can be accommodated in both display modes are:

(H × V × planes)  $12 \times 9 \times 1$ ,  $12 \times 10 \times 1$ ,  $12 \times 13 \times 1$ ,  $12 \times 16 \times 1$ .

These modes allow two colours per character position.

In CC mode two additional character matrices are available to allow four colours per character.

(H  $\times$  V  $\times$  planes) 12  $\times$  13  $\times$  2, 12  $\times$  16  $\times$  2.

The characters are stored physically in ROM in a matrix of size either  $12 \times 10$  or  $12 \times 16$ .

#### 19.10.2 CHARACTER SET SELECTION

Four character sets are available in the device. A set can consist of alphanumeric characters as required by the WST or US Closed Captioning, Customer definable On-Screen Display characters, and Special Graphic characters.

**CC:** Only a single character set can be used for display and this is selected using the Basic Set selection TXT18.BS<1:0>. When selecting a character set in CC mode the Twist Set selection TXT19.TS<1:0> should be set to the same value as TXT18.BS<1:0> for correct operation. **TXT:** Two character sets can be displayed at once. These are the basic G0 set or the alternative G0 set (Twist Set). The basic set is selected using TXT18.BS<1:0>. The alternative/twist character set is defined by TXT19.TS<1:0>. Since the alternative character set is an option it can be enabled or disabled using TXT19.TEN, and the language code that is defined for the alternative set is defined by TXT19.TC<2:0>.

The National option table is selected using TXT18.NOT<3:0>. A maximum of 31 National option tables can be defined when combined with the EAST/WEST control bit located in register TXT4.

An example of the character set selection and definitions is show in Table 28.

An example of the National option reference table is shown in Table 29. Only a certain number of national options will be relevant for each of the Character sets.

| BS1/TS1 | BS0/TS0 | CHARACTER SET | EXAMPLE LANGUAGE |
|---------|---------|---------------|------------------|
| 0       | 0       | Set 0         | Latin            |
| 0       | 1       | Set 1         | Greek            |
| 1       | 0       | Set 2         | Cyrillic         |
| 1       | 1       | Set 3         | French/Arabic    |

#### Table 28 Character set selection

 Table 29
 National option selection

| C12 | C13 | C14 | NOT<3:0> = 0000 | NOT<3:0> = 0001 | NOT<3:0> = 0010 | <br>NOT<3:0> = 1110 |
|-----|-----|-----|-----------------|-----------------|-----------------|---------------------|
| 0   | 0   | 0   | English         | Polish          | English         | <br>Polish          |
| 0   | 0   | 1   | German          | German          | German          | <br>German          |
| 0   | 1   | 0   | Swedish         | Swedish         | Swedish         | <br>Estonian        |
| 0   | 1   | 1   | Italian         | Italian         | Italian         | <br>Lettish         |
| 1   | 0   | 0   | French          | French          | French          | <br>Russian         |
| 1   | 0   | 1   | Spanish         | -               | Spanish         | <br>Serb-Croat      |
| 1   | 1   | 0   | Czech           | Czech           | Turkish         | <br>Czech           |
| 1   | 1   | 1   | -               | _               | _               | <br>-               |

75

SAA55xx

### 19.11 ROM addressing

Three ROMs are used to generate the correct pixel information. The first contains the National option look-up table, the second contains the Basic Character look-up table and the third contains the Character Pixel information.

Although these are individual ROMs, since they do not need to be accessed simultaneously they are all combined into a single ROM unit.



SAA55xx

19.11.1 CHARACTER TABLE

**CC:** The character table is shown in Fig.37.

TXT: One of the character set options (Pan-European: Latin) is shown in Fig.30.

| 0 |     | 1        | 2          | 3                                  | 4          | 5        | 6      | 7 | 8 | 9 | Α | В | С | D | E | F   |
|---|-----|----------|------------|------------------------------------|------------|----------|--------|---|---|---|---|---|---|---|---|-----|
| 0 |     | ®        | SP         | 0                                  | @          | Р        | ú      | р |   |   |   |   |   |   |   |     |
| 1 |     | o        | !          | 1                                  | Α          | Q        | а      | q |   |   |   |   |   |   |   |     |
| 2 |     | 1/2      | "          | 2                                  | В          | R        | b      | r |   |   |   |   |   |   |   |     |
| 3 |     | Ś        | #          | 3                                  | С          | S        | с      | S |   |   |   |   |   |   |   |     |
| 4 |     | тм       | \$         | 4                                  | D          | Т        | d      | t |   |   |   |   |   |   |   |     |
| 5 |     | ¢        | %          | 5                                  | E          | U        | е      | u |   |   |   |   |   |   |   |     |
| 6 |     | £        | &          | 6                                  | F          | V        | f      | v |   |   |   |   |   |   |   |     |
| 7 |     | ₽        | ,          | 7                                  | G          | W        | g      | w |   |   |   |   |   |   |   |     |
| 8 |     | à        | (          | 8                                  | н          | Х        | h      | x |   |   |   |   |   |   |   |     |
| 9 |     | _        | )          | 9                                  | I          | Y        | i      | у |   |   |   |   |   |   |   |     |
| A |     | è        | á          | :                                  | J          | Z        | j      | z |   |   |   |   |   |   |   |     |
| в |     | â        | +          | ;                                  | K          | [        | k      | Ç |   |   |   |   |   |   |   |     |
| c |     | ê        | ,          | <                                  | L          | é        |        |   |   |   |   |   |   |   |   |     |
| D |     | î        | -          | =                                  | М          | ]        | m      | Ñ |   |   |   |   |   |   |   |     |
| E | _   | Ô        | •          | >                                  | N          | Í        | n      | ñ |   |   |   |   |   |   |   |     |
| F |     | û        | /          | ?                                  | 0          | Ó        | 0      | n |   |   |   |   |   |   |   | MBK |
|   | _ A | dditiona | al table l | ers in col<br>ocations<br>or norma | s for norr | mal char | acters |   |   |   |   |   |   |   |   |     |

#### 19.12 Redefinable characters

A number of Dynamically Redefinable Characters (DRC) are available. These are mapped onto the normal character codes, and replace the predefined ROM value.

There are 32 DRCs, the first 16 occupy the character codes 80H to 8FH, the second 16 occupy the locations 90H to 9FH. This allows for 32 DRCs or 16 Special DRCs.

The remapping of the standard OSD to the DRCs is activated when the TXT20.DRCS ENABLE bit is set. The selection of Normal or Special OSD symbols is defined by the TXT20.OSD PLANES.

Each character is stored in a matrix of  $12 \times 16 \times 1$  (V  $\times$  H  $\times$  planes), this allows for all possible character matrices to be defined within a single location.



### 19.12.1 DEFINING CHARACTERS

The DRC RAM is mapped into the 80C51 RAM address space and starts at location 8800H. The character matrix is 12 bits wide and therefore requires two bytes to be written for each word, the first byte (even addresses), addresses the lower 8 bits and the lower nibble of the second byte (odd addresses) addresses the upper 4 bits.

For characters of 9, 10 or 16 lines high the pixel information starts in the first address and continues sequentially for the required number of address.

Characters of 13 lines high are defined with an initial offset of 1 address, this is to allow for correct generation of fringing across boundaries of clustered characters see Fig.39. The characters continue sequentially for 13 lines after which a further line can again be used for generation of correct fringing across boundaries of clustered characters.



#### 19.13 Display synchronization

The horizontal and vertical synchronizing signals from the TV deflection are used as inputs. Both signals can be inverted before being delivered to the Phase Selector section.

**CC:** The polarity is controlled using either VPOL or HPOL bits in the MMR Text Position Vertical.

**TXT:** The TXT1.H POLARIY and TXT1.V POLARITY bits control the polarity.

A line locked 12 MHz clock is derived from the 12 MHz free running oscillator by the Phase Selector. This line locked clock is used to clock the whole of the display block.

The horizontal and vertical sync signals are synchronized with the 12 MHz clock before being used in the display section.

#### 19.14 Video/data switch (Fast Blanking) polarity

The polarity of the Video/data (Fast Blanking) signal can be inverted. The polarity is set with the VDSPOL bit in the MMR RGB Brightness.

#### Table 30 Fast Blanking signal polarity

| VDSPOL | VDS | CONDITION     |
|--------|-----|---------------|
| 0      | 1   | RGB display   |
| 0      | 0   | Video display |
| 1      | 0   | RGB display   |
| 1      | 1   | Video display |

#### 19.15 Video/Data switch adjustment

To take into account the delay between the RGB values and the VDS signal due to external buffering, the VDS signal can be moved in relation to the RGB signals. The VDS signal can be set to be either a clock cycle before or after the RGB signal, or coincident with the RGB signal. This is done using VDEL<2:0> in the MMR Configuration.

SAA55xx

## Enhanced TV microcontrollers with On-Screen Display (OSD)

### 19.16 RGB brightness control

A brightness control is provided to allow the RGB upper output voltage level to be modified. The nominal value is 1 V into a 150  $\Omega$  resistor, but can be varied between 0.7 and 1.2 V.

The brightness is set in RGB Brightness Register.

#### Table 31 RGB brightness

| BRI3 TO BRI0 | RGB BRIGHTNESS |
|--------------|----------------|
| 0000         | lowest value   |
|              |                |
| 1111         | highest value  |

### 19.17 Contrast reduction

CC: This feature is not available in CC mode.

**TXT**: The  $\overline{COR}$  bits in SFRs TXT5 and TXT6 control when the  $\overline{COR}$  output of the device is activated (i.e. pulled LOW). This output is intended to act on the TVs display circuits to reduce contrast of the video when it is active. The result of contrast reduction is to improve the readability of the text in a mixed teletext and video display.

The bits in the TXT5 and TXT6 SFRs allow the display to be set up so that, for example, the areas inside teletext boxes will be contrast reduced when a subtitle is being displayed but that the rest of the screen will be displayed as normal video.

## 20 MEMORY MAPPED REGISTERS (MMR)

The memory mapped registers are used to control the display. The registers are mapped into the microcontroller MOVX address space, starting at address 87F0H and extending to 87FFH.

| summary |
|---------|
|         |

| REGISTER<br>NUMBER | MEMORY<br>ADDRESS | FUNCTION               |
|--------------------|-------------------|------------------------|
| 0                  | 87F0H             | Display Control        |
| 1                  | 87F1H             | Text Position Vertical |
| 2                  | 87F2H             | Text Area Start        |
| 3                  | 87F3H             | Fringing Control       |
| 4                  | 87F4H             | Text Area End          |
| 5                  | 87F5H             | Scroll Area            |
| 6                  | 87F6H             | Scroll Range           |
| 7                  | 87F7H             | RGB Brightness         |
| 8                  | 87F8H             | Status                 |
| 9                  | 87F9H             | Reserved               |
| 10                 | 87FAH             | Reserved               |
| 11                 | 87FBH             | Reserved               |
| 12                 | 87FCH             | HSYNC Delay            |
| 13                 | 87FDH             | VSYNC Delay            |
| 14                 | 87FEH             | Top Scroll Line        |
| 15                 | 87FFH             | Configuration          |

## Table 33 MMR map

|      | DAM |                           | -      | •     |       |       | •     | •    |      | •    | DEOFT |
|------|-----|---------------------------|--------|-------|-------|-------|-------|------|------|------|-------|
| ADD  | R/W | NAME                      | 7      | 6     | 5     | 4     | 3     | 2    | 1    | 0    | RESET |
| 87F0 | R/W | Display<br>Control        | SRC3   | SRC2  | SRC1  | SRC0  | -     | MSH  | MOD1 | MOD0 | 00H   |
| 87F1 | R/W | Text Position<br>Vertical | VPOL   | HPOL  | VOL5  | VOL4  | VOL3  | VOL2 | VOL1 | VOL0 | 00H   |
| 87F2 | R/W | Text Area<br>Start        | HOP1   | HOP0  | TAS5  | TAS4  | TAS3  | TAS2 | TAS1 | TAS0 | 00H   |
| 87F3 | R/W | Fringing<br>Control       | FRC3   | FRC2  | FRC1  | FRC0  | FRDN  | FRDE | FRDS | FRDW | 00H   |
| 87F4 | R/W | Text Area<br>End          | _      | _     | TAE5  | TAE4  | TAE3  | TAE2 | TAE1 | TAE0 | 00H   |
| 87F5 | R/W | Scroll Area               | SSH3   | SSH2  | SSH1  | SSH0  | SSP3  | SSP2 | SSP1 | SSP0 | 00H   |
| 87F6 | R/W | Scroll Range              | SPS3   | SPS2  | SPS1  | SPS0  | STS3  | STS2 | STS1 | STS0 | 00H   |
| 87F7 | R/W | RGB<br>Brightness         | VDSPOL | _     | -     | _     | BRI3  | BRI2 | BRI1 | BRI0 | 00H   |
| 87F8 | R   | Status                    | BUSY   | FIELD | SCON  | FLR   | SCR3  | SCR2 | SCR1 | SCR0 | 00H   |
|      | W   |                           | _      | _     | SCON  | FLR   | SCR3  | SCR2 | SCR1 | SCR0 | 00H   |
| 87FC | R/W | HSYNC<br>Delay            | -      | HSD6  | HSD5  | HSD4  | HSD3  | HSD3 | HSD1 | HSD0 | 00H   |
| 87FD | R/W | VSYNC<br>Delay            | _      | VSD6  | VSD5  | VSD4  | VSD3  | VSD2 | VSD1 | VSD0 | 00H   |
| 87FE | R/W | Top Scroll<br>Line        | _      | _     | -     | -     | SCL3  | SCL2 | SCL1 | SCL0 | 00H   |
| 87FF | R/W | Configuration             | CC     | VDEL2 | VDEL1 | VDEL0 | TXT/V | _    | -    | -    | 00H   |

## Preliminary specification

SAA55xx

## Enhanced TV microcontrollers with On-Screen Display (OSD)

## Table 34 MMR bit definition

| REGISTER              | FUNCTION                                         |
|-----------------------|--------------------------------------------------|
| Display Control       |                                                  |
| SRC3 to SRC0          | screen colour definition                         |
| MSH                   | meshing all background colours (logic 1)         |
| MOD2 to MOD0          | 00 = Video                                       |
|                       | 01 = Full Text                                   |
|                       | 10 = Mixed Screen Colour                         |
|                       | 11 = Mixed Video                                 |
| Text Position Vertica | al                                               |
| VPOL                  | inverted input polarity (logic 1)                |
| HPOL                  | inverted input polarity (logic 1)                |
| VOL5 to VOL0          | display start vertical offset from VSYNC (lines) |
| Text Area Start       |                                                  |
| HOP1 to HOP0          | fine horizontal offset in quarter of characters  |
| TAS5 to TAS0          | text area start                                  |
| Fringing Control      |                                                  |
| FRC3 to FRC0          | fringing colour, value address of CLUT           |
| FRDN                  | fringe in north direction (logic 1)              |
| FRDE                  | fringe in east direction (logic 1)               |
| FRDS                  | fringe in south direction (logic 1)              |
| FRDW                  | fringe in west direction (logic 1)               |
| Text Area End         |                                                  |
| TAE5 to TAE0          | text area end, in full characters                |
| Scroll Area           |                                                  |
| SSH3 to SSH0          | soft scroll height                               |
| SSP3 to SSP0          | soft scroll position                             |
| Scroll Range          |                                                  |
| SPS3 to SPS0          | stop scroll row                                  |
| STS3 to STS0          | start scroll row                                 |
| RGB Brightness        |                                                  |
| VDSPOL                | VDS polarity                                     |
|                       | 0 = RGB(1), Video(0)                             |
|                       | 1 = RGB (0), Video (1)                           |
| BRI3 to BRI0          | RGB brightness control                           |
|                       |                                                  |

| REGISTER        | FUNCTION                                                        |  |
|-----------------|-----------------------------------------------------------------|--|
| Status read     |                                                                 |  |
| BUSY            | access to display memory could cause display problems (logic 1) |  |
| FIELD           | even field (logic 1)                                            |  |
| FLR             | active flash region background only displayed (logic 1)         |  |
| SCR3 to SCR0    | first scroll row                                                |  |
| Status write    |                                                                 |  |
| SCON            | scroll area enabled (logic 1)                                   |  |
| FLR             | active flash region background colour only displayed (logic 1)  |  |
| SCR3 to SCR0    | first scroll row                                                |  |
| HSYNC Delay     |                                                                 |  |
| HSD6 to HSD0    | HSYNC delay, in full size characters                            |  |
| VSYNC Delay     | · ·                                                             |  |
| VSD6 to VSD0    | VSYNC delay in number of 8-bit 12 MHz clock cycles              |  |
| Top Scroll Line |                                                                 |  |
| SCL3 to SCL0    | top line for scroll                                             |  |
| Configuration   |                                                                 |  |
| CC              | closed caption mode (logic 1)                                   |  |
| VDEL2 to VDEL0  | pixel delay between VDS and RGB output                          |  |
|                 | 000 = VDS switched to video, not active                         |  |
|                 | 001 = VDS active one pixel earlier then RGB                     |  |
|                 | 010 = VDS synchronous to RGB                                    |  |
|                 | 100 = VDS active one pixel after RGB                            |  |
| TXT/V           | BUSY signal switch                                              |  |
|                 | horizontal (logic 1)                                            |  |

## SAA55xx

### 21 LIMITING VALUES

In accordance with Absolute Maximum Rating System (IEC 60134).

| SYMBOL           | PARAMETER                        | CONDITIONS | MIN. | MAX.                         | UNIT |
|------------------|----------------------------------|------------|------|------------------------------|------|
| V <sub>DDX</sub> | supply voltage (all supplies)    |            | -0.5 | +4.0                         | V    |
| VI               | input voltage (any input)        | note 1     | -0.5 | V <sub>DD</sub> + 0.5 or 4.1 | V    |
| Vo               | output voltage (any output)      | note 1     | -0.5 | V <sub>DD</sub> + 0.5        | V    |
| lo               | output current (each output)     |            | -    | 10                           | mA   |
| I <sub>IOK</sub> | DC input or output diode current |            | -    | 20                           | mA   |
| T <sub>amb</sub> | ambient temperature              |            | -20  | +70                          | °C   |
| T <sub>stg</sub> | storage temperature              |            | -55  | +125                         | °C   |

#### Note

1. This maximum value refers to 5 V tolerant I/Os and may be 6 V maximum but only when V<sub>DD</sub> is present.

### 22 CHARACTERISTICS

 $V_{DD}$  = 3.3 V  $\pm$  10%;  $V_{SS}$  = 0 V;  $T_{amb}$  = –20 to +70 °C; unless otherwise specified.

| SYMBOL                | PARAMETER                                   | CONDITIONS         | MIN.  | TYP.  | MAX.  | UNIT |
|-----------------------|---------------------------------------------|--------------------|-------|-------|-------|------|
| Supplies              |                                             |                    | -     | - I   |       |      |
| V <sub>DDX</sub>      | any supply voltage ( $V_{DD}$ to $V_{SS}$ ) |                    | 3.0   | 3.3   | 3.6   | V    |
| I <sub>DDP</sub>      | periphery supply current                    | note 1             | 1     | -     | -     | mA   |
| I <sub>DDC</sub>      | core supply current                         |                    | _     | 15    | 18    | mA   |
| I <sub>DDC(id)</sub>  | Idle mode core supply current               |                    | _     | 4.6   | 6     | mA   |
| I <sub>DDC(pd)</sub>  | Power-down mode core supply current         |                    | -     | 0.76  | 1     | mA   |
| I <sub>DDC(stb)</sub> | Standby mode core supply current            |                    | -     | 5.1   | 9     | mA   |
| I <sub>DDA</sub>      | analog supply current                       |                    | _     | 45    | 48    | mA   |
| I <sub>DDA(id)</sub>  | Idle mode analog supply current             |                    | _     | 0.87  | 1     | mA   |
| I <sub>DDA(pd)</sub>  | Power-down mode analog supply current       |                    | -     | 0.45  | 0.7   | mA   |
| I <sub>DDA(stb)</sub> | Standby mode analog supply current          |                    | -     | 809   | 950   | μΑ   |
| Digital inpu          | ts                                          |                    |       |       |       |      |
| RESET                 |                                             |                    |       |       |       |      |
| V <sub>IL</sub>       | LOW-level input voltage                     |                    | _     | _     | 1.00  | V    |
| V <sub>IH</sub>       | HIGH-level input voltage                    |                    | 1.85  | -     | _     | V    |
| V <sub>hys</sub>      | hysteresis voltage of Schmitt trigger input |                    | 0.44  | -     | 0.58  | V    |
| ILI                   | input leakage current                       | V <sub>1</sub> = 0 | -     | -     | 0.17  | μA   |
| R <sub>pd</sub>       | equivalent pull-down resistance             | $V_{I} = V_{DD}$   | 55.73 | 70.71 | 92.45 | kΩ   |

| SYMBOL           | PARAMETER                            | CONDITIONS                                         | MIN. | TYP. | MAX.  | UNIT |
|------------------|--------------------------------------|----------------------------------------------------|------|------|-------|------|
| HSYNC, VS        | SYNC                                 | -1                                                 |      | ļ    |       |      |
| V <sub>IL</sub>  | LOW-level input voltage              |                                                    | -    | -    | 0.96  | V    |
| VIH              | HIGH-level input voltage             |                                                    | 1.80 | _    | _     | V    |
| V <sub>hys</sub> | hysteresis of Schmitt trigger input  |                                                    | 0.40 | _    | 0.56  | V    |
| ILI              | Input leakage current                | $V_{I} = 0$ to $V_{DD}$                            | -    | -    | 0.00  | μA   |
| Digital outp     | outs                                 | •                                                  | •    | ·    |       |      |
| FRAME, VC        | DS                                   |                                                    |      |      |       |      |
| V <sub>OL</sub>  | LOW-level output voltage             | I <sub>OL</sub> = 3 mA                             | _    | _    | 0.13  | V    |
| V <sub>OH</sub>  | HIGH-level output voltage            | I <sub>OH</sub> = 3 mA                             | 2.84 | _    | _     | V    |
| t <sub>r</sub>   | output rise time                     | 10% to 90%;<br>C <sub>L</sub> = 70 pF              | 7.50 | 8.85 | 10.90 | ns   |
| t <sub>f</sub>   | output fall time                     | 10% to 90%;<br>C <sub>L</sub> = 70 pF              | 6.70 | 7.97 | 10.00 | ns   |
| COR (OPEN        | -DRAIN OUTPUT)                       |                                                    |      |      |       |      |
| V <sub>OL</sub>  | LOW-level output voltage             | I <sub>OL</sub> = 3 mA                             | -    | -    | 0.14  | V    |
| V <sub>OH</sub>  | HIGH-level pull-up output voltage    | I <sub>OL</sub> = –3 mA;<br>push-pull              | 2.84 | -    | -     | V    |
| V <sub>IL</sub>  | LOW-level input voltage              |                                                    | _    | _    | 0.00  | V    |
| V <sub>IH</sub>  | HIGH-level input voltage             |                                                    | 0.00 | -    | 5.50  | V    |
| ILI              | input leakage current                | $V_{I} = 0$ to $V_{DD}$                            | -    | -    | 0.12  | μA   |
| t <sub>r</sub>   | output rise time                     | 10% to 90%;<br>C <sub>L</sub> = 70 pF              | 7.20 | 8.64 | 11.10 | ns   |
| t <sub>f</sub>   | output fall time                     | 10% to 90%;<br>C <sub>L</sub> = 70 pF              | 4.90 | 7.34 | 9.40  | ns   |
| Digital inpu     | it/outputs                           | •                                                  |      |      |       | •    |
| Р0.0 то Р0.      | 4, Р0.7, Р1.0 то Р1.1, Р2.1 то Р2.7, | РЗ.0 то РЗ.7                                       |      |      |       |      |
| V <sub>IL</sub>  | LOW-level input voltage              |                                                    | _    | _    | 0.98  | V    |
| V <sub>IH</sub>  | HIGH-level input voltage             |                                                    | 1.78 | _    | _     | V    |
| V <sub>hys</sub> | hysteresis of Schmitt trigger input  |                                                    | 0.41 | _    | 0.55  | V    |
| I <sub>LI</sub>  | input leakage current                | $V_{I} = 0$ to $V_{DD}$                            | _    | _    | 0.01  | μA   |
| V <sub>OL</sub>  | LOW-level output voltage             | $I_{OL} = 4 \text{ mA}$                            | -    | -    | 0.18  | V    |
| V <sub>OH</sub>  | HIGH-level output voltage            | I <sub>OH</sub> = -4 mA<br>push-pull               | 2.81 | -    | 5.50  | V    |
| t <sub>r</sub>   | output rise time                     | 10% to 90%;<br>C <sub>L</sub> = 70 pF<br>push-pull | 6.50 | 8.47 | 10.70 | ns   |
| t <sub>f</sub>   | output fall time                     | 10% to 90%;<br>C <sub>L</sub> = 70 pF              | 5.70 | 7.56 | 10.00 | ns   |

| SYMBOL           | PARAMETER                                   | CONDITIONS                                          | MIN.  | TYP.  | MAX.   | UNIT |
|------------------|---------------------------------------------|-----------------------------------------------------|-------|-------|--------|------|
| P1.2, P1.3       | AND P2.0                                    |                                                     | -1    |       |        |      |
| V <sub>IL</sub>  | LOW-level input voltage                     |                                                     | _     | _     | 0.99   | V    |
| VIH              | HIGH-level input voltage                    |                                                     | 1.80  | _     | _      | V    |
| V <sub>hys</sub> | hysteresis voltage of Schmitt trigger input |                                                     | 0.42  | -     | 0.56   | V    |
| ILI              | input leakage current                       | $V_I = 0$ to $V_{DD}$                               | -     | -     | 0.02   | μA   |
| V <sub>OL</sub>  | LOW-level output voltage                    | $I_{OL} = 4 \text{ mA}$                             | -     | -     | 0.17   | V    |
| V <sub>OH</sub>  | HIGH-level output voltage                   | I <sub>OH</sub> = -4 mA<br>push-pull                | 2.81  | -     | 5.50   | V    |
| t <sub>r</sub>   | output rise time                            | 10% to 90%;<br>$C_{L} = 70 \text{ pF}$<br>push-pull | 7.00  | 8.47  | 10.50  | ns   |
| t <sub>f</sub>   | output fall time                            | 10% to 90%;<br>C <sub>L</sub> = 70 pF               | 5.40  | 7.36  | 9.30   | ns   |
| P0.5 AND P       | 0.6                                         |                                                     |       |       |        |      |
| V <sub>IL</sub>  | LOW-level input voltage                     |                                                     | -     | -     | 0.98   | V    |
| V <sub>IH</sub>  | HIGH-level input voltage                    |                                                     | 1.82  | _     | -      | V    |
| ILI              | input leakage current                       | $V_I = 0$ to $V_{DD}$                               | -     | -     | 0.11   | μA   |
| V <sub>hys</sub> | hysteresis voltage of Schmitt trigger input |                                                     | 0.42  | -     | 0.58   | V    |
| V <sub>OL</sub>  | LOW-level output voltage                    | I <sub>OL</sub> = 8 mA                              | -     | -     | 0.20   | V    |
| V <sub>OH</sub>  | HIGH-level output voltage                   | I <sub>OH</sub> = −8 mA<br>push-pull                | 2.76  | -     | 5.50   | V    |
| t <sub>r</sub>   | output rise time                            | 10% to 90%;<br>$C_{L} = 70 \text{ pF}$<br>push-pull | 7.40  | 8.22  | 8.80   | ns   |
| t <sub>f</sub>   | output fall time                            | 10% to 90%;<br>C <sub>L</sub> = 70 pF               | 4.20  | 4.57  | 5.20   | ns   |
| Р1.4 то Р1.      | 7 (OPEN-DRAIN)                              |                                                     |       |       |        |      |
| V <sub>IL</sub>  | LOW-level input voltage                     |                                                     | _     | -     | 1.08   | V    |
| V <sub>IH</sub>  | HIGH-level input voltage                    |                                                     | 1.99  | -     | _      | V    |
| V <sub>hys</sub> | hysteresis voltage of Schmitt trigger input |                                                     | 0.49  | -     | 0.60   | V    |
| ILI              | input leakage current                       | $V_I = 0$ to $V_{DD}$                               | -     | -     | 0.13   | μA   |
| V <sub>OL</sub>  | LOW-level output voltage                    | I <sub>OL</sub> = 8 mA                              | -     | -     | 0.35   | V    |
| t <sub>f</sub>   | output fall time                            | 10% to 90%;<br>C <sub>L</sub> = 70 pF               | 69.70 | 83.67 | 103.30 | ns   |

| SYMBOL                | PARAMETER                                             | CONDITIONS                                                   | MIN.             | TYP. | MAX.                   | UNIT |
|-----------------------|-------------------------------------------------------|--------------------------------------------------------------|------------------|------|------------------------|------|
| Analog inp            | uts                                                   | 1                                                            | -!               | - !  |                        | _I   |
| CVBS0 AND             | CVBS1                                                 |                                                              |                  |      |                        |      |
| V <sub>sync</sub>     | sync voltage amplitude                                |                                                              | 0.1              | 0.3  | 0.6                    | V    |
| V <sub>vid(p-p)</sub> | video input voltage amplitude<br>(peak-to-peak value) |                                                              | 0.7              | 1.0  | 1.4                    | V    |
| Z <sub>source</sub>   | source impedance                                      |                                                              | 0                | -    | 250                    | Ω    |
| V <sub>IH</sub>       | HIGH-level input voltage                              |                                                              | 3.0              | -    | V <sub>DDA</sub> + 0.3 | V    |
| CI                    | input capacitance                                     |                                                              | -                | -    | 10                     | pF   |
| IREF                  |                                                       |                                                              |                  |      |                        |      |
| R <sub>gnd</sub>      | resistor to ground                                    | resistor<br>tolerance 2%                                     | -                | 24   | -                      | kΩ   |
| ADC0 TO AD            | DC3                                                   |                                                              | ·                |      | ·                      |      |
| VIH                   | HIGH-level input voltage                              |                                                              | -                | -    | V <sub>DDA</sub>       | V    |
| Cl                    | input capacitance                                     |                                                              | _                | -    | 10                     | pF   |
| VPE                   |                                                       |                                                              | •                |      | •                      |      |
| V <sub>IH</sub>       | HIGH-level input voltage                              |                                                              | _                | _    | 9.0                    | V    |
| Analog out            | puts                                                  |                                                              |                  |      |                        |      |
| R, G AND B            | ·                                                     |                                                              |                  |      |                        |      |
| I <sub>OL</sub>       | Output current (black Level)                          | V <sub>DDA</sub> = 3.3 V                                     | -10              | _    | +10                    | μA   |
| I <sub>OH</sub>       | Output current (maximum<br>Intensity)                 | V <sub>DDA</sub> = 3.3 V<br>Intensity level<br>code = 31 dec | 6.0              | 6.67 | 7.3                    | mA   |
|                       | Output current (70% of full<br>Intensity)             | $V_{DDA} = 3.3 V$<br>Intensity level<br>code = 0 dec         | 4.2              | 4.7  | 5.1                    | mA   |
| R <sub>load</sub>     | load resistor to V <sub>SSA</sub>                     | resistor<br>tolerance 5%                                     | -                | 150  | -                      | Ω    |
| CL                    | load capacitance                                      |                                                              | -                | -    | 15                     | pF   |
| Analog inp            | ut/output                                             |                                                              | •                | •    | ·                      | •    |
| SYNC_FILT             | ER                                                    |                                                              |                  |      |                        |      |
| C <sub>sync</sub>     | storage capacitor to ground                           |                                                              | _                | 100  | _                      | nF   |
| V <sub>sync</sub>     | sync filter level voltage for nominal sync amplitude  |                                                              | 0.35             | 0.55 | 0.75                   | V    |
| Crystal osc           | illator                                               |                                                              |                  | · ·  |                        |      |
| XTALIN                |                                                       |                                                              |                  |      |                        |      |
| V <sub>IL</sub>       | LOW-level input voltage                               |                                                              | V <sub>SSA</sub> | _    | _                      | V    |
| VIH                   | HIGH-level input voltage                              |                                                              | -                | _    | V <sub>DDA</sub>       | V    |
| CI                    | input capacitance                                     |                                                              | _                |      | 10                     | pF   |

## SAA55xx

| SYMBOL            | PARAMETER                     | CONDITIONS               | MIN. | TYP.   | MAX.                    | UNIT |
|-------------------|-------------------------------|--------------------------|------|--------|-------------------------|------|
| XTALOUT           |                               | •                        | _    |        | I                       |      |
| Co                | output capacitance            |                          | -    | -      | 10                      | pF   |
| Crystal spe       | cification; notes 2 and 3     |                          | •    |        | •                       |      |
| f <sub>xtal</sub> | nominal frequency             | fundamental mode         | -    | 12     | -                       | MHz  |
| CL                | crystal load capacitance      |                          | -    | -      | 30                      | pF   |
| C <sub>1</sub>    | crystal motional capacitance  | T <sub>amb</sub> = 25 °C | _    | -      | 20                      | fF   |
| R <sub>r</sub>    | resonance resistance          | T <sub>amb</sub> = 25 °C | _    | -      | 60                      | Ω    |
| C <sub>osc</sub>  | capacitors at XTALIN, XTALOUT | T <sub>amb</sub> = 25 °C | _    | note 4 | _                       | pF   |
| C <sub>0</sub>    | crystal holder capacitance    | T <sub>amb</sub> = 25 °C | _    | -      | note 5                  | pF   |
| T <sub>xtal</sub> | temperature range             |                          | -20  | +25    | +85                     | °C   |
| Xj                | adjustment tolerance          | T <sub>amb</sub> = 25 °C | -    | -      | $\pm 50 \times 10^{-6}$ |      |
| X <sub>d</sub>    | drift                         |                          | _    | _      | ±100 × 10 <sup>-6</sup> |      |

#### Notes

- 1. Peripheral current is dependent on external components and voltage levels on I/Os.
- 2. Crystal order number 4322 143 05561.
- 3. If the 4322 143 05561 crystal is not used, then the formulae in the crystal specification should be used. Where  $C_{IO} = 7 \text{ pF}$ , the mean of the capacitances due to the chip at XTALIN and at XTALOUT.  $C_{ext}$  is a value for the mean of the stray capacitances due to the external circuit at XTALIN and XTALOUT. The maximum value for the crystal holder capacitance is to ensure start-up,  $C_{osc}$  may need to be reduced from the initially selected value.
- 4.  $C_{osc(typ)} = 2C_L C_{IO} C_{ext}$
- 5.  $C_{0(max)} = 35 \frac{1}{2}(C_{osc} + C_{IO} + C_{ext})$

## SAA55xx

| Table 35 | I <sup>2</sup> C-bus | characteristics |
|----------|----------------------|-----------------|
|----------|----------------------|-----------------|

|                     | DAD AMETED                                                                                   | FAST-M | FAST-MODE I <sup>2</sup> C-bus |      |  |
|---------------------|----------------------------------------------------------------------------------------------|--------|--------------------------------|------|--|
| SYMBOL              | PARAMETER                                                                                    | MIN.   | MAX.                           | UNIT |  |
| f <sub>SCL</sub>    | SCL clock frequency                                                                          | 0      | 400                            | kHz  |  |
| t <sub>BUF</sub>    | bus free time between a STOP and START condition                                             | 1.3    | -                              | μs   |  |
| t <sub>HD;STA</sub> | hold time (repeated) START condition. After this period, the first clock pulse is generated. | 0.6    | -                              | μs   |  |
| t <sub>LOW</sub>    | LOW period of the SCL clock                                                                  | 1.3    | -                              | μs   |  |
| t <sub>HIGH</sub>   | HIGH period of the SCL clock                                                                 | 0.6    | -                              | μs   |  |
| t <sub>SU;STA</sub> | set-up time for a repeated START condition                                                   | 0.6    | -                              | μs   |  |
| t <sub>HD;DAT</sub> | data hold time; notes 1 and 2                                                                | 0      | 0.9                            | μs   |  |
| t <sub>SU;DAT</sub> | data set-up time, note 3                                                                     | 100    | -                              | ns   |  |
| t <sub>r</sub>      | rise time of both SDA and SCL signals; note 4                                                | 20     | 300                            | ns   |  |
| t <sub>f</sub>      | fall time of both SDA and SCL signals; note 4                                                | 20     | 300                            | ns   |  |
| t <sub>su;sтo</sub> | set-up time for STOP condition                                                               | 0.6    | -                              | μs   |  |
| C <sub>b</sub>      | capacitive load for each bus line                                                            | -      | 400                            | pF   |  |

#### Notes

- A device must internally provide a hold time of at least 300 ns for the SDA signal (referred to the V<sub>IL(min)</sub> of the SCL signal) in order to bridge the undefined region of the falling edge of SCL.
- 2. The maximum f<sub>HD;DAT</sub> has only to be met if the device does not stretch the LOW period t<sub>LOW</sub> of the SCL signal.
- 3. A fast-mode I<sup>2</sup>C-bus device can be used in a standard mode I<sup>2</sup>C-bus system but the requirement  $t_{SU;DAT} \ge 250$  ns must then be met. This will automatically be the case if the device does not stretch the LOW period of the SCL signal. If such a device does stretch the LOW period of the SCL signal, it must output the next data bit to the SDA line  $t_{r(max)} + t_{SU;DAT} = 1000 + 250 + 1250$  ns (according to the standard mode I<sup>2</sup>C-bus specification) before the SCL line is released.
- 4.  $C_b$  = total capacitance of one bus line in pF.

### 23 QUALITY AND RELIABILITY

This device will meet Philips Semiconductors General Quality Specification for Business group "Consumer Integrated Circuits SNW-FQ-611-Part E". The principal requirements are shown in Tables 36 to 39.

#### 23.1 Group A

 Table 36
 Acceptance tests per lot

| TEST       | REQUIREMENTS                |
|------------|-----------------------------|
| Mechanical | cumulative target: <80 ppm  |
| Electrical | cumulative target: <100 ppm |

#### 23.2 Group B

 Table 37 Processability tests (by package family)

| TEST                   | REQUIREMENTS     |
|------------------------|------------------|
| Solderability          | 0/16 on all lots |
| Mechanical             | 0/15 on all lots |
| Solder heat resistance | 0/15 on all lots |

#### 23.3 Group C

Table 38 Reliability tests (by process family)

| TEST                            | CONDITIONS                                                                       | REQUIREMENTS                         |
|---------------------------------|----------------------------------------------------------------------------------|--------------------------------------|
| Operational life                | 168 hours at T <sub>j</sub> = 150 °C                                             | <1000 FPM at T <sub>j</sub> = 150 °C |
| Humidity life                   | temperature, humidity, bias<br>1000 hours, 85 °C, 85% RH<br>(or equivalent test) | <2000 FPM                            |
| Temperature cycling performance | T <sub>stg(min)</sub> to T <sub>stg(max)</sub>                                   | <2000 FPM                            |

#### Table 39 Reliability tests (by device type)

| TEST             | CONDITIONS                             | REQUIREMENTS                                   |
|------------------|----------------------------------------|------------------------------------------------|
| ESD and latch-up | ESD Human body model 100 pF,<br>1.5 kΩ | 2000 V                                         |
|                  | ESD Machine model 200 pF, 0 $\Omega$   | 200 V                                          |
|                  | latch-up                               | 100 mA, $1.5 \times V_{DD}$ (absolute maximum) |

#### Notes to Tables 36 to 39

1. ppm = fraction of defective devices, in parts per million.

2. FPM = fraction of devices failing at test condition, in Failures Per Million.

# On-Screen Enhanced TV microcontrollers Display (OSD) with

# SAA55xx





2000 Feb 23

\_

9

Preliminary specification

#### Preliminary specification

## Enhanced TV microcontrollers with On-Screen Display (OSD)

## 25 EMC GUIDELINES

Optimization of circuit return paths and minimisation of common mode emission will be assisted by using a double sided printed-circuit board (PCB) with low inductance ground plane.

On a single sided PCB local ground plane under the whole IC should be present as shown in Fig.41. This should be connected by the widest possible connection back to the PCB ground connection, and bulk electrolytic decoupling capacitor. It should preferably not connect to other grounds on the way and no wire links should be present in this connect. The use of wire links increases ground bounce by introducing inductance into the ground.

The supply pins can be decoupled at the pin to the ground plane under the IC. This is easily accomplished using surface mount capacitors, which are more effective than leaded components at high frequency. Using a device socket will unfortunately add to the area and inductance of the external bypass loop.

A ferrite bead or inductor with resistive characteristics at high frequencies may be utilised in the supply line close to the decoupling capacitor to provide a high-impedance. To prevent pollution by conduction onto the signal lines (which may then radiate) signals connected to the  $V_{DD}$  supply via a pull-up resistor should not be connected to the IC side of this ferrite component.

OSCGND should be connected only to the crystal load capacitors and not the local or circuit GND.

Physical connection distances to associated active devices should be short.

Output traces should be routed with close proximity to mutually coupled ground return paths.



SAA55xx

## 26 REFERENCES

- 1. 80C51 Based 8-Bit Microcontrollers. Philips Semiconductors (ref. IC20).
- 2. The I<sup>2</sup>C-bus and how to use it (including specification). Philips Semiconductors.
- 3. Enhanced Teletext Specification European Telecommunication Standard ETS 300 706.
- 4. World System Teletext and Data Broadcasting System. DTI. December 1987 (525 WST only).
- 5. Specification of the Domestic Video Programme Delivery Control System (PDC); EBU Tech. 3262-E.
- 6. Recommended Practise for Line 21 Data Service EIA-608.

SAA55xx

## Enhanced TV microcontrollers with On-Screen Display (OSD)

## 27 PACKAGE OUTLINES

### SDIP52: plastic shrink dual in-line package; 52 leads (600 mil)



SOT247-1



## SAA55xx

### 28 SOLDERING

## 28.1 Introduction to soldering through-hole mount packages

This text gives a brief insight to wave, dip and manual soldering. A more in-depth account of soldering ICs can be found in our *"Data Handbook IC26; Integrated Circuit Packages"* (document order number 9398 652 90011).

Wave soldering is the preferred method for mounting of through-hole mount IC packages on a printed-circuit board.

#### 28.2 Soldering by dipping or by solder wave

The maximum permissible temperature of the solder is 260 °C; solder at this temperature must not be in contact with the joints 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.

### 28.3 Manual soldering

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

#### 28.4 Suitability of through-hole mount IC packages for dipping and wave soldering methods

| PACKAGE                   | SOLDERING METHOD |                         |
|---------------------------|------------------|-------------------------|
|                           | DIPPING          | WAVE                    |
| DBS, DIP, HDIP, SDIP, SIL | suitable         | suitable <sup>(1)</sup> |

#### Note

1. For SDIP packages, the longitudinal axis must be parallel to the transport direction of the printed-circuit board.

## SAA55xx

## 29 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 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.

#### **30 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.

## 31 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.

SAA55xx

NOTES

SAA55xx

NOTES

## Philips Semiconductors – a worldwide company

Argentina: see South America Australia: 3 Figtree Drive, HOMEBUSH, NSW 2140, Tel. +61 2 9704 8141, Fax. +61 2 9704 8139 Austria: Computerstr. 6, A-1101 WIEN, P.O. Box 213, Tel. +43 1 60 101 1248. Fax. +43 1 60 101 1210 Belarus: Hotel Minsk Business Center, Bld. 3, r. 1211, Volodarski Str. 6, 220050 MINSK, Tel. +375 172 20 0733, Fax. +375 172 20 0773 Belgium: see The Netherlands Brazil: see South America Bulgaria: Philips Bulgaria Ltd., Energoproject, 15th floor, 51 James Bourchier Blvd., 1407 SOFIA, Tel. +359 2 68 9211, Fax. +359 2 68 9102 Canada: PHILIPS SEMICONDUCTORS/COMPONENTS, Tel. +1 800 234 7381, Fax. +1 800 943 0087 China/Hong Kong: 501 Hong Kong Industrial Technology Centre, 72 Tat Chee Avenue, Kowloon Tong, HONG KONG, Tel. +852 2319 7888, Fax. +852 2319 7700 Colombia: see South America Czech Republic: see Austria Denmark: Sydhavnsgade 23, 1780 COPENHAGEN V, Tel. +45 33 29 3333, Fax. +45 33 29 3905 Finland: Sinikalliontie 3, FIN-02630 ESPOO, Tel. +358 9 615 800, Fax. +358 9 6158 0920 France: 51 Rue Carnot, BP317, 92156 SURESNES Cedex, Tel. +33 1 4099 6161, Fax. +33 1 4099 6427 Germany: Hammerbrookstraße 69, D-20097 HAMBURG, Tel. +49 40 2353 60, Fax. +49 40 2353 6300 Hungary: see Austria India: Philips INDIA Ltd, Band Box Building, 2nd floor, 254-D, Dr. Annie Besant Road, Worli, MUMBAI 400 025, Tel. +91 22 493 8541, Fax. +91 22 493 0966 Indonesia: PT Philips Development Corporation, Semiconductors Division, Gedung Philips, Jl. Buncit Raya Kav.99-100, JAKARTA 12510, Tel. +62 21 794 0040 ext. 2501, Fax. +62 21 794 0080 Ireland: Newstead, Clonskeagh, DUBLIN 14, Tel. +353 1 7640 000, Fax. +353 1 7640 200 Israel: RAPAC Electronics, 7 Kehilat Saloniki St, PO Box 18053, TEL AVIV 61180, Tel. +972 3 645 0444, Fax. +972 3 649 1007 Italy: PHILIPS SEMICONDUCTORS, Via Casati, 23 - 20052 MONZA (MI), Tel. +39 039 203 6838. Fax +39 039 203 6800 Japan: Philips Bldg 13-37, Kohnan 2-chome, Minato-ku, TOKYO 108-8507, Tel. +81 3 3740 5130, Fax. +81 3 3740 5057 Korea: Philips House, 260-199 Itaewon-dong, Yongsan-ku, SEOUL, Tel. +82 2 709 1412, Fax. +82 2 709 1415 Malaysia: No. 76 Jalan Universiti, 46200 PETALING JAYA, SELANGOR, Tel. +60 3 750 5214, Fax. +60 3 757 4880 Mexico: 5900 Gateway East, Suite 200, EL PASO, TEXAS 79905, Tel. +9-5 800 234 7381, Fax +9-5 800 943 0087

Middle East: see Italy

For all other countries apply to: Philips Semiconductors, International Marketing & Sales Communications, Building BE-p, P.O. Box 218, 5600 MD EINDHOVEN, The Netherlands, Fax. +31 40 27 24825

Netherlands: Postbus 90050, 5600 PB EINDHOVEN, Bldg. VB, Tel. +31 40 27 82785, Fax. +31 40 27 88399 New Zealand: 2 Wagener Place, C.P.O. Box 1041, AUCKLAND, Tel. +64 9 849 4160, Fax. +64 9 849 7811 Norway: Box 1, Manglerud 0612, OSLO, Tel. +47 22 74 8000, Fax. +47 22 74 8341 Pakistan: see Singapore Philippines: Philips Semiconductors Philippines Inc., 106 Valero St. Salcedo Village, P.O. Box 2108 MCC, MAKATI, Metro MANILA, Tel. +63 2 816 6380, Fax. +63 2 817 3474 Poland: Al.Jerozolimskie 195 B, 02-222 WARSAW, Tel. +48 22 5710 000, Fax. +48 22 5710 001 Portugal: see Spain Romania: see Italy Russia: Philips Russia, UI. Usatcheva 35A, 119048 MOSCOW, Tel. +7 095 755 6918, Fax. +7 095 755 6919 Singapore: Lorong 1, Toa Payoh, SINGAPORE 319762, Tel. +65 350 2538, Fax. +65 251 6500 Slovakia: see Austria Slovenia: see Italy South Africa: S.A. PHILIPS Pty Ltd., 195-215 Main Road Martindale, 2092 JOHANNESBURG, P.O. Box 58088 Newville 2114, Tel. +27 11 471 5401, Fax. +27 11 471 5398 South America: Al. Vicente Pinzon, 173, 6th floor, 04547-130 SÃO PAULO, SP, Brazil Tel. +55 11 821 2333. Fax. +55 11 821 2382 Spain: Balmes 22, 08007 BARCELONA Tel. +34 93 301 6312, Fax. +34 93 301 4107 Sweden: Kottbygatan 7, Akalla, S-16485 STOCKHOLM, Tel. +46 8 5985 2000, Fax. +46 8 5985 2745 Switzerland: Allmendstrasse 140, CH-8027 ZÜRICH, Tel. +41 1 488 2741 Fax. +41 1 488 3263 Taiwan: Philips Semiconductors, 6F, No. 96, Chien Kuo N. Rd., Sec. 1, TAIPEI, Taiwan Tel. +886 2 2134 2886, Fax. +886 2 2134 2874 Thailand: PHILIPS ELECTRONICS (THAILAND) Ltd. 209/2 Sanpavuth-Bangna Road Prakanong, BANGKOK 10260, Tel. +66 2 745 4090, Fax. +66 2 398 0793 Turkey: Yukari Dudullu, Org. San. Blg., 2.Cad. Nr. 28 81260 Umraniye, ISTANBUL, Tel. +90 216 522 1500, Fax. +90 216 522 1813 Ukraine: PHILIPS UKRAINE, 4 Patrice Lumumba str., Building B, Floor 7, 252042 KIEV, Tel. +380 44 264 2776, Fax. +380 44 268 0461 United Kingdom: Philips Semiconductors Ltd., 276 Bath Road, Hayes, MIDDLESEX UB3 5BX, Tel. +44 208 730 5000, Fax. +44 208 754 8421 United States: 811 East Arques Avenue, SUNNYVALE, CA 94088-3409, Tel. +1 800 234 7381, Fax. +1 800 943 0087 Uruguay: see South America

Vietnam: see Singapore

Yugoslavia: PHILIPS, Trg N. Pasica 5/v, 11000 BEOGRAD, Tel. +381 11 3341 299, Fax.+381 11 3342 553

Internet: http://www.semiconductors.philips.com

All rights are reserved. Reproduction in whole or in part is prohibited without the prior written consent of the copyright owner. The information presented in this document does not form part of any quotation or contract, is believed to be accurate and reliable and may be changed without notice. No liability will be accepted by the publisher for any consequence of its use. Publication thereof does not convey nor imply any license under patent- or other industrial or intellectual property rights.

Printed in The Netherlands

© Philips Electronics N.V. 2000

753504/02/pp100

Date of release: 2000 Feb 23

Document order number: 9397 750 06787

SCA 69

Let's make things better.



