mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 14:17:36 +00:00
Kernel: Implement O_DIRECT open() flag to bypass disk caches
Files opened with O_DIRECT will now bypass the disk cache in read/write operations (though metadata operations will still hit the disk cache.) This will allow us to test actual disk performance instead of testing disk *cache* performance, if that's what we want. :^) There's room for improvment here, we're very aggressively flushing any dirty cache entries for the specific block before reading/writing that block. This is done by walking the entire cache, which may be slow.
This commit is contained in:
parent
3de3daf765
commit
59ed235c85
7 changed files with 59 additions and 18 deletions
|
@ -21,14 +21,15 @@ public:
|
|||
protected:
|
||||
explicit DiskBackedFS(NonnullRefPtr<DiskDevice>&&);
|
||||
|
||||
bool read_block(unsigned index, u8* buffer) const;
|
||||
bool read_blocks(unsigned index, unsigned count, u8* buffer) const;
|
||||
bool read_block(unsigned index, u8* buffer, FileDescription* = nullptr) const;
|
||||
bool read_blocks(unsigned index, unsigned count, u8* buffer, FileDescription* = nullptr) const;
|
||||
|
||||
bool write_block(unsigned index, const u8*);
|
||||
bool write_blocks(unsigned index, unsigned count, const u8*);
|
||||
bool write_block(unsigned index, const u8*, FileDescription* = nullptr);
|
||||
bool write_blocks(unsigned index, unsigned count, const u8*, FileDescription* = nullptr);
|
||||
|
||||
private:
|
||||
DiskCache& cache() const;
|
||||
void flush_specific_block_if_needed(unsigned index);
|
||||
|
||||
NonnullRefPtr<DiskDevice> m_device;
|
||||
mutable OwnPtr<DiskCache> m_cache;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue