diff options
author | Jisheng Zhang <jszhang@marvell.com> | 2015-11-26 07:20:38 -0500 |
---|---|---|
committer | Daniel Lezcano <daniel.lezcano@linaro.org> | 2015-12-16 03:44:23 -0500 |
commit | 08e4b44852626f3549c8bd45308431d9c9e0ee6d (patch) | |
tree | 199a125a955ce755018af169f9d1096d77d3b76d /drivers/clocksource | |
parent | 520ddad4e560423a320bc1861792da19b0b879f9 (diff) |
clockevents/drivers/arm_global_timer: Use writel_relaxed in gt_compare_set
Use the relaxed version to improve performance. we measured time of
4096 rounds of gt_compare_set() spent on Marvell BG2Q:
before the patch: 3690648ns on average
after the patch: 1083023ns on average
improved by 70%!
Signed-off-by: Jisheng Zhang <jszhang@marvell.com>
Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org>
Diffstat (limited to 'drivers/clocksource')
-rw-r--r-- | drivers/clocksource/arm_global_timer.c | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/drivers/clocksource/arm_global_timer.c b/drivers/clocksource/arm_global_timer.c index a2cb6fae9295..f99be6bafad1 100644 --- a/drivers/clocksource/arm_global_timer.c +++ b/drivers/clocksource/arm_global_timer.c | |||
@@ -99,17 +99,17 @@ static void gt_compare_set(unsigned long delta, int periodic) | |||
99 | 99 | ||
100 | counter += delta; | 100 | counter += delta; |
101 | ctrl = GT_CONTROL_TIMER_ENABLE; | 101 | ctrl = GT_CONTROL_TIMER_ENABLE; |
102 | writel(ctrl, gt_base + GT_CONTROL); | 102 | writel_relaxed(ctrl, gt_base + GT_CONTROL); |
103 | writel(lower_32_bits(counter), gt_base + GT_COMP0); | 103 | writel_relaxed(lower_32_bits(counter), gt_base + GT_COMP0); |
104 | writel(upper_32_bits(counter), gt_base + GT_COMP1); | 104 | writel_relaxed(upper_32_bits(counter), gt_base + GT_COMP1); |
105 | 105 | ||
106 | if (periodic) { | 106 | if (periodic) { |
107 | writel(delta, gt_base + GT_AUTO_INC); | 107 | writel_relaxed(delta, gt_base + GT_AUTO_INC); |
108 | ctrl |= GT_CONTROL_AUTO_INC; | 108 | ctrl |= GT_CONTROL_AUTO_INC; |
109 | } | 109 | } |
110 | 110 | ||
111 | ctrl |= GT_CONTROL_COMP_ENABLE | GT_CONTROL_IRQ_ENABLE; | 111 | ctrl |= GT_CONTROL_COMP_ENABLE | GT_CONTROL_IRQ_ENABLE; |
112 | writel(ctrl, gt_base + GT_CONTROL); | 112 | writel_relaxed(ctrl, gt_base + GT_CONTROL); |
113 | } | 113 | } |
114 | 114 | ||
115 | static int gt_clockevent_shutdown(struct clock_event_device *evt) | 115 | static int gt_clockevent_shutdown(struct clock_event_device *evt) |