1d1e9710bSLeonard Crestez# SPDX-License-Identifier: GPL-2.0 2d1e9710bSLeonard Crestez# 3d1e9710bSLeonard Crestez# Copyright (c) NXP 2019 4d1e9710bSLeonard Crestez 5d1e9710bSLeonard Crestezimport gdb 6d1e9710bSLeonard Crestezimport sys 7d1e9710bSLeonard Crestez 8e7e6f462SLeonard Crestezfrom linux import utils, lists, constants 9d1e9710bSLeonard Crestez 10d1e9710bSLeonard Crestezclk_core_type = utils.CachedType("struct clk_core") 11d1e9710bSLeonard Crestez 12d1e9710bSLeonard Crestez 13d1e9710bSLeonard Crestezdef clk_core_for_each_child(hlist_head): 14d1e9710bSLeonard Crestez return lists.hlist_for_each_entry(hlist_head, 15d1e9710bSLeonard Crestez clk_core_type.get_type().pointer(), "child_node") 16d1e9710bSLeonard Crestez 17d1e9710bSLeonard Crestez 18d1e9710bSLeonard Crestezclass LxClkSummary(gdb.Command): 19e7e6f462SLeonard Crestez """Print clk tree summary 20e7e6f462SLeonard Crestez 21e7e6f462SLeonard CrestezOutput is a subset of /sys/kernel/debug/clk/clk_summary 22e7e6f462SLeonard Crestez 23e7e6f462SLeonard CrestezNo calls are made during printing, instead a (c) if printed after values which 24e7e6f462SLeonard Crestezare cached and potentially out of date""" 25d1e9710bSLeonard Crestez 26d1e9710bSLeonard Crestez def __init__(self): 27d1e9710bSLeonard Crestez super(LxClkSummary, self).__init__("lx-clk-summary", gdb.COMMAND_DATA) 28d1e9710bSLeonard Crestez 29d1e9710bSLeonard Crestez def show_subtree(self, clk, level): 30e7e6f462SLeonard Crestez gdb.write("%*s%-*s %7d %8d %8d %11lu%s\n" % ( 31d1e9710bSLeonard Crestez level * 3 + 1, "", 32d1e9710bSLeonard Crestez 30 - level * 3, 33d1e9710bSLeonard Crestez clk['name'].string(), 34d1e9710bSLeonard Crestez clk['enable_count'], 35d1e9710bSLeonard Crestez clk['prepare_count'], 36e7e6f462SLeonard Crestez clk['protect_count'], 37e7e6f462SLeonard Crestez clk['rate'], 38e7e6f462SLeonard Crestez '(c)' if clk['flags'] & constants.LX_CLK_GET_RATE_NOCACHE else ' ')) 39d1e9710bSLeonard Crestez 40d1e9710bSLeonard Crestez for child in clk_core_for_each_child(clk['children']): 41d1e9710bSLeonard Crestez self.show_subtree(child, level + 1) 42d1e9710bSLeonard Crestez 43d1e9710bSLeonard Crestez def invoke(self, arg, from_tty): 44*1d7adbc7SFlorian Fainelli if utils.gdb_eval_or_none("clk_root_list") is None: 45*1d7adbc7SFlorian Fainelli raise gdb.GdbError("No clocks registered") 46d1e9710bSLeonard Crestez gdb.write(" enable prepare protect \n") 47e7e6f462SLeonard Crestez gdb.write(" clock count count count rate \n") 48e7e6f462SLeonard Crestez gdb.write("------------------------------------------------------------------------\n") 49d1e9710bSLeonard Crestez for clk in clk_core_for_each_child(gdb.parse_and_eval("clk_root_list")): 50d1e9710bSLeonard Crestez self.show_subtree(clk, 0) 51d1e9710bSLeonard Crestez for clk in clk_core_for_each_child(gdb.parse_and_eval("clk_orphan_list")): 52d1e9710bSLeonard Crestez self.show_subtree(clk, 0) 53d1e9710bSLeonard Crestez 54d1e9710bSLeonard Crestez 55d1e9710bSLeonard CrestezLxClkSummary() 56988b2686SLeonard Crestez 57988b2686SLeonard Crestez 58988b2686SLeonard Crestezclass LxClkCoreLookup(gdb.Function): 59988b2686SLeonard Crestez """Find struct clk_core by name""" 60988b2686SLeonard Crestez 61988b2686SLeonard Crestez def __init__(self): 62988b2686SLeonard Crestez super(LxClkCoreLookup, self).__init__("lx_clk_core_lookup") 63988b2686SLeonard Crestez 64988b2686SLeonard Crestez def lookup_hlist(self, hlist_head, name): 65988b2686SLeonard Crestez for child in clk_core_for_each_child(hlist_head): 66988b2686SLeonard Crestez if child['name'].string() == name: 67988b2686SLeonard Crestez return child 68988b2686SLeonard Crestez result = self.lookup_hlist(child['children'], name) 69988b2686SLeonard Crestez if result: 70988b2686SLeonard Crestez return result 71988b2686SLeonard Crestez 72988b2686SLeonard Crestez def invoke(self, name): 73988b2686SLeonard Crestez name = name.string() 74988b2686SLeonard Crestez return (self.lookup_hlist(gdb.parse_and_eval("clk_root_list"), name) or 75988b2686SLeonard Crestez self.lookup_hlist(gdb.parse_and_eval("clk_orphan_list"), name)) 76988b2686SLeonard Crestez 77988b2686SLeonard Crestez 78988b2686SLeonard CrestezLxClkCoreLookup() 79