Fix PCI interrupt allocation on the Milan.

Note that this _seems_ to work. It can't be really tested before my board
is upgraded.
This commit is contained in:
leo 2002-01-09 21:19:14 +00:00
parent b4fb0f417f
commit 2112cf1085
2 changed files with 57 additions and 11 deletions

View File

@ -1,4 +1,4 @@
/* $NetBSD: pci_machdep.c,v 1.32 2001/05/28 07:22:37 leo Exp $ */ /* $NetBSD: pci_machdep.c,v 1.33 2002/01/09 21:19:14 leo Exp $ */
/* /*
* Copyright (c) 1996 Leo Weppelman. All rights reserved. * Copyright (c) 1996 Leo Weppelman. All rights reserved.
@ -101,7 +101,7 @@ int _bus_dmamap_create __P((bus_dma_tag_t, bus_size_t, int, bus_size_t,
bus_size_t, int, bus_dmamap_t *)); bus_size_t, int, bus_dmamap_t *));
struct atari_bus_dma_tag pci_bus_dma_tag = { struct atari_bus_dma_tag pci_bus_dma_tag = {
0, 0,
#ifdef _ATARIHW_ #if defined(_ATARIHW_)
0x80000000, /* On the Hades, CPU memory starts here PCI-wise */ 0x80000000, /* On the Hades, CPU memory starts here PCI-wise */
#else #else
0, 0,
@ -444,15 +444,21 @@ enable_pci_devices()
} }
} }
#if defined(_ATARIHW_)
/* /*
* Both interrupt pin & line are set to the device (== slot) * Both interrupt pin & line are set to the device (== slot)
* number. This makes sense on the atari because the * number. This makes sense on the atari Hades because the
* individual slots are hard-wired to a specific MFP-pin. * individual slots are hard-wired to a specific MFP-pin.
* XXX: This is _not_ true on the Milan.
*/ */
csr = (DEV2SLOT(dev) << PCI_INTERRUPT_PIN_SHIFT); csr = (DEV2SLOT(dev) << PCI_INTERRUPT_PIN_SHIFT);
csr |= (DEV2SLOT(dev) << PCI_INTERRUPT_LINE_SHIFT); csr |= (DEV2SLOT(dev) << PCI_INTERRUPT_LINE_SHIFT);
pci_conf_write(pc, tag, PCI_INTERRUPT_REG, csr); pci_conf_write(pc, tag, PCI_INTERRUPT_REG, csr);
#else
/*
* On the Milan, we accept the BIOS's choice.
*/
#endif
} }
/* /*
@ -614,22 +620,56 @@ pci_intr_map(pa, ihp)
{ {
int line = pa->pa_intrline; int line = pa->pa_intrline;
#if defined(_MILANHW_)
/*
* On the Hades, the 'pin' info is useless.
*/
{
int pin = pa->pa_intrpin;
if (pin == 0) {
/* No IRQ used. */
goto bad;
}
if (pin > PCI_INTERRUPT_PIN_MAX) {
printf("pci_intr_map: bad interrupt pin %d\n", pin);
goto bad;
}
}
#endif /* _MILANHW_ */
/* /*
* According to the PCI-spec, 255 means `unknown' or `no connection'. * According to the PCI-spec, 255 means `unknown' or `no connection'.
* Interpret this as 'no interrupt assigned'. * Interpret this as 'no interrupt assigned'.
*/ */
if (line == 255) { if (line == 255)
*ihp = -1; goto bad;
return 1;
}
/* /*
* Values are pretty useless on the Hades since all interrupt * Values are pretty useless on the Hades since all interrupt
* lines for a card are tied together and hardwired to a * lines for a card are tied together and hardwired to a
* specific TT-MFP I/O port. * specific TT-MFP I/O port.
* On the Milan, they are tied to the ICU.
*/ */
#if defined(_MILANHW_)
if (line >= 16) {
printf("pci_intr_map: bad interrupt line %d\n", line);
goto bad;
}
if (line == 2) {
printf("pci_intr_map: changed line 2 to line 9\n");
line = 9;
}
/* Assume line == 0 means unassigned */
if (line == 0)
goto bad;
#endif
*ihp = line; *ihp = line;
return 0; return 0;
bad:
*ihp = -1;
return 1;
} }
const char * const char *

View File

@ -1,4 +1,4 @@
/* $NetBSD: pci_milan.c,v 1.2 2001/05/28 08:30:03 leo Exp $ */ /* $NetBSD: pci_milan.c,v 1.3 2002/01/09 21:19:14 leo Exp $ */
/*- /*-
* Copyright (c) 2001 The NetBSD Foundation, Inc. * Copyright (c) 2001 The NetBSD Foundation, Inc.
@ -44,7 +44,11 @@
#include <dev/pci/pcivar.h> #include <dev/pci/pcivar.h>
#include <dev/pci/pcireg.h> #include <dev/pci/pcireg.h>
#include <dev/isa/isavar.h> /* isa_intr_{dis}establish */
#include <dev/isa/isareg.h> /* isa_intr_{dis}establish */
#include <machine/bswap.h> #include <machine/bswap.h>
#include <machine/isa_machdep.h> /* isa_intr_{dis}establish */
#include <atari/pci/pci_vga.h> #include <atari/pci/pci_vga.h>
#include <atari/dev/grf_etreg.h> #include <atari/dev/grf_etreg.h>
@ -101,8 +105,9 @@ pci_intr_establish(pc, ih, level, ih_fun, ih_arg)
int (*ih_fun) __P((void *)); int (*ih_fun) __P((void *));
void *ih_arg; void *ih_arg;
{ {
printf("pci_intr_establish: Not yet implemented\n"); if (ih == 0 || ih >= 16 || ih == 2)
return NULL; panic("pci_intr_establish: bogus handle 0x%x\n", ih);
return isa_intr_establish(NULL, ih, IST_LEVEL, level, ih_fun, ih_arg);
} }
void void
@ -110,6 +115,7 @@ pci_intr_disestablish(pc, cookie)
pci_chipset_tag_t pc; pci_chipset_tag_t pc;
void *cookie; void *cookie;
{ {
isa_intr_disestablish(NULL, cookie);
} }
/* /*