ethtool: Null-terminate filename passed to ethtool_ops::flash_device
The parameters for ETHTOOL_FLASHDEV include a filename, which ought to be null-terminated. Currently the only driver that implements ethtool_ops::flash_device attempts to add a null terminator if necessary, but does it wrongly. Do it in the ethtool core instead. Signed-off-by: Ben Hutchings <bhutchings@solarflare.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
efcdbf24fd
commit
786f528119
@@ -716,12 +716,8 @@ static int
|
|||||||
be_do_flash(struct net_device *netdev, struct ethtool_flash *efl)
|
be_do_flash(struct net_device *netdev, struct ethtool_flash *efl)
|
||||||
{
|
{
|
||||||
struct be_adapter *adapter = netdev_priv(netdev);
|
struct be_adapter *adapter = netdev_priv(netdev);
|
||||||
char file_name[ETHTOOL_FLASH_MAX_FILENAME];
|
|
||||||
|
|
||||||
file_name[ETHTOOL_FLASH_MAX_FILENAME - 1] = 0;
|
return be_load_fw(adapter, efl->data);
|
||||||
strcpy(file_name, efl->data);
|
|
||||||
|
|
||||||
return be_load_fw(adapter, file_name);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
@@ -1190,6 +1190,8 @@ static noinline_for_stack int ethtool_flash_device(struct net_device *dev,
|
|||||||
if (!dev->ethtool_ops->flash_device)
|
if (!dev->ethtool_ops->flash_device)
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
|
efl.data[ETHTOOL_FLASH_MAX_FILENAME - 1] = 0;
|
||||||
|
|
||||||
return dev->ethtool_ops->flash_device(dev, &efl);
|
return dev->ethtool_ops->flash_device(dev, &efl);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user