Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp1557995pxf; Fri, 19 Mar 2021 09:43:41 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxLvUrqDxOuey1wtCldv5DlscdF+6LxKq/aZLiT7Tn2u2cVWj0VbCVNhenNfA2+MrXkhM86 X-Received: by 2002:a17:906:a1c8:: with SMTP id bx8mr5256935ejb.381.1616172220852; Fri, 19 Mar 2021 09:43:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616172220; cv=none; d=google.com; s=arc-20160816; b=GA7zBteSa+qHLtZh04Cts6qMpji86GSkI3EnUFRuSBpBoCvrZlOChX5tL3SMuP3d/P CquKJOlHavrolhpyhOAX9mG9BuX1nD+pbNmBUjiN56AeJqx0TTdmXOCI5160mzCTtmCP lmBn3UVJgGx2nEyrnC7cVheWGM+L2+MjCA4Sn1WSxSq1ZBHWWgGLUKSP5ywLtNRO9Tkk A+u46VtaqR45MolcFOu+/Q8SWXLBHp14npknoBW81M9B4SFXLYJfLvABaxAMSyyLcalr gJw5fQtu1LKwPwoiu+Ia1YO0o5mDSdO3iRG6wnz+O9pBWbCo5lcQTUkUNT5+xTzO2Yeg lvbQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=YNWS5puwicBVnbc0KL7R46v6EeF1NTuCODWKFbq27gA=; b=pzzQkkEKeey7HDBomz05k9loYhSsbsMeb+8FRM3BtbnGVAEiButuvgQNs8gbDmMK3L xRNySwCOV5cn2I5zjs64mZ0egAb0i2VncMIqF4aTz8oM5iJUm9tE/ufCutbKADfdXq/0 XuEWlq1YbGrCnyzNA8slcNLfJWz8SBjUSBmtVl2XDWESC+GaJh5EjUZa8onJDzfqgOsY vG1WVytBAZBU95L2+iZSrL/VO6lUR3OO2acgtgdAeSWBL88uFLmbPO4V+tN5YJ9z0nN8 1CKbLYhzo3/Ulo3l07D9zl/GZ/S9JUqdFTcNZkS/6ZdcBAmQTbZy8T10l/g5XnnaEwp/ vjPw== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id hq23si4563869ejc.116.2021.03.19.09.43.17; Fri, 19 Mar 2021 09:43:40 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230461AbhCSQm2 (ORCPT + 99 others); Fri, 19 Mar 2021 12:42:28 -0400 Received: from relay6-d.mail.gandi.net ([217.70.183.198]:41713 "EHLO relay6-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229956AbhCSQmC (ORCPT ); Fri, 19 Mar 2021 12:42:02 -0400 X-Originating-IP: 5.92.35.220 Received: from uno.localdomain (mob-5-92-35-220.net.vodafone.it [5.92.35.220]) (Authenticated sender: jacopo@jmondi.org) by relay6-d.mail.gandi.net (Postfix) with ESMTPSA id 4806FC0005; Fri, 19 Mar 2021 16:41:57 +0000 (UTC) From: Jacopo Mondi To: kieran.bingham+renesas@ideasonboard.com, laurent.pinchart+renesas@ideasonboard.com, niklas.soderlund+renesas@ragnatech.se, geert@linux-m68k.org Cc: Jacopo Mondi , Mauro Carvalho Chehab , linux-media@vger.kernel.org, linux-renesas-soc@vger.kernel.org, linux-kernel@vger.kernel.org, Laurent Pinchart Subject: [PATCH v3 09/19] media: i2c: max9271: Introduce wake_up() function Date: Fri, 19 Mar 2021 17:41:38 +0100 Message-Id: <20210319164148.199192-10-jacopo+renesas@jmondi.org> X-Mailer: git-send-email 2.30.0 In-Reply-To: <20210319164148.199192-1-jacopo+renesas@jmondi.org> References: <20210319164148.199192-1-jacopo+renesas@jmondi.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The MAX9271 chip manual prescribes a delay of 5 milliseconds after the chip exits from low power state. Add a new function to the max9271 library driver that wakes up the chip with a dummy i2c transaction and implements the correct delay of 5 milliseconds after the chip exits from low power state. Use the newly introduced function in the rdacm20 and rdacm21 camera drivers. The former was not respecting the required delay while the latter was waiting for a too-short timeout. Do not handle the initial i2c address configuration in the library driver function as the camera module drivers control address reprogramming. Reviewed-by: Kieran Bingham Reviewed-by: Laurent Pinchart Signed-off-by: Jacopo Mondi --- drivers/media/i2c/max9271.c | 7 +++++++ drivers/media/i2c/max9271.h | 9 +++++++++ drivers/media/i2c/rdacm20.c | 2 +- drivers/media/i2c/rdacm21.c | 3 +-- 4 files changed, 18 insertions(+), 3 deletions(-) diff --git a/drivers/media/i2c/max9271.c b/drivers/media/i2c/max9271.c index 2c7dc7fb9846..f7bfe7266763 100644 --- a/drivers/media/i2c/max9271.c +++ b/drivers/media/i2c/max9271.c @@ -80,6 +80,13 @@ static int max9271_pclk_detect(struct max9271_device *dev) return -EIO; } +void max9271_wake_up(struct max9271_device *dev) +{ + i2c_smbus_read_byte(dev->client); + usleep_range(5000, 8000); +} +EXPORT_SYMBOL_GPL(max9271_wake_up); + int max9271_set_serial_link(struct max9271_device *dev, bool enable) { int ret; diff --git a/drivers/media/i2c/max9271.h b/drivers/media/i2c/max9271.h index d78fb21441e9..dc5e4e70ba6f 100644 --- a/drivers/media/i2c/max9271.h +++ b/drivers/media/i2c/max9271.h @@ -85,6 +85,15 @@ struct max9271_device { struct i2c_client *client; }; +/** + * max9271_wake_up() - Wake up the serializer by issuing an i2c transaction + * @dev: The max9271 device + * + * This function shall be called before any other interaction with the + * serializer. + */ +void max9271_wake_up(struct max9271_device *dev); + /** * max9271_set_serial_link() - Enable/disable serial link * @dev: The max9271 device diff --git a/drivers/media/i2c/rdacm20.c b/drivers/media/i2c/rdacm20.c index 3cab6af7eba6..2881e752efbe 100644 --- a/drivers/media/i2c/rdacm20.c +++ b/drivers/media/i2c/rdacm20.c @@ -547,7 +547,7 @@ static int rdacm20_initialize(struct rdacm20_device *dev) /* Verify communication with the MAX9271: ping to wakeup. */ dev->serializer->client->addr = MAX9271_DEFAULT_ADDR; - i2c_smbus_read_byte(dev->serializer->client); + max9271_wake_up(dev->serializer); /* Serial link disabled during config as it needs a valid pixel clock. */ ret = max9271_set_serial_link(dev->serializer, false); diff --git a/drivers/media/i2c/rdacm21.c b/drivers/media/i2c/rdacm21.c index 318a3b40d9e6..1706a59bfd58 100644 --- a/drivers/media/i2c/rdacm21.c +++ b/drivers/media/i2c/rdacm21.c @@ -511,8 +511,7 @@ static int rdacm21_initialize(struct rdacm21_device *dev) /* Verify communication with the MAX9271: ping to wakeup. */ dev->serializer.client->addr = MAX9271_DEFAULT_ADDR; - i2c_smbus_read_byte(dev->serializer.client); - usleep_range(3000, 5000); + max9271_wake_up(&dev->serializer); /* Enable reverse channel and disable the serial link. */ ret = max9271_set_serial_link(&dev->serializer, false); -- 2.30.0