Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755052Ab2BUVaP (ORCPT ); Tue, 21 Feb 2012 16:30:15 -0500 Received: from filtteri1.pp.htv.fi ([213.243.153.184]:39089 "EHLO filtteri1.pp.htv.fi" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752693Ab2BUVaO (ORCPT ); Tue, 21 Feb 2012 16:30:14 -0500 Date: Tue, 21 Feb 2012 21:30:07 +0000 (UTC) From: Aaro Koskinen X-X-Sender: aaro@localhost To: Marek Szyprowski cc: linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-media@vger.kernel.org, linux-mm@kvack.org, linaro-mm-sig@lists.linaro.org, Michal Nazarewicz , Kyungmin Park , Russell King , Andrew Morton , KAMEZAWA Hiroyuki , Daniel Walker , Mel Gorman , Arnd Bergmann , Jesse Barker , Jonathan Corbet , Shariq Hasnain , Chunsang Jeong , Dave Hansen , Benjamin Gaignard , Rob Clark , Ohad Ben-Cohen Subject: Re: [PATCHv22 13/16] drivers: add Contiguous Memory Allocator In-Reply-To: <1329507036-24362-14-git-send-email-m.szyprowski@samsung.com> Message-ID: References: <1329507036-24362-1-git-send-email-m.szyprowski@samsung.com> <1329507036-24362-14-git-send-email-m.szyprowski@samsung.com> User-Agent: Alpine 2.00 (DEB 1167 2008-08-23) MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII; format=flowed Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1383 Lines: 47 Hi, On Fri, 17 Feb 2012, Marek Szyprowski wrote: > +/** > + * dma_release_from_contiguous() - release allocated pages > + * @dev: Pointer to device for which the pages were allocated. > + * @pages: Allocated pages. > + * @count: Number of allocated pages. > + * > + * This function releases memory allocated by dma_alloc_from_contiguous(). > + * It returns false when provided pages do not belong to contiguous area and > + * true otherwise. > + */ > +bool dma_release_from_contiguous(struct device *dev, struct page *pages, > + int count) > +{ > + struct cma *cma = dev_get_cma_area(dev); > + unsigned long pfn; > + > + if (!cma || !pages) > + return false; > + > + pr_debug("%s(page %p)\n", __func__, (void *)pages); > + > + pfn = page_to_pfn(pages); > + > + if (pfn < cma->base_pfn || pfn >= cma->base_pfn + cma->count) > + return false; > + > + VM_BUG_ON(pfn + count > cma->base_pfn); Are you sure the VM_BUG_ON() condition is correct here? > + mutex_lock(&cma_mutex); > + bitmap_clear(cma->bitmap, pfn - cma->base_pfn, count); > + free_contig_range(pfn, count); > + mutex_unlock(&cma_mutex); > + > + return true; > +} A. -- 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/