summaryrefslogtreecommitdiffstats
path: root/sys/pccard
diff options
context:
space:
mode:
Diffstat (limited to 'sys/pccard')
-rw-r--r--sys/pccard/pcic_pci.c69
1 files changed, 42 insertions, 27 deletions
diff --git a/sys/pccard/pcic_pci.c b/sys/pccard/pcic_pci.c
index 43544b0..36ad508 100644
--- a/sys/pccard/pcic_pci.c
+++ b/sys/pccard/pcic_pci.c
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2001 M. Warner Losh. All Rights Reserved.
+ * Copyright (c) 2000, 2002 M. Warner Losh. All Rights Reserved.
* Copyright (c) 1997 Ted Faber All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
@@ -111,6 +111,15 @@ a value of 2, while chips installed in a laptop need a value of 1 (which is\n\
also the default). This is similar to hw.pcic.intr_path, but separate so\n\
that it can default to ISA when intr_path defaults to PCI.");
+static int pcic_ti12xx_enable_pci_clock = 0;
+TUNABLE_INT("hw.pcic.ti12xx_enable_pci_clock", &pcic_ti12xx_enable_pci_clock);
+SYSCTL_INT(_hw_pcic, OID_AUTO, ti12xx_enable_pci_clock, CTLFLAG_RD,
+ &pcic_ti12xx_enable_pci_clock, 0,
+ "Some TI-12xx parts need to have the PCI clock enabled. These designs do\n\
+not provide a clock themselves. Most of the reference boards have the\n\
+required oscillator parts, so the number of machines that needs this to be\n\
+set is vanishingly small.");
+
static void pcic_pci_cardbus_init(device_t);
static pcic_intr_way_t pcic_pci_gen_func;
static pcic_intr_way_t pcic_pci_gen_csc;
@@ -124,9 +133,9 @@ static pcic_intr_way_t pcic_pci_oz68xx_func;
static pcic_intr_way_t pcic_pci_oz68xx_csc;
static pcic_init_t pcic_pci_oz68xx_init;
-static pcic_intr_way_t pcic_pci_pd67xx_func;
-static pcic_intr_way_t pcic_pci_pd67xx_csc;
-static pcic_init_t pcic_pci_pd67xx_init;
+static pcic_intr_way_t pcic_pci_pd6729_func;
+static pcic_intr_way_t pcic_pci_pd6729_csc;
+static pcic_init_t pcic_pci_pd6729_init;
static pcic_intr_way_t pcic_pci_pd68xx_func;
static pcic_intr_way_t pcic_pci_pd68xx_csc;
@@ -161,11 +170,11 @@ static struct pcic_chip pcic_pci_oz68xx_chip = {
pcic_pci_oz68xx_init
};
-static struct pcic_chip pcic_pci_pd67xx_chip = {
- pcic_pci_pd67xx_func,
- pcic_pci_pd67xx_csc,
+static struct pcic_chip pcic_pci_pd6729_chip = {
+ pcic_pci_pd6729_func,
+ pcic_pci_pd6729_csc,
pcic_pci_gen_mapirq,
- pcic_pci_pd67xx_init
+ pcic_pci_pd6729_init
};
static struct pcic_chip pcic_pci_pd68xx_chip = {
@@ -222,9 +231,9 @@ struct pcic_pci_table
struct pcic_chip *chip;
} pcic_pci_devs[] = {
{ PCIC_ID_OMEGA_82C094, "Omega 82C094G",
- PCIC_I82365, PCIC_DF_POWER, &pcic_pci_pd67xx_chip },
+ PCIC_I82365, PCIC_DF_POWER, &pcic_pci_pd6729_chip },
{ PCIC_ID_CLPD6729, "Cirrus Logic PD6729/6730 PCI-PCMCIA Bridge",
- PCIC_PD6729, PCIC_PD_POWER, &pcic_pci_pd67xx_chip },
+ PCIC_PD6729, PCIC_PD_POWER, &pcic_pci_pd6729_chip },
{ PCIC_ID_CLPD6832, "Cirrus Logic PD6832 PCI-CardBus Bridge",
PCIC_PD673X, PCIC_CARDBUS_POWER, &pcic_pci_pd68xx_chip },
{ PCIC_ID_CLPD6833, "Cirrus Logic PD6833 PCI-CardBus Bridge",
@@ -449,7 +458,7 @@ pcic_pci_oz68xx_init(device_t dev)
* with them to know for sure.
*/
static int
-pcic_pci_pd67xx_func(struct pcic_slot *sp, enum pcic_intr_way way)
+pcic_pci_pd6729_func(struct pcic_slot *sp, enum pcic_intr_way way)
{
/*
* For pci interrupts, we need to set bit 3 of extension register
@@ -465,7 +474,7 @@ pcic_pci_pd67xx_func(struct pcic_slot *sp, enum pcic_intr_way way)
}
static int
-pcic_pci_pd67xx_csc(struct pcic_slot *sp, enum pcic_intr_way way)
+pcic_pci_pd6729_csc(struct pcic_slot *sp, enum pcic_intr_way way)
{
/*
* For pci interrupts, we need to set bit 4 of extension register
@@ -482,12 +491,15 @@ pcic_pci_pd67xx_csc(struct pcic_slot *sp, enum pcic_intr_way way)
static void
-pcic_pci_pd67xx_init(device_t dev)
+pcic_pci_pd6729_init(device_t dev)
{
struct pcic_softc *sc = device_get_softc(dev);
- if (sc->csc_route == pcic_iw_pci || sc->func_route == pcic_iw_pci)
- device_printf(dev, "PD67xx maybe broken for PCI routing.\n");
+ /*
+ * Tell the chip to do its routing thing.
+ */
+ pcic_pci_pd6729_func(&sc->slots[0], sc->func_route);
+ pcic_pci_pd6729_csc(&sc->slots[0], sc->csc_route);
}
/*
@@ -608,12 +620,13 @@ pcic_pci_ti113x_func(struct pcic_slot *sp, enum pcic_intr_way way)
/*
* The TI-1130 (and 1030 and 1131) have a different interrupt
- * routing control than the newer cards. assume we're not
- * routing PCI, but enable as necessary when we find someone
- * uses PCI interrupts. In order to get any pci interrupts,
- * PCI_IRQ_ENA (bit 5) must be set. If either PCI_IREQ (bit
- * 4) or PCI_CSC (bit 3) are set, then set bit 5 at the same
- * time, since setting them enables the PCI interrupt routing.
+ * routing control than the newer chips. assume we're not
+ * routing either csc or func interrupts via PCI, but enable
+ * as necessary when we find someone uses PCI interrupts. In
+ * order to get any pci interrupts, PCI_IRQ_ENA (bit 5) must
+ * be set. If either PCI_IREQ (bit 4) or PCI_CSC (bit 3) are
+ * set, then set bit 5 at the same time, since setting them
+ * enables the PCI interrupt routing.
*
* It also appears necessary to set the function routing bit
* in the bridge control register, but cardbus_init does that
@@ -696,16 +709,18 @@ pcic_pci_ti12xx_func(struct pcic_slot *sp, enum pcic_intr_way way)
devcntl, 1);
syscntl |= TI113X_SYSCNTL_INTRTIE;
}
-#if 0
+
/*
* I've had reports that we need the pci clock enabled,
- * but I'm unsure how wise this is in general, so it
- * is ifdef'd out at the moment
+ * provide a hook to do so. The number of cards that
+ * require this is quite small.
*/
- syscntl |= TI12XX_SYSCNTL_PCI_CLOCK;
- pci_write_config(dev, TI113X_PCI_SYSTEM_CONTROL, syscntl, 4);
+ if (pcic_ti12xx_enable_pci_clock) {
+ syscntl |= TI12XX_SYSCNTL_PCI_CLOCK;
+ pci_write_config(dev, TI113X_PCI_SYSTEM_CONTROL,
+ syscntl, 4);
+ }
-#endif
/*
* Some PCI add-in cards don't have good EEPROMs on them,
* so they get this MUX register wrong. The MUX register
OpenPOWER on IntegriCloud