Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1225170imm; Wed, 1 Aug 2018 12:13:57 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdHGAJe5QQKQ+6zOgFvLnQzcqFbUnH66kFAShoXDGSJ5KKSN3zwNbE952rI+lBJtDohURMn X-Received: by 2002:a62:d544:: with SMTP id d65-v6mr27834771pfg.107.1533150837365; Wed, 01 Aug 2018 12:13:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533150837; cv=none; d=google.com; s=arc-20160816; b=0VemlZsRf2NuFPDOgscYBJDiSw+19/jW4nu6weufcFerVQVbe7mW3qg1IdcV+LRZC9 lPdZT93gLoy/1fMOJtFTOeG+mqBornycng8GFnwVh8zbPl2QiFeWncYBy2iw92NNIUhO vKZ6HSu5W6qge88iM1eQT4LcTvoF2wz3kaF3IkCxYEElDpPbrSC7PiDWrJ8mTgD87QH/ q3nlr6OrGZ/KXtFSVhpYjuBxzlLS0FC7uBsFg6xIesFu4AjgtKtsB1/5EMfghkTBxZwa grK48ZcBBv7CeCEMnJXaRpplA3CO0iH72Rvh8DLqY3sYgVi0ogfQLoB4UkJ0jMHIiZpT qtGw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=4XgQr0v93BmMi0+ykyaOvN9BFSFtuq3EFayKXlWi74s=; b=qzQBOlGVuUYywszQled9wpQCrJ+MDzD8yaV6VzB0uR4b5c2oDyQYx24RiXnEV/H/mK XsB3bm0Bi40Ax150QKXrve1BqWfvNF2TXzbLOZRa5X4G54TnfJ4EmtT2vo8XAVvegycd RcY+yd7isXNASRJcwkDZYhcNhREKneBbH+qp1xTM5k1kO5jT+CuzachdL8DDJllGYtmL 8MGS12ZHDDQOzvo+xCFEsOJgy9bVwSzZ7n0rCXq33y5teTCkj31rwBE/Ke9d4kVpEm+B IPxlXO17qABLXwk2uVa+ekEsHQH2gjmtk6VTYPKw6q24Ue2uk2shBpx2M1Btt9Tfpdb0 i/wg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=bEa93Ifb; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n19-v6si14502748plp.298.2018.08.01.12.13.42; Wed, 01 Aug 2018 12:13:57 -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=@gmail.com header.s=20161025 header.b=bEa93Ifb; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387700AbeHAVAA (ORCPT + 99 others); Wed, 1 Aug 2018 17:00:00 -0400 Received: from mail-pl0-f68.google.com ([209.85.160.68]:37089 "EHLO mail-pl0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727684AbeHAU76 (ORCPT ); Wed, 1 Aug 2018 16:59:58 -0400 Received: by mail-pl0-f68.google.com with SMTP id d5-v6so3693498pll.4; Wed, 01 Aug 2018 12:12:44 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references; bh=4XgQr0v93BmMi0+ykyaOvN9BFSFtuq3EFayKXlWi74s=; b=bEa93Ifb9Faj5Wl5K9X/HWUc334Za9fdns9J+zj68XBgCqCcWzrNyIbLvoW7/b6XPY JOUiQYnhDmM3V6Do0Qnjn9eJLZQljDWVC7QwhkbAGg+q0vuWLrcMDp7Ucgr1X9+3Q7SZ 9jtVYflW4bBP2z3AW17squlhZ/eF4NIr4+xX9rDT8ot6/0X4m4PtI2W68t0tUQxlqcqM C4R+Oz/zoPcG9BvodU8mUEgLwPdXuzeJB2+8ALzmzCCNxCGc9oxr2vo7e53v1Nmom1uF Ixu4ykgPKDbPm2JrXJ0wPPuz8uRQKuxw5XxqN5w+8jGhx84J3e4TCCc16kvuk4vm7hkR kBNg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=4XgQr0v93BmMi0+ykyaOvN9BFSFtuq3EFayKXlWi74s=; b=uROCv0y8WWH/m2OqNjNTNGP+tB8Ne8x+Kckos/4bk1Kedjf90sm7PXDMTYvN4sgqDr HzvYCV6vi0yygUm1YQn+wV8nNeqvFnPFxHijNT/0eJWj53/qv+m0t2ug5yUgIXqwVM8h suF6koRrZ9FOLHjaABBTPJmeEn23apVnG1SCDCzQC5g3QR45ncTLr/jxJBaMM+cCUmft Hf2yHGY+5oPi0c7GvDLVWayFmCgVOrTkvN9hPn5VSJLOpolplBGOh+xC000oHIqUVLzi XzfQsfgnEpwORBNaQjhoivwD25y8HAYhDB750gjWIeXTWG/tJ/3helQen6FcvU3FTm5S CzXg== X-Gm-Message-State: AOUpUlF4Bt3UwkoONskcxCCpvlFrT9ZrEZsdify7lvy/UhEkK86o7P6T tqsvw/R//LgacGE4Isy7LTKdX6fP X-Received: by 2002:a17:902:bd82:: with SMTP id q2-v6mr9484396pls.178.1533150764185; Wed, 01 Aug 2018 12:12:44 -0700 (PDT) Received: from mappy.world.mentorg.com (c-24-5-209-231.hsd1.ca.comcast.net. [24.5.209.231]) by smtp.googlemail.com with ESMTPSA id u42-v6sm31171336pgn.1.2018.08.01.12.12.42 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Wed, 01 Aug 2018 12:12:43 -0700 (PDT) From: Steve Longerbeam X-Google-Original-From: Steve Longerbeam To: linux-media@vger.kernel.org Cc: Philipp Zabel , Steve Longerbeam , dri-devel@lists.freedesktop.org (open list:DRM DRIVERS FOR FREESCALE IMX), linux-kernel@vger.kernel.org (open list) Subject: [PATCH v3 05/14] gpu: ipu-v3: Allow negative offsets for interlaced scanning Date: Wed, 1 Aug 2018 12:12:18 -0700 Message-Id: <1533150747-30677-6-git-send-email-steve_longerbeam@mentor.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1533150747-30677-1-git-send-email-steve_longerbeam@mentor.com> References: <1533150747-30677-1-git-send-email-steve_longerbeam@mentor.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Philipp Zabel The IPU also supports interlaced buffers that start with the bottom field. To achieve this, the the base address EBA has to be increased by a stride length and the interlace offset ILO has to be set to the negative stride. Signed-off-by: Philipp Zabel Signed-off-by: Steve Longerbeam --- drivers/gpu/ipu-v3/ipu-cpmem.c | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/drivers/gpu/ipu-v3/ipu-cpmem.c b/drivers/gpu/ipu-v3/ipu-cpmem.c index e68e473..8cd9e37 100644 --- a/drivers/gpu/ipu-v3/ipu-cpmem.c +++ b/drivers/gpu/ipu-v3/ipu-cpmem.c @@ -269,9 +269,20 @@ EXPORT_SYMBOL_GPL(ipu_cpmem_set_uv_offset); void ipu_cpmem_interlaced_scan(struct ipuv3_channel *ch, int stride) { + u32 ilo, sly; + + if (stride < 0) { + stride = -stride; + ilo = 0x100000 - (stride / 8); + } else { + ilo = stride / 8; + } + + sly = (stride * 2) - 1; + ipu_ch_param_write_field(ch, IPU_FIELD_SO, 1); - ipu_ch_param_write_field(ch, IPU_FIELD_ILO, stride / 8); - ipu_ch_param_write_field(ch, IPU_FIELD_SLY, (stride * 2) - 1); + ipu_ch_param_write_field(ch, IPU_FIELD_ILO, ilo); + ipu_ch_param_write_field(ch, IPU_FIELD_SLY, sly); }; EXPORT_SYMBOL_GPL(ipu_cpmem_interlaced_scan); -- 2.7.4