mirror of https://gitee.com/openkylin/linux.git
clk: mvebu: armada-37xx-periph: save the IP base address in the driver data
Prepare the introduction of suspend/resume hooks by having an easy way to access all the registers in one go just from a device: add the IP base address in the driver data. Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com> Signed-off-by: Stephen Boyd <sboyd@kernel.org>
This commit is contained in:
parent
5b394b2ddf
commit
d9d95e78cf
|
@ -56,6 +56,7 @@
|
||||||
struct clk_periph_driver_data {
|
struct clk_periph_driver_data {
|
||||||
struct clk_hw_onecell_data *hw_data;
|
struct clk_hw_onecell_data *hw_data;
|
||||||
spinlock_t lock;
|
spinlock_t lock;
|
||||||
|
void __iomem *reg;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct clk_double_div {
|
struct clk_double_div {
|
||||||
|
@ -680,7 +681,6 @@ static int armada_3700_periph_clock_probe(struct platform_device *pdev)
|
||||||
struct device *dev = &pdev->dev;
|
struct device *dev = &pdev->dev;
|
||||||
int num_periph = 0, i, ret;
|
int num_periph = 0, i, ret;
|
||||||
struct resource *res;
|
struct resource *res;
|
||||||
void __iomem *reg;
|
|
||||||
|
|
||||||
data = of_device_get_match_data(dev);
|
data = of_device_get_match_data(dev);
|
||||||
if (!data)
|
if (!data)
|
||||||
|
@ -689,11 +689,6 @@ static int armada_3700_periph_clock_probe(struct platform_device *pdev)
|
||||||
while (data[num_periph].name)
|
while (data[num_periph].name)
|
||||||
num_periph++;
|
num_periph++;
|
||||||
|
|
||||||
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
|
||||||
reg = devm_ioremap_resource(dev, res);
|
|
||||||
if (IS_ERR(reg))
|
|
||||||
return PTR_ERR(reg);
|
|
||||||
|
|
||||||
driver_data = devm_kzalloc(dev, sizeof(*driver_data), GFP_KERNEL);
|
driver_data = devm_kzalloc(dev, sizeof(*driver_data), GFP_KERNEL);
|
||||||
if (!driver_data)
|
if (!driver_data)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
@ -706,12 +701,16 @@ static int armada_3700_periph_clock_probe(struct platform_device *pdev)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
driver_data->hw_data->num = num_periph;
|
driver_data->hw_data->num = num_periph;
|
||||||
|
|
||||||
|
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
||||||
|
driver_data->reg = devm_ioremap_resource(dev, res);
|
||||||
|
if (IS_ERR(driver_data->reg))
|
||||||
|
return PTR_ERR(driver_data->reg);
|
||||||
|
|
||||||
spin_lock_init(&driver_data->lock);
|
spin_lock_init(&driver_data->lock);
|
||||||
|
|
||||||
for (i = 0; i < num_periph; i++) {
|
for (i = 0; i < num_periph; i++) {
|
||||||
struct clk_hw **hw = &driver_data->hw_data->hws[i];
|
struct clk_hw **hw = &driver_data->hw_data->hws[i];
|
||||||
|
if (armada_3700_add_composite_clk(&data[i], driver_data->reg,
|
||||||
if (armada_3700_add_composite_clk(&data[i], reg,
|
|
||||||
&driver_data->lock, dev, hw))
|
&driver_data->lock, dev, hw))
|
||||||
dev_err(dev, "Can't register periph clock %s\n",
|
dev_err(dev, "Can't register periph clock %s\n",
|
||||||
data[i].name);
|
data[i].name);
|
||||||
|
|
Loading…
Reference in New Issue