Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752050AbaG1Vyq (ORCPT ); Mon, 28 Jul 2014 17:54:46 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:49379 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751509AbaG1Vyo (ORCPT ); Mon, 28 Jul 2014 17:54:44 -0400 Date: Mon, 28 Jul 2014 14:54:43 -0700 From: Andrew Morton To: Christoph Lameter Cc: Sasha Levin , Gilad Ben-Yossef , Thomas Gleixner , Tejun Heo , John Stultz , Mike Frysinger , Minchan Kim , Hakan Akkan , Max Krasnyansky , Frederic Weisbecker , "Paul E. McKenney" , linux-kernel@vger.kernel.org, linux-mm@kvack.org, hughd@google.com, viresh.kumar@linaro.org, hpa@zytor.com, mingo@kernel.org, peterz@infradead.org Subject: Re: vmstat: On demand vmstat workers V8 Message-Id: <20140728145443.dce6fe72aed1bbdcf95b21f6@linux-foundation.org> In-Reply-To: References: <53D31101.8000107@oracle.com> X-Mailer: Sylpheed 3.2.0beta5 (GTK+ 2.24.10; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 28 Jul 2014 13:55:17 -0500 (CDT) Christoph Lameter wrote: > On Fri, 25 Jul 2014, Sasha Levin wrote: > > > This patch doesn't interact well with my fuzzing setup. I'm seeing > > the following: > > > > [ 490.446927] BUG: using __this_cpu_read() in preemptible [00000000] code: kworker/16:1/7368 > > [ 490.447909] caller is __this_cpu_preempt_check+0x13/0x20 > > __this_cpu_read() from vmstat_update is only called from a kworker that > is bound to a single cpu. A false positive? schedule_delayed_work() uses system_wq. The comment in workqueue.h says * system_wq is the one used by schedule[_delayed]_work[_on](). * Multi-CPU multi-threaded. There are users which expect relatively * short queue flush time. Don't queue works which can run for too * long. but the code itself does system_wq = alloc_workqueue("events", 0, 0); ie: it didn't pass WQ_UNBOUND in the flags. Tejun, wazzup? Also, Sasha's report showed this: [ 490.464613] kernel BUG at mm/vmstat.c:1278! That's your VM_BUG_ON() in vmstat_update(). That ain't no false positive! Is this code expecting that schedule_delayed_work() will schedule the work on the current CPU? I don't think it will do that. Maybe you should be looking at schedule_delayed_work_on(). -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/