From 006309e8d75b22efc7418095e408b3b3774ef8ea Mon Sep 17 00:00:00 2001 From: Matthew Ahrens Date: Mon, 3 Apr 2017 09:47:11 -0700 Subject: [PATCH] OpenZFS 8375 - Kernel memory leak in nvpair code Authored by: Matthew Ahrens Reviewed by: Pavel Zakharov Reviewed by: George Wilson Reviewed by: Prashanth Sreenivasa Reviewed by: Robert Mustacchi Approved by: Dan McDonald Reviewed-by: Don Brady Reviewed-by: George Melikov Reviewed-by: Brian Behlendorf Ported-by: Giuseppe Di Natale OpenZFS-issue: https://www.illumos.org/issues/8375 OpenZFS-commit: https://github.com/openzfs/openzfs/commit/843c211 Closes #6578 --- module/nvpair/nvpair.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/module/nvpair/nvpair.c b/module/nvpair/nvpair.c index 2e3820981a..8e654053cb 100644 --- a/module/nvpair/nvpair.c +++ b/module/nvpair/nvpair.c @@ -21,7 +21,7 @@ /* * Copyright (c) 2000, 2010, Oracle and/or its affiliates. All rights reserved. - * Copyright (c) 2015, 2016 by Delphix. All rights reserved. + * Copyright (c) 2015, 2017 by Delphix. All rights reserved. */ #include @@ -2200,8 +2200,10 @@ nvs_embedded(nvstream_t *nvs, nvlist_t *embedded) nvlist_init(embedded, embedded->nvl_nvflag, priv); - if (nvs->nvs_recursion >= nvpair_max_recursion) + if (nvs->nvs_recursion >= nvpair_max_recursion) { + nvlist_free(embedded); return (EINVAL); + } nvs->nvs_recursion++; if ((err = nvs_operation(nvs, embedded, NULL)) != 0) nvlist_free(embedded);