]> git.droids-corp.org - dpdk.git/commitdiff
contigmem: cleanup properly when load fails
authorJim Harris <james.r.harris@intel.com>
Mon, 9 Mar 2020 10:00:25 +0000 (03:00 -0700)
committerDavid Marchand <david.marchand@redhat.com>
Thu, 19 Mar 2020 14:42:00 +0000 (15:42 +0100)
If contigmem is not able to allocate all of the
requested buffers, it frees whatever buffers were
able to be allocated up until that point.

But the pointers are not set to NULL in that case.
After the load fails, the FreeBSD kernel will
immediately call the contigmem unload handler, which
tries to free the buffers again since the pointers
were not set to NULL.

It's not clear that we should just rely on the unload
handler getting called after load failure. So let's
keep the existing cleanup code in the load handler,
but explicitly set the pointers to NULL after freeing
them.

Fixes: 5f51eca22489 ("contigmem: free allocated memory on error")
Cc: stable@dpdk.org
Signed-off-by: Jim Harris <james.r.harris@intel.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
kernel/freebsd/contigmem/contigmem.c

index 7ea0bc61774621b5e39f10b851d82777420b5269..bd72f4d62015662cf0f4d27f7924fb58f3abfbfa 100644 (file)
@@ -165,9 +165,11 @@ contigmem_load()
 
 error:
        for (i = 0; i < contigmem_num_buffers; i++) {
-               if (contigmem_buffers[i].addr != NULL)
+               if (contigmem_buffers[i].addr != NULL) {
                        contigfree(contigmem_buffers[i].addr,
                                contigmem_buffer_size, M_CONTIGMEM);
+                       contigmem_buffers[i].addr = NULL;
+               }
                if (mtx_initialized(&contigmem_buffers[i].mtx))
                        mtx_destroy(&contigmem_buffers[i].mtx);
        }