1
0
mirror of https://git.FreeBSD.org/src.git synced 2025-01-28 16:43:09 +00:00

Now that mxge supports MSI-X interrupts, reverse the logic and flag

legacy interrupts rather than MSI as a special case.  Prior to this
commit, the interrupt handler was doing the slow handshaking with
the device to ensure the legacy interrupt was lowered in both
the legacy and MSI-X case.  This handshaking was not
required for MSI-X.
This commit is contained in:
Andrew Gallatin 2008-02-14 16:24:14 +00:00
parent 5014f8ded4
commit 91ed89132c
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=176281
2 changed files with 10 additions and 8 deletions

View File

@ -2685,7 +2685,7 @@ mxge_intr(void *arg)
}
valid = stats->valid;
if (!sc->msi_enabled) {
if (sc->legacy_irq) {
/* lower legacy IRQ */
*sc->irq_deassert = 0;
if (!mxge_deassert_wait)
@ -2705,6 +2705,8 @@ mxge_intr(void *arg)
mxge_clean_rx_done(ss);
send_done_count = be32toh(stats->send_done_count);
}
if (sc->legacy_irq && mxge_deassert_wait)
mb();
} while (*((volatile uint8_t *) &stats->valid));
if (__predict_false(stats->stats_updated)) {
@ -4035,9 +4037,9 @@ mxge_add_single_irq(mxge_softc_t *sc)
count = pci_msi_count(sc->dev);
if (count == 1 && pci_alloc_msi(sc->dev, &count) == 0) {
rid = 1;
sc->msi_enabled = 1;
} else {
rid = 0;
sc->legacy_irq = 1;
}
sc->irq_res = bus_alloc_resource(sc->dev, SYS_RES_IRQ, &rid, 0, ~0,
1, RF_SHAREABLE | RF_ACTIVE);
@ -4047,7 +4049,7 @@ mxge_add_single_irq(mxge_softc_t *sc)
}
if (mxge_verbose)
device_printf(sc->dev, "using %s irq %ld\n",
sc->msi_enabled ? "MSI" : "INTx",
sc->legacy_irq ? "INTx" : "MSI",
rman_get_start(sc->irq_res));
err = bus_setup_intr(sc->dev, sc->irq_res,
INTR_TYPE_NET | INTR_MPSAFE,
@ -4057,8 +4059,8 @@ mxge_add_single_irq(mxge_softc_t *sc)
mxge_intr, &sc->ss[0], &sc->ih);
if (err != 0) {
bus_release_resource(sc->dev, SYS_RES_IRQ,
sc->msi_enabled ? 1 : 0, sc->irq_res);
if (sc->msi_enabled)
sc->legacy_irq ? 0 : 1, sc->irq_res);
if (!sc->legacy_irq)
pci_release_msi(sc->dev);
}
return err;
@ -4099,8 +4101,8 @@ mxge_rem_single_irq(mxge_softc_t *sc)
{
bus_teardown_intr(sc->dev, sc->irq_res, sc->ih);
bus_release_resource(sc->dev, SYS_RES_IRQ,
sc->msi_enabled ? 1 : 0, sc->irq_res);
if (sc->msi_enabled)
sc->legacy_irq ? 0 : 1, sc->irq_res);
if (!sc->legacy_irq)
pci_release_msi(sc->dev);
}

View File

@ -206,7 +206,7 @@ struct mxge_softc {
mxge_dma_t cmd_dma;
mxge_dma_t zeropad_dma;
struct pci_dev *pdev;
int msi_enabled;
int legacy_irq;
int link_state;
unsigned int rdma_tags_available;
int intr_coal_delay;