1. 01 Mar, 2017 1 commit
    • Sergey Vojtovich's avatar
      MDEV-11221 - main.events_restart failed in bb · e9ad4bdb
      Sergey Vojtovich authored
      Applied lost in a merge revision 7f38a070:
      
      MDEV-10043 - main.events_restart fails sporadically in buildbot (crashes upon
                   shutdown)
      
      There was race condition between shutdown thread and event worker threads.
      
      Shutdown thread waits for thread_count to become 0 in close_connections(). It
      may happen so that event worker thread was started but didn't increment
      thread_count by this time. In this case shutdown thread may miss wait for this
      working thread and continue deinitialization. Worker thread in turn may continue
      execution and crash on deinitialized data.
      
      Fixed by incrementing thread_count before thread is actually created like it is
      done for connection threads.
      
      Also let event scheduler not to inc/dec running threads counter for symmetry
      with other "service" threads.
      e9ad4bdb
  2. 28 Feb, 2017 15 commits
  3. 27 Feb, 2017 2 commits
    • Daniel Black's avatar
      MDEV-11619: mtr --mem {no argument of a directory} (#320) · b54566d7
      Daniel Black authored
      This removes functionality of where ./mtr --mem /tmp/dir could be a directory.
      
      Now MTR_MEM=/tmp/dir ./mtr is needed.
      
      The case where MTR_MEM=/tmp/dir ./mtr --mem has the equivalent effect.
      Signed-off-by: default avatarDaniel Black <daniel.black@au.ibm.com>
      
      --mem works better as a pure flag, because it can be followed by command-line arguments (test names). If the option is allowed to have a value, the test name which directly follows it will be treated as the option value instead. It is possible to implement workarounds to avoid this, but they would not be completely reliable, and there is no practical purpose of such extension of functionality to justify them.
      b54566d7
    • Oleksandr Byelkin's avatar
      MDEV-11935: Queries in stored procedures with and EXISTS(SELECT * FROM VIEW)... · e5b877ce
      Oleksandr Byelkin authored
      MDEV-11935: Queries in stored procedures with and EXISTS(SELECT * FROM VIEW) crashes and closes hte conneciton.
      
      Use correct start point even for taken out from subselect items in process of exists2in conversion.
      e5b877ce
  4. 26 Feb, 2017 1 commit
  5. 23 Feb, 2017 1 commit
  6. 22 Feb, 2017 2 commits
    • Marko Mäkelä's avatar
      MDEV-11520 post-fix · a0ce92dd
      Marko Mäkelä authored
      fil_extend_space_to_desired_size(): Use a proper type cast when
      computing start_offset for the posix_fallocate() call on 32-bit systems
      (where sizeof(ulint) < sizeof(os_offset_t)). This could affect 32-bit
      systems when extending files that are at least 4 MiB long.
      
      This bug existed in MariaDB 10.0 before MDEV-11520. In MariaDB 10.1
      it had been fixed in MDEV-11556.
      a0ce92dd
    • Marko Mäkelä's avatar
      MDEV-11520 Extending an InnoDB data file unnecessarily allocates · 81695ab8
      Marko Mäkelä authored
      a large memory buffer on Windows
      
      fil_extend_space_to_desired_size(), os_file_set_size(): Use calloc()
      for memory allocation, and handle failures. Properly check the return
      status of posix_fallocate(), and pass the correct arguments to
      posix_fallocate().
      
      On Windows, instead of extending the file by at most 1 megabyte at a time,
      write a zero-filled page at the end of the file.
      According to the Microsoft blog post
      https://blogs.msdn.microsoft.com/oldnewthing/20110922-00/?p=9573
      this will physically extend the file by writing zero bytes.
      (InnoDB never uses DeviceIoControl() to set the file sparse.)
      
      I tested that the file extension works properly with a multi-file
      system tablespace, both with --innodb-use-fallocate and
      --skip-innodb-use-fallocate (the default):
      
      ./mtr \
      --mysqld=--innodb-use-fallocate \
      --mysqld=--innodb-autoextend-increment=1 \
      --mysqld=--innodb-data-file-path='ibdata1:5M;ibdata2:5M:autoextend' \
      --parallel=auto --force --retry=0 --suite=innodb &
      
      ls -lsh mysql-test/var/*/mysqld.1/data/ibdata2
      (several samples while running the test)
      81695ab8
  7. 21 Feb, 2017 1 commit
  8. 20 Feb, 2017 2 commits
    • Marko Mäkelä's avatar
      MDEV-11802 innodb.innodb_bug14676111 fails · 13493078
      Marko Mäkelä authored
      The function trx_purge_stop() was calling os_event_reset(purge_sys->event)
      before calling rw_lock_x_lock(&purge_sys->latch). The os_event_set()
      call in srv_purge_coordinator_suspend() is protected by that X-latch.
      
      It would seem a good idea to consistently protect both os_event_set()
      and os_event_reset() calls with a common mutex or rw-lock in those
      cases where os_event_set() and os_event_reset() are used
      like condition variables, tied to changes of shared state.
      
      For each os_event_t, we try to document the mutex or rw-lock that is
      being used. For some events, frequent calls to os_event_set() seem to
      try to avoid hangs. Some events are never waited for infinitely, only
      timed waits, and os_event_set() is used for early termination of these
      waits.
      
      os_aio_simulated_put_read_threads_to_sleep(): Define as a null macro
      on other systems than Windows. TODO: remove this altogether and disable
      innodb_use_native_aio on Windows.
      
      os_aio_segment_wait_events[]: Initialize only if innodb_use_native_aio=0.
      13493078
    • Marko Mäkelä's avatar
      Revert the MDEV-4396 tweak to innodb.innodb_bug14676111. · 72994d64
      Marko Mäkelä authored
      MDEV-11802 aims to fix the root cause instead.
      72994d64
  9. 19 Feb, 2017 3 commits
    • Elena Stepanova's avatar
      MDEV-10631 rpl.rpl_mdev6386 failed in buildbot · 343ba585
      Elena Stepanova authored
      The failure happens due to a race condition between processing
      a row event (INSERT) and an automatically generated event
      DROP TEMPORARY TABLE. Even though DROP has a higher GTID, it can
      become visible in @@gtid_slave_pos before the row event with
      a lower GTID has been committed. Since the test makes the slave
      to synchronize with the master using GTID, the waiting stops
      as soon as GTID of the DROP TEMPORARY TABLE becomes visible,
      and if changes from the previous event haven't been applied yet,
      the error occurs.
      
      According to Kristian (see the comment to MDEV-10631), the real
      problem is that DROP TEMPORARY TABLE is logged in the row mode
      at all. For this particular test, since DROP does not do anything,
      nothing prevents it from competing with the prior transaction.
      
      The workaround for the test is to add a meaningful event
      after DROP TEMPORARY TABLE, so that the slave would wait on its
      GTID instead of the one from DROP.
      
      Additionally (unrelated to this problem) removed FLUSH TABLES,
      which, as the comment stated, should have been removed after
      MDEV-6403 was fixed.
      343ba585
    • Elena Stepanova's avatar
      MDEV-11766 Tests failed in buildbot with semaphore waiting warnings · 72a822f2
      Elena Stepanova authored
      The standalone warning is not a sign of a problem, just of slowness,
      so it should be added to global suppressions. If a real problem
      happens, there will be other errors
      72a822f2
    • Daniel Black's avatar
      MDEV-11619: mtr --mem and $MTR_MEM support in sane and consistent manner (10.0) (#289) · 5e42c958
      Daniel Black authored
      * Revert "Make --mem a pure flag. If there is need to specifically set the location"
      
      This reverts commit 716621db.
      
      * MDEV-11619: mtr: when --mem is pure flag, conflicts with $MTR_MEM
      
      Conflicts occurs when MTR_MEM=/xxx/yy ./mtr --mem is invoked. Here
      the --mem option overrides opt_mem leaving the default path to be chosen.
      
      This change makes when MTR_MEM set, opt_mem, the flag, is also
      set. Both the environment and flag can no be set without conflicting.
      Signed-off-by: default avatarDaniel Black <daniel.black@au.ibm.com>
      
      * MDEV-11619: if opt_mem is a path include it first
      
      * MDEV-11619: MTR_MEM locations - don't follow symlinks
      
      From Bjorn Munch it seems symlinks can confuse some
      tests. Lets just avoid those.
      
      (ref: https://github.com/mysql/mysql-server/pull/116#issuecomment-268479774)
      Signed-off-by: default avatarDaniel Black <daniel.black@au.ibm.com>
      5e42c958
  10. 16 Feb, 2017 1 commit
  11. 09 Feb, 2017 1 commit
  12. 08 Feb, 2017 1 commit
  13. 05 Feb, 2017 1 commit
    • Marko Mäkelä's avatar
      Rewrite the innodb.log_file_size test with DBUG_EXECUTE_IF. · f1627045
      Marko Mäkelä authored
      Remove the debug parameter innodb_force_recovery_crash that was
      introduced into MySQL 5.6 by me in WL#6494 which allowed InnoDB
      to resize the redo log on startup.
      
      Let innodb.log_file_size actually start up the server, but ensure
      that the InnoDB storage engine refuses to start up in each of the
      scenarios.
      f1627045
  14. 04 Feb, 2017 2 commits
    • Marko Mäkelä's avatar
      MDEV-11985 Make innodb_read_only shutdown more robust · 20e83474
      Marko Mäkelä authored
      If InnoDB is started in innodb_read_only mode such that
      recovered incomplete transactions exist at startup
      (but the redo logs are clean), an assertion will fail at shutdown,
      because there would exist some non-prepared transactions.
      
      logs_empty_and_mark_files_at_shutdown(): Do not wait for incomplete
      transactions to finish if innodb_read_only or innodb_force_recovery>=3.
      Wait for purge to finish in only one place.
      
      trx_sys_close(): Relax the assertion that would fail first.
      
      trx_free_prepared(): Also free recovered TRX_STATE_ACTIVE transactions
      if innodb_read_only or innodb_force_recovery>=3.
      20e83474
    • Marko Mäkelä's avatar
      MDEV-11947 InnoDB purge workers fail to shut down · 9f0dbb31
      Marko Mäkelä authored
      srv_release_threads(): Actually wait for the threads to resume
      from suspension. On CentOS 5 and possibly other platforms,
      os_event_set() may be lost.
      
      srv_resume_thread(): A counterpart of srv_suspend_thread().
      Optionally wait for the event to be set, optionally with a timeout,
      and then release the thread from suspension.
      
      srv_free_slot(): Unconditionally suspend the thread. It is always
      in resumed state when this function is entered.
      
      srv_active_wake_master_thread_low(): Only call os_event_set().
      
      srv_purge_coordinator_suspend(): Use srv_resume_thread() instead
      of the complicated logic.
      9f0dbb31
  15. 03 Feb, 2017 1 commit
  16. 01 Feb, 2017 4 commits
  17. 30 Jan, 2017 1 commit