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:
parent
b4fb0f417f
commit
2112cf1085
@ -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 *
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user