Received: by 10.223.176.5 with SMTP id f5csp4415233wra; Tue, 30 Jan 2018 07:02:10 -0800 (PST) X-Google-Smtp-Source: AH8x226ATWWEezfvrGeLxEwJlFRsKUHNHYcWHrKlD1xORp6ylou+Q6qgmIlIbXHOqzWcbUqkn+IQ X-Received: by 10.101.100.132 with SMTP id e4mr7047579pgv.398.1517324530573; Tue, 30 Jan 2018 07:02:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517324530; cv=none; d=google.com; s=arc-20160816; b=sVTK4vjZH+NmYJAAugaqmIymmcsXFUiCiPQbWDsI0G47xrZwXAJmocwAMGdsrfcAW5 MFhKbDzXKgBO2AxTRKRtpTKg256NXcpch7bjOzeh46Kj+ghJswV0Y29yoKPeTmmX+R50 +HCKZPG/yKDXCh0R1Yvuir46uezV7ss56iv9uTk2eUWKBypVYApAq0sWMUaBz0fq0Y/n gv8YmnyCGSSuJ/hk6Jgl/Ry/AJodKk+/Vuw/k/en3ZlCAWCZ5HWs3oT5PM/0wzPJ9kOk l6AZVUokVlt6jcP1cgk0DsCPRlHEIohG6iJERT4ZVrfE+Hw8UH2abOHip6J7bHs44UHK Nuxw== 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=qBSiup7AGRN2E1VyAwfO/Nj4hdfNYJk8HSSHXrCC1i8=; b=ogxLGq2rdA0yPFjqqzh3oMKjKUJcmH8ObxxG4dtIBTkpU/AEt0P8gvubUAC1lo+Nbn Sfixqe0x0uiF3n287K7/FBLxiA6IrFOQXWukCRLesMSekoTHrF4MLEYaK/vsJn9f29Z0 ZopGhtaKEq7TEhhHKvhXCLkHdFq2bJSZghgN7itMxM+O1k/gUaEEZ8PXS4yp1+xcMCtk xLuk1+Drs/taDk8bk6SpKnenIGYYcnccHa+LmDfSIR5ep8Vl2os0X92heeV3lNtVR8Rv vS8SkxDqjy5+KUxx3T/kCLuqhftHS1r7BzbD2RL7EOEKsnNQQtfJDlbI+IK9xiyCtIX3 Valw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=W4hxv7l7; 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 a3-v6si39988plc.552.2018.01.30.07.01.51; Tue, 30 Jan 2018 07:02:10 -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=W4hxv7l7; 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 S1751976AbeA3PBP (ORCPT + 99 others); Tue, 30 Jan 2018 10:01:15 -0500 Received: from galahad.ideasonboard.com ([185.26.127.97]:45511 "EHLO galahad.ideasonboard.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751429AbeA3PBN (ORCPT ); Tue, 30 Jan 2018 10:01:13 -0500 Received: from avalon.localnet (unknown [IPv6:2a02:a03f:52fb:2b00:ac86:2f77:64c9:83c0]) by galahad.ideasonboard.com (Postfix) with ESMTPSA id 7184F2014A; Tue, 30 Jan 2018 16:00:02 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1517324402; bh=kK8BFzRNN+lDQxCvrWSCFCHs3BYRAq85UkpnUAgeKiM=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=W4hxv7l7bLnjx/Cg23OEodPG9Xsti8FFwrbeZevjf2ryvbb/6cUINa3pl+CQVb8tJ 9H8P2cDt+zK5hpzF1jgEjpetKmajzJGdcMH3/fyAhZLuowNJzQp2cBKu+upu62HC8w JhbjmlsioAiBMoKsl1EqCpygM/zSfCV0B1mLGEvw= 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:01:30 +0200 Message-ID: <9032382.xZ397EfsLU@avalon> Organization: Ideas on Board Oy In-Reply-To: References: <20180130104200.21602-1-philippe.cornu@st.com> 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 12:51:25 EET Benjamin Gaignard wrote: > 2018-01-30 11:42 GMT+01:00 Philippe Cornu : > > 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 > > Applied on drm-misc-next. A 9 minutes review window is pretty small... I've been told before that I should then review v1 instead of complaining about short review times for v2, but in this case v2 introduces a bug that wasn't present in v1. > > --- > > 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); > > +} > > + > > > > 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, > > > > -- > > 2.15.1 -- Regards, Laurent Pinchart