summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorArkadiusz Hiler <arkadiusz.hiler@intel.com>2020-05-06 16:48:45 +0300
committerArkadiusz Hiler <arkadiusz.hiler@intel.com>2020-05-11 15:56:20 +0300
commit31657c63bcc0c7f0d3eb9d8c03a39b7987c60d7d (patch)
treebcd2d7297fb18e3be96f6daff02bf61b80bfbe60 /lib
parent609572dd1d3bd91bb035f7742ab705aa9136b639 (diff)
lib/igt_chamelium: Sleep when doing autodiscovery
Autodiscovery was wrongly assuming that whenever we do chamelium_plug() the connector state change is immediate. It was working most of the time for native connectors, but may explain some of the flip-flopping skips. The problem got only more serious with the advent of LSPcons as USB-C, where we have much things happening on the signal path, introducing delays. So for the sake of reliability this change introduces sleep(10) between plug and reprobe. The number is about 2 * the_most_pathological_case_observed. Also the discovery step is performed only if there is no static port mapping set up. After the discovery is done, IGT prints the mapping ready to be pasted into .igtrc. Cc: Kunal Joshi <kunal1.joshi@intel.com> Cc: Imre Deak <imre.deak@intel.com> Cc: Maarten Lankhorst <maarten.lankhorst@linux.intel.com> Signed-off-by: Arkadiusz Hiler <arkadiusz.hiler@intel.com> Reviewed-by: Imre Deak <imre.deak@intel.com>
Diffstat (limited to 'lib')
-rw-r--r--lib/igt_chamelium.c28
1 files changed, 26 insertions, 2 deletions
diff --git a/lib/igt_chamelium.c b/lib/igt_chamelium.c
index c704b84f..28be5248 100644
--- a/lib/igt_chamelium.c
+++ b/lib/igt_chamelium.c
@@ -82,6 +82,14 @@
*
*/
+/*
+ * We cannot expect chamelium_plug() to take effect imediately.
+ *
+ * Especially with modern, more complex hardware where we may have LSPcons and
+ * USB controllers in the way.
+ */
+#define CHAMELIUM_HOTPLUG_DETECTION_DELAY 10
+
struct chamelium_edid {
struct chamelium *chamelium;
struct edid *base;
@@ -2231,6 +2239,10 @@ static bool chamelium_autodiscover(struct chamelium *chamelium, int drm_fd)
chamelium_plug(chamelium, port);
}
+ igt_info("Sleeping %d seconds for the hotplug to take effect.\n",
+ CHAMELIUM_HOTPLUG_DETECTION_DELAY);
+ sleep(CHAMELIUM_HOTPLUG_DETECTION_DELAY);
+
/* Reprobe connectors and build the mapping */
res = drmModeGetResources(drm_fd);
if (!res)
@@ -2448,8 +2460,20 @@ struct chamelium *chamelium_init(int drm_fd)
if (!chamelium_read_port_mappings(chamelium, drm_fd))
goto error;
- if (!chamelium_autodiscover(chamelium, drm_fd))
- goto error;
+ if (chamelium->port_count == 0) {
+ igt_info("Chamelium configured without port mapping, "
+ "performing autodiscovery\n");
+
+ if (!chamelium_autodiscover(chamelium, drm_fd))
+ goto error;
+
+ if (chamelium->port_count != 0)
+ igt_info("\nConsider adding the following to your .igtrc:\n");
+ for (int i = 0; i < chamelium->port_count; ++i) {
+ igt_info("[Chamelium:%s]\n", chamelium->ports[i].name);
+ igt_info("ChameliumPortID=%d\n\n", chamelium->ports[i].id);
+ }
+ }
cleanup_instance = chamelium;
igt_install_exit_handler(chamelium_exit_handler);