Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp1729133pxk; Fri, 4 Sep 2020 18:19:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw5HSx6z+nB5sVs5XIs8fEEhk0DOxTZqNpLJKkYF+wUtYRJcdyFKofHJjR9cHDP2oKKMQgn X-Received: by 2002:a05:6402:615:: with SMTP id n21mr10926890edv.59.1599268779082; Fri, 04 Sep 2020 18:19:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1599268779; cv=none; d=google.com; s=arc-20160816; b=wQ+e+1cWBEwYnbnN5Z2UXzFEraznWkU5wjEJZSD9x7BVUkyx8Kje6NaHyjPGB+TQTU Q/4bQrXOcaLsTdln7d9fTIAt5GwR2raPBynXvdOU7nWjTYKvMt+XmEzYoQ96Ysj36AcH QqcWr7aDYNamKlM+LMJlbE8lW+oe+HP/Ypqn5vzSNvP0yudy+lAC3bQ8mvWeWsv6kH1C Kjfd1TwKaFqpWccPc1CqvThSuKaonTRAYkUJ88SodoYQ+OiBmmEdo3FGCe0M43h1o5bk lgjFijZcayzUmAAkZ3G5XylB+u8oXBoo2FV1bHKDSqOf+stzPNxl4XDBBxmmhj9Y33/C gZWg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=2TwEP2bwMgCZ9+c0ywDi8aPPqSNthraxohoKZ3dokMo=; b=hXHepCMFqdZ9ROFnteF6voFuZc9XcRVkB8wkM1S/tQzaYmSTPJK6ZV7Wt3N05/xKoU SgOJpcr9aAOSikRv9gdoWlhlLyVZsNj+ty4TDZfGUTV4LwoGrJ0uEG+hDJG3i2xvcseH P7XnqLfyMe2WJY0pdQX5p/2gbEVoT34zZERJOd/pDParst8qBDf4JjiOUaJ29ApRIaRW /p6ldRtdN2KgRejx4zaMR/0mvQzSp0K6E+EGtWmMfTHtroK1hyxBFlLcoW+yzkkmUzCJ CRekkdlIo4OR/o33qL6GWkV98ecbVKQ9yLq1SH4dtjqYawgkTMTHesP899X6S2Oai+u1 BkIQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=aNPORyb3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s2si5252073ejs.269.2020.09.04.18.19.16; Fri, 04 Sep 2020 18:19:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=aNPORyb3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726406AbgIEBQj (ORCPT + 99 others); Fri, 4 Sep 2020 21:16:39 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46996 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726208AbgIEBQj (ORCPT ); Fri, 4 Sep 2020 21:16:39 -0400 Received: from mail-lj1-x242.google.com (mail-lj1-x242.google.com [IPv6:2a00:1450:4864:20::242]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8FD08C061244 for ; Fri, 4 Sep 2020 18:16:38 -0700 (PDT) Received: by mail-lj1-x242.google.com with SMTP id t23so10029682ljc.3 for ; Fri, 04 Sep 2020 18:16:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=2TwEP2bwMgCZ9+c0ywDi8aPPqSNthraxohoKZ3dokMo=; b=aNPORyb3s9zdHHQPHQGEQDspHeU5Y9EhJb7wcXo98GqGH++TEklqyYX7pSP07YCh0Q AcpP3vImA+41+ln1T3pjaJs5mtX+o0c2KLaPD1g18iZoWgfUBk2brxUpvRkY0dACxgMP ZBvZGRLv6EByHNO+y2x/f85wGzZIQ/VcO7S0jtP+XTRLqh9ZXRuajTAQ29YYqU0e01qR FQRc5wzlXVHXpswbvzQqxeg2sIwzhxTnAUdokZXKt2e8evCZnT7taIebRM9/BwIrIY1V FzYvOUDqfpxZjxQdCBSKE5sPMznhhWzfIHrnbwkWVhtjhjhEAlXm15oRrtpx+sUiqMs+ sX6Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=2TwEP2bwMgCZ9+c0ywDi8aPPqSNthraxohoKZ3dokMo=; b=WOnIAcyu5sK65XMJjThenp3ZKflO53UFq6RzEXvG/M6NGVythA6ZIALv76XDIxqZOC +lbVnPdU/uGaZJBk2/vlmNCCD0cRJaC2IpmLhww3obQO44DsUmm1k4CNu4OjZ3aotJ6D o17Siafqni/gajJNqieIJCjH9CKc5FvSAxZy+IVX/GG8fG/XEIp3HHdSrNjY0tI/NojY ivFgphscgdAl2muw2X1Di5NntPhG2Uxrhls7OfeHyQRKpoXsUXspIDK4iWbkhsR6eNjW xFlnNlK72jjY3i1ztrGILyeCoYQGwnCZ8HBGz0Xpv63UoXjNgYQFMUQuZpZSUvISYCk8 6QHQ== X-Gm-Message-State: AOAM533FjceIM+DHZVI2yS03LSJG/k32Kkm3PnKgrX8bWGUwDbskoQyR tqqlGgHmpnGHhCL+/hUbUwoOp5xXAgp4tcr7itk= X-Received: by 2002:a05:651c:2c9:: with SMTP id f9mr4903765ljo.257.1599268596661; Fri, 04 Sep 2020 18:16:36 -0700 (PDT) MIME-Version: 1.0 References: <1598995271-6755-1-git-send-email-jrdr.linux@gmail.com> In-Reply-To: From: Souptick Joarder Date: Sat, 5 Sep 2020 06:46:24 +0530 Message-ID: Subject: Re: [linux-next PATCH v4] drivers/virt/fsl_hypervisor: Fix error handling path To: Andrew Morton Cc: Jason Gunthorpe , Dan Williams , Greg KH , timur@freescale.com, linux-kernel@vger.kernel.org, Dan Carpenter , John Hubbard Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Andrew, On Wed, Sep 2, 2020 at 3:00 AM John Hubbard wrote: > > On 9/1/20 2:21 PM, Souptick Joarder wrote: > > First, when memory allocation for sg_list_unaligned failed, there > > is a bug of calling put_pages() as we haven't pinned any pages. > > > > Second, if get_user_pages_fast() failed we should unpin num_pinned > > pages. > > > > This will address both. > > > > As part of these changes, minor update in documentation. > > > > Fixes: 6db7199407ca ("drivers/virt: introduce Freescale hypervisor > > management driver") > > Signed-off-by: Souptick Joarder > > Reviewed-by: Dan Carpenter > > Reviewed-by: John Hubbard > > --- > > This looks good to me. Can you please take this patch through the mm tree ? > > thanks, > -- > John Hubbard > NVIDIA > > > v2: > > Added review tag. > > > > v3: > > Address review comment on v2 from John. > > Added review tag. > > > > v4: > > Address another set of review comments from John. > > > > drivers/virt/fsl_hypervisor.c | 17 ++++++++--------- > > 1 file changed, 8 insertions(+), 9 deletions(-) > > > > diff --git a/drivers/virt/fsl_hypervisor.c b/drivers/virt/fsl_hypervisor.c > > index 1b0b11b..46ee0a0 100644 > > --- a/drivers/virt/fsl_hypervisor.c > > +++ b/drivers/virt/fsl_hypervisor.c > > @@ -157,7 +157,7 @@ static long ioctl_memcpy(struct fsl_hv_ioctl_memcpy __user *p) > > > > unsigned int i; > > long ret = 0; > > - int num_pinned; /* return value from get_user_pages() */ > > + int num_pinned = 0; /* return value from get_user_pages_fast() */ > > phys_addr_t remote_paddr; /* The next address in the remote buffer */ > > uint32_t count; /* The number of bytes left to copy */ > > > > @@ -174,7 +174,7 @@ static long ioctl_memcpy(struct fsl_hv_ioctl_memcpy __user *p) > > return -EINVAL; > > > > /* > > - * The array of pages returned by get_user_pages() covers only > > + * The array of pages returned by get_user_pages_fast() covers only > > * page-aligned memory. Since the user buffer is probably not > > * page-aligned, we need to handle the discrepancy. > > * > > @@ -224,7 +224,7 @@ static long ioctl_memcpy(struct fsl_hv_ioctl_memcpy __user *p) > > > > /* > > * 'pages' is an array of struct page pointers that's initialized by > > - * get_user_pages(). > > + * get_user_pages_fast(). > > */ > > pages = kcalloc(num_pages, sizeof(struct page *), GFP_KERNEL); > > if (!pages) { > > @@ -241,7 +241,7 @@ static long ioctl_memcpy(struct fsl_hv_ioctl_memcpy __user *p) > > if (!sg_list_unaligned) { > > pr_debug("fsl-hv: could not allocate S/G list\n"); > > ret = -ENOMEM; > > - goto exit; > > + goto free_pages; > > } > > sg_list = PTR_ALIGN(sg_list_unaligned, sizeof(struct fh_sg_list)); > > > > @@ -250,7 +250,6 @@ static long ioctl_memcpy(struct fsl_hv_ioctl_memcpy __user *p) > > num_pages, param.source != -1 ? FOLL_WRITE : 0, pages); > > > > if (num_pinned != num_pages) { > > - /* get_user_pages() failed */ > > pr_debug("fsl-hv: could not lock source buffer\n"); > > ret = (num_pinned < 0) ? num_pinned : -EFAULT; > > goto exit; > > @@ -292,13 +291,13 @@ static long ioctl_memcpy(struct fsl_hv_ioctl_memcpy __user *p) > > virt_to_phys(sg_list), num_pages); > > > > exit: > > - if (pages) { > > - for (i = 0; i < num_pages; i++) > > - if (pages[i]) > > - put_page(pages[i]); > > + if (pages && (num_pinned > 0)) { > > + for (i = 0; i < num_pinned; i++) > > + put_page(pages[i]); > > } > > > > kfree(sg_list_unaligned); > > +free_pages: > > kfree(pages); > > > > if (!ret) > > >