diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-01-18 01:07:11 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-01-18 01:07:11 +0000 |
commit | dfbf2f58ee3f5f2481db498f006137eeb1dfdfb5 (patch) | |
tree | 732d71eebd5199f995f24614e5bd4e153e933c14 /src/libserver | |
parent | b4f959e150106634c75b4ca95e2f634f5b8946a6 (diff) | |
download | rspamd-dfbf2f58ee3f5f2481db498f006137eeb1dfdfb5.tar.gz rspamd-dfbf2f58ee3f5f2481db498f006137eeb1dfdfb5.zip |
Rework hyperscan notifies to reduce noise level
Diffstat (limited to 'src/libserver')
-rw-r--r-- | src/libserver/re_cache.c | 48 | ||||
-rw-r--r-- | src/libserver/re_cache.h | 9 | ||||
-rw-r--r-- | src/libserver/rspamd_control.c | 2 | ||||
-rw-r--r-- | src/libserver/rspamd_control.h | 4 |
4 files changed, 46 insertions, 17 deletions
diff --git a/src/libserver/re_cache.c b/src/libserver/re_cache.c index 4434576c8..e0de03184 100644 --- a/src/libserver/re_cache.c +++ b/src/libserver/re_cache.c @@ -100,6 +100,7 @@ struct rspamd_re_cache { guint max_re_data; gchar hash[rspamd_cryptobox_HASHBYTES + 1]; #ifdef WITH_HYPERSCAN + gboolean hyperscan_loaded; gboolean disable_hyperscan; hs_platform_info_t plt; #endif @@ -186,11 +187,26 @@ rspamd_re_cache_new (void) cache->re_classes = g_hash_table_new (g_int64_hash, g_int64_equal); cache->nre = 0; cache->re = g_ptr_array_new_full (256, rspamd_re_cache_elt_dtor); +#ifdef WITH_HYPERSCAN + cache->hyperscan_loaded = FALSE; +#endif REF_INIT_RETAIN (cache, rspamd_re_cache_destroy); return cache; } +gboolean +rspamd_re_cache_is_hs_loaded (struct rspamd_re_cache *cache) +{ + g_assert (cache != NULL); + +#ifdef WITH_HYPERSCAN + return cache->hyperscan_loaded; +#else + return FALSE; +#endif +} + rspamd_regexp_t * rspamd_re_cache_add (struct rspamd_re_cache *cache, rspamd_regexp_t *re, enum rspamd_re_type type, gpointer type_data, gsize datalen) @@ -1011,7 +1027,7 @@ rspamd_re_cache_is_finite (struct rspamd_re_cache *cache, gint rspamd_re_cache_compile_hyperscan (struct rspamd_re_cache *cache, - const char *cache_dir, gdouble max_time, + const char *cache_dir, gdouble max_time, gboolean silent, GError **err) { g_assert (cache != NULL); @@ -1051,24 +1067,27 @@ rspamd_re_cache_compile_hyperscan (struct rspamd_re_cache *cache, g_assert (fd != -1); lseek (fd, RSPAMD_HS_MAGIC_LEN + sizeof (cache->plt), SEEK_SET); read (fd, &n, sizeof (n)); - total += n; close (fd); if (re_class->type_len > 0) { - msg_info_re_cache ( - "skip already valid class %s(%*s) to cache %6s, %d regexps", - rspamd_re_cache_type_to_string (re_class->type), - (gint) re_class->type_len - 1, - re_class->type_data, - re_class->hash, - n); + if (!silent) { + msg_info_re_cache ( + "skip already valid class %s(%*s) to cache %6s, %d regexps", + rspamd_re_cache_type_to_string (re_class->type), + (gint) re_class->type_len - 1, + re_class->type_data, + re_class->hash, + n); + } } else { - msg_info_re_cache ( - "skip already valid class %s to cache %6s, %d regexps", - rspamd_re_cache_type_to_string (re_class->type), - re_class->hash, - n); + if (!silent) { + msg_info_re_cache ( + "skip already valid class %s to cache %6s, %d regexps", + rspamd_re_cache_type_to_string (re_class->type), + re_class->hash, + n); + } } continue; @@ -1491,6 +1510,7 @@ rspamd_re_cache_load_hyperscan (struct rspamd_re_cache *cache, } msg_info_re_cache ("hyperscan database of %d regexps has been loaded", total); + cache->hyperscan_loaded = TRUE; return TRUE; #endif diff --git a/src/libserver/re_cache.h b/src/libserver/re_cache.h index ae5cf9019..8358f146e 100644 --- a/src/libserver/re_cache.h +++ b/src/libserver/re_cache.h @@ -84,6 +84,13 @@ void rspamd_re_cache_init (struct rspamd_re_cache *cache, struct rspamd_config *cfg); /** + * Returns true when hyperscan is loaded + * @param cache + * @return + */ +gboolean rspamd_re_cache_is_hs_loaded (struct rspamd_re_cache *cache); + +/** * Get runtime data for a cache */ struct rspamd_re_runtime* rspamd_re_cache_runtime_new (struct rspamd_re_cache *cache); @@ -145,7 +152,7 @@ enum rspamd_re_type rspamd_re_cache_type_from_string (const char *str); * Compile expressions to the hyperscan tree and store in the `cache_dir` */ gint rspamd_re_cache_compile_hyperscan (struct rspamd_re_cache *cache, - const char *cache_dir, gdouble max_time, + const char *cache_dir, gdouble max_time, gboolean silent, GError **err); diff --git a/src/libserver/rspamd_control.c b/src/libserver/rspamd_control.c index 6696cd183..a91431cac 100644 --- a/src/libserver/rspamd_control.c +++ b/src/libserver/rspamd_control.c @@ -716,9 +716,9 @@ rspamd_srv_handler (gint fd, short what, gpointer ud) * workers */ wcmd.cmd.hs_loaded.cache_dir = cmd.cmd.hs_loaded.cache_dir; + wcmd.cmd.hs_loaded.forced = cmd.cmd.hs_loaded.forced; rspamd_control_broadcast_cmd (srv, &wcmd, rspamd_control_hs_io_handler, NULL); - rdata->rep.reply.hs_loaded.unused = 0; break; default: msg_err ("unknown command type: %d", cmd.type); diff --git a/src/libserver/rspamd_control.h b/src/libserver/rspamd_control.h index a15ace0d6..f8113cbb4 100644 --- a/src/libserver/rspamd_control.h +++ b/src/libserver/rspamd_control.h @@ -64,6 +64,7 @@ struct rspamd_control_command { } recompile; struct { gpointer cache_dir; + gboolean forced; } hs_loaded; struct { guint unused; @@ -112,6 +113,7 @@ struct rspamd_srv_command { } spair; struct { gpointer cache_dir; + gboolean forced; } hs_loaded; } cmd; }; @@ -124,7 +126,7 @@ struct rspamd_srv_reply { gint code; } spair; struct { - gint unused; + gint forced; } hs_loaded; } reply; }; |