Merge pull request #174 from mingnus/2021-04-28-coverity-fixes
Fix issues detected by Coverity
This commit is contained in:
commit
2413b5d31f
54
Makefile.in
54
Makefile.in
@ -20,15 +20,18 @@ V=@
|
|||||||
|
|
||||||
PROGRAMS=\
|
PROGRAMS=\
|
||||||
bin/pdata_tools
|
bin/pdata_tools
|
||||||
|
DEV_TOOLS=\
|
||||||
ifeq ("@TESTING@", "yes")
|
bin/pdata_tools_dev
|
||||||
PROGRAMS += bin/pdata_tools_dev
|
|
||||||
TESTLIBS=\
|
TESTLIBS=\
|
||||||
lib/libft.so
|
lib/libft.so
|
||||||
endif
|
|
||||||
|
|
||||||
.PHONY: all
|
.PHONY: all dev-tools
|
||||||
all: $(PROGRAMS) $(TESTLIBS)
|
all: $(PROGRAMS)
|
||||||
|
dev-tools: $(DEV_TOOLS)
|
||||||
|
|
||||||
|
ifeq ("@TESTING@", "yes")
|
||||||
|
all += $(TESTLIB)
|
||||||
|
endif
|
||||||
|
|
||||||
include contrib/Makefile
|
include contrib/Makefile
|
||||||
|
|
||||||
@ -84,10 +87,7 @@ COMMON_SOURCE=\
|
|||||||
persistent-data/space_map.cc \
|
persistent-data/space_map.cc \
|
||||||
persistent-data/transaction_manager.cc \
|
persistent-data/transaction_manager.cc \
|
||||||
persistent-data/validators.cc \
|
persistent-data/validators.cc \
|
||||||
thin-provisioning/cache_stream.cc \
|
|
||||||
thin-provisioning/chunk_stream.cc \
|
|
||||||
thin-provisioning/device_tree.cc \
|
thin-provisioning/device_tree.cc \
|
||||||
thin-provisioning/fixed_chunk_stream.cc \
|
|
||||||
thin-provisioning/human_readable_format.cc \
|
thin-provisioning/human_readable_format.cc \
|
||||||
thin-provisioning/mapping_tree.cc \
|
thin-provisioning/mapping_tree.cc \
|
||||||
thin-provisioning/metadata.cc \
|
thin-provisioning/metadata.cc \
|
||||||
@ -95,7 +95,6 @@ COMMON_SOURCE=\
|
|||||||
thin-provisioning/metadata_counter.cc \
|
thin-provisioning/metadata_counter.cc \
|
||||||
thin-provisioning/metadata_dumper.cc \
|
thin-provisioning/metadata_dumper.cc \
|
||||||
thin-provisioning/override_emitter.cc \
|
thin-provisioning/override_emitter.cc \
|
||||||
thin-provisioning/pool_stream.cc \
|
|
||||||
thin-provisioning/restore_emitter.cc \
|
thin-provisioning/restore_emitter.cc \
|
||||||
thin-provisioning/rmap_visitor.cc \
|
thin-provisioning/rmap_visitor.cc \
|
||||||
thin-provisioning/superblock.cc \
|
thin-provisioning/superblock.cc \
|
||||||
@ -137,8 +136,12 @@ DEVTOOLS_SOURCE=\
|
|||||||
dbg-lib/sm_show_traits.cc \
|
dbg-lib/sm_show_traits.cc \
|
||||||
era/devel_commands.cc \
|
era/devel_commands.cc \
|
||||||
era/era_debug.cc \
|
era/era_debug.cc \
|
||||||
|
thin-provisioning/cache_stream.cc \
|
||||||
|
thin-provisioning/chunk_stream.cc \
|
||||||
thin-provisioning/damage_generator.cc \
|
thin-provisioning/damage_generator.cc \
|
||||||
thin-provisioning/devel_commands.cc \
|
thin-provisioning/devel_commands.cc \
|
||||||
|
thin-provisioning/fixed_chunk_stream.cc \
|
||||||
|
thin-provisioning/pool_stream.cc \
|
||||||
thin-provisioning/thin_debug.cc \
|
thin-provisioning/thin_debug.cc \
|
||||||
thin-provisioning/thin_generate_damage.cc \
|
thin-provisioning/thin_generate_damage.cc \
|
||||||
thin-provisioning/thin_generate_mappings.cc \
|
thin-provisioning/thin_generate_mappings.cc \
|
||||||
@ -185,7 +188,8 @@ CXXFLAGS+=@CXXOPTIMISE_FLAG@
|
|||||||
CXXFLAGS+=@CXXDEBUG_FLAG@
|
CXXFLAGS+=@CXXDEBUG_FLAG@
|
||||||
CXXFLAGS+=@CXX_STRERROR_FLAG@
|
CXXFLAGS+=@CXX_STRERROR_FLAG@
|
||||||
CXXFLAGS+=@LFS_FLAGS@
|
CXXFLAGS+=@LFS_FLAGS@
|
||||||
INCLUDES+=-I$(TOP_BUILDDIR) -I$(TOP_DIR) -I$(TOP_DIR)/thin-provisioning
|
CPPFLAGS?=@CPPFLAGS@
|
||||||
|
CPPFLAGS+=-I$(TOP_BUILDDIR) -I$(TOP_DIR)
|
||||||
LIBS:=-laio -lexpat -lboost_iostreams -ldl
|
LIBS:=-laio -lexpat -lboost_iostreams -ldl
|
||||||
DEV_LIBS:=-lncurses
|
DEV_LIBS:=-lncurses
|
||||||
|
|
||||||
@ -211,30 +215,21 @@ INSTALL_DIR = $(INSTALL) -m 755 -d
|
|||||||
INSTALL_PROGRAM = $(INSTALL) -m 755
|
INSTALL_PROGRAM = $(INSTALL) -m 755
|
||||||
INSTALL_DATA = $(INSTALL) -p -m 644
|
INSTALL_DATA = $(INSTALL) -p -m 644
|
||||||
|
|
||||||
ifeq ("@TESTING@", "yes")
|
|
||||||
TEST_INCLUDES=\
|
|
||||||
-I$(TOP_DIR) \
|
|
||||||
-Igoogletest/googlemock/include \
|
|
||||||
-Igoogletest/googletest/include
|
|
||||||
else
|
|
||||||
TEST_INCLUDES=
|
|
||||||
endif
|
|
||||||
|
|
||||||
.SUFFIXES: .d .txt .8
|
.SUFFIXES: .d .txt .8
|
||||||
|
|
||||||
%.o: %.cc
|
%.o: %.cc
|
||||||
@echo " [CXX] $<"
|
@echo " [CXX] $<"
|
||||||
@mkdir -p $(dir $@)
|
@mkdir -p $(dir $@)
|
||||||
$(V) $(CXX) -c $(INCLUDES) $(CXXFLAGS) -o $@ $<
|
$(V) $(CXX) -c $(CPPFLAGS) $(CXXFLAGS) -o $@ $<
|
||||||
$(V) $(CXX) -MM -MT $(subst .cc,.o,$<) $(INCLUDES) $(TEST_INCLUDES) $(CXXFLAGS) $< > $*.$$$$; \
|
$(V) $(CXX) -MM -MT $(subst .cc,.o,$<) $(CPPFLAGS) $(CXXFLAGS) $< > $*.$$$$; \
|
||||||
sed 's,\([^ :]*\)\.o[ :]*,\1.o \1.gmo $* : Makefile ,g' < $*.$$$$ > $*.d; \
|
sed 's,\([^ :]*\)\.o[ :]*,\1.o \1.gmo $* : Makefile ,g' < $*.$$$$ > $*.d; \
|
||||||
$(RM) $*.$$$$
|
$(RM) $*.$$$$
|
||||||
|
|
||||||
%.o: %.c
|
%.o: %.c
|
||||||
@echo " [CC] $<"
|
@echo " [CC] $<"
|
||||||
@mkdir -p $(dir $@)
|
@mkdir -p $(dir $@)
|
||||||
$(V) $(CC) -c $(INCLUDES) $(CFLAGS) -o $@ $<
|
$(V) $(CC) -c $(CPPFLAGS) $(CFLAGS) -o $@ $<
|
||||||
$(V) $(CC) -MM -MT $(subst .cc,.o,$<) $(INCLUDES) $(TEST_INCLUDES) $(CFLAGS) $< > $*.$$$$; \
|
$(V) $(CC) -MM -MT $(subst .cc,.o,$<) $(CPPFLAGS) $(CFLAGS) $< > $*.$$$$; \
|
||||||
sed 's,\([^ :]*\)\.o[ :]*,\1.o \1.gmo $* : Makefile ,g' < $*.$$$$ > $*.d; \
|
sed 's,\([^ :]*\)\.o[ :]*,\1.o \1.gmo $* : Makefile ,g' < $*.$$$$ > $*.d; \
|
||||||
$(RM) $*.$$$$
|
$(RM) $*.$$$$
|
||||||
|
|
||||||
@ -275,7 +270,7 @@ clean:
|
|||||||
find . -name \*.o -delete
|
find . -name \*.o -delete
|
||||||
find . -name \*.gmo -delete
|
find . -name \*.gmo -delete
|
||||||
find . -name \*.d -delete
|
find . -name \*.d -delete
|
||||||
$(RM) $(PROGRAMS) lib/*.a lib/*.so
|
$(RM) $(PROGRAMS) $(DEV_TOOLS) lib/*.a lib/*.so
|
||||||
|
|
||||||
distclean: clean
|
distclean: clean
|
||||||
$(RM) config.cache config.log config.status configure.h version.h Makefile unit-tests/Makefile
|
$(RM) config.cache config.log config.status configure.h version.h Makefile unit-tests/Makefile
|
||||||
@ -360,7 +355,8 @@ install-rust-tools: man8/thin_metadata_pack.8 man8/thin_metadata_unpack.8 rust-t
|
|||||||
$(INSTALL_DATA) man8/thin_metadata_pack.8 $(MANPATH)/man8
|
$(INSTALL_DATA) man8/thin_metadata_pack.8 $(MANPATH)/man8
|
||||||
$(INSTALL_DATA) man8/thin_metadata_unpack.8 $(MANPATH)/man8
|
$(INSTALL_DATA) man8/thin_metadata_unpack.8 $(MANPATH)/man8
|
||||||
|
|
||||||
ifeq ("@TESTING@", "yes")
|
#----------------------------------------------------------------
|
||||||
|
|
||||||
include unit-tests/Makefile
|
include unit-tests/Makefile
|
||||||
|
|
||||||
LIBFT_SOURCE=\
|
LIBFT_SOURCE=\
|
||||||
@ -376,11 +372,11 @@ lib/libft.so: $(LIBFT_OBJECTS)
|
|||||||
|
|
||||||
.PHONEY: functional-test unit-test
|
.PHONEY: functional-test unit-test
|
||||||
|
|
||||||
functional-test: $(PROGRAMS) $(TESTLIBS)
|
functional-test: $(PROGRAMS) $(DEV_TOOLS) $(TESTLIBS)
|
||||||
cd functional-tests && ./run-tests run
|
cd functional-tests && ./run-tests run
|
||||||
|
|
||||||
test: functional-test unit-test
|
test: functional-test unit-test
|
||||||
endif
|
|
||||||
|
#----------------------------------------------------------------
|
||||||
|
|
||||||
-include $(DEPEND_FILES)
|
-include $(DEPEND_FILES)
|
||||||
|
|
||||||
|
@ -25,8 +25,14 @@ command::die(string const &msg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
::uint64_t
|
::uint64_t
|
||||||
command::parse_uint64(string const &str, string const &desc)
|
command::parse_uint64(char const *str, char const *desc)
|
||||||
{
|
{
|
||||||
|
if (!str) {
|
||||||
|
ostringstream out;
|
||||||
|
out << "Couldn't parse " << desc << ": NULL";
|
||||||
|
die(out.str());
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
// FIXME: check trailing garbage is handled
|
// FIXME: check trailing garbage is handled
|
||||||
return lexical_cast<::uint64_t>(str);
|
return lexical_cast<::uint64_t>(str);
|
||||||
|
@ -19,7 +19,7 @@ namespace base {
|
|||||||
virtual ~command() {}
|
virtual ~command() {}
|
||||||
|
|
||||||
void die(std::string const &msg);
|
void die(std::string const &msg);
|
||||||
uint64_t parse_uint64(std::string const &str, std::string const &desc);
|
uint64_t parse_uint64(char const *str, char const *desc);
|
||||||
|
|
||||||
|
|
||||||
virtual void usage(std::ostream &out) const = 0;
|
virtual void usage(std::ostream &out) const = 0;
|
||||||
|
@ -155,8 +155,10 @@ file_utils::zero_superblock(std::string const &path)
|
|||||||
throw runtime_error("out of memory");
|
throw runtime_error("out of memory");
|
||||||
|
|
||||||
memset(buffer, 0, SUPERBLOCK_SIZE);
|
memset(buffer, 0, SUPERBLOCK_SIZE);
|
||||||
if (::write(fd.fd_, buffer, SUPERBLOCK_SIZE) != SUPERBLOCK_SIZE)
|
if (::write(fd.fd_, buffer, SUPERBLOCK_SIZE) != SUPERBLOCK_SIZE) {
|
||||||
|
free(buffer);
|
||||||
throw runtime_error("couldn't zero superblock");
|
throw runtime_error("couldn't zero superblock");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
//----------------------------------------------------------------
|
||||||
|
@ -174,9 +174,6 @@ aio_engine::wait_(timespec *ts)
|
|||||||
cbs_.free(cb);
|
cbs_.free(cb);
|
||||||
return optional<wait_result>(make_pair(false, context));
|
return optional<wait_result>(make_pair(false, context));
|
||||||
}
|
}
|
||||||
|
|
||||||
// shouldn't get here
|
|
||||||
return optional<wait_result>(make_pair(false, 0));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
struct timespec
|
struct timespec
|
||||||
|
@ -56,9 +56,6 @@ namespace {
|
|||||||
default:
|
default:
|
||||||
throw runtime_error("invalid hint width");
|
throw runtime_error("invalid hint width");
|
||||||
}
|
}
|
||||||
|
|
||||||
// never get here
|
|
||||||
return std::shared_ptr<array_base>();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------
|
//--------------------------------
|
||||||
@ -93,9 +90,6 @@ namespace {
|
|||||||
default:
|
default:
|
||||||
throw runtime_error("invalid hint width");
|
throw runtime_error("invalid hint width");
|
||||||
}
|
}
|
||||||
|
|
||||||
// never get here
|
|
||||||
return std::shared_ptr<array_base>();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------
|
//--------------------------------
|
||||||
|
@ -18,7 +18,7 @@ contrib/%.a: contrib/%.o
|
|||||||
$(V)echo " [AR] $@"
|
$(V)echo " [AR] $@"
|
||||||
$(V)$(AR) rcs $@ $^
|
$(V)$(AR) rcs $@ $^
|
||||||
|
|
||||||
contrib/%.so: contrib/%.a
|
contrib/%.so: contrib/%.o
|
||||||
$(V)echo " [LD] $@"
|
$(V)echo " [LD] $@"
|
||||||
$(V)$(CC) -shared -Wl,-soname,$@ -o $@ $<
|
$(V)$(CC) -shared -Wl,-soname,$@ -o $@ $<
|
||||||
|
|
||||||
|
@ -14,6 +14,7 @@ namespace {
|
|||||||
: md_(md),
|
: md_(md),
|
||||||
in_superblock_(false),
|
in_superblock_(false),
|
||||||
in_writeset_(false),
|
in_writeset_(false),
|
||||||
|
era_(0),
|
||||||
in_era_array_(false) {
|
in_era_array_(false) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,7 +62,7 @@ chunk const &
|
|||||||
cache_stream::get()
|
cache_stream::get()
|
||||||
{
|
{
|
||||||
chunk_wrapper *w = new chunk_wrapper(*this);
|
chunk_wrapper *w = new chunk_wrapper(*this);
|
||||||
return w->c_;
|
return w->c_; // wrapper will get freed by the put method
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -645,6 +645,10 @@ namespace {
|
|||||||
public:
|
public:
|
||||||
mapping_emit_visitor(emitter::ptr e)
|
mapping_emit_visitor(emitter::ptr e)
|
||||||
: e_(e),
|
: e_(e),
|
||||||
|
origin_start_(0),
|
||||||
|
dest_start_(0),
|
||||||
|
time_(0),
|
||||||
|
len_(0),
|
||||||
in_range_(false) {
|
in_range_(false) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -8,22 +8,109 @@ using namespace thin_provisioning;
|
|||||||
|
|
||||||
//----------------------------------------------------------------
|
//----------------------------------------------------------------
|
||||||
|
|
||||||
|
struct shared_object {
|
||||||
|
public:
|
||||||
|
shared_object(const char *shared_lib) {
|
||||||
|
handle_ = dlopen(shared_lib, RTLD_LAZY);
|
||||||
|
if (!handle_)
|
||||||
|
throw runtime_error(dlerror());
|
||||||
|
|
||||||
|
dlerror(); // Clear any existing error
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual ~shared_object() {
|
||||||
|
dlclose(handle_);
|
||||||
|
}
|
||||||
|
|
||||||
|
void *get_symbol(const char *symbol) {
|
||||||
|
void *sym = dlsym(handle_, symbol);
|
||||||
|
|
||||||
|
char *error = dlerror();
|
||||||
|
if (error)
|
||||||
|
throw runtime_error(error);
|
||||||
|
|
||||||
|
return sym;
|
||||||
|
}
|
||||||
|
|
||||||
|
void *handle_;
|
||||||
|
};
|
||||||
|
|
||||||
|
class shared_emitter : public emitter {
|
||||||
|
public:
|
||||||
|
shared_emitter(const char *shared_lib, ostream &out): sobj_(shared_lib) {
|
||||||
|
emitter::ptr (*create_fn)(ostream &out);
|
||||||
|
create_fn = reinterpret_cast<emitter::ptr (*)(ostream &)>(
|
||||||
|
sobj_.get_symbol("create_emitter"));
|
||||||
|
inner_ = create_fn(out);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual ~shared_emitter() {
|
||||||
|
}
|
||||||
|
|
||||||
|
void begin_superblock(std::string const &uuid,
|
||||||
|
uint64_t time,
|
||||||
|
uint64_t trans_id,
|
||||||
|
boost::optional<uint32_t> flags,
|
||||||
|
boost::optional<uint32_t> version,
|
||||||
|
uint32_t data_block_size,
|
||||||
|
uint64_t nr_data_blocks,
|
||||||
|
boost::optional<uint64_t> metadata_snap) {
|
||||||
|
inner_->begin_superblock(uuid,
|
||||||
|
time,
|
||||||
|
trans_id,
|
||||||
|
flags,
|
||||||
|
version,
|
||||||
|
data_block_size,
|
||||||
|
nr_data_blocks,
|
||||||
|
metadata_snap);
|
||||||
|
}
|
||||||
|
|
||||||
|
void end_superblock() {
|
||||||
|
inner_->end_superblock();
|
||||||
|
}
|
||||||
|
|
||||||
|
void begin_device(uint32_t dev_id,
|
||||||
|
uint64_t mapped_blocks,
|
||||||
|
uint64_t trans_id,
|
||||||
|
uint64_t creation_time,
|
||||||
|
uint64_t snap_time) {
|
||||||
|
inner_->begin_device(dev_id, mapped_blocks, trans_id, creation_time, snap_time);
|
||||||
|
}
|
||||||
|
|
||||||
|
void end_device() {
|
||||||
|
inner_->end_device();
|
||||||
|
}
|
||||||
|
|
||||||
|
void begin_named_mapping(std::string const &name) {
|
||||||
|
inner_->begin_named_mapping(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
void end_named_mapping() {
|
||||||
|
inner_->end_named_mapping();
|
||||||
|
}
|
||||||
|
|
||||||
|
void identifier(std::string const &name) {
|
||||||
|
inner_->identifier(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
void range_map(uint64_t origin_begin, uint64_t data_begin, uint32_t time, uint64_t len) {
|
||||||
|
inner_->range_map(origin_begin, data_begin, time, len);
|
||||||
|
}
|
||||||
|
|
||||||
|
void single_map(uint64_t origin_block, uint64_t data_block, uint32_t time) {
|
||||||
|
inner_->single_map(origin_block, data_block, time);
|
||||||
|
}
|
||||||
|
|
||||||
|
shared_object sobj_;
|
||||||
|
emitter::ptr inner_;
|
||||||
|
};
|
||||||
|
|
||||||
|
//----------------------------------------------------------------
|
||||||
|
|
||||||
emitter::ptr
|
emitter::ptr
|
||||||
thin_provisioning::create_custom_emitter(string const &shared_lib, ostream &out)
|
thin_provisioning::create_custom_emitter(string const &shared_lib, ostream &out)
|
||||||
{
|
{
|
||||||
emitter::ptr (*create_fn)(ostream &out);
|
return emitter::ptr(new shared_emitter(shared_lib.c_str(), out));
|
||||||
void *handle = dlopen(shared_lib.c_str(), RTLD_LAZY);
|
|
||||||
if (!handle)
|
|
||||||
throw runtime_error(dlerror());
|
|
||||||
|
|
||||||
dlerror(); // Clear any existing error
|
|
||||||
create_fn = reinterpret_cast<emitter::ptr (*)(ostream &)>(dlsym(handle, "create_emitter"));
|
|
||||||
|
|
||||||
char *error = dlerror();
|
|
||||||
if (error)
|
|
||||||
throw runtime_error(error);
|
|
||||||
|
|
||||||
return create_fn(out);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------
|
//----------------------------------------------------------------
|
||||||
|
@ -214,7 +214,9 @@ namespace {
|
|||||||
class simple_emitter : public diff_emitter {
|
class simple_emitter : public diff_emitter {
|
||||||
public:
|
public:
|
||||||
simple_emitter(indented_stream &out)
|
simple_emitter(indented_stream &out)
|
||||||
: diff_emitter(out) {
|
: diff_emitter(out),
|
||||||
|
vbegin_(0),
|
||||||
|
vend_(0) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void left_only(uint64_t vbegin, uint64_t dbegin, uint64_t len) {
|
void left_only(uint64_t vbegin, uint64_t dbegin, uint64_t len) {
|
||||||
|
@ -143,7 +143,6 @@ thin_dump_cmd::run(int argc, char **argv)
|
|||||||
int c;
|
int c;
|
||||||
char const *output = NULL;
|
char const *output = NULL;
|
||||||
const char shortopts[] = "hm::o:f:rV";
|
const char shortopts[] = "hm::o:f:rV";
|
||||||
char *end_ptr;
|
|
||||||
block_address metadata_snap = 0;
|
block_address metadata_snap = 0;
|
||||||
::uint64_t dev_id;
|
::uint64_t dev_id;
|
||||||
struct flags flags;
|
struct flags flags;
|
||||||
@ -181,13 +180,7 @@ thin_dump_cmd::run(int argc, char **argv)
|
|||||||
flags.use_metadata_snap = true;
|
flags.use_metadata_snap = true;
|
||||||
if (optarg) {
|
if (optarg) {
|
||||||
// FIXME: deprecate this option
|
// FIXME: deprecate this option
|
||||||
metadata_snap = strtoull(optarg, &end_ptr, 10);
|
metadata_snap = parse_uint64(optarg, "metadata-snap");
|
||||||
if (end_ptr == optarg) {
|
|
||||||
cerr << "couldn't parse <metadata-snap>" << endl;
|
|
||||||
usage(cerr);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
flags.snap_location = metadata_snap;
|
flags.snap_location = metadata_snap;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -197,12 +190,7 @@ thin_dump_cmd::run(int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 1:
|
case 1:
|
||||||
dev_id = strtoull(optarg, &end_ptr, 10);
|
dev_id = parse_uint64(optarg, "dev-id");
|
||||||
if (end_ptr == optarg) {
|
|
||||||
cerr << "couldn't parse <dev-id>\n";
|
|
||||||
usage(cerr);
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
flags.opts.select_dev(dev_id);
|
flags.opts.select_dev(dev_id);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -192,9 +192,13 @@ static void printf_aligned(struct global *g, char const *a, char const *b, char
|
|||||||
{
|
{
|
||||||
char buf[80];
|
char buf[80];
|
||||||
|
|
||||||
strcpy(buf, b);
|
if (units) {
|
||||||
if (units)
|
char left_bracket = mandatory ? '{' : '[';
|
||||||
strcat(buf, mandatory ? "{" :"["), strcat(buf, g->unit.chars), strcat(buf, mandatory ? "}" : "]");
|
char right_bracket = mandatory ? '}' : ']';
|
||||||
|
snprintf(buf, 80, "%s%c%s%c", b, left_bracket, g->unit.chars, right_bracket);
|
||||||
|
} else {
|
||||||
|
snprintf(buf, 80, "%s", b);
|
||||||
|
}
|
||||||
|
|
||||||
printf("\t%-4s%-44s%s\n", a, buf, c);
|
printf("\t%-4s%-44s%s\n", a, buf, c);
|
||||||
}
|
}
|
||||||
|
@ -56,7 +56,7 @@ using namespace thin_provisioning;
|
|||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
bool factor_of(block_address f, block_address n) {
|
bool factor_of(block_address f, block_address n) {
|
||||||
return (n % f) == 0;
|
return f && (n % f) == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint64_t parse_int(string const &str, string const &desc) {
|
uint64_t parse_int(string const &str, string const &desc) {
|
||||||
@ -132,11 +132,15 @@ namespace {
|
|||||||
class duplicate_detector {
|
class duplicate_detector {
|
||||||
public:
|
public:
|
||||||
void scan_with_variable_sized_chunks(chunk_stream &stream) {
|
void scan_with_variable_sized_chunks(chunk_stream &stream) {
|
||||||
|
if (!stream.size())
|
||||||
|
return;
|
||||||
variable_chunk_stream vstream(stream, 4096);
|
variable_chunk_stream vstream(stream, 4096);
|
||||||
scan(vstream);
|
scan(vstream);
|
||||||
}
|
}
|
||||||
|
|
||||||
void scan_with_fixed_sized_chunks(chunk_stream &stream, block_address chunk_size) {
|
void scan_with_fixed_sized_chunks(chunk_stream &stream, block_address chunk_size) {
|
||||||
|
if (!stream.size())
|
||||||
|
return;
|
||||||
fixed_chunk_stream fstream(stream, chunk_size);
|
fixed_chunk_stream fstream(stream, chunk_size);
|
||||||
scan(fstream);
|
scan(fstream);
|
||||||
}
|
}
|
||||||
@ -222,7 +226,7 @@ namespace {
|
|||||||
if (fs.content_based_chunks)
|
if (fs.content_based_chunks)
|
||||||
detector.scan_with_variable_sized_chunks(pstream);
|
detector.scan_with_variable_sized_chunks(pstream);
|
||||||
else {
|
else {
|
||||||
if (*fs.block_size) {
|
if (!!fs.block_size) {
|
||||||
if (factor_of(*fs.block_size, block_size))
|
if (factor_of(*fs.block_size, block_size))
|
||||||
block_size = *fs.block_size;
|
block_size = *fs.block_size;
|
||||||
else
|
else
|
||||||
|
@ -206,7 +206,8 @@ namespace {
|
|||||||
|
|
||||||
void run() {
|
void run() {
|
||||||
auto line_length = 80;
|
auto line_length = 80;
|
||||||
for (block_address b = 0; b < 2000; b++) {
|
block_address nr_blocks = std::min<block_address>(2000, bm_.get_nr_blocks());
|
||||||
|
for (block_address b = 0; b < nr_blocks; b++) {
|
||||||
block_manager::read_ref rr = bm_.read_lock(b);
|
block_manager::read_ref rr = bm_.read_lock(b);
|
||||||
|
|
||||||
if (!(b % line_length)) {
|
if (!(b % line_length)) {
|
||||||
|
@ -81,9 +81,9 @@ TEST_OBJECTS=$(subst .cc,.gmo,$(TEST_SOURCE))
|
|||||||
%.gmo: %.cc
|
%.gmo: %.cc
|
||||||
@echo " [CXX] $<"
|
@echo " [CXX] $<"
|
||||||
@mkdir -p $(dir $@)
|
@mkdir -p $(dir $@)
|
||||||
$(V) $(CXX) -c $(TEST_INCLUDES) $(CPPFLAGS) $(GMOCK_INCLUDES) $(CXXFLAGS) $(GMOCK_FLAGS) -o $@ $<
|
$(V) $(CXX) -c $(CPPFLAGS) $(GMOCK_INCLUDES) $(CXXFLAGS) $(GMOCK_FLAGS) -o $@ $<
|
||||||
@echo " [DEP] $<"
|
@echo " [DEP] $<"
|
||||||
$(V) $(CXX) -MM -MT $(subst .cc,.o,$<) $(TEST_INCLUDES) $(CPPFLAGS) $(GMOCK_INCLUDES) $(CXXFLAGS) $(GMOCK_FLAGS) $< > $*.$$$$; \
|
$(V) $(CXX) -MM -MT $(subst .cc,.o,$<) $(CPPFLAGS) $(GMOCK_INCLUDES) $(CXXFLAGS) $(GMOCK_FLAGS) $< > $*.$$$$; \
|
||||||
sed 's,\([^ :]*\)\.o[ :]*,\1.o \1.gmo $* : Makefile ,g' < $*.$$$$ > $*.d; \
|
sed 's,\([^ :]*\)\.o[ :]*,\1.o \1.gmo $* : Makefile ,g' < $*.$$$$ > $*.d; \
|
||||||
$(RM) $*.$$$$
|
$(RM) $*.$$$$
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user