Blame SOURCES/iotop-0.6-gitab35334d.patch

199af3
diff -up iotop-0.6/iotop/data.py.gitab35334d iotop-0.6/iotop/data.py
199af3
--- iotop-0.6/iotop/data.py.gitab35334d	2022-02-15 21:51:20.828263067 +0100
199af3
+++ iotop-0.6/iotop/data.py	2022-02-15 21:51:20.830263041 +0100
199af3
@@ -453,3 +453,11 @@ class ProcessList(DumpableObject):
199af3
 
199af3
     def clear(self):
199af3
         self.processes = {}
199af3
+
199af3
+
199af3
+def sysctl_task_delayacct():
199af3
+    try:
199af3
+        with open('/proc/sys/kernel/task_delayacct') as f:
199af3
+            return bool(int(f.read().strip()))
199af3
+    except FileNotFoundError:
199af3
+        return None
199af3
diff -up iotop-0.6/iotop/ui.py.gitab35334d iotop-0.6/iotop/ui.py
199af3
--- iotop-0.6/iotop/ui.py.gitab35334d	2022-02-15 21:51:20.828263067 +0100
199af3
+++ iotop-0.6/iotop/ui.py	2022-02-15 21:51:56.415788740 +0100
199af3
@@ -30,7 +30,7 @@ import signal
199af3
 import sys
199af3
 import time
199af3
 
199af3
-from iotop.data import find_uids, TaskStatsNetlink, ProcessList, Stats
199af3
+from iotop.data import find_uids, TaskStatsNetlink, ProcessList, Stats, sysctl_task_delayacct
199af3
 from iotop.data import ThreadInfo
199af3
 from iotop.version import VERSION
199af3
 from iotop import ioprio
199af3
@@ -377,7 +377,7 @@ class IOTopUI(object):
199af3
         def format(p):
199af3
             stats = format_stats(self.options, p, self.process_list.duration)
199af3
             io_delay, swapin_delay, read_bytes, write_bytes = stats
199af3
-            if Stats.has_blkio_delay_total:
199af3
+            if self.has_swapin_io:
199af3
                 delay_stats = '%7s %7s ' % (swapin_delay, io_delay)
199af3
             else:
199af3
                 delay_stats = ' ?unavailable?  '
199af3
@@ -431,6 +431,14 @@ class IOTopUI(object):
199af3
             pid += 'TID'
199af3
         titles = [pid, '  PRIO', '  USER', '     DISK READ', '  DISK WRITE',
199af3
                   '  SWAPIN', '      IO', '    COMMAND']
199af3
+        self.has_swapin_io = Stats.has_blkio_delay_total
199af3
+        if self.has_swapin_io:
199af3
+            # Linux kernels without the sysctl return None and
199af3
+            # iotop just uses the heuristic for those versions.
199af3
+            # Linux kernels with the sysctl return True or False
199af3
+            # and iotop then uses the sysctl value instead.
199af3
+            if sysctl_task_delayacct() == False:
199af3
+                self.has_swapin_io = False
199af3
         lines = self.get_data()
199af3
         if self.options.time:
199af3
             titles = ['    TIME'] + titles
199af3
@@ -464,7 +472,7 @@ class IOTopUI(object):
199af3
                 title = title[:remaining_cols]
199af3
                 remaining_cols -= len(title)
199af3
                 self.win.addstr(title, attr)
199af3
-            if Stats.has_blkio_delay_total:
199af3
+            if self.has_swapin_io:
199af3
                 status_msg = None
199af3
             else:
199af3
                 status_msg = ('CONFIG_TASK_DELAY_ACCT '