summaryrefslogtreecommitdiff
path: root/sql/sql_string.h
diff options
context:
space:
mode:
authorMonty <monty@mariadb.org>2018-04-04 12:16:12 +0300
committerMonty <monty@mariadb.org>2018-05-07 00:07:32 +0300
commit30ebc3ee9efcab635b1f3e14b9198a58ae93c233 (patch)
tree81e3ad66cd4ec8693964317cbf23515d0e9ecf35 /sql/sql_string.h
parenta22a339f8e044a1e8df011beb0b4c8f43792ac96 (diff)
downloadmariadb-git-30ebc3ee9efcab635b1f3e14b9198a58ae93c233.tar.gz
Add likely/unlikely to speed up execution
Added to: - if (error) - Lex - sql_yacc.yy and sql_yacc_ora.yy - In header files to alloc() calls - Added thd argument to thd_net_is_killed()
Diffstat (limited to 'sql/sql_string.h')
-rw-r--r--sql/sql_string.h20
1 files changed, 11 insertions, 9 deletions
diff --git a/sql/sql_string.h b/sql/sql_string.h
index e30132a427d..d110e10647a 100644
--- a/sql/sql_string.h
+++ b/sql/sql_string.h
@@ -402,9 +402,10 @@ public:
if (ALIGN_SIZE(arg_length+1) < Alloced_length)
{
char *new_ptr;
- if (!(new_ptr=(char*)
- my_realloc(Ptr, arg_length,MYF((thread_specific ?
- MY_THREAD_SPECIFIC : 0)))))
+ if (unlikely(!(new_ptr=(char*)
+ my_realloc(Ptr,
+ arg_length,MYF((thread_specific ?
+ MY_THREAD_SPECIFIC : 0))))))
{
Alloced_length = 0;
real_alloc(arg_length);
@@ -455,7 +456,7 @@ public:
CHARSET_INFO *fromcs, const char *src, size_t src_length,
size_t nchars, String_copier *copier)
{
- if (alloc(tocs->mbmaxlen * src_length))
+ if (unlikely(alloc(tocs->mbmaxlen * src_length)))
return true;
str_length= copier->well_formed_copy(tocs, Ptr, Alloced_length,
fromcs, src, (uint)src_length, (uint)nchars);
@@ -511,7 +512,7 @@ public:
}
else
{
- if (realloc_with_extra(str_length + 1))
+ if (unlikely(realloc_with_extra(str_length + 1)))
return 1;
Ptr[str_length++]=chr;
}
@@ -521,8 +522,8 @@ public:
{
for (const char *src_end= src + srclen ; src != src_end ; src++)
{
- if (append(_dig_vec_lower[((uchar) *src) >> 4]) ||
- append(_dig_vec_lower[((uchar) *src) & 0x0F]))
+ if (unlikely(append(_dig_vec_lower[((uchar) *src) >> 4])) ||
+ unlikely(append(_dig_vec_lower[((uchar) *src) & 0x0F])))
return true;
}
return false;
@@ -638,7 +639,7 @@ public:
uint32 new_length= arg_length + str_length;
if (new_length > Alloced_length)
{
- if (realloc(new_length + step_alloc))
+ if (unlikely(realloc(new_length + step_alloc)))
return 0;
}
uint32 old_length= str_length;
@@ -650,7 +651,8 @@ public:
inline bool append(const char *s, uint32 arg_length, uint32 step_alloc)
{
uint32 new_length= arg_length + str_length;
- if (new_length > Alloced_length && realloc(new_length + step_alloc))
+ if (new_length > Alloced_length &&
+ unlikely(realloc(new_length + step_alloc)))
return TRUE;
memcpy(Ptr+str_length, s, arg_length);
str_length+= arg_length;