Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp4323238imu; Mon, 14 Jan 2019 20:30:53 -0800 (PST) X-Google-Smtp-Source: ALg8bN61VhItRASot2aRN4trhArxdYbSx/wQrmurWGwhIzoBmHPopQH9AWWGnUEyHwgZh9VyIJf5 X-Received: by 2002:a62:520b:: with SMTP id g11mr2037074pfb.53.1547526653073; Mon, 14 Jan 2019 20:30:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1547526653; cv=none; d=google.com; s=arc-20160816; b=hEaHgCYthhHnr/dTTKGiSzzR/WRcUTISUQZyuUd58miz+ggVlAdAsxPm5CYh73MQcZ QeHX/Udzx7Sep6nE6h/PIUL3qVsCu1/WHpno+w2mdw4VneIMvMtSsNgSW2J0Ofk/Cgb+ 1ZMlGqpWILIkcDXY/EndMTCOtKNJ7CqHbhh0ZXJHUYW+0Jhr+A7YvsNP7HKWnZMFXy5F OMHdgjVuI0DYyBEO3yHz8n2s8K8hfCKnOkZFAvf/2O0OaxjWIcCKCy0IeJhv1CU+6Hmi tQOriSJsLsUj4sFSeVkO0bbTAKvDfyxmtSBBNOx4ztRGAwYU35pJ/FWpd60IZ+abYh2U m5cQ== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=2tN2sGcytVFY0+Ywgd3h3jYjcEeH9XS+csfG72SxBlE=; b=h3qQrONB/xhu9SJUYXP52nPRwC+yxjok4dUezBf4mZGz7zPwmnLIGDaKFlTNBIkjxb cLbacvlnTSIbV+lf2vTiTLXijTxbBuc7K7gVv2+RRRW55FWVfLXpyLubcndeM4adxaZY g2v0zn8PYv4CKS3WzWvFUivqAGnJcc5oEuSnVSGx57xGOFD+IIRca/RwfDWmcHdCgWHj Fp/ex1+vGiWHmHsHB3RHwLfCDmTVYb1MWuXE42I+qaDyEWcOQWRq+wZpev9gg1q1ZQu8 9HpvbEvmRFF6Qzr5ScPftXnF5ecGZkYaKLl2UgtraBq8mTE14xk/QaSNvrhddMjj3v88 ESCA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel-dk.20150623.gappssmtp.com header.s=20150623 header.b=1hnhTsOE; 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 r14si2341221pgk.75.2019.01.14.20.30.37; Mon, 14 Jan 2019 20:30:53 -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-dk.20150623.gappssmtp.com header.s=20150623 header.b=1hnhTsOE; 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 S1727461AbfAOE2i (ORCPT + 99 others); Mon, 14 Jan 2019 23:28:38 -0500 Received: from mail-pl1-f196.google.com ([209.85.214.196]:35289 "EHLO mail-pl1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727235AbfAOE2i (ORCPT ); Mon, 14 Jan 2019 23:28:38 -0500 Received: by mail-pl1-f196.google.com with SMTP id p8so685612plo.2 for ; Mon, 14 Jan 2019 20:28:37 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=kernel-dk.20150623.gappssmtp.com; s=20150623; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=2tN2sGcytVFY0+Ywgd3h3jYjcEeH9XS+csfG72SxBlE=; b=1hnhTsOEZiVMzvTpyXFrvUON6TXbKq+0+V8oZseLIoe4LOCylFDfiWv/Mzm+XQ75py CqhAKa6tnKZf6prEdBzYkvBuVoaTqtobyrTk+ZwWvBeCrroUJafEmDzG666viGVcH5Tb CPJ7D2OVbXlvk9WsUJQYYIp+NY+C54YGpHey9nzRKJyUOE5NuC/wv1E65Jis2yxtprkn wN3gcxM70/yKt7cUYFFH8UdB+Y0NZW84IQVRPIdkyXa+5mWTlRI5J9mcaZnkCo1ejpYD HfzBHNYJ7B0TlYYJkw1jZdkmXxgtFCUDi/HQZtVA8EivLY35k10fj+kq1zPb0wib1UE1 Zdag== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=2tN2sGcytVFY0+Ywgd3h3jYjcEeH9XS+csfG72SxBlE=; b=q8IIyH2QUI0dCq2E/gwOe00TslxpbeUy7UJ3r4g9uAqijqbFjMmGy+ZBcRpYfUdPw+ hkpGIcBlJyVNvgFRnW5atOMLa0IWW+XjZ4qrp5avQ2yic97hAvr/2YTuJlyZ4CZOwpOu 7ttdKzVghP93VXvrxYt/GYXFP3HS1YaqIA7PNbBFVINCxLicwjxtzpkGidLzc6HOVI9J 5b1qGfYeqIqwANlKRJKcLk4oZs9dQXD+U/RheE7hqKaSYkv9x/huVanB9tomVl6GRWki lDxnJXz170srclGXFO7rUnxbzy2EB8CzK4Kvq2S+8+0jsebRRqgrsNnO0ZQcD14ZEeNI LHNg== X-Gm-Message-State: AJcUukdydSuOXrdOlahPUhxuHUmDM7/gRP2oYV1gQyhAwojR7XneWn3R TdEo2Meut/TLi8bGSQe59w0d7ncbEOZFhg== X-Received: by 2002:a17:902:8d95:: with SMTP id v21mr2124047plo.162.1547526517063; Mon, 14 Jan 2019 20:28:37 -0800 (PST) Received: from [192.168.1.121] (66.29.188.166.static.utbb.net. [66.29.188.166]) by smtp.gmail.com with ESMTPSA id v184sm2256197pfb.182.2019.01.14.20.28.34 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 14 Jan 2019 20:28:35 -0800 (PST) Subject: Re: [PATCH] sbitmap: Protect swap_lock from hardirq To: Ming Lei Cc: linux-block@vger.kernel.org, Clark Williams , Guenter Roeck , Steven Rostedt , Linus Torvalds , linux-kernel@vger.kernel.org References: <20190115035952.13325-1-ming.lei@redhat.com> From: Jens Axboe Message-ID: Date: Mon, 14 Jan 2019 21:28:33 -0700 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.2.1 MIME-Version: 1.0 In-Reply-To: <20190115035952.13325-1-ming.lei@redhat.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 1/14/19 8:59 PM, Ming Lei wrote: > The original report is actually one real deadlock: > > [ 106.132865] Possible interrupt unsafe locking scenario: > [ 106.132865] > [ 106.133659] CPU0 CPU1 > [ 106.134194] ---- ---- > [ 106.134733] lock(&(&sb->map[i].swap_lock)->rlock); > [ 106.135318] local_irq_disable(); > [ 106.136014] lock(&sbq->ws[i].wait); > [ 106.136747] lock(&(&hctx->dispatch_wait_lock)->rlock); > [ 106.137742] > [ 106.138110] lock(&sbq->ws[i].wait); > > Because we may call blk_mq_get_driver_tag() directly from > blk_mq_dispatch_rq_list() without holding any lock, then HARDIRQ may come > and the above DEADLOCK is triggered. > > ab53dcfb3e7b ("sbitmap: Protect swap_lock from hardirq") tries to fix > this issue by using 'spin_lock_bh', which isn't enough because we complete > request from hardirq context direclty in case of multiqueue. Thanks Ming, I'll queue this up for shipping this week. -- Jens Axboe