diff options
author | Thierry Reding <treding@nvidia.com> | 2015-12-09 18:37:48 +0100 |
---|---|---|
committer | Emil Velikov <emil.l.velikov@gmail.com> | 2015-12-18 17:44:22 +0000 |
commit | b020b02f841af6c04d97d484db0ecf1149b93abf (patch) | |
tree | 5fbaf520ac2e243c8c4ac6dbf3e116d4b16f5274 | |
parent | 6223481b8de901b5356afdef538726f1fb77bfd1 (diff) |
vbltest: Use util_open()
Use the new util_open() helper instead of open-coding the method for
finding a usable device. While at it, this adds -D and -M command-line
options to vbltest to make its usage more consistent with its siblings
modetest and proptest.
Signed-off-by: Thierry Reding <treding@nvidia.com>
Reviewed-by: Emil Velikov <emil.l.velikov@gmail.com>
-rw-r--r-- | tests/vbltest/Makefile.am | 3 | ||||
-rw-r--r-- | tests/vbltest/vbltest.c | 38 |
2 files changed, 20 insertions, 21 deletions
diff --git a/tests/vbltest/Makefile.am b/tests/vbltest/Makefile.am index 182e3b6d..276afad5 100644 --- a/tests/vbltest/Makefile.am +++ b/tests/vbltest/Makefile.am @@ -15,4 +15,5 @@ endif vbltest_SOURCES = \ vbltest.c vbltest_LDADD = \ - $(top_builddir)/libdrm.la + $(top_builddir)/libdrm.la \ + $(top_builddir)/tests/util/libutil.la diff --git a/tests/vbltest/vbltest.c b/tests/vbltest/vbltest.c index de93e770..60badf11 100644 --- a/tests/vbltest/vbltest.c +++ b/tests/vbltest/vbltest.c @@ -55,10 +55,11 @@ #include "xf86drmMode.h" #include "util/common.h" +#include "util/kms.h" extern char *optarg; extern int optind, opterr, optopt; -static char optstr[] = "s"; +static char optstr[] = "D:M:s"; int secondary = 0; @@ -97,16 +98,19 @@ static void vblank_handler(int fd, unsigned int frame, unsigned int sec, static void usage(char *name) { - fprintf(stderr, "usage: %s [-s]\n", name); - fprintf(stderr, "\t-s\tuse secondary pipe\n"); + fprintf(stderr, "usage: %s [-DMs]\n", name); + fprintf(stderr, "\n"); + fprintf(stderr, "options:\n"); + fprintf(stderr, " -D DEVICE open the given device\n"); + fprintf(stderr, " -M MODULE open the given module\n"); + fprintf(stderr, " -s use secondary pipe\n"); exit(0); } int main(int argc, char **argv) { - unsigned i; + const char *device = NULL, *module = NULL; int c, fd, ret; - const char *modules[] = { "i915", "radeon", "nouveau", "vmwgfx", "exynos", "omapdrm", "tilcdc", "msm", "tegra", "imx-drm" , "rockchip" }; drmVBlank vbl; drmEventContext evctx; struct vbl_info handler_info; @@ -114,6 +118,12 @@ int main(int argc, char **argv) opterr = 0; while ((c = getopt(argc, argv, optstr)) != -1) { switch (c) { + case 'D': + device = optarg; + break; + case 'M': + module = optarg; + break; case 's': secondary = 1; break; @@ -123,21 +133,9 @@ int main(int argc, char **argv) } } - for (i = 0; i < ARRAY_SIZE(modules); i++) { - printf("trying to load module %s...", modules[i]); - fd = drmOpen(modules[i], NULL); - if (fd < 0) { - printf("failed.\n"); - } else { - printf("success.\n"); - break; - } - } - - if (i == ARRAY_SIZE(modules)) { - fprintf(stderr, "failed to load any modules, aborting.\n"); - return -1; - } + fd = util_open(module, device); + if (fd < 0) + return 1; /* Get current count first */ vbl.request.type = DRM_VBLANK_RELATIVE; |