Commit a913a823 authored by GuanXuetao's avatar GuanXuetao

unicore32 time.c: change calculate method for clock_event_device

apply clockevents_calc_mult_shift() to get rid of
shift assignment and mult calculation for osmr0
  -- by advice with Thomas Gleixner
Signed-off-by: default avatarGuan Xuetao <gxt@mprc.pku.edu.cn>
parent b31d8273
...@@ -66,11 +66,6 @@ puv3_osmr0_set_mode(enum clock_event_mode mode, struct clock_event_device *c) ...@@ -66,11 +66,6 @@ puv3_osmr0_set_mode(enum clock_event_mode mode, struct clock_event_device *c)
static struct clock_event_device ckevt_puv3_osmr0 = { static struct clock_event_device ckevt_puv3_osmr0 = {
.name = "osmr0", .name = "osmr0",
.features = CLOCK_EVT_FEAT_ONESHOT, .features = CLOCK_EVT_FEAT_ONESHOT,
#ifdef CONFIG_ARCH_FPGA
.shift = 18, /* correct shift val: 16, but warn_on_slowpath */
#else
.shift = 30,
#endif
.rating = 200, .rating = 200,
.set_next_event = puv3_osmr0_set_next_event, .set_next_event = puv3_osmr0_set_next_event,
.set_mode = puv3_osmr0_set_mode, .set_mode = puv3_osmr0_set_mode,
...@@ -101,8 +96,8 @@ void __init time_init(void) ...@@ -101,8 +96,8 @@ void __init time_init(void)
OST_OIER = 0; /* disable any timer interrupts */ OST_OIER = 0; /* disable any timer interrupts */
OST_OSSR = 0; /* clear status on all timers */ OST_OSSR = 0; /* clear status on all timers */
ckevt_puv3_osmr0.mult = clockevents_calc_mult_shift(&ckevt_puv3_osmr0, CLOCK_TICK_RATE, 5);
div_sc(CLOCK_TICK_RATE, NSEC_PER_SEC, ckevt_puv3_osmr0.shift);
ckevt_puv3_osmr0.max_delta_ns = ckevt_puv3_osmr0.max_delta_ns =
clockevent_delta2ns(0x7fffffff, &ckevt_puv3_osmr0); clockevent_delta2ns(0x7fffffff, &ckevt_puv3_osmr0);
ckevt_puv3_osmr0.min_delta_ns = ckevt_puv3_osmr0.min_delta_ns =
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment