Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
f0071c7b
Commit
f0071c7b
authored
May 19, 2002
by
Jan Kara
Committed by
Linus Torvalds
May 19, 2002
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] [5/13] quota-5-space
This patch implements accounting of used space in bytes.
parent
f48acc23
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
77 additions
and
83 deletions
+77
-83
fs/dquot.c
fs/dquot.c
+25
-25
include/linux/fs.h
include/linux/fs.h
+2
-2
include/linux/quota.h
include/linux/quota.h
+11
-25
include/linux/quotaops.h
include/linux/quotaops.h
+39
-31
No files found.
fs/dquot.c
View file @
f0071c7b
...
@@ -703,9 +703,9 @@ static inline void dquot_incr_inodes(struct dquot *dquot, unsigned long number)
...
@@ -703,9 +703,9 @@ static inline void dquot_incr_inodes(struct dquot *dquot, unsigned long number)
mark_dquot_dirty
(
dquot
);
mark_dquot_dirty
(
dquot
);
}
}
static
inline
void
dquot_incr_
blocks
(
struct
dquot
*
dquot
,
unsigned
long
number
)
static
inline
void
dquot_incr_
space
(
struct
dquot
*
dquot
,
qsize_t
number
)
{
{
dquot
->
dq_cur
blocks
+=
number
;
dquot
->
dq_cur
space
+=
number
;
mark_dquot_dirty
(
dquot
);
mark_dquot_dirty
(
dquot
);
}
}
...
@@ -721,13 +721,13 @@ static inline void dquot_decr_inodes(struct dquot *dquot, unsigned long number)
...
@@ -721,13 +721,13 @@ static inline void dquot_decr_inodes(struct dquot *dquot, unsigned long number)
mark_dquot_dirty
(
dquot
);
mark_dquot_dirty
(
dquot
);
}
}
static
inline
void
dquot_decr_
blocks
(
struct
dquot
*
dquot
,
unsigned
long
number
)
static
inline
void
dquot_decr_
space
(
struct
dquot
*
dquot
,
qsize_t
number
)
{
{
if
(
dquot
->
dq_cur
blocks
>
number
)
if
(
dquot
->
dq_cur
space
>
number
)
dquot
->
dq_cur
blocks
-=
number
;
dquot
->
dq_cur
space
-=
number
;
else
else
dquot
->
dq_cur
blocks
=
0
;
dquot
->
dq_cur
space
=
0
;
if
(
dquot
->
dq_curblocks
<
dquot
->
dq_bsoftlimit
)
if
(
toqb
(
dquot
->
dq_curspace
)
<
dquot
->
dq_bsoftlimit
)
dquot
->
dq_btime
=
(
time_t
)
0
;
dquot
->
dq_btime
=
(
time_t
)
0
;
dquot
->
dq_flags
&=
~
DQ_BLKS
;
dquot
->
dq_flags
&=
~
DQ_BLKS
;
mark_dquot_dirty
(
dquot
);
mark_dquot_dirty
(
dquot
);
...
@@ -837,14 +837,14 @@ static int check_idq(struct dquot *dquot, ulong inodes, char *warntype)
...
@@ -837,14 +837,14 @@ static int check_idq(struct dquot *dquot, ulong inodes, char *warntype)
return
QUOTA_OK
;
return
QUOTA_OK
;
}
}
static
int
check_bdq
(
struct
dquot
*
dquot
,
ulong
blocks
,
char
prealloc
,
char
*
warntype
)
static
int
check_bdq
(
struct
dquot
*
dquot
,
qsize_t
space
,
int
prealloc
,
char
*
warntype
)
{
{
*
warntype
=
0
;
*
warntype
=
0
;
if
(
blocks
<=
0
||
dquot
->
dq_flags
&
DQ_FAKE
)
if
(
space
<=
0
||
dquot
->
dq_flags
&
DQ_FAKE
)
return
QUOTA_OK
;
return
QUOTA_OK
;
if
(
dquot
->
dq_bhardlimit
&&
if
(
dquot
->
dq_bhardlimit
&&
(
dquot
->
dq_curblocks
+
blocks
)
>
dquot
->
dq_bhardlimit
&&
toqb
(
dquot
->
dq_curspace
+
space
)
>
dquot
->
dq_bhardlimit
&&
!
ignore_hardlimit
(
dquot
))
{
!
ignore_hardlimit
(
dquot
))
{
if
(
!
prealloc
)
if
(
!
prealloc
)
*
warntype
=
BHARDWARN
;
*
warntype
=
BHARDWARN
;
...
@@ -852,7 +852,7 @@ static int check_bdq(struct dquot *dquot, ulong blocks, char prealloc, char *war
...
@@ -852,7 +852,7 @@ static int check_bdq(struct dquot *dquot, ulong blocks, char prealloc, char *war
}
}
if
(
dquot
->
dq_bsoftlimit
&&
if
(
dquot
->
dq_bsoftlimit
&&
(
dquot
->
dq_curblocks
+
blocks
)
>
dquot
->
dq_bsoftlimit
&&
toqb
(
dquot
->
dq_curspace
+
space
)
>
dquot
->
dq_bsoftlimit
&&
dquot
->
dq_btime
&&
CURRENT_TIME
>=
dquot
->
dq_btime
&&
dquot
->
dq_btime
&&
CURRENT_TIME
>=
dquot
->
dq_btime
&&
!
ignore_hardlimit
(
dquot
))
{
!
ignore_hardlimit
(
dquot
))
{
if
(
!
prealloc
)
if
(
!
prealloc
)
...
@@ -861,7 +861,7 @@ static int check_bdq(struct dquot *dquot, ulong blocks, char prealloc, char *war
...
@@ -861,7 +861,7 @@ static int check_bdq(struct dquot *dquot, ulong blocks, char prealloc, char *war
}
}
if
(
dquot
->
dq_bsoftlimit
&&
if
(
dquot
->
dq_bsoftlimit
&&
(
dquot
->
dq_curblocks
+
blocks
)
>
dquot
->
dq_bsoftlimit
&&
toqb
(
dquot
->
dq_curspace
+
space
)
>
dquot
->
dq_bsoftlimit
&&
dquot
->
dq_btime
==
0
)
{
dquot
->
dq_btime
==
0
)
{
if
(
!
prealloc
)
{
if
(
!
prealloc
)
{
*
warntype
=
BSOFTWARN
;
*
warntype
=
BSOFTWARN
;
...
@@ -948,7 +948,7 @@ void dquot_drop(struct inode *inode)
...
@@ -948,7 +948,7 @@ void dquot_drop(struct inode *inode)
/*
/*
* This operation can block, but only after everything is updated
* This operation can block, but only after everything is updated
*/
*/
int
dquot_alloc_
block
(
struct
inode
*
inode
,
unsigned
long
number
,
char
warn
)
int
dquot_alloc_
space
(
struct
inode
*
inode
,
qsize_t
number
,
int
warn
)
{
{
int
cnt
,
ret
=
NO_QUOTA
;
int
cnt
,
ret
=
NO_QUOTA
;
struct
dquot
*
dquot
[
MAXQUOTAS
];
struct
dquot
*
dquot
[
MAXQUOTAS
];
...
@@ -970,9 +970,9 @@ int dquot_alloc_block(struct inode *inode, unsigned long number, char warn)
...
@@ -970,9 +970,9 @@ int dquot_alloc_block(struct inode *inode, unsigned long number, char warn)
for
(
cnt
=
0
;
cnt
<
MAXQUOTAS
;
cnt
++
)
{
for
(
cnt
=
0
;
cnt
<
MAXQUOTAS
;
cnt
++
)
{
if
(
dquot
[
cnt
]
==
NODQUOT
)
if
(
dquot
[
cnt
]
==
NODQUOT
)
continue
;
continue
;
dquot_incr_
blocks
(
dquot
[
cnt
],
number
);
dquot_incr_
space
(
dquot
[
cnt
],
number
);
}
}
inode
->
i_blocks
+=
number
<<
(
BLOCK_SIZE_BITS
-
9
)
;
inode
->
i_blocks
+=
number
>>
9
;
/* NOBLOCK End */
/* NOBLOCK End */
ret
=
QUOTA_OK
;
ret
=
QUOTA_OK
;
warn_put_all:
warn_put_all:
...
@@ -1026,7 +1026,7 @@ int dquot_alloc_inode(const struct inode *inode, unsigned long number)
...
@@ -1026,7 +1026,7 @@ int dquot_alloc_inode(const struct inode *inode, unsigned long number)
/*
/*
* This is a non-blocking operation.
* This is a non-blocking operation.
*/
*/
void
dquot_free_
block
(
struct
inode
*
inode
,
unsigned
long
number
)
void
dquot_free_
space
(
struct
inode
*
inode
,
qsize_t
number
)
{
{
unsigned
short
cnt
;
unsigned
short
cnt
;
struct
dquot
*
dquot
;
struct
dquot
*
dquot
;
...
@@ -1037,10 +1037,10 @@ void dquot_free_block(struct inode *inode, unsigned long number)
...
@@ -1037,10 +1037,10 @@ void dquot_free_block(struct inode *inode, unsigned long number)
dquot
=
dqduplicate
(
inode
->
i_dquot
[
cnt
]);
dquot
=
dqduplicate
(
inode
->
i_dquot
[
cnt
]);
if
(
dquot
==
NODQUOT
)
if
(
dquot
==
NODQUOT
)
continue
;
continue
;
dquot_decr_
blocks
(
dquot
,
number
);
dquot_decr_
space
(
dquot
,
number
);
dqputduplicate
(
dquot
);
dqputduplicate
(
dquot
);
}
}
inode
->
i_blocks
-=
number
<<
(
BLOCK_SIZE_BITS
-
9
)
;
inode
->
i_blocks
-=
number
>>
9
;
unlock_kernel
();
unlock_kernel
();
/* NOBLOCK End */
/* NOBLOCK End */
}
}
...
@@ -1073,7 +1073,7 @@ void dquot_free_inode(const struct inode *inode, unsigned long number)
...
@@ -1073,7 +1073,7 @@ void dquot_free_inode(const struct inode *inode, unsigned long number)
*/
*/
int
dquot_transfer
(
struct
inode
*
inode
,
struct
iattr
*
iattr
)
int
dquot_transfer
(
struct
inode
*
inode
,
struct
iattr
*
iattr
)
{
{
unsigned
long
blocks
;
qsize_t
space
;
struct
dquot
*
transfer_from
[
MAXQUOTAS
];
struct
dquot
*
transfer_from
[
MAXQUOTAS
];
struct
dquot
*
transfer_to
[
MAXQUOTAS
];
struct
dquot
*
transfer_to
[
MAXQUOTAS
];
int
cnt
,
ret
=
NO_QUOTA
,
chuid
=
(
iattr
->
ia_valid
&
ATTR_UID
)
&&
inode
->
i_uid
!=
iattr
->
ia_uid
,
int
cnt
,
ret
=
NO_QUOTA
,
chuid
=
(
iattr
->
ia_valid
&
ATTR_UID
)
&&
inode
->
i_uid
!=
iattr
->
ia_uid
,
...
@@ -1103,7 +1103,7 @@ int dquot_transfer(struct inode *inode, struct iattr *iattr)
...
@@ -1103,7 +1103,7 @@ int dquot_transfer(struct inode *inode, struct iattr *iattr)
}
}
}
}
/* NOBLOCK START: From now on we shouldn't block */
/* NOBLOCK START: From now on we shouldn't block */
blocks
=
(
inode
->
i_blocks
>>
1
)
;
space
=
((
qsize_t
)
inode
->
i_blocks
)
<<
9
;
/* Build the transfer_from list and check the limits */
/* Build the transfer_from list and check the limits */
for
(
cnt
=
0
;
cnt
<
MAXQUOTAS
;
cnt
++
)
{
for
(
cnt
=
0
;
cnt
<
MAXQUOTAS
;
cnt
++
)
{
/* The second test can fail when quotaoff is in progress... */
/* The second test can fail when quotaoff is in progress... */
...
@@ -1113,7 +1113,7 @@ int dquot_transfer(struct inode *inode, struct iattr *iattr)
...
@@ -1113,7 +1113,7 @@ int dquot_transfer(struct inode *inode, struct iattr *iattr)
if
(
transfer_from
[
cnt
]
==
NODQUOT
)
/* Can happen on quotafiles (quota isn't initialized on them)... */
if
(
transfer_from
[
cnt
]
==
NODQUOT
)
/* Can happen on quotafiles (quota isn't initialized on them)... */
continue
;
continue
;
if
(
check_idq
(
transfer_to
[
cnt
],
1
,
warntype
+
cnt
)
==
NO_QUOTA
||
if
(
check_idq
(
transfer_to
[
cnt
],
1
,
warntype
+
cnt
)
==
NO_QUOTA
||
check_bdq
(
transfer_to
[
cnt
],
blocks
,
0
,
warntype
+
cnt
)
==
NO_QUOTA
)
check_bdq
(
transfer_to
[
cnt
],
space
,
0
,
warntype
+
cnt
)
==
NO_QUOTA
)
goto
warn_put_all
;
goto
warn_put_all
;
}
}
...
@@ -1128,10 +1128,10 @@ int dquot_transfer(struct inode *inode, struct iattr *iattr)
...
@@ -1128,10 +1128,10 @@ int dquot_transfer(struct inode *inode, struct iattr *iattr)
continue
;
continue
;
dquot_decr_inodes
(
transfer_from
[
cnt
],
1
);
dquot_decr_inodes
(
transfer_from
[
cnt
],
1
);
dquot_decr_
blocks
(
transfer_from
[
cnt
],
blocks
);
dquot_decr_
space
(
transfer_from
[
cnt
],
space
);
dquot_incr_inodes
(
transfer_to
[
cnt
],
1
);
dquot_incr_inodes
(
transfer_to
[
cnt
],
1
);
dquot_incr_
blocks
(
transfer_to
[
cnt
],
blocks
);
dquot_incr_
space
(
transfer_to
[
cnt
],
space
);
if
(
inode
->
i_dquot
[
cnt
]
==
NODQUOT
)
if
(
inode
->
i_dquot
[
cnt
]
==
NODQUOT
)
BUG
();
BUG
();
...
@@ -1162,9 +1162,9 @@ int dquot_transfer(struct inode *inode, struct iattr *iattr)
...
@@ -1162,9 +1162,9 @@ int dquot_transfer(struct inode *inode, struct iattr *iattr)
struct
dquot_operations
dquot_operations
=
{
struct
dquot_operations
dquot_operations
=
{
initialize:
dquot_initialize
,
/* mandatory */
initialize:
dquot_initialize
,
/* mandatory */
drop:
dquot_drop
,
/* mandatory */
drop:
dquot_drop
,
/* mandatory */
alloc_block:
dquot_alloc_
block
,
alloc_block:
dquot_alloc_
space
,
alloc_inode:
dquot_alloc_inode
,
alloc_inode:
dquot_alloc_inode
,
free_block:
dquot_free_
block
,
free_block:
dquot_free_
space
,
free_inode:
dquot_free_inode
,
free_inode:
dquot_free_inode
,
transfer:
dquot_transfer
transfer:
dquot_transfer
};
};
...
...
include/linux/fs.h
View file @
f0071c7b
...
@@ -847,9 +847,9 @@ static inline void mark_inode_dirty_sync(struct inode *inode)
...
@@ -847,9 +847,9 @@ static inline void mark_inode_dirty_sync(struct inode *inode)
struct
dquot_operations
{
struct
dquot_operations
{
void
(
*
initialize
)
(
struct
inode
*
,
short
);
void
(
*
initialize
)
(
struct
inode
*
,
short
);
void
(
*
drop
)
(
struct
inode
*
);
void
(
*
drop
)
(
struct
inode
*
);
int
(
*
alloc_
block
)
(
struct
inode
*
,
unsigned
long
,
char
);
int
(
*
alloc_
space
)
(
struct
inode
*
,
qsize_t
,
int
);
int
(
*
alloc_inode
)
(
const
struct
inode
*
,
unsigned
long
);
int
(
*
alloc_inode
)
(
const
struct
inode
*
,
unsigned
long
);
void
(
*
free_
block
)
(
struct
inode
*
,
unsigned
long
);
void
(
*
free_
space
)
(
struct
inode
*
,
qsize_t
);
void
(
*
free_inode
)
(
const
struct
inode
*
,
unsigned
long
);
void
(
*
free_inode
)
(
const
struct
inode
*
,
unsigned
long
);
int
(
*
transfer
)
(
struct
inode
*
,
struct
iattr
*
);
int
(
*
transfer
)
(
struct
inode
*
,
struct
iattr
*
);
};
};
...
...
include/linux/quota.h
View file @
f0071c7b
...
@@ -46,30 +46,16 @@
...
@@ -46,30 +46,16 @@
#define __DQUOT_NUM_VERSION__ 6*10000+5*100+1
#define __DQUOT_NUM_VERSION__ 6*10000+5*100+1
typedef
__kernel_uid32_t
qid_t
;
/* Type in which we store ids in memory */
typedef
__kernel_uid32_t
qid_t
;
/* Type in which we store ids in memory */
typedef
__u64
qsize_t
;
/* Type in which we store sizes */
/*
/* Size of blocks in which are counted size limits */
* Convert diskblocks to blocks and the other way around.
#define QUOTABLOCK_BITS 10
*/
#define QUOTABLOCK_SIZE (1 << QUOTABLOCK_BITS)
#define dbtob(num) (num << BLOCK_SIZE_BITS)
#define btodb(num) (num >> BLOCK_SIZE_BITS)
/*
* Convert count of filesystem blocks to diskquota blocks, meant
* for filesystems where i_blksize != BLOCK_SIZE
*/
#define fs_to_dq_blocks(num, blksize) (((num) * (blksize)) / BLOCK_SIZE)
/*
/* Conversion routines from and to quota blocks */
* Definitions for disk quotas imposed on the average user
#define qb2kb(x) ((x) << (QUOTABLOCK_BITS-10))
* (big brother finally hits Linux).
#define kb2qb(x) ((x) >> (QUOTABLOCK_BITS-10))
*
#define toqb(x) (((x) + QUOTABLOCK_SIZE - 1) >> QUOTABLOCK_BITS)
* The following constants define the amount of time given a user
* before the soft limits are treated as hard limits (usually resulting
* in an allocation failure). The timer is started when the user crosses
* their soft limit, it is reset when they go below their soft limit.
*/
#define MAX_IQ_TIME 604800
/* (7*24*60*60) 1 week */
#define MAX_DQ_TIME 604800
/* (7*24*60*60) 1 week */
#define MAXQUOTAS 2
#define MAXQUOTAS 2
#define USRQUOTA 0
/* element used for user quotas */
#define USRQUOTA 0
/* element used for user quotas */
...
@@ -105,7 +91,7 @@ typedef __kernel_uid32_t qid_t; /* Type in which we store ids in memory */
...
@@ -105,7 +91,7 @@ typedef __kernel_uid32_t qid_t; /* Type in which we store ids in memory */
struct
mem_dqblk
{
struct
mem_dqblk
{
__u32
dqb_bhardlimit
;
/* absolute limit on disk blks alloc */
__u32
dqb_bhardlimit
;
/* absolute limit on disk blks alloc */
__u32
dqb_bsoftlimit
;
/* preferred limit on disk blks */
__u32
dqb_bsoftlimit
;
/* preferred limit on disk blks */
__u32
dqb_curblocks
;
/* current block count
*/
qsize_t
dqb_curspace
;
/* current used space
*/
__u32
dqb_ihardlimit
;
/* absolute limit on allocated inodes */
__u32
dqb_ihardlimit
;
/* absolute limit on allocated inodes */
__u32
dqb_isoftlimit
;
/* preferred inode limit */
__u32
dqb_isoftlimit
;
/* preferred inode limit */
__u32
dqb_curinodes
;
/* current # allocated inodes */
__u32
dqb_curinodes
;
/* current # allocated inodes */
...
@@ -119,7 +105,7 @@ struct mem_dqblk {
...
@@ -119,7 +105,7 @@ struct mem_dqblk {
struct
quota_format_type
;
struct
quota_format_type
;
struct
mem_dqinfo
{
struct
mem_dqinfo
{
struct
quota_format_type
*
dqi_format
;
struct
quota_format_type
*
dqi_format
;
int
dqi_flags
;
int
dqi_flags
;
unsigned
int
dqi_bgrace
;
unsigned
int
dqi_bgrace
;
unsigned
int
dqi_igrace
;
unsigned
int
dqi_igrace
;
...
@@ -148,7 +134,7 @@ extern inline void mark_info_dirty(struct mem_dqinfo *info)
...
@@ -148,7 +134,7 @@ extern inline void mark_info_dirty(struct mem_dqinfo *info)
*/
*/
#define dq_bhardlimit dq_dqb.dqb_bhardlimit
#define dq_bhardlimit dq_dqb.dqb_bhardlimit
#define dq_bsoftlimit dq_dqb.dqb_bsoftlimit
#define dq_bsoftlimit dq_dqb.dqb_bsoftlimit
#define dq_cur
blocks dq_dqb.dqb_curblocks
#define dq_cur
space dq_dqb.dqb_curspace
#define dq_ihardlimit dq_dqb.dqb_ihardlimit
#define dq_ihardlimit dq_dqb.dqb_ihardlimit
#define dq_isoftlimit dq_dqb.dqb_isoftlimit
#define dq_isoftlimit dq_dqb.dqb_isoftlimit
#define dq_curinodes dq_dqb.dqb_curinodes
#define dq_curinodes dq_dqb.dqb_curinodes
...
...
include/linux/quotaops.h
View file @
f0071c7b
...
@@ -25,10 +25,10 @@ extern void dquot_drop(struct inode *inode);
...
@@ -25,10 +25,10 @@ extern void dquot_drop(struct inode *inode);
extern
int
quota_off
(
struct
super_block
*
sb
,
short
type
);
extern
int
quota_off
(
struct
super_block
*
sb
,
short
type
);
extern
int
sync_dquots
(
struct
super_block
*
sb
,
short
type
);
extern
int
sync_dquots
(
struct
super_block
*
sb
,
short
type
);
extern
int
dquot_alloc_
block
(
struct
inode
*
inode
,
unsigned
long
number
,
char
prealloc
);
extern
int
dquot_alloc_
space
(
struct
inode
*
inode
,
qsize_t
number
,
int
prealloc
);
extern
int
dquot_alloc_inode
(
const
struct
inode
*
inode
,
unsigned
long
number
);
extern
int
dquot_alloc_inode
(
const
struct
inode
*
inode
,
unsigned
long
number
);
extern
void
dquot_free_
block
(
struct
inode
*
inode
,
unsigned
long
number
);
extern
void
dquot_free_
space
(
struct
inode
*
inode
,
qsize_t
number
);
extern
void
dquot_free_inode
(
const
struct
inode
*
inode
,
unsigned
long
number
);
extern
void
dquot_free_inode
(
const
struct
inode
*
inode
,
unsigned
long
number
);
extern
int
dquot_transfer
(
struct
inode
*
inode
,
struct
iattr
*
iattr
);
extern
int
dquot_transfer
(
struct
inode
*
inode
,
struct
iattr
*
iattr
);
...
@@ -59,50 +59,50 @@ static __inline__ void DQUOT_DROP(struct inode *inode)
...
@@ -59,50 +59,50 @@ static __inline__ void DQUOT_DROP(struct inode *inode)
unlock_kernel
();
unlock_kernel
();
}
}
static
__inline__
int
DQUOT_PREALLOC_
BLOCK_NODIRTY
(
struct
inode
*
inode
,
in
t
nr
)
static
__inline__
int
DQUOT_PREALLOC_
SPACE_NODIRTY
(
struct
inode
*
inode
,
qsize_
t
nr
)
{
{
lock_kernel
();
lock_kernel
();
if
(
sb_any_quota_enabled
(
inode
->
i_sb
))
{
if
(
sb_any_quota_enabled
(
inode
->
i_sb
))
{
/*
Number of used blocks is updated in alloc_block
() */
/*
Used space is updated in alloc_space
() */
if
(
inode
->
i_sb
->
dq_op
->
alloc_
block
(
inode
,
fs_to_dq_blocks
(
nr
,
inode
->
i_sb
->
s_blocksize
)
,
1
)
==
NO_QUOTA
)
{
if
(
inode
->
i_sb
->
dq_op
->
alloc_
space
(
inode
,
nr
,
1
)
==
NO_QUOTA
)
{
unlock_kernel
();
unlock_kernel
();
return
1
;
return
1
;
}
}
}
}
else
else
inode
->
i_blocks
+=
nr
<<
(
inode
->
i_sb
->
s_blocksize_bits
-
9
)
;
inode
->
i_blocks
+=
nr
>>
9
;
unlock_kernel
();
unlock_kernel
();
return
0
;
return
0
;
}
}
static
__inline__
int
DQUOT_PREALLOC_
BLOCK
(
struct
inode
*
inode
,
in
t
nr
)
static
__inline__
int
DQUOT_PREALLOC_
SPACE
(
struct
inode
*
inode
,
qsize_
t
nr
)
{
{
int
ret
;
int
ret
;
if
(
!
(
ret
=
DQUOT_PREALLOC_
BLOCK
_NODIRTY
(
inode
,
nr
)))
if
(
!
(
ret
=
DQUOT_PREALLOC_
SPACE
_NODIRTY
(
inode
,
nr
)))
mark_inode_dirty
(
inode
);
mark_inode_dirty
(
inode
);
return
ret
;
return
ret
;
}
}
static
__inline__
int
DQUOT_ALLOC_
BLOCK_NODIRTY
(
struct
inode
*
inode
,
in
t
nr
)
static
__inline__
int
DQUOT_ALLOC_
SPACE_NODIRTY
(
struct
inode
*
inode
,
qsize_
t
nr
)
{
{
lock_kernel
();
lock_kernel
();
if
(
sb_any_quota_enabled
(
inode
->
i_sb
))
{
if
(
sb_any_quota_enabled
(
inode
->
i_sb
))
{
/*
Number of used blocks is updated in alloc_block
() */
/*
Used space is updated in alloc_space
() */
if
(
inode
->
i_sb
->
dq_op
->
alloc_
block
(
inode
,
fs_to_dq_blocks
(
nr
,
inode
->
i_sb
->
s_blocksize
)
,
0
)
==
NO_QUOTA
)
{
if
(
inode
->
i_sb
->
dq_op
->
alloc_
space
(
inode
,
nr
,
0
)
==
NO_QUOTA
)
{
unlock_kernel
();
unlock_kernel
();
return
1
;
return
1
;
}
}
}
}
else
else
inode
->
i_blocks
+=
nr
<<
(
inode
->
i_sb
->
s_blocksize_bits
-
9
)
;
inode
->
i_blocks
+=
nr
>>
9
;
unlock_kernel
();
unlock_kernel
();
return
0
;
return
0
;
}
}
static
__inline__
int
DQUOT_ALLOC_
BLOCK
(
struct
inode
*
inode
,
in
t
nr
)
static
__inline__
int
DQUOT_ALLOC_
SPACE
(
struct
inode
*
inode
,
qsize_
t
nr
)
{
{
int
ret
;
int
ret
;
if
(
!
(
ret
=
DQUOT_ALLOC_
BLOCK
_NODIRTY
(
inode
,
nr
)))
if
(
!
(
ret
=
DQUOT_ALLOC_
SPACE
_NODIRTY
(
inode
,
nr
)))
mark_inode_dirty
(
inode
);
mark_inode_dirty
(
inode
);
return
ret
;
return
ret
;
}
}
...
@@ -121,19 +121,19 @@ static __inline__ int DQUOT_ALLOC_INODE(struct inode *inode)
...
@@ -121,19 +121,19 @@ static __inline__ int DQUOT_ALLOC_INODE(struct inode *inode)
return
0
;
return
0
;
}
}
static
__inline__
void
DQUOT_FREE_
BLOCK_NODIRTY
(
struct
inode
*
inode
,
in
t
nr
)
static
__inline__
void
DQUOT_FREE_
SPACE_NODIRTY
(
struct
inode
*
inode
,
qsize_
t
nr
)
{
{
lock_kernel
();
lock_kernel
();
if
(
sb_any_quota_enabled
(
inode
->
i_sb
))
if
(
sb_any_quota_enabled
(
inode
->
i_sb
))
inode
->
i_sb
->
dq_op
->
free_
block
(
inode
,
fs_to_dq_blocks
(
nr
,
inode
->
i_sb
->
s_blocksize
)
);
inode
->
i_sb
->
dq_op
->
free_
space
(
inode
,
nr
);
else
else
inode
->
i_blocks
-=
nr
<<
(
inode
->
i_sb
->
s_blocksize_bits
-
9
)
;
inode
->
i_blocks
-=
nr
>>
9
;
unlock_kernel
();
unlock_kernel
();
}
}
static
__inline__
void
DQUOT_FREE_
BLOCK
(
struct
inode
*
inode
,
in
t
nr
)
static
__inline__
void
DQUOT_FREE_
SPACE
(
struct
inode
*
inode
,
qsize_
t
nr
)
{
{
DQUOT_FREE_
BLOCK
_NODIRTY
(
inode
,
nr
);
DQUOT_FREE_
SPACE
_NODIRTY
(
inode
,
nr
);
mark_inode_dirty
(
inode
);
mark_inode_dirty
(
inode
);
}
}
...
@@ -174,48 +174,56 @@ static __inline__ int DQUOT_TRANSFER(struct inode *inode, struct iattr *iattr)
...
@@ -174,48 +174,56 @@ static __inline__ int DQUOT_TRANSFER(struct inode *inode, struct iattr *iattr)
#define DQUOT_SYNC(sb) do { } while(0)
#define DQUOT_SYNC(sb) do { } while(0)
#define DQUOT_OFF(sb) do { } while(0)
#define DQUOT_OFF(sb) do { } while(0)
#define DQUOT_TRANSFER(inode, iattr) (0)
#define DQUOT_TRANSFER(inode, iattr) (0)
extern
__inline__
int
DQUOT_PREALLOC_
BLOCK_NODIRTY
(
struct
inode
*
inode
,
in
t
nr
)
extern
__inline__
int
DQUOT_PREALLOC_
SPACE_NODIRTY
(
struct
inode
*
inode
,
qsize_
t
nr
)
{
{
lock_kernel
();
lock_kernel
();
inode
->
i_blocks
+=
nr
<<
(
inode
->
i_sb
->
s_blocksize_bits
-
9
)
;
inode
->
i_blocks
+=
nr
>>
9
;
unlock_kernel
();
unlock_kernel
();
return
0
;
return
0
;
}
}
extern
__inline__
int
DQUOT_PREALLOC_
BLOCK
(
struct
inode
*
inode
,
in
t
nr
)
extern
__inline__
int
DQUOT_PREALLOC_
SPACE
(
struct
inode
*
inode
,
qsize_
t
nr
)
{
{
DQUOT_PREALLOC_
BLOCK
_NODIRTY
(
inode
,
nr
);
DQUOT_PREALLOC_
SPACE
_NODIRTY
(
inode
,
nr
);
mark_inode_dirty
(
inode
);
mark_inode_dirty
(
inode
);
return
0
;
return
0
;
}
}
extern
__inline__
int
DQUOT_ALLOC_
BLOCK_NODIRTY
(
struct
inode
*
inode
,
in
t
nr
)
extern
__inline__
int
DQUOT_ALLOC_
SPACE_NODIRTY
(
struct
inode
*
inode
,
qsize_
t
nr
)
{
{
lock_kernel
();
lock_kernel
();
inode
->
i_blocks
+=
nr
<<
(
inode
->
i_sb
->
s_blocksize_bits
-
9
)
;
inode
->
i_blocks
+=
nr
>>
9
;
unlock_kernel
();
unlock_kernel
();
return
0
;
return
0
;
}
}
extern
__inline__
int
DQUOT_ALLOC_
BLOCK
(
struct
inode
*
inode
,
in
t
nr
)
extern
__inline__
int
DQUOT_ALLOC_
SPACE
(
struct
inode
*
inode
,
qsize_
t
nr
)
{
{
DQUOT_ALLOC_
BLOCK
_NODIRTY
(
inode
,
nr
);
DQUOT_ALLOC_
SPACE
_NODIRTY
(
inode
,
nr
);
mark_inode_dirty
(
inode
);
mark_inode_dirty
(
inode
);
return
0
;
return
0
;
}
}
extern
__inline__
void
DQUOT_FREE_
BLOCK_NODIRTY
(
struct
inode
*
inode
,
in
t
nr
)
extern
__inline__
void
DQUOT_FREE_
SPACE_NODIRTY
(
struct
inode
*
inode
,
qsize_
t
nr
)
{
{
lock_kernel
();
lock_kernel
();
inode
->
i_blocks
-=
nr
<<
(
inode
->
i_sb
->
s_blocksize_bits
-
9
)
;
inode
->
i_blocks
-=
nr
>>
9
;
unlock_kernel
();
unlock_kernel
();
}
}
extern
__inline__
void
DQUOT_FREE_
BLOCK
(
struct
inode
*
inode
,
in
t
nr
)
extern
__inline__
void
DQUOT_FREE_
SPACE
(
struct
inode
*
inode
,
qsize_
t
nr
)
{
{
DQUOT_FREE_
BLOCK
_NODIRTY
(
inode
,
nr
);
DQUOT_FREE_
SPACE
_NODIRTY
(
inode
,
nr
);
mark_inode_dirty
(
inode
);
mark_inode_dirty
(
inode
);
}
}
#endif
/* CONFIG_QUOTA */
#endif
/* CONFIG_QUOTA */
#define DQUOT_PREALLOC_BLOCK_NODIRTY(inode, nr) DQUOT_PREALLOC_SPACE_NODIRTY(inode, ((qsize_t)(nr)) << (inode)->i_sb->s_blocksize_bits)
#define DQUOT_PREALLOC_BLOCK(inode, nr) DQUOT_PREALLOC_SPACE(inode, ((qsize_t)(nr)) << (inode)->i_sb->s_blocksize_bits)
#define DQUOT_ALLOC_BLOCK_NODIRTY(inode, nr) DQUOT_ALLOC_SPACE_NODIRTY(inode, ((qsize_t)(nr)) << (inode)->i_sb->s_blocksize_bits)
#define DQUOT_ALLOC_BLOCK(inode, nr) DQUOT_ALLOC_SPACE(inode, fs_to_dq_blocks(nr, ((qsize_t)(nr)) << (inode)->i_sb->s_blocksize_bits)
#define DQUOT_FREE_BLOCK_NODIRTY(inode, nr) DQUOT_FREE_SPACE_NODIRTY(inode, ((qsize_t)(nr)) << (inode)->i_sb->s_blocksize_bits)
#define DQUOT_FREE_BLOCK(inode, nr) DQUOT_FREE_SPACE(inode, fs_to_dq_blocks(nr, ((qsize_t)(nr)) << (inode)->i_sb->s_blocksize_bits)
#endif
/* _LINUX_QUOTAOPS_ */
#endif
/* _LINUX_QUOTAOPS_ */
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment