Commit 9b5fab58 authored by Tor Didriksen's avatar Tor Didriksen

Bug#13009341 CRASH IN STR_TO_DATETIME AFTER MISBEHAVING "BLOB" VALUE COMPARISON

The range optimizer uses 'save_in_field_no_warnings()' to verify properties of
'value <cmp> field' expressions.
If this execution yields an error, it should abort.
parent 30e2a543
/* Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved. /* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
This program is free software; you can redistribute it and/or modify This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by it under the terms of the GNU General Public License as published by
...@@ -671,6 +671,15 @@ public: ...@@ -671,6 +671,15 @@ public:
/* Number of SEL_ARG objects allocated by SEL_ARG::clone_tree operations */ /* Number of SEL_ARG objects allocated by SEL_ARG::clone_tree operations */
uint alloced_sel_args; uint alloced_sel_args;
bool statement_should_be_aborted() const
{
return
thd->is_fatal_error ||
thd->is_error() ||
alloced_sel_args > SEL_ARG::MAX_SEL_ARGS;
}
}; };
class PARAM : public RANGE_OPT_PARAM class PARAM : public RANGE_OPT_PARAM
...@@ -5541,34 +5550,35 @@ static SEL_TREE *get_mm_tree(RANGE_OPT_PARAM *param,COND *cond) ...@@ -5541,34 +5550,35 @@ static SEL_TREE *get_mm_tree(RANGE_OPT_PARAM *param,COND *cond)
if (((Item_cond*) cond)->functype() == Item_func::COND_AND_FUNC) if (((Item_cond*) cond)->functype() == Item_func::COND_AND_FUNC)
{ {
tree=0; tree= NULL;
Item *item; Item *item;
while ((item=li++)) while ((item=li++))
{ {
SEL_TREE *new_tree=get_mm_tree(param,item); SEL_TREE *new_tree= get_mm_tree(param,item);
if (param->thd->is_fatal_error || if (param->statement_should_be_aborted())
param->alloced_sel_args > SEL_ARG::MAX_SEL_ARGS) DBUG_RETURN(NULL);
DBUG_RETURN(0); // out of memory tree= tree_and(param,tree,new_tree);
tree=tree_and(param,tree,new_tree); if (tree && tree->type == SEL_TREE::IMPOSSIBLE)
if (tree && tree->type == SEL_TREE::IMPOSSIBLE) break;
break;
} }
} }
else else
{ // COND OR { // COND OR
tree=get_mm_tree(param,li++); tree= get_mm_tree(param,li++);
if (param->statement_should_be_aborted())
DBUG_RETURN(NULL);
if (tree) if (tree)
{ {
Item *item; Item *item;
while ((item=li++)) while ((item=li++))
{ {
SEL_TREE *new_tree=get_mm_tree(param,item); SEL_TREE *new_tree=get_mm_tree(param,item);
if (!new_tree) if (new_tree == NULL || param->statement_should_be_aborted())
DBUG_RETURN(0); // out of memory DBUG_RETURN(NULL);
tree=tree_or(param,tree,new_tree); tree= tree_or(param,tree,new_tree);
if (!tree || tree->type == SEL_TREE::ALWAYS) if (tree == NULL || tree->type == SEL_TREE::ALWAYS)
break; break;
} }
} }
} }
DBUG_RETURN(tree); DBUG_RETURN(tree);
......
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