2007-02-11 18:31:01 +01:00
/* linux/include/asm-arm/plat-s3c24xx/cpu.h
2005-04-16 15:20:36 -07:00
*
* Copyright ( c ) 2004 - 2005 Simtec Electronics
* Ben Dooks < ben @ simtec . co . uk >
*
* Header file for S3C24XX CPU support
*
* 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 .
*/
/* todo - fix when rmk changes iodescs to use `void __iomem *` */
2006-01-26 15:20:50 +00:00
# define IODESC_ENT(x) { (unsigned long)S3C24XX_VA_##x, __phys_to_pfn(S3C24XX_PA_##x), S3C24XX_SZ_##x, MT_DEVICE }
2005-04-16 15:20:36 -07:00
# ifndef MHZ
# define MHZ (1000*1000)
# endif
# define print_mhz(m) ((m) / MHZ), ((m / 1000) % 1000)
/* forward declaration */
2006-06-18 23:04:05 +01:00
struct s3c24xx_uart_resources ;
struct platform_device ;
2005-04-16 15:20:36 -07:00
struct s3c2410_uartcfg ;
struct map_desc ;
2008-10-21 14:06:31 +01:00
/* per-cpu initialisation function table. */
struct cpu_table {
unsigned long idcode ;
unsigned long idmask ;
void ( * map_io ) ( void ) ;
void ( * init_uarts ) ( struct s3c2410_uartcfg * cfg , int no ) ;
void ( * init_clocks ) ( int xtal ) ;
int ( * init ) ( void ) ;
const char * name ;
} ;
extern void s3c_init_cpu ( unsigned long idcode ,
struct cpu_table * cpus , unsigned int cputab_size ) ;
2005-04-16 15:20:36 -07:00
/* core initialisation functions */
extern void s3c24xx_init_irq ( void ) ;
extern void s3c24xx_init_io ( struct map_desc * mach_desc , int size ) ;
extern void s3c24xx_init_uarts ( struct s3c2410_uartcfg * cfg , int no ) ;
extern void s3c24xx_init_clocks ( int xtal ) ;
2006-06-18 23:04:05 +01:00
extern void s3c24xx_init_uartdevs ( char * name ,
struct s3c24xx_uart_resources * res ,
struct s3c2410_uartcfg * cfg , int no ) ;
2005-04-16 15:20:36 -07:00
/* timer for 2410/2440 */
struct sys_timer ;
extern struct sys_timer s3c24xx_timer ;
/* system device classes */
2006-06-22 22:18:13 +01:00
extern struct sysdev_class s3c2410_sysclass ;
2006-06-24 21:21:27 +01:00
extern struct sysdev_class s3c2412_sysclass ;
2005-04-16 15:20:36 -07:00
extern struct sysdev_class s3c2440_sysclass ;
2006-06-18 23:06:41 +01:00
extern struct sysdev_class s3c2442_sysclass ;
2007-02-16 12:12:31 +01:00
extern struct sysdev_class s3c2443_sysclass ;