sysctl_net_core.c 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. /* -*- linux-c -*-
  2. * sysctl_net_core.c: sysctl interface to net core subsystem.
  3. *
  4. * Begun April 1, 1996, Mike Shaver.
  5. * Added /proc/sys/net/core directory entry (empty =) ). [MS]
  6. */
  7. #include <linux/mm.h>
  8. #include <linux/sysctl.h>
  9. #include <linux/config.h>
  10. #include <linux/module.h>
  11. #ifdef CONFIG_SYSCTL
  12. extern int netdev_max_backlog;
  13. extern int weight_p;
  14. extern int no_cong_thresh;
  15. extern int no_cong;
  16. extern int lo_cong;
  17. extern int mod_cong;
  18. extern int netdev_fastroute;
  19. extern int net_msg_cost;
  20. extern int net_msg_burst;
  21. extern __u32 sysctl_wmem_max;
  22. extern __u32 sysctl_rmem_max;
  23. extern __u32 sysctl_wmem_default;
  24. extern __u32 sysctl_rmem_default;
  25. extern int sysctl_core_destroy_delay;
  26. extern int sysctl_optmem_max;
  27. extern int sysctl_somaxconn;
  28. #ifdef CONFIG_NET_DIVERT
  29. extern char sysctl_divert_version[];
  30. #endif /* CONFIG_NET_DIVERT */
  31. /*
  32. * This strdup() is used for creating copies of network
  33. * device names to be handed over to sysctl.
  34. */
  35. char *net_sysctl_strdup(const char *s)
  36. {
  37. char *rv = kmalloc(strlen(s)+1, GFP_KERNEL);
  38. if (rv)
  39. strcpy(rv, s);
  40. return rv;
  41. }
  42. ctl_table core_table[] = {
  43. #ifdef CONFIG_NET
  44. {
  45. .ctl_name = NET_CORE_WMEM_MAX,
  46. .procname = "wmem_max",
  47. .data = &sysctl_wmem_max,
  48. .maxlen = sizeof(int),
  49. .mode = 0644,
  50. .proc_handler = &proc_dointvec
  51. },
  52. {
  53. .ctl_name = NET_CORE_RMEM_MAX,
  54. .procname = "rmem_max",
  55. .data = &sysctl_rmem_max,
  56. .maxlen = sizeof(int),
  57. .mode = 0644,
  58. .proc_handler = &proc_dointvec
  59. },
  60. {
  61. .ctl_name = NET_CORE_WMEM_DEFAULT,
  62. .procname = "wmem_default",
  63. .data = &sysctl_wmem_default,
  64. .maxlen = sizeof(int),
  65. .mode = 0644,
  66. .proc_handler = &proc_dointvec
  67. },
  68. {
  69. .ctl_name = NET_CORE_RMEM_DEFAULT,
  70. .procname = "rmem_default",
  71. .data = &sysctl_rmem_default,
  72. .maxlen = sizeof(int),
  73. .mode = 0644,
  74. .proc_handler = &proc_dointvec
  75. },
  76. {
  77. .ctl_name = NET_CORE_DEV_WEIGHT,
  78. .procname = "dev_weight",
  79. .data = &weight_p,
  80. .maxlen = sizeof(int),
  81. .mode = 0644,
  82. .proc_handler = &proc_dointvec
  83. },
  84. {
  85. .ctl_name = NET_CORE_MAX_BACKLOG,
  86. .procname = "netdev_max_backlog",
  87. .data = &netdev_max_backlog,
  88. .maxlen = sizeof(int),
  89. .mode = 0644,
  90. .proc_handler = &proc_dointvec
  91. },
  92. {
  93. .ctl_name = NET_CORE_NO_CONG_THRESH,
  94. .procname = "no_cong_thresh",
  95. .data = &no_cong_thresh,
  96. .maxlen = sizeof(int),
  97. .mode = 0644,
  98. .proc_handler = &proc_dointvec
  99. },
  100. {
  101. .ctl_name = NET_CORE_NO_CONG,
  102. .procname = "no_cong",
  103. .data = &no_cong,
  104. .maxlen = sizeof(int),
  105. .mode = 0644,
  106. .proc_handler = &proc_dointvec
  107. },
  108. {
  109. .ctl_name = NET_CORE_LO_CONG,
  110. .procname = "lo_cong",
  111. .data = &lo_cong,
  112. .maxlen = sizeof(int),
  113. .mode = 0644,
  114. .proc_handler = &proc_dointvec
  115. },
  116. {
  117. .ctl_name = NET_CORE_MOD_CONG,
  118. .procname = "mod_cong",
  119. .data = &mod_cong,
  120. .maxlen = sizeof(int),
  121. .mode = 0644,
  122. .proc_handler = &proc_dointvec
  123. },
  124. {
  125. .ctl_name = NET_CORE_MSG_COST,
  126. .procname = "message_cost",
  127. .data = &net_msg_cost,
  128. .maxlen = sizeof(int),
  129. .mode = 0644,
  130. .proc_handler = &proc_dointvec_jiffies,
  131. .strategy = &sysctl_jiffies,
  132. },
  133. {
  134. .ctl_name = NET_CORE_MSG_BURST,
  135. .procname = "message_burst",
  136. .data = &net_msg_burst,
  137. .maxlen = sizeof(int),
  138. .mode = 0644,
  139. .proc_handler = &proc_dointvec,
  140. },
  141. {
  142. .ctl_name = NET_CORE_OPTMEM_MAX,
  143. .procname = "optmem_max",
  144. .data = &sysctl_optmem_max,
  145. .maxlen = sizeof(int),
  146. .mode = 0644,
  147. .proc_handler = &proc_dointvec
  148. },
  149. #ifdef CONFIG_NET_DIVERT
  150. {
  151. .ctl_name = NET_CORE_DIVERT_VERSION,
  152. .procname = "divert_version",
  153. .data = (void *)sysctl_divert_version,
  154. .maxlen = 32,
  155. .mode = 0444,
  156. .proc_handler = &proc_dostring
  157. },
  158. #endif /* CONFIG_NET_DIVERT */
  159. #endif /* CONFIG_NET */
  160. {
  161. .ctl_name = NET_CORE_SOMAXCONN,
  162. .procname = "somaxconn",
  163. .data = &sysctl_somaxconn,
  164. .maxlen = sizeof(int),
  165. .mode = 0644,
  166. .proc_handler = &proc_dointvec
  167. },
  168. { .ctl_name = 0 }
  169. };
  170. EXPORT_SYMBOL(net_sysctl_strdup);
  171. #endif