blob: 0e130b5077a571851df0ab4e67f6184feb5c40d4 [file] [log] [blame]
Thomas Gleixner1802d0b2019-05-27 08:55:21 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Pawel Moll3ecbf052012-09-24 14:55:40 +01002/*
Pawel Moll3ecbf052012-09-24 14:55:40 +01003 *
4 * Copyright (C) 2012 ARM Limited
5 */
6
7#ifndef _LINUX_VEXPRESS_H
8#define _LINUX_VEXPRESS_H
9
10#include <linux/device.h>
Pawel Moll3b9334a2014-04-30 16:46:29 +010011#include <linux/regmap.h>
Pawel Moll3ecbf052012-09-24 14:55:40 +010012
13#define VEXPRESS_SITE_MB 0
14#define VEXPRESS_SITE_DB1 1
15#define VEXPRESS_SITE_DB2 2
16#define VEXPRESS_SITE_MASTER 0xf
17
Pawel Moll3b9334a2014-04-30 16:46:29 +010018/* Config infrastructure */
19
20void vexpress_config_set_master(u32 site);
21u32 vexpress_config_get_master(void);
22
23void vexpress_config_lock(void *arg);
24void vexpress_config_unlock(void *arg);
25
26int vexpress_config_get_topo(struct device_node *node, u32 *site,
27 u32 *position, u32 *dcc);
28
Pawel Moll3ecbf052012-09-24 14:55:40 +010029/* Config bridge API */
30
Pawel Moll3b9334a2014-04-30 16:46:29 +010031struct vexpress_config_bridge_ops {
32 struct regmap * (*regmap_init)(struct device *dev, void *context);
33 void (*regmap_exit)(struct regmap *regmap, void *context);
Pawel Moll3ecbf052012-09-24 14:55:40 +010034};
35
Pawel Moll3b9334a2014-04-30 16:46:29 +010036struct device *vexpress_config_bridge_register(struct device *parent,
37 struct vexpress_config_bridge_ops *ops, void *context);
Pawel Moll3ecbf052012-09-24 14:55:40 +010038
Pawel Moll3b9334a2014-04-30 16:46:29 +010039/* Config regmap API */
Pawel Moll3ecbf052012-09-24 14:55:40 +010040
Pawel Moll3b9334a2014-04-30 16:46:29 +010041struct regmap *devm_regmap_init_vexpress_config(struct device *dev);
Pawel Moll3ecbf052012-09-24 14:55:40 +010042
Pawel Moll88e0abc2012-09-18 12:24:57 +010043/* Platform control */
44
Pawel Moll88e0abc2012-09-18 12:24:57 +010045void vexpress_flags_set(u32 data);
46
Pawel Moll3ecbf052012-09-24 14:55:40 +010047#endif