diff options
author | Paul Burton <paul.burton@imgtec.com> | 2014-03-05 06:35:53 -0500 |
---|---|---|
committer | Paul Burton <paul.burton@imgtec.com> | 2014-05-02 11:39:11 -0400 |
commit | 414408d0eedd782a397ba89fd8f732ffbd3acde8 (patch) | |
tree | a747abf36d79d04d5a916a4e6fc230ccdf1776e7 /arch/mips/kernel/irq-gic.c | |
parent | 0467811e9bdb22c7a1595db4c230efd99265e3c7 (diff) |
MIPS: allow GIC clockevent device config from other CPUs
This patch allows the GIC clockevent device for a CPU to be configured
by another CPU. This makes GIC clockevent devices suitable for use as
the tick broadcast device, where formerly the GIC timer local to the
configuring CPU would have been configured incorrectly.
Signed-off-by: Paul Burton <paul.burton@imgtec.com>
Diffstat (limited to 'arch/mips/kernel/irq-gic.c')
-rw-r--r-- | arch/mips/kernel/irq-gic.c | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/arch/mips/kernel/irq-gic.c b/arch/mips/kernel/irq-gic.c index 8520dad6d4e3..88e4c323382c 100644 --- a/arch/mips/kernel/irq-gic.c +++ b/arch/mips/kernel/irq-gic.c | |||
@@ -54,6 +54,21 @@ void gic_write_compare(cycle_t cnt) | |||
54 | (int)(cnt & 0xffffffff)); | 54 | (int)(cnt & 0xffffffff)); |
55 | } | 55 | } |
56 | 56 | ||
57 | void gic_write_cpu_compare(cycle_t cnt, int cpu) | ||
58 | { | ||
59 | unsigned long flags; | ||
60 | |||
61 | local_irq_save(flags); | ||
62 | |||
63 | GICWRITE(GIC_REG(VPE_LOCAL, GIC_VPE_OTHER_ADDR), cpu); | ||
64 | GICWRITE(GIC_REG(VPE_OTHER, GIC_VPE_COMPARE_HI), | ||
65 | (int)(cnt >> 32)); | ||
66 | GICWRITE(GIC_REG(VPE_OTHER, GIC_VPE_COMPARE_LO), | ||
67 | (int)(cnt & 0xffffffff)); | ||
68 | |||
69 | local_irq_restore(flags); | ||
70 | } | ||
71 | |||
57 | cycle_t gic_read_compare(void) | 72 | cycle_t gic_read_compare(void) |
58 | { | 73 | { |
59 | unsigned int hi, lo; | 74 | unsigned int hi, lo; |