mirror of
https://github.com/ukui/kernel.git
synced 2026-03-09 10:07:04 -07:00
Merge tag 'mfd-next-4.14' of git://git.kernel.org/pub/scm/linux/kernel/git/lee/mfd
Pull MFD updates from Lee Jones:
"New Drivers
- RK805 Power Management IC (PMIC)
- ROHM BD9571MWV-M MFD Power Management IC (PMIC)
- Texas Instruments TPS68470 Power Management IC (PMIC) & LEDs
New Device Support:
- Add support for HiSilicon Hi6421v530 to hi6421-pmic-core
- Add support for X-Powers AXP806 to axp20x
- Add support for X-Powers AXP813 to axp20x
- Add support for Intel Sunrise Point LPSS to intel-lpss-pci
New Functionality:
- Amend API to provide register layout; atmel-smc
Fix-ups:
- DT re-work; omap, nokia
- Header file location change {I2C => MFD}; dm355evm_msp, tps65010
- Fix chip ID formatting issue(s); rk808
- Optionally register touchscreen devices; da9052-core
- Documentation improvements; twl-core
- Constification; rtsx_pcr, ab8500-core, da9055-i2c, da9052-spi
- Drop unnecessary static declaration; max8925-i2c
- Kconfig changes (missing deps and remove module support)
- Slim down oversized licence statement; hi6421-pmic-core
- Use managed resources (devm_*); lp87565
- Supply proper error checking/handling; t7l66xb
Bug Fixes:
- Fix counter duplication issue; da9052-core
- Fix potential NULL deference issue; max8998
- Leave SPI-NOR write-protection bit alone; lpc_ich
- Ensure device is put into reset during suspend; intel-lpss
- Correct register offset variable size; omap-usb-tll"
* tag 'mfd-next-4.14' of git://git.kernel.org/pub/scm/linux/kernel/git/lee/mfd: (61 commits)
mfd: intel_soc_pmic: Differentiate between Bay and Cherry Trail CRC variants
mfd: intel_soc_pmic: Export separate mfd-cell configs for BYT and CHT
dt-bindings: mfd: Add bindings for ZII RAVE devices
mfd: omap-usb-tll: Fix register offsets
mfd: da9052: Constify spi_device_id
mfd: intel-lpss: Put I2C and SPI controllers into reset state on suspend
mfd: da9055: Constify i2c_device_id
mfd: intel-lpss: Add missing PCI ID for Intel Sunrise Point LPSS devices
mfd: t7l66xb: Handle return value of clk_prepare_enable
mfd: Add ROHM BD9571MWV-M PMIC DT bindings
mfd: intel_soc_pmic_chtwc: Turn Kconfig option into a bool
mfd: lp87565: Convert to use devm_mfd_add_devices()
mfd: Add support for TPS68470 device
mfd: lpc_ich: Do not touch SPI-NOR write protection bit on Haswell/Broadwell
mfd: syscon: atmel-smc: Add helper to retrieve register layout
mfd: axp20x: Use correct platform device ID for many PEK
dt-bindings: mfd: axp20x: Introduce bindings for AXP813
mfd: axp20x: Add support for AXP813 PMIC
dt-bindings: mfd: axp20x: Add AXP806 to supported list of chips
mfd: Add ROHM BD9571MWV-M MFD PMIC driver
...
This commit is contained in:
@@ -24,6 +24,17 @@ config IIO_INTERRUPT_TRIGGER
|
||||
To compile this driver as a module, choose M here: the
|
||||
module will be called iio-trig-interrupt.
|
||||
|
||||
config IIO_STM32_LPTIMER_TRIGGER
|
||||
tristate "STM32 Low-Power Timer Trigger"
|
||||
depends on MFD_STM32_LPTIMER || COMPILE_TEST
|
||||
help
|
||||
Select this option to enable STM32 Low-Power Timer Trigger.
|
||||
This can be used as trigger source for STM32 internal ADC
|
||||
and/or DAC.
|
||||
|
||||
To compile this driver as a module, choose M here: the
|
||||
module will be called stm32-lptimer-trigger.
|
||||
|
||||
config IIO_STM32_TIMER_TRIGGER
|
||||
tristate "STM32 Timer Trigger"
|
||||
depends on (ARCH_STM32 && OF && MFD_STM32_TIMERS) || COMPILE_TEST
|
||||
|
||||
@@ -6,6 +6,7 @@
|
||||
|
||||
obj-$(CONFIG_IIO_HRTIMER_TRIGGER) += iio-trig-hrtimer.o
|
||||
obj-$(CONFIG_IIO_INTERRUPT_TRIGGER) += iio-trig-interrupt.o
|
||||
obj-$(CONFIG_IIO_STM32_LPTIMER_TRIGGER) += stm32-lptimer-trigger.o
|
||||
obj-$(CONFIG_IIO_STM32_TIMER_TRIGGER) += stm32-timer-trigger.o
|
||||
obj-$(CONFIG_IIO_SYSFS_TRIGGER) += iio-trig-sysfs.o
|
||||
obj-$(CONFIG_IIO_TIGHTLOOP_TRIGGER) += iio-trig-loop.o
|
||||
|
||||
@@ -0,0 +1,118 @@
|
||||
/*
|
||||
* STM32 Low-Power Timer Trigger driver
|
||||
*
|
||||
* Copyright (C) STMicroelectronics 2017
|
||||
*
|
||||
* Author: Fabrice Gasnier <fabrice.gasnier@st.com>.
|
||||
*
|
||||
* License terms: GNU General Public License (GPL), version 2
|
||||
*
|
||||
* Inspired by Benjamin Gaignard's stm32-timer-trigger driver
|
||||
*/
|
||||
|
||||
#include <linux/iio/timer/stm32-lptim-trigger.h>
|
||||
#include <linux/mfd/stm32-lptimer.h>
|
||||
#include <linux/module.h>
|
||||
#include <linux/platform_device.h>
|
||||
|
||||
/* List Low-Power Timer triggers */
|
||||
static const char * const stm32_lptim_triggers[] = {
|
||||
LPTIM1_OUT,
|
||||
LPTIM2_OUT,
|
||||
LPTIM3_OUT,
|
||||
};
|
||||
|
||||
struct stm32_lptim_trigger {
|
||||
struct device *dev;
|
||||
const char *trg;
|
||||
};
|
||||
|
||||
static int stm32_lptim_validate_device(struct iio_trigger *trig,
|
||||
struct iio_dev *indio_dev)
|
||||
{
|
||||
if (indio_dev->modes & INDIO_HARDWARE_TRIGGERED)
|
||||
return 0;
|
||||
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
static const struct iio_trigger_ops stm32_lptim_trigger_ops = {
|
||||
.owner = THIS_MODULE,
|
||||
.validate_device = stm32_lptim_validate_device,
|
||||
};
|
||||
|
||||
/**
|
||||
* is_stm32_lptim_trigger
|
||||
* @trig: trigger to be checked
|
||||
*
|
||||
* return true if the trigger is a valid STM32 IIO Low-Power Timer Trigger
|
||||
* either return false
|
||||
*/
|
||||
bool is_stm32_lptim_trigger(struct iio_trigger *trig)
|
||||
{
|
||||
return (trig->ops == &stm32_lptim_trigger_ops);
|
||||
}
|
||||
EXPORT_SYMBOL(is_stm32_lptim_trigger);
|
||||
|
||||
static int stm32_lptim_setup_trig(struct stm32_lptim_trigger *priv)
|
||||
{
|
||||
struct iio_trigger *trig;
|
||||
|
||||
trig = devm_iio_trigger_alloc(priv->dev, "%s", priv->trg);
|
||||
if (!trig)
|
||||
return -ENOMEM;
|
||||
|
||||
trig->dev.parent = priv->dev->parent;
|
||||
trig->ops = &stm32_lptim_trigger_ops;
|
||||
iio_trigger_set_drvdata(trig, priv);
|
||||
|
||||
return devm_iio_trigger_register(priv->dev, trig);
|
||||
}
|
||||
|
||||
static int stm32_lptim_trigger_probe(struct platform_device *pdev)
|
||||
{
|
||||
struct stm32_lptim_trigger *priv;
|
||||
u32 index;
|
||||
int ret;
|
||||
|
||||
priv = devm_kzalloc(&pdev->dev, sizeof(*priv), GFP_KERNEL);
|
||||
if (!priv)
|
||||
return -ENOMEM;
|
||||
|
||||
if (of_property_read_u32(pdev->dev.of_node, "reg", &index))
|
||||
return -EINVAL;
|
||||
|
||||
if (index >= ARRAY_SIZE(stm32_lptim_triggers))
|
||||
return -EINVAL;
|
||||
|
||||
priv->dev = &pdev->dev;
|
||||
priv->trg = stm32_lptim_triggers[index];
|
||||
|
||||
ret = stm32_lptim_setup_trig(priv);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
platform_set_drvdata(pdev, priv);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static const struct of_device_id stm32_lptim_trig_of_match[] = {
|
||||
{ .compatible = "st,stm32-lptimer-trigger", },
|
||||
{},
|
||||
};
|
||||
MODULE_DEVICE_TABLE(of, stm32_lptim_trig_of_match);
|
||||
|
||||
static struct platform_driver stm32_lptim_trigger_driver = {
|
||||
.probe = stm32_lptim_trigger_probe,
|
||||
.driver = {
|
||||
.name = "stm32-lptimer-trigger",
|
||||
.of_match_table = stm32_lptim_trig_of_match,
|
||||
},
|
||||
};
|
||||
module_platform_driver(stm32_lptim_trigger_driver);
|
||||
|
||||
MODULE_AUTHOR("Fabrice Gasnier <fabrice.gasnier@st.com>");
|
||||
MODULE_ALIAS("platform:stm32-lptimer-trigger");
|
||||
MODULE_DESCRIPTION("STMicroelectronics STM32 LPTIM trigger driver");
|
||||
MODULE_LICENSE("GPL v2");
|
||||
Reference in New Issue
Block a user