diff mbox series

[RFC,v3,3/3] Rename nla_strlcpy to nla_strscpy.

Message ID 20201020164707.30402-4-laniel_francis@privacyrequired.com
State Superseded
Headers show
Series Fix inefficiences and rename nla_strlcpy | expand

Commit Message

Francis Laniel Oct. 20, 2020, 4:47 p.m. UTC
From: Francis Laniel <laniel_francis@privacyrequired.com>

Calls to nla_strlcpy are now replaced by calls to nla_strscpy which is the new
name of this function.

Signed-off-by: Francis Laniel <laniel_francis@privacyrequired.com>
---
 drivers/infiniband/core/nldev.c            | 10 +++++-----
 drivers/net/can/vxcan.c                    |  4 ++--
 drivers/net/veth.c                         |  4 ++--
 include/linux/genl_magic_struct.h          |  2 +-
 include/net/netlink.h                      |  4 ++--
 include/net/pkt_cls.h                      |  2 +-
 kernel/taskstats.c                         |  2 +-
 lib/nlattr.c                               |  6 +++---
 net/core/fib_rules.c                       |  4 ++--
 net/core/rtnetlink.c                       | 12 ++++++------
 net/decnet/dn_dev.c                        |  2 +-
 net/ieee802154/nl-mac.c                    |  2 +-
 net/ipv4/devinet.c                         |  2 +-
 net/ipv4/fib_semantics.c                   |  2 +-
 net/ipv4/metrics.c                         |  2 +-
 net/netfilter/ipset/ip_set_hash_netiface.c |  4 ++--
 net/netfilter/nf_tables_api.c              |  6 +++---
 net/netfilter/nfnetlink_acct.c             |  2 +-
 net/netfilter/nfnetlink_cthelper.c         |  4 ++--
 net/netfilter/nft_ct.c                     |  2 +-
 net/netfilter/nft_log.c                    |  2 +-
 net/netlabel/netlabel_mgmt.c               |  2 +-
 net/nfc/netlink.c                          |  2 +-
 net/sched/act_api.c                        |  2 +-
 net/sched/act_ipt.c                        |  2 +-
 net/sched/act_simple.c                     |  4 ++--
 net/sched/cls_api.c                        |  2 +-
 net/sched/sch_api.c                        |  2 +-
 net/tipc/netlink_compat.c                  |  2 +-
 29 files changed, 49 insertions(+), 49 deletions(-)

Comments

Kees Cook Oct. 21, 2020, 11:49 p.m. UTC | #1
On Tue, Oct 20, 2020 at 06:47:07PM +0200, laniel_francis@privacyrequired.com wrote:
> From: Francis Laniel <laniel_francis@privacyrequired.com>

> 

> Calls to nla_strlcpy are now replaced by calls to nla_strscpy which is the new

> name of this function.

> 

> Signed-off-by: Francis Laniel <laniel_francis@privacyrequired.com>


The Subject could also be: "treewide: Rename nla_strlcpy to nla_strscpy"

But otherwise, yup, easy mechanical change.

Reviewed-by: Kees Cook <keescook@chromium.org>


> ---

>  drivers/infiniband/core/nldev.c            | 10 +++++-----

>  drivers/net/can/vxcan.c                    |  4 ++--

>  drivers/net/veth.c                         |  4 ++--

>  include/linux/genl_magic_struct.h          |  2 +-

>  include/net/netlink.h                      |  4 ++--

>  include/net/pkt_cls.h                      |  2 +-

>  kernel/taskstats.c                         |  2 +-

>  lib/nlattr.c                               |  6 +++---

>  net/core/fib_rules.c                       |  4 ++--

>  net/core/rtnetlink.c                       | 12 ++++++------

>  net/decnet/dn_dev.c                        |  2 +-

>  net/ieee802154/nl-mac.c                    |  2 +-

>  net/ipv4/devinet.c                         |  2 +-

>  net/ipv4/fib_semantics.c                   |  2 +-

>  net/ipv4/metrics.c                         |  2 +-

>  net/netfilter/ipset/ip_set_hash_netiface.c |  4 ++--

>  net/netfilter/nf_tables_api.c              |  6 +++---

>  net/netfilter/nfnetlink_acct.c             |  2 +-

>  net/netfilter/nfnetlink_cthelper.c         |  4 ++--

>  net/netfilter/nft_ct.c                     |  2 +-

>  net/netfilter/nft_log.c                    |  2 +-

>  net/netlabel/netlabel_mgmt.c               |  2 +-

>  net/nfc/netlink.c                          |  2 +-

>  net/sched/act_api.c                        |  2 +-

>  net/sched/act_ipt.c                        |  2 +-

>  net/sched/act_simple.c                     |  4 ++--

>  net/sched/cls_api.c                        |  2 +-

>  net/sched/sch_api.c                        |  2 +-

>  net/tipc/netlink_compat.c                  |  2 +-

>  29 files changed, 49 insertions(+), 49 deletions(-)

> 

> diff --git a/drivers/infiniband/core/nldev.c b/drivers/infiniband/core/nldev.c

> index 12d29d54a081..08366e254b1d 100644

> --- a/drivers/infiniband/core/nldev.c

> +++ b/drivers/infiniband/core/nldev.c

