rtc-ab-eoz9.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Real Time Clock driver for AB-RTCMC-32.768kHz-EOZ9 chip.
  4. * Copyright (C) 2019 Orolia
  5. *
  6. */
  7. #include <linux/module.h>
  8. #include <linux/rtc.h>
  9. #include <linux/i2c.h>
  10. #include <linux/bcd.h>
  11. #include <linux/of.h>
  12. #include <linux/regmap.h>
  13. #include <linux/bitfield.h>
  14. #include <linux/hwmon.h>
  15. #include <linux/hwmon-sysfs.h>
  16. #define ABEOZ9_REG_CTRL1 0x00
  17. #define ABEOZ9_REG_CTRL1_MASK GENMASK(7, 0)
  18. #define ABEOZ9_REG_CTRL1_WE BIT(0)
  19. #define ABEOZ9_REG_CTRL1_TE BIT(1)
  20. #define ABEOZ9_REG_CTRL1_TAR BIT(2)
  21. #define ABEOZ9_REG_CTRL1_EERE BIT(3)
  22. #define ABEOZ9_REG_CTRL1_SRON BIT(4)
  23. #define ABEOZ9_REG_CTRL1_TD0 BIT(5)
  24. #define ABEOZ9_REG_CTRL1_TD1 BIT(6)
  25. #define ABEOZ9_REG_CTRL1_CLKINT BIT(7)
  26. #define ABEOZ9_REG_CTRL_INT 0x01
  27. #define ABEOZ9_REG_CTRL_INT_AIE BIT(0)
  28. #define ABEOZ9_REG_CTRL_INT_TIE BIT(1)
  29. #define ABEOZ9_REG_CTRL_INT_V1IE BIT(2)
  30. #define ABEOZ9_REG_CTRL_INT_V2IE BIT(3)
  31. #define ABEOZ9_REG_CTRL_INT_SRIE BIT(4)
  32. #define ABEOZ9_REG_CTRL_INT_FLAG 0x02
  33. #define ABEOZ9_REG_CTRL_INT_FLAG_AF BIT(0)
  34. #define ABEOZ9_REG_CTRL_INT_FLAG_TF BIT(1)
  35. #define ABEOZ9_REG_CTRL_INT_FLAG_V1IF BIT(2)
  36. #define ABEOZ9_REG_CTRL_INT_FLAG_V2IF BIT(3)
  37. #define ABEOZ9_REG_CTRL_INT_FLAG_SRF BIT(4)
  38. #define ABEOZ9_REG_CTRL_STATUS 0x03
  39. #define ABEOZ9_REG_CTRL_STATUS_V1F BIT(2)
  40. #define ABEOZ9_REG_CTRL_STATUS_V2F BIT(3)
  41. #define ABEOZ9_REG_CTRL_STATUS_SR BIT(4)
  42. #define ABEOZ9_REG_CTRL_STATUS_PON BIT(5)
  43. #define ABEOZ9_REG_CTRL_STATUS_EEBUSY BIT(7)
  44. #define ABEOZ9_REG_SEC 0x08
  45. #define ABEOZ9_REG_MIN 0x09
  46. #define ABEOZ9_REG_HOURS 0x0A
  47. #define ABEOZ9_HOURS_PM BIT(6)
  48. #define ABEOZ9_REG_DAYS 0x0B
  49. #define ABEOZ9_REG_WEEKDAYS 0x0C
  50. #define ABEOZ9_REG_MONTHS 0x0D
  51. #define ABEOZ9_REG_YEARS 0x0E
  52. #define ABEOZ9_SEC_LEN 7
  53. #define ABEOZ9_REG_ALARM_SEC 0x10
  54. #define ABEOZ9_BIT_ALARM_SEC GENMASK(6, 0)
  55. #define ABEOZ9_REG_ALARM_MIN 0x11
  56. #define ABEOZ9_BIT_ALARM_MIN GENMASK(6, 0)
  57. #define ABEOZ9_REG_ALARM_HOURS 0x12
  58. #define ABEOZ9_BIT_ALARM_HOURS_PM BIT(5)
  59. #define ABEOZ9_BIT_ALARM_HOURS GENMASK(4, 0)
  60. #define ABEOZ9_REG_ALARM_DAYS 0x13
  61. #define ABEOZ9_BIT_ALARM_DAYS GENMASK(5, 0)
  62. #define ABEOZ9_REG_ALARM_WEEKDAYS 0x14
  63. #define ABEOZ9_BIT_ALARM_WEEKDAYS GENMASK(2, 0)
  64. #define ABEOZ9_REG_ALARM_MONTHS 0x15
  65. #define ABEOZ9_BIT_ALARM_MONTHS GENMASK(4, 0)
  66. #define ABEOZ9_REG_ALARM_YEARS 0x16
  67. #define ABEOZ9_ALARM_LEN 7
  68. #define ABEOZ9_BIT_ALARM_AE BIT(7)
  69. #define ABEOZ9_REG_REG_TEMP 0x20
  70. #define ABEOZ953_TEMP_MAX 120
  71. #define ABEOZ953_TEMP_MIN -60
  72. #define ABEOZ9_REG_EEPROM 0x30
  73. #define ABEOZ9_REG_EEPROM_MASK GENMASK(8, 0)
  74. #define ABEOZ9_REG_EEPROM_THP BIT(0)
  75. #define ABEOZ9_REG_EEPROM_THE BIT(1)
  76. #define ABEOZ9_REG_EEPROM_FD0 BIT(2)
  77. #define ABEOZ9_REG_EEPROM_FD1 BIT(3)
  78. #define ABEOZ9_REG_EEPROM_R1K BIT(4)
  79. #define ABEOZ9_REG_EEPROM_R5K BIT(5)
  80. #define ABEOZ9_REG_EEPROM_R20K BIT(6)
  81. #define ABEOZ9_REG_EEPROM_R80K BIT(7)
  82. struct abeoz9_rtc_data {
  83. struct rtc_device *rtc;
  84. struct regmap *regmap;
  85. struct device *hwmon_dev;
  86. };
  87. static int abeoz9_check_validity(struct device *dev)
  88. {
  89. struct abeoz9_rtc_data *data = dev_get_drvdata(dev);
  90. struct regmap *regmap = data->regmap;
  91. int ret;
  92. int val;
  93. ret = regmap_read(regmap, ABEOZ9_REG_CTRL_STATUS, &val);
  94. if (ret < 0) {
  95. dev_err(dev,
  96. "unable to get CTRL_STATUS register (%d)\n", ret);
  97. return ret;
  98. }
  99. if (val & ABEOZ9_REG_CTRL_STATUS_PON) {
  100. dev_warn(dev, "power-on reset detected, date is invalid\n");
  101. return -EINVAL;
  102. }
  103. if (val & ABEOZ9_REG_CTRL_STATUS_V1F) {
  104. dev_warn(dev,
  105. "voltage drops below VLOW1 threshold, date is invalid\n");
  106. return -EINVAL;
  107. }
  108. if ((val & ABEOZ9_REG_CTRL_STATUS_V2F)) {
  109. dev_warn(dev,
  110. "voltage drops below VLOW2 threshold, date is invalid\n");
  111. return -EINVAL;
  112. }
  113. return 0;
  114. }
  115. static int abeoz9_reset_validity(struct regmap *regmap)
  116. {
  117. return regmap_update_bits(regmap, ABEOZ9_REG_CTRL_STATUS,
  118. ABEOZ9_REG_CTRL_STATUS_V1F |
  119. ABEOZ9_REG_CTRL_STATUS_V2F |
  120. ABEOZ9_REG_CTRL_STATUS_PON,
  121. 0);
  122. }
  123. static int abeoz9_rtc_get_time(struct device *dev, struct rtc_time *tm)
  124. {
  125. struct abeoz9_rtc_data *data = dev_get_drvdata(dev);
  126. u8 regs[ABEOZ9_SEC_LEN];
  127. int ret;
  128. ret = abeoz9_check_validity(dev);
  129. if (ret)
  130. return ret;
  131. ret = regmap_bulk_read(data->regmap, ABEOZ9_REG_SEC,
  132. regs,
  133. sizeof(regs));
  134. if (ret) {
  135. dev_err(dev, "reading RTC time failed (%d)\n", ret);
  136. return ret;
  137. }
  138. tm->tm_sec = bcd2bin(regs[ABEOZ9_REG_SEC - ABEOZ9_REG_SEC] & 0x7F);
  139. tm->tm_min = bcd2bin(regs[ABEOZ9_REG_MIN - ABEOZ9_REG_SEC] & 0x7F);
  140. if (regs[ABEOZ9_REG_HOURS - ABEOZ9_REG_SEC] & ABEOZ9_HOURS_PM) {
  141. tm->tm_hour =
  142. bcd2bin(regs[ABEOZ9_REG_HOURS - ABEOZ9_REG_SEC] & 0x1f);
  143. if (regs[ABEOZ9_REG_HOURS - ABEOZ9_REG_SEC] & ABEOZ9_HOURS_PM)
  144. tm->tm_hour += 12;
  145. } else {
  146. tm->tm_hour = bcd2bin(regs[ABEOZ9_REG_HOURS - ABEOZ9_REG_SEC]);
  147. }
  148. tm->tm_mday = bcd2bin(regs[ABEOZ9_REG_DAYS - ABEOZ9_REG_SEC]);
  149. tm->tm_wday = bcd2bin(regs[ABEOZ9_REG_WEEKDAYS - ABEOZ9_REG_SEC]);
  150. tm->tm_mon = bcd2bin(regs[ABEOZ9_REG_MONTHS - ABEOZ9_REG_SEC]) - 1;
  151. tm->tm_year = bcd2bin(regs[ABEOZ9_REG_YEARS - ABEOZ9_REG_SEC]) + 100;
  152. return ret;
  153. }
  154. static int abeoz9_rtc_set_time(struct device *dev, struct rtc_time *tm)
  155. {
  156. struct abeoz9_rtc_data *data = dev_get_drvdata(dev);
  157. struct regmap *regmap = data->regmap;
  158. u8 regs[ABEOZ9_SEC_LEN];
  159. int ret;
  160. regs[ABEOZ9_REG_SEC - ABEOZ9_REG_SEC] = bin2bcd(tm->tm_sec);
  161. regs[ABEOZ9_REG_MIN - ABEOZ9_REG_SEC] = bin2bcd(tm->tm_min);
  162. regs[ABEOZ9_REG_HOURS - ABEOZ9_REG_SEC] = bin2bcd(tm->tm_hour);
  163. regs[ABEOZ9_REG_DAYS - ABEOZ9_REG_SEC] = bin2bcd(tm->tm_mday);
  164. regs[ABEOZ9_REG_WEEKDAYS - ABEOZ9_REG_SEC] = bin2bcd(tm->tm_wday);
  165. regs[ABEOZ9_REG_MONTHS - ABEOZ9_REG_SEC] = bin2bcd(tm->tm_mon + 1);
  166. regs[ABEOZ9_REG_YEARS - ABEOZ9_REG_SEC] = bin2bcd(tm->tm_year - 100);
  167. ret = regmap_bulk_write(data->regmap, ABEOZ9_REG_SEC,
  168. regs,
  169. sizeof(regs));
  170. if (ret) {
  171. dev_err(dev, "set RTC time failed (%d)\n", ret);
  172. return ret;
  173. }
  174. return abeoz9_reset_validity(regmap);
  175. }
  176. static int abeoz9_rtc_read_alarm(struct device *dev, struct rtc_wkalrm *alarm)
  177. {
  178. struct abeoz9_rtc_data *data = dev_get_drvdata(dev);
  179. struct regmap *regmap = data->regmap;
  180. u8 regs[ABEOZ9_ALARM_LEN];
  181. u8 val[2];
  182. int ret;
  183. ret = abeoz9_check_validity(dev);
  184. if (ret)
  185. return ret;
  186. ret = regmap_bulk_read(regmap, ABEOZ9_REG_CTRL_INT, val, sizeof(val));
  187. if (ret)
  188. return ret;
  189. alarm->enabled = val[0] & ABEOZ9_REG_CTRL_INT_AIE;
  190. alarm->pending = val[1] & ABEOZ9_REG_CTRL_INT_FLAG_AF;
  191. ret = regmap_bulk_read(regmap, ABEOZ9_REG_ALARM_SEC, regs, sizeof(regs));
  192. if (ret)
  193. return ret;
  194. alarm->time.tm_sec = bcd2bin(FIELD_GET(ABEOZ9_BIT_ALARM_SEC, regs[0]));
  195. alarm->time.tm_min = bcd2bin(FIELD_GET(ABEOZ9_BIT_ALARM_MIN, regs[1]));
  196. alarm->time.tm_hour = bcd2bin(FIELD_GET(ABEOZ9_BIT_ALARM_HOURS, regs[2]));
  197. if (FIELD_GET(ABEOZ9_BIT_ALARM_HOURS_PM, regs[2]))
  198. alarm->time.tm_hour += 12;
  199. alarm->time.tm_mday = bcd2bin(FIELD_GET(ABEOZ9_BIT_ALARM_DAYS, regs[3]));
  200. return 0;
  201. }
  202. static int abeoz9_rtc_alarm_irq_enable(struct device *dev, u32 enable)
  203. {
  204. struct abeoz9_rtc_data *data = dev_get_drvdata(dev);
  205. return regmap_update_bits(data->regmap, ABEOZ9_REG_CTRL_INT,
  206. ABEOZ9_REG_CTRL_INT_AIE,
  207. FIELD_PREP(ABEOZ9_REG_CTRL_INT_AIE, enable));
  208. }
  209. static int abeoz9_rtc_set_alarm(struct device *dev, struct rtc_wkalrm *alarm)
  210. {
  211. struct abeoz9_rtc_data *data = dev_get_drvdata(dev);
  212. u8 regs[ABEOZ9_ALARM_LEN] = {0};
  213. int ret;
  214. ret = regmap_update_bits(data->regmap, ABEOZ9_REG_CTRL_INT_FLAG,
  215. ABEOZ9_REG_CTRL_INT_FLAG_AF, 0);
  216. if (ret)
  217. return ret;
  218. regs[0] = ABEOZ9_BIT_ALARM_AE | FIELD_PREP(ABEOZ9_BIT_ALARM_SEC,
  219. bin2bcd(alarm->time.tm_sec));
  220. regs[1] = ABEOZ9_BIT_ALARM_AE | FIELD_PREP(ABEOZ9_BIT_ALARM_MIN,
  221. bin2bcd(alarm->time.tm_min));
  222. regs[2] = ABEOZ9_BIT_ALARM_AE | FIELD_PREP(ABEOZ9_BIT_ALARM_HOURS,
  223. bin2bcd(alarm->time.tm_hour));
  224. regs[3] = ABEOZ9_BIT_ALARM_AE | FIELD_PREP(ABEOZ9_BIT_ALARM_DAYS,
  225. bin2bcd(alarm->time.tm_mday));
  226. ret = regmap_bulk_write(data->regmap, ABEOZ9_REG_ALARM_SEC, regs,
  227. sizeof(regs));
  228. if (ret)
  229. return ret;
  230. return abeoz9_rtc_alarm_irq_enable(dev, alarm->enabled);
  231. }
  232. static irqreturn_t abeoz9_rtc_irq(int irq, void *dev)
  233. {
  234. struct abeoz9_rtc_data *data = dev_get_drvdata(dev);
  235. unsigned int val;
  236. int ret;
  237. ret = regmap_read(data->regmap, ABEOZ9_REG_CTRL_INT_FLAG, &val);
  238. if (ret)
  239. return IRQ_NONE;
  240. if (!FIELD_GET(ABEOZ9_REG_CTRL_INT_FLAG_AF, val))
  241. return IRQ_NONE;
  242. regmap_update_bits(data->regmap, ABEOZ9_REG_CTRL_INT_FLAG,
  243. ABEOZ9_REG_CTRL_INT_FLAG_AF, 0);
  244. rtc_update_irq(data->rtc, 1, RTC_IRQF | RTC_AF);
  245. return IRQ_HANDLED;
  246. }
  247. static int abeoz9_trickle_parse_dt(struct device_node *node)
  248. {
  249. u32 ohms = 0;
  250. if (of_property_read_u32(node, "trickle-resistor-ohms", &ohms))
  251. return 0;
  252. switch (ohms) {
  253. case 1000:
  254. return ABEOZ9_REG_EEPROM_R1K;
  255. case 5000:
  256. return ABEOZ9_REG_EEPROM_R5K;
  257. case 20000:
  258. return ABEOZ9_REG_EEPROM_R20K;
  259. case 80000:
  260. return ABEOZ9_REG_EEPROM_R80K;
  261. default:
  262. return 0;
  263. }
  264. }
  265. static int abeoz9_rtc_setup(struct device *dev, struct device_node *node)
  266. {
  267. struct abeoz9_rtc_data *data = dev_get_drvdata(dev);
  268. struct regmap *regmap = data->regmap;
  269. int ret;
  270. /* Enable Self Recovery, Clock for Watch and EEPROM refresh functions */
  271. ret = regmap_update_bits(regmap, ABEOZ9_REG_CTRL1,
  272. ABEOZ9_REG_CTRL1_MASK,
  273. ABEOZ9_REG_CTRL1_WE |
  274. ABEOZ9_REG_CTRL1_EERE |
  275. ABEOZ9_REG_CTRL1_SRON);
  276. if (ret < 0) {
  277. dev_err(dev, "unable to set CTRL_1 register (%d)\n", ret);
  278. return ret;
  279. }
  280. ret = regmap_write(regmap, ABEOZ9_REG_CTRL_INT, 0);
  281. if (ret < 0) {
  282. dev_err(dev,
  283. "unable to set control CTRL_INT register (%d)\n",
  284. ret);
  285. return ret;
  286. }
  287. ret = regmap_write(regmap, ABEOZ9_REG_CTRL_INT_FLAG, 0);
  288. if (ret < 0) {
  289. dev_err(dev,
  290. "unable to set control CTRL_INT_FLAG register (%d)\n",
  291. ret);
  292. return ret;
  293. }
  294. ret = abeoz9_trickle_parse_dt(node);
  295. /* Enable built-in termometer */
  296. ret |= ABEOZ9_REG_EEPROM_THE;
  297. ret = regmap_update_bits(regmap, ABEOZ9_REG_EEPROM,
  298. ABEOZ9_REG_EEPROM_MASK,
  299. ret);
  300. if (ret < 0) {
  301. dev_err(dev, "unable to set EEPROM register (%d)\n", ret);
  302. return ret;
  303. }
  304. return ret;
  305. }
  306. static const struct rtc_class_ops rtc_ops = {
  307. .read_time = abeoz9_rtc_get_time,
  308. .set_time = abeoz9_rtc_set_time,
  309. .read_alarm = abeoz9_rtc_read_alarm,
  310. .set_alarm = abeoz9_rtc_set_alarm,
  311. .alarm_irq_enable = abeoz9_rtc_alarm_irq_enable,
  312. };
  313. static const struct regmap_config abeoz9_rtc_regmap_config = {
  314. .reg_bits = 8,
  315. .val_bits = 8,
  316. .max_register = 0x3f,
  317. };
  318. #if IS_REACHABLE(CONFIG_HWMON)
  319. static int abeoz9z3_temp_read(struct device *dev,
  320. enum hwmon_sensor_types type,
  321. u32 attr, int channel, long *temp)
  322. {
  323. struct abeoz9_rtc_data *data = dev_get_drvdata(dev);
  324. struct regmap *regmap = data->regmap;
  325. int ret;
  326. unsigned int val;
  327. ret = regmap_read(regmap, ABEOZ9_REG_CTRL_STATUS, &val);
  328. if (ret < 0)
  329. return ret;
  330. if ((val & ABEOZ9_REG_CTRL_STATUS_V1F) ||
  331. (val & ABEOZ9_REG_CTRL_STATUS_V2F)) {
  332. dev_err(dev,
  333. "thermometer might be disabled due to low voltage\n");
  334. return -EINVAL;
  335. }
  336. switch (attr) {
  337. case hwmon_temp_input:
  338. ret = regmap_read(regmap, ABEOZ9_REG_REG_TEMP, &val);
  339. if (ret < 0)
  340. return ret;
  341. *temp = 1000 * (val + ABEOZ953_TEMP_MIN);
  342. return 0;
  343. case hwmon_temp_max:
  344. *temp = 1000 * ABEOZ953_TEMP_MAX;
  345. return 0;
  346. case hwmon_temp_min:
  347. *temp = 1000 * ABEOZ953_TEMP_MIN;
  348. return 0;
  349. default:
  350. return -EOPNOTSUPP;
  351. }
  352. }
  353. static umode_t abeoz9_is_visible(const void *data,
  354. enum hwmon_sensor_types type,
  355. u32 attr, int channel)
  356. {
  357. switch (attr) {
  358. case hwmon_temp_input:
  359. case hwmon_temp_max:
  360. case hwmon_temp_min:
  361. return 0444;
  362. default:
  363. return 0;
  364. }
  365. }
  366. static const u32 abeoz9_chip_config[] = {
  367. HWMON_C_REGISTER_TZ,
  368. 0
  369. };
  370. static const struct hwmon_channel_info abeoz9_chip = {
  371. .type = hwmon_chip,
  372. .config = abeoz9_chip_config,
  373. };
  374. static const u32 abeoz9_temp_config[] = {
  375. HWMON_T_INPUT | HWMON_T_MAX | HWMON_T_MIN,
  376. 0
  377. };
  378. static const struct hwmon_channel_info abeoz9_temp = {
  379. .type = hwmon_temp,
  380. .config = abeoz9_temp_config,
  381. };
  382. static const struct hwmon_channel_info *abeoz9_info[] = {
  383. &abeoz9_chip,
  384. &abeoz9_temp,
  385. NULL
  386. };
  387. static const struct hwmon_ops abeoz9_hwmon_ops = {
  388. .is_visible = abeoz9_is_visible,
  389. .read = abeoz9z3_temp_read,
  390. };
  391. static const struct hwmon_chip_info abeoz9_chip_info = {
  392. .ops = &abeoz9_hwmon_ops,
  393. .info = abeoz9_info,
  394. };
  395. static void abeoz9_hwmon_register(struct device *dev,
  396. struct abeoz9_rtc_data *data)
  397. {
  398. data->hwmon_dev =
  399. devm_hwmon_device_register_with_info(dev,
  400. "abeoz9",
  401. data,
  402. &abeoz9_chip_info,
  403. NULL);
  404. if (IS_ERR(data->hwmon_dev)) {
  405. dev_warn(dev, "unable to register hwmon device %ld\n",
  406. PTR_ERR(data->hwmon_dev));
  407. }
  408. }
  409. #else
  410. static void abeoz9_hwmon_register(struct device *dev,
  411. struct abeoz9_rtc_data *data)
  412. {
  413. }
  414. #endif
  415. static int abeoz9_probe(struct i2c_client *client)
  416. {
  417. struct abeoz9_rtc_data *data = NULL;
  418. struct device *dev = &client->dev;
  419. struct regmap *regmap;
  420. int ret;
  421. if (!i2c_check_functionality(client->adapter, I2C_FUNC_I2C |
  422. I2C_FUNC_SMBUS_BYTE_DATA |
  423. I2C_FUNC_SMBUS_I2C_BLOCK))
  424. return -ENODEV;
  425. regmap = devm_regmap_init_i2c(client, &abeoz9_rtc_regmap_config);
  426. if (IS_ERR(regmap)) {
  427. ret = PTR_ERR(regmap);
  428. dev_err(dev, "regmap allocation failed: %d\n", ret);
  429. return ret;
  430. }
  431. data = devm_kzalloc(dev, sizeof(*data), GFP_KERNEL);
  432. if (!data)
  433. return -ENOMEM;
  434. data->regmap = regmap;
  435. dev_set_drvdata(dev, data);
  436. ret = abeoz9_rtc_setup(dev, client->dev.of_node);
  437. if (ret)
  438. return ret;
  439. data->rtc = devm_rtc_allocate_device(dev);
  440. ret = PTR_ERR_OR_ZERO(data->rtc);
  441. if (ret)
  442. return ret;
  443. data->rtc->ops = &rtc_ops;
  444. data->rtc->range_min = RTC_TIMESTAMP_BEGIN_2000;
  445. data->rtc->range_max = RTC_TIMESTAMP_END_2099;
  446. clear_bit(RTC_FEATURE_ALARM, data->rtc->features);
  447. if (client->irq > 0) {
  448. ret = devm_request_threaded_irq(dev, client->irq, NULL,
  449. abeoz9_rtc_irq,
  450. IRQF_TRIGGER_LOW | IRQF_ONESHOT,
  451. dev_name(dev), dev);
  452. if (ret) {
  453. dev_err(dev, "failed to request alarm irq\n");
  454. return ret;
  455. }
  456. } else {
  457. clear_bit(RTC_FEATURE_UPDATE_INTERRUPT, data->rtc->features);
  458. }
  459. if (client->irq > 0 || device_property_read_bool(dev, "wakeup-source")) {
  460. ret = device_init_wakeup(dev, true);
  461. set_bit(RTC_FEATURE_ALARM, data->rtc->features);
  462. }
  463. ret = devm_rtc_register_device(data->rtc);
  464. if (ret)
  465. return ret;
  466. abeoz9_hwmon_register(dev, data);
  467. return 0;
  468. }
  469. #ifdef CONFIG_OF
  470. static const struct of_device_id abeoz9_dt_match[] = {
  471. { .compatible = "abracon,abeoz9" },
  472. { },
  473. };
  474. MODULE_DEVICE_TABLE(of, abeoz9_dt_match);
  475. #endif
  476. static const struct i2c_device_id abeoz9_id[] = {
  477. { "abeoz9", 0 },
  478. { }
  479. };
  480. static struct i2c_driver abeoz9_driver = {
  481. .driver = {
  482. .name = "rtc-ab-eoz9",
  483. .of_match_table = of_match_ptr(abeoz9_dt_match),
  484. },
  485. .probe_new = abeoz9_probe,
  486. .id_table = abeoz9_id,
  487. };
  488. module_i2c_driver(abeoz9_driver);
  489. MODULE_AUTHOR("Artem Panfilov <[email protected]>");
  490. MODULE_DESCRIPTION("Abracon AB-RTCMC-32.768kHz-EOZ9 RTC driver");
  491. MODULE_LICENSE("GPL");