diff --git a/include/maria.h b/include/maria.h index a4c425ced47..7fdf95f7ac4 100644 --- a/include/maria.h +++ b/include/maria.h @@ -29,148 +29,19 @@ extern "C" { #endif -#define MARIA_CANNOT_ROLLBACK +#define MARIA_UNIQUE_HASH_LENGTH 4 +extern my_bool maria_delay_key_write; +uint maria_max_key_length(void); +#define maria_max_key_segments() HA_MAX_KEY_SEG -/* - Limit max keys according to HA_MAX_POSSIBLE_KEY; See myisamchk.h for details -*/ - -#if MAX_INDEXES > HA_MAX_POSSIBLE_KEY -#define MARIA_MAX_KEY HA_MAX_POSSIBLE_KEY /* Max allowed keys */ -#else -#define MARIA_MAX_KEY MAX_INDEXES /* Max allowed keys */ -#endif - -#define MARIA_NAME_IEXT ".MAI" -#define MARIA_NAME_DEXT ".MAD" -/* Max extra space to use when sorting keys */ -#define MARIA_MAX_TEMP_LENGTH (2*1024L*1024L*1024L) -/* Possible values for maria_block_size (must be power of 2) */ -#define MARIA_KEY_BLOCK_LENGTH 8192 /* default key block length */ -#define MARIA_MIN_KEY_BLOCK_LENGTH 1024 /* Min key block length */ -#define MARIA_MAX_KEY_BLOCK_LENGTH 32768 -/* Minimal page cache when we only want to be able to scan a table */ -#define MARIA_MIN_PAGE_CACHE_SIZE (8192L*16L) - -/* - In the following macros '_keyno_' is 0 .. keys-1. - If there can be more keys than bits in the key_map, the highest bit - is for all upper keys. They cannot be switched individually. - This means that clearing of high keys is ignored, setting one high key - sets all high keys. -*/ -#define MARIA_KEYMAP_BITS (8 * SIZEOF_LONG_LONG) -#define MARIA_KEYMAP_HIGH_MASK (1ULL << (MARIA_KEYMAP_BITS - 1)) -#define maria_get_mask_all_keys_active(_keys_) \ - (((_keys_) < MARIA_KEYMAP_BITS) ? \ - ((1ULL << (_keys_)) - 1ULL) : \ - (~ 0ULL)) -#if MARIA_MAX_KEY > MARIA_KEYMAP_BITS -#define maria_is_key_active(_keymap_,_keyno_) \ - (((_keyno_) < MARIA_KEYMAP_BITS) ? \ - MY_TEST((_keymap_) & (1ULL << (_keyno_))) : \ - MY_TEST((_keymap_) & MARIA_KEYMAP_HIGH_MASK)) -#define maria_set_key_active(_keymap_,_keyno_) \ - (_keymap_)|= (((_keyno_) < MARIA_KEYMAP_BITS) ? \ - (1ULL << (_keyno_)) : \ - MARIA_KEYMAP_HIGH_MASK) -#define maria_clear_key_active(_keymap_,_keyno_) \ - (_keymap_)&= (((_keyno_) < MARIA_KEYMAP_BITS) ? \ - (~ (1ULL << (_keyno_))) : \ - (~ (0ULL)) /*ignore*/ ) -#else -#define maria_is_key_active(_keymap_,_keyno_) \ - MY_TEST((_keymap_) & (1ULL << (_keyno_))) -#define maria_set_key_active(_keymap_,_keyno_) \ - (_keymap_)|= (1ULL << (_keyno_)) -#define maria_clear_key_active(_keymap_,_keyno_) \ - (_keymap_)&= (~ (1ULL << (_keyno_))) -#endif -#define maria_is_any_key_active(_keymap_) \ - MY_TEST((_keymap_)) -#define maria_is_all_keys_active(_keymap_,_keys_) \ - ((_keymap_) == maria_get_mask_all_keys_active(_keys_)) -#define maria_set_all_keys_active(_keymap_,_keys_) \ - (_keymap_)= maria_get_mask_all_keys_active(_keys_) -#define maria_clear_all_keys_active(_keymap_) \ - (_keymap_)= 0 -#define maria_intersect_keys_active(_to_,_from_) \ - (_to_)&= (_from_) -#define maria_is_any_intersect_keys_active(_keymap1_,_keys_,_keymap2_) \ - ((_keymap1_) & (_keymap2_) & \ - maria_get_mask_all_keys_active(_keys_)) -#define maria_copy_keys_active(_to_,_maxkeys_,_from_) \ - (_to_)= (maria_get_mask_all_keys_active(_maxkeys_) & \ - (_from_)) - - /* Param to/from maria_info */ - -typedef ulonglong MARIA_RECORD_POS; - -typedef struct st_maria_info -{ - ha_rows records; /* Records in database */ - ha_rows deleted; /* Deleted records in database */ - MARIA_RECORD_POS recpos; /* Pos for last used record */ - MARIA_RECORD_POS newrecpos; /* Pos if we write new record */ - MARIA_RECORD_POS dup_key_pos; /* Position to record with dup key */ - my_off_t data_file_length; /* Length of data file */ - my_off_t max_data_file_length, index_file_length; - my_off_t max_index_file_length, delete_length; - ulonglong auto_increment; - ulonglong key_map; /* Which keys are used */ - time_t create_time; /* When table was created */ - time_t check_time; - time_t update_time; - ulong record_offset; - double *rec_per_key; /* for sql optimizing */ - ulong reclength; /* Recordlength */ - ulong mean_reclength; /* Mean recordlength (if packed) */ - char *data_file_name, *index_file_name; - enum data_file_type data_file_type; - uint keys; /* Number of keys in use */ - uint options; /* HA_OPTION_... used */ - uint reflength; - int errkey, /* With key was dupplicated on err */ - sortkey; /* clustered by this key */ - File filenr; /* (uniq) filenr for datafile */ -} MARIA_INFO; - - -typedef struct st_maria_create_info -{ - const char *index_file_name, *data_file_name; /* If using symlinks */ - ha_rows max_rows; - ha_rows reloc_rows; - ulonglong auto_increment; - ulonglong data_file_length; - ulonglong key_file_length; - ulong s3_block_size; - /* Size of null bitmap at start of row */ - uint null_bytes; - uint old_options; - uint compression_algorithm; - enum data_file_type org_data_file_type; - uint16 language; - my_bool with_auto_increment, transactional, encrypted; -} MARIA_CREATE_INFO; - -struct st_maria_share; -struct st_maria_handler; /* For referense */ -typedef struct st_maria_handler MARIA_HA; -struct st_maria_s_param; -struct st_maria_keydef; +struct st_maria_bit_buff; struct st_maria_page; - -typedef struct st_maria_key /* Internal info about a key */ -{ - uchar *data; /* Data for key */ - struct st_maria_keydef *keyinfo; /* Definition for key */ - uint data_length; /* Length of key data */ - uint ref_length; /* record ref + transid */ - uint32 flag; /* 0 or SEARCH_PART_KEY */ -} MARIA_KEY; - +struct st_maria_s_param; +struct st_maria_share; +typedef struct st_maria_decode_tree MARIA_DECODE_TREE; +typedef struct st_maria_handler MARIA_HA; +typedef struct st_maria_key MARIA_KEY; +typedef ulonglong MARIA_RECORD_POS; typedef struct st_maria_keydef /* Key definition with open & info */ { @@ -213,8 +84,6 @@ typedef struct st_maria_keydef /* Key definition with open & info */ } MARIA_KEYDEF; -#define MARIA_UNIQUE_HASH_LENGTH 4 - typedef struct st_maria_unique_def /* Segment definition of unique */ { uint16 keysegs; /* Number of key-segment */ @@ -223,17 +92,6 @@ typedef struct st_maria_unique_def /* Segment definition of unique */ HA_KEYSEG *seg, *end; } MARIA_UNIQUEDEF; -typedef struct st_maria_decode_tree /* Decode huff-table */ -{ - uint16 *table; - uint quick_table_bits; - uchar *intervalls; -} MARIA_DECODE_TREE; - - -struct st_maria_bit_buff; -typedef struct s3_info S3_INFO; - /* Note that null markers should always be first in a row ! When creating a column, one should only specify: @@ -265,157 +123,32 @@ typedef struct st_maria_columndef /* column information */ } MARIA_COLUMNDEF; -extern ulong maria_block_size, maria_checkpoint_frequency; -extern ulong maria_concurrent_insert; -extern my_bool maria_flush, maria_single_user, maria_page_checksums; -extern my_bool maria_delay_key_write; -extern my_off_t maria_max_temp_length; -extern ulong maria_bulk_insert_tree_size, maria_data_pointer_size; -extern MY_TMPDIR *maria_tmpdir; -extern my_bool maria_encrypt_tables; +typedef struct st_maria_create_info +{ + const char *index_file_name, *data_file_name; /* If using symlinks */ + ha_rows max_rows; + ha_rows reloc_rows; + ulonglong auto_increment; + ulonglong data_file_length; + ulonglong key_file_length; + ulong s3_block_size; + /* Size of null bitmap at start of row */ + uint null_bytes; + uint old_options; + uint compression_algorithm; + enum data_file_type org_data_file_type; + uint16 language; + my_bool with_auto_increment, transactional, encrypted; +} MARIA_CREATE_INFO; -/* - This is used to check if a symlink points into the mysql data home, - which is normally forbidden as it can be used to get access to - not privileged data -*/ -extern int (*maria_test_invalid_symlink)(const char *filename); - - /* Prototypes for maria-functions */ - -extern int maria_init(void); -extern void maria_end(void); -extern my_bool maria_upgrade(void); -extern int maria_close(MARIA_HA *file); -extern int maria_delete(MARIA_HA *file, const uchar *buff); -extern MARIA_HA *maria_open(const char *name, int mode, - uint wait_if_locked, S3_INFO *s3); -extern int maria_panic(enum ha_panic_function function); -extern int maria_rfirst(MARIA_HA *file, uchar *buf, int inx); -extern int maria_rkey(MARIA_HA *file, uchar *buf, int inx, - const uchar *key, key_part_map keypart_map, - enum ha_rkey_function search_flag); -extern int maria_rlast(MARIA_HA *file, uchar *buf, int inx); -extern int maria_rnext(MARIA_HA *file, uchar *buf, int inx); -extern int maria_rnext_same(MARIA_HA *info, uchar *buf); -extern int maria_rprev(MARIA_HA *file, uchar *buf, int inx); -extern int maria_rrnd(MARIA_HA *file, uchar *buf, - MARIA_RECORD_POS pos); -extern int maria_scan_init(MARIA_HA *file); -extern int maria_scan(MARIA_HA *file, uchar *buf); -extern void maria_scan_end(MARIA_HA *file); -extern int maria_rsame(MARIA_HA *file, uchar *record, int inx); -extern int maria_rsame_with_pos(MARIA_HA *file, uchar *record, - int inx, MARIA_RECORD_POS pos); -extern int maria_update(MARIA_HA *file, const uchar *old, - const uchar *new_record); -extern int maria_write(MARIA_HA *file, const uchar *buff); -extern MARIA_RECORD_POS maria_position(MARIA_HA *file); -extern int maria_status(MARIA_HA *info, MARIA_INFO *x, uint flag); -extern int maria_lock_database(MARIA_HA *file, int lock_type); extern int maria_create(const char *name, enum data_file_type record_type, uint keys, MARIA_KEYDEF *keydef, - uint columns, MARIA_COLUMNDEF *columndef, - uint uniques, MARIA_UNIQUEDEF *uniquedef, - MARIA_CREATE_INFO *create_info, uint flags); -extern int maria_delete_table(const char *name); -extern int maria_rename(const char *from, const char *to); -extern int maria_extra(MARIA_HA *file, - enum ha_extra_function function, void *extra_arg); -extern int maria_reset(MARIA_HA *file); -extern ha_rows maria_records_in_range(MARIA_HA *info, int inx, - const key_range *min_key, - const key_range *max_key, - page_range *page); -extern int maria_is_changed(MARIA_HA *info); -extern int maria_delete_all_rows(MARIA_HA *info); -extern uint maria_get_pointer_length(ulonglong file_length, uint def); -extern int maria_commit(MARIA_HA *info); -extern int maria_begin(MARIA_HA *info); -extern void maria_disable_logging(MARIA_HA *info); -extern void maria_enable_logging(MARIA_HA *info); - -#define HA_RECOVER_NONE 0 /* No automatic recover */ -#define HA_RECOVER_DEFAULT 1 /* Automatic recover active */ -#define HA_RECOVER_BACKUP 2 /* Make a backupfile on recover */ -#define HA_RECOVER_FORCE 4 /* Recover even if we loose rows */ -#define HA_RECOVER_QUICK 8 /* Don't check rows in data file */ - -#define HA_RECOVER_ANY (HA_RECOVER_DEFAULT | HA_RECOVER_BACKUP | HA_RECOVER_FORCE | HA_RECOVER_QUICK) - -/* this is used to pass to mysql_mariachk_table */ - -#define MARIA_CHK_REPAIR 1 /* equivalent to mariachk -r */ -#define MARIA_CHK_VERIFY 2 /* Verify, run repair if failure */ - -typedef uint maria_bit_type; - -typedef struct st_maria_bit_buff -{ /* Used for packing of record */ - maria_bit_type current_byte; - uint bits; - uchar *pos, *end, *blob_pos, *blob_end; - uint error; -} MARIA_BIT_BUFF; - -/* functions in maria_check */ -void maria_chk_init(HA_CHECK *param); -void maria_chk_init_for_check(HA_CHECK *param, MARIA_HA *info); -int maria_chk_status(HA_CHECK *param, MARIA_HA *info); -int maria_chk_del(HA_CHECK *param, MARIA_HA *info, ulonglong test_flag); -int maria_chk_size(HA_CHECK *param, MARIA_HA *info); -int maria_chk_key(HA_CHECK *param, MARIA_HA *info); -int maria_chk_data_link(HA_CHECK *param, MARIA_HA *info, my_bool extend); -int maria_repair(HA_CHECK *param, MARIA_HA *info, char * name, my_bool); -int maria_sort_index(HA_CHECK *param, MARIA_HA *info, char * name); -int maria_zerofill(HA_CHECK *param, MARIA_HA *info, const char *name); -int maria_repair_by_sort(HA_CHECK *param, MARIA_HA *info, - const char *name, my_bool rep_quick); -int maria_repair_parallel(HA_CHECK *param, MARIA_HA *info, - const char *name, my_bool rep_quick); -int maria_change_to_newfile(const char *filename, const char *old_ext, - const char *new_ext, time_t backup_time, - myf myflags); -void maria_lock_memory(HA_CHECK *param); -int maria_update_state_info(HA_CHECK *param, MARIA_HA *info, uint update); -void maria_update_key_parts(MARIA_KEYDEF *keyinfo, double *rec_per_key_part, - ulonglong *unique, ulonglong *notnull, - ulonglong records); -int maria_filecopy(HA_CHECK *param, File to, File from, my_off_t start, - my_off_t length, const char *type); -int maria_movepoint(MARIA_HA *info, uchar *record, my_off_t oldpos, - my_off_t newpos, uint prot_key); -int maria_test_if_almost_full(MARIA_HA *info); -int maria_recreate_table(HA_CHECK *param, MARIA_HA **org_info, char *filename); -int maria_disable_indexes(MARIA_HA *info); -int maria_enable_indexes(MARIA_HA *info); -int maria_indexes_are_disabled(MARIA_HA *info); -void maria_disable_indexes_for_rebuild(MARIA_HA *info, ha_rows rows, - my_bool all_keys); -my_bool maria_test_if_sort_rep(MARIA_HA *info, ha_rows rows, ulonglong key_map, - my_bool force); - -int maria_init_bulk_insert(MARIA_HA *info, size_t cache_size, ha_rows rows); -void maria_flush_bulk_insert(MARIA_HA *info, uint inx); -int maria_end_bulk_insert(MARIA_HA *info, my_bool abort); -int maria_preload(MARIA_HA *info, ulonglong key_map, my_bool ignore_leaves); -void maria_versioning(MARIA_HA *info, my_bool versioning); -void maria_ignore_trids(MARIA_HA *info); -uint maria_max_key_length(void); -my_bool maria_too_big_key_for_sort(MARIA_KEYDEF *key, ha_rows rows); -#define maria_max_key_segments() HA_MAX_KEY_SEG - -/* fulltext functions */ -FT_INFO *maria_ft_init_search(uint,void *, uint, uchar *, size_t, - CHARSET_INFO *, uchar *); - -/* 'Almost-internal' Maria functions */ - -void _ma_update_auto_increment_key(HA_CHECK *param, MARIA_HA *info, - my_bool repair); - + uint columns, MARIA_COLUMNDEF *columndef, + uint uniques, MARIA_UNIQUEDEF *uniquedef, + MARIA_CREATE_INFO *create_info, uint flags); #ifdef __cplusplus } #endif #endif + diff --git a/storage/maria/ha_maria.h b/storage/maria/ha_maria.h index d04c3c11b0f..deca18b689d 100644 --- a/storage/maria/ha_maria.h +++ b/storage/maria/ha_maria.h @@ -21,7 +21,7 @@ /* class for the maria handler */ -#include +#include "maria_def.h" #include "handler.h" #include "table.h" diff --git a/storage/maria/ma_pagecache.h b/storage/maria/ma_pagecache.h index 1096444aa33..3e409a63b30 100644 --- a/storage/maria/ma_pagecache.h +++ b/storage/maria/ma_pagecache.h @@ -354,8 +354,6 @@ extern my_bool multi_pagecache_set(const uchar *key, uint length, PAGECACHE *pagecache); extern void multi_pagecache_change(PAGECACHE *old_data, PAGECACHE *new_data); -extern int reset_pagecache_counters(const char *name, - PAGECACHE *pagecache); #ifndef DBUG_OFF void pagecache_file_no_dirty_page(PAGECACHE *pagecache, PAGECACHE_FILE *file); #else diff --git a/storage/maria/ma_sp_test.c b/storage/maria/ma_sp_test.c index 290a94872b5..ae8f3575438 100644 --- a/storage/maria/ma_sp_test.c +++ b/storage/maria/ma_sp_test.c @@ -17,7 +17,7 @@ /* Written by Alex Barkov, who has a shared copyright to this code */ #include -#include "maria.h" +#include "maria_def.h" #ifdef HAVE_SPATIAL #include "ma_sp_defs.h" diff --git a/storage/maria/ma_state.h b/storage/maria/ma_state.h index 98a7faf24a7..b27b75f54ab 100644 --- a/storage/maria/ma_state.h +++ b/storage/maria/ma_state.h @@ -13,6 +13,10 @@ along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335 USA */ +#ifndef MA_STATE_INCLUDED +#define MA_STATE_INCLUDED +C_MODE_START + /* Struct to store tables in use by one transaction */ typedef struct st_maria_status_info @@ -69,10 +73,6 @@ void _ma_copy_status(void* to, void *from); my_bool _ma_reset_update_flag(void *param, my_bool concurrent_insert); my_bool _ma_start_trans(void* param); my_bool _ma_check_status(void *param); -my_bool _ma_block_get_status(void* param, my_bool concurrent_insert); -void _ma_block_update_status(void *param); -void _ma_block_restore_status(void *param); -my_bool _ma_block_check_status(void *param); void maria_versioning(MARIA_HA *info, my_bool versioning); void _ma_set_share_data_file_length(struct st_maria_share *share, ulonglong new_length); @@ -86,3 +86,6 @@ void _ma_remove_not_visible_states_with_lock(struct st_maria_share *share, my_bool all); void _ma_remove_table_from_trnman(MARIA_HA *info); void _ma_reset_history(struct st_maria_share *share); + +C_MODE_END +#endif diff --git a/storage/maria/maria_def.h b/storage/maria/maria_def.h index 60ff34ff5aa..07394d41a76 100644 --- a/storage/maria/maria_def.h +++ b/storage/maria/maria_def.h @@ -15,13 +15,15 @@ /* This file is included by all internal maria files */ +#ifndef MARIA_DEF_INCLUDED +#define MARIA_DEF_INCLUDED + #include #ifdef EMBEDDED_LIBRARY #undef WITH_S3_STORAGE_ENGINE #endif -C_MODE_START #include "maria.h" /* Structs & some defines */ #include "ma_pagecache.h" #include /* packing of keys */ @@ -36,6 +38,277 @@ C_MODE_START #include #include +#define MARIA_CANNOT_ROLLBACK + +C_MODE_START + +/* + Limit max keys according to HA_MAX_POSSIBLE_KEY; See myisamchk.h for details +*/ + +#if MAX_INDEXES > HA_MAX_POSSIBLE_KEY +#define MARIA_MAX_KEY HA_MAX_POSSIBLE_KEY /* Max allowed keys */ +#else +#define MARIA_MAX_KEY MAX_INDEXES /* Max allowed keys */ +#endif + +#define MARIA_NAME_IEXT ".MAI" +#define MARIA_NAME_DEXT ".MAD" +/* Max extra space to use when sorting keys */ +#define MARIA_MAX_TEMP_LENGTH (2*1024L*1024L*1024L) +/* Possible values for maria_block_size (must be power of 2) */ +#define MARIA_KEY_BLOCK_LENGTH 8192 /* default key block length */ +#define MARIA_MIN_KEY_BLOCK_LENGTH 1024 /* Min key block length */ +#define MARIA_MAX_KEY_BLOCK_LENGTH 32768 +/* Minimal page cache when we only want to be able to scan a table */ +#define MARIA_MIN_PAGE_CACHE_SIZE (8192L*16L) + +/* + In the following macros '_keyno_' is 0 .. keys-1. + If there can be more keys than bits in the key_map, the highest bit + is for all upper keys. They cannot be switched individually. + This means that clearing of high keys is ignored, setting one high key + sets all high keys. +*/ +#define MARIA_KEYMAP_BITS (8 * SIZEOF_LONG_LONG) +#define MARIA_KEYMAP_HIGH_MASK (1ULL << (MARIA_KEYMAP_BITS - 1)) +#define maria_get_mask_all_keys_active(_keys_) \ + (((_keys_) < MARIA_KEYMAP_BITS) ? \ + ((1ULL << (_keys_)) - 1ULL) : \ + (~ 0ULL)) +#if MARIA_MAX_KEY > MARIA_KEYMAP_BITS +#define maria_is_key_active(_keymap_,_keyno_) \ + (((_keyno_) < MARIA_KEYMAP_BITS) ? \ + MY_TEST((_keymap_) & (1ULL << (_keyno_))) : \ + MY_TEST((_keymap_) & MARIA_KEYMAP_HIGH_MASK)) +#define maria_set_key_active(_keymap_,_keyno_) \ + (_keymap_)|= (((_keyno_) < MARIA_KEYMAP_BITS) ? \ + (1ULL << (_keyno_)) : \ + MARIA_KEYMAP_HIGH_MASK) +#define maria_clear_key_active(_keymap_,_keyno_) \ + (_keymap_)&= (((_keyno_) < MARIA_KEYMAP_BITS) ? \ + (~ (1ULL << (_keyno_))) : \ + (~ (0ULL)) /*ignore*/ ) +#else +#define maria_is_key_active(_keymap_,_keyno_) \ + MY_TEST((_keymap_) & (1ULL << (_keyno_))) +#define maria_set_key_active(_keymap_,_keyno_) \ + (_keymap_)|= (1ULL << (_keyno_)) +#define maria_clear_key_active(_keymap_,_keyno_) \ + (_keymap_)&= (~ (1ULL << (_keyno_))) +#endif +#define maria_is_any_key_active(_keymap_) \ + MY_TEST((_keymap_)) +#define maria_is_all_keys_active(_keymap_,_keys_) \ + ((_keymap_) == maria_get_mask_all_keys_active(_keys_)) +#define maria_set_all_keys_active(_keymap_,_keys_) \ + (_keymap_)= maria_get_mask_all_keys_active(_keys_) +#define maria_clear_all_keys_active(_keymap_) \ + (_keymap_)= 0 +#define maria_intersect_keys_active(_to_,_from_) \ + (_to_)&= (_from_) +#define maria_is_any_intersect_keys_active(_keymap1_,_keys_,_keymap2_) \ + ((_keymap1_) & (_keymap2_) & \ + maria_get_mask_all_keys_active(_keys_)) +#define maria_copy_keys_active(_to_,_maxkeys_,_from_) \ + (_to_)= (maria_get_mask_all_keys_active(_maxkeys_) & \ + (_from_)) + + /* Param to/from maria_info */ + +typedef struct st_maria_info +{ + ha_rows records; /* Records in database */ + ha_rows deleted; /* Deleted records in database */ + MARIA_RECORD_POS recpos; /* Pos for last used record */ + MARIA_RECORD_POS newrecpos; /* Pos if we write new record */ + MARIA_RECORD_POS dup_key_pos; /* Position to record with dup key */ + my_off_t data_file_length; /* Length of data file */ + my_off_t max_data_file_length, index_file_length; + my_off_t max_index_file_length, delete_length; + ulonglong auto_increment; + ulonglong key_map; /* Which keys are used */ + time_t create_time; /* When table was created */ + time_t check_time; + time_t update_time; + ulong record_offset; + double *rec_per_key; /* for sql optimizing */ + ulong reclength; /* Recordlength */ + ulong mean_reclength; /* Mean recordlength (if packed) */ + char *data_file_name, *index_file_name; + enum data_file_type data_file_type; + uint keys; /* Number of keys in use */ + uint options; /* HA_OPTION_... used */ + uint reflength; + int errkey, /* With key was dupplicated on err */ + sortkey; /* clustered by this key */ + File filenr; /* (uniq) filenr for datafile */ +} MARIA_INFO; + +struct st_maria_share; +struct st_maria_handler; /* For referense */ +struct st_maria_keydef; + +typedef struct st_maria_key /* Internal info about a key */ +{ + uchar *data; /* Data for key */ + struct st_maria_keydef *keyinfo; /* Definition for key */ + uint data_length; /* Length of key data */ + uint ref_length; /* record ref + transid */ + uint32 flag; /* 0 or SEARCH_PART_KEY */ +} MARIA_KEY; + +typedef struct st_maria_decode_tree /* Decode huff-table */ +{ + uint16 *table; + uint quick_table_bits; + uchar *intervalls; +} MARIA_DECODE_TREE; + + +typedef struct s3_info S3_INFO; + +extern ulong maria_block_size, maria_checkpoint_frequency; +extern ulong maria_concurrent_insert; +extern my_bool maria_flush, maria_single_user, maria_page_checksums; +extern my_off_t maria_max_temp_length; +extern ulong maria_bulk_insert_tree_size, maria_data_pointer_size; +extern MY_TMPDIR *maria_tmpdir; +extern my_bool maria_encrypt_tables; + +/* + This is used to check if a symlink points into the mysql data home, + which is normally forbidden as it can be used to get access to + not privileged data +*/ +extern int (*maria_test_invalid_symlink)(const char *filename); + + /* Prototypes for maria-functions */ + +extern int maria_init(void); +extern void maria_end(void); +extern my_bool maria_upgrade(void); +extern int maria_close(MARIA_HA *file); +extern int maria_delete(MARIA_HA *file, const uchar *buff); +extern MARIA_HA *maria_open(const char *name, int mode, + uint wait_if_locked, S3_INFO *s3); +extern int maria_panic(enum ha_panic_function function); +extern int maria_rfirst(MARIA_HA *file, uchar *buf, int inx); +extern int maria_rkey(MARIA_HA *file, uchar *buf, int inx, + const uchar *key, key_part_map keypart_map, + enum ha_rkey_function search_flag); +extern int maria_rlast(MARIA_HA *file, uchar *buf, int inx); +extern int maria_rnext(MARIA_HA *file, uchar *buf, int inx); +extern int maria_rnext_same(MARIA_HA *info, uchar *buf); +extern int maria_rprev(MARIA_HA *file, uchar *buf, int inx); +extern int maria_rrnd(MARIA_HA *file, uchar *buf, + MARIA_RECORD_POS pos); +extern int maria_scan_init(MARIA_HA *file); +extern int maria_scan(MARIA_HA *file, uchar *buf); +extern void maria_scan_end(MARIA_HA *file); +extern int maria_rsame(MARIA_HA *file, uchar *record, int inx); +extern int maria_rsame_with_pos(MARIA_HA *file, uchar *record, + int inx, MARIA_RECORD_POS pos); +extern int maria_update(MARIA_HA *file, const uchar *old, + const uchar *new_record); +extern int maria_write(MARIA_HA *file, const uchar *buff); +extern MARIA_RECORD_POS maria_position(MARIA_HA *file); +extern int maria_status(MARIA_HA *info, MARIA_INFO *x, uint flag); +extern int maria_lock_database(MARIA_HA *file, int lock_type); +extern int maria_delete_table(const char *name); +extern int maria_rename(const char *from, const char *to); +extern int maria_extra(MARIA_HA *file, + enum ha_extra_function function, void *extra_arg); +extern int maria_reset(MARIA_HA *file); +extern ha_rows maria_records_in_range(MARIA_HA *info, int inx, + const key_range *min_key, + const key_range *max_key, + page_range *page); +extern int maria_is_changed(MARIA_HA *info); +extern int maria_delete_all_rows(MARIA_HA *info); +extern uint maria_get_pointer_length(ulonglong file_length, uint def); +extern int maria_commit(MARIA_HA *info); +extern int maria_begin(MARIA_HA *info); +extern void maria_disable_logging(MARIA_HA *info); +extern void maria_enable_logging(MARIA_HA *info); + +#define HA_RECOVER_NONE 0 /* No automatic recover */ +#define HA_RECOVER_DEFAULT 1 /* Automatic recover active */ +#define HA_RECOVER_BACKUP 2 /* Make a backupfile on recover */ +#define HA_RECOVER_FORCE 4 /* Recover even if we loose rows */ +#define HA_RECOVER_QUICK 8 /* Don't check rows in data file */ + +#define HA_RECOVER_ANY (HA_RECOVER_DEFAULT | HA_RECOVER_BACKUP | HA_RECOVER_FORCE | HA_RECOVER_QUICK) + +/* this is used to pass to mysql_mariachk_table */ + +#define MARIA_CHK_REPAIR 1 /* equivalent to mariachk -r */ +#define MARIA_CHK_VERIFY 2 /* Verify, run repair if failure */ + +typedef uint maria_bit_type; + +typedef struct st_maria_bit_buff +{ /* Used for packing of record */ + maria_bit_type current_byte; + uint bits; + uchar *pos, *end, *blob_pos, *blob_end; + uint error; +} MARIA_BIT_BUFF; + +/* functions in maria_check */ +void maria_chk_init(HA_CHECK *param); +void maria_chk_init_for_check(HA_CHECK *param, MARIA_HA *info); +int maria_chk_status(HA_CHECK *param, MARIA_HA *info); +int maria_chk_del(HA_CHECK *param, MARIA_HA *info, ulonglong test_flag); +int maria_chk_size(HA_CHECK *param, MARIA_HA *info); +int maria_chk_key(HA_CHECK *param, MARIA_HA *info); +int maria_chk_data_link(HA_CHECK *param, MARIA_HA *info, my_bool extend); +int maria_repair(HA_CHECK *param, MARIA_HA *info, char * name, my_bool); +int maria_sort_index(HA_CHECK *param, MARIA_HA *info, char * name); +int maria_zerofill(HA_CHECK *param, MARIA_HA *info, const char *name); +int maria_repair_by_sort(HA_CHECK *param, MARIA_HA *info, + const char *name, my_bool rep_quick); +int maria_repair_parallel(HA_CHECK *param, MARIA_HA *info, + const char *name, my_bool rep_quick); +int maria_change_to_newfile(const char *filename, const char *old_ext, + const char *new_ext, time_t backup_time, + myf myflags); +void maria_lock_memory(HA_CHECK *param); +int maria_update_state_info(HA_CHECK *param, MARIA_HA *info, uint update); +void maria_update_key_parts(MARIA_KEYDEF *keyinfo, double *rec_per_key_part, + ulonglong *unique, ulonglong *notnull, + ulonglong records); +int maria_filecopy(HA_CHECK *param, File to, File from, my_off_t start, + my_off_t length, const char *type); +int maria_movepoint(MARIA_HA *info, uchar *record, my_off_t oldpos, + my_off_t newpos, uint prot_key); +int maria_test_if_almost_full(MARIA_HA *info); +int maria_recreate_table(HA_CHECK *param, MARIA_HA **org_info, char *filename); +int maria_disable_indexes(MARIA_HA *info); +int maria_enable_indexes(MARIA_HA *info); +int maria_indexes_are_disabled(MARIA_HA *info); +void maria_disable_indexes_for_rebuild(MARIA_HA *info, ha_rows rows, + my_bool all_keys); +my_bool maria_test_if_sort_rep(MARIA_HA *info, ha_rows rows, ulonglong key_map, + my_bool force); + +int maria_init_bulk_insert(MARIA_HA *info, size_t cache_size, ha_rows rows); +void maria_flush_bulk_insert(MARIA_HA *info, uint inx); +int maria_end_bulk_insert(MARIA_HA *info, my_bool abort); +int maria_preload(MARIA_HA *info, ulonglong key_map, my_bool ignore_leaves); +void maria_ignore_trids(MARIA_HA *info); +my_bool maria_too_big_key_for_sort(MARIA_KEYDEF *key, ha_rows rows); + +/* fulltext functions */ +FT_INFO *maria_ft_init_search(uint,void *, uint, uchar *, size_t, + CHARSET_INFO *, uchar *); + +/* 'Almost-internal' Maria functions */ + +void _ma_update_auto_increment_key(HA_CHECK *param, MARIA_HA *info, + my_bool repair); + + /* Do extra sanity checking */ #define SANITY_CHECKS 1 #ifdef EXTRA_DEBUG @@ -1370,12 +1643,6 @@ my_bool _ma_cmp_dynamic_unique(MARIA_HA *info, MARIA_UNIQUEDEF *def, const uchar *record, MARIA_RECORD_POS pos); my_bool _ma_unique_comp(MARIA_UNIQUEDEF *def, const uchar *a, const uchar *b, my_bool null_are_equal); -my_bool _ma_get_status(void *param, my_bool concurrent_insert); -void _ma_update_status(void *param); -void _ma_restore_status(void *param); -void _ma_copy_status(void *to, void *from); -my_bool _ma_check_status(void *param); -void _ma_restore_status(void *param); void _ma_reset_status(MARIA_HA *maria); int _ma_def_scan_remember_pos(MARIA_HA *info, MARIA_RECORD_POS *lastpos); int _ma_def_scan_restore_pos(MARIA_HA *info, MARIA_RECORD_POS lastpos); @@ -1495,3 +1762,4 @@ static inline void decrement_share_in_trans(MARIA_SHARE *share) mysql_mutex_unlock(&share->intern_lock); } C_MODE_END +#endif