@@ -245,6 +245,7 @@ TESTS_progs = \
perf \
debugfs \
tools \
+ ddx_intel_after_fbdev \
$(NULL)
# IMPORTANT: The ZZ_ tests need to be run last!
deleted file mode 100755
@@ -1,73 +0,0 @@
-#!/bin/bash
-#
-# Testcase: Load Intel DDX after fbdev was loaded
-#
-
-whoami | grep -q root || {
- echo "ERROR: not running as root"
- exit 1
-}
-
-# no other X session should be running
-find /tmp/ -name .X*lock 2>/dev/null | grep -q X && {
- echo "ERROR: X session already running"
- exit 1
-}
-
-TMPDIR=$(mktemp -d /tmp/igt.XXXX) || {
- echo "ERROR: Failed to create temp dir"
- exit 1
-}
-
-cat > $TMPDIR/xorg.conf.fbdev << EOF
-Section "Device"
- Driver "fbdev"
- Identifier "Device[fbdev]"
-EndSection
-EOF
-
-cat > $TMPDIR/xorg.conf.intel << EOF
-Section "Device"
- Driver "intel"
- Identifier "Device[intel]"
-EndSection
-EOF
-
-# log before fbdev
-dmesg -c > $TMPDIR/dmesg.1.before.fbdev
-cp /var/log/Xorg.0.log $TMPDIR/Xorg.0.log.1.before.fbdev
-
-# run fbdev
-xinit -- /usr/bin/X -config $TMPDIR/xorg.conf.fbdev &
-sleep 5
-if [ -f `which intel_reg` ]; then
-`which intel_reg` dump > $TMPDIR/intel_reg_dump.1.fbdev
-fi
-killall X
-
-# log after fbdev & before intel
-dmesg -c > $TMPDIR/dmesg.2.after.fbdev.before.intel
-cp /var/log/Xorg.0.log $TMPDIR/Xorg.0.log.2.after.fbdev.before.intel
-
-sleep 5
-
-# run intel
-xinit -- /usr/bin/X -config $TMPDIR/xorg.conf.intel &
-sleep 5
-if [ -f `which intel_reg` ]; then
-`which intel_reg` dump > $TMPDIR/intel_reg_dump.2.intel
-fi
-killall X
-
-# log after intel
-dmesg -c > $TMPDIR/dmesg.3.after.intel
-cp /var/log/Xorg.0.log $TMPDIR/Xorg.0.log.3.after.intel
-
-cp $0 $TMPDIR/
-
-tar czf $TMPDIR.tar.gz $TMPDIR/*
-if [ -f $TMPDIR.tar.gz ]; then
- echo $TMPDIR.tar.gz contains this script, all configs and logs generated on this tests
-fi
-
-exit 0
new file mode 100644
@@ -0,0 +1,113 @@
+/*
+ * Copyright © 2017 Intel Corporation
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice (including the next
+ * paragraph) shall be included in all copies or substantial portions of the
+ * Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+ * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
+ * IN THE SOFTWARE.
+ */
+#ifdef HAVE_CONFIG_H
+#include "config.h"
+#endif
+#include "igt.h"
+#include <unistd.h>
+#include <sys/types.h>
+
+int main(int argc, char **argv)
+{
+ int status;
+ FILE *file;
+ char *path;
+ const char xorg_fbdev[] =
+ "Section \"Device\"\n"
+ " Driver \"fbdev\"\n"
+ " Identifier \"Device[fbdev]\"\n"
+ "EndSection\n";
+ const char xorg_intel[] =
+ "Section \"Device\"\n"
+ " Driver \"intel\"\n"
+ " Identifier \"Device[intel]\"\n"
+ "EndSection\n";
+ char *tmpdir = strdup("/tmp/igt.XXXXXX");
+
+ igt_skip_on_simulation();
+
+ igt_assert_f(getuid() == 0, "ERROR: not running as root\n");
+
+ igt_assert_f(igt_exec_quiet("find /tmp/ -name .X*lock | grep -q X")
+ != IGT_EXIT_SUCCESS,
+ "ERROR: X session already running\n");
+
+ igt_assert_f(mkdtemp(tmpdir) != NULL,
+ "ERROR: Failed to create temp dir\n");
+
+ /* config files */
+ igt_assert(asprintf(&path, "%s/xorg.conf.fbdev", tmpdir) != -1);
+ igt_assert((file = fopen(path, "w")) != NULL);
+ fwrite(xorg_fbdev, 1, sizeof(xorg_fbdev), file);
+ free(path);
+ fclose(file);
+
+ igt_assert(asprintf(&path, "%s/xorg.conf.intel", tmpdir) != -1);
+ igt_assert((file = fopen(path, "w")) != NULL);
+ fwrite(xorg_intel, 1, sizeof(xorg_intel), file);
+ free(path);
+ fclose(file);
+
+ /* log before fbdev */
+ igt_exec_cmd(status, "dmesg -c > %s/dmesg.1.before.fbdev", tmpdir);
+ igt_exec_cmd(status, "cp /var/log/Xorg.0.log "
+ "%s/Xorg.0.log.1.before.fbdev", tmpdir);
+
+ /* run fbdev */
+ igt_exec_cmd(status, "xinit -- /usr/bin/X -config "
+ "%s/xorg.conf.fbdev &", tmpdir);
+ sleep(5);
+ igt_exec_cmd(status, "../tools/intel_reg dump > "
+ "%s/intel_reg_dump.1.fbdev", tmpdir);
+ igt_exec_quiet("killall -r X");
+
+ /* log after fbdev & before intel */
+ igt_exec_cmd(status, "dmesg -c > %s/dmesg.2.after.fbdev.before.intel",
+ tmpdir);
+ igt_exec_cmd(status, "cp /var/log/Xorg.0.log "
+ "%s/Xorg.0.log.2.after.fbdev.before.intel", tmpdir);
+ sleep(5);
+
+ /* run intel */
+ igt_exec_cmd(status, "xinit -- /usr/bin/X -config "
+ "%s/xorg.conf.intel &", tmpdir);
+ sleep(5);
+ igt_exec_quiet("killall -r X");
+ sleep(1);
+ igt_exec_cmd(status, "../tools/intel_reg dump > "
+ "%s/intel_reg_dump.2.intel", tmpdir);
+
+ /* log after intel */
+ igt_exec_cmd(status, "dmesg -c > %s/dmesg.3.after.intel", tmpdir);
+ igt_exec_cmd(status, "cp /var/log/Xorg.0.log %s/Xorg.0.log.3.after.intel",
+ tmpdir);
+
+ igt_exec_cmd(status, "tar czf %s.tar.gz %s/*", tmpdir, tmpdir);
+ if (status == IGT_EXIT_SUCCESS) {
+ igt_info("%s.tar.gz contains this script, all configs "
+ "and logs generated on this tests\n", tmpdir);
+ }
+ free(tmpdir);
+
+ igt_exit();
+}
v2: Use igt_exec_cmd macro. Signed-off-by: Abdiel Janulgue <abdiel.janulgue@linux.intel.com> --- tests/Makefile.sources | 1 + tests/ddx_intel_after_fbdev | 73 --------------------------- tests/ddx_intel_after_fbdev.c | 113 ++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 114 insertions(+), 73 deletions(-) delete mode 100755 tests/ddx_intel_after_fbdev create mode 100644 tests/ddx_intel_after_fbdev.c