devicetree.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v3 0/2] net/phy: micrel: Add DT configuration support and
@ 2014-04-29  9:33 Hubert Chaumette
  2014-04-29  9:33 ` [PATCH v3 1/2] Add support for ksz9031 PAD skew configuration over devicetree Hubert Chaumette
                   ` (2 more replies)
  0 siblings, 3 replies; 4+ messages in thread
From: Hubert Chaumette @ 2014-04-29  9:33 UTC (permalink / raw)
  To: f.fainelli
  Cc: netdev, linux-kernel, robh+dt, pawel.moll, mark.rutland,
	ijc+devicetree, galak, rdunlap, xobs, davem, devicetree,
	linux-doc

 - Adds DT configuration support for ksz9031
 - Renames micrel-ksz9021.txt to micrel-ksz90x1.txt and adds ksz9031 binding
   documentation

Changes since v2:
 - Merged together ksz9031_load_{clk,data,ctrl}_skew_values()
 - Added field length and number of fields prameter to account for registers
  specificities
 - Added binding documentation

Changes since v1:
 - Removed ksz9021 and ksz9031 fixup deletions from arch/arm/mach-imx/mach-imx6q.c

Hubert Chaumette (2):
  Add support for ksz9031 PAD skew configuration over devicetree.
  Update Micrel KSZ90x1 binding documentation

 .../devicetree/bindings/net/micrel-ksz9021.txt     |  49 ------
 .../devicetree/bindings/net/micrel-ksz90x1.txt     |  83 ++++++++++
 drivers/net/phy/micrel.c                           | 167 ++++++---------------
 3 files changed, 127 insertions(+), 172 deletions(-)
 delete mode 100644 Documentation/devicetree/bindings/net/micrel-ksz9021.txt
 create mode 100644 Documentation/devicetree/bindings/net/micrel-ksz90x1.txt

-- 
1.9.2

^ permalink raw reply	[flat|nested] 4+ messages in thread

* [PATCH v3 1/2] Add support for ksz9031 PAD skew configuration over devicetree.
  2014-04-29  9:33 [PATCH v3 0/2] net/phy: micrel: Add DT configuration support and Hubert Chaumette
