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 | |
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>
-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; |