diff options
author | Tejun Heo <tj@kernel.org> | 2011-04-29 10:15:14 +0200 |
---|---|---|
committer | Jens Axboe <jaxboe@fusionio.com> | 2011-04-29 10:17:25 +0200 |
commit | bf2253a6f00e8fea5b026e471e9f0d0a1b3621f2 (patch) | |
tree | 5ae346dd9f30041f5b33aca2f5adea4f44dd8f6f /virt/kvm/async_pf.h | |
parent | block: unexport DISK_EVENT_MEDIA_CHANGE for legacy/fringe drivers (diff) | |
download | linux-bf2253a6f00e8fea5b026e471e9f0d0a1b3621f2.tar.xz linux-bf2253a6f00e8fea5b026e471e9f0d0a1b3621f2.zip |
cdrom: always check_disk_change() on open
cdrom_open() called check_disk_change() after the rest of open path
succeeded which leads to the following bizarre behavior.
* After media change, if the device opened without O_NONBLOCK,
open_for_data() naturally fails with -ENOMEDIA and
check_disk_change() is never called. The media is known to be gone
and the open failure makes it obvious to the userland but device
invalidation never happens.
* But if the device is opened with O_NONBLOCK, all the checks are
bypassed and cdrom_open() doesn't notice that the media is not there
and check_disk_change() is called and invalidation happens.
There's nothing to be gained by avoiding calling check_disk_change()
on open failure. Common cases end up calling check_disk_change()
anyway. All we get is inconsistent behavior.
Fix it by moving check_disk_change() invocation to the top of
cdrom_open() so that it always gets called regardless of how the rest
of open proceeds.
Stable: 2.6.38
Signed-off-by: Tejun Heo <tj@kernel.org>
Reported-by: Amit Shah <amit.shah@redhat.com>
Tested-by: Amit Shah <amit.shah@redhat.com>
Cc: stable@kernel.org
Signed-off-by: Jens Axboe <jaxboe@fusionio.com>
Diffstat (limited to 'virt/kvm/async_pf.h')
0 files changed, 0 insertions, 0 deletions