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
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
ff0ecc09
Commit
ff0ecc09
authored
Dec 19, 2004
by
unknown
Browse files
Options
Browse Files
Download
Plain Diff
Merge bk-internal.mysql.com:/home/bk/mysql-5.0
into mysql.com:/home/my/mysql-5.0 innobase/os/os0proc.c: Auto merged
parents
06904103
bf01c529
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
131 additions
and
61 deletions
+131
-61
innobase/include/rem0rec.ic
innobase/include/rem0rec.ic
+56
-25
innobase/include/trx0roll.h
innobase/include/trx0roll.h
+12
-4
innobase/log/log0recv.c
innobase/log/log0recv.c
+0
-1
innobase/srv/srv0start.c
innobase/srv/srv0start.c
+5
-7
innobase/trx/trx0roll.c
innobase/trx/trx0roll.c
+51
-18
server-tools/instance-manager/mysql_connection.cc
server-tools/instance-manager/mysql_connection.cc
+3
-1
server-tools/instance-manager/priv.cc
server-tools/instance-manager/priv.cc
+4
-0
sql/sql_derived.cc
sql/sql_derived.cc
+0
-5
No files found.
innobase/include/rem0rec.ic
View file @
ff0ecc09
...
@@ -40,8 +40,18 @@ most significant bytes and bits are written below less significant.
...
@@ -40,8 +40,18 @@ most significant bytes and bits are written below less significant.
(1) byte offset (2) bit usage within byte
(1) byte offset (2) bit usage within byte
downward from
downward from
origin -> 1 8 bits pointer to next record (relative)
origin -> 1 8 bits relative offset of next record
2 8 bits pointer to next record (relative)
2 8 bits relative offset of next record
the relative offset is an unsigned 16-bit
integer:
(offset_of_next_record
- offset_of_this_record) mod 64Ki,
where mod is the modulo as a non-negative
number;
we can calculate the the offset of the next
record with the formula:
relative_offset + offset_of_this_record
mod UNIV_PAGE_SIZE
3 3 bits status:
3 3 bits status:
000=conventional record
000=conventional record
001=node pointer record (inside B-tree)
001=node pointer record (inside B-tree)
...
@@ -252,26 +262,37 @@ UNIV_INLINE
...
@@ -252,26 +262,37 @@ UNIV_INLINE
ulint
ulint
rec_get_next_offs(
rec_get_next_offs(
/*==============*/
/*==============*/
/* out: the page offset of the next chained record */
/* out: the page offset of the next chained record, or
0 if none */
rec_t* rec, /* in: physical record */
rec_t* rec, /* in: physical record */
ibool comp) /* in: TRUE=compact page format */
ibool comp) /* in: TRUE=compact page format */
{
{
ulint field_value;
ut_ad(REC_NEXT_MASK == 0xFFFFUL);
ut_ad(REC_NEXT_SHIFT == 0);
field_value = mach_read_from_2(rec - REC_NEXT);
if (comp) {
if (comp) {
lint ret = (signed short) rec_get_bit_field_2(rec, REC_NEXT,
REC_NEXT_MASK, REC_NEXT_SHIFT);
#if UNIV_PAGE_SIZE <= 32768
#if UNIV_PAGE_SIZE <= 32768
/* with 64 KiB page size, the pointer will "wrap around",
/* Note that for 64 KiB pages, field_value can 'wrap around'
and the following assertions are invalid */
and the debug assertion is not valid */
ut_ad(ret + ut_align_offset(rec, UNIV_PAGE_SIZE) <
UNIV_PAGE_SIZE);
ut_ad((int16_t)field_value
+ ut_align_offset(rec, UNIV_PAGE_SIZE)
< UNIV_PAGE_SIZE);
#endif
#endif
return(ret ? ut_align_offset(rec + ret, UNIV_PAGE_SIZE) : 0);
if (field_value == 0) {
}
else {
return(0);
ulint ret = rec_get_bit_field_2(rec, REC_NEXT,
}
REC_NEXT_MASK, REC_NEXT_SHIFT);
ut_ad(ret < UNIV_PAGE_SIZE);
return(ut_align_offset(rec + field_value, UNIV_PAGE_SIZE));
return(ret);
} else {
ut_ad(field_value < UNIV_PAGE_SIZE);
return(field_value);
}
}
}
}
...
@@ -284,21 +305,31 @@ rec_set_next_offs(
...
@@ -284,21 +305,31 @@ rec_set_next_offs(
/*==============*/
/*==============*/
rec_t* rec, /* in: physical record */
rec_t* rec, /* in: physical record */
ibool comp, /* in: TRUE=compact page format */
ibool comp, /* in: TRUE=compact page format */
ulint next) /* in: offset of the next record */
ulint next) /* in: offset of the next record
, or 0 if none
*/
{
{
ut_ad(rec);
ut_ad(rec);
ut_ad(UNIV_PAGE_SIZE > next);
ut_ad(UNIV_PAGE_SIZE > next);
ut_ad(REC_NEXT_MASK == 0xFFFFUL);
ut_ad(REC_NEXT_SHIFT == 0);
if (comp) {
if (comp) {
rec_set_bit_field_2(rec, next
ulint field_value;
? (next - ut_align_offset(rec, UNIV_PAGE_SIZE))
#ifdef UNIV_DEBUG /* avoid an assertion failure */
if (next) {
& (REC_NEXT_MASK >> REC_NEXT_SHIFT)
/* The following two statements calculate
#endif
next - offset_of_rec mod 64Ki, where mod is the modulo
: 0, REC_NEXT, REC_NEXT_MASK, REC_NEXT_SHIFT);
as a non-negative number */
field_value = (ulint)((lint)next
- (lint)ut_align_offset(rec, UNIV_PAGE_SIZE));
field_value &= REC_NEXT_MASK;
} else {
field_value = 0;
}
mach_write_to_2(rec - REC_NEXT, field_value);
} else {
} else {
rec_set_bit_field_2(rec, next,
mach_write_to_2(rec - REC_NEXT, next);
REC_NEXT, REC_NEXT_MASK, REC_NEXT_SHIFT);
}
}
}
}
...
...
innobase/include/trx0roll.h
View file @
ff0ecc09
...
@@ -105,11 +105,19 @@ trx_rollback(
...
@@ -105,11 +105,19 @@ trx_rollback(
Rollback or clean up transactions which have no user session. If the
Rollback or clean up transactions which have no user session. If the
transaction already was committed, then we clean up a possible insert
transaction already was committed, then we clean up a possible insert
undo log. If the transaction was not yet committed, then we roll it back.
undo log. If the transaction was not yet committed, then we roll it back.
Note: this is done in a background thread */
Note: this is done in a background thread
.
*/
void
*
#ifndef __WIN__
trx_rollback_or_clean_all_without_sess
(
void
*
);
void
*
/*============================================*/
#else
ulint
#endif
trx_rollback_or_clean_all_without_sess
(
/*===================================*/
/* out: a dummy parameter */
void
*
arg
__attribute__
((
unused
)));
/* in: a dummy parameter required by
os_thread_create */
/********************************************************************
/********************************************************************
Finishes a transaction rollback. */
Finishes a transaction rollback. */
...
...
innobase/log/log0recv.c
View file @
ff0ecc09
...
@@ -2937,7 +2937,6 @@ recv_recovery_from_checkpoint_finish(void)
...
@@ -2937,7 +2937,6 @@ recv_recovery_from_checkpoint_finish(void)
#ifndef UNIV_LOG_DEBUG
#ifndef UNIV_LOG_DEBUG
recv_sys_free
();
recv_sys_free
();
#endif
#endif
if
(
srv_force_recovery
<
SRV_FORCE_NO_TRX_UNDO
)
{
if
(
srv_force_recovery
<
SRV_FORCE_NO_TRX_UNDO
)
{
os_thread_create
(
trx_rollback_or_clean_all_without_sess
,
os_thread_create
(
trx_rollback_or_clean_all_without_sess
,
(
void
*
)
&
i
,
&
recovery_thread_id
);
(
void
*
)
&
i
,
&
recovery_thread_id
);
...
...
innobase/srv/srv0start.c
View file @
ff0ecc09
...
@@ -1403,15 +1403,13 @@ NetWare. */
...
@@ -1403,15 +1403,13 @@ NetWare. */
fsp_header_inc_size
(
0
,
sum_of_new_sizes
,
&
mtr
);
fsp_header_inc_size
(
0
,
sum_of_new_sizes
,
&
mtr
);
mtr_commit
(
&
mtr
);
mtr_commit
(
&
mtr
);
}
if
(
recv_needed_recovery
)
{
/* Immediately write the log record about increased tablespace
ut_print_timestamp
(
stderr
);
size to disk, so that it is durable even if mysqld would crash
fprintf
(
stderr
,
quickly */
" InnoDB: Flushing modified pages from the buffer pool...
\n
"
);
}
log_make_checkpoint_at
(
ut_dulint_max
,
TRUE
);
log_buffer_flush_to_disk
();
}
#ifdef UNIV_LOG_ARCHIVE
#ifdef UNIV_LOG_ARCHIVE
/* Archiving is always off under MySQL */
/* Archiving is always off under MySQL */
...
...
innobase/trx/trx0roll.c
View file @
ff0ecc09
...
@@ -30,9 +30,13 @@ Created 3/26/1996 Heikki Tuuri
...
@@ -30,9 +30,13 @@ Created 3/26/1996 Heikki Tuuri
/* This many pages must be undone before a truncate is tried within rollback */
/* This many pages must be undone before a truncate is tried within rollback */
#define TRX_ROLL_TRUNC_THRESHOLD 1
#define TRX_ROLL_TRUNC_THRESHOLD 1
/* In crash recovery, the current trx to be rolled back */
trx_t
*
trx_roll_crash_recv_trx
=
NULL
;
/* In crash recovery we set this to the undo n:o of the current trx to be
/* In crash recovery we set this to the undo n:o of the current trx to be
rolled back. Then we can print how many % the rollback has progressed. */
rolled back. Then we can print how many % the rollback has progressed. */
ib_longlong
trx_roll_max_undo_no
;
ib_longlong
trx_roll_max_undo_no
;
/* Auxiliary variable which tells the previous progress % we printed */
/* Auxiliary variable which tells the previous progress % we printed */
ulint
trx_roll_progress_printed_pct
;
ulint
trx_roll_progress_printed_pct
;
...
@@ -332,11 +336,19 @@ trx_savept_take(
...
@@ -332,11 +336,19 @@ trx_savept_take(
Rollback or clean up transactions which have no user session. If the
Rollback or clean up transactions which have no user session. If the
transaction already was committed, then we clean up a possible insert
transaction already was committed, then we clean up a possible insert
undo log. If the transaction was not yet committed, then we roll it back.
undo log. If the transaction was not yet committed, then we roll it back.
Note: this is done in a background thread */
Note: this is done in a background thread
.
*/
void
*
#ifndef __WIN__
trx_rollback_or_clean_all_without_sess
(
void
*
i
)
void
*
/*========================================*/
#else
ulint
#endif
trx_rollback_or_clean_all_without_sess
(
/*===================================*/
/* out: a dummy parameter */
void
*
arg
__attribute__
((
unused
)))
/* in: a dummy parameter required by
os_thread_create */
{
{
mem_heap_t
*
heap
;
mem_heap_t
*
heap
;
que_fork_t
*
fork
;
que_fork_t
*
fork
;
...
@@ -361,9 +373,9 @@ trx_rollback_or_clean_all_without_sess(void *i)
...
@@ -361,9 +373,9 @@ trx_rollback_or_clean_all_without_sess(void *i)
if
(
UT_LIST_GET_FIRST
(
trx_sys
->
trx_list
))
{
if
(
UT_LIST_GET_FIRST
(
trx_sys
->
trx_list
))
{
fprintf
(
stderr
,
fprintf
(
stderr
,
"InnoDB: Starting
rollback of uncommitted transactions
\n
"
);
"InnoDB: Starting in background the
rollback of uncommitted transactions
\n
"
);
}
else
{
}
else
{
os_thread_exit
(
i
)
;
goto
leave_function
;
}
}
loop:
loop:
heap
=
mem_heap_create
(
512
);
heap
=
mem_heap_create
(
512
);
...
@@ -373,7 +385,6 @@ loop:
...
@@ -373,7 +385,6 @@ loop:
trx
=
UT_LIST_GET_FIRST
(
trx_sys
->
trx_list
);
trx
=
UT_LIST_GET_FIRST
(
trx_sys
->
trx_list
);
while
(
trx
)
{
while
(
trx
)
{
if
((
trx
->
sess
||
(
trx
->
conc_state
==
TRX_NOT_STARTED
)))
{
if
((
trx
->
sess
||
(
trx
->
conc_state
==
TRX_NOT_STARTED
)))
{
trx
=
UT_LIST_GET_NEXT
(
trx_list
,
trx
);
trx
=
UT_LIST_GET_NEXT
(
trx_list
,
trx
);
}
else
if
(
trx
->
conc_state
==
TRX_PREPARED
)
{
}
else
if
(
trx
->
conc_state
==
TRX_PREPARED
)
{
...
@@ -386,17 +397,17 @@ loop:
...
@@ -386,17 +397,17 @@ loop:
mutex_exit
(
&
kernel_mutex
);
mutex_exit
(
&
kernel_mutex
);
if
(
trx
==
NULL
)
{
if
(
trx
==
NULL
)
{
ut_print_timestamp
(
stderr
);
fprintf
(
stderr
,
fprintf
(
stderr
,
"InnoDB: Rollback of uncommitted transactions completed
\n
"
);
"
InnoDB: Rollback of uncommitted transactions completed
\n
"
);
mem_heap_free
(
heap
);
mem_heap_free
(
heap
);
os_thread_exit
(
i
)
;
goto
leave_function
;
}
}
trx
->
sess
=
trx_dummy_sess
;
trx
->
sess
=
trx_dummy_sess
;
if
(
trx
->
conc_state
==
TRX_COMMITTED_IN_MEMORY
)
{
if
(
trx
->
conc_state
==
TRX_COMMITTED_IN_MEMORY
)
{
fprintf
(
stderr
,
"InnoDB: Cleaning up trx with id %lu %lu
\n
"
,
fprintf
(
stderr
,
"InnoDB: Cleaning up trx with id %lu %lu
\n
"
,
(
ulong
)
ut_dulint_get_high
(
trx
->
id
),
(
ulong
)
ut_dulint_get_high
(
trx
->
id
),
...
@@ -425,21 +436,28 @@ loop:
...
@@ -425,21 +436,28 @@ loop:
ut_a
(
thr
==
que_fork_start_command
(
fork
));
ut_a
(
thr
==
que_fork_start_command
(
fork
));
trx_roll_crash_recv_trx
=
trx
;
trx_roll_max_undo_no
=
ut_conv_dulint_to_longlong
(
trx
->
undo_no
);
trx_roll_max_undo_no
=
ut_conv_dulint_to_longlong
(
trx
->
undo_no
);
trx_roll_progress_printed_pct
=
0
;
trx_roll_progress_printed_pct
=
0
;
rows_to_undo
=
trx_roll_max_undo_no
;
rows_to_undo
=
trx_roll_max_undo_no
;
if
(
rows_to_undo
>
1000000000
)
{
if
(
rows_to_undo
>
1000000000
)
{
rows_to_undo
=
rows_to_undo
/
1000000
;
rows_to_undo
=
rows_to_undo
/
1000000
;
unit
=
"M"
;
unit
=
"M"
;
}
}
ut_print_timestamp
(
stderr
);
fprintf
(
stderr
,
fprintf
(
stderr
,
"
InnoDB: Rolling back trx with id %lu %lu, %lu%s rows to undo
"
,
"
InnoDB: Rolling back trx with id %lu %lu, %lu%s rows to undo
\n
"
,
(
ulong
)
ut_dulint_get_high
(
trx
->
id
),
(
ulong
)
ut_dulint_get_high
(
trx
->
id
),
(
ulong
)
ut_dulint_get_low
(
trx
->
id
),
(
ulong
)
ut_dulint_get_low
(
trx
->
id
),
(
ulong
)
rows_to_undo
,
unit
);
(
ulong
)
rows_to_undo
,
unit
);
mutex_exit
(
&
kernel_mutex
);
mutex_exit
(
&
kernel_mutex
);
trx
->
mysql_thread_id
=
os_thread_get_curr_id
();
trx
->
mysql_process_no
=
os_proc_get_number
();
if
(
trx
->
dict_operation
)
{
if
(
trx
->
dict_operation
)
{
row_mysql_lock_data_dictionary
(
trx
);
row_mysql_lock_data_dictionary
(
trx
);
}
}
...
@@ -454,7 +472,7 @@ loop:
...
@@ -454,7 +472,7 @@ loop:
fprintf
(
stderr
,
fprintf
(
stderr
,
"InnoDB: Waiting for rollback of trx id %lu to end
\n
"
,
"InnoDB: Waiting for rollback of trx id %lu to end
\n
"
,
(
ulong
)
ut_dulint_get_low
(
trx
->
id
));
(
ulong
)
ut_dulint_get_low
(
trx
->
id
));
os_thread_sleep
(
100000
);
os_thread_sleep
(
100000
);
mutex_enter
(
&
kernel_mutex
);
mutex_enter
(
&
kernel_mutex
);
...
@@ -493,9 +511,23 @@ loop:
...
@@ -493,9 +511,23 @@ loop:
(
ulong
)
ut_dulint_get_low
(
trx
->
id
));
(
ulong
)
ut_dulint_get_low
(
trx
->
id
));
mem_heap_free
(
heap
);
mem_heap_free
(
heap
);
trx_roll_crash_recv_trx
=
NULL
;
goto
loop
;
goto
loop
;
os_thread_exit
(
i
);
/* not reached */
leave_function:
/* We count the number of threads in os_thread_exit(). A created
thread should always use that to exit and not use return() to exit. */
os_thread_exit
(
NULL
);
/* The following is dummy code to keep the compiler happy: */
#ifndef __WIN__
return
(
NULL
);
#else
return
(
0
);
#endif
}
}
/***********************************************************************
/***********************************************************************
...
@@ -856,16 +888,17 @@ try_again:
...
@@ -856,16 +888,17 @@ try_again:
ut_ad
(
ut_dulint_cmp
(
ut_dulint_add
(
undo_no
,
1
),
trx
->
undo_no
)
==
0
);
ut_ad
(
ut_dulint_cmp
(
ut_dulint_add
(
undo_no
,
1
),
trx
->
undo_no
)
==
0
);
/* We print rollback progress info if we are in a crash recovery
/* We print rollback progress info if we are in a crash recovery
and the transaction has at least 1000 row operations to undo */
and the transaction has at least 1000 row operations to undo. */
if
(
trx
==
trx_roll_crash_recv_trx
&&
trx_roll_max_undo_no
>
1000
)
{
if
(
srv_is_being_started
&&
trx_roll_max_undo_no
>
1000
)
{
progress_pct
=
100
-
(
ulint
)
progress_pct
=
100
-
(
ulint
)
((
ut_conv_dulint_to_longlong
(
undo_no
)
*
100
)
((
ut_conv_dulint_to_longlong
(
undo_no
)
*
100
)
/
trx_roll_max_undo_no
);
/
trx_roll_max_undo_no
);
if
(
progress_pct
!=
trx_roll_progress_printed_pct
)
{
if
(
progress_pct
!=
trx_roll_progress_printed_pct
)
{
if
(
trx_roll_progress_printed_pct
==
0
)
{
if
(
trx_roll_progress_printed_pct
==
0
)
{
fprintf
(
stderr
,
fprintf
(
stderr
,
"
\n
InnoDB: Progress in percents: %lu
"
,
(
ulong
)
progress_pct
);
"
\n
InnoDB: Progress in percents: %lu
\n
"
,
(
ulong
)
progress_pct
);
}
else
{
}
else
{
fprintf
(
stderr
,
fprintf
(
stderr
,
" %lu"
,
(
ulong
)
progress_pct
);
" %lu"
,
(
ulong
)
progress_pct
);
...
...
server-tools/instance-manager/mysql_connection.cc
View file @
ff0ecc09
...
@@ -191,9 +191,11 @@ void Mysql_connection_thread::run()
...
@@ -191,9 +191,11 @@ void Mysql_connection_thread::run()
int
Mysql_connection_thread
::
check_connection
()
int
Mysql_connection_thread
::
check_connection
()
{
{
ulong
pkt_len
=
0
;
// to hold client reply length
ulong
pkt_len
=
0
;
// to hold client reply length
/* maximum size of the version string */
enum
{
MAX_VERSION_LENGTH
=
80
};
/* buffer for the first packet */
/* packet contains: */
/* buffer for the first packet */
/* packet contains: */
char
buff
[
mysqlmanager_version_length
+
1
+
// server version, 0-ended
char
buff
[
MAX_VERSION_LENGTH
+
1
+
// server version, 0-ended
4
+
// connection id
4
+
// connection id
SCRAMBLE_LENGTH
+
2
+
// scramble (in 2 pieces)
SCRAMBLE_LENGTH
+
2
+
// scramble (in 2 pieces)
18
];
// server variables: flags,
18
];
// server variables: flags,
...
...
server-tools/instance-manager/priv.cc
View file @
ff0ecc09
...
@@ -16,6 +16,10 @@
...
@@ -16,6 +16,10 @@
#include "priv.h"
#include "priv.h"
/*
The following string must be less then 80 characters, as
mysql_connection.cc relies on it
*/
const
char
mysqlmanager_version
[]
=
"0.2-alpha"
;
const
char
mysqlmanager_version
[]
=
"0.2-alpha"
;
const
int
mysqlmanager_version_length
=
sizeof
(
mysqlmanager_version
)
-
1
;
const
int
mysqlmanager_version_length
=
sizeof
(
mysqlmanager_version
)
-
1
;
...
...
sql/sql_derived.cc
View file @
ff0ecc09
...
@@ -268,13 +268,8 @@ int mysql_derived_filling(THD *thd, LEX *lex, TABLE_LIST *orig_table_list)
...
@@ -268,13 +268,8 @@ int mysql_derived_filling(THD *thd, LEX *lex, TABLE_LIST *orig_table_list)
unit
->
cleanup
();
unit
->
cleanup
();
}
}
else
else
{
free_tmp_table
(
thd
,
table
);
unit
->
cleanup
();
unit
->
cleanup
();
}
lex
->
current_select
=
save_current_select
;
lex
->
current_select
=
save_current_select
;
if
(
res
)
free_tmp_table
(
thd
,
table
);
}
}
return
res
;
return
res
;
}
}
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