1 /* SPDX-License-Identifier: GPL-2.0-or-later */
3 * CCI cache coherent interconnect support
5 * Copyright (C) 2013 ARM Ltd.
8 #ifndef __LINUX_ARM_CCI_H
9 #define __LINUX_ARM_CCI_H
11 #include <linux/errno.h>
12 #include <linux/types.h>
14 #include <asm/arm-cci.h>
19 extern bool cci_probed(void);
21 static inline bool cci_probed(void) { return false; }
24 #ifdef CONFIG_ARM_CCI400_PORT_CTRL
25 extern int cci_ace_get_port(struct device_node
*dn
);
26 extern int cci_disable_port_by_cpu(u64 mpidr
);
27 extern int __cci_control_port_by_device(struct device_node
*dn
, bool enable
);
28 extern int __cci_control_port_by_index(u32 port
, bool enable
);
30 static inline int cci_ace_get_port(struct device_node
*dn
)
34 static inline int cci_disable_port_by_cpu(u64 mpidr
) { return -ENODEV
; }
35 static inline int __cci_control_port_by_device(struct device_node
*dn
,
40 static inline int __cci_control_port_by_index(u32 port
, bool enable
)
46 void cci_enable_port_for_self(void);
48 #define cci_disable_port_by_device(dev) \
49 __cci_control_port_by_device(dev, false)
50 #define cci_enable_port_by_device(dev) \
51 __cci_control_port_by_device(dev, true)
52 #define cci_disable_port_by_index(dev) \
53 __cci_control_port_by_index(dev, false)
54 #define cci_enable_port_by_index(dev) \
55 __cci_control_port_by_index(dev, true)