1. 13 Mar, 2019 4 commits
    • Marko Mäkelä's avatar
      MDEV-18836 ASAN: heap-use-after-free after TRUNCATE · 56304875
      Marko Mäkelä authored
      row_drop_tables_for_mysql_in_background(): Copy the table name
      before closing the table handle, to avoid heap-use-after-free if
      another thread succeeds in dropping the table before
      row_drop_table_for_mysql_in_background() completes the table name lookup.
      
      dict_mem_create_temporary_tablename(): With innodb_safe_truncate=ON
      (the default), generate a simple, unique, collision-free table name
      using only the id, no pseudorandom component. This is safe, because
      on startup, we will drop any #sql tables that might exist in InnoDB.
      This is a backport from 10.3. It should have been backported already
      as part of backporting MDEV-14717,MDEV-14585 which were prerequisites
      for the MDEV-13564 backup-friendly TRUNCATE TABLE.
      This seems to reduce the chance of table creation failures in
      ha_innobase::truncate().
      
      ha_innobase::truncate(): Do not invoke close(), but instead
      mimic it, so that we can restore to the original table handle
      in case opening the truncated copy of the table failed.
      56304875
    • Marko Mäkelä's avatar
      Add an end-of-tests marker to ease merges · ec24dd0b
      Marko Mäkelä authored
      ec24dd0b
    • Jan Lindström's avatar
      MDEV-18577: Indexes problem on import dump SQL · d0ebb155
      Jan Lindström authored
      Problem was that we skipped background persistent statistics calculation
      on applier nodes if thread is marked as high priority (a.k.a BF).
      However, on applier nodes all DDL which is replicate will be executed
      as high priority i.e BF.
      
      Fixed by allowing background persistent statistics calculation on
      applier nodes even when thread is marked as BF. This could lead
      BF lock waits but for queries on that node needs that statistics.
      d0ebb155
    • Sergey Vojtovich's avatar
      MDEV-14984 - regression in connect performance · 20928e2e
      Sergey Vojtovich authored
      Removed redundant plugin_thdvar_cleanup() from end_connection(): called by
      THD::free_connection(), which always follows end_connection().
      
      Saves at least one lock(LOCK_plugin) and one
      rdlock(LOCK_system_variables_hash).
      
      Benchmarked on a 2socket/20core/40threads Broadwell system using sysbench
      connect brencmark @40 threads (with select 1 disabled).
      
      10.2 shows moderate improvement: 136219.93 -> 137766.31 CPS.
      10.3 is improvement is somewhat better: 93018.29 -> 101379.77 CPS.
      
      Also backported MyRocks memory leak fix from 10.4, which turned out to
      be unrelated.
      20928e2e
  2. 12 Mar, 2019 12 commits
    • Marko Mäkelä's avatar
      Revert a part of commit 676f43da · aa605846
      Marko Mäkelä authored
      We do want to ignore InnoDB's internal #sql-ib*.ibd at shutdown,
      because those tables will be dropped on the next startup.
      Failure to filter out these table names occasionally causes some
      unwanted output for tests that restart InnoDB soon after dropping
      or truncating tables, for example innodb.recovery_shutdown.
      aa605846
    • Marko Mäkelä's avatar
      TruncateLogParser::scan(): Simplify string operations · ee17f728
      Marko Mäkelä authored
      This also fixes -Wstringop-truncation that GCC 8 issued for strncpy().
      ee17f728
    • Marko Mäkelä's avatar
      Silence GCC 8 -Wno-class-memaccess · 945edfff
      Marko Mäkelä authored
      945edfff
    • Varun Gupta's avatar
      MDEV-18502: Server crash in find_field_in_tables upon 2nd execution of SP... · fe8cf7f1
      Varun Gupta authored
      MDEV-18502: Server crash in find_field_in_tables upon 2nd execution of SP which causes ER_WRONG_GROUP_FIELD
      
      Fixed by the commit cb11b3fb.
      Adding the test case for this issue.
      fe8cf7f1
    • Varun Gupta's avatar
      MDEV-18431: Select max + row_number giving incorrect result · a4e58882
      Varun Gupta authored
      The issue here was when we had a subquery and a window function in an expression in
      the select list then subquery was getting computed after window function computation.
      This resulted in incorrect results because the subquery was correlated and the fields
      in the subquery was pointing to the base table instead of the temporary table.
      
      The approach to fix this was to have an additional field in the temporary table
      for the subquery and to execute the subquery before window function execution.
      After execution the values for the subquery were stored in the temporary table
      and then when we needed to calcuate the expression, all we do is read the values
      from the temporary table for the subquery.
      a4e58882
    • Marko Mäkelä's avatar
      Add an end-of-tests marker to ease merges · f72760df
      Marko Mäkelä authored
      f72760df
    • Marko Mäkelä's avatar
      MDEV-18902 Uninitialized variable in recv_parse_log_recs() · bef947b4
      Marko Mäkelä authored
      recv_parse_log_recs(): Do not compare type if ptr==end_ptr
      (we have reached the end of the redo log parsing buffer),
      because it will not have been correctly initialized in that case.
      bef947b4
    • Marko Mäkelä's avatar
      MDEV-18878: Fix GCC -flifetime-dse · e070cfe3
      Marko Mäkelä authored
      GCC 6 and later can optimize away the memset() that is part of
      mem_heap_zalloc() in a placement new call. So, instead of relying
      on that kind of initialization, explicitly initialize the necessary
      fields in the constructors.
      
      que_common_t::que_common_t(): Initialize more fields in the
      default constructor.
      
      purge_vcol_info_t::purge_vcol_info_t(): Initialize all fields in
      the default constructor.
      
      purge_node_t::purge_node_t(): Initialize all necessary fields.
      
      Reference:
      
          https://gcc.gnu.org/bugzilla/show_bug.cgi?id=71388
      
          https://gcc.gnu.org/ml/gcc/2016-02/msg00207.html
      e070cfe3
    • Marko Mäkelä's avatar
      Merge 10.1 into 10.2 · e374755b
      Marko Mäkelä authored
      e374755b
    • Marko Mäkelä's avatar
      MDEV-18749: Fix GCC -flifetime-dse · 32de60bb
      Marko Mäkelä authored
      row_merge_create_fts_sort_index(): Initialize dict_col_t in
      an unambiguous way. GCC 6 and later appear to be able to optimize
      away the memset() that is part of mem_heap_zalloc() in the
      placement new call. Let us avoid using placement new in order
      to ensure that the objects will actually be initialized.
      
      https://gcc.gnu.org/bugzilla/show_bug.cgi?id=71388
      
      https://gcc.gnu.org/ml/gcc/2016-02/msg00207.html
      
      While the latter reference hints that the optimization is only
      applicable to non-POD types (and dict_col_t does not define
      any member functions before 10.2), it is most consistent to
      use the same initialization across all versions.
      32de60bb
    • Sergei Golubchik's avatar
      MDEV-17070 Table corruption or Assertion `table->file->stats.records > 0 ||... · 69abd437
      Sergei Golubchik authored
      MDEV-17070 Table corruption or Assertion `table->file->stats.records > 0 || error' or Assertion `!is_set() || (m_status == DA_OK_BULK && is_bulk_op())' failed upon actions on temporary table
      
      This was caused by a combination of factors:
      * MyISAM/Aria temporary tables historically never saved the state
        to disk (MYI/MAI), because the state never needed to persist
      * certain ALTER TABLE operations modify the original TABLE structure
        and if they fail, the original table has to be reopened to
        revert all changes (m_needs_reopen=1)
      
      as a result, when ALTER fails and MyISAM/Aria temp table gets reopened,
      it reads the stale state from the disk.
      
      As a fix, MyISAM/Aria tables now *always* write the state to disk
      on close, *unless* HA_EXTRA_PREPARE_FOR_DROP was done first. And
      the server now always does HA_EXTRA_PREPARE_FOR_DROP before dropping
      a temporary table.
      69abd437
    • Sergei Golubchik's avatar
      7025a51a
  3. 11 Mar, 2019 10 commits
    • Alexey Botchkov's avatar
      MDEV-18886 JSON_ARRAY() does not recognise JSON argument. · acb4a872
      Alexey Botchkov authored
      JSON_ARRAY and JSON_OBJECT functions with no arguments now get the
      connection charset. Item_func_convert_charset returns the correct
      is_json() flag.
      acb4a872
    • Sergey Vojtovich's avatar
      ea52ecbc
    • Sergey Vojtovich's avatar
      MDEV-17595 - ALTER TABLE ADD FOREIGN KEY crash · 149b7547
      Sergey Vojtovich authored
      ALTER TABLE ... ADD FOREIGN KEY may trigger assertion failure when
      it has LOCK=EXCLUSIVE clause or concurrent FLUSH TABLES is being
      executed.
      
      In both cases being altered table is marked as flushed, which forces
      subsequent attempt to open parent table to re-open. Which in turn is
      not allowed while transaction is running.
      
      Rather than opening parent table, just take appropriate MDL lock.
      
      Also removed table_already_fk_prelocked() check: MDL itself has much
      better methods to handle duplicate locks. E.g. the former won't acquire
      MDL_SHARED_NO_WRITE if it already has MDL_SHARED_READ.
      149b7547
    • Marko Mäkelä's avatar
      MDEV-18878: Correct a condition · 28e713dc
      Marko Mäkelä authored
      Initialize node->trx_id before checking if a table can be skipped.
      28e713dc
    • Marko Mäkelä's avatar
      Try to address MDEV-17745 · 21975280
      Marko Mäkelä authored
      wait_all_purged.inc: Wait for 60 seconds instead of 30 seconds.
      Purge can be slow on buildbot, especially in ASAN-instrumented builds.
      21975280
    • Marko Mäkelä's avatar
      MDEV-18878: Slimmer purge in non-debug builds · 6e767046
      Marko Mäkelä authored
      purge_node_t::in_progress: Replaces purge_node_t::done.
      Only present in debug builds.
      
      purge_node_t::start(): Moved from the start of row_purge_step().
      
      purge_node_t::end(): Replaces row_purge_end().
      
      trx_purge_attach_undo_recs(): Omit a check from non-debug builds.
      6e767046
    • Marko Mäkelä's avatar
      MDEV-18878 Purge: Optimize away futile table lookups · 1ab049e5
      Marko Mäkelä authored
      If a table has been dropped, rebuilt, or its tablespace has been
      discarded or the table is corrupted, it does not make sense to
      look up that table again while purging old undo log records.
      
      purge_node_t::purge_node_t(): Replaces row_purge_node_create().
      
      que_common_t::que_common_t(): Constructor.
      
      row_import_update_index_root(): Remove the constant parameter
      dict_locked=true, and update the table->def_trx_id in the cache.
      
      purge_node_t::unavailable_table_id: The latest unavailable table ID,
      to avoid future lookups.
      
      purge_node_t::def_trx_id: The latest modification of the table
      identified by unavailable_table_id, or TRX_ID_MAX.
      
      purge_node_t::is_skipped(): Determine if a table should be skipped.
      
      purge_node_t::skip(): Note that a table should be skipped.
      1ab049e5
    • Marko Mäkelä's avatar
      Merge 10.1 into 10.2 · 3ea49d35
      Marko Mäkelä authored
      3ea49d35
    • Eugene Kosov's avatar
      MDEV-17703 Add WITH_UBSAN switch to CMake similar to WITH_ASAN · 2a2ab121
      Eugene Kosov authored
      This can be useful:
      UBSAN_OPTIONS=log_path=/some/path
      
      clang users may want to increase stack size in include/my_pthread.h or enable
      some optimizations
      2a2ab121
    • Marko Mäkelä's avatar
      Clean up mysql-test/suite/galera/disabled.def again · 04150218
      Marko Mäkelä authored
      Clean up after commit 0957d257
      which introduced some disorder (unsorted or duplicated test names).
      04150218
  4. 09 Mar, 2019 6 commits
  5. 08 Mar, 2019 3 commits
  6. 07 Mar, 2019 5 commits