~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to storage/myisam/myisamdef.h

  • Committer: Brian Aker
  • Date: 2009-01-24 09:43:35 UTC
  • Revision ID: brian@gir-3.local-20090124094335-6qdtvc35gl5fvivz
Adding in an example singe thread scheduler

Show diffs side-by-side

added added

removed removed

Lines of Context:
15
15
 
16
16
/* This file is included by all internal myisam files */
17
17
 
18
 
#ifndef PLUGIN_MYISAM_MYISAM_PRIV_H
19
 
#define PLUGIN_MYISAM_MYISAM_PRIV_H
 
18
#ifndef MYISAMDEF_H
 
19
#define MYISAMDEF_H
20
20
 
21
 
#include "config.h"
 
21
#include <drizzled/global.h>
22
22
#include "myisam.h"                     /* Structs & some defines */
23
23
#include "myisampack.h"                 /* packing of keys */
24
 
#include "drizzled/tree.h"
25
 
#include "drizzled/internal/my_pthread.h"
26
 
#include <drizzled/thr_lock.h>
 
24
#include <mysys/my_tree.h>
 
25
#include <mysys/my_pthread.h>
 
26
#include <mysys/thr_lock.h>
27
27
#include <drizzled/common.h>
28
28
 
29
 
#include <assert.h>
30
 
#include <fcntl.h>
31
29
#include <string.h>
32
 
#include <list>
33
30
 
34
31
#if defined(my_write)
35
32
#undef my_write                         /* undef map from my_nosys; We need test-if-disk full */
36
33
#endif
37
34
 
 
35
#ifdef  __cplusplus
 
36
extern "C" {
 
37
#endif
 
38
 
38
39
typedef struct st_mi_status_info
39
40
{
40
 
  drizzled::ha_rows records;                    /* Rows in table */
41
 
  drizzled::ha_rows del;                                /* Removed rows */
42
 
  drizzled::internal::my_off_t empty;                   /* lost space in datafile */
43
 
  drizzled::internal::my_off_t key_empty;                       /* lost space in indexfile */
44
 
  drizzled::internal::my_off_t key_file_length;
45
 
  drizzled::internal::my_off_t data_file_length;
46
 
  drizzled::internal::ha_checksum checksum;
 
41
  ha_rows records;                      /* Rows in table */
 
42
  ha_rows del;                          /* Removed rows */
 
43
  my_off_t empty;                       /* lost space in datafile */
 
44
  my_off_t key_empty;                   /* lost space in indexfile */
 
45
  my_off_t key_file_length;
 
46
  my_off_t data_file_length;
 
47
  ha_checksum checksum;
47
48
} MI_STATUS_INFO;
48
49
 
49
50
typedef struct st_mi_state_info
66
67
  } header;
67
68
 
68
69
  MI_STATUS_INFO state;
69
 
  drizzled::ha_rows split;                      /* number of split blocks */
70
 
  drizzled::internal::my_off_t dellink;                 /* Link to next removed block */
 
70
  ha_rows split;                        /* number of split blocks */
 
71
  my_off_t dellink;                     /* Link to next removed block */
71
72
  uint64_t auto_increment;
72
73
  ulong process;                        /* process that updated table last */
73
74
  ulong unique;                         /* Unique number for this process */
74
75
  ulong update_count;                   /* Updated for each write lock */
75
76
  ulong status;
76
77
  ulong *rec_per_key_part;
77
 
  drizzled::internal::my_off_t *key_root;                       /* Start of key trees */
78
 
  drizzled::internal::my_off_t *key_del;                        /* delete links for trees */
79
 
  drizzled::internal::my_off_t rec_per_key_rows;                /* Rows when calculating rec_per_key */
 
78
  my_off_t *key_root;                   /* Start of key trees */
 
79
  my_off_t *key_del;                    /* delete links for trees */
 
80
  my_off_t rec_per_key_rows;            /* Rows when calculating rec_per_key */
80
81
 
81
82
  ulong sec_index_changed;              /* Updated when new sec_index */
82
83
  ulong sec_index_used;                 /* which extra index are in use */
83
84
  uint64_t key_map;                     /* Which keys are in use */
84
 
  drizzled::internal::ha_checksum checksum;                 /* Table checksum */
 
85
  ha_checksum checksum;                 /* Table checksum */
85
86
  ulong version;                        /* timestamp of create */
86
87
  time_t create_time;                   /* Time when created database */
87
88
  time_t recover_time;                  /* Time for last recover */
110
111
 
111
112
typedef struct st_mi_base_info
112
113
{
113
 
  drizzled::internal::my_off_t keystart;                        /* Start of keys */
114
 
  drizzled::internal::my_off_t max_data_file_length;
115
 
  drizzled::internal::my_off_t max_key_file_length;
116
 
  drizzled::internal::my_off_t margin_key_file_length;
117
 
  drizzled::ha_rows records,reloc;              /* Create information */
 
114
  my_off_t keystart;                    /* Start of keys */
 
115
  my_off_t max_data_file_length;
 
116
  my_off_t max_key_file_length;
 
117
  my_off_t margin_key_file_length;
 
118
  ha_rows records,reloc;                /* Create information */
118
119
  ulong mean_row_length;                /* Create information */
119
120
  ulong reclength;                      /* length of unpacked record */
120
121
  ulong pack_reclength;                 /* Length of full packed rec. */
160
161
 
161
162
#define MAX_NONMAPPED_INSERTS 1000
162
163
 
163
 
namespace drizzled { class Session; }
164
 
 
165
164
typedef struct st_mi_isam_share {       /* Shared between opens */
166
165
  MI_STATE_INFO state;
167
166
  MI_BASE_INFO base;
169
168
  MI_KEYDEF  *keyinfo;                  /* Key definitions */
170
169
  MI_UNIQUEDEF *uniqueinfo;             /* unique definitions */
171
170
  HA_KEYSEG *keyparts;                  /* key part info */
172
 
  drizzled::MI_COLUMNDEF *rec;                  /* Pointer to field information */
 
171
  MI_COLUMNDEF *rec;                    /* Pointer to field information */
173
172
  MI_PACK    pack;                      /* Data about packed records */
174
173
  MI_BLOB    *blobs;                    /* Pointer to blobs */
175
 
  std::list<drizzled::Session *> *in_use;         /* List of threads using this table */
 
174
  LIST *in_use;                         /* List of threads using this table */
176
175
  char  *unique_file_name;              /* realpath() of index file */
177
176
  char  *data_file_name,                /* Resolved path names from symlinks */
178
177
        *index_file_name;
179
178
  unsigned char *file_map;                      /* mem-map of file if possible */
180
 
  drizzled::KEY_CACHE *key_cache;                       /* ref to the current key cache */
 
179
  KEY_CACHE *key_cache;                 /* ref to the current key cache */
181
180
  MI_DECODE_TREE *decode_trees;
182
181
  uint16_t *decode_tables;
183
 
  int (*read_record)(struct st_myisam_info*, drizzled::internal::my_off_t, unsigned char*);
 
182
  int (*read_record)(struct st_myisam_info*, my_off_t, unsigned char*);
184
183
  int (*write_record)(struct st_myisam_info*, const unsigned char*);
185
 
  int (*update_record)(struct st_myisam_info*, drizzled::internal::my_off_t, const unsigned char*);
 
184
  int (*update_record)(struct st_myisam_info*, my_off_t, const unsigned char*);
186
185
  int (*delete_record)(struct st_myisam_info*);
187
 
  int (*read_rnd)(struct st_myisam_info*, unsigned char*, drizzled::internal::my_off_t, bool);
 
186
  int (*read_rnd)(struct st_myisam_info*, unsigned char*, my_off_t, bool);
188
187
  int (*compare_record)(struct st_myisam_info*, const unsigned char *);
189
188
  /* Function to use for a row checksum. */
190
 
  drizzled::internal::ha_checksum (*calc_checksum)(struct st_myisam_info*, const unsigned char *);
 
189
  ha_checksum (*calc_checksum)(struct st_myisam_info*, const unsigned char *);
191
190
  int (*compare_unique)(struct st_myisam_info*, MI_UNIQUEDEF *,
192
 
                        const unsigned char *record, drizzled::internal::my_off_t pos);
193
 
  size_t (*file_read)(MI_INFO *, unsigned char *, size_t, drizzled::internal::my_off_t, drizzled::myf);
194
 
  size_t (*file_write)(MI_INFO *, const unsigned char *, size_t, drizzled::internal::my_off_t, drizzled::myf);
 
191
                        const unsigned char *record, my_off_t pos);
 
192
  size_t (*file_read)(MI_INFO *, unsigned char *, size_t, my_off_t, myf);
 
193
  size_t (*file_write)(MI_INFO *, const unsigned char *, size_t, my_off_t, myf);
 
194
  invalidator_by_filename invalidator;  /* query cache invalidator */
195
195
  ulong this_process;                   /* processid */
196
196
  ulong last_process;                   /* For table-change-check */
197
197
  ulong last_version;                   /* Version on start */
201
201
  ulong state_diff_length;
202
202
  uint  rec_reflength;                  /* rec_reflength in use now */
203
203
  uint32_t  unique_name_length;
204
 
  int   kfile;                          /* Shared keyfile */
205
 
  int   data_file;                      /* Shared data file */
 
204
  File  kfile;                          /* Shared keyfile */
 
205
  File  data_file;                      /* Shared data file */
206
206
  int   mode;                           /* mode of file on open */
207
207
  uint  reopen;                         /* How many times reopened */
208
208
  uint  w_locks,r_locks,tot_locks;      /* Number of read/write locks */
209
209
  uint  blocksize;                      /* blocksize of keyfile */
210
 
  drizzled::myf write_flag;
211
 
  enum drizzled::data_file_type data_file_type;
 
210
  myf write_flag;
 
211
  enum data_file_type data_file_type;
212
212
  /* Below flag is needed to make log tables work with concurrent insert */
213
213
  bool is_log_table;
214
214
 
217
217
    not_flushed,
218
218
    temporary,delay_key_write,
219
219
    concurrent_insert;
220
 
  drizzled::THR_LOCK lock;
 
220
  THR_LOCK lock;
221
221
  pthread_mutex_t intern_lock;          /* Locking for use with _locking */
222
222
  pthread_rwlock_t *key_root_lock;
223
 
  drizzled::internal::my_off_t mmaped_length;
 
223
  my_off_t mmaped_length;
224
224
  uint32_t     nonmmaped_inserts;           /* counter of writing in non-mmaped
225
225
                                           area */
226
226
  pthread_rwlock_t mmap_lock;
245
245
  MI_BLOB     *blobs;                   /* Pointer to blobs */
246
246
  MI_BIT_BUFF  bit_buff;
247
247
  /* accumulate indexfile changes between write's */
248
 
  drizzled::TREE                *bulk_insert;
249
 
  drizzled::Session *in_use;                      /* Thread using this table          */
 
248
  TREE          *bulk_insert;
 
249
  LIST in_use;                          /* Thread using this table          */
250
250
  char *filename;                       /* parameter to open filename       */
251
251
  unsigned char *buff,                          /* Temp area for key                */
252
252
        *lastkey,*lastkey2;             /* Last used search key             */
256
256
        *int_maxpos;                    /*  -""-  */
257
257
  uint32_t  int_nod_flag;                       /*  -""-  */
258
258
  uint32_t int_keytree_version;         /*  -""-  */
259
 
  int (*read_record)(struct st_myisam_info*, drizzled::internal::my_off_t, unsigned char*);
 
259
  int (*read_record)(struct st_myisam_info*, my_off_t, unsigned char*);
 
260
  invalidator_by_filename invalidator;  /* query cache invalidator */
260
261
  ulong this_unique;                    /* uniq filenumber or thread */
261
262
  ulong last_unique;                    /* last unique number */
262
263
  ulong this_loop;                      /* counter for this open */
263
264
  ulong last_loop;                      /* last used counter */
264
 
  drizzled::internal::my_off_t lastpos,                 /* Last record position */
 
265
  my_off_t lastpos,                     /* Last record position */
265
266
        nextpos;                        /* Position to next record */
266
 
  drizzled::internal::my_off_t save_lastpos;
267
 
  drizzled::internal::my_off_t pos;                             /* Intern variable */
268
 
  drizzled::internal::my_off_t last_keypage;            /* Last key page read */
269
 
  drizzled::internal::my_off_t last_search_keypage;             /* Last keypage when searching */
270
 
  drizzled::internal::my_off_t dupp_key_pos;
271
 
  drizzled::internal::ha_checksum checksum;                 /* Temp storage for row checksum */
 
267
  my_off_t save_lastpos;
 
268
  my_off_t pos;                         /* Intern variable */
 
269
  my_off_t last_keypage;                /* Last key page read */
 
270
  my_off_t last_search_keypage;         /* Last keypage when searching */
 
271
  my_off_t dupp_key_pos;
 
272
  ha_checksum checksum;                 /* Temp storage for row checksum */
272
273
  /* QQ: the folloing two xxx_length fields should be removed,
273
274
     as they are not compatible with parallel repair */
274
275
  ulong packed_length,blob_length;      /* Length of found, packed record */
278
279
  int   lastinx;                        /* Last used index */
279
280
  uint  lastkey_length;                 /* Length of key in lastkey */
280
281
  uint  last_rkey_length;               /* Last length in mi_rkey() */
281
 
  enum drizzled::ha_rkey_function last_key_func;  /* CONTAIN, OVERLAP, etc */
 
282
  enum ha_rkey_function last_key_func;  /* CONTAIN, OVERLAP, etc */
282
283
  uint32_t  save_lastkey_length;
283
284
  uint32_t  pack_key_length;                /* For MYISAMMRG */
284
285
  uint16_t last_used_keyseg;              /* For MyISAMMRG */
288
289
  uint  data_changed;                   /* Somebody has changed data */
289
290
  uint  save_update;                    /* When using KEY_READ */
290
291
  int   save_lastinx;
291
 
  drizzled::internal::IO_CACHE rec_cache;                       /* When cacheing records */
 
292
  LIST  open_list;
 
293
  IO_CACHE rec_cache;                   /* When cacheing records */
292
294
  uint32_t  preload_buff_size;              /* When preloading indexes */
293
 
  drizzled::myf lock_wait;                      /* is 0 or MY_DONT_WAIT */
 
295
  myf lock_wait;                        /* is 0 or MY_DONT_WAIT */
294
296
  bool was_locked;                      /* Was locked in panic */
295
297
  bool append_insert_at_end;            /* Set if concurrent insert */
296
298
  bool quick_mode;
300
302
 
301
303
  index_cond_func_t index_cond_func;   /* Index condition function */
302
304
  void *index_cond_func_arg;           /* parameter for the func */
303
 
  drizzled::THR_LOCK_DATA lock;
 
305
  THR_LOCK_DATA lock;
304
306
  unsigned char  *rtree_recursion_state;        /* For RTREE */
305
307
  int     rtree_recursion_depth;
306
308
};
307
309
 
308
310
typedef struct st_buffpek {
309
 
  off_t file_pos;                    /* Where we are in the sort file */
 
311
  my_off_t file_pos;                    /* Where we are in the sort file */
310
312
  unsigned char *base,*key;                     /* Key pointers */
311
 
  drizzled::ha_rows count;                        /* Number of rows in table */
 
313
  ha_rows count;                        /* Number of rows in table */
312
314
  ulong mem_count;                      /* numbers of keys in memory */
313
315
  ulong max_keys;                       /* Max keys in buffert */
314
316
} BUFFPEK;
316
318
typedef struct st_mi_sort_param
317
319
{
318
320
  pthread_t  thr;
319
 
  drizzled::internal::IO_CACHE read_cache, tempfile, tempfile_for_exceptions;
320
 
  drizzled::DYNAMIC_ARRAY buffpek;
 
321
  IO_CACHE read_cache, tempfile, tempfile_for_exceptions;
 
322
  DYNAMIC_ARRAY buffpek;
321
323
  MI_BIT_BUFF   bit_buff;               /* For parallel repair of packrec. */
322
324
 
323
325
  /*
327
329
  uint64_t unique[MI_MAX_KEY_SEG+1];
328
330
  uint64_t notnull[MI_MAX_KEY_SEG+1];
329
331
 
330
 
  drizzled::internal::my_off_t pos,max_pos,filepos,start_recpos;
 
332
  my_off_t pos,max_pos,filepos,start_recpos;
331
333
  uint32_t key, key_length,real_key_length,sortbuff_size;
332
334
  uint32_t maxbuffers, keys, find_length, sort_keys_length;
333
335
  bool fix_datafile, master;
338
340
  unsigned char **sort_keys;
339
341
  unsigned char *rec_buff;
340
342
  void *wordlist, *wordptr;
341
 
  drizzled::memory::Root wordroot;
 
343
  MEM_ROOT wordroot;
342
344
  unsigned char *record;
343
345
  int (*key_cmp)(struct st_mi_sort_param *, const void *, const void *);
344
346
  int (*key_read)(struct st_mi_sort_param *,void *);
345
347
  int (*key_write)(struct st_mi_sort_param *, const void *);
346
348
  void (*lock_in_memory)(MI_CHECK *);
347
349
  int (*write_keys)(struct st_mi_sort_param *, register unsigned char **,
348
 
                     uint32_t , struct st_buffpek *, drizzled::internal::IO_CACHE *);
349
 
  unsigned int (*read_to_buffer)(drizzled::internal::IO_CACHE *,struct st_buffpek *, uint);
350
 
  int (*write_key)(struct st_mi_sort_param *, drizzled::internal::IO_CACHE *,unsigned char *,
 
350
                     uint32_t , struct st_buffpek *, IO_CACHE *);
 
351
  unsigned int (*read_to_buffer)(IO_CACHE *,struct st_buffpek *, uint);
 
352
  int (*write_key)(struct st_mi_sort_param *, IO_CACHE *,unsigned char *,
351
353
                       uint, uint);
352
354
} MI_SORT_PARAM;
353
355
 
463
465
 
464
466
        /* Some extern variables */
465
467
 
466
 
extern std::list<MI_INFO *> myisam_open_list;
 
468
extern LIST *myisam_open_list;
467
469
extern unsigned char  myisam_file_magic[], myisam_pack_file_magic[];
468
470
extern uint32_t  myisam_read_vec[], myisam_readnext_vec[];
469
471
extern uint32_t myisam_quick_table_bits;
484
486
 
485
487
        /* Prototypes for intern functions */
486
488
 
487
 
extern int _mi_read_dynamic_record(MI_INFO *info,drizzled::internal::my_off_t filepos,unsigned char *buf);
 
489
extern int _mi_read_dynamic_record(MI_INFO *info,my_off_t filepos,unsigned char *buf);
488
490
extern int _mi_write_dynamic_record(MI_INFO*, const unsigned char*);
489
 
extern int _mi_update_dynamic_record(MI_INFO*, drizzled::internal::my_off_t, const unsigned char*);
 
491
extern int _mi_update_dynamic_record(MI_INFO*, my_off_t, const unsigned char*);
490
492
extern int _mi_delete_dynamic_record(MI_INFO *info);
491
493
extern int _mi_cmp_dynamic_record(MI_INFO *info,const unsigned char *record);
492
 
extern int _mi_read_rnd_dynamic_record(MI_INFO *, unsigned char *,drizzled::internal::my_off_t, bool);
 
494
extern int _mi_read_rnd_dynamic_record(MI_INFO *, unsigned char *,my_off_t, bool);
493
495
extern int _mi_write_blob_record(MI_INFO*, const unsigned char*);
494
 
extern int _mi_update_blob_record(MI_INFO*, drizzled::internal::my_off_t, const unsigned char*);
495
 
extern int _mi_read_static_record(MI_INFO *info, drizzled::internal::my_off_t filepos,unsigned char *buf);
 
496
extern int _mi_update_blob_record(MI_INFO*, my_off_t, const unsigned char*);
 
497
extern int _mi_read_static_record(MI_INFO *info, my_off_t filepos,unsigned char *buf);
496
498
extern int _mi_write_static_record(MI_INFO*, const unsigned char*);
497
 
extern int _mi_update_static_record(MI_INFO*, drizzled::internal::my_off_t, const unsigned char*);
 
499
extern int _mi_update_static_record(MI_INFO*, my_off_t, const unsigned char*);
498
500
extern int _mi_delete_static_record(MI_INFO *info);
499
501
extern int _mi_cmp_static_record(MI_INFO *info,const unsigned char *record);
500
 
extern int _mi_read_rnd_static_record(MI_INFO*, unsigned char *,drizzled::internal::my_off_t, bool);
 
502
extern int _mi_read_rnd_static_record(MI_INFO*, unsigned char *,my_off_t, bool);
501
503
extern int _mi_ck_write(MI_INFO *info,uint32_t keynr,unsigned char *key,uint32_t length);
502
504
extern int _mi_ck_real_write_btree(MI_INFO *info, MI_KEYDEF *keyinfo,
503
505
                                   unsigned char *key, uint32_t key_length,
504
 
                                   drizzled::internal::my_off_t *root, uint32_t comp_flag);
505
 
extern int _mi_enlarge_root(MI_INFO *info,MI_KEYDEF *keyinfo,unsigned char *key, drizzled::internal::my_off_t *root);
 
506
                                   my_off_t *root, uint32_t comp_flag);
 
507
extern int _mi_enlarge_root(MI_INFO *info,MI_KEYDEF *keyinfo,unsigned char *key, my_off_t *root);
506
508
extern int _mi_insert(MI_INFO *info,MI_KEYDEF *keyinfo,unsigned char *key,
507
509
                      unsigned char *anc_buff,unsigned char *key_pos,unsigned char *key_buff,
508
510
                      unsigned char *father_buff, unsigned char *father_keypos,
509
 
                      drizzled::internal::my_off_t father_page, bool insert_last);
 
511
                      my_off_t father_page, bool insert_last);
510
512
extern int _mi_split_page(MI_INFO *info,MI_KEYDEF *keyinfo,unsigned char *key,
511
513
                          unsigned char *buff,unsigned char *key_buff, bool insert_last);
512
514
extern unsigned char *_mi_find_half_pos(uint32_t nod_flag,MI_KEYDEF *keyinfo,unsigned char *page,
547
549
extern int _mi_decrement_open_count(MI_INFO *info);
548
550
extern int _mi_check_index(MI_INFO *info,int inx);
549
551
extern int _mi_search(MI_INFO *info,MI_KEYDEF *keyinfo,unsigned char *key,uint32_t key_len,
550
 
                      uint32_t nextflag,drizzled::internal::my_off_t pos);
 
552
                      uint32_t nextflag,my_off_t pos);
551
553
extern int _mi_bin_search(struct st_myisam_info *info,MI_KEYDEF *keyinfo,
552
554
                          unsigned char *page,unsigned char *key,uint32_t key_len,uint32_t comp_flag,
553
555
                          unsigned char * *ret_pos,unsigned char *buff, bool *was_last_key);
557
559
extern int _mi_prefix_search(MI_INFO *info,MI_KEYDEF *keyinfo,unsigned char *page,
558
560
                          unsigned char *key,uint32_t key_len,uint32_t comp_flag,
559
561
                          unsigned char **ret_pos,unsigned char *buff, bool *was_last_key);
560
 
extern drizzled::internal::my_off_t _mi_kpos(uint32_t nod_flag,unsigned char *after_key);
561
 
extern void _mi_kpointer(MI_INFO *info,unsigned char *buff,drizzled::internal::my_off_t pos);
562
 
extern drizzled::internal::my_off_t _mi_dpos(MI_INFO *info, uint32_t nod_flag,unsigned char *after_key);
563
 
extern drizzled::internal::my_off_t _mi_rec_pos(MYISAM_SHARE *info, unsigned char *ptr);
564
 
void _mi_dpointer(MI_INFO *info, unsigned char *buff,drizzled::internal::my_off_t pos);
 
562
extern my_off_t _mi_kpos(uint32_t nod_flag,unsigned char *after_key);
 
563
extern void _mi_kpointer(MI_INFO *info,unsigned char *buff,my_off_t pos);
 
564
extern my_off_t _mi_dpos(MI_INFO *info, uint32_t nod_flag,unsigned char *after_key);
 
565
extern my_off_t _mi_rec_pos(MYISAM_SHARE *info, unsigned char *ptr);
 
566
void _mi_dpointer(MI_INFO *info, unsigned char *buff,my_off_t pos);
565
567
extern uint32_t _mi_get_static_key(MI_KEYDEF *keyinfo,uint32_t nod_flag,unsigned char * *page,
566
568
                               unsigned char *key);
567
569
extern uint32_t _mi_get_pack_key(MI_KEYDEF *keyinfo,uint32_t nod_flag,unsigned char * *page,
578
580
                               HA_KEYSEG *end);
579
581
extern unsigned char *_mi_move_key(MI_KEYDEF *keyinfo,unsigned char *to,unsigned char *from);
580
582
extern int _mi_search_next(MI_INFO *info,MI_KEYDEF *keyinfo,unsigned char *key,
581
 
                           uint32_t key_length,uint32_t nextflag,drizzled::internal::my_off_t pos);
582
 
extern int _mi_search_first(MI_INFO *info,MI_KEYDEF *keyinfo,drizzled::internal::my_off_t pos);
583
 
extern int _mi_search_last(MI_INFO *info,MI_KEYDEF *keyinfo,drizzled::internal::my_off_t pos);
584
 
extern unsigned char *_mi_fetch_keypage(MI_INFO *info,MI_KEYDEF *keyinfo,drizzled::internal::my_off_t page,
 
583
                           uint32_t key_length,uint32_t nextflag,my_off_t pos);
 
584
extern int _mi_search_first(MI_INFO *info,MI_KEYDEF *keyinfo,my_off_t pos);
 
585
extern int _mi_search_last(MI_INFO *info,MI_KEYDEF *keyinfo,my_off_t pos);
 
586
extern unsigned char *_mi_fetch_keypage(MI_INFO *info,MI_KEYDEF *keyinfo,my_off_t page,
585
587
                                int level,unsigned char *buff,int return_buffer);
586
 
extern int _mi_write_keypage(MI_INFO *info,MI_KEYDEF *keyinfo,drizzled::internal::my_off_t page,
 
588
extern int _mi_write_keypage(MI_INFO *info,MI_KEYDEF *keyinfo,my_off_t page,
587
589
                             int level, unsigned char *buff);
588
 
extern int _mi_dispose(MI_INFO *info,MI_KEYDEF *keyinfo,drizzled::internal::my_off_t pos,
 
590
extern int _mi_dispose(MI_INFO *info,MI_KEYDEF *keyinfo,my_off_t pos,
589
591
                      int level);
590
 
extern drizzled::internal::my_off_t _mi_new(MI_INFO *info,MI_KEYDEF *keyinfo,int level);
 
592
extern my_off_t _mi_new(MI_INFO *info,MI_KEYDEF *keyinfo,int level);
591
593
extern uint32_t _mi_make_key(MI_INFO *info,uint32_t keynr,unsigned char *key,
592
 
                         const unsigned char *record,drizzled::internal::my_off_t filepos);
 
594
                         const unsigned char *record,my_off_t filepos);
593
595
extern uint32_t _mi_pack_key(register MI_INFO *info, uint32_t keynr, unsigned char *key,
594
 
                         unsigned char *old, drizzled::key_part_map keypart_map,
 
596
                         unsigned char *old, key_part_map keypart_map,
595
597
                         HA_KEYSEG **last_used_keyseg);
596
 
extern int _mi_read_key_record(MI_INFO *info,drizzled::internal::my_off_t filepos,unsigned char *buf);
597
 
extern int _mi_read_cache(drizzled::internal::IO_CACHE *info,unsigned char *buff,drizzled::internal::my_off_t pos,
 
598
extern int _mi_read_key_record(MI_INFO *info,my_off_t filepos,unsigned char *buf);
 
599
extern int _mi_read_cache(IO_CACHE *info,unsigned char *buff,my_off_t pos,
598
600
                          uint32_t length,int re_read_if_possibly);
599
601
extern uint64_t retrieve_auto_increment(MI_INFO *info,const unsigned char *record);
600
602
 
609
611
                            ulong reclength);
610
612
extern bool _mi_rec_check(MI_INFO *info,const unsigned char *record, unsigned char *packpos,
611
613
                             ulong packed_length, bool with_checkum);
612
 
extern int _mi_write_part_record(MI_INFO *info,drizzled::internal::my_off_t filepos,ulong length,
613
 
                                 drizzled::internal::my_off_t next_filepos,unsigned char **record,
 
614
extern int _mi_write_part_record(MI_INFO *info,my_off_t filepos,ulong length,
 
615
                                 my_off_t next_filepos,unsigned char **record,
614
616
                                 ulong *reclength,int *flag);
615
617
extern void _mi_print_key(FILE *stream,HA_KEYSEG *keyseg,const unsigned char *key,
616
618
                          uint32_t length);
617
619
extern bool _mi_read_pack_info(MI_INFO *info,bool fix_keys);
618
 
extern int _mi_read_pack_record(MI_INFO *info,drizzled::internal::my_off_t filepos,unsigned char *buf);
619
 
extern int _mi_read_rnd_pack_record(MI_INFO*, unsigned char *,drizzled::internal::my_off_t, bool);
 
620
extern int _mi_read_pack_record(MI_INFO *info,my_off_t filepos,unsigned char *buf);
 
621
extern int _mi_read_rnd_pack_record(MI_INFO*, unsigned char *,my_off_t, bool);
620
622
extern int _mi_pack_rec_unpack(MI_INFO *info, MI_BIT_BUFF *bit_buff,
621
623
                               unsigned char *to, unsigned char *from, ulong reclength);
 
624
extern uint64_t mi_safe_mul(uint64_t a,uint64_t b);
622
625
 
623
626
struct st_sort_info;
624
627
 
629
632
  ulong data_len;
630
633
  ulong block_len;
631
634
  ulong blob_len;
632
 
  drizzled::internal::my_off_t filepos;
633
 
  drizzled::internal::my_off_t next_filepos;
634
 
  drizzled::internal::my_off_t prev_filepos;
 
635
  my_off_t filepos;
 
636
  my_off_t next_filepos;
 
637
  my_off_t prev_filepos;
635
638
  uint32_t second_read;
636
639
  uint32_t offset;
637
640
} MI_BLOCK_INFO;
648
651
#define NEED_MEM        ((uint) 10*4*(IO_SIZE+32)+32) /* Nead for recursion */
649
652
#define MAXERR                  20
650
653
#define BUFFERS_WHEN_SORTING    16              /* Alloc for sort-key-tree */
651
 
#define WRITE_COUNT             1000
 
654
#define WRITE_COUNT             MY_HOW_OFTEN_TO_WRITE
652
655
#define INDEX_TMP_EXT           ".TMM"
653
656
#define DATA_TMP_EXT            ".TMD"
654
657
 
666
669
#define fast_mi_writeinfo(INFO) if (!(INFO)->s->tot_locks) (void) _mi_writeinfo((INFO),0)
667
670
#define fast_mi_readinfo(INFO) ((INFO)->lock_type == F_UNLCK) && _mi_readinfo((INFO),F_RDLCK,1)
668
671
 
669
 
extern uint32_t _mi_get_block_info(MI_BLOCK_INFO *,int, drizzled::internal::my_off_t);
 
672
extern uint32_t _mi_get_block_info(MI_BLOCK_INFO *,File, my_off_t);
670
673
extern uint32_t _mi_rec_pack(MI_INFO *info,unsigned char *to,const unsigned char *from);
671
674
extern uint32_t _mi_pack_get_block_info(MI_INFO *myisam, MI_BIT_BUFF *bit_buff,
672
675
                                    MI_BLOCK_INFO *info, unsigned char **rec_buff_p,
673
 
                                    int file, drizzled::internal::my_off_t filepos);
 
676
                                    File file, my_off_t filepos);
674
677
extern void _my_store_blob_length(unsigned char *pos,uint32_t pack_length,uint32_t length);
675
678
extern void mi_report_error(int errcode, const char *file_name);
676
679
extern size_t mi_mmap_pread(MI_INFO *info, unsigned char *Buffer,
677
 
                            size_t Count, drizzled::internal::my_off_t offset, drizzled::myf MyFlags);
 
680
                            size_t Count, my_off_t offset, myf MyFlags);
678
681
extern size_t mi_mmap_pwrite(MI_INFO *info, const unsigned char *Buffer,
679
 
                             size_t Count, drizzled::internal::my_off_t offset, drizzled::myf MyFlags);
 
682
                             size_t Count, my_off_t offset, myf MyFlags);
680
683
extern size_t mi_nommap_pread(MI_INFO *info, unsigned char *Buffer,
681
 
                              size_t Count, drizzled::internal::my_off_t offset, drizzled::myf MyFlags);
 
684
                              size_t Count, my_off_t offset, myf MyFlags);
682
685
extern size_t mi_nommap_pwrite(MI_INFO *info, const unsigned char *Buffer,
683
 
                               size_t Count, drizzled::internal::my_off_t offset, drizzled::myf MyFlags);
 
686
                               size_t Count, my_off_t offset, myf MyFlags);
684
687
 
685
 
uint32_t mi_state_info_write(int file, MI_STATE_INFO *state, uint32_t pWrite);
686
 
uint32_t mi_state_info_read_dsk(int file, MI_STATE_INFO *state, bool pRead);
687
 
uint32_t mi_base_info_write(int file, MI_BASE_INFO *base);
688
 
int mi_keyseg_write(int file, const HA_KEYSEG *keyseg);
689
 
uint32_t mi_keydef_write(int file, MI_KEYDEF *keydef);
690
 
uint32_t mi_uniquedef_write(int file, MI_UNIQUEDEF *keydef);
691
 
uint32_t mi_recinfo_write(int file, drizzled::MI_COLUMNDEF *recinfo);
 
688
uint32_t mi_state_info_write(File file, MI_STATE_INFO *state, uint32_t pWrite);
 
689
unsigned char *mi_state_info_read(unsigned char *ptr, MI_STATE_INFO *state);
 
690
uint32_t mi_state_info_read_dsk(File file, MI_STATE_INFO *state, bool pRead);
 
691
uint32_t mi_base_info_write(File file, MI_BASE_INFO *base);
 
692
unsigned char *my_n_base_info_read(unsigned char *ptr, MI_BASE_INFO *base);
 
693
int mi_keyseg_write(File file, const HA_KEYSEG *keyseg);
 
694
unsigned char *mi_keyseg_read(unsigned char *ptr, HA_KEYSEG *keyseg);
 
695
uint32_t mi_keydef_write(File file, MI_KEYDEF *keydef);
 
696
unsigned char *mi_keydef_read(unsigned char *ptr, MI_KEYDEF *keydef);
 
697
uint32_t mi_uniquedef_write(File file, MI_UNIQUEDEF *keydef);
 
698
unsigned char *mi_uniquedef_read(unsigned char *ptr, MI_UNIQUEDEF *keydef);
 
699
uint32_t mi_recinfo_write(File file, MI_COLUMNDEF *recinfo);
 
700
unsigned char *mi_recinfo_read(unsigned char *ptr, MI_COLUMNDEF *recinfo);
692
701
extern int mi_disable_indexes(MI_INFO *info);
693
702
extern int mi_enable_indexes(MI_INFO *info);
694
703
extern int mi_indexes_are_disabled(MI_INFO *info);
695
704
ulong _my_calc_total_blob_length(MI_INFO *info, const unsigned char *record);
696
 
drizzled::internal::ha_checksum mi_checksum(MI_INFO *info, const unsigned char *buf);
697
 
drizzled::internal::ha_checksum mi_static_checksum(MI_INFO *info, const unsigned char *buf);
 
705
ha_checksum mi_checksum(MI_INFO *info, const unsigned char *buf);
 
706
ha_checksum mi_static_checksum(MI_INFO *info, const unsigned char *buf);
698
707
bool mi_check_unique(MI_INFO *info, MI_UNIQUEDEF *def, unsigned char *record,
699
 
                     drizzled::internal::ha_checksum unique_hash, drizzled::internal::my_off_t pos);
700
 
drizzled::internal::ha_checksum mi_unique_hash(MI_UNIQUEDEF *def, const unsigned char *buf);
 
708
                     ha_checksum unique_hash, my_off_t pos);
 
709
ha_checksum mi_unique_hash(MI_UNIQUEDEF *def, const unsigned char *buf);
701
710
int _mi_cmp_static_unique(MI_INFO *info, MI_UNIQUEDEF *def,
702
 
                           const unsigned char *record, drizzled::internal::my_off_t pos);
 
711
                           const unsigned char *record, my_off_t pos);
703
712
int _mi_cmp_dynamic_unique(MI_INFO *info, MI_UNIQUEDEF *def,
704
 
                           const unsigned char *record, drizzled::internal::my_off_t pos);
 
713
                           const unsigned char *record, my_off_t pos);
705
714
int mi_unique_comp(MI_UNIQUEDEF *def, const unsigned char *a, const unsigned char *b,
706
715
                   bool null_are_equal);
707
716
void mi_get_status(void* param, int concurrent_insert);
712
721
 
713
722
extern MI_INFO *test_if_reopen(char *filename);
714
723
bool check_table_is_closed(const char *name, const char *where);
715
 
int mi_open_datafile(MI_INFO *info, MYISAM_SHARE *share, int file_to_dup);
 
724
int mi_open_datafile(MI_INFO *info, MYISAM_SHARE *share, File file_to_dup);
716
725
int mi_open_keyfile(MYISAM_SHARE *share);
717
726
void mi_setup_functions(register MYISAM_SHARE *share);
718
 
bool mi_dynmap_file(MI_INFO *info, drizzled::internal::my_off_t size);
719
 
void mi_remap_file(MI_INFO *info, drizzled::internal::my_off_t size);
 
727
bool mi_dynmap_file(MI_INFO *info, my_off_t size);
 
728
void mi_remap_file(MI_INFO *info, my_off_t size);
720
729
 
721
730
int mi_check_index_cond(register MI_INFO *info, uint32_t keynr, unsigned char *record);
722
731
 
727
736
void mi_check_print_info(MI_CHECK *param, const char *fmt,...);
728
737
int flush_pending_blocks(MI_SORT_PARAM *param);
729
738
int thr_write_keys(MI_SORT_PARAM *sort_param);
730
 
/* needs extern "C" because we pass it to pthread_create */
731
 
extern "C" pthread_handler_t thr_find_all_keys(void *arg);
732
 
int flush_blocks(MI_CHECK *param, drizzled::KEY_CACHE *key_cache, int file);
 
739
pthread_handler_t thr_find_all_keys(void *arg);
 
740
int flush_blocks(MI_CHECK *param, KEY_CACHE *key_cache, File file);
733
741
 
734
742
int sort_write_record(MI_SORT_PARAM *sort_param);
735
743
int _create_index_by_sort(MI_SORT_PARAM *info,bool no_messages, size_t);
737
745
extern void mi_set_index_cond_func(MI_INFO *info, index_cond_func_t func,
738
746
                                   void *func_arg);
739
747
/* Just for myisam legacy */
740
 
extern size_t my_pwrite(int Filedes,const unsigned char *Buffer,size_t Count,
741
 
                        drizzled::internal::my_off_t offset,drizzled::myf MyFlags);
742
 
extern size_t my_pread(int Filedes,unsigned char *Buffer,size_t Count,drizzled::internal::my_off_t offset,
743
 
                       drizzled::myf MyFlags);
 
748
extern size_t my_pwrite(File Filedes,const unsigned char *Buffer,size_t Count,
 
749
                      my_off_t offset,myf MyFlags);
 
750
extern size_t my_pread(File Filedes,unsigned char *Buffer,size_t Count,my_off_t offset,
 
751
                     myf MyFlags);
744
752
 
745
753
/* Needed for handler */
746
 
void mi_disable_non_unique_index(MI_INFO *info, drizzled::ha_rows rows);
747
 
void _mi_report_crashed(MI_INFO *file, const char *message, const char *sfile,
748
 
                        uint32_t sline);
749
 
 
750
 
#endif /* PLUGIN_MYISAM_MYISAM_PRIV_H */
 
754
void mi_disable_non_unique_index(MI_INFO *info, ha_rows rows);
 
755
void _mi_report_crashed(MI_INFO *file __attribute__((unused)),
 
756
                        const char *message __attribute__((unused)),
 
757
                        const char *sfile __attribute__((unused)),
 
758
                        uint32_t sline __attribute__((unused)));
 
759
 
 
760
#ifdef __cplusplus
 
761
}
 
762
#endif
 
763
 
 
764
 
 
765
#endif /* MYISAMDEF_H */