• Programmable width and height of the OSD window,
built from maximum 1152 characters
• 8 different colours for foreground and background
inclusive transparent colours
• Overlay port for external OSD controller.
1.4Video output
• Single pixel/clock (24-bit) or double pixel/clock (48-bit)
digital RGB output
• Generation of synchronization and validation signals for
the Thin Film Transistor (TFT) display
• Frame rate control (temporal dithering) for displaying
true colour graphics on high colour displays
• Free programmable timing for displays of several
manufacturers.
1.5Memory interface
• Support of both 1M × 16 SDRAM, 256k × 32 SGRAM or
128k × 32 SGRAM devices
• Maximum memory clock frequency of 125 MHz
• Scalable memory size built of either 2, 3 or 4 SDRAM,
or of 1 or 2 SGRAM devices
• Special mode for operation without external memory.
1.6Miscellaneous
• Internal Phase-Locked Loop (PLL) for memory and
panel clock generation from the system clock
• I2C-bus interface with 2 selectable addresses
• Boundary scan test circuit and Joint Test Action Group
(JTAG) test controller
• Pin compatible to SAA6721E
• Programming compatible to SAA6721E.
1999 Aug 253
Philips SemiconductorsPreliminary specification
XGA RGB to TFT graphics engineSAA6712E
2GENERAL DESCRIPTION
The SAA6712E is a graphics engine, which converts
digital RGB data into video signals suitable for TFT
displays. It supports SXGA input resolution as well as true
colour. Independent horizontal and vertical up and
downscaling can display the input data arbitrarily on the
connected TFT display. Auto-scan capability allows the
applied graphics mode to be detected.
The SAA6712E must be embedded into a system
containing a microcontroller with an I2C-bus serial
interface. For auto-scan capabilities a frame buffer built
from SGRAM or SDRAM is needed. The size of this frame
buffer depends on the maximumresolution and bandwidth
neededfor the application. For converting theanalog RGB
stream into a digital data stream one or two ADCs with
3 channels each for R, G and B are needed.
Overlay signals can be generated either by an internal
OSD generator or supplied via the overlay port from an
external OSD controller.
3QUICK REFERENCE DATA
SYMBOLPARAMETERMIN.TYP.MAX.UNIT
V
I
DDD
V
V
DDD
i
o
digital supply voltage3.03.33.6V
digital supply current−600840mA
input voltagesLVTTL compatible
output voltages memory portLVTTL compatible
output voltages TFT portCMOS compatible
1. Generally all inputs are 5 V tolerant TTL inputs. All outputs are CMOS, except the memory interface ports, which are
LVTTL compatible.
2. Connect to ground when not using the JTAG controller.
7FUNCTIONAL DESCRIPTION
7.1Data path
Input video data is sampled either as RGB data in single
pixels from only one ADC or in double pixels in interleaved
formatfrom two ADCs. The clock for sampling the data will
always be provided from external circuitry. The video
stream will be adapted from the input frame rate to the
output frame rate needed by the panel. Therefore a frame
buffer built of SDRAMs or SGRAMs is used. If the panel
supports the incoming frame rate from the RGB port, the
adaption can be done without external memory.
If zooming must be performed the upscaler behind the
memory interface will be enabled. For downscaling the
downscaler in front of the memory interface in the data
path will be used. A colour correction can be done via a
look-up table. The resulting video stream can now be
positioned elsewhere in the output data stream by the
panning unit. If an external OSD controller is embedded
into the system, its OSD window will be put into the video
stream by the OSD overlay port. Additionally the internal
OSD will be inserted in the next stage. The temporal
dithering allows true colour pictures to be displayed on
high colour panels. The output interface provides the
timing and control signals necessary for the connected
panel.
Pin
PORTI/O
(1)
DESCRIPTION
7.2System clocks
7.2.1INPUT INTERFACE CLOCK (VCLK)
This clock is used for sampling the incoming RGB data
stream. In RGB mode this clock varies from
25 to 150 MHz in single ADC mode. If two ADCs are used
the RGB input clock is between 12.5 and 75 MHz.
The RGB clock can be generated by the external ADCs or
an external video PLL.
7.2.2MEMORY INTERFACE CLOCK (MCLKI)
The memory clock is the synchronous clock for the
external frame buffer. Depending on the bandwidth
needed by the application, and the connected SDRAM or
SGRAM devices, the clock varies from 83 to 125 MHz.
It can be generated internally by the PLL from the system
clock (CLK), or by an external quartz oscillator.
If the internal PLL is used, the memory clock frequency
can be derived from the following formula:
f_memory
Where N = pre-divider ratio and f_system = clock at
pin CLK.
f_system
----------------------- N
16×=
1999 Aug 2513
Philips SemiconductorsPreliminary specification
XGA RGB to TFT graphics engineSAA6712E
7.2.3I2C-BUS INTERFACE CLOCK (SCL)
This clock drives the interface to the external
microcontroller. Its frequency range is from
100 kHz to 1 MHz.
7.2.4SYSTEM CLOCK (CLK)
This clock is used to drive the internal PLL. The frequency
range is from 24 to 50 MHz.
7.2.5TFT PANEL CLOCK (PCLK)
This clock is the timing reference for the panel.
The frequency is the same as the system clock, or it can
be generated from the internal PLL by using the following
formula:
f_tft
f_system
----------------------- N
32
×=
-----M
Where N = pre-divider ratio and M = post-divider ratio.
7.3RGB input port
The RGB input port can operate in two modes; single pixel
mode (24 bits) and double pixel mode (48 bits). For single
pixel mode only ports VPA7 to VPA0, VPB7 to VPB0, and
VPC7 to VPC0 are internally sampled. For double pixel
mode two pixels must be provided at the RGB input port.
Therefore ports VPD7 to VPD0, VPE7 to VPE0, and
VPF7 to VPF0 are also needed.
The VPA/B/C ports are sampled on the rising edge of the
RGB input clock (VCLK), and the VPD/E/F ports on the
falling edge (see Fig.3).
The synchronization pulses from the graphics card are
used to identify the frame outline. The vertical
synchronization pulse is connected to pin VVS, and the
horizontal synchronization pulse is connected to pin VHS.
For calibrating the connected Analog-to-Digital Converter
(ADC) the SAA6712E delivers a clamp pulse at
pin CLAMP, and a gain correction pulse at pin GAINC
(see Fig.4).
The sample window of the RGB input port is controlled by
four counters; horizontal and vertical offset, and horizontal
and vertical window size.
The offset counters start at the inactive or second edge of
their corresponding synchronization signal.
handbook, full pagewidth
VCLK
VPA/B/C
VPD/E/F
Fig.3 RGB input port timing.
1999 Aug 2514
MHB243
Philips SemiconductorsPreliminary specification
XGA RGB to TFT graphics engineSAA6712E
handbook, full pagewidth
VHS
RGB data
GAINC
CLAMP
Fig.4 Clamp and gain correction pulses.
7.4TFT output port
The TFT output port consists of two pixel ports (A and B),
each containing red, green and blue colour information
with a resolution of 8 bits per colour. The first pixel port is
mapped to PAR7 to PAR0, PAG7 to PAG0, and
PAB7 to PAB0. The second port is mapped to
PBR7 to PBR0, PBG7 to PBG0, and PBB7 to PBB0.
The vertical and horizontal synchronization signals are
mapped to pins PVS and PHS. A data validation signal
framing visible pixels is available at pin PDE.
Allof the above mentioned signalsare synchronized to the
output clock at pin PCLK. The active edge of this clock is
programmable.
blanking
MHB244
125 MHz. This clockcan be providedeither by the internal
PLL, or externally be applied to pin MCLKI.
The memory data bus is split into 4 ports:
port 0 (DQ0 to DQ15), port 1 (DQ16 to DQ31),
port 2 (DQ32 to DQ47) and port 3 (DQ48 to DQ63).
To adapt the external memory to the needs of the
application by means of memory size and bandwidth, it is
possible to scale the external memory by using only the
number of subsequent ports needed to build up the frame
buffer and to achieve the memory bandwidth. As a second
step for bandwidth optimization several speed grades of
memory devices can be used.
7.5.1SDRAM MEMORY CONFIGURATION
7.4.1SINGLE PIXEL MODE
The single pixel mode is designed to support TFT panels
with single pixel input, and for direct connection of panel
link transmitters. Only the first pixel port PAR7 to PAR0,
PAG7 to PAG0, and PAB7 to PAB0 is used. The data is
applied at double the frequency in comparison to the
double pixel output mode.
7.4.2DOUBLE PIXEL MODE
Thedoublepixel mode is used for direct connection of TFT
panels with double pixel input. Both output ports are used.
Thefirst pixel is applied atport A, and the second atport B.
7.5Memory port
The memory port connects the SAA6712E to the external
frame buffer. This frame memory can be built from either
1M × 16 SDRAM or 256k × 32 SGRAM devices.
Supported are RAM devices with clock frequencies up to
1999 Aug 2515
SDRAMs are available in sizes from 16 Mbits. For this
application a wide data bus is required, so that at least
1M × 16 devices must be used. To achieve the desired
bandwidth, 2 to 4 devices must be used in parallel, which
resultsin a frame buffer size of 4 to 8 Mbytes.But only half
of this memory will be used by the SAA6712E.
The memory port of the SAA6712E can be divided into
4 SDRAM channels. Each channel is 16 bits wide, and
provides in High Speed Channel (HSC) mode with a
125 MHz memory clock and an effective bandwidth of
228 Mbits/s. A Medium Speed Channel (MSC) with a
100 MHz memory clock gives an effective bandwidth of
182 Mbits/s, 91% effective bandwidth assumed.
Table 2 gives the channel configuration for several input
and panel resolutions.
7.5.2SGRAM MEMORY CONFIGURATION
SGRAMdevicesorganizedto256k × 32 bits are available,
and feature the wide data bus for high speed applications.
With these devices a frame buffer can be built, without
wasting memory because of bandwidth. In case of
SGRAM usage, the memory data bus of the SAA6712E
can be split into 2 channels of 32 bits each.
Each channel gives, in HSC mode with 125 MHz clock
frequency, an effective bandwidth of 456 Mbits/s; and in
MSC mode, with 100 MHz clock speed, an effective
bandwidth of 364 Mbits/s.
Table 3 gives the channel configuration for several input
and panel resolutions.
411 Mbits/s
bandwidth;
1 × HSC or
2 × MSC
452 Mbits/s
bandwidth;
2 × HSC or
3 × MSC
452 Mbits/s
bandwidth;
1 × HSC or
2 × MSC
475 Mbits/s
bandwidth;
3 × HSC or
3 × MSC
475 Mbits/s
bandwidth;
2 × HSC or
2 × MSC
540 Mbits/s
bandwidth;
3 × HSC or
3 × MSC
540 Mbits/s
bandwidth;
2 × HSC or
2 × MSC
Note
1. 36 MHz clock frequency.
1999 Aug 2516
Philips SemiconductorsPreliminary specification
XGA RGB to TFT graphics engineSAA6712E
7.6I2C-bus interface
This serial interface consists of only two signals, the serial
clock line (SCL) and the serial data line (SDA).
The maximum supported frequency on this bus is 1 MHz.
Spikes with a maximum pulse length of 50 ns are
suppressed by the internal input filter.
The SAA6712E operates as a slave and cannot initiate
any data transfer, so the clock line is always input. Via the
dataline, data is transmitted and received, sothis pin must
be input/output. The SCL and SDA lines are driven by
open-drain stages and pull-up resistors. When a logic 0 is
applied, the bus is set to ground level via the output
buffers. When a logic 1 is applied, the output buffer
switchesto 3-state and the pull-up resistors pullthe bus up
to +5 V.
Datatransfer changes on SDA are allowed only whenSCL
is LOW. Data is sampled on the positive edge of SCL.
In Idle state the output buffers are in 3-state, and the bus
is HIGH. A data transfer must be initiated by an I2C-bus
masterdevice. This is done by sending a STARTcondition
whenSDAchangesfromHIGHtoLOWwhenSCLisHIGH
(see Fig.5). The device address of the SAA6712E must
then be sent with the desired I/O direction.
If the SAA6712E reads its device address, it
acknowledges this by sending a single bit ACK to the
master. If write mode was selected, the master sends the
register address to be written and then the data bytes.
If read mode was selected, the SAA6712E sends the data
bytes starting from the last address accessed either by
write command or the next address at a read command.
All byte transfers are acknowledged from the receiving
device. The data transfer is aborted by sending a STOP
condition, when SDA changes from LOW to HIGH when
SCL is HIGH (see Fig.6).
If a new address has to be read or written, it is possible to
send a new START condition without a preceding STOP
condition. In this case the bus is still occupied by the
master, and it can initiate a new data transfer. This is
usefulfor read activities, where atfirst the register address
must be sent in write mode and after that a read command
will be sent to read data from this and following addresses.
If the data transfer was a read transferand the master was
receiver, the master must not generate an acknowledge
before the STOP condition.
handbook, full pagewidth
SCL
SDA
handbook, full pagewidth
SCL
SDAD7D4D5D6D1D0ACKD2D3A/A
START condition
A4A1A2A3A6A5ACKR/W
A0R5R7R6
Fig.5 Start of a data transfer.
Fig.6 End of a data transfer.
acknowledge
D1D0
acknowledge/
not acknowledge
MHB248
STOP condition
MHB249
1999 Aug 2517
Philips SemiconductorsPreliminary specification
XGA RGB to TFT graphics engineSAA6712E
7.7Scaling algorithm
The SAA6712E features different scaling engines for up
and downscaling, for both horizontal and vertical
processing. The horizontal scaling engines are
independent from each other. The vertical scaling engines
share the line buffer, so they cannot operate in parallel.
7.7.1UPSCALING
The upscaling engine is used for enlarging the incoming
video frames. The magnification can be programmed
individually for horizontal and vertical scaling.
The maximum scaling factor for both directions is 64.
The implemented filter algorithm (see Fig.7) uses
interpolation with pixel enhancement, based on a free
programmable transition function. It is therefore possible
to define the transition between two calculated pixels to
obtain different sharpness characteristics. This transition
function must be defined in the 7 bits × 64 look-up table,
withanumberrangingfrom0 to 64. Different functions can
be programmed for horizontal and vertical scaling.
7.7.2DOWNSCALING
The downscaling engine is used for reducing the incoming
RGB data stream, i.e. for displaying high resolution input
frames on panels with a smaller resolution.
The scaling ratio can be programmed independently for
both horizontal and vertical downscaling units.
The algorithm uses pixel accumulation, achieving a
minimum scaling factor of1⁄64.
handbook, full pagewidth
AB
O
(1) The linear interpolation results in smoothing the sharp edges of the original picture if a pixel must be calculated.
(2) Some kind of1⁄xfunction results in sharper edges, because of the smaller transition interval.
(3) Phase correct pixel repetition can be done with this function.
intensity of
output pixel O
100% A,
0% B
0% A,
100% B
100% A,
0% B
(3)
(2)
0% A,
100% B
Fig.7 Interpolation function definition.
(1)
MHB250
ratio between
input pixels A, B
1999 Aug 2518
Philips SemiconductorsPreliminary specification
XGA RGB to TFT graphics engineSAA6712E
8SYSTEM DESCRIPTION
8.1Programming registers
The SAA6712E is a highly integrated device with many
features. To get the desired functionality and performance
it must be programmed correctly. In general, before
programming, the device must be switched to the internal
reset state to prevent unwanted functions while changing
the registers.
After writing to all registers the internal reset can be
released. There are some registers (mainly offset
counters) that can be changed during data processing
without an internal reset. All accesses to the on screen
display can be done during data processing.
Table 5 Programming register overview
ADDRESS R/WD7D6D5D4D3D2D1D0
State
0Rreserved
1Rreserved
2R/W iic_test_register[7 to 0]
3Rintr
RGB mode detection
4Rpos_
5Rv_lines[7 to 0]
6Rv_lines[10 to 8]
7Rh_clocks[7 to 0]
8Rh_clocks[11 to 8]
RGB auto-adjustment
9Wref_line[7 to 0]
10Wref_line[10 to 8]
11Wref_pixel[7 to 0]
12Wref_pixel[11 to 8]
13Wref_colour[7 to 0]
14Rref_pixel_red[7 to 0]
15Rref_pixel_green[7 to 0]
16Rref_pixel_blue[7 to 0]
17Rblack_lines[7 to 0]
18Rblack_pixels[7 to 0]
19Rblack_
20Rnon_black_lines[7 to 0]
21Rnon_black_lines[10 to 8]
Table 4 I
MSBLSB
011101SADR/
When bit SAD = 0 the address is 74H; when bit SAD = 1
the address is 76H.
Table 5 shows the programming model.
2
C-bus device address
pos_
vsync
hsync
no_
vsync
no_
hsync
pixels[8]
W
1999 Aug 2519
Philips SemiconductorsPreliminary specification
XGA RGB to TFT graphics engineSAA6712E
ADDRESS R/WD7D6D5D4D3D2D1D0
22Rnon_black_pixels[7 to 0]
23Rnon_black_pixels[11 to 8]
General configuration
24Wintr_clearsingle_
adc_mode
25Wfrc_onblank_
Clock distribution
26Wpor_mclkpre_div_
enable
27Wpre_div_clock_p_high[3 to 0]pre_div_clock_p_low[3 to 0]
28Wpre_div_clock_n_high[3 to 0]pre_div_clock_n_low[3 to 0]
29Wpre_div_clock_n_offs[3 to 0]
30Wpost_div_clock_p_high[3 to 0]post_div_clock_p_low[3 to 0]
31Wpost_div_clock_n_high[3 to 0]post_div_clock_n_low[3 to 0]
32Wpost_div_clock_n_offs[3 to 0]
Input interface
33Win_form_
on
34Wnot used
35Wv_offset[7 to 0]
36Wv_offset[10 to 8]
37Wh_offset[7 to 0]
38Wh_offset[11 to 8]
39Wv_length[7 to 0]
40Wv_length[10 to 8]
41Wh_length[7 to 0]
42Wh_length[11 to 8]
43Wclamp_on[7 to 0]
44Wclamp_off[7 to 0]
45Wgainc_on_delay[7 to 0]
46Wgainc_off_delay[7 to 0]
Colour correction
47Wred_proggreen_
48Wcolour_index[7 to 0]
49W
(1)
colour_value[7 to 0]
post_div_
enable
no_
memory_
mode
pre_div_
half_clock
adc_
sample_
seq
memory_
init
post_div_
half_clock
gainc_polclamp_pol vs_polhs_pol
reset_
input_path
pll_enable pll_pclkpll_mclk
prog
reset_
memory_
path
screen
blue_prog colour_
reset_
proc_path
power_
down
correction
_on
1999 Aug 2520
Loading...
+ 44 hidden pages
You need points to download manuals.
1 point = 1 manual.
You can buy points or you can get point for every manual you upload.