xref: /xnu-11215.1.10/tests/vm/diag_threshold_test_limit_and_threshold_same.c (revision 8d741a5de7ff4191bf97d57b9f54c2f6d4a15585)
1*8d741a5dSApple OSS Distributions /**
2*8d741a5dSApple OSS Distributions  *  double_limit_test.c
3*8d741a5dSApple OSS Distributions  *  DiagThresholdTest
4*8d741a5dSApple OSS Distributions  *
5*8d741a5dSApple OSS Distributions  * Test the check if reloading a memory diagnostics limit retriggers exceptions
6*8d741a5dSApple OSS Distributions  * Copyright (c) 2022 Apple Inc. All rights reserved.
7*8d741a5dSApple OSS Distributions  */
8*8d741a5dSApple OSS Distributions #include <stdio.h>
9*8d741a5dSApple OSS Distributions #include "vm/diag_threshold_test.h"
10*8d741a5dSApple OSS Distributions #include <sys/kern_memorystatus.h>
11*8d741a5dSApple OSS Distributions #include <darwintest.h>
12*8d741a5dSApple OSS Distributions 
13*8d741a5dSApple OSS Distributions static void diag_threshold_test_limit_and_threshold_same(struct test_case *test_case, void *param);
14*8d741a5dSApple OSS Distributions static test_case_t diag_threshold_test_limit_and_threshold_same_test = {
15*8d741a5dSApple OSS Distributions 	.short_name = "diag_threshold_test_limit_and_threshold_same",
16*8d741a5dSApple OSS Distributions 	.test_name = "Test on which a diag threshold and a limit is set with same value",
17*8d741a5dSApple OSS Distributions 	.test_code = diag_threshold_test_limit_and_threshold_same,
18*8d741a5dSApple OSS Distributions 	.result_already_present = FALSE,
19*8d741a5dSApple OSS Distributions 	.exception_not_expected = FALSE,
20*8d741a5dSApple OSS Distributions 	.exceptions_handled_in_test = TRUE,
21*8d741a5dSApple OSS Distributions };
22*8d741a5dSApple OSS Distributions 
23*8d741a5dSApple OSS Distributions T_GLOBAL_META(
24*8d741a5dSApple OSS Distributions 	T_META_ENABLED(TARGET_OS_IPHONE),
25*8d741a5dSApple OSS Distributions 	T_META_NAMESPACE("xnu.vm.100432442"),
26*8d741a5dSApple OSS Distributions 	T_META_RADAR_COMPONENT_NAME("xnu"),
27*8d741a5dSApple OSS Distributions 	T_META_OWNER("jsolsona"),
28*8d741a5dSApple OSS Distributions 	T_META_RADAR_COMPONENT_VERSION("VM")
29*8d741a5dSApple OSS Distributions 	);
30*8d741a5dSApple OSS Distributions 
31*8d741a5dSApple OSS Distributions /**
32*8d741a5dSApple OSS Distributions  * This function sets a threshold, but is expected to fail, so we cannot use
33*8d741a5dSApple OSS Distributions  * the standard test threshold function
34*8d741a5dSApple OSS Distributions  */
35*8d741a5dSApple OSS Distributions static bool
get_diagthreshold_limits(int * limit_param,boolean_t * status)36*8d741a5dSApple OSS Distributions get_diagthreshold_limits(int *limit_param, boolean_t *status)
37*8d741a5dSApple OSS Distributions {
38*8d741a5dSApple OSS Distributions 	memorystatus_diag_memlimit_properties_t limit;
39*8d741a5dSApple OSS Distributions 	diag_mem_threshold_log_test("Get threshold limit");
40*8d741a5dSApple OSS Distributions 	int pid = getpid();
41*8d741a5dSApple OSS Distributions 	int retValue = memorystatus_control(
42*8d741a5dSApple OSS Distributions 		MEMORYSTATUS_CMD_GET_DIAG_LIMIT,
43*8d741a5dSApple OSS Distributions 		pid,
44*8d741a5dSApple OSS Distributions 		0,
45*8d741a5dSApple OSS Distributions 		&limit, sizeof(limit)
46*8d741a5dSApple OSS Distributions 		);
47*8d741a5dSApple OSS Distributions 	T_ASSERT_MACH_ERROR( retValue, KERN_SUCCESS, "Verification diagnostics threshold limit adjustment");
48*8d741a5dSApple OSS Distributions 	*limit_param = (int)(limit.memlimit);
49*8d741a5dSApple OSS Distributions 	*status = limit.threshold_enabled;
50*8d741a5dSApple OSS Distributions 
51*8d741a5dSApple OSS Distributions 	return (retValue == KERN_SUCCESS) ? false : true;
52*8d741a5dSApple OSS Distributions }
53*8d741a5dSApple OSS Distributions static void
diag_threshold_test_limit_and_threshold_same(struct test_case * test_case,__unused void * param)54*8d741a5dSApple OSS Distributions diag_threshold_test_limit_and_threshold_same(struct test_case *test_case, __unused void *param)
55*8d741a5dSApple OSS Distributions {
56*8d741a5dSApple OSS Distributions 	test_context_t *info = (test_context_t *)param;
57*8d741a5dSApple OSS Distributions 	int limit_param;
58*8d741a5dSApple OSS Distributions 	boolean_t status;
59*8d741a5dSApple OSS Distributions 
60*8d741a5dSApple OSS Distributions 	dispatch_semaphore_signal(info->executor_ready_for_exceptions);
61*8d741a5dSApple OSS Distributions 	diag_mem_set_jetsam_watermark(LOW_JETSAM_LIMIT);
62*8d741a5dSApple OSS Distributions 	diag_mem_set_jetsam_limit(WORKING_LIMIT);
63*8d741a5dSApple OSS Distributions 	bool retValue = set_memory_diagnostics_threshold_limits(WORKING_LIMIT, true);
64*8d741a5dSApple OSS Distributions 	retValue = get_diagthreshold_limits(&limit_param, &status);
65*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(false, status, "Threshold is disabled automatically");
66*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(WORKING_LIMIT, limit_param, "Adjusted threshold is correct");
67*8d741a5dSApple OSS Distributions 
68*8d741a5dSApple OSS Distributions 	retValue = set_memory_diagnostics_threshold_limits(WORKING_LIMIT << 1, true);
69*8d741a5dSApple OSS Distributions 	diag_mem_threshold_log_test("Modifying threshold limit,expecting threshold is automatically enabled");
70*8d741a5dSApple OSS Distributions 	retValue = get_diagthreshold_limits(&limit_param, &status);
71*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(true, status, "Threshold is enabled automatically");
72*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(WORKING_LIMIT << 1, limit_param, "Adjusted threshold is correct");
73*8d741a5dSApple OSS Distributions 
74*8d741a5dSApple OSS Distributions 	retValue = set_memory_diagnostics_threshold_limits(WORKING_LIMIT, true);
75*8d741a5dSApple OSS Distributions 	diag_mem_set_jetsam_watermark(LOW_JETSAM_LIMIT );
76*8d741a5dSApple OSS Distributions 	diag_mem_set_jetsam_limit(WORKING_LIMIT);
77*8d741a5dSApple OSS Distributions 	retValue = get_diagthreshold_limits(&limit_param, &status);
78*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(false, status, "Threshold is disabled automatically");
79*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(WORKING_LIMIT, limit_param, "Adjusted threshold is correct");
80*8d741a5dSApple OSS Distributions 
81*8d741a5dSApple OSS Distributions 	retValue = set_memory_diagnostics_threshold_limits(WORKING_LIMIT << 1, true);
82*8d741a5dSApple OSS Distributions 	diag_mem_threshold_log_test("Modifying threshold limit,expecting threshold is automatically enabled");
83*8d741a5dSApple OSS Distributions 	retValue = get_diagthreshold_limits(&limit_param, &status);
84*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(true, status, "Threshold is enabled automatically");
85*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(WORKING_LIMIT << 1, limit_param, "Adjusted threshold is correct");
86*8d741a5dSApple OSS Distributions 
87*8d741a5dSApple OSS Distributions 
88*8d741a5dSApple OSS Distributions 	diag_mem_set_jetsam_watermark(LOW_JETSAM_LIMIT << 1);
89*8d741a5dSApple OSS Distributions 	diag_mem_set_jetsam_limit(WORKING_LIMIT << 1);
90*8d741a5dSApple OSS Distributions 	diag_mem_threshold_log_test("Modifying jetsam limit,expecting threshold is automatically enabled");
91*8d741a5dSApple OSS Distributions 	retValue = get_diagthreshold_limits(&limit_param, &status);
92*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(false, status, "Threshold is disabled automatically");
93*8d741a5dSApple OSS Distributions 	T_ASSERT_EQ(WORKING_LIMIT << 1, limit_param, "Adjusted threshold is correct");
94*8d741a5dSApple OSS Distributions 	test_case->did_pass = TRUE;
95*8d741a5dSApple OSS Distributions 	test_case->result_already_present = TRUE;
96*8d741a5dSApple OSS Distributions }
97*8d741a5dSApple OSS Distributions 
98*8d741a5dSApple OSS Distributions T_DECL(diag_threshold_test_limit_and_threshold_same,
99*8d741a5dSApple OSS Distributions     "Test on which a diag watermark and a threshold is set with same value",
100*8d741a5dSApple OSS Distributions     T_META_TAG_VM_PREFERRED)
101*8d741a5dSApple OSS Distributions {
102*8d741a5dSApple OSS Distributions 	diag_mem_threshold_set_setup(&diag_threshold_test_limit_and_threshold_same_test);
103*8d741a5dSApple OSS Distributions }
104