Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp846062pxb; Tue, 3 Nov 2020 14:14:53 -0800 (PST) X-Google-Smtp-Source: ABdhPJzCv7wqQYlQU0pjcEutp/bcMJk96iMozSyx84UG/R5Ss6bXYm+/jdEVZvSFq1QQ92vGj4xL X-Received: by 2002:a17:906:ad8c:: with SMTP id la12mr21341157ejb.521.1604441693520; Tue, 03 Nov 2020 14:14:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604441693; cv=none; d=google.com; s=arc-20160816; b=hS3xYSV92eRHeeVxXcjNanbElPPy0RzbANOX2/KMYD+c+NU7EyJ0svDJwGwACutzWO mNNeqaBf6YJtM75nAW8nyzPLGDEwFithyHXb9xIufvBjj3PJKowLAT/S4tUq4FNKvr0r aWds/M2HKZALlUz9Qk7QknryUaXv/d8tXrYgVCoxKMkQXrsXrVeZBE59xgwqUhL638S/ t2OiSWiBSeO+Dw58Kvm5WRSzjImZVfeSHHiFm965OZvzetVagXaXis6ABKuWaYDKsFyj jw++2E/rZQPz+PT9vEOQBwhkt/ecjAYCf55yDiiYoig2hrqmTfqGNzeLdDuU9ELKAk8Y EkWA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=L/NQ45XyMr2JgSC0c59j7gygi6ENIPoUzllHlzKXlhM=; b=VaMoK4zPivVKHYKesGpwzgxB3y1KpOp2r76E1KHaNl992wvvybfFdOX9AiKIXvV/+C kSxeqtYlObfF0SdhxxDZqaAZsfySNaV92IrJv+KdZR5aPTEUKYp2W7zTivIEIvfYHo7M Ko6GeugjqkY8QKQmRIUugQ2h8iQPWagiOIuGRLUlIfSVfrAiaQkusMV8FNl4yjJlmGAN oQjMgFX1nr+On3rxTYnkh38FKtkScFurZmB8s6f3n6UIdOauH7+cwW0PAXnpycEs5cHC IG46RWV9tcdcEg2sbZD5Uyr055GqI58foIL8DcY2dI6+8BLjlRkhcOunDlP+J2N8QFfh OdoA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Zo1RGV22; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j7si13276682edy.250.2020.11.03.14.14.30; Tue, 03 Nov 2020 14:14:53 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=Zo1RGV22; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730795AbgKCWKI (ORCPT + 99 others); Tue, 3 Nov 2020 17:10:08 -0500 Received: from mail.kernel.org ([198.145.29.99]:47624 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729834AbgKCUhy (ORCPT ); Tue, 3 Nov 2020 15:37:54 -0500 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (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 0800D22277; Tue, 3 Nov 2020 20:37:53 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1604435874; bh=BkW3RaTsgcy2bokJC/5ugcgK+ra6Cfb9jO+gBVXEaKQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Zo1RGV226bx3YMUZMu3xH+QOMApZaO5rGqM5P0gG/aqNqvtvEh5S1lzhWbHaLD6C8 EOleXmmKR/DHGIXdYKdGOntoikEUvQBBoOJXYOXufNe9XTqlidh3CStw/k6yRgXZM8 syewAfdWlgI7N1m0Cd8463CkzqMCINk9Xb8GVxxA= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Julien Grall , Juergen Gross , Jan Beulich , Wei Liu Subject: [PATCH 5.9 007/391] xen/scsiback: use lateeoi irq binding Date: Tue, 3 Nov 2020 21:30:58 +0100 Message-Id: <20201103203348.577850562@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201103203348.153465465@linuxfoundation.org> References: <20201103203348.153465465@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Juergen Gross commit 86991b6e7ea6c613b7692f65106076943449b6b7 upstream. In order to reduce the chance for the system becoming unresponsive due to event storms triggered by a misbehaving scsifront use the lateeoi irq binding for scsiback and unmask the event channel only just before leaving the event handling function. In case of a ring protocol error don't issue an EOI in order to avoid the possibility to use that for producing an event storm. This at once will result in no further call of scsiback_irq_fn(), so the ring_error struct member can be dropped and scsiback_do_cmd_fn() can signal the protocol error via a negative return value. This is part of XSA-332. Cc: stable@vger.kernel.org Reported-by: Julien Grall Signed-off-by: Juergen Gross Reviewed-by: Jan Beulich Reviewed-by: Wei Liu Signed-off-by: Greg Kroah-Hartman --- drivers/xen/xen-scsiback.c | 23 +++++++++++++---------- 1 file changed, 13 insertions(+), 10 deletions(-) --- a/drivers/xen/xen-scsiback.c +++ b/drivers/xen/xen-scsiback.c @@ -91,7 +91,6 @@ struct vscsibk_info { unsigned int irq; struct vscsiif_back_ring ring; - int ring_error; spinlock_t ring_lock; atomic_t nr_unreplied_reqs; @@ -722,7 +721,8 @@ static struct vscsibk_pend *prepare_pend return pending_req; } -static int scsiback_do_cmd_fn(struct vscsibk_info *info) +static int scsiback_do_cmd_fn(struct vscsibk_info *info, + unsigned int *eoi_flags) { struct vscsiif_back_ring *ring = &info->ring; struct vscsiif_request ring_req; @@ -739,11 +739,12 @@ static int scsiback_do_cmd_fn(struct vsc rc = ring->rsp_prod_pvt; pr_warn("Dom%d provided bogus ring requests (%#x - %#x = %u). Halting ring processing\n", info->domid, rp, rc, rp - rc); - info->ring_error = 1; - return 0; + return -EINVAL; } while ((rc != rp)) { + *eoi_flags &= ~XEN_EOI_FLAG_SPURIOUS; + if (RING_REQUEST_CONS_OVERFLOW(ring, rc)) break; @@ -802,13 +803,16 @@ static int scsiback_do_cmd_fn(struct vsc static irqreturn_t scsiback_irq_fn(int irq, void *dev_id) { struct vscsibk_info *info = dev_id; + int rc; + unsigned int eoi_flags = XEN_EOI_FLAG_SPURIOUS; - if (info->ring_error) - return IRQ_HANDLED; - - while (scsiback_do_cmd_fn(info)) + while ((rc = scsiback_do_cmd_fn(info, &eoi_flags)) > 0) cond_resched(); + /* In case of a ring error we keep the event channel masked. */ + if (!rc) + xen_irq_lateeoi(irq, eoi_flags); + return IRQ_HANDLED; } @@ -829,7 +833,7 @@ static int scsiback_init_sring(struct vs sring = (struct vscsiif_sring *)area; BACK_RING_INIT(&info->ring, sring, PAGE_SIZE); - err = bind_interdomain_evtchn_to_irq(info->domid, evtchn); + err = bind_interdomain_evtchn_to_irq_lateeoi(info->domid, evtchn); if (err < 0) goto unmap_page; @@ -1253,7 +1257,6 @@ static int scsiback_probe(struct xenbus_ info->domid = dev->otherend_id; spin_lock_init(&info->ring_lock); - info->ring_error = 0; atomic_set(&info->nr_unreplied_reqs, 0); init_waitqueue_head(&info->waiting_to_free); info->dev = dev;