mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-21 19:19:57 +07:00
44e259ac90
The PMU device contains an interrupt controller, power control and resets. The interrupt controller is a little sub-standard in that there is no race free way to clear down pending interrupts, so we try to avoid problems by reducing the window as much as possible, and clearing as infrequently as possible. The interrupt support is implemented using an IRQ domain, and the parent interrupt referenced in the standard DT way. The power domains and reset support is closely related - there is a defined sequence for powering down a domain which is tightly coupled with asserting the reset. Hence, it makes sense to group these two together, and in order to avoid any locking contention disrupting this sequence, we avoid the use of syscon or regmap. This patch adds the core PMU driver: power domains must be defined in the DT file in order to make use of them. The reset controller can be referenced in the standard way for reset controllers. Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk> Signed-off-by: Andrew Lunn <andrew@lunn.ch> Signed-off-by: Gregory CLEMENT <gregory.clement@free-electrons.com>
42 lines
976 B
C
42 lines
976 B
C
/*
|
|
* arch/arm/mach-mvebu/dove.c
|
|
*
|
|
* Marvell Dove 88AP510 System On Chip FDT Board
|
|
*
|
|
* This file is licensed under the terms of the GNU General Public
|
|
* License version 2. This program is licensed "as is" without any
|
|
* warranty of any kind, whether express or implied.
|
|
*/
|
|
|
|
#include <linux/init.h>
|
|
#include <linux/mbus.h>
|
|
#include <linux/of.h>
|
|
#include <linux/of_platform.h>
|
|
#include <linux/soc/dove/pmu.h>
|
|
#include <asm/hardware/cache-tauros2.h>
|
|
#include <asm/mach/arch.h>
|
|
#include "common.h"
|
|
|
|
static void __init dove_init(void)
|
|
{
|
|
pr_info("Dove 88AP510 SoC\n");
|
|
|
|
#ifdef CONFIG_CACHE_TAUROS2
|
|
tauros2_init(0);
|
|
#endif
|
|
BUG_ON(mvebu_mbus_dt_init(false));
|
|
dove_init_pmu();
|
|
of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL);
|
|
}
|
|
|
|
static const char * const dove_dt_compat[] __initconst = {
|
|
"marvell,dove",
|
|
NULL
|
|
};
|
|
|
|
DT_MACHINE_START(DOVE_DT, "Marvell Dove")
|
|
.init_machine = dove_init,
|
|
.restart = mvebu_restart,
|
|
.dt_compat = dove_dt_compat,
|
|
MACHINE_END
|