* [PATCH 0/5] regulator: mp8859: add driver for DC/DC converter used on rk3399-roc-pc board @ 2020-01-06 21:16 Markus Reichl 2020-01-06 21:16 ` [PATCH 1/5] regulator: mp8859: add driver Markus Reichl ` (4 more replies) 0 siblings, 5 replies; 14+ messages in thread From: Markus Reichl @ 2020-01-06 21:16 UTC (permalink / raw) To: linux-rockchip, Liam Girdwood, Mark Brown, Rob Herring, Mark Rutland, Heiko Stuebner Cc: Markus Reichl, linux-kernel, devicetree, linux-arm-kernel On rk3399-roc-pc board a voltage regulator MP8859 from Monolithic Power Systems is used to supply the 12V power line. This delivers 5V as a default value after boot. The voltage is controllable via I2C. Add a basic driver to set and get the voltage of the MP8859 and add a matching node with fixed 12V in the DT of the board. Markus Reichl (5): regulator: mp8859: add driver regulator: mp8859: add config option and build entry dt-bindings: add vendor Monolithic Power Systems dt-bindings: regulator: add MPS mp8859 voltage regulator arm64: dts: rockchip: Enable mp8859 regulator on rk3399-roc-pc .../devicetree/bindings/regulator/mp8859.txt | 22 +++ .../devicetree/bindings/vendor-prefixes.yaml | 2 + .../boot/dts/rockchip/rk3399-roc-pc.dtsi | 32 ++-- drivers/regulator/Kconfig | 11 ++ drivers/regulator/Makefile | 1 + drivers/regulator/mp8859.c | 156 ++++++++++++++++++ 6 files changed, 210 insertions(+), 14 deletions(-) create mode 100644 Documentation/devicetree/bindings/regulator/mp8859.txt create mode 100644 drivers/regulator/mp8859.c -- 2.24.1 ^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH 1/5] regulator: mp8859: add driver 2020-01-06 21:16 [PATCH 0/5] regulator: mp8859: add driver for DC/DC converter used on rk3399-roc-pc board Markus Reichl @ 2020-01-06 21:16 ` Markus Reichl 2020-01-08 15:59 ` Applied "regulator: mp8859: add driver" to the regulator tree Mark Brown 2020-01-06 21:16 ` [PATCH 2/5] regulator: mp8859: add config option and build entry Markus Reichl ` (3 subsequent siblings) 4 siblings, 1 reply; 14+ messages in thread From: Markus Reichl @ 2020-01-06 21:16 UTC (permalink / raw) To: linux-rockchip, Liam Girdwood, Mark Brown, Rob Herring, Mark Rutland, Heiko Stuebner Cc: Markus Reichl, linux-kernel, devicetree, linux-arm-kernel The MP8859 from Monolithic Power Systems is a single output DC/DC converter. The voltage can be controlled via I2C. Signed-off-by: Markus Reichl <m.reichl@fivetechno.de> --- drivers/regulator/mp8859.c | 156 +++++++++++++++++++++++++++++++++++++ 1 file changed, 156 insertions(+) create mode 100644 drivers/regulator/mp8859.c diff --git a/drivers/regulator/mp8859.c b/drivers/regulator/mp8859.c new file mode 100644 index 000000000000..e804a5267301 --- /dev/null +++ b/drivers/regulator/mp8859.c @@ -0,0 +1,156 @@ +// SPDX-License-Identifier: GPL-2.0 +// +// Copyright (c) 2019 five technologies GmbH +// Author: Markus Reichl <m.reichl@fivetechno.de> + +#include <linux/module.h> +#include <linux/i2c.h> +#include <linux/of.h> +#include <linux/regulator/driver.h> +#include <linux/regmap.h> + + +#define VOL_MIN_IDX 0x00 +#define VOL_MAX_IDX 0x7ff + +/* Register definitions */ +#define MP8859_VOUT_L_REG 0 //3 lo Bits +#define MP8859_VOUT_H_REG 1 //8 hi Bits +#define MP8859_VOUT_GO_REG 2 +#define MP8859_IOUT_LIM_REG 3 +#define MP8859_CTL1_REG 4 +#define MP8859_CTL2_REG 5 +#define MP8859_RESERVED1_REG 6 +#define MP8859_RESERVED2_REG 7 +#define MP8859_RESERVED3_REG 8 +#define MP8859_STATUS_REG 9 +#define MP8859_INTERRUPT_REG 0x0A +#define MP8859_MASK_REG 0x0B +#define MP8859_ID1_REG 0x0C +#define MP8859_MFR_ID_REG 0x27 +#define MP8859_DEV_ID_REG 0x28 +#define MP8859_IC_REV_REG 0x29 + +#define MP8859_MAX_REG 0x29 + +#define MP8859_GO_BIT 0x01 + + +static int mp8859_set_voltage_sel(struct regulator_dev *rdev, unsigned int sel) +{ + int ret; + + ret = regmap_write(rdev->regmap, MP8859_VOUT_L_REG, sel & 0x7); + + if (ret) + return ret; + ret = regmap_write(rdev->regmap, MP8859_VOUT_H_REG, sel >> 3); + + if (ret) + return ret; + ret = regmap_update_bits(rdev->regmap, MP8859_VOUT_GO_REG, + MP8859_GO_BIT, 1); + return ret; +} + +static int mp8859_get_voltage_sel(struct regulator_dev *rdev) +{ + unsigned int val_tmp; + unsigned int val; + int ret; + + ret = regmap_read(rdev->regmap, MP8859_VOUT_H_REG, &val_tmp); + + if (ret) + return ret; + val = val_tmp << 3; + + ret = regmap_read(rdev->regmap, MP8859_VOUT_L_REG, &val_tmp); + + if (ret) + return ret; + val |= val_tmp & 0x07; + return val; +} + +static const struct regulator_linear_range mp8859_dcdc_ranges[] = { + REGULATOR_LINEAR_RANGE(0, VOL_MIN_IDX, VOL_MAX_IDX, 10000), +}; + +static const struct regmap_config mp8859_regmap = { + .reg_bits = 8, + .val_bits = 8, + .max_register = MP8859_MAX_REG, + .cache_type = REGCACHE_RBTREE, +}; + +static const struct regulator_ops mp8859_ops = { + .set_voltage_sel = mp8859_set_voltage_sel, + .get_voltage_sel = mp8859_get_voltage_sel, + .list_voltage = regulator_list_voltage_linear_range, +}; + +static const struct regulator_desc mp8859_regulators[] = { + { + .id = 0, + .type = REGULATOR_VOLTAGE, + .name = "mp8859_dcdc", + .of_match = of_match_ptr("mp8859_dcdc"), + .n_voltages = VOL_MAX_IDX + 1, + .linear_ranges = mp8859_dcdc_ranges, + .n_linear_ranges = 1, + .ops = &mp8859_ops, + .owner = THIS_MODULE, + }, +}; + +static int mp8859_i2c_probe(struct i2c_client *i2c) +{ + int ret; + struct regulator_config config = {.dev = &i2c->dev}; + struct regmap *regmap = devm_regmap_init_i2c(i2c, &mp8859_regmap); + struct regulator_dev *rdev; + + if (IS_ERR(regmap)) { + ret = PTR_ERR(regmap); + dev_err(&i2c->dev, "regmap init failed: %d\n", ret); + return ret; + } + rdev = devm_regulator_register(&i2c->dev, &mp8859_regulators[0], + &config); + + if (IS_ERR(rdev)) { + ret = PTR_ERR(rdev); + dev_err(&i2c->dev, "failed to register %s: %d\n", + mp8859_regulators[0].name, ret); + return ret; + } + return 0; +} + +static const struct of_device_id mp8859_dt_id[] = { + {.compatible = "mps,mp8859"}, + {}, +}; +MODULE_DEVICE_TABLE(of, mp8859_dt_id); + +static const struct i2c_device_id mp8859_i2c_id[] = { + { "mp8859", }, + { }, +}; +MODULE_DEVICE_TABLE(i2c, mp8859_i2c_id); + +static struct i2c_driver mp8859_regulator_driver = { + .driver = { + .name = "mp8859", + .of_match_table = of_match_ptr(mp8859_dt_id), + }, + .probe_new = mp8859_i2c_probe, + .id_table = mp8859_i2c_id, +}; + +module_i2c_driver(mp8859_regulator_driver); + +MODULE_DESCRIPTION("Monolithic Power Systems MP8859 voltage regulator driver"); +MODULE_AUTHOR("Markus Reichl <m.reichl@fivetechno.de>"); +MODULE_LICENSE("GPL v2"); -- 2.24.1 ^ permalink raw reply related [flat|nested] 14+ messages in thread
* Applied "regulator: mp8859: add driver" to the regulator tree 2020-01-06 21:16 ` [PATCH 1/5] regulator: mp8859: add driver Markus Reichl @ 2020-01-08 15:59 ` Mark Brown 0 siblings, 0 replies; 14+ messages in thread From: Mark Brown @ 2020-01-08 15:59 UTC (permalink / raw) To: Markus Reichl Cc: Mark Rutland, devicetree, Heiko Stuebner, linux-kernel, Rob Herring, Liam Girdwood, linux-rockchip, Mark Brown, linux-arm-kernel The patch regulator: mp8859: add driver has been applied to the regulator tree at https://git.kernel.org/pub/scm/linux/kernel/git/broonie/regulator.git for-5.6 All being well this means that it will be integrated into the linux-next tree (usually sometime in the next 24 hours) and sent to Linus during the next merge window (or sooner if it is a bug fix), however if problems are discovered then the patch may be dropped or reverted. You may get further e-mails resulting from automated or manual testing and review of the tree, please engage with people reporting problems and send followup patches addressing any issues that are reported if needed. If any updates are required or you are submitting further changes they should be sent as incremental updates against current git, existing patches will not be replaced. Please add any relevant lists and maintainers to the CCs when replying to this mail. Thanks, Mark From 4444a1c10069e2f371fa497ba22feafafed5aada Mon Sep 17 00:00:00 2001 From: Markus Reichl <m.reichl@fivetechno.de> Date: Mon, 6 Jan 2020 22:16:24 +0100 Subject: [PATCH] regulator: mp8859: add driver The MP8859 from Monolithic Power Systems is a single output DC/DC converter. The voltage can be controlled via I2C. Signed-off-by: Markus Reichl <m.reichl@fivetechno.de> Link: https://lore.kernel.org/r/20200106211633.2882-2-m.reichl@fivetechno.de Signed-off-by: Mark Brown <broonie@kernel.org> --- drivers/regulator/mp8859.c | 156 +++++++++++++++++++++++++++++++++++++ 1 file changed, 156 insertions(+) create mode 100644 drivers/regulator/mp8859.c diff --git a/drivers/regulator/mp8859.c b/drivers/regulator/mp8859.c new file mode 100644 index 000000000000..e804a5267301 --- /dev/null +++ b/drivers/regulator/mp8859.c @@ -0,0 +1,156 @@ +// SPDX-License-Identifier: GPL-2.0 +// +// Copyright (c) 2019 five technologies GmbH +// Author: Markus Reichl <m.reichl@fivetechno.de> + +#include <linux/module.h> +#include <linux/i2c.h> +#include <linux/of.h> +#include <linux/regulator/driver.h> +#include <linux/regmap.h> + + +#define VOL_MIN_IDX 0x00 +#define VOL_MAX_IDX 0x7ff + +/* Register definitions */ +#define MP8859_VOUT_L_REG 0 //3 lo Bits +#define MP8859_VOUT_H_REG 1 //8 hi Bits +#define MP8859_VOUT_GO_REG 2 +#define MP8859_IOUT_LIM_REG 3 +#define MP8859_CTL1_REG 4 +#define MP8859_CTL2_REG 5 +#define MP8859_RESERVED1_REG 6 +#define MP8859_RESERVED2_REG 7 +#define MP8859_RESERVED3_REG 8 +#define MP8859_STATUS_REG 9 +#define MP8859_INTERRUPT_REG 0x0A +#define MP8859_MASK_REG 0x0B +#define MP8859_ID1_REG 0x0C +#define MP8859_MFR_ID_REG 0x27 +#define MP8859_DEV_ID_REG 0x28 +#define MP8859_IC_REV_REG 0x29 + +#define MP8859_MAX_REG 0x29 + +#define MP8859_GO_BIT 0x01 + + +static int mp8859_set_voltage_sel(struct regulator_dev *rdev, unsigned int sel) +{ + int ret; + + ret = regmap_write(rdev->regmap, MP8859_VOUT_L_REG, sel & 0x7); + + if (ret) + return ret; + ret = regmap_write(rdev->regmap, MP8859_VOUT_H_REG, sel >> 3); + + if (ret) + return ret; + ret = regmap_update_bits(rdev->regmap, MP8859_VOUT_GO_REG, + MP8859_GO_BIT, 1); + return ret; +} + +static int mp8859_get_voltage_sel(struct regulator_dev *rdev) +{ + unsigned int val_tmp; + unsigned int val; + int ret; + + ret = regmap_read(rdev->regmap, MP8859_VOUT_H_REG, &val_tmp); + + if (ret) + return ret; + val = val_tmp << 3; + + ret = regmap_read(rdev->regmap, MP8859_VOUT_L_REG, &val_tmp); + + if (ret) + return ret; + val |= val_tmp & 0x07; + return val; +} + +static const struct regulator_linear_range mp8859_dcdc_ranges[] = { + REGULATOR_LINEAR_RANGE(0, VOL_MIN_IDX, VOL_MAX_IDX, 10000), +}; + +static const struct regmap_config mp8859_regmap = { + .reg_bits = 8, + .val_bits = 8, + .max_register = MP8859_MAX_REG, + .cache_type = REGCACHE_RBTREE, +}; + +static const struct regulator_ops mp8859_ops = { + .set_voltage_sel = mp8859_set_voltage_sel, + .get_voltage_sel = mp8859_get_voltage_sel, + .list_voltage = regulator_list_voltage_linear_range, +}; + +static const struct regulator_desc mp8859_regulators[] = { + { + .id = 0, + .type = REGULATOR_VOLTAGE, + .name = "mp8859_dcdc", + .of_match = of_match_ptr("mp8859_dcdc"), + .n_voltages = VOL_MAX_IDX + 1, + .linear_ranges = mp8859_dcdc_ranges, + .n_linear_ranges = 1, + .ops = &mp8859_ops, + .owner = THIS_MODULE, + }, +}; + +static int mp8859_i2c_probe(struct i2c_client *i2c) +{ + int ret; + struct regulator_config config = {.dev = &i2c->dev}; + struct regmap *regmap = devm_regmap_init_i2c(i2c, &mp8859_regmap); + struct regulator_dev *rdev; + + if (IS_ERR(regmap)) { + ret = PTR_ERR(regmap); + dev_err(&i2c->dev, "regmap init failed: %d\n", ret); + return ret; + } + rdev = devm_regulator_register(&i2c->dev, &mp8859_regulators[0], + &config); + + if (IS_ERR(rdev)) { + ret = PTR_ERR(rdev); + dev_err(&i2c->dev, "failed to register %s: %d\n", + mp8859_regulators[0].name, ret); + return ret; + } + return 0; +} + +static const struct of_device_id mp8859_dt_id[] = { + {.compatible = "mps,mp8859"}, + {}, +}; +MODULE_DEVICE_TABLE(of, mp8859_dt_id); + +static const struct i2c_device_id mp8859_i2c_id[] = { + { "mp8859", }, + { }, +}; +MODULE_DEVICE_TABLE(i2c, mp8859_i2c_id); + +static struct i2c_driver mp8859_regulator_driver = { + .driver = { + .name = "mp8859", + .of_match_table = of_match_ptr(mp8859_dt_id), + }, + .probe_new = mp8859_i2c_probe, + .id_table = mp8859_i2c_id, +}; + +module_i2c_driver(mp8859_regulator_driver); + +MODULE_DESCRIPTION("Monolithic Power Systems MP8859 voltage regulator driver"); +MODULE_AUTHOR("Markus Reichl <m.reichl@fivetechno.de>"); +MODULE_LICENSE("GPL v2"); -- 2.20.1 ^ permalink raw reply related [flat|nested] 14+ messages in thread
* [PATCH 2/5] regulator: mp8859: add config option and build entry 2020-01-06 21:16 [PATCH 0/5] regulator: mp8859: add driver for DC/DC converter used on rk3399-roc-pc board Markus Reichl 2020-01-06 21:16 ` [PATCH 1/5] regulator: mp8859: add driver Markus Reichl @ 2020-01-06 21:16 ` Markus Reichl [not found] ` <20200106211633.2882-3-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> 2020-01-08 15:58 ` Applied "regulator: mp8859: add config option and build entry" to the regulator tree Mark Brown 2020-01-06 21:16 ` [PATCH 3/5] dt-bindings: add vendor Monolithic Power Systems Markus Reichl ` (2 subsequent siblings) 4 siblings, 2 replies; 14+ messages in thread From: Markus Reichl @ 2020-01-06 21:16 UTC (permalink / raw) To: linux-rockchip, Liam Girdwood, Mark Brown, Rob Herring, Mark Rutland, Heiko Stuebner Cc: Markus Reichl, linux-kernel, devicetree, linux-arm-kernel Add entries for the mp8859 regulator driver to the build system. Signed-off-by: Markus Reichl <m.reichl@fivetechno.de> --- drivers/regulator/Kconfig | 11 +++++++++++ drivers/regulator/Makefile | 1 + 2 files changed, 12 insertions(+) diff --git a/drivers/regulator/Kconfig b/drivers/regulator/Kconfig index 56512748a47d..593733a88a61 100644 --- a/drivers/regulator/Kconfig +++ b/drivers/regulator/Kconfig @@ -612,6 +612,17 @@ config REGULATOR_MCP16502 through the regulator interface. In addition it enables suspend-to-ram/standby transition. +config REGULATOR_MP8859 + tristate "MPS MP8859 regulator driver" + depends on I2C + select REGMAP_I2C + help + Say y here to support the MP8859 voltage regulator. This driver + supports basic operations (get/set voltage) through the regulator + interface. + Say M here if you want to include support for the regulator as a + module. The module will be named "mp8859". + config REGULATOR_MT6311 tristate "MediaTek MT6311 PMIC" depends on I2C diff --git a/drivers/regulator/Makefile b/drivers/regulator/Makefile index 9eccf93bc3ab..8ba8e5deebbd 100644 --- a/drivers/regulator/Makefile +++ b/drivers/regulator/Makefile @@ -78,6 +78,7 @@ obj-$(CONFIG_REGULATOR_MC13783) += mc13783-regulator.o obj-$(CONFIG_REGULATOR_MC13892) += mc13892-regulator.o obj-$(CONFIG_REGULATOR_MC13XXX_CORE) += mc13xxx-regulator-core.o obj-$(CONFIG_REGULATOR_MCP16502) += mcp16502.o +obj-$(CONFIG_REGULATOR_MP8859) += mp8859.o obj-$(CONFIG_REGULATOR_MT6311) += mt6311-regulator.o obj-$(CONFIG_REGULATOR_MT6323) += mt6323-regulator.o obj-$(CONFIG_REGULATOR_MT6358) += mt6358-regulator.o -- 2.24.1 ^ permalink raw reply related [flat|nested] 14+ messages in thread
[parent not found: <20200106211633.2882-3-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org>]
* Re: [PATCH 2/5] regulator: mp8859: add config option and build entry [not found] ` <20200106211633.2882-3-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> @ 2020-01-06 21:22 ` Heiko Stübner 2020-01-07 7:29 ` Markus Reichl 0 siblings, 1 reply; 14+ messages in thread From: Heiko Stübner @ 2020-01-06 21:22 UTC (permalink / raw) To: Markus Reichl Cc: Mark Rutland, devicetree-u79uwXL29TY76Z2rM5mHXA, Liam Girdwood, Rob Herring, linux-kernel-u79uwXL29TY76Z2rM5mHXA, linux-rockchip-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r, Mark Brown, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r Am Montag, 6. Januar 2020, 22:16:25 CET schrieb Markus Reichl: > Add entries for the mp8859 regulator driver > to the build system. > > Signed-off-by: Markus Reichl <m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> this still should get merged into patch1 :-) Heiko ^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH 2/5] regulator: mp8859: add config option and build entry 2020-01-06 21:22 ` Heiko Stübner @ 2020-01-07 7:29 ` Markus Reichl 0 siblings, 0 replies; 14+ messages in thread From: Markus Reichl @ 2020-01-07 7:29 UTC (permalink / raw) To: Heiko Stübner Cc: Mark Rutland, devicetree, Liam Girdwood, Rob Herring, linux-kernel, linux-rockchip, Mark Brown, linux-arm-kernel Hi Heiko, Am 06.01.20 um 22:22 schrieb Heiko Stübner: > Am Montag, 6. Januar 2020, 22:16:25 CET schrieb Markus Reichl: >> Add entries for the mp8859 regulator driver >> to the build system. >> >> Signed-off-by: Markus Reichl <m.reichl@fivetechno.de> > > this still should get merged into patch1 :-) Will merge them in next version. > > Heiko > > > > _______________________________________________ > Linux-rockchip mailing list > Linux-rockchip@lists.infradead.org > http://lists.infradead.org/mailman/listinfo/linux-rockchip > Gruß, -- Markus Reichl ^ permalink raw reply [flat|nested] 14+ messages in thread
* Applied "regulator: mp8859: add config option and build entry" to the regulator tree 2020-01-06 21:16 ` [PATCH 2/5] regulator: mp8859: add config option and build entry Markus Reichl [not found] ` <20200106211633.2882-3-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> @ 2020-01-08 15:58 ` Mark Brown 1 sibling, 0 replies; 14+ messages in thread From: Mark Brown @ 2020-01-08 15:58 UTC (permalink / raw) To: Markus Reichl Cc: Mark Rutland, devicetree, Heiko Stuebner, linux-kernel, Rob Herring, Liam Girdwood, linux-rockchip, Mark Brown, linux-arm-kernel The patch regulator: mp8859: add config option and build entry has been applied to the regulator tree at https://git.kernel.org/pub/scm/linux/kernel/git/broonie/regulator.git for-5.6 All being well this means that it will be integrated into the linux-next tree (usually sometime in the next 24 hours) and sent to Linus during the next merge window (or sooner if it is a bug fix), however if problems are discovered then the patch may be dropped or reverted. You may get further e-mails resulting from automated or manual testing and review of the tree, please engage with people reporting problems and send followup patches addressing any issues that are reported if needed. If any updates are required or you are submitting further changes they should be sent as incremental updates against current git, existing patches will not be replaced. Please add any relevant lists and maintainers to the CCs when replying to this mail. Thanks, Mark From c66f1cbad53a61f00f8b6273e737d5e560b69ec7 Mon Sep 17 00:00:00 2001 From: Markus Reichl <m.reichl@fivetechno.de> Date: Mon, 6 Jan 2020 22:16:25 +0100 Subject: [PATCH] regulator: mp8859: add config option and build entry Add entries for the mp8859 regulator driver to the build system. Signed-off-by: Markus Reichl <m.reichl@fivetechno.de> Link: https://lore.kernel.org/r/20200106211633.2882-3-m.reichl@fivetechno.de Signed-off-by: Mark Brown <broonie@kernel.org> --- drivers/regulator/Kconfig | 11 +++++++++++ drivers/regulator/Makefile | 1 + 2 files changed, 12 insertions(+) diff --git a/drivers/regulator/Kconfig b/drivers/regulator/Kconfig index 56512748a47d..593733a88a61 100644 --- a/drivers/regulator/Kconfig +++ b/drivers/regulator/Kconfig @@ -612,6 +612,17 @@ config REGULATOR_MCP16502 through the regulator interface. In addition it enables suspend-to-ram/standby transition. +config REGULATOR_MP8859 + tristate "MPS MP8859 regulator driver" + depends on I2C + select REGMAP_I2C + help + Say y here to support the MP8859 voltage regulator. This driver + supports basic operations (get/set voltage) through the regulator + interface. + Say M here if you want to include support for the regulator as a + module. The module will be named "mp8859". + config REGULATOR_MT6311 tristate "MediaTek MT6311 PMIC" depends on I2C diff --git a/drivers/regulator/Makefile b/drivers/regulator/Makefile index 9eccf93bc3ab..8ba8e5deebbd 100644 --- a/drivers/regulator/Makefile +++ b/drivers/regulator/Makefile @@ -78,6 +78,7 @@ obj-$(CONFIG_REGULATOR_MC13783) += mc13783-regulator.o obj-$(CONFIG_REGULATOR_MC13892) += mc13892-regulator.o obj-$(CONFIG_REGULATOR_MC13XXX_CORE) += mc13xxx-regulator-core.o obj-$(CONFIG_REGULATOR_MCP16502) += mcp16502.o +obj-$(CONFIG_REGULATOR_MP8859) += mp8859.o obj-$(CONFIG_REGULATOR_MT6311) += mt6311-regulator.o obj-$(CONFIG_REGULATOR_MT6323) += mt6323-regulator.o obj-$(CONFIG_REGULATOR_MT6358) += mt6358-regulator.o -- 2.20.1 ^ permalink raw reply related [flat|nested] 14+ messages in thread
* [PATCH 3/5] dt-bindings: add vendor Monolithic Power Systems 2020-01-06 21:16 [PATCH 0/5] regulator: mp8859: add driver for DC/DC converter used on rk3399-roc-pc board Markus Reichl 2020-01-06 21:16 ` [PATCH 1/5] regulator: mp8859: add driver Markus Reichl 2020-01-06 21:16 ` [PATCH 2/5] regulator: mp8859: add config option and build entry Markus Reichl @ 2020-01-06 21:16 ` Markus Reichl 2020-01-08 20:32 ` Rob Herring 2020-01-06 21:16 ` [PATCH 4/5] dt-bindings: regulator: add MPS mp8859 voltage regulator Markus Reichl 2020-01-06 21:16 ` [PATCH 5/5] arm64: dts: rockchip: Enable mp8859 regulator on rk3399-roc-pc Markus Reichl 4 siblings, 1 reply; 14+ messages in thread From: Markus Reichl @ 2020-01-06 21:16 UTC (permalink / raw) To: linux-rockchip, Liam Girdwood, Mark Brown, Rob Herring, Mark Rutland, Heiko Stuebner Cc: Markus Reichl, linux-kernel, devicetree, linux-arm-kernel MPS produce power regulators like the MP8859. Signed-off-by: Markus Reichl <m.reichl@fivetechno.de> --- Documentation/devicetree/bindings/vendor-prefixes.yaml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Documentation/devicetree/bindings/vendor-prefixes.yaml b/Documentation/devicetree/bindings/vendor-prefixes.yaml index fa6aa3c5a500..4fa3bb494745 100644 --- a/Documentation/devicetree/bindings/vendor-prefixes.yaml +++ b/Documentation/devicetree/bindings/vendor-prefixes.yaml @@ -617,6 +617,8 @@ patternProperties: description: Moxa Inc. "^mpl,.*": description: MPL AG + "^mps,.*": + description: Monolithic Power Systems Inc. "^mqmaker,.*": description: mqmaker Inc. "^mscc,.*": -- 2.24.1 ^ permalink raw reply related [flat|nested] 14+ messages in thread
* Re: [PATCH 3/5] dt-bindings: add vendor Monolithic Power Systems 2020-01-06 21:16 ` [PATCH 3/5] dt-bindings: add vendor Monolithic Power Systems Markus Reichl @ 2020-01-08 20:32 ` Rob Herring 0 siblings, 0 replies; 14+ messages in thread From: Rob Herring @ 2020-01-08 20:32 UTC (permalink / raw) Cc: linux-rockchip, Liam Girdwood, Mark Brown, Mark Rutland, Heiko Stuebner, Markus Reichl, linux-kernel, devicetree, linux-arm-kernel On Mon, 6 Jan 2020 22:16:26 +0100, Markus Reichl wrote: > MPS produce power regulators like the MP8859. > > Signed-off-by: Markus Reichl <m.reichl@fivetechno.de> > --- > Documentation/devicetree/bindings/vendor-prefixes.yaml | 2 ++ > 1 file changed, 2 insertions(+) > Applied, thanks. Rob ^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH 4/5] dt-bindings: regulator: add MPS mp8859 voltage regulator 2020-01-06 21:16 [PATCH 0/5] regulator: mp8859: add driver for DC/DC converter used on rk3399-roc-pc board Markus Reichl ` (2 preceding siblings ...) 2020-01-06 21:16 ` [PATCH 3/5] dt-bindings: add vendor Monolithic Power Systems Markus Reichl @ 2020-01-06 21:16 ` Markus Reichl [not found] ` <20200106211633.2882-5-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> 2020-01-06 21:16 ` [PATCH 5/5] arm64: dts: rockchip: Enable mp8859 regulator on rk3399-roc-pc Markus Reichl 4 siblings, 1 reply; 14+ messages in thread From: Markus Reichl @ 2020-01-06 21:16 UTC (permalink / raw) To: linux-rockchip, Liam Girdwood, Mark Brown, Rob Herring, Mark Rutland, Heiko Stuebner Cc: Markus Reichl, linux-kernel, devicetree, linux-arm-kernel The MP8859 from Monolithic Power Systems is a single output dc/dc converter with voltage control over i2c. Signed-off-by: Markus Reichl <m.reichl@fivetechno.de> --- .../devicetree/bindings/regulator/mp8859.txt | 22 +++++++++++++++++++ 1 file changed, 22 insertions(+) create mode 100644 Documentation/devicetree/bindings/regulator/mp8859.txt diff --git a/Documentation/devicetree/bindings/regulator/mp8859.txt b/Documentation/devicetree/bindings/regulator/mp8859.txt new file mode 100644 index 000000000000..74ad69730989 --- /dev/null +++ b/Documentation/devicetree/bindings/regulator/mp8859.txt @@ -0,0 +1,22 @@ +Monolithic Power Systems MP8859 voltage regulator + +Required properties: +- compatible: "mps,mp8859"; +- reg: I2C slave address. + +Optional subnode for regulator: "mp8859_dcdc", using common regulator +bindings given in <Documentation/devicetree/bindings/regulator/regulator.txt>. + +Example: + + mp8859: regulator@66 { + compatible = "mps,mp8859"; + reg = <0x66>; + dc_12v: mp8859_dcdc { + regulator-name = "dc_12v"; + regulator-min-microvolt = <12000000>; + regulator-max-microvolt = <12000000>; + regulator-boot-on; + regulator-always-on; + }; + }; -- 2.24.1 ^ permalink raw reply related [flat|nested] 14+ messages in thread
[parent not found: <20200106211633.2882-5-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org>]
* Applied "regulator: bindings: add MPS mp8859 voltage regulator" to the regulator tree [not found] ` <20200106211633.2882-5-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> @ 2020-01-08 15:58 ` Mark Brown 0 siblings, 0 replies; 14+ messages in thread From: Mark Brown @ 2020-01-08 15:58 UTC (permalink / raw) To: Markus Reichl Cc: Mark Rutland, devicetree-u79uwXL29TY76Z2rM5mHXA, Heiko Stuebner, linux-kernel-u79uwXL29TY76Z2rM5mHXA, Rob Herring, Liam Girdwood, linux-rockchip-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r, Mark Brown, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r The patch regulator: bindings: add MPS mp8859 voltage regulator has been applied to the regulator tree at https://git.kernel.org/pub/scm/linux/kernel/git/broonie/regulator.git for-5.6 All being well this means that it will be integrated into the linux-next tree (usually sometime in the next 24 hours) and sent to Linus during the next merge window (or sooner if it is a bug fix), however if problems are discovered then the patch may be dropped or reverted. You may get further e-mails resulting from automated or manual testing and review of the tree, please engage with people reporting problems and send followup patches addressing any issues that are reported if needed. If any updates are required or you are submitting further changes they should be sent as incremental updates against current git, existing patches will not be replaced. Please add any relevant lists and maintainers to the CCs when replying to this mail. Thanks, Mark From 44665f7d082977e8bb1803ec0e596f141cba7196 Mon Sep 17 00:00:00 2001 From: Markus Reichl <m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> Date: Mon, 6 Jan 2020 22:16:27 +0100 Subject: [PATCH] regulator: bindings: add MPS mp8859 voltage regulator The MP8859 from Monolithic Power Systems is a single output dc/dc converter with voltage control over i2c. Signed-off-by: Markus Reichl <m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> Link: https://lore.kernel.org/r/20200106211633.2882-5-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org Signed-off-by: Mark Brown <broonie-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org> --- .../devicetree/bindings/regulator/mp8859.txt | 22 +++++++++++++++++++ 1 file changed, 22 insertions(+) create mode 100644 Documentation/devicetree/bindings/regulator/mp8859.txt diff --git a/Documentation/devicetree/bindings/regulator/mp8859.txt b/Documentation/devicetree/bindings/regulator/mp8859.txt new file mode 100644 index 000000000000..74ad69730989 --- /dev/null +++ b/Documentation/devicetree/bindings/regulator/mp8859.txt @@ -0,0 +1,22 @@ +Monolithic Power Systems MP8859 voltage regulator + +Required properties: +- compatible: "mps,mp8859"; +- reg: I2C slave address. + +Optional subnode for regulator: "mp8859_dcdc", using common regulator +bindings given in <Documentation/devicetree/bindings/regulator/regulator.txt>. + +Example: + + mp8859: regulator@66 { + compatible = "mps,mp8859"; + reg = <0x66>; + dc_12v: mp8859_dcdc { + regulator-name = "dc_12v"; + regulator-min-microvolt = <12000000>; + regulator-max-microvolt = <12000000>; + regulator-boot-on; + regulator-always-on; + }; + }; -- 2.20.1 ^ permalink raw reply related [flat|nested] 14+ messages in thread
* [PATCH 5/5] arm64: dts: rockchip: Enable mp8859 regulator on rk3399-roc-pc 2020-01-06 21:16 [PATCH 0/5] regulator: mp8859: add driver for DC/DC converter used on rk3399-roc-pc board Markus Reichl ` (3 preceding siblings ...) 2020-01-06 21:16 ` [PATCH 4/5] dt-bindings: regulator: add MPS mp8859 voltage regulator Markus Reichl @ 2020-01-06 21:16 ` Markus Reichl [not found] ` <20200106211633.2882-6-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> 4 siblings, 1 reply; 14+ messages in thread From: Markus Reichl @ 2020-01-06 21:16 UTC (permalink / raw) To: linux-rockchip, Liam Girdwood, Mark Brown, Rob Herring, Mark Rutland, Heiko Stuebner Cc: Markus Reichl, linux-kernel, devicetree, linux-arm-kernel The rk3399-roc-pc uses a MP8859 DC/DC converter for 12V supply. This supplies 5V only in default state after booting. Now we can control the output voltage via I2C interface. Add a node for the driver to reach 12V. Signed-off-by: Markus Reichl <m.reichl@fivetechno.de> --- .../boot/dts/rockchip/rk3399-roc-pc.dtsi | 32 +++++++++++-------- 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/arch/arm64/boot/dts/rockchip/rk3399-roc-pc.dtsi b/arch/arm64/boot/dts/rockchip/rk3399-roc-pc.dtsi index 8e01b04144b7..9f225e9c3d54 100644 --- a/arch/arm64/boot/dts/rockchip/rk3399-roc-pc.dtsi +++ b/arch/arm64/boot/dts/rockchip/rk3399-roc-pc.dtsi @@ -110,20 +110,6 @@ vcc_vbus_typec0: vcc-vbus-typec0 { regulator-max-microvolt = <5000000>; }; - /* - * should be placed inside mp8859, but not until mp8859 has - * its own dt-binding. - */ - dc_12v: mp8859-dcdc1 { - compatible = "regulator-fixed"; - regulator-name = "dc_12v"; - regulator-always-on; - regulator-boot-on; - regulator-min-microvolt = <12000000>; - regulator-max-microvolt = <12000000>; - vin-supply = <&vcc_vbus_typec0>; - }; - /* switched by pmic_sleep */ vcc1v8_s3: vcca1v8_s3: vcc1v8-s3 { compatible = "regulator-fixed"; @@ -546,6 +532,24 @@ fusb0: usb-typec@22 { vbus-supply = <&vcc_vbus_typec0>; status = "okay"; }; + + mp8859: regulator@66 { + compatible = "mps,mp8859"; + reg = <0x66>; + dc_12v: mp8859_dcdc { + regulator-name = "dc_12v"; + regulator-min-microvolt = <12000000>; + regulator-max-microvolt = <12000000>; + regulator-always-on; + regulator-boot-on; + vin-supply = <&vcc_vbus_typec0>; + + regulator-state-mem { + regulator-on-in-suspend; + regulator-suspend-microvolt = <12000000>; + }; + }; + }; }; &i2s0 { -- 2.24.1 ^ permalink raw reply related [flat|nested] 14+ messages in thread
[parent not found: <20200106211633.2882-6-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org>]
* Re: [PATCH 5/5] arm64: dts: rockchip: Enable mp8859 regulator on rk3399-roc-pc [not found] ` <20200106211633.2882-6-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> @ 2020-01-08 23:30 ` Heiko Stuebner 0 siblings, 0 replies; 14+ messages in thread From: Heiko Stuebner @ 2020-01-08 23:30 UTC (permalink / raw) To: Markus Reichl Cc: Mark Rutland, devicetree-u79uwXL29TY76Z2rM5mHXA, Liam Girdwood, Rob Herring, linux-kernel-u79uwXL29TY76Z2rM5mHXA, linux-rockchip-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r, Mark Brown, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r Am Montag, 6. Januar 2020, 22:16:28 CET schrieb Markus Reichl: > The rk3399-roc-pc uses a MP8859 DC/DC converter for 12V supply. > This supplies 5V only in default state after booting. > Now we can control the output voltage via I2C interface. > Add a node for the driver to reach 12V. > > Signed-off-by: Markus Reichl <m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> applied for 5.6 now that the driver-side got merged Thanks Heiko ^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH 0/5] regulator: mp8859: add driver for DC/DC converter used on rk3399-roc-pc board @ 2020-01-04 15:32 Markus Reichl 2020-01-04 15:32 ` [PATCH 3/5] dt-bindings: add vendor Monolithic Power Systems Markus Reichl 0 siblings, 1 reply; 14+ messages in thread From: Markus Reichl @ 2020-01-04 15:32 UTC (permalink / raw) To: linux-rockchip Cc: Markus Reichl, Angus Ainslie (Purism), devicetree, Heiko Stuebner, Jagan Teki, Laurent Pinchart, Linus Walleij, linux-arm-kernel, linux-kernel, Maxime Ripard, Rob Herring, Shawn Guo, Stephan Gerhold On rk3399-roc-pc board a voltage regulator MP8859 from Monolithic Power Systems is used to supply the 12V power line. This delivers 5V as a default value after boot. The voltage is controllable via I2C. Add a basic driver to set and get the voltage of the MP8859 and add a matching node with fixed 12V in the DT of the board. Markus Reichl (5): regulator: mp8859: add driver regulator: mp8859: add config option and build entry dt-bindings: add vendor Monolithic Power Systems dt-bindings: regulator: add MPS mp8859 voltage regulator arm64: dts: rockchip: Enable mp8859 regulator on rk3399-roc-pc .../devicetree/bindings/regulator/mp8859.txt | 22 +++ .../devicetree/bindings/vendor-prefixes.yaml | 2 + .../boot/dts/rockchip/rk3399-roc-pc.dtsi | 32 ++-- drivers/regulator/Kconfig | 11 ++ drivers/regulator/Makefile | 1 + drivers/regulator/mp8859.c | 156 ++++++++++++++++++ 6 files changed, 210 insertions(+), 14 deletions(-) create mode 100644 Documentation/devicetree/bindings/regulator/mp8859.txt create mode 100644 drivers/regulator/mp8859.c -- 2.24.1 ^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH 3/5] dt-bindings: add vendor Monolithic Power Systems 2020-01-04 15:32 [PATCH 0/5] regulator: mp8859: add driver for DC/DC converter used on rk3399-roc-pc board Markus Reichl @ 2020-01-04 15:32 ` Markus Reichl 0 siblings, 0 replies; 14+ messages in thread From: Markus Reichl @ 2020-01-04 15:32 UTC (permalink / raw) To: linux-rockchip, Rob Herring, Mark Rutland Cc: Markus Reichl, Maxime Ripard, Linus Walleij, Stephan Gerhold, Heiko Stuebner, Icenowy Zheng, Laurent Pinchart, devicetree, linux-kernel MPS produce power regulators like the MP8859. Signed-off-by: Markus Reichl <m.reichl@fivetechno.de> --- Documentation/devicetree/bindings/vendor-prefixes.yaml | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Documentation/devicetree/bindings/vendor-prefixes.yaml b/Documentation/devicetree/bindings/vendor-prefixes.yaml index fa6aa3c5a500..4fa3bb494745 100644 --- a/Documentation/devicetree/bindings/vendor-prefixes.yaml +++ b/Documentation/devicetree/bindings/vendor-prefixes.yaml @@ -617,6 +617,8 @@ patternProperties: description: Moxa Inc. "^mpl,.*": description: MPL AG + "^mps,.*": + description: Monolithic Power Systems Inc. "^mqmaker,.*": description: mqmaker Inc. "^mscc,.*": -- 2.24.1 ^ permalink raw reply related [flat|nested] 14+ messages in thread
end of thread, other threads:[~2020-01-08 23:30 UTC | newest] Thread overview: 14+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2020-01-06 21:16 [PATCH 0/5] regulator: mp8859: add driver for DC/DC converter used on rk3399-roc-pc board Markus Reichl 2020-01-06 21:16 ` [PATCH 1/5] regulator: mp8859: add driver Markus Reichl 2020-01-08 15:59 ` Applied "regulator: mp8859: add driver" to the regulator tree Mark Brown 2020-01-06 21:16 ` [PATCH 2/5] regulator: mp8859: add config option and build entry Markus Reichl [not found] ` <20200106211633.2882-3-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> 2020-01-06 21:22 ` Heiko Stübner 2020-01-07 7:29 ` Markus Reichl 2020-01-08 15:58 ` Applied "regulator: mp8859: add config option and build entry" to the regulator tree Mark Brown 2020-01-06 21:16 ` [PATCH 3/5] dt-bindings: add vendor Monolithic Power Systems Markus Reichl 2020-01-08 20:32 ` Rob Herring 2020-01-06 21:16 ` [PATCH 4/5] dt-bindings: regulator: add MPS mp8859 voltage regulator Markus Reichl [not found] ` <20200106211633.2882-5-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> 2020-01-08 15:58 ` Applied "regulator: bindings: add MPS mp8859 voltage regulator" to the regulator tree Mark Brown 2020-01-06 21:16 ` [PATCH 5/5] arm64: dts: rockchip: Enable mp8859 regulator on rk3399-roc-pc Markus Reichl [not found] ` <20200106211633.2882-6-m.reichl-SRyzfwRm/0rPTwkrwQOX7A@public.gmane.org> 2020-01-08 23:30 ` Heiko Stuebner -- strict thread matches above, loose matches on Subject: below -- 2020-01-04 15:32 [PATCH 0/5] regulator: mp8859: add driver for DC/DC converter used on rk3399-roc-pc board Markus Reichl 2020-01-04 15:32 ` [PATCH 3/5] dt-bindings: add vendor Monolithic Power Systems Markus Reichl
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).