@ -499,9 +499,8 @@ class PartitionIndexReader : public BlockBasedTable::IndexReaderCommon {
uint64_t last_off = handle . offset ( ) + block_size ( handle ) ;
uint64_t last_off = handle . offset ( ) + block_size ( handle ) ;
uint64_t prefetch_len = last_off - prefetch_off ;
uint64_t prefetch_len = last_off - prefetch_off ;
std : : unique_ptr < FilePrefetchBuffer > prefetch_buffer ;
std : : unique_ptr < FilePrefetchBuffer > prefetch_buffer ;
auto & file = rep - > file ;
rep - > CreateFilePrefetchBuffer ( 0 , 0 , & prefetch_buffer ) ;
prefetch_buffer . reset ( new FilePrefetchBuffer ( ) ) ;
s = prefetch_buffer - > Prefetch ( rep - > file . get ( ) , prefetch_off ,
s = prefetch_buffer - > Prefetch ( file . get ( ) , prefetch_off ,
static_cast < size_t > ( prefetch_len ) ) ;
static_cast < size_t > ( prefetch_len ) ) ;
// After prefetch, read the partitions one by one
// After prefetch, read the partitions one by one
@ -1147,8 +1146,14 @@ Status BlockBasedTable::Open(
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 ;
if ( ! ioptions . allow_mmap_reads ) {
s = PrefetchTail ( file . get ( ) , file_size , tail_prefetch_stats , prefetch_all ,
s = PrefetchTail ( file . get ( ) , file_size , tail_prefetch_stats , prefetch_all ,
preload_all , & prefetch_buffer ) ;
preload_all , & prefetch_buffer ) ;
} else {
// Should not prefetch for mmap mode.
prefetch_buffer . reset ( new FilePrefetchBuffer (
nullptr , 0 , 0 , false /* enable */ , true /* track_min_offset */ ) ) ;
}
// Read in the following order:
// Read in the following order:
// 1. Footer
// 1. Footer
@ -1274,10 +1279,12 @@ Status BlockBasedTable::PrefetchTail(
Status s ;
Status s ;
// TODO should not have this special logic in the future.
// TODO should not have this special logic in the future.
if ( ! file - > use_direct_io ( ) ) {
if ( ! file - > use_direct_io ( ) ) {
prefetch_buffer - > reset ( new FilePrefetchBuffer ( nullptr , 0 , 0 , false , true ) ) ;
prefetch_buffer - > reset ( new FilePrefetchBuffer (
nullptr , 0 , 0 , false /* enable */ , true /* track_min_offset */ ) ) ;
s = file - > Prefetch ( prefetch_off , prefetch_len ) ;
s = file - > Prefetch ( prefetch_off , prefetch_len ) ;
} else {
} else {
prefetch_buffer - > reset ( new FilePrefetchBuffer ( nullptr , 0 , 0 , true , true ) ) ;
prefetch_buffer - > reset ( new FilePrefetchBuffer (
nullptr , 0 , 0 , true /* enable */ , true /* track_min_offset */ ) ) ;
s = ( * prefetch_buffer ) - > Prefetch ( file , prefetch_off , prefetch_len ) ;
s = ( * prefetch_buffer ) - > Prefetch ( file , prefetch_off , prefetch_len ) ;
}
}
return s ;
return s ;
@ -3016,23 +3023,23 @@ void BlockBasedTableIterator<TBlockIter, TValue>::InitDataBlock() {
} else if ( rep - > file - > use_direct_io ( ) & & ! prefetch_buffer_ ) {
} else if ( rep - > file - > use_direct_io ( ) & & ! prefetch_buffer_ ) {
// Direct I/O
// Direct I/O
// Let FilePrefetchBuffer take care of the readahead.
// Let FilePrefetchBuffer take care of the readahead.
prefetch_buffer_ . reset ( new FilePrefetchBuffer (
rep - > Create FilePrefetchBuffer(
rep - > file . get ( ) , BlockBasedTable : : kInitAutoReadaheadSize ,
BlockBasedTable : : kInitAutoReadaheadSize ,
BlockBasedTable : : kMaxAutoReadaheadSize ) ) ;
BlockBasedTable : : kMaxAutoReadaheadSize , & prefetch_buffer_ ) ;
}
}
}
}
} else if ( ! prefetch_buffer_ ) {
} else if ( ! prefetch_buffer_ ) {
// Explicit user requested readahead
// Explicit user requested readahead
// The actual condition is:
// The actual condition is:
// if (read_options_.readahead_size != 0 && !prefetch_buffer_)
// if (read_options_.readahead_size != 0 && !prefetch_buffer_)
prefetch_buffer_ . reset ( new FilePrefetchBuffer (
rep - > CreateFilePrefetchBuffer ( read_options_ . readahead_size ,
rep - > file . get ( ) , read_options_ . readahead_size ,
read_options_ . readahead_size ,
read_options_ . readahead_size ) ) ;
& prefetch_buffer_ ) ;
}
}
} else if ( ! prefetch_buffer_ ) {
} else if ( ! prefetch_buffer_ ) {
prefetch_buffer_ . reset (
rep - > CreateFilePrefetchBuffer ( compaction_readahead_size_ ,
new FilePrefetchBuffer ( rep - > file . get ( ) , compaction_readahead_size_ ,
compaction_readahead_size_ ,
compaction_readahead_size_ ) ) ;
& prefetch_buffer_ ) ;
}
}
Status s ;
Status s ;