Received: by 10.223.185.116 with SMTP id b49csp2511268wrg; Mon, 12 Feb 2018 10:43:58 -0800 (PST) X-Google-Smtp-Source: AH8x226nqbgyHAlo8aUYfih7V6hWESkLef2TcnsNjMW1FTZiu9Ktl2QPzgWicHbccYg4/dywxFDB X-Received: by 2002:a17:902:461:: with SMTP id 88-v6mr3006225ple.88.1518461038059; Mon, 12 Feb 2018 10:43:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518461038; cv=none; d=google.com; s=arc-20160816; b=zGJHzFHJQa5aGxfOFjv6aKSRz7sOApIxqpYxBrBN/evJVxn2Siao3xXnDKrqMLH50f ppgzecmj+kLdjO74ojtzZCttH1WrxZR20LaWbsFK08AV1gD4iJewfBn9mqC/hz7RdWSZ yCPTe87tPU+vHxgfzdH5quD7nbVc8H7vS+G361nlR/lpPmLAmlgtsi3AwBQPeHfljT90 Y/kaGHkMf+7LAgcd3hwDA2ETa0NgiFIIuZwcr8GbqeBZ/C9EBf3yNahdLOU5ZPMkPGLe LyEnf7Mewj5EIEVxqbxLqcsS2uBiXUQ6XhVtKqsAEDKSPbmTbB3edWAkbn8sJQ9GcrEy dvAA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=Xjj9dHcwkQ93s+mL3Y30pIfe8FZa5OAUa3BnAW4UJKg=; b=xY5WooZHPkbMeziQXxXU6KO3zvmmH13QA/JE/QnVeFqNCs8v+IHwdIOTQJcf09bKpn VxpXnX18AWlqKEIV1UiBChj0KqNrxczjo4wtcGLn15U9cgob0o8JY6LBW/N+0X1WRNtO guJbwbbzF/zwAiFqzCid7DKMjcdj5j+kGCIF3bnm+4E9FFhB9f6x9J21wwh6Fwg+u7/a cGDLf6v9bD/3u2dk5tqFSyflL/KHimMItIVQJkWDmGjuUIy8ynsWvBcVNaI1iM0jbR/e ndwU0t0TmeswgAdqmEAhsFo9PO695Xxz7gEgbm6OeuEzfyXjYGpSppXhtDkIPdHrbx2E bfDw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 3-v6si4519196plm.409.2018.02.12.10.43.43; Mon, 12 Feb 2018 10:43:58 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753606AbeBLSmu (ORCPT + 99 others); Mon, 12 Feb 2018 13:42:50 -0500 Received: from mail-ot0-f195.google.com ([74.125.82.195]:43982 "EHLO mail-ot0-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751196AbeBLSmt (ORCPT ); Mon, 12 Feb 2018 13:42:49 -0500 Received: by mail-ot0-f195.google.com with SMTP id q12so14897786otg.10 for ; Mon, 12 Feb 2018 10:42:49 -0800 (PST) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=Xjj9dHcwkQ93s+mL3Y30pIfe8FZa5OAUa3BnAW4UJKg=; b=ZLWCQikWag3dl9KtCxnCLdMMPXblqwvDV5ubHu2S6UKvNrCTZtQQLpkVqij754xg4O 4NhhArUKCPADxTCbAytgXe+lcegKRcEvUCAqLhTjxJO8ICn+BbVJtm0GDn0Fp8uxpClH nd/PsgNkgY7IzrADeFTchL8irDKPZOaj+8gNtQWI4Xvjp+Dgf5F/m/TENc4xSxuSYYGD ngUiY8ZEEVDAxOiil5xAQftHrMtXpbkUdlseG2igCOmOHLiJKzzEzDg2ztjVomCDOb2o x8mSTPbb9srwIVtqWoAdROhydqvD4/1P0luQMwXqZFaDkVmsBZqJA7TqmYo+vJWp44oA LeTg== X-Gm-Message-State: APf1xPD8THSli7VNU2RU7fza/K4BT0T0ZEVVOOGrEpxQa7qfMNQC2VSy jVM0L78CkIGY6+taJJvXUpv5hA== X-Received: by 10.157.9.220 with SMTP id 28mr9815241otz.363.1518460968805; Mon, 12 Feb 2018 10:42:48 -0800 (PST) Received: from ?IPv6:2601:602:9802:a8dc::f21a? ([2601:602:9802:a8dc::f21a]) by smtp.gmail.com with ESMTPSA id z124sm4690540oia.38.2018.02.12.10.42.46 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 12 Feb 2018 10:42:47 -0800 (PST) Subject: Re: [PATCH] staging: android: ion: Add requested allocation alignment To: Alexey Skidanov , sumit.semwal@linaro.org, gregkh@linuxfoundation.org, arve@android.com, tkjos@android.com, maco@android.com, devel@driverdev.osuosl.org Cc: linux-kernel@vger.kernel.org, Liam Mark References: <1518257863-6903-1-git-send-email-alexey.skidanov@intel.com> From: Laura Abbott Message-ID: Date: Mon, 12 Feb 2018 10:42:46 -0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.5.2 MIME-Version: 1.0 In-Reply-To: <1518257863-6903-1-git-send-email-alexey.skidanov@intel.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 02/10/2018 02:17 AM, Alexey Skidanov wrote: > Current ion defined allocation ioctl doesn't allow to specify the requested > allocation alignment. CMA heap allocates buffers aligned on buffer size > page order. > > Sometimes, the alignment requirement is less restrictive. In such cases, > providing specific alignment may reduce the external memory fragmentation > and in some cases it may avoid the allocation request failure. > I really do not want to bring this back as part of the regular ABI. Having an alignment parameter that gets used for exactly one heap only leads to confusion (which is why it was removed from the ABI in the first place). The alignment came from the behavior of the DMA APIs. Do you actually need to specify any alignment from userspace or do you only need page size? Thanks, Laura > To fix this, we add an alignment parameter to the allocation ioctl. > > Signed-off-by: Alexey Skidanov > --- > drivers/staging/android/ion/ion-ioctl.c | 3 ++- > drivers/staging/android/ion/ion.c | 14 +++++++++----- > drivers/staging/android/ion/ion.h | 9 ++++++--- > drivers/staging/android/ion/ion_carveout_heap.c | 3 ++- > drivers/staging/android/ion/ion_chunk_heap.c | 3 ++- > drivers/staging/android/ion/ion_cma_heap.c | 18 ++++++++++++------ > drivers/staging/android/ion/ion_system_heap.c | 6 ++++-- > drivers/staging/android/uapi/ion.h | 7 +++---- > 8 files changed, 40 insertions(+), 23 deletions(-) > > diff --git a/drivers/staging/android/ion/ion-ioctl.c b/drivers/staging/android/ion/ion-ioctl.c > index c789893..9fe022b 100644 > --- a/drivers/staging/android/ion/ion-ioctl.c > +++ b/drivers/staging/android/ion/ion-ioctl.c > @@ -83,7 +83,8 @@ long ion_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) > > fd = ion_alloc(data.allocation.len, > data.allocation.heap_id_mask, > - data.allocation.flags); > + data.allocation.flags, > + data.allocation.align); > if (fd < 0) > return fd; > > diff --git a/drivers/staging/android/ion/ion.c b/drivers/staging/android/ion/ion.c > index f480885..35ddc7a 100644 > --- a/drivers/staging/android/ion/ion.c > +++ b/drivers/staging/android/ion/ion.c > @@ -78,7 +78,8 @@ static void ion_buffer_add(struct ion_device *dev, > static struct ion_buffer *ion_buffer_create(struct ion_heap *heap, > struct ion_device *dev, > unsigned long len, > - unsigned long flags) > + unsigned long flags, > + unsigned int align) > { > struct ion_buffer *buffer; > int ret; > @@ -90,14 +91,14 @@ static struct ion_buffer *ion_buffer_create(struct ion_heap *heap, > buffer->heap = heap; > buffer->flags = flags; > > - ret = heap->ops->allocate(heap, buffer, len, flags); > + ret = heap->ops->allocate(heap, buffer, len, flags, align); > > if (ret) { > if (!(heap->flags & ION_HEAP_FLAG_DEFER_FREE)) > goto err2; > > ion_heap_freelist_drain(heap, 0); > - ret = heap->ops->allocate(heap, buffer, len, flags); > + ret = heap->ops->allocate(heap, buffer, len, flags, align); > if (ret) > goto err2; > } > @@ -390,7 +391,10 @@ static const struct dma_buf_ops dma_buf_ops = { > .unmap = ion_dma_buf_kunmap, > }; > > -int ion_alloc(size_t len, unsigned int heap_id_mask, unsigned int flags) > +int ion_alloc(size_t len, > + unsigned int heap_id_mask, > + unsigned int flags, > + unsigned int align) > { > struct ion_device *dev = internal_dev; > struct ion_buffer *buffer = NULL; > @@ -417,7 +421,7 @@ int ion_alloc(size_t len, unsigned int heap_id_mask, unsigned int flags) > /* if the caller didn't specify this heap id */ > if (!((1 << heap->id) & heap_id_mask)) > continue; > - buffer = ion_buffer_create(heap, dev, len, flags); > + buffer = ion_buffer_create(heap, dev, len, flags, align); > if (!IS_ERR(buffer)) > break; > } > diff --git a/drivers/staging/android/ion/ion.h b/drivers/staging/android/ion/ion.h > index f5f9cd6..0c161d2 100644 > --- a/drivers/staging/android/ion/ion.h > +++ b/drivers/staging/android/ion/ion.h > @@ -123,8 +123,10 @@ struct ion_device { > */ > struct ion_heap_ops { > int (*allocate)(struct ion_heap *heap, > - struct ion_buffer *buffer, unsigned long len, > - unsigned long flags); > + struct ion_buffer *buffer, > + unsigned long len, > + unsigned long flags, > + unsigned int align); > void (*free)(struct ion_buffer *buffer); > void * (*map_kernel)(struct ion_heap *heap, struct ion_buffer *buffer); > void (*unmap_kernel)(struct ion_heap *heap, struct ion_buffer *buffer); > @@ -228,7 +230,8 @@ int ion_heap_pages_zero(struct page *page, size_t size, pgprot_t pgprot); > > int ion_alloc(size_t len, > unsigned int heap_id_mask, > - unsigned int flags); > + unsigned int flags, > + unsigned int align); > > /** > * ion_heap_init_shrinker > diff --git a/drivers/staging/android/ion/ion_carveout_heap.c b/drivers/staging/android/ion/ion_carveout_heap.c > index fee7650..deae9dd 100644 > --- a/drivers/staging/android/ion/ion_carveout_heap.c > +++ b/drivers/staging/android/ion/ion_carveout_heap.c > @@ -59,7 +59,8 @@ static void ion_carveout_free(struct ion_heap *heap, phys_addr_t addr, > static int ion_carveout_heap_allocate(struct ion_heap *heap, > struct ion_buffer *buffer, > unsigned long size, > - unsigned long flags) > + unsigned long flags, > + unsigned int align) > { > struct sg_table *table; > phys_addr_t paddr; > diff --git a/drivers/staging/android/ion/ion_chunk_heap.c b/drivers/staging/android/ion/ion_chunk_heap.c > index 102c093..15f9518 100644 > --- a/drivers/staging/android/ion/ion_chunk_heap.c > +++ b/drivers/staging/android/ion/ion_chunk_heap.c > @@ -35,7 +35,8 @@ struct ion_chunk_heap { > static int ion_chunk_heap_allocate(struct ion_heap *heap, > struct ion_buffer *buffer, > unsigned long size, > - unsigned long flags) > + unsigned long flags, > + unsigned int align) > { > struct ion_chunk_heap *chunk_heap = > container_of(heap, struct ion_chunk_heap, heap); > diff --git a/drivers/staging/android/ion/ion_cma_heap.c b/drivers/staging/android/ion/ion_cma_heap.c > index 86196ff..f3f8deb 100644 > --- a/drivers/staging/android/ion/ion_cma_heap.c > +++ b/drivers/staging/android/ion/ion_cma_heap.c > @@ -32,25 +32,31 @@ struct ion_cma_heap { > #define to_cma_heap(x) container_of(x, struct ion_cma_heap, heap) > > /* ION CMA heap operations functions */ > -static int ion_cma_allocate(struct ion_heap *heap, struct ion_buffer *buffer, > +static int ion_cma_allocate(struct ion_heap *heap, > + struct ion_buffer *buffer, > unsigned long len, > - unsigned long flags) > + unsigned long flags, > + unsigned int align) > { > struct ion_cma_heap *cma_heap = to_cma_heap(heap); > struct sg_table *table; > struct page *pages; > unsigned long size = PAGE_ALIGN(len); > unsigned long nr_pages = size >> PAGE_SHIFT; > - unsigned long align = get_order(size); > + int order = get_order(align); > int ret; > > - if (align > CONFIG_CMA_ALIGNMENT) > - align = CONFIG_CMA_ALIGNMENT; > + /* CMA allocation alignment is in PAGE_SIZE order */ > + if (order > CONFIG_CMA_ALIGNMENT) > + order = CONFIG_CMA_ALIGNMENT; > > - pages = cma_alloc(cma_heap->cma, nr_pages, align, GFP_KERNEL); > + pages = cma_alloc(cma_heap->cma, nr_pages, order, GFP_KERNEL); > if (!pages) > return -ENOMEM; > > + pr_debug("Allocated block of %lu pages starting at 0x%lX", > + nr_pages, page_to_pfn(pages)); > + > table = kmalloc(sizeof(*table), GFP_KERNEL); > if (!table) > goto err; > diff --git a/drivers/staging/android/ion/ion_system_heap.c b/drivers/staging/android/ion/ion_system_heap.c > index 4dc5d7a..b5a1720 100644 > --- a/drivers/staging/android/ion/ion_system_heap.c > +++ b/drivers/staging/android/ion/ion_system_heap.c > @@ -125,7 +125,8 @@ static struct page *alloc_largest_available(struct ion_system_heap *heap, > static int ion_system_heap_allocate(struct ion_heap *heap, > struct ion_buffer *buffer, > unsigned long size, > - unsigned long flags) > + unsigned long flags, > + unsigned int align) > { > struct ion_system_heap *sys_heap = container_of(heap, > struct ion_system_heap, > @@ -363,7 +364,8 @@ device_initcall(ion_system_heap_create); > static int ion_system_contig_heap_allocate(struct ion_heap *heap, > struct ion_buffer *buffer, > unsigned long len, > - unsigned long flags) > + unsigned long flags, > + unsigned int align) > { > int order = get_order(len); > struct page *page; > diff --git a/drivers/staging/android/uapi/ion.h b/drivers/staging/android/uapi/ion.h > index 9e21451..b093edd 100644 > --- a/drivers/staging/android/uapi/ion.h > +++ b/drivers/staging/android/uapi/ion.h > @@ -70,9 +70,8 @@ enum ion_heap_type { > * @len: size of the allocation > * @heap_id_mask: mask of heap ids to allocate from > * @flags: flags passed to heap > - * @handle: pointer that will be populated with a cookie to use to > - * refer to this allocation > - * > + * @fd: file descriptor associated with newly allocated buffer > + * @align: allocation alignment > * Provided by userspace as an argument to the ioctl > */ > struct ion_allocation_data { > @@ -80,7 +79,7 @@ struct ion_allocation_data { > __u32 heap_id_mask; > __u32 flags; > __u32 fd; > - __u32 unused; > + __u32 align; > }; > > #define MAX_HEAP_NAME 32 >