Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753039Ab3FEIxq (ORCPT ); Wed, 5 Jun 2013 04:53:46 -0400 Received: from mail-ob0-f178.google.com ([209.85.214.178]:55304 "EHLO mail-ob0-f178.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751949Ab3FEIxn convert rfc822-to-8bit (ORCPT ); Wed, 5 Jun 2013 04:53:43 -0400 MIME-Version: 1.0 In-Reply-To: <51AEFBA1.302@linux.vnet.ibm.com> References: <51AEFBA1.302@linux.vnet.ibm.com> Date: Wed, 5 Jun 2013 14:23:42 +0530 Message-ID: Subject: Re: [PATCH] cpufreq: prevent 'policy->cpus' become offline in __gov_queue_work() From: Viresh Kumar To: Michael Wang Cc: cpufreq@vger.kernel.org, linux-pm@vger.kernel.org, LKML , rjw@sisk.pl, Jiri Kosina , Borislav Petkov , Frederic Weisbecker , "tony.luck@intel.com" , Thomas Gleixner , x86@kernel.org, "paulmck@linux.vnet.ibm.com" 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 Content-Length: 3777 Lines: 62 On 5 June 2013 14:19, Michael Wang wrote: > > Jiri Kosina and Borislav Petkov > reported the warning: > > [ 51.616759] ------------[ cut here ]------------ > [ 51.621460] WARNING: at arch/x86/kernel/smp.c:123 native_smp_send_reschedule+0x58/0x60() > [ 51.629638] Modules linked in: ext2 vfat fat loop snd_hda_codec_hdmi usbhid snd_hda_codec_realtek coretemp kvm_intel kvm snd_hda_intel snd_hda_codec crc32_pclmul crc32c_intel ghash_clmulni_intel snd_hwdep snd_pcm aesni_intel sb_edac aes_x86_64 ehci_pci snd_page_alloc glue_helper snd_timer xhci_hcd snd iTCO_wdt iTCO_vendor_support ehci_hcd edac_core lpc_ich acpi_cpufreq lrw gf128mul ablk_helper cryptd mperf usbcore usb_common soundcore mfd_core dcdbas evdev pcspkr processor i2c_i801 button microcode > [ 51.675581] CPU: 0 PID: 244 Comm: kworker/1:1 Tainted: G W 3.10.0-rc1+ #10 > [ 51.683407] Hardware name: Dell Inc. Precision T3600/0PTTT9, BIOS A08 01/24/2013 > [ 51.690901] Workqueue: events od_dbs_timer > [ 51.695069] 0000000000000009 ffff88043a2f5b68 ffffffff8161441c ffff88043a2f5ba8 > [ 51.702602] ffffffff8103e540 0000000000000033 0000000000000001 ffff88043d5f8000 > [ 51.710136] 00000000ffff0ce1 0000000000000001 ffff88044fc4fc08 ffff88043a2f5bb8 > [ 51.717691] Call Trace: > [ 51.720191] [] dump_stack+0x19/0x1b > [ 51.725396] [] warn_slowpath_common+0x70/0xa0 > [ 51.731473] [] warn_slowpath_null+0x1a/0x20 > [ 51.737378] [] native_smp_send_reschedule+0x58/0x60 > [ 51.744013] [] wake_up_nohz_cpu+0x2d/0xa0 > [ 51.749745] [] add_timer_on+0x8f/0x110 > [ 51.755214] [] __queue_delayed_work+0x16e/0x1a0 > [ 51.761470] [] ? try_to_grab_pending+0xd1/0x1a0 > [ 51.767724] [] mod_delayed_work_on+0x5a/0xa0 > [ 51.773719] [] gov_queue_work+0x4d/0xc0 > [ 51.779271] [] od_dbs_timer+0xcb/0x170 > [ 51.784734] [] process_one_work+0x1fd/0x540 > [ 51.790634] [] ? process_one_work+0x192/0x540 > [ 51.796711] [] worker_thread+0x122/0x380 > [ 51.802350] [] ? rescuer_thread+0x320/0x320 > [ 51.808264] [] kthread+0xea/0xf0 > [ 51.813200] [] ? flush_kthread_worker+0x150/0x150 > [ 51.819644] [] ret_from_fork+0x7c/0xb0 > [ 51.918165] nouveau E[ DRM] GPU lockup - switching to software fbcon > [ 51.930505] [] ? flush_kthread_worker+0x150/0x150 > [ 51.936994] ---[ end trace f419538ada83b5c5 ]--- > > It was caused by the policy->cpus changed during the process of > __gov_queue_work(), in other word, cpu offline happened. > > This patch will use get/put_online_cpus() to prevent the offline > happen inside __gov_queue_work(), after applied the patch, the > warning is gone as Jiri tested: > > Link: https://lkml.org/lkml/2013/6/5/88 > > CC: "Rafael J. Wysocki" > CC: Viresh Kumar > Reported-by: Borislav Petkov > Reported-by: Jiri Kosina > Tested-by: Jiri Kosina > Signed-off-by: Michael Wang > --- > drivers/cpufreq/cpufreq_governor.c | 3 +++ > 1 files changed, 3 insertions(+), 0 deletions(-) Acked-by: Viresh Kumar -- 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/