xref: /aosp_15_r20/external/igt-gpu-tools/tests/kms_sysfs_edid_timing.c (revision d83cc019efdc2edc6c4b16e9034a3ceb8d35d77c)
1*d83cc019SAndroid Build Coastguard Worker /*
2*d83cc019SAndroid Build Coastguard Worker  * Copyright © 2016 Intel Corporation
3*d83cc019SAndroid Build Coastguard Worker  *
4*d83cc019SAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a
5*d83cc019SAndroid Build Coastguard Worker  * copy of this software and associated documentation files (the "Software"),
6*d83cc019SAndroid Build Coastguard Worker  * to deal in the Software without restriction, including without limitation
7*d83cc019SAndroid Build Coastguard Worker  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*d83cc019SAndroid Build Coastguard Worker  * and/or sell copies of the Software, and to permit persons to whom the
9*d83cc019SAndroid Build Coastguard Worker  * Software is furnished to do so, subject to the following conditions:
10*d83cc019SAndroid Build Coastguard Worker  *
11*d83cc019SAndroid Build Coastguard Worker  * The above copyright notice and this permission notice (including the next
12*d83cc019SAndroid Build Coastguard Worker  * paragraph) shall be included in all copies or substantial portions of the
13*d83cc019SAndroid Build Coastguard Worker  * Software.
14*d83cc019SAndroid Build Coastguard Worker  *
15*d83cc019SAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*d83cc019SAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*d83cc019SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18*d83cc019SAndroid Build Coastguard Worker  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*d83cc019SAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20*d83cc019SAndroid Build Coastguard Worker  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
21*d83cc019SAndroid Build Coastguard Worker  * IN THE SOFTWARE.
22*d83cc019SAndroid Build Coastguard Worker  */
23*d83cc019SAndroid Build Coastguard Worker #include "igt.h"
24*d83cc019SAndroid Build Coastguard Worker 
25*d83cc019SAndroid Build Coastguard Worker #include <dirent.h>
26*d83cc019SAndroid Build Coastguard Worker #include <fcntl.h>
27*d83cc019SAndroid Build Coastguard Worker #include <sys/stat.h>
28*d83cc019SAndroid Build Coastguard Worker 
29*d83cc019SAndroid Build Coastguard Worker #define THRESHOLD_PER_CONNECTOR	10
30*d83cc019SAndroid Build Coastguard Worker #define THRESHOLD_TOTAL		50
31*d83cc019SAndroid Build Coastguard Worker #define CHECK_TIMES		15
32*d83cc019SAndroid Build Coastguard Worker 
33*d83cc019SAndroid Build Coastguard Worker IGT_TEST_DESCRIPTION("This check the time we take to read the content of all "
34*d83cc019SAndroid Build Coastguard Worker 		     "the possible connectors. Without the edid -ENXIO patch "
35*d83cc019SAndroid Build Coastguard Worker 		     "(http://permalink.gmane.org/gmane.comp.video.dri.devel/62083), "
36*d83cc019SAndroid Build Coastguard Worker 		     "we sometimes take a *really* long time. "
37*d83cc019SAndroid Build Coastguard Worker 		     "So let's just check for some reasonable timing here");
38*d83cc019SAndroid Build Coastguard Worker 
39*d83cc019SAndroid Build Coastguard Worker 
40*d83cc019SAndroid Build Coastguard Worker igt_simple_main
41*d83cc019SAndroid Build Coastguard Worker {
42*d83cc019SAndroid Build Coastguard Worker 	DIR *dirp;
43*d83cc019SAndroid Build Coastguard Worker 	struct dirent *de;
44*d83cc019SAndroid Build Coastguard Worker 
45*d83cc019SAndroid Build Coastguard Worker 	dirp = opendir("/sys/class/drm");
46*d83cc019SAndroid Build Coastguard Worker 	igt_assert(dirp != NULL);
47*d83cc019SAndroid Build Coastguard Worker 
48*d83cc019SAndroid Build Coastguard Worker 	while ((de = readdir(dirp))) {
49*d83cc019SAndroid Build Coastguard Worker 		struct igt_mean mean = {};
50*d83cc019SAndroid Build Coastguard Worker 		struct stat st;
51*d83cc019SAndroid Build Coastguard Worker 		char path[PATH_MAX];
52*d83cc019SAndroid Build Coastguard Worker 		int i;
53*d83cc019SAndroid Build Coastguard Worker 
54*d83cc019SAndroid Build Coastguard Worker 		if (*de->d_name == '.')
55*d83cc019SAndroid Build Coastguard Worker 			continue;;
56*d83cc019SAndroid Build Coastguard Worker 
57*d83cc019SAndroid Build Coastguard Worker 		snprintf(path, sizeof(path), "/sys/class/drm/%s/status",
58*d83cc019SAndroid Build Coastguard Worker 				de->d_name);
59*d83cc019SAndroid Build Coastguard Worker 
60*d83cc019SAndroid Build Coastguard Worker 		if (stat(path, &st))
61*d83cc019SAndroid Build Coastguard Worker 			continue;
62*d83cc019SAndroid Build Coastguard Worker 
63*d83cc019SAndroid Build Coastguard Worker 		igt_mean_init(&mean);
64*d83cc019SAndroid Build Coastguard Worker 		for (i = 0; i < CHECK_TIMES; i++) {
65*d83cc019SAndroid Build Coastguard Worker 			struct timespec ts = {};
66*d83cc019SAndroid Build Coastguard Worker 			int fd;
67*d83cc019SAndroid Build Coastguard Worker 
68*d83cc019SAndroid Build Coastguard Worker 			if ((fd = open(path, O_WRONLY)) < 0)
69*d83cc019SAndroid Build Coastguard Worker 				continue;
70*d83cc019SAndroid Build Coastguard Worker 
71*d83cc019SAndroid Build Coastguard Worker 			igt_nsec_elapsed(&ts);
72*d83cc019SAndroid Build Coastguard Worker 			igt_ignore_warn(write(fd, "detect\n", 7));
73*d83cc019SAndroid Build Coastguard Worker 			igt_mean_add(&mean, igt_nsec_elapsed(&ts));
74*d83cc019SAndroid Build Coastguard Worker 
75*d83cc019SAndroid Build Coastguard Worker 			close(fd);
76*d83cc019SAndroid Build Coastguard Worker 		}
77*d83cc019SAndroid Build Coastguard Worker 
78*d83cc019SAndroid Build Coastguard Worker 		igt_debug("%s: mean.max %.2fns, %.2fus, %.2fms, "
79*d83cc019SAndroid Build Coastguard Worker 			  "mean.avg %.2fns, %.2fus, %.2fms\n",
80*d83cc019SAndroid Build Coastguard Worker 			  de->d_name,
81*d83cc019SAndroid Build Coastguard Worker 			  mean.max, mean.max / 1e3, mean.max / 1e6,
82*d83cc019SAndroid Build Coastguard Worker 			  mean.mean, mean.mean / 1e3, mean.mean / 1e6);
83*d83cc019SAndroid Build Coastguard Worker 
84*d83cc019SAndroid Build Coastguard Worker 		if (mean.max > (THRESHOLD_PER_CONNECTOR * 1e6)) {
85*d83cc019SAndroid Build Coastguard Worker 			igt_warn("%s: probe time exceed 10ms, "
86*d83cc019SAndroid Build Coastguard Worker 				 "max=%.2fms, avg=%.2fms\n", de->d_name,
87*d83cc019SAndroid Build Coastguard Worker 				 mean.max / 1e6, mean.mean / 1e6);
88*d83cc019SAndroid Build Coastguard Worker 		}
89*d83cc019SAndroid Build Coastguard Worker 		igt_assert_f(mean.mean < (THRESHOLD_TOTAL * 1e6),
90*d83cc019SAndroid Build Coastguard Worker 			     "%s: average probe time exceeded 50ms, "
91*d83cc019SAndroid Build Coastguard Worker 			     "max=%.2fms, avg=%.2fms\n", de->d_name,
92*d83cc019SAndroid Build Coastguard Worker 			     mean.max / 1e6, mean.mean / 1e6);
93*d83cc019SAndroid Build Coastguard Worker 
94*d83cc019SAndroid Build Coastguard Worker 	}
95*d83cc019SAndroid Build Coastguard Worker 	closedir(dirp);
96*d83cc019SAndroid Build Coastguard Worker 
97*d83cc019SAndroid Build Coastguard Worker }
98