diff options
| author | Andrew Bresticker <abrestic@chromium.org> | 2014-10-20 15:03:49 -0400 |
|---|---|---|
| committer | Ralf Baechle <ralf@linux-mips.org> | 2014-11-24 01:44:57 -0500 |
| commit | 387904ff84caeeff5aa5aad43aef4d0e5ce4bb24 (patch) | |
| tree | 781cc604660fd8f0ac99e8e5fda26aee13691385 | |
| parent | 7d9ad5d8c3639113765a3a0ad78c18a736d9f494 (diff) | |
irqchip: mips-gic: Export function to read counter width
Export the function gic_get_count_width to read the width of
the GIC global counter from GIC_SH_CONFIG. Update the GIC
clocksource driver to use this new function.
Signed-off-by: Andrew Bresticker <abrestic@chromium.org>
Cc: Daniel Lezcano <daniel.lezcano@linaro.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Jason Cooper <jason@lakedaemon.net>
Cc: Paul Burton <paul.burton@imgtec.com>
Cc: Qais Yousef <qais.yousef@imgtec.com>
Cc: John Crispin <blogic@openwrt.org>
Cc: linux-mips@linux-mips.org
Cc: linux-kernel@vger.kernel.org
Patchwork: https://patchwork.linux-mips.org/patch/8124/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
| -rw-r--r-- | arch/mips/include/asm/gic.h | 1 | ||||
| -rw-r--r-- | arch/mips/kernel/csrc-gic.c | 9 | ||||
| -rw-r--r-- | drivers/irqchip/irq-mips-gic.c | 11 |
3 files changed, 13 insertions, 8 deletions
diff --git a/arch/mips/include/asm/gic.h b/arch/mips/include/asm/gic.h index 727b7bf903a8..c88e1fa22365 100644 --- a/arch/mips/include/asm/gic.h +++ b/arch/mips/include/asm/gic.h | |||
| @@ -370,6 +370,7 @@ extern void gic_init(unsigned long gic_base_addr, | |||
| 370 | unsigned int irqbase); | 370 | unsigned int irqbase); |
| 371 | extern void gic_clocksource_init(unsigned int); | 371 | extern void gic_clocksource_init(unsigned int); |
| 372 | extern cycle_t gic_read_count(void); | 372 | extern cycle_t gic_read_count(void); |
| 373 | extern unsigned int gic_get_count_width(void); | ||
| 373 | extern cycle_t gic_read_compare(void); | 374 | extern cycle_t gic_read_compare(void); |
| 374 | extern void gic_write_compare(cycle_t cnt); | 375 | extern void gic_write_compare(cycle_t cnt); |
| 375 | extern void gic_write_cpu_compare(cycle_t cnt, int cpu); | 376 | extern void gic_write_cpu_compare(cycle_t cnt, int cpu); |
diff --git a/arch/mips/kernel/csrc-gic.c b/arch/mips/kernel/csrc-gic.c index e02620901117..ab615c6c51a5 100644 --- a/arch/mips/kernel/csrc-gic.c +++ b/arch/mips/kernel/csrc-gic.c | |||
| @@ -23,15 +23,8 @@ static struct clocksource gic_clocksource = { | |||
| 23 | 23 | ||
| 24 | void __init gic_clocksource_init(unsigned int frequency) | 24 | void __init gic_clocksource_init(unsigned int frequency) |
| 25 | { | 25 | { |
| 26 | unsigned int config, bits; | ||
| 27 | |||
| 28 | /* Calculate the clocksource mask. */ | ||
| 29 | GICREAD(GIC_REG(SHARED, GIC_SH_CONFIG), config); | ||
| 30 | bits = 32 + ((config & GIC_SH_CONFIG_COUNTBITS_MSK) >> | ||
| 31 | (GIC_SH_CONFIG_COUNTBITS_SHF - 2)); | ||
| 32 | |||
| 33 | /* Set clocksource mask. */ | 26 | /* Set clocksource mask. */ |
| 34 | gic_clocksource.mask = CLOCKSOURCE_MASK(bits); | 27 | gic_clocksource.mask = CLOCKSOURCE_MASK(gic_get_count_width()); |
| 35 | 28 | ||
| 36 | /* Calculate a somewhat reasonable rating value. */ | 29 | /* Calculate a somewhat reasonable rating value. */ |
| 37 | gic_clocksource.rating = 200 + frequency / 10000000; | 30 | gic_clocksource.rating = 200 + frequency / 10000000; |
diff --git a/drivers/irqchip/irq-mips-gic.c b/drivers/irqchip/irq-mips-gic.c index e49a39a8c853..b5fad6377736 100644 --- a/drivers/irqchip/irq-mips-gic.c +++ b/drivers/irqchip/irq-mips-gic.c | |||
| @@ -63,6 +63,17 @@ cycle_t gic_read_count(void) | |||
| 63 | return (((cycle_t) hi) << 32) + lo; | 63 | return (((cycle_t) hi) << 32) + lo; |
| 64 | } | 64 | } |
| 65 | 65 | ||
| 66 | unsigned int gic_get_count_width(void) | ||
| 67 | { | ||
| 68 | unsigned int bits, config; | ||
| 69 | |||
| 70 | GICREAD(GIC_REG(SHARED, GIC_SH_CONFIG), config); | ||
| 71 | bits = 32 + 4 * ((config & GIC_SH_CONFIG_COUNTBITS_MSK) >> | ||
| 72 | GIC_SH_CONFIG_COUNTBITS_SHF); | ||
| 73 | |||
| 74 | return bits; | ||
| 75 | } | ||
| 76 | |||
| 66 | void gic_write_compare(cycle_t cnt) | 77 | void gic_write_compare(cycle_t cnt) |
| 67 | { | 78 | { |
| 68 | GICWRITE(GIC_REG(VPE_LOCAL, GIC_VPE_COMPARE_HI), | 79 | GICWRITE(GIC_REG(VPE_LOCAL, GIC_VPE_COMPARE_HI), |
