Index | Thread | Search

From:
Marcus Glocker <marcus@nazgul.ch>
Subject:
Re: sys/uvideo: sync GUID to pixelformat mappngs with Linux 6.13-rc7
To:
"Kirill A. Korinsky" <kirill@korins.ky>
Cc:
tech@openbsd.org
Date:
Thu, 16 Jan 2025 20:47:16 +0100

Download raw body.

Thread
On Thu, Jan 16, 2025 at 03:32:51PM GMT, Kirill A. Korinsky wrote:

> On Thu, 16 Jan 2025 13:56:22 +0100,
> Kirill A. Korinsky <kirill@korins.ky> wrote:
> >
> > On Thu, 16 Jan 2025 07:20:46 +0100,
> > Marcus Glocker <marcus@nazgul.ch> wrote:
> > >
> > > On Wed, Jan 15, 2025 at 09:43:22PM GMT, Kirill A. Korinsky wrote:
> > >
> > > > tech@
> > > >
> > > > I'd like to sync mappings of GUID to pixel format with Linux 6.13-rc7.
> > > >
> > > > Sources for used data:
> > > >  - https://github.com/torvalds/linux/blob/v6.13-rc7/drivers/media/common/uvc.c
> > > >  - https://github.com/torvalds/linux/blob/v6.13-rc7/include/linux/usb/uvc.h
> > > >
> > > > Ok?
> > >
> > > Why not, makes sense.  Also quickly regression tested.
> > >
> > > ok mglocker@
> > >
> >
> > I had made one more read and discovered few typos.
> >
> > UVIDEO_FORMAT_GUID_GBRG, UVIDEO_FORMAT_GUID_GRBG, UVIDEO_FORMAT_GUID_RGGB
> > and UVIDEO_FORMAT_GUID_RG16 were wrong, and UVIDEO_FORMAT_GUID_GR16 was
> > missed. All this 4 leter combinations... heh.
> >
> > Also, I had replaced 0x00 to '\0' at the end of the "string" in GUID.

Since you force me to look closer at your diff ;-), does it make sense
to set NUL after the four digit string, since I can see that rule
doesn't apply for all the strings, for example:

#define UVIDEO_FORMAT_GUID_INVZ {                       \
    'I',  'N',  'V',  'Z',  0x90, 0x2d, 0x58, 0x4a,     \
    0x92, 0x0b, 0x77, 0x3f, 0x1f, 0x2c, 0x55, 0x6b }

#define UVIDEO_FORMAT_GUID_INVI {                       \
    'I',  'N',  'V',  'I',  0xdb, 0x57, 0x49, 0x5e,     \
    0x8e, 0x3f, 0xf4, 0x79, 0x53, 0x2b, 0x94, 0x6f }

Or should we do it the same as Linux, and just always set 0x00?

> >
> > Ok?
> >
> 
> Ooops, wrong diff with partially missed UVIDEO_FORMAT_GUID_GR16.
> 
> Here the right one.
> 
> Index: sys/dev/usb/uvideo.c
> ===================================================================
> RCS file: /home/cvs/src/sys/dev/usb/uvideo.c,v
> diff -u -p -r1.235 uvideo.c
> --- sys/dev/usb/uvideo.c	15 Jan 2025 20:34:50 -0000	1.235
> +++ sys/dev/usb/uvideo.c	16 Jan 2025 12:32:52 -0000
> @@ -392,7 +392,25 @@ const struct uvideo_map_fmts {
>  	{ UVIDEO_FORMAT_GUID_I420, V4L2_PIX_FMT_YUV420 },
>  	{ UVIDEO_FORMAT_GUID_Y800, V4L2_PIX_FMT_GREY },
>  	{ UVIDEO_FORMAT_GUID_Y8, V4L2_PIX_FMT_GREY },
> +	{ UVIDEO_FORMAT_GUID_D3DFMT_L8, V4L2_PIX_FMT_GREY },
>  	{ UVIDEO_FORMAT_GUID_KSMEDIA_L8_IR, V4L2_PIX_FMT_GREY },
> +	{ UVIDEO_FORMAT_GUID_BY8, V4L2_PIX_FMT_SBGGR8 },
> +	{ UVIDEO_FORMAT_GUID_BA81, V4L2_PIX_FMT_SBGGR8 },
> +	{ UVIDEO_FORMAT_GUID_GBRG, V4L2_PIX_FMT_SGBRG8 },
> +	{ UVIDEO_FORMAT_GUID_GRBG, V4L2_PIX_FMT_SGRBG8 },
> +	{ UVIDEO_FORMAT_GUID_RGGB, V4L2_PIX_FMT_SRGGB8 },
> +	{ UVIDEO_FORMAT_GUID_RGBP, V4L2_PIX_FMT_RGB565 },
> +	{ UVIDEO_FORMAT_GUID_D3DFMT_R5G6B5, V4L2_PIX_FMT_RGB565 },
> +	{ UVIDEO_FORMAT_GUID_BGR3, V4L2_PIX_FMT_BGR24 },
> +	{ UVIDEO_FORMAT_GUID_BGR4, V4L2_PIX_FMT_XBGR32 },
> +	{ UVIDEO_FORMAT_GUID_H265, V4L2_PIX_FMT_HEVC },
> +	{ UVIDEO_FORMAT_GUID_RW10, V4L2_PIX_FMT_SRGGB10P },
> +	{ UVIDEO_FORMAT_GUID_BG16, V4L2_PIX_FMT_SBGGR16 },
> +	{ UVIDEO_FORMAT_GUID_GB16, V4L2_PIX_FMT_SGBRG16 },
> +	{ UVIDEO_FORMAT_GUID_RG16, V4L2_PIX_FMT_SRGGB16 },
> +	{ UVIDEO_FORMAT_GUID_GR16, V4L2_PIX_FMT_SGRBG16 },
> +	{ UVIDEO_FORMAT_GUID_INVZ, V4L2_PIX_FMT_Z16 },
> +	{ UVIDEO_FORMAT_GUID_INVI, V4L2_PIX_FMT_Y10 },
>  };
> 
>  int
> Index: sys/dev/usb/uvideo.h
> ===================================================================
> RCS file: /home/cvs/src/sys/dev/usb/uvideo.h,v
> diff -u -p -r1.62 uvideo.h
> --- sys/dev/usb/uvideo.h	13 Jan 2025 15:32:36 -0000	1.62
> +++ sys/dev/usb/uvideo.h	16 Jan 2025 14:31:28 -0000
> @@ -316,9 +316,81 @@ struct usb_video_probe_commit {
>      'Y',  '8',  ' ',  ' ',  '\0', 0x00, 0x10, 0x00,	\
>      0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> 
> +#define	UVIDEO_FORMAT_GUID_D3DFMT_L8	{		\
> +    0x32, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00,	\
> +    0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
>  #define	UVIDEO_FORMAT_GUID_KSMEDIA_L8_IR	{	\
>      0x32, 0x00, 0x00, 0x00, 0x02, 0x00, 0x10, 0x00,	\
>      0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
> +#define	UVIDEO_FORMAT_GUID_BY8	{			\
> +    'B',  'Y',  '8',  ' ',  '\0', 0x00, 0x10, 0x00,	\
> +    0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
> +#define	UVIDEO_FORMAT_GUID_BA81	{			\
> +    'B',  'A',  '8',  '1',  '\0', 0x00, 0x10, 0x00,	\
> +    0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
> +#define	UVIDEO_FORMAT_GUID_GBRG	{			\
> +    'G',  'B',  'R',  'G',  '\0', 0x00, 0x10, 0x00,	\
> +    0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
> +#define	UVIDEO_FORMAT_GUID_GRBG	{			\
> +    'G',  'R',  'B',  'G',  '\0', 0x00, 0x10, 0x00,	\
> +    0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
> +#define	UVIDEO_FORMAT_GUID_RGGB	{			\
> +    'R',  'G',  'G',  'B',  '\0', 0x00, 0x10, 0x00,	\
> +    0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
> +#define	UVIDEO_FORMAT_GUID_RGBP	{			\
> +    'R',  'G',  'B',  'P',  '\0', 0x00, 0x10, 0x00,	\
> +    0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
> +#define	UVIDEO_FORMAT_GUID_D3DFMT_R5G6B5	{	\
> +    0x7b, 0xeb, 0x36, 0xe4, 0x4f, 0x52, 0xce, 0x11,	\
> +    0x9f, 0x53, 0x00, 0x20, 0xaf, 0x0b, 0xa7, 0x70 }
> +
> +#define	UVIDEO_FORMAT_GUID_BGR3	{			\
> +    0x7d, 0xeb, 0x36, 0xe4, 0x4f, 0x52, 0xce, 0x11,	\
> +    0x9f, 0x53, 0x00, 0x20, 0xaf, 0x0b, 0xa7, 0x70 }
> +
> +#define	UVIDEO_FORMAT_GUID_BGR4	{			\
> +    0x7e, 0xeb, 0x36, 0xe4, 0x4f, 0x52, 0xce, 0x11,	\
> +    0x9f, 0x53, 0x00, 0x20, 0xaf, 0x0b, 0xa7, 0x70 }
> +
> +#define	UVIDEO_FORMAT_GUID_H265	{			\
> +    'H',  '2',  '6',  '5',  '\0', 0x00, 0x10, 0x00,	\
> +    0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
> +#define	UVIDEO_FORMAT_GUID_RW10	{			\
> +    'R',  'W',  '1',  '0',  '\0', 0x00, 0x10, 0x00,	\
> +    0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
> +#define	UVIDEO_FORMAT_GUID_BG16	{			\
> +    'B',  'G',  '1',  '6',  '\0', 0x00, 0x10, 0x00,	\
> +    0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
> +#define	UVIDEO_FORMAT_GUID_GB16	{			\
> +    'G',  'B',  '1',  '6',  '\0', 0x00, 0x10, 0x00,	\
> +    0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
> +#define	UVIDEO_FORMAT_GUID_RG16	{			\
> +    'R',  'G',  '1',  '6',  '\0', 0x00, 0x10, 0x00,	\
> +    0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
> +#define	UVIDEO_FORMAT_GUID_GR16	{			\
> +    'G',  'R',  '1',  '6',  '\0', 0x00, 0x10, 0x00,	\
> +    0x80, 0x00, 0x00, 0xaa, 0x00, 0x38, 0x9b, 0x71 }
> +
> +#define	UVIDEO_FORMAT_GUID_INVZ	{			\
> +    'I',  'N',  'V',  'Z',  0x90, 0x2d, 0x58, 0x4a,	\
> +    0x92, 0x0b, 0x77, 0x3f, 0x1f, 0x2c, 0x55, 0x6b }
> +
> +#define	UVIDEO_FORMAT_GUID_INVI	{			\
> +    'I',  'N',  'V',  'I',  0xdb, 0x57, 0x49, 0x5e,	\
> +    0x8e, 0x3f, 0xf4, 0x79, 0x53, 0x2b, 0x94, 0x6f }
> 
>  /*
>   * USB Video Payload MJPEG
> 
> 
> -- 
> wbr, Kirill
>