diff options
author | Nathan Scott <nathans@sgi.com> | 2005-11-02 21:53:34 -0500 |
---|---|---|
committer | Nathan Scott <nathans@sgi.com> | 2005-11-02 21:53:34 -0500 |
commit | de69e5f44ecbf1d9faca4f473f4210473d26cd41 (patch) | |
tree | 45d51d1c45afa3f08c8a46a7d591506d8ff50068 /fs/quota.c | |
parent | a2f8e178ad3e576d107f5d9d47c056dd57221857 (diff) |
[XFS] Add a mechanism for XFS to use the generic quota sync method.
This is now used to issue a delayed allocation flush before reporting
quota, which allows the used space quota report to match reality.
Signed-off-by: Nathan Scott <nathans@sgi.com>
Diffstat (limited to 'fs/quota.c')
-rw-r--r-- | fs/quota.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/fs/quota.c b/fs/quota.c index f5d1cff55196..1df7832b4e08 100644 --- a/fs/quota.c +++ b/fs/quota.c | |||
@@ -118,6 +118,10 @@ static int xqm_quotactl_valid(struct super_block *sb, int type, int cmd, qid_t i | |||
118 | if (!sb->s_qcop->get_xquota) | 118 | if (!sb->s_qcop->get_xquota) |
119 | return -ENOSYS; | 119 | return -ENOSYS; |
120 | break; | 120 | break; |
121 | case Q_XQUOTASYNC: | ||
122 | if (!sb->s_qcop->quota_sync) | ||
123 | return -ENOSYS; | ||
124 | break; | ||
121 | default: | 125 | default: |
122 | return -EINVAL; | 126 | return -EINVAL; |
123 | } | 127 | } |
@@ -128,7 +132,7 @@ static int xqm_quotactl_valid(struct super_block *sb, int type, int cmd, qid_t i | |||
128 | (type == XQM_GRPQUOTA && !in_egroup_p(id))) && | 132 | (type == XQM_GRPQUOTA && !in_egroup_p(id))) && |
129 | !capable(CAP_SYS_ADMIN)) | 133 | !capable(CAP_SYS_ADMIN)) |
130 | return -EPERM; | 134 | return -EPERM; |
131 | } else if (cmd != Q_XGETQSTAT) { | 135 | } else if (cmd != Q_XGETQSTAT && cmd != Q_XQUOTASYNC) { |
132 | if (!capable(CAP_SYS_ADMIN)) | 136 | if (!capable(CAP_SYS_ADMIN)) |
133 | return -EPERM; | 137 | return -EPERM; |
134 | } | 138 | } |
@@ -322,6 +326,8 @@ static int do_quotactl(struct super_block *sb, int type, int cmd, qid_t id, void | |||
322 | return -EFAULT; | 326 | return -EFAULT; |
323 | return 0; | 327 | return 0; |
324 | } | 328 | } |
329 | case Q_XQUOTASYNC: | ||
330 | return sb->s_qcop->quota_sync(sb, type); | ||
325 | /* We never reach here unless validity check is broken */ | 331 | /* We never reach here unless validity check is broken */ |
326 | default: | 332 | default: |
327 | BUG(); | 333 | BUG(); |