On Wed, Jun 19, 2019 at 04:20:11PM +0200, Fabien Parent wrote: > connectcts as a slave to a SoC using SPI, wrapped inside PWRAP. > > Signed-off-by: Fabien Parent <fparent@xxxxxxxxxxxx> This has your signoff... > +++ b/drivers/regulator/mt6392-regulator.c > @@ -0,0 +1,490 @@ > +// SPDX-License-Identifier: GPL-2.0 > +/* > + * Copyright (c) 2019 MediaTek Inc. > + * Author: Chen Zhong <chen.zhong@xxxxxxxxxxxx> > + */ ...but someone else from a different company wrote it? Also please make the entire header a C++ one so this looks more consistent. > +static const u32 ldo_volt_table2[] = { > + 3300000, 3400000, 3500000, 3600000, > +}; This looks like a linear range? > +static int mt6392_get_status(struct regulator_dev *rdev) > +{ > + int ret; > + u32 regval; > + struct mt6392_regulator_info *info = rdev_get_drvdata(rdev); > + > + ret = regmap_read(rdev->regmap, info->desc.enable_reg, ®val); > + if (ret != 0) { > + dev_err(&rdev->dev, "Failed to get enable reg: %d\n", ret); > + return ret; > + } > + > + return (regval & info->qi) ? REGULATOR_STATUS_ON : REGULATOR_STATUS_OFF; > +} This appears to just be reading back the enable bit, the status operation should only be implemented if it can check if the regulator is actually working. Please also don't use the ternery operator needlessly, just write normal conditional statements to help people read the code. > +static int mt6392_buck_set_mode(struct regulator_dev *rdev, unsigned int mode) > +{ > + int ret, val = 0; > + struct mt6392_regulator_info *info = rdev_get_drvdata(rdev); > + u32 reg_value; > + > + if (!info->modeset_mask) { > + dev_err(&rdev->dev, "regulator %s doesn't support set_mode\n", > + info->desc.name); > + return -EINVAL; > + } If a regulator doesn't have support for set_mode() the operation shouldn't be provided for it. > + ret = regmap_update_bits(rdev->regmap, info->modeset_reg, > + info->modeset_mask, val); > + > + if (regmap_read(rdev->regmap, info->modeset_reg, ®_value) < 0) { > + dev_err(&rdev->dev, "Failed to read register value\n"); > + return -EIO; > + } Why are we doing this read? It's not like anything even looks at the value. > +static int mt6392_set_buck_vosel_reg(struct platform_device *pdev) > +{ > + struct mt6397_chip *mt6392 = dev_get_drvdata(pdev->dev.parent); > + int i; > + u32 regval; > + > + for (i = 0; i < MT6392_MAX_REGULATOR; i++) { > + if (mt6392_regulators[i].vselctrl_reg) { > + if (regmap_read(mt6392->regmap, > + mt6392_regulators[i].vselctrl_reg, > + ®val) < 0) { > + dev_err(&pdev->dev, > + "Failed to read buck ctrl\n"); > + return -EIO; > + } The indentation here is seriously messed up, parts of the conditional statement are indented as far as the code block inside the conditional statement - usually the continuation of the condition would align with the (. > + > + if (regval & mt6392_regulators[i].vselctrl_mask) { > + mt6392_regulators[i].desc.vsel_reg = > + mt6392_regulators[i].vselon_reg; > + } Again here the indentation is weird, this is actually one statement in the { } but the second line isn't indented. I'm also not altogether clear why this function is doing what it's doing, some comments or something would be good at least. > + /* Constrain board-specific capabilities according to what > + * this driver and the chip itself can actually do. > + */ > + c = rdev->constraints; > + c->valid_modes_mask |= REGULATOR_MODE_NORMAL| > + REGULATOR_MODE_STANDBY | REGULATOR_MODE_FAST; > + c->valid_ops_mask |= REGULATOR_CHANGE_MODE; This is broken, the driver should absolutely not modify constraints. The driver isn't even doing what the comment says here, it's enabling permissions regardless of if they were enabled by the machine. > +static const struct of_device_id mt6392_of_match[] = { > + { .compatible = "mediatek,mt6392-regulator", }, > + { /* sentinel */ }, > +}; > +MODULE_DEVICE_TABLE(of, mt6392_of_match); There is no need for a compatible for this subfunction, it's specific to a single chip so we should be able to enumerate it just by enumerating that chip and this way of binding regulators is very Linux specific. Just have the MFD register the regulator device.
Attachment:
signature.asc
Description: PGP signature