diff options
| author | Govindarajulu Varadarajan <_govind@gmx.com> | 2015-06-11 02:22:55 -0400 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2015-06-11 02:42:39 -0400 |
| commit | 19b596bda1c5400808635fde0d521c1f89a6c1a3 (patch) | |
| tree | 5484ba980423c60c8f684cc681d9c76883fe11ff /drivers/net/ethernet | |
| parent | 6286e8285078ab02b215bba1d42a05ecfd864515 (diff) | |
enic: check return value for stat dump
We do not check the return value of enic_dev_stats_dump(). If allocation
fails, we will hit NULL pointer reference.
Return only if memory allocation fails. For other failures, we return the
previously recorded values.
Signed-off-by: Govindarajulu Varadarajan <_govind@gmx.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet')
| -rw-r--r-- | drivers/net/ethernet/cisco/enic/enic_ethtool.c | 20 | ||||
| -rw-r--r-- | drivers/net/ethernet/cisco/enic/enic_main.c | 9 |
2 files changed, 25 insertions, 4 deletions
diff --git a/drivers/net/ethernet/cisco/enic/enic_ethtool.c b/drivers/net/ethernet/cisco/enic/enic_ethtool.c index 28d9ca675a27..68d47b196dae 100644 --- a/drivers/net/ethernet/cisco/enic/enic_ethtool.c +++ b/drivers/net/ethernet/cisco/enic/enic_ethtool.c | |||
| @@ -131,8 +131,15 @@ static void enic_get_drvinfo(struct net_device *netdev, | |||
| 131 | { | 131 | { |
| 132 | struct enic *enic = netdev_priv(netdev); | 132 | struct enic *enic = netdev_priv(netdev); |
| 133 | struct vnic_devcmd_fw_info *fw_info; | 133 | struct vnic_devcmd_fw_info *fw_info; |
| 134 | int err; | ||
| 134 | 135 | ||
| 135 | enic_dev_fw_info(enic, &fw_info); | 136 | err = enic_dev_fw_info(enic, &fw_info); |
| 137 | /* return only when pci_zalloc_consistent fails in vnic_dev_fw_info | ||
| 138 | * For other failures, like devcmd failure, we return previously | ||
| 139 | * recorded info. | ||
| 140 | */ | ||
| 141 | if (err == -ENOMEM) | ||
| 142 | return; | ||
| 136 | 143 | ||
| 137 | strlcpy(drvinfo->driver, DRV_NAME, sizeof(drvinfo->driver)); | 144 | strlcpy(drvinfo->driver, DRV_NAME, sizeof(drvinfo->driver)); |
| 138 | strlcpy(drvinfo->version, DRV_VERSION, sizeof(drvinfo->version)); | 145 | strlcpy(drvinfo->version, DRV_VERSION, sizeof(drvinfo->version)); |
| @@ -181,8 +188,15 @@ static void enic_get_ethtool_stats(struct net_device *netdev, | |||
| 181 | struct enic *enic = netdev_priv(netdev); | 188 | struct enic *enic = netdev_priv(netdev); |
| 182 | struct vnic_stats *vstats; | 189 | struct vnic_stats *vstats; |
| 183 | unsigned int i; | 190 | unsigned int i; |
| 184 | 191 | int err; | |
| 185 | enic_dev_stats_dump(enic, &vstats); | 192 | |
| 193 | err = enic_dev_stats_dump(enic, &vstats); | ||
| 194 | /* return only when pci_zalloc_consistent fails in vnic_dev_stats_dump | ||
| 195 | * For other failures, like devcmd failure, we return previously | ||
| 196 | * recorded stats. | ||
| 197 | */ | ||
| 198 | if (err == -ENOMEM) | ||
| 199 | return; | ||
| 186 | 200 | ||
| 187 | for (i = 0; i < enic_n_tx_stats; i++) | 201 | for (i = 0; i < enic_n_tx_stats; i++) |
| 188 | *(data++) = ((u64 *)&vstats->tx)[enic_tx_stats[i].index]; | 202 | *(data++) = ((u64 *)&vstats->tx)[enic_tx_stats[i].index]; |
diff --git a/drivers/net/ethernet/cisco/enic/enic_main.c b/drivers/net/ethernet/cisco/enic/enic_main.c index 0e5a01dd7545..eadae1b412c6 100644 --- a/drivers/net/ethernet/cisco/enic/enic_main.c +++ b/drivers/net/ethernet/cisco/enic/enic_main.c | |||
| @@ -615,8 +615,15 @@ static struct rtnl_link_stats64 *enic_get_stats(struct net_device *netdev, | |||
| 615 | { | 615 | { |
| 616 | struct enic *enic = netdev_priv(netdev); | 616 | struct enic *enic = netdev_priv(netdev); |
| 617 | struct vnic_stats *stats; | 617 | struct vnic_stats *stats; |
| 618 | int err; | ||
| 618 | 619 | ||
| 619 | enic_dev_stats_dump(enic, &stats); | 620 | err = enic_dev_stats_dump(enic, &stats); |
| 621 | /* return only when pci_zalloc_consistent fails in vnic_dev_stats_dump | ||
| 622 | * For other failures, like devcmd failure, we return previously | ||
| 623 | * recorded stats. | ||
| 624 | */ | ||
| 625 | if (err == -ENOMEM) | ||
| 626 | return net_stats; | ||
| 620 | 627 | ||
| 621 | net_stats->tx_packets = stats->tx.tx_frames_ok; | 628 | net_stats->tx_packets = stats->tx.tx_frames_ok; |
| 622 | net_stats->tx_bytes = stats->tx.tx_bytes_ok; | 629 | net_stats->tx_bytes = stats->tx.tx_bytes_ok; |
