1. 07 Dec, 2021 2 commits
    • Marko Mäkelä's avatar
      MDEV-27190 InnoDB upgrade from 10.2, 10.3, 10.4 is not crash-safe · cfcfdc65
      Marko Mäkelä authored
      During startup, InnoDB must write a FILE_CHECKPOINT record.
      However, before MDEV-12353 (in MariaDB Server 10.2, 10.3, 10.4)
      the corresponding record MLOG_CHECKPOINT was encoded in a different way.
      
      When we are upgrading from a logically empty 10.2, 10.3, or 10.4 redo log,
      we must not write anything to the old log file, because if the server were
      killed during the upgrade, we would end up with a corrupted log file, and
      both the old and the new server would refuse to start up.
      
      On upgrade, we must simply create a new logically empty log file
      and replace the old ib_logfile0 with that.
      cfcfdc65
    • Eugene Kosov's avatar
      MDEV-27183 optimize std::map lookup in during crash recovery · 890c5517
      Eugene Kosov authored
      This is a low hanging fruit. Before this patch std::map::emplace() was
      a ~50% of the whole recv_sys_t::parse() operation in by test.
      After the fix it's only ~20%.
      
      recv_sys_t::parse() recv_sys_t::pages is a collection of all pages
      to recovery. Often, there are multiple changes for a single page.
      Often, they go in a row and for such cases let's avoid
      lookup in a std::map. cached_pages_it serves as a cache
      of size 1.
      
      recv_sys_t::add(): replace page_id argument with a std::map::iterator
      890c5517
  2. 06 Dec, 2021 1 commit
  3. 03 Dec, 2021 6 commits
  4. 01 Dec, 2021 2 commits
    • Marko Mäkelä's avatar
      MDEV-12353 fixup: Correct a comment · f9726ced
      Marko Mäkelä authored
      Several EXTENDED type records have already been implemented.
      f9726ced
    • Jan Lindström's avatar
      Fix bad galera tests · d7b37de9
      Jan Lindström authored
      * galera_kill_applier : we should make sure that node has
        correct number of wsrep appliers
      * galera_bad_wsrep_new_cluster: This test restarts both nodes,
      so it is bad on mtr. Make sure it is run alone
      * galera_update_limit : Make sure we have PK when needed
      galera_as_slave_replay : bf abort was not consistent
      * galera_unicode_pk : Add wait_conditions so that all nodes
      are part of cluster and DDL and INSERT has replicated before
      any further operations are done.
      * galera_bf_abort_at_after_statement : Add wait_conditions
      to make sure all nodes are part of cluster and that DDL
      and INSERT has replicated. Make sure we reset DEBUG_SYNC.
      d7b37de9
  5. 30 Nov, 2021 1 commit
    • Martin Beck's avatar
      MDEV-27088: Server crash on ARM (WMM architecture) due to missing barriers in lf-hash (10.5) · 4ebac0fc
      Martin Beck authored
      MariaDB server crashes on ARM (weak memory model architecture) while
      concurrently executing l_find to load node->key and add_to_purgatory
      to store node->key = NULL. l_find then uses key (which is NULL), to
      pass it to a comparison function.
      
      The specific problem is the out-of-order execution that happens on a
      weak memory model architecture. Two essential reorderings are possible,
      which need to be prevented.
      
      a) As l_find has no barriers in place between the optimistic read of
      the key field lf_hash.cc#L117 and the verification of link lf_hash.cc#L124,
      the processor can reorder the load to happen after the while-loop.
      
      In that case, a concurrent thread executing add_to_purgatory on the same
      node can be scheduled to store NULL at the key field lf_alloc-pin.c#L253
      before key is loaded in l_find.
      
      b) A node is marked as deleted by a CAS in l_delete lf_hash.cc#L247 and
      taken off the list with an upfollowing CAS lf_hash.cc#L252. Only if both
      CAS succeed, the key field is written to by add_to_purgatory. However,
      due to a missing barrier, the relaxed store of key lf_alloc-pin.c#L253
      can be moved ahead of the two CAS operations, which makes the value of
      the local purgatory list stored by add_to_purgatory visible to all threads
      operating on the list. As the node is not marked as deleted yet, the
      same error occurs in l_find.
      
      This change three accesses to be atomic.
      
      * optimistic read of key in l_find lf_hash.cc#L117
      * read of link for verification lf_hash.cc#L124
      * write of key in add_to_purgatory lf_alloc-pin.c#L253
      
      Reviewers: Sergei Vojtovich, Sergei Golubchik
      
      Fixes: MDEV-23510 / d30c1331a18d875e553f3fcf544997e4f33fb943
      4ebac0fc
  6. 29 Nov, 2021 5 commits
  7. 26 Nov, 2021 4 commits
    • Sergei Golubchik's avatar
      MDEV-26972 MTR worker aborts after server restart failure · f5441ef4
      Sergei Golubchik authored
      restore the old behavior where without a debugger mtr does not
      wait for mysqld to start. It was broken in feacc0aa
      f5441ef4
    • Sergei Golubchik's avatar
      MDEV-26755 innodb.undo_truncate: ilink::assert_linked(): Assertion `prev != 0 && next != 0' failed · a96b4282
      Sergei Golubchik authored
      close_connections() in mysqld.cc sends a signal to all threads.
      But InnoDB is too busy purging, doesn't react immediately.
      close_connections() waits 20 seconds, which isn't enough in this
      particular case, and then unlinks all threads from
      the list and forcibly closes their vio connection.
      
      InnoDB background  threads have no vio connection to close, but
      they're unlinked all the same. So when later they finally notice
      the shutdown request and try to unlink themselves, they fail to
      assert that they're still linked.
      
      Fix: don't assert_linked, as another thread can unlink this THD anytime
      a96b4282
    • Sergei Golubchik's avatar
      add a test case · 4ba74785
      Sergei Golubchik authored
      MDEV-20330 Combination of "," (comma), cross join and left join fails to parse
      4ba74785
    • Hugo Wen's avatar
      MDEV-27124: Update definer of Add/DropGeometryColumn procedures from 'root' to 'mariadb.sys' · e9572e53
      Hugo Wen authored
      From 10.4.13, the `mariadb.sys` user was created to replace `root` definers.
       - In commit 0253ea7f, definer of
         Add/DropGeometryColumn procedures was changed to `mariadb.sys`, in
         `scripts/maria_add_gis_sp.sql.in`.
         However, maria_add_gis_sp.sql only applies to new databases created by
         installation script. Databases upgraded from old versions will miss this
         change.
       - In addition, according to commit
         0d6d801e(MDEV-23102), in some scenarios
         when root user is replaced it will skip creating `mariadb.sys` user.
      
      This commit is to update the definer from `root` to `mariadb.sys` during
      upgrade. It only makes the change if the original definers are root.
      
      Doesn't choose to execute `maria_add_gis_sp.sql` in upgrade script to
      recreate the procedures is because of considering the scenarios of
      MDEV-23102 that `root` user is replaced and `mariadb.sys` is not created.
      
      All new code of the whole pull request, including one or several files
      that are either new files or modified ones, are contributed under the
      BSD-new license. I am contributing on behalf of my employer Amazon Web
      Services, Inc.
      e9572e53
  8. 25 Nov, 2021 1 commit
  9. 24 Nov, 2021 10 commits
    • Sergei Krivonos's avatar
      Json_writer_object add integers · cba065f4
      Sergei Krivonos authored
      cba065f4
    • Sergei Krivonos's avatar
    • ryancaicse's avatar
      MDEV-26558 Fix a deadlock due to cyclic dependence · f809a4fb
      ryancaicse authored
      Fix a potential deadlock bug between locks ctrl_mutex and entry->mutex
      f809a4fb
    • Marko Mäkelä's avatar
      Cleanup: offsetof instead of my_offsetof · b53ee760
      Marko Mäkelä authored
      Sys_lc_messages, Sys_lc_time_names: Use offsetof(MY_LOCALE, ...)
      because the type has standard layout.
      b53ee760
    • Marko Mäkelä's avatar
      MDEV-26682 fixup: GCC -Wunused-variable · 917b4210
      Marko Mäkelä authored
      917b4210
    • Marko Mäkelä's avatar
      PFS_events_statements cleanup: Use offsetof · 6b2b5108
      Marko Mäkelä authored
      The macro my_offsetof() performs pointer arithmetics that may be
      undefined behavior. As reported in MDEV-26272, it may cause
      clang -fsanitize=undefined to generate invalid memory references.
      
      struct PFS_events_statements: Convert to std::is_standard_layout
      by encapsulating the standard-layout struct PFS_events instead of
      deriving from it, so that the standard macro offsetof() can be used.
      
      PFS_events_statements::copy(): Renamed from copy_events_statements().
      A cast to void* is now needed in memcpy() to avoid GCC -Wclass-memaccess
      "writing to an object ... leaves 64 bytes unchanged".
      6b2b5108
    • Marko Mäkelä's avatar
      Cleanup: offsetof instead of my_offsetof · 7e7235fa
      Marko Mäkelä authored
      mdl_hash_function(): Use plain offsetof; MDL_key has standard layout.
      7e7235fa
    • Daniel Black's avatar
      Debian: comment default config · 8d398710
      Daniel Black authored
      There's no need for Debian to set config items to their
      default. Left commented user, datadir and tmpdir as
      these may want to be changed. lc-messages and skip-external-locks
      are so infrequently set even listing them looks overly verbose.
      
      socket left uncommented in [client-server] as various client
      implementations may have different defaults compiled in.
      8d398710
    • Daniel Black's avatar
      mysql_install_db: remove MySQL references · ef179dad
      Daniel Black authored
      MySQL documentation isn't going to help our
      users and we shouldn't refer to it.
      ef179dad
    • Marc Olivier Bergeron's avatar
      MDEV-27066: Fixed scientific notation parsing bug · 749d8ded
      Marc Olivier Bergeron authored
      The bug occurs where the float token containing a dot with an 'e'
      notation was dropped from the request completely.
      
      This causes a manner of invalid SQL statements like:
      
      select id 1.e, char 10.e(id 2.e), concat 3.e('a'12356.e,'b'1.e,'c'1.1234e)1.e, 12 1.e*2 1.e, 12 1.e/2 1.e, 12 1.e|2 1.e, 12 1.e^2 1.e, 12 1.e%2 1.e, 12 1.e&2 from test;
      
      To be parsed correctly as if it was:
      
      select id, char(id), concat('a','b','c'), 12*2, 12/2, 12|2, 12^2, 12%2, 12&2 from test.test;
      
      This correct parsing occurs when e is followed by any of:
      
      ( ) . , | & % * ^ /
      749d8ded
  10. 23 Nov, 2021 6 commits
    • Alexey Bychko's avatar
      MDEV-22522 RPM packages have meaningless summary/description · fe065f8d
      Alexey Bychko authored
      this patch moves cpack summury and description for optional packages
      to the appropriate CMakeLists.txt files
      fe065f8d
    • Julius Goryavsky's avatar
      1c7dd233
    • Julius Goryavsky's avatar
      MDEV-26915: SST scripts do not take log_bin_index setting into account · 2f51511c
      Julius Goryavsky authored
      Currently, SST scripts assume that the filename specified in
      the --log-bin-index argument either does not contain an extension
      or uses the standard ".index" extension. Similar assumptions are
      used for the log_bin_index parameter read from the configuration
      file. This commit adds support for arbitrary extensions for the
      index file paths.
      2f51511c
    • Julius Goryavsky's avatar
      MDEV-26064: mariabackup SST fails when starting with --innodb-force-recovery · b9525997
      Julius Goryavsky authored
      If the server is started with the --innodb-force-recovery argument
      on the command line, then during SST this argument can be passed to
      mariabackup only at the --prepare stage, and accordingly it must be
      removed from the --mysqld-args list (and it is not should be passed
      to mariabackup otherwise).
      
      This commit fixes a flaw in the SST scripts and add a test that
      checks the ability to run the joiner node in a configuration that
      uses --innodb-force-recovery=1.
      b9525997
    • Julius Goryavsky's avatar
      MDEV-26915: SST scripts do not take log_bin_index setting into account · 1ea7d596
      Julius Goryavsky authored
      Currently, SST scripts assume that the filename specified in
      the --log-bin-index argument either does not contain an extension
      or uses the standard ".index" extension. Similar assumptions are
      used for the log_bin_index parameter read from the configuration
      file. This commit adds support for arbitrary extensions for the
      index file paths.
      1ea7d596
    • Julius Goryavsky's avatar
      MDEV-26064: mariabackup SST fails when starting with --innodb-force-recovery · f21a36d5
      Julius Goryavsky authored
      If the server is started with the --innodb-force-recovery argument
      on the command line, then during SST this argument can be passed to
      mariabackup only at the --prepare stage, and accordingly it must be
      removed from the --mysqld-args list (and it is not should be passed
      to mariabackup otherwise).
      
      This commit fixes a flaw in the SST scripts and add a test that
      checks the ability to run the joiner node in a configuration that
      uses --innodb-force-recovery=1.
      f21a36d5
  11. 21 Nov, 2021 1 commit
    • Igor Babaev's avatar
      MDEV-26470 "No database" selected when using CTE in a subquery of DELETE statement · 114e18b8
      Igor Babaev authored
      This bug led to reporting bogus messages "No database selected" for DELETE
      statements if they used subqueries in their WHERE conditions and these
      subqueries contained references to CTEs.
      The bug happened because the grammar rule for DELETE statement did not
      call the function LEX::check_cte_dependencies_and_resolve_references() and
      as a result of it references to CTEs were not identified as such.
      
      Approved by Oleksandr Byelkin <sanja@mariadb.com>
      114e18b8
  12. 20 Nov, 2021 1 commit
    • Igor Babaev's avatar
      MDEV-27086 "No database selected" when using UNION of CTEs to define table · 0dae4163
      Igor Babaev authored
      This bug concerned only CREATE TABLE statements of the form
        CREATE TABLE <table name> AS <with clause> <union>.
      For such a statement not all references to CTE used in <union> were resolved.
      As a result a bogus message was reported for the first unresolved reference.
      This happened because for such statements the function resolving references
      to CTEs LEX::check_cte_dependencies_and_resolve_references() was called
      prematurely in the parser.
      
      Approved by Oleksandr Byelkin <sanja@mariadb.com>
      0dae4163