1*e3723e1fSApple OSS Distributions #include <pthread.h>
2*e3723e1fSApple OSS Distributions #include <stdlib.h>
3*e3723e1fSApple OSS Distributions #include <stdio.h>
4*e3723e1fSApple OSS Distributions #include <unistd.h>
5*e3723e1fSApple OSS Distributions
6*e3723e1fSApple OSS Distributions #include <mach/mach.h>
7*e3723e1fSApple OSS Distributions #include <mach/mach_vm.h>
8*e3723e1fSApple OSS Distributions
9*e3723e1fSApple OSS Distributions static void*
loop(void * arg)10*e3723e1fSApple OSS Distributions loop(__attribute__ ((unused)) void *arg)
11*e3723e1fSApple OSS Distributions {
12*e3723e1fSApple OSS Distributions while (1) {
13*e3723e1fSApple OSS Distributions }
14*e3723e1fSApple OSS Distributions }
15*e3723e1fSApple OSS Distributions
16*e3723e1fSApple OSS Distributions
17*e3723e1fSApple OSS Distributions static int
run_additional_threads(int nthreads)18*e3723e1fSApple OSS Distributions run_additional_threads(int nthreads)
19*e3723e1fSApple OSS Distributions {
20*e3723e1fSApple OSS Distributions for (int i = 0; i < nthreads; i++) {
21*e3723e1fSApple OSS Distributions pthread_t pthread;
22*e3723e1fSApple OSS Distributions int err;
23*e3723e1fSApple OSS Distributions
24*e3723e1fSApple OSS Distributions err = pthread_create(&pthread, NULL, loop, NULL);
25*e3723e1fSApple OSS Distributions if (err) {
26*e3723e1fSApple OSS Distributions return err;
27*e3723e1fSApple OSS Distributions }
28*e3723e1fSApple OSS Distributions }
29*e3723e1fSApple OSS Distributions
30*e3723e1fSApple OSS Distributions return 0;
31*e3723e1fSApple OSS Distributions }
32*e3723e1fSApple OSS Distributions
33*e3723e1fSApple OSS Distributions static int
allocate_and_wire_memory(mach_vm_size_t size)34*e3723e1fSApple OSS Distributions allocate_and_wire_memory(mach_vm_size_t size)
35*e3723e1fSApple OSS Distributions {
36*e3723e1fSApple OSS Distributions int err;
37*e3723e1fSApple OSS Distributions task_t task = mach_task_self();
38*e3723e1fSApple OSS Distributions mach_vm_address_t addr;
39*e3723e1fSApple OSS Distributions
40*e3723e1fSApple OSS Distributions if (size <= 0) {
41*e3723e1fSApple OSS Distributions return 0;
42*e3723e1fSApple OSS Distributions }
43*e3723e1fSApple OSS Distributions
44*e3723e1fSApple OSS Distributions err = mach_vm_allocate(task, &addr, size, VM_FLAGS_ANYWHERE);
45*e3723e1fSApple OSS Distributions if (err != KERN_SUCCESS) {
46*e3723e1fSApple OSS Distributions printf("mach_vm_allocate returned non-zero: %s\n", mach_error_string(err));
47*e3723e1fSApple OSS Distributions return err;
48*e3723e1fSApple OSS Distributions }
49*e3723e1fSApple OSS Distributions err = mach_vm_protect(task, addr, size, 0, VM_PROT_READ | VM_PROT_WRITE);
50*e3723e1fSApple OSS Distributions if (err != KERN_SUCCESS) {
51*e3723e1fSApple OSS Distributions printf("mach_vm_protect returned non-zero: %s\n", mach_error_string(err));
52*e3723e1fSApple OSS Distributions return err;
53*e3723e1fSApple OSS Distributions }
54*e3723e1fSApple OSS Distributions host_t host_priv_port;
55*e3723e1fSApple OSS Distributions err = host_get_host_priv_port(mach_host_self(), &host_priv_port);
56*e3723e1fSApple OSS Distributions if (err != KERN_SUCCESS) {
57*e3723e1fSApple OSS Distributions printf("host_get_host_priv_port returned non-zero: %s\n", mach_error_string(err));
58*e3723e1fSApple OSS Distributions return err;
59*e3723e1fSApple OSS Distributions }
60*e3723e1fSApple OSS Distributions err = mach_vm_wire(host_priv_port, task, addr, size, VM_PROT_READ | VM_PROT_WRITE);
61*e3723e1fSApple OSS Distributions if (err != KERN_SUCCESS) {
62*e3723e1fSApple OSS Distributions printf("mach_vm_wire returned non-zero: %s\n", mach_error_string(err));
63*e3723e1fSApple OSS Distributions return err;
64*e3723e1fSApple OSS Distributions }
65*e3723e1fSApple OSS Distributions
66*e3723e1fSApple OSS Distributions return 0;
67*e3723e1fSApple OSS Distributions }
68*e3723e1fSApple OSS Distributions
69*e3723e1fSApple OSS Distributions int
main(int argc,char * argv[])70*e3723e1fSApple OSS Distributions main(int argc, char *argv[])
71*e3723e1fSApple OSS Distributions {
72*e3723e1fSApple OSS Distributions int nthreads = 0;
73*e3723e1fSApple OSS Distributions int err;
74*e3723e1fSApple OSS Distributions mach_vm_size_t wired_mem = 0;
75*e3723e1fSApple OSS Distributions
76*e3723e1fSApple OSS Distributions if (argc > 1) {
77*e3723e1fSApple OSS Distributions nthreads = (int)strtoul(argv[1], NULL, 10);
78*e3723e1fSApple OSS Distributions }
79*e3723e1fSApple OSS Distributions if (argc > 2) {
80*e3723e1fSApple OSS Distributions wired_mem = (mach_vm_size_t)strtoul(argv[2], NULL, 10);
81*e3723e1fSApple OSS Distributions }
82*e3723e1fSApple OSS Distributions
83*e3723e1fSApple OSS Distributions err = allocate_and_wire_memory(wired_mem);
84*e3723e1fSApple OSS Distributions if (err) {
85*e3723e1fSApple OSS Distributions return err;
86*e3723e1fSApple OSS Distributions }
87*e3723e1fSApple OSS Distributions
88*e3723e1fSApple OSS Distributions err = run_additional_threads(nthreads);
89*e3723e1fSApple OSS Distributions if (err) {
90*e3723e1fSApple OSS Distributions return err;
91*e3723e1fSApple OSS Distributions }
92*e3723e1fSApple OSS Distributions
93*e3723e1fSApple OSS Distributions return 0;
94*e3723e1fSApple OSS Distributions }
95