Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp4628737ybl; Wed, 22 Jan 2020 01:34:51 -0800 (PST) X-Google-Smtp-Source: APXvYqzlxmUfHGgef27Flbn32QZ8GVsXjKRdkNvB+zvRbzYKry0J93hkGkAWsTWaUdhaF7muMWn7 X-Received: by 2002:a05:6830:18d4:: with SMTP id v20mr6934690ote.29.1579685690958; Wed, 22 Jan 2020 01:34:50 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579685690; cv=none; d=google.com; s=arc-20160816; b=vvX3Y4XLPBnH+zV5K7aulceBfinQn7FlBfHN+O2vSVGPYz/ps3ozNBugZYwxjr/RTT 8fxsRAN2YY6+vesU/wHFykLzAGSa+FnsieyuOZCTp6Bl5F09rNrM1mEO0jQA6ankxIlc OibjHgaiExqm1UuUd8/F1TKlSe0vU9TKkF13yKdf0p/0SMPaCvrvSqq6IT8zeIPtd1J/ OwIh0i/M3V4yj2TbAD70W9OuvAkOkJsup6J6CeIpWPbm03pYhXYsoreU2X64jvJrGFAS 4wICrGXxOUpkBMcjmT+Ahhr9o9xqDzSC7AWA/LCkDbDuM6Cq0Xgv12rAzmNTmtOuRW+l liHg== 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=LdoVFd6zPZiduv+zrC00+xNoLxNZIj+/2TUlENcKM4A=; b=n6lzYmnP0vxdceWIVXDgt5jWH3WNY9SliNOHCV/bGLcGKcj011kbx4D0D1L1JMGqHy yI4J2vaOrv03q3ZVPTyYUsj1zzbjqmpsui2JjT6AWaKhaI3hTP6jMyAX3HcRCi9axyid nXYJTe8ImSZ07gYLZU31Sfgmxsy3oNpAwO0q2AbgStV/5v+8Pd8yXt42dLhBiEqfuMyj CKYn2CdFdWczxa2gRwg7Prb7ZiXckIWr3mTm7NpPiNdhrnDCV+O9JatyLPwF1WNSTFyu SohNrYBF1ydRbN2nhviw/T8NiPFJW6l6UxPLWktIWo2qMBgXn8nohnQ5zpmvYj6H3nWX M4Gg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=DIj2ekrG; 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 h203si21704948oif.3.2020.01.22.01.34.39; Wed, 22 Jan 2020 01:34:50 -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=DIj2ekrG; 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 S1726078AbgAVJcW (ORCPT + 99 others); Wed, 22 Jan 2020 04:32:22 -0500 Received: from mail.kernel.org ([198.145.29.99]:45074 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729439AbgAVJcU (ORCPT ); Wed, 22 Jan 2020 04:32:20 -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 AE9E32071E; Wed, 22 Jan 2020 09:32:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1579685540; bh=yuc2WD3xnHmcdfjcvYL1sN24yQMukUchQOZdU/paCYU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=DIj2ekrGCGZbMSEB2IfwlLxFKmeMxqOQqNh3gGrRX8d7DXOGWFqGrxicCmkanLs+h B3wd4iFi/Ll5N+GW9QBjXGOk+kAy9KvyRgpijeNzC/o5+KU+dxvhljWnfOLAIKqEjE RQhLbHdp5KnlQCtkLzrw4oonU4wWPXluChVc6P3U= 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.4 55/76] USB: serial: io_edgeport: use irqsave() in USBs complete callback Date: Wed, 22 Jan 2020 10:29:11 +0100 Message-Id: <20200122092759.185198066@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200122092751.587775548@linuxfoundation.org> References: <20200122092751.587775548@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 4db280e6fac9..1995e6306b88 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