1. 28 Jan, 2017 3 commits
    • Igor Babaev's avatar
      Fixed bug mdev-10773. · abfcdb8f
      Igor Babaev authored
      The temporary tables created for recursive table references
      should be closed in close_thread_tables(), because they might
      be used in the statements like ANALYZE WITH r AS (...) SELECT * from r
      where r is defined through recursion.
      abfcdb8f
    • Sergei Golubchik's avatar
      mysqlbinlog memory leaks · 64b5e942
      Sergei Golubchik authored
      that failed main.mysqlbinlog
      64b5e942
    • Sergei Golubchik's avatar
      cleanup: thd_destructor_proxy · 30ba3100
      Sergei Golubchik authored
      1. wait for thd_destructor_proxy thread to start after creating it.
         this ensures that the thread is ready to receive a shutdown signal
         whenever we want to send it.
      2. join it at shutdown, this guarantees that no innodb THD will exist
         after innobase_end().
      
      this fixes crashes and memory leaks in main.mysqld_option_err
      (were innodb was started and then immediately shut down).
      30ba3100
  2. 27 Jan, 2017 9 commits
  3. 26 Jan, 2017 5 commits
  4. 25 Jan, 2017 9 commits
  5. 24 Jan, 2017 11 commits
    • Igor Babaev's avatar
      Fixed bug mdev-11820. · 423b7da3
      Igor Babaev authored
      The fields st_select_lex::cond_pushed_into_where and
      st_select_lex::cond_pushed_into_having should be re-initialized
      for the unit specifying a derived table at every re-execution
      of the query that uses this derived table, because the result
      of condition pushdown may be different for different executions.
      423b7da3
    • Alexey Botchkov's avatar
      MDEV-11557 Port MySQL-5.7 JSON tests to MariaDB. · 35760c00
      Alexey Botchkov authored
              more fixes.
      35760c00
    • Alexey Botchkov's avatar
      MDEV-11042 Implement GeoJSON functions. · 1782102d
      Alexey Botchkov authored
              Typenames made into proper character case.
      1782102d
    • Varun Gupta's avatar
      MDEV-11108: adjusted test results · 6cdbf202
      Varun Gupta authored
      6cdbf202
    • Alexey Botchkov's avatar
      MDEV-11557 port MySQL-5.7 JSON tests to MariaDB. · 50831b0f
      Alexey Botchkov authored
              json_no_table.test ported.
      50831b0f
    • Jan Lindström's avatar
      e5398aca
    • Alexander Barkov's avatar
    • Alexander Barkov's avatar
      MDEV-11780 Crash with PREPARE + SP out parameter + literal · ae91690d
      Alexander Barkov authored
      Before "MDEV-10709 Expressions as parameters to Dynamic SQL" only
      user variables were syntactically allowed as EXECUTE parameters.
      User variables were OK as both IN and OUT parameters.
      When Item_param was bound to an actual parameter (a user variable),
      it automatically meant that the bound Item was settable.
      The DBUG_ASSERT() in Protocol_text::send_out_parameters() guarded that
      the actual parameter is really settable.
      
      After MDEV-10709, any kind of expressions are allowed as EXECUTE IN parameters.
      But the patch for MDEV-10709 forgot to check that only descendants of
      Settable_routine_parameter should be allowed as OUT parameters.
      So an attempt to pass a non-settable parameter as an OUT parameter
      made server crash on the above mentioned DBUG_ASSERT.
      
      This patch changes Item_param::get_settable_routine_parameter(),
      which previously always returned "this". Now, when Item_param is bound
      to some Item, it caches if the bound Item is settable.
      Item_param::get_settable_routine_parameter() now returns "this" only
      if the bound actual parameter is settable, and returns NULL otherwise.
      ae91690d
    • 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
  6. 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