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 c7a2e77ca1da5acf0e1ce080ba172867138ec66f..a1146cb10919e5647720f1ec6d0abf27fed652d0 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 1efcb97039cd46a17642c93dff06ea34b5c67c8b..e5bbc28ed12c3a221a6b1a06d4379d406da0e9da 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);