1. 09 Jan, 2009 1 commit
    • Michael Widenius's avatar
      Code cleanup: · 7eda7f13
      Michael Widenius authored
      - Removed not needed casts
      - Indentation fixes
      - Changed some buffer variables to uchar, to be able to remove casts
      
      
      storage/maria/ma_bitmap.c:
        Removed not needed casts
      storage/maria/ma_blockrec.c:
        Removed not needed casts
      storage/maria/ma_check.c:
        Removed not needed casts.
        Changed type of buffers to be able to remove casts
      storage/maria/ma_create.c:
        Removed not needed casts
      storage/maria/ma_delete.c:
        Removed not needed casts
      storage/maria/ma_dynrec.c:
        Removed not needed casts
      storage/maria/ma_extra.c:
        Removed not needed casts
      storage/maria/ma_ft_boolean_search.c:
        Removed not needed casts
      storage/maria/ma_ft_nlq_search.c:
        Removed not needed casts
      storage/maria/ma_ft_parser.c:
        Removed not needed casts
      storage/maria/ma_loghandler.c:
        Removed not needed casts
      storage/maria/ma_open.c:
        Removed not needed casts
      storage/maria/ma_packrec.c:
        Removed not needed casts
      storage/maria/ma_pagecache.c:
        Removed not needed casts
      storage/maria/ma_preload.c:
        Removed not needed casts
        Removed not needed initialization
      storage/maria/ma_rnext_same.c:
        Removed not needed casts
      storage/maria/ma_rt_index.c:
        Removed not needed casts
      storage/maria/ma_search.c:
        Removed not needed casts
      storage/maria/ma_sort.c:
        Removed not needed casts
        Removed not needed if
        Fixed indentation
      storage/maria/ma_statrec.c:
        Removed not needed casts
      storage/maria/ma_test2.c:
        Removed not needed casts
      storage/maria/ma_write.c:
        Removed not needed casts
        Indentation fixes
      storage/maria/maria_chk.c:
        Removed not needed casts
      storage/maria/maria_pack.c:
        Removed not needed casts
      7eda7f13
  2. 01 Sep, 2008 1 commit
    • Michael Widenius's avatar
      Added MARIA_PAGE structure to keep all information about a maria key page. · d6bdf033
      Michael Widenius authored
      This allowed me to remove a lot of parameters to functions, local variables,
      duplicate code and identical constructs.  It should also make the code easier
      to read.
      Changed all marking of page as changed to use offset instead of pointers; This removed
      one theoretical problem where dynamic_array may have been moved between two calls.
      In addition I changed some functions from return my_bool
      
      
      include/maria.h:
        Changes to use MARIA_PAGE
      storage/maria/ma_check.c:
        Changes to use MARIA_PAGE
        Folded lines longer > 79 characters
      storage/maria/ma_delete.c:
        Changes to use MARIA_PAGE
        Changed _ma_ck_delete(), ma_log_delete(), ma_write_undo_key_delete() and _ma_ck_real_delete() to return type my_bool
        Removed some calls to maria_print_error() as the caller (maria_delete() and maria_write()) also prints the error
      storage/maria/ma_ft_update.c:
        Fix needed as _ma_ck_delete() now returns my_bool
        New parameter for ma_write_keypage.
      storage/maria/ma_key_recover.c:
        Changes to use MARIA_PAGE
      storage/maria/ma_key_recover.h:
        Updated function prototypes
      storage/maria/ma_page.c:
        Changes to use MARIA_PAGE
        Added _ma_page_setup() for old functions that doesn't (yet) use MARIA_PAGE natively
      storage/maria/ma_range.c:
        Changes to use MARIA_PAGE
      storage/maria/ma_rt_index.c:
        Changes to use MARIA_PAGE
        Changed maria_rtree_delete() and maria_rtree_real_delete() to return type my_bool
        Removed one 'if (node_flag) as this was always true
        Changed lable 'err1' to 'err' as there was no other error lables
        Moved allocation of page_buff outside of loop for fewer alloc/free calls
        Changed n_pages and m_pages to uint as 65000 pages is more than enough
      storage/maria/ma_rt_index.h:
        Updated function prototypes
      storage/maria/ma_rt_key.c:
        Changes to use MARIA_PAGE
      storage/maria/ma_rt_key.h:
        Updated function prototypes
      storage/maria/ma_rt_mbr.c:
        Changes to use MARIA_PAGE
      storage/maria/ma_rt_mbr.h:
        Updated function prototypes
      storage/maria/ma_rt_split.c:
        Changes to use MARIA_PAGE
      storage/maria/ma_search.c:
        Changes to use MARIA_PAGE
      storage/maria/ma_write.c:
        Changes to use MARIA_PAGE
        Changed _ma_ck_write_btree_with_log(), _ma_ck_real_write_btree(), ma_enlarge_root() to use return type my_bool
        Don't set *root to HA_OFFSET_ERROR in case of error
        Removed maria_print_error() calls as caller will do this
        Simplified logic in balance_page by introducing pointers to left and right pages
      storage/maria/maria_chk.c:
        Changes to use MARIA_PAGE
      storage/maria/maria_def.h:
        Changes to use MARIA_PAGE
        Removed some not used macros
        Added macros for MARIA_PAGE handling
      d6bdf033
  3. 26 Aug, 2008 1 commit
    • Michael Widenius's avatar
      Fix for Bug#36499 Maria: potential deadlock · dd406c1e
      Michael Widenius authored
      This was done by introducing another mutex for handling the key_del link
      I also renamed all key_del variables to start with key_del prefix
      
      
      storage/maria/ma_close.c:
        Rename of key_del variables
      storage/maria/ma_key_recover.c:
        Changed key_del to be protexted by it's own mutex: key_del_lock
        Rename of key_del variables
        Removed comment for old bug
      storage/maria/ma_key_recover.h:
        Rename of key_del variables
      storage/maria/ma_open.c:
        Initialization for new key_del_lock mutex
        Renamed intern_cond to key_del_cond as it was only used for protection of key_del
      storage/maria/ma_page.c:
        Rename of key_del variables
      storage/maria/ma_write.c:
        Rename of key_del variables
      storage/maria/maria_def.h:
        Rename of key_del variables
        Added key_del_lock
      dd406c1e
  4. 25 Aug, 2008 4 commits
    • Michael Widenius's avatar
      Fixed some wrong usage of my_bool · 6629c764
      Michael Widenius authored
      Fixed compiler warning
      Ensure that pagecache returns correct error number
      
      
      storage/maria/ma_pagecache.c:
        Ensure that block->error contain error code from my_errno (not return value from pread/pwrite)
        Went through usage of my_pread/my_pwrite and ensured that result was threated correctly
        Fixed some wrong usage of my_bool
      6629c764
    • Michael Widenius's avatar
      Automatic merge · 43528b9d
      Michael Widenius authored
      43528b9d
    • Michael Widenius's avatar
      Changed all file names in maria to LEX_STRING and removed some calls to strlen() · 1a5de5bc
      Michael Widenius authored
      Ensure that pagecache gives correct error number even if error for block happend
      
      
      mysys/my_pread.c:
        Indentation fix
      storage/maria/ha_maria.cc:
        filenames changed to be of type LEX_STRING
      storage/maria/ma_check.c:
        filenames changed to be of type LEX_STRING
      storage/maria/ma_checkpoint.c:
        filenames changed to be of type LEX_STRING
      storage/maria/ma_create.c:
        filenames changed to be of type LEX_STRING
      storage/maria/ma_dbug.c:
        filenames changed to be of type LEX_STRING
      storage/maria/ma_delete.c:
        filenames changed to be of type LEX_STRING
      storage/maria/ma_info.c:
        filenames changed to be of type LEX_STRING
      storage/maria/ma_keycache.c:
        filenames changed to be of type LEX_STRING
      storage/maria/ma_locking.c:
        filenames changed to be of type LEX_STRING
      storage/maria/ma_loghandler.c:
        filenames changed to be of type LEX_STRING
      storage/maria/ma_open.c:
        filenames changed to be of type LEX_STRING
      storage/maria/ma_pagecache.c:
        Store error number for last failed operation in the page block
        This should fix some asserts() when errno was not properly set after failure to read block in another thread
      storage/maria/ma_recovery.c:
        filenames changed to be of type LEX_STRING
      storage/maria/ma_update.c:
        filenames changed to be of type LEX_STRING
      storage/maria/ma_write.c:
        filenames changed to be of type LEX_STRING
      storage/maria/maria_def.h:
        filenames changed to be of type LEX_STRING
      storage/maria/maria_ftdump.c:
        filenames changed to be of type LEX_STRING
      storage/maria/maria_pack.c:
        filenames changed to be of type LEX_STRING
      1a5de5bc
    • Sergei Golubchik's avatar
      BUG#38606: delete in lock write concurrent · 4bdb308b
      Sergei Golubchik authored
      (sanja's patch)
      4bdb308b
  5. 24 Aug, 2008 1 commit
    • Michael Widenius's avatar
      Fix for bug#38484 DELETE causes crash or index corruption · d145362e
      Michael Widenius authored
      There is no test cases as it's not trivial to do a test case for this.
      The new code for Maria is however executed by the test case in the bug report.
      
      mysql-test/mysql-test-run.pl:
        Avoid warnings when running with --extern
      storage/maria/ha_maria.cc:
        Disable not complete assert until Sanja can push a proper fix
      storage/maria/ma_delete.c:
        Fix that pageflag for page is calculated based on original values
      storage/maria/ma_search.c:
        Ensure that prev_length structure variable is properly reset when not used
      storage/myisam/mi_search.c:
        Ensure that prev_length structure variable is properly reset when not used
      d145362e
  6. 18 Aug, 2008 2 commits
    • Michael Widenius's avatar
      Automatic merge · 57e0bdb3
      Michael Widenius authored
      57e0bdb3
    • Michael Widenius's avatar
      Fixes for Bug #38016 Maria: trying to access freed memory when committing a transaction · ea31b1e6
      Michael Widenius authored
      Don't write out states if they haven't changed
      
      sql/sql_base.cc:
        Call extra(HA_EXTRA_PREPARE_FOR_DROP) before doing a drop of a table
        More DBUG
      sql/sql_table.cc:
        Call extra(HA_EXTRA_PREPARE_FOR_RENAME) before renaming a table
      storage/maria/ha_maria.cc:
        Ensure that file->trn is set when we call extra(HA_EXTRA_PREPARE_FOR_DROP/RENAME)
      storage/maria/ma_close.c:
        When doing close, assert if we have pointers in trn->table_list that points to the MARIA_SHARE
      storage/maria/ma_extra.c:
        Reset info->state_start in case of drop/rename. This fixes the problem of accessing freed memory in repair
        Don't write state changed if they haven't changed
      storage/maria/ma_open.c:
        Reset share->changed after we have written out a state (speed optimization to not write states when they haven't changed)
      storage/maria/ma_state.c:
        Decrement share->in_trans properly in DBUG_BINARY to ensure that the DBUG_ASSERT() in maria_close() works
        More DBUG
      ea31b1e6
  7. 16 Aug, 2008 1 commit
    • Sergei Golubchik's avatar
      Bug#38466 maria: range query returns no data · edb33da7
      Sergei Golubchik authored
      storage/maria/ma_search.c:
        when we found a matching key on the node page and want to search in the left leaf
        we must use only SEARCH_FIND flag, and never SEARCH_BIGGER, SEARCH_SMALLER, or SEARCH_LAST
      edb33da7
  8. 11 Aug, 2008 1 commit
  9. 12 Jul, 2008 2 commits
    • Michael Widenius's avatar
      Auto merge · 9e762653
      Michael Widenius authored
      mysql-test/r/maria2.result:
        Manual merge
      9e762653
    • Michael Widenius's avatar
      Fixing bug when using alter table on locked maria table · 50fa1eb8
      Michael Widenius authored
      Reset history when we reenable logging for transactional tables (safety fix)
      
      mysql-test/r/maria2.result:
        New results
      mysql-test/t/maria2.test:
        Added test case for alter table on locked maria table
      mysql-test/valgrind.supp:
        Added suppression rules for warnings in libc / libld
      storage/maria/ma_extra.c:
        Remove table from trnman list if we are going to drop or rename it; We don't want not existing shares in the list when we do commit!
      storage/maria/ma_recovery.c:
        Ensure that info->state don't point to history event when we disable logging for a table;  This is needed as alter table will first do commit and then unlock, which would cause us to access a non existing object when we reenable logging.
        Reset history when we reenable logging (safety fix)
      storage/maria/ma_state.c:
        Do less work when share->now_transactional is not set. (Safety fix)
        Added function to remove shares to be deleted from trnman->used_tables
        Added function to reset history to current context
      storage/maria/ma_state.h:
        Prototypes for new function
      50fa1eb8
  10. 11 Jul, 2008 1 commit
    • Guilhem Bichot's avatar
      Fix for BUG#38018 INSERT SELECT ON DUPLICATE KEY UPDATE and LOAD DATA CONCURRENT REPLACE · 6f8b889a
      Guilhem Bichot authored
      used TL_WRITE_CONCURRENT_INSERT though they may update/delete a row. This could cause concurrent SELECTs
      to see a changing table while the SELECT happens, or if the query was made of a group of SELECTs,
      some SELECTs would see different versions of the table. And anyway versioning in Maria was so far coded
      to support only insertions. REPLACE SELECT, INSERT VALUES ON DUPLICATE KEY UPDATE, LOAD DATA REPLACE
      were ok.
      
      mysql-test/r/maria2.result:
        result. Without the code fix, the assertion added to ha_maria::update_row() would fire twice.
      mysql-test/t/maria2.test:
        test when INSERT ON DUPLICATE KEY UPDATE and LOAD DATA CONCURRENT REPLACE do update rows
      storage/maria/ha_maria.cc:
        Assert that update_row and delete_row never see TL_WRITE_CONCURRENT_INSERT.
        INSERT SELECT ON DUPLICATE KEY UPDATE and LOAD DATA CONCURRENT REPLACE
        must upgrade TL_WRITE_CONCURRENT_INSERT to TL_WRITE because they may update/delete a row.
      6f8b889a
  11. 10 Jul, 2008 2 commits
  12. 09 Jul, 2008 6 commits
    • Guilhem Bichot's avatar
      Merge of latest mysql-maria · 8de480a2
      Guilhem Bichot authored
      8de480a2
    • Guilhem Bichot's avatar
      Fix for BUG#37873 "Client gets ok from INSERT VALUES before commit record is on disk": · 71f72bad
      Guilhem Bichot authored
      this was true also for INSERT SELECT, UPDATE, DELETE. This fix will be removed when Maria supports COMMIT/ROLLBACK
      ("Maria 2.0"), because then Maria will trans_register_ha() and so participate in ha_commit_trans().
      Without the fix, the assertion added to ha_maria::external_lock() fires many times in *maria*.test.
      
      sql/sql_parse.cc:
        Before sending OK to client, commit transaction in Maria.
      storage/maria/ha_maria.cc:
        Assertion added to external_lock() when committing: OK should not have been sent yet (ACI*D*).
        In ha_maria::implicit_commit(), possibility to not create a new transaction, this is used
        before net_end_statement(), when the next step is close_thread_tables();
        in this use case, ha_maria::implicit_commit() should not commit if under LOCK TABLES.
      storage/maria/ha_maria.h:
        new prototype
      71f72bad
    • Michael Widenius's avatar
      Fixes for bug#37276: · 7f022824
      Michael Widenius authored
      - Fixes key corruption where pages wasn't marked that they contained transid.
      - Fixed bug in block record that could create too small rows when transid was removed. This fixed some asserts() when testing block length
      
      Added --abort-source-on-error to the mysql client. (Very helpfull when debugging wrong .sql files)
      
      client/client_priv.h:
        Added enum for new option to mysql
      client/mysql.cc:
        Added new option --abort-source-on-error to allow one to get 'source' to stop on error. This is 0 by default, to keep old behaviour.
        Print file name and line number when getting an error when doing source filename
      sql/field.cc:
        Removed old dead code
      sql/sql_class.cc:
        Removed old dead code
      storage/maria/ma_blockrec.c:
        Added checking of min block length to check_directory()
        When creating new directory entry, set length to 0; This ensures that the assert checks() on block lengths works properly.
        Added more DBUG_ASSERT() and more calls to check_directory()
        In get_head_or_tail_page(), send in correct min_block_length. This is now safe as the length of new blocks are now 0
      storage/maria/ma_delete.c:
        When moving key to parent page, mark page if key has transid
      storage/maria/ma_write.c:
        Fixed bug where _ma_find_last_pos() didn't set int_key->flag.
        Simpilifed code by unrolling loop.
      7f022824
    • Guilhem Bichot's avatar
      Test for fix made by Monty for BUG#37276 (CHECK TABLE said Invalid key block... · 942b3879
      Guilhem Bichot authored
      Test for fix made by Monty for BUG#37276 (CHECK TABLE said Invalid key block position: 15731098820608  key
      +# block size: 8192  file_length: 425984). Other corruption cases still not fixed.
      Without the fix, the test would yield the corruption message in CHECK TABLE.
      
      mysql-test/r/maria-big2.result:
        result
      mysql-test/t/maria-big2.test:
        test for bugfix
      942b3879
    • Guilhem Bichot's avatar
      - lifting a limit: INSERT|REPLACE SELECT and LOAD DATA always prevented... · 81d3d3ac
      Guilhem Bichot authored
      - lifting a limit: INSERT|REPLACE SELECT and LOAD DATA always prevented versioning, now what do so is if
      the table is empty.
      - lifting another limit: versioning was disabled if table had more than one unique index
      - correcting test of statement-based binlogging, when converting read locks to TL_READ_NO_INSERT
      
      KNOWN_BUGS.txt:
        removing mostly fixed limitation (see ha_maria.cc)
      mysql-test/r/maria-mvcc.result:
        result update
      mysql-test/t/maria-mvcc.test:
        now when table is empty it does not do versioning, so test hung; inserting one row at start of the test,
        to enable versioning.
      sql/sql_parse.cc:
        Maria team wrongly removed this "break", thanks Davi for noticing
      storage/maria/ha_maria.cc:
        - We used to prevent versioning in INSERT/REPLACE SELECT and LOAD DATA, because the index rebuild done by
        bulk insert sometimes, is unsafe when versioning is on. Here we change that: in store_lock(), if the table is empty
        (which is required for index rebuild to be used), we disable versioning; in start_bulk_insert(), we don't do
        index rebuild if versioning is enabled.
        - Test for statement-based binlogging was incomplete: statement-based binlogging is on for this statement
        if binlog is open and statement has binlogging enabled and statement is not doing row-based binlogging
      storage/maria/ma_open.c:
        Monty and I agreed that it's ok to have versioning on a table with more than one unique index: if an INSERT
        hits a duplicate key when inserting the second index' key, no other thread should be able to touch the 
        first index' just-inserted key, because that key has an uncommitted transaction id, so the first thread
        should have time to remove the first index' key.
      81d3d3ac
    • Guilhem Bichot's avatar
      Fix for BUG#37876 "Importing Maria table from other server via binary copy does not work": · 60b88ce4
      Guilhem Bichot authored
      - after auto-zerofill (ha_maria::check_and_repair()) kepts its state's LSNs unchanged, which could
      be the same as the create_rename_lsn of another pre-existing table, which would break versioning as this LSN
      serves as unique identifier in the versioning code (in maria_open()). Even the state pieces which
      maria_zerofill() did change were lost (because they didn't go to disk).
      - after this fix, if two tables were auto-zerofilled at the same time (by _ma_mark_changed())
      they could receive the same create_rename_lsn, which would break versioning again. Fix is to write a log
      record each time a table is imported.
      - Print state's LSNs (create_rename_lsn, is_of_horizon, skip_redo_lsn) and UUID in maria_chk -dvv.
      
      mysql-test/r/maria-autozerofill.result:
        result
      mysql-test/t/maria-autozerofill.test:
        Test for auto-zerofilling
      storage/maria/ha_maria.cc:
        The state changes done by auto-zerofilling never reached disk.
      storage/maria/ma_check.c:
        When zerofilling a table, including its pages' LSNs, new state LSNs are needed next time the table
        is imported into a Maria instance.
      storage/maria/ma_create.c:
        Write LOGREC_IMPORTED_TABLE when importing a table. This is informative and ensures
        that the table gets a unique create_rename_lsn even though multiple tables
        are imported by concurrent threads (it advances the log's end LSN).
      storage/maria/ma_key_recover.c:
        comment
      storage/maria/ma_locking.c:
        instead of using translog_get_horizon() for state's LSNs of imported table,
        use the LSN of to-be-written LOGREC_IMPORTED_TABLE.
      storage/maria/ma_loghandler.c:
        New type of log record
      storage/maria/ma_loghandler.h:
        New type of log record
      storage/maria/ma_loghandler_lsn.h:
        New name for constant as can be used not only by maria_chk but auto-zerofill now too.
      storage/maria/ma_open.c:
        instead of using translog_get_horizon() for state's LSNs of imported table,
        use the LSN of to-be-written LOGREC_IMPORTED_TABLE.
      storage/maria/ma_recovery.c:
        print content of LOGREC_IMPORTED_TABLE in maria_read_log.
      storage/maria/maria_chk.c:
        print info about LSNs of the table's state, and UUID, when maria_chk -dvv
      storage/maria/maria_pack.c:
        new name for constant
      storage/maria/unittest/ma_test_recovery.pl:
        Now that maria_chk -dvv shows state LSNs and UUID those need to be filtered out,
        as maria_read_log -a does not use the same as at original run.
      60b88ce4
  13. 05 Jul, 2008 2 commits
    • Michael Widenius's avatar
      Automatic merge · f9ef13d5
      Michael Widenius authored
      f9ef13d5
    • Michael Widenius's avatar
      Bug#37276 maria crash on insert around the time check table is run · 82d79389
      Michael Widenius authored
      Fixed several (but not all) issues found by the test program:
      - ASSERT on row_length in ma_blockrec.c::_ma_compact_block_page()
      - Fixed bug when splitting node pages
      - Fixed hang in 'closeing tables' (conflicting mutex order) by ensuring we first take trnman lock and then share->intern_lock
      
      storage/maria/ma_blockrec.c:
        When compacting a row page when allocating space for a new row, the min length of a the new block may be temporarly smaller than 'min_block_length'.
      storage/maria/ma_check.c:
        More DBUG output
      storage/maria/ma_checkpoint.c:
        Call new function _ma_remove_not_visible_states_with_lock() to ensure we first take lock on trnman and then on share->intern_lock
        +
      storage/maria/ma_close.c:
        Added comment
      storage/maria/ma_open.c:
        Added comment
      storage/maria/ma_search.c:
        Copy also node data; Caused bug when splitting node pages
      storage/maria/ma_state.c:
        Added _ma_remove_not_visible_states_with_lock() to ensure we take locks in right order
      storage/maria/ma_state.h:
        Added new prototype
      storage/maria/trnman.c:
        Added trnman_lock() and trnman_unlock().
        Needed by _ma_remove_not_visible_states_with_lock() to get mutex in right order
      storage/maria/trnman_public.h:
        Added new prototypes
      82d79389
  14. 03 Jul, 2008 1 commit
    • Guilhem Bichot's avatar
      Fix for BUG#35107 "maria-preload.test is disabled because unrepeatable page cache statistics" · 4d48802f
      Guilhem Bichot authored
      What varies accross machine is maria_pagecache_read_requests, but maria_pagecache_reads doesn't and
      is the most interesting (helps verify that disk wasn't touched after preloading), that's all we keep.
      
      mysql-test/r/maria-preload.result:
        unrepeatable variable removed
      mysql-test/t/maria-preload.test:
        unrepeatable variable removed
      storage/maria/ma_test_force_start.pl:
        portability fix for running under Windows
      4d48802f
  15. 02 Jul, 2008 1 commit
  16. 01 Jul, 2008 1 commit
    • Guilhem Bichot's avatar
      Back-port of changes made to 6.0-maria (to remove compiler warnings or fix simple test failures) · 3e37fb35
      Guilhem Bichot authored
      in the last days: substitution in tests has to work for absolute datadir (/dev/shm/...);
      internal temp tables (like information_schema) can be Maria; Maria may not be compiled in; splitting
      too long maria.test in two; mtr --embedded runs in mysql-test not mysql-test/var/master-data
      so we need some absolute paths in tests; can't restart mysqld in --embedded; missing DBUG_VOID_RETURN in
      mysqltest.c (fix from Serg); is_collation_character_set_applicability.test was too long name
      which broke tar's 99-char limit.
      3e37fb35
  17. 30 Jun, 2008 4 commits
    • Guilhem Bichot's avatar
      cutting test in two because it takes many things · 6559f5c2
      Guilhem Bichot authored
      mysql-test/r/maria-recovery.result:
        cutting test in two
      mysql-test/r/maria-recovery2.result:
        cutting test in two
      mysql-test/t/maria-recovery.test:
        cutting test in two
      mysql-test/t/maria-recovery2-master.opt:
        cutting test in two
      mysql-test/t/maria-recovery2.test:
        cutting test in two
      6559f5c2
    • Guilhem Bichot's avatar
      Fix for BUG#37288 "Maria - zerofill corrupts table". Testcase is running... · 24257638
      Guilhem Bichot authored
      Fix for BUG#37288 "Maria - zerofill corrupts table". Testcase is running ma_test_recovery.pl on Windows.
      
      storage/maria/ma_blockrec.c:
        comment
      storage/maria/ma_check.c:
        When zerofilling the data file, _ma_compact_block_page() may increase free space in a
        page so bitmap page needs to be corrected.
      24257638
    • Guilhem Bichot's avatar
      Fix for BUG#35107 "maria-preload.test is disabled because causes assertion". · fdebe278
      Guilhem Bichot authored
      maria-preload will be re-enabled later because other pieces of it have possibly random output.
      
      storage/maria/ma_check.c:
        Fix for BUG#35107 "maria-preload.test is disabled because causes assertion".
      fdebe278
    • Guilhem Bichot's avatar
      Fix for unit test failures. · 0432bc1e
      Guilhem Bichot authored
      storage/maria/ma_test1.c:
        rec_length was too short by one byte: at line 299 memcpy(record,read_record,rec_length) thus didn't copy the
        last byte, so 'record' was not ok for use by update_record(), contained an incomplete blob address, sometimes
        crashed on Itanium.
      storage/maria/unittest/ma_test_loghandler_multithread-t.c:
        Tests failed once, never before for hundreds of times, we don't know if test is correct, disabling.
      0432bc1e
  18. 28 Jun, 2008 5 commits
    • Michael Widenius's avatar
      Disable versioning (concurrent writes) if more than one unique key · f27efe69
      Michael Widenius authored
      The reason for this is that if we change one unique key and then get a failure on the second, we may not be able to rename the first one back before someone else writes the same key value.  In Maria 2.0, when we keep deleted key values in the tree, this will not be a problem anymore
      Fixed typedisable concurrent insert/select for SQLCOM_LOAD as there are problems with concurrent threads during index recreation
      
      KNOWN_BUGS.txt:
        More comments
      storage/maria/ha_maria.cc:
        Fixed typo (REPLACE -> INSERT)
        Also disable concurrent insert/select for SQLCOM_LOAD as there are problems with concurrent threads during index recreation
      storage/maria/ma_open.c:
        Disable versioning (concurrent writes) if more than one unique key
      f27efe69
    • Michael Widenius's avatar
      Automatic merge · c5805837
      Michael Widenius authored
      Added some minor changes that was done in my tree while waiting for test to run:
      - Remove in Maria T_QUICK when retrying repair for enabling indexes, as the record file may be in use by other threads
      - Disable code that is only relevant for EXTERNAL_LOCKING
      
      include/m_string.h:
        Automatic merge
      storage/maria/ha_maria.cc:
        Remove T_QUICK when retrying repair for enabling indexes, as the record file may be in use by other threads
      storage/maria/ma_check.c:
        Automatic merge
      storage/maria/ma_key.c:
        Automatic merge
      storage/maria/ma_loghandler.c:
        Automatic merge
      storage/maria/ma_open.c:
        Disable code that is only relevant for EXTERNAL_LOCKING
      storage/maria/ma_sp_key.c:
        Automatic merge
      storage/maria/ma_write.c:
        Automatic merge
      storage/maria/trnman.c:
        Automatic merge
      c5805837
    • Michael Widenius's avatar
      Fix for Bug #37007 Maria: different checksum for MyISAM table depending on CHECKSUM=0|1 · d29e7f74
      Michael Widenius authored
      This also adds a check that MyISAM tables with incompatible checksums are detected by CHECK TABLE ... [FOR UPGRADE] and thus also by mysql_upgrade.
      The tables that are incomatible are MyISAM tables with ROW_FORMAT=fixed and has VARCHAR fields and have CHECKSUM enabled.
      Before these tables gave different checksum if you used CHECK TABLE with or without EXTENDED
      
      mysql-test/r/old-mode.result:
        Now we get same results with and without EXTENDED
      mysql-test/r/row-checksum-old.result:
        Initial results
      mysql-test/r/row-checksum.result:
        Initial results
      mysql-test/t/old-mode.test:
        Added test with QUICK to show that the live checksum is not used when running with --old
      mysql-test/t/row-checksum-old-master.opt:
        Start mysqld with --old mode to enable old checksum code
      mysql-test/t/row-checksum-old.test:
        Run row-checksum test under mysqld --old
      mysql-test/t/row-checksum.test:
        Verify that checksum are calculated the same way with and without EXTENDED
        We run this with several storage engines to ensure results are the same over storage engines
      sql/ha_partition.cc:
        Use new HA_HAS_xxx_CHECKSUM flags
      sql/handler.cc:
        Use new HA_HAS_xxx_CHECKSUM flags
      sql/handler.h:
        Split HA_HAS_CHECKSUM into HA_HAS_NEW_CHECKSUM and HA_HAS_OLD_CHECKSUM flags.
        This is a safe API change as only MyISAM and Maria should use these handler flags.
      sql/sql_show.cc:
        Use new HA_HAS_xxx_CHECKSUM flags
      sql/sql_table.cc:
        Use file->checksum() for live checksums if the life checksum method corresponds to the mysqld --old flag
      storage/maria/ha_maria.cc:
        Use new HA_HAS_xxx_CHECKSUM flags
      storage/myisam/ha_myisam.cc:
        Set HA_HAS_OLD_CHECKSUM and/or HA_HAS_NEW_CHECKSUM flags depending on if this is a new myisam or old myisam file
        Add method check_for_upgrade() to detect if the table is of old version with a checksum that is incompatible with CHECK TABLE ... EXTENDED
      storage/myisam/ha_myisam.h:
        Added check_for_upgrade()
      storage/myisam/mi_open.c:
        Removed not neede cast
        Initialize share->has_null_fields and share->has_varchar_fields variables
      storage/myisam/myisamdef.h:
        Added share->has_null_fields and share->has_varchar_fields
      d29e7f74
    • Sergei Golubchik's avatar
    • Michael Widenius's avatar
      Fix for Bug #36578 Maria: maria-recover may fail to autorepair a table · 9f589947
      Michael Widenius authored
      Fixed also some similar issues in MyISAM. This was not noticed before as MyISAM did a second retry without key cache (which just made the second repair attempty slower)
      
      storage/maria/ha_maria.cc:
        Print information if we retry without quick in case of CHECK TABLE table_name QUICK
        Remove T_QUICK flag when retrying repair, but set T_SAFE_REPAIR to ensure we don't loose any rows
        Remember T_RETRY_WITH_QUICK flag when restoring repair flags
        Don't print 'checking table' if we are not checking table in auto-repair
        Don't use T_QUICK in auto repair (safer)
        Changed parameter of type HA_PARAM &param to HA_PARAM *param
      storage/maria/ha_maria.h:
        Changed parameter of type HA_PARAM &param to HA_PARAM *param
      storage/maria/ma_check.c:
        Added retry without T_QUICK if there is a problem reading a row in BLOCK_RECORD
      storage/myisam/ha_myisam.cc:
        Remove T_QUICK flag when retrying repair, but set T_SAFE_REPAIR to ensure we don't loose any rows
        Remember T_RETRY_WITH_QUICK flag when restoring repair flags
      9f589947
  19. 26 Jun, 2008 3 commits
    • unknown's avatar
      merge · 38d024b5
      unknown authored
      38d024b5
    • unknown's avatar
      Fixed maria-big test failure. · 7b8d4af1
      unknown authored
      storage/maria/ma_loghandler.c:
        Processed case when current buffer filled but there is no new LSN in the buffer generated (so it is no need to fluesh this buffer) and buffer->last_lsn is LSN_IMPOSSIBLE.
      7b8d4af1
    • Guilhem Bichot's avatar
      Fixes for build errors under Windows and compiler warning under Linux · f0c53638
      Guilhem Bichot authored
      include/m_string.h:
        new macro like LINT_INIT but for struct. In m_string.h because bzero() becomes available only there
      storage/maria/ma_check.c:
        compiler error under Windows (declaration after statements...)
      storage/maria/ma_key.c:
        trnman.h is not in include/ but in storage/maria
      storage/maria/ma_sp_key.c:
        trnman.h is not in include/ but in storage/maria
      storage/maria/ma_write.c:
        avoid compiler warning (org_key.flag may be used uninitialized)
      f0c53638