Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

rtc: max31335: Add driver support for max31331

MAX31331 is an ultra-low-power, I2C Real-Time Clock RTC.

Signed-off-by: PavithraUdayakumar-adi <pavithra.u@analog.com>
Link: https://lore.kernel.org/r/20250217-add_support_max31331_fix_8-v1-2-16ebcfc02336@analog.com
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>

authored by

PavithraUdayakumar-adi and committed by
Alexandre Belloni
a4193578 fe135955

+122 -43
+122 -43
drivers/rtc/rtc-max31335.c
··· 184 184 #define MAX31335_RAM_SIZE 32 185 185 #define MAX31335_TIME_SIZE 0x07 186 186 187 + /* MAX31331 Register Map */ 188 + #define MAX31331_RTC_CONFIG2 0x04 189 + 187 190 #define clk_hw_to_max31335(_hw) container_of(_hw, struct max31335_data, clkout) 191 + 192 + /* Supported Maxim RTC */ 193 + enum max_rtc_ids { 194 + ID_MAX31331, 195 + ID_MAX31335, 196 + MAX_RTC_ID_NR 197 + }; 198 + 199 + struct chip_desc { 200 + u8 sec_reg; 201 + u8 alarm1_sec_reg; 202 + 203 + u8 int_en_reg; 204 + u8 int_status_reg; 205 + 206 + u8 ram_reg; 207 + u8 ram_size; 208 + 209 + u8 temp_reg; 210 + 211 + u8 trickle_reg; 212 + 213 + u8 clkout_reg; 214 + 215 + enum max_rtc_ids id; 216 + }; 188 217 189 218 struct max31335_data { 190 219 struct regmap *regmap; 191 220 struct rtc_device *rtc; 192 221 struct clk_hw clkout; 222 + struct clk *clkin; 223 + const struct chip_desc *chip; 224 + int irq; 193 225 }; 194 226 195 227 static const int max31335_clkout_freq[] = { 1, 64, 1024, 32768 }; 228 + 229 + static const struct chip_desc chip[MAX_RTC_ID_NR] = { 230 + [ID_MAX31331] = { 231 + .id = ID_MAX31331, 232 + .int_en_reg = 0x01, 233 + .int_status_reg = 0x00, 234 + .sec_reg = 0x08, 235 + .alarm1_sec_reg = 0x0F, 236 + .ram_reg = 0x20, 237 + .ram_size = 32, 238 + .trickle_reg = 0x1B, 239 + .clkout_reg = 0x04, 240 + }, 241 + [ID_MAX31335] = { 242 + .id = ID_MAX31335, 243 + .int_en_reg = 0x01, 244 + .int_status_reg = 0x00, 245 + .sec_reg = 0x0A, 246 + .alarm1_sec_reg = 0x11, 247 + .ram_reg = 0x40, 248 + .ram_size = 32, 249 + .temp_reg = 0x35, 250 + .trickle_reg = 0x1D, 251 + .clkout_reg = 0x06, 252 + }, 253 + }; 196 254 197 255 static const u16 max31335_trickle_resistors[] = {3000, 6000, 11000}; 198 256 199 257 static bool max31335_volatile_reg(struct device *dev, unsigned int reg) 200 258 { 259 + struct max31335_data *max31335 = dev_get_drvdata(dev); 260 + const struct chip_desc *chip = max31335->chip; 261 + 201 262 /* time keeping registers */ 202 - if (reg >= MAX31335_SECONDS && 203 - reg < MAX31335_SECONDS + MAX31335_TIME_SIZE) 263 + if (reg >= chip->sec_reg && reg < chip->sec_reg + MAX31335_TIME_SIZE) 204 264 return true; 205 265 206 266 /* interrupt status register */ 207 - if (reg == MAX31335_STATUS1) 267 + if (reg == chip->int_status_reg) 208 268 return true; 209 269 210 - /* temperature registers */ 211 - if (reg == MAX31335_TEMP_DATA_MSB || reg == MAX31335_TEMP_DATA_LSB) 270 + /* temperature registers if valid */ 271 + if (chip->temp_reg && (reg == chip->temp_reg || reg == chip->temp_reg + 1)) 212 272 return true; 213 273 214 274 return false; ··· 287 227 u8 date[7]; 288 228 int ret; 289 229 290 - ret = regmap_bulk_read(max31335->regmap, MAX31335_SECONDS, date, 230 + ret = regmap_bulk_read(max31335->regmap, max31335->chip->sec_reg, date, 291 231 sizeof(date)); 292 232 if (ret) 293 233 return ret; ··· 322 262 if (tm->tm_year >= 200) 323 263 date[5] |= FIELD_PREP(MAX31335_MONTH_CENTURY, 1); 324 264 325 - return regmap_bulk_write(max31335->regmap, MAX31335_SECONDS, date, 265 + return regmap_bulk_write(max31335->regmap, max31335->chip->sec_reg, date, 326 266 sizeof(date)); 327 267 } 328 268 ··· 333 273 struct rtc_time time; 334 274 u8 regs[6]; 335 275 336 - ret = regmap_bulk_read(max31335->regmap, MAX31335_ALM1_SEC, regs, 276 + ret = regmap_bulk_read(max31335->regmap, max31335->chip->alarm1_sec_reg, regs, 337 277 sizeof(regs)); 338 278 if (ret) 339 279 return ret; ··· 352 292 if (time.tm_year >= 200) 353 293 alrm->time.tm_year += 100; 354 294 355 - ret = regmap_read(max31335->regmap, MAX31335_INT_EN1, &ctrl); 295 + ret = regmap_read(max31335->regmap, max31335->chip->int_en_reg, &ctrl); 356 296 if (ret) 357 297 return ret; 358 298 359 - ret = regmap_read(max31335->regmap, MAX31335_STATUS1, &status); 299 + ret = regmap_read(max31335->regmap, max31335->chip->int_status_reg, &status); 360 300 if (ret) 361 301 return ret; 362 302 ··· 380 320 regs[4] = bin2bcd(alrm->time.tm_mon + 1); 381 321 regs[5] = bin2bcd(alrm->time.tm_year % 100); 382 322 383 - ret = regmap_bulk_write(max31335->regmap, MAX31335_ALM1_SEC, 323 + ret = regmap_bulk_write(max31335->regmap, max31335->chip->alarm1_sec_reg, 384 324 regs, sizeof(regs)); 385 325 if (ret) 386 326 return ret; 387 327 388 328 reg = FIELD_PREP(MAX31335_INT_EN1_A1IE, alrm->enabled); 389 - ret = regmap_update_bits(max31335->regmap, MAX31335_INT_EN1, 329 + ret = regmap_update_bits(max31335->regmap, max31335->chip->int_en_reg, 390 330 MAX31335_INT_EN1_A1IE, reg); 391 331 if (ret) 392 332 return ret; 393 333 394 - ret = regmap_update_bits(max31335->regmap, MAX31335_STATUS1, 334 + ret = regmap_update_bits(max31335->regmap, max31335->chip->int_status_reg, 395 335 MAX31335_STATUS1_A1F, 0); 396 336 397 337 return 0; ··· 401 341 { 402 342 struct max31335_data *max31335 = dev_get_drvdata(dev); 403 343 404 - return regmap_update_bits(max31335->regmap, MAX31335_INT_EN1, 344 + return regmap_update_bits(max31335->regmap, max31335->chip->int_en_reg, 405 345 MAX31335_INT_EN1_A1IE, enabled); 406 346 } 407 347 408 348 static irqreturn_t max31335_handle_irq(int irq, void *dev_id) 409 349 { 410 350 struct max31335_data *max31335 = dev_id; 411 - bool status; 412 - int ret; 351 + struct mutex *lock = &max31335->rtc->ops_lock; 352 + int ret, status; 413 353 414 - ret = regmap_update_bits_check(max31335->regmap, MAX31335_STATUS1, 415 - MAX31335_STATUS1_A1F, 0, &status); 354 + mutex_lock(lock); 355 + 356 + ret = regmap_read(max31335->regmap, max31335->chip->int_status_reg, &status); 416 357 if (ret) 417 - return IRQ_HANDLED; 358 + goto exit; 418 359 419 - if (status) 360 + if (FIELD_GET(MAX31335_STATUS1_A1F, status)) { 361 + ret = regmap_update_bits(max31335->regmap, max31335->chip->int_status_reg, 362 + MAX31335_STATUS1_A1F, 0); 363 + if (ret) 364 + goto exit; 365 + 420 366 rtc_update_irq(max31335->rtc, 1, RTC_AF | RTC_IRQF); 367 + } 368 + 369 + exit: 370 + mutex_unlock(lock); 421 371 422 372 return IRQ_HANDLED; 423 373 } ··· 474 404 475 405 i = i + trickle_cfg; 476 406 477 - return regmap_write(max31335->regmap, MAX31335_TRICKLE_REG, 407 + return regmap_write(max31335->regmap, max31335->chip->trickle_reg, 478 408 FIELD_PREP(MAX31335_TRICKLE_REG_TRICKLE, i) | 479 409 FIELD_PREP(MAX31335_TRICKLE_REG_EN_TRICKLE, 480 410 chargeable)); ··· 488 418 unsigned int reg; 489 419 int ret; 490 420 491 - ret = regmap_read(max31335->regmap, MAX31335_RTC_CONFIG2, &reg); 421 + ret = regmap_read(max31335->regmap, max31335->chip->clkout_reg, &reg); 492 422 if (ret) 493 423 return 0; 494 424 ··· 519 449 ARRAY_SIZE(max31335_clkout_freq)); 520 450 freq_mask = __roundup_pow_of_two(ARRAY_SIZE(max31335_clkout_freq)) - 1; 521 451 522 - return regmap_update_bits(max31335->regmap, MAX31335_RTC_CONFIG2, 523 - freq_mask, index); 452 + return regmap_update_bits(max31335->regmap, max31335->chip->clkout_reg, 453 + freq_mask, index); 524 454 } 525 455 526 456 static int max31335_clkout_enable(struct clk_hw *hw) 527 457 { 528 458 struct max31335_data *max31335 = clk_hw_to_max31335(hw); 529 459 530 - return regmap_set_bits(max31335->regmap, MAX31335_RTC_CONFIG2, 531 - MAX31335_RTC_CONFIG2_ENCLKO); 460 + return regmap_set_bits(max31335->regmap, max31335->chip->clkout_reg, 461 + MAX31335_RTC_CONFIG2_ENCLKO); 532 462 } 533 463 534 464 static void max31335_clkout_disable(struct clk_hw *hw) 535 465 { 536 466 struct max31335_data *max31335 = clk_hw_to_max31335(hw); 537 467 538 - regmap_clear_bits(max31335->regmap, MAX31335_RTC_CONFIG2, 468 + regmap_clear_bits(max31335->regmap, max31335->chip->clkout_reg, 539 469 MAX31335_RTC_CONFIG2_ENCLKO); 540 470 } 541 471 ··· 545 475 unsigned int reg; 546 476 int ret; 547 477 548 - ret = regmap_read(max31335->regmap, MAX31335_RTC_CONFIG2, &reg); 478 + ret = regmap_read(max31335->regmap, max31335->chip->clkout_reg, &reg); 549 479 if (ret) 550 480 return ret; 551 481 ··· 570 500 void *val, size_t bytes) 571 501 { 572 502 struct max31335_data *max31335 = priv; 573 - unsigned int reg = MAX31335_TS0_SEC_1_128 + offset; 503 + unsigned int reg = max31335->chip->ram_reg + offset; 574 504 575 505 return regmap_bulk_read(max31335->regmap, reg, val, bytes); 576 506 } ··· 579 509 void *val, size_t bytes) 580 510 { 581 511 struct max31335_data *max31335 = priv; 582 - unsigned int reg = MAX31335_TS0_SEC_1_128 + offset; 512 + unsigned int reg = max31335->chip->ram_reg + offset; 583 513 584 514 return regmap_bulk_write(max31335->regmap, reg, val, bytes); 585 515 } ··· 603 533 if (type != hwmon_temp || attr != hwmon_temp_input) 604 534 return -EOPNOTSUPP; 605 535 606 - ret = regmap_bulk_read(max31335->regmap, MAX31335_TEMP_DATA_MSB, 536 + ret = regmap_bulk_read(max31335->regmap, max31335->chip->temp_reg, 607 537 reg, 2); 608 538 if (ret) 609 539 return ret; ··· 647 577 int ret; 648 578 649 579 if (!device_property_present(dev, "#clock-cells")) 650 - return regmap_clear_bits(max31335->regmap, MAX31335_RTC_CONFIG2, 651 - MAX31335_RTC_CONFIG2_ENCLKO); 580 + return regmap_clear_bits(max31335->regmap, max31335->chip->clkout_reg, 581 + MAX31335_RTC_CONFIG2_ENCLKO); 652 582 653 583 max31335->clkout.init = &max31335_clk_init; 654 584 ··· 675 605 #if IS_REACHABLE(HWMON) 676 606 struct device *hwmon; 677 607 #endif 608 + const struct chip_desc *match; 678 609 int ret; 679 610 680 611 max31335 = devm_kzalloc(&client->dev, sizeof(*max31335), GFP_KERNEL); ··· 687 616 return PTR_ERR(max31335->regmap); 688 617 689 618 i2c_set_clientdata(client, max31335); 690 - 619 + match = i2c_get_match_data(client); 620 + if (!match) 621 + return -ENODEV; 622 + max31335->chip = match; 691 623 max31335->rtc = devm_rtc_allocate_device(&client->dev); 692 624 if (IS_ERR(max31335->rtc)) 693 625 return PTR_ERR(max31335->rtc); ··· 713 639 dev_warn(&client->dev, 714 640 "unable to request IRQ, alarm max31335 disabled\n"); 715 641 client->irq = 0; 642 + } else { 643 + max31335->irq = client->irq; 716 644 } 717 645 } 718 646 ··· 728 652 "cannot register rtc nvmem\n"); 729 653 730 654 #if IS_REACHABLE(HWMON) 731 - hwmon = devm_hwmon_device_register_with_info(&client->dev, client->name, 732 - max31335, 733 - &max31335_chip_info, 734 - NULL); 735 - if (IS_ERR(hwmon)) 736 - return dev_err_probe(&client->dev, PTR_ERR(hwmon), 737 - "cannot register hwmon device\n"); 655 + if (max31335->chip->temp_reg) { 656 + hwmon = devm_hwmon_device_register_with_info(&client->dev, client->name, max31335, 657 + &max31335_chip_info, NULL); 658 + if (IS_ERR(hwmon)) 659 + return dev_err_probe(&client->dev, PTR_ERR(hwmon), 660 + "cannot register hwmon device\n"); 661 + } 738 662 #endif 739 663 740 664 ret = max31335_trickle_charger_setup(&client->dev, max31335); ··· 745 669 } 746 670 747 671 static const struct i2c_device_id max31335_id[] = { 748 - { "max31335" }, 672 + { "max31331", (kernel_ulong_t)&chip[ID_MAX31331] }, 673 + { "max31335", (kernel_ulong_t)&chip[ID_MAX31335] }, 749 674 { } 750 675 }; 751 676 752 677 MODULE_DEVICE_TABLE(i2c, max31335_id); 753 678 754 679 static const struct of_device_id max31335_of_match[] = { 755 - { .compatible = "adi,max31335" }, 680 + { .compatible = "adi,max31331", .data = &chip[ID_MAX31331] }, 681 + { .compatible = "adi,max31335", .data = &chip[ID_MAX31335] }, 756 682 { } 757 683 }; 758 684 ··· 771 693 module_i2c_driver(max31335_driver); 772 694 773 695 MODULE_AUTHOR("Antoniu Miclaus <antoniu.miclaus@analog.com>"); 696 + MODULE_AUTHOR("Saket Kumar Purwar <Saket.Kumarpurwar@analog.com>"); 774 697 MODULE_DESCRIPTION("MAX31335 RTC driver"); 775 698 MODULE_LICENSE("GPL");