2022-06-07 16:11:14 +02:00
// SPDX-License-Identifier: GPL-2.0-only
2009-08-06 15:12:43 +03:00
/*
* arch / arm / mach - dove / common . c
*
* Core functions for Marvell Dove 88 AP510 System On Chip
*/
2011-12-15 08:15:07 +01:00
# include <linux/clk-provider.h>
2013-01-29 22:23:09 +01:00
# include <linux/dma-mapping.h>
# include <linux/init.h>
2019-04-18 15:20:22 -07:00
# include <linux/io.h>
2012-08-15 19:07:33 +02:00
# include <linux/of.h>
# include <linux/of_platform.h>
2013-01-29 22:23:09 +01:00
# include <linux/platform_data/dma-mv_xor.h>
# include <linux/platform_data/usb-ehci-orion.h>
# include <linux/platform_device.h>
2015-12-08 10:58:09 +00:00
# include <linux/soc/dove/pmu.h>
2009-11-24 19:33:52 +02:00
# include <asm/hardware/cache-tauros2.h>
2013-01-29 22:23:09 +01:00
# include <asm/mach/arch.h>
2009-08-06 15:12:43 +03:00
# include <asm/mach/map.h>
# include <asm/mach/time.h>
2011-05-15 13:32:41 +02:00
# include <plat/common.h>
2013-01-29 22:23:09 +01:00
# include <plat/irq.h>
# include <plat/time.h>
2019-07-31 21:56:54 +02:00
# include "bridge-regs.h"
# include "pm.h"
2009-08-06 15:12:43 +03:00
# include "common.h"
2013-07-26 10:17:43 -03:00
/* These can go away once Dove uses the mvebu-mbus DT binding */
# define DOVE_MBUS_PCIE0_MEM_TARGET 0x4
# define DOVE_MBUS_PCIE0_MEM_ATTR 0xe8
# define DOVE_MBUS_PCIE0_IO_TARGET 0x4
# define DOVE_MBUS_PCIE0_IO_ATTR 0xe0
# define DOVE_MBUS_PCIE1_MEM_TARGET 0x8
# define DOVE_MBUS_PCIE1_MEM_ATTR 0xe8
# define DOVE_MBUS_PCIE1_IO_TARGET 0x8
# define DOVE_MBUS_PCIE1_IO_ATTR 0xe0
# define DOVE_MBUS_CESA_TARGET 0x3
# define DOVE_MBUS_CESA_ATTR 0x1
# define DOVE_MBUS_BOOTROM_TARGET 0x1
# define DOVE_MBUS_BOOTROM_ATTR 0xfd
# define DOVE_MBUS_SCRATCHPAD_TARGET 0xd
# define DOVE_MBUS_SCRATCHPAD_ATTR 0x0
2009-08-06 15:12:43 +03:00
/*****************************************************************************
* I / O Address Mapping
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2020-03-06 12:56:38 +00:00
static struct map_desc __maybe_unused dove_io_desc [ ] __initdata = {
2009-08-06 15:12:43 +03:00
{
2012-09-11 14:27:18 +02:00
. virtual = ( unsigned long ) DOVE_SB_REGS_VIRT_BASE ,
2009-08-06 15:12:43 +03:00
. pfn = __phys_to_pfn ( DOVE_SB_REGS_PHYS_BASE ) ,
. length = DOVE_SB_REGS_SIZE ,
. type = MT_DEVICE ,
} , {
2012-09-11 14:27:18 +02:00
. virtual = ( unsigned long ) DOVE_NB_REGS_VIRT_BASE ,
2009-08-06 15:12:43 +03:00
. pfn = __phys_to_pfn ( DOVE_NB_REGS_PHYS_BASE ) ,
. length = DOVE_NB_REGS_SIZE ,
. type = MT_DEVICE ,
} ,
} ;
void __init dove_map_io ( void )
{
iotable_init ( dove_io_desc , ARRAY_SIZE ( dove_io_desc ) ) ;
}
2011-12-15 08:15:07 +01:00
/*****************************************************************************
* CLK tree
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2012-08-15 19:07:30 +02:00
static int dove_tclk ;
2012-08-15 19:07:31 +02:00
static DEFINE_SPINLOCK ( gating_lock ) ;
2011-12-15 08:15:07 +01:00
static struct clk * tclk ;
2012-08-15 19:07:31 +02:00
static struct clk __init * dove_register_gate ( const char * name ,
const char * parent , u8 bit_idx )
2011-12-15 08:15:07 +01:00
{
2012-08-15 19:07:31 +02:00
return clk_register_gate ( NULL , name , parent , 0 ,
( void __iomem * ) CLOCK_GATING_CONTROL ,
bit_idx , 0 , & gating_lock ) ;
}
2012-08-15 19:07:30 +02:00
static void __init dove_clk_init ( void )
2011-12-15 08:15:07 +01:00
{
2012-08-15 19:07:31 +02:00
struct clk * usb0 , * usb1 , * sata , * pex0 , * pex1 , * sdio0 , * sdio1 ;
struct clk * nand , * camera , * i2s0 , * i2s1 , * crypto , * ac97 , * pdma ;
struct clk * xor0 , * xor1 , * ge , * gephy ;
2012-04-06 17:17:26 +02:00
2016-04-19 18:45:48 -07:00
tclk = clk_register_fixed_rate ( NULL , " tclk " , NULL , 0 , dove_tclk ) ;
2012-04-06 17:17:26 +02:00
2012-08-15 19:07:31 +02:00
usb0 = dove_register_gate ( " usb0 " , " tclk " , CLOCK_GATING_BIT_USB0 ) ;
usb1 = dove_register_gate ( " usb1 " , " tclk " , CLOCK_GATING_BIT_USB1 ) ;
sata = dove_register_gate ( " sata " , " tclk " , CLOCK_GATING_BIT_SATA ) ;
pex0 = dove_register_gate ( " pex0 " , " tclk " , CLOCK_GATING_BIT_PCIE0 ) ;
pex1 = dove_register_gate ( " pex1 " , " tclk " , CLOCK_GATING_BIT_PCIE1 ) ;
sdio0 = dove_register_gate ( " sdio0 " , " tclk " , CLOCK_GATING_BIT_SDIO0 ) ;
sdio1 = dove_register_gate ( " sdio1 " , " tclk " , CLOCK_GATING_BIT_SDIO1 ) ;
nand = dove_register_gate ( " nand " , " tclk " , CLOCK_GATING_BIT_NAND ) ;
camera = dove_register_gate ( " camera " , " tclk " , CLOCK_GATING_BIT_CAMERA ) ;
i2s0 = dove_register_gate ( " i2s0 " , " tclk " , CLOCK_GATING_BIT_I2S0 ) ;
i2s1 = dove_register_gate ( " i2s1 " , " tclk " , CLOCK_GATING_BIT_I2S1 ) ;
crypto = dove_register_gate ( " crypto " , " tclk " , CLOCK_GATING_BIT_CRYPTO ) ;
ac97 = dove_register_gate ( " ac97 " , " tclk " , CLOCK_GATING_BIT_AC97 ) ;
pdma = dove_register_gate ( " pdma " , " tclk " , CLOCK_GATING_BIT_PDMA ) ;
xor0 = dove_register_gate ( " xor0 " , " tclk " , CLOCK_GATING_BIT_XOR0 ) ;
xor1 = dove_register_gate ( " xor1 " , " tclk " , CLOCK_GATING_BIT_XOR1 ) ;
gephy = dove_register_gate ( " gephy " , " tclk " , CLOCK_GATING_BIT_GIGA_PHY ) ;
ge = dove_register_gate ( " ge " , " gephy " , CLOCK_GATING_BIT_GBE ) ;
orion_clkdev_add ( NULL , " orion_spi.0 " , tclk ) ;
orion_clkdev_add ( NULL , " orion_spi.1 " , tclk ) ;
orion_clkdev_add ( NULL , " orion_wdt " , tclk ) ;
orion_clkdev_add ( NULL , " mv64xxx_i2c.0 " , tclk ) ;
orion_clkdev_add ( NULL , " orion-ehci.0 " , usb0 ) ;
orion_clkdev_add ( NULL , " orion-ehci.1 " , usb1 ) ;
2012-09-25 02:02:15 +02:00
orion_clkdev_add ( NULL , " mv643xx_eth_port.0 " , ge ) ;
orion_clkdev_add ( NULL , " sata_mv.0 " , sata ) ;
2012-08-15 19:07:31 +02:00
orion_clkdev_add ( " 0 " , " pcie " , pex0 ) ;
orion_clkdev_add ( " 1 " , " pcie " , pex1 ) ;
orion_clkdev_add ( NULL , " sdhci-dove.0 " , sdio0 ) ;
orion_clkdev_add ( NULL , " sdhci-dove.1 " , sdio1 ) ;
orion_clkdev_add ( NULL , " orion_nand " , nand ) ;
orion_clkdev_add ( NULL , " cafe1000-ccic.0 " , camera ) ;
2013-08-04 20:27:03 +01:00
orion_clkdev_add ( NULL , " mvebu-audio.0 " , i2s0 ) ;
orion_clkdev_add ( NULL , " mvebu-audio.1 " , i2s1 ) ;
2012-08-15 19:07:31 +02:00
orion_clkdev_add ( NULL , " mv_crypto " , crypto ) ;
orion_clkdev_add ( NULL , " dove-ac97 " , ac97 ) ;
orion_clkdev_add ( NULL , " dove-pdma " , pdma ) ;
2012-10-30 11:59:42 +01:00
orion_clkdev_add ( NULL , MV_XOR_NAME " .0 " , xor0 ) ;
orion_clkdev_add ( NULL , MV_XOR_NAME " .1 " , xor1 ) ;
2011-12-15 08:15:07 +01:00
}
2009-08-06 15:12:43 +03:00
/*****************************************************************************
* EHCI0
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void __init dove_ehci0_init ( void )
{
2012-02-08 15:52:47 +01:00
orion_ehci_init ( DOVE_USB0_PHYS_BASE , IRQ_DOVE_USB0 , EHCI_PHY_NA ) ;
2009-08-06 15:12:43 +03:00
}
/*****************************************************************************
* EHCI1
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void __init dove_ehci1_init ( void )
{
2011-12-07 21:48:08 +01:00
orion_ehci_1_init ( DOVE_USB1_PHYS_BASE , IRQ_DOVE_USB1 ) ;
2009-08-06 15:12:43 +03:00
}
/*****************************************************************************
* GE00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void __init dove_ge00_init ( struct mv643xx_eth_platform_data * eth_data )
{
2012-06-12 15:59:45 +02:00
orion_ge00_init ( eth_data , DOVE_GE00_PHYS_BASE ,
2012-07-26 12:15:46 +02:00
IRQ_DOVE_GE00_SUM , IRQ_DOVE_GE00_ERR ,
1600 ) ;
2009-08-06 15:12:43 +03:00
}
/*****************************************************************************
* SoC RTC
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2013-10-23 16:12:52 +02:00
static void __init dove_rtc_init ( void )
2009-08-06 15:12:43 +03:00
{
2011-05-15 13:32:42 +02:00
orion_rtc_init ( DOVE_RTC_PHYS_BASE , IRQ_DOVE_RTC ) ;
2009-08-06 15:12:43 +03:00
}
/*****************************************************************************
* SATA
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void __init dove_sata_init ( struct mv_sata_platform_data * sata_data )
{
2011-12-07 21:48:08 +01:00
orion_sata_init ( sata_data , DOVE_SATA_PHYS_BASE , IRQ_DOVE_SATA ) ;
2011-05-15 13:32:50 +02:00
2009-08-06 15:12:43 +03:00
}
/*****************************************************************************
* UART0
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void __init dove_uart0_init ( void )
{
2011-05-15 13:32:41 +02:00
orion_uart0_init ( DOVE_UART0_VIRT_BASE , DOVE_UART0_PHYS_BASE ,
2011-12-24 03:06:34 +01:00
IRQ_DOVE_UART_0 , tclk ) ;
2009-08-06 15:12:43 +03:00
}
/*****************************************************************************
* UART1
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void __init dove_uart1_init ( void )
{
2011-05-15 13:32:41 +02:00
orion_uart1_init ( DOVE_UART1_VIRT_BASE , DOVE_UART1_PHYS_BASE ,
2011-12-24 03:06:34 +01:00
IRQ_DOVE_UART_1 , tclk ) ;
2009-08-06 15:12:43 +03:00
}
/*****************************************************************************
* UART2
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void __init dove_uart2_init ( void )
{
2011-05-15 13:32:41 +02:00
orion_uart2_init ( DOVE_UART2_VIRT_BASE , DOVE_UART2_PHYS_BASE ,
2011-12-24 03:06:34 +01:00
IRQ_DOVE_UART_2 , tclk ) ;
2009-08-06 15:12:43 +03:00
}
/*****************************************************************************
* UART3
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void __init dove_uart3_init ( void )
{
2011-05-15 13:32:41 +02:00
orion_uart3_init ( DOVE_UART3_VIRT_BASE , DOVE_UART3_PHYS_BASE ,
2011-12-24 03:06:34 +01:00
IRQ_DOVE_UART_3 , tclk ) ;
2009-08-06 15:12:43 +03:00
}
/*****************************************************************************
2011-05-15 13:32:46 +02:00
* SPI
2009-08-06 15:12:43 +03:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void __init dove_spi0_init ( void )
{
2012-04-06 17:17:26 +02:00
orion_spi_init ( DOVE_SPI0_PHYS_BASE ) ;
2009-08-06 15:12:43 +03:00
}
void __init dove_spi1_init ( void )
{
2012-04-06 17:17:26 +02:00
orion_spi_1_init ( DOVE_SPI1_PHYS_BASE ) ;
2009-08-06 15:12:43 +03:00
}
/*****************************************************************************
* I2C
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void __init dove_i2c_init ( void )
{
2011-05-15 13:32:45 +02:00
orion_i2c_init ( DOVE_I2C_PHYS_BASE , IRQ_DOVE_I2C , 10 ) ;
2009-08-06 15:12:43 +03:00
}
/*****************************************************************************
* Time handling
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-10-15 16:50:26 +02:00
void __init dove_init_early ( void )
{
orion_time_set_base ( TIMER_VIRT_BASE ) ;
2013-03-21 17:59:17 +01:00
mvebu_mbus_init ( " marvell,dove-mbus " ,
BRIDGE_WINS_BASE , BRIDGE_WINS_SZ ,
DOVE_MC_WINS_BASE , DOVE_MC_WINS_SZ ) ;
2010-10-15 16:50:26 +02:00
}
2012-08-15 19:07:30 +02:00
static int __init dove_find_tclk ( void )
2009-08-06 15:12:43 +03:00
{
return 166666667 ;
}
2012-11-08 12:40:59 -07:00
void __init dove_timer_init ( void )
2009-08-06 15:12:43 +03:00
{
2012-08-15 19:07:30 +02:00
dove_tclk = dove_find_tclk ( ) ;
2010-10-15 16:50:26 +02:00
orion_time_init ( BRIDGE_VIRT_BASE , BRIDGE_INT_TIMER1_CLR ,
2012-08-15 19:07:30 +02:00
IRQ_DOVE_BRIDGE , dove_tclk ) ;
2009-08-06 15:12:43 +03:00
}
/*****************************************************************************
* XOR 0
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2013-10-23 16:12:52 +02:00
static void __init dove_xor0_init ( void )
2009-08-06 15:12:43 +03:00
{
2011-12-07 21:48:08 +01:00
orion_xor0_init ( DOVE_XOR0_PHYS_BASE , DOVE_XOR0_HIGH_PHYS_BASE ,
2011-05-15 13:32:48 +02:00
IRQ_DOVE_XOR_00 , IRQ_DOVE_XOR_01 ) ;
2009-08-06 15:12:43 +03:00
}
/*****************************************************************************
* XOR 1
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2013-10-23 16:12:52 +02:00
static void __init dove_xor1_init ( void )
2009-08-06 15:12:43 +03:00
{
2011-05-15 13:32:48 +02:00
orion_xor1_init ( DOVE_XOR1_PHYS_BASE , DOVE_XOR1_HIGH_PHYS_BASE ,
IRQ_DOVE_XOR_10 , IRQ_DOVE_XOR_11 ) ;
2009-08-06 15:12:43 +03:00
}
2010-05-06 16:12:06 +03:00
/*****************************************************************************
* SDIO
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static u64 sdio_dmamask = DMA_BIT_MASK ( 32 ) ;
static struct resource dove_sdio0_resources [ ] = {
{
. start = DOVE_SDIO0_PHYS_BASE ,
. end = DOVE_SDIO0_PHYS_BASE + 0xff ,
. flags = IORESOURCE_MEM ,
} , {
. start = IRQ_DOVE_SDIO0 ,
. end = IRQ_DOVE_SDIO0 ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static struct platform_device dove_sdio0 = {
2010-10-28 21:23:53 +02:00
. name = " sdhci-dove " ,
2010-05-06 16:12:06 +03:00
. id = 0 ,
. dev = {
. dma_mask = & sdio_dmamask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = dove_sdio0_resources ,
. num_resources = ARRAY_SIZE ( dove_sdio0_resources ) ,
} ;
void __init dove_sdio0_init ( void )
{
platform_device_register ( & dove_sdio0 ) ;
}
static struct resource dove_sdio1_resources [ ] = {
{
. start = DOVE_SDIO1_PHYS_BASE ,
. end = DOVE_SDIO1_PHYS_BASE + 0xff ,
. flags = IORESOURCE_MEM ,
} , {
. start = IRQ_DOVE_SDIO1 ,
. end = IRQ_DOVE_SDIO1 ,
. flags = IORESOURCE_IRQ ,
} ,
} ;
static struct platform_device dove_sdio1 = {
2010-10-28 21:23:53 +02:00
. name = " sdhci-dove " ,
2010-05-06 16:12:06 +03:00
. id = 1 ,
. dev = {
. dma_mask = & sdio_dmamask ,
. coherent_dma_mask = DMA_BIT_MASK ( 32 ) ,
} ,
. resource = dove_sdio1_resources ,
. num_resources = ARRAY_SIZE ( dove_sdio1_resources ) ,
} ;
void __init dove_sdio1_init ( void )
{
platform_device_register ( & dove_sdio1 ) ;
}
2013-03-21 17:59:17 +01:00
void __init dove_setup_cpu_wins ( void )
{
/*
* The PCIe windows will no longer be statically allocated
2013-07-26 10:17:43 -03:00
* here once Dove is migrated to the pci - mvebu driver . The
* non - PCIe windows will no longer be created here once Dove
* fully moves to DT .
2013-03-21 17:59:17 +01:00
*/
2013-07-26 10:17:43 -03:00
mvebu_mbus_add_window_remap_by_id ( DOVE_MBUS_PCIE0_IO_TARGET ,
DOVE_MBUS_PCIE0_IO_ATTR ,
2013-03-21 17:59:17 +01:00
DOVE_PCIE0_IO_PHYS_BASE ,
DOVE_PCIE0_IO_SIZE ,
2013-07-26 10:17:43 -03:00
DOVE_PCIE0_IO_BUS_BASE ) ;
mvebu_mbus_add_window_remap_by_id ( DOVE_MBUS_PCIE1_IO_TARGET ,
DOVE_MBUS_PCIE1_IO_ATTR ,
2013-03-21 17:59:17 +01:00
DOVE_PCIE1_IO_PHYS_BASE ,
DOVE_PCIE1_IO_SIZE ,
2013-07-26 10:17:43 -03:00
DOVE_PCIE1_IO_BUS_BASE ) ;
mvebu_mbus_add_window_by_id ( DOVE_MBUS_PCIE0_MEM_TARGET ,
DOVE_MBUS_PCIE0_MEM_ATTR ,
DOVE_PCIE0_MEM_PHYS_BASE ,
DOVE_PCIE0_MEM_SIZE ) ;
mvebu_mbus_add_window_by_id ( DOVE_MBUS_PCIE1_MEM_TARGET ,
DOVE_MBUS_PCIE1_MEM_ATTR ,
DOVE_PCIE1_MEM_PHYS_BASE ,
DOVE_PCIE1_MEM_SIZE ) ;
mvebu_mbus_add_window_by_id ( DOVE_MBUS_CESA_TARGET ,
DOVE_MBUS_CESA_ATTR ,
DOVE_CESA_PHYS_BASE ,
DOVE_CESA_SIZE ) ;
mvebu_mbus_add_window_by_id ( DOVE_MBUS_BOOTROM_TARGET ,
DOVE_MBUS_BOOTROM_ATTR ,
DOVE_BOOTROM_PHYS_BASE ,
DOVE_BOOTROM_SIZE ) ;
mvebu_mbus_add_window_by_id ( DOVE_MBUS_SCRATCHPAD_TARGET ,
DOVE_MBUS_SCRATCHPAD_ATTR ,
DOVE_SCRATCHPAD_PHYS_BASE ,
DOVE_SCRATCHPAD_SIZE ) ;
2013-03-21 17:59:17 +01:00
}
2015-12-02 22:27:03 +01:00
static struct resource orion_wdt_resource [ ] = {
DEFINE_RES_MEM ( TIMER_PHYS_BASE , 0x04 ) ,
DEFINE_RES_MEM ( RSTOUTn_MASK_PHYS , 0x04 ) ,
} ;
static struct platform_device orion_wdt_device = {
. name = " orion_wdt " ,
. id = - 1 ,
. num_resources = ARRAY_SIZE ( orion_wdt_resource ) ,
. resource = orion_wdt_resource ,
} ;
static void __init __maybe_unused orion_wdt_init ( void )
{
platform_device_register ( & orion_wdt_device ) ;
}
2015-12-08 10:58:09 +00:00
static const struct dove_pmu_domain_initdata pmu_domains [ ] __initconst = {
{
. pwr_mask = PMU_PWR_VPU_PWR_DWN_MASK ,
. rst_mask = PMU_SW_RST_VIDEO_MASK ,
. iso_mask = PMU_ISO_VIDEO_MASK ,
. name = " vpu-domain " ,
} , {
. pwr_mask = PMU_PWR_GPU_PWR_DWN_MASK ,
. rst_mask = PMU_SW_RST_GPU_MASK ,
. iso_mask = PMU_ISO_GPU_MASK ,
. name = " gpu-domain " ,
} , {
/* sentinel */
} ,
} ;
static const struct dove_pmu_initdata pmu_data __initconst = {
. pmc_base = DOVE_PMU_VIRT_BASE ,
. pmu_base = DOVE_PMU_VIRT_BASE + 0x8000 ,
. irq = IRQ_DOVE_PMU ,
. irq_domain_start = IRQ_DOVE_PMU_START ,
. domains = pmu_domains ,
} ;
2009-08-06 15:12:43 +03:00
void __init dove_init ( void )
{
2012-08-15 19:07:30 +02:00
pr_info ( " Dove 88AP510 SoC, TCLK = %d MHz. \n " ,
( dove_tclk + 499999 ) / 1000000 ) ;
2009-08-06 15:12:43 +03:00
2009-11-24 19:33:52 +02:00
# ifdef CONFIG_CACHE_TAUROS2
2012-07-31 14:13:13 +08:00
tauros2_init ( 0 ) ;
2009-11-24 19:33:52 +02:00
# endif
2013-03-21 17:59:17 +01:00
dove_setup_cpu_wins ( ) ;
2009-08-06 15:12:43 +03:00
2011-12-15 08:15:07 +01:00
/* Setup root of clk tree */
2012-08-15 19:07:30 +02:00
dove_clk_init ( ) ;
2011-12-15 08:15:07 +01:00
2009-08-06 15:12:43 +03:00
/* internal devices that every board has */
2015-12-08 10:58:09 +00:00
dove_init_pmu_legacy ( & pmu_data ) ;
2009-08-06 15:12:43 +03:00
dove_rtc_init ( ) ;
dove_xor0_init ( ) ;
dove_xor1_init ( ) ;
}
2011-11-05 09:48:52 +00:00
2013-07-08 16:01:40 -07:00
void dove_restart ( enum reboot_mode mode , const char * cmd )
2011-11-05 09:48:52 +00:00
{
/*
* Enable soft reset to assert RSTOUTn .
*/
writel ( SOFT_RESET_OUT_EN , RSTOUTn_MASK ) ;
/*
* Assert soft reset .
*/
writel ( SOFT_RESET , SYSTEM_SOFT_RESET ) ;
while ( 1 )
;
}