|
@@ -3722,8 +3722,12 @@ static int selinux_skb_peerlbl_sid(struct sk_buff *skb, u16 family, u32 *sid)
|
|
|
u32 nlbl_sid;
|
|
|
u32 nlbl_type;
|
|
|
|
|
|
- selinux_skb_xfrm_sid(skb, &xfrm_sid);
|
|
|
- selinux_netlbl_skbuff_getsid(skb, family, &nlbl_type, &nlbl_sid);
|
|
|
+ err = selinux_skb_xfrm_sid(skb, &xfrm_sid);
|
|
|
+ if (unlikely(err))
|
|
|
+ return -EACCES;
|
|
|
+ err = selinux_netlbl_skbuff_getsid(skb, family, &nlbl_type, &nlbl_sid);
|
|
|
+ if (unlikely(err))
|
|
|
+ return -EACCES;
|
|
|
|
|
|
err = security_net_peersid_resolve(nlbl_sid, nlbl_type, xfrm_sid, sid);
|
|
|
if (unlikely(err)) {
|