Lines Matching defs:ttcce
385 struct ttc_timer_clockevent *ttcce = container_of(ttc,
393 clockevents_update_freq(&ttcce->ce, ndata->new_rate / PRESCALE);
406 struct ttc_timer_clockevent *ttcce;
409 ttcce = kzalloc(sizeof(*ttcce), GFP_KERNEL);
410 if (!ttcce)
413 ttcce->ttc.clk = clk;
415 err = clk_prepare_enable(ttcce->ttc.clk);
419 ttcce->ttc.clk_rate_change_nb.notifier_call =
421 ttcce->ttc.clk_rate_change_nb.next = NULL;
423 err = clk_notifier_register(ttcce->ttc.clk,
424 &ttcce->ttc.clk_rate_change_nb);
430 ttcce->ttc.freq = clk_get_rate(ttcce->ttc.clk);
432 ttcce->ttc.base_addr = base;
433 ttcce->ce.name = "ttc_clockevent";
434 ttcce->ce.features = CLOCK_EVT_FEAT_PERIODIC | CLOCK_EVT_FEAT_ONESHOT;
435 ttcce->ce.set_next_event = ttc_set_next_event;
436 ttcce->ce.set_state_shutdown = ttc_shutdown;
437 ttcce->ce.set_state_periodic = ttc_set_periodic;
438 ttcce->ce.set_state_oneshot = ttc_shutdown;
439 ttcce->ce.tick_resume = ttc_resume;
440 ttcce->ce.rating = 200;
441 ttcce->ce.irq = irq;
442 ttcce->ce.cpumask = cpu_possible_mask;
449 writel_relaxed(0x23, ttcce->ttc.base_addr + TTC_CNT_CNTRL_OFFSET);
451 ttcce->ttc.base_addr + TTC_CLK_CNTRL_OFFSET);
452 writel_relaxed(0x1, ttcce->ttc.base_addr + TTC_IER_OFFSET);
455 IRQF_TIMER, ttcce->ce.name, ttcce);
459 clockevents_config_and_register(&ttcce->ce,
460 ttcce->ttc.freq / PRESCALE, 1, 0xfffe);
465 kfree(ttcce);