Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp4611744imu; Sat, 19 Jan 2019 13:48:09 -0800 (PST) X-Google-Smtp-Source: ALg8bN49NVumHFT9IXUVmeWDczUXEs+vS5AhV8Jv8UbwFVWeS2FT6DgUHuetVIDk0T8oOu2IUZrM X-Received: by 2002:a63:3d49:: with SMTP id k70mr22774420pga.191.1547934489723; Sat, 19 Jan 2019 13:48:09 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1547934489; cv=none; d=google.com; s=arc-20160816; b=tTrST8A2G1NultLeI+K1ZxOCOVevgYm/yoDl3jRrd6+rsBpqX8/N0Ne8iWEW2x726B kgbWtmsfx6LvpiekGjyRIr5T4kVRTHQIMu8w/sXPS46p4Ax+b6472H15hcDYCQyezYJH 37qxs9CKZPSGbRDGiqd7y2rXndIZW3YeTEFsyFQ/MgwI9QzsYnsAjyWSNUMhVRtLdh0V pDlTfJF5l7rFVttRiF31Z/ydtwyqngc4qo973a2XKh3Jz5ZaDRik9gpS/z9MBbzqEmU2 pQmWMZDR3eJKBeoraWb/IqZTWq2BGIB/GSaCfucXCGC0zjkTYaQg9HFrkTSmSrwan6Zy 0uuA== 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; bh=w4pDpNNiZVftYGZN/ZfjMBwdA+nK0DkXdKOIzQhsz4k=; b=Cv7L58KcccDZmpnBfrLBIt/7qEk/Hd0DfxjkaccsUrlkXaFlSii9+gJOxDye5hKzpk cWsx1yJel83LnH6vyOMdh9G5mMJtP4FIgetShJ+ItT5y2uEXXlQHNyU1HL0n6lSPKoQh FJ/Pl/MF16SX7B4XXdsr0XCBnPST7HZ2a1bzQFsmzRZ3jQlFeECt5i4pQQocerchtRKF /6Da7rgzDVDdjuXrW1HOoeDcJu+OBaJSjYSsv4jiSecomsdCCmJBEWjM5DBwXk/wfT+M Stv+XjdoA9M+CoJQ/PTYJ/D61c/6pTki7zHZKX7yI4HKGglriSIkq7BwiGkk0FIA2RMb joAQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=YtdhT8Rb; 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 b8si8044270pgi.575.2019.01.19.13.47.47; Sat, 19 Jan 2019 13:48:09 -0800 (PST) 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=YtdhT8Rb; 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 S1729740AbfASVqP (ORCPT + 99 others); Sat, 19 Jan 2019 16:46:15 -0500 Received: from mail-wm1-f65.google.com ([209.85.128.65]:50244 "EHLO mail-wm1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729056AbfASVqO (ORCPT ); Sat, 19 Jan 2019 16:46:14 -0500 Received: by mail-wm1-f65.google.com with SMTP id n190so7586669wmd.0; Sat, 19 Jan 2019 13:46:12 -0800 (PST) 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=w4pDpNNiZVftYGZN/ZfjMBwdA+nK0DkXdKOIzQhsz4k=; b=YtdhT8RbsdmQsBpQBYCWX0f1PY7Jefd/07yOzlZTUBuyPkZ4DvkM2+8YNO2a9NT0dQ 08rh+SjbGnEGSm9TQvg4hzXhScXLsp5C48NaVELrWom2pt8GT9JwKpHlhz2aGFW9h2TN R83DNFAg7IGT4tV9SHZiEaa5ioBYjNrS9vn95hmYtKt8/GG4XCMo7tjo546RYMYObkwb e49RTIwV8bbE/7/IFqSw78xu7th9v+zrtV6zleKD4MJ03j9ltclWeHTP7F/Bd3mm7Kmt /QGfKuMbpMwWU6zv7zo4iEvrM7G9AzduduUVsXVbCFUC4h7iveihPQlrpgdARcn9O/wm gYGg== 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=w4pDpNNiZVftYGZN/ZfjMBwdA+nK0DkXdKOIzQhsz4k=; b=i56oWNQxcWfBoe6RH8QIVD7RBtyevA17nH3JZ7HyIOazbk+uq1YjxqS7LLM9oomX27 M4cD8MIDpVtoIHPjXiWaEG2VJr/qTPoHYSJElv7WxRBWbbK3Y35A691KSiDhuVTVg0HT GUPEWsSmSADGJyHg0UCHy5jzdgy8PN9Mmm3IyqSoPlOLEYUAEcP1+/lv8pec3MpqYi2z oQE5VyjaEsbS2I6hnHRSWsmbaztBj2BC5Zz/ZQMMat6IJziuAAyO6D2uNkD+E2XJXEiG UCRryBAXL3HH9UqAvvYBzbJTxBgqqWBlbMB+RHhRVCekUcZbV7V5ka9AjPgWVUe42mmt YwQQ== X-Gm-Message-State: AJcUukeIPeVFfe/rKpT/t5yneLRx6jnyM+A/UFv1MnUGFZ0fKfFI1yyi xgw0KkjK4p1OPJlyLXbYr0Xyn9dZ X-Received: by 2002:a1c:2b01:: with SMTP id r1mr19430582wmr.7.1547934371081; Sat, 19 Jan 2019 13:46:11 -0800 (PST) Received: from mappy.world.mentorg.com (sjewanfw1-nat.mentorg.com. [139.181.7.34]) by smtp.gmail.com with ESMTPSA id o5sm26432048wrw.46.2019.01.19.13.46.08 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Sat, 19 Jan 2019 13:46:10 -0800 (PST) From: Steve Longerbeam To: linux-media@vger.kernel.org Cc: Steve Longerbeam , stable@vger.kernel.org, Philipp Zabel , Mauro Carvalho Chehab , Greg Kroah-Hartman , devel@driverdev.osuosl.org (open list:STAGING SUBSYSTEM), linux-kernel@vger.kernel.org (open list) Subject: [PATCH 1/4] media: imx: csi: Allow unknown nearest upstream entities Date: Sat, 19 Jan 2019 13:45:57 -0800 Message-Id: <20190119214600.30897-2-slongerbeam@gmail.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20190119214600.30897-1-slongerbeam@gmail.com> References: <20190119214600.30897-1-slongerbeam@gmail.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On i.MX6, the nearest upstream entity to the CSI can only be the CSI video muxes or the Synopsys DW MIPI CSI-2 receiver. However the i.MX53 has no CSI video muxes or a MIPI CSI-2 receiver. So allow for the nearest upstream entity to the CSI to be something other than those. Fixes: bf3cfaa712e5c ("media: staging/imx: get CSI bus type from nearest upstream entity") Signed-off-by: Steve Longerbeam Cc: stable@vger.kernel.org --- drivers/staging/media/imx/imx-media-csi.c | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) diff --git a/drivers/staging/media/imx/imx-media-csi.c b/drivers/staging/media/imx/imx-media-csi.c index 555aa45e02e3..b9af7d3d4974 100644 --- a/drivers/staging/media/imx/imx-media-csi.c +++ b/drivers/staging/media/imx/imx-media-csi.c @@ -154,9 +154,10 @@ static inline bool requires_passthrough(struct v4l2_fwnode_endpoint *ep, /* * Parses the fwnode endpoint from the source pad of the entity * connected to this CSI. This will either be the entity directly - * upstream from the CSI-2 receiver, or directly upstream from the - * video mux. The endpoint is needed to determine the bus type and - * bus config coming into the CSI. + * upstream from the CSI-2 receiver, directly upstream from the + * video mux, or directly upstream from the CSI itself. The endpoint + * is needed to determine the bus type and bus config coming into + * the CSI. */ static int csi_get_upstream_endpoint(struct csi_priv *priv, struct v4l2_fwnode_endpoint *ep) @@ -172,7 +173,8 @@ static int csi_get_upstream_endpoint(struct csi_priv *priv, if (!priv->src_sd) return -EPIPE; - src = &priv->src_sd->entity; + sd = priv->src_sd; + src = &sd->entity; if (src->function == MEDIA_ENT_F_VID_MUX) { /* @@ -186,6 +188,14 @@ static int csi_get_upstream_endpoint(struct csi_priv *priv, src = &sd->entity; } + /* + * If the source is neither the video mux nor the CSI-2 receiver, + * get the source pad directly upstream from CSI itself. + */ + if (src->function != MEDIA_ENT_F_VID_MUX && + sd->grp_id != IMX_MEDIA_GRP_ID_CSI2) + src = &priv->sd.entity; + /* get source pad of entity directly upstream from src */ pad = imx_media_find_upstream_pad(priv->md, src, 0); if (IS_ERR(pad)) -- 2.17.1