xref: /xnu-10002.81.5/tests/vm_memory_tests_src/server.c (revision 5e3eaea39dcf651e66cb99ba7d70e32cc4a99587)
1*5e3eaea3SApple OSS Distributions #include "mach_vm_tests.h"
2*5e3eaea3SApple OSS Distributions boolean_t debug = TRUE;
3*5e3eaea3SApple OSS Distributions 
4*5e3eaea3SApple OSS Distributions int
main()5*5e3eaea3SApple OSS Distributions main()
6*5e3eaea3SApple OSS Distributions {
7*5e3eaea3SApple OSS Distributions 	dispatch_source_t parentSource = dispatch_source_create(DISPATCH_SOURCE_TYPE_PROC, (uintptr_t)getppid(), DISPATCH_PROC_EXIT, NULL);
8*5e3eaea3SApple OSS Distributions 	dispatch_source_set_event_handler(parentSource, ^{
9*5e3eaea3SApple OSS Distributions 		T_LOG("Event handler got invoked. Parent process died. Exiting");
10*5e3eaea3SApple OSS Distributions 		exit(1);
11*5e3eaea3SApple OSS Distributions 	});
12*5e3eaea3SApple OSS Distributions 	dispatch_activate(parentSource);
13*5e3eaea3SApple OSS Distributions 
14*5e3eaea3SApple OSS Distributions 	const char *serviceName = MACH_VM_TEST_SERVICE_NAME;
15*5e3eaea3SApple OSS Distributions 
16*5e3eaea3SApple OSS Distributions 	kern_return_t ret;
17*5e3eaea3SApple OSS Distributions 	mach_port_t bootstrap;
18*5e3eaea3SApple OSS Distributions 	task_get_bootstrap_port(mach_task_self(), &bootstrap);
19*5e3eaea3SApple OSS Distributions 
20*5e3eaea3SApple OSS Distributions 	mach_port_t port;
21*5e3eaea3SApple OSS Distributions 	mach_port_allocate(mach_task_self(), MACH_PORT_RIGHT_RECEIVE, &port);
22*5e3eaea3SApple OSS Distributions 
23*5e3eaea3SApple OSS Distributions #pragma clang diagnostic push
24*5e3eaea3SApple OSS Distributions #pragma clang diagnostic ignored "-Wdeprecated"
25*5e3eaea3SApple OSS Distributions 	ret = bootstrap_register2(bootstrap, (char *)serviceName, port, BOOTSTRAP_ALLOW_LOOKUP);
26*5e3eaea3SApple OSS Distributions #pragma clang diagnostic pop
27*5e3eaea3SApple OSS Distributions 
28*5e3eaea3SApple OSS Distributions 	mach_msg_size_t messageSize = sizeof(ipc_message_t) + sizeof(mach_msg_trailer_t) + 64;
29*5e3eaea3SApple OSS Distributions 	ipc_message_t *message = (ipc_message_t *)calloc(1, messageSize);
30*5e3eaea3SApple OSS Distributions 
31*5e3eaea3SApple OSS Distributions 	message->header.msgh_bits = MACH_MSGH_BITS_ZERO;
32*5e3eaea3SApple OSS Distributions 	message->header.msgh_size = messageSize;
33*5e3eaea3SApple OSS Distributions 	message->header.msgh_remote_port = MACH_PORT_NULL;
34*5e3eaea3SApple OSS Distributions 	message->header.msgh_local_port = port;
35*5e3eaea3SApple OSS Distributions 
36*5e3eaea3SApple OSS Distributions 	ret = mach_msg(&message->header, MACH_RCV_MSG, 0, messageSize, port, MACH_MSG_TIMEOUT_NONE, MACH_PORT_NULL);
37*5e3eaea3SApple OSS Distributions 	if (ret == KERN_SUCCESS) {
38*5e3eaea3SApple OSS Distributions 		if (MACH_MSGH_BITS_REMOTE(message->header.msgh_bits) == MACH_MSG_TYPE_PORT_SEND) {
39*5e3eaea3SApple OSS Distributions 			persistentReplyPort = message->header.msgh_remote_port;
40*5e3eaea3SApple OSS Distributions 			mach_port_mod_refs(mach_task_self(), persistentReplyPort, MACH_PORT_RIGHT_SEND, 1);
41*5e3eaea3SApple OSS Distributions 		}
42*5e3eaea3SApple OSS Distributions 	}
43*5e3eaea3SApple OSS Distributions 
44*5e3eaea3SApple OSS Distributions 	mach_server_make_memory_entry(port);
45*5e3eaea3SApple OSS Distributions 	mach_server_remap(port);
46*5e3eaea3SApple OSS Distributions 	mach_server_read(port, VM_OP_READ);
47*5e3eaea3SApple OSS Distributions 	//mach_server_read(port, VM_OP_WRITE);
48*5e3eaea3SApple OSS Distributions 	mach_server_read(port, VM_OP_READ_OVERWRITE);
49*5e3eaea3SApple OSS Distributions 
50*5e3eaea3SApple OSS Distributions 
51*5e3eaea3SApple OSS Distributions 	message->header.msgh_bits = MACH_MSGH_BITS_ZERO;
52*5e3eaea3SApple OSS Distributions 	message->header.msgh_size = messageSize;
53*5e3eaea3SApple OSS Distributions 	message->header.msgh_remote_port = MACH_PORT_NULL;
54*5e3eaea3SApple OSS Distributions 	message->header.msgh_local_port = port;
55*5e3eaea3SApple OSS Distributions 
56*5e3eaea3SApple OSS Distributions 	mach_server_construct_header(message, port);
57*5e3eaea3SApple OSS Distributions 	message->vm_op = VM_OP_EXIT;
58*5e3eaea3SApple OSS Distributions 	ret = mach_msg(&message->header, MACH_SEND_MSG, message->header.msgh_size, 0, MACH_PORT_NULL, MACH_MSG_TIMEOUT_NONE, MACH_PORT_NULL);
59*5e3eaea3SApple OSS Distributions 	if (ret != KERN_SUCCESS) {
60*5e3eaea3SApple OSS Distributions 		T_LOG("ERROR: Failed to send message to client: (%d) %s\n", ret, mach_error_string(ret));
61*5e3eaea3SApple OSS Distributions 		return 1;
62*5e3eaea3SApple OSS Distributions 	}
63*5e3eaea3SApple OSS Distributions 
64*5e3eaea3SApple OSS Distributions 	(void)parentSource;
65*5e3eaea3SApple OSS Distributions 
66*5e3eaea3SApple OSS Distributions 	return 0;
67*5e3eaea3SApple OSS Distributions }
68