On Thu, Dec 19, 2024 at 04:31:16PM -0800, Jakub Kicinski wrote: > Tests using HW stats wait for them to stabilize, using data from > ethtool -c as the delay. Not all drivers implement ethtool -c > so handle the errors gracefully. > > Signed-off-by: Jakub Kicinski <kuba@xxxxxxxxxx> > --- > CC: shuah@xxxxxxxxxx > CC: willemb@xxxxxxxxxx > CC: petrm@xxxxxxxxxx > CC: linux-kselftest@xxxxxxxxxxxxxxx > --- > tools/testing/selftests/drivers/net/lib/py/env.py | 9 +++++++-- > tools/testing/selftests/net/lib/py/utils.py | 6 ++++-- > 2 files changed, 11 insertions(+), 4 deletions(-) > > diff --git a/tools/testing/selftests/drivers/net/lib/py/env.py b/tools/testing/selftests/drivers/net/lib/py/env.py > index 1ea9bb695e94..fea343f209ea 100644 > --- a/tools/testing/selftests/drivers/net/lib/py/env.py > +++ b/tools/testing/selftests/drivers/net/lib/py/env.py > @@ -5,7 +5,7 @@ import time > from pathlib import Path > from lib.py import KsftSkipEx, KsftXfailEx > from lib.py import ksft_setup > -from lib.py import cmd, ethtool, ip > +from lib.py import cmd, ethtool, ip, CmdExitFailure > from lib.py import NetNS, NetdevSimDev > from .remote import Remote > > @@ -234,7 +234,12 @@ from .remote import Remote > Good drivers will tell us via ethtool what their sync period is. > """ > if self._stats_settle_time is None: > - data = ethtool("-c " + self.ifname, json=True)[0] > + data = {} > + try: > + data = ethtool("-c " + self.ifname, json=True)[0] > + except CmdExitFailure as e: > + if "Operation not supported" not in e.cmd.stderr: > + raise How important is this time to the test itself? If it is not available, can the test just default to 50ms and keep going? I would of thought we find more issues by running the test too slowly, than not running it at all, unless having the wrong timer makes it more flaky. Andrew