Received: by 2002:ac0:aed5:0:0:0:0:0 with SMTP id t21csp1179362imb; Sat, 2 Mar 2019 05:50:18 -0800 (PST) X-Google-Smtp-Source: APXvYqwGKYAs13mhP5eXVmHN7qPpErPDOg5W23Cx6AKFuTCcChyPXl5mVKGNnAWPICGPq/islOrk X-Received: by 2002:a17:902:82cc:: with SMTP id u12mr10952103plz.189.1551534618554; Sat, 02 Mar 2019 05:50:18 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551534618; cv=none; d=google.com; s=arc-20160816; b=uB2Rcndm1thRn13YrE7DH34lvETOerNHn5sWjVEIJ1HqrqEtuySa0AnwvaMxfr9Mdl SA1Vzb296RKnnEBxlWdi486nynnl7Wz5e9hb/DpWb4AAGgD5vCSFAOi0blW559ukkKU/ 9sUjBHKnkAcgBhhYccmypMUV/eP6ZlHEHVGvJ1ReOs2XZ3miqJDdoDfFDmk4erPr8xaq k1020WL5CkR8p7SnWyK5sp4z/MB96WMPSZWTUlgB6i0n0/41tT6fWGUNg7W2Fh6/g+F3 s0QWf6XGxD1tMwClCXWOaMq3FdjS98uDI5Y+ob8unn3611MlA+ZsJ+YeSwID7azM/owx 4eaw== 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=wxL42rLO+knxV/H+LAuOb2sP8Z0M0piko+tf3gyVE/8=; b=KRzreMV1Atg2Rxh/YJznd4roLkvn3QyXJcQvYz7W/B40zkTRCdKTgPGu5Bl+a6cv7D YO67H++oZfPT6o5Lpg/vgIc1UYJFhw5gM6eMECehAXCmy0+qRQ4RPu6oHPB0x+ovhrvC Ds84eVZyyTihWX156lQnk1FBvJXiKw1N0oEUO61q8Gg+Bm8ucXCIR7UjFhdPXST6xsXw n7p2mR8F1eluB446zOnxtW7SldI02+X3E+opjsnht1GRtzPF8nfw+0dA2GkdC9OFDUH/ 7VIEorRHF3gwqG/Opj9qDoKgpbiz+BbTx6tynjZ+tjf45QRFtjlCsNZkOCwKyZct/Veo fbIA== 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 g34si729076pld.15.2019.03.02.05.50.03; Sat, 02 Mar 2019 05:50:18 -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 S1726985AbfCBNsT (ORCPT + 99 others); Sat, 2 Mar 2019 08:48:19 -0500 Received: from sauhun.de ([88.99.104.3]:36374 "EHLO pokefinder.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726384AbfCBNrs (ORCPT ); Sat, 2 Mar 2019 08:47:48 -0500 Received: from localhost (p54B33179.dip0.t-ipconnect.de [84.179.49.121]) by pokefinder.org (Postfix) with ESMTPSA id 7AB254A177A; Sat, 2 Mar 2019 14:47:46 +0100 (CET) From: Wolfram Sang To: linux-i2c@vger.kernel.org Cc: linux-renesas-soc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Keerthy , Peter Rosin , Tony Lindgren , Russell King , Andy Shevchenko , Stefan Lengfeld , Phil Reid , Tero Kristo , linux-omap@vger.kernel.org, linux-tegra@vger.kernel.org, Wolfram Sang Subject: [RFC PATCH v2 6/7] i2c: tegra-bpmp: convert to use new atomic callbacks Date: Sat, 2 Mar 2019 14:47:34 +0100 Message-Id: <20190302134735.4393-7-wsa+renesas@sang-engineering.com> X-Mailer: git-send-email 2.11.0 In-Reply-To: <20190302134735.4393-1-wsa+renesas@sang-engineering.com> References: <20190302134735.4393-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 The driver did handle this internally, convert it to use the new callbacks. Signed-off-by: Wolfram Sang --- drivers/i2c/busses/i2c-tegra-bpmp.c | 27 ++++++++++++++++++++++----- 1 file changed, 22 insertions(+), 5 deletions(-) diff --git a/drivers/i2c/busses/i2c-tegra-bpmp.c b/drivers/i2c/busses/i2c-tegra-bpmp.c index f6cd35d0a2ac..02b78ba5b23b 100644 --- a/drivers/i2c/busses/i2c-tegra-bpmp.c +++ b/drivers/i2c/busses/i2c-tegra-bpmp.c @@ -207,7 +207,8 @@ static int tegra_bpmp_i2c_msg_len_check(struct i2c_msg *msgs, unsigned int num) static int tegra_bpmp_i2c_msg_xfer(struct tegra_bpmp_i2c *i2c, struct mrq_i2c_request *request, - struct mrq_i2c_response *response) + struct mrq_i2c_response *response, + bool atomic) { struct tegra_bpmp_message msg; int err; @@ -222,7 +223,7 @@ static int tegra_bpmp_i2c_msg_xfer(struct tegra_bpmp_i2c *i2c, msg.rx.data = response; msg.rx.size = sizeof(*response); - if (irqs_disabled()) + if (atomic) err = tegra_bpmp_transfer_atomic(i2c->bpmp, &msg); else err = tegra_bpmp_transfer(i2c->bpmp, &msg); @@ -230,8 +231,9 @@ static int tegra_bpmp_i2c_msg_xfer(struct tegra_bpmp_i2c *i2c, return err; } -static int tegra_bpmp_i2c_xfer(struct i2c_adapter *adapter, - struct i2c_msg *msgs, int num) +static int tegra_bpmp_i2c_xfer_common(struct i2c_adapter *adapter, + struct i2c_msg *msgs, int num, + bool atomic) { struct tegra_bpmp_i2c *i2c = i2c_get_adapdata(adapter); struct mrq_i2c_response response; @@ -253,7 +255,7 @@ static int tegra_bpmp_i2c_xfer(struct i2c_adapter *adapter, return err; } - err = tegra_bpmp_i2c_msg_xfer(i2c, &request, &response); + err = tegra_bpmp_i2c_msg_xfer(i2c, &request, &response, atomic); if (err < 0) { dev_err(i2c->dev, "failed to transfer message: %d\n", err); return err; @@ -268,6 +270,20 @@ static int tegra_bpmp_i2c_xfer(struct i2c_adapter *adapter, return num; } +static int tegra_bpmp_i2c_xfer(struct i2c_adapter *adapter, + struct i2c_msg *msgs, int num) + +{ + return tegra_bpmp_i2c_xfer_common(adapter, msgs, num, false); +} + +static int tegra_bpmp_i2c_xfer_atomic(struct i2c_adapter *adapter, + struct i2c_msg *msgs, int num) + +{ + return tegra_bpmp_i2c_xfer_common(adapter, msgs, num, true); +} + static u32 tegra_bpmp_i2c_func(struct i2c_adapter *adapter) { return I2C_FUNC_I2C | I2C_FUNC_SMBUS_EMUL | I2C_FUNC_10BIT_ADDR | @@ -276,6 +292,7 @@ static u32 tegra_bpmp_i2c_func(struct i2c_adapter *adapter) static const struct i2c_algorithm tegra_bpmp_i2c_algo = { .master_xfer = tegra_bpmp_i2c_xfer, + .master_xfer_atomic = tegra_bpmp_i2c_xfer_atomic, .functionality = tegra_bpmp_i2c_func, }; -- 2.11.0