FROMLIST: clocksource/drivers/timer-of: Remove __init markings

Remove __init markings to allow timer drivers
can be compiled as modules.

Link: https://lore.kernel.org/lkml/20230421034649.15247-5-walter.chang@mediatek.com/T/
Bug: 161675989
Change-Id: I74c9d1b4bc6f49dc5a69b4502ca68cb8cc3cbf02
Signed-off-by: Chun-Hung Wu <chun-hung.wu@mediatek.com>
This commit is contained in:
Chun-Hung Wu 2023-02-14 18:53:13 +08:00 committed by Greg Kroah-Hartman
parent bc213daa95
commit 4625c2b602
2 changed files with 15 additions and 14 deletions

View File

@ -19,7 +19,7 @@
* *
* Free the irq resource * Free the irq resource
*/ */
static __init void timer_of_irq_exit(struct of_timer_irq *of_irq) static void timer_of_irq_exit(struct of_timer_irq *of_irq)
{ {
struct timer_of *to = container_of(of_irq, struct timer_of, of_irq); struct timer_of *to = container_of(of_irq, struct timer_of, of_irq);
@ -47,8 +47,8 @@ static __init void timer_of_irq_exit(struct of_timer_irq *of_irq)
* *
* Returns 0 on success, < 0 otherwise * Returns 0 on success, < 0 otherwise
*/ */
static __init int timer_of_irq_init(struct device_node *np, static int timer_of_irq_init(struct device_node *np,
struct of_timer_irq *of_irq) struct of_timer_irq *of_irq)
{ {
int ret; int ret;
struct timer_of *to = container_of(of_irq, struct timer_of, of_irq); struct timer_of *to = container_of(of_irq, struct timer_of, of_irq);
@ -91,7 +91,7 @@ static __init int timer_of_irq_init(struct device_node *np,
* *
* Disables and releases the refcount on the clk * Disables and releases the refcount on the clk
*/ */
static __init void timer_of_clk_exit(struct of_timer_clk *of_clk) static void timer_of_clk_exit(struct of_timer_clk *of_clk)
{ {
of_clk->rate = 0; of_clk->rate = 0;
clk_disable_unprepare(of_clk->clk); clk_disable_unprepare(of_clk->clk);
@ -107,8 +107,8 @@ static __init void timer_of_clk_exit(struct of_timer_clk *of_clk)
* *
* Returns 0 on success, < 0 otherwise * Returns 0 on success, < 0 otherwise
*/ */
static __init int timer_of_clk_init(struct device_node *np, static int timer_of_clk_init(struct device_node *np,
struct of_timer_clk *of_clk) struct of_timer_clk *of_clk)
{ {
int ret; int ret;
@ -146,13 +146,13 @@ static __init int timer_of_clk_init(struct device_node *np,
goto out; goto out;
} }
static __init void timer_of_base_exit(struct of_timer_base *of_base) static void timer_of_base_exit(struct of_timer_base *of_base)
{ {
iounmap(of_base->base); iounmap(of_base->base);
} }
static __init int timer_of_base_init(struct device_node *np, static int timer_of_base_init(struct device_node *np,
struct of_timer_base *of_base) struct of_timer_base *of_base)
{ {
of_base->base = of_base->name ? of_base->base = of_base->name ?
of_io_request_and_map(np, of_base->index, of_base->name) : of_io_request_and_map(np, of_base->index, of_base->name) :
@ -165,7 +165,7 @@ static __init int timer_of_base_init(struct device_node *np,
return 0; return 0;
} }
int __init timer_of_init(struct device_node *np, struct timer_of *to) int timer_of_init(struct device_node *np, struct timer_of *to)
{ {
int ret = -EINVAL; int ret = -EINVAL;
int flags = 0; int flags = 0;
@ -209,6 +209,7 @@ int __init timer_of_init(struct device_node *np, struct timer_of *to)
timer_of_base_exit(&to->of_base); timer_of_base_exit(&to->of_base);
return ret; return ret;
} }
EXPORT_SYMBOL_GPL(timer_of_init);
/** /**
* timer_of_cleanup - release timer_of resources * timer_of_cleanup - release timer_of resources
@ -217,7 +218,7 @@ int __init timer_of_init(struct device_node *np, struct timer_of *to)
* Release the resources that has been used in timer_of_init(). * Release the resources that has been used in timer_of_init().
* This function should be called in init error cases * This function should be called in init error cases
*/ */
void __init timer_of_cleanup(struct timer_of *to) void timer_of_cleanup(struct timer_of *to)
{ {
if (to->flags & TIMER_OF_IRQ) if (to->flags & TIMER_OF_IRQ)
timer_of_irq_exit(&to->of_irq); timer_of_irq_exit(&to->of_irq);

View File

@ -66,9 +66,9 @@ static inline unsigned long timer_of_period(struct timer_of *to)
return to->of_clk.period; return to->of_clk.period;
} }
extern int __init timer_of_init(struct device_node *np, extern int timer_of_init(struct device_node *np,
struct timer_of *to); struct timer_of *to);
extern void __init timer_of_cleanup(struct timer_of *to); extern void timer_of_cleanup(struct timer_of *to);
#endif #endif