Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp5407421imu; Wed, 19 Dec 2018 10:32:54 -0800 (PST) X-Google-Smtp-Source: AFSGD/VgJgJ5d/396e/uulGkuMuFb9UxaUQ8xXOobwJCaXOv4ND8glvgLtlzWAg1Texp6DytFIVB X-Received: by 2002:a17:902:2969:: with SMTP id g96mr21177766plb.295.1545244374473; Wed, 19 Dec 2018 10:32:54 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1545244374; cv=none; d=google.com; s=arc-20160816; b=czIu5jk+C45+eY6ClQE1v5YACu0GGmq9iS3adlbt6l52M5/pl3TF6xUOKPSIjJ35aU H+W5gNT4Txt9h0o7ACVwKU8LLZoStqZMlJws/uxQ3tAUvdMeHD2q0DEPWxo3RehoL3Ti V5/fXgwBrZK6J3gpsoL5NSWJ0CTqMmLjaXQVQ/1Hkc66yod9QsuAc41T7q/U+Fs6m02k EHOMMc4o+n5zAdTh9e6cH8MFzqfSCVk5TDzvOeIXmvL+E2sO2Laz0+8TnNDVmHeUHFjq DeiOoIS8f8dkmW7ayeI44Q30L7rrhHqvP0tcF4rmi68Pz10Km83Bsq3VY9CT0ylAILwI yv5w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=5JoYEUrUsPj23HqEWhBDjwHuA/oENY4DxMfQ3zq3bk4=; b=uJ7omoUjFDIRHkdeG6zVFNt8cpSkgF73W6eH1tSDGEEaHAqbYNVrmacNyVRU7gjyJc NRZgNKcxBdRZbs78NWzvtwHC6CtLqBcacNMT3dhLp625xY5DKutGegJntTjA+LzTASlU i0j4bYmnnngaPeI2jJBtlOMCacO4Vw6UeTBL7AAFUq+f9fTV2mbML+0OzbUcCe+rtXeE pyfctN+GHqRckc8ZDwfS90WoicCT3U3HFvFHlneH004/Dianikm2s6+EcXYAGovsyBXe 3nSh5Q6Yudb1o9lKPdEDEXNVvALh8u8Y7aRQTWjcVlxF3tF86mT0g0gaWLfTqNSKB2av SVlg== 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 i189si16995333pfg.265.2018.12.19.10.32.38; Wed, 19 Dec 2018 10:32:54 -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; 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 S1730125AbeLSQtR (ORCPT + 99 others); Wed, 19 Dec 2018 11:49:17 -0500 Received: from sauhun.de ([88.99.104.3]:55886 "EHLO pokefinder.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729995AbeLSQsk (ORCPT ); Wed, 19 Dec 2018 11:48:40 -0500 Received: from localhost (p54B333DA.dip0.t-ipconnect.de [84.179.51.218]) by pokefinder.org (Postfix) with ESMTPSA id E11302E35D4; Wed, 19 Dec 2018 17:48:38 +0100 (CET) From: Wolfram Sang To: linux-i2c@vger.kernel.org Cc: linux-renesas-soc@vger.kernel.org, Hans de Goede , linux-pm@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Wolfram Sang , Orson Zhai , Baolin Wang , Chunyan Zhang , linux-kernel@vger.kernel.org Subject: [PATCH 07/10] i2c: sprd: use core helper to mark adapter suspended Date: Wed, 19 Dec 2018 17:48:23 +0100 Message-Id: <20181219164827.20985-8-wsa+renesas@sang-engineering.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20181219164827.20985-1-wsa+renesas@sang-engineering.com> References: <20181219164827.20985-1-wsa+renesas@sang-engineering.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Rejecting transfers should be handled by the core. Signed-off-by: Wolfram Sang --- drivers/i2c/busses/i2c-sprd.c | 14 ++------------ 1 file changed, 2 insertions(+), 12 deletions(-) diff --git a/drivers/i2c/busses/i2c-sprd.c b/drivers/i2c/busses/i2c-sprd.c index e266d8a713d9..961123529678 100644 --- a/drivers/i2c/busses/i2c-sprd.c +++ b/drivers/i2c/busses/i2c-sprd.c @@ -86,7 +86,6 @@ struct sprd_i2c { u32 count; int irq; int err; - bool is_suspended; }; static void sprd_i2c_set_count(struct sprd_i2c *i2c_dev, u32 count) @@ -284,9 +283,6 @@ static int sprd_i2c_master_xfer(struct i2c_adapter *i2c_adap, struct sprd_i2c *i2c_dev = i2c_adap->algo_data; int im, ret; - if (i2c_dev->is_suspended) - return -EBUSY; - ret = pm_runtime_get_sync(i2c_dev->dev); if (ret < 0) return ret; @@ -590,10 +586,7 @@ static int __maybe_unused sprd_i2c_suspend_noirq(struct device *dev) { struct sprd_i2c *i2c_dev = dev_get_drvdata(dev); - i2c_lock_bus(&i2c_dev->adap, I2C_LOCK_ROOT_ADAPTER); - i2c_dev->is_suspended = true; - i2c_unlock_bus(&i2c_dev->adap, I2C_LOCK_ROOT_ADAPTER); - + i2c_mark_adapter_suspended(&i2c_dev->adap); return pm_runtime_force_suspend(dev); } @@ -601,10 +594,7 @@ static int __maybe_unused sprd_i2c_resume_noirq(struct device *dev) { struct sprd_i2c *i2c_dev = dev_get_drvdata(dev); - i2c_lock_bus(&i2c_dev->adap, I2C_LOCK_ROOT_ADAPTER); - i2c_dev->is_suspended = false; - i2c_unlock_bus(&i2c_dev->adap, I2C_LOCK_ROOT_ADAPTER); - + i2c_mark_adapter_resumed(&i2c_dev->adap); return pm_runtime_force_resume(dev); } -- 2.11.0