diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-06-10 09:33:48 -0400 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-06-10 09:34:04 -0400 |
commit | c6b144054597604e4991874f1bbf9953d691a8da (patch) | |
tree | 4f5e82e0c4853df3c3ea675254d5d354ffd8b8ec /src | |
parent | 2d4741851a2329e1cb317e5b6df0e9487c6a5305 (diff) | |
download | rspamd-c6b144054597604e4991874f1bbf9953d691a8da.tar.gz rspamd-c6b144054597604e4991874f1bbf9953d691a8da.zip |
Implement watching for async symbols.
Diffstat (limited to 'src')
-rw-r--r-- | src/libserver/symbols_cache.c | 20 | ||||
-rw-r--r-- | src/libserver/task.c | 5 |
2 files changed, 23 insertions, 2 deletions
diff --git a/src/libserver/symbols_cache.c b/src/libserver/symbols_cache.c index 40a54ad06..b74f2c7d7 100644 --- a/src/libserver/symbols_cache.c +++ b/src/libserver/symbols_cache.c @@ -850,6 +850,19 @@ rspamd_symbols_cache_metric_limit (struct rspamd_task *task, return FALSE; } +static void +rspamd_symbols_cache_watcher_cb (gpointer sessiond, gpointer ud) +{ + struct rspamd_task *task = sessiond; + struct cache_item *item = ud; + struct cache_savepoint *checkpoint; + + checkpoint = task->checkpoint; + + /* Specify that we are done with this item */ + setbit (checkpoint->processed_bits, item->id * 2 + 1); +} + static gboolean rspamd_symbols_cache_check_symbol (struct rspamd_task *task, struct symbols_cache *cache, @@ -867,6 +880,9 @@ rspamd_symbols_cache_check_symbol (struct rspamd_task *task, setbit (checkpoint->processed_bits, item->id * 2); t1 = rspamd_get_ticks (); pending_before = rspamd_session_events_pending (task->s); + /* Watch for events appeared */ + rspamd_session_watch_start (task->s, rspamd_symbols_cache_watcher_cb, + item); if (item->symbol != NULL && G_UNLIKELY (check_debug_symbol (task->cfg, item->symbol))) { @@ -879,10 +895,10 @@ rspamd_symbols_cache_check_symbol (struct rspamd_task *task, } t2 = rspamd_get_ticks (); - pending_after = rspamd_session_events_pending (task->s); - diff = (t2 - t1) * 1000000; rspamd_set_counter (item, diff); + rspamd_session_watch_stop (task->s); + pending_after = rspamd_session_events_pending (task->s); if (pending_before == pending_after) { /* No new events registered */ diff --git a/src/libserver/task.c b/src/libserver/task.c index e063f0f5b..1638a46f3 100644 --- a/src/libserver/task.c +++ b/src/libserver/task.c @@ -135,6 +135,11 @@ rspamd_task_fin (void *arg) return TRUE; } + if (RSPAMD_TASK_IS_PROCESSED (task)) { + rspamd_task_reply (task); + return TRUE; + } + /* One more iteration */ return FALSE; } |