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