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
c12c0952
Commit
c12c0952
authored
Feb 08, 2006
by
pappa@c-9a08e253.1238-1-64736c10.cust.bredbandsbolaget.se
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
WL 2826: Error handling for ALTER TABLE for partitioning Step 13
Lots of compilation fixes
parent
221a17db
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
91 additions
and
76 deletions
+91
-76
sql/mysql_priv.h
sql/mysql_priv.h
+4
-4
sql/sql_partition.cc
sql/sql_partition.cc
+28
-28
sql/sql_table.cc
sql/sql_table.cc
+59
-44
No files found.
sql/mysql_priv.h
View file @
c12c0952
...
...
@@ -647,7 +647,7 @@ my_error_inject(int value)
}
#define ERROR_INJECT_CRASH(code) \
DBUG_EXECUTE_COND(code, abort()
;
)
DBUG_EXECUTE_COND(code, abort())
#define ERROR_INJECT_ACTION(code, action) \
(my_error_inject_name(code) ? ((action), 0) : 0)
#define ERROR_INJECT(code) \
...
...
@@ -1171,9 +1171,9 @@ typedef struct st_table_log_entry
typedef
struct
st_table_log_memory_entry
{
uint
entry_pos
;
TABLE_LOG_MEMORY
*
next_log_entry
;
TABLE_LOG_MEMORY
*
prev_log_entry
;
TABLE_LOG_MEMORY
*
next_active_log_entry
;
struct
st_table_log_memory_entry
*
next_log_entry
;
struct
st_table_log_memory_entry
*
prev_log_entry
;
struct
st_table_log_memory_entry
*
next_active_log_entry
;
}
TABLE_LOG_MEMORY_ENTRY
;
bool
write_table_log_entry
(
TABLE_LOG_ENTRY
*
table_log_entry
,
...
...
sql/sql_partition.cc
View file @
c12c0952
...
...
@@ -5409,25 +5409,25 @@ uint fast_alter_partition_table(THD *thd, TABLE *table,
to test if recovery is properly done.
*/
if
(
write_log_shadow_frm
(
lpt
,
FALSE
)
||
ERROR_INJECT_CRASH
(
1000
)
||
ERROR_INJECT_CRASH
(
"crash_drop_partition_1"
)
||
mysql_write_frm
(
lpt
,
WFRM_WRITE_SHADOW
)
||
ERROR_INJECT_CRASH
(
1001
)
||
ERROR_INJECT_CRASH
(
"crash_drop_partition_2"
)
||
write_log_drop_partition
(
lpt
)
||
ERROR_INJECT_CRASH
(
1002
)
||
ERROR_INJECT_CRASH
(
"crash_drop_partition_3"
)
||
abort_and_upgrade_lock
(
lpt
)
||
((
!
thd
->
lex
->
no_write_to_binlog
)
&&
(
write_bin_log
(
thd
,
FALSE
,
thd
->
query
,
thd
->
query_length
),
FALSE
))
||
ERROR_INJECT_CRASH
(
1003
)
||
ERROR_INJECT_CRASH
(
"crash_drop_partition_4"
)
||
mysql_write_frm
(
lpt
,
WFRM_INSTALL_SHADOW
)
||
(
close_open_tables_and_downgrade
(
lpt
),
FALSE
)
||
ERROR_INJECT_CRASH
(
1004
)
||
ERROR_INJECT_CRASH
(
"crash_drop_partition_5"
)
||
table
->
file
->
extra
(
HA_EXTRA_PREPARE_FOR_DELETE
)
||
ERROR_INJECT_CRASH
(
1005
)
||
ERROR_INJECT_CRASH
(
"crash_drop_partition_6"
)
||
mysql_drop_partitions
(
lpt
)
||
ERROR_INJECT_CRASH
(
1006
)
||
ERROR_INJECT_CRASH
(
"crash_drop_partition_7"
)
||
write_log_completed
(
lpt
)
||
ERROR_INJECT_CRASH
(
1007
)
||
ERROR_INJECT_CRASH
(
"crash_drop_partition_8"
)
||
(
mysql_wait_completed_table
(
lpt
,
table
),
FALSE
))
{
fast_alter_partition_error_handler
(
lpt
);
...
...
@@ -5465,25 +5465,25 @@ uint fast_alter_partition_table(THD *thd, TABLE *table,
9) Complete query
*/
if
(
write_log_shadow_frm
(
lpt
,
FALSE
)
||
ERROR_INJECT_CRASH
(
1010
)
||
ERROR_INJECT_CRASH
(
"crash_add_partition_1"
)
||
mysql_write_frm
(
lpt
,
WFRM_WRITE_SHADOW
)
||
ERROR_INJECT_CRASH
(
1011
)
||
ERROR_INJECT_CRASH
(
"crash_add_partition_2"
)
||
write_log_add_partition
(
lpt
)
||
ERROR_INJECT_CRASH
(
1012
)
||
ERROR_INJECT_CRASH
(
"crash_add_partition_3"
)
||
mysql_change_partitions
(
lpt
)
||
ERROR_INJECT_CRASH
(
1013
)
||
ERROR_INJECT_CRASH
(
"crash_add_partition_4"
)
||
abort_and_upgrade_lock
(
lpt
)
||
((
!
thd
->
lex
->
no_write_to_binlog
)
&&
(
write_bin_log
(
thd
,
FALSE
,
thd
->
query
,
thd
->
query_length
),
FALSE
))
||
ERROR_INJECT_CRASH
(
1014
)
||
ERROR_INJECT_CRASH
(
"crash_add_partition_5"
)
||
write_log_shadow_frm
(
lpt
,
TRUE
)
||
ERROR_INJECT_CRASH
(
1015
)
||
ERROR_INJECT_CRASH
(
"crash_add_partition_6"
)
||
mysql_write_frm
(
lpt
,
WFRM_INSTALL_SHADOW
)
||
ERROR_INJECT_CRASH
(
1016
)
||
ERROR_INJECT_CRASH
(
"crash_add_partition_7"
)
||
(
close_open_tables_and_downgrade
(
lpt
),
FALSE
)
||
write_log_completed
(
lpt
)
||
ERROR_INJECT_CRASH
(
1017
))
ERROR_INJECT_CRASH
(
"crash_add_partition_8"
))
{
fast_alter_partition_error_handler
(
lpt
);
DBUG_RETURN
(
TRUE
);
...
...
@@ -5546,32 +5546,32 @@ uint fast_alter_partition_table(THD *thd, TABLE *table,
*/
if
(
write_log_shadow_frm
(
lpt
,
FALSE
)
||
ERROR_INJECT_CRASH
(
1020
)
||
ERROR_INJECT_CRASH
(
"crash_change_partition_1"
)
||
mysql_write_frm
(
lpt
,
WFRM_WRITE_SHADOW
)
||
ERROR_INJECT_CRASH
(
1021
)
||
ERROR_INJECT_CRASH
(
"crash_change_partition_2"
)
||
write_log_ph1_change_partition
(
lpt
)
||
ERROR_INJECT_CRASH
(
1022
)
||
ERROR_INJECT_CRASH
(
"crash_change_partition_3"
)
||
mysql_change_partitions
(
lpt
)
||
ERROR_INJECT_CRASH
(
1023
)
||
ERROR_INJECT_CRASH
(
"crash_change_partition_4"
)
||
write_log_ph2_change_partition
(
lpt
)
||
ERROR_INJECT_CRASH
(
1024
)
||
ERROR_INJECT_CRASH
(
"crash_change_partition_5"
)
||
abort_and_upgrade_lock
(
lpt
)
||
table
->
file
->
extra
(
HA_EXTRA_PREPARE_FOR_DELETE
)
||
ERROR_INJECT_CRASH
(
1025
)
||
ERROR_INJECT_CRASH
(
"crash_change_partition_6"
)
||
mysql_rename_partitions
(
lpt
)
||
ERROR_INJECT_CRASH
(
1026
)
||
ERROR_INJECT_CRASH
(
"crash_change_partition_7"
)
||
((
!
thd
->
lex
->
no_write_to_binlog
)
&&
(
write_bin_log
(
thd
,
FALSE
,
thd
->
query
,
thd
->
query_length
),
FALSE
))
||
ERROR_INJECT_CRASH
(
1027
)
||
ERROR_INJECT_CRASH
(
"crash_change_partition_8"
)
||
mysql_write_frm
(
lpt
,
WFRM_INSTALL_SHADOW
)
||
ERROR_INJECT_CRASH
(
1028
)
||
ERROR_INJECT_CRASH
(
"crash_change_partition_9"
)
||
(
close_open_tables_and_downgrade
(
lpt
),
FALSE
)
||
ERROR_INJECT_CRASH
(
1029
)
||
ERROR_INJECT_CRASH
(
"crash_change_partition_10"
)
||
mysql_drop_partitions
(
lpt
)
||
ERROR_INJECT_CRASH
(
1030
)
||
ERROR_INJECT_CRASH
(
"crash_change_partition_11"
)
||
write_log_completed
(
lpt
)
||
ERROR_INJECT_CRASH
(
1031
)
||
ERROR_INJECT_CRASH
(
"crash_change_partition_12"
)
||
(
mysql_wait_completed_table
(
lpt
,
table
),
FALSE
))
{
fast_alter_partition_error_handler
(
lpt
);
...
...
sql/sql_table.cc
View file @
c12c0952
...
...
@@ -357,7 +357,7 @@ write_table_log_header()
DBUG_ENTER
(
"write_table_log_header"
);
int4store
(
&
global_table_log
.
file_entry
[
0
],
global_table_log
.
no_entries
);
const_var
=
NAME
LEN
;
const_var
=
FN_
LEN
;
int2store
(
&
global_table_log
.
file_entry
[
4
],
const_var
);
const_var
=
32
;
int2store
(
&
global_table_log
.
file_entry
[
6
],
const_var
);
...
...
@@ -428,11 +428,12 @@ read_table_log_header()
{
char
*
file_entry
=
(
char
*
)
global_table_log
.
file_entry
;
char
file_name
[
FN_REFLEN
];
uint
entry_no
;
DBUG_ENTER
(
"read_table_log_header"
);
bzero
(
file_entry
,
sizeof
(
global_table_log
.
file_entry
));
create_table_log_file_name
(
file_name
);
if
(
!
(
my_open
(
file_name
,
O_RDWR
|
O_TRUNC
,
MYF
(
0
))))
if
(
!
(
my_open
(
file_name
,
O_RDWR
|
O_TRUNC
|
O_BINARY
,
MYF
(
0
))))
{
if
(
read_table_log_file_entry
(
0UL
))
{
...
...
@@ -467,10 +468,10 @@ bool
read_table_log_entry
(
uint
read_entry
,
TABLE_LOG_ENTRY
*
table_log_entry
)
{
char
*
file_entry
=
(
char
*
)
&
global_table_log
.
file_entry
;
uint
inx
;
DBUG_ENTER
(
"read_table_log_entry"
);
if
(
read_table_log_file_entry
(
global_table_log
.
file_id
,
(
char
*
)
&
file_entry
,
read_entry
))
if
(
read_table_log_file_entry
(
read_entry
))
{
/* Error handling */
DBUG_RETURN
(
TRUE
);
...
...
@@ -479,10 +480,10 @@ read_table_log_entry(uint read_entry, TABLE_LOG_ENTRY *table_log_entry)
table_log_entry
->
action_type
=
file_entry
[
1
];
table_log_entry
->
next_entry
=
uint4korr
(
&
file_entry
[
2
]);
table_log_entry
->
name
=
&
file_entry
[
6
];
in
dex
=
6
+
global_table_log
->
name_len
;
table_log_entry
->
from_name
=
&
file_entry
[
in
de
x
];
in
dex
+=
global_table_log
->
name_len
;
table_log_entry
->
handler_type
=
&
file_entry
[
in
de
x
];
in
x
=
6
+
global_table_log
.
name_len
;
table_log_entry
->
from_name
=
&
file_entry
[
inx
];
in
x
+=
global_table_log
.
name_len
;
table_log_entry
->
handler_type
=
&
file_entry
[
inx
];
DBUG_RETURN
(
FALSE
);
}
...
...
@@ -508,10 +509,11 @@ init_table_log()
DBUG_ENTER
(
"init_table_log"
);
create_table_log_file_name
(
file_name
);
VOID
(
my_delete
(
file_name
));
VOID
(
my_delete
(
file_name
,
MYF
(
0
)
));
if
((
global_table_log
.
file_id
=
my_create
(
file_name
,
CREATE_MODE
,
create_flags
,
MYF
(
0
)))
<
0
)
O_RDWR
|
O_TRUNC
|
O_BINARY
,
MYF
(
0
)))
<
0
)
{
/* Couldn't create table log file, this is serious error */
abort
();
...
...
@@ -556,28 +558,31 @@ execute_table_log_action(TABLE_LOG_ENTRY *table_log_entry)
static
bool
get_free_table_log_entry
(
TABLE_LOG_MEMORY_ENTRY
**
active_entry
)
get_free_table_log_entry
(
TABLE_LOG_MEMORY_ENTRY
**
active_entry
,
bool
*
write_header
)
{
bool
write_header
;
uint
entry_no
;
TABLE_LOG_MEMORY_ENTRY
*
used_entry
;
TABLE_LOG_MEMORY_ENTRY
*
first_used
=
global_table_log
.
first_used
;
DBUG_ENTER
(
"get_free_table_log_entry"
);
if
(
global_table_log
.
first_free
==
NULL
)
{
if
(
!
(
used_entry
=
my_malloc
(
sizeof
(
TABLE_LOG_MEMORY_ENTRY
))))
if
(
!
(
used_entry
=
(
TABLE_LOG_MEMORY_ENTRY
*
)
my_malloc
(
sizeof
(
TABLE_LOG_MEMORY_ENTRY
),
MYF
(
0
))))
{
DBUG_RETURN
(
TRUE
);
}
global_table_log
.
no_entries
++
;
used_entry
->
entry_
no
=
entry_no
=
global_table_log
.
no_entries
;
write_header
=
TRUE
;
used_entry
->
entry_
pos
=
entry_no
=
global_table_log
.
no_entries
;
*
write_header
=
TRUE
;
}
else
{
used_entry
=
global_table_log
.
first_free
;
global_table_log
.
first_free
=
used_entry
->
next_log_entry
;
entry_no
=
first_free
->
entry_pos
;
used_entry
=
first_free
;
write_header
=
FALSE
;
entry_no
=
used_entry
->
entry_pos
;
*
write_header
=
FALSE
;
}
/*
Move from free list to used list
...
...
@@ -589,6 +594,7 @@ get_free_table_log_entry(TABLE_LOG_MEMORY_ENTRY **active_entry)
first_used
->
prev_log_entry
=
used_entry
;
*
active_entry
=
used_entry
;
DBUG_RETURN
(
FALSE
);
}
...
...
@@ -616,7 +622,7 @@ bool
write_table_log_entry
(
TABLE_LOG_ENTRY
*
table_log_entry
,
TABLE_LOG_MEMORY_ENTRY
**
active_entry
)
{
bool
error
;
bool
error
,
write_header
;
DBUG_ENTER
(
"write_table_log_entry"
);
global_table_log
.
file_entry
[
0
]
=
'i'
;
...
...
@@ -624,24 +630,25 @@ write_table_log_entry(TABLE_LOG_ENTRY *table_log_entry,
int4store
(
&
global_table_log
.
file_entry
[
2
],
table_log_entry
->
next_entry
);
strcpy
(
&
global_table_log
.
file_entry
[
6
],
table_log_entry
->
name
);
if
(
table_log_entry
.
action_type
==
'r'
)
global_table_log
.
file_entry
[
6
+
NAME
LEN
]
=
0
;
if
(
table_log_entry
->
action_type
==
'r'
)
global_table_log
.
file_entry
[
6
+
FN_
LEN
]
=
0
;
else
strcpy
(
&
global_table_log
.
file_entry
[
6
+
NAME
LEN
],
strcpy
(
&
global_table_log
.
file_entry
[
6
+
FN_
LEN
],
table_log_entry
->
from_name
);
strcpy
(
&
global_table_log
.
file_entry
[
6
+
(
2
*
NAME
LEN
)],
strcpy
(
&
global_table_log
.
file_entry
[
6
+
(
2
*
FN_
LEN
)],
table_log_entry
->
handler_type
);
if
(
get_free_table_log_entry
(
active_entry
))
if
(
get_free_table_log_entry
(
active_entry
,
&
write_header
))
{
DBUG_RETURN
(
TRUE
);
}
error
=
FALSE
;
if
(
write_table_log_file_entry
(
global_table_log
.
file_id
,
global_table_log
.
file_entry
,
(
*
active_entry
)
->
entry_pos
))
if
(
write_table_log_file_entry
((
*
active_entry
)
->
entry_pos
))
error
=
TRUE
;
else
if
(
write_header
||
!
(
write_table_log_header
()))
if
(
write_header
&&
!
error
)
{
if
(
sync_table_log
()
||
write_table_log_header
())
error
=
TRUE
;
}
if
(
error
)
release_table_log_memory_entry
(
*
active_entry
);
DBUG_RETURN
(
error
);
...
...
@@ -673,6 +680,7 @@ bool
write_execute_table_log_entry
(
uint
first_entry
,
TABLE_LOG_MEMORY_ENTRY
**
active_entry
)
{
bool
write_header
;
char
*
file_entry
=
(
char
*
)
global_table_log
.
file_entry
;
DBUG_ENTER
(
"write_execute_table_log_entry"
);
...
...
@@ -681,9 +689,9 @@ write_execute_table_log_entry(uint first_entry,
file_entry
[
1
]
=
0
;
/* Ignored for execute entries */
int4store
(
&
file_entry
[
2
],
first_entry
);
file_entry
[
6
]
=
0
;
file_entry
[
6
+
NAME
LEN
]
=
0
;
file_entry
[
6
+
2
*
NAME
LEN
]
=
0
;
if
(
get_free_table_log_entry
(
active_entry
))
file_entry
[
6
+
FN_
LEN
]
=
0
;
file_entry
[
6
+
2
*
FN_
LEN
]
=
0
;
if
(
get_free_table_log_entry
(
active_entry
,
&
write_header
))
{
DBUG_RETURN
(
TRUE
);
}
...
...
@@ -693,6 +701,14 @@ write_execute_table_log_entry(uint first_entry,
DBUG_RETURN
(
TRUE
);
}
VOID
(
sync_table_log
());
if
(
write_header
)
{
if
(
write_table_log_header
())
{
release_table_log_memory_entry
(
*
active_entry
);
DBUG_RETURN
(
TRUE
);
}
}
DBUG_RETURN
(
FALSE
);
}
...
...
@@ -723,7 +739,7 @@ release_table_log_memory_entry(TABLE_LOG_MEMORY_ENTRY *log_entry)
global_table_log
.
first_used
=
next_log_entry
;
if
(
next_log_entry
)
next_log_entry
->
prev_log_entry
=
prev_log_entry
;
DBUG_
RETURN_VOID
;
DBUG_
VOID_RETURN
;
}
...
...
@@ -738,7 +754,6 @@ release_table_log_memory_entry(TABLE_LOG_MEMORY_ENTRY *log_entry)
FALSE Success
*/
static
bool
execute_table_log_entry
(
uint
first_entry
)
{
...
...
@@ -781,7 +796,7 @@ execute_table_log_recovery()
TABLE_LOG_ENTRY
table_log_entry
;
DBUG_ENTER
(
"execute_table_log_recovery"
);
no_entries
=
read_log_header
();
no_entries
=
read_
table_
log_header
();
for
(
i
=
0
;
i
<
no_entries
;
i
++
)
{
if
(
read_table_log_entry
(
i
,
&
table_log_entry
))
...
...
@@ -799,12 +814,12 @@ execute_table_log_recovery()
never end up here
*/
abort
();
DBUG_
RETURN_VOID
;
DBUG_
VOID_RETURN
;
}
}
}
VOID
(
init_table_log
());
DBUG_
RETURN_VOID
;
DBUG_
VOID_RETURN
;
}
...
...
@@ -826,17 +841,17 @@ release_table_log()
VOID
(
pthread_mutex_destroy
(
&
LOCK_gtl
));
while
(
used_list
)
{
TABLE_LOG_MEMORY_ENTRY
tmp
=
used_list
;
my_free
(
used_list
,
MYF
(
0
));
TABLE_LOG_MEMORY_ENTRY
*
tmp
=
used_list
;
my_free
(
(
char
*
)
used_list
,
MYF
(
0
));
used_list
=
tmp
->
next_log_entry
;
}
while
(
free_list
)
{
TABLE_LOG_MEMORY_ENTRY
tmp
=
free_list
;
my_free
(
free_list
,
MYF
(
0
));
TABLE_LOG_MEMORY_ENTRY
*
tmp
=
free_list
;
my_free
(
(
char
*
)
free_list
,
MYF
(
0
));
free_list
=
tmp
->
next_log_entry
;
}
DBUG_
RETURN_VOID
;
DBUG_
VOID_RETURN
;
}
...
...
@@ -854,7 +869,7 @@ lock_global_table_log()
DBUG_ENTER
(
"lock_global_table_log"
);
VOID
(
pthread_mutex_lock
(
&
LOCK_gtl
));
DBUG_
RETURN_VOID
;
DBUG_
VOID_RETURN
;
}
...
...
@@ -872,7 +887,7 @@ unlock_global_table_log()
DBUG_ENTER
(
"unlock_global_table_log"
);
VOID
(
pthread_mutex_unlock
(
&
LOCK_gtl
));
DBUG_
RETURN_VOID
;
DBUG_
VOID_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