diff options
| author | Dmitry Torokhov <[email protected]> | 2023-08-30 16:06:38 -0700 | 
|---|---|---|
| committer | Dmitry Torokhov <[email protected]> | 2023-08-30 16:06:38 -0700 | 
| commit | 1ac731c529cd4d6adbce134754b51ff7d822b145 (patch) | |
| tree | 143ab3f35ca5f3b69f583c84e6964b17139c2ec1 /drivers/clk/sprd/common.c | |
| parent | 07b4c950f27bef0362dc6ad7ee713aab61d58149 (diff) | |
| parent | 54116d442e001e1b6bd482122043b1870998a1f3 (diff) | |
Merge branch 'next' into for-linus
Prepare input updates for 6.6 merge window.
Diffstat (limited to 'drivers/clk/sprd/common.c')
| -rw-r--r-- | drivers/clk/sprd/common.c | 11 | 
1 files changed, 7 insertions, 4 deletions
diff --git a/drivers/clk/sprd/common.c b/drivers/clk/sprd/common.c index ce81e4087a8f..16142fbb7a47 100644 --- a/drivers/clk/sprd/common.c +++ b/drivers/clk/sprd/common.c @@ -17,7 +17,6 @@ static const struct regmap_config sprdclk_regmap_config = {  	.reg_bits	= 32,  	.reg_stride	= 4,  	.val_bits	= 32, -	.max_register	= 0xffff,  	.fast_io	= true,  }; @@ -43,8 +42,10 @@ int sprd_clk_regmap_init(struct platform_device *pdev,  	struct device *dev = &pdev->dev;  	struct device_node *node = dev->of_node, *np;  	struct regmap *regmap; +	struct resource *res; +	struct regmap_config reg_config = sprdclk_regmap_config; -	if (of_find_property(node, "sprd,syscon", NULL)) { +	if (of_property_present(node, "sprd,syscon")) {  		regmap = syscon_regmap_lookup_by_phandle(node, "sprd,syscon");  		if (IS_ERR(regmap)) {  			pr_err("%s: failed to get syscon regmap\n", __func__); @@ -59,12 +60,14 @@ int sprd_clk_regmap_init(struct platform_device *pdev,  			return PTR_ERR(regmap);  		}  	} else { -		base = devm_platform_ioremap_resource(pdev, 0); +		base = devm_platform_get_and_ioremap_resource(pdev, 0, &res);  		if (IS_ERR(base))  			return PTR_ERR(base); +		reg_config.max_register = resource_size(res) - reg_config.reg_stride; +  		regmap = devm_regmap_init_mmio(&pdev->dev, base, -					       &sprdclk_regmap_config); +					       ®_config);  		if (IS_ERR(regmap)) {  			pr_err("failed to init regmap\n");  			return PTR_ERR(regmap);  |