diff options
Diffstat (limited to 'net/core')
| -rw-r--r-- | net/core/dev.c | 12 | ||||
| -rw-r--r-- | net/core/dev_addr_lists.c | 2 | ||||
| -rw-r--r-- | net/core/pktgen.c | 2 | ||||
| -rw-r--r-- | net/core/scm.c | 2 |
4 files changed, 13 insertions, 5 deletions
diff --git a/net/core/dev.c b/net/core/dev.c index 8ae6631abcc..6561021d22d 100644 --- a/net/core/dev.c +++ b/net/core/dev.c | |||
| @@ -1114,13 +1114,21 @@ EXPORT_SYMBOL(netdev_bonding_change); | |||
| 1114 | void dev_load(struct net *net, const char *name) | 1114 | void dev_load(struct net *net, const char *name) |
| 1115 | { | 1115 | { |
| 1116 | struct net_device *dev; | 1116 | struct net_device *dev; |
| 1117 | int no_module; | ||
| 1117 | 1118 | ||
| 1118 | rcu_read_lock(); | 1119 | rcu_read_lock(); |
| 1119 | dev = dev_get_by_name_rcu(net, name); | 1120 | dev = dev_get_by_name_rcu(net, name); |
| 1120 | rcu_read_unlock(); | 1121 | rcu_read_unlock(); |
| 1121 | 1122 | ||
| 1122 | if (!dev && capable(CAP_NET_ADMIN)) | 1123 | no_module = !dev; |
| 1123 | request_module("%s", name); | 1124 | if (no_module && capable(CAP_NET_ADMIN)) |
| 1125 | no_module = request_module("netdev-%s", name); | ||
| 1126 | if (no_module && capable(CAP_SYS_MODULE)) { | ||
| 1127 | if (!request_module("%s", name)) | ||
| 1128 | pr_err("Loading kernel module for a network device " | ||
| 1129 | "with CAP_SYS_MODULE (deprecated). Use CAP_NET_ADMIN and alias netdev-%s " | ||
| 1130 | "instead\n", name); | ||
| 1131 | } | ||
| 1124 | } | 1132 | } |
| 1125 | EXPORT_SYMBOL(dev_load); | 1133 | EXPORT_SYMBOL(dev_load); |
| 1126 | 1134 | ||
diff --git a/net/core/dev_addr_lists.c b/net/core/dev_addr_lists.c index 508f9c18992..133fd22ea28 100644 --- a/net/core/dev_addr_lists.c +++ b/net/core/dev_addr_lists.c | |||
| @@ -144,7 +144,7 @@ void __hw_addr_del_multiple(struct netdev_hw_addr_list *to_list, | |||
| 144 | 144 | ||
| 145 | list_for_each_entry(ha, &from_list->list, list) { | 145 | list_for_each_entry(ha, &from_list->list, list) { |
| 146 | type = addr_type ? addr_type : ha->type; | 146 | type = addr_type ? addr_type : ha->type; |
| 147 | __hw_addr_del(to_list, ha->addr, addr_len, addr_type); | 147 | __hw_addr_del(to_list, ha->addr, addr_len, type); |
| 148 | } | 148 | } |
| 149 | } | 149 | } |
| 150 | EXPORT_SYMBOL(__hw_addr_del_multiple); | 150 | EXPORT_SYMBOL(__hw_addr_del_multiple); |
diff --git a/net/core/pktgen.c b/net/core/pktgen.c index a9e7fc4c461..b5bada92f63 100644 --- a/net/core/pktgen.c +++ b/net/core/pktgen.c | |||
| @@ -3321,7 +3321,7 @@ static void show_results(struct pktgen_dev *pkt_dev, int nr_frags) | |||
| 3321 | pkt_dev->started_at); | 3321 | pkt_dev->started_at); |
| 3322 | ktime_t idle = ns_to_ktime(pkt_dev->idle_acc); | 3322 | ktime_t idle = ns_to_ktime(pkt_dev->idle_acc); |
| 3323 | 3323 | ||
| 3324 | p += sprintf(p, "OK: %llu(c%llu+d%llu) nsec, %llu (%dbyte,%dfrags)\n", | 3324 | p += sprintf(p, "OK: %llu(c%llu+d%llu) usec, %llu (%dbyte,%dfrags)\n", |
| 3325 | (unsigned long long)ktime_to_us(elapsed), | 3325 | (unsigned long long)ktime_to_us(elapsed), |
| 3326 | (unsigned long long)ktime_to_us(ktime_sub(elapsed, idle)), | 3326 | (unsigned long long)ktime_to_us(ktime_sub(elapsed, idle)), |
| 3327 | (unsigned long long)ktime_to_us(idle), | 3327 | (unsigned long long)ktime_to_us(idle), |
diff --git a/net/core/scm.c b/net/core/scm.c index bbe45445080..4c1ef026d69 100644 --- a/net/core/scm.c +++ b/net/core/scm.c | |||
| @@ -95,7 +95,7 @@ static int scm_fp_copy(struct cmsghdr *cmsg, struct scm_fp_list **fplp) | |||
| 95 | int fd = fdp[i]; | 95 | int fd = fdp[i]; |
| 96 | struct file *file; | 96 | struct file *file; |
| 97 | 97 | ||
| 98 | if (fd < 0 || !(file = fget(fd))) | 98 | if (fd < 0 || !(file = fget_raw(fd))) |
| 99 | return -EBADF; | 99 | return -EBADF; |
| 100 | *fpp++ = file; | 100 | *fpp++ = file; |
| 101 | fpl->count++; | 101 | fpl->count++; |
