[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20250106065724.3674510-1-peng.fan@oss.nxp.com>
Date: Mon, 6 Jan 2025 14:57:24 +0800
From: "Peng Fan (OSS)" <peng.fan@....nxp.com>
To: sudeep.holla@....com,
cristian.marussi@....com,
arm-scmi@...r.kernel.org
Cc: linux-arm-kernel@...ts.infradead.org,
linux-kernel@...r.kernel.org,
Peng Fan <peng.fan@....com>
Subject: [RFC] firmware: arm_scmi: Optimize the iteration of scmi_requested_devices
From: Peng Fan <peng.fan@....com>
scmi_requested_devices is organized in IDR based link lists, so only
need to search the link lists when there is a match protocol_id.
Back to search the next id with 'continue' to save cpu cycles, if
protocol_id does not match.
Signed-off-by: Peng Fan <peng.fan@....com>
---
RFC:
Tested on i.MX95.
drivers/firmware/arm_scmi/bus.c | 3 +++
1 file changed, 3 insertions(+)
diff --git a/drivers/firmware/arm_scmi/bus.c b/drivers/firmware/arm_scmi/bus.c
index 157172a5f2b5..42deab5903fb 100644
--- a/drivers/firmware/arm_scmi/bus.c
+++ b/drivers/firmware/arm_scmi/bus.c
@@ -79,6 +79,8 @@ static int scmi_protocol_device_request(const struct scmi_device_id *id_table)
if (rdev->id_table->protocol_id ==
id_table->protocol_id)
phead = head;
+ else
+ continue;
}
list_for_each_entry(rdev, head, node) {
if (!strcmp(rdev->id_table->name, id_table->name)) {
@@ -89,6 +91,7 @@ static int scmi_protocol_device_request(const struct scmi_device_id *id_table)
goto out;
}
}
+ break;
}
/*
--
2.37.1
Powered by blists - more mailing lists