Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp1254623ybl; Wed, 14 Aug 2019 13:28:16 -0700 (PDT) X-Google-Smtp-Source: APXvYqwe3FRnRvJAA3OWXKHg0E5xagHa2FC5JhjdvYL/DEzESwJRcLQnsLU1NDW9ctlzdivLuy0f X-Received: by 2002:a63:204b:: with SMTP id r11mr797550pgm.121.1565814496254; Wed, 14 Aug 2019 13:28:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1565814496; cv=none; d=google.com; s=arc-20160816; b=pNm3XmdCCJ6FZ+NXdVnlRU5lvGS2Wab2OvHlH0M/w4GhdhOknRP9LuHRFFnXMyc0Tu 6StyS9O7BVpEqvLFTKADOn6Li+8KPpPMlr0NOUdt1VNK0xFyjShO6ndMvVQmL0H6Npzg iD8qX666Z/D3hMkrR84L5wo2F3dhxxcaUuFOj3HVIgZ7TphuDDLgnuaL+HVrGSP9aKaT BPUSgO1lvtN98bAtAuNIaafdLuHz2o5plwFX4DihVRWu+9R+GSgdHWa0Ro7ZJc1l2YdV L4EUf0ku6fqRwhaTJpQe4f1z8nwtrdf0AXBp3Nn26okr/OCRqfn8odTnnEbjRpnssU5Y cshQ== 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:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=wmcFopsMu5h1+niHrkjw4pD9uKUVvbb+A1IqW4BFVPA=; b=xa8koncPsVyXt4e4+Sjv9C8yRCJkLEhjojIZ6udFTg7+1xJdVIbSXHfIsF7fgMYo30 0WshvQf68ZAGqtaZUBdoxaxy7LJXwT/DV7IMYK/yhIzttL++9W/ys94aCc5ercgysFhJ vDkXPT9WAbc6iQ+lWjXN4c9VTjNjGXc2eUOlrc+AfdwRulE2+gnNRWUTb0sc+1igwkVP le69maF46Ip5I+qzHYj5aNTPCKPS4sC4aPrIDKTpguy43Zt4JDKqCSVlGZdLitOCy4n9 xpbD8TIOAfSm7TY71DGfcxeAal2RPlqLsM9BIrJeBvTObwR4OV9WAYnsEe/PHjTBmgYS mdTw== 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 d13si417122pfo.33.2019.08.14.13.28.01; Wed, 14 Aug 2019 13:28:16 -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 S1729657AbfHNU1W (ORCPT + 99 others); Wed, 14 Aug 2019 16:27:22 -0400 Received: from relay9-d.mail.gandi.net ([217.70.183.199]:35937 "EHLO relay9-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729625AbfHNU1V (ORCPT ); Wed, 14 Aug 2019 16:27:21 -0400 X-Originating-IP: 87.5.130.64 Received: from uno.homenet.telecomitalia.it (host64-130-dynamic.5-87-r.retail.telecomitalia.it [87.5.130.64]) (Authenticated sender: jacopo@jmondi.org) by relay9-d.mail.gandi.net (Postfix) with ESMTPSA id D59F3FF807; Wed, 14 Aug 2019 20:27:18 +0000 (UTC) From: Jacopo Mondi To: Mauro Carvalho Chehab , Hans Verkuil , Sakari Ailus , Laurent Pinchart Cc: Jacopo Mondi , linux-media@vger.kernel.org (open list:MEDIA INPUT INFRASTRUCTURE (V4L/DVB)), linux-kernel@vger.kernel.org (open list) Subject: [RFC 5/5] media: i2c: ov13858: Report the camera location Date: Wed, 14 Aug 2019 22:28:15 +0200 Message-Id: <20190814202815.32491-6-jacopo@jmondi.org> X-Mailer: git-send-email 2.22.0 In-Reply-To: <20190814202815.32491-1-jacopo@jmondi.org> References: <20190814202815.32491-1-jacopo@jmondi.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The camera location is retrieved from the firmware interface parsing the "location" device property and reported through the read-only V4L2_CID_LOCATION control. Signed-off-by: Jacopo Mondi --- drivers/media/i2c/ov13858.c | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/drivers/media/i2c/ov13858.c b/drivers/media/i2c/ov13858.c index 45bb872db3c5..6baefc3083e1 100644 --- a/drivers/media/i2c/ov13858.c +++ b/drivers/media/i2c/ov13858.c @@ -1591,6 +1591,7 @@ static int ov13858_init_controls(struct ov13858 *ov13858) struct i2c_client *client = v4l2_get_subdevdata(&ov13858->sd); struct v4l2_ctrl_handler *ctrl_hdlr; s64 exposure_max; + u32 location; s64 vblank_def; s64 vblank_min; s64 hblank; @@ -1659,6 +1660,16 @@ static int ov13858_init_controls(struct ov13858 *ov13858) V4L2_CID_TEST_PATTERN, ARRAY_SIZE(ov13858_test_pattern_menu) - 1, 0, 0, ov13858_test_pattern_menu); + + ret = device_property_read_u32(&client->dev, "location", &location); + if (!ret) { + v4l2_ctrl_new_std(ctrl_hdlr, &ov13858_ctrl_ops, + V4L2_CID_LOCATION, V4L2_LOCATION_FRONT, + V4L2_LOCATION_BACK, 1, + location == V4L2_LOCATION_FRONT ? + V4L2_LOCATION_FRONT : V4L2_LOCATION_BACK); + } + if (ctrl_hdlr->error) { ret = ctrl_hdlr->error; dev_err(&client->dev, "%s control init failed (%d)\n", -- 2.22.0