summaryrefslogtreecommitdiffstats
path: root/sys/amd64/amd64/local_apic.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/amd64/amd64/local_apic.c')
-rw-r--r--sys/amd64/amd64/local_apic.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/sys/amd64/amd64/local_apic.c b/sys/amd64/amd64/local_apic.c
index 4debf4b..e81ac65 100644
--- a/sys/amd64/amd64/local_apic.c
+++ b/sys/amd64/amd64/local_apic.c
@@ -46,7 +46,6 @@ __FBSDID("$FreeBSD$");
#include <sys/mutex.h>
#include <sys/pcpu.h>
#include <sys/smp.h>
-#include <sys/proc.h>
#include <vm/vm.h>
#include <vm/pmap.h>
@@ -607,14 +606,13 @@ lapic_eoi(void)
}
void
-lapic_handle_intr(void *cookie, struct intrframe frame)
+lapic_handle_intr(int vector, struct trapframe frame)
{
struct intsrc *isrc;
- int vec = (uintptr_t)cookie;
- if (vec == -1)
+ if (vector == -1)
panic("Couldn't get vector from ISR!");
- isrc = intr_lookup_source(apic_idt_to_irq(vec));
+ isrc = intr_lookup_source(apic_idt_to_irq(vector));
intr_execute_handlers(isrc, &frame);
}
@@ -623,6 +621,10 @@ lapic_handle_timer(struct clockframe frame)
{
struct lapic *la;
+ /* Send EOI first thing. */
+ lapic_eoi();
+
+ /* Look up our local APIC structure for the tick counters. */
la = &lapics[PCPU_GET(apic_id)];
(*la->la_timer_count)++;
critical_enter();
OpenPOWER on IntegriCloud