diff options
| -rw-r--r-- | drivers/clk/clk-composite.c | 5 | ||||
| -rw-r--r-- | drivers/clk/clk-loongson2.c | 2 | ||||
| -rw-r--r-- | drivers/clk/mediatek/clk-mt8365.c | 18 | ||||
| -rw-r--r-- | drivers/clk/pxa/clk-pxa3xx.c | 2 | 
4 files changed, 21 insertions, 6 deletions
| diff --git a/drivers/clk/clk-composite.c b/drivers/clk/clk-composite.c index edfa94641bbf..66759fe28fad 100644 --- a/drivers/clk/clk-composite.c +++ b/drivers/clk/clk-composite.c @@ -119,7 +119,10 @@ static int clk_composite_determine_rate(struct clk_hw *hw,  			if (ret)  				continue; -			rate_diff = abs(req->rate - tmp_req.rate); +			if (req->rate >= tmp_req.rate) +				rate_diff = req->rate - tmp_req.rate; +			else +				rate_diff = tmp_req.rate - req->rate;  			if (!rate_diff || !req->best_parent_hw  				       || best_rate_diff > rate_diff) { diff --git a/drivers/clk/clk-loongson2.c b/drivers/clk/clk-loongson2.c index 70ae1dd2e474..bacdcbb287ac 100644 --- a/drivers/clk/clk-loongson2.c +++ b/drivers/clk/clk-loongson2.c @@ -40,7 +40,7 @@ static struct clk_hw *loongson2_clk_register(struct device *dev,  {  	int ret;  	struct clk_hw *hw; -	struct clk_init_data init; +	struct clk_init_data init = { };  	hw = devm_kzalloc(dev, sizeof(*hw), GFP_KERNEL);  	if (!hw) diff --git a/drivers/clk/mediatek/clk-mt8365.c b/drivers/clk/mediatek/clk-mt8365.c index 6b4e193f648d..c87a6c4a7967 100644 --- a/drivers/clk/mediatek/clk-mt8365.c +++ b/drivers/clk/mediatek/clk-mt8365.c @@ -23,6 +23,7 @@  static DEFINE_SPINLOCK(mt8365_clk_lock);  static const struct mtk_fixed_clk top_fixed_clks[] = { +	FIXED_CLK(CLK_TOP_CLK_NULL, "clk_null", NULL, 0),  	FIXED_CLK(CLK_TOP_I2S0_BCK, "i2s0_bck", NULL, 26000000),  	FIXED_CLK(CLK_TOP_DSI0_LNTC_DSICK, "dsi0_lntc_dsick", "clk26m",  		  75000000), @@ -559,6 +560,14 @@ static const struct mtk_clk_divider top_adj_divs[] = {  		  0x324, 16, 8, CLK_DIVIDER_ROUND_CLOSEST),  	DIV_ADJ_F(CLK_TOP_APLL12_CK_DIV3, "apll12_ck_div3", "apll_i2s3_sel",  		  0x324, 24, 8, CLK_DIVIDER_ROUND_CLOSEST), +	DIV_ADJ_F(CLK_TOP_APLL12_CK_DIV4, "apll12_ck_div4", "apll_tdmout_sel", +		  0x328, 0, 8, CLK_DIVIDER_ROUND_CLOSEST), +	DIV_ADJ_F(CLK_TOP_APLL12_CK_DIV4B, "apll12_ck_div4b", "apll_tdmout_sel", +		  0x328, 8, 8, CLK_DIVIDER_ROUND_CLOSEST), +	DIV_ADJ_F(CLK_TOP_APLL12_CK_DIV5, "apll12_ck_div5", "apll_tdmin_sel", +		  0x328, 16, 8, CLK_DIVIDER_ROUND_CLOSEST), +	DIV_ADJ_F(CLK_TOP_APLL12_CK_DIV5B, "apll12_ck_div5b", "apll_tdmin_sel", +		  0x328, 24, 8, CLK_DIVIDER_ROUND_CLOSEST),  	DIV_ADJ_F(CLK_TOP_APLL12_CK_DIV6, "apll12_ck_div6", "apll_spdif_sel",  		  0x32c, 0, 8, CLK_DIVIDER_ROUND_CLOSEST),  }; @@ -583,15 +592,15 @@ static const struct mtk_gate_regs top2_cg_regs = {  #define GATE_TOP0(_id, _name, _parent, _shift)			\  	GATE_MTK(_id, _name, _parent, &top0_cg_regs,		\ -		 _shift, &mtk_clk_gate_ops_no_setclr_inv) +		 _shift, &mtk_clk_gate_ops_no_setclr)  #define GATE_TOP1(_id, _name, _parent, _shift)			\  	GATE_MTK(_id, _name, _parent, &top1_cg_regs,		\ -		 _shift, &mtk_clk_gate_ops_no_setclr) +		 _shift, &mtk_clk_gate_ops_no_setclr_inv)  #define GATE_TOP2(_id, _name, _parent, _shift)			\  	GATE_MTK(_id, _name, _parent, &top2_cg_regs,		\ -		 _shift, &mtk_clk_gate_ops_no_setclr) +		 _shift, &mtk_clk_gate_ops_no_setclr_inv)  static const struct mtk_gate top_clk_gates[] = {  	GATE_TOP0(CLK_TOP_CONN_32K, "conn_32k", "clk32k", 10), @@ -696,6 +705,7 @@ static const struct mtk_gate ifr_clks[] = {  	GATE_IFR3(CLK_IFR_GCPU, "ifr_gcpu", "axi_sel", 8),  	GATE_IFR3(CLK_IFR_TRNG, "ifr_trng", "axi_sel", 9),  	GATE_IFR3(CLK_IFR_AUXADC, "ifr_auxadc", "clk26m", 10), +	GATE_IFR3(CLK_IFR_CPUM, "ifr_cpum", "clk26m", 11),  	GATE_IFR3(CLK_IFR_AUXADC_MD, "ifr_auxadc_md", "clk26m", 14),  	GATE_IFR3(CLK_IFR_AP_DMA, "ifr_ap_dma", "axi_sel", 18),  	GATE_IFR3(CLK_IFR_DEBUGSYS, "ifr_debugsys", "axi_sel", 24), @@ -717,6 +727,8 @@ static const struct mtk_gate ifr_clks[] = {  	GATE_IFR5(CLK_IFR_PWRAP_TMR, "ifr_pwrap_tmr", "clk26m", 12),  	GATE_IFR5(CLK_IFR_PWRAP_SPI, "ifr_pwrap_spi", "clk26m", 13),  	GATE_IFR5(CLK_IFR_PWRAP_SYS, "ifr_pwrap_sys", "clk26m", 14), +	GATE_MTK_FLAGS(CLK_IFR_MCU_PM_BK, "ifr_mcu_pm_bk", NULL, &ifr5_cg_regs, +			17, &mtk_clk_gate_ops_setclr, CLK_IGNORE_UNUSED),  	GATE_IFR5(CLK_IFR_IRRX_26M, "ifr_irrx_26m", "clk26m", 22),  	GATE_IFR5(CLK_IFR_IRRX_32K, "ifr_irrx_32k", "clk32k", 23),  	GATE_IFR5(CLK_IFR_I2C0_AXI, "ifr_i2c0_axi", "i2c_sel", 24), diff --git a/drivers/clk/pxa/clk-pxa3xx.c b/drivers/clk/pxa/clk-pxa3xx.c index 42958a542662..621e298f101a 100644 --- a/drivers/clk/pxa/clk-pxa3xx.c +++ b/drivers/clk/pxa/clk-pxa3xx.c @@ -164,7 +164,7 @@ void pxa3xx_clk_update_accr(u32 disable, u32 enable, u32 xclkcfg, u32 mask)  	accr &= ~disable;  	accr |= enable; -	writel(accr, ACCR); +	writel(accr, clk_regs + ACCR);  	if (xclkcfg)  		__asm__("mcr p14, 0, %0, c6, c0, 0\n" : : "r"(xclkcfg)); | 
