@@ -464,6 +464,27 @@ static int set_clk_mode(struct device *dev, struct regmap *regmap,
464
464
OUT32K_MODE_CMOS );
465
465
}
466
466
467
+ static struct i2c_client * bd71828_dev ;
468
+ static void bd71828_power_off (void )
469
+ {
470
+ while (true) {
471
+ s32 val ;
472
+
473
+ /* We are not allowed to sleep, so do not use regmap involving mutexes here. */
474
+ val = i2c_smbus_read_byte_data (bd71828_dev , BD71828_REG_PS_CTRL_1 );
475
+ if (val >= 0 )
476
+ i2c_smbus_write_byte_data (bd71828_dev ,
477
+ BD71828_REG_PS_CTRL_1 ,
478
+ BD71828_MASK_STATE_HBNT | (u8 )val );
479
+ mdelay (500 );
480
+ }
481
+ }
482
+
483
+ static void bd71828_remove_poweroff (void * data )
484
+ {
485
+ pm_power_off = NULL ;
486
+ }
487
+
467
488
static int bd71828_i2c_probe (struct i2c_client * i2c )
468
489
{
469
490
struct regmap_irq_chip_data * irq_data ;
@@ -542,7 +563,20 @@ static int bd71828_i2c_probe(struct i2c_client *i2c)
542
563
ret = devm_mfd_add_devices (& i2c -> dev , PLATFORM_DEVID_AUTO , mfd , cells ,
543
564
NULL , 0 , regmap_irq_get_domain (irq_data ));
544
565
if (ret )
545
- dev_err_probe (& i2c -> dev , ret , "Failed to create subdevices\n" );
566
+ return dev_err_probe (& i2c -> dev , ret , "Failed to create subdevices\n" );
567
+
568
+ if (of_device_is_system_power_controller (i2c -> dev .of_node ) &&
569
+ chip_type == ROHM_CHIP_TYPE_BD71828 ) {
570
+ if (!pm_power_off ) {
571
+ bd71828_dev = i2c ;
572
+ pm_power_off = bd71828_power_off ;
573
+ ret = devm_add_action_or_reset (& i2c -> dev ,
574
+ bd71828_remove_poweroff ,
575
+ NULL );
576
+ } else {
577
+ dev_warn (& i2c -> dev , "Poweroff callback already assigned\n" );
578
+ }
579
+ }
546
580
547
581
return ret ;
548
582
}
0 commit comments