Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp728163pxb; Fri, 14 Jan 2022 15:08:57 -0800 (PST) X-Google-Smtp-Source: ABdhPJy0ff9SidBi5JcWP7LtJ6xARpp7w3HcB0Sna2qrKjls6Z5t55BjhbiodsBdntRSokwIevdy X-Received: by 2002:a63:8c:: with SMTP id 134mr9835979pga.599.1642201736961; Fri, 14 Jan 2022 15:08:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642201736; cv=none; d=google.com; s=arc-20160816; b=AZTMmsH2MqamWnYRNi92PJaczAb0IYdWjpLyI4zfMWJ9Jl6KCJhZaqd/qWZSchyuTd uGtF/6srCk9wLIla80jL55UNWu3J6V/jUYqAIN5O98mwOgJgg63Q8k25M5s9uVgjRXPi DB3LpoFCLGCH4SvoD8xVhliVCVSgJBbrts+oTp3Q75zF/Xn5b6YGDIue9GBc5pXWN+li cUicAZM1HUNAVoeCMmsakxWge28dI60afGbo23UQXeKTIdY4B8WJ124obYiGbxliLBMy hZvVRe6bcuoUmkCSLgJ9qAW8nabRJSeIWAcSoeuG8BamwF+wJ9CuHWhbqxGIJGeW8HyI fFlQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=0wOvJxanjv8dJh5us8ooGzpb/lM+VsWX3ZsU7uSOCqY=; b=gBRfdLw9MDgQQD2xS/O3LMcYYIup6ZQH/NZd+48Zaql9Da2i48EdItrJnz/gN1gDEA VBY4agnJcIqTZzkRlElY7nKO/JRlbhILzU90hrQD74CH9/EcuiuwlMxNyHX4l2dJAoQY XbJIXfdjbLKiJH0EBKb01AKsfzvVcOau18q38O1n9Btrq/MIzcemZoNWUaCqJLoAyBJh vs4jgPs1IztCunNBSTyPI/8B6e4/uzTEqmtZoKpc8JzQIWmhJl8/9vktzSmKE25pKTAP 81+lOvmSgcNuW9IkaL2Pxb/csHVHsEq5c1ot0QlHwwWAoAY2iKjocBmYks+mwEXPKDKk xQEg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=BbbzC1QW; 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=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id mu13si14166315pjb.61.2022.01.14.15.08.45; Fri, 14 Jan 2022 15:08:56 -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=@redhat.com header.s=mimecast20190719 header.b=BbbzC1QW; 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=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230024AbiANV5f (ORCPT + 99 others); Fri, 14 Jan 2022 16:57:35 -0500 Received: from us-smtp-delivery-124.mimecast.com ([170.10.133.124]:27639 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230001AbiANV5d (ORCPT ); Fri, 14 Jan 2022 16:57:33 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1642197452; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=0wOvJxanjv8dJh5us8ooGzpb/lM+VsWX3ZsU7uSOCqY=; b=BbbzC1QWvLFkLm0przHgaiEssyvFXWbObc/7qcWgMpRtKwL7z8YJYZjaPN0xyx3qjnBuoI ELFfrMGl2Gr0GP/u9oGi9IX/mFnK7r+/ZELRJvPvQMh+rPxWLMe16xRDV+BlF4VfqaHmwB rwX/fAalxBh1gEGJ0pZbDmtAAov2tcQ= Received: from mail-ed1-f71.google.com (mail-ed1-f71.google.com [209.85.208.71]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id us-mta-300-44Pu1O30N3KqjY7B0gl_Fg-1; Fri, 14 Jan 2022 16:57:31 -0500 X-MC-Unique: 44Pu1O30N3KqjY7B0gl_Fg-1 Received: by mail-ed1-f71.google.com with SMTP id l10-20020a056402124a00b0040186fbe40dso717157edw.7 for ; Fri, 14 Jan 2022 13:57:31 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=0wOvJxanjv8dJh5us8ooGzpb/lM+VsWX3ZsU7uSOCqY=; b=FL0wExhWXZtsFUnn+JBSu+8cZ/9B3BPUGHozkDHU25Z2LFSN4quw19z5Tq1JsVtsTG 2tMtRiKedyxVWAIv81qZntMT6P7BNwtXfgOPj/rmIS9M2BpSITyj9Us+e/asa1FF24A2 vizxVZ2caHUKgBWZ+hap/Th/ZB9vjSsUD75tUgDGYWOgVea9qbY4sAM++nJvc/JONXC9 kOwoW+QiPAu4zKLvYcxWTxAaMFF0EViGnLsDRUrhiQe2TN2qvI/7hftOLPF7AC9bE8AC BAGtoGv9/ewqAt6nXCG8cqD5ZCClH+AeXZm9RXjFMUDjW4MDJH5AujABOSlwH66ag+3P TNgA== X-Gm-Message-State: AOAM531XbjuOY+FdFW7MeaYCGm6v82TwHeF1j68M2wUxyN4gzH0k6dHd k9reVwPqYrCWHrRQsldbcYuWzl9oXTmFs5v7e+a7Q/QAhCXsZjMUC03mjpUedRoK0lAZ9XcIj4t MDTEqnnX6XWyWTMN8pRoy3Ic6hMrw3cgt1zN13uIMWXqh/vBR/h7jUoC/ctzbPxwGzRzB8A== X-Received: by 2002:aa7:db41:: with SMTP id n1mr10643172edt.307.1642197449930; Fri, 14 Jan 2022 13:57:29 -0800 (PST) X-Received: by 2002:aa7:db41:: with SMTP id n1mr10643153edt.307.1642197449573; Fri, 14 Jan 2022 13:57:29 -0800 (PST) Received: from redhat.com ([2.55.154.210]) by smtp.gmail.com with ESMTPSA id hd16sm2084204ejc.62.2022.01.14.13.57.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 14 Jan 2022 13:57:29 -0800 (PST) Date: Fri, 14 Jan 2022 16:57:27 -0500 From: "Michael S. Tsirkin" To: linux-kernel@vger.kernel.org Cc: Amit Shah , Arnd Bergmann , Greg Kroah-Hartman , virtualization@lists.linux-foundation.org Subject: [PATCH v2 2/3] virtio_console: break out of buf poll on remove Message-ID: <20220114215641.239984-3-mst@redhat.com> References: <20220114215641.239984-1-mst@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20220114215641.239984-1-mst@redhat.com> X-Mailer: git-send-email 2.27.0.106.g8ac3dc51b1 X-Mutt-Fcc: =sent Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org A common pattern for device reset is currently: vdev->config->reset(vdev); .. cleanup .. reset prevents new interrupts from arriving and waits for interrupt handlers to finish. However if - as is common - the handler queues a work request which is flushed during the cleanup stage, we have code adding buffers / trying to get buffers while device is reset. Not good. This was reproduced by running modprobe virtio_console modprobe -r virtio_console in a loop. Fix this up by calling virtio_break_device + flush before reset. Bugzilla: https://bugzilla.redhat.com/show_bug.cgi?id=1786239 Signed-off-by: Michael S. Tsirkin --- drivers/char/virtio_console.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/drivers/char/virtio_console.c b/drivers/char/virtio_console.c index 2359889a35a0..e3c430539a17 100644 --- a/drivers/char/virtio_console.c +++ b/drivers/char/virtio_console.c @@ -1957,6 +1957,13 @@ static void virtcons_remove(struct virtio_device *vdev) list_del(&portdev->list); spin_unlock_irq(&pdrvdata_lock); + /* Device is going away, exit any polling for buffers */ + virtio_break_device(vdev); + if (use_multiport(portdev)) + flush_work(&portdev->control_work); + else + flush_work(&portdev->config_work); + /* Disable interrupts for vqs */ virtio_reset_device(vdev); /* Finish up work that's lined up */ -- MST