mirror of
https://github.com/torvalds/linux.git
synced 2024-11-22 04:38:03 +00:00
rtc: tps6594: introduce private structure as drvdata
This patch will prepare for the next one (power management support) by introducing struct tps6594_rtc. No functionnal change. Signed-off-by: Richard Genoud <richard.genoud@bootlin.com> Link: https://lore.kernel.org/r/20240618141851.1810000-3-richard.genoud@bootlin.com Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
This commit is contained in:
parent
94d4154792
commit
29bf97586f
@ -42,6 +42,10 @@
|
|||||||
// Multiplier for ppb conversions
|
// Multiplier for ppb conversions
|
||||||
#define PPB_MULT NANO
|
#define PPB_MULT NANO
|
||||||
|
|
||||||
|
struct tps6594_rtc {
|
||||||
|
struct rtc_device *rtc_dev;
|
||||||
|
};
|
||||||
|
|
||||||
static int tps6594_rtc_alarm_irq_enable(struct device *dev,
|
static int tps6594_rtc_alarm_irq_enable(struct device *dev,
|
||||||
unsigned int enabled)
|
unsigned int enabled)
|
||||||
{
|
{
|
||||||
@ -325,11 +329,11 @@ static int tps6594_rtc_set_offset(struct device *dev, long offset)
|
|||||||
return tps6594_rtc_set_calibration(dev, calibration);
|
return tps6594_rtc_set_calibration(dev, calibration);
|
||||||
}
|
}
|
||||||
|
|
||||||
static irqreturn_t tps6594_rtc_interrupt(int irq, void *rtc)
|
static irqreturn_t tps6594_rtc_interrupt(int irq, void *data)
|
||||||
{
|
{
|
||||||
struct device *dev = rtc;
|
struct device *dev = data;
|
||||||
struct tps6594 *tps = dev_get_drvdata(dev->parent);
|
struct tps6594 *tps = dev_get_drvdata(dev->parent);
|
||||||
struct rtc_device *rtc_dev = dev_get_drvdata(dev);
|
struct tps6594_rtc *rtc = dev_get_drvdata(dev);
|
||||||
int ret;
|
int ret;
|
||||||
u32 rtc_reg;
|
u32 rtc_reg;
|
||||||
|
|
||||||
@ -337,7 +341,7 @@ static irqreturn_t tps6594_rtc_interrupt(int irq, void *rtc)
|
|||||||
if (ret)
|
if (ret)
|
||||||
return IRQ_NONE;
|
return IRQ_NONE;
|
||||||
|
|
||||||
rtc_update_irq(rtc_dev, 1, RTC_IRQF | RTC_AF);
|
rtc_update_irq(rtc->rtc_dev, 1, RTC_IRQF | RTC_AF);
|
||||||
|
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
@ -356,13 +360,17 @@ static int tps6594_rtc_probe(struct platform_device *pdev)
|
|||||||
{
|
{
|
||||||
struct tps6594 *tps = dev_get_drvdata(pdev->dev.parent);
|
struct tps6594 *tps = dev_get_drvdata(pdev->dev.parent);
|
||||||
struct device *dev = &pdev->dev;
|
struct device *dev = &pdev->dev;
|
||||||
struct rtc_device *rtc;
|
struct tps6594_rtc *rtc;
|
||||||
int irq;
|
int irq;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
rtc = devm_rtc_allocate_device(dev);
|
rtc = devm_kzalloc(dev, sizeof(*rtc), GFP_KERNEL);
|
||||||
if (IS_ERR(rtc))
|
if (!rtc)
|
||||||
return PTR_ERR(rtc);
|
return -ENOMEM;
|
||||||
|
|
||||||
|
rtc->rtc_dev = devm_rtc_allocate_device(dev);
|
||||||
|
if (IS_ERR(rtc->rtc_dev))
|
||||||
|
return PTR_ERR(rtc->rtc_dev);
|
||||||
|
|
||||||
// Enable crystal oscillator.
|
// Enable crystal oscillator.
|
||||||
ret = regmap_set_bits(tps->regmap, TPS6594_REG_RTC_CTRL_2,
|
ret = regmap_set_bits(tps->regmap, TPS6594_REG_RTC_CTRL_2,
|
||||||
@ -423,11 +431,11 @@ static int tps6594_rtc_probe(struct platform_device *pdev)
|
|||||||
return dev_err_probe(dev, ret,
|
return dev_err_probe(dev, ret,
|
||||||
"Failed to init rtc as wakeup source\n");
|
"Failed to init rtc as wakeup source\n");
|
||||||
|
|
||||||
rtc->ops = &tps6594_rtc_ops;
|
rtc->rtc_dev->ops = &tps6594_rtc_ops;
|
||||||
rtc->range_min = RTC_TIMESTAMP_BEGIN_2000;
|
rtc->rtc_dev->range_min = RTC_TIMESTAMP_BEGIN_2000;
|
||||||
rtc->range_max = RTC_TIMESTAMP_END_2099;
|
rtc->rtc_dev->range_max = RTC_TIMESTAMP_END_2099;
|
||||||
|
|
||||||
return devm_rtc_register_device(rtc);
|
return devm_rtc_register_device(rtc->rtc_dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct platform_device_id tps6594_rtc_id_table[] = {
|
static const struct platform_device_id tps6594_rtc_id_table[] = {
|
||||||
|
Loading…
Reference in New Issue
Block a user