Btrfs: fix use after free in O_DIRECT
This fixes a bug where we use dip after we have freed it. Instead just use the file_offset that was passed to the function. Thanks, Signed-off-by: Josef Bacik <josef@redhat.com>
This commit is contained in:
parent
5a92bc88ce
commit
955256f2c3
1 changed files with 1 additions and 2 deletions
|
@ -5934,8 +5934,7 @@ static void btrfs_submit_direct(int rw, struct bio *bio, struct inode *inode,
|
||||||
*/
|
*/
|
||||||
if (write) {
|
if (write) {
|
||||||
struct btrfs_ordered_extent *ordered;
|
struct btrfs_ordered_extent *ordered;
|
||||||
ordered = btrfs_lookup_ordered_extent(inode,
|
ordered = btrfs_lookup_ordered_extent(inode, file_offset);
|
||||||
dip->logical_offset);
|
|
||||||
if (!test_bit(BTRFS_ORDERED_PREALLOC, &ordered->flags) &&
|
if (!test_bit(BTRFS_ORDERED_PREALLOC, &ordered->flags) &&
|
||||||
!test_bit(BTRFS_ORDERED_NOCOW, &ordered->flags))
|
!test_bit(BTRFS_ORDERED_NOCOW, &ordered->flags))
|
||||||
btrfs_free_reserved_extent(root, ordered->start,
|
btrfs_free_reserved_extent(root, ordered->start,
|
||||||
|
|
Loading…
Reference in a new issue