Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755034AbbLGHon (ORCPT ); Mon, 7 Dec 2015 02:44:43 -0500 Received: from mailout4.w1.samsung.com ([210.118.77.14]:61630 "EHLO mailout4.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754205AbbLGHok (ORCPT ); Mon, 7 Dec 2015 02:44:40 -0500 X-AuditID: cbfec7f4-f79026d00000418a-53-566538e53c9e Subject: Re: [PATCH] drivers: dma-coherent: simplify dma_init_coherent_memory return value To: Michal Nazarewicz , Greg Kroah-Hartman References: <1449260058-3572-1-git-send-email-mina86@mina86.com> Cc: linux-kernel@vger.kernel.org, torvalds@linux-foundation.org, linux-arm-kernel@lists.infradead.org, arnd@arndb.de, iamjoonsoo.kim@lge.com From: Marek Szyprowski Message-id: <566538E4.30209@samsung.com> Date: Mon, 07 Dec 2015 08:44:36 +0100 User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:38.0) Gecko/20100101 Thunderbird/38.4.0 MIME-version: 1.0 In-reply-to: <1449260058-3572-1-git-send-email-mina86@mina86.com> Content-type: text/plain; charset=utf-8; format=flowed Content-transfer-encoding: 7bit X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFnrMLMWRmVeSWpSXmKPExsVy+t/xK7pPLVLDDD6f17D4O+kYu0Xz4vVs Fiu7m9ksNj2+xmpxedccNosFx1tYLR71vWV3YPf4/WsSo0fX2ytMHidm/Gbx2D93DbvH5iX1 Huv+vGLy+LxJLoA9issmJTUnsyy1SN8ugSvjxcznjAU3JSqunnrA2MC4VbiLkZNDQsBEYtPi c2wQtpjEhXvrgWwuDiGBpYwSjVtPMEI4zxklfu9ZxtTFyMEhLBAjsetxKYgpAmT2n/YBMYUE HCTW7mIGqWYW6GOU+DlxMjvITDYBQ4mut11g83kFNCTatl8Ds1kEVCWaJh1jBrFFgcY8XryV FaJGUOLH5HssIDangKPE0re7wWqYBcwkvrw8zAphy0tsXvOWeQKjwCwkLbOQlM1CUraAkXkV o2hqaXJBcVJ6rqFecWJucWleul5yfu4mRkjQf9nBuPiY1SFGAQ5GJR5ei/SUMCHWxLLiytxD jBIczEoivMJxQCHelMTKqtSi/Pii0pzU4kOM0hwsSuK8c3e9DxESSE8sSc1OTS1ILYLJMnFw SjUwprc/Zl8c0bFM+DKLZbvmroX94p89jqy/aeN26XLYlP6lSrIPkty3e+3OtgqeH/P1zkSu euv87XN6xKveHrurqJjVIRMgFSidpXzR3S48p3H+uSe/5ZPD/2Wu9K/+fs52o+P6v0sX9N0K /az+aaWoqOPFVxWTlnBnHTJfp26n+u+M+xvPaU98lViKMxINtZiLihMBtzUWGnYCAAA= Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3314 Lines: 97 Hello, On 2015-12-04 21:14, Michal Nazarewicz wrote: > Since only dma_declare_coherent_memory cares about > dma_init_coherent_memory returning part of flags as it return value, > move the condition to the former and simplify the latter. This in > turn makes rmem_dma_device_init less confusing. > > Reported-by: Fugang Duan > Signed-off-by: Michal Nazarewicz Acked-by: Marek Szyprowski > --- > drivers/base/dma-coherent.c | 28 +++++++++++----------------- > 1 file changed, 11 insertions(+), 17 deletions(-) > > diff --git a/drivers/base/dma-coherent.c b/drivers/base/dma-coherent.c > index 55b8398..87b8083 100644 > --- a/drivers/base/dma-coherent.c > +++ b/drivers/base/dma-coherent.c > @@ -17,9 +17,9 @@ struct dma_coherent_mem { > spinlock_t spinlock; > }; > > -static int dma_init_coherent_memory(phys_addr_t phys_addr, dma_addr_t device_addr, > - size_t size, int flags, > - struct dma_coherent_mem **mem) > +static bool dma_init_coherent_memory( > + phys_addr_t phys_addr, dma_addr_t device_addr, size_t size, int flags, > + struct dma_coherent_mem **mem) > { > struct dma_coherent_mem *dma_mem = NULL; > void __iomem *mem_base = NULL; > @@ -50,17 +50,13 @@ static int dma_init_coherent_memory(phys_addr_t phys_addr, dma_addr_t device_add > spin_lock_init(&dma_mem->spinlock); > > *mem = dma_mem; > - > - if (flags & DMA_MEMORY_MAP) > - return DMA_MEMORY_MAP; > - > - return DMA_MEMORY_IO; > + return true; > > out: > kfree(dma_mem); > if (mem_base) > iounmap(mem_base); > - return 0; > + return false; > } > > static void dma_release_coherent_memory(struct dma_coherent_mem *mem) > @@ -88,15 +84,13 @@ int dma_declare_coherent_memory(struct device *dev, phys_addr_t phys_addr, > dma_addr_t device_addr, size_t size, int flags) > { > struct dma_coherent_mem *mem; > - int ret; > > - ret = dma_init_coherent_memory(phys_addr, device_addr, size, flags, > - &mem); > - if (ret == 0) > + if (!dma_init_coherent_memory(phys_addr, device_addr, size, flags, > + &mem)) > return 0; > > if (dma_assign_coherent_memory(dev, mem) == 0) > - return ret; > + return flags & DMA_MEMORY_MAP ? DMA_MEMORY_MAP : DMA_MEMORY_IO; > > dma_release_coherent_memory(mem); > return 0; > @@ -281,9 +275,9 @@ static int rmem_dma_device_init(struct reserved_mem *rmem, struct device *dev) > struct dma_coherent_mem *mem = rmem->priv; > > if (!mem && > - dma_init_coherent_memory(rmem->base, rmem->base, rmem->size, > - DMA_MEMORY_MAP | DMA_MEMORY_EXCLUSIVE, > - &mem) != DMA_MEMORY_MAP) { > + !dma_init_coherent_memory(rmem->base, rmem->base, rmem->size, > + DMA_MEMORY_MAP | DMA_MEMORY_EXCLUSIVE, > + &mem)) { > pr_err("Reserved memory: failed to init DMA memory pool at %pa, size %ld MiB\n", > &rmem->base, (unsigned long)rmem->size / SZ_1M); > return -ENODEV; Best regards -- Marek Szyprowski, PhD Samsung R&D Institute Poland -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/