Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(7)

Side by Side Diff: base/power_monitor/power_monitor_mac.mm

Issue 10959020: SystemMonitor refactoring: move power state monitor into a separate class called PowerMonitor (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: add power notifier Created 8 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // Implementation based on sample code from 5 // Implementation based on sample code from
6 // http://developer.apple.com/library/mac/#qa/qa1340/_index.html. 6 // http://developer.apple.com/library/mac/#qa/qa1340/_index.html.
7 7
8 #include "base/system_monitor/system_monitor.h" 8 #include "base/power_monitor/power_monitor.h"
9 9
10 #include <IOKit/pwr_mgt/IOPMLib.h> 10 #include <IOKit/pwr_mgt/IOPMLib.h>
11 #include <IOKit/IOMessage.h> 11 #include <IOKit/IOMessage.h>
12 12
13 namespace base { 13 namespace base {
14 14
15 namespace { 15 namespace {
16 16
17 io_connect_t g_system_power_io_port = 0; 17 io_connect_t g_system_power_io_port = 0;
18 IONotificationPortRef g_notification_port_ref = 0; 18 IONotificationPortRef g_notification_port_ref = 0;
19 io_object_t g_notifier_object = 0; 19 io_object_t g_notifier_object = 0;
20 PowerMonitor::Notifier* g_power_notifier = NULL;
20 21
21 void SystemPowerEventCallback(void*, 22 void SystemPowerEventCallback(void*,
22 io_service_t service, 23 io_service_t service,
23 natural_t message_type, 24 natural_t message_type,
24 void* message_argument) { 25 void* message_argument) {
25 SystemMonitor* sys_monitor = SystemMonitor::Get(); 26 if (g_power_notifier == NULL)
26 DCHECK(sys_monitor); 27 g_power_notifier = PowerMonitor::GetInstance()->GetNotifierOnce();
vandebo (ex-Chrome) 2012/10/23 01:27:57 Set this in PlatformInit and assert that we get it
28
27 switch (message_type) { 29 switch (message_type) {
28 case kIOMessageSystemWillSleep: 30 case kIOMessageSystemWillSleep:
29 sys_monitor->ProcessPowerMessage(SystemMonitor::SUSPEND_EVENT); 31 if (g_power_notifier)
32 g_power_notifier->ProcessPowerEvent(base::PowerMonitor::SUSPEND_EVENT);
30 IOAllowPowerChange(g_system_power_io_port, 33 IOAllowPowerChange(g_system_power_io_port,
31 reinterpret_cast<intptr_t>(message_argument)); 34 reinterpret_cast<intptr_t>(message_argument));
32 break; 35 break;
33 36
34 case kIOMessageSystemWillPowerOn: 37 case kIOMessageSystemWillPowerOn:
35 sys_monitor->ProcessPowerMessage(SystemMonitor::RESUME_EVENT); 38 if (g_power_notifier)
39 g_power_notifier->ProcessPowerEvent(PowerMonitor::RESUME_EVENT);
36 break; 40 break;
37 } 41 }
38 } 42 }
39 43
40 } // namespace 44 } // namespace
41 45
42 // The reason we can't include this code in the constructor is because 46 // The reason we can't include this code in the constructor is because
43 // PlatformInit() requires an active runloop and the IO port needs to be 47 // PlatformInit() requires an active runloop and the IO port needs to be
44 // allocated at sandbox initialization time, before there's a runloop. 48 // allocated at sandbox initialization time, before there's a runloop.
45 // See crbug.com/83783 . 49 // See crbug.com/83783 .
46 50
47 // static 51 // static
48 void SystemMonitor::AllocateSystemIOPorts() { 52 void PowerMonitor::AllocateSystemIOPorts() {
49 DCHECK_EQ(g_system_power_io_port, 0u); 53 if (g_system_power_io_port != 0u)
Hongbo Min 2012/10/21 09:56:03 If I keep the original DCHECK_EQ stmt, lots of tes
vandebo (ex-Chrome) 2012/10/23 01:27:57 DCHECKs are used on the bots even in release mode.
54 return;
50 55
51 // Notification port allocated by IORegisterForSystemPower. 56 // Notification port allocated by IORegisterForSystemPower.
52 57
53 g_system_power_io_port = IORegisterForSystemPower( 58 g_system_power_io_port = IORegisterForSystemPower(
54 NULL, &g_notification_port_ref, SystemPowerEventCallback, 59 NULL, &g_notification_port_ref, SystemPowerEventCallback,
55 &g_notifier_object); 60 &g_notifier_object);
56 61
57 DCHECK_NE(g_system_power_io_port, 0u); 62 DCHECK_NE(g_system_power_io_port, 0u);
58 } 63 }
59 64
60 void SystemMonitor::PlatformInit() { 65 void PowerMonitor::PlatformInit() {
61 // Need to call AllocateSystemIOPorts() before constructing a SystemMonitor 66 // Need to call AllocateSystemIOPorts() before creating a PowerMonitor
62 // object. 67 // object.
63 DCHECK_NE(g_system_power_io_port, 0u); 68 CHECK_NE(g_system_power_io_port, 0u);
64 if (g_system_power_io_port == 0)
65 return;
66 69
67 // Add the notification port to the application runloop 70 // Add the notification port to the application runloop
68 CFRunLoopAddSource( 71 CFRunLoopAddSource(
69 CFRunLoopGetCurrent(), 72 CFRunLoopGetCurrent(),
70 IONotificationPortGetRunLoopSource(g_notification_port_ref), 73 IONotificationPortGetRunLoopSource(g_notification_port_ref),
71 kCFRunLoopCommonModes); 74 kCFRunLoopCommonModes);
72 } 75 }
73 76
74 void SystemMonitor::PlatformDestroy() { 77
75 DCHECK_NE(g_system_power_io_port, 0u); 78 void PowerMonitor::PlatformDestroy() {
76 if (g_system_power_io_port == 0) 79 CHECK_NE(g_system_power_io_port, 0u);
77 return;
78 80
79 // Remove the sleep notification port from the application runloop 81 // Remove the sleep notification port from the application runloop
80 CFRunLoopRemoveSource( 82 CFRunLoopRemoveSource(
81 CFRunLoopGetCurrent(), 83 CFRunLoopGetCurrent(),
82 IONotificationPortGetRunLoopSource(g_notification_port_ref), 84 IONotificationPortGetRunLoopSource(g_notification_port_ref),
83 kCFRunLoopCommonModes); 85 kCFRunLoopCommonModes);
84 86
85 // Deregister for system sleep notifications 87 // Deregister for system sleep notifications
86 IODeregisterForSystemPower(&g_notifier_object); 88 IODeregisterForSystemPower(&g_notifier_object);
87 89
88 // IORegisterForSystemPower implicitly opens the Root Power Domain IOService, 90 // IORegisterForSystemPower implicitly opens the Root Power Domain IOService,
89 // so we close it here. 91 // so we close it here.
90 IOServiceClose(g_system_power_io_port); 92 IOServiceClose(g_system_power_io_port);
91 93
92 g_system_power_io_port = 0; 94 g_system_power_io_port = 0;
93 95
94 // Destroy the notification port allocated by IORegisterForSystemPower. 96 // Destroy the notification port allocated by IORegisterForSystemPower.
95 IONotificationPortDestroy(g_notification_port_ref); 97 IONotificationPortDestroy(g_notification_port_ref);
96 } 98 }
97 99
98 } // namespace base 100 } // namespace base
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698