FileBackedDiskDevice.cpp 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. #define _FILE_OFFSET_BITS 64
  2. #include <Kernel/Devices/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. RefPtr<FileBackedDiskDevice> FileBackedDiskDevice::create(String&& image_path, unsigned block_size)
  8. {
  9. return adopt(*new FileBackedDiskDevice(move(image_path), block_size));
  10. }
  11. FileBackedDiskDevice::FileBackedDiskDevice(const String& image_path, size_t block_size)
  12. : DiskDevice(0, 0, block_size)
  13. , m_image_path(image_path)
  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. bool FileBackedDiskDevice::read_block(unsigned index, u8* out) const
  25. {
  26. DiskOffset offset = index * block_size();
  27. return read_internal(offset, block_size(), out);
  28. }
  29. bool FileBackedDiskDevice::write_block(unsigned index, const u8* data)
  30. {
  31. DiskOffset offset = index * block_size();
  32. return write_internal(offset, block_size(), data);
  33. }
  34. bool FileBackedDiskDevice::read_internal(DiskOffset offset, unsigned length, u8* out) const
  35. {
  36. #ifndef IGNORE_FILE_LENGTH
  37. if (offset + length >= m_file_length)
  38. return false;
  39. #endif
  40. #ifdef FBBD_DEBUG
  41. printf("[FileBackedDiskDevice] Read device @ offset %llx, length %u\n", offset, length);
  42. #endif
  43. fseeko(m_file, offset, SEEK_SET);
  44. unsigned nread = fread(out, sizeof(u8), length, m_file);
  45. ASSERT(nread == length);
  46. return true;
  47. }
  48. bool FileBackedDiskDevice::write_internal(DiskOffset offset, unsigned length, const u8* data)
  49. {
  50. #ifndef IGNORE_FILE_LENGTH
  51. if (offset + length >= m_file_length)
  52. return false;
  53. #endif
  54. #ifdef FBBD_DEBUG
  55. printf("[FileBackedDiskDevice] Write device @ offset %llx, length %u\n", offset, length);
  56. #endif
  57. fseeko(m_file, offset, SEEK_SET);
  58. // size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream);
  59. unsigned nwritten = fwrite(data, sizeof(u8), length, m_file);
  60. ASSERT(nwritten == length);
  61. return true;
  62. }
  63. const char* FileBackedDiskDevice::class_name() const
  64. {
  65. return "FileBackedDiskDevice";
  66. }