1. 25 Aug, 2017 1 commit
    • Marko Mäkelä's avatar
      MDEV-13637 InnoDB change buffer housekeeping can cause redo log overrun and possibly deadlocks · 582545a3
      Marko Mäkelä authored
      The function ibuf_remove_free_page() may be called while the caller
      is holding several mutexes or rw-locks. Because of this, this
      housekeeping loop may cause performance glitches for operations that
      involve tables that are stored in the InnoDB system tablespace.
      Also deadlocks might be possible.
      
      The worst impact of all is that due to the mutexes being held, calls to
      log_free_check() had to be skipped during this housekeeping.
      This means that the cyclic InnoDB redo log may be overwritten.
      If the system crashes during this, it would be unable to recover.
      
      The entry point to the problematic code is ibuf_free_excess_pages().
      It would make sense to call it before acquiring any mutexes or rw-locks,
      in any 'pessimistic' operation that involves the system tablespace.
      
      fseg_create_general(), fseg_alloc_free_page_general(): Do not call
      ibuf_free_excess_pages() while potentially holding some latches.
      
      ibuf_remove_free_page(): Do call log_free_check(), like every operation
      that is about to generate redo log should do.
      
      ibuf_free_excess_pages(): Remove some assertions that are replaced
      by stricter assertions in the log_free_check() that is now called by
      ibuf_remove_free_page().
      
      row_ins_sec_index_entry(), row_undo_ins_remove_sec_low(),
      row_undo_mod_del_mark_or_remove_sec_low(),
      row_undo_mod_del_unmark_sec_and_undo_update(): Call
      ibuf_free_excess_pages() if the operation may involve allocating pages
      and change buffering in the system tablespace.
      582545a3
  2. 24 Aug, 2017 2 commits
  3. 23 Aug, 2017 4 commits
  4. 18 Aug, 2017 1 commit
    • Jan Lindström's avatar
      MDEV-8960: Can't refer the same column twice in one ALTER TABLE · ce6c0e58
      Jan Lindström authored
      Problem was that if column was created in alter table when
      it was refered again it was not tried to find from list
      of current columns.
      
      mysql_prepare_alter_table:
        There is two cases
          (1) If alter table adds a new column and then later alter
              changes the field definition, there was no check from
      	list of new columns, instead an incorrect error was given.
          (2) If alter table adds a new column and then later alter
              changes the default, there was no check from list of
      	new columns, instead an incorrect error was given.
      ce6c0e58
  5. 14 Aug, 2017 1 commit
  6. 13 Aug, 2017 1 commit
  7. 09 Aug, 2017 1 commit
    • Marko Mäkelä's avatar
      Revert an InnoDB Memcached plugin fix that was merged from MySQL 5.6.37 · cb9648a6
      Marko Mäkelä authored
      Revert the following change, because Memcached is not present
      in MariaDB Server. We had better avoid adding dead code.
      
      commit d9bc5e03d788b958ce8c76e157239953db60adb2
      Author: Aakanksha Verma <aakanksha.verma@oracle.com>
      Date:   Thu May 18 14:31:01 2017 +0530
      
          Bug #24605783 MYSQL GOT SIGNAL 6 ASSERTION FAILURE
      cb9648a6
  8. 07 Aug, 2017 1 commit
  9. 04 Aug, 2017 2 commits
  10. 03 Aug, 2017 8 commits
  11. 02 Aug, 2017 2 commits
  12. 01 Aug, 2017 9 commits
  13. 30 Jul, 2017 5 commits
  14. 29 Jul, 2017 2 commits