Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/dtor/input
[sfrench/cifs-2.6.git] / Documentation / media / uapi / v4l / pixfmt-srggb12p.rst
1 .. Permission is granted to copy, distribute and/or modify this
2 .. document under the terms of the GNU Free Documentation License,
3 .. Version 1.1 or any later version published by the Free Software
4 .. Foundation, with no Invariant Sections, no Front-Cover Texts
5 .. and no Back-Cover Texts. A copy of the license is included at
6 .. Documentation/media/uapi/fdl-appendix.rst.
7 ..
8 .. TODO: replace it to GFDL-1.1-or-later WITH no-invariant-sections
9
10 .. _V4L2-PIX-FMT-SRGGB12P:
11 .. _v4l2-pix-fmt-sbggr12p:
12 .. _v4l2-pix-fmt-sgbrg12p:
13 .. _v4l2-pix-fmt-sgrbg12p:
14
15 *******************************************************************************************************************************
16 V4L2_PIX_FMT_SRGGB12P ('pRAA'), V4L2_PIX_FMT_SGRBG12P ('pgAA'), V4L2_PIX_FMT_SGBRG12P ('pGAA'), V4L2_PIX_FMT_SBGGR12P ('pBAA'),
17 *******************************************************************************************************************************
18
19
20 12-bit packed Bayer formats
21
22
23 Description
24 ===========
25
26 These four pixel formats are packed raw sRGB / Bayer formats with 12
27 bits per colour. Every two consecutive samples are packed into three
28 bytes. Each of the first two bytes contain the 8 high order bits of
29 the pixels, and the third byte contains the four least significants
30 bits of each pixel, in the same order.
31
32 Each n-pixel row contains n/2 green samples and n/2 blue or red
33 samples, with alternating green-red and green-blue rows. They are
34 conventionally described as GRGR... BGBG..., RGRG... GBGB..., etc.
35 Below is an example of a small V4L2_PIX_FMT_SBGGR12P image:
36
37 **Byte Order.**
38 Each cell is one byte.
39
40 .. tabularcolumns:: |p{2.0cm}|p{1.0cm}|p{1.0cm}|p{2.7cm}|p{1.0cm}|p{1.0cm}|p{2.7cm}|
41
42
43 .. flat-table::
44     :header-rows:  0
45     :stub-columns: 0
46     :widths:       2 1 1 1 1 1 1
47
48
49     -  -  start + 0:
50        -  B\ :sub:`00high`
51        -  G\ :sub:`01high`
52        -  G\ :sub:`01low`\ (bits 7--4)
53
54           B\ :sub:`00low`\ (bits 3--0)
55        -  B\ :sub:`02high`
56        -  G\ :sub:`03high`
57        -  G\ :sub:`03low`\ (bits 7--4)
58
59           B\ :sub:`02low`\ (bits 3--0)
60
61     -  -  start + 6:
62        -  G\ :sub:`10high`
63        -  R\ :sub:`11high`
64        -  R\ :sub:`11low`\ (bits 7--4)
65
66           G\ :sub:`10low`\ (bits 3--0)
67        -  G\ :sub:`12high`
68        -  R\ :sub:`13high`
69        -  R\ :sub:`13low`\ (bits 3--2)
70
71           G\ :sub:`12low`\ (bits 3--0)
72     -  -  start + 12:
73        -  B\ :sub:`20high`
74        -  G\ :sub:`21high`
75        -  G\ :sub:`21low`\ (bits 7--4)
76
77           B\ :sub:`20low`\ (bits 3--0)
78        -  B\ :sub:`22high`
79        -  G\ :sub:`23high`
80        -  G\ :sub:`23low`\ (bits 7--4)
81
82           B\ :sub:`22low`\ (bits 3--0)
83     -  -  start + 18:
84        -  G\ :sub:`30high`
85        -  R\ :sub:`31high`
86        -  R\ :sub:`31low`\ (bits 7--4)
87
88           G\ :sub:`30low`\ (bits 3--0)
89        -  G\ :sub:`32high`
90        -  R\ :sub:`33high`
91        -  R\ :sub:`33low`\ (bits 3--2)
92
93           G\ :sub:`32low`\ (bits 3--0)