rtc-x1205.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697
  1. /*
  2. * An i2c driver for the Xicor/Intersil X1205 RTC
  3. * Copyright 2004 Karen Spearel
  4. * Copyright 2005 Alessandro Zummo
  5. *
  6. * please send all reports to:
  7. * Karen Spearel <kas111 at gmail dot com>
  8. * Alessandro Zummo <a.zummo@towertech.it>
  9. *
  10. * based on a lot of other RTC drivers.
  11. *
  12. * Information and datasheet:
  13. * http://www.intersil.com/cda/deviceinfo/0,1477,X1205,00.html
  14. *
  15. * This program is free software; you can redistribute it and/or modify
  16. * it under the terms of the GNU General Public License version 2 as
  17. * published by the Free Software Foundation.
  18. */
  19. #include <linux/i2c.h>
  20. #include <linux/bcd.h>
  21. #include <linux/rtc.h>
  22. #include <linux/delay.h>
  23. #include <linux/module.h>
  24. #define DRV_VERSION "1.0.8"
  25. /* offsets into CCR area */
  26. #define CCR_SEC 0
  27. #define CCR_MIN 1
  28. #define CCR_HOUR 2
  29. #define CCR_MDAY 3
  30. #define CCR_MONTH 4
  31. #define CCR_YEAR 5
  32. #define CCR_WDAY 6
  33. #define CCR_Y2K 7
  34. #define X1205_REG_SR 0x3F /* status register */
  35. #define X1205_REG_Y2K 0x37
  36. #define X1205_REG_DW 0x36
  37. #define X1205_REG_YR 0x35
  38. #define X1205_REG_MO 0x34
  39. #define X1205_REG_DT 0x33
  40. #define X1205_REG_HR 0x32
  41. #define X1205_REG_MN 0x31
  42. #define X1205_REG_SC 0x30
  43. #define X1205_REG_DTR 0x13
  44. #define X1205_REG_ATR 0x12
  45. #define X1205_REG_INT 0x11
  46. #define X1205_REG_0 0x10
  47. #define X1205_REG_Y2K1 0x0F
  48. #define X1205_REG_DWA1 0x0E
  49. #define X1205_REG_YRA1 0x0D
  50. #define X1205_REG_MOA1 0x0C
  51. #define X1205_REG_DTA1 0x0B
  52. #define X1205_REG_HRA1 0x0A
  53. #define X1205_REG_MNA1 0x09
  54. #define X1205_REG_SCA1 0x08
  55. #define X1205_REG_Y2K0 0x07
  56. #define X1205_REG_DWA0 0x06
  57. #define X1205_REG_YRA0 0x05
  58. #define X1205_REG_MOA0 0x04
  59. #define X1205_REG_DTA0 0x03
  60. #define X1205_REG_HRA0 0x02
  61. #define X1205_REG_MNA0 0x01
  62. #define X1205_REG_SCA0 0x00
  63. #define X1205_CCR_BASE 0x30 /* Base address of CCR */
  64. #define X1205_ALM0_BASE 0x00 /* Base address of ALARM0 */
  65. #define X1205_SR_RTCF 0x01 /* Clock failure */
  66. #define X1205_SR_WEL 0x02 /* Write Enable Latch */
  67. #define X1205_SR_RWEL 0x04 /* Register Write Enable */
  68. #define X1205_SR_AL0 0x20 /* Alarm 0 match */
  69. #define X1205_DTR_DTR0 0x01
  70. #define X1205_DTR_DTR1 0x02
  71. #define X1205_DTR_DTR2 0x04
  72. #define X1205_HR_MIL 0x80 /* Set in ccr.hour for 24 hr mode */
  73. #define X1205_INT_AL0E 0x20 /* Alarm 0 enable */
  74. static struct i2c_driver x1205_driver;
  75. /*
  76. * In the routines that deal directly with the x1205 hardware, we use
  77. * rtc_time -- month 0-11, hour 0-23, yr = calendar year-epoch
  78. * Epoch is initialized as 2000. Time is set to UTC.
  79. */
  80. static int x1205_get_datetime(struct i2c_client *client, struct rtc_time *tm,
  81. unsigned char reg_base)
  82. {
  83. unsigned char dt_addr[2] = { 0, reg_base };
  84. unsigned char buf[8];
  85. int i;
  86. struct i2c_msg msgs[] = {
  87. {/* setup read ptr */
  88. .addr = client->addr,
  89. .len = 2,
  90. .buf = dt_addr
  91. },
  92. {/* read date */
  93. .addr = client->addr,
  94. .flags = I2C_M_RD,
  95. .len = 8,
  96. .buf = buf
  97. },
  98. };
  99. /* read date registers */
  100. if (i2c_transfer(client->adapter, &msgs[0], 2) != 2) {
  101. dev_err(&client->dev, "%s: read error\n", __func__);
  102. return -EIO;
  103. }
  104. dev_dbg(&client->dev,
  105. "%s: raw read data - sec=%02x, min=%02x, hr=%02x, "
  106. "mday=%02x, mon=%02x, year=%02x, wday=%02x, y2k=%02x\n",
  107. __func__,
  108. buf[0], buf[1], buf[2], buf[3],
  109. buf[4], buf[5], buf[6], buf[7]);
  110. /* Mask out the enable bits if these are alarm registers */
  111. if (reg_base < X1205_CCR_BASE)
  112. for (i = 0; i <= 4; i++)
  113. buf[i] &= 0x7F;
  114. tm->tm_sec = bcd2bin(buf[CCR_SEC]);
  115. tm->tm_min = bcd2bin(buf[CCR_MIN]);
  116. tm->tm_hour = bcd2bin(buf[CCR_HOUR] & 0x3F); /* hr is 0-23 */
  117. tm->tm_mday = bcd2bin(buf[CCR_MDAY]);
  118. tm->tm_mon = bcd2bin(buf[CCR_MONTH]) - 1; /* mon is 0-11 */
  119. tm->tm_year = bcd2bin(buf[CCR_YEAR])
  120. + (bcd2bin(buf[CCR_Y2K]) * 100) - 1900;
  121. tm->tm_wday = buf[CCR_WDAY];
  122. dev_dbg(&client->dev, "%s: tm is secs=%d, mins=%d, hours=%d, "
  123. "mday=%d, mon=%d, year=%d, wday=%d\n",
  124. __func__,
  125. tm->tm_sec, tm->tm_min, tm->tm_hour,
  126. tm->tm_mday, tm->tm_mon, tm->tm_year, tm->tm_wday);
  127. return 0;
  128. }
  129. static int x1205_get_status(struct i2c_client *client, unsigned char *sr)
  130. {
  131. static unsigned char sr_addr[2] = { 0, X1205_REG_SR };
  132. struct i2c_msg msgs[] = {
  133. { /* setup read ptr */
  134. .addr = client->addr,
  135. .len = 2,
  136. .buf = sr_addr
  137. },
  138. { /* read status */
  139. .addr = client->addr,
  140. .flags = I2C_M_RD,
  141. .len = 1,
  142. .buf = sr
  143. },
  144. };
  145. /* read status register */
  146. if (i2c_transfer(client->adapter, &msgs[0], 2) != 2) {
  147. dev_err(&client->dev, "%s: read error\n", __func__);
  148. return -EIO;
  149. }
  150. return 0;
  151. }
  152. static int x1205_set_datetime(struct i2c_client *client, struct rtc_time *tm,
  153. u8 reg_base, unsigned char alm_enable)
  154. {
  155. int i, xfer;
  156. unsigned char rdata[10] = { 0, reg_base };
  157. unsigned char *buf = rdata + 2;
  158. static const unsigned char wel[3] = { 0, X1205_REG_SR,
  159. X1205_SR_WEL };
  160. static const unsigned char rwel[3] = { 0, X1205_REG_SR,
  161. X1205_SR_WEL | X1205_SR_RWEL };
  162. static const unsigned char diswe[3] = { 0, X1205_REG_SR, 0 };
  163. dev_dbg(&client->dev,
  164. "%s: sec=%d min=%d hour=%d mday=%d mon=%d year=%d wday=%d\n",
  165. __func__, tm->tm_sec, tm->tm_min, tm->tm_hour, tm->tm_mday,
  166. tm->tm_mon, tm->tm_year, tm->tm_wday);
  167. buf[CCR_SEC] = bin2bcd(tm->tm_sec);
  168. buf[CCR_MIN] = bin2bcd(tm->tm_min);
  169. /* set hour and 24hr bit */
  170. buf[CCR_HOUR] = bin2bcd(tm->tm_hour) | X1205_HR_MIL;
  171. buf[CCR_MDAY] = bin2bcd(tm->tm_mday);
  172. /* month, 1 - 12 */
  173. buf[CCR_MONTH] = bin2bcd(tm->tm_mon + 1);
  174. /* year, since the rtc epoch*/
  175. buf[CCR_YEAR] = bin2bcd(tm->tm_year % 100);
  176. buf[CCR_WDAY] = tm->tm_wday & 0x07;
  177. buf[CCR_Y2K] = bin2bcd((tm->tm_year + 1900) / 100);
  178. /* If writing alarm registers, set compare bits on registers 0-4 */
  179. if (reg_base < X1205_CCR_BASE)
  180. for (i = 0; i <= 4; i++)
  181. buf[i] |= 0x80;
  182. /* this sequence is required to unlock the chip */
  183. if ((xfer = i2c_master_send(client, wel, 3)) != 3) {
  184. dev_err(&client->dev, "%s: wel - %d\n", __func__, xfer);
  185. return -EIO;
  186. }
  187. if ((xfer = i2c_master_send(client, rwel, 3)) != 3) {
  188. dev_err(&client->dev, "%s: rwel - %d\n", __func__, xfer);
  189. return -EIO;
  190. }
  191. xfer = i2c_master_send(client, rdata, sizeof(rdata));
  192. if (xfer != sizeof(rdata)) {
  193. dev_err(&client->dev,
  194. "%s: result=%d addr=%02x, data=%02x\n",
  195. __func__,
  196. xfer, rdata[1], rdata[2]);
  197. return -EIO;
  198. }
  199. /* If we wrote to the nonvolatile region, wait 10msec for write cycle*/
  200. if (reg_base < X1205_CCR_BASE) {
  201. unsigned char al0e[3] = { 0, X1205_REG_INT, 0 };
  202. msleep(10);
  203. /* ...and set or clear the AL0E bit in the INT register */
  204. /* Need to set RWEL again as the write has cleared it */
  205. xfer = i2c_master_send(client, rwel, 3);
  206. if (xfer != 3) {
  207. dev_err(&client->dev,
  208. "%s: aloe rwel - %d\n",
  209. __func__,
  210. xfer);
  211. return -EIO;
  212. }
  213. if (alm_enable)
  214. al0e[2] = X1205_INT_AL0E;
  215. xfer = i2c_master_send(client, al0e, 3);
  216. if (xfer != 3) {
  217. dev_err(&client->dev,
  218. "%s: al0e - %d\n",
  219. __func__,
  220. xfer);
  221. return -EIO;
  222. }
  223. /* and wait 10msec again for this write to complete */
  224. msleep(10);
  225. }
  226. /* disable further writes */
  227. if ((xfer = i2c_master_send(client, diswe, 3)) != 3) {
  228. dev_err(&client->dev, "%s: diswe - %d\n", __func__, xfer);
  229. return -EIO;
  230. }
  231. return 0;
  232. }
  233. static int x1205_fix_osc(struct i2c_client *client)
  234. {
  235. int err;
  236. struct rtc_time tm;
  237. memset(&tm, 0, sizeof(tm));
  238. err = x1205_set_datetime(client, &tm, X1205_CCR_BASE, 0);
  239. if (err < 0)
  240. dev_err(&client->dev, "unable to restart the oscillator\n");
  241. return err;
  242. }
  243. static int x1205_get_dtrim(struct i2c_client *client, int *trim)
  244. {
  245. unsigned char dtr;
  246. static unsigned char dtr_addr[2] = { 0, X1205_REG_DTR };
  247. struct i2c_msg msgs[] = {
  248. { /* setup read ptr */
  249. .addr = client->addr,
  250. .len = 2,
  251. .buf = dtr_addr
  252. },
  253. { /* read dtr */
  254. .addr = client->addr,
  255. .flags = I2C_M_RD,
  256. .len = 1,
  257. .buf = &dtr
  258. },
  259. };
  260. /* read dtr register */
  261. if (i2c_transfer(client->adapter, &msgs[0], 2) != 2) {
  262. dev_err(&client->dev, "%s: read error\n", __func__);
  263. return -EIO;
  264. }
  265. dev_dbg(&client->dev, "%s: raw dtr=%x\n", __func__, dtr);
  266. *trim = 0;
  267. if (dtr & X1205_DTR_DTR0)
  268. *trim += 20;
  269. if (dtr & X1205_DTR_DTR1)
  270. *trim += 10;
  271. if (dtr & X1205_DTR_DTR2)
  272. *trim = -*trim;
  273. return 0;
  274. }
  275. static int x1205_get_atrim(struct i2c_client *client, int *trim)
  276. {
  277. s8 atr;
  278. static unsigned char atr_addr[2] = { 0, X1205_REG_ATR };
  279. struct i2c_msg msgs[] = {
  280. {/* setup read ptr */
  281. .addr = client->addr,
  282. .len = 2,
  283. .buf = atr_addr
  284. },
  285. {/* read atr */
  286. .addr = client->addr,
  287. .flags = I2C_M_RD,
  288. .len = 1,
  289. .buf = &atr
  290. },
  291. };
  292. /* read atr register */
  293. if (i2c_transfer(client->adapter, &msgs[0], 2) != 2) {
  294. dev_err(&client->dev, "%s: read error\n", __func__);
  295. return -EIO;
  296. }
  297. dev_dbg(&client->dev, "%s: raw atr=%x\n", __func__, atr);
  298. /* atr is a two's complement value on 6 bits,
  299. * perform sign extension. The formula is
  300. * Catr = (atr * 0.25pF) + 11.00pF.
  301. */
  302. if (atr & 0x20)
  303. atr |= 0xC0;
  304. dev_dbg(&client->dev, "%s: raw atr=%x (%d)\n", __func__, atr, atr);
  305. *trim = (atr * 250) + 11000;
  306. dev_dbg(&client->dev, "%s: real=%d\n", __func__, *trim);
  307. return 0;
  308. }
  309. struct x1205_limit
  310. {
  311. unsigned char reg, mask, min, max;
  312. };
  313. static int x1205_validate_client(struct i2c_client *client)
  314. {
  315. int i, xfer;
  316. /* Probe array. We will read the register at the specified
  317. * address and check if the given bits are zero.
  318. */
  319. static const unsigned char probe_zero_pattern[] = {
  320. /* register, mask */
  321. X1205_REG_SR, 0x18,
  322. X1205_REG_DTR, 0xF8,
  323. X1205_REG_ATR, 0xC0,
  324. X1205_REG_INT, 0x18,
  325. X1205_REG_0, 0xFF,
  326. };
  327. static const struct x1205_limit probe_limits_pattern[] = {
  328. /* register, mask, min, max */
  329. { X1205_REG_Y2K, 0xFF, 19, 20 },
  330. { X1205_REG_DW, 0xFF, 0, 6 },
  331. { X1205_REG_YR, 0xFF, 0, 99 },
  332. { X1205_REG_MO, 0xFF, 0, 12 },
  333. { X1205_REG_DT, 0xFF, 0, 31 },
  334. { X1205_REG_HR, 0x7F, 0, 23 },
  335. { X1205_REG_MN, 0xFF, 0, 59 },
  336. { X1205_REG_SC, 0xFF, 0, 59 },
  337. { X1205_REG_Y2K1, 0xFF, 19, 20 },
  338. { X1205_REG_Y2K0, 0xFF, 19, 20 },
  339. };
  340. /* check that registers have bits a 0 where expected */
  341. for (i = 0; i < ARRAY_SIZE(probe_zero_pattern); i += 2) {
  342. unsigned char buf;
  343. unsigned char addr[2] = { 0, probe_zero_pattern[i] };
  344. struct i2c_msg msgs[2] = {
  345. {
  346. .addr = client->addr,
  347. .len = 2,
  348. .buf = addr
  349. },
  350. {
  351. .addr = client->addr,
  352. .flags = I2C_M_RD,
  353. .len = 1,
  354. .buf = &buf
  355. },
  356. };
  357. if ((xfer = i2c_transfer(client->adapter, msgs, 2)) != 2) {
  358. dev_err(&client->dev,
  359. "%s: could not read register %x\n",
  360. __func__, probe_zero_pattern[i]);
  361. return -EIO;
  362. }
  363. if ((buf & probe_zero_pattern[i+1]) != 0) {
  364. dev_err(&client->dev,
  365. "%s: register=%02x, zero pattern=%d, value=%x\n",
  366. __func__, probe_zero_pattern[i], i, buf);
  367. return -ENODEV;
  368. }
  369. }
  370. /* check limits (only registers with bcd values) */
  371. for (i = 0; i < ARRAY_SIZE(probe_limits_pattern); i++) {
  372. unsigned char reg, value;
  373. unsigned char addr[2] = { 0, probe_limits_pattern[i].reg };
  374. struct i2c_msg msgs[2] = {
  375. {
  376. .addr = client->addr,
  377. .len = 2,
  378. .buf = addr
  379. },
  380. {
  381. .addr = client->addr,
  382. .flags = I2C_M_RD,
  383. .len = 1,
  384. .buf = &reg
  385. },
  386. };
  387. if ((xfer = i2c_transfer(client->adapter, msgs, 2)) != 2) {
  388. dev_err(&client->dev,
  389. "%s: could not read register %x\n",
  390. __func__, probe_limits_pattern[i].reg);
  391. return -EIO;
  392. }
  393. value = bcd2bin(reg & probe_limits_pattern[i].mask);
  394. if (value > probe_limits_pattern[i].max ||
  395. value < probe_limits_pattern[i].min) {
  396. dev_dbg(&client->dev,
  397. "%s: register=%x, lim pattern=%d, value=%d\n",
  398. __func__, probe_limits_pattern[i].reg,
  399. i, value);
  400. return -ENODEV;
  401. }
  402. }
  403. return 0;
  404. }
  405. static int x1205_rtc_read_alarm(struct device *dev, struct rtc_wkalrm *alrm)
  406. {
  407. int err;
  408. unsigned char intreg, status;
  409. static unsigned char int_addr[2] = { 0, X1205_REG_INT };
  410. struct i2c_client *client = to_i2c_client(dev);
  411. struct i2c_msg msgs[] = {
  412. { /* setup read ptr */
  413. .addr = client->addr,
  414. .len = 2,
  415. .buf = int_addr
  416. },
  417. {/* read INT register */
  418. .addr = client->addr,
  419. .flags = I2C_M_RD,
  420. .len = 1,
  421. .buf = &intreg
  422. },
  423. };
  424. /* read interrupt register and status register */
  425. if (i2c_transfer(client->adapter, &msgs[0], 2) != 2) {
  426. dev_err(&client->dev, "%s: read error\n", __func__);
  427. return -EIO;
  428. }
  429. err = x1205_get_status(client, &status);
  430. if (err == 0) {
  431. alrm->pending = (status & X1205_SR_AL0) ? 1 : 0;
  432. alrm->enabled = (intreg & X1205_INT_AL0E) ? 1 : 0;
  433. err = x1205_get_datetime(client, &alrm->time, X1205_ALM0_BASE);
  434. }
  435. return err;
  436. }
  437. static int x1205_rtc_set_alarm(struct device *dev, struct rtc_wkalrm *alrm)
  438. {
  439. return x1205_set_datetime(to_i2c_client(dev),
  440. &alrm->time, X1205_ALM0_BASE, alrm->enabled);
  441. }
  442. static int x1205_rtc_read_time(struct device *dev, struct rtc_time *tm)
  443. {
  444. return x1205_get_datetime(to_i2c_client(dev),
  445. tm, X1205_CCR_BASE);
  446. }
  447. static int x1205_rtc_set_time(struct device *dev, struct rtc_time *tm)
  448. {
  449. return x1205_set_datetime(to_i2c_client(dev),
  450. tm, X1205_CCR_BASE, 0);
  451. }
  452. static int x1205_rtc_proc(struct device *dev, struct seq_file *seq)
  453. {
  454. int err, dtrim, atrim;
  455. if ((err = x1205_get_dtrim(to_i2c_client(dev), &dtrim)) == 0)
  456. seq_printf(seq, "digital_trim\t: %d ppm\n", dtrim);
  457. if ((err = x1205_get_atrim(to_i2c_client(dev), &atrim)) == 0)
  458. seq_printf(seq, "analog_trim\t: %d.%02d pF\n",
  459. atrim / 1000, atrim % 1000);
  460. return 0;
  461. }
  462. static const struct rtc_class_ops x1205_rtc_ops = {
  463. .proc = x1205_rtc_proc,
  464. .read_time = x1205_rtc_read_time,
  465. .set_time = x1205_rtc_set_time,
  466. .read_alarm = x1205_rtc_read_alarm,
  467. .set_alarm = x1205_rtc_set_alarm,
  468. };
  469. static ssize_t x1205_sysfs_show_atrim(struct device *dev,
  470. struct device_attribute *attr, char *buf)
  471. {
  472. int err, atrim;
  473. err = x1205_get_atrim(to_i2c_client(dev), &atrim);
  474. if (err)
  475. return err;
  476. return sprintf(buf, "%d.%02d pF\n", atrim / 1000, atrim % 1000);
  477. }
  478. static DEVICE_ATTR(atrim, S_IRUGO, x1205_sysfs_show_atrim, NULL);
  479. static ssize_t x1205_sysfs_show_dtrim(struct device *dev,
  480. struct device_attribute *attr, char *buf)
  481. {
  482. int err, dtrim;
  483. err = x1205_get_dtrim(to_i2c_client(dev), &dtrim);
  484. if (err)
  485. return err;
  486. return sprintf(buf, "%d ppm\n", dtrim);
  487. }
  488. static DEVICE_ATTR(dtrim, S_IRUGO, x1205_sysfs_show_dtrim, NULL);
  489. static int x1205_sysfs_register(struct device *dev)
  490. {
  491. int err;
  492. err = device_create_file(dev, &dev_attr_atrim);
  493. if (err)
  494. return err;
  495. err = device_create_file(dev, &dev_attr_dtrim);
  496. if (err)
  497. device_remove_file(dev, &dev_attr_atrim);
  498. return err;
  499. }
  500. static void x1205_sysfs_unregister(struct device *dev)
  501. {
  502. device_remove_file(dev, &dev_attr_atrim);
  503. device_remove_file(dev, &dev_attr_dtrim);
  504. }
  505. static int x1205_probe(struct i2c_client *client,
  506. const struct i2c_device_id *id)
  507. {
  508. int err = 0;
  509. unsigned char sr;
  510. struct rtc_device *rtc;
  511. dev_dbg(&client->dev, "%s\n", __func__);
  512. if (!i2c_check_functionality(client->adapter, I2C_FUNC_I2C))
  513. return -ENODEV;
  514. if (x1205_validate_client(client) < 0)
  515. return -ENODEV;
  516. dev_info(&client->dev, "chip found, driver version " DRV_VERSION "\n");
  517. rtc = rtc_device_register(x1205_driver.driver.name, &client->dev,
  518. &x1205_rtc_ops, THIS_MODULE);
  519. if (IS_ERR(rtc))
  520. return PTR_ERR(rtc);
  521. i2c_set_clientdata(client, rtc);
  522. /* Check for power failures and eventually enable the osc */
  523. if ((err = x1205_get_status(client, &sr)) == 0) {
  524. if (sr & X1205_SR_RTCF) {
  525. dev_err(&client->dev,
  526. "power failure detected, "
  527. "please set the clock\n");
  528. udelay(50);
  529. x1205_fix_osc(client);
  530. }
  531. }
  532. else
  533. dev_err(&client->dev, "couldn't read status\n");
  534. err = x1205_sysfs_register(&client->dev);
  535. if (err)
  536. goto exit_devreg;
  537. return 0;
  538. exit_devreg:
  539. rtc_device_unregister(rtc);
  540. return err;
  541. }
  542. static int x1205_remove(struct i2c_client *client)
  543. {
  544. struct rtc_device *rtc = i2c_get_clientdata(client);
  545. rtc_device_unregister(rtc);
  546. x1205_sysfs_unregister(&client->dev);
  547. return 0;
  548. }
  549. static const struct i2c_device_id x1205_id[] = {
  550. { "x1205", 0 },
  551. { }
  552. };
  553. MODULE_DEVICE_TABLE(i2c, x1205_id);
  554. static struct i2c_driver x1205_driver = {
  555. .driver = {
  556. .name = "rtc-x1205",
  557. },
  558. .probe = x1205_probe,
  559. .remove = x1205_remove,
  560. .id_table = x1205_id,
  561. };
  562. module_i2c_driver(x1205_driver);
  563. MODULE_AUTHOR(
  564. "Karen Spearel <kas111 at gmail dot com>, "
  565. "Alessandro Zummo <a.zummo@towertech.it>");
  566. MODULE_DESCRIPTION("Xicor/Intersil X1205 RTC driver");
  567. MODULE_LICENSE("GPL");
  568. MODULE_VERSION(DRV_VERSION);