70
72
sets all high keys.
72
74
#define MI_KEYMAP_BITS (8 * SIZEOF_LONG_LONG)
73
#define MI_KEYMAP_HIGH_MASK (1UL << (MI_KEYMAP_BITS - 1))
75
#define MI_KEYMAP_HIGH_MASK (1ULL << (MI_KEYMAP_BITS - 1))
74
76
#define mi_get_mask_all_keys_active(_keys_) \
75
77
(((_keys_) < MI_KEYMAP_BITS) ? \
76
((1UL << (_keys_)) - 1UL) : \
78
((1ULL << (_keys_)) - 1ULL) : \
79
81
#if MI_MAX_KEY > MI_KEYMAP_BITS
81
83
#define mi_is_key_active(_keymap_,_keyno_) \
82
84
(((_keyno_) < MI_KEYMAP_BITS) ? \
83
test((_keymap_) & (1UL << (_keyno_))) : \
85
test((_keymap_) & (1ULL << (_keyno_))) : \
84
86
test((_keymap_) & MI_KEYMAP_HIGH_MASK))
85
87
#define mi_set_key_active(_keymap_,_keyno_) \
86
88
(_keymap_)|= (((_keyno_) < MI_KEYMAP_BITS) ? \
87
(1UL << (_keyno_)) : \
89
(1ULL << (_keyno_)) : \
88
90
MI_KEYMAP_HIGH_MASK)
89
91
#define mi_clear_key_active(_keymap_,_keyno_) \
90
92
(_keymap_)&= (((_keyno_) < MI_KEYMAP_BITS) ? \
91
(~ (1UL << (_keyno_))) : \
92
(~ (0UL)) /*ignore*/ )
93
(~ (1ULL << (_keyno_))) : \
94
(~ (0ULL)) /*ignore*/ )
96
98
#define mi_is_key_active(_keymap_,_keyno_) \
97
test((_keymap_) & (1UL << (_keyno_)))
99
test((_keymap_) & (1ULL << (_keyno_)))
98
100
#define mi_set_key_active(_keymap_,_keyno_) \
99
(_keymap_)|= (1UL << (_keyno_))
101
(_keymap_)|= (1ULL << (_keyno_))
100
102
#define mi_clear_key_active(_keymap_,_keyno_) \
101
(_keymap_)&= (~ (1UL << (_keyno_)))
103
(_keymap_)&= (~ (1ULL << (_keyno_)))
173
175
typedef struct st_mi_keydef /* Key definition with open & info */
175
177
struct st_mi_isam_share *share; /* Pointer to base (set in mi_open) */
176
uint16_t keysegs; /* Number of key-segment */
177
uint16_t flag; /* NOSAME, PACK_USED */
178
uint16 keysegs; /* Number of key-segment */
179
uint16 flag; /* NOSAME, PACK_USED */
179
uint8_t key_alg; /* BTREE, RTREE */
180
uint16_t block_length; /* Length of keyblock (auto) */
181
uint16_t underflow_block_length; /* When to execute underflow */
182
uint16_t keylength; /* Tot length of keyparts (auto) */
183
uint16_t minlength; /* min length of (packed) key (auto) */
184
uint16_t maxlength; /* max length of (packed) key (auto) */
185
uint16_t block_size_index; /* block_size (auto) */
186
uint32_t version; /* For concurrent read/write */
181
uint8 key_alg; /* BTREE, RTREE */
182
uint16 block_length; /* Length of keyblock (auto) */
183
uint16 underflow_block_length; /* When to execute underflow */
184
uint16 keylength; /* Tot length of keyparts (auto) */
185
uint16 minlength; /* min length of (packed) key (auto) */
186
uint16 maxlength; /* max length of (packed) key (auto) */
187
uint16 block_size_index; /* block_size (auto) */
188
uint32 version; /* For concurrent read/write */
188
190
HA_KEYSEG *seg,*end;
190
192
int (*bin_search)(struct st_myisam_info *info,struct st_mi_keydef *keyinfo,
191
unsigned char *page,unsigned char *key,
192
uint32_t key_len,uint32_t comp_flag,unsigned char * *ret_pos,
193
unsigned char *buff, bool *was_last_key);
194
uint32_t (*get_key)(struct st_mi_keydef *keyinfo,uint32_t nod_flag,unsigned char * *page,
196
int (*pack_key)(struct st_mi_keydef *keyinfo,uint32_t nod_flag,unsigned char *next_key,
197
unsigned char *org_key, unsigned char *prev_key, unsigned char *key,
193
uchar *page,uchar *key,
194
uint key_len,uint comp_flag,uchar * *ret_pos,
195
uchar *buff, my_bool *was_last_key);
196
uint (*get_key)(struct st_mi_keydef *keyinfo,uint nod_flag,uchar * *page,
198
int (*pack_key)(struct st_mi_keydef *keyinfo,uint nod_flag,uchar *next_key,
199
uchar *org_key, uchar *prev_key, uchar *key,
198
200
struct st_mi_s_param *s_temp);
199
void (*store_key)(struct st_mi_keydef *keyinfo, unsigned char *key_pos,
201
void (*store_key)(struct st_mi_keydef *keyinfo, uchar *key_pos,
200
202
struct st_mi_s_param *s_temp);
201
int (*ck_insert)(struct st_myisam_info *inf, uint32_t k_nr, unsigned char *k, uint32_t klen);
202
int (*ck_delete)(struct st_myisam_info *inf, uint32_t k_nr, unsigned char *k, uint32_t klen);
203
int (*ck_insert)(struct st_myisam_info *inf, uint k_nr, uchar *k, uint klen);
204
int (*ck_delete)(struct st_myisam_info *inf, uint k_nr, uchar *k, uint klen);
232
234
typedef struct st_columndef /* column information */
234
int16_t type; /* en_fieldtype */
235
uint16_t length; /* length of field */
236
uint32_t offset; /* Offset to position in row */
237
uint8_t null_bit; /* If column may be 0 */
238
uint16_t null_pos; /* position for null marker */
236
int16 type; /* en_fieldtype */
237
uint16 length; /* length of field */
238
uint32 offset; /* Offset to position in row */
239
uint8 null_bit; /* If column may be 0 */
240
uint16 null_pos; /* position for null marker */
240
242
#ifndef NOT_PACKED_DATABASES
241
243
void (*unpack)(struct st_columndef *rec,struct st_mi_bit_buff *buff,
242
unsigned char *start,unsigned char *end);
244
uchar *start,uchar *end);
243
245
enum en_fieldtype base_type;
244
uint32_t space_length_bits,pack_type;
246
uint space_length_bits,pack_type;
245
247
MI_DECODE_TREE *huff_tree;
250
252
extern char * myisam_log_filename; /* Name of logfile */
251
extern uint32_t myisam_block_size;
252
extern uint32_t myisam_concurrent_insert;
253
extern ulong myisam_block_size;
254
extern ulong myisam_concurrent_insert;
253
255
extern bool myisam_flush,myisam_delay_key_write,myisam_single_user;
254
256
extern my_off_t myisam_max_temp_length;
255
extern uint32_t myisam_bulk_insert_tree_size, myisam_data_pointer_size;
257
extern ulong myisam_bulk_insert_tree_size, myisam_data_pointer_size;
257
259
/* Prototypes for myisam-functions */
259
261
extern int mi_close(struct st_myisam_info *file);
260
extern int mi_delete(struct st_myisam_info *file,const unsigned char *buff);
262
extern int mi_delete(struct st_myisam_info *file,const uchar *buff);
261
263
extern struct st_myisam_info *mi_open(const char *name,int mode,
262
uint32_t wait_if_locked);
264
uint wait_if_locked);
263
265
extern int mi_panic(enum ha_panic_function function);
264
extern int mi_rfirst(struct st_myisam_info *file,unsigned char *buf,int inx);
265
extern int mi_rkey(MI_INFO *info, unsigned char *buf, int inx, const unsigned char *key,
266
extern int mi_rfirst(struct st_myisam_info *file,uchar *buf,int inx);
267
extern int mi_rkey(MI_INFO *info, uchar *buf, int inx, const uchar *key,
266
268
key_part_map keypart_map, enum ha_rkey_function search_flag);
267
extern int mi_rlast(struct st_myisam_info *file,unsigned char *buf,int inx);
268
extern int mi_rnext(struct st_myisam_info *file,unsigned char *buf,int inx);
269
extern int mi_rnext_same(struct st_myisam_info *info, unsigned char *buf);
270
extern int mi_rprev(struct st_myisam_info *file,unsigned char *buf,int inx);
271
extern int mi_rrnd(struct st_myisam_info *file,unsigned char *buf, my_off_t pos);
269
extern int mi_rlast(struct st_myisam_info *file,uchar *buf,int inx);
270
extern int mi_rnext(struct st_myisam_info *file,uchar *buf,int inx);
271
extern int mi_rnext_same(struct st_myisam_info *info, uchar *buf);
272
extern int mi_rprev(struct st_myisam_info *file,uchar *buf,int inx);
273
extern int mi_rrnd(struct st_myisam_info *file,uchar *buf, my_off_t pos);
272
274
extern int mi_scan_init(struct st_myisam_info *file);
273
extern int mi_scan(struct st_myisam_info *file,unsigned char *buf);
274
extern int mi_rsame(struct st_myisam_info *file,unsigned char *record,int inx);
275
extern int mi_rsame_with_pos(struct st_myisam_info *file,unsigned char *record,
275
extern int mi_scan(struct st_myisam_info *file,uchar *buf);
276
extern int mi_rsame(struct st_myisam_info *file,uchar *record,int inx);
277
extern int mi_rsame_with_pos(struct st_myisam_info *file,uchar *record,
276
278
int inx, my_off_t pos);
277
extern int mi_update(struct st_myisam_info *file,const unsigned char *old,
278
unsigned char *new_record);
279
extern int mi_write(struct st_myisam_info *file,unsigned char *buff);
279
extern int mi_update(struct st_myisam_info *file,const uchar *old,
281
extern int mi_write(struct st_myisam_info *file,uchar *buff);
280
282
extern my_off_t mi_position(struct st_myisam_info *file);
281
extern int mi_status(struct st_myisam_info *info, MI_ISAMINFO *x, uint32_t flag);
283
extern int mi_status(struct st_myisam_info *info, MI_ISAMINFO *x, uint flag);
282
284
extern int mi_lock_database(struct st_myisam_info *file,int lock_type);
283
extern int mi_create(const char *name,uint32_t keys,MI_KEYDEF *keydef,
284
uint32_t columns, MI_COLUMNDEF *columndef,
285
uint32_t uniques, MI_UNIQUEDEF *uniquedef,
286
MI_CREATE_INFO *create_info, uint32_t flags);
285
extern int mi_create(const char *name,uint keys,MI_KEYDEF *keydef,
286
uint columns, MI_COLUMNDEF *columndef,
287
uint uniques, MI_UNIQUEDEF *uniquedef,
288
MI_CREATE_INFO *create_info, uint flags);
287
289
extern int mi_delete_table(const char *name);
288
290
extern int mi_rename(const char *from, const char *to);
289
291
extern int mi_extra(struct st_myisam_info *file,
400
402
ha_checksum record_checksum,glob_crc;
401
403
ulong use_buffers,read_buffer_length,write_buffer_length,
402
404
sort_buffer_length,sort_key_blocks;
403
uint32_t out_flag,warning_printed,error_printed,verbose;
404
uint32_t opt_sort_key,total_files,max_level;
405
uint32_t testflag, key_cache_block_size;
407
bool using_global_keycache, opt_lock_memory, opt_follow_links;
408
bool retry_repair, force_sort;
405
uint out_flag,warning_printed,error_printed,verbose;
406
uint opt_sort_key,total_files,max_level;
407
uint testflag, key_cache_block_size;
409
my_bool using_global_keycache, opt_lock_memory, opt_follow_links;
410
my_bool retry_repair, force_sort;
409
411
char temp_filename[FN_REFLEN],*isam_file_name;
410
412
MY_TMPDIR *tmpdir;
411
413
int tmpfile_createflag;
459
461
int mi_repair_parallel(MI_CHECK *param, register MI_INFO *info,
460
462
const char * name, int rep_quick);
461
463
int change_to_newfile(const char * filename, const char * old_ext,
462
const char * new_ext, uint32_t raid_chunks,
464
const char * new_ext, uint raid_chunks,
464
466
void lock_memory(MI_CHECK *param);
465
467
void update_auto_increment_key(MI_CHECK *param, MI_INFO *info,
467
int update_state_info(MI_CHECK *param, MI_INFO *info,uint32_t update);
469
int update_state_info(MI_CHECK *param, MI_INFO *info,uint update);
468
470
void update_key_parts(MI_KEYDEF *keyinfo, ulong *rec_per_key_part,
469
471
uint64_t *unique, uint64_t *notnull,
470
472
uint64_t records);
471
473
int filecopy(MI_CHECK *param, File to,File from,my_off_t start,
472
474
my_off_t length, const char *type);
473
int movepoint(MI_INFO *info,unsigned char *record,my_off_t oldpos,
474
my_off_t newpos, uint32_t prot_key);
475
int write_data_suffix(SORT_INFO *sort_info, bool fix_datafile);
475
int movepoint(MI_INFO *info,uchar *record,my_off_t oldpos,
476
my_off_t newpos, uint prot_key);
477
int write_data_suffix(SORT_INFO *sort_info, my_bool fix_datafile);
476
478
int test_if_almost_full(MI_INFO *info);
477
479
int recreate_table(MI_CHECK *param, MI_INFO **org_info, char *filename);
478
bool mi_test_if_sort_rep(MI_INFO *info, ha_rows rows, uint64_t key_map,
480
my_bool mi_test_if_sort_rep(MI_INFO *info, ha_rows rows, uint64_t key_map,
481
int mi_init_bulk_insert(MI_INFO *info, uint32_t cache_size, ha_rows rows);
482
void mi_flush_bulk_insert(MI_INFO *info, uint32_t inx);
483
int mi_init_bulk_insert(MI_INFO *info, ulong cache_size, ha_rows rows);
484
void mi_flush_bulk_insert(MI_INFO *info, uint inx);
483
485
void mi_end_bulk_insert(MI_INFO *info);
484
486
int mi_assign_to_key_cache(MI_INFO *info, uint64_t key_map,
485
487
KEY_CACHE *key_cache);
486
488
void mi_change_key_cache(KEY_CACHE *old_key_cache,
487
489
KEY_CACHE *new_key_cache);
488
int mi_preload(MI_INFO *info, uint64_t key_map, bool ignore_leaves);
490
int mi_preload(MI_INFO *info, uint64_t key_map, my_bool ignore_leaves);
490
492
#ifdef __cplusplus