mirror of
https://github.com/MariaDB/server.git
synced 2025-01-19 13:32:33 +01:00
7f890ab6aa
From revision r5703 to r5716 Detailed revision comments: r5703 | marko | 2009-08-27 02:25:00 -0500 (Thu, 27 Aug 2009) | 41 lines branches/zip: Replace the constant 3/8 ratio that controls the LRU_old size with the settable global variable innodb_old_blocks_pct. The minimum and maximum values are 5 and 95 per cent, respectively. The default is 100*3/8, in line with the old behavior. ut_time_ms(): New utility function, to return the current time in milliseconds. TODO: Is there a more efficient timestamp function, such as rdtsc divided by a power of two? buf_LRU_old_threshold_ms: New variable, corresponding to innodb_old_blocks_time. The value 0 is the default behaviour: no timeout before making blocks 'new'. bpage->accessed, bpage->LRU_position, buf_pool->ulint_clock: Remove. bpage->access_time: New field, replacing bpage->accessed. Protected by buf_pool_mutex instead of bpage->mutex. Updated when a page is created or accessed the first time in the buffer pool. buf_LRU_old_ratio, innobase_old_blocks_pct: New variables, corresponding to innodb_old_blocks_pct buf_LRU_old_ratio_update(), innobase_old_blocks_pct_update(): Update functions for buf_LRU_old_ratio, innobase_old_blocks_pct. buf_page_peek_if_too_old(): Compare ut_time_ms() to bpage->access_time if buf_LRU_old_threshold_ms && bpage->old. Else observe buf_LRU_old_ratio and bpage->freed_page_clock. buf_pool_t: Add n_pages_made_young, n_pages_not_made_young, n_pages_made_young_old, n_pages_not_made_young, for statistics. buf_print(): Display buf_pool->n_pages_made_young, buf_pool->n_pages_not_made_young. This function is only for crash diagnostics. buf_print_io(): Display buf_pool->LRU_old_len and quantities derived from buf_pool->n_pages_made_young, buf_pool->n_pages_not_made_young. This function is invoked by SHOW ENGINE INNODB STATUS. rb://129 approved by Heikki Tuuri. This addresses Bug #45015. r5704 | marko | 2009-08-27 03:31:17 -0500 (Thu, 27 Aug 2009) | 32 lines branches/zip: Fix a critical bug in fast index creation that could corrupt the created indexes. row_merge(): Make "half" an in/out parameter. Determine the offset of half the output file. Copy the last blocks record-by-record instead of block-by-block, so that the records can be counted. Check that the input and output have matching n_rec. row_merge_sort(): Do not assume that two blocks of size N are merged into a block of size 2*N. The output block can be shorter than the input if the last page of each input block is almost empty. Use an accurate termination condition, based on the "half" computed by row_merge(). row_merge_read(), row_merge_write(), row_merge_blocks(): Add debug output. merge_file_t, row_merge_file_create(): Add n_rec, the number of records in the merge file. row_merge_read_clustered_index(): Update n_rec. row_merge_blocks(): Update and check n_rec. row_merge_blocks_copy(): New function, for copying the last blocks in row_merge(). Update and check n_rec. This bug was discovered with a user-supplied test case that creates an index where the initial temporary file is 249 one-megabyte blocks and the merged files become smaller. In the test, possible merge record sizes are 10, 18, and 26 bytes. rb://150 approved by Sunny Bains. This addresses Issue #320. r5705 | marko | 2009-08-27 06:56:24 -0500 (Thu, 27 Aug 2009) | 11 lines branches/zip: dict_index_find_cols(): On column name lookup failure, return DB_CORRUPTION (HA_ERR_CRASHED) instead of abnormally terminating the server. Also, disable the previously added diagnostic output to the error log, because mysql-test-run does not like extra output in the error log. (Bug #44571) dict_index_add_to_cache(): Handle errors from dict_index_find_cols(). mysql-test/innodb_bug44571.test: A test case for triggering the bug. rb://135 approved by Sunny Bains. r5706 | inaam | 2009-08-27 11:00:27 -0500 (Thu, 27 Aug 2009) | 20 lines branches/zip rb://147 Done away with following two status variables: innodb_buffer_pool_read_ahead_rnd innodb_buffer_pool_read_ahead_seq Introduced two new status variables: innodb_buffer_pool_read_ahead = number of pages read as part of readahead since server startup innodb_buffer_pool_read_ahead_evicted = number of pages that are read in as readahead but were evicted before ever being accessed since server startup i.e.: a measure of how badly our readahead is performing SHOW INNODB STATUS will show two extra numbers in buffer pool section: pages read ahead/sec and pages evicted without access/sec Approved by: Marko r5707 | inaam | 2009-08-27 11:20:35 -0500 (Thu, 27 Aug 2009) | 6 lines branches/zip Remove unused macros as we erased the random readahead code in r5703. Also fixed some comments. r5708 | inaam | 2009-08-27 17:43:32 -0500 (Thu, 27 Aug 2009) | 4 lines branches/zip Remove redundant TRUE : FALSE from the return statement r5709 | inaam | 2009-08-28 01:22:46 -0500 (Fri, 28 Aug 2009) | 5 lines branches/zip rb://152 Disable display of deprecated parameter innodb_file_io_threads in 'show variables'. r5714 | marko | 2009-08-31 01:10:10 -0500 (Mon, 31 Aug 2009) | 5 lines branches/zip: buf_chunk_not_freed(): Do not acquire block->mutex unless block->page.state == BUF_BLOCK_FILE_PAGE. Check that block->page.state makes sense. Approved by Sunny Bains over the IM. r5716 | vasil | 2009-08-31 02:47:49 -0500 (Mon, 31 Aug 2009) | 9 lines branches/zip: Fix Bug#46718 InnoDB plugin incompatible with gcc 4.1 (at least: on PPC): "Undefined symbol" by implementing our own check in plug.in instead of using the result from the check from MySQL because it is insufficient. Approved by: Marko (rb://154)
1201 lines
40 KiB
Text
1201 lines
40 KiB
Text
2009-08-27 The InnoDB Team
|
|
|
|
* dict/dict0dict.c, include/dict0dict.h,
|
|
mysql-test/innodb_bug44571.result, mysql-test/innodb_bug44571.test:
|
|
Fix Bug#44571 InnoDB Plugin crashes on ADD INDEX
|
|
|
|
2009-08-27 The InnoDB Team
|
|
|
|
* row/row0merge.c:
|
|
Fix a bug in the merge sort that can corrupt indexes in fast index
|
|
creation. Add some consistency checks. Check that the number of
|
|
records remains constant in every merge sort pass.
|
|
|
|
2009-08-27 The InnoDB Team
|
|
|
|
* buf/buf0buf.c, buf/buf0lru.c, buf/buf0rea.c,
|
|
handler/ha_innodb.cc, include/buf0buf.h, include/buf0buf.ic,
|
|
include/buf0lru.h, include/ut0ut.h, ut/ut0ut.c:
|
|
Make it possible to tune the buffer pool LRU eviction policy to be
|
|
more resistant against index scans. Introduce the settable global
|
|
variables innodb_old_blocks_pct and innodb_old_blocks_time for
|
|
controlling the buffer pool eviction policy. The parameter
|
|
innodb_old_blocks_pct (5..95) controls the desired amount of "old"
|
|
blocks in the LRU list. The default is 37, corresponding to the
|
|
old fixed ratio of 3/8. Each time a block is accessed, it will be
|
|
moved to the "new" blocks if its first access was at least
|
|
innodb_old_blocks_time milliseconds ago (default 0, meaning every
|
|
block). The idea is that in index scans, blocks will be accessed
|
|
a few times within innodb_old_blocks_time, and they will remain in
|
|
the "old" section of the LRU list. Thus, when
|
|
innodb_old_blocks_time is nonzero, blocks retrieved for one-time
|
|
index scans will be more likely candidates for eviction than
|
|
blocks that are accessed in random patterns.
|
|
|
|
2009-08-26 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, os/os0file.c:
|
|
Fix Bug#42885 buf_read_ahead_random, buf_read_ahead_linear counters,
|
|
thread wakeups
|
|
|
|
2009-08-20 The InnoDB Team
|
|
|
|
* lock/lock0lock.c:
|
|
Fix Bug#46650 Innodb assertion autoinc_lock == lock in
|
|
lock_table_remove_low on INSERT SELECT
|
|
|
|
2009-08-13 The InnoDB Team
|
|
|
|
* handler/handler0alter.cc:
|
|
Fix Bug#46657 InnoDB plugin: invalid read in index_merge_innodb test
|
|
(Valgrind)
|
|
|
|
2009-07-20 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, buf/buf0rea.c, include/srv0srv.h, srv/srv0srv.c
|
|
Change the read ahead parameter name to innodb_read_ahead_threshold.
|
|
Change the meaning of this parameter to signify the number of pages
|
|
that must be sequentially accessed for InnoDB to trigger a readahead
|
|
request.
|
|
|
|
2009-07-20 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc:
|
|
Fix Bug#39802 On Windows, 32-bit time_t should be enforced
|
|
|
|
2009-07-16 The InnoDB Team
|
|
|
|
* include/univ.i:
|
|
Support inlining of functions and prefetch with Sun Studio.
|
|
These changes are based on contribution from
|
|
Sun Microsystems Inc. under a BSD license.
|
|
|
|
2009-07-14 The InnoDB Team
|
|
|
|
* fil/fil0fil.c:
|
|
Fix Bug#45814 URL reference in InnoDB server errors needs adjusting to
|
|
match documentation
|
|
|
|
2009-07-14 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, mysql-test/innodb_bug21704.result,
|
|
mysql-test/innodb_bug21704.test:
|
|
Fix Bug#21704 Renaming column does not update FK definition
|
|
|
|
2009-07-10 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, srv/srv0srv.c:
|
|
Change the defaults for
|
|
innodb_sync_spin_loops: 20 -> 30
|
|
innodb_spin_wait_delay: 5 -> 6
|
|
|
|
2009-07-08 The InnoDB Team
|
|
|
|
* srv/srv0srv.c, buf/buf0flu.c, handler/ha_innodb.cc,
|
|
include/srv0srv.h, include/log0log.ic, include/buf0flu.h,
|
|
include/log0log.h:
|
|
Implement the adaptive flushing of dirty pages, which uses
|
|
a heuristics based flushing rate of dirty pages to avoid IO
|
|
bursts at checkpoint. Expose new configure knob
|
|
innodb_adaptive_flushing to control whether the new flushing
|
|
algorithm should be used.
|
|
|
|
2009-07-07 The InnoDB Team
|
|
|
|
* srv/srv0srv.c, handler/ha_innodb.cc, log/log0log.c,
|
|
include/srv0srv.h:
|
|
Implement IO capacity tuning. Expose new configure knob
|
|
innodb_io_capacity to control the master threads IO rate. The
|
|
ibuf merge is also changed from synchronous to asynchronous.
|
|
These changes are based on contribution from Google Inc.
|
|
under a BSD license.
|
|
|
|
2009-07-02 The InnoDB Team
|
|
|
|
* include/ut0ut.h, plug.in, ut/ut0ut.c:
|
|
Use the PAUSE instruction inside the spinloop if it is available,
|
|
Thanks to Mikael Ronstrom <mikael@mysql.com>.
|
|
|
|
2009-06-29 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, mysql-test/innodb_file_format.test,
|
|
mysql-test/innodb_file_format.result:
|
|
Do not crash on SET GLOBAL innodb_file_format=DEFAULT
|
|
or SET GLOBAL innodb_file_format_check=DEFAULT.
|
|
|
|
2009-06-29 The InnoDB Team
|
|
|
|
* buf/buf0buf.c, buf/buf0rea.c, lock/lock0lock.c:
|
|
Tolerate missing tablespaces during crash recovery and when
|
|
printing information on locks.
|
|
|
|
2009-06-29 The InnoDB Team
|
|
|
|
* buf/buf0buf.c:
|
|
Fix a race condition when reading buf_fix_count.
|
|
Currently, it is not being protected by the buffer pool mutex,
|
|
but by the block mutex.
|
|
|
|
2009-06-29 The InnoDB Team
|
|
|
|
* handler/handler0alter.cc:
|
|
Start the user transaction prebuilt->trx if it was not started
|
|
before adding or dropping an index. Without this fix, the
|
|
table could be locked outside an active transaction.
|
|
|
|
2009-06-25 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc,
|
|
mysql-test/innodb_bug42101.test,
|
|
mysql-test/innodb_bug42101.result,
|
|
mysql-test/innodb_bug42101-nonzero.test,
|
|
mysql-test/innodb_bug42101-nonzero.result:
|
|
Fix Bug#45749 Race condition in SET GLOBAL
|
|
innodb_commit_concurrency=DEFAULT
|
|
|
|
2009-06-25 The InnoDB Team
|
|
|
|
* dict/dict0dict.c:
|
|
When an index column cannot be found in the table during index
|
|
creation, display additional diagnostic before an assertion failure.
|
|
This does NOT fix Bug #44571 InnoDB Plugin crashes on ADD INDEX,
|
|
but it helps understand the reason of the crash.
|
|
|
|
2009-06-17 The InnoDB Team
|
|
|
|
* row/row0merge.c:
|
|
Fix Bug#45426 UNIV_DEBUG build cause assertion error at CREATE INDEX
|
|
|
|
2009-06-17 The InnoDB Team
|
|
|
|
* mysql-test/innodb_bug45357.result, mysql-test/innodb_bug45357.test,
|
|
row/row0mysql.c:
|
|
Fix Bug#45357 5.1.35 crashes with Failing assertion: index->type &
|
|
DICT_CLUSTERED
|
|
|
|
2009-06-17 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, mysql-test/innodb-autoinc.result,
|
|
mysql-test/innodb-autoinc.test:
|
|
Fix Bug#44030 Error: (1500) Couldn't read the MAX(ID) autoinc value
|
|
from the index (PRIMARY)
|
|
|
|
2009-06-11 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, mysql-test/innodb.result, srv/srv0srv.c:
|
|
Change the following defaults:
|
|
max_dirty_pages_pct: from 90 to 75, max allowed from 100 to 99
|
|
additional_mem_pool_size: from 1 to 8 MB
|
|
buffer_pool_size: from 8 to 128 MB
|
|
log_buffer_size: from 1 to 8 MB
|
|
read_io_threads/write_io_threads: from 1 to 4
|
|
|
|
2009-06-09 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, include/trx0trx.h, trx/trx0trx.c:
|
|
Enable Group Commit functionality that was broken in 5.0 when
|
|
distributed transactions were introduced.
|
|
|
|
2009-06-05 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, include/os0file.h, include/srv0srv.h,
|
|
os/os0file.c, srv/srv0srv.c, srv/srv0start.c:
|
|
Enable functionality to have multiple background IO helper threads.
|
|
Expose new configure knobs innodb_read_io_threads and
|
|
innodb_write_io_threads and deprecate innodb_file_io_threads (this
|
|
parameter was relevant only on windows). Internally this allows
|
|
multiple segments for read and write IO request arrays where one
|
|
thread works on one segment.
|
|
|
|
2009-06-05 The InnoDB Team
|
|
|
|
* buf/buf0lru.c, buf/buf0rea.c, handler/ha_innodb.cc,
|
|
include/srv0srv.h, srv/srv0srv.c:
|
|
Fix a bug in linear read ahead:
|
|
1) Take into account access pattern when deciding whether or not to
|
|
do linear read ahead.
|
|
2) Expose a knob innodb_read_ahead_factor = [0-64] default (8),
|
|
dynamic, global to control linear read ahead behavior. This is the
|
|
value of the number of pages that InnoDB will tolerate within a
|
|
64 page extent even if they are accessed out of order or have
|
|
not been accessed at all. This number (which varies from 0 to 64)
|
|
is indicative of the slack that we have when deciding about linear
|
|
readahead.
|
|
3) Disable random read ahead. Keep the code for now.
|
|
|
|
2009-06-03 The InnoDB Team
|
|
|
|
* dict/dict0dict.c, mysql-test/t/innodb_mysql.test,
|
|
mysql-test/r/innodb_mysql.result:
|
|
Fix Bug#39793 Foreign keys not constructed when column
|
|
has a '#' in a comment or default value
|
|
|
|
2009-05-27 The InnoDB Team
|
|
|
|
* Doxyfile:
|
|
Allow the extraction of documentation from the code base with the
|
|
Doxygen tool. Convert and add many (but not yet all) comments to
|
|
Doxygen format.
|
|
|
|
2009-05-19 The InnoDB Team
|
|
|
|
* btr/btr0btr.c, btr/btr0cur.c, lock/lock0lock.c,
|
|
include/page0page.ic, include/lock0lock.h, include/dict0dict.h,
|
|
include/page0page.h, include/dict0dict.ic, ibuf/ibuf0ibuf.c,
|
|
page/page0zip.c, page/page0page.c:
|
|
Write updates of PAGE_MAX_TRX_ID to the redo log and add debug
|
|
assertions for checking that PAGE_MAX_TRX_ID is valid on leaf
|
|
pages of secondary indexes and the insert buffer B-tree. This bug
|
|
could cause failures in secondary index lookups in consistent
|
|
reads right after crash recovery.
|
|
|
|
2009-05-18 The InnoDB Team
|
|
|
|
* btr/btr0cur.c:
|
|
Correctly estimate the space needed on the compressed page when
|
|
performing an update by delete-and-insert.
|
|
|
|
2009-05-14 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, include/srv0srv.h,
|
|
mysql-test/innodb_bug42101-nonzero-master.opt,
|
|
mysql-test/innodb_bug42101-nonzero.result,
|
|
mysql-test/innodb_bug42101-nonzero.test,
|
|
mysql-test/innodb_bug42101.result, mysql-test/innodb_bug42101.test,
|
|
srv/srv0srv.c:
|
|
Fix Bug#42101 Race condition in innodb_commit_concurrency
|
|
|
|
2009-05-13 The InnoDB Team
|
|
|
|
* dict/dict0dict.c:
|
|
Fix Bug#44320 InnoDB: missing DB_ROLL_PTR in Table Monitor COLUMNS
|
|
output
|
|
|
|
2009-04-23 The InnoDB Team
|
|
|
|
* row/row0mysql.c:
|
|
When scanning indexes, report in the error log any error codes
|
|
returned by the search function. These error codes will still be
|
|
ignored in CHECK TABLE.
|
|
|
|
2009-04-23 The InnoDB Team
|
|
|
|
* include/trx0types.h:
|
|
Define the logical type names trx_id_t, roll_ptr_t, and undo_no_t
|
|
and use them in place of dulint everywhere.
|
|
|
|
2009-04-18 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, include/pars0pars.h:
|
|
Fix Bug#29125 Windows Server X64: so many compiler warnings
|
|
|
|
2009-04-16 The InnoDB Team
|
|
|
|
* include/univ.i:
|
|
Define REFMAN as the base URL of the MySQL Reference Manual and
|
|
use the macro in all diagnostic output.
|
|
|
|
2009-04-16 The InnoDB Team
|
|
|
|
* CMakeLists.txt, include/os0sync.h, include/sync0sync.h,
|
|
include/sync0sync.ic, include/univ.i, srv/srv0start.c,
|
|
sync/sync0sync.c:
|
|
Use the Windows Interlocked functions for atomic memory
|
|
access.
|
|
|
|
2009-04-15 The InnoDB Team
|
|
|
|
* mysql-test/innodb.result, mysql-test/innodb.test:
|
|
Fix Bug#43309 Test main.innodb can't be run twice
|
|
|
|
2009-04-14 The InnoDB Team
|
|
|
|
* CMakeLists.txt, handler/win_delay_loader.cc,
|
|
win-plugin/win-plugin.diff:
|
|
Remove statically linked libraries from MySQL (zlib and strings).
|
|
|
|
2009-04-11 The InnoDB Team
|
|
|
|
* CMakeLists.txt, win-plugin/README, win-plugin/win-plugin.diff:
|
|
Rewrite CMakeLists.txt.
|
|
|
|
2009-04-07 The InnoDB Team
|
|
|
|
* include/os0sync.h, include/sync0rw.ic, include/sync0sync.h,
|
|
include/sync0sync.ic, include/univ.i, plug.in, srv/srv0srv.c,
|
|
srv/srv0start.c, sync/sync0arr.c, sync/sync0sync.c:
|
|
Enable atomics on Solaris (using the libc functions as defined in
|
|
atomic.h) if GCC atomic builtins are not present.
|
|
|
|
2009-04-07 The InnoDB Team
|
|
|
|
* btr/btr0btr.c, dict/dict0dict.c, ibuf/ibuf0ibuf.c,
|
|
include/data0data.h, include/data0data.ic, include/data0type.h,
|
|
include/data0type.ic, include/dict0dict.h, include/dict0dict.ic,
|
|
include/rem0rec.ic, mysql-test/innodb.result, mysql-test/innodb.test,
|
|
pars/pars0pars.c, rem/rem0rec.c, row/row0upd.c:
|
|
Fix Bug#44032 In ROW_FORMAT=REDUNDANT, update UTF-8 CHAR
|
|
to/from NULL is not in-place
|
|
|
|
2009-04-07 The InnoDB Team
|
|
|
|
* page/page0cur.c:
|
|
Fix Bug#43660 SHOW INDEXES/ANALYZE does NOT update cardinality for
|
|
indexes of InnoDB table
|
|
|
|
2009-04-06 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc:
|
|
Make the parameter innodb_change_buffering settable by the
|
|
configuration file or mysqld command line options. Before this
|
|
fix, the initial value specified for this parameter was ignored.
|
|
|
|
2009-04-06 The InnoDB Team
|
|
|
|
* sync/sync0rw.c:
|
|
Avoid a bogus failure in UNIV_SYNC_DEBUG diagnostics.
|
|
|
|
2009-04-02 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, include/srv0srv.h, srv/srv0srv.c:
|
|
Add new parameter innodb_spin_wait_delay to set the maximum delay
|
|
between polling for a spin lock.
|
|
|
|
2009-04-02 The InnoDB Team
|
|
|
|
* dict/dict0crea.c, handler/ha_innodb.cc, handler/ha_innodb.h,
|
|
include/dict0mem.h, include/row0merge.h, include/row0mysql.h,
|
|
mysql-test/innodb-index.result, mysql-test/innodb-index.test,
|
|
row/row0merge.c, row/row0sel.c:
|
|
In consistent reads, refuse to use newly created indexes that may
|
|
lack history.
|
|
|
|
2009-03-25 The InnoDB Team
|
|
|
|
* buf/buf0buf.c, handler/ha_innodb.cc, include/buf0buf.h:
|
|
In SHOW ENGINE INNODB MUTEX do not show the status of block->mutex,
|
|
block->lock, block->lock->mutex (if applicable) and all mutexes and
|
|
rw-locks for which number of os-waits are zero because this can
|
|
be overwhelming particularly when the buffer pool is very large.
|
|
|
|
2009-03-20 The InnoDB Team
|
|
|
|
* buf/buf0buf.c, include/log0recv.h, log/log0recv.c:
|
|
Remove the compile-time constant parameters of
|
|
recv_recover_page(), recv_scan_log_recs(), and recv_sys_init().
|
|
|
|
2009-03-20 The InnoDB Team
|
|
|
|
* data/data0type.c, handler/ha_innodb.cc, include/ha_prototypes.h:
|
|
Declare innobase_get_at_most_n_mbchars() in ha_prototypes.h.
|
|
|
|
2009-03-20 The InnoDB Team
|
|
|
|
* fil/fil0fil.h, fil/fil0fil.c, srv/srv0start.c:
|
|
Add the parameter hash_size to fil_init().
|
|
|
|
2009-03-20 The InnoDB Team
|
|
|
|
* fil/fil0fil.c:
|
|
Refer to fil_system directly, not via local variables.
|
|
|
|
2009-03-20 The InnoDB Team
|
|
|
|
* page/page0page.c:
|
|
In page_validate(), always report the space id, page number and
|
|
the name of the index when corruption is noticed.
|
|
|
|
2009-03-20 The InnoDB Team
|
|
|
|
* include/log0log.h, include/log0log.ic, log/log0log.c:
|
|
Add in/out comments or const qualifiers to some function
|
|
parameters as appropriate.
|
|
|
|
2009-03-20 The InnoDB Team
|
|
|
|
* dict/dict0boot.c, dict/dict0dict.c, fsp/fsp0fsp.c,
|
|
include/dict0dict.h, include/srv0srv.h, srv/srv0srv.c,
|
|
page/page0page.c:
|
|
Replace srv_sys->dummy_ind1 and srv_sys->dummy_ind2 with
|
|
dict_ind_redundant and dict_ind_compact, which are
|
|
initialized by dict_init().
|
|
|
|
2009-03-11 The InnoDB Team
|
|
|
|
InnoDB Plugin 1.0.3 released
|
|
|
|
2009-03-05 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, mysql-test/innodb-autoinc.result,
|
|
mysql-test/innodb-autoinc.test:
|
|
Fix Bug#43203 Overflow from auto incrementing causes server segv
|
|
|
|
2009-02-25 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, mysql-test/innodb-autoinc.result,
|
|
mysql-test/innodb-autoinc.test:
|
|
Fix Bug#42714 AUTO_INCREMENT errors in 5.1.31
|
|
|
|
2009-02-23 The InnoDB Team
|
|
|
|
* btr/btr0cur.c:
|
|
Fix Bug#43043 Crash on BLOB delete operation
|
|
|
|
2009-02-20 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc:
|
|
Make innodb_use_sys_malloc=ON the default.
|
|
|
|
2009-02-20 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, mysql-test/innodb-autoinc.result,
|
|
mysql-test/innodb-autoinc.test:
|
|
Fix Bug#42400 InnoDB autoinc code can't handle floating-point columns
|
|
|
|
2009-02-18 The InnoDB Team
|
|
|
|
* include/ut0mem.h, os/os0proc.c, ut/ut0mem.c:
|
|
Protect ut_total_allocated_memory with ut_list_mutex in
|
|
os_mem_alloc_large() and os_mem_free_large(). The lack of this mutex
|
|
protection could cause an assertion failure during fast index
|
|
creation. Also, add UNIV_MEM_ALLOC and UNIV_MEM_FREE instrumentation
|
|
to os_mem_alloc_large() and os_mem_free_large(), so that Valgrind can
|
|
detect more errors.
|
|
|
|
2009-02-11 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc:
|
|
Make innodb_thread_concurrency=0 the default. The old default value
|
|
was 8. A non-zero setting may be useful when InnoDB is showing severe
|
|
scalability problems under multiple concurrent connections.
|
|
|
|
2009-02-10 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, handler/ha_innodb.h:
|
|
Fix Bug#41676 Table names are case insensitive in locking
|
|
|
|
2009-02-10 The InnoDB Team
|
|
|
|
* mem/mem0dbg.c, mem/mem0mem.c, mem/mem0pool.c:
|
|
When innodb_use_sys_malloc is set, ignore
|
|
innodb_additional_mem_pool_size, because nothing will be allocated
|
|
from mem_comm_pool.
|
|
|
|
2009-02-10 The InnoDB Team
|
|
|
|
* ut/ut0mem.c:
|
|
Map ut_malloc_low(), ut_realloc(), and ut_free() directly to malloc(),
|
|
realloc(), and free() when innodb_use_sys_malloc is set. As a side
|
|
effect, ut_total_allocated_memory ("Total memory allocated" in the
|
|
"BUFFER POOL AND MEMORY" section of SHOW ENGINE INNODB STATUS) will
|
|
exclude any memory allocated by these functions when
|
|
innodb_use_sys_malloc is set.
|
|
|
|
2009-02-10 The InnoDB Team
|
|
|
|
* btr/btr0cur.c, btr/btr0sea.c, buf/buf0buf.c, handler/ha_innodb.cc,
|
|
include/buf0buf.ic, include/os0sync.h, include/srv0srv.h,
|
|
include/sync0rw.h, include/sync0rw.ic, include/sync0sync.h,
|
|
include/sync0sync.ic, include/univ.i, row/row0sel.c, srv/srv0srv.c,
|
|
srv/srv0start.c, sync/sync0arr.c, sync/sync0rw.c, sync/sync0sync.c:
|
|
On those platforms that support it, implement the synchronization
|
|
primitives of InnoDB mutexes and read/write locks with GCC atomic
|
|
builtins instead of Pthreads mutexes and InnoDB mutexes. These changes
|
|
are based on a patch supplied by Mark Callaghan of Google under a BSD
|
|
license.
|
|
|
|
2009-01-30 The InnoDB Team
|
|
|
|
* btr/btr0cur.c, btr/btr0sea.c, buf/buf0buf.c, handler/ha_innodb.cc,
|
|
include/btr0sea.h, include/buf0buf.h, include/sync0sync.h,
|
|
sync/sync0sync.c:
|
|
Make the configuration parameter innodb_adaptive_hash_index dynamic,
|
|
so that it can be changed at runtime.
|
|
|
|
2009-01-29 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, ibuf/ibuf0ibuf.c, include/ibuf0ibuf.h,
|
|
include/ibuf0ibuf.ic:
|
|
Implement the settable global variable innodb_change_buffering,
|
|
with the allowed values 'none' and 'inserts'. The default value
|
|
'inserts' enables the buffering of inserts to non-unique secondary
|
|
index trees when the B-tree leaf page is not in the buffer pool.
|
|
|
|
2009-01-27 The InnoDB Team
|
|
|
|
* buf/buf0lru.c:
|
|
Fix a race condition in buf_LRU_invalidate_tablespace(): The
|
|
compressed page size (zip_size) was read while the block descriptor
|
|
was no longer protected by a mutex. This could lead to corruption
|
|
when a table is dropped on a busy system that contains compressed
|
|
tables.
|
|
|
|
2009-01-26 The InnoDB Team
|
|
|
|
* btr/btr0sea.c, buf/buf0buf.c, include/buf0buf.h, include/buf0buf.ic,
|
|
include/mtr0log.ic, include/row0upd.ic, mtr/mtr0mtr.c:
|
|
Implement buf_block_align() with pointer arithmetics, as it is in the
|
|
built-in InnoDB distributed with MySQL. Do not acquire the buffer pool
|
|
mutex before buf_block_align(). This removes a scalability bottleneck
|
|
in the adaptive hash index lookup. In CHECK TABLE, check that
|
|
buf_pool->page_hash is consistent with buf_block_align().
|
|
|
|
2009-01-23 The InnoDB Team
|
|
|
|
* btr/btr0sea.c:
|
|
Fix Bug#42279 Race condition in btr_search_drop_page_hash_when_freed()
|
|
|
|
2009-01-23 The InnoDB Team
|
|
|
|
* buf/buf0buf.c, include/buf0buf.h:
|
|
Remove the unused mode BUF_GET_NOWAIT of buf_page_get_gen()
|
|
|
|
2009-01-20 The InnoDB Team
|
|
|
|
* include/rem0rec.h, include/rem0rec.ic:
|
|
Fix Bug#41571 MySQL segfaults after innodb recovery
|
|
|
|
2009-01-20 The InnoDB Team
|
|
|
|
* lock/lock0lock.c:
|
|
Fix Bug#42152 Race condition in lock_is_table_exclusive()
|
|
|
|
2009-01-14 The InnoDB Team
|
|
|
|
* include/trx0roll.h, trx/trx0roll.c, trx/trx0trx.c:
|
|
Fix Bug#38187 Error 153 when creating savepoints
|
|
|
|
2009-01-14 The InnoDB Team
|
|
|
|
* dict/dict0load.c:
|
|
Fix Bug#42075 dict_load_indexes failure in dict_load_table will
|
|
corrupt the dictionary cache
|
|
|
|
2009-01-13 The InnoDB Team
|
|
|
|
* buf/buf0buddy.c, dict/dict0dict.c, dict/dict0mem.c, fil/fil0fil.c,
|
|
ha/ha0storage.c, handler/ha_innodb.cc, handler/win_delay_loader.cc,
|
|
include/buf0buf.ic, include/dict0dict.ic, include/hash0hash.h,
|
|
thr/thr0loc.c, trx/trx0i_s.c:
|
|
Add the parameter ASSERTION to HASH_SEARCH() macro, and use it for
|
|
light validation of the traversed items in hash table lookups when
|
|
UNIV_DEBUG is enabled.
|
|
|
|
2009-01-09 The InnoDB Team
|
|
|
|
* buf/buf0flu.c, include/buf0flu.h, include/buf0flu.ic:
|
|
Remove unused code from the functions
|
|
buf_flush_insert_into_flush_list() and
|
|
buf_flush_insert_sorted_into_flush_list().
|
|
|
|
2009-01-09 The InnoDB Team
|
|
|
|
* buf/buf0flu.c:
|
|
Simplify the functions buf_flush_try_page() and buf_flush_batch(). Add
|
|
debug assertions and an explanation to buf_flush_write_block_low().
|
|
|
|
2009-01-07 The InnoDB Team
|
|
|
|
* row/row0merge.c:
|
|
Fix a bug in recovery when dropping temporary indexes.
|
|
|
|
2009-01-07 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, handler/ha_innodb.h, handler/handler0alter.cc:
|
|
Fix Bug#41680 calls to trx_allocate_for_mysql are not consistent
|
|
|
|
2009-01-07 The InnoDB Team
|
|
|
|
* mysql-test/innodb_bug41904.result, mysql-test/innodb_bug41904.test,
|
|
row/row0merge.c:
|
|
Fix Bug#41904 create unique index problem
|
|
|
|
2009-01-02 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, include/srv0srv.h, mem/mem0pool.c,
|
|
mysql-test/innodb-use-sys-malloc-master.opt,
|
|
mysql-test/innodb-use-sys-malloc.result,
|
|
mysql-test/innodb-use-sys-malloc.test, srv/srv0srv.c, srv/srv0start.c:
|
|
Implement the configuration parameter innodb_use_sys_malloc (false by
|
|
default), for disabling InnoDB's internal memory allocator and using
|
|
system malloc/free instead. The "BUFFER POOL AND MEMORY" section of
|
|
SHOW ENGINE INNODB STATUS will report "in additional pool allocated
|
|
allocated 0" when innodb_use_sys_malloc is set.
|
|
|
|
2008-12-30 The InnoDB Team
|
|
|
|
* btr/btr0btr.c:
|
|
When setting the PAGE_LEVEL of a compressed B-tree page from or to 0,
|
|
compress the page at the same time. This is necessary, because the
|
|
column information stored on the compressed page will differ between
|
|
leaf and non-leaf pages. Leaf pages are identified by PAGE_LEVEL=0.
|
|
This bug can make InnoDB crash when all rows of a compressed table are
|
|
deleted.
|
|
|
|
2008-12-17 The InnoDB Team
|
|
|
|
* include/row0sel.h, include/row0upd.h, pars/pars0pars.c,
|
|
row/row0mysql.c, row/row0sel.c, row/row0upd.c:
|
|
Remove update-in-place select from the internal SQL interpreter. It
|
|
was only used for updating the InnoDB internal data dictionary when
|
|
renaming or dropping tables. It could have caused deadlocks when
|
|
acquiring latches on insert buffer bitmap pages.
|
|
|
|
2008-12-17 The InnoDB Team
|
|
|
|
* btr/btr0sea.c, buf/buf0buf.c, buf/buf0lru.c, ha/ha0ha.c,
|
|
ha/hash0hash.c, include/buf0buf.h, include/ha0ha.h, include/ha0ha.ic,
|
|
include/hash0hash.h, include/univ.i:
|
|
Introduce the preprocessor symbol UNIV_AHI_DEBUG for enabling adaptive
|
|
hash index debugging independently of UNIV_DEBUG.
|
|
|
|
2008-12-16 The InnoDB Team
|
|
|
|
* btr/btr0cur.c:
|
|
Do not update the free bits in the insert buffer bitmap when inserting
|
|
or deleting from the insert buffer B-tree. Assert that records in the
|
|
insert buffer B-tree are never updated.
|
|
|
|
2008-12-12 The InnoDB Team
|
|
|
|
* buf/buf0buf.c, fil/fil0fil.c, fsp/fsp0fsp.c, ibuf/ibuf0ibuf.c,
|
|
include/fil0fil.h, include/ibuf0ibuf.h, include/ibuf0ibuf.ic,
|
|
include/ibuf0types.h:
|
|
Clean up the insert buffer subsystem so that only one insert
|
|
buffer B-tree exists.
|
|
Originally, there were provisions in InnoDB for multiple insert
|
|
buffer B-trees, apparently one for each tablespace.
|
|
When Heikki Tuuri implemented multiple InnoDB tablespaces in
|
|
MySQL/InnoDB 4.1, he made the insert buffer live only in the
|
|
system tablespace (space 0) but left the provisions in the code.
|
|
|
|
2008-12-11 The InnoDB Team
|
|
|
|
* include/srv0srv.h, os/os0proc.c, srv/srv0srv.c:
|
|
Fix the issue that the InnoDB plugin fails if innodb_buffer_pool_size
|
|
is defined bigger than 4096M on 64-bit Windows. This bug should not
|
|
have affected other 64-bit systems.
|
|
|
|
2008-12-09 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc:
|
|
Fix Bug#40386 Not flushing query cache after truncate.
|
|
|
|
2008-12-09 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, srv/srv0srv.c, trx/trx0trx.c:
|
|
Fix Bug#40760 "set global innodb_thread_concurrency = 0;" is not safe
|
|
|
|
2008-12-04 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, handler/mysql_addons.cc,
|
|
include/mysql_addons.h, trx/trx0i_s.c, win-plugin/win-plugin.diff:
|
|
Remove dependencies to MySQL internals (defining MYSQL_SERVER).
|
|
|
|
2008-12-02 The InnoDB Team
|
|
|
|
* page/page0cur.c:
|
|
When allocating space for a record from the free list of previously
|
|
purged records, zero out the DB_TRX_ID and DB_ROLL_PTR of the purged
|
|
record if the new record would not overwrite these fields. This fixes
|
|
a harmless content mismatch reported by page_zip_validate().
|
|
|
|
2008-12-02 The InnoDB Team
|
|
|
|
* row/row0merge.c:
|
|
Replace the WHILE 1 with WHILE 1=1 in the SQL procedure, so that the
|
|
loop will actually be entered and temporary indexes be dropped during
|
|
crash recovery.
|
|
|
|
2008-12-01 The InnoDB Team
|
|
|
|
InnoDB Plugin 1.0.2 released
|
|
|
|
2008-10-31 The InnoDB Team
|
|
|
|
* dict/dict0mem.c, include/dict0mem.h, include/lock0lock.h,
|
|
include/row0mysql.h, include/trx0trx.h, include/univ.i,
|
|
include/ut0vec.h, include/ut0vec.ic, lock/lock0lock.c,
|
|
row/row0mysql.c, trx/trx0trx.c:
|
|
Fix Bug#26316 Triggers create duplicate entries on auto-increment
|
|
columns
|
|
|
|
2008-10-30 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, handler/handler0vars.h,
|
|
handler/win_delay_loader.cc, mysql-test/innodb_bug40360.result,
|
|
mysql-test/innodb_bug40360.test:
|
|
Fix Bug#40360 Binlog related errors with binlog off
|
|
|
|
2008-10-29 The InnoDB Team
|
|
|
|
* include/data0type.ic:
|
|
Fix Bug#40369 dtype_get_sql_null_size() returns 0 or 1, not the size
|
|
|
|
2008-10-29 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, include/srv0srv.h, srv/srv0srv.c:
|
|
Fix Bug#38189 innodb_stats_on_metadata missing
|
|
|
|
2008-10-28 The InnoDB Team
|
|
|
|
* CMakeLists.txt, ha_innodb.def, handler/ha_innodb.cc,
|
|
handler/handler0alter.cc, handler/handler0vars.h, handler/i_s.cc,
|
|
handler/win_delay_loader.cc, win-plugin/*:
|
|
Implemented the delayloading of externals for the plugin on Windows.
|
|
This makes it possible to build a dynamic plugin (ha_innodb.dll) on
|
|
Windows.
|
|
|
|
2008-10-27 The InnoDB Team
|
|
|
|
* CMakeLists.txt:
|
|
Fix Bug#19424 InnoDB: Possibly a memory overrun of the buffer being
|
|
freed (64-bit Visual C)
|
|
|
|
2008-10-23 The InnoDB Team
|
|
|
|
* ibuf/ibuf0ibuf.c:
|
|
ibuf_delete_rec(): When the cursor to the insert buffer record
|
|
cannot be restored, do not complain if the tablespace does not
|
|
exist, because the insert buffer record may have been discarded by
|
|
some other thread. This bug has existed in MySQL/InnoDB since
|
|
version 4.1, when innodb_file_per_table was implemented.
|
|
This may fix Bug#27276 InnoDB Error: ibuf cursor restoration fails.
|
|
|
|
2008-10-22 The InnoDB Team
|
|
|
|
* dict/dict0dict.c, dict/dict0mem.c, handler/ha_innodb.cc,
|
|
handler/ha_innodb.h, include/dict0dict.h, include/dict0mem.h,
|
|
row/row0mysql.c:
|
|
Fix Bug#39830 Table autoinc value not updated on first insert
|
|
Fix Bug#35498 Cannot get table test/table1 auto-inccounter value in
|
|
::info
|
|
Fix Bug#36411 "Failed to read auto-increment value from storage
|
|
engine" in 5.1.24 auto-inc
|
|
|
|
2008-10-22 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, include/row0mysql.h, row/row0mysql.c:
|
|
Fix Bug#40224 New AUTOINC changes mask reporting of deadlock/timeout
|
|
errors
|
|
|
|
2008-10-16 The InnoDB Team
|
|
|
|
* dict/dict0dict.c, mysql-test/innodb-index.result,
|
|
mysql-test/innodb-index.test:
|
|
Skip the undo log size check when creating REDUNDANT and COMPACT
|
|
tables. In ROW_FORMAT=DYNAMIC and ROW_FORMAT=COMPRESSED, column
|
|
prefix indexes require that prefixes of externally stored columns
|
|
be written to the undo log. This may make the undo log record
|
|
bigger than the record on the B-tree page. The maximum size of an
|
|
undo log record is the page size. That must be checked for, in
|
|
dict_index_add_to_cache(). However, this restriction must not
|
|
be enforced on REDUNDANT or COMPACT tables.
|
|
|
|
2008-10-15 The InnoDB Team
|
|
|
|
* btr/btr0cur.c, include/btr0cur.h, row/row0ext.c, row/row0sel.c,
|
|
row/row0upd.c:
|
|
When the server crashes while freeing an externally stored column
|
|
of a compressed table, the BTR_EXTERN_LEN field in the BLOB
|
|
pointer will be written as 0. Tolerate this in the functions that
|
|
deal with externally stored columns. This fixes problems after
|
|
crash recovery, in the rollback of incomplete transactions, and in
|
|
the purge of delete-marked records.
|
|
|
|
2008-10-15 The InnoDB Team
|
|
|
|
* btr/btr0btr.c, include/page0zip.h, page/page0zip.c, include/univ.i:
|
|
When a B-tree node of a compressed table is split or merged, the
|
|
compression may fail. In this case, the entire compressed page
|
|
will be copied and the excess records will be deleted. However,
|
|
page_zip_copy(), now renamed to page_zip_copy_recs(), copied too
|
|
many fields in the page header, overwriting PAGE_BTR_SEG_LEAF and
|
|
PAGE_BTR_SEG_TOP when splitting the B-tree root. This caused
|
|
corruption of compressed tables. Furthermore, the lock table and
|
|
the adaptive hash index would be corrupted, because we forgot to
|
|
update them when invoking page_zip_copy_recs().
|
|
|
|
Introduce the symbol UNIV_ZIP_DEBUG for triggering the copying of
|
|
compressed pages more often, for debugging purposes.
|
|
|
|
2008-10-10 The InnoDB Team
|
|
|
|
* handler/handler0alter.cc, include/row0merge.h, row/row0merge.c,
|
|
row/row0mysql.c:
|
|
Fix some locking issues, mainly in fast index creation. The
|
|
InnoDB data dictionary cache should be latched whenever a
|
|
transaction is holding locks on any data dictionary tables.
|
|
Otherwise, lock waits or deadlocks could occur. Furthermore, the
|
|
data dictionary transaction must be committed (and the locks
|
|
released) before the data dictionary latch is released.
|
|
|
|
ha_innobase::add_index(): Lock the data dictionary before renaming
|
|
or dropping the created indexes, because neither operation will
|
|
commit the data dictionary transaction.
|
|
|
|
ha_innobase::final_drop_index(): Commit the transactions before
|
|
unlocking the data dictionary.
|
|
|
|
2008-10-09 The InnoDB Team
|
|
|
|
* buf/buf0lru.c:
|
|
Fix Bug#39939 DROP TABLE/DISCARD TABLESPACE takes long time in
|
|
buf_LRU_invalidate_tablespace()
|
|
|
|
2008-10-08 The InnoDB Team
|
|
|
|
* dict/dict0crea.c, trx/trx0roll.c, include/row0mysql.h,
|
|
row/row0merge.c, row/row0mysql.c:
|
|
When dropping a table, hold the data dictionary latch until the
|
|
transaction has been committed. The data dictionary latch is
|
|
supposed to prevent lock waits and deadlocks in the data
|
|
dictionary tables. Due to this bug, DROP TABLE could cause a
|
|
deadlock or hang. Note that because of Bug#33650 and Bug#39833,
|
|
MySQL may also drop a (temporary) table when executing CREATE INDEX
|
|
or ALTER TABLE ... ADD INDEX.
|
|
|
|
2008-10-04 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, mysql-test/innodb_bug39438-master.opt,
|
|
mysql-test/innodb_bug39438.result, mysql-test/innodb_bug39438.test:
|
|
Fix Bug#39438 Testcase for Bug#39436 crashes on 5.1 in
|
|
fil_space_get_latch
|
|
|
|
2008-10-04 The InnoDB Team
|
|
|
|
* include/lock0lock.h, lock/lock0lock.c,
|
|
mysql-test/innodb_bug38231.result, mysql-test/innodb_bug38231.test,
|
|
row/row0mysql.c:
|
|
Fix Bug#38231 Innodb crash in lock_reset_all_on_table() on TRUNCATE +
|
|
LOCK / UNLOCK
|
|
|
|
2008-10-04 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc:
|
|
Fix Bug#35498 Cannot get table test/table1 auto-inccounter value in
|
|
::info
|
|
|
|
2008-10-04 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, handler/ha_innodb.h:
|
|
Fix Bug#37788 InnoDB Plugin: AUTO_INCREMENT wrong for compressed
|
|
tables
|
|
|
|
2008-10-04 The InnoDB Team
|
|
|
|
* dict/dict0dict.c, handler/ha_innodb.cc, handler/ha_innodb.h,
|
|
include/dict0dict.h, include/dict0mem.h, row/row0mysql.c:
|
|
Fix Bug#39830 Table autoinc value not updated on first insert
|
|
|
|
2008-10-03 The InnoDB Team
|
|
|
|
* mysql-test/innodb-index.test, mysql-test/innodb-index.result,
|
|
mysql-test/innodb-timeout.test, mysql-test/innodb-timeout.result,
|
|
srv/srv0srv.c, include/srv0srv.h, handler/ha_innodb.cc,
|
|
include/ha_prototypes.h:
|
|
Fix Bug#36285 innodb_lock_wait_timeout is not dynamic, not per session
|
|
|
|
2008-09-19 The InnoDB Team
|
|
|
|
* os/os0proc.c:
|
|
Fix a memory leak on Windows. The memory leak was due to wrong
|
|
parameters passed into VirtualFree() call. As the result, the
|
|
call fails with Windows error 87.
|
|
|
|
2008-09-17 The InnoDB Team
|
|
|
|
* mysql-test/innodb.result, mysql-test/innodb-zip.result,
|
|
mysql-test/innodb-zip.test, mysql-test/innodb.test, ibuf/ibuf0ibuf.c,
|
|
dict/dict0crea.c, dict/dict0load.c, dict/dict0boot.c,
|
|
include/dict0dict.h, include/trx0trx.h, dict/dict0dict.c,
|
|
trx/trx0trx.c, include/ha_prototypes.h, handler/ha_innodb.cc:
|
|
When creating an index in innodb_strict_mode, check that the
|
|
maximum record size will never exceed the B-tree page size limit.
|
|
For uncompressed tables, there should always be enough space for
|
|
two records in an empty B-tree page. For compressed tables, there
|
|
should be enough space for storing two node pointer records or one
|
|
data record in an empty page in uncompressed format.
|
|
The purpose of this check is to guarantee that INSERT or UPDATE
|
|
will never fail due to too big record size.
|
|
|
|
2008-09-17 The InnoDB Team
|
|
|
|
* btr/btr0cur.c, data/data0data.c, include/page0zip.h,
|
|
include/page0zip.ic, page/page0zip.c, mysql-test/innodb_bug36172.test:
|
|
Prevent infinite B-tree page splits in compressed tables by
|
|
ensuring that there will always be enough space for two node
|
|
pointer records in an empty B-tree page. Also, require that at
|
|
least one data record will fit in an empty compressed page. This
|
|
will reduce the maximum size of records in compressed tables.
|
|
|
|
2008-09-09 The InnoDB Team
|
|
|
|
* mysql-test/innodb.result:
|
|
Fix the failing innodb test by merging changes that MySQL made to
|
|
that file (r2646.12.1 in MySQL BZR repository)
|
|
|
|
2008-09-09 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, mysql-test/innodb-autoinc.result,
|
|
mysql-test/innodb-autoinc.test:
|
|
Fix Bug#38839 auto increment does not work properly with InnoDB after
|
|
update
|
|
|
|
2008-09-09 The InnoDB Team
|
|
|
|
* dict/dict0dict.c, handler/handler0alter.cc, include/dict0dict.h,
|
|
mysql-test/innodb-index.result, mysql-test/innodb-index.test:
|
|
Fix Bug#38786 InnoDB plugin crashes on drop table/create table with FK
|
|
|
|
2008-08-21 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, include/ha_prototypes.h, row/row0sel.c:
|
|
Fix Bug#37885 row_search_for_mysql may gap lock unnecessarily with SQL
|
|
comments in query
|
|
|
|
2008-08-21 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc:
|
|
Fix Bug#38185 ha_innobase::info can hold locks even when called with
|
|
HA_STATUS_NO_LOCK
|
|
|
|
2008-08-18 The InnoDB Team
|
|
|
|
* buf/buf0buf.c, buf/buf0lru.c, include/buf0buf.ic, include/univ.i:
|
|
Introduce UNIV_LRU_DEBUG for debugging the LRU buffer pool cache
|
|
|
|
2008-08-08 The InnoDB Team
|
|
|
|
* buf/buf0lru.c, include/buf0buf.h:
|
|
Fix two recovery bugs that could lead to a crash in debug builds with
|
|
small buffer size
|
|
|
|
2008-08-07 The InnoDB Team
|
|
|
|
* btr/btr0cur.c, handler/ha_innodb.cc, include/srv0srv.h,
|
|
srv/srv0srv.c:
|
|
Add a parameter innodb_stats_sample_pages to allow users to control
|
|
the number of index dives when InnoDB estimates the cardinality of
|
|
an index (ANALYZE TABLE, SHOW TABLE STATUS etc)
|
|
|
|
2008-08-07 The InnoDB Team
|
|
|
|
* trx/trx0i_s.c:
|
|
Fix a bug that would lead to a crash if a SELECT was issued from the
|
|
INFORMATION_SCHEMA tables and there are rolling back transactions at
|
|
the same time
|
|
|
|
2008-08-06 The InnoDB Team
|
|
|
|
* btr/btr0btr.c, btr/btr0cur.c, ibuf/ibuf0ibuf.c, include/btr0cur.h,
|
|
include/trx0roll.h, include/trx0types.h, row/row0purge.c,
|
|
row/row0uins.c, row/row0umod.c, trx/trx0roll.c:
|
|
In the rollback of incomplete transactions after crash recovery,
|
|
tolerate clustered index records whose externally stored columns
|
|
have not been written.
|
|
|
|
2008-07-30 The InnoDB Team
|
|
|
|
* trx/trx0trx.c:
|
|
Fixes a race in recovery where the recovery thread recovering a
|
|
PREPARED trx and the background rollback thread can both try
|
|
to free the trx after its status is set to COMMITTED_IN_MEMORY.
|
|
|
|
2008-07-29 The InnoDB Team
|
|
|
|
* include/trx0rec.h, row/row0purge.c, row/row0vers.c, trx/trx0rec.c:
|
|
Fix a BLOB corruption bug
|
|
|
|
2008-07-15 The InnoDB Team
|
|
|
|
* btr/btr0sea.c, dict/dict0dict.c, include/btr0sea.h:
|
|
Fixed a timing hole where a thread dropping an index can free the
|
|
in-memory index struct while another thread is still using that
|
|
structure to remove entries from adaptive hash index belonging
|
|
to one of the pages that belongs to the index being dropped.
|
|
|
|
2008-07-04 The InnoDB Team
|
|
|
|
* mysql-test/innodb-index.result:
|
|
Fix the failing innodb-index test by adjusting the result to a new
|
|
MySQL behavior (the change occured in BZR-r2667)
|
|
|
|
2008-07-03 The InnoDB Team
|
|
|
|
* mysql-test/innodb-zip.result, mysql-test/innodb-zip.test:
|
|
Remove the negative test cases that produce warnings
|
|
|
|
2008-07-02 The InnoDB Team
|
|
|
|
* mysql-test/innodb-replace.result, mysql-test/innodb-index.test:
|
|
Disable part of innodb-index test because MySQL changed its behavior
|
|
and is not calling ::add_index() anymore when adding primary index on
|
|
non-NULL column
|
|
|
|
2008-07-01 The InnoDB Team
|
|
|
|
* mysql-test/innodb-replace.result, mysql-test/innodb-replace.test:
|
|
Fix the failing innodb-replace test by merging changes that MySQL
|
|
made to that file (r2659 in MySQL BZR repository)
|
|
|
|
2008-07-01 The InnoDB Team
|
|
|
|
* lock/lock0lock.c:
|
|
Fix Bug#36942 Performance problem in lock_get_n_rec_locks (SHOW INNODB
|
|
STATUS)
|
|
|
|
2008-07-01 The InnoDB Team
|
|
|
|
* ha/ha0ha.c:
|
|
Fix Bug#36941 Performance problem in ha_print_info (SHOW INNODB
|
|
STATUS)
|
|
|
|
2008-07-01 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, mysql-test/innodb-autoinc.result,
|
|
mysql-test/innodb-autoinc.test:
|
|
Fix Bug#37531 After truncate, auto_increment behaves incorrectly for
|
|
InnoDB
|
|
|
|
2008-06-19 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc:
|
|
Rewrite the function innodb_plugin_init() to support parameters in
|
|
different order (in static and dynamic InnoDB) and to support more
|
|
parameters in the static InnoDB
|
|
|
|
2008-06-19 The InnoDB Team
|
|
|
|
* handler/handler0alter.cc:
|
|
Fix a bug in ::add_index() which set the transaction state to "active"
|
|
but never restored it to the original value. This bug caused warnings
|
|
to be printed by the rpl.rpl_ddl mysql-test.
|
|
|
|
2008-06-19 The InnoDB Team
|
|
|
|
* mysql-test/patches:
|
|
Add a directory which contains patches, which need to be applied to
|
|
MySQL source in order to get some mysql-tests to succeed. The patches
|
|
cannot be committed in MySQL repository because they are specific to
|
|
the InnoDB plugin.
|
|
|
|
2008-06-19 The InnoDB Team
|
|
|
|
* mysql-test/innodb-zip.result, mysql-test/innodb-zip.test,
|
|
row/row0row.c:
|
|
Fix an anomaly when updating a record with BLOB prefix
|
|
|
|
2008-06-18 The InnoDB Team
|
|
|
|
* include/trx0sys.h, srv/srv0start.c, trx/trx0sys.c:
|
|
Fix a bug in recovery which was a side effect of the file_format_check
|
|
changes
|
|
|
|
2008-06-09 The InnoDB Team
|
|
|
|
* mysql-test/innodb.result:
|
|
Fix the failing innodb test by merging changes that MySQL made to that
|
|
file
|
|
|
|
2008-06-06 The InnoDB Team
|
|
|
|
* buf/buf0buf.c, handler/ha_innodb.cc, include/buf0buf.h,
|
|
include/srv0srv.h, srv/srv0srv.c:
|
|
Fix Bug#36600 SHOW STATUS takes a lot of CPU in
|
|
buf_get_latched_pages_number
|
|
|
|
* handler/ha_innodb.cc, os/os0file.c:
|
|
Fix Bug#11894 innodb_file_per_table crashes w/ Windows .sym symbolic
|
|
link hack
|
|
|
|
* include/ut0ut.h, srv/srv0srv.c, ut/ut0ut.c:
|
|
Fix Bug#36819 ut_usectime does not handle errors from gettimeofday
|
|
|
|
* handler/ha_innodb.cc:
|
|
Fix Bug#35602 Failed to read auto-increment value from storage engine
|
|
|
|
* srv/srv0start.c:
|
|
Fix Bug#36149 Read buffer overflow in srv0start.c found during "make
|
|
test"
|
|
|
|
2008-05-08 The InnoDB Team
|
|
|
|
* btr/btr0btr.c, mysql-test/innodb_bug36172.result,
|
|
mysql-test/innodb_bug36172.test:
|
|
Fix Bug#36172 insert into compressed innodb table crashes
|
|
|
|
2008-05-08 The InnoDB Team
|
|
|
|
InnoDB Plugin 1.0.1 released
|
|
|
|
2008-05-06 The InnoDB Team
|
|
|
|
* handler/ha_innodb.cc, include/srv0srv.h, include/sync0sync.h,
|
|
include/trx0sys.h, mysql-test/innodb-zip.result,
|
|
mysql-test/innodb-zip.test, srv/srv0srv.c, srv/srv0start.c,
|
|
sync/sync0sync.c, trx/trx0sys.c:
|
|
Implement the system tablespace tagging
|
|
|
|
* handler/ha_innodb.cc, handler/i_s.cc, include/univ.i,
|
|
srv/srv0start.c:
|
|
Add InnoDB version in INFORMATION_SCHEMA.PLUGINS.PLUGIN_VERSION,
|
|
in the startup message and in a server variable innodb_version.
|
|
|
|
* sync/sync0sync.c:
|
|
Fix a bug in the sync debug code where a lock with level
|
|
SYNC_LEVEL_VARYING would cause an assertion failure when a thread
|
|
tried to release it.
|
|
|
|
2008-04-30 The InnoDB Team
|
|
|
|
* Makefile.am:
|
|
Fix Bug#36434 ha_innodb.so is installed in the wrong directory
|
|
|
|
* handler/ha_innodb.cc:
|
|
Merge change from MySQL (Fix Bug#35406 5.1-opt crashes on select from
|
|
I_S.REFERENTIAL_CONSTRAINTS):
|
|
ChangeSet@1.2563, 2008-03-18 19:42:04+04:00, gluh@mysql.com +1 -0
|
|
|
|
* scripts/install_innodb_plugins.sql:
|
|
Added
|
|
|
|
* mysql-test/innodb.result:
|
|
Merge change from MySQL (this fixes the failing innodb test):
|
|
ChangeSet@1.1810.3601.4, 2008-02-07 02:33:21+04:00
|
|
|
|
* row/row0sel.c:
|
|
Fix Bug#35226 RBR event crashes slave
|
|
|
|
* handler/ha_innodb.cc:
|
|
Change the fix for Bug#32440 to show bytes instead of kilobytes in
|
|
INFORMATION_SCHEMA.TABLES.DATA_FREE
|
|
|
|
* handler/ha_innodb.cc, mysql-test/innodb.result,
|
|
mysql-test/innodb.test:
|
|
Fix Bug#29507 TRUNCATE shows to many rows effected
|
|
|
|
* handler/ha_innodb.cc, mysql-test/innodb.result,
|
|
mysql-test/innodb.test:
|
|
Fix Bug#35537 Innodb doesn't increment handler_update and
|
|
handler_delete
|
|
|
|
2008-04-29 The InnoDB Team
|
|
|
|
* handler/i_s.cc, include/srv0start.h, srv/srv0start.c:
|
|
Fix Bug#36310 InnoDB plugin crash
|
|
|
|
2008-04-23 The InnoDB Team
|
|
|
|
* mysql-test/innodb_bug36169.result, mysql-test/innodb_bug36169.test,
|
|
row/row0mysql.c:
|
|
Fix Bug#36169 create innodb compressed table with too large row size
|
|
crashed
|
|
|
|
* (outside the source tree):
|
|
Fix Bug#36222 New InnoDB plugin 1.0 has wrong MKDIR_P defined in
|
|
Makefile.in
|
|
|
|
2008-04-15 The InnoDB Team
|
|
|
|
InnoDB Plugin 1.0.0 released
|