MdeModulePkg/RegularExpressionDxe: Miss null pointer check

Oniguruma https://github.com/kkos/oniguruma
this change is merged from oniguruma develop branch.
from commit ea36d810f1d9b28f3ef20bd8d453bea2f7fb598b

Cc: Liming Gao <liming.gao@intel.com>
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Dongao Guo <dongao.guo@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
This commit is contained in:
Dongao Guo 2018-10-11 14:57:01 +08:00 committed by Liming Gao
parent 16bd7c35df
commit a5def17714
3 changed files with 39 additions and 1 deletions

View File

@ -197,7 +197,7 @@ extern int onigenc_egcb_is_break_position P_((OnigEncoding enc, UChar* p, UChar*
else if ((buk)->fold_len == 3)\ else if ((buk)->fold_len == 3)\
addr = OnigUnicodeFolds3 + (buk)->index;\ addr = OnigUnicodeFolds3 + (buk)->index;\
else\ else\
addr = 0;\ return ONIGERR_INVALID_CODE_POINT_VALUE;\
} while (0) } while (0)
extern OnigCodePoint OnigUnicodeFolds1[]; extern OnigCodePoint OnigUnicodeFolds1[];

View File

@ -966,6 +966,7 @@ name_add(regex_t* reg, UChar* name, UChar* name_end, int backref, ScanEnv* env)
#ifdef USE_ST_LIBRARY #ifdef USE_ST_LIBRARY
if (IS_NULL(t)) { if (IS_NULL(t)) {
t = onig_st_init_strend_table_with_size(INIT_NAMES_ALLOC_NUM); t = onig_st_init_strend_table_with_size(INIT_NAMES_ALLOC_NUM);
CHECK_NULL_RETURN_MEMERR(t);
reg->name_table = (void* )t; reg->name_table = (void* )t;
} }
e = (NameEntry* )xmalloc(sizeof(NameEntry)); e = (NameEntry* )xmalloc(sizeof(NameEntry));
@ -1372,6 +1373,7 @@ callout_name_entry(CalloutNameEntry** rentry, OnigEncoding enc,
#ifdef USE_ST_LIBRARY #ifdef USE_ST_LIBRARY
if (IS_NULL(t)) { if (IS_NULL(t)) {
t = onig_st_init_callout_name_table_with_size(INIT_NAMES_ALLOC_NUM); t = onig_st_init_callout_name_table_with_size(INIT_NAMES_ALLOC_NUM);
CHECK_NULL_RETURN_MEMERR(t);
GlobalCalloutNameTable = t; GlobalCalloutNameTable = t;
} }
e = (CalloutNameEntry* )xmalloc(sizeof(CalloutNameEntry)); e = (CalloutNameEntry* )xmalloc(sizeof(CalloutNameEntry));
@ -1616,6 +1618,7 @@ onig_get_callout_start_func(regex_t* reg, int callout_num)
CalloutListEntry* e; CalloutListEntry* e;
e = onig_reg_callout_list_at(reg, callout_num); e = onig_reg_callout_list_at(reg, callout_num);
CHECK_NULL_RETURN(e);
return e->start_func; return e->start_func;
} }
@ -1623,6 +1626,7 @@ extern const UChar*
onig_get_callout_tag_start(regex_t* reg, int callout_num) onig_get_callout_tag_start(regex_t* reg, int callout_num)
{ {
CalloutListEntry* e = onig_reg_callout_list_at(reg, callout_num); CalloutListEntry* e = onig_reg_callout_list_at(reg, callout_num);
CHECK_NULL_RETURN(e);
return e->tag_start; return e->tag_start;
} }
@ -1630,6 +1634,7 @@ extern const UChar*
onig_get_callout_tag_end(regex_t* reg, int callout_num) onig_get_callout_tag_end(regex_t* reg, int callout_num)
{ {
CalloutListEntry* e = onig_reg_callout_list_at(reg, callout_num); CalloutListEntry* e = onig_reg_callout_list_at(reg, callout_num);
CHECK_NULL_RETURN(e);
return e->tag_end; return e->tag_end;
} }
@ -1904,6 +1909,7 @@ callout_tag_entry(regex_t* reg, UChar* name, UChar* name_end,
r = callout_tag_entry_raw(ext->tag_table, name, name_end, entry_val); r = callout_tag_entry_raw(ext->tag_table, name, name_end, entry_val);
e = onig_reg_callout_list_at(reg, (int )entry_val); e = onig_reg_callout_list_at(reg, (int )entry_val);
CHECK_NULL_RETURN_MEMERR(e);
e->tag_start = name; e->tag_start = name;
e->tag_end = name_end; e->tag_end = name_end;
@ -2138,6 +2144,8 @@ node_new_anychar_with_fixed_option(OnigOptionType option)
Node* node; Node* node;
node = node_new_anychar(); node = node_new_anychar();
CHECK_NULL_RETURN(node);
ct = CTYPE_(node); ct = CTYPE_(node);
ct->options = option; ct->options = option;
NODE_STATUS_ADD(node, FIXED_OPTION); NODE_STATUS_ADD(node, FIXED_OPTION);
@ -3174,6 +3182,7 @@ static Node*
node_new_str_raw(UChar* s, UChar* end) node_new_str_raw(UChar* s, UChar* end)
{ {
Node* node = node_new_str(s, end); Node* node = node_new_str(s, end);
CHECK_NULL_RETURN(node);
NODE_STRING_SET_RAW(node); NODE_STRING_SET_RAW(node);
return node; return node;
} }
@ -3206,6 +3215,7 @@ str_node_split_last_char(Node* node, OnigEncoding enc)
p = onigenc_get_prev_char_head(enc, sn->s, sn->end); p = onigenc_get_prev_char_head(enc, sn->s, sn->end);
if (p && p > sn->s) { /* can be split. */ if (p && p > sn->s) { /* can be split. */
rn = node_new_str(p, sn->end); rn = node_new_str(p, sn->end);
CHECK_NULL_RETURN(rn);
if (NODE_STRING_IS_RAW(node)) if (NODE_STRING_IS_RAW(node))
NODE_STRING_SET_RAW(rn); NODE_STRING_SET_RAW(rn);
@ -6626,6 +6636,11 @@ parse_callout_of_contents(Node** np, int cterm, UChar** src, UChar* end, ScanEnv
} }
e = onig_reg_callout_list_at(env->reg, num); e = onig_reg_callout_list_at(env->reg, num);
if (IS_NULL(e)) {
xfree(contents);
return ONIGERR_MEMORY;
}
e->of = ONIG_CALLOUT_OF_CONTENTS; e->of = ONIG_CALLOUT_OF_CONTENTS;
e->in = in; e->in = in;
e->name_id = ONIG_NON_NAME_ID; e->name_id = ONIG_NON_NAME_ID;
@ -6935,6 +6950,8 @@ parse_callout_of_name(Node** np, int cterm, UChar** src, UChar* end, ScanEnv* en
if (r != ONIG_NORMAL) return r; if (r != ONIG_NORMAL) return r;
e = onig_reg_callout_list_at(env->reg, num); e = onig_reg_callout_list_at(env->reg, num);
CHECK_NULL_RETURN_MEMERR(e);
e->of = ONIG_CALLOUT_OF_NAME; e->of = ONIG_CALLOUT_OF_NAME;
e->in = in; e->in = in;
e->name_id = name_id; e->name_id = name_id;
@ -8098,6 +8115,11 @@ parse_branch(Node** top, OnigToken* tok, int term, UChar** src, UChar* end,
} }
else { else {
*top = node_new_list(node, NULL); *top = node_new_list(node, NULL);
if (IS_NULL(*top)) {
onig_node_free(node);
return ONIGERR_MEMORY;
}
headp = &(NODE_CDR(*top)); headp = &(NODE_CDR(*top));
while (r != TK_EOT && r != term && r != TK_ALT) { while (r != TK_EOT && r != term && r != TK_ALT) {
r = parse_exp(&node, tok, term, src, end, env); r = parse_exp(&node, tok, term, src, end, env);
@ -8133,6 +8155,7 @@ parse_subexp(Node** top, OnigToken* tok, int term, UChar** src, UChar* end,
env->parse_depth++; env->parse_depth++;
if (env->parse_depth > ParseDepthLimit) if (env->parse_depth > ParseDepthLimit)
return ONIGERR_PARSE_DEPTH_LIMIT_OVER; return ONIGERR_PARSE_DEPTH_LIMIT_OVER;
r = parse_branch(&node, tok, term, src, end, env); r = parse_branch(&node, tok, term, src, end, env);
if (r < 0) { if (r < 0) {
onig_node_free(node); onig_node_free(node);
@ -8144,6 +8167,11 @@ parse_subexp(Node** top, OnigToken* tok, int term, UChar** src, UChar* end,
} }
else if (r == TK_ALT) { else if (r == TK_ALT) {
*top = onig_node_new_alt(node, NULL); *top = onig_node_new_alt(node, NULL);
if (IS_NULL(*top)) {
onig_node_free(node);
return ONIGERR_MEMORY;
}
headp = &(NODE_CDR(*top)); headp = &(NODE_CDR(*top));
while (r == TK_ALT) { while (r == TK_ALT) {
r = fetch_token(tok, src, end, env); r = fetch_token(tok, src, end, env);
@ -8154,6 +8182,12 @@ parse_subexp(Node** top, OnigToken* tok, int term, UChar** src, UChar* end,
return r; return r;
} }
*headp = onig_node_new_alt(node, NULL); *headp = onig_node_new_alt(node, NULL);
if (IS_NULL(*headp)) {
onig_node_free(node);
onig_node_free(*top);
return ONIGERR_MEMORY;
}
headp = &(NODE_CDR(*headp)); headp = &(NODE_CDR(*headp));
} }

View File

@ -758,6 +758,10 @@ onig_unicode_define_user_property(const char* name, OnigCodePoint* ranges)
if (UserDefinedPropertyTable == 0) { if (UserDefinedPropertyTable == 0) {
UserDefinedPropertyTable = onig_st_init_strend_table_with_size(10); UserDefinedPropertyTable = onig_st_init_strend_table_with_size(10);
if (IS_NULL(UserDefinedPropertyTable)) {
xfree(s);
return ONIGERR_MEMORY;
}
} }
e = UserDefinedPropertyRanges + UserDefinedPropertyNum; e = UserDefinedPropertyRanges + UserDefinedPropertyNum;