0

为了好玩和练习,我尝试创建一个将位模式写入硬盘驱动器特定扇区的程序。我的想法是能够提供特定的扇区号(以 LBA 格式)并让程序尝试写入它然后从中读取并确定写入和读取是否相同。

到目前为止,该程序有效。但是,在处理非常大的驱动器(因此非常大的偏移量)时,我遇到了问题。

例如,从头寻找到 LBA 1306638144(即寻找到 1306638144*512)会溢出 seek 的off_t

  //approximately what I am trying to achieve

  #define SECTOR_SIZE 512

  char buf[SECTOR_SIZE] = {0}; //would be initialised with a specific pattern
  long long offset = 1306638144*SECTOR_SIZE
  int fd = open("/dev/sdb", O_RDWR);
  
  lseek(fd, offset, SEEK_SET); //offset overflows
  write(fd, buf, sizeof(buf)/sizeof(char));

我尝试通过迭代增加SEEK_CUR并避免传递大量数字来解决这个问题。

有没有适当的方法来处理这个问题?lseek() 是执行此操作的错误函数吗?有没有更好的方法来寻找特定的部门?

最好的祝福!

4

1 回答 1

0

lseek只接受off_t偏移值,在大多数架构上,它们是 32 位有符号长值。即使您准备了long long偏移量,它也会在使用前转换为 32 位值。

但是 Posix 现在带有lseek64. 它几乎是具有相同接口的相同功能,只是它使用off64_t保证(至少)64 位的类型偏移量。

因此,如果您必须处理偏移量可能大于(有符号)32 位值可以表示的文件(或设备),则只需使用启用的新 64 位lseek64而不是旧的。lseek

于 2020-07-21T08:15:16.817 回答