aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/tools/perf/scripts/python/event_analyzing_sample.py
diff options
context:
space:
mode:
authorSascha Hauer <s.hauer@pengutronix.de>2025-06-12 14:56:57 +0200
committerStephen Boyd <sboyd@kernel.org>2025-06-19 17:30:02 -0700
commit6306e0c5a0d28e9df2b5902f4a021204bee75173 (patch)
treebed4baa1816982f5a56b9521bde23f0080e328cb /tools/perf/scripts/python/event_analyzing_sample.py
parentLinux 6.16-rc1 (diff)
downloadwireguard-linux-6306e0c5a0d28e9df2b5902f4a021204bee75173.tar.xz
wireguard-linux-6306e0c5a0d28e9df2b5902f4a021204bee75173.zip
clk: scmi: Handle case where child clocks are initialized before their parents
The SCMI clock driver currently assumes that parent clocks are always initialized before their children. However, this assumption can fail if a child clock is encountered before its parent during probe. This leads to an issue during initialization of the parent_data array: sclk->parent_data[i].hw = hws[sclk->info->parents[i]]; If the parent clock's hardware structure has not been initialized yet, this assignment results in invalid data. To resolve this, allocate all struct scmi_clk instances as a contiguous array at the beginning of the probe and populate the hws[] array upfront. This ensures that any parent referenced later is already initialized, regardless of the order in which clocks are processed. Note that we can no longer free individual scmi_clk instances if scmi_clk_ops_init() fails which shouldn't be a problem if the SCMI platform has proper per-agent clock discovery. Fixes: 65a8a3dd3b95f ("clk: scmi: Add support for clock {set,get}_parent") Reviewed-by: peng.fan@nxp.com Reviewed-by: Cristian Marussi <cristian.marussi@arm.com> Reviewed-by: Sudeep Holla <sudeep.holla@arm.com> Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de> Link: https://lore.kernel.org/r/20250612-clk-scmi-children-parent-fix-v3-1-7de52a27593d@pengutronix.de Signed-off-by: Stephen Boyd <sboyd@kernel.org>
Diffstat (limited to 'tools/perf/scripts/python/event_analyzing_sample.py')
0 files changed, 0 insertions, 0 deletions