1. 11 Jan, 2017 8 commits
    • Monty's avatar
      New simpler bugfix for UPDATE and virtual BLOBs · ea1b2504
      Monty authored
      When updating a table with virtual BLOB columns, the following might
      happen:
      - an old record is read from the table, it has no virtual blob values
      - update_virtual_fields() is run, vcol blob gets its value into the
        record. But only a pointer to the value is in the table->record[0],
        the value is in Field_blob::value String (but it doesn't have to be!
        it can be in the record, if the column is just a copy of another
        columns: ... b VARCHAR, c BLOB AS (b) ...)
      - store_record(table,record[1]), old record now is in record[1]
      - fill_record() prepares new values in record[0], vcol blob is updated,
        new value replaces the old one in the Field_blob::value
      - now both record[1] and record[0] have a pointer that points to the
        *new* vcol blob value. Or record[1] has a pointer to nowhere if
         Field_blob::value had to realloc.
      
      To fix this I have introduced a new String object 'read_value' in
      Field_blob.  When updating virtual columns when a row has been read,
      the allocated value is stored in 'read_value' instead of 'value'.  The
      allocated blobs for the new row is stored in 'value' as before.
      
      I also made, as a safety precaution, the insert delayed handling of
      blobs more general by using value to store strings instead of the
      record.  This ensures that virtual functions on delayed insert should
      work in as in the case of normal insert.
      
      Triggers are now properly updating the read, write and vcol maps for used
      fields. This means that we don't need VCOL_UPDATE_FOR_READ_WRITE anymore
      and there is no need for any other special handling of triggers in
      update_virtual_fields().
      
      To be able to test how many times virtual fields are invoked, I also
      relaxed rules that one can use local (@) variables in DEFAULT and non
      persistent virtual field expressions.
      ea1b2504
    • Monty's avatar
      Revert "bugfix: UPDATE and virtual BLOBs" · 7454087d
      Monty authored
      This reverts commit f73bdb68.
      7454087d
    • Monty's avatar
      Fixed issues found by buildbot · 1628a2ae
      Monty authored
      - MDEV-11621 rpl.rpl_gtid_stop_start fails sporadically in buildbot
      - MDEV-11620 rpl.rpl_upgrade_master_info fails sporadically in buildbot
      
      The issue above was probably that the build machine was overworked and the
      shutdown took longer than 30 resp 10 seconds, which caused MyISAM tables
      to be marked as crashed.
      Fixed by flushing myisam tables before doing a forced shutdown/kill.
      I also increased timeout for forced shutdown from 10 seconds to 60 seconds
      to fix other possible issues on slow machines.
      
      Fixed also some compiler warnings
      1628a2ae
    • Monty's avatar
      Fixed bugs found by mysql-test-run: · 1afb1704
      Monty authored
      - privilege_table_io.test didn't properly reset roles_mapping
      - Fixed memory allocation problem with CHECK CONSTRAINT, found when
        running --valgrind main.check_constraint
      1afb1704
    • Sergei Golubchik's avatar
      Make atomic writes general · ed008a74
      Sergei Golubchik authored
      - Atomic writes are enabled by default
      - Automatically detect if device supports atomic write and use it if
        atomic writes are enabled
      - Remove ATOMIC WRITE options from CREATE TABLE
        - Atomic write is a device option, not a table options as the table may
          crash if the media changes
      - Add support for SHANNON SSD cards
      ed008a74
    • Monty's avatar
      Removed usage of my_hash_search() with uninitialized HASH. · ed0bc17b
      Monty authored
      - Not documented on intened usage
      - Extra checking takes time for all HASH usage
      ed0bc17b
    • Monty's avatar
      Improve mysys/hash by caching hash_nr · e80ad58d
      Monty authored
      This is done without using any additional memory
      Added internal test case
      
      This is similar to MDEV-7716
      e80ad58d
    • Monty's avatar
      Fixes for running with gcov · 67034b6d
      Monty authored
      67034b6d
  2. 10 Jan, 2017 3 commits
    • Marko Mäkelä's avatar
      Merge 10.1 into 10.2 · f27ca6f6
      Marko Mäkelä authored
      f27ca6f6
    • Marko Mäkelä's avatar
      Merge 10.0 into 10.1 · 5044dae2
      Marko Mäkelä authored
      5044dae2
    • Marko Mäkelä's avatar
      Fix an innodb_plugin leak noted in MDEV-11686 · 78e6fafc
      Marko Mäkelä authored
      buf_flush_init_flush_rbt() was called too early in MariaDB server 10.0,
      10.1, MySQL 5.5 and MySQL 5.6. The memory leak has been fixed in
      the XtraDB storage engine and in MySQL 5.7.
      
      As a result, when the server is started to initialize new data files,
      the buf_pool->flush_rbt will be created unnecessarily and then leaked.
      This memory leak was noticed in MariaDB server 10.1 when running the
      test encryption.innodb_first_page.
      78e6fafc
  3. 09 Jan, 2017 4 commits
  4. 08 Jan, 2017 1 commit
    • Monty's avatar
      MDEV-11317: `! is_set()' or `!is_set() || (m_status == DA_OK_BULK &&... · eed319b6
      Monty authored
      MDEV-11317: `! is_set()' or `!is_set() || (m_status == DA_OK_BULK && is_bulk_op())' fails in Diagnostics_area::set_ok_status on CREATE OR REPLACE with ARCHIVE table
      
      Problem was with deleting non existing .frm file for a storage engine that
      doesn't have .frm files (yet)
      
      Fixed by not giving an error for non existing .frm files for storage engines
      that are using discovery
      Fixed also valgrind supression related to the given test case
      eed319b6
  5. 07 Jan, 2017 3 commits
  6. 06 Jan, 2017 7 commits
    • Vladislav Vaintroub's avatar
      MDEV-11087 Search path for my.ini is wrong for default installation · eaf6b053
      Vladislav Vaintroub authored
      Add <install_root>/data/my.ini to the search path -  this my.ini location
      is used since MariaDB 5.2
      eaf6b053
    • Vladislav Vaintroub's avatar
      Windows : use meaningful DEFAULT_MYSQL_HOME - base directory · 82b8741a
      Vladislav Vaintroub authored
      for the default installation.
      
      It is now defined as "C:/Program Files/MariaDB ${MYSQL_BASE_VERSION}"
      which is where installer indeed puts it by default.
      
      It still does not cover every case -32bit installer on 64 bit Windows would put installation
      root under  "C:/Program Files (x86)", but better than the path used
      previously C:/MariaDB${MYSQL_BASE_VERSION}, which was never correct.
      82b8741a
    • Vladislav Vaintroub's avatar
      MDEV-11088 Client plugins cannot be loaded by command line tools · ae6eb7a0
      Vladislav Vaintroub authored
      in default installation.
      
      Added plugin-dir to the [client] section of the generated my.ini,
      so that  installed services (MSI or mysql_install_db.exe) would be able to
      find plugin directory.
      ae6eb7a0
    • Marko Mäkelä's avatar
      Suppress warnings of NUMA not working. · bbd4844a
      Marko Mäkelä authored
      bbd4844a
    • Marko Mäkelä's avatar
      ac0b0efa
    • Dmitry Lenev's avatar
      MDEV-9084 Calling a stored function from a nested select from temporary table... · e4978d26
      Dmitry Lenev authored
      MDEV-9084 Calling a stored function from a nested select from temporary table causes unpredictable behavior
      
      Cherry-pick: f4a0af070ce49abae60040f6f32e1074309c27fb
      Author: Dmitry Lenev <dmitry.lenev@oracle.com>
      Date:   Mon Jul 25 16:06:52 2016 +0300
      
        Fix for bug #16672723 "CAN'T FIND TEMPORARY TABLE".
      
        Attempt to execute prepared CREATE TABLE SELECT statement which used
        temporary table in the subquery in FROM clause and stored function
        failed with unwarranted ER_NO_SUCH_TABLE error. The same happened
        when such statement was used in stored procedure and this procedure
        was re-executed.
      
        The problem occurred because execution of such prepared statement/its
        re-execution as part of stored procedure incorrectly set
        Query_table_list::query_tables_own_last marker, indicating the last
        table which is directly used by statement. As result temporary table
        used in the subquery was treated as indirectly used/belonging to
        prelocking list and was not pre-opened by open_temporary_tables()
        call before statement execution. Thus causing ER_NO_SUCH_TABLE errors
        since our code assumes that temporary tables need to be correctly
        pre-opened before statement execution.
      
        This problem became visible only in version 5.6 after patches related to
        bug 11746602/27480 "EXTEND CREATE TEMPORARY TABLES PRIVILEGE TO ALLOW
        TEMP TABLE OPERATIONS" since they have introduced pre-opening of temporary
        tables for statements.
      
        Incorrect setting of Query_table_list::query_tables_own_last happened
        in LEX::first_lists_tables_same() method which is called by CREATE TABLE
        SELECT implementation as part of LEX::unlink_first_table(), which temporary
        excludes table list element for table being created from the query table
        list before handling SELECT part.
      
        LEX::first_lists_tables_same() tries to ensure that global table list of
        the statement starts with the first table list element from the first
        statement select. To do this it moves such table list element to the head
        of the global table list. If this table happens to be last directly-used
        table for the statement, query_tables_own_last marker is pointing to it.
        Since this marker was not updated when table list element was moved we
        ended up with all tables except the first table separated by it as if
        they were not directly used by statement (i.e. belonged to prelocked
        tables list).
      
        This fix changes code of LEX::first_lists_tables_same() to update
        query_tables_own_last marker in cases when it points to the table
        being moved. It is set to the table which precedes table being moved
        in this case.
      e4978d26
    • Kristian Nielsen's avatar
      MDEV-10271: Stopped SQL slave thread doesn't print a message to error log like IO thread does · 43378f36
      Kristian Nielsen authored
      Make the slave SQL thread always output to the error log the message "Slave
      SQL thread exiting, replication stopped in ..." whenever it previously
      outputted "Slave SQL thread initialized, starting replication ...".
      
      Before this patch, it was somewhat inconsistent in which cases the message
      would be output and in which not, depending on the exact time and cause of
      the condition that caused the SQL thread to stop.
      43378f36
  7. 05 Jan, 2017 12 commits
    • Elena Stepanova's avatar
      Replication tests fail on valgrind due to waiting-related timeouts · 670b8580
      Elena Stepanova authored
      MTR raises default wait_for_pos_timeout from 300 to 1500 when tests
      are run with valgrind. The same needs to be done for other
      replication-related waits.
      
      The change should fix one of failures mentioned in MDEV-10653
      (rpl.rpl_parallel fails in buildbot with timeout), the one
      on the valgrind builder; but not all of them
      670b8580
    • Elena Stepanova's avatar
      MDEV-10988 Sphinx test suite refuses to run silently · b2b6cf49
      Elena Stepanova authored
      Add diagnostics output if any Sphinx components aren't found
      b2b6cf49
    • Marko Mäkelä's avatar
      Merge 10.1 into 10.2 · 4ce579d2
      Marko Mäkelä authored
      4ce579d2
    • Marko Mäkelä's avatar
      Merge 10.0 into 10.1 · 8049d2e9
      Marko Mäkelä authored
      8049d2e9
    • Marko Mäkelä's avatar
      MDEV-11730 Memory leak in innodb.innodb_corrupt_bit · f0c19b6a
      Marko Mäkelä authored
      Memory was leaked when ALTER TABLE is attempted on a table
      that contains corrupted indexes.
      The memory leak was reported by AddressSanitizer for the test
      innodb.innodb_corrupt_bit. The leak was introduced into
      MariaDB Server 10.0.26, 10.1.15, 10.2.1 by the following:
      
      commit c081c978
      Merge: 1d21b221 a482e76e
      Author: Sergei Golubchik <serg@mariadb.org>
      Date:   Tue Jun 21 14:11:02 2016 +0200
      
         Merge branch '5.5' into bb-10.0
      f0c19b6a
    • Marko Mäkelä's avatar
      Merge 10.1 to 10.2. · 11b7dff5
      Marko Mäkelä authored
      This makes no functional change to MariaDB Server 10.2.
      XtraDB is not being built, and in InnoDB, there was no
      memory leak in buf_dblwr_process() in MariaDB Server 10.2.
      11b7dff5
    • Marko Mäkelä's avatar
      fb5ee7d6
    • Marko Mäkelä's avatar
      Post-merge fix for MDEV-11638. · 30f27b0d
      Marko Mäkelä authored
      logs_empty_and_mark_files_at_shutdown(): Wait for the log_scrub_thread
      to exit.
      30f27b0d
    • Marko Mäkelä's avatar
      Fix InnoDB compilation warnings. · a8ac6dc5
      Marko Mäkelä authored
      Most of them are trivial, except for the thread_sync_t refactoring.
      We must not invoke memset() on non-POD objects.
      
      mtflush_work_initialized: Remove. Refer to mtflush_ctx != NULL instead.
      
      thread_sync_t::thread_sync_t(): Refactored from
      buf_mtflu_handler_init().
      
      thread_sync_t::~thread_sync_t(): Refactored from
      buf_mtflu_io_thread_exit().
      a8ac6dc5
    • Marko Mäkelä's avatar
      MDEV-11713 Optimize DBUG_PRINT and introduce DBUG_LOG · bf35deda
      Marko Mäkelä authored
      MariaDB Server is unnecessarily evaluating the arguments of
      DBUG_PRINT() macros when the label is not defined.
      
      The macro DBUG_LOG() for C++ operator<< output which was added for
      InnoDB diagnostics in MySQL 5.7 is missing from MariaDB. Unlike the
      MySQL 5.7 implementation, MariaDB will avoid allocating and
      initializing the output string when the label is not defined.
      
      Introduce DBUG_OUT("crypt") and DBUG_OUT("checksum") for some InnoDB
      diagnostics, replacing some use of ib::info().
      bf35deda
    • Marko Mäkelä's avatar
      Merge 10.1 to 10.2 · 4e7b382d
      Marko Mäkelä authored
      Most conflicts are related to the MDEV-11638 InnoDB shutdown refactoring.
      4e7b382d
    • Marko Mäkelä's avatar
      Post-push fix for Part 1 of MDEV-8139 Fix scrubbing tests · 758af98f
      Marko Mäkelä authored
      In the backport of Bug#24450908 UNDO LOG EXISTS AFTER SLOW SHUTDOWN
      from MySQL 5.7 to the MySQL 5.6 based MariaDB Server 10.1, we must
      use a mutex when HAVE_ATOMIC_BUILTINS is not defined.
      
      Also, correct a function comment. In MySQL 5.6 and MariaDB Server 10.1,
      also temporary InnoDB tables are redo-logged.
      758af98f
  8. 04 Jan, 2017 2 commits
    • Igor Babaev's avatar
      Fixed bug mdev-11674. · 348ccb6f
      Igor Babaev authored
      1. The rows of a recursive CTE at some point may overflow
      the HEAP temporary table containing them. At this point
      the table is converted to a MyISAM temporary table and the
      new added rows are placed into this MyISAM table.
      A bug in the of select_union_recursive::send_data prevented
      the server from writing the row that caused the overflow
      into the temporary table used for the result of the iteration
      steps. This could lead, in particular,to a premature end
      of the iterations.
      2. The method TABLE::insert_all_rows_into() that was used
      to copy all rows of one temporary table into another
      did not take into account that the destination temporary
      table must be converted to a MyISAM table at some point.
      This patch fixed this problem. It also renamed the method
      into TABLE::insert_all_rows_into_tmp_table() and added
      an extra parameter needed for the conversion.
      348ccb6f
    • Marko Mäkelä's avatar
      MDEV-8139 Fix scrubbing tests · ffb38c97
      Marko Mäkelä authored
      encryption.innodb_scrub: Clean up. Make it also cover ROW_FORMAT=COMPRESSED,
      removing the need for encryption.innodb_scrub_compressed.
      Add a FIXME comment saying that we should create a secondary index, to
      demonstrate that also undo log pages get scrubbed. Currently that is
      not working!
      
      Also clean up encryption.innodb_scrub_background, but keep it disabled,
      because the background scrubbing does not work reliably.
      
      Fix both tests so that if something is not scrubbed, the test will be
      aborted, so that the data files will be preserved. Allow the tests to
      run on Windows as well.
      ffb38c97