Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp691418img; Wed, 20 Mar 2019 08:53:22 -0700 (PDT) X-Google-Smtp-Source: APXvYqwJc/V/3bJi5WGVccAt/1jB7/S2qrk0unJiUGP8KHnExDPhFJRYKjPLFhJqHnxVf405d99X X-Received: by 2002:a17:902:bccc:: with SMTP id o12mr8315378pls.70.1553097202090; Wed, 20 Mar 2019 08:53:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553097202; cv=none; d=google.com; s=arc-20160816; b=gV1DdD4gUTCo65gO3oCzK7QjW2IBezFDAckmY39RDm1t3DjucMDtrWhoL4jeht1iEx XGVHjvR62ErR09R2/MlzlZc3z+PfhwDDo2ivXQy60p5u338w83WlgXtULN9tXQ1ZizG3 hH7KwN4v0SZb+NahjLEilyise7r8GapjTIeOxkG/+BOJzCHhB2dWLlQkNHq9z9nDi03R 0YzP2Mnkl203KxFx6vWFqSqbQp/BtlCd7mch8uYxXwV5zn3y4L/O2/fvYxRiebfjnzSN JSMb4E6A9ucQwKNg627HaNHq5s27VfyCWctIrqs6HIOVlY70MxniEiPloZmRRUbuB/KH y/5Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:date:cc:to:from:subject:message-id:dkim-signature; bh=fZvkrfoKvsXaRRSlCkWokbRGFfY9R+iHSFvvambPWa4=; b=PGdMtvi7Gzhqh7476x/hCyCc2zjWk6JuFKKIPMgAq5TBpl5zlWBCUkCACb+NyKD6e5 shO36UAODLV0EbQlRUrAvA5WwA6FezXd+BkqsiVnql/CEAt9vcM8NJoUOiZ1ol3r69tN o0VISWu4O07HZeL9BQcz90D7tjEL4l3miKYvgfKSfdyebnR6Hl/sA6+5FOUE9Zi8j5wq lKXeLl3igoaR2+nj7GIS6yoeAzkx8gW16AD9sZXxSwgLWJmaTXeh4V4k74EWrMio3cr8 LJCWdlbUc48ZbzCf7TE/w4FKKN/5INxMu6zS18wB+8AvD/dQJ5izOsry4lgaJ6ub+i7Q uDKg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ndufresne-ca.20150623.gappssmtp.com header.s=20150623 header.b=iDxXfyKo; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d3si2158988pla.399.2019.03.20.08.53.05; Wed, 20 Mar 2019 08:53:22 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@ndufresne-ca.20150623.gappssmtp.com header.s=20150623 header.b=iDxXfyKo; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726844AbfCTPwC (ORCPT + 99 others); Wed, 20 Mar 2019 11:52:02 -0400 Received: from mail-qk1-f196.google.com ([209.85.222.196]:40417 "EHLO mail-qk1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726362AbfCTPwB (ORCPT ); Wed, 20 Mar 2019 11:52:01 -0400 Received: by mail-qk1-f196.google.com with SMTP id w20so6206734qka.7 for ; Wed, 20 Mar 2019 08:52:01 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ndufresne-ca.20150623.gappssmtp.com; s=20150623; h=message-id:subject:from:to:cc:date:in-reply-to:references :user-agent:mime-version; bh=fZvkrfoKvsXaRRSlCkWokbRGFfY9R+iHSFvvambPWa4=; b=iDxXfyKoLJxPaOFkd2B9t/HBTabBjALlQ+JGMJaHJOM8tj/0WCq/hUz+Dx8An7i+qL JncD6zOOjXSl1vql5hcA/h05RtoaywdaHqywJ6ov/efrpxna13N2r2WEA9O6Q1re5kEa oXWN0sKKoQ1iQeDLv5uES+9o+hJJqOLds3110awiXREyBo14LzXlxsM1SYRyjgiboaXI RJei4/Ck3SLJB4dbisQ30o/e6d57wouOyjC7Db8Mx/GOJaGKvomUjrhy1lym6iUKl4CB 74n5M2Eimvr8ANBNcQ5M6MLY3tL1A7wzrCbWa0+8tAMIKMDlLPchzEGWo8We46dFaMDs Zv9Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:message-id:subject:from:to:cc:date:in-reply-to :references:user-agent:mime-version; bh=fZvkrfoKvsXaRRSlCkWokbRGFfY9R+iHSFvvambPWa4=; b=F26b4idLeB96++Tm+RW83TFZw3N10zquh5PLek26Ao4C+RBTLH5Ty7ggbLv4DbtcG5 0vZAj3cAYIb3dQL+VIS7pJOrKKug18mNK4dIoVpH11evzszsuSECUOXNM+idl4CLOPn6 Toec8qCoSm6fGKt7dXiUjCIrXZdAHSBCNxPZByXTA2rWtUvv8JZWqyYLwJJqHcGbTOaz sGa7+g6anUf28w5npXdvEcpqWjPgJ7rFKQLYmCHK9HDCS1mB0mCrB113bb08JcEZUQaG EuySZkpf0P+KzTL3bHZ2wFKQBf8Ij85s8/BVtjjlhH75tEDkzM/yUKY+e/H1lDrOzLAC va3g== X-Gm-Message-State: APjAAAXfLV6JAK/wpP+J3RlhJHajG6OkHHUh+Se4HTTAecAx7PBpTbd2 /1DX/4GwOu26oRhWDoPfh9abjw== X-Received: by 2002:ae9:e007:: with SMTP id m7mr7161510qkk.248.1553097120540; Wed, 20 Mar 2019 08:52:00 -0700 (PDT) Received: from tpx230-nicolas.collaboramtl (modemcable154.55-37-24.static.videotron.ca. [24.37.55.154]) by smtp.gmail.com with ESMTPSA id j34sm1248149qte.49.2019.03.20.08.51.59 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Wed, 20 Mar 2019 08:51:59 -0700 (PDT) Message-ID: Subject: Re: [RFC PATCH 18/20] lib: image-formats: Add v4l2 formats support From: Nicolas Dufresne To: Ville =?ISO-8859-1?Q?Syrj=E4l=E4?= Cc: Maxime Ripard , Daniel Vetter , David Airlie , Maarten Lankhorst , Sean Paul , Mauro Carvalho Chehab , Sakari Ailus , linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, Paul Kocialkowski , Hans Verkuil , Laurent Pinchart , Thomas Petazzoni , linux-media@vger.kernel.org Date: Wed, 20 Mar 2019 11:51:58 -0400 In-Reply-To: <20190320142739.GK3888@intel.com> References: <20190320142739.GK3888@intel.com> Content-Type: multipart/signed; micalg="pgp-sha1"; protocol="application/pgp-signature"; boundary="=-0ffIFB3qBxPxmhy23nKQ" User-Agent: Evolution 3.30.5 (3.30.5-1.fc29) MIME-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --=-0ffIFB3qBxPxmhy23nKQ Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable Le mercredi 20 mars 2019 =C3=A0 16:27 +0200, Ville Syrj=C3=A4l=C3=A4 a =C3= =A9crit : > On Tue, Mar 19, 2019 at 07:29:18PM -0400, Nicolas Dufresne wrote: > > Le mardi 19 mars 2019 =C3=A0 22:57 +0100, Maxime Ripard a =C3=A9crit : > > > V4L2 uses different fourcc's than DRM, and has a different set of for= mats. > > > For now, let's add the v4l2 fourcc's for the already existing formats= . > > >=20 > > > Signed-off-by: Maxime Ripard > > > --- > > > include/linux/image-formats.h | 9 +++++- > > > lib/image-formats.c | 67 +++++++++++++++++++++++++++++++++= +++- > > > 2 files changed, 76 insertions(+) > > >=20 > > > diff --git a/include/linux/image-formats.h b/include/linux/image-form= ats.h > > > index 53fd73a71b3d..fbc3a4501ebd 100644 > > > --- a/include/linux/image-formats.h > > > +++ b/include/linux/image-formats.h > > > @@ -26,6 +26,13 @@ struct image_format_info { > > > }; > > > =20 > > > /** > > > + * @v4l2_fmt: > > > + * > > > + * V4L2 4CC format identifier (V4L2_PIX_FMT_*) > > > + */ > > > + u32 v4l2_fmt; > > > + > > > + /** > > > * @depth: > > > * > > > * Color depth (number of bits per pixel excluding padding bits), > > > @@ -222,6 +229,8 @@ image_format_info_is_yuv_sampling_444(const struc= t image_format_info *info) > > > =20 > > > const struct image_format_info *__image_format_drm_lookup(u32 drm); > > > const struct image_format_info *image_format_drm_lookup(u32 drm); > > > +const struct image_format_info *__image_format_v4l2_lookup(u32 v4l2)= ; > > > +const struct image_format_info *image_format_v4l2_lookup(u32 v4l2); > > > unsigned int image_format_plane_cpp(const struct image_format_info *= format, > > > int plane); > > > unsigned int image_format_plane_width(int width, > > > diff --git a/lib/image-formats.c b/lib/image-formats.c > > > index 9b9a73220c5d..39f1d38ae861 100644 > > > --- a/lib/image-formats.c > > > +++ b/lib/image-formats.c > > > @@ -8,6 +8,7 @@ > > > static const struct image_format_info formats[] =3D { > > > { > > > .drm_fmt =3D DRM_FORMAT_C8, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_GREY, > > > .depth =3D 8, > > > .num_planes =3D 1, > > > .cpp =3D { 1, 0, 0 }, > > > @@ -15,6 +16,7 @@ static const struct image_format_info formats[] =3D= { > > > .vsub =3D 1, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_RGB332, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_RGB332, > > > .depth =3D 8, > > > .num_planes =3D 1, > > > .cpp =3D { 1, 0, 0 }, > > > @@ -29,6 +31,7 @@ static const struct image_format_info formats[] =3D= { > > > .vsub =3D 1, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_XRGB4444, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_XRGB444, > > > .depth =3D 0, > > > .num_planes =3D 1, > > > .cpp =3D { 2, 0, 0 }, > > > @@ -57,6 +60,7 @@ static const struct image_format_info formats[] =3D= { > > > .vsub =3D 1, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_ARGB4444, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_ARGB444, > > > .depth =3D 0, > > > .num_planes =3D 1, > > > .cpp =3D { 2, 0, 0 }, > > > @@ -89,6 +93,7 @@ static const struct image_format_info formats[] =3D= { > > > .has_alpha =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_XRGB1555, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_XRGB555, > > > .depth =3D 15, > > > .num_planes =3D 1, > > > .cpp =3D { 2, 0, 0 }, > > > @@ -117,6 +122,7 @@ static const struct image_format_info formats[] = =3D { > > > .vsub =3D 1, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_ARGB1555, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_ARGB555, > > > .depth =3D 15, > > > .num_planes =3D 1, > > > .cpp =3D { 2, 0, 0 }, > > > @@ -149,6 +155,7 @@ static const struct image_format_info formats[] = =3D { > > > .has_alpha =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_RGB565, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_RGB565, > > > .depth =3D 16, > > > .num_planes =3D 1, > > > .cpp =3D { 2, 0, 0 }, > > > @@ -163,6 +170,7 @@ static const struct image_format_info formats[] = =3D { > > > .vsub =3D 1, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_RGB888, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_RGB24, > > > .depth =3D 24, > > > .num_planes =3D 1, > > > .cpp =3D { 3, 0, 0 }, > > > @@ -170,6 +178,7 @@ static const struct image_format_info formats[] = =3D { > > > .vsub =3D 1, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_BGR888, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_BGR24, > > > .depth =3D 24, > > > .num_planes =3D 1, > > > .cpp =3D { 3, 0, 0 }, > > > @@ -177,6 +186,7 @@ static const struct image_format_info formats[] = =3D { > > > .vsub =3D 1, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_XRGB8888, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_XRGB32, > >=20 > > All RGB mapping should be surrounded by ifdef, because many (not all) > > DRM formats represent the order of component when placed in a CPU > > register, unlike V4L2 which uses memory order. I've pick this one >=20 > DRM formats are explicitly defined as little endian. Yes, that means the same thing. The mapping has nothing to do with the buffer bytes order, unlike V4L2 (and most streaming stack) do. Though the mapping in DRM isn't consistent. Again, this mapping is not correct, it will result in swapped colors. >=20 > > randomly, but this one on most system, little endian, will match > > V4L2_PIX_FMT_XBGR32. This type of complex mapping can be found in > > multiple places, notably in GStreamer: > >=20 > > https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/blob/master/sy= s/kms/gstkmsutils.c#L45 > >=20 > > > .depth =3D 24, > > > .num_planes =3D 1, > > > .cpp =3D { 4, 0, 0 }, > > > @@ -281,6 +291,7 @@ static const struct image_format_info formats[] = =3D { > > > .has_alpha =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_ARGB8888, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_ARGB32, > > > .depth =3D 32, > > > .num_planes =3D 1, > > > .cpp =3D { 4, 0, 0 }, > > > @@ -361,6 +372,7 @@ static const struct image_format_info formats[] = =3D { > > > .has_alpha =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_YUV410, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_YUV410, > > > .depth =3D 0, > > > .num_planes =3D 3, > > > .cpp =3D { 1, 1, 1 }, > > > @@ -369,6 +381,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_YVU410, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_YVU410, > > > .depth =3D 0, > > > .num_planes =3D 3, > > > .cpp =3D { 1, 1, 1 }, > > > @@ -393,6 +406,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_YUV420, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_YUV420M, > > > .depth =3D 0, > > > .num_planes =3D 3, > > > .cpp =3D { 1, 1, 1 }, > > > @@ -401,6 +415,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_YVU420, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_YVU420M, > > > .depth =3D 0, > > > .num_planes =3D 3, > > > .cpp =3D { 1, 1, 1 }, > > > @@ -409,6 +424,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_YUV422, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_YUV422M, > > > .depth =3D 0, > > > .num_planes =3D 3, > > > .cpp =3D { 1, 1, 1 }, > > > @@ -417,6 +433,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_YVU422, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_YVU422M, > > > .depth =3D 0, > > > .num_planes =3D 3, > > > .cpp =3D { 1, 1, 1 }, > > > @@ -425,6 +442,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_YUV444, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_YUV444M, > > > .depth =3D 0, > > > .num_planes =3D 3, > > > .cpp =3D { 1, 1, 1 }, > > > @@ -433,6 +451,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_YVU444, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_YVU444M, > > > .depth =3D 0, > > > .num_planes =3D 3, > > > .cpp =3D { 1, 1, 1 }, > > > @@ -441,6 +460,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_NV12, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_NV12, > > > .depth =3D 0, > > > .num_planes =3D 2, > > > .cpp =3D { 1, 2, 0 }, > > > @@ -449,6 +469,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_NV21, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_NV21, > > > .depth =3D 0, > > > .num_planes =3D 2, > > > .cpp =3D { 1, 2, 0 }, > > > @@ -457,6 +478,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_NV16, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_NV16, > > > .depth =3D 0, > > > .num_planes =3D 2, > > > .cpp =3D { 1, 2, 0 }, > > > @@ -465,6 +487,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_NV61, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_NV61, > > > .depth =3D 0, > > > .num_planes =3D 2, > > > .cpp =3D { 1, 2, 0 }, > > > @@ -473,6 +496,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_NV24, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_NV24, > > > .depth =3D 0, > > > .num_planes =3D 2, > > > .cpp =3D { 1, 2, 0 }, > > > @@ -481,6 +505,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_NV42, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_NV42, > > > .depth =3D 0, > > > .num_planes =3D 2, > > > .cpp =3D { 1, 2, 0 }, > > > @@ -489,6 +514,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_YUYV, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_YUYV, > > > .depth =3D 0, > > > .num_planes =3D 1, > > > .cpp =3D { 2, 0, 0 }, > > > @@ -497,6 +523,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_YVYU, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_YVYU, > > > .depth =3D 0, > > > .num_planes =3D 1, > > > .cpp =3D { 2, 0, 0 }, > > > @@ -505,6 +532,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_UYVY, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_UYVY, > > > .depth =3D 0, > > > .num_planes =3D 1, > > > .cpp =3D { 2, 0, 0 }, > > > @@ -513,6 +541,7 @@ static const struct image_format_info formats[] = =3D { > > > .is_yuv =3D true, > > > }, { > > > .drm_fmt =3D DRM_FORMAT_VYUY, > > > + .v4l2_fmt =3D V4L2_PIX_FMT_VYUY, > > > .depth =3D 0, > > > .num_planes =3D 1, > > > .cpp =3D { 2, 0, 0 }, > > > @@ -632,6 +661,44 @@ const struct image_format_info *image_format_drm= _lookup(u32 drm) > > > EXPORT_SYMBOL(image_format_drm_lookup); > > > =20 > > > /** > > > + * __image_format_v4l2_lookup - query information for a given format > > > + * @v4l2: V4L2 fourcc pixel format (V4L2_PIX_FMT_*) > > > + * > > > + * The caller should only pass a supported pixel format to this func= tion. > > > + * > > > + * Returns: > > > + * The instance of struct image_format_info that describes the pixel= format, or > > > + * NULL if the format is unsupported. > > > + */ > > > +const struct image_format_info *__image_format_v4l2_lookup(u32 v4l2) > > > +{ > > > + return __image_format_lookup(v4l2_fmt, v4l2); > > > +} > > > +EXPORT_SYMBOL(__image_format_v4l2_lookup); > > > + > > > +/** > > > + * image_format_v4l2_lookup - query information for a given format > > > + * @v4l2: V4L2 fourcc pixel format (V4L2_PIX_FMT_*) > > > + * > > > + * The caller should only pass a supported pixel format to this func= tion. > > > + * Unsupported pixel formats will generate a warning in the kernel l= og. > > > + * > > > + * Returns: > > > + * The instance of struct image_format_info that describes the pixel= format, or > > > + * NULL if the format is unsupported. > > > + */ > > > +const struct image_format_info *image_format_v4l2_lookup(u32 v4l2) > > > +{ > > > + const struct image_format_info *format; > > > + > > > + format =3D __image_format_v4l2_lookup(v4l2); > > > + > > > + WARN_ON(!format); > > > + return format; > > > +} > > > +EXPORT_SYMBOL(image_format_v4l2_lookup); > > > + > > > +/** > > > * image_format_plane_cpp - determine the bytes per pixel value > > > * @format: pointer to the image_format > > > * @plane: plane index > >=20 > > _______________________________________________ > > dri-devel mailing list > > dri-devel@lists.freedesktop.org > > https://lists.freedesktop.org/mailman/listinfo/dri-devel --=-0ffIFB3qBxPxmhy23nKQ Content-Type: application/pgp-signature; name="signature.asc" Content-Description: This is a digitally signed message part Content-Transfer-Encoding: 7bit -----BEGIN PGP SIGNATURE----- iF0EABECAB0WIQSScpfJiL+hb5vvd45xUwItrAaoHAUCXJJhngAKCRBxUwItrAao HPY+AJ4gi8fUzSbfJDt/3oMayoasrfqy1ACfbKwLK5dqYKSKL3mC5I26E8kNM9A= =Oy9/ -----END PGP SIGNATURE----- --=-0ffIFB3qBxPxmhy23nKQ--