blob: d0e44201d855b0cbaf181b960737adf630fb78f7 [file] [log] [blame]
Thomas Gleixner1a59d1b82019-05-27 08:55:05 +02001/* SPDX-License-Identifier: GPL-2.0-or-later */
Lorenzo Pieralisied69bdd2012-07-13 15:55:52 +01002/*
3 * CCI cache coherent interconnect support
4 *
5 * Copyright (C) 2013 ARM Ltd.
Lorenzo Pieralisied69bdd2012-07-13 15:55:52 +01006 */
7
8#ifndef __LINUX_ARM_CCI_H
9#define __LINUX_ARM_CCI_H
10
11#include <linux/errno.h>
12#include <linux/types.h>
13
Suzuki K. Poulose772742a2015-03-18 12:24:40 +000014#include <asm/arm-cci.h>
15
Lorenzo Pieralisied69bdd2012-07-13 15:55:52 +010016struct device_node;
17
18#ifdef CONFIG_ARM_CCI
19extern bool cci_probed(void);
Suzuki K. Pouloseee8e5d52015-03-18 12:24:41 +000020#else
21static inline bool cci_probed(void) { return false; }
22#endif
23
24#ifdef CONFIG_ARM_CCI400_PORT_CTRL
Lorenzo Pieralisied69bdd2012-07-13 15:55:52 +010025extern int cci_ace_get_port(struct device_node *dn);
26extern int cci_disable_port_by_cpu(u64 mpidr);
27extern int __cci_control_port_by_device(struct device_node *dn, bool enable);
28extern int __cci_control_port_by_index(u32 port, bool enable);
29#else
Lorenzo Pieralisied69bdd2012-07-13 15:55:52 +010030static inline int cci_ace_get_port(struct device_node *dn)
31{
32 return -ENODEV;
33}
34static inline int cci_disable_port_by_cpu(u64 mpidr) { return -ENODEV; }
35static inline int __cci_control_port_by_device(struct device_node *dn,
36 bool enable)
37{
38 return -ENODEV;
39}
40static inline int __cci_control_port_by_index(u32 port, bool enable)
41{
42 return -ENODEV;
43}
44#endif
Suzuki K. Pouloseee8e5d52015-03-18 12:24:41 +000045
Lorenzo Pieralisied69bdd2012-07-13 15:55:52 +010046#define cci_disable_port_by_device(dev) \
47 __cci_control_port_by_device(dev, false)
48#define cci_enable_port_by_device(dev) \
49 __cci_control_port_by_device(dev, true)
50#define cci_disable_port_by_index(dev) \
51 __cci_control_port_by_index(dev, false)
52#define cci_enable_port_by_index(dev) \
53 __cci_control_port_by_index(dev, true)
54
55#endif