2005-04-16 15:20:36 -07:00
/*
* linux / arch / arm / mach - pxa / generic . c
*
* Author : Nicolas Pitre
* Created : Jun 15 , 2001
* Copyright : MontaVista Software Inc .
*
* Code common to all PXA machines .
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation .
*
* Since this file should be linked before any other machine specific file ,
* the __initcall ( ) here will be executed first . This serves as default
* initialization stuff for PXA machines which can be overridden later if
* need be .
*/
2011-07-26 10:53:52 +01:00
# include <linux/gpio.h>
2005-04-16 15:20:36 -07:00
# include <linux/module.h>
# include <linux/kernel.h>
# include <linux/init.h>
2008-08-05 16:14:15 +01:00
# include <mach/hardware.h>
2005-04-16 15:20:36 -07:00
# include <asm/mach/map.h>
2008-12-18 11:10:32 +08:00
# include <asm/mach-types.h>
2005-04-16 15:20:36 -07:00
2014-07-14 18:52:04 +02:00
# include <mach/irqs.h>
2008-08-07 11:05:25 +01:00
# include <mach/reset.h>
2010-11-03 16:29:35 +01:00
# include <mach/smemc.h>
2010-11-24 11:54:19 +08:00
# include <mach/pxa3xx-regs.h>
2005-04-16 15:20:36 -07:00
# include "generic.h"
2014-07-14 18:52:04 +02:00
# include <clocksource/pxa.h>
2005-04-16 15:20:36 -07:00
2008-07-29 14:26:00 +08:00
void clear_reset_status ( unsigned int mask )
{
if ( cpu_is_pxa2xx ( ) )
pxa2xx_clear_reset_status ( mask ) ;
2010-11-24 11:54:19 +08:00
else {
/* RESET_STATUS_* has a 1:1 mapping with ARSR */
ARSR = mask ;
}
2008-07-29 14:26:00 +08:00
}
2014-07-14 18:52:04 +02:00
/*
* For non device - tree builds , keep legacy timer init
*/
2014-07-26 20:49:39 +02:00
void __init pxa_timer_init ( void )
2014-07-14 18:52:04 +02:00
{
2014-12-27 14:55:25 +01:00
if ( cpu_is_pxa25x ( ) )
pxa25x_clocks_init ( ) ;
if ( cpu_is_pxa27x ( ) )
pxa27x_clocks_init ( ) ;
2015-02-07 22:54:03 +01:00
if ( cpu_is_pxa3xx ( ) )
pxa3xx_clocks_init ( ) ;
2016-09-19 21:12:13 +02:00
pxa_timer_nodt_init ( IRQ_OST0 , io_p2v ( 0x40a00000 ) ) ;
2014-07-14 18:52:04 +02:00
}
2007-08-20 10:07:44 +01:00
/*
* Get the clock frequency as reflected by CCCR and the turbo flag .
* We assume these values have been applied via a fcs .
* If info is not 0 we also display the current settings .
*/
unsigned int get_clk_frequency_khz ( int info )
{
2008-09-11 10:27:30 +08:00
if ( cpu_is_pxa25x ( ) )
2007-08-20 10:07:44 +01:00
return pxa25x_get_clk_frequency_khz ( info ) ;
2007-09-11 19:13:17 -07:00
else if ( cpu_is_pxa27x ( ) )
2007-08-20 10:07:44 +01:00
return pxa27x_get_clk_frequency_khz ( info ) ;
2010-09-19 20:09:10 -04:00
return 0 ;
2007-08-20 10:07:44 +01:00
}
EXPORT_SYMBOL ( get_clk_frequency_khz ) ;
2005-04-16 15:20:36 -07:00
/*
* Intel PXA2xx internal register mapping .
*
2010-10-11 02:20:19 +02:00
* Note : virtual 0xfffe0000 - 0xffffffff is reserved for the vector table
* and cache flush area .
2005-04-16 15:20:36 -07:00
*/
2010-10-11 02:20:19 +02:00
static struct map_desc common_io_desc [ ] __initdata = {
2005-10-28 15:19:01 +01:00
{ /* Devs */
2014-07-11 13:00:36 +02:00
. virtual = ( unsigned long ) PERIPH_VIRT ,
. pfn = __phys_to_pfn ( PERIPH_PHYS ) ,
. length = PERIPH_SIZE ,
2005-10-28 15:19:01 +01:00
. type = MT_DEVICE
}
2005-04-16 15:20:36 -07:00
} ;
void __init pxa_map_io ( void )
{
2014-06-05 14:10:57 -05:00
debug_ll_io_init ( ) ;
2010-10-11 02:20:19 +02:00
iotable_init ( ARRAY_AND_SIZE ( common_io_desc ) ) ;
2005-04-16 15:20:36 -07:00
}