xref: /xnu-10002.81.5/iokit/Kernel/IOPMPowerSource.cpp (revision 5e3eaea39dcf651e66cb99ba7d70e32cc4a99587)
1*5e3eaea3SApple OSS Distributions /*
2*5e3eaea3SApple OSS Distributions  * Copyright (c) 1998-2005 Apple Computer, Inc. All rights reserved.
3*5e3eaea3SApple OSS Distributions  *
4*5e3eaea3SApple OSS Distributions  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
5*5e3eaea3SApple OSS Distributions  *
6*5e3eaea3SApple OSS Distributions  * This file contains Original Code and/or Modifications of Original Code
7*5e3eaea3SApple OSS Distributions  * as defined in and that are subject to the Apple Public Source License
8*5e3eaea3SApple OSS Distributions  * Version 2.0 (the 'License'). You may not use this file except in
9*5e3eaea3SApple OSS Distributions  * compliance with the License. The rights granted to you under the License
10*5e3eaea3SApple OSS Distributions  * may not be used to create, or enable the creation or redistribution of,
11*5e3eaea3SApple OSS Distributions  * unlawful or unlicensed copies of an Apple operating system, or to
12*5e3eaea3SApple OSS Distributions  * circumvent, violate, or enable the circumvention or violation of, any
13*5e3eaea3SApple OSS Distributions  * terms of an Apple operating system software license agreement.
14*5e3eaea3SApple OSS Distributions  *
15*5e3eaea3SApple OSS Distributions  * Please obtain a copy of the License at
16*5e3eaea3SApple OSS Distributions  * http://www.opensource.apple.com/apsl/ and read it before using this file.
17*5e3eaea3SApple OSS Distributions  *
18*5e3eaea3SApple OSS Distributions  * The Original Code and all software distributed under the License are
19*5e3eaea3SApple OSS Distributions  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
20*5e3eaea3SApple OSS Distributions  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21*5e3eaea3SApple OSS Distributions  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
22*5e3eaea3SApple OSS Distributions  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23*5e3eaea3SApple OSS Distributions  * Please see the License for the specific language governing rights and
24*5e3eaea3SApple OSS Distributions  * limitations under the License.
25*5e3eaea3SApple OSS Distributions  *
26*5e3eaea3SApple OSS Distributions  * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
27*5e3eaea3SApple OSS Distributions  */
28*5e3eaea3SApple OSS Distributions 
29*5e3eaea3SApple OSS Distributions #include <IOKit/pwr_mgt/IOPMPowerSource.h>
30*5e3eaea3SApple OSS Distributions #include <IOKit/pwr_mgt/IOPM.h>
31*5e3eaea3SApple OSS Distributions #include <IOKit/IOMessage.h>
32*5e3eaea3SApple OSS Distributions #include <IOKit/IOLib.h>
33*5e3eaea3SApple OSS Distributions #include <os/log.h>
34*5e3eaea3SApple OSS Distributions 
35*5e3eaea3SApple OSS Distributions #define super IOService
36*5e3eaea3SApple OSS Distributions 
OSDefineMetaClassAndStructors(IOPMPowerSource,IOService)37*5e3eaea3SApple OSS Distributions OSDefineMetaClassAndStructors(IOPMPowerSource, IOService)
38*5e3eaea3SApple OSS Distributions 
39*5e3eaea3SApple OSS Distributions // *****************************************************************************
40*5e3eaea3SApple OSS Distributions // powerSource
41*5e3eaea3SApple OSS Distributions //
42*5e3eaea3SApple OSS Distributions // Static initializer for IOPMPowerSource. Returns a new instance of the class
43*5e3eaea3SApple OSS Distributions // which the caller must attach to the power plane.
44*5e3eaea3SApple OSS Distributions // *****************************************************************************
45*5e3eaea3SApple OSS Distributions 
46*5e3eaea3SApple OSS Distributions IOPMPowerSource *IOPMPowerSource::powerSource(void)
47*5e3eaea3SApple OSS Distributions {
48*5e3eaea3SApple OSS Distributions 	IOPMPowerSource *ps = new IOPMPowerSource;
49*5e3eaea3SApple OSS Distributions 
50*5e3eaea3SApple OSS Distributions 	if (ps) {
51*5e3eaea3SApple OSS Distributions 		ps->init();
52*5e3eaea3SApple OSS Distributions 		return ps;
53*5e3eaea3SApple OSS Distributions 	}
54*5e3eaea3SApple OSS Distributions 	return NULL;
55*5e3eaea3SApple OSS Distributions }
56*5e3eaea3SApple OSS Distributions 
57*5e3eaea3SApple OSS Distributions // *****************************************************************************
58*5e3eaea3SApple OSS Distributions // init
59*5e3eaea3SApple OSS Distributions //
60*5e3eaea3SApple OSS Distributions // *****************************************************************************
61*5e3eaea3SApple OSS Distributions bool
init(void)62*5e3eaea3SApple OSS Distributions IOPMPowerSource::init(void)
63*5e3eaea3SApple OSS Distributions {
64*5e3eaea3SApple OSS Distributions 	if (!super::init()) {
65*5e3eaea3SApple OSS Distributions 		return false;
66*5e3eaea3SApple OSS Distributions 	}
67*5e3eaea3SApple OSS Distributions 
68*5e3eaea3SApple OSS Distributions 	nextInList = NULL;
69*5e3eaea3SApple OSS Distributions 
70*5e3eaea3SApple OSS Distributions 	properties = OSDictionary::withCapacity(10);
71*5e3eaea3SApple OSS Distributions 	if (!properties) {
72*5e3eaea3SApple OSS Distributions 		return false;
73*5e3eaea3SApple OSS Distributions 	}
74*5e3eaea3SApple OSS Distributions 	properties->setCapacityIncrement(1);
75*5e3eaea3SApple OSS Distributions 
76*5e3eaea3SApple OSS Distributions 	externalConnectedKey = OSSymbol::withCString(kIOPMPSExternalConnectedKey);
77*5e3eaea3SApple OSS Distributions 	externalChargeCapableKey = OSSymbol::withCString(kIOPMPSExternalChargeCapableKey);
78*5e3eaea3SApple OSS Distributions 	batteryInstalledKey = OSSymbol::withCString(kIOPMPSBatteryInstalledKey);
79*5e3eaea3SApple OSS Distributions 	chargingKey = OSSymbol::withCString(kIOPMPSIsChargingKey);
80*5e3eaea3SApple OSS Distributions 	warnLevelKey = OSSymbol::withCString(kIOPMPSAtWarnLevelKey);
81*5e3eaea3SApple OSS Distributions 	criticalLevelKey = OSSymbol::withCString(kIOPMPSAtCriticalLevelKey);
82*5e3eaea3SApple OSS Distributions 	currentCapacityKey = OSSymbol::withCString(kIOPMPSCurrentCapacityKey);
83*5e3eaea3SApple OSS Distributions 	maxCapacityKey = OSSymbol::withCString(kIOPMPSMaxCapacityKey);
84*5e3eaea3SApple OSS Distributions 	timeRemainingKey = OSSymbol::withCString(kIOPMPSTimeRemainingKey);
85*5e3eaea3SApple OSS Distributions 	amperageKey = OSSymbol::withCString(kIOPMPSAmperageKey);
86*5e3eaea3SApple OSS Distributions 	voltageKey = OSSymbol::withCString(kIOPMPSVoltageKey);
87*5e3eaea3SApple OSS Distributions 	cycleCountKey = OSSymbol::withCString(kIOPMPSCycleCountKey);
88*5e3eaea3SApple OSS Distributions 	adapterInfoKey = OSSymbol::withCString(kIOPMPSAdapterInfoKey);
89*5e3eaea3SApple OSS Distributions 	locationKey = OSSymbol::withCString(kIOPMPSLocationKey);
90*5e3eaea3SApple OSS Distributions 	errorConditionKey = OSSymbol::withCString(kIOPMPSErrorConditionKey);
91*5e3eaea3SApple OSS Distributions 	manufacturerKey = OSSymbol::withCString(kIOPMPSManufacturerKey);
92*5e3eaea3SApple OSS Distributions 	modelKey = OSSymbol::withCString(kIOPMPSModelKey);
93*5e3eaea3SApple OSS Distributions 	serialKey = OSSymbol::withCString(kIOPMPSSerialKey);
94*5e3eaea3SApple OSS Distributions 	batteryInfoKey = OSSymbol::withCString(kIOPMPSLegacyBatteryInfoKey);
95*5e3eaea3SApple OSS Distributions 
96*5e3eaea3SApple OSS Distributions 	return true;
97*5e3eaea3SApple OSS Distributions }
98*5e3eaea3SApple OSS Distributions 
99*5e3eaea3SApple OSS Distributions // *****************************************************************************
100*5e3eaea3SApple OSS Distributions // free
101*5e3eaea3SApple OSS Distributions //
102*5e3eaea3SApple OSS Distributions // *****************************************************************************
103*5e3eaea3SApple OSS Distributions void
free(void)104*5e3eaea3SApple OSS Distributions IOPMPowerSource::free(void)
105*5e3eaea3SApple OSS Distributions {
106*5e3eaea3SApple OSS Distributions 	if (properties) {
107*5e3eaea3SApple OSS Distributions 		properties->release();
108*5e3eaea3SApple OSS Distributions 	}
109*5e3eaea3SApple OSS Distributions 	if (externalConnectedKey) {
110*5e3eaea3SApple OSS Distributions 		externalConnectedKey->release();
111*5e3eaea3SApple OSS Distributions 	}
112*5e3eaea3SApple OSS Distributions 	if (externalChargeCapableKey) {
113*5e3eaea3SApple OSS Distributions 		externalChargeCapableKey->release();
114*5e3eaea3SApple OSS Distributions 	}
115*5e3eaea3SApple OSS Distributions 	if (batteryInstalledKey) {
116*5e3eaea3SApple OSS Distributions 		batteryInstalledKey->release();
117*5e3eaea3SApple OSS Distributions 	}
118*5e3eaea3SApple OSS Distributions 	if (chargingKey) {
119*5e3eaea3SApple OSS Distributions 		chargingKey->release();
120*5e3eaea3SApple OSS Distributions 	}
121*5e3eaea3SApple OSS Distributions 	if (warnLevelKey) {
122*5e3eaea3SApple OSS Distributions 		warnLevelKey->release();
123*5e3eaea3SApple OSS Distributions 	}
124*5e3eaea3SApple OSS Distributions 	if (criticalLevelKey) {
125*5e3eaea3SApple OSS Distributions 		criticalLevelKey->release();
126*5e3eaea3SApple OSS Distributions 	}
127*5e3eaea3SApple OSS Distributions 	if (currentCapacityKey) {
128*5e3eaea3SApple OSS Distributions 		currentCapacityKey->release();
129*5e3eaea3SApple OSS Distributions 	}
130*5e3eaea3SApple OSS Distributions 	if (maxCapacityKey) {
131*5e3eaea3SApple OSS Distributions 		maxCapacityKey->release();
132*5e3eaea3SApple OSS Distributions 	}
133*5e3eaea3SApple OSS Distributions 	if (timeRemainingKey) {
134*5e3eaea3SApple OSS Distributions 		timeRemainingKey->release();
135*5e3eaea3SApple OSS Distributions 	}
136*5e3eaea3SApple OSS Distributions 	if (amperageKey) {
137*5e3eaea3SApple OSS Distributions 		amperageKey->release();
138*5e3eaea3SApple OSS Distributions 	}
139*5e3eaea3SApple OSS Distributions 	if (voltageKey) {
140*5e3eaea3SApple OSS Distributions 		voltageKey->release();
141*5e3eaea3SApple OSS Distributions 	}
142*5e3eaea3SApple OSS Distributions 	if (cycleCountKey) {
143*5e3eaea3SApple OSS Distributions 		cycleCountKey->release();
144*5e3eaea3SApple OSS Distributions 	}
145*5e3eaea3SApple OSS Distributions 	if (adapterInfoKey) {
146*5e3eaea3SApple OSS Distributions 		adapterInfoKey->release();
147*5e3eaea3SApple OSS Distributions 	}
148*5e3eaea3SApple OSS Distributions 	if (errorConditionKey) {
149*5e3eaea3SApple OSS Distributions 		errorConditionKey->release();
150*5e3eaea3SApple OSS Distributions 	}
151*5e3eaea3SApple OSS Distributions 	if (manufacturerKey) {
152*5e3eaea3SApple OSS Distributions 		manufacturerKey->release();
153*5e3eaea3SApple OSS Distributions 	}
154*5e3eaea3SApple OSS Distributions 	if (modelKey) {
155*5e3eaea3SApple OSS Distributions 		modelKey->release();
156*5e3eaea3SApple OSS Distributions 	}
157*5e3eaea3SApple OSS Distributions 	if (serialKey) {
158*5e3eaea3SApple OSS Distributions 		serialKey->release();
159*5e3eaea3SApple OSS Distributions 	}
160*5e3eaea3SApple OSS Distributions 	if (locationKey) {
161*5e3eaea3SApple OSS Distributions 		locationKey->release();
162*5e3eaea3SApple OSS Distributions 	}
163*5e3eaea3SApple OSS Distributions 	if (batteryInfoKey) {
164*5e3eaea3SApple OSS Distributions 		batteryInfoKey->release();
165*5e3eaea3SApple OSS Distributions 	}
166*5e3eaea3SApple OSS Distributions 
167*5e3eaea3SApple OSS Distributions 	super::free();
168*5e3eaea3SApple OSS Distributions }
169*5e3eaea3SApple OSS Distributions 
170*5e3eaea3SApple OSS Distributions // *****************************************************************************
171*5e3eaea3SApple OSS Distributions // updateStatus
172*5e3eaea3SApple OSS Distributions //
173*5e3eaea3SApple OSS Distributions // Update power source state in IORegistry and message interested clients
174*5e3eaea3SApple OSS Distributions // notifying them of our change.
175*5e3eaea3SApple OSS Distributions // *****************************************************************************
176*5e3eaea3SApple OSS Distributions void
updateStatus(void)177*5e3eaea3SApple OSS Distributions IOPMPowerSource::updateStatus(void)
178*5e3eaea3SApple OSS Distributions {
179*5e3eaea3SApple OSS Distributions 	OSCollectionIterator            *iterator;
180*5e3eaea3SApple OSS Distributions 	OSObject                        *iteratorKey;
181*5e3eaea3SApple OSS Distributions 	OSObject                        *obj;
182*5e3eaea3SApple OSS Distributions 
183*5e3eaea3SApple OSS Distributions 	// do nothing if settings haven't changed
184*5e3eaea3SApple OSS Distributions 	if (!settingsChangedSinceUpdate) {
185*5e3eaea3SApple OSS Distributions 		return;
186*5e3eaea3SApple OSS Distributions 	}
187*5e3eaea3SApple OSS Distributions 
188*5e3eaea3SApple OSS Distributions 	iterator = OSCollectionIterator::withCollection(properties);
189*5e3eaea3SApple OSS Distributions 	if (!iterator) {
190*5e3eaea3SApple OSS Distributions 		return;
191*5e3eaea3SApple OSS Distributions 	}
192*5e3eaea3SApple OSS Distributions 
193*5e3eaea3SApple OSS Distributions 	while ((iteratorKey = iterator->getNextObject())) {
194*5e3eaea3SApple OSS Distributions 		OSSymbol *key;
195*5e3eaea3SApple OSS Distributions 
196*5e3eaea3SApple OSS Distributions 		key = OSDynamicCast(OSSymbol, iteratorKey);
197*5e3eaea3SApple OSS Distributions 		if (!key) {
198*5e3eaea3SApple OSS Distributions 			continue;
199*5e3eaea3SApple OSS Distributions 		}
200*5e3eaea3SApple OSS Distributions 		obj = properties->getObject(key);
201*5e3eaea3SApple OSS Distributions 		if (!obj) {
202*5e3eaea3SApple OSS Distributions 			continue;
203*5e3eaea3SApple OSS Distributions 		}
204*5e3eaea3SApple OSS Distributions 		setProperty(key, obj);
205*5e3eaea3SApple OSS Distributions 	}
206*5e3eaea3SApple OSS Distributions 	iterator->release();
207*5e3eaea3SApple OSS Distributions 
208*5e3eaea3SApple OSS Distributions 	settingsChangedSinceUpdate = false;
209*5e3eaea3SApple OSS Distributions 
210*5e3eaea3SApple OSS Distributions 	// And up goes the flare
211*5e3eaea3SApple OSS Distributions 	IOMessage notifyMessage = kIOPMMessageBatteryStatusHasChanged;
212*5e3eaea3SApple OSS Distributions #if DEVELOPMENT || DEBUG
213*5e3eaea3SApple OSS Distributions 	os_log(OS_LOG_DEFAULT, "notify clients '%u'\n", (unsigned int)notifyMessage);
214*5e3eaea3SApple OSS Distributions #endif
215*5e3eaea3SApple OSS Distributions 	messageClients(notifyMessage);
216*5e3eaea3SApple OSS Distributions }
217*5e3eaea3SApple OSS Distributions 
218*5e3eaea3SApple OSS Distributions 
219*5e3eaea3SApple OSS Distributions /*******************************************************************************
220*5e3eaea3SApple OSS Distributions  *
221*5e3eaea3SApple OSS Distributions  * PROTECTED Accessors. All the setters! Yay!
222*5e3eaea3SApple OSS Distributions  *
223*5e3eaea3SApple OSS Distributions  ******************************************************************************/
224*5e3eaea3SApple OSS Distributions 
225*5e3eaea3SApple OSS Distributions void
setPSProperty(const OSSymbol * key,OSObject * val)226*5e3eaea3SApple OSS Distributions IOPMPowerSource::setPSProperty(const OSSymbol *key, OSObject *val)
227*5e3eaea3SApple OSS Distributions {
228*5e3eaea3SApple OSS Distributions 	OSObject    *lastVal;
229*5e3eaea3SApple OSS Distributions 
230*5e3eaea3SApple OSS Distributions 	if (!key || !val) {
231*5e3eaea3SApple OSS Distributions 		return;
232*5e3eaea3SApple OSS Distributions 	}
233*5e3eaea3SApple OSS Distributions 
234*5e3eaea3SApple OSS Distributions 	// Compare new setting with existing setting; update
235*5e3eaea3SApple OSS Distributions 	// 'settingsChangedSinceUpdate' if the setting has changed.
236*5e3eaea3SApple OSS Distributions 	// If values are OSNumbers, do equality comparison.
237*5e3eaea3SApple OSS Distributions 	// Otherwise, just compare pointers.
238*5e3eaea3SApple OSS Distributions 
239*5e3eaea3SApple OSS Distributions 	if ((lastVal = properties->getObject(key))) {
240*5e3eaea3SApple OSS Distributions 		if (val->isEqualTo(lastVal)) {
241*5e3eaea3SApple OSS Distributions 			// settings didn't change
242*5e3eaea3SApple OSS Distributions 		} else {
243*5e3eaea3SApple OSS Distributions 			// num val is not equal to last val
244*5e3eaea3SApple OSS Distributions 			settingsChangedSinceUpdate = true;
245*5e3eaea3SApple OSS Distributions 		}
246*5e3eaea3SApple OSS Distributions 	} else {
247*5e3eaea3SApple OSS Distributions 		// new setting; no last value
248*5e3eaea3SApple OSS Distributions 		settingsChangedSinceUpdate = true;
249*5e3eaea3SApple OSS Distributions 	}
250*5e3eaea3SApple OSS Distributions 
251*5e3eaea3SApple OSS Distributions 	// here's the part where we go crazy.
252*5e3eaea3SApple OSS Distributions 	properties->setObject(key, val);
253*5e3eaea3SApple OSS Distributions }
254*5e3eaea3SApple OSS Distributions 
255*5e3eaea3SApple OSS Distributions 
256*5e3eaea3SApple OSS Distributions 
257*5e3eaea3SApple OSS Distributions void
setExternalConnected(bool b)258*5e3eaea3SApple OSS Distributions IOPMPowerSource::setExternalConnected(bool b)
259*5e3eaea3SApple OSS Distributions {
260*5e3eaea3SApple OSS Distributions 	setPSProperty(externalConnectedKey,
261*5e3eaea3SApple OSS Distributions 	    b ? kOSBooleanTrue : kOSBooleanFalse);
262*5e3eaea3SApple OSS Distributions }
263*5e3eaea3SApple OSS Distributions 
264*5e3eaea3SApple OSS Distributions void
setExternalChargeCapable(bool b)265*5e3eaea3SApple OSS Distributions IOPMPowerSource::setExternalChargeCapable(bool b)
266*5e3eaea3SApple OSS Distributions {
267*5e3eaea3SApple OSS Distributions 	setPSProperty(externalChargeCapableKey,
268*5e3eaea3SApple OSS Distributions 	    b ? kOSBooleanTrue : kOSBooleanFalse);
269*5e3eaea3SApple OSS Distributions }
270*5e3eaea3SApple OSS Distributions 
271*5e3eaea3SApple OSS Distributions void
setBatteryInstalled(bool b)272*5e3eaea3SApple OSS Distributions IOPMPowerSource::setBatteryInstalled(bool b)
273*5e3eaea3SApple OSS Distributions {
274*5e3eaea3SApple OSS Distributions 	setPSProperty(batteryInstalledKey,
275*5e3eaea3SApple OSS Distributions 	    b ? kOSBooleanTrue : kOSBooleanFalse);
276*5e3eaea3SApple OSS Distributions }
277*5e3eaea3SApple OSS Distributions 
278*5e3eaea3SApple OSS Distributions void
setIsCharging(bool b)279*5e3eaea3SApple OSS Distributions IOPMPowerSource::setIsCharging(bool b)
280*5e3eaea3SApple OSS Distributions {
281*5e3eaea3SApple OSS Distributions 	setPSProperty(chargingKey,
282*5e3eaea3SApple OSS Distributions 	    b ? kOSBooleanTrue : kOSBooleanFalse);
283*5e3eaea3SApple OSS Distributions }
284*5e3eaea3SApple OSS Distributions 
285*5e3eaea3SApple OSS Distributions void
setAtWarnLevel(bool b)286*5e3eaea3SApple OSS Distributions IOPMPowerSource::setAtWarnLevel(bool b)
287*5e3eaea3SApple OSS Distributions {
288*5e3eaea3SApple OSS Distributions 	setPSProperty(warnLevelKey,
289*5e3eaea3SApple OSS Distributions 	    b ? kOSBooleanTrue : kOSBooleanFalse);
290*5e3eaea3SApple OSS Distributions }
291*5e3eaea3SApple OSS Distributions 
292*5e3eaea3SApple OSS Distributions void
setAtCriticalLevel(bool b)293*5e3eaea3SApple OSS Distributions IOPMPowerSource::setAtCriticalLevel(bool b)
294*5e3eaea3SApple OSS Distributions {
295*5e3eaea3SApple OSS Distributions 	setPSProperty(criticalLevelKey,
296*5e3eaea3SApple OSS Distributions 	    b ? kOSBooleanTrue : kOSBooleanFalse);
297*5e3eaea3SApple OSS Distributions }
298*5e3eaea3SApple OSS Distributions 
299*5e3eaea3SApple OSS Distributions 
300*5e3eaea3SApple OSS Distributions void
setCurrentCapacity(unsigned int val)301*5e3eaea3SApple OSS Distributions IOPMPowerSource::setCurrentCapacity(unsigned int val)
302*5e3eaea3SApple OSS Distributions {
303*5e3eaea3SApple OSS Distributions 	OSNumber *n = OSNumber::withNumber(val, 32);
304*5e3eaea3SApple OSS Distributions 	setPSProperty(currentCapacityKey, n);
305*5e3eaea3SApple OSS Distributions 	n->release();
306*5e3eaea3SApple OSS Distributions }
307*5e3eaea3SApple OSS Distributions 
308*5e3eaea3SApple OSS Distributions void
setMaxCapacity(unsigned int val)309*5e3eaea3SApple OSS Distributions IOPMPowerSource::setMaxCapacity(unsigned int val)
310*5e3eaea3SApple OSS Distributions {
311*5e3eaea3SApple OSS Distributions 	OSNumber *n = OSNumber::withNumber(val, 32);
312*5e3eaea3SApple OSS Distributions 	setPSProperty(maxCapacityKey, n);
313*5e3eaea3SApple OSS Distributions 	n->release();
314*5e3eaea3SApple OSS Distributions }
315*5e3eaea3SApple OSS Distributions 
316*5e3eaea3SApple OSS Distributions void
setTimeRemaining(int val)317*5e3eaea3SApple OSS Distributions IOPMPowerSource::setTimeRemaining(int val)
318*5e3eaea3SApple OSS Distributions {
319*5e3eaea3SApple OSS Distributions 	OSNumber *n = OSNumber::withNumber(val, 32);
320*5e3eaea3SApple OSS Distributions 	setPSProperty(timeRemainingKey, n);
321*5e3eaea3SApple OSS Distributions 	n->release();
322*5e3eaea3SApple OSS Distributions }
323*5e3eaea3SApple OSS Distributions 
324*5e3eaea3SApple OSS Distributions void
setAmperage(int val)325*5e3eaea3SApple OSS Distributions IOPMPowerSource::setAmperage(int val)
326*5e3eaea3SApple OSS Distributions {
327*5e3eaea3SApple OSS Distributions 	OSNumber *n = OSNumber::withNumber(val, 32);
328*5e3eaea3SApple OSS Distributions 	setPSProperty(amperageKey, n);
329*5e3eaea3SApple OSS Distributions 	n->release();
330*5e3eaea3SApple OSS Distributions }
331*5e3eaea3SApple OSS Distributions 
332*5e3eaea3SApple OSS Distributions void
setVoltage(unsigned int val)333*5e3eaea3SApple OSS Distributions IOPMPowerSource::setVoltage(unsigned int val)
334*5e3eaea3SApple OSS Distributions {
335*5e3eaea3SApple OSS Distributions 	OSNumber *n = OSNumber::withNumber(val, 32);
336*5e3eaea3SApple OSS Distributions 	setPSProperty(voltageKey, n);
337*5e3eaea3SApple OSS Distributions 	n->release();
338*5e3eaea3SApple OSS Distributions }
339*5e3eaea3SApple OSS Distributions 
340*5e3eaea3SApple OSS Distributions void
setCycleCount(unsigned int val)341*5e3eaea3SApple OSS Distributions IOPMPowerSource::setCycleCount(unsigned int val)
342*5e3eaea3SApple OSS Distributions {
343*5e3eaea3SApple OSS Distributions 	OSNumber *n = OSNumber::withNumber(val, 32);
344*5e3eaea3SApple OSS Distributions 	setPSProperty(cycleCountKey, n);
345*5e3eaea3SApple OSS Distributions 	n->release();
346*5e3eaea3SApple OSS Distributions }
347*5e3eaea3SApple OSS Distributions 
348*5e3eaea3SApple OSS Distributions void
setAdapterInfo(int val)349*5e3eaea3SApple OSS Distributions IOPMPowerSource::setAdapterInfo(int val)
350*5e3eaea3SApple OSS Distributions {
351*5e3eaea3SApple OSS Distributions 	OSNumber *n = OSNumber::withNumber(val, 32);
352*5e3eaea3SApple OSS Distributions 	setPSProperty(adapterInfoKey, n);
353*5e3eaea3SApple OSS Distributions 	n->release();
354*5e3eaea3SApple OSS Distributions }
355*5e3eaea3SApple OSS Distributions 
356*5e3eaea3SApple OSS Distributions void
setLocation(int val)357*5e3eaea3SApple OSS Distributions IOPMPowerSource::setLocation(int val)
358*5e3eaea3SApple OSS Distributions {
359*5e3eaea3SApple OSS Distributions 	OSNumber *n = OSNumber::withNumber(val, 32);
360*5e3eaea3SApple OSS Distributions 	setPSProperty(locationKey, n);
361*5e3eaea3SApple OSS Distributions 	n->release();
362*5e3eaea3SApple OSS Distributions }
363*5e3eaea3SApple OSS Distributions 
364*5e3eaea3SApple OSS Distributions void
setErrorCondition(OSSymbol * s)365*5e3eaea3SApple OSS Distributions IOPMPowerSource::setErrorCondition(OSSymbol *s)
366*5e3eaea3SApple OSS Distributions {
367*5e3eaea3SApple OSS Distributions 	setPSProperty(errorConditionKey, s);
368*5e3eaea3SApple OSS Distributions }
369*5e3eaea3SApple OSS Distributions 
370*5e3eaea3SApple OSS Distributions void
setManufacturer(OSSymbol * s)371*5e3eaea3SApple OSS Distributions IOPMPowerSource::setManufacturer(OSSymbol *s)
372*5e3eaea3SApple OSS Distributions {
373*5e3eaea3SApple OSS Distributions 	setPSProperty(manufacturerKey, s);
374*5e3eaea3SApple OSS Distributions }
375*5e3eaea3SApple OSS Distributions 
376*5e3eaea3SApple OSS Distributions void
setModel(OSSymbol * s)377*5e3eaea3SApple OSS Distributions IOPMPowerSource::setModel(OSSymbol *s)
378*5e3eaea3SApple OSS Distributions {
379*5e3eaea3SApple OSS Distributions 	setPSProperty(modelKey, s);
380*5e3eaea3SApple OSS Distributions }
381*5e3eaea3SApple OSS Distributions 
382*5e3eaea3SApple OSS Distributions void
setSerial(OSSymbol * s)383*5e3eaea3SApple OSS Distributions IOPMPowerSource::setSerial(OSSymbol *s)
384*5e3eaea3SApple OSS Distributions {
385*5e3eaea3SApple OSS Distributions 	setPSProperty(serialKey, s);
386*5e3eaea3SApple OSS Distributions }
387*5e3eaea3SApple OSS Distributions 
388*5e3eaea3SApple OSS Distributions void
setLegacyIOBatteryInfo(OSDictionary * d)389*5e3eaea3SApple OSS Distributions IOPMPowerSource::setLegacyIOBatteryInfo(OSDictionary *d)
390*5e3eaea3SApple OSS Distributions {
391*5e3eaea3SApple OSS Distributions 	setPSProperty(batteryInfoKey, d);
392*5e3eaea3SApple OSS Distributions }
393*5e3eaea3SApple OSS Distributions 
394*5e3eaea3SApple OSS Distributions 
395*5e3eaea3SApple OSS Distributions 
396*5e3eaea3SApple OSS Distributions 
397*5e3eaea3SApple OSS Distributions /*******************************************************************************
398*5e3eaea3SApple OSS Distributions  *
399*5e3eaea3SApple OSS Distributions  * PUBLIC Accessors. All the getters! Boo!
400*5e3eaea3SApple OSS Distributions  *
401*5e3eaea3SApple OSS Distributions  ******************************************************************************/
402*5e3eaea3SApple OSS Distributions 
403*5e3eaea3SApple OSS Distributions OSObject *
getPSProperty(const OSSymbol * symmie)404*5e3eaea3SApple OSS Distributions IOPMPowerSource::getPSProperty(const OSSymbol *symmie)
405*5e3eaea3SApple OSS Distributions {
406*5e3eaea3SApple OSS Distributions 	if (!symmie) {
407*5e3eaea3SApple OSS Distributions 		return NULL;
408*5e3eaea3SApple OSS Distributions 	}
409*5e3eaea3SApple OSS Distributions 	return properties->getObject(symmie);
410*5e3eaea3SApple OSS Distributions }
411*5e3eaea3SApple OSS Distributions 
412*5e3eaea3SApple OSS Distributions bool
externalConnected(void)413*5e3eaea3SApple OSS Distributions IOPMPowerSource::externalConnected(void)
414*5e3eaea3SApple OSS Distributions {
415*5e3eaea3SApple OSS Distributions 	return kOSBooleanTrue == properties->getObject(externalConnectedKey);
416*5e3eaea3SApple OSS Distributions }
417*5e3eaea3SApple OSS Distributions 
418*5e3eaea3SApple OSS Distributions bool
externalChargeCapable(void)419*5e3eaea3SApple OSS Distributions IOPMPowerSource::externalChargeCapable(void)
420*5e3eaea3SApple OSS Distributions {
421*5e3eaea3SApple OSS Distributions 	return kOSBooleanTrue == properties->getObject(externalChargeCapableKey);
422*5e3eaea3SApple OSS Distributions }
423*5e3eaea3SApple OSS Distributions 
424*5e3eaea3SApple OSS Distributions bool
batteryInstalled(void)425*5e3eaea3SApple OSS Distributions IOPMPowerSource::batteryInstalled(void)
426*5e3eaea3SApple OSS Distributions {
427*5e3eaea3SApple OSS Distributions 	return kOSBooleanTrue == properties->getObject(batteryInstalledKey);
428*5e3eaea3SApple OSS Distributions }
429*5e3eaea3SApple OSS Distributions 
430*5e3eaea3SApple OSS Distributions bool
isCharging(void)431*5e3eaea3SApple OSS Distributions IOPMPowerSource::isCharging(void)
432*5e3eaea3SApple OSS Distributions {
433*5e3eaea3SApple OSS Distributions 	return kOSBooleanTrue == properties->getObject(chargingKey);
434*5e3eaea3SApple OSS Distributions }
435*5e3eaea3SApple OSS Distributions 
436*5e3eaea3SApple OSS Distributions bool
atWarnLevel(void)437*5e3eaea3SApple OSS Distributions IOPMPowerSource::atWarnLevel(void)
438*5e3eaea3SApple OSS Distributions {
439*5e3eaea3SApple OSS Distributions 	return kOSBooleanTrue == properties->getObject(warnLevelKey);
440*5e3eaea3SApple OSS Distributions }
441*5e3eaea3SApple OSS Distributions 
442*5e3eaea3SApple OSS Distributions bool
atCriticalLevel(void)443*5e3eaea3SApple OSS Distributions IOPMPowerSource::atCriticalLevel(void)
444*5e3eaea3SApple OSS Distributions {
445*5e3eaea3SApple OSS Distributions 	return kOSBooleanTrue == properties->getObject(criticalLevelKey);
446*5e3eaea3SApple OSS Distributions }
447*5e3eaea3SApple OSS Distributions 
448*5e3eaea3SApple OSS Distributions unsigned int
currentCapacity(void)449*5e3eaea3SApple OSS Distributions IOPMPowerSource::currentCapacity(void)
450*5e3eaea3SApple OSS Distributions {
451*5e3eaea3SApple OSS Distributions 	OSNumber        *n;
452*5e3eaea3SApple OSS Distributions 	n = OSDynamicCast(OSNumber, properties->getObject(currentCapacityKey));
453*5e3eaea3SApple OSS Distributions 	if (!n) {
454*5e3eaea3SApple OSS Distributions 		return 0;
455*5e3eaea3SApple OSS Distributions 	} else {
456*5e3eaea3SApple OSS Distributions 		return (unsigned int)n->unsigned32BitValue();
457*5e3eaea3SApple OSS Distributions 	}
458*5e3eaea3SApple OSS Distributions }
459*5e3eaea3SApple OSS Distributions 
460*5e3eaea3SApple OSS Distributions unsigned int
maxCapacity(void)461*5e3eaea3SApple OSS Distributions IOPMPowerSource::maxCapacity(void)
462*5e3eaea3SApple OSS Distributions {
463*5e3eaea3SApple OSS Distributions 	OSNumber        *n;
464*5e3eaea3SApple OSS Distributions 	n = OSDynamicCast(OSNumber, properties->getObject(maxCapacityKey));
465*5e3eaea3SApple OSS Distributions 	if (!n) {
466*5e3eaea3SApple OSS Distributions 		return 0;
467*5e3eaea3SApple OSS Distributions 	} else {
468*5e3eaea3SApple OSS Distributions 		return (unsigned int)n->unsigned32BitValue();
469*5e3eaea3SApple OSS Distributions 	}
470*5e3eaea3SApple OSS Distributions }
471*5e3eaea3SApple OSS Distributions 
472*5e3eaea3SApple OSS Distributions unsigned int
capacityPercentRemaining(void)473*5e3eaea3SApple OSS Distributions IOPMPowerSource::capacityPercentRemaining(void)
474*5e3eaea3SApple OSS Distributions {
475*5e3eaea3SApple OSS Distributions 	unsigned int _currentCapacity = currentCapacity();
476*5e3eaea3SApple OSS Distributions 	unsigned int _maxCapacity = maxCapacity();
477*5e3eaea3SApple OSS Distributions 	if (0 == _maxCapacity) {
478*5e3eaea3SApple OSS Distributions 		return 0;
479*5e3eaea3SApple OSS Distributions 	} else {
480*5e3eaea3SApple OSS Distributions 		return (100 * _currentCapacity) / _maxCapacity;
481*5e3eaea3SApple OSS Distributions 	}
482*5e3eaea3SApple OSS Distributions }
483*5e3eaea3SApple OSS Distributions 
484*5e3eaea3SApple OSS Distributions int
timeRemaining(void)485*5e3eaea3SApple OSS Distributions IOPMPowerSource::timeRemaining(void)
486*5e3eaea3SApple OSS Distributions {
487*5e3eaea3SApple OSS Distributions 	OSNumber        *n;
488*5e3eaea3SApple OSS Distributions 	n = OSDynamicCast(OSNumber, properties->getObject(timeRemainingKey));
489*5e3eaea3SApple OSS Distributions 	if (!n) {
490*5e3eaea3SApple OSS Distributions 		return 0;
491*5e3eaea3SApple OSS Distributions 	} else {
492*5e3eaea3SApple OSS Distributions 		return (int)n->unsigned32BitValue();
493*5e3eaea3SApple OSS Distributions 	}
494*5e3eaea3SApple OSS Distributions }
495*5e3eaea3SApple OSS Distributions 
496*5e3eaea3SApple OSS Distributions int
amperage(void)497*5e3eaea3SApple OSS Distributions IOPMPowerSource::amperage(void)
498*5e3eaea3SApple OSS Distributions {
499*5e3eaea3SApple OSS Distributions 	OSNumber        *n;
500*5e3eaea3SApple OSS Distributions 	n = OSDynamicCast(OSNumber, properties->getObject(amperageKey));
501*5e3eaea3SApple OSS Distributions 	if (!n) {
502*5e3eaea3SApple OSS Distributions 		return 0;
503*5e3eaea3SApple OSS Distributions 	} else {
504*5e3eaea3SApple OSS Distributions 		return (int)n->unsigned32BitValue();
505*5e3eaea3SApple OSS Distributions 	}
506*5e3eaea3SApple OSS Distributions }
507*5e3eaea3SApple OSS Distributions 
508*5e3eaea3SApple OSS Distributions unsigned int
voltage(void)509*5e3eaea3SApple OSS Distributions IOPMPowerSource::voltage(void)
510*5e3eaea3SApple OSS Distributions {
511*5e3eaea3SApple OSS Distributions 	OSNumber        *n;
512*5e3eaea3SApple OSS Distributions 	n = OSDynamicCast(OSNumber, properties->getObject(voltageKey));
513*5e3eaea3SApple OSS Distributions 	if (!n) {
514*5e3eaea3SApple OSS Distributions 		return 0;
515*5e3eaea3SApple OSS Distributions 	} else {
516*5e3eaea3SApple OSS Distributions 		return (unsigned int)n->unsigned32BitValue();
517*5e3eaea3SApple OSS Distributions 	}
518*5e3eaea3SApple OSS Distributions }
519*5e3eaea3SApple OSS Distributions 
520*5e3eaea3SApple OSS Distributions unsigned int
cycleCount(void)521*5e3eaea3SApple OSS Distributions IOPMPowerSource::cycleCount(void)
522*5e3eaea3SApple OSS Distributions {
523*5e3eaea3SApple OSS Distributions 	OSNumber        *n;
524*5e3eaea3SApple OSS Distributions 	n = OSDynamicCast(OSNumber, properties->getObject(cycleCountKey));
525*5e3eaea3SApple OSS Distributions 	if (!n) {
526*5e3eaea3SApple OSS Distributions 		return 0;
527*5e3eaea3SApple OSS Distributions 	} else {
528*5e3eaea3SApple OSS Distributions 		return (unsigned int)n->unsigned32BitValue();
529*5e3eaea3SApple OSS Distributions 	}
530*5e3eaea3SApple OSS Distributions }
531*5e3eaea3SApple OSS Distributions 
532*5e3eaea3SApple OSS Distributions int
adapterInfo(void)533*5e3eaea3SApple OSS Distributions IOPMPowerSource::adapterInfo(void)
534*5e3eaea3SApple OSS Distributions {
535*5e3eaea3SApple OSS Distributions 	OSNumber        *n;
536*5e3eaea3SApple OSS Distributions 	n = OSDynamicCast(OSNumber, properties->getObject(adapterInfoKey));
537*5e3eaea3SApple OSS Distributions 	if (!n) {
538*5e3eaea3SApple OSS Distributions 		return 0;
539*5e3eaea3SApple OSS Distributions 	} else {
540*5e3eaea3SApple OSS Distributions 		return (int)n->unsigned32BitValue();
541*5e3eaea3SApple OSS Distributions 	}
542*5e3eaea3SApple OSS Distributions }
543*5e3eaea3SApple OSS Distributions 
544*5e3eaea3SApple OSS Distributions int
location(void)545*5e3eaea3SApple OSS Distributions IOPMPowerSource::location(void)
546*5e3eaea3SApple OSS Distributions {
547*5e3eaea3SApple OSS Distributions 	OSNumber        *n;
548*5e3eaea3SApple OSS Distributions 	n = OSDynamicCast(OSNumber, properties->getObject(locationKey));
549*5e3eaea3SApple OSS Distributions 	if (!n) {
550*5e3eaea3SApple OSS Distributions 		return 0;
551*5e3eaea3SApple OSS Distributions 	} else {
552*5e3eaea3SApple OSS Distributions 		return (unsigned int)n->unsigned32BitValue();
553*5e3eaea3SApple OSS Distributions 	}
554*5e3eaea3SApple OSS Distributions }
555*5e3eaea3SApple OSS Distributions 
556*5e3eaea3SApple OSS Distributions OSSymbol *
errorCondition(void)557*5e3eaea3SApple OSS Distributions IOPMPowerSource::errorCondition(void)
558*5e3eaea3SApple OSS Distributions {
559*5e3eaea3SApple OSS Distributions 	return OSDynamicCast(OSSymbol, properties->getObject(errorConditionKey));
560*5e3eaea3SApple OSS Distributions }
561*5e3eaea3SApple OSS Distributions 
562*5e3eaea3SApple OSS Distributions OSSymbol *
manufacturer(void)563*5e3eaea3SApple OSS Distributions IOPMPowerSource::manufacturer(void)
564*5e3eaea3SApple OSS Distributions {
565*5e3eaea3SApple OSS Distributions 	return OSDynamicCast(OSSymbol, properties->getObject(manufacturerKey));
566*5e3eaea3SApple OSS Distributions }
567*5e3eaea3SApple OSS Distributions 
568*5e3eaea3SApple OSS Distributions OSSymbol *
model(void)569*5e3eaea3SApple OSS Distributions IOPMPowerSource::model(void)
570*5e3eaea3SApple OSS Distributions {
571*5e3eaea3SApple OSS Distributions 	return OSDynamicCast(OSSymbol, properties->getObject(modelKey));
572*5e3eaea3SApple OSS Distributions }
573*5e3eaea3SApple OSS Distributions 
574*5e3eaea3SApple OSS Distributions OSSymbol *
serial(void)575*5e3eaea3SApple OSS Distributions IOPMPowerSource::serial(void)
576*5e3eaea3SApple OSS Distributions {
577*5e3eaea3SApple OSS Distributions 	return OSDynamicCast(OSSymbol, properties->getObject(serialKey));
578*5e3eaea3SApple OSS Distributions }
579*5e3eaea3SApple OSS Distributions 
580*5e3eaea3SApple OSS Distributions OSDictionary *
legacyIOBatteryInfo(void)581*5e3eaea3SApple OSS Distributions IOPMPowerSource::legacyIOBatteryInfo(void)
582*5e3eaea3SApple OSS Distributions {
583*5e3eaea3SApple OSS Distributions 	return OSDynamicCast(OSDictionary, properties->getObject(batteryInfoKey));
584*5e3eaea3SApple OSS Distributions }
585