From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1760918Ab1F1TAO (ORCPT ); Tue, 28 Jun 2011 15:00:14 -0400 Received: from 0122700014.0.fullrate.dk ([95.166.99.235]:44364 "EHLO kernel.dk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1760785Ab1F1S7I (ORCPT ); Tue, 28 Jun 2011 14:59:08 -0400 Message-ID: <4E0A2479.4060809@kernel.dk> Date: Tue, 28 Jun 2011 20:59:05 +0200 From: Jens Axboe MIME-Version: 1.0 To: Sergey Senozhatsky CC: linux-kernel@vger.kernel.org Subject: Re: [PATCH] cfq: Suspicious rcu_dereference_check() usage at __cfq_exit_single_io_context() References: <20110628111853.GA3189@swordfish.minsk.epam.com> In-Reply-To: <20110628111853.GA3189@swordfish.minsk.epam.com> Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2011-06-28 13:18, Sergey Senozhatsky wrote: > Protect __cfq_exit_single_io_context() call with rcu_read_lock(), since it > modifies RCU pointer ioc->ioc_data. > > [ 1349.369446] rcu_scheduler_active = 1, debug_locks = 0 > [ 1349.369451] 3 locks held by scsi_scan_4/5203: > [ 1349.369454] #0: (&shost->scan_mutex){+.+.+.}, at: [] scsi_scan_host_selected+0xba/0x18c > [ 1349.369473] #1: (&eq->sysfs_lock){+.+...}, at: [] elevator_exit+0x18/0x49 > [ 1349.369489] #2: (&(&q->__queue_lock)->rlock){-.-...}, at: [] cfq_exit_queue+0x42/0x171 > [ 1349.369503] > [ 1349.369504] stack backtrace: > [ 1349.369510] Pid: 5203, comm: scsi_scan_4 Not tainted 3.0.0-rc5-dbg-00479-gbe4a634 #629 > [ 1349.369515] Call Trace: > [ 1349.369526] [] lockdep_rcu_dereference+0xa7/0xaf > [ 1349.369534] [] __cfq_exit_single_io_context+0x85/0xe1 > [ 1349.369541] [] cfq_exit_queue+0x66/0x171 > [ 1349.369548] [] elevator_exit+0x2c/0x49 > [ 1349.369556] [] blk_cleanup_queue+0x4a/0x63 > [ 1349.369563] [] scsi_free_queue+0x9/0xb > [ 1349.369571] [] __scsi_remove_device+0xa7/0xb4 > [ 1349.369577] [] scsi_probe_and_add_lun+0xa78/0xab5 > [ 1349.369586] [] __scsi_scan_target+0x5d3/0x625 > [ 1349.369594] [] ? __pm_runtime_resume+0x2f/0x59 > [ 1349.369603] [] ? mark_held_locks+0x4b/0x6d > [ 1349.369613] [] ? _raw_spin_unlock_irqrestore+0x42/0x74 > [ 1349.369622] [] ? get_parent_ip+0xf/0x40 > [ 1349.369630] [] ? sub_preempt_count+0x8f/0xa3 > [ 1349.369637] [] scsi_scan_channel.part.8+0x52/0x6d > [ 1349.369645] [] scsi_scan_host_selected+0x104/0x18c > [ 1349.369652] [] ? do_scsi_scan_host+0x70/0x70 > [ 1349.369658] [] do_scsi_scan_host+0x6b/0x70 > [ 1349.369665] [] do_scan_async+0x1d/0x15d > [ 1349.369671] [] ? do_scsi_scan_host+0x70/0x70 > [ 1349.369680] [] kthread+0x9a/0xa2 > [ 1349.369689] [] kernel_thread_helper+0x4/0x10 > [ 1349.369696] [] ? finish_task_switch+0x76/0xf0 > [ 1349.369703] [] ? retint_restore_args+0x13/0x13 > [ 1349.369710] [] ? __init_kthread_worker+0x53/0x53 > [ 1349.369717] [] ? gs_change+0x13/0x13 Thanks, I already have a patch queued up to fix this. -- Jens Axboe