Lines Matching +full:mips +full:- +full:gic
1 // SPDX-License-Identifier: GPL-2.0
2 // Copyright (C) 2012 MIPS Technologies, Inc. All rights reserved.
4 #define pr_fmt(fmt) "mips-gic-timer: " fmt
17 #include <asm/mips-cps.h>
54 int cpu = cpumask_first(evt->cpumask); in gic_next_event()
66 res = ((int)(gic_read_count() - cnt) >= 0) ? -ETIME : 0; in gic_next_event()
75 cd->event_handler(cd); in gic_compare_interrupt()
89 cd->name = "MIPS GIC"; in gic_clockevent_cpu_init()
90 cd->features = CLOCK_EVT_FEAT_ONESHOT | in gic_clockevent_cpu_init()
93 cd->rating = 350; in gic_clockevent_cpu_init()
94 cd->irq = gic_timer_irq; in gic_clockevent_cpu_init()
95 cd->cpumask = cpumask_of(cpu); in gic_clockevent_cpu_init()
96 cd->set_next_event = gic_next_event; in gic_clockevent_cpu_init()
128 on_each_cpu(gic_update_frequency, (void *)cnd->new_rate, 1); in gic_clk_notifier()
149 return -ENXIO; in gic_clockevent_init()
158 "clockevents/mips/gic/timer:starting", in gic_clockevent_init()
169 .name = "GIC",
182 pr_info("GIC timer is unstable due to %s\n", reason); in gic_clocksource_unstable()
214 if (!mips_gic_present() || !node->parent || in gic_clocksource_of_init()
215 !of_device_is_compatible(node->parent, "mti,gic")) { in gic_clocksource_of_init()
217 return -ENXIO; in gic_clocksource_of_init()
230 } else if (of_property_read_u32(node, "clock-frequency", in gic_clocksource_of_init()
233 return -EINVAL; in gic_clocksource_of_init()
238 return -EINVAL; in gic_clocksource_of_init()
255 * It's safe to use the MIPS GIC timer as a sched clock source only if in gic_clocksource_of_init()
268 TIMER_OF_DECLARE(mips_gic_timer, "mti,gic-timer",