pmaports/device/testing/linux-samsung-i927/0042-ARM-dts-tegra20-glide-Add-cameras-regulators.patch
Oliver Smith 64035ac463
device/*: move to device/testing/* ()
Prepare for better device categorization by moving everything to testing
subdir first.

[skip-ci]: chicken-egg problem: passing pmaports CI depends on pmbootstrap MR
				depends on this MR

Related: postmarketos#16
2020-03-14 08:35:32 +01:00

138 lines
3.8 KiB
Diff

From bce4b77a6c6ca82e4e0518c80444d3b879c7b60e Mon Sep 17 00:00:00 2001
From: Sergey Larin <cerg2010cerg2010@mail.ru>
Date: Thu, 20 Jun 2019 20:03:09 +0300
Subject: [PATCH] ARM: dts: tegra20-glide: Add cameras regulators
Cameras use multiple power sources on this board. Labels near the regulator
indicate the camera which uses the regulator and the order of powering on.
Also, the reset GPIO is specified to keep the info inside DT.
Signed-off-by: Sergey Larin <cerg2010cerg2010@mail.ru>
---
arch/arm/boot/dts/tegra20-glide.dts | 94 ++++++++++++++++++++++++++++-
1 file changed, 91 insertions(+), 3 deletions(-)
diff --git a/arch/arm/boot/dts/tegra20-glide.dts b/arch/arm/boot/dts/tegra20-glide.dts
index b55effa69fbe..f2af07aba8a3 100644
--- a/arch/arm/boot/dts/tegra20-glide.dts
+++ b/arch/arm/boot/dts/tegra20-glide.dts
@@ -578,6 +578,7 @@
/* Not supported - no DT binding */
/* m5mo@1f {
reg = <0x1f>;
+ reset-gpios = <&gpio TEGRA_GPIO(D, 2) GPIO_ACTIVE_HIGH>;
}; */
/* Not supported - no DT binding */
@@ -997,10 +998,48 @@
#address-cells = <1>;
#size-cells = <0>;
- /* Not supported - no driver?/no DT binding? */
- /* m5mo_pmic@3e {
+ max8893@3e {
+ compatible = "maxim,max8893";
reg = <0x3e>;
- }; */
+
+ regulators {
+ /* Front camera - s5k6aafx, back - m5mo */
+ /* Numbers used to indicate the sequence */
+ front_1_back_1: buck {
+ regulator-name = "cam_isp_core_1v2";
+ regulator-min-microvolt = <1200000>;
+ regulator-max-microvolt = <1200000>;
+ };
+
+ front_4_back_5: ldo1 {
+ regulator-name = "vt_io_1v8,cam_isp_1v8";
+ regulator-min-microvolt = <1800000>;
+ regulator-max-microvolt = <1800000>;
+ };
+
+ front_3_back_4: ldo2 {
+ regulator-name = "vt_core_1v5";
+ regulator-min-microvolt = <1500000>;
+ regulator-max-microvolt = <1500000>;
+ };
+
+ front_5_back_6: ldo3 {
+ regulator-name = "vt_cam_1v8,vt_sensor_io_1v8";
+ regulator-min-microvolt = <1800000>;
+ regulator-max-microvolt = <1800000>;
+ };
+
+ ldo4 {
+ /* not used */
+ };
+
+ back_7: ldo5 {
+ regulator-name = "cam_sensor_io_1v8";
+ regulator-min-microvolt = <1800000>;
+ regulator-max-microvolt = <1800000>;
+ };
+ };
+ };
};
i2c@17 {
@@ -1397,6 +1436,55 @@
// gpio = <&gpio TEGRA_GPIO(N, 6) GPIO_ACTIVE_HIGH>;
// gpio = <&gpio TEGRA_GPIO(B, 2) GPIO_ACTIVE_HIGH>;
};
+
+ front_2_back_3: regulator@5 {
+ compatible = "regulator-fixed";
+ reg = <5>;
+ regulator-name = "cam-pmic-en2";
+ /* voltage is unknown */
+ regulator-min-microvolt = <1800000>;
+ regulator-max-microvolt = <1800000>;
+ gpio = <&gpio TEGRA_GPIO(T, 3) GPIO_ACTIVE_HIGH>;
+ enable-active-high;
+ };
+
+ /*
+ * on m5mo, this needs to be disabled after
+ * cam-vt-nrst GPIO, but I don't know how to
+ * write this here properly. Probably will need
+ * to dance with pinmux?
+ */
+ front_6_back_8_10: regulator@6 {
+ compatible = "regulator-fixed";
+ reg = <6>;
+ regulator-name = "cam-vt-nstby";
+ /* voltage is unknown */
+ regulator-min-microvolt = <3300000>;
+ regulator-max-microvolt = <3300000>;
+ gpio = <&gpio TEGRA_GPIO(D, 5) GPIO_ACTIVE_HIGH>;
+ enable-active-high;
+ };
+
+ front_7_back_9: regulator@7 {
+ compatible = "regulator-fixed";
+ reg = <7>;
+ regulator-name = "cam-vt-nrst";
+ /* voltage is unknown */
+ regulator-min-microvolt = <1800000>;
+ regulator-max-microvolt = <1800000>;
+ gpio = <&gpio TEGRA_GPIO(T, 4) GPIO_ACTIVE_HIGH>;
+ enable-active-high;
+ };
+
+ back_2: regulator@8 {
+ compatible = "regulator-fixed";
+ reg = <8>;
+ regulator-name = "cam-mega-core-1p2-en";
+ regulator-min-microvolt = <1200000>;
+ regulator-max-microvolt = <1200000>;
+ gpio = <&gpio TEGRA_GPIO(R, 0) GPIO_ACTIVE_HIGH>;
+ enable-active-high;
+ };
};
sound {
--
2.22.0