Commit 967bd206 authored by Dmitry Lenev's avatar Dmitry Lenev

Improve concurrency in metadata locking subsystem by

moving calculation of hash value when looking up
MDL_lock objects in MDL_map out of critical section.
parent 4d0f0c78
...@@ -384,12 +384,16 @@ void MDL_map::destroy() ...@@ -384,12 +384,16 @@ void MDL_map::destroy()
MDL_lock* MDL_map::find_or_insert(const MDL_key *mdl_key) MDL_lock* MDL_map::find_or_insert(const MDL_key *mdl_key)
{ {
MDL_lock *lock; MDL_lock *lock;
my_hash_value_type hash_value;
hash_value= my_calc_hash(&m_locks, mdl_key->ptr(), mdl_key->length());
retry: retry:
pthread_mutex_lock(&m_mutex); pthread_mutex_lock(&m_mutex);
if (!(lock= (MDL_lock*) my_hash_search(&m_locks, if (!(lock= (MDL_lock*) my_hash_search_using_hash_value(&m_locks,
mdl_key->ptr(), hash_value,
mdl_key->length()))) mdl_key->ptr(),
mdl_key->length())))
{ {
lock= MDL_lock::create(mdl_key); lock= MDL_lock::create(mdl_key);
if (!lock || my_hash_insert(&m_locks, (uchar*)lock)) if (!lock || my_hash_insert(&m_locks, (uchar*)lock))
...@@ -418,12 +422,16 @@ retry: ...@@ -418,12 +422,16 @@ retry:
MDL_lock* MDL_map::find(const MDL_key *mdl_key) MDL_lock* MDL_map::find(const MDL_key *mdl_key)
{ {
MDL_lock *lock; MDL_lock *lock;
my_hash_value_type hash_value;
hash_value= my_calc_hash(&m_locks, mdl_key->ptr(), mdl_key->length());
retry: retry:
pthread_mutex_lock(&m_mutex); pthread_mutex_lock(&m_mutex);
if (!(lock= (MDL_lock*) my_hash_search(&m_locks, if (!(lock= (MDL_lock*) my_hash_search_using_hash_value(&m_locks,
mdl_key->ptr(), hash_value,
mdl_key->length()))) mdl_key->ptr(),
mdl_key->length())))
{ {
pthread_mutex_unlock(&m_mutex); pthread_mutex_unlock(&m_mutex);
return NULL; return NULL;
......
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