quota.h 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. /* This just represents the non-kernel parts of <linux/quota.h>.
  2. *
  3. * here's the corresponding copyright:
  4. * Copyright (c) 1982, 1986 Regents of the University of California.
  5. * All rights reserved.
  6. *
  7. * This code is derived from software contributed to Berkeley by
  8. * Robert Elz at The University of Melbourne.
  9. *
  10. * Redistribution and use in source and binary forms, with or without
  11. * modification, are permitted provided that the following conditions
  12. * are met:
  13. * 1. Redistributions of source code must retain the above copyright
  14. * notice, this list of conditions and the following disclaimer.
  15. * 2. Redistributions in binary form must reproduce the above copyright
  16. * notice, this list of conditions and the following disclaimer in the
  17. * documentation and/or other materials provided with the distribution.
  18. * 4. Neither the name of the University nor the names of its contributors
  19. * may be used to endorse or promote products derived from this software
  20. * without specific prior written permission.
  21. *
  22. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  23. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  24. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  25. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  26. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  27. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  28. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  29. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  30. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  31. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  32. * SUCH DAMAGE.
  33. *
  34. * Version: $Id: quota.h,v 1.1 2002/01/03 04:00:09 andersen Exp $
  35. */
  36. #ifndef _SYS_QUOTA_H
  37. #define _SYS_QUOTA_H 1
  38. #include <features.h>
  39. #include <sys/types.h>
  40. /*
  41. * Convert diskblocks to blocks and the other way around.
  42. * currently only to fool the BSD source. :-)
  43. */
  44. #define dbtob(num) ((num) << 10)
  45. #define btodb(num) ((num) >> 10)
  46. /*
  47. * Convert count of filesystem blocks to diskquota blocks, meant
  48. * for filesystems where i_blksize != BLOCK_SIZE
  49. */
  50. #define fs_to_dq_blocks(num, blksize) (((num) * (blksize)) / BLOCK_SIZE)
  51. /*
  52. * Definitions for disk quotas imposed on the average user
  53. * (big brother finally hits Linux).
  54. *
  55. * The following constants define the amount of time given a user
  56. * before the soft limits are treated as hard limits (usually resulting
  57. * in an allocation failure). The timer is started when the user crosses
  58. * their soft limit, it is reset when they go below their soft limit.
  59. */
  60. #define MAX_IQ_TIME 604800 /* (7*24*60*60) 1 week */
  61. #define MAX_DQ_TIME 604800 /* (7*24*60*60) 1 week */
  62. #define MAXQUOTAS 2
  63. #define USRQUOTA 0 /* element used for user quotas */
  64. #define GRPQUOTA 1 /* element used for group quotas */
  65. /*
  66. * Definitions for the default names of the quotas files.
  67. */
  68. #define INITQFNAMES { \
  69. "user", /* USRQUOTA */ \
  70. "group", /* GRPQUOTA */ \
  71. "undefined", \
  72. };
  73. #define QUOTAFILENAME "quota"
  74. #define QUOTAGROUP "staff"
  75. #define NR_DQHASH 43 /* Just an arbitrary number any suggestions ? */
  76. #define NR_DQUOTS 256 /* Number of quotas active at one time */
  77. /*
  78. * Command definitions for the 'quotactl' system call.
  79. * The commands are broken into a main command defined below
  80. * and a subcommand that is used to convey the type of
  81. * quota that is being manipulated (see above).
  82. */
  83. #define SUBCMDMASK 0x00ff
  84. #define SUBCMDSHIFT 8
  85. #define QCMD(cmd, type) (((cmd) << SUBCMDSHIFT) | ((type) & SUBCMDMASK))
  86. #define Q_QUOTAON 0x0100 /* enable quotas */
  87. #define Q_QUOTAOFF 0x0200 /* disable quotas */
  88. #define Q_GETQUOTA 0x0300 /* get limits and usage */
  89. #define Q_SETQUOTA 0x0400 /* set limits and usage */
  90. #define Q_SETUSE 0x0500 /* set usage */
  91. #define Q_SYNC 0x0600 /* sync disk copy of a filesystems quotas */
  92. #define Q_SETQLIM 0x0700 /* set limits */
  93. #define Q_GETSTATS 0x0800 /* get collected stats */
  94. #define Q_RSQUASH 0x1000 /* set root_squash option */
  95. /*
  96. * The following structure defines the format of the disk quota file
  97. * (as it appears on disk) - the file is an array of these structures
  98. * indexed by user or group number.
  99. */
  100. struct dqblk
  101. {
  102. u_int32_t dqb_bhardlimit; /* absolute limit on disk blks alloc */
  103. u_int32_t dqb_bsoftlimit; /* preferred limit on disk blks */
  104. u_int32_t dqb_curblocks; /* current block count */
  105. u_int32_t dqb_ihardlimit; /* maximum # allocated inodes */
  106. u_int32_t dqb_isoftlimit; /* preferred inode limit */
  107. u_int32_t dqb_curinodes; /* current # allocated inodes */
  108. time_t dqb_btime; /* time limit for excessive disk use */
  109. time_t dqb_itime; /* time limit for excessive files */
  110. };
  111. /*
  112. * Shorthand notation.
  113. */
  114. #define dq_bhardlimit dq_dqb.dqb_bhardlimit
  115. #define dq_bsoftlimit dq_dqb.dqb_bsoftlimit
  116. #define dq_curblocks dq_dqb.dqb_curblocks
  117. #define dq_ihardlimit dq_dqb.dqb_ihardlimit
  118. #define dq_isoftlimit dq_dqb.dqb_isoftlimit
  119. #define dq_curinodes dq_dqb.dqb_curinodes
  120. #define dq_btime dq_dqb.dqb_btime
  121. #define dq_itime dq_dqb.dqb_itime
  122. #define dqoff(UID) ((loff_t)((UID) * sizeof (struct dqblk)))
  123. struct dqstats
  124. {
  125. u_int32_t lookups;
  126. u_int32_t drops;
  127. u_int32_t reads;
  128. u_int32_t writes;
  129. u_int32_t cache_hits;
  130. u_int32_t pages_allocated;
  131. u_int32_t allocated_dquots;
  132. u_int32_t free_dquots;
  133. u_int32_t syncs;
  134. };
  135. __BEGIN_DECLS
  136. extern int quotactl (int __cmd, const char *__special, int __id,
  137. caddr_t __addr) __THROW;
  138. __END_DECLS
  139. #endif /* sys/quota.h */