diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-02-23 17:47:33 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-02-23 17:47:33 +0000 |
commit | 42dde66aa6a2e3ef225af67676d0d728e8e9cdc4 (patch) | |
tree | 977f2eb88b070376d7da3da251c320af261d0121 | |
parent | ceafdab3aedfd9069d1d45bac6d247f620382e74 (diff) | |
download | rspamd-42dde66aa6a2e3ef225af67676d0d728e8e9cdc4.tar.gz rspamd-42dde66aa6a2e3ef225af67676d0d728e8e9cdc4.zip |
Fix pcre jit fast path (one more time)
-rw-r--r-- | src/libutil/regexp.c | 33 | ||||
-rw-r--r-- | src/libutil/regexp.h | 1 |
2 files changed, 25 insertions, 9 deletions
diff --git a/src/libutil/regexp.c b/src/libutil/regexp.c index 4cc012567..02f734d66 100644 --- a/src/libutil/regexp.c +++ b/src/libutil/regexp.c @@ -181,6 +181,7 @@ rspamd_regexp_post_process (rspamd_regexp_t *r) } if (pcre2_jit_compile (r->re, jit_flags) < 0) { msg_err ("jit compilation of %s is not supported", r->pattern); + r->flags |= RSPAMD_REGEXP_FLAG_DISABLE_JIT; } if (pcre2_pattern_info (r->re, PCRE2_INFO_JITSIZE, &jsz) >= 0 && jsz > 0) { @@ -188,9 +189,10 @@ rspamd_regexp_post_process (rspamd_regexp_t *r) } else { msg_err ("jit compilation of %s is not supported", r->pattern); + r->flags |= RSPAMD_REGEXP_FLAG_DISABLE_JIT; } - if (r->jstack) { + if (r->jstack && !(r->flags & RSPAMD_REGEXP_FLAG_DISABLE_JIT)) { pcre2_jit_stack_assign (r->mcontext, NULL, r->jstack); } @@ -199,16 +201,18 @@ rspamd_regexp_post_process (rspamd_regexp_t *r) if (pcre2_jit_compile (r->raw_re, jit_flags) < 0) { msg_debug ("jit compilation of %s is not supported", r->pattern); + r->flags |= RSPAMD_REGEXP_FLAG_DISABLE_JIT; } if (pcre2_pattern_info (r->raw_re, PCRE2_INFO_JITSIZE, &jsz) >= 0 && jsz > 0) { r->raw_jstack = pcre2_jit_stack_create (32 * 1024, 512 * 1024, NULL); + r->flags |= RSPAMD_REGEXP_FLAG_DISABLE_JIT; } else { msg_debug ("jit compilation of raw %s is not supported", r->pattern); } - if (r->raw_jstack) { + if (r->raw_jstack && !(r->flags & RSPAMD_REGEXP_FLAG_DISABLE_JIT)) { pcre2_jit_stack_assign (r->raw_mcontext, NULL, r->raw_jstack); } } @@ -234,6 +238,7 @@ rspamd_regexp_post_process (rspamd_regexp_t *r) msg_warn ("cannot optimize regexp pattern: '%s': %s", r->pattern, err_str); try_jit = FALSE; + r->flags |= RSPAMD_REGEXP_FLAG_DISABLE_JIT; } if (r->raw_re && r->raw_re != r->re) { @@ -262,6 +267,7 @@ rspamd_regexp_post_process (rspamd_regexp_t *r) if (n != 0 || jit != 1) { msg_debug ("jit compilation of %s is not supported", r->pattern); r->jstack = NULL; + r->flags |= RSPAMD_REGEXP_FLAG_DISABLE_JIT; } else { r->jstack = pcre_jit_stack_alloc (32 * 1024, 512 * 1024); @@ -273,6 +279,7 @@ rspamd_regexp_post_process (rspamd_regexp_t *r) else { msg_warn ("cannot optimize regexp pattern: '%s': %s", r->pattern, err_str); + r->flags |= RSPAMD_REGEXP_FLAG_DISABLE_JIT; } if (try_raw_jit) { @@ -292,6 +299,7 @@ rspamd_regexp_post_process (rspamd_regexp_t *r) if (n != 0 || jit != 1) { msg_debug ("jit compilation of %s is not supported", r->pattern); r->raw_jstack = NULL; + r->flags |= RSPAMD_REGEXP_FLAG_DISABLE_JIT; } else { r->raw_jstack = pcre_jit_stack_alloc (32 * 1024, 512 * 1024); @@ -593,7 +601,7 @@ rspamd_regexp_search (rspamd_regexp_t *re, const gchar *text, gsize len, g_assert (remain > 0); g_assert (mt != NULL); - if (st != NULL) { + if (st != NULL && !(re->flags & RSPAMD_REGEXP_FLAG_DISABLE_JIT)) { rc = pcre_jit_exec (r, ext, mt, remain, 0, 0, ovec, ncaptures, st); } @@ -700,17 +708,24 @@ rspamd_regexp_search (rspamd_regexp_t *re, const gchar *text, gsize len, mcontext = re->mcontext; match_flags |= PCRE_FLAG(UTF); - if (!g_utf8_validate (mt, remain, NULL)) { - msg_err ("bad utf8 input for JIT re"); - return FALSE; - } } match_data = pcre2_match_data_create (re->ncaptures + 1, NULL); #ifdef HAVE_PCRE_JIT - rc = pcre2_jit_match (r, mt, remain, 0, match_flags, match_data, - mcontext); + if (!(re->flags & RSPAMD_REGEXP_FLAG_DISABLE_JIT)) { + if (!g_utf8_validate (mt, remain, NULL)) { + msg_err ("bad utf8 input for JIT re"); + return FALSE; + } + + rc = pcre2_jit_match (r, mt, remain, 0, match_flags, match_data, + mcontext); + } + else { + rc = pcre2_match (r, mt, remain, 0, match_flags, match_data, + mcontext); + } #else rc = pcre2_match (r, mt, remain, 0, match_flags, match_data, mcontext); diff --git a/src/libutil/regexp.h b/src/libutil/regexp.h index 72ac6eec7..d130dea2b 100644 --- a/src/libutil/regexp.h +++ b/src/libutil/regexp.h @@ -32,6 +32,7 @@ #define RSPAMD_REGEXP_FLAG_NOOPT (1 << 2) #define RSPAMD_REGEXP_FLAG_FULL_MATCH (1 << 3) #define RSPAMD_REGEXP_FLAG_PCRE_ONLY (1 << 4) +#define RSPAMD_REGEXP_FLAG_DISABLE_JIT (1 << 5) typedef struct rspamd_regexp_s rspamd_regexp_t; struct rspamd_regexp_cache; |