cleanup direct io flag in WritableFileWriter

Summary:
remove unnecessary field `direct_io_`, use `use_direct_io()` instead.
Closes https://github.com/facebook/rocksdb/pull/1992

Differential Revision: D4712195

Pulled By: lightmark

fbshipit-source-id: 57d34f9
main
Aaron Gao 8 years ago committed by Facebook Github Bot
parent 5fa927aa97
commit d525718a93
  1. 15
      util/file_reader_writer.cc
  2. 2
      util/file_reader_writer.h

@ -115,7 +115,7 @@ Status WritableFileWriter::Append(const Slice& data) {
} }
// Flush only when buffered I/O // Flush only when buffered I/O
if (!direct_io_ && (buf_.Capacity() - buf_.CurrentSize()) < left) { if (!use_direct_io() && (buf_.Capacity() - buf_.CurrentSize()) < left) {
if (buf_.CurrentSize() > 0) { if (buf_.CurrentSize() > 0) {
s = Flush(); s = Flush();
if (!s.ok()) { if (!s.ok()) {
@ -134,7 +134,7 @@ Status WritableFileWriter::Append(const Slice& data) {
// We never write directly to disk with direct I/O on. // We never write directly to disk with direct I/O on.
// or we simply use it for its original purpose to accumulate many small // or we simply use it for its original purpose to accumulate many small
// chunks // chunks
if (direct_io_ || (buf_.Capacity() >= left)) { if (use_direct_io() || (buf_.Capacity() >= left)) {
while (left > 0) { while (left > 0) {
size_t appended = buf_.Append(src, left); size_t appended = buf_.Append(src, left);
left -= appended; left -= appended;
@ -211,7 +211,7 @@ Status WritableFileWriter::Flush() {
rocksdb_kill_odds * REDUCE_ODDS2); rocksdb_kill_odds * REDUCE_ODDS2);
if (buf_.CurrentSize() > 0) { if (buf_.CurrentSize() > 0) {
if (direct_io_) { if (use_direct_io()) {
#ifndef ROCKSDB_LITE #ifndef ROCKSDB_LITE
s = WriteDirect(); s = WriteDirect();
#endif // !ROCKSDB_LITE #endif // !ROCKSDB_LITE
@ -240,7 +240,7 @@ Status WritableFileWriter::Flush() {
// the page. // the page.
// Xfs does neighbor page flushing outside of the specified ranges. We // Xfs does neighbor page flushing outside of the specified ranges. We
// need to make sure sync range is far from the write offset. // need to make sure sync range is far from the write offset.
if (!direct_io_ && bytes_per_sync_) { if (!use_direct_io() && bytes_per_sync_) {
const uint64_t kBytesNotSyncRange = 1024 * 1024; // recent 1MB is not synced. const uint64_t kBytesNotSyncRange = 1024 * 1024; // recent 1MB is not synced.
const uint64_t kBytesAlignWhenSync = 4 * 1024; // Align 4KB. const uint64_t kBytesAlignWhenSync = 4 * 1024; // Align 4KB.
if (filesize_ > kBytesNotSyncRange) { if (filesize_ > kBytesNotSyncRange) {
@ -264,7 +264,7 @@ Status WritableFileWriter::Sync(bool use_fsync) {
return s; return s;
} }
TEST_KILL_RANDOM("WritableFileWriter::Sync:0", rocksdb_kill_odds); TEST_KILL_RANDOM("WritableFileWriter::Sync:0", rocksdb_kill_odds);
if (!direct_io_ && pending_sync_) { if (!use_direct_io() && pending_sync_) {
s = SyncInternal(use_fsync); s = SyncInternal(use_fsync);
if (!s.ok()) { if (!s.ok()) {
return s; return s;
@ -328,7 +328,7 @@ size_t WritableFileWriter::RequestToken(size_t bytes, bool align) {
// limiter if available // limiter if available
Status WritableFileWriter::WriteBuffered(const char* data, size_t size) { Status WritableFileWriter::WriteBuffered(const char* data, size_t size) {
Status s; Status s;
assert(!direct_io_); assert(!use_direct_io());
const char* src = data; const char* src = data;
size_t left = size; size_t left = size;
@ -365,9 +365,8 @@ Status WritableFileWriter::WriteBuffered(const char* data, size_t size) {
// offsets. // offsets.
#ifndef ROCKSDB_LITE #ifndef ROCKSDB_LITE
Status WritableFileWriter::WriteDirect() { Status WritableFileWriter::WriteDirect() {
assert(use_direct_io());
Status s; Status s;
assert(direct_io_);
const size_t alignment = buf_.Alignment(); const size_t alignment = buf_.Alignment();
assert((next_write_offset_ % alignment) == 0); assert((next_write_offset_ % alignment) == 0);

@ -115,7 +115,6 @@ class WritableFileWriter {
// so we need to go back and write that page again // so we need to go back and write that page again
uint64_t next_write_offset_; uint64_t next_write_offset_;
bool pending_sync_; bool pending_sync_;
const bool direct_io_;
uint64_t last_sync_size_; uint64_t last_sync_size_;
uint64_t bytes_per_sync_; uint64_t bytes_per_sync_;
RateLimiter* rate_limiter_; RateLimiter* rate_limiter_;
@ -130,7 +129,6 @@ class WritableFileWriter {
filesize_(0), filesize_(0),
next_write_offset_(0), next_write_offset_(0),
pending_sync_(false), pending_sync_(false),
direct_io_(writable_file_->use_direct_io()),
last_sync_size_(0), last_sync_size_(0),
bytes_per_sync_(options.bytes_per_sync), bytes_per_sync_(options.bytes_per_sync),
rate_limiter_(options.rate_limiter), rate_limiter_(options.rate_limiter),

Loading…
Cancel
Save