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
06a45722
Commit
06a45722
authored
Aug 09, 2010
by
Michael Widenius
Browse files
Options
Browse Files
Download
Plain Diff
Automatic merge
parents
4339204c
7cf51004
Changes
14
Show whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
99 additions
and
28 deletions
+99
-28
include/my_sys.h
include/my_sys.h
+1
-0
mysql-test/mysql-test-run.pl
mysql-test/mysql-test-run.pl
+1
-0
mysys/my_static.c
mysys/my_static.c
+1
-0
mysys/my_sync.c
mysys/my_sync.c
+3
-0
sql/mysqld.cc
sql/mysqld.cc
+7
-1
storage/innodb_plugin/include/univ.i
storage/innodb_plugin/include/univ.i
+1
-1
storage/maria/ma_key_recover.c
storage/maria/ma_key_recover.c
+36
-8
storage/maria/ma_key_recover.h
storage/maria/ma_key_recover.h
+2
-1
storage/maria/ma_loghandler.h
storage/maria/ma_loghandler.h
+14
-1
storage/maria/ma_rt_index.c
storage/maria/ma_rt_index.c
+6
-3
storage/maria/ma_write.c
storage/maria/ma_write.c
+22
-8
storage/xtradb/include/univ.i
storage/xtradb/include/univ.i
+1
-1
strings/longlong2str.c
strings/longlong2str.c
+2
-2
strings/longlong2str_asm.c
strings/longlong2str_asm.c
+2
-2
No files found.
include/my_sys.h
View file @
06a45722
...
@@ -270,6 +270,7 @@ extern size_t sf_malloc_cur_memory, sf_malloc_max_memory;
...
@@ -270,6 +270,7 @@ extern size_t sf_malloc_cur_memory, sf_malloc_max_memory;
extern
ulong
my_default_record_cache_size
;
extern
ulong
my_default_record_cache_size
;
extern
my_bool
NEAR
my_disable_locking
,
NEAR
my_disable_async_io
,
extern
my_bool
NEAR
my_disable_locking
,
NEAR
my_disable_async_io
,
NEAR
my_disable_flush_key_blocks
,
NEAR
my_disable_symlinks
;
NEAR
my_disable_flush_key_blocks
,
NEAR
my_disable_symlinks
;
extern
my_bool
my_disable_sync
;
extern
char
wild_many
,
wild_one
,
wild_prefix
;
extern
char
wild_many
,
wild_one
,
wild_prefix
;
extern
const
char
*
charsets_dir
;
extern
const
char
*
charsets_dir
;
/* from default.c */
/* from default.c */
...
...
mysql-test/mysql-test-run.pl
View file @
06a45722
...
@@ -1799,6 +1799,7 @@ sub mysql_fix_arguments () {
...
@@ -1799,6 +1799,7 @@ sub mysql_fix_arguments () {
mtr_add_arg
(
$args
,
"
--basedir=%s
",
$basedir
);
mtr_add_arg
(
$args
,
"
--basedir=%s
",
$basedir
);
mtr_add_arg
(
$args
,
"
--bindir=%s
",
$path_client_bindir
);
mtr_add_arg
(
$args
,
"
--bindir=%s
",
$path_client_bindir
);
mtr_add_arg
(
$args
,
"
--verbose
");
mtr_add_arg
(
$args
,
"
--verbose
");
mtr_add_arg
(
$args
,
"
--sync-sys=0
");
# Speed up test suite
return
mtr_args2str
(
$exe
,
@$args
);
return
mtr_args2str
(
$exe
,
@$args
);
}
}
...
...
mysys/my_static.c
View file @
06a45722
...
@@ -119,6 +119,7 @@ ulonglong query_performance_frequency, query_performance_offset;
...
@@ -119,6 +119,7 @@ ulonglong query_performance_frequency, query_performance_offset;
/* How to disable options */
/* How to disable options */
my_bool
NEAR
my_disable_locking
=
0
;
my_bool
NEAR
my_disable_locking
=
0
;
my_bool
NEAR
my_disable_sync
=
0
;
my_bool
NEAR
my_disable_async_io
=
0
;
my_bool
NEAR
my_disable_async_io
=
0
;
my_bool
NEAR
my_disable_flush_key_blocks
=
0
;
my_bool
NEAR
my_disable_flush_key_blocks
=
0
;
my_bool
NEAR
my_disable_symlinks
=
0
;
my_bool
NEAR
my_disable_symlinks
=
0
;
...
...
mysys/my_sync.c
View file @
06a45722
...
@@ -48,6 +48,9 @@ int my_sync(File fd, myf my_flags)
...
@@ -48,6 +48,9 @@ int my_sync(File fd, myf my_flags)
DBUG_ENTER
(
"my_sync"
);
DBUG_ENTER
(
"my_sync"
);
DBUG_PRINT
(
"my"
,(
"fd: %d my_flags: %d"
,
fd
,
my_flags
));
DBUG_PRINT
(
"my"
,(
"fd: %d my_flags: %d"
,
fd
,
my_flags
));
if
(
my_disable_sync
)
DBUG_RETURN
(
0
);
statistic_increment
(
my_sync_count
,
&
THR_LOCK_open
);
statistic_increment
(
my_sync_count
,
&
THR_LOCK_open
);
do
do
{
{
...
...
sql/mysqld.cc
View file @
06a45722
...
@@ -429,6 +429,7 @@ static bool volatile ready_to_exit;
...
@@ -429,6 +429,7 @@ static bool volatile ready_to_exit;
static
my_bool
opt_debugging
=
0
,
opt_external_locking
=
0
,
opt_console
=
0
;
static
my_bool
opt_debugging
=
0
,
opt_external_locking
=
0
,
opt_console
=
0
;
static
my_bool
opt_short_log_format
=
0
;
static
my_bool
opt_short_log_format
=
0
;
static
my_bool
opt_ignore_wrong_options
=
0
,
opt_expect_abort
=
0
;
static
my_bool
opt_ignore_wrong_options
=
0
,
opt_expect_abort
=
0
;
static
my_bool
opt_sync
=
0
;
static
uint
kill_cached_threads
,
wake_thread
;
static
uint
kill_cached_threads
,
wake_thread
;
ulong
thread_created
;
ulong
thread_created
;
uint
thread_handling
;
uint
thread_handling
;
...
@@ -5945,7 +5946,7 @@ enum options_mysqld
...
@@ -5945,7 +5946,7 @@ enum options_mysqld
OPT_RANGE_ALLOC_BLOCK_SIZE
,
OPT_ALLOW_SUSPICIOUS_UDFS
,
OPT_RANGE_ALLOC_BLOCK_SIZE
,
OPT_ALLOW_SUSPICIOUS_UDFS
,
OPT_QUERY_ALLOC_BLOCK_SIZE
,
OPT_QUERY_PREALLOC_SIZE
,
OPT_QUERY_ALLOC_BLOCK_SIZE
,
OPT_QUERY_PREALLOC_SIZE
,
OPT_TRANS_ALLOC_BLOCK_SIZE
,
OPT_TRANS_PREALLOC_SIZE
,
OPT_TRANS_ALLOC_BLOCK_SIZE
,
OPT_TRANS_PREALLOC_SIZE
,
OPT_SYNC_FRM
,
OPT_SYNC_BINLOG
,
OPT_SYNC_FRM
,
OPT_SYNC_BINLOG
,
OPT_SYNC
,
OPT_SYNC_REPLICATION
,
OPT_SYNC_REPLICATION
,
OPT_SYNC_REPLICATION_SLAVE_ID
,
OPT_SYNC_REPLICATION_SLAVE_ID
,
OPT_SYNC_REPLICATION_TIMEOUT
,
OPT_SYNC_REPLICATION_TIMEOUT
,
...
@@ -7474,6 +7475,10 @@ thread is in the relay logs.",
...
@@ -7474,6 +7475,10 @@ thread is in the relay logs.",
{
"sync-frm"
,
OPT_SYNC_FRM
,
"Sync .frm to disk on create. Enabled by default."
,
{
"sync-frm"
,
OPT_SYNC_FRM
,
"Sync .frm to disk on create. Enabled by default."
,
&
opt_sync_frm
,
&
opt_sync_frm
,
0
,
GET_BOOL
,
NO_ARG
,
1
,
0
,
&
opt_sync_frm
,
&
opt_sync_frm
,
0
,
GET_BOOL
,
NO_ARG
,
1
,
0
,
0
,
0
,
0
,
0
},
0
,
0
,
0
,
0
},
{
"sync-sys"
,
OPT_SYNC
,
"Enable/disable system sync calls. Should only be turned off when running "
"tests or debugging!!"
,
&
opt_sync
,
&
opt_sync
,
0
,
GET_BOOL
,
NO_ARG
,
1
,
0
,
0
,
0
,
0
,
0
},
{
"table_cache"
,
OPT_TABLE_OPEN_CACHE
,
{
"table_cache"
,
OPT_TABLE_OPEN_CACHE
,
"Deprecated; use --table_open_cache instead."
,
"Deprecated; use --table_open_cache instead."
,
&
table_cache_size
,
&
table_cache_size
,
0
,
GET_ULONG
,
&
table_cache_size
,
&
table_cache_size
,
0
,
GET_ULONG
,
...
@@ -9230,6 +9235,7 @@ static int get_options(int *argc,char **argv)
...
@@ -9230,6 +9235,7 @@ static int get_options(int *argc,char **argv)
In most cases the global variables will not be used
In most cases the global variables will not be used
*/
*/
my_disable_locking
=
myisam_single_user
=
test
(
opt_external_locking
==
0
);
my_disable_locking
=
myisam_single_user
=
test
(
opt_external_locking
==
0
);
my_disable_sync
=
opt_sync
==
0
;
my_default_record_cache_size
=
global_system_variables
.
read_buff_size
;
my_default_record_cache_size
=
global_system_variables
.
read_buff_size
;
myisam_max_temp_length
=
myisam_max_temp_length
=
(
my_off_t
)
global_system_variables
.
myisam_max_sort_file_size
;
(
my_off_t
)
global_system_variables
.
myisam_max_sort_file_size
;
...
...
storage/innodb_plugin/include/univ.i
View file @
06a45722
...
@@ -165,7 +165,7 @@ command. Not tested on Windows. */
...
@@ -165,7 +165,7 @@ command. Not tested on Windows. */
#define UNIV_COMPILE_TEST_FUNCS
#define UNIV_COMPILE_TEST_FUNCS
*/
*/
#
if
defined
HAVE_VALGRIND
#
if
defined
(
HAVE_valgrind
)
&
&
defined(HAVE_VALGRIND_MEMCHECK_H)
#
define
UNIV_DEBUG_VALGRIND
#
define
UNIV_DEBUG_VALGRIND
#
endif
/* HAVE_VALGRIND */
#
endif
/* HAVE_VALGRIND */
#
if
0
#
if
0
...
...
storage/maria/ma_key_recover.c
View file @
06a45722
...
@@ -494,7 +494,8 @@ my_bool _ma_log_add(MARIA_PAGE *ma_page,
...
@@ -494,7 +494,8 @@ my_bool _ma_log_add(MARIA_PAGE *ma_page,
my_bool
handle_overflow
__attribute__
((
unused
)))
my_bool
handle_overflow
__attribute__
((
unused
)))
{
{
LSN
lsn
;
LSN
lsn
;
uchar
log_data
[
FILEID_STORE_SIZE
+
PAGE_STORE_SIZE
+
3
+
3
+
3
+
3
+
7
+
2
];
uchar
log_data
[
FILEID_STORE_SIZE
+
PAGE_STORE_SIZE
+
2
+
3
+
3
+
3
+
3
+
7
+
2
];
uchar
*
log_pos
;
uchar
*
log_pos
;
uchar
*
buff
=
ma_page
->
buff
;
uchar
*
buff
=
ma_page
->
buff
;
LEX_CUSTRING
log_array
[
TRANSLOG_INTERNAL_PARTS
+
3
];
LEX_CUSTRING
log_array
[
TRANSLOG_INTERNAL_PARTS
+
3
];
...
@@ -509,6 +510,7 @@ my_bool _ma_log_add(MARIA_PAGE *ma_page,
...
@@ -509,6 +510,7 @@ my_bool _ma_log_add(MARIA_PAGE *ma_page,
(
ulong
)
ma_page
->
pos
,
org_page_length
,
changed_length
,
(
ulong
)
ma_page
->
pos
,
org_page_length
,
changed_length
,
move_length
));
move_length
));
DBUG_ASSERT
(
info
->
s
->
now_transactional
);
DBUG_ASSERT
(
info
->
s
->
now_transactional
);
DBUG_ASSERT
(
move_length
<=
(
int
)
changed_length
);
/*
/*
Write REDO entry that contains the logical operations we need
Write REDO entry that contains the logical operations we need
...
@@ -519,6 +521,11 @@ my_bool _ma_log_add(MARIA_PAGE *ma_page,
...
@@ -519,6 +521,11 @@ my_bool _ma_log_add(MARIA_PAGE *ma_page,
page_store
(
log_pos
,
page_pos
);
page_store
(
log_pos
,
page_pos
);
log_pos
+=
PAGE_STORE_SIZE
;
log_pos
+=
PAGE_STORE_SIZE
;
#ifdef EXTRA_DEBUG_KEY_CHANGES
*
log_pos
++=
KEY_OP_DEBUG
;
*
log_pos
++=
KEY_OP_DEBUG_LOG_ADD
;
#endif
/* Store keypage_flag */
/* Store keypage_flag */
*
log_pos
++=
KEY_OP_SET_PAGEFLAG
;
*
log_pos
++=
KEY_OP_SET_PAGEFLAG
;
*
log_pos
++=
buff
[
KEYPAGE_TRANSFLAG_OFFSET
];
*
log_pos
++=
buff
[
KEYPAGE_TRANSFLAG_OFFSET
];
...
@@ -533,21 +540,31 @@ my_bool _ma_log_add(MARIA_PAGE *ma_page,
...
@@ -533,21 +540,31 @@ my_bool _ma_log_add(MARIA_PAGE *ma_page,
DBUG_ASSERT
(
handle_overflow
);
DBUG_ASSERT
(
handle_overflow
);
if
(
offset
+
changed_length
>
page_length
)
if
(
offset
+
changed_length
>
page_length
)
{
{
/* Log that data changed to end of page */
changed_length
=
page_length
-
offset
;
changed_length
=
page_length
-
offset
;
move_length
=
0
;
move_length
=
0
;
/* Set page to max length */
org_page_length
=
page_length
;
*
log_pos
++=
KEY_OP_MAX_PAGELENGTH
;
}
}
else
else
{
{
/* They key will not be part of the page ; Don't log it */
uint
diff
=
org_page_length
+
move_length
-
page_length
;
uint
diff
=
org_page_length
+
move_length
-
page_length
;
log_pos
[
0
]
=
KEY_OP_DEL_SUFFIX
;
log_pos
[
0
]
=
KEY_OP_DEL_SUFFIX
;
int2store
(
log_pos
+
1
,
diff
);
int2store
(
log_pos
+
1
,
diff
);
log_pos
+=
3
;
log_pos
+=
3
;
org_page_length
=
page_length
-
move_length
;
org_page_length
-=
diff
;
DBUG_ASSERT
(
org_page_length
==
page_length
-
move_length
);
}
}
DBUG_ASSERT
(
offset
!=
org_page_length
);
}
}
if
(
offset
==
org_page_length
)
if
(
offset
==
org_page_length
)
{
DBUG_ASSERT
(
move_length
==
(
int
)
changed_length
);
log_pos
[
0
]
=
KEY_OP_ADD_SUFFIX
;
log_pos
[
0
]
=
KEY_OP_ADD_SUFFIX
;
}
else
else
{
{
log_pos
[
0
]
=
KEY_OP_OFFSET
;
log_pos
[
0
]
=
KEY_OP_OFFSET
;
...
@@ -832,6 +849,8 @@ uint _ma_apply_redo_index_free_page(MARIA_HA *info,
...
@@ -832,6 +849,8 @@ uint _ma_apply_redo_index_free_page(MARIA_HA *info,
KEY_OP_CHECK 6 page_length[2},CRC Used only when debugging
KEY_OP_CHECK 6 page_length[2},CRC Used only when debugging
KEY_OP_COMPACT_PAGE 6 transid
KEY_OP_COMPACT_PAGE 6 transid
KEY_OP_SET_PAGEFLAG 1 flag for page
KEY_OP_SET_PAGEFLAG 1 flag for page
KEY_OP_MAX_PAGELENGTH 0 Set page to max length
KEY_OP_DEBUG 1 Info where logging was done
@return Operation status
@return Operation status
@retval 0 OK
@retval 0 OK
...
@@ -850,6 +869,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
...
@@ -850,6 +869,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
const
uchar
*
header_end
=
header
+
head_length
;
const
uchar
*
header_end
=
header
+
head_length
;
uint
page_offset
=
0
,
org_page_length
;
uint
page_offset
=
0
,
org_page_length
;
uint
nod_flag
,
page_length
,
keypage_header
,
keynr
;
uint
nod_flag
,
page_length
,
keypage_header
,
keynr
;
uint
max_page_length
=
share
->
block_size
-
KEYPAGE_CHECKSUM_SIZE
;
int
result
;
int
result
;
MARIA_PAGE
page
;
MARIA_PAGE
page
;
DBUG_ENTER
(
"_ma_apply_redo_index"
);
DBUG_ENTER
(
"_ma_apply_redo_index"
);
...
@@ -898,7 +918,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
...
@@ -898,7 +918,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
header
+=
2
;
header
+=
2
;
DBUG_PRINT
(
"redo"
,
(
"key_op_shift: %d"
,
length
));
DBUG_PRINT
(
"redo"
,
(
"key_op_shift: %d"
,
length
));
DBUG_ASSERT
(
page_offset
!=
0
&&
page_offset
<=
page_length
&&
DBUG_ASSERT
(
page_offset
!=
0
&&
page_offset
<=
page_length
&&
page_length
+
length
<
share
->
block_size
);
page_length
+
length
<
=
max_page_length
);
if
(
length
<
0
)
if
(
length
<
0
)
bmove
(
buff
+
page_offset
,
buff
+
page_offset
-
length
,
bmove
(
buff
+
page_offset
,
buff
+
page_offset
-
length
,
...
@@ -927,7 +947,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
...
@@ -927,7 +947,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
insert_length
,
changed_length
));
insert_length
,
changed_length
));
DBUG_ASSERT
(
insert_length
<=
changed_length
&&
DBUG_ASSERT
(
insert_length
<=
changed_length
&&
page_length
+
changed_length
<=
share
->
block_size
);
page_length
+
changed_length
<=
max_page_length
);
bmove_upp
(
buff
+
page_length
+
insert_length
,
buff
+
page_length
,
bmove_upp
(
buff
+
page_length
+
insert_length
,
buff
+
page_length
,
page_length
-
keypage_header
);
page_length
-
keypage_header
);
...
@@ -954,7 +974,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
...
@@ -954,7 +974,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
{
{
uint
insert_length
=
uint2korr
(
header
);
uint
insert_length
=
uint2korr
(
header
);
DBUG_PRINT
(
"redo"
,
(
"key_op_add_prefix: %u"
,
insert_length
));
DBUG_PRINT
(
"redo"
,
(
"key_op_add_prefix: %u"
,
insert_length
));
DBUG_ASSERT
(
page_length
+
insert_length
<=
share
->
block_size
);
DBUG_ASSERT
(
page_length
+
insert_length
<=
max_page_length
);
memcpy
(
buff
+
page_length
,
header
+
2
,
insert_length
);
memcpy
(
buff
+
page_length
,
header
+
2
,
insert_length
);
page_length
+=
insert_length
;
page_length
+=
insert_length
;
...
@@ -983,7 +1003,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
...
@@ -983,7 +1003,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
page_length
-
LSN_STORE_SIZE
))
page_length
-
LSN_STORE_SIZE
))
{
{
DBUG_PRINT
(
"error"
,
(
"page_length %u"
,
page_length
));
DBUG_PRINT
(
"error"
,
(
"page_length %u"
,
page_length
));
DBUG_DUMP
(
"KEY_OP_CHECK bad page"
,
buff
,
share
->
block_size
);
DBUG_DUMP
(
"KEY_OP_CHECK bad page"
,
buff
,
max_page_length
);
DBUG_ASSERT
(
"crc"
==
"failure in REDO_INDEX"
);
DBUG_ASSERT
(
"crc"
==
"failure in REDO_INDEX"
);
}
}
#endif
#endif
...
@@ -991,6 +1011,14 @@ uint _ma_apply_redo_index(MARIA_HA *info,
...
@@ -991,6 +1011,14 @@ uint _ma_apply_redo_index(MARIA_HA *info,
header
+=
6
;
header
+=
6
;
break
;
break
;
}
}
case
KEY_OP_DEBUG
:
DBUG_PRINT
(
"redo"
,
(
"Debug: %u"
,
(
uint
)
header
[
0
]));
header
++
;
break
;
case
KEY_OP_MAX_PAGELENGTH
:
DBUG_PRINT
(
"redo"
,
(
"key_op_max_page_length"
));
page_length
=
max_page_length
;
break
;
case
KEY_OP_MULTI_COPY
:
/* 9 */
case
KEY_OP_MULTI_COPY
:
/* 9 */
{
{
/*
/*
...
@@ -1011,7 +1039,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
...
@@ -1011,7 +1039,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
log_memcpy_length
=
uint2korr
(
header
);
log_memcpy_length
=
uint2korr
(
header
);
header
+=
2
;
header
+=
2
;
log_memcpy_end
=
header
+
log_memcpy_length
;
log_memcpy_end
=
header
+
log_memcpy_length
;
DBUG_ASSERT
(
full_length
<
share
->
block_size
);
DBUG_ASSERT
(
full_length
<
=
max_page_length
);
while
(
header
<
log_memcpy_end
)
while
(
header
<
log_memcpy_end
)
{
{
uint
to
,
from
;
uint
to
,
from
;
...
@@ -1020,7 +1048,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
...
@@ -1020,7 +1048,7 @@ uint _ma_apply_redo_index(MARIA_HA *info,
from
=
uint2korr
(
header
);
from
=
uint2korr
(
header
);
header
+=
2
;
header
+=
2
;
/* "from" is a place in the existing page */
/* "from" is a place in the existing page */
DBUG_ASSERT
(
max
(
from
,
to
)
<
share
->
block_size
);
DBUG_ASSERT
(
max
(
from
,
to
)
<
max_page_length
);
memcpy
(
buff
+
to
,
buff
+
from
,
full_length
);
memcpy
(
buff
+
to
,
buff
+
from
,
full_length
);
}
}
break
;
break
;
...
...
storage/maria/ma_key_recover.h
View file @
06a45722
...
@@ -72,7 +72,8 @@ my_bool _ma_log_add(MARIA_PAGE *page, uint buff_length, uchar *key_pos,
...
@@ -72,7 +72,8 @@ my_bool _ma_log_add(MARIA_PAGE *page, uint buff_length, uchar *key_pos,
my_bool
handle_overflow
);
my_bool
handle_overflow
);
my_bool
_ma_log_delete
(
MARIA_PAGE
*
page
,
const
uchar
*
key_pos
,
my_bool
_ma_log_delete
(
MARIA_PAGE
*
page
,
const
uchar
*
key_pos
,
uint
changed_length
,
uint
move_length
);
uint
changed_length
,
uint
move_length
);
my_bool
_ma_log_change
(
MARIA_PAGE
*
page
,
const
uchar
*
key_pos
,
uint
length
);
my_bool
_ma_log_change
(
MARIA_PAGE
*
page
,
const
uchar
*
key_pos
,
uint
length
,
enum
en_key_debug
debug_marker
);
my_bool
_ma_log_new
(
MARIA_PAGE
*
page
,
my_bool
root_page
);
my_bool
_ma_log_new
(
MARIA_PAGE
*
page
,
my_bool
root_page
);
uint
_ma_apply_redo_index_new_page
(
MARIA_HA
*
info
,
LSN
lsn
,
uint
_ma_apply_redo_index_new_page
(
MARIA_HA
*
info
,
LSN
lsn
,
...
...
storage/maria/ma_loghandler.h
View file @
06a45722
...
@@ -165,7 +165,20 @@ enum en_key_op
...
@@ -165,7 +165,20 @@ enum en_key_op
KEY_OP_CHECK
,
/* For debugging; CRC of used part of page */
KEY_OP_CHECK
,
/* For debugging; CRC of used part of page */
KEY_OP_MULTI_COPY
,
/* List of memcpy()s with fixed-len sources in page */
KEY_OP_MULTI_COPY
,
/* List of memcpy()s with fixed-len sources in page */
KEY_OP_SET_PAGEFLAG
,
/* Set pageflag from next byte */
KEY_OP_SET_PAGEFLAG
,
/* Set pageflag from next byte */
KEY_OP_COMPACT_PAGE
/* Compact key page */
KEY_OP_COMPACT_PAGE
,
/* Compact key page */
KEY_OP_MAX_PAGELENGTH
,
/* Set page to max page length */
KEY_OP_DEBUG
/* Entry for storing what triggered redo_index */
};
enum
en_key_debug
{
KEY_OP_DEBUG_RTREE_COMBINE
,
KEY_OP_DEBUG_RTREE_SPLIT
,
KEY_OP_DEBUG_RTREE_SET_KEY
,
KEY_OP_DEBUG_FATHER_CHANGED_1
,
KEY_OP_DEBUG_FATHER_CHANGED_2
,
KEY_OP_DEBUG_LOG_SPLIT
,
KEY_OP_DEBUG_LOG_ADD
};
};
...
...
storage/maria/ma_rt_index.c
View file @
06a45722
...
@@ -625,7 +625,8 @@ static int maria_rtree_insert_req(MARIA_HA *info, MARIA_KEY *key,
...
@@ -625,7 +625,8 @@ static int maria_rtree_insert_req(MARIA_HA *info, MARIA_KEY *key,
{
{
maria_rtree_combine_rect
(
keyinfo
->
seg
,
k
,
key
->
data
,
k
,
key_length
);
maria_rtree_combine_rect
(
keyinfo
->
seg
,
k
,
key
->
data
,
k
,
key_length
);
if
(
share
->
now_transactional
&&
if
(
share
->
now_transactional
&&
_ma_log_change
(
&
page
,
k
,
key_length
))
_ma_log_change
(
&
page
,
k
,
key_length
,
KEY_OP_DEBUG_RTREE_COMBINE
))
goto
err
;
goto
err
;
page_mark_changed
(
info
,
&
page
);
page_mark_changed
(
info
,
&
page
);
if
(
_ma_write_keypage
(
&
page
,
PAGECACHE_LOCK_LEFT_WRITELOCKED
,
if
(
_ma_write_keypage
(
&
page
,
PAGECACHE_LOCK_LEFT_WRITELOCKED
,
...
@@ -652,7 +653,8 @@ static int maria_rtree_insert_req(MARIA_HA *info, MARIA_KEY *key,
...
@@ -652,7 +653,8 @@ static int maria_rtree_insert_req(MARIA_HA *info, MARIA_KEY *key,
if
(
maria_rtree_set_key_mbr
(
info
,
&
k_key
,
_ma_kpos
(
nod_flag
,
k
)))
if
(
maria_rtree_set_key_mbr
(
info
,
&
k_key
,
_ma_kpos
(
nod_flag
,
k
)))
goto
err
;
goto
err
;
if
(
share
->
now_transactional
&&
if
(
share
->
now_transactional
&&
_ma_log_change
(
&
page
,
k
,
key_length
))
_ma_log_change
(
&
page
,
k
,
key_length
,
KEY_OP_DEBUG_RTREE_SPLIT
))
goto
err
;
goto
err
;
/* add new key for new page */
/* add new key for new page */
_ma_kpointer
(
info
,
new_key_buff
-
nod_flag
,
*
new_page
);
_ma_kpointer
(
info
,
new_key_buff
-
nod_flag
,
*
new_page
);
...
@@ -964,7 +966,8 @@ static int maria_rtree_delete_req(MARIA_HA *info, const MARIA_KEY *key,
...
@@ -964,7 +966,8 @@ static int maria_rtree_delete_req(MARIA_HA *info, const MARIA_KEY *key,
_ma_kpos
(
nod_flag
,
k
)))
_ma_kpos
(
nod_flag
,
k
)))
goto
err
;
goto
err
;
if
(
share
->
now_transactional
&&
if
(
share
->
now_transactional
&&
_ma_log_change
(
&
page
,
k
,
key
->
data_length
))
_ma_log_change
(
&
page
,
k
,
key
->
data_length
,
KEY_OP_DEBUG_RTREE_SET_KEY
))
goto
err
;
goto
err
;
page_mark_changed
(
info
,
&
page
)
page_mark_changed
(
info
,
&
page
)
if
(
_ma_write_keypage
(
&
page
,
if
(
_ma_write_keypage
(
&
page
,
...
...
storage/maria/ma_write.c
View file @
06a45722
...
@@ -1416,7 +1416,8 @@ static int _ma_balance_page(MARIA_HA *info, MARIA_KEYDEF *keyinfo,
...
@@ -1416,7 +1416,8 @@ static int _ma_balance_page(MARIA_HA *info, MARIA_KEYDEF *keyinfo,
/* Log changes to father (one level up) page */
/* Log changes to father (one level up) page */
if
(
share
->
now_transactional
&&
if
(
share
->
now_transactional
&&
_ma_log_change
(
father_page
,
father_key_pos
,
k_length
))
_ma_log_change
(
father_page
,
father_key_pos
,
k_length
,
KEY_OP_DEBUG_FATHER_CHANGED_1
))
goto
err
;
goto
err
;
/*
/*
...
@@ -1583,7 +1584,8 @@ static int _ma_balance_page(MARIA_HA *info, MARIA_KEYDEF *keyinfo,
...
@@ -1583,7 +1584,8 @@ static int _ma_balance_page(MARIA_HA *info, MARIA_KEYDEF *keyinfo,
/* Log changes to father (one level up) page */
/* Log changes to father (one level up) page */
if
(
share
->
now_transactional
&&
if
(
share
->
now_transactional
&&
_ma_log_change
(
father_page
,
father_key_pos
,
k_length
))
_ma_log_change
(
father_page
,
father_key_pos
,
k_length
,
KEY_OP_DEBUG_FATHER_CHANGED_2
))
goto
err
;
goto
err
;
}
}
...
@@ -1905,11 +1907,11 @@ my_bool _ma_log_new(MARIA_PAGE *ma_page, my_bool root_page)
...
@@ -1905,11 +1907,11 @@ my_bool _ma_log_new(MARIA_PAGE *ma_page, my_bool root_page)
Log when some part of the key page changes
Log when some part of the key page changes
*/
*/
my_bool
_ma_log_change
(
MARIA_PAGE
*
ma_page
,
my_bool
_ma_log_change
(
MARIA_PAGE
*
ma_page
,
const
uchar
*
key_pos
,
uint
length
,
const
uchar
*
key_pos
,
uint
length
)
enum
en_key_debug
debug_marker
__attribute__
((
unused
))
)
{
{
LSN
lsn
;
LSN
lsn
;
uchar
log_data
[
FILEID_STORE_SIZE
+
PAGE_STORE_SIZE
+
6
+
7
],
*
log_pos
;
uchar
log_data
[
FILEID_STORE_SIZE
+
PAGE_STORE_SIZE
+
2
+
6
+
7
],
*
log_pos
;
LEX_CUSTRING
log_array
[
TRANSLOG_INTERNAL_PARTS
+
3
];
LEX_CUSTRING
log_array
[
TRANSLOG_INTERNAL_PARTS
+
3
];
uint
offset
=
(
uint
)
(
key_pos
-
ma_page
->
buff
),
translog_parts
;
uint
offset
=
(
uint
)
(
key_pos
-
ma_page
->
buff
),
translog_parts
;
uint
extra_length
=
0
;
uint
extra_length
=
0
;
...
@@ -1919,18 +1921,26 @@ my_bool _ma_log_change(MARIA_PAGE *ma_page,
...
@@ -1919,18 +1921,26 @@ my_bool _ma_log_change(MARIA_PAGE *ma_page,
DBUG_PRINT
(
"enter"
,
(
"page: %lu length: %u"
,
(
ulong
)
ma_page
->
pos
,
length
));
DBUG_PRINT
(
"enter"
,
(
"page: %lu length: %u"
,
(
ulong
)
ma_page
->
pos
,
length
));
DBUG_ASSERT
(
info
->
s
->
now_transactional
);
DBUG_ASSERT
(
info
->
s
->
now_transactional
);
DBUG_ASSERT
(
offset
+
length
<=
ma_page
->
size
);
/* Store address of new root page */
/* Store address of new root page */
page
=
ma_page
->
pos
/
info
->
s
->
block_size
;
page
=
ma_page
->
pos
/
info
->
s
->
block_size
;
page_store
(
log_data
+
FILEID_STORE_SIZE
,
page
);
page_store
(
log_data
+
FILEID_STORE_SIZE
,
page
);
log_pos
=
log_data
+
FILEID_STORE_SIZE
+
PAGE_STORE_SIZE
;
log_pos
=
log_data
+
FILEID_STORE_SIZE
+
PAGE_STORE_SIZE
;
#ifdef EXTRA_DEBUG_KEY_CHANGES
(
*
log_pos
++
)
=
KEY_OP_DEBUG
;
(
*
log_pos
++
)
=
debug_marker
;
#endif
log_pos
[
0
]
=
KEY_OP_OFFSET
;
log_pos
[
0
]
=
KEY_OP_OFFSET
;
int2store
(
log_pos
+
1
,
offset
);
int2store
(
log_pos
+
1
,
offset
);
log_pos
[
3
]
=
KEY_OP_CHANGE
;
log_pos
[
3
]
=
KEY_OP_CHANGE
;
int2store
(
log_pos
+
4
,
length
);
int2store
(
log_pos
+
4
,
length
);
log_pos
+=
6
;
log_array
[
TRANSLOG_INTERNAL_PARTS
+
0
].
str
=
log_data
;
log_array
[
TRANSLOG_INTERNAL_PARTS
+
0
].
str
=
log_data
;
log_array
[
TRANSLOG_INTERNAL_PARTS
+
0
].
length
=
sizeof
(
log_data
)
-
7
;
log_array
[
TRANSLOG_INTERNAL_PARTS
+
0
].
length
=
(
log_pos
-
log_data
)
;
log_array
[
TRANSLOG_INTERNAL_PARTS
+
1
].
str
=
key_pos
;
log_array
[
TRANSLOG_INTERNAL_PARTS
+
1
].
str
=
key_pos
;
log_array
[
TRANSLOG_INTERNAL_PARTS
+
1
].
length
=
length
;
log_array
[
TRANSLOG_INTERNAL_PARTS
+
1
].
length
=
length
;
translog_parts
=
2
;
translog_parts
=
2
;
...
@@ -1941,7 +1951,6 @@ my_bool _ma_log_change(MARIA_PAGE *ma_page,
...
@@ -1941,7 +1951,6 @@ my_bool _ma_log_change(MARIA_PAGE *ma_page,
ha_checksum
crc
;
ha_checksum
crc
;
crc
=
my_checksum
(
0
,
ma_page
->
buff
+
LSN_STORE_SIZE
,
crc
=
my_checksum
(
0
,
ma_page
->
buff
+
LSN_STORE_SIZE
,
page_length
-
LSN_STORE_SIZE
);
page_length
-
LSN_STORE_SIZE
);
log_pos
+=
6
;
log_pos
[
0
]
=
KEY_OP_CHECK
;
log_pos
[
0
]
=
KEY_OP_CHECK
;
int2store
(
log_pos
+
1
,
page_length
);
int2store
(
log_pos
+
1
,
page_length
);
int4store
(
log_pos
+
3
,
crc
);
int4store
(
log_pos
+
3
,
crc
);
...
@@ -1987,7 +1996,7 @@ static my_bool _ma_log_split(MARIA_PAGE *ma_page,
...
@@ -1987,7 +1996,7 @@ static my_bool _ma_log_split(MARIA_PAGE *ma_page,
uint
changed_length
)
uint
changed_length
)
{
{
LSN
lsn
;
LSN
lsn
;
uchar
log_data
[
FILEID_STORE_SIZE
+
PAGE_STORE_SIZE
+
3
+
3
+
3
+
3
+
3
+
2
+
7
];
uchar
log_data
[
FILEID_STORE_SIZE
+
PAGE_STORE_SIZE
+
2
+
3
+
3
+
3
+
3
+
3
+
2
+
7
];
uchar
*
log_pos
;
uchar
*
log_pos
;
LEX_CUSTRING
log_array
[
TRANSLOG_INTERNAL_PARTS
+
4
];
LEX_CUSTRING
log_array
[
TRANSLOG_INTERNAL_PARTS
+
4
];
uint
offset
=
(
uint
)
(
key_pos
-
ma_page
->
buff
);
uint
offset
=
(
uint
)
(
key_pos
-
ma_page
->
buff
);
...
@@ -2003,6 +2012,11 @@ static my_bool _ma_log_split(MARIA_PAGE *ma_page,
...
@@ -2003,6 +2012,11 @@ static my_bool _ma_log_split(MARIA_PAGE *ma_page,
page_store
(
log_pos
,
page
);
page_store
(
log_pos
,
page
);
log_pos
+=
PAGE_STORE_SIZE
;
log_pos
+=
PAGE_STORE_SIZE
;
#ifdef EXTRA_DEBUG_KEY_CHANGES
(
*
log_pos
++
)
=
KEY_OP_DEBUG
;
(
*
log_pos
++
)
=
KEY_OP_DEBUG_LOG_SPLIT
;
#endif
if
(
new_length
<=
offset
||
!
key_pos
)
if
(
new_length
<=
offset
||
!
key_pos
)
{
{
/*
/*
...
...
storage/xtradb/include/univ.i
View file @
06a45722
...
@@ -168,7 +168,7 @@ command. Not tested on Windows. */
...
@@ -168,7 +168,7 @@ command. Not tested on Windows. */
#define UNIV_COMPILE_TEST_FUNCS
#define UNIV_COMPILE_TEST_FUNCS
*/
*/
#
if
def
HAVE_valgrind
#
if
defined
(
HAVE_valgrind
)
&
&
defined(HAVE_VALGRIND_MEMCHECK_H)
#
define
UNIV_DEBUG_VALGRIND
#
define
UNIV_DEBUG_VALGRIND
#
endif
/* HAVE_valgrind */
#
endif
/* HAVE_valgrind */
#
if
0
#
if
0
...
...
strings/longlong2str.c
View file @
06a45722
...
@@ -81,14 +81,14 @@ char *longlong2str(longlong val,char *dst,int radix, int upcase)
...
@@ -81,14 +81,14 @@ char *longlong2str(longlong val,char *dst,int radix, int upcase)
{
{
ulonglong
quo
=
uval
/
(
uint
)
radix
;
ulonglong
quo
=
uval
/
(
uint
)
radix
;
uint
rem
=
(
uint
)
(
uval
-
quo
*
(
uint
)
radix
);
uint
rem
=
(
uint
)
(
uval
-
quo
*
(
uint
)
radix
);
*--
p
=
_
dig_vec
[
rem
];
*--
p
=
dig_vec
[
rem
];
uval
=
quo
;
uval
=
quo
;
}
}
long_val
=
(
long
)
uval
;
long_val
=
(
long
)
uval
;
while
(
long_val
!=
0
)
while
(
long_val
!=
0
)
{
{
long
quo
=
long_val
/
radix
;
long
quo
=
long_val
/
radix
;
*--
p
=
_
dig_vec
[(
uchar
)
(
long_val
-
quo
*
radix
)];
*--
p
=
dig_vec
[(
uchar
)
(
long_val
-
quo
*
radix
)];
long_val
=
quo
;
long_val
=
quo
;
}
}
while
((
*
dst
++
=
*
p
++
)
!=
0
)
;
while
((
*
dst
++
=
*
p
++
)
!=
0
)
;
...
...
strings/longlong2str_asm.c
View file @
06a45722
...
@@ -26,7 +26,7 @@
...
@@ -26,7 +26,7 @@
extern
char
*
longlong2str_with_dig_vector
(
longlong
val
,
char
*
dst
,
int
radix
,
extern
char
*
longlong2str_with_dig_vector
(
longlong
val
,
char
*
dst
,
int
radix
,
const
char
*
dig_vector
);
const
char
*
dig_vector
);
char
*
longlong2str
(
longlong
val
,
char
*
dst
,
int
radix
)
char
*
longlong2str
(
longlong
val
,
char
*
dst
,
int
radix
,
int
upcase
)
{
{
return
longlong2str_with_dig_vector
(
val
,
dst
,
radix
,
_dig_vec_upp
er
);
return
longlong2str_with_dig_vector
(
val
,
dst
,
radix
,
upcase
?
_dig_vec_upper
:
_dig_vec_low
er
);
}
}
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