Blame view
include/media/soc_mediabus.h
2.73 KB
9a74251d8 V4L/DVB (13658): ... |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
/* * SoC-camera Media Bus API extensions * * Copyright (C) 2009, Guennadi Liakhovetski <g.liakhovetski@gmx.de> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 as * published by the Free Software Foundation. */ #ifndef SOC_MEDIABUS_H #define SOC_MEDIABUS_H #include <linux/videodev2.h> |
2ef2d5a33 [media] v4l: Move... |
15 |
#include <linux/v4l2-mediabus.h> |
9a74251d8 V4L/DVB (13658): ... |
16 17 18 |
/** * enum soc_mbus_packing - data packing types on the media-bus |
cc552b620 [media] V4L: soc-... |
19 20 |
* @SOC_MBUS_PACKING_NONE: no packing, bit-for-bit transfer to RAM, one * sample represents one pixel |
9a74251d8 V4L/DVB (13658): ... |
21 22 23 24 25 |
* @SOC_MBUS_PACKING_2X8_PADHI: 16 bits transferred in 2 8-bit samples, in the * possibly incomplete byte high bits are padding * @SOC_MBUS_PACKING_2X8_PADLO: as above, but low bits are padding * @SOC_MBUS_PACKING_EXTEND16: sample width (e.g., 10 bits) has to be extended * to 16 bits |
cc552b620 [media] V4L: soc-... |
26 27 28 |
* @SOC_MBUS_PACKING_VARIABLE: compressed formats with variable packing * @SOC_MBUS_PACKING_1_5X8: used for packed YUV 4:2:0 formats, where 4 * pixels occupy 6 bytes in RAM |
9a74251d8 V4L/DVB (13658): ... |
29 30 31 32 33 34 |
*/ enum soc_mbus_packing { SOC_MBUS_PACKING_NONE, SOC_MBUS_PACKING_2X8_PADHI, SOC_MBUS_PACKING_2X8_PADLO, SOC_MBUS_PACKING_EXTEND16, |
64149deb6 [media] V4L: soc-... |
35 |
SOC_MBUS_PACKING_VARIABLE, |
cc552b620 [media] V4L: soc-... |
36 |
SOC_MBUS_PACKING_1_5X8, |
9a74251d8 V4L/DVB (13658): ... |
37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 |
}; /** * enum soc_mbus_order - sample order on the media bus * @SOC_MBUS_ORDER_LE: least significant sample first * @SOC_MBUS_ORDER_BE: most significant sample first */ enum soc_mbus_order { SOC_MBUS_ORDER_LE, SOC_MBUS_ORDER_BE, }; /** * struct soc_mbus_pixelfmt - Data format on the media bus * @name: Name of the format * @fourcc: Fourcc code, that will be obtained if the data is * stored in memory in the following way: * @packing: Type of sample-packing, that has to be used * @order: Sample order when storing in memory * @bits_per_sample: How many bits the bridge has to sample */ struct soc_mbus_pixelfmt { const char *name; u32 fourcc; enum soc_mbus_packing packing; enum soc_mbus_order order; u8 bits_per_sample; }; |
93f116d59 [media] V4L: soc-... |
65 66 67 68 69 70 71 72 73 74 75 76 77 78 |
/** * struct soc_mbus_lookup - Lookup FOURCC IDs by mediabus codes for pass-through * @code: mediabus pixel-code * @fmt: pixel format description */ struct soc_mbus_lookup { enum v4l2_mbus_pixelcode code; struct soc_mbus_pixelfmt fmt; }; const struct soc_mbus_pixelfmt *soc_mbus_find_fmtdesc( enum v4l2_mbus_pixelcode code, const struct soc_mbus_lookup *lookup, int n); |
9a74251d8 V4L/DVB (13658): ... |
79 80 81 |
const struct soc_mbus_pixelfmt *soc_mbus_get_fmtdesc( enum v4l2_mbus_pixelcode code); s32 soc_mbus_bytes_per_line(u32 width, const struct soc_mbus_pixelfmt *mf); |
cc552b620 [media] V4L: soc-... |
82 83 |
int soc_mbus_samples_per_pixel(const struct soc_mbus_pixelfmt *mf, unsigned int *numerator, unsigned int *denominator); |
32c69fcc7 [media] V4L: soc-... |
84 85 |
unsigned int soc_mbus_config_compatible(const struct v4l2_mbus_config *cfg, unsigned int flags); |
9a74251d8 V4L/DVB (13658): ... |
86 87 |
#endif |