ipv6.h 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * ipv6 in net namespaces
  4. */
  5. #include <net/inet_frag.h>
  6. #ifndef __NETNS_IPV6_H__
  7. #define __NETNS_IPV6_H__
  8. #include <net/dst_ops.h>
  9. struct ctl_table_header;
  10. struct netns_sysctl_ipv6 {
  11. #ifdef CONFIG_SYSCTL
  12. struct ctl_table_header *hdr;
  13. struct ctl_table_header *route_hdr;
  14. struct ctl_table_header *icmp_hdr;
  15. struct ctl_table_header *frags_hdr;
  16. struct ctl_table_header *xfrm6_hdr;
  17. #endif
  18. int bindv6only;
  19. int flush_delay;
  20. int ip6_rt_max_size;
  21. int ip6_rt_gc_min_interval;
  22. int ip6_rt_gc_timeout;
  23. int ip6_rt_gc_interval;
  24. int ip6_rt_gc_elasticity;
  25. int ip6_rt_mtu_expires;
  26. int ip6_rt_min_advmss;
  27. int flowlabel_consistency;
  28. int auto_flowlabels;
  29. int icmpv6_time;
  30. int anycast_src_echo_reply;
  31. int ip_nonlocal_bind;
  32. int fwmark_reflect;
  33. int idgen_retries;
  34. int idgen_delay;
  35. int flowlabel_state_ranges;
  36. int flowlabel_reflect;
  37. int max_dst_opts_cnt;
  38. int max_hbh_opts_cnt;
  39. int max_dst_opts_len;
  40. int max_hbh_opts_len;
  41. };
  42. struct netns_ipv6 {
  43. struct netns_sysctl_ipv6 sysctl;
  44. struct ipv6_devconf *devconf_all;
  45. struct ipv6_devconf *devconf_dflt;
  46. struct inet_peer_base *peers;
  47. struct netns_frags frags;
  48. #ifdef CONFIG_NETFILTER
  49. struct xt_table *ip6table_filter;
  50. struct xt_table *ip6table_mangle;
  51. struct xt_table *ip6table_raw;
  52. #ifdef CONFIG_SECURITY
  53. struct xt_table *ip6table_security;
  54. #endif
  55. struct xt_table *ip6table_nat;
  56. #endif
  57. struct rt6_info *ip6_null_entry;
  58. struct rt6_statistics *rt6_stats;
  59. struct timer_list ip6_fib_timer;
  60. struct hlist_head *fib_table_hash;
  61. struct fib6_table *fib6_main_tbl;
  62. struct list_head fib6_walkers;
  63. struct dst_ops ip6_dst_ops;
  64. rwlock_t fib6_walker_lock;
  65. spinlock_t fib6_gc_lock;
  66. unsigned int ip6_rt_gc_expire;
  67. unsigned long ip6_rt_last_gc;
  68. #ifdef CONFIG_IPV6_MULTIPLE_TABLES
  69. bool fib6_has_custom_rules;
  70. struct rt6_info *ip6_prohibit_entry;
  71. struct rt6_info *ip6_blk_hole_entry;
  72. struct fib6_table *fib6_local_tbl;
  73. struct fib_rules_ops *fib6_rules_ops;
  74. #endif
  75. struct sock **icmp_sk;
  76. struct sock *ndisc_sk;
  77. struct sock *tcp_sk;
  78. struct sock *igmp_sk;
  79. struct sock *mc_autojoin_sk;
  80. #ifdef CONFIG_IPV6_MROUTE
  81. #ifndef CONFIG_IPV6_MROUTE_MULTIPLE_TABLES
  82. struct mr6_table *mrt6;
  83. #else
  84. struct list_head mr6_tables;
  85. struct fib_rules_ops *mr6_rules_ops;
  86. #endif
  87. #endif
  88. atomic_t dev_addr_genid;
  89. atomic_t fib6_sernum;
  90. struct seg6_pernet_data *seg6_data;
  91. struct fib_notifier_ops *notifier_ops;
  92. struct {
  93. struct hlist_head head;
  94. spinlock_t lock;
  95. u32 seq;
  96. } ip6addrlbl_table;
  97. };
  98. #if IS_ENABLED(CONFIG_NF_DEFRAG_IPV6)
  99. struct netns_nf_frag {
  100. struct netns_sysctl_ipv6 sysctl;
  101. struct netns_frags frags;
  102. };
  103. #endif
  104. #endif