xref: /openbmc/linux/drivers/rtc/rtc-pcf8563.c (revision 2612e3bbc0386368a850140a6c9b990cd496a5ec)
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 = &reg,
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