It was <2021-03-30 wto 02:03>, when Alexandre Belloni wrote:
> The core now has RTC_FEATURE_ALARM for the driver to indicate whether
> alarms are available. Use that instead of HAS_ALARM to ensure the alarm
> callbacks are not even called.
>
> Signed-off-by: Alexandre Belloni <alexandre.bell...@bootlin.com>
> ---
>  drivers/rtc/rtc-ds1307.c | 42 +++++++---------------------------------
>  1 file changed, 7 insertions(+), 35 deletions(-)
>

Tested-by: Łukasz Stelmach <l.stelm...@samsung.com>
Reviewed-by: Łukasz Stelmach <l.stelm...@samsung.com>

> diff --git a/drivers/rtc/rtc-ds1307.c b/drivers/rtc/rtc-ds1307.c
> index cd8e438bc9c4..76d67c419f7d 100644
> --- a/drivers/rtc/rtc-ds1307.c
> +++ b/drivers/rtc/rtc-ds1307.c
> @@ -171,7 +171,6 @@ struct ds1307 {
>       enum ds_type            type;
>       unsigned long           flags;
>  #define HAS_NVRAM    0               /* bit 0 == sysfs file active */
> -#define HAS_ALARM    1               /* bit 1 == irq claimed */
>       struct device           *dev;
>       struct regmap           *regmap;
>       const char              *name;
> @@ -411,9 +410,6 @@ static int ds1337_read_alarm(struct device *dev, struct 
> rtc_wkalrm *t)
>       int                     ret;
>       u8                      regs[9];
>  
> -     if (!test_bit(HAS_ALARM, &ds1307->flags))
> -             return -EINVAL;
> -
>       /* read all ALARM1, ALARM2, and status registers at once */
>       ret = regmap_bulk_read(ds1307->regmap, DS1339_REG_ALARM1_SECS,
>                              regs, sizeof(regs));
> @@ -454,9 +450,6 @@ static int ds1337_set_alarm(struct device *dev, struct 
> rtc_wkalrm *t)
>       u8                      control, status;
>       int                     ret;
>  
> -     if (!test_bit(HAS_ALARM, &ds1307->flags))
> -             return -EINVAL;
> -
>       dev_dbg(dev, "%s secs=%d, mins=%d, "
>               "hours=%d, mday=%d, enabled=%d, pending=%d\n",
>               "alarm set", t->time.tm_sec, t->time.tm_min,
> @@ -512,9 +505,6 @@ static int ds1307_alarm_irq_enable(struct device *dev, 
> unsigned int enabled)
>  {
>       struct ds1307           *ds1307 = dev_get_drvdata(dev);
>  
> -     if (!test_bit(HAS_ALARM, &ds1307->flags))
> -             return -ENOTTY;
> -
>       return regmap_update_bits(ds1307->regmap, DS1337_REG_CONTROL,
>                                 DS1337_BIT_A1IE,
>                                 enabled ? DS1337_BIT_A1IE : 0);
> @@ -592,9 +582,6 @@ static int rx8130_read_alarm(struct device *dev, struct 
> rtc_wkalrm *t)
>       u8 ald[3], ctl[3];
>       int ret;
>  
> -     if (!test_bit(HAS_ALARM, &ds1307->flags))
> -             return -EINVAL;
> -
>       /* Read alarm registers. */
>       ret = regmap_bulk_read(ds1307->regmap, RX8130_REG_ALARM_MIN, ald,
>                              sizeof(ald));
> @@ -634,9 +621,6 @@ static int rx8130_set_alarm(struct device *dev, struct 
> rtc_wkalrm *t)
>       u8 ald[3], ctl[3];
>       int ret;
>  
> -     if (!test_bit(HAS_ALARM, &ds1307->flags))
> -             return -EINVAL;
> -
>       dev_dbg(dev, "%s, sec=%d min=%d hour=%d wday=%d mday=%d mon=%d "
>               "enabled=%d pending=%d\n", __func__,
>               t->time.tm_sec, t->time.tm_min, t->time.tm_hour,
> @@ -681,9 +665,6 @@ static int rx8130_alarm_irq_enable(struct device *dev, 
> unsigned int enabled)
>       struct ds1307 *ds1307 = dev_get_drvdata(dev);
>       int ret, reg;
>  
> -     if (!test_bit(HAS_ALARM, &ds1307->flags))
> -             return -EINVAL;
> -
>       ret = regmap_read(ds1307->regmap, RX8130_REG_CONTROL0, &reg);
>       if (ret < 0)
>               return ret;
> @@ -735,9 +716,6 @@ static int mcp794xx_read_alarm(struct device *dev, struct 
> rtc_wkalrm *t)
>       u8 regs[10];
>       int ret;
>  
> -     if (!test_bit(HAS_ALARM, &ds1307->flags))
> -             return -EINVAL;
> -
>       /* Read control and alarm 0 registers. */
>       ret = regmap_bulk_read(ds1307->regmap, MCP794XX_REG_CONTROL, regs,
>                              sizeof(regs));
> @@ -793,9 +771,6 @@ static int mcp794xx_set_alarm(struct device *dev, struct 
> rtc_wkalrm *t)
>       unsigned char regs[10];
>       int wday, ret;
>  
> -     if (!test_bit(HAS_ALARM, &ds1307->flags))
> -             return -EINVAL;
> -
>       wday = mcp794xx_alm_weekday(dev, &t->time);
>       if (wday < 0)
>               return wday;
> @@ -842,9 +817,6 @@ static int mcp794xx_alarm_irq_enable(struct device *dev, 
> unsigned int enabled)
>  {
>       struct ds1307 *ds1307 = dev_get_drvdata(dev);
>  
> -     if (!test_bit(HAS_ALARM, &ds1307->flags))
> -             return -EINVAL;
> -
>       return regmap_update_bits(ds1307->regmap, MCP794XX_REG_CONTROL,
>                                 MCP794XX_BIT_ALM0_EN,
>                                 enabled ? MCP794XX_BIT_ALM0_EN : 0);
> @@ -1641,7 +1613,7 @@ static int ds3231_clks_register(struct ds1307 *ds1307)
>                * Interrupt signal due to alarm conditions and square-wave
>                * output share same pin, so don't initialize both.
>                */
> -             if (i == DS3231_CLK_SQW && test_bit(HAS_ALARM, &ds1307->flags))
> +             if (i == DS3231_CLK_SQW && test_bit(RTC_FEATURE_ALARM, 
> ds1307->rtc->features))
>                       continue;
>  
>               init.name = ds3231_clks_names[i];
> @@ -1964,15 +1936,15 @@ static int ds1307_probe(struct i2c_client *client,
>                            bin2bcd(tmp));
>       }
>  
> -     if (want_irq || ds1307_can_wakeup_device) {
> -             device_set_wakeup_capable(ds1307->dev, true);
> -             set_bit(HAS_ALARM, &ds1307->flags);
> -     }
> -
>       ds1307->rtc = devm_rtc_allocate_device(ds1307->dev);
>       if (IS_ERR(ds1307->rtc))
>               return PTR_ERR(ds1307->rtc);
>  
> +     if (want_irq || ds1307_can_wakeup_device)
> +             device_set_wakeup_capable(ds1307->dev, true);
> +     else
> +             clear_bit(RTC_FEATURE_ALARM, ds1307->rtc->features);
> +
>       if (ds1307_can_wakeup_device && !want_irq) {
>               dev_info(ds1307->dev,
>                        "'wakeup-source' is set, request for an IRQ is 
> disabled!\n");
> @@ -1988,7 +1960,7 @@ static int ds1307_probe(struct i2c_client *client,
>               if (err) {
>                       client->irq = 0;
>                       device_set_wakeup_capable(ds1307->dev, false);
> -                     clear_bit(HAS_ALARM, &ds1307->flags);
> +                     clear_bit(RTC_FEATURE_ALARM, ds1307->rtc->features);
>                       dev_err(ds1307->dev, "unable to request IRQ!\n");
>               } else {
>                       dev_dbg(ds1307->dev, "got IRQ %d\n", client->irq);

-- 
Łukasz Stelmach
Samsung R&D Institute Poland
Samsung Electronics

Attachment: signature.asc
Description: PGP signature

Reply via email to