From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S965079AbbFJVAQ (ORCPT ); Wed, 10 Jun 2015 17:00:16 -0400 Received: from mail-qk0-f182.google.com ([209.85.220.182]:34887 "EHLO mail-qk0-f182.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S964960AbbFJVAO (ORCPT ); Wed, 10 Jun 2015 17:00:14 -0400 MIME-Version: 1.0 In-Reply-To: <1433851493-23685-5-git-send-email-sergey.senozhatsky@gmail.com> References: <1433851493-23685-1-git-send-email-sergey.senozhatsky@gmail.com> <1433851493-23685-5-git-send-email-sergey.senozhatsky@gmail.com> From: Dan Streetman Date: Wed, 10 Jun 2015 16:59:53 -0400 X-Google-Sender-Auth: y317Wa6pYv43tVuNHoZFYDG02DU Message-ID: Subject: Re: [RFC][PATCH 4/5] mm/zpool: allow NULL `zpool' pointer in zpool_destroy_pool() To: Sergey Senozhatsky Cc: Andrew Morton , Minchan Kim , Christoph Lameter , Pekka Enberg , Joonsoo Kim , Michal Hocko , David Rientjes , Linux-MM , linux-kernel , Sergey Senozhatsky Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Jun 9, 2015 at 8:04 AM, Sergey Senozhatsky wrote: > zpool_destroy_pool() does not tolerate a NULL zpool pointer > argument and performs a NULL-pointer dereference. Although > there is only one zpool_destroy_pool() user (as of 4.1), > still update it to be coherent with the corresponding > destroy() functions of the remainig pool-allocators (slab, > mempool, etc.), which now allow NULL pool-pointers. > > For consistency, tweak zpool_destroy_pool() and NULL-check the > pointer there. > > Proposed by Andrew Morton. > > Signed-off-by: Sergey Senozhatsky > Reported-by: Andrew Morton > LKML-reference: https://lkml.org/lkml/2015/6/8/583 Acked-by: Dan Streetman > --- > mm/zpool.c | 3 +++ > 1 file changed, 3 insertions(+) > > diff --git a/mm/zpool.c b/mm/zpool.c > index bacdab6..2f59b90 100644 > --- a/mm/zpool.c > +++ b/mm/zpool.c > @@ -202,6 +202,9 @@ struct zpool *zpool_create_pool(char *type, char *name, gfp_t gfp, > */ > void zpool_destroy_pool(struct zpool *zpool) > { > + if (unlikely(!zpool)) > + return; > + > pr_info("destroying pool type %s\n", zpool->type); > > spin_lock(&pools_lock); > -- > 2.4.3.368.g7974889 > > -- > To unsubscribe, send a message with 'unsubscribe linux-mm' in > the body to majordomo@kvack.org. For more info on Linux MM, > see: http://www.linux-mm.org/ . > Don't email: email@kvack.org