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