2.7.25. V4L2_PIX_FMT_NV12M ('NM12'), V4L2_PIX_FMT_NV21M ('NM21'), V4L2_PIX_FMT_NV12MT_16X16

V4L2_PIX_FMT_NV21M V4L2_PIX_FMT_NV12MT_16X16 Variation of V4L2_PIX_FMT_NV12 and V4L2_PIX_FMT_NV21 with planes non contiguous in memory.

2.7.25.1. Description

This is a multi-planar, two-plane version of the YUV 4:2:0 format. The three components are separated into two sub-images or planes. V4L2_PIX_FMT_NV12M differs from V4L2_PIX_FMT_NV12 in that the two planes are non-contiguous in memory, i.e. the chroma plane do not necessarily immediately follows the luma plane. The luminance data occupies the first plane. The Y plane has one byte per pixel. In the second plane there is a chrominance data with alternating chroma samples. The CbCr plane is the same width, in bytes, as the Y plane (and of the image), but is half as tall in pixels. Each CbCr pair belongs to four pixels. For example, Cb0/Cr0 belongs to Y'00, Y'01, Y'10, Y'11. V4L2_PIX_FMT_NV12MT_16X16 is the tiled version of V4L2_PIX_FMT_NV12M with 16x16 macroblock tiles. Here pixels are arranged in 16x16 2D tiles and tiles are arranged in linear order in memory. V4L2_PIX_FMT_NV21M is the same as V4L2_PIX_FMT_NV12M except the Cb and Cr bytes are swapped, the CrCb plane starts with a Cr byte.

V4L2_PIX_FMT_NV12M is intended to be used only in drivers and applications that support the multi-planar API, described in Single- and multi-planar APIs.

If the Y plane has pad bytes after each row, then the CbCr plane has as many pad bytes after its rows.

Byte Order. Each cell is one byte.

start0 + 0:

Y'00

Y'01

Y'02

Y'03

start0 + 4:

Y'10

Y'11

Y'12

Y'13

start0 + 8:

Y'20

Y'21

Y'22

Y'23

start0 + 12:

Y'30

Y'31

Y'32

Y'33

start1 + 0:

Cb00

Cr00

Cb01

Cr01

start1 + 4:

Cb10

Cr10

Cb11

Cr11

Color Sample Location:

0

1

2

3

0

Y

Y

Y

Y

C

C

1

Y

Y

Y

Y

2

Y

Y

Y

Y

C

C

3

Y

Y

Y

Y