Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3064065ybt; Mon, 29 Jun 2020 14:19:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzZZ3vX6G6g5X8YL0aieadCBDaLa1LJ16p+ECs1h3iwnB3hF40JBbi5uyC1t7DDA3Un8Nd9 X-Received: by 2002:a17:906:38d6:: with SMTP id r22mr15125194ejd.219.1593465567960; Mon, 29 Jun 2020 14:19:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593465567; cv=none; d=google.com; s=arc-20160816; b=rG59n+6azLhRRdOH71fU8tSmxiKGyKGyMeQ8h4bgrYX/0lZjbDszZlRJAaxDHqDc1m X05e0/Lw+DGJpXXW4GErDX4L4JrF3sXtDzFruP6Br5fF5rSU4v2hYGc1zIkRuc1w/vKG PAdPghcgZLRw2Mkmj+g1S5QhFFeZAfYVkI8+xsh0cb3kMbhpvhkUtVK4OsiCe4tOmMSZ cjK5F0eHoeCuwOjjm2wlSySQBrY4iKq9PeSaxiQy/Ot42QNCZKcSEhP9bzYWkABOdhj1 tMwqZe8g1nSe8zpvxXuLqf3Q7og4brsF1i5G1ze4ohzIZsKONI25RKGiuDIWPrMW+Gln ZIMg== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=YTqLGPC7YmrAaPuHQKNN1lYZMzJVkdIIb1BJu4c9lLo=; b=ZBCQ5lZLcx5GPRursbBJUX07nPWG7U0bCQU76JNZinQy+OS4m8LyVy1RTLqg+EwaAr Eph9SxZR0SOKhlDzhmxwOBK4rQp/TqzjZtOBC0ZIptlo0UgX6qRvhVIl+Rj6wi2Fld9O gtNZT4aKMYM4A4wxRk8kMCNycG54JL9/b/XKMowSywNOUHO4+tTKGDut2p1i9jGYmJZT +hEjFeH3DBw8Tm6cGDyqpQ6rT8OHdTR5SqmflGJPEfgIGX2wjMUJQ1DEVfp8rvuI6oO8 PxFUw1cnztsAsXAkeCgJ4GHA/L+oH25BlGeLNdPWKNOHfXwkjVHymx+p3E99MBBZjU1V +4mA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=yMDGvTXD; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x5si427923eje.481.2020.06.29.14.19.05; Mon, 29 Jun 2020 14:19:27 -0700 (PDT) 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=yMDGvTXD; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388662AbgF2VPx (ORCPT + 99 others); Mon, 29 Jun 2020 17:15:53 -0400 Received: from mail.kernel.org ([198.145.29.99]:42454 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729955AbgF2SzQ (ORCPT ); Mon, 29 Jun 2020 14:55:16 -0400 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 56A8525569; Mon, 29 Jun 2020 15:55:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1593446128; bh=Jo8In8pOuQGqnMtj6T+n6gTtyibSKsc+LNmmeZu4R8w=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=yMDGvTXD5gOJ0EloMKNQ64W8Jsh7qpZzyzFoSDCjJ4fRRD5k943hFmUoJKjjaYQMX jcXmiEuSXHOBG8KFXm+85RaMZh76PjJV7uH4g0HgCvgMiQOtxrmP3JuLJFxNpBI8zJ t+Rih80sOG2GrgqhqT9/cwnL4ImOUlLaMcGAZCJU= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Luis Chamberlain , Jan Kara , Bart Van Assche , Christoph Hellwig , Jens Axboe , Sasha Levin Subject: [PATCH 4.4 119/135] blktrace: break out of blktrace setup on concurrent calls Date: Mon, 29 Jun 2020 11:52:53 -0400 Message-Id: <20200629155309.2495516-120-sashal@kernel.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200629155309.2495516-1-sashal@kernel.org> References: <20200629155309.2495516-1-sashal@kernel.org> MIME-Version: 1.0 X-KernelTest-Patch: http://kernel.org/pub/linux/kernel/v4.x/stable-review/patch-4.4.229-rc1.gz X-KernelTest-Tree: git://git.kernel.org/pub/scm/linux/kernel/git/stable/linux-stable-rc.git X-KernelTest-Branch: linux-4.4.y X-KernelTest-Patches: git://git.kernel.org/pub/scm/linux/kernel/git/stable/stable-queue.git X-KernelTest-Version: 4.4.229-rc1 X-KernelTest-Deadline: 2020-07-01T15:53+00:00 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Luis Chamberlain [ Upstream commit 1b0b283648163dae2a214ca28ed5a99f62a77319 ] We use one blktrace per request_queue, that means one per the entire disk. So we cannot run one blktrace on say /dev/vda and then /dev/vda1, or just two calls on /dev/vda. We check for concurrent setup only at the very end of the blktrace setup though. If we try to run two concurrent blktraces on the same block device the second one will fail, and the first one seems to go on. However when one tries to kill the first one one will see things like this: The kernel will show these: ``` debugfs: File 'dropped' in directory 'nvme1n1' already present! debugfs: File 'msg' in directory 'nvme1n1' already present! debugfs: File 'trace0' in directory 'nvme1n1' already present! `` And userspace just sees this error message for the second call: ``` blktrace /dev/nvme1n1 BLKTRACESETUP(2) /dev/nvme1n1 failed: 5/Input/output error ``` The first userspace process #1 will also claim that the files were taken underneath their nose as well. The files are taken away form the first process given that when the second blktrace fails, it will follow up with a BLKTRACESTOP and BLKTRACETEARDOWN. This means that even if go-happy process #1 is waiting for blktrace data, we *have* been asked to take teardown the blktrace. This can easily be reproduced with break-blktrace [0] run_0005.sh test. Just break out early if we know we're already going to fail, this will prevent trying to create the files all over again, which we know still exist. [0] https://github.com/mcgrof/break-blktrace Signed-off-by: Luis Chamberlain Signed-off-by: Jan Kara Reviewed-by: Bart Van Assche Reviewed-by: Christoph Hellwig Signed-off-by: Jens Axboe Signed-off-by: Sasha Levin --- kernel/trace/blktrace.c | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/kernel/trace/blktrace.c b/kernel/trace/blktrace.c index 6737564680193..8ac3663e0012d 100644 --- a/kernel/trace/blktrace.c +++ b/kernel/trace/blktrace.c @@ -15,6 +15,9 @@ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA * */ + +#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt + #include #include #include @@ -481,6 +484,16 @@ int do_blk_trace_setup(struct request_queue *q, char *name, dev_t dev, */ strreplace(buts->name, '/', '_'); + /* + * bdev can be NULL, as with scsi-generic, this is a helpful as + * we can be. + */ + if (q->blk_trace) { + pr_warn("Concurrent blktraces are not allowed on %s\n", + buts->name); + return -EBUSY; + } + bt = kzalloc(sizeof(*bt), GFP_KERNEL); if (!bt) return -ENOMEM; -- 2.25.1