]> git.ipfire.org Git - thirdparty/u-boot.git/commitdiff
test: dm: add PHY common props unit tests and sandbox DT nodes
authorLucien.Jheng <lucienzx159@gmail.com>
Sat, 25 Apr 2026 08:06:49 +0000 (16:06 +0800)
committerJerome Forissier <jerome.forissier@arm.com>
Wed, 6 May 2026 09:07:22 +0000 (11:07 +0200)
Add sandbox DM unit tests for the PHY common properties library and the
corresponding device tree test nodes to arch/sandbox/dts/test.dts.
Also enable CONFIG_PHY_COMMON_PROPS in configs/sandbox_defconfig so
the tests are built and run in the sandbox environment.

The test file covers rx/tx polarity lookups for all relevant cases:

  - missing property (defaults to PHY_POL_NORMAL)
  - single value without names array (applies to all modes)
  - count mismatch between values and names arrays (-EINVAL)
  - name found by exact match
  - name not found with no "default" fallback (-EINVAL)
  - name not found with a "default" entry (uses fallback value)
  - unsupported polarity value (-EOPNOTSUPP)

Ported from Linux KUnit test:
  linux/drivers/phy/phy-common-props-test.c

Signed-off-by: Lucien.Jheng <lucienzx159@gmail.com>
arch/sandbox/dts/test.dts
configs/sandbox_defconfig
test/dm/Makefile
test/dm/phy_common_props.c [new file with mode: 0644]

index ac92ebf1afd764ce37f97de03281f0d1f335a4b1..0887de4333b01ca836865486d0dba8bfc3a88469 100644 (file)
@@ -16,6 +16,7 @@
 #include <dt-bindings/leds/common.h>
 #include <dt-bindings/pinctrl/sandbox-pinmux.h>
 #include <dt-bindings/mux/mux.h>
+#include <dt-bindings/phy/phy.h>
 
 / {
        model = "sandbox";
                phy-names = "phy1";
        };
 
+       /* PHY common props test nodes */
+       phy_common_props_missing: phy-common-props-missing {
+               /* empty: no rx-polarity or tx-polarity properties */
+       };
+
+       phy_common_props_more_values: phy-common-props-more-values {
+               /* 3 values but only 2 names => count mismatch */
+               rx-polarity = <PHY_POL_NORMAL PHY_POL_INVERT PHY_POL_NORMAL>;
+               rx-polarity-names = "sgmii", "2500base-x";
+               tx-polarity = <PHY_POL_NORMAL PHY_POL_INVERT PHY_POL_NORMAL>;
+               tx-polarity-names = "sgmii", "2500base-x";
+       };
+
+       phy_common_props_single: phy-common-props-single {
+               /* 1 value, no names array => value applies to all modes */
+               rx-polarity = <PHY_POL_INVERT>;
+               tx-polarity = <PHY_POL_INVERT>;
+       };
+
+       phy_common_props_more_names: phy-common-props-more-names {
+               /* 2 values but 3 names => count mismatch */
+               rx-polarity = <PHY_POL_NORMAL PHY_POL_INVERT>;
+               rx-polarity-names = "sgmii", "2500base-x", "1000base-x";
+               tx-polarity = <PHY_POL_NORMAL PHY_POL_INVERT>;
+               tx-polarity-names = "sgmii", "2500base-x", "1000base-x";
+       };
+
+       phy_common_props_find_by_name: phy-common-props-find-by-name {
+               /* valid 3-element arrays, lookup by mode name */
+               rx-polarity = <PHY_POL_NORMAL PHY_POL_INVERT PHY_POL_AUTO>;
+               rx-polarity-names = "sgmii", "2500base-x", "usb-ss";
+               tx-polarity = <PHY_POL_NORMAL PHY_POL_INVERT PHY_POL_NORMAL>;
+               tx-polarity-names = "sgmii", "2500base-x", "1000base-x";
+       };
+
+       phy_common_props_no_default: phy-common-props-no-default {
+               /* name not in array, no "default" entry => -EINVAL */
+               rx-polarity = <PHY_POL_NORMAL PHY_POL_INVERT>;
+               rx-polarity-names = "2500base-x", "1000base-x";
+               tx-polarity = <PHY_POL_NORMAL PHY_POL_INVERT>;
+               tx-polarity-names = "2500base-x", "1000base-x";
+       };
+
+       phy_common_props_with_default: phy-common-props-with-default {
+               /* name not in array, but "default" entry exists */
+               rx-polarity = <PHY_POL_NORMAL PHY_POL_INVERT>;
+               rx-polarity-names = "2500base-x", "default";
+               tx-polarity = <PHY_POL_NORMAL PHY_POL_INVERT>;
+               tx-polarity-names = "2500base-x", "default";
+       };
+
+       phy_common_props_unsupported: phy-common-props-unsupported {
+               /* PHY_POL_AUTO is not supported for manual-only modes */
+               rx-polarity = <PHY_POL_AUTO>;
+               rx-polarity-names = "sgmii";
+               tx-polarity = <PHY_POL_AUTO>;
+               tx-polarity-names = "sgmii";
+       };
+
        some-bus {
                #address-cells = <1>;
                #size-cells = <0>;
index f26295103f1cddef3765bf674912a0d77a258b0c..55dc7845544c27b1649e805572daaf24e2f8ad79 100644 (file)
@@ -285,6 +285,7 @@ CONFIG_PCI_REGION_MULTI_ENTRY=y
 CONFIG_PCI_FTPCI100=y
 CONFIG_PCI_SANDBOX=y
 CONFIG_PHY=y
+CONFIG_PHY_COMMON_PROPS=y
 CONFIG_PHY_SANDBOX=y
 CONFIG_PINCTRL=y
 CONFIG_PINCONF=y
index 771b703b737de3214e48fab6dd8f5d31fddb6c35..d69b0e08d66ab589f26bd8e46d0fd3ef0538ac2d 100644 (file)
@@ -88,6 +88,7 @@ obj-$(CONFIG_P2SB) += p2sb.o
 obj-$(CONFIG_PCI_ENDPOINT) += pci_ep.o
 obj-$(CONFIG_PCH) += pch.o
 obj-$(CONFIG_PHY) += phy.o
+obj-$(CONFIG_PHY_COMMON_PROPS) += phy_common_props.o
 ifneq ($(CONFIG_PINMUX),)
 obj-$(CONFIG_PINCONF) += pinmux.o
 endif
diff --git a/test/dm/phy_common_props.c b/test/dm/phy_common_props.c
new file mode 100644 (file)
index 0000000..21f5042
--- /dev/null
@@ -0,0 +1,319 @@
+// SPDX-License-Identifier: GPL-2.0-or-later
+/*
+ * U-Boot sandbox DM tests for PHY common props
+ *
+ * Ported from Linux KUnit test:
+ *   linux/drivers/phy/phy-common-props-test.c
+ *
+ * Copyright 2025-2026 NXP
+ */
+#include <dm.h>
+#include <dm/ofnode.h>
+#include <dm/test.h>
+#include <linux/bitops.h>
+#include <linux/phy/phy-common-props.h>
+#include <dt-bindings/phy/phy.h>
+#include <test/test.h>
+#include <test/ut.h>
+
+/* --- RX polarity tests -------------------------------------------------- */
+
+/* Test: rx-polarity property is missing => default PHY_POL_NORMAL */
+static int dm_test_phy_common_props_rx_missing(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-missing");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_rx_polarity(node, "sgmii", &val);
+       ut_asserteq(0, ret);
+       ut_asserteq(PHY_POL_NORMAL, val);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_rx_missing, UTF_SCAN_FDT);
+
+/* Test: rx-polarity has more values than rx-polarity-names => -EINVAL */
+static int dm_test_phy_common_props_rx_more_values(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-more-values");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_rx_polarity(node, "sgmii", &val);
+       ut_asserteq(-EINVAL, ret);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_rx_more_values, UTF_SCAN_FDT);
+
+/* Test: rx-polarity has 1 value and rx-polarity-names does not exist */
+static int dm_test_phy_common_props_rx_single_value(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-single");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_rx_polarity(node, "sgmii", &val);
+       ut_asserteq(0, ret);
+       ut_asserteq(PHY_POL_INVERT, val);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_rx_single_value, UTF_SCAN_FDT);
+
+/* Test: rx-polarity-names has more values than rx-polarity => -EINVAL */
+static int dm_test_phy_common_props_rx_more_names(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-more-names");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_rx_polarity(node, "sgmii", &val);
+       ut_asserteq(-EINVAL, ret);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_rx_more_names, UTF_SCAN_FDT);
+
+/* Test: valid arrays, find polarity by mode name */
+static int dm_test_phy_common_props_rx_find_by_name(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-find-by-name");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_rx_polarity(node, "sgmii", &val);
+       ut_asserteq(0, ret);
+       ut_asserteq(PHY_POL_NORMAL, val);
+
+       ret = phy_get_manual_rx_polarity(node, "2500base-x", &val);
+       ut_asserteq(0, ret);
+       ut_asserteq(PHY_POL_INVERT, val);
+
+       /* "usb-ss" has PHY_POL_AUTO; auto is supported here */
+       ret = phy_get_rx_polarity(node, "usb-ss", BIT(PHY_POL_AUTO),
+                                 PHY_POL_AUTO, &val);
+       ut_asserteq(0, ret);
+       ut_asserteq(PHY_POL_AUTO, val);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_rx_find_by_name, UTF_SCAN_FDT);
+
+/* Test: name not found, no "default" entry => -EINVAL */
+static int dm_test_phy_common_props_rx_no_default(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-no-default");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_rx_polarity(node, "sgmii", &val);
+       ut_asserteq(-EINVAL, ret);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_rx_no_default, UTF_SCAN_FDT);
+
+/* Test: name not found, "default" entry exists => use default polarity */
+static int dm_test_phy_common_props_rx_with_default(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-with-default");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_rx_polarity(node, "sgmii", &val);
+       ut_asserteq(0, ret);
+       ut_asserteq(PHY_POL_INVERT, val);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_rx_with_default, UTF_SCAN_FDT);
+
+/* Test: polarity value found but not in supported set => -EOPNOTSUPP */
+static int dm_test_phy_common_props_rx_unsupported(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-unsupported");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_rx_polarity(node, "sgmii", &val);
+       ut_asserteq(-EOPNOTSUPP, ret);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_rx_unsupported, UTF_SCAN_FDT);
+
+/* --- TX polarity tests -------------------------------------------------- */
+
+/* Test: tx-polarity property is missing => default PHY_POL_NORMAL */
+static int dm_test_phy_common_props_tx_missing(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-missing");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_tx_polarity(node, "sgmii", &val);
+       ut_asserteq(0, ret);
+       ut_asserteq(PHY_POL_NORMAL, val);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_tx_missing, UTF_SCAN_FDT);
+
+/* Test: tx-polarity has more values than tx-polarity-names => -EINVAL */
+static int dm_test_phy_common_props_tx_more_values(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-more-values");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_tx_polarity(node, "sgmii", &val);
+       ut_asserteq(-EINVAL, ret);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_tx_more_values, UTF_SCAN_FDT);
+
+/* Test: tx-polarity has 1 value and tx-polarity-names does not exist */
+static int dm_test_phy_common_props_tx_single_value(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-single");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_tx_polarity(node, "sgmii", &val);
+       ut_asserteq(0, ret);
+       ut_asserteq(PHY_POL_INVERT, val);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_tx_single_value, UTF_SCAN_FDT);
+
+/* Test: tx-polarity-names has more values than tx-polarity => -EINVAL */
+static int dm_test_phy_common_props_tx_more_names(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-more-names");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_tx_polarity(node, "sgmii", &val);
+       ut_asserteq(-EINVAL, ret);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_tx_more_names, UTF_SCAN_FDT);
+
+/* Test: valid arrays, find polarity by mode name */
+static int dm_test_phy_common_props_tx_find_by_name(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-find-by-name");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_tx_polarity(node, "sgmii", &val);
+       ut_asserteq(0, ret);
+       ut_asserteq(PHY_POL_NORMAL, val);
+
+       ret = phy_get_manual_tx_polarity(node, "2500base-x", &val);
+       ut_asserteq(0, ret);
+       ut_asserteq(PHY_POL_INVERT, val);
+
+       ret = phy_get_manual_tx_polarity(node, "1000base-x", &val);
+       ut_asserteq(0, ret);
+       ut_asserteq(PHY_POL_NORMAL, val);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_tx_find_by_name, UTF_SCAN_FDT);
+
+/* Test: name not found, no "default" entry => -EINVAL */
+static int dm_test_phy_common_props_tx_no_default(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-no-default");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_tx_polarity(node, "sgmii", &val);
+       ut_asserteq(-EINVAL, ret);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_tx_no_default, UTF_SCAN_FDT);
+
+/* Test: name not found, "default" entry exists => use default polarity */
+static int dm_test_phy_common_props_tx_with_default(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-with-default");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_tx_polarity(node, "sgmii", &val);
+       ut_asserteq(0, ret);
+       ut_asserteq(PHY_POL_INVERT, val);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_tx_with_default, UTF_SCAN_FDT);
+
+/* Test: polarity value found but not in supported set => -EOPNOTSUPP */
+static int dm_test_phy_common_props_tx_unsupported(struct unit_test_state *uts)
+{
+       ofnode node = ofnode_path("/phy-common-props-unsupported");
+       unsigned int val;
+       int ret;
+
+       ut_assert(ofnode_valid(node));
+
+       ret = phy_get_manual_tx_polarity(node, "sgmii", &val);
+       ut_asserteq(-EOPNOTSUPP, ret);
+
+       return 0;
+}
+
+DM_TEST(dm_test_phy_common_props_tx_unsupported, UTF_SCAN_FDT);