Date: Sat, 24 Jun 2006 14:57:34 GMT From: Paolo Pisati <piso@FreeBSD.org> To: Perforce Change Reviews <perforce@freebsd.org> Subject: PERFORCE change 99941 for review Message-ID: <200606241457.k5OEvY2O058375@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=99941 Change 99941 by piso@piso_newluxor on 2006/06/24 14:56:52 Finished to reconvert all the drivers marked as FIX_INTR_FILTER as interrupt filters. Affected files ... .. //depot/projects/soc2006/intr_filter/amd64/isa/clock.c#3 edit .. //depot/projects/soc2006/intr_filter/arm/at91/at91_pio.c#3 edit .. //depot/projects/soc2006/intr_filter/arm/at91/at91_rtc.c#3 edit .. //depot/projects/soc2006/intr_filter/arm/at91/at91_st.c#3 edit .. //depot/projects/soc2006/intr_filter/arm/sa11x0/sa11x0_ost.c#3 edit .. //depot/projects/soc2006/intr_filter/arm/xscale/i80321/i80321_timer.c#3 edit .. //depot/projects/soc2006/intr_filter/dev/adlink/adlink.c#3 edit .. //depot/projects/soc2006/intr_filter/dev/cy/cy_isa.c#3 edit .. //depot/projects/soc2006/intr_filter/dev/cy/cy_pci.c#4 edit .. //depot/projects/soc2006/intr_filter/dev/em/if_em.c#4 edit .. //depot/projects/soc2006/intr_filter/dev/zs/zs_macio.c#3 edit .. //depot/projects/soc2006/intr_filter/pc98/cbus/clock.c#3 edit .. //depot/projects/soc2006/intr_filter/pc98/cbus/sio.c#3 edit .. //depot/projects/soc2006/intr_filter/powerpc/powermac/pswitch.c#3 edit .. //depot/projects/soc2006/intr_filter/sparc64/pci/psycho.c#3 edit .. //depot/projects/soc2006/intr_filter/sparc64/sbus/sbus.c#3 edit Differences ... ==== //depot/projects/soc2006/intr_filter/amd64/isa/clock.c#3 (text+ko) ==== @@ -759,9 +759,8 @@ * that it can drive hardclock(). Otherwise, change the 8254 * timecounter to user a simpler algorithm. */ - // XXX - FIX_INTR_FILTER if (!using_lapic_timer) { - intr_add_handler("clk", 0, (driver_intr_t *)clkintr, NULL, + intr_add_handler("clk", 0, (driver_filter_t *)clkintr, NULL, NULL, INTR_TYPE_CLK | INTR_FAST, NULL); i8254_intsrc = intr_lookup_source(0); if (i8254_intsrc != NULL) @@ -795,8 +794,7 @@ /* Enable periodic interrupts from the RTC. */ rtc_statusb |= RTCSB_PINTR; - // XXX - FIX_INTR_FILTER - intr_add_handler("rtc", 8, (driver_intr_t *)rtcintr, NULL, + intr_add_handler("rtc", 8, (driver_filter_t *)rtcintr, NULL, NULL, INTR_TYPE_CLK | INTR_FAST, NULL); writertc(RTC_STATUSB, rtc_statusb); ==== //depot/projects/soc2006/intr_filter/arm/at91/at91_pio.c#3 (text) ==== @@ -124,9 +124,8 @@ * Activate the interrupt, but disable all interrupts in the hardware */ WR4(sc, PIO_IDR, 0xffffffff); - // XXX - FIX_INTR_FILTER err = bus_setup_intr(dev, sc->irq_res, INTR_TYPE_MISC | INTR_FAST, - (driver_intr_t *)at91_pio_intr, sc, &sc->intrhand); + (driver_filter_t *)at91_pio_intr, NULL, sc, &sc->intrhand); if (err) { AT91_PIO_LOCK_DESTROY(sc); goto out; ==== //depot/projects/soc2006/intr_filter/arm/at91/at91_rtc.c#3 (text) ==== @@ -110,9 +110,8 @@ * Activate the interrupt, but disable all interrupts in the hardware */ WR4(sc, RTC_IDR, 0xffffffff); - // XXX - FIX_INTR_FILTER err = bus_setup_intr(dev, sc->irq_res, INTR_TYPE_MISC | INTR_FAST, - (driver_intr_t *)at91_rtc_intr, sc, &sc->intrhand); + (driver_filter_t *)at91_rtc_intr, NULL, sc, &sc->intrhand); if (err) { AT91_RTC_LOCK_DESTROY(sc); goto out; ==== //depot/projects/soc2006/intr_filter/arm/at91/at91_st.c#3 (text) ==== @@ -175,12 +175,11 @@ /* The system timer shares the system irq (1) */ irq = bus_alloc_resource(dev, SYS_RES_IRQ, &rid, 1, 1, 1, RF_ACTIVE | RF_SHAREABLE); - // XXX - FIX_INTR_FILTER if (!irq) panic("Unable to allocate irq for the system timer"); else bus_setup_intr(dev, irq, INTR_TYPE_CLK | INTR_FAST, - (driver_intr_t *)clock_intr, NULL, &ih); + (driver_filter_t *)clock_intr, NULL, NULL, &ih); WR4(ST_PIMR, rel_value); ==== //depot/projects/soc2006/intr_filter/arm/sa11x0/sa11x0_ost.c#3 (text+ko) ==== @@ -273,13 +273,11 @@ rid = 1; irq2 = bus_alloc_resource(dev, SYS_RES_IRQ, &rid, 0, ~0, 1, RF_ACTIVE); - // XXX - FIX_INTR_FILTER bus_setup_intr(dev, irq1, INTR_TYPE_CLK | INTR_FAST, - (driver_intr_t *)clockintr, NULL, &ih1); + (driver_filter_t *)clockintr, NULL, NULL, &ih1); #if 0 - // XXX - FIX_INTR_FILTER bus_setup_intr(dev, irq2, INTR_TYPE_CLK | INTR_FAST, - (driver_intr_t *)statintr, NULL, &ih2); + (driver_filter_t *)statintr, NULL, NULL, &ih2); #endif bus_space_write_4(saost_sc->sc_iot, saost_sc->sc_ioh, SAOST_SR, 0xf); bus_space_write_4(saost_sc->sc_iot, saost_sc->sc_ioh, SAOST_IR, 3); ==== //depot/projects/soc2006/intr_filter/arm/xscale/i80321/i80321_timer.c#3 (text+ko) ==== @@ -334,12 +334,11 @@ irq = bus_alloc_resource(dev, SYS_RES_IRQ, &rid, ICU_INT_TMR0, ICU_INT_TMR0, 1, RF_ACTIVE); - // XXX - FIX_INTR_FILTER if (!irq) panic("Unable to setup the clock irq handler.\n"); else bus_setup_intr(dev, irq, INTR_TYPE_CLK | INTR_FAST, - (driver_intr_t *)clockhandler, NULL, &ihl); + (driver_filter_t *)clockhandler, NULL, NULL, &ihl); tmr0_write(0); /* stop timer */ tisr_write(TISR_TMR0); /* clear interrupt */ ==== //depot/projects/soc2006/intr_filter/dev/adlink/adlink.c#3 (text+ko) ==== @@ -373,10 +373,9 @@ if (error) return (error); - // XXX - FIX_INTR_FILTER i = bus_setup_intr(self, sc->res[2], INTR_MPSAFE | INTR_TYPE_MISC | INTR_FAST, - (driver_intr_t *)adlink_intr, sc, &sc->intrhand); + (driver_filter_t *)adlink_intr, NULL, sc, &sc->intrhand); if (i) { printf("adlink: Couldn't get FAST intr\n"); i = bus_setup_intr(self, sc->res[2], ==== //depot/projects/soc2006/intr_filter/dev/cy/cy_isa.c#3 (text+ko) ==== @@ -132,9 +132,8 @@ device_printf(dev, "interrupt resource allocation failed\n"); goto fail; } - // XXX - FIX_INTR_FILTER if (bus_setup_intr(dev, irq_res, INTR_TYPE_TTY | INTR_FAST, - (driver_intr_t *)cyintr, vsc, &irq_cookie) != 0) { + (driver_filter_t *)cyintr, NULL, vsc, &irq_cookie) != 0) { device_printf(dev, "interrupt setup failed\n"); goto fail; } ==== //depot/projects/soc2006/intr_filter/dev/cy/cy_pci.c#4 (text+ko) ==== @@ -145,15 +145,14 @@ goto fail; } #ifdef CY_PCI_FASTINTR - // XXX - FIX_INTR_FILTER irq_setup = bus_setup_intr(dev, irq_res, INTR_TYPE_TTY | INTR_FAST, - (driver_intr_t *)cyintr, vsc, &irq_cookie); + (driver_filter_t *)cyintr, NULL, vsc, &irq_cookie); #else irq_setup = ENXIO; #endif if (irq_setup != 0) irq_setup = bus_setup_intr(dev, irq_res, INTR_TYPE_TTY, - (driver_intr_t *)cyintr, vsc, &irq_cookie); + NULL, (driver_intr_t *)cyintr, vsc, &irq_cookie); if (irq_setup != 0) { device_printf(dev, "interrupt setup failed\n"); goto fail; ==== //depot/projects/soc2006/intr_filter/dev/em/if_em.c#4 (text+ko) ==== @@ -1992,9 +1992,8 @@ taskqueue_thread_enqueue, &sc->tq); taskqueue_start_threads(&sc->tq, 1, PI_NET, "%s taskq", device_get_nameunit(sc->dev)); - // XXX - FIX_INTR_FILTER if ((error = bus_setup_intr(dev, sc->res_interrupt, - INTR_TYPE_NET | INTR_FAST, em_intr_fast, NULL, sc, + INTR_TYPE_NET | INTR_FAST, em_intr_fast, NULL, NULL, sc, &sc->int_handler_tag)) != 0) { device_printf(dev, "Failed to register fast interrupt " "handler: %d\n", error); ==== //depot/projects/soc2006/intr_filter/dev/zs/zs_macio.c#3 (text+ko) ==== @@ -158,9 +158,8 @@ device_printf(dev, "could not allocate interrupt 1\n"); goto error; } - // XXX - FIX_INTR_FILTER if (bus_setup_intr(dev, sc->sc_irqres1, INTR_TYPE_TTY | INTR_FAST, - (driver_intr_t *)zs_intr, sc, &sc->sc_ih1) != 0) { + (driver_filter_t *)zs_intr, NULL, sc, &sc->sc_ih1) != 0) { device_printf(dev, "could not setup interrupt 1\n"); goto error; } @@ -171,9 +170,8 @@ device_printf(dev, "could not allocate interrupt 2\n"); goto error; } - // XXX - FIX_INTR_FILTER if (bus_setup_intr(dev, sc->sc_irqres2, INTR_TYPE_TTY | INTR_FAST, - (driver_intr_t *)zs_intr, sc, &sc->sc_ih2) != 0) { + (driver_filter_t *)zs_intr, NULL, sc, &sc->sc_ih2) != 0) { device_printf(dev, "could not setup interrupt 2\n"); goto error; } ==== //depot/projects/soc2006/intr_filter/pc98/cbus/clock.c#3 (text+ko) ==== @@ -775,8 +775,7 @@ * timecounter to user a simpler algorithm. */ if (!using_lapic_timer) { - // XXX - FIX_INTR_FILTER - intr_add_handler("clk", 0, (driver_intr_t *)clkintr, NULL, + intr_add_handler("clk", 0, (driver_filter_t *)clkintr, NULL, NULL, INTR_TYPE_CLK | INTR_FAST, NULL); i8254_intsrc = intr_lookup_source(0); if (i8254_intsrc != NULL) ==== //depot/projects/soc2006/intr_filter/pc98/cbus/sio.c#3 (text+ko) ==== @@ -1738,10 +1738,9 @@ rid = 0; com->irqres = bus_alloc_resource_any(dev, SYS_RES_IRQ, &rid, RF_ACTIVE); if (com->irqres) { - // XXX - FIX_INTR_FILTER ret = bus_setup_intr(dev, com->irqres, INTR_TYPE_TTY | INTR_FAST, - (driver_intr_t *)siointr, com, + (driver_filter_t *)siointr, NULL, com, &com->cookie); if (ret) { ret = bus_setup_intr(dev, ==== //depot/projects/soc2006/intr_filter/powerpc/powermac/pswitch.c#3 (text+ko) ==== @@ -121,9 +121,8 @@ return (ENXIO); } - // XXX - FIX_INTR_FILTER if (bus_setup_intr(dev, sc->sc_irq, INTR_TYPE_MISC | INTR_FAST, - (driver_intr_t *)pswitch_intr, dev, &sc->sc_ih) != 0) { + (driver_filter_t *)pswitch_intr, NULL, dev, &sc->sc_ih) != 0) { device_printf(dev, "could not setup interrupt\n"); bus_release_resource(dev, SYS_RES_IRQ, sc->sc_irqrid, sc->sc_irq); ==== //depot/projects/soc2006/intr_filter/sparc64/pci/psycho.c#3 (text+ko) ==== @@ -80,7 +80,7 @@ const char *); static const struct psycho_desc *psycho_get_desc(phandle_t, const char *); static void psycho_set_intr(struct psycho_softc *, int, device_t, bus_addr_t, - int, driver_intr_t); + int, void *); static int psycho_find_intrmap(struct psycho_softc *, int, bus_addr_t *, bus_addr_t *, u_long *); static void psycho_intr_stub(void *); @@ -453,9 +453,8 @@ * half this is. Hummingbird/Sabre don't have a PCI bus B error * interrupt but they are also only used for PCI bus A. */ - // XXX - FIX_INTR_FILTER psycho_set_intr(sc, 0, dev, sc->sc_half == 0 ? PSR_PCIAERR_INT_MAP : - PSR_PCIBERR_INT_MAP, INTR_FAST, (driver_intr_t *)psycho_pci_bus); + PSR_PCIBERR_INT_MAP, INTR_FAST, psycho_pci_bus); /* * If we're a Hummingbird/Sabre or the first of a pair of Psycho's to @@ -471,14 +470,11 @@ * XXX Not all controllers have these, but installing them * is better than trying to sort through this mess. */ - // XXX - FIX_INTR_FILTER psycho_set_intr(sc, 1, dev, PSR_UE_INT_MAP, INTR_FAST, - (driver_intr_t *)psycho_ue); + psycho_ue); psycho_set_intr(sc, 2, dev, PSR_CE_INT_MAP, 0, psycho_ce); - // XXX - FIX_INTR_FILTER psycho_set_intr(sc, 3, dev, PSR_POWER_INT_MAP, - PSYCHO_PWRFAIL_INT_FLAGS, - (driver_intr_t *)psycho_powerfail); + PSYCHO_PWRFAIL_INT_FLAGS, psycho_powerfail); /* Psycho-specific initialization */ if (sc->sc_mode == PSYCHO_MODE_PSYCHO) { /* @@ -490,9 +486,8 @@ * The spare hardware interrupt is used for the * over-temperature interrupt. */ - // XXX - FIX_INTR_FILTER psycho_set_intr(sc, 4, dev, PSR_SPARE_INT_MAP, - INTR_FAST, (driver_intr_t *)psycho_overtemp); + INTR_FAST, psycho_overtemp); #ifdef PSYCHO_MAP_WAKEUP /* * psycho_wakeup() doesn't do anything useful right @@ -618,7 +613,7 @@ static void psycho_set_intr(struct psycho_softc *sc, int index, device_t dev, - bus_addr_t map, int iflags, driver_intr_t handler) + bus_addr_t map, int iflags, void *handler) { int rid, vec; uint64_t mr; @@ -630,8 +625,12 @@ vec, vec, 1, RF_ACTIVE); if (sc->sc_irq_res[index] == NULL) panic("%s: failed to get interrupt", __func__); - bus_setup_intr(dev, sc->sc_irq_res[index], INTR_TYPE_MISC | iflags, - handler, sc, &sc->sc_ihand[index]); + if (iflags & INTR_FAST) + bus_setup_intr(dev, sc->sc_irq_res[index], INTR_TYPE_MISC | iflags, + handler, NULL, sc, &sc->sc_ihand[index]); + else + bus_setup_intr(dev, sc->sc_irq_res[index], INTR_TYPE_MISC | iflags, + NULL, handler, sc, &sc->sc_ihand[index]); PSYCHO_WRITE8(sc, map, INTMAP_ENABLE(mr, PCPU_GET(mid))); } ==== //depot/projects/soc2006/intr_filter/sparc64/sbus/sbus.c#3 (text+ko) ==== @@ -433,9 +433,8 @@ if ((sc->sc_ot_ires = bus_alloc_resource(dev, SYS_RES_IRQ, &rid, vec, vec, 1, RF_ACTIVE)) == NULL) panic("%s: failed to get temperature interrupt", __func__); - // XXX - FIX_INTR_FILTER bus_setup_intr(dev, sc->sc_ot_ires, INTR_TYPE_MISC | INTR_FAST, - (driver_intr_t *)sbus_overtemp, sc, &sc->sc_ot_ihand); + (driver_filter_t *)sbus_overtemp, NULL, sc, &sc->sc_ot_ihand); SYSIO_WRITE8(sc, SBR_THERM_INT_MAP, INTMAP_ENABLE(mr, PCPU_GET(mid))); rid = 0; mr = SYSIO_READ8(sc, SBR_POWER_INT_MAP); @@ -443,9 +442,8 @@ if ((sc->sc_pf_ires = bus_alloc_resource(dev, SYS_RES_IRQ, &rid, vec, vec, 1, RF_ACTIVE)) == NULL) panic("%s: failed to get power fail interrupt", __func__); - // XXX - FIX_INTR_FILTER bus_setup_intr(dev, sc->sc_pf_ires, INTR_TYPE_MISC | INTR_FAST, - (driver_intr_t *)sbus_pwrfail, sc, &sc->sc_pf_ihand); + (driver_filter_t *)sbus_pwrfail, NULL, sc, &sc->sc_pf_ihand); SYSIO_WRITE8(sc, SBR_POWER_INT_MAP, INTMAP_ENABLE(mr, PCPU_GET(mid))); /* Initialize the counter-timer. */
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200606241457.k5OEvY2O058375>