aboutsummaryrefslogtreecommitdiff
path: root/kernel/ethosu_capabilities.h
diff options
context:
space:
mode:
authorKristofer Jonsson <kristofer.jonsson@arm.com>2023-01-20 13:38:13 +0100
committerKristofer Jonsson <kristofer.jonsson@arm.com>2023-02-02 16:30:39 +0100
commitec47704ab3fd50a9ef8339f33139ddae4caa00b6 (patch)
tree87698ce04f75b460580dfbc637d453dbfc141c37 /kernel/ethosu_capabilities.h
parentd779a08a0f7ca3cdde16941720ddc7af96e74520 (diff)
downloadethos-u-linux-driver-stack-ec47704ab3fd50a9ef8339f33139ddae4caa00b6.tar.gz
Break circulare dependency on struct ethosu_device
The 'struct ethosu_device' has been passed as argument to classes. This creates a circular dependency dependency and it gives all classes full visibility to all resources in the device struct. This patch removes the circular dependency. Using device_lock() and device_unlock() to for synchronization. Change-Id: I8322e6530c72d7bd67f48f411b4f14b612be2706
Diffstat (limited to 'kernel/ethosu_capabilities.h')
-rw-r--r--kernel/ethosu_capabilities.h7
1 files changed, 4 insertions, 3 deletions
diff --git a/kernel/ethosu_capabilities.h b/kernel/ethosu_capabilities.h
index 3a79dc5..30bf475 100644
--- a/kernel/ethosu_capabilities.h
+++ b/kernel/ethosu_capabilities.h
@@ -42,7 +42,7 @@ struct ethosu_uapi_device_capabilities;
* struct ethosu_capabilities - Capabilities internal struct
*/
struct ethosu_capabilities {
- struct ethosu_device *edev;
+ struct device *dev;
struct completion done;
struct ethosu_uapi_device_capabilities *uapi;
struct ethosu_mailbox_msg msg;
@@ -53,10 +53,11 @@ struct ethosu_capabilities {
* Functions
****************************************************************************/
-int ethosu_capabilities_request(struct ethosu_device *edev,
+int ethosu_capabilities_request(struct device *dev,
+ struct ethosu_mailbox *mailbox,
struct ethosu_uapi_device_capabilities *uapi);
-void ethosu_capability_rsp(struct ethosu_device *edev,
+void ethosu_capability_rsp(struct ethosu_mailbox *mailbox,
int msg_id,
struct ethosu_core_msg_capabilities_rsp *rsp);