Merge remote-tracking branches 'regulator/topic/s2mpa01', 'regulator/topic/supplies...
authorMark Brown <broonie@kernel.org>
Sun, 19 Feb 2017 16:40:41 +0000 (16:40 +0000)
committerMark Brown <broonie@kernel.org>
Sun, 19 Feb 2017 16:40:41 +0000 (16:40 +0000)
1  2  3  4 
drivers/regulator/core.c

index 6ea646466a072ebfd22cbfb67210202f7a2162d7,04baac9a165bbb56da292a51d0a56055947861e0,bcf67abd1cd2d66265e20b7953faf23b4d022d20,04baac9a165bbb56da292a51d0a56055947861e0..53d4fc70dbd0981cdb73eabdc815346c25963b6b
@@@@@ -1601,47 -1593,49 -1606,49 -1593,49 +1614,47 @@@@@ struct regulator *_regulator_get(struc
                return ERR_PTR(-EINVAL);
        }
    
 ---    if (dev)
 ---            devname = dev_name(dev);
  - 
  -     if (have_full_constraints())
  -             ret = -ENODEV;
  -     else
  -             ret = -EPROBE_DEFER;
  - 
  -     rdev = regulator_dev_lookup(dev, id, &ret);
  -     if (rdev)
  -             goto found;
 +++    rdev = regulator_dev_lookup(dev, id);
 +++    if (IS_ERR(rdev)) {
 +++            ret = PTR_ERR(rdev);
    
 - -    if (have_full_constraints())
 - -            ret = -ENODEV;
 - -    else
 - -            ret = -EPROBE_DEFER;
 - -
 - -    rdev = regulator_dev_lookup(dev, id, &ret);
 - -    if (rdev)
 - -            goto found;
 - -
 ---    regulator = ERR_PTR(ret);
 +++            /*
 +++             * If regulator_dev_lookup() fails with error other
 +++             * than -ENODEV our job here is done, we simply return it.
 +++             */
 +++            if (ret != -ENODEV)
 +++                    return ERR_PTR(ret);
    
 ---    /*
 ---     * If we have return value from dev_lookup fail, we do not expect to
 ---     * succeed, so, quit with appropriate error value
 ---     */
 ---    if (ret && ret != -ENODEV)
 ---            return regulator;
 +++            if (!have_full_constraints()) {
 +++                    dev_warn(dev,
 +++                             "incomplete constraints, dummy supplies not allowed\n");
 +++                    return ERR_PTR(-ENODEV);
 +++            }
    
 ---    if (!devname)
 ---            devname = "deviceless";
 +++            switch (get_type) {
 +++            case NORMAL_GET:
 +++                    /*
 +++                     * Assume that a regulator is physically present and
 +++                     * enabled, even if it isn't hooked up, and just
 +++                     * provide a dummy.
 +++                     */
 +++                    dev_warn(dev,
 +++                             "%s supply %s not found, using dummy regulator\n",
 +++                             devname, id);
 +++                    rdev = dummy_regulator_rdev;
 +++                    get_device(&rdev->dev);
 +++                    break;
    
 ---    /*
 ---     * Assume that a regulator is physically present and enabled
 ---     * even if it isn't hooked up and just provide a dummy.
 ---     */
 ---    if (have_full_constraints() && allow_dummy) {
 ---            pr_warn("%s supply %s not found, using dummy regulator\n",
 ---                    devname, id);
 +++            case EXCLUSIVE_GET:
 +++                    dev_warn(dev,
 +++                             "dummy supplies not allowed for exclusive requests\n");
 +++                    /* fall through */
    
 ---            rdev = dummy_regulator_rdev;
 ---            get_device(&rdev->dev);
 ---            goto found;
 ---    /* Don't log an error when called from regulator_get_optional() */
 ---    } else if (!have_full_constraints() || exclusive) {
 ---            dev_warn(dev, "dummy supplies not allowed\n");
 +++            default:
 +++                    return ERR_PTR(-ENODEV);
 +++            }
        }
    
 ---    return regulator;
 ---
 ---found:
        if (rdev->exclusive) {
                regulator = ERR_PTR(-EPERM);
                put_device(&rdev->dev);