mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
netlink: Rename pid to portid to avoid confusion
It is a frequent mistake to confuse the netlink port identifier with a process identifier. Try to reduce this confusion by renaming fields that hold port identifiers portid instead of pid. I have carefully avoided changing the structures exported to userspace to avoid changing the userspace API. I have successfully built an allyesconfig kernel with this change. Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com> Acked-by: Stephen Hemminger <shemminger@vyatta.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
9f00d9776b
commit
15e473046c
@ -166,7 +166,7 @@ static int crypto_report_alg(struct crypto_alg *alg,
|
|||||||
struct crypto_user_alg *ualg;
|
struct crypto_user_alg *ualg;
|
||||||
int err = 0;
|
int err = 0;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, NETLINK_CB(in_skb).pid, info->nlmsg_seq,
|
nlh = nlmsg_put(skb, NETLINK_CB(in_skb).portid, info->nlmsg_seq,
|
||||||
CRYPTO_MSG_GETALG, sizeof(*ualg), info->nlmsg_flags);
|
CRYPTO_MSG_GETALG, sizeof(*ualg), info->nlmsg_flags);
|
||||||
if (!nlh) {
|
if (!nlh) {
|
||||||
err = -EMSGSIZE;
|
err = -EMSGSIZE;
|
||||||
@ -216,7 +216,7 @@ static int crypto_report(struct sk_buff *in_skb, struct nlmsghdr *in_nlh,
|
|||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
return nlmsg_unicast(crypto_nlsk, skb, NETLINK_CB(in_skb).pid);
|
return nlmsg_unicast(crypto_nlsk, skb, NETLINK_CB(in_skb).portid);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int crypto_dump_report(struct sk_buff *skb, struct netlink_callback *cb)
|
static int crypto_dump_report(struct sk_buff *skb, struct netlink_callback *cb)
|
||||||
|
@ -1886,7 +1886,7 @@ static int team_nl_cmd_noop(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (!msg)
|
if (!msg)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
hdr = genlmsg_put(msg, info->snd_pid, info->snd_seq,
|
hdr = genlmsg_put(msg, info->snd_portid, info->snd_seq,
|
||||||
&team_nl_family, 0, TEAM_CMD_NOOP);
|
&team_nl_family, 0, TEAM_CMD_NOOP);
|
||||||
if (IS_ERR(hdr)) {
|
if (IS_ERR(hdr)) {
|
||||||
err = PTR_ERR(hdr);
|
err = PTR_ERR(hdr);
|
||||||
@ -1895,7 +1895,7 @@ static int team_nl_cmd_noop(struct sk_buff *skb, struct genl_info *info)
|
|||||||
|
|
||||||
genlmsg_end(msg, hdr);
|
genlmsg_end(msg, hdr);
|
||||||
|
|
||||||
return genlmsg_unicast(genl_info_net(info), msg, info->snd_pid);
|
return genlmsg_unicast(genl_info_net(info), msg, info->snd_portid);
|
||||||
|
|
||||||
err_msg_put:
|
err_msg_put:
|
||||||
nlmsg_free(msg);
|
nlmsg_free(msg);
|
||||||
@ -1952,7 +1952,7 @@ static int team_nl_send_generic(struct genl_info *info, struct team *team,
|
|||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto err_fill;
|
goto err_fill;
|
||||||
|
|
||||||
err = genlmsg_unicast(genl_info_net(info), skb, info->snd_pid);
|
err = genlmsg_unicast(genl_info_net(info), skb, info->snd_portid);
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
err_fill:
|
err_fill:
|
||||||
@ -1961,11 +1961,11 @@ static int team_nl_send_generic(struct genl_info *info, struct team *team,
|
|||||||
}
|
}
|
||||||
|
|
||||||
typedef int team_nl_send_func_t(struct sk_buff *skb,
|
typedef int team_nl_send_func_t(struct sk_buff *skb,
|
||||||
struct team *team, u32 pid);
|
struct team *team, u32 portid);
|
||||||
|
|
||||||
static int team_nl_send_unicast(struct sk_buff *skb, struct team *team, u32 pid)
|
static int team_nl_send_unicast(struct sk_buff *skb, struct team *team, u32 portid)
|
||||||
{
|
{
|
||||||
return genlmsg_unicast(dev_net(team->dev), skb, pid);
|
return genlmsg_unicast(dev_net(team->dev), skb, portid);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int team_nl_fill_one_option_get(struct sk_buff *skb, struct team *team,
|
static int team_nl_fill_one_option_get(struct sk_buff *skb, struct team *team,
|
||||||
@ -2050,13 +2050,13 @@ static int team_nl_fill_one_option_get(struct sk_buff *skb, struct team *team,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int __send_and_alloc_skb(struct sk_buff **pskb,
|
static int __send_and_alloc_skb(struct sk_buff **pskb,
|
||||||
struct team *team, u32 pid,
|
struct team *team, u32 portid,
|
||||||
team_nl_send_func_t *send_func)
|
team_nl_send_func_t *send_func)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
if (*pskb) {
|
if (*pskb) {
|
||||||
err = send_func(*pskb, team, pid);
|
err = send_func(*pskb, team, portid);
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
@ -2066,7 +2066,7 @@ static int __send_and_alloc_skb(struct sk_buff **pskb,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int team_nl_send_options_get(struct team *team, u32 pid, u32 seq,
|
static int team_nl_send_options_get(struct team *team, u32 portid, u32 seq,
|
||||||
int flags, team_nl_send_func_t *send_func,
|
int flags, team_nl_send_func_t *send_func,
|
||||||
struct list_head *sel_opt_inst_list)
|
struct list_head *sel_opt_inst_list)
|
||||||
{
|
{
|
||||||
@ -2083,11 +2083,11 @@ static int team_nl_send_options_get(struct team *team, u32 pid, u32 seq,
|
|||||||
struct team_option_inst, tmp_list);
|
struct team_option_inst, tmp_list);
|
||||||
|
|
||||||
start_again:
|
start_again:
|
||||||
err = __send_and_alloc_skb(&skb, team, pid, send_func);
|
err = __send_and_alloc_skb(&skb, team, portid, send_func);
|
||||||
if (err)
|
if (err)
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
hdr = genlmsg_put(skb, pid, seq, &team_nl_family, flags | NLM_F_MULTI,
|
hdr = genlmsg_put(skb, portid, seq, &team_nl_family, flags | NLM_F_MULTI,
|
||||||
TEAM_CMD_OPTIONS_GET);
|
TEAM_CMD_OPTIONS_GET);
|
||||||
if (IS_ERR(hdr))
|
if (IS_ERR(hdr))
|
||||||
return PTR_ERR(hdr);
|
return PTR_ERR(hdr);
|
||||||
@ -2120,15 +2120,15 @@ static int team_nl_send_options_get(struct team *team, u32 pid, u32 seq,
|
|||||||
goto start_again;
|
goto start_again;
|
||||||
|
|
||||||
send_done:
|
send_done:
|
||||||
nlh = nlmsg_put(skb, pid, seq, NLMSG_DONE, 0, flags | NLM_F_MULTI);
|
nlh = nlmsg_put(skb, portid, seq, NLMSG_DONE, 0, flags | NLM_F_MULTI);
|
||||||
if (!nlh) {
|
if (!nlh) {
|
||||||
err = __send_and_alloc_skb(&skb, team, pid, send_func);
|
err = __send_and_alloc_skb(&skb, team, portid, send_func);
|
||||||
if (err)
|
if (err)
|
||||||
goto errout;
|
goto errout;
|
||||||
goto send_done;
|
goto send_done;
|
||||||
}
|
}
|
||||||
|
|
||||||
return send_func(skb, team, pid);
|
return send_func(skb, team, portid);
|
||||||
|
|
||||||
nla_put_failure:
|
nla_put_failure:
|
||||||
err = -EMSGSIZE;
|
err = -EMSGSIZE;
|
||||||
@ -2151,7 +2151,7 @@ static int team_nl_cmd_options_get(struct sk_buff *skb, struct genl_info *info)
|
|||||||
|
|
||||||
list_for_each_entry(opt_inst, &team->option_inst_list, list)
|
list_for_each_entry(opt_inst, &team->option_inst_list, list)
|
||||||
list_add_tail(&opt_inst->tmp_list, &sel_opt_inst_list);
|
list_add_tail(&opt_inst->tmp_list, &sel_opt_inst_list);
|
||||||
err = team_nl_send_options_get(team, info->snd_pid, info->snd_seq,
|
err = team_nl_send_options_get(team, info->snd_portid, info->snd_seq,
|
||||||
NLM_F_ACK, team_nl_send_unicast,
|
NLM_F_ACK, team_nl_send_unicast,
|
||||||
&sel_opt_inst_list);
|
&sel_opt_inst_list);
|
||||||
|
|
||||||
@ -2305,7 +2305,7 @@ static int team_nl_cmd_options_set(struct sk_buff *skb, struct genl_info *info)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int team_nl_fill_port_list_get(struct sk_buff *skb,
|
static int team_nl_fill_port_list_get(struct sk_buff *skb,
|
||||||
u32 pid, u32 seq, int flags,
|
u32 portid, u32 seq, int flags,
|
||||||
struct team *team,
|
struct team *team,
|
||||||
bool fillall)
|
bool fillall)
|
||||||
{
|
{
|
||||||
@ -2313,7 +2313,7 @@ static int team_nl_fill_port_list_get(struct sk_buff *skb,
|
|||||||
void *hdr;
|
void *hdr;
|
||||||
struct team_port *port;
|
struct team_port *port;
|
||||||
|
|
||||||
hdr = genlmsg_put(skb, pid, seq, &team_nl_family, flags,
|
hdr = genlmsg_put(skb, portid, seq, &team_nl_family, flags,
|
||||||
TEAM_CMD_PORT_LIST_GET);
|
TEAM_CMD_PORT_LIST_GET);
|
||||||
if (IS_ERR(hdr))
|
if (IS_ERR(hdr))
|
||||||
return PTR_ERR(hdr);
|
return PTR_ERR(hdr);
|
||||||
@ -2362,7 +2362,7 @@ static int team_nl_fill_port_list_get_all(struct sk_buff *skb,
|
|||||||
struct genl_info *info, int flags,
|
struct genl_info *info, int flags,
|
||||||
struct team *team)
|
struct team *team)
|
||||||
{
|
{
|
||||||
return team_nl_fill_port_list_get(skb, info->snd_pid,
|
return team_nl_fill_port_list_get(skb, info->snd_portid,
|
||||||
info->snd_seq, NLM_F_ACK,
|
info->snd_seq, NLM_F_ACK,
|
||||||
team, true);
|
team, true);
|
||||||
}
|
}
|
||||||
@ -2415,7 +2415,7 @@ static struct genl_multicast_group team_change_event_mcgrp = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static int team_nl_send_multicast(struct sk_buff *skb,
|
static int team_nl_send_multicast(struct sk_buff *skb,
|
||||||
struct team *team, u32 pid)
|
struct team *team, u32 portid)
|
||||||
{
|
{
|
||||||
return genlmsg_multicast_netns(dev_net(team->dev), skb, 0,
|
return genlmsg_multicast_netns(dev_net(team->dev), skb, 0,
|
||||||
team_change_event_mcgrp.id, GFP_KERNEL);
|
team_change_event_mcgrp.id, GFP_KERNEL);
|
||||||
|
@ -38,7 +38,7 @@ MODULE_AUTHOR("Jouni Malinen");
|
|||||||
MODULE_DESCRIPTION("Software simulator of 802.11 radio(s) for mac80211");
|
MODULE_DESCRIPTION("Software simulator of 802.11 radio(s) for mac80211");
|
||||||
MODULE_LICENSE("GPL");
|
MODULE_LICENSE("GPL");
|
||||||
|
|
||||||
static u32 wmediumd_pid;
|
static u32 wmediumd_portid;
|
||||||
|
|
||||||
static int radios = 2;
|
static int radios = 2;
|
||||||
module_param(radios, int, 0444);
|
module_param(radios, int, 0444);
|
||||||
@ -545,7 +545,7 @@ static bool mac80211_hwsim_addr_match(struct mac80211_hwsim_data *data,
|
|||||||
|
|
||||||
static void mac80211_hwsim_tx_frame_nl(struct ieee80211_hw *hw,
|
static void mac80211_hwsim_tx_frame_nl(struct ieee80211_hw *hw,
|
||||||
struct sk_buff *my_skb,
|
struct sk_buff *my_skb,
|
||||||
int dst_pid)
|
int dst_portid)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
struct mac80211_hwsim_data *data = hw->priv;
|
struct mac80211_hwsim_data *data = hw->priv;
|
||||||
@ -619,7 +619,7 @@ static void mac80211_hwsim_tx_frame_nl(struct ieee80211_hw *hw,
|
|||||||
goto nla_put_failure;
|
goto nla_put_failure;
|
||||||
|
|
||||||
genlmsg_end(skb, msg_head);
|
genlmsg_end(skb, msg_head);
|
||||||
genlmsg_unicast(&init_net, skb, dst_pid);
|
genlmsg_unicast(&init_net, skb, dst_portid);
|
||||||
|
|
||||||
/* Enqueue the packet */
|
/* Enqueue the packet */
|
||||||
skb_queue_tail(&data->pending, my_skb);
|
skb_queue_tail(&data->pending, my_skb);
|
||||||
@ -715,7 +715,7 @@ static void mac80211_hwsim_tx(struct ieee80211_hw *hw,
|
|||||||
{
|
{
|
||||||
bool ack;
|
bool ack;
|
||||||
struct ieee80211_tx_info *txi;
|
struct ieee80211_tx_info *txi;
|
||||||
u32 _pid;
|
u32 _portid;
|
||||||
|
|
||||||
mac80211_hwsim_monitor_rx(hw, skb);
|
mac80211_hwsim_monitor_rx(hw, skb);
|
||||||
|
|
||||||
@ -726,10 +726,10 @@ static void mac80211_hwsim_tx(struct ieee80211_hw *hw,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* wmediumd mode check */
|
/* wmediumd mode check */
|
||||||
_pid = ACCESS_ONCE(wmediumd_pid);
|
_portid = ACCESS_ONCE(wmediumd_portid);
|
||||||
|
|
||||||
if (_pid)
|
if (_portid)
|
||||||
return mac80211_hwsim_tx_frame_nl(hw, skb, _pid);
|
return mac80211_hwsim_tx_frame_nl(hw, skb, _portid);
|
||||||
|
|
||||||
/* NO wmediumd detected, perfect medium simulation */
|
/* NO wmediumd detected, perfect medium simulation */
|
||||||
ack = mac80211_hwsim_tx_frame_no_nl(hw, skb);
|
ack = mac80211_hwsim_tx_frame_no_nl(hw, skb);
|
||||||
@ -814,7 +814,7 @@ static void mac80211_hwsim_beacon_tx(void *arg, u8 *mac,
|
|||||||
struct ieee80211_hw *hw = arg;
|
struct ieee80211_hw *hw = arg;
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
struct ieee80211_tx_info *info;
|
struct ieee80211_tx_info *info;
|
||||||
u32 _pid;
|
u32 _portid;
|
||||||
|
|
||||||
hwsim_check_magic(vif);
|
hwsim_check_magic(vif);
|
||||||
|
|
||||||
@ -831,10 +831,10 @@ static void mac80211_hwsim_beacon_tx(void *arg, u8 *mac,
|
|||||||
mac80211_hwsim_monitor_rx(hw, skb);
|
mac80211_hwsim_monitor_rx(hw, skb);
|
||||||
|
|
||||||
/* wmediumd mode check */
|
/* wmediumd mode check */
|
||||||
_pid = ACCESS_ONCE(wmediumd_pid);
|
_portid = ACCESS_ONCE(wmediumd_portid);
|
||||||
|
|
||||||
if (_pid)
|
if (_portid)
|
||||||
return mac80211_hwsim_tx_frame_nl(hw, skb, _pid);
|
return mac80211_hwsim_tx_frame_nl(hw, skb, _portid);
|
||||||
|
|
||||||
mac80211_hwsim_tx_frame_no_nl(hw, skb);
|
mac80211_hwsim_tx_frame_no_nl(hw, skb);
|
||||||
dev_kfree_skb(skb);
|
dev_kfree_skb(skb);
|
||||||
@ -1315,7 +1315,7 @@ static void hwsim_send_ps_poll(void *dat, u8 *mac, struct ieee80211_vif *vif)
|
|||||||
struct hwsim_vif_priv *vp = (void *)vif->drv_priv;
|
struct hwsim_vif_priv *vp = (void *)vif->drv_priv;
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
struct ieee80211_pspoll *pspoll;
|
struct ieee80211_pspoll *pspoll;
|
||||||
u32 _pid;
|
u32 _portid;
|
||||||
|
|
||||||
if (!vp->assoc)
|
if (!vp->assoc)
|
||||||
return;
|
return;
|
||||||
@ -1336,10 +1336,10 @@ static void hwsim_send_ps_poll(void *dat, u8 *mac, struct ieee80211_vif *vif)
|
|||||||
memcpy(pspoll->ta, mac, ETH_ALEN);
|
memcpy(pspoll->ta, mac, ETH_ALEN);
|
||||||
|
|
||||||
/* wmediumd mode check */
|
/* wmediumd mode check */
|
||||||
_pid = ACCESS_ONCE(wmediumd_pid);
|
_portid = ACCESS_ONCE(wmediumd_portid);
|
||||||
|
|
||||||
if (_pid)
|
if (_portid)
|
||||||
return mac80211_hwsim_tx_frame_nl(data->hw, skb, _pid);
|
return mac80211_hwsim_tx_frame_nl(data->hw, skb, _portid);
|
||||||
|
|
||||||
if (!mac80211_hwsim_tx_frame_no_nl(data->hw, skb))
|
if (!mac80211_hwsim_tx_frame_no_nl(data->hw, skb))
|
||||||
printk(KERN_DEBUG "%s: PS-poll frame not ack'ed\n", __func__);
|
printk(KERN_DEBUG "%s: PS-poll frame not ack'ed\n", __func__);
|
||||||
@ -1353,7 +1353,7 @@ static void hwsim_send_nullfunc(struct mac80211_hwsim_data *data, u8 *mac,
|
|||||||
struct hwsim_vif_priv *vp = (void *)vif->drv_priv;
|
struct hwsim_vif_priv *vp = (void *)vif->drv_priv;
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
struct ieee80211_hdr *hdr;
|
struct ieee80211_hdr *hdr;
|
||||||
u32 _pid;
|
u32 _portid;
|
||||||
|
|
||||||
if (!vp->assoc)
|
if (!vp->assoc)
|
||||||
return;
|
return;
|
||||||
@ -1375,10 +1375,10 @@ static void hwsim_send_nullfunc(struct mac80211_hwsim_data *data, u8 *mac,
|
|||||||
memcpy(hdr->addr3, vp->bssid, ETH_ALEN);
|
memcpy(hdr->addr3, vp->bssid, ETH_ALEN);
|
||||||
|
|
||||||
/* wmediumd mode check */
|
/* wmediumd mode check */
|
||||||
_pid = ACCESS_ONCE(wmediumd_pid);
|
_portid = ACCESS_ONCE(wmediumd_portid);
|
||||||
|
|
||||||
if (_pid)
|
if (_portid)
|
||||||
return mac80211_hwsim_tx_frame_nl(data->hw, skb, _pid);
|
return mac80211_hwsim_tx_frame_nl(data->hw, skb, _portid);
|
||||||
|
|
||||||
if (!mac80211_hwsim_tx_frame_no_nl(data->hw, skb))
|
if (!mac80211_hwsim_tx_frame_no_nl(data->hw, skb))
|
||||||
printk(KERN_DEBUG "%s: nullfunc frame not ack'ed\n", __func__);
|
printk(KERN_DEBUG "%s: nullfunc frame not ack'ed\n", __func__);
|
||||||
@ -1632,10 +1632,10 @@ static int hwsim_register_received_nl(struct sk_buff *skb_2,
|
|||||||
if (info == NULL)
|
if (info == NULL)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
wmediumd_pid = info->snd_pid;
|
wmediumd_portid = info->snd_portid;
|
||||||
|
|
||||||
printk(KERN_DEBUG "mac80211_hwsim: received a REGISTER, "
|
printk(KERN_DEBUG "mac80211_hwsim: received a REGISTER, "
|
||||||
"switching to wmediumd mode with pid %d\n", info->snd_pid);
|
"switching to wmediumd mode with pid %d\n", info->snd_portid);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
out:
|
out:
|
||||||
@ -1672,10 +1672,10 @@ static int mac80211_hwsim_netlink_notify(struct notifier_block *nb,
|
|||||||
if (state != NETLINK_URELEASE)
|
if (state != NETLINK_URELEASE)
|
||||||
return NOTIFY_DONE;
|
return NOTIFY_DONE;
|
||||||
|
|
||||||
if (notify->pid == wmediumd_pid) {
|
if (notify->portid == wmediumd_portid) {
|
||||||
printk(KERN_INFO "mac80211_hwsim: wmediumd released netlink"
|
printk(KERN_INFO "mac80211_hwsim: wmediumd released netlink"
|
||||||
" socket, switching to perfect channel medium\n");
|
" socket, switching to perfect channel medium\n");
|
||||||
wmediumd_pid = 0;
|
wmediumd_portid = 0;
|
||||||
}
|
}
|
||||||
return NOTIFY_DONE;
|
return NOTIFY_DONE;
|
||||||
|
|
||||||
|
@ -2119,7 +2119,7 @@ iscsi_if_recv_msg(struct sk_buff *skb, struct nlmsghdr *nlh, uint32_t *group)
|
|||||||
switch (nlh->nlmsg_type) {
|
switch (nlh->nlmsg_type) {
|
||||||
case ISCSI_UEVENT_CREATE_SESSION:
|
case ISCSI_UEVENT_CREATE_SESSION:
|
||||||
err = iscsi_if_create_session(priv, ep, ev,
|
err = iscsi_if_create_session(priv, ep, ev,
|
||||||
NETLINK_CB(skb).pid,
|
NETLINK_CB(skb).portid,
|
||||||
ev->u.c_session.initial_cmdsn,
|
ev->u.c_session.initial_cmdsn,
|
||||||
ev->u.c_session.cmds_max,
|
ev->u.c_session.cmds_max,
|
||||||
ev->u.c_session.queue_depth);
|
ev->u.c_session.queue_depth);
|
||||||
@ -2132,7 +2132,7 @@ iscsi_if_recv_msg(struct sk_buff *skb, struct nlmsghdr *nlh, uint32_t *group)
|
|||||||
}
|
}
|
||||||
|
|
||||||
err = iscsi_if_create_session(priv, ep, ev,
|
err = iscsi_if_create_session(priv, ep, ev,
|
||||||
NETLINK_CB(skb).pid,
|
NETLINK_CB(skb).portid,
|
||||||
ev->u.c_bound_session.initial_cmdsn,
|
ev->u.c_bound_session.initial_cmdsn,
|
||||||
ev->u.c_bound_session.cmds_max,
|
ev->u.c_bound_session.cmds_max,
|
||||||
ev->u.c_bound_session.queue_depth);
|
ev->u.c_bound_session.queue_depth);
|
||||||
|
@ -135,7 +135,7 @@ int netlink_send(struct sock *sock, int group, u16 type, void *msg, int len)
|
|||||||
}
|
}
|
||||||
memcpy(nlmsg_data(nlh), msg, len);
|
memcpy(nlmsg_data(nlh), msg, len);
|
||||||
|
|
||||||
NETLINK_CB(skb).pid = 0;
|
NETLINK_CB(skb).portid = 0;
|
||||||
NETLINK_CB(skb).dst_group = 0;
|
NETLINK_CB(skb).dst_group = 0;
|
||||||
|
|
||||||
ret = netlink_broadcast(sock, skb, 0, group+1, GFP_ATOMIC);
|
ret = netlink_broadcast(sock, skb, 0, group+1, GFP_ATOMIC);
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
#include "dlm_internal.h"
|
#include "dlm_internal.h"
|
||||||
|
|
||||||
static uint32_t dlm_nl_seqnum;
|
static uint32_t dlm_nl_seqnum;
|
||||||
static uint32_t listener_nlpid;
|
static uint32_t listener_nlportid;
|
||||||
|
|
||||||
static struct genl_family family = {
|
static struct genl_family family = {
|
||||||
.id = GENL_ID_GENERATE,
|
.id = GENL_ID_GENERATE,
|
||||||
@ -64,13 +64,13 @@ static int send_data(struct sk_buff *skb)
|
|||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
|
|
||||||
return genlmsg_unicast(&init_net, skb, listener_nlpid);
|
return genlmsg_unicast(&init_net, skb, listener_nlportid);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int user_cmd(struct sk_buff *skb, struct genl_info *info)
|
static int user_cmd(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
listener_nlpid = info->snd_pid;
|
listener_nlportid = info->snd_portid;
|
||||||
printk("user_cmd nlpid %u\n", listener_nlpid);
|
printk("user_cmd nlpid %u\n", listener_nlportid);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -165,7 +165,7 @@ static inline struct nlmsghdr *nlmsg_hdr(const struct sk_buff *skb)
|
|||||||
|
|
||||||
struct netlink_skb_parms {
|
struct netlink_skb_parms {
|
||||||
struct scm_creds creds; /* Skb credentials */
|
struct scm_creds creds; /* Skb credentials */
|
||||||
__u32 pid;
|
__u32 portid;
|
||||||
__u32 dst_group;
|
__u32 dst_group;
|
||||||
struct sock *ssk;
|
struct sock *ssk;
|
||||||
};
|
};
|
||||||
@ -205,14 +205,14 @@ extern void __netlink_clear_multicast_users(struct sock *sk, unsigned int group)
|
|||||||
extern void netlink_clear_multicast_users(struct sock *sk, unsigned int group);
|
extern void netlink_clear_multicast_users(struct sock *sk, unsigned int group);
|
||||||
extern void netlink_ack(struct sk_buff *in_skb, struct nlmsghdr *nlh, int err);
|
extern void netlink_ack(struct sk_buff *in_skb, struct nlmsghdr *nlh, int err);
|
||||||
extern int netlink_has_listeners(struct sock *sk, unsigned int group);
|
extern int netlink_has_listeners(struct sock *sk, unsigned int group);
|
||||||
extern int netlink_unicast(struct sock *ssk, struct sk_buff *skb, __u32 pid, int nonblock);
|
extern int netlink_unicast(struct sock *ssk, struct sk_buff *skb, __u32 portid, int nonblock);
|
||||||
extern int netlink_broadcast(struct sock *ssk, struct sk_buff *skb, __u32 pid,
|
extern int netlink_broadcast(struct sock *ssk, struct sk_buff *skb, __u32 portid,
|
||||||
__u32 group, gfp_t allocation);
|
__u32 group, gfp_t allocation);
|
||||||
extern int netlink_broadcast_filtered(struct sock *ssk, struct sk_buff *skb,
|
extern int netlink_broadcast_filtered(struct sock *ssk, struct sk_buff *skb,
|
||||||
__u32 pid, __u32 group, gfp_t allocation,
|
__u32 portid, __u32 group, gfp_t allocation,
|
||||||
int (*filter)(struct sock *dsk, struct sk_buff *skb, void *data),
|
int (*filter)(struct sock *dsk, struct sk_buff *skb, void *data),
|
||||||
void *filter_data);
|
void *filter_data);
|
||||||
extern int netlink_set_err(struct sock *ssk, __u32 pid, __u32 group, int code);
|
extern int netlink_set_err(struct sock *ssk, __u32 portid, __u32 group, int code);
|
||||||
extern int netlink_register_notifier(struct notifier_block *nb);
|
extern int netlink_register_notifier(struct notifier_block *nb);
|
||||||
extern int netlink_unregister_notifier(struct notifier_block *nb);
|
extern int netlink_unregister_notifier(struct notifier_block *nb);
|
||||||
|
|
||||||
@ -253,12 +253,12 @@ struct netlink_callback {
|
|||||||
|
|
||||||
struct netlink_notify {
|
struct netlink_notify {
|
||||||
struct net *net;
|
struct net *net;
|
||||||
int pid;
|
int portid;
|
||||||
int protocol;
|
int protocol;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct nlmsghdr *
|
struct nlmsghdr *
|
||||||
__nlmsg_put(struct sk_buff *skb, u32 pid, u32 seq, int type, int len, int flags);
|
__nlmsg_put(struct sk_buff *skb, u32 portid, u32 seq, int type, int len, int flags);
|
||||||
|
|
||||||
struct netlink_dump_control {
|
struct netlink_dump_control {
|
||||||
int (*dump)(struct sk_buff *skb, struct netlink_callback *);
|
int (*dump)(struct sk_buff *skb, struct netlink_callback *);
|
||||||
|
@ -2458,7 +2458,7 @@ struct wireless_dev {
|
|||||||
|
|
||||||
int beacon_interval;
|
int beacon_interval;
|
||||||
|
|
||||||
u32 ap_unexpected_nlpid;
|
u32 ap_unexpected_nlportid;
|
||||||
|
|
||||||
#ifdef CONFIG_CFG80211_WEXT
|
#ifdef CONFIG_CFG80211_WEXT
|
||||||
/* wext data */
|
/* wext data */
|
||||||
|
@ -65,7 +65,7 @@ struct genl_family {
|
|||||||
/**
|
/**
|
||||||
* struct genl_info - receiving information
|
* struct genl_info - receiving information
|
||||||
* @snd_seq: sending sequence number
|
* @snd_seq: sending sequence number
|
||||||
* @snd_pid: netlink pid of sender
|
* @snd_portid: netlink portid of sender
|
||||||
* @nlhdr: netlink message header
|
* @nlhdr: netlink message header
|
||||||
* @genlhdr: generic netlink message header
|
* @genlhdr: generic netlink message header
|
||||||
* @userhdr: user specific header
|
* @userhdr: user specific header
|
||||||
@ -75,7 +75,7 @@ struct genl_family {
|
|||||||
*/
|
*/
|
||||||
struct genl_info {
|
struct genl_info {
|
||||||
u32 snd_seq;
|
u32 snd_seq;
|
||||||
u32 snd_pid;
|
u32 snd_portid;
|
||||||
struct nlmsghdr * nlhdr;
|
struct nlmsghdr * nlhdr;
|
||||||
struct genlmsghdr * genlhdr;
|
struct genlmsghdr * genlhdr;
|
||||||
void * userhdr;
|
void * userhdr;
|
||||||
@ -130,10 +130,10 @@ extern int genl_register_mc_group(struct genl_family *family,
|
|||||||
struct genl_multicast_group *grp);
|
struct genl_multicast_group *grp);
|
||||||
extern void genl_unregister_mc_group(struct genl_family *family,
|
extern void genl_unregister_mc_group(struct genl_family *family,
|
||||||
struct genl_multicast_group *grp);
|
struct genl_multicast_group *grp);
|
||||||
extern void genl_notify(struct sk_buff *skb, struct net *net, u32 pid,
|
extern void genl_notify(struct sk_buff *skb, struct net *net, u32 portid,
|
||||||
u32 group, struct nlmsghdr *nlh, gfp_t flags);
|
u32 group, struct nlmsghdr *nlh, gfp_t flags);
|
||||||
|
|
||||||
void *genlmsg_put(struct sk_buff *skb, u32 pid, u32 seq,
|
void *genlmsg_put(struct sk_buff *skb, u32 portid, u32 seq,
|
||||||
struct genl_family *family, int flags, u8 cmd);
|
struct genl_family *family, int flags, u8 cmd);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -183,7 +183,7 @@ static inline void *genlmsg_put_reply(struct sk_buff *skb,
|
|||||||
struct genl_family *family,
|
struct genl_family *family,
|
||||||
int flags, u8 cmd)
|
int flags, u8 cmd)
|
||||||
{
|
{
|
||||||
return genlmsg_put(skb, info->snd_pid, info->snd_seq, family,
|
return genlmsg_put(skb, info->snd_portid, info->snd_seq, family,
|
||||||
flags, cmd);
|
flags, cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -212,49 +212,49 @@ static inline void genlmsg_cancel(struct sk_buff *skb, void *hdr)
|
|||||||
* genlmsg_multicast_netns - multicast a netlink message to a specific netns
|
* genlmsg_multicast_netns - multicast a netlink message to a specific netns
|
||||||
* @net: the net namespace
|
* @net: the net namespace
|
||||||
* @skb: netlink message as socket buffer
|
* @skb: netlink message as socket buffer
|
||||||
* @pid: own netlink pid to avoid sending to yourself
|
* @portid: own netlink portid to avoid sending to yourself
|
||||||
* @group: multicast group id
|
* @group: multicast group id
|
||||||
* @flags: allocation flags
|
* @flags: allocation flags
|
||||||
*/
|
*/
|
||||||
static inline int genlmsg_multicast_netns(struct net *net, struct sk_buff *skb,
|
static inline int genlmsg_multicast_netns(struct net *net, struct sk_buff *skb,
|
||||||
u32 pid, unsigned int group, gfp_t flags)
|
u32 portid, unsigned int group, gfp_t flags)
|
||||||
{
|
{
|
||||||
return nlmsg_multicast(net->genl_sock, skb, pid, group, flags);
|
return nlmsg_multicast(net->genl_sock, skb, portid, group, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* genlmsg_multicast - multicast a netlink message to the default netns
|
* genlmsg_multicast - multicast a netlink message to the default netns
|
||||||
* @skb: netlink message as socket buffer
|
* @skb: netlink message as socket buffer
|
||||||
* @pid: own netlink pid to avoid sending to yourself
|
* @portid: own netlink portid to avoid sending to yourself
|
||||||
* @group: multicast group id
|
* @group: multicast group id
|
||||||
* @flags: allocation flags
|
* @flags: allocation flags
|
||||||
*/
|
*/
|
||||||
static inline int genlmsg_multicast(struct sk_buff *skb, u32 pid,
|
static inline int genlmsg_multicast(struct sk_buff *skb, u32 portid,
|
||||||
unsigned int group, gfp_t flags)
|
unsigned int group, gfp_t flags)
|
||||||
{
|
{
|
||||||
return genlmsg_multicast_netns(&init_net, skb, pid, group, flags);
|
return genlmsg_multicast_netns(&init_net, skb, portid, group, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* genlmsg_multicast_allns - multicast a netlink message to all net namespaces
|
* genlmsg_multicast_allns - multicast a netlink message to all net namespaces
|
||||||
* @skb: netlink message as socket buffer
|
* @skb: netlink message as socket buffer
|
||||||
* @pid: own netlink pid to avoid sending to yourself
|
* @portid: own netlink portid to avoid sending to yourself
|
||||||
* @group: multicast group id
|
* @group: multicast group id
|
||||||
* @flags: allocation flags
|
* @flags: allocation flags
|
||||||
*
|
*
|
||||||
* This function must hold the RTNL or rcu_read_lock().
|
* This function must hold the RTNL or rcu_read_lock().
|
||||||
*/
|
*/
|
||||||
int genlmsg_multicast_allns(struct sk_buff *skb, u32 pid,
|
int genlmsg_multicast_allns(struct sk_buff *skb, u32 portid,
|
||||||
unsigned int group, gfp_t flags);
|
unsigned int group, gfp_t flags);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* genlmsg_unicast - unicast a netlink message
|
* genlmsg_unicast - unicast a netlink message
|
||||||
* @skb: netlink message as socket buffer
|
* @skb: netlink message as socket buffer
|
||||||
* @pid: netlink pid of the destination socket
|
* @portid: netlink portid of the destination socket
|
||||||
*/
|
*/
|
||||||
static inline int genlmsg_unicast(struct net *net, struct sk_buff *skb, u32 pid)
|
static inline int genlmsg_unicast(struct net *net, struct sk_buff *skb, u32 portid)
|
||||||
{
|
{
|
||||||
return nlmsg_unicast(net->genl_sock, skb, pid);
|
return nlmsg_unicast(net->genl_sock, skb, portid);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -264,7 +264,7 @@ static inline int genlmsg_unicast(struct net *net, struct sk_buff *skb, u32 pid)
|
|||||||
*/
|
*/
|
||||||
static inline int genlmsg_reply(struct sk_buff *skb, struct genl_info *info)
|
static inline int genlmsg_reply(struct sk_buff *skb, struct genl_info *info)
|
||||||
{
|
{
|
||||||
return genlmsg_unicast(genl_info_net(info), skb, info->snd_pid);
|
return genlmsg_unicast(genl_info_net(info), skb, info->snd_portid);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -17,7 +17,7 @@ struct nf_conntrack_ecache {
|
|||||||
unsigned long missed; /* missed events */
|
unsigned long missed; /* missed events */
|
||||||
u16 ctmask; /* bitmask of ct events to be delivered */
|
u16 ctmask; /* bitmask of ct events to be delivered */
|
||||||
u16 expmask; /* bitmask of expect events to be delivered */
|
u16 expmask; /* bitmask of expect events to be delivered */
|
||||||
u32 pid; /* netlink pid of destroyer */
|
u32 portid; /* netlink portid of destroyer */
|
||||||
struct timer_list timeout;
|
struct timer_list timeout;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -60,7 +60,7 @@ nf_ct_ecache_ext_add(struct nf_conn *ct, u16 ctmask, u16 expmask, gfp_t gfp)
|
|||||||
/* This structure is passed to event handler */
|
/* This structure is passed to event handler */
|
||||||
struct nf_ct_event {
|
struct nf_ct_event {
|
||||||
struct nf_conn *ct;
|
struct nf_conn *ct;
|
||||||
u32 pid;
|
u32 portid;
|
||||||
int report;
|
int report;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -92,7 +92,7 @@ nf_conntrack_event_cache(enum ip_conntrack_events event, struct nf_conn *ct)
|
|||||||
static inline int
|
static inline int
|
||||||
nf_conntrack_eventmask_report(unsigned int eventmask,
|
nf_conntrack_eventmask_report(unsigned int eventmask,
|
||||||
struct nf_conn *ct,
|
struct nf_conn *ct,
|
||||||
u32 pid,
|
u32 portid,
|
||||||
int report)
|
int report)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
@ -112,11 +112,11 @@ nf_conntrack_eventmask_report(unsigned int eventmask,
|
|||||||
if (nf_ct_is_confirmed(ct) && !nf_ct_is_dying(ct)) {
|
if (nf_ct_is_confirmed(ct) && !nf_ct_is_dying(ct)) {
|
||||||
struct nf_ct_event item = {
|
struct nf_ct_event item = {
|
||||||
.ct = ct,
|
.ct = ct,
|
||||||
.pid = e->pid ? e->pid : pid,
|
.portid = e->portid ? e->portid : portid,
|
||||||
.report = report
|
.report = report
|
||||||
};
|
};
|
||||||
/* This is a resent of a destroy event? If so, skip missed */
|
/* This is a resent of a destroy event? If so, skip missed */
|
||||||
unsigned long missed = e->pid ? 0 : e->missed;
|
unsigned long missed = e->portid ? 0 : e->missed;
|
||||||
|
|
||||||
if (!((eventmask | missed) & e->ctmask))
|
if (!((eventmask | missed) & e->ctmask))
|
||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
@ -126,11 +126,11 @@ nf_conntrack_eventmask_report(unsigned int eventmask,
|
|||||||
spin_lock_bh(&ct->lock);
|
spin_lock_bh(&ct->lock);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
/* This is a destroy event that has been
|
/* This is a destroy event that has been
|
||||||
* triggered by a process, we store the PID
|
* triggered by a process, we store the PORTID
|
||||||
* to include it in the retransmission. */
|
* to include it in the retransmission. */
|
||||||
if (eventmask & (1 << IPCT_DESTROY) &&
|
if (eventmask & (1 << IPCT_DESTROY) &&
|
||||||
e->pid == 0 && pid != 0)
|
e->portid == 0 && portid != 0)
|
||||||
e->pid = pid;
|
e->portid = portid;
|
||||||
else
|
else
|
||||||
e->missed |= eventmask;
|
e->missed |= eventmask;
|
||||||
} else
|
} else
|
||||||
@ -145,9 +145,9 @@ nf_conntrack_eventmask_report(unsigned int eventmask,
|
|||||||
|
|
||||||
static inline int
|
static inline int
|
||||||
nf_conntrack_event_report(enum ip_conntrack_events event, struct nf_conn *ct,
|
nf_conntrack_event_report(enum ip_conntrack_events event, struct nf_conn *ct,
|
||||||
u32 pid, int report)
|
u32 portid, int report)
|
||||||
{
|
{
|
||||||
return nf_conntrack_eventmask_report(1 << event, ct, pid, report);
|
return nf_conntrack_eventmask_report(1 << event, ct, portid, report);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int
|
static inline int
|
||||||
@ -158,7 +158,7 @@ nf_conntrack_event(enum ip_conntrack_events event, struct nf_conn *ct)
|
|||||||
|
|
||||||
struct nf_exp_event {
|
struct nf_exp_event {
|
||||||
struct nf_conntrack_expect *exp;
|
struct nf_conntrack_expect *exp;
|
||||||
u32 pid;
|
u32 portid;
|
||||||
int report;
|
int report;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -172,7 +172,7 @@ extern void nf_ct_expect_unregister_notifier(struct net *net, struct nf_exp_even
|
|||||||
static inline void
|
static inline void
|
||||||
nf_ct_expect_event_report(enum ip_conntrack_expect_events event,
|
nf_ct_expect_event_report(enum ip_conntrack_expect_events event,
|
||||||
struct nf_conntrack_expect *exp,
|
struct nf_conntrack_expect *exp,
|
||||||
u32 pid,
|
u32 portid,
|
||||||
int report)
|
int report)
|
||||||
{
|
{
|
||||||
struct net *net = nf_ct_exp_net(exp);
|
struct net *net = nf_ct_exp_net(exp);
|
||||||
@ -191,7 +191,7 @@ nf_ct_expect_event_report(enum ip_conntrack_expect_events event,
|
|||||||
if (e->expmask & (1 << event)) {
|
if (e->expmask & (1 << event)) {
|
||||||
struct nf_exp_event item = {
|
struct nf_exp_event item = {
|
||||||
.exp = exp,
|
.exp = exp,
|
||||||
.pid = pid,
|
.portid = portid,
|
||||||
.report = report
|
.report = report
|
||||||
};
|
};
|
||||||
notify->fcn(1 << event, &item);
|
notify->fcn(1 << event, &item);
|
||||||
@ -216,20 +216,20 @@ static inline void nf_conntrack_event_cache(enum ip_conntrack_events event,
|
|||||||
struct nf_conn *ct) {}
|
struct nf_conn *ct) {}
|
||||||
static inline int nf_conntrack_eventmask_report(unsigned int eventmask,
|
static inline int nf_conntrack_eventmask_report(unsigned int eventmask,
|
||||||
struct nf_conn *ct,
|
struct nf_conn *ct,
|
||||||
u32 pid,
|
u32 portid,
|
||||||
int report) { return 0; }
|
int report) { return 0; }
|
||||||
static inline int nf_conntrack_event(enum ip_conntrack_events event,
|
static inline int nf_conntrack_event(enum ip_conntrack_events event,
|
||||||
struct nf_conn *ct) { return 0; }
|
struct nf_conn *ct) { return 0; }
|
||||||
static inline int nf_conntrack_event_report(enum ip_conntrack_events event,
|
static inline int nf_conntrack_event_report(enum ip_conntrack_events event,
|
||||||
struct nf_conn *ct,
|
struct nf_conn *ct,
|
||||||
u32 pid,
|
u32 portid,
|
||||||
int report) { return 0; }
|
int report) { return 0; }
|
||||||
static inline void nf_ct_deliver_cached_events(const struct nf_conn *ct) {}
|
static inline void nf_ct_deliver_cached_events(const struct nf_conn *ct) {}
|
||||||
static inline void nf_ct_expect_event(enum ip_conntrack_expect_events event,
|
static inline void nf_ct_expect_event(enum ip_conntrack_expect_events event,
|
||||||
struct nf_conntrack_expect *exp) {}
|
struct nf_conntrack_expect *exp) {}
|
||||||
static inline void nf_ct_expect_event_report(enum ip_conntrack_expect_events e,
|
static inline void nf_ct_expect_event_report(enum ip_conntrack_expect_events e,
|
||||||
struct nf_conntrack_expect *exp,
|
struct nf_conntrack_expect *exp,
|
||||||
u32 pid,
|
u32 portid,
|
||||||
int report) {}
|
int report) {}
|
||||||
|
|
||||||
static inline int nf_conntrack_ecache_init(struct net *net)
|
static inline int nf_conntrack_ecache_init(struct net *net)
|
||||||
|
@ -217,19 +217,19 @@ struct nla_policy {
|
|||||||
/**
|
/**
|
||||||
* struct nl_info - netlink source information
|
* struct nl_info - netlink source information
|
||||||
* @nlh: Netlink message header of original request
|
* @nlh: Netlink message header of original request
|
||||||
* @pid: Netlink PID of requesting application
|
* @portid: Netlink PORTID of requesting application
|
||||||
*/
|
*/
|
||||||
struct nl_info {
|
struct nl_info {
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct net *nl_net;
|
struct net *nl_net;
|
||||||
u32 pid;
|
u32 portid;
|
||||||
};
|
};
|
||||||
|
|
||||||
extern int netlink_rcv_skb(struct sk_buff *skb,
|
extern int netlink_rcv_skb(struct sk_buff *skb,
|
||||||
int (*cb)(struct sk_buff *,
|
int (*cb)(struct sk_buff *,
|
||||||
struct nlmsghdr *));
|
struct nlmsghdr *));
|
||||||
extern int nlmsg_notify(struct sock *sk, struct sk_buff *skb,
|
extern int nlmsg_notify(struct sock *sk, struct sk_buff *skb,
|
||||||
u32 pid, unsigned int group, int report,
|
u32 portid, unsigned int group, int report,
|
||||||
gfp_t flags);
|
gfp_t flags);
|
||||||
|
|
||||||
extern int nla_validate(const struct nlattr *head,
|
extern int nla_validate(const struct nlattr *head,
|
||||||
@ -444,7 +444,7 @@ static inline int nlmsg_report(const struct nlmsghdr *nlh)
|
|||||||
/**
|
/**
|
||||||
* nlmsg_put - Add a new netlink message to an skb
|
* nlmsg_put - Add a new netlink message to an skb
|
||||||
* @skb: socket buffer to store message in
|
* @skb: socket buffer to store message in
|
||||||
* @pid: netlink process id
|
* @portid: netlink process id
|
||||||
* @seq: sequence number of message
|
* @seq: sequence number of message
|
||||||
* @type: message type
|
* @type: message type
|
||||||
* @payload: length of message payload
|
* @payload: length of message payload
|
||||||
@ -453,13 +453,13 @@ static inline int nlmsg_report(const struct nlmsghdr *nlh)
|
|||||||
* Returns NULL if the tailroom of the skb is insufficient to store
|
* Returns NULL if the tailroom of the skb is insufficient to store
|
||||||
* the message header and payload.
|
* the message header and payload.
|
||||||
*/
|
*/
|
||||||
static inline struct nlmsghdr *nlmsg_put(struct sk_buff *skb, u32 pid, u32 seq,
|
static inline struct nlmsghdr *nlmsg_put(struct sk_buff *skb, u32 portid, u32 seq,
|
||||||
int type, int payload, int flags)
|
int type, int payload, int flags)
|
||||||
{
|
{
|
||||||
if (unlikely(skb_tailroom(skb) < nlmsg_total_size(payload)))
|
if (unlikely(skb_tailroom(skb) < nlmsg_total_size(payload)))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
return __nlmsg_put(skb, pid, seq, type, payload, flags);
|
return __nlmsg_put(skb, portid, seq, type, payload, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -478,7 +478,7 @@ static inline struct nlmsghdr *nlmsg_put_answer(struct sk_buff *skb,
|
|||||||
int type, int payload,
|
int type, int payload,
|
||||||
int flags)
|
int flags)
|
||||||
{
|
{
|
||||||
return nlmsg_put(skb, NETLINK_CB(cb->skb).pid, cb->nlh->nlmsg_seq,
|
return nlmsg_put(skb, NETLINK_CB(cb->skb).portid, cb->nlh->nlmsg_seq,
|
||||||
type, payload, flags);
|
type, payload, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -563,18 +563,18 @@ static inline void nlmsg_free(struct sk_buff *skb)
|
|||||||
* nlmsg_multicast - multicast a netlink message
|
* nlmsg_multicast - multicast a netlink message
|
||||||
* @sk: netlink socket to spread messages to
|
* @sk: netlink socket to spread messages to
|
||||||
* @skb: netlink message as socket buffer
|
* @skb: netlink message as socket buffer
|
||||||
* @pid: own netlink pid to avoid sending to yourself
|
* @portid: own netlink portid to avoid sending to yourself
|
||||||
* @group: multicast group id
|
* @group: multicast group id
|
||||||
* @flags: allocation flags
|
* @flags: allocation flags
|
||||||
*/
|
*/
|
||||||
static inline int nlmsg_multicast(struct sock *sk, struct sk_buff *skb,
|
static inline int nlmsg_multicast(struct sock *sk, struct sk_buff *skb,
|
||||||
u32 pid, unsigned int group, gfp_t flags)
|
u32 portid, unsigned int group, gfp_t flags)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
NETLINK_CB(skb).dst_group = group;
|
NETLINK_CB(skb).dst_group = group;
|
||||||
|
|
||||||
err = netlink_broadcast(sk, skb, pid, group, flags);
|
err = netlink_broadcast(sk, skb, portid, group, flags);
|
||||||
if (err > 0)
|
if (err > 0)
|
||||||
err = 0;
|
err = 0;
|
||||||
|
|
||||||
@ -585,13 +585,13 @@ static inline int nlmsg_multicast(struct sock *sk, struct sk_buff *skb,
|
|||||||
* nlmsg_unicast - unicast a netlink message
|
* nlmsg_unicast - unicast a netlink message
|
||||||
* @sk: netlink socket to spread message to
|
* @sk: netlink socket to spread message to
|
||||||
* @skb: netlink message as socket buffer
|
* @skb: netlink message as socket buffer
|
||||||
* @pid: netlink pid of the destination socket
|
* @portid: netlink portid of the destination socket
|
||||||
*/
|
*/
|
||||||
static inline int nlmsg_unicast(struct sock *sk, struct sk_buff *skb, u32 pid)
|
static inline int nlmsg_unicast(struct sock *sk, struct sk_buff *skb, u32 portid)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
err = netlink_unicast(sk, skb, pid, MSG_DONTWAIT);
|
err = netlink_unicast(sk, skb, portid, MSG_DONTWAIT);
|
||||||
if (err > 0)
|
if (err > 0)
|
||||||
err = 0;
|
err = 0;
|
||||||
|
|
||||||
|
@ -89,7 +89,7 @@ struct nfc_target {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct nfc_genl_data {
|
struct nfc_genl_data {
|
||||||
u32 poll_req_pid;
|
u32 poll_req_portid;
|
||||||
struct mutex genl_data_mutex;
|
struct mutex genl_data_mutex;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -263,7 +263,7 @@ struct km_event {
|
|||||||
} data;
|
} data;
|
||||||
|
|
||||||
u32 seq;
|
u32 seq;
|
||||||
u32 pid;
|
u32 portid;
|
||||||
u32 event;
|
u32 event;
|
||||||
struct net *net;
|
struct net *net;
|
||||||
};
|
};
|
||||||
@ -310,7 +310,7 @@ extern void km_state_notify(struct xfrm_state *x, const struct km_event *c);
|
|||||||
|
|
||||||
struct xfrm_tmpl;
|
struct xfrm_tmpl;
|
||||||
extern int km_query(struct xfrm_state *x, struct xfrm_tmpl *t, struct xfrm_policy *pol);
|
extern int km_query(struct xfrm_state *x, struct xfrm_tmpl *t, struct xfrm_policy *pol);
|
||||||
extern void km_state_expired(struct xfrm_state *x, int hard, u32 pid);
|
extern void km_state_expired(struct xfrm_state *x, int hard, u32 portid);
|
||||||
extern int __xfrm_state_delete(struct xfrm_state *x);
|
extern int __xfrm_state_delete(struct xfrm_state *x);
|
||||||
|
|
||||||
struct xfrm_state_afinfo {
|
struct xfrm_state_afinfo {
|
||||||
@ -1554,7 +1554,7 @@ extern int xfrm_migrate(const struct xfrm_selector *sel, u8 dir, u8 type,
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern int km_new_mapping(struct xfrm_state *x, xfrm_address_t *ipaddr, __be16 sport);
|
extern int km_new_mapping(struct xfrm_state *x, xfrm_address_t *ipaddr, __be16 sport);
|
||||||
extern void km_policy_expired(struct xfrm_policy *pol, int dir, int hard, u32 pid);
|
extern void km_policy_expired(struct xfrm_policy *pol, int dir, int hard, u32 portid);
|
||||||
extern int km_report(struct net *net, u8 proto, struct xfrm_selector *sel, xfrm_address_t *addr);
|
extern int km_report(struct net *net, u8 proto, struct xfrm_selector *sel, xfrm_address_t *addr);
|
||||||
|
|
||||||
extern void xfrm_input_init(void);
|
extern void xfrm_input_init(void);
|
||||||
|
@ -87,11 +87,11 @@ static int audit_failure = AUDIT_FAIL_PRINTK;
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* If audit records are to be written to the netlink socket, audit_pid
|
* If audit records are to be written to the netlink socket, audit_pid
|
||||||
* contains the pid of the auditd process and audit_nlk_pid contains
|
* contains the pid of the auditd process and audit_nlk_portid contains
|
||||||
* the pid to use to send netlink messages to that process.
|
* the portid to use to send netlink messages to that process.
|
||||||
*/
|
*/
|
||||||
int audit_pid;
|
int audit_pid;
|
||||||
static int audit_nlk_pid;
|
static int audit_nlk_portid;
|
||||||
|
|
||||||
/* If audit_rate_limit is non-zero, limit the rate of sending audit records
|
/* If audit_rate_limit is non-zero, limit the rate of sending audit records
|
||||||
* to that number per second. This prevents DoS attacks, but results in
|
* to that number per second. This prevents DoS attacks, but results in
|
||||||
@ -401,7 +401,7 @@ static void kauditd_send_skb(struct sk_buff *skb)
|
|||||||
int err;
|
int err;
|
||||||
/* take a reference in case we can't send it and we want to hold it */
|
/* take a reference in case we can't send it and we want to hold it */
|
||||||
skb_get(skb);
|
skb_get(skb);
|
||||||
err = netlink_unicast(audit_sock, skb, audit_nlk_pid, 0);
|
err = netlink_unicast(audit_sock, skb, audit_nlk_portid, 0);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
BUG_ON(err != -ECONNREFUSED); /* Shouldn't happen */
|
BUG_ON(err != -ECONNREFUSED); /* Shouldn't happen */
|
||||||
printk(KERN_ERR "audit: *NO* daemon at audit_pid=%d\n", audit_pid);
|
printk(KERN_ERR "audit: *NO* daemon at audit_pid=%d\n", audit_pid);
|
||||||
@ -692,7 +692,7 @@ static int audit_receive_msg(struct sk_buff *skb, struct nlmsghdr *nlh)
|
|||||||
status_set.backlog_limit = audit_backlog_limit;
|
status_set.backlog_limit = audit_backlog_limit;
|
||||||
status_set.lost = atomic_read(&audit_lost);
|
status_set.lost = atomic_read(&audit_lost);
|
||||||
status_set.backlog = skb_queue_len(&audit_skb_queue);
|
status_set.backlog = skb_queue_len(&audit_skb_queue);
|
||||||
audit_send_reply(NETLINK_CB(skb).pid, seq, AUDIT_GET, 0, 0,
|
audit_send_reply(NETLINK_CB(skb).portid, seq, AUDIT_GET, 0, 0,
|
||||||
&status_set, sizeof(status_set));
|
&status_set, sizeof(status_set));
|
||||||
break;
|
break;
|
||||||
case AUDIT_SET:
|
case AUDIT_SET:
|
||||||
@ -720,7 +720,7 @@ static int audit_receive_msg(struct sk_buff *skb, struct nlmsghdr *nlh)
|
|||||||
sessionid, sid, 1);
|
sessionid, sid, 1);
|
||||||
|
|
||||||
audit_pid = new_pid;
|
audit_pid = new_pid;
|
||||||
audit_nlk_pid = NETLINK_CB(skb).pid;
|
audit_nlk_portid = NETLINK_CB(skb).portid;
|
||||||
}
|
}
|
||||||
if (status_get->mask & AUDIT_STATUS_RATE_LIMIT) {
|
if (status_get->mask & AUDIT_STATUS_RATE_LIMIT) {
|
||||||
err = audit_set_rate_limit(status_get->rate_limit,
|
err = audit_set_rate_limit(status_get->rate_limit,
|
||||||
@ -782,7 +782,7 @@ static int audit_receive_msg(struct sk_buff *skb, struct nlmsghdr *nlh)
|
|||||||
}
|
}
|
||||||
/* fallthrough */
|
/* fallthrough */
|
||||||
case AUDIT_LIST:
|
case AUDIT_LIST:
|
||||||
err = audit_receive_filter(msg_type, NETLINK_CB(skb).pid,
|
err = audit_receive_filter(msg_type, NETLINK_CB(skb).portid,
|
||||||
uid, seq, data, nlmsg_len(nlh),
|
uid, seq, data, nlmsg_len(nlh),
|
||||||
loginuid, sessionid, sid);
|
loginuid, sessionid, sid);
|
||||||
break;
|
break;
|
||||||
@ -801,7 +801,7 @@ static int audit_receive_msg(struct sk_buff *skb, struct nlmsghdr *nlh)
|
|||||||
}
|
}
|
||||||
/* fallthrough */
|
/* fallthrough */
|
||||||
case AUDIT_LIST_RULES:
|
case AUDIT_LIST_RULES:
|
||||||
err = audit_receive_filter(msg_type, NETLINK_CB(skb).pid,
|
err = audit_receive_filter(msg_type, NETLINK_CB(skb).portid,
|
||||||
uid, seq, data, nlmsg_len(nlh),
|
uid, seq, data, nlmsg_len(nlh),
|
||||||
loginuid, sessionid, sid);
|
loginuid, sessionid, sid);
|
||||||
break;
|
break;
|
||||||
@ -872,7 +872,7 @@ static int audit_receive_msg(struct sk_buff *skb, struct nlmsghdr *nlh)
|
|||||||
memcpy(sig_data->ctx, ctx, len);
|
memcpy(sig_data->ctx, ctx, len);
|
||||||
security_release_secctx(ctx, len);
|
security_release_secctx(ctx, len);
|
||||||
}
|
}
|
||||||
audit_send_reply(NETLINK_CB(skb).pid, seq, AUDIT_SIGNAL_INFO,
|
audit_send_reply(NETLINK_CB(skb).portid, seq, AUDIT_SIGNAL_INFO,
|
||||||
0, 0, sig_data, sizeof(*sig_data) + len);
|
0, 0, sig_data, sizeof(*sig_data) + len);
|
||||||
kfree(sig_data);
|
kfree(sig_data);
|
||||||
break;
|
break;
|
||||||
@ -891,7 +891,7 @@ static int audit_receive_msg(struct sk_buff *skb, struct nlmsghdr *nlh)
|
|||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
|
|
||||||
if (!err)
|
if (!err)
|
||||||
audit_send_reply(NETLINK_CB(skb).pid, seq,
|
audit_send_reply(NETLINK_CB(skb).portid, seq,
|
||||||
AUDIT_TTY_GET, 0, 0, &s, sizeof(s));
|
AUDIT_TTY_GET, 0, 0, &s, sizeof(s));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -467,7 +467,7 @@ static int cmd_attr_register_cpumask(struct genl_info *info)
|
|||||||
rc = parse(info->attrs[TASKSTATS_CMD_ATTR_REGISTER_CPUMASK], mask);
|
rc = parse(info->attrs[TASKSTATS_CMD_ATTR_REGISTER_CPUMASK], mask);
|
||||||
if (rc < 0)
|
if (rc < 0)
|
||||||
goto out;
|
goto out;
|
||||||
rc = add_del_listener(info->snd_pid, mask, REGISTER);
|
rc = add_del_listener(info->snd_portid, mask, REGISTER);
|
||||||
out:
|
out:
|
||||||
free_cpumask_var(mask);
|
free_cpumask_var(mask);
|
||||||
return rc;
|
return rc;
|
||||||
@ -483,7 +483,7 @@ static int cmd_attr_deregister_cpumask(struct genl_info *info)
|
|||||||
rc = parse(info->attrs[TASKSTATS_CMD_ATTR_DEREGISTER_CPUMASK], mask);
|
rc = parse(info->attrs[TASKSTATS_CMD_ATTR_DEREGISTER_CPUMASK], mask);
|
||||||
if (rc < 0)
|
if (rc < 0)
|
||||||
goto out;
|
goto out;
|
||||||
rc = add_del_listener(info->snd_pid, mask, DEREGISTER);
|
rc = add_del_listener(info->snd_portid, mask, DEREGISTER);
|
||||||
out:
|
out:
|
||||||
free_cpumask_var(mask);
|
free_cpumask_var(mask);
|
||||||
return rc;
|
return rc;
|
||||||
|
@ -467,14 +467,14 @@ static int fdb_to_nud(const struct net_bridge_fdb_entry *fdb)
|
|||||||
|
|
||||||
static int fdb_fill_info(struct sk_buff *skb, const struct net_bridge *br,
|
static int fdb_fill_info(struct sk_buff *skb, const struct net_bridge *br,
|
||||||
const struct net_bridge_fdb_entry *fdb,
|
const struct net_bridge_fdb_entry *fdb,
|
||||||
u32 pid, u32 seq, int type, unsigned int flags)
|
u32 portid, u32 seq, int type, unsigned int flags)
|
||||||
{
|
{
|
||||||
unsigned long now = jiffies;
|
unsigned long now = jiffies;
|
||||||
struct nda_cacheinfo ci;
|
struct nda_cacheinfo ci;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct ndmsg *ndm;
|
struct ndmsg *ndm;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, type, sizeof(*ndm), flags);
|
nlh = nlmsg_put(skb, portid, seq, type, sizeof(*ndm), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -555,7 +555,7 @@ int br_fdb_dump(struct sk_buff *skb,
|
|||||||
goto skip;
|
goto skip;
|
||||||
|
|
||||||
if (fdb_fill_info(skb, br, f,
|
if (fdb_fill_info(skb, br, f,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
RTM_NEWNEIGH,
|
RTM_NEWNEIGH,
|
||||||
NLM_F_MULTI) < 0)
|
NLM_F_MULTI) < 0)
|
||||||
|
@ -127,7 +127,7 @@ static int br_dump_ifinfo(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
goto skip;
|
goto skip;
|
||||||
|
|
||||||
if (br_fill_ifinfo(skb, port,
|
if (br_fill_ifinfo(skb, port,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, RTM_NEWLINK,
|
cb->nlh->nlmsg_seq, RTM_NEWLINK,
|
||||||
NLM_F_MULTI) < 0)
|
NLM_F_MULTI) < 0)
|
||||||
break;
|
break;
|
||||||
|
@ -549,7 +549,7 @@ static int cgw_dump_jobs(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (idx < s_idx)
|
if (idx < s_idx)
|
||||||
goto cont;
|
goto cont;
|
||||||
|
|
||||||
if (cgw_put_job(skb, gwj, RTM_NEWROUTE, NETLINK_CB(cb->skb).pid,
|
if (cgw_put_job(skb, gwj, RTM_NEWROUTE, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI) < 0)
|
cb->nlh->nlmsg_seq, NLM_F_MULTI) < 0)
|
||||||
break;
|
break;
|
||||||
cont:
|
cont:
|
||||||
|
@ -402,7 +402,7 @@ static int fib_nl_newrule(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg)
|
|||||||
if (unresolved)
|
if (unresolved)
|
||||||
ops->unresolved_rules++;
|
ops->unresolved_rules++;
|
||||||
|
|
||||||
notify_rule_change(RTM_NEWRULE, rule, ops, nlh, NETLINK_CB(skb).pid);
|
notify_rule_change(RTM_NEWRULE, rule, ops, nlh, NETLINK_CB(skb).portid);
|
||||||
flush_route_cache(ops);
|
flush_route_cache(ops);
|
||||||
rules_ops_put(ops);
|
rules_ops_put(ops);
|
||||||
return 0;
|
return 0;
|
||||||
@ -500,7 +500,7 @@ static int fib_nl_delrule(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
notify_rule_change(RTM_DELRULE, rule, ops, nlh,
|
notify_rule_change(RTM_DELRULE, rule, ops, nlh,
|
||||||
NETLINK_CB(skb).pid);
|
NETLINK_CB(skb).portid);
|
||||||
if (ops->delete)
|
if (ops->delete)
|
||||||
ops->delete(rule);
|
ops->delete(rule);
|
||||||
fib_rule_put(rule);
|
fib_rule_put(rule);
|
||||||
@ -601,7 +601,7 @@ static int dump_rules(struct sk_buff *skb, struct netlink_callback *cb,
|
|||||||
if (idx < cb->args[1])
|
if (idx < cb->args[1])
|
||||||
goto skip;
|
goto skip;
|
||||||
|
|
||||||
if (fib_nl_fill_rule(skb, rule, NETLINK_CB(cb->skb).pid,
|
if (fib_nl_fill_rule(skb, rule, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, RTM_NEWRULE,
|
cb->nlh->nlmsg_seq, RTM_NEWRULE,
|
||||||
NLM_F_MULTI, ops) < 0)
|
NLM_F_MULTI, ops) < 0)
|
||||||
break;
|
break;
|
||||||
|
@ -2102,7 +2102,7 @@ static int neightbl_dump_info(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (tidx < tbl_skip || (family && tbl->family != family))
|
if (tidx < tbl_skip || (family && tbl->family != family))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (neightbl_fill_info(skb, tbl, NETLINK_CB(cb->skb).pid,
|
if (neightbl_fill_info(skb, tbl, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, RTM_NEWNEIGHTBL,
|
cb->nlh->nlmsg_seq, RTM_NEWNEIGHTBL,
|
||||||
NLM_F_MULTI) <= 0)
|
NLM_F_MULTI) <= 0)
|
||||||
break;
|
break;
|
||||||
@ -2115,7 +2115,7 @@ static int neightbl_dump_info(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
goto next;
|
goto next;
|
||||||
|
|
||||||
if (neightbl_fill_param_info(skb, tbl, p,
|
if (neightbl_fill_param_info(skb, tbl, p,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
RTM_NEWNEIGHTBL,
|
RTM_NEWNEIGHTBL,
|
||||||
NLM_F_MULTI) <= 0)
|
NLM_F_MULTI) <= 0)
|
||||||
@ -2244,7 +2244,7 @@ static int neigh_dump_table(struct neigh_table *tbl, struct sk_buff *skb,
|
|||||||
continue;
|
continue;
|
||||||
if (idx < s_idx)
|
if (idx < s_idx)
|
||||||
goto next;
|
goto next;
|
||||||
if (neigh_fill_info(skb, n, NETLINK_CB(cb->skb).pid,
|
if (neigh_fill_info(skb, n, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
RTM_NEWNEIGH,
|
RTM_NEWNEIGH,
|
||||||
NLM_F_MULTI) <= 0) {
|
NLM_F_MULTI) <= 0) {
|
||||||
@ -2281,7 +2281,7 @@ static int pneigh_dump_table(struct neigh_table *tbl, struct sk_buff *skb,
|
|||||||
continue;
|
continue;
|
||||||
if (idx < s_idx)
|
if (idx < s_idx)
|
||||||
goto next;
|
goto next;
|
||||||
if (pneigh_fill_info(skb, n, NETLINK_CB(cb->skb).pid,
|
if (pneigh_fill_info(skb, n, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
RTM_NEWNEIGH,
|
RTM_NEWNEIGH,
|
||||||
NLM_F_MULTI, tbl) <= 0) {
|
NLM_F_MULTI, tbl) <= 0) {
|
||||||
|
@ -1081,7 +1081,7 @@ static int rtnl_dump_ifinfo(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (idx < s_idx)
|
if (idx < s_idx)
|
||||||
goto cont;
|
goto cont;
|
||||||
if (rtnl_fill_ifinfo(skb, dev, RTM_NEWLINK,
|
if (rtnl_fill_ifinfo(skb, dev, RTM_NEWLINK,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, 0,
|
cb->nlh->nlmsg_seq, 0,
|
||||||
NLM_F_MULTI,
|
NLM_F_MULTI,
|
||||||
ext_filter_mask) <= 0)
|
ext_filter_mask) <= 0)
|
||||||
@ -1899,14 +1899,14 @@ static int rtnl_getlink(struct sk_buff *skb, struct nlmsghdr* nlh, void *arg)
|
|||||||
if (nskb == NULL)
|
if (nskb == NULL)
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
|
|
||||||
err = rtnl_fill_ifinfo(nskb, dev, RTM_NEWLINK, NETLINK_CB(skb).pid,
|
err = rtnl_fill_ifinfo(nskb, dev, RTM_NEWLINK, NETLINK_CB(skb).portid,
|
||||||
nlh->nlmsg_seq, 0, 0, ext_filter_mask);
|
nlh->nlmsg_seq, 0, 0, ext_filter_mask);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
/* -EMSGSIZE implies BUG in if_nlmsg_size */
|
/* -EMSGSIZE implies BUG in if_nlmsg_size */
|
||||||
WARN_ON(err == -EMSGSIZE);
|
WARN_ON(err == -EMSGSIZE);
|
||||||
kfree_skb(nskb);
|
kfree_skb(nskb);
|
||||||
} else
|
} else
|
||||||
err = rtnl_unicast(nskb, net, NETLINK_CB(skb).pid);
|
err = rtnl_unicast(nskb, net, NETLINK_CB(skb).portid);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
@ -2180,9 +2180,9 @@ static int nlmsg_populate_fdb(struct sk_buff *skb,
|
|||||||
{
|
{
|
||||||
struct netdev_hw_addr *ha;
|
struct netdev_hw_addr *ha;
|
||||||
int err;
|
int err;
|
||||||
u32 pid, seq;
|
u32 portid, seq;
|
||||||
|
|
||||||
pid = NETLINK_CB(cb->skb).pid;
|
portid = NETLINK_CB(cb->skb).portid;
|
||||||
seq = cb->nlh->nlmsg_seq;
|
seq = cb->nlh->nlmsg_seq;
|
||||||
|
|
||||||
list_for_each_entry(ha, &list->list, list) {
|
list_for_each_entry(ha, &list->list, list) {
|
||||||
@ -2190,7 +2190,7 @@ static int nlmsg_populate_fdb(struct sk_buff *skb,
|
|||||||
goto skip;
|
goto skip;
|
||||||
|
|
||||||
err = nlmsg_populate_fdb_fill(skb, dev, ha->addr,
|
err = nlmsg_populate_fdb_fill(skb, dev, ha->addr,
|
||||||
pid, seq, 0, NTF_SELF);
|
portid, seq, 0, NTF_SELF);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
return err;
|
return err;
|
||||||
skip:
|
skip:
|
||||||
|
@ -1319,7 +1319,7 @@ static int dcbnl_cee_fill(struct sk_buff *skb, struct net_device *netdev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int dcbnl_notify(struct net_device *dev, int event, int cmd,
|
static int dcbnl_notify(struct net_device *dev, int event, int cmd,
|
||||||
u32 seq, u32 pid, int dcbx_ver)
|
u32 seq, u32 portid, int dcbx_ver)
|
||||||
{
|
{
|
||||||
struct net *net = dev_net(dev);
|
struct net *net = dev_net(dev);
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
@ -1330,7 +1330,7 @@ static int dcbnl_notify(struct net_device *dev, int event, int cmd,
|
|||||||
if (!ops)
|
if (!ops)
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
skb = dcbnl_newmsg(event, cmd, pid, seq, 0, &nlh);
|
skb = dcbnl_newmsg(event, cmd, portid, seq, 0, &nlh);
|
||||||
if (!skb)
|
if (!skb)
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
|
|
||||||
@ -1353,16 +1353,16 @@ static int dcbnl_notify(struct net_device *dev, int event, int cmd,
|
|||||||
}
|
}
|
||||||
|
|
||||||
int dcbnl_ieee_notify(struct net_device *dev, int event, int cmd,
|
int dcbnl_ieee_notify(struct net_device *dev, int event, int cmd,
|
||||||
u32 seq, u32 pid)
|
u32 seq, u32 portid)
|
||||||
{
|
{
|
||||||
return dcbnl_notify(dev, event, cmd, seq, pid, DCB_CAP_DCBX_VER_IEEE);
|
return dcbnl_notify(dev, event, cmd, seq, portid, DCB_CAP_DCBX_VER_IEEE);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(dcbnl_ieee_notify);
|
EXPORT_SYMBOL(dcbnl_ieee_notify);
|
||||||
|
|
||||||
int dcbnl_cee_notify(struct net_device *dev, int event, int cmd,
|
int dcbnl_cee_notify(struct net_device *dev, int event, int cmd,
|
||||||
u32 seq, u32 pid)
|
u32 seq, u32 portid)
|
||||||
{
|
{
|
||||||
return dcbnl_notify(dev, event, cmd, seq, pid, DCB_CAP_DCBX_VER_CEE);
|
return dcbnl_notify(dev, event, cmd, seq, portid, DCB_CAP_DCBX_VER_CEE);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(dcbnl_cee_notify);
|
EXPORT_SYMBOL(dcbnl_cee_notify);
|
||||||
|
|
||||||
@ -1656,7 +1656,7 @@ static int dcb_doit(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg)
|
|||||||
struct net_device *netdev;
|
struct net_device *netdev;
|
||||||
struct dcbmsg *dcb = nlmsg_data(nlh);
|
struct dcbmsg *dcb = nlmsg_data(nlh);
|
||||||
struct nlattr *tb[DCB_ATTR_MAX + 1];
|
struct nlattr *tb[DCB_ATTR_MAX + 1];
|
||||||
u32 pid = skb ? NETLINK_CB(skb).pid : 0;
|
u32 portid = skb ? NETLINK_CB(skb).portid : 0;
|
||||||
int ret = -EINVAL;
|
int ret = -EINVAL;
|
||||||
struct sk_buff *reply_skb;
|
struct sk_buff *reply_skb;
|
||||||
struct nlmsghdr *reply_nlh = NULL;
|
struct nlmsghdr *reply_nlh = NULL;
|
||||||
@ -1690,7 +1690,7 @@ static int dcb_doit(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg)
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
reply_skb = dcbnl_newmsg(fn->type, dcb->cmd, pid, nlh->nlmsg_seq,
|
reply_skb = dcbnl_newmsg(fn->type, dcb->cmd, portid, nlh->nlmsg_seq,
|
||||||
nlh->nlmsg_flags, &reply_nlh);
|
nlh->nlmsg_flags, &reply_nlh);
|
||||||
if (!reply_skb) {
|
if (!reply_skb) {
|
||||||
ret = -ENOBUFS;
|
ret = -ENOBUFS;
|
||||||
@ -1705,7 +1705,7 @@ static int dcb_doit(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg)
|
|||||||
|
|
||||||
nlmsg_end(reply_skb, reply_nlh);
|
nlmsg_end(reply_skb, reply_nlh);
|
||||||
|
|
||||||
ret = rtnl_unicast(reply_skb, &init_net, pid);
|
ret = rtnl_unicast(reply_skb, &init_net, portid);
|
||||||
out:
|
out:
|
||||||
dev_put(netdev);
|
dev_put(netdev);
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -667,12 +667,12 @@ static inline size_t dn_ifaddr_nlmsg_size(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int dn_nl_fill_ifaddr(struct sk_buff *skb, struct dn_ifaddr *ifa,
|
static int dn_nl_fill_ifaddr(struct sk_buff *skb, struct dn_ifaddr *ifa,
|
||||||
u32 pid, u32 seq, int event, unsigned int flags)
|
u32 portid, u32 seq, int event, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct ifaddrmsg *ifm;
|
struct ifaddrmsg *ifm;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*ifm), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*ifm), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -753,7 +753,7 @@ static int dn_nl_dump_ifaddr(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (dn_idx < skip_naddr)
|
if (dn_idx < skip_naddr)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (dn_nl_fill_ifaddr(skb, ifa, NETLINK_CB(cb->skb).pid,
|
if (dn_nl_fill_ifaddr(skb, ifa, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, RTM_NEWADDR,
|
cb->nlh->nlmsg_seq, RTM_NEWADDR,
|
||||||
NLM_F_MULTI) < 0)
|
NLM_F_MULTI) < 0)
|
||||||
goto done;
|
goto done;
|
||||||
|
@ -1543,7 +1543,7 @@ static int dn_route_input(struct sk_buff *skb)
|
|||||||
return dn_route_input_slow(skb);
|
return dn_route_input_slow(skb);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int dn_rt_fill_info(struct sk_buff *skb, u32 pid, u32 seq,
|
static int dn_rt_fill_info(struct sk_buff *skb, u32 portid, u32 seq,
|
||||||
int event, int nowait, unsigned int flags)
|
int event, int nowait, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct dn_route *rt = (struct dn_route *)skb_dst(skb);
|
struct dn_route *rt = (struct dn_route *)skb_dst(skb);
|
||||||
@ -1551,7 +1551,7 @@ static int dn_rt_fill_info(struct sk_buff *skb, u32 pid, u32 seq,
|
|||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
long expires;
|
long expires;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*r), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*r), flags);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -1685,7 +1685,7 @@ static int dn_cache_getroute(struct sk_buff *in_skb, struct nlmsghdr *nlh, void
|
|||||||
if (rtm->rtm_flags & RTM_F_NOTIFY)
|
if (rtm->rtm_flags & RTM_F_NOTIFY)
|
||||||
rt->rt_flags |= RTCF_NOTIFY;
|
rt->rt_flags |= RTCF_NOTIFY;
|
||||||
|
|
||||||
err = dn_rt_fill_info(skb, NETLINK_CB(in_skb).pid, nlh->nlmsg_seq, RTM_NEWROUTE, 0, 0);
|
err = dn_rt_fill_info(skb, NETLINK_CB(in_skb).portid, nlh->nlmsg_seq, RTM_NEWROUTE, 0, 0);
|
||||||
|
|
||||||
if (err == 0)
|
if (err == 0)
|
||||||
goto out_free;
|
goto out_free;
|
||||||
@ -1694,7 +1694,7 @@ static int dn_cache_getroute(struct sk_buff *in_skb, struct nlmsghdr *nlh, void
|
|||||||
goto out_free;
|
goto out_free;
|
||||||
}
|
}
|
||||||
|
|
||||||
return rtnl_unicast(skb, &init_net, NETLINK_CB(in_skb).pid);
|
return rtnl_unicast(skb, &init_net, NETLINK_CB(in_skb).portid);
|
||||||
|
|
||||||
out_free:
|
out_free:
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
@ -1737,7 +1737,7 @@ int dn_cache_dump(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (idx < s_idx)
|
if (idx < s_idx)
|
||||||
continue;
|
continue;
|
||||||
skb_dst_set(skb, dst_clone(&rt->dst));
|
skb_dst_set(skb, dst_clone(&rt->dst));
|
||||||
if (dn_rt_fill_info(skb, NETLINK_CB(cb->skb).pid,
|
if (dn_rt_fill_info(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, RTM_NEWROUTE,
|
cb->nlh->nlmsg_seq, RTM_NEWROUTE,
|
||||||
1, NLM_F_MULTI) <= 0) {
|
1, NLM_F_MULTI) <= 0) {
|
||||||
skb_dst_drop(skb);
|
skb_dst_drop(skb);
|
||||||
|
@ -291,14 +291,14 @@ static inline size_t dn_fib_nlmsg_size(struct dn_fib_info *fi)
|
|||||||
return payload;
|
return payload;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int dn_fib_dump_info(struct sk_buff *skb, u32 pid, u32 seq, int event,
|
static int dn_fib_dump_info(struct sk_buff *skb, u32 portid, u32 seq, int event,
|
||||||
u32 tb_id, u8 type, u8 scope, void *dst, int dst_len,
|
u32 tb_id, u8 type, u8 scope, void *dst, int dst_len,
|
||||||
struct dn_fib_info *fi, unsigned int flags)
|
struct dn_fib_info *fi, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct rtmsg *rtm;
|
struct rtmsg *rtm;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*rtm), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*rtm), flags);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -374,14 +374,14 @@ static void dn_rtmsg_fib(int event, struct dn_fib_node *f, int z, u32 tb_id,
|
|||||||
struct nlmsghdr *nlh, struct netlink_skb_parms *req)
|
struct nlmsghdr *nlh, struct netlink_skb_parms *req)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
u32 pid = req ? req->pid : 0;
|
u32 portid = req ? req->portid : 0;
|
||||||
int err = -ENOBUFS;
|
int err = -ENOBUFS;
|
||||||
|
|
||||||
skb = nlmsg_new(dn_fib_nlmsg_size(DN_FIB_INFO(f)), GFP_KERNEL);
|
skb = nlmsg_new(dn_fib_nlmsg_size(DN_FIB_INFO(f)), GFP_KERNEL);
|
||||||
if (skb == NULL)
|
if (skb == NULL)
|
||||||
goto errout;
|
goto errout;
|
||||||
|
|
||||||
err = dn_fib_dump_info(skb, pid, nlh->nlmsg_seq, event, tb_id,
|
err = dn_fib_dump_info(skb, portid, nlh->nlmsg_seq, event, tb_id,
|
||||||
f->fn_type, f->fn_scope, &f->fn_key, z,
|
f->fn_type, f->fn_scope, &f->fn_key, z,
|
||||||
DN_FIB_INFO(f), 0);
|
DN_FIB_INFO(f), 0);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
@ -390,7 +390,7 @@ static void dn_rtmsg_fib(int event, struct dn_fib_node *f, int z, u32 tb_id,
|
|||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
goto errout;
|
goto errout;
|
||||||
}
|
}
|
||||||
rtnl_notify(skb, &init_net, pid, RTNLGRP_DECnet_ROUTE, nlh, GFP_KERNEL);
|
rtnl_notify(skb, &init_net, portid, RTNLGRP_DECnet_ROUTE, nlh, GFP_KERNEL);
|
||||||
return;
|
return;
|
||||||
errout:
|
errout:
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
@ -411,7 +411,7 @@ static __inline__ int dn_hash_dump_bucket(struct sk_buff *skb,
|
|||||||
continue;
|
continue;
|
||||||
if (f->fn_state & DN_S_ZOMBIE)
|
if (f->fn_state & DN_S_ZOMBIE)
|
||||||
continue;
|
continue;
|
||||||
if (dn_fib_dump_info(skb, NETLINK_CB(cb->skb).pid,
|
if (dn_fib_dump_info(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
RTM_NEWROUTE,
|
RTM_NEWROUTE,
|
||||||
tb->n,
|
tb->n,
|
||||||
|
@ -246,7 +246,7 @@ int ieee802154_nl_start_confirm(struct net_device *dev, u8 status)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(ieee802154_nl_start_confirm);
|
EXPORT_SYMBOL(ieee802154_nl_start_confirm);
|
||||||
|
|
||||||
static int ieee802154_nl_fill_iface(struct sk_buff *msg, u32 pid,
|
static int ieee802154_nl_fill_iface(struct sk_buff *msg, u32 portid,
|
||||||
u32 seq, int flags, struct net_device *dev)
|
u32 seq, int flags, struct net_device *dev)
|
||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
@ -534,7 +534,7 @@ static int ieee802154_list_iface(struct sk_buff *skb,
|
|||||||
if (!msg)
|
if (!msg)
|
||||||
goto out_dev;
|
goto out_dev;
|
||||||
|
|
||||||
rc = ieee802154_nl_fill_iface(msg, info->snd_pid, info->snd_seq,
|
rc = ieee802154_nl_fill_iface(msg, info->snd_portid, info->snd_seq,
|
||||||
0, dev);
|
0, dev);
|
||||||
if (rc < 0)
|
if (rc < 0)
|
||||||
goto out_free;
|
goto out_free;
|
||||||
@ -565,7 +565,7 @@ static int ieee802154_dump_iface(struct sk_buff *skb,
|
|||||||
if (idx < s_idx || (dev->type != ARPHRD_IEEE802154))
|
if (idx < s_idx || (dev->type != ARPHRD_IEEE802154))
|
||||||
goto cont;
|
goto cont;
|
||||||
|
|
||||||
if (ieee802154_nl_fill_iface(skb, NETLINK_CB(cb->skb).pid,
|
if (ieee802154_nl_fill_iface(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI, dev) < 0)
|
cb->nlh->nlmsg_seq, NLM_F_MULTI, dev) < 0)
|
||||||
break;
|
break;
|
||||||
cont:
|
cont:
|
||||||
|
@ -35,7 +35,7 @@
|
|||||||
|
|
||||||
#include "ieee802154.h"
|
#include "ieee802154.h"
|
||||||
|
|
||||||
static int ieee802154_nl_fill_phy(struct sk_buff *msg, u32 pid,
|
static int ieee802154_nl_fill_phy(struct sk_buff *msg, u32 portid,
|
||||||
u32 seq, int flags, struct wpan_phy *phy)
|
u32 seq, int flags, struct wpan_phy *phy)
|
||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
@ -105,7 +105,7 @@ static int ieee802154_list_phy(struct sk_buff *skb,
|
|||||||
if (!msg)
|
if (!msg)
|
||||||
goto out_dev;
|
goto out_dev;
|
||||||
|
|
||||||
rc = ieee802154_nl_fill_phy(msg, info->snd_pid, info->snd_seq,
|
rc = ieee802154_nl_fill_phy(msg, info->snd_portid, info->snd_seq,
|
||||||
0, phy);
|
0, phy);
|
||||||
if (rc < 0)
|
if (rc < 0)
|
||||||
goto out_free;
|
goto out_free;
|
||||||
@ -138,7 +138,7 @@ static int ieee802154_dump_phy_iter(struct wpan_phy *phy, void *_data)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
rc = ieee802154_nl_fill_phy(data->skb,
|
rc = ieee802154_nl_fill_phy(data->skb,
|
||||||
NETLINK_CB(data->cb->skb).pid,
|
NETLINK_CB(data->cb->skb).portid,
|
||||||
data->cb->nlh->nlmsg_seq,
|
data->cb->nlh->nlmsg_seq,
|
||||||
NLM_F_MULTI,
|
NLM_F_MULTI,
|
||||||
phy);
|
phy);
|
||||||
|
@ -311,7 +311,7 @@ int inet_addr_onlink(struct in_device *in_dev, __be32 a, __be32 b)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void __inet_del_ifa(struct in_device *in_dev, struct in_ifaddr **ifap,
|
static void __inet_del_ifa(struct in_device *in_dev, struct in_ifaddr **ifap,
|
||||||
int destroy, struct nlmsghdr *nlh, u32 pid)
|
int destroy, struct nlmsghdr *nlh, u32 portid)
|
||||||
{
|
{
|
||||||
struct in_ifaddr *promote = NULL;
|
struct in_ifaddr *promote = NULL;
|
||||||
struct in_ifaddr *ifa, *ifa1 = *ifap;
|
struct in_ifaddr *ifa, *ifa1 = *ifap;
|
||||||
@ -345,7 +345,7 @@ static void __inet_del_ifa(struct in_device *in_dev, struct in_ifaddr **ifap,
|
|||||||
inet_hash_remove(ifa);
|
inet_hash_remove(ifa);
|
||||||
*ifap1 = ifa->ifa_next;
|
*ifap1 = ifa->ifa_next;
|
||||||
|
|
||||||
rtmsg_ifa(RTM_DELADDR, ifa, nlh, pid);
|
rtmsg_ifa(RTM_DELADDR, ifa, nlh, portid);
|
||||||
blocking_notifier_call_chain(&inetaddr_chain,
|
blocking_notifier_call_chain(&inetaddr_chain,
|
||||||
NETDEV_DOWN, ifa);
|
NETDEV_DOWN, ifa);
|
||||||
inet_free_ifa(ifa);
|
inet_free_ifa(ifa);
|
||||||
@ -382,7 +382,7 @@ static void __inet_del_ifa(struct in_device *in_dev, struct in_ifaddr **ifap,
|
|||||||
is valid, it will try to restore deleted routes... Grr.
|
is valid, it will try to restore deleted routes... Grr.
|
||||||
So that, this order is correct.
|
So that, this order is correct.
|
||||||
*/
|
*/
|
||||||
rtmsg_ifa(RTM_DELADDR, ifa1, nlh, pid);
|
rtmsg_ifa(RTM_DELADDR, ifa1, nlh, portid);
|
||||||
blocking_notifier_call_chain(&inetaddr_chain, NETDEV_DOWN, ifa1);
|
blocking_notifier_call_chain(&inetaddr_chain, NETDEV_DOWN, ifa1);
|
||||||
|
|
||||||
if (promote) {
|
if (promote) {
|
||||||
@ -395,7 +395,7 @@ static void __inet_del_ifa(struct in_device *in_dev, struct in_ifaddr **ifap,
|
|||||||
}
|
}
|
||||||
|
|
||||||
promote->ifa_flags &= ~IFA_F_SECONDARY;
|
promote->ifa_flags &= ~IFA_F_SECONDARY;
|
||||||
rtmsg_ifa(RTM_NEWADDR, promote, nlh, pid);
|
rtmsg_ifa(RTM_NEWADDR, promote, nlh, portid);
|
||||||
blocking_notifier_call_chain(&inetaddr_chain,
|
blocking_notifier_call_chain(&inetaddr_chain,
|
||||||
NETDEV_UP, promote);
|
NETDEV_UP, promote);
|
||||||
for (ifa = next_sec; ifa; ifa = ifa->ifa_next) {
|
for (ifa = next_sec; ifa; ifa = ifa->ifa_next) {
|
||||||
@ -417,7 +417,7 @@ static void inet_del_ifa(struct in_device *in_dev, struct in_ifaddr **ifap,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int __inet_insert_ifa(struct in_ifaddr *ifa, struct nlmsghdr *nlh,
|
static int __inet_insert_ifa(struct in_ifaddr *ifa, struct nlmsghdr *nlh,
|
||||||
u32 pid)
|
u32 portid)
|
||||||
{
|
{
|
||||||
struct in_device *in_dev = ifa->ifa_dev;
|
struct in_device *in_dev = ifa->ifa_dev;
|
||||||
struct in_ifaddr *ifa1, **ifap, **last_primary;
|
struct in_ifaddr *ifa1, **ifap, **last_primary;
|
||||||
@ -464,7 +464,7 @@ static int __inet_insert_ifa(struct in_ifaddr *ifa, struct nlmsghdr *nlh,
|
|||||||
/* Send message first, then call notifier.
|
/* Send message first, then call notifier.
|
||||||
Notifier will trigger FIB update, so that
|
Notifier will trigger FIB update, so that
|
||||||
listeners of netlink will know about new ifaddr */
|
listeners of netlink will know about new ifaddr */
|
||||||
rtmsg_ifa(RTM_NEWADDR, ifa, nlh, pid);
|
rtmsg_ifa(RTM_NEWADDR, ifa, nlh, portid);
|
||||||
blocking_notifier_call_chain(&inetaddr_chain, NETDEV_UP, ifa);
|
blocking_notifier_call_chain(&inetaddr_chain, NETDEV_UP, ifa);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
@ -563,7 +563,7 @@ static int inet_rtm_deladdr(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg
|
|||||||
!inet_ifa_match(nla_get_be32(tb[IFA_ADDRESS]), ifa)))
|
!inet_ifa_match(nla_get_be32(tb[IFA_ADDRESS]), ifa)))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
__inet_del_ifa(in_dev, ifap, 1, nlh, NETLINK_CB(skb).pid);
|
__inet_del_ifa(in_dev, ifap, 1, nlh, NETLINK_CB(skb).portid);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -649,7 +649,7 @@ static int inet_rtm_newaddr(struct sk_buff *skb, struct nlmsghdr *nlh, void *arg
|
|||||||
if (IS_ERR(ifa))
|
if (IS_ERR(ifa))
|
||||||
return PTR_ERR(ifa);
|
return PTR_ERR(ifa);
|
||||||
|
|
||||||
return __inet_insert_ifa(ifa, nlh, NETLINK_CB(skb).pid);
|
return __inet_insert_ifa(ifa, nlh, NETLINK_CB(skb).portid);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1246,12 +1246,12 @@ static size_t inet_nlmsg_size(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int inet_fill_ifaddr(struct sk_buff *skb, struct in_ifaddr *ifa,
|
static int inet_fill_ifaddr(struct sk_buff *skb, struct in_ifaddr *ifa,
|
||||||
u32 pid, u32 seq, int event, unsigned int flags)
|
u32 portid, u32 seq, int event, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct ifaddrmsg *ifm;
|
struct ifaddrmsg *ifm;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*ifm), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*ifm), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -1313,7 +1313,7 @@ static int inet_dump_ifaddr(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (ip_idx < s_ip_idx)
|
if (ip_idx < s_ip_idx)
|
||||||
continue;
|
continue;
|
||||||
if (inet_fill_ifaddr(skb, ifa,
|
if (inet_fill_ifaddr(skb, ifa,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
RTM_NEWADDR, NLM_F_MULTI) <= 0) {
|
RTM_NEWADDR, NLM_F_MULTI) <= 0) {
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
@ -1335,7 +1335,7 @@ static int inet_dump_ifaddr(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void rtmsg_ifa(int event, struct in_ifaddr *ifa, struct nlmsghdr *nlh,
|
static void rtmsg_ifa(int event, struct in_ifaddr *ifa, struct nlmsghdr *nlh,
|
||||||
u32 pid)
|
u32 portid)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
u32 seq = nlh ? nlh->nlmsg_seq : 0;
|
u32 seq = nlh ? nlh->nlmsg_seq : 0;
|
||||||
@ -1347,14 +1347,14 @@ static void rtmsg_ifa(int event, struct in_ifaddr *ifa, struct nlmsghdr *nlh,
|
|||||||
if (skb == NULL)
|
if (skb == NULL)
|
||||||
goto errout;
|
goto errout;
|
||||||
|
|
||||||
err = inet_fill_ifaddr(skb, ifa, pid, seq, event, 0);
|
err = inet_fill_ifaddr(skb, ifa, portid, seq, event, 0);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
/* -EMSGSIZE implies BUG in inet_nlmsg_size() */
|
/* -EMSGSIZE implies BUG in inet_nlmsg_size() */
|
||||||
WARN_ON(err == -EMSGSIZE);
|
WARN_ON(err == -EMSGSIZE);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
goto errout;
|
goto errout;
|
||||||
}
|
}
|
||||||
rtnl_notify(skb, net, pid, RTNLGRP_IPV4_IFADDR, nlh, GFP_KERNEL);
|
rtnl_notify(skb, net, portid, RTNLGRP_IPV4_IFADDR, nlh, GFP_KERNEL);
|
||||||
return;
|
return;
|
||||||
errout:
|
errout:
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
|
@ -557,7 +557,7 @@ static int rtm_to_fib_config(struct net *net, struct sk_buff *skb,
|
|||||||
cfg->fc_flags = rtm->rtm_flags;
|
cfg->fc_flags = rtm->rtm_flags;
|
||||||
cfg->fc_nlflags = nlh->nlmsg_flags;
|
cfg->fc_nlflags = nlh->nlmsg_flags;
|
||||||
|
|
||||||
cfg->fc_nlinfo.pid = NETLINK_CB(skb).pid;
|
cfg->fc_nlinfo.portid = NETLINK_CB(skb).portid;
|
||||||
cfg->fc_nlinfo.nlh = nlh;
|
cfg->fc_nlinfo.nlh = nlh;
|
||||||
cfg->fc_nlinfo.nl_net = net;
|
cfg->fc_nlinfo.nl_net = net;
|
||||||
|
|
||||||
@ -955,7 +955,7 @@ static void nl_fib_input(struct sk_buff *skb)
|
|||||||
struct fib_result_nl *frn;
|
struct fib_result_nl *frn;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct fib_table *tb;
|
struct fib_table *tb;
|
||||||
u32 pid;
|
u32 portid;
|
||||||
|
|
||||||
net = sock_net(skb->sk);
|
net = sock_net(skb->sk);
|
||||||
nlh = nlmsg_hdr(skb);
|
nlh = nlmsg_hdr(skb);
|
||||||
@ -973,10 +973,10 @@ static void nl_fib_input(struct sk_buff *skb)
|
|||||||
|
|
||||||
nl_fib_lookup(frn, tb);
|
nl_fib_lookup(frn, tb);
|
||||||
|
|
||||||
pid = NETLINK_CB(skb).pid; /* pid of sending process */
|
portid = NETLINK_CB(skb).portid; /* pid of sending process */
|
||||||
NETLINK_CB(skb).pid = 0; /* from kernel */
|
NETLINK_CB(skb).portid = 0; /* from kernel */
|
||||||
NETLINK_CB(skb).dst_group = 0; /* unicast */
|
NETLINK_CB(skb).dst_group = 0; /* unicast */
|
||||||
netlink_unicast(net->ipv4.fibnl, skb, pid, MSG_DONTWAIT);
|
netlink_unicast(net->ipv4.fibnl, skb, portid, MSG_DONTWAIT);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __net_init nl_fib_lookup_init(struct net *net)
|
static int __net_init nl_fib_lookup_init(struct net *net)
|
||||||
|
@ -391,7 +391,7 @@ void rtmsg_fib(int event, __be32 key, struct fib_alias *fa,
|
|||||||
if (skb == NULL)
|
if (skb == NULL)
|
||||||
goto errout;
|
goto errout;
|
||||||
|
|
||||||
err = fib_dump_info(skb, info->pid, seq, event, tb_id,
|
err = fib_dump_info(skb, info->portid, seq, event, tb_id,
|
||||||
fa->fa_type, key, dst_len,
|
fa->fa_type, key, dst_len,
|
||||||
fa->fa_tos, fa->fa_info, nlm_flags);
|
fa->fa_tos, fa->fa_info, nlm_flags);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
@ -400,7 +400,7 @@ void rtmsg_fib(int event, __be32 key, struct fib_alias *fa,
|
|||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
goto errout;
|
goto errout;
|
||||||
}
|
}
|
||||||
rtnl_notify(skb, info->nl_net, info->pid, RTNLGRP_IPV4_ROUTE,
|
rtnl_notify(skb, info->nl_net, info->portid, RTNLGRP_IPV4_ROUTE,
|
||||||
info->nlh, GFP_KERNEL);
|
info->nlh, GFP_KERNEL);
|
||||||
return;
|
return;
|
||||||
errout:
|
errout:
|
||||||
@ -989,14 +989,14 @@ struct fib_info *fib_create_info(struct fib_config *cfg)
|
|||||||
return ERR_PTR(err);
|
return ERR_PTR(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
int fib_dump_info(struct sk_buff *skb, u32 pid, u32 seq, int event,
|
int fib_dump_info(struct sk_buff *skb, u32 portid, u32 seq, int event,
|
||||||
u32 tb_id, u8 type, __be32 dst, int dst_len, u8 tos,
|
u32 tb_id, u8 type, __be32 dst, int dst_len, u8 tos,
|
||||||
struct fib_info *fi, unsigned int flags)
|
struct fib_info *fi, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct rtmsg *rtm;
|
struct rtmsg *rtm;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*rtm), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*rtm), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
|
@ -1873,7 +1873,7 @@ static int fn_trie_dump_fa(t_key key, int plen, struct list_head *fah,
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fib_dump_info(skb, NETLINK_CB(cb->skb).pid,
|
if (fib_dump_info(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
RTM_NEWROUTE,
|
RTM_NEWROUTE,
|
||||||
tb->tb_id,
|
tb->tb_id,
|
||||||
|
@ -70,7 +70,7 @@ static inline void inet_diag_unlock_handler(
|
|||||||
int inet_sk_diag_fill(struct sock *sk, struct inet_connection_sock *icsk,
|
int inet_sk_diag_fill(struct sock *sk, struct inet_connection_sock *icsk,
|
||||||
struct sk_buff *skb, struct inet_diag_req_v2 *req,
|
struct sk_buff *skb, struct inet_diag_req_v2 *req,
|
||||||
struct user_namespace *user_ns,
|
struct user_namespace *user_ns,
|
||||||
u32 pid, u32 seq, u16 nlmsg_flags,
|
u32 portid, u32 seq, u16 nlmsg_flags,
|
||||||
const struct nlmsghdr *unlh)
|
const struct nlmsghdr *unlh)
|
||||||
{
|
{
|
||||||
const struct inet_sock *inet = inet_sk(sk);
|
const struct inet_sock *inet = inet_sk(sk);
|
||||||
@ -84,7 +84,7 @@ int inet_sk_diag_fill(struct sock *sk, struct inet_connection_sock *icsk,
|
|||||||
handler = inet_diag_table[req->sdiag_protocol];
|
handler = inet_diag_table[req->sdiag_protocol];
|
||||||
BUG_ON(handler == NULL);
|
BUG_ON(handler == NULL);
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, unlh->nlmsg_type, sizeof(*r),
|
nlh = nlmsg_put(skb, portid, seq, unlh->nlmsg_type, sizeof(*r),
|
||||||
nlmsg_flags);
|
nlmsg_flags);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
@ -201,23 +201,23 @@ EXPORT_SYMBOL_GPL(inet_sk_diag_fill);
|
|||||||
static int inet_csk_diag_fill(struct sock *sk,
|
static int inet_csk_diag_fill(struct sock *sk,
|
||||||
struct sk_buff *skb, struct inet_diag_req_v2 *req,
|
struct sk_buff *skb, struct inet_diag_req_v2 *req,
|
||||||
struct user_namespace *user_ns,
|
struct user_namespace *user_ns,
|
||||||
u32 pid, u32 seq, u16 nlmsg_flags,
|
u32 portid, u32 seq, u16 nlmsg_flags,
|
||||||
const struct nlmsghdr *unlh)
|
const struct nlmsghdr *unlh)
|
||||||
{
|
{
|
||||||
return inet_sk_diag_fill(sk, inet_csk(sk),
|
return inet_sk_diag_fill(sk, inet_csk(sk),
|
||||||
skb, req, user_ns, pid, seq, nlmsg_flags, unlh);
|
skb, req, user_ns, portid, seq, nlmsg_flags, unlh);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int inet_twsk_diag_fill(struct inet_timewait_sock *tw,
|
static int inet_twsk_diag_fill(struct inet_timewait_sock *tw,
|
||||||
struct sk_buff *skb, struct inet_diag_req_v2 *req,
|
struct sk_buff *skb, struct inet_diag_req_v2 *req,
|
||||||
u32 pid, u32 seq, u16 nlmsg_flags,
|
u32 portid, u32 seq, u16 nlmsg_flags,
|
||||||
const struct nlmsghdr *unlh)
|
const struct nlmsghdr *unlh)
|
||||||
{
|
{
|
||||||
long tmo;
|
long tmo;
|
||||||
struct inet_diag_msg *r;
|
struct inet_diag_msg *r;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, unlh->nlmsg_type, sizeof(*r),
|
nlh = nlmsg_put(skb, portid, seq, unlh->nlmsg_type, sizeof(*r),
|
||||||
nlmsg_flags);
|
nlmsg_flags);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
@ -260,14 +260,14 @@ static int inet_twsk_diag_fill(struct inet_timewait_sock *tw,
|
|||||||
static int sk_diag_fill(struct sock *sk, struct sk_buff *skb,
|
static int sk_diag_fill(struct sock *sk, struct sk_buff *skb,
|
||||||
struct inet_diag_req_v2 *r,
|
struct inet_diag_req_v2 *r,
|
||||||
struct user_namespace *user_ns,
|
struct user_namespace *user_ns,
|
||||||
u32 pid, u32 seq, u16 nlmsg_flags,
|
u32 portid, u32 seq, u16 nlmsg_flags,
|
||||||
const struct nlmsghdr *unlh)
|
const struct nlmsghdr *unlh)
|
||||||
{
|
{
|
||||||
if (sk->sk_state == TCP_TIME_WAIT)
|
if (sk->sk_state == TCP_TIME_WAIT)
|
||||||
return inet_twsk_diag_fill((struct inet_timewait_sock *)sk,
|
return inet_twsk_diag_fill((struct inet_timewait_sock *)sk,
|
||||||
skb, r, pid, seq, nlmsg_flags,
|
skb, r, portid, seq, nlmsg_flags,
|
||||||
unlh);
|
unlh);
|
||||||
return inet_csk_diag_fill(sk, skb, r, user_ns, pid, seq, nlmsg_flags, unlh);
|
return inet_csk_diag_fill(sk, skb, r, user_ns, portid, seq, nlmsg_flags, unlh);
|
||||||
}
|
}
|
||||||
|
|
||||||
int inet_diag_dump_one_icsk(struct inet_hashinfo *hashinfo, struct sk_buff *in_skb,
|
int inet_diag_dump_one_icsk(struct inet_hashinfo *hashinfo, struct sk_buff *in_skb,
|
||||||
@ -316,14 +316,14 @@ int inet_diag_dump_one_icsk(struct inet_hashinfo *hashinfo, struct sk_buff *in_s
|
|||||||
|
|
||||||
err = sk_diag_fill(sk, rep, req,
|
err = sk_diag_fill(sk, rep, req,
|
||||||
sk_user_ns(NETLINK_CB(in_skb).ssk),
|
sk_user_ns(NETLINK_CB(in_skb).ssk),
|
||||||
NETLINK_CB(in_skb).pid,
|
NETLINK_CB(in_skb).portid,
|
||||||
nlh->nlmsg_seq, 0, nlh);
|
nlh->nlmsg_seq, 0, nlh);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
WARN_ON(err == -EMSGSIZE);
|
WARN_ON(err == -EMSGSIZE);
|
||||||
nlmsg_free(rep);
|
nlmsg_free(rep);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
err = netlink_unicast(net->diag_nlsk, rep, NETLINK_CB(in_skb).pid,
|
err = netlink_unicast(net->diag_nlsk, rep, NETLINK_CB(in_skb).portid,
|
||||||
MSG_DONTWAIT);
|
MSG_DONTWAIT);
|
||||||
if (err > 0)
|
if (err > 0)
|
||||||
err = 0;
|
err = 0;
|
||||||
@ -557,7 +557,7 @@ static int inet_csk_diag_dump(struct sock *sk,
|
|||||||
|
|
||||||
return inet_csk_diag_fill(sk, skb, r,
|
return inet_csk_diag_fill(sk, skb, r,
|
||||||
sk_user_ns(NETLINK_CB(cb->skb).ssk),
|
sk_user_ns(NETLINK_CB(cb->skb).ssk),
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI, cb->nlh);
|
cb->nlh->nlmsg_seq, NLM_F_MULTI, cb->nlh);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -592,14 +592,14 @@ static int inet_twsk_diag_dump(struct inet_timewait_sock *tw,
|
|||||||
}
|
}
|
||||||
|
|
||||||
return inet_twsk_diag_fill(tw, skb, r,
|
return inet_twsk_diag_fill(tw, skb, r,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI, cb->nlh);
|
cb->nlh->nlmsg_seq, NLM_F_MULTI, cb->nlh);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int inet_diag_fill_req(struct sk_buff *skb, struct sock *sk,
|
static int inet_diag_fill_req(struct sk_buff *skb, struct sock *sk,
|
||||||
struct request_sock *req,
|
struct request_sock *req,
|
||||||
struct user_namespace *user_ns,
|
struct user_namespace *user_ns,
|
||||||
u32 pid, u32 seq,
|
u32 portid, u32 seq,
|
||||||
const struct nlmsghdr *unlh)
|
const struct nlmsghdr *unlh)
|
||||||
{
|
{
|
||||||
const struct inet_request_sock *ireq = inet_rsk(req);
|
const struct inet_request_sock *ireq = inet_rsk(req);
|
||||||
@ -608,7 +608,7 @@ static int inet_diag_fill_req(struct sk_buff *skb, struct sock *sk,
|
|||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
long tmo;
|
long tmo;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, unlh->nlmsg_type, sizeof(*r),
|
nlh = nlmsg_put(skb, portid, seq, unlh->nlmsg_type, sizeof(*r),
|
||||||
NLM_F_MULTI);
|
NLM_F_MULTI);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
@ -711,7 +711,7 @@ static int inet_diag_dump_reqs(struct sk_buff *skb, struct sock *sk,
|
|||||||
|
|
||||||
err = inet_diag_fill_req(skb, sk, req,
|
err = inet_diag_fill_req(skb, sk, req,
|
||||||
sk_user_ns(NETLINK_CB(cb->skb).ssk),
|
sk_user_ns(NETLINK_CB(cb->skb).ssk),
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, cb->nlh);
|
cb->nlh->nlmsg_seq, cb->nlh);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
cb->args[3] = j + 1;
|
cb->args[3] = j + 1;
|
||||||
|
@ -626,7 +626,7 @@ static void ipmr_destroy_unres(struct mr_table *mrt, struct mfc_cache *c)
|
|||||||
e->error = -ETIMEDOUT;
|
e->error = -ETIMEDOUT;
|
||||||
memset(&e->msg, 0, sizeof(e->msg));
|
memset(&e->msg, 0, sizeof(e->msg));
|
||||||
|
|
||||||
rtnl_unicast(skb, net, NETLINK_CB(skb).pid);
|
rtnl_unicast(skb, net, NETLINK_CB(skb).portid);
|
||||||
} else {
|
} else {
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
}
|
}
|
||||||
@ -870,7 +870,7 @@ static void ipmr_cache_resolve(struct net *net, struct mr_table *mrt,
|
|||||||
memset(&e->msg, 0, sizeof(e->msg));
|
memset(&e->msg, 0, sizeof(e->msg));
|
||||||
}
|
}
|
||||||
|
|
||||||
rtnl_unicast(skb, net, NETLINK_CB(skb).pid);
|
rtnl_unicast(skb, net, NETLINK_CB(skb).portid);
|
||||||
} else {
|
} else {
|
||||||
ip_mr_forward(net, mrt, skb, c, 0);
|
ip_mr_forward(net, mrt, skb, c, 0);
|
||||||
}
|
}
|
||||||
@ -2117,12 +2117,12 @@ int ipmr_get_route(struct net *net, struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int ipmr_fill_mroute(struct mr_table *mrt, struct sk_buff *skb,
|
static int ipmr_fill_mroute(struct mr_table *mrt, struct sk_buff *skb,
|
||||||
u32 pid, u32 seq, struct mfc_cache *c)
|
u32 portid, u32 seq, struct mfc_cache *c)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct rtmsg *rtm;
|
struct rtmsg *rtm;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, RTM_NEWROUTE, sizeof(*rtm), NLM_F_MULTI);
|
nlh = nlmsg_put(skb, portid, seq, RTM_NEWROUTE, sizeof(*rtm), NLM_F_MULTI);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -2176,7 +2176,7 @@ static int ipmr_rtm_dumproute(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (e < s_e)
|
if (e < s_e)
|
||||||
goto next_entry;
|
goto next_entry;
|
||||||
if (ipmr_fill_mroute(mrt, skb,
|
if (ipmr_fill_mroute(mrt, skb,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
mfc) < 0)
|
mfc) < 0)
|
||||||
goto done;
|
goto done;
|
||||||
|
@ -2136,7 +2136,7 @@ struct rtable *ip_route_output_flow(struct net *net, struct flowi4 *flp4,
|
|||||||
EXPORT_SYMBOL_GPL(ip_route_output_flow);
|
EXPORT_SYMBOL_GPL(ip_route_output_flow);
|
||||||
|
|
||||||
static int rt_fill_info(struct net *net, __be32 dst, __be32 src,
|
static int rt_fill_info(struct net *net, __be32 dst, __be32 src,
|
||||||
struct flowi4 *fl4, struct sk_buff *skb, u32 pid,
|
struct flowi4 *fl4, struct sk_buff *skb, u32 portid,
|
||||||
u32 seq, int event, int nowait, unsigned int flags)
|
u32 seq, int event, int nowait, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct rtable *rt = skb_rtable(skb);
|
struct rtable *rt = skb_rtable(skb);
|
||||||
@ -2146,7 +2146,7 @@ static int rt_fill_info(struct net *net, __be32 dst, __be32 src,
|
|||||||
u32 error;
|
u32 error;
|
||||||
u32 metrics[RTAX_MAX];
|
u32 metrics[RTAX_MAX];
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*r), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*r), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -2306,12 +2306,12 @@ static int inet_rtm_getroute(struct sk_buff *in_skb, struct nlmsghdr *nlh, void
|
|||||||
rt->rt_flags |= RTCF_NOTIFY;
|
rt->rt_flags |= RTCF_NOTIFY;
|
||||||
|
|
||||||
err = rt_fill_info(net, dst, src, &fl4, skb,
|
err = rt_fill_info(net, dst, src, &fl4, skb,
|
||||||
NETLINK_CB(in_skb).pid, nlh->nlmsg_seq,
|
NETLINK_CB(in_skb).portid, nlh->nlmsg_seq,
|
||||||
RTM_NEWROUTE, 0, 0);
|
RTM_NEWROUTE, 0, 0);
|
||||||
if (err <= 0)
|
if (err <= 0)
|
||||||
goto errout_free;
|
goto errout_free;
|
||||||
|
|
||||||
err = rtnl_unicast(skb, net, NETLINK_CB(in_skb).pid);
|
err = rtnl_unicast(skb, net, NETLINK_CB(in_skb).portid);
|
||||||
errout:
|
errout:
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
|
@ -803,7 +803,7 @@ static int tcp_metrics_dump_info(struct sk_buff *skb,
|
|||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
|
|
||||||
hdr = genlmsg_put(skb, NETLINK_CB(cb->skb).pid, cb->nlh->nlmsg_seq,
|
hdr = genlmsg_put(skb, NETLINK_CB(cb->skb).portid, cb->nlh->nlmsg_seq,
|
||||||
&tcp_metrics_nl_family, NLM_F_MULTI,
|
&tcp_metrics_nl_family, NLM_F_MULTI,
|
||||||
TCP_METRICS_CMD_GET);
|
TCP_METRICS_CMD_GET);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
|
@ -26,7 +26,7 @@ static int sk_diag_dump(struct sock *sk, struct sk_buff *skb,
|
|||||||
|
|
||||||
return inet_sk_diag_fill(sk, NULL, skb, req,
|
return inet_sk_diag_fill(sk, NULL, skb, req,
|
||||||
sk_user_ns(NETLINK_CB(cb->skb).ssk),
|
sk_user_ns(NETLINK_CB(cb->skb).ssk),
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI, cb->nlh);
|
cb->nlh->nlmsg_seq, NLM_F_MULTI, cb->nlh);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -72,14 +72,14 @@ static int udp_dump_one(struct udp_table *tbl, struct sk_buff *in_skb,
|
|||||||
|
|
||||||
err = inet_sk_diag_fill(sk, NULL, rep, req,
|
err = inet_sk_diag_fill(sk, NULL, rep, req,
|
||||||
sk_user_ns(NETLINK_CB(in_skb).ssk),
|
sk_user_ns(NETLINK_CB(in_skb).ssk),
|
||||||
NETLINK_CB(in_skb).pid,
|
NETLINK_CB(in_skb).portid,
|
||||||
nlh->nlmsg_seq, 0, nlh);
|
nlh->nlmsg_seq, 0, nlh);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
WARN_ON(err == -EMSGSIZE);
|
WARN_ON(err == -EMSGSIZE);
|
||||||
kfree_skb(rep);
|
kfree_skb(rep);
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
err = netlink_unicast(net->diag_nlsk, rep, NETLINK_CB(in_skb).pid,
|
err = netlink_unicast(net->diag_nlsk, rep, NETLINK_CB(in_skb).portid,
|
||||||
MSG_DONTWAIT);
|
MSG_DONTWAIT);
|
||||||
if (err > 0)
|
if (err > 0)
|
||||||
err = 0;
|
err = 0;
|
||||||
|
@ -3534,12 +3534,12 @@ static inline int inet6_ifaddr_msgsize(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int inet6_fill_ifaddr(struct sk_buff *skb, struct inet6_ifaddr *ifa,
|
static int inet6_fill_ifaddr(struct sk_buff *skb, struct inet6_ifaddr *ifa,
|
||||||
u32 pid, u32 seq, int event, unsigned int flags)
|
u32 portid, u32 seq, int event, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
u32 preferred, valid;
|
u32 preferred, valid;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(struct ifaddrmsg), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(struct ifaddrmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -3577,7 +3577,7 @@ static int inet6_fill_ifaddr(struct sk_buff *skb, struct inet6_ifaddr *ifa,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int inet6_fill_ifmcaddr(struct sk_buff *skb, struct ifmcaddr6 *ifmca,
|
static int inet6_fill_ifmcaddr(struct sk_buff *skb, struct ifmcaddr6 *ifmca,
|
||||||
u32 pid, u32 seq, int event, u16 flags)
|
u32 portid, u32 seq, int event, u16 flags)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
u8 scope = RT_SCOPE_UNIVERSE;
|
u8 scope = RT_SCOPE_UNIVERSE;
|
||||||
@ -3586,7 +3586,7 @@ static int inet6_fill_ifmcaddr(struct sk_buff *skb, struct ifmcaddr6 *ifmca,
|
|||||||
if (ipv6_addr_scope(&ifmca->mca_addr) & IFA_SITE)
|
if (ipv6_addr_scope(&ifmca->mca_addr) & IFA_SITE)
|
||||||
scope = RT_SCOPE_SITE;
|
scope = RT_SCOPE_SITE;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(struct ifaddrmsg), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(struct ifaddrmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -3602,7 +3602,7 @@ static int inet6_fill_ifmcaddr(struct sk_buff *skb, struct ifmcaddr6 *ifmca,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int inet6_fill_ifacaddr(struct sk_buff *skb, struct ifacaddr6 *ifaca,
|
static int inet6_fill_ifacaddr(struct sk_buff *skb, struct ifacaddr6 *ifaca,
|
||||||
u32 pid, u32 seq, int event, unsigned int flags)
|
u32 portid, u32 seq, int event, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
u8 scope = RT_SCOPE_UNIVERSE;
|
u8 scope = RT_SCOPE_UNIVERSE;
|
||||||
@ -3611,7 +3611,7 @@ static int inet6_fill_ifacaddr(struct sk_buff *skb, struct ifacaddr6 *ifaca,
|
|||||||
if (ipv6_addr_scope(&ifaca->aca_addr) & IFA_SITE)
|
if (ipv6_addr_scope(&ifaca->aca_addr) & IFA_SITE)
|
||||||
scope = RT_SCOPE_SITE;
|
scope = RT_SCOPE_SITE;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(struct ifaddrmsg), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(struct ifaddrmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -3652,7 +3652,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,
|
|||||||
if (++ip_idx < s_ip_idx)
|
if (++ip_idx < s_ip_idx)
|
||||||
continue;
|
continue;
|
||||||
err = inet6_fill_ifaddr(skb, ifa,
|
err = inet6_fill_ifaddr(skb, ifa,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
RTM_NEWADDR,
|
RTM_NEWADDR,
|
||||||
NLM_F_MULTI);
|
NLM_F_MULTI);
|
||||||
@ -3668,7 +3668,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,
|
|||||||
if (ip_idx < s_ip_idx)
|
if (ip_idx < s_ip_idx)
|
||||||
continue;
|
continue;
|
||||||
err = inet6_fill_ifmcaddr(skb, ifmca,
|
err = inet6_fill_ifmcaddr(skb, ifmca,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
RTM_GETMULTICAST,
|
RTM_GETMULTICAST,
|
||||||
NLM_F_MULTI);
|
NLM_F_MULTI);
|
||||||
@ -3683,7 +3683,7 @@ static int in6_dump_addrs(struct inet6_dev *idev, struct sk_buff *skb,
|
|||||||
if (ip_idx < s_ip_idx)
|
if (ip_idx < s_ip_idx)
|
||||||
continue;
|
continue;
|
||||||
err = inet6_fill_ifacaddr(skb, ifaca,
|
err = inet6_fill_ifacaddr(skb, ifaca,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
RTM_GETANYCAST,
|
RTM_GETANYCAST,
|
||||||
NLM_F_MULTI);
|
NLM_F_MULTI);
|
||||||
@ -3805,7 +3805,7 @@ static int inet6_rtm_getaddr(struct sk_buff *in_skb, struct nlmsghdr *nlh,
|
|||||||
goto errout_ifa;
|
goto errout_ifa;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = inet6_fill_ifaddr(skb, ifa, NETLINK_CB(in_skb).pid,
|
err = inet6_fill_ifaddr(skb, ifa, NETLINK_CB(in_skb).portid,
|
||||||
nlh->nlmsg_seq, RTM_NEWADDR, 0);
|
nlh->nlmsg_seq, RTM_NEWADDR, 0);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
/* -EMSGSIZE implies BUG in inet6_ifaddr_msgsize() */
|
/* -EMSGSIZE implies BUG in inet6_ifaddr_msgsize() */
|
||||||
@ -3813,7 +3813,7 @@ static int inet6_rtm_getaddr(struct sk_buff *in_skb, struct nlmsghdr *nlh,
|
|||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
goto errout_ifa;
|
goto errout_ifa;
|
||||||
}
|
}
|
||||||
err = rtnl_unicast(skb, net, NETLINK_CB(in_skb).pid);
|
err = rtnl_unicast(skb, net, NETLINK_CB(in_skb).portid);
|
||||||
errout_ifa:
|
errout_ifa:
|
||||||
in6_ifa_put(ifa);
|
in6_ifa_put(ifa);
|
||||||
errout:
|
errout:
|
||||||
@ -4015,14 +4015,14 @@ static int inet6_fill_link_af(struct sk_buff *skb, const struct net_device *dev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int inet6_fill_ifinfo(struct sk_buff *skb, struct inet6_dev *idev,
|
static int inet6_fill_ifinfo(struct sk_buff *skb, struct inet6_dev *idev,
|
||||||
u32 pid, u32 seq, int event, unsigned int flags)
|
u32 portid, u32 seq, int event, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct net_device *dev = idev->dev;
|
struct net_device *dev = idev->dev;
|
||||||
struct ifinfomsg *hdr;
|
struct ifinfomsg *hdr;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
void *protoinfo;
|
void *protoinfo;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*hdr), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*hdr), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -4080,7 +4080,7 @@ static int inet6_dump_ifinfo(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (!idev)
|
if (!idev)
|
||||||
goto cont;
|
goto cont;
|
||||||
if (inet6_fill_ifinfo(skb, idev,
|
if (inet6_fill_ifinfo(skb, idev,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
RTM_NEWLINK, NLM_F_MULTI) <= 0)
|
RTM_NEWLINK, NLM_F_MULTI) <= 0)
|
||||||
goto out;
|
goto out;
|
||||||
@ -4128,14 +4128,14 @@ static inline size_t inet6_prefix_nlmsg_size(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int inet6_fill_prefix(struct sk_buff *skb, struct inet6_dev *idev,
|
static int inet6_fill_prefix(struct sk_buff *skb, struct inet6_dev *idev,
|
||||||
struct prefix_info *pinfo, u32 pid, u32 seq,
|
struct prefix_info *pinfo, u32 portid, u32 seq,
|
||||||
int event, unsigned int flags)
|
int event, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct prefixmsg *pmsg;
|
struct prefixmsg *pmsg;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct prefix_cacheinfo ci;
|
struct prefix_cacheinfo ci;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*pmsg), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*pmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
|
@ -470,10 +470,10 @@ static void ip6addrlbl_putmsg(struct nlmsghdr *nlh,
|
|||||||
static int ip6addrlbl_fill(struct sk_buff *skb,
|
static int ip6addrlbl_fill(struct sk_buff *skb,
|
||||||
struct ip6addrlbl_entry *p,
|
struct ip6addrlbl_entry *p,
|
||||||
u32 lseq,
|
u32 lseq,
|
||||||
u32 pid, u32 seq, int event,
|
u32 portid, u32 seq, int event,
|
||||||
unsigned int flags)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh = nlmsg_put(skb, pid, seq, event,
|
struct nlmsghdr *nlh = nlmsg_put(skb, portid, seq, event,
|
||||||
sizeof(struct ifaddrlblmsg), flags);
|
sizeof(struct ifaddrlblmsg), flags);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
@ -503,7 +503,7 @@ static int ip6addrlbl_dump(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
net_eq(ip6addrlbl_net(p), net)) {
|
net_eq(ip6addrlbl_net(p), net)) {
|
||||||
if ((err = ip6addrlbl_fill(skb, p,
|
if ((err = ip6addrlbl_fill(skb, p,
|
||||||
ip6addrlbl_table.seq,
|
ip6addrlbl_table.seq,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
RTM_NEWADDRLABEL,
|
RTM_NEWADDRLABEL,
|
||||||
NLM_F_MULTI)) <= 0)
|
NLM_F_MULTI)) <= 0)
|
||||||
@ -574,7 +574,7 @@ static int ip6addrlbl_get(struct sk_buff *in_skb, struct nlmsghdr* nlh,
|
|||||||
}
|
}
|
||||||
|
|
||||||
err = ip6addrlbl_fill(skb, p, lseq,
|
err = ip6addrlbl_fill(skb, p, lseq,
|
||||||
NETLINK_CB(in_skb).pid, nlh->nlmsg_seq,
|
NETLINK_CB(in_skb).portid, nlh->nlmsg_seq,
|
||||||
RTM_NEWADDRLABEL, 0);
|
RTM_NEWADDRLABEL, 0);
|
||||||
|
|
||||||
ip6addrlbl_put(p);
|
ip6addrlbl_put(p);
|
||||||
@ -585,7 +585,7 @@ static int ip6addrlbl_get(struct sk_buff *in_skb, struct nlmsghdr* nlh,
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = rtnl_unicast(skb, net, NETLINK_CB(in_skb).pid);
|
err = rtnl_unicast(skb, net, NETLINK_CB(in_skb).portid);
|
||||||
out:
|
out:
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
@ -838,7 +838,7 @@ static void ip6mr_destroy_unres(struct mr6_table *mrt, struct mfc6_cache *c)
|
|||||||
nlh->nlmsg_len = NLMSG_LENGTH(sizeof(struct nlmsgerr));
|
nlh->nlmsg_len = NLMSG_LENGTH(sizeof(struct nlmsgerr));
|
||||||
skb_trim(skb, nlh->nlmsg_len);
|
skb_trim(skb, nlh->nlmsg_len);
|
||||||
((struct nlmsgerr *)NLMSG_DATA(nlh))->error = -ETIMEDOUT;
|
((struct nlmsgerr *)NLMSG_DATA(nlh))->error = -ETIMEDOUT;
|
||||||
rtnl_unicast(skb, net, NETLINK_CB(skb).pid);
|
rtnl_unicast(skb, net, NETLINK_CB(skb).portid);
|
||||||
} else
|
} else
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
}
|
}
|
||||||
@ -1052,7 +1052,7 @@ static void ip6mr_cache_resolve(struct net *net, struct mr6_table *mrt,
|
|||||||
skb_trim(skb, nlh->nlmsg_len);
|
skb_trim(skb, nlh->nlmsg_len);
|
||||||
((struct nlmsgerr *)NLMSG_DATA(nlh))->error = -EMSGSIZE;
|
((struct nlmsgerr *)NLMSG_DATA(nlh))->error = -EMSGSIZE;
|
||||||
}
|
}
|
||||||
rtnl_unicast(skb, net, NETLINK_CB(skb).pid);
|
rtnl_unicast(skb, net, NETLINK_CB(skb).portid);
|
||||||
} else
|
} else
|
||||||
ip6_mr_forward(net, mrt, skb, c);
|
ip6_mr_forward(net, mrt, skb, c);
|
||||||
}
|
}
|
||||||
@ -2202,12 +2202,12 @@ int ip6mr_get_route(struct net *net,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int ip6mr_fill_mroute(struct mr6_table *mrt, struct sk_buff *skb,
|
static int ip6mr_fill_mroute(struct mr6_table *mrt, struct sk_buff *skb,
|
||||||
u32 pid, u32 seq, struct mfc6_cache *c)
|
u32 portid, u32 seq, struct mfc6_cache *c)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct rtmsg *rtm;
|
struct rtmsg *rtm;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, RTM_NEWROUTE, sizeof(*rtm), NLM_F_MULTI);
|
nlh = nlmsg_put(skb, portid, seq, RTM_NEWROUTE, sizeof(*rtm), NLM_F_MULTI);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -2260,7 +2260,7 @@ static int ip6mr_rtm_dumproute(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (e < s_e)
|
if (e < s_e)
|
||||||
goto next_entry;
|
goto next_entry;
|
||||||
if (ip6mr_fill_mroute(mrt, skb,
|
if (ip6mr_fill_mroute(mrt, skb,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
mfc) < 0)
|
mfc) < 0)
|
||||||
goto done;
|
goto done;
|
||||||
|
@ -1874,7 +1874,7 @@ static struct rt6_info *rt6_add_route_info(struct net *net,
|
|||||||
.fc_dst_len = prefixlen,
|
.fc_dst_len = prefixlen,
|
||||||
.fc_flags = RTF_GATEWAY | RTF_ADDRCONF | RTF_ROUTEINFO |
|
.fc_flags = RTF_GATEWAY | RTF_ADDRCONF | RTF_ROUTEINFO |
|
||||||
RTF_UP | RTF_PREF(pref),
|
RTF_UP | RTF_PREF(pref),
|
||||||
.fc_nlinfo.pid = 0,
|
.fc_nlinfo.portid = 0,
|
||||||
.fc_nlinfo.nlh = NULL,
|
.fc_nlinfo.nlh = NULL,
|
||||||
.fc_nlinfo.nl_net = net,
|
.fc_nlinfo.nl_net = net,
|
||||||
};
|
};
|
||||||
@ -1924,7 +1924,7 @@ struct rt6_info *rt6_add_dflt_router(const struct in6_addr *gwaddr,
|
|||||||
.fc_ifindex = dev->ifindex,
|
.fc_ifindex = dev->ifindex,
|
||||||
.fc_flags = RTF_GATEWAY | RTF_ADDRCONF | RTF_DEFAULT |
|
.fc_flags = RTF_GATEWAY | RTF_ADDRCONF | RTF_DEFAULT |
|
||||||
RTF_UP | RTF_EXPIRES | RTF_PREF(pref),
|
RTF_UP | RTF_EXPIRES | RTF_PREF(pref),
|
||||||
.fc_nlinfo.pid = 0,
|
.fc_nlinfo.portid = 0,
|
||||||
.fc_nlinfo.nlh = NULL,
|
.fc_nlinfo.nlh = NULL,
|
||||||
.fc_nlinfo.nl_net = dev_net(dev),
|
.fc_nlinfo.nl_net = dev_net(dev),
|
||||||
};
|
};
|
||||||
@ -2285,7 +2285,7 @@ static int rtm_to_fib6_config(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
if (rtm->rtm_type == RTN_LOCAL)
|
if (rtm->rtm_type == RTN_LOCAL)
|
||||||
cfg->fc_flags |= RTF_LOCAL;
|
cfg->fc_flags |= RTF_LOCAL;
|
||||||
|
|
||||||
cfg->fc_nlinfo.pid = NETLINK_CB(skb).pid;
|
cfg->fc_nlinfo.portid = NETLINK_CB(skb).portid;
|
||||||
cfg->fc_nlinfo.nlh = nlh;
|
cfg->fc_nlinfo.nlh = nlh;
|
||||||
cfg->fc_nlinfo.nl_net = sock_net(skb->sk);
|
cfg->fc_nlinfo.nl_net = sock_net(skb->sk);
|
||||||
|
|
||||||
@ -2376,7 +2376,7 @@ static inline size_t rt6_nlmsg_size(void)
|
|||||||
static int rt6_fill_node(struct net *net,
|
static int rt6_fill_node(struct net *net,
|
||||||
struct sk_buff *skb, struct rt6_info *rt,
|
struct sk_buff *skb, struct rt6_info *rt,
|
||||||
struct in6_addr *dst, struct in6_addr *src,
|
struct in6_addr *dst, struct in6_addr *src,
|
||||||
int iif, int type, u32 pid, u32 seq,
|
int iif, int type, u32 portid, u32 seq,
|
||||||
int prefix, int nowait, unsigned int flags)
|
int prefix, int nowait, unsigned int flags)
|
||||||
{
|
{
|
||||||
struct rtmsg *rtm;
|
struct rtmsg *rtm;
|
||||||
@ -2392,7 +2392,7 @@ static int rt6_fill_node(struct net *net,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, type, sizeof(*rtm), flags);
|
nlh = nlmsg_put(skb, portid, seq, type, sizeof(*rtm), flags);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -2537,7 +2537,7 @@ int rt6_dump_route(struct rt6_info *rt, void *p_arg)
|
|||||||
|
|
||||||
return rt6_fill_node(arg->net,
|
return rt6_fill_node(arg->net,
|
||||||
arg->skb, rt, NULL, NULL, 0, RTM_NEWROUTE,
|
arg->skb, rt, NULL, NULL, 0, RTM_NEWROUTE,
|
||||||
NETLINK_CB(arg->cb->skb).pid, arg->cb->nlh->nlmsg_seq,
|
NETLINK_CB(arg->cb->skb).portid, arg->cb->nlh->nlmsg_seq,
|
||||||
prefix, 0, NLM_F_MULTI);
|
prefix, 0, NLM_F_MULTI);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2617,14 +2617,14 @@ static int inet6_rtm_getroute(struct sk_buff *in_skb, struct nlmsghdr* nlh, void
|
|||||||
skb_dst_set(skb, &rt->dst);
|
skb_dst_set(skb, &rt->dst);
|
||||||
|
|
||||||
err = rt6_fill_node(net, skb, rt, &fl6.daddr, &fl6.saddr, iif,
|
err = rt6_fill_node(net, skb, rt, &fl6.daddr, &fl6.saddr, iif,
|
||||||
RTM_NEWROUTE, NETLINK_CB(in_skb).pid,
|
RTM_NEWROUTE, NETLINK_CB(in_skb).portid,
|
||||||
nlh->nlmsg_seq, 0, 0, 0);
|
nlh->nlmsg_seq, 0, 0, 0);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
goto errout;
|
goto errout;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = rtnl_unicast(skb, net, NETLINK_CB(in_skb).pid);
|
err = rtnl_unicast(skb, net, NETLINK_CB(in_skb).portid);
|
||||||
errout:
|
errout:
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
@ -2644,14 +2644,14 @@ void inet6_rt_notify(int event, struct rt6_info *rt, struct nl_info *info)
|
|||||||
goto errout;
|
goto errout;
|
||||||
|
|
||||||
err = rt6_fill_node(net, skb, rt, NULL, NULL, 0,
|
err = rt6_fill_node(net, skb, rt, NULL, NULL, 0,
|
||||||
event, info->pid, seq, 0, 0, 0);
|
event, info->portid, seq, 0, 0, 0);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
/* -EMSGSIZE implies BUG in rt6_nlmsg_size() */
|
/* -EMSGSIZE implies BUG in rt6_nlmsg_size() */
|
||||||
WARN_ON(err == -EMSGSIZE);
|
WARN_ON(err == -EMSGSIZE);
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
goto errout;
|
goto errout;
|
||||||
}
|
}
|
||||||
rtnl_notify(skb, net, info->pid, RTNLGRP_IPV6_ROUTE,
|
rtnl_notify(skb, net, info->portid, RTNLGRP_IPV6_ROUTE,
|
||||||
info->nlh, gfp_any());
|
info->nlh, gfp_any());
|
||||||
return;
|
return;
|
||||||
errout:
|
errout:
|
||||||
|
@ -100,7 +100,7 @@ static int irda_nl_get_mode(struct sk_buff *skb, struct genl_info *info)
|
|||||||
goto err_out;
|
goto err_out;
|
||||||
}
|
}
|
||||||
|
|
||||||
hdr = genlmsg_put(msg, info->snd_pid, info->snd_seq,
|
hdr = genlmsg_put(msg, info->snd_portid, info->snd_seq,
|
||||||
&irda_nl_family, 0, IRDA_NL_CMD_GET_MODE);
|
&irda_nl_family, 0, IRDA_NL_CMD_GET_MODE);
|
||||||
if (hdr == NULL) {
|
if (hdr == NULL) {
|
||||||
ret = -EMSGSIZE;
|
ret = -EMSGSIZE;
|
||||||
|
@ -54,7 +54,7 @@ struct pfkey_sock {
|
|||||||
|
|
||||||
struct {
|
struct {
|
||||||
uint8_t msg_version;
|
uint8_t msg_version;
|
||||||
uint32_t msg_pid;
|
uint32_t msg_portid;
|
||||||
int (*dump)(struct pfkey_sock *sk);
|
int (*dump)(struct pfkey_sock *sk);
|
||||||
void (*done)(struct pfkey_sock *sk);
|
void (*done)(struct pfkey_sock *sk);
|
||||||
union {
|
union {
|
||||||
@ -1447,7 +1447,7 @@ static int key_notify_sa(struct xfrm_state *x, const struct km_event *c)
|
|||||||
hdr->sadb_msg_errno = 0;
|
hdr->sadb_msg_errno = 0;
|
||||||
hdr->sadb_msg_reserved = 0;
|
hdr->sadb_msg_reserved = 0;
|
||||||
hdr->sadb_msg_seq = c->seq;
|
hdr->sadb_msg_seq = c->seq;
|
||||||
hdr->sadb_msg_pid = c->pid;
|
hdr->sadb_msg_pid = c->portid;
|
||||||
|
|
||||||
pfkey_broadcast(skb, GFP_ATOMIC, BROADCAST_ALL, NULL, xs_net(x));
|
pfkey_broadcast(skb, GFP_ATOMIC, BROADCAST_ALL, NULL, xs_net(x));
|
||||||
|
|
||||||
@ -1486,7 +1486,7 @@ static int pfkey_add(struct sock *sk, struct sk_buff *skb, const struct sadb_msg
|
|||||||
else
|
else
|
||||||
c.event = XFRM_MSG_UPDSA;
|
c.event = XFRM_MSG_UPDSA;
|
||||||
c.seq = hdr->sadb_msg_seq;
|
c.seq = hdr->sadb_msg_seq;
|
||||||
c.pid = hdr->sadb_msg_pid;
|
c.portid = hdr->sadb_msg_pid;
|
||||||
km_state_notify(x, &c);
|
km_state_notify(x, &c);
|
||||||
out:
|
out:
|
||||||
xfrm_state_put(x);
|
xfrm_state_put(x);
|
||||||
@ -1523,7 +1523,7 @@ static int pfkey_delete(struct sock *sk, struct sk_buff *skb, const struct sadb_
|
|||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
c.seq = hdr->sadb_msg_seq;
|
c.seq = hdr->sadb_msg_seq;
|
||||||
c.pid = hdr->sadb_msg_pid;
|
c.portid = hdr->sadb_msg_pid;
|
||||||
c.event = XFRM_MSG_DELSA;
|
c.event = XFRM_MSG_DELSA;
|
||||||
km_state_notify(x, &c);
|
km_state_notify(x, &c);
|
||||||
out:
|
out:
|
||||||
@ -1701,7 +1701,7 @@ static int key_notify_sa_flush(const struct km_event *c)
|
|||||||
hdr->sadb_msg_satype = pfkey_proto2satype(c->data.proto);
|
hdr->sadb_msg_satype = pfkey_proto2satype(c->data.proto);
|
||||||
hdr->sadb_msg_type = SADB_FLUSH;
|
hdr->sadb_msg_type = SADB_FLUSH;
|
||||||
hdr->sadb_msg_seq = c->seq;
|
hdr->sadb_msg_seq = c->seq;
|
||||||
hdr->sadb_msg_pid = c->pid;
|
hdr->sadb_msg_pid = c->portid;
|
||||||
hdr->sadb_msg_version = PF_KEY_V2;
|
hdr->sadb_msg_version = PF_KEY_V2;
|
||||||
hdr->sadb_msg_errno = (uint8_t) 0;
|
hdr->sadb_msg_errno = (uint8_t) 0;
|
||||||
hdr->sadb_msg_len = (sizeof(struct sadb_msg) / sizeof(uint64_t));
|
hdr->sadb_msg_len = (sizeof(struct sadb_msg) / sizeof(uint64_t));
|
||||||
@ -1736,7 +1736,7 @@ static int pfkey_flush(struct sock *sk, struct sk_buff *skb, const struct sadb_m
|
|||||||
|
|
||||||
c.data.proto = proto;
|
c.data.proto = proto;
|
||||||
c.seq = hdr->sadb_msg_seq;
|
c.seq = hdr->sadb_msg_seq;
|
||||||
c.pid = hdr->sadb_msg_pid;
|
c.portid = hdr->sadb_msg_pid;
|
||||||
c.event = XFRM_MSG_FLUSHSA;
|
c.event = XFRM_MSG_FLUSHSA;
|
||||||
c.net = net;
|
c.net = net;
|
||||||
km_state_notify(NULL, &c);
|
km_state_notify(NULL, &c);
|
||||||
@ -1764,7 +1764,7 @@ static int dump_sa(struct xfrm_state *x, int count, void *ptr)
|
|||||||
out_hdr->sadb_msg_errno = 0;
|
out_hdr->sadb_msg_errno = 0;
|
||||||
out_hdr->sadb_msg_reserved = 0;
|
out_hdr->sadb_msg_reserved = 0;
|
||||||
out_hdr->sadb_msg_seq = count + 1;
|
out_hdr->sadb_msg_seq = count + 1;
|
||||||
out_hdr->sadb_msg_pid = pfk->dump.msg_pid;
|
out_hdr->sadb_msg_pid = pfk->dump.msg_portid;
|
||||||
|
|
||||||
if (pfk->dump.skb)
|
if (pfk->dump.skb)
|
||||||
pfkey_broadcast(pfk->dump.skb, GFP_ATOMIC, BROADCAST_ONE,
|
pfkey_broadcast(pfk->dump.skb, GFP_ATOMIC, BROADCAST_ONE,
|
||||||
@ -1798,7 +1798,7 @@ static int pfkey_dump(struct sock *sk, struct sk_buff *skb, const struct sadb_ms
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
pfk->dump.msg_version = hdr->sadb_msg_version;
|
pfk->dump.msg_version = hdr->sadb_msg_version;
|
||||||
pfk->dump.msg_pid = hdr->sadb_msg_pid;
|
pfk->dump.msg_portid = hdr->sadb_msg_pid;
|
||||||
pfk->dump.dump = pfkey_dump_sa;
|
pfk->dump.dump = pfkey_dump_sa;
|
||||||
pfk->dump.done = pfkey_dump_sa_done;
|
pfk->dump.done = pfkey_dump_sa_done;
|
||||||
xfrm_state_walk_init(&pfk->dump.u.state, proto);
|
xfrm_state_walk_init(&pfk->dump.u.state, proto);
|
||||||
@ -2157,7 +2157,7 @@ static int key_notify_policy(struct xfrm_policy *xp, int dir, const struct km_ev
|
|||||||
out_hdr->sadb_msg_type = event2poltype(c->event);
|
out_hdr->sadb_msg_type = event2poltype(c->event);
|
||||||
out_hdr->sadb_msg_errno = 0;
|
out_hdr->sadb_msg_errno = 0;
|
||||||
out_hdr->sadb_msg_seq = c->seq;
|
out_hdr->sadb_msg_seq = c->seq;
|
||||||
out_hdr->sadb_msg_pid = c->pid;
|
out_hdr->sadb_msg_pid = c->portid;
|
||||||
pfkey_broadcast(out_skb, GFP_ATOMIC, BROADCAST_ALL, NULL, xp_net(xp));
|
pfkey_broadcast(out_skb, GFP_ATOMIC, BROADCAST_ALL, NULL, xp_net(xp));
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -2272,7 +2272,7 @@ static int pfkey_spdadd(struct sock *sk, struct sk_buff *skb, const struct sadb_
|
|||||||
c.event = XFRM_MSG_NEWPOLICY;
|
c.event = XFRM_MSG_NEWPOLICY;
|
||||||
|
|
||||||
c.seq = hdr->sadb_msg_seq;
|
c.seq = hdr->sadb_msg_seq;
|
||||||
c.pid = hdr->sadb_msg_pid;
|
c.portid = hdr->sadb_msg_pid;
|
||||||
|
|
||||||
km_policy_notify(xp, pol->sadb_x_policy_dir-1, &c);
|
km_policy_notify(xp, pol->sadb_x_policy_dir-1, &c);
|
||||||
xfrm_pol_put(xp);
|
xfrm_pol_put(xp);
|
||||||
@ -2351,7 +2351,7 @@ static int pfkey_spddelete(struct sock *sk, struct sk_buff *skb, const struct sa
|
|||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
c.seq = hdr->sadb_msg_seq;
|
c.seq = hdr->sadb_msg_seq;
|
||||||
c.pid = hdr->sadb_msg_pid;
|
c.portid = hdr->sadb_msg_pid;
|
||||||
c.data.byid = 0;
|
c.data.byid = 0;
|
||||||
c.event = XFRM_MSG_DELPOLICY;
|
c.event = XFRM_MSG_DELPOLICY;
|
||||||
km_policy_notify(xp, pol->sadb_x_policy_dir-1, &c);
|
km_policy_notify(xp, pol->sadb_x_policy_dir-1, &c);
|
||||||
@ -2597,7 +2597,7 @@ static int pfkey_spdget(struct sock *sk, struct sk_buff *skb, const struct sadb_
|
|||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
c.seq = hdr->sadb_msg_seq;
|
c.seq = hdr->sadb_msg_seq;
|
||||||
c.pid = hdr->sadb_msg_pid;
|
c.portid = hdr->sadb_msg_pid;
|
||||||
c.data.byid = 1;
|
c.data.byid = 1;
|
||||||
c.event = XFRM_MSG_DELPOLICY;
|
c.event = XFRM_MSG_DELPOLICY;
|
||||||
km_policy_notify(xp, dir, &c);
|
km_policy_notify(xp, dir, &c);
|
||||||
@ -2634,7 +2634,7 @@ static int dump_sp(struct xfrm_policy *xp, int dir, int count, void *ptr)
|
|||||||
out_hdr->sadb_msg_satype = SADB_SATYPE_UNSPEC;
|
out_hdr->sadb_msg_satype = SADB_SATYPE_UNSPEC;
|
||||||
out_hdr->sadb_msg_errno = 0;
|
out_hdr->sadb_msg_errno = 0;
|
||||||
out_hdr->sadb_msg_seq = count + 1;
|
out_hdr->sadb_msg_seq = count + 1;
|
||||||
out_hdr->sadb_msg_pid = pfk->dump.msg_pid;
|
out_hdr->sadb_msg_pid = pfk->dump.msg_portid;
|
||||||
|
|
||||||
if (pfk->dump.skb)
|
if (pfk->dump.skb)
|
||||||
pfkey_broadcast(pfk->dump.skb, GFP_ATOMIC, BROADCAST_ONE,
|
pfkey_broadcast(pfk->dump.skb, GFP_ATOMIC, BROADCAST_ONE,
|
||||||
@ -2663,7 +2663,7 @@ static int pfkey_spddump(struct sock *sk, struct sk_buff *skb, const struct sadb
|
|||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
|
|
||||||
pfk->dump.msg_version = hdr->sadb_msg_version;
|
pfk->dump.msg_version = hdr->sadb_msg_version;
|
||||||
pfk->dump.msg_pid = hdr->sadb_msg_pid;
|
pfk->dump.msg_portid = hdr->sadb_msg_pid;
|
||||||
pfk->dump.dump = pfkey_dump_sp;
|
pfk->dump.dump = pfkey_dump_sp;
|
||||||
pfk->dump.done = pfkey_dump_sp_done;
|
pfk->dump.done = pfkey_dump_sp_done;
|
||||||
xfrm_policy_walk_init(&pfk->dump.u.policy, XFRM_POLICY_TYPE_MAIN);
|
xfrm_policy_walk_init(&pfk->dump.u.policy, XFRM_POLICY_TYPE_MAIN);
|
||||||
@ -2682,7 +2682,7 @@ static int key_notify_policy_flush(const struct km_event *c)
|
|||||||
hdr = (struct sadb_msg *) skb_put(skb_out, sizeof(struct sadb_msg));
|
hdr = (struct sadb_msg *) skb_put(skb_out, sizeof(struct sadb_msg));
|
||||||
hdr->sadb_msg_type = SADB_X_SPDFLUSH;
|
hdr->sadb_msg_type = SADB_X_SPDFLUSH;
|
||||||
hdr->sadb_msg_seq = c->seq;
|
hdr->sadb_msg_seq = c->seq;
|
||||||
hdr->sadb_msg_pid = c->pid;
|
hdr->sadb_msg_pid = c->portid;
|
||||||
hdr->sadb_msg_version = PF_KEY_V2;
|
hdr->sadb_msg_version = PF_KEY_V2;
|
||||||
hdr->sadb_msg_errno = (uint8_t) 0;
|
hdr->sadb_msg_errno = (uint8_t) 0;
|
||||||
hdr->sadb_msg_len = (sizeof(struct sadb_msg) / sizeof(uint64_t));
|
hdr->sadb_msg_len = (sizeof(struct sadb_msg) / sizeof(uint64_t));
|
||||||
@ -2711,7 +2711,7 @@ static int pfkey_spdflush(struct sock *sk, struct sk_buff *skb, const struct sad
|
|||||||
|
|
||||||
c.data.type = XFRM_POLICY_TYPE_MAIN;
|
c.data.type = XFRM_POLICY_TYPE_MAIN;
|
||||||
c.event = XFRM_MSG_FLUSHPOLICY;
|
c.event = XFRM_MSG_FLUSHPOLICY;
|
||||||
c.pid = hdr->sadb_msg_pid;
|
c.portid = hdr->sadb_msg_pid;
|
||||||
c.seq = hdr->sadb_msg_seq;
|
c.seq = hdr->sadb_msg_seq;
|
||||||
c.net = net;
|
c.net = net;
|
||||||
km_policy_notify(NULL, 0, &c);
|
km_policy_notify(NULL, 0, &c);
|
||||||
|
@ -78,7 +78,7 @@ static int l2tp_nl_cmd_noop(struct sk_buff *skb, struct genl_info *info)
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
hdr = genlmsg_put(msg, info->snd_pid, info->snd_seq,
|
hdr = genlmsg_put(msg, info->snd_portid, info->snd_seq,
|
||||||
&l2tp_nl_family, 0, L2TP_CMD_NOOP);
|
&l2tp_nl_family, 0, L2TP_CMD_NOOP);
|
||||||
if (IS_ERR(hdr)) {
|
if (IS_ERR(hdr)) {
|
||||||
ret = PTR_ERR(hdr);
|
ret = PTR_ERR(hdr);
|
||||||
@ -87,7 +87,7 @@ static int l2tp_nl_cmd_noop(struct sk_buff *skb, struct genl_info *info)
|
|||||||
|
|
||||||
genlmsg_end(msg, hdr);
|
genlmsg_end(msg, hdr);
|
||||||
|
|
||||||
return genlmsg_unicast(genl_info_net(info), msg, info->snd_pid);
|
return genlmsg_unicast(genl_info_net(info), msg, info->snd_portid);
|
||||||
|
|
||||||
err_out:
|
err_out:
|
||||||
nlmsg_free(msg);
|
nlmsg_free(msg);
|
||||||
@ -235,7 +235,7 @@ static int l2tp_nl_cmd_tunnel_modify(struct sk_buff *skb, struct genl_info *info
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int l2tp_nl_tunnel_send(struct sk_buff *skb, u32 pid, u32 seq, int flags,
|
static int l2tp_nl_tunnel_send(struct sk_buff *skb, u32 portid, u32 seq, int flags,
|
||||||
struct l2tp_tunnel *tunnel)
|
struct l2tp_tunnel *tunnel)
|
||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
@ -248,7 +248,7 @@ static int l2tp_nl_tunnel_send(struct sk_buff *skb, u32 pid, u32 seq, int flags,
|
|||||||
struct l2tp_stats stats;
|
struct l2tp_stats stats;
|
||||||
unsigned int start;
|
unsigned int start;
|
||||||
|
|
||||||
hdr = genlmsg_put(skb, pid, seq, &l2tp_nl_family, flags,
|
hdr = genlmsg_put(skb, portid, seq, &l2tp_nl_family, flags,
|
||||||
L2TP_CMD_TUNNEL_GET);
|
L2TP_CMD_TUNNEL_GET);
|
||||||
if (IS_ERR(hdr))
|
if (IS_ERR(hdr))
|
||||||
return PTR_ERR(hdr);
|
return PTR_ERR(hdr);
|
||||||
@ -359,12 +359,12 @@ static int l2tp_nl_cmd_tunnel_get(struct sk_buff *skb, struct genl_info *info)
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = l2tp_nl_tunnel_send(msg, info->snd_pid, info->snd_seq,
|
ret = l2tp_nl_tunnel_send(msg, info->snd_portid, info->snd_seq,
|
||||||
NLM_F_ACK, tunnel);
|
NLM_F_ACK, tunnel);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto err_out;
|
goto err_out;
|
||||||
|
|
||||||
return genlmsg_unicast(net, msg, info->snd_pid);
|
return genlmsg_unicast(net, msg, info->snd_portid);
|
||||||
|
|
||||||
err_out:
|
err_out:
|
||||||
nlmsg_free(msg);
|
nlmsg_free(msg);
|
||||||
@ -384,7 +384,7 @@ static int l2tp_nl_cmd_tunnel_dump(struct sk_buff *skb, struct netlink_callback
|
|||||||
if (tunnel == NULL)
|
if (tunnel == NULL)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
if (l2tp_nl_tunnel_send(skb, NETLINK_CB(cb->skb).pid,
|
if (l2tp_nl_tunnel_send(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
tunnel) <= 0)
|
tunnel) <= 0)
|
||||||
goto out;
|
goto out;
|
||||||
@ -604,7 +604,7 @@ static int l2tp_nl_cmd_session_modify(struct sk_buff *skb, struct genl_info *inf
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int l2tp_nl_session_send(struct sk_buff *skb, u32 pid, u32 seq, int flags,
|
static int l2tp_nl_session_send(struct sk_buff *skb, u32 portid, u32 seq, int flags,
|
||||||
struct l2tp_session *session)
|
struct l2tp_session *session)
|
||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
@ -616,7 +616,7 @@ static int l2tp_nl_session_send(struct sk_buff *skb, u32 pid, u32 seq, int flags
|
|||||||
|
|
||||||
sk = tunnel->sock;
|
sk = tunnel->sock;
|
||||||
|
|
||||||
hdr = genlmsg_put(skb, pid, seq, &l2tp_nl_family, flags, L2TP_CMD_SESSION_GET);
|
hdr = genlmsg_put(skb, portid, seq, &l2tp_nl_family, flags, L2TP_CMD_SESSION_GET);
|
||||||
if (IS_ERR(hdr))
|
if (IS_ERR(hdr))
|
||||||
return PTR_ERR(hdr);
|
return PTR_ERR(hdr);
|
||||||
|
|
||||||
@ -705,12 +705,12 @@ static int l2tp_nl_cmd_session_get(struct sk_buff *skb, struct genl_info *info)
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = l2tp_nl_session_send(msg, info->snd_pid, info->snd_seq,
|
ret = l2tp_nl_session_send(msg, info->snd_portid, info->snd_seq,
|
||||||
0, session);
|
0, session);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
goto err_out;
|
goto err_out;
|
||||||
|
|
||||||
return genlmsg_unicast(genl_info_net(info), msg, info->snd_pid);
|
return genlmsg_unicast(genl_info_net(info), msg, info->snd_portid);
|
||||||
|
|
||||||
err_out:
|
err_out:
|
||||||
nlmsg_free(msg);
|
nlmsg_free(msg);
|
||||||
@ -742,7 +742,7 @@ static int l2tp_nl_cmd_session_dump(struct sk_buff *skb, struct netlink_callback
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (l2tp_nl_session_send(skb, NETLINK_CB(cb->skb).pid,
|
if (l2tp_nl_session_send(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
session) <= 0)
|
session) <= 0)
|
||||||
break;
|
break;
|
||||||
|
@ -563,13 +563,13 @@ flag_exist(const struct nlmsghdr *nlh)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static struct nlmsghdr *
|
static struct nlmsghdr *
|
||||||
start_msg(struct sk_buff *skb, u32 pid, u32 seq, unsigned int flags,
|
start_msg(struct sk_buff *skb, u32 portid, u32 seq, unsigned int flags,
|
||||||
enum ipset_cmd cmd)
|
enum ipset_cmd cmd)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct nfgenmsg *nfmsg;
|
struct nfgenmsg *nfmsg;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, cmd | (NFNL_SUBSYS_IPSET << 8),
|
nlh = nlmsg_put(skb, portid, seq, cmd | (NFNL_SUBSYS_IPSET << 8),
|
||||||
sizeof(*nfmsg), flags);
|
sizeof(*nfmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -1045,7 +1045,7 @@ ip_set_dump_start(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
ip_set_id_t index = IPSET_INVALID_ID, max;
|
ip_set_id_t index = IPSET_INVALID_ID, max;
|
||||||
struct ip_set *set = NULL;
|
struct ip_set *set = NULL;
|
||||||
struct nlmsghdr *nlh = NULL;
|
struct nlmsghdr *nlh = NULL;
|
||||||
unsigned int flags = NETLINK_CB(cb->skb).pid ? NLM_F_MULTI : 0;
|
unsigned int flags = NETLINK_CB(cb->skb).portid ? NLM_F_MULTI : 0;
|
||||||
u32 dump_type, dump_flags;
|
u32 dump_type, dump_flags;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
@ -1093,7 +1093,7 @@ ip_set_dump_start(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
pr_debug("reference set\n");
|
pr_debug("reference set\n");
|
||||||
__ip_set_get(index);
|
__ip_set_get(index);
|
||||||
}
|
}
|
||||||
nlh = start_msg(skb, NETLINK_CB(cb->skb).pid,
|
nlh = start_msg(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, flags,
|
cb->nlh->nlmsg_seq, flags,
|
||||||
IPSET_CMD_LIST);
|
IPSET_CMD_LIST);
|
||||||
if (!nlh) {
|
if (!nlh) {
|
||||||
@ -1226,7 +1226,7 @@ call_ad(struct sock *ctnl, struct sk_buff *skb, struct ip_set *set,
|
|||||||
skb2 = nlmsg_new(payload, GFP_KERNEL);
|
skb2 = nlmsg_new(payload, GFP_KERNEL);
|
||||||
if (skb2 == NULL)
|
if (skb2 == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
rep = __nlmsg_put(skb2, NETLINK_CB(skb).pid,
|
rep = __nlmsg_put(skb2, NETLINK_CB(skb).portid,
|
||||||
nlh->nlmsg_seq, NLMSG_ERROR, payload, 0);
|
nlh->nlmsg_seq, NLMSG_ERROR, payload, 0);
|
||||||
errmsg = nlmsg_data(rep);
|
errmsg = nlmsg_data(rep);
|
||||||
errmsg->error = ret;
|
errmsg->error = ret;
|
||||||
@ -1241,7 +1241,7 @@ call_ad(struct sock *ctnl, struct sk_buff *skb, struct ip_set *set,
|
|||||||
|
|
||||||
*errline = lineno;
|
*errline = lineno;
|
||||||
|
|
||||||
netlink_unicast(ctnl, skb2, NETLINK_CB(skb).pid, MSG_DONTWAIT);
|
netlink_unicast(ctnl, skb2, NETLINK_CB(skb).portid, MSG_DONTWAIT);
|
||||||
/* Signal netlink not to send its ACK/errmsg. */
|
/* Signal netlink not to send its ACK/errmsg. */
|
||||||
return -EINTR;
|
return -EINTR;
|
||||||
}
|
}
|
||||||
@ -1416,7 +1416,7 @@ ip_set_header(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
if (skb2 == NULL)
|
if (skb2 == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
nlh2 = start_msg(skb2, NETLINK_CB(skb).pid, nlh->nlmsg_seq, 0,
|
nlh2 = start_msg(skb2, NETLINK_CB(skb).portid, nlh->nlmsg_seq, 0,
|
||||||
IPSET_CMD_HEADER);
|
IPSET_CMD_HEADER);
|
||||||
if (!nlh2)
|
if (!nlh2)
|
||||||
goto nlmsg_failure;
|
goto nlmsg_failure;
|
||||||
@ -1428,7 +1428,7 @@ ip_set_header(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
goto nla_put_failure;
|
goto nla_put_failure;
|
||||||
nlmsg_end(skb2, nlh2);
|
nlmsg_end(skb2, nlh2);
|
||||||
|
|
||||||
ret = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).pid, MSG_DONTWAIT);
|
ret = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).portid, MSG_DONTWAIT);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
@ -1476,7 +1476,7 @@ ip_set_type(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
if (skb2 == NULL)
|
if (skb2 == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
nlh2 = start_msg(skb2, NETLINK_CB(skb).pid, nlh->nlmsg_seq, 0,
|
nlh2 = start_msg(skb2, NETLINK_CB(skb).portid, nlh->nlmsg_seq, 0,
|
||||||
IPSET_CMD_TYPE);
|
IPSET_CMD_TYPE);
|
||||||
if (!nlh2)
|
if (!nlh2)
|
||||||
goto nlmsg_failure;
|
goto nlmsg_failure;
|
||||||
@ -1489,7 +1489,7 @@ ip_set_type(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
nlmsg_end(skb2, nlh2);
|
nlmsg_end(skb2, nlh2);
|
||||||
|
|
||||||
pr_debug("Send TYPE, nlmsg_len: %u\n", nlh2->nlmsg_len);
|
pr_debug("Send TYPE, nlmsg_len: %u\n", nlh2->nlmsg_len);
|
||||||
ret = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).pid, MSG_DONTWAIT);
|
ret = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).portid, MSG_DONTWAIT);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
@ -1525,7 +1525,7 @@ ip_set_protocol(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
if (skb2 == NULL)
|
if (skb2 == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
nlh2 = start_msg(skb2, NETLINK_CB(skb).pid, nlh->nlmsg_seq, 0,
|
nlh2 = start_msg(skb2, NETLINK_CB(skb).portid, nlh->nlmsg_seq, 0,
|
||||||
IPSET_CMD_PROTOCOL);
|
IPSET_CMD_PROTOCOL);
|
||||||
if (!nlh2)
|
if (!nlh2)
|
||||||
goto nlmsg_failure;
|
goto nlmsg_failure;
|
||||||
@ -1533,7 +1533,7 @@ ip_set_protocol(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
goto nla_put_failure;
|
goto nla_put_failure;
|
||||||
nlmsg_end(skb2, nlh2);
|
nlmsg_end(skb2, nlh2);
|
||||||
|
|
||||||
ret = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).pid, MSG_DONTWAIT);
|
ret = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).portid, MSG_DONTWAIT);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
@ -2939,7 +2939,7 @@ static int ip_vs_genl_dump_service(struct sk_buff *skb,
|
|||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
|
|
||||||
hdr = genlmsg_put(skb, NETLINK_CB(cb->skb).pid, cb->nlh->nlmsg_seq,
|
hdr = genlmsg_put(skb, NETLINK_CB(cb->skb).portid, cb->nlh->nlmsg_seq,
|
||||||
&ip_vs_genl_family, NLM_F_MULTI,
|
&ip_vs_genl_family, NLM_F_MULTI,
|
||||||
IPVS_CMD_NEW_SERVICE);
|
IPVS_CMD_NEW_SERVICE);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
@ -3128,7 +3128,7 @@ static int ip_vs_genl_dump_dest(struct sk_buff *skb, struct ip_vs_dest *dest,
|
|||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
|
|
||||||
hdr = genlmsg_put(skb, NETLINK_CB(cb->skb).pid, cb->nlh->nlmsg_seq,
|
hdr = genlmsg_put(skb, NETLINK_CB(cb->skb).portid, cb->nlh->nlmsg_seq,
|
||||||
&ip_vs_genl_family, NLM_F_MULTI,
|
&ip_vs_genl_family, NLM_F_MULTI,
|
||||||
IPVS_CMD_NEW_DEST);
|
IPVS_CMD_NEW_DEST);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
@ -3257,7 +3257,7 @@ static int ip_vs_genl_dump_daemon(struct sk_buff *skb, __be32 state,
|
|||||||
struct netlink_callback *cb)
|
struct netlink_callback *cb)
|
||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
hdr = genlmsg_put(skb, NETLINK_CB(cb->skb).pid, cb->nlh->nlmsg_seq,
|
hdr = genlmsg_put(skb, NETLINK_CB(cb->skb).portid, cb->nlh->nlmsg_seq,
|
||||||
&ip_vs_genl_family, NLM_F_MULTI,
|
&ip_vs_genl_family, NLM_F_MULTI,
|
||||||
IPVS_CMD_NEW_DAEMON);
|
IPVS_CMD_NEW_DAEMON);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
|
@ -61,7 +61,7 @@ void nf_ct_deliver_cached_events(struct nf_conn *ct)
|
|||||||
goto out_unlock;
|
goto out_unlock;
|
||||||
|
|
||||||
item.ct = ct;
|
item.ct = ct;
|
||||||
item.pid = 0;
|
item.portid = 0;
|
||||||
item.report = 0;
|
item.report = 0;
|
||||||
|
|
||||||
ret = notify->fcn(events | missed, &item);
|
ret = notify->fcn(events | missed, &item);
|
||||||
|
@ -418,16 +418,16 @@ ctnetlink_dump_use(struct sk_buff *skb, const struct nf_conn *ct)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
ctnetlink_fill_info(struct sk_buff *skb, u32 pid, u32 seq, u32 type,
|
ctnetlink_fill_info(struct sk_buff *skb, u32 portid, u32 seq, u32 type,
|
||||||
struct nf_conn *ct)
|
struct nf_conn *ct)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct nfgenmsg *nfmsg;
|
struct nfgenmsg *nfmsg;
|
||||||
struct nlattr *nest_parms;
|
struct nlattr *nest_parms;
|
||||||
unsigned int flags = pid ? NLM_F_MULTI : 0, event;
|
unsigned int flags = portid ? NLM_F_MULTI : 0, event;
|
||||||
|
|
||||||
event = (NFNL_SUBSYS_CTNETLINK << 8 | IPCTNL_MSG_CT_NEW);
|
event = (NFNL_SUBSYS_CTNETLINK << 8 | IPCTNL_MSG_CT_NEW);
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*nfmsg), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*nfmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
goto nlmsg_failure;
|
goto nlmsg_failure;
|
||||||
|
|
||||||
@ -604,7 +604,7 @@ ctnetlink_conntrack_event(unsigned int events, struct nf_ct_event *item)
|
|||||||
goto errout;
|
goto errout;
|
||||||
|
|
||||||
type |= NFNL_SUBSYS_CTNETLINK << 8;
|
type |= NFNL_SUBSYS_CTNETLINK << 8;
|
||||||
nlh = nlmsg_put(skb, item->pid, 0, type, sizeof(*nfmsg), flags);
|
nlh = nlmsg_put(skb, item->portid, 0, type, sizeof(*nfmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
goto nlmsg_failure;
|
goto nlmsg_failure;
|
||||||
|
|
||||||
@ -680,7 +680,7 @@ ctnetlink_conntrack_event(unsigned int events, struct nf_ct_event *item)
|
|||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
|
|
||||||
nlmsg_end(skb, nlh);
|
nlmsg_end(skb, nlh);
|
||||||
err = nfnetlink_send(skb, net, item->pid, group, item->report,
|
err = nfnetlink_send(skb, net, item->portid, group, item->report,
|
||||||
GFP_ATOMIC);
|
GFP_ATOMIC);
|
||||||
if (err == -ENOBUFS || err == -EAGAIN)
|
if (err == -ENOBUFS || err == -EAGAIN)
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
@ -757,7 +757,7 @@ ctnetlink_dump_table(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
#endif
|
#endif
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
res =
|
res =
|
||||||
ctnetlink_fill_info(skb, NETLINK_CB(cb->skb).pid,
|
ctnetlink_fill_info(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
NFNL_MSG_TYPE(cb->nlh->nlmsg_type),
|
NFNL_MSG_TYPE(cb->nlh->nlmsg_type),
|
||||||
ct);
|
ct);
|
||||||
@ -961,7 +961,7 @@ ctnetlink_del_conntrack(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
else {
|
else {
|
||||||
/* Flush the whole table */
|
/* Flush the whole table */
|
||||||
nf_conntrack_flush_report(net,
|
nf_conntrack_flush_report(net,
|
||||||
NETLINK_CB(skb).pid,
|
NETLINK_CB(skb).portid,
|
||||||
nlmsg_report(nlh));
|
nlmsg_report(nlh));
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -985,7 +985,7 @@ ctnetlink_del_conntrack(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
|
|
||||||
if (del_timer(&ct->timeout)) {
|
if (del_timer(&ct->timeout)) {
|
||||||
if (nf_conntrack_event_report(IPCT_DESTROY, ct,
|
if (nf_conntrack_event_report(IPCT_DESTROY, ct,
|
||||||
NETLINK_CB(skb).pid,
|
NETLINK_CB(skb).portid,
|
||||||
nlmsg_report(nlh)) < 0) {
|
nlmsg_report(nlh)) < 0) {
|
||||||
nf_ct_delete_from_lists(ct);
|
nf_ct_delete_from_lists(ct);
|
||||||
/* we failed to report the event, try later */
|
/* we failed to report the event, try later */
|
||||||
@ -1069,14 +1069,14 @@ ctnetlink_get_conntrack(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
err = ctnetlink_fill_info(skb2, NETLINK_CB(skb).pid, nlh->nlmsg_seq,
|
err = ctnetlink_fill_info(skb2, NETLINK_CB(skb).portid, nlh->nlmsg_seq,
|
||||||
NFNL_MSG_TYPE(nlh->nlmsg_type), ct);
|
NFNL_MSG_TYPE(nlh->nlmsg_type), ct);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
nf_ct_put(ct);
|
nf_ct_put(ct);
|
||||||
if (err <= 0)
|
if (err <= 0)
|
||||||
goto free;
|
goto free;
|
||||||
|
|
||||||
err = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).pid, MSG_DONTWAIT);
|
err = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).portid, MSG_DONTWAIT);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
@ -1616,7 +1616,7 @@ ctnetlink_new_conntrack(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
(1 << IPCT_PROTOINFO) |
|
(1 << IPCT_PROTOINFO) |
|
||||||
(1 << IPCT_NATSEQADJ) |
|
(1 << IPCT_NATSEQADJ) |
|
||||||
(1 << IPCT_MARK) | events,
|
(1 << IPCT_MARK) | events,
|
||||||
ct, NETLINK_CB(skb).pid,
|
ct, NETLINK_CB(skb).portid,
|
||||||
nlmsg_report(nlh));
|
nlmsg_report(nlh));
|
||||||
nf_ct_put(ct);
|
nf_ct_put(ct);
|
||||||
}
|
}
|
||||||
@ -1638,7 +1638,7 @@ ctnetlink_new_conntrack(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
(1 << IPCT_PROTOINFO) |
|
(1 << IPCT_PROTOINFO) |
|
||||||
(1 << IPCT_NATSEQADJ) |
|
(1 << IPCT_NATSEQADJ) |
|
||||||
(1 << IPCT_MARK),
|
(1 << IPCT_MARK),
|
||||||
ct, NETLINK_CB(skb).pid,
|
ct, NETLINK_CB(skb).portid,
|
||||||
nlmsg_report(nlh));
|
nlmsg_report(nlh));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1648,15 +1648,15 @@ ctnetlink_new_conntrack(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
ctnetlink_ct_stat_cpu_fill_info(struct sk_buff *skb, u32 pid, u32 seq,
|
ctnetlink_ct_stat_cpu_fill_info(struct sk_buff *skb, u32 portid, u32 seq,
|
||||||
__u16 cpu, const struct ip_conntrack_stat *st)
|
__u16 cpu, const struct ip_conntrack_stat *st)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct nfgenmsg *nfmsg;
|
struct nfgenmsg *nfmsg;
|
||||||
unsigned int flags = pid ? NLM_F_MULTI : 0, event;
|
unsigned int flags = portid ? NLM_F_MULTI : 0, event;
|
||||||
|
|
||||||
event = (NFNL_SUBSYS_CTNETLINK << 8 | IPCTNL_MSG_CT_GET_STATS_CPU);
|
event = (NFNL_SUBSYS_CTNETLINK << 8 | IPCTNL_MSG_CT_GET_STATS_CPU);
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*nfmsg), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*nfmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
goto nlmsg_failure;
|
goto nlmsg_failure;
|
||||||
|
|
||||||
@ -1708,7 +1708,7 @@ ctnetlink_ct_stat_cpu_dump(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
|
|
||||||
st = per_cpu_ptr(net->ct.stat, cpu);
|
st = per_cpu_ptr(net->ct.stat, cpu);
|
||||||
if (ctnetlink_ct_stat_cpu_fill_info(skb,
|
if (ctnetlink_ct_stat_cpu_fill_info(skb,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
cpu, st) < 0)
|
cpu, st) < 0)
|
||||||
break;
|
break;
|
||||||
@ -1734,16 +1734,16 @@ ctnetlink_stat_ct_cpu(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
ctnetlink_stat_ct_fill_info(struct sk_buff *skb, u32 pid, u32 seq, u32 type,
|
ctnetlink_stat_ct_fill_info(struct sk_buff *skb, u32 portid, u32 seq, u32 type,
|
||||||
struct net *net)
|
struct net *net)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct nfgenmsg *nfmsg;
|
struct nfgenmsg *nfmsg;
|
||||||
unsigned int flags = pid ? NLM_F_MULTI : 0, event;
|
unsigned int flags = portid ? NLM_F_MULTI : 0, event;
|
||||||
unsigned int nr_conntracks = atomic_read(&net->ct.count);
|
unsigned int nr_conntracks = atomic_read(&net->ct.count);
|
||||||
|
|
||||||
event = (NFNL_SUBSYS_CTNETLINK << 8 | IPCTNL_MSG_CT_GET_STATS);
|
event = (NFNL_SUBSYS_CTNETLINK << 8 | IPCTNL_MSG_CT_GET_STATS);
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*nfmsg), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*nfmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
goto nlmsg_failure;
|
goto nlmsg_failure;
|
||||||
|
|
||||||
@ -1776,14 +1776,14 @@ ctnetlink_stat_ct(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
if (skb2 == NULL)
|
if (skb2 == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
err = ctnetlink_stat_ct_fill_info(skb2, NETLINK_CB(skb).pid,
|
err = ctnetlink_stat_ct_fill_info(skb2, NETLINK_CB(skb).portid,
|
||||||
nlh->nlmsg_seq,
|
nlh->nlmsg_seq,
|
||||||
NFNL_MSG_TYPE(nlh->nlmsg_type),
|
NFNL_MSG_TYPE(nlh->nlmsg_type),
|
||||||
sock_net(skb->sk));
|
sock_net(skb->sk));
|
||||||
if (err <= 0)
|
if (err <= 0)
|
||||||
goto free;
|
goto free;
|
||||||
|
|
||||||
err = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).pid, MSG_DONTWAIT);
|
err = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).portid, MSG_DONTWAIT);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
@ -2073,15 +2073,15 @@ ctnetlink_exp_dump_expect(struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
ctnetlink_exp_fill_info(struct sk_buff *skb, u32 pid, u32 seq,
|
ctnetlink_exp_fill_info(struct sk_buff *skb, u32 portid, u32 seq,
|
||||||
int event, const struct nf_conntrack_expect *exp)
|
int event, const struct nf_conntrack_expect *exp)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct nfgenmsg *nfmsg;
|
struct nfgenmsg *nfmsg;
|
||||||
unsigned int flags = pid ? NLM_F_MULTI : 0;
|
unsigned int flags = portid ? NLM_F_MULTI : 0;
|
||||||
|
|
||||||
event |= NFNL_SUBSYS_CTNETLINK_EXP << 8;
|
event |= NFNL_SUBSYS_CTNETLINK_EXP << 8;
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*nfmsg), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*nfmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
goto nlmsg_failure;
|
goto nlmsg_failure;
|
||||||
|
|
||||||
@ -2132,7 +2132,7 @@ ctnetlink_expect_event(unsigned int events, struct nf_exp_event *item)
|
|||||||
goto errout;
|
goto errout;
|
||||||
|
|
||||||
type |= NFNL_SUBSYS_CTNETLINK_EXP << 8;
|
type |= NFNL_SUBSYS_CTNETLINK_EXP << 8;
|
||||||
nlh = nlmsg_put(skb, item->pid, 0, type, sizeof(*nfmsg), flags);
|
nlh = nlmsg_put(skb, item->portid, 0, type, sizeof(*nfmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
goto nlmsg_failure;
|
goto nlmsg_failure;
|
||||||
|
|
||||||
@ -2147,7 +2147,7 @@ ctnetlink_expect_event(unsigned int events, struct nf_exp_event *item)
|
|||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
|
|
||||||
nlmsg_end(skb, nlh);
|
nlmsg_end(skb, nlh);
|
||||||
nfnetlink_send(skb, net, item->pid, group, item->report, GFP_ATOMIC);
|
nfnetlink_send(skb, net, item->portid, group, item->report, GFP_ATOMIC);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
nla_put_failure:
|
nla_put_failure:
|
||||||
@ -2190,7 +2190,7 @@ ctnetlink_exp_dump_table(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
cb->args[1] = 0;
|
cb->args[1] = 0;
|
||||||
}
|
}
|
||||||
if (ctnetlink_exp_fill_info(skb,
|
if (ctnetlink_exp_fill_info(skb,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
IPCTNL_MSG_EXP_NEW,
|
IPCTNL_MSG_EXP_NEW,
|
||||||
exp) < 0) {
|
exp) < 0) {
|
||||||
@ -2283,14 +2283,14 @@ ctnetlink_get_expect(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
err = ctnetlink_exp_fill_info(skb2, NETLINK_CB(skb).pid,
|
err = ctnetlink_exp_fill_info(skb2, NETLINK_CB(skb).portid,
|
||||||
nlh->nlmsg_seq, IPCTNL_MSG_EXP_NEW, exp);
|
nlh->nlmsg_seq, IPCTNL_MSG_EXP_NEW, exp);
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
nf_ct_expect_put(exp);
|
nf_ct_expect_put(exp);
|
||||||
if (err <= 0)
|
if (err <= 0)
|
||||||
goto free;
|
goto free;
|
||||||
|
|
||||||
err = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).pid, MSG_DONTWAIT);
|
err = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).portid, MSG_DONTWAIT);
|
||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
@ -2344,7 +2344,7 @@ ctnetlink_del_expect(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
/* after list removal, usage count == 1 */
|
/* after list removal, usage count == 1 */
|
||||||
spin_lock_bh(&nf_conntrack_lock);
|
spin_lock_bh(&nf_conntrack_lock);
|
||||||
if (del_timer(&exp->timeout)) {
|
if (del_timer(&exp->timeout)) {
|
||||||
nf_ct_unlink_expect_report(exp, NETLINK_CB(skb).pid,
|
nf_ct_unlink_expect_report(exp, NETLINK_CB(skb).portid,
|
||||||
nlmsg_report(nlh));
|
nlmsg_report(nlh));
|
||||||
nf_ct_expect_put(exp);
|
nf_ct_expect_put(exp);
|
||||||
}
|
}
|
||||||
@ -2366,7 +2366,7 @@ ctnetlink_del_expect(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
if (!strcmp(m_help->helper->name, name) &&
|
if (!strcmp(m_help->helper->name, name) &&
|
||||||
del_timer(&exp->timeout)) {
|
del_timer(&exp->timeout)) {
|
||||||
nf_ct_unlink_expect_report(exp,
|
nf_ct_unlink_expect_report(exp,
|
||||||
NETLINK_CB(skb).pid,
|
NETLINK_CB(skb).portid,
|
||||||
nlmsg_report(nlh));
|
nlmsg_report(nlh));
|
||||||
nf_ct_expect_put(exp);
|
nf_ct_expect_put(exp);
|
||||||
}
|
}
|
||||||
@ -2382,7 +2382,7 @@ ctnetlink_del_expect(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
hnode) {
|
hnode) {
|
||||||
if (del_timer(&exp->timeout)) {
|
if (del_timer(&exp->timeout)) {
|
||||||
nf_ct_unlink_expect_report(exp,
|
nf_ct_unlink_expect_report(exp,
|
||||||
NETLINK_CB(skb).pid,
|
NETLINK_CB(skb).portid,
|
||||||
nlmsg_report(nlh));
|
nlmsg_report(nlh));
|
||||||
nf_ct_expect_put(exp);
|
nf_ct_expect_put(exp);
|
||||||
}
|
}
|
||||||
@ -2447,7 +2447,7 @@ static int
|
|||||||
ctnetlink_create_expect(struct net *net, u16 zone,
|
ctnetlink_create_expect(struct net *net, u16 zone,
|
||||||
const struct nlattr * const cda[],
|
const struct nlattr * const cda[],
|
||||||
u_int8_t u3,
|
u_int8_t u3,
|
||||||
u32 pid, int report)
|
u32 portid, int report)
|
||||||
{
|
{
|
||||||
struct nf_conntrack_tuple tuple, mask, master_tuple;
|
struct nf_conntrack_tuple tuple, mask, master_tuple;
|
||||||
struct nf_conntrack_tuple_hash *h = NULL;
|
struct nf_conntrack_tuple_hash *h = NULL;
|
||||||
@ -2560,7 +2560,7 @@ ctnetlink_create_expect(struct net *net, u16 zone,
|
|||||||
if (err < 0)
|
if (err < 0)
|
||||||
goto err_out;
|
goto err_out;
|
||||||
}
|
}
|
||||||
err = nf_ct_expect_related_report(exp, pid, report);
|
err = nf_ct_expect_related_report(exp, portid, report);
|
||||||
err_out:
|
err_out:
|
||||||
nf_ct_expect_put(exp);
|
nf_ct_expect_put(exp);
|
||||||
out:
|
out:
|
||||||
@ -2603,7 +2603,7 @@ ctnetlink_new_expect(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
if (nlh->nlmsg_flags & NLM_F_CREATE) {
|
if (nlh->nlmsg_flags & NLM_F_CREATE) {
|
||||||
err = ctnetlink_create_expect(net, zone, cda,
|
err = ctnetlink_create_expect(net, zone, cda,
|
||||||
u3,
|
u3,
|
||||||
NETLINK_CB(skb).pid,
|
NETLINK_CB(skb).portid,
|
||||||
nlmsg_report(nlh));
|
nlmsg_report(nlh));
|
||||||
}
|
}
|
||||||
return err;
|
return err;
|
||||||
@ -2618,15 +2618,15 @@ ctnetlink_new_expect(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
ctnetlink_exp_stat_fill_info(struct sk_buff *skb, u32 pid, u32 seq, int cpu,
|
ctnetlink_exp_stat_fill_info(struct sk_buff *skb, u32 portid, u32 seq, int cpu,
|
||||||
const struct ip_conntrack_stat *st)
|
const struct ip_conntrack_stat *st)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct nfgenmsg *nfmsg;
|
struct nfgenmsg *nfmsg;
|
||||||
unsigned int flags = pid ? NLM_F_MULTI : 0, event;
|
unsigned int flags = portid ? NLM_F_MULTI : 0, event;
|
||||||
|
|
||||||
event = (NFNL_SUBSYS_CTNETLINK << 8 | IPCTNL_MSG_EXP_GET_STATS_CPU);
|
event = (NFNL_SUBSYS_CTNETLINK << 8 | IPCTNL_MSG_EXP_GET_STATS_CPU);
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*nfmsg), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*nfmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
goto nlmsg_failure;
|
goto nlmsg_failure;
|
||||||
|
|
||||||
@ -2665,7 +2665,7 @@ ctnetlink_exp_stat_cpu_dump(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
st = per_cpu_ptr(net->ct.stat, cpu);
|
st = per_cpu_ptr(net->ct.stat, cpu);
|
||||||
if (ctnetlink_exp_stat_fill_info(skb, NETLINK_CB(cb->skb).pid,
|
if (ctnetlink_exp_stat_fill_info(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
cpu, st) < 0)
|
cpu, st) < 0)
|
||||||
break;
|
break;
|
||||||
|
@ -91,16 +91,16 @@ nfnl_acct_new(struct sock *nfnl, struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
nfnl_acct_fill_info(struct sk_buff *skb, u32 pid, u32 seq, u32 type,
|
nfnl_acct_fill_info(struct sk_buff *skb, u32 portid, u32 seq, u32 type,
|
||||||
int event, struct nf_acct *acct)
|
int event, struct nf_acct *acct)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct nfgenmsg *nfmsg;
|
struct nfgenmsg *nfmsg;
|
||||||
unsigned int flags = pid ? NLM_F_MULTI : 0;
|
unsigned int flags = portid ? NLM_F_MULTI : 0;
|
||||||
u64 pkts, bytes;
|
u64 pkts, bytes;
|
||||||
|
|
||||||
event |= NFNL_SUBSYS_ACCT << 8;
|
event |= NFNL_SUBSYS_ACCT << 8;
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*nfmsg), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*nfmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
goto nlmsg_failure;
|
goto nlmsg_failure;
|
||||||
|
|
||||||
@ -150,7 +150,7 @@ nfnl_acct_dump(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (last && cur != last)
|
if (last && cur != last)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (nfnl_acct_fill_info(skb, NETLINK_CB(cb->skb).pid,
|
if (nfnl_acct_fill_info(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
NFNL_MSG_TYPE(cb->nlh->nlmsg_type),
|
NFNL_MSG_TYPE(cb->nlh->nlmsg_type),
|
||||||
NFNL_MSG_ACCT_NEW, cur) < 0) {
|
NFNL_MSG_ACCT_NEW, cur) < 0) {
|
||||||
@ -195,7 +195,7 @@ nfnl_acct_get(struct sock *nfnl, struct sk_buff *skb,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = nfnl_acct_fill_info(skb2, NETLINK_CB(skb).pid,
|
ret = nfnl_acct_fill_info(skb2, NETLINK_CB(skb).portid,
|
||||||
nlh->nlmsg_seq,
|
nlh->nlmsg_seq,
|
||||||
NFNL_MSG_TYPE(nlh->nlmsg_type),
|
NFNL_MSG_TYPE(nlh->nlmsg_type),
|
||||||
NFNL_MSG_ACCT_NEW, cur);
|
NFNL_MSG_ACCT_NEW, cur);
|
||||||
@ -203,7 +203,7 @@ nfnl_acct_get(struct sock *nfnl, struct sk_buff *skb,
|
|||||||
kfree_skb(skb2);
|
kfree_skb(skb2);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
ret = netlink_unicast(nfnl, skb2, NETLINK_CB(skb).pid,
|
ret = netlink_unicast(nfnl, skb2, NETLINK_CB(skb).portid,
|
||||||
MSG_DONTWAIT);
|
MSG_DONTWAIT);
|
||||||
if (ret > 0)
|
if (ret > 0)
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
@ -395,16 +395,16 @@ nfnl_cthelper_dump_policy(struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
nfnl_cthelper_fill_info(struct sk_buff *skb, u32 pid, u32 seq, u32 type,
|
nfnl_cthelper_fill_info(struct sk_buff *skb, u32 portid, u32 seq, u32 type,
|
||||||
int event, struct nf_conntrack_helper *helper)
|
int event, struct nf_conntrack_helper *helper)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct nfgenmsg *nfmsg;
|
struct nfgenmsg *nfmsg;
|
||||||
unsigned int flags = pid ? NLM_F_MULTI : 0;
|
unsigned int flags = portid ? NLM_F_MULTI : 0;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
event |= NFNL_SUBSYS_CTHELPER << 8;
|
event |= NFNL_SUBSYS_CTHELPER << 8;
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*nfmsg), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*nfmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
goto nlmsg_failure;
|
goto nlmsg_failure;
|
||||||
|
|
||||||
@ -468,7 +468,7 @@ nfnl_cthelper_dump_table(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
cb->args[1] = 0;
|
cb->args[1] = 0;
|
||||||
}
|
}
|
||||||
if (nfnl_cthelper_fill_info(skb,
|
if (nfnl_cthelper_fill_info(skb,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
NFNL_MSG_TYPE(cb->nlh->nlmsg_type),
|
NFNL_MSG_TYPE(cb->nlh->nlmsg_type),
|
||||||
NFNL_MSG_CTHELPER_NEW, cur) < 0) {
|
NFNL_MSG_CTHELPER_NEW, cur) < 0) {
|
||||||
@ -538,7 +538,7 @@ nfnl_cthelper_get(struct sock *nfnl, struct sk_buff *skb,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = nfnl_cthelper_fill_info(skb2, NETLINK_CB(skb).pid,
|
ret = nfnl_cthelper_fill_info(skb2, NETLINK_CB(skb).portid,
|
||||||
nlh->nlmsg_seq,
|
nlh->nlmsg_seq,
|
||||||
NFNL_MSG_TYPE(nlh->nlmsg_type),
|
NFNL_MSG_TYPE(nlh->nlmsg_type),
|
||||||
NFNL_MSG_CTHELPER_NEW, cur);
|
NFNL_MSG_CTHELPER_NEW, cur);
|
||||||
@ -547,7 +547,7 @@ nfnl_cthelper_get(struct sock *nfnl, struct sk_buff *skb,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = netlink_unicast(nfnl, skb2, NETLINK_CB(skb).pid,
|
ret = netlink_unicast(nfnl, skb2, NETLINK_CB(skb).portid,
|
||||||
MSG_DONTWAIT);
|
MSG_DONTWAIT);
|
||||||
if (ret > 0)
|
if (ret > 0)
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
@ -155,16 +155,16 @@ cttimeout_new_timeout(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
ctnl_timeout_fill_info(struct sk_buff *skb, u32 pid, u32 seq, u32 type,
|
ctnl_timeout_fill_info(struct sk_buff *skb, u32 portid, u32 seq, u32 type,
|
||||||
int event, struct ctnl_timeout *timeout)
|
int event, struct ctnl_timeout *timeout)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct nfgenmsg *nfmsg;
|
struct nfgenmsg *nfmsg;
|
||||||
unsigned int flags = pid ? NLM_F_MULTI : 0;
|
unsigned int flags = portid ? NLM_F_MULTI : 0;
|
||||||
struct nf_conntrack_l4proto *l4proto = timeout->l4proto;
|
struct nf_conntrack_l4proto *l4proto = timeout->l4proto;
|
||||||
|
|
||||||
event |= NFNL_SUBSYS_CTNETLINK_TIMEOUT << 8;
|
event |= NFNL_SUBSYS_CTNETLINK_TIMEOUT << 8;
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*nfmsg), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*nfmsg), flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
goto nlmsg_failure;
|
goto nlmsg_failure;
|
||||||
|
|
||||||
@ -222,7 +222,7 @@ ctnl_timeout_dump(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (last && cur != last)
|
if (last && cur != last)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (ctnl_timeout_fill_info(skb, NETLINK_CB(cb->skb).pid,
|
if (ctnl_timeout_fill_info(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
NFNL_MSG_TYPE(cb->nlh->nlmsg_type),
|
NFNL_MSG_TYPE(cb->nlh->nlmsg_type),
|
||||||
IPCTNL_MSG_TIMEOUT_NEW, cur) < 0) {
|
IPCTNL_MSG_TIMEOUT_NEW, cur) < 0) {
|
||||||
@ -268,7 +268,7 @@ cttimeout_get_timeout(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = ctnl_timeout_fill_info(skb2, NETLINK_CB(skb).pid,
|
ret = ctnl_timeout_fill_info(skb2, NETLINK_CB(skb).portid,
|
||||||
nlh->nlmsg_seq,
|
nlh->nlmsg_seq,
|
||||||
NFNL_MSG_TYPE(nlh->nlmsg_type),
|
NFNL_MSG_TYPE(nlh->nlmsg_type),
|
||||||
IPCTNL_MSG_TIMEOUT_NEW, cur);
|
IPCTNL_MSG_TIMEOUT_NEW, cur);
|
||||||
@ -276,7 +276,7 @@ cttimeout_get_timeout(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
kfree_skb(skb2);
|
kfree_skb(skb2);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
ret = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).pid,
|
ret = netlink_unicast(ctnl, skb2, NETLINK_CB(skb).portid,
|
||||||
MSG_DONTWAIT);
|
MSG_DONTWAIT);
|
||||||
if (ret > 0)
|
if (ret > 0)
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
@ -56,7 +56,7 @@ struct nfulnl_instance {
|
|||||||
struct sk_buff *skb; /* pre-allocatd skb */
|
struct sk_buff *skb; /* pre-allocatd skb */
|
||||||
struct timer_list timer;
|
struct timer_list timer;
|
||||||
struct user_namespace *peer_user_ns; /* User namespace of the peer process */
|
struct user_namespace *peer_user_ns; /* User namespace of the peer process */
|
||||||
int peer_pid; /* PID of the peer process */
|
int peer_portid; /* PORTID of the peer process */
|
||||||
|
|
||||||
/* configurable parameters */
|
/* configurable parameters */
|
||||||
unsigned int flushtimeout; /* timeout until queue flush */
|
unsigned int flushtimeout; /* timeout until queue flush */
|
||||||
@ -133,7 +133,7 @@ instance_put(struct nfulnl_instance *inst)
|
|||||||
static void nfulnl_timer(unsigned long data);
|
static void nfulnl_timer(unsigned long data);
|
||||||
|
|
||||||
static struct nfulnl_instance *
|
static struct nfulnl_instance *
|
||||||
instance_create(u_int16_t group_num, int pid, struct user_namespace *user_ns)
|
instance_create(u_int16_t group_num, int portid, struct user_namespace *user_ns)
|
||||||
{
|
{
|
||||||
struct nfulnl_instance *inst;
|
struct nfulnl_instance *inst;
|
||||||
int err;
|
int err;
|
||||||
@ -164,7 +164,7 @@ instance_create(u_int16_t group_num, int pid, struct user_namespace *user_ns)
|
|||||||
setup_timer(&inst->timer, nfulnl_timer, (unsigned long)inst);
|
setup_timer(&inst->timer, nfulnl_timer, (unsigned long)inst);
|
||||||
|
|
||||||
inst->peer_user_ns = user_ns;
|
inst->peer_user_ns = user_ns;
|
||||||
inst->peer_pid = pid;
|
inst->peer_portid = portid;
|
||||||
inst->group_num = group_num;
|
inst->group_num = group_num;
|
||||||
|
|
||||||
inst->qthreshold = NFULNL_QTHRESH_DEFAULT;
|
inst->qthreshold = NFULNL_QTHRESH_DEFAULT;
|
||||||
@ -336,7 +336,7 @@ __nfulnl_send(struct nfulnl_instance *inst)
|
|||||||
if (!nlh)
|
if (!nlh)
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
status = nfnetlink_unicast(inst->skb, &init_net, inst->peer_pid,
|
status = nfnetlink_unicast(inst->skb, &init_net, inst->peer_portid,
|
||||||
MSG_DONTWAIT);
|
MSG_DONTWAIT);
|
||||||
|
|
||||||
inst->qlen = 0;
|
inst->qlen = 0;
|
||||||
@ -703,7 +703,7 @@ nfulnl_rcv_nl_event(struct notifier_block *this,
|
|||||||
if (event == NETLINK_URELEASE && n->protocol == NETLINK_NETFILTER) {
|
if (event == NETLINK_URELEASE && n->protocol == NETLINK_NETFILTER) {
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
/* destroy all instances for this pid */
|
/* destroy all instances for this portid */
|
||||||
spin_lock_bh(&instances_lock);
|
spin_lock_bh(&instances_lock);
|
||||||
for (i = 0; i < INSTANCE_BUCKETS; i++) {
|
for (i = 0; i < INSTANCE_BUCKETS; i++) {
|
||||||
struct hlist_node *tmp, *t2;
|
struct hlist_node *tmp, *t2;
|
||||||
@ -712,7 +712,7 @@ nfulnl_rcv_nl_event(struct notifier_block *this,
|
|||||||
|
|
||||||
hlist_for_each_entry_safe(inst, tmp, t2, head, hlist) {
|
hlist_for_each_entry_safe(inst, tmp, t2, head, hlist) {
|
||||||
if ((net_eq(n->net, &init_net)) &&
|
if ((net_eq(n->net, &init_net)) &&
|
||||||
(n->pid == inst->peer_pid))
|
(n->portid == inst->peer_portid))
|
||||||
__instance_destroy(inst);
|
__instance_destroy(inst);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -774,7 +774,7 @@ nfulnl_recv_config(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
inst = instance_lookup_get(group_num);
|
inst = instance_lookup_get(group_num);
|
||||||
if (inst && inst->peer_pid != NETLINK_CB(skb).pid) {
|
if (inst && inst->peer_portid != NETLINK_CB(skb).portid) {
|
||||||
ret = -EPERM;
|
ret = -EPERM;
|
||||||
goto out_put;
|
goto out_put;
|
||||||
}
|
}
|
||||||
@ -788,7 +788,7 @@ nfulnl_recv_config(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
inst = instance_create(group_num,
|
inst = instance_create(group_num,
|
||||||
NETLINK_CB(skb).pid,
|
NETLINK_CB(skb).portid,
|
||||||
sk_user_ns(NETLINK_CB(skb).ssk));
|
sk_user_ns(NETLINK_CB(skb).ssk));
|
||||||
if (IS_ERR(inst)) {
|
if (IS_ERR(inst)) {
|
||||||
ret = PTR_ERR(inst);
|
ret = PTR_ERR(inst);
|
||||||
@ -947,7 +947,7 @@ static int seq_show(struct seq_file *s, void *v)
|
|||||||
|
|
||||||
return seq_printf(s, "%5d %6d %5d %1d %5d %6d %2d\n",
|
return seq_printf(s, "%5d %6d %5d %1d %5d %6d %2d\n",
|
||||||
inst->group_num,
|
inst->group_num,
|
||||||
inst->peer_pid, inst->qlen,
|
inst->peer_portid, inst->qlen,
|
||||||
inst->copy_mode, inst->copy_range,
|
inst->copy_mode, inst->copy_range,
|
||||||
inst->flushtimeout, atomic_read(&inst->use));
|
inst->flushtimeout, atomic_read(&inst->use));
|
||||||
}
|
}
|
||||||
|
@ -44,7 +44,7 @@ struct nfqnl_instance {
|
|||||||
struct hlist_node hlist; /* global list of queues */
|
struct hlist_node hlist; /* global list of queues */
|
||||||
struct rcu_head rcu;
|
struct rcu_head rcu;
|
||||||
|
|
||||||
int peer_pid;
|
int peer_portid;
|
||||||
unsigned int queue_maxlen;
|
unsigned int queue_maxlen;
|
||||||
unsigned int copy_range;
|
unsigned int copy_range;
|
||||||
unsigned int queue_dropped;
|
unsigned int queue_dropped;
|
||||||
@ -92,7 +92,7 @@ instance_lookup(u_int16_t queue_num)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static struct nfqnl_instance *
|
static struct nfqnl_instance *
|
||||||
instance_create(u_int16_t queue_num, int pid)
|
instance_create(u_int16_t queue_num, int portid)
|
||||||
{
|
{
|
||||||
struct nfqnl_instance *inst;
|
struct nfqnl_instance *inst;
|
||||||
unsigned int h;
|
unsigned int h;
|
||||||
@ -111,7 +111,7 @@ instance_create(u_int16_t queue_num, int pid)
|
|||||||
}
|
}
|
||||||
|
|
||||||
inst->queue_num = queue_num;
|
inst->queue_num = queue_num;
|
||||||
inst->peer_pid = pid;
|
inst->peer_portid = portid;
|
||||||
inst->queue_maxlen = NFQNL_QMAX_DEFAULT;
|
inst->queue_maxlen = NFQNL_QMAX_DEFAULT;
|
||||||
inst->copy_range = 0xfffff;
|
inst->copy_range = 0xfffff;
|
||||||
inst->copy_mode = NFQNL_COPY_NONE;
|
inst->copy_mode = NFQNL_COPY_NONE;
|
||||||
@ -440,7 +440,7 @@ nfqnl_enqueue_packet(struct nf_queue_entry *entry, unsigned int queuenum)
|
|||||||
}
|
}
|
||||||
spin_lock_bh(&queue->lock);
|
spin_lock_bh(&queue->lock);
|
||||||
|
|
||||||
if (!queue->peer_pid) {
|
if (!queue->peer_portid) {
|
||||||
err = -EINVAL;
|
err = -EINVAL;
|
||||||
goto err_out_free_nskb;
|
goto err_out_free_nskb;
|
||||||
}
|
}
|
||||||
@ -459,7 +459,7 @@ nfqnl_enqueue_packet(struct nf_queue_entry *entry, unsigned int queuenum)
|
|||||||
*packet_id_ptr = htonl(entry->id);
|
*packet_id_ptr = htonl(entry->id);
|
||||||
|
|
||||||
/* nfnetlink_unicast will either free the nskb or add it to a socket */
|
/* nfnetlink_unicast will either free the nskb or add it to a socket */
|
||||||
err = nfnetlink_unicast(nskb, &init_net, queue->peer_pid, MSG_DONTWAIT);
|
err = nfnetlink_unicast(nskb, &init_net, queue->peer_portid, MSG_DONTWAIT);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
queue->queue_user_dropped++;
|
queue->queue_user_dropped++;
|
||||||
goto err_out_unlock;
|
goto err_out_unlock;
|
||||||
@ -616,7 +616,7 @@ nfqnl_rcv_nl_event(struct notifier_block *this,
|
|||||||
if (event == NETLINK_URELEASE && n->protocol == NETLINK_NETFILTER) {
|
if (event == NETLINK_URELEASE && n->protocol == NETLINK_NETFILTER) {
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
/* destroy all instances for this pid */
|
/* destroy all instances for this portid */
|
||||||
spin_lock(&instances_lock);
|
spin_lock(&instances_lock);
|
||||||
for (i = 0; i < INSTANCE_BUCKETS; i++) {
|
for (i = 0; i < INSTANCE_BUCKETS; i++) {
|
||||||
struct hlist_node *tmp, *t2;
|
struct hlist_node *tmp, *t2;
|
||||||
@ -625,7 +625,7 @@ nfqnl_rcv_nl_event(struct notifier_block *this,
|
|||||||
|
|
||||||
hlist_for_each_entry_safe(inst, tmp, t2, head, hlist) {
|
hlist_for_each_entry_safe(inst, tmp, t2, head, hlist) {
|
||||||
if ((n->net == &init_net) &&
|
if ((n->net == &init_net) &&
|
||||||
(n->pid == inst->peer_pid))
|
(n->portid == inst->peer_portid))
|
||||||
__instance_destroy(inst);
|
__instance_destroy(inst);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -650,7 +650,7 @@ static const struct nla_policy nfqa_verdict_batch_policy[NFQA_MAX+1] = {
|
|||||||
[NFQA_MARK] = { .type = NLA_U32 },
|
[NFQA_MARK] = { .type = NLA_U32 },
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct nfqnl_instance *verdict_instance_lookup(u16 queue_num, int nlpid)
|
static struct nfqnl_instance *verdict_instance_lookup(u16 queue_num, int nlportid)
|
||||||
{
|
{
|
||||||
struct nfqnl_instance *queue;
|
struct nfqnl_instance *queue;
|
||||||
|
|
||||||
@ -658,7 +658,7 @@ static struct nfqnl_instance *verdict_instance_lookup(u16 queue_num, int nlpid)
|
|||||||
if (!queue)
|
if (!queue)
|
||||||
return ERR_PTR(-ENODEV);
|
return ERR_PTR(-ENODEV);
|
||||||
|
|
||||||
if (queue->peer_pid != nlpid)
|
if (queue->peer_portid != nlportid)
|
||||||
return ERR_PTR(-EPERM);
|
return ERR_PTR(-EPERM);
|
||||||
|
|
||||||
return queue;
|
return queue;
|
||||||
@ -698,7 +698,7 @@ nfqnl_recv_verdict_batch(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
LIST_HEAD(batch_list);
|
LIST_HEAD(batch_list);
|
||||||
u16 queue_num = ntohs(nfmsg->res_id);
|
u16 queue_num = ntohs(nfmsg->res_id);
|
||||||
|
|
||||||
queue = verdict_instance_lookup(queue_num, NETLINK_CB(skb).pid);
|
queue = verdict_instance_lookup(queue_num, NETLINK_CB(skb).portid);
|
||||||
if (IS_ERR(queue))
|
if (IS_ERR(queue))
|
||||||
return PTR_ERR(queue);
|
return PTR_ERR(queue);
|
||||||
|
|
||||||
@ -749,7 +749,7 @@ nfqnl_recv_verdict(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
queue = instance_lookup(queue_num);
|
queue = instance_lookup(queue_num);
|
||||||
if (!queue)
|
if (!queue)
|
||||||
|
|
||||||
queue = verdict_instance_lookup(queue_num, NETLINK_CB(skb).pid);
|
queue = verdict_instance_lookup(queue_num, NETLINK_CB(skb).portid);
|
||||||
if (IS_ERR(queue))
|
if (IS_ERR(queue))
|
||||||
return PTR_ERR(queue);
|
return PTR_ERR(queue);
|
||||||
|
|
||||||
@ -832,7 +832,7 @@ nfqnl_recv_config(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
|
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
queue = instance_lookup(queue_num);
|
queue = instance_lookup(queue_num);
|
||||||
if (queue && queue->peer_pid != NETLINK_CB(skb).pid) {
|
if (queue && queue->peer_portid != NETLINK_CB(skb).portid) {
|
||||||
ret = -EPERM;
|
ret = -EPERM;
|
||||||
goto err_out_unlock;
|
goto err_out_unlock;
|
||||||
}
|
}
|
||||||
@ -844,7 +844,7 @@ nfqnl_recv_config(struct sock *ctnl, struct sk_buff *skb,
|
|||||||
ret = -EBUSY;
|
ret = -EBUSY;
|
||||||
goto err_out_unlock;
|
goto err_out_unlock;
|
||||||
}
|
}
|
||||||
queue = instance_create(queue_num, NETLINK_CB(skb).pid);
|
queue = instance_create(queue_num, NETLINK_CB(skb).portid);
|
||||||
if (IS_ERR(queue)) {
|
if (IS_ERR(queue)) {
|
||||||
ret = PTR_ERR(queue);
|
ret = PTR_ERR(queue);
|
||||||
goto err_out_unlock;
|
goto err_out_unlock;
|
||||||
@ -1016,7 +1016,7 @@ static int seq_show(struct seq_file *s, void *v)
|
|||||||
|
|
||||||
return seq_printf(s, "%5d %6d %5d %1d %5d %5d %5d %8d %2d\n",
|
return seq_printf(s, "%5d %6d %5d %1d %5d %5d %5d %8d %2d\n",
|
||||||
inst->queue_num,
|
inst->queue_num,
|
||||||
inst->peer_pid, inst->queue_total,
|
inst->peer_portid, inst->queue_total,
|
||||||
inst->copy_mode, inst->copy_range,
|
inst->copy_mode, inst->copy_range,
|
||||||
inst->queue_dropped, inst->queue_user_dropped,
|
inst->queue_dropped, inst->queue_user_dropped,
|
||||||
inst->id_sequence, 1);
|
inst->id_sequence, 1);
|
||||||
|
@ -627,7 +627,7 @@ static int netlbl_cipsov4_listall_cb(struct cipso_v4_doi *doi_def, void *arg)
|
|||||||
struct netlbl_cipsov4_doiwalk_arg *cb_arg = arg;
|
struct netlbl_cipsov4_doiwalk_arg *cb_arg = arg;
|
||||||
void *data;
|
void *data;
|
||||||
|
|
||||||
data = genlmsg_put(cb_arg->skb, NETLINK_CB(cb_arg->nl_cb->skb).pid,
|
data = genlmsg_put(cb_arg->skb, NETLINK_CB(cb_arg->nl_cb->skb).portid,
|
||||||
cb_arg->seq, &netlbl_cipsov4_gnl_family,
|
cb_arg->seq, &netlbl_cipsov4_gnl_family,
|
||||||
NLM_F_MULTI, NLBL_CIPSOV4_C_LISTALL);
|
NLM_F_MULTI, NLBL_CIPSOV4_C_LISTALL);
|
||||||
if (data == NULL)
|
if (data == NULL)
|
||||||
|
@ -448,7 +448,7 @@ static int netlbl_mgmt_listall_cb(struct netlbl_dom_map *entry, void *arg)
|
|||||||
struct netlbl_domhsh_walk_arg *cb_arg = arg;
|
struct netlbl_domhsh_walk_arg *cb_arg = arg;
|
||||||
void *data;
|
void *data;
|
||||||
|
|
||||||
data = genlmsg_put(cb_arg->skb, NETLINK_CB(cb_arg->nl_cb->skb).pid,
|
data = genlmsg_put(cb_arg->skb, NETLINK_CB(cb_arg->nl_cb->skb).portid,
|
||||||
cb_arg->seq, &netlbl_mgmt_gnl_family,
|
cb_arg->seq, &netlbl_mgmt_gnl_family,
|
||||||
NLM_F_MULTI, NLBL_MGMT_C_LISTALL);
|
NLM_F_MULTI, NLBL_MGMT_C_LISTALL);
|
||||||
if (data == NULL)
|
if (data == NULL)
|
||||||
@ -613,7 +613,7 @@ static int netlbl_mgmt_protocols_cb(struct sk_buff *skb,
|
|||||||
int ret_val = -ENOMEM;
|
int ret_val = -ENOMEM;
|
||||||
void *data;
|
void *data;
|
||||||
|
|
||||||
data = genlmsg_put(skb, NETLINK_CB(cb->skb).pid, cb->nlh->nlmsg_seq,
|
data = genlmsg_put(skb, NETLINK_CB(cb->skb).portid, cb->nlh->nlmsg_seq,
|
||||||
&netlbl_mgmt_gnl_family, NLM_F_MULTI,
|
&netlbl_mgmt_gnl_family, NLM_F_MULTI,
|
||||||
NLBL_MGMT_C_PROTOCOLS);
|
NLBL_MGMT_C_PROTOCOLS);
|
||||||
if (data == NULL)
|
if (data == NULL)
|
||||||
|
@ -1096,7 +1096,7 @@ static int netlbl_unlabel_staticlist_gen(u32 cmd,
|
|||||||
char *secctx;
|
char *secctx;
|
||||||
u32 secctx_len;
|
u32 secctx_len;
|
||||||
|
|
||||||
data = genlmsg_put(cb_arg->skb, NETLINK_CB(cb_arg->nl_cb->skb).pid,
|
data = genlmsg_put(cb_arg->skb, NETLINK_CB(cb_arg->nl_cb->skb).portid,
|
||||||
cb_arg->seq, &netlbl_unlabel_gnl_family,
|
cb_arg->seq, &netlbl_unlabel_gnl_family,
|
||||||
NLM_F_MULTI, cmd);
|
NLM_F_MULTI, cmd);
|
||||||
if (data == NULL)
|
if (data == NULL)
|
||||||
|
@ -67,8 +67,8 @@
|
|||||||
struct netlink_sock {
|
struct netlink_sock {
|
||||||
/* struct sock has to be the first member of netlink_sock */
|
/* struct sock has to be the first member of netlink_sock */
|
||||||
struct sock sk;
|
struct sock sk;
|
||||||
u32 pid;
|
u32 portid;
|
||||||
u32 dst_pid;
|
u32 dst_portid;
|
||||||
u32 dst_group;
|
u32 dst_group;
|
||||||
u32 flags;
|
u32 flags;
|
||||||
u32 subscriptions;
|
u32 subscriptions;
|
||||||
@ -104,7 +104,7 @@ static inline int netlink_is_kernel(struct sock *sk)
|
|||||||
return nlk_sk(sk)->flags & NETLINK_KERNEL_SOCKET;
|
return nlk_sk(sk)->flags & NETLINK_KERNEL_SOCKET;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct nl_pid_hash {
|
struct nl_portid_hash {
|
||||||
struct hlist_head *table;
|
struct hlist_head *table;
|
||||||
unsigned long rehash_time;
|
unsigned long rehash_time;
|
||||||
|
|
||||||
@ -118,7 +118,7 @@ struct nl_pid_hash {
|
|||||||
};
|
};
|
||||||
|
|
||||||
struct netlink_table {
|
struct netlink_table {
|
||||||
struct nl_pid_hash hash;
|
struct nl_portid_hash hash;
|
||||||
struct hlist_head mc_list;
|
struct hlist_head mc_list;
|
||||||
struct listeners __rcu *listeners;
|
struct listeners __rcu *listeners;
|
||||||
unsigned int flags;
|
unsigned int flags;
|
||||||
@ -145,9 +145,9 @@ static inline u32 netlink_group_mask(u32 group)
|
|||||||
return group ? 1 << (group - 1) : 0;
|
return group ? 1 << (group - 1) : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline struct hlist_head *nl_pid_hashfn(struct nl_pid_hash *hash, u32 pid)
|
static inline struct hlist_head *nl_portid_hashfn(struct nl_portid_hash *hash, u32 portid)
|
||||||
{
|
{
|
||||||
return &hash->table[jhash_1word(pid, hash->rnd) & hash->mask];
|
return &hash->table[jhash_1word(portid, hash->rnd) & hash->mask];
|
||||||
}
|
}
|
||||||
|
|
||||||
static void netlink_destroy_callback(struct netlink_callback *cb)
|
static void netlink_destroy_callback(struct netlink_callback *cb)
|
||||||
@ -239,17 +239,17 @@ netlink_unlock_table(void)
|
|||||||
wake_up(&nl_table_wait);
|
wake_up(&nl_table_wait);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct sock *netlink_lookup(struct net *net, int protocol, u32 pid)
|
static struct sock *netlink_lookup(struct net *net, int protocol, u32 portid)
|
||||||
{
|
{
|
||||||
struct nl_pid_hash *hash = &nl_table[protocol].hash;
|
struct nl_portid_hash *hash = &nl_table[protocol].hash;
|
||||||
struct hlist_head *head;
|
struct hlist_head *head;
|
||||||
struct sock *sk;
|
struct sock *sk;
|
||||||
struct hlist_node *node;
|
struct hlist_node *node;
|
||||||
|
|
||||||
read_lock(&nl_table_lock);
|
read_lock(&nl_table_lock);
|
||||||
head = nl_pid_hashfn(hash, pid);
|
head = nl_portid_hashfn(hash, portid);
|
||||||
sk_for_each(sk, node, head) {
|
sk_for_each(sk, node, head) {
|
||||||
if (net_eq(sock_net(sk), net) && (nlk_sk(sk)->pid == pid)) {
|
if (net_eq(sock_net(sk), net) && (nlk_sk(sk)->portid == portid)) {
|
||||||
sock_hold(sk);
|
sock_hold(sk);
|
||||||
goto found;
|
goto found;
|
||||||
}
|
}
|
||||||
@ -260,7 +260,7 @@ static struct sock *netlink_lookup(struct net *net, int protocol, u32 pid)
|
|||||||
return sk;
|
return sk;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct hlist_head *nl_pid_hash_zalloc(size_t size)
|
static struct hlist_head *nl_portid_hash_zalloc(size_t size)
|
||||||
{
|
{
|
||||||
if (size <= PAGE_SIZE)
|
if (size <= PAGE_SIZE)
|
||||||
return kzalloc(size, GFP_ATOMIC);
|
return kzalloc(size, GFP_ATOMIC);
|
||||||
@ -270,7 +270,7 @@ static struct hlist_head *nl_pid_hash_zalloc(size_t size)
|
|||||||
get_order(size));
|
get_order(size));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void nl_pid_hash_free(struct hlist_head *table, size_t size)
|
static void nl_portid_hash_free(struct hlist_head *table, size_t size)
|
||||||
{
|
{
|
||||||
if (size <= PAGE_SIZE)
|
if (size <= PAGE_SIZE)
|
||||||
kfree(table);
|
kfree(table);
|
||||||
@ -278,7 +278,7 @@ static void nl_pid_hash_free(struct hlist_head *table, size_t size)
|
|||||||
free_pages((unsigned long)table, get_order(size));
|
free_pages((unsigned long)table, get_order(size));
|
||||||
}
|
}
|
||||||
|
|
||||||
static int nl_pid_hash_rehash(struct nl_pid_hash *hash, int grow)
|
static int nl_portid_hash_rehash(struct nl_portid_hash *hash, int grow)
|
||||||
{
|
{
|
||||||
unsigned int omask, mask, shift;
|
unsigned int omask, mask, shift;
|
||||||
size_t osize, size;
|
size_t osize, size;
|
||||||
@ -296,7 +296,7 @@ static int nl_pid_hash_rehash(struct nl_pid_hash *hash, int grow)
|
|||||||
size *= 2;
|
size *= 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
table = nl_pid_hash_zalloc(size);
|
table = nl_portid_hash_zalloc(size);
|
||||||
if (!table)
|
if (!table)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -311,23 +311,23 @@ static int nl_pid_hash_rehash(struct nl_pid_hash *hash, int grow)
|
|||||||
struct hlist_node *node, *tmp;
|
struct hlist_node *node, *tmp;
|
||||||
|
|
||||||
sk_for_each_safe(sk, node, tmp, &otable[i])
|
sk_for_each_safe(sk, node, tmp, &otable[i])
|
||||||
__sk_add_node(sk, nl_pid_hashfn(hash, nlk_sk(sk)->pid));
|
__sk_add_node(sk, nl_portid_hashfn(hash, nlk_sk(sk)->portid));
|
||||||
}
|
}
|
||||||
|
|
||||||
nl_pid_hash_free(otable, osize);
|
nl_portid_hash_free(otable, osize);
|
||||||
hash->rehash_time = jiffies + 10 * 60 * HZ;
|
hash->rehash_time = jiffies + 10 * 60 * HZ;
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline int nl_pid_hash_dilute(struct nl_pid_hash *hash, int len)
|
static inline int nl_portid_hash_dilute(struct nl_portid_hash *hash, int len)
|
||||||
{
|
{
|
||||||
int avg = hash->entries >> hash->shift;
|
int avg = hash->entries >> hash->shift;
|
||||||
|
|
||||||
if (unlikely(avg > 1) && nl_pid_hash_rehash(hash, 1))
|
if (unlikely(avg > 1) && nl_portid_hash_rehash(hash, 1))
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
if (unlikely(len > avg) && time_after(jiffies, hash->rehash_time)) {
|
if (unlikely(len > avg) && time_after(jiffies, hash->rehash_time)) {
|
||||||
nl_pid_hash_rehash(hash, 0);
|
nl_portid_hash_rehash(hash, 0);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -356,9 +356,9 @@ netlink_update_listeners(struct sock *sk)
|
|||||||
* makes sure updates are visible before bind or setsockopt return. */
|
* makes sure updates are visible before bind or setsockopt return. */
|
||||||
}
|
}
|
||||||
|
|
||||||
static int netlink_insert(struct sock *sk, struct net *net, u32 pid)
|
static int netlink_insert(struct sock *sk, struct net *net, u32 portid)
|
||||||
{
|
{
|
||||||
struct nl_pid_hash *hash = &nl_table[sk->sk_protocol].hash;
|
struct nl_portid_hash *hash = &nl_table[sk->sk_protocol].hash;
|
||||||
struct hlist_head *head;
|
struct hlist_head *head;
|
||||||
int err = -EADDRINUSE;
|
int err = -EADDRINUSE;
|
||||||
struct sock *osk;
|
struct sock *osk;
|
||||||
@ -366,10 +366,10 @@ static int netlink_insert(struct sock *sk, struct net *net, u32 pid)
|
|||||||
int len;
|
int len;
|
||||||
|
|
||||||
netlink_table_grab();
|
netlink_table_grab();
|
||||||
head = nl_pid_hashfn(hash, pid);
|
head = nl_portid_hashfn(hash, portid);
|
||||||
len = 0;
|
len = 0;
|
||||||
sk_for_each(osk, node, head) {
|
sk_for_each(osk, node, head) {
|
||||||
if (net_eq(sock_net(osk), net) && (nlk_sk(osk)->pid == pid))
|
if (net_eq(sock_net(osk), net) && (nlk_sk(osk)->portid == portid))
|
||||||
break;
|
break;
|
||||||
len++;
|
len++;
|
||||||
}
|
}
|
||||||
@ -377,17 +377,17 @@ static int netlink_insert(struct sock *sk, struct net *net, u32 pid)
|
|||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
err = -EBUSY;
|
err = -EBUSY;
|
||||||
if (nlk_sk(sk)->pid)
|
if (nlk_sk(sk)->portid)
|
||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
err = -ENOMEM;
|
err = -ENOMEM;
|
||||||
if (BITS_PER_LONG > 32 && unlikely(hash->entries >= UINT_MAX))
|
if (BITS_PER_LONG > 32 && unlikely(hash->entries >= UINT_MAX))
|
||||||
goto err;
|
goto err;
|
||||||
|
|
||||||
if (len && nl_pid_hash_dilute(hash, len))
|
if (len && nl_portid_hash_dilute(hash, len))
|
||||||
head = nl_pid_hashfn(hash, pid);
|
head = nl_portid_hashfn(hash, portid);
|
||||||
hash->entries++;
|
hash->entries++;
|
||||||
nlk_sk(sk)->pid = pid;
|
nlk_sk(sk)->portid = portid;
|
||||||
sk_add_node(sk, head);
|
sk_add_node(sk, head);
|
||||||
err = 0;
|
err = 0;
|
||||||
|
|
||||||
@ -518,11 +518,11 @@ static int netlink_release(struct socket *sock)
|
|||||||
|
|
||||||
skb_queue_purge(&sk->sk_write_queue);
|
skb_queue_purge(&sk->sk_write_queue);
|
||||||
|
|
||||||
if (nlk->pid) {
|
if (nlk->portid) {
|
||||||
struct netlink_notify n = {
|
struct netlink_notify n = {
|
||||||
.net = sock_net(sk),
|
.net = sock_net(sk),
|
||||||
.protocol = sk->sk_protocol,
|
.protocol = sk->sk_protocol,
|
||||||
.pid = nlk->pid,
|
.portid = nlk->portid,
|
||||||
};
|
};
|
||||||
atomic_notifier_call_chain(&netlink_chain,
|
atomic_notifier_call_chain(&netlink_chain,
|
||||||
NETLINK_URELEASE, &n);
|
NETLINK_URELEASE, &n);
|
||||||
@ -559,24 +559,24 @@ static int netlink_autobind(struct socket *sock)
|
|||||||
{
|
{
|
||||||
struct sock *sk = sock->sk;
|
struct sock *sk = sock->sk;
|
||||||
struct net *net = sock_net(sk);
|
struct net *net = sock_net(sk);
|
||||||
struct nl_pid_hash *hash = &nl_table[sk->sk_protocol].hash;
|
struct nl_portid_hash *hash = &nl_table[sk->sk_protocol].hash;
|
||||||
struct hlist_head *head;
|
struct hlist_head *head;
|
||||||
struct sock *osk;
|
struct sock *osk;
|
||||||
struct hlist_node *node;
|
struct hlist_node *node;
|
||||||
s32 pid = task_tgid_vnr(current);
|
s32 portid = task_tgid_vnr(current);
|
||||||
int err;
|
int err;
|
||||||
static s32 rover = -4097;
|
static s32 rover = -4097;
|
||||||
|
|
||||||
retry:
|
retry:
|
||||||
cond_resched();
|
cond_resched();
|
||||||
netlink_table_grab();
|
netlink_table_grab();
|
||||||
head = nl_pid_hashfn(hash, pid);
|
head = nl_portid_hashfn(hash, portid);
|
||||||
sk_for_each(osk, node, head) {
|
sk_for_each(osk, node, head) {
|
||||||
if (!net_eq(sock_net(osk), net))
|
if (!net_eq(sock_net(osk), net))
|
||||||
continue;
|
continue;
|
||||||
if (nlk_sk(osk)->pid == pid) {
|
if (nlk_sk(osk)->portid == portid) {
|
||||||
/* Bind collision, search negative pid values. */
|
/* Bind collision, search negative portid values. */
|
||||||
pid = rover--;
|
portid = rover--;
|
||||||
if (rover > -4097)
|
if (rover > -4097)
|
||||||
rover = -4097;
|
rover = -4097;
|
||||||
netlink_table_ungrab();
|
netlink_table_ungrab();
|
||||||
@ -585,7 +585,7 @@ static int netlink_autobind(struct socket *sock)
|
|||||||
}
|
}
|
||||||
netlink_table_ungrab();
|
netlink_table_ungrab();
|
||||||
|
|
||||||
err = netlink_insert(sk, net, pid);
|
err = netlink_insert(sk, net, portid);
|
||||||
if (err == -EADDRINUSE)
|
if (err == -EADDRINUSE)
|
||||||
goto retry;
|
goto retry;
|
||||||
|
|
||||||
@ -668,8 +668,8 @@ static int netlink_bind(struct socket *sock, struct sockaddr *addr,
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (nlk->pid) {
|
if (nlk->portid) {
|
||||||
if (nladdr->nl_pid != nlk->pid)
|
if (nladdr->nl_pid != nlk->portid)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
} else {
|
} else {
|
||||||
err = nladdr->nl_pid ?
|
err = nladdr->nl_pid ?
|
||||||
@ -715,7 +715,7 @@ static int netlink_connect(struct socket *sock, struct sockaddr *addr,
|
|||||||
|
|
||||||
if (addr->sa_family == AF_UNSPEC) {
|
if (addr->sa_family == AF_UNSPEC) {
|
||||||
sk->sk_state = NETLINK_UNCONNECTED;
|
sk->sk_state = NETLINK_UNCONNECTED;
|
||||||
nlk->dst_pid = 0;
|
nlk->dst_portid = 0;
|
||||||
nlk->dst_group = 0;
|
nlk->dst_group = 0;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -726,12 +726,12 @@ static int netlink_connect(struct socket *sock, struct sockaddr *addr,
|
|||||||
if (nladdr->nl_groups && !netlink_capable(sock, NL_CFG_F_NONROOT_SEND))
|
if (nladdr->nl_groups && !netlink_capable(sock, NL_CFG_F_NONROOT_SEND))
|
||||||
return -EPERM;
|
return -EPERM;
|
||||||
|
|
||||||
if (!nlk->pid)
|
if (!nlk->portid)
|
||||||
err = netlink_autobind(sock);
|
err = netlink_autobind(sock);
|
||||||
|
|
||||||
if (err == 0) {
|
if (err == 0) {
|
||||||
sk->sk_state = NETLINK_CONNECTED;
|
sk->sk_state = NETLINK_CONNECTED;
|
||||||
nlk->dst_pid = nladdr->nl_pid;
|
nlk->dst_portid = nladdr->nl_pid;
|
||||||
nlk->dst_group = ffs(nladdr->nl_groups);
|
nlk->dst_group = ffs(nladdr->nl_groups);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -750,10 +750,10 @@ static int netlink_getname(struct socket *sock, struct sockaddr *addr,
|
|||||||
*addr_len = sizeof(*nladdr);
|
*addr_len = sizeof(*nladdr);
|
||||||
|
|
||||||
if (peer) {
|
if (peer) {
|
||||||
nladdr->nl_pid = nlk->dst_pid;
|
nladdr->nl_pid = nlk->dst_portid;
|
||||||
nladdr->nl_groups = netlink_group_mask(nlk->dst_group);
|
nladdr->nl_groups = netlink_group_mask(nlk->dst_group);
|
||||||
} else {
|
} else {
|
||||||
nladdr->nl_pid = nlk->pid;
|
nladdr->nl_pid = nlk->portid;
|
||||||
nladdr->nl_groups = nlk->groups ? nlk->groups[0] : 0;
|
nladdr->nl_groups = nlk->groups ? nlk->groups[0] : 0;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@ -772,19 +772,19 @@ static void netlink_overrun(struct sock *sk)
|
|||||||
atomic_inc(&sk->sk_drops);
|
atomic_inc(&sk->sk_drops);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct sock *netlink_getsockbypid(struct sock *ssk, u32 pid)
|
static struct sock *netlink_getsockbyportid(struct sock *ssk, u32 portid)
|
||||||
{
|
{
|
||||||
struct sock *sock;
|
struct sock *sock;
|
||||||
struct netlink_sock *nlk;
|
struct netlink_sock *nlk;
|
||||||
|
|
||||||
sock = netlink_lookup(sock_net(ssk), ssk->sk_protocol, pid);
|
sock = netlink_lookup(sock_net(ssk), ssk->sk_protocol, portid);
|
||||||
if (!sock)
|
if (!sock)
|
||||||
return ERR_PTR(-ECONNREFUSED);
|
return ERR_PTR(-ECONNREFUSED);
|
||||||
|
|
||||||
/* Don't bother queuing skb if kernel socket has no input function */
|
/* Don't bother queuing skb if kernel socket has no input function */
|
||||||
nlk = nlk_sk(sock);
|
nlk = nlk_sk(sock);
|
||||||
if (sock->sk_state == NETLINK_CONNECTED &&
|
if (sock->sk_state == NETLINK_CONNECTED &&
|
||||||
nlk->dst_pid != nlk_sk(ssk)->pid) {
|
nlk->dst_portid != nlk_sk(ssk)->portid) {
|
||||||
sock_put(sock);
|
sock_put(sock);
|
||||||
return ERR_PTR(-ECONNREFUSED);
|
return ERR_PTR(-ECONNREFUSED);
|
||||||
}
|
}
|
||||||
@ -935,7 +935,7 @@ static int netlink_unicast_kernel(struct sock *sk, struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
int netlink_unicast(struct sock *ssk, struct sk_buff *skb,
|
int netlink_unicast(struct sock *ssk, struct sk_buff *skb,
|
||||||
u32 pid, int nonblock)
|
u32 portid, int nonblock)
|
||||||
{
|
{
|
||||||
struct sock *sk;
|
struct sock *sk;
|
||||||
int err;
|
int err;
|
||||||
@ -945,7 +945,7 @@ int netlink_unicast(struct sock *ssk, struct sk_buff *skb,
|
|||||||
|
|
||||||
timeo = sock_sndtimeo(ssk, nonblock);
|
timeo = sock_sndtimeo(ssk, nonblock);
|
||||||
retry:
|
retry:
|
||||||
sk = netlink_getsockbypid(ssk, pid);
|
sk = netlink_getsockbyportid(ssk, portid);
|
||||||
if (IS_ERR(sk)) {
|
if (IS_ERR(sk)) {
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return PTR_ERR(sk);
|
return PTR_ERR(sk);
|
||||||
@ -1005,7 +1005,7 @@ static int netlink_broadcast_deliver(struct sock *sk, struct sk_buff *skb)
|
|||||||
struct netlink_broadcast_data {
|
struct netlink_broadcast_data {
|
||||||
struct sock *exclude_sk;
|
struct sock *exclude_sk;
|
||||||
struct net *net;
|
struct net *net;
|
||||||
u32 pid;
|
u32 portid;
|
||||||
u32 group;
|
u32 group;
|
||||||
int failure;
|
int failure;
|
||||||
int delivery_failure;
|
int delivery_failure;
|
||||||
@ -1026,7 +1026,7 @@ static int do_one_broadcast(struct sock *sk,
|
|||||||
if (p->exclude_sk == sk)
|
if (p->exclude_sk == sk)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
if (nlk->pid == p->pid || p->group - 1 >= nlk->ngroups ||
|
if (nlk->portid == p->portid || p->group - 1 >= nlk->ngroups ||
|
||||||
!test_bit(p->group - 1, nlk->groups))
|
!test_bit(p->group - 1, nlk->groups))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
@ -1078,7 +1078,7 @@ static int do_one_broadcast(struct sock *sk,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int netlink_broadcast_filtered(struct sock *ssk, struct sk_buff *skb, u32 pid,
|
int netlink_broadcast_filtered(struct sock *ssk, struct sk_buff *skb, u32 portid,
|
||||||
u32 group, gfp_t allocation,
|
u32 group, gfp_t allocation,
|
||||||
int (*filter)(struct sock *dsk, struct sk_buff *skb, void *data),
|
int (*filter)(struct sock *dsk, struct sk_buff *skb, void *data),
|
||||||
void *filter_data)
|
void *filter_data)
|
||||||
@ -1092,7 +1092,7 @@ int netlink_broadcast_filtered(struct sock *ssk, struct sk_buff *skb, u32 pid,
|
|||||||
|
|
||||||
info.exclude_sk = ssk;
|
info.exclude_sk = ssk;
|
||||||
info.net = net;
|
info.net = net;
|
||||||
info.pid = pid;
|
info.portid = portid;
|
||||||
info.group = group;
|
info.group = group;
|
||||||
info.failure = 0;
|
info.failure = 0;
|
||||||
info.delivery_failure = 0;
|
info.delivery_failure = 0;
|
||||||
@ -1130,17 +1130,17 @@ int netlink_broadcast_filtered(struct sock *ssk, struct sk_buff *skb, u32 pid,
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(netlink_broadcast_filtered);
|
EXPORT_SYMBOL(netlink_broadcast_filtered);
|
||||||
|
|
||||||
int netlink_broadcast(struct sock *ssk, struct sk_buff *skb, u32 pid,
|
int netlink_broadcast(struct sock *ssk, struct sk_buff *skb, u32 portid,
|
||||||
u32 group, gfp_t allocation)
|
u32 group, gfp_t allocation)
|
||||||
{
|
{
|
||||||
return netlink_broadcast_filtered(ssk, skb, pid, group, allocation,
|
return netlink_broadcast_filtered(ssk, skb, portid, group, allocation,
|
||||||
NULL, NULL);
|
NULL, NULL);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(netlink_broadcast);
|
EXPORT_SYMBOL(netlink_broadcast);
|
||||||
|
|
||||||
struct netlink_set_err_data {
|
struct netlink_set_err_data {
|
||||||
struct sock *exclude_sk;
|
struct sock *exclude_sk;
|
||||||
u32 pid;
|
u32 portid;
|
||||||
u32 group;
|
u32 group;
|
||||||
int code;
|
int code;
|
||||||
};
|
};
|
||||||
@ -1156,7 +1156,7 @@ static int do_one_set_err(struct sock *sk, struct netlink_set_err_data *p)
|
|||||||
if (!net_eq(sock_net(sk), sock_net(p->exclude_sk)))
|
if (!net_eq(sock_net(sk), sock_net(p->exclude_sk)))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
if (nlk->pid == p->pid || p->group - 1 >= nlk->ngroups ||
|
if (nlk->portid == p->portid || p->group - 1 >= nlk->ngroups ||
|
||||||
!test_bit(p->group - 1, nlk->groups))
|
!test_bit(p->group - 1, nlk->groups))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
@ -1174,14 +1174,14 @@ static int do_one_set_err(struct sock *sk, struct netlink_set_err_data *p)
|
|||||||
/**
|
/**
|
||||||
* netlink_set_err - report error to broadcast listeners
|
* netlink_set_err - report error to broadcast listeners
|
||||||
* @ssk: the kernel netlink socket, as returned by netlink_kernel_create()
|
* @ssk: the kernel netlink socket, as returned by netlink_kernel_create()
|
||||||
* @pid: the PID of a process that we want to skip (if any)
|
* @portid: the PORTID of a process that we want to skip (if any)
|
||||||
* @groups: the broadcast group that will notice the error
|
* @groups: the broadcast group that will notice the error
|
||||||
* @code: error code, must be negative (as usual in kernelspace)
|
* @code: error code, must be negative (as usual in kernelspace)
|
||||||
*
|
*
|
||||||
* This function returns the number of broadcast listeners that have set the
|
* This function returns the number of broadcast listeners that have set the
|
||||||
* NETLINK_RECV_NO_ENOBUFS socket option.
|
* NETLINK_RECV_NO_ENOBUFS socket option.
|
||||||
*/
|
*/
|
||||||
int netlink_set_err(struct sock *ssk, u32 pid, u32 group, int code)
|
int netlink_set_err(struct sock *ssk, u32 portid, u32 group, int code)
|
||||||
{
|
{
|
||||||
struct netlink_set_err_data info;
|
struct netlink_set_err_data info;
|
||||||
struct hlist_node *node;
|
struct hlist_node *node;
|
||||||
@ -1189,7 +1189,7 @@ int netlink_set_err(struct sock *ssk, u32 pid, u32 group, int code)
|
|||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
info.exclude_sk = ssk;
|
info.exclude_sk = ssk;
|
||||||
info.pid = pid;
|
info.portid = portid;
|
||||||
info.group = group;
|
info.group = group;
|
||||||
/* sk->sk_err wants a positive error value */
|
/* sk->sk_err wants a positive error value */
|
||||||
info.code = -code;
|
info.code = -code;
|
||||||
@ -1354,7 +1354,7 @@ static int netlink_sendmsg(struct kiocb *kiocb, struct socket *sock,
|
|||||||
struct sock *sk = sock->sk;
|
struct sock *sk = sock->sk;
|
||||||
struct netlink_sock *nlk = nlk_sk(sk);
|
struct netlink_sock *nlk = nlk_sk(sk);
|
||||||
struct sockaddr_nl *addr = msg->msg_name;
|
struct sockaddr_nl *addr = msg->msg_name;
|
||||||
u32 dst_pid;
|
u32 dst_portid;
|
||||||
u32 dst_group;
|
u32 dst_group;
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
int err;
|
int err;
|
||||||
@ -1374,18 +1374,18 @@ static int netlink_sendmsg(struct kiocb *kiocb, struct socket *sock,
|
|||||||
err = -EINVAL;
|
err = -EINVAL;
|
||||||
if (addr->nl_family != AF_NETLINK)
|
if (addr->nl_family != AF_NETLINK)
|
||||||
goto out;
|
goto out;
|
||||||
dst_pid = addr->nl_pid;
|
dst_portid = addr->nl_pid;
|
||||||
dst_group = ffs(addr->nl_groups);
|
dst_group = ffs(addr->nl_groups);
|
||||||
err = -EPERM;
|
err = -EPERM;
|
||||||
if ((dst_group || dst_pid) &&
|
if ((dst_group || dst_portid) &&
|
||||||
!netlink_capable(sock, NL_CFG_F_NONROOT_SEND))
|
!netlink_capable(sock, NL_CFG_F_NONROOT_SEND))
|
||||||
goto out;
|
goto out;
|
||||||
} else {
|
} else {
|
||||||
dst_pid = nlk->dst_pid;
|
dst_portid = nlk->dst_portid;
|
||||||
dst_group = nlk->dst_group;
|
dst_group = nlk->dst_group;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!nlk->pid) {
|
if (!nlk->portid) {
|
||||||
err = netlink_autobind(sock);
|
err = netlink_autobind(sock);
|
||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
@ -1399,7 +1399,7 @@ static int netlink_sendmsg(struct kiocb *kiocb, struct socket *sock,
|
|||||||
if (skb == NULL)
|
if (skb == NULL)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
NETLINK_CB(skb).pid = nlk->pid;
|
NETLINK_CB(skb).portid = nlk->portid;
|
||||||
NETLINK_CB(skb).dst_group = dst_group;
|
NETLINK_CB(skb).dst_group = dst_group;
|
||||||
NETLINK_CB(skb).creds = siocb->scm->creds;
|
NETLINK_CB(skb).creds = siocb->scm->creds;
|
||||||
|
|
||||||
@ -1417,9 +1417,9 @@ static int netlink_sendmsg(struct kiocb *kiocb, struct socket *sock,
|
|||||||
|
|
||||||
if (dst_group) {
|
if (dst_group) {
|
||||||
atomic_inc(&skb->users);
|
atomic_inc(&skb->users);
|
||||||
netlink_broadcast(sk, skb, dst_pid, dst_group, GFP_KERNEL);
|
netlink_broadcast(sk, skb, dst_portid, dst_group, GFP_KERNEL);
|
||||||
}
|
}
|
||||||
err = netlink_unicast(sk, skb, dst_pid, msg->msg_flags&MSG_DONTWAIT);
|
err = netlink_unicast(sk, skb, dst_portid, msg->msg_flags&MSG_DONTWAIT);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
scm_destroy(siocb->scm);
|
scm_destroy(siocb->scm);
|
||||||
@ -1482,7 +1482,7 @@ static int netlink_recvmsg(struct kiocb *kiocb, struct socket *sock,
|
|||||||
struct sockaddr_nl *addr = (struct sockaddr_nl *)msg->msg_name;
|
struct sockaddr_nl *addr = (struct sockaddr_nl *)msg->msg_name;
|
||||||
addr->nl_family = AF_NETLINK;
|
addr->nl_family = AF_NETLINK;
|
||||||
addr->nl_pad = 0;
|
addr->nl_pad = 0;
|
||||||
addr->nl_pid = NETLINK_CB(skb).pid;
|
addr->nl_pid = NETLINK_CB(skb).portid;
|
||||||
addr->nl_groups = netlink_group_mask(NETLINK_CB(skb).dst_group);
|
addr->nl_groups = netlink_group_mask(NETLINK_CB(skb).dst_group);
|
||||||
msg->msg_namelen = sizeof(*addr);
|
msg->msg_namelen = sizeof(*addr);
|
||||||
}
|
}
|
||||||
@ -1683,7 +1683,7 @@ void netlink_clear_multicast_users(struct sock *ksk, unsigned int group)
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct nlmsghdr *
|
struct nlmsghdr *
|
||||||
__nlmsg_put(struct sk_buff *skb, u32 pid, u32 seq, int type, int len, int flags)
|
__nlmsg_put(struct sk_buff *skb, u32 portid, u32 seq, int type, int len, int flags)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
int size = NLMSG_LENGTH(len);
|
int size = NLMSG_LENGTH(len);
|
||||||
@ -1692,7 +1692,7 @@ __nlmsg_put(struct sk_buff *skb, u32 pid, u32 seq, int type, int len, int flags)
|
|||||||
nlh->nlmsg_type = type;
|
nlh->nlmsg_type = type;
|
||||||
nlh->nlmsg_len = size;
|
nlh->nlmsg_len = size;
|
||||||
nlh->nlmsg_flags = flags;
|
nlh->nlmsg_flags = flags;
|
||||||
nlh->nlmsg_pid = pid;
|
nlh->nlmsg_pid = portid;
|
||||||
nlh->nlmsg_seq = seq;
|
nlh->nlmsg_seq = seq;
|
||||||
if (!__builtin_constant_p(size) || NLMSG_ALIGN(size) - size != 0)
|
if (!__builtin_constant_p(size) || NLMSG_ALIGN(size) - size != 0)
|
||||||
memset(NLMSG_DATA(nlh) + len, 0, NLMSG_ALIGN(size) - size);
|
memset(NLMSG_DATA(nlh) + len, 0, NLMSG_ALIGN(size) - size);
|
||||||
@ -1788,7 +1788,7 @@ int netlink_dump_start(struct sock *ssk, struct sk_buff *skb,
|
|||||||
atomic_inc(&skb->users);
|
atomic_inc(&skb->users);
|
||||||
cb->skb = skb;
|
cb->skb = skb;
|
||||||
|
|
||||||
sk = netlink_lookup(sock_net(ssk), ssk->sk_protocol, NETLINK_CB(skb).pid);
|
sk = netlink_lookup(sock_net(ssk), ssk->sk_protocol, NETLINK_CB(skb).portid);
|
||||||
if (sk == NULL) {
|
if (sk == NULL) {
|
||||||
netlink_destroy_callback(cb);
|
netlink_destroy_callback(cb);
|
||||||
return -ECONNREFUSED;
|
return -ECONNREFUSED;
|
||||||
@ -1836,7 +1836,7 @@ void netlink_ack(struct sk_buff *in_skb, struct nlmsghdr *nlh, int err)
|
|||||||
|
|
||||||
sk = netlink_lookup(sock_net(in_skb->sk),
|
sk = netlink_lookup(sock_net(in_skb->sk),
|
||||||
in_skb->sk->sk_protocol,
|
in_skb->sk->sk_protocol,
|
||||||
NETLINK_CB(in_skb).pid);
|
NETLINK_CB(in_skb).portid);
|
||||||
if (sk) {
|
if (sk) {
|
||||||
sk->sk_err = ENOBUFS;
|
sk->sk_err = ENOBUFS;
|
||||||
sk->sk_error_report(sk);
|
sk->sk_error_report(sk);
|
||||||
@ -1845,12 +1845,12 @@ void netlink_ack(struct sk_buff *in_skb, struct nlmsghdr *nlh, int err)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
rep = __nlmsg_put(skb, NETLINK_CB(in_skb).pid, nlh->nlmsg_seq,
|
rep = __nlmsg_put(skb, NETLINK_CB(in_skb).portid, nlh->nlmsg_seq,
|
||||||
NLMSG_ERROR, payload, 0);
|
NLMSG_ERROR, payload, 0);
|
||||||
errmsg = nlmsg_data(rep);
|
errmsg = nlmsg_data(rep);
|
||||||
errmsg->error = err;
|
errmsg->error = err;
|
||||||
memcpy(&errmsg->msg, nlh, err ? nlh->nlmsg_len : sizeof(*nlh));
|
memcpy(&errmsg->msg, nlh, err ? nlh->nlmsg_len : sizeof(*nlh));
|
||||||
netlink_unicast(in_skb->sk, skb, NETLINK_CB(in_skb).pid, MSG_DONTWAIT);
|
netlink_unicast(in_skb->sk, skb, NETLINK_CB(in_skb).portid, MSG_DONTWAIT);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(netlink_ack);
|
EXPORT_SYMBOL(netlink_ack);
|
||||||
|
|
||||||
@ -1900,33 +1900,33 @@ EXPORT_SYMBOL(netlink_rcv_skb);
|
|||||||
* nlmsg_notify - send a notification netlink message
|
* nlmsg_notify - send a notification netlink message
|
||||||
* @sk: netlink socket to use
|
* @sk: netlink socket to use
|
||||||
* @skb: notification message
|
* @skb: notification message
|
||||||
* @pid: destination netlink pid for reports or 0
|
* @portid: destination netlink portid for reports or 0
|
||||||
* @group: destination multicast group or 0
|
* @group: destination multicast group or 0
|
||||||
* @report: 1 to report back, 0 to disable
|
* @report: 1 to report back, 0 to disable
|
||||||
* @flags: allocation flags
|
* @flags: allocation flags
|
||||||
*/
|
*/
|
||||||
int nlmsg_notify(struct sock *sk, struct sk_buff *skb, u32 pid,
|
int nlmsg_notify(struct sock *sk, struct sk_buff *skb, u32 portid,
|
||||||
unsigned int group, int report, gfp_t flags)
|
unsigned int group, int report, gfp_t flags)
|
||||||
{
|
{
|
||||||
int err = 0;
|
int err = 0;
|
||||||
|
|
||||||
if (group) {
|
if (group) {
|
||||||
int exclude_pid = 0;
|
int exclude_portid = 0;
|
||||||
|
|
||||||
if (report) {
|
if (report) {
|
||||||
atomic_inc(&skb->users);
|
atomic_inc(&skb->users);
|
||||||
exclude_pid = pid;
|
exclude_portid = portid;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* errors reported via destination sk->sk_err, but propagate
|
/* errors reported via destination sk->sk_err, but propagate
|
||||||
* delivery errors if NETLINK_BROADCAST_ERROR flag is set */
|
* delivery errors if NETLINK_BROADCAST_ERROR flag is set */
|
||||||
err = nlmsg_multicast(sk, skb, exclude_pid, group, flags);
|
err = nlmsg_multicast(sk, skb, exclude_portid, group, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (report) {
|
if (report) {
|
||||||
int err2;
|
int err2;
|
||||||
|
|
||||||
err2 = nlmsg_unicast(sk, skb, pid);
|
err2 = nlmsg_unicast(sk, skb, portid);
|
||||||
if (!err || err == -ESRCH)
|
if (!err || err == -ESRCH)
|
||||||
err = err2;
|
err = err2;
|
||||||
}
|
}
|
||||||
@ -1951,7 +1951,7 @@ static struct sock *netlink_seq_socket_idx(struct seq_file *seq, loff_t pos)
|
|||||||
loff_t off = 0;
|
loff_t off = 0;
|
||||||
|
|
||||||
for (i = 0; i < MAX_LINKS; i++) {
|
for (i = 0; i < MAX_LINKS; i++) {
|
||||||
struct nl_pid_hash *hash = &nl_table[i].hash;
|
struct nl_portid_hash *hash = &nl_table[i].hash;
|
||||||
|
|
||||||
for (j = 0; j <= hash->mask; j++) {
|
for (j = 0; j <= hash->mask; j++) {
|
||||||
sk_for_each(s, node, &hash->table[j]) {
|
sk_for_each(s, node, &hash->table[j]) {
|
||||||
@ -1999,7 +1999,7 @@ static void *netlink_seq_next(struct seq_file *seq, void *v, loff_t *pos)
|
|||||||
j = iter->hash_idx + 1;
|
j = iter->hash_idx + 1;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
struct nl_pid_hash *hash = &nl_table[i].hash;
|
struct nl_portid_hash *hash = &nl_table[i].hash;
|
||||||
|
|
||||||
for (; j <= hash->mask; j++) {
|
for (; j <= hash->mask; j++) {
|
||||||
s = sk_head(&hash->table[j]);
|
s = sk_head(&hash->table[j]);
|
||||||
@ -2038,7 +2038,7 @@ static int netlink_seq_show(struct seq_file *seq, void *v)
|
|||||||
seq_printf(seq, "%pK %-3d %-6d %08x %-8d %-8d %pK %-8d %-8d %-8lu\n",
|
seq_printf(seq, "%pK %-3d %-6d %08x %-8d %-8d %pK %-8d %-8d %-8lu\n",
|
||||||
s,
|
s,
|
||||||
s->sk_protocol,
|
s->sk_protocol,
|
||||||
nlk->pid,
|
nlk->portid,
|
||||||
nlk->groups ? (u32)nlk->groups[0] : 0,
|
nlk->groups ? (u32)nlk->groups[0] : 0,
|
||||||
sk_rmem_alloc_get(s),
|
sk_rmem_alloc_get(s),
|
||||||
sk_wmem_alloc_get(s),
|
sk_wmem_alloc_get(s),
|
||||||
@ -2183,12 +2183,12 @@ static int __init netlink_proto_init(void)
|
|||||||
order = get_bitmask_order(min(limit, (unsigned long)UINT_MAX)) - 1;
|
order = get_bitmask_order(min(limit, (unsigned long)UINT_MAX)) - 1;
|
||||||
|
|
||||||
for (i = 0; i < MAX_LINKS; i++) {
|
for (i = 0; i < MAX_LINKS; i++) {
|
||||||
struct nl_pid_hash *hash = &nl_table[i].hash;
|
struct nl_portid_hash *hash = &nl_table[i].hash;
|
||||||
|
|
||||||
hash->table = nl_pid_hash_zalloc(1 * sizeof(*hash->table));
|
hash->table = nl_portid_hash_zalloc(1 * sizeof(*hash->table));
|
||||||
if (!hash->table) {
|
if (!hash->table) {
|
||||||
while (i-- > 0)
|
while (i-- > 0)
|
||||||
nl_pid_hash_free(nl_table[i].hash.table,
|
nl_portid_hash_free(nl_table[i].hash.table,
|
||||||
1 * sizeof(*hash->table));
|
1 * sizeof(*hash->table));
|
||||||
kfree(nl_table);
|
kfree(nl_table);
|
||||||
goto panic;
|
goto panic;
|
||||||
|
@ -501,7 +501,7 @@ EXPORT_SYMBOL(genl_unregister_family);
|
|||||||
/**
|
/**
|
||||||
* genlmsg_put - Add generic netlink header to netlink message
|
* genlmsg_put - Add generic netlink header to netlink message
|
||||||
* @skb: socket buffer holding the message
|
* @skb: socket buffer holding the message
|
||||||
* @pid: netlink pid the message is addressed to
|
* @portid: netlink portid the message is addressed to
|
||||||
* @seq: sequence number (usually the one of the sender)
|
* @seq: sequence number (usually the one of the sender)
|
||||||
* @family: generic netlink family
|
* @family: generic netlink family
|
||||||
* @flags: netlink message flags
|
* @flags: netlink message flags
|
||||||
@ -509,13 +509,13 @@ EXPORT_SYMBOL(genl_unregister_family);
|
|||||||
*
|
*
|
||||||
* Returns pointer to user specific header
|
* Returns pointer to user specific header
|
||||||
*/
|
*/
|
||||||
void *genlmsg_put(struct sk_buff *skb, u32 pid, u32 seq,
|
void *genlmsg_put(struct sk_buff *skb, u32 portid, u32 seq,
|
||||||
struct genl_family *family, int flags, u8 cmd)
|
struct genl_family *family, int flags, u8 cmd)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct genlmsghdr *hdr;
|
struct genlmsghdr *hdr;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, family->id, GENL_HDRLEN +
|
nlh = nlmsg_put(skb, portid, seq, family->id, GENL_HDRLEN +
|
||||||
family->hdrsize, flags);
|
family->hdrsize, flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -585,7 +585,7 @@ static int genl_rcv_msg(struct sk_buff *skb, struct nlmsghdr *nlh)
|
|||||||
}
|
}
|
||||||
|
|
||||||
info.snd_seq = nlh->nlmsg_seq;
|
info.snd_seq = nlh->nlmsg_seq;
|
||||||
info.snd_pid = NETLINK_CB(skb).pid;
|
info.snd_portid = NETLINK_CB(skb).portid;
|
||||||
info.nlhdr = nlh;
|
info.nlhdr = nlh;
|
||||||
info.genlhdr = nlmsg_data(nlh);
|
info.genlhdr = nlmsg_data(nlh);
|
||||||
info.userhdr = nlmsg_data(nlh) + GENL_HDRLEN;
|
info.userhdr = nlmsg_data(nlh) + GENL_HDRLEN;
|
||||||
@ -626,12 +626,12 @@ static struct genl_family genl_ctrl = {
|
|||||||
.netnsok = true,
|
.netnsok = true,
|
||||||
};
|
};
|
||||||
|
|
||||||
static int ctrl_fill_info(struct genl_family *family, u32 pid, u32 seq,
|
static int ctrl_fill_info(struct genl_family *family, u32 portid, u32 seq,
|
||||||
u32 flags, struct sk_buff *skb, u8 cmd)
|
u32 flags, struct sk_buff *skb, u8 cmd)
|
||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
|
|
||||||
hdr = genlmsg_put(skb, pid, seq, &genl_ctrl, flags, cmd);
|
hdr = genlmsg_put(skb, portid, seq, &genl_ctrl, flags, cmd);
|
||||||
if (hdr == NULL)
|
if (hdr == NULL)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -701,7 +701,7 @@ static int ctrl_fill_info(struct genl_family *family, u32 pid, u32 seq,
|
|||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ctrl_fill_mcgrp_info(struct genl_multicast_group *grp, u32 pid,
|
static int ctrl_fill_mcgrp_info(struct genl_multicast_group *grp, u32 portid,
|
||||||
u32 seq, u32 flags, struct sk_buff *skb,
|
u32 seq, u32 flags, struct sk_buff *skb,
|
||||||
u8 cmd)
|
u8 cmd)
|
||||||
{
|
{
|
||||||
@ -709,7 +709,7 @@ static int ctrl_fill_mcgrp_info(struct genl_multicast_group *grp, u32 pid,
|
|||||||
struct nlattr *nla_grps;
|
struct nlattr *nla_grps;
|
||||||
struct nlattr *nest;
|
struct nlattr *nest;
|
||||||
|
|
||||||
hdr = genlmsg_put(skb, pid, seq, &genl_ctrl, flags, cmd);
|
hdr = genlmsg_put(skb, portid, seq, &genl_ctrl, flags, cmd);
|
||||||
if (hdr == NULL)
|
if (hdr == NULL)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -756,7 +756,7 @@ static int ctrl_dumpfamily(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
continue;
|
continue;
|
||||||
if (++n < fams_to_skip)
|
if (++n < fams_to_skip)
|
||||||
continue;
|
continue;
|
||||||
if (ctrl_fill_info(rt, NETLINK_CB(cb->skb).pid,
|
if (ctrl_fill_info(rt, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
skb, CTRL_CMD_NEWFAMILY) < 0)
|
skb, CTRL_CMD_NEWFAMILY) < 0)
|
||||||
goto errout;
|
goto errout;
|
||||||
@ -773,7 +773,7 @@ static int ctrl_dumpfamily(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static struct sk_buff *ctrl_build_family_msg(struct genl_family *family,
|
static struct sk_buff *ctrl_build_family_msg(struct genl_family *family,
|
||||||
u32 pid, int seq, u8 cmd)
|
u32 portid, int seq, u8 cmd)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
int err;
|
int err;
|
||||||
@ -782,7 +782,7 @@ static struct sk_buff *ctrl_build_family_msg(struct genl_family *family,
|
|||||||
if (skb == NULL)
|
if (skb == NULL)
|
||||||
return ERR_PTR(-ENOBUFS);
|
return ERR_PTR(-ENOBUFS);
|
||||||
|
|
||||||
err = ctrl_fill_info(family, pid, seq, 0, skb, cmd);
|
err = ctrl_fill_info(family, portid, seq, 0, skb, cmd);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
nlmsg_free(skb);
|
nlmsg_free(skb);
|
||||||
return ERR_PTR(err);
|
return ERR_PTR(err);
|
||||||
@ -792,7 +792,7 @@ static struct sk_buff *ctrl_build_family_msg(struct genl_family *family,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static struct sk_buff *ctrl_build_mcgrp_msg(struct genl_multicast_group *grp,
|
static struct sk_buff *ctrl_build_mcgrp_msg(struct genl_multicast_group *grp,
|
||||||
u32 pid, int seq, u8 cmd)
|
u32 portid, int seq, u8 cmd)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
int err;
|
int err;
|
||||||
@ -801,7 +801,7 @@ static struct sk_buff *ctrl_build_mcgrp_msg(struct genl_multicast_group *grp,
|
|||||||
if (skb == NULL)
|
if (skb == NULL)
|
||||||
return ERR_PTR(-ENOBUFS);
|
return ERR_PTR(-ENOBUFS);
|
||||||
|
|
||||||
err = ctrl_fill_mcgrp_info(grp, pid, seq, 0, skb, cmd);
|
err = ctrl_fill_mcgrp_info(grp, portid, seq, 0, skb, cmd);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
nlmsg_free(skb);
|
nlmsg_free(skb);
|
||||||
return ERR_PTR(err);
|
return ERR_PTR(err);
|
||||||
@ -853,7 +853,7 @@ static int ctrl_getfamily(struct sk_buff *skb, struct genl_info *info)
|
|||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
}
|
}
|
||||||
|
|
||||||
msg = ctrl_build_family_msg(res, info->snd_pid, info->snd_seq,
|
msg = ctrl_build_family_msg(res, info->snd_portid, info->snd_seq,
|
||||||
CTRL_CMD_NEWFAMILY);
|
CTRL_CMD_NEWFAMILY);
|
||||||
if (IS_ERR(msg))
|
if (IS_ERR(msg))
|
||||||
return PTR_ERR(msg);
|
return PTR_ERR(msg);
|
||||||
@ -971,7 +971,7 @@ static int __init genl_init(void)
|
|||||||
|
|
||||||
subsys_initcall(genl_init);
|
subsys_initcall(genl_init);
|
||||||
|
|
||||||
static int genlmsg_mcast(struct sk_buff *skb, u32 pid, unsigned long group,
|
static int genlmsg_mcast(struct sk_buff *skb, u32 portid, unsigned long group,
|
||||||
gfp_t flags)
|
gfp_t flags)
|
||||||
{
|
{
|
||||||
struct sk_buff *tmp;
|
struct sk_buff *tmp;
|
||||||
@ -986,7 +986,7 @@ static int genlmsg_mcast(struct sk_buff *skb, u32 pid, unsigned long group,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
err = nlmsg_multicast(prev->genl_sock, tmp,
|
err = nlmsg_multicast(prev->genl_sock, tmp,
|
||||||
pid, group, flags);
|
portid, group, flags);
|
||||||
if (err)
|
if (err)
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
@ -994,20 +994,20 @@ static int genlmsg_mcast(struct sk_buff *skb, u32 pid, unsigned long group,
|
|||||||
prev = net;
|
prev = net;
|
||||||
}
|
}
|
||||||
|
|
||||||
return nlmsg_multicast(prev->genl_sock, skb, pid, group, flags);
|
return nlmsg_multicast(prev->genl_sock, skb, portid, group, flags);
|
||||||
error:
|
error:
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
int genlmsg_multicast_allns(struct sk_buff *skb, u32 pid, unsigned int group,
|
int genlmsg_multicast_allns(struct sk_buff *skb, u32 portid, unsigned int group,
|
||||||
gfp_t flags)
|
gfp_t flags)
|
||||||
{
|
{
|
||||||
return genlmsg_mcast(skb, pid, group, flags);
|
return genlmsg_mcast(skb, portid, group, flags);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(genlmsg_multicast_allns);
|
EXPORT_SYMBOL(genlmsg_multicast_allns);
|
||||||
|
|
||||||
void genl_notify(struct sk_buff *skb, struct net *net, u32 pid, u32 group,
|
void genl_notify(struct sk_buff *skb, struct net *net, u32 portid, u32 group,
|
||||||
struct nlmsghdr *nlh, gfp_t flags)
|
struct nlmsghdr *nlh, gfp_t flags)
|
||||||
{
|
{
|
||||||
struct sock *sk = net->genl_sock;
|
struct sock *sk = net->genl_sock;
|
||||||
@ -1016,6 +1016,6 @@ void genl_notify(struct sk_buff *skb, struct net *net, u32 pid, u32 group,
|
|||||||
if (nlh)
|
if (nlh)
|
||||||
report = nlmsg_report(nlh);
|
report = nlmsg_report(nlh);
|
||||||
|
|
||||||
nlmsg_notify(sk, skb, pid, group, report, flags);
|
nlmsg_notify(sk, skb, portid, group, report, flags);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(genl_notify);
|
EXPORT_SYMBOL(genl_notify);
|
||||||
|
@ -58,7 +58,7 @@ static int nfc_genl_send_target(struct sk_buff *msg, struct nfc_target *target,
|
|||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
|
|
||||||
hdr = genlmsg_put(msg, NETLINK_CB(cb->skb).pid, cb->nlh->nlmsg_seq,
|
hdr = genlmsg_put(msg, NETLINK_CB(cb->skb).portid, cb->nlh->nlmsg_seq,
|
||||||
&nfc_genl_family, flags, NFC_CMD_GET_TARGET);
|
&nfc_genl_family, flags, NFC_CMD_GET_TARGET);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
@ -165,7 +165,7 @@ int nfc_genl_targets_found(struct nfc_dev *dev)
|
|||||||
struct sk_buff *msg;
|
struct sk_buff *msg;
|
||||||
void *hdr;
|
void *hdr;
|
||||||
|
|
||||||
dev->genl_data.poll_req_pid = 0;
|
dev->genl_data.poll_req_portid = 0;
|
||||||
|
|
||||||
msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_ATOMIC);
|
msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_ATOMIC);
|
||||||
if (!msg)
|
if (!msg)
|
||||||
@ -347,13 +347,13 @@ int nfc_genl_device_removed(struct nfc_dev *dev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int nfc_genl_send_device(struct sk_buff *msg, struct nfc_dev *dev,
|
static int nfc_genl_send_device(struct sk_buff *msg, struct nfc_dev *dev,
|
||||||
u32 pid, u32 seq,
|
u32 portid, u32 seq,
|
||||||
struct netlink_callback *cb,
|
struct netlink_callback *cb,
|
||||||
int flags)
|
int flags)
|
||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
|
|
||||||
hdr = genlmsg_put(msg, pid, seq, &nfc_genl_family, flags,
|
hdr = genlmsg_put(msg, portid, seq, &nfc_genl_family, flags,
|
||||||
NFC_CMD_GET_DEVICE);
|
NFC_CMD_GET_DEVICE);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
@ -401,7 +401,7 @@ static int nfc_genl_dump_devices(struct sk_buff *skb,
|
|||||||
while (dev) {
|
while (dev) {
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
rc = nfc_genl_send_device(skb, dev, NETLINK_CB(cb->skb).pid,
|
rc = nfc_genl_send_device(skb, dev, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, cb, NLM_F_MULTI);
|
cb->nlh->nlmsg_seq, cb, NLM_F_MULTI);
|
||||||
if (rc < 0)
|
if (rc < 0)
|
||||||
break;
|
break;
|
||||||
@ -520,7 +520,7 @@ static int nfc_genl_get_device(struct sk_buff *skb, struct genl_info *info)
|
|||||||
goto out_putdev;
|
goto out_putdev;
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = nfc_genl_send_device(msg, dev, info->snd_pid, info->snd_seq,
|
rc = nfc_genl_send_device(msg, dev, info->snd_portid, info->snd_seq,
|
||||||
NULL, 0);
|
NULL, 0);
|
||||||
if (rc < 0)
|
if (rc < 0)
|
||||||
goto out_free;
|
goto out_free;
|
||||||
@ -611,7 +611,7 @@ static int nfc_genl_start_poll(struct sk_buff *skb, struct genl_info *info)
|
|||||||
|
|
||||||
rc = nfc_start_poll(dev, im_protocols, tm_protocols);
|
rc = nfc_start_poll(dev, im_protocols, tm_protocols);
|
||||||
if (!rc)
|
if (!rc)
|
||||||
dev->genl_data.poll_req_pid = info->snd_pid;
|
dev->genl_data.poll_req_portid = info->snd_portid;
|
||||||
|
|
||||||
mutex_unlock(&dev->genl_data.genl_data_mutex);
|
mutex_unlock(&dev->genl_data.genl_data_mutex);
|
||||||
|
|
||||||
@ -645,13 +645,13 @@ static int nfc_genl_stop_poll(struct sk_buff *skb, struct genl_info *info)
|
|||||||
|
|
||||||
mutex_lock(&dev->genl_data.genl_data_mutex);
|
mutex_lock(&dev->genl_data.genl_data_mutex);
|
||||||
|
|
||||||
if (dev->genl_data.poll_req_pid != info->snd_pid) {
|
if (dev->genl_data.poll_req_portid != info->snd_portid) {
|
||||||
rc = -EBUSY;
|
rc = -EBUSY;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = nfc_stop_poll(dev);
|
rc = nfc_stop_poll(dev);
|
||||||
dev->genl_data.poll_req_pid = 0;
|
dev->genl_data.poll_req_portid = 0;
|
||||||
|
|
||||||
out:
|
out:
|
||||||
mutex_unlock(&dev->genl_data.genl_data_mutex);
|
mutex_unlock(&dev->genl_data.genl_data_mutex);
|
||||||
@ -771,15 +771,15 @@ static int nfc_genl_rcv_nl_event(struct notifier_block *this,
|
|||||||
if (event != NETLINK_URELEASE || n->protocol != NETLINK_GENERIC)
|
if (event != NETLINK_URELEASE || n->protocol != NETLINK_GENERIC)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
pr_debug("NETLINK_URELEASE event from id %d\n", n->pid);
|
pr_debug("NETLINK_URELEASE event from id %d\n", n->portid);
|
||||||
|
|
||||||
nfc_device_iter_init(&iter);
|
nfc_device_iter_init(&iter);
|
||||||
dev = nfc_device_iter_next(&iter);
|
dev = nfc_device_iter_next(&iter);
|
||||||
|
|
||||||
while (dev) {
|
while (dev) {
|
||||||
if (dev->genl_data.poll_req_pid == n->pid) {
|
if (dev->genl_data.poll_req_portid == n->portid) {
|
||||||
nfc_stop_poll(dev);
|
nfc_stop_poll(dev);
|
||||||
dev->genl_data.poll_req_pid = 0;
|
dev->genl_data.poll_req_portid = 0;
|
||||||
}
|
}
|
||||||
dev = nfc_device_iter_next(&iter);
|
dev = nfc_device_iter_next(&iter);
|
||||||
}
|
}
|
||||||
@ -792,7 +792,7 @@ static int nfc_genl_rcv_nl_event(struct notifier_block *this,
|
|||||||
|
|
||||||
void nfc_genl_data_init(struct nfc_genl_data *genl_data)
|
void nfc_genl_data_init(struct nfc_genl_data *genl_data)
|
||||||
{
|
{
|
||||||
genl_data->poll_req_pid = 0;
|
genl_data->poll_req_portid = 0;
|
||||||
mutex_init(&genl_data->genl_data_mutex);
|
mutex_init(&genl_data->genl_data_mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -286,7 +286,7 @@ static int output_userspace(struct datapath *dp, struct sk_buff *skb,
|
|||||||
upcall.cmd = OVS_PACKET_CMD_ACTION;
|
upcall.cmd = OVS_PACKET_CMD_ACTION;
|
||||||
upcall.key = &OVS_CB(skb)->flow->key;
|
upcall.key = &OVS_CB(skb)->flow->key;
|
||||||
upcall.userdata = NULL;
|
upcall.userdata = NULL;
|
||||||
upcall.pid = 0;
|
upcall.portid = 0;
|
||||||
|
|
||||||
for (a = nla_data(attr), rem = nla_len(attr); rem > 0;
|
for (a = nla_data(attr), rem = nla_len(attr); rem > 0;
|
||||||
a = nla_next(a, &rem)) {
|
a = nla_next(a, &rem)) {
|
||||||
@ -296,7 +296,7 @@ static int output_userspace(struct datapath *dp, struct sk_buff *skb,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case OVS_USERSPACE_ATTR_PID:
|
case OVS_USERSPACE_ATTR_PID:
|
||||||
upcall.pid = nla_get_u32(a);
|
upcall.portid = nla_get_u32(a);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -225,7 +225,7 @@ void ovs_dp_process_received_packet(struct vport *p, struct sk_buff *skb)
|
|||||||
upcall.cmd = OVS_PACKET_CMD_MISS;
|
upcall.cmd = OVS_PACKET_CMD_MISS;
|
||||||
upcall.key = &key;
|
upcall.key = &key;
|
||||||
upcall.userdata = NULL;
|
upcall.userdata = NULL;
|
||||||
upcall.pid = p->upcall_pid;
|
upcall.portid = p->upcall_portid;
|
||||||
ovs_dp_upcall(dp, skb, &upcall);
|
ovs_dp_upcall(dp, skb, &upcall);
|
||||||
consume_skb(skb);
|
consume_skb(skb);
|
||||||
stats_counter = &stats->n_missed;
|
stats_counter = &stats->n_missed;
|
||||||
@ -261,7 +261,7 @@ int ovs_dp_upcall(struct datapath *dp, struct sk_buff *skb,
|
|||||||
int dp_ifindex;
|
int dp_ifindex;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
if (upcall_info->pid == 0) {
|
if (upcall_info->portid == 0) {
|
||||||
err = -ENOTCONN;
|
err = -ENOTCONN;
|
||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
@ -395,7 +395,7 @@ static int queue_userspace_packet(struct net *net, int dp_ifindex,
|
|||||||
|
|
||||||
skb_copy_and_csum_dev(skb, nla_data(nla));
|
skb_copy_and_csum_dev(skb, nla_data(nla));
|
||||||
|
|
||||||
err = genlmsg_unicast(net, user_skb, upcall_info->pid);
|
err = genlmsg_unicast(net, user_skb, upcall_info->portid);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
kfree_skb(nskb);
|
kfree_skb(nskb);
|
||||||
@ -780,7 +780,7 @@ static struct genl_multicast_group ovs_dp_flow_multicast_group = {
|
|||||||
|
|
||||||
/* Called with genl_lock. */
|
/* Called with genl_lock. */
|
||||||
static int ovs_flow_cmd_fill_info(struct sw_flow *flow, struct datapath *dp,
|
static int ovs_flow_cmd_fill_info(struct sw_flow *flow, struct datapath *dp,
|
||||||
struct sk_buff *skb, u32 pid,
|
struct sk_buff *skb, u32 portid,
|
||||||
u32 seq, u32 flags, u8 cmd)
|
u32 seq, u32 flags, u8 cmd)
|
||||||
{
|
{
|
||||||
const int skb_orig_len = skb->len;
|
const int skb_orig_len = skb->len;
|
||||||
@ -795,7 +795,7 @@ static int ovs_flow_cmd_fill_info(struct sw_flow *flow, struct datapath *dp,
|
|||||||
sf_acts = rcu_dereference_protected(flow->sf_acts,
|
sf_acts = rcu_dereference_protected(flow->sf_acts,
|
||||||
lockdep_genl_is_held());
|
lockdep_genl_is_held());
|
||||||
|
|
||||||
ovs_header = genlmsg_put(skb, pid, seq, &dp_flow_genl_family, flags, cmd);
|
ovs_header = genlmsg_put(skb, portid, seq, &dp_flow_genl_family, flags, cmd);
|
||||||
if (!ovs_header)
|
if (!ovs_header)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -879,7 +879,7 @@ static struct sk_buff *ovs_flow_cmd_alloc_info(struct sw_flow *flow)
|
|||||||
|
|
||||||
static struct sk_buff *ovs_flow_cmd_build_info(struct sw_flow *flow,
|
static struct sk_buff *ovs_flow_cmd_build_info(struct sw_flow *flow,
|
||||||
struct datapath *dp,
|
struct datapath *dp,
|
||||||
u32 pid, u32 seq, u8 cmd)
|
u32 portid, u32 seq, u8 cmd)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
int retval;
|
int retval;
|
||||||
@ -888,7 +888,7 @@ static struct sk_buff *ovs_flow_cmd_build_info(struct sw_flow *flow,
|
|||||||
if (!skb)
|
if (!skb)
|
||||||
return ERR_PTR(-ENOMEM);
|
return ERR_PTR(-ENOMEM);
|
||||||
|
|
||||||
retval = ovs_flow_cmd_fill_info(flow, dp, skb, pid, seq, 0, cmd);
|
retval = ovs_flow_cmd_fill_info(flow, dp, skb, portid, seq, 0, cmd);
|
||||||
BUG_ON(retval < 0);
|
BUG_ON(retval < 0);
|
||||||
return skb;
|
return skb;
|
||||||
}
|
}
|
||||||
@ -970,7 +970,7 @@ static int ovs_flow_cmd_new_or_set(struct sk_buff *skb, struct genl_info *info)
|
|||||||
flow->hash = ovs_flow_hash(&key, key_len);
|
flow->hash = ovs_flow_hash(&key, key_len);
|
||||||
ovs_flow_tbl_insert(table, flow);
|
ovs_flow_tbl_insert(table, flow);
|
||||||
|
|
||||||
reply = ovs_flow_cmd_build_info(flow, dp, info->snd_pid,
|
reply = ovs_flow_cmd_build_info(flow, dp, info->snd_portid,
|
||||||
info->snd_seq,
|
info->snd_seq,
|
||||||
OVS_FLOW_CMD_NEW);
|
OVS_FLOW_CMD_NEW);
|
||||||
} else {
|
} else {
|
||||||
@ -1008,7 +1008,7 @@ static int ovs_flow_cmd_new_or_set(struct sk_buff *skb, struct genl_info *info)
|
|||||||
ovs_flow_deferred_free_acts(old_acts);
|
ovs_flow_deferred_free_acts(old_acts);
|
||||||
}
|
}
|
||||||
|
|
||||||
reply = ovs_flow_cmd_build_info(flow, dp, info->snd_pid,
|
reply = ovs_flow_cmd_build_info(flow, dp, info->snd_portid,
|
||||||
info->snd_seq, OVS_FLOW_CMD_NEW);
|
info->snd_seq, OVS_FLOW_CMD_NEW);
|
||||||
|
|
||||||
/* Clear stats. */
|
/* Clear stats. */
|
||||||
@ -1020,7 +1020,7 @@ static int ovs_flow_cmd_new_or_set(struct sk_buff *skb, struct genl_info *info)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!IS_ERR(reply))
|
if (!IS_ERR(reply))
|
||||||
genl_notify(reply, genl_info_net(info), info->snd_pid,
|
genl_notify(reply, genl_info_net(info), info->snd_portid,
|
||||||
ovs_dp_flow_multicast_group.id, info->nlhdr,
|
ovs_dp_flow_multicast_group.id, info->nlhdr,
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
else
|
else
|
||||||
@ -1061,7 +1061,7 @@ static int ovs_flow_cmd_get(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (!flow)
|
if (!flow)
|
||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
|
|
||||||
reply = ovs_flow_cmd_build_info(flow, dp, info->snd_pid,
|
reply = ovs_flow_cmd_build_info(flow, dp, info->snd_portid,
|
||||||
info->snd_seq, OVS_FLOW_CMD_NEW);
|
info->snd_seq, OVS_FLOW_CMD_NEW);
|
||||||
if (IS_ERR(reply))
|
if (IS_ERR(reply))
|
||||||
return PTR_ERR(reply);
|
return PTR_ERR(reply);
|
||||||
@ -1103,13 +1103,13 @@ static int ovs_flow_cmd_del(struct sk_buff *skb, struct genl_info *info)
|
|||||||
|
|
||||||
ovs_flow_tbl_remove(table, flow);
|
ovs_flow_tbl_remove(table, flow);
|
||||||
|
|
||||||
err = ovs_flow_cmd_fill_info(flow, dp, reply, info->snd_pid,
|
err = ovs_flow_cmd_fill_info(flow, dp, reply, info->snd_portid,
|
||||||
info->snd_seq, 0, OVS_FLOW_CMD_DEL);
|
info->snd_seq, 0, OVS_FLOW_CMD_DEL);
|
||||||
BUG_ON(err < 0);
|
BUG_ON(err < 0);
|
||||||
|
|
||||||
ovs_flow_deferred_free(flow);
|
ovs_flow_deferred_free(flow);
|
||||||
|
|
||||||
genl_notify(reply, genl_info_net(info), info->snd_pid,
|
genl_notify(reply, genl_info_net(info), info->snd_portid,
|
||||||
ovs_dp_flow_multicast_group.id, info->nlhdr, GFP_KERNEL);
|
ovs_dp_flow_multicast_group.id, info->nlhdr, GFP_KERNEL);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -1137,7 +1137,7 @@ static int ovs_flow_cmd_dump(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
if (ovs_flow_cmd_fill_info(flow, dp, skb,
|
if (ovs_flow_cmd_fill_info(flow, dp, skb,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
OVS_FLOW_CMD_NEW) < 0)
|
OVS_FLOW_CMD_NEW) < 0)
|
||||||
break;
|
break;
|
||||||
@ -1191,13 +1191,13 @@ static struct genl_multicast_group ovs_dp_datapath_multicast_group = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static int ovs_dp_cmd_fill_info(struct datapath *dp, struct sk_buff *skb,
|
static int ovs_dp_cmd_fill_info(struct datapath *dp, struct sk_buff *skb,
|
||||||
u32 pid, u32 seq, u32 flags, u8 cmd)
|
u32 portid, u32 seq, u32 flags, u8 cmd)
|
||||||
{
|
{
|
||||||
struct ovs_header *ovs_header;
|
struct ovs_header *ovs_header;
|
||||||
struct ovs_dp_stats dp_stats;
|
struct ovs_dp_stats dp_stats;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
ovs_header = genlmsg_put(skb, pid, seq, &dp_datapath_genl_family,
|
ovs_header = genlmsg_put(skb, portid, seq, &dp_datapath_genl_family,
|
||||||
flags, cmd);
|
flags, cmd);
|
||||||
if (!ovs_header)
|
if (!ovs_header)
|
||||||
goto error;
|
goto error;
|
||||||
@ -1222,7 +1222,7 @@ static int ovs_dp_cmd_fill_info(struct datapath *dp, struct sk_buff *skb,
|
|||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct sk_buff *ovs_dp_cmd_build_info(struct datapath *dp, u32 pid,
|
static struct sk_buff *ovs_dp_cmd_build_info(struct datapath *dp, u32 portid,
|
||||||
u32 seq, u8 cmd)
|
u32 seq, u8 cmd)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
@ -1232,7 +1232,7 @@ static struct sk_buff *ovs_dp_cmd_build_info(struct datapath *dp, u32 pid,
|
|||||||
if (!skb)
|
if (!skb)
|
||||||
return ERR_PTR(-ENOMEM);
|
return ERR_PTR(-ENOMEM);
|
||||||
|
|
||||||
retval = ovs_dp_cmd_fill_info(dp, skb, pid, seq, 0, cmd);
|
retval = ovs_dp_cmd_fill_info(dp, skb, portid, seq, 0, cmd);
|
||||||
if (retval < 0) {
|
if (retval < 0) {
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return ERR_PTR(retval);
|
return ERR_PTR(retval);
|
||||||
@ -1311,7 +1311,7 @@ static int ovs_dp_cmd_new(struct sk_buff *skb, struct genl_info *info)
|
|||||||
parms.options = NULL;
|
parms.options = NULL;
|
||||||
parms.dp = dp;
|
parms.dp = dp;
|
||||||
parms.port_no = OVSP_LOCAL;
|
parms.port_no = OVSP_LOCAL;
|
||||||
parms.upcall_pid = nla_get_u32(a[OVS_DP_ATTR_UPCALL_PID]);
|
parms.upcall_portid = nla_get_u32(a[OVS_DP_ATTR_UPCALL_PID]);
|
||||||
|
|
||||||
vport = new_vport(&parms);
|
vport = new_vport(&parms);
|
||||||
if (IS_ERR(vport)) {
|
if (IS_ERR(vport)) {
|
||||||
@ -1322,7 +1322,7 @@ static int ovs_dp_cmd_new(struct sk_buff *skb, struct genl_info *info)
|
|||||||
goto err_destroy_ports_array;
|
goto err_destroy_ports_array;
|
||||||
}
|
}
|
||||||
|
|
||||||
reply = ovs_dp_cmd_build_info(dp, info->snd_pid,
|
reply = ovs_dp_cmd_build_info(dp, info->snd_portid,
|
||||||
info->snd_seq, OVS_DP_CMD_NEW);
|
info->snd_seq, OVS_DP_CMD_NEW);
|
||||||
err = PTR_ERR(reply);
|
err = PTR_ERR(reply);
|
||||||
if (IS_ERR(reply))
|
if (IS_ERR(reply))
|
||||||
@ -1332,7 +1332,7 @@ static int ovs_dp_cmd_new(struct sk_buff *skb, struct genl_info *info)
|
|||||||
list_add_tail(&dp->list_node, &ovs_net->dps);
|
list_add_tail(&dp->list_node, &ovs_net->dps);
|
||||||
rtnl_unlock();
|
rtnl_unlock();
|
||||||
|
|
||||||
genl_notify(reply, genl_info_net(info), info->snd_pid,
|
genl_notify(reply, genl_info_net(info), info->snd_portid,
|
||||||
ovs_dp_datapath_multicast_group.id, info->nlhdr,
|
ovs_dp_datapath_multicast_group.id, info->nlhdr,
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
return 0;
|
return 0;
|
||||||
@ -1394,7 +1394,7 @@ static int ovs_dp_cmd_del(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (IS_ERR(dp))
|
if (IS_ERR(dp))
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
reply = ovs_dp_cmd_build_info(dp, info->snd_pid,
|
reply = ovs_dp_cmd_build_info(dp, info->snd_portid,
|
||||||
info->snd_seq, OVS_DP_CMD_DEL);
|
info->snd_seq, OVS_DP_CMD_DEL);
|
||||||
err = PTR_ERR(reply);
|
err = PTR_ERR(reply);
|
||||||
if (IS_ERR(reply))
|
if (IS_ERR(reply))
|
||||||
@ -1402,7 +1402,7 @@ static int ovs_dp_cmd_del(struct sk_buff *skb, struct genl_info *info)
|
|||||||
|
|
||||||
__dp_destroy(dp);
|
__dp_destroy(dp);
|
||||||
|
|
||||||
genl_notify(reply, genl_info_net(info), info->snd_pid,
|
genl_notify(reply, genl_info_net(info), info->snd_portid,
|
||||||
ovs_dp_datapath_multicast_group.id, info->nlhdr,
|
ovs_dp_datapath_multicast_group.id, info->nlhdr,
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
|
|
||||||
@ -1419,7 +1419,7 @@ static int ovs_dp_cmd_set(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (IS_ERR(dp))
|
if (IS_ERR(dp))
|
||||||
return PTR_ERR(dp);
|
return PTR_ERR(dp);
|
||||||
|
|
||||||
reply = ovs_dp_cmd_build_info(dp, info->snd_pid,
|
reply = ovs_dp_cmd_build_info(dp, info->snd_portid,
|
||||||
info->snd_seq, OVS_DP_CMD_NEW);
|
info->snd_seq, OVS_DP_CMD_NEW);
|
||||||
if (IS_ERR(reply)) {
|
if (IS_ERR(reply)) {
|
||||||
err = PTR_ERR(reply);
|
err = PTR_ERR(reply);
|
||||||
@ -1428,7 +1428,7 @@ static int ovs_dp_cmd_set(struct sk_buff *skb, struct genl_info *info)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
genl_notify(reply, genl_info_net(info), info->snd_pid,
|
genl_notify(reply, genl_info_net(info), info->snd_portid,
|
||||||
ovs_dp_datapath_multicast_group.id, info->nlhdr,
|
ovs_dp_datapath_multicast_group.id, info->nlhdr,
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
|
|
||||||
@ -1444,7 +1444,7 @@ static int ovs_dp_cmd_get(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (IS_ERR(dp))
|
if (IS_ERR(dp))
|
||||||
return PTR_ERR(dp);
|
return PTR_ERR(dp);
|
||||||
|
|
||||||
reply = ovs_dp_cmd_build_info(dp, info->snd_pid,
|
reply = ovs_dp_cmd_build_info(dp, info->snd_portid,
|
||||||
info->snd_seq, OVS_DP_CMD_NEW);
|
info->snd_seq, OVS_DP_CMD_NEW);
|
||||||
if (IS_ERR(reply))
|
if (IS_ERR(reply))
|
||||||
return PTR_ERR(reply);
|
return PTR_ERR(reply);
|
||||||
@ -1461,7 +1461,7 @@ static int ovs_dp_cmd_dump(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
|
|
||||||
list_for_each_entry(dp, &ovs_net->dps, list_node) {
|
list_for_each_entry(dp, &ovs_net->dps, list_node) {
|
||||||
if (i >= skip &&
|
if (i >= skip &&
|
||||||
ovs_dp_cmd_fill_info(dp, skb, NETLINK_CB(cb->skb).pid,
|
ovs_dp_cmd_fill_info(dp, skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
OVS_DP_CMD_NEW) < 0)
|
OVS_DP_CMD_NEW) < 0)
|
||||||
break;
|
break;
|
||||||
@ -1521,13 +1521,13 @@ struct genl_multicast_group ovs_dp_vport_multicast_group = {
|
|||||||
|
|
||||||
/* Called with RTNL lock or RCU read lock. */
|
/* Called with RTNL lock or RCU read lock. */
|
||||||
static int ovs_vport_cmd_fill_info(struct vport *vport, struct sk_buff *skb,
|
static int ovs_vport_cmd_fill_info(struct vport *vport, struct sk_buff *skb,
|
||||||
u32 pid, u32 seq, u32 flags, u8 cmd)
|
u32 portid, u32 seq, u32 flags, u8 cmd)
|
||||||
{
|
{
|
||||||
struct ovs_header *ovs_header;
|
struct ovs_header *ovs_header;
|
||||||
struct ovs_vport_stats vport_stats;
|
struct ovs_vport_stats vport_stats;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
ovs_header = genlmsg_put(skb, pid, seq, &dp_vport_genl_family,
|
ovs_header = genlmsg_put(skb, portid, seq, &dp_vport_genl_family,
|
||||||
flags, cmd);
|
flags, cmd);
|
||||||
if (!ovs_header)
|
if (!ovs_header)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
@ -1537,7 +1537,7 @@ static int ovs_vport_cmd_fill_info(struct vport *vport, struct sk_buff *skb,
|
|||||||
if (nla_put_u32(skb, OVS_VPORT_ATTR_PORT_NO, vport->port_no) ||
|
if (nla_put_u32(skb, OVS_VPORT_ATTR_PORT_NO, vport->port_no) ||
|
||||||
nla_put_u32(skb, OVS_VPORT_ATTR_TYPE, vport->ops->type) ||
|
nla_put_u32(skb, OVS_VPORT_ATTR_TYPE, vport->ops->type) ||
|
||||||
nla_put_string(skb, OVS_VPORT_ATTR_NAME, vport->ops->get_name(vport)) ||
|
nla_put_string(skb, OVS_VPORT_ATTR_NAME, vport->ops->get_name(vport)) ||
|
||||||
nla_put_u32(skb, OVS_VPORT_ATTR_UPCALL_PID, vport->upcall_pid))
|
nla_put_u32(skb, OVS_VPORT_ATTR_UPCALL_PID, vport->upcall_portid))
|
||||||
goto nla_put_failure;
|
goto nla_put_failure;
|
||||||
|
|
||||||
ovs_vport_get_stats(vport, &vport_stats);
|
ovs_vport_get_stats(vport, &vport_stats);
|
||||||
@ -1559,7 +1559,7 @@ static int ovs_vport_cmd_fill_info(struct vport *vport, struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Called with RTNL lock or RCU read lock. */
|
/* Called with RTNL lock or RCU read lock. */
|
||||||
struct sk_buff *ovs_vport_cmd_build_info(struct vport *vport, u32 pid,
|
struct sk_buff *ovs_vport_cmd_build_info(struct vport *vport, u32 portid,
|
||||||
u32 seq, u8 cmd)
|
u32 seq, u8 cmd)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
@ -1569,7 +1569,7 @@ struct sk_buff *ovs_vport_cmd_build_info(struct vport *vport, u32 pid,
|
|||||||
if (!skb)
|
if (!skb)
|
||||||
return ERR_PTR(-ENOMEM);
|
return ERR_PTR(-ENOMEM);
|
||||||
|
|
||||||
retval = ovs_vport_cmd_fill_info(vport, skb, pid, seq, 0, cmd);
|
retval = ovs_vport_cmd_fill_info(vport, skb, portid, seq, 0, cmd);
|
||||||
if (retval < 0) {
|
if (retval < 0) {
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return ERR_PTR(retval);
|
return ERR_PTR(retval);
|
||||||
@ -1661,21 +1661,21 @@ static int ovs_vport_cmd_new(struct sk_buff *skb, struct genl_info *info)
|
|||||||
parms.options = a[OVS_VPORT_ATTR_OPTIONS];
|
parms.options = a[OVS_VPORT_ATTR_OPTIONS];
|
||||||
parms.dp = dp;
|
parms.dp = dp;
|
||||||
parms.port_no = port_no;
|
parms.port_no = port_no;
|
||||||
parms.upcall_pid = nla_get_u32(a[OVS_VPORT_ATTR_UPCALL_PID]);
|
parms.upcall_portid = nla_get_u32(a[OVS_VPORT_ATTR_UPCALL_PID]);
|
||||||
|
|
||||||
vport = new_vport(&parms);
|
vport = new_vport(&parms);
|
||||||
err = PTR_ERR(vport);
|
err = PTR_ERR(vport);
|
||||||
if (IS_ERR(vport))
|
if (IS_ERR(vport))
|
||||||
goto exit_unlock;
|
goto exit_unlock;
|
||||||
|
|
||||||
reply = ovs_vport_cmd_build_info(vport, info->snd_pid, info->snd_seq,
|
reply = ovs_vport_cmd_build_info(vport, info->snd_portid, info->snd_seq,
|
||||||
OVS_VPORT_CMD_NEW);
|
OVS_VPORT_CMD_NEW);
|
||||||
if (IS_ERR(reply)) {
|
if (IS_ERR(reply)) {
|
||||||
err = PTR_ERR(reply);
|
err = PTR_ERR(reply);
|
||||||
ovs_dp_detach_port(vport);
|
ovs_dp_detach_port(vport);
|
||||||
goto exit_unlock;
|
goto exit_unlock;
|
||||||
}
|
}
|
||||||
genl_notify(reply, genl_info_net(info), info->snd_pid,
|
genl_notify(reply, genl_info_net(info), info->snd_portid,
|
||||||
ovs_dp_vport_multicast_group.id, info->nlhdr, GFP_KERNEL);
|
ovs_dp_vport_multicast_group.id, info->nlhdr, GFP_KERNEL);
|
||||||
|
|
||||||
exit_unlock:
|
exit_unlock:
|
||||||
@ -1707,9 +1707,9 @@ static int ovs_vport_cmd_set(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (err)
|
if (err)
|
||||||
goto exit_unlock;
|
goto exit_unlock;
|
||||||
if (a[OVS_VPORT_ATTR_UPCALL_PID])
|
if (a[OVS_VPORT_ATTR_UPCALL_PID])
|
||||||
vport->upcall_pid = nla_get_u32(a[OVS_VPORT_ATTR_UPCALL_PID]);
|
vport->upcall_portid = nla_get_u32(a[OVS_VPORT_ATTR_UPCALL_PID]);
|
||||||
|
|
||||||
reply = ovs_vport_cmd_build_info(vport, info->snd_pid, info->snd_seq,
|
reply = ovs_vport_cmd_build_info(vport, info->snd_portid, info->snd_seq,
|
||||||
OVS_VPORT_CMD_NEW);
|
OVS_VPORT_CMD_NEW);
|
||||||
if (IS_ERR(reply)) {
|
if (IS_ERR(reply)) {
|
||||||
netlink_set_err(sock_net(skb->sk)->genl_sock, 0,
|
netlink_set_err(sock_net(skb->sk)->genl_sock, 0,
|
||||||
@ -1717,7 +1717,7 @@ static int ovs_vport_cmd_set(struct sk_buff *skb, struct genl_info *info)
|
|||||||
goto exit_unlock;
|
goto exit_unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
genl_notify(reply, genl_info_net(info), info->snd_pid,
|
genl_notify(reply, genl_info_net(info), info->snd_portid,
|
||||||
ovs_dp_vport_multicast_group.id, info->nlhdr, GFP_KERNEL);
|
ovs_dp_vport_multicast_group.id, info->nlhdr, GFP_KERNEL);
|
||||||
|
|
||||||
exit_unlock:
|
exit_unlock:
|
||||||
@ -1743,7 +1743,7 @@ static int ovs_vport_cmd_del(struct sk_buff *skb, struct genl_info *info)
|
|||||||
goto exit_unlock;
|
goto exit_unlock;
|
||||||
}
|
}
|
||||||
|
|
||||||
reply = ovs_vport_cmd_build_info(vport, info->snd_pid, info->snd_seq,
|
reply = ovs_vport_cmd_build_info(vport, info->snd_portid, info->snd_seq,
|
||||||
OVS_VPORT_CMD_DEL);
|
OVS_VPORT_CMD_DEL);
|
||||||
err = PTR_ERR(reply);
|
err = PTR_ERR(reply);
|
||||||
if (IS_ERR(reply))
|
if (IS_ERR(reply))
|
||||||
@ -1751,7 +1751,7 @@ static int ovs_vport_cmd_del(struct sk_buff *skb, struct genl_info *info)
|
|||||||
|
|
||||||
ovs_dp_detach_port(vport);
|
ovs_dp_detach_port(vport);
|
||||||
|
|
||||||
genl_notify(reply, genl_info_net(info), info->snd_pid,
|
genl_notify(reply, genl_info_net(info), info->snd_portid,
|
||||||
ovs_dp_vport_multicast_group.id, info->nlhdr, GFP_KERNEL);
|
ovs_dp_vport_multicast_group.id, info->nlhdr, GFP_KERNEL);
|
||||||
|
|
||||||
exit_unlock:
|
exit_unlock:
|
||||||
@ -1773,7 +1773,7 @@ static int ovs_vport_cmd_get(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (IS_ERR(vport))
|
if (IS_ERR(vport))
|
||||||
goto exit_unlock;
|
goto exit_unlock;
|
||||||
|
|
||||||
reply = ovs_vport_cmd_build_info(vport, info->snd_pid, info->snd_seq,
|
reply = ovs_vport_cmd_build_info(vport, info->snd_portid, info->snd_seq,
|
||||||
OVS_VPORT_CMD_NEW);
|
OVS_VPORT_CMD_NEW);
|
||||||
err = PTR_ERR(reply);
|
err = PTR_ERR(reply);
|
||||||
if (IS_ERR(reply))
|
if (IS_ERR(reply))
|
||||||
@ -1808,7 +1808,7 @@ static int ovs_vport_cmd_dump(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
hlist_for_each_entry_rcu(vport, n, &dp->ports[i], dp_hash_node) {
|
hlist_for_each_entry_rcu(vport, n, &dp->ports[i], dp_hash_node) {
|
||||||
if (j >= skip &&
|
if (j >= skip &&
|
||||||
ovs_vport_cmd_fill_info(vport, skb,
|
ovs_vport_cmd_fill_info(vport, skb,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
NLM_F_MULTI,
|
NLM_F_MULTI,
|
||||||
OVS_VPORT_CMD_NEW) < 0)
|
OVS_VPORT_CMD_NEW) < 0)
|
||||||
|
@ -129,7 +129,7 @@ struct dp_upcall_info {
|
|||||||
u8 cmd;
|
u8 cmd;
|
||||||
const struct sw_flow_key *key;
|
const struct sw_flow_key *key;
|
||||||
const struct nlattr *userdata;
|
const struct nlattr *userdata;
|
||||||
u32 pid;
|
u32 portid;
|
||||||
};
|
};
|
||||||
|
|
||||||
static inline struct net *ovs_dp_get_net(struct datapath *dp)
|
static inline struct net *ovs_dp_get_net(struct datapath *dp)
|
||||||
|
@ -125,7 +125,7 @@ struct vport *ovs_vport_alloc(int priv_size, const struct vport_ops *ops,
|
|||||||
|
|
||||||
vport->dp = parms->dp;
|
vport->dp = parms->dp;
|
||||||
vport->port_no = parms->port_no;
|
vport->port_no = parms->port_no;
|
||||||
vport->upcall_pid = parms->upcall_pid;
|
vport->upcall_portid = parms->upcall_portid;
|
||||||
vport->ops = ops;
|
vport->ops = ops;
|
||||||
INIT_HLIST_NODE(&vport->dp_hash_node);
|
INIT_HLIST_NODE(&vport->dp_hash_node);
|
||||||
|
|
||||||
|
@ -70,7 +70,7 @@ struct vport_err_stats {
|
|||||||
* @rcu: RCU callback head for deferred destruction.
|
* @rcu: RCU callback head for deferred destruction.
|
||||||
* @port_no: Index into @dp's @ports array.
|
* @port_no: Index into @dp's @ports array.
|
||||||
* @dp: Datapath to which this port belongs.
|
* @dp: Datapath to which this port belongs.
|
||||||
* @upcall_pid: The Netlink port to use for packets received on this port that
|
* @upcall_portid: The Netlink port to use for packets received on this port that
|
||||||
* miss the flow table.
|
* miss the flow table.
|
||||||
* @hash_node: Element in @dev_table hash table in vport.c.
|
* @hash_node: Element in @dev_table hash table in vport.c.
|
||||||
* @dp_hash_node: Element in @datapath->ports hash table in datapath.c.
|
* @dp_hash_node: Element in @datapath->ports hash table in datapath.c.
|
||||||
@ -83,7 +83,7 @@ struct vport {
|
|||||||
struct rcu_head rcu;
|
struct rcu_head rcu;
|
||||||
u16 port_no;
|
u16 port_no;
|
||||||
struct datapath *dp;
|
struct datapath *dp;
|
||||||
u32 upcall_pid;
|
u32 upcall_portid;
|
||||||
|
|
||||||
struct hlist_node hash_node;
|
struct hlist_node hash_node;
|
||||||
struct hlist_node dp_hash_node;
|
struct hlist_node dp_hash_node;
|
||||||
@ -113,7 +113,7 @@ struct vport_parms {
|
|||||||
/* For ovs_vport_alloc(). */
|
/* For ovs_vport_alloc(). */
|
||||||
struct datapath *dp;
|
struct datapath *dp;
|
||||||
u16 port_no;
|
u16 port_no;
|
||||||
u32 upcall_pid;
|
u32 upcall_portid;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -126,13 +126,13 @@ static int pdiag_put_fanout(struct packet_sock *po, struct sk_buff *nlskb)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int sk_diag_fill(struct sock *sk, struct sk_buff *skb, struct packet_diag_req *req,
|
static int sk_diag_fill(struct sock *sk, struct sk_buff *skb, struct packet_diag_req *req,
|
||||||
u32 pid, u32 seq, u32 flags, int sk_ino)
|
u32 portid, u32 seq, u32 flags, int sk_ino)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct packet_diag_msg *rp;
|
struct packet_diag_msg *rp;
|
||||||
struct packet_sock *po = pkt_sk(sk);
|
struct packet_sock *po = pkt_sk(sk);
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, SOCK_DIAG_BY_FAMILY, sizeof(*rp), flags);
|
nlh = nlmsg_put(skb, portid, seq, SOCK_DIAG_BY_FAMILY, sizeof(*rp), flags);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -184,7 +184,7 @@ static int packet_diag_dump(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (num < s_num)
|
if (num < s_num)
|
||||||
goto next;
|
goto next;
|
||||||
|
|
||||||
if (sk_diag_fill(sk, skb, req, NETLINK_CB(cb->skb).pid,
|
if (sk_diag_fill(sk, skb, req, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
sock_i_ino(sk)) < 0)
|
sock_i_ino(sk)) < 0)
|
||||||
goto done;
|
goto done;
|
||||||
|
@ -33,7 +33,7 @@
|
|||||||
/* Device address handling */
|
/* Device address handling */
|
||||||
|
|
||||||
static int fill_addr(struct sk_buff *skb, struct net_device *dev, u8 addr,
|
static int fill_addr(struct sk_buff *skb, struct net_device *dev, u8 addr,
|
||||||
u32 pid, u32 seq, int event);
|
u32 portid, u32 seq, int event);
|
||||||
|
|
||||||
void phonet_address_notify(int event, struct net_device *dev, u8 addr)
|
void phonet_address_notify(int event, struct net_device *dev, u8 addr)
|
||||||
{
|
{
|
||||||
@ -101,12 +101,12 @@ static int addr_doit(struct sk_buff *skb, struct nlmsghdr *nlh, void *attr)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int fill_addr(struct sk_buff *skb, struct net_device *dev, u8 addr,
|
static int fill_addr(struct sk_buff *skb, struct net_device *dev, u8 addr,
|
||||||
u32 pid, u32 seq, int event)
|
u32 portid, u32 seq, int event)
|
||||||
{
|
{
|
||||||
struct ifaddrmsg *ifm;
|
struct ifaddrmsg *ifm;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*ifm), 0);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*ifm), 0);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -148,7 +148,7 @@ static int getaddr_dumpit(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (fill_addr(skb, pnd->netdev, addr << 2,
|
if (fill_addr(skb, pnd->netdev, addr << 2,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, RTM_NEWADDR) < 0)
|
cb->nlh->nlmsg_seq, RTM_NEWADDR) < 0)
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
@ -165,12 +165,12 @@ static int getaddr_dumpit(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
/* Routes handling */
|
/* Routes handling */
|
||||||
|
|
||||||
static int fill_route(struct sk_buff *skb, struct net_device *dev, u8 dst,
|
static int fill_route(struct sk_buff *skb, struct net_device *dev, u8 dst,
|
||||||
u32 pid, u32 seq, int event)
|
u32 portid, u32 seq, int event)
|
||||||
{
|
{
|
||||||
struct rtmsg *rtm;
|
struct rtmsg *rtm;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*rtm), 0);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*rtm), 0);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -276,7 +276,7 @@ static int route_dumpit(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
|
|
||||||
if (addr_idx++ < addr_start_idx)
|
if (addr_idx++ < addr_start_idx)
|
||||||
continue;
|
continue;
|
||||||
if (fill_route(skb, dev, addr << 2, NETLINK_CB(cb->skb).pid,
|
if (fill_route(skb, dev, addr << 2, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, RTM_NEWROUTE))
|
cb->nlh->nlmsg_seq, RTM_NEWROUTE))
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -644,7 +644,7 @@ int tcf_action_copy_stats(struct sk_buff *skb, struct tc_action *a,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
tca_get_fill(struct sk_buff *skb, struct tc_action *a, u32 pid, u32 seq,
|
tca_get_fill(struct sk_buff *skb, struct tc_action *a, u32 portid, u32 seq,
|
||||||
u16 flags, int event, int bind, int ref)
|
u16 flags, int event, int bind, int ref)
|
||||||
{
|
{
|
||||||
struct tcamsg *t;
|
struct tcamsg *t;
|
||||||
@ -652,7 +652,7 @@ tca_get_fill(struct sk_buff *skb, struct tc_action *a, u32 pid, u32 seq,
|
|||||||
unsigned char *b = skb_tail_pointer(skb);
|
unsigned char *b = skb_tail_pointer(skb);
|
||||||
struct nlattr *nest;
|
struct nlattr *nest;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*t), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*t), flags);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
goto out_nlmsg_trim;
|
goto out_nlmsg_trim;
|
||||||
t = nlmsg_data(nlh);
|
t = nlmsg_data(nlh);
|
||||||
@ -678,7 +678,7 @@ tca_get_fill(struct sk_buff *skb, struct tc_action *a, u32 pid, u32 seq,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
act_get_notify(struct net *net, u32 pid, struct nlmsghdr *n,
|
act_get_notify(struct net *net, u32 portid, struct nlmsghdr *n,
|
||||||
struct tc_action *a, int event)
|
struct tc_action *a, int event)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
@ -686,16 +686,16 @@ act_get_notify(struct net *net, u32 pid, struct nlmsghdr *n,
|
|||||||
skb = alloc_skb(NLMSG_GOODSIZE, GFP_KERNEL);
|
skb = alloc_skb(NLMSG_GOODSIZE, GFP_KERNEL);
|
||||||
if (!skb)
|
if (!skb)
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
if (tca_get_fill(skb, a, pid, n->nlmsg_seq, 0, event, 0, 0) <= 0) {
|
if (tca_get_fill(skb, a, portid, n->nlmsg_seq, 0, event, 0, 0) <= 0) {
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
return rtnl_unicast(skb, net, pid);
|
return rtnl_unicast(skb, net, portid);
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct tc_action *
|
static struct tc_action *
|
||||||
tcf_action_get_1(struct nlattr *nla, struct nlmsghdr *n, u32 pid)
|
tcf_action_get_1(struct nlattr *nla, struct nlmsghdr *n, u32 portid)
|
||||||
{
|
{
|
||||||
struct nlattr *tb[TCA_ACT_MAX + 1];
|
struct nlattr *tb[TCA_ACT_MAX + 1];
|
||||||
struct tc_action *a;
|
struct tc_action *a;
|
||||||
@ -762,7 +762,7 @@ static struct tc_action *create_a(int i)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int tca_action_flush(struct net *net, struct nlattr *nla,
|
static int tca_action_flush(struct net *net, struct nlattr *nla,
|
||||||
struct nlmsghdr *n, u32 pid)
|
struct nlmsghdr *n, u32 portid)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
unsigned char *b;
|
unsigned char *b;
|
||||||
@ -799,7 +799,7 @@ static int tca_action_flush(struct net *net, struct nlattr *nla,
|
|||||||
if (a->ops == NULL)
|
if (a->ops == NULL)
|
||||||
goto err_out;
|
goto err_out;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, n->nlmsg_seq, RTM_DELACTION, sizeof(*t), 0);
|
nlh = nlmsg_put(skb, portid, n->nlmsg_seq, RTM_DELACTION, sizeof(*t), 0);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
goto out_module_put;
|
goto out_module_put;
|
||||||
t = nlmsg_data(nlh);
|
t = nlmsg_data(nlh);
|
||||||
@ -823,7 +823,7 @@ static int tca_action_flush(struct net *net, struct nlattr *nla,
|
|||||||
nlh->nlmsg_flags |= NLM_F_ROOT;
|
nlh->nlmsg_flags |= NLM_F_ROOT;
|
||||||
module_put(a->ops->owner);
|
module_put(a->ops->owner);
|
||||||
kfree(a);
|
kfree(a);
|
||||||
err = rtnetlink_send(skb, net, pid, RTNLGRP_TC,
|
err = rtnetlink_send(skb, net, portid, RTNLGRP_TC,
|
||||||
n->nlmsg_flags & NLM_F_ECHO);
|
n->nlmsg_flags & NLM_F_ECHO);
|
||||||
if (err > 0)
|
if (err > 0)
|
||||||
return 0;
|
return 0;
|
||||||
@ -841,7 +841,7 @@ static int tca_action_flush(struct net *net, struct nlattr *nla,
|
|||||||
|
|
||||||
static int
|
static int
|
||||||
tca_action_gd(struct net *net, struct nlattr *nla, struct nlmsghdr *n,
|
tca_action_gd(struct net *net, struct nlattr *nla, struct nlmsghdr *n,
|
||||||
u32 pid, int event)
|
u32 portid, int event)
|
||||||
{
|
{
|
||||||
int i, ret;
|
int i, ret;
|
||||||
struct nlattr *tb[TCA_ACT_MAX_PRIO + 1];
|
struct nlattr *tb[TCA_ACT_MAX_PRIO + 1];
|
||||||
@ -853,13 +853,13 @@ tca_action_gd(struct net *net, struct nlattr *nla, struct nlmsghdr *n,
|
|||||||
|
|
||||||
if (event == RTM_DELACTION && n->nlmsg_flags & NLM_F_ROOT) {
|
if (event == RTM_DELACTION && n->nlmsg_flags & NLM_F_ROOT) {
|
||||||
if (tb[1] != NULL)
|
if (tb[1] != NULL)
|
||||||
return tca_action_flush(net, tb[1], n, pid);
|
return tca_action_flush(net, tb[1], n, portid);
|
||||||
else
|
else
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 1; i <= TCA_ACT_MAX_PRIO && tb[i]; i++) {
|
for (i = 1; i <= TCA_ACT_MAX_PRIO && tb[i]; i++) {
|
||||||
act = tcf_action_get_1(tb[i], n, pid);
|
act = tcf_action_get_1(tb[i], n, portid);
|
||||||
if (IS_ERR(act)) {
|
if (IS_ERR(act)) {
|
||||||
ret = PTR_ERR(act);
|
ret = PTR_ERR(act);
|
||||||
goto err;
|
goto err;
|
||||||
@ -874,7 +874,7 @@ tca_action_gd(struct net *net, struct nlattr *nla, struct nlmsghdr *n,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (event == RTM_GETACTION)
|
if (event == RTM_GETACTION)
|
||||||
ret = act_get_notify(net, pid, n, head, event);
|
ret = act_get_notify(net, portid, n, head, event);
|
||||||
else { /* delete */
|
else { /* delete */
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
|
|
||||||
@ -884,7 +884,7 @@ tca_action_gd(struct net *net, struct nlattr *nla, struct nlmsghdr *n,
|
|||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (tca_get_fill(skb, head, pid, n->nlmsg_seq, 0, event,
|
if (tca_get_fill(skb, head, portid, n->nlmsg_seq, 0, event,
|
||||||
0, 1) <= 0) {
|
0, 1) <= 0) {
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
@ -893,7 +893,7 @@ tca_action_gd(struct net *net, struct nlattr *nla, struct nlmsghdr *n,
|
|||||||
|
|
||||||
/* now do the delete */
|
/* now do the delete */
|
||||||
tcf_action_destroy(head, 0);
|
tcf_action_destroy(head, 0);
|
||||||
ret = rtnetlink_send(skb, net, pid, RTNLGRP_TC,
|
ret = rtnetlink_send(skb, net, portid, RTNLGRP_TC,
|
||||||
n->nlmsg_flags & NLM_F_ECHO);
|
n->nlmsg_flags & NLM_F_ECHO);
|
||||||
if (ret > 0)
|
if (ret > 0)
|
||||||
return 0;
|
return 0;
|
||||||
@ -905,7 +905,7 @@ tca_action_gd(struct net *net, struct nlattr *nla, struct nlmsghdr *n,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int tcf_add_notify(struct net *net, struct tc_action *a,
|
static int tcf_add_notify(struct net *net, struct tc_action *a,
|
||||||
u32 pid, u32 seq, int event, u16 flags)
|
u32 portid, u32 seq, int event, u16 flags)
|
||||||
{
|
{
|
||||||
struct tcamsg *t;
|
struct tcamsg *t;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
@ -920,7 +920,7 @@ static int tcf_add_notify(struct net *net, struct tc_action *a,
|
|||||||
|
|
||||||
b = skb_tail_pointer(skb);
|
b = skb_tail_pointer(skb);
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*t), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*t), flags);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
goto out_kfree_skb;
|
goto out_kfree_skb;
|
||||||
t = nlmsg_data(nlh);
|
t = nlmsg_data(nlh);
|
||||||
@ -940,7 +940,7 @@ static int tcf_add_notify(struct net *net, struct tc_action *a,
|
|||||||
nlh->nlmsg_len = skb_tail_pointer(skb) - b;
|
nlh->nlmsg_len = skb_tail_pointer(skb) - b;
|
||||||
NETLINK_CB(skb).dst_group = RTNLGRP_TC;
|
NETLINK_CB(skb).dst_group = RTNLGRP_TC;
|
||||||
|
|
||||||
err = rtnetlink_send(skb, net, pid, RTNLGRP_TC, flags & NLM_F_ECHO);
|
err = rtnetlink_send(skb, net, portid, RTNLGRP_TC, flags & NLM_F_ECHO);
|
||||||
if (err > 0)
|
if (err > 0)
|
||||||
err = 0;
|
err = 0;
|
||||||
return err;
|
return err;
|
||||||
@ -953,7 +953,7 @@ static int tcf_add_notify(struct net *net, struct tc_action *a,
|
|||||||
|
|
||||||
static int
|
static int
|
||||||
tcf_action_add(struct net *net, struct nlattr *nla, struct nlmsghdr *n,
|
tcf_action_add(struct net *net, struct nlattr *nla, struct nlmsghdr *n,
|
||||||
u32 pid, int ovr)
|
u32 portid, int ovr)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
struct tc_action *act;
|
struct tc_action *act;
|
||||||
@ -971,7 +971,7 @@ tcf_action_add(struct net *net, struct nlattr *nla, struct nlmsghdr *n,
|
|||||||
/* dump then free all the actions after update; inserted policy
|
/* dump then free all the actions after update; inserted policy
|
||||||
* stays intact
|
* stays intact
|
||||||
*/
|
*/
|
||||||
ret = tcf_add_notify(net, act, pid, seq, RTM_NEWACTION, n->nlmsg_flags);
|
ret = tcf_add_notify(net, act, portid, seq, RTM_NEWACTION, n->nlmsg_flags);
|
||||||
for (a = act; a; a = act) {
|
for (a = act; a; a = act) {
|
||||||
act = a->next;
|
act = a->next;
|
||||||
kfree(a);
|
kfree(a);
|
||||||
@ -984,7 +984,7 @@ static int tc_ctl_action(struct sk_buff *skb, struct nlmsghdr *n, void *arg)
|
|||||||
{
|
{
|
||||||
struct net *net = sock_net(skb->sk);
|
struct net *net = sock_net(skb->sk);
|
||||||
struct nlattr *tca[TCA_ACT_MAX + 1];
|
struct nlattr *tca[TCA_ACT_MAX + 1];
|
||||||
u32 pid = skb ? NETLINK_CB(skb).pid : 0;
|
u32 portid = skb ? NETLINK_CB(skb).portid : 0;
|
||||||
int ret = 0, ovr = 0;
|
int ret = 0, ovr = 0;
|
||||||
|
|
||||||
ret = nlmsg_parse(n, sizeof(struct tcamsg), tca, TCA_ACT_MAX, NULL);
|
ret = nlmsg_parse(n, sizeof(struct tcamsg), tca, TCA_ACT_MAX, NULL);
|
||||||
@ -1008,17 +1008,17 @@ static int tc_ctl_action(struct sk_buff *skb, struct nlmsghdr *n, void *arg)
|
|||||||
if (n->nlmsg_flags & NLM_F_REPLACE)
|
if (n->nlmsg_flags & NLM_F_REPLACE)
|
||||||
ovr = 1;
|
ovr = 1;
|
||||||
replay:
|
replay:
|
||||||
ret = tcf_action_add(net, tca[TCA_ACT_TAB], n, pid, ovr);
|
ret = tcf_action_add(net, tca[TCA_ACT_TAB], n, portid, ovr);
|
||||||
if (ret == -EAGAIN)
|
if (ret == -EAGAIN)
|
||||||
goto replay;
|
goto replay;
|
||||||
break;
|
break;
|
||||||
case RTM_DELACTION:
|
case RTM_DELACTION:
|
||||||
ret = tca_action_gd(net, tca[TCA_ACT_TAB], n,
|
ret = tca_action_gd(net, tca[TCA_ACT_TAB], n,
|
||||||
pid, RTM_DELACTION);
|
portid, RTM_DELACTION);
|
||||||
break;
|
break;
|
||||||
case RTM_GETACTION:
|
case RTM_GETACTION:
|
||||||
ret = tca_action_gd(net, tca[TCA_ACT_TAB], n,
|
ret = tca_action_gd(net, tca[TCA_ACT_TAB], n,
|
||||||
pid, RTM_GETACTION);
|
portid, RTM_GETACTION);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
BUG();
|
BUG();
|
||||||
@ -1085,7 +1085,7 @@ tc_dump_action(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
goto out_module_put;
|
goto out_module_put;
|
||||||
}
|
}
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, NETLINK_CB(cb->skb).pid, cb->nlh->nlmsg_seq,
|
nlh = nlmsg_put(skb, NETLINK_CB(cb->skb).portid, cb->nlh->nlmsg_seq,
|
||||||
cb->nlh->nlmsg_type, sizeof(*t), 0);
|
cb->nlh->nlmsg_type, sizeof(*t), 0);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
goto out_module_put;
|
goto out_module_put;
|
||||||
@ -1109,7 +1109,7 @@ tc_dump_action(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
nla_nest_cancel(skb, nest);
|
nla_nest_cancel(skb, nest);
|
||||||
|
|
||||||
nlh->nlmsg_len = skb_tail_pointer(skb) - b;
|
nlh->nlmsg_len = skb_tail_pointer(skb) - b;
|
||||||
if (NETLINK_CB(cb->skb).pid && ret)
|
if (NETLINK_CB(cb->skb).portid && ret)
|
||||||
nlh->nlmsg_flags |= NLM_F_MULTI;
|
nlh->nlmsg_flags |= NLM_F_MULTI;
|
||||||
module_put(a_o->owner);
|
module_put(a_o->owner);
|
||||||
return skb->len;
|
return skb->len;
|
||||||
|
@ -343,13 +343,13 @@ static int tc_ctl_tfilter(struct sk_buff *skb, struct nlmsghdr *n, void *arg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int tcf_fill_node(struct sk_buff *skb, struct tcf_proto *tp,
|
static int tcf_fill_node(struct sk_buff *skb, struct tcf_proto *tp,
|
||||||
unsigned long fh, u32 pid, u32 seq, u16 flags, int event)
|
unsigned long fh, u32 portid, u32 seq, u16 flags, int event)
|
||||||
{
|
{
|
||||||
struct tcmsg *tcm;
|
struct tcmsg *tcm;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
unsigned char *b = skb_tail_pointer(skb);
|
unsigned char *b = skb_tail_pointer(skb);
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*tcm), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*tcm), flags);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
goto out_nlmsg_trim;
|
goto out_nlmsg_trim;
|
||||||
tcm = nlmsg_data(nlh);
|
tcm = nlmsg_data(nlh);
|
||||||
@ -381,18 +381,18 @@ static int tfilter_notify(struct net *net, struct sk_buff *oskb,
|
|||||||
unsigned long fh, int event)
|
unsigned long fh, int event)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
u32 pid = oskb ? NETLINK_CB(oskb).pid : 0;
|
u32 portid = oskb ? NETLINK_CB(oskb).portid : 0;
|
||||||
|
|
||||||
skb = alloc_skb(NLMSG_GOODSIZE, GFP_KERNEL);
|
skb = alloc_skb(NLMSG_GOODSIZE, GFP_KERNEL);
|
||||||
if (!skb)
|
if (!skb)
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
|
|
||||||
if (tcf_fill_node(skb, tp, fh, pid, n->nlmsg_seq, 0, event) <= 0) {
|
if (tcf_fill_node(skb, tp, fh, portid, n->nlmsg_seq, 0, event) <= 0) {
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
return rtnetlink_send(skb, net, pid, RTNLGRP_TC,
|
return rtnetlink_send(skb, net, portid, RTNLGRP_TC,
|
||||||
n->nlmsg_flags & NLM_F_ECHO);
|
n->nlmsg_flags & NLM_F_ECHO);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -407,7 +407,7 @@ static int tcf_node_dump(struct tcf_proto *tp, unsigned long n,
|
|||||||
{
|
{
|
||||||
struct tcf_dump_args *a = (void *)arg;
|
struct tcf_dump_args *a = (void *)arg;
|
||||||
|
|
||||||
return tcf_fill_node(a->skb, tp, n, NETLINK_CB(a->cb->skb).pid,
|
return tcf_fill_node(a->skb, tp, n, NETLINK_CB(a->cb->skb).portid,
|
||||||
a->cb->nlh->nlmsg_seq, NLM_F_MULTI, RTM_NEWTFILTER);
|
a->cb->nlh->nlmsg_seq, NLM_F_MULTI, RTM_NEWTFILTER);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -465,7 +465,7 @@ static int tc_dump_tfilter(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (t > s_t)
|
if (t > s_t)
|
||||||
memset(&cb->args[1], 0, sizeof(cb->args)-sizeof(cb->args[0]));
|
memset(&cb->args[1], 0, sizeof(cb->args)-sizeof(cb->args[0]));
|
||||||
if (cb->args[1] == 0) {
|
if (cb->args[1] == 0) {
|
||||||
if (tcf_fill_node(skb, tp, 0, NETLINK_CB(cb->skb).pid,
|
if (tcf_fill_node(skb, tp, 0, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
RTM_NEWTFILTER) <= 0)
|
RTM_NEWTFILTER) <= 0)
|
||||||
break;
|
break;
|
||||||
|
@ -1185,7 +1185,7 @@ static int tc_modify_qdisc(struct sk_buff *skb, struct nlmsghdr *n, void *arg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int tc_fill_qdisc(struct sk_buff *skb, struct Qdisc *q, u32 clid,
|
static int tc_fill_qdisc(struct sk_buff *skb, struct Qdisc *q, u32 clid,
|
||||||
u32 pid, u32 seq, u16 flags, int event)
|
u32 portid, u32 seq, u16 flags, int event)
|
||||||
{
|
{
|
||||||
struct tcmsg *tcm;
|
struct tcmsg *tcm;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
@ -1193,7 +1193,7 @@ static int tc_fill_qdisc(struct sk_buff *skb, struct Qdisc *q, u32 clid,
|
|||||||
struct gnet_dump d;
|
struct gnet_dump d;
|
||||||
struct qdisc_size_table *stab;
|
struct qdisc_size_table *stab;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*tcm), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*tcm), flags);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
goto out_nlmsg_trim;
|
goto out_nlmsg_trim;
|
||||||
tcm = nlmsg_data(nlh);
|
tcm = nlmsg_data(nlh);
|
||||||
@ -1248,25 +1248,25 @@ static int qdisc_notify(struct net *net, struct sk_buff *oskb,
|
|||||||
struct Qdisc *old, struct Qdisc *new)
|
struct Qdisc *old, struct Qdisc *new)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
u32 pid = oskb ? NETLINK_CB(oskb).pid : 0;
|
u32 portid = oskb ? NETLINK_CB(oskb).portid : 0;
|
||||||
|
|
||||||
skb = alloc_skb(NLMSG_GOODSIZE, GFP_KERNEL);
|
skb = alloc_skb(NLMSG_GOODSIZE, GFP_KERNEL);
|
||||||
if (!skb)
|
if (!skb)
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
|
|
||||||
if (old && !tc_qdisc_dump_ignore(old)) {
|
if (old && !tc_qdisc_dump_ignore(old)) {
|
||||||
if (tc_fill_qdisc(skb, old, clid, pid, n->nlmsg_seq,
|
if (tc_fill_qdisc(skb, old, clid, portid, n->nlmsg_seq,
|
||||||
0, RTM_DELQDISC) < 0)
|
0, RTM_DELQDISC) < 0)
|
||||||
goto err_out;
|
goto err_out;
|
||||||
}
|
}
|
||||||
if (new && !tc_qdisc_dump_ignore(new)) {
|
if (new && !tc_qdisc_dump_ignore(new)) {
|
||||||
if (tc_fill_qdisc(skb, new, clid, pid, n->nlmsg_seq,
|
if (tc_fill_qdisc(skb, new, clid, portid, n->nlmsg_seq,
|
||||||
old ? NLM_F_REPLACE : 0, RTM_NEWQDISC) < 0)
|
old ? NLM_F_REPLACE : 0, RTM_NEWQDISC) < 0)
|
||||||
goto err_out;
|
goto err_out;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (skb->len)
|
if (skb->len)
|
||||||
return rtnetlink_send(skb, net, pid, RTNLGRP_TC,
|
return rtnetlink_send(skb, net, portid, RTNLGRP_TC,
|
||||||
n->nlmsg_flags & NLM_F_ECHO);
|
n->nlmsg_flags & NLM_F_ECHO);
|
||||||
|
|
||||||
err_out:
|
err_out:
|
||||||
@ -1289,7 +1289,7 @@ static int tc_dump_qdisc_root(struct Qdisc *root, struct sk_buff *skb,
|
|||||||
q_idx++;
|
q_idx++;
|
||||||
} else {
|
} else {
|
||||||
if (!tc_qdisc_dump_ignore(q) &&
|
if (!tc_qdisc_dump_ignore(q) &&
|
||||||
tc_fill_qdisc(skb, q, q->parent, NETLINK_CB(cb->skb).pid,
|
tc_fill_qdisc(skb, q, q->parent, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI, RTM_NEWQDISC) <= 0)
|
cb->nlh->nlmsg_seq, NLM_F_MULTI, RTM_NEWQDISC) <= 0)
|
||||||
goto done;
|
goto done;
|
||||||
q_idx++;
|
q_idx++;
|
||||||
@ -1300,7 +1300,7 @@ static int tc_dump_qdisc_root(struct Qdisc *root, struct sk_buff *skb,
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (!tc_qdisc_dump_ignore(q) &&
|
if (!tc_qdisc_dump_ignore(q) &&
|
||||||
tc_fill_qdisc(skb, q, q->parent, NETLINK_CB(cb->skb).pid,
|
tc_fill_qdisc(skb, q, q->parent, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI, RTM_NEWQDISC) <= 0)
|
cb->nlh->nlmsg_seq, NLM_F_MULTI, RTM_NEWQDISC) <= 0)
|
||||||
goto done;
|
goto done;
|
||||||
q_idx++;
|
q_idx++;
|
||||||
@ -1375,7 +1375,7 @@ static int tc_ctl_tclass(struct sk_buff *skb, struct nlmsghdr *n, void *arg)
|
|||||||
const struct Qdisc_class_ops *cops;
|
const struct Qdisc_class_ops *cops;
|
||||||
unsigned long cl = 0;
|
unsigned long cl = 0;
|
||||||
unsigned long new_cl;
|
unsigned long new_cl;
|
||||||
u32 pid = tcm->tcm_parent;
|
u32 portid = tcm->tcm_parent;
|
||||||
u32 clid = tcm->tcm_handle;
|
u32 clid = tcm->tcm_handle;
|
||||||
u32 qid = TC_H_MAJ(clid);
|
u32 qid = TC_H_MAJ(clid);
|
||||||
int err;
|
int err;
|
||||||
@ -1403,8 +1403,8 @@ static int tc_ctl_tclass(struct sk_buff *skb, struct nlmsghdr *n, void *arg)
|
|||||||
|
|
||||||
/* Step 1. Determine qdisc handle X:0 */
|
/* Step 1. Determine qdisc handle X:0 */
|
||||||
|
|
||||||
if (pid != TC_H_ROOT) {
|
if (portid != TC_H_ROOT) {
|
||||||
u32 qid1 = TC_H_MAJ(pid);
|
u32 qid1 = TC_H_MAJ(portid);
|
||||||
|
|
||||||
if (qid && qid1) {
|
if (qid && qid1) {
|
||||||
/* If both majors are known, they must be identical. */
|
/* If both majors are known, they must be identical. */
|
||||||
@ -1418,10 +1418,10 @@ static int tc_ctl_tclass(struct sk_buff *skb, struct nlmsghdr *n, void *arg)
|
|||||||
/* Now qid is genuine qdisc handle consistent
|
/* Now qid is genuine qdisc handle consistent
|
||||||
* both with parent and child.
|
* both with parent and child.
|
||||||
*
|
*
|
||||||
* TC_H_MAJ(pid) still may be unspecified, complete it now.
|
* TC_H_MAJ(portid) still may be unspecified, complete it now.
|
||||||
*/
|
*/
|
||||||
if (pid)
|
if (portid)
|
||||||
pid = TC_H_MAKE(qid, pid);
|
portid = TC_H_MAKE(qid, portid);
|
||||||
} else {
|
} else {
|
||||||
if (qid == 0)
|
if (qid == 0)
|
||||||
qid = dev->qdisc->handle;
|
qid = dev->qdisc->handle;
|
||||||
@ -1439,7 +1439,7 @@ static int tc_ctl_tclass(struct sk_buff *skb, struct nlmsghdr *n, void *arg)
|
|||||||
|
|
||||||
/* Now try to get class */
|
/* Now try to get class */
|
||||||
if (clid == 0) {
|
if (clid == 0) {
|
||||||
if (pid == TC_H_ROOT)
|
if (portid == TC_H_ROOT)
|
||||||
clid = qid;
|
clid = qid;
|
||||||
} else
|
} else
|
||||||
clid = TC_H_MAKE(qid, clid);
|
clid = TC_H_MAKE(qid, clid);
|
||||||
@ -1478,7 +1478,7 @@ static int tc_ctl_tclass(struct sk_buff *skb, struct nlmsghdr *n, void *arg)
|
|||||||
new_cl = cl;
|
new_cl = cl;
|
||||||
err = -EOPNOTSUPP;
|
err = -EOPNOTSUPP;
|
||||||
if (cops->change)
|
if (cops->change)
|
||||||
err = cops->change(q, clid, pid, tca, &new_cl);
|
err = cops->change(q, clid, portid, tca, &new_cl);
|
||||||
if (err == 0)
|
if (err == 0)
|
||||||
tclass_notify(net, skb, n, q, new_cl, RTM_NEWTCLASS);
|
tclass_notify(net, skb, n, q, new_cl, RTM_NEWTCLASS);
|
||||||
|
|
||||||
@ -1492,7 +1492,7 @@ static int tc_ctl_tclass(struct sk_buff *skb, struct nlmsghdr *n, void *arg)
|
|||||||
|
|
||||||
static int tc_fill_tclass(struct sk_buff *skb, struct Qdisc *q,
|
static int tc_fill_tclass(struct sk_buff *skb, struct Qdisc *q,
|
||||||
unsigned long cl,
|
unsigned long cl,
|
||||||
u32 pid, u32 seq, u16 flags, int event)
|
u32 portid, u32 seq, u16 flags, int event)
|
||||||
{
|
{
|
||||||
struct tcmsg *tcm;
|
struct tcmsg *tcm;
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
@ -1500,7 +1500,7 @@ static int tc_fill_tclass(struct sk_buff *skb, struct Qdisc *q,
|
|||||||
struct gnet_dump d;
|
struct gnet_dump d;
|
||||||
const struct Qdisc_class_ops *cl_ops = q->ops->cl_ops;
|
const struct Qdisc_class_ops *cl_ops = q->ops->cl_ops;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, event, sizeof(*tcm), flags);
|
nlh = nlmsg_put(skb, portid, seq, event, sizeof(*tcm), flags);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
goto out_nlmsg_trim;
|
goto out_nlmsg_trim;
|
||||||
tcm = nlmsg_data(nlh);
|
tcm = nlmsg_data(nlh);
|
||||||
@ -1540,18 +1540,18 @@ static int tclass_notify(struct net *net, struct sk_buff *oskb,
|
|||||||
unsigned long cl, int event)
|
unsigned long cl, int event)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
u32 pid = oskb ? NETLINK_CB(oskb).pid : 0;
|
u32 portid = oskb ? NETLINK_CB(oskb).portid : 0;
|
||||||
|
|
||||||
skb = alloc_skb(NLMSG_GOODSIZE, GFP_KERNEL);
|
skb = alloc_skb(NLMSG_GOODSIZE, GFP_KERNEL);
|
||||||
if (!skb)
|
if (!skb)
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
|
|
||||||
if (tc_fill_tclass(skb, q, cl, pid, n->nlmsg_seq, 0, event) < 0) {
|
if (tc_fill_tclass(skb, q, cl, portid, n->nlmsg_seq, 0, event) < 0) {
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
return rtnetlink_send(skb, net, pid, RTNLGRP_TC,
|
return rtnetlink_send(skb, net, portid, RTNLGRP_TC,
|
||||||
n->nlmsg_flags & NLM_F_ECHO);
|
n->nlmsg_flags & NLM_F_ECHO);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1565,7 +1565,7 @@ static int qdisc_class_dump(struct Qdisc *q, unsigned long cl, struct qdisc_walk
|
|||||||
{
|
{
|
||||||
struct qdisc_dump_args *a = (struct qdisc_dump_args *)arg;
|
struct qdisc_dump_args *a = (struct qdisc_dump_args *)arg;
|
||||||
|
|
||||||
return tc_fill_tclass(a->skb, q, cl, NETLINK_CB(a->cb->skb).pid,
|
return tc_fill_tclass(a->skb, q, cl, NETLINK_CB(a->cb->skb).portid,
|
||||||
a->cb->nlh->nlmsg_seq, NLM_F_MULTI, RTM_NEWTCLASS);
|
a->cb->nlh->nlmsg_seq, NLM_F_MULTI, RTM_NEWTCLASS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,7 +62,7 @@ static int handle_cmd(struct sk_buff *skb, struct genl_info *info)
|
|||||||
rep_nlh = nlmsg_hdr(rep_buf);
|
rep_nlh = nlmsg_hdr(rep_buf);
|
||||||
memcpy(rep_nlh, req_nlh, hdr_space);
|
memcpy(rep_nlh, req_nlh, hdr_space);
|
||||||
rep_nlh->nlmsg_len = rep_buf->len;
|
rep_nlh->nlmsg_len = rep_buf->len;
|
||||||
genlmsg_unicast(&init_net, rep_buf, NETLINK_CB(skb).pid);
|
genlmsg_unicast(&init_net, rep_buf, NETLINK_CB(skb).portid);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -110,12 +110,12 @@ static int sk_diag_show_rqlen(struct sock *sk, struct sk_buff *nlskb)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int sk_diag_fill(struct sock *sk, struct sk_buff *skb, struct unix_diag_req *req,
|
static int sk_diag_fill(struct sock *sk, struct sk_buff *skb, struct unix_diag_req *req,
|
||||||
u32 pid, u32 seq, u32 flags, int sk_ino)
|
u32 portid, u32 seq, u32 flags, int sk_ino)
|
||||||
{
|
{
|
||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
struct unix_diag_msg *rep;
|
struct unix_diag_msg *rep;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, SOCK_DIAG_BY_FAMILY, sizeof(*rep),
|
nlh = nlmsg_put(skb, portid, seq, SOCK_DIAG_BY_FAMILY, sizeof(*rep),
|
||||||
flags);
|
flags);
|
||||||
if (!nlh)
|
if (!nlh)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
@ -159,7 +159,7 @@ static int sk_diag_fill(struct sock *sk, struct sk_buff *skb, struct unix_diag_r
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int sk_diag_dump(struct sock *sk, struct sk_buff *skb, struct unix_diag_req *req,
|
static int sk_diag_dump(struct sock *sk, struct sk_buff *skb, struct unix_diag_req *req,
|
||||||
u32 pid, u32 seq, u32 flags)
|
u32 portid, u32 seq, u32 flags)
|
||||||
{
|
{
|
||||||
int sk_ino;
|
int sk_ino;
|
||||||
|
|
||||||
@ -170,7 +170,7 @@ static int sk_diag_dump(struct sock *sk, struct sk_buff *skb, struct unix_diag_r
|
|||||||
if (!sk_ino)
|
if (!sk_ino)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
return sk_diag_fill(sk, skb, req, pid, seq, flags, sk_ino);
|
return sk_diag_fill(sk, skb, req, portid, seq, flags, sk_ino);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int unix_diag_dump(struct sk_buff *skb, struct netlink_callback *cb)
|
static int unix_diag_dump(struct sk_buff *skb, struct netlink_callback *cb)
|
||||||
@ -200,7 +200,7 @@ static int unix_diag_dump(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
if (!(req->udiag_states & (1 << sk->sk_state)))
|
if (!(req->udiag_states & (1 << sk->sk_state)))
|
||||||
goto next;
|
goto next;
|
||||||
if (sk_diag_dump(sk, skb, req,
|
if (sk_diag_dump(sk, skb, req,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq,
|
cb->nlh->nlmsg_seq,
|
||||||
NLM_F_MULTI) < 0)
|
NLM_F_MULTI) < 0)
|
||||||
goto done;
|
goto done;
|
||||||
@ -267,7 +267,7 @@ static int unix_diag_get_exact(struct sk_buff *in_skb,
|
|||||||
if (!rep)
|
if (!rep)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
err = sk_diag_fill(sk, rep, req, NETLINK_CB(in_skb).pid,
|
err = sk_diag_fill(sk, rep, req, NETLINK_CB(in_skb).portid,
|
||||||
nlh->nlmsg_seq, 0, req->udiag_ino);
|
nlh->nlmsg_seq, 0, req->udiag_ino);
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
nlmsg_free(rep);
|
nlmsg_free(rep);
|
||||||
@ -277,7 +277,7 @@ static int unix_diag_get_exact(struct sk_buff *in_skb,
|
|||||||
|
|
||||||
goto again;
|
goto again;
|
||||||
}
|
}
|
||||||
err = netlink_unicast(net->diag_nlsk, rep, NETLINK_CB(in_skb).pid,
|
err = netlink_unicast(net->diag_nlsk, rep, NETLINK_CB(in_skb).portid,
|
||||||
MSG_DONTWAIT);
|
MSG_DONTWAIT);
|
||||||
if (err > 0)
|
if (err > 0)
|
||||||
err = 0;
|
err = 0;
|
||||||
|
@ -55,7 +55,7 @@ struct cfg80211_registered_device {
|
|||||||
int opencount; /* also protected by devlist_mtx */
|
int opencount; /* also protected by devlist_mtx */
|
||||||
wait_queue_head_t dev_wait;
|
wait_queue_head_t dev_wait;
|
||||||
|
|
||||||
u32 ap_beacons_nlpid;
|
u32 ap_beacons_nlportid;
|
||||||
|
|
||||||
/* protected by RTNL only */
|
/* protected by RTNL only */
|
||||||
int num_running_ifaces;
|
int num_running_ifaces;
|
||||||
|
@ -615,7 +615,7 @@ EXPORT_SYMBOL(cfg80211_del_sta);
|
|||||||
struct cfg80211_mgmt_registration {
|
struct cfg80211_mgmt_registration {
|
||||||
struct list_head list;
|
struct list_head list;
|
||||||
|
|
||||||
u32 nlpid;
|
u32 nlportid;
|
||||||
|
|
||||||
int match_len;
|
int match_len;
|
||||||
|
|
||||||
@ -624,7 +624,7 @@ struct cfg80211_mgmt_registration {
|
|||||||
u8 match[];
|
u8 match[];
|
||||||
};
|
};
|
||||||
|
|
||||||
int cfg80211_mlme_register_mgmt(struct wireless_dev *wdev, u32 snd_pid,
|
int cfg80211_mlme_register_mgmt(struct wireless_dev *wdev, u32 snd_portid,
|
||||||
u16 frame_type, const u8 *match_data,
|
u16 frame_type, const u8 *match_data,
|
||||||
int match_len)
|
int match_len)
|
||||||
{
|
{
|
||||||
@ -672,7 +672,7 @@ int cfg80211_mlme_register_mgmt(struct wireless_dev *wdev, u32 snd_pid,
|
|||||||
|
|
||||||
memcpy(nreg->match, match_data, match_len);
|
memcpy(nreg->match, match_data, match_len);
|
||||||
nreg->match_len = match_len;
|
nreg->match_len = match_len;
|
||||||
nreg->nlpid = snd_pid;
|
nreg->nlportid = snd_portid;
|
||||||
nreg->frame_type = cpu_to_le16(frame_type);
|
nreg->frame_type = cpu_to_le16(frame_type);
|
||||||
list_add(&nreg->list, &wdev->mgmt_registrations);
|
list_add(&nreg->list, &wdev->mgmt_registrations);
|
||||||
|
|
||||||
@ -685,7 +685,7 @@ int cfg80211_mlme_register_mgmt(struct wireless_dev *wdev, u32 snd_pid,
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cfg80211_mlme_unregister_socket(struct wireless_dev *wdev, u32 nlpid)
|
void cfg80211_mlme_unregister_socket(struct wireless_dev *wdev, u32 nlportid)
|
||||||
{
|
{
|
||||||
struct wiphy *wiphy = wdev->wiphy;
|
struct wiphy *wiphy = wdev->wiphy;
|
||||||
struct cfg80211_registered_device *rdev = wiphy_to_dev(wiphy);
|
struct cfg80211_registered_device *rdev = wiphy_to_dev(wiphy);
|
||||||
@ -694,7 +694,7 @@ void cfg80211_mlme_unregister_socket(struct wireless_dev *wdev, u32 nlpid)
|
|||||||
spin_lock_bh(&wdev->mgmt_registrations_lock);
|
spin_lock_bh(&wdev->mgmt_registrations_lock);
|
||||||
|
|
||||||
list_for_each_entry_safe(reg, tmp, &wdev->mgmt_registrations, list) {
|
list_for_each_entry_safe(reg, tmp, &wdev->mgmt_registrations, list) {
|
||||||
if (reg->nlpid != nlpid)
|
if (reg->nlportid != nlportid)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if (rdev->ops->mgmt_frame_register) {
|
if (rdev->ops->mgmt_frame_register) {
|
||||||
@ -710,8 +710,8 @@ void cfg80211_mlme_unregister_socket(struct wireless_dev *wdev, u32 nlpid)
|
|||||||
|
|
||||||
spin_unlock_bh(&wdev->mgmt_registrations_lock);
|
spin_unlock_bh(&wdev->mgmt_registrations_lock);
|
||||||
|
|
||||||
if (nlpid == wdev->ap_unexpected_nlpid)
|
if (nlportid == wdev->ap_unexpected_nlportid)
|
||||||
wdev->ap_unexpected_nlpid = 0;
|
wdev->ap_unexpected_nlportid = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cfg80211_mlme_purge_registrations(struct wireless_dev *wdev)
|
void cfg80211_mlme_purge_registrations(struct wireless_dev *wdev)
|
||||||
@ -872,7 +872,7 @@ bool cfg80211_rx_mgmt(struct wireless_dev *wdev, int freq, int sig_mbm,
|
|||||||
/* found match! */
|
/* found match! */
|
||||||
|
|
||||||
/* Indicate the received Action frame to user space */
|
/* Indicate the received Action frame to user space */
|
||||||
if (nl80211_send_mgmt(rdev, wdev, reg->nlpid,
|
if (nl80211_send_mgmt(rdev, wdev, reg->nlportid,
|
||||||
freq, sig_mbm,
|
freq, sig_mbm,
|
||||||
buf, len, gfp))
|
buf, len, gfp))
|
||||||
continue;
|
continue;
|
||||||
|
@ -496,11 +496,11 @@ static bool is_valid_ie_attr(const struct nlattr *attr)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* message building helper */
|
/* message building helper */
|
||||||
static inline void *nl80211hdr_put(struct sk_buff *skb, u32 pid, u32 seq,
|
static inline void *nl80211hdr_put(struct sk_buff *skb, u32 portid, u32 seq,
|
||||||
int flags, u8 cmd)
|
int flags, u8 cmd)
|
||||||
{
|
{
|
||||||
/* since there is no private header just add the generic one */
|
/* since there is no private header just add the generic one */
|
||||||
return genlmsg_put(skb, pid, seq, &nl80211_fam, flags, cmd);
|
return genlmsg_put(skb, portid, seq, &nl80211_fam, flags, cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int nl80211_msg_put_channel(struct sk_buff *msg,
|
static int nl80211_msg_put_channel(struct sk_buff *msg,
|
||||||
@ -851,7 +851,7 @@ static int nl80211_put_iface_combinations(struct wiphy *wiphy,
|
|||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int nl80211_send_wiphy(struct sk_buff *msg, u32 pid, u32 seq, int flags,
|
static int nl80211_send_wiphy(struct sk_buff *msg, u32 portid, u32 seq, int flags,
|
||||||
struct cfg80211_registered_device *dev)
|
struct cfg80211_registered_device *dev)
|
||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
@ -866,7 +866,7 @@ static int nl80211_send_wiphy(struct sk_buff *msg, u32 pid, u32 seq, int flags,
|
|||||||
const struct ieee80211_txrx_stypes *mgmt_stypes =
|
const struct ieee80211_txrx_stypes *mgmt_stypes =
|
||||||
dev->wiphy.mgmt_stypes;
|
dev->wiphy.mgmt_stypes;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, pid, seq, flags, NL80211_CMD_NEW_WIPHY);
|
hdr = nl80211hdr_put(msg, portid, seq, flags, NL80211_CMD_NEW_WIPHY);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -1267,7 +1267,7 @@ static int nl80211_dump_wiphy(struct sk_buff *skb, struct netlink_callback *cb)
|
|||||||
continue;
|
continue;
|
||||||
if (++idx <= start)
|
if (++idx <= start)
|
||||||
continue;
|
continue;
|
||||||
if (nl80211_send_wiphy(skb, NETLINK_CB(cb->skb).pid,
|
if (nl80211_send_wiphy(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
dev) < 0) {
|
dev) < 0) {
|
||||||
idx--;
|
idx--;
|
||||||
@ -1290,7 +1290,7 @@ static int nl80211_get_wiphy(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (!msg)
|
if (!msg)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
if (nl80211_send_wiphy(msg, info->snd_pid, info->snd_seq, 0, dev) < 0) {
|
if (nl80211_send_wiphy(msg, info->snd_portid, info->snd_seq, 0, dev) < 0) {
|
||||||
nlmsg_free(msg);
|
nlmsg_free(msg);
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
}
|
}
|
||||||
@ -1736,14 +1736,14 @@ static inline u64 wdev_id(struct wireless_dev *wdev)
|
|||||||
((u64)wiphy_to_dev(wdev->wiphy)->wiphy_idx << 32);
|
((u64)wiphy_to_dev(wdev->wiphy)->wiphy_idx << 32);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int nl80211_send_iface(struct sk_buff *msg, u32 pid, u32 seq, int flags,
|
static int nl80211_send_iface(struct sk_buff *msg, u32 portid, u32 seq, int flags,
|
||||||
struct cfg80211_registered_device *rdev,
|
struct cfg80211_registered_device *rdev,
|
||||||
struct wireless_dev *wdev)
|
struct wireless_dev *wdev)
|
||||||
{
|
{
|
||||||
struct net_device *dev = wdev->netdev;
|
struct net_device *dev = wdev->netdev;
|
||||||
void *hdr;
|
void *hdr;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, pid, seq, flags, NL80211_CMD_NEW_INTERFACE);
|
hdr = nl80211hdr_put(msg, portid, seq, flags, NL80211_CMD_NEW_INTERFACE);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -1807,7 +1807,7 @@ static int nl80211_dump_interface(struct sk_buff *skb, struct netlink_callback *
|
|||||||
if_idx++;
|
if_idx++;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (nl80211_send_iface(skb, NETLINK_CB(cb->skb).pid,
|
if (nl80211_send_iface(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
rdev, wdev) < 0) {
|
rdev, wdev) < 0) {
|
||||||
mutex_unlock(&rdev->devlist_mtx);
|
mutex_unlock(&rdev->devlist_mtx);
|
||||||
@ -1838,7 +1838,7 @@ static int nl80211_get_interface(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (!msg)
|
if (!msg)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
if (nl80211_send_iface(msg, info->snd_pid, info->snd_seq, 0,
|
if (nl80211_send_iface(msg, info->snd_portid, info->snd_seq, 0,
|
||||||
dev, wdev) < 0) {
|
dev, wdev) < 0) {
|
||||||
nlmsg_free(msg);
|
nlmsg_free(msg);
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
@ -2056,7 +2056,7 @@ static int nl80211_new_interface(struct sk_buff *skb, struct genl_info *info)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (nl80211_send_iface(msg, info->snd_pid, info->snd_seq, 0,
|
if (nl80211_send_iface(msg, info->snd_portid, info->snd_seq, 0,
|
||||||
rdev, wdev) < 0) {
|
rdev, wdev) < 0) {
|
||||||
nlmsg_free(msg);
|
nlmsg_free(msg);
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
@ -2191,7 +2191,7 @@ static int nl80211_get_key(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (!msg)
|
if (!msg)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, info->snd_pid, info->snd_seq, 0,
|
hdr = nl80211hdr_put(msg, info->snd_portid, info->snd_seq, 0,
|
||||||
NL80211_CMD_NEW_KEY);
|
NL80211_CMD_NEW_KEY);
|
||||||
if (IS_ERR(hdr))
|
if (IS_ERR(hdr))
|
||||||
return PTR_ERR(hdr);
|
return PTR_ERR(hdr);
|
||||||
@ -2769,7 +2769,7 @@ static bool nl80211_put_sta_rate(struct sk_buff *msg, struct rate_info *info,
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int nl80211_send_station(struct sk_buff *msg, u32 pid, u32 seq,
|
static int nl80211_send_station(struct sk_buff *msg, u32 portid, u32 seq,
|
||||||
int flags,
|
int flags,
|
||||||
struct cfg80211_registered_device *rdev,
|
struct cfg80211_registered_device *rdev,
|
||||||
struct net_device *dev,
|
struct net_device *dev,
|
||||||
@ -2778,7 +2778,7 @@ static int nl80211_send_station(struct sk_buff *msg, u32 pid, u32 seq,
|
|||||||
void *hdr;
|
void *hdr;
|
||||||
struct nlattr *sinfoattr, *bss_param;
|
struct nlattr *sinfoattr, *bss_param;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, pid, seq, flags, NL80211_CMD_NEW_STATION);
|
hdr = nl80211hdr_put(msg, portid, seq, flags, NL80211_CMD_NEW_STATION);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -2931,7 +2931,7 @@ static int nl80211_dump_station(struct sk_buff *skb,
|
|||||||
goto out_err;
|
goto out_err;
|
||||||
|
|
||||||
if (nl80211_send_station(skb,
|
if (nl80211_send_station(skb,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
dev, netdev, mac_addr,
|
dev, netdev, mac_addr,
|
||||||
&sinfo) < 0)
|
&sinfo) < 0)
|
||||||
@ -2977,7 +2977,7 @@ static int nl80211_get_station(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (!msg)
|
if (!msg)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
if (nl80211_send_station(msg, info->snd_pid, info->snd_seq, 0,
|
if (nl80211_send_station(msg, info->snd_portid, info->snd_seq, 0,
|
||||||
rdev, dev, mac_addr, &sinfo) < 0) {
|
rdev, dev, mac_addr, &sinfo) < 0) {
|
||||||
nlmsg_free(msg);
|
nlmsg_free(msg);
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
@ -3303,7 +3303,7 @@ static int nl80211_del_station(struct sk_buff *skb, struct genl_info *info)
|
|||||||
return rdev->ops->del_station(&rdev->wiphy, dev, mac_addr);
|
return rdev->ops->del_station(&rdev->wiphy, dev, mac_addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int nl80211_send_mpath(struct sk_buff *msg, u32 pid, u32 seq,
|
static int nl80211_send_mpath(struct sk_buff *msg, u32 portid, u32 seq,
|
||||||
int flags, struct net_device *dev,
|
int flags, struct net_device *dev,
|
||||||
u8 *dst, u8 *next_hop,
|
u8 *dst, u8 *next_hop,
|
||||||
struct mpath_info *pinfo)
|
struct mpath_info *pinfo)
|
||||||
@ -3311,7 +3311,7 @@ static int nl80211_send_mpath(struct sk_buff *msg, u32 pid, u32 seq,
|
|||||||
void *hdr;
|
void *hdr;
|
||||||
struct nlattr *pinfoattr;
|
struct nlattr *pinfoattr;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, pid, seq, flags, NL80211_CMD_NEW_STATION);
|
hdr = nl80211hdr_put(msg, portid, seq, flags, NL80211_CMD_NEW_STATION);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -3389,7 +3389,7 @@ static int nl80211_dump_mpath(struct sk_buff *skb,
|
|||||||
if (err)
|
if (err)
|
||||||
goto out_err;
|
goto out_err;
|
||||||
|
|
||||||
if (nl80211_send_mpath(skb, NETLINK_CB(cb->skb).pid,
|
if (nl80211_send_mpath(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
netdev, dst, next_hop,
|
netdev, dst, next_hop,
|
||||||
&pinfo) < 0)
|
&pinfo) < 0)
|
||||||
@ -3438,7 +3438,7 @@ static int nl80211_get_mpath(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (!msg)
|
if (!msg)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
if (nl80211_send_mpath(msg, info->snd_pid, info->snd_seq, 0,
|
if (nl80211_send_mpath(msg, info->snd_portid, info->snd_seq, 0,
|
||||||
dev, dst, next_hop, &pinfo) < 0) {
|
dev, dst, next_hop, &pinfo) < 0) {
|
||||||
nlmsg_free(msg);
|
nlmsg_free(msg);
|
||||||
return -ENOBUFS;
|
return -ENOBUFS;
|
||||||
@ -3679,7 +3679,7 @@ static int nl80211_get_mesh_config(struct sk_buff *skb,
|
|||||||
msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
|
msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
|
||||||
if (!msg)
|
if (!msg)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
hdr = nl80211hdr_put(msg, info->snd_pid, info->snd_seq, 0,
|
hdr = nl80211hdr_put(msg, info->snd_portid, info->snd_seq, 0,
|
||||||
NL80211_CMD_GET_MESH_CONFIG);
|
NL80211_CMD_GET_MESH_CONFIG);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
goto out;
|
goto out;
|
||||||
@ -3998,7 +3998,7 @@ static int nl80211_get_reg(struct sk_buff *skb, struct genl_info *info)
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, info->snd_pid, info->snd_seq, 0,
|
hdr = nl80211hdr_put(msg, info->snd_portid, info->snd_seq, 0,
|
||||||
NL80211_CMD_GET_REG);
|
NL80211_CMD_GET_REG);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
goto put_failure;
|
goto put_failure;
|
||||||
@ -4616,7 +4616,7 @@ static int nl80211_send_bss(struct sk_buff *msg, struct netlink_callback *cb,
|
|||||||
|
|
||||||
ASSERT_WDEV_LOCK(wdev);
|
ASSERT_WDEV_LOCK(wdev);
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, NETLINK_CB(cb->skb).pid, seq, flags,
|
hdr = nl80211hdr_put(msg, NETLINK_CB(cb->skb).portid, seq, flags,
|
||||||
NL80211_CMD_NEW_SCAN_RESULTS);
|
NL80211_CMD_NEW_SCAN_RESULTS);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
return -1;
|
return -1;
|
||||||
@ -4735,14 +4735,14 @@ static int nl80211_dump_scan(struct sk_buff *skb,
|
|||||||
return skb->len;
|
return skb->len;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int nl80211_send_survey(struct sk_buff *msg, u32 pid, u32 seq,
|
static int nl80211_send_survey(struct sk_buff *msg, u32 portid, u32 seq,
|
||||||
int flags, struct net_device *dev,
|
int flags, struct net_device *dev,
|
||||||
struct survey_info *survey)
|
struct survey_info *survey)
|
||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
struct nlattr *infoattr;
|
struct nlattr *infoattr;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, pid, seq, flags,
|
hdr = nl80211hdr_put(msg, portid, seq, flags,
|
||||||
NL80211_CMD_NEW_SURVEY_RESULTS);
|
NL80211_CMD_NEW_SURVEY_RESULTS);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
@ -4836,7 +4836,7 @@ static int nl80211_dump_survey(struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (nl80211_send_survey(skb,
|
if (nl80211_send_survey(skb,
|
||||||
NETLINK_CB(cb->skb).pid,
|
NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
netdev,
|
netdev,
|
||||||
&survey) < 0)
|
&survey) < 0)
|
||||||
@ -5451,7 +5451,7 @@ static int nl80211_testmode_dump(struct sk_buff *skb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
void *hdr = nl80211hdr_put(skb, NETLINK_CB(cb->skb).pid,
|
void *hdr = nl80211hdr_put(skb, NETLINK_CB(cb->skb).portid,
|
||||||
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
cb->nlh->nlmsg_seq, NLM_F_MULTI,
|
||||||
NL80211_CMD_TESTMODE);
|
NL80211_CMD_TESTMODE);
|
||||||
struct nlattr *tmdata;
|
struct nlattr *tmdata;
|
||||||
@ -5491,7 +5491,7 @@ static int nl80211_testmode_dump(struct sk_buff *skb,
|
|||||||
|
|
||||||
static struct sk_buff *
|
static struct sk_buff *
|
||||||
__cfg80211_testmode_alloc_skb(struct cfg80211_registered_device *rdev,
|
__cfg80211_testmode_alloc_skb(struct cfg80211_registered_device *rdev,
|
||||||
int approxlen, u32 pid, u32 seq, gfp_t gfp)
|
int approxlen, u32 portid, u32 seq, gfp_t gfp)
|
||||||
{
|
{
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
void *hdr;
|
void *hdr;
|
||||||
@ -5501,7 +5501,7 @@ __cfg80211_testmode_alloc_skb(struct cfg80211_registered_device *rdev,
|
|||||||
if (!skb)
|
if (!skb)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(skb, pid, seq, 0, NL80211_CMD_TESTMODE);
|
hdr = nl80211hdr_put(skb, portid, seq, 0, NL80211_CMD_TESTMODE);
|
||||||
if (!hdr) {
|
if (!hdr) {
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -5531,7 +5531,7 @@ struct sk_buff *cfg80211_testmode_alloc_reply_skb(struct wiphy *wiphy,
|
|||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
return __cfg80211_testmode_alloc_skb(rdev, approxlen,
|
return __cfg80211_testmode_alloc_skb(rdev, approxlen,
|
||||||
rdev->testmode_info->snd_pid,
|
rdev->testmode_info->snd_portid,
|
||||||
rdev->testmode_info->snd_seq,
|
rdev->testmode_info->snd_seq,
|
||||||
GFP_KERNEL);
|
GFP_KERNEL);
|
||||||
}
|
}
|
||||||
@ -5867,7 +5867,7 @@ static int nl80211_remain_on_channel(struct sk_buff *skb,
|
|||||||
if (!msg)
|
if (!msg)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, info->snd_pid, info->snd_seq, 0,
|
hdr = nl80211hdr_put(msg, info->snd_portid, info->snd_seq, 0,
|
||||||
NL80211_CMD_REMAIN_ON_CHANNEL);
|
NL80211_CMD_REMAIN_ON_CHANNEL);
|
||||||
|
|
||||||
if (IS_ERR(hdr)) {
|
if (IS_ERR(hdr)) {
|
||||||
@ -6086,7 +6086,7 @@ static int nl80211_register_mgmt(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (!rdev->ops->mgmt_tx)
|
if (!rdev->ops->mgmt_tx)
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
return cfg80211_mlme_register_mgmt(wdev, info->snd_pid, frame_type,
|
return cfg80211_mlme_register_mgmt(wdev, info->snd_portid, frame_type,
|
||||||
nla_data(info->attrs[NL80211_ATTR_FRAME_MATCH]),
|
nla_data(info->attrs[NL80211_ATTR_FRAME_MATCH]),
|
||||||
nla_len(info->attrs[NL80211_ATTR_FRAME_MATCH]));
|
nla_len(info->attrs[NL80211_ATTR_FRAME_MATCH]));
|
||||||
}
|
}
|
||||||
@ -6167,7 +6167,7 @@ static int nl80211_tx_mgmt(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (!msg)
|
if (!msg)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, info->snd_pid, info->snd_seq, 0,
|
hdr = nl80211hdr_put(msg, info->snd_portid, info->snd_seq, 0,
|
||||||
NL80211_CMD_FRAME);
|
NL80211_CMD_FRAME);
|
||||||
|
|
||||||
if (IS_ERR(hdr)) {
|
if (IS_ERR(hdr)) {
|
||||||
@ -6284,7 +6284,7 @@ static int nl80211_get_power_save(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (!msg)
|
if (!msg)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, info->snd_pid, info->snd_seq, 0,
|
hdr = nl80211hdr_put(msg, info->snd_portid, info->snd_seq, 0,
|
||||||
NL80211_CMD_GET_POWER_SAVE);
|
NL80211_CMD_GET_POWER_SAVE);
|
||||||
if (!hdr) {
|
if (!hdr) {
|
||||||
err = -ENOBUFS;
|
err = -ENOBUFS;
|
||||||
@ -6486,7 +6486,7 @@ static int nl80211_get_wowlan(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (!msg)
|
if (!msg)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, info->snd_pid, info->snd_seq, 0,
|
hdr = nl80211hdr_put(msg, info->snd_portid, info->snd_seq, 0,
|
||||||
NL80211_CMD_GET_WOWLAN);
|
NL80211_CMD_GET_WOWLAN);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
goto nla_put_failure;
|
goto nla_put_failure;
|
||||||
@ -6760,10 +6760,10 @@ static int nl80211_register_unexpected_frame(struct sk_buff *skb,
|
|||||||
wdev->iftype != NL80211_IFTYPE_P2P_GO)
|
wdev->iftype != NL80211_IFTYPE_P2P_GO)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
if (wdev->ap_unexpected_nlpid)
|
if (wdev->ap_unexpected_nlportid)
|
||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
|
|
||||||
wdev->ap_unexpected_nlpid = info->snd_pid;
|
wdev->ap_unexpected_nlportid = info->snd_portid;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -6793,7 +6793,7 @@ static int nl80211_probe_client(struct sk_buff *skb,
|
|||||||
if (!msg)
|
if (!msg)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, info->snd_pid, info->snd_seq, 0,
|
hdr = nl80211hdr_put(msg, info->snd_portid, info->snd_seq, 0,
|
||||||
NL80211_CMD_PROBE_CLIENT);
|
NL80211_CMD_PROBE_CLIENT);
|
||||||
|
|
||||||
if (IS_ERR(hdr)) {
|
if (IS_ERR(hdr)) {
|
||||||
@ -6828,10 +6828,10 @@ static int nl80211_register_beacons(struct sk_buff *skb, struct genl_info *info)
|
|||||||
if (!(rdev->wiphy.flags & WIPHY_FLAG_REPORTS_OBSS))
|
if (!(rdev->wiphy.flags & WIPHY_FLAG_REPORTS_OBSS))
|
||||||
return -EOPNOTSUPP;
|
return -EOPNOTSUPP;
|
||||||
|
|
||||||
if (rdev->ap_beacons_nlpid)
|
if (rdev->ap_beacons_nlportid)
|
||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
|
|
||||||
rdev->ap_beacons_nlpid = info->snd_pid;
|
rdev->ap_beacons_nlportid = info->snd_portid;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -7628,12 +7628,12 @@ static int nl80211_add_scan_req(struct sk_buff *msg,
|
|||||||
static int nl80211_send_scan_msg(struct sk_buff *msg,
|
static int nl80211_send_scan_msg(struct sk_buff *msg,
|
||||||
struct cfg80211_registered_device *rdev,
|
struct cfg80211_registered_device *rdev,
|
||||||
struct wireless_dev *wdev,
|
struct wireless_dev *wdev,
|
||||||
u32 pid, u32 seq, int flags,
|
u32 portid, u32 seq, int flags,
|
||||||
u32 cmd)
|
u32 cmd)
|
||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, pid, seq, flags, cmd);
|
hdr = nl80211hdr_put(msg, portid, seq, flags, cmd);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -7657,11 +7657,11 @@ static int
|
|||||||
nl80211_send_sched_scan_msg(struct sk_buff *msg,
|
nl80211_send_sched_scan_msg(struct sk_buff *msg,
|
||||||
struct cfg80211_registered_device *rdev,
|
struct cfg80211_registered_device *rdev,
|
||||||
struct net_device *netdev,
|
struct net_device *netdev,
|
||||||
u32 pid, u32 seq, int flags, u32 cmd)
|
u32 portid, u32 seq, int flags, u32 cmd)
|
||||||
{
|
{
|
||||||
void *hdr;
|
void *hdr;
|
||||||
|
|
||||||
hdr = nl80211hdr_put(msg, pid, seq, flags, cmd);
|
hdr = nl80211hdr_put(msg, portid, seq, flags, cmd);
|
||||||
if (!hdr)
|
if (!hdr)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
@ -8370,9 +8370,9 @@ static bool __nl80211_unexpected_frame(struct net_device *dev, u8 cmd,
|
|||||||
struct sk_buff *msg;
|
struct sk_buff *msg;
|
||||||
void *hdr;
|
void *hdr;
|
||||||
int err;
|
int err;
|
||||||
u32 nlpid = ACCESS_ONCE(wdev->ap_unexpected_nlpid);
|
u32 nlportid = ACCESS_ONCE(wdev->ap_unexpected_nlportid);
|
||||||
|
|
||||||
if (!nlpid)
|
if (!nlportid)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
msg = nlmsg_new(100, gfp);
|
msg = nlmsg_new(100, gfp);
|
||||||
@ -8396,7 +8396,7 @@ static bool __nl80211_unexpected_frame(struct net_device *dev, u8 cmd,
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
genlmsg_unicast(wiphy_net(&rdev->wiphy), msg, nlpid);
|
genlmsg_unicast(wiphy_net(&rdev->wiphy), msg, nlportid);
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
nla_put_failure:
|
nla_put_failure:
|
||||||
@ -8420,7 +8420,7 @@ bool nl80211_unexpected_4addr_frame(struct net_device *dev,
|
|||||||
}
|
}
|
||||||
|
|
||||||
int nl80211_send_mgmt(struct cfg80211_registered_device *rdev,
|
int nl80211_send_mgmt(struct cfg80211_registered_device *rdev,
|
||||||
struct wireless_dev *wdev, u32 nlpid,
|
struct wireless_dev *wdev, u32 nlportid,
|
||||||
int freq, int sig_dbm,
|
int freq, int sig_dbm,
|
||||||
const u8 *buf, size_t len, gfp_t gfp)
|
const u8 *buf, size_t len, gfp_t gfp)
|
||||||
{
|
{
|
||||||
@ -8449,7 +8449,7 @@ int nl80211_send_mgmt(struct cfg80211_registered_device *rdev,
|
|||||||
|
|
||||||
genlmsg_end(msg, hdr);
|
genlmsg_end(msg, hdr);
|
||||||
|
|
||||||
return genlmsg_unicast(wiphy_net(&rdev->wiphy), msg, nlpid);
|
return genlmsg_unicast(wiphy_net(&rdev->wiphy), msg, nlportid);
|
||||||
|
|
||||||
nla_put_failure:
|
nla_put_failure:
|
||||||
genlmsg_cancel(msg, hdr);
|
genlmsg_cancel(msg, hdr);
|
||||||
@ -8804,9 +8804,9 @@ void cfg80211_report_obss_beacon(struct wiphy *wiphy,
|
|||||||
struct cfg80211_registered_device *rdev = wiphy_to_dev(wiphy);
|
struct cfg80211_registered_device *rdev = wiphy_to_dev(wiphy);
|
||||||
struct sk_buff *msg;
|
struct sk_buff *msg;
|
||||||
void *hdr;
|
void *hdr;
|
||||||
u32 nlpid = ACCESS_ONCE(rdev->ap_beacons_nlpid);
|
u32 nlportid = ACCESS_ONCE(rdev->ap_beacons_nlportid);
|
||||||
|
|
||||||
if (!nlpid)
|
if (!nlportid)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
msg = nlmsg_new(len + 100, gfp);
|
msg = nlmsg_new(len + 100, gfp);
|
||||||
@ -8829,7 +8829,7 @@ void cfg80211_report_obss_beacon(struct wiphy *wiphy,
|
|||||||
|
|
||||||
genlmsg_end(msg, hdr);
|
genlmsg_end(msg, hdr);
|
||||||
|
|
||||||
genlmsg_unicast(wiphy_net(&rdev->wiphy), msg, nlpid);
|
genlmsg_unicast(wiphy_net(&rdev->wiphy), msg, nlportid);
|
||||||
return;
|
return;
|
||||||
|
|
||||||
nla_put_failure:
|
nla_put_failure:
|
||||||
@ -8853,9 +8853,9 @@ static int nl80211_netlink_notify(struct notifier_block * nb,
|
|||||||
|
|
||||||
list_for_each_entry_rcu(rdev, &cfg80211_rdev_list, list) {
|
list_for_each_entry_rcu(rdev, &cfg80211_rdev_list, list) {
|
||||||
list_for_each_entry_rcu(wdev, &rdev->wdev_list, list)
|
list_for_each_entry_rcu(wdev, &rdev->wdev_list, list)
|
||||||
cfg80211_mlme_unregister_socket(wdev, notify->pid);
|
cfg80211_mlme_unregister_socket(wdev, notify->portid);
|
||||||
if (rdev->ap_beacons_nlpid == notify->pid)
|
if (rdev->ap_beacons_nlportid == notify->portid)
|
||||||
rdev->ap_beacons_nlpid = 0;
|
rdev->ap_beacons_nlportid = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
rcu_read_unlock();
|
rcu_read_unlock();
|
||||||
|
@ -166,7 +166,7 @@ static DEFINE_SPINLOCK(xfrm_state_gc_lock);
|
|||||||
int __xfrm_state_delete(struct xfrm_state *x);
|
int __xfrm_state_delete(struct xfrm_state *x);
|
||||||
|
|
||||||
int km_query(struct xfrm_state *x, struct xfrm_tmpl *t, struct xfrm_policy *pol);
|
int km_query(struct xfrm_state *x, struct xfrm_tmpl *t, struct xfrm_policy *pol);
|
||||||
void km_state_expired(struct xfrm_state *x, int hard, u32 pid);
|
void km_state_expired(struct xfrm_state *x, int hard, u32 portid);
|
||||||
|
|
||||||
static struct xfrm_state_afinfo *xfrm_state_lock_afinfo(unsigned int family)
|
static struct xfrm_state_afinfo *xfrm_state_lock_afinfo(unsigned int family)
|
||||||
{
|
{
|
||||||
@ -1674,13 +1674,13 @@ void km_state_notify(struct xfrm_state *x, const struct km_event *c)
|
|||||||
EXPORT_SYMBOL(km_policy_notify);
|
EXPORT_SYMBOL(km_policy_notify);
|
||||||
EXPORT_SYMBOL(km_state_notify);
|
EXPORT_SYMBOL(km_state_notify);
|
||||||
|
|
||||||
void km_state_expired(struct xfrm_state *x, int hard, u32 pid)
|
void km_state_expired(struct xfrm_state *x, int hard, u32 portid)
|
||||||
{
|
{
|
||||||
struct net *net = xs_net(x);
|
struct net *net = xs_net(x);
|
||||||
struct km_event c;
|
struct km_event c;
|
||||||
|
|
||||||
c.data.hard = hard;
|
c.data.hard = hard;
|
||||||
c.pid = pid;
|
c.portid = portid;
|
||||||
c.event = XFRM_MSG_EXPIRE;
|
c.event = XFRM_MSG_EXPIRE;
|
||||||
km_state_notify(x, &c);
|
km_state_notify(x, &c);
|
||||||
|
|
||||||
@ -1726,13 +1726,13 @@ int km_new_mapping(struct xfrm_state *x, xfrm_address_t *ipaddr, __be16 sport)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(km_new_mapping);
|
EXPORT_SYMBOL(km_new_mapping);
|
||||||
|
|
||||||
void km_policy_expired(struct xfrm_policy *pol, int dir, int hard, u32 pid)
|
void km_policy_expired(struct xfrm_policy *pol, int dir, int hard, u32 portid)
|
||||||
{
|
{
|
||||||
struct net *net = xp_net(pol);
|
struct net *net = xp_net(pol);
|
||||||
struct km_event c;
|
struct km_event c;
|
||||||
|
|
||||||
c.data.hard = hard;
|
c.data.hard = hard;
|
||||||
c.pid = pid;
|
c.portid = portid;
|
||||||
c.event = XFRM_MSG_POLEXPIRE;
|
c.event = XFRM_MSG_POLEXPIRE;
|
||||||
km_policy_notify(pol, dir, &c);
|
km_policy_notify(pol, dir, &c);
|
||||||
|
|
||||||
|
@ -603,7 +603,7 @@ static int xfrm_add_sa(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
}
|
}
|
||||||
|
|
||||||
c.seq = nlh->nlmsg_seq;
|
c.seq = nlh->nlmsg_seq;
|
||||||
c.pid = nlh->nlmsg_pid;
|
c.portid = nlh->nlmsg_pid;
|
||||||
c.event = nlh->nlmsg_type;
|
c.event = nlh->nlmsg_type;
|
||||||
|
|
||||||
km_state_notify(x, &c);
|
km_state_notify(x, &c);
|
||||||
@ -676,7 +676,7 @@ static int xfrm_del_sa(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
c.seq = nlh->nlmsg_seq;
|
c.seq = nlh->nlmsg_seq;
|
||||||
c.pid = nlh->nlmsg_pid;
|
c.portid = nlh->nlmsg_pid;
|
||||||
c.event = nlh->nlmsg_type;
|
c.event = nlh->nlmsg_type;
|
||||||
km_state_notify(x, &c);
|
km_state_notify(x, &c);
|
||||||
|
|
||||||
@ -826,7 +826,7 @@ static int dump_one_state(struct xfrm_state *x, int count, void *ptr)
|
|||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, NETLINK_CB(in_skb).pid, sp->nlmsg_seq,
|
nlh = nlmsg_put(skb, NETLINK_CB(in_skb).portid, sp->nlmsg_seq,
|
||||||
XFRM_MSG_NEWSA, sizeof(*p), sp->nlmsg_flags);
|
XFRM_MSG_NEWSA, sizeof(*p), sp->nlmsg_flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
@ -904,7 +904,7 @@ static inline size_t xfrm_spdinfo_msgsize(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int build_spdinfo(struct sk_buff *skb, struct net *net,
|
static int build_spdinfo(struct sk_buff *skb, struct net *net,
|
||||||
u32 pid, u32 seq, u32 flags)
|
u32 portid, u32 seq, u32 flags)
|
||||||
{
|
{
|
||||||
struct xfrmk_spdinfo si;
|
struct xfrmk_spdinfo si;
|
||||||
struct xfrmu_spdinfo spc;
|
struct xfrmu_spdinfo spc;
|
||||||
@ -913,7 +913,7 @@ static int build_spdinfo(struct sk_buff *skb, struct net *net,
|
|||||||
int err;
|
int err;
|
||||||
u32 *f;
|
u32 *f;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, XFRM_MSG_NEWSPDINFO, sizeof(u32), 0);
|
nlh = nlmsg_put(skb, portid, seq, XFRM_MSG_NEWSPDINFO, sizeof(u32), 0);
|
||||||
if (nlh == NULL) /* shouldn't really happen ... */
|
if (nlh == NULL) /* shouldn't really happen ... */
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -946,17 +946,17 @@ static int xfrm_get_spdinfo(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
struct net *net = sock_net(skb->sk);
|
struct net *net = sock_net(skb->sk);
|
||||||
struct sk_buff *r_skb;
|
struct sk_buff *r_skb;
|
||||||
u32 *flags = nlmsg_data(nlh);
|
u32 *flags = nlmsg_data(nlh);
|
||||||
u32 spid = NETLINK_CB(skb).pid;
|
u32 sportid = NETLINK_CB(skb).portid;
|
||||||
u32 seq = nlh->nlmsg_seq;
|
u32 seq = nlh->nlmsg_seq;
|
||||||
|
|
||||||
r_skb = nlmsg_new(xfrm_spdinfo_msgsize(), GFP_ATOMIC);
|
r_skb = nlmsg_new(xfrm_spdinfo_msgsize(), GFP_ATOMIC);
|
||||||
if (r_skb == NULL)
|
if (r_skb == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
if (build_spdinfo(r_skb, net, spid, seq, *flags) < 0)
|
if (build_spdinfo(r_skb, net, sportid, seq, *flags) < 0)
|
||||||
BUG();
|
BUG();
|
||||||
|
|
||||||
return nlmsg_unicast(net->xfrm.nlsk, r_skb, spid);
|
return nlmsg_unicast(net->xfrm.nlsk, r_skb, sportid);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline size_t xfrm_sadinfo_msgsize(void)
|
static inline size_t xfrm_sadinfo_msgsize(void)
|
||||||
@ -967,7 +967,7 @@ static inline size_t xfrm_sadinfo_msgsize(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int build_sadinfo(struct sk_buff *skb, struct net *net,
|
static int build_sadinfo(struct sk_buff *skb, struct net *net,
|
||||||
u32 pid, u32 seq, u32 flags)
|
u32 portid, u32 seq, u32 flags)
|
||||||
{
|
{
|
||||||
struct xfrmk_sadinfo si;
|
struct xfrmk_sadinfo si;
|
||||||
struct xfrmu_sadhinfo sh;
|
struct xfrmu_sadhinfo sh;
|
||||||
@ -975,7 +975,7 @@ static int build_sadinfo(struct sk_buff *skb, struct net *net,
|
|||||||
int err;
|
int err;
|
||||||
u32 *f;
|
u32 *f;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, pid, seq, XFRM_MSG_NEWSADINFO, sizeof(u32), 0);
|
nlh = nlmsg_put(skb, portid, seq, XFRM_MSG_NEWSADINFO, sizeof(u32), 0);
|
||||||
if (nlh == NULL) /* shouldn't really happen ... */
|
if (nlh == NULL) /* shouldn't really happen ... */
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -1003,17 +1003,17 @@ static int xfrm_get_sadinfo(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
struct net *net = sock_net(skb->sk);
|
struct net *net = sock_net(skb->sk);
|
||||||
struct sk_buff *r_skb;
|
struct sk_buff *r_skb;
|
||||||
u32 *flags = nlmsg_data(nlh);
|
u32 *flags = nlmsg_data(nlh);
|
||||||
u32 spid = NETLINK_CB(skb).pid;
|
u32 sportid = NETLINK_CB(skb).portid;
|
||||||
u32 seq = nlh->nlmsg_seq;
|
u32 seq = nlh->nlmsg_seq;
|
||||||
|
|
||||||
r_skb = nlmsg_new(xfrm_sadinfo_msgsize(), GFP_ATOMIC);
|
r_skb = nlmsg_new(xfrm_sadinfo_msgsize(), GFP_ATOMIC);
|
||||||
if (r_skb == NULL)
|
if (r_skb == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
if (build_sadinfo(r_skb, net, spid, seq, *flags) < 0)
|
if (build_sadinfo(r_skb, net, sportid, seq, *flags) < 0)
|
||||||
BUG();
|
BUG();
|
||||||
|
|
||||||
return nlmsg_unicast(net->xfrm.nlsk, r_skb, spid);
|
return nlmsg_unicast(net->xfrm.nlsk, r_skb, sportid);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int xfrm_get_sa(struct sk_buff *skb, struct nlmsghdr *nlh,
|
static int xfrm_get_sa(struct sk_buff *skb, struct nlmsghdr *nlh,
|
||||||
@ -1033,7 +1033,7 @@ static int xfrm_get_sa(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
if (IS_ERR(resp_skb)) {
|
if (IS_ERR(resp_skb)) {
|
||||||
err = PTR_ERR(resp_skb);
|
err = PTR_ERR(resp_skb);
|
||||||
} else {
|
} else {
|
||||||
err = nlmsg_unicast(net->xfrm.nlsk, resp_skb, NETLINK_CB(skb).pid);
|
err = nlmsg_unicast(net->xfrm.nlsk, resp_skb, NETLINK_CB(skb).portid);
|
||||||
}
|
}
|
||||||
xfrm_state_put(x);
|
xfrm_state_put(x);
|
||||||
out_noput:
|
out_noput:
|
||||||
@ -1114,7 +1114,7 @@ static int xfrm_alloc_userspi(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = nlmsg_unicast(net->xfrm.nlsk, resp_skb, NETLINK_CB(skb).pid);
|
err = nlmsg_unicast(net->xfrm.nlsk, resp_skb, NETLINK_CB(skb).portid);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
xfrm_state_put(x);
|
xfrm_state_put(x);
|
||||||
@ -1401,7 +1401,7 @@ static int xfrm_add_policy(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
|
|
||||||
c.event = nlh->nlmsg_type;
|
c.event = nlh->nlmsg_type;
|
||||||
c.seq = nlh->nlmsg_seq;
|
c.seq = nlh->nlmsg_seq;
|
||||||
c.pid = nlh->nlmsg_pid;
|
c.portid = nlh->nlmsg_pid;
|
||||||
km_policy_notify(xp, p->dir, &c);
|
km_policy_notify(xp, p->dir, &c);
|
||||||
|
|
||||||
xfrm_pol_put(xp);
|
xfrm_pol_put(xp);
|
||||||
@ -1486,7 +1486,7 @@ static int dump_one_policy(struct xfrm_policy *xp, int dir, int count, void *ptr
|
|||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, NETLINK_CB(in_skb).pid, sp->nlmsg_seq,
|
nlh = nlmsg_put(skb, NETLINK_CB(in_skb).portid, sp->nlmsg_seq,
|
||||||
XFRM_MSG_NEWPOLICY, sizeof(*p), sp->nlmsg_flags);
|
XFRM_MSG_NEWPOLICY, sizeof(*p), sp->nlmsg_flags);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
@ -1621,7 +1621,7 @@ static int xfrm_get_policy(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
err = PTR_ERR(resp_skb);
|
err = PTR_ERR(resp_skb);
|
||||||
} else {
|
} else {
|
||||||
err = nlmsg_unicast(net->xfrm.nlsk, resp_skb,
|
err = nlmsg_unicast(net->xfrm.nlsk, resp_skb,
|
||||||
NETLINK_CB(skb).pid);
|
NETLINK_CB(skb).portid);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
uid_t loginuid = audit_get_loginuid(current);
|
uid_t loginuid = audit_get_loginuid(current);
|
||||||
@ -1638,7 +1638,7 @@ static int xfrm_get_policy(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
c.data.byid = p->index;
|
c.data.byid = p->index;
|
||||||
c.event = nlh->nlmsg_type;
|
c.event = nlh->nlmsg_type;
|
||||||
c.seq = nlh->nlmsg_seq;
|
c.seq = nlh->nlmsg_seq;
|
||||||
c.pid = nlh->nlmsg_pid;
|
c.portid = nlh->nlmsg_pid;
|
||||||
km_policy_notify(xp, p->dir, &c);
|
km_policy_notify(xp, p->dir, &c);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1668,7 +1668,7 @@ static int xfrm_flush_sa(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
c.data.proto = p->proto;
|
c.data.proto = p->proto;
|
||||||
c.event = nlh->nlmsg_type;
|
c.event = nlh->nlmsg_type;
|
||||||
c.seq = nlh->nlmsg_seq;
|
c.seq = nlh->nlmsg_seq;
|
||||||
c.pid = nlh->nlmsg_pid;
|
c.portid = nlh->nlmsg_pid;
|
||||||
c.net = net;
|
c.net = net;
|
||||||
km_state_notify(NULL, &c);
|
km_state_notify(NULL, &c);
|
||||||
|
|
||||||
@ -1695,7 +1695,7 @@ static int build_aevent(struct sk_buff *skb, struct xfrm_state *x, const struct
|
|||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, c->pid, c->seq, XFRM_MSG_NEWAE, sizeof(*id), 0);
|
nlh = nlmsg_put(skb, c->portid, c->seq, XFRM_MSG_NEWAE, sizeof(*id), 0);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -1777,11 +1777,11 @@ static int xfrm_get_ae(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
spin_lock_bh(&x->lock);
|
spin_lock_bh(&x->lock);
|
||||||
c.data.aevent = p->flags;
|
c.data.aevent = p->flags;
|
||||||
c.seq = nlh->nlmsg_seq;
|
c.seq = nlh->nlmsg_seq;
|
||||||
c.pid = nlh->nlmsg_pid;
|
c.portid = nlh->nlmsg_pid;
|
||||||
|
|
||||||
if (build_aevent(r_skb, x, &c) < 0)
|
if (build_aevent(r_skb, x, &c) < 0)
|
||||||
BUG();
|
BUG();
|
||||||
err = nlmsg_unicast(net->xfrm.nlsk, r_skb, NETLINK_CB(skb).pid);
|
err = nlmsg_unicast(net->xfrm.nlsk, r_skb, NETLINK_CB(skb).portid);
|
||||||
spin_unlock_bh(&x->lock);
|
spin_unlock_bh(&x->lock);
|
||||||
xfrm_state_put(x);
|
xfrm_state_put(x);
|
||||||
return err;
|
return err;
|
||||||
@ -1827,7 +1827,7 @@ static int xfrm_new_ae(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
|
|
||||||
c.event = nlh->nlmsg_type;
|
c.event = nlh->nlmsg_type;
|
||||||
c.seq = nlh->nlmsg_seq;
|
c.seq = nlh->nlmsg_seq;
|
||||||
c.pid = nlh->nlmsg_pid;
|
c.portid = nlh->nlmsg_pid;
|
||||||
c.data.aevent = XFRM_AE_CU;
|
c.data.aevent = XFRM_AE_CU;
|
||||||
km_state_notify(x, &c);
|
km_state_notify(x, &c);
|
||||||
err = 0;
|
err = 0;
|
||||||
@ -1862,7 +1862,7 @@ static int xfrm_flush_policy(struct sk_buff *skb, struct nlmsghdr *nlh,
|
|||||||
c.data.type = type;
|
c.data.type = type;
|
||||||
c.event = nlh->nlmsg_type;
|
c.event = nlh->nlmsg_type;
|
||||||
c.seq = nlh->nlmsg_seq;
|
c.seq = nlh->nlmsg_seq;
|
||||||
c.pid = nlh->nlmsg_pid;
|
c.portid = nlh->nlmsg_pid;
|
||||||
c.net = net;
|
c.net = net;
|
||||||
km_policy_notify(NULL, 0, &c);
|
km_policy_notify(NULL, 0, &c);
|
||||||
return 0;
|
return 0;
|
||||||
@ -2370,7 +2370,7 @@ static int build_expire(struct sk_buff *skb, struct xfrm_state *x, const struct
|
|||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, c->pid, 0, XFRM_MSG_EXPIRE, sizeof(*ue), 0);
|
nlh = nlmsg_put(skb, c->portid, 0, XFRM_MSG_EXPIRE, sizeof(*ue), 0);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -2429,7 +2429,7 @@ static int xfrm_notify_sa_flush(const struct km_event *c)
|
|||||||
if (skb == NULL)
|
if (skb == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, c->pid, c->seq, XFRM_MSG_FLUSHSA, sizeof(*p), 0);
|
nlh = nlmsg_put(skb, c->portid, c->seq, XFRM_MSG_FLUSHSA, sizeof(*p), 0);
|
||||||
if (nlh == NULL) {
|
if (nlh == NULL) {
|
||||||
kfree_skb(skb);
|
kfree_skb(skb);
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
@ -2497,7 +2497,7 @@ static int xfrm_notify_sa(struct xfrm_state *x, const struct km_event *c)
|
|||||||
if (skb == NULL)
|
if (skb == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, c->pid, c->seq, c->event, headlen, 0);
|
nlh = nlmsg_put(skb, c->portid, c->seq, c->event, headlen, 0);
|
||||||
err = -EMSGSIZE;
|
err = -EMSGSIZE;
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
goto out_free_skb;
|
goto out_free_skb;
|
||||||
@ -2696,7 +2696,7 @@ static int build_polexpire(struct sk_buff *skb, struct xfrm_policy *xp,
|
|||||||
struct nlmsghdr *nlh;
|
struct nlmsghdr *nlh;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, c->pid, 0, XFRM_MSG_POLEXPIRE, sizeof(*upe), 0);
|
nlh = nlmsg_put(skb, c->portid, 0, XFRM_MSG_POLEXPIRE, sizeof(*upe), 0);
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
return -EMSGSIZE;
|
return -EMSGSIZE;
|
||||||
|
|
||||||
@ -2756,7 +2756,7 @@ static int xfrm_notify_policy(struct xfrm_policy *xp, int dir, const struct km_e
|
|||||||
if (skb == NULL)
|
if (skb == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, c->pid, c->seq, c->event, headlen, 0);
|
nlh = nlmsg_put(skb, c->portid, c->seq, c->event, headlen, 0);
|
||||||
err = -EMSGSIZE;
|
err = -EMSGSIZE;
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
goto out_free_skb;
|
goto out_free_skb;
|
||||||
@ -2810,7 +2810,7 @@ static int xfrm_notify_policy_flush(const struct km_event *c)
|
|||||||
if (skb == NULL)
|
if (skb == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
nlh = nlmsg_put(skb, c->pid, c->seq, XFRM_MSG_FLUSHPOLICY, 0, 0);
|
nlh = nlmsg_put(skb, c->portid, c->seq, XFRM_MSG_FLUSHPOLICY, 0, 0);
|
||||||
err = -EMSGSIZE;
|
err = -EMSGSIZE;
|
||||||
if (nlh == NULL)
|
if (nlh == NULL)
|
||||||
goto out_free_skb;
|
goto out_free_skb;
|
||||||
|
Loading…
Reference in New Issue
Block a user