Lines Matching refs:br
24 static bool clk_branch_in_hwcg_mode(const struct clk_branch *br) in clk_branch_in_hwcg_mode() argument
28 if (!br->hwcg_reg) in clk_branch_in_hwcg_mode()
31 regmap_read(br->clkr.regmap, br->hwcg_reg, &val); in clk_branch_in_hwcg_mode()
33 return !!(val & BIT(br->hwcg_bit)); in clk_branch_in_hwcg_mode()
36 static bool clk_branch_check_halt(const struct clk_branch *br, bool enabling) in clk_branch_check_halt() argument
38 bool invert = (br->halt_check == BRANCH_HALT_ENABLE); in clk_branch_check_halt()
41 regmap_read(br->clkr.regmap, br->halt_reg, &val); in clk_branch_check_halt()
43 val &= BIT(br->halt_bit); in clk_branch_check_halt()
55 static bool clk_branch2_check_halt(const struct clk_branch *br, bool enabling) in clk_branch2_check_halt() argument
63 regmap_read(br->clkr.regmap, br->halt_reg, &val); in clk_branch2_check_halt()
74 static int clk_branch_wait(const struct clk_branch *br, bool enabling, in clk_branch_wait() argument
77 bool voted = br->halt_check & BRANCH_VOTED; in clk_branch_wait()
78 const char *name = __clk_get_name(br->clkr.hw.clk); in clk_branch_wait()
81 if (clk_branch_in_hwcg_mode(br)) in clk_branch_wait()
84 if (br->halt_check == BRANCH_HALT_DELAY || (!enabling && voted)) { in clk_branch_wait()
86 } else if (br->halt_check == BRANCH_HALT_ENABLE || in clk_branch_wait()
87 br->halt_check == BRANCH_HALT || in clk_branch_wait()
92 if (check_halt(br, enabling)) in clk_branch_wait()
106 struct clk_branch *br = to_clk_branch(hw); in clk_branch_toggle() local
117 return clk_branch_wait(br, en, check_halt); in clk_branch_toggle()