Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp6064228imu; Tue, 13 Nov 2018 16:47:19 -0800 (PST) X-Google-Smtp-Source: AJdET5dvoFcVlxkAW+353Ec+A1RjqZeidlpvP1mgWmXIb8CcMxFhFy/9pdICqkxoa9rIf78iDEir X-Received: by 2002:a63:2744:: with SMTP id n65mr6766557pgn.65.1542156439925; Tue, 13 Nov 2018 16:47:19 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542156439; cv=none; d=google.com; s=arc-20160816; b=0RQE5cchm0iHq6BhU1JTEK+tOUFlGdPrLDcqSlwJOXHebp9N8S1ul3Smqr3gcyMtTT Fq30k+r3PkiIDBcZkPaarN81MiFX/J2stLQptDnSTIww7RFG+k1AqBhTwfJ3d2FyAdHq IcdPAimel5IrhZMEgBHKlPX6BFZkk32YHqwRXQCzK+C6AFDI/Da0pyGzvrAQu0hr0M5t sfhM57dD8ULaO14/DSWe4rABnZU1nhYRepcrlsnn80bXGaoAyGeiZ3at+VTkt9+wIe8R T8QeOediYJHEVcLXZC7S2SmEIPmMFccy6qAdHaDgvOT0pRfzPBIianAdlIXNfvBo9tk8 NpSw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:organization:autocrypt:openpgp:from:references:cc:to :subject:reply-to:dkim-signature; bh=BmlOjt0ptoa+Q2WBtyDNZYqXJ+QgKzn0YO4EaysvY4g=; b=hfXWslE1BisXxUBnXRqLdiu1zjfIOWun2vEW43ezM7ul7/a0LtfdTMFC7lVFG9jpYa SseRg0YxI7o7Vp+PvvR5qD1tjMDhwacYm4UK+0gu8op9O3JuQTXcWxRGPR0876VF1riT EtLEKYkwCPAdLeNuf60FXUroPwURUJSxv16V60IBCX9uksYDp3EpW/KcSCBLpbvfGoSR PQDtF2sAVnQm8eDQEIN673PSZmyCiiuDUDxWgxIAXb42wqQzFh2hvz7gLCaxTiGZ+qMa 8CsOnMhzICK8Po3MrrhqTo7CcIoM2354M4vSPwXrcGafNrD+l92CNDV1+A90ZiENFgzy ddiA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=wcDgu0WM; 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 y7-v6si22328994plk.174.2018.11.13.16.47.03; Tue, 13 Nov 2018 16:47:19 -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 (test mode) header.i=@ideasonboard.com header.s=mail header.b=wcDgu0WM; 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 S1731083AbeKNKrb (ORCPT + 99 others); Wed, 14 Nov 2018 05:47:31 -0500 Received: from perceval.ideasonboard.com ([213.167.242.64]:43836 "EHLO perceval.ideasonboard.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726193AbeKNKrb (ORCPT ); Wed, 14 Nov 2018 05:47:31 -0500 Received: from [172.30.51.137] (unknown [64.114.255.97]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id EFD0ADF; Wed, 14 Nov 2018 01:46:35 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1542156399; bh=lPAj5mApNWpkD9aaiJGMcjsh5NHqd2CwBjTTPlzVExw=; h=Reply-To:Subject:To:Cc:References:From:Date:In-Reply-To:From; b=wcDgu0WM1VscChhqR1RO6TrOKT4Q0QPc1hI9VqsKP+ctUnZzIrDavZN+gJ5m222U9 MPnGhfEf9+/gSgJsiK9tdXNGh4gaQOeiMAVfhcw6IvVRQeIzZhaMD2hHbLbvhZuYyt 9UNlzcp9GbJPKKlkpTohrEHS0SZxSFh/BsO0e64c= Reply-To: kieran.bingham@ideasonboard.com Subject: Re: [PATCH v4 3/4] media: i2c: Add MAX9286 driver To: Luca Ceresoli , linux-renesas-soc@vger.kernel.org, linux-media@vger.kernel.org, devicetree@vger.kernel.org, sakari.ailus@iki.fi Cc: =?UTF-8?Q?Niklas_S=c3=b6derlund?= , Jacopo Mondi , Laurent Pinchart , Kieran Bingham , linux-kernel@vger.kernel.org, Jacopo Mondi , Laurent Pinchart , =?UTF-8?Q?Niklas_S=c3=b6derlund?= References: <20181102154723.23662-1-kieran.bingham@ideasonboard.com> <20181102154723.23662-4-kieran.bingham@ideasonboard.com> <5238fa80-7678-97a8-47ee-6a26970d862d@lucaceresoli.net> From: Kieran Bingham Openpgp: preference=signencrypt Autocrypt: addr=kieran.bingham@ideasonboard.com; keydata= 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 sbsRB8KNNvVXBOVNwko86rQqF9drZuw= Organization: Ideas on Board Message-ID: <07ee8a2c-81a8-ca32-96cf-67d6a883e3f5@ideasonboard.com> Date: Tue, 13 Nov 2018 16:46:31 -0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.2.1 MIME-Version: 1.0 In-Reply-To: <5238fa80-7678-97a8-47ee-6a26970d862d@lucaceresoli.net> Content-Type: text/plain; charset=utf-8 Content-Language: en-GB Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Luca, Thank you for your review, On 13/11/2018 14:49, Luca Ceresoli wrote: > Hi Kieran, All, > > below a few minor questions, and a big one at the bottom. > > On 02/11/18 16:47, Kieran Bingham wrote: >> From: Kieran Bingham >> >> The MAX9286 is a 4-channel GMSL deserializer with coax or STP input and >> CSI-2 output. The device supports multicamera streaming applications, >> and features the ability to synchronise the attached cameras. >> >> CSI-2 output can be configured with 1 to 4 lanes, and a control channel >> is supported over I2C, which implements an I2C mux to facilitate >> communications with connected cameras across the reverse control >> channel. >> >> Signed-off-by: Jacopo Mondi >> Signed-off-by: Kieran Bingham >> Signed-off-by: Laurent Pinchart >> Signed-off-by: Niklas Söderlund > > [...] > >> +struct max9286_device { >> + struct i2c_client *client; >> + struct v4l2_subdev sd; >> + struct media_pad pads[MAX9286_N_PADS]; >> + struct regulator *regulator; >> + bool poc_enabled; >> + int streaming; >> + >> + struct i2c_mux_core *mux; >> + unsigned int mux_channel; >> + >> + struct v4l2_ctrl_handler ctrls; >> + >> + struct v4l2_mbus_framefmt fmt[MAX9286_N_SINKS]; > > 5 pads, 4 formats. Why does the source node have no fmt? The source pad is a CSI2 link - so a 'frame format' would be inappropriate. >> +static int max9286_init(struct device *dev, void *data) >> +{ >> + struct max9286_device *max9286; >> + struct i2c_client *client; >> + struct device_node *ep; >> + unsigned int i; >> + int ret; >> + >> + /* Skip non-max9286 devices. */ >> + if (!dev->of_node || !of_match_node(max9286_dt_ids, dev->of_node)) >> + return 0; >> + >> + client = to_i2c_client(dev); >> + max9286 = i2c_get_clientdata(client); >> + >> + /* Enable the bus power. */ >> + ret = regulator_enable(max9286->regulator); >> + if (ret < 0) { >> + dev_err(&client->dev, "Unable to turn PoC on\n"); >> + return ret; >> + } >> + >> + max9286->poc_enabled = true; >> + >> + ret = max9286_setup(max9286); >> + if (ret) { >> + dev_err(dev, "Unable to setup max9286\n"); >> + goto err_regulator; >> + } >> + >> + v4l2_i2c_subdev_init(&max9286->sd, client, &max9286_subdev_ops); >> + max9286->sd.internal_ops = &max9286_subdev_internal_ops; >> + max9286->sd.flags = V4L2_SUBDEV_FL_HAS_DEVNODE; > ^ > > This way you're clearing the V4L2_SUBDEV_FL_IS_I2C set by > v4l2_i2c_subdev_init(), even though using devicetree I think this won't > matter in the current kernel code. However I think "max9286->sd.flags |= > ..." is more correct here, and it's also what most other drivers do. A quick glance looks like you're right. That looks like a good catch! I've updated locally ready for v5. >> + v4l2_ctrl_handler_init(&max9286->ctrls, 1); >> + /* >> + * FIXME: Compute the real pixel rate. The 50 MP/s value comes from the >> + * hardcoded frequency in the BSP CSI-2 receiver driver. >> + */ >> + v4l2_ctrl_new_std(&max9286->ctrls, NULL, V4L2_CID_PIXEL_RATE, >> + 50000000, 50000000, 1, 50000000); >> + max9286->sd.ctrl_handler = &max9286->ctrls; >> + ret = max9286->ctrls.error; >> + if (ret) >> + goto err_regulator; >> + >> + max9286->sd.entity.function = MEDIA_ENT_F_PROC_VIDEO_PIXEL_FORMATTER; > > According to the docs MEDIA_ENT_F_VID_IF_BRIDGE appears more fitting. Yes, I agree. We recently updated the adv748x to this too. Also updated locally to add to v5. >> +static int max9286_probe(struct i2c_client *client, >> + const struct i2c_device_id *did) >> +{ >> + struct max9286_device *dev; >> + unsigned int i; >> + int ret; >> + >> + dev = kzalloc(sizeof(*dev), GFP_KERNEL); >> + if (!dev) >> + return -ENOMEM; >> + >> + dev->client = client; >> + i2c_set_clientdata(client, dev); >> + >> + for (i = 0; i < MAX9286_N_SINKS; i++) >> + max9286_init_format(&dev->fmt[i]); >> + >> + ret = max9286_parse_dt(dev); >> + if (ret) >> + return ret; >> + >> + dev->regulator = regulator_get(&client->dev, "poc"); >> + if (IS_ERR(dev->regulator)) { >> + if (PTR_ERR(dev->regulator) != -EPROBE_DEFER) >> + dev_err(&client->dev, >> + "Unable to get PoC regulator (%ld)\n", >> + PTR_ERR(dev->regulator)); >> + ret = PTR_ERR(dev->regulator); >> + goto err_free; >> + } >> + >> + /* >> + * We can have multiple MAX9286 instances on the same physical I2C >> + * bus, and I2C children behind ports of separate MAX9286 instances >> + * having the same I2C address. As the MAX9286 starts by default with >> + * all ports enabled, we need to disable all ports on all MAX9286 >> + * instances before proceeding to further initialize the devices and >> + * instantiate children. >> + * >> + * Start by just disabling all channels on the current device. Then, >> + * if all other MAX9286 on the parent bus have been probed, proceed >> + * to initialize them all, including the current one. >> + */ >> + max9286_i2c_mux_close(dev); >> + >> + /* >> + * The MAX9286 initialises with auto-acknowledge enabled by default. >> + * This means that if multiple MAX9286 devices are connected to an I2C >> + * bus, another MAX9286 could ack I2C transfers meant for a device on >> + * the other side of the GMSL links for this MAX9286 (such as a >> + * MAX9271). To prevent that disable auto-acknowledge early on; it >> + * will be enabled later as needed. >> + */ >> + max9286_configure_i2c(dev, false); >> + >> + ret = device_for_each_child(client->dev.parent, &client->dev, >> + max9286_is_bound); >> + if (ret) >> + return 0; >> + >> + dev_dbg(&client->dev, >> + "All max9286 probed: start initialization sequence\n"); >> + ret = device_for_each_child(client->dev.parent, NULL, >> + max9286_init); > > I can't manage to like this initialization sequence, sorry. If at all > possible, each max9286 should initialize itself independently from each > other, like any normal driver. Yes, I think we're in agreement here, but unfortunately this section is a workaround for the fact that our devices share a common address space. We (currently) *must* disable both devices before we start the initialisation process for either on our platform currently... That said - I think this section needs to be removed from the upstream part at least for now. I think we should probably carry this 'workaround' separately. This part is the core issue that I talked about in my presentation at ALS-Japan [0] [0] https://sched.co/EaXa > First, it requires that each chip on the remote side can configure its > own slave address. Not all chips do. > > Second, using a static i2c address map does not scale well and limits > hotplugging, as I discussed in my reply to patch 1/4. The problem should > be solvable cleanly if the MAX9286 supports address translation like the > TI chips. I don't think we can treat GMSL as hot-pluggable currently ... But as we discussed - I see that we should think about this for FPD-Link Also as a further aside here, we use "device_is_bound" which is not exported, and means that this driver won't compile successfully as a module currently (thanks to the kbuild test robot for highlighting that) > Thanks, > -- Regards -- Kieran