@ -99,17 +99,18 @@ Status RandomAccessFileReader::Read(uint64_t offset, size_t n, Slice* result,
}
}
Slice tmp ;
Slice tmp ;
time_t start_ts = 0 ;
FileOperationInfo : : TimePoint start_ts ;
uint64_t orig_offset = 0 ;
uint64_t orig_offset = 0 ;
if ( ShouldNotifyListeners ( ) ) {
if ( ShouldNotifyListeners ( ) ) {
start_ts = std : : chrono : : system_clock : : to_time_t (
start_ts = std : : chrono : : system_clock : : now ( ) ;
std : : chrono : : system_clock : : now ( ) ) ;
orig_offset = aligned_offset + buf . CurrentSize ( ) ;
orig_offset = aligned_offset + buf . CurrentSize ( ) ;
}
}
s = file_ - > Read ( aligned_offset + buf . CurrentSize ( ) , allowed , & tmp ,
s = file_ - > Read ( aligned_offset + buf . CurrentSize ( ) , allowed , & tmp ,
buf . Destination ( ) ) ;
buf . Destination ( ) ) ;
if ( ShouldNotifyListeners ( ) ) {
if ( ShouldNotifyListeners ( ) ) {
NotifyOnFileReadFinish ( orig_offset , tmp . size ( ) , start_ts , s ) ;
auto finish_ts = std : : chrono : : system_clock : : now ( ) ;
NotifyOnFileReadFinish ( orig_offset , tmp . size ( ) , start_ts , finish_ts ,
s ) ;
}
}
buf . Size ( buf . CurrentSize ( ) + tmp . size ( ) ) ;
buf . Size ( buf . CurrentSize ( ) + tmp . size ( ) ) ;
@ -145,16 +146,17 @@ Status RandomAccessFileReader::Read(uint64_t offset, size_t n, Slice* result,
Slice tmp_result ;
Slice tmp_result ;
# ifndef ROCKSDB_LITE
# ifndef ROCKSDB_LITE
time_t start_ts = 0 ;
FileOperationInfo : : TimePoint start_ts ;
if ( ShouldNotifyListeners ( ) ) {
if ( ShouldNotifyListeners ( ) ) {
start_ts = std : : chrono : : system_clock : : to_time_t (
start_ts = std : : chrono : : system_clock : : now ( ) ;
std : : chrono : : system_clock : : now ( ) ) ;
}
}
# endif
# endif
s = file_ - > Read ( offset + pos , allowed , & tmp_result , scratch + pos ) ;
s = file_ - > Read ( offset + pos , allowed , & tmp_result , scratch + pos ) ;
# ifndef ROCKSDB_LITE
# ifndef ROCKSDB_LITE
if ( ShouldNotifyListeners ( ) ) {
if ( ShouldNotifyListeners ( ) ) {
NotifyOnFileReadFinish ( offset + pos , tmp_result . size ( ) , start_ts , s ) ;
auto finish_ts = std : : chrono : : system_clock : : now ( ) ;
NotifyOnFileReadFinish ( offset + pos , tmp_result . size ( ) , start_ts ,
finish_ts , s ) ;
}
}
# endif
# endif
@ -444,18 +446,18 @@ Status WritableFileWriter::WriteBuffered(const char* data, size_t size) {
TEST_SYNC_POINT ( " WritableFileWriter::Flush:BeforeAppend " ) ;
TEST_SYNC_POINT ( " WritableFileWriter::Flush:BeforeAppend " ) ;
# ifndef ROCKSDB_LITE
# ifndef ROCKSDB_LITE
time_t start_ts = 0 ;
FileOperationInfo : : TimePoint start_ts ;
uint64_t old_size = writable_file_ - > GetFileSize ( ) ;
uint64_t old_size = writable_file_ - > GetFileSize ( ) ;
if ( ShouldNotifyListeners ( ) ) {
if ( ShouldNotifyListeners ( ) ) {
start_ts = std : : chrono : : system_clock : : to_time_t (
start_ts = std : : chrono : : system_clock : : now ( ) ;
std : : chrono : : system_clock : : now ( ) ) ;
old_size = next_write_offset_ ;
old_size = next_write_offset_ ;
}
}
# endif
# endif
s = writable_file_ - > Append ( Slice ( src , allowed ) ) ;
s = writable_file_ - > Append ( Slice ( src , allowed ) ) ;
# ifndef ROCKSDB_LITE
# ifndef ROCKSDB_LITE
if ( ShouldNotifyListeners ( ) ) {
if ( ShouldNotifyListeners ( ) ) {
NotifyOnFileWriteFinish ( old_size , allowed , start_ts , s ) ;
auto finish_ts = std : : chrono : : system_clock : : now ( ) ;
NotifyOnFileWriteFinish ( old_size , allowed , start_ts , finish_ts , s ) ;
}
}
# endif
# endif
if ( ! s . ok ( ) ) {
if ( ! s . ok ( ) ) {
@ -520,15 +522,15 @@ Status WritableFileWriter::WriteDirect() {
{
{
IOSTATS_TIMER_GUARD ( write_nanos ) ;
IOSTATS_TIMER_GUARD ( write_nanos ) ;
TEST_SYNC_POINT ( " WritableFileWriter::Flush:BeforeAppend " ) ;
TEST_SYNC_POINT ( " WritableFileWriter::Flush:BeforeAppend " ) ;
time_t start_ts ( 0 ) ;
FileOperationInfo : : TimePoint start_ts ;
if ( ShouldNotifyListeners ( ) ) {
if ( ShouldNotifyListeners ( ) ) {
start_ts = std : : chrono : : system_clock : : to_time_t (
start_ts = std : : chrono : : system_clock : : now ( ) ;
std : : chrono : : system_clock : : now ( ) ) ;
}
}
// direct writes must be positional
// direct writes must be positional
s = writable_file_ - > PositionedAppend ( Slice ( src , size ) , write_offset ) ;
s = writable_file_ - > PositionedAppend ( Slice ( src , size ) , write_offset ) ;
if ( ShouldNotifyListeners ( ) ) {
if ( ShouldNotifyListeners ( ) ) {
NotifyOnFileWriteFinish ( write_offset , size , start_ts , s ) ;
auto finish_ts = std : : chrono : : system_clock : : now ( ) ;
NotifyOnFileWriteFinish ( write_offset , size , start_ts , finish_ts , s ) ;
}
}
if ( ! s . ok ( ) ) {
if ( ! s . ok ( ) ) {
buf_ . Size ( file_advance + leftover_tail ) ;
buf_ . Size ( file_advance + leftover_tail ) ;