@ -219,12 +219,12 @@ class BlockBasedTable : public TableReader {
// input_iter: if it is not null, update this one and return it as Iterator
// input_iter: if it is not null, update this one and return it as Iterator
template < typename TBlockIter >
template < typename TBlockIter >
static TBlockIter * NewDataBlockIterator (
TBlockIter * NewDataBlockIterator (
const Rep * rep , const Re adOptions & ro , const BlockHandle & block_hanlde ,
const ReadOptions & ro , const BlockHandle & block_hanlde ,
TBlockIter * input_iter = nullptr , bool is_index = false ,
TBlockIter * input_iter = nullptr , bool is_index = false ,
bool key_includes_seq = true , bool index_key_is_full = true ,
bool key_includes_seq = true , bool index_key_is_full = true ,
GetContext * get_context = nullptr , Status s = Status ( ) ,
GetContext * get_context = nullptr , Status s = Status ( ) ,
FilePrefetchBuffer * prefetch_buffer = nullptr ) ;
FilePrefetchBuffer * prefetch_buffer = nullptr ) const ;
class PartitionedIndexIteratorState ;
class PartitionedIndexIteratorState ;
@ -238,6 +238,14 @@ class BlockBasedTable : public TableReader {
friend class MockedBlockBasedTable ;
friend class MockedBlockBasedTable ;
static std : : atomic < uint64_t > next_cache_key_id_ ;
static std : : atomic < uint64_t > next_cache_key_id_ ;
Cache : : Handle * GetEntryFromCache ( Cache * block_cache , const Slice & key ,
Tickers block_cache_miss_ticker ,
Tickers block_cache_hit_ticker ,
uint64_t * block_cache_miss_stats ,
uint64_t * block_cache_hit_stats ,
Statistics * statistics ,
GetContext * get_context ) const ;
// If block cache enabled (compressed or uncompressed), looks for the block
// If block cache enabled (compressed or uncompressed), looks for the block
// identified by handle in (1) uncompressed cache, (2) compressed cache, and
// identified by handle in (1) uncompressed cache, (2) compressed cache, and
// then (3) file. If found, inserts into the cache(s) that were searched
// then (3) file. If found, inserts into the cache(s) that were searched
@ -247,22 +255,20 @@ class BlockBasedTable : public TableReader {
// @param block_entry value is set to the uncompressed block if found. If
// @param block_entry value is set to the uncompressed block if found. If
// in uncompressed block cache, also sets cache_handle to reference that
// in uncompressed block cache, also sets cache_handle to reference that
// block.
// block.
static Status MaybeReadBlockAndLoadToCache (
Status MaybeReadBlockAndLoadToCache (
FilePrefetchBuffer * prefetch_buffer , const Rep * rep ,
FilePrefetchBuffer * prefetch_buffer , const ReadOptions & ro ,
const ReadOptions & ro , const BlockHandle & handle ,
const BlockHandle & handle , const UncompressionDict & uncompression_dict ,
const UncompressionDict & uncompression_dict ,
CachableEntry < Block > * block_entry , bool is_index = false ,
CachableEntry < Block > * block_entry , bool is_index = false ,
GetContext * get_context = nullptr ) ;
GetContext * get_context = nullptr ) const ;
// Similar to the above, with one crucial difference: it will retrieve the
// Similar to the above, with one crucial difference: it will retrieve the
// block from the file even if there are no caches configured (assuming the
// block from the file even if there are no caches configured (assuming the
// read options allow I/O).
// read options allow I/O).
static Status RetrieveBlock ( FilePrefetchBuffer * prefetch_buffer ,
Status RetrieveBlock ( FilePrefetchBuffer * prefetch_buffer ,
const Rep * rep , const ReadOptions & ro ,
const ReadOptions & ro , const BlockHandle & handle ,
const BlockHandle & handle ,
const UncompressionDict & uncompression_dict ,
const UncompressionDict & uncompression_dict ,
CachableEntry < Block > * block_entry , bool is_index ,
CachableEntry < Block > * block_entry , bool is_index ,
GetContext * get_context ) ;
GetContext * get_context ) const ;
// For the following two functions:
// For the following two functions:
// if `no_io == true`, we will not try to read filter/index from sst file
// if `no_io == true`, we will not try to read filter/index from sst file
@ -276,9 +282,9 @@ class BlockBasedTable : public TableReader {
const bool is_a_filter_partition , bool no_io , GetContext * get_context ,
const bool is_a_filter_partition , bool no_io , GetContext * get_context ,
const SliceTransform * prefix_extractor = nullptr ) const ;
const SliceTransform * prefix_extractor = nullptr ) const ;
static CachableEntry < UncompressionDict > GetUncompressionDict (
CachableEntry < UncompressionDict > GetUncompressionDict (
const Rep * rep , FilePrefetchBuffer * prefetch_buffer , bool no_io ,
FilePrefetchBuffer * prefetch_buffer , bool no_io ,
GetContext * get_context ) ;
GetContext * get_context ) const ;
// Get the iterator from the index reader.
// Get the iterator from the index reader.
// If input_iter is not set, return new Iterator
// If input_iter is not set, return new Iterator
@ -301,13 +307,12 @@ class BlockBasedTable : public TableReader {
// pointer to the block as well as its block handle.
// pointer to the block as well as its block handle.
// @param uncompression_dict Data for presetting the compression library's
// @param uncompression_dict Data for presetting the compression library's
// dictionary.
// dictionary.
static Status GetDataBlockFromCache (
Status GetDataBlockFromCache (
const Slice & block_cache_key , const Slice & compressed_block_cache_key ,
const Slice & block_cache_key , const Slice & compressed_block_cache_key ,
Cache * block_cache , Cache * block_cache_compressed , const Rep * rep ,
Cache * block_cache , Cache * block_cache_compressed ,
const ReadOptions & read_options , CachableEntry < Block > * block ,
const ReadOptions & read_options , CachableEntry < Block > * block ,
const UncompressionDict & uncompression_dict ,
const UncompressionDict & uncompression_dict , bool is_index = false ,
size_t read_amp_bytes_per_bit , bool is_index = false ,
GetContext * get_context = nullptr ) const ;
GetContext * get_context = nullptr ) ;
// Put a raw block (maybe compressed) to the corresponding block caches.
// Put a raw block (maybe compressed) to the corresponding block caches.
// This method will perform decompression against raw_block if needed and then
// This method will perform decompression against raw_block if needed and then
@ -319,16 +324,16 @@ class BlockBasedTable : public TableReader {
// PutDataBlockToCache(). After the call, the object will be invalid.
// PutDataBlockToCache(). After the call, the object will be invalid.
// @param uncompression_dict Data for presetting the compression library's
// @param uncompression_dict Data for presetting the compression library's
// dictionary.
// dictionary.
static Status PutDataBlockToCache (
Status PutDataBlockToCache ( const Slice & block_cache_key ,
const Slice & block_cache_key , const Slice & compressed_block_cache_key ,
const Slice & compressed_block_cache_key ,
Cache * block_cache , Cache * block_cache_compressed ,
Cache * block_cache , Cache * block_cache_compressed ,
const ReadOptions & read_options , const ImmutableCFOptions & ioptions ,
CachableEntry < Block > * cached_block ,
CachableEntry < Block > * block , BlockContents * raw_block_contents ,
BlockContents * raw_block_contents ,
CompressionType raw_block_comp_type , uint32_t format_version ,
CompressionType raw_block_comp_type ,
const UncompressionDict & uncompression_dict , SequenceNumber seq_no ,
const UncompressionDict & uncompression_dict ,
size_t read_amp_bytes_per_bit , MemoryAllocator * memory_allocator ,
SequenceNumber seq_no ,
bool is_index = false , Cache : : Priority pri = Cache : : Priority : : LOW ,
MemoryAllocator * memory_allocator , bool is_index ,
GetContext * get_context = nullptr ) ;
GetContext * get_context ) const ;
// Calls (*handle_result)(arg, ...) repeatedly, starting with the entry found
// Calls (*handle_result)(arg, ...) repeatedly, starting with the entry found
// after a call to Seek(key), until handle_result returns false.
// after a call to Seek(key), until handle_result returns false.
@ -336,8 +341,6 @@ class BlockBasedTable : public TableReader {
friend class TableCache ;
friend class TableCache ;
friend class BlockBasedTableBuilder ;
friend class BlockBasedTableBuilder ;
void ReadMeta ( const Footer & footer ) ;
// Figure the index type, update it in rep_, and also return it.
// Figure the index type, update it in rep_, and also return it.
BlockBasedTableOptions : : IndexType UpdateIndexType ( ) ;
BlockBasedTableOptions : : IndexType UpdateIndexType ( ) ;
@ -365,28 +368,25 @@ class BlockBasedTable : public TableReader {
TailPrefetchStats * tail_prefetch_stats , const bool prefetch_all ,
TailPrefetchStats * tail_prefetch_stats , const bool prefetch_all ,
const bool preload_all ,
const bool preload_all ,
std : : unique_ptr < FilePrefetchBuffer > * prefetch_buffer ) ;
std : : unique_ptr < FilePrefetchBuffer > * prefetch_buffer ) ;
static Status ReadMetaBlock ( Rep * rep , FilePrefetchBuffer * prefetch_buffer ,
Status ReadMetaBlock ( FilePrefetchBuffer * prefetch_buffer ,
std : : unique_ptr < Block > * meta_block ,
std : : unique_ptr < Block > * meta_block ,
std : : unique_ptr < InternalIterator > * iter ) ;
std : : unique_ptr < InternalIterator > * iter ) ;
static Status TryReadPropertiesWithGlobalSeqno (
Status TryReadPropertiesWithGlobalSeqno ( FilePrefetchBuffer * prefetch_buffer ,
Rep * rep , FilePrefetchBuffer * prefetch_buffer , const Slice & handle_value ,
const Slice & handle_value ,
TableProperties * * table_properties ) ;
TableProperties * * table_properties ) ;
static Status ReadPropertiesBlock ( Rep * rep ,
Status ReadPropertiesBlock ( FilePrefetchBuffer * prefetch_buffer ,
FilePrefetchBuffer * prefetch_buffer ,
InternalIterator * meta_iter ,
InternalIterator * meta_iter ,
const SequenceNumber largest_seqno ) ;
const SequenceNumber largest_seqno ) ;
static Status ReadRangeDelBlock (
Status ReadRangeDelBlock ( FilePrefetchBuffer * prefetch_buffer ,
Rep * rep , FilePrefetchBuffer * prefetch_buffer ,
InternalIterator * meta_iter ,
InternalIterator * meta_iter ,
const InternalKeyComparator & internal_comparator ) ;
const InternalKeyComparator & internal_comparator ) ;
static Status ReadCompressionDictBlock (
Status ReadCompressionDictBlock (
const Rep * rep , FilePrefetchBuffer * prefetch_buffer ,
FilePrefetchBuffer * prefetch_buffer ,
std : : unique_ptr < const BlockContents > * compression_dict_block ) ;
std : : unique_ptr < const BlockContents > * compression_dict_block ) const ;
static Status PrefetchIndexAndFilterBlocks (
Status PrefetchIndexAndFilterBlocks (
Rep * rep , FilePrefetchBuffer * prefetch_buffer ,
FilePrefetchBuffer * prefetch_buffer , InternalIterator * meta_iter ,
InternalIterator * meta_iter , BlockBasedTable * new_table ,
BlockBasedTable * new_table , bool prefetch_all ,
bool prefetch_all , const BlockBasedTableOptions & table_options ,
const BlockBasedTableOptions & table_options , const int level ) ;
const int level ) ;
Status VerifyChecksumInMetaBlocks ( InternalIteratorBase < Slice > * index_iter ) ;
Status VerifyChecksumInMetaBlocks ( InternalIteratorBase < Slice > * index_iter ) ;
Status VerifyChecksumInBlocks ( InternalIteratorBase < BlockHandle > * index_iter ) ;
Status VerifyChecksumInBlocks ( InternalIteratorBase < BlockHandle > * index_iter ) ;