2012-07-18 16:07:18 -06:00
/*
* Copyright ( C ) 2012 Altera Corporation
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 2 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
2012-11-05 16:18:28 -06:00
# include <linux/irqchip.h>
2012-10-25 10:41:39 -06:00
# include <linux/of_address.h>
2012-07-18 16:07:18 -06:00
# include <linux/of_irq.h>
# include <linux/of_platform.h>
2013-07-08 16:01:40 -07:00
# include <linux/reboot.h>
2012-07-18 16:07:18 -06:00
# include <asm/hardware/cache-l2x0.h>
# include <asm/mach/arch.h>
2012-10-25 10:41:39 -06:00
# include <asm/mach/map.h>
2012-07-18 16:07:18 -06:00
2012-10-25 10:41:39 -06:00
# include "core.h"
void __iomem * socfpga_scu_base_addr = ( ( void __iomem * ) ( SOCFPGA_SCU_VIRT_BASE ) ) ;
void __iomem * sys_manager_base_addr ;
void __iomem * rst_manager_base_addr ;
2013-02-11 17:30:33 -06:00
unsigned long cpu1start_addr ;
2012-10-25 10:41:39 -06:00
static struct map_desc scu_io_desc __initdata = {
. virtual = SOCFPGA_SCU_VIRT_BASE ,
. pfn = 0 , /* run-time */
. length = SZ_8K ,
. type = MT_DEVICE ,
} ;
2012-10-29 01:27:24 +01:00
static struct map_desc uart_io_desc __initdata = {
. virtual = 0xfec02000 ,
. pfn = __phys_to_pfn ( 0xffc02000 ) ,
. length = SZ_8K ,
. type = MT_DEVICE ,
} ;
2012-10-25 10:41:39 -06:00
static void __init socfpga_scu_map_io ( void )
{
unsigned long base ;
/* Get SCU base */
asm ( " mrc p15, 4, %0, c15, c0, 0 " : " =r " ( base ) ) ;
scu_io_desc . pfn = __phys_to_pfn ( base ) ;
iotable_init ( & scu_io_desc , 1 ) ;
}
static void __init socfpga_map_io ( void )
{
socfpga_scu_map_io ( ) ;
2012-10-29 01:27:24 +01:00
iotable_init ( & uart_io_desc , 1 ) ;
early_printk ( " Early printk initialized \n " ) ;
2012-10-25 10:41:39 -06:00
}
2012-07-18 16:07:18 -06:00
2012-10-25 10:41:39 -06:00
void __init socfpga_sysmgr_init ( void )
{
struct device_node * np ;
np = of_find_compatible_node ( NULL , NULL , " altr,sys-mgr " ) ;
2013-02-11 17:30:33 -06:00
if ( of_property_read_u32 ( np , " cpu1-start-addr " ,
( u32 * ) & cpu1start_addr ) )
pr_err ( " SMP: Need cpu1-start-addr in device tree. \n " ) ;
2012-10-25 10:41:39 -06:00
sys_manager_base_addr = of_iomap ( np , 0 ) ;
np = of_find_compatible_node ( NULL , NULL , " altr,rst-mgr " ) ;
rst_manager_base_addr = of_iomap ( np , 0 ) ;
}
2012-11-05 16:18:28 -06:00
static void __init socfpga_init_irq ( void )
2012-07-18 16:07:18 -06:00
{
2012-11-05 16:18:28 -06:00
irqchip_init ( ) ;
2012-10-25 10:41:39 -06:00
socfpga_sysmgr_init ( ) ;
2012-07-18 16:07:18 -06:00
}
2013-07-08 16:01:40 -07:00
static void socfpga_cyclone5_restart ( enum reboot_mode mode , const char * cmd )
2012-07-18 16:07:18 -06:00
{
2013-04-11 10:55:24 -05:00
u32 temp ;
temp = readl ( rst_manager_base_addr + SOCFPGA_RSTMGR_CTRL ) ;
2013-07-08 16:01:40 -07:00
if ( mode = = REBOOT_HARD )
2013-04-11 10:55:24 -05:00
temp | = RSTMGR_CTRL_SWCOLDRSTREQ ;
else
temp | = RSTMGR_CTRL_SWWARMRSTREQ ;
writel ( temp , rst_manager_base_addr + SOCFPGA_RSTMGR_CTRL ) ;
2012-07-18 16:07:18 -06:00
}
static void __init socfpga_cyclone5_init ( void )
{
l2x0_of_init ( 0 , ~ 0UL ) ;
of_platform_populate ( NULL , of_default_bus_match_table , NULL , NULL ) ;
}
static const char * altera_dt_match [ ] = {
" altr,socfpga " ,
NULL
} ;
DT_MACHINE_START ( SOCFPGA , " Altera SOCFPGA " )
2012-10-25 10:41:39 -06:00
. smp = smp_ops ( socfpga_smp_ops ) ,
. map_io = socfpga_map_io ,
2012-11-05 16:18:28 -06:00
. init_irq = socfpga_init_irq ,
2012-07-18 16:07:18 -06:00
. init_machine = socfpga_cyclone5_init ,
. restart = socfpga_cyclone5_restart ,
. dt_compat = altera_dt_match ,
MACHINE_END