License cleanup: add SPDX GPL-2.0 license identifier to files with no license
Many source files in the tree are missing licensing information, which
makes it harder for compliance tools to determine the correct license.
By default all files without license information are under the default
license of the kernel, which is GPL version 2.
Update the files which contain no license information with the 'GPL-2.0'
SPDX license identifier. The SPDX identifier is a legally binding
shorthand, which can be used instead of the full boiler plate text.
This patch is based on work done by Thomas Gleixner and Kate Stewart and
Philippe Ombredanne.
How this work was done:
Patches were generated and checked against linux-4.14-rc6 for a subset of
the use cases:
- file had no licensing information it it.
- file was a */uapi/* one with no licensing information in it,
- file was a */uapi/* one with existing licensing information,
Further patches will be generated in subsequent months to fix up cases
where non-standard license headers were used, and references to license
had to be inferred by heuristics based on keywords.
The analysis to determine which SPDX License Identifier to be applied to
a file was done in a spreadsheet of side by side results from of the
output of two independent scanners (ScanCode & Windriver) producing SPDX
tag:value files created by Philippe Ombredanne. Philippe prepared the
base worksheet, and did an initial spot review of a few 1000 files.
The 4.13 kernel was the starting point of the analysis with 60,537 files
assessed. Kate Stewart did a file by file comparison of the scanner
results in the spreadsheet to determine which SPDX license identifier(s)
to be applied to the file. She confirmed any determination that was not
immediately clear with lawyers working with the Linux Foundation.
Criteria used to select files for SPDX license identifier tagging was:
- Files considered eligible had to be source code files.
- Make and config files were included as candidates if they contained >5
lines of source
- File already had some variant of a license header in it (even if <5
lines).
All documentation files were explicitly excluded.
The following heuristics were used to determine which SPDX license
identifiers to apply.
- when both scanners couldn't find any license traces, file was
considered to have no license information in it, and the top level
COPYING file license applied.
For non */uapi/* files that summary was:
SPDX license identifier # files
---------------------------------------------------|-------
GPL-2.0 11139
and resulted in the first patch in this series.
If that file was a */uapi/* path one, it was "GPL-2.0 WITH
Linux-syscall-note" otherwise it was "GPL-2.0". Results of that was:
SPDX license identifier # files
---------------------------------------------------|-------
GPL-2.0 WITH Linux-syscall-note 930
and resulted in the second patch in this series.
- if a file had some form of licensing information in it, and was one
of the */uapi/* ones, it was denoted with the Linux-syscall-note if
any GPL family license was found in the file or had no licensing in
it (per prior point). Results summary:
SPDX license identifier # files
---------------------------------------------------|------
GPL-2.0 WITH Linux-syscall-note 270
GPL-2.0+ WITH Linux-syscall-note 169
((GPL-2.0 WITH Linux-syscall-note) OR BSD-2-Clause) 21
((GPL-2.0 WITH Linux-syscall-note) OR BSD-3-Clause) 17
LGPL-2.1+ WITH Linux-syscall-note 15
GPL-1.0+ WITH Linux-syscall-note 14
((GPL-2.0+ WITH Linux-syscall-note) OR BSD-3-Clause) 5
LGPL-2.0+ WITH Linux-syscall-note 4
LGPL-2.1 WITH Linux-syscall-note 3
((GPL-2.0 WITH Linux-syscall-note) OR MIT) 3
((GPL-2.0 WITH Linux-syscall-note) AND MIT) 1
and that resulted in the third patch in this series.
- when the two scanners agreed on the detected license(s), that became
the concluded license(s).
- when there was disagreement between the two scanners (one detected a
license but the other didn't, or they both detected different
licenses) a manual inspection of the file occurred.
- In most cases a manual inspection of the information in the file
resulted in a clear resolution of the license that should apply (and
which scanner probably needed to revisit its heuristics).
- When it was not immediately clear, the license identifier was
confirmed with lawyers working with the Linux Foundation.
- If there was any question as to the appropriate license identifier,
the file was flagged for further research and to be revisited later
in time.
In total, over 70 hours of logged manual review was done on the
spreadsheet to determine the SPDX license identifiers to apply to the
source files by Kate, Philippe, Thomas and, in some cases, confirmation
by lawyers working with the Linux Foundation.
Kate also obtained a third independent scan of the 4.13 code base from
FOSSology, and compared selected files where the other two scanners
disagreed against that SPDX file, to see if there was new insights. The
Windriver scanner is based on an older version of FOSSology in part, so
they are related.
Thomas did random spot checks in about 500 files from the spreadsheets
for the uapi headers and agreed with SPDX license identifier in the
files he inspected. For the non-uapi files Thomas did random spot checks
in about 15000 files.
In initial set of patches against 4.14-rc6, 3 files were found to have
copy/paste license identifier errors, and have been fixed to reflect the
correct identifier.
Additionally Philippe spent 10 hours this week doing a detailed manual
inspection and review of the 12,461 patched files from the initial patch
version early this week with:
- a full scancode scan run, collecting the matched texts, detected
license ids and scores
- reviewing anything where there was a license detected (about 500+
files) to ensure that the applied SPDX license was correct
- reviewing anything where there was no detection but the patch license
was not GPL-2.0 WITH Linux-syscall-note to ensure that the applied
SPDX license was correct
This produced a worksheet with 20 files needing minor correction. This
worksheet was then exported into 3 different .csv files for the
different types of files to be modified.
These .csv files were then reviewed by Greg. Thomas wrote a script to
parse the csv files and add the proper SPDX tag to the file, in the
format that the file expected. This script was further refined by Greg
based on the output to detect more types of files automatically and to
distinguish between header and source .c files (which need different
comment types.) Finally Greg ran the script using the .csv files to
generate the patches.
Reviewed-by: Kate Stewart <kstewart@linuxfoundation.org>
Reviewed-by: Philippe Ombredanne <pombredanne@nexb.com>
Reviewed-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2017-11-01 15:07:57 +01:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
2007-03-22 11:48:11 -07:00
|
|
|
#ifndef __NET_RTNETLINK_H
|
|
|
|
#define __NET_RTNETLINK_H
|
|
|
|
|
|
|
|
#include <linux/rtnetlink.h>
|
2024-10-16 11:53:50 -07:00
|
|
|
#include <linux/srcu.h>
|
2007-03-22 11:48:11 -07:00
|
|
|
#include <net/netlink.h>
|
|
|
|
|
2017-04-16 09:48:24 -07:00
|
|
|
typedef int (*rtnl_doit_func)(struct sk_buff *, struct nlmsghdr *,
|
|
|
|
struct netlink_ext_ack *);
|
2007-03-22 11:48:11 -07:00
|
|
|
typedef int (*rtnl_dumpit_func)(struct sk_buff *, struct netlink_callback *);
|
|
|
|
|
2017-08-09 20:41:52 +02:00
|
|
|
enum rtnl_link_flags {
|
2022-04-13 13:51:55 +03:00
|
|
|
RTNL_FLAG_DOIT_UNLOCKED = BIT(0),
|
2024-10-21 11:32:29 -07:00
|
|
|
#define RTNL_FLAG_DOIT_PERNET RTNL_FLAG_DOIT_UNLOCKED
|
2024-11-07 16:48:23 -08:00
|
|
|
#define RTNL_FLAG_DOIT_PERNET_WIP RTNL_FLAG_DOIT_UNLOCKED
|
2022-04-13 13:51:55 +03:00
|
|
|
RTNL_FLAG_BULK_DEL_SUPPORTED = BIT(1),
|
2024-02-22 10:50:15 +00:00
|
|
|
RTNL_FLAG_DUMP_UNLOCKED = BIT(2),
|
2024-06-03 11:48:26 -07:00
|
|
|
RTNL_FLAG_DUMP_SPLIT_NLM_DONE = BIT(3), /* legacy behavior */
|
2017-08-09 20:41:52 +02:00
|
|
|
};
|
|
|
|
|
2022-04-13 13:51:51 +03:00
|
|
|
enum rtnl_kinds {
|
|
|
|
RTNL_KIND_NEW,
|
|
|
|
RTNL_KIND_DEL,
|
|
|
|
RTNL_KIND_GET,
|
|
|
|
RTNL_KIND_SET
|
|
|
|
};
|
2022-04-13 13:51:52 +03:00
|
|
|
#define RTNL_KIND_MASK 0x3
|
|
|
|
|
|
|
|
static inline enum rtnl_kinds rtnl_msgtype_kind(int msgtype)
|
|
|
|
{
|
|
|
|
return msgtype & RTNL_KIND_MASK;
|
|
|
|
}
|
2022-04-13 13:51:51 +03:00
|
|
|
|
2024-10-14 13:18:28 -07:00
|
|
|
/**
|
|
|
|
* struct rtnl_msg_handler - rtnetlink message type and handlers
|
|
|
|
*
|
|
|
|
* @owner: NULL for built-in, THIS_MODULE for module
|
|
|
|
* @protocol: Protocol family or PF_UNSPEC
|
|
|
|
* @msgtype: rtnetlink message type
|
|
|
|
* @doit: Function pointer called for each request message
|
|
|
|
* @dumpit: Function pointer called for each dump request (NLM_F_DUMP) message
|
|
|
|
* @flags: rtnl_link_flags to modify behaviour of doit/dumpit functions
|
|
|
|
*/
|
2024-10-08 11:47:32 -07:00
|
|
|
struct rtnl_msg_handler {
|
|
|
|
struct module *owner;
|
|
|
|
int protocol;
|
|
|
|
int msgtype;
|
|
|
|
rtnl_doit_func doit;
|
|
|
|
rtnl_dumpit_func dumpit;
|
|
|
|
int flags;
|
|
|
|
};
|
|
|
|
|
2013-09-22 10:32:23 -07:00
|
|
|
void rtnl_unregister_all(int protocol);
|
2007-03-22 11:48:11 -07:00
|
|
|
|
2024-10-08 11:47:32 -07:00
|
|
|
int __rtnl_register_many(const struct rtnl_msg_handler *handlers, int n);
|
|
|
|
void __rtnl_unregister_many(const struct rtnl_msg_handler *handlers, int n);
|
|
|
|
|
|
|
|
#define rtnl_register_many(handlers) \
|
|
|
|
__rtnl_register_many(handlers, ARRAY_SIZE(handlers))
|
|
|
|
#define rtnl_unregister_many(handlers) \
|
|
|
|
__rtnl_unregister_many(handlers, ARRAY_SIZE(handlers))
|
|
|
|
|
2009-08-25 16:07:40 +02:00
|
|
|
static inline int rtnl_msg_family(const struct nlmsghdr *nlh)
|
2007-03-25 23:24:24 -07:00
|
|
|
{
|
|
|
|
if (nlmsg_len(nlh) >= sizeof(struct rtgenmsg))
|
|
|
|
return ((struct rtgenmsg *) nlmsg_data(nlh))->rtgen_family;
|
|
|
|
else
|
|
|
|
return AF_UNSPEC;
|
|
|
|
}
|
|
|
|
|
2007-06-13 12:03:51 -07:00
|
|
|
/**
|
|
|
|
* struct rtnl_link_ops - rtnetlink link operations
|
|
|
|
*
|
2024-11-07 16:48:15 -08:00
|
|
|
* @list: Used internally, protected by link_ops_mutex and SRCU
|
2024-10-16 11:53:50 -07:00
|
|
|
* @srcu: Used internally
|
2007-06-13 12:03:51 -07:00
|
|
|
* @kind: Identifier
|
2021-03-02 13:24:23 +01:00
|
|
|
* @netns_refund: Physical device, move to init_net on netns exit
|
2024-11-07 16:48:18 -08:00
|
|
|
* @peer_type: Peer device specific netlink attribute number (e.g. VETH_INFO_PEER)
|
2007-06-13 12:03:51 -07:00
|
|
|
* @maxtype: Highest device specific netlink attribute number
|
|
|
|
* @policy: Netlink policy for device specific attribute validation
|
|
|
|
* @validate: Optional validation function for netlink/changelink parameters
|
2021-06-12 10:20:54 +02:00
|
|
|
* @alloc: netdev allocation function, can be %NULL and is then used
|
|
|
|
* in place of alloc_netdev_mqs(), in this case @priv_size
|
|
|
|
* and @setup are unused. Returns a netdev or ERR_PTR().
|
2007-06-13 12:03:51 -07:00
|
|
|
* @priv_size: sizeof net_device private space
|
|
|
|
* @setup: net_device setup function
|
|
|
|
* @newlink: Function for configuring and registering a new device
|
|
|
|
* @changelink: Function for changing parameters of an existing device
|
|
|
|
* @dellink: Function to remove a device
|
|
|
|
* @get_size: Function to calculate required room for dumping device
|
|
|
|
* specific netlink attributes
|
|
|
|
* @fill_info: Function to dump device specific netlink attributes
|
2012-04-10 18:32:59 +00:00
|
|
|
* @get_xstats_size: Function to calculate required room for dumping device
|
2007-06-13 12:03:51 -07:00
|
|
|
* specific statistics
|
|
|
|
* @fill_xstats: Function to dump device specific statistics
|
2012-07-20 02:28:47 +00:00
|
|
|
* @get_num_tx_queues: Function to determine number of transmit queues
|
|
|
|
* to create when creating a new device.
|
|
|
|
* @get_num_rx_queues: Function to determine number of receive queues
|
|
|
|
* to create when creating a new device.
|
2015-01-15 15:11:16 +01:00
|
|
|
* @get_link_net: Function to get the i/o netns of the device
|
2016-04-30 10:25:27 +02:00
|
|
|
* @get_linkxstats_size: Function to calculate the required room for
|
|
|
|
* dumping device-specific extended link stats
|
|
|
|
* @fill_linkxstats: Function to dump device-specific extended link stats
|
2007-06-13 12:03:51 -07:00
|
|
|
*/
|
|
|
|
struct rtnl_link_ops {
|
|
|
|
struct list_head list;
|
2024-10-16 11:53:50 -07:00
|
|
|
struct srcu_struct srcu;
|
2007-06-13 12:03:51 -07:00
|
|
|
|
|
|
|
const char *kind;
|
|
|
|
|
|
|
|
size_t priv_size;
|
2021-06-12 10:20:54 +02:00
|
|
|
struct net_device *(*alloc)(struct nlattr *tb[],
|
|
|
|
const char *ifname,
|
|
|
|
unsigned char name_assign_type,
|
|
|
|
unsigned int num_tx_queues,
|
|
|
|
unsigned int num_rx_queues);
|
2007-06-13 12:03:51 -07:00
|
|
|
void (*setup)(struct net_device *dev);
|
|
|
|
|
2021-03-02 13:24:23 +01:00
|
|
|
bool netns_refund;
|
2024-11-07 16:48:18 -08:00
|
|
|
const u16 peer_type;
|
2018-05-30 15:20:52 -07:00
|
|
|
unsigned int maxtype;
|
2007-06-13 12:03:51 -07:00
|
|
|
const struct nla_policy *policy;
|
|
|
|
int (*validate)(struct nlattr *tb[],
|
2017-06-25 23:56:01 +02:00
|
|
|
struct nlattr *data[],
|
|
|
|
struct netlink_ext_ack *extack);
|
2007-06-13 12:03:51 -07:00
|
|
|
|
2009-11-08 00:53:51 -08:00
|
|
|
int (*newlink)(struct net *src_net,
|
|
|
|
struct net_device *dev,
|
2007-06-13 12:03:51 -07:00
|
|
|
struct nlattr *tb[],
|
2017-06-25 23:55:59 +02:00
|
|
|
struct nlattr *data[],
|
|
|
|
struct netlink_ext_ack *extack);
|
2007-06-13 12:03:51 -07:00
|
|
|
int (*changelink)(struct net_device *dev,
|
|
|
|
struct nlattr *tb[],
|
2017-06-25 23:56:00 +02:00
|
|
|
struct nlattr *data[],
|
|
|
|
struct netlink_ext_ack *extack);
|
2009-10-27 07:06:36 +00:00
|
|
|
void (*dellink)(struct net_device *dev,
|
|
|
|
struct list_head *head);
|
2007-06-13 12:03:51 -07:00
|
|
|
|
|
|
|
size_t (*get_size)(const struct net_device *dev);
|
|
|
|
int (*fill_info)(struct sk_buff *skb,
|
|
|
|
const struct net_device *dev);
|
|
|
|
|
|
|
|
size_t (*get_xstats_size)(const struct net_device *dev);
|
|
|
|
int (*fill_xstats)(struct sk_buff *skb,
|
|
|
|
const struct net_device *dev);
|
2012-07-20 02:28:47 +00:00
|
|
|
unsigned int (*get_num_tx_queues)(void);
|
|
|
|
unsigned int (*get_num_rx_queues)(void);
|
2014-01-22 09:05:55 +01:00
|
|
|
|
2018-05-30 15:20:52 -07:00
|
|
|
unsigned int slave_maxtype;
|
2014-01-22 09:05:55 +01:00
|
|
|
const struct nla_policy *slave_policy;
|
|
|
|
int (*slave_changelink)(struct net_device *dev,
|
|
|
|
struct net_device *slave_dev,
|
|
|
|
struct nlattr *tb[],
|
2017-06-25 23:56:02 +02:00
|
|
|
struct nlattr *data[],
|
|
|
|
struct netlink_ext_ack *extack);
|
2014-01-22 09:05:55 +01:00
|
|
|
size_t (*get_slave_size)(const struct net_device *dev,
|
|
|
|
const struct net_device *slave_dev);
|
|
|
|
int (*fill_slave_info)(struct sk_buff *skb,
|
|
|
|
const struct net_device *dev,
|
|
|
|
const struct net_device *slave_dev);
|
2015-01-15 15:11:16 +01:00
|
|
|
struct net *(*get_link_net)(const struct net_device *dev);
|
2016-06-28 16:57:05 +02:00
|
|
|
size_t (*get_linkxstats_size)(const struct net_device *dev,
|
|
|
|
int attr);
|
2016-04-30 10:25:27 +02:00
|
|
|
int (*fill_linkxstats)(struct sk_buff *skb,
|
|
|
|
const struct net_device *dev,
|
2016-06-28 16:57:05 +02:00
|
|
|
int *prividx, int attr);
|
2007-06-13 12:03:51 -07:00
|
|
|
};
|
|
|
|
|
2013-09-22 10:32:23 -07:00
|
|
|
int rtnl_link_register(struct rtnl_link_ops *ops);
|
|
|
|
void rtnl_link_unregister(struct rtnl_link_ops *ops);
|
2007-06-13 12:03:51 -07:00
|
|
|
|
2010-11-16 04:30:14 +00:00
|
|
|
/**
|
|
|
|
* struct rtnl_af_ops - rtnetlink address family operations
|
|
|
|
*
|
2024-10-16 11:53:57 -07:00
|
|
|
* @list: Used internally, protected by RTNL and SRCU
|
|
|
|
* @srcu: Used internally
|
2010-11-16 04:30:14 +00:00
|
|
|
* @family: Address family
|
|
|
|
* @fill_link_af: Function to fill IFLA_AF_SPEC with address family
|
|
|
|
* specific netlink attributes.
|
|
|
|
* @get_link_af_size: Function to calculate size of address family specific
|
2012-04-10 18:32:59 +00:00
|
|
|
* netlink attributes.
|
2010-11-22 01:31:54 +00:00
|
|
|
* @validate_link_af: Validate a IFLA_AF_SPEC attribute, must check attr
|
|
|
|
* for invalid configuration settings.
|
|
|
|
* @set_link_af: Function to parse a IFLA_AF_SPEC attribute and modify
|
|
|
|
* net_device accordingly.
|
2010-11-16 04:30:14 +00:00
|
|
|
*/
|
|
|
|
struct rtnl_af_ops {
|
|
|
|
struct list_head list;
|
2024-10-16 11:53:57 -07:00
|
|
|
struct srcu_struct srcu;
|
|
|
|
|
2010-11-16 04:30:14 +00:00
|
|
|
int family;
|
|
|
|
|
|
|
|
int (*fill_link_af)(struct sk_buff *skb,
|
2015-09-11 16:48:48 -04:00
|
|
|
const struct net_device *dev,
|
|
|
|
u32 ext_filter_mask);
|
2015-10-19 09:23:28 -07:00
|
|
|
size_t (*get_link_af_size)(const struct net_device *dev,
|
|
|
|
u32 ext_filter_mask);
|
2010-11-16 04:30:14 +00:00
|
|
|
|
2010-11-22 01:31:54 +00:00
|
|
|
int (*validate_link_af)(const struct net_device *dev,
|
2021-08-03 20:02:50 +08:00
|
|
|
const struct nlattr *attr,
|
|
|
|
struct netlink_ext_ack *extack);
|
2010-11-22 01:31:54 +00:00
|
|
|
int (*set_link_af)(struct net_device *dev,
|
2021-04-07 08:59:12 -07:00
|
|
|
const struct nlattr *attr,
|
|
|
|
struct netlink_ext_ack *extack);
|
2017-01-16 14:16:36 +00:00
|
|
|
int (*fill_stats_af)(struct sk_buff *skb,
|
|
|
|
const struct net_device *dev);
|
|
|
|
size_t (*get_stats_af_size)(const struct net_device *dev);
|
2010-11-16 04:30:14 +00:00
|
|
|
};
|
|
|
|
|
2024-10-16 11:53:56 -07:00
|
|
|
int rtnl_af_register(struct rtnl_af_ops *ops);
|
2013-09-22 10:32:23 -07:00
|
|
|
void rtnl_af_unregister(struct rtnl_af_ops *ops);
|
2010-11-16 04:30:14 +00:00
|
|
|
|
2013-09-22 10:32:23 -07:00
|
|
|
struct net *rtnl_link_get_net(struct net *src_net, struct nlattr *tb[]);
|
2015-04-10 01:45:53 +02:00
|
|
|
struct net_device *rtnl_create_link(struct net *net, const char *ifname,
|
2014-07-14 16:37:25 +02:00
|
|
|
unsigned char name_assign_type,
|
2013-09-22 10:32:23 -07:00
|
|
|
const struct rtnl_link_ops *ops,
|
2018-11-06 12:51:14 -08:00
|
|
|
struct nlattr *tb[],
|
|
|
|
struct netlink_ext_ack *extack);
|
2022-10-28 04:42:24 -04:00
|
|
|
int rtnl_delete_link(struct net_device *dev, u32 portid, const struct nlmsghdr *nlh);
|
2022-10-28 04:42:21 -04:00
|
|
|
int rtnl_configure_link(struct net_device *dev, const struct ifinfomsg *ifm,
|
|
|
|
u32 portid, const struct nlmsghdr *nlh);
|
2010-11-16 04:30:14 +00:00
|
|
|
|
net: validate veth and vxcan peer ifindexes
veth and vxcan need to make sure the ifindexes of the peer
are not negative, core does not validate this.
Using iproute2 with user-space-level checking removed:
Before:
# ./ip link add index 10 type veth peer index -1
# ip link show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN mode DEFAULT group default qlen 1000
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
2: enp1s0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP mode DEFAULT group default qlen 1000
link/ether 52:54:00:74:b2:03 brd ff:ff:ff:ff:ff:ff
10: veth1@veth0: <BROADCAST,MULTICAST,M-DOWN> mtu 1500 qdisc noop state DOWN mode DEFAULT group default qlen 1000
link/ether 8a:90:ff:57:6d:5d brd ff:ff:ff:ff:ff:ff
-1: veth0@veth1: <BROADCAST,MULTICAST,M-DOWN> mtu 1500 qdisc noop state DOWN mode DEFAULT group default qlen 1000
link/ether ae:ed:18:e6:fa:7f brd ff:ff:ff:ff:ff:ff
Now:
$ ./ip link add index 10 type veth peer index -1
Error: ifindex can't be negative.
This problem surfaced in net-next because an explicit WARN()
was added, the root cause is older.
Fixes: e6f8f1a739b6 ("veth: Allow to create peer link with given ifindex")
Fixes: a8f820a380a2 ("can: add Virtual CAN Tunnel driver (vxcan)")
Reported-by: syzbot+5ba06978f34abb058571@syzkaller.appspotmail.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Reviewed-by: Eric Dumazet <edumazet@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2023-08-18 18:26:02 -07:00
|
|
|
int rtnl_nla_parse_ifinfomsg(struct nlattr **tb, const struct nlattr *nla_peer,
|
|
|
|
struct netlink_ext_ack *exterr);
|
2018-09-04 21:53:47 +02:00
|
|
|
struct net *rtnl_get_net_ns_capable(struct sock *sk, int netnsid);
|
2007-08-08 22:16:38 -07:00
|
|
|
|
2007-06-13 12:03:51 -07:00
|
|
|
#define MODULE_ALIAS_RTNL_LINK(kind) MODULE_ALIAS("rtnl-link-" kind)
|
|
|
|
|
2007-03-22 11:48:11 -07:00
|
|
|
#endif
|