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:
parent
9e82540901
commit
ffc3c62ca2
@ -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;
|
||||||
|
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user