]> git.saurik.com Git - apple/xnu.git/blame - libsyscall/wrappers/getiopolicy_np.c
xnu-7195.81.3.tar.gz
[apple/xnu.git] / libsyscall / wrappers / getiopolicy_np.c
CommitLineData
39236c6e
A
1/*
2 * Copyright (c) 2006 Apple Computer, Inc. All rights reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
0a7de745 5 *
39236c6e
A
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
11 * file.
0a7de745 12 *
39236c6e
A
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
0a7de745 20 *
39236c6e
A
21 * @APPLE_LICENSE_HEADER_END@
22 */
23#include <errno.h>
24#include <sys/resource.h>
fe8ab488 25#include <mach/port.h>
39236c6e
A
26
27extern int __iopolicysys(int, struct _iopol_param_t *);
fe8ab488 28extern void _pthread_clear_qos_tsd(mach_port_t);
39236c6e
A
29
30int
31getiopolicy_np(int iotype, int scope)
32{
33 int policy, error;
34 struct _iopol_param_t iop_param;
35
cb323159 36 if ((iotype != IOPOL_TYPE_DISK && iotype != IOPOL_TYPE_VFS_ATIME_UPDATES && iotype != IOPOL_TYPE_VFS_MATERIALIZE_DATALESS_FILES) ||
0a7de745 37 (scope != IOPOL_SCOPE_PROCESS && scope != IOPOL_SCOPE_THREAD)) {
39236c6e
A
38 errno = EINVAL;
39 policy = -1;
40 goto exit;
41 }
42
43 iop_param.iop_scope = scope;
44 iop_param.iop_iotype = iotype;
45 error = __iopolicysys(IOPOL_CMD_GET, &iop_param);
46 if (error != 0) {
47 errno = error;
48 policy = -1;
49 goto exit;
50 }
51
52 policy = iop_param.iop_policy;
53
0a7de745 54exit:
39236c6e
A
55 return policy;
56}
57
58int
59setiopolicy_np(int iotype, int scope, int policy)
60{
61 /* kernel validates the indiv values, no need to repeat it */
62 struct _iopol_param_t iop_param;
fe8ab488 63
39236c6e
A
64 iop_param.iop_scope = scope;
65 iop_param.iop_iotype = iotype;
66 iop_param.iop_policy = policy;
67
fe8ab488
A
68 int rv = __iopolicysys(IOPOL_CMD_SET, &iop_param);
69 if (rv == -2) {
70 /* not an actual error but indication that __iopolicysys removed the thread QoS */
0a7de745 71 _pthread_clear_qos_tsd(MACH_PORT_NULL);
fe8ab488
A
72 rv = 0;
73 }
74
75 return rv;
39236c6e 76}