Blob DB: Initialize all fields in Blob Header, Footer and Record structs

Summary:
Fixing un-itializations caught by valgrind.
Closes https://github.com/facebook/rocksdb/pull/3103

Differential Revision: D6200195

Pulled By: sagar0

fbshipit-source-id: bf35a3fb03eb1d308e4c5ce30dee1e345d7b03b3
This commit is contained in:
Sagar Vemuri 2017-10-31 16:27:22 -07:00 committed by Yi Wu
parent 9e82540901
commit ffc3c62ca2
2 changed files with 18 additions and 13 deletions

View File

@ -552,6 +552,8 @@ std::shared_ptr<BlobFile> BlobDBImpl::SelectBlobFile() {
bfile->file_size_ = BlobLogHeader::kSize; bfile->file_size_ = BlobLogHeader::kSize;
bfile->header_.compression = bdb_options_.compression; bfile->header_.compression = bdb_options_.compression;
bfile->header_.has_ttl = false; bfile->header_.has_ttl = false;
bfile->header_.column_family_id =
reinterpret_cast<ColumnFamilyHandleImpl*>(DefaultColumnFamily())->GetID();
bfile->header_valid_ = true; bfile->header_valid_ = true;
bfile->SetHasTTL(false); bfile->SetHasTTL(false);
@ -615,6 +617,9 @@ std::shared_ptr<BlobFile> BlobDBImpl::SelectBlobFileTTL(uint64_t expiration) {
bfile->header_.expiration_range = expiration_range; bfile->header_.expiration_range = expiration_range;
bfile->header_.compression = bdb_options_.compression; bfile->header_.compression = bdb_options_.compression;
bfile->header_.has_ttl = true; bfile->header_.has_ttl = true;
bfile->header_.column_family_id =
reinterpret_cast<ColumnFamilyHandleImpl*>(DefaultColumnFamily())->GetID();
;
bfile->header_valid_ = true; bfile->header_valid_ = true;
bfile->SetHasTTL(true); bfile->SetHasTTL(true);
bfile->file_size_ = BlobLogHeader::kSize; bfile->file_size_ = BlobLogHeader::kSize;

View File

@ -43,10 +43,10 @@ struct BlobLogHeader {
static constexpr size_t kSize = 30; static constexpr size_t kSize = 30;
uint32_t version = kVersion1; uint32_t version = kVersion1;
uint32_t column_family_id; uint32_t column_family_id = 0;
CompressionType compression; CompressionType compression = kNoCompression;
bool has_ttl; bool has_ttl = false;
ExpirationRange expiration_range; ExpirationRange expiration_range = std::make_pair(0, 0);
void EncodeTo(std::string* dst); void EncodeTo(std::string* dst);
@ -68,10 +68,10 @@ struct BlobLogHeader {
struct BlobLogFooter { struct BlobLogFooter {
static constexpr size_t kSize = 48; static constexpr size_t kSize = 48;
uint64_t blob_count; uint64_t blob_count = 0;
ExpirationRange expiration_range; ExpirationRange expiration_range = std::make_pair(0, 0);
SequenceRange sequence_range; SequenceRange sequence_range = std::make_pair(0, 0);
uint32_t crc; uint32_t crc = 0;
void EncodeTo(std::string* dst); void EncodeTo(std::string* dst);
@ -101,11 +101,11 @@ struct BlobLogRecord {
// header include fields up to blob CRC // header include fields up to blob CRC
static constexpr size_t kHeaderSize = 32; static constexpr size_t kHeaderSize = 32;
uint64_t key_size; uint64_t key_size = 0;
uint64_t value_size; uint64_t value_size = 0;
uint64_t expiration; uint64_t expiration = 0;
uint32_t header_crc; uint32_t header_crc = 0;
uint32_t blob_crc; uint32_t blob_crc = 0;
Slice key; Slice key;
Slice value; Slice value;
std::string key_buf; std::string key_buf;