blob: 6b206ba6aa0e992042293c20205305146bf58ceb [file] [log] [blame]
Pawel Moll3ecbf052012-09-24 14:55:40 +01001/*
2 * This program is free software; you can redistribute it and/or modify
3 * it under the terms of the GNU General Public License version 2 as
4 * published by the Free Software Foundation.
5 *
6 * This program is distributed in the hope that it will be useful,
7 * but WITHOUT ANY WARRANTY; without even the implied warranty of
8 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
9 * GNU General Public License for more details.
10 *
11 * Copyright (C) 2012 ARM Limited
12 */
13
14#ifndef _LINUX_VEXPRESS_H
15#define _LINUX_VEXPRESS_H
16
17#include <linux/device.h>
Pawel Moll3b9334a2014-04-30 16:46:29 +010018#include <linux/platform_device.h>
Robin Holt7b6d8642013-07-08 16:01:40 -070019#include <linux/reboot.h>
Pawel Moll3b9334a2014-04-30 16:46:29 +010020#include <linux/regmap.h>
Pawel Moll3ecbf052012-09-24 14:55:40 +010021
22#define VEXPRESS_SITE_MB 0
23#define VEXPRESS_SITE_DB1 1
24#define VEXPRESS_SITE_DB2 2
25#define VEXPRESS_SITE_MASTER 0xf
26
Pawel Moll88e0abc2012-09-18 12:24:57 +010027#define VEXPRESS_GPIO_MMC_CARDIN 0
28#define VEXPRESS_GPIO_MMC_WPROT 1
29#define VEXPRESS_GPIO_FLASH_WPn 2
Pawel Moll8ea402f2013-01-30 10:33:16 +000030#define VEXPRESS_GPIO_LED0 3
31#define VEXPRESS_GPIO_LED1 4
32#define VEXPRESS_GPIO_LED2 5
33#define VEXPRESS_GPIO_LED3 6
34#define VEXPRESS_GPIO_LED4 7
35#define VEXPRESS_GPIO_LED5 8
36#define VEXPRESS_GPIO_LED6 9
37#define VEXPRESS_GPIO_LED7 10
Pawel Moll88e0abc2012-09-18 12:24:57 +010038
39#define VEXPRESS_RES_FUNC(_site, _func) \
40{ \
41 .start = (_site), \
42 .end = (_func), \
43 .flags = IORESOURCE_BUS, \
44}
45
Pawel Moll3b9334a2014-04-30 16:46:29 +010046/* Config infrastructure */
47
48void vexpress_config_set_master(u32 site);
49u32 vexpress_config_get_master(void);
50
51void vexpress_config_lock(void *arg);
52void vexpress_config_unlock(void *arg);
53
54int vexpress_config_get_topo(struct device_node *node, u32 *site,
55 u32 *position, u32 *dcc);
56
Pawel Moll3ecbf052012-09-24 14:55:40 +010057/* Config bridge API */
58
Pawel Moll3b9334a2014-04-30 16:46:29 +010059struct vexpress_config_bridge_ops {
60 struct regmap * (*regmap_init)(struct device *dev, void *context);
61 void (*regmap_exit)(struct regmap *regmap, void *context);
Pawel Moll3ecbf052012-09-24 14:55:40 +010062};
63
Pawel Moll3b9334a2014-04-30 16:46:29 +010064struct device *vexpress_config_bridge_register(struct device *parent,
65 struct vexpress_config_bridge_ops *ops, void *context);
Pawel Moll3ecbf052012-09-24 14:55:40 +010066
Pawel Moll3b9334a2014-04-30 16:46:29 +010067/* Config regmap API */
Pawel Moll3ecbf052012-09-24 14:55:40 +010068
Pawel Moll3b9334a2014-04-30 16:46:29 +010069struct regmap *devm_regmap_init_vexpress_config(struct device *dev);
Pawel Moll3ecbf052012-09-24 14:55:40 +010070
Pawel Moll88e0abc2012-09-18 12:24:57 +010071/* Platform control */
72
73u32 vexpress_get_procid(int site);
74u32 vexpress_get_hbi(int site);
75void *vexpress_get_24mhz_clock_base(void);
76void vexpress_flags_set(u32 data);
77
Pawel Moll88e0abc2012-09-18 12:24:57 +010078void vexpress_sysreg_early_init(void __iomem *base);
79void vexpress_sysreg_of_early_init(void);
Pawel Moll3b9334a2014-04-30 16:46:29 +010080int vexpress_sysreg_config_device_register(struct platform_device *pdev);
Pawel Moll88e0abc2012-09-18 12:24:57 +010081
Pawel Moll38669e02012-10-09 12:56:36 +010082/* Clocks */
83
Pawel Moll38669e02012-10-09 12:56:36 +010084void vexpress_clk_init(void __iomem *sp810_base);
Pawel Moll38669e02012-10-09 12:56:36 +010085
Pawel Moll3ecbf052012-09-24 14:55:40 +010086#endif