1. 24 Jan, 2017 3 commits
    • Jan Lindström's avatar
      Fix compiler error on native AIO. · 83680449
      Jan Lindström authored
      83680449
    • Jan Lindström's avatar
      MDEV-11879: Duplicate option innochecksum -l (--log, --leaf) · 51b248cf
      Jan Lindström authored
      Move --leaf under -e to avoid duplicate option and retain
      -l for --log (to maintain compatibility with MySQL 5.7).
      51b248cf
    • Jan Lindström's avatar
      MDEV-11254: innodb-use-trim has no effect in 10.2 · 6495806e
      Jan Lindström authored
      Problem was that implementation merged from 10.1 was incompatible
      with InnoDB 5.7.
      
      buf0buf.cc: Add functions to return should we punch hole and
      how big.
      
      buf0flu.cc: Add written page to IORequest
      
      fil0fil.cc: Remove unneeded status call and add test is
      sparse files and punch hole supported by file system when
      tablespace is created. Add call to get file system
      block size. Used file node is added to IORequest. Added
      functions to check is punch hole supported and setting
      punch hole.
      
      ha_innodb.cc: Remove unneeded status variables (trim512-32768)
      and trim_op_saved. Deprecate innodb_use_trim and
      set it ON by default. Add function to set innodb-use-trim
      dynamically.
      
      dberr.h: Add error code DB_IO_NO_PUNCH_HOLE
      if punch hole operation fails.
      
      fil0fil.h: Add punch_hole variable to fil_space_t and
      block size to fil_node_t.
      
      os0api.h: Header to helper functions on buf0buf.cc and
      fil0fil.cc for os0file.h
      
      os0file.h: Remove unneeded m_block_size from IORequest
      and add bpage to IORequest to know actual size of
      the block and m_fil_node to know tablespace file
      system block size and does it support punch hole.
      
      os0file.cc: Add function punch_hole() to IORequest
      to do punch_hole operation,
      get the file system block size and determine
      does file system support sparse files (for punch hole).
      
      page0size.h: remove implicit copy disable and
      use this implicit copy to implement copy_from()
      function.
      
      buf0dblwr.cc, buf0flu.cc, buf0rea.cc, fil0fil.cc, fil0fil.h,
      os0file.h, os0file.cc, log0log.cc, log0recv.cc:
      Remove unneeded write_size parameter from fil_io
      calls.
      
      srv0mon.h, srv0srv.h, srv0mon.cc: Remove unneeded
      trim512-trim32678 status variables. Removed
      these from monitor tests.
      6495806e
  2. 23 Jan, 2017 3 commits
    • Alexey Botchkov's avatar
      MDEV-11042 Implement GeoJSON functions. · 0d107a85
      Alexey Botchkov authored
              ST_AsGeoJSON and ST_GeomFromGeoJSON functions implemented.
      0d107a85
    • Varun Gupta's avatar
      MDEV-11108: Assertion `uniq_tuple_length_arg <= table->file->max_key_length()'... · 1f3ad6a4
      Varun Gupta authored
      MDEV-11108: Assertion `uniq_tuple_length_arg <= table->file->max_key_length()' failed in SJ_TMP_TABLE::create_sj_weedout_tmp_table
      
      Removed the assert from the if clause to the else clause.
      1f3ad6a4
    • Alexander Barkov's avatar
      MDEV-11134 Assertion `fixed' failed in Item::const_charset_converter(THD*,... · 45e40892
      Alexander Barkov authored
      MDEV-11134 Assertion `fixed' failed in Item::const_charset_converter(THD*, CHARSET_INFO*, bool, const char*)
      
      Problem: Item_param::basic_const_item() returned true when fixed==false.
      This unexpected combination made Item::const_charset_converter() crash
      on asserts.
      
      Fix:
      - Changing all Item_param::set_xxx() to set "fixed" to true.
        This fixes the problem.
      - Additionally, changing all Item_param::set_xxx() to set
        Item_param::item_type, to avoid duplicate code, and for consistency,
        to make the code symmetric between different constant types.
        Before this patch only set_null() set item_type.
      - Moving Item_param::state and Item_param::item_type from public to private,
        to make sure easier that these members are in sync with "fixed" and to
        each other.
      - Adding a new argument "unsigned_arg" to Item::set_decimal(),
        and reusing it in two places instead of duplicate code.
      - Adding a new method Item_param::fix_temporal() and reusing it in two places.
      - Adding methods has_no_value(), has_long_data_value(), has_int_value(),
        instead of direct access to Item_param::state.
      45e40892
  3. 22 Jan, 2017 3 commits
  4. 20 Jan, 2017 1 commit
    • Monty's avatar
      [MDEV-10570] Add Flashback support · d75d8631
      Monty authored
      ==== Description ====
      
      Flashback can rollback the instances/databases/tables to an old snapshot.
      It's implement on Server-Level by full image format binary logs (--binlog-row-image=FULL), so it supports all engines.
      Currently, it’s a feature inside mysqlbinlog tool (with --flashback arguments).
      
      Because the flashback binlog events will store in the memory, you should check if there is enough memory in your machine.
      
      ==== New Arguments to mysqlbinlog ====
      
      --flashback (-B)
      It will let mysqlbinlog to work on FLASHBACK mode.
      
      ==== New Arguments to mysqld ====
      
      --flashback
      
      Setup the server to use flashback. This enables binary log in row mode
      and will enable extra logging for DDL's needed by flashback feature
      
      ==== Example ====
      
      I have a table "t" in database "test", we can compare the output with "--flashback" and without.
      
      #client/mysqlbinlog /data/mysqldata_10.0/binlog/mysql-bin.000001 -vv -d test -T t --start-datetime="2013-03-27 14:54:00" > /tmp/1.sql
      #client/mysqlbinlog /data/mysqldata_10.0/binlog/mysql-bin.000001 -vv -d test -T t --start-datetime="2013-03-27 14:54:00" -B > /tmp/2.sql
      
      Then, importing the output flashback file (/tmp/2.log), it can flashback your database/table to the special time (--start-datetime).
      And if you know the exact postion, "--start-postion" is also works, mysqlbinlog will output the flashback logs that can flashback to "--start-postion" position.
      
      ==== Implement ====
      
      1. As we know, if binlog_format is ROW (binlog-row-image=FULL in 10.1 and later), all columns value are store in the row event, so we can get the data before mis-operation.
      
      2. Just do following things:
      
        2.1 Change Event Type, INSERT->DELETE, DELETE->INSERT.
        For example:
          INSERT INTO t VALUES (...)  ---> DELETE FROM t WHERE ...
          DELETE FROM t ... ---> INSERT INTO t VALUES (...)
      
        2.2 For Update_Event, swapping the SET part and WHERE part.
        For example:
          UPDATE t SET cols1 = vals1 WHERE cols2 = vals2
          --->
          UPDATE t SET cols2 = vals2 WHERE cols1 = vals1
      
        2.3 For Multi-Rows Event, reverse the rows sequence, from the last row to the first row.
        For example:
          DELETE FROM t WHERE id=1; DELETE FROM t WHERE id=2; ...; DELETE FROM t WHERE id=n;
          --->
          DELETE FROM t WHERE id=n; ...; DELETE FROM t WHERE id=2; DELETE FROM t WHERE id=1;
      
        2.4 Output those events from the last one to the first one which mis-operation happened.
        For example:
      d75d8631
  5. 19 Jan, 2017 3 commits
    • Elena Stepanova's avatar
      Follow-up for the 10.1 -> 10.2 merge · b9631b46
      Elena Stepanova authored
      Fix 32-bit rdiffs to get rid of failed hunks
      b9631b46
    • Marko Mäkelä's avatar
      Merge 10.1 to 10.2. · b05bf8ff
      Marko Mäkelä authored
      Most notably, this includes MDEV-11623, which includes a fix and
      an upgrade procedure for the InnoDB file format incompatibility
      that is present in MariaDB Server 10.1.0 through 10.1.20.
      
      In other words, this merge should address
      MDEV-11202 InnoDB 10.1 -> 10.2 migration does not work
      b05bf8ff
    • Igor Babaev's avatar
      Fixed bug mdev-11818. · 833aa97c
      Igor Babaev authored
      When a query containing a WITH clause is printed by EXPLAIN
      EXTENDED command there should not be any data expansion in
      the query specifications of the WITH elements of this WITH
      clause.
      833aa97c
  6. 18 Jan, 2017 12 commits
    • Marko Mäkelä's avatar
      MDEV-11202 InnoDB 10.1 -> 10.2 migration does not work · a1315a65
      Marko Mäkelä authored
      This is the final preparation for the merge of MDEV-11623
      from MariaDB Server 10.1 (correcting the assignment of
      FSP_SPACE_FLAGS in MariaDB Server 10.1).
      
      We must avoid reading FSP_SPACE_FLAGS directly from page 0,
      because the flags that affect the uncompressed page size
      cannot be trusted if we are upgrading from MariaDB 10.1.
      
      We will pass fil_space_t* instead of a numeric tablespace ID
      in many low-level functions, so that fil_space_t::flags
      will be available. This will also reduce the amount o
      tablespace ID lookups and the pressure on fil_system->mutex.
      
      fil_space_is_being_truncated(), fil_space_is_redo_skipped(),
      PageCallback::set_page_size(), fsp_header_get_page_size(): Remove.
      
      fil_node_open_file(), fil_space_get_crypt_data(): Use space->flags.
      
      fsp_free_extent(), fseg_get_first_extent(), fsp_get_space_header(),
      xdes_get_descriptor_with_space_hdr(), xdes_get_descriptor(),
      xdes_lst_get_descriptor(), fsp_space_modify_check(),
      fsp_init_file_page(), fsp_alloc_free_extent(), fsp_page_create(),
      fsp_alloc_free_page(), fsp_free_page(), fsp_alloc_seg_inode_page(),
      fsp_alloc_seg_inode(), fsp_free_seg_inode(), fseg_fill_free_list(),
      fseg_mark_page_used(), fseg_free_page_low(), fseg_free_extent():
      Take fil_space_t* as a parameter, instead of taking a numeric ID.
      a1315a65
    • Marko Mäkelä's avatar
      MDEV-11831 Make InnoDB mini-transaction memo checks stricter · 8780b895
      Marko Mäkelä authored
      InnoDB keeps track of buffer-fixed buf_block_t or acquired rw_lock_t
      within a mini-transaction. There are some memo_contains assertions
      in the code that document when certain blocks or rw_locks must be held.
      But, these assertions only check the mini-transaction memo, not the fact
      whether the rw_lock_t are actually being held by the caller.
      
      btr_pcur_store_position(): Remove #ifdef, and assert that the block
      is always buffer-fixed.
      
      rtr_pcur_getnext_from_path(), rtr_pcur_open_low(),
      ibuf_rec_get_page_no_func(), ibuf_rec_get_space_func(),
      ibuf_rec_get_info_func(), ibuf_rec_get_op_type_func(),
      ibuf_build_entry_from_ibuf_rec_func(), ibuf_rec_get_volume_func(),
      ibuf_get_merge_page_nos_func(), ibuf_get_volume_buffered_count_func()
      ibuf_get_entry_counter_low_func(), page_set_ssn_id(),
      row_vers_old_has_index_entry(), row_vers_build_for_consistent_read(),
      row_vers_build_for_semi_consistent_read(),
      trx_undo_prev_version_build():
      Make use of mtr_memo_contains_page_flagged().
      
      mtr_t::memo_contains(): Take a const memo. Assert rw_lock_own().
      
      FindPage, FlaggedCheck: Assert rw_lock_own_flagged().
      8780b895
    • Jan Lindström's avatar
      Fix test failure on sysvars_innodb. · 95ebca71
      Jan Lindström authored
      MySQL Compression code was removed but missed this test case.
      95ebca71
    • Jan Lindström's avatar
      Fix test failure on innodb-page_compression_snappy test. · 716b8784
      Jan Lindström authored
      Modified test data to be more easily compressed and
      fixed mtr_suppression if compression fails.
      716b8784
    • Sergei Petrunia's avatar
      NOT FIXED: MDEV-10773: ANALYZE FORMAT=JSON query_with_CTE crashes · 25e5ce19
      Sergei Petrunia authored
      Remove the testcase. It turns out, the crash still happens, just not
      on all platforms.
      25e5ce19
    • Oleksandr Byelkin's avatar
    • Marko Mäkelä's avatar
      Remove references to innodb_file_format. · 08413254
      Marko Mäkelä authored
      innodb_file_format=Barracuda is the default in MariaDB 10.2.
      Do not set it, because the option will be removed in MariaDB 10.3.
      
      Also, do not set innodb_file_per_table=1 because it is the default.
      
      Note that MDEV-11828 should fix the test innodb.innodb-64k
      already in 10.1.
      08413254
    • Marko Mäkelä's avatar
      MDEV-11824 Allow ROW_FORMAT=DYNAMIC in the InnoDB system tablespace · 085b292a
      Marko Mäkelä authored
      When MySQL 5.7.9 (and MariaDB Server 10.2) introduced
      innodb_default_row_format and made ROW_FORMAT=DYNAMIC the default,
      it became possible to create any ROW_FORMAT tables in the InnoDB
      system tablespace, except ROW_FORMAT=COMPRESSED.
      
      In MySQL 5.7, it is possible to create ROW_FORMAT=DYNAMIC
      tables when TABLESPACE=innodb_system is explicitly specified.
      Because MariaDB Server 10.2 does not support the MySQL 5.7
      TABLESPACE=innodb_system attribute for tables, we should allow
      ROW_FORMAT=DYNAMIC when innodb_file_per_table=0.
      
      Also, remove the test innodb_zip.innodb-create-options, which was
      an outdated copy of innodb_zip.create_options.
      085b292a
    • Marko Mäkelä's avatar
      MDEV-11816 Disallow CREATE TEMPORARY TABLE…ROW_FORMAT=COMPRESSED · 7cf97ed4
      Marko Mäkelä authored
      MySQL 5.7 allows temporary tables to be created in ROW_FORMAT=COMPRESSED.
      The usefulness of this is questionable. WL#7899 in MySQL 8.0.0
      prevents the creation of such compressed tables, so that all InnoDB
      temporary tables will be located inside the predefined
      InnoDB temporary tablespace.
      
      Pick up and adjust some tests from MySQL 5.7 and 8.0.
      
      dict_tf_to_fsp_flags(): Remove the parameter is_temp.
      fsp_flags_init(): Remove the parameter is_temporary.
      
      row_mysql_drop_temp_tables(): Remove. There cannot be any temporary
      tables in InnoDB. (This never removed #sql* tables in the datadir
      which were created by DDL.)
      
      dict_table_t::dir_path_of_temp_table: Remove.
      
      create_table_info_t::m_temp_path: Remove.
      
      create_table_info_t::create_options_are_invalid(): Do not allow
      ROW_FORMAT=COMPRESSED or KEY_BLOCK_SIZE for temporary tables.
      
      create_table_info_t::innobase_table_flags(): Do not unnecessarily
      prevent CREATE TEMPORARY TABLE with SPATIAL INDEX.
      (MySQL 5.7 does allow this.)
      
      fil_space_belongs_in_lru(): The only FIL_TYPE_TEMPORARY tablespace
      is never subjected to closing least-recently-used files.
      7cf97ed4
    • Marko Mäkelä's avatar
      Remove MYSQL_TABLESPACES. · 494e4b99
      Marko Mäkelä authored
      MySQL 5.7 introduced partial support for user-created shared tablespaces
      (for example, import and export are not supported).
      
      MariaDB Server does not support tablespaces at this point of time.
      Let us remove most InnoDB code and data structures that is related
      to shared tablespaces.
      494e4b99
    • Marko Mäkelä's avatar
      Remove MYSQL_COMPRESSION. · 1eabad5d
      Marko Mäkelä authored
      The MariaDB 10.1 page_compression is incompatible with the Oracle
      implementation that was introduced in MySQL 5.7 later.
      
      Remove the Oracle implementation. Also remove the remaining traces of
      MYSQL_ENCRYPTION.
      
      This will also remove traces of PUNCH_HOLE until it is implemented
      better. The only effective call to os_file_punch_hole() was in
      fil_node_create_low() to test if the operation is supported for the file.
      
      In other words, it looks like page_compression is not working in
      MariaDB 10.2, because no code equivalent to the 10.1 os_file_trim()
      is enabled.
      1eabad5d
    • Marko Mäkelä's avatar
      Remove MYSQL_ENCRYPTION. · 70c11485
      Marko Mäkelä authored
      MariaDB will likely never support MySQL-style encryption for
      InnoDB, because we cannot link with the Oracle encryption plugin.
      This is preparation for merging MDEV-11623.
      70c11485
  7. 17 Jan, 2017 4 commits
  8. 16 Jan, 2017 3 commits
    • Marko Mäkelä's avatar
      MDEV-11623 follow-up: Adjust one more test. · 03497129
      Marko Mäkelä authored
      The function fsp_flags_try_adjust(), which is called on startup,
      is incrementing the Innodb_pages0_read counts for every affected file.
      Adjust the result of encryption.innodb_lotoftables accordingly.
      03497129
    • Marko Mäkelä's avatar
      MDEV-11623 follow-up: Adjust tests. · 7e3f3deb
      Marko Mäkelä authored
      innodb.doublewrite: Similar to what was done to innodb.101_compatibility,
      add an explicit $_ parameter to the Perl unpack function.
      Also, fix some diagnostic messages in the Perl code.
      
      innodb.innodb-wl5522-debug: Adjust for the changed error codes and
      messages on fault injection.
      7e3f3deb
    • Elena Stepanova's avatar
      101_compatibility test fails on CentOS 5 · 3a91dec1
      Elena Stepanova authored
      Apparently, in older versions of Perl unpack does not have a logic
      for using $_ as a default value for the second argument. Fixed by
      specifying it explicitly
      3a91dec1
  9. 15 Jan, 2017 8 commits
    • Elena Stepanova's avatar
      34c89d01
    • Marko Mäkelä's avatar
      MDEV-11623 MariaDB 10.1 fails to start datadir created with · ab1e6fef
      Marko Mäkelä authored
      MariaDB 10.0/MySQL 5.6 using innodb-page-size!=16K
      
      The storage format of FSP_SPACE_FLAGS was accidentally broken
      already in MariaDB 10.1.0. This fix is bringing the format in
      line with other MySQL and MariaDB release series.
      
      Please refer to the comments that were added to fsp0fsp.h
      for details.
      
      This is an INCOMPATIBLE CHANGE that affects users of
      page_compression and non-default innodb_page_size. Upgrading
      to this release will correct the flags in the data files.
      If you want to downgrade to earlier MariaDB 10.1.x, please refer
      to the test innodb.101_compatibility how to reset the
      FSP_SPACE_FLAGS in the files.
      
      NOTE: MariaDB 10.1.0 to 10.1.20 can misinterpret
      uncompressed data files with innodb_page_size=4k or 64k as
      compressed innodb_page_size=16k files, and then probably fail
      when trying to access the pages. See the comments in the
      function fsp_flags_convert_from_101() for detailed analysis.
      
      Move PAGE_COMPRESSION to FSP_SPACE_FLAGS bit position 16.
      In this way, compressed innodb_page_size=16k tablespaces will not
      be mistaken for uncompressed ones by MariaDB 10.1.0 to 10.1.20.
      
      Derive PAGE_COMPRESSION_LEVEL, ATOMIC_WRITES and DATA_DIR from the
      dict_table_t::flags when the table is available, in
      fil_space_for_table_exists_in_mem() or fil_open_single_table_tablespace().
      During crash recovery, fil_load_single_table_tablespace() will use
      innodb_compression_level for the PAGE_COMPRESSION_LEVEL.
      
      FSP_FLAGS_MEM_MASK: A bitmap of the memory-only fil_space_t::flags
      that are not to be written to FSP_SPACE_FLAGS. Currently, these will
      include PAGE_COMPRESSION_LEVEL, ATOMIC_WRITES and DATA_DIR.
      
      Introduce the macro FSP_FLAGS_PAGE_SSIZE(). We only support
      one innodb_page_size for the whole instance.
      
      When creating a dummy tablespace for the redo log, use
      fil_space_t::flags=0. The flags are never written to the redo log files.
      
      Remove many FSP_FLAGS_SET_ macros.
      
      dict_tf_verify_flags(): Remove. This is basically only duplicating
      the logic of dict_tf_to_fsp_flags(), used in a debug assertion.
      
      fil_space_t::mark: Remove. This flag was not used for anything.
      
      fil_space_for_table_exists_in_mem(): Remove the unnecessary parameter
      mark_space, and add a parameter for table flags. Check that
      fil_space_t::flags match the table flags, and adjust the (memory-only)
      flags based on the table flags.
      
      fil_node_open_file(): Remove some redundant or unreachable conditions,
      do not use stderr for output, and avoid unnecessary server aborts.
      
      fil_user_tablespace_restore_page(): Convert the flags, so that the
      correct page_size will be used when restoring a page from the
      doublewrite buffer.
      
      fil_space_get_page_compressed(), fsp_flags_is_page_compressed(): Remove.
      It suffices to have fil_space_is_page_compressed().
      
      FSP_FLAGS_WIDTH_DATA_DIR, FSP_FLAGS_WIDTH_PAGE_COMPRESSION_LEVEL,
      FSP_FLAGS_WIDTH_ATOMIC_WRITES: Remove, because these flags do not
      exist in the FSP_SPACE_FLAGS but only in memory.
      
      fsp_flags_try_adjust(): New function, to adjust the FSP_SPACE_FLAGS
      in page 0. Called by fil_open_single_table_tablespace(),
      fil_space_for_table_exists_in_mem(), innobase_start_or_create_for_mysql()
      except if --innodb-read-only is active.
      
      fsp_flags_is_valid(ulint): Reimplement from the scratch, with
      accurate comments. Do not display any details of detected
      inconsistencies, because the output could be confusing when
      dealing with MariaDB 10.1.x data files.
      
      fsp_flags_convert_from_101(ulint): Convert flags from buggy
      MariaDB 10.1.x format, or return ULINT_UNDEFINED if the flags
      cannot be in MariaDB 10.1.x format.
      
      fsp_flags_match(): Check the flags when probing files.
      Implemented based on fsp_flags_is_valid()
      and fsp_flags_convert_from_101().
      
      dict_check_tablespaces_and_store_max_id(): Do not access the
      page after committing the mini-transaction.
      
      IMPORT TABLESPACE fixes:
      
      AbstractCallback::init(): Convert the flags.
      
      FetchIndexRootPages::operator(): Check that the tablespace flags match the
      table flags. Do not attempt to convert tablespace flags to table flags,
      because the conversion would necessarily be lossy.
      
      PageConverter::update_header(): Write back the correct flags.
      This takes care of the flags in IMPORT TABLESPACE.
      ab1e6fef
    • Marko Mäkelä's avatar
      MDEV-11799 InnoDB can abort if the doublewrite buffer · a9d00db1
      Marko Mäkelä authored
      contains a bad and a good copy
      
      Clean up the InnoDB doublewrite buffer code.
      
      buf_dblwr_init_or_load_pages(): Do not add empty pages to the buffer.
      
      buf_dblwr_process(): Do consider changes to pages that are all zero.
      Do not abort when finding a corrupted copy of a page in the doublewrite
      buffer, because there could be multiple copies in the doublewrite buffer,
      and only one of them needs to be good.
      a9d00db1
    • Marko Mäkelä's avatar
    • Sergei Golubchik's avatar
      MDEV-11551 Server crashes in Field::is_real_null · 5dfab33c
      Sergei Golubchik authored
      sometimes table->s->stored_fields is less than table->s->null_fields
      5dfab33c
    • Sergei Golubchik's avatar
      max_session_mem_used server variable · 7e2f9d09
      Sergei Golubchik authored
      7e2f9d09
    • Sergei Golubchik's avatar
      bugfix: mutex order violation in embedded · ab3388c3
      Sergei Golubchik authored
      safe_mutex: Found wrong usage of mutex 'LOCK_thread_count' and 'LOCK_status'
      Mutex currently locked (in reverse order):
      LOCK_status        sql/sql_class.h  line 3873
      LOCK_thread_count  libmysqld/lib_sql.cc  line 432
      ab3388c3
    • Sergei Golubchik's avatar
      1282eb69