batman-adv: Replace usage of strlcpy with strscpy
authorSven Eckelmann <sven@narfation.org>
Sat, 6 Jul 2019 12:56:13 +0000 (14:56 +0200)
committerSimon Wunderlich <sw@simonwunderlich.de>
Mon, 22 Jul 2019 19:34:14 +0000 (21:34 +0200)
The strscpy was introduced to fix some API problems around strlcpy. And
checkpatch started to report recently that strlcpy is deprecated and
strscpy is preferred.

The functionality introduced in commit 30035e45753b ("string: provide
strscpy()") improves following points compared to strlcpy:

* it doesn't read from memory beyond (src + size)
* provides an easy way to check for destination buffer overflow
* robust against asynchronous source buffer changes

Since batman-adv doesn't depend on any of the previously mentioned behavior
changes, the usage of strlcpy can simply be replaced by strscpy to silence
checkpatch.

Signed-off-by: Sven Eckelmann <sven@narfation.org>
Signed-off-by: Simon Wunderlich <sw@simonwunderlich.de>
net/batman-adv/soft-interface.c
net/batman-adv/sysfs.c

index c7a2e77..a1146cb 100644 (file)
@@ -943,10 +943,10 @@ static const struct net_device_ops batadv_netdev_ops = {
 static void batadv_get_drvinfo(struct net_device *dev,
                               struct ethtool_drvinfo *info)
 {
-       strlcpy(info->driver, "B.A.T.M.A.N. advanced", sizeof(info->driver));
-       strlcpy(info->version, BATADV_SOURCE_VERSION, sizeof(info->version));
-       strlcpy(info->fw_version, "N/A", sizeof(info->fw_version));
-       strlcpy(info->bus_info, "batman", sizeof(info->bus_info));
+       strscpy(info->driver, "B.A.T.M.A.N. advanced", sizeof(info->driver));
+       strscpy(info->version, BATADV_SOURCE_VERSION, sizeof(info->version));
+       strscpy(info->fw_version, "N/A", sizeof(info->fw_version));
+       strscpy(info->bus_info, "batman", sizeof(info->bus_info));
 }
 
 /* Inspired by drivers/net/ethernet/dlink/sundance.c:1702
index 1efcb97..e5bbc28 100644 (file)
@@ -1070,7 +1070,7 @@ static ssize_t batadv_store_mesh_iface(struct kobject *kobj,
        dev_hold(net_dev);
        INIT_WORK(&store_work->work, batadv_store_mesh_iface_work);
        store_work->net_dev = net_dev;
-       strlcpy(store_work->soft_iface_name, buff,
+       strscpy(store_work->soft_iface_name, buff,
                sizeof(store_work->soft_iface_name));
 
        queue_work(batadv_event_workqueue, &store_work->work);