Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp1102288ybg; Tue, 2 Jun 2020 01:08:50 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwp+zeZmDz2j11hsPtZ5liNAupea8Gw+uGMThZP0nzVD4XqBv2f5remFMK/ixMUHT00fGsb X-Received: by 2002:a50:f05d:: with SMTP id u29mr23388009edl.229.1591085330370; Tue, 02 Jun 2020 01:08:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1591085330; cv=none; d=google.com; s=arc-20160816; b=dT4PU6OMSQFvh/V7oMKvDiYIJcSZnEQSJaqtLXSkA5Z3F4Vm3CndlrlMYirUujUBHu OPM0raNELlsqr2VAMcaYPv7gSRobtAlawIksKXRymXPC7sYrzIJ4ZSUTchO3CjGPf3+l VvpFYPYsucOmc5jWIoCeP/5ZcN+6ResmdGzltCQrmncCzzQQ9hcoMI/hOn1VEqT8q+8B dZawJiixg7iAOUI2Nsm50q9Fg+96wSOPbL2lNJwFRtWXn/KDoyAHS7tBNEAaQu3UGYR8 W7hZRUTN1EpnVxlklPyInBGead5HeYd4W37jJVkHoJO9ZlBL+nlj1jdM8Pdkg95GU6zZ 0wqw== 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=xEXkwZKus6X9amvK6F1OP8kCpc4pO5A7sywsELNZrs8=; b=HAL/NMgxnAZifb82G+cnvSmOrBIpRfXRYFz2XCEOAEIZlCqSV1K1knlPFrRdzB1Gie Ni5frxdk5ZLFlYJIoDy4FP5s5GIxOcL1cV+xTKM2N+f53tbFjHcU33e/3veD+EuEYG76 puaBBchCVMG6nk1ySRmHSK8Js4lRfyNGfG4pcOsb5SNd5nHSYNbNb16fgpA8yRqCBDc+ vqpCfGDNVl1p2uOJKF/dlbafmHH2ctpjuB/jIZXt2eRW/ZXg5aDs+RHPTzxghw/KM2o+ uzxu8X0ySRVTehVDsVL8ASaObUZxy4QCKqAcLfTFqJVSSnI3kqG4At7iZjL/66FF0gE5 L7Xw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2020-01-29 header.b=mNQOTPGv; 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=oracle.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f23si1121459ejy.135.2020.06.02.01.08.26; Tue, 02 Jun 2020 01:08:50 -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=@oracle.com header.s=corp-2020-01-29 header.b=mNQOTPGv; 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=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726174AbgFBIE1 (ORCPT + 99 others); Tue, 2 Jun 2020 04:04:27 -0400 Received: from userp2120.oracle.com ([156.151.31.85]:45788 "EHLO userp2120.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725811AbgFBIE1 (ORCPT ); Tue, 2 Jun 2020 04:04:27 -0400 Received: from pps.filterd (userp2120.oracle.com [127.0.0.1]) by userp2120.oracle.com (8.16.0.42/8.16.0.42) with SMTP id 0527w72g103122; Tue, 2 Jun 2020 08:04:21 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oracle.com; h=subject : to : cc : references : from : message-id : date : mime-version : in-reply-to : content-type : content-transfer-encoding; s=corp-2020-01-29; bh=xEXkwZKus6X9amvK6F1OP8kCpc4pO5A7sywsELNZrs8=; b=mNQOTPGvnR1L3n9B+FwJpWcF6QRbkCA6A8OKhPY49lLFUsK9qPhpn6TjoOe3AmhIa4K8 iqtDeEGRbHDpzIJTtRFNB/vUPDEUCizuQlAa7YesNlmLitTDy8sUcEFJvCyhyoVHgJaX 23iouTWjrp8/j/BAY8OIiWI4Tk1N5lzqXcgOsyVelsGQ0N6HoSWa1EPz2P51DriChCEJ RIk8gfKmVnKilf+mRX3TM/xvcHUtTENDaN+MdTfTWp5fs449h99Pj27R0o8N3roS+nVK WJXrFkkchkzpL1gSG7Lya0mUN2Im8acX73bA0R4Ychpbi5HF6swDJXcexwLFJ1euIkvT hg== Received: from aserp3020.oracle.com (aserp3020.oracle.com [141.146.126.70]) by userp2120.oracle.com with ESMTP id 31djtv011e-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=FAIL); Tue, 02 Jun 2020 08:04:21 +0000 Received: from pps.filterd (aserp3020.oracle.com [127.0.0.1]) by aserp3020.oracle.com (8.16.0.42/8.16.0.42) with SMTP id 0527vsDH126055; Tue, 2 Jun 2020 08:02:20 GMT Received: from aserv0122.oracle.com (aserv0122.oracle.com [141.146.126.236]) by aserp3020.oracle.com with ESMTP id 31c25n51rj-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Tue, 02 Jun 2020 08:02:20 +0000 Received: from abhmp0009.oracle.com (abhmp0009.oracle.com [141.146.116.15]) by aserv0122.oracle.com (8.14.4/8.14.4) with ESMTP id 05282Jir015345; Tue, 2 Jun 2020 08:02:19 GMT Received: from [192.168.0.110] (/183.246.144.78) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Tue, 02 Jun 2020 01:02:19 -0700 Subject: Re: [PATCH 1/1] blk-mq: get ctx in order to handle BLK_MQ_S_INACTIVE in blk_mq_get_tag() To: Dongli Zhang , linux-block@vger.kernel.org Cc: axboe@kernel.dk, hare@suse.de, dwagner@suse.de, ming.lei@redhat.com, linux-kernel@vger.kernel.org References: <20200602061749.32029-1-dongli.zhang@oracle.com> From: Bob Liu Message-ID: Date: Tue, 2 Jun 2020 16:01:43 +0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.4.1 MIME-Version: 1.0 In-Reply-To: <20200602061749.32029-1-dongli.zhang@oracle.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit X-Proofpoint-Virus-Version: vendor=nai engine=6000 definitions=9639 signatures=668686 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 adultscore=0 suspectscore=0 spamscore=0 malwarescore=0 bulkscore=0 mlxscore=0 phishscore=0 mlxlogscore=999 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2004280000 definitions=main-2006020051 X-Proofpoint-Virus-Version: vendor=nai engine=6000 definitions=9639 signatures=668686 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 cotscore=-2147483648 adultscore=0 priorityscore=1501 phishscore=0 mlxlogscore=999 suspectscore=0 spamscore=0 clxscore=1011 lowpriorityscore=0 mlxscore=0 bulkscore=0 malwarescore=0 impostorscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2004280000 definitions=main-2006020051 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 6/2/20 2:17 PM, Dongli Zhang wrote: > When scheduler is set, we hit below page fault when we offline cpu. > > [ 1061.007725] BUG: kernel NULL pointer dereference, address: 0000000000000040 > [ 1061.008710] #PF: supervisor read access in kernel mode > [ 1061.009492] #PF: error_code(0x0000) - not-present page > [ 1061.010241] PGD 0 P4D 0 > [ 1061.010614] Oops: 0000 [#1] SMP PTI > [ 1061.011130] CPU: 0 PID: 122 Comm: kworker/0:1H Not tainted 5.7.0-rc7+ #2' > ... ... > [ 1061.013760] Workqueue: kblockd blk_mq_run_work_fn > [ 1061.014446] RIP: 0010:blk_mq_put_tag+0xf/0x30 > ... ... > [ 1061.017726] RSP: 0018:ffffa5c18037fc70 EFLAGS: 00010287 > [ 1061.018475] RAX: 0000000000000000 RBX: ffffa5c18037fcf0 RCX: 0000000000000004 > [ 1061.019507] RDX: 0000000000000000 RSI: 0000000000000000 RDI: ffff911535dc1180 > ... ... > [ 1061.028454] Call Trace: > [ 1061.029307] blk_mq_get_tag+0x26e/0x280 > [ 1061.029866] ? wait_woken+0x80/0x80 > [ 1061.030378] blk_mq_get_driver_tag+0x99/0x110 > [ 1061.031009] blk_mq_dispatch_rq_list+0x107/0x5e0 > [ 1061.031672] ? elv_rb_del+0x1a/0x30 > [ 1061.032178] blk_mq_do_dispatch_sched+0xe2/0x130 > [ 1061.032844] __blk_mq_sched_dispatch_requests+0xcc/0x150 > [ 1061.033638] blk_mq_sched_dispatch_requests+0x2b/0x50 > [ 1061.034239] __blk_mq_run_hw_queue+0x75/0x110 > [ 1061.034867] process_one_work+0x15c/0x370 > [ 1061.035450] worker_thread+0x44/0x3d0 > [ 1061.035980] kthread+0xf3/0x130 > [ 1061.036440] ? max_active_store+0x80/0x80 > [ 1061.037018] ? kthread_bind+0x10/0x10 > [ 1061.037554] ret_from_fork+0x35/0x40 > [ 1061.038073] Modules linked in: > [ 1061.038543] CR2: 0000000000000040 > [ 1061.038962] ---[ end trace d20e1df7d028e69f ]--- > > This is because blk_mq_get_driver_tag() would be used to allocate tag once > scheduler (e.g., mq-deadline) is set. However, in order to handle > BLK_MQ_S_INACTIVE in blk_mq_get_tag(), we need to set data->ctx for > blk_mq_put_tag(). > > Fixes: bf0beec0607db3c6 ("blk-mq: drain I/O when all CPUs in a hctx are offline") > Signed-off-by: Dongli Zhang > --- > This is based on for-next because currently the pull request for v5.8 is > not picked by mainline. > > block/blk-mq.c | 1 + > 1 file changed, 1 insertion(+) > > diff --git a/block/blk-mq.c b/block/blk-mq.c > index 9a36ac1c1fa1..8bf6c06a86c1 100644 > --- a/block/blk-mq.c > +++ b/block/blk-mq.c > @@ -1056,6 +1056,7 @@ bool blk_mq_get_driver_tag(struct request *rq) > { > struct blk_mq_alloc_data data = { > .q = rq->q, > + .ctx = rq->mq_ctx, > .hctx = rq->mq_hctx, > .flags = BLK_MQ_REQ_NOWAIT, > .cmd_flags = rq->cmd_flags, > Nice catch! Reviewed-by: Bob Liu