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