diff options
author | Andrew Donnellan <andrew.donnellan@au1.ibm.com> | 2015-09-29 21:58:06 -0400 |
---|---|---|
committer | Michael Ellerman <mpe@ellerman.id.au> | 2015-09-30 21:49:32 -0400 |
commit | 52adee580d3c71a0dfabc3168597421981d68b86 (patch) | |
tree | 6473ccee43f1d3b83226df14ef00a2c3adf9910e | |
parent | 8dde152ea34860403c839598bdef3f07239eb25a (diff) |
cxl: fix leak of ctx->irq_bitmap when releasing context via kernel API
At present, ctx->irq_bitmap is freed in afu_release_irqs(), which is called
from afu_release() via cxl_context_detach().
Move the freeing of ctx->irq_bitmap from afu_release_irqs() to
reclaim_ctx() (called through cxl_context_free()) so it's freed when
releasing a context via the kernel API (cxl_release_context()) or the
userspace API (afu_release()).
Reported-by: Matthew R. Ochs <mrochs@linux.vnet.ibm.com>
Fixes: 6f7f0b3df6d4 ("cxl: Add AFU virtual PHB and kernel API")
Signed-off-by: Andrew Donnellan <andrew.donnellan@au1.ibm.com>
Acked-by: Ian Munsie <imunsie@au1.ibm.com>
Reviewed-by: Matthew R. Ochs <mrochs@linux.vnet.ibm.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
-rw-r--r-- | drivers/misc/cxl/context.c | 3 | ||||
-rw-r--r-- | drivers/misc/cxl/irq.c | 2 |
2 files changed, 3 insertions, 2 deletions
diff --git a/drivers/misc/cxl/context.c b/drivers/misc/cxl/context.c index e762f85ee233..2faa1270d085 100644 --- a/drivers/misc/cxl/context.c +++ b/drivers/misc/cxl/context.c | |||
@@ -275,6 +275,9 @@ static void reclaim_ctx(struct rcu_head *rcu) | |||
275 | if (ctx->kernelapi) | 275 | if (ctx->kernelapi) |
276 | kfree(ctx->mapping); | 276 | kfree(ctx->mapping); |
277 | 277 | ||
278 | if (ctx->irq_bitmap) | ||
279 | kfree(ctx->irq_bitmap); | ||
280 | |||
278 | kfree(ctx); | 281 | kfree(ctx); |
279 | } | 282 | } |
280 | 283 | ||
diff --git a/drivers/misc/cxl/irq.c b/drivers/misc/cxl/irq.c index 38b57d65b731..09a406058c46 100644 --- a/drivers/misc/cxl/irq.c +++ b/drivers/misc/cxl/irq.c | |||
@@ -524,7 +524,5 @@ void afu_release_irqs(struct cxl_context *ctx, void *cookie) | |||
524 | afu_irq_name_free(ctx); | 524 | afu_irq_name_free(ctx); |
525 | cxl_release_irq_ranges(&ctx->irqs, ctx->afu->adapter); | 525 | cxl_release_irq_ranges(&ctx->irqs, ctx->afu->adapter); |
526 | 526 | ||
527 | kfree(ctx->irq_bitmap); | ||
528 | ctx->irq_bitmap = NULL; | ||
529 | ctx->irq_count = 0; | 527 | ctx->irq_count = 0; |
530 | } | 528 | } |