162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci
362306a36Sopenharmony_ci#ifndef __QCOM_CLK_KRAIT_H
462306a36Sopenharmony_ci#define __QCOM_CLK_KRAIT_H
562306a36Sopenharmony_ci
662306a36Sopenharmony_ci#include <linux/clk-provider.h>
762306a36Sopenharmony_ci
862306a36Sopenharmony_cistruct krait_mux_clk {
962306a36Sopenharmony_ci	unsigned int	*parent_map;
1062306a36Sopenharmony_ci	u32		offset;
1162306a36Sopenharmony_ci	u32		mask;
1262306a36Sopenharmony_ci	u32		shift;
1362306a36Sopenharmony_ci	u32		en_mask;
1462306a36Sopenharmony_ci	bool		lpl;
1562306a36Sopenharmony_ci	u8		safe_sel;
1662306a36Sopenharmony_ci	u8		old_index;
1762306a36Sopenharmony_ci	bool		reparent;
1862306a36Sopenharmony_ci	bool		disable_sec_src_gating;
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci	struct clk_hw	hw;
2162306a36Sopenharmony_ci	struct notifier_block   clk_nb;
2262306a36Sopenharmony_ci};
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_ci#define to_krait_mux_clk(_hw) container_of(_hw, struct krait_mux_clk, hw)
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ciextern const struct clk_ops krait_mux_clk_ops;
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_cistruct krait_div2_clk {
2962306a36Sopenharmony_ci	u32		offset;
3062306a36Sopenharmony_ci	u8		width;
3162306a36Sopenharmony_ci	u32		shift;
3262306a36Sopenharmony_ci	bool		lpl;
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci	struct clk_hw	hw;
3562306a36Sopenharmony_ci};
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ci#define to_krait_div2_clk(_hw) container_of(_hw, struct krait_div2_clk, hw)
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ciextern const struct clk_ops krait_div2_clk_ops;
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ci#endif
42