Lines Matching +full:haptic +full:- +full:driver

1 // SPDX-License-Identifier: GPL-2.0+
3 // MFD core driver for the Maxim MAX77843
14 #include <linux/mfd/max77693-common.h>
15 #include <linux/mfd/max77843-private.h>
21 .name = "max77843-muic",
22 .of_compatible = "maxim,max77843-muic",
24 .name = "max77843-regulator",
25 .of_compatible = "maxim,max77843-regulator",
27 .name = "max77843-charger",
28 .of_compatible = "maxim,max77843-charger"
30 .name = "max77843-fuelgauge",
31 .of_compatible = "maxim,max77843-fuelgauge",
33 .name = "max77843-haptic",
34 .of_compatible = "maxim,max77843-haptic",
72 max77843->i2c_chg = i2c_new_dummy_device(max77843->i2c->adapter, I2C_ADDR_CHG); in max77843_chg_init()
73 if (IS_ERR(max77843->i2c_chg)) { in max77843_chg_init()
74 dev_err(&max77843->i2c->dev, in max77843_chg_init()
76 return PTR_ERR(max77843->i2c_chg); in max77843_chg_init()
78 i2c_set_clientdata(max77843->i2c_chg, max77843); in max77843_chg_init()
80 max77843->regmap_chg = devm_regmap_init_i2c(max77843->i2c_chg, in max77843_chg_init()
82 if (IS_ERR(max77843->regmap_chg)) { in max77843_chg_init()
83 ret = PTR_ERR(max77843->regmap_chg); in max77843_chg_init()
90 i2c_unregister_device(max77843->i2c_chg); in max77843_chg_init()
102 max77843 = devm_kzalloc(&i2c->dev, sizeof(*max77843), GFP_KERNEL); in max77843_probe()
104 return -ENOMEM; in max77843_probe()
107 max77843->dev = &i2c->dev; in max77843_probe()
108 max77843->i2c = i2c; in max77843_probe()
109 max77843->irq = i2c->irq; in max77843_probe()
110 max77843->type = id->driver_data; in max77843_probe()
112 max77843->regmap = devm_regmap_init_i2c(i2c, in max77843_probe()
114 if (IS_ERR(max77843->regmap)) { in max77843_probe()
115 dev_err(&i2c->dev, "Failed to allocate topsys register map\n"); in max77843_probe()
116 return PTR_ERR(max77843->regmap); in max77843_probe()
119 ret = regmap_add_irq_chip(max77843->regmap, max77843->irq, in max77843_probe()
121 0, &max77843_irq_chip, &max77843->irq_data_topsys); in max77843_probe()
123 dev_err(&i2c->dev, "Failed to add TOPSYS IRQ chip\n"); in max77843_probe()
127 ret = regmap_read(max77843->regmap, in max77843_probe()
130 dev_err(&i2c->dev, "Failed to read PMIC ID\n"); in max77843_probe()
133 dev_info(&i2c->dev, "device ID: 0x%x\n", reg_data); in max77843_probe()
137 dev_err(&i2c->dev, "Failed to init Charger\n"); in max77843_probe()
141 ret = regmap_update_bits(max77843->regmap, in max77843_probe()
146 dev_err(&i2c->dev, "Failed to unmask interrupt source\n"); in max77843_probe()
150 ret = mfd_add_devices(max77843->dev, -1, max77843_devs, in max77843_probe()
153 dev_err(&i2c->dev, "Failed to add mfd device\n"); in max77843_probe()
157 device_init_wakeup(max77843->dev, true); in max77843_probe()
162 regmap_del_irq_chip(max77843->irq, max77843->irq_data_topsys); in max77843_probe()
182 disable_irq(max77843->irq); in max77843_suspend()
184 enable_irq_wake(max77843->irq); in max77843_suspend()
195 disable_irq_wake(max77843->irq); in max77843_resume()
196 enable_irq(max77843->irq); in max77843_resume()
204 .driver = {