* [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation
@ 2016-04-06 11:37 Dan Murphy
2016-04-06 11:38 ` [U-Boot] [uboot][PATCH v3 2/2] net: phy: ti: Allow the driver to be more configurable Dan Murphy
2016-04-07 4:45 ` [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation Mugunthan V N
0 siblings, 2 replies; 8+ messages in thread
From: Dan Murphy @ 2016-04-06 11:37 UTC (permalink / raw)
To: u-boot
Add the device tree bindings and the accompanying documentation
for the TI DP83867 Giga bit ethernet phy driver.
The original document was from:
[commit 2a10154abcb75ad0d7b6bfea6210ac743ec60897 from the Linux kernel]
Signed-off-by: Dan Murphy <dmurphy@ti.com>
---
v3 - Modify the binding to the kernel changed int -> internal for the delay - https://patchwork.ozlabs.org/patch/606595/
doc/device-tree-bindings/net/ti,dp83867.txt | 29 ++++++++++++++++++++++++
include/dt-bindings/net/ti-dp83867.h | 35 +++++++++++++++++++++++++++++
2 files changed, 64 insertions(+)
create mode 100644 doc/device-tree-bindings/net/ti,dp83867.txt
create mode 100644 include/dt-bindings/net/ti-dp83867.h
diff --git a/doc/device-tree-bindings/net/ti,dp83867.txt b/doc/device-tree-bindings/net/ti,dp83867.txt
new file mode 100644
index 0000000..0ec009c
--- /dev/null
+++ b/doc/device-tree-bindings/net/ti,dp83867.txt
@@ -0,0 +1,29 @@
+* Texas Instruments - dp83867 Giga bit ethernet phy
+
+Required properties:
+ - ti,rx-internal-delay - RGMII Recieve Clock Delay - see dt-bindings/net/ti-dp83867.h
+ for applicable values
+ - ti,tx-internal-delay - RGMII Transmit Clock Delay - see dt-bindings/net/ti-dp83867.h
+ for applicable values
+ - ti,fifo-depth - Transmitt FIFO depth- see dt-bindings/net/ti-dp83867.h
+ for applicable values
+
+Default child nodes are standard Ethernet PHY device
+nodes as described in doc/devicetree/bindings/net/ethernet.txt
+
+Example:
+
+&mac {
+ pinctrl-0 = <&davinci_mdio_default>;
+ pinctrl-1 = <&davinci_mdio_sleep>;
+ status = "okay";
+
+ ti,rx_internal_delay = <DP83867_RGMIIDCTL_1_50_NS>;
+ ti,tx_internal_delay = <DP83867_RGMIIDCTL_2_50_NS>;
+ ti,fifo_depth = <DP83867_PHYCR_FIFO_DEPTH_8_B_NIB>;
+
+};
+
+
+Datasheet can be found:
+http://www.ti.com/product/DP83867IR/datasheet
diff --git a/include/dt-bindings/net/ti-dp83867.h b/include/dt-bindings/net/ti-dp83867.h
new file mode 100644
index 0000000..5c592fb
--- /dev/null
+++ b/include/dt-bindings/net/ti-dp83867.h
@@ -0,0 +1,35 @@
+/*
+ * TI DP83867 PHY drivers
+ *
+ * SPDX-License-Identifier: GPL-2.0
+ *
+ */
+
+#ifndef _DT_BINDINGS_TI_DP83867_H
+#define _DT_BINDINGS_TI_DP83867_H
+
+/* PHY CTRL bits */
+#define DP83867_PHYCR_FIFO_DEPTH_3_B_NIB 0x00
+#define DP83867_PHYCR_FIFO_DEPTH_4_B_NIB 0x01
+#define DP83867_PHYCR_FIFO_DEPTH_6_B_NIB 0x02
+#define DP83867_PHYCR_FIFO_DEPTH_8_B_NIB 0x03
+
+/* RGMIIDCTL internal delay for rx and tx */
+#define DP83867_RGMIIDCTL_250_PS 0x0
+#define DP83867_RGMIIDCTL_500_PS 0x1
+#define DP83867_RGMIIDCTL_750_PS 0x2
+#define DP83867_RGMIIDCTL_1_NS 0x3
+#define DP83867_RGMIIDCTL_1_25_NS 0x4
+#define DP83867_RGMIIDCTL_1_50_NS 0x5
+#define DP83867_RGMIIDCTL_1_75_NS 0x6
+#define DP83867_RGMIIDCTL_2_00_NS 0x7
+#define DP83867_RGMIIDCTL_2_25_NS 0x8
+#define DP83867_RGMIIDCTL_2_50_NS 0x9
+#define DP83867_RGMIIDCTL_2_75_NS 0xa
+#define DP83867_RGMIIDCTL_3_00_NS 0xb
+#define DP83867_RGMIIDCTL_3_25_NS 0xc
+#define DP83867_RGMIIDCTL_3_50_NS 0xd
+#define DP83867_RGMIIDCTL_3_75_NS 0xe
+#define DP83867_RGMIIDCTL_4_00_NS 0xf
+
+#endif
--
2.8.0.rc3
^ permalink raw reply related [flat|nested] 8+ messages in thread
* [U-Boot] [uboot][PATCH v3 2/2] net: phy: ti: Allow the driver to be more configurable
2016-04-06 11:37 [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation Dan Murphy
@ 2016-04-06 11:38 ` Dan Murphy
2016-04-07 4:45 ` [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation Mugunthan V N
1 sibling, 0 replies; 8+ messages in thread
From: Dan Murphy @ 2016-04-06 11:38 UTC (permalink / raw)
To: u-boot
Not all devices use the same internal delay or fifo depth.
Add the ability to set the internal delay for rx or tx and the
fifo depth via the devicetree. If the value is not set in the
devicetree then set the delay to the default.
If devicetree is not used then use the default defines within the
driver.
Signed-off-by: Dan Murphy <dmurphy@ti.com>
---
v3 - Modify the binding to the kernel changed int -> internal for the delay - https://patchwork.ozlabs.org/patch/606595/
drivers/net/phy/ti.c | 81 ++++++++++++++++++++++++++++++++++++++++++++++------
1 file changed, 73 insertions(+), 8 deletions(-)
diff --git a/drivers/net/phy/ti.c b/drivers/net/phy/ti.c
index c3912d5..c32b9fd 100644
--- a/drivers/net/phy/ti.c
+++ b/drivers/net/phy/ti.c
@@ -6,6 +6,14 @@
*/
#include <common.h>
#include <phy.h>
+#include <linux/compat.h>
+#include <malloc.h>
+
+#include <fdtdec.h>
+#include <dm.h>
+#include <dt-bindings/net/ti-dp83867.h>
+
+DECLARE_GLOBAL_DATA_PTR;
/* TI DP83867 */
#define DP83867_DEVADDR 0x1f
@@ -57,6 +65,17 @@
#define MII_MMD_CTRL_INCR_RDWT 0x8000 /* post increment on reads & writes */
#define MII_MMD_CTRL_INCR_ON_WT 0xC000 /* post increment on writes only */
+/* User setting - can be taken from DTS */
+#define DEFAULT_RX_ID_DELAY DP83867_RGMIIDCTL_2_25_NS
+#define DEFAULT_TX_ID_DELAY DP83867_RGMIIDCTL_2_75_NS
+#define DEFAULT_FIFO_DEPTH DP83867_PHYCR_FIFO_DEPTH_4_B_NIB
+
+struct dp83867_private {
+ int rx_id_delay;
+ int tx_id_delay;
+ int fifo_depth;
+};
+
/**
* phy_read_mmd_indirect - reads data from the MMD registers
* @phydev: The PHY device bus
@@ -134,16 +153,58 @@ static inline bool phy_interface_is_rgmii(struct phy_device *phydev)
phydev->interface <= PHY_INTERFACE_MODE_RGMII_TXID;
}
-/* User setting - can be taken from DTS */
-#define RX_ID_DELAY 8
-#define TX_ID_DELAY 0xa
-#define FIFO_DEPTH 1
+#if defined(CONFIG_DM_ETH)
+/**
+ * dp83867_data_init - Convenience function for setting PHY specific data
+ *
+ * @phydev: the phy_device struct
+ */
+static int dp83867_of_init(struct phy_device *phydev)
+{
+ struct dp83867_private *dp83867 = phydev->priv;
+ struct udevice *dev = phydev->dev;
+
+ dp83867->rx_id_delay = fdtdec_get_uint(gd->fdt_blob, dev->of_offset,
+ "ti,rx_internal_delay", DEFAULT_RX_ID_DELAY);
+
+ dp83867->tx_id_delay = fdtdec_get_uint(gd->fdt_blob, dev->of_offset,
+ "ti,tx_internal_delay", DEFAULT_TX_ID_DELAY);
+
+ dp83867->fifo_depth = fdtdec_get_uint(gd->fdt_blob, dev->of_offset,
+ "ti,fifo_depth", DEFAULT_FIFO_DEPTH);
+
+ return 0;
+}
+#else
+static int dp83867_of_init(struct phy_device *phydev)
+{
+ dp83867->rx_id_delay = DEFAULT_RX_ID_DELAY;
+ dp83867->tx_id_delay = DEFAULT_TX_ID_DELAY;
+ dp83867->fifo_depth = DEFAULT_FIFO_DEPTH;
+
+ return 0;
+}
+#endif
static int dp83867_config(struct phy_device *phydev)
{
+ struct dp83867_private *dp83867;
unsigned int val, delay;
int ret;
+ if (!phydev->priv) {
+ dp83867 = kzalloc(sizeof(*dp83867), GFP_KERNEL);
+ if (!dp83867)
+ return -ENOMEM;
+
+ phydev->priv = dp83867;
+ ret = dp83867_of_init(phydev);
+ if (ret)
+ goto err_out;
+ } else {
+ dp83867 = (struct dp83867_private *)phydev->priv;
+ }
+
/* Restart the PHY. */
val = phy_read(phydev, MDIO_DEVAD_NONE, DP83867_CTRL);
phy_write(phydev, MDIO_DEVAD_NONE, DP83867_CTRL,
@@ -152,9 +213,9 @@ static int dp83867_config(struct phy_device *phydev)
if (phy_interface_is_rgmii(phydev)) {
ret = phy_write(phydev, MDIO_DEVAD_NONE, MII_DP83867_PHYCTRL,
(DP83867_MDI_CROSSOVER_AUTO << DP83867_MDI_CROSSOVER) |
- (FIFO_DEPTH << DP83867_PHYCR_FIFO_DEPTH_SHIFT));
+ (dp83867->fifo_depth << DP83867_PHYCR_FIFO_DEPTH_SHIFT));
if (ret)
- return ret;
+ goto err_out;
}
if ((phydev->interface >= PHY_INTERFACE_MODE_RGMII_ID) &&
@@ -175,8 +236,8 @@ static int dp83867_config(struct phy_device *phydev)
phy_write_mmd_indirect(phydev, DP83867_RGMIICTL,
DP83867_DEVADDR, phydev->addr, val);
- delay = (RX_ID_DELAY |
- (TX_ID_DELAY << DP83867_RGMII_TX_CLK_DELAY_SHIFT));
+ delay = (dp83867->rx_id_delay |
+ (dp83867->tx_id_delay << DP83867_RGMII_TX_CLK_DELAY_SHIFT));
phy_write_mmd_indirect(phydev, DP83867_RGMIIDCTL,
DP83867_DEVADDR, phydev->addr, delay);
@@ -184,6 +245,10 @@ static int dp83867_config(struct phy_device *phydev)
genphy_config_aneg(phydev);
return 0;
+
+err_out:
+ kfree(dp83867);
+ return ret;
}
static struct phy_driver DP83867_driver = {
--
2.8.0.rc3
^ permalink raw reply related [flat|nested] 8+ messages in thread
* [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation
2016-04-06 11:37 [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation Dan Murphy
2016-04-06 11:38 ` [U-Boot] [uboot][PATCH v3 2/2] net: phy: ti: Allow the driver to be more configurable Dan Murphy
@ 2016-04-07 4:45 ` Mugunthan V N
2016-04-07 16:02 ` Dan Murphy
1 sibling, 1 reply; 8+ messages in thread
From: Mugunthan V N @ 2016-04-07 4:45 UTC (permalink / raw)
To: u-boot
On Wednesday 06 April 2016 05:07 PM, Dan Murphy wrote:
> Add the device tree bindings and the accompanying documentation
> for the TI DP83867 Giga bit ethernet phy driver.
>
> The original document was from:
> [commit 2a10154abcb75ad0d7b6bfea6210ac743ec60897 from the Linux kernel]
>
> Signed-off-by: Dan Murphy <dmurphy@ti.com>
> ---
>
> v3 - Modify the binding to the kernel changed int -> internal for the delay - https://patchwork.ozlabs.org/patch/606595/
>
> doc/device-tree-bindings/net/ti,dp83867.txt | 29 ++++++++++++++++++++++++
> include/dt-bindings/net/ti-dp83867.h | 35 +++++++++++++++++++++++++++++
> 2 files changed, 64 insertions(+)
> create mode 100644 doc/device-tree-bindings/net/ti,dp83867.txt
> create mode 100644 include/dt-bindings/net/ti-dp83867.h
>
> diff --git a/doc/device-tree-bindings/net/ti,dp83867.txt b/doc/device-tree-bindings/net/ti,dp83867.txt
> new file mode 100644
> index 0000000..0ec009c
> --- /dev/null
> +++ b/doc/device-tree-bindings/net/ti,dp83867.txt
> @@ -0,0 +1,29 @@
> +* Texas Instruments - dp83867 Giga bit ethernet phy
> +
> +Required properties:
> + - ti,rx-internal-delay - RGMII Recieve Clock Delay - see dt-bindings/net/ti-dp83867.h
> + for applicable values
> + - ti,tx-internal-delay - RGMII Transmit Clock Delay - see dt-bindings/net/ti-dp83867.h
> + for applicable values
> + - ti,fifo-depth - Transmitt FIFO depth- see dt-bindings/net/ti-dp83867.h
> + for applicable values
> +
> +Default child nodes are standard Ethernet PHY device
> +nodes as described in doc/devicetree/bindings/net/ethernet.txt
> +
> +Example:
> +
> +&mac {
> + pinctrl-0 = <&davinci_mdio_default>;
> + pinctrl-1 = <&davinci_mdio_sleep>;
> + status = "okay";
> +
> + ti,rx_internal_delay = <DP83867_RGMIIDCTL_1_50_NS>;
> + ti,tx_internal_delay = <DP83867_RGMIIDCTL_2_50_NS>;
> + ti,fifo_depth = <DP83867_PHYCR_FIFO_DEPTH_8_B_NIB>;
> +
> +};
This example should in phy node and not in mac node as per the linux
commmit mentioned above?
Regards
Mugunthan V N
> +
> +
> +Datasheet can be found:
> +http://www.ti.com/product/DP83867IR/datasheet
> diff --git a/include/dt-bindings/net/ti-dp83867.h b/include/dt-bindings/net/ti-dp83867.h
> new file mode 100644
> index 0000000..5c592fb
> --- /dev/null
> +++ b/include/dt-bindings/net/ti-dp83867.h
> @@ -0,0 +1,35 @@
> +/*
> + * TI DP83867 PHY drivers
> + *
> + * SPDX-License-Identifier: GPL-2.0
> + *
> + */
> +
> +#ifndef _DT_BINDINGS_TI_DP83867_H
> +#define _DT_BINDINGS_TI_DP83867_H
> +
> +/* PHY CTRL bits */
> +#define DP83867_PHYCR_FIFO_DEPTH_3_B_NIB 0x00
> +#define DP83867_PHYCR_FIFO_DEPTH_4_B_NIB 0x01
> +#define DP83867_PHYCR_FIFO_DEPTH_6_B_NIB 0x02
> +#define DP83867_PHYCR_FIFO_DEPTH_8_B_NIB 0x03
> +
> +/* RGMIIDCTL internal delay for rx and tx */
> +#define DP83867_RGMIIDCTL_250_PS 0x0
> +#define DP83867_RGMIIDCTL_500_PS 0x1
> +#define DP83867_RGMIIDCTL_750_PS 0x2
> +#define DP83867_RGMIIDCTL_1_NS 0x3
> +#define DP83867_RGMIIDCTL_1_25_NS 0x4
> +#define DP83867_RGMIIDCTL_1_50_NS 0x5
> +#define DP83867_RGMIIDCTL_1_75_NS 0x6
> +#define DP83867_RGMIIDCTL_2_00_NS 0x7
> +#define DP83867_RGMIIDCTL_2_25_NS 0x8
> +#define DP83867_RGMIIDCTL_2_50_NS 0x9
> +#define DP83867_RGMIIDCTL_2_75_NS 0xa
> +#define DP83867_RGMIIDCTL_3_00_NS 0xb
> +#define DP83867_RGMIIDCTL_3_25_NS 0xc
> +#define DP83867_RGMIIDCTL_3_50_NS 0xd
> +#define DP83867_RGMIIDCTL_3_75_NS 0xe
> +#define DP83867_RGMIIDCTL_4_00_NS 0xf
> +
> +#endif
>
^ permalink raw reply [flat|nested] 8+ messages in thread
* [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation
2016-04-07 4:45 ` [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation Mugunthan V N
@ 2016-04-07 16:02 ` Dan Murphy
2016-04-08 9:25 ` Michal Simek
0 siblings, 1 reply; 8+ messages in thread
From: Dan Murphy @ 2016-04-07 16:02 UTC (permalink / raw)
To: u-boot
Mugunthan
On 04/06/2016 11:45 PM, Mugunthan V N wrote:
> On Wednesday 06 April 2016 05:07 PM, Dan Murphy wrote:
>> Add the device tree bindings and the accompanying documentation
>> for the TI DP83867 Giga bit ethernet phy driver.
>>
>> The original document was from:
>> [commit 2a10154abcb75ad0d7b6bfea6210ac743ec60897 from the Linux kernel]
>>
>> Signed-off-by: Dan Murphy <dmurphy@ti.com>
>> ---
>>
>> v3 - Modify the binding to the kernel changed int -> internal for the delay - https://patchwork.ozlabs.org/patch/606595/
>>
>> doc/device-tree-bindings/net/ti,dp83867.txt | 29 ++++++++++++++++++++++++
>> include/dt-bindings/net/ti-dp83867.h | 35 +++++++++++++++++++++++++++++
>> 2 files changed, 64 insertions(+)
>> create mode 100644 doc/device-tree-bindings/net/ti,dp83867.txt
>> create mode 100644 include/dt-bindings/net/ti-dp83867.h
>>
>> diff --git a/doc/device-tree-bindings/net/ti,dp83867.txt b/doc/device-tree-bindings/net/ti,dp83867.txt
>> new file mode 100644
>> index 0000000..0ec009c
>> --- /dev/null
>> +++ b/doc/device-tree-bindings/net/ti,dp83867.txt
>> @@ -0,0 +1,29 @@
>> +* Texas Instruments - dp83867 Giga bit ethernet phy
>> +
>> +Required properties:
>> + - ti,rx-internal-delay - RGMII Recieve Clock Delay - see dt-bindings/net/ti-dp83867.h
>> + for applicable values
>> + - ti,tx-internal-delay - RGMII Transmit Clock Delay - see dt-bindings/net/ti-dp83867.h
>> + for applicable values
>> + - ti,fifo-depth - Transmitt FIFO depth- see dt-bindings/net/ti-dp83867.h
>> + for applicable values
>> +
>> +Default child nodes are standard Ethernet PHY device
>> +nodes as described in doc/devicetree/bindings/net/ethernet.txt
>> +
>> +Example:
>> +
>> +&mac {
>> + pinctrl-0 = <&davinci_mdio_default>;
>> + pinctrl-1 = <&davinci_mdio_sleep>;
>> + status = "okay";
>> +
>> + ti,rx_internal_delay = <DP83867_RGMIIDCTL_1_50_NS>;
>> + ti,tx_internal_delay = <DP83867_RGMIIDCTL_2_50_NS>;
>> + ti,fifo_depth = <DP83867_PHYCR_FIFO_DEPTH_8_B_NIB>;
>> +
>> +};
> This example should in phy node and not in mac node as per the linux
> commmit mentioned above?
Are you saying that the code should look like this
&mac {
pinctrl-0 = <&davinci_mdio_default>;
pinctrl-1 = <&davinci_mdio_sleep>;
status = "okay";
phy-handle = <ðernet_phy>;
ethernet_phy: ethernet-phy at 0 {
reg = <0>;
ti,rx_int_delay = <DP83867_RGMIIDCTL_2_25_NS>;
ti,tx_int_delay = <DP83867_RGMIIDCTL_2_75_NS>;
ti,fifo_depth = <DP83867_PHYCR_FIFO_DEPTH_4_B_NIB>;
};
This is the way it is in the kernel.
uBoot cpsw code is missing the kernel patch 9e42f7152 to be able to do this.
Dan
>
> Regards
> Mugunthan V N
>
>> +
>> +
>> +Datasheet can be found:
>> +http://www.ti.com/product/DP83867IR/datasheet
>> diff --git a/include/dt-bindings/net/ti-dp83867.h b/include/dt-bindings/net/ti-dp83867.h
>> new file mode 100644
>> index 0000000..5c592fb
>> --- /dev/null
>> +++ b/include/dt-bindings/net/ti-dp83867.h
>> @@ -0,0 +1,35 @@
>> +/*
>> + * TI DP83867 PHY drivers
>> + *
>> + * SPDX-License-Identifier: GPL-2.0
>> + *
>> + */
>> +
>> +#ifndef _DT_BINDINGS_TI_DP83867_H
>> +#define _DT_BINDINGS_TI_DP83867_H
>> +
>> +/* PHY CTRL bits */
>> +#define DP83867_PHYCR_FIFO_DEPTH_3_B_NIB 0x00
>> +#define DP83867_PHYCR_FIFO_DEPTH_4_B_NIB 0x01
>> +#define DP83867_PHYCR_FIFO_DEPTH_6_B_NIB 0x02
>> +#define DP83867_PHYCR_FIFO_DEPTH_8_B_NIB 0x03
>> +
>> +/* RGMIIDCTL internal delay for rx and tx */
>> +#define DP83867_RGMIIDCTL_250_PS 0x0
>> +#define DP83867_RGMIIDCTL_500_PS 0x1
>> +#define DP83867_RGMIIDCTL_750_PS 0x2
>> +#define DP83867_RGMIIDCTL_1_NS 0x3
>> +#define DP83867_RGMIIDCTL_1_25_NS 0x4
>> +#define DP83867_RGMIIDCTL_1_50_NS 0x5
>> +#define DP83867_RGMIIDCTL_1_75_NS 0x6
>> +#define DP83867_RGMIIDCTL_2_00_NS 0x7
>> +#define DP83867_RGMIIDCTL_2_25_NS 0x8
>> +#define DP83867_RGMIIDCTL_2_50_NS 0x9
>> +#define DP83867_RGMIIDCTL_2_75_NS 0xa
>> +#define DP83867_RGMIIDCTL_3_00_NS 0xb
>> +#define DP83867_RGMIIDCTL_3_25_NS 0xc
>> +#define DP83867_RGMIIDCTL_3_50_NS 0xd
>> +#define DP83867_RGMIIDCTL_3_75_NS 0xe
>> +#define DP83867_RGMIIDCTL_4_00_NS 0xf
>> +
>> +#endif
>>
--
------------------
Dan Murphy
^ permalink raw reply [flat|nested] 8+ messages in thread
* [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation
2016-04-07 16:02 ` Dan Murphy
@ 2016-04-08 9:25 ` Michal Simek
2016-04-08 12:05 ` Dan Murphy
0 siblings, 1 reply; 8+ messages in thread
From: Michal Simek @ 2016-04-08 9:25 UTC (permalink / raw)
To: u-boot
On 7.4.2016 18:02, Dan Murphy wrote:
> Mugunthan
>
> On 04/06/2016 11:45 PM, Mugunthan V N wrote:
>> On Wednesday 06 April 2016 05:07 PM, Dan Murphy wrote:
>>> Add the device tree bindings and the accompanying documentation
>>> for the TI DP83867 Giga bit ethernet phy driver.
>>>
>>> The original document was from:
>>> [commit 2a10154abcb75ad0d7b6bfea6210ac743ec60897 from the Linux kernel]
>>>
>>> Signed-off-by: Dan Murphy <dmurphy@ti.com>
>>> ---
>>>
>>> v3 - Modify the binding to the kernel changed int -> internal for the delay - https://patchwork.ozlabs.org/patch/606595/
>>>
>>> doc/device-tree-bindings/net/ti,dp83867.txt | 29 ++++++++++++++++++++++++
>>> include/dt-bindings/net/ti-dp83867.h | 35 +++++++++++++++++++++++++++++
>>> 2 files changed, 64 insertions(+)
>>> create mode 100644 doc/device-tree-bindings/net/ti,dp83867.txt
>>> create mode 100644 include/dt-bindings/net/ti-dp83867.h
>>>
>>> diff --git a/doc/device-tree-bindings/net/ti,dp83867.txt b/doc/device-tree-bindings/net/ti,dp83867.txt
>>> new file mode 100644
>>> index 0000000..0ec009c
>>> --- /dev/null
>>> +++ b/doc/device-tree-bindings/net/ti,dp83867.txt
>>> @@ -0,0 +1,29 @@
>>> +* Texas Instruments - dp83867 Giga bit ethernet phy
>>> +
>>> +Required properties:
>>> + - ti,rx-internal-delay - RGMII Recieve Clock Delay - see dt-bindings/net/ti-dp83867.h
>>> + for applicable values
>>> + - ti,tx-internal-delay - RGMII Transmit Clock Delay - see dt-bindings/net/ti-dp83867.h
>>> + for applicable values
>>> + - ti,fifo-depth - Transmitt FIFO depth- see dt-bindings/net/ti-dp83867.h
>>> + for applicable values
>>> +
>>> +Default child nodes are standard Ethernet PHY device
>>> +nodes as described in doc/devicetree/bindings/net/ethernet.txt
>>> +
>>> +Example:
>>> +
>>> +&mac {
>>> + pinctrl-0 = <&davinci_mdio_default>;
>>> + pinctrl-1 = <&davinci_mdio_sleep>;
>>> + status = "okay";
>>> +
>>> + ti,rx_internal_delay = <DP83867_RGMIIDCTL_1_50_NS>;
>>> + ti,tx_internal_delay = <DP83867_RGMIIDCTL_2_50_NS>;
>>> + ti,fifo_depth = <DP83867_PHYCR_FIFO_DEPTH_8_B_NIB>;
>>> +
>>> +};
>> This example should in phy node and not in mac node as per the linux
>> commmit mentioned above?
>
> Are you saying that the code should look like this
>
> &mac {
> pinctrl-0 = <&davinci_mdio_default>;
> pinctrl-1 = <&davinci_mdio_sleep>;
> status = "okay";
> phy-handle = <ðernet_phy>;
>
> ethernet_phy: ethernet-phy at 0 {
> reg = <0>;
> ti,rx_int_delay = <DP83867_RGMIIDCTL_2_25_NS>;
> ti,tx_int_delay = <DP83867_RGMIIDCTL_2_75_NS>;
> ti,fifo_depth = <DP83867_PHYCR_FIFO_DEPTH_4_B_NIB>;
> };
>
> This is the way it is in the kernel.
First of all. Please rebase your 2/2 on the top of current branch.
sgmii support was added recently.
Here is what I use on zynqmp.
http://lists.denx.de/pipermail/u-boot/2016-April/250866.html
And it reflects the description above.
Thanks,
Michal
^ permalink raw reply [flat|nested] 8+ messages in thread
* [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation
2016-04-08 9:25 ` Michal Simek
@ 2016-04-08 12:05 ` Dan Murphy
2016-04-08 12:29 ` Michal Simek
0 siblings, 1 reply; 8+ messages in thread
From: Dan Murphy @ 2016-04-08 12:05 UTC (permalink / raw)
To: u-boot
On 04/08/2016 04:25 AM, Michal Simek wrote:
> On 7.4.2016 18:02, Dan Murphy wrote:
>> Mugunthan
>>
>> On 04/06/2016 11:45 PM, Mugunthan V N wrote:
>>> On Wednesday 06 April 2016 05:07 PM, Dan Murphy wrote:
>>>> Add the device tree bindings and the accompanying documentation
>>>> for the TI DP83867 Giga bit ethernet phy driver.
>>>>
>>>> The original document was from:
>>>> [commit 2a10154abcb75ad0d7b6bfea6210ac743ec60897 from the Linux kernel]
>>>>
>>>> Signed-off-by: Dan Murphy <dmurphy@ti.com>
>>>> ---
>>>>
>>>> v3 - Modify the binding to the kernel changed int -> internal for the delay - https://patchwork.ozlabs.org/patch/606595/
>>>>
>>>> doc/device-tree-bindings/net/ti,dp83867.txt | 29 ++++++++++++++++++++++++
>>>> include/dt-bindings/net/ti-dp83867.h | 35 +++++++++++++++++++++++++++++
>>>> 2 files changed, 64 insertions(+)
>>>> create mode 100644 doc/device-tree-bindings/net/ti,dp83867.txt
>>>> create mode 100644 include/dt-bindings/net/ti-dp83867.h
>>>>
>>>> diff --git a/doc/device-tree-bindings/net/ti,dp83867.txt b/doc/device-tree-bindings/net/ti,dp83867.txt
>>>> new file mode 100644
>>>> index 0000000..0ec009c
>>>> --- /dev/null
>>>> +++ b/doc/device-tree-bindings/net/ti,dp83867.txt
>>>> @@ -0,0 +1,29 @@
>>>> +* Texas Instruments - dp83867 Giga bit ethernet phy
>>>> +
>>>> +Required properties:
>>>> + - ti,rx-internal-delay - RGMII Recieve Clock Delay - see dt-bindings/net/ti-dp83867.h
>>>> + for applicable values
>>>> + - ti,tx-internal-delay - RGMII Transmit Clock Delay - see dt-bindings/net/ti-dp83867.h
>>>> + for applicable values
>>>> + - ti,fifo-depth - Transmitt FIFO depth- see dt-bindings/net/ti-dp83867.h
>>>> + for applicable values
>>>> +
>>>> +Default child nodes are standard Ethernet PHY device
>>>> +nodes as described in doc/devicetree/bindings/net/ethernet.txt
>>>> +
>>>> +Example:
>>>> +
>>>> +&mac {
>>>> + pinctrl-0 = <&davinci_mdio_default>;
>>>> + pinctrl-1 = <&davinci_mdio_sleep>;
>>>> + status = "okay";
>>>> +
>>>> + ti,rx_internal_delay = <DP83867_RGMIIDCTL_1_50_NS>;
>>>> + ti,tx_internal_delay = <DP83867_RGMIIDCTL_2_50_NS>;
>>>> + ti,fifo_depth = <DP83867_PHYCR_FIFO_DEPTH_8_B_NIB>;
>>>> +
>>>> +};
>>> This example should in phy node and not in mac node as per the linux
>>> commmit mentioned above?
>> Are you saying that the code should look like this
>>
>> &mac {
>> pinctrl-0 = <&davinci_mdio_default>;
>> pinctrl-1 = <&davinci_mdio_sleep>;
>> status = "okay";
>> phy-handle = <ðernet_phy>;
>>
>> ethernet_phy: ethernet-phy at 0 {
>> reg = <0>;
>> ti,rx_int_delay = <DP83867_RGMIIDCTL_2_25_NS>;
>> ti,tx_int_delay = <DP83867_RGMIIDCTL_2_75_NS>;
>> ti,fifo_depth = <DP83867_PHYCR_FIFO_DEPTH_4_B_NIB>;
>> };
>>
>> This is the way it is in the kernel.
> First of all. Please rebase your 2/2 on the top of current branch.
> sgmii support was added recently.
Yeah I had a feeling that I was going to need to do that.
>
> Here is what I use on zynqmp.
> http://lists.denx.de/pipermail/u-boot/2016-April/250866.html
> And it reflects the description above.
OK the zync_gem supports phy-handle. cpsw does not. Looks like I have
to add a patch to cpsw.
Dan
>
> Thanks,
> Michal
--
------------------
Dan Murphy
^ permalink raw reply [flat|nested] 8+ messages in thread
* [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation
2016-04-08 12:05 ` Dan Murphy
@ 2016-04-08 12:29 ` Michal Simek
2016-04-08 15:26 ` Dan Murphy
0 siblings, 1 reply; 8+ messages in thread
From: Michal Simek @ 2016-04-08 12:29 UTC (permalink / raw)
To: u-boot
On 8.4.2016 14:05, Dan Murphy wrote:
> On 04/08/2016 04:25 AM, Michal Simek wrote:
>> On 7.4.2016 18:02, Dan Murphy wrote:
>>> Mugunthan
>>>
>>> On 04/06/2016 11:45 PM, Mugunthan V N wrote:
>>>> On Wednesday 06 April 2016 05:07 PM, Dan Murphy wrote:
>>>>> Add the device tree bindings and the accompanying documentation
>>>>> for the TI DP83867 Giga bit ethernet phy driver.
>>>>>
>>>>> The original document was from:
>>>>> [commit 2a10154abcb75ad0d7b6bfea6210ac743ec60897 from the Linux kernel]
>>>>>
>>>>> Signed-off-by: Dan Murphy <dmurphy@ti.com>
>>>>> ---
>>>>>
>>>>> v3 - Modify the binding to the kernel changed int -> internal for the delay - https://patchwork.ozlabs.org/patch/606595/
>>>>>
>>>>> doc/device-tree-bindings/net/ti,dp83867.txt | 29 ++++++++++++++++++++++++
>>>>> include/dt-bindings/net/ti-dp83867.h | 35 +++++++++++++++++++++++++++++
>>>>> 2 files changed, 64 insertions(+)
>>>>> create mode 100644 doc/device-tree-bindings/net/ti,dp83867.txt
>>>>> create mode 100644 include/dt-bindings/net/ti-dp83867.h
>>>>>
>>>>> diff --git a/doc/device-tree-bindings/net/ti,dp83867.txt b/doc/device-tree-bindings/net/ti,dp83867.txt
>>>>> new file mode 100644
>>>>> index 0000000..0ec009c
>>>>> --- /dev/null
>>>>> +++ b/doc/device-tree-bindings/net/ti,dp83867.txt
>>>>> @@ -0,0 +1,29 @@
>>>>> +* Texas Instruments - dp83867 Giga bit ethernet phy
>>>>> +
>>>>> +Required properties:
>>>>> + - ti,rx-internal-delay - RGMII Recieve Clock Delay - see dt-bindings/net/ti-dp83867.h
>>>>> + for applicable values
>>>>> + - ti,tx-internal-delay - RGMII Transmit Clock Delay - see dt-bindings/net/ti-dp83867.h
>>>>> + for applicable values
>>>>> + - ti,fifo-depth - Transmitt FIFO depth- see dt-bindings/net/ti-dp83867.h
>>>>> + for applicable values
>>>>> +
>>>>> +Default child nodes are standard Ethernet PHY device
>>>>> +nodes as described in doc/devicetree/bindings/net/ethernet.txt
>>>>> +
>>>>> +Example:
>>>>> +
>>>>> +&mac {
>>>>> + pinctrl-0 = <&davinci_mdio_default>;
>>>>> + pinctrl-1 = <&davinci_mdio_sleep>;
>>>>> + status = "okay";
>>>>> +
>>>>> + ti,rx_internal_delay = <DP83867_RGMIIDCTL_1_50_NS>;
>>>>> + ti,tx_internal_delay = <DP83867_RGMIIDCTL_2_50_NS>;
>>>>> + ti,fifo_depth = <DP83867_PHYCR_FIFO_DEPTH_8_B_NIB>;
>>>>> +
>>>>> +};
>>>> This example should in phy node and not in mac node as per the linux
>>>> commmit mentioned above?
>>> Are you saying that the code should look like this
>>>
>>> &mac {
>>> pinctrl-0 = <&davinci_mdio_default>;
>>> pinctrl-1 = <&davinci_mdio_sleep>;
>>> status = "okay";
>>> phy-handle = <ðernet_phy>;
>>>
>>> ethernet_phy: ethernet-phy at 0 {
>>> reg = <0>;
>>> ti,rx_int_delay = <DP83867_RGMIIDCTL_2_25_NS>;
>>> ti,tx_int_delay = <DP83867_RGMIIDCTL_2_75_NS>;
>>> ti,fifo_depth = <DP83867_PHYCR_FIFO_DEPTH_4_B_NIB>;
>>> };
>>>
>>> This is the way it is in the kernel.
>> First of all. Please rebase your 2/2 on the top of current branch.
>> sgmii support was added recently.
>
> Yeah I had a feeling that I was going to need to do that.
>
>>
>> Here is what I use on zynqmp.
>> http://lists.denx.de/pipermail/u-boot/2016-April/250866.html
>> And it reflects the description above.
>
> OK the zync_gem supports phy-handle. cpsw does not. Looks like I have
> to add a patch to cpsw.
yep but again your patch is failing on zynqmp. Because I don't think
there is hook to read that values from DT.
I didn't look at details but definitely please check it.
Thanks,
Michal
^ permalink raw reply [flat|nested] 8+ messages in thread
* [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation
2016-04-08 12:29 ` Michal Simek
@ 2016-04-08 15:26 ` Dan Murphy
0 siblings, 0 replies; 8+ messages in thread
From: Dan Murphy @ 2016-04-08 15:26 UTC (permalink / raw)
To: u-boot
On 04/08/2016 07:29 AM, Michal Simek wrote:
> On 8.4.2016 14:05, Dan Murphy wrote:
>> On 04/08/2016 04:25 AM, Michal Simek wrote:
>>> On 7.4.2016 18:02, Dan Murphy wrote:
>>>> Mugunthan
>>>>
>>>> On 04/06/2016 11:45 PM, Mugunthan V N wrote:
>>>>> On Wednesday 06 April 2016 05:07 PM, Dan Murphy wrote:
>>>>>> Add the device tree bindings and the accompanying documentation
>>>>>> for the TI DP83867 Giga bit ethernet phy driver.
>>>>>>
>>>>>> The original document was from:
>>>>>> [commit 2a10154abcb75ad0d7b6bfea6210ac743ec60897 from the Linux kernel]
>>>>>>
>>>>>> Signed-off-by: Dan Murphy <dmurphy@ti.com>
>>>>>> ---
>>>>>>
>>>>>> v3 - Modify the binding to the kernel changed int -> internal for the delay - https://patchwork.ozlabs.org/patch/606595/
>>>>>>
>>>>>> doc/device-tree-bindings/net/ti,dp83867.txt | 29 ++++++++++++++++++++++++
>>>>>> include/dt-bindings/net/ti-dp83867.h | 35 +++++++++++++++++++++++++++++
>>>>>> 2 files changed, 64 insertions(+)
>>>>>> create mode 100644 doc/device-tree-bindings/net/ti,dp83867.txt
>>>>>> create mode 100644 include/dt-bindings/net/ti-dp83867.h
>>>>>>
>>>>>> diff --git a/doc/device-tree-bindings/net/ti,dp83867.txt b/doc/device-tree-bindings/net/ti,dp83867.txt
>>>>>> new file mode 100644
>>>>>> index 0000000..0ec009c
>>>>>> --- /dev/null
>>>>>> +++ b/doc/device-tree-bindings/net/ti,dp83867.txt
>>>>>> @@ -0,0 +1,29 @@
>>>>>> +* Texas Instruments - dp83867 Giga bit ethernet phy
>>>>>> +
>>>>>> +Required properties:
>>>>>> + - ti,rx-internal-delay - RGMII Recieve Clock Delay - see dt-bindings/net/ti-dp83867.h
>>>>>> + for applicable values
>>>>>> + - ti,tx-internal-delay - RGMII Transmit Clock Delay - see dt-bindings/net/ti-dp83867.h
>>>>>> + for applicable values
>>>>>> + - ti,fifo-depth - Transmitt FIFO depth- see dt-bindings/net/ti-dp83867.h
>>>>>> + for applicable values
>>>>>> +
>>>>>> +Default child nodes are standard Ethernet PHY device
>>>>>> +nodes as described in doc/devicetree/bindings/net/ethernet.txt
>>>>>> +
>>>>>> +Example:
>>>>>> +
>>>>>> +&mac {
>>>>>> + pinctrl-0 = <&davinci_mdio_default>;
>>>>>> + pinctrl-1 = <&davinci_mdio_sleep>;
>>>>>> + status = "okay";
>>>>>> +
>>>>>> + ti,rx_internal_delay = <DP83867_RGMIIDCTL_1_50_NS>;
>>>>>> + ti,tx_internal_delay = <DP83867_RGMIIDCTL_2_50_NS>;
>>>>>> + ti,fifo_depth = <DP83867_PHYCR_FIFO_DEPTH_8_B_NIB>;
>>>>>> +
>>>>>> +};
>>>>> This example should in phy node and not in mac node as per the linux
>>>>> commmit mentioned above?
>>>> Are you saying that the code should look like this
>>>>
>>>> &mac {
>>>> pinctrl-0 = <&davinci_mdio_default>;
>>>> pinctrl-1 = <&davinci_mdio_sleep>;
>>>> status = "okay";
>>>> phy-handle = <ðernet_phy>;
>>>>
>>>> ethernet_phy: ethernet-phy at 0 {
>>>> reg = <0>;
>>>> ti,rx_int_delay = <DP83867_RGMIIDCTL_2_25_NS>;
>>>> ti,tx_int_delay = <DP83867_RGMIIDCTL_2_75_NS>;
>>>> ti,fifo_depth = <DP83867_PHYCR_FIFO_DEPTH_4_B_NIB>;
>>>> };
>>>>
>>>> This is the way it is in the kernel.
>>> First of all. Please rebase your 2/2 on the top of current branch.
>>> sgmii support was added recently.
>> Yeah I had a feeling that I was going to need to do that.
>>
>>> Here is what I use on zynqmp.
>>> http://lists.denx.de/pipermail/u-boot/2016-April/250866.html
>>> And it reflects the description above.
>> OK the zync_gem supports phy-handle. cpsw does not. Looks like I have
>> to add a patch to cpsw.
> yep but again your patch is failing on zynqmp. Because I don't think
> there is hook to read that values from DT.
> I didn't look at details but definitely please check it.
Actually this is a problem in the zynqmp mac driver.
zynqmp reads the phy-handle and then dumps the information so
the dp83867 or any phy driver for that matter is not getting the data.
I will send a patch in to fix the zynqmp driver as well
Dan
>
> Thanks,
> Michal
>
>
--
------------------
Dan Murphy
^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2016-04-08 15:26 UTC | newest]
Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-04-06 11:37 [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation Dan Murphy
2016-04-06 11:38 ` [U-Boot] [uboot][PATCH v3 2/2] net: phy: ti: Allow the driver to be more configurable Dan Murphy
2016-04-07 4:45 ` [U-Boot] [uboot][PATCH v3 1/2] net: phy: dp83867: Add device tree bindings and documentation Mugunthan V N
2016-04-07 16:02 ` Dan Murphy
2016-04-08 9:25 ` Michal Simek
2016-04-08 12:05 ` Dan Murphy
2016-04-08 12:29 ` Michal Simek
2016-04-08 15:26 ` Dan Murphy
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox