Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1149471imm; Fri, 13 Jul 2018 12:24:21 -0700 (PDT) X-Google-Smtp-Source: AAOMgpe4Guo88zhHkX1dmfdTCKglP3NOrSxLvWWAgimorCqcGbV4KfbmnqCQvpNJfAkvE41/2F23 X-Received: by 2002:a62:98d6:: with SMTP id d83-v6mr8472582pfk.186.1531509861629; Fri, 13 Jul 2018 12:24:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531509861; cv=none; d=google.com; s=arc-20160816; b=WzAF0zIWSmH67mvhwp5DPu4clJXqJdSy6WNzKJQf3HT6hPKO87FzSFmhiULd2jtO0j a5LUBdv4VPex+VHpoPeNVtHtE45ViN88fjwOGLl753fRn7teNwcB8S4YbdJCudlh0D1r 7F9mK5/bcc2bUSxSl3XEs9Ca41MnqJoYyj2ltcFu40vJrOQu2X31JIL7ygwVlbBkQb43 fvTpbtpayDclerb3F9HUVcoi8W1IuGV6i9XvJslccnxE5HyUmvtx1LDDTueFvVQrLfjQ gfiqoe9w9BMz+g30B8ONYOks6chjkAF0AhG39f2Zdx7TBrntDnjJnNCFEQ7xnaaOFk5w Z2Vw== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=GklzCT84N6Yb1WwM7XXZyxXeWWqbB4JggAW6jMaz0AE=; b=HdUzY3gb53Iq04TNIkZrgP8y6fcoiQ1aL/EFsgRhZ0xZ5dzjSpXPtBPPHzsHlnDCZJ ccVdl0uNPfoC49penp0xz+/MfBugqU3Q6psbHjVmv0PpUSVP48leKTSn3t5T+fP6Lofe 5kDtXNAMI/77ls8h7QC4ZXAIhyq1fvrDqK+F7AwN8QN7efi/EeDM/2iHX+h3nkCnvg7t g8XySXWLrj/wy6KxSsDLBR1Fi8FUf5XkpWsU7fXa7SBQ65jf8smyixHMvx0w+0Y6cXk6 nJcznLtoC+1si+K127WB5szo/8T7CG+Ffn5bJPu/qTJsjzc7QxrmPQe9ZblIokeMRxjF vkSg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v3-v6si22387451pgs.172.2018.07.13.12.24.06; Fri, 13 Jul 2018 12:24:21 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731992AbeGMThs (ORCPT + 99 others); Fri, 13 Jul 2018 15:37:48 -0400 Received: from mga18.intel.com ([134.134.136.126]:12557 "EHLO mga18.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731493AbeGMThs (ORCPT ); Fri, 13 Jul 2018 15:37:48 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga006.fm.intel.com ([10.253.24.20]) by orsmga106.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 13 Jul 2018 12:21:50 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.51,348,1526367600"; d="scan'208";a="245527673" Received: from yoojae-mobl1.amr.corp.intel.com (HELO [10.7.153.143]) ([10.7.153.143]) by fmsmga006.fm.intel.com with ESMTP; 13 Jul 2018 12:21:35 -0700 Subject: Re: [PATCH] i2c: aspeed: Adjust spinlock scope in the irq handler To: Brendan Higgins Cc: Benjamin Herrenschmidt , Joel Stanley , Andrew Jeffery , linux-i2c@vger.kernel.org, OpenBMC Maillist , Linux ARM , linux-aspeed@lists.ozlabs.org, Linux Kernel Mailing List , jarkko.nikula@linux.intel.com, james.feist@linux.intel.com, vernon.mauery@linux.intel.com References: <20180702214011.16071-1-jae.hyun.yoo@linux.intel.com> From: Jae Hyun Yoo Message-ID: <59538d26-f025-28da-63df-f675e80fd68b@linux.intel.com> Date: Fri, 13 Jul 2018 12:21:35 -0700 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 7/12/2018 1:41 AM, Brendan Higgins wrote: > On Mon, Jul 2, 2018 at 2:40 PM Jae Hyun Yoo > wrote: >> >> This patch adjusts spinlock scope to make it wrap the whole irq >> handler using a single lock/unlock which covers both master and >> slave handlers. >> >> Signed-off-by: Jae Hyun Yoo >> --- >> drivers/i2c/busses/i2c-aspeed.c | 16 ++++++++++------ >> 1 file changed, 10 insertions(+), 6 deletions(-) >> >> diff --git a/drivers/i2c/busses/i2c-aspeed.c b/drivers/i2c/busses/i2c-aspeed.c >> index 60e4d0e939a3..9f02aa959a3e 100644 >> --- a/drivers/i2c/busses/i2c-aspeed.c >> +++ b/drivers/i2c/busses/i2c-aspeed.c >> @@ -234,7 +234,6 @@ static bool aspeed_i2c_slave_irq(struct aspeed_i2c_bus *bus) >> bool irq_handled = true; >> u8 value; >> >> - spin_lock(&bus->lock); >> if (!slave) { >> irq_handled = false; >> goto out; >> @@ -325,7 +324,6 @@ static bool aspeed_i2c_slave_irq(struct aspeed_i2c_bus *bus) >> writel(status_ack, bus->base + ASPEED_I2C_INTR_STS_REG); >> >> out: >> - spin_unlock(&bus->lock); >> return irq_handled; >> } >> #endif /* CONFIG_I2C_SLAVE */ >> @@ -389,7 +387,6 @@ static bool aspeed_i2c_master_irq(struct aspeed_i2c_bus *bus) >> u8 recv_byte; >> int ret; >> >> - spin_lock(&bus->lock); >> irq_status = readl(bus->base + ASPEED_I2C_INTR_STS_REG); >> /* Ack all interrupt bits. */ >> writel(irq_status, bus->base + ASPEED_I2C_INTR_STS_REG); >> @@ -547,22 +544,29 @@ static bool aspeed_i2c_master_irq(struct aspeed_i2c_bus *bus) >> dev_err(bus->dev, >> "irq handled != irq. expected 0x%08x, but was 0x%08x\n", >> irq_status, status_ack); >> - spin_unlock(&bus->lock); >> return !!irq_status; >> } >> >> static irqreturn_t aspeed_i2c_bus_irq(int irq, void *dev_id) >> { >> struct aspeed_i2c_bus *bus = dev_id; >> + bool ret; >> + >> + spin_lock(&bus->lock); >> >> #if IS_ENABLED(CONFIG_I2C_SLAVE) >> if (aspeed_i2c_slave_irq(bus)) { >> dev_dbg(bus->dev, "irq handled by slave.\n"); >> - return IRQ_HANDLED; >> + ret = true; >> + goto out; >> } >> #endif /* CONFIG_I2C_SLAVE */ >> >> - return aspeed_i2c_master_irq(bus) ? IRQ_HANDLED : IRQ_NONE; >> + ret = aspeed_i2c_master_irq(bus); >> + >> +out: >> + spin_unlock(&bus->lock); >> + return ret ? IRQ_HANDLED : IRQ_NONE; >> } >> >> static int aspeed_i2c_master_xfer(struct i2c_adapter *adap, >> -- >> 2.17.1 >> > > Reviewed-by: Brendan Higgins > > Thanks! > Thanks Brendan! BTW, to whom should I ask applying this patch? Should I send v2 after adding your reviewed-by tag? Thanks, Jae