rcu-cbs.py 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. #!/usr/bin/env drgn
  2. # SPDX-License-Identifier: GPL-2.0+
  3. #
  4. # Dump out the number of RCU callbacks outstanding.
  5. #
  6. # On older kernels having multiple flavors of RCU, this dumps out the
  7. # number of callbacks for the most heavily used flavor.
  8. #
  9. # Usage: sudo drgn rcu-cbs.py
  10. #
  11. # Copyright (C) 2021 Facebook, Inc.
  12. #
  13. # Authors: Paul E. McKenney <[email protected]>
  14. import sys
  15. import drgn
  16. from drgn import NULL, Object
  17. from drgn.helpers.linux import *
  18. def get_rdp0(prog):
  19. try:
  20. rdp0 = prog.variable('rcu_preempt_data', 'kernel/rcu/tree.c');
  21. except LookupError:
  22. rdp0 = NULL;
  23. if rdp0 == NULL:
  24. try:
  25. rdp0 = prog.variable('rcu_sched_data',
  26. 'kernel/rcu/tree.c');
  27. except LookupError:
  28. rdp0 = NULL;
  29. if rdp0 == NULL:
  30. rdp0 = prog.variable('rcu_data', 'kernel/rcu/tree.c');
  31. return rdp0.address_of_();
  32. rdp0 = get_rdp0(prog);
  33. # Sum up RCU callbacks.
  34. sum = 0;
  35. for cpu in for_each_possible_cpu(prog):
  36. rdp = per_cpu_ptr(rdp0, cpu);
  37. len = rdp.cblist.len.value_();
  38. # print("CPU " + str(cpu) + " RCU callbacks: " + str(len));
  39. sum += len;
  40. print("Number of RCU callbacks in flight: " + str(sum));