FileSystem.cpp 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. #include <AK/Assertions.h>
  2. #include <AK/HashMap.h>
  3. #include <AK/StringBuilder.h>
  4. #include <LibC/errno_numbers.h>
  5. #include "FileSystem.h"
  6. #include "MemoryManager.h"
  7. #include <Kernel/LocalSocket.h>
  8. static dword s_lastFileSystemID;
  9. static HashMap<dword, FS*>* s_fs_map;
  10. static HashTable<Inode*>* s_inode_set;
  11. static HashMap<dword, FS*>& all_fses()
  12. {
  13. if (!s_fs_map)
  14. s_fs_map = new HashMap<dword, FS*>();
  15. return *s_fs_map;
  16. }
  17. HashTable<Inode*>& all_inodes()
  18. {
  19. if (!s_inode_set)
  20. s_inode_set = new HashTable<Inode*>();
  21. return *s_inode_set;
  22. }
  23. FS::FS()
  24. : m_fsid(++s_lastFileSystemID)
  25. {
  26. all_fses().set(m_fsid, this);
  27. }
  28. FS::~FS()
  29. {
  30. all_fses().remove(m_fsid);
  31. }
  32. FS* FS::from_fsid(dword id)
  33. {
  34. auto it = all_fses().find(id);
  35. if (it != all_fses().end())
  36. return (*it).value;
  37. return nullptr;
  38. }
  39. ByteBuffer Inode::read_entire(FileDescriptor* descriptor) const
  40. {
  41. size_t initial_size = metadata().size ? metadata().size : 4096;
  42. StringBuilder builder(initial_size);
  43. ssize_t nread;
  44. byte buffer[4096];
  45. off_t offset = 0;
  46. for (;;) {
  47. nread = read_bytes(offset, sizeof(buffer), buffer, descriptor);
  48. ASSERT(nread <= (ssize_t)sizeof(buffer));
  49. if (nread <= 0)
  50. break;
  51. builder.append((const char*)buffer, nread);
  52. offset += nread;
  53. }
  54. if (nread < 0) {
  55. kprintf("Inode::read_entire: ERROR: %d\n", nread);
  56. return nullptr;
  57. }
  58. return builder.to_byte_buffer();
  59. }
  60. FS::DirectoryEntry::DirectoryEntry(const char* n, InodeIdentifier i, byte ft)
  61. : name_length(strlen(n))
  62. , inode(i)
  63. , file_type(ft)
  64. {
  65. memcpy(name, n, name_length);
  66. name[name_length] = '\0';
  67. }
  68. FS::DirectoryEntry::DirectoryEntry(const char* n, size_t nl, InodeIdentifier i, byte ft)
  69. : name_length(nl)
  70. , inode(i)
  71. , file_type(ft)
  72. {
  73. memcpy(name, n, nl);
  74. name[nl] = '\0';
  75. }
  76. Inode::Inode(FS& fs, unsigned index)
  77. : m_lock("Inode")
  78. , m_fs(fs)
  79. , m_index(index)
  80. {
  81. all_inodes().set(this);
  82. }
  83. Inode::~Inode()
  84. {
  85. all_inodes().remove(this);
  86. }
  87. void Inode::will_be_destroyed()
  88. {
  89. if (m_metadata_dirty)
  90. flush_metadata();
  91. }
  92. void Inode::inode_contents_changed(off_t offset, ssize_t size, const byte* data)
  93. {
  94. if (m_vmo)
  95. m_vmo->inode_contents_changed(Badge<Inode>(), offset, size, data);
  96. }
  97. void Inode::inode_size_changed(size_t old_size, size_t new_size)
  98. {
  99. if (m_vmo)
  100. m_vmo->inode_size_changed(Badge<Inode>(), old_size, new_size);
  101. }
  102. int Inode::set_atime(time_t)
  103. {
  104. return -ENOTIMPL;
  105. }
  106. int Inode::set_ctime(time_t)
  107. {
  108. return -ENOTIMPL;
  109. }
  110. int Inode::set_mtime(time_t)
  111. {
  112. return -ENOTIMPL;
  113. }
  114. int Inode::increment_link_count()
  115. {
  116. return -ENOTIMPL;
  117. }
  118. int Inode::decrement_link_count()
  119. {
  120. return -ENOTIMPL;
  121. }
  122. void FS::sync()
  123. {
  124. for (auto* inode : all_inodes()) {
  125. if (inode->is_metadata_dirty())
  126. inode->flush_metadata();
  127. }
  128. }
  129. void Inode::set_vmo(VMObject& vmo)
  130. {
  131. m_vmo = vmo.make_weak_ptr();
  132. }
  133. bool Inode::bind_socket(LocalSocket& socket)
  134. {
  135. ASSERT(!m_socket);
  136. m_socket = socket;
  137. return true;
  138. }
  139. bool Inode::unbind_socket()
  140. {
  141. ASSERT(m_socket);
  142. m_socket = nullptr;
  143. return true;
  144. }