summaryrefslogtreecommitdiff
path: root/sys/arch/arc/algor/algorbus.c
diff options
context:
space:
mode:
authorPer Fogelstrom <pefo@cvs.openbsd.org>1998-03-16 09:38:53 +0000
committerPer Fogelstrom <pefo@cvs.openbsd.org>1998-03-16 09:38:53 +0000
commita963ca51673d0d081904efce31dd28f05d83e730 (patch)
treef51de935de8777cae9204bbaa29b11aa7007425d /sys/arch/arc/algor/algorbus.c
parentc1aa08ed9b8f4b392adef8685e4f55ff3b189dbb (diff)
DDB.
Support for Algorithmics R5000/R10000 evaluation board. So far only the RM5260 is supported. RM5270 - RM7000 later. R5000 and R10000 depending on access to cpu modules. vm_machdep.c moved to arch/mips/mips.
Diffstat (limited to 'sys/arch/arc/algor/algorbus.c')
-rw-r--r--sys/arch/arc/algor/algorbus.c139
1 files changed, 93 insertions, 46 deletions
diff --git a/sys/arch/arc/algor/algorbus.c b/sys/arch/arc/algor/algorbus.c
index bd80dab664f..b3dda7ae362 100644
--- a/sys/arch/arc/algor/algorbus.c
+++ b/sys/arch/arc/algor/algorbus.c
@@ -1,7 +1,7 @@
-/* $OpenBSD: algorbus.c,v 1.4 1998/01/29 14:54:45 pefo Exp $ */
+/* $OpenBSD: algorbus.c,v 1.5 1998/03/16 09:38:25 pefo Exp $ */
/*
- * Copyright (c) 1996 Per Fogelstrom
+ * Copyright (c) 1996, 1997, 1998 Per Fogelstrom, Opsycon AB
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
@@ -14,7 +14,7 @@
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed under OpenBSD by
- * Per Fogelstrom.
+ * Per Fogelstrom, Opsycon AB.
* 4. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
@@ -44,7 +44,7 @@
#include <machine/intr.h>
#include <machine/autoconf.h>
-#include <arc/arc/arctype.h>
+#include <mips/archtype.h>
#include <arc/algor/algor.h>
#include <dev/ic/mc146818reg.h>
@@ -76,7 +76,8 @@ int algor_clkintr __P((unsigned, struct clockframe *));
int algor_errintr __P((unsigned, struct clockframe *));
int p4032_imask = 0;
-int p4032_ixr = 0;
+int p4032_ixr0 = 0; /* Routing for local and panic ints. */
+int p4032_ixr1 = 0; /* Routing for pci and ide ints. */
/*
* Interrupt dispatch table.
@@ -98,14 +99,18 @@ static struct algor_int_desc int_table[] = {
{0, algor_intrnull, (void *)NULL, 0 }, /* 13 */
{0, algor_intrnull, (void *)NULL, 0 }, /* 14 */
{0, algor_intrnull, (void *)NULL, 0 }, /* 15 */
+ {0, algor_intrnull, (void *)NULL, 0 }, /* 16 */
+ {0, algor_intrnull, (void *)NULL, 0 }, /* 17 */
+ {0, algor_intrnull, (void *)NULL, 0 }, /* 18 */
+ {0, algor_intrnull, (void *)NULL, 0 }, /* 19 */
};
#define NUM_INT_SLOTS (sizeof(int_table) / sizeof(struct algor_int_desc))
struct algor_dev {
struct confargs ps_ca;
- u_int8_t ps_mask;
- u_int8_t ps_ipl;
- u_int16_t ps_route;
+ u_int8_t ps_mask; /* Interrupt mask register value */
+ u_int8_t ps_ipl; /* IPL to route int to */
+ u_int16_t ps_route; /* int routing mask bits */
intr_handler_t ps_handler;
void *ps_base;
};
@@ -121,27 +126,34 @@ struct algor_dev algor_4032_cpu[] = {
{{ NULL, -1, NULL, },
0, 0x0000, NULL, (void *)NULL, },
};
-#define NUM_ALGOR_DEVS (sizeof(algor_4032_cpu) / sizeof(struct algor_dev))
+
+struct algor_dev algor_5064_cpu[] = {
+ {{ "dallas_rtc", 0, 0, },
+ P4032_IM_RTC, IPL_CLOCK, 0xc000, algor_intrnull, (void *)P5064_CLOCK, },
+ {{ "com", 1, 0, },
+ P4032_IM_COM1, IPL_TTY, 0x00c0, algor_intrnull, (void *)P5064_COM1, },
+ {{ "com", 2, 0, },
+ P4032_IM_COM2, IPL_TTY, 0x0300, algor_intrnull, (void *)P5064_COM2, },
+ {{ "lpt", 3, 0, },
+ P4032_IM_CENTR,IPL_TTY, 0x0c00, algor_intrnull, (void *)P5064_CENTR, },
+ {{ NULL, -1, NULL, },
+ 0, 0x0000, NULL, (void *)NULL, },
+};
/* IPL routing values */
static int ipxrtab[] = {
- 0x000000, /* IPL_BIO */
- 0x555555, /* IPL_NET */
- 0xaaaaaa, /* IPL_TTY */
- 0xffffff, /* IPL_CLOCK */
+ 0x00000000, /* IPL_BIO */
+ 0x55555555, /* IPL_NET */
+ 0xaaaaaaaa, /* IPL_TTY */
+ 0xffffffff, /* IPL_CLOCK */
};
struct algor_dev *algor_cpu_devs[] = {
NULL, /* Unused */
- NULL, /* Unused */
- NULL, /* Unused */
- NULL, /* Unused */
- NULL, /* Unused */
- NULL, /* Unused */
- algor_4032_cpu, /* 6 = ALGORITHMICS R4032 Board */
- NULL,
+ algor_4032_cpu, /* 0x21 = ALGORITHMICS P-4032 board */
+ algor_5064_cpu, /* 0x22 = ALGORITHMICS P-5064 board */
};
int nalgor_cpu_devs = sizeof algor_cpu_devs / sizeof algor_cpu_devs[0];
@@ -159,8 +171,8 @@ algormatch(parent, cfdata, aux)
return (0);
/* Make sure that unit exists. */
- if (cf->cf_unit != 0 || system_type > nalgor_cpu_devs
- || algor_cpu_devs[system_type] == NULL)
+ if (cf->cf_unit != 0 || (system_type - ALGOR_CLASS) > nalgor_cpu_devs
+ || algor_cpu_devs[system_type - ALGOR_CLASS] == NULL)
return (0);
return (1);
@@ -179,10 +191,10 @@ algorattach(parent, self, aux)
printf("\n");
/* keep our CPU device description handy */
- sc->sc_devs = algor_cpu_devs[system_type];
+ sc->sc_devs = algor_cpu_devs[system_type - ALGOR_CLASS];
/* set up interrupt handlers */
- set_intr(INT_MASK_1, algor_iointr, 2);
+ set_intr(INT_MASK_1, algor_iointr, 3);
set_intr(INT_MASK_4, algor_errintr, 0);
sc->sc_bus.ab_dv = (struct device *)sc;
@@ -248,21 +260,27 @@ algor_intr_establish(ca, handler, arg)
int_table[slot].int_hand = handler;
int_table[slot].param = arg;
}
- p4032_ixr |= ipxrtab[ipl] & dev->ps_route;
- outb(P4032_IXR0, p4032_ixr);
- outb(P4032_IXR1, p4032_ixr >> 8);
- outb(P4032_IXR2, p4032_ixr >> 16);
+ p4032_ixr0 |= ipxrtab[ipl] & dev->ps_route;
+ switch(system_type) {
+ case ALGOR_P4032:
+ outb(P4032_IXR0, p4032_ixr0);
+ outb(P4032_IXR1, p4032_ixr0 >> 8);
+ break;
+ case ALGOR_P5064:
+ outb(P5064_IXR0, p4032_ixr0);
+ outb(P5064_IXR1, p4032_ixr0 >> 8);
+ break;
+ }
if(slot == 0) { /* Slot 0 is special, clock */
- set_intr(INT_MASK_0 << ipl, algor_clkintr, ipl + 1);
+ set_intr(INT_MASK_0 << ipl, algor_clkintr, ipl + 2);
}
else {
- set_intr(INT_MASK_0 << ipl, algor_iointr, ipl + 1);
+ set_intr(INT_MASK_0 << ipl, algor_iointr, ipl + 2);
}
p4032_imask |= dev->ps_mask;
outb(P4032_IMR, p4032_imask);
- outb(P4032_PCIIMR, p4032_imask >> 8);
}
void *
@@ -280,12 +298,25 @@ algor_pci_intr_establish(ih, level, handler, arg, name)
if(level < IPL_BIO || level >= IPL_CLOCK) {
panic("pci intr: ipl level out of range");
}
- if(ih < 0 || ih >= 4) {
+ if(ih < 0 || ih >= 12 || ih == 7 || ih == 8) {
panic("pci intr: irq out of range");
}
- imask = (0x1000 << ih);
- route = (0x30000 << (ih+ih));
+ switch(system_type) {
+ case ALGOR_P4032:
+ imask = (0x00001000 << ih);
+ route = (0x3 << (ih+ih));
+ break;
+ case ALGOR_P5064:
+ if(ih > 8) {
+ imask = (0x00000100 << (ih - 8));
+ }
+ else {
+ imask = (0x00001000 << ih);
+ }
+ route = (0x3 << (ih+ih));
+ break;
+ }
slot = NUM_INT_SLOTS;
while(slot > 0) {
@@ -301,12 +332,19 @@ algor_pci_intr_establish(ih, level, handler, arg, name)
int_table[slot].int_hand = handler;
int_table[slot].param = arg;
- p4032_ixr |= ipxrtab[level] & route;
- outb(P4032_IXR0, p4032_ixr);
- outb(P4032_IXR1, p4032_ixr >> 8);
- outb(P4032_IXR2, p4032_ixr >> 16);
+ p4032_ixr1 |= ipxrtab[level] & route;
+ switch(system_type) {
+ case ALGOR_P4032:
+ outb(P4032_IXR2, p4032_ixr1);
+ break;
+ case ALGOR_P5064:
+ outb(P5064_IXR2, p4032_ixr1);
+ outb(P5064_IXR3, p4032_ixr1 >> 8);
+ outb(P5064_IXR4, p4032_ixr1 >> 16);
+ break;
+ }
- set_intr(INT_MASK_0 << level, algor_iointr, level + 1);
+ set_intr(INT_MASK_0 << level, algor_iointr, level + 2);
p4032_imask |= imask;
outb(P4032_IMR, p4032_imask);
@@ -395,8 +433,14 @@ algor_clkintr(mask, cf)
struct clockframe *cf;
{
/* Ack clock interrupt */
- outb(P4032_CLOCK, MC_REGC);
- (void) inb(P4032_CLOCK + 4);
+ if(system_type == ALGOR_P4032) {
+ outb(P4032_CLOCK, MC_REGC);
+ (void) inb(P4032_CLOCK + 4);
+ }
+ else {
+ outb(P5064_CLOCK, MC_REGC);
+ (void) inb(P5064_CLOCK + 1);
+ }
hardclock(cf);
@@ -407,7 +451,7 @@ algor_clkintr(mask, cf)
}
/*
- * Handle algor interval clock interrupt.
+ * Handle algor error interrupt.
*/
int
algor_errintr(mask, cf)
@@ -421,18 +465,21 @@ algor_errintr(mask, cf)
if(why & P4032_IRR_BER) {
printf("Bus error interrupt\n");
outb(P4032_ICR, P4032_IRR_BER);
+#ifdef DDB
+ Debugger();
+#endif
}
if(why & P4032_IRR_PFAIL) {
printf("Power failure!\n");
}
if(why & P4032_IRR_DBG) {
printf("Debug switch\n");
- outb(P4032_ICR, P4032_IRR_DBG);
-#ifdef DEBUG
- mdbpanic();
+#ifdef DDB
+ Debugger();
#else
- printf("Not DEBUG compiled, sorry!\n");
+ printf("Sorry, recompile kernel with DDB!\n");
#endif
+ outb(P4032_ICR, P4032_IRR_DBG);
}
return(~0);
}