Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp3443937ybk; Tue, 19 May 2020 04:59:03 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy0NluWm3l7dCV6JSLDrlNO8vmWoE10qPtdk3XtEB4ZeoWyG/qXGBKNI0QTPpK3HN24I8tE X-Received: by 2002:a17:906:1ed3:: with SMTP id m19mr306066ejj.429.1589889543471; Tue, 19 May 2020 04:59:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1589889543; cv=none; d=google.com; s=arc-20160816; b=cpZTO338FMm3qLoZ9QR2mW1zp7Sa3Fo0wF1TTkv+3lxcZG7IwipWpsAIzc9frUnE0a 63/exXPDD73WQWyGr/Wu2J+wuj/Bdax50lzGVFO++XfXiu7xglg2Ug9n1i2roh+0gxvM vg+LGNweFOjQIhEyQOhEwy0K5PoJQcQw4peQ4mpNmbGmx80THoMk4XQ6OspW0geCfb5D vOTn+EvI5qumoc4pdiWdBVvcwByfPRVNNtCy8stXCDgS76v0cVKprqaZfvtkFhAaDH26 GN+W9VVxkr3JqtHs7Iih+FKWyEGTmdNseTPT0PBvTqktozDEtvgRVi91t8TFNaSC0WfC 1TmQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:ironport-sdr:ironport-sdr; bh=SrNwMXvpt8TZ8BQNsxFpf6C96FhrtqXiGzxAkWNb1KA=; b=w5CCin4VZO5Xxvohi0pi8t32pkt2RolyJ/5cMtyvlWmjPwO+prsnX0HlDS69l3VBKP VOBkFqjE6L2pQvmQnKBIr356gL92nzKQl3iBqVc6wSUkJyB6roeP14PJu1yXP/IzSFBL zPGHulhk9WMFFSFp75NAOwIKz8UPgjcZoHRiBry9cUr5z9714ce1i67ApplrOO9k8QNt nkkWZ/Gtjg7gGyFjeJ2K5irOuAdouy3QWUoUTkbwuJAcBGD43XbbZn1ubymO++v52WiG NiBSZrGxKt5Tdq+BA+CcXeQamGp09gf+usS9ERB1rHFYZiGhwjL5v9BQD+cBGw1d5muB 5UBw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id du13si10359ejc.640.2020.05.19.04.58.39; Tue, 19 May 2020 04:59:03 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728662AbgESL5O (ORCPT + 99 others); Tue, 19 May 2020 07:57:14 -0400 Received: from mga14.intel.com ([192.55.52.115]:51524 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726949AbgESL5O (ORCPT ); Tue, 19 May 2020 07:57:14 -0400 IronPort-SDR: NqNHNWuUlddp6v9r0jTsQr38jUf+IMK28lRvyvxyVW2eXuK4J6evY6sC1O8d37Kq8YHNXDGDNU KPsgC35sGfeQ== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga007.jf.intel.com ([10.7.209.58]) by fmsmga103.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 19 May 2020 04:57:13 -0700 IronPort-SDR: jyV9rlo0jY05dtLVE84kx6AZSS4ovmpPrjaCPfmSvzq3tkFF4M5NtqoIwUxWRHU5QFlp7wjYoZ ZRhzK7on77fg== X-IronPort-AV: E=Sophos;i="5.73,410,1583222400"; d="scan'208";a="253221285" Received: from paasikivi.fi.intel.com ([10.237.72.42]) by orsmga007-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 19 May 2020 04:57:09 -0700 Received: by paasikivi.fi.intel.com (Postfix, from userid 1000) id 6918E20CEF; Tue, 19 May 2020 14:57:07 +0300 (EEST) Date: Tue, 19 May 2020 14:57:07 +0300 From: Sakari Ailus To: Roman Kovalivskyi Cc: linux-kernel@vger.kernel.org, linux-media@vger.kernel.org, linux-renesas-soc@vger.kernel.org, Luis Oliveira , Niklas =?iso-8859-1?Q?S=F6derlund?= , Jacopo Mondi , Michael Rodin , Mauro Carvalho Chehab , Hugues Fruchet , Maxime Ripard , Adam Ford , Todor Tomov , Suresh Udipi , Andrew Gabbasov , Eugeniu Rosca , Dave Stevenson Subject: Re: [PATCH v2 3/6] media: ov5647: Add support for non-continuous clock mode Message-ID: <20200519115707.GK20066@paasikivi.fi.intel.com> References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Roman, On Tue, May 19, 2020 at 04:16:18AM +0300, Roman Kovalivskyi wrote: > From: Dave Stevenson > > The driver was only supporting continuous clock mode > although this was not stated anywhere. > Non-continuous clock saves a small amount of power and > on some SoCs is easier to interface with. > > Signed-off-by: Dave Stevenson > Signed-off-by: Roman Kovalivskyi > --- > drivers/media/i2c/ov5647.c | 25 ++++++++++++++++++++++--- > 1 file changed, 22 insertions(+), 3 deletions(-) > > diff --git a/drivers/media/i2c/ov5647.c b/drivers/media/i2c/ov5647.c > index 796cc80f8ee1..10f35c637f91 100644 > --- a/drivers/media/i2c/ov5647.c > +++ b/drivers/media/i2c/ov5647.c > @@ -44,6 +44,7 @@ > #define PWDN_ACTIVE_DELAY_MS 20 > > #define MIPI_CTRL00_CLOCK_LANE_GATE BIT(5) > +#define MIPI_CTRL00_LINE_SYNC_ENABLE BIT(4) > #define MIPI_CTRL00_BUS_IDLE BIT(2) > #define MIPI_CTRL00_CLOCK_LANE_DISABLE BIT(0) > > @@ -95,6 +96,7 @@ struct ov5647 { > int power_count; > struct clk *xclk; > struct gpio_desc *pwdn; > + bool is_clock_contiguous; > }; > > static inline struct ov5647 *to_state(struct v4l2_subdev *sd) > @@ -274,9 +276,15 @@ static int ov5647_set_virtual_channel(struct v4l2_subdev *sd, int channel) > > static int ov5647_stream_on(struct v4l2_subdev *sd) > { > + struct ov5647 *ov5647 = to_state(sd); > + u8 val = MIPI_CTRL00_BUS_IDLE; > int ret; > > - ret = ov5647_write(sd, OV5647_REG_MIPI_CTRL00, MIPI_CTRL00_BUS_IDLE); > + if (ov5647->is_clock_contiguous) > + val |= MIPI_CTRL00_CLOCK_LANE_GATE | > + MIPI_CTRL00_LINE_SYNC_ENABLE; > + > + ret = ov5647_write(sd, OV5647_REG_MIPI_CTRL00, val); > if (ret < 0) > return ret; > > @@ -573,7 +581,7 @@ static const struct v4l2_subdev_internal_ops ov5647_subdev_internal_ops = { > .open = ov5647_open, > }; > > -static int ov5647_parse_dt(struct device_node *np) > +static int ov5647_parse_dt(struct ov5647 *sensor, struct device_node *np) > { > struct v4l2_fwnode_endpoint bus_cfg = { .bus_type = 0 }; > struct device_node *ep; > @@ -586,6 +594,17 @@ static int ov5647_parse_dt(struct device_node *np) > > ret = v4l2_fwnode_endpoint_parse(of_fwnode_handle(ep), &bus_cfg); > Extra newline. > + if (!ret) { > + of_node_put(ep); > + of_node_put(np); Why to put np as well? > + return ret; Please add a label at the end; it makes error handling easier. > + } > + > + if (bus_cfg.bus_type == V4L2_MBUS_CSI2_DPHY > + || bus_cfg.bus_type == V4L2_MBUS_CSI2_CPHY) I bet this device is D-PHY only. > + sensor->is_clock_contiguous = bus_cfg.bus.mipi_csi2.flags > + & V4L2_MBUS_CSI2_NONCONTINUOUS_CLOCK; Now that you're making use of bus specific parameters, please set the bus type first before calling v4l2_fwnode_endpoint_parse(). > + > of_node_put(ep); > return ret; > } > @@ -604,7 +623,7 @@ static int ov5647_probe(struct i2c_client *client) > return -ENOMEM; > > if (IS_ENABLED(CONFIG_OF) && np) { > - ret = ov5647_parse_dt(np); > + ret = ov5647_parse_dt(sensor, np); > if (ret) { > dev_err(dev, "DT parsing error: %d\n", ret); > return ret; -- Kind regards, Sakari Ailus