quotaops.h 11.6 KB
Newer Older
L
Linus Torvalds 已提交
1 2 3 4 5 6 7 8 9 10 11
/*
 * Definitions for diskquota-operations. When diskquota is configured these
 * macros expand to the right source-code.
 *
 * Author:  Marco van Wieringen <mvw@planets.elm.net>
 */
#ifndef _LINUX_QUOTAOPS_
#define _LINUX_QUOTAOPS_

#include <linux/fs.h>

12 13 14 15
static inline struct quota_info *sb_dqopt(struct super_block *sb)
{
	return &sb->s_dquot;
}
16

L
Linus Torvalds 已提交
17 18 19 20 21
#if defined(CONFIG_QUOTA)

/*
 * declaration of quota_function calls in kernel.
 */
22
void sync_quota_sb(struct super_block *sb, int type);
23 24 25 26 27
static inline void writeout_quota_sb(struct super_block *sb, int type)
{
	if (sb->s_qcop->quota_sync)
		sb->s_qcop->quota_sync(sb, type);
}
28 29 30

int dquot_initialize(struct inode *inode, int type);
int dquot_drop(struct inode *inode);
31 32
struct dquot *dqget(struct super_block *sb, unsigned int id, int type);
void dqput(struct dquot *dquot);
33 34 35
int dquot_scan_active(struct super_block *sb,
		      int (*fn)(struct dquot *dquot, unsigned long priv),
		      unsigned long priv);
36 37
struct dquot *dquot_alloc(struct super_block *sb, int type);
void dquot_destroy(struct dquot *dquot);
38 39

int dquot_alloc_space(struct inode *inode, qsize_t number, int prealloc);
40
int dquot_alloc_inode(const struct inode *inode, qsize_t number);
41

42 43 44 45 46
int dquot_reserve_space(struct inode *inode, qsize_t number, int prealloc);
int dquot_claim_space(struct inode *inode, qsize_t number);
void dquot_release_reserved_space(struct inode *inode, qsize_t number);
qsize_t dquot_get_reserved_space(struct inode *inode);

47
int dquot_free_space(struct inode *inode, qsize_t number);
48
int dquot_free_inode(const struct inode *inode, qsize_t number);
49 50 51 52 53 54 55 56 57 58

int dquot_transfer(struct inode *inode, struct iattr *iattr);
int dquot_commit(struct dquot *dquot);
int dquot_acquire(struct dquot *dquot);
int dquot_release(struct dquot *dquot);
int dquot_commit_info(struct super_block *sb, int type);
int dquot_mark_dquot_dirty(struct dquot *dquot);

int vfs_quota_on(struct super_block *sb, int type, int format_id,
 	char *path, int remount);
59 60
int vfs_quota_enable(struct inode *inode, int type, int format_id,
	unsigned int flags);
61 62
int vfs_quota_on_path(struct super_block *sb, int type, int format_id,
 	struct path *path);
63 64 65
int vfs_quota_on_mount(struct super_block *sb, char *qf_name,
 	int format_id, int type);
int vfs_quota_off(struct super_block *sb, int type, int remount);
66
int vfs_quota_disable(struct super_block *sb, int type, unsigned int flags);
67 68 69 70 71 72 73 74 75
int vfs_quota_sync(struct super_block *sb, int type);
int vfs_get_dqinfo(struct super_block *sb, int type, struct if_dqinfo *ii);
int vfs_set_dqinfo(struct super_block *sb, int type, struct if_dqinfo *ii);
int vfs_get_dqblk(struct super_block *sb, int type, qid_t id, struct if_dqblk *di);
int vfs_set_dqblk(struct super_block *sb, int type, qid_t id, struct if_dqblk *di);

void vfs_dq_drop(struct inode *inode);
int vfs_dq_transfer(struct inode *inode, struct iattr *iattr);
int vfs_dq_quota_on_remount(struct super_block *sb);
L
Linus Torvalds 已提交
76

77 78 79 80
static inline struct mem_dqinfo *sb_dqinfo(struct super_block *sb, int type)
{
	return sb_dqopt(sb)->info + type;
}
81 82 83 84 85

/*
 * Functions for checking status of quota
 */

86
static inline int sb_has_quota_usage_enabled(struct super_block *sb, int type)
87
{
88 89
	return sb_dqopt(sb)->flags &
				dquot_state_flag(DQUOT_USAGE_ENABLED, type);
90
}
91

92
static inline int sb_has_quota_limits_enabled(struct super_block *sb, int type)
93
{
94 95
	return sb_dqopt(sb)->flags &
				dquot_state_flag(DQUOT_LIMITS_ENABLED, type);
96
}
97

