diff options
author | Per Fogelstrom <pefo@cvs.openbsd.org> | 1998-03-16 09:38:53 +0000 |
---|---|---|
committer | Per Fogelstrom <pefo@cvs.openbsd.org> | 1998-03-16 09:38:53 +0000 |
commit | a963ca51673d0d081904efce31dd28f05d83e730 (patch) | |
tree | f51de935de8777cae9204bbaa29b11aa7007425d /sys/arch/arc/algor/algorbus.c | |
parent | c1aa08ed9b8f4b392adef8685e4f55ff3b189dbb (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.c | 139 |
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); } |