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

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: Call AllocateSystemIOPorts before PowerMonitor's ctor 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 // A helper function as a friend function of PowerMonitor.
16 void ProcessPowerEventHelper(PowerMonitor::PowerEvent power_event) {
17 PowerMonitor* power_monitor = PowerMonitor::GetInstance();
18 power_monitor->ProcessPowerEvent(power_event);
19 }
20
15 namespace { 21 namespace {
16 22
17 io_connect_t g_system_power_io_port = 0; 23 io_connect_t g_system_power_io_port = 0;
18 IONotificationPortRef g_notification_port_ref = 0; 24 IONotificationPortRef g_notification_port_ref = 0;
19 io_object_t g_notifier_object = 0; 25 io_object_t g_notifier_object = 0;
20 26
21 void SystemPowerEventCallback(void*, 27 void SystemPowerEventCallback(void*,
22 io_service_t service, 28 io_service_t service,
23 natural_t message_type, 29 natural_t message_type,
24 void* message_argument) { 30 void* message_argument) {
25 SystemMonitor* sys_monitor = SystemMonitor::Get();
26 DCHECK(sys_monitor);
27 switch (message_type) { 31 switch (message_type) {
28 case kIOMessageSystemWillSleep: 32 case kIOMessageSystemWillSleep:
29 sys_monitor->ProcessPowerMessage(SystemMonitor::SUSPEND_EVENT); 33 ProcessPowerEventHelper(PowerMonitor::SUSPEND_EVENT);
30 IOAllowPowerChange(g_system_power_io_port, 34 IOAllowPowerChange(g_system_power_io_port,
31 reinterpret_cast<intptr_t>(message_argument)); 35 reinterpret_cast<intptr_t>(message_argument));
32 break; 36 break;
33 37
34 case kIOMessageSystemWillPowerOn: 38 case kIOMessageSystemWillPowerOn:
35 sys_monitor->ProcessPowerMessage(SystemMonitor::RESUME_EVENT); 39 ProcessPowerEventHelper(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/16 14:14:40 base/power_monitor/power_monitor_mac.mm:53: if (g_
vandebo (ex-Chrome) 2012/10/16 18:50:16 Hmm, this is a consequence of changing it to a Sin
willchan no longer on Chromium 2012/10/16 20:32:37 I'm confused. Why is this better than before? Let
vandebo (ex-Chrome) 2012/10/16 23:55:09 Maybe this and the other issue is why it wasn't a
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