提交 7c4bb81c 编写于 作者: L Linus Torvalds

Merge tag 'mfd-fixes-3.19' of git://git.kernel.org/pub/scm/linux/kernel/git/lee/mfd

Pull MFD fixes from Lee Jones:
 - Avoid platform ID collision in da9052
 - Skip caching volatile registers in tps65218
 - Use correct address base in tps65218
 - Repair deadlock on suspend in rtsx_usb

* tag 'mfd-fixes-3.19' of git://git.kernel.org/pub/scm/linux/kernel/git/lee/mfd:
  mfd: rtsx_usb: Fix runtime PM deadlock
  mfd: tps65218: Make INT1 our status_base register
  mfd: tps65218: Make INT[12] and STATUS registers volatile
  mfd: da9052-core: Fix platform-device id collision
...@@ -554,7 +554,8 @@ int da9052_device_init(struct da9052 *da9052, u8 chip_id) ...@@ -554,7 +554,8 @@ int da9052_device_init(struct da9052 *da9052, u8 chip_id)
return ret; return ret;
} }
ret = mfd_add_devices(da9052->dev, -1, da9052_subdev_info, ret = mfd_add_devices(da9052->dev, PLATFORM_DEVID_AUTO,
da9052_subdev_info,
ARRAY_SIZE(da9052_subdev_info), NULL, 0, NULL); ARRAY_SIZE(da9052_subdev_info), NULL, 0, NULL);
if (ret) { if (ret) {
dev_err(da9052->dev, "mfd_add_devices failed: %d\n", ret); dev_err(da9052->dev, "mfd_add_devices failed: %d\n", ret);
......
...@@ -681,21 +681,9 @@ static void rtsx_usb_disconnect(struct usb_interface *intf) ...@@ -681,21 +681,9 @@ static void rtsx_usb_disconnect(struct usb_interface *intf)
#ifdef CONFIG_PM #ifdef CONFIG_PM
static int rtsx_usb_suspend(struct usb_interface *intf, pm_message_t message) static int rtsx_usb_suspend(struct usb_interface *intf, pm_message_t message)
{ {
struct rtsx_ucr *ucr =
(struct rtsx_ucr *)usb_get_intfdata(intf);
dev_dbg(&intf->dev, "%s called with pm message 0x%04x\n", dev_dbg(&intf->dev, "%s called with pm message 0x%04x\n",
__func__, message.event); __func__, message.event);
/*
* Call to make sure LED is off during suspend to save more power.
* It is NOT a permanent state and could be turned on anytime later.
* Thus no need to call turn_on when resunming.
*/
mutex_lock(&ucr->dev_mutex);
rtsx_usb_turn_off_led(ucr);
mutex_unlock(&ucr->dev_mutex);
return 0; return 0;
} }
......
...@@ -125,10 +125,21 @@ int tps65218_clear_bits(struct tps65218 *tps, unsigned int reg, ...@@ -125,10 +125,21 @@ int tps65218_clear_bits(struct tps65218 *tps, unsigned int reg,
} }
EXPORT_SYMBOL_GPL(tps65218_clear_bits); EXPORT_SYMBOL_GPL(tps65218_clear_bits);
static const struct regmap_range tps65218_yes_ranges[] = {
regmap_reg_range(TPS65218_REG_INT1, TPS65218_REG_INT2),
regmap_reg_range(TPS65218_REG_STATUS, TPS65218_REG_STATUS),
};
static const struct regmap_access_table tps65218_volatile_table = {
.yes_ranges = tps65218_yes_ranges,
.n_yes_ranges = ARRAY_SIZE(tps65218_yes_ranges),
};
static struct regmap_config tps65218_regmap_config = { static struct regmap_config tps65218_regmap_config = {
.reg_bits = 8, .reg_bits = 8,
.val_bits = 8, .val_bits = 8,
.cache_type = REGCACHE_RBTREE, .cache_type = REGCACHE_RBTREE,
.volatile_table = &tps65218_volatile_table,
}; };
static const struct regmap_irq tps65218_irqs[] = { static const struct regmap_irq tps65218_irqs[] = {
...@@ -193,6 +204,7 @@ static struct regmap_irq_chip tps65218_irq_chip = { ...@@ -193,6 +204,7 @@ static struct regmap_irq_chip tps65218_irq_chip = {
.num_regs = 2, .num_regs = 2,
.mask_base = TPS65218_REG_INT_MASK1, .mask_base = TPS65218_REG_INT_MASK1,
.status_base = TPS65218_REG_INT1,
}; };
static const struct of_device_id of_tps65218_match_table[] = { static const struct of_device_id of_tps65218_match_table[] = {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册
新手
引导
客服 返回
顶部