]>
Commit | Line | Data |
---|---|---|
9a74251d GL |
1 | /* |
2 | * Media Bus API header | |
3 | * | |
4 | * Copyright (C) 2009, Guennadi Liakhovetski <g.liakhovetski@gmx.de> | |
5 | * | |
6 | * This program is free software; you can redistribute it and/or modify | |
7 | * it under the terms of the GNU General Public License version 2 as | |
8 | * published by the Free Software Foundation. | |
9 | */ | |
10 | ||
11 | #ifndef V4L2_MEDIABUS_H | |
12 | #define V4L2_MEDIABUS_H | |
13 | ||
14 | /* | |
15 | * These pixel codes uniquely identify data formats on the media bus. Mostly | |
16 | * they correspond to similarly named V4L2_PIX_FMT_* formats, format 0 is | |
17 | * reserved, V4L2_MBUS_FMT_FIXED shall be used by host-client pairs, where the | |
18 | * data format is fixed. Additionally, "2X8" means that one pixel is transferred | |
19 | * in two 8-bit samples, "BE" or "LE" specify in which order those samples are | |
20 | * transferred over the bus: "LE" means that the least significant bits are | |
21 | * transferred first, "BE" means that the most significant bits are transferred | |
22 | * first, and "PADHI" and "PADLO" define which bits - low or high, in the | |
23 | * incomplete high byte, are filled with padding bits. | |
24 | */ | |
25 | enum v4l2_mbus_pixelcode { | |
26 | V4L2_MBUS_FMT_FIXED = 1, | |
ace6e979 GL |
27 | V4L2_MBUS_FMT_YUYV8_2X8, |
28 | V4L2_MBUS_FMT_YVYU8_2X8, | |
29 | V4L2_MBUS_FMT_UYVY8_2X8, | |
30 | V4L2_MBUS_FMT_VYUY8_2X8, | |
0edc4afb HV |
31 | V4L2_MBUS_FMT_YVYU10_2X10, |
32 | V4L2_MBUS_FMT_YUYV10_2X10, | |
33 | V4L2_MBUS_FMT_YVYU10_1X20, | |
34 | V4L2_MBUS_FMT_YUYV10_1X20, | |
d7709fff HV |
35 | V4L2_MBUS_FMT_RGB444_2X8_PADHI_LE, |
36 | V4L2_MBUS_FMT_RGB444_2X8_PADHI_BE, | |
9a74251d GL |
37 | V4L2_MBUS_FMT_RGB555_2X8_PADHI_LE, |
38 | V4L2_MBUS_FMT_RGB555_2X8_PADHI_BE, | |
39 | V4L2_MBUS_FMT_RGB565_2X8_LE, | |
40 | V4L2_MBUS_FMT_RGB565_2X8_BE, | |
0915d559 SH |
41 | V4L2_MBUS_FMT_BGR565_2X8_LE, |
42 | V4L2_MBUS_FMT_BGR565_2X8_BE, | |
9a74251d GL |
43 | V4L2_MBUS_FMT_SBGGR8_1X8, |
44 | V4L2_MBUS_FMT_SBGGR10_1X10, | |
45 | V4L2_MBUS_FMT_GREY8_1X8, | |
46 | V4L2_MBUS_FMT_Y10_1X10, | |
47 | V4L2_MBUS_FMT_SBGGR10_2X8_PADHI_LE, | |
48 | V4L2_MBUS_FMT_SBGGR10_2X8_PADLO_LE, | |
49 | V4L2_MBUS_FMT_SBGGR10_2X8_PADHI_BE, | |
50 | V4L2_MBUS_FMT_SBGGR10_2X8_PADLO_BE, | |
260bb38a | 51 | V4L2_MBUS_FMT_SGRBG8_1X8, |
c6b65ab7 GL |
52 | V4L2_MBUS_FMT_SBGGR12_1X12, |
53 | V4L2_MBUS_FMT_YUYV8_1_5X8, | |
54 | V4L2_MBUS_FMT_YVYU8_1_5X8, | |
55 | V4L2_MBUS_FMT_UYVY8_1_5X8, | |
56 | V4L2_MBUS_FMT_VYUY8_1_5X8, | |
9a74251d GL |
57 | }; |
58 | ||
59 | /** | |
60 | * struct v4l2_mbus_framefmt - frame format on the media bus | |
61 | * @width: frame width | |
62 | * @height: frame height | |
63 | * @code: data format code | |
64 | * @field: used interlacing type | |
65 | * @colorspace: colorspace of the data | |
66 | */ | |
67 | struct v4l2_mbus_framefmt { | |
68 | __u32 width; | |
69 | __u32 height; | |
70 | enum v4l2_mbus_pixelcode code; | |
71 | enum v4l2_field field; | |
72 | enum v4l2_colorspace colorspace; | |
73 | }; | |
74 | ||
3a21ceed HV |
75 | static inline void v4l2_fill_pix_format(struct v4l2_pix_format *pix_fmt, |
76 | const struct v4l2_mbus_framefmt *mbus_fmt) | |
77 | { | |
78 | pix_fmt->width = mbus_fmt->width; | |
79 | pix_fmt->height = mbus_fmt->height; | |
80 | pix_fmt->field = mbus_fmt->field; | |
81 | pix_fmt->colorspace = mbus_fmt->colorspace; | |
82 | } | |
83 | ||
84 | static inline void v4l2_fill_mbus_format(struct v4l2_mbus_framefmt *mbus_fmt, | |
85 | const struct v4l2_pix_format *pix_fmt, | |
86 | enum v4l2_mbus_pixelcode code) | |
87 | { | |
88 | mbus_fmt->width = pix_fmt->width; | |
89 | mbus_fmt->height = pix_fmt->height; | |
90 | mbus_fmt->field = pix_fmt->field; | |
91 | mbus_fmt->colorspace = pix_fmt->colorspace; | |
92 | mbus_fmt->code = code; | |
93 | } | |
94 | ||
9a74251d | 95 | #endif |