[file_utils] rename get_nr_blocks() -> get_nr_metadata_blocks() and introduce get_nr_blocks()

This commit is contained in:
Joe Thornber 2016-03-04 10:43:58 +00:00
parent c8276a41f7
commit 8676198e76
4 changed files with 18 additions and 8 deletions

View File

@ -8,11 +8,13 @@
#include <unistd.h> #include <unistd.h>
using namespace base; using namespace base;
using namespace bcache;
using namespace persistent_data;
//---------------------------------------------------------------- //----------------------------------------------------------------
persistent_data::block_address block_address
persistent_data::get_nr_blocks(string const &path) persistent_data::get_nr_blocks(string const &path, block_address block_size)
{ {
using namespace persistent_data; using namespace persistent_data;
@ -24,7 +26,7 @@ persistent_data::get_nr_blocks(string const &path)
throw runtime_error("Couldn't stat dev path"); throw runtime_error("Couldn't stat dev path");
if (S_ISREG(info.st_mode) && info.st_size) if (S_ISREG(info.st_mode) && info.st_size)
nr_blocks = div_up<block_address>(info.st_size, MD_BLOCK_SIZE); nr_blocks = div_down<block_address>(info.st_size, block_size);
else if (S_ISBLK(info.st_mode)) { else if (S_ISBLK(info.st_mode)) {
// To get the size of a block device we need to // To get the size of a block device we need to
@ -39,7 +41,7 @@ persistent_data::get_nr_blocks(string const &path)
throw runtime_error("ioctl BLKGETSIZE64 failed"); throw runtime_error("ioctl BLKGETSIZE64 failed");
} }
::close(fd); ::close(fd);
nr_blocks = div_down<block_address>(nr_blocks, MD_BLOCK_SIZE); nr_blocks = div_down<block_address>(nr_blocks, block_size);
} else } else
// FIXME: needs a better message // FIXME: needs a better message
throw runtime_error("bad path"); throw runtime_error("bad path");
@ -47,10 +49,16 @@ persistent_data::get_nr_blocks(string const &path)
return nr_blocks; return nr_blocks;
} }
block_address
persistent_data::get_nr_metadata_blocks(string const &path)
{
return get_nr_blocks(path, MD_BLOCK_SIZE);
}
persistent_data::block_manager<>::ptr persistent_data::block_manager<>::ptr
persistent_data::open_bm(std::string const &dev_path, block_manager<>::mode m, bool excl) persistent_data::open_bm(std::string const &dev_path, block_manager<>::mode m, bool excl)
{ {
block_address nr_blocks = get_nr_blocks(dev_path); block_address nr_blocks = get_nr_metadata_blocks(dev_path);
return block_manager<>::ptr(new block_manager<>(dev_path, nr_blocks, 1, m, excl)); return block_manager<>::ptr(new block_manager<>(dev_path, nr_blocks, 1, m, excl));
} }

View File

@ -9,7 +9,9 @@
// FIXME: move to a different unit // FIXME: move to a different unit
namespace persistent_data { namespace persistent_data {
persistent_data::block_address get_nr_blocks(string const &path); block_address get_nr_blocks(string const &path, block_address block_size);
block_address get_nr_metadata_blocks(string const &path);
block_manager<>::ptr open_bm(std::string const &dev_path, block_manager<>::ptr open_bm(std::string const &dev_path,
block_manager<>::mode m, bool excl = true); block_manager<>::mode m, bool excl = true);

View File

@ -43,7 +43,7 @@ using namespace thin_provisioning;
namespace { namespace {
block_manager<>::ptr block_manager<>::ptr
open_bm(string const &path) { open_bm(string const &path) {
block_address nr_blocks = get_nr_blocks(path); block_address nr_blocks = get_nr_metadata_blocks(path);
block_manager<>::mode m = block_manager<>::READ_ONLY; block_manager<>::mode m = block_manager<>::READ_ONLY;
return block_manager<>::ptr(new block_manager<>(path, nr_blocks, 1, m)); return block_manager<>::ptr(new block_manager<>(path, nr_blocks, 1, m));
} }

View File

@ -23,7 +23,7 @@ using namespace thin_provisioning;
namespace { namespace {
block_manager<>::ptr block_manager<>::ptr
open_bm(string const &path) { open_bm(string const &path) {
block_address nr_blocks = get_nr_blocks(path); block_address nr_blocks = get_nr_metadata_blocks(path);
block_manager<>::mode m = block_manager<>::READ_ONLY; block_manager<>::mode m = block_manager<>::READ_ONLY;
return block_manager<>::ptr(new block_manager<>(path, nr_blocks, 1, m)); return block_manager<>::ptr(new block_manager<>(path, nr_blocks, 1, m));
} }