Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755465AbcCRV0R (ORCPT ); Fri, 18 Mar 2016 17:26:17 -0400 Received: from www.linutronix.de ([62.245.132.108]:38614 "EHLO Galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751059AbcCRV0O (ORCPT ); Fri, 18 Mar 2016 17:26:14 -0400 From: Richard Cochran To: Cc: , Robert Richter , oprofile-list@lists.sf.net Subject: [PATCH 4/5] oprofile: nmi-timer: Handle the FROZEN hot plug notifier actions. Date: Fri, 18 Mar 2016 22:26:10 +0100 Message-Id: <1458336371-17748-4-git-send-email-rcochran@linutronix.de> X-Mailer: git-send-email 1.7.10.4 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1274 Lines: 35 When performing a suspend operation, the kernel brings all of the non-boot CPUs offline, calling the hot plug notifiers with the flag, CPU_TASKS_FROZEN, set in the action code. Similarly, during resume, the CPUs are brought back online, but again the notifiers have the FROZEN flag set. While some very few drivers really need to treat suspend/resume specially, this driver unintentionally ignores the notifications. This patch changes the driver to react to the FROZEN hot plug events. As a result, the NMI timer is no longer left running during the suspended state. Cc: Robert Richter Cc: oprofile-list@lists.sf.net Signed-off-by: Richard Cochran --- drivers/oprofile/nmi_timer_int.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/oprofile/nmi_timer_int.c b/drivers/oprofile/nmi_timer_int.c index 9559829..37ae173 100644 --- a/drivers/oprofile/nmi_timer_int.c +++ b/drivers/oprofile/nmi_timer_int.c @@ -63,7 +63,7 @@ static int nmi_timer_cpu_notifier(struct notifier_block *b, unsigned long action void *data) { int cpu = (unsigned long)data; - switch (action) { + switch (action & ~CPU_TASKS_FROZEN) { case CPU_DOWN_FAILED: case CPU_ONLINE: nmi_timer_start_cpu(cpu); -- 2.1.4