rtc: ds1307: improve trickle charger initialization
Instead of storing the trickle_charger_setup value in struct chip_desc we can let function ds1307_trickle_init return it because it's used in the probe function only. This allows us to constify struct chip_desc variables in a next step. Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@free-electrons.com>
This commit is contained in:
parent
0b6ee80594
commit
d8490fd55a
@ -141,7 +141,6 @@ struct chip_desc {
|
|||||||
u8 century_bit;
|
u8 century_bit;
|
||||||
u8 bbsqi_bit;
|
u8 bbsqi_bit;
|
||||||
u16 trickle_charger_reg;
|
u16 trickle_charger_reg;
|
||||||
u8 trickle_charger_setup;
|
|
||||||
u8 (*do_trickle_setup)(struct ds1307 *, uint32_t,
|
u8 (*do_trickle_setup)(struct ds1307 *, uint32_t,
|
||||||
bool);
|
bool);
|
||||||
};
|
};
|
||||||
@ -941,23 +940,23 @@ static u8 do_trickle_setup_ds1339(struct ds1307 *ds1307,
|
|||||||
return setup;
|
return setup;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ds1307_trickle_init(struct ds1307 *ds1307,
|
static u8 ds1307_trickle_init(struct ds1307 *ds1307,
|
||||||
struct chip_desc *chip)
|
struct chip_desc *chip)
|
||||||
{
|
{
|
||||||
uint32_t ohms = 0;
|
uint32_t ohms;
|
||||||
bool diode = true;
|
bool diode = true;
|
||||||
|
|
||||||
if (!chip->do_trickle_setup)
|
if (!chip->do_trickle_setup)
|
||||||
goto out;
|
return 0;
|
||||||
|
|
||||||
if (device_property_read_u32(ds1307->dev, "trickle-resistor-ohms",
|
if (device_property_read_u32(ds1307->dev, "trickle-resistor-ohms",
|
||||||
&ohms))
|
&ohms))
|
||||||
goto out;
|
return 0;
|
||||||
|
|
||||||
if (device_property_read_bool(ds1307->dev, "trickle-diode-disable"))
|
if (device_property_read_bool(ds1307->dev, "trickle-diode-disable"))
|
||||||
diode = false;
|
diode = false;
|
||||||
chip->trickle_charger_setup = chip->do_trickle_setup(ds1307,
|
|
||||||
ohms, diode);
|
return chip->do_trickle_setup(ds1307, ohms, diode);
|
||||||
out:
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*----------------------------------------------------------------------*/
|
/*----------------------------------------------------------------------*/
|
||||||
@ -1319,6 +1318,7 @@ static int ds1307_probe(struct i2c_client *client,
|
|||||||
struct ds1307_platform_data *pdata = dev_get_platdata(&client->dev);
|
struct ds1307_platform_data *pdata = dev_get_platdata(&client->dev);
|
||||||
struct rtc_time tm;
|
struct rtc_time tm;
|
||||||
unsigned long timestamp;
|
unsigned long timestamp;
|
||||||
|
u8 trickle_charger_setup = 0;
|
||||||
|
|
||||||
irq_handler_t irq_handler = ds1307_irq;
|
irq_handler_t irq_handler = ds1307_irq;
|
||||||
|
|
||||||
@ -1359,18 +1359,17 @@ static int ds1307_probe(struct i2c_client *client,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!pdata)
|
if (!pdata)
|
||||||
ds1307_trickle_init(ds1307, chip);
|
trickle_charger_setup = ds1307_trickle_init(ds1307, chip);
|
||||||
else if (pdata->trickle_charger_setup)
|
else if (pdata->trickle_charger_setup)
|
||||||
chip->trickle_charger_setup = pdata->trickle_charger_setup;
|
trickle_charger_setup = pdata->trickle_charger_setup;
|
||||||
|
|
||||||
if (chip->trickle_charger_setup && chip->trickle_charger_reg) {
|
if (trickle_charger_setup && chip->trickle_charger_reg) {
|
||||||
|
trickle_charger_setup |= DS13XX_TRICKLE_CHARGER_MAGIC;
|
||||||
dev_dbg(ds1307->dev,
|
dev_dbg(ds1307->dev,
|
||||||
"writing trickle charger info 0x%x to 0x%x\n",
|
"writing trickle charger info 0x%x to 0x%x\n",
|
||||||
DS13XX_TRICKLE_CHARGER_MAGIC | chip->trickle_charger_setup,
|
trickle_charger_setup, chip->trickle_charger_reg);
|
||||||
chip->trickle_charger_reg);
|
|
||||||
regmap_write(ds1307->regmap, chip->trickle_charger_reg,
|
regmap_write(ds1307->regmap, chip->trickle_charger_reg,
|
||||||
DS13XX_TRICKLE_CHARGER_MAGIC |
|
trickle_charger_setup);
|
||||||
chip->trickle_charger_setup);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
buf = ds1307->regs;
|
buf = ds1307->regs;
|
||||||
|
Loading…
Reference in New Issue
Block a user