> @@ -932,7 +932,7 @@ static int nldev_set_doit(struct sk_buff *skb, struct nlmsghdr *nlh,

>  	if (tb[RDMA_NLDEV_ATTR_DEV_NAME]) {

>  		char name[IB_DEVICE_NAME_MAX] = {};

>  

> -		nla_strlcpy(name, tb[RDMA_NLDEV_ATTR_DEV_NAME],

> +		nla_strscpy(name, tb[RDMA_NLDEV_ATTR_DEV_NAME],

>  			    IB_DEVICE_NAME_MAX);

>  		if (strlen(name) == 0) {

>  			err = -EINVAL;

> @@ -1529,13 +1529,13 @@ static int nldev_newlink(struct sk_buff *skb, struct nlmsghdr *nlh,

>  	    !tb[RDMA_NLDEV_ATTR_LINK_TYPE] || !tb[RDMA_NLDEV_ATTR_NDEV_NAME])

>  		return -EINVAL;

>  

> -	nla_strlcpy(ibdev_name, tb[RDMA_NLDEV_ATTR_DEV_NAME],

> +	nla_strscpy(ibdev_name, tb[RDMA_NLDEV_ATTR_DEV_NAME],

>  		    sizeof(ibdev_name));

>  	if (strchr(ibdev_name, '%') || strlen(ibdev_name) == 0)

>  		return -EINVAL;

>  

> -	nla_strlcpy(type, tb[RDMA_NLDEV_ATTR_LINK_TYPE], sizeof(type));

> -	nla_strlcpy(ndev_name, tb[RDMA_NLDEV_ATTR_NDEV_NAME],

> +	nla_strscpy(type, tb[RDMA_NLDEV_ATTR_LINK_TYPE], sizeof(type));

> +	nla_strscpy(ndev_name, tb[RDMA_NLDEV_ATTR_NDEV_NAME],

>  		    sizeof(ndev_name));

>  

>  	ndev = dev_get_by_name(sock_net(skb->sk), ndev_name);

> @@ -1602,7 +1602,7 @@ static int nldev_get_chardev(struct sk_buff *skb, struct nlmsghdr *nlh,

>  	if (err || !tb[RDMA_NLDEV_ATTR_CHARDEV_TYPE])

>  		return -EINVAL;

>  

> -	nla_strlcpy(client_name, tb[RDMA_NLDEV_ATTR_CHARDEV_TYPE],

> +	nla_strscpy(client_name, tb[RDMA_NLDEV_ATTR_CHARDEV_TYPE],

>  		    sizeof(client_name));

>  

>  	if (tb[RDMA_NLDEV_ATTR_DEV_INDEX]) {

> diff --git a/drivers/net/can/vxcan.c b/drivers/net/can/vxcan.c

> index d6ba9426be4d..fa47bab510bb 100644

> --- a/drivers/net/can/vxcan.c

> +++ b/drivers/net/can/vxcan.c

> @@ -186,7 +186,7 @@ static int vxcan_newlink(struct net *net, struct net_device *dev,

>  	}

>  

>  	if (ifmp && tbp[IFLA_IFNAME]) {

> -		nla_strlcpy(ifname, tbp[IFLA_IFNAME], IFNAMSIZ);

> +		nla_strscpy(ifname, tbp[IFLA_IFNAME], IFNAMSIZ);

>  		name_assign_type = NET_NAME_USER;

>  	} else {

>  		snprintf(ifname, IFNAMSIZ, DRV_NAME "%%d");

> @@ -223,7 +223,7 @@ static int vxcan_newlink(struct net *net, struct net_device *dev,

>  

>  	/* register first device */

>  	if (tb[IFLA_IFNAME])

> -		nla_strlcpy(dev->name, tb[IFLA_IFNAME], IFNAMSIZ);

> +		nla_strscpy(dev->name, tb[IFLA_IFNAME], IFNAMSIZ);

>  	else

>  		snprintf(dev->name, IFNAMSIZ, DRV_NAME "%%d");

>  

> diff --git a/drivers/net/veth.c b/drivers/net/veth.c

> index 8c737668008a..359d3ab33c4d 100644

> --- a/drivers/net/veth.c

> +++ b/drivers/net/veth.c

> @@ -1329,7 +1329,7 @@ static int veth_newlink(struct net *src_net, struct net_device *dev,

>  	}

>  

>  	if (ifmp && tbp[IFLA_IFNAME]) {

> -		nla_strlcpy(ifname, tbp[IFLA_IFNAME], IFNAMSIZ);

> +		nla_strscpy(ifname, tbp[IFLA_IFNAME], IFNAMSIZ);

>  		name_assign_type = NET_NAME_USER;

>  	} else {

>  		snprintf(ifname, IFNAMSIZ, DRV_NAME "%%d");

> @@ -1379,7 +1379,7 @@ static int veth_newlink(struct net *src_net, struct net_device *dev,

>  		eth_hw_addr_random(dev);

>  

>  	if (tb[IFLA_IFNAME])

> -		nla_strlcpy(dev->name, tb[IFLA_IFNAME], IFNAMSIZ);

> +		nla_strscpy(dev->name, tb[IFLA_IFNAME], IFNAMSIZ);

>  	else

>  		snprintf(dev->name, IFNAMSIZ, DRV_NAME "%%d");

>  

> diff --git a/include/linux/genl_magic_struct.h b/include/linux/genl_magic_struct.h

> index eeae59d3ceb7..35d21fddaf2d 100644

> --- a/include/linux/genl_magic_struct.h

> +++ b/include/linux/genl_magic_struct.h

> @@ -89,7 +89,7 @@ static inline int nla_put_u64_0pad(struct sk_buff *skb, int attrtype, u64 value)

>  			nla_get_u64, nla_put_u64_0pad, false)

>  #define __str_field(attr_nr, attr_flag, name, maxlen) \

>  	__array(attr_nr, attr_flag, name, NLA_NUL_STRING, char, maxlen, \

> -			nla_strlcpy, nla_put, false)

> +			nla_strscpy, nla_put, false)

>  #define __bin_field(attr_nr, attr_flag, name, maxlen) \

>  	__array(attr_nr, attr_flag, name, NLA_BINARY, char, maxlen, \

>  			nla_memcpy, nla_put, false)

> diff --git a/include/net/netlink.h b/include/net/netlink.h

> index 446ca182e13d..1ceec518ab49 100644

> --- a/include/net/netlink.h

> +++ b/include/net/netlink.h

> @@ -142,7 +142,7 @@

>   * Attribute Misc:

>   *   nla_memcpy(dest, nla, count)	copy attribute into memory

>   *   nla_memcmp(nla, data, size)	compare attribute with memory area

> - *   nla_strlcpy(dst, nla, size)	copy attribute to a sized string

> + *   nla_strscpy(dst, nla, size)	copy attribute to a sized string

>   *   nla_strcmp(nla, str)		compare attribute with string

>   *

>   * Attribute Parsing:

> @@ -506,7 +506,7 @@ int __nla_parse(struct nlattr **tb, int maxtype, const struct nlattr *head,

>  		struct netlink_ext_ack *extack);

>  int nla_policy_len(const struct nla_policy *, int);

>  struct nlattr *nla_find(const struct nlattr *head, int len, int attrtype);

> -ssize_t nla_strlcpy(char *dst, const struct nlattr *nla, size_t dstsize);

> +ssize_t nla_strscpy(char *dst, const struct nlattr *nla, size_t dstsize);

>  char *nla_strdup(const struct nlattr *nla, gfp_t flags);

>  int nla_memcpy(void *dest, const struct nlattr *src, int count);

>  int nla_memcmp(const struct nlattr *nla, const void *data, size_t size);

> diff --git a/include/net/pkt_cls.h b/include/net/pkt_cls.h

> index db9a828f4f4f..133f9ad4d4f9 100644

> --- a/include/net/pkt_cls.h

> +++ b/include/net/pkt_cls.h

> @@ -512,7 +512,7 @@ tcf_change_indev(struct net *net, struct nlattr *indev_tlv,

>  	char indev[IFNAMSIZ];

>  	struct net_device *dev;

>  

> -	if (nla_strlcpy(indev, indev_tlv, IFNAMSIZ) < 0) {

> +	if (nla_strscpy(indev, indev_tlv, IFNAMSIZ) < 0) {

>  		NL_SET_ERR_MSG_ATTR(extack, indev_tlv,

>  				    "Interface name too long");

>  		return -EINVAL;

> diff --git a/kernel/taskstats.c b/kernel/taskstats.c

> index a2802b6ff4bb..2b4898b4752e 100644

> --- a/kernel/taskstats.c

> +++ b/kernel/taskstats.c

> @@ -346,7 +346,7 @@ static int parse(struct nlattr *na, struct cpumask *mask)

>  	data = kmalloc(len, GFP_KERNEL);

>  	if (!data)

>  		return -ENOMEM;

> -	nla_strlcpy(data, na, len);

> +	nla_strscpy(data, na, len);

>  	ret = cpulist_parse(data, mask);

>  	kfree(data);

>  	return ret;

> diff --git a/lib/nlattr.c b/lib/nlattr.c

> index 447182543c03..09aa181569e0 100644

> --- a/lib/nlattr.c

> +++ b/lib/nlattr.c

> @@ -709,7 +709,7 @@ struct nlattr *nla_find(const struct nlattr *head, int len, int attrtype)

>  EXPORT_SYMBOL(nla_find);

>  

>  /**

> - * nla_strlcpy - Copy string attribute payload into a sized buffer

> + * nla_strscpy - Copy string attribute payload into a sized buffer

>   * @dst: Where to copy the string to.

>   * @nla: Attribute to copy the string from.

>   * @dstsize: Size of destination buffer.

> @@ -722,7 +722,7 @@ EXPORT_SYMBOL(nla_find);

>   * * -E2BIG - If @dstsize is 0 or greater than U16_MAX or @nla length greater

>   *            than @dstsize.

>   */

> -ssize_t nla_strlcpy(char *dst, const struct nlattr *nla, size_t dstsize)

> +ssize_t nla_strscpy(char *dst, const struct nlattr *nla, size_t dstsize)

>  {

>  	size_t srclen = nla_len(nla);

>  	char *src = nla_data(nla);

> @@ -749,7 +749,7 @@ ssize_t nla_strlcpy(char *dst, const struct nlattr *nla, size_t dstsize)

>  

>  	return ret;

>  }

> -EXPORT_SYMBOL(nla_strlcpy);

> +EXPORT_SYMBOL(nla_strscpy);

>  

>  /**

>   * nla_strdup - Copy string attribute payload into a newly allocated buffer

> diff --git a/net/core/fib_rules.c b/net/core/fib_rules.c

> index 7bcfb16854cb..cd80ffed6d26 100644

> --- a/net/core/fib_rules.c

> +++ b/net/core/fib_rules.c

> @@ -563,7 +563,7 @@ static int fib_nl2rule(struct sk_buff *skb, struct nlmsghdr *nlh,

>  		struct net_device *dev;

>  

>  		nlrule->iifindex = -1;

> -		nla_strlcpy(nlrule->iifname, tb[FRA_IIFNAME], IFNAMSIZ);

> +		nla_strscpy(nlrule->iifname, tb[FRA_IIFNAME], IFNAMSIZ);

>  		dev = __dev_get_by_name(net, nlrule->iifname);

>  		if (dev)

>  			nlrule->iifindex = dev->ifindex;

> @@ -573,7 +573,7 @@ static int fib_nl2rule(struct sk_buff *skb, struct nlmsghdr *nlh,

>  		struct net_device *dev;

>  

>  		nlrule->oifindex = -1;

> -		nla_strlcpy(nlrule->oifname, tb[FRA_OIFNAME], IFNAMSIZ);

> +		nla_strscpy(nlrule->oifname, tb[FRA_OIFNAME], IFNAMSIZ);

>  		dev = __dev_get_by_name(net, nlrule->oifname);

>  		if (dev)

>  			nlrule->oifindex = dev->ifindex;

> diff --git a/net/core/rtnetlink.c b/net/core/rtnetlink.c

> index 68e0682450c6..e0059256fe93 100644

> --- a/net/core/rtnetlink.c

> +++ b/net/core/rtnetlink.c

> @@ -1939,7 +1939,7 @@ static const struct rtnl_link_ops *linkinfo_to_kind_ops(const struct nlattr *nla

>  	if (linfo[IFLA_INFO_KIND]) {

>  		char kind[MODULE_NAME_LEN];

>  

> -		nla_strlcpy(kind, linfo[IFLA_INFO_KIND], sizeof(kind));

> +		nla_strscpy(kind, linfo[IFLA_INFO_KIND], sizeof(kind));

>  		ops = rtnl_link_ops_get(kind);

>  	}

>  

> @@ -2953,9 +2953,9 @@ static struct net_device *rtnl_dev_get(struct net *net,

>  	if (!ifname) {

>  		ifname = buffer;

>  		if (ifname_attr)

> -			nla_strlcpy(ifname, ifname_attr, IFNAMSIZ);

> +			nla_strscpy(ifname, ifname_attr, IFNAMSIZ);

>  		else if (altifname_attr)

> -			nla_strlcpy(ifname, altifname_attr, ALTIFNAMSIZ);

> +			nla_strscpy(ifname, altifname_attr, ALTIFNAMSIZ);

>  		else

>  			return NULL;

>  	}

> @@ -2983,7 +2983,7 @@ static int rtnl_setlink(struct sk_buff *skb, struct nlmsghdr *nlh,

>  		goto errout;

>  

>  	if (tb[IFLA_IFNAME])

> -		nla_strlcpy(ifname, tb[IFLA_IFNAME], IFNAMSIZ);

> +		nla_strscpy(ifname, tb[IFLA_IFNAME], IFNAMSIZ);

>  	else

>  		ifname[0] = '\0';

>  

> @@ -3264,7 +3264,7 @@ static int __rtnl_newlink(struct sk_buff *skb, struct nlmsghdr *nlh,

>  		return err;

>  

>  	if (tb[IFLA_IFNAME])

> -		nla_strlcpy(ifname, tb[IFLA_IFNAME], IFNAMSIZ);

> +		nla_strscpy(ifname, tb[IFLA_IFNAME], IFNAMSIZ);

>  	else

>  		ifname[0] = '\0';

>  

> @@ -3296,7 +3296,7 @@ static int __rtnl_newlink(struct sk_buff *skb, struct nlmsghdr *nlh,

>  		memset(linkinfo, 0, sizeof(linkinfo));

>  

>  	if (linkinfo[IFLA_INFO_KIND]) {

> -		nla_strlcpy(kind, linkinfo[IFLA_INFO_KIND], sizeof(kind));

> +		nla_strscpy(kind, linkinfo[IFLA_INFO_KIND], sizeof(kind));

>  		ops = rtnl_link_ops_get(kind);

>  	} else {

>  		kind[0] = '\0';

> diff --git a/net/decnet/dn_dev.c b/net/decnet/dn_dev.c

> index 15d42353f1a3..d1c50a48614b 100644

> --- a/net/decnet/dn_dev.c

> +++ b/net/decnet/dn_dev.c

> @@ -658,7 +658,7 @@ static int dn_nl_newaddr(struct sk_buff *skb, struct nlmsghdr *nlh,

>  	ifa->ifa_dev = dn_db;

>  

>  	if (tb[IFA_LABEL])

> -		nla_strlcpy(ifa->ifa_label, tb[IFA_LABEL], IFNAMSIZ);

> +		nla_strscpy(ifa->ifa_label, tb[IFA_LABEL], IFNAMSIZ);

>  	else

>  		memcpy(ifa->ifa_label, dev->name, IFNAMSIZ);

>  

> diff --git a/net/ieee802154/nl-mac.c b/net/ieee802154/nl-mac.c

> index 6d091e419d3e..9c640d670ffe 100644

> --- a/net/ieee802154/nl-mac.c

> +++ b/net/ieee802154/nl-mac.c

> @@ -149,7 +149,7 @@ static struct net_device *ieee802154_nl_get_dev(struct genl_info *info)

>  	if (info->attrs[IEEE802154_ATTR_DEV_NAME]) {

>  		char name[IFNAMSIZ + 1];

>  

> -		nla_strlcpy(name, info->attrs[IEEE802154_ATTR_DEV_NAME],

> +		nla_strscpy(name, info->attrs[IEEE802154_ATTR_DEV_NAME],

>  			    sizeof(name));

>  		dev = dev_get_by_name(&init_net, name);

>  	} else if (info->attrs[IEEE802154_ATTR_DEV_INDEX]) {

> diff --git a/net/ipv4/devinet.c b/net/ipv4/devinet.c

> index 123a6d39438f..a50951a90f63 100644

> --- a/net/ipv4/devinet.c

> +++ b/net/ipv4/devinet.c

> @@ -881,7 +881,7 @@ static struct in_ifaddr *rtm_to_ifaddr(struct net *net, struct nlmsghdr *nlh,

>  		ifa->ifa_broadcast = nla_get_in_addr(tb[IFA_BROADCAST]);

>  

>  	if (tb[IFA_LABEL])

> -		nla_strlcpy(ifa->ifa_label, tb[IFA_LABEL], IFNAMSIZ);

> +		nla_strscpy(ifa->ifa_label, tb[IFA_LABEL], IFNAMSIZ);

>  	else

>  		memcpy(ifa->ifa_label, dev->name, IFNAMSIZ);

>  

> diff --git a/net/ipv4/fib_semantics.c b/net/ipv4/fib_semantics.c

> index 1f75dc686b6b..4b505074b24f 100644

> --- a/net/ipv4/fib_semantics.c

> +++ b/net/ipv4/fib_semantics.c

> @@ -973,7 +973,7 @@ bool fib_metrics_match(struct fib_config *cfg, struct fib_info *fi)

>  			char tmp[TCP_CA_NAME_MAX];

>  			bool ecn_ca = false;

>  

> -			nla_strlcpy(tmp, nla, sizeof(tmp));

> +			nla_strscpy(tmp, nla, sizeof(tmp));

>  			val = tcp_ca_get_key_by_name(fi->fib_net, tmp, &ecn_ca);

>  		} else {

>  			if (nla_len(nla) != sizeof(u32))

> diff --git a/net/ipv4/metrics.c b/net/ipv4/metrics.c

> index 3205d5f7c8c9..25ea6ac44db9 100644

> --- a/net/ipv4/metrics.c

> +++ b/net/ipv4/metrics.c

> @@ -31,7 +31,7 @@ static int ip_metrics_convert(struct net *net, struct nlattr *fc_mx,

>  		if (type == RTAX_CC_ALGO) {

>  			char tmp[TCP_CA_NAME_MAX];

>  

> -			nla_strlcpy(tmp, nla, sizeof(tmp));

> +			nla_strscpy(tmp, nla, sizeof(tmp));

>  			val = tcp_ca_get_key_by_name(net, tmp, &ecn_ca);

>  			if (val == TCP_CA_UNSPEC) {

>  				NL_SET_ERR_MSG(extack, "Unknown tcp congestion algorithm");

> diff --git a/net/netfilter/ipset/ip_set_hash_netiface.c b/net/netfilter/ipset/ip_set_hash_netiface.c

> index be5e95a0d876..b96fd0c55eaa 100644

> --- a/net/netfilter/ipset/ip_set_hash_netiface.c

> +++ b/net/netfilter/ipset/ip_set_hash_netiface.c

> @@ -225,7 +225,7 @@ hash_netiface4_uadt(struct ip_set *set, struct nlattr *tb[],

>  		if (e.cidr > HOST_MASK)

>  			return -IPSET_ERR_INVALID_CIDR;

>  	}

> -	nla_strlcpy(e.iface, tb[IPSET_ATTR_IFACE], IFNAMSIZ);

> +	nla_strscpy(e.iface, tb[IPSET_ATTR_IFACE], IFNAMSIZ);

>  

>  	if (tb[IPSET_ATTR_CADT_FLAGS]) {

>  		u32 cadt_flags = ip_set_get_h32(tb[IPSET_ATTR_CADT_FLAGS]);

> @@ -442,7 +442,7 @@ hash_netiface6_uadt(struct ip_set *set, struct nlattr *tb[],

>  

>  	ip6_netmask(&e.ip, e.cidr);

>  

> -	nla_strlcpy(e.iface, tb[IPSET_ATTR_IFACE], IFNAMSIZ);

> +	nla_strscpy(e.iface, tb[IPSET_ATTR_IFACE], IFNAMSIZ);

>  

>  	if (tb[IPSET_ATTR_CADT_FLAGS]) {

>  		u32 cadt_flags = ip_set_get_h32(tb[IPSET_ATTR_CADT_FLAGS]);

> diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c

> index 9957e0ed8658..90c39e694e87 100644

> --- a/net/netfilter/nf_tables_api.c

> +++ b/net/netfilter/nf_tables_api.c

> @@ -1281,7 +1281,7 @@ static struct nft_chain *nft_chain_lookup(struct net *net,

>  	if (nla == NULL)

>  		return ERR_PTR(-EINVAL);

>  

> -	nla_strlcpy(search, nla, sizeof(search));

> +	nla_strscpy(search, nla, sizeof(search));

>  

>  	WARN_ON(!rcu_read_lock_held() &&

>  		!lockdep_commit_lock_is_held(net));

> @@ -1721,7 +1721,7 @@ static struct nft_hook *nft_netdev_hook_alloc(struct net *net,

>  		goto err_hook_alloc;

>  	}

>  

> -	nla_strlcpy(ifname, attr, IFNAMSIZ);

> +	nla_strscpy(ifname, attr, IFNAMSIZ);

>  	dev = __dev_get_by_name(net, ifname);

>  	if (!dev) {

>  		err = -ENOENT;

> @@ -5734,7 +5734,7 @@ struct nft_object *nft_obj_lookup(const struct net *net,

>  	struct rhlist_head *tmp, *list;

>  	struct nft_object *obj;

>  

> -	nla_strlcpy(search, nla, sizeof(search));

> +	nla_strscpy(search, nla, sizeof(search));

>  	k.name = search;

>  

>  	WARN_ON_ONCE(!rcu_read_lock_held() &&

> diff --git a/net/netfilter/nfnetlink_acct.c b/net/netfilter/nfnetlink_acct.c

> index 5bfec829c12f..5e511df8d709 100644

> --- a/net/netfilter/nfnetlink_acct.c

> +++ b/net/netfilter/nfnetlink_acct.c

> @@ -112,7 +112,7 @@ static int nfnl_acct_new(struct net *net, struct sock *nfnl,

>  		nfacct->flags = flags;

>  	}

>  

> -	nla_strlcpy(nfacct->name, tb[NFACCT_NAME], NFACCT_NAME_MAX);

> +	nla_strscpy(nfacct->name, tb[NFACCT_NAME], NFACCT_NAME_MAX);

>  

>  	if (tb[NFACCT_BYTES]) {

>  		atomic64_set(&nfacct->bytes,

> diff --git a/net/netfilter/nfnetlink_cthelper.c b/net/netfilter/nfnetlink_cthelper.c

> index 5b0d0a77379c..0f94fce1d3ed 100644

> --- a/net/netfilter/nfnetlink_cthelper.c

> +++ b/net/netfilter/nfnetlink_cthelper.c

> @@ -146,7 +146,7 @@ nfnl_cthelper_expect_policy(struct nf_conntrack_expect_policy *expect_policy,

>  	    !tb[NFCTH_POLICY_EXPECT_TIMEOUT])

>  		return -EINVAL;

>  

> -	nla_strlcpy(expect_policy->name,

> +	nla_strscpy(expect_policy->name,

>  		    tb[NFCTH_POLICY_NAME], NF_CT_HELPER_NAME_LEN);

>  	expect_policy->max_expected =

>  		ntohl(nla_get_be32(tb[NFCTH_POLICY_EXPECT_MAX]));

> @@ -233,7 +233,7 @@ nfnl_cthelper_create(const struct nlattr * const tb[],

>  	if (ret < 0)

>  		goto err1;

>  

> -	nla_strlcpy(helper->name,

> +	nla_strscpy(helper->name,

>  		    tb[NFCTH_NAME], NF_CT_HELPER_NAME_LEN);

>  	size = ntohl(nla_get_be32(tb[NFCTH_PRIV_DATA_LEN]));

>  	if (size > sizeof_field(struct nf_conn_help, data)) {

> diff --git a/net/netfilter/nft_ct.c b/net/netfilter/nft_ct.c

> index 322bd674963e..a8c4d442231c 100644

> --- a/net/netfilter/nft_ct.c

> +++ b/net/netfilter/nft_ct.c

> @@ -990,7 +990,7 @@ static int nft_ct_helper_obj_init(const struct nft_ctx *ctx,

>  	if (!priv->l4proto)

>  		return -ENOENT;

>  

> -	nla_strlcpy(name, tb[NFTA_CT_HELPER_NAME], sizeof(name));

> +	nla_strscpy(name, tb[NFTA_CT_HELPER_NAME], sizeof(name));

>  

>  	if (tb[NFTA_CT_HELPER_L3PROTO])

>  		family = ntohs(nla_get_be16(tb[NFTA_CT_HELPER_L3PROTO]));

> diff --git a/net/netfilter/nft_log.c b/net/netfilter/nft_log.c

> index 57899454a530..a06a46b039c5 100644

> --- a/net/netfilter/nft_log.c

> +++ b/net/netfilter/nft_log.c

> @@ -152,7 +152,7 @@ static int nft_log_init(const struct nft_ctx *ctx,

>  		priv->prefix = kmalloc(nla_len(nla) + 1, GFP_KERNEL);

>  		if (priv->prefix == NULL)

>  			return -ENOMEM;

> -		nla_strlcpy(priv->prefix, nla, nla_len(nla) + 1);

> +		nla_strscpy(priv->prefix, nla, nla_len(nla) + 1);

>  	} else {

>  		priv->prefix = (char *)nft_log_null_prefix;

>  	}

> diff --git a/net/netlabel/netlabel_mgmt.c b/net/netlabel/netlabel_mgmt.c

> index eb1d66d20afb..df1b41ed73fd 100644

> --- a/net/netlabel/netlabel_mgmt.c

> +++ b/net/netlabel/netlabel_mgmt.c

> @@ -95,7 +95,7 @@ static int netlbl_mgmt_add_common(struct genl_info *info,

>  			ret_val = -ENOMEM;

>  			goto add_free_entry;

>  		}

> -		nla_strlcpy(entry->domain,

> +		nla_strscpy(entry->domain,

>  			    info->attrs[NLBL_MGMT_A_DOMAIN], tmp_size);

>  	}

>  

> diff --git a/net/nfc/netlink.c b/net/nfc/netlink.c

> index e894254c17d4..438ff1f30a33 100644

> --- a/net/nfc/netlink.c

> +++ b/net/nfc/netlink.c

> @@ -1226,7 +1226,7 @@ static int nfc_genl_fw_download(struct sk_buff *skb, struct genl_info *info)

>  	if (!dev)

>  		return -ENODEV;

>  

> -	nla_strlcpy(firmware_name, info->attrs[NFC_ATTR_FIRMWARE_NAME],

> +	nla_strscpy(firmware_name, info->attrs[NFC_ATTR_FIRMWARE_NAME],

>  		    sizeof(firmware_name));

>  

>  	rc = nfc_fw_download(dev, firmware_name);

> diff --git a/net/sched/act_api.c b/net/sched/act_api.c

> index 541574520c52..eac24a73115f 100644

> --- a/net/sched/act_api.c

> +++ b/net/sched/act_api.c

> @@ -935,7 +935,7 @@ struct tc_action *tcf_action_init_1(struct net *net, struct tcf_proto *tp,

>  			NL_SET_ERR_MSG(extack, "TC action kind must be specified");

>  			goto err_out;

>  		}

> -		if (nla_strlcpy(act_name, kind, IFNAMSIZ) < 0) {

> +		if (nla_strscpy(act_name, kind, IFNAMSIZ) < 0) {

>  			NL_SET_ERR_MSG(extack, "TC action name too long");

>  			goto err_out;

>  		}

> diff --git a/net/sched/act_ipt.c b/net/sched/act_ipt.c

> index 8dc3bec0d325..ac7297f42355 100644

> --- a/net/sched/act_ipt.c

> +++ b/net/sched/act_ipt.c

> @@ -166,7 +166,7 @@ static int __tcf_ipt_init(struct net *net, unsigned int id, struct nlattr *nla,

>  	if (unlikely(!tname))

>  		goto err1;

>  	if (tb[TCA_IPT_TABLE] == NULL ||

> -	    nla_strlcpy(tname, tb[TCA_IPT_TABLE], IFNAMSIZ) >= IFNAMSIZ)

> +	    nla_strscpy(tname, tb[TCA_IPT_TABLE], IFNAMSIZ) >= IFNAMSIZ)

>  		strcpy(tname, "mangle");

>  

>  	t = kmemdup(td, td->u.target_size, GFP_KERNEL);

> diff --git a/net/sched/act_simple.c b/net/sched/act_simple.c

> index a4f3d0f0daa9..726cc956d06f 100644

> --- a/net/sched/act_simple.c

> +++ b/net/sched/act_simple.c

> @@ -52,7 +52,7 @@ static int alloc_defdata(struct tcf_defact *d, const struct nlattr *defdata)

>  	d->tcfd_defdata = kzalloc(SIMP_MAX_DATA, GFP_KERNEL);

>  	if (unlikely(!d->tcfd_defdata))

>  		return -ENOMEM;

> -	nla_strlcpy(d->tcfd_defdata, defdata, SIMP_MAX_DATA);

> +	nla_strscpy(d->tcfd_defdata, defdata, SIMP_MAX_DATA);

>  	return 0;

>  }

>  

> @@ -71,7 +71,7 @@ static int reset_policy(struct tc_action *a, const struct nlattr *defdata,

>  	spin_lock_bh(&d->tcf_lock);

>  	goto_ch = tcf_action_set_ctrlact(a, p->action, goto_ch);

>  	memset(d->tcfd_defdata, 0, SIMP_MAX_DATA);

> -	nla_strlcpy(d->tcfd_defdata, defdata, SIMP_MAX_DATA);

> +	nla_strscpy(d->tcfd_defdata, defdata, SIMP_MAX_DATA);

>  	spin_unlock_bh(&d->tcf_lock);

>  	if (goto_ch)

>  		tcf_chain_put_by_act(goto_ch);

> diff --git a/net/sched/cls_api.c b/net/sched/cls_api.c

> index c78241c853a5..6ff3b817083a 100644

> --- a/net/sched/cls_api.c

> +++ b/net/sched/cls_api.c

> @@ -223,7 +223,7 @@ static inline u32 tcf_auto_prio(struct tcf_proto *tp)

>  static bool tcf_proto_check_kind(struct nlattr *kind, char *name)

>  {

>  	if (kind)

> -		return nla_strlcpy(name, kind, IFNAMSIZ) < 0;

> +		return nla_strscpy(name, kind, IFNAMSIZ) < 0;

>  	memset(name, 0, IFNAMSIZ);

>  	return false;

>  }

> diff --git a/net/sched/sch_api.c b/net/sched/sch_api.c

> index f9b053b30a7b..cb4f30700c74 100644

> --- a/net/sched/sch_api.c

> +++ b/net/sched/sch_api.c

> @@ -1170,7 +1170,7 @@ static struct Qdisc *qdisc_create(struct net_device *dev,

>  #ifdef CONFIG_MODULES

>  	if (ops == NULL && kind != NULL) {

>  		char name[IFNAMSIZ];

> -		if (nla_strlcpy(name, kind, IFNAMSIZ) > 0) {

> +		if (nla_strscpy(name, kind, IFNAMSIZ) > 0) {

>  			/* We dropped the RTNL semaphore in order to

>  			 * perform the module load.  So, even if we

>  			 * succeeded in loading the module we have to

> diff --git a/net/tipc/netlink_compat.c b/net/tipc/netlink_compat.c

> index 1c7aa51cc2a3..644c7ec41ddf 100644

> --- a/net/tipc/netlink_compat.c

> +++ b/net/tipc/netlink_compat.c

> @@ -695,7 +695,7 @@ static int tipc_nl_compat_link_dump(struct tipc_nl_compat_msg *msg,

>  

>  	link_info.dest = nla_get_flag(link[TIPC_NLA_LINK_DEST]);

>  	link_info.up = htonl(nla_get_flag(link[TIPC_NLA_LINK_UP]));

> -	nla_strlcpy(link_info.str, link[TIPC_NLA_LINK_NAME],

> +	nla_strscpy(link_info.str, link[TIPC_NLA_LINK_NAME],

>  		    TIPC_MAX_LINK_NAME);

>  

>  	return tipc_add_tlv(msg->rep, TIPC_TLV_LINK_INFO,

> -- 

> 2.20.1

> 


-- 
Kees Cook
diff mbox series

Patch

diff --git a/drivers/infiniband/core/nldev.c b/drivers/infiniband/core/nldev.c
index 12d29d54a081..08366e254b1d 100644
--- a/drivers/infiniband/core/nldev.c
+++ b/drivers/infiniband/core/nldev.c
@@ -932,7 +932,7 @@  static int nldev_set_doit(struct sk_buff *skb, struct nlmsghdr *nlh,
 	if (tb[RDMA_NLDEV_ATTR_DEV_NAME]) {
 		char name[IB_DEVICE_NAME_MAX] = {};
 
-		nla_strlcpy(name, tb[RDMA_NLDEV_ATTR_DEV_NAME],
+		nla_strscpy(name, tb[RDMA_NLDEV_ATTR_DEV_NAME],
 			    IB_DEVICE_NAME_MAX);
 		if (strlen(name) == 0) {
 			err = -EINVAL;
@@ -1529,13 +1529,13 @@  static int nldev_newlink(struct sk_buff *skb, struct nlmsghdr *nlh,
 	    !tb[RDMA_NLDEV_ATTR_LINK_TYPE] || !tb[RDMA_NLDEV_ATTR_NDEV_NAME])
 		return -EINVAL;
 
-	nla_strlcpy(ibdev_name, tb[RDMA_NLDEV_ATTR_DEV_NAME],
+	nla_strscpy(ibdev_name, tb[RDMA_NLDEV_ATTR_DEV_NAME],
 		    sizeof(ibdev_name));
 	if (strchr(ibdev_name, '%') || strlen(ibdev_name) == 0)
 		return -EINVAL;
 
-	nla_strlcpy(type, tb[RDMA_NLDEV_ATTR_LINK_TYPE], sizeof(type));
-	nla_strlcpy(ndev_name, tb[RDMA_NLDEV_ATTR_NDEV_NAME],
+	nla_strscpy(type, tb[RDMA_NLDEV_ATTR_LINK_TYPE], sizeof(type));
+	nla_strscpy(ndev_name, tb[RDMA_NLDEV_ATTR_NDEV_NAME],
 		    sizeof(ndev_name));
 
 	ndev = dev_get_by_name(sock_net(skb->sk), ndev_name);
@@ -1602,7 +1602,7 @@  static int nldev_get_chardev(struct sk_buff *skb, struct nlmsghdr *nlh,
 	if (err || !tb[RDMA_NLDEV_ATTR_CHARDEV_TYPE])
 		return -EINVAL;
 
-	nla_strlcpy(client_name, tb[RDMA_NLDEV_ATTR_CHARDEV_TYPE],
+	nla_strscpy(client_name, tb[RDMA_NLDEV_ATTR_CHARDEV_TYPE],
 		    sizeof(client_name));
 
 	if (tb[RDMA_NLDEV_ATTR_DEV_INDEX]) {
diff --git a/drivers/net/can/vxcan.c b/drivers/net/can/vxcan.c
index d6ba9426be4d..fa47bab510bb 100644
--- a/drivers/net/can/vxcan.c
+++ b/drivers/net/can/vxcan.c
@@ -186,7 +186,7 @@  static int vxcan_newlink(struct net *net, struct net_device *dev,
 	}
 
 	if (ifmp && tbp[IFLA_IFNAME]) {
-		nla_strlcpy(ifname, tbp[IFLA_IFNAME], IFNAMSIZ);
+		nla_strscpy(ifname, tbp[IFLA_IFNAME], IFNAMSIZ);
 		name_assign_type = NET_NAME_USER;
 	} else {
 		snprintf(ifname, IFNAMSIZ, DRV_NAME "%%d");
@@ -223,7 +223,7 @@  static int vxcan_newlink(struct net *net, struct net_device *dev,
 
 	/* register first device */
 	if (tb[IFLA_IFNAME])
-		nla_strlcpy(dev->name, tb[IFLA_IFNAME], IFNAMSIZ);
+		nla_strscpy(dev->name, tb[IFLA_IFNAME], IFNAMSIZ);
 	else
 		snprintf(dev->name, IFNAMSIZ, DRV_NAME "%%d");
 
diff --git a/drivers/net/veth.c b/drivers/net/veth.c
index 8c737668008a..359d3ab33c4d 100644
--- a/drivers/net/veth.c
+++ b/drivers/net/veth.c
@@ -1329,7 +1329,7 @@  static int veth_newlink(struct net *src_net, struct net_device *dev,
 	}
 
 	if (ifmp && tbp[IFLA_IFNAME]) {
-		nla_strlcpy(ifname, tbp[IFLA_IFNAME], IFNAMSIZ);
+		nla_strscpy(ifname, tbp[IFLA_IFNAME], IFNAMSIZ);
 		name_assign_type = NET_NAME_USER;
 	} else {
 		snprintf(ifname, IFNAMSIZ, DRV_NAME "%%d");
@@ -1379,7 +1379,7 @@  static int veth_newlink(struct net *src_net, struct net_device *dev,
 		eth_hw_addr_random(dev);
 
 	if (tb[IFLA_IFNAME])
-		nla_strlcpy(dev->name, tb[IFLA_IFNAME], IFNAMSIZ);
+		nla_strscpy(dev->name, tb[IFLA_IFNAME], IFNAMSIZ);
 	else
 		snprintf(dev->name, IFNAMSIZ, DRV_NAME "%%d");
 
diff --git a/include/linux/genl_magic_struct.h b/include/linux/genl_magic_struct.h
index eeae59d3ceb7..35d21fddaf2d 100644
--- a/include/linux/genl_magic_struct.h
+++ b/include/linux/genl_magic_struct.h
@@ -89,7 +89,7 @@  static inline int nla_put_u64_0pad(struct sk_buff *skb, int attrtype, u64 value)
 			nla_get_u64, nla_put_u64_0pad, false)
 #define __str_field(attr_nr, attr_flag, name, maxlen) \
 	__array(attr_nr, attr_flag, name, NLA_NUL_STRING, char, maxlen, \
-			nla_strlcpy, nla_put, false)
+			nla_strscpy, nla_put, false)
 #define __bin_field(attr_nr, attr_flag, name, maxlen) \
 	__array(attr_nr, attr_flag, name, NLA_BINARY, char, maxlen, \
 			nla_memcpy, nla_put, false)
diff --git a/include/net/netlink.h b/include/net/netlink.h
index 446ca182e13d..1ceec518ab49 100644
--- a/include/net/netlink.h
+++ b/include/net/netlink.h
@@ -142,7 +142,7 @@ 
  * Attribute Misc:
  *   nla_memcpy(dest, nla, count)	copy attribute into memory
  *   nla_memcmp(nla, data, size)	compare attribute with memory area
- *   nla_strlcpy(dst, nla, size)	copy attribute to a sized string
+ *   nla_strscpy(dst, nla, size)	copy attribute to a sized string
  *   nla_strcmp(nla, str)		compare attribute with string
  *
  * Attribute Parsing:
@@ -506,7 +506,7 @@  int __nla_parse(struct nlattr **tb, int maxtype, const struct nlattr *head,
 		struct netlink_ext_ack *extack);
 int nla_policy_len(const struct nla_policy *, int);
 struct nlattr *nla_find(const struct nlattr *head, int len, int attrtype);
-ssize_t nla_strlcpy(char *dst, const struct nlattr *nla, size_t dstsize);
+ssize_t nla_strscpy(char *dst, const struct nlattr *nla, size_t dstsize);
 char *nla_strdup(const struct nlattr *nla, gfp_t flags);
 int nla_memcpy(void *dest, const struct nlattr *src, int count);
 int nla_memcmp(const struct nlattr *nla, const void *data, size_t size);
diff --git a/include/net/pkt_cls.h b/include/net/pkt_cls.h
index db9a828f4f4f..133f9ad4d4f9 100644
--- a/include/net/pkt_cls.h
+++ b/include/net/pkt_cls.h
@@ -512,7 +512,7 @@  tcf_change_indev(struct net *net, struct nlattr *indev_tlv,
 	char indev[IFNAMSIZ];
 	struct net_device *dev;
 
-	if (nla_strlcpy(indev, indev_tlv, IFNAMSIZ) < 0) {
+	if (nla_strscpy(indev, indev_tlv, IFNAMSIZ) < 0) {
 		NL_SET_ERR_MSG_ATTR(extack, indev_tlv,
 				    "Interface name too long");
 		return -EINVAL;
diff --git a/kernel/taskstats.c b/kernel/taskstats.c
index a2802b6ff4bb..2b4898b4752e 100644
--- a/kernel/taskstats.c
+++ b/kernel/taskstats.c
@@ -346,7 +346,7 @@  static int parse(struct nlattr *na, struct cpumask *mask)
 	data = kmalloc(len, GFP_KERNEL);
 	if (!data)
 		return -ENOMEM;
-	nla_strlcpy(data, na, len);
+	nla_strscpy(data, na, len);
 	ret = cpulist_parse(data, mask);
 	kfree(data);
 	return ret;
diff --git a/lib/nlattr.c b/lib/nlattr.c
index 447182543c03..09aa181569e0 100644
--- a/lib/nlattr.c
+++ b/lib/nlattr.c
@@ -709,7 +709,7 @@  struct nlattr *nla_find(const struct nlattr *head, int len, int attrtype)
 EXPORT_SYMBOL(nla_find);
 
 /**
- * nla_strlcpy - Copy string attribute payload into a sized buffer
+ * nla_strscpy - Copy string attribute payload into a sized buffer
  * @dst: Where to copy the string to.
  * @nla: Attribute to copy the string from.
  * @dstsize: Size of destination buffer.
@@ -722,7 +722,7 @@  EXPORT_SYMBOL(nla_find);
  * * -E2BIG - If @dstsize is 0 or greater than U16_MAX or @nla length greater
  *            than @dstsize.
  */
-ssize_t nla_strlcpy(char *dst, const struct nlattr *nla, size_t dstsize)
+ssize_t nla_strscpy(char *dst, const struct nlattr *nla, size_t dstsize)
 {
 	size_t srclen = nla_len(nla);
 	char *src = nla_data(nla);
@@ -749,7 +749,7 @@  ssize_t nla_strlcpy(char *dst, const struct nlattr *nla, size_t dstsize)
 
 	return ret;
 }
-EXPORT_SYMBOL(nla_strlcpy);
+EXPORT_SYMBOL(nla_strscpy);
 
 /**
  * nla_strdup - Copy string attribute payload into a newly allocated buffer
diff --git a/net/core/fib_rules.c b/net/core/fib_rules.c
index 7bcfb16854cb..cd80ffed6d26 100644
--- a/net/core/fib_rules.c
+++ b/net/core/fib_rules.c
@@ -563,7 +563,7 @@  static int fib_nl2rule(struct sk_buff *skb, struct nlmsghdr *nlh,
 		struct net_device *dev;
 
 		nlrule->iifindex = -1;
-		nla_strlcpy(nlrule->iifname, tb[FRA_IIFNAME], IFNAMSIZ);
+		nla_strscpy(nlrule->iifname, tb[FRA_IIFNAME], IFNAMSIZ);
 		dev = __dev_get_by_name(net, nlrule->iifname);
 		if (dev)
 			nlrule->iifindex = dev->ifindex;
@@ -573,7 +573,7 @@  static int fib_nl2rule(struct sk_buff *skb, struct nlmsghdr *nlh,
 		struct net_device *dev;
 
 		nlrule->oifindex = -1;
-		nla_strlcpy(nlrule->oifname, tb[FRA_OIFNAME], IFNAMSIZ);
+		nla_strscpy(nlrule->oifname, tb[FRA_OIFNAME], IFNAMSIZ);
 		dev = __dev_get_by_name(net, nlrule->oifname);
 		if (dev)
 			nlrule->oifindex = dev->ifindex;
diff --git a/net/core/rtnetlink.c b/net/core/rtnetlink.c
index 68e0682450c6..e0059256fe93 100644
--- a/net/core/rtnetlink.c
+++ b/net/core/rtnetlink.c
@@ -1939,7 +1939,7 @@  static const struct rtnl_link_ops *linkinfo_to_kind_ops(const struct nlattr *nla
 	if (linfo[IFLA_INFO_KIND]) {
 		char kind[MODULE_NAME_LEN];
 
-		nla_strlcpy(kind, linfo[IFLA_INFO_KIND], sizeof(kind));
+		nla_strscpy(kind, linfo[IFLA_INFO_KIND], sizeof(kind));
 		ops = rtnl_link_ops_get(kind);
 	}
 
@@ -2953,9 +2953,9 @@  static struct net_device *rtnl_dev_get(struct net *net,
 	if (!ifname) {
 		ifname = buffer;
 		if (ifname_attr)
-			nla_strlcpy(ifname, ifname_attr, IFNAMSIZ);
+			nla_strscpy(ifname, ifname_attr, IFNAMSIZ);
 		else if (altifname_attr)
-			nla_strlcpy(ifname, altifname_attr, ALTIFNAMSIZ);
+			nla_strscpy(ifname, altifname_attr, ALTIFNAMSIZ);
 		else
 			return NULL;
 	}
@@ -2983,7 +2983,7 @@  static int rtnl_setlink(struct sk_buff *skb, struct nlmsghdr *nlh,
 		goto errout;
 
 	if (tb[IFLA_IFNAME])
-		nla_strlcpy(ifname, tb[IFLA_IFNAME], IFNAMSIZ);
+		nla_strscpy(ifname, tb[IFLA_IFNAME], IFNAMSIZ);
 	else
 		ifname[0] = '\0';
 
@@ -3264,7 +3264,7 @@  static int __rtnl_newlink(struct sk_buff *skb, struct nlmsghdr *nlh,
 		return err;
 
 	if (tb[IFLA_IFNAME])
-		nla_strlcpy(ifname, tb[IFLA_IFNAME], IFNAMSIZ);
+		nla_strscpy(ifname, tb[IFLA_IFNAME], IFNAMSIZ);
 	else
 		ifname[0] = '\0';
 
@@ -3296,7 +3296,7 @@  static int __rtnl_newlink(struct sk_buff *skb, struct nlmsghdr *nlh,
 		memset(linkinfo, 0, sizeof(linkinfo));
 
 	if (linkinfo[IFLA_INFO_KIND]) {
-		nla_strlcpy(kind, linkinfo[IFLA_INFO_KIND], sizeof(kind));
+		nla_strscpy(kind, linkinfo[IFLA_INFO_KIND], sizeof(kind));
 		ops = rtnl_link_ops_get(kind);
 	} else {
 		kind[0] = '\0';
diff --git a/net/decnet/dn_dev.c b/net/decnet/dn_dev.c
index 15d42353f1a3..d1c50a48614b 100644
--- a/net/decnet/dn_dev.c
+++ b/net/decnet/dn_dev.c
@@ -658,7 +658,7 @@  static int dn_nl_newaddr(struct sk_buff *skb, struct nlmsghdr *nlh,
 	ifa->ifa_dev = dn_db;
 
 	if (tb[IFA_LABEL])
-		nla_strlcpy(ifa->ifa_label, tb[IFA_LABEL], IFNAMSIZ);
+		nla_strscpy(ifa->ifa_label, tb[IFA_LABEL], IFNAMSIZ);
 	else
 		memcpy(ifa->ifa_label, dev->name, IFNAMSIZ);
 
diff --git a/net/ieee802154/nl-mac.c b/net/ieee802154/nl-mac.c
index 6d091e419d3e..9c640d670ffe 100644
--- a/net/ieee802154/nl-mac.c
+++ b/net/ieee802154/nl-mac.c
@@ -149,7 +149,7 @@  static struct net_device *ieee802154_nl_get_dev(struct genl_info *info)
 	if (info->attrs[IEEE802154_ATTR_DEV_NAME]) {
 		char name[IFNAMSIZ + 1];
 
-		nla_strlcpy(name, info->attrs[IEEE802154_ATTR_DEV_NAME],
+		nla_strscpy(name, info->attrs[IEEE802154_ATTR_DEV_NAME],
 			    sizeof(name));
 		dev = dev_get_by_name(&init_net, name);
 	} else if (info->attrs[IEEE802154_ATTR_DEV_INDEX]) {
diff --git a/net/ipv4/devinet.c b/net/ipv4/devinet.c
index 123a6d39438f..a50951a90f63 100644
--- a/net/ipv4/devinet.c
+++ b/net/ipv4/devinet.c
@@ -881,7 +881,7 @@  static struct in_ifaddr *rtm_to_ifaddr(struct net *net, struct nlmsghdr *nlh,
 		ifa->ifa_broadcast = nla_get_in_addr(tb[IFA_BROADCAST]);
 
 	if (tb[IFA_LABEL])
-		nla_strlcpy(ifa->ifa_label, tb[IFA_LABEL], IFNAMSIZ);
+		nla_strscpy(ifa->ifa_label, tb[IFA_LABEL], IFNAMSIZ);
 	else
 		memcpy(ifa->ifa_label, dev->name, IFNAMSIZ);
 
diff --git a/net/ipv4/fib_semantics.c b/net/ipv4/fib_semantics.c
index 1f75dc686b6b..4b505074b24f 100644
--- a/net/ipv4/fib_semantics.c
+++ b/net/ipv4/fib_semantics.c
@@ -973,7 +973,7 @@  bool fib_metrics_match(struct fib_config *cfg, struct fib_info *fi)
 			char tmp[TCP_CA_NAME_MAX];
 			bool ecn_ca = false;
 
-			nla_strlcpy(tmp, nla, sizeof(tmp));
+			nla_strscpy(tmp, nla, sizeof(tmp));
 			val = tcp_ca_get_key_by_name(fi->fib_net, tmp, &ecn_ca);
 		} else {
 			if (nla_len(nla) != sizeof(u32))
diff --git a/net/ipv4/metrics.c b/net/ipv4/metrics.c
index 3205d5f7c8c9..25ea6ac44db9 100644
--- a/net/ipv4/metrics.c
+++ b/net/ipv4/metrics.c
@@ -31,7 +31,7 @@  static int ip_metrics_convert(struct net *net, struct nlattr *fc_mx,
 		if (type == RTAX_CC_ALGO) {
 			char tmp[TCP_CA_NAME_MAX];
 
-			nla_strlcpy(tmp, nla, sizeof(tmp));
+			nla_strscpy(tmp, nla, sizeof(tmp));
 			val = tcp_ca_get_key_by_name(net, tmp, &ecn_ca);
 			if (val == TCP_CA_UNSPEC) {
 				NL_SET_ERR_MSG(extack, "Unknown tcp congestion algorithm");
diff --git a/net/netfilter/ipset/ip_set_hash_netiface.c b/net/netfilter/ipset/ip_set_hash_netiface.c
index be5e95a0d876..b96fd0c55eaa 100644
--- a/net/netfilter/ipset/ip_set_hash_netiface.c
+++ b/net/netfilter/ipset/ip_set_hash_netiface.c
@@ -225,7 +225,7 @@  hash_netiface4_uadt(struct ip_set *set, struct nlattr *tb[],
 		if (e.cidr > HOST_MASK)
 			return -IPSET_ERR_INVALID_CIDR;
 	}
-	nla_strlcpy(e.iface, tb[IPSET_ATTR_IFACE], IFNAMSIZ);
+	nla_strscpy(e.iface, tb[IPSET_ATTR_IFACE], IFNAMSIZ);
 
 	if (tb[IPSET_ATTR_CADT_FLAGS]) {
 		u32 cadt_flags = ip_set_get_h32(tb[IPSET_ATTR_CADT_FLAGS]);
@@ -442,7 +442,7 @@  hash_netiface6_uadt(struct ip_set *set, struct nlattr *tb[],
 
 	ip6_netmask(&e.ip, e.cidr);
 
-	nla_strlcpy(e.iface, tb[IPSET_ATTR_IFACE], IFNAMSIZ);
+	nla_strscpy(e.iface, tb[IPSET_ATTR_IFACE], IFNAMSIZ);
 
 	if (tb[IPSET_ATTR_CADT_FLAGS]) {
 		u32 cadt_flags = ip_set_get_h32(tb[IPSET_ATTR_CADT_FLAGS]);
diff --git a/net/netfilter/nf_tables_api.c b/net/netfilter/nf_tables_api.c
index 9957e0ed8658..90c39e694e87 100644
--- a/net/netfilter/nf_tables_api.c
+++ b/net/netfilter/nf_tables_api.c
@@ -1281,7 +1281,7 @@  static struct nft_chain *nft_chain_lookup(struct net *net,
 	if (nla == NULL)
 		return ERR_PTR(-EINVAL);
 
-	nla_strlcpy(search, nla, sizeof(search));
+	nla_strscpy(search, nla, sizeof(search));
 
 	WARN_ON(!rcu_read_lock_held() &&
 		!lockdep_commit_lock_is_held(net));
@@ -1721,7 +1721,7 @@  static struct nft_hook *nft_netdev_hook_alloc(struct net *net,
 		goto err_hook_alloc;
 	}
 
-	nla_strlcpy(ifname, attr, IFNAMSIZ);
+	nla_strscpy(ifname, attr, IFNAMSIZ);
 	dev = __dev_get_by_name(net, ifname);
 	if (!dev) {
 		err = -ENOENT;
@@ -5734,7 +5734,7 @@  struct nft_object *nft_obj_lookup(const struct net *net,
 	struct rhlist_head *tmp, *list;
 	struct nft_object *obj;
 
-	nla_strlcpy(search, nla, sizeof(search));
+	nla_strscpy(search, nla, sizeof(search));
 	k.name = search;
 
 	WARN_ON_ONCE(!rcu_read_lock_held() &&
diff --git a/net/netfilter/nfnetlink_acct.c b/net/netfilter/nfnetlink_acct.c
index 5bfec829c12f..5e511df8d709 100644
--- a/net/netfilter/nfnetlink_acct.c
+++ b/net/netfilter/nfnetlink_acct.c
@@ -112,7 +112,7 @@  static int nfnl_acct_new(struct net *net, struct sock *nfnl,
 		nfacct->flags = flags;
 	}
 
-	nla_strlcpy(nfacct->name, tb[NFACCT_NAME], NFACCT_NAME_MAX);
+	nla_strscpy(nfacct->name, tb[NFACCT_NAME], NFACCT_NAME_MAX);
 
 	if (tb[NFACCT_BYTES]) {
 		atomic64_set(&nfacct->bytes,
diff --git a/net/netfilter/nfnetlink_cthelper.c b/net/netfilter/nfnetlink_cthelper.c
index 5b0d0a77379c..0f94fce1d3ed 100644
--- a/net/netfilter/nfnetlink_cthelper.c
+++ b/net/netfilter/nfnetlink_cthelper.c
@@ -146,7 +146,7 @@  nfnl_cthelper_expect_policy(struct nf_conntrack_expect_policy *expect_policy,
 	    !tb[NFCTH_POLICY_EXPECT_TIMEOUT])
 		return -EINVAL;
 
-	nla_strlcpy(expect_policy->name,
+	nla_strscpy(expect_policy->name,
 		    tb[NFCTH_POLICY_NAME], NF_CT_HELPER_NAME_LEN);
 	expect_policy->max_expected =
 		ntohl(nla_get_be32(tb[NFCTH_POLICY_EXPECT_MAX]));
@@ -233,7 +233,7 @@  nfnl_cthelper_create(const struct nlattr * const tb[],
 	if (ret < 0)
 		goto err1;
 
-	nla_strlcpy(helper->name,
+	nla_strscpy(helper->name,
 		    tb[NFCTH_NAME], NF_CT_HELPER_NAME_LEN);
 	size = ntohl(nla_get_be32(tb[NFCTH_PRIV_DATA_LEN]));
 	if (size > sizeof_field(struct nf_conn_help, data)) {
diff --git a/net/netfilter/nft_ct.c b/net/netfilter/nft_ct.c
index 322bd674963e..a8c4d442231c 100644
--- a/net/netfilter/nft_ct.c
+++ b/net/netfilter/nft_ct.c
@@ -990,7 +990,7 @@  static int nft_ct_helper_obj_init(const struct nft_ctx *ctx,
 	if (!priv->l4proto)
 		return -ENOENT;
 
-	nla_strlcpy(name, tb[NFTA_CT_HELPER_NAME], sizeof(name));
+	nla_strscpy(name, tb[NFTA_CT_HELPER_NAME], sizeof(name));
 
 	if (tb[NFTA_CT_HELPER_L3PROTO])
 		family = ntohs(nla_get_be16(tb[NFTA_CT_HELPER_L3PROTO]));
diff --git a/net/netfilter/nft_log.c b/net/netfilter/nft_log.c
index 57899454a530..a06a46b039c5 100644
--- a/net/netfilter/nft_log.c
+++ b/net/netfilter/nft_log.c
@@ -152,7 +152,7 @@  static int nft_log_init(const struct nft_ctx *ctx,
 		priv->prefix = kmalloc(nla_len(nla) + 1, GFP_KERNEL);
 		if (priv->prefix == NULL)
 			return -ENOMEM;
-		nla_strlcpy(priv->prefix, nla, nla_len(nla) + 1);
+		nla_strscpy(priv->prefix, nla, nla_len(nla) + 1);
 	} else {
 		priv->prefix = (char *)nft_log_null_prefix;
 	}
diff --git a/net/netlabel/netlabel_mgmt.c b/net/netlabel/netlabel_mgmt.c
index eb1d66d20afb..df1b41ed73fd 100644
--- a/net/netlabel/netlabel_mgmt.c
+++ b/net/netlabel/netlabel_mgmt.c
@@ -95,7 +95,7 @@  static int netlbl_mgmt_add_common(struct genl_info *info,
 			ret_val = -ENOMEM;
 			goto add_free_entry;
 		}
-		nla_strlcpy(entry->domain,
+		nla_strscpy(entry->domain,
 			    info->attrs[NLBL_MGMT_A_DOMAIN], tmp_size);
 	}
 
diff --git a/net/nfc/netlink.c b/net/nfc/netlink.c
index e894254c17d4..438ff1f30a33 100644
--- a/net/nfc/netlink.c
+++ b/net/nfc/netlink.c
@@ -1226,7 +1226,7 @@  static int nfc_genl_fw_download(struct sk_buff *skb, struct genl_info *info)
 	if (!dev)
 		return -ENODEV;
 
-	nla_strlcpy(firmware_name, info->attrs[NFC_ATTR_FIRMWARE_NAME],
+	nla_strscpy(firmware_name, info->attrs[NFC_ATTR_FIRMWARE_NAME],
 		    sizeof(firmware_name));
 
 	rc = nfc_fw_download(dev, firmware_name);
diff --git a/net/sched/act_api.c b/net/sched/act_api.c
index 541574520c52..eac24a73115f 100644
--- a/net/sched/act_api.c
+++ b/net/sched/act_api.c
@@ -935,7 +935,7 @@  struct tc_action *tcf_action_init_1(struct net *net, struct tcf_proto *tp,
 			NL_SET_ERR_MSG(extack, "TC action kind must be specified");
 			goto err_out;
 		}
-		if (nla_strlcpy(act_name, kind, IFNAMSIZ) < 0) {
+		if (nla_strscpy(act_name, kind, IFNAMSIZ) < 0) {
 			NL_SET_ERR_MSG(extack, "TC action name too long");
 			goto err_out;
 		}
diff --git a/net/sched/act_ipt.c b/net/sched/act_ipt.c
index 8dc3bec0d325..ac7297f42355 100644
--- a/net/sched/act_ipt.c
+++ b/net/sched/act_ipt.c
@@ -166,7 +166,7 @@  static int __tcf_ipt_init(struct net *net, unsigned int id, struct nlattr *nla,
 	if (unlikely(!tname))
 		goto err1;
 	if (tb[TCA_IPT_TABLE] == NULL ||
-	    nla_strlcpy(tname, tb[TCA_IPT_TABLE], IFNAMSIZ) >= IFNAMSIZ)
+	    nla_strscpy(tname, tb[TCA_IPT_TABLE], IFNAMSIZ) >= IFNAMSIZ)
 		strcpy(tname, "mangle");
 
 	t = kmemdup(td, td->u.target_size, GFP_KERNEL);
diff --git a/net/sched/act_simple.c b/net/sched/act_simple.c
index a4f3d0f0daa9..726cc956d06f 100644
--- a/net/sched/act_simple.c
+++ b/net/sched/act_simple.c
@@ -52,7 +52,7 @@  static int alloc_defdata(struct tcf_defact *d, const struct nlattr *defdata)
 	d->tcfd_defdata = kzalloc(SIMP_MAX_DATA, GFP_KERNEL);
 	if (unlikely(!d->tcfd_defdata))
 		return -ENOMEM;
-	nla_strlcpy(d->tcfd_defdata, defdata, SIMP_MAX_DATA);
+	nla_strscpy(d->tcfd_defdata, defdata, SIMP_MAX_DATA);
 	return 0;
 }
 
@@ -71,7 +71,7 @@  static int reset_policy(struct tc_action *a, const struct nlattr *defdata,
 	spin_lock_bh(&d->tcf_lock);
 	goto_ch = tcf_action_set_ctrlact(a, p->action, goto_ch);
 	memset(d->tcfd_defdata, 0, SIMP_MAX_DATA);
-	nla_strlcpy(d->tcfd_defdata, defdata, SIMP_MAX_DATA);
+	nla_strscpy(d->tcfd_defdata, defdata, SIMP_MAX_DATA);
 	spin_unlock_bh(&d->tcf_lock);
 	if (goto_ch)
 		tcf_chain_put_by_act(goto_ch);
diff --git a/net/sched/cls_api.c b/net/sched/cls_api.c
index c78241c853a5..6ff3b817083a 100644
--- a/net/sched/cls_api.c
+++ b/net/sched/cls_api.c
@@ -223,7 +223,7 @@  static inline u32 tcf_auto_prio(struct tcf_proto *tp)
 static bool tcf_proto_check_kind(struct nlattr *kind, char *name)
 {
 	if (kind)
-		return nla_strlcpy(name, kind, IFNAMSIZ) < 0;
+		return nla_strscpy(name, kind, IFNAMSIZ) < 0;
 	memset(name, 0, IFNAMSIZ);
 	return false;
 }
diff --git a/net/sched/sch_api.c b/net/sched/sch_api.c
index f9b053b30a7b..cb4f30700c74 100644
--- a/net/sched/sch_api.c
+++ b/net/sched/sch_api.c
@@ -1170,7 +1170,7 @@  static struct Qdisc *qdisc_create(struct net_device *dev,
 #ifdef CONFIG_MODULES
 	if (ops == NULL && kind != NULL) {
 		char name[IFNAMSIZ];
-		if (nla_strlcpy(name, kind, IFNAMSIZ) > 0) {
+		if (nla_strscpy(name, kind, IFNAMSIZ) > 0) {
 			/* We dropped the RTNL semaphore in order to
 			 * perform the module load.  So, even if we
 			 * succeeded in loading the module we have to
diff --git a/net/tipc/netlink_compat.c b/net/tipc/netlink_compat.c
index 1c7aa51cc2a3..644c7ec41ddf 100644
--- a/net/tipc/netlink_compat.c
+++ b/net/tipc/netlink_compat.c
@@ -695,7 +695,7 @@  static int tipc_nl_compat_link_dump(struct tipc_nl_compat_msg *msg,
 
 	link_info.dest = nla_get_flag(link[TIPC_NLA_LINK_DEST]);
 	link_info.up = htonl(nla_get_flag(link[TIPC_NLA_LINK_UP]));
-	nla_strlcpy(link_info.str, link[TIPC_NLA_LINK_NAME],
+	nla_strscpy(link_info.str, link[TIPC_NLA_LINK_NAME],
 		    TIPC_MAX_LINK_NAME);
 
 	return tipc_add_tlv(msg->rep, TIPC_TLV_LINK_INFO,