From: Klement Sekera Date: Fri, 19 Nov 2021 10:49:48 +0000 (+0100) Subject: snort: fix coverity warning X-Git-Tag: v22.06-rc0~205 X-Git-Url: https://gerrit.fd.io/r/gitweb?a=commitdiff_plain;h=c2810b32cde694a8e245a4f10aa5ce839ad866c7;p=vpp.git snort: fix coverity warning Add error handling for incomplete read. Type: fix Fixes: 839b1473e9 Signed-off-by: Klement Sekera Change-Id: Ibf1b2f633793510244ea1aa6af0902021aeb67ad --- diff --git a/src/plugins/snort/main.c b/src/plugins/snort/main.c index d05b6310891..6b7e49a23ad 100644 --- a/src/plugins/snort/main.c +++ b/src/plugins/snort/main.c @@ -195,9 +195,18 @@ snort_deq_ready (clib_file_t *uf) snort_per_thread_data_t *ptd = vec_elt_at_index (sm->per_thread_data, vm->thread_index); u64 counter; + ssize_t bytes_read; - if (read (uf->file_descriptor, &counter, sizeof (counter)) < 0) - return clib_error_return (0, "client closed socket"); + bytes_read = read (uf->file_descriptor, &counter, sizeof (counter)); + if (bytes_read < 0) + { + return clib_error_return (0, "client closed socket"); + } + + if (bytes_read < sizeof (counter)) + { + return clib_error_return (0, "unexpected truncated read"); + } clib_interrupt_set (ptd->interrupts, uf->private_data); vlib_node_set_interrupt_pending (vm, snort_deq_node.index);