Lines Matching refs:pcf85063

66 struct pcf85063 {  struct
76 struct pcf85063 *pcf85063 = dev_get_drvdata(dev); in pcf85063_rtc_read_time() argument
86 rc = regmap_bulk_read(pcf85063->regmap, PCF85063_REG_SC, regs, in pcf85063_rtc_read_time()
93 dev_warn(&pcf85063->rtc->dev, "Power loss detected, invalid time\n"); in pcf85063_rtc_read_time()
111 struct pcf85063 *pcf85063 = dev_get_drvdata(dev); in pcf85063_rtc_set_time() local
119 rc = regmap_update_bits(pcf85063->regmap, PCF85063_REG_CTRL1, in pcf85063_rtc_set_time()
144 rc = regmap_bulk_write(pcf85063->regmap, PCF85063_REG_SC, in pcf85063_rtc_set_time()
154 return regmap_update_bits(pcf85063->regmap, PCF85063_REG_CTRL1, in pcf85063_rtc_set_time()
160 struct pcf85063 *pcf85063 = dev_get_drvdata(dev); in pcf85063_rtc_read_alarm() local
165 ret = regmap_bulk_read(pcf85063->regmap, PCF85063_REG_ALM_S, in pcf85063_rtc_read_alarm()
175 ret = regmap_read(pcf85063->regmap, PCF85063_REG_CTRL2, &val); in pcf85063_rtc_read_alarm()
186 struct pcf85063 *pcf85063 = dev_get_drvdata(dev); in pcf85063_rtc_set_alarm() local
196 ret = regmap_update_bits(pcf85063->regmap, PCF85063_REG_CTRL2, in pcf85063_rtc_set_alarm()
201 ret = regmap_bulk_write(pcf85063->regmap, PCF85063_REG_ALM_S, in pcf85063_rtc_set_alarm()
206 return regmap_update_bits(pcf85063->regmap, PCF85063_REG_CTRL2, in pcf85063_rtc_set_alarm()
214 struct pcf85063 *pcf85063 = dev_get_drvdata(dev); in pcf85063_rtc_alarm_irq_enable() local
216 return regmap_update_bits(pcf85063->regmap, PCF85063_REG_CTRL2, in pcf85063_rtc_alarm_irq_enable()
223 struct pcf85063 *pcf85063 = dev_id; in pcf85063_rtc_handle_irq() local
227 err = regmap_read(pcf85063->regmap, PCF85063_REG_CTRL2, &val); in pcf85063_rtc_handle_irq()
232 rtc_update_irq(pcf85063->rtc, 1, RTC_IRQF | RTC_AF); in pcf85063_rtc_handle_irq()
233 regmap_update_bits(pcf85063->regmap, PCF85063_REG_CTRL2, in pcf85063_rtc_handle_irq()
244 struct pcf85063 *pcf85063 = dev_get_drvdata(dev); in pcf85063_read_offset() local
249 ret = regmap_read(pcf85063->regmap, PCF85063_REG_OFFSET, &reg); in pcf85063_read_offset()
266 struct pcf85063 *pcf85063 = dev_get_drvdata(dev); in pcf85063_set_offset() local
285 return regmap_write(pcf85063->regmap, PCF85063_REG_OFFSET, reg); in pcf85063_set_offset()
291 struct pcf85063 *pcf85063 = dev_get_drvdata(dev); in pcf85063_ioctl() local
296 ret = regmap_read(pcf85063->regmap, PCF85063_REG_SC, &status); in pcf85063_ioctl()
340 static int pcf85063_load_capacitance(struct pcf85063 *pcf85063, in pcf85063_load_capacitance() argument
354 dev_warn(&pcf85063->rtc->dev, "Unknown quartz-load-femtofarads value: %d. Assuming 7000", in pcf85063_load_capacitance()
364 return regmap_update_bits(pcf85063->regmap, PCF85063_REG_CTRL1, in pcf85063_load_capacitance()
373 #define clkout_hw_to_pcf85063(_hw) container_of(_hw, struct pcf85063, clkout_hw)
389 struct pcf85063 *pcf85063 = clkout_hw_to_pcf85063(hw); in pcf85063_clkout_recalc_rate() local
391 int ret = regmap_read(pcf85063->regmap, PCF85063_REG_CTRL2, &buf); in pcf85063_clkout_recalc_rate()
415 struct pcf85063 *pcf85063 = clkout_hw_to_pcf85063(hw); in pcf85063_clkout_set_rate() local
420 return regmap_update_bits(pcf85063->regmap, in pcf85063_clkout_set_rate()
429 struct pcf85063 *pcf85063 = clkout_hw_to_pcf85063(hw); in pcf85063_clkout_control() local
433 ret = regmap_read(pcf85063->regmap, PCF85063_REG_OFFSET, &buf); in pcf85063_clkout_control()
450 return regmap_update_bits(pcf85063->regmap, PCF85063_REG_CTRL2, in pcf85063_clkout_control()
466 struct pcf85063 *pcf85063 = clkout_hw_to_pcf85063(hw); in pcf85063_clkout_is_prepared() local
468 int ret = regmap_read(pcf85063->regmap, PCF85063_REG_CTRL2, &buf); in pcf85063_clkout_is_prepared()
485 static struct clk *pcf85063_clkout_register_clk(struct pcf85063 *pcf85063) in pcf85063_clkout_register_clk() argument
489 struct device_node *node = pcf85063->rtc->dev.parent->of_node; in pcf85063_clkout_register_clk()
496 pcf85063->clkout_hw.init = &init; in pcf85063_clkout_register_clk()
502 clk = devm_clk_register(&pcf85063->rtc->dev, &pcf85063->clkout_hw); in pcf85063_clkout_register_clk()
540 struct pcf85063 *pcf85063; in pcf85063_probe() local
555 pcf85063 = devm_kzalloc(&client->dev, sizeof(struct pcf85063), in pcf85063_probe()
557 if (!pcf85063) in pcf85063_probe()
563 pcf85063->regmap = devm_regmap_init_i2c(client, &config->regmap); in pcf85063_probe()
564 if (IS_ERR(pcf85063->regmap)) in pcf85063_probe()
565 return PTR_ERR(pcf85063->regmap); in pcf85063_probe()
567 i2c_set_clientdata(client, pcf85063); in pcf85063_probe()
569 err = regmap_read(pcf85063->regmap, PCF85063_REG_CTRL1, &tmp); in pcf85063_probe()
575 pcf85063->rtc = devm_rtc_allocate_device(&client->dev); in pcf85063_probe()
576 if (IS_ERR(pcf85063->rtc)) in pcf85063_probe()
577 return PTR_ERR(pcf85063->rtc); in pcf85063_probe()
579 err = pcf85063_load_capacitance(pcf85063, client->dev.of_node, in pcf85063_probe()
585 pcf85063->rtc->ops = &pcf85063_rtc_ops; in pcf85063_probe()
586 pcf85063->rtc->range_min = RTC_TIMESTAMP_BEGIN_2000; in pcf85063_probe()
587 pcf85063->rtc->range_max = RTC_TIMESTAMP_END_2099; in pcf85063_probe()
588 pcf85063->rtc->uie_unsupported = 1; in pcf85063_probe()
594 "pcf85063", pcf85063); in pcf85063_probe()
596 dev_warn(&pcf85063->rtc->dev, in pcf85063_probe()
599 pcf85063->rtc->ops = &pcf85063_rtc_ops_alarm; in pcf85063_probe()
603 dev_err(&pcf85063->rtc->dev, in pcf85063_probe()
608 nvmem_cfg.priv = pcf85063->regmap; in pcf85063_probe()
609 rtc_nvmem_register(pcf85063->rtc, &nvmem_cfg); in pcf85063_probe()
613 pcf85063_clkout_register_clk(pcf85063); in pcf85063_probe()
616 return rtc_register_device(pcf85063->rtc); in pcf85063_probe()