- 29 Dec, 2018 4 commits
-
-
Sergey Vojtovich authored
Trivial fil_space_t::n_pending_ios transition. Since it is not obvious which memory barriers are supposed to be issued, seq_cst memory order was preserved.
-
Sergey Vojtovich authored
Almost trivial ReadView::m_state transition. Since C++11 doesn't seem to allow mixed (atomic and non-atomic) access to atomic variables, we have to perform all accesses atomically.
-
Sergey Vojtovich authored
srv_sys_t::n_threads_active transition to Atomic_counter.
-
Sergey Vojtovich authored
Almost trivial TTASFutexMutex::m_lock_word transition. Since C++11 doesn't seem to allow mixed (atomic and non-atomic) access to atomic variables, we have to perform all accesses atomically.
-
- 28 Dec, 2018 8 commits
-
-
Aleksey Midenkov authored
Closes #986
-
Marko Mäkelä authored
Remove an unused variable, and propagate the error to the caller instead of calling exit().
-
Marko Mäkelä authored
dict_table_t::rollback_instant(): Restore dict_index_t::n_core_fields.
-
Sergey Vojtovich authored
Added lf_hash_size() macro, so that callers don't need to use atomic operations.
-
Sergey Vojtovich authored
Simplified worker threads completion waiting, made it use std::atomic.
-
Sergey Vojtovich authored
This is follow-up patch. Avoid calling constructor/destructor twice.
-
Marko Mäkelä authored
This is a follow-up to commit 9581c4a8 which added a memcpy() call to rtr_copy_buf(), to copy rw_lock_t debug_latch. This could emit a warning. A cleaner approach is to make buf_block_t::debug_latch a pointer, so that we can avoid copying it. An even cleaner approach would be to redesign the InnoDB SPATIAL INDEX code so that the function rtr_copy_buf() is not needed at all.
-
Marko Mäkelä authored
-
- 27 Dec, 2018 28 commits
-
-
Vladislav Vaintroub authored
avoid calling SSL_get_verify_mode() and SSL_get_verify_depth(), since yassl implementation of the function accesses the acceptor context, which can be freed on FLUSH SSL command.
-
Sergey Vojtovich authored
purge_sys_t::m_enabled transition to std::atomic. enabled_latched() doesn't make much sense: in this particular case it is as fast as atomic load. The sole caller has to reload it's value anyway, due to rw_lock_x_lock(&purge_sys.latch) issuing acquire memory barrier. When purge_sys_t::close() is reached, m_enabled must be false, otherwise we may free members, which are still in use by the coordinator thread.
-
Sergey Vojtovich authored
purge_sys_t::m_paused transition to Atomic_counter. paused_latched() doesn't make much sense: in this particular case it is as fast as atomic load. The sole caller has to reload it's value anyway, due to rw_lock_x_lock(&purge_sys.latch) issuing acquire memory barrier.
-
Sergey Vojtovich authored
onlineddl_rowlog_rows transition to Atomic_counter.
-
Sergey Vojtovich authored
os_aio_validate_count transition to Atomic_counter.
-
Sergey Vojtovich authored
ibuf_t::n_merges transition to Atomic_counter.
-
Sergey Vojtovich authored
dict_table_t::n_foreign_key_checks_running transition to Atomic_counter.
-
Sergey Vojtovich authored
trx_sys_t::rseg_history_len transition to Atomic_counter.
-
Sergey Vojtovich authored
fil_space_t::redo_skipped_count transition to Atomic_counter.
-
Sergey Vojtovich authored
srv_conc_t.n_active and srv_conc_t.n_waiting transition to Atomic_counter.
-
Sergey Vojtovich authored
btr_defragment_compression_failures, btr_defragment_failures and btr_defragment_count transition to Atomic_counter.
-
Sergey Vojtovich authored
os_thread_count transition to Atomic_counter.
-
Sergey Vojtovich authored
Almost trivial rw_lock_t::waiters transition. Since C++11 doesn't seem to allow mixed (atomic and non-atomic) access to atomic variables, we have to perform atomic initialisation.
-
Sergey Vojtovich authored
Almost trivial rw_lock_t::lock_word transition. Since C++11 doesn't seem to allow mixed (atomic and non-atomic) access to atomic variables, we have to perform atomic initialisation. Also made previously broken code in gis0sea.cc even more broken. It is unclear how it was supposed to work and what exactly it was supposed to do.
-
Sergey Vojtovich authored
os_total_large_mem_allocated transition to Atomic_counter.
-
Sergey Vojtovich authored
Replaced simple_atomic_counter with Atomic_counter.
-
Sergey Vojtovich authored
Trivial buf_tmp_buffer_t::reserved transition. Relaxed memory order looks suspicious when used by methods that have acquire()/release() names. Especially if intention is to transfer some variable or memory region from one thread to another. Or is memory ordering guaranteed by something else, e.g. some mutex that protects broader range of acquire/release functionality?
-
Sergey Vojtovich authored
Almost trivial TTASEventMutex::m_lock_word transition. Since C++11 doesn't seem to allow mixed (atomic and non-atomic) access to atomic variables, we have to perform all accesses atomically.
-
Sergey Vojtovich authored
Almost trivial TTASMutex::m_lock_word transition. Since C++11 doesn't seem to allow mixed (atomic and non-atomic) access to atomic variables, we have to perform all accesses atomically.
-
Sergey Vojtovich authored
dict_table_t::n_ref_count transition to Atomic_counter.
-
Sergey Vojtovich authored
Trivial srv_running transition.
-
Sergey Vojtovich authored
trx_t::n_ref transition to Atomic_counter.
-
Sergey Vojtovich authored
rw_trx_hash_element_t::no transition to Atomic_counter. Since C++11 doesn't seem to allow mixed (atomic and non-atomic) access to atomic variables, we have to perform atomic initialisation.
-
Sergey Vojtovich authored
Almost trivial trx_sys_t::m_rw_trx_hash_version transition. Since C++11 doesn't seem to allow mixed (atomic and non-atomic) access to atomic variables, we have to perform atomic initialisation.
-
Sergey Vojtovich authored
trx_sys_t::m_max_trx_id transition to Atomic_counter. Since C++11 doesn't seem to allow mixed (atomic and non-atomic) access to atomic variables, we have to perform atomic initialisation.
-
Sergey Vojtovich authored
fil_validate_count transition to Atomic_counter.
-
Sergey Vojtovich authored
Added Atomic_counter class to replace big set of atomic operations uses in InnoDB, as well as in the server.
-
Marko Mäkelä authored
The fix for MDEV-17901 did not cover cases where the AUTO_INCREMENT column was not dropped, but some other columns before it were. commit_cache_norebuild(): Revert the MDEV-17901 fix. dict_index_t::clear_instant_alter(): Update table->persistent_autoinc.
-