@ 2014-04-29  9:33 ` Hubert Chaumette
  2014-04-29  9:33 ` [PATCH v3 2/2] Update Micrel KSZ90x1 binding documentation Hubert Chaumette
       [not found] ` <1398764005-23855-1-git-send-email-hchaumette-HH5893ap9ioXz/+GnIZSFEEOCMrvLtNR@public.gmane.org>
  2 siblings, 0 replies; 4+ messages in thread
From: Hubert Chaumette @ 2014-04-29  9:33 UTC (permalink / raw)
  To: f.fainelli
  Cc: netdev, linux-kernel, robh+dt, pawel.moll, mark.rutland,
	ijc+devicetree, galak, rdunlap, xobs, davem, devicetree,
	linux-doc

Adds support for ksz9031 PAD skew configuration over devicetree.

Signed-off-by: Hubert Chaumette <hchaumette@adeneo-embedded.com>
---
 drivers/net/phy/micrel.c | 167 +++++++++++++----------------------------------
 1 file changed, 44 insertions(+), 123 deletions(-)

diff --git a/drivers/net/phy/micrel.c b/drivers/net/phy/micrel.c
index df56b26..c936b72 100644
--- a/drivers/net/phy/micrel.c
+++ b/drivers/net/phy/micrel.c
@@ -271,156 +271,77 @@ static int ksz9031_extended_read(struct phy_device *phydev,
 	return phy_read(phydev, MII_KSZ9031RN_MMD_REGDATA_REG);
 }
 
-/* Two 5-bit fields register */
-static int ksz9031_load_clk_skew_values(struct phy_device *phydev,
-					struct device_node *of_node,
-					char *field1, char *field2)
+static int ksz9031_of_load_skew_values(struct phy_device *phydev,
+				       struct device_node *of_node,
+				       u16 reg, size_t field_sz,
+				       char *field[], u8 numfields)
 {
-	int val1 = -1;
-	int val2 = -2;
-	int newval;
+	int val[4] = {-1, -2, -3, -4};
 	int matches = 0;
+	u16 mask;
+	u16 maxval;
+	u16 newval;
+	int i;
 
-	if (!of_property_read_u32(of_node, field1, &val1))
-		matches++;
-
-	if (!of_property_read_u32(of_node, field2, &val2))
-		matches++;
+	for (i = 0; i < numfields; i++)
+		if (!of_property_read_u32(of_node, field[i], val + i))
+			matches++;
 
 	if (!matches)
 		return 0;
 
-	if (matches < 2)
-		newval = ksz9031_extended_read(phydev, OP_DATA, 2,
-				MII_KSZ9031RN_CLK_PAD_SKEW);
-	else
-		newval = 0;
-
-	if (val1 != -1)
-		newval = (newval & 0xffe0) |
-			 ((val1 / KSZ9031_PS_TO_REG) & 0x1f);
-
-	if (val2 != -2)
-		newval = (newval & 0xfc1f) |
-			 (((val2 / KSZ9031_PS_TO_REG) & 0x1f) << 5);
-
-	return ksz9031_extended_write(phydev, OP_DATA, 2,
-			MII_KSZ9031RN_CLK_PAD_SKEW, newval);
-}
-
-/* Four 4-bit fields register */
-static int ksz9031_load_data_skew_values(struct phy_device *phydev,
-					 struct device_node *of_node, u16 reg,
-					 char *field1, char *field2,
-					 char *field3, char *field4)
-{
-	int val1 = -1;
-	int val2 = -2;
-	int val3 = -3;
-	int val4 = -4;
-	int newval;
-	int matches = 0;
-
-	if (!of_property_read_u32(of_node, field1, &val1))
-		matches++;
-
-	if (!of_property_read_u32(of_node, field2, &val2))
-		matches++;
-
-	if (!of_property_read_u32(of_node, field3, &val3))
-		matches++;
-
-	if (!of_property_read_u32(of_node, field4, &val4))
-		matches++;
-
-	if (!matches)
-		return 0;
-
-	if (matches < 4)
+	if (matches < numfields)
 		newval = ksz9031_extended_read(phydev, OP_DATA, 2, reg);
 	else
 		newval = 0;
 
-	if (val1 != -1)
-		newval = (newval & 0xfff0) |
-			 (((val1 / KSZ9031_PS_TO_REG) & 0xf) << 0);
-
-	if (val2 != -2)
-		newval = (newval & 0xff0f) |
-			 (((val2 / KSZ9031_PS_TO_REG) & 0xf) << 4);
-
-	if (val3 != -3)
-		newval = (newval & 0xf0ff) |
-			 (((val3 / KSZ9031_PS_TO_REG) & 0xf) << 8);
-
-	if (val4 != -4)
-		newval = (newval & 0x0fff) |
-			 (((val4 / KSZ9031_PS_TO_REG) & 0xf) << 12);
+	maxval = (field_sz == 4) ? 0xf : 0x1f;
+	for (i = 0; i < numfields; i++)
+		if (val[i] != -(i + 1)) {
+			mask = 0xffff;
+			mask ^= maxval << (field_sz * i);
+			newval = (newval & mask) |
+				(((val[i] / KSZ9031_PS_TO_REG) & maxval)
+					<< (field_sz * i));
+		}
 
 	return ksz9031_extended_write(phydev, OP_DATA, 2, reg, newval);
 }
 
-/* Two 4-bit fields register */
-static int ksz9031_load_ctrl_skew_values(struct phy_device *phydev,
-					 struct device_node *of_node,
-					 char *field1, char *field2)
-{
-	int val1 = -1;
-	int val2 = -2;
-	int newval;
-	int matches = 0;
-
-	if (!of_property_read_u32(of_node, field1, &val1))
-		matches++;
-
-	if (!of_property_read_u32(of_node, field2, &val2))
-		matches++;
-
-	if (!matches)
-		return 0;
-
-	if (matches < 2)
-		newval = ksz9031_extended_read(phydev, OP_DATA, 2,
-				MII_KSZ9031RN_CONTROL_PAD_SKEW);
-	else
-		newval = 0;
-
-	if (val1 != -1)
-		newval = (newval & 0xfff0) |
-			 (((val1 / KSZ9031_PS_TO_REG) & 0xf) << 0);
-
-	if (val2 != -2)
-		newval = (newval & 0xff0f) |
-			 (((val2 / KSZ9031_PS_TO_REG) & 0xf) << 4);
-
-	return ksz9031_extended_write(phydev, OP_DATA, 2,
-			MII_KSZ9031RN_CONTROL_PAD_SKEW, newval);
-}
-
 static int ksz9031_config_init(struct phy_device *phydev)
 {
 	struct device *dev = &phydev->dev;
 	struct device_node *of_node = dev->of_node;
+	char *clk_skews[2] = {"rxc-skew-ps", "txc-skew-ps"};
+	char *rx_data_skews[4] = {
+		"rxd0-skew-ps", "rxd1-skew-ps",
+		"rxd2-skew-ps", "rxd3-skew-ps"
+	};
+	char *tx_data_skews[4] = {
+		"txd0-skew-ps", "txd1-skew-ps",
+		"txd2-skew-ps", "txd3-skew-ps"
+	};
+	char *control_skews[2] = {"txen-skew-ps", "rxdv-skew-ps"};
 
 	if (!of_node && dev->parent->of_node)
 		of_node = dev->parent->of_node;
 
 	if (of_node) {
-		ksz9031_load_clk_skew_values(phydev, of_node,
-				"rxc-skew-ps", "txc-skew-ps");
+		ksz9031_of_load_skew_values(phydev, of_node,
+				MII_KSZ9031RN_CLK_PAD_SKEW, 5,
+				clk_skews, 2);
 
-		ksz9031_load_data_skew_values(phydev, of_node,
-				MII_KSZ9031RN_RX_DATA_PAD_SKEW,
-				"rxd0-skew-ps", "rxd1-skew-ps",
-				"rxd2-skew-ps", "rxd3-skew-ps");
+		ksz9031_of_load_skew_values(phydev, of_node,
+				MII_KSZ9031RN_CONTROL_PAD_SKEW, 4,
+				control_skews, 2);
 
-		ksz9031_load_data_skew_values(phydev, of_node,
-				MII_KSZ9031RN_TX_DATA_PAD_SKEW,
-				"txd0-skew-ps", "txd1-skew-ps",
-				"txd2-skew-ps", "txd3-skew-ps");
+		ksz9031_of_load_skew_values(phydev, of_node,
+				MII_KSZ9031RN_RX_DATA_PAD_SKEW, 4,
+				rx_data_skews, 4);
 
-		ksz9031_load_ctrl_skew_values(phydev, of_node,
-				"txen-skew-ps", "rxdv-skew-ps");
+		ksz9031_of_load_skew_values(phydev, of_node,
+				MII_KSZ9031RN_TX_DATA_PAD_SKEW, 4,
+				tx_data_skews, 4);
 	}
 	return 0;
 }
-- 
1.9.2

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* [PATCH v3 2/2] Update Micrel KSZ90x1 binding documentation
  2014-04-29  9:33 [PATCH v3 0/2] net/phy: micrel: Add DT configuration support and Hubert Chaumette
  2014-04-29  9:33 ` [PATCH v3 1/2] Add support for ksz9031 PAD skew configuration over devicetree Hubert Chaumette
