From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from bhuna.collabora.co.uk (bhuna.collabora.co.uk [46.235.227.227]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id E23A02C82 for ; Fri, 15 Oct 2021 17:19:51 +0000 (UTC) Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: andrzej.p) with ESMTPSA id 74A091F4502D Subject: Re: [PATCH v7 11/11] media: hantro: Support NV12 on the G2 core To: =?UTF-8?Q?Jernej_=c5=a0krabec?= , linux-media@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-rockchip@lists.infradead.org, linux-staging@lists.linux.dev Cc: Benjamin Gaignard , Boris Brezillon , Ezequiel Garcia , Fabio Estevam , Greg Kroah-Hartman , Hans Verkuil , Heiko Stuebner , Mauro Carvalho Chehab , Nicolas Dufresne , NXP Linux Team , Pengutronix Kernel Team , Philipp Zabel , Sascha Hauer , Shawn Guo , kernel@collabora.com, Ezequiel Garcia References: <20210929160439.6601-1-andrzej.p@collabora.com> <20210929160439.6601-12-andrzej.p@collabora.com> <3448839.R56niFO833@kista> From: Andrzej Pietrasiewicz Message-ID: <84fd4395-5cac-c933-7639-dd3cd844a9cf@collabora.com> Date: Fri, 15 Oct 2021 19:19:47 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.13.0 Precedence: bulk X-Mailing-List: linux-staging@lists.linux.dev List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 In-Reply-To: <3448839.R56niFO833@kista> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Hi Jernej, W dniu 14.10.2021 o 19:42, Jernej Škrabec pisze: > Hi Andrzej! > > Dne sreda, 29. september 2021 ob 18:04:39 CEST je Andrzej Pietrasiewicz > napisal(a): >> The G2 decoder block produces NV12 4x4 tiled format (NV12_4L4). >> Enable the G2 post-processor block, in order to produce regular NV12. >> >> The logic in hantro_postproc.c is leveraged to take care of allocating >> the extra buffers and configure the post-processor, which is >> significantly simpler than the one on the G1. > > Quick summary of discussion on LibreELEC Slack: > When using NV12 format on Allwinner H6 variant of G2 (needs some driver > changes), I get frames out of order. If I use native NV12 tiled format, frames > are ordered correctly. > > Currently I'm not sure if this is issue with my changes or is this general > issue. > > I would be grateful if anyone can test frame order with and without > postprocessing enabled on imx8. Take some dynamic video with a lot of short > scenes. It's pretty obvious when frames are out of order. > I checked on imx8 and cannot observe any such artifacts. Andrzej > However, given that frames themself are correctly decoded and without > postprocessing in right order, that shouldn't block merging previous patches. > I tried few different videos and frames were all decoded correctly. > > Best regards, > Jernej > >> >> Signed-off-by: Ezequiel Garcia >> Signed-off-by: Andrzej Pietrasiewicz >> --- >> .../staging/media/hantro/hantro_g2_vp9_dec.c | 6 ++-- >> drivers/staging/media/hantro/hantro_hw.h | 1 + >> .../staging/media/hantro/hantro_postproc.c | 31 +++++++++++++++++++ >> drivers/staging/media/hantro/imx8m_vpu_hw.c | 11 +++++++ >> 4 files changed, 46 insertions(+), 3 deletions(-) >> >> diff --git a/drivers/staging/media/hantro/hantro_g2_vp9_dec.c b/drivers/ > staging/media/hantro/hantro_g2_vp9_dec.c >> index 7f827b9f0133..1a26be72c878 100644 >> --- a/drivers/staging/media/hantro/hantro_g2_vp9_dec.c >> +++ b/drivers/staging/media/hantro/hantro_g2_vp9_dec.c >> @@ -152,7 +152,7 @@ static void config_output(struct hantro_ctx *ctx, >> hantro_reg_write(ctx->dev, &g2_out_dis, 0); >> hantro_reg_write(ctx->dev, &g2_output_format, 0); >> >> - luma_addr = vb2_dma_contig_plane_dma_addr(&dst->base.vb.vb2_buf, > 0); >> + luma_addr = hantro_get_dec_buf_addr(ctx, &dst->base.vb.vb2_buf); >> hantro_write_addr(ctx->dev, G2_OUT_LUMA_ADDR, luma_addr); >> >> chroma_addr = luma_addr + chroma_offset(ctx, dec_params); >> @@ -191,7 +191,7 @@ static void config_ref(struct hantro_ctx *ctx, >> hantro_reg_write(ctx->dev, &ref_reg->hor_scale, (refw << 14) / > dst->vp9.width); >> hantro_reg_write(ctx->dev, &ref_reg->ver_scale, (refh << 14) / > dst->vp9.height); >> >> - luma_addr = vb2_dma_contig_plane_dma_addr(&buf->base.vb.vb2_buf, > 0); >> + luma_addr = hantro_get_dec_buf_addr(ctx, &buf->base.vb.vb2_buf); >> hantro_write_addr(ctx->dev, ref_reg->y_base, luma_addr); >> >> chroma_addr = luma_addr + chroma_offset(ctx, dec_params); >> @@ -236,7 +236,7 @@ static void config_ref_registers(struct hantro_ctx *ctx, >> config_ref(ctx, dst, &ref_regs[1], dec_params, dec_params- >> golden_frame_ts); >> config_ref(ctx, dst, &ref_regs[2], dec_params, dec_params- >> alt_frame_ts); >> >> - mv_addr = vb2_dma_contig_plane_dma_addr(&mv_ref->base.vb.vb2_buf, > 0) + >> + mv_addr = hantro_get_dec_buf_addr(ctx, &mv_ref->base.vb.vb2_buf) + >> mv_offset(ctx, dec_params); >> hantro_write_addr(ctx->dev, G2_REF_MV_ADDR(0), mv_addr); >> >> diff --git a/drivers/staging/media/hantro/hantro_hw.h b/drivers/staging/ > media/hantro/hantro_hw.h >> index 2961d399fd60..3d4a5dc1e6d5 100644 >> --- a/drivers/staging/media/hantro/hantro_hw.h >> +++ b/drivers/staging/media/hantro/hantro_hw.h >> @@ -274,6 +274,7 @@ extern const struct hantro_variant rk3399_vpu_variant; >> extern const struct hantro_variant sama5d4_vdec_variant; >> >> extern const struct hantro_postproc_ops hantro_g1_postproc_ops; >> +extern const struct hantro_postproc_ops hantro_g2_postproc_ops; >> >> extern const u32 hantro_vp8_dec_mc_filter[8][6]; >> >> diff --git a/drivers/staging/media/hantro/hantro_postproc.c b/drivers/ > staging/media/hantro/hantro_postproc.c >> index 4549aec08feb..79a66d001738 100644 >> --- a/drivers/staging/media/hantro/hantro_postproc.c >> +++ b/drivers/staging/media/hantro/hantro_postproc.c >> @@ -11,6 +11,7 @@ >> #include "hantro.h" >> #include "hantro_hw.h" >> #include "hantro_g1_regs.h" >> +#include "hantro_g2_regs.h" >> >> #define HANTRO_PP_REG_WRITE(vpu, reg_name, val) \ >> { \ >> @@ -99,6 +100,21 @@ static void hantro_postproc_g1_enable(struct hantro_ctx > *ctx) >> HANTRO_PP_REG_WRITE(vpu, display_width, ctx->dst_fmt.width); >> } >> >> +static void hantro_postproc_g2_enable(struct hantro_ctx *ctx) >> +{ >> + struct hantro_dev *vpu = ctx->dev; >> + struct vb2_v4l2_buffer *dst_buf; >> + size_t chroma_offset = ctx->dst_fmt.width * ctx->dst_fmt.height; >> + dma_addr_t dst_dma; >> + >> + dst_buf = hantro_get_dst_buf(ctx); >> + dst_dma = vb2_dma_contig_plane_dma_addr(&dst_buf->vb2_buf, 0); >> + >> + hantro_write_addr(vpu, G2_RS_OUT_LUMA_ADDR, dst_dma); >> + hantro_write_addr(vpu, G2_RS_OUT_CHROMA_ADDR, dst_dma + > chroma_offset); >> + hantro_reg_write(vpu, &g2_out_rs_e, 1); >> +} >> + >> void hantro_postproc_free(struct hantro_ctx *ctx) >> { >> struct hantro_dev *vpu = ctx->dev; >> @@ -127,6 +143,9 @@ int hantro_postproc_alloc(struct hantro_ctx *ctx) >> if (ctx->vpu_src_fmt->fourcc == V4L2_PIX_FMT_H264_SLICE) >> buf_size += hantro_h264_mv_size(ctx->dst_fmt.width, >> ctx- >> dst_fmt.height); >> + else if (ctx->vpu_src_fmt->fourcc == V4L2_PIX_FMT_VP9_FRAME) >> + buf_size += hantro_vp9_mv_size(ctx->dst_fmt.width, >> + ctx- >> dst_fmt.height); >> >> for (i = 0; i < num_buffers; ++i) { >> struct hantro_aux_buf *priv = &ctx->postproc.dec_q[i]; >> @@ -152,6 +171,13 @@ static void hantro_postproc_g1_disable(struct > hantro_ctx *ctx) >> HANTRO_PP_REG_WRITE_S(vpu, pipeline_en, 0x0); >> } >> >> +static void hantro_postproc_g2_disable(struct hantro_ctx *ctx) >> +{ >> + struct hantro_dev *vpu = ctx->dev; >> + >> + hantro_reg_write(vpu, &g2_out_rs_e, 0); >> +} >> + >> void hantro_postproc_disable(struct hantro_ctx *ctx) >> { >> struct hantro_dev *vpu = ctx->dev; >> @@ -172,3 +198,8 @@ const struct hantro_postproc_ops hantro_g1_postproc_ops > = { >> .enable = hantro_postproc_g1_enable, >> .disable = hantro_postproc_g1_disable, >> }; >> + >> +const struct hantro_postproc_ops hantro_g2_postproc_ops = { >> + .enable = hantro_postproc_g2_enable, >> + .disable = hantro_postproc_g2_disable, >> +}; >> diff --git a/drivers/staging/media/hantro/imx8m_vpu_hw.c b/drivers/staging/ > media/hantro/imx8m_vpu_hw.c >> index 455a107ffb02..1a43f6fceef9 100644 >> --- a/drivers/staging/media/hantro/imx8m_vpu_hw.c >> +++ b/drivers/staging/media/hantro/imx8m_vpu_hw.c >> @@ -132,6 +132,14 @@ static const struct hantro_fmt imx8m_vpu_dec_fmts[] = { >> }, >> }; >> >> +static const struct hantro_fmt imx8m_vpu_g2_postproc_fmts[] = { >> + { >> + .fourcc = V4L2_PIX_FMT_NV12, >> + .codec_mode = HANTRO_MODE_NONE, >> + .postprocessed = true, >> + }, >> +}; >> + >> static const struct hantro_fmt imx8m_vpu_g2_dec_fmts[] = { >> { >> .fourcc = V4L2_PIX_FMT_NV12_4L4, >> @@ -301,6 +309,9 @@ const struct hantro_variant imx8mq_vpu_g2_variant = { >> .dec_offset = 0x0, >> .dec_fmts = imx8m_vpu_g2_dec_fmts, >> .num_dec_fmts = ARRAY_SIZE(imx8m_vpu_g2_dec_fmts), >> + .postproc_fmts = imx8m_vpu_g2_postproc_fmts, >> + .num_postproc_fmts = ARRAY_SIZE(imx8m_vpu_g2_postproc_fmts), >> + .postproc_ops = &hantro_g2_postproc_ops, >> .codec = HANTRO_HEVC_DECODER | HANTRO_VP9_DECODER, >> .codec_ops = imx8mq_vpu_g2_codec_ops, >> .init = imx8mq_vpu_hw_init, >> -- >> 2.17.1 >> >> > > From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 91D7BC433F5 for ; Fri, 15 Oct 2021 17:21:05 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 53F9C600CD for ; Fri, 15 Oct 2021 17:21:05 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.4.1 mail.kernel.org 53F9C600CD Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=collabora.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:Content-Type: Content-Transfer-Encoding:List-Subscribe:List-Help:List-Post:List-Archive: List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:Date:Message-ID:From: References:Cc:To:Subject:Reply-To:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=s0CBkWTNe/y/pmry5pQNSgBUS6pd3J8eSa32/EFyZLw=; b=krL6HX9d6AsX+ZLmVm4ebR3AE1 EJJlIXH4i4GOOr2BlzEUjm9SkE/1HOWuI4dC9nF3/LCZrPl8+5MuoyTd+YilxM54WQKeVcXuVSYPS svxSt8bWmRZmsdBBDioV7TVePQHZmMtYrMowVUhgIide/Om8lilTWwqfFEeA3w1TOCiwL/2RF3TuY XdRa1NvPjH2Z0Sge58IAiHzhW4VwRnjypLfrSrhDCvD/CKZutEPK53V7HAN/mR0i+7RiOquHkQUoK T/hY0baWjsJKitFfqdQahw2W3gEaW4yEpjCSbPor4BpTUksrF6cKHytPc0lc8UTvoRJDKqgz4lk4i NEYc9U3A==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1mbQt8-008IKZ-Um; Fri, 15 Oct 2021 17:20:58 +0000 Received: from bhuna.collabora.co.uk ([46.235.227.227]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1mbQs6-008I0O-9N; Fri, 15 Oct 2021 17:19:56 +0000 Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: andrzej.p) with ESMTPSA id 74A091F4502D Subject: Re: [PATCH v7 11/11] media: hantro: Support NV12 on the G2 core To: =?UTF-8?Q?Jernej_=c5=a0krabec?= , linux-media@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-rockchip@lists.infradead.org, linux-staging@lists.linux.dev Cc: Benjamin Gaignard , Boris Brezillon , Ezequiel Garcia , Fabio Estevam , Greg Kroah-Hartman , Hans Verkuil , Heiko Stuebner , Mauro Carvalho Chehab , Nicolas Dufresne , NXP Linux Team , Pengutronix Kernel Team , Philipp Zabel , Sascha Hauer , Shawn Guo , kernel@collabora.com, Ezequiel Garcia References: <20210929160439.6601-1-andrzej.p@collabora.com> <20210929160439.6601-12-andrzej.p@collabora.com> <3448839.R56niFO833@kista> From: Andrzej Pietrasiewicz Message-ID: <84fd4395-5cac-c933-7639-dd3cd844a9cf@collabora.com> Date: Fri, 15 Oct 2021 19:19:47 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.13.0 MIME-Version: 1.0 In-Reply-To: <3448839.R56niFO833@kista> Content-Language: en-US X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20211015_101954_626044_AF8AE156 X-CRM114-Status: GOOD ( 30.70 ) X-BeenThere: linux-rockchip@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: Upstream kernel work for Rockchip platforms List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Transfer-Encoding: base64 Content-Type: text/plain; charset="utf-8"; Format="flowed" Sender: "Linux-rockchip" Errors-To: linux-rockchip-bounces+linux-rockchip=archiver.kernel.org@lists.infradead.org SGkgSmVybmVqLAoKVyBkbml1IDE0LjEwLjIwMjEgb8KgMTk6NDIsIEplcm5laiDFoGtyYWJlYyBw aXN6ZToKPiBIaSBBbmRyemVqIQo+IAo+IERuZSBzcmVkYSwgMjkuIHNlcHRlbWJlciAyMDIxIG9i IDE4OjA0OjM5IENFU1QgamUgQW5kcnplaiBQaWV0cmFzaWV3aWN6Cj4gbmFwaXNhbChhKToKPj4g VGhlIEcyIGRlY29kZXIgYmxvY2sgcHJvZHVjZXMgTlYxMiA0eDQgdGlsZWQgZm9ybWF0IChOVjEy XzRMNCkuCj4+IEVuYWJsZSB0aGUgRzIgcG9zdC1wcm9jZXNzb3IgYmxvY2ssIGluIG9yZGVyIHRv IHByb2R1Y2UgcmVndWxhciBOVjEyLgo+Pgo+PiBUaGUgbG9naWMgaW4gaGFudHJvX3Bvc3Rwcm9j LmMgaXMgbGV2ZXJhZ2VkIHRvIHRha2UgY2FyZSBvZiBhbGxvY2F0aW5nCj4+IHRoZSBleHRyYSBi dWZmZXJzIGFuZCBjb25maWd1cmUgdGhlIHBvc3QtcHJvY2Vzc29yLCB3aGljaCBpcwo+PiBzaWdu aWZpY2FudGx5IHNpbXBsZXIgdGhhbiB0aGUgb25lIG9uIHRoZSBHMS4KPiAKPiBRdWljayBzdW1t YXJ5IG9mIGRpc2N1c3Npb24gb24gTGlicmVFTEVDIFNsYWNrOgo+IFdoZW4gdXNpbmcgTlYxMiBm b3JtYXQgb24gQWxsd2lubmVyIEg2IHZhcmlhbnQgb2YgRzIgKG5lZWRzIHNvbWUgZHJpdmVyCj4g Y2hhbmdlcyksIEkgZ2V0IGZyYW1lcyBvdXQgb2Ygb3JkZXIuIElmIEkgdXNlIG5hdGl2ZSBOVjEy IHRpbGVkIGZvcm1hdCwgZnJhbWVzCj4gYXJlIG9yZGVyZWQgY29ycmVjdGx5Lgo+IAo+IEN1cnJl bnRseSBJJ20gbm90IHN1cmUgaWYgdGhpcyBpcyBpc3N1ZSB3aXRoIG15IGNoYW5nZXMgb3IgaXMg dGhpcyBnZW5lcmFsCj4gaXNzdWUuCj4gCj4gSSB3b3VsZCBiZSBncmF0ZWZ1bCBpZiBhbnlvbmUg Y2FuIHRlc3QgZnJhbWUgb3JkZXIgd2l0aCBhbmQgd2l0aG91dAo+IHBvc3Rwcm9jZXNzaW5nIGVu YWJsZWQgb24gaW14OC4gVGFrZSBzb21lIGR5bmFtaWMgdmlkZW8gd2l0aCBhIGxvdCBvZiBzaG9y dAo+IHNjZW5lcy4gSXQncyBwcmV0dHkgb2J2aW91cyB3aGVuIGZyYW1lcyBhcmUgb3V0IG9mIG9y ZGVyLgo+IAoKSSBjaGVja2VkIG9uIGlteDggYW5kIGNhbm5vdCBvYnNlcnZlIGFueSBzdWNoIGFy dGlmYWN0cy4KCkFuZHJ6ZWoKCj4gSG93ZXZlciwgZ2l2ZW4gdGhhdCBmcmFtZXMgdGhlbXNlbGYg YXJlIGNvcnJlY3RseSBkZWNvZGVkIGFuZCB3aXRob3V0Cj4gcG9zdHByb2Nlc3NpbmcgaW4gcmln aHQgb3JkZXIsIHRoYXQgc2hvdWxkbid0IGJsb2NrIG1lcmdpbmcgcHJldmlvdXMgcGF0Y2hlcy4K PiBJIHRyaWVkIGZldyBkaWZmZXJlbnQgdmlkZW9zIGFuZCBmcmFtZXMgd2VyZSBhbGwgZGVjb2Rl ZCBjb3JyZWN0bHkuCj4gCj4gQmVzdCByZWdhcmRzLAo+IEplcm5lago+IAo+Pgo+PiBTaWduZWQt b2ZmLWJ5OiBFemVxdWllbCBHYXJjaWEgPGV6ZXF1aWVsQGNvbGxhYm9yYS5jb20+Cj4+IFNpZ25l ZC1vZmYtYnk6IEFuZHJ6ZWogUGlldHJhc2lld2ljeiA8YW5kcnplai5wQGNvbGxhYm9yYS5jb20+ Cj4+IC0tLQo+PiAgIC4uLi9zdGFnaW5nL21lZGlhL2hhbnRyby9oYW50cm9fZzJfdnA5X2RlYy5j ICB8ICA2ICsrLS0KPj4gICBkcml2ZXJzL3N0YWdpbmcvbWVkaWEvaGFudHJvL2hhbnRyb19ody5o ICAgICAgfCAgMSArCj4+ICAgLi4uL3N0YWdpbmcvbWVkaWEvaGFudHJvL2hhbnRyb19wb3N0cHJv Yy5jICAgIHwgMzEgKysrKysrKysrKysrKysrKysrKwo+PiAgIGRyaXZlcnMvc3RhZ2luZy9tZWRp YS9oYW50cm8vaW14OG1fdnB1X2h3LmMgICB8IDExICsrKysrKysKPj4gICA0IGZpbGVzIGNoYW5n ZWQsIDQ2IGluc2VydGlvbnMoKyksIDMgZGVsZXRpb25zKC0pCj4+Cj4+IGRpZmYgLS1naXQgYS9k cml2ZXJzL3N0YWdpbmcvbWVkaWEvaGFudHJvL2hhbnRyb19nMl92cDlfZGVjLmMgYi9kcml2ZXJz Lwo+IHN0YWdpbmcvbWVkaWEvaGFudHJvL2hhbnRyb19nMl92cDlfZGVjLmMKPj4gaW5kZXggN2Y4 MjdiOWYwMTMzLi4xYTI2YmU3MmM4NzggMTAwNjQ0Cj4+IC0tLSBhL2RyaXZlcnMvc3RhZ2luZy9t ZWRpYS9oYW50cm8vaGFudHJvX2cyX3ZwOV9kZWMuYwo+PiArKysgYi9kcml2ZXJzL3N0YWdpbmcv bWVkaWEvaGFudHJvL2hhbnRyb19nMl92cDlfZGVjLmMKPj4gQEAgLTE1Miw3ICsxNTIsNyBAQCBz dGF0aWMgdm9pZCBjb25maWdfb3V0cHV0KHN0cnVjdCBoYW50cm9fY3R4ICpjdHgsCj4+ICAgCWhh bnRyb19yZWdfd3JpdGUoY3R4LT5kZXYsICZnMl9vdXRfZGlzLCAwKTsKPj4gICAJaGFudHJvX3Jl Z193cml0ZShjdHgtPmRldiwgJmcyX291dHB1dF9mb3JtYXQsIDApOwo+PiAgIAo+PiAtCWx1bWFf YWRkciA9IHZiMl9kbWFfY29udGlnX3BsYW5lX2RtYV9hZGRyKCZkc3QtPmJhc2UudmIudmIyX2J1 ZiwKPiAwKTsKPj4gKwlsdW1hX2FkZHIgPSBoYW50cm9fZ2V0X2RlY19idWZfYWRkcihjdHgsICZk c3QtPmJhc2UudmIudmIyX2J1Zik7Cj4+ICAgCWhhbnRyb193cml0ZV9hZGRyKGN0eC0+ZGV2LCBH Ml9PVVRfTFVNQV9BRERSLCBsdW1hX2FkZHIpOwo+PiAgIAo+PiAgIAljaHJvbWFfYWRkciA9IGx1 bWFfYWRkciArIGNocm9tYV9vZmZzZXQoY3R4LCBkZWNfcGFyYW1zKTsKPj4gQEAgLTE5MSw3ICsx OTEsNyBAQCBzdGF0aWMgdm9pZCBjb25maWdfcmVmKHN0cnVjdCBoYW50cm9fY3R4ICpjdHgsCj4+ ICAgCWhhbnRyb19yZWdfd3JpdGUoY3R4LT5kZXYsICZyZWZfcmVnLT5ob3Jfc2NhbGUsIChyZWZ3 IDw8IDE0KSAvCj4gZHN0LT52cDkud2lkdGgpOwo+PiAgIAloYW50cm9fcmVnX3dyaXRlKGN0eC0+ ZGV2LCAmcmVmX3JlZy0+dmVyX3NjYWxlLCAocmVmaCA8PCAxNCkgLwo+IGRzdC0+dnA5LmhlaWdo dCk7Cj4+ICAgCj4+IC0JbHVtYV9hZGRyID0gdmIyX2RtYV9jb250aWdfcGxhbmVfZG1hX2FkZHIo JmJ1Zi0+YmFzZS52Yi52YjJfYnVmLAo+IDApOwo+PiArCWx1bWFfYWRkciA9IGhhbnRyb19nZXRf ZGVjX2J1Zl9hZGRyKGN0eCwgJmJ1Zi0+YmFzZS52Yi52YjJfYnVmKTsKPj4gICAJaGFudHJvX3dy aXRlX2FkZHIoY3R4LT5kZXYsIHJlZl9yZWctPnlfYmFzZSwgbHVtYV9hZGRyKTsKPj4gICAKPj4g ICAJY2hyb21hX2FkZHIgPSBsdW1hX2FkZHIgKyBjaHJvbWFfb2Zmc2V0KGN0eCwgZGVjX3BhcmFt cyk7Cj4+IEBAIC0yMzYsNyArMjM2LDcgQEAgc3RhdGljIHZvaWQgY29uZmlnX3JlZl9yZWdpc3Rl cnMoc3RydWN0IGhhbnRyb19jdHggKmN0eCwKPj4gICAJY29uZmlnX3JlZihjdHgsIGRzdCwgJnJl Zl9yZWdzWzFdLCBkZWNfcGFyYW1zLCBkZWNfcGFyYW1zLQo+PiBnb2xkZW5fZnJhbWVfdHMpOwo+ PiAgIAljb25maWdfcmVmKGN0eCwgZHN0LCAmcmVmX3JlZ3NbMl0sIGRlY19wYXJhbXMsIGRlY19w YXJhbXMtCj4+IGFsdF9mcmFtZV90cyk7Cj4+ICAgCj4+IC0JbXZfYWRkciA9IHZiMl9kbWFfY29u dGlnX3BsYW5lX2RtYV9hZGRyKCZtdl9yZWYtPmJhc2UudmIudmIyX2J1ZiwKPiAwKSArCj4+ICsJ bXZfYWRkciA9IGhhbnRyb19nZXRfZGVjX2J1Zl9hZGRyKGN0eCwgJm12X3JlZi0+YmFzZS52Yi52 YjJfYnVmKSArCj4+ICAgCQkgIG12X29mZnNldChjdHgsIGRlY19wYXJhbXMpOwo+PiAgIAloYW50 cm9fd3JpdGVfYWRkcihjdHgtPmRldiwgRzJfUkVGX01WX0FERFIoMCksIG12X2FkZHIpOwo+PiAg IAo+PiBkaWZmIC0tZ2l0IGEvZHJpdmVycy9zdGFnaW5nL21lZGlhL2hhbnRyby9oYW50cm9faHcu aCBiL2RyaXZlcnMvc3RhZ2luZy8KPiBtZWRpYS9oYW50cm8vaGFudHJvX2h3LmgKPj4gaW5kZXgg Mjk2MWQzOTlmZDYwLi4zZDRhNWRjMWU2ZDUgMTAwNjQ0Cj4+IC0tLSBhL2RyaXZlcnMvc3RhZ2lu Zy9tZWRpYS9oYW50cm8vaGFudHJvX2h3LmgKPj4gKysrIGIvZHJpdmVycy9zdGFnaW5nL21lZGlh L2hhbnRyby9oYW50cm9faHcuaAo+PiBAQCAtMjc0LDYgKzI3NCw3IEBAIGV4dGVybiBjb25zdCBz dHJ1Y3QgaGFudHJvX3ZhcmlhbnQgcmszMzk5X3ZwdV92YXJpYW50Owo+PiAgIGV4dGVybiBjb25z dCBzdHJ1Y3QgaGFudHJvX3ZhcmlhbnQgc2FtYTVkNF92ZGVjX3ZhcmlhbnQ7Cj4+ICAgCj4+ICAg ZXh0ZXJuIGNvbnN0IHN0cnVjdCBoYW50cm9fcG9zdHByb2Nfb3BzIGhhbnRyb19nMV9wb3N0cHJv Y19vcHM7Cj4+ICtleHRlcm4gY29uc3Qgc3RydWN0IGhhbnRyb19wb3N0cHJvY19vcHMgaGFudHJv X2cyX3Bvc3Rwcm9jX29wczsKPj4gICAKPj4gICBleHRlcm4gY29uc3QgdTMyIGhhbnRyb192cDhf ZGVjX21jX2ZpbHRlcls4XVs2XTsKPj4gICAKPj4gZGlmZiAtLWdpdCBhL2RyaXZlcnMvc3RhZ2lu Zy9tZWRpYS9oYW50cm8vaGFudHJvX3Bvc3Rwcm9jLmMgYi9kcml2ZXJzLwo+IHN0YWdpbmcvbWVk aWEvaGFudHJvL2hhbnRyb19wb3N0cHJvYy5jCj4+IGluZGV4IDQ1NDlhZWMwOGZlYi4uNzlhNjZk MDAxNzM4IDEwMDY0NAo+PiAtLS0gYS9kcml2ZXJzL3N0YWdpbmcvbWVkaWEvaGFudHJvL2hhbnRy b19wb3N0cHJvYy5jCj4+ICsrKyBiL2RyaXZlcnMvc3RhZ2luZy9tZWRpYS9oYW50cm8vaGFudHJv X3Bvc3Rwcm9jLmMKPj4gQEAgLTExLDYgKzExLDcgQEAKPj4gICAjaW5jbHVkZSAiaGFudHJvLmgi Cj4+ICAgI2luY2x1ZGUgImhhbnRyb19ody5oIgo+PiAgICNpbmNsdWRlICJoYW50cm9fZzFfcmVn cy5oIgo+PiArI2luY2x1ZGUgImhhbnRyb19nMl9yZWdzLmgiCj4+ICAgCj4+ICAgI2RlZmluZSBI QU5UUk9fUFBfUkVHX1dSSVRFKHZwdSwgcmVnX25hbWUsIHZhbCkgXAo+PiAgIHsgXAo+PiBAQCAt OTksNiArMTAwLDIxIEBAIHN0YXRpYyB2b2lkIGhhbnRyb19wb3N0cHJvY19nMV9lbmFibGUoc3Ry dWN0IGhhbnRyb19jdHgKPiAqY3R4KQo+PiAgIAlIQU5UUk9fUFBfUkVHX1dSSVRFKHZwdSwgZGlz cGxheV93aWR0aCwgY3R4LT5kc3RfZm10LndpZHRoKTsKPj4gICB9Cj4+ICAgCj4+ICtzdGF0aWMg dm9pZCBoYW50cm9fcG9zdHByb2NfZzJfZW5hYmxlKHN0cnVjdCBoYW50cm9fY3R4ICpjdHgpCj4+ ICt7Cj4+ICsJc3RydWN0IGhhbnRyb19kZXYgKnZwdSA9IGN0eC0+ZGV2Owo+PiArCXN0cnVjdCB2 YjJfdjRsMl9idWZmZXIgKmRzdF9idWY7Cj4+ICsJc2l6ZV90IGNocm9tYV9vZmZzZXQgPSBjdHgt PmRzdF9mbXQud2lkdGggKiBjdHgtPmRzdF9mbXQuaGVpZ2h0Owo+PiArCWRtYV9hZGRyX3QgZHN0 X2RtYTsKPj4gKwo+PiArCWRzdF9idWYgPSBoYW50cm9fZ2V0X2RzdF9idWYoY3R4KTsKPj4gKwlk c3RfZG1hID0gdmIyX2RtYV9jb250aWdfcGxhbmVfZG1hX2FkZHIoJmRzdF9idWYtPnZiMl9idWYs IDApOwo+PiArCj4+ICsJaGFudHJvX3dyaXRlX2FkZHIodnB1LCBHMl9SU19PVVRfTFVNQV9BRERS LCBkc3RfZG1hKTsKPj4gKwloYW50cm9fd3JpdGVfYWRkcih2cHUsIEcyX1JTX09VVF9DSFJPTUFf QUREUiwgZHN0X2RtYSArCj4gY2hyb21hX29mZnNldCk7Cj4+ICsJaGFudHJvX3JlZ193cml0ZSh2 cHUsICZnMl9vdXRfcnNfZSwgMSk7Cj4+ICt9Cj4+ICsKPj4gICB2b2lkIGhhbnRyb19wb3N0cHJv Y19mcmVlKHN0cnVjdCBoYW50cm9fY3R4ICpjdHgpCj4+ICAgewo+PiAgIAlzdHJ1Y3QgaGFudHJv X2RldiAqdnB1ID0gY3R4LT5kZXY7Cj4+IEBAIC0xMjcsNiArMTQzLDkgQEAgaW50IGhhbnRyb19w b3N0cHJvY19hbGxvYyhzdHJ1Y3QgaGFudHJvX2N0eCAqY3R4KQo+PiAgIAlpZiAoY3R4LT52cHVf c3JjX2ZtdC0+Zm91cmNjID09IFY0TDJfUElYX0ZNVF9IMjY0X1NMSUNFKQo+PiAgIAkJYnVmX3Np emUgKz0gaGFudHJvX2gyNjRfbXZfc2l6ZShjdHgtPmRzdF9mbXQud2lkdGgsCj4+ICAgCQkJCQkJ Y3R4LQo+PiBkc3RfZm10LmhlaWdodCk7Cj4+ICsJZWxzZSBpZiAoY3R4LT52cHVfc3JjX2ZtdC0+ Zm91cmNjID09IFY0TDJfUElYX0ZNVF9WUDlfRlJBTUUpCj4+ICsJCWJ1Zl9zaXplICs9IGhhbnRy b192cDlfbXZfc2l6ZShjdHgtPmRzdF9mbXQud2lkdGgsCj4+ICsJCQkJCSAgICAgICBjdHgtCj4+ IGRzdF9mbXQuaGVpZ2h0KTsKPj4gICAKPj4gICAJZm9yIChpID0gMDsgaSA8IG51bV9idWZmZXJz OyArK2kpIHsKPj4gICAJCXN0cnVjdCBoYW50cm9fYXV4X2J1ZiAqcHJpdiA9ICZjdHgtPnBvc3Rw cm9jLmRlY19xW2ldOwo+PiBAQCAtMTUyLDYgKzE3MSwxMyBAQCBzdGF0aWMgdm9pZCBoYW50cm9f cG9zdHByb2NfZzFfZGlzYWJsZShzdHJ1Y3QKPiBoYW50cm9fY3R4ICpjdHgpCj4+ICAgCUhBTlRS T19QUF9SRUdfV1JJVEVfUyh2cHUsIHBpcGVsaW5lX2VuLCAweDApOwo+PiAgIH0KPj4gICAKPj4g K3N0YXRpYyB2b2lkIGhhbnRyb19wb3N0cHJvY19nMl9kaXNhYmxlKHN0cnVjdCBoYW50cm9fY3R4 ICpjdHgpCj4+ICt7Cj4+ICsJc3RydWN0IGhhbnRyb19kZXYgKnZwdSA9IGN0eC0+ZGV2Owo+PiAr Cj4+ICsJaGFudHJvX3JlZ193cml0ZSh2cHUsICZnMl9vdXRfcnNfZSwgMCk7Cj4+ICt9Cj4+ICsK Pj4gICB2b2lkIGhhbnRyb19wb3N0cHJvY19kaXNhYmxlKHN0cnVjdCBoYW50cm9fY3R4ICpjdHgp Cj4+ICAgewo+PiAgIAlzdHJ1Y3QgaGFudHJvX2RldiAqdnB1ID0gY3R4LT5kZXY7Cj4+IEBAIC0x NzIsMyArMTk4LDggQEAgY29uc3Qgc3RydWN0IGhhbnRyb19wb3N0cHJvY19vcHMgaGFudHJvX2cx X3Bvc3Rwcm9jX29wcwo+ID0gewo+PiAgIAkuZW5hYmxlID0gaGFudHJvX3Bvc3Rwcm9jX2cxX2Vu YWJsZSwKPj4gICAJLmRpc2FibGUgPSBoYW50cm9fcG9zdHByb2NfZzFfZGlzYWJsZSwKPj4gICB9 Owo+PiArCj4+ICtjb25zdCBzdHJ1Y3QgaGFudHJvX3Bvc3Rwcm9jX29wcyBoYW50cm9fZzJfcG9z dHByb2Nfb3BzID0gewo+PiArCS5lbmFibGUgPSBoYW50cm9fcG9zdHByb2NfZzJfZW5hYmxlLAo+ PiArCS5kaXNhYmxlID0gaGFudHJvX3Bvc3Rwcm9jX2cyX2Rpc2FibGUsCj4+ICt9Owo+PiBkaWZm IC0tZ2l0IGEvZHJpdmVycy9zdGFnaW5nL21lZGlhL2hhbnRyby9pbXg4bV92cHVfaHcuYyBiL2Ry aXZlcnMvc3RhZ2luZy8KPiBtZWRpYS9oYW50cm8vaW14OG1fdnB1X2h3LmMKPj4gaW5kZXggNDU1 YTEwN2ZmYjAyLi4xYTQzZjZmY2VlZjkgMTAwNjQ0Cj4+IC0tLSBhL2RyaXZlcnMvc3RhZ2luZy9t ZWRpYS9oYW50cm8vaW14OG1fdnB1X2h3LmMKPj4gKysrIGIvZHJpdmVycy9zdGFnaW5nL21lZGlh L2hhbnRyby9pbXg4bV92cHVfaHcuYwo+PiBAQCAtMTMyLDYgKzEzMiwxNCBAQCBzdGF0aWMgY29u c3Qgc3RydWN0IGhhbnRyb19mbXQgaW14OG1fdnB1X2RlY19mbXRzW10gPSB7Cj4+ICAgCX0sCj4+ ICAgfTsKPj4gICAKPj4gK3N0YXRpYyBjb25zdCBzdHJ1Y3QgaGFudHJvX2ZtdCBpbXg4bV92cHVf ZzJfcG9zdHByb2NfZm10c1tdID0gewo+PiArCXsKPj4gKwkJLmZvdXJjYyA9IFY0TDJfUElYX0ZN VF9OVjEyLAo+PiArCQkuY29kZWNfbW9kZSA9IEhBTlRST19NT0RFX05PTkUsCj4+ICsJCS5wb3N0 cHJvY2Vzc2VkID0gdHJ1ZSwKPj4gKwl9LAo+PiArfTsKPj4gKwo+PiAgIHN0YXRpYyBjb25zdCBz dHJ1Y3QgaGFudHJvX2ZtdCBpbXg4bV92cHVfZzJfZGVjX2ZtdHNbXSA9IHsKPj4gICAJewo+PiAg IAkJLmZvdXJjYyA9IFY0TDJfUElYX0ZNVF9OVjEyXzRMNCwKPj4gQEAgLTMwMSw2ICszMDksOSBA QCBjb25zdCBzdHJ1Y3QgaGFudHJvX3ZhcmlhbnQgaW14OG1xX3ZwdV9nMl92YXJpYW50ID0gewo+ PiAgIAkuZGVjX29mZnNldCA9IDB4MCwKPj4gICAJLmRlY19mbXRzID0gaW14OG1fdnB1X2cyX2Rl Y19mbXRzLAo+PiAgIAkubnVtX2RlY19mbXRzID0gQVJSQVlfU0laRShpbXg4bV92cHVfZzJfZGVj X2ZtdHMpLAo+PiArCS5wb3N0cHJvY19mbXRzID0gaW14OG1fdnB1X2cyX3Bvc3Rwcm9jX2ZtdHMs Cj4+ICsJLm51bV9wb3N0cHJvY19mbXRzID0gQVJSQVlfU0laRShpbXg4bV92cHVfZzJfcG9zdHBy b2NfZm10cyksCj4+ICsJLnBvc3Rwcm9jX29wcyA9ICZoYW50cm9fZzJfcG9zdHByb2Nfb3BzLAo+ PiAgIAkuY29kZWMgPSBIQU5UUk9fSEVWQ19ERUNPREVSIHwgSEFOVFJPX1ZQOV9ERUNPREVSLAo+ PiAgIAkuY29kZWNfb3BzID0gaW14OG1xX3ZwdV9nMl9jb2RlY19vcHMsCj4+ICAgCS5pbml0ID0g aW14OG1xX3ZwdV9od19pbml0LAo+PiAtLSAKPj4gMi4xNy4xCj4+Cj4+Cj4gCj4gCgoKX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX18KTGludXgtcm9ja2NoaXAg bWFpbGluZyBsaXN0CkxpbnV4LXJvY2tjaGlwQGxpc3RzLmluZnJhZGVhZC5vcmcKaHR0cDovL2xp c3RzLmluZnJhZGVhZC5vcmcvbWFpbG1hbi9saXN0aW5mby9saW51eC1yb2NrY2hpcAo= From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 326EFC433FE for ; Fri, 15 Oct 2021 17:21:45 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id DE96161205 for ; Fri, 15 Oct 2021 17:21:44 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.4.1 mail.kernel.org DE96161205 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=collabora.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:Content-Type: Content-Transfer-Encoding:List-Subscribe:List-Help:List-Post:List-Archive: List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:Date:Message-ID:From: References:Cc:To:Subject:Reply-To:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=xg+OkjQnSr+93rK4Be1/yf2MNA9p00GI7JciOJZnxbw=; b=vRyWpTR5h4P1y7liYrnIDIHbsM HQYSUYEoRr3Cq/7THYTSPf550CTNQkK6Xx44VOwITTUgHgsUzr7QZXhPXMlBtqoBLCPtDYOhI8nhB 3iuB9/0trlaIAwruDgTEZNaoTmh9sawHhQnygIkkIhayWQ0a7dXm206JZzuvq6n4rTlP/riecHrlR 65tm8vilwTFE826BBdgnSCktQoWS/JJmFQq6c9LzPEUdYO645ltmf8tIOPEaRmzTvNpiBcZzwDVP3 5WSwESG+Vv9TkacLiZwUtZxKw/vRm9+6mWV++f6E+JK16ehuKfv9qElWVSmpkF6LNO9puZ0qkH4K/ bHP5eteA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1mbQsD-008I3Z-7x; Fri, 15 Oct 2021 17:20:02 +0000 Received: from bhuna.collabora.co.uk ([46.235.227.227]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1mbQs6-008I0O-9N; Fri, 15 Oct 2021 17:19:56 +0000 Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: andrzej.p) with ESMTPSA id 74A091F4502D Subject: Re: [PATCH v7 11/11] media: hantro: Support NV12 on the G2 core To: =?UTF-8?Q?Jernej_=c5=a0krabec?= , linux-media@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-rockchip@lists.infradead.org, linux-staging@lists.linux.dev Cc: Benjamin Gaignard , Boris Brezillon , Ezequiel Garcia , Fabio Estevam , Greg Kroah-Hartman , Hans Verkuil , Heiko Stuebner , Mauro Carvalho Chehab , Nicolas Dufresne , NXP Linux Team , Pengutronix Kernel Team , Philipp Zabel , Sascha Hauer , Shawn Guo , kernel@collabora.com, Ezequiel Garcia References: <20210929160439.6601-1-andrzej.p@collabora.com> <20210929160439.6601-12-andrzej.p@collabora.com> <3448839.R56niFO833@kista> From: Andrzej Pietrasiewicz Message-ID: <84fd4395-5cac-c933-7639-dd3cd844a9cf@collabora.com> Date: Fri, 15 Oct 2021 19:19:47 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.13.0 MIME-Version: 1.0 In-Reply-To: <3448839.R56niFO833@kista> Content-Language: en-US X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20211015_101954_626044_AF8AE156 X-CRM114-Status: GOOD ( 30.70 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Transfer-Encoding: base64 Content-Type: text/plain; charset="utf-8"; Format="flowed" Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org SGkgSmVybmVqLAoKVyBkbml1IDE0LjEwLjIwMjEgb8KgMTk6NDIsIEplcm5laiDFoGtyYWJlYyBw aXN6ZToKPiBIaSBBbmRyemVqIQo+IAo+IERuZSBzcmVkYSwgMjkuIHNlcHRlbWJlciAyMDIxIG9i IDE4OjA0OjM5IENFU1QgamUgQW5kcnplaiBQaWV0cmFzaWV3aWN6Cj4gbmFwaXNhbChhKToKPj4g VGhlIEcyIGRlY29kZXIgYmxvY2sgcHJvZHVjZXMgTlYxMiA0eDQgdGlsZWQgZm9ybWF0IChOVjEy XzRMNCkuCj4+IEVuYWJsZSB0aGUgRzIgcG9zdC1wcm9jZXNzb3IgYmxvY2ssIGluIG9yZGVyIHRv IHByb2R1Y2UgcmVndWxhciBOVjEyLgo+Pgo+PiBUaGUgbG9naWMgaW4gaGFudHJvX3Bvc3Rwcm9j LmMgaXMgbGV2ZXJhZ2VkIHRvIHRha2UgY2FyZSBvZiBhbGxvY2F0aW5nCj4+IHRoZSBleHRyYSBi dWZmZXJzIGFuZCBjb25maWd1cmUgdGhlIHBvc3QtcHJvY2Vzc29yLCB3aGljaCBpcwo+PiBzaWdu aWZpY2FudGx5IHNpbXBsZXIgdGhhbiB0aGUgb25lIG9uIHRoZSBHMS4KPiAKPiBRdWljayBzdW1t YXJ5IG9mIGRpc2N1c3Npb24gb24gTGlicmVFTEVDIFNsYWNrOgo+IFdoZW4gdXNpbmcgTlYxMiBm b3JtYXQgb24gQWxsd2lubmVyIEg2IHZhcmlhbnQgb2YgRzIgKG5lZWRzIHNvbWUgZHJpdmVyCj4g Y2hhbmdlcyksIEkgZ2V0IGZyYW1lcyBvdXQgb2Ygb3JkZXIuIElmIEkgdXNlIG5hdGl2ZSBOVjEy IHRpbGVkIGZvcm1hdCwgZnJhbWVzCj4gYXJlIG9yZGVyZWQgY29ycmVjdGx5Lgo+IAo+IEN1cnJl bnRseSBJJ20gbm90IHN1cmUgaWYgdGhpcyBpcyBpc3N1ZSB3aXRoIG15IGNoYW5nZXMgb3IgaXMg dGhpcyBnZW5lcmFsCj4gaXNzdWUuCj4gCj4gSSB3b3VsZCBiZSBncmF0ZWZ1bCBpZiBhbnlvbmUg Y2FuIHRlc3QgZnJhbWUgb3JkZXIgd2l0aCBhbmQgd2l0aG91dAo+IHBvc3Rwcm9jZXNzaW5nIGVu YWJsZWQgb24gaW14OC4gVGFrZSBzb21lIGR5bmFtaWMgdmlkZW8gd2l0aCBhIGxvdCBvZiBzaG9y dAo+IHNjZW5lcy4gSXQncyBwcmV0dHkgb2J2aW91cyB3aGVuIGZyYW1lcyBhcmUgb3V0IG9mIG9y ZGVyLgo+IAoKSSBjaGVja2VkIG9uIGlteDggYW5kIGNhbm5vdCBvYnNlcnZlIGFueSBzdWNoIGFy dGlmYWN0cy4KCkFuZHJ6ZWoKCj4gSG93ZXZlciwgZ2l2ZW4gdGhhdCBmcmFtZXMgdGhlbXNlbGYg YXJlIGNvcnJlY3RseSBkZWNvZGVkIGFuZCB3aXRob3V0Cj4gcG9zdHByb2Nlc3NpbmcgaW4gcmln aHQgb3JkZXIsIHRoYXQgc2hvdWxkbid0IGJsb2NrIG1lcmdpbmcgcHJldmlvdXMgcGF0Y2hlcy4K PiBJIHRyaWVkIGZldyBkaWZmZXJlbnQgdmlkZW9zIGFuZCBmcmFtZXMgd2VyZSBhbGwgZGVjb2Rl ZCBjb3JyZWN0bHkuCj4gCj4gQmVzdCByZWdhcmRzLAo+IEplcm5lago+IAo+Pgo+PiBTaWduZWQt b2ZmLWJ5OiBFemVxdWllbCBHYXJjaWEgPGV6ZXF1aWVsQGNvbGxhYm9yYS5jb20+Cj4+IFNpZ25l ZC1vZmYtYnk6IEFuZHJ6ZWogUGlldHJhc2lld2ljeiA8YW5kcnplai5wQGNvbGxhYm9yYS5jb20+ Cj4+IC0tLQo+PiAgIC4uLi9zdGFnaW5nL21lZGlhL2hhbnRyby9oYW50cm9fZzJfdnA5X2RlYy5j ICB8ICA2ICsrLS0KPj4gICBkcml2ZXJzL3N0YWdpbmcvbWVkaWEvaGFudHJvL2hhbnRyb19ody5o ICAgICAgfCAgMSArCj4+ICAgLi4uL3N0YWdpbmcvbWVkaWEvaGFudHJvL2hhbnRyb19wb3N0cHJv Yy5jICAgIHwgMzEgKysrKysrKysrKysrKysrKysrKwo+PiAgIGRyaXZlcnMvc3RhZ2luZy9tZWRp YS9oYW50cm8vaW14OG1fdnB1X2h3LmMgICB8IDExICsrKysrKysKPj4gICA0IGZpbGVzIGNoYW5n ZWQsIDQ2IGluc2VydGlvbnMoKyksIDMgZGVsZXRpb25zKC0pCj4+Cj4+IGRpZmYgLS1naXQgYS9k cml2ZXJzL3N0YWdpbmcvbWVkaWEvaGFudHJvL2hhbnRyb19nMl92cDlfZGVjLmMgYi9kcml2ZXJz Lwo+IHN0YWdpbmcvbWVkaWEvaGFudHJvL2hhbnRyb19nMl92cDlfZGVjLmMKPj4gaW5kZXggN2Y4 MjdiOWYwMTMzLi4xYTI2YmU3MmM4NzggMTAwNjQ0Cj4+IC0tLSBhL2RyaXZlcnMvc3RhZ2luZy9t ZWRpYS9oYW50cm8vaGFudHJvX2cyX3ZwOV9kZWMuYwo+PiArKysgYi9kcml2ZXJzL3N0YWdpbmcv bWVkaWEvaGFudHJvL2hhbnRyb19nMl92cDlfZGVjLmMKPj4gQEAgLTE1Miw3ICsxNTIsNyBAQCBz dGF0aWMgdm9pZCBjb25maWdfb3V0cHV0KHN0cnVjdCBoYW50cm9fY3R4ICpjdHgsCj4+ICAgCWhh bnRyb19yZWdfd3JpdGUoY3R4LT5kZXYsICZnMl9vdXRfZGlzLCAwKTsKPj4gICAJaGFudHJvX3Jl Z193cml0ZShjdHgtPmRldiwgJmcyX291dHB1dF9mb3JtYXQsIDApOwo+PiAgIAo+PiAtCWx1bWFf YWRkciA9IHZiMl9kbWFfY29udGlnX3BsYW5lX2RtYV9hZGRyKCZkc3QtPmJhc2UudmIudmIyX2J1 ZiwKPiAwKTsKPj4gKwlsdW1hX2FkZHIgPSBoYW50cm9fZ2V0X2RlY19idWZfYWRkcihjdHgsICZk c3QtPmJhc2UudmIudmIyX2J1Zik7Cj4+ICAgCWhhbnRyb193cml0ZV9hZGRyKGN0eC0+ZGV2LCBH Ml9PVVRfTFVNQV9BRERSLCBsdW1hX2FkZHIpOwo+PiAgIAo+PiAgIAljaHJvbWFfYWRkciA9IGx1 bWFfYWRkciArIGNocm9tYV9vZmZzZXQoY3R4LCBkZWNfcGFyYW1zKTsKPj4gQEAgLTE5MSw3ICsx OTEsNyBAQCBzdGF0aWMgdm9pZCBjb25maWdfcmVmKHN0cnVjdCBoYW50cm9fY3R4ICpjdHgsCj4+ ICAgCWhhbnRyb19yZWdfd3JpdGUoY3R4LT5kZXYsICZyZWZfcmVnLT5ob3Jfc2NhbGUsIChyZWZ3 IDw8IDE0KSAvCj4gZHN0LT52cDkud2lkdGgpOwo+PiAgIAloYW50cm9fcmVnX3dyaXRlKGN0eC0+ ZGV2LCAmcmVmX3JlZy0+dmVyX3NjYWxlLCAocmVmaCA8PCAxNCkgLwo+IGRzdC0+dnA5LmhlaWdo dCk7Cj4+ICAgCj4+IC0JbHVtYV9hZGRyID0gdmIyX2RtYV9jb250aWdfcGxhbmVfZG1hX2FkZHIo JmJ1Zi0+YmFzZS52Yi52YjJfYnVmLAo+IDApOwo+PiArCWx1bWFfYWRkciA9IGhhbnRyb19nZXRf ZGVjX2J1Zl9hZGRyKGN0eCwgJmJ1Zi0+YmFzZS52Yi52YjJfYnVmKTsKPj4gICAJaGFudHJvX3dy aXRlX2FkZHIoY3R4LT5kZXYsIHJlZl9yZWctPnlfYmFzZSwgbHVtYV9hZGRyKTsKPj4gICAKPj4g ICAJY2hyb21hX2FkZHIgPSBsdW1hX2FkZHIgKyBjaHJvbWFfb2Zmc2V0KGN0eCwgZGVjX3BhcmFt cyk7Cj4+IEBAIC0yMzYsNyArMjM2LDcgQEAgc3RhdGljIHZvaWQgY29uZmlnX3JlZl9yZWdpc3Rl cnMoc3RydWN0IGhhbnRyb19jdHggKmN0eCwKPj4gICAJY29uZmlnX3JlZihjdHgsIGRzdCwgJnJl Zl9yZWdzWzFdLCBkZWNfcGFyYW1zLCBkZWNfcGFyYW1zLQo+PiBnb2xkZW5fZnJhbWVfdHMpOwo+ PiAgIAljb25maWdfcmVmKGN0eCwgZHN0LCAmcmVmX3JlZ3NbMl0sIGRlY19wYXJhbXMsIGRlY19w YXJhbXMtCj4+IGFsdF9mcmFtZV90cyk7Cj4+ICAgCj4+IC0JbXZfYWRkciA9IHZiMl9kbWFfY29u dGlnX3BsYW5lX2RtYV9hZGRyKCZtdl9yZWYtPmJhc2UudmIudmIyX2J1ZiwKPiAwKSArCj4+ICsJ bXZfYWRkciA9IGhhbnRyb19nZXRfZGVjX2J1Zl9hZGRyKGN0eCwgJm12X3JlZi0+YmFzZS52Yi52 YjJfYnVmKSArCj4+ICAgCQkgIG12X29mZnNldChjdHgsIGRlY19wYXJhbXMpOwo+PiAgIAloYW50 cm9fd3JpdGVfYWRkcihjdHgtPmRldiwgRzJfUkVGX01WX0FERFIoMCksIG12X2FkZHIpOwo+PiAg IAo+PiBkaWZmIC0tZ2l0IGEvZHJpdmVycy9zdGFnaW5nL21lZGlhL2hhbnRyby9oYW50cm9faHcu aCBiL2RyaXZlcnMvc3RhZ2luZy8KPiBtZWRpYS9oYW50cm8vaGFudHJvX2h3LmgKPj4gaW5kZXgg Mjk2MWQzOTlmZDYwLi4zZDRhNWRjMWU2ZDUgMTAwNjQ0Cj4+IC0tLSBhL2RyaXZlcnMvc3RhZ2lu Zy9tZWRpYS9oYW50cm8vaGFudHJvX2h3LmgKPj4gKysrIGIvZHJpdmVycy9zdGFnaW5nL21lZGlh L2hhbnRyby9oYW50cm9faHcuaAo+PiBAQCAtMjc0LDYgKzI3NCw3IEBAIGV4dGVybiBjb25zdCBz dHJ1Y3QgaGFudHJvX3ZhcmlhbnQgcmszMzk5X3ZwdV92YXJpYW50Owo+PiAgIGV4dGVybiBjb25z dCBzdHJ1Y3QgaGFudHJvX3ZhcmlhbnQgc2FtYTVkNF92ZGVjX3ZhcmlhbnQ7Cj4+ICAgCj4+ICAg ZXh0ZXJuIGNvbnN0IHN0cnVjdCBoYW50cm9fcG9zdHByb2Nfb3BzIGhhbnRyb19nMV9wb3N0cHJv Y19vcHM7Cj4+ICtleHRlcm4gY29uc3Qgc3RydWN0IGhhbnRyb19wb3N0cHJvY19vcHMgaGFudHJv X2cyX3Bvc3Rwcm9jX29wczsKPj4gICAKPj4gICBleHRlcm4gY29uc3QgdTMyIGhhbnRyb192cDhf ZGVjX21jX2ZpbHRlcls4XVs2XTsKPj4gICAKPj4gZGlmZiAtLWdpdCBhL2RyaXZlcnMvc3RhZ2lu Zy9tZWRpYS9oYW50cm8vaGFudHJvX3Bvc3Rwcm9jLmMgYi9kcml2ZXJzLwo+IHN0YWdpbmcvbWVk aWEvaGFudHJvL2hhbnRyb19wb3N0cHJvYy5jCj4+IGluZGV4IDQ1NDlhZWMwOGZlYi4uNzlhNjZk MDAxNzM4IDEwMDY0NAo+PiAtLS0gYS9kcml2ZXJzL3N0YWdpbmcvbWVkaWEvaGFudHJvL2hhbnRy b19wb3N0cHJvYy5jCj4+ICsrKyBiL2RyaXZlcnMvc3RhZ2luZy9tZWRpYS9oYW50cm8vaGFudHJv X3Bvc3Rwcm9jLmMKPj4gQEAgLTExLDYgKzExLDcgQEAKPj4gICAjaW5jbHVkZSAiaGFudHJvLmgi Cj4+ICAgI2luY2x1ZGUgImhhbnRyb19ody5oIgo+PiAgICNpbmNsdWRlICJoYW50cm9fZzFfcmVn cy5oIgo+PiArI2luY2x1ZGUgImhhbnRyb19nMl9yZWdzLmgiCj4+ICAgCj4+ICAgI2RlZmluZSBI QU5UUk9fUFBfUkVHX1dSSVRFKHZwdSwgcmVnX25hbWUsIHZhbCkgXAo+PiAgIHsgXAo+PiBAQCAt OTksNiArMTAwLDIxIEBAIHN0YXRpYyB2b2lkIGhhbnRyb19wb3N0cHJvY19nMV9lbmFibGUoc3Ry dWN0IGhhbnRyb19jdHgKPiAqY3R4KQo+PiAgIAlIQU5UUk9fUFBfUkVHX1dSSVRFKHZwdSwgZGlz cGxheV93aWR0aCwgY3R4LT5kc3RfZm10LndpZHRoKTsKPj4gICB9Cj4+ICAgCj4+ICtzdGF0aWMg dm9pZCBoYW50cm9fcG9zdHByb2NfZzJfZW5hYmxlKHN0cnVjdCBoYW50cm9fY3R4ICpjdHgpCj4+ ICt7Cj4+ICsJc3RydWN0IGhhbnRyb19kZXYgKnZwdSA9IGN0eC0+ZGV2Owo+PiArCXN0cnVjdCB2 YjJfdjRsMl9idWZmZXIgKmRzdF9idWY7Cj4+ICsJc2l6ZV90IGNocm9tYV9vZmZzZXQgPSBjdHgt PmRzdF9mbXQud2lkdGggKiBjdHgtPmRzdF9mbXQuaGVpZ2h0Owo+PiArCWRtYV9hZGRyX3QgZHN0 X2RtYTsKPj4gKwo+PiArCWRzdF9idWYgPSBoYW50cm9fZ2V0X2RzdF9idWYoY3R4KTsKPj4gKwlk c3RfZG1hID0gdmIyX2RtYV9jb250aWdfcGxhbmVfZG1hX2FkZHIoJmRzdF9idWYtPnZiMl9idWYs IDApOwo+PiArCj4+ICsJaGFudHJvX3dyaXRlX2FkZHIodnB1LCBHMl9SU19PVVRfTFVNQV9BRERS LCBkc3RfZG1hKTsKPj4gKwloYW50cm9fd3JpdGVfYWRkcih2cHUsIEcyX1JTX09VVF9DSFJPTUFf QUREUiwgZHN0X2RtYSArCj4gY2hyb21hX29mZnNldCk7Cj4+ICsJaGFudHJvX3JlZ193cml0ZSh2 cHUsICZnMl9vdXRfcnNfZSwgMSk7Cj4+ICt9Cj4+ICsKPj4gICB2b2lkIGhhbnRyb19wb3N0cHJv Y19mcmVlKHN0cnVjdCBoYW50cm9fY3R4ICpjdHgpCj4+ICAgewo+PiAgIAlzdHJ1Y3QgaGFudHJv X2RldiAqdnB1ID0gY3R4LT5kZXY7Cj4+IEBAIC0xMjcsNiArMTQzLDkgQEAgaW50IGhhbnRyb19w b3N0cHJvY19hbGxvYyhzdHJ1Y3QgaGFudHJvX2N0eCAqY3R4KQo+PiAgIAlpZiAoY3R4LT52cHVf c3JjX2ZtdC0+Zm91cmNjID09IFY0TDJfUElYX0ZNVF9IMjY0X1NMSUNFKQo+PiAgIAkJYnVmX3Np emUgKz0gaGFudHJvX2gyNjRfbXZfc2l6ZShjdHgtPmRzdF9mbXQud2lkdGgsCj4+ICAgCQkJCQkJ Y3R4LQo+PiBkc3RfZm10LmhlaWdodCk7Cj4+ICsJZWxzZSBpZiAoY3R4LT52cHVfc3JjX2ZtdC0+ Zm91cmNjID09IFY0TDJfUElYX0ZNVF9WUDlfRlJBTUUpCj4+ICsJCWJ1Zl9zaXplICs9IGhhbnRy b192cDlfbXZfc2l6ZShjdHgtPmRzdF9mbXQud2lkdGgsCj4+ICsJCQkJCSAgICAgICBjdHgtCj4+ IGRzdF9mbXQuaGVpZ2h0KTsKPj4gICAKPj4gICAJZm9yIChpID0gMDsgaSA8IG51bV9idWZmZXJz OyArK2kpIHsKPj4gICAJCXN0cnVjdCBoYW50cm9fYXV4X2J1ZiAqcHJpdiA9ICZjdHgtPnBvc3Rw cm9jLmRlY19xW2ldOwo+PiBAQCAtMTUyLDYgKzE3MSwxMyBAQCBzdGF0aWMgdm9pZCBoYW50cm9f cG9zdHByb2NfZzFfZGlzYWJsZShzdHJ1Y3QKPiBoYW50cm9fY3R4ICpjdHgpCj4+ICAgCUhBTlRS T19QUF9SRUdfV1JJVEVfUyh2cHUsIHBpcGVsaW5lX2VuLCAweDApOwo+PiAgIH0KPj4gICAKPj4g K3N0YXRpYyB2b2lkIGhhbnRyb19wb3N0cHJvY19nMl9kaXNhYmxlKHN0cnVjdCBoYW50cm9fY3R4 ICpjdHgpCj4+ICt7Cj4+ICsJc3RydWN0IGhhbnRyb19kZXYgKnZwdSA9IGN0eC0+ZGV2Owo+PiAr Cj4+ICsJaGFudHJvX3JlZ193cml0ZSh2cHUsICZnMl9vdXRfcnNfZSwgMCk7Cj4+ICt9Cj4+ICsK Pj4gICB2b2lkIGhhbnRyb19wb3N0cHJvY19kaXNhYmxlKHN0cnVjdCBoYW50cm9fY3R4ICpjdHgp Cj4+ICAgewo+PiAgIAlzdHJ1Y3QgaGFudHJvX2RldiAqdnB1ID0gY3R4LT5kZXY7Cj4+IEBAIC0x NzIsMyArMTk4LDggQEAgY29uc3Qgc3RydWN0IGhhbnRyb19wb3N0cHJvY19vcHMgaGFudHJvX2cx X3Bvc3Rwcm9jX29wcwo+ID0gewo+PiAgIAkuZW5hYmxlID0gaGFudHJvX3Bvc3Rwcm9jX2cxX2Vu YWJsZSwKPj4gICAJLmRpc2FibGUgPSBoYW50cm9fcG9zdHByb2NfZzFfZGlzYWJsZSwKPj4gICB9 Owo+PiArCj4+ICtjb25zdCBzdHJ1Y3QgaGFudHJvX3Bvc3Rwcm9jX29wcyBoYW50cm9fZzJfcG9z dHByb2Nfb3BzID0gewo+PiArCS5lbmFibGUgPSBoYW50cm9fcG9zdHByb2NfZzJfZW5hYmxlLAo+ PiArCS5kaXNhYmxlID0gaGFudHJvX3Bvc3Rwcm9jX2cyX2Rpc2FibGUsCj4+ICt9Owo+PiBkaWZm IC0tZ2l0IGEvZHJpdmVycy9zdGFnaW5nL21lZGlhL2hhbnRyby9pbXg4bV92cHVfaHcuYyBiL2Ry aXZlcnMvc3RhZ2luZy8KPiBtZWRpYS9oYW50cm8vaW14OG1fdnB1X2h3LmMKPj4gaW5kZXggNDU1 YTEwN2ZmYjAyLi4xYTQzZjZmY2VlZjkgMTAwNjQ0Cj4+IC0tLSBhL2RyaXZlcnMvc3RhZ2luZy9t ZWRpYS9oYW50cm8vaW14OG1fdnB1X2h3LmMKPj4gKysrIGIvZHJpdmVycy9zdGFnaW5nL21lZGlh L2hhbnRyby9pbXg4bV92cHVfaHcuYwo+PiBAQCAtMTMyLDYgKzEzMiwxNCBAQCBzdGF0aWMgY29u c3Qgc3RydWN0IGhhbnRyb19mbXQgaW14OG1fdnB1X2RlY19mbXRzW10gPSB7Cj4+ICAgCX0sCj4+ ICAgfTsKPj4gICAKPj4gK3N0YXRpYyBjb25zdCBzdHJ1Y3QgaGFudHJvX2ZtdCBpbXg4bV92cHVf ZzJfcG9zdHByb2NfZm10c1tdID0gewo+PiArCXsKPj4gKwkJLmZvdXJjYyA9IFY0TDJfUElYX0ZN VF9OVjEyLAo+PiArCQkuY29kZWNfbW9kZSA9IEhBTlRST19NT0RFX05PTkUsCj4+ICsJCS5wb3N0 cHJvY2Vzc2VkID0gdHJ1ZSwKPj4gKwl9LAo+PiArfTsKPj4gKwo+PiAgIHN0YXRpYyBjb25zdCBz dHJ1Y3QgaGFudHJvX2ZtdCBpbXg4bV92cHVfZzJfZGVjX2ZtdHNbXSA9IHsKPj4gICAJewo+PiAg IAkJLmZvdXJjYyA9IFY0TDJfUElYX0ZNVF9OVjEyXzRMNCwKPj4gQEAgLTMwMSw2ICszMDksOSBA QCBjb25zdCBzdHJ1Y3QgaGFudHJvX3ZhcmlhbnQgaW14OG1xX3ZwdV9nMl92YXJpYW50ID0gewo+ PiAgIAkuZGVjX29mZnNldCA9IDB4MCwKPj4gICAJLmRlY19mbXRzID0gaW14OG1fdnB1X2cyX2Rl Y19mbXRzLAo+PiAgIAkubnVtX2RlY19mbXRzID0gQVJSQVlfU0laRShpbXg4bV92cHVfZzJfZGVj X2ZtdHMpLAo+PiArCS5wb3N0cHJvY19mbXRzID0gaW14OG1fdnB1X2cyX3Bvc3Rwcm9jX2ZtdHMs Cj4+ICsJLm51bV9wb3N0cHJvY19mbXRzID0gQVJSQVlfU0laRShpbXg4bV92cHVfZzJfcG9zdHBy b2NfZm10cyksCj4+ICsJLnBvc3Rwcm9jX29wcyA9ICZoYW50cm9fZzJfcG9zdHByb2Nfb3BzLAo+ PiAgIAkuY29kZWMgPSBIQU5UUk9fSEVWQ19ERUNPREVSIHwgSEFOVFJPX1ZQOV9ERUNPREVSLAo+ PiAgIAkuY29kZWNfb3BzID0gaW14OG1xX3ZwdV9nMl9jb2RlY19vcHMsCj4+ICAgCS5pbml0ID0g aW14OG1xX3ZwdV9od19pbml0LAo+PiAtLSAKPj4gMi4xNy4xCj4+Cj4+Cj4gCj4gCgoKX19fX19f X19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX18KbGludXgtYXJtLWtlcm5l bCBtYWlsaW5nIGxpc3QKbGludXgtYXJtLWtlcm5lbEBsaXN0cy5pbmZyYWRlYWQub3JnCmh0dHA6 Ly9saXN0cy5pbmZyYWRlYWQub3JnL21haWxtYW4vbGlzdGluZm8vbGludXgtYXJtLWtlcm5lbAo=