summaryrefslogtreecommitdiff
path: root/storage/perfschema/pfs.cc
diff options
context:
space:
mode:
authorSergei Golubchik <serg@mariadb.org>2015-12-13 17:19:18 +0100
committerSergei Golubchik <serg@mariadb.org>2015-12-13 17:19:18 +0100
commitb418e978260777b88b7291db98682559212cb632 (patch)
tree07008bce5d661cc93dbeae3e322cca149cd4c02e /storage/perfschema/pfs.cc
parent095b7b92d1d8ddf07d91a4f5917b9c052e403c68 (diff)
parent6bb292f1bc6781639533fbe0c681b1d86bb7ef3e (diff)
downloadmariadb-git-b418e978260777b88b7291db98682559212cb632.tar.gz
Merge branch 'merge/merge-perfschema-5.6' into 10.0
Diffstat (limited to 'storage/perfschema/pfs.cc')
-rw-r--r--storage/perfschema/pfs.cc9
1 files changed, 9 insertions, 0 deletions
diff --git a/storage/perfschema/pfs.cc b/storage/perfschema/pfs.cc
index 58d766f480a..dd61df5f861 100644
--- a/storage/perfschema/pfs.cc
+++ b/storage/perfschema/pfs.cc
@@ -4388,6 +4388,8 @@ get_thread_statement_locker_v1(PSI_statement_locker_state *state,
const void *charset)
{
DBUG_ASSERT(state != NULL);
+ DBUG_ASSERT(charset != NULL);
+
if (! flag_global_instrumentation)
return NULL;
PFS_statement_class *klass= find_statement_class(key);
@@ -4432,6 +4434,8 @@ get_thread_statement_locker_v1(PSI_statement_locker_state *state,
pfs->m_lock_time= 0;
pfs->m_current_schema_name_length= 0;
pfs->m_sqltext_length= 0;
+ pfs->m_sqltext_truncated= false;
+ pfs->m_sqltext_cs_number= system_charset_info->number; /* default */
pfs->m_message_text[0]= '\0';
pfs->m_sql_errno= 0;
@@ -4511,6 +4515,7 @@ get_thread_statement_locker_v1(PSI_statement_locker_state *state,
state->m_digest= NULL;
state->m_schema_name_length= 0;
+ state->m_cs_number= ((CHARSET_INFO *)charset)->number;
return reinterpret_cast<PSI_statement_locker*> (state);
}
@@ -4616,10 +4621,14 @@ static void set_statement_text_v1(PSI_statement_locker *locker,
PFS_events_statements *pfs= reinterpret_cast<PFS_events_statements*> (state->m_statement);
DBUG_ASSERT(pfs != NULL);
if (text_len > sizeof (pfs->m_sqltext))
+ {
text_len= sizeof(pfs->m_sqltext);
+ pfs->m_sqltext_truncated= true;
+ }
if (text_len)
memcpy(pfs->m_sqltext, text, text_len);
pfs->m_sqltext_length= text_len;
+ pfs->m_sqltext_cs_number= state->m_cs_number;
}
return;