Commit d853042b authored by Michael Widenius's avatar Michael Widenius

Added missing write_unlock() in case of errors

parent 15419a55
...@@ -459,8 +459,11 @@ int SEQUENCE::read_initial_values(TABLE *table) ...@@ -459,8 +459,11 @@ int SEQUENCE::read_initial_values(TABLE *table)
mdl_requests.push_front(&mdl_request); mdl_requests.push_front(&mdl_request);
if (thd->mdl_context.acquire_locks(&mdl_requests, if (thd->mdl_context.acquire_locks(&mdl_requests,
thd->variables.lock_wait_timeout)) thd->variables.lock_wait_timeout))
{
write_unlock(table);
DBUG_RETURN(HA_ERR_LOCK_WAIT_TIMEOUT); DBUG_RETURN(HA_ERR_LOCK_WAIT_TIMEOUT);
} }
}
save_lock_type= table->reginfo.lock_type; save_lock_type= table->reginfo.lock_type;
table->reginfo.lock_type= TL_READ; table->reginfo.lock_type= TL_READ;
if (!(lock= mysql_lock_tables(thd, &table, 1, if (!(lock= mysql_lock_tables(thd, &table, 1,
...@@ -468,6 +471,7 @@ int SEQUENCE::read_initial_values(TABLE *table) ...@@ -468,6 +471,7 @@ int SEQUENCE::read_initial_values(TABLE *table)
{ {
if (mdl_lock_used) if (mdl_lock_used)
thd->mdl_context.release_lock(mdl_request.ticket); thd->mdl_context.release_lock(mdl_request.ticket);
write_unlock(table);
DBUG_RETURN(HA_ERR_LOCK_WAIT_TIMEOUT); DBUG_RETURN(HA_ERR_LOCK_WAIT_TIMEOUT);
} }
DBUG_ASSERT(table->reginfo.lock_type == TL_READ); DBUG_ASSERT(table->reginfo.lock_type == TL_READ);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment