cregit-Linux how code gets into the kernel

Release 4.16 drivers/clk/qcom/clk-regmap-divider.c

Directory: drivers/clk/qcom
/*
 * Copyright (c) 2014, The Linux Foundation. All rights reserved.
 *
 * This software is licensed under the terms of the GNU General Public
 * License version 2, as published by the Free Software Foundation, and
 * may be copied, distributed, and modified under those terms.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 */

#include <linux/kernel.h>
#include <linux/bitops.h>
#include <linux/regmap.h>
#include <linux/export.h>

#include "clk-regmap-divider.h"


static inline struct clk_regmap_div *to_clk_regmap_div(struct clk_hw *hw) { return container_of(to_clk_regmap(hw), struct clk_regmap_div, clkr); }

Contributors

PersonTokensPropCommitsCommitProp
Julia Cartwright28100.00%1100.00%
Total28100.00%1100.00%


static long div_round_ro_rate(struct clk_hw *hw, unsigned long rate, unsigned long *prate) { struct clk_regmap_div *divider = to_clk_regmap_div(hw); struct clk_regmap *clkr = &divider->clkr; u32 div; struct clk_hw *hw_parent = clk_hw_get_parent(hw); regmap_read(clkr->regmap, divider->reg, &div); div >>= divider->shift; div &= BIT(divider->width) - 1; div += 1; if (clk_hw_get_flags(hw) & CLK_SET_RATE_PARENT) { if (!hw_parent) return -EINVAL; *prate = clk_hw_round_rate(hw_parent, rate * div); } return DIV_ROUND_UP_ULL((u64)*prate, div); }

Contributors

PersonTokensPropCommitsCommitProp
Abhishek Sahu132100.00%1100.00%
Total132100.00%1100.00%


static long div_round_rate(struct clk_hw *hw, unsigned long rate, unsigned long *prate) { struct clk_regmap_div *divider = to_clk_regmap_div(hw); return divider_round_rate(hw, rate, prate, NULL, divider->width, CLK_DIVIDER_ROUND_CLOSEST); }

Contributors

PersonTokensPropCommitsCommitProp
Julia Cartwright48100.00%1100.00%
Total48100.00%1100.00%


static int div_set_rate(struct clk_hw *hw, unsigned long rate, unsigned long parent_rate) { struct clk_regmap_div *divider = to_clk_regmap_div(hw); struct clk_regmap *clkr = &divider->clkr; u32 div; div = divider_get_val(rate, parent_rate, NULL, divider->width, CLK_DIVIDER_ROUND_CLOSEST); return regmap_update_bits(clkr->regmap, divider->reg, (BIT(divider->width) - 1) << divider->shift, div << divider->shift); }

Contributors

PersonTokensPropCommitsCommitProp
Julia Cartwright92100.00%1100.00%
Total92100.00%1100.00%


static unsigned long div_recalc_rate(struct clk_hw *hw, unsigned long parent_rate) { struct clk_regmap_div *divider = to_clk_regmap_div(hw); struct clk_regmap *clkr = &divider->clkr; u32 div; regmap_read(clkr->regmap, divider->reg, &div); div >>= divider->shift; div &= BIT(divider->width) - 1; return divider_recalc_rate(hw, parent_rate, div, NULL, CLK_DIVIDER_ROUND_CLOSEST, divider->width); }

Contributors

PersonTokensPropCommitsCommitProp
Julia Cartwright8495.45%150.00%
Jerome Brunet44.55%150.00%
Total88100.00%2100.00%

const struct clk_ops clk_regmap_div_ops = { .round_rate = div_round_rate, .set_rate = div_set_rate, .recalc_rate = div_recalc_rate, }; EXPORT_SYMBOL_GPL(clk_regmap_div_ops); const struct clk_ops clk_regmap_div_ro_ops = { .round_rate = div_round_ro_rate, .recalc_rate = div_recalc_rate, }; EXPORT_SYMBOL_GPL(clk_regmap_div_ro_ops);

Overall Contributors

PersonTokensPropCommitsCommitProp
Julia Cartwright29565.12%133.33%
Abhishek Sahu15434.00%133.33%
Jerome Brunet40.88%133.33%
Total453100.00%3100.00%
Directory: drivers/clk/qcom
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.