Ticket #4631 (new defect)
Opened 2 hours ago
File transfer hangs upon "Skip all" on I/O errors
Reported by: | zaytsev | Owned by: | |
---|---|---|---|
Priority: | major | Milestone: | 4.8.34 |
Component: | mc-core | Version: | master |
Keywords: | Cc: | kilobyte@… | |
Blocked By: | Blocking: | ||
Branch state: | no branch | Votes for changeset: |
Description
Forwarded from https://bugs-devel.debian.org/cgi-bin/bugreport.cgi?bug=844331:
When a "Copy" or "Move" operation hits an io error, it offers to "Skip" the
current file, "Skip all", "Retry", "Abort". If you select "Skip all", it
will ask you once whether to delete the incomplete file, then hang. The UI
is still responsive, showing an ever-increasing ETA, yet no progress is
being done.
On the other hand, mere "Skip" does work -- it asks two questions per file
(Skip then delete incomplete), which is greatly tedious but allows progress.
As I can't quite mail you a physical bad disk, I've crafted a small image
that you can loop-mount. It's formatted with btrfs (for data checksums) and
has all of the three files scribbled over so the checksums don't match.
While in the root of this filesystem, with the cursor over the only
directory, please press F5 or F6. Select a destination, then "Skip all".
By the way, an unrelated bug: F3 over one of these files, it'll happily
claim the files are empty instead of reporting the error. "cat", "tar" or
anything will report it correctly.
Note that the image I've attached to the previous mail uses btrfs, but the
problem is in no way btrfs-specific. It's the only mainline filesystem[1]
that has data checksums, making it trivial to simulate an I/O error without
physically damaging a disk or using a block device simulator.
To use the image:
sudo mount -o loop -t btrfs img /mnt/somehwere
Obviously, a bad sector can hit a directory rather than a plain file, which
results in a different kind of "fun", but this reproducer does the far
more likely case of bad files.