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&& image_path, unsigned block_size)
  8. {
  9. return adopt(*new FileBackedDiskDevice(move(image_path), block_size));
  10. }
  11. FileBackedDiskDevice::FileBackedDiskDevice(String&& image_path, unsigned block_size)
  12. : m_image_path(move(image_path))
  13. , m_block_size(block_size)
  14. {
  15. struct stat st;
  16. int result = stat(m_image_path.characters(), &st);
  17. ASSERT(result != -1);
  18. m_file_length = st.st_size;
  19. m_file = fopen(m_image_path.characters(), "r+");
  20. }
  21. FileBackedDiskDevice::~FileBackedDiskDevice()
  22. {
  23. }
  24. unsigned FileBackedDiskDevice::block_size() const
  25. {
  26. return m_block_size;
  27. }
  28. bool FileBackedDiskDevice::read_block(unsigned index, byte* out) const
  29. {
  30. DiskOffset offset = index * m_block_size;
  31. return read_internal(offset, block_size(), out);
  32. }
  33. bool FileBackedDiskDevice::write_block(unsigned index, const byte* data)
  34. {
  35. DiskOffset offset = index * m_block_size;
  36. return write_internal(offset, block_size(), data);
  37. }
  38. bool FileBackedDiskDevice::read_internal(DiskOffset 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_internal(DiskOffset 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::class_name() const
  68. {
  69. return "FileBackedDiskDevice";
  70. }