@ -780,49 +780,25 @@ Status BlockBasedTable::Open(const ImmutableCFOptions& ioptions, 
			
		
	
		
		
			
				
					
					                             TailPrefetchStats *  tail_prefetch_stats )  {                               TailPrefetchStats *  tail_prefetch_stats )  {   
			
		
	
		
		
			
				
					
					  table_reader - > reset ( ) ;    table_reader - > reset ( ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  Status  s ;   
			
		
	
		
		
			
				
					
					  Footer  footer ;    Footer  footer ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  std : : unique_ptr < FilePrefetchBuffer >  prefetch_buffer ;    std : : unique_ptr < FilePrefetchBuffer >  prefetch_buffer ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // prefetch both index and filters, down to all partitions
    // prefetch both index and filters, down to all partitions
   
			
		
	
		
		
			
				
					
					  const  bool  prefetch_all  =  prefetch_index_and_filter_in_cache  | |  level  = =  0 ;    const  bool  prefetch_all  =  prefetch_index_and_filter_in_cache  | |  level  = =  0 ;   
			
		
	
		
		
			
				
					
					  const  bool  preload_all  =  ! table_options . cache_index_and_filter_blocks ;    const  bool  preload_all  =  ! table_options . cache_index_and_filter_blocks ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  size_t  tail_prefetch_size  =  0 ;    s  =  PrefetchTail ( file . get ( ) ,  file_size ,  tail_prefetch_stats ,  prefetch_all ,   
			
				
				
			
		
	
		
		
			
				
					
					  if  ( tail_prefetch_stats  ! =  nullptr )  {                     preload_all ,  & prefetch_buffer ) ;   
			
				
				
			
		
	
		
		
			
				
					
					    // Multiple threads may get a 0 (no history) when running in parallel,
  
 
			
				
				
			
		
	
		
		
			
				
					
					    // but it will get cleared after the first of them finishes.
    // Read in the following order:
   
			
				
				
			
		
	
		
		
			
				
					
					    tail_prefetch_size  =  tail_prefetch_stats - > GetSuggestedPrefetchSize ( ) ;    //    1. Footer
   
			
				
				
			
		
	
		
		
			
				
					
					  }    //    2. [metaindex block]
   
			
				
				
			
		
	
		
		
			
				
					
					  if  ( tail_prefetch_size  = =  0 )  {    //    3. [meta block: properties]
   
			
				
				
			
		
	
		
		
			
				
					
					    // Before read footer, readahead backwards to prefetch data. Do more
    //    4. [meta block: range deletion tombstone]
   
			
				
				
			
		
	
		
		
			
				
					
					    // readahead if we're going to read index/filter.
    //    5. [meta block: compression dictionary]
   
			
				
				
			
		
	
		
		
			
				
					
					    // TODO: This may incorrectly select small readahead in case partitioned
    //    6. [meta block: index]
   
			
				
				
			
		
	
		
		
			
				
					
					    // index/filter is enabled and top-level partition pinning is enabled.
    //    7. [meta block: filter]
   
			
				
				
			
		
	
		
		
			
				
					
					    // That's because we need to issue readahead before we read the properties,
   
			
		
	
		
		
			
				
					
					    // at which point we don't yet know the index type.
   
			
		
	
		
		
			
				
					
					    tail_prefetch_size  =  prefetch_all  | |  preload_all  ?  512  *  1024  :  4  *  1024 ;   
			
		
	
		
		
			
				
					
					  }   
			
		
	
		
		
			
				
					
					  size_t  prefetch_off ;   
			
		
	
		
		
			
				
					
					  size_t  prefetch_len ;   
			
		
	
		
		
			
				
					
					  if  ( file_size  <  tail_prefetch_size )  {   
			
		
	
		
		
			
				
					
					    prefetch_off  =  0 ;   
			
		
	
		
		
			
				
					
					    prefetch_len  =  static_cast < size_t > ( file_size ) ;   
			
		
	
		
		
			
				
					
					  }  else  {   
			
		
	
		
		
			
				
					
					    prefetch_off  =  static_cast < size_t > ( file_size  -  tail_prefetch_size ) ;   
			
		
	
		
		
			
				
					
					    prefetch_len  =  tail_prefetch_size ;   
			
		
	
		
		
			
				
					
					  }   
			
		
	
		
		
			
				
					
					  TEST_SYNC_POINT_CALLBACK ( " BlockBasedTable::Open::TailPrefetchLen " ,   
			
		
	
		
		
			
				
					
					                           & tail_prefetch_size ) ;   
			
		
	
		
		
			
				
					
					  Status  s ;   
			
		
	
		
		
			
				
					
					  // TODO should not have this special logic in the future.
   
			
		
	
		
		
			
				
					
					  if  ( ! file - > use_direct_io ( ) )  {   
			
		
	
		
		
			
				
					
					    prefetch_buffer . reset ( new  FilePrefetchBuffer ( nullptr ,  0 ,  0 ,  false ,  true ) ) ;   
			
		
	
		
		
			
				
					
					    s  =  file - > Prefetch ( prefetch_off ,  prefetch_len ) ;   
			
		
	
		
		
			
				
					
					  }  else  {   
			
		
	
		
		
			
				
					
					    prefetch_buffer . reset ( new  FilePrefetchBuffer ( nullptr ,  0 ,  0 ,  true ,  true ) ) ;   
			
		
	
		
		
			
				
					
					    s  =  prefetch_buffer - > Prefetch ( file . get ( ) ,  prefetch_off ,  prefetch_len ) ;   
			
		
	
		
		
			
				
					
					  }   
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					  s  =  ReadFooterFromFile ( file . get ( ) ,  prefetch_buffer . get ( ) ,  file_size ,  & footer ,    s  =  ReadFooterFromFile ( file . get ( ) ,  prefetch_buffer . get ( ) ,  file_size ,  & footer ,   
			
		
	
		
		
			
				
					
					                         kBlockBasedTableMagicNumber ) ;                           kBlockBasedTableMagicNumber ) ;   
			
		
	
		
		
			
				
					
					  if  ( ! s . ok ( ) )  {    if  ( ! s . ok ( ) )  {   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -867,38 +843,85 @@ Status BlockBasedTable::Open(const ImmutableCFOptions& ioptions, 
			
		
	
		
		
			
				
					
					    return  s ;      return  s ;   
			
		
	
		
		
			
				
					
					  }    }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // Find filter handle and filter type
    s  =  ReadPropertiesBlock ( rep ,  prefetch_buffer . get ( ) ,  meta_iter . get ( ) ,   
			
				
				
			
		
	
		
		
			
				
					
					  if  ( rep - > filter_policy )  {                            largest_seqno ) ;   
			
				
				
			
		
	
		
		
			
				
					
					    for  ( auto  filter_type  :    if  ( ! s . ok ( ) )  {   
			
				
				
			
		
	
		
		
			
				
					
					         { Rep : : FilterType : : kFullFilter ,  Rep : : FilterType : : kPartitionedFilter ,      return  s ;   
			
				
				
			
		
	
		
		
			
				
					
					          Rep : : FilterType : : kBlockFilter } )  {   
			
		
	
		
		
			
				
					
					      std : : string  prefix ;   
			
		
	
		
		
			
				
					
					      switch  ( filter_type )  {   
			
		
	
		
		
			
				
					
					        case  Rep : : FilterType : : kFullFilter :   
			
		
	
		
		
			
				
					
					          prefix  =  kFullFilterBlockPrefix ;   
			
		
	
		
		
			
				
					
					          break ;   
			
		
	
		
		
			
				
					
					        case  Rep : : FilterType : : kPartitionedFilter :   
			
		
	
		
		
			
				
					
					          prefix  =  kPartitionedFilterBlockPrefix ;   
			
		
	
		
		
			
				
					
					          break ;   
			
		
	
		
		
			
				
					
					        case  Rep : : FilterType : : kBlockFilter :   
			
		
	
		
		
			
				
					
					          prefix  =  kFilterBlockPrefix ;   
			
		
	
		
		
			
				
					
					          break ;   
			
		
	
		
		
			
				
					
					        default :   
			
		
	
		
		
			
				
					
					          assert ( 0 ) ;   
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					  }    }   
			
		
	
		
		
			
				
					
					      std : : string  filter_block_key  =  prefix ;    // Disregard return status of ReadRangeDelBlock and ReadCompressionDictBlock.
   
			
				
				
			
		
	
		
		
			
				
					
					      filter_block_key . append ( rep - > filter_policy - > Name ( ) ) ;    s  =  ReadRangeDelBlock ( rep ,  prefetch_buffer . get ( ) ,  meta_iter . get ( ) ,   
			
				
				
			
		
	
		
		
			
				
					
					      if  ( FindMetaBlock ( meta_iter . get ( ) ,  filter_block_key ,  & rep - > filter_handle )                          new_table . get ( ) ,  internal_comparator ) ;   
			
				
				
			
		
	
		
		
			
				
					
					              . ok ( ) )  {    s  =  ReadCompressionDictBlock ( rep ,  prefetch_buffer . get ( ) ,  meta_iter . get ( ) ) ;   
			
				
				
			
		
	
		
		
			
				
					
					        rep - > filter_type  =  filter_type ;  
 
			
				
				
			
		
	
		
		
			
				
					
					        break ;    s  =  PrefetchIndexAndFilterBlocks ( rep ,  prefetch_buffer . get ( ) ,  meta_iter . get ( ) ,   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					                                   new_table . get ( ) ,  prefix_extractor ,   
			
		
	
		
		
			
				
					
					                                   prefetch_all ,  table_options ,  level ,   
			
		
	
		
		
			
				
					
					                                   prefetch_index_and_filter_in_cache ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  if  ( s . ok ( ) )  {   
			
		
	
		
		
			
				
					
					    // Update tail prefetch stats
   
			
		
	
		
		
			
				
					
					    assert ( prefetch_buffer . get ( )  ! =  nullptr ) ;   
			
		
	
		
		
			
				
					
					    if  ( tail_prefetch_stats  ! =  nullptr )  {   
			
		
	
		
		
			
				
					
					      assert ( prefetch_buffer - > min_offset_read ( )  <  file_size ) ;   
			
		
	
		
		
			
				
					
					      tail_prefetch_stats - > RecordEffectiveSize (   
			
		
	
		
		
			
				
					
					          static_cast < size_t > ( file_size )  -  prefetch_buffer - > min_offset_read ( ) ) ;   
			
		
	
		
		
			
				
					
					    }      }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    * table_reader  =  std : : move ( new_table ) ;   
			
		
	
		
		
			
				
					
					  }    }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  return  s ;   
			
		
	
		
		
			
				
					
					} }  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // Read the properties
  Status  BlockBasedTable : : PrefetchTail (  
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					    RandomAccessFileReader *  file ,  uint64_t  file_size ,   
			
		
	
		
		
			
				
					
					    TailPrefetchStats *  tail_prefetch_stats ,  const  bool  prefetch_all ,   
			
		
	
		
		
			
				
					
					    const  bool  preload_all ,   
			
		
	
		
		
			
				
					
					    std : : unique_ptr < FilePrefetchBuffer > *  prefetch_buffer )  {   
			
		
	
		
		
			
				
					
					  size_t  tail_prefetch_size  =  0 ;   
			
		
	
		
		
			
				
					
					  if  ( tail_prefetch_stats  ! =  nullptr )  {   
			
		
	
		
		
			
				
					
					    // Multiple threads may get a 0 (no history) when running in parallel,
   
			
		
	
		
		
			
				
					
					    // but it will get cleared after the first of them finishes.
   
			
		
	
		
		
			
				
					
					    tail_prefetch_size  =  tail_prefetch_stats - > GetSuggestedPrefetchSize ( ) ;   
			
		
	
		
		
			
				
					
					  }   
			
		
	
		
		
			
				
					
					  if  ( tail_prefetch_size  = =  0 )  {   
			
		
	
		
		
			
				
					
					    // Before read footer, readahead backwards to prefetch data. Do more
   
			
		
	
		
		
			
				
					
					    // readahead if we're going to read index/filter.
   
			
		
	
		
		
			
				
					
					    // TODO: This may incorrectly select small readahead in case partitioned
   
			
		
	
		
		
			
				
					
					    // index/filter is enabled and top-level partition pinning is enabled.
   
			
		
	
		
		
			
				
					
					    // That's because we need to issue readahead before we read the properties,
   
			
		
	
		
		
			
				
					
					    // at which point we don't yet know the index type.
   
			
		
	
		
		
			
				
					
					    tail_prefetch_size  =  prefetch_all  | |  preload_all  ?  512  *  1024  :  4  *  1024 ;   
			
		
	
		
		
			
				
					
					  }   
			
		
	
		
		
			
				
					
					  size_t  prefetch_off ;   
			
		
	
		
		
			
				
					
					  size_t  prefetch_len ;   
			
		
	
		
		
			
				
					
					  if  ( file_size  <  tail_prefetch_size )  {   
			
		
	
		
		
			
				
					
					    prefetch_off  =  0 ;   
			
		
	
		
		
			
				
					
					    prefetch_len  =  static_cast < size_t > ( file_size ) ;   
			
		
	
		
		
			
				
					
					  }  else  {   
			
		
	
		
		
			
				
					
					    prefetch_off  =  static_cast < size_t > ( file_size  -  tail_prefetch_size ) ;   
			
		
	
		
		
			
				
					
					    prefetch_len  =  tail_prefetch_size ;   
			
		
	
		
		
			
				
					
					  }   
			
		
	
		
		
			
				
					
					  TEST_SYNC_POINT_CALLBACK ( " BlockBasedTable::Open::TailPrefetchLen " ,   
			
		
	
		
		
			
				
					
					                           & tail_prefetch_size ) ;   
			
		
	
		
		
			
				
					
					  Status  s ;   
			
		
	
		
		
			
				
					
					  // TODO should not have this special logic in the future.
   
			
		
	
		
		
			
				
					
					  if  ( ! file - > use_direct_io ( ) )  {   
			
		
	
		
		
			
				
					
					    prefetch_buffer - > reset ( new  FilePrefetchBuffer ( nullptr ,  0 ,  0 ,  false ,  true ) ) ;   
			
		
	
		
		
			
				
					
					    s  =  file - > Prefetch ( prefetch_off ,  prefetch_len ) ;   
			
		
	
		
		
			
				
					
					  }  else  {   
			
		
	
		
		
			
				
					
					    prefetch_buffer - > reset ( new  FilePrefetchBuffer ( nullptr ,  0 ,  0 ,  true ,  true ) ) ;   
			
		
	
		
		
			
				
					
					    s  =  ( * prefetch_buffer ) - > Prefetch ( file ,  prefetch_off ,  prefetch_len ) ;   
			
		
	
		
		
			
				
					
					  }   
			
		
	
		
		
			
				
					
					  return  s ;   
			
		
	
		
		
			
				
					
					}  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					Status  BlockBasedTable : : ReadPropertiesBlock (  
			
		
	
		
		
			
				
					
					    Rep *  rep ,  FilePrefetchBuffer *  prefetch_buffer ,  InternalIterator *  meta_iter ,   
			
		
	
		
		
			
				
					
					    const  SequenceNumber  largest_seqno )  {   
			
		
	
		
		
			
				
					
					  bool  found_properties_block  =  true ;    bool  found_properties_block  =  true ;   
			
		
	
		
		
			
				
					
					  s  =  SeekToPropertiesBlock ( meta_iter . get ( ) ,  & found_properties_block ) ;    Status  s ;   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					  s  =  SeekToPropertiesBlock ( meta_iter ,  & found_properties_block ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  if  ( ! s . ok ( ) )  {    if  ( ! s . ok ( ) )  {   
			
		
	
		
		
			
				
					
					    ROCKS_LOG_WARN ( rep - > ioptions . info_log ,      ROCKS_LOG_WARN ( rep - > ioptions . info_log ,   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -908,9 +931,8 @@ Status BlockBasedTable::Open(const ImmutableCFOptions& ioptions, 
			
		
	
		
		
			
				
					
					    s  =  meta_iter - > status ( ) ;      s  =  meta_iter - > status ( ) ;   
			
		
	
		
		
			
				
					
					    TableProperties *  table_properties  =  nullptr ;      TableProperties *  table_properties  =  nullptr ;   
			
		
	
		
		
			
				
					
					    if  ( s . ok ( ) )  {      if  ( s . ok ( ) )  {   
			
		
	
		
		
			
				
					
					      s  =  ReadProperties ( meta_iter - > value ( ) ,  rep - > file . get ( ) ,        s  =  ReadProperties ( meta_iter - > value ( ) ,  rep - > file . get ( ) ,  prefetch_buffer ,   
			
				
				
			
		
	
		
		
			
				
					
					                         prefetch_buffer . get ( ) ,  rep - > footer ,  rep - > ioptions ,                           rep - > footer ,  rep - > ioptions ,  & table_properties ,   
			
				
				
			
		
	
		
		
			
				
					
					                         & table_properties ,   
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					                         false  /* compression_type_missing */ ,                           false  /* compression_type_missing */ ,   
			
		
	
		
		
			
				
					
					                         nullptr  /* memory_allocator */ ) ;                           nullptr  /* memory_allocator */ ) ;   
			
		
	
		
		
			
				
					
					    }      }   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -937,41 +959,6 @@ Status BlockBasedTable::Open(const ImmutableCFOptions& ioptions, 
			
		
	
		
		
			
				
					
					  }    }   
			
		
	
		
		
			
				
					
					# endif   // ROCKSDB_LITE
 # endif   // ROCKSDB_LITE
  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // Read the compression dictionary meta block
   
			
		
	
		
		
			
				
					
					  bool  found_compression_dict ;   
			
		
	
		
		
			
				
					
					  BlockHandle  compression_dict_handle ;   
			
		
	
		
		
			
				
					
					  s  =  SeekToCompressionDictBlock ( meta_iter . get ( ) ,  & found_compression_dict ,   
			
		
	
		
		
			
				
					
					    & compression_dict_handle ) ;   
			
		
	
		
		
			
				
					
					  if  ( ! s . ok ( ) )  {   
			
		
	
		
		
			
				
					
					    ROCKS_LOG_WARN (   
			
		
	
		
		
			
				
					
					        rep - > ioptions . info_log ,   
			
		
	
		
		
			
				
					
					        " Error when seeking to compression dictionary block from file: %s " ,   
			
		
	
		
		
			
				
					
					        s . ToString ( ) . c_str ( ) ) ;   
			
		
	
		
		
			
				
					
					  }  else  if  ( found_compression_dict  & &  ! compression_dict_handle . IsNull ( ) )  {   
			
		
	
		
		
			
				
					
					    // TODO(andrewkr): Add to block cache if cache_index_and_filter_blocks is
   
			
		
	
		
		
			
				
					
					    // true.
   
			
		
	
		
		
			
				
					
					    std : : unique_ptr < BlockContents >  compression_dict_cont { new  BlockContents ( ) } ;   
			
		
	
		
		
			
				
					
					    PersistentCacheOptions  cache_options ;   
			
		
	
		
		
			
				
					
					    ReadOptions  read_options ;   
			
		
	
		
		
			
				
					
					    read_options . verify_checksums  =  false ;   
			
		
	
		
		
			
				
					
					    BlockFetcher  compression_block_fetcher (   
			
		
	
		
		
			
				
					
					        rep - > file . get ( ) ,  prefetch_buffer . get ( ) ,  rep - > footer ,  read_options ,   
			
		
	
		
		
			
				
					
					        compression_dict_handle ,  compression_dict_cont . get ( ) ,  rep - > ioptions ,   
			
		
	
		
		
			
				
					
					        false  /* decompress */ ,  false  /*maybe_compressed*/ ,   
			
		
	
		
		
			
				
					
					        Slice ( )  /*compression dict*/ ,  cache_options ) ;   
			
		
	
		
		
			
				
					
					    s  =  compression_block_fetcher . ReadBlockContents ( ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    if  ( ! s . ok ( ) )  {   
			
		
	
		
		
			
				
					
					      ROCKS_LOG_WARN (   
			
		
	
		
		
			
				
					
					          rep - > ioptions . info_log ,   
			
		
	
		
		
			
				
					
					          " Encountered error while reading data from compression dictionary  "   
			
		
	
		
		
			
				
					
					          " block %s " ,   
			
		
	
		
		
			
				
					
					          s . ToString ( ) . c_str ( ) ) ;   
			
		
	
		
		
			
				
					
					    }  else  {   
			
		
	
		
		
			
				
					
					      rep - > compression_dict_block  =  std : : move ( compression_dict_cont ) ;   
			
		
	
		
		
			
				
					
					    }   
			
		
	
		
		
			
				
					
					  }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // Read the table properties, if provided.
    // Read the table properties, if provided.
   
			
		
	
		
		
			
				
					
					  if  ( rep - > table_properties )  {    if  ( rep - > table_properties )  {   
			
		
	
		
		
			
				
					
					    rep - > whole_key_filtering  & =      rep - > whole_key_filtering  & =   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -986,13 +973,18 @@ Status BlockBasedTable::Open(const ImmutableCFOptions& ioptions, 
			
		
	
		
		
			
				
					
					                                & ( rep - > global_seqno ) ) ;                                  & ( rep - > global_seqno ) ) ;   
			
		
	
		
		
			
				
					
					    if  ( ! s . ok ( ) )  {      if  ( ! s . ok ( ) )  {   
			
		
	
		
		
			
				
					
					      ROCKS_LOG_ERROR ( rep - > ioptions . info_log ,  " %s " ,  s . ToString ( ) . c_str ( ) ) ;        ROCKS_LOG_ERROR ( rep - > ioptions . info_log ,  " %s " ,  s . ToString ( ) . c_str ( ) ) ;   
			
		
	
		
		
			
				
					
					      return  s ;   
			
		
	
		
		
			
				
					
					    }      }   
			
		
	
		
		
			
				
					
					  }    }   
			
		
	
		
		
			
				
					
					  return  s ;   
			
		
	
		
		
			
				
					
					}  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // Read the range del meta block
  Status  BlockBasedTable : : ReadRangeDelBlock (  
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					    Rep *  rep ,  FilePrefetchBuffer *  prefetch_buffer ,  InternalIterator *  meta_iter ,   
			
		
	
		
		
			
				
					
					    BlockBasedTable *  new_table ,   
			
		
	
		
		
			
				
					
					    const  InternalKeyComparator &  internal_comparator )  {   
			
		
	
		
		
			
				
					
					  Status  s ;   
			
		
	
		
		
			
				
					
					  bool  found_range_del_block ;    bool  found_range_del_block ;   
			
		
	
		
		
			
				
					
					  s  =  SeekToRangeDelBlock ( meta_iter . get ( ) ,  & found_range_del_block ,    s  =  SeekToRangeDelBlock ( meta_iter ,  & found_range_del_block ,   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					                          & rep - > range_del_handle ) ;                            & rep - > range_del_handle ) ;   
			
		
	
		
		
			
				
					
					  if  ( ! s . ok ( ) )  {    if  ( ! s . ok ( ) )  {   
			
		
	
		
		
			
				
					
					    ROCKS_LOG_WARN (      ROCKS_LOG_WARN (   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1002,7 +994,7 @@ Status BlockBasedTable::Open(const ImmutableCFOptions& ioptions, 
			
		
	
		
		
			
				
					
					  }  else  if  ( found_range_del_block  & &  ! rep - > range_del_handle . IsNull ( ) )  {    }  else  if  ( found_range_del_block  & &  ! rep - > range_del_handle . IsNull ( ) )  {   
			
		
	
		
		
			
				
					
					    ReadOptions  read_options ;      ReadOptions  read_options ;   
			
		
	
		
		
			
				
					
					    s  =  MaybeReadBlockAndLoadToCache (      s  =  MaybeReadBlockAndLoadToCache (   
			
		
	
		
		
			
				
					
					        prefetch_buffer . get ( ) ,  rep ,  read_options ,  rep - > range_del_handle ,          prefetch_buffer ,  rep ,  read_options ,  rep - > range_del_handle ,   
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					        Slice ( )  /* compression_dict */ ,  & rep - > range_del_entry ,          Slice ( )  /* compression_dict */ ,  & rep - > range_del_entry ,   
			
		
	
		
		
			
				
					
					        false  /* is_index */ ,  nullptr  /* get_context */ ) ;          false  /* is_index */ ,  nullptr  /* get_context */ ) ;   
			
		
	
		
		
			
				
					
					    if  ( ! s . ok ( ) )  {      if  ( ! s . ok ( ) )  {   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1016,6 +1008,84 @@ Status BlockBasedTable::Open(const ImmutableCFOptions& ioptions, 
			
		
	
		
		
			
				
					
					    rep - > fragmented_range_dels  =  std : : make_shared < FragmentedRangeTombstoneList > (      rep - > fragmented_range_dels  =  std : : make_shared < FragmentedRangeTombstoneList > (   
			
		
	
		
		
			
				
					
					        std : : move ( iter ) ,  internal_comparator ) ;          std : : move ( iter ) ,  internal_comparator ) ;   
			
		
	
		
		
			
				
					
					  }    }   
			
		
	
		
		
			
				
					
					  return  s ;   
			
		
	
		
		
			
				
					
					}  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					Status  BlockBasedTable : : ReadCompressionDictBlock (  
			
		
	
		
		
			
				
					
					    Rep *  rep ,  FilePrefetchBuffer *  prefetch_buffer ,   
			
		
	
		
		
			
				
					
					    InternalIterator *  meta_iter )  {   
			
		
	
		
		
			
				
					
					  Status  s ;   
			
		
	
		
		
			
				
					
					  bool  found_compression_dict ;   
			
		
	
		
		
			
				
					
					  BlockHandle  compression_dict_handle ;   
			
		
	
		
		
			
				
					
					  s  =  SeekToCompressionDictBlock ( meta_iter ,  & found_compression_dict ,   
			
		
	
		
		
			
				
					
					                                 & compression_dict_handle ) ;   
			
		
	
		
		
			
				
					
					  if  ( ! s . ok ( ) )  {   
			
		
	
		
		
			
				
					
					    ROCKS_LOG_WARN (   
			
		
	
		
		
			
				
					
					        rep - > ioptions . info_log ,   
			
		
	
		
		
			
				
					
					        " Error when seeking to compression dictionary block from file: %s " ,   
			
		
	
		
		
			
				
					
					        s . ToString ( ) . c_str ( ) ) ;   
			
		
	
		
		
			
				
					
					  }  else  if  ( found_compression_dict  & &  ! compression_dict_handle . IsNull ( ) )  {   
			
		
	
		
		
			
				
					
					    // TODO(andrewkr): Add to block cache if cache_index_and_filter_blocks is
   
			
		
	
		
		
			
				
					
					    // true.
   
			
		
	
		
		
			
				
					
					    std : : unique_ptr < BlockContents >  compression_dict_cont { new  BlockContents ( ) } ;   
			
		
	
		
		
			
				
					
					    PersistentCacheOptions  cache_options ;   
			
		
	
		
		
			
				
					
					    ReadOptions  read_options ;   
			
		
	
		
		
			
				
					
					    read_options . verify_checksums  =  false ;   
			
		
	
		
		
			
				
					
					    BlockFetcher  compression_block_fetcher (   
			
		
	
		
		
			
				
					
					        rep - > file . get ( ) ,  prefetch_buffer ,  rep - > footer ,  read_options ,   
			
		
	
		
		
			
				
					
					        compression_dict_handle ,  compression_dict_cont . get ( ) ,  rep - > ioptions ,   
			
		
	
		
		
			
				
					
					        false  /* decompress */ ,  false  /*maybe_compressed*/ ,   
			
		
	
		
		
			
				
					
					        Slice ( )  /*compression dict*/ ,  cache_options ) ;   
			
		
	
		
		
			
				
					
					    s  =  compression_block_fetcher . ReadBlockContents ( ) ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					    if  ( ! s . ok ( ) )  {   
			
		
	
		
		
			
				
					
					      ROCKS_LOG_WARN (   
			
		
	
		
		
			
				
					
					          rep - > ioptions . info_log ,   
			
		
	
		
		
			
				
					
					          " Encountered error while reading data from compression dictionary  "   
			
		
	
		
		
			
				
					
					          " block %s " ,   
			
		
	
		
		
			
				
					
					          s . ToString ( ) . c_str ( ) ) ;   
			
		
	
		
		
			
				
					
					    }  else  {   
			
		
	
		
		
			
				
					
					      rep - > compression_dict_block  =  std : : move ( compression_dict_cont ) ;   
			
		
	
		
		
			
				
					
					    }   
			
		
	
		
		
			
				
					
					  }   
			
		
	
		
		
			
				
					
					  return  s ;   
			
		
	
		
		
			
				
					
					}  
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					Status  BlockBasedTable : : PrefetchIndexAndFilterBlocks (  
			
		
	
		
		
			
				
					
					    Rep *  rep ,  FilePrefetchBuffer *  prefetch_buffer ,  InternalIterator *  meta_iter ,   
			
		
	
		
		
			
				
					
					    BlockBasedTable *  new_table ,  const  SliceTransform *  prefix_extractor ,   
			
		
	
		
		
			
				
					
					    bool  prefetch_all ,  const  BlockBasedTableOptions &  table_options ,   
			
		
	
		
		
			
				
					
					    const  int  level ,  const  bool  prefetch_index_and_filter_in_cache )  {   
			
		
	
		
		
			
				
					
					  Status  s ;   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  // Find filter handle and filter type
   
			
		
	
		
		
			
				
					
					  if  ( rep - > filter_policy )  {   
			
		
	
		
		
			
				
					
					    for  ( auto  filter_type  :   
			
		
	
		
		
			
				
					
					         { Rep : : FilterType : : kFullFilter ,  Rep : : FilterType : : kPartitionedFilter ,   
			
		
	
		
		
			
				
					
					          Rep : : FilterType : : kBlockFilter } )  {   
			
		
	
		
		
			
				
					
					      std : : string  prefix ;   
			
		
	
		
		
			
				
					
					      switch  ( filter_type )  {   
			
		
	
		
		
			
				
					
					        case  Rep : : FilterType : : kFullFilter :   
			
		
	
		
		
			
				
					
					          prefix  =  kFullFilterBlockPrefix ;   
			
		
	
		
		
			
				
					
					          break ;   
			
		
	
		
		
			
				
					
					        case  Rep : : FilterType : : kPartitionedFilter :   
			
		
	
		
		
			
				
					
					          prefix  =  kPartitionedFilterBlockPrefix ;   
			
		
	
		
		
			
				
					
					          break ;   
			
		
	
		
		
			
				
					
					        case  Rep : : FilterType : : kBlockFilter :   
			
		
	
		
		
			
				
					
					          prefix  =  kFilterBlockPrefix ;   
			
		
	
		
		
			
				
					
					          break ;   
			
		
	
		
		
			
				
					
					        default :   
			
		
	
		
		
			
				
					
					          assert ( 0 ) ;   
			
		
	
		
		
			
				
					
					      }   
			
		
	
		
		
			
				
					
					      std : : string  filter_block_key  =  prefix ;   
			
		
	
		
		
			
				
					
					      filter_block_key . append ( rep - > filter_policy - > Name ( ) ) ;   
			
		
	
		
		
			
				
					
					      if  ( FindMetaBlock ( meta_iter ,  filter_block_key ,  & rep - > filter_handle )   
			
		
	
		
		
			
				
					
					              . ok ( ) )  {   
			
		
	
		
		
			
				
					
					        rep - > filter_type  =  filter_type ;   
			
		
	
		
		
			
				
					
					        break ;   
			
		
	
		
		
			
				
					
					      }   
			
		
	
		
		
			
				
					
					    }   
			
		
	
		
		
			
				
					
					  }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  bool  need_upper_bound_check  =    bool  need_upper_bound_check  =   
			
		
	
		
		
			
				
					
					      PrefixExtractorChanged ( rep - > table_properties . get ( ) ,  prefix_extractor ) ;        PrefixExtractorChanged ( rep - > table_properties . get ( ) ,  prefix_extractor ) ;   
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -1097,8 +1167,8 @@ Status BlockBasedTable::Open(const ImmutableCFOptions& ioptions, 
			
		
	
		
		
			
				
					
					    // pre-load these blocks, which will kept in member variables in Rep
      // pre-load these blocks, which will kept in member variables in Rep
   
			
		
	
		
		
			
				
					
					    // and with a same life-time as this table object.
      // and with a same life-time as this table object.
   
			
		
	
		
		
			
				
					
					    IndexReader *  index_reader  =  nullptr ;      IndexReader *  index_reader  =  nullptr ;   
			
		
	
		
		
			
				
					
					    s  =  new_table - > CreateIndexReader ( prefetch_buffer . get ( ) ,  & index_reader ,      s  =  new_table - > CreateIndexReader ( prefetch_buffer ,  & index_reader ,  meta_it er ,   
			
				
				
			
		
	
		
		
			
				
					
					                                     meta_iter . get ( ) ,  level ) ;                                       level ) ;   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					    if  ( s . ok ( ) )  {      if  ( s . ok ( ) )  {   
			
		
	
		
		
			
				
					
					      rep - > index_reader . reset ( index_reader ) ;        rep - > index_reader . reset ( index_reader ) ;   
			
		
	
		
		
			
				
					
					      // The partitions of partitioned index are always stored in cache. They
        // The partitions of partitioned index are always stored in cache. They
   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1111,8 +1181,8 @@ Status BlockBasedTable::Open(const ImmutableCFOptions& ioptions, 
			
		
	
		
		
			
				
					
					      // Set filter block
        // Set filter block
   
			
		
	
		
		
			
				
					
					      if  ( rep - > filter_policy )  {        if  ( rep - > filter_policy )  {   
			
		
	
		
		
			
				
					
					        const  bool  is_a_filter_partition  =  true ;          const  bool  is_a_filter_partition  =  true ;   
			
		
	
		
		
			
				
					
					        auto  filter  =  new_table - > ReadFilter (          auto  filter  =  new_table - > ReadFilter ( prefetch_buffer ,  rep - > filter_handle ,   
			
				
				
			
		
	
		
		
			
				
					
					            prefetch_buffer . get ( ) ,  rep - > filter_handle , ! is_a_filter_partition ,                                               ! is_a_filter_partition ,   
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					                                            rep - > table_prefix_extractor . get ( ) ) ;                                              rep - > table_prefix_extractor . get ( ) ) ;   
			
		
	
		
		
			
				
					
					        rep - > filter . reset ( filter ) ;          rep - > filter . reset ( filter ) ;   
			
		
	
		
		
			
				
					
					        // Refer to the comment above about paritioned indexes always being
          // Refer to the comment above about paritioned indexes always being
   
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -1126,16 +1196,6 @@ Status BlockBasedTable::Open(const ImmutableCFOptions& ioptions, 
			
		
	
		
		
			
				
					
					    }      }   
			
		
	
		
		
			
				
					
					  }    }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  if  ( s . ok ( ) )  {   
			
		
	
		
		
			
				
					
					    assert ( prefetch_buffer . get ( )  ! =  nullptr ) ;   
			
		
	
		
		
			
				
					
					    if  ( tail_prefetch_stats  ! =  nullptr )  {   
			
		
	
		
		
			
				
					
					      assert ( prefetch_buffer - > min_offset_read ( )  <  file_size ) ;   
			
		
	
		
		
			
				
					
					      tail_prefetch_stats - > RecordEffectiveSize (   
			
		
	
		
		
			
				
					
					        static_cast < size_t > ( file_size )  -  prefetch_buffer - > min_offset_read ( ) ) ;   
			
		
	
		
		
			
				
					
					    }   
			
		
	
		
		
			
				
					
					    * table_reader  =  std : : move ( new_table ) ;   
			
		
	
		
		
			
				
					
					  }   
			
		
	
		
		
			
				
					
					
 
			
		
	
		
		
			
				
					
					  return  s ;    return  s ;   
			
		
	
		
		
			
				
					
					} }