2 * Copyright (c) 1998-2000 Apple Computer, Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * The contents of this file constitute Original Code as defined in and
7 * are subject to the Apple Public Source License Version 1.1 (the
8 * "License"). You may not use this file except in compliance with the
9 * License. Please obtain a copy of the License at
10 * http://www.apple.com/publicsource and read it before using this file.
12 * This Original Code and all software distributed under the License are
13 * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
14 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
16 * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
17 * License for the specific language governing rights and limitations
20 * @APPLE_LICENSE_HEADER_END@
23 * Copyright (c) 1999 Apple Computer, Inc. All rights reserved.
27 #include <IOKit/assert.h>
28 #include <IOKit/IOLib.h>
29 #include <IOKit/IOKitKeys.h>
30 #include <IOKit/IOBufferMemoryDescriptor.h>
31 #include "RootDomainUserClient.h"
32 #include <IOKit/pwr_mgt/IOPMLibDefs.h>
34 #define super IOUserClient
36 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
38 OSDefineMetaClassAndStructors(RootDomainUserClient
, IOUserClient
)
40 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
42 bool RootDomainUserClient::initWithTask(task_t owningTask
, void *security_id
,
43 UInt32 type
, OSDictionary
* properties
)
46 properties
->setObject(kIOUserClientCrossEndianCompatibleKey
, kOSBooleanTrue
);
48 if (!super::initWithTask(owningTask
, security_id
, type
, properties
))
51 fOwningTask
= owningTask
;
52 task_reference (fOwningTask
);
57 bool RootDomainUserClient::start( IOService
* provider
)
59 assert(OSDynamicCast(IOPMrootDomain
, provider
));
60 if(!super::start(provider
))
62 fOwner
= (IOPMrootDomain
*)provider
;
68 IOReturn
RootDomainUserClient::secureSleepSystem( int *return_code
)
72 IOReturn ret
= kIOReturnNotPrivileged
;
74 ret
= clientHasPrivilege(fOwningTask
, kIOClientPrivilegeLocalUser
);
75 local_priv
= (kIOReturnSuccess
== ret
);
77 ret
= clientHasPrivilege(fOwningTask
, kIOClientPrivilegeAdministrator
);
78 admin_priv
= (kIOReturnSuccess
== ret
);
80 if((local_priv
|| admin_priv
) && fOwner
) {
81 *return_code
= fOwner
->sleepSystem();
82 return kIOReturnSuccess
;
84 *return_code
= kIOReturnNotPrivileged
;
85 return kIOReturnSuccess
;
90 IOReturn
RootDomainUserClient::secureSetAggressiveness(
92 unsigned long newLevel
,
97 IOReturn ret
= kIOReturnNotPrivileged
;
99 ret
= clientHasPrivilege(fOwningTask
, kIOClientPrivilegeLocalUser
);
100 local_priv
= (kIOReturnSuccess
== ret
);
102 ret
= clientHasPrivilege(fOwningTask
, kIOClientPrivilegeAdministrator
);
103 admin_priv
= (kIOReturnSuccess
== ret
);
105 if((local_priv
|| admin_priv
) && fOwner
) {
106 *return_code
= fOwner
->setAggressiveness(type
, newLevel
);
107 return kIOReturnSuccess
;
109 *return_code
= kIOReturnNotPrivileged
;
110 return kIOReturnSuccess
;
116 IOReturn
RootDomainUserClient::clientClose( void )
121 task_deallocate(fOwningTask
);
125 return kIOReturnSuccess
;
129 RootDomainUserClient::getTargetAndMethodForIndex( IOService
** targetP
, UInt32 index
)
131 static IOExternalMethod sMethods
[] = {
132 { // kPMSetAggressiveness, 0
133 (IOService
*)1, (IOMethod
)&RootDomainUserClient::secureSetAggressiveness
, kIOUCScalarIScalarO
, 2, 1
135 { // kPMGetAggressiveness, 1
136 0, (IOMethod
)&IOPMrootDomain::getAggressiveness
, kIOUCScalarIScalarO
, 1, 1
138 { // kPMSleepSystem, 2
139 (IOService
*)1, (IOMethod
)&RootDomainUserClient::secureSleepSystem
, kIOUCScalarIScalarO
, 0, 1
141 { // kPMAllowPowerChange, 3
142 0, (IOMethod
)&IOPMrootDomain::allowPowerChange
, kIOUCScalarIScalarO
, 1, 0
144 { // kPMCancelPowerChange, 4
145 0, (IOMethod
)&IOPMrootDomain::cancelPowerChange
, kIOUCScalarIScalarO
, 1, 0
147 { // kPMShutdownSystem, 5
148 0, (IOMethod
)&IOPMrootDomain::shutdownSystem
, kIOUCScalarIScalarO
, 0, 0
150 { // kPMRestartSystem, 6
151 0, (IOMethod
)&IOPMrootDomain::restartSystem
, kIOUCScalarIScalarO
, 0, 0
153 { // kPMSetPreventative, 7
154 (IOService
*)1, (IOMethod
)&RootDomainUserClient::setPreventative
, kIOUCScalarIScalarO
, 2, 0
158 if(index
>= kNumPMMethods
)
161 if (sMethods
[index
].object
)
166 return &sMethods
[index
];
171 RootDomainUserClient::setPreventative(UInt32 on_off
, UInt32 types_of_sleep
)