dst_metadata.h 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. #ifndef __NET_DST_METADATA_H
  2. #define __NET_DST_METADATA_H 1
  3. #include <linux/skbuff.h>
  4. #include <net/ip_tunnels.h>
  5. #include <net/dst.h>
  6. struct metadata_dst {
  7. struct dst_entry dst;
  8. size_t opts_len;
  9. union {
  10. struct ip_tunnel_info tun_info;
  11. } u;
  12. };
  13. static inline struct metadata_dst *skb_metadata_dst(struct sk_buff *skb)
  14. {
  15. struct metadata_dst *md_dst = (struct metadata_dst *) skb_dst(skb);
  16. if (md_dst && md_dst->dst.flags & DST_METADATA)
  17. return md_dst;
  18. return NULL;
  19. }
  20. static inline struct ip_tunnel_info *skb_tunnel_info(struct sk_buff *skb,
  21. int family)
  22. {
  23. struct metadata_dst *md_dst = skb_metadata_dst(skb);
  24. struct rtable *rt;
  25. if (md_dst)
  26. return &md_dst->u.tun_info;
  27. switch (family) {
  28. case AF_INET:
  29. rt = (struct rtable *)skb_dst(skb);
  30. if (rt && rt->rt_lwtstate)
  31. return lwt_tun_info(rt->rt_lwtstate);
  32. break;
  33. }
  34. return NULL;
  35. }
  36. static inline bool skb_valid_dst(const struct sk_buff *skb)
  37. {
  38. struct dst_entry *dst = skb_dst(skb);
  39. return dst && !(dst->flags & DST_METADATA);
  40. }
  41. struct metadata_dst *metadata_dst_alloc(u8 optslen, gfp_t flags);
  42. #endif /* __NET_DST_METADATA_H */