blob: 0b4d5b9021651f7e54f86f61bc1b6b8a417f5725 [file] [log] [blame]
Sam Ravnborg1d059952011-02-25 23:01:19 -08001#include <linux/platform_device.h>
2
Al Viro32231a62007-07-21 19:18:57 -07003#include <asm/btfixup.h>
4
Sam Ravnborgbbdc2662011-02-25 23:00:19 -08005/*
6 * Platform specific irq configuration
7 * The individual platforms assign their platform
8 * specifics in their init functions.
9 */
10struct sparc_irq_config {
11 void (*init_timers)(irq_handler_t);
Sam Ravnborg1d059952011-02-25 23:01:19 -080012 unsigned int (*build_device_irq)(struct platform_device *op,
13 unsigned int real_irq);
Sam Ravnborgbbdc2662011-02-25 23:00:19 -080014};
15extern struct sparc_irq_config sparc_irq_config;
16
17
Al Viro0f516812007-07-21 19:19:38 -070018/* Dave Redman (djhr@tadpole.co.uk)
19 * changed these to function pointers.. it saves cycles and will allow
20 * the irq dependencies to be split into different files at a later date
21 * sun4c_irq.c, sun4m_irq.c etc so we could reduce the kernel size.
22 * Jakub Jelinek (jj@sunsite.mff.cuni.cz)
23 * Changed these to btfixup entities... It saves cycles :)
24 */
25
26BTFIXUPDEF_CALL(void, disable_irq, unsigned int)
27BTFIXUPDEF_CALL(void, enable_irq, unsigned int)
Al Viro32231a62007-07-21 19:18:57 -070028BTFIXUPDEF_CALL(void, disable_pil_irq, unsigned int)
29BTFIXUPDEF_CALL(void, enable_pil_irq, unsigned int)
30BTFIXUPDEF_CALL(void, clear_clock_irq, void)
Al Viro32231a62007-07-21 19:18:57 -070031BTFIXUPDEF_CALL(void, load_profile_irq, int, unsigned int)
32
Al Viro0f516812007-07-21 19:19:38 -070033static inline void __disable_irq(unsigned int irq)
34{
35 BTFIXUP_CALL(disable_irq)(irq);
36}
37
38static inline void __enable_irq(unsigned int irq)
39{
40 BTFIXUP_CALL(enable_irq)(irq);
41}
42
Al Viro32231a62007-07-21 19:18:57 -070043static inline void disable_pil_irq(unsigned int irq)
44{
45 BTFIXUP_CALL(disable_pil_irq)(irq);
46}
47
48static inline void enable_pil_irq(unsigned int irq)
49{
50 BTFIXUP_CALL(enable_pil_irq)(irq);
51}
52
53static inline void clear_clock_irq(void)
54{
55 BTFIXUP_CALL(clear_clock_irq)();
56}
57
Al Viro32231a62007-07-21 19:18:57 -070058static inline void load_profile_irq(int cpu, int limit)
59{
60 BTFIXUP_CALL(load_profile_irq)(cpu, limit);
61}
62
Al Viro32231a62007-07-21 19:18:57 -070063#ifdef CONFIG_SMP
64BTFIXUPDEF_CALL(void, set_cpu_int, int, int)
65BTFIXUPDEF_CALL(void, clear_cpu_int, int, int)
66BTFIXUPDEF_CALL(void, set_irq_udt, int)
67
68#define set_cpu_int(cpu,level) BTFIXUP_CALL(set_cpu_int)(cpu,level)
69#define clear_cpu_int(cpu,level) BTFIXUP_CALL(clear_cpu_int)(cpu,level)
70#define set_irq_udt(cpu) BTFIXUP_CALL(set_irq_udt)(cpu)
71#endif