Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp680893ybi; Fri, 2 Aug 2019 02:31:13 -0700 (PDT) X-Google-Smtp-Source: APXvYqxbam0uQLbVoMVXPQLVNc63A2D0h3cLXIwe6Cc3byyt5J2Fhe5DvGuzjb+NfXesClLES3Rk X-Received: by 2002:a17:90a:2008:: with SMTP id n8mr3439538pjc.4.1564738273467; Fri, 02 Aug 2019 02:31:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564738273; cv=none; d=google.com; s=arc-20160816; b=slIJVCqcK0gvyk8W2t1NpNTYXFFQiWhX0k9Syw7IpLMpG6ob4VKNeCiwlIt2Ah6Ica q6DQM9AydNCRPY65z/RsdenHcUFTPwuyvflSjB3pnM12hVOtE9FP4bPzKpmq2ml9z1bD PYUMJ+CnezEH4ZM1oCJ/iHrPnctIIAwmgs+FSZ4OKSX1UL1V1/vDSfWf/V3a49JS0weg IPAZ98dIBNatPPcDWd1Q3DDuohqLUsMYLxMlD1IhNdKDIk41tck5VfxjbffPs9XtBFhw nQkT/+ue6ohbmBK28mdN0rmSb0fFVfydKvy2d6dZOrLMrp3FbjrVwE5t7YGG776OJS4t /6bg== 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; bh=bCVi5g2GSfKsOOMT8hBbe+PvwVCIP5swzwpOKIw0nlY=; b=vdLzif24RNfVjafCNQGLG2ZpDp9DlcWPeuzOrcPrIz0qfzjmL8Y2UPaIr5R3Jdblfh /yBXXuAmFy/2+YxReolkgGDorePMljhNPnxlumUTpGf7nWHPXkW1rFU+JOIOQKHY7Fhk G71gOxA2CS5NfJcm3F/Iiuyia2NHQJkZyZYiyxHZVG3QTLHkK1mIl/Qugcl6LYp6vumU yAzePP5U32KP4f7E2AzL3ohZmfC9Hws0WWtbc638foFopBTI1uZ0MbEDkK4SNskZLYw5 oyCs1n0IbuApgVjfRZH6bi0tngYinqaM23zyLkqdPalMdVj2ayGq2t3D3tWRvYMmaAs0 Kyyg== ARC-Authentication-Results: i=1; mx.google.com; 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 i189si40767307pge.253.2019.08.02.02.30.57; Fri, 02 Aug 2019 02:31:13 -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; 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 S2389872AbfHBHfB (ORCPT + 99 others); Fri, 2 Aug 2019 03:35:01 -0400 Received: from relmlor1.renesas.com ([210.160.252.171]:17475 "EHLO relmlie5.idc.renesas.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S2389759AbfHBHe7 (ORCPT ); Fri, 2 Aug 2019 03:34:59 -0400 X-IronPort-AV: E=Sophos;i="5.64,337,1559487600"; d="scan'208";a="23151164" Received: from unknown (HELO relmlir5.idc.renesas.com) ([10.200.68.151]) by relmlie5.idc.renesas.com with ESMTP; 02 Aug 2019 16:34:58 +0900 Received: from fabrizio-dev.ree.adwin.renesas.com (unknown [10.226.36.196]) by relmlir5.idc.renesas.com (Postfix) with ESMTP id 72C0840078B4; Fri, 2 Aug 2019 16:34:55 +0900 (JST) From: Fabrizio Castro To: Laurent Pinchart , Kieran Bingham , Jacopo Mondi , David Airlie , Daniel Vetter Cc: Fabrizio Castro , dri-devel@lists.freedesktop.org, linux-renesas-soc@vger.kernel.org, linux-kernel@vger.kernel.org, Simon Horman , Geert Uytterhoeven , Chris Paterson , Biju Das Subject: [PATCH/RFC 05/12] drm: rcar-du: lvds: Add data swap support Date: Fri, 2 Aug 2019 08:34:02 +0100 Message-Id: <1564731249-22671-6-git-send-email-fabrizio.castro@bp.renesas.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1564731249-22671-1-git-send-email-fabrizio.castro@bp.renesas.com> References: <1564731249-22671-1-git-send-email-fabrizio.castro@bp.renesas.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When in vertical stripe mode of operation, there is the option of swapping even data and odd data on the two LVDS interfaces used to drive the video output. Add data swap support by exposing a new DT property named "renesas,swap-data". Signed-off-by: Fabrizio Castro --- drivers/gpu/drm/rcar-du/rcar_lvds.c | 23 ++++++++++++++++------- 1 file changed, 16 insertions(+), 7 deletions(-) diff --git a/drivers/gpu/drm/rcar-du/rcar_lvds.c b/drivers/gpu/drm/rcar-du/rcar_lvds.c index 3aeaf9e..c306fab 100644 --- a/drivers/gpu/drm/rcar-du/rcar_lvds.c +++ b/drivers/gpu/drm/rcar-du/rcar_lvds.c @@ -69,6 +69,7 @@ struct rcar_lvds { struct drm_bridge *companion; bool dual_link; + bool stripe_swap_data; }; #define bridge_to_rcar_lvds(bridge) \ @@ -439,12 +440,16 @@ static void rcar_lvds_enable(struct drm_bridge *bridge) rcar_lvds_write(lvds, LVDCHCR, lvdhcr); if (lvds->info->quirks & RCAR_LVDS_QUIRK_DUAL_LINK) { - /* - * Configure vertical stripe based on the mode of operation of - * the connected device. - */ - rcar_lvds_write(lvds, LVDSTRIPE, - lvds->dual_link ? LVDSTRIPE_ST_ON : 0); + u32 lvdstripe = 0; + + if (lvds->dual_link) + /* + * Configure vertical stripe based on the mode of + * operation of the connected device. + */ + lvdstripe = LVDSTRIPE_ST_ON | (lvds->stripe_swap_data ? + LVDSTRIPE_ST_SWAP : 0); + rcar_lvds_write(lvds, LVDSTRIPE, lvdstripe); } /* @@ -770,8 +775,12 @@ static int rcar_lvds_parse_dt(struct rcar_lvds *lvds) } } - if (lvds->dual_link) + if (lvds->dual_link) { + lvds->stripe_swap_data = of_property_read_bool( + lvds->dev->of_node, + "renesas,swap-data"); ret = rcar_lvds_parse_dt_companion(lvds); + } done: of_node_put(local_output); -- 2.7.4