[PATCH i-g-t 5/6] tests/core_hotunplug: Always check device health after late close
Janusz Krzysztofik
janusz.krzysztofik at linux.intel.com
Fri Sep 16 13:42:19 UTC 2022
Subtests hotrebind and hotreplug perform post-operation device healthcheck
while keeping an old instance of the device still open, then, if the
healthcheck succeeds, return without closing that old device instance.
Next, recover() function called from a follow-up igt_fixture section only
closes the old device, without re-checking the device health thereafter.
As a consequence, next tasks may be executed in an insane environment.
Mark the device as requiring a healthcheck before return from those
subtests, and teach recover() to perform additional healthckech after
device close if that mark is set.
Signed-off-by: Janusz Krzysztofik <janusz.krzysztofik at linux.intel.com>
---
tests/core_hotunplug.c | 9 +++++++++
1 file changed, 9 insertions(+)
diff --git a/tests/core_hotunplug.c b/tests/core_hotunplug.c
index 7c7ed09e63..205287f57f 100644
--- a/tests/core_hotunplug.c
+++ b/tests/core_hotunplug.c
@@ -467,6 +467,11 @@ static void recover(struct hotunplug *priv)
{
cleanup(priv);
+ if (priv->need_healthcheck) {
+ igt_ignore_warn(healthcheck(priv, true));
+ priv->need_healthcheck = false;
+ }
+
/* unbind the driver from a possibly hot rebound unhealthy device */
if (!faccessat(priv->fd.sysfs_drv, priv->dev_bus_addr, F_OK, 0) &&
priv->fd.drm == -1 && priv->fd.drm_hc == -1 && priv->failure)
@@ -571,6 +576,8 @@ static void hotrebind(struct hotunplug *priv)
driver_bind(priv, 0);
igt_assert_f(healthcheck(priv, false), "%s\n", priv->failure);
+
+ priv->need_healthcheck = true;
}
static void hotreplug(struct hotunplug *priv)
@@ -584,6 +591,8 @@ static void hotreplug(struct hotunplug *priv)
bus_rescan(priv, 0);
igt_assert_f(healthcheck(priv, false), "%s\n", priv->failure);
+
+ priv->need_healthcheck = true;
}
static void hotrebind_lateclose(struct hotunplug *priv)
--
2.25.1
More information about the Intel-gfx-trybot
mailing list