mirror of
https://github.com/matrix-construct/construct
synced 2025-01-14 00:34:18 +01:00
ircd:;fs: Rename various fsync/sync related.
This commit is contained in:
parent
a3613b1f4c
commit
9d423f84d8
6 changed files with 31 additions and 31 deletions
|
@ -86,7 +86,7 @@ enum ircd::fs::index
|
||||||
#include "aio.h"
|
#include "aio.h"
|
||||||
#include "read.h"
|
#include "read.h"
|
||||||
#include "write.h"
|
#include "write.h"
|
||||||
#include "fsync.h"
|
#include "sync.h"
|
||||||
#include "stdin.h"
|
#include "stdin.h"
|
||||||
#include "support.h"
|
#include "support.h"
|
||||||
|
|
||||||
|
|
|
@ -9,27 +9,27 @@
|
||||||
// full license for this software is available in the LICENSE file.
|
// full license for this software is available in the LICENSE file.
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
#define HAVE_IRCD_FS_FSYNC_H
|
#define HAVE_IRCD_FS_SYNC_H
|
||||||
|
|
||||||
namespace ircd::fs
|
namespace ircd::fs
|
||||||
{
|
{
|
||||||
struct fsync_opts extern const fsync_opts_default;
|
struct sync_opts extern const sync_opts_default;
|
||||||
|
|
||||||
void fdsync(const fd &, const fsync_opts & = fsync_opts_default);
|
void fdsync(const fd &, const sync_opts & = sync_opts_default);
|
||||||
void fsync(const fd &, const fsync_opts & = fsync_opts_default);
|
void fsync(const fd &, const sync_opts & = sync_opts_default);
|
||||||
void sync(const fd &, const fsync_opts & = fsync_opts_default);
|
void sync(const fd &, const sync_opts & = sync_opts_default);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Options for a write operation
|
/// Options for a write operation
|
||||||
struct ircd::fs::fsync_opts
|
struct ircd::fs::sync_opts
|
||||||
{
|
{
|
||||||
fsync_opts() = default;
|
sync_opts() = default;
|
||||||
|
|
||||||
/// Determines whether this operation is conducted via AIO. If not, a
|
/// Determines whether this operation is conducted via AIO. If not, a
|
||||||
/// direct syscall is made. Using AIO will only block one ircd::ctx while
|
/// direct syscall is made. Using AIO will only block one ircd::ctx while
|
||||||
/// a direct syscall will block the thread (all contexts). If AIO is not
|
/// a direct syscall will block the thread (all contexts). If AIO is not
|
||||||
/// available or enabled setting this has no effect.
|
/// available or enabled setting this has no effect.
|
||||||
bool async {true};
|
bool synchronous {false};
|
||||||
|
|
||||||
/// Request priority. This value is ignored by the kernel for the
|
/// Request priority. This value is ignored by the kernel for the
|
||||||
/// operations provided by this interface. It is still provided for
|
/// operations provided by this interface. It is still provided for
|
|
@ -28,7 +28,7 @@ namespace ircd::fs::aio
|
||||||
//
|
//
|
||||||
|
|
||||||
ircd::fs::aio::request::fsync::fsync(const int &fd,
|
ircd::fs::aio::request::fsync::fsync(const int &fd,
|
||||||
const fsync_opts &opts)
|
const sync_opts &opts)
|
||||||
:request{fd}
|
:request{fd}
|
||||||
{
|
{
|
||||||
aio_reqprio = reqprio(opts.priority);
|
aio_reqprio = reqprio(opts.priority);
|
||||||
|
@ -41,7 +41,7 @@ ircd::fs::aio::request::fsync::fsync(const int &fd,
|
||||||
|
|
||||||
void
|
void
|
||||||
ircd::fs::aio::fsync(const fd &fd,
|
ircd::fs::aio::fsync(const fd &fd,
|
||||||
const fsync_opts &opts)
|
const sync_opts &opts)
|
||||||
{
|
{
|
||||||
aio::request::fsync request
|
aio::request::fsync request
|
||||||
{
|
{
|
||||||
|
@ -56,7 +56,7 @@ ircd::fs::aio::fsync(const fd &fd,
|
||||||
//
|
//
|
||||||
|
|
||||||
ircd::fs::aio::request::fdsync::fdsync(const int &fd,
|
ircd::fs::aio::request::fdsync::fdsync(const int &fd,
|
||||||
const fsync_opts &opts)
|
const sync_opts &opts)
|
||||||
:request{fd}
|
:request{fd}
|
||||||
{
|
{
|
||||||
aio_reqprio = reqprio(opts.priority);
|
aio_reqprio = reqprio(opts.priority);
|
||||||
|
@ -69,7 +69,7 @@ ircd::fs::aio::request::fdsync::fdsync(const int &fd,
|
||||||
|
|
||||||
void
|
void
|
||||||
ircd::fs::aio::fdsync(const fd &fd,
|
ircd::fs::aio::fdsync(const fd &fd,
|
||||||
const fsync_opts &opts)
|
const sync_opts &opts)
|
||||||
{
|
{
|
||||||
aio::request::fdsync request
|
aio::request::fdsync request
|
||||||
{
|
{
|
||||||
|
|
|
@ -19,8 +19,8 @@ namespace ircd::fs::aio
|
||||||
void prefetch(const fd &, const size_t &, const read_opts &);
|
void prefetch(const fd &, const size_t &, const read_opts &);
|
||||||
size_t write(const fd &, const const_buffers &, const write_opts &);
|
size_t write(const fd &, const const_buffers &, const write_opts &);
|
||||||
size_t read(const fd &, const mutable_buffers &, const read_opts &);
|
size_t read(const fd &, const mutable_buffers &, const read_opts &);
|
||||||
void fdsync(const fd &, const fsync_opts &);
|
void fdsync(const fd &, const sync_opts &);
|
||||||
void fsync(const fd &, const fsync_opts &);
|
void fsync(const fd &, const sync_opts &);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// AIO context instance from the kernel. Right now this is a singleton with
|
/// AIO context instance from the kernel. Right now this is a singleton with
|
||||||
|
@ -101,12 +101,12 @@ struct ircd::fs::aio::request::write
|
||||||
struct ircd::fs::aio::request::fdsync
|
struct ircd::fs::aio::request::fdsync
|
||||||
:request
|
:request
|
||||||
{
|
{
|
||||||
fdsync(const int &fd, const fsync_opts &);
|
fdsync(const int &fd, const sync_opts &);
|
||||||
};
|
};
|
||||||
|
|
||||||
/// fsync request control block
|
/// fsync request control block
|
||||||
struct ircd::fs::aio::request::fsync
|
struct ircd::fs::aio::request::fsync
|
||||||
:request
|
:request
|
||||||
{
|
{
|
||||||
fsync(const int &fd, const fsync_opts &);
|
fsync(const int &fd, const sync_opts &);
|
||||||
};
|
};
|
||||||
|
|
12
ircd/db.cc
12
ircd/db.cc
|
@ -4754,7 +4754,7 @@ noexcept try
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
fs::fsync_opts opts;
|
fs::sync_opts opts;
|
||||||
fs::fdsync(fd, opts);
|
fs::fdsync(fd, opts);
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
@ -4801,7 +4801,7 @@ noexcept try
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
fs::fsync_opts opts;
|
fs::sync_opts opts;
|
||||||
fs::sync(fd, opts);
|
fs::sync(fd, opts);
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
@ -4846,7 +4846,7 @@ noexcept try
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
fs::fsync_opts opts;
|
fs::sync_opts opts;
|
||||||
fs::fsync(fd, opts);
|
fs::fsync(fd, opts);
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
@ -6983,7 +6983,7 @@ noexcept try
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
fs::fsync_opts opts;
|
fs::sync_opts opts;
|
||||||
fs::fsync(fd, opts);
|
fs::fsync(fd, opts);
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
@ -7030,7 +7030,7 @@ noexcept try
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
fs::fsync_opts opts;
|
fs::sync_opts opts;
|
||||||
fs::sync(fd, opts);
|
fs::sync(fd, opts);
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
@ -7077,7 +7077,7 @@ noexcept try
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
fs::fsync_opts opts;
|
fs::sync_opts opts;
|
||||||
fs::fdsync(fd, opts);
|
fs::fdsync(fd, opts);
|
||||||
return Status::OK();
|
return Status::OK();
|
||||||
}
|
}
|
||||||
|
|
16
ircd/fs.cc
16
ircd/fs.cc
|
@ -512,15 +512,15 @@ ircd::fs::stdin::tty::write(const string_view &buf)
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
//
|
//
|
||||||
// fs/fsync.h
|
// fs/sync.h
|
||||||
//
|
//
|
||||||
|
|
||||||
ircd::fs::fsync_opts
|
ircd::fs::sync_opts
|
||||||
const ircd::fs::fsync_opts_default;
|
const ircd::fs::sync_opts_default;
|
||||||
|
|
||||||
void
|
void
|
||||||
ircd::fs::sync(const fd &fd,
|
ircd::fs::sync(const fd &fd,
|
||||||
const fsync_opts &opts)
|
const sync_opts &opts)
|
||||||
{
|
{
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
syscall(::syncfs, fd);
|
syscall(::syncfs, fd);
|
||||||
|
@ -531,10 +531,10 @@ ircd::fs::sync(const fd &fd,
|
||||||
|
|
||||||
void
|
void
|
||||||
ircd::fs::fsync(const fd &fd,
|
ircd::fs::fsync(const fd &fd,
|
||||||
const fsync_opts &opts)
|
const sync_opts &opts)
|
||||||
{
|
{
|
||||||
#ifdef IRCD_USE_AIO
|
#ifdef IRCD_USE_AIO
|
||||||
if(aio::context && opts.async && support::aio_fsync)
|
if(aio::context && !opts.synchronous && support::aio_fsync)
|
||||||
return aio::fsync(fd, opts);
|
return aio::fsync(fd, opts);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -543,10 +543,10 @@ ircd::fs::fsync(const fd &fd,
|
||||||
|
|
||||||
void
|
void
|
||||||
ircd::fs::fdsync(const fd &fd,
|
ircd::fs::fdsync(const fd &fd,
|
||||||
const fsync_opts &opts)
|
const sync_opts &opts)
|
||||||
{
|
{
|
||||||
#ifdef IRCD_USE_AIO
|
#ifdef IRCD_USE_AIO
|
||||||
if(aio::context && opts.async && support::aio_fdsync)
|
if(aio::context && !opts.synchronous && support::aio_fdsync)
|
||||||
return aio::fdsync(fd, opts);
|
return aio::fdsync(fd, opts);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue