Commit 42bda685 authored by Marko Mäkelä's avatar Marko Mäkelä

MDEV-33585 follow-up optimization

log_t: Define buf_size, max_buf_free as 32-bit and next_checkpoint_no
as byte (we only need a bit) and rearrange some data members,
so that on AMD64 we can fit log_sys.latch and log_sys.log in
the same 64-byte cache line.

mtr_t::commit_log(), mtr_t::commit_logger: A part of mtr_t::commit()
split into a separate function, so that we will not unnecessarily invoke
log_sys.get_write_target() when running on a memory-mapped log file,
or log_sys.is_pmem().

Reviewed by: Vladislav Vaintroub
Tested by: Matthias Leich
parent 0892e6d0
...@@ -230,8 +230,6 @@ struct log_t ...@@ -230,8 +230,6 @@ struct log_t
/** Last written LSN */ /** Last written LSN */
lsn_t write_lsn; lsn_t write_lsn;
/** recommended maximum buf_free size, after which the buffer is flushed */
size_t max_buf_free;
/** buffer for writing data to ib_logfile0, or nullptr if is_pmem() /** buffer for writing data to ib_logfile0, or nullptr if is_pmem()
In write_buf(), buf and flush_buf are swapped */ In write_buf(), buf and flush_buf are swapped */
...@@ -241,6 +239,10 @@ struct log_t ...@@ -241,6 +239,10 @@ struct log_t
std::atomic<bool> need_checkpoint; std::atomic<bool> need_checkpoint;
/** whether a checkpoint is pending; protected by latch.wr_lock() */ /** whether a checkpoint is pending; protected by latch.wr_lock() */
Atomic_relaxed<bool> checkpoint_pending; Atomic_relaxed<bool> checkpoint_pending;
/** next checkpoint number (protected by latch.wr_lock()) */
byte next_checkpoint_no;
/** recommended maximum buf_free size, after which the buffer is flushed */
unsigned max_buf_free;
/** Log sequence number when a log file overwrite (broken crash recovery) /** Log sequence number when a log file overwrite (broken crash recovery)
was noticed. Protected by latch.wr_lock(). */ was noticed. Protected by latch.wr_lock(). */
lsn_t overwrite_warned; lsn_t overwrite_warned;
...@@ -249,8 +251,6 @@ struct log_t ...@@ -249,8 +251,6 @@ struct log_t
Atomic_relaxed<lsn_t> last_checkpoint_lsn; Atomic_relaxed<lsn_t> last_checkpoint_lsn;
/** next checkpoint LSN (protected by latch.wr_lock()) */ /** next checkpoint LSN (protected by latch.wr_lock()) */
lsn_t next_checkpoint_lsn; lsn_t next_checkpoint_lsn;
/** next checkpoint number (protected by latch.wr_lock()) */
ulint next_checkpoint_no;
/** Log file */ /** Log file */
log_file_t log; log_file_t log;
...@@ -323,6 +323,7 @@ struct log_t ...@@ -323,6 +323,7 @@ struct log_t
/** whether there is capacity in the log buffer */ /** whether there is capacity in the log buffer */
bool buf_free_ok() const noexcept bool buf_free_ok() const noexcept
{ {
ut_ad(!is_pmem());
return (buf_free.load(std::memory_order_relaxed) & ~buf_free_LOCK) < return (buf_free.load(std::memory_order_relaxed) & ~buf_free_LOCK) <
max_buf_free; max_buf_free;
} }
......
...@@ -695,6 +695,13 @@ struct mtr_t { ...@@ -695,6 +695,13 @@ struct mtr_t {
/** Encrypt the log */ /** Encrypt the log */
ATTRIBUTE_NOINLINE void encrypt(); ATTRIBUTE_NOINLINE void encrypt();
/** Commit the mini-transaction log.
@tparam pmem log_sys.is_pmem()
@param mtr mini-transaction
@param lsns {start_lsn,flush_ahead} */
template<bool pmem>
static void commit_log(mtr_t *mtr, std::pair<lsn_t,page_flush_ahead> lsns);
/** Append the redo log records to the redo log buffer. /** Append the redo log records to the redo log buffer.
@return {start_lsn,flush_ahead} */ @return {start_lsn,flush_ahead} */
std::pair<lsn_t,page_flush_ahead> do_write(); std::pair<lsn_t,page_flush_ahead> do_write();
...@@ -708,6 +715,8 @@ struct mtr_t { ...@@ -708,6 +715,8 @@ struct mtr_t {
template<bool spin,bool pmem> static template<bool spin,bool pmem> static
std::pair<lsn_t,page_flush_ahead> finish_writer(mtr_t *mtr, size_t len); std::pair<lsn_t,page_flush_ahead> finish_writer(mtr_t *mtr, size_t len);
/** The applicable variant of commit_log() */
static void (*commit_logger)(mtr_t *, std::pair<lsn_t,page_flush_ahead>);
/** The applicable variant of finish_writer() */ /** The applicable variant of finish_writer() */
static std::pair<lsn_t,page_flush_ahead> (*finisher)(mtr_t *, size_t); static std::pair<lsn_t,page_flush_ahead> (*finisher)(mtr_t *, size_t);
......
...@@ -235,7 +235,7 @@ void log_t::attach_low(log_file_t file, os_offset_t size) ...@@ -235,7 +235,7 @@ void log_t::attach_low(log_file_t file, os_offset_t size)
log.close(); log.close();
mprotect(ptr, size_t(size), PROT_READ); mprotect(ptr, size_t(size), PROT_READ);
buf= static_cast<byte*>(ptr); buf= static_cast<byte*>(ptr);
max_buf_free= size; max_buf_free= 1;
# if defined __linux__ || defined _WIN32 # if defined __linux__ || defined _WIN32
set_block_size(CPU_LEVEL1_DCACHE_LINESIZE); set_block_size(CPU_LEVEL1_DCACHE_LINESIZE);
# endif # endif
......
This diff is collapsed.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment