瀏覽代碼

Merge remote-tracking branch 'regulator/topic/bypass' into regulator-next

Mark Brown 9 年之前
父節點
當前提交
75941a1ba3
共有 1 個文件被更改,包括 14 次插入0 次删除
  1. 14 0
      drivers/regulator/core.c

+ 14 - 0
drivers/regulator/core.c

@@ -3116,6 +3116,20 @@ EXPORT_SYMBOL_GPL(regulator_sync_voltage);
 static int _regulator_get_voltage(struct regulator_dev *rdev)
 {
 	int sel, ret;
+	bool bypassed;
+
+	if (rdev->desc->ops->get_bypass) {
+		ret = rdev->desc->ops->get_bypass(rdev, &bypassed);
+		if (ret < 0)
+			return ret;
+		if (bypassed) {
+			/* if bypassed the regulator must have a supply */
+			if (!rdev->supply)
+				return -EINVAL;
+
+			return _regulator_get_voltage(rdev->supply->rdev);
+		}
+	}
 
 	if (rdev->desc->ops->get_voltage_sel) {
 		sel = rdev->desc->ops->get_voltage_sel(rdev);