1. 14 Jul, 2011 2 commits
  2. 13 Jul, 2011 1 commit
  3. 12 Jul, 2011 3 commits
  4. 11 Jul, 2011 1 commit
  5. 10 Jul, 2011 7 commits
    • Sergei Golubchik's avatar
    • Sergei Golubchik's avatar
      fix memory leaks and other problems found by safemalloc · 49501b4c
      Sergei Golubchik authored
      client/mysql_upgrade.c:
        missing DBUG_RETURN
      client/mysqladmin.cc:
        client plugin memory wasn't freed
      client/mysqlcheck.c:
        client plugin memory, defaults, a result set, a command-line option value were not freed.
        missing DBUG_RETURN.
      client/mysqldump.c:
        client plugin memory wasn't freed
      client/mysqlslap.c:
        client plugin memory wasn't freed
      client/mysqltest.cc:
        hopeless. cannot be fixed.
      mysql-test/valgrind.supp:
        Bug#56666 is now fixed.
      mysys/array.c:
        really, don't allocate if the caller didn't ask to.
      mysys/my_init.c:
        safemalloc checks must be done at the very end
      mysys/my_thr_init.c:
        not needed anymore
      sql-common/client.c:
        memory leak
      sql/log.cc:
        log_file was not closed, memory leak.
      sql/mysqld.cc:
        fix bug#56666 (causing many P_S related memory leaks).
        close_active_mi() not called for --bootstrap, memory leak.
      sql/sql_lex.cc:
        redo Lex->mi handling
      sql/sql_lex.h:
        redo Lex->mi handling
      sql/sql_plugin.cc:
        plugins having PLUGIN_VAR_MEMALLOC string variables have this variables allocated in every THD.
        The memory was freed in ~THD but only if plugin was still active. If plugin was unloaded the
        variable was not found and the memory was lost. By loading and unloading plugins an arbitrary
        amount of memory can be lost.
      sql/sql_repl.cc:
        redo Lex->mi handling
      sql/sql_yacc.yy:
        completely wrong handling of Lex->mi - run-time memory leak, by repeating the statement
        arbitrary amount of memory can be lost.
        
        Lex->mi.repl_ignore_server_ids_opt was allocated when parsing CHANGE MASTER,
        and freed after executing the statement. if parser failed on syntax (or another)
        error the statement was never executed. Lex->mi was simply bzero-ed for the next
        CHANGE MASTER  statement.
      sql/table.cc:
        didn't compile
      storage/perfschema/pfs_lock.h:
        Bug#56666 is fixed
      49501b4c
    • Sergei Golubchik's avatar
      add safemalloc back · 172f5e28
      Sergei Golubchik authored
      ... but differently
      
      client/mysqltest.cc:
        my_safe_print_str() don't append \n anymore
      dbug/dbug.c:
        restore safemalloc as a part of dbug suite
      dbug/user.r:
        restore 'S' flag documentation
      include/my_dbug.h:
        restore safemalloc as a part of dbug suite
      include/my_sys.h:
        move valgrind defines to a dedicated header
      mysys/my_malloc.c:
        use new safemalloc
      mysys/stacktrace.c:
        don't append \n. let the calller do it, if needed
      sql/mysqld.cc:
        my_safe_print_str() don't append \n anymore
      172f5e28
    • Sergei Golubchik's avatar
      small dbug cleanup · 02b82326
      Sergei Golubchik authored
      02b82326
    • Sergei Golubchik's avatar
      remove remnants of safemalloc and · a00b3849
      Sergei Golubchik authored
      very old halloca() support
      a00b3849
    • Sergei Golubchik's avatar
      only allocate extra-port (in tests) when needed · 274e06a5
      Sergei Golubchik authored
      (otherwise 10 ports per worker will be not enough)
      274e06a5
    • Sergei Golubchik's avatar
      update .bzrignore · 5b74c2da
      Sergei Golubchik authored
      5b74c2da
  6. 04 Jul, 2011 1 commit
  7. 03 Jul, 2011 2 commits
  8. 02 Jul, 2011 2 commits
  9. 16 Jun, 2011 2 commits
    • Jorgen Loland's avatar
      BUG#11882110: UPDATE REPORTS ER_KEY_NOT_FOUND IF TABLE IS · 5a0e7394
      Jorgen Loland authored
                    UPDATED TWICE
      
      For multi update it is not allowed to update a column
      of a table if that table is accessed through multiple aliases
      and either
      1) the updated column is used as partitioning key
      2) the updated column is part of the primary key 
         and the primary key is clustered
      
      This check is done in unsafe_key_update().
      
      The bug was that for case 2), it was checked whether
      updated_column_number == table_share->primary_key 
      However, the primary_key variable is the index number of the 
      primary key, not a column number.
      
      Prior to this bugfix, the first column was wrongly believed to be
      the primary key. The columns covered by an index is found in
      table->key_info[idx_number]->key_part. The bugfix is to check if
      any of the columns in the keyparts of the primary key are
      updated.
      
      The user-visible effect is that for storage engines with
      clustered primary key (e.g. InnoDB but not MyISAM) queries
      like 
      "UPDATE t1 AS A JOIN t2 AS B SET A.primkey=..."
      will now error with 
      "ERROR HY000: Primary key/partition key update is not allowed 
      since the table is updated both as 'A' and 'B'." 
      instead of 
      "ERROR 1032 (HY000): Can't find record in 't1_tb'"
      even if primkey is not the first column in the table. This 
      was the intended behavior of bugfix 11764529.
      
      
      mysql-test/r/multi_update.result:
        Add test for bug#11882110
      mysql-test/r/multi_update_innodb.result:
        Add test for bug#11882110
      mysql-test/t/multi_update.test:
        Add test for bug#11882110
      mysql-test/t/multi_update_innodb.test:
        Add test for bug#11882110
      sql/sql_update.cc:
        unsafe_key_update() wrongly checked if the primary key index
        number was the same as updated column number. Now it is checked
        whether any of the columns making up the primary key is updated.
      sql/table.h:
        Fix comment on TABLE_SHARE::primary_key. Incorrect comment
        was introduced by an earlier merge conflict (as per dlenev)
      5a0e7394
    • Vinay Fisrekar's avatar
      4e4e09ea
  10. 15 Jun, 2011 4 commits
  11. 14 Jun, 2011 2 commits
    • Marko Mäkelä's avatar
      Null merge mysql-5.1 to mysql-5.5. · fd3c17bb
      Marko Mäkelä authored
      fd3c17bb
    • Marko Mäkelä's avatar
      Merge a fix from mysql-5.5 to mysql-5.1: · 98d527d3
      Marko Mäkelä authored
      revno 2995.37.209
      revision id marko.makela@oracle.com-20110518120508-qhn7vz814vn77v5k
      parent marko.makela@oracle.com-20110517121555-lmple24qzxqkzep4
      timestamp: Wed 2011-05-18 15:05:08 +0300
      message:
        Fix a bogus UNIV_SYNC_DEBUG failure in the fix of Bug #59641
        or Oracle Bug #11766513.
      
        trx_undo_free_prepared(): Do not acquire or release trx->rseg->mutex.
        This code is invoked in the single-threaded part of shutdown, therefore
        a mutex is not needed.
      98d527d3
  12. 13 Jun, 2011 4 commits
    • Mayank Prasad's avatar
      BUG#12561297:LIBMYSQLD/EXAMPLE/MYSQL_EMBEDDED IS ABORTING. · 34142b84
      Mayank Prasad authored
      Issue:
      When libmysqld/example/mysql_embedded is executed, it was getting abort. Its a
      regression as it was working in 5.1 and failed in 5.5. Issue is there because 
      remaining_argc/remaining_argv were not getting assigned correctly in 
      init_embedded_server() which were being used later in init_common_variable().
      
      Solution:
      Rectified code to pass correct argc/argv to be used in init_common_variable().
      
      libmysqld/lib_sql.cc:
        Rectified remaining_argc/remaining_argv assignment.
      mysql-test/r/mysql_embedded.result:
        Result file for the test case added.
      mysql-test/t/mysql_embedded.test:
        Added test case to verify libmysqld/example/mysql_embedded works.
      34142b84
    • Mattias Jonsson's avatar
      merge · 77577014
      Mattias Jonsson authored
      77577014
    • Mattias Jonsson's avatar
      merge · e827b51f
      Mattias Jonsson authored
      e827b51f
    • Mattias Jonsson's avatar
      merge · 44aa582b
      Mattias Jonsson authored
      44aa582b
  13. 10 Jun, 2011 9 commits