Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp4642283ybl; Wed, 22 Jan 2020 01:53:39 -0800 (PST) X-Google-Smtp-Source: APXvYqzNj4dcSD43O+lms1yiy8bV7o8OC26t5mg1UaMCuPtG5HIj2eZu4hZUnYoCJ4jz20UDU2ec X-Received: by 2002:aca:eb83:: with SMTP id j125mr5893660oih.153.1579686819819; Wed, 22 Jan 2020 01:53:39 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579686819; cv=none; d=google.com; s=arc-20160816; b=spw2ehKFgsDQFeJq6gHUMO3LAIj+y8WGITOR3it4iGnFh3JqMi5Ok0Y7GAuDqnlr+e XX/myW29mUiK9VmxGq0jBzdhzJHRGQDxh+P0S/kpmd9EN4NdB6hP0VLFt737TY2gUkAR PImvSWvp2wj4bWQw4pkL/2voZjTxbcZlCu6h5Q/u59Sir73acaG4OgVlusmXSiO/Ywe+ rpt5I6iV7pKtBNN6leb2BZnr9UegJ2awwZx38tdkwzu4HQ2W0pznbM29TIv9Io+OaE55 48BszvJU7IZY21/xWb2cJToJ8zsWif7xgYRarCHgfACGBCGKFdpxu9aU+IRjmCpVLtPd Ktnw== 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=BPKQBVyLSmK9CvDvLyrUVi6z9Zoz/d2iEjMJBMmw2OY=; b=Cte3kEST8WfHZ9AlYOk4i8rsJaVF+1XetHJTTUyRM0N/aGX4WLJSQs3RHVj9ltTiPd 6g5ReKeo3i+wCgpJtotpX2XAUzp9BIxH6a/5ahRLR+cqvGvsmK5ihFCs64hUT/gh/B2U rglR9DWSmWvl6NCp5pRuQTbq1RkBIJfPRWoOwJYJ9aZ9AZdlqCm1SG+bfQhLwCEAM0v9 rSHqyI7INP+ou+QYTVsxWUsD6j6x9VVd+kWLBqJ5naq3j3tCLI5Y/y7SsdLkbWXmVs2o CFsx0ivAqZn32Ey8RA2mMoUB5L3WGprDVnn/KyfAoU78twygGu1FZTJ3ZRDOMrzOYik9 f0XA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=BMbCjDV2; 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 n25si19705013oij.175.2020.01.22.01.53.27; Wed, 22 Jan 2020 01:53:39 -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=BMbCjDV2; 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 S1731033AbgAVJgP (ORCPT + 99 others); Wed, 22 Jan 2020 04:36:15 -0500 Received: from mail.kernel.org ([198.145.29.99]:51560 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731634AbgAVJgI (ORCPT ); Wed, 22 Jan 2020 04:36:08 -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 49CDF2467A; Wed, 22 Jan 2020 09:36:07 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1579685767; bh=tBqdpAMMkV29Q/s1tH+suMTJHE0eP4HIV/Cod+Jo7Hk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=BMbCjDV2mA7c2MDAYuMGHTYFfzsW157QEf6l9WuDyNY0tP9nTV7+pQ2YxQbFhNFsB P/aohSPnZ5kCXmvS5rsdLfXgdodna4Ngw94nIpzDhqAh+A30fBFgtOz1ZJuLjNPmE0 u6f6em7dG/EzFMlRYbuZ1k3IZUNBbBI9MlNVQ/eA= 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.9 71/97] USB: serial: io_edgeport: use irqsave() in USBs complete callback Date: Wed, 22 Jan 2020 10:29:15 +0100 Message-Id: <20200122092807.822542059@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200122092755.678349497@linuxfoundation.org> References: <20200122092755.678349497@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 61671e277bb4..b9b56ec6ff24 100644 --- a/drivers/usb/serial/io_edgeport.c +++ b/drivers/usb/serial/io_edgeport.c @@ -572,6 +572,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; @@ -603,7 +604,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", @@ -626,7 +627,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 */ @@ -639,9 +641,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); @@ -682,6 +686,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", @@ -701,7 +706,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; @@ -725,7 +730,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