scripts/gdb: add iteration function for rbtree
BugLink: https://bugs.launchpad.net/bugs/2089884
commit 0c77e103c45fa1b119f5d3bb4625eee081c1a6cf upstream.
Add inorder iteration function for rbtree usage.
This is a preparation patch for the next patch to fix the gdb mounts
issue.
Link: https://lkml.kernel.org/r/20240723064902.124154-3-kuan-ying.lee@canonical.com
Fixes: 2eea9ce431 ("mounts: keep list of mounts in an rbtree")
Signed-off-by: Kuan-Ying Lee <kuan-ying.lee@canonical.com>
Cc: Jan Kiszka <jan.kiszka@siemens.com>
Cc: Kieran Bingham <kbingham@kernel.org>
Cc: <stable@vger.kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Koichiro Den <koichiro.den@canonical.com>
Signed-off-by: Roxana Nicolescu <roxana.nicolescu@canonical.com>
This commit is contained in:
committed by
Mehmet Basaran
parent
a60ff1ea60
commit
df050a8fb8
@@ -9,6 +9,18 @@ from linux import utils
|
||||
rb_root_type = utils.CachedType("struct rb_root")
|
||||
rb_node_type = utils.CachedType("struct rb_node")
|
||||
|
||||
def rb_inorder_for_each(root):
|
||||
def inorder(node):
|
||||
if node:
|
||||
yield from inorder(node['rb_left'])
|
||||
yield node
|
||||
yield from inorder(node['rb_right'])
|
||||
|
||||
yield from inorder(root['rb_node'])
|
||||
|
||||
def rb_inorder_for_each_entry(root, gdbtype, member):
|
||||
for node in rb_inorder_for_each(root):
|
||||
yield utils.container_of(node, gdbtype, member)
|
||||
|
||||
def rb_first(root):
|
||||
if root.type == rb_root_type.get_type():
|
||||
|
||||
Reference in New Issue
Block a user