rtc-pcf8523.c 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378
  1. /*
  2. * Copyright (C) 2012 Avionic Design GmbH
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License version 2 as
  6. * published by the Free Software Foundation.
  7. */
  8. #include <linux/bcd.h>
  9. #include <linux/i2c.h>
  10. #include <linux/module.h>
  11. #include <linux/rtc.h>
  12. #include <linux/of.h>
  13. #define DRIVER_NAME "rtc-pcf8523"
  14. #define REG_CONTROL1 0x00
  15. #define REG_CONTROL1_CAP_SEL (1 << 7)
  16. #define REG_CONTROL1_STOP (1 << 5)
  17. #define REG_CONTROL3 0x02
  18. #define REG_CONTROL3_PM_BLD (1 << 7) /* battery low detection disabled */
  19. #define REG_CONTROL3_PM_VDD (1 << 6) /* switch-over disabled */
  20. #define REG_CONTROL3_PM_DSM (1 << 5) /* direct switching mode */
  21. #define REG_CONTROL3_PM_MASK 0xe0
  22. #define REG_CONTROL3_BLF (1 << 2) /* battery low bit, read-only */
  23. #define REG_SECONDS 0x03
  24. #define REG_SECONDS_OS (1 << 7)
  25. #define REG_MINUTES 0x04
  26. #define REG_HOURS 0x05
  27. #define REG_DAYS 0x06
  28. #define REG_WEEKDAYS 0x07
  29. #define REG_MONTHS 0x08
  30. #define REG_YEARS 0x09
  31. #define REG_OFFSET 0x0e
  32. #define REG_OFFSET_MODE BIT(7)
  33. struct pcf8523 {
  34. struct rtc_device *rtc;
  35. };
  36. static int pcf8523_read(struct i2c_client *client, u8 reg, u8 *valuep)
  37. {
  38. struct i2c_msg msgs[2];
  39. u8 value = 0;
  40. int err;
  41. msgs[0].addr = client->addr;
  42. msgs[0].flags = 0;
  43. msgs[0].len = sizeof(reg);
  44. msgs[0].buf = &reg;
  45. msgs[1].addr = client->addr;
  46. msgs[1].flags = I2C_M_RD;
  47. msgs[1].len = sizeof(value);
  48. msgs[1].buf = &value;
  49. err = i2c_transfer(client->adapter, msgs, ARRAY_SIZE(msgs));
  50. if (err < 0)
  51. return err;
  52. *valuep = value;
  53. return 0;
  54. }
  55. static int pcf8523_write(struct i2c_client *client, u8 reg, u8 value)
  56. {
  57. u8 buffer[2] = { reg, value };
  58. struct i2c_msg msg;
  59. int err;
  60. msg.addr = client->addr;
  61. msg.flags = 0;
  62. msg.len = sizeof(buffer);
  63. msg.buf = buffer;
  64. err = i2c_transfer(client->adapter, &msg, 1);
  65. if (err < 0)
  66. return err;
  67. return 0;
  68. }
  69. static int pcf8523_select_capacitance(struct i2c_client *client, bool high)
  70. {
  71. u8 value;
  72. int err;
  73. err = pcf8523_read(client, REG_CONTROL1, &value);
  74. if (err < 0)
  75. return err;
  76. if (!high)
  77. value &= ~REG_CONTROL1_CAP_SEL;
  78. else
  79. value |= REG_CONTROL1_CAP_SEL;
  80. err = pcf8523_write(client, REG_CONTROL1, value);
  81. if (err < 0)
  82. return err;
  83. return err;
  84. }
  85. static int pcf8523_set_pm(struct i2c_client *client, u8 pm)
  86. {
  87. u8 value;
  88. int err;
  89. err = pcf8523_read(client, REG_CONTROL3, &value);
  90. if (err < 0)
  91. return err;
  92. value = (value & ~REG_CONTROL3_PM_MASK) | pm;
  93. err = pcf8523_write(client, REG_CONTROL3, value);
  94. if (err < 0)
  95. return err;
  96. return 0;
  97. }
  98. static int pcf8523_stop_rtc(struct i2c_client *client)
  99. {
  100. u8 value;
  101. int err;
  102. err = pcf8523_read(client, REG_CONTROL1, &value);
  103. if (err < 0)
  104. return err;
  105. value |= REG_CONTROL1_STOP;
  106. err = pcf8523_write(client, REG_CONTROL1, value);
  107. if (err < 0)
  108. return err;
  109. return 0;
  110. }
  111. static int pcf8523_start_rtc(struct i2c_client *client)
  112. {
  113. u8 value;
  114. int err;
  115. err = pcf8523_read(client, REG_CONTROL1, &value);
  116. if (err < 0)
  117. return err;
  118. value &= ~REG_CONTROL1_STOP;
  119. err = pcf8523_write(client, REG_CONTROL1, value);
  120. if (err < 0)
  121. return err;
  122. return 0;
  123. }
  124. static int pcf8523_rtc_read_time(struct device *dev, struct rtc_time *tm)
  125. {
  126. struct i2c_client *client = to_i2c_client(dev);
  127. u8 start = REG_SECONDS, regs[7];
  128. struct i2c_msg msgs[2];
  129. int err;
  130. msgs[0].addr = client->addr;
  131. msgs[0].flags = 0;
  132. msgs[0].len = 1;
  133. msgs[0].buf = &start;
  134. msgs[1].addr = client->addr;
  135. msgs[1].flags = I2C_M_RD;
  136. msgs[1].len = sizeof(regs);
  137. msgs[1].buf = regs;
  138. err = i2c_transfer(client->adapter, msgs, ARRAY_SIZE(msgs));
  139. if (err < 0)
  140. return err;
  141. if (regs[0] & REG_SECONDS_OS)
  142. return -EINVAL;
  143. tm->tm_sec = bcd2bin(regs[0] & 0x7f);
  144. tm->tm_min = bcd2bin(regs[1] & 0x7f);
  145. tm->tm_hour = bcd2bin(regs[2] & 0x3f);
  146. tm->tm_mday = bcd2bin(regs[3] & 0x3f);
  147. tm->tm_wday = regs[4] & 0x7;
  148. tm->tm_mon = bcd2bin(regs[5] & 0x1f) - 1;
  149. tm->tm_year = bcd2bin(regs[6]) + 100;
  150. return 0;
  151. }
  152. static int pcf8523_rtc_set_time(struct device *dev, struct rtc_time *tm)
  153. {
  154. struct i2c_client *client = to_i2c_client(dev);
  155. struct i2c_msg msg;
  156. u8 regs[8];
  157. int err;
  158. /*
  159. * The hardware can only store values between 0 and 99 in it's YEAR
  160. * register (with 99 overflowing to 0 on increment).
  161. * After 2100-02-28 we could start interpreting the year to be in the
  162. * interval [2100, 2199], but there is no path to switch in a smooth way
  163. * because the chip handles YEAR=0x00 (and the out-of-spec
  164. * YEAR=0xa0) as a leap year, but 2100 isn't.
  165. */
  166. if (tm->tm_year < 100 || tm->tm_year >= 200)
  167. return -EINVAL;
  168. err = pcf8523_stop_rtc(client);
  169. if (err < 0)
  170. return err;
  171. regs[0] = REG_SECONDS;
  172. /* This will purposely overwrite REG_SECONDS_OS */
  173. regs[1] = bin2bcd(tm->tm_sec);
  174. regs[2] = bin2bcd(tm->tm_min);
  175. regs[3] = bin2bcd(tm->tm_hour);
  176. regs[4] = bin2bcd(tm->tm_mday);
  177. regs[5] = tm->tm_wday;
  178. regs[6] = bin2bcd(tm->tm_mon + 1);
  179. regs[7] = bin2bcd(tm->tm_year - 100);
  180. msg.addr = client->addr;
  181. msg.flags = 0;
  182. msg.len = sizeof(regs);
  183. msg.buf = regs;
  184. err = i2c_transfer(client->adapter, &msg, 1);
  185. if (err < 0) {
  186. /*
  187. * If the time cannot be set, restart the RTC anyway. Note
  188. * that errors are ignored if the RTC cannot be started so
  189. * that we have a chance to propagate the original error.
  190. */
  191. pcf8523_start_rtc(client);
  192. return err;
  193. }
  194. return pcf8523_start_rtc(client);
  195. }
  196. #ifdef CONFIG_RTC_INTF_DEV
  197. static int pcf8523_rtc_ioctl(struct device *dev, unsigned int cmd,
  198. unsigned long arg)
  199. {
  200. struct i2c_client *client = to_i2c_client(dev);
  201. u8 value;
  202. int ret = 0, err;
  203. switch (cmd) {
  204. case RTC_VL_READ:
  205. err = pcf8523_read(client, REG_CONTROL3, &value);
  206. if (err < 0)
  207. return err;
  208. if (value & REG_CONTROL3_BLF)
  209. ret = 1;
  210. if (copy_to_user((void __user *)arg, &ret, sizeof(int)))
  211. return -EFAULT;
  212. return 0;
  213. default:
  214. return -ENOIOCTLCMD;
  215. }
  216. }
  217. #else
  218. #define pcf8523_rtc_ioctl NULL
  219. #endif
  220. static int pcf8523_rtc_read_offset(struct device *dev, long *offset)
  221. {
  222. struct i2c_client *client = to_i2c_client(dev);
  223. int err;
  224. u8 value;
  225. s8 val;
  226. err = pcf8523_read(client, REG_OFFSET, &value);
  227. if (err < 0)
  228. return err;
  229. /* sign extend the 7-bit offset value */
  230. val = value << 1;
  231. *offset = (value & REG_OFFSET_MODE ? 4069 : 4340) * (val >> 1);
  232. return 0;
  233. }
  234. static int pcf8523_rtc_set_offset(struct device *dev, long offset)
  235. {
  236. struct i2c_client *client = to_i2c_client(dev);
  237. long reg_m0, reg_m1;
  238. u8 value;
  239. reg_m0 = clamp(DIV_ROUND_CLOSEST(offset, 4340), -64L, 63L);
  240. reg_m1 = clamp(DIV_ROUND_CLOSEST(offset, 4069), -64L, 63L);
  241. if (abs(reg_m0 * 4340 - offset) < abs(reg_m1 * 4069 - offset))
  242. value = reg_m0 & 0x7f;
  243. else
  244. value = (reg_m1 & 0x7f) | REG_OFFSET_MODE;
  245. return pcf8523_write(client, REG_OFFSET, value);
  246. }
  247. static const struct rtc_class_ops pcf8523_rtc_ops = {
  248. .read_time = pcf8523_rtc_read_time,
  249. .set_time = pcf8523_rtc_set_time,
  250. .ioctl = pcf8523_rtc_ioctl,
  251. .read_offset = pcf8523_rtc_read_offset,
  252. .set_offset = pcf8523_rtc_set_offset,
  253. };
  254. static int pcf8523_probe(struct i2c_client *client,
  255. const struct i2c_device_id *id)
  256. {
  257. struct pcf8523 *pcf;
  258. int err;
  259. if (!i2c_check_functionality(client->adapter, I2C_FUNC_I2C))
  260. return -ENODEV;
  261. pcf = devm_kzalloc(&client->dev, sizeof(*pcf), GFP_KERNEL);
  262. if (!pcf)
  263. return -ENOMEM;
  264. err = pcf8523_select_capacitance(client, true);
  265. if (err < 0)
  266. return err;
  267. err = pcf8523_set_pm(client, 0);
  268. if (err < 0)
  269. return err;
  270. pcf->rtc = devm_rtc_device_register(&client->dev, DRIVER_NAME,
  271. &pcf8523_rtc_ops, THIS_MODULE);
  272. if (IS_ERR(pcf->rtc))
  273. return PTR_ERR(pcf->rtc);
  274. i2c_set_clientdata(client, pcf);
  275. return 0;
  276. }
  277. static const struct i2c_device_id pcf8523_id[] = {
  278. { "pcf8523", 0 },
  279. { }
  280. };
  281. MODULE_DEVICE_TABLE(i2c, pcf8523_id);
  282. #ifdef CONFIG_OF
  283. static const struct of_device_id pcf8523_of_match[] = {
  284. { .compatible = "nxp,pcf8523" },
  285. { }
  286. };
  287. MODULE_DEVICE_TABLE(of, pcf8523_of_match);
  288. #endif
  289. static struct i2c_driver pcf8523_driver = {
  290. .driver = {
  291. .name = DRIVER_NAME,
  292. .of_match_table = of_match_ptr(pcf8523_of_match),
  293. },
  294. .probe = pcf8523_probe,
  295. .id_table = pcf8523_id,
  296. };
  297. module_i2c_driver(pcf8523_driver);
  298. MODULE_AUTHOR("Thierry Reding <thierry.reding@avionic-design.de>");
  299. MODULE_DESCRIPTION("NXP PCF8523 RTC driver");
  300. MODULE_LICENSE("GPL v2");