• unknown's avatar
    Added error HA_ERR_FILE_TOO_SHORT to be used when files are shorter than... · ebf7ab7b
    unknown authored
    Added error HA_ERR_FILE_TOO_SHORT to be used when files are shorter than expected (by my_read/my_pread)
    Added debugger hook _my_dbug_put_break_here() that is called if we get a CRC that matches --debug-crc-break (my_crc_dbug_break)
    Fixed REDO_REPAIR to use all repair modes (repair, repair_by_sort, repair_paralell
    REDO_REPAIR now also logs used key map
    Fixed some bugs in REDO logging of key pages
    Better error messages from maria_read_log
    Added my_readwrite_flags to init_pagecache() to be able to get better error messages and simplify code.
    Don't allow pagecaches with less than 8 blocks (Causes strange crashes)
    Added EXTRA_DEBUG_KEY_CHANGES. When this is defined some REDO_INDEX entries contains page checksums (these are calculated and checked in DBUG mode, ignored otherwise)
    Fixed bug in ma_pagecache unit tests that caused program to sometimes fail
    Added some missing calls to MY_INIT() that caused some unit tests to fail
    Fixed that TRUNCATE works properly on temporary MyISAM files
    Updates some result files to new table checksums results (checksum when NULL fields are ignored)
    perl test-insert can be replayed with maria_read_log!
    
    
    sql/share/Makefile.am:
      Change mode to -rw-rw-r--
    BitKeeper/etc/ignore:
      added storage/maria/unittest/page_cache_test_file_1 storage/maria/unittest/pagecache_debug.log
    include/maria.h:
      Added maria_tmpdir
    include/my_base.h:
      Added error HA_ERR_FILE_TOO_SHORT
    include/my_sys.h:
      Added variable my_crc_dbug_check
      Added function my_dbug_put_break_here()
    include/myisamchk.h:
      Added org_key_map (Needed for writing REDO record for REPAIR)
    mysql-test/r/innodb.result:
      Updated to new checksum algorithm (NULL ignored)
    mysql-test/r/mix2_myisam.result:
      Updated to new checksum algorithm (NULL ignored)
    mysql-test/r/myisam.result:
      Updated to new checksum algorithm (NULL ignored)
    mysql-test/t/myisam.test:
      Added used table
    mysys/checksum.c:
      Added DBUG for checksum results
      Added debugger hook so that _my_dbug_put_break_here() is called if we get matching CRC
    mysys/lf_alloc-pin.c:
      Fixed compiler warning
    mysys/my_handler.c:
      Added new error message
    mysys/my_init.c:
      If my_progname is not given, use 'unknown' form my_progname_short
      Added debugger function my_debug_put_break_here()
    mysys/my_pread.c:
      In case of too short file when MY_NABP or MY_FNABP is specified, give error HA_ERR_FILE_TO_SHORT
    mysys/my_read.c:
      In case of too short file when MY_NABP or MY_FNABP is specified, give error HA_ERR_FILE_TO_SHORT
    sql/mysqld.cc:
      Added debug option --debug-crc-break
    sql/sql_parse.cc:
      Trivial optimization
    storage/maria/ha_maria.cc:
      Renamed variable to be more logical
      Ensure that param.testflag is correct when calling repair
      Added extra argument to init_pagecache
      Set default value for maria_tempdir
    storage/maria/ma_blockrec.c:
      Test for HA_ERR_FILE_TOO_SHORT instead for -1
    storage/maria/ma_cache.c:
      Test for HA_ERR_FILE_TOO_SHORT instead for -1
    storage/maria/ma_check.c:
      Set param->testflag to match how repair is run (needed for REDO logging)
      Simple optimization
      Moved flag if page is node from pagelength to keypage-flag byte
      Log used key map in REDO log.
    storage/maria/ma_delete.c:
      Remember previous UNDO entry when writing undo (for future CLR records)
      Moved flag if page is node from pagelength to keypage-flag byte
      Fixed some bugs in redo logging
      Added CRC for some translog REDO_INDEX entries
    storage/maria/ma_dynrec.c:
      Test for HA_ERR_FILE_TOO_SHORT instead for -1
    storage/maria/ma_ft_update.c:
      Fixed call to _ma_store_page_used()
    storage/maria/ma_key_recover.c:
      Added CRC for some translog REDO_INDEX entries
      Removed not needed pagecache_write() in _ma_apply_redo_index()
    storage/maria/ma_locking.c:
      Test for HA_ERR_FILE_TOO_SHORT instead for -1
    storage/maria/ma_loghandler.c:
      Added used key map to REDO_REPAIR_TABLE
    storage/maria/ma_loghandler.h:
      Added operation for checksum of key pages
    storage/maria/ma_open.c:
      Allocate storage for undo lsn pointers
    storage/maria/ma_pagecache.c:
      Remove not needed include file
      Change logging to use fd: for file descritors as other code
      Added my_readwrite_flags to init_pagecache() to be able to get better error messages for maria_chk/maria_read_log
      Don't allow pagecaches with less than 8 blocks
      Remove wrong DBUG_ASSERT()
    storage/maria/ma_pagecache.h:
      Added readwrite_flags
    storage/maria/ma_recovery.c:
      Better error messages for maria_read_log:
      - Added eprint() for printing error messages
      - Print extra \n before error message if we are printing %0 %10 ...
      
      Added used key_map to REDO_REPAIR log entry
      More DBUG
      Call same repair method that was used by mysqld
    storage/maria/ma_rt_index.c:
      Moved flag if page is node from pagelength to keypage-flag byte
    storage/maria/ma_rt_key.c:
      Fixed call to _ma_store_page_used()
    storage/maria/ma_rt_split.c:
      Moved flag if page is node from pagelength to keypage-flag byte
    storage/maria/ma_static.c:
      Added maria_tmpdir
    storage/maria/ma_test1.c:
      Updated call to init_pagecache()
    storage/maria/ma_test2.c:
      Updated call to init_pagecache()
    storage/maria/ma_test3.c:
      Updated call to init_pagecache()
    storage/maria/ma_write.c:
      Removed #ifdef NOT_YET
      Moved flag if page is node from pagelength to keypage-flag byte
      Fixed bug in  _ma_log_del_prefix()
    storage/maria/maria_chk.c:
      Fixed wrong min limit for page_buffer_size
      Updated call to init_pagecache()
    storage/maria/maria_def.h:
      Added EXTRA_DEBUG_KEY_CHANGES. When this is defined some REDO_INDEX entries contains page checksums
      Moved flag if page is node from pagelength to keypage-flag byte
    storage/maria/maria_ftdump.c:
      Updated call to init_pagecache()
    storage/maria/maria_pack.c:
      Updated call to init_pagecache()
      Reset share->state.create_rename_lsn & share->state.is_of_horizon
    storage/maria/maria_read_log.c:
      Better error messages
      Added --tmpdir option (needed to set temporary directory for REDO_REPAIR)
      Added --start-from-lsn
      Changed option for --display-only to 'd' (wanted to use -o for 'offset')
    storage/maria/unittest/lockman2-t.c:
      Added missing call to MY_INIT()
    storage/maria/unittest/ma_pagecache_consist.c:
      Updated call to init_pagecache()
    storage/maria/unittest/ma_pagecache_single.c:
      Fixed bug that caused program to sometimes fail
      Added some DBUG_ASSERTS()
      Changed some calls to malloc()/free() to my_malloc()/my_free()
      Create extra file to expose original hard-to-find bug
    storage/maria/unittest/ma_test_loghandler-t.c:
      Updated call to init_pagecache()
    storage/maria/unittest/ma_test_loghandler_first_lsn-t.c:
      Updated call to init_pagecache()
    storage/maria/unittest/ma_test_loghandler_max_lsn-t.c:
      Updated call to init_pagecache()
    storage/maria/unittest/ma_test_loghandler_multigroup-t.c:
      Updated call to init_pagecache()
    storage/maria/unittest/ma_test_loghandler_multithread-t.c:
      Updated call to init_pagecache()
    storage/maria/unittest/ma_test_loghandler_noflush-t.c:
      Updated call to init_pagecache()
    storage/maria/unittest/ma_test_loghandler_pagecache-t.c:
      Updated call to init_pagecache()
    storage/maria/unittest/ma_test_loghandler_purge-t.c:
      Updated call to init_pagecache()
    storage/maria/unittest/test_file.c:
      Changed malloc()/free() to my_malloc()/my_free()
      Fixed memory leak
      Changd logic a bit while trying to find bug in reset_file()
    storage/maria/unittest/trnman-t.c:
      Added missing call to MY_INIT()
    storage/myisam/mi_cache.c:
      Test for HA_ERR_FILE_TOO_SHORT instead for -1
    storage/myisam/mi_create.c:
      Removed O_EXCL to get TRUNCATE to work for temporary files
    storage/myisam/mi_dynrec.c:
      Test for HA_ERR_FILE_TOO_SHORT instead for -1
    storage/myisam/mi_locking.c:
      Test for HA_ERR_FILE_TOO_SHORT instead for -1
    mysql-test/r/old-mode.result:
      New BitKeeper file ``mysql-test/r/old-mode.result''
    mysql-test/t/old-mode-master.opt:
      New BitKeeper file ``mysql-test/t/old-mode-master.opt''
    mysql-test/t/old-mode.test:
      New BitKeeper file ``mysql-test/t/old-mode.test''
    ebf7ab7b
ma_dynrec.c 55.3 KB