| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #ifndef __ASM_SH_IRQ_H
 | 
					
						
							|  |  |  | #define __ASM_SH_IRQ_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <asm/machvec.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-12 14:09:35 +09:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * A sane default based on a reasonable vector table size, platforms are | 
					
						
							|  |  |  |  * advised to cap this at the hard limit that they're interested in | 
					
						
							|  |  |  |  * through the machvec. | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2007-03-12 14:09:35 +09:00
										 |  |  | #define NR_IRQS 256
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-06 12:05:02 +09:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Convert back and forth between INTEVT and IRQ values. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2007-03-14 13:03:35 +09:00
										 |  |  | #ifdef CONFIG_CPU_HAS_INTEVT
 | 
					
						
							| 
									
										
										
										
											2006-12-06 12:05:02 +09:00
										 |  |  | #define evt2irq(evt)		(((evt) >> 5) - 16)
 | 
					
						
							|  |  |  | #define irq2evt(irq)		(((irq) + 16) << 5)
 | 
					
						
							| 
									
										
										
										
											2007-03-14 13:03:35 +09:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #define evt2irq(evt)		(evt)
 | 
					
						
							|  |  |  | #define irq2evt(irq)		(irq)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2006-12-06 12:05:02 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Simple Mask Register Support | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | extern void make_maskreg_irq(unsigned int irq); | 
					
						
							|  |  |  | extern unsigned short *irq_mask_register; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-09-27 17:03:56 +09:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * PINT IRQs | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void init_IRQ_pint(void); | 
					
						
							| 
									
										
										
										
											2006-12-06 12:05:02 +09:00
										 |  |  | void make_imask_irq(unsigned int irq); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | static inline int generic_irq_demux(int irq) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return irq; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define irq_canonicalize(irq)	(irq)
 | 
					
						
							| 
									
										
										
										
											2006-11-20 13:55:34 +09:00
										 |  |  | #define irq_demux(irq)		sh_mv.mv_irq_demux(irq)
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-11-02 12:16:51 +09:00
										 |  |  | #ifdef CONFIG_IRQSTACKS
 | 
					
						
							| 
									
										
										
										
											2006-09-27 18:22:14 +09:00
										 |  |  | extern void irq_ctx_init(int cpu); | 
					
						
							|  |  |  | extern void irq_ctx_exit(int cpu); | 
					
						
							|  |  |  | # define __ARCH_HAS_DO_SOFTIRQ
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | # define irq_ctx_init(cpu) do { } while (0)
 | 
					
						
							|  |  |  | # define irq_ctx_exit(cpu) do { } while (0)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-13 20:16:47 +09:00
										 |  |  | #ifdef CONFIG_CPU_SH5
 | 
					
						
							| 
									
										
										
										
											2008-07-29 08:09:44 +09:00
										 |  |  | #include <cpu/irq.h>
 | 
					
						
							| 
									
										
										
										
											2008-02-13 20:16:47 +09:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #endif /* __ASM_SH_IRQ_H */
 |