summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/mvme88k/dev/syscon.c17
-rw-r--r--sys/arch/mvme88k/include/mvme188.h336
-rw-r--r--sys/arch/mvme88k/mvme88k/m188_machdep.c105
3 files changed, 216 insertions, 242 deletions
diff --git a/sys/arch/mvme88k/dev/syscon.c b/sys/arch/mvme88k/dev/syscon.c
index 4a09e3998fd..bc02b437717 100644
--- a/sys/arch/mvme88k/dev/syscon.c
+++ b/sys/arch/mvme88k/dev/syscon.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: syscon.c,v 1.23 2005/07/18 02:43:25 fgsch Exp $ */
+/* $OpenBSD: syscon.c,v 1.24 2006/04/15 15:45:21 miod Exp $ */
/*
* Copyright (c) 1999 Steve Murphree, Jr.
* All rights reserved.
@@ -175,8 +175,8 @@ int
sysconabort(eframe)
void *eframe;
{
- ISR_RESET_NMI;
- nmihand((struct frame *)eframe);
+ *(volatile u_int32_t *)MVME188_CLRINT = ISTATE_ABORT;
+ nmihand(eframe);
return (1);
}
@@ -184,8 +184,8 @@ int
sysconsysfail(eframe)
void *eframe;
{
- ISR_RESET_SYSFAIL;
- nmihand((struct frame *)eframe);
+ *(volatile u_int32_t *)MVME188_CLRINT = ISTATE_SYSFAIL;
+ printf("WARNING: SYSFAIL* ASSERTED\n");
return (1);
}
@@ -193,8 +193,8 @@ int
sysconacfail(eframe)
void *eframe;
{
- ISR_RESET_ACFAIL;
- nmihand((struct frame *)eframe);
+ *(volatile u_int32_t *)MVME188_CLRINT = ISTATE_ACFAIL;
+ printf("WARNING: ACFAIL* ASSERTED\n");
return (1);
}
@@ -202,6 +202,7 @@ int
sysconm188(eframe)
void *eframe;
{
- printf("MVME188 interrupting?\n");
+ /* shouldn't happen! */
+ printf("MVME188: self-inflicted interrupt\n");
return (1);
}
diff --git a/sys/arch/mvme88k/include/mvme188.h b/sys/arch/mvme88k/include/mvme188.h
index 2184e8d7d0f..9a836a7ba8e 100644
--- a/sys/arch/mvme88k/include/mvme188.h
+++ b/sys/arch/mvme88k/include/mvme188.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: mvme188.h,v 1.21 2006/04/13 21:16:15 miod Exp $ */
+/* $OpenBSD: mvme188.h,v 1.22 2006/04/15 15:45:24 miod Exp $ */
/*
* Copyright (c) 1999 Steve Murphree, Jr.
* All rights reserved.
@@ -46,228 +46,170 @@
#ifndef __MACHINE_MVME188_H__
#define __MACHINE_MVME188_H__
-#define MVME188_EPROM 0xFFC00000
+#define MVME188_EPROM 0xffc00000
#define MVME188_EPROM_SIZE 0x00080000
-#define MVME188_SRAM 0xFFE00000
+#define MVME188_SRAM 0xffe00000
#define MVME188_SRAM_SIZE 0x00020000
-#define MVME188_UTILITY 0xFF000000
+#define MVME188_UTILITY 0xff000000
#define MVME188_UTILITY_SIZE 0x01000000
-#define UTIL_START 0xFFC00000 /* start of MVME188 utility space */
-#define UTIL_SIZE 0x003FFFFF /* size of MVME188 utility space */
+#define UTIL_START 0xffc00000 /* start of MVME188 utility space */
+#define UTIL_SIZE 0x003fffff /* size of MVME188 utility space */
/*
* MVME188 declarations for hardware level device registers and such.
*/
-/* base address for the interrupt control registers */
-#define INTR_CONTROL_BASE 0xfff84000
-#define VMEA24SPACE 0xEEC00000 /* VMEA24 master addr space (4 Meg) */
-
/* per-processor interrupt enable registers */
-#define MVME188_IEN0 0xFFF84004 /* interrupt enable CPU 0 */
-#define MVME188_IEN1 0xFFF84008 /* interrupt enable CPU 1 */
-#define MVME188_IEN2 0xFFF84010 /* interrupt enable CPU 2 */
-#define MVME188_IEN3 0xFFF84020 /* interrupt enable CPU 3 */
-
-/* same as above */
-#define IEN0_REG 0xfff84004
-#define IEN1_REG 0xfff84008
-#define IEN2_REG 0xfff84010
-#define IEN3_REG 0xfff84020
-
-#define IENALL_REG 0xfff8403c
-
-#define MVME188_IST 0xFFF84040 /* interrupt status register */
-#define IST_REG 0xfff84040 /* same as above */
-
-#define MVME188_SETSWI 0xFFF84080 /* generate soft interrupt */
-#define MVME188_CLRSWI 0xFFF84084 /* reset soft interrupt */
-#define MVME188_ISTATE 0xFFF84088 /* HW interrupt status */
-#define MVME188_CLRINT 0xFFF8408C /* reset HW interrupt */
-
-/* same as above */
-#define SETSWI_REG 0xfff84080 /* SETSWI register addr */
-#define CLRSWI_REG 0xfff84084 /* CLRSWI register addr */
-#define ISTATE_REG 0xfff84088
-#define CLRINT_REG 0xfff8408C
-
-#define MVME188_VIRQLV 0xFFF85000
-#define MVME188_VIACK1V 0xFFF85004
-#define MVME188_VIACK2V 0xFFF85008
-#define MVME188_VIACK3V 0xFFF8500C
-#define MVME188_VIACK4V 0xFFF85010
-#define MVME188_VIACK5V 0xFFF85014
-#define MVME188_VIACK6V 0xFFF85018
-#define MVME188_VIACK7V 0xFFF8501C
-#define MVME188_VIRQV 0xFFF85020
+#define MVME188_IEN0 0xfff84004 /* interrupt enable CPU 0 */
+#define MVME188_IEN1 0xfff84008 /* interrupt enable CPU 1 */
+#define MVME188_IEN2 0xfff84010 /* interrupt enable CPU 2 */
+#define MVME188_IEN3 0xfff84020 /* interrupt enable CPU 3 */
+#define MVME188_IENALL 0xfff8403c /* simultaneous write */
+
+#define MVME188_IST 0xfff84040 /* interrupt status register */
+
+#define MVME188_SETSWI 0xfff84080 /* generate soft interrupt */
+#define MVME188_CLRSWI 0xfff84084 /* reset soft interrupt */
+#define MVME188_ISTATE 0xfff84088 /* HW interrupt status */
+#define MVME188_CLRINT 0xfff8408c /* reset HW interrupt */
+
+#define MVME188_VIRQLV 0xfff85000
+#define MVME188_VIACK1V 0xfff85004
+#define MVME188_VIACK2V 0xfff85008
+#define MVME188_VIACK3V 0xfff8500c
+#define MVME188_VIACK4V 0xfff85010
+#define MVME188_VIACK5V 0xfff85014
+#define MVME188_VIACK6V 0xfff85018
+#define MVME188_VIACK7V 0xfff8501c
+#define MVME188_VIRQV 0xfff85020
#define M188_IVEC 0x40 /* vector returned upon MVME188 int */
-#define MVME188_GCSR 0xFFF86000 /* 188 global control and status reg */
-#define MVME188_UCSR 0xFFF87000 /* 188 utility control and status reg */
-#define MVME188_BASAD 0xFFF87004 /* 188 base address reg */
-#define MVME188_GLBRES 0xFFF8700C /* 188 global reset reg */
-
-#define GCSR_BASE 0xfff86000
+#define MVME188_GCSR 0xfff86000 /* global control and status reg */
#define GLB0 0xfff86001
#define GLB1 0xfff86003
#define GLB2 0xfff86005
#define GLB3 0xfff86007
#define M188_LRST 0x00000080
#define M188_SYSCON 0x00000040
-#define UCSR_REG 0xfff87000
-#define GLBRES_REG 0xfff8700C
-
-#define MVME188_CCSR 0xFFF88000 /* 188 CPU board control status reg */
-#define MVME188_ERROR 0xFFF88004 /* 188 Mbus fault reg */
-#define MVME188_PCNFA 0xFFF88008 /* 188 Pbus A decoder reg */
-#define MVME188_PCNFB 0xFFF8800C /* 188 Pbus B decoder reg */
-#define MVME188_EXTAD 0xFFF88010 /* 188 A24 master A24-A31 addr reg */
-#define MVME188_WHOAMI 0xFFF88018 /* 188 whoami reg */
-#define MVME188_WMAD 0xFFF88020 /* 188 write mbus addr decoder reg */
-#define MVME188_RMAD 0xFFF88024 /* 188 read mbus addr decoder reg */
-#define MVME188_WVAD 0xFFF88028 /* 188 write vmebus addr decoder reg */
-#define MVME188_RVAD 0xFFF8802C /* 188 read vmebus adds decoder reg */
-
-/* duplicates of above */
-#define CCSR_REG 0xfff88000
-#define ERROR_REG 0xfff88004 /* ERROR register addr */
-#define PCNFA_REG 0xfff88008
-#define PCNFB_REG 0xfff8800c
-#define EXTAD_REG 0xfff88010
-#define EXTAM_REG 0xfff88014
-#define WHOAMI_REG 0xfff88018 /* WHOAMI register addr */
-#define WMAD_REG 0xfff88020
-#define RMAD_REG 0xfff88024
-#define WVAD_REG 0xfff88028
-#define RVAD_REG 0xfff8802c
-
-#define MAD_MDS 0x07 /* 188 MAD Device Select bits */
-
-#define VMEA24 0x5 /* Mbus addess decode select for VMEA24 */
-#define VADV 0x1 /* vmeaddres decode enable */
-#define VBDSELBIT 0 /* bit to enable vme slave response low true */
-#define VBDISABLE 0x1 /* VME BUS Disable */
-#define VSDBIT 1 /* bit number to enable snooping low true */
-#define VSDISABLE 0x2 /* VME Snoop Disable */
-#define VASPBIT 21 /* addr space 0 = A32, 1 = A24 bit */
-#define VASP 0x00200000 /* A24 VME address space */
-#define VPN 0x00400000 /* Page Number LSB */
-#define PAGECNT 0x400 /* number of (4 meg) pages to map */
-
-#define UCSR_PWRUPBIT 0x4000 /* 188 UCSR powerup indicator */
-#define UCSR_DRVSFBIT 0x2000 /* 188 UCSR Board system fail */
-#define UCSR_BRIRQBIT 0x1000 /* 188 UCSR drives VME IRQ1 broadcast int */
-#define UCSR_ROBINBIT 0x800 /* 188 UCSR sel round robin VME arbiter mode */
-#define UCSR_BRLVBITS 0x600 /* 188 UCSR VME bus request level 0-3 */
-#define UCSR_RNEVERBIT 0x100 /* 188 UCSR VME bus never release once req'd */
-#define UCSR_RONRBIT 0x80 /* 188 UCSR VME bus req release on no request */
-#define UCSR_RWDBIT 0x40 /* 188 UCSR VME bus request release when done */
-#define UCSR_EARBTOBIT 0x20 /* 188 UCSR enable VME arbiter bus timeout */
-
-/* MVME188 VMEbus data transfer timeout select */
-#define VTOSELBITS 0x18 /* 188 UCSR VMEbus timeout select bits */
-#define VTO32US 0x00 /* VMEbus timeout length - 32 MicroSec */
-#define VTO64US 0x01 /* VMEbus timeout length - 64 MicroSec */
-#define VTO128US 0x10 /* VMEbus timeout length - 128 MicroSec */
-#define VTODISABLE 0x18 /* VMEbus timeout length - disabled */
+#define MVME188_UCSR 0xfff87000 /* utility control and status reg */
+#define MVME188_BASAD 0xfff87004 /* base address reg */
+#define MVME188_GLBRES 0xfff8700c /* global reset reg */
+
+#define MVME188_CCSR 0xfff88000 /* CPU board control status reg */
+#define MVME188_ERROR 0xfff88004 /* Mbus fault reg */
+#define MVME188_PCNFA 0xfff88008 /* Pbus A decoder reg */
+#define MVME188_PCNFB 0xfff8800c /* Pbus B decoder reg */
+#define MVME188_EXTAD 0xfff88010 /* A24 master A24-A31 addr reg */
+#define MVME188_WHOAMI 0xfff88018 /* whoami reg */
+#define MVME188_WMAD 0xfff88020 /* write mbus addr decoder reg */
+#define MVME188_RMAD 0xfff88024 /* read mbus addr decoder reg */
+#define MVME188_WVAD 0xfff88028 /* write vmebus addr decoder reg */
+#define MVME188_RVAD 0xfff8802c /* read vmebus adds decoder reg */
/*
- * processor dependend code section
- * main goal is to concentrate HW dependencies into a few lines
+ * IEN and IST register bits
+ * Refer to MVME188 RISC Microcomputer User's Manual, table 4.3
*/
-#define ISR_LOW_SOFTINT_MASK(cpu) (1 << (cpu))
-#define ISR_HIGH_SOFTINT_MASK(cpu) (1 << ((cpu) + 24))
-#define ISR_LOW_SOFTMASK 0xf
-#define ISR_HIGH_SOFTMASK (0xf << 24)
-#define ISR_SOFTINT_EXCEPT_MASK(cpu) \
- (ISR_LOW_SOFTINT_MASK(cpu) | ISR_HIGH_SOFTINT_MASK(cpu) | 0xf0fffff0)
-#define ISR_CLOCKINT_MASK (1 << IEN_CIOI_LOG)
-
-#define ISR_RESET_NMI *(int *volatile)MVME188_CLRINT = 1 << CLRINT_CLRABRTI_LOG
-#define ISR_RESET_SYSFAIL *(int *volatile)MVME188_CLRINT = 1 << CLRINT_CLRSFI_LOG
-#define ISR_RESET_ACFAIL *(int *volatile)MVME188_CLRINT = 1 << CLRINT_CLRACFI_LOG
-#define ISR_RESET_LOW_SOFTINT(cpu) *(int *)MVME188_CLRSWI = ISR_LOW_SOFTINT_MASK(cpu)
-#define ISR_RESET_HIGH_SOFTINT(cpu) *(int *)MVME188_CLRSWI = (1 << (cpu + MAX_CPUS))
-#define ISR_DETERMINE_LOW_SOFTINT(cpu) *(unsigned int *volatile)MVME188_IST & ISR_LOW_SOFTINT_MASK(cpu)
-#define ISR_DETERMINE_HIGH_SOFTINT(cpu) *(unsigned int *volatile)MVME188_IST & ISR_HIGH_SOFTINT_MASK(cpu)
-#define ISR_GENERATE_LOW_SOFTINT(cpu) *((unsigned int *volatile)MVME188_SETSWI) = ISR_LOW_SOFTINT_MASK(cpu)
-#define ISR_GENERATE_HIGH_SOFTINT(cpu) *((unsigned int *volatile)MVME188_SETSWI) = (1 << (cpu + MAX_CPUS))
-#define ISR_RESET_MACHINE *((unsigned *volatile) MVME188_GLBRES) = 1
-#define ISR_GET_CURRENT_MASK(cpu) *int_mask_reg[cpu] & *(int *volatile)MVME188_IST
-
-#define IST_STRING "\20\40ABRT\37ACF\36ARBTO\35DTI\34SWI7\33SWI6\32SWI5\31SWI4\30IRQ7\27res\26CIOI\25SF\24IRQ6\23res\22DI\21SIGHPI\20res\17IRQ5\16res\15IRQ4\14res\13IRQ3\12res\11LWI\10SIGLPI\7IRQ2\6res\5IRQ1\4SWI3\3SWI2\2SWI1\1SWI0"
+
+#define IRQ_ABORT 0x80000000 /* 31 */
+#define IRQ_ACF 0x40000000 /* 30 */
+#define IRQ_ARBTO 0x20000000 /* 29 */
+#define IRQ_DTI 0x10000000 /* 28 */
+#define IRQ_SWI7 0x08000000 /* 27 */
+#define IRQ_SWI6 0x04000000 /* 26 */
+#define IRQ_SWI5 0x02000000 /* 25 */
+#define IRQ_SWI4 0x01000000 /* 24 */
+#define IRQ_VME7 0x00800000 /* 23 */
+#define IRQ_CIOI 0x00200000 /* 21 */
+#define IRQ_SF 0x00100000 /* 20 */
+#define IRQ_VME6 0x00080000 /* 19 */
+#define IRQ_DI 0x00020000 /* 17 */
+#define IRQ_SIGHPI 0x00010000 /* 16 */
+#define IRQ_VME5 0x00004000 /* 14 */
+#define IRQ_VME4 0x00001000 /* 12 */
+#define IRQ_VME3 0x00000400 /* 10 */
+#define IRQ_LMI 0x00000100 /* 08 */
+#define IRQ_SIGLPI 0x00000080 /* 07 */
+#define IRQ_VME2 0x00000040 /* 06 */
+#define IRQ_VME1 0x00000010 /* 04 */
+#define IRQ_SWI3 0x00000008 /* 03 */
+#define IRQ_SWI2 0x00000004 /* 02 */
+#define IRQ_SWI1 0x00000002 /* 01 */
+#define IRQ_SWI0 0x00000001 /* 00 */
+
+#define IST_STRING "\20" \
+ "\40ABRT\37ACF\36ARBTO\35DTI\34SWI7\33SWI6\32SWI5\31SWI4" \
+ "\30IRQ7\26CIOI\25SF\24IRQ6\22DI\21SIGHPI" \
+ "\17IRQ5\15IRQ4\13IRQ3\11LWI" \
+ "\10SIGLPI\7IRQ2\5IRQ1\4SWI3\3SWI2\2SWI1\1SWI0"
+
+/* groups by function */
+
+/* hardware irq bits */
+#define HW_FAILURE_MASK (IRQ_ABORT | IRQ_ACF | IRQ_ARBTO | IRQ_SF)
+/* software irq bits */
+#define SOFT_INTERRUPT_MASK (IRQ_SWI7 | IRQ_SWI6 | IRQ_SWI5 | IRQ_SWI4 | \
+ IRQ_SWI3 | IRQ_SWI2 | IRQ_SWI1 | IRQ_SWI0)
+/* VME irq bits */
+#define VME_INTERRUPT_MASK (IRQ_VME7 | IRQ_VME6 | IRQ_VME5 | IRQ_VME4 | \
+ IRQ_VME3 | IRQ_VME2 | IRQ_VME1)
+/* on-board irq bits */
+#define OBIO_INTERRUPT_MASK (IRQ_DTI | IRQ_CIOI | IRQ_DI | IRQ_SIGHPI | \
+ IRQ_LMI | IRQ_SIGLPI)
+
+/* groups by interrupt levels */
+
+#define LVL7 (IRQ_ABORT | IRQ_ACF | IRQ_VME7 | IRQ_SF)
+#define LVL6 (IRQ_VME6)
+#define LVL5 (IRQ_VME5 | IRQ_DTI | IRQ_CIOI)
+#define LVL4 (IRQ_VME4)
+#define LVL3 (IRQ_VME3 | IRQ_DI)
+#define LVL2 (IRQ_VME2)
+#define LVL1 (IRQ_VME1)
+#define LVL0 (0x0)
+
+/* interrupts we want to process on the master CPU only */
+#define SLAVE_MASK (HW_FAILURE_MASK | OBIO_INTERRUPT_MASK)
+
+#define MASK_LVL_0 (LVL7 | LVL6 | LVL5 | LVL4 | LVL3 | LVL2 | LVL1)
+#define MASK_LVL_1 (LVL7 | LVL6 | LVL5 | LVL4 | LVL3 | LVL2)
+#define MASK_LVL_2 (LVL7 | LVL6 | LVL5 | LVL4 | LVL3)
+#define MASK_LVL_3 (LVL7 | LVL6 | LVL5 | LVL4)
+#define MASK_LVL_4 (LVL7 | LVL6 | LVL5)
+#define MASK_LVL_5 (LVL7 | LVL6)
+#define MASK_LVL_6 (LVL7)
+#define MASK_LVL_7 0x00000000 /* all ints disabled */
#define INT_LEVEL 8 /* # of interrupt level + 1 */
+#define ISR_GET_CURRENT_MASK(cpu) \
+ (*(volatile u_int *)MVME188_IST & *int_mask_reg[cpu])
-#define IEN_ABRT_LOG 31
-#define IEN_CIOI_LOG 21
-#define IEN_DTI_LOG 28
-#define IEN_DI_LOG 17
-
-#define CLRINT_CLRABRTI_LOG 2 /* offset into CLRSWI */
-#define CLRINT_CLRACFI_LOG 1 /* offset into CLRSWI */
-#define CLRINT_CLRSFI_LOG 0 /* offset into CLRSWI */
-
-/* the following codes are the INT exception enable and status bits. */
-/* Refer to MVME188 RISC Microcomputer User's Manual, 4-10. */
-#define ABRT_BIT 0x80000000 /* 31 */
-#define ACF_BIT 0x40000000 /* 30 */
-#define ARBTO_BIT 0x20000000 /* 29 */
-#define DTI_BIT 0x10000000 /* 28 */
-#define SWI7_BIT 0x08000000 /* 27 */
-#define SWI6_BIT 0x04000000 /* 26 */
-#define SWI5_BIT 0x02000000 /* 25 */
-#define SWI4_BIT 0x01000000 /* 24 */
-#define IRQ7_BIT 0x00800000 /* 23 */
-#define CIOI_BIT 0x00200000 /* 21 */
-#define SF_BIT 0x00100000 /* 20 */
-#define IRQ6_BIT 0x00080000 /* 19 */
-#define DI_BIT 0x00020000 /* 17 */
-#define SIGHPI_BIT 0x00010000 /* 16 */
-#define IRQ5_BIT 0x00004000 /* 14 */
-#define IRQ4_BIT 0x00001000 /* 12 */
-#define IRQ3_BIT 0x00000400 /* 10 */
-#define LMI_BIT 0x00000100 /* 08 */
-#define SIGLPI_BIT 0x00000080 /* 07 */
-#define IRQ2_BIT 0x00000040 /* 06 */
-#define IRQ1_BIT 0x00000010 /* 04 */
-#define SWI3_BIT 0x00000008 /* 03 */
-#define SWI2_BIT 0x00000004 /* 02 */
-#define SWI1_BIT 0x00000002 /* 01 */
-#define SWI0_BIT 0x00000001 /* 00 */
+/*
+ * ISTATE and CLRINT register bits
+ */
+
+#define ISTATE_ABORT 0x04
+#define ISTATE_ACFAIL 0x02
+#define ISTATE_SYSFAIL 0x01
/*
- * masks and offsets for IST
- * These are a combination of the above
+ * UCSR register bits
*/
-#define HW_FAILURE_MASK 0xE0100000 /* hardware irq bits */
-#define SOFT_INTERRUPT_MASK 0x0F00000F /* software irq bits */
-#define VME_INTERRUPT_MASK 0x00885450 /* vme irq bits */
-#define OBIO_INTERRUPT_MASK 0x10330180 /* on board I/O */
-
-#define HW_FAILURE_ACF ACF_BIT /* AC failure */
-#define HW_FAILURE_ABRTO ARBTO_BIT /* Arbiter timeout */
-#define HW_FAILURE_SYSFAIL SF_BIT /* SYSFAIL asserted */
-#define HW_FAILURE_ABORT ABRT_BIT /* Abort pressed */
-
-#define LVL7 (ABRT_BIT | ACF_BIT | IRQ7_BIT | SF_BIT)
-#define LVL6 (IRQ6_BIT)
-#define LVL5 (IRQ5_BIT | DTI_BIT | CIOI_BIT)
-#define LVL4 (IRQ4_BIT)
-#define LVL3 (IRQ3_BIT | DI_BIT)
-#define LVL2 (IRQ2_BIT)
-#define LVL1 (IRQ1_BIT)
-#define LVL0 (0x0)
-#define SLAVE_MASK (LVL6 | LVL1)
-
-#define MASK_LVL_0 (LVL7 | LVL6 | LVL5 | LVL4 | LVL3 | LVL2 | LVL1)
-#define MASK_LVL_1 (LVL7 | LVL6 | LVL5 | LVL4 | LVL3 | LVL2)
-#define MASK_LVL_2 (LVL7 | LVL6 | LVL5 | LVL4 | LVL3)
-#define MASK_LVL_3 (LVL7 | LVL6 | LVL5 | LVL4)
-#define MASK_LVL_4 (LVL7 | LVL6 | LVL5)
-#define MASK_LVL_5 (LVL7 | LVL6)
-#define MASK_LVL_6 (LVL7)
-#define MASK_LVL_7 0x00000000 /* all ints disabled */
+
+#define UCSR_PWRUPBIT 0x00004000 /* powerup indicator */
+#define UCSR_DRVSFBIT 0x00002000 /* Board system fail */
+#define UCSR_BRIRQBIT 0x00001000 /* drives VME IRQ1 broadcast int */
+#define UCSR_ROBINBIT 0x00000800 /* sel round robin VME arbiter mode */
+#define UCSR_BRLVBITS 0x00000600 /* VME bus request level 0-3 */
+#define UCSR_RNEVERBIT 0x00000100 /* VME bus never release once req'd */
+#define UCSR_RONRBIT 0x00000080 /* VME bus req release on no request */
+#define UCSR_RWDBIT 0x00000040 /* VME bus request release when done */
+#define UCSR_EARBTOBIT 0x00000020 /* enable VME arbiter bus timeout */
+#define VTOSELBITS 0x00000018 /* VMEbus timeout select bits */
+#define VTO32US 0x00 /* 32 usec */
+#define VTO64US 0x01 /* 64 usec */
+#define VTO128US 0x10 /* 128 usec */
+#define VTODISABLE 0x18 /* disabled */
/* these are the various Z8536 CIO counter/timer registers */
#define CIO_BASE 0xfff83000
diff --git a/sys/arch/mvme88k/mvme88k/m188_machdep.c b/sys/arch/mvme88k/mvme88k/m188_machdep.c
index 7791d55cbf2..77c275fce79 100644
--- a/sys/arch/mvme88k/mvme88k/m188_machdep.c
+++ b/sys/arch/mvme88k/mvme88k/m188_machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: m188_machdep.c,v 1.13 2006/04/13 21:16:17 miod Exp $ */
+/* $OpenBSD: m188_machdep.c,v 1.14 2006/04/15 15:45:24 miod Exp $ */
/*
* Copyright (c) 1998, 1999, 2000, 2001 Steve Murphree, Jr.
* Copyright (c) 1996 Nivas Madhur
@@ -75,19 +75,27 @@ u_int m188_setipl(u_int);
void m188_startup(void);
/*
- * *int_mask_reg[CPU]
- * Points to the hardware interrupt status register for each CPU.
+ * The MVME188 interrupt arbiter has 25 orthogonal interrupt sources.
+ * We fold this model in the 8-level spl model this port uses, enforcing
+ * priorities manually with the interrupt masks.
+ */
+
+/*
+ * interrupt status register for each CPU.
*/
unsigned int *volatile int_mask_reg[] = {
- (unsigned int *)IEN0_REG,
- (unsigned int *)IEN1_REG,
- (unsigned int *)IEN2_REG,
- (unsigned int *)IEN3_REG
+ (unsigned int *)MVME188_IEN0,
+ (unsigned int *)MVME188_IEN1,
+ (unsigned int *)MVME188_IEN2,
+ (unsigned int *)MVME188_IEN3
};
unsigned int m188_curspl[] = {0, 0, 0, 0};
-unsigned int int_mask_val[INT_LEVEL] = {
+/*
+ * external interrupt masks per spl.
+ */
+const unsigned int int_mask_val[INT_LEVEL] = {
MASK_LVL_0,
MASK_LVL_1,
MASK_LVL_2,
@@ -119,8 +127,8 @@ m188_memsize()
#define MVME188_MAX_MEMORY ((4 * 64) / 4) /* 4 64MB boards */
for (pgnum = 0; pgnum < MVME188_MAX_MEMORY; pgnum++) {
- *(volatile int32_t *)RMAD_REG = (pgnum << 22);
- rmad = *(volatile int32_t *)RMAD_REG;
+ *(volatile int32_t *)MVME188_RMAD = (pgnum << 22);
+ rmad = *(volatile int32_t *)MVME188_RMAD;
if (rmad & 0x04) /* not a memory board */
break;
@@ -156,10 +164,7 @@ m188_bootstrap()
md_raiseipl = &m188_raiseipl;
/* clear and disable all interrupts */
- *(volatile u_int32_t *)IEN0_REG = 0;
- *(volatile u_int32_t *)IEN1_REG = 0;
- *(volatile u_int32_t *)IEN2_REG = 0;
- *(volatile u_int32_t *)IEN3_REG = 0;
+ *(volatile u_int32_t *)MVME188_IENALL = 0;
/* supply a vector base for m188ih */
*(volatile u_int8_t *)MVME188_VIRQV = M188_IVEC;
@@ -171,23 +176,20 @@ m188_reset()
volatile int cnt;
/* clear and disable all interrupts */
- *(volatile u_int32_t *)IEN0_REG = 0;
- *(volatile u_int32_t *)IEN1_REG = 0;
- *(volatile u_int32_t *)IEN2_REG = 0;
- *(volatile u_int32_t *)IEN3_REG = 0;
+ *(volatile u_int32_t *)MVME188_IENALL = 0;
if ((*(volatile u_int8_t *)GLB1) & M188_SYSCON) {
/* Force a complete VMEbus reset */
- *(volatile u_int32_t *)GLBRES_REG = 1;
+ *(volatile u_int32_t *)MVME188_GLBRES = 1;
} else {
/* Force only a local reset */
*(volatile u_int8_t *)GLB1 |= M188_LRST;
}
- *(volatile u_int32_t *)UCSR_REG |= 0x2000; /* clear SYSFAIL */
+ *(volatile u_int32_t *)MVME188_UCSR |= 0x2000; /* clear SYSFAIL */
for (cnt = 0; cnt < 5*1024*1024; cnt++)
;
- *(volatile u_int32_t *)UCSR_REG |= 0x2000; /* clear SYSFAIL */
+ *(volatile u_int32_t *)MVME188_UCSR |= 0x2000; /* clear SYSFAIL */
printf("reset failed\n");
}
@@ -201,12 +203,11 @@ safe_level(u_int mask, u_int curlevel)
int i;
for (i = curlevel; i < INT_LEVEL; i++)
- if (!(int_mask_val[i] & mask))
- return i;
+ if ((int_mask_val[i] & mask) == 0)
+ return (i);
- panic("safe_level: no safe level for mask 0x%08x level %d found",
- mask, curlevel);
- /* NOTREACHED */
+ /* NOTREACHED since int_mask_val[INT_LEVEL - 1] is zero */
+ return (INT_LEVEL - 1);
}
u_int
@@ -226,7 +227,7 @@ m188_setipl(u_int level)
mask = int_mask_val[level];
#ifdef MULTIPROCESSOR
if (cpu != master_cpu)
- mask &= SLAVE_MASK;
+ mask &= ~SLAVE_MASK;
#endif
*int_mask_reg[cpu] = mask;
@@ -246,7 +247,7 @@ m188_raiseipl(u_int level)
mask = int_mask_val[level];
#ifdef MULTIPROCESSOR
if (cpu != master_cpu)
- mask &= SLAVE_MASK;
+ mask &= ~SLAVE_MASK;
#endif
*int_mask_reg[cpu] = mask;
@@ -259,17 +260,47 @@ m188_raiseipl(u_int level)
* Device interrupt handler for MVME188
*/
-/* Hard coded vector table for onboard devices. */
+/*
+ * Hard coded vector table for onboard devices and hardware failure
+ * interrupts.
+ */
const unsigned int obio_vec[32] = {
- 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0,
- 0, SYSCV_SCC, 0, 0, SYSCV_SYSF, SYSCV_TIMER2, 0, 0,
- 0, 0, 0, 0, SYSCV_TIMER1, 0, SYSCV_ACF, SYSCV_ABRT
+ 0, /* SWI0 */
+ 0, /* SWI1 */
+ 0, /* SWI2 */
+ 0, /* SWI3 */
+ 0, /* VME1 */
+ 0,
+ 0, /* VME2 */
+ 0, /* SIGLPI */ /* no vector, but always masked */
+ 0, /* LMI */ /* no vector, but always masked */
+ 0,
+ 0, /* VME3 */
+ 0,
+ 0, /* VME4 */
+ 0,
+ 0, /* VME5 */
+ 0,
+ 0, /* SIGHPI */ /* no vector, but always masked */
+ SYSCV_SCC, /* DI */
+ 0,
+ 0, /* VME6 */
+ SYSCV_SYSF, /* SF */
+ SYSCV_TIMER2, /* CIOI */
+ 0,
+ 0, /* VME7 */
+ 0, /* SWI4 */
+ 0, /* SWI5 */
+ 0, /* SWI6 */
+ 0, /* SWI7 */
+ SYSCV_TIMER1, /* DTI */
+ 0, /* ARBTO */ /* no vector, but always masked */
+ SYSCV_ACF, /* ACF */
+ SYSCV_ABRT /* ABORT */
};
-#define GET_MASK(cpu, val) *int_mask_reg[cpu] & (val)
-#define VME_VECTOR_MASK 0x1ff /* mask into VIACK register */
-#define VME_BERR_MASK 0x100 /* timeout during VME IACK cycle */
+#define VME_VECTOR_MASK 0x1ff /* mask into VIACK register */
+#define VME_BERR_MASK 0x100 /* timeout during VME IACK cycle */
void
m188_ext_int(u_int v, struct trapframe *eframe)
@@ -341,7 +372,7 @@ m188_ext_int(u_int v, struct trapframe *eframe)
* For now, only the timer interrupt requires its condition
* to be cleared before interrupts are enabled.
*/
- if (unmasked == 0 && (cur_mask & DTI_BIT) == 0) {
+ if (unmasked == 0 && (cur_mask & IRQ_DTI) == 0) {
set_psr(get_psr() & ~PSR_IND);
unmasked = 1;
}