我有一个问题,有时当我将 iso 映像刻录到 CD-R 时:
sudo wodim -v driveropts=burnfree -data dev=/dev/scd0 input.iso
然后再读一遍:
sudo dd if=/dev/cdrom of=output.iso
dd: reading `/dev/cdrom': Input/output error
...
我最终得到了两个不相同的 iso 映像,即最后output.iso
缺少 2048 个字节。然而,当我挂载 iso 映像或 CD-R 并比较挂载点上的实际文件时,两者都是相同的。
这是预期的行为还是实际上不正确的数据刻录?如果符合预期,我如何验证刻录过程是否成功?
我首先问的原因是它似乎是可重现的行为,某些 iso 映像出现 2048 字节短,即使在重复刻录时也是如此,但所有刻录的 CD-R 本身都是相同的。
还有背后的原因是什么:
dd: reading `/dev/cdrom': Input/output error
因为它总是发生,我认为这是正常的,但它背后的技术原因是什么?我假设 CD 不允许设备直接检测大小,所以dd
读取直到它遇到困难的方式结束。
编辑: superusers.com 上的用户 karol 提到大小问题和读取错误都是-tao
在 wodim 中使用(默认)而不是-dao
模式的结果。我还不能测试它,但这听起来是迄今为止最合理的解释。
事实上,它可能是填充。检查文件大小,是不是
output.iso
稍大一些?看看最后
output.iso
:我猜是零?
您可以尝试运行
ls -l input.iso
以获取其确切大小,然后:请注意,这将非常慢,因为您一次读取一个字节。如果大小可以被一个整数整除,则将该整数替换为
1
inbs=1
并除以该count
数字。即使一次 2 个字节也会快得多!至于你的第二个问题,输入/输出错误发生在
dd
设备末端。没什么好担心的。此问题可能与您使用 dd 有关。
conv=direct
使用 dd 读取光盘时尝试添加,即:这告诉
dd
使用O_DIRECT
它的 I/O,绕过内核块层。(通常,即使调用程序请求较少,块层也会读取 4KB 块。对于具有奇数扇区的磁盘来说,这可能是一半时间错误的原因???)