1. 19 Apr, 2018 1 commit
    • Daniel Black's avatar
      MDEV-8743: mysqld port/socket - FD_CLOEXEC if no SOCK_CLOEXEC · ccd566af
      Daniel Black authored
      In MDEV-8743, the port/socket of mysqld was changed to set FD_CLOEXEC.
      The existing mysql_socket_socket function already set that with
      SOCK_CLOEXEC when the socket was created. So here we move the fcntl
      functionality to the mysql_socket_socket as port/socket are the only
      callers.
      
      Preprocessor checks of SOCK_CLOEXEC cannot be done as its a 0 if not
      there and SOCK_CLOEXEC (being the value of the enum in bits/socket_type.h)
      Preprocesssor logic for arithmetic and non-arithmetic defines are
      hard/nonportable/ugly to read. As such we just check in my_global.h
      and define HAVE_SOCK_CLOEXEC if we have it.
      
      There was a disparity in behaviour between defined(WITH_WSREP) and
      not depending on the OS, so the WITH_WSREP condition was removed
      from setting calling fcntl.
      
      All sockets are now maked SOCK_CLOEXEC/FD_CLOEXEC.
      
      strace of mysqld with SOCK_CLOEXEC:
      
      socket(AF_INET, SOCK_STREAM|SOCK_CLOEXEC, IPPROTO_TCP) = 10
      write(2, "180419 14:52:40 [Note] Server socket created on IP: '127.0.0.1'.\n", 65180419 14:52:40 [Note] Server socket created on IP: '127.0.0.1'.
      ) = 65
      setsockopt(10, SOL_SOCKET, SO_REUSEADDR, [1], 4) = 0
      bind(10, {sa_family=AF_INET, sin_port=htons(16020), sin_addr=inet_addr("127.0.0.1")}, 16) = 0
      listen(10, 150)                         = 0
      socket(AF_INET, SOCK_STREAM|SOCK_CLOEXEC, IPPROTO_TCP) = 11
      write(2, "180419 14:52:40 [Note] Server socket created on IP: '127.0.0.1'.\n", 65180419 14:52:40 [Note] Server socket created on IP: '127.0.0.1'.
      ) = 65
      setsockopt(11, SOL_SOCKET, SO_REUSEADDR, [1], 4) = 0
      bind(11, {sa_family=AF_INET, sin_port=htons(16021), sin_addr=inet_addr("127.0.0.1")}, 16) = 0
      listen(11, 150)                         = 0
      socket(AF_UNIX, SOCK_STREAM|SOCK_CLOEXEC, 0) = 12
      unlink("/home/dan/repos/build-mariadb-server-10.0/mysql-test/var/tmp/mysqld.1.sock") = -1 ENOENT (No such file or directory)
      setsockopt(12, SOL_SOCKET, SO_REUSEADDR, [1], 4) = 0
      umask(000)                              = 006
      bind(12, {sa_family=AF_UNIX, sun_path="/home/dan/repos/build-mariadb-server-10.0/mysql-test/var/tmp/mysqld.1.sock"}, 110) = 0
      umask(006)                              = 000
      listen(12, 150)                         = 0
      ccd566af
  2. 15 Mar, 2018 1 commit
    • Daniel Black's avatar
      MDEV-8743: where O_CLOEXEC is available, use for innodb buf_dump · 8b54c314
      Daniel Black authored
      As this is the only moderately critical fopened for writing file,
      create an alternate path to use open and fdopen for non-glibc platforms
      that support O_CLOEXEC (BSDs).
      
      Tested on Linux (by modifing the GLIBC defination) to take this
      alternate path:
      
      $ cd /proc/23874
      $ more fdinfo/71
      pos:    0
      flags:  02100001
      mnt_id: 24
      $ ls -la fd/71
      l-wx------. 1 dan dan 64 Mar 14 13:30 fd/71 -> /dev/shm/var_auto_i7rl/mysqld.1/data/ib_buffer_pool.incomplete
      8b54c314
  3. 14 Mar, 2018 1 commit
  4. 02 Mar, 2018 1 commit
  5. 25 Feb, 2018 1 commit
  6. 06 Feb, 2018 1 commit
  7. 01 Feb, 2018 1 commit
  8. 27 Jan, 2018 1 commit
  9. 25 Jan, 2018 4 commits
  10. 24 Jan, 2018 14 commits
    • Vicențiu Ciorbaru's avatar
      Remove xtradb "fragmentation-statistics" patches · 12c42bd2
      Vicențiu Ciorbaru authored
      The patches are implemented using server changes in THD. We are not
      interested in having special code for certain storage engines, if
      possible.
      12c42bd2
    • Vicențiu Ciorbaru's avatar
      a82bb5d3
    • Vicențiu Ciorbaru's avatar
      3699a4b5
    • Vicențiu Ciorbaru's avatar
      Remove innodb.test "keep away" comment · d69d488b
      Vicențiu Ciorbaru authored
      This was a leftover post 5.5->10.0 merge. It should've been deleted
      there.
      d69d488b
    • Vicențiu Ciorbaru's avatar
      Update Tokudb Test Results · d81e41e7
      Vicențiu Ciorbaru authored
      d81e41e7
    • Vicențiu Ciorbaru's avatar
      Make TokuDB run on 10.0 · fc3df561
      Vicențiu Ciorbaru authored
      fc3df561
    • Vicențiu Ciorbaru's avatar
      c5f333ad
    • Vicențiu Ciorbaru's avatar
      Squashed commit of connect/10.0: · 1e88e855
      Vicențiu Ciorbaru authored
      Main additions:
      
      commit 543c2006a70983c2ce75024bce3679b0c20f9ae6
      Author: Olivier Bertrand <bertrandop@gmail.com>
      Date:   Thu Jan 4 13:51:13 2018 +0100
      
          - Fix MDEV-9844, MDEV-10179, MDEV-14214
           This is done by removing the tbl table type THREAD option
           that causes a multiple of sporadic bugs.
           This may be temporary depending on whether a real fix is found.
            modified:   storage/connect/mysql-test/connect/disabled.def
            modified:   storage/connect/tabtbl.cpp
            modified:   storage/connect/tabtbl.h
      
      commit 54bc4ea024ca5fb5c137c618084d8cccfba2ee3f
      Author: Olivier Bertrand <bertrandop@gmail.com>
      Date:   Fri Nov 3 16:21:56 2017 +0100
      
          - Fix MDEV-13925: Actually this fixes SELECT queries when
            the WHERE clause have single quote.
            modified:   storage/connect/ha_connect.cc
      
          - Use Windows VirtualAlloc and VirtualFree for the Sarea workspace
            modified:   storage/connect/global.h
            modified:   storage/connect/ha_connect.cc
            modified:   storage/connect/jsonudf.cpp
            modified:   storage/connect/plgdbutl.cpp
            modified:   storage/connect/plugutil.cpp
            modified:   storage/connect/user_connect.cc
      
          - Change inihandl from c to c++.
            Because it now includes global.h that contains a bool function definition
            that make compile to fail on Linux.
            modified:   storage/connect/CMakeLists.txt
            removed:    storage/connect/inihandl.c
            added:      storage/connect/inihandl.cpp
      
          - Fix MDEV-13860 CONNECT engine does not build with JDBC without ODBC.
            By including Sergei's patch in connect_assisted_discovery.
            modified:   storage/connect/ha_connect.cc
      
      commit c07064d31a4d7ee0533fec144648d93873c0dd17
      Author: Olivier Bertrand <bertrandop@gmail.com>
      Date:   Wed Oct 18 00:11:00 2017 +0200
      
          - Update version number
            modified:   storage/connect/ha_connect.cc
      
          - Include MONGO in all Java enabled distributions
            Mongo will be enabled only for 10.2 and 10.3
            modified:   storage/connect/CMakeLists.txt
      
          - Change JDBC_SUPPORT to JAVA_SUPPORT which also replaces MONGO_SUPPORT
            MONGO_SUPPORT is now just used to enable the MONGO table type
            modified:   storage/connect/filter.cpp
            modified:   storage/connect/ha_connect.cc
            modified:   storage/connect/ha_connect.h
            modified:   storage/connect/mongo.cpp
            modified:   storage/connect/mycat.cc
            modified:   storage/connect/plgdbutl.cpp
            modified:   storage/connect/tabjson.cpp
            modified:   storage/connect/tabjson.h
      
          - Move MakeSelector function from FILTER to mongo.cpp
            modified:   storage/connect/filter.cpp
            modified:   storage/connect/filter.h
            modified:   storage/connect/cmgoconn.cpp
            modified:   storage/connect/jmgoconn.cpp
            modified:   storage/connect/mongo.cpp
      
          - Do mongo_init only on first use of the MongoDB C Driver
            This will permit to delay load the mongo lib on Windows
            modified:   storage/connect/cmgoconn.cpp
            modified:   storage/connect/cmgoconn.h
            modified:   storage/connect/ha_connect.cc
      
          - Replace NEW_VAR by a test on MYSQL_VERSION_ID
            modified:   storage/connect/ha_connect.cc
      
          - Suppress enable_mongo session variable
            modified:   storage/connect/ha_connect.cc
            modified:   storage/connect/mycat.cc
      
          - Make some function headers identical in .h and .cc file
            (replacing const char* by PCSZ)
            modified:   storage/connect/ha_connect.cc
            modified:   storage/connect/ha_connect.h
      
          - Change a parameter type from uchar* to const uchar*
            (for ScanRecord and CheckRecord)
            modified:   storage/connect/ha_connect.cc
            modified:   storage/connect/ha_connect.h
      
          - Changes on LIKE and NOT LIKE does not fix a bug yet
            modified:   storage/connect/ha_connect.cc
      
          - Suppress PIVOT_SUPPORT (PIVOT type is unconditionnal)
            modified:   storage/connect/ha_connect.cc
            modified:   storage/connect/mycat.cc
      
          - Change the strz function from inline to static
            modified:   storage/connect/ha_connect.cc
            modified:   storage/connect/ha_connect.h
      
          - export the JavaConn class and the MgoColumns and IsNum functions
            modified:   storage/connect/javaconn.h
            modified:   storage/connect/json.h
            modified:   storage/connect/mongo.h
      
          - Fix MDEV-13924
            modified:   storage/connect/jdbconn.cpp
      
          - Make a temporary fix for the compiler bug in CalculateArray
            modified:   storage/connect/jsonudf.cpp
            modified:   storage/connect/tabjson.cpp
      
          - Typo
            modified:   storage/connect/jdbccat.h
            modified:   storage/connect/reldef.h
            modified:   storage/connect/tabext.h
            modified:   storage/connect/tabjmg.cpp
            modified:   storage/connect/tabxml.h
            modified:   storage/connect/valblk.h
            modified:   storage/connect/value.h
            modified:   storage/connect/xtable.h
      
          - Fix a bug in MONGO tests by changing 'MONGO' to $TYPE
            modified:   storage/connect/mysql-test/connect/t/mongo_test.inc
      
          - Record test results to reflect all changes
            modified:   storage/connect/mysql-test/connect/r/json_java_2.result
            modified:   storage/connect/mysql-test/connect/r/json_java_3.result
            modified:   storage/connect/mysql-test/connect/r/json_mongo_c.result
            modified:   storage/connect/mysql-test/connect/r/mongo_c.result
            modified:   storage/connect/mysql-test/connect/r/mongo_java_2.result
            modified:   storage/connect/mysql-test/connect/r/mongo_java_3.result
      
      commit 3da90fd112e7d5ee6f0bd9c3fc3eeb4529b30e93
      Author: Olivier Bertrand <bertrandop@gmail.com>
      Date:   Wed Oct 11 12:21:56 2017 +0200
      
          Fix MDEV-13924 modified: storage/connect/jdbconn.cpp
      
      commit 2566e67da80f291414f02c7dd6a8ca3557161d26
      Author: Olivier Bertrand <bertrandop@gmail.com>
      Date:   Mon Sep 11 16:38:41 2017 +0200
      
          Enable MONGO for the C driver. Modified: modified:   storage/connect/CMakeLists.txt
      
      commit 27ae11db830c5d62bbf8b8b13cab976b74efe7dd
      Author: Olivier Bertrand <bertrandop@gmail.com>
      Date:   Tue Sep 5 19:52:04 2017 +0200
      
          - Update version number
            modified:   storage/connect/ha_connect.cc
      
          - Regard columns with binary charset as string (was binary)
            modified:   storage/connect/ha_connect.cc
            modified:   storage/connect/tabmysql.cpp
            modified:   storage/connect/tabutil.cpp
      
          - Support length 0 for CHAR and VARCHAR
            modified:   storage/connect/ha_connect.cc
            modified:   storage/connect/reldef.cpp
            modified:   storage/connect/value.cpp
      
          - Add ACCEPT option for void columns in discovery
            modified:   storage/connect/tabjson.cpp
      
          - Update some tests because of above change
            modified:   storage/connect/mysql-test/connect/r/json_java_2.result
            modified:   storage/connect/mysql-test/connect/r/json_java_3.result
            modified:   storage/connect/mysql-test/connect/r/json_mongo_c.result
            modified:   storage/connect/mysql-test/connect/r/mongo_c.result
            modified:   storage/connect/mysql-test/connect/r/mongo_java_2.result
            modified:   storage/connect/mysql-test/connect/r/mongo_java_3.result
            modified:   storage/connect/mysql-test/connect/r/odbc_oracle.result
            modified:   storage/connect/mysql-test/connect/r/updelx.result
            modified:   storage/connect/mysql-test/connect/t/mongo_test.inc
      
      commit f6ee6cd1d42d861fa50fea8d9a7079347b7ddfd6
      Author: Olivier Bertrand <bertrandop@gmail.com>
      Date:   Sat Sep 2 16:06:10 2017 +0200
      
          - Fix MongoDB C Driver adding for CMAKE.
            Requires MongoDB C Driver version 1.7 now available
            modified:   storage/connect/CMakeLists.txt
      
          - Add more trace to tbl_thread.test (to debug failure)
            modified:   storage/connect/mysql-test/connect/r/tbl_thread.result
            modified:   storage/connect/mysql-test/connect/t/tbl_thread.test
      1e88e855
    • Vicențiu Ciorbaru's avatar
      Fix Innodb ASAN error on init · b20f821e
      Vicențiu Ciorbaru authored
      Backport 7c03edf2 from xtradb to innodb
      b20f821e
    • Vicențiu Ciorbaru's avatar
      d833bb65
    • Oleksandr Byelkin's avatar
      typo fix · 76577e1e
      Oleksandr Byelkin authored
      76577e1e
    • Sergei Golubchik's avatar
      MDEV-13187 incorrect backslash parsing in clients · e2da680c
      Sergei Golubchik authored
      also cover USE and other built-in commands
      e2da680c
    • Jan Lindström's avatar
      Merge pull request #549 from grooverdan/10.0-galera-sst-default-options · 08b2c516
      Jan Lindström authored
      MDEV-15044 - sst use of mysqld --default* options, sst script enhancements, mtr tests
      08b2c516
    • Ian Gilfillan's avatar
      Update sponsors · e431d900
      Ian Gilfillan authored
      e431d900
  11. 23 Jan, 2018 14 commits
    • Monty's avatar
      MDEV-14245 tokudb_alter_table.drop_add_pk_part_104 fails · d0acfa45
      Monty authored
      "tokudb_alter_table.drop_add_pk_part_104 leaves a temporary file behind"
      
      Fixed by copying 3 lines from 10.1 to 10.0 that cleaned up the temporary
      file for partitioning tables.
      d0acfa45
    • Monty's avatar
      Fixed a few compiler warnings · d5d0c624
      Monty authored
      d5d0c624
    • Monty's avatar
      Fix for MDEV-14141 Crash in print_keydup_error() · b3c7cf81
      Monty authored
      May also fix: MDEV-14970 "MariaDB crashed with signal 11 and Aria table"
      
      I am not able to reproduce a crash, however there was no protection in
      print_keydup_error() if the storage engine reported the wrong key number.
      
      This patch adds such a protection and should stop any further crashes
      in this case.
      
      Other things:
      - Added extra protection in Aria to not set errkey to more than number of
        keys. (Don't think this is cause of this crash, but better safe than
        sorry)
      - Extend test_if_equal_repl_errors() to handle different cases of
        ER_DUP_ENTRY. This is just mainly precaution for the future.
      b3c7cf81
    • Marko Mäkelä's avatar
      Add ASAN instrumentation (and more strict Valgrind) to InnoDB · 8637931f
      Marko Mäkelä authored
      mem_heap_free_heap_top(): Remove UNIV_MEM_ASSERT_W() and unpoison
      the memory region first, because part of it may have been poisoned
      by an earlier mem_heap_free_top() call.
      Poison the address range at the end.
      
      mem_heap_block_free(): Poison the address range at the end.
      
      UNIV_MEM_ASSERT_AND_ALLOC(): Replace with UNIV_MEM_ALLOC().
      We want to keep the address ranges poisoned (unaccessible) as
      long as possible.
      
      UNIV_MEM_ASSERT_AND_FREE(): Replace with UNIV_MEM_FREE().
      8637931f
    • Vicențiu Ciorbaru's avatar
      5.6.38-83.0 · f6716cef
      Vicențiu Ciorbaru authored
      f6716cef
    • Marko Mäkelä's avatar
      Silence -Wimplicit-fallthrough · 70a9b12d
      Marko Mäkelä authored
      70a9b12d
    • Vicențiu Ciorbaru's avatar
      5.6.38-83.0 · cd33250d
      Vicențiu Ciorbaru authored
      cd33250d
    • Vicențiu Ciorbaru's avatar
      5.6.39 · 3dfe1480
      Vicențiu Ciorbaru authored
      3dfe1480
    • Oleksandr Byelkin's avatar
      MDEV-14786: Server crashes in Item_cond::transform on 2nd execution of SP querying from a view · ba8d0fa7
      Oleksandr Byelkin authored
      MDEV-14957: JOIN::prepare gets unusable "conds" as argument
      
      Do not touch merged derived (it is irreversible)
      
      Fix first argument of in_optimizer for calls possible before fix_fields()
      ba8d0fa7
    • Oleksandr Byelkin's avatar
      11408a69
    • Oleksandr Byelkin's avatar
      MDEV-7533: COLUMN_JSON() doesn't escape control characters in string values · a4663af0
      Oleksandr Byelkin authored
      escape all charecters less or equal 0x1F (control symbols)
      (shorter sequence are not used to make code simple, long encoding is always legal according to the rfc4627)
      a4663af0
    • Sachin Setiya's avatar
      MDEV-14586 Assertion `0' failed in retrieve_auto_increment ... · 94da1cb4
      Sachin Setiya authored
      Problem:-
       If we create table using myisam/aria then this crashes the server.
        CREATE TABLE t1(a bit(1), b int auto_increment , index(a,b));
        insert into t1 values(1,1);
       Or this query
        CREATE TABLE t1 (b BIT(1), pk INTEGER AUTO_INCREMENT PRIMARY KEY);
        ALTER TABLE t1 ADD INDEX(b,pk);
        INSERT INTO t1 VALUES (1,b'1');
        ALTER TABLE t1 DROP PRIMARY KEY;
      
      Reason:-
       The reason for this is
       1st- find_ref_key() finds what key an auto_increment field belongs to by
        comparing key_part->offset and field->ptr. But BIT fields might have
        zero length in the record, so a key might have many key parts with the
        same offset. That is, comparing offsets cannot uniquely identify the
        correct key part.
       2nd- Since next_number_key_offset is zero it myisam/aria will think that
        auto_increment is in first part of key.
       3nd- myisam/aria will call retrieve_auto_key which will see first key_part
        field as a bit field and call assert(0)
      
      Solution:-
        Many key parts might have the same offset, but BIT fields do not
        support auto_increment. So, we can skip all key parts over BIT fields,
        and then comparing offsets will be unambiguous.
      94da1cb4
    • Daniel Black's avatar
      cc315541
    • Karim Geiger's avatar
      Fix error message typo · 701c7e77
      Karim Geiger authored
      701c7e77