~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:
11
11
 
12
12
   You should have received a copy of the GNU General Public License
13
13
   along with this program; if not, write to the Free Software
14
 
   Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA */
 
14
   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
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
 
 
34
 
#include <boost/thread/mutex.hpp>
35
30
 
36
31
#if defined(my_write)
37
32
#undef my_write                         /* undef map from my_nosys; We need test-if-disk full */
38
33
#endif
39
34
 
40
 
/* Typical key cash */
41
 
static const uint32_t KEY_CACHE_SIZE= 8*1024*1024;
42
 
 
43
 
/* Default size of a key cache block  */
44
 
static const uint32_t KEY_CACHE_BLOCK_SIZE= 1024;
 
35
#ifdef  __cplusplus
 
36
extern "C" {
 
37
#endif
45
38
 
46
39
typedef struct st_mi_status_info
47
40
{
48
 
  drizzled::ha_rows records;                    /* Rows in table */
49
 
  drizzled::ha_rows del;                                /* Removed rows */
50
 
  drizzled::internal::my_off_t empty;                   /* lost space in datafile */
51
 
  drizzled::internal::my_off_t key_empty;                       /* lost space in indexfile */
52
 
  drizzled::internal::my_off_t key_file_length;
53
 
  drizzled::internal::my_off_t data_file_length;
54
 
  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;
55
48
} MI_STATUS_INFO;
56
49
 
57
50
typedef struct st_mi_state_info
74
67
  } header;
75
68
 
76
69
  MI_STATUS_INFO state;
77
 
  drizzled::ha_rows split;                      /* number of split blocks */
78
 
  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 */
79
72
  uint64_t auto_increment;
80
73
  ulong process;                        /* process that updated table last */
81
74
  ulong unique;                         /* Unique number for this process */
82
75
  ulong update_count;                   /* Updated for each write lock */
83
76
  ulong status;
84
77
  ulong *rec_per_key_part;
85
 
  drizzled::internal::my_off_t *key_root;                       /* Start of key trees */
86
 
  drizzled::internal::my_off_t *key_del;                        /* delete links for trees */
87
 
  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 */
88
81
 
89
82
  ulong sec_index_changed;              /* Updated when new sec_index */
90
83
  ulong sec_index_used;                 /* which extra index are in use */
91
84
  uint64_t key_map;                     /* Which keys are in use */
92
 
  drizzled::internal::ha_checksum checksum;                 /* Table checksum */
 
85
  ha_checksum checksum;                 /* Table checksum */
93
86
  ulong version;                        /* timestamp of create */
94
87
  time_t create_time;                   /* Time when created database */
95
88
  time_t recover_time;                  /* Time for last recover */
118
111
 
119
112
typedef struct st_mi_base_info
120
113
{
121
 
  drizzled::internal::my_off_t keystart;                        /* Start of keys */
122
 
  drizzled::internal::my_off_t max_data_file_length;
123
 
  drizzled::internal::my_off_t max_key_file_length;
124
 
  drizzled::internal::my_off_t margin_key_file_length;
125
 
  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 */
126
119
  ulong mean_row_length;                /* Create information */
127
120
  ulong reclength;                      /* length of unpacked record */
128
121
  ulong pack_reclength;                 /* Length of full packed rec. */
168
161
 
169
162
#define MAX_NONMAPPED_INSERTS 1000
170
163
 
171
 
namespace drizzled { class Session; }
172
 
 
173
164
typedef struct st_mi_isam_share {       /* Shared between opens */
174
165
  MI_STATE_INFO state;
175
166
  MI_BASE_INFO base;
177
168
  MI_KEYDEF  *keyinfo;                  /* Key definitions */
178
169
  MI_UNIQUEDEF *uniqueinfo;             /* unique definitions */
179
170
  HA_KEYSEG *keyparts;                  /* key part info */
180
 
  drizzled::MI_COLUMNDEF *rec;                  /* Pointer to field information */
 
171
  MI_COLUMNDEF *rec;                    /* Pointer to field information */
181
172
  MI_PACK    pack;                      /* Data about packed records */
182
173
  MI_BLOB    *blobs;                    /* Pointer to blobs */
183
 
  std::list<drizzled::Session *> *in_use;         /* List of threads using this table */
 
174
  LIST *in_use;                         /* List of threads using this table */
184
175
  char  *unique_file_name;              /* realpath() of index file */
185
176
  char  *data_file_name,                /* Resolved path names from symlinks */
186
177
        *index_file_name;
187
178
  unsigned char *file_map;                      /* mem-map of file if possible */
188
 
private:
189
 
  drizzled::KEY_CACHE key_cache;                        /* ref to the current key cache */
190
 
public:
191
 
  drizzled::KEY_CACHE *getKeyCache()
192
 
  {
193
 
    return &key_cache;
194
 
  }
195
 
 
196
 
  void setKeyCache();
197
 
 
 
179
  KEY_CACHE *key_cache;                 /* ref to the current key cache */
198
180
  MI_DECODE_TREE *decode_trees;
199
181
  uint16_t *decode_tables;
200
 
  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*);
201
183
  int (*write_record)(struct st_myisam_info*, const unsigned char*);
202
 
  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*);
203
185
  int (*delete_record)(struct st_myisam_info*);
204
 
  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);
205
187
  int (*compare_record)(struct st_myisam_info*, const unsigned char *);
206
188
  /* Function to use for a row checksum. */
207
 
  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 *);
208
190
  int (*compare_unique)(struct st_myisam_info*, MI_UNIQUEDEF *,
209
 
                        const unsigned char *record, drizzled::internal::my_off_t pos);
210
 
  size_t (*file_read)(MI_INFO *, unsigned char *, size_t, drizzled::internal::my_off_t, drizzled::myf);
211
 
  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 */
212
195
  ulong this_process;                   /* processid */
213
196
  ulong last_process;                   /* For table-change-check */
214
197
  ulong last_version;                   /* Version on start */
215
 
  uint64_t options;                     /* Options used */
 
198
  ulong options;                        /* Options used */
216
199
  ulong min_pack_length;                /* Theese are used by packed data */
217
200
  ulong max_pack_length;
218
201
  ulong state_diff_length;
219
202
  uint  rec_reflength;                  /* rec_reflength in use now */
220
203
  uint32_t  unique_name_length;
221
 
  int   kfile;                          /* Shared keyfile */
222
 
  int   data_file;                      /* Shared data file */
 
204
  File  kfile;                          /* Shared keyfile */
 
205
  File  data_file;                      /* Shared data file */
223
206
  int   mode;                           /* mode of file on open */
224
207
  uint  reopen;                         /* How many times reopened */
225
208
  uint  w_locks,r_locks,tot_locks;      /* Number of read/write locks */
226
209
  uint  blocksize;                      /* blocksize of keyfile */
227
 
  drizzled::myf write_flag;
228
 
  enum drizzled::data_file_type data_file_type;
 
210
  myf write_flag;
 
211
  enum data_file_type data_file_type;
229
212
  /* Below flag is needed to make log tables work with concurrent insert */
230
213
  bool is_log_table;
231
214
 
234
217
    not_flushed,
235
218
    temporary,delay_key_write,
236
219
    concurrent_insert;
237
 
  drizzled::internal::my_off_t mmaped_length;
 
220
  THR_LOCK lock;
 
221
  pthread_mutex_t intern_lock;          /* Locking for use with _locking */
 
222
  pthread_rwlock_t *key_root_lock;
 
223
  my_off_t mmaped_length;
238
224
  uint32_t     nonmmaped_inserts;           /* counter of writing in non-mmaped
239
225
                                           area */
 
226
  pthread_rwlock_t mmap_lock;
240
227
} MYISAM_SHARE;
241
228
 
242
229
 
258
245
  MI_BLOB     *blobs;                   /* Pointer to blobs */
259
246
  MI_BIT_BUFF  bit_buff;
260
247
  /* accumulate indexfile changes between write's */
261
 
  drizzled::TREE                *bulk_insert;
262
 
  drizzled::Session *in_use;                      /* Thread using this table          */
 
248
  TREE          *bulk_insert;
 
249
  LIST in_use;                          /* Thread using this table          */
263
250
  char *filename;                       /* parameter to open filename       */
264
251
  unsigned char *buff,                          /* Temp area for key                */
265
252
        *lastkey,*lastkey2;             /* Last used search key             */
269
256
        *int_maxpos;                    /*  -""-  */
270
257
  uint32_t  int_nod_flag;                       /*  -""-  */
271
258
  uint32_t int_keytree_version;         /*  -""-  */
272
 
  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 */
273
261
  ulong this_unique;                    /* uniq filenumber or thread */
274
262
  ulong last_unique;                    /* last unique number */
275
263
  ulong this_loop;                      /* counter for this open */
276
264
  ulong last_loop;                      /* last used counter */
277
 
  drizzled::internal::my_off_t lastpos,                 /* Last record position */
 
265
  my_off_t lastpos,                     /* Last record position */
278
266
        nextpos;                        /* Position to next record */
279
 
  drizzled::internal::my_off_t save_lastpos;
280
 
  drizzled::internal::my_off_t pos;                             /* Intern variable */
281
 
  drizzled::internal::my_off_t last_keypage;            /* Last key page read */
282
 
  drizzled::internal::my_off_t last_search_keypage;             /* Last keypage when searching */
283
 
  drizzled::internal::my_off_t dupp_key_pos;
284
 
  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 */
285
273
  /* QQ: the folloing two xxx_length fields should be removed,
286
274
     as they are not compatible with parallel repair */
287
275
  ulong packed_length,blob_length;      /* Length of found, packed record */
291
279
  int   lastinx;                        /* Last used index */
292
280
  uint  lastkey_length;                 /* Length of key in lastkey */
293
281
  uint  last_rkey_length;               /* Last length in mi_rkey() */
294
 
  enum drizzled::ha_rkey_function last_key_func;  /* CONTAIN, OVERLAP, etc */
 
282
  enum ha_rkey_function last_key_func;  /* CONTAIN, OVERLAP, etc */
295
283
  uint32_t  save_lastkey_length;
296
284
  uint32_t  pack_key_length;                /* For MYISAMMRG */
297
285
  uint16_t last_used_keyseg;              /* For MyISAMMRG */
301
289
  uint  data_changed;                   /* Somebody has changed data */
302
290
  uint  save_update;                    /* When using KEY_READ */
303
291
  int   save_lastinx;
304
 
  drizzled::internal::IO_CACHE rec_cache;                       /* When cacheing records */
 
292
  LIST  open_list;
 
293
  IO_CACHE rec_cache;                   /* When cacheing records */
305
294
  uint32_t  preload_buff_size;              /* When preloading indexes */
306
 
  drizzled::myf lock_wait;                      /* is 0 or MY_DONT_WAIT */
 
295
  myf lock_wait;                        /* is 0 or MY_DONT_WAIT */
307
296
  bool was_locked;                      /* Was locked in panic */
308
297
  bool append_insert_at_end;            /* Set if concurrent insert */
309
298
  bool quick_mode;
313
302
 
314
303
  index_cond_func_t index_cond_func;   /* Index condition function */
315
304
  void *index_cond_func_arg;           /* parameter for the func */
316
 
  drizzled::THR_LOCK_DATA lock;
 
305
  THR_LOCK_DATA lock;
317
306
  unsigned char  *rtree_recursion_state;        /* For RTREE */
318
307
  int     rtree_recursion_depth;
319
308
};
320
309
 
321
310
typedef struct st_buffpek {
322
 
  off_t file_pos;                    /* Where we are in the sort file */
 
311
  my_off_t file_pos;                    /* Where we are in the sort file */
323
312
  unsigned char *base,*key;                     /* Key pointers */
324
 
  drizzled::ha_rows count;                        /* Number of rows in table */
 
313
  ha_rows count;                        /* Number of rows in table */
325
314
  ulong mem_count;                      /* numbers of keys in memory */
326
315
  ulong max_keys;                       /* Max keys in buffert */
327
316
} BUFFPEK;
329
318
typedef struct st_mi_sort_param
330
319
{
331
320
  pthread_t  thr;
332
 
  drizzled::internal::IO_CACHE read_cache, tempfile, tempfile_for_exceptions;
333
 
  drizzled::DYNAMIC_ARRAY buffpek;
 
321
  IO_CACHE read_cache, tempfile, tempfile_for_exceptions;
 
322
  DYNAMIC_ARRAY buffpek;
334
323
  MI_BIT_BUFF   bit_buff;               /* For parallel repair of packrec. */
335
324
 
336
325
  /*
340
329
  uint64_t unique[MI_MAX_KEY_SEG+1];
341
330
  uint64_t notnull[MI_MAX_KEY_SEG+1];
342
331
 
343
 
  drizzled::internal::my_off_t pos,max_pos,filepos,start_recpos;
 
332
  my_off_t pos,max_pos,filepos,start_recpos;
344
333
  uint32_t key, key_length,real_key_length,sortbuff_size;
345
334
  uint32_t maxbuffers, keys, find_length, sort_keys_length;
346
335
  bool fix_datafile, master;
351
340
  unsigned char **sort_keys;
352
341
  unsigned char *rec_buff;
353
342
  void *wordlist, *wordptr;
354
 
  drizzled::memory::Root wordroot;
 
343
  MEM_ROOT wordroot;
355
344
  unsigned char *record;
356
345
  int (*key_cmp)(struct st_mi_sort_param *, const void *, const void *);
357
346
  int (*key_read)(struct st_mi_sort_param *,void *);
358
347
  int (*key_write)(struct st_mi_sort_param *, const void *);
359
348
  void (*lock_in_memory)(MI_CHECK *);
360
349
  int (*write_keys)(struct st_mi_sort_param *, register unsigned char **,
361
 
                     uint32_t , struct st_buffpek *, drizzled::internal::IO_CACHE *);
362
 
  unsigned int (*read_to_buffer)(drizzled::internal::IO_CACHE *,struct st_buffpek *, uint);
363
 
  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 *,
364
353
                       uint, uint);
365
354
} MI_SORT_PARAM;
366
355
 
472
461
#define MI_UNIQUE_HASH_TYPE     HA_KEYTYPE_ULONG_INT
473
462
#define mi_unique_store(A,B)    mi_int4store((A),(B))
474
463
 
475
 
extern boost::mutex THR_LOCK_myisam;
 
464
extern pthread_mutex_t THR_LOCK_myisam;
476
465
 
477
466
        /* Some extern variables */
478
467
 
479
 
extern std::list<MI_INFO *> myisam_open_list;
 
468
extern LIST *myisam_open_list;
480
469
extern unsigned char  myisam_file_magic[], myisam_pack_file_magic[];
481
470
extern uint32_t  myisam_read_vec[], myisam_readnext_vec[];
482
471
extern uint32_t myisam_quick_table_bits;
497
486
 
498
487
        /* Prototypes for intern functions */
499
488
 
500
 
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);
501
490
extern int _mi_write_dynamic_record(MI_INFO*, const unsigned char*);
502
 
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*);
503
492
extern int _mi_delete_dynamic_record(MI_INFO *info);
504
493
extern int _mi_cmp_dynamic_record(MI_INFO *info,const unsigned char *record);
505
 
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);
506
495
extern int _mi_write_blob_record(MI_INFO*, const unsigned char*);
507
 
extern int _mi_update_blob_record(MI_INFO*, drizzled::internal::my_off_t, const unsigned char*);
508
 
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);
509
498
extern int _mi_write_static_record(MI_INFO*, const unsigned char*);
510
 
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*);
511
500
extern int _mi_delete_static_record(MI_INFO *info);
512
501
extern int _mi_cmp_static_record(MI_INFO *info,const unsigned char *record);
513
 
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);
514
503
extern int _mi_ck_write(MI_INFO *info,uint32_t keynr,unsigned char *key,uint32_t length);
515
504
extern int _mi_ck_real_write_btree(MI_INFO *info, MI_KEYDEF *keyinfo,
516
505
                                   unsigned char *key, uint32_t key_length,
517
 
                                   drizzled::internal::my_off_t *root, uint32_t comp_flag);
518
 
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);
519
508
extern int _mi_insert(MI_INFO *info,MI_KEYDEF *keyinfo,unsigned char *key,
520
509
                      unsigned char *anc_buff,unsigned char *key_pos,unsigned char *key_buff,
521
510
                      unsigned char *father_buff, unsigned char *father_keypos,
522
 
                      drizzled::internal::my_off_t father_page, bool insert_last);
 
511
                      my_off_t father_page, bool insert_last);
523
512
extern int _mi_split_page(MI_INFO *info,MI_KEYDEF *keyinfo,unsigned char *key,
524
513
                          unsigned char *buff,unsigned char *key_buff, bool insert_last);
525
514
extern unsigned char *_mi_find_half_pos(uint32_t nod_flag,MI_KEYDEF *keyinfo,unsigned char *page,
560
549
extern int _mi_decrement_open_count(MI_INFO *info);
561
550
extern int _mi_check_index(MI_INFO *info,int inx);
562
551
extern int _mi_search(MI_INFO *info,MI_KEYDEF *keyinfo,unsigned char *key,uint32_t key_len,
563
 
                      uint32_t nextflag,drizzled::internal::my_off_t pos);
 
552
                      uint32_t nextflag,my_off_t pos);
564
553
extern int _mi_bin_search(struct st_myisam_info *info,MI_KEYDEF *keyinfo,
565
554
                          unsigned char *page,unsigned char *key,uint32_t key_len,uint32_t comp_flag,
566
555
                          unsigned char * *ret_pos,unsigned char *buff, bool *was_last_key);
570
559
extern int _mi_prefix_search(MI_INFO *info,MI_KEYDEF *keyinfo,unsigned char *page,
571
560
                          unsigned char *key,uint32_t key_len,uint32_t comp_flag,
572
561
                          unsigned char **ret_pos,unsigned char *buff, bool *was_last_key);
573
 
extern drizzled::internal::my_off_t _mi_kpos(uint32_t nod_flag,unsigned char *after_key);
574
 
extern void _mi_kpointer(MI_INFO *info,unsigned char *buff,drizzled::internal::my_off_t pos);
575
 
extern drizzled::internal::my_off_t _mi_dpos(MI_INFO *info, uint32_t nod_flag,unsigned char *after_key);
576
 
extern drizzled::internal::my_off_t _mi_rec_pos(MYISAM_SHARE *info, unsigned char *ptr);
577
 
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);
578
567
extern uint32_t _mi_get_static_key(MI_KEYDEF *keyinfo,uint32_t nod_flag,unsigned char * *page,
579
568
                               unsigned char *key);
580
569
extern uint32_t _mi_get_pack_key(MI_KEYDEF *keyinfo,uint32_t nod_flag,unsigned char * *page,
591
580
                               HA_KEYSEG *end);
592
581
extern unsigned char *_mi_move_key(MI_KEYDEF *keyinfo,unsigned char *to,unsigned char *from);
593
582
extern int _mi_search_next(MI_INFO *info,MI_KEYDEF *keyinfo,unsigned char *key,
594
 
                           uint32_t key_length,uint32_t nextflag,drizzled::internal::my_off_t pos);
595
 
extern int _mi_search_first(MI_INFO *info,MI_KEYDEF *keyinfo,drizzled::internal::my_off_t pos);
596
 
extern int _mi_search_last(MI_INFO *info,MI_KEYDEF *keyinfo,drizzled::internal::my_off_t pos);
597
 
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,
598
587
                                int level,unsigned char *buff,int return_buffer);
599
 
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,
600
589
                             int level, unsigned char *buff);
601
 
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,
602
591
                      int level);
603
 
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);
604
593
extern uint32_t _mi_make_key(MI_INFO *info,uint32_t keynr,unsigned char *key,
605
 
                         const unsigned char *record,drizzled::internal::my_off_t filepos);
 
594
                         const unsigned char *record,my_off_t filepos);
606
595
extern uint32_t _mi_pack_key(register MI_INFO *info, uint32_t keynr, unsigned char *key,
607
 
                         unsigned char *old, drizzled::key_part_map keypart_map,
 
596
                         unsigned char *old, key_part_map keypart_map,
608
597
                         HA_KEYSEG **last_used_keyseg);
609
 
extern int _mi_read_key_record(MI_INFO *info,drizzled::internal::my_off_t filepos,unsigned char *buf);
610
 
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,
611
600
                          uint32_t length,int re_read_if_possibly);
612
601
extern uint64_t retrieve_auto_increment(MI_INFO *info,const unsigned char *record);
613
602
 
622
611
                            ulong reclength);
623
612
extern bool _mi_rec_check(MI_INFO *info,const unsigned char *record, unsigned char *packpos,
624
613
                             ulong packed_length, bool with_checkum);
625
 
extern int _mi_write_part_record(MI_INFO *info,drizzled::internal::my_off_t filepos,ulong length,
626
 
                                 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,
627
616
                                 ulong *reclength,int *flag);
628
617
extern void _mi_print_key(FILE *stream,HA_KEYSEG *keyseg,const unsigned char *key,
629
618
                          uint32_t length);
630
619
extern bool _mi_read_pack_info(MI_INFO *info,bool fix_keys);
631
 
extern int _mi_read_pack_record(MI_INFO *info,drizzled::internal::my_off_t filepos,unsigned char *buf);
632
 
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);
633
622
extern int _mi_pack_rec_unpack(MI_INFO *info, MI_BIT_BUFF *bit_buff,
634
623
                               unsigned char *to, unsigned char *from, ulong reclength);
 
624
extern uint64_t mi_safe_mul(uint64_t a,uint64_t b);
635
625
 
636
626
struct st_sort_info;
637
627
 
642
632
  ulong data_len;
643
633
  ulong block_len;
644
634
  ulong blob_len;
645
 
  drizzled::internal::my_off_t filepos;
646
 
  drizzled::internal::my_off_t next_filepos;
647
 
  drizzled::internal::my_off_t prev_filepos;
 
635
  my_off_t filepos;
 
636
  my_off_t next_filepos;
 
637
  my_off_t prev_filepos;
648
638
  uint32_t second_read;
649
639
  uint32_t offset;
650
640
} MI_BLOCK_INFO;
661
651
#define NEED_MEM        ((uint) 10*4*(IO_SIZE+32)+32) /* Nead for recursion */
662
652
#define MAXERR                  20
663
653
#define BUFFERS_WHEN_SORTING    16              /* Alloc for sort-key-tree */
664
 
#define WRITE_COUNT             1000
 
654
#define WRITE_COUNT             MY_HOW_OFTEN_TO_WRITE
665
655
#define INDEX_TMP_EXT           ".TMM"
666
656
#define DATA_TMP_EXT            ".TMD"
667
657
 
679
669
#define fast_mi_writeinfo(INFO) if (!(INFO)->s->tot_locks) (void) _mi_writeinfo((INFO),0)
680
670
#define fast_mi_readinfo(INFO) ((INFO)->lock_type == F_UNLCK) && _mi_readinfo((INFO),F_RDLCK,1)
681
671
 
682
 
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);
683
673
extern uint32_t _mi_rec_pack(MI_INFO *info,unsigned char *to,const unsigned char *from);
684
674
extern uint32_t _mi_pack_get_block_info(MI_INFO *myisam, MI_BIT_BUFF *bit_buff,
685
675
                                    MI_BLOCK_INFO *info, unsigned char **rec_buff_p,
686
 
                                    int file, drizzled::internal::my_off_t filepos);
 
676
                                    File file, my_off_t filepos);
687
677
extern void _my_store_blob_length(unsigned char *pos,uint32_t pack_length,uint32_t length);
688
678
extern void mi_report_error(int errcode, const char *file_name);
689
679
extern size_t mi_mmap_pread(MI_INFO *info, unsigned char *Buffer,
690
 
                            size_t Count, drizzled::internal::my_off_t offset, drizzled::myf MyFlags);
 
680
                            size_t Count, my_off_t offset, myf MyFlags);
691
681
extern size_t mi_mmap_pwrite(MI_INFO *info, const unsigned char *Buffer,
692
 
                             size_t Count, drizzled::internal::my_off_t offset, drizzled::myf MyFlags);
 
682
                             size_t Count, my_off_t offset, myf MyFlags);
693
683
extern size_t mi_nommap_pread(MI_INFO *info, unsigned char *Buffer,
694
 
                              size_t Count, drizzled::internal::my_off_t offset, drizzled::myf MyFlags);
 
684
                              size_t Count, my_off_t offset, myf MyFlags);
695
685
extern size_t mi_nommap_pwrite(MI_INFO *info, const unsigned char *Buffer,
696
 
                               size_t Count, drizzled::internal::my_off_t offset, drizzled::myf MyFlags);
 
686
                               size_t Count, my_off_t offset, myf MyFlags);
697
687
 
698
 
uint32_t mi_state_info_write(int file, MI_STATE_INFO *state, uint32_t pWrite);
699
 
uint32_t mi_state_info_read_dsk(int file, MI_STATE_INFO *state, bool pRead);
700
 
uint32_t mi_base_info_write(int file, MI_BASE_INFO *base);
701
 
int mi_keyseg_write(int file, const HA_KEYSEG *keyseg);
702
 
uint32_t mi_keydef_write(int file, MI_KEYDEF *keydef);
703
 
uint32_t mi_uniquedef_write(int file, MI_UNIQUEDEF *keydef);
704
 
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);
705
701
extern int mi_disable_indexes(MI_INFO *info);
706
702
extern int mi_enable_indexes(MI_INFO *info);
707
703
extern int mi_indexes_are_disabled(MI_INFO *info);
708
704
ulong _my_calc_total_blob_length(MI_INFO *info, const unsigned char *record);
709
 
drizzled::internal::ha_checksum mi_checksum(MI_INFO *info, const unsigned char *buf);
710
 
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);
711
707
bool mi_check_unique(MI_INFO *info, MI_UNIQUEDEF *def, unsigned char *record,
712
 
                     drizzled::internal::ha_checksum unique_hash, drizzled::internal::my_off_t pos);
713
 
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);
714
710
int _mi_cmp_static_unique(MI_INFO *info, MI_UNIQUEDEF *def,
715
 
                           const unsigned char *record, drizzled::internal::my_off_t pos);
 
711
                           const unsigned char *record, my_off_t pos);
716
712
int _mi_cmp_dynamic_unique(MI_INFO *info, MI_UNIQUEDEF *def,
717
 
                           const unsigned char *record, drizzled::internal::my_off_t pos);
 
713
                           const unsigned char *record, my_off_t pos);
718
714
int mi_unique_comp(MI_UNIQUEDEF *def, const unsigned char *a, const unsigned char *b,
719
715
                   bool null_are_equal);
 
716
void mi_get_status(void* param, int concurrent_insert);
 
717
void mi_update_status(void* param);
 
718
void mi_restore_status(void* param);
 
719
void mi_copy_status(void* to,void *from);
 
720
bool mi_check_status(void* param);
720
721
 
721
722
extern MI_INFO *test_if_reopen(char *filename);
722
723
bool check_table_is_closed(const char *name, const char *where);
723
 
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);
724
725
int mi_open_keyfile(MYISAM_SHARE *share);
725
726
void mi_setup_functions(register MYISAM_SHARE *share);
726
 
bool mi_dynmap_file(MI_INFO *info, drizzled::internal::my_off_t size);
727
 
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);
728
729
 
729
730
int mi_check_index_cond(register MI_INFO *info, uint32_t keynr, unsigned char *record);
730
731
 
735
736
void mi_check_print_info(MI_CHECK *param, const char *fmt,...);
736
737
int flush_pending_blocks(MI_SORT_PARAM *param);
737
738
int thr_write_keys(MI_SORT_PARAM *sort_param);
738
 
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);
739
741
 
740
742
int sort_write_record(MI_SORT_PARAM *sort_param);
741
743
int _create_index_by_sort(MI_SORT_PARAM *info,bool no_messages, size_t);
743
745
extern void mi_set_index_cond_func(MI_INFO *info, index_cond_func_t func,
744
746
                                   void *func_arg);
745
747
/* Just for myisam legacy */
746
 
extern size_t my_pwrite(int Filedes,const unsigned char *Buffer,size_t Count,
747
 
                        drizzled::internal::my_off_t offset,drizzled::myf MyFlags);
748
 
extern size_t my_pread(int Filedes,unsigned char *Buffer,size_t Count,drizzled::internal::my_off_t offset,
749
 
                       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);
750
752
 
751
753
/* Needed for handler */
752
 
void mi_disable_non_unique_index(MI_INFO *info, drizzled::ha_rows rows);
753
 
void _mi_report_crashed(MI_INFO *file, const char *message, const char *sfile,
754
 
                        uint32_t sline);
755
 
 
756
 
#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 */