1. 23 Oct, 2008 3 commits
    • sunny's avatar
      branches/zip: · 119142d2
      sunny authored
      Merge revisions 2852:2854 from branches/5.1:
      
        ------------------------------------------------------------------------
        r2854 | sunny | 2008-10-23 08:30:32 +0300 (Thu, 23 Oct 2008) | 13 lines
        Changed paths:
           M /branches/5.1/dict/dict0dict.c
           M /branches/5.1/dict/dict0mem.c
           M /branches/5.1/handler/ha_innodb.cc
           M /branches/5.1/handler/ha_innodb.h
           M /branches/5.1/include/dict0dict.h
           M /branches/5.1/include/dict0mem.h
           M /branches/5.1/row/row0mysql.c
        
        branches/5.1: Backport changes from branches/zip r2725
        
        Simplify the autoinc initialization code. This removes the
        non-determinism related to reading the table's autoinc value for the first
        time. This change has also reduced the sizeof dict_table_t by sizeof(ibool)
        bytes because we don't need the dict_table_t::autoinc_inited field anymore.
        
        Bug#39830 Table autoinc value not updated on first insert.
        Bug#35498 Cannot get table test/table1 auto-inccounter value in ::info
        Bug#36411 Failed to read auto-increment value from storage engine" in 5.1.24 auto-inc
        rb://16
        
        
        ------------------------------------------------------------------------
      119142d2
    • sunny's avatar
      Reverting test file changes from r2855 · 44895677
      sunny authored
      44895677
    • sunny's avatar
      branches/zip: · f9c42d81
      sunny authored
      Merge revisions 2837:2852 from branches/5.1:
      
        ------------------------------------------------------------------------
        r2849 | sunny | 2008-10-22 12:01:18 +0300 (Wed, 22 Oct 2008) | 8 lines
        Changed paths:
           M /branches/5.1/handler/ha_innodb.cc
           M /branches/5.1/include/row0mysql.h
           M /branches/5.1/row/row0mysql.c
        
        branches/5.1: Return the actual error code encountered when allocating
        a new autoinc value. The change in behavior (bug) was introduced in 5.1.22
        when we introduced the new AUTOINC locking model.
        
        rb://31
        
        Bug#40224 New AUTOINC changes mask reporting of deadlock/timeout errors
        
        ------------------------------------------------------------------------
        r2852 | sunny | 2008-10-23 01:42:24 +0300 (Thu, 23 Oct 2008) | 9 lines
        Changed paths:
           M /branches/5.1/handler/ha_innodb.cc
           M /branches/5.1/handler/ha_innodb.h
        
        branches/5.1: Backport r2724 from branches/zip
        
        Check column value against the col max value before updating the table's
        global autoinc counter value. This is part of simplifying the AUTOINC
        sub-system. We extract the type info from MySQL data structures at runtime.
        
        This fixes Bug#37788 InnoDB Plugin: AUTO_INCREMENT wrong for compressed tables
        
        
        ------------------------------------------------------------------------
      f9c42d81
  2. 22 Oct, 2008 3 commits
  3. 21 Oct, 2008 4 commits
    • vasil's avatar
      branches/zip: · 49589d0a
      vasil authored
      Merge 2744:2837 from branches/5.1 (skipping r2782 and r2826):
      
        ------------------------------------------------------------------------
        r2832 | vasil | 2008-10-21 10:08:30 +0300 (Tue, 21 Oct 2008) | 10 lines
        Changed paths:
           M /branches/5.1/handler/ha_innodb.cc
        
        branches/5.1:
        
        In ha_innobase::info():
        
        Replace sql_print_warning() which prints to mysqld error log with
        push_warning_printf() which sends the error message to the client.
        
        Suggested by:	Marko, Sunny, Michael
        Objected by:	Inaam
        
        ------------------------------------------------------------------------
        r2837 | vasil | 2008-10-21 12:07:44 +0300 (Tue, 21 Oct 2008) | 32 lines
        Changed paths:
           M /branches/5.1/mysql-test/innodb-semi-consistent.result
           M /branches/5.1/mysql-test/innodb-semi-consistent.test
           M /branches/5.1/mysql-test/innodb.result
           M /branches/5.1/mysql-test/innodb.test
        
        branches/5.1:
        
        Merge a change from MySQL (this fixes the failing innodb and
        innodb-semi-consistent tests):
        
          revno: 2757
          committer: Georgi Kodinov <kgeorge@mysql.com>
          branch nick: B39812-5.1-5.1.29-rc
          timestamp: Fri 2008-10-03 15:24:19 +0300
          message:
            Bug #39812: Make statement replication default for 5.1 (to match 5.0)
            
            Make STMT replication default for 5.1.
            Add a default of MIXED into the config files
            Fix the tests that needed MIXED replication mode.
          modified:
            mysql-test/include/mix1.inc
            mysql-test/r/innodb-semi-consistent.result
            mysql-test/r/innodb.result
            mysql-test/r/innodb_mysql.result
            mysql-test/r/tx_isolation_func.result
            mysql-test/t/innodb-semi-consistent.test
            mysql-test/t/innodb.test
            mysql-test/t/tx_isolation_func.test
            sql/mysqld.cc
            support-files/my-huge.cnf.sh
            support-files/my-innodb-heavy-4G.cnf.sh
            support-files/my-large.cnf.sh
            support-files/my-medium.cnf.sh
            support-files/my-small.cnf.sh
        
        
        ------------------------------------------------------------------------
      49589d0a
    • marko's avatar
      ea6d7034
    • marko's avatar
    • marko's avatar
      branches/zip: ibuf_insert_low(): Avoid unnecessarily · cb8ae339
      marko authored
      acquiring and releasing ibuf_mutex.
      cb8ae339
  4. 20 Oct, 2008 2 commits
  5. 16 Oct, 2008 2 commits
    • vasil's avatar
      branches/zip: · 2453a49a
      vasil authored
      Fix Mantis issue#61:
      
      In row_undo_ins_parse_undo_rec(): if we find that a table has no indexes
      (dict_table_get_first_index() returns NULL) do not try to call
      trx_undo_rec_get_row_ref() with a NULL pointer because that would lead to
      a crash. Instead, print a warning and set node->table to NULL just like
      it is done if the .ibd file is missing.
      
      Approved by:	Heikki (via IM)
      2453a49a
    • marko's avatar
      branches/zip: Skip the undo log size check on REDUNDANT and COMPACT tables. · bb4b3f40
      marko authored
      In ROW_FORMAT=DYNAMIC and ROW_FORMAT=COMPRESSED, column prefix indexes
      require that prefixes of externally stored columns be written to the
      undo log. This may make the undo log record bigger than the record on
      the B-tree page.  The maximum size of an undo log record is the page
      size.  That must be checked for, in dict_index_add_to_cache().
      
      dict_index_add_to_cache(): Skip the undo log size check for REDUNDANT
      and COMPACT tables. These tables store prefixes of externally stored
      columns locally within the clustered index record.  There are no special
      considerations for the undo log record size.
      
      innodb-index.test: Ensure that the check exists for ROW_FORMAT=DYNAMIC,
      but not for ROW_FORMAT=COMPACT.
      
      This fixes issue #99.  rb://28 approved by Sunny.
      bb4b3f40
  6. 15 Oct, 2008 4 commits
    • marko's avatar
      branches/zip: When the server crashes while freeing an externally stored · 8ec95fc7
      marko authored
      column of a compressed table, the BTR_EXTERN_LEN field in the BLOB pointer
      will be written as 0.  Tolerate this in the functions that deal with
      externally stored columns.  This fixes Issue #80 and was posted at rb://26.
      
      Note that the clustered index record is always deleted or purged last,
      after any secondary index records referring to it have been deleted.
      
      btr_free_externally_stored_field(): On an uncompressed table, zero out
      the BTR_EXTERN_LEN, so that half-deleted BLOBs can be detected after
      crash recovery.
      
      btr_copy_externally_stored_field_prefix(): Return 0 if the BLOB has been
      half-deleted.
      
      row_upd_ext_fetch(): Assert that the externally stored column exists.
      
      row_ext_cache_fill(): Allow btr_copy_externally_stored_field_prefix()
      to return 0.
      
      row_sel_sec_rec_is_for_blob(): Return FALSE if the BLOB has been half-deleted.
      This is correct, because the clustered index record would have been deleted
      or purged last, after any secondary index records referring to it had been
      deleted.
      8ec95fc7
    • marko's avatar
      branches/zip: Introduce UNIV_ZIP_COPY for invoking page_zip_copy_recs() · f644f6af
      marko authored
      more often in B-tree operations.
      f644f6af
    • marko's avatar
      branches/zip: When invoking page_zip_copy_recs(), update the lock table · 05c33d6d
      marko authored
      and the adaptive hash index.  This should fix Issue #95 and Issue #87.
      
      page_zip_copy_recs(): Copy PAGE_MAX_TRX_ID as well, to have similar behavior
      to page_copy_rec_list_start() and page_copy_rec_list_end().
      
      btr_root_raise_and_insert(), btr_page_split_and_insert(), btr_lift_page_up():
      Update the lock table and the adaptive hash index.
      05c33d6d
    • marko's avatar
      branches/zip: row_create_table_for_mysql(), row_create_index_for_mysql(): · 344481d5
      marko authored
      Note that the dictionary object will be freed.
      344481d5
  7. 14 Oct, 2008 2 commits
  8. 13 Oct, 2008 4 commits
  9. 11 Oct, 2008 2 commits
  10. 10 Oct, 2008 1 commit
    • marko's avatar
      branches/zip: Fix some locking issues, mainly in fast index creation. · 41953325
      marko authored
      This should hopefully address Issue #85.
      
      ha_innobase::add_index(): Lock the data dictionary before invoking
      row_merge_rename_indexes() or row_merge_drop_indexes(), because neither
      function will commit the transaction.
      
      ha_innobase::final_drop_index(): Commit the transactions before
      unlocking the data dictionary.
      
      row_merge_drop_index(), row_merge_drop_indexes(), row_merge_rename_tables(),
      row_merge_rename_indexes(): Note and assert that the data dictionary must
      have been exclusively locked by the caller, because the transaction will
      not be committed.
      
      row_drop_database_for_mysql(): Commit the transaction immediately after
      dropping each table.  When MySQL is holding open handles to some tables,
      it can otherwise occur than the data dictionary is unlocked while the
      transaction has not been committed.  This bug was introduced in r2739,
      which changed the semantics of row_drop_table_for_mysql().
      
      row_drop_database_for_mysql(): Postpone mem_free(table_name), so that
      an error printout will not dereference freed memory.
      41953325
  11. 09 Oct, 2008 1 commit
    • marko's avatar
      branches/zip: Merge revisions 2722:2744 from branches/5.1: · 77a22984
      marko authored
        ------------------------------------------------------------------------
        r2742 | inaam | 2008-10-08 22:02:15 +0300 (Wed, 08 Oct 2008) | 11 lines
      
        branches/5.1:
      
        Fix Bug#39939 DROP TABLE/DISCARD TABLESPACE takes long time in
        buf_LRU_invalidate_tablespace()
      
        Improve implementation of buf_LRU_invalidate_tablespace by attempting
        hash index drop in batches instead of doing it one by one.
      
        Reviewed by: Heikki, Sunny, Marko
        Approved by: Heikki
        ------------------------------------------------------------------------
        r2744 | marko | 2008-10-09 10:53:09 +0300 (Thu, 09 Oct 2008) | 5 lines
      
        branches/5.1: ha_innobase::delete_all_rows(): In response to a user asking
        <http://forums.innodb.com/read.php?4,215,215> why DELETE FROM t is not
        mapped to TRUNCATE TABLE t as it is in MyISAM, note in a comment that
        DELETE is transactional while TRUNCATE is not.
        ------------------------------------------------------------------------
      77a22984
  12. 08 Oct, 2008 3 commits
    • marko's avatar
      branches/zip: mysql-test/patches/innodb_file_per_table.diff: · c39985b0
      marko authored
      @@GLOBAL.innodb_file_per_table can be 0 or 1, while
      SELECT VARIABLE_VALUE FROM INFORMATION_SCHEMA.GLOBAL_VARIABLES
      WHERE VARIABLE_NAME='innodb_file_per_table'
      can be 'OFF' or 'ON'.  For some reason, MySQL evaluates
      (0 = 'OFF') to 1 and (1 = 'ON') to 0.  Thus, the test would
      fail if innodb_file_per_table is set.
      c39985b0
    • marko's avatar
      branches/zip: page_copy_rec_list_end(): Remove the call · d546c0cf
      marko authored
      page_zip_validate_low(new_page_zip, new_page, TRUE) because it would
      cause bogus failures in btr_compress(), as noted in Issue #79.
      d546c0cf
    • marko's avatar
      branches/zip: Do not release the data dictionary latch while holding locks · a9a21fb9
      marko authored
      to the data dictionary records.  This should fix Issue #83.
      
      row_drop_table_for_mysql_no_commit(): Rename back to
      row_drop_table_for_mysql().  Commit the transaction if the data
      dictionary was not locked when the function was called.  Otherwise,
      neither commit the transaction nor unlock the data dictionary.
      
      row_merge_drop_table(): Let row_drop_table_for_mysql() take care of
      locking the data dictionary.
      
      dict_create_or_check_foreign_constraint_tables(),
      trx_rollback_active(), row_create_table_for_mysql(),
      row_create_index_for_mysql(), row_table_add_foreign_constraints():
      Explicitly commit the transaction, because row_drop_table_for_mysql()
      would no longer commit it, given that the data dictionary will be
      locked during the calls.
      
      Approved by Sunny (over IM). rb://23
      a9a21fb9
  13. 07 Oct, 2008 6 commits
    • marko's avatar
      branches/zip: Improve page_zip_validate() instrumentation. · 278a68a0
      marko authored
      btr_lift_page_up(): Invoke page_zip_validate() on every page whose level
      is adjusted.
      
      btr_compress(): Invoke page_zip_validate() on merge_page at the end.
      
      page_zip_copy_recs(): Relax the page_zip_validate(...) to
      page_zip_validate_low(..., sloppy = TRUE) to avoid bogus assertion failures.
      
      page_copy_rec_list_end(), page_delete_rec_list_start():
      Invoke page_zip_validate_low(sloppy = TRUE).
      278a68a0
    • marko's avatar
      branches/zip: mysql-test/patches/information_schema.diff: · f52d978e
      marko authored
      Add patches to other mysql-test results that fail because of the added
      INFORMATION_SCHEMA tables: information_schema_db.result, mysqlshow.result.
      f52d978e
    • vasil's avatar
      branches/zip: · aed42707
      vasil authored
      Rename type_bit_innodb.diff to bug32625.diff since an equivalent patch has
      been submitted to MySQL as Bug#32625 Make test type_bit_innodb more robust.
      aed42707
    • marko's avatar
      branches/zip: Add some more patches to mysql-test. · 2eda3b44
      marko authored
      type_bit_innodb.diff: Ignore the reported duplicate value.  The reported
      value depends on the internal workings of the merge sort in
      fast index creation.  In the built-in InnoDB of MySQL 5.1, the records
      are copied to a new temporary table in the order they were selected from
      the original table.
      
      information_schema.diff: Account for the INFORMATION_SCHEMA tables that
      were added in the InnoDB plugin.
      
      innodb_file_per_table.diff: In the InnoDB plugin, innodb_file_per_table
      is a settable global variable.
      2eda3b44
    • marko's avatar
      branches/zip: Patch the mysql-test suite, so that it will not fail · a25e07ba
      marko authored
      because innodb_lock_wait_timeout is a settable session variable as of r2716.
      
      mysql-test/patches/innodb_lock_wait_timeout.diff: New file.
      a25e07ba
    • calvin's avatar
      Delete the recently added files from MySQL source tree, for · 0eed3f2e
      calvin authored
      Windows plugin. Instead, we will commit diff only.
      0eed3f2e
  14. 06 Oct, 2008 3 commits
    • marko's avatar
      branches/zip: Improve the diagnostics of issue #79. · 80e6e2c2
      marko authored
      page_zip_fail_func(): Display the timestamp.
      
      page_zip_validate_low(): Display information about ignored min_rec_flag
      differences.
      80e6e2c2
    • marko's avatar
      branches/zip: Relax the page_zip_validate() check during crash recovery: · 5f3fbb7b
      marko authored
      ignore intermittent differences in the "predefined minimum record" flag.
      
      page_zip_validate_low(): Renamed from page_zip_validate(), with an
      additional parameter: ibool sloppy.  Ignore REC_INFO_MIN_REC_FLAG when
      sloppy == TRUE.
      
      page_zip_validate(): Wrapper for page_zip_validate_low().  Pass
      sloppy = recv_recovery_is_on().
      
      recv_recover_page(): After applying the changes from the redo log to a
      compressed B-tree page, invoke page_zip_validate_low() in strict mode.
      5f3fbb7b
    • vasil's avatar
      branches/zip: · 9daa40cc
      vasil authored
      Add more ChangeLog entries from the merge
      of 2702:2722 from branches/5.1 (r2723).
      9daa40cc