|
@@ -23,6 +23,7 @@
|
|
|
#include "sysfile.h"
|
|
|
#include "dlmglue.h"
|
|
|
#include "uptodate.h"
|
|
|
+#include "super.h"
|
|
|
#include "quota.h"
|
|
|
|
|
|
static struct workqueue_struct *ocfs2_quota_wq = NULL;
|
|
@@ -114,6 +115,15 @@ int ocfs2_read_quota_block(struct inode *inode, u64 v_block,
|
|
|
int rc = 0;
|
|
|
struct buffer_head *tmp = *bh;
|
|
|
|
|
|
+ if (i_size_read(inode) >> inode->i_sb->s_blocksize_bits <= v_block) {
|
|
|
+ ocfs2_error(inode->i_sb,
|
|
|
+ "Quota file %llu is probably corrupted! Requested "
|
|
|
+ "to read block %Lu but file has size only %Lu\n",
|
|
|
+ (unsigned long long)OCFS2_I(inode)->ip_blkno,
|
|
|
+ (unsigned long long)v_block,
|
|
|
+ (unsigned long long)i_size_read(inode));
|
|
|
+ return -EIO;
|
|
|
+ }
|
|
|
rc = ocfs2_read_virt_blocks(inode, v_block, 1, &tmp, 0,
|
|
|
ocfs2_validate_quota_block);
|
|
|
if (rc)
|