Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp1627718pxb; Mon, 12 Apr 2021 02:49:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwbNRy2q0v6k8BrPVB9jeoknE5ZPoJnpUjQPpFDbKmDBSRWzwrLRPOnU6WAnPYD4o94HSdD X-Received: by 2002:a17:902:7c83:b029:e8:c368:543 with SMTP id y3-20020a1709027c83b02900e8c3680543mr25596787pll.58.1618220953342; Mon, 12 Apr 2021 02:49:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618220953; cv=none; d=google.com; s=arc-20160816; b=HXSQaBo1+A9ezcRXIcC04thePI+rBszLOl6DhI0TwHfo6PYrCQZ7XdQy/HBEHcpMUy ILs6+gG7jon6iL52ilCkt+OoWEplBccF6a9TIyCZP+VupKLogv7UFgAX8z7i0oL/AIJK AR8WjbGu188qFAEzjjTRKPGuGyXwPxfxJQR4ZoPkaxVi/zAzpiy+P2BqOib43RysxnPp jfFixbkUczlL8swj6I7q8klFgpPbekI6Vbx9yi2IjGbq1MEr9kBGCiLLniCltuxd7wMJ SJrTQhfQGCh32IBe5OPlnYs0saa+Ler5ziIkk8O5rnacEjbZYKryQYUT+aa0M6e2qdhk Wlqg== 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=BhKr/aJhL/Xey0OSW3qE5m07P93MYuRQDs/yUV1ffHM=; b=KxMn0ZTX3a7xA37qW4fx1Fqw1LQAxSTRn8zvhjPqIzdR3E2c/vCHCHJN2nUPV3faBp Y7H5JXcZbnsG4gg/bWih3KNcYQA0NXp9HFsmqVvq7rys5gSvd5U/ouiKZb8NPEDAsWHD I6S+aEov+Rc/V9M6ZMHv5mDpetsYxPWaFXyUKz7/y7F7XxErf2LFjCpI0oTT89awqOfG dBwqBxebvQ/eysXf04jRVUBJDkbhIAG2l7sXpdXPtAdhQnzLMV4ylVhuGOfmGGmZVXAk KjJpkrZorIZhvcS7v4f1OC6ZsEaiX+YF+h2GPwQ5/63bCTjHl5b5OndQaj1aCVtJDGrC FAQw== 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 d36si12277901pgd.553.2021.04.12.02.48.59; Mon, 12 Apr 2021 02:49:13 -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 S241383AbhDLJsl (ORCPT + 99 others); Mon, 12 Apr 2021 05:48:41 -0400 Received: from relay12.mail.gandi.net ([217.70.178.232]:48177 "EHLO relay12.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240669AbhDLJez (ORCPT ); Mon, 12 Apr 2021 05:34:55 -0400 Received: from uno.lan (93-34-118-233.ip49.fastwebnet.it [93.34.118.233]) (Authenticated sender: jacopo@jmondi.org) by relay12.mail.gandi.net (Postfix) with ESMTPSA id B6893200013; Mon, 12 Apr 2021 09:34:32 +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 v4 07/17] media: i2c: max9271: Introduce wake_up() function Date: Mon, 12 Apr 2021 11:34:41 +0200 Message-Id: <20210412093451.14198-8-jacopo+renesas@jmondi.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210412093451.14198-1-jacopo+renesas@jmondi.org> References: <20210412093451.14198-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. Reviewed-by: Kieran Bingham Reviewed-by: Laurent Pinchart Signed-off-by: Jacopo Mondi --- drivers/media/i2c/max9271.c | 12 ++++++++++++ drivers/media/i2c/max9271.h | 9 +++++++++ drivers/media/i2c/rdacm20.c | 4 +--- drivers/media/i2c/rdacm21.c | 5 +---- 4 files changed, 23 insertions(+), 7 deletions(-) diff --git a/drivers/media/i2c/max9271.c b/drivers/media/i2c/max9271.c index 2c7dc7fb9846..ff86c8c4ea61 100644 --- a/drivers/media/i2c/max9271.c +++ b/drivers/media/i2c/max9271.c @@ -80,6 +80,18 @@ static int max9271_pclk_detect(struct max9271_device *dev) return -EIO; } +void max9271_wake_up(struct max9271_device *dev) +{ + /* + * Use the chip default address as this function has to be called + * before any other one. + */ + dev->client->addr = MAX9271_DEFAULT_ADDR; + 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 90eb73f0e6e9..c1a717153303 100644 --- a/drivers/media/i2c/rdacm20.c +++ b/drivers/media/i2c/rdacm20.c @@ -455,9 +455,7 @@ static int rdacm20_initialize(struct rdacm20_device *dev) unsigned int retry = 3; int ret; - /* 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 179d107f494c..553e3f03752b 100644 --- a/drivers/media/i2c/rdacm21.c +++ b/drivers/media/i2c/rdacm21.c @@ -450,10 +450,7 @@ static int rdacm21_initialize(struct rdacm21_device *dev) { int ret; - /* 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.31.1