2019-05-27 08:55:01 +02:00
// SPDX-License-Identifier: GPL-2.0-or-later
2006-02-02 13:50:44 -06:00
/*
* misc setup functions for MPC83xx
*
* Maintainer : Kumar Gala < galak @ kernel . crashing . org >
*/
# include <linux/stddef.h>
# include <linux/kernel.h>
2011-07-22 23:55:42 +04:00
# include <linux/of_platform.h>
2011-11-17 18:48:48 +04:00
# include <linux/pci.h>
2006-02-02 13:50:44 -06:00
2018-12-10 11:41:29 +00:00
# include <asm/debug.h>
2006-02-02 13:50:44 -06:00
# include <asm/io.h>
# include <asm/hw_irq.h>
2011-07-22 23:55:42 +04:00
# include <asm/ipic.h>
2006-02-02 13:50:44 -06:00
# include <sysdev/fsl_soc.h>
2011-11-17 18:48:48 +04:00
# include <sysdev/fsl_pci.h>
2006-02-02 13:50:44 -06:00
2019-09-16 20:25:41 +00:00
# include <mm/mmu_decl.h>
2006-02-02 13:50:44 -06:00
# include "mpc83xx.h"
2007-01-26 00:37:11 -06:00
static __be32 __iomem * restart_reg_base ;
static int __init mpc83xx_restart_init ( void )
{
/* map reset restart_reg_baseister space */
restart_reg_base = ioremap ( get_immrbase ( ) + 0x900 , 0xff ) ;
return 0 ;
}
arch_initcall ( mpc83xx_restart_init ) ;
2016-07-12 10:54:52 +10:00
void __noreturn mpc83xx_restart ( char * cmd )
2006-02-02 13:50:44 -06:00
{
# define RST_OFFSET 0x00000900
# define RST_PROT_REG 0x00000018
# define RST_CTRL_REG 0x0000001c
local_irq_disable ( ) ;
2007-01-26 00:37:11 -06:00
if ( restart_reg_base ) {
/* enable software reset "RSTE" */
out_be32 ( restart_reg_base + ( RST_PROT_REG > > 2 ) , 0x52535445 ) ;
/* set software hard reset */
out_be32 ( restart_reg_base + ( RST_CTRL_REG > > 2 ) , 0x2 ) ;
} else {
printk ( KERN_EMERG " Error: Restart registers not mapped, spinning! \n " ) ;
}
2006-02-02 13:50:44 -06:00
for ( ; ; ) ;
}
long __init mpc83xx_time_init ( void )
{
# define SPCR_OFFSET 0x00000110
# define SPCR_TBEN 0x00400000
__be32 __iomem * spcr = ioremap ( get_immrbase ( ) + SPCR_OFFSET , 4 ) ;
__be32 tmp ;
tmp = in_be32 ( spcr ) ;
out_be32 ( spcr , tmp | SPCR_TBEN ) ;
iounmap ( spcr ) ;
return 0 ;
}
2011-07-22 23:55:42 +04:00
void __init mpc83xx_ipic_init_IRQ ( void )
{
struct device_node * np ;
/* looking for fsl,pq2pro-pic which is asl compatible with fsl,ipic */
np = of_find_compatible_node ( NULL , NULL , " fsl,ipic " ) ;
if ( ! np )
np = of_find_node_by_type ( NULL , " ipic " ) ;
if ( ! np )
return ;
ipic_init ( np , 0 ) ;
of_node_put ( np ) ;
/* Initialize the default interrupt mapping priorities,
* in case the boot rom changed something on us .
*/
ipic_set_default_priority ( ) ;
}
2014-09-10 21:56:38 +02:00
static const struct of_device_id of_bus_ids [ ] __initconst = {
2011-11-17 18:48:47 +04:00
{ . type = " soc " , } ,
{ . compatible = " soc " , } ,
{ . compatible = " simple-bus " } ,
{ . compatible = " gianfar " } ,
{ . compatible = " gpio-leds " , } ,
{ . type = " qe " , } ,
{ . compatible = " fsl,qe " , } ,
{ } ,
} ;
int __init mpc83xx_declare_of_platform_devices ( void )
{
of_platform_bus_probe ( NULL , of_bus_ids , NULL ) ;
return 0 ;
}
2011-11-17 18:48:48 +04:00
# ifdef CONFIG_PCI
void __init mpc83xx_setup_pci ( void )
{
struct device_node * np ;
for_each_compatible_node ( np , " pci " , " fsl,mpc8349-pci " )
mpc83xx_add_bridge ( np ) ;
for_each_compatible_node ( np , " pci " , " fsl,mpc8314-pcie " )
mpc83xx_add_bridge ( np ) ;
}
# endif
2016-08-23 10:06:58 +08:00
void __init mpc83xx_setup_arch ( void )
{
if ( ppc_md . progress )
ppc_md . progress ( " mpc83xx_setup_arch() " , 0 ) ;
2019-09-16 20:25:41 +00:00
if ( ! __map_without_bats ) {
phys_addr_t immrbase = get_immrbase ( ) ;
int immrsize = IS_ALIGNED ( immrbase , SZ_2M ) ? SZ_2M : SZ_1M ;
unsigned long va = fix_to_virt ( FIX_IMMR_BASE ) ;
setbat ( - 1 , va , immrbase , immrsize , PAGE_KERNEL_NCG ) ;
update_bats ( ) ;
}
2016-08-23 10:06:58 +08:00
}
2018-12-10 11:41:29 +00:00
int machine_check_83xx ( struct pt_regs * regs )
{
u32 mask = 1 < < ( 31 - IPIC_MCP_WDT ) ;
if ( ! ( regs - > msr & SRR1_MCE_MCP ) | | ! ( ipic_get_mcp_status ( ) & mask ) )
return machine_check_generic ( regs ) ;
ipic_clear_mcp_status ( mask ) ;
if ( debugger_fault_handler ( regs ) )
return 1 ;
die ( " Watchdog NMI Reset " , regs , 0 ) ;
return 1 ;
}