11da177e4SLinus Torvalds /* 21da177e4SLinus Torvalds * linux/arch/arm/mach-pxa/generic.h 31da177e4SLinus Torvalds * 41da177e4SLinus Torvalds * Author: Nicolas Pitre 51da177e4SLinus Torvalds * Copyright: MontaVista Software Inc. 61da177e4SLinus Torvalds * 71da177e4SLinus Torvalds * This program is free software; you can redistribute it and/or modify 81da177e4SLinus Torvalds * it under the terms of the GNU General Public License version 2 as 91da177e4SLinus Torvalds * published by the Free Software Foundation. 101da177e4SLinus Torvalds */ 111da177e4SLinus Torvalds 121da177e4SLinus Torvalds struct sys_timer; 131da177e4SLinus Torvalds 141da177e4SLinus Torvalds extern struct sys_timer pxa_timer; 15*a58fbcd8SEric Miao extern void __init pxa_init_irq(int irq_nr, 16*a58fbcd8SEric Miao int (*set_wake)(unsigned int, unsigned int)); 17cd49104dSEric Miao extern void __init pxa25x_init_irq(void); 18cd49104dSEric Miao extern void __init pxa27x_init_irq(void); 192c8086a5Seric miao extern void __init pxa3xx_init_irq(void); 201da177e4SLinus Torvalds extern void __init pxa_map_io(void); 211da177e4SLinus Torvalds 221da177e4SLinus Torvalds extern unsigned int get_clk_frequency_khz(int info); 2330f0b408Seric miao extern int pxa_last_gpio; 241da177e4SLinus Torvalds 251da177e4SLinus Torvalds #define SET_BANK(__nr,__start,__size) \ 261da177e4SLinus Torvalds mi->bank[__nr].start = (__start), \ 271da177e4SLinus Torvalds mi->bank[__nr].size = (__size), \ 281da177e4SLinus Torvalds mi->bank[__nr].node = (((unsigned)(__start) - PHYS_OFFSET) >> 27) 291da177e4SLinus Torvalds 303d3934c3Seric miao #define ARRAY_AND_SIZE(x) (x), ARRAY_SIZE(x) 313d3934c3Seric miao 3215a40333SRussell King #ifdef CONFIG_PXA25x 3315a40333SRussell King extern unsigned pxa25x_get_clk_frequency_khz(int); 3415a40333SRussell King extern unsigned pxa25x_get_memclk_frequency_10khz(void); 3515a40333SRussell King #else 3615a40333SRussell King #define pxa25x_get_clk_frequency_khz(x) (0) 3715a40333SRussell King #define pxa25x_get_memclk_frequency_10khz() (0) 3815a40333SRussell King #endif 3915a40333SRussell King 4015a40333SRussell King #ifdef CONFIG_PXA27x 4115a40333SRussell King extern unsigned pxa27x_get_clk_frequency_khz(int); 4215a40333SRussell King extern unsigned pxa27x_get_memclk_frequency_10khz(void); 4315a40333SRussell King #else 4415a40333SRussell King #define pxa27x_get_clk_frequency_khz(x) (0) 4515a40333SRussell King #define pxa27x_get_memclk_frequency_10khz() (0) 4615a40333SRussell King #endif 4715a40333SRussell King 4804fef228SEric Miao #if defined(CONFIG_PXA25x) || defined(CONFIG_PXA27x) 4904fef228SEric Miao extern void pxa2xx_clear_reset_status(unsigned int); 5004fef228SEric Miao #else 5104fef228SEric Miao static inline void pxa2xx_clear_reset_status(unsigned int mask) {} 5204fef228SEric Miao #endif 5304fef228SEric Miao 542c8086a5Seric miao #ifdef CONFIG_PXA3xx 552c8086a5Seric miao extern unsigned pxa3xx_get_clk_frequency_khz(int); 562c8086a5Seric miao extern unsigned pxa3xx_get_memclk_frequency_10khz(void); 5704fef228SEric Miao extern void pxa3xx_clear_reset_status(unsigned int); 582c8086a5Seric miao #else 592c8086a5Seric miao #define pxa3xx_get_clk_frequency_khz(x) (0) 602c8086a5Seric miao #define pxa3xx_get_memclk_frequency_10khz() (0) 6104fef228SEric Miao static inline void pxa3xx_clear_reset_status(unsigned int mask) {} 622c8086a5Seric miao #endif 63c0165504Seric miao 64c0165504Seric miao extern struct sysdev_class pxa_irq_sysclass; 6516dfdbf0Seric miao extern struct sysdev_class pxa_gpio_sysclass; 665a3d9651SEric Miao extern struct sysdev_class pxa2xx_mfp_sysclass; 674be35e23Seric miao extern struct sysdev_class pxa3xx_mfp_sysclass; 68