summaryrefslogtreecommitdiffstats
path: root/fs/attr.c
diff options
context:
space:
mode:
authorJosef Bacik <jbacik@fusionio.com>2012-07-31 16:28:48 -0400
committerChris Mason <chris.mason@oracle.com>2012-08-28 16:53:27 -0400
commiteb838e73dc2121d2bae47d5678952cd7d48793b5 (patch)
treee451338c2f68b413f1a3f5821ec0d63f8ef60196 /fs/attr.c
parentdadd1105ca9a1e506c678e8e410e9623efdda821 (diff)
downloadop-kernel-dev-eb838e73dc2121d2bae47d5678952cd7d48793b5.zip
op-kernel-dev-eb838e73dc2121d2bae47d5678952cd7d48793b5.tar.gz
Btrfs: lock extents as we map them in DIO
A deadlock in xfstests 113 was uncovered by commit d187663ef24cd3d033f0cbf2867e70b36a3a90b8 This is because we would not return EIOCBQUEUED for short AIO reads, instead we'd wait for the DIO to complete and then return the amount of data we transferred, which would allow our stuff to unlock the remaning amount. But with this change this no longer happens, so if we have a short AIO read (for example if we try to read past EOF), we could leave the section from EOF to the end of where we tried to read locked. Fixing this is tricky since there is no clear way to know exactly how much data DIO truly submitted for IO, so to make this less hard on ourselves and less combersome we need to lock the extents as we try to map them, and then we unlock any areas we didn't actually map. This makes us completely safe from deadlocks and reliance on a particular behavior of the DIO code. This also lays the groundwork for allowing us to use the normal csum storage method for reads which means we can remove an allocation. Thanks, Signed-off-by: Josef Bacik <jbacik@fusionio.com>
Diffstat (limited to 'fs/attr.c')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud