Received: by 10.192.165.156 with SMTP id m28csp287773imm; Tue, 17 Apr 2018 10:07:39 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/syna1QlBvuDa/fyMibRtN0JwUHGQu9t/o/M82Yc6Gr3hDVA4j/ojeMYKhF2oF2SaFm0Vh X-Received: by 2002:a17:902:b112:: with SMTP id q18-v6mr2349777plr.371.1523984859654; Tue, 17 Apr 2018 10:07:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1523984859; cv=none; d=google.com; s=arc-20160816; b=Ck+nVUGAmcTBF4lcouNF5QCz+G22GXO1B9Ke31LItHauurtKuc1NspjRhakdJowP+H nHBqM4Km/ueCMh3J+hSotip/BM+NjvMLi4n+1L1wNfkkY/qk1gz6eGTwZwyF3C8mpzji bL9+rqgEDDtJDJ5uQEuMWkkG4/YB+DBCpNVWS2XcG1rWP5KFModBMUzU0X/2iD1ZNc6y ZhZRuDXsT7H3b8YZpjf+E0DNDYAJec3jlrGDOSO+dyCuQ0EmM6aXz/tRtwBD42sKi6hp ukLkJ8/YbY6N6ZDG7+Y42UtRHGHtPmBDJZz6GOHRiJmrBwS9uHfJe7v/48gSksdK3jfV +fFg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :in-reply-to:message-id:date:subject:cc:to:from :arc-authentication-results; bh=MW4vZO8wR6+Mv5tIcADUAw/AYq22Kc5qo+ardkF+64U=; b=pvl5W2cSVTS00lAA8Z5WS+odfBj8O3RsAXy1srJ4lQMKgsbkOlB/jIcFva2iANkIxu 0Q8zFcjYi7kzrMkh8JiQ0BU7BPGlCfVhScRJ3Fhv7E877K+GUT0ZnTq6vvTSHWwF9es5 q75W8zhFI+dqOuxX7qXHy7u0N9B2bwU2c9CnYAmO61/ORjfdjzhMVgeOEDm4mvbpeXjs PAUwX0kVMvgxMKPWQnxNAfDsR5aBFLjeN5Qd6W0qLAdZSRgIyn4kmn0j1YfIxy0ZA4gO ZaP2aXmitmQ7/p4rz9ldpiF2/zwNy6XvNcyvg3qSd9iSfFZ6RJGOOc/lR/JDaj9gKoVS g2uA== ARC-Authentication-Results: i=1; mx.google.com; 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 a63si13392513pfc.131.2018.04.17.10.07.23; Tue, 17 Apr 2018 10:07:39 -0700 (PDT) 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; 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 S1753628AbeDQQBS (ORCPT + 99 others); Tue, 17 Apr 2018 12:01:18 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:60364 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753595AbeDQQBP (ORCPT ); Tue, 17 Apr 2018 12:01:15 -0400 Received: from localhost (unknown [46.44.180.42]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 1F2D6DF7; Tue, 17 Apr 2018 16:01:14 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Tejun Heo , Bart Van Assche , Hannes Reinecke , Ming Lei , Christoph Hellwig , Johannes Thumshirn , Oleksandr Natalenko , Martin Steigerwald , Jens Axboe Subject: [PATCH 4.16 36/68] block: Change a rcu_read_{lock,unlock}_sched() pair into rcu_read_{lock,unlock}() Date: Tue, 17 Apr 2018 17:57:49 +0200 Message-Id: <20180417155750.802123392@linuxfoundation.org> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180417155749.341779147@linuxfoundation.org> References: <20180417155749.341779147@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.16-stable review patch. If anyone has any objections, please let me know. ------------------ From: Bart Van Assche commit 818e0fa293ca836eba515615c64680ea916fd7cd upstream. scsi_device_quiesce() uses synchronize_rcu() to guarantee that the effect of blk_set_preempt_only() will be visible for percpu_ref_tryget() calls that occur after the queue unfreeze by using the approach explained in https://lwn.net/Articles/573497/. The rcu read lock and unlock calls in blk_queue_enter() form a pair with the synchronize_rcu() call in scsi_device_quiesce(). Both scsi_device_quiesce() and blk_queue_enter() must either use regular RCU or RCU-sched. Since neither the RCU-protected code in blk_queue_enter() nor blk_queue_usage_counter_release() sleeps, regular RCU protection is sufficient. Note: scsi_device_quiesce() does not have to be modified since it already uses synchronize_rcu(). Reported-by: Tejun Heo Fixes: 3a0a529971ec ("block, scsi: Make SCSI quiesce and resume work reliably") Signed-off-by: Bart Van Assche Acked-by: Tejun Heo Cc: Tejun Heo Cc: Hannes Reinecke Cc: Ming Lei Cc: Christoph Hellwig Cc: Johannes Thumshirn Cc: Oleksandr Natalenko Cc: Martin Steigerwald Cc: stable@vger.kernel.org # v4.15 Signed-off-by: Jens Axboe Signed-off-by: Greg Kroah-Hartman --- block/blk-core.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) --- a/block/blk-core.c +++ b/block/blk-core.c @@ -827,7 +827,7 @@ int blk_queue_enter(struct request_queue bool success = false; int ret; - rcu_read_lock_sched(); + rcu_read_lock(); if (percpu_ref_tryget_live(&q->q_usage_counter)) { /* * The code that sets the PREEMPT_ONLY flag is @@ -840,7 +840,7 @@ int blk_queue_enter(struct request_queue percpu_ref_put(&q->q_usage_counter); } } - rcu_read_unlock_sched(); + rcu_read_unlock(); if (success) return 0;