* [U-Boot] [PATCH v3 1/5] tegra: usb gadget: fix ci udc operation if not hostpc capable
2016-09-15 7:27 [U-Boot] [PATCH v3 0/5] various fixes mainly for colibri_t20 Marcel Ziswiler
@ 2016-09-15 7:27 ` Marcel Ziswiler
2016-09-15 7:27 ` [U-Boot] [PATCH v3 2/5] simple panel: fix spelling of debug message Marcel Ziswiler
` (3 subsequent siblings)
4 siblings, 0 replies; 10+ messages in thread
From: Marcel Ziswiler @ 2016-09-15 7:27 UTC (permalink / raw)
To: u-boot
The Tegra 2 aka T20 is not host PC capable. Therefore gate the define
CONFIG_CI_UDC_HAS_HOSTPC in tegra-common-usb-gadget.h in case of
CONFIG_TEGRA20.
Signed-off-by: Marcel Ziswiler <marcel.ziswiler@toradex.com>
Acked-by: Stephen Warren <swarren@nvidia.com>
---
Changes in v3:
- Add Stephen's ack.
Changes in v2:
- As suggested by Stephen gating the CONFIG_CI_UDC_HAS_HOSTPC define
with CONFIG_TEGRA20 rather than duplicating the same into all other
SoC type specific header files.
include/configs/tegra-common-usb-gadget.h | 2 ++
1 file changed, 2 insertions(+)
diff --git a/include/configs/tegra-common-usb-gadget.h b/include/configs/tegra-common-usb-gadget.h
index 3e3eeea..2e492c1 100644
--- a/include/configs/tegra-common-usb-gadget.h
+++ b/include/configs/tegra-common-usb-gadget.h
@@ -10,7 +10,9 @@
#ifndef CONFIG_SPL_BUILD
/* USB gadget mode support*/
+#ifndef CONFIG_TEGRA20
#define CONFIG_CI_UDC_HAS_HOSTPC
+#endif
/* USB mass storage protocol */
#define CONFIG_USB_FUNCTION_MASS_STORAGE
/* DFU protocol */
--
2.5.5
^ permalink raw reply related [flat|nested] 10+ messages in thread* [U-Boot] [PATCH v3 2/5] simple panel: fix spelling of debug message
2016-09-15 7:27 [U-Boot] [PATCH v3 0/5] various fixes mainly for colibri_t20 Marcel Ziswiler
2016-09-15 7:27 ` [U-Boot] [PATCH v3 1/5] tegra: usb gadget: fix ci udc operation if not hostpc capable Marcel Ziswiler
@ 2016-09-15 7:27 ` Marcel Ziswiler
2016-09-15 7:27 ` [U-Boot] [PATCH v3 3/5] regulator: fixed: honour optionality of enable gpio Marcel Ziswiler
` (2 subsequent siblings)
4 siblings, 0 replies; 10+ messages in thread
From: Marcel Ziswiler @ 2016-09-15 7:27 UTC (permalink / raw)
To: u-boot
Fix spelling of debug message from cnnot to cannot.
Signed-off-by: Marcel Ziswiler <marcel.ziswiler@toradex.com>
Acked-by: Anatolij Gustschin <agust@denx.de>
---
Changes in v3:
- No change.
Changes in v2:
- Add Anatolij's ack.
drivers/video/simple_panel.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/drivers/video/simple_panel.c b/drivers/video/simple_panel.c
index b2fe345..baa95f6 100644
--- a/drivers/video/simple_panel.c
+++ b/drivers/video/simple_panel.c
@@ -42,7 +42,7 @@ static int simple_panel_ofdata_to_platdata(struct udevice *dev)
ret = uclass_get_device_by_phandle(UCLASS_REGULATOR, dev,
"power-supply", &priv->reg);
if (ret) {
- debug("%s: Warning: cnnot get power supply: ret=%d\n",
+ debug("%s: Warning: cannot get power supply: ret=%d\n",
__func__, ret);
if (ret != -ENOENT)
return ret;
--
2.5.5
^ permalink raw reply related [flat|nested] 10+ messages in thread* [U-Boot] [PATCH v3 3/5] regulator: fixed: honour optionality of enable gpio
2016-09-15 7:27 [U-Boot] [PATCH v3 0/5] various fixes mainly for colibri_t20 Marcel Ziswiler
2016-09-15 7:27 ` [U-Boot] [PATCH v3 1/5] tegra: usb gadget: fix ci udc operation if not hostpc capable Marcel Ziswiler
2016-09-15 7:27 ` [U-Boot] [PATCH v3 2/5] simple panel: fix spelling of debug message Marcel Ziswiler
@ 2016-09-15 7:27 ` Marcel Ziswiler
2016-09-15 8:15 ` Przemyslaw Marczak
2016-09-15 9:30 ` John Keeping
2016-09-15 7:27 ` [U-Boot] [PATCH v3 4/5] colibri_t20: fix display configuration Marcel Ziswiler
2016-09-15 7:27 ` [U-Boot] [PATCH v3 5/5] colibri_t20: fix usb operation and controller order Marcel Ziswiler
4 siblings, 2 replies; 10+ messages in thread
From: Marcel Ziswiler @ 2016-09-15 7:27 UTC (permalink / raw)
To: u-boot
According to the binding documentation the fixed regulator enable GPIO
is optional. However so far registration thereof failed if no enable
GPIO was specified. Fix this by making it entirely optional whether an
enable GPIO is used.
Signed-off-by: Marcel Ziswiler <marcel.ziswiler@toradex.com>
---
Changes in v3:
- Introduce new patch to honour optionality of fixed regulator enable
GPIO.
Changes in v2: None
drivers/power/regulator/fixed.c | 11 +++++++----
1 file changed, 7 insertions(+), 4 deletions(-)
diff --git a/drivers/power/regulator/fixed.c b/drivers/power/regulator/fixed.c
index 37b8400..c68da70 100644
--- a/drivers/power/regulator/fixed.c
+++ b/drivers/power/regulator/fixed.c
@@ -37,11 +37,12 @@ static int fixed_regulator_ofdata_to_platdata(struct udevice *dev)
/* Set type to fixed */
uc_pdata->type = REGULATOR_TYPE_FIXED;
- /* Get fixed regulator gpio desc */
+ /* Get fixed regulator optional enable GPIO desc */
gpio = &dev_pdata->gpio;
ret = gpio_request_by_name(dev, "gpio", 0, gpio, GPIOD_IS_OUT);
if (ret)
- debug("Fixed regulator gpio - not found! Error: %d", ret);
+ debug("Fixed reg optional enable GPIO - not found! Error: %d",
+ ret);
/* Get optional ramp up delay */
dev_pdata->startup_delay_us = fdtdec_get_uint(gd->fdt_blob,
@@ -87,8 +88,9 @@ static bool fixed_regulator_get_enable(struct udevice *dev)
{
struct fixed_regulator_platdata *dev_pdata = dev_get_platdata(dev);
+ /* Enable GPIO is optional */
if (!dev_pdata->gpio.dev)
- return false;
+ return true;
return dm_gpio_get_value(&dev_pdata->gpio);
}
@@ -98,8 +100,9 @@ static int fixed_regulator_set_enable(struct udevice *dev, bool enable)
struct fixed_regulator_platdata *dev_pdata = dev_get_platdata(dev);
int ret;
+ /* Enable GPIO is optional */
if (!dev_pdata->gpio.dev)
- return -ENOSYS;
+ return 0;
ret = dm_gpio_set_value(&dev_pdata->gpio, enable);
if (ret) {
--
2.5.5
^ permalink raw reply related [flat|nested] 10+ messages in thread* [U-Boot] [PATCH v3 3/5] regulator: fixed: honour optionality of enable gpio
2016-09-15 7:27 ` [U-Boot] [PATCH v3 3/5] regulator: fixed: honour optionality of enable gpio Marcel Ziswiler
@ 2016-09-15 8:15 ` Przemyslaw Marczak
2016-09-15 9:30 ` John Keeping
1 sibling, 0 replies; 10+ messages in thread
From: Przemyslaw Marczak @ 2016-09-15 8:15 UTC (permalink / raw)
To: u-boot
Hello Marcel,
On 09/15/2016 09:27 AM, Marcel Ziswiler wrote:
> According to the binding documentation the fixed regulator enable GPIO
> is optional. However so far registration thereof failed if no enable
> GPIO was specified. Fix this by making it entirely optional whether an
> enable GPIO is used.
>
> Signed-off-by: Marcel Ziswiler <marcel.ziswiler@toradex.com>
>
> ---
>
> Changes in v3:
> - Introduce new patch to honour optionality of fixed regulator enable
> GPIO.
>
> Changes in v2: None
>
> drivers/power/regulator/fixed.c | 11 +++++++----
> 1 file changed, 7 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/power/regulator/fixed.c b/drivers/power/regulator/fixed.c
> index 37b8400..c68da70 100644
> --- a/drivers/power/regulator/fixed.c
> +++ b/drivers/power/regulator/fixed.c
> @@ -37,11 +37,12 @@ static int fixed_regulator_ofdata_to_platdata(struct udevice *dev)
> /* Set type to fixed */
> uc_pdata->type = REGULATOR_TYPE_FIXED;
>
> - /* Get fixed regulator gpio desc */
> + /* Get fixed regulator optional enable GPIO desc */
> gpio = &dev_pdata->gpio;
> ret = gpio_request_by_name(dev, "gpio", 0, gpio, GPIOD_IS_OUT);
> if (ret)
> - debug("Fixed regulator gpio - not found! Error: %d", ret);
> + debug("Fixed reg optional enable GPIO - not found! Error: %d",
> + ret);
The "reg" is usually threated as a "register", so full word is better here.
>
> /* Get optional ramp up delay */
> dev_pdata->startup_delay_us = fdtdec_get_uint(gd->fdt_blob,
> @@ -87,8 +88,9 @@ static bool fixed_regulator_get_enable(struct udevice *dev)
> {
> struct fixed_regulator_platdata *dev_pdata = dev_get_platdata(dev);
>
> + /* Enable GPIO is optional */
> if (!dev_pdata->gpio.dev)
> - return false;
> + return true;
That is good fix :)
>
> return dm_gpio_get_value(&dev_pdata->gpio);
> }
> @@ -98,8 +100,9 @@ static int fixed_regulator_set_enable(struct udevice *dev, bool enable)
> struct fixed_regulator_platdata *dev_pdata = dev_get_platdata(dev);
> int ret;
>
> + /* Enable GPIO is optional */
> if (!dev_pdata->gpio.dev)
> - return -ENOSYS;
> + return 0;
>
> ret = dm_gpio_set_value(&dev_pdata->gpio, enable);
> if (ret) {
I don't think, that returning the 0 (success) is a good idea.
We should return some error value, because this is checked
by the regulator's command code.
User can be informed about what was happened - instead of getting
command succeed - but without any results behind the command.
Maybe the -ENOSYS is not the best here. What about -EPERM?
We could assume, that such operation is not permitted for this device.
Best regards,
--
Przemyslaw Marczak
Samsung R&D Institute Poland
Samsung Electronics
p.marczak at samsung.com
^ permalink raw reply [flat|nested] 10+ messages in thread* [U-Boot] [PATCH v3 3/5] regulator: fixed: honour optionality of enable gpio
2016-09-15 7:27 ` [U-Boot] [PATCH v3 3/5] regulator: fixed: honour optionality of enable gpio Marcel Ziswiler
2016-09-15 8:15 ` Przemyslaw Marczak
@ 2016-09-15 9:30 ` John Keeping
2016-09-15 18:58 ` Stephen Warren
1 sibling, 1 reply; 10+ messages in thread
From: John Keeping @ 2016-09-15 9:30 UTC (permalink / raw)
To: u-boot
On Thu, 15 Sep 2016 09:27:22 +0200, Marcel Ziswiler wrote:
> According to the binding documentation the fixed regulator enable GPIO
> is optional. However so far registration thereof failed if no enable
> GPIO was specified. Fix this by making it entirely optional whether an
> enable GPIO is used.
>
> Signed-off-by: Marcel Ziswiler <marcel.ziswiler@toradex.com>
>
> ---
>
> Changes in v3:
> - Introduce new patch to honour optionality of fixed regulator enable
> GPIO.
>
> Changes in v2: None
>
> drivers/power/regulator/fixed.c | 11 +++++++----
> 1 file changed, 7 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/power/regulator/fixed.c b/drivers/power/regulator/fixed.c
> index 37b8400..c68da70 100644
> --- a/drivers/power/regulator/fixed.c
> +++ b/drivers/power/regulator/fixed.c
> @@ -37,11 +37,12 @@ static int fixed_regulator_ofdata_to_platdata(struct udevice *dev)
> /* Set type to fixed */
> uc_pdata->type = REGULATOR_TYPE_FIXED;
>
> - /* Get fixed regulator gpio desc */
> + /* Get fixed regulator optional enable GPIO desc */
> gpio = &dev_pdata->gpio;
> ret = gpio_request_by_name(dev, "gpio", 0, gpio, GPIOD_IS_OUT);
> if (ret)
> - debug("Fixed regulator gpio - not found! Error: %d", ret);
> + debug("Fixed reg optional enable GPIO - not found! Error: %d",
> + ret);
If we're changing this, should we tighten up the error handling? It's
only ENOENT that we want to ignore here, other errors should probably
make fixed_regulator_ofdata_to_platdata() fail.
> /* Get optional ramp up delay */
> dev_pdata->startup_delay_us = fdtdec_get_uint(gd->fdt_blob,
> @@ -87,8 +88,9 @@ static bool fixed_regulator_get_enable(struct udevice *dev)
> {
> struct fixed_regulator_platdata *dev_pdata = dev_get_platdata(dev);
>
> + /* Enable GPIO is optional */
> if (!dev_pdata->gpio.dev)
> - return false;
> + return true;
This looks much better to me (I thought I had a similar change locally
but I can't find it now).
> return dm_gpio_get_value(&dev_pdata->gpio);
> }
> @@ -98,8 +100,9 @@ static int fixed_regulator_set_enable(struct udevice *dev, bool enable)
> struct fixed_regulator_platdata *dev_pdata = dev_get_platdata(dev);
> int ret;
>
> + /* Enable GPIO is optional */
> if (!dev_pdata->gpio.dev)
> - return -ENOSYS;
> + return 0;
I'm not sure about this change, the current behaviour seems correct to
me. After this we're pretending that fixed_set_enable(dev, false) has
succeeded, when it has not.
> ret = dm_gpio_set_value(&dev_pdata->gpio, enable);
> if (ret) {
^ permalink raw reply [flat|nested] 10+ messages in thread* [U-Boot] [PATCH v3 3/5] regulator: fixed: honour optionality of enable gpio
2016-09-15 9:30 ` John Keeping
@ 2016-09-15 18:58 ` Stephen Warren
0 siblings, 0 replies; 10+ messages in thread
From: Stephen Warren @ 2016-09-15 18:58 UTC (permalink / raw)
To: u-boot
On 09/15/2016 03:30 AM, John Keeping wrote:
> On Thu, 15 Sep 2016 09:27:22 +0200, Marcel Ziswiler wrote:
>
>> According to the binding documentation the fixed regulator enable GPIO
>> is optional. However so far registration thereof failed if no enable
>> GPIO was specified. Fix this by making it entirely optional whether an
>> enable GPIO is used.
>> @@ -98,8 +100,9 @@ static int fixed_regulator_set_enable(struct udevice *dev, bool enable)
>> struct fixed_regulator_platdata *dev_pdata = dev_get_platdata(dev);
>> int ret;
>>
>> + /* Enable GPIO is optional */
>> if (!dev_pdata->gpio.dev)
>> - return -ENOSYS;
>> + return 0;
>
> I'm not sure about this change, the current behaviour seems correct to
> me. After this we're pretending that fixed_set_enable(dev, false) has
> succeeded, when it has not.
That should probably be:
if (!dev_pdata->gpio.dev) {
if (!enable)
return -ENOSYS
return 0;
}
^ permalink raw reply [flat|nested] 10+ messages in thread
* [U-Boot] [PATCH v3 4/5] colibri_t20: fix display configuration
2016-09-15 7:27 [U-Boot] [PATCH v3 0/5] various fixes mainly for colibri_t20 Marcel Ziswiler
` (2 preceding siblings ...)
2016-09-15 7:27 ` [U-Boot] [PATCH v3 3/5] regulator: fixed: honour optionality of enable gpio Marcel Ziswiler
@ 2016-09-15 7:27 ` Marcel Ziswiler
2016-09-15 18:59 ` Stephen Warren
2016-09-15 7:27 ` [U-Boot] [PATCH v3 5/5] colibri_t20: fix usb operation and controller order Marcel Ziswiler
4 siblings, 1 reply; 10+ messages in thread
From: Marcel Ziswiler @ 2016-09-15 7:27 UTC (permalink / raw)
To: u-boot
Without this patch the following error will be shown:
stdio_add_devices: Video device failed (ret=-22)
As commit ec5507707a1d1e84056a6c864338f95f6118d3ca (video: tegra: Move
to using simple-panel and pwm-backlight) states the Colibri T20 needs
updating too which this patch finally attempts doing.
Signed-off-by: Marcel Ziswiler <marcel.ziswiler@toradex.com>
---
Changes in v3:
- Get rid of dummy N/C GPIO work around now as the fixed regulator
properly honours optionality of enable GPIO.
Changes in v2:
- Rename dummy regulator to reg_3v3 as suggested by Stephen.
- Keep dummy N/C GPIO to work around bug in U-Boot regulator driver
requiring such node despite its binding claiming it being optional.
arch/arm/dts/tegra20-colibri.dts | 71 +++++++++++++++++++++++++++++-----------
1 file changed, 51 insertions(+), 20 deletions(-)
diff --git a/arch/arm/dts/tegra20-colibri.dts b/arch/arm/dts/tegra20-colibri.dts
index 2cf24d3..5b803d9 100644
--- a/arch/arm/dts/tegra20-colibri.dts
+++ b/arch/arm/dts/tegra20-colibri.dts
@@ -21,12 +21,24 @@
};
host1x at 50000000 {
- status = "okay";
dc at 54200000 {
- status = "okay";
rgb {
status = "okay";
nvidia,panel = <&lcd_panel>;
+ display-timings {
+ timing at 0 {
+ /* VESA VGA */
+ clock-frequency = <25175000>;
+ hactive = <640>;
+ vactive = <480>;
+ hback-porch = <48>;
+ hfront-porch = <16>;
+ hsync-len = <96>;
+ vback-porch = <31>;
+ vfront-porch = <11>;
+ vsync-len = <2>;
+ };
+ };
};
};
};
@@ -60,6 +72,10 @@
};
};
+ pwm at 7000a000 {
+ status = "okay";
+ };
+
/*
* GEN1_I2C: I2C_SDA/SCL on SODIMM pin 194/196 (e.g. RTC on carrier
* board)
@@ -91,6 +107,18 @@
cd-gpios = <&gpio TEGRA_GPIO(C, 7) GPIO_ACTIVE_LOW>;
};
+ backlight: backlight {
+ compatible = "pwm-backlight";
+
+ brightness-levels = <255 128 64 32 16 8 4 0>;
+ default-brightness-level = <6>;
+ /* BL_ON */
+ enable-gpios = <&gpio TEGRA_GPIO(T, 4) GPIO_ACTIVE_HIGH>;
+ power-supply = <®_3v3>;
+ /* PWM<A> */
+ pwms = <&pwm 0 5000000>;
+ };
+
clocks {
compatible = "simple-bus";
#address-cells = <1>;
@@ -104,25 +132,28 @@
};
};
- pwm: pwm at 7000a000 {
- status = "okay";
+ lcd_panel: panel {
+ /*
+ * edt,et057090dhu: EDT 5.7" LCD TFT
+ * edt,et070080dh6: EDT 7.0" LCD TFT
+ */
+ compatible = "edt,et057090dhu", "simple-panel";
+
+ backlight = <&backlight>;
};
- lcd_panel: panel {
- clock = <25175000>;
- xres = <640>;
- yres = <480>;
- left-margin = <48>; /* horizontal back porch */
- right-margin = <16>; /* horizontal front porch */
- hsync-len = <96>;
- lower-margin = <11>; /* vertical front porch */
- upper-margin = <31>; /* vertical back porch */
- vsync-len = <2>;
- hsync-active-high;
- vsync-active-high;
- nvidia,bits-per-pixel = <16>;
- nvidia,pwm = <&pwm 0 0>;
- nvidia,backlight-enable-gpios = <&gpio TEGRA_GPIO(T, 4) GPIO_ACTIVE_HIGH>;
- nvidia,panel-timings = <0 0 0 0>;
+ regulators {
+ compatible = "simple-bus";
+ #address-cells = <1>;
+ #size-cells = <0>;
+
+ reg_3v3: regulator at 0 {
+ compatible = "regulator-fixed";
+ reg = <0>;
+ regulator-name = "+V3.3";
+ regulator-min-microvolt = <3300000>;
+ regulator-max-microvolt = <3300000>;
+ regulator-always-on;
+ };
};
};
--
2.5.5
^ permalink raw reply related [flat|nested] 10+ messages in thread* [U-Boot] [PATCH v3 4/5] colibri_t20: fix display configuration
2016-09-15 7:27 ` [U-Boot] [PATCH v3 4/5] colibri_t20: fix display configuration Marcel Ziswiler
@ 2016-09-15 18:59 ` Stephen Warren
0 siblings, 0 replies; 10+ messages in thread
From: Stephen Warren @ 2016-09-15 18:59 UTC (permalink / raw)
To: u-boot
On 09/15/2016 01:27 AM, Marcel Ziswiler wrote:
> Without this patch the following error will be shown:
>
> stdio_add_devices: Video device failed (ret=-22)
>
> As commit ec5507707a1d1e84056a6c864338f95f6118d3ca (video: tegra: Move
> to using simple-panel and pwm-backlight) states the Colibri T20 needs
> updating too which this patch finally attempts doing.
I haven't looked at this in any detail at all, but the one thing that
stood out to me before is fixed, so,
Acked-by: Stephen Warren <swarren@nvidia.com>
^ permalink raw reply [flat|nested] 10+ messages in thread
* [U-Boot] [PATCH v3 5/5] colibri_t20: fix usb operation and controller order
2016-09-15 7:27 [U-Boot] [PATCH v3 0/5] various fixes mainly for colibri_t20 Marcel Ziswiler
` (3 preceding siblings ...)
2016-09-15 7:27 ` [U-Boot] [PATCH v3 4/5] colibri_t20: fix display configuration Marcel Ziswiler
@ 2016-09-15 7:27 ` Marcel Ziswiler
4 siblings, 0 replies; 10+ messages in thread
From: Marcel Ziswiler @ 2016-09-15 7:27 UTC (permalink / raw)
To: u-boot
Without this patch the following error will be shown:
Colibri T20 # usb start
starting USB...
No controllers found
This patch fixes USB operation and also the controller order as the
CI UDC driver may only be instantiated on the first aka OTG port.
Signed-off-by: Marcel Ziswiler <marcel.ziswiler@toradex.com>
Acked-by: Stephen Warren <swarren@nvidia.com>
---
Changes in v3:
- Add Stephen's ack.
Changes in v2:
- No change.
- As suggested by Stephen remove last patch 5/5 colibri_t20: enable dfu
also for nand.
arch/arm/dts/tegra20-colibri.dts | 45 +++++++++++++++++++++-------------------
1 file changed, 24 insertions(+), 21 deletions(-)
diff --git a/arch/arm/dts/tegra20-colibri.dts b/arch/arm/dts/tegra20-colibri.dts
index 5b803d9..6bc8c49 100644
--- a/arch/arm/dts/tegra20-colibri.dts
+++ b/arch/arm/dts/tegra20-colibri.dts
@@ -14,10 +14,10 @@
i2c0 = "/i2c at 7000d000";
i2c1 = "/i2c at 7000c000";
i2c2 = "/i2c at 7000c400";
- usb0 = "/usb at c5008000";
- usb1 = "/usb at c5000000";
- usb2 = "/usb at c5004000";
sdhci0 = "/sdhci at c8000600";
+ usb0 = "/usb at c5000000";
+ usb1 = "/usb at c5004000"; /* on-module only, for ASIX */
+ usb2 = "/usb at c5008000";
};
host1x at 50000000 {
@@ -43,24 +43,6 @@
};
};
- usb at c5000000 {
- statuc = "okay";
- dr_mode = "otg";
- };
-
- usb at c5004000 {
- statuc = "okay";
- /* VBUS_LAN */
- nvidia,phy-reset-gpio = <&gpio TEGRA_GPIO(V, 1) GPIO_ACTIVE_HIGH>;
- nvidia,vbus-gpio = <&gpio TEGRA_GPIO(BB, 1) GPIO_ACTIVE_HIGH>;
- };
-
- usb at c5008000 {
- statuc = "okay";
- /* USBH_PEN */
- nvidia,vbus-gpio = <&gpio TEGRA_GPIO(W, 2) GPIO_ACTIVE_LOW>;
- };
-
nand-controller at 70008000 {
nvidia,wp-gpios = <&gpio TEGRA_GPIO(S, 0) GPIO_ACTIVE_HIGH>;
nvidia,width = <8>;
@@ -101,6 +83,27 @@
clock-frequency = <100000>;
};
+ /* EHCI instance 0: USB1_DP/N -> USBC_P/N */
+ usb at c5000000 {
+ status = "okay";
+ dr_mode = "otg";
+ };
+
+ /* EHCI instance 1: ULPI -> USB3340 -> AX88772B */
+ usb at c5004000 {
+ status = "okay";
+ /* VBUS_LAN */
+ nvidia,phy-reset-gpio = <&gpio TEGRA_GPIO(V, 1) GPIO_ACTIVE_HIGH>;
+ nvidia,vbus-gpio = <&gpio TEGRA_GPIO(BB, 1) GPIO_ACTIVE_HIGH>;
+ };
+
+ /* EHCI instance 2: USB3_DP/N -> USBH_P/N */
+ usb at c5008000 {
+ status = "okay";
+ /* USBH_PEN */
+ nvidia,vbus-gpio = <&gpio TEGRA_GPIO(W, 2) GPIO_ACTIVE_LOW>;
+ };
+
sdhci at c8000600 {
status = "okay";
bus-width = <4>;
--
2.5.5
^ permalink raw reply related [flat|nested] 10+ messages in thread