dst_ops.h 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. #ifndef _NET_DST_OPS_H
  2. #define _NET_DST_OPS_H
  3. #include <linux/types.h>
  4. #include <linux/percpu_counter.h>
  5. #include <linux/cache.h>
  6. struct dst_entry;
  7. struct kmem_cachep;
  8. struct net_device;
  9. struct sk_buff;
  10. struct dst_ops {
  11. unsigned short family;
  12. __be16 protocol;
  13. unsigned gc_thresh;
  14. int (*gc)(struct dst_ops *ops);
  15. struct dst_entry * (*check)(struct dst_entry *, __u32 cookie);
  16. unsigned int (*default_advmss)(const struct dst_entry *);
  17. unsigned int (*default_mtu)(const struct dst_entry *);
  18. void (*destroy)(struct dst_entry *);
  19. void (*ifdown)(struct dst_entry *,
  20. struct net_device *dev, int how);
  21. struct dst_entry * (*negative_advice)(struct dst_entry *);
  22. void (*link_failure)(struct sk_buff *);
  23. void (*update_pmtu)(struct dst_entry *dst, u32 mtu);
  24. int (*local_out)(struct sk_buff *skb);
  25. struct kmem_cache *kmem_cachep;
  26. struct percpu_counter pcpuc_entries ____cacheline_aligned_in_smp;
  27. };
  28. static inline int dst_entries_get_fast(struct dst_ops *dst)
  29. {
  30. return percpu_counter_read_positive(&dst->pcpuc_entries);
  31. }
  32. static inline int dst_entries_get_slow(struct dst_ops *dst)
  33. {
  34. int res;
  35. local_bh_disable();
  36. res = percpu_counter_sum_positive(&dst->pcpuc_entries);
  37. local_bh_enable();
  38. return res;
  39. }
  40. static inline void dst_entries_add(struct dst_ops *dst, int val)
  41. {
  42. local_bh_disable();
  43. percpu_counter_add(&dst->pcpuc_entries, val);
  44. local_bh_enable();
  45. }
  46. static inline int dst_entries_init(struct dst_ops *dst)
  47. {
  48. return percpu_counter_init(&dst->pcpuc_entries, 0);
  49. }
  50. static inline void dst_entries_destroy(struct dst_ops *dst)
  51. {
  52. percpu_counter_destroy(&dst->pcpuc_entries);
  53. }
  54. #endif