mirror of https://gitee.com/openkylin/linux.git
s390/qeth: avoid null pointer dereference on OSN
Access card->dev only after checking whether's its valid. Signed-off-by: Julian Wiedmann <jwi@linux.vnet.ibm.com> Reviewed-by: Ursula Braun <ubraun@linux.vnet.ibm.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
2d2ebb3ed0
commit
25e2c341e7
|
@ -965,7 +965,6 @@ static int qeth_l2_setup_netdev(struct qeth_card *card)
|
||||||
case QETH_CARD_TYPE_OSN:
|
case QETH_CARD_TYPE_OSN:
|
||||||
card->dev = alloc_netdev(0, "osn%d", NET_NAME_UNKNOWN,
|
card->dev = alloc_netdev(0, "osn%d", NET_NAME_UNKNOWN,
|
||||||
ether_setup);
|
ether_setup);
|
||||||
card->dev->flags |= IFF_NOARP;
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
card->dev = alloc_etherdev(0);
|
card->dev = alloc_etherdev(0);
|
||||||
|
@ -980,9 +979,12 @@ static int qeth_l2_setup_netdev(struct qeth_card *card)
|
||||||
card->dev->min_mtu = 64;
|
card->dev->min_mtu = 64;
|
||||||
card->dev->max_mtu = ETH_MAX_MTU;
|
card->dev->max_mtu = ETH_MAX_MTU;
|
||||||
card->dev->netdev_ops = &qeth_l2_netdev_ops;
|
card->dev->netdev_ops = &qeth_l2_netdev_ops;
|
||||||
card->dev->ethtool_ops =
|
if (card->info.type == QETH_CARD_TYPE_OSN) {
|
||||||
(card->info.type != QETH_CARD_TYPE_OSN) ?
|
card->dev->ethtool_ops = &qeth_l2_osn_ops;
|
||||||
&qeth_l2_ethtool_ops : &qeth_l2_osn_ops;
|
card->dev->flags |= IFF_NOARP;
|
||||||
|
} else {
|
||||||
|
card->dev->ethtool_ops = &qeth_l2_ethtool_ops;
|
||||||
|
}
|
||||||
card->dev->features |= NETIF_F_HW_VLAN_CTAG_FILTER;
|
card->dev->features |= NETIF_F_HW_VLAN_CTAG_FILTER;
|
||||||
if (card->info.type == QETH_CARD_TYPE_OSD && !card->info.guestlan) {
|
if (card->info.type == QETH_CARD_TYPE_OSD && !card->info.guestlan) {
|
||||||
card->dev->hw_features = NETIF_F_SG;
|
card->dev->hw_features = NETIF_F_SG;
|
||||||
|
|
Loading…
Reference in New Issue