@ 2014-04-29  9:33 ` Hubert Chaumette
       [not found] ` <1398764005-23855-1-git-send-email-hchaumette-HH5893ap9ioXz/+GnIZSFEEOCMrvLtNR@public.gmane.org>
  2 siblings, 0 replies; 4+ messages in thread
From: Hubert Chaumette @ 2014-04-29  9:33 UTC (permalink / raw)
  To: f.fainelli
  Cc: netdev, linux-kernel, robh+dt, pawel.moll, mark.rutland,
	ijc+devicetree, galak, rdunlap, xobs, davem, devicetree,
	linux-doc

Renames micrel-ksz9021.txt to micrel-ksz90x1.txt and adds documentation for
the KSZ9031 binding from patch 1. Also adds step increment information, and
note about phy fixups. 

Signed-off-by: Hubert Chaumette <hchaumette@adeneo-embedded.com>
---
 .../devicetree/bindings/net/micrel-ksz9021.txt     | 49 -------------
 .../devicetree/bindings/net/micrel-ksz90x1.txt     | 83 ++++++++++++++++++++++
 2 files changed, 83 insertions(+), 49 deletions(-)
 delete mode 100644 Documentation/devicetree/bindings/net/micrel-ksz9021.txt
 create mode 100644 Documentation/devicetree/bindings/net/micrel-ksz90x1.txt

