1. 13 Jun, 2007 4 commits
    • marko's avatar
      branches/zip: Remove reads of freed memory in fast index creation. · a5ddf51a
      marko authored
      Because row_drop_table_for_mysql_no_commit() checks with dict_load_table()
      if the table was successfully dropped, we cannot pass table->name to it.
      
      row_merge_drop_table(): Pass a copy of table->name to
      row_drop_table_for_mysql().
      
      row_prebuilt_free(): Do not dereference prebuilt->table->name after a
      successful invocation of row_add_table_to_background_drop_list().  The
      table object may be freed at any time.  Remove the debug message
      "Dropping table".
      a5ddf51a
    • marko's avatar
      branches/zip: Fix a few bugs in fast index creation. No more crashes · 62ad3dbd
      marko authored
      occur in mysql-test-run, but mysql-test-run reports some warnings for
      some tests and incorrect results for innodb-index.test.
      
      innobase_start_trx_and_assign_read_view(): Use thd instead of current_thd.
      
      ha_innobase::add_index(): Use ha_thd() instead of current_thd.
      Commit the transaction at the end.
      
      row_merge_rename_index(): Really change the name of the index.  This was
      broken in r1430.
      62ad3dbd
    • marko's avatar
      branches/zip: Merge 1571:1575 from trunk. · 258fb5d4
      marko authored
      258fb5d4
    • marko's avatar
      branches/zip: trx_commit_for_mysql(): Replace ut_a(err) · 251a921e
      marko authored
      with ut_a(err == DB_SUCCESS).
      251a921e
  2. 12 Jun, 2007 2 commits
  3. 11 Jun, 2007 2 commits
    • marko's avatar
      branches/zip: Initialize some uninitialized variables in order to avoid · 5ab4cfd4
      marko authored
      comparing uninitialized values.
      
      dict_mem_table_create(): Initialize table->version_number.
      
      ins_node_create(): Initialize node->table_version_number.
      
      row_create_prebuilt(): Initialize all fields.  Initialize most fields
      by memset(), so that any fields that are added will be initialized
      automatically.
      5ab4cfd4
    • marko's avatar
      branches/zip: Create special single-table tablespace file names for · 1cfcd4f2
      marko authored
      temporary tablespaces in fast index creation.  The tablespaces must
      reside in the same directory as the persistent tablespaces, so that
      they can be renamed without copying.  Namespace collisions are avoided
      by replacing the ".ibd" file name suffix with ".ib1" or ".ib2".
      
      fil_make_ibd_name(): Treat names starting with TEMP_TABLE_PREFIX
      specially.  Document the dependence on
      innobase_create_temporary_tablename().
      1cfcd4f2
  4. 08 Jun, 2007 4 commits
    • marko's avatar
      branches/zip: Fix bugs in merge sort. · 0954bbed
      marko authored
      row_merge_buf_add(): Correctly calculate buf->total_size.
      
      row_merge_buf_write(): Add an assertion about buf->total_size.
      
      row_merge_heap_create(), row_merge_read_rec(), row_merge_insert_index_tuples():
      offsets needs to be 1 + REC_OFFS_HEADER_SIZE + n_fields.  Previously, we
      allocated one element too little.
      
      row_merge_blocks(): Use goto instead of break in the AT_END argument
      of ROW_MERGE_WRITE_GET_NEXT.
      0954bbed
    • marko's avatar
      branches/zip: row_merge_build_indexes(): Allocate all buffers with a · ffe5998e
      marko authored
      single os_mem_alloc_large() call.  The function mem_alloc() that was
      used previously allocates unaligned memory.
      
      row_merge_blocks(): Replace block1, block2, block3 with a single array.
      Replace buf1, buf2, buf3 with buf[3].  Replace b1..b3 with b0..b2.
      Replace mrec1,2 with mrec0,1.  Replace offsets1,2 with offsets0,1.
      
      row_merge(), row_merge_sort(): Replace block1, block2, block3 with a
      single array.
      ffe5998e
    • marko's avatar
      branches/zip: Reimplement merge sort in fast index creation. · fd91f7bb
      marko authored
      The creation of the primary key does not work.  We will have to flag
      externally stored columns and copy the externally stored part from
      the old table.
      
      row_build_index_for_mysql(): Rename to row_merge_build_indexes().
      Move from row0mysql.c to row0merge.c.
      
      Remove private declarations from row0merge.h.  Make many functions static
      in row0merge.c.
      
      cmp_rec_rec_simple(): A new comparison function.
      
      dict_index_get_min_size(): New function.
      
      OS_FILE_FROM_FD(fd): A macro for converting from int to os_file_t.
      
      rec_convert_dtuple_to_rec_comp(): Make the interface lower-level.
      
      rec_get_converted_size_comp(): Return also extra_size.
      
      UT_SORT_FUNCTION_BODY(): Remove reference to an obsolete test program.
      
      row_rec_to_index_entry_low(): New function.
      
      row0merge.c: Implement merge sort based on file streams instead of
      fixed-size blocks.  Sort the small blocks as arrays of dfield_t*,
      because it is faster than invoking rec_get_offsets() for every
      comparison.
      fd91f7bb
    • marko's avatar
      branches/zip: Merge 1553:1556 from trunk. · 2d90ae68
      marko authored
      2d90ae68
  5. 07 Jun, 2007 5 commits
  6. 06 Jun, 2007 2 commits
  7. 04 Jun, 2007 2 commits
    • marko's avatar
      branches/zip: Minor cleanup. · 1d2284c3
      marko authored
      row_merge_mark_prebuilt_obsolete(): Rename to row_prebuilt_table_obsolete()
      and move from row0merge.c to row0mysql.c.  Remove the parameter trx.
      
      row_merge_print_table(): Remove.
      1d2284c3
    • marko's avatar
      branches/zip: Minor cleanup. · d1bf0b7d
      marko authored
      row_remove_indexes_for_mysql(): Rename to row_merge_drop_indexes(),
      move from row0mysql.c to row0merge.c and make the return type void.
      
      row_merge_remove_index(): Rename to row_merge_drop_index() and make
      the return type void.
      d1bf0b7d
  8. 29 May, 2007 1 commit
  9. 28 May, 2007 1 commit
  10. 24 May, 2007 1 commit
  11. 22 May, 2007 4 commits
  12. 21 May, 2007 1 commit
  13. 18 May, 2007 4 commits
  14. 16 May, 2007 2 commits
    • marko's avatar
      branches/zip: btr_cur_optimistic_insert(): Set the insert buffer free bits · 6613d537
      marko authored
      exactly.  Rename the local variable "ulint level" to "ibool leaf".
      Document that if the function returns DB_SUCCESS on a compressed page that
      is covered by the insert buffer, the mini-transaction must be committed
      before latching any further pages.  Verify that this is the case on all
      execution paths.
      6613d537
    • marko's avatar
      branches/zip: Document and obey the rules for modifying the free bits in · 36e875f7
      marko authored
      the insert buffer bitmap.
      
      ibuf_set_free_bits_func(): Never disable redo logging.
      
      ibuf_update_free_bits_zip(): Remove.
      
      btr_page_reorganize_low(), page_zip_reorganize(): Do not update the insert
      buffer bitmap.  Instead, document that callers will have to take care of it,
      and adapt the callers.
      
      btr_compress(): On error, reset the insert buffer free bits.
      
      btr_cur_insert_if_possible(): Do not modify the insert buffer bitmap.
      
      btr_compress(), btr_cur_optimistic_insert(): On compressed pages,
      reset the insert buffer bitmap.  Document why.
      
      btr_cur_update_alloc_zip(): Document why it is necessary and sufficient
      to reset the insert buffer free bits.
      
      btr_cur_update_in_place(), btr_cur_optimistic_update(),
      btr_cur_pessimistic_update(): Update the free bits in the same
      mini-transaction.  Document that the mini-transaction must be
      committed before latching any further pages.  Verify that this
      is the case in all execution paths.
      
      row_ins_sec_index_entry_by_modify(), row_ins_clust_index_entry_by_modify(),
      row_undo_mod_clust_low(): Because these functions call
      btr_cur_update_in_place(), btr_cur_optimistic_update(), or
      btr_cur_pessimistic_update(), document that the mini-transaction must be
      committed before latching any further pages.  Verify that this is the case
      in all execution paths.
      36e875f7
  15. 15 May, 2007 1 commit
    • marko's avatar
      branches/zip: Minor cleanup. · 19569a8b
      marko authored
      page_cur_tuple_insert(), page_cur_rec_insert(): Improve the documentation.
      Note that the physical position of page_cursor may change.
      
      page_cur_rec_insert(), page_cur_insert_rec_low(), page_cur_insert_rec_zip():
      Add a const qualifier to the parameter rec.
      19569a8b
  16. 14 May, 2007 1 commit
  17. 07 May, 2007 1 commit
    • marko's avatar
      branches/zip: Fix two bugs. · fbc6f37c
      marko authored
      mtr_commit(): Do not acquire the log mutex if no log records are to be written.
      
      ibuf_set_free_bits_func(): Do not clear mtr.modifications, because that would
      prevent the dirty insert buffer bitmap block from being moved to the flush
      list.  Instead, assume that mtr_commit() will not acquire log_sys->mutex
      because redo logging is disabled.
      
      buf_page_init_for_read(): I/O-fix the block before buf_buddy_alloc(), because
      the newly allocated block could otherwise be reused by the compressed page.
      fbc6f37c
  18. 06 May, 2007 2 commits
    • marko's avatar
      branches/zip: When reading pages for merging buffered inserts, request that · dd529ee4
      marko authored
      the pages be decompressed.
      
      buf_read_page_low(), buf_page_init_for_read(): Add parameter "unzip".
      dd529ee4
    • marko's avatar
      branches/zip: ibuf_set_free_bits_func(): Disable redo logging when · 2e739224
      marko authored
      crash recovery is in progress.  This avoids a hang when
      btr_parse_page_reorganize(), called from an I/O handler thread,
      attempts to acquire log_sys->mutex while it is being held by
      the main thread (the one that runs innobase_init()).  This change
      was committed accidentally.  It may be unsafe to clear
      mtr.modifications, because buf_page_release() at mtr_commit() may
      forget to put modified pages to the flush list.
      
      Cleanup: Remove the "type" parameter from many ibuf functions.
      Let the caller check that !dict_index_is_clust().  This should avoid
      function calls and register spilling.
      
      ibuf_set_free_bits_func(), ibuf_set_free_bits(): Remove the parameter "type".
      
      ibuf_reset_free_bits_with_type(): Rename to ibuf_reset_free_bits().
      Remove the parameter "type".
      
      ibuf_update_free_bits_if_full(), ibuf_update_free_bits_zip(),
      ibuf_update_free_bits_low(), ibuf_update_free_bits_for_two_pages_low():
      Remove the parameter "index".
      2e739224