184fbd619SBiju Das // SPDX-License-Identifier: GPL-2.0
284fbd619SBiju Das //
384fbd619SBiju Das // Renesas USB VBUS output regulator driver
484fbd619SBiju Das //
584fbd619SBiju Das // Copyright (C) 2024 Renesas Electronics Corporation
684fbd619SBiju Das //
784fbd619SBiju Das
884fbd619SBiju Das #include <linux/module.h>
984fbd619SBiju Das #include <linux/err.h>
1084fbd619SBiju Das #include <linux/kernel.h>
1184fbd619SBiju Das #include <linux/of.h>
1284fbd619SBiju Das #include <linux/platform_device.h>
1384fbd619SBiju Das #include <linux/regmap.h>
1484fbd619SBiju Das #include <linux/regulator/driver.h>
1584fbd619SBiju Das #include <linux/regulator/of_regulator.h>
1684fbd619SBiju Das
1784fbd619SBiju Das static const struct regulator_ops rzg2l_usb_vbus_reg_ops = {
1884fbd619SBiju Das .enable = regulator_enable_regmap,
1984fbd619SBiju Das .disable = regulator_disable_regmap,
2084fbd619SBiju Das .is_enabled = regulator_is_enabled_regmap,
2184fbd619SBiju Das };
2284fbd619SBiju Das
2384fbd619SBiju Das static const struct regulator_desc rzg2l_usb_vbus_rdesc = {
2484fbd619SBiju Das .name = "vbus",
2584fbd619SBiju Das .of_match = of_match_ptr("regulator-vbus"),
2684fbd619SBiju Das .ops = &rzg2l_usb_vbus_reg_ops,
2784fbd619SBiju Das .type = REGULATOR_VOLTAGE,
2884fbd619SBiju Das .owner = THIS_MODULE,
2984fbd619SBiju Das .enable_reg = 0,
3084fbd619SBiju Das .enable_mask = BIT(0),
3184fbd619SBiju Das .enable_is_inverted = true,
3284fbd619SBiju Das .fixed_uV = 5000000,
3384fbd619SBiju Das .n_voltages = 1,
3484fbd619SBiju Das };
3584fbd619SBiju Das
rzg2l_usb_vbus_regulator_probe(struct platform_device * pdev)3684fbd619SBiju Das static int rzg2l_usb_vbus_regulator_probe(struct platform_device *pdev)
3784fbd619SBiju Das {
3884fbd619SBiju Das struct regulator_config config = { };
3984fbd619SBiju Das struct device *dev = &pdev->dev;
4084fbd619SBiju Das struct regulator_dev *rdev;
4184fbd619SBiju Das
4284fbd619SBiju Das config.regmap = dev_get_regmap(dev->parent, NULL);
4384fbd619SBiju Das if (!config.regmap)
4484fbd619SBiju Das return dev_err_probe(dev, -ENOENT, "Failed to get regmap\n");
4584fbd619SBiju Das
4684fbd619SBiju Das config.dev = dev;
4784fbd619SBiju Das config.of_node = of_get_child_by_name(dev->parent->of_node, "regulator-vbus");
4884fbd619SBiju Das if (!config.of_node)
4984fbd619SBiju Das return dev_err_probe(dev, -ENODEV, "regulator node not found\n");
5084fbd619SBiju Das
5184fbd619SBiju Das rdev = devm_regulator_register(dev, &rzg2l_usb_vbus_rdesc, &config);
5284fbd619SBiju Das of_node_put(config.of_node);
53*7368e9f4SMarkus Elfring if (IS_ERR(rdev))
5484fbd619SBiju Das return dev_err_probe(dev, PTR_ERR(rdev),
5584fbd619SBiju Das "not able to register vbus regulator\n");
5684fbd619SBiju Das
5784fbd619SBiju Das return 0;
5884fbd619SBiju Das }
5984fbd619SBiju Das
6084fbd619SBiju Das static struct platform_driver rzg2l_usb_vbus_regulator_driver = {
6184fbd619SBiju Das .probe = rzg2l_usb_vbus_regulator_probe,
6284fbd619SBiju Das .driver = {
6384fbd619SBiju Das .name = "rzg2l-usb-vbus-regulator",
6484fbd619SBiju Das .probe_type = PROBE_PREFER_ASYNCHRONOUS,
6584fbd619SBiju Das },
6684fbd619SBiju Das };
6784fbd619SBiju Das module_platform_driver(rzg2l_usb_vbus_regulator_driver);
6884fbd619SBiju Das
6984fbd619SBiju Das MODULE_AUTHOR("Biju Das <biju.das.jz@bp.renesas.com>");
7084fbd619SBiju Das MODULE_DESCRIPTION("Renesas RZ/G2L USB Vbus Regulator Driver");
7184fbd619SBiju Das MODULE_LICENSE("GPL");
72