net: phy: micrel: Allow probing without .driver_data
authorFabio Estevam <festevam@denx.de>
Fri, 13 May 2022 11:46:12 +0000 (08:46 -0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 9 Jun 2022 08:22:38 +0000 (10:22 +0200)
[ Upstream commit f2ef6f7539c68c6bd6c32323d8845ee102b7c450 ]

Currently, if the .probe element is present in the phy_driver structure
and the .driver_data is not, a NULL pointer dereference happens.

Allow passing .probe without .driver_data by inserting NULL checks
for priv->type.

Signed-off-by: Fabio Estevam <festevam@denx.de>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Link: https://lore.kernel.org/r/20220513114613.762810-1-festevam@gmail.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/phy/micrel.c

index 64d829ed98876819a2130e2fa0efdbdb006cb034..05a8985d710736ae44423a7411bc0cdeddf0dff4 100644 (file)
@@ -335,7 +335,7 @@ static int kszphy_config_reset(struct phy_device *phydev)
                }
        }
 
-       if (priv->led_mode >= 0)
+       if (priv->type && priv->led_mode >= 0)
                kszphy_setup_led(phydev, priv->type->led_mode_reg, priv->led_mode);
 
        return 0;
@@ -351,10 +351,10 @@ static int kszphy_config_init(struct phy_device *phydev)
 
        type = priv->type;
 
-       if (type->has_broadcast_disable)
+       if (type && type->has_broadcast_disable)
                kszphy_broadcast_disable(phydev);
 
-       if (type->has_nand_tree_disable)
+       if (type && type->has_nand_tree_disable)
                kszphy_nand_tree_disable(phydev);
 
        return kszphy_config_reset(phydev);
@@ -1328,7 +1328,7 @@ static int kszphy_probe(struct phy_device *phydev)
 
        priv->type = type;
 
-       if (type->led_mode_reg) {
+       if (type && type->led_mode_reg) {
                ret = of_property_read_u32(np, "micrel,led-mode",
                                &priv->led_mode);
                if (ret)
@@ -1349,7 +1349,8 @@ static int kszphy_probe(struct phy_device *phydev)
                unsigned long rate = clk_get_rate(clk);
                bool rmii_ref_clk_sel_25_mhz;
 
-               priv->rmii_ref_clk_sel = type->has_rmii_ref_clk_sel;
+               if (type)
+                       priv->rmii_ref_clk_sel = type->has_rmii_ref_clk_sel;
                rmii_ref_clk_sel_25_mhz = of_property_read_bool(np,
                                "micrel,rmii-reference-clock-select-25-mhz");