PNX1300/01/02/11 Data Book
Philips Semiconductors
6-6
PRELIMINARY SPECIFICATION
mat by vertical subsampling with a (1 1) / 2 or more so-
phisticated filter. Vertical filtering can be performed in
software using the DSPCPU
’
s efficient multimedia oper-
ations or by hardware in the on-chip ICP.
The filtering process exercises special care at the left
and right edges of the active area of the CCIR656 data
stream, as defined by the SAV, EAV code positions. See
Figure 6-7
. Since no pixels exist to the left of the first pix-
el or to the right of the last pixel, filtering can result in ar-
tifacts. To minimize artifacts, the image is extended by
mirroring pixels around the left-most and right-most pixel.
Note that the image is mirrored around pixel
‘
a
’
, the first
pixel after the SAV code and around pixel
‘
zz
’
, the last
pixel before the EAV
1
code. Pixel
‘
a
’
in
Figure 6-7
is the
(chroma, luma) pair defined by the first three camera
bytes of the UYVYUYVY... stream after SAV.
Refer to
Figure 6-11
for an overview of the memory
mapped I/O (MMIO) registers that are used to control
and observe the operation of VI in fullres capture mode.
To ensure compatibility with future devices, any unde-
fined MMIO bits should be ignored when read and written
as
’
0
’
s.
Upon hardware or software reset (
Section 6.1.4,
“
Hard-
ware and Software Reset
”
), the VI_CTL, VI_STATUS,
and VI_CLOCK registers are set to all zeros.
At any point in time, the VI_STATUS register fields (see
Figure 6-11
) indicate the current camera status:
CUR_X: The pixel index (0 to M
–
1) of the most
recently received camera pixel. CUR_X gets set to
zero for the first pixel following receipt of a SAV
code
2
, and incremented on every valid Y sample
received thereafter.
CUR_Y: The line index (0 to N
–
1) within the current
field of the camera line that is currently being
received. CUR_Y gets set to zero upon receipt of a
negative edge of V, i.e., upon the first SAV code con-
taining V=0 after one or more SAV codes containing
V=1. This is equivalent to the first line after the end of
vertical retrace. CUR_Y gets incremented upon
every successive SAV code.
FIELD2: Indicates whether the field currently being
received is a field1 or 2. This flag gets updated based
on the F field of every received SAV code. Note that
field1 is the
‘
top
’
field, i.e. the field containing the top-
most visible line. Field1 contains lines 1,3,5 etc.
Field2 contains lines 2,4,6,8 etc.
Table 6-3
illustrates common digital camera standards
and the number of active pixels per line, lines per field,
and fields per second. Note that any source is accept-
able to VI, as long as the maximum VI_CLK rate is not
exceeded.
Figure 6-9
shows the details of an incoming field and the
captured image. The incoming field consists of N hori-
zontal lines, each line having M pixels labeled 0 through
M
–
1. Lines are numbered from 0 through N
–
1. The cap-
tured image is a subset of the incoming image. It is de-
fined by the capture parameters (START_X, START_Y,
WIDTH, HEIGHT) held in the VI_CAP_START and
VI_CAP_SIZE MMIO registers (see
Figure 6-11
).
START_X: defines the starting pixel number (X-coor-
dinate of the starting pixel). START_X must be even,
and greater than or equal to
‘
0
’
.
START_Y: defines the starting line number (Y-coordi-
nate of the starting pixel). START_Y must be greater
than or equal to
‘
0
’
.
WIDTH: Defines the width of the captured image in
pixels. WIDTH must be even.
HEIGHT: Defines the height of the captured image in
lines.
Image capture starts after the following conditions are
met:
VI_CTL.CAPTURE ENABLE is asserted.
VI_STATUS.CAPTURE COMPLETE is de-asserted,
indicating that any previously captured image has
been acknowledged.
CUR_Y = START_Y occurs.
Once image capture is started, HEIGHT
‘
lines
’
are cap-
tured. Each line capture starts if:
The previous line capture, if any, is completed.
CUR_X = START_X
Once line capture starts, it continues for 2*WIDTH pixel
clocks
3
in which VI_DVALID is asserted, irrespective of
the presence of one or more EAV codes.
Note that capture continues regardless of any horizontal
or vertical retrace and associated CUR_Y or CUR_X re-
set. This provides special applications with the ability to
capture information embedded inside the horizontal or
vertical blanking interval. If it is desirable to capture pix-
els in the horizontal blanking interval, a minimum time
separation of 1
μ
s is required between the last pixel cap-
tured on line
y
and the first pixel captured on line
y+1.
An
exception to this rule is allowed if and only if the storage
parameters below are chosen such that the last and first
1.
EAV codes with multiple bit errors are accepted and en-
able the mirroring function.
Note that VI uses the SAV protection bits to implement
single error correction and double error detection. An
SAV code with double error is ignored.
2.
Table 6-3. Common video source parameters.
Video Source
M
(# active pixels)
N
(# active lines)
Field
Rate
(Hz)
CCIR601
50 Hz/625 lines
CCIR601
60 Hz/525 lines
square pixel
50 Hz/625 lines
square pixel
60 Hz/525 lines
720
288
50
720
240
60
768
288
50
640
240
60
3.
Four clocks for each C
b
,Y,C
r
,Y group representing two
luminance pixels