diff options
Diffstat (limited to 'sys/arch/hppa')
-rw-r--r-- | sys/arch/hppa/include/intr.h | 220 |
1 files changed, 45 insertions, 175 deletions
diff --git a/sys/arch/hppa/include/intr.h b/sys/arch/hppa/include/intr.h index e6ef8eb485a..a469c574e2d 100644 --- a/sys/arch/hppa/include/intr.h +++ b/sys/arch/hppa/include/intr.h @@ -1,4 +1,4 @@ -/* $OpenBSD: intr.h,v 1.3 1998/07/14 17:47:28 mickey Exp $ */ +/* $OpenBSD: intr.h,v 1.4 1998/11/23 03:32:19 mickey Exp $ */ /* * Copyright (c) 1990,1991,1992,1994 The University of Utah and @@ -24,138 +24,26 @@ * Author: Jeff Forys, Bob Wheeler, University of Utah CSL */ -#ifndef _HPPA_INTR_H_ -#define _HPPA_INTR_H_ +#ifndef _MACHINE_INTR_H_ +#define _MACHINE_INTR_H_ -/* - * While the original 8 SPL's were "plenty", the PA-RISC chip provides us - * with 32 possible interrupt levels. We take advantage of this by using - * the standard SPL names (e.g. splbio, splimp) and mapping them into the - * PA-RISC interrupt scheme. Obviously, to understand how SPL's work on - * the PA-RISC, one must first have an understanding as to how interrupts - * are handled on these chips! - * - * Briefly, the CPU has a 32-bit control register for External Interrupt - * Requests (EIR). Each bit corresponds to a specific external interrupt. - * Bits in the EIR can be masked by the External Interrupt Enable Mask - * (EIEM) control register. Zero bits in the EIEM mask pending external - * interrupt requests for the corresponding bit positions. Finally, the - * PSW I-bit must be set to allow interrupts to occur. - * - * SPL values then, are possible values for the EIEM. For example, SPL0 - * would set the EIEM to 0xffffffff (enable all external interrupts), and - * SPLCLOCK would set the EIEM to 0x0 (disable all external interrupts). - */ +#define CPU_NINTS 32 -/* - * Define all possible External Interrupt Enable Masks (EIEMs). - */ -#define INTPRI_00 0x00000000 -#define INTPRI_01 0x80000000 -#define INTPRI_02 0xc0000000 -#define INTPRI_03 0xe0000000 -#define INTPRI_04 0xf0000000 -#define INTPRI_05 0xf8000000 -#define INTPRI_06 0xfc000000 -#define INTPRI_07 0xfe000000 -#define INTPRI_08 0xff000000 -#define INTPRI_09 0xff800000 -#define INTPRI_10 0xffc00000 -#define INTPRI_11 0xffe00000 -#define INTPRI_12 0xfff00000 -#define INTPRI_13 0xfff80000 -#define INTPRI_14 0xfffc0000 -#define INTPRI_15 0xfffe0000 -#define INTPRI_16 0xffff0000 -#define INTPRI_17 0xffff8000 -#define INTPRI_18 0xffffc000 -#define INTPRI_19 0xffffe000 -#define INTPRI_20 0xfffff000 -#define INTPRI_21 0xfffff800 -#define INTPRI_22 0xfffffc00 -#define INTPRI_23 0xfffffe00 -#define INTPRI_24 0xffffff00 -#define INTPRI_25 0xffffff80 -#define INTPRI_26 0xffffffc0 -#define INTPRI_27 0xffffffe0 -#define INTPRI_28 0xfffffff0 -#define INTPRI_29 0xfffffff8 -#define INTPRI_30 0xfffffffc -#define INTPRI_31 0xfffffffe -#define INTPRI_32 0xffffffff +/* hardwired clock int line */ +#define INT_ITMR (0x80000000) -/* - * Convert PA-RISC EIEMs into machine-independent SPLs as follows: - * - * 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 2 2 3 3 - * 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 - * +-+-+-+-+-+-+-+-+---+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ - * |c|p| | |v| | | |b i| | | | | | | |t| | | | | | | |n| | |s| | | | | - * |l|w| | |m| | | |i m| | | | | | | |t| | | | | | | |e| | |c| | | | | - * |k|r| | | | | | |o p| | | | | | | |y| | | | | | | |t| | |l| | | | | - * | | | | | | | | | | | | | | | | | | | | | | | | | | | |k| | | | | - * +-+-+-+-+-+-+-+-+---+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ - * - * The machine-dependent SPL's are also included below (indented). - * To change the interrupt priority of a particular device, you need - * only change it's corresponding #define below. - * - * Notes: - * - software prohibits more than one machine-dependent SPL per bit on - * a given architecture (e.g. hp700 or hp800). In cases where there - * are multiple equivalent devices which interrupt at the same level - * (e.g. ASP RS232 #1 and #2), the interrupt table insertion routine - * will always add in the unit number (arg0) to offset the entry. - * - hard clock must be the first bit (i.e. 0x80000000). - * - SPL7 is any non-zero value (since the PSW I-bit is off). - * - SPLIMP serves two purposes: blocks network interfaces and blocks - * memory allocation via malloc. In theory, SPLLAN would be high - * enough. However, on the 700, the SCSI driver uses malloc at - * interrupt time requiring SPLIMP >= SPLBIO. On the 800, we are - * still using HP-UX drivers which make the assumption that - * SPLIMP >= SPLCIO. New drivers would address both problems. - */ -#define SPLHIGH 0x00000007 /* any non-zero, non-INTPRI value */ -#define SPLCLOCK INTPRI_00 /* hard clock */ -#define SPLPOWER INTPRI_01 /* power failure (unused) */ -#define SPLVIPER INTPRI_03 /* (hp700) Viper */ -#define SPLVM INTPRI_04 /* TLB shootdown (unused) */ -#define SPLBIO INTPRI_08 /* block I/O */ -#define SPLASP INTPRI_08 /* (hp700) ASP */ -#define SPLCIO INTPRI_08 /* (hp800) CIO */ -#define SPLIMP INTPRI_08 /* network & malloc */ -#define SPLEISA INTPRI_09 /* (hp700 EISA) */ -#define SPLCIOHPIB INTPRI_09 /* (hp800) CIO HP-IB */ -#define SPLFWSCSI INTPRI_10 /* (hp700 internal FW SCSI) */ -#define SPLSCSI INTPRI_11 /* (hp700 internal SCSI) */ -#define SPLLAN INTPRI_12 /* (hp700 LAN) */ -#define SPLCIOLAN INTPRI_12 /* (hp800 CIO LAN) */ -#define SPLFDDI_1 INTPRI_13 /* FDDI #1 (graphics #1) */ -#define SPLFDDI_2 INTPRI_14 /* FDDI #2 (graphics #2) */ -#define SPLTTY INTPRI_16 /* TTY */ -#define SPLCIOMUX INTPRI_16 /* (hp800) CIO MUX */ -#define SPLDCA INTPRI_16 /* (hp700) RS232 #1 */ -/* INTPRI_17 * (hp700) RS232 #2 */ -#define SPLGRF INTPRI_18 /* (hp700/hp800) graphics #1) */ -/* INTPRI_19 * (hp700/hp800) graphics #2) */ -#define SPLHIL INTPRI_20 /* (hp700/hp800) HIL */ -#define SPLNET INTPRI_24 /* soft net */ -#define SPLSCLK INTPRI_27 /* soft clock */ -#define SPL0 INTPRI_32 /* no interrupts masked */ +#define IPL_NONE 0 +#define IPL_BIO 1 +#define IPL_NET 2 +#define IPL_TTY 3 +#define IPL_CLOCK 4 +#define IPL_HIGH 5 -/* - * Define interrupt bits/masks. - * N.B. A lower privilege transfer trap uses an illegal SPL_IBIT. - */ -#define SPL_IMASK_CLOCK INTPRI_01 +#define IST_NONE 0 +#define IST_PULSE 1 +#define IST_EDGE 2 +#define IST_LEVEL 3 -#define SPL_IBIT_CIO 8 -#define SPL_IBIT_CIOHPIB 9 -#define SPL_IBIT_CIOLAN 12 -#define SPL_IBIT_CIOMUX 16 -#define SPL_IBIT_SOFTNET 24 -#define SPL_IBIT_SOFTCLK 27 -#define SPL_IBIT_LPRIV 32 /* fake interrupt */ #if !defined(_LOCORE) /* @@ -167,61 +55,43 @@ * arguments. However, when the argument can be variable, there * is little or no win; as a result, splx() is not inline'd. */ -#define __splhigh(splhval) \ -({ \ - register unsigned int _ctl_r; \ - __asm __volatile ("mfctl 15,%0" : "=r" (_ctl_r) : ); \ - __asm __volatile ("mtctl %0,15" : : "r" (splhval) ); \ - __asm __volatile ("rsm 1,%%r0" : : ); \ - _ctl_r; \ +#define __splhigh(splhval) ({ \ + register u_int _ctl_r; \ + __asm __volatile("mfctl %%cr15,%0" : "=r" (_ctl_r)); \ + __asm __volatile("mtctl %0,%%cr15" :: "r" (splhval)); \ + __asm __volatile("rsm 1, %%r0"::); \ + _ctl_r; \ }) -#define __spllow(spllval) \ -({ \ - register unsigned int _ctl_r; \ - __asm __volatile ("mfctl 15,%0" : "=r" (_ctl_r) : ); \ - __asm __volatile ("mtctl %0,15" : : "r" (spllval) ); \ - __asm __volatile ("ssm 1,%%r0" : : ); \ - _ctl_r; \ +#define __spllow(spllval) ({ \ + register u_int _ctl_r; \ + __asm __volatile("mfctl %%cr15,%0" : "=r" (_ctl_r)); \ + __asm __volatile("mtctl %0,%%cr15" :: "r" (spllval)); \ + __asm __volatile("ssm 1, %%r0"::); \ + _ctl_r; \ }) -#define splhigh() __splhigh(SPLHIGH) -#define splclock() __spllow(SPLCLOCK) -#define splpower() __spllow(SPLPOWER) -#define splvm() __spllow(SPLVM) -#define splbio() __spllow(SPLBIO) -#define splimp() __spllow(SPLIMP) -#define spltty() __spllow(SPLTTY) -#define splnet() __spllow(SPLNET) -#define splstatclock() __spllow(SPLCLOCK) -#define splsoft() __spllow(SPLSCLK) +#define spl0() __spllow(0xffffffff) +#define splsoft() __spllow(INT_ITMR) #define splsoftnet() splsoft() #define splsoftclock() splsoft() -#define spl0() __spllow(SPL0) - +#define splnet() __spllow(INT_ITMR) +#define splbio() __spllow(INT_ITMR) +#define splimp() __spllow(INT_ITMR) +#define spltty() __spllow(INT_ITMR) +#define splclock() __spllow(0) +#define splstatclock() __spllow(0) +#define splhigh() __splhigh(0) int splx __P((int)); -#define setsoftclock() (PAGE0->mem_hpa->io_eir = SPL_IBIT_SOFTCLK) -#define setsoftnet() (void)(1) -/* - * BASEPRI is true when the specified EIEM is equal to the SPL level of - * the idle loop in swtch() (i.e. SPL0). - */ -#define BASEPRI(eiem) ((eiem) == (unsigned int)SPL0) +/* software interrupt register */ +extern u_int32_t sir; -/* - * This is a generic interrupt switch table. It may be used by various - * interrupt systems. For each interrupt, it holds a handler and an - * EIEM mask (selected from SPL* or, more generally, INTPRI*). - * - * So that these tables can be easily found, please prefix them with - * the label "itab_" (e.g. "itab_proc"). - */ -struct intrtab { - int (*handler) __P((void)); /* ptr to routine to call */ - unsigned int intpri; /* INTPRI (SPL) with which to call it */ - int arg0, arg1; /* 2 arguments to handler: arg0 is unit */ -}; +#define SIR_CLOCK 0x01 +#define SIR_NET 0x02 + +#define setsoftclock() (sir |= SIR_CLOCK) +#define setsoftnet() (sir |= SIR_NET) #endif /* !_LOCORE */ -#endif /* _HPPA_INTR_H_ */ +#endif /* _MACHINE_INTR_H_ */ |