]> git.saurik.com Git - apple/xnu.git/blame - bsd/tests/pmap_test_sysctl.c
xnu-6153.41.3.tar.gz
[apple/xnu.git] / bsd / tests / pmap_test_sysctl.c
CommitLineData
1c79356b 1/*
d9a64523 2 * Copyright (c) 2016 Apple Inc. All rights reserved.
5d5c5d0d 3 *
2d21ac55 4 * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
0a7de745 5 *
2d21ac55
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. The rights granted to you under the License
10 * may not be used to create, or enable the creation or redistribution of,
11 * unlawful or unlicensed copies of an Apple operating system, or to
12 * circumvent, violate, or enable the circumvention or violation of, any
13 * terms of an Apple operating system software license agreement.
0a7de745 14 *
2d21ac55
A
15 * Please obtain a copy of the License at
16 * http://www.opensource.apple.com/apsl/ and read it before using this file.
0a7de745 17 *
2d21ac55
A
18 * The Original Code and all software distributed under the License are
19 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
8f6c56a5
A
20 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
2d21ac55
A
22 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23 * Please see the License for the specific language governing rights and
24 * limitations under the License.
0a7de745 25 *
2d21ac55 26 * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
1c79356b 27 */
0b4e3aa0 28
d9a64523 29#include <sys/sysctl.h>
0b4e3aa0 30
d9a64523
A
31extern kern_return_t test_pmap_enter_disconnect(unsigned int);
32extern kern_return_t test_pmap_iommu_disconnect(void);
cb323159 33extern kern_return_t test_pmap_extended(void);
1c79356b 34
d9a64523
A
35static int
36sysctl_test_pmap_enter_disconnect(__unused struct sysctl_oid *oidp, __unused void *arg1, __unused int arg2, struct sysctl_req *req)
37{
38 unsigned int num_loops;
39 int error, changed;
40 error = sysctl_io_number(req, 0, sizeof(num_loops), &num_loops, &changed);
0a7de745 41 if (error || !changed) {
d9a64523 42 return error;
0a7de745 43 }
d9a64523
A
44 return test_pmap_enter_disconnect(num_loops);
45}
1c79356b 46
d9a64523 47SYSCTL_PROC(_kern, OID_AUTO, pmap_enter_disconnect_test,
0a7de745
A
48 CTLTYPE_INT | CTLFLAG_RW | CTLFLAG_LOCKED,
49 0, 0, sysctl_test_pmap_enter_disconnect, "I", "");
d9a64523
A
50
51static int
52sysctl_test_pmap_iommu_disconnect(__unused struct sysctl_oid *oidp, __unused void *arg1, __unused int arg2, struct sysctl_req *req)
53{
54 unsigned int run = 0;
55 int error, changed;
56 error = sysctl_io_number(req, 0, sizeof(run), &run, &changed);
0a7de745 57 if (error || !changed) {
d9a64523 58 return error;
0a7de745 59 }
d9a64523 60 return test_pmap_iommu_disconnect();
1c79356b 61}
1c79356b 62
d9a64523 63SYSCTL_PROC(_kern, OID_AUTO, pmap_iommu_disconnect_test,
0a7de745
A
64 CTLTYPE_INT | CTLFLAG_RW | CTLFLAG_LOCKED,
65 0, 0, sysctl_test_pmap_iommu_disconnect, "I", "");
cb323159
A
66
67static int
68sysctl_test_pmap_extended(__unused struct sysctl_oid *oidp, __unused void *arg1, __unused int arg2, struct sysctl_req *req)
69{
70 unsigned int run = 0;
71 int error, changed;
72 error = sysctl_io_number(req, 0, sizeof(run), &run, &changed);
73 if (error || !changed) {
74 return error;
75 }
76 return test_pmap_extended();
77}
78
79SYSCTL_PROC(_kern, OID_AUTO, pmap_extended_test,
80 CTLTYPE_INT | CTLFLAG_RW | CTLFLAG_LOCKED,
81 0, 0, sysctl_test_pmap_extended, "I", "");