Lines Matching +full:ev +full:- +full:evienb
1 // SPDX-License-Identifier: GPL-2.0-or-later
43 #define ISL1219_REG_EV_EVIENB (1<<7) /* event in pull-up disable */
182 return -ENODEV; in isl1208_i2c_validate_client()
239 return -EIO; in isl1208_i2c_get_dtr()
241 /* dtr encodes adjustments of {-60,-40,-20,0,20,40,60} ppm */ in isl1208_i2c_get_dtr()
242 dtr = ((dtr & 0x3) * 20) * (dtr & (1 << 2) ? -1 : 1); in isl1208_i2c_get_dtr()
279 dev_err(&client->dev, "%s: reading INT failed\n", __func__); in isl1208_rtc_toggle_alarm()
290 dev_err(&client->dev, "%s: writing INT failed\n", __func__); in isl1208_rtc_toggle_alarm()
305 dev_err(&client->dev, "%s: reading SR failed\n", __func__); in isl1208_rtc_proc()
322 seq_printf(seq, "digital_trim\t: %d ppm\n", dtr - 100); in isl1208_rtc_proc()
344 dev_err(&client->dev, "%s: reading SR failed\n", __func__); in isl1208_i2c_read_time()
345 return -EIO; in isl1208_i2c_read_time()
350 dev_err(&client->dev, "%s: reading RTC section failed\n", in isl1208_i2c_read_time()
355 tm->tm_sec = bcd2bin(regs[ISL1208_REG_SC]); in isl1208_i2c_read_time()
356 tm->tm_min = bcd2bin(regs[ISL1208_REG_MN]); in isl1208_i2c_read_time()
362 tm->tm_hour = bcd2bin(_hr & 0x3f); in isl1208_i2c_read_time()
365 tm->tm_hour = bcd2bin(_hr & 0x1f); in isl1208_i2c_read_time()
367 tm->tm_hour += 12; in isl1208_i2c_read_time()
371 tm->tm_mday = bcd2bin(regs[ISL1208_REG_DT]); in isl1208_i2c_read_time()
372 tm->tm_mon = bcd2bin(regs[ISL1208_REG_MO]) - 1; /* rtc starts at 1 */ in isl1208_i2c_read_time()
373 tm->tm_year = bcd2bin(regs[ISL1208_REG_YR]) + 100; in isl1208_i2c_read_time()
374 tm->tm_wday = bcd2bin(regs[ISL1208_REG_DW]); in isl1208_i2c_read_time()
382 struct rtc_time *const tm = &alarm->time; in isl1208_i2c_read_alarm()
387 dev_err(&client->dev, "%s: reading SR failed\n", __func__); in isl1208_i2c_read_alarm()
394 dev_err(&client->dev, "%s: reading alarm section failed\n", in isl1208_i2c_read_alarm()
400 tm->tm_sec = bcd2bin(regs[ISL1208_REG_SCA - ISL1208_REG_SCA] & 0x7f); in isl1208_i2c_read_alarm()
401 tm->tm_min = bcd2bin(regs[ISL1208_REG_MNA - ISL1208_REG_SCA] & 0x7f); in isl1208_i2c_read_alarm()
402 tm->tm_hour = bcd2bin(regs[ISL1208_REG_HRA - ISL1208_REG_SCA] & 0x3f); in isl1208_i2c_read_alarm()
403 tm->tm_mday = bcd2bin(regs[ISL1208_REG_DTA - ISL1208_REG_SCA] & 0x3f); in isl1208_i2c_read_alarm()
404 tm->tm_mon = in isl1208_i2c_read_alarm()
405 bcd2bin(regs[ISL1208_REG_MOA - ISL1208_REG_SCA] & 0x1f) - 1; in isl1208_i2c_read_alarm()
406 tm->tm_wday = bcd2bin(regs[ISL1208_REG_DWA - ISL1208_REG_SCA] & 0x03); in isl1208_i2c_read_alarm()
411 dev_err(&client->dev, "%s: reading RTC YR failed\n", __func__); in isl1208_i2c_read_alarm()
414 tm->tm_year = bcd2bin(yr) + 100; in isl1208_i2c_read_alarm()
418 dev_err(&client->dev, "%s: reading INT failed\n", __func__); in isl1208_i2c_read_alarm()
421 alarm->enabled = !!(icr & ISL1208_REG_INT_ALME); in isl1208_i2c_read_alarm()
429 struct rtc_time *alarm_tm = &alarm->time; in isl1208_i2c_set_alarm()
440 if (!alarm->enabled || rtc_tm_sub(alarm_tm, &rtc_tm) <= 0) in isl1208_i2c_set_alarm()
446 regs[ISL1208_REG_SCA - offs] = bin2bcd(alarm_tm->tm_sec) | enable; in isl1208_i2c_set_alarm()
447 regs[ISL1208_REG_MNA - offs] = bin2bcd(alarm_tm->tm_min) | enable; in isl1208_i2c_set_alarm()
448 regs[ISL1208_REG_HRA - offs] = bin2bcd(alarm_tm->tm_hour) | in isl1208_i2c_set_alarm()
451 regs[ISL1208_REG_DTA - offs] = bin2bcd(alarm_tm->tm_mday) | enable; in isl1208_i2c_set_alarm()
452 regs[ISL1208_REG_MOA - offs] = bin2bcd(alarm_tm->tm_mon + 1) | enable; in isl1208_i2c_set_alarm()
453 regs[ISL1208_REG_DWA - offs] = bin2bcd(alarm_tm->tm_wday & 7) | enable; in isl1208_i2c_set_alarm()
459 dev_err(&client->dev, "%s: writing ALARM section failed\n", in isl1208_i2c_set_alarm()
483 /* The clock has an 8 bit wide bcd-coded register (they never learn) in isl1208_i2c_set_time()
485 * in the 2000-2099 range, so any value less than 100 is invalid. in isl1208_i2c_set_time()
487 if (tm->tm_year < 100) in isl1208_i2c_set_time()
488 return -EINVAL; in isl1208_i2c_set_time()
490 regs[ISL1208_REG_SC] = bin2bcd(tm->tm_sec); in isl1208_i2c_set_time()
491 regs[ISL1208_REG_MN] = bin2bcd(tm->tm_min); in isl1208_i2c_set_time()
492 regs[ISL1208_REG_HR] = bin2bcd(tm->tm_hour) | ISL1208_REG_HR_MIL; in isl1208_i2c_set_time()
494 regs[ISL1208_REG_DT] = bin2bcd(tm->tm_mday); in isl1208_i2c_set_time()
495 regs[ISL1208_REG_MO] = bin2bcd(tm->tm_mon + 1); in isl1208_i2c_set_time()
496 regs[ISL1208_REG_YR] = bin2bcd(tm->tm_year - 100); in isl1208_i2c_set_time()
498 regs[ISL1208_REG_DW] = bin2bcd(tm->tm_wday & 7); in isl1208_i2c_set_time()
502 dev_err(&client->dev, "%s: reading SR failed\n", __func__); in isl1208_i2c_set_time()
510 dev_err(&client->dev, "%s: writing SR failed\n", __func__); in isl1208_i2c_set_time()
517 dev_err(&client->dev, "%s: writing RTC section failed\n", in isl1208_i2c_set_time()
525 dev_err(&client->dev, "%s: reading SR failed\n", __func__); in isl1208_i2c_set_time()
531 dev_err(&client->dev, "%s: writing SR failed\n", __func__); in isl1208_i2c_set_time()
560 struct i2c_client *client = to_i2c_client(dev->parent); in timestamp0_store()
582 struct i2c_client *client = to_i2c_client(dev->parent); in timestamp0_show()
605 tm.tm_sec = bcd2bin(regs[ISL1219_REG_SCT - ISL1219_REG_SCT] & 0x7f); in timestamp0_show()
606 tm.tm_min = bcd2bin(regs[ISL1219_REG_MNT - ISL1219_REG_SCT] & 0x7f); in timestamp0_show()
607 tm.tm_hour = bcd2bin(regs[ISL1219_REG_HRT - ISL1219_REG_SCT] & 0x3f); in timestamp0_show()
608 tm.tm_mday = bcd2bin(regs[ISL1219_REG_DTT - ISL1219_REG_SCT] & 0x3f); in timestamp0_show()
610 bcd2bin(regs[ISL1219_REG_MOT - ISL1219_REG_SCT] & 0x1f) - 1; in timestamp0_show()
611 tm.tm_year = bcd2bin(regs[ISL1219_REG_YRT - ISL1219_REG_SCT]) + 100; in timestamp0_show()
642 dev_err(&client->dev, "%s: reading SR failed\n", in isl1208_rtc_interrupt()
649 dev_dbg(&client->dev, "alarm!\n"); in isl1208_rtc_interrupt()
651 rtc_update_irq(isl1208->rtc, 1, RTC_IRQF | RTC_AF); in isl1208_rtc_interrupt()
657 dev_err(&client->dev, "%s: writing SR failed\n", in isl1208_rtc_interrupt()
668 if (isl1208->config->has_tamper && (sr & ISL1208_REG_SR_EVT)) { in isl1208_rtc_interrupt()
669 dev_warn(&client->dev, "event detected"); in isl1208_rtc_interrupt()
671 if (isl1208->config->has_timestamp) in isl1208_rtc_interrupt()
672 sysfs_notify(&isl1208->rtc->dev.kobj, NULL, in isl1208_rtc_interrupt()
693 int atr = isl1208_i2c_get_atr(to_i2c_client(dev->parent)); in isl1208_sysfs_show_atrim()
706 int dtr = isl1208_i2c_get_dtr(to_i2c_client(dev->parent)); in isl1208_sysfs_show_dtrim()
710 return sprintf(buf, "%d ppm\n", dtr - 100); in isl1208_sysfs_show_dtrim()
719 int usr = isl1208_i2c_get_usr(to_i2c_client(dev->parent)); in isl1208_sysfs_show_usr()
731 int usr = -1; in isl1208_sysfs_store_usr()
735 return -EINVAL; in isl1208_sysfs_store_usr()
738 return -EINVAL; in isl1208_sysfs_store_usr()
742 return -EINVAL; in isl1208_sysfs_store_usr()
744 if (isl1208_i2c_set_usr(to_i2c_client(dev->parent), usr)) in isl1208_sysfs_store_usr()
745 return -EIO; in isl1208_sysfs_store_usr()
777 struct i2c_client *client = to_i2c_client(isl1208->rtc->dev.parent); in isl1208_nvmem_read()
791 struct i2c_client *client = to_i2c_client(isl1208->rtc->dev.parent); in isl1208_nvmem_write()
812 int rc = devm_request_threaded_irq(&client->dev, irq, NULL, in isl1208_setup_irq()
818 device_init_wakeup(&client->dev, 1); in isl1208_setup_irq()
821 dev_err(&client->dev, in isl1208_setup_irq()
833 clk = devm_clk_get_optional(&client->dev, name); in isl1208_clk_present()
844 int evdet_irq = -1; in isl1208_probe()
849 if (!i2c_check_functionality(client->adapter, I2C_FUNC_I2C)) in isl1208_probe()
850 return -ENODEV; in isl1208_probe()
853 return -ENODEV; in isl1208_probe()
856 isl1208 = devm_kzalloc(&client->dev, sizeof(*isl1208), GFP_KERNEL); in isl1208_probe()
858 return -ENOMEM; in isl1208_probe()
862 isl1208->config = i2c_get_match_data(client); in isl1208_probe()
863 if (!isl1208->config) in isl1208_probe()
864 return -ENODEV; in isl1208_probe()
879 isl1208->rtc = devm_rtc_allocate_device(&client->dev); in isl1208_probe()
880 if (IS_ERR(isl1208->rtc)) in isl1208_probe()
881 return PTR_ERR(isl1208->rtc); in isl1208_probe()
883 isl1208->rtc->ops = &isl1208_rtc_ops; in isl1208_probe()
886 isl1208->nvmem_config = isl1208_nvmem_config; in isl1208_probe()
887 isl1208->nvmem_config.size = isl1208->config->nvmem_length; in isl1208_probe()
888 isl1208->nvmem_config.priv = isl1208; in isl1208_probe()
892 dev_err(&client->dev, "reading status failed\n"); in isl1208_probe()
896 if (isl1208->config->has_inverted_osc_bit) in isl1208_probe()
904 dev_warn(&client->dev, "rtc power failure detected, " in isl1208_probe()
907 if (isl1208->config->has_tamper) { in isl1208_probe()
908 struct device_node *np = client->dev.of_node; in isl1208_probe()
909 u32 evienb; in isl1208_probe() local
913 dev_err(&client->dev, "failed to read EV reg\n"); in isl1208_probe()
917 if (!of_property_read_u32(np, "isil,ev-evienb", &evienb)) { in isl1208_probe()
918 if (evienb) in isl1208_probe()
925 dev_err(&client->dev, "could not enable tamper detection\n"); in isl1208_probe()
930 if (isl1208->config->has_timestamp) { in isl1208_probe()
931 rc = rtc_add_group(isl1208->rtc, &isl1219_rtc_sysfs_files); in isl1208_probe()
936 rc = rtc_add_group(isl1208->rtc, &isl1208_rtc_sysfs_files); in isl1208_probe()
940 if (client->irq > 0) { in isl1208_probe()
941 rc = isl1208_setup_irq(client, client->irq); in isl1208_probe()
945 clear_bit(RTC_FEATURE_UPDATE_INTERRUPT, isl1208->rtc->features); in isl1208_probe()
948 if (evdet_irq > 0 && evdet_irq != client->irq) in isl1208_probe()
953 rc = devm_rtc_nvmem_register(isl1208->rtc, &isl1208->nvmem_config); in isl1208_probe()
957 return devm_rtc_register_device(isl1208->rtc); in isl1208_probe()
962 .name = "rtc-isl1208",