Commit 3b499679 authored by Marko Mäkelä's avatar Marko Mäkelä

MDEV-28049 Error on compiling trx0purge.cc

In commit 83212632
the trx_rseg_latch was instrumented for performance_schema,
but some acqusitions of rd_lock() were not adjusted.
Thus, the build would fail on platforms where a futex-based
rw-lock is not available (SUX_LOCK_GENERIC) unless the code
was built with cmake -DPLUGIN_PERFSCHEMA=NO.
parent e0dc22b2
...@@ -119,7 +119,7 @@ TRANSACTIONAL_INLINE inline bool TrxUndoRsegsIterator::set_next() ...@@ -119,7 +119,7 @@ TRANSACTIONAL_INLINE inline bool TrxUndoRsegsIterator::set_next()
trx_id_t last_trx_no, tail_trx_no; trx_id_t last_trx_no, tail_trx_no;
{ {
#ifdef SUX_LOCK_GENERIC #ifdef SUX_LOCK_GENERIC
purge_sys.rseg->latch.rd_lock(); purge_sys.rseg->latch.rd_lock(SRW_LOCK_CALL);
#else #else
transactional_shared_lock_guard<srw_spin_lock> rg transactional_shared_lock_guard<srw_spin_lock> rg
{purge_sys.rseg->latch}; {purge_sys.rseg->latch};
...@@ -636,7 +636,7 @@ TRANSACTIONAL_TARGET static void trx_purge_truncate_history() ...@@ -636,7 +636,7 @@ TRANSACTIONAL_TARGET static void trx_purge_truncate_history()
if (rseg.space != &space) if (rseg.space != &space)
continue; continue;
#ifdef SUX_LOCK_GENERIC #ifdef SUX_LOCK_GENERIC
rseg.latch.rd_lock(); rseg.latch.rd_lock(SRW_LOCK_CALL);
#else #else
transactional_shared_lock_guard<srw_spin_lock> g{rseg.latch}; transactional_shared_lock_guard<srw_spin_lock> g{rseg.latch};
#endif #endif
......
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