Tôi đang cố gắng cứu dữ liệu từ thẻ SDHC bằng ddresTHER:
while true ; do ddrescue -d /dev/mmcblk0p1 mmc.img mmc.log ; done
Bộ điều khiển, tôi không chắc là nó trên thẻ hay là trong máy tính xách tay của tôi, dường như trả lại lỗi cho tất cả các lĩnh vực (xuất hiện trong syslog) sau khi một số thành phần xấu nhất định đã được đọc (mà không ' T hiển thị trong syslog), tôi thấy rằng việc bật thẻ ra và vào khe lại đặt lại điều này và báo cáo các lĩnh vực tốt là tốt trở lại cho đến khi có quá nhiều thành phần xấu được đọc, v.v.
Hiện tại tôi đang sử dụng vòng lặp này, theo dõi đầu ra trạng thái của ddresTHER, đặt lại thẻ theo cách thủ công. Có cách nào để thiết lập lại bộ điều khiển mà không cần tháo thẻ, vì vậy quá trình cứu hộ có thể chạy không cần giám sát?
Có thể điều này có liên quan, nhưng trong máy tính xách tay Dell này, để người đọc thậm chí nhận thấy một thẻ đã được cắm, nó phải được thực hiện trong khi khởi động hoặc sử dụng echo 1 > /sys/bus/pci/rescan
, nhưng chỉ một lần, sau đó thiết bị PCI đọc xuất hiện và mọi thứ hoạt động như mong đợi:
07:00.0 System peripheral: JMicron Technology Corp. SD/MMC Host Controller (rev 30)
Subsystem: Dell Device 046e
Flags: bus master, fast devsel, latency 0, IRQ 16
Memory at f0600000 (32-bit, non-prefetchable) [size=256]
Capabilities: [a4] Power Management version 3
Capabilities: [80] Express Endpoint, MSI 00
Capabilities: [94] MSI: Enable- Count=1/1 Maskable- 64bit-
Kernel driver in use: sdhci-pci
Syslog có liên quan:
# pop in card
mmc0: new SDHC card at address b368
mmcblk0: mmc0:b368 NCard 15.0 GiB (ro)
mmcblk0: p1
# ddrescue begins to read, error count increases, until at some point:
mmcblk0: error -110 transferring data, sector 12854624, nr 1, cmd response 0x900, card status 0x0
end_request: I/O error, dev mmcblk0, sector 12854624
mmcblk0: error -110 transferring data, sector 12854625, nr 1, cmd response 0x900, card status 0x0
end_request: I/O error, dev mmcblk0, sector 12854625
mmcblk0: error -110 transferring data, sector 12854626, nr 1, cmd response 0x900, card status 0x0
end_request: I/O error, dev mmcblk0, sector 12854626
mmcblk0: error -110 transferring data, sector 12854627, nr 1, cmd response 0x900, card status 0x0
end_request: I/O error, dev mmcblk0, sector 12854627
mmcblk0: error -110 transferring data, sector 12854628, nr 1, cmd response 0x900, card status 0x0
end_request: I/O error, dev mmcblk0, sector 12854628
# time since last successful read increases, pop out card
mmc0: Card removed during transfer!
mmc0: Resetting controller.
mmcblk0: error -123 sending status command, retrying
mmcblk0: error -123 sending status command, retrying
mmcblk0: error -123 sending status command, aborting
mmc0: card b368 removed
# GOTO 10
Tôi cũng đã thử sử dụng đầu đọc thẻ USB, thay vì tạo ra các lỗi này trong syslog, nó chỉ biến mất và cần phải cắm lại để tiếp tục.
Có vẻ như tải lại sdhci_pci
mô-đun thực hiện thủ thuật, nhưng tôi tự hỏi liệu có một tùy chọn ít vũ phu hơn để làm điều này không:
while sleep 1 ; do
ddrescue -d -T 1 /dev/mmcblk0p1 mmc.img mmc.log
modprobe -r sdhci_pci
modprobe sdhci_pci
done