1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */ 2*4882a593Smuzhiyun 3*4882a593Smuzhiyun #ifndef __QCOM_CLK_KRAIT_H 4*4882a593Smuzhiyun #define __QCOM_CLK_KRAIT_H 5*4882a593Smuzhiyun 6*4882a593Smuzhiyun #include <linux/clk-provider.h> 7*4882a593Smuzhiyun 8*4882a593Smuzhiyun struct krait_mux_clk { 9*4882a593Smuzhiyun unsigned int *parent_map; 10*4882a593Smuzhiyun u32 offset; 11*4882a593Smuzhiyun u32 mask; 12*4882a593Smuzhiyun u32 shift; 13*4882a593Smuzhiyun u32 en_mask; 14*4882a593Smuzhiyun bool lpl; 15*4882a593Smuzhiyun u8 safe_sel; 16*4882a593Smuzhiyun u8 old_index; 17*4882a593Smuzhiyun bool reparent; 18*4882a593Smuzhiyun 19*4882a593Smuzhiyun struct clk_hw hw; 20*4882a593Smuzhiyun struct notifier_block clk_nb; 21*4882a593Smuzhiyun }; 22*4882a593Smuzhiyun 23*4882a593Smuzhiyun #define to_krait_mux_clk(_hw) container_of(_hw, struct krait_mux_clk, hw) 24*4882a593Smuzhiyun 25*4882a593Smuzhiyun extern const struct clk_ops krait_mux_clk_ops; 26*4882a593Smuzhiyun 27*4882a593Smuzhiyun struct krait_div2_clk { 28*4882a593Smuzhiyun u32 offset; 29*4882a593Smuzhiyun u8 width; 30*4882a593Smuzhiyun u32 shift; 31*4882a593Smuzhiyun bool lpl; 32*4882a593Smuzhiyun 33*4882a593Smuzhiyun struct clk_hw hw; 34*4882a593Smuzhiyun }; 35*4882a593Smuzhiyun 36*4882a593Smuzhiyun #define to_krait_div2_clk(_hw) container_of(_hw, struct krait_div2_clk, hw) 37*4882a593Smuzhiyun 38*4882a593Smuzhiyun extern const struct clk_ops krait_div2_clk_ops; 39*4882a593Smuzhiyun 40*4882a593Smuzhiyun #endif 41