return skb->dst_pending_confirm != 0;
 }
 
-static inline struct sec_path *skb_sec_path(struct sk_buff *skb)
+static inline struct sec_path *skb_sec_path(const struct sk_buff *skb)
 {
 #ifdef CONFIG_XFRM
        return skb->sp;
 
 #ifdef CONFIG_XFRM
 static inline struct xfrm_state *xfrm_input_state(struct sk_buff *skb)
 {
-       return skb->sp->xvec[skb->sp->len - 1];
+       struct sec_path *sp = skb_sec_path(skb);
+
+       return sp->xvec[sp->len - 1];
 }
 #endif
 
 static inline struct xfrm_offload *xfrm_offload(struct sk_buff *skb)
 {
 #ifdef CONFIG_XFRM
-       struct sec_path *sp = skb->sp;
+       struct sec_path *sp = skb_sec_path(skb);
 
        if (!sp || !sp->olen || sp->len != sp->olen)
                return NULL;
 
        void *tmp;
        struct xfrm_state *x;
 
-       if (xo && (xo->flags & XFRM_DEV_RESUME))
-               x = skb->sp->xvec[skb->sp->len - 1];
-       else
+       if (xo && (xo->flags & XFRM_DEV_RESUME)) {
+               struct sec_path *sp = skb_sec_path(skb);
+
+               x = sp->xvec[sp->len - 1];
+       } else {
                x = skb_dst(skb)->xfrm;
+       }
 
        tmp = ESP_SKB_CB(skb)->tmp;
        esp_ssg_unref(x, tmp);
 
        struct crypto_aead *aead;
        netdev_features_t esp_features = features;
        struct xfrm_offload *xo = xfrm_offload(skb);
+       struct sec_path *sp;
 
        if (!xo)
                return ERR_PTR(-EINVAL);
        if (!(skb_shinfo(skb)->gso_type & SKB_GSO_ESP))
                return ERR_PTR(-EINVAL);
 
-       x = skb->sp->xvec[skb->sp->len - 1];
+       sp = skb_sec_path(skb);
+       x = sp->xvec[sp->len - 1];
        aead = x->data;
        esph = ip_esp_hdr(skb);
 
 
        void *tmp;
        struct xfrm_state *x;
 
-       if (xo && (xo->flags & XFRM_DEV_RESUME))
-               x = skb->sp->xvec[skb->sp->len - 1];
-       else
+       if (xo && (xo->flags & XFRM_DEV_RESUME)) {
+               struct sec_path *sp = skb_sec_path(skb);
+
+               x = sp->xvec[sp->len - 1];
+       } else {
                x = skb_dst(skb)->xfrm;
+       }
 
        tmp = ESP_SKB_CB(skb)->tmp;
        esp_ssg_unref(x, tmp);
 
        struct crypto_aead *aead;
        netdev_features_t esp_features = features;
        struct xfrm_offload *xo = xfrm_offload(skb);
+       struct sec_path *sp;
 
        if (!xo)
                return ERR_PTR(-EINVAL);
        if (!(skb_shinfo(skb)->gso_type & SKB_GSO_ESP))
                return ERR_PTR(-EINVAL);
 
-       x = skb->sp->xvec[skb->sp->len - 1];
+       sp = skb_sec_path(skb);
+       x = sp->xvec[sp->len - 1];
        aead = x->data;
        esph = ip_esp_hdr(skb);
 
 
                goto drop;
        }
 
-       skb->sp->xvec[skb->sp->len++] = x;
+       sp->xvec[sp->len++] = x;
 
        spin_lock(&x->lock);
 
 
                                    struct nft_regs *regs,
                                    const struct nft_pktinfo *pkt)
 {
-       const struct sec_path *sp = pkt->skb->sp;
+       const struct sec_path *sp = skb_sec_path(pkt->skb);
        const struct xfrm_state *state;
 
        if (sp == NULL || sp->len <= priv->spnum) {
 
                unsigned short family)
 {
        const struct xt_policy_elem *e;
-       const struct sec_path *sp = skb->sp;
+       const struct sec_path *sp = skb_sec_path(skb);
        int strict = info->flags & XT_POLICY_MATCH_STRICT;
        int i, pos;
 
 
        struct softnet_data *sd;
        netdev_features_t esp_features = features;
        struct xfrm_offload *xo = xfrm_offload(skb);
+       struct sec_path *sp;
 
        if (!xo)
                return skb;
        if (!(features & NETIF_F_HW_ESP))
                esp_features = features & ~(NETIF_F_SG | NETIF_F_CSUM_MASK);
 
-       x = skb->sp->xvec[skb->sp->len - 1];
+       sp = skb_sec_path(skb);
+       x = sp->xvec[sp->len - 1];
        if (xo->flags & XFRM_GRO || x->xso.flags & XFRM_OFFLOAD_INBOUND)
                return skb;
 
 
        daddr = (xfrm_address_t *)(skb_network_header(skb) +
                                   XFRM_SPI_SKB_CB(skb)->daddroff);
        do {
-               if (skb->sp->len == XFRM_MAX_DEPTH) {
+               sp = skb_sec_path(skb);
+
+               if (sp->len == XFRM_MAX_DEPTH) {
                        secpath_reset(skb);
                        XFRM_INC_STATS(net, LINUX_MIB_XFRMINBUFFERERROR);
                        goto drop;
 
                skb->mark = xfrm_smark_get(skb->mark, x);
 
-               skb->sp->xvec[skb->sp->len++] = x;
+               sp->xvec[sp->len++] = x;
 
 lock:
                spin_lock(&x->lock);
        nf_reset(skb);
 
        if (decaps) {
-               if (skb->sp)
-                       skb->sp->olen = 0;
+               sp = skb_sec_path(skb);
+               if (sp)
+                       sp->olen = 0;
                skb_dst_drop(skb);
                gro_cells_receive(&gro_cells, skb);
                return 0;
 
                err = x->inner_mode->afinfo->transport_finish(skb, xfrm_gro || async);
                if (xfrm_gro) {
-                       if (skb->sp)
-                               skb->sp->olen = 0;
+                       sp = skb_sec_path(skb);
+                       if (sp)
+                               sp->olen = 0;
                        skb_dst_drop(skb);
                        gro_cells_receive(&gro_cells, skb);
                        return err;
 
 static inline int
 xfrm_secpath_reject(int idx, struct sk_buff *skb, const struct flowi *fl)
 {
+       struct sec_path *sp = skb_sec_path(skb);
        struct xfrm_state *x;
 
-       if (!skb->sp || idx < 0 || idx >= skb->sp->len)
+       if (!sp || idx < 0 || idx >= sp->len)
                return 0;
-       x = skb->sp->xvec[idx];
+       x = sp->xvec[idx];
        if (!x->type->reject)
                return 0;
        return x->type->reject(x, skb, fl);
        struct flowi fl;
        int xerr_idx = -1;
        const struct xfrm_if_cb *ifcb;
+       struct sec_path *sp;
        struct xfrm_if *xi;
        u32 if_id = 0;
 
        nf_nat_decode_session(skb, &fl, family);
 
        /* First, check used SA against their selectors. */
-       if (skb->sp) {
+       sp = skb_sec_path(skb);
+       if (sp) {
                int i;
 
-               for (i = skb->sp->len-1; i >= 0; i--) {
-                       struct xfrm_state *x = skb->sp->xvec[i];
+               for (i = sp->len - 1; i >= 0; i--) {
+                       struct xfrm_state *x = sp->xvec[i];
                        if (!xfrm_selector_match(&x->sel, &fl, family)) {
                                XFRM_INC_STATS(net, LINUX_MIB_XFRMINSTATEMISMATCH);
                                return 0;
        }
 
        if (!pol) {
-               if (skb->sp && secpath_has_nontransport(skb->sp, 0, &xerr_idx)) {
+               if (sp && secpath_has_nontransport(sp, 0, &xerr_idx)) {
                        xfrm_secpath_reject(xerr_idx, skb, &fl);
                        XFRM_INC_STATS(net, LINUX_MIB_XFRMINNOPOLS);
                        return 0;
 #endif
 
        if (pol->action == XFRM_POLICY_ALLOW) {
-               struct sec_path *sp;
                static struct sec_path dummy;
                struct xfrm_tmpl *tp[XFRM_MAX_DEPTH];
                struct xfrm_tmpl *stp[XFRM_MAX_DEPTH];
                int ti = 0;
                int i, k;
 
-               if ((sp = skb->sp) == NULL)
+               sp = skb_sec_path(skb);
+               if (!sp)
                        sp = &dummy;
 
                for (pi = 0; pi < npols; pi++) {
 
                                        u32 *sid, int ckall)
 {
        u32 sid_session = SECSID_NULL;
-       struct sec_path *sp = skb->sp;
+       struct sec_path *sp = skb_sec_path(skb);
 
        if (sp) {
                int i;
                              struct common_audit_data *ad)
 {
        int i;
-       struct sec_path *sp = skb->sp;
+       struct sec_path *sp = skb_sec_path(skb);
        u32 peer_sid = SECINITSID_UNLABELED;
 
        if (sp) {