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
f5bd8340
Commit
f5bd8340
authored
Dec 01, 2012
by
Mattias Jonsson
Browse files
Options
Browse Files
Download
Plain Diff
merge of bug#14589559 into mysql-5.1
parents
e7e9fa59
fbe1315b
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
124 additions
and
100 deletions
+124
-100
sql/sql_table.cc
sql/sql_table.cc
+124
-100
No files found.
sql/sql_table.cc
View file @
f5bd8340
...
...
@@ -617,13 +617,6 @@ uint build_tmptable_filename(THD* thd, char *buff, size_t bufflen)
struct
st_global_ddl_log
{
/*
We need to adjust buffer size to be able to handle downgrades/upgrades
where IO_SIZE has changed. We'll set the buffer size such that we can
handle that the buffer size was upto 4 times bigger in the version
that wrote the DDL log.
*/
char
file_entry_buf
[
4
*
IO_SIZE
];
char
file_name_str
[
FN_REFLEN
];
char
*
file_name
;
DDL_LOG_MEMORY_ENTRY
*
first_free
;
...
...
@@ -651,51 +644,60 @@ pthread_mutex_t LOCK_gdl;
#define DDL_LOG_NUM_ENTRY_POS 0
#define DDL_LOG_NAME_LEN_POS 4
#define DDL_LOG_IO_SIZE_POS 8
#define DDL_LOG_HEADER_SIZE 12
/*
Read one entry from ddl log file
SYNOPSIS
read_ddl_log_file_entry()
entry_no Entry number to read
RETURN VALUES
TRUE Error
FALSE Success
/**
Read one entry from ddl log file.
@param[out] file_entry_buf Buffer to read into
@param entry_no Entry number to read
@param size Number of bytes of the entry to read
@return Operation status
@retval true Error
@retval false Success
*/
static
bool
read_ddl_log_file_entry
(
uint
entry_no
)
static
bool
read_ddl_log_file_entry
(
uchar
*
file_entry_buf
,
uint
entry_no
,
uint
size
)
{
bool
error
=
FALSE
;
File
file_id
=
global_ddl_log
.
file_id
;
uchar
*
file_entry_buf
=
(
uchar
*
)
global_ddl_log
.
file_entry_buf
;
uint
io_size
=
global_ddl_log
.
io_size
;
DBUG_ENTER
(
"read_ddl_log_file_entry"
);
DBUG_ASSERT
(
io_size
>=
size
);
if
(
my_pread
(
file_id
,
file_entry_buf
,
io_
size
,
io_size
*
entry_no
,
MYF
(
MY_WME
))
!=
io_
size
)
if
(
my_pread
(
file_id
,
file_entry_buf
,
size
,
io_size
*
entry_no
,
MYF
(
MY_WME
))
!=
size
)
error
=
TRUE
;
DBUG_RETURN
(
error
);
}
/*
Write one entry from ddl log file
SYNOPSIS
write_ddl_log_file_entry()
entry_no Entry number to write
RETURN VALUES
TRUE Error
FALSE Success
/**
Write one entry to ddl log file.
@param file_entry_buf Buffer to write
@param entry_no Entry number to write
@param size Number of bytes of the entry to write
@return Operation status
@retval true Error
@retval false Success
*/
static
bool
write_ddl_log_file_entry
(
uint
entry_no
)
static
bool
write_ddl_log_file_entry
(
uchar
*
file_entry_buf
,
uint
entry_no
,
uint
size
)
{
bool
error
=
FALSE
;
File
file_id
=
global_ddl_log
.
file_id
;
char
*
file_entry_buf
=
(
char
*
)
global_ddl_log
.
file_entry_buf
;
uint
io_size
=
global_ddl_log
.
io_size
;
DBUG_ENTER
(
"write_ddl_log_file_entry"
);
DBUG_ASSERT
(
io_size
>=
size
);
if
(
my_pwrite
(
file_id
,
(
uchar
*
)
file_entry_buf
,
IO_SIZE
,
IO_SIZE
*
entry_no
,
MYF
(
MY_WME
))
!=
IO_SIZE
)
if
(
my_pwrite
(
file_id
,
file_entry_buf
,
size
,
io_size
*
entry_no
,
MYF
(
MY_WME
))
!=
size
)
error
=
TRUE
;
DBUG_RETURN
(
error
);
}
...
...
@@ -714,17 +716,20 @@ static bool write_ddl_log_header()
{
uint16
const_var
;
bool
error
=
FALSE
;
uchar
file_entry_buf
[
DDL_LOG_HEADER_SIZE
];
DBUG_ENTER
(
"write_ddl_log_header"
);
DBUG_ASSERT
((
DDL_LOG_NAME_POS
+
3
*
global_ddl_log
.
name_len
)
<=
global_ddl_log
.
io_size
);
int4store
(
&
global_ddl_log
.
file_entry_buf
[
DDL_LOG_NUM_ENTRY_POS
],
int4store
(
&
file_entry_buf
[
DDL_LOG_NUM_ENTRY_POS
],
global_ddl_log
.
num_entries
);
const_var
=
FN_LEN
;
int4store
(
&
global_ddl_log
.
file_entry_buf
[
DDL_LOG_NAME_LEN_POS
],
const_var
=
global_ddl_log
.
name_len
;
int4store
(
&
file_entry_buf
[
DDL_LOG_NAME_LEN_POS
],
(
ulong
)
const_var
);
const_var
=
IO_SIZE
;
int4store
(
&
global_ddl_log
.
file_entry_buf
[
DDL_LOG_IO_SIZE_POS
],
const_var
=
global_ddl_log
.
io_size
;
int4store
(
&
file_entry_buf
[
DDL_LOG_IO_SIZE_POS
],
(
ulong
)
const_var
);
if
(
write_ddl_log_file_entry
(
0UL
))
if
(
write_ddl_log_file_entry
(
file_entry_buf
,
0UL
,
DDL_LOG_HEADER_SIZE
))
{
sql_print_error
(
"Error writing ddl log header"
);
DBUG_RETURN
(
TRUE
);
...
...
@@ -764,17 +769,19 @@ static inline void create_ddl_log_file_name(char *file_name)
static
uint
read_ddl_log_header
()
{
char
*
file_entry_buf
=
(
char
*
)
global_ddl_log
.
file_entry_buf
;
char
file_entry_buf
[
DDL_LOG_HEADER_SIZE
]
;
char
file_name
[
FN_REFLEN
];
uint
entry_no
;
bool
successful_open
=
FALSE
;
DBUG_ENTER
(
"read_ddl_log_header"
);
DBUG_ASSERT
(
global_ddl_log
.
io_size
<=
IO_SIZE
);
create_ddl_log_file_name
(
file_name
);
if
((
global_ddl_log
.
file_id
=
my_open
(
file_name
,
O_RDWR
|
O_BINARY
,
MYF
(
0
)))
>=
0
)
{
if
(
read_ddl_log_file_entry
(
0UL
))
if
(
read_ddl_log_file_entry
((
uchar
*
)
file_entry_buf
,
0UL
,
DDL_LOG_HEADER_SIZE
))
{
/* Write message into error log */
sql_print_error
(
"Failed to read ddl log file in recovery"
);
...
...
@@ -787,8 +794,6 @@ static uint read_ddl_log_header()
entry_no
=
uint4korr
(
&
file_entry_buf
[
DDL_LOG_NUM_ENTRY_POS
]);
global_ddl_log
.
name_len
=
uint4korr
(
&
file_entry_buf
[
DDL_LOG_NAME_LEN_POS
]);
global_ddl_log
.
io_size
=
uint4korr
(
&
file_entry_buf
[
DDL_LOG_IO_SIZE_POS
]);
DBUG_ASSERT
(
global_ddl_log
.
io_size
<=
sizeof
(
global_ddl_log
.
file_entry_buf
));
}
else
{
...
...
@@ -803,30 +808,22 @@ static uint read_ddl_log_header()
}
/*
Read a ddl log entry
SYNOPSIS
read_ddl_log_entry()
read_entry Number of entry to read
out:entry_info Information from entry
RETURN VALUES
TRUE Error
FALSE Success
DESCRIPTION
Read a specified entry in the ddl log
/**
Set ddl log entry struct from buffer
@param read_entry Entry number
@param file_entry_buf Buffer to use
@param ddl_log_entry Entry to be set
@note Pointers in ddl_log_entry will point into file_entry_buf!
*/
bool
read_ddl_log_entry
(
uint
read_entry
,
DDL_LOG_ENTRY
*
ddl_log_entry
)
static
void
set_ddl_log_entry_from_buf
(
uint
read_entry
,
uchar
*
file_entry_buf
,
DDL_LOG_ENTRY
*
ddl_log_entry
)
{
char
*
file_entry_buf
=
(
char
*
)
&
global_ddl_log
.
file_entry_buf
;
uint
inx
;
uchar
single_char
;
DBUG_ENTER
(
"read_ddl_log_entry"
);
if
(
read_ddl_log_file_entry
(
read_entry
))
{
DBUG_RETURN
(
TRUE
);
}
DBUG_ENTER
(
"set_ddl_log_entry_from_buf"
);
ddl_log_entry
->
entry_pos
=
read_entry
;
single_char
=
file_entry_buf
[
DDL_LOG_ENTRY_TYPE_POS
];
ddl_log_entry
->
entry_type
=
(
enum
ddl_log_entry_code
)
single_char
;
...
...
@@ -834,14 +831,14 @@ bool read_ddl_log_entry(uint read_entry, DDL_LOG_ENTRY *ddl_log_entry)
ddl_log_entry
->
action_type
=
(
enum
ddl_log_action_code
)
single_char
;
ddl_log_entry
->
phase
=
file_entry_buf
[
DDL_LOG_PHASE_POS
];
ddl_log_entry
->
next_entry
=
uint4korr
(
&
file_entry_buf
[
DDL_LOG_NEXT_ENTRY_POS
]);
ddl_log_entry
->
name
=
&
file_entry_buf
[
DDL_LOG_NAME_POS
];
ddl_log_entry
->
name
=
(
char
*
)
&
file_entry_buf
[
DDL_LOG_NAME_POS
];
inx
=
DDL_LOG_NAME_POS
+
global_ddl_log
.
name_len
;
ddl_log_entry
->
from_name
=
&
file_entry_buf
[
inx
];
ddl_log_entry
->
from_name
=
(
char
*
)
&
file_entry_buf
[
inx
];
inx
+=
global_ddl_log
.
name_len
;
ddl_log_entry
->
handler_name
=
&
file_entry_buf
[
inx
];
DBUG_
RETURN
(
FALSE
)
;
ddl_log_entry
->
handler_name
=
(
char
*
)
&
file_entry_buf
[
inx
];
DBUG_
VOID_RETURN
;
}
/*
Initialise ddl log
...
...
@@ -1044,6 +1041,7 @@ static bool get_free_ddl_log_entry(DDL_LOG_MEMORY_ENTRY **active_entry,
DDL_LOG_MEMORY_ENTRY
*
first_used
=
global_ddl_log
.
first_used
;
DBUG_ENTER
(
"get_free_ddl_log_entry"
);
safe_mutex_assert_owner
(
&
LOCK_gdl
);
if
(
global_ddl_log
.
first_free
==
NULL
)
{
if
(
!
(
used_entry
=
(
DDL_LOG_MEMORY_ENTRY
*
)
my_malloc
(
...
...
@@ -1100,34 +1098,35 @@ bool write_ddl_log_entry(DDL_LOG_ENTRY *ddl_log_entry,
DDL_LOG_MEMORY_ENTRY
**
active_entry
)
{
bool
error
,
write_header
;
char
file_entry_buf
[
IO_SIZE
];
DBUG_ENTER
(
"write_ddl_log_entry"
);
if
(
init_ddl_log
())
{
DBUG_RETURN
(
TRUE
);
}
global_ddl_log
.
file_entry_buf
[
DDL_LOG_ENTRY_TYPE_POS
]
=
file_entry_buf
[
DDL_LOG_ENTRY_TYPE_POS
]
=
(
char
)
DDL_LOG_ENTRY_CODE
;
global_ddl_log
.
file_entry_buf
[
DDL_LOG_ACTION_TYPE_POS
]
=
file_entry_buf
[
DDL_LOG_ACTION_TYPE_POS
]
=
(
char
)
ddl_log_entry
->
action_type
;
global_ddl_log
.
file_entry_buf
[
DDL_LOG_PHASE_POS
]
=
0
;
int4store
(
&
global_ddl_log
.
file_entry_buf
[
DDL_LOG_NEXT_ENTRY_POS
],
file_entry_buf
[
DDL_LOG_PHASE_POS
]
=
0
;
int4store
(
&
file_entry_buf
[
DDL_LOG_NEXT_ENTRY_POS
],
ddl_log_entry
->
next_entry
);
DBUG_ASSERT
(
strlen
(
ddl_log_entry
->
name
)
<
FN_LEN
);
strmake
(
&
global_ddl_log
.
file_entry_buf
[
DDL_LOG_NAME_POS
]
,
ddl_log_entry
->
name
,
FN_LEN
-
1
);
DBUG_ASSERT
(
strlen
(
ddl_log_entry
->
name
)
<
global_ddl_log
.
name_len
);
strmake
(
&
file_entry_buf
[
DDL_LOG_NAME_POS
],
ddl_log_entry
->
name
,
global_ddl_log
.
name_len
-
1
);
if
(
ddl_log_entry
->
action_type
==
DDL_LOG_RENAME_ACTION
||
ddl_log_entry
->
action_type
==
DDL_LOG_REPLACE_ACTION
)
{
DBUG_ASSERT
(
strlen
(
ddl_log_entry
->
from_name
)
<
FN_LEN
);
strmake
(
&
global_ddl_log
.
file_entry_buf
[
DDL_LOG_NAME_POS
+
FN_LEN
],
ddl_log_entry
->
from_name
,
FN_LEN
-
1
);
DBUG_ASSERT
(
strlen
(
ddl_log_entry
->
from_name
)
<
global_ddl_log
.
name_len
);
strmake
(
&
file_entry_buf
[
DDL_LOG_NAME_POS
+
global_ddl_log
.
name_len
],
ddl_log_entry
->
from_name
,
global_ddl_log
.
name_len
-
1
);
}
else
global_ddl_log
.
file_entry_buf
[
DDL_LOG_NAME_POS
+
FN_LEN
]
=
0
;
DBUG_ASSERT
(
strlen
(
ddl_log_entry
->
handler_name
)
<
FN_LEN
);
strmake
(
&
global_ddl_log
.
file_entry_buf
[
DDL_LOG_NAME_POS
+
(
2
*
FN_LEN
)],
ddl_log_entry
->
handler_name
,
FN_LEN
-
1
);
file_entry_buf
[
DDL_LOG_NAME_POS
+
global_ddl_log
.
name_len
]
=
0
;
DBUG_ASSERT
(
strlen
(
ddl_log_entry
->
handler_name
)
<
global_ddl_log
.
name_len
);
strmake
(
&
file_entry_buf
[
DDL_LOG_NAME_POS
+
(
2
*
global_ddl_log
.
name_len
)],
ddl_log_entry
->
handler_name
,
global_ddl_log
.
name_len
-
1
);
if
(
get_free_ddl_log_entry
(
active_entry
,
&
write_header
))
{
DBUG_RETURN
(
TRUE
);
...
...
@@ -1135,14 +1134,15 @@ bool write_ddl_log_entry(DDL_LOG_ENTRY *ddl_log_entry,
error
=
FALSE
;
DBUG_PRINT
(
"ddl_log"
,
(
"write type %c next %u name '%s' from_name '%s' handler '%s'"
,
(
char
)
global_ddl_log
.
file_entry_buf
[
DDL_LOG_ACTION_TYPE_POS
],
(
char
)
file_entry_buf
[
DDL_LOG_ACTION_TYPE_POS
],
ddl_log_entry
->
next_entry
,
(
char
*
)
&
global_ddl_log
.
file_entry_buf
[
DDL_LOG_NAME_POS
],
(
char
*
)
&
global_ddl_log
.
file_entry_buf
[
DDL_LOG_NAME_POS
+
FN_LEN
],
(
char
*
)
&
global_ddl_log
.
file_entry_buf
[
DDL_LOG_NAME_POS
+
(
2
*
FN_LEN
)]));
if
(
write_ddl_log_file_entry
((
*
active_entry
)
->
entry_pos
))
(
char
*
)
&
file_entry_buf
[
DDL_LOG_NAME_POS
],
(
char
*
)
&
file_entry_buf
[
DDL_LOG_NAME_POS
+
global_ddl_log
.
name_len
],
(
char
*
)
&
file_entry_buf
[
DDL_LOG_NAME_POS
+
(
2
*
global_ddl_log
.
name_len
)]));
if
(
write_ddl_log_file_entry
((
uchar
*
)
file_entry_buf
,
(
*
active_entry
)
->
entry_pos
,
IO_SIZE
))
{
error
=
TRUE
;
sql_print_error
(
"Failed to write entry_no = %u"
,
...
...
@@ -1192,7 +1192,7 @@ bool write_execute_ddl_log_entry(uint first_entry,
DDL_LOG_MEMORY_ENTRY
**
active_entry
)
{
bool
write_header
=
FALSE
;
char
*
file_entry_buf
=
(
char
*
)
global_ddl_log
.
file_entry_buf
;
char
file_entry_buf
[
IO_SIZE
]
;
DBUG_ENTER
(
"write_execute_ddl_log_entry"
);
if
(
init_ddl_log
())
...
...
@@ -1216,8 +1216,8 @@ bool write_execute_ddl_log_entry(uint first_entry,
file_entry_buf
[
DDL_LOG_PHASE_POS
]
=
0
;
int4store
(
&
file_entry_buf
[
DDL_LOG_NEXT_ENTRY_POS
],
first_entry
);
file_entry_buf
[
DDL_LOG_NAME_POS
]
=
0
;
file_entry_buf
[
DDL_LOG_NAME_POS
+
FN_LEN
]
=
0
;
file_entry_buf
[
DDL_LOG_NAME_POS
+
2
*
FN_LEN
]
=
0
;
file_entry_buf
[
DDL_LOG_NAME_POS
+
global_ddl_log
.
name_len
]
=
0
;
file_entry_buf
[
DDL_LOG_NAME_POS
+
2
*
global_ddl_log
.
name_len
]
=
0
;
if
(
!
(
*
active_entry
))
{
if
(
get_free_ddl_log_entry
(
active_entry
,
&
write_header
))
...
...
@@ -1225,7 +1225,9 @@ bool write_execute_ddl_log_entry(uint first_entry,
DBUG_RETURN
(
TRUE
);
}
}
if
(
write_ddl_log_file_entry
((
*
active_entry
)
->
entry_pos
))
if
(
write_ddl_log_file_entry
((
uchar
*
)
file_entry_buf
,
(
*
active_entry
)
->
entry_pos
,
IO_SIZE
))
{
sql_print_error
(
"Error writing execute entry in ddl log"
);
release_ddl_log_memory_entry
(
*
active_entry
);
...
...
@@ -1270,10 +1272,16 @@ bool write_execute_ddl_log_entry(uint first_entry,
bool
deactivate_ddl_log_entry
(
uint
entry_no
)
{
char
*
file_entry_buf
=
(
char
*
)
global_ddl_log
.
file_entry_buf
;
uchar
file_entry_buf
[
DDL_LOG_NAME_POS
]
;
DBUG_ENTER
(
"deactivate_ddl_log_entry"
);
if
(
!
read_ddl_log_file_entry
(
entry_no
))
/*
Only need to read and write the first bytes of the entry, where
ENTRY_TYPE, ACTION_TYPE and PHASE reside. Using DDL_LOG_NAME_POS
to include all info except for the names.
*/
if
(
!
read_ddl_log_file_entry
(
file_entry_buf
,
entry_no
,
DDL_LOG_NAME_POS
))
{
if
(
file_entry_buf
[
DDL_LOG_ENTRY_TYPE_POS
]
==
DDL_LOG_ENTRY_CODE
)
{
...
...
@@ -1291,7 +1299,7 @@ bool deactivate_ddl_log_entry(uint entry_no)
{
DBUG_ASSERT
(
0
);
}
if
(
write_ddl_log_file_entry
(
entry_no
))
if
(
write_ddl_log_file_entry
(
file_entry_buf
,
entry_no
,
DDL_LOG_NAME_POS
))
{
sql_print_error
(
"Error in deactivating log entry. Position = %u"
,
entry_no
);
...
...
@@ -1352,6 +1360,7 @@ void release_ddl_log_memory_entry(DDL_LOG_MEMORY_ENTRY *log_entry)
DDL_LOG_MEMORY_ENTRY
*
next_log_entry
=
log_entry
->
next_log_entry
;
DDL_LOG_MEMORY_ENTRY
*
prev_log_entry
=
log_entry
->
prev_log_entry
;
DBUG_ENTER
(
"release_ddl_log_memory_entry"
);
safe_mutex_assert_owner
(
&
LOCK_gdl
);
global_ddl_log
.
first_free
=
log_entry
;
log_entry
->
next_log_entry
=
first_free
;
...
...
@@ -1381,24 +1390,26 @@ bool execute_ddl_log_entry(THD *thd, uint first_entry)
{
DDL_LOG_ENTRY
ddl_log_entry
;
uint
read_entry
=
first_entry
;
uchar
file_entry_buf
[
IO_SIZE
];
DBUG_ENTER
(
"execute_ddl_log_entry"
);
pthread_mutex_lock
(
&
LOCK_gdl
);
do
{
if
(
read_ddl_log_
entry
(
read_entry
,
&
ddl_log_entry
))
if
(
read_ddl_log_
file_entry
(
file_entry_buf
,
read_entry
,
IO_SIZE
))
{
/*
Write to error
log and continue with next log entry */
/*
Print the error to the
log and continue with next log entry */
sql_print_error
(
"Failed to read entry = %u from ddl log"
,
read_entry
);
break
;
}
set_ddl_log_entry_from_buf
(
read_entry
,
file_entry_buf
,
&
ddl_log_entry
);
DBUG_ASSERT
(
ddl_log_entry
.
entry_type
==
DDL_LOG_ENTRY_CODE
||
ddl_log_entry
.
entry_type
==
DDL_IGNORE_LOG_ENTRY_CODE
);
if
(
execute_ddl_log_action
(
thd
,
&
ddl_log_entry
))
{
/*
Write to error
log and continue with next log entry */
/*
Print the error to the
log and continue with next log entry */
sql_print_error
(
"Failed to execute action for entry = %u from ddl log"
,
read_entry
);
break
;
...
...
@@ -1443,13 +1454,14 @@ void execute_ddl_log_recovery()
uint
num_entries
,
i
;
THD
*
thd
;
DDL_LOG_ENTRY
ddl_log_entry
;
uchar
*
file_entry_buf
;
uint
io_size
;
char
file_name
[
FN_REFLEN
];
DBUG_ENTER
(
"execute_ddl_log_recovery"
);
/*
Initialise global_ddl_log struct
*/
bzero
(
global_ddl_log
.
file_entry_buf
,
sizeof
(
global_ddl_log
.
file_entry_buf
));
global_ddl_log
.
inited
=
FALSE
;
global_ddl_log
.
recovery_phase
=
TRUE
;
global_ddl_log
.
io_size
=
IO_SIZE
;
...
...
@@ -1464,14 +1476,23 @@ void execute_ddl_log_recovery()
thd
->
store_globals
();
num_entries
=
read_ddl_log_header
();
io_size
=
global_ddl_log
.
io_size
;
file_entry_buf
=
(
uchar
*
)
my_malloc
(
io_size
,
MYF
(
0
));
if
(
!
file_entry_buf
)
{
sql_print_error
(
"Failed to allocate buffer for recover ddl log"
);
DBUG_VOID_RETURN
;
}
for
(
i
=
1
;
i
<
num_entries
+
1
;
i
++
)
{
if
(
read_ddl_log_
entry
(
i
,
&
ddl_log_entry
))
if
(
read_ddl_log_
file_entry
(
file_entry_buf
,
i
,
io_size
))
{
sql_print_error
(
"Failed to read entry no = %u from ddl log"
,
i
);
continue
;
}
set_ddl_log_entry_from_buf
(
i
,
file_entry_buf
,
&
ddl_log_entry
);
if
(
ddl_log_entry
.
entry_type
==
DDL_LOG_EXECUTE_CODE
)
{
if
(
execute_ddl_log_entry
(
thd
,
ddl_log_entry
.
next_entry
))
...
...
@@ -1486,6 +1507,7 @@ void execute_ddl_log_recovery()
VOID
(
my_delete
(
file_name
,
MYF
(
0
)));
global_ddl_log
.
recovery_phase
=
FALSE
;
delete
thd
;
my_free
(
file_entry_buf
,
MYF
(
0
));
/* Remember that we don't have a THD */
my_pthread_setspecific_ptr
(
THR_THD
,
0
);
DBUG_VOID_RETURN
;
...
...
@@ -1502,14 +1524,16 @@ void execute_ddl_log_recovery()
void
release_ddl_log
()
{
DDL_LOG_MEMORY_ENTRY
*
free_list
=
global_ddl_log
.
first_free
;
DDL_LOG_MEMORY_ENTRY
*
used_list
=
global_ddl_log
.
first_used
;
DDL_LOG_MEMORY_ENTRY
*
free_list
;
DDL_LOG_MEMORY_ENTRY
*
used_list
;
DBUG_ENTER
(
"release_ddl_log"
);
if
(
!
global_ddl_log
.
do_release
)
DBUG_VOID_RETURN
;
pthread_mutex_lock
(
&
LOCK_gdl
);
free_list
=
global_ddl_log
.
first_free
;
used_list
=
global_ddl_log
.
first_used
;
while
(
used_list
)
{
DDL_LOG_MEMORY_ENTRY
*
tmp
=
used_list
->
next_log_entry
;
...
...
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