svn commit: r295499 - head/sys/mips/mips
Adrian Chadd
adrian at FreeBSD.org
Thu Feb 11 06:13:55 UTC 2016
Author: adrian
Date: Thu Feb 11 06:13:53 2016
New Revision: 295499
URL: https://svnweb.freebsd.org/changeset/base/295499
Log:
Teach the MIPS ticker to attach itself properly when using INTRNG.
Submitted by: Stanislav Galabov <sgalabov at gmail.com>
Reviewed by: kan
Differential Revision: https://reviews.freebsd.org/D5183
Modified:
head/sys/mips/mips/tick.c
Modified: head/sys/mips/mips/tick.c
==============================================================================
--- head/sys/mips/mips/tick.c Thu Feb 11 06:09:27 2016 (r295498)
+++ head/sys/mips/mips/tick.c Thu Feb 11 06:13:53 2016 (r295499)
@@ -51,6 +51,10 @@ __FBSDID("$FreeBSD$");
#include <machine/locore.h>
#include <machine/md_var.h>
+#ifdef MIPS_INTRNG
+#include <machine/intr.h>
+#endif
+
uint64_t counter_freq;
struct timecounter *platform_timecounter;
@@ -324,12 +328,18 @@ static int
clock_attach(device_t dev)
{
struct clock_softc *sc;
+#ifndef MIPS_INTRNG
int error;
+#endif
if (device_get_unit(dev) != 0)
panic("can't attach more clocks");
softc = sc = device_get_softc(dev);
+#ifdef MIPS_INTRNG
+ cpu_establish_hardintr("clock", clock_intr, NULL, sc, 5, INTR_TYPE_CLK,
+ NULL);
+#else
sc->intr_rid = 0;
sc->intr_res = bus_alloc_resource(dev,
SYS_RES_IRQ, &sc->intr_rid, 5, 5, 1, RF_ACTIVE);
@@ -343,6 +353,7 @@ clock_attach(device_t dev)
device_printf(dev, "bus_setup_intr returned %d\n", error);
return (error);
}
+#endif
sc->tc.tc_get_timecount = counter_get_timecount;
sc->tc.tc_counter_mask = 0xffffffff;
More information about the svn-src-head
mailing list