From: Philippe Antoine Date: Thu, 9 Dec 2021 14:06:24 +0000 (+0100) Subject: fuzz: use parsed rules in sigpcap target X-Git-Tag: suricata-7.0.0-beta1~1022 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=add1a0f561f648493ccca33cceb4dd32140d01ff;p=thirdparty%2Fsuricata.git fuzz: use parsed rules in sigpcap target Ticket: 4125 As commit d21a252238fd766d3c2ec4c2d165d429dad0d85a But for sigpcap target as well --- diff --git a/src/tests/fuzz/fuzz_sigpcap.c b/src/tests/fuzz/fuzz_sigpcap.c index d177c7c09d..37066b6834 100644 --- a/src/tests/fuzz/fuzz_sigpcap.c +++ b/src/tests/fuzz/fuzz_sigpcap.c @@ -122,6 +122,15 @@ int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) if (DetectEngineReload(&surifuzz) < 0) { return 0; } + DetectEngineThreadCtx *old_det_ctx = FlowWorkerGetDetectCtxPtr(fwd); + + DetectEngineCtx *de_ctx = DetectEngineGetCurrent(); + de_ctx->ref_cnt--; + DetectEngineThreadCtx *new_det_ctx = DetectEngineThreadCtxInitForReload(&tv, de_ctx, 1); + FlowWorkerReplaceDetectCtx(fwd, new_det_ctx); + + DetectEngineThreadCtxDeinit(NULL, old_det_ctx); + if (pos < size) { //skip zero pos++;