106 lines
2.1 KiB
C
Raw Normal View History

2016-03-17 15:15:52 +00:00
#ifndef BLOCK_CACHE_COPIER_H
#define BLOCK_CACHE_COPIER_H
2016-04-14 08:54:32 +01:00
#include "block-cache/io_engine.h"
#include "block-cache/mem_pool.h"
2016-03-17 15:15:52 +00:00
#include <string>
2016-04-14 08:54:32 +01:00
#include <list>
#include <map>
2016-03-17 15:15:52 +00:00
//----------------------------------------------------------------
namespace bcache {
2016-04-14 08:54:32 +01:00
using block_address = uint64_t;
struct copy_op {
copy_op()
: src_b(0),
src_e(0),
dest_b(0),
read_complete(false),
2016-04-14 08:54:32 +01:00
write_complete(false) {
}
copy_op(block_address src_b_,
block_address src_e_,
block_address dest_b_)
: src_b(src_b_),
src_e(src_e_),
dest_b(dest_b_),
read_complete(false),
write_complete(false) {
}
bool operator <(copy_op const &rhs) const {
return dest_b < rhs.dest_b;
}
bool success() const {
return read_complete && write_complete;
}
2016-04-14 08:54:32 +01:00
block_address src_b, src_e;
block_address dest_b;
bool read_complete;
bool write_complete;
};
class copy_job {
public:
copy_job(copy_op const &op_, void *data_)
: op(op_), data(data_) {
}
copy_op op;
void *data;
};
2016-03-17 15:15:52 +00:00
class copier {
public:
copier(io_engine &engine,
std::string const &src, std::string const &dest,
2016-04-14 08:54:32 +01:00
sector_t block_size, size_t mem);
~copier();
2016-04-14 08:54:32 +01:00
sector_t get_block_size() const {
return block_size_;
}
2016-03-17 15:15:52 +00:00
2016-04-14 08:54:32 +01:00
// Blocks if out of memory.
void issue(copy_op const &op);
2016-03-17 15:15:52 +00:00
2016-04-14 08:54:32 +01:00
unsigned nr_pending() const;
boost::optional<copy_op> wait();
boost::optional<copy_op> wait(unsigned &micro);
2016-03-17 15:15:52 +00:00
private:
bool pending() const;
bool wait_successful(io_engine::wait_result const &p);
boost::optional<copy_op> wait_complete();
void wait_(unsigned &micro);
2016-04-14 08:54:32 +01:00
void wait_();
void complete(copy_job const &j);
sector_t to_sector(block_address b) const;
unsigned genkey();
mempool pool_;
sector_t block_size_;
io_engine &engine_;
2016-04-14 08:54:32 +01:00
io_engine::handle src_handle_;
io_engine::handle dest_handle_;
unsigned genkey_count_;
using job_map = std::map<unsigned, copy_job>;
using op_list = std::list<copy_op>;
job_map jobs_;
op_list complete_;
2016-03-17 15:15:52 +00:00
};
}
//----------------------------------------------------------------
#endif