1. 02 Apr, 2008 1 commit
    • unknown's avatar
      Fix for BUG#35570 "CHECKSUM TABLE unreliable if LINESTRING field (same content... · ebaf694a
      unknown authored
      Fix for BUG#35570 "CHECKSUM TABLE unreliable if LINESTRING field (same content / differen checksum)"
      This will be back-ported to 5.x trees but the work for R-tree logging critically needs this patch in Maria now.
      
      
      mysql-test/r/myisam.result:
        checksums are identical; without the code fix they were all different
      mysql-test/t/myisam.test:
        test that same tables give same checksums
      sql/sql_table.cc:
        Type GEOMETRY is implemented on top of type BLOB, so, just like for BLOB, its 'field' contains pointers
        which it does not make sense to include in the checksum; it rather has to be converted to a string and
        then we can compute the checksum.
      ebaf694a
  2. 01 Apr, 2008 1 commit
    • unknown's avatar
      Merge of changes in MyISAM since December 16 -> April 1 · 1ad29099
      unknown authored
      Fixes bugs:
      Bug#28837  MyISAM storage engine error (134) doing delete with self-join
      Bug#31277  myisamchk --unpack corrupts table
      Bug#4692   DISABLE/ENABLE KEYS waste a space
      Bug#31305  myisam tables crash when they are near capacity
      
      
      BitKeeper/etc/ignore:
        added unittest/tmp/*
      mysql-test/r/maria.result:
        Moved missing tests from myisam.test to maria.test
      mysql-test/t/maria.test:
        Moved missing tests from myisam.test to maria.test
      storage/maria/ha_maria.cc:
        Merge of changes in MyISAM since December 16 -> April 1
        Fixes bug in self join (Bug#28837: MyISAM storage engine error (134) doing delete with self-join)
      storage/maria/ha_maria.h:
        Merge of changes in MyISAM since December 16 -> April 1
      storage/maria/ma_blockrec.c:
        Merge of changes in MyISAM since December 16 -> April 1
        Fixes bug in self join (Bug#28837: MyISAM storage engine error (134) doing delete with self-join)
        The problem is that we may be using a cached key page with old information. Versioning will fix this
      storage/maria/ma_check.c:
        Merge of changes in MyISAM since December 16 -> April 1
        This fixes a problem with pack_reclength not beeing big enough (Bug #31277 myisamchk --unpack corrupts table)
        BUG#4692 - DISABLE/ENABLE KEYS waste a space
      storage/maria/ma_delete.c:
        Indentation fixes
      storage/maria/ma_dynrec.c:
        Merge of changes in MyISAM since December 16 -> April 1
        Fixes Bug#31305 myisam tables crash when they are near capacity.
        (This uses a simpler fix than in MyISAM by remembering the length of the current row)
      storage/maria/ma_ft_boolean_search.c:
        Merge of all changes from myisam/ft_boolean_search.c (This file had not been kept up to date)
      storage/maria/ma_open.c:
        Merge of changes in MyISAM since December 16 -> April 1
        Calculate default_rec_buff_size more exact to be sure it's always big enough
      storage/maria/ma_packrec.c:
        Merge of changes in MyISAM since December 16 -> April 1
        Update default_rec_buff_size to be big enough to hold one packed row
        Related to Bug#31277 myisamchk --unpack corrupts table
      storage/maria/ma_rnext_same.c:
        Indentation fixes
      storage/maria/ma_rt_index.c:
        Merge of changes in MyISAM since December 16 -> April 1
      storage/maria/ma_rt_mbr.c:
        Merge of changes in MyISAM since December 16 -> April 1
        (Added comment)
      storage/maria/ma_search.c:
        Merge of changes in MyISAM since December 16 -> April 1
        (Added comment)
      storage/maria/ma_sort.c:
        Merge of changes in MyISAM since December 16 -> April 1
      storage/maria/ma_statrec.c:
        Indentation fixes
      storage/maria/ma_test2.c:
        Indentation fixes
      storage/maria/maria_chk.c:
        Indentation fixes
      storage/maria/maria_pack.c:
        Merge of changes in MyISAM since December 16 -> April 1
      1ad29099
  3. 23 Mar, 2008 1 commit
  4. 21 Mar, 2008 1 commit
    • unknown's avatar
      Fix for pushbuild problems: innocuous Valgrind error (uninitialized · 591f93d6
      unknown authored
      bytes in unimportant, unused pieces of index pages) and test failure
      because test requires Maria. Compiler warning.
      About Valgrind error, two of the three bzero() added here are
      needed to silence the error (the third is added for symmetry).
      
      
      mysql-test/t/maria-gis-rtree.test:
        requires Maria
      storage/maria/ma_loghandler.c:
        "uint64->uint16 possible loss of precision" on Windows
      storage/maria/ma_rt_index.c:
        We bzero the entire new page, as is done in _ma_enlarge_root()
        for B-tree pages. This silences Valgrind warnings and allows
        better compression.
      storage/maria/ma_rt_split.c:
        We bzero the entire new page, as is done in _ma_enlarge_root()
        for B-tree pages. This silences Valgrind warnings and allows
        better compression.
      591f93d6
  5. 20 Mar, 2008 2 commits
    • unknown's avatar
      Merge gbichot@bk-internal.mysql.com:/home/bk/mysql-maria · 422183f5
      unknown authored
      into  gbichot4.local:/home/mysql_src/mysql-maria-monty
      
      422183f5
    • unknown's avatar
      Fix for BUG#35441 "Cannot change PAGE_CHECKSUM table option". · a643d828
      unknown authored
      A big test was written and is committed, which found 3 bugs in total:
      - ALTER TABLE PAGE_CHECKSUM=0 sometimes had no effect
      - ALTER TABLE ENGINE=MARIA sometimes changed page checksumming in
      the table
      - SHOW CREATE TABLE and 'maria_chk -dv' disagreed on the presence
      of page checksumming.
      They are all fixed here. Side-effect is that SHOW CREATE TABLE now
      always prints a PAGE_CHECKSUM clause for Maria tables.
      
      
      mysql-test/mysql-test-run.pl:
        allow calling maria_chk and maria_pack in tests
      mysql-test/r/maria.result:
        PAGE_CHECKSUM=0 is now always printed
      mysql-test/t/create.test:
        PAGE_CHECKSUM= is now always present in SHOW CREATE TABLE of Maria tables
      mysql-test/t/disabled.def:
        better bug number
      sql/sql_table.cc:
        If ALTER TABLE PAGE_CHECKSUM=#, it affects the engine's data (structure
        of data pages) so a full table rebuild is needed. We already did
        so for ROW_FORMAT=#, following same logic. This fixes disagreements
        between SHOW CREATE TABLE and 'maria_chk -dv' regarding the
        presence of page checksums after certain ALTER TABLE (as seen
        with the attached testcase).
      storage/maria/ha_maria.cc:
        In ALTER TABLE PAGE_CHECKSUM=0, ha_maria::update_create_info() started
        with create_info->page_checksum=HA_CHOICE_NO and wrongly set it
        to the table's original setting, which is HA_CHOICE_YES if the table
        had page checksums, in which case the ALTER left page checksum
        in the table.
        The fix for this bug is: only if create_info->page_checksum is
        undefined (no clause in the ALTER TABLE, or we are in SHOW CREATE TABLE)
        we may set HA_CHOICE_YES.
        The second bug in this file was that the code left HA_CHOICE_UNDEF if
        the table didn't have page checksums originally, leading ALTER TABLE
        ENGINE=MARIA to change the table's page checksum to the value of
        maria_page_checksum.
        This is fixed by setting create_info->page_checksum to HA_CHOICE_NO
        if UNDEF and table does not have page checksum.
        The side-effect of this last fix, because ha_maria::update_create_info()
        is also called by SHOW CREATE TABLE, is that:
        SET GLOBAL maria_page_checksum=0;
        CREATE TABLE t(a INT) ENGINE=MARIA;
        SHOW CREATE TABLE t;
        which used to not show a PAGE_CHECKSUM= clause, now shows PAGE_CHECKSUM=0.
        I consider this side-effect good:
        - clearer for users: it eliminates the differences between the
        above and this:
        SET GLOBAL maria_page_checksum=0;
        CREATE TABLE t(a INT) ENGINE=MARIA PAGE_CHECKSUM=0;
        SHOW CREATE TABLE t;
        which already showed PAGE_CHECKSUM=0; difference which is not easy
        to explain.
        - if using mysqldump to copy from one server to another, it eliminates
        the dependency on the value of maria_page_checksum being the same on
        original server and new server.
      mysql-test/r/maria-page-checksum.result:
        Result. If you undo the code fixes and run the test, the new result
        file will show bugs at:
        error lineno 56 : expected PAGE_CHECKSUM=1, got Page checksums are not used
        error lineno 73 : expected PAGE_CHECKSUM=0, got ) ENGINE=MARIA DEFAULT CHARSET=latin1 PAGE_CHECKSUM=1
        error lineno 110 : expected PAGE_CHECKSUM=1, got Page checksums are not used
        error lineno 164 : expected PAGE_CHECKSUM=1, got Page checksums are not used
        error lineno 181 : expected PAGE_CHECKSUM=0, got ) ENGINE=MARIA DEFAULT CHARSET=latin1 PAGE_CHECKSUM=1
        error lineno 218 : expected PAGE_CHECKSUM=1, got Page checksums are not used
        error lineno 253 : expected PAGE_CHECKSUM=0, got ) ENGINE=MARIA DEFAULT CHARSET=latin1 PAGE_CHECKSUM=1
        error lineno 307 : expected PAGE_CHECKSUM=0, got ) ENGINE=MARIA DEFAULT CHARSET=latin1 PAGE_CHECKSUM=1
        error lineno 361 : expected PAGE_CHECKSUM=0, got ) ENGINE=MARIA DEFAULT CHARSET=latin1 PAGE_CHECKSUM=1
        error lineno 415 : expected PAGE_CHECKSUM=0, got ) ENGINE=MARIA DEFAULT CHARSET=latin1 PAGE_CHECKSUM=1
        error lineno 488 : expected PAGE_CHECKSUM=1, got Page checksums are not used
        error lineno 505 : expected PAGE_CHECKSUM=0, got ) ENGINE=MARIA DEFAULT CHARSET=latin1 PAGE_CHECKSUM=1
        error lineno 542 : expected PAGE_CHECKSUM=1, got Page checksums are not used
        error lineno 577 : expected PAGE_CHECKSUM=0, got ) ENGINE=MARIA DEFAULT CHARSET=latin1 PAGE_CHECKSUM=1
        error lineno 631 : expected PAGE_CHECKSUM=0, got ) ENGINE=MARIA DEFAULT CHARSET=latin1 PAGE_CHECKSUM=1
        (lineno is line number in the result file)
      mysql-test/t/maria-page-checksum.test:
        Test for the 3 bugs
      a643d828
  6. 18 Mar, 2008 2 commits
  7. 17 Mar, 2008 2 commits
    • unknown's avatar
      Merge gbichot@bk-internal.mysql.com:/home/bk/mysql-maria · 0ee1ce4d
      unknown authored
      into  gbichot4.local:/home/mysql_src/mysql-maria-monty
      
      0ee1ce4d
    • unknown's avatar
      Fix for BUG#35273 "Corrupted table if using GIS index": · 1174c4b9
      unknown authored
      when modifying R-tree indices we forgot to unpin pages (causing
      flush at-end-of-statement to fail - because page is pinned - and thus
      mark table corrupted) and also to unlock key_del (causing assertion
      failure info->used_key_del==0 at maria_close()).
      
      
      storage/maria/ma_rt_index.c:
        When modifying pages of R-tree indices we keep them pinned, and
        lock key_del, so we here make sure to unpin and unlock at the end
        of the modification. I checked all functions which add to info->pinned_pages
        or call _ma_lock_key_del(): the parent is always maria_rtree_insert()
        or maria_rtree_delete(), which thus do the unpin/unlock now.
      mysql-test/r/maria-gis-rtree.result:
        new result, which is incorrect (filed as BUG#35351) but at least
        test does not crash anymore
      mysql-test/t/maria-gis-rtree.test:
        test of Maria's GIS functionality (R-tree indices etc); copied from
        MyISAM's gis-rtree.test; used to crash without the bugfixes.
      1174c4b9
  8. 16 Mar, 2008 1 commit
  9. 11 Mar, 2008 1 commit
    • unknown's avatar
      Fixed statistic calculation. · 9c466e53
      unknown authored
      (BUG#35030 maria_pagecache_read* status
      variables updated at wrong moment)
      
      
      storage/maria/ma_pagecache.c:
        Fixed statistic calculation.
      9c466e53
  10. 10 Mar, 2008 1 commit
    • unknown's avatar
      Very small changes. · 75d61782
      unknown authored
      
      storage/maria/ma_locking.c:
        define 'share' only in block which needs it
      storage/maria/unittest/ma_test_recovery.pl:
        more straightforward way to compute file's MD5
      75d61782
  11. 08 Mar, 2008 4 commits
    • unknown's avatar
      Maria's usage of my_stat() is unreliable on Windows. (BUG#35036) · 50df2b33
      unknown authored
      %llu replaces with %s/llstr() as in other MySQL code.
      
      
      storage/maria/ma_loghandler.c:
        my_stat is not reliable under windows for determinating file
        length so it is replaced with my_seek.
        %llu replaces with %s/llstr() as in other MySQL code.
      50df2b33
    • unknown's avatar
      Merge abelkin@bk-internal.mysql.com:/home/bk/mysql-maria · 2d3731b1
      unknown authored
      into  desktop.sanja.is.com.ua:/home/bell/mysql/bk/work-maria-bug34712
      
      2d3731b1
    • unknown's avatar
      Merge bk-internal.mysql.com:/home/bk/mysql-maria · bff5c4aa
      unknown authored
      into  mysql.com:/home/my/mysql-maria
      
      bff5c4aa
    • unknown's avatar
      Fix for #Bug35048 "maria table corruption reported when transactional=0 · d0277130
      unknown authored
      Problem was that page in bitmap was marked as full even if there was free places in page directory
      
      
      mysql-test/r/maria.result:
        Test case for problem with head/tail page with 255 entries
        (Bug 35048 "maria table corruption reported when transactional=0)
      mysql-test/t/maria.test:
        Test case for problem with head/tail page with 255 entries
        (Bug 35048 "maria table corruption reported when transactional=0)
      storage/maria/ma_blockrec.c:
        Fix to ensure that bitmap is marked 'full' when the head/tail page directory is full
      storage/maria/ma_check.c:
        Better check when directory for head/tail pages are marked full (The page directory can't hold a row tail + blob tails)
      d0277130
  12. 07 Mar, 2008 2 commits
    • unknown's avatar
      Avoiding changing log on flush call · 2b329f60
      unknown authored
      if nothing was added to the log
      (BUG#34712 maria_read_log changes log
      file content on several platforms though not needed)
      Fixed callback call (now under loghandler lock).
      
      
      storage/maria/ma_loghandler.c:
        Flag that signaling about "everythig-flushed" state of
        the log added, to avoid changing log on flush request
        if nothing was written but horizon placed on the page boarder.
        Fixed callback call (now under loghandler lock).
      2b329f60
    • unknown's avatar
      Removed external call to md5sum and added · e59795a8
      unknown authored
      an internal procedure for it. Removed my_which()
      as unneccessary.
      
      e59795a8
  13. 05 Mar, 2008 2 commits
  14. 04 Mar, 2008 11 commits
    • unknown's avatar
      Merge desktop.sanja.is.com.ua:/home/bell/mysql/bk/mysql-maria · 94241186
      unknown authored
      into  desktop.sanja.is.com.ua:/home/bell/mysql/bk/work-maria-bug34634
      
      
      storage/maria/ma_pagecache.c:
        Auto merged
      94241186
    • unknown's avatar
      Fixed problem of deleting blocks which are being evicted at · c595976d
      unknown authored
      the moment. (BUG#34634)
      Fixed potential bug in pinning schema.
      
      
      storage/maria/ma_pagecache.c:
        Fixed problem of deleting blocks which are being evicted at
        the moment.
        Fixed potential bug in pinning schema.
      c595976d
    • unknown's avatar
      Fixed excessive assertion reported in BUG#35031 · 05312930
      unknown authored
      "Using maria-block-size != 8192 makes Maria crash or say "error 174""
      
      
      storage/maria/ma_create.c:
        fixed excessive assertion
      05312930
    • unknown's avatar
      have to disable test until bug is fixed · 3eab346c
      unknown authored
      3eab346c
    • unknown's avatar
      fix for compilation failure in non-debug builds · 1dacf3ae
      unknown authored
      
      sql/mysqld.cc:
        option -# and --debug, and default_dbug_option, do not exist in non-debug builds
      1dacf3ae
    • unknown's avatar
      Merge gbichot4.local:/home/mysql_src/mysql-maria-monty · b469b2da
      unknown authored
      into  gbichot4.local:/home/mysql_src/mysql-maria-clean
      
      
      storage/maria/ha_maria.cc:
        Auto merged
      storage/maria/ma_pagecache.c:
        Auto merged
      b469b2da
    • unknown's avatar
      Making ma_pagecache_rwconsist_1k-t unit test build under Windows · c4bf4549
      unknown authored
      
      storage/maria/unittest/CMakeLists.txt:
        build unit test under Windows too
      storage/maria/unittest/ma_pagecache_rwconsist.c:
        portability fix for Windows
      c4bf4549
    • unknown's avatar
      Fixed crashing bug when starting mysqld with --dbug · c7f6f037
      unknown authored
      Fixed crash when using other maria block size than 8192
      Fixed bug that caused tables to be reported as crashed if maria_log_control was deleted
      
      
      mysql-test/valgrind.supp:
        Suppress leaks on SuSE 10.3, x86 64 bit
      sql/mysqld.cc:
        Don't give warning in case of timeout for pthread_cond_timedwait
        Fixed crashing bug when starting mysqld with --dbug
      storage/maria/ha_maria.cc:
        Fixed crash when using other block size than 8192 (Crash happend later in bitmap page handling)
      storage/maria/ma_locking.c:
        When we write a new uuid for a zerofilled file, also update the lsn's
      storage/maria/ma_open.c:
        Don't update lsn on open. Wait until first time file is changed
        Fixed bug that caused tables to be reported as crashed if maria_log_control was deleted
      strings/strmake.c:
        Fixed warnings for strings without end 0 when running under valgrind.
      c7f6f037
    • unknown's avatar
      copyright and license info · f139350c
      unknown authored
      
      storage/maria/Makefile.am:
        copyright
      storage/maria/ma_pagecache.c:
        copyright
      storage/maria/ma_pagecache.h:
        copyright
      storage/maria/ma_pagecaches.c:
        copyright
      storage/maria/ma_pagecrc.c:
        copyright
      storage/maria/unittest/Makefile.am:
        copyright
      storage/maria/unittest/lockman-t.c:
        copyright
      storage/maria/unittest/lockman1-t.c:
        copyright
      storage/maria/unittest/lockman2-t.c:
        copyright
      storage/maria/unittest/ma_control_file-t.c:
        copyright
      storage/maria/unittest/ma_loghandler_examples.c:
        copyright
      storage/maria/unittest/ma_maria_log_cleanup.c:
        copyright
      storage/maria/unittest/ma_pagecache_consist.c:
        copyright
      storage/maria/unittest/ma_pagecache_rwconsist.c:
        copyright
      storage/maria/unittest/ma_pagecache_single.c:
        copyright
      storage/maria/unittest/ma_test_loghandler-t.c:
        copyright
      storage/maria/unittest/ma_test_loghandler_first_lsn-t.c:
        copyright
      storage/maria/unittest/ma_test_loghandler_max_lsn-t.c:
        copyright
      storage/maria/unittest/ma_test_loghandler_multigroup-t.c:
        copyright
      storage/maria/unittest/ma_test_loghandler_multithread-t.c:
        copyright
      storage/maria/unittest/ma_test_loghandler_noflush-t.c:
        copyright
      storage/maria/unittest/ma_test_loghandler_nologs-t.c:
        copyright
      storage/maria/unittest/ma_test_loghandler_pagecache-t.c:
        copyright
      storage/maria/unittest/ma_test_loghandler_purge-t.c:
        copyright
      storage/maria/unittest/test_file.c:
        copyright
      storage/maria/unittest/test_file.h:
        copyright
      storage/maria/unittest/trnman-t.c:
        copyright
      f139350c
    • unknown's avatar
      Fix for BUG#34089 "Maria crash on LOAD INDEX after FLUSH TABLES". · 18cc207f
      unknown authored
      
      storage/maria/ha_maria.cc:
        enable LOAD INDEX for Maria
      storage/maria/ma_preload.c:
        Making index preloading work for Maria.
      storage/maria/maria_def.h:
        We don't need this #define anymore, ma_test_recovery.pl uses
        zerofill to do comparisons of physical files.
      mysql-test/r/maria-preload.result:
        result. The values of maria_pagecache_reads look too high, see
        BUG#35030 "maria_pagecache_read* status variables updated at wrong moment"
      mysql-test/t/maria-preload.test:
        Test of index preloading in Maria
      18cc207f
    • unknown's avatar
      Merge bk-internal.mysql.com:/home/bk/mysql-maria · f13a1330
      unknown authored
      into  mysql.com:/home/my/mysql-maria
      
      f13a1330
  15. 03 Mar, 2008 2 commits
  16. 02 Mar, 2008 2 commits
  17. 29 Feb, 2008 1 commit
  18. 26 Feb, 2008 1 commit
    • unknown's avatar
      WL#3072 Maria Recovery · 8853344b
      unknown authored
      fixes for ma_test_recovery.pl to work in release builds too:
      - bugfix in maria_zerofill_index()
      - applying of LOGREC_INSERT_ROW_BLOBS now zeroes unused end of non-full
      blob page (a mutation of tail page when it takes >75% of maria_block_size)
      like write_full_pages() does.
      
      
      storage/maria/ma_blockrec.c:
        When we write a non-full blob page at run-time, we zero the rest of
        it (see write_full_pages()). We now do the same in
        _ma_apply_redo_insert_row_blobs(): this is consistent and helps
        having log-applying produce the same page as run-time.
      storage/maria/ma_check.c:
        maria_zerofill_index() was wrong: it didn't zero certain bytes
        because it believed that the count of relevant bytes is
        _ma_get_page_used(share, buff) + share->keypage_header,
        whereas it's only the first term.
      storage/maria/ma_pagecache.c:
        typo
      storage/maria/ma_pagecache.h:
        typo
      storage/maria/maria_chk.c:
        enable --zerofill-keep-lsn in all builds
      storage/maria/unittest/ma_test_recovery.pl:
        now even release builds can run ma_test_recovery.pl, because zerofill
        makes tables of this test (made by run-time and by log-applying)
        identical.
      8853344b
  19. 25 Feb, 2008 2 commits