dst_ops.h 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  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. void (*destroy)(struct dst_entry *);
  17. void (*ifdown)(struct dst_entry *,
  18. struct net_device *dev, int how);
  19. struct dst_entry * (*negative_advice)(struct dst_entry *);
  20. void (*link_failure)(struct sk_buff *);
  21. void (*update_pmtu)(struct dst_entry *dst, u32 mtu);
  22. int (*local_out)(struct sk_buff *skb);
  23. struct kmem_cache *kmem_cachep;
  24. struct percpu_counter pcpuc_entries ____cacheline_aligned_in_smp;
  25. };
  26. static inline int dst_entries_get_fast(struct dst_ops *dst)
  27. {
  28. return percpu_counter_read_positive(&dst->pcpuc_entries);
  29. }
  30. static inline int dst_entries_get_slow(struct dst_ops *dst)
  31. {
  32. int res;
  33. local_bh_disable();
  34. res = percpu_counter_sum_positive(&dst->pcpuc_entries);
  35. local_bh_enable();
  36. return res;
  37. }
  38. static inline void dst_entries_add(struct dst_ops *dst, int val)
  39. {
  40. local_bh_disable();
  41. percpu_counter_add(&dst->pcpuc_entries, val);
  42. local_bh_enable();
  43. }
  44. static inline int dst_entries_init(struct dst_ops *dst)
  45. {
  46. return percpu_counter_init(&dst->pcpuc_entries, 0);
  47. }
  48. static inline void dst_entries_destroy(struct dst_ops *dst)
  49. {
  50. percpu_counter_destroy(&dst->pcpuc_entries);
  51. }
  52. #endif