mirror of
https://github.com/torvalds/linux.git
synced 2025-01-01 15:51:46 +00:00
kobject: add kobject_uevent_net_broadcast()
This removes some #ifdef pollution and will ease follow up patches. Signed-off-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
752fbcc334
commit
16dff336b3
@ -294,6 +294,57 @@ static void cleanup_uevent_env(struct subprocess_info *info)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
static int kobject_uevent_net_broadcast(struct kobject *kobj,
|
||||||
|
struct kobj_uevent_env *env,
|
||||||
|
const char *action_string,
|
||||||
|
const char *devpath)
|
||||||
|
{
|
||||||
|
int retval = 0;
|
||||||
|
#if defined(CONFIG_NET)
|
||||||
|
struct uevent_sock *ue_sk;
|
||||||
|
|
||||||
|
/* send netlink message */
|
||||||
|
list_for_each_entry(ue_sk, &uevent_sock_list, list) {
|
||||||
|
struct sock *uevent_sock = ue_sk->sk;
|
||||||
|
struct sk_buff *skb;
|
||||||
|
size_t len;
|
||||||
|
|
||||||
|
if (!netlink_has_listeners(uevent_sock, 1))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
/* allocate message with the maximum possible size */
|
||||||
|
len = strlen(action_string) + strlen(devpath) + 2;
|
||||||
|
skb = alloc_skb(len + env->buflen, GFP_KERNEL);
|
||||||
|
if (skb) {
|
||||||
|
char *scratch;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
/* add header */
|
||||||
|
scratch = skb_put(skb, len);
|
||||||
|
sprintf(scratch, "%s@%s", action_string, devpath);
|
||||||
|
|
||||||
|
/* copy keys to our continuous event payload buffer */
|
||||||
|
for (i = 0; i < env->envp_idx; i++) {
|
||||||
|
len = strlen(env->envp[i]) + 1;
|
||||||
|
scratch = skb_put(skb, len);
|
||||||
|
strcpy(scratch, env->envp[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
NETLINK_CB(skb).dst_group = 1;
|
||||||
|
retval = netlink_broadcast_filtered(uevent_sock, skb,
|
||||||
|
0, 1, GFP_KERNEL,
|
||||||
|
kobj_bcast_filter,
|
||||||
|
kobj);
|
||||||
|
/* ENOBUFS should be handled in userspace */
|
||||||
|
if (retval == -ENOBUFS || retval == -ESRCH)
|
||||||
|
retval = 0;
|
||||||
|
} else
|
||||||
|
retval = -ENOMEM;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return retval;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* kobject_uevent_env - send an uevent with environmental data
|
* kobject_uevent_env - send an uevent with environmental data
|
||||||
*
|
*
|
||||||
@ -316,9 +367,6 @@ int kobject_uevent_env(struct kobject *kobj, enum kobject_action action,
|
|||||||
const struct kset_uevent_ops *uevent_ops;
|
const struct kset_uevent_ops *uevent_ops;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
int retval = 0;
|
int retval = 0;
|
||||||
#ifdef CONFIG_NET
|
|
||||||
struct uevent_sock *ue_sk;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
pr_debug("kobject: '%s' (%p): %s\n",
|
pr_debug("kobject: '%s' (%p): %s\n",
|
||||||
kobject_name(kobj), kobj, __func__);
|
kobject_name(kobj), kobj, __func__);
|
||||||
@ -427,46 +475,8 @@ int kobject_uevent_env(struct kobject *kobj, enum kobject_action action,
|
|||||||
mutex_unlock(&uevent_sock_mutex);
|
mutex_unlock(&uevent_sock_mutex);
|
||||||
goto exit;
|
goto exit;
|
||||||
}
|
}
|
||||||
|
retval = kobject_uevent_net_broadcast(kobj, env, action_string,
|
||||||
#if defined(CONFIG_NET)
|
devpath);
|
||||||
/* send netlink message */
|
|
||||||
list_for_each_entry(ue_sk, &uevent_sock_list, list) {
|
|
||||||
struct sock *uevent_sock = ue_sk->sk;
|
|
||||||
struct sk_buff *skb;
|
|
||||||
size_t len;
|
|
||||||
|
|
||||||
if (!netlink_has_listeners(uevent_sock, 1))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
/* allocate message with the maximum possible size */
|
|
||||||
len = strlen(action_string) + strlen(devpath) + 2;
|
|
||||||
skb = alloc_skb(len + env->buflen, GFP_KERNEL);
|
|
||||||
if (skb) {
|
|
||||||
char *scratch;
|
|
||||||
|
|
||||||
/* add header */
|
|
||||||
scratch = skb_put(skb, len);
|
|
||||||
sprintf(scratch, "%s@%s", action_string, devpath);
|
|
||||||
|
|
||||||
/* copy keys to our continuous event payload buffer */
|
|
||||||
for (i = 0; i < env->envp_idx; i++) {
|
|
||||||
len = strlen(env->envp[i]) + 1;
|
|
||||||
scratch = skb_put(skb, len);
|
|
||||||
strcpy(scratch, env->envp[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
NETLINK_CB(skb).dst_group = 1;
|
|
||||||
retval = netlink_broadcast_filtered(uevent_sock, skb,
|
|
||||||
0, 1, GFP_KERNEL,
|
|
||||||
kobj_bcast_filter,
|
|
||||||
kobj);
|
|
||||||
/* ENOBUFS should be handled in userspace */
|
|
||||||
if (retval == -ENOBUFS || retval == -ESRCH)
|
|
||||||
retval = 0;
|
|
||||||
} else
|
|
||||||
retval = -ENOMEM;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
mutex_unlock(&uevent_sock_mutex);
|
mutex_unlock(&uevent_sock_mutex);
|
||||||
|
|
||||||
#ifdef CONFIG_UEVENT_HELPER
|
#ifdef CONFIG_UEVENT_HELPER
|
||||||
|
Loading…
Reference in New Issue
Block a user