1 /* SPDX-License-Identifier: GPL-2.0-only */
3 * SoC-camera Media Bus API extensions
5 * Copyright (C) 2009, Guennadi Liakhovetski <g.liakhovetski@gmx.de>
11 #include <linux/videodev2.h>
12 #include <linux/v4l2-mediabus.h>
15 * enum soc_mbus_packing - data packing types on the media-bus
16 * @SOC_MBUS_PACKING_NONE: no packing, bit-for-bit transfer to RAM, one
17 * sample represents one pixel
18 * @SOC_MBUS_PACKING_2X8_PADHI: 16 bits transferred in 2 8-bit samples, in the
19 * possibly incomplete byte high bits are padding
20 * @SOC_MBUS_PACKING_2X8_PADLO: as above, but low bits are padding
21 * @SOC_MBUS_PACKING_EXTEND16: sample width (e.g., 10 bits) has to be extended
23 * @SOC_MBUS_PACKING_VARIABLE: compressed formats with variable packing
24 * @SOC_MBUS_PACKING_1_5X8: used for packed YUV 4:2:0 formats, where 4
25 * pixels occupy 6 bytes in RAM
26 * @SOC_MBUS_PACKING_EXTEND32: sample width (e.g., 24 bits) has to be extended
29 enum soc_mbus_packing
{
30 SOC_MBUS_PACKING_NONE
,
31 SOC_MBUS_PACKING_2X8_PADHI
,
32 SOC_MBUS_PACKING_2X8_PADLO
,
33 SOC_MBUS_PACKING_EXTEND16
,
34 SOC_MBUS_PACKING_VARIABLE
,
35 SOC_MBUS_PACKING_1_5X8
,
36 SOC_MBUS_PACKING_EXTEND32
,
40 * enum soc_mbus_order - sample order on the media bus
41 * @SOC_MBUS_ORDER_LE: least significant sample first
42 * @SOC_MBUS_ORDER_BE: most significant sample first
50 * enum soc_mbus_layout - planes layout in memory
51 * @SOC_MBUS_LAYOUT_PACKED: color components packed
52 * @SOC_MBUS_LAYOUT_PLANAR_2Y_U_V: YUV components stored in 3 planes (4:2:2)
53 * @SOC_MBUS_LAYOUT_PLANAR_2Y_C: YUV components stored in a luma and a
54 * chroma plane (C plane is half the size
56 * @SOC_MBUS_LAYOUT_PLANAR_Y_C: YUV components stored in a luma and a
57 * chroma plane (C plane is the same size
60 enum soc_mbus_layout
{
61 SOC_MBUS_LAYOUT_PACKED
= 0,
62 SOC_MBUS_LAYOUT_PLANAR_2Y_U_V
,
63 SOC_MBUS_LAYOUT_PLANAR_2Y_C
,
64 SOC_MBUS_LAYOUT_PLANAR_Y_C
,
68 * struct soc_mbus_pixelfmt - Data format on the media bus
69 * @fourcc: Fourcc code, that will be obtained if the data is
70 * stored in memory in the following way:
71 * @packing: Type of sample-packing, that has to be used
72 * @order: Sample order when storing in memory
73 * @bits_per_sample: How many bits the bridge has to sample
75 struct soc_mbus_pixelfmt
{
77 enum soc_mbus_packing packing
;
78 enum soc_mbus_order order
;
79 enum soc_mbus_layout layout
;
84 * struct soc_mbus_lookup - Lookup FOURCC IDs by mediabus codes for pass-through
85 * @code: mediabus pixel-code
86 * @fmt: pixel format description
88 struct soc_mbus_lookup
{
90 struct soc_mbus_pixelfmt fmt
;
93 const struct soc_mbus_pixelfmt
*soc_mbus_find_fmtdesc(
95 const struct soc_mbus_lookup
*lookup
,
97 const struct soc_mbus_pixelfmt
*soc_mbus_get_fmtdesc(
99 s32
soc_mbus_bytes_per_line(u32 width
, const struct soc_mbus_pixelfmt
*mf
);
100 s32
soc_mbus_image_size(const struct soc_mbus_pixelfmt
*mf
,
101 u32 bytes_per_line
, u32 height
);
102 int soc_mbus_samples_per_pixel(const struct soc_mbus_pixelfmt
*mf
,
103 unsigned int *numerator
, unsigned int *denominator
);
104 unsigned int soc_mbus_config_compatible(const struct v4l2_mbus_config
*cfg
,