1. 29 Mar, 2021 1 commit
    • Marko Mäkelä's avatar
      MDEV-24302: RESET MASTER hangs · e8b7fceb
      Marko Mäkelä authored
      Starting with MariaDB 10.5, roughly after MDEV-23855 was fixed,
      we are observing sporadic hangs during the execution of the
      RESET MASTER statement. We are hoping to fix the hangs with these
      changes, but due to the rather infrequent occurrence of the hangs
      and our inability to reliably reproduce the hangs, we cannot be
      sure of this.
      
      What we do know is that innodb_force_recovery=2 (or a larger setting)
      will prevent srv_master_callback (the former srv_master_thread) from
      running. In that mode, periodic log flushes would never occur and
      RESET MASTER could hang indefinitely. That is demonstrated by the new
      test case that was developed by Andrei Elkin. We fix this case by
      implementing a special case for it.
      
      This also includes some code cleanup and renames of misleadingly
      named code. The interface has nothing to do with log checkpoints in
      the storage engine; it is only about requesting log writes to be
      persistent.
      
      handlerton::commit_checkpoint_request,
      commit_checkpoint_notify_ha(): Remove the unused parameter hton.
      
      log_requests.start: Replaces pending_checkpoint_list.
      log_requests.end: Replaces pending_checkpoint_list_end.
      log_requests.mutex: Replaces pending_checkpoint_mutex.
      
      log_flush_notify_and_unlock(), log_flush_notify(): Replaces
      innobase_mysql_log_notify().  The new implementation should be
      functionally equivalent to the old one.
      
      innodb_log_flush_request(): Replaces innobase_checkpoint_request().
      Implement a fast path for common cases, and reduce the mutex hold time.
      POSSIBLE FIX OF THE HANG: We will invoke commit_checkpoint_notify_ha()
      for the current request if it is already satisfied, as well as invoke
      log_flush_notify_and_unlock() for any satisfied requests.
      
      log_write(): Invoke log_flush_notify() when the write is already durable.
      This was missing WITH_PMEM when the log is in persistent memory.
      
      Reviewed by: Vladislav Vaintroub
      e8b7fceb
  2. 28 Mar, 2021 1 commit
    • Monty's avatar
      Fixed access to undefined memory · 8e2d69f7
      Monty authored
      alloc_query() is examined the content of it's argument, which was
      uninitalized.
      Fixed by storing stmt_id in llbuf, according to code comments.
      8e2d69f7
  3. 27 Mar, 2021 3 commits
  4. 26 Mar, 2021 5 commits
    • Michael Okoko's avatar
      Replace mallinfo with mallinfo2 on supported systems · 48141f3c
      Michael Okoko authored
      `mallinfo` is deprecated since glibc 2.33 and has been replaced by mallinfo2.
      The deprecation causes building the server to fail if glibc version is > 2.33.
      
      Check if mallinfo2 exist on the system and use it instead.
      48141f3c
    • Eugene Kosov's avatar
    • Eugene Kosov's avatar
      MDEV-25238 add support for -fsanitize-address-use-after-scope · dfae51de
      Eugene Kosov authored
      Use like this: cmake -DWITH_ASAN=ON -DWITH_ASAN_SCOPE=ON
      dfae51de
    • Marko Mäkelä's avatar
      MDEV-24786: row_upd_clust_step() skips mtr_t::commit() on virtual column error · a6d66fe7
      Marko Mäkelä authored
      The function row_upd_clust_step() is invoking several static functions,
      some of which used to commit the mini-transaction in some cases.
      If innobase_get_computed_value() would fail due to some reason,
      we would fail to invoke mtr_t::commit() and release buffer pool
      page latches. This would likely lead to a hanging server later.
      
      This regression was introduced in
      commit 97db6c15 (MDEV-20618).
      
      row_upd_index_is_referenced(), row_upd_sec_index_entry(),
      row_upd_sec_index_entry(): Cleanup: Replace some ibool with bool.
      
      row_upd_clust_rec_by_insert(), row_upd_clust_rec(): Guarantee that
      the mini-transaction will always remain in active state.
      
      row_upd_del_mark_clust_rec(): Guarantee that
      the mini-transaction will always remain in active state.
      This fixes one "leak" of mini-transaction on DB_COMPUTE_VALUE_FAILED.
      
      row_upd_clust_step(): Use only one return path, which will always
      invoke mtr.commit(). After a failed row_upd_store_row() call, we
      will no longer "leak" the mini-transaction.
      
      This fix was verified by RQG on 10.6 (depending on MDEV-371 that
      was introduced in 10.4). Unfortunately, it is challenging to
      create a regression test for this, and a test case could soon become
      invalid as more bugs in virtual column evaluation are fixed.
      a6d66fe7
    • Marko Mäkelä's avatar
      MDEV-25265: ALTER TABLE...IMPORT TABLESPACE fails after DROP INDEX · 2e67b9f6
      Marko Mäkelä authored
      A side effect of the MDEV-24589 bug fix is that if
      FLUSH TABLE...FOR EXPORT is initiated before the history of an
      earlier DROP INDEX operation has been purged, then the data file
      will contain allocated pages that belonged to the dropped indexes.
      These pages would never be freed after a subsequent IMPORT TABLESPACE.
      
      We will work around this regression by making IMPORT TABLESPACE
      tolerate pages that refer to an unknown index.
      2e67b9f6
  5. 25 Mar, 2021 4 commits
    • Daniel Black's avatar
      MEM_CHECK_DEFINED: replace HAVE_valgrind · bcb9ca41
      Daniel Black authored
      HAVE_valgrind_or_MSAN to HAVE_valgrind was incorrect in
      af784385.
      
      In my_valgrind.h when clang exists (hence no __has_feature(memory_sanitizer),
      and -DWITH_VALGRIND=1, but without memcheck.h, we end up with a MEM_CHECK_DEFINED
      being empty.
      
      If we are also doing a CMAKE_BUILD_TYPE=Debug this results a number of
      [-Werror,-Wunused-variable] errors because MEM_CHECK_DEFINED is empty.
      With MEM_CHECK_DEFINED empty, there becomes no uses of this of the
      fixed field and innodb variables in this patch.
      
      So we stop using HAVE_valgrind as catchall and use the name
      HAVE_CHECK_MEM to indicate that a CHECK_MEM_DEFINED function exists.
      
      Reviewer: Monty
      
      Corrects: af784385
      bcb9ca41
    • Vladislav Vaintroub's avatar
    • mkaruza's avatar
      MDEV-21697: Galera assertion !wsrep_has_changes(thd) || (thd->lex->sql_command... · d1ff2c58
      mkaruza authored
      MDEV-21697: Galera assertion !wsrep_has_changes(thd) || (thd->lex->sql_command == SQLCOM_CREATE_TABLE && !thd->is_current_stmt_binlog_format_row())
      
      Prevent adding WSREP keys with CTAS when table is is not InnoDB.
      Reviewed-by: default avatarJan Lindström <jan.lindstrom@mariadb.com>
      d1ff2c58
    • Jan Lindström's avatar
      MDEV-24954 : 10.5.9 crashes on int wsrep::client_state::ordered_commit():... · 161f4036
      Jan Lindström authored
      MDEV-24954 : 10.5.9 crashes on int wsrep::client_state::ordered_commit(): Assertion `owning_thread_id_ == wsrep::this_thread::get_id()' failed.
      
      Binlog group commit could lead to a situation where group commit leader
      accesses participant thd's wsrep client state concurrently with the
      thread executing the participant thd.
      
      This is because of race condition in
      MYSQL_BIN_LOG::write_transaction_to_binlog_events(),
      and was fixed by moving wsrep_ordered_commit() to happen in
      MYSQL_BIN_LOG::queue_for_group_commit() under protection of
      LOCK_prepare_ordered mutex.
      161f4036
  6. 24 Mar, 2021 3 commits
    • Sergei Golubchik's avatar
      MDEV-25242 Server crashes in check_grant upon invoking function with userstat enabled · 5a798071
      Sergei Golubchik authored
      use check_grant(..., number_of_tables=1, ...) if you only need
      to check privileges for one table
      5a798071
    • Vladislav Vaintroub's avatar
      MDEV-23740 postfix - potentially uninitialized variable passed to vio_socket_io_wait. · cdb86faf
      Vladislav Vaintroub authored
      
      Thanks to Daniel Black for reporting.
      cdb86faf
    • Igor Babaev's avatar
      MDEV-25128 Wrong result from join with materialized semi-join and · 480a0671
      Igor Babaev authored
                 splittable derived
      
      If one of joined tables of the processed query is a materialized derived
      table (or view or CTE) with GROUP BY clause then under some conditions it
      can be subject to split optimization. With this optimization new equalities
      are injected into the WHERE condition of the SELECT that specifies this
      derived table. The injected equalities are generated for all join orders
      with which the split optimization can employed. After the best join order
      has been chosen only certain of this equalities are really needed. The
      others can be safely removed. If it's not done and some of injected
      equalities involve expressions over semi-joins with look-up access then
      the query may return a wrong result set.
      This patch effectively removes equalities injected for split optimization
      that are needed only at the optimization stage and not needed for execution.
      
      Approved by serg@mariadb.com
      480a0671
  7. 23 Mar, 2021 10 commits
  8. 22 Mar, 2021 6 commits
    • Marko Mäkelä's avatar
      MDEV-23076 Misleading "InnoDB: using atomic writes" · 56274bd5
      Marko Mäkelä authored
      As suggested by Vladislav Vaintroub, let us remove misleading
      and malformatted startup messages.
      
      Even if the global variable srv_use_atomic_writes were set, we would
      still invoke my_test_if_atomic_write() to check if writes are atomic
      with a particular page size.
      
      When using the default innodb_page_size=16k, page writes should be
      atomic on NTFS when using ROW_FORMAT=COMPRESSED and KEY_BLOCK_SIZE<=4.
      
      Disabling srv_use_atomic_writes when innodb_file_per_table=OFF does
      not make sense, because that is a dynamic parameter.
      
      We also correct the documentation string of innodb_use_atomic_writes
      and remove the duplicate variable innobase_use_atomic_writes.
      56274bd5
    • Marko Mäkelä's avatar
      MDEV-22653: Remove the useless parameter innodb_simulate_comp_failures · 0f8caadc
      Marko Mäkelä authored
      The debug parameter innodb_simulate_comp_failures injected compression
      failures for ROW_FORMAT=COMPRESSED tables, breaking the pre-existing
      logic that I had implemented in the InnoDB Plugin for MySQL 5.1 to prevent
      compressed page overflows. A much better check is already achieved by
      defining UNIV_ZIP_COPY at the compilation time.
      (Only UNIV_ZIP_DEBUG is part of cmake -DWITH_INNODB_EXTRA_DEBUG=ON.)
      0f8caadc
    • Monty's avatar
      Fixed wrong usage strlen(), should be sizeof() · d902b53c
      Monty authored
      Found by running valgrind on mtr tests
      d902b53c
    • Marko Mäkelä's avatar
      MDEV-24796 Assertion `page_has_next... failed in btr_pcur_store_position() · 61e00db6
      Marko Mäkelä authored
      In commit eaeb8ec4 (MDEV-24653)
      an incorrect debug assertion was introduced.
      
      btr_pcur_store_position(): If the only record in the page is the
      instant ALTER TABLE metadata record, we cannot expect there to be
      a successor page. The situation could be improved by MDEV-24673 later.
      61e00db6
    • Dmitry Shulga's avatar
    • Otto Kekäläinen's avatar
      Fix various spelling errors still found in code · cebf9ee2
      Otto Kekäläinen authored
      Reseting -> Resetting
      Unknow -> Unknown
      capabilites -> capabilities
      choosen -> chosen
      direcory -> directory
      informations -> information
      openned -> opened
      refered -> referred
      to access -> one to access
      missmatch -> mismatch
      succesfully -> successfully
      dont -> don't
      cebf9ee2
  9. 21 Mar, 2021 3 commits
  10. 20 Mar, 2021 4 commits