1 /* SPDX-License-Identifier: GPL-2.0 */ 2 #ifndef __TIMER_OF_H__ 3 #define __TIMER_OF_H__ 4 5 #include <linux/clockchips.h> 6 7 #define TIMER_OF_BASE 0x1 8 #define TIMER_OF_CLOCK 0x2 9 #define TIMER_OF_IRQ 0x4 10 11 struct of_timer_irq { 12 int irq; 13 int index; 14 int percpu; 15 const char *name; 16 unsigned long flags; 17 irq_handler_t handler; 18 }; 19 20 struct of_timer_base { 21 void __iomem *base; 22 const char *name; 23 int index; 24 }; 25 26 struct of_timer_clk { 27 struct clk *clk; 28 const char *name; 29 int index; 30 unsigned long rate; 31 unsigned long period; 32 }; 33 34 struct timer_of { 35 unsigned int flags; 36 struct clock_event_device clkevt; 37 struct of_timer_base of_base; 38 struct of_timer_irq of_irq; 39 struct of_timer_clk of_clk; 40 void *private_data; 41 }; 42 43 static inline struct timer_of *to_timer_of(struct clock_event_device *clkevt) 44 { 45 return container_of(clkevt, struct timer_of, clkevt); 46 } 47 48 static inline void __iomem *timer_of_base(struct timer_of *to) 49 { 50 return to->of_base.base; 51 } 52 53 static inline int timer_of_irq(struct timer_of *to) 54 { 55 return to->of_irq.irq; 56 } 57 58 static inline unsigned long timer_of_rate(struct timer_of *to) 59 { 60 return to->of_clk.rate; 61 } 62 63 static inline unsigned long timer_of_period(struct timer_of *to) 64 { 65 return to->of_clk.period; 66 } 67 68 extern int __init timer_of_init(struct device_node *np, 69 struct timer_of *to); 70 71 extern void __init timer_of_cleanup(struct timer_of *to); 72 73 #endif 74