Received: by 10.223.176.5 with SMTP id f5csp2537wra; Tue, 30 Jan 2018 07:12:31 -0800 (PST) X-Google-Smtp-Source: AH8x227rZz3CZASRna+wAaCbkcN2idDNnnb3qL/u7lX+PJi8JuJqtmr7N/fbwQtsKlSw5BfXCJiW X-Received: by 10.98.75.91 with SMTP id y88mr30755779pfa.178.1517325151110; Tue, 30 Jan 2018 07:12:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517325151; cv=none; d=google.com; s=arc-20160816; b=TULDCi9mY3AgRSQTcXgrh+MUOIwd6a/X/oN6+KuGqFtumhdhlvIIMSH2CuVvdzlmgq y8DeHbzT6K5wP1PIAGAJDu8bGEBRBUwADutBPnWRT0i3TO0AY6N4fOh+GfyJGjd4O+Cc yg7hqVKcwp0tg7PJNgW5VX9f3SrfQGmOUkr5yrkQxl/BhjdIyr9NLjCkaCnM3iExMc5R g166NKF4D9W4VU/l6ssVz4vz60Fyl4uXF/8IReui/gKvn0itYfn6HchTfsvBb3dsdBs0 iXcrPl75s7OUWboCmL/zTIcUhDMihOZcpk3DeJA/KOyNWs0hEP4KM1EaNsJHgX4btIFx j4Pw== 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:mime-version :references:in-reply-to:organization:message-id:date:subject:cc:to :from:dkim-signature:arc-authentication-results; bh=4lsZ9GpIDvd8Vcuc6Yy4S4HKZaAes1WHWpo2hz5Bf1s=; b=rayz/PeuVa5ASQOjhj1mrZ3Ui8jlAJdo+I66o0H9NQumq19y6JxNiNkpkw1VWZgBoh 85dgANFqSaAiTJUiUBGo69gpQNRoAx/rPA7aa/NMrYyWGPzKy5OCNYn8fjxZx6yR205Y Qalm0BohDNKmn544XmO7HUa2bwZVqfUjc4U0hSZbG49l81yUzYrpg4uH3Ea0V5PSnnOk UMipw2KbyNePPlYJPyxqmMO2Sjq1mw/2/0Pn3SyUwSOQL66pTNof7sdVf4BSsMo9XRCu xfSXMnXtSUSPs/XAvvK8fOLSQKf7ZSWOYfHg7tPPgProsFjU2Cpdz3SpmtQbB4CnBFmT LEhw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=VOSo07L/; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id u185si9390077pgd.397.2018.01.30.07.12.15; Tue, 30 Jan 2018 07:12:31 -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; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=VOSo07L/; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752949AbeA3PK3 (ORCPT + 99 others); Tue, 30 Jan 2018 10:10:29 -0500 Received: from galahad.ideasonboard.com ([185.26.127.97]:45550 "EHLO galahad.ideasonboard.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751678AbeA3PK2 (ORCPT ); Tue, 30 Jan 2018 10:10:28 -0500 Received: from avalon.localnet (unknown [IPv6:2a02:a03f:52fb:2b00:ac86:2f77:64c9:83c0]) by galahad.ideasonboard.com (Postfix) with ESMTPSA id 548922014A; Tue, 30 Jan 2018 16:09:17 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1517324957; bh=373zzbQFvkKAAb+iuwjkaj//YgbX3SYP0RptdSDgvK4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=VOSo07L/TN16rFtRBONxr240SfWpeYHnVlxbm7BOlmc/fFWF1xNSml4FYpetvDycg NegsJVf8PRIDgcYzfJKmInVwigTTrd2uS4GWnH4bB2s4JA+9+4ND5nPucX7D2QYxHF fDSbIzs4ThuVRoLwzNhgvipx0gmA0ZRtLT3C1sc4= From: Laurent Pinchart To: Benjamin Gaignard Cc: Philippe Cornu , Yannick Fertre , Vincent Abriou , David Airlie , dri-devel@lists.freedesktop.org, Linux Kernel Mailing List , Archit Taneja , Andrzej Hajda , Fabien Dessenne , Mickael Reulier , Ludovic Barre , Alexandre Torgue , Maxime Coquelin Subject: Re: [PATCH v2] drm/stm: drv: Improve data transfers Date: Tue, 30 Jan 2018 17:10:43 +0200 Message-ID: <28099300.xC2jyNz3X5@avalon> Organization: Ideas on Board Oy In-Reply-To: References: <20180130104200.21602-1-philippe.cornu@st.com> <3365044.AohtTD8A6l@avalon> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Benjamin, On Tuesday, 30 January 2018 17:08:48 EET Benjamin Gaignard wrote: > 2018-01-30 15:58 GMT+01:00 Laurent Pinchart: > > On Tuesday, 30 January 2018 12:42:00 EET Philippe Cornu wrote: > >> To optimize data transfers, align pitch on 128 bytes & height > >> on 4 bytes. This optimization is not applicable on hw without MMU. > >> > >> Signed-off-by: Yannick Fertre > >> Signed-off-by: Vincent Abriou > >> Signed-off-by: Philippe Cornu > >> --- > >> Changes in v2: Rename stm_dumb_create() to stm_gem_cma_dumb_create() and > >> > >> move CONFIG_MMU inside the function following comments from Benjamin > >> Gaignard. > >> > >> drivers/gpu/drm/stm/drv.c | 20 +++++++++++++++++++- > >> 1 file changed, 19 insertions(+), 1 deletion(-) > >> > >> diff --git a/drivers/gpu/drm/stm/drv.c b/drivers/gpu/drm/stm/drv.c > >> index 8fe954c27fba..8bc7e8418b8d 100644 > >> --- a/drivers/gpu/drm/stm/drv.c > >> +++ b/drivers/gpu/drm/stm/drv.c > >> @@ -31,6 +31,24 @@ static const struct drm_mode_config_funcs > >> drv_mode_config_funcs = { .atomic_commit = drm_atomic_helper_commit, > >> > >> }; > >> > >> +static int stm_gem_cma_dumb_create(struct drm_file *file, > >> + struct drm_device *dev, > >> + struct drm_mode_create_dumb *args) > >> +{ > >> +#ifdef CONFIG_MMU > >> + unsigned int min_pitch = DIV_ROUND_UP(args->width * args->bpp, 8); > >> + > >> + /* > >> + * in order to optimize data transfer, pitch is aligned on > >> + * 128 bytes, height is aligned on 4 bytes > >> + */ > >> + args->pitch = roundup(min_pitch, 128); > >> + args->height = roundup(args->height, 4); > >> +#endif > >> + > >> + return drm_gem_cma_dumb_create_internal(file, dev, args); > > > > In the !CONFIG_MMU case you now bypass the pitch and size calculations > > performed by drm_gem_cma_dumb_create(), allowing userspace to allocate > > arbitrarily large buffers. Is that intentional ? > > My bad, I will send a fix Thank you. > >> +} > >> + > >> > >> DEFINE_DRM_GEM_CMA_FOPS(drv_driver_fops); > >> > >> static struct drm_driver drv_driver = { > >> > >> @@ -44,7 +62,7 @@ static struct drm_driver drv_driver = { > >> > >> .minor = 0, > >> .patchlevel = 0, > >> .fops = &drv_driver_fops, > >> > >> - .dumb_create = drm_gem_cma_dumb_create, > >> + .dumb_create = stm_gem_cma_dumb_create, > >> > >> .prime_handle_to_fd = drm_gem_prime_handle_to_fd, > >> .prime_fd_to_handle = drm_gem_prime_fd_to_handle, > >> .gem_free_object_unlocked = drm_gem_cma_free_object, -- Regards, Laurent Pinchart