98 99
static inline int sb_has_quota_suspended(struct super_block *sb, int type)
{
100 101
	return sb_dqopt(sb)->flags &
				dquot_state_flag(DQUOT_SUSPENDED, type);
102
}
103

104 105 106 107 108
static inline int sb_any_quota_suspended(struct super_block *sb)
{
	return sb_has_quota_suspended(sb, USRQUOTA) ||
		sb_has_quota_suspended(sb, GRPQUOTA);
}
109

110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134
/* Does kernel know about any quota information for given sb + type? */
static inline int sb_has_quota_loaded(struct super_block *sb, int type)
{
	/* Currently if anything is on, then quota usage is on as well */
	return sb_has_quota_usage_enabled(sb, type);
}

static inline int sb_any_quota_loaded(struct super_block *sb)
{
	return sb_has_quota_loaded(sb, USRQUOTA) ||
		sb_has_quota_loaded(sb, GRPQUOTA);
}

static inline int sb_has_quota_active(struct super_block *sb, int type)
{
	return sb_has_quota_loaded(sb, type) &&
	       !sb_has_quota_suspended(sb, type);
}

static inline int sb_any_quota_active(struct super_block *sb)
{
	return sb_has_quota_active(sb, USRQUOTA) ||
	       sb_has_quota_active(sb, GRPQUOTA);
}

L
Linus Torvalds 已提交
135 136 137
/*
 * Operations supported for diskquotas.
 */
138
extern const struct dquot_operations dquot_operations;
L
Linus Torvalds 已提交
139 140 141 142 143 144 145
extern struct quotactl_ops vfs_quotactl_ops;

#define sb_dquot_ops (&dquot_operations)
#define sb_quotactl_ops (&vfs_quotactl_ops)

/* It is better to call this function outside of any transaction as it might
 * need a lot of space in journal for dquot structure allocation. */
146
static inline void vfs_dq_init(struct inode *inode)
L
Linus Torvalds 已提交
147 148
{
	BUG_ON(!inode->i_sb);
149
	if (sb_any_quota_active(inode->i_sb) && !IS_NOQUOTA(inode))
L
Linus Torvalds 已提交
150 151 152 153 154
		inode->i_sb->dq_op->initialize(inode, -1);
}

/* The following allocation/freeing/transfer functions *must* be called inside
 * a transaction (deadlocks possible otherwise) */
155
static inline int vfs_dq_prealloc_space_nodirty(struct inode *inode, qsize_t nr)
L
Linus Torvalds 已提交
156
{
157
	if (sb_any_quota_active(inode->i_sb)) {
L
Linus Torvalds 已提交
158 159 160 161 162 163 164 165 166
		/* Used space is updated in alloc_space() */
		if (inode->i_sb->dq_op->alloc_space(inode, nr, 1) == NO_QUOTA)
			return 1;
	}
	else
		inode_add_bytes(inode, nr);
	return 0;
}

167
static inline int vfs_dq_prealloc_space(struct inode *inode, qsize_t nr)
L
Linus Torvalds 已提交
168 169
{
	int ret;
170
        if (!(ret =  vfs_dq_prealloc_space_nodirty(inode, nr)))
L
Linus Torvalds 已提交
171 172 173 174
		mark_inode_dirty(inode);
	return ret;
}

175
static inline int vfs_dq_alloc_space_nodirty(struct inode *inode, qsize_t nr)
L
Linus Torvalds 已提交
176
{
177
	if (sb_any_quota_active(inode->i_sb)) {
L
Linus Torvalds 已提交
178 179 180 181 182 183 184 185 186
		/* Used space is updated in alloc_space() */
		if (inode->i_sb->dq_op->alloc_space(inode, nr, 0) == NO_QUOTA)
			return 1;
	}
	else
		inode_add_bytes(inode, nr);
	return 0;
}

187
static inline int vfs_dq_alloc_space(struct inode *inode, qsize_t nr)
L
Linus Torvalds 已提交
188 189
{
	int ret;
190
	if (!(ret = vfs_dq_alloc_space_nodirty(inode, nr)))
L
Linus Torvalds 已提交
191 192 193 194
		mark_inode_dirty(inode);
	return ret;
}

195 196 197 198 199 200 201 202 203 204
static inline int vfs_dq_reserve_space(struct inode *inode, qsize_t nr)
{
	if (sb_any_quota_active(inode->i_sb)) {
		/* Used space is updated in alloc_space() */
		if (inode->i_sb->dq_op->reserve_space(inode, nr, 0) == NO_QUOTA)
			return 1;
	}
	return 0;
}

