Orange Pi5 kernel

Deprecated Linux kernel 5.10.110 for OrangePi 5/5B/5+ boards

3 Commits   0 Branches   0 Tags
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  1) /* SPDX-License-Identifier: GPL-2.0 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  2) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  3)  * mcfclk.h -- coldfire specific clock structure
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  4)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  5) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  6) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  7) #ifndef mcfclk_h
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  8) #define mcfclk_h
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  9) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) struct clk;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) struct clk_ops {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) 	void (*enable)(struct clk *);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) 	void (*disable)(struct clk *);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) struct clk {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) 	const char *name;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) 	struct clk_ops *clk_ops;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) 	unsigned long rate;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) 	unsigned long enabled;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) 	u8 slot;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) extern struct clk *mcf_clks[];
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) #ifdef MCFPM_PPMCR0
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) extern struct clk_ops clk_ops0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) #ifdef MCFPM_PPMCR1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) extern struct clk_ops clk_ops1;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) #endif /* MCFPM_PPMCR1 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) extern struct clk_ops clk_ops2;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) #define DEFINE_CLK(clk_bank, clk_name, clk_slot, clk_rate) \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) static struct clk __clk_##clk_bank##_##clk_slot = { \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) 	.name = clk_name, \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38) 	.clk_ops = &clk_ops##clk_bank, \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) 	.rate = clk_rate, \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) 	.slot = clk_slot, \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) void __clk_init_enabled(struct clk *);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) void __clk_init_disabled(struct clk *);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45) #else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) #define DEFINE_CLK(clk_ref, clk_name, clk_rate) \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47)         static struct clk clk_##clk_ref = { \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48)                 .name = clk_name, \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49)                 .rate = clk_rate, \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50)         }
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) #endif /* MCFPM_PPMCR0 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) #endif /* mcfclk_h */