1. 21 Jun, 2022 7 commits
    • Marko Mäkelä's avatar
      Merge 10.8 into 10.9 · 707f2aa2
      Marko Mäkelä authored
      707f2aa2
    • Marko Mäkelä's avatar
      Merge 10.7 into 10.8 · 54ac356d
      Marko Mäkelä authored
      54ac356d
    • Marko Mäkelä's avatar
      Merge 10.6 into 10.7 · 6680fd8d
      Marko Mäkelä authored
      6680fd8d
    • Marko Mäkelä's avatar
      MDEV-28836: Memory alignment cleanup · 37946731
      Marko Mäkelä authored
      Table_cache_instance: Define the structure aligned at
      the CPU cache line, and remove a pad[] data member.
      Krunal Bauskar reported this to improve performance on ARMv8.
      
      aligned_malloc(): Wrapper for the Microsoft _aligned_malloc()
      and the ISO/IEC 9899:2011 <stdlib.h> aligned_alloc().
      Note: The parameters are in the Microsoft order (size, alignment),
      opposite of aligned_alloc(alignment, size).
      Note: The standard defines that size must be an integer multiple
      of alignment. It is enforced by AddressSanitizer but not by GNU libc
      on Linux.
      
      aligned_free(): Wrapper for the Microsoft _aligned_free() and
      the standard free().
      
      HAVE_ALIGNED_ALLOC: A new test. Unfortunately, support for
      aligned_alloc() may still be missing on some platforms.
      We will fall back to posix_memalign() for those cases.
      
      HAVE_MEMALIGN: Remove, along with any use of the nonstandard memalign().
      
      PFS_ALIGNEMENT (sic): Removed; we will use CPU_LEVEL1_DCACHE_LINESIZE.
      
      PFS_ALIGNED: Defined using the C++11 keyword alignas.
      
      buf_pool_t::page_hash_table::create(),
      lock_sys_t::hash_table::create():
      lock_sys_t::hash_table::resize(): Pad the allocation size to an
      integer multiple of the alignment.
      
      Reviewed by: Vladislav Vaintroub
      37946731
    • Marko Mäkelä's avatar
      MDEV-28870 InnoDB: Missing FILE_CREATE, FILE_DELETE or FILE_MODIFY before FILE_CHECKPOINT · 2e43af69
      Marko Mäkelä authored
      There was a race condition between log_checkpoint_low() and
      deleting or renaming data files. The scenario is as follows:
      
      1. The buffer pool does not contain dirty pages.
      2. A FILE_DELETE or FILE_RENAME record is written.
      3. The checkpoint LSN will be moved ahead of the write of the record.
      4. The server is killed before the file is actually renamed or deleted.
      
      We will prevent this race condition by ensuring that a log checkpoint
      cannot occur between the durable write and the file system operation:
      
      1. Durably write the FILE_DELETE or FILE_RENAME record.
      2. Perform the file system operation.
      3. Allow any log checkpoint to proceed.
      
      mtr_t::commit_file(): Implement the DELETE or RENAME logic.
      
      fil_delete_tablespace(): Delegate some of the logic to
      mtr_t::commit_file().
      
      fil_space_t::rename(): Delegate some logic to mtr_t::commit_file().
      Remove the debug injection point fil_rename_tablespace_failure_2
      because we do test RENAME failures without any debug injection.
      
      fil_name_write_rename_low(), fil_name_write_rename(): Remove.
      
      Tested by Matthias Leich
      2e43af69
    • Marko Mäkelä's avatar
      MDEV-28845 fixup: Prevent an infinite loop · 55f02c24
      Marko Mäkelä authored
      buf_page_create_low(): Before retrying, release the exclusive page latch
      in order to prevent an infinite loop in buf_pool_t::corrupted_evict().
      55f02c24
    • Marko Mäkelä's avatar
      MDEV-28782 fixup: ./mtr --embedded · 3b662c6e
      Marko Mäkelä authored
      3b662c6e
  2. 20 Jun, 2022 3 commits
    • Vladislav Vaintroub's avatar
      MDEV-28819 Statically compiled encryption plugins do not work · 3aabda7e
      Vladislav Vaintroub authored
      Disable building hashicorp encryption plugin statically
      3aabda7e
    • Marko Mäkelä's avatar
      Merge 10.8 into 10.9 · 70fffc70
      Marko Mäkelä authored
      70fffc70
    • Marko Mäkelä's avatar
      MDEV-28879 Assertion `l->lsn <= log_sys.get_lsn()' failed around recv_recover_page · 325e6aa7
      Marko Mäkelä authored
      recv_recover_page(): Correct a debug assertion to refer to recv_sys.lsn,
      which may be ahead of log_sys.lsn during non-final recovery batches.
      In commit 685d958e (MDEV-14425)
      when some redundant LSN fields were removed,
      log_sys.log.scanned_lsn had been replaced with a reference to
      log_sys.lsn instead of the more appropriate recv_sys.lsn.
      
      recv_scan_log(): Remove a redundant call to log_sys.set_recovered_lsn().
      It suffices to adjust the log_sys.lsn after parsing (and before starting
      to apply) records for the last batch.
      
      Note: Normally, log_sys.lsn must be the latest log sequence number.
      Before the final recovery batch, this may be safely violated, because
      log_write_up_to() will be a no-op. That function will be invoked by the
      buf_flush_page_cleaner thread to initiate writes of recovered pages.
      325e6aa7
  3. 18 Jun, 2022 1 commit
  4. 17 Jun, 2022 2 commits
  5. 16 Jun, 2022 10 commits
  6. 15 Jun, 2022 4 commits
    • Marko Mäkelä's avatar
      MDEV-28845 InnoDB: Failing assertion: bpage->can_relocate() in buf0lru.cc · 253806df
      Marko Mäkelä authored
      Since commit 0b47c126 (MDEV-13542)
      we treat all-zero pages as corrupted ones.
      
      During a stress test, a read-ahead of an all-zero page was triggered
      and the page read was completed concurrently with buf_page_create_low().
      This caused the assertion to fail, because buf_page_create_low() was
      waiting for the page latch.
      
      buf_page_get_low(): Only invoke buf_pool_t::corrupted_evict()
      if the block was not already marked as corrupted.
      
      buf_page_create_low(): On page identifier mismatch, retry the
      buf_pool.page_hash lookup.
      
      buf_pool_t::corrupted_evict(): Set the state of the block to FREED
      so that a concurrent buf_page_get_low() will refuse to load the page.
      Wait for the page latch to be vacant before proceeding to remove
      the block from buf_pool.page_hash and buf_pool.LRU.
      
      page_id_t::set_corrupted(), page_id_t::is_corrupted(): Accessors
      for indicating a corrupted page identifier.
      
      Tested by Matthias Leich
      253806df
    • Marko Mäkelä's avatar
      MDEV-13542 fixup: Relax an assertion · 0850267d
      Marko Mäkelä authored
      0850267d
    • Vlad Lesin's avatar
      MDEV-28832 infinite loop in mariabackup if log LOG_HEADER_FORMAT field is 0 · 27309fc6
      Vlad Lesin authored
      Avoid the loop with getting rid of back and forth jumping.
      27309fc6
    • Marko Mäkelä's avatar
      Merge 10.8 into 10.9 · 9fe784ff
      Marko Mäkelä authored
      9fe784ff
  7. 14 Jun, 2022 8 commits
    • Marko Mäkelä's avatar
      MDEV-28766: SET GLOBAL innodb_log_file_buffering · 4c0cd953
      Marko Mäkelä authored
      In commit c4c88307 (MDEV-28111) we disabled
      the file system cache on the InnoDB write-ahead log file (ib_logfile0)
      by default on Linux.
      
      It turns out that especially with innodb_flush_trx_log_at_commit=2,
      writing to the log via the file system cache typically improves throughput,
      especially on slow storage or at a small number of concurrent transactions.
      For other values of innodb_flush_log_at_trx_commit, direct writes were
      observed to be mostly but not always faster. Whether it pays off to
      disable the file system cache on the log may depend on the type of storage,
      the workload, and the operating system kernel version.
      
      On Linux and Microsoft Windows, we will introduce the settable Boolean
      global variable innodb_log_file_buffering that indicates whether the
      file system cache on the redo log file is enabled. The default value is
      innodb_log_file_buffering=OFF. If the server is started up with
      innodb_flush_log_at_trx_commit=2, the value will be changed to
      innodb_log_file_buffering=ON.
      
      When a persistent memory interface is being used for the log,
      the value cannot be changed from innodb_log_file_buffering=OFF.
      On Linux, when the physical block size cannot be determined
      to be a power of 2 between 64 and 4096 bytes, the file system cache
      cannot be disabled, and innodb_log_file_buffering=ON cannot be changed.
      
      Server log messages will indicate whether the file system cache is
      enabled for the redo log:
      
      [Note] InnoDB: Buffered log writes (block size=512 bytes)
      [Note] InnoDB: File system buffers for log disabled (block size=512 bytes)
      
      After this change, the startup parameter innodb_flush_method will no
      longer control whether O_DIRECT will be set on the redo log on Linux.
      
      On other operating systems that support O_DIRECT, no interface has been
      implemented for controlling the file system cache for the redo log.
      The innodb_flush_method values O_DIRECT, O_DIRECT_NO_FSYNC, O_DSYNC
      will enable O_DIRECT for data files, not the log.
      
      Tested by: Matthias Leich, Axel Schwenke
      4c0cd953
    • Marko Mäkelä's avatar
      Merge 10.7 into 10.8 · 813986a6
      Marko Mäkelä authored
      813986a6
    • Marko Mäkelä's avatar
      Merge 10.6 into 10.7 · 42d3a7b6
      Marko Mäkelä authored
      42d3a7b6
    • Marko Mäkelä's avatar
      MDEV-28840 innodb_undo_log_truncate is not crash-safe · 6c82ab4f
      Marko Mäkelä authored
      trx_purge_free_segment(): Do mark that the block will be modified.
      
      It seems possible that this regression was introduced by the
      changes to the page-freeing logic
      in commit 4179f93d (MDEV-18976).
      
      Tested by: Matthias Leich
      6c82ab4f
    • Thirunarayanan Balathandayuthapani's avatar
      MDEV-25581 Allow user thread to do InnoDB fts cache sync · 6c669b95
      Thirunarayanan Balathandayuthapani authored
      - innodb_fts.sync_block doesn't make sense after MDEV-25581's patch
      because fts cache syncing is done as a part of insert operation
      and it leads to completion of select over insert sometimes.
      This test case is not relevant any more
      6c669b95
    • Marko Mäkelä's avatar
      Merge 10.6 into 10.7 · ddf511c4
      Marko Mäkelä authored
      ddf511c4
    • Marko Mäkelä's avatar
      Merge 10.5 into 10.6 · 1f1fa7e0
      Marko Mäkelä authored
      1f1fa7e0
    • Marko Mäkelä's avatar
      MDEV-28828 SIGSEGV in buf_flush_LRU_list_batch · 4849d94f
      Marko Mäkelä authored
      In commit 73fee39e (MDEV-27985)
      a regression was introduced that would cause bpage=nullptr to
      be referenced.
      
      buf_flush_LRU_list_batch(): Always terminate the loop upon
      encountering a null pointer.
      4849d94f
  8. 13 Jun, 2022 5 commits