sortix-mirror/kernel/include/sortix/kernel/fcache.h

153 lines
3.8 KiB
C
Raw Normal View History

2013-03-12 13:24:31 +00:00
/*******************************************************************************
Copyright(C) Jonas 'Sortie' Termansen 2013.
This file is part of Sortix.
Sortix is free software: you can redistribute it and/or modify it under the
terms of the GNU General Public License as published by the Free Software
Foundation, either version 3 of the License, or (at your option) any later
version.
Sortix is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
details.
You should have received a copy of the GNU General Public License along with
Sortix. If not, see <http://www.gnu.org/licenses/>.
sortix/kernel/fcache.h
Cache mechanism for file contents.
*******************************************************************************/
#ifndef INCLUDE_SORTIX_KERNEL_FCACHE_H
#define INCLUDE_SORTIX_KERNEL_FCACHE_H
#include <sys/types.h>
#include <stddef.h>
#include <stdint.h>
2013-03-12 13:24:31 +00:00
#include <sortix/kernel/addralloc.h>
#include <sortix/kernel/kthread.h>
#include <sortix/kernel/memorymanagement.h>
namespace Sortix {
struct ioctx_struct;
typedef struct ioctx_struct ioctx_t;
class BlockCache;
struct BlockCacheArea;
struct BlockCacheBlock;
class FileCache;
//class FileCacheBackend;
const uintptr_t BCACHE_PRESENT = 1 << 0;
const uintptr_t BCACHE_USED = 1 << 1;
const uintptr_t BCACHE_MODIFIED = 1 << 2;
class BlockCache
{
public:
BlockCache();
~BlockCache();
BlockCacheBlock* AcquireBlock();
void ReleaseBlock(BlockCacheBlock* block);
void MarkUsed(BlockCacheBlock* block);
void MarkModified(BlockCacheBlock* block);
uint8_t* BlockData(BlockCacheBlock* block);
public:
bool AddArea();
void UnlinkBlock(BlockCacheBlock* block);
void LinkBlock(BlockCacheBlock* block);
2013-03-12 16:41:25 +00:00
uint8_t* BlockDataUnlocked(BlockCacheBlock* block);
2013-03-12 13:24:31 +00:00
private:
BlockCacheArea* areas;
size_t areas_used;
size_t areas_length;
size_t blocks_per_area;
2013-03-12 16:41:25 +00:00
size_t unused_block_count;
size_t blocks_used;
size_t blocks_allocated;
2013-03-12 13:24:31 +00:00
BlockCacheBlock* mru_block;
BlockCacheBlock* lru_block;
BlockCacheBlock* unused_block;
kthread_mutex_t bcache_mutex;
};
struct BlockCacheArea
{
uint8_t* data;
BlockCacheBlock* blocks;
struct addralloc_t addralloc;
};
struct BlockCacheBlock
{
uintptr_t information;
FileCache* fcache;
BlockCacheBlock* next_block;
BlockCacheBlock* prev_block;
uintptr_t BlockId() { return information >> 12; }
};
class FileCache
{
public:
static void Init();
public:
FileCache(/*FileCacheBackend* backend = NULL*/);
~FileCache();
int sync(ioctx_t* ctx);
ssize_t pread(ioctx_t* ctx, uint8_t* buf, size_t count, off_t off);
ssize_t pwrite(ioctx_t* ctx, const uint8_t* buf, size_t count, off_t off);
int truncate(ioctx_t* ctx, off_t length);
off_t lseek(ioctx_t* ctx, off_t offset, int whence);
//bool ChangeBackend(FileCacheBackend* backend, bool sync_old);
off_t GetFileSize();
private:
bool ChangeSize(off_t newsize, bool exact);
bool ChangeNumBlocks(size_t numblocks, bool exact);
bool Synchronize();
void InitializeFileData(off_t to_where);
private:
off_t file_size;
off_t file_written;
BlockCacheBlock** blocks;
size_t blocks_used;
size_t blocks_length;
kthread_mutex_t fcache_mutex;
bool modified;
bool modified_size;
//FileCacheBackend* backend;
};
/*
class FileCacheBackend
{
public:
virtual ~FileCacheBackend() { }
virtual int fcache_sync(ioctx_t* ctx) = 0;
virtual ssize_t fcache_pread(ioctx_t* ctx, uint8_t* buf, size_t count, off_t off) = 0;
virtual ssize_t fcache_pwrite(ioctx_t* ctx, const uint8_t* buf, size_t count, off_t off) = 0;
virtual int fcache_truncate(ioctx_t* ctx, off_t length) = 0;
virtual off_t fcache_lseek(ioctx_t* ctx, off_t offset, int whence) = 0;
};
*/
} // namespace Sortix
#endif