diff --git a/Documentation/devicetree/bindings/net/micrel-ksz9021.txt b/Documentation/devicetree/bindings/net/micrel-ksz9021.txt
deleted file mode 100644
index 997a63f..0000000
--- a/Documentation/devicetree/bindings/net/micrel-ksz9021.txt
+++ /dev/null
@@ -1,49 +0,0 @@
-Micrel KSZ9021 Gigabit Ethernet PHY
-
-Some boards require special tuning values, particularly when it comes to
-clock delays.  You can specify clock delay values by adding
-micrel-specific properties to an Ethernet OF device node.
-
-All skew control options are specified in picoseconds.  The minimum
-value is 0, and the maximum value is 3000.
-
-Optional properties:
- - rxc-skew-ps : Skew control of RXC pad
- - rxdv-skew-ps : Skew control of RX CTL pad
- - txc-skew-ps : Skew control of TXC pad
- - txen-skew-ps : Skew control of TX_CTL pad
- - rxd0-skew-ps : Skew control of RX data 0 pad
- - rxd1-skew-ps : Skew control of RX data 1 pad
- - rxd2-skew-ps : Skew control of RX data 2 pad
- - rxd3-skew-ps : Skew control of RX data 3 pad
- - txd0-skew-ps : Skew control of TX data 0 pad
- - txd1-skew-ps : Skew control of TX data 1 pad
- - txd2-skew-ps : Skew control of TX data 2 pad
- - txd3-skew-ps : Skew control of TX data 3 pad
-
-Examples:
-
-	/* Attach to an Ethernet device with autodetected PHY */
-	&enet {
-		rxc-skew-ps = <3000>;
-		rxdv-skew-ps = <0>;
-		txc-skew-ps = <3000>;
-		txen-skew-ps = <0>;
-		status = "okay";
-	};
-
-	/* Attach to an explicitly-specified PHY */
-	mdio {
-		phy0: ethernet-phy@0 {
-			rxc-skew-ps = <3000>;
-			rxdv-skew-ps = <0>;
-			txc-skew-ps = <3000>;
-			txen-skew-ps = <0>;
-			reg = <0>;
-		};
-	};
-	ethernet@70000 {
-		status = "okay";
-		phy = <&phy0>;
-		phy-mode = "rgmii-id";
-	};
diff --git a/Documentation/devicetree/bindings/net/micrel-ksz90x1.txt b/Documentation/devicetree/bindings/net/micrel-ksz90x1.txt
new file mode 100644
index 0000000..692076f
--- /dev/null
+++ b/Documentation/devicetree/bindings/net/micrel-ksz90x1.txt
@@ -0,0 +1,83 @@
+Micrel KSZ9021/KSZ9031 Gigabit Ethernet PHY
+
+Some boards require special tuning values, particularly when it comes to
+clock delays. You can specify clock delay values by adding
+micrel-specific properties to an Ethernet OF device node.
+
+Note that these settings are applied after any phy-specific fixup from
+phy_fixup_list (see phy_init_hw() from drivers/net/phy/phy_device.c),
+and therefore may overwrite them.
+
+KSZ9021:
+
+  All skew control options are specified in picoseconds. The minimum
+  value is 0, the maximum value is 3000, and it is incremented by 200ps
+  steps.
+
+  Optional properties:
+
+    - rxc-skew-ps : Skew control of RXC pad
+    - rxdv-skew-ps : Skew control of RX CTL pad
+    - txc-skew-ps : Skew control of TXC pad
+    - txen-skew-ps : Skew control of TX CTL pad
+    - rxd0-skew-ps : Skew control of RX data 0 pad
+    - rxd1-skew-ps : Skew control of RX data 1 pad
+    - rxd2-skew-ps : Skew control of RX data 2 pad
+    - rxd3-skew-ps : Skew control of RX data 3 pad
+    - txd0-skew-ps : Skew control of TX data 0 pad
+    - txd1-skew-ps : Skew control of TX data 1 pad
+    - txd2-skew-ps : Skew control of TX data 2 pad
+    - txd3-skew-ps : Skew control of TX data 3 pad
+
+KSZ9031:
+
+  All skew control options are specified in picoseconds. The minimum
+  value is 0, and the maximum is property-dependent. The increment
+  step is 60ps.
+
+  Optional properties:
+
+    Maximum value of 1860:
+
+      - rxc-skew-ps : Skew control of RX clock pad
+      - txc-skew-ps : Skew control of TX clock pad
+
+    Maximum value of 900:
+
+      - rxdv-skew-ps : Skew control of RX CTL pad
+      - txen-skew-ps : Skew control of TX CTL pad
+      - rxd0-skew-ps : Skew control of RX data 0 pad
+      - rxd1-skew-ps : Skew control of RX data 1 pad
+      - rxd2-skew-ps : Skew control of RX data 2 pad
+      - rxd3-skew-ps : Skew control of RX data 3 pad
+      - txd0-skew-ps : Skew control of TX data 0 pad
+      - txd1-skew-ps : Skew control of TX data 1 pad
+      - txd2-skew-ps : Skew control of TX data 2 pad
+      - txd3-skew-ps : Skew control of TX data 3 pad
+
+Examples:
+
+	/* Attach to an Ethernet device with autodetected PHY */
+	&enet {
+		rxc-skew-ps = <3000>;
+		rxdv-skew-ps = <0>;
+		txc-skew-ps = <3000>;
+		txen-skew-ps = <0>;
+		status = "okay";
+	};
+
+	/* Attach to an explicitly-specified PHY */
+	mdio {
+		phy0: ethernet-phy@0 {
+			rxc-skew-ps = <3000>;
+			rxdv-skew-ps = <0>;
+			txc-skew-ps = <3000>;
+			txen-skew-ps = <0>;
+			reg = <0>;
+		};
+	};
+	ethernet@70000 {
+		status = "okay";
+		phy = <&phy0>;
+		phy-mode = "rgmii-id";
+	};
-- 
1.9.2

^ permalink raw reply related	[flat|nested] 4+ messages in thread

* Re: [PATCH v3 0/2] net/phy: micrel: Add DT configuration support and
       [not found] ` <1398764005-23855-1-git-send-email-hchaumette-HH5893ap9ioXz/+GnIZSFEEOCMrvLtNR@public.gmane.org>
@ 2014-05-02 19:58   ` David Miller
  0 siblings, 0 replies; 4+ messages in thread
From: David Miller @ 2014-05-02 19:58 UTC (permalink / raw)
  To: hchaumette-HH5893ap9ioXz/+GnIZSFEEOCMrvLtNR
  Cc: f.fainelli-Re5JQEeQqe8AvxtiuMwx3w, netdev-u79uwXL29TY76Z2rM5mHXA,
	linux-kernel-u79uwXL29TY76Z2rM5mHXA,
	robh+dt-DgEjT+Ai2ygdnm+yROfE0A, pawel.moll-5wv7dgnIgG8,
	mark.rutland-5wv7dgnIgG8, ijc+devicetree-KcIKpvwj1kUDXYZnReoRVg,
	galak-sgV2jX0FEOL9JmXXK+q4OQ, rdunlap-wEGCiKHe2LqWVfeAwA7xHQ,
	xobs-nXMMniAx+RbQT0dZR+AlfA, devicetree-u79uwXL29TY76Z2rM5mHXA,
	linux-doc-u79uwXL29TY76Z2rM5mHXA

From: Hubert Chaumette <hchaumette-HH5893ap9ioXz/+GnIZSFEEOCMrvLtNR@public.gmane.org>
Date: Tue, 29 Apr 2014 11:33:23 +0200

>  - Adds DT configuration support for ksz9031
>  - Renames micrel-ksz9021.txt to micrel-ksz90x1.txt and adds ksz9031 binding
>    documentation
> 
> Changes since v2:
>  - Merged together ksz9031_load_{clk,data,ctrl}_skew_values()
>  - Added field length and number of fields prameter to account for registers
>   specificities
>  - Added binding documentation

These patches do not apply cleanly to net-next, please respin.

Thanks.
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2014-05-02 19:58 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-04-29  9:33 [PATCH v3 0/2] net/phy: micrel: Add DT configuration support and Hubert Chaumette
2014-04-29  9:33 ` [PATCH v3 1/2] Add support for ksz9031 PAD skew configuration over devicetree Hubert Chaumette
2014-04-29  9:33 ` [PATCH v3 2/2] Update Micrel KSZ90x1 binding documentation Hubert Chaumette
     [not found] ` <1398764005-23855-1-git-send-email-hchaumette-HH5893ap9ioXz/+GnIZSFEEOCMrvLtNR@public.gmane.org>
2014-05-02 19:58   ` [PATCH v3 0/2] net/phy: micrel: Add DT configuration support and David Miller

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).