Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp4640177ybl; Wed, 22 Jan 2020 01:50:25 -0800 (PST) X-Google-Smtp-Source: APXvYqzH4Ge5v0Oj2M4Tac2INcl4O0M+LLNSIo1IA/bIUpg2ZKuLgW4MLnIcyh/2dRedXQg4jX3O X-Received: by 2002:a9d:6b03:: with SMTP id g3mr6727775otp.200.1579686625269; Wed, 22 Jan 2020 01:50:25 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579686625; cv=none; d=google.com; s=arc-20160816; b=IJqg4/vBOt0MYpc95+h1Mo42enH2Lww5vXy/NGKX6AXyj+cAbjAK3xJekOAJJCJeuE 4ydP5wqTGv9reEEJrxNzLA5Df7lZgwWAs/sKYjIfA7sNFsUsqGq4gmnVUb5ovrL5jbdZ ttQBQQ5xzMlmZbA1HeTnFaoZr2xmB+s3tvBiSj5dQ1U4xa6vLwJ04ESP7JZdhbTjh3HH 8Nh0xiFcILdQT4OHTAj9Rvc0XWt0A9HxMy9tY+c3Dk8HDB/q+3swEgtti+IpX79bL4Za 49yd3gzrIgh/oaVqwDLXJboaFyOVGPyPYY/kayI9wxos5cZZ42jGVxXv2fI+SiX7W11k EBKQ== 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:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=wfxo0ypam+OPo7SklrUtJUehSvQRmwHejZFofgXGjaE=; b=qT6irpAI60PBc/7/AuQ6Jdxn89voDd3eNTyHkSrknnSRKiXthS9D7SCnFUc925kAfd YInEy6orvtLo1GKXK3RCdnOyiHkzoOHcEQKdESK9srmNCJXs+9t8tln6Xoj5ETtPY1Yg YVkpNZKlvzE7QE2VG+n2QdEJfb5YBxWH/dbHOAB9tyZN1eNJy/6OkHRDOju3kwG6Egzk EldrVx7HNpLA0rUG8rLxJedLuXIw9I3H6tyVsXP09ifNXUsdxpLS+cPzwhgvFa4EIGUZ AeojT+XKISH6tdC+8iJR1Q2SqcsKdn3aeyOQY7PJYJ0Rbj10ZWd1u6j8VZNWwHxjyOg8 htow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=eYYYQeTv; 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 q15si13233513otk.44.2020.01.22.01.50.13; Wed, 22 Jan 2020 01:50:25 -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; dkim=pass header.i=@kernel.org header.s=default header.b=eYYYQeTv; 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 S1733295AbgAVJkC (ORCPT + 99 others); Wed, 22 Jan 2020 04:40:02 -0500 Received: from mail.kernel.org ([198.145.29.99]:58382 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1733104AbgAVJj6 (ORCPT ); Wed, 22 Jan 2020 04:39:58 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id CD32924698; Wed, 22 Jan 2020 09:39:56 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1579685997; bh=4wZbYFNTr0SRfrRjKvqb0dHa2GAEiUJgedttLIvQc1s=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=eYYYQeTvQxAxKZoiUB2RneZo5LLQXnrzPokn/6bYpEsR3zj6ph1bi1rzFmtY20QIy hN2jByxhuYhlXJ2QGlPxW/mU6mfcwndYGqh7amhNGRwz20+Wi6eh1dArBeWnGGDqKi k4CRNkMsJ1DxoswbYnbYiX4ZoYUxd8GZhjqWjC8Q= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, John Ogness , Sebastian Andrzej Siewior , Johan Hovold , Sasha Levin Subject: [PATCH 4.14 31/65] USB: serial: io_edgeport: use irqsave() in USBs complete callback Date: Wed, 22 Jan 2020 10:29:16 +0100 Message-Id: <20200122092755.237700655@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200122092750.976732974@linuxfoundation.org> References: <20200122092750.976732974@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: John Ogness [ Upstream commit dd1fae527612543e560e84f2eba4f6ef2006ac55 ] The USB completion callback does not disable interrupts while acquiring the lock. We want to remove the local_irq_disable() invocation from __usb_hcd_giveback_urb() and therefore it is required for the callback handler to disable the interrupts while acquiring the lock. The callback may be invoked either in IRQ or BH context depending on the USB host controller. Use the _irqsave() variant of the locking primitives. Signed-off-by: John Ogness Signed-off-by: Sebastian Andrzej Siewior Signed-off-by: Johan Hovold Signed-off-by: Sasha Levin --- drivers/usb/serial/io_edgeport.c | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/drivers/usb/serial/io_edgeport.c b/drivers/usb/serial/io_edgeport.c index 467870f504a5..8810de817095 100644 --- a/drivers/usb/serial/io_edgeport.c +++ b/drivers/usb/serial/io_edgeport.c @@ -652,6 +652,7 @@ static void edge_interrupt_callback(struct urb *urb) struct usb_serial_port *port; unsigned char *data = urb->transfer_buffer; int length = urb->actual_length; + unsigned long flags; int bytes_avail; int position; int txCredits; @@ -683,7 +684,7 @@ static void edge_interrupt_callback(struct urb *urb) if (length > 1) { bytes_avail = data[0] | (data[1] << 8); if (bytes_avail) { - spin_lock(&edge_serial->es_lock); + spin_lock_irqsave(&edge_serial->es_lock, flags); edge_serial->rxBytesAvail += bytes_avail; dev_dbg(dev, "%s - bytes_avail=%d, rxBytesAvail=%d, read_in_progress=%d\n", @@ -706,7 +707,8 @@ static void edge_interrupt_callback(struct urb *urb) edge_serial->read_in_progress = false; } } - spin_unlock(&edge_serial->es_lock); + spin_unlock_irqrestore(&edge_serial->es_lock, + flags); } } /* grab the txcredits for the ports if available */ @@ -719,9 +721,11 @@ static void edge_interrupt_callback(struct urb *urb) port = edge_serial->serial->port[portNumber]; edge_port = usb_get_serial_port_data(port); if (edge_port->open) { - spin_lock(&edge_port->ep_lock); + spin_lock_irqsave(&edge_port->ep_lock, + flags); edge_port->txCredits += txCredits; - spin_unlock(&edge_port->ep_lock); + spin_unlock_irqrestore(&edge_port->ep_lock, + flags); dev_dbg(dev, "%s - txcredits for port%d = %d\n", __func__, portNumber, edge_port->txCredits); @@ -762,6 +766,7 @@ static void edge_bulk_in_callback(struct urb *urb) int retval; __u16 raw_data_length; int status = urb->status; + unsigned long flags; if (status) { dev_dbg(&urb->dev->dev, "%s - nonzero read bulk status received: %d\n", @@ -781,7 +786,7 @@ static void edge_bulk_in_callback(struct urb *urb) usb_serial_debug_data(dev, __func__, raw_data_length, data); - spin_lock(&edge_serial->es_lock); + spin_lock_irqsave(&edge_serial->es_lock, flags); /* decrement our rxBytes available by the number that we just got */ edge_serial->rxBytesAvail -= raw_data_length; @@ -805,7 +810,7 @@ static void edge_bulk_in_callback(struct urb *urb) edge_serial->read_in_progress = false; } - spin_unlock(&edge_serial->es_lock); + spin_unlock_irqrestore(&edge_serial->es_lock, flags); } -- 2.20.1