205
static inline int vfs_dq_alloc_inode(struct inode *inode)
L
Linus Torvalds 已提交
206
{
207
	if (sb_any_quota_active(inode->i_sb)) {
208
		vfs_dq_init(inode);
L
Linus Torvalds 已提交
209 210 211 212 213 214
		if (inode->i_sb->dq_op->alloc_inode(inode, 1) == NO_QUOTA)
			return 1;
	}
	return 0;
}

215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239
/*
 * Convert in-memory reserved quotas to real consumed quotas
 */
static inline int vfs_dq_claim_space(struct inode *inode, qsize_t nr)
{
	if (sb_any_quota_active(inode->i_sb)) {
		if (inode->i_sb->dq_op->claim_space(inode, nr) == NO_QUOTA)
			return 1;
	} else
		inode_add_bytes(inode, nr);

	mark_inode_dirty(inode);
	return 0;
}

/*
 * Release reserved (in-memory) quotas
 */
static inline
void vfs_dq_release_reservation_space(struct inode *inode, qsize_t nr)
{
	if (sb_any_quota_active(inode->i_sb))
		inode->i_sb->dq_op->release_rsv(inode, nr);
}

240
static inline void vfs_dq_free_space_nodirty(struct inode *inode, qsize_t nr)
L
Linus Torvalds 已提交
241
{
242
	if (sb_any_quota_active(inode->i_sb))
L
Linus Torvalds 已提交
243 244 245 246 247
		inode->i_sb->dq_op->free_space(inode, nr);
	else
		inode_sub_bytes(inode, nr);
}

248
static inline void vfs_dq_free_space(struct inode *inode, qsize_t nr)
L
Linus Torvalds 已提交
249
{
250
	vfs_dq_free_space_nodirty(inode, nr);
L
Linus Torvalds 已提交
251 252 253
	mark_inode_dirty(inode);
}

254
static inline void vfs_dq_free_inode(struct inode *inode)
L
Linus Torvalds 已提交
255
{
256
	if (sb_any_quota_active(inode->i_sb))
L
Linus Torvalds 已提交
257 258 259
		inode->i_sb->dq_op->free_inode(inode, 1);
}

260
/* Cannot be called inside a transaction */
261
static inline int vfs_dq_off(struct super_block *sb, int remount)
L
Linus Torvalds 已提交
262 263 264
{
	int ret = -ENOSYS;

265 266 267 268 269
	if (sb->s_qcop && sb->s_qcop->quota_off)
		ret = sb->s_qcop->quota_off(sb, -1, remount);
	return ret;
}

L
Linus Torvalds 已提交
270 271
#else

272
static inline int sb_has_quota_usage_enabled(struct super_block *sb, int type)
273 274 275 276
{
	return 0;
}

277
static inline int sb_has_quota_limits_enabled(struct super_block *sb, int type)
278 279 280 281 282 283 284 285 286 287 288 289 290
{
	return 0;
}

static inline int sb_has_quota_suspended(struct super_block *sb, int type)
{
	return 0;
}

static inline int sb_any_quota_suspended(struct super_block *sb)
{
	return 0;
}
291

292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312
/* Does kernel know about any quota information for given sb + type? */
static inline int sb_has_quota_loaded(struct super_block *sb, int type)
{
	return 0;
}

static inline int sb_any_quota_loaded(struct super_block *sb)
{
	return 0;
}

static inline int sb_has_quota_active(struct super_block *sb, int type)
{
	return 0;
}

static inline int sb_any_quota_active(struct super_block *sb)
{
	return 0;
}

L
Linus Torvalds 已提交
313 314 315 316 317
/*
 * NO-OP when quota not configured.
 */
#define sb_dquot_ops				(NULL)
#define sb_quotactl_ops				(NULL)
318

319
static inline void vfs_dq_init(struct inode *inode)
320 321 322
{
}

323
static inline void vfs_dq_drop(struct inode *inode)
324 325 326
{
}

327
static inline int vfs_dq_alloc_inode(struct inode *inode)
328 329 330 331
{
	return 0;
}

332
static inline void vfs_dq_free_inode(struct inode *inode)
333 334 335
{
}

336
static inline void sync_quota_sb(struct super_block *sb, int type)
337 338 339
{
}

340 341 342 343
static inline void writeout_quota_sb(struct super_block *sb, int type)
{
}

344
static inline int vfs_dq_off(struct super_block *sb, int remount)
345 346 347 348
{
	return 0;
}

349
static inline int vfs_dq_quota_on_remount(struct super_block *sb)
350 351 352 353
{
	return 0;
}

354
static inline int vfs_dq_transfer(struct inode *inode, struct iattr *iattr)
355 356 357 358
{
	return 0;
}

359
static inline int vfs_dq_prealloc_space_nodirty(struct inode *inode, qsize_t nr)
L
Linus Torvalds 已提交
360 361 362 363 364
{
	inode_add_bytes(inode, nr);
	return 0;
}

365
static inline int vfs_dq_prealloc_space(struct inode *inode, qsize_t nr)
L
Linus Torvalds 已提交
366
{
367
	vfs_dq_prealloc_space_nodirty(inode, nr);
L
Linus Torvalds 已提交
368 369 370 371
	mark_inode_dirty(inode);
	return 0;
}

372
static inline int vfs_dq_alloc_space_nodirty(struct inode *inode, qsize_t nr)
L
Linus Torvalds 已提交
373 374 375 376 377
{
	inode_add_bytes(inode, nr);
	return 0;
}

378
static inline int vfs_dq_alloc_space(struct inode *inode, qsize_t nr)
L
Linus Torvalds 已提交
379
{
380
	vfs_dq_alloc_space_nodirty(inode, nr);
L
Linus Torvalds 已提交
381 382 383 384
	mark_inode_dirty(inode);
	return 0;
}

385 386 387 388 389
static inline int vfs_dq_reserve_space(struct inode *inode, qsize_t nr)
{
	return 0;
}

390 391 392 393 394 395 396 397 398 399 400
static inline int vfs_dq_claim_space(struct inode *inode, qsize_t nr)
{
	return vfs_dq_alloc_space(inode, nr);
}

static inline
int vfs_dq_release_reservation_space(struct inode *inode, qsize_t nr)
{
	return 0;
}

401
static inline void vfs_dq_free_space_nodirty(struct inode *inode, qsize_t nr)
L
Linus Torvalds 已提交
402 403 404 405
{
	inode_sub_bytes(inode, nr);
}

406
static inline void vfs_dq_free_space(struct inode *inode, qsize_t nr)
L
Linus Torvalds 已提交
407
{
408
	vfs_dq_free_space_nodirty(inode, nr);
L
Linus Torvalds 已提交
409 410 411 412 413
	mark_inode_dirty(inode);
}	

#endif /* CONFIG_QUOTA */

414
static inline int vfs_dq_prealloc_block_nodirty(struct inode *inode, qsize_t nr)
J
Jan Kara 已提交
415
{
416
	return vfs_dq_prealloc_space_nodirty(inode, nr << inode->i_blkbits);
J
Jan Kara 已提交
417 418
}

419
static inline int vfs_dq_prealloc_block(struct inode *inode, qsize_t nr)
J
Jan Kara 已提交
420
{
421
	return vfs_dq_prealloc_space(inode, nr << inode->i_blkbits);
J
Jan Kara 已提交
422 423
}

424
static inline int vfs_dq_alloc_block_nodirty(struct inode *inode, qsize_t nr)
J
Jan Kara 已提交
425
{
426
	return vfs_dq_alloc_space_nodirty(inode, nr << inode->i_blkbits);
J
Jan Kara 已提交
427 428
}

429
static inline int vfs_dq_alloc_block(struct inode *inode, qsize_t nr)
J
Jan Kara 已提交
430
{
431
	return vfs_dq_alloc_space(inode, nr << inode->i_blkbits);
J
Jan Kara 已提交
432 433
}

434 435
static inline int vfs_dq_reserve_block(struct inode *inode, qsize_t nr)
{
436
	return vfs_dq_reserve_space(inode, nr << inode->i_blkbits);
437 438
}

439 440
static inline int vfs_dq_claim_block(struct inode *inode, qsize_t nr)
{
441
	return vfs_dq_claim_space(inode, nr << inode->i_blkbits);
442 443 444 445 446 447 448 449
}

static inline
void vfs_dq_release_reservation_block(struct inode *inode, qsize_t nr)
{
	vfs_dq_release_reservation_space(inode, nr << inode->i_blkbits);
}

450
static inline void vfs_dq_free_block_nodirty(struct inode *inode, qsize_t nr)
J
Jan Kara 已提交
451
{
452
	vfs_dq_free_space_nodirty(inode, nr << inode->i_blkbits);
J
Jan Kara 已提交
453 454
}

455
static inline void vfs_dq_free_block(struct inode *inode, qsize_t nr)
J
Jan Kara 已提交
456
{
457
	vfs_dq_free_space(inode, nr << inode->i_blkbits);
J
Jan Kara 已提交
458
}
L
Linus Torvalds 已提交
459 460

#endif /* _LINUX_QUOTAOPS_ */