diff options
-rw-r--r-- | fs/ntfs/aops.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/fs/ntfs/aops.c b/fs/ntfs/aops.c index 01c770979921..8946130c87ad 100644 --- a/fs/ntfs/aops.c +++ b/fs/ntfs/aops.c | |||
@@ -922,7 +922,7 @@ static int ntfs_write_mst_block(struct page *page, | |||
922 | ntfs_volume *vol = ni->vol; | 922 | ntfs_volume *vol = ni->vol; |
923 | u8 *kaddr; | 923 | u8 *kaddr; |
924 | unsigned int rec_size = ni->itype.index.block_size; | 924 | unsigned int rec_size = ni->itype.index.block_size; |
925 | ntfs_inode *locked_nis[PAGE_SIZE / rec_size]; | 925 | ntfs_inode *locked_nis[PAGE_SIZE / NTFS_BLOCK_SIZE]; |
926 | struct buffer_head *bh, *head, *tbh, *rec_start_bh; | 926 | struct buffer_head *bh, *head, *tbh, *rec_start_bh; |
927 | struct buffer_head *bhs[MAX_BUF_PER_PAGE]; | 927 | struct buffer_head *bhs[MAX_BUF_PER_PAGE]; |
928 | runlist_element *rl; | 928 | runlist_element *rl; |
@@ -931,6 +931,9 @@ static int ntfs_write_mst_block(struct page *page, | |||
931 | bool sync, is_mft, page_is_dirty, rec_is_dirty; | 931 | bool sync, is_mft, page_is_dirty, rec_is_dirty; |
932 | unsigned char bh_size_bits; | 932 | unsigned char bh_size_bits; |
933 | 933 | ||
934 | if (WARN_ON(rec_size < NTFS_BLOCK_SIZE)) | ||
935 | return -EINVAL; | ||
936 | |||
934 | ntfs_debug("Entering for inode 0x%lx, attribute type 0x%x, page index " | 937 | ntfs_debug("Entering for inode 0x%lx, attribute type 0x%x, page index " |
935 | "0x%lx.", vi->i_ino, ni->type, page->index); | 938 | "0x%lx.", vi->i_ino, ni->type, page->index); |
936 | BUG_ON(!NInoNonResident(ni)); | 939 | BUG_ON(!NInoNonResident(ni)); |