On Wed, Apr 25, 2018 at 10:56:42AM +0100, Anatoly Burakov wrote: > We close fd if we managed to find it in the list of allocated > segment lists (which should always be the case under normal > conditions), but if we didn't, the fd was leaking. Close it if > we couldn't find it in the segment list. This is not an issue > as if the segment is zero length, we're getting rid of it > anyway, so there's no harm in not storing the fd anywhere. > > Coverity issue: 272568 >
This coverity issue indicates two resource leaks, while I think this patch only closes one of them. /Bruce > Fixes: 2a04139f66b4 ("eal: add single file segments option") > Cc: anatoly.bura...@intel.com > > Signed-off-by: Anatoly Burakov <anatoly.bura...@intel.com> > --- > lib/librte_eal/linuxapp/eal/eal_memalloc.c | 2 ++ > 1 file changed, 2 insertions(+) > > diff --git a/lib/librte_eal/linuxapp/eal/eal_memalloc.c > b/lib/librte_eal/linuxapp/eal/eal_memalloc.c > index 9156f8b..fab5a98 100644 > --- a/lib/librte_eal/linuxapp/eal/eal_memalloc.c > +++ b/lib/librte_eal/linuxapp/eal/eal_memalloc.c > @@ -569,6 +569,8 @@ free_seg(struct rte_memseg *ms, struct hugepage_info *hi, > if (te != NULL && te->fd >= 0) { > close(te->fd); > te->fd = -1; > + } else { > + close(fd); > } > unlink(path); > } > -- > 2.7.4