FileBackedDiskDevice.cpp 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. #define _FILE_OFFSET_BITS 64
  2. #include "FileBackedDiskDevice.h"
  3. #include <cstring>
  4. #include <sys/stat.h>
  5. //#define FBBD_DEBUG
  6. #define IGNORE_FILE_LENGTH // Useful for e.g /dev/hda2
  7. RetainPtr<FileBackedDiskDevice> FileBackedDiskDevice::create(String&& imagePath, unsigned blockSize)
  8. {
  9. return adopt(*new FileBackedDiskDevice(std::move(imagePath), blockSize));
  10. }
  11. FileBackedDiskDevice::FileBackedDiskDevice(String&& imagePath, unsigned blockSize)
  12. : m_imagePath(std::move(imagePath))
  13. , m_blockSize(blockSize)
  14. {
  15. struct stat st;
  16. int result = stat(m_imagePath.characters(), &st);
  17. ASSERT(result != -1);
  18. m_fileLength = st.st_size;
  19. m_file = fopen(m_imagePath.characters(), "r+");
  20. }
  21. FileBackedDiskDevice::~FileBackedDiskDevice()
  22. {
  23. }
  24. unsigned FileBackedDiskDevice::blockSize() const
  25. {
  26. return m_blockSize;
  27. }
  28. bool FileBackedDiskDevice::readBlock(unsigned index, byte* out) const
  29. {
  30. qword offset = index * m_blockSize;
  31. return read(offset, blockSize(), out);
  32. }
  33. bool FileBackedDiskDevice::writeBlock(unsigned index, const byte* data)
  34. {
  35. qword offset = index * m_blockSize;
  36. return write(offset, blockSize(), data);
  37. }
  38. bool FileBackedDiskDevice::read(qword offset, unsigned length, byte* out) const
  39. {
  40. #ifndef IGNORE_FILE_LENGTH
  41. if (offset + length >= m_fileLength)
  42. return false;
  43. #endif
  44. #ifdef FBBD_DEBUG
  45. printf("[FileBackedDiskDevice] Read device @ offset %llx, length %u\n", offset, length);
  46. #endif
  47. fseeko(m_file, offset, SEEK_SET);
  48. unsigned nread = fread(out, sizeof(byte), length, m_file);
  49. ASSERT(nread == length);
  50. return true;
  51. }
  52. bool FileBackedDiskDevice::write(qword offset, unsigned length, const byte* data)
  53. {
  54. #ifndef IGNORE_FILE_LENGTH
  55. if (offset + length >= m_fileLength)
  56. return false;
  57. #endif
  58. #ifdef FBBD_DEBUG
  59. printf("[FileBackedDiskDevice] Write device @ offset %llx, length %u\n", offset, length);
  60. #endif
  61. fseeko(m_file, offset, SEEK_SET);
  62. // size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream);
  63. unsigned nwritten = fwrite(data, sizeof(byte), length, m_file);
  64. ASSERT(nwritten == length);
  65. return true;
  66. }
  67. const char* FileBackedDiskDevice::className() const
  68. {
  69. return "FileBackedDiskDevice";
  70. }