Commit d64d11b7 authored by Jakub Kicinski's avatar Jakub Kicinski

Merge branch 'replace-deprecated-strcpy-with-strscpy'

Hongbo Li says:

====================
replace deprecated strcpy with strscpy

The deprecated helper strcpy() performs no bounds checking on the
destination buffer. This could result in linear overflows beyond
the end of the buffer, leading to all kinds of misbehaviors.
The safe replacement is strscpy() [1].

Link: https://www.kernel.org/doc/html/latest/process/deprecated.html#strcpy [1]
====================

Link: https://patch.msgid.link/20240828123224.3697672-1-lihongbo22@huawei.comSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parents 3cbd2090 82183b03
...@@ -11143,7 +11143,7 @@ struct net_device *alloc_netdev_mqs(int sizeof_priv, const char *name, ...@@ -11143,7 +11143,7 @@ struct net_device *alloc_netdev_mqs(int sizeof_priv, const char *name,
if (!dev->ethtool) if (!dev->ethtool)
goto free_all; goto free_all;
strcpy(dev->name, name); strscpy(dev->name, name);
dev->name_assign_type = name_assign_type; dev->name_assign_type = name_assign_type;
dev->group = INIT_NETDEV_GROUP; dev->group = INIT_NETDEV_GROUP;
if (!dev->ethtool_ops) if (!dev->ethtool_ops)
......
...@@ -1326,7 +1326,7 @@ int ip_tunnel_init(struct net_device *dev) ...@@ -1326,7 +1326,7 @@ int ip_tunnel_init(struct net_device *dev)
tunnel->dev = dev; tunnel->dev = dev;
tunnel->net = dev_net(dev); tunnel->net = dev_net(dev);
strcpy(tunnel->parms.name, dev->name); strscpy(tunnel->parms.name, dev->name);
iph->version = 4; iph->version = 4;
iph->ihl = 5; iph->ihl = 5;
......
...@@ -826,7 +826,7 @@ static int get_info(struct net *net, void __user *user, const int *len) ...@@ -826,7 +826,7 @@ static int get_info(struct net *net, void __user *user, const int *len)
sizeof(info.underflow)); sizeof(info.underflow));
info.num_entries = private->number; info.num_entries = private->number;
info.size = private->size; info.size = private->size;
strcpy(info.name, name); strscpy(info.name, name);
if (copy_to_user(user, &info, *len) != 0) if (copy_to_user(user, &info, *len) != 0)
ret = -EFAULT; ret = -EFAULT;
......
...@@ -981,7 +981,7 @@ static int get_info(struct net *net, void __user *user, const int *len) ...@@ -981,7 +981,7 @@ static int get_info(struct net *net, void __user *user, const int *len)
sizeof(info.underflow)); sizeof(info.underflow));
info.num_entries = private->number; info.num_entries = private->number;
info.size = private->size; info.size = private->size;
strcpy(info.name, name); strscpy(info.name, name);
if (copy_to_user(user, &info, *len) != 0) if (copy_to_user(user, &info, *len) != 0)
ret = -EFAULT; ret = -EFAULT;
......
...@@ -1944,7 +1944,7 @@ static void ndisc_warn_deprecated_sysctl(const struct ctl_table *ctl, ...@@ -1944,7 +1944,7 @@ static void ndisc_warn_deprecated_sysctl(const struct ctl_table *ctl,
static char warncomm[TASK_COMM_LEN]; static char warncomm[TASK_COMM_LEN];
static int warned; static int warned;
if (strcmp(warncomm, current->comm) && warned < 5) { if (strcmp(warncomm, current->comm) && warned < 5) {
strcpy(warncomm, current->comm); strscpy(warncomm, current->comm);
pr_warn("process `%s' is using deprecated sysctl (%s) net.ipv6.neigh.%s.%s - use net.ipv6.neigh.%s.%s_ms instead\n", pr_warn("process `%s' is using deprecated sysctl (%s) net.ipv6.neigh.%s.%s - use net.ipv6.neigh.%s.%s_ms instead\n",
warncomm, func, warncomm, func,
dev_name, ctl->procname, dev_name, ctl->procname,
......
...@@ -189,7 +189,7 @@ static int __must_check nr_add_node(ax25_address *nr, const char *mnemonic, ...@@ -189,7 +189,7 @@ static int __must_check nr_add_node(ax25_address *nr, const char *mnemonic,
} }
nr_node->callsign = *nr; nr_node->callsign = *nr;
strcpy(nr_node->mnemonic, mnemonic); strscpy(nr_node->mnemonic, mnemonic);
nr_node->which = 0; nr_node->which = 0;
nr_node->count = 1; nr_node->count = 1;
...@@ -214,7 +214,7 @@ static int __must_check nr_add_node(ax25_address *nr, const char *mnemonic, ...@@ -214,7 +214,7 @@ static int __must_check nr_add_node(ax25_address *nr, const char *mnemonic,
nr_node_lock(nr_node); nr_node_lock(nr_node);
if (quality != 0) if (quality != 0)
strcpy(nr_node->mnemonic, mnemonic); strscpy(nr_node->mnemonic, mnemonic);
for (found = 0, i = 0; i < nr_node->count; i++) { for (found = 0, i = 0; i < nr_node->count; i++) {
if (nr_node->routes[i].neighbour == nr_neigh) { if (nr_node->routes[i].neighbour == nr_neigh) {
......
...@@ -326,7 +326,7 @@ static int tipc_enable_bearer(struct net *net, const char *name, ...@@ -326,7 +326,7 @@ static int tipc_enable_bearer(struct net *net, const char *name,
if (!b) if (!b)
return -ENOMEM; return -ENOMEM;
strcpy(b->name, name); strscpy(b->name, name);
b->media = m; b->media = m;
res = m->enable_media(net, b, attr); res = m->enable_media(net, b, attr);
if (res) { if (res) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment