x86/platform/intel-mid: Mark regulators explicitly defined
authorAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Sat, 9 Jul 2016 13:45:29 +0000 (16:45 +0300)
committerIngo Molnar <mingo@kernel.org>
Sun, 10 Jul 2016 08:33:41 +0000 (10:33 +0200)
Intel MID platforms are using explicitly defined regulators.

Let the regulator core know that we do not have any additional
regulators left. This lets it substitute unprovided regulators with
dummy ones.

Without this change when CONFIG_REGULATOR=y the USB driver fails on getting
"vbus" regulator and SDHCI can't get "vmmc" and "vqmmc" regulators either.

Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Link: http://lkml.kernel.org/r/1468071929-77383-1-git-send-email-andriy.shevchenko@linux.intel.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
arch/x86/platform/intel-mid/intel-mid.c

index 90bb997ed0a21889fd95482bfe298862b46eaacf..abbf49c6e9d3525d9188ba7f13ef0bdfa740ff32 100644 (file)
@@ -16,6 +16,7 @@
 #include <linux/init.h>
 #include <linux/kernel.h>
 #include <linux/interrupt.h>
+#include <linux/regulator/machine.h>
 #include <linux/scatterlist.h>
 #include <linux/sfi.h>
 #include <linux/irq.h>
@@ -144,6 +145,15 @@ static void intel_mid_arch_setup(void)
 out:
        if (intel_mid_ops->arch_setup)
                intel_mid_ops->arch_setup();
+
+       /*
+        * Intel MID platforms are using explicitly defined regulators.
+        *
+        * Let the regulator core know that we do not have any additional
+        * regulators left. This lets it substitute unprovided regulators with
+        * dummy ones:
+        */
+       regulator_has_full_constraints();
 }
 
 /* MID systems don't have i8042 controller */