xfs_sysctl.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. /*
  2. * Copyright (c) 2001-2005 Silicon Graphics, Inc.
  3. * All Rights Reserved.
  4. *
  5. * This program is free software; you can redistribute it and/or
  6. * modify it under the terms of the GNU General Public License as
  7. * published by the Free Software Foundation.
  8. *
  9. * This program is distributed in the hope that it would be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program; if not, write the Free Software Foundation,
  16. * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  17. */
  18. #ifndef __XFS_SYSCTL_H__
  19. #define __XFS_SYSCTL_H__
  20. #include <linux/sysctl.h>
  21. /*
  22. * Tunable xfs parameters
  23. */
  24. typedef struct xfs_sysctl_val {
  25. int min;
  26. int val;
  27. int max;
  28. } xfs_sysctl_val_t;
  29. typedef struct xfs_param {
  30. xfs_sysctl_val_t sgid_inherit; /* Inherit S_ISGID if process' GID is
  31. * not a member of parent dir GID. */
  32. xfs_sysctl_val_t symlink_mode; /* Link creat mode affected by umask */
  33. xfs_sysctl_val_t panic_mask; /* bitmask to cause panic on errors. */
  34. xfs_sysctl_val_t error_level; /* Degree of reporting for problems */
  35. xfs_sysctl_val_t syncd_timer; /* Interval between xfssyncd wakeups */
  36. xfs_sysctl_val_t stats_clear; /* Reset all XFS statistics to zero. */
  37. xfs_sysctl_val_t inherit_sync; /* Inherit the "sync" inode flag. */
  38. xfs_sysctl_val_t inherit_nodump;/* Inherit the "nodump" inode flag. */
  39. xfs_sysctl_val_t inherit_noatim;/* Inherit the "noatime" inode flag. */
  40. xfs_sysctl_val_t xfs_buf_timer; /* Interval between xfsbufd wakeups. */
  41. xfs_sysctl_val_t xfs_buf_age; /* Metadata buffer age before flush. */
  42. xfs_sysctl_val_t inherit_nosym; /* Inherit the "nosymlinks" flag. */
  43. xfs_sysctl_val_t rotorstep; /* inode32 AG rotoring control knob */
  44. xfs_sysctl_val_t inherit_nodfrg;/* Inherit the "nodefrag" inode flag. */
  45. xfs_sysctl_val_t fstrm_timer; /* Filestream dir-AG assoc'n timeout. */
  46. xfs_sysctl_val_t eofb_timer; /* Interval between eofb scan wakeups */
  47. } xfs_param_t;
  48. /*
  49. * xfs_error_level:
  50. *
  51. * How much error reporting will be done when internal problems are
  52. * encountered. These problems normally return an EFSCORRUPTED to their
  53. * caller, with no other information reported.
  54. *
  55. * 0 No error reports
  56. * 1 Report EFSCORRUPTED errors that will cause a filesystem shutdown
  57. * 5 Report all EFSCORRUPTED errors (all of the above errors, plus any
  58. * additional errors that are known to not cause shutdowns)
  59. *
  60. * xfs_panic_mask bit 0x8 turns the error reports into panics
  61. */
  62. enum {
  63. /* XFS_REFCACHE_SIZE = 1 */
  64. /* XFS_REFCACHE_PURGE = 2 */
  65. /* XFS_RESTRICT_CHOWN = 3 */
  66. XFS_SGID_INHERIT = 4,
  67. XFS_SYMLINK_MODE = 5,
  68. XFS_PANIC_MASK = 6,
  69. XFS_ERRLEVEL = 7,
  70. XFS_SYNCD_TIMER = 8,
  71. /* XFS_PROBE_DMAPI = 9 */
  72. /* XFS_PROBE_IOOPS = 10 */
  73. /* XFS_PROBE_QUOTA = 11 */
  74. XFS_STATS_CLEAR = 12,
  75. XFS_INHERIT_SYNC = 13,
  76. XFS_INHERIT_NODUMP = 14,
  77. XFS_INHERIT_NOATIME = 15,
  78. XFS_BUF_TIMER = 16,
  79. XFS_BUF_AGE = 17,
  80. /* XFS_IO_BYPASS = 18 */
  81. XFS_INHERIT_NOSYM = 19,
  82. XFS_ROTORSTEP = 20,
  83. XFS_INHERIT_NODFRG = 21,
  84. XFS_FILESTREAM_TIMER = 22,
  85. };
  86. extern xfs_param_t xfs_params;
  87. struct xfs_globals {
  88. int log_recovery_delay; /* log recovery delay (secs) */
  89. };
  90. extern struct xfs_globals xfs_globals;
  91. #ifdef CONFIG_SYSCTL
  92. extern int xfs_sysctl_register(void);
  93. extern void xfs_sysctl_unregister(void);
  94. #else
  95. # define xfs_sysctl_register() (0)
  96. # define xfs_sysctl_unregister() do { } while (0)
  97. #endif /* CONFIG_SYSCTL */
  98. #endif /* __XFS_SYSCTL_H__ */