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()
|
2016-06-07 11:12:27 +01:00
|
|
|
: src_b(0),
|
|
|
|
src_e(0),
|
|
|
|
dest_b(0),
|
|
|
|
read_complete(false),
|
2016-04-14 08:54:32 +01:00
|
|
|
write_complete(false) {
|
|
|
|
}
|
|
|
|
|
2016-05-07 11:47:40 +01:00
|
|
|
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) {
|
|
|
|
}
|
|
|
|
|
2016-06-14 16:27:17 +01:00
|
|
|
bool operator <(copy_op const &rhs) const {
|
|
|
|
return dest_b < rhs.dest_b;
|
|
|
|
}
|
|
|
|
|
2016-06-07 11:12:27 +01:00
|
|
|
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:
|
2016-06-07 11:12:27 +01:00
|
|
|
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);
|
2016-06-07 11:12:27 +01:00
|
|
|
~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();
|
2016-06-14 16:27:17 +01:00
|
|
|
boost::optional<copy_op> wait(unsigned µ);
|
2016-03-17 15:15:52 +00:00
|
|
|
|
|
|
|
private:
|
2016-06-14 16:27:17 +01:00
|
|
|
bool pending() const;
|
|
|
|
bool wait_successful(io_engine::wait_result const &p);
|
|
|
|
boost::optional<copy_op> wait_complete();
|
|
|
|
void wait_(unsigned µ);
|
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_;
|
|
|
|
unsigned nr_blocks_;
|
2016-06-07 11:12:27 +01:00
|
|
|
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
|