Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
74c32d69
Commit
74c32d69
authored
Aug 28, 2010
by
Vasil Dimov
Browse files
Options
Browse Files
Download
Plain Diff
Merge mysql-5.1-innodb -> mysql-5.1-bugteam
parents
1087cfc4
72ec16b1
Changes
20
Show whitespace changes
Inline
Side-by-side
Showing
20 changed files
with
365 additions
and
136 deletions
+365
-136
mysql-test/collections/default.experimental
mysql-test/collections/default.experimental
+2
-0
storage/innobase/dict/dict0dict.c
storage/innobase/dict/dict0dict.c
+37
-25
storage/innobase/fil/fil0fil.c
storage/innobase/fil/fil0fil.c
+87
-17
storage/innobase/fsp/fsp0fsp.c
storage/innobase/fsp/fsp0fsp.c
+49
-0
storage/innobase/handler/ha_innodb.cc
storage/innobase/handler/ha_innodb.cc
+57
-38
storage/innobase/include/db0err.h
storage/innobase/include/db0err.h
+6
-0
storage/innobase/include/fil0fil.h
storage/innobase/include/fil0fil.h
+12
-2
storage/innobase/include/univ.i
storage/innobase/include/univ.i
+6
-0
storage/innodb_plugin/ChangeLog
storage/innodb_plugin/ChangeLog
+17
-0
storage/innodb_plugin/btr/btr0sea.c
storage/innodb_plugin/btr/btr0sea.c
+2
-0
storage/innodb_plugin/dict/dict0dict.c
storage/innodb_plugin/dict/dict0dict.c
+35
-23
storage/innodb_plugin/ha/ha0ha.c
storage/innodb_plugin/ha/ha0ha.c
+2
-0
storage/innodb_plugin/handler/ha_innodb.cc
storage/innodb_plugin/handler/ha_innodb.cc
+25
-23
storage/innodb_plugin/include/btr0sea.h
storage/innodb_plugin/include/btr0sea.h
+4
-0
storage/innodb_plugin/include/ha0ha.h
storage/innodb_plugin/include/ha0ha.h
+2
-0
storage/innodb_plugin/include/univ.i
storage/innodb_plugin/include/univ.i
+1
-1
storage/innodb_plugin/include/ut0mem.h
storage/innodb_plugin/include/ut0mem.h
+2
-1
storage/innodb_plugin/row/row0sel.c
storage/innodb_plugin/row/row0sel.c
+12
-3
storage/innodb_plugin/trx/trx0undo.c
storage/innodb_plugin/trx/trx0undo.c
+2
-1
storage/innodb_plugin/ut/ut0mem.c
storage/innodb_plugin/ut/ut0mem.c
+5
-2
No files found.
mysql-test/collections/default.experimental
View file @
74c32d69
...
@@ -12,6 +12,8 @@ funcs_1.ndb* # joro : NDB tests marked as experiment
...
@@ -12,6 +12,8 @@ funcs_1.ndb* # joro : NDB tests marked as experiment
funcs_2.ndb_charset # joro : NDB tests marked as experimental as agreed with bochklin
funcs_2.ndb_charset # joro : NDB tests marked as experimental as agreed with bochklin
innodb_plugin.* @solaris # Bug#56063 InnoDB Plugin mysql-tests fail on Solaris
main.ctype_gbk_binlog @solaris # Bug#46010: main.ctype_gbk_binlog fails sporadically : Table 't2' already exists
main.ctype_gbk_binlog @solaris # Bug#46010: main.ctype_gbk_binlog fails sporadically : Table 't2' already exists
main.func_str @solaris # joro: Bug#40928
main.func_str @solaris # joro: Bug#40928
main.sp @solaris # joro : Bug#54138
main.sp @solaris # joro : Bug#54138
...
...
storage/innobase/dict/dict0dict.c
View file @
74c32d69
...
@@ -616,8 +616,7 @@ dict_table_get_on_id(
...
@@ -616,8 +616,7 @@ dict_table_get_on_id(
{
{
dict_table_t
*
table
;
dict_table_t
*
table
;
if
(
ut_dulint_cmp
(
table_id
,
DICT_FIELDS_ID
)
<=
0
if
(
trx
->
dict_operation_lock_mode
==
RW_X_LATCH
)
{
||
trx
->
dict_operation_lock_mode
==
RW_X_LATCH
)
{
/* Note: An X latch implies that the transaction
/* Note: An X latch implies that the transaction
already owns the dictionary mutex. */
already owns the dictionary mutex. */
...
@@ -2140,7 +2139,7 @@ dict_foreign_add_to_cache(
...
@@ -2140,7 +2139,7 @@ dict_foreign_add_to_cache(
mem_heap_free
(
foreign
->
heap
);
mem_heap_free
(
foreign
->
heap
);
}
}
return
(
DB_
CANNOT_ADD_CONSTRAINT
);
return
(
DB_
FOREIGN_NO_INDEX
);
}
}
for_in_cache
->
referenced_table
=
ref_table
;
for_in_cache
->
referenced_table
=
ref_table
;
...
@@ -2184,7 +2183,7 @@ dict_foreign_add_to_cache(
...
@@ -2184,7 +2183,7 @@ dict_foreign_add_to_cache(
mem_heap_free
(
foreign
->
heap
);
mem_heap_free
(
foreign
->
heap
);
}
}
return
(
DB_
CANNOT_ADD_CONSTRAINT
);
return
(
DB_
REFERENCING_NO_INDEX
);
}
}
for_in_cache
->
foreign_table
=
for_table
;
for_in_cache
->
foreign_table
=
for_table
;
...
@@ -3754,7 +3753,6 @@ dict_update_statistics_low(
...
@@ -3754,7 +3753,6 @@ dict_update_statistics_low(
dictionary mutex */
dictionary mutex */
{
{
dict_index_t
*
index
;
dict_index_t
*
index
;
ulint
size
;
ulint
sum_of_index_sizes
=
0
;
ulint
sum_of_index_sizes
=
0
;
if
(
table
->
ibd_file_missing
)
{
if
(
table
->
ibd_file_missing
)
{
...
@@ -3770,14 +3768,6 @@ dict_update_statistics_low(
...
@@ -3770,14 +3768,6 @@ dict_update_statistics_low(
return
;
return
;
}
}
/* If we have set a high innodb_force_recovery level, do not calculate
statistics, as a badly corrupted index can cause a crash in it. */
if
(
srv_force_recovery
>=
SRV_FORCE_NO_IBUF_MERGE
)
{
return
;
}
/* Find out the sizes of the indexes and how many different values
/* Find out the sizes of the indexes and how many different values
for the key they approximately have */
for the key they approximately have */
...
@@ -3789,7 +3779,13 @@ dict_update_statistics_low(
...
@@ -3789,7 +3779,13 @@ dict_update_statistics_low(
return
;
return
;
}
}
while
(
index
)
{
do
{
if
(
UNIV_LIKELY
(
srv_force_recovery
<
SRV_FORCE_NO_IBUF_MERGE
||
(
srv_force_recovery
<
SRV_FORCE_NO_LOG_REDO
&&
(
index
->
type
&
DICT_CLUSTERED
))))
{
ulint
size
;
size
=
btr_get_size
(
index
,
BTR_TOTAL_SIZE
);
size
=
btr_get_size
(
index
,
BTR_TOTAL_SIZE
);
index
->
stat_index_size
=
size
;
index
->
stat_index_size
=
size
;
...
@@ -3806,10 +3802,26 @@ dict_update_statistics_low(
...
@@ -3806,10 +3802,26 @@ dict_update_statistics_low(
index
->
stat_n_leaf_pages
=
size
;
index
->
stat_n_leaf_pages
=
size
;
btr_estimate_number_of_different_key_vals
(
index
);
btr_estimate_number_of_different_key_vals
(
index
);
}
else
{
/* If we have set a high innodb_force_recovery
level, do not calculate statistics, as a badly
corrupted index can cause a crash in it.
Initialize some bogus index cardinality
statistics, so that the data can be queried in
various means, also via secondary indexes. */
ulint
i
;
index
=
dict_table_get_next_index
(
index
);
sum_of_index_sizes
++
;
index
->
stat_index_size
=
index
->
stat_n_leaf_pages
=
1
;
for
(
i
=
dict_index_get_n_unique
(
index
);
i
;
)
{
index
->
stat_n_diff_key_vals
[
i
--
]
=
1
;
}
}
}
index
=
dict_table_get_next_index
(
index
);
}
while
(
index
);
index
=
dict_table_get_first_index
(
table
);
index
=
dict_table_get_first_index
(
table
);
table
->
stat_n_rows
=
index
->
stat_n_diff_key_vals
[
table
->
stat_n_rows
=
index
->
stat_n_diff_key_vals
[
...
...
storage/innobase/fil/fil0fil.c
View file @
74c32d69
...
@@ -966,6 +966,8 @@ fil_space_create(
...
@@ -966,6 +966,8 @@ fil_space_create(
HASH_SEARCH
(
name_hash
,
system
->
name_hash
,
ut_fold_string
(
name
),
space
,
HASH_SEARCH
(
name_hash
,
system
->
name_hash
,
ut_fold_string
(
name
),
space
,
0
==
strcmp
(
name
,
space
->
name
));
0
==
strcmp
(
name
,
space
->
name
));
if
(
space
!=
NULL
)
{
if
(
space
!=
NULL
)
{
ibool
success
;
ut_print_timestamp
(
stderr
);
ut_print_timestamp
(
stderr
);
fprintf
(
stderr
,
fprintf
(
stderr
,
" InnoDB: Warning: trying to init to the"
" InnoDB: Warning: trying to init to the"
...
@@ -1002,9 +1004,10 @@ fil_space_create(
...
@@ -1002,9 +1004,10 @@ fil_space_create(
namesake_id
=
space
->
id
;
namesake_id
=
space
->
id
;
mutex_exit
(
&
(
system
->
mutex
));
success
=
fil_space_free
(
namesake_id
,
FALSE
);
ut_a
(
success
);
fil_space_free
(
namesake_id
);
mutex_exit
(
&
(
system
->
mutex
)
);
goto
try_again
;
goto
try_again
;
}
}
...
@@ -1127,6 +1130,33 @@ fil_assign_new_space_id(void)
...
@@ -1127,6 +1130,33 @@ fil_assign_new_space_id(void)
return
(
id
);
return
(
id
);
}
}
/***********************************************************************
Check if the space id exists in the cache, complain to stderr if the
space id cannot be found. */
static
fil_space_t
*
fil_space_search
(
/*=============*/
/* out: file space instance*/
ulint
id
)
/* in: space id */
{
fil_space_t
*
space
;
ut_ad
(
mutex_own
(
&
fil_system
->
mutex
));
HASH_SEARCH
(
hash
,
fil_system
->
spaces
,
id
,
space
,
space
->
id
==
id
);
if
(
space
==
NULL
)
{
ut_print_timestamp
(
stderr
);
fprintf
(
stderr
,
" InnoDB: Error: trying to remove tablespace %lu"
" from the cache but
\n
"
"InnoDB: it is not there.
\n
"
,
(
ulong
)
id
);
}
return
(
space
);
}
/***********************************************************************
/***********************************************************************
Frees a space object from the tablespace memory cache. Closes the files in
Frees a space object from the tablespace memory cache. Closes the files in
the chain but does not delete them. There must not be any pending i/o's or
the chain but does not delete them. There must not be any pending i/o's or
...
@@ -1136,26 +1166,20 @@ ibool
...
@@ -1136,26 +1166,20 @@ ibool
fil_space_free
(
fil_space_free
(
/*===========*/
/*===========*/
/* out: TRUE if success */
/* out: TRUE if success */
ulint
id
)
/* in: space id */
ulint
id
,
/* in: space id */
ibool
x_latched
)
/* in: TRUE if caller has space->latch
in X mode */
{
{
fil_system_t
*
system
=
fil_system
;
fil_system_t
*
system
=
fil_system
;
fil_space_t
*
space
;
fil_space_t
*
space
;
fil_space_t
*
namespace
;
fil_space_t
*
namespace
;
fil_node_t
*
fil_node
;
fil_node_t
*
fil_node
;
mutex_enter
(
&
(
system
->
mutex
));
ut_ad
(
mutex_own
(
&
fil_
system
->
mutex
));
HASH_SEARCH
(
hash
,
system
->
spaces
,
id
,
space
,
space
->
id
==
id
);
space
=
fil_space_search
(
id
);
if
(
!
space
)
{
ut_print_timestamp
(
stderr
);
fprintf
(
stderr
,
" InnoDB: Error: trying to remove tablespace %lu"
" from the cache but
\n
"
"InnoDB: it is not there.
\n
"
,
(
ulong
)
id
);
mutex_exit
(
&
(
system
->
mutex
));
if
(
space
==
NULL
)
{
return
(
FALSE
);
return
(
FALSE
);
}
}
...
@@ -1191,7 +1215,9 @@ fil_space_free(
...
@@ -1191,7 +1215,9 @@ fil_space_free(
ut_a
(
0
==
UT_LIST_GET_LEN
(
space
->
chain
));
ut_a
(
0
==
UT_LIST_GET_LEN
(
space
->
chain
));
mutex_exit
(
&
(
system
->
mutex
));
if
(
x_latched
)
{
rw_lock_x_unlock
(
&
space
->
latch
);
}
rw_lock_free
(
&
(
space
->
latch
));
rw_lock_free
(
&
(
space
->
latch
));
...
@@ -2048,6 +2074,19 @@ fil_delete_tablespace(
...
@@ -2048,6 +2074,19 @@ fil_delete_tablespace(
path
=
mem_strdup
(
space
->
name
);
path
=
mem_strdup
(
space
->
name
);
mutex_exit
(
&
(
system
->
mutex
));
mutex_exit
(
&
(
system
->
mutex
));
/* Important: We rely on the data dictionary mutex to ensure
that a race is not possible here. It should serialize the tablespace
drop/free. We acquire an X latch only to avoid a race condition
when accessing the tablespace instance via:
fsp_get_available_space_in_free_extents().
There our main motivation is to reduce the contention on the
dictionary mutex and not correctness. */
rw_lock_x_lock
(
&
space
->
latch
);
#ifndef UNIV_HOTBACKUP
#ifndef UNIV_HOTBACKUP
/* Invalidate in the buffer pool all pages belonging to the
/* Invalidate in the buffer pool all pages belonging to the
tablespace. Since we have set space->is_being_deleted = TRUE, readahead
tablespace. Since we have set space->is_being_deleted = TRUE, readahead
...
@@ -2060,7 +2099,11 @@ fil_delete_tablespace(
...
@@ -2060,7 +2099,11 @@ fil_delete_tablespace(
#endif
#endif
/* printf("Deleting tablespace %s id %lu\n", space->name, id); */
/* printf("Deleting tablespace %s id %lu\n", space->name, id); */
success
=
fil_space_free
(
id
);
mutex_enter
(
&
system
->
mutex
);
success
=
fil_space_free
(
id
,
TRUE
);
mutex_exit
(
&
system
->
mutex
);
if
(
success
)
{
if
(
success
)
{
success
=
os_file_delete
(
path
);
success
=
os_file_delete
(
path
);
...
@@ -2068,6 +2111,8 @@ fil_delete_tablespace(
...
@@ -2068,6 +2111,8 @@ fil_delete_tablespace(
if
(
!
success
)
{
if
(
!
success
)
{
success
=
os_file_delete_if_exists
(
path
);
success
=
os_file_delete_if_exists
(
path
);
}
}
}
else
{
rw_lock_x_unlock
(
&
space
->
latch
);
}
}
if
(
success
)
{
if
(
success
)
{
...
@@ -4569,3 +4614,28 @@ fil_page_get_type(
...
@@ -4569,3 +4614,28 @@ fil_page_get_type(
return
(
mach_read_from_2
(
page
+
FIL_PAGE_TYPE
));
return
(
mach_read_from_2
(
page
+
FIL_PAGE_TYPE
));
}
}
/***********************************************************************
Returns TRUE if a single-table tablespace is being deleted. */
ibool
fil_tablespace_is_being_deleted
(
/*============================*/
/* out: TRUE if space is being deleted */
ulint
id
)
/* in: space id */
{
fil_space_t
*
space
;
ibool
is_being_deleted
;
mutex_enter
(
&
fil_system
->
mutex
);
HASH_SEARCH
(
hash
,
fil_system
->
spaces
,
id
,
space
,
space
->
id
==
id
);
ut_a
(
space
!=
NULL
);
is_being_deleted
=
space
->
is_being_deleted
;
mutex_exit
(
&
fil_system
->
mutex
);
return
(
is_being_deleted
);
}
storage/innobase/fsp/fsp0fsp.c
View file @
74c32d69
...
@@ -2842,12 +2842,61 @@ fsp_get_available_space_in_free_extents(
...
@@ -2842,12 +2842,61 @@ fsp_get_available_space_in_free_extents(
ut_ad
(
!
mutex_own
(
&
kernel_mutex
));
ut_ad
(
!
mutex_own
(
&
kernel_mutex
));
/* The convoluted mutex acquire is to overcome latching order
issues: The problem is that the fil_mutex is at a lower level
than the tablespace latch and the buffer pool mutex. We have to
first prevent any operations on the file system by acquiring the
dictionary mutex. Then acquire the tablespace latch to obey the
latching order and then release the dictionary mutex. That way we
ensure that the tablespace instance can't be freed while we are
examining its contents (see fil_space_free()).
However, there is one further complication, we release the fil_mutex
when we need to invalidate the the pages in the buffer pool and we
reacquire the fil_mutex when deleting and freeing the tablespace
instance in fil0fil.c. Here we need to account for that situation
too. */
dict_mutex_enter_for_mysql
();
/* At this stage there is no guarantee that the tablespace even
exists in the cache. */
if
(
fil_tablespace_deleted_or_being_deleted_in_mem
(
space
,
-
1
))
{
dict_mutex_exit_for_mysql
();
return
(
ULLINT_UNDEFINED
);
}
mtr_start
(
&
mtr
);
mtr_start
(
&
mtr
);
latch
=
fil_space_get_latch
(
space
);
latch
=
fil_space_get_latch
(
space
);
/* This should ensure that the tablespace instance can't be freed
by another thread. However, the tablespace pages can still be freed
from the buffer pool. We need to check for that again. */
mtr_x_lock
(
latch
,
&
mtr
);
mtr_x_lock
(
latch
,
&
mtr
);
dict_mutex_exit_for_mysql
();
/* At this point it is possible for the tablespace to be deleted and
its pages removed from the buffer pool. We need to check for that
situation. However, the tablespace instance can't be deleted because
our latching above should ensure that. */
if
(
fil_tablespace_is_being_deleted
(
space
))
{
mtr_commit
(
&
mtr
);
return
(
ULLINT_UNDEFINED
);
}
/* From here on even if the user has dropped the tablespace, the
pages _must_ still exist in the buffer pool and the tablespace
instance _must be in the file system hash table. */
space_header
=
fsp_get_space_header
(
space
,
&
mtr
);
space_header
=
fsp_get_space_header
(
space
,
&
mtr
);
size
=
mtr_read_ulint
(
space_header
+
FSP_SIZE
,
MLOG_4BYTES
,
&
mtr
);
size
=
mtr_read_ulint
(
space_header
+
FSP_SIZE
,
MLOG_4BYTES
,
&
mtr
);
...
...
storage/innobase/handler/ha_innodb.cc
View file @
74c32d69
...
@@ -707,7 +707,9 @@ convert_error_code_to_mysql(
...
@@ -707,7 +707,9 @@ convert_error_code_to_mysql(
return
(
HA_ERR_ROW_IS_REFERENCED
);
return
(
HA_ERR_ROW_IS_REFERENCED
);
}
else
if
(
error
==
(
int
)
DB_CANNOT_ADD_CONSTRAINT
)
{
}
else
if
(
error
==
(
int
)
DB_CANNOT_ADD_CONSTRAINT
||
error
==
(
int
)
DB_FOREIGN_NO_INDEX
||
error
==
(
int
)
DB_REFERENCING_NO_INDEX
)
{
return
(
HA_ERR_CANNOT_ADD_FOREIGN
);
return
(
HA_ERR_CANNOT_ADD_FOREIGN
);
...
@@ -6099,6 +6101,8 @@ ha_innobase::rename_table(
...
@@ -6099,6 +6101,8 @@ ha_innobase::rename_table(
innobase_commit_low
(
trx
);
innobase_commit_low
(
trx
);
trx_free_for_mysql
(
trx
);
trx_free_for_mysql
(
trx
);
switch
(
error
)
{
case
DB_DUPLICATE_KEY
:
/* Add a special case to handle the Duplicated Key error
/* Add a special case to handle the Duplicated Key error
and return DB_ERROR instead.
and return DB_ERROR instead.
This is to avoid a possible SIGSEGV error from mysql error
This is to avoid a possible SIGSEGV error from mysql error
...
@@ -6111,10 +6115,28 @@ ha_innobase::rename_table(
...
@@ -6111,10 +6115,28 @@ ha_innobase::rename_table(
the dup key error here is due to an existing table whose name
the dup key error here is due to an existing table whose name
is the one we are trying to rename to) and return the generic
is the one we are trying to rename to) and return the generic
error code. */
error code. */
if
(
error
==
(
int
)
DB_DUPLICATE_KEY
)
{
my_error
(
ER_TABLE_EXISTS_ERROR
,
MYF
(
0
),
to
);
my_error
(
ER_TABLE_EXISTS_ERROR
,
MYF
(
0
),
to
);
error
=
DB_ERROR
;
error
=
DB_ERROR
;
break
;
case
DB_FOREIGN_NO_INDEX
:
push_warning_printf
(
thd
,
MYSQL_ERROR
::
WARN_LEVEL_WARN
,
HA_ERR_CANNOT_ADD_FOREIGN
,
"Alter or rename of table '%s' failed"
" because the new table is a child table"
" in a FK relationship and it does not"
" have an index that contains foreign"
" keys as its prefix columns."
,
norm_to
);
break
;
case
DB_REFERENCING_NO_INDEX
:
push_warning_printf
(
thd
,
MYSQL_ERROR
::
WARN_LEVEL_WARN
,
HA_ERR_CANNOT_ADD_FOREIGN
,
"Alter or rename of table '%s' failed"
" because the new table is a parent table"
" in a FK relationship and it does not"
" have an index that contains foreign"
" keys as its prefix columns."
,
norm_to
);
break
;
}
}
error
=
convert_error_code_to_mysql
(
error
,
NULL
);
error
=
convert_error_code_to_mysql
(
error
,
NULL
);
...
@@ -6343,8 +6365,6 @@ ha_innobase::info(
...
@@ -6343,8 +6365,6 @@ ha_innobase::info(
dict_index_t
*
index
;
dict_index_t
*
index
;
ha_rows
rec_per_key
;
ha_rows
rec_per_key
;
ib_longlong
n_rows
;
ib_longlong
n_rows
;
ulong
j
;
ulong
i
;
char
path
[
FN_REFLEN
];
char
path
[
FN_REFLEN
];
os_file_stat_t
stat_info
;
os_file_stat_t
stat_info
;
...
@@ -6354,16 +6374,6 @@ ha_innobase::info(
...
@@ -6354,16 +6374,6 @@ ha_innobase::info(
statistics calculation on tables, because that may crash the
statistics calculation on tables, because that may crash the
server if an index is badly corrupted. */
server if an index is badly corrupted. */
if
(
srv_force_recovery
>=
SRV_FORCE_NO_IBUF_MERGE
)
{
/* We return success (0) instead of HA_ERR_CRASHED,
because we want MySQL to process this query and not
stop, like it would do if it received the error code
HA_ERR_CRASHED. */
DBUG_RETURN
(
0
);
}
/* We do not know if MySQL can call this function before calling
/* We do not know if MySQL can call this function before calling
external_lock(). To be safe, update the thd of the current table
external_lock(). To be safe, update the thd of the current table
handle. */
handle. */
...
@@ -6458,25 +6468,24 @@ ha_innobase::info(
...
@@ -6458,25 +6468,24 @@ ha_innobase::info(
acquiring latches inside InnoDB, we do not call it if we
acquiring latches inside InnoDB, we do not call it if we
are asked by MySQL to avoid locking. Another reason to
are asked by MySQL to avoid locking. Another reason to
avoid the call is that it uses quite a lot of CPU.
avoid the call is that it uses quite a lot of CPU.
See Bug#38185.
See Bug#38185. */
We do not update delete_length if no locking is requested
if
(
flag
&
HA_STATUS_NO_LOCK
)
{
so the "old" value can remain. delete_length is initialized
/* We do not update delete_length if no
to 0 in the ha_statistics' constructor. */
locking is requested so the "old" value can
if
(
!
(
flag
&
HA_STATUS_NO_LOCK
))
{
remain. delete_length is initialized to 0 in
the ha_statistics' constructor. */
/* lock the data dictionary to avoid races with
}
else
if
(
UNIV_UNLIKELY
ibd_file_missing and tablespace_discarded */
(
srv_force_recovery
>=
SRV_FORCE_NO_IBUF_MERGE
))
{
row_mysql_lock_data_dictionary
(
prebuilt
->
trx
);
/* Avoid accessing the tablespace if
innodb_crash_recovery is set to a high value. */
/* ib_table->space must be an existent tablespace */
stats
.
delete_length
=
0
;
if
(
!
ib_table
->
ibd_file_missing
&&
!
ib_table
->
tablespace_discarded
)
{
stats
.
delete_length
=
fsp_get_available_space_in_free_extents
(
ib_table
->
space
)
*
1024
;
}
else
{
}
else
{
ullint
avail_space
;
avail_space
=
fsp_get_available_space_in_free_extents
(
ib_table
->
space
);
if
(
avail_space
==
ULLINT_UNDEFINED
)
{
THD
*
thd
;
THD
*
thd
;
thd
=
ha_thd
();
thd
=
ha_thd
();
...
@@ -6493,9 +6502,9 @@ ha_innobase::info(
...
@@ -6493,9 +6502,9 @@ ha_innobase::info(
ib_table
->
name
);
ib_table
->
name
);
stats
.
delete_length
=
0
;
stats
.
delete_length
=
0
;
}
else
{
stats
.
delete_length
=
avail_space
*
1024
;
}
}
row_mysql_unlock_data_dictionary
(
prebuilt
->
trx
);
}
}
stats
.
check_time
=
0
;
stats
.
check_time
=
0
;
...
@@ -6508,6 +6517,7 @@ ha_innobase::info(
...
@@ -6508,6 +6517,7 @@ ha_innobase::info(
}
}
if
(
flag
&
HA_STATUS_CONST
)
{
if
(
flag
&
HA_STATUS_CONST
)
{
ulong
i
=
0
;
index
=
dict_table_get_first_index_noninline
(
ib_table
);
index
=
dict_table_get_first_index_noninline
(
ib_table
);
if
(
prebuilt
->
clust_index_was_generated
)
{
if
(
prebuilt
->
clust_index_was_generated
)
{
...
@@ -6515,6 +6525,8 @@ ha_innobase::info(
...
@@ -6515,6 +6525,8 @@ ha_innobase::info(
}
}
for
(
i
=
0
;
i
<
table
->
s
->
keys
;
i
++
)
{
for
(
i
=
0
;
i
<
table
->
s
->
keys
;
i
++
)
{
ulong
j
;
if
(
index
==
NULL
)
{
if
(
index
==
NULL
)
{
sql_print_error
(
"Table %s contains fewer "
sql_print_error
(
"Table %s contains fewer "
"indexes inside InnoDB than "
"indexes inside InnoDB than "
...
@@ -6571,6 +6583,11 @@ ha_innobase::info(
...
@@ -6571,6 +6583,11 @@ ha_innobase::info(
}
}
}
}
if
(
srv_force_recovery
>=
SRV_FORCE_NO_IBUF_MERGE
)
{
goto
func_exit
;
}
if
(
flag
&
HA_STATUS_ERRKEY
)
{
if
(
flag
&
HA_STATUS_ERRKEY
)
{
ut_a
(
prebuilt
->
trx
);
ut_a
(
prebuilt
->
trx
);
ut_a
(
prebuilt
->
trx
->
magic_n
==
TRX_MAGIC_N
);
ut_a
(
prebuilt
->
trx
->
magic_n
==
TRX_MAGIC_N
);
...
@@ -6583,6 +6600,7 @@ ha_innobase::info(
...
@@ -6583,6 +6600,7 @@ ha_innobase::info(
stats
.
auto_increment_value
=
innobase_peek_autoinc
();
stats
.
auto_increment_value
=
innobase_peek_autoinc
();
}
}
func_exit:
prebuilt
->
trx
->
op_info
=
(
char
*
)
""
;
prebuilt
->
trx
->
op_info
=
(
char
*
)
""
;
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
...
@@ -7814,16 +7832,17 @@ ha_innobase::store_lock(
...
@@ -7814,16 +7832,17 @@ ha_innobase::store_lock(
&&
(
lock_type
==
TL_READ
||
lock_type
==
TL_READ_NO_INSERT
)
&&
(
lock_type
==
TL_READ
||
lock_type
==
TL_READ_NO_INSERT
)
&&
(
sql_command
==
SQLCOM_INSERT_SELECT
&&
(
sql_command
==
SQLCOM_INSERT_SELECT
||
sql_command
==
SQLCOM_UPDATE
||
sql_command
==
SQLCOM_UPDATE
||
sql_command
==
SQLCOM_CREATE_TABLE
))
{
||
sql_command
==
SQLCOM_CREATE_TABLE
||
sql_command
==
SQLCOM_SET_OPTION
))
{
/* If we either have innobase_locks_unsafe_for_binlog
/* If we either have innobase_locks_unsafe_for_binlog
option set or this session is using READ COMMITTED
option set or this session is using READ COMMITTED
isolation level and isolation level of the transaction
isolation level and isolation level of the transaction
is not set to serializable and MySQL is doing
is not set to serializable and MySQL is doing
INSERT INTO...SELECT or UPDATE ... = (SELECT ...) or
INSERT INTO...SELECT or UPDATE ... = (SELECT ...) or
CREATE ... SELECT...
without FOR UPDATE or
CREATE ... SELECT...
or SET ... = (SELECT ...)
IN SHARE MODE in select, then we use consistent
without FOR UPDATE or IN SHARE MODE in select,
read for select. */
then we use consistent
read for select. */
prebuilt
->
select_lock_type
=
LOCK_NONE
;
prebuilt
->
select_lock_type
=
LOCK_NONE
;
prebuilt
->
stored_select_lock_type
=
LOCK_NONE
;
prebuilt
->
stored_select_lock_type
=
LOCK_NONE
;
...
...
storage/innobase/include/db0err.h
View file @
74c32d69
...
@@ -73,6 +73,12 @@ Created 5/24/1996 Heikki Tuuri
...
@@ -73,6 +73,12 @@ Created 5/24/1996 Heikki Tuuri
a later version of the engine. */
a later version of the engine. */
#define DB_INTERRUPTED 49
/* the query has been interrupted with
#define DB_INTERRUPTED 49
/* the query has been interrupted with
"KILL QUERY N;" */
"KILL QUERY N;" */
#define DB_FOREIGN_NO_INDEX 50
/* the child (foreign) table does not
have an index that contains the
foreign keys as its prefix columns */
#define DB_REFERENCING_NO_INDEX 51
/* the parent (referencing) table does
not have an index that contains the
foreign keys as its prefix columns */
/* The following are partial failure codes */
/* The following are partial failure codes */
#define DB_FAIL 1000
#define DB_FAIL 1000
...
...
storage/innobase/include/fil0fil.h
View file @
74c32d69
...
@@ -203,7 +203,9 @@ ibool
...
@@ -203,7 +203,9 @@ ibool
fil_space_free
(
fil_space_free
(
/*===========*/
/*===========*/
/* out: TRUE if success */
/* out: TRUE if success */
ulint
id
);
/* in: space id */
ulint
id
,
/* in: space id */
ibool
x_latched
);
/* in: TRUE if caller has space->latch
in X mode */
/***********************************************************************
/***********************************************************************
Returns the size of the space in pages. The tablespace must be cached in the
Returns the size of the space in pages. The tablespace must be cached in the
memory cache. */
memory cache. */
...
@@ -710,6 +712,14 @@ fil_page_get_type(
...
@@ -710,6 +712,14 @@ fil_page_get_type(
written to page, the return value not defined */
written to page, the return value not defined */
byte
*
page
);
/* in: file page */
byte
*
page
);
/* in: file page */
/***********************************************************************
Returns TRUE if a single-table tablespace is being deleted. */
ibool
fil_tablespace_is_being_deleted
(
/*============================*/
/* out: TRUE if space is being deleted */
ulint
id
);
/* in: space id */
typedef
struct
fil_space_struct
fil_space_t
;
typedef
struct
fil_space_struct
fil_space_t
;
...
...
storage/innobase/include/univ.i
View file @
74c32d69
...
@@ -234,6 +234,12 @@ typedef unsigned long long int ullint;
...
@@ -234,6 +234,12 @@ typedef unsigned long long int ullint;
/* Maximum value for a ulint */
/* Maximum value for a ulint */
#
define
ULINT_MAX
((
ulint
)(
-
2
))
#
define
ULINT_MAX
((
ulint
)(
-
2
))
/* THe 'undefined' value for ullint */
#
define
ULLINT_UNDEFINED
((
ullint
)(
-
1
))
/* Maximum value for a ullint */
#
define
ULLINT_MAX
((
ullint
)(
-
2
))
/* This 'ibool' type is used within Innobase. Remember that different included
/* This 'ibool' type is used within Innobase. Remember that different included
headers may define 'bool' differently. Do not assume that 'bool' is a ulint! */
headers may define 'bool' differently. Do not assume that 'bool' is a ulint! */
#
define
ibool
ulint
#
define
ibool
ulint
...
...
storage/innodb_plugin/ChangeLog
View file @
74c32d69
2010-08-24 The InnoDB Team
* handler/ha_innodb.c, dict/dict0dict.c:
Fix Bug #55832 selects crash too easily when innodb_force_recovery>3
2010-08-03 The InnoDB Team
* include/ut0mem.h, ut/ut0mem.c:
Fix Bug #55627 segv in ut_free pars_lexer_close innobase_shutdown
innodb-use-sys-malloc=0
2010-08-01 The InnoDB Team
* handler/ha_innodb.cc
Fix Bug #55382 Assignment with SELECT expressions takes unexpected
S locks in READ COMMITTED
2010-07-27 The InnoDB Team
2010-07-27 The InnoDB Team
* include/mem0pool.h, mem/mem0mem.c, mem/mem0pool.c, srv/srv0start.c:
* include/mem0pool.h, mem/mem0mem.c, mem/mem0pool.c, srv/srv0start.c:
...
...
storage/innodb_plugin/btr/btr0sea.c
View file @
74c32d69
...
@@ -1734,6 +1734,7 @@ btr_search_update_hash_on_insert(
...
@@ -1734,6 +1734,7 @@ btr_search_update_hash_on_insert(
}
}
}
}
#if defined UNIV_AHI_DEBUG || defined UNIV_DEBUG
/********************************************************************//**
/********************************************************************//**
Validates the search system.
Validates the search system.
@return TRUE if ok */
@return TRUE if ok */
...
@@ -1897,3 +1898,4 @@ btr_search_validate(void)
...
@@ -1897,3 +1898,4 @@ btr_search_validate(void)
return
(
ok
);
return
(
ok
);
}
}
#endif
/* defined UNIV_AHI_DEBUG || defined UNIV_DEBUG */
storage/innodb_plugin/dict/dict0dict.c
View file @
74c32d69
...
@@ -568,8 +568,7 @@ dict_table_get_on_id(
...
@@ -568,8 +568,7 @@ dict_table_get_on_id(
{
{
dict_table_t
*
table
;
dict_table_t
*
table
;
if
(
ut_dulint_cmp
(
table_id
,
DICT_FIELDS_ID
)
<=
0
if
(
trx
->
dict_operation_lock_mode
==
RW_X_LATCH
)
{
||
trx
->
dict_operation_lock_mode
==
RW_X_LATCH
)
{
/* Note: An X latch implies that the transaction
/* Note: An X latch implies that the transaction
already owns the dictionary mutex. */
already owns the dictionary mutex. */
...
@@ -4192,7 +4191,6 @@ dict_update_statistics_low(
...
@@ -4192,7 +4191,6 @@ dict_update_statistics_low(
dictionary mutex */
dictionary mutex */
{
{
dict_index_t
*
index
;
dict_index_t
*
index
;
ulint
size
;
ulint
sum_of_index_sizes
=
0
;
ulint
sum_of_index_sizes
=
0
;
if
(
table
->
ibd_file_missing
)
{
if
(
table
->
ibd_file_missing
)
{
...
@@ -4207,14 +4205,6 @@ dict_update_statistics_low(
...
@@ -4207,14 +4205,6 @@ dict_update_statistics_low(
return
;
return
;
}
}
/* If we have set a high innodb_force_recovery level, do not calculate
statistics, as a badly corrupted index can cause a crash in it. */
if
(
srv_force_recovery
>=
SRV_FORCE_NO_IBUF_MERGE
)
{
return
;
}
/* Find out the sizes of the indexes and how many different values
/* Find out the sizes of the indexes and how many different values
for the key they approximately have */
for the key they approximately have */
...
@@ -4226,7 +4216,13 @@ dict_update_statistics_low(
...
@@ -4226,7 +4216,13 @@ dict_update_statistics_low(
return
;
return
;
}
}
while
(
index
)
{
do
{
if
(
UNIV_LIKELY
(
srv_force_recovery
<
SRV_FORCE_NO_IBUF_MERGE
||
(
srv_force_recovery
<
SRV_FORCE_NO_LOG_REDO
&&
dict_index_is_clust
(
index
))))
{
ulint
size
;
size
=
btr_get_size
(
index
,
BTR_TOTAL_SIZE
);
size
=
btr_get_size
(
index
,
BTR_TOTAL_SIZE
);
index
->
stat_index_size
=
size
;
index
->
stat_index_size
=
size
;
...
@@ -4243,10 +4239,26 @@ dict_update_statistics_low(
...
@@ -4243,10 +4239,26 @@ dict_update_statistics_low(
index
->
stat_n_leaf_pages
=
size
;
index
->
stat_n_leaf_pages
=
size
;
btr_estimate_number_of_different_key_vals
(
index
);
btr_estimate_number_of_different_key_vals
(
index
);
}
else
{
/* If we have set a high innodb_force_recovery
level, do not calculate statistics, as a badly
corrupted index can cause a crash in it.
Initialize some bogus index cardinality
statistics, so that the data can be queried in
various means, also via secondary indexes. */
ulint
i
;
index
=
dict_table_get_next_index
(
index
);
sum_of_index_sizes
++
;
index
->
stat_index_size
=
index
->
stat_n_leaf_pages
=
1
;
for
(
i
=
dict_index_get_n_unique
(
index
);
i
;
)
{
index
->
stat_n_diff_key_vals
[
i
--
]
=
1
;
}
}
}
index
=
dict_table_get_next_index
(
index
);
}
while
(
index
);
index
=
dict_table_get_first_index
(
table
);
index
=
dict_table_get_first_index
(
table
);
dict_index_stat_mutex_enter
(
index
);
dict_index_stat_mutex_enter
(
index
);
...
...
storage/innodb_plugin/ha/ha0ha.c
View file @
74c32d69
...
@@ -354,6 +354,7 @@ ha_remove_all_nodes_to_page(
...
@@ -354,6 +354,7 @@ ha_remove_all_nodes_to_page(
#endif
#endif
}
}
#if defined UNIV_AHI_DEBUG || defined UNIV_DEBUG
/*************************************************************//**
/*************************************************************//**
Validates a given range of the cells in hash table.
Validates a given range of the cells in hash table.
@return TRUE if ok */
@return TRUE if ok */
...
@@ -400,6 +401,7 @@ ha_validate(
...
@@ -400,6 +401,7 @@ ha_validate(
return
(
ok
);
return
(
ok
);
}
}
#endif
/* defined UNIV_AHI_DEBUG || defined UNIV_DEBUG */
/*************************************************************//**
/*************************************************************//**
Prints info of a hash table. */
Prints info of a hash table. */
...
...
storage/innodb_plugin/handler/ha_innodb.cc
View file @
74c32d69
...
@@ -7511,28 +7511,15 @@ ha_innobase::info(
...
@@ -7511,28 +7511,15 @@ ha_innobase::info(
dict_index_t
*
index
;
dict_index_t
*
index
;
ha_rows
rec_per_key
;
ha_rows
rec_per_key
;
ib_int64_t
n_rows
;
ib_int64_t
n_rows
;
ulong
j
;
ulong
i
;
char
path
[
FN_REFLEN
];
char
path
[
FN_REFLEN
];
os_file_stat_t
stat_info
;
os_file_stat_t
stat_info
;
DBUG_ENTER
(
"info"
);
DBUG_ENTER
(
"info"
);
/* If we are forcing recovery at a high level, we will suppress
/* If we are forcing recovery at a high level, we will suppress
statistics calculation on tables, because that may crash the
statistics calculation on tables, because that may crash the
server if an index is badly corrupted. */
server if an index is badly corrupted. */
if
(
srv_force_recovery
>=
SRV_FORCE_NO_IBUF_MERGE
)
{
/* We return success (0) instead of HA_ERR_CRASHED,
because we want MySQL to process this query and not
stop, like it would do if it received the error code
HA_ERR_CRASHED. */
DBUG_RETURN
(
0
);
}
/* We do not know if MySQL can call this function before calling
/* We do not know if MySQL can call this function before calling
external_lock(). To be safe, update the thd of the current table
external_lock(). To be safe, update the thd of the current table
handle. */
handle. */
...
@@ -7627,12 +7614,18 @@ ha_innobase::info(
...
@@ -7627,12 +7614,18 @@ ha_innobase::info(
acquiring latches inside InnoDB, we do not call it if we
acquiring latches inside InnoDB, we do not call it if we
are asked by MySQL to avoid locking. Another reason to
are asked by MySQL to avoid locking. Another reason to
avoid the call is that it uses quite a lot of CPU.
avoid the call is that it uses quite a lot of CPU.
See Bug#38185.
See Bug#38185. */
We do not update delete_length if no locking is requested
if
(
flag
&
HA_STATUS_NO_LOCK
)
{
so the "old" value can remain. delete_length is initialized
/* We do not update delete_length if no
to 0 in the ha_statistics' constructor. */
locking is requested so the "old" value can
if
(
!
(
flag
&
HA_STATUS_NO_LOCK
))
{
remain. delete_length is initialized to 0 in
the ha_statistics' constructor. */
}
else
if
(
UNIV_UNLIKELY
(
srv_force_recovery
>=
SRV_FORCE_NO_IBUF_MERGE
))
{
/* Avoid accessing the tablespace if
innodb_crash_recovery is set to a high value. */
stats
.
delete_length
=
0
;
}
else
{
/* lock the data dictionary to avoid races with
/* lock the data dictionary to avoid races with
ibd_file_missing and tablespace_discarded */
ibd_file_missing and tablespace_discarded */
row_mysql_lock_data_dictionary
(
prebuilt
->
trx
);
row_mysql_lock_data_dictionary
(
prebuilt
->
trx
);
...
@@ -7677,6 +7670,7 @@ ha_innobase::info(
...
@@ -7677,6 +7670,7 @@ ha_innobase::info(
}
}
if
(
flag
&
HA_STATUS_CONST
)
{
if
(
flag
&
HA_STATUS_CONST
)
{
ulong
i
;
/* Verify the number of index in InnoDB and MySQL
/* Verify the number of index in InnoDB and MySQL
matches up. If prebuilt->clust_index_was_generated
matches up. If prebuilt->clust_index_was_generated
holds, InnoDB defines GEN_CLUST_INDEX internally */
holds, InnoDB defines GEN_CLUST_INDEX internally */
...
@@ -7693,6 +7687,7 @@ ha_innobase::info(
...
@@ -7693,6 +7687,7 @@ ha_innobase::info(
}
}
for
(
i
=
0
;
i
<
table
->
s
->
keys
;
i
++
)
{
for
(
i
=
0
;
i
<
table
->
s
->
keys
;
i
++
)
{
ulong
j
;
/* We could get index quickly through internal
/* We could get index quickly through internal
index mapping with the index translation table.
index mapping with the index translation table.
The identity of index (match up index name with
The identity of index (match up index name with
...
@@ -7758,6 +7753,11 @@ ha_innobase::info(
...
@@ -7758,6 +7753,11 @@ ha_innobase::info(
}
}
}
}
if
(
srv_force_recovery
>=
SRV_FORCE_NO_IBUF_MERGE
)
{
goto
func_exit
;
}
if
(
flag
&
HA_STATUS_ERRKEY
)
{
if
(
flag
&
HA_STATUS_ERRKEY
)
{
const
dict_index_t
*
err_index
;
const
dict_index_t
*
err_index
;
...
@@ -7778,6 +7778,7 @@ ha_innobase::info(
...
@@ -7778,6 +7778,7 @@ ha_innobase::info(
stats
.
auto_increment_value
=
innobase_peek_autoinc
();
stats
.
auto_increment_value
=
innobase_peek_autoinc
();
}
}
func_exit:
prebuilt
->
trx
->
op_info
=
(
char
*
)
""
;
prebuilt
->
trx
->
op_info
=
(
char
*
)
""
;
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
...
@@ -9235,7 +9236,8 @@ ha_innobase::store_lock(
...
@@ -9235,7 +9236,8 @@ ha_innobase::store_lock(
&&
(
sql_command
==
SQLCOM_INSERT_SELECT
&&
(
sql_command
==
SQLCOM_INSERT_SELECT
||
sql_command
==
SQLCOM_REPLACE_SELECT
||
sql_command
==
SQLCOM_REPLACE_SELECT
||
sql_command
==
SQLCOM_UPDATE
||
sql_command
==
SQLCOM_UPDATE
||
sql_command
==
SQLCOM_CREATE_TABLE
))
{
||
sql_command
==
SQLCOM_CREATE_TABLE
||
sql_command
==
SQLCOM_SET_OPTION
))
{
/* If we either have innobase_locks_unsafe_for_binlog
/* If we either have innobase_locks_unsafe_for_binlog
option set or this session is using READ COMMITTED
option set or this session is using READ COMMITTED
...
@@ -9243,9 +9245,9 @@ ha_innobase::store_lock(
...
@@ -9243,9 +9245,9 @@ ha_innobase::store_lock(
is not set to serializable and MySQL is doing
is not set to serializable and MySQL is doing
INSERT INTO...SELECT or REPLACE INTO...SELECT
INSERT INTO...SELECT or REPLACE INTO...SELECT
or UPDATE ... = (SELECT ...) or CREATE ...
or UPDATE ... = (SELECT ...) or CREATE ...
SELECT...
without FOR UPDATE or IN SHARE
SELECT...
or SET ... = (SELECT ...) without
MODE in select, then we use consistent read
FOR UPDATE or IN SHARE MODE in select,
for select. */
then we use consistent read
for select. */
prebuilt
->
select_lock_type
=
LOCK_NONE
;
prebuilt
->
select_lock_type
=
LOCK_NONE
;
prebuilt
->
stored_select_lock_type
=
LOCK_NONE
;
prebuilt
->
stored_select_lock_type
=
LOCK_NONE
;
...
...
storage/innodb_plugin/include/btr0sea.h
View file @
74c32d69
...
@@ -180,6 +180,7 @@ btr_search_update_hash_on_delete(
...
@@ -180,6 +180,7 @@ btr_search_update_hash_on_delete(
btr_cur_t
*
cursor
);
/*!< in: cursor which was positioned on the
btr_cur_t
*
cursor
);
/*!< in: cursor which was positioned on the
record to delete using btr_cur_search_...,
record to delete using btr_cur_search_...,
the record is not yet deleted */
the record is not yet deleted */
#if defined UNIV_AHI_DEBUG || defined UNIV_DEBUG
/********************************************************************//**
/********************************************************************//**
Validates the search system.
Validates the search system.
@return TRUE if ok */
@return TRUE if ok */
...
@@ -187,6 +188,9 @@ UNIV_INTERN
...
@@ -187,6 +188,9 @@ UNIV_INTERN
ibool
ibool
btr_search_validate
(
void
);
btr_search_validate
(
void
);
/*======================*/
/*======================*/
#else
# define btr_search_validate() TRUE
#endif
/* defined UNIV_AHI_DEBUG || defined UNIV_DEBUG */
/** Flag: has the search system been enabled?
/** Flag: has the search system been enabled?
Protected by btr_search_latch and btr_search_enabled_mutex. */
Protected by btr_search_latch and btr_search_enabled_mutex. */
...
...
storage/innodb_plugin/include/ha0ha.h
View file @
74c32d69
...
@@ -186,6 +186,7 @@ ha_remove_all_nodes_to_page(
...
@@ -186,6 +186,7 @@ ha_remove_all_nodes_to_page(
hash_table_t
*
table
,
/*!< in: hash table */
hash_table_t
*
table
,
/*!< in: hash table */
ulint
fold
,
/*!< in: fold value */
ulint
fold
,
/*!< in: fold value */
const
page_t
*
page
);
/*!< in: buffer page */
const
page_t
*
page
);
/*!< in: buffer page */
#if defined UNIV_AHI_DEBUG || defined UNIV_DEBUG
/*************************************************************//**
/*************************************************************//**
Validates a given range of the cells in hash table.
Validates a given range of the cells in hash table.
@return TRUE if ok */
@return TRUE if ok */
...
@@ -196,6 +197,7 @@ ha_validate(
...
@@ -196,6 +197,7 @@ ha_validate(
hash_table_t
*
table
,
/*!< in: hash table */
hash_table_t
*
table
,
/*!< in: hash table */
ulint
start_index
,
/*!< in: start index */
ulint
start_index
,
/*!< in: start index */
ulint
end_index
);
/*!< in: end index */
ulint
end_index
);
/*!< in: end index */
#endif
/* defined UNIV_AHI_DEBUG || defined UNIV_DEBUG */
/*************************************************************//**
/*************************************************************//**
Prints info of a hash table. */
Prints info of a hash table. */
UNIV_INTERN
UNIV_INTERN
...
...
storage/innodb_plugin/include/univ.i
View file @
74c32d69
...
@@ -46,7 +46,7 @@ Created 1/20/1994 Heikki Tuuri
...
@@ -46,7 +46,7 @@ Created 1/20/1994 Heikki Tuuri
#
define
INNODB_VERSION_MAJOR
1
#
define
INNODB_VERSION_MAJOR
1
#
define
INNODB_VERSION_MINOR
0
#
define
INNODB_VERSION_MINOR
0
#
define
INNODB_VERSION_BUGFIX
1
1
#
define
INNODB_VERSION_BUGFIX
1
2
/* The following is the InnoDB version as shown in
/* The following is the InnoDB version as shown in
SELECT plugin_version FROM information_schema.plugins;
SELECT plugin_version FROM information_schema.plugins;
...
...
storage/innodb_plugin/include/ut0mem.h
View file @
74c32d69
...
@@ -113,7 +113,8 @@ ut_test_malloc(
...
@@ -113,7 +113,8 @@ ut_test_malloc(
ulint
n
);
/*!< in: try to allocate this many bytes */
ulint
n
);
/*!< in: try to allocate this many bytes */
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
/**********************************************************************//**
/**********************************************************************//**
Frees a memory block allocated with ut_malloc. */
Frees a memory block allocated with ut_malloc. Freeing a NULL pointer is
a nop. */
UNIV_INTERN
UNIV_INTERN
void
void
ut_free
(
ut_free
(
...
...
storage/innodb_plugin/row/row0sel.c
View file @
74c32d69
...
@@ -2690,7 +2690,6 @@ row_sel_store_mysql_rec(
...
@@ -2690,7 +2690,6 @@ row_sel_store_mysql_rec(
ut_ad
(
prebuilt
->
mysql_template
);
ut_ad
(
prebuilt
->
mysql_template
);
ut_ad
(
prebuilt
->
default_rec
);
ut_ad
(
prebuilt
->
default_rec
);
ut_ad
(
rec_offs_validate
(
rec
,
NULL
,
offsets
));
ut_ad
(
rec_offs_validate
(
rec
,
NULL
,
offsets
));
ut_ad
(
!
rec_get_deleted_flag
(
rec
,
rec_offs_comp
(
offsets
)));
if
(
UNIV_LIKELY_NULL
(
prebuilt
->
blob_heap
))
{
if
(
UNIV_LIKELY_NULL
(
prebuilt
->
blob_heap
))
{
mem_heap_free
(
prebuilt
->
blob_heap
);
mem_heap_free
(
prebuilt
->
blob_heap
);
...
@@ -3611,6 +3610,7 @@ row_search_for_mysql(
...
@@ -3611,6 +3610,7 @@ row_search_for_mysql(
row_sel_try_search_shortcut_for_mysql().
row_sel_try_search_shortcut_for_mysql().
The latch will not be released until
The latch will not be released until
mtr_commit(&mtr). */
mtr_commit(&mtr). */
ut_ad
(
!
rec_get_deleted_flag
(
rec
,
comp
));
if
(
!
row_sel_store_mysql_rec
(
buf
,
prebuilt
,
if
(
!
row_sel_store_mysql_rec
(
buf
,
prebuilt
,
rec
,
offsets
))
{
rec
,
offsets
))
{
...
@@ -4238,7 +4238,7 @@ row_search_for_mysql(
...
@@ -4238,7 +4238,7 @@ row_search_for_mysql(
rec
=
old_vers
;
rec
=
old_vers
;
}
}
}
else
if
(
!
lock_sec_rec_cons_read_sees
(
rec
,
trx
->
read_view
))
{
}
else
{
/* We are looking into a non-clustered index,
/* We are looking into a non-clustered index,
and to get the right version of the record we
and to get the right version of the record we
have to look also into the clustered index: this
have to look also into the clustered index: this
...
@@ -4246,10 +4246,14 @@ row_search_for_mysql(
...
@@ -4246,10 +4246,14 @@ row_search_for_mysql(
information via the clustered index record. */
information via the clustered index record. */
ut_ad
(
index
!=
clust_index
);
ut_ad
(
index
!=
clust_index
);
ut_ad
(
!
dict_index_is_clust
(
index
));
if
(
!
lock_sec_rec_cons_read_sees
(
rec
,
trx
->
read_view
))
{
goto
requires_clust_rec
;
goto
requires_clust_rec
;
}
}
}
}
}
/* NOTE that at this point rec can be an old version of a clustered
/* NOTE that at this point rec can be an old version of a clustered
index record built for a consistent read. We cannot assume after this
index record built for a consistent read. We cannot assume after this
...
@@ -4370,8 +4374,13 @@ row_search_for_mysql(
...
@@ -4370,8 +4374,13 @@ row_search_for_mysql(
ULINT_UNDEFINED
,
&
heap
);
ULINT_UNDEFINED
,
&
heap
);
result_rec
=
rec
;
result_rec
=
rec
;
}
}
/* result_rec can legitimately be delete-marked
now that it has been established that it points to a
clustered index record that exists in the read view. */
}
else
{
}
else
{
result_rec
=
rec
;
result_rec
=
rec
;
ut_ad
(
!
rec_get_deleted_flag
(
rec
,
comp
));
}
}
/* We found a qualifying record 'result_rec'. At this point,
/* We found a qualifying record 'result_rec'. At this point,
...
...
storage/innodb_plugin/trx/trx0undo.c
View file @
74c32d69
...
@@ -1938,7 +1938,8 @@ trx_undo_update_cleanup(
...
@@ -1938,7 +1938,8 @@ trx_undo_update_cleanup(
UT_LIST_ADD_FIRST
(
undo_list
,
rseg
->
update_undo_cached
,
undo
);
UT_LIST_ADD_FIRST
(
undo_list
,
rseg
->
update_undo_cached
,
undo
);
}
else
{
}
else
{
ut_ad
(
undo
->
state
==
TRX_UNDO_TO_PURGE
);
ut_ad
(
undo
->
state
==
TRX_UNDO_TO_PURGE
||
undo
->
state
==
TRX_UNDO_TO_FREE
);
trx_undo_mem_free
(
undo
);
trx_undo_mem_free
(
undo
);
}
}
...
...
storage/innodb_plugin/ut/ut0mem.c
View file @
74c32d69
...
@@ -290,7 +290,8 @@ ut_test_malloc(
...
@@ -290,7 +290,8 @@ ut_test_malloc(
#endif
/* !UNIV_HOTBACKUP */
#endif
/* !UNIV_HOTBACKUP */
/**********************************************************************//**
/**********************************************************************//**
Frees a memory block allocated with ut_malloc. */
Frees a memory block allocated with ut_malloc. Freeing a NULL pointer is
a nop. */
UNIV_INTERN
UNIV_INTERN
void
void
ut_free
(
ut_free
(
...
@@ -300,7 +301,9 @@ ut_free(
...
@@ -300,7 +301,9 @@ ut_free(
#ifndef UNIV_HOTBACKUP
#ifndef UNIV_HOTBACKUP
ut_mem_block_t
*
block
;
ut_mem_block_t
*
block
;
if
(
UNIV_LIKELY
(
srv_use_sys_malloc
))
{
if
(
ptr
==
NULL
)
{
return
;
}
else
if
(
UNIV_LIKELY
(
srv_use_sys_malloc
))
{
free
(
ptr
);
free
(
ptr
);
return
;
return
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment