1. 03 Jun, 2020 2 commits
  2. 02 Jun, 2020 7 commits
    • Marko Mäkelä's avatar
      MDEV-22773 Assertion page_get_page_no... in btr_pcur_store_position() · 95ac7902
      Marko Mäkelä authored
      btr_pcur_store_position(): Replace a too strict debug assertion.
      It is possible to have a clustered index B-tree for a logically
      empty table, which will consist of a node pointer from the root
      page to a leaf page that contains the metadata record.
      
      The too strict debug assertion was added in
      commit 0e5a4ac2 (MDEV-15562).
      95ac7902
    • Monty's avatar
      Added larger timeout to backup_stages.test · 457e3128
      Monty authored
      MDEV-21546 main.backup_stages occasionally fails with lock wait timeout
      457e3128
    • Varun Gupta's avatar
      MDEV-22509: Server crashes in Field_inet6::store_inet6_null_with_warn / Field::maybe_null · d5e8b4d7
      Varun Gupta authored
      For field with type INET, during EITS collection the min and max values are store in text
      representation in the statistical table.
      While retrieving the value from the statistical table, the value is stored back in the original
      field using binary form instead of text and this was resulting in the crash.
      
      Introduced 2 functions in the Field structure:
        1) store_to_statistical_minmax_field
        2) store_from_statistical_minmax_field
      d5e8b4d7
    • Marko Mäkelä's avatar
      MDEV-21546 main.backup_stages occasionally reports lock wait timeout · 6df2f2db
      Marko Mäkelä authored
      With MDEV-16678, InnoDB background tasks (most notably, the purge of
      committed transaction history) can acquire metadata locks.
      Because of this, the lock_wait_timeout=0 is too strict and must
      be relaxed.
      
      The test used to fail easily if an extra sleep was added to
      the end of dict_table_close(), before the MDL release. Now,
      with lock_wait_timeout=1, the test passes even with an extra
      0.1-second sleep added to dict_table_close().
      
      Thanks to Monty for providing this fix.
      6df2f2db
    • Marko Mäkelä's avatar
      Merge 10.2 into 10.3 · 8300f639
      Marko Mäkelä authored
      8300f639
    • Marko Mäkelä's avatar
      MDEV-22770 trx_undo_report_rename() fails to release page latches · 804761a8
      Marko Mäkelä authored
      commit f74023b9 (MDEV-15090)
      inadvertently removed a mtr_t::commit() call from
      trx_undo_report_rename(), causing an InnoDB hang if
      we failed to log a RENAME operation.
      
      It is unclear whether this condition is possible in practice.
      The test case involved SET GLOBAL innodb_trx_rseg_n_slots_debug=1
      and a failed CREATE TABLE...SELECT, whose error handling would
      internally invoke RENAME in InnoDB.
      804761a8
    • Marko Mäkelä's avatar
      MDEV-22027 Assertion oldest_lsn >= log_sys.last_checkpoint_lsn failed · 0d6d63e1
      Marko Mäkelä authored
      log_buf_pool_get_oldest_modification(): Acquire
      log_sys_t::flush_order_mutex in order to prevent a race condition
      that was introduced in
      commit 1a6f708e (MDEV-15058).
      
      Before that change, log_buf_pool_get_oldest_modification()
      was protected by both log_sys.mutex and log_sys.flush_order_mutex
      like it was supposed to be ever since
      commit a52c4820 (MySQL 5.5.10).
      
      buf_pool_t::get_oldest_modification(): Replaces
      buf_pool_get_oldest_modification(), to emphasize that
      log_sys.flush_order_mutex must be acquired by the caller if needed.
      
      log_close(): Invoke log_buf_pool_get_oldest_modification()
      in order to ensure a clean shutdown.
      
      The scenario of the race condition is as follows:
      
      1. The buffer pool is clean (no writes are pending).
      2. mtr_add_dirtied_pages_to_flush_list() releases log_sys.mutex.
      3. log_buf_pool_get_oldest_modification() observes that the
      buffer pool is clean and returns log_sys.lsn.
      4. log_checkpoint() completes, writing a wrong checkpoint header
      according to which everything up to log_sys.lsn was clean.
      5. mtr_add_dirtied_pages_to_flush_list() completes the execution
      of mtr_memo_note_modifications(), releases the page latches and
      the flush_order_mutex.
      6. On a subsequent log_checkpoint(), the assertion could fail
      if the page modifications had not been flushed yet.
      
      The failing assertion (which is valid) was added in MySQL 5.7
      mysql/mysql-server@5c6c6ec69336369487dfc080a6980089b4e1a3c2
      and merged to MariaDB Server 10.2.2 in
      commit fec844ac.
      0d6d63e1
  3. 01 Jun, 2020 17 commits
  4. 31 May, 2020 3 commits
  5. 30 May, 2020 4 commits
  6. 29 May, 2020 7 commits
    • Monty's avatar
      Fixed wrong length in my_default.c · 043828bd
      Monty authored
      This couldn't cause any bugs as ptr was zero terminated, but still better
      to have the length correct.
      043828bd
    • Monty's avatar
      SHOW TABLE STATUS now shows if an Aria table is transactional or not · df4ab26a
      Monty authored
      This change also affects information_schema.tables
      
      The create table option "transactional=0 | 1" is now always shown for
      storage engines that supports both transactional/crash safe tables and
      non transactional tables.
      
      Before this patch the transactional=... option was only shown if the user
      specified transactional=... in the CREATE TABLE or ALTER TABLE statement.
      The reason for the change was to be able to make it easy to know if an Aria
      table is transactional or not.
      df4ab26a
    • Marko Mäkelä's avatar
      Merge 10.2 into 10.3 · e9aaa10c
      Marko Mäkelä authored
      e9aaa10c
    • Sergey Vojtovich's avatar
      Attempt fixing mroonga gcc 8 build failure · 49854811
      Sergey Vojtovich authored
      Part of MDEV-19061 - table_share used for reading statistical tables is
                           not protected
      49854811
    • Sergey Vojtovich's avatar
      Thread safe histograms loading · c2798784
      Sergey Vojtovich authored
      Previously multiple threads were allowed to load histograms concurrently.
      There were no known problems caused by this. But given amount of data
      races in this code, it'd happen sooner or later.
      
      To avoid scalability bottleneck, histograms loading is protected by
      per-TABLE_SHARE atomic variable.
      
      Whenever histograms were loaded by preceding statement (hot-path), a
      scalable load-acquire check is performed.
      
      Whenever histograms have to be loaded anew, mutual exclusion for loaders
      is established by atomic variable. If histograms are being loaded
      concurrently, statement waits until load is completed.
      
      - Table_statistics::total_hist_size moved to TABLE_STATISTICS_CB: only
        meaningful within TABLE_SHARE (not used for collected stats).
      - TABLE_STATISTICS_CB::histograms_can_be_read and
        TABLE_STATISTICS_CB::histograms_are_read are replaced with a tri state
        atomic variable.
      - Simplified away alloc_histograms_for_table_share().
      
      Note: there's still likely a data race if a thread attempts accessing
      histograms data after it failed to load it (because of concurrent load).
      It was there previously and goes out of the scope of this effort. One way
      of fixing it could be reviving TABLE::histograms_are_read and adding
      appropriate checks whenever it is needed.
      
      Part of MDEV-19061 - table_share used for reading statistical tables is
                           not protected
      c2798784
    • Sergey Vojtovich's avatar
      Thread safe statistics loading · 609a0d3d
      Sergey Vojtovich authored
      Previously multiple threads were allowed to load statistics concurrently.
      There were no known problems caused by this. But given amount of data
      races in this code, it'd happen sooner or later.
      
      To avoid scalability bottleneck, statistics loading is protected by
      per-TABLE_SHARE atomic variable.
      
      Whenever statistics were loaded by preceding statement (hot-path), a
      scalable load-acquire check is performed.
      
      Whenever statistics have to be loaded anew, mutual exclusion for loaders
      is established by atomic variable. If statistics are being loaded
      concurrently, statement waits until load is completed.
      
      TABLE_STATISTICS_CB::stats_can_be_read and
      TABLE_STATISTICS_CB::stats_is_read are replaced with a tri state atomic
      variable.
      
      Part of MDEV-19061 - table_share used for reading statistical tables is
                           not protected
      609a0d3d
    • Sergey Vojtovich's avatar
      Simplified away statistics_for_tables_is_needed() · 1055a7f4
      Sergey Vojtovich authored
      Removed redundant loops, integrated logics into the caller instead.
      Unified condition in read_statistics_for_tables(), less
      "table_share != NULL" checks, no more potential "table_share == NULL"
      dereferencing.
      
      Part of MDEV-19061 - table_share used for reading statistical tables is
                           not protected
      1055a7f4