net: netcp: check for interface handle in netcp_module_probe()

Currently netcp_module_probe() doesn't check the return value of
of_parse_phandle() that points to the interface data for the
module and then pass the node ptr to the module which is incorrect.
Check for return value and free the intf_modpriv if there is error.

Signed-off-by: Murali Karicheri <m-karicheri2@ti.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Karicheri, Muralidharan 2015-09-23 13:37:09 -04:00 committed by David S. Miller
parent e558b1fbf5
commit 915c585787
1 changed files with 5 additions and 0 deletions

View File

@ -299,6 +299,11 @@ static int netcp_module_probe(struct netcp_device *netcp_device,
interface = of_parse_phandle(netcp_intf->node_interface, interface = of_parse_phandle(netcp_intf->node_interface,
module->name, 0); module->name, 0);
if (!interface) {
devm_kfree(dev, intf_modpriv);
continue;
}
intf_modpriv->netcp_priv = netcp_intf; intf_modpriv->netcp_priv = netcp_intf;
intf_modpriv->netcp_module = module; intf_modpriv->netcp_module = module;
list_add_tail(&intf_modpriv->intf_list, list_add_tail(&intf_modpriv->intf_list,