1d2912cb1SThomas Gleixner // SPDX-License-Identifier: GPL-2.0-only
2b5a82d62SAlessandro Zummo /*
3b5a82d62SAlessandro Zummo * An I2C driver for the Philips PCF8563 RTC
4b5a82d62SAlessandro Zummo * Copyright 2005-06 Tower Technologies
5b5a82d62SAlessandro Zummo *
6b5a82d62SAlessandro Zummo * Author: Alessandro Zummo <a.zummo@towertech.it>
7b5a82d62SAlessandro Zummo * Maintainers: http://www.nslu2-linux.org/
8b5a82d62SAlessandro Zummo *
9b5a82d62SAlessandro Zummo * based on the other drivers in this same directory.
10b5a82d62SAlessandro Zummo *
1194af1e73SFabio Estevam * https://www.nxp.com/docs/en/data-sheet/PCF8563.pdf
12b5a82d62SAlessandro Zummo */
13b5a82d62SAlessandro Zummo
14a39a6405SHeiko Schocher #include <linux/clk-provider.h>
15b5a82d62SAlessandro Zummo #include <linux/i2c.h>
16b5a82d62SAlessandro Zummo #include <linux/bcd.h>
17b5a82d62SAlessandro Zummo #include <linux/rtc.h>
185a0e3ad6STejun Heo #include <linux/slab.h>
192113852bSPaul Gortmaker #include <linux/module.h>
208dccaf06SNick Bowler #include <linux/of.h>
2123f809eeSSachin Kamat #include <linux/err.h>
22b5a82d62SAlessandro Zummo
23b5a82d62SAlessandro Zummo #define PCF8563_REG_ST1 0x00 /* status */
24b5a82d62SAlessandro Zummo #define PCF8563_REG_ST2 0x01
25d53f9b68SNobuhiro Iwamatsu #define PCF8563_BIT_AIE BIT(1)
26d53f9b68SNobuhiro Iwamatsu #define PCF8563_BIT_AF BIT(3)
2745ef0458SJan Kardell #define PCF8563_BITS_ST2_N (7 << 5)
28b5a82d62SAlessandro Zummo
29b5a82d62SAlessandro Zummo #define PCF8563_REG_SC 0x02 /* datetime */
30b5a82d62SAlessandro Zummo #define PCF8563_REG_MN 0x03
31b5a82d62SAlessandro Zummo #define PCF8563_REG_HR 0x04
32b5a82d62SAlessandro Zummo #define PCF8563_REG_DM 0x05
33b5a82d62SAlessandro Zummo #define PCF8563_REG_DW 0x06
34b5a82d62SAlessandro Zummo #define PCF8563_REG_MO 0x07
35b5a82d62SAlessandro Zummo #define PCF8563_REG_YR 0x08
36b5a82d62SAlessandro Zummo
37b5a82d62SAlessandro Zummo #define PCF8563_REG_AMN 0x09 /* alarm */
38b5a82d62SAlessandro Zummo
39b5a82d62SAlessandro Zummo #define PCF8563_REG_CLKO 0x0D /* clock out */
40a39a6405SHeiko Schocher #define PCF8563_REG_CLKO_FE 0x80 /* clock out enabled */
41a39a6405SHeiko Schocher #define PCF8563_REG_CLKO_F_MASK 0x03 /* frequenc mask */
42a39a6405SHeiko Schocher #define PCF8563_REG_CLKO_F_32768HZ 0x00
43a39a6405SHeiko Schocher #define PCF8563_REG_CLKO_F_1024HZ 0x01
44a39a6405SHeiko Schocher #define PCF8563_REG_CLKO_F_32HZ 0x02
45a39a6405SHeiko Schocher #define PCF8563_REG_CLKO_F_1HZ 0x03
46a39a6405SHeiko Schocher
47b5a82d62SAlessandro Zummo #define PCF8563_REG_TMRC 0x0E /* timer control */
48ff0bc501SJan Kardell #define PCF8563_TMRC_ENABLE BIT(7)
49ff0bc501SJan Kardell #define PCF8563_TMRC_4096 0
50ff0bc501SJan Kardell #define PCF8563_TMRC_64 1
51ff0bc501SJan Kardell #define PCF8563_TMRC_1 2
52ff0bc501SJan Kardell #define PCF8563_TMRC_1_60 3
53ff0bc501SJan Kardell #define PCF8563_TMRC_MASK 3
54ff0bc501SJan Kardell
55b5a82d62SAlessandro Zummo #define PCF8563_REG_TMR 0x0F /* timer */
56b5a82d62SAlessandro Zummo
57b5a82d62SAlessandro Zummo #define PCF8563_SC_LV 0x80 /* low voltage */
58b5a82d62SAlessandro Zummo #define PCF8563_MO_C 0x80 /* century */
59b5a82d62SAlessandro Zummo
60e5fc9cc0SAlessandro Zummo static struct i2c_driver pcf8563_driver;
61e5fc9cc0SAlessandro Zummo
62cbb94502SAtsushi Nemoto struct pcf8563 {
63e5fc9cc0SAlessandro Zummo struct rtc_device *rtc;
64cbb94502SAtsushi Nemoto /*
65cbb94502SAtsushi Nemoto * The meaning of MO_C bit varies by the chip type.
66cbb94502SAtsushi Nemoto * From PCF8563 datasheet: this bit is toggled when the years
67cbb94502SAtsushi Nemoto * register overflows from 99 to 00
68cbb94502SAtsushi Nemoto * 0 indicates the century is 20xx
69cbb94502SAtsushi Nemoto * 1 indicates the century is 19xx
70cbb94502SAtsushi Nemoto * From RTC8564 datasheet: this bit indicates change of
71cbb94502SAtsushi Nemoto * century. When the year digit data overflows from 99 to 00,
72cbb94502SAtsushi Nemoto * this bit is set. By presetting it to 0 while still in the
73cbb94502SAtsushi Nemoto * 20th century, it will be set in year 2000, ...
74cbb94502SAtsushi Nemoto * There seems no reliable way to know how the system use this
75cbb94502SAtsushi Nemoto * bit. So let's do it heuristically, assuming we are live in
76cbb94502SAtsushi Nemoto * 1970...2069.
77cbb94502SAtsushi Nemoto */
78cbb94502SAtsushi Nemoto int c_polarity; /* 0: MO_C=1 means 19xx, otherwise MO_C=1 means 20xx */
79ede3e9d4SVincent Donnefort
80ede3e9d4SVincent Donnefort struct i2c_client *client;
81a39a6405SHeiko Schocher #ifdef CONFIG_COMMON_CLK
82a39a6405SHeiko Schocher struct clk_hw clkout_hw;
83a39a6405SHeiko Schocher #endif
84cbb94502SAtsushi Nemoto };
85cbb94502SAtsushi Nemoto
pcf8563_read_block_data(struct i2c_client * client,unsigned char reg,unsigned char length,unsigned char * buf)862784366cSVincent Donnefort static int pcf8563_read_block_data(struct i2c_client *client, unsigned char reg,
872784366cSVincent Donnefort unsigned char length, unsigned char *buf)
882784366cSVincent Donnefort {
892784366cSVincent Donnefort struct i2c_msg msgs[] = {
902784366cSVincent Donnefort {/* setup read ptr */
912784366cSVincent Donnefort .addr = client->addr,
922784366cSVincent Donnefort .len = 1,
932784366cSVincent Donnefort .buf = ®,
942784366cSVincent Donnefort },
952784366cSVincent Donnefort {
962784366cSVincent Donnefort .addr = client->addr,
972784366cSVincent Donnefort .flags = I2C_M_RD,
982784366cSVincent Donnefort .len = length,
992784366cSVincent Donnefort .buf = buf
1002784366cSVincent Donnefort },
1012784366cSVincent Donnefort };
1022784366cSVincent Donnefort
1032784366cSVincent Donnefort if ((i2c_transfer(client->adapter, msgs, 2)) != 2) {
1042784366cSVincent Donnefort dev_err(&client->dev, "%s: read error\n", __func__);
1052784366cSVincent Donnefort return -EIO;
1062784366cSVincent Donnefort }
1072784366cSVincent Donnefort
1082784366cSVincent Donnefort return 0;
1092784366cSVincent Donnefort }
1102784366cSVincent Donnefort
pcf8563_write_block_data(struct i2c_client * client,unsigned char reg,unsigned char length,unsigned char * buf)1112784366cSVincent Donnefort static int pcf8563_write_block_data(struct i2c_client *client,
1122784366cSVincent Donnefort unsigned char reg, unsigned char length,
1132784366cSVincent Donnefort unsigned char *buf)
1142784366cSVincent Donnefort {
1152784366cSVincent Donnefort int i, err;
1162784366cSVincent Donnefort
1172784366cSVincent Donnefort for (i = 0; i < length; i++) {
1182784366cSVincent Donnefort unsigned char data[2] = { reg + i, buf[i] };
1192784366cSVincent Donnefort
1202784366cSVincent Donnefort err = i2c_master_send(client, data, sizeof(data));
1212784366cSVincent Donnefort if (err != sizeof(data)) {
1222784366cSVincent Donnefort dev_err(&client->dev,
1232784366cSVincent Donnefort "%s: err=%d addr=%02x, data=%02x\n",
1242784366cSVincent Donnefort __func__, err, data[0], data[1]);
1252784366cSVincent Donnefort return -EIO;
1262784366cSVincent Donnefort }
1272784366cSVincent Donnefort }
1282784366cSVincent Donnefort
1292784366cSVincent Donnefort return 0;
1302784366cSVincent Donnefort }
1312784366cSVincent Donnefort
pcf8563_set_alarm_mode(struct i2c_client * client,bool on)132ede3e9d4SVincent Donnefort static int pcf8563_set_alarm_mode(struct i2c_client *client, bool on)
133ede3e9d4SVincent Donnefort {
13417a1e5e8SJan Kardell unsigned char buf;
135ede3e9d4SVincent Donnefort int err;
136ede3e9d4SVincent Donnefort
13717a1e5e8SJan Kardell err = pcf8563_read_block_data(client, PCF8563_REG_ST2, 1, &buf);
138ede3e9d4SVincent Donnefort if (err < 0)
139ede3e9d4SVincent Donnefort return err;
140ede3e9d4SVincent Donnefort
141ede3e9d4SVincent Donnefort if (on)
14217a1e5e8SJan Kardell buf |= PCF8563_BIT_AIE;
143ede3e9d4SVincent Donnefort else
14417a1e5e8SJan Kardell buf &= ~PCF8563_BIT_AIE;
145ede3e9d4SVincent Donnefort
14645ef0458SJan Kardell buf &= ~(PCF8563_BIT_AF | PCF8563_BITS_ST2_N);
147ede3e9d4SVincent Donnefort
14817a1e5e8SJan Kardell err = pcf8563_write_block_data(client, PCF8563_REG_ST2, 1, &buf);
149ede3e9d4SVincent Donnefort if (err < 0) {
150ede3e9d4SVincent Donnefort dev_err(&client->dev, "%s: write error\n", __func__);
151ede3e9d4SVincent Donnefort return -EIO;
152ede3e9d4SVincent Donnefort }
153ede3e9d4SVincent Donnefort
154ede3e9d4SVincent Donnefort return 0;
155ede3e9d4SVincent Donnefort }
156ede3e9d4SVincent Donnefort
pcf8563_get_alarm_mode(struct i2c_client * client,unsigned char * en,unsigned char * pen)157ede3e9d4SVincent Donnefort static int pcf8563_get_alarm_mode(struct i2c_client *client, unsigned char *en,
158ede3e9d4SVincent Donnefort unsigned char *pen)
159ede3e9d4SVincent Donnefort {
160ede3e9d4SVincent Donnefort unsigned char buf;
161ede3e9d4SVincent Donnefort int err;
162ede3e9d4SVincent Donnefort
163ede3e9d4SVincent Donnefort err = pcf8563_read_block_data(client, PCF8563_REG_ST2, 1, &buf);
164ede3e9d4SVincent Donnefort if (err)
165ede3e9d4SVincent Donnefort return err;
166ede3e9d4SVincent Donnefort
167ede3e9d4SVincent Donnefort if (en)
168ede3e9d4SVincent Donnefort *en = !!(buf & PCF8563_BIT_AIE);
169ede3e9d4SVincent Donnefort if (pen)
170ede3e9d4SVincent Donnefort *pen = !!(buf & PCF8563_BIT_AF);
171ede3e9d4SVincent Donnefort
172ede3e9d4SVincent Donnefort return 0;
173ede3e9d4SVincent Donnefort }
174ede3e9d4SVincent Donnefort
pcf8563_irq(int irq,void * dev_id)175ede3e9d4SVincent Donnefort static irqreturn_t pcf8563_irq(int irq, void *dev_id)
176ede3e9d4SVincent Donnefort {
177ede3e9d4SVincent Donnefort struct pcf8563 *pcf8563 = i2c_get_clientdata(dev_id);
178ede3e9d4SVincent Donnefort int err;
179ede3e9d4SVincent Donnefort char pending;
180ede3e9d4SVincent Donnefort
181ede3e9d4SVincent Donnefort err = pcf8563_get_alarm_mode(pcf8563->client, NULL, &pending);
182e698a512SArnd Bergmann if (err)
1833ff38237SArnd Bergmann return IRQ_NONE;
184ede3e9d4SVincent Donnefort
185ede3e9d4SVincent Donnefort if (pending) {
186ede3e9d4SVincent Donnefort rtc_update_irq(pcf8563->rtc, 1, RTC_IRQF | RTC_AF);
187ede3e9d4SVincent Donnefort pcf8563_set_alarm_mode(pcf8563->client, 1);
188ede3e9d4SVincent Donnefort return IRQ_HANDLED;
189ede3e9d4SVincent Donnefort }
190ede3e9d4SVincent Donnefort
191ede3e9d4SVincent Donnefort return IRQ_NONE;
192ede3e9d4SVincent Donnefort }
193ede3e9d4SVincent Donnefort
194b5a82d62SAlessandro Zummo /*
195b5a82d62SAlessandro Zummo * In the routines that deal directly with the pcf8563 hardware, we use
196b5a82d62SAlessandro Zummo * rtc_time -- month 0-11, hour 0-23, yr = calendar year-epoch.
197b5a82d62SAlessandro Zummo */
pcf8563_rtc_read_time(struct device * dev,struct rtc_time * tm)198c7d5f6dbSAlexandre Belloni static int pcf8563_rtc_read_time(struct device *dev, struct rtc_time *tm)
199b5a82d62SAlessandro Zummo {
200c7d5f6dbSAlexandre Belloni struct i2c_client *client = to_i2c_client(dev);
201e5fc9cc0SAlessandro Zummo struct pcf8563 *pcf8563 = i2c_get_clientdata(client);
2022784366cSVincent Donnefort unsigned char buf[9];
2032784366cSVincent Donnefort int err;
204b5a82d62SAlessandro Zummo
2052784366cSVincent Donnefort err = pcf8563_read_block_data(client, PCF8563_REG_ST1, 9, buf);
2062784366cSVincent Donnefort if (err)
2072784366cSVincent Donnefort return err;
208b5a82d62SAlessandro Zummo
2090f20b767SAlexander Stein if (buf[PCF8563_REG_SC] & PCF8563_SC_LV) {
210538330ccSJan Kardell dev_err(&client->dev,
211b5a82d62SAlessandro Zummo "low voltage detected, date/time is not reliable.\n");
212538330ccSJan Kardell return -EINVAL;
2130f20b767SAlexander Stein }
214b5a82d62SAlessandro Zummo
215b5a82d62SAlessandro Zummo dev_dbg(&client->dev,
216b5a82d62SAlessandro Zummo "%s: raw data is st1=%02x, st2=%02x, sec=%02x, min=%02x, hr=%02x, "
217b5a82d62SAlessandro Zummo "mday=%02x, wday=%02x, mon=%02x, year=%02x\n",
2182a4e2b87SHarvey Harrison __func__,
219b5a82d62SAlessandro Zummo buf[0], buf[1], buf[2], buf[3],
220b5a82d62SAlessandro Zummo buf[4], buf[5], buf[6], buf[7],
221b5a82d62SAlessandro Zummo buf[8]);
222b5a82d62SAlessandro Zummo
223b5a82d62SAlessandro Zummo
224fe20ba70SAdrian Bunk tm->tm_sec = bcd2bin(buf[PCF8563_REG_SC] & 0x7F);
225fe20ba70SAdrian Bunk tm->tm_min = bcd2bin(buf[PCF8563_REG_MN] & 0x7F);
226fe20ba70SAdrian Bunk tm->tm_hour = bcd2bin(buf[PCF8563_REG_HR] & 0x3F); /* rtc hr 0-23 */
227fe20ba70SAdrian Bunk tm->tm_mday = bcd2bin(buf[PCF8563_REG_DM] & 0x3F);
228b5a82d62SAlessandro Zummo tm->tm_wday = buf[PCF8563_REG_DW] & 0x07;
229fe20ba70SAdrian Bunk tm->tm_mon = bcd2bin(buf[PCF8563_REG_MO] & 0x1F) - 1; /* rtc mn 1-12 */
230f648d40bSAlexandre Belloni tm->tm_year = bcd2bin(buf[PCF8563_REG_YR]) + 100;
231cbb94502SAtsushi Nemoto /* detect the polarity heuristically. see note above. */
232cbb94502SAtsushi Nemoto pcf8563->c_polarity = (buf[PCF8563_REG_MO] & PCF8563_MO_C) ?
233cbb94502SAtsushi Nemoto (tm->tm_year >= 100) : (tm->tm_year < 100);
234b5a82d62SAlessandro Zummo
235b5a82d62SAlessandro Zummo dev_dbg(&client->dev, "%s: tm is secs=%d, mins=%d, hours=%d, "
236b5a82d62SAlessandro Zummo "mday=%d, mon=%d, year=%d, wday=%d\n",
2372a4e2b87SHarvey Harrison __func__,
238b5a82d62SAlessandro Zummo tm->tm_sec, tm->tm_min, tm->tm_hour,
239b5a82d62SAlessandro Zummo tm->tm_mday, tm->tm_mon, tm->tm_year, tm->tm_wday);
240b5a82d62SAlessandro Zummo
241b5a82d62SAlessandro Zummo return 0;
242b5a82d62SAlessandro Zummo }
243b5a82d62SAlessandro Zummo
pcf8563_rtc_set_time(struct device * dev,struct rtc_time * tm)244c7d5f6dbSAlexandre Belloni static int pcf8563_rtc_set_time(struct device *dev, struct rtc_time *tm)
245b5a82d62SAlessandro Zummo {
246c7d5f6dbSAlexandre Belloni struct i2c_client *client = to_i2c_client(dev);
247e5fc9cc0SAlessandro Zummo struct pcf8563 *pcf8563 = i2c_get_clientdata(client);
248b5a82d62SAlessandro Zummo unsigned char buf[9];
249b5a82d62SAlessandro Zummo
250b5a82d62SAlessandro Zummo dev_dbg(&client->dev, "%s: secs=%d, mins=%d, hours=%d, "
251b5a82d62SAlessandro Zummo "mday=%d, mon=%d, year=%d, wday=%d\n",
2522a4e2b87SHarvey Harrison __func__,
253b5a82d62SAlessandro Zummo tm->tm_sec, tm->tm_min, tm->tm_hour,
254b5a82d62SAlessandro Zummo tm->tm_mday, tm->tm_mon, tm->tm_year, tm->tm_wday);
255b5a82d62SAlessandro Zummo
256b5a82d62SAlessandro Zummo /* hours, minutes and seconds */
257fe20ba70SAdrian Bunk buf[PCF8563_REG_SC] = bin2bcd(tm->tm_sec);
258fe20ba70SAdrian Bunk buf[PCF8563_REG_MN] = bin2bcd(tm->tm_min);
259fe20ba70SAdrian Bunk buf[PCF8563_REG_HR] = bin2bcd(tm->tm_hour);
260b5a82d62SAlessandro Zummo
261fe20ba70SAdrian Bunk buf[PCF8563_REG_DM] = bin2bcd(tm->tm_mday);
262b5a82d62SAlessandro Zummo
263b5a82d62SAlessandro Zummo /* month, 1 - 12 */
264fe20ba70SAdrian Bunk buf[PCF8563_REG_MO] = bin2bcd(tm->tm_mon + 1);
265b5a82d62SAlessandro Zummo
266b5a82d62SAlessandro Zummo /* year and century */
267f648d40bSAlexandre Belloni buf[PCF8563_REG_YR] = bin2bcd(tm->tm_year - 100);
268cbb94502SAtsushi Nemoto if (pcf8563->c_polarity ? (tm->tm_year >= 100) : (tm->tm_year < 100))
269b5a82d62SAlessandro Zummo buf[PCF8563_REG_MO] |= PCF8563_MO_C;
270b5a82d62SAlessandro Zummo
271b5a82d62SAlessandro Zummo buf[PCF8563_REG_DW] = tm->tm_wday & 0x07;
272b5a82d62SAlessandro Zummo
273b0c57b59SRobert Kmiec return pcf8563_write_block_data(client, PCF8563_REG_SC,
2742784366cSVincent Donnefort 9 - PCF8563_REG_SC, buf + PCF8563_REG_SC);
275b5a82d62SAlessandro Zummo }
276b5a82d62SAlessandro Zummo
pcf8563_rtc_ioctl(struct device * dev,unsigned int cmd,unsigned long arg)2770f20b767SAlexander Stein static int pcf8563_rtc_ioctl(struct device *dev, unsigned int cmd, unsigned long arg)
2780f20b767SAlexander Stein {
279935272aaSAlexandre Belloni struct i2c_client *client = to_i2c_client(dev);
280b371b10eSAlexandre Belloni int ret;
2810f20b767SAlexander Stein
2820f20b767SAlexander Stein switch (cmd) {
2830f20b767SAlexander Stein case RTC_VL_READ:
284935272aaSAlexandre Belloni ret = i2c_smbus_read_byte_data(client, PCF8563_REG_SC);
285935272aaSAlexandre Belloni if (ret < 0)
286935272aaSAlexandre Belloni return ret;
287935272aaSAlexandre Belloni
288b371b10eSAlexandre Belloni return put_user(ret & PCF8563_SC_LV ? RTC_VL_DATA_INVALID : 0,
289b371b10eSAlexandre Belloni (unsigned int __user *)arg);
2900f20b767SAlexander Stein default:
2910f20b767SAlexander Stein return -ENOIOCTLCMD;
2920f20b767SAlexander Stein }
2930f20b767SAlexander Stein }
2940f20b767SAlexander Stein
pcf8563_rtc_read_alarm(struct device * dev,struct rtc_wkalrm * tm)295ede3e9d4SVincent Donnefort static int pcf8563_rtc_read_alarm(struct device *dev, struct rtc_wkalrm *tm)
296ede3e9d4SVincent Donnefort {
297ede3e9d4SVincent Donnefort struct i2c_client *client = to_i2c_client(dev);
298ede3e9d4SVincent Donnefort unsigned char buf[4];
299ede3e9d4SVincent Donnefort int err;
300ede3e9d4SVincent Donnefort
301ede3e9d4SVincent Donnefort err = pcf8563_read_block_data(client, PCF8563_REG_AMN, 4, buf);
302ede3e9d4SVincent Donnefort if (err)
303ede3e9d4SVincent Donnefort return err;
304ede3e9d4SVincent Donnefort
305ede3e9d4SVincent Donnefort dev_dbg(&client->dev,
306ede3e9d4SVincent Donnefort "%s: raw data is min=%02x, hr=%02x, mday=%02x, wday=%02x\n",
307ede3e9d4SVincent Donnefort __func__, buf[0], buf[1], buf[2], buf[3]);
308ede3e9d4SVincent Donnefort
309d2c92705SUwe Kleine-König tm->time.tm_sec = 0;
310ede3e9d4SVincent Donnefort tm->time.tm_min = bcd2bin(buf[0] & 0x7F);
311c7aef4f8SJan Kardell tm->time.tm_hour = bcd2bin(buf[1] & 0x3F);
312c7aef4f8SJan Kardell tm->time.tm_mday = bcd2bin(buf[2] & 0x3F);
313ede3e9d4SVincent Donnefort tm->time.tm_wday = bcd2bin(buf[3] & 0x7);
314ede3e9d4SVincent Donnefort
315ede3e9d4SVincent Donnefort err = pcf8563_get_alarm_mode(client, &tm->enabled, &tm->pending);
316ede3e9d4SVincent Donnefort if (err < 0)
317ede3e9d4SVincent Donnefort return err;
318ede3e9d4SVincent Donnefort
319ede3e9d4SVincent Donnefort dev_dbg(&client->dev, "%s: tm is mins=%d, hours=%d, mday=%d, wday=%d,"
320ede3e9d4SVincent Donnefort " enabled=%d, pending=%d\n", __func__, tm->time.tm_min,
321ede3e9d4SVincent Donnefort tm->time.tm_hour, tm->time.tm_mday, tm->time.tm_wday,
322ede3e9d4SVincent Donnefort tm->enabled, tm->pending);
323ede3e9d4SVincent Donnefort
324ede3e9d4SVincent Donnefort return 0;
325ede3e9d4SVincent Donnefort }
326ede3e9d4SVincent Donnefort
pcf8563_rtc_set_alarm(struct device * dev,struct rtc_wkalrm * tm)327ede3e9d4SVincent Donnefort static int pcf8563_rtc_set_alarm(struct device *dev, struct rtc_wkalrm *tm)
328ede3e9d4SVincent Donnefort {
329ede3e9d4SVincent Donnefort struct i2c_client *client = to_i2c_client(dev);
330ede3e9d4SVincent Donnefort unsigned char buf[4];
331ede3e9d4SVincent Donnefort int err;
332599cda55SJan Kardell
333ede3e9d4SVincent Donnefort buf[0] = bin2bcd(tm->time.tm_min);
334ede3e9d4SVincent Donnefort buf[1] = bin2bcd(tm->time.tm_hour);
335ede3e9d4SVincent Donnefort buf[2] = bin2bcd(tm->time.tm_mday);
336ede3e9d4SVincent Donnefort buf[3] = tm->time.tm_wday & 0x07;
337ede3e9d4SVincent Donnefort
338ede3e9d4SVincent Donnefort err = pcf8563_write_block_data(client, PCF8563_REG_AMN, 4, buf);
339ede3e9d4SVincent Donnefort if (err)
340ede3e9d4SVincent Donnefort return err;
341ede3e9d4SVincent Donnefort
3421856e0b2SAlexandre Belloni return pcf8563_set_alarm_mode(client, !!tm->enabled);
343ede3e9d4SVincent Donnefort }
344ede3e9d4SVincent Donnefort
pcf8563_irq_enable(struct device * dev,unsigned int enabled)345ede3e9d4SVincent Donnefort static int pcf8563_irq_enable(struct device *dev, unsigned int enabled)
346ede3e9d4SVincent Donnefort {
347a45d528aSJan Kardell dev_dbg(dev, "%s: en=%d\n", __func__, enabled);
348ede3e9d4SVincent Donnefort return pcf8563_set_alarm_mode(to_i2c_client(dev), !!enabled);
349ede3e9d4SVincent Donnefort }
350ede3e9d4SVincent Donnefort
351a39a6405SHeiko Schocher #ifdef CONFIG_COMMON_CLK
352a39a6405SHeiko Schocher /*
353a39a6405SHeiko Schocher * Handling of the clkout
354a39a6405SHeiko Schocher */
355a39a6405SHeiko Schocher
356a39a6405SHeiko Schocher #define clkout_hw_to_pcf8563(_hw) container_of(_hw, struct pcf8563, clkout_hw)
357a39a6405SHeiko Schocher
358e7560341SNobuhiro Iwamatsu static const int clkout_rates[] = {
359a39a6405SHeiko Schocher 32768,
360a39a6405SHeiko Schocher 1024,
361a39a6405SHeiko Schocher 32,
362a39a6405SHeiko Schocher 1,
363a39a6405SHeiko Schocher };
364a39a6405SHeiko Schocher
pcf8563_clkout_recalc_rate(struct clk_hw * hw,unsigned long parent_rate)365a39a6405SHeiko Schocher static unsigned long pcf8563_clkout_recalc_rate(struct clk_hw *hw,
366a39a6405SHeiko Schocher unsigned long parent_rate)
367a39a6405SHeiko Schocher {
368a39a6405SHeiko Schocher struct pcf8563 *pcf8563 = clkout_hw_to_pcf8563(hw);
369a39a6405SHeiko Schocher struct i2c_client *client = pcf8563->client;
370a39a6405SHeiko Schocher unsigned char buf;
371a39a6405SHeiko Schocher int ret = pcf8563_read_block_data(client, PCF8563_REG_CLKO, 1, &buf);
372a39a6405SHeiko Schocher
373a39a6405SHeiko Schocher if (ret < 0)
374a39a6405SHeiko Schocher return 0;
375a39a6405SHeiko Schocher
376a39a6405SHeiko Schocher buf &= PCF8563_REG_CLKO_F_MASK;
377a3350f9cSPhilipp Zabel return clkout_rates[buf];
378a39a6405SHeiko Schocher }
379a39a6405SHeiko Schocher
pcf8563_clkout_round_rate(struct clk_hw * hw,unsigned long rate,unsigned long * prate)380a39a6405SHeiko Schocher static long pcf8563_clkout_round_rate(struct clk_hw *hw, unsigned long rate,
381a39a6405SHeiko Schocher unsigned long *prate)
382a39a6405SHeiko Schocher {
383a39a6405SHeiko Schocher int i;
384a39a6405SHeiko Schocher
385a39a6405SHeiko Schocher for (i = 0; i < ARRAY_SIZE(clkout_rates); i++)
386a39a6405SHeiko Schocher if (clkout_rates[i] <= rate)
387a39a6405SHeiko Schocher return clkout_rates[i];
388a39a6405SHeiko Schocher
389a39a6405SHeiko Schocher return 0;
390a39a6405SHeiko Schocher }
391a39a6405SHeiko Schocher
pcf8563_clkout_set_rate(struct clk_hw * hw,unsigned long rate,unsigned long parent_rate)392a39a6405SHeiko Schocher static int pcf8563_clkout_set_rate(struct clk_hw *hw, unsigned long rate,
393a39a6405SHeiko Schocher unsigned long parent_rate)
394a39a6405SHeiko Schocher {
395a39a6405SHeiko Schocher struct pcf8563 *pcf8563 = clkout_hw_to_pcf8563(hw);
396a39a6405SHeiko Schocher struct i2c_client *client = pcf8563->client;
397a39a6405SHeiko Schocher unsigned char buf;
398a39a6405SHeiko Schocher int ret = pcf8563_read_block_data(client, PCF8563_REG_CLKO, 1, &buf);
399a39a6405SHeiko Schocher int i;
400a39a6405SHeiko Schocher
401a39a6405SHeiko Schocher if (ret < 0)
402a39a6405SHeiko Schocher return ret;
403a39a6405SHeiko Schocher
404a39a6405SHeiko Schocher for (i = 0; i < ARRAY_SIZE(clkout_rates); i++)
405a39a6405SHeiko Schocher if (clkout_rates[i] == rate) {
406a39a6405SHeiko Schocher buf &= ~PCF8563_REG_CLKO_F_MASK;
407a39a6405SHeiko Schocher buf |= i;
408a39a6405SHeiko Schocher ret = pcf8563_write_block_data(client,
409a39a6405SHeiko Schocher PCF8563_REG_CLKO, 1,
410a39a6405SHeiko Schocher &buf);
411a39a6405SHeiko Schocher return ret;
412a39a6405SHeiko Schocher }
413a39a6405SHeiko Schocher
414a39a6405SHeiko Schocher return -EINVAL;
415a39a6405SHeiko Schocher }
416a39a6405SHeiko Schocher
pcf8563_clkout_control(struct clk_hw * hw,bool enable)417a39a6405SHeiko Schocher static int pcf8563_clkout_control(struct clk_hw *hw, bool enable)
418a39a6405SHeiko Schocher {
419a39a6405SHeiko Schocher struct pcf8563 *pcf8563 = clkout_hw_to_pcf8563(hw);
420a39a6405SHeiko Schocher struct i2c_client *client = pcf8563->client;
421a39a6405SHeiko Schocher unsigned char buf;
422a39a6405SHeiko Schocher int ret = pcf8563_read_block_data(client, PCF8563_REG_CLKO, 1, &buf);
423a39a6405SHeiko Schocher
424a39a6405SHeiko Schocher if (ret < 0)
425a39a6405SHeiko Schocher return ret;
426a39a6405SHeiko Schocher
427a39a6405SHeiko Schocher if (enable)
428a39a6405SHeiko Schocher buf |= PCF8563_REG_CLKO_FE;
429a39a6405SHeiko Schocher else
430a39a6405SHeiko Schocher buf &= ~PCF8563_REG_CLKO_FE;
431a39a6405SHeiko Schocher
432a39a6405SHeiko Schocher ret = pcf8563_write_block_data(client, PCF8563_REG_CLKO, 1, &buf);
433a39a6405SHeiko Schocher return ret;
434a39a6405SHeiko Schocher }
435a39a6405SHeiko Schocher
pcf8563_clkout_prepare(struct clk_hw * hw)436a39a6405SHeiko Schocher static int pcf8563_clkout_prepare(struct clk_hw *hw)
437a39a6405SHeiko Schocher {
438a39a6405SHeiko Schocher return pcf8563_clkout_control(hw, 1);
439a39a6405SHeiko Schocher }
440a39a6405SHeiko Schocher
pcf8563_clkout_unprepare(struct clk_hw * hw)441a39a6405SHeiko Schocher static void pcf8563_clkout_unprepare(struct clk_hw *hw)
442a39a6405SHeiko Schocher {
443a39a6405SHeiko Schocher pcf8563_clkout_control(hw, 0);
444a39a6405SHeiko Schocher }
445a39a6405SHeiko Schocher
pcf8563_clkout_is_prepared(struct clk_hw * hw)446a39a6405SHeiko Schocher static int pcf8563_clkout_is_prepared(struct clk_hw *hw)
447a39a6405SHeiko Schocher {
448a39a6405SHeiko Schocher struct pcf8563 *pcf8563 = clkout_hw_to_pcf8563(hw);
449a39a6405SHeiko Schocher struct i2c_client *client = pcf8563->client;
450a39a6405SHeiko Schocher unsigned char buf;
451a39a6405SHeiko Schocher int ret = pcf8563_read_block_data(client, PCF8563_REG_CLKO, 1, &buf);
452a39a6405SHeiko Schocher
453a39a6405SHeiko Schocher if (ret < 0)
454a39a6405SHeiko Schocher return ret;
455a39a6405SHeiko Schocher
456a39a6405SHeiko Schocher return !!(buf & PCF8563_REG_CLKO_FE);
457a39a6405SHeiko Schocher }
458a39a6405SHeiko Schocher
459a39a6405SHeiko Schocher static const struct clk_ops pcf8563_clkout_ops = {
460a39a6405SHeiko Schocher .prepare = pcf8563_clkout_prepare,
461a39a6405SHeiko Schocher .unprepare = pcf8563_clkout_unprepare,
462a39a6405SHeiko Schocher .is_prepared = pcf8563_clkout_is_prepared,
463a39a6405SHeiko Schocher .recalc_rate = pcf8563_clkout_recalc_rate,
464a39a6405SHeiko Schocher .round_rate = pcf8563_clkout_round_rate,
465a39a6405SHeiko Schocher .set_rate = pcf8563_clkout_set_rate,
466a39a6405SHeiko Schocher };
467a39a6405SHeiko Schocher
pcf8563_clkout_register_clk(struct pcf8563 * pcf8563)468a39a6405SHeiko Schocher static struct clk *pcf8563_clkout_register_clk(struct pcf8563 *pcf8563)
469a39a6405SHeiko Schocher {
470a39a6405SHeiko Schocher struct i2c_client *client = pcf8563->client;
471a39a6405SHeiko Schocher struct device_node *node = client->dev.of_node;
472a39a6405SHeiko Schocher struct clk *clk;
473a39a6405SHeiko Schocher struct clk_init_data init;
474a39a6405SHeiko Schocher int ret;
475a39a6405SHeiko Schocher unsigned char buf;
476a39a6405SHeiko Schocher
477a39a6405SHeiko Schocher /* disable the clkout output */
478a39a6405SHeiko Schocher buf = 0;
479a39a6405SHeiko Schocher ret = pcf8563_write_block_data(client, PCF8563_REG_CLKO, 1, &buf);
480a39a6405SHeiko Schocher if (ret < 0)
481a39a6405SHeiko Schocher return ERR_PTR(ret);
482a39a6405SHeiko Schocher
483a39a6405SHeiko Schocher init.name = "pcf8563-clkout";
484a39a6405SHeiko Schocher init.ops = &pcf8563_clkout_ops;
48574e1af32SStephen Boyd init.flags = 0;
486a39a6405SHeiko Schocher init.parent_names = NULL;
487a39a6405SHeiko Schocher init.num_parents = 0;
488a39a6405SHeiko Schocher pcf8563->clkout_hw.init = &init;
489a39a6405SHeiko Schocher
490a39a6405SHeiko Schocher /* optional override of the clockname */
491a39a6405SHeiko Schocher of_property_read_string(node, "clock-output-names", &init.name);
492a39a6405SHeiko Schocher
493a39a6405SHeiko Schocher /* register the clock */
494a39a6405SHeiko Schocher clk = devm_clk_register(&client->dev, &pcf8563->clkout_hw);
495a39a6405SHeiko Schocher
496a39a6405SHeiko Schocher if (!IS_ERR(clk))
497a39a6405SHeiko Schocher of_clk_add_provider(node, of_clk_src_simple_get, clk);
498a39a6405SHeiko Schocher
499a39a6405SHeiko Schocher return clk;
500a39a6405SHeiko Schocher }
501a39a6405SHeiko Schocher #endif
502a39a6405SHeiko Schocher
503ff8371acSDavid Brownell static const struct rtc_class_ops pcf8563_rtc_ops = {
5040f20b767SAlexander Stein .ioctl = pcf8563_rtc_ioctl,
505b5a82d62SAlessandro Zummo .read_time = pcf8563_rtc_read_time,
506b5a82d62SAlessandro Zummo .set_time = pcf8563_rtc_set_time,
507ede3e9d4SVincent Donnefort .read_alarm = pcf8563_rtc_read_alarm,
508ede3e9d4SVincent Donnefort .set_alarm = pcf8563_rtc_set_alarm,
509ede3e9d4SVincent Donnefort .alarm_irq_enable = pcf8563_irq_enable,
510b5a82d62SAlessandro Zummo };
511b5a82d62SAlessandro Zummo
pcf8563_probe(struct i2c_client * client)5123f4a3322SStephen Kitt static int pcf8563_probe(struct i2c_client *client)
513b5a82d62SAlessandro Zummo {
514cbb94502SAtsushi Nemoto struct pcf8563 *pcf8563;
515ede3e9d4SVincent Donnefort int err;
516ff0bc501SJan Kardell unsigned char buf;
517b5a82d62SAlessandro Zummo
518e5fc9cc0SAlessandro Zummo dev_dbg(&client->dev, "%s\n", __func__);
519b5a82d62SAlessandro Zummo
520e5fc9cc0SAlessandro Zummo if (!i2c_check_functionality(client->adapter, I2C_FUNC_I2C))
521e5fc9cc0SAlessandro Zummo return -ENODEV;
522b5a82d62SAlessandro Zummo
523d6fbdc34SJingoo Han pcf8563 = devm_kzalloc(&client->dev, sizeof(struct pcf8563),
524d6fbdc34SJingoo Han GFP_KERNEL);
525e5fc9cc0SAlessandro Zummo if (!pcf8563)
526e5fc9cc0SAlessandro Zummo return -ENOMEM;
527b5a82d62SAlessandro Zummo
528b74d2caaSAlessandro Zummo i2c_set_clientdata(client, pcf8563);
529ede3e9d4SVincent Donnefort pcf8563->client = client;
530ede3e9d4SVincent Donnefort device_set_wakeup_capable(&client->dev, 1);
531b74d2caaSAlessandro Zummo
532ff0bc501SJan Kardell /* Set timer to lowest frequency to save power (ref Haoyu datasheet) */
533ff0bc501SJan Kardell buf = PCF8563_TMRC_1_60;
534ff0bc501SJan Kardell err = pcf8563_write_block_data(client, PCF8563_REG_TMRC, 1, &buf);
535ff0bc501SJan Kardell if (err < 0) {
536ff0bc501SJan Kardell dev_err(&client->dev, "%s: write error\n", __func__);
537ff0bc501SJan Kardell return err;
538ff0bc501SJan Kardell }
539ff0bc501SJan Kardell
5403572e8aeSChen-Yu Tsai /* Clear flags and disable interrupts */
5413572e8aeSChen-Yu Tsai buf = 0;
5423572e8aeSChen-Yu Tsai err = pcf8563_write_block_data(client, PCF8563_REG_ST2, 1, &buf);
5433572e8aeSChen-Yu Tsai if (err < 0) {
5443572e8aeSChen-Yu Tsai dev_err(&client->dev, "%s: write error\n", __func__);
545a45d528aSJan Kardell return err;
546a45d528aSJan Kardell }
547a45d528aSJan Kardell
5488d3f805eSAlexandre Belloni pcf8563->rtc = devm_rtc_allocate_device(&client->dev);
549ede3e9d4SVincent Donnefort if (IS_ERR(pcf8563->rtc))
550ede3e9d4SVincent Donnefort return PTR_ERR(pcf8563->rtc);
551ede3e9d4SVincent Donnefort
5528d3f805eSAlexandre Belloni pcf8563->rtc->ops = &pcf8563_rtc_ops;
5538d3f805eSAlexandre Belloni /* the pcf8563 alarm only supports a minute accuracy */
554cf4521edSAlexandre Belloni set_bit(RTC_FEATURE_ALARM_RES_MINUTE, pcf8563->rtc->features);
555d28a0e14SAlexandre Belloni clear_bit(RTC_FEATURE_UPDATE_INTERRUPT, pcf8563->rtc->features);
556f648d40bSAlexandre Belloni pcf8563->rtc->range_min = RTC_TIMESTAMP_BEGIN_2000;
557f648d40bSAlexandre Belloni pcf8563->rtc->range_max = RTC_TIMESTAMP_END_2099;
558f648d40bSAlexandre Belloni pcf8563->rtc->set_start_time = true;
5598d3f805eSAlexandre Belloni
560ede3e9d4SVincent Donnefort if (client->irq > 0) {
561827009a8SAlexandre Belloni unsigned long irqflags = IRQF_TRIGGER_LOW;
562827009a8SAlexandre Belloni
563827009a8SAlexandre Belloni if (dev_fwnode(&client->dev))
564827009a8SAlexandre Belloni irqflags = 0;
565827009a8SAlexandre Belloni
566ede3e9d4SVincent Donnefort err = devm_request_threaded_irq(&client->dev, client->irq,
567ede3e9d4SVincent Donnefort NULL, pcf8563_irq,
568827009a8SAlexandre Belloni IRQF_SHARED | IRQF_ONESHOT | irqflags,
569f09e7069SAlexandre Belloni pcf8563_driver.driver.name, client);
570ede3e9d4SVincent Donnefort if (err) {
571ede3e9d4SVincent Donnefort dev_err(&client->dev, "unable to request IRQ %d\n",
572ede3e9d4SVincent Donnefort client->irq);
573ede3e9d4SVincent Donnefort return err;
574ede3e9d4SVincent Donnefort }
57560cfac17SVincent Whitchurch } else {
57660cfac17SVincent Whitchurch clear_bit(RTC_FEATURE_ALARM, pcf8563->rtc->features);
577ede3e9d4SVincent Donnefort }
578ede3e9d4SVincent Donnefort
579fdcfd854SBartosz Golaszewski err = devm_rtc_register_device(pcf8563->rtc);
5808d3f805eSAlexandre Belloni if (err)
5818d3f805eSAlexandre Belloni return err;
5828d3f805eSAlexandre Belloni
583a39a6405SHeiko Schocher #ifdef CONFIG_COMMON_CLK
584a39a6405SHeiko Schocher /* register clk in common clk framework */
585a39a6405SHeiko Schocher pcf8563_clkout_register_clk(pcf8563);
586a39a6405SHeiko Schocher #endif
587a39a6405SHeiko Schocher
588ede3e9d4SVincent Donnefort return 0;
589b5a82d62SAlessandro Zummo }
590b5a82d62SAlessandro Zummo
5913760f736SJean Delvare static const struct i2c_device_id pcf8563_id[] = {
5923760f736SJean Delvare { "pcf8563", 0 },
5938ea9212cSJon Smirl { "rtc8564", 0 },
594198be989SMarek Vasut { "pca8565", 0 },
5953760f736SJean Delvare { }
5963760f736SJean Delvare };
5973760f736SJean Delvare MODULE_DEVICE_TABLE(i2c, pcf8563_id);
5983760f736SJean Delvare
5998dccaf06SNick Bowler #ifdef CONFIG_OF
6005a167f45SGreg Kroah-Hartman static const struct of_device_id pcf8563_of_match[] = {
6018dccaf06SNick Bowler { .compatible = "nxp,pcf8563" },
602cd646ec0SAlexandre Belloni { .compatible = "epson,rtc8564" },
603deaa3ff4SAlexandre Belloni { .compatible = "microcrystal,rv8564" },
604198be989SMarek Vasut { .compatible = "nxp,pca8565" },
6058dccaf06SNick Bowler {}
6068dccaf06SNick Bowler };
6078dccaf06SNick Bowler MODULE_DEVICE_TABLE(of, pcf8563_of_match);
6088dccaf06SNick Bowler #endif
6098dccaf06SNick Bowler
610e5fc9cc0SAlessandro Zummo static struct i2c_driver pcf8563_driver = {
611e5fc9cc0SAlessandro Zummo .driver = {
612e5fc9cc0SAlessandro Zummo .name = "rtc-pcf8563",
6138dccaf06SNick Bowler .of_match_table = of_match_ptr(pcf8563_of_match),
614e5fc9cc0SAlessandro Zummo },
615*31b0cecbSUwe Kleine-König .probe = pcf8563_probe,
6163760f736SJean Delvare .id_table = pcf8563_id,
617e5fc9cc0SAlessandro Zummo };
618e5fc9cc0SAlessandro Zummo
6190abc9201SAxel Lin module_i2c_driver(pcf8563_driver);
620b5a82d62SAlessandro Zummo
621b5a82d62SAlessandro Zummo MODULE_AUTHOR("Alessandro Zummo <a.zummo@towertech.it>");
622b5a82d62SAlessandro Zummo MODULE_DESCRIPTION("Philips PCF8563/Epson RTC8564 RTC driver");
623b5a82d62SAlessandro Zummo MODULE_LICENSE("GPL");
624