b7d418131d
* [file_utils] spin-off syscall-related file operations 1. Eliminate the potential circular dependency between persistent-data/block.h and persistent-data/file_utils.h, if the former one wants to include the latter. 2. Avoid namespace pollution by removing the "using namespace std" declaration in block.tcc. 3. Correct the header hierarchy: base/xml_utils.h now no longer depends on the higher-level persistent-data/file_utils.h * [file_utils] support block files in get_file_length()
40 lines
1.1 KiB
C++
40 lines
1.1 KiB
C++
#include "persistent-data/math_utils.h"
|
|
#include "persistent-data/file_utils.h"
|
|
|
|
#include <linux/fs.h>
|
|
#include <sys/ioctl.h>
|
|
#include <sys/types.h>
|
|
#include <sys/stat.h>
|
|
#include <fcntl.h>
|
|
#include <sstream>
|
|
#include <unistd.h>
|
|
|
|
using namespace base;
|
|
using namespace bcache;
|
|
using namespace persistent_data;
|
|
using namespace std;
|
|
|
|
//----------------------------------------------------------------
|
|
|
|
persistent_data::block_address
|
|
persistent_data::get_nr_blocks(std::string const &path, sector_t block_size)
|
|
{
|
|
return div_down<block_address>(file_utils::get_file_length(path),
|
|
block_size);
|
|
}
|
|
|
|
block_address
|
|
persistent_data::get_nr_metadata_blocks(std::string const &path)
|
|
{
|
|
return get_nr_blocks(path, MD_BLOCK_SIZE);
|
|
}
|
|
|
|
persistent_data::block_manager<>::ptr
|
|
persistent_data::open_bm(std::string const &dev_path, block_manager<>::mode m, bool excl)
|
|
{
|
|
block_address nr_blocks = get_nr_metadata_blocks(dev_path);
|
|
return block_manager<>::ptr(new block_manager<>(dev_path, nr_blocks, 1, m, excl));
|
|
}
|
|
|
|
//----------------------------------------------------------------
|