mirror of https://gitee.com/openkylin/linux.git
rtc: ds1307: replace HAS_ALARM by RTC_FEATURE_ALARM
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. Tested-by: Łukasz Stelmach <l.stelmach@samsung.com> Reviewed-by: Łukasz Stelmach <l.stelmach@samsung.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com> Link: https://lore.kernel.org/r/20210418000023.995758-1-alexandre.belloni@bootlin.com
This commit is contained in:
parent
7942121b8c
commit
64e9d8e4db
|
@ -171,7 +171,6 @@ struct ds1307 {
|
||||||
enum ds_type type;
|
enum ds_type type;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
#define HAS_NVRAM 0 /* bit 0 == sysfs file active */
|
#define HAS_NVRAM 0 /* bit 0 == sysfs file active */
|
||||||
#define HAS_ALARM 1 /* bit 1 == irq claimed */
|
|
||||||
struct device *dev;
|
struct device *dev;
|
||||||
struct regmap *regmap;
|
struct regmap *regmap;
|
||||||
const char *name;
|
const char *name;
|
||||||
|
@ -411,9 +410,6 @@ static int ds1337_read_alarm(struct device *dev, struct rtc_wkalrm *t)
|
||||||
int ret;
|
int ret;
|
||||||
u8 regs[9];
|
u8 regs[9];
|
||||||
|
|
||||||
if (!test_bit(HAS_ALARM, &ds1307->flags))
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
/* read all ALARM1, ALARM2, and status registers at once */
|
/* read all ALARM1, ALARM2, and status registers at once */
|
||||||
ret = regmap_bulk_read(ds1307->regmap, DS1339_REG_ALARM1_SECS,
|
ret = regmap_bulk_read(ds1307->regmap, DS1339_REG_ALARM1_SECS,
|
||||||
regs, sizeof(regs));
|
regs, sizeof(regs));
|
||||||
|
@ -454,9 +450,6 @@ static int ds1337_set_alarm(struct device *dev, struct rtc_wkalrm *t)
|
||||||
u8 control, status;
|
u8 control, status;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (!test_bit(HAS_ALARM, &ds1307->flags))
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
dev_dbg(dev, "%s secs=%d, mins=%d, "
|
dev_dbg(dev, "%s secs=%d, mins=%d, "
|
||||||
"hours=%d, mday=%d, enabled=%d, pending=%d\n",
|
"hours=%d, mday=%d, enabled=%d, pending=%d\n",
|
||||||
"alarm set", t->time.tm_sec, t->time.tm_min,
|
"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);
|
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,
|
return regmap_update_bits(ds1307->regmap, DS1337_REG_CONTROL,
|
||||||
DS1337_BIT_A1IE,
|
DS1337_BIT_A1IE,
|
||||||
enabled ? DS1337_BIT_A1IE : 0);
|
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];
|
u8 ald[3], ctl[3];
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (!test_bit(HAS_ALARM, &ds1307->flags))
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
/* Read alarm registers. */
|
/* Read alarm registers. */
|
||||||
ret = regmap_bulk_read(ds1307->regmap, RX8130_REG_ALARM_MIN, ald,
|
ret = regmap_bulk_read(ds1307->regmap, RX8130_REG_ALARM_MIN, ald,
|
||||||
sizeof(ald));
|
sizeof(ald));
|
||||||
|
@ -634,9 +621,6 @@ static int rx8130_set_alarm(struct device *dev, struct rtc_wkalrm *t)
|
||||||
u8 ald[3], ctl[3];
|
u8 ald[3], ctl[3];
|
||||||
int ret;
|
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 "
|
dev_dbg(dev, "%s, sec=%d min=%d hour=%d wday=%d mday=%d mon=%d "
|
||||||
"enabled=%d pending=%d\n", __func__,
|
"enabled=%d pending=%d\n", __func__,
|
||||||
t->time.tm_sec, t->time.tm_min, t->time.tm_hour,
|
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);
|
struct ds1307 *ds1307 = dev_get_drvdata(dev);
|
||||||
int ret, reg;
|
int ret, reg;
|
||||||
|
|
||||||
if (!test_bit(HAS_ALARM, &ds1307->flags))
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
ret = regmap_read(ds1307->regmap, RX8130_REG_CONTROL0, ®);
|
ret = regmap_read(ds1307->regmap, RX8130_REG_CONTROL0, ®);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -735,9 +716,6 @@ static int mcp794xx_read_alarm(struct device *dev, struct rtc_wkalrm *t)
|
||||||
u8 regs[10];
|
u8 regs[10];
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (!test_bit(HAS_ALARM, &ds1307->flags))
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
/* Read control and alarm 0 registers. */
|
/* Read control and alarm 0 registers. */
|
||||||
ret = regmap_bulk_read(ds1307->regmap, MCP794XX_REG_CONTROL, regs,
|
ret = regmap_bulk_read(ds1307->regmap, MCP794XX_REG_CONTROL, regs,
|
||||||
sizeof(regs));
|
sizeof(regs));
|
||||||
|
@ -793,9 +771,6 @@ static int mcp794xx_set_alarm(struct device *dev, struct rtc_wkalrm *t)
|
||||||
unsigned char regs[10];
|
unsigned char regs[10];
|
||||||
int wday, ret;
|
int wday, ret;
|
||||||
|
|
||||||
if (!test_bit(HAS_ALARM, &ds1307->flags))
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
wday = mcp794xx_alm_weekday(dev, &t->time);
|
wday = mcp794xx_alm_weekday(dev, &t->time);
|
||||||
if (wday < 0)
|
if (wday < 0)
|
||||||
return wday;
|
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);
|
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,
|
return regmap_update_bits(ds1307->regmap, MCP794XX_REG_CONTROL,
|
||||||
MCP794XX_BIT_ALM0_EN,
|
MCP794XX_BIT_ALM0_EN,
|
||||||
enabled ? MCP794XX_BIT_ALM0_EN : 0);
|
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
|
* Interrupt signal due to alarm conditions and square-wave
|
||||||
* output share same pin, so don't initialize both.
|
* 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;
|
continue;
|
||||||
|
|
||||||
init.name = ds3231_clks_names[i];
|
init.name = ds3231_clks_names[i];
|
||||||
|
@ -1964,15 +1936,15 @@ static int ds1307_probe(struct i2c_client *client,
|
||||||
bin2bcd(tmp));
|
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);
|
ds1307->rtc = devm_rtc_allocate_device(ds1307->dev);
|
||||||
if (IS_ERR(ds1307->rtc))
|
if (IS_ERR(ds1307->rtc))
|
||||||
return PTR_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) {
|
if (ds1307_can_wakeup_device && !want_irq) {
|
||||||
dev_info(ds1307->dev,
|
dev_info(ds1307->dev,
|
||||||
"'wakeup-source' is set, request for an IRQ is disabled!\n");
|
"'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) {
|
if (err) {
|
||||||
client->irq = 0;
|
client->irq = 0;
|
||||||
device_set_wakeup_capable(ds1307->dev, false);
|
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");
|
dev_err(ds1307->dev, "unable to request IRQ!\n");
|
||||||
} else {
|
} else {
|
||||||
dev_dbg(ds1307->dev, "got IRQ %d\n", client->irq);
|
dev_dbg(ds1307->dev, "got IRQ %d\n", client->irq);
|
||||||
|
|
Loading…
Reference in New Issue