0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013 #include <linux/module.h>
0014 #include <linux/kernel.h>
0015 #include <linux/device.h>
0016 #include <linux/printk.h>
0017 #include <linux/spi/spi.h>
0018 #include <linux/rtc.h>
0019 #include <linux/of.h>
0020 #include <linux/bcd.h>
0021 #include <linux/delay.h>
0022
0023
0024 #define MCP795_EEREAD 0x03
0025 #define MCP795_EEWRITE 0x02
0026 #define MCP795_EEWRDI 0x04
0027 #define MCP795_EEWREN 0x06
0028 #define MCP795_SRREAD 0x05
0029 #define MCP795_SRWRITE 0x01
0030 #define MCP795_READ 0x13
0031 #define MCP795_WRITE 0x12
0032 #define MCP795_UNLOCK 0x14
0033 #define MCP795_IDWRITE 0x32
0034 #define MCP795_IDREAD 0x33
0035 #define MCP795_CLRWDT 0x44
0036 #define MCP795_CLRRAM 0x54
0037
0038
0039 #define MCP795_REG_SECONDS 0x01
0040 #define MCP795_REG_DAY 0x04
0041 #define MCP795_REG_MONTH 0x06
0042 #define MCP795_REG_CONTROL 0x08
0043 #define MCP795_REG_ALM0_SECONDS 0x0C
0044 #define MCP795_REG_ALM0_DAY 0x0F
0045
0046 #define MCP795_ST_BIT BIT(7)
0047 #define MCP795_24_BIT BIT(6)
0048 #define MCP795_LP_BIT BIT(5)
0049 #define MCP795_EXTOSC_BIT BIT(3)
0050 #define MCP795_OSCON_BIT BIT(5)
0051 #define MCP795_ALM0_BIT BIT(4)
0052 #define MCP795_ALM1_BIT BIT(5)
0053 #define MCP795_ALM0IF_BIT BIT(3)
0054 #define MCP795_ALM0C0_BIT BIT(4)
0055 #define MCP795_ALM0C1_BIT BIT(5)
0056 #define MCP795_ALM0C2_BIT BIT(6)
0057
0058 #define SEC_PER_DAY (24 * 60 * 60)
0059
0060 static int mcp795_rtcc_read(struct device *dev, u8 addr, u8 *buf, u8 count)
0061 {
0062 struct spi_device *spi = to_spi_device(dev);
0063 int ret;
0064 u8 tx[2];
0065
0066 tx[0] = MCP795_READ;
0067 tx[1] = addr;
0068 ret = spi_write_then_read(spi, tx, sizeof(tx), buf, count);
0069
0070 if (ret)
0071 dev_err(dev, "Failed reading %d bytes from address %x.\n",
0072 count, addr);
0073
0074 return ret;
0075 }
0076
0077 static int mcp795_rtcc_write(struct device *dev, u8 addr, u8 *data, u8 count)
0078 {
0079 struct spi_device *spi = to_spi_device(dev);
0080 int ret;
0081 u8 tx[257];
0082
0083 tx[0] = MCP795_WRITE;
0084 tx[1] = addr;
0085 memcpy(&tx[2], data, count);
0086
0087 ret = spi_write(spi, tx, 2 + count);
0088
0089 if (ret)
0090 dev_err(dev, "Failed to write %d bytes to address %x.\n",
0091 count, addr);
0092
0093 return ret;
0094 }
0095
0096 static int mcp795_rtcc_set_bits(struct device *dev, u8 addr, u8 mask, u8 state)
0097 {
0098 int ret;
0099 u8 tmp;
0100
0101 ret = mcp795_rtcc_read(dev, addr, &tmp, 1);
0102 if (ret)
0103 return ret;
0104
0105 if ((tmp & mask) != state) {
0106 tmp = (tmp & ~mask) | state;
0107 ret = mcp795_rtcc_write(dev, addr, &tmp, 1);
0108 }
0109
0110 return ret;
0111 }
0112
0113 static int mcp795_stop_oscillator(struct device *dev, bool *extosc)
0114 {
0115 int retries = 5;
0116 int ret;
0117 u8 data;
0118
0119 ret = mcp795_rtcc_set_bits(dev, MCP795_REG_SECONDS, MCP795_ST_BIT, 0);
0120 if (ret)
0121 return ret;
0122 ret = mcp795_rtcc_read(dev, MCP795_REG_CONTROL, &data, 1);
0123 if (ret)
0124 return ret;
0125 *extosc = !!(data & MCP795_EXTOSC_BIT);
0126 ret = mcp795_rtcc_set_bits(
0127 dev, MCP795_REG_CONTROL, MCP795_EXTOSC_BIT, 0);
0128 if (ret)
0129 return ret;
0130
0131 do {
0132 usleep_range(700, 800);
0133 ret = mcp795_rtcc_read(dev, MCP795_REG_DAY, &data, 1);
0134 if (ret)
0135 break;
0136 if (!(data & MCP795_OSCON_BIT))
0137 break;
0138
0139 } while (--retries);
0140
0141 return !retries ? -EIO : ret;
0142 }
0143
0144 static int mcp795_start_oscillator(struct device *dev, bool *extosc)
0145 {
0146 if (extosc) {
0147 u8 data = *extosc ? MCP795_EXTOSC_BIT : 0;
0148 int ret;
0149
0150 ret = mcp795_rtcc_set_bits(
0151 dev, MCP795_REG_CONTROL, MCP795_EXTOSC_BIT, data);
0152 if (ret)
0153 return ret;
0154 }
0155 return mcp795_rtcc_set_bits(
0156 dev, MCP795_REG_SECONDS, MCP795_ST_BIT, MCP795_ST_BIT);
0157 }
0158
0159
0160 static int mcp795_update_alarm(struct device *dev, bool enable)
0161 {
0162 int ret;
0163
0164 dev_dbg(dev, "%s alarm\n", enable ? "Enable" : "Disable");
0165
0166 if (enable) {
0167
0168 ret = mcp795_rtcc_set_bits(dev, MCP795_REG_ALM0_DAY,
0169 MCP795_ALM0IF_BIT, 0);
0170 if (ret)
0171 return ret;
0172
0173 ret = mcp795_rtcc_set_bits(dev, MCP795_REG_CONTROL,
0174 MCP795_ALM0_BIT, MCP795_ALM0_BIT);
0175 } else {
0176
0177 ret = mcp795_rtcc_set_bits(dev, MCP795_REG_CONTROL,
0178 MCP795_ALM0_BIT | MCP795_ALM1_BIT, 0);
0179 }
0180 return ret;
0181 }
0182
0183 static int mcp795_set_time(struct device *dev, struct rtc_time *tim)
0184 {
0185 int ret;
0186 u8 data[7];
0187 bool extosc;
0188
0189
0190 ret = mcp795_stop_oscillator(dev, &extosc);
0191 if (ret)
0192 return ret;
0193
0194
0195 ret = mcp795_rtcc_read(dev, MCP795_REG_SECONDS, data, sizeof(data));
0196
0197 if (ret)
0198 return ret;
0199
0200 data[0] = (data[0] & 0x80) | bin2bcd(tim->tm_sec);
0201 data[1] = (data[1] & 0x80) | bin2bcd(tim->tm_min);
0202 data[2] = bin2bcd(tim->tm_hour);
0203 data[3] = (data[3] & 0xF8) | bin2bcd(tim->tm_wday + 1);
0204 data[4] = bin2bcd(tim->tm_mday);
0205 data[5] = (data[5] & MCP795_LP_BIT) | bin2bcd(tim->tm_mon + 1);
0206
0207 if (tim->tm_year > 100)
0208 tim->tm_year -= 100;
0209
0210 data[6] = bin2bcd(tim->tm_year);
0211
0212
0213
0214
0215
0216 ret = mcp795_rtcc_write(dev, MCP795_REG_SECONDS, data, 5);
0217 if (ret)
0218 return ret;
0219
0220 ret = mcp795_rtcc_write(dev, MCP795_REG_MONTH, &data[5], 2);
0221 if (ret)
0222 return ret;
0223
0224
0225
0226
0227
0228 ret = mcp795_start_oscillator(dev, extosc ? &extosc : NULL);
0229 if (ret)
0230 return ret;
0231
0232 dev_dbg(dev, "Set mcp795: %ptR\n", tim);
0233
0234 return 0;
0235 }
0236
0237 static int mcp795_read_time(struct device *dev, struct rtc_time *tim)
0238 {
0239 int ret;
0240 u8 data[7];
0241
0242 ret = mcp795_rtcc_read(dev, MCP795_REG_SECONDS, data, sizeof(data));
0243
0244 if (ret)
0245 return ret;
0246
0247 tim->tm_sec = bcd2bin(data[0] & 0x7F);
0248 tim->tm_min = bcd2bin(data[1] & 0x7F);
0249 tim->tm_hour = bcd2bin(data[2] & 0x3F);
0250 tim->tm_wday = bcd2bin(data[3] & 0x07) - 1;
0251 tim->tm_mday = bcd2bin(data[4] & 0x3F);
0252 tim->tm_mon = bcd2bin(data[5] & 0x1F) - 1;
0253 tim->tm_year = bcd2bin(data[6]) + 100;
0254
0255 dev_dbg(dev, "Read from mcp795: %ptR\n", tim);
0256
0257 return 0;
0258 }
0259
0260 static int mcp795_set_alarm(struct device *dev, struct rtc_wkalrm *alm)
0261 {
0262 struct rtc_time now_tm;
0263 time64_t now;
0264 time64_t later;
0265 u8 tmp[6];
0266 int ret;
0267
0268
0269 ret = mcp795_read_time(dev, &now_tm);
0270 if (ret)
0271 return ret;
0272
0273 now = rtc_tm_to_time64(&now_tm);
0274 later = rtc_tm_to_time64(&alm->time);
0275 if (later <= now)
0276 return -EINVAL;
0277
0278 if ((later - now) >=
0279 (SEC_PER_DAY * (365 + is_leap_year(alm->time.tm_year))))
0280 return -EDOM;
0281
0282 ret = mcp795_update_alarm(dev, false);
0283 if (ret)
0284 return ret;
0285
0286 ret = mcp795_rtcc_read(dev, MCP795_REG_ALM0_SECONDS, tmp, sizeof(tmp));
0287 if (ret)
0288 return ret;
0289
0290 alm->time.tm_year = -1;
0291 alm->time.tm_isdst = -1;
0292 alm->time.tm_yday = -1;
0293
0294 tmp[0] = (tmp[0] & 0x80) | bin2bcd(alm->time.tm_sec);
0295 tmp[1] = (tmp[1] & 0x80) | bin2bcd(alm->time.tm_min);
0296 tmp[2] = (tmp[2] & 0xE0) | bin2bcd(alm->time.tm_hour);
0297 tmp[3] = (tmp[3] & 0x80) | bin2bcd(alm->time.tm_wday + 1);
0298
0299 tmp[3] |= (MCP795_ALM0C2_BIT | MCP795_ALM0C1_BIT | MCP795_ALM0C0_BIT);
0300 tmp[4] = (tmp[4] & 0xC0) | bin2bcd(alm->time.tm_mday);
0301 tmp[5] = (tmp[5] & 0xE0) | bin2bcd(alm->time.tm_mon + 1);
0302
0303 ret = mcp795_rtcc_write(dev, MCP795_REG_ALM0_SECONDS, tmp, sizeof(tmp));
0304 if (ret)
0305 return ret;
0306
0307
0308 if (alm->enabled) {
0309 ret = mcp795_update_alarm(dev, true);
0310 if (ret)
0311 return ret;
0312 dev_dbg(dev, "Alarm IRQ armed\n");
0313 }
0314 dev_dbg(dev, "Set alarm: %ptRdr(%d) %ptRt\n",
0315 &alm->time, alm->time.tm_wday, &alm->time);
0316 return 0;
0317 }
0318
0319 static int mcp795_read_alarm(struct device *dev, struct rtc_wkalrm *alm)
0320 {
0321 u8 data[6];
0322 int ret;
0323
0324 ret = mcp795_rtcc_read(
0325 dev, MCP795_REG_ALM0_SECONDS, data, sizeof(data));
0326 if (ret)
0327 return ret;
0328
0329 alm->time.tm_sec = bcd2bin(data[0] & 0x7F);
0330 alm->time.tm_min = bcd2bin(data[1] & 0x7F);
0331 alm->time.tm_hour = bcd2bin(data[2] & 0x1F);
0332 alm->time.tm_wday = bcd2bin(data[3] & 0x07) - 1;
0333 alm->time.tm_mday = bcd2bin(data[4] & 0x3F);
0334 alm->time.tm_mon = bcd2bin(data[5] & 0x1F) - 1;
0335 alm->time.tm_year = -1;
0336 alm->time.tm_isdst = -1;
0337 alm->time.tm_yday = -1;
0338
0339 dev_dbg(dev, "Read alarm: %ptRdr(%d) %ptRt\n",
0340 &alm->time, alm->time.tm_wday, &alm->time);
0341 return 0;
0342 }
0343
0344 static int mcp795_alarm_irq_enable(struct device *dev, unsigned int enabled)
0345 {
0346 return mcp795_update_alarm(dev, !!enabled);
0347 }
0348
0349 static irqreturn_t mcp795_irq(int irq, void *data)
0350 {
0351 struct spi_device *spi = data;
0352 struct rtc_device *rtc = spi_get_drvdata(spi);
0353 int ret;
0354
0355 rtc_lock(rtc);
0356
0357
0358
0359
0360
0361 ret = mcp795_update_alarm(&spi->dev, false);
0362 if (ret)
0363 dev_err(&spi->dev,
0364 "Failed to disable alarm in IRQ (ret=%d)\n", ret);
0365 rtc_update_irq(rtc, 1, RTC_AF | RTC_IRQF);
0366
0367 rtc_unlock(rtc);
0368
0369 return IRQ_HANDLED;
0370 }
0371
0372 static const struct rtc_class_ops mcp795_rtc_ops = {
0373 .read_time = mcp795_read_time,
0374 .set_time = mcp795_set_time,
0375 .read_alarm = mcp795_read_alarm,
0376 .set_alarm = mcp795_set_alarm,
0377 .alarm_irq_enable = mcp795_alarm_irq_enable
0378 };
0379
0380 static int mcp795_probe(struct spi_device *spi)
0381 {
0382 struct rtc_device *rtc;
0383 int ret;
0384
0385 spi->mode = SPI_MODE_0;
0386 spi->bits_per_word = 8;
0387 ret = spi_setup(spi);
0388 if (ret) {
0389 dev_err(&spi->dev, "Unable to setup SPI\n");
0390 return ret;
0391 }
0392
0393
0394 mcp795_start_oscillator(&spi->dev, NULL);
0395
0396 mcp795_rtcc_set_bits(&spi->dev, 0x03, MCP795_24_BIT, 0);
0397
0398 rtc = devm_rtc_device_register(&spi->dev, "rtc-mcp795",
0399 &mcp795_rtc_ops, THIS_MODULE);
0400 if (IS_ERR(rtc))
0401 return PTR_ERR(rtc);
0402
0403 spi_set_drvdata(spi, rtc);
0404
0405 if (spi->irq > 0) {
0406 dev_dbg(&spi->dev, "Alarm support enabled\n");
0407
0408
0409
0410
0411 mcp795_rtcc_set_bits(&spi->dev, MCP795_REG_ALM0_DAY,
0412 MCP795_ALM0IF_BIT, 0);
0413 ret = devm_request_threaded_irq(&spi->dev, spi->irq, NULL,
0414 mcp795_irq, IRQF_TRIGGER_FALLING | IRQF_ONESHOT,
0415 dev_name(&rtc->dev), spi);
0416 if (ret)
0417 dev_err(&spi->dev, "Failed to request IRQ: %d: %d\n",
0418 spi->irq, ret);
0419 else
0420 device_init_wakeup(&spi->dev, true);
0421 }
0422 return 0;
0423 }
0424
0425 #ifdef CONFIG_OF
0426 static const struct of_device_id mcp795_of_match[] = {
0427 { .compatible = "maxim,mcp795" },
0428 { }
0429 };
0430 MODULE_DEVICE_TABLE(of, mcp795_of_match);
0431 #endif
0432
0433 static const struct spi_device_id mcp795_spi_ids[] = {
0434 { .name = "mcp795" },
0435 { }
0436 };
0437 MODULE_DEVICE_TABLE(spi, mcp795_spi_ids);
0438
0439 static struct spi_driver mcp795_driver = {
0440 .driver = {
0441 .name = "rtc-mcp795",
0442 .of_match_table = of_match_ptr(mcp795_of_match),
0443 },
0444 .probe = mcp795_probe,
0445 .id_table = mcp795_spi_ids,
0446 };
0447
0448 module_spi_driver(mcp795_driver);
0449
0450 MODULE_DESCRIPTION("MCP795 RTC SPI Driver");
0451 MODULE_AUTHOR("Josef Gajdusek <atx@atx.name>");
0452 MODULE_LICENSE("GPL");
0453 MODULE_ALIAS("spi:mcp795");