Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3046427yba; Tue, 16 Apr 2019 03:36:18 -0700 (PDT) X-Google-Smtp-Source: APXvYqyOgaq7Lo4zNnN03/22v75WC9onB6vgcfU0j8bJAmdmzeyebmKtMYLmY6sndMEe45r9vfHF X-Received: by 2002:a65:6149:: with SMTP id o9mr6830333pgv.254.1555410978543; Tue, 16 Apr 2019 03:36:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555410978; cv=none; d=google.com; s=arc-20160816; b=LaxSnhz5eKyxeyNqrvQE0IsaLfXt0f9LCRleSHREYMGrabvpLRn4B9cSUrZ/QGsXHX X7NdYVtq1cq0Y4jmujwiTFUIgHAcrsFJ8+KsJEwHbXdE4Vcqywm1yMBG9BsKPQeKYn+z Ue08f/l4FA4UBX7ZN0ydRMPl6AuV2JXqj/yUl++5UAUdrUjAB8wwD6KmMzlK9Me9Ri74 uJbskI5hTpALboyTdh6lgmm/Rd5fPZ0PXqb4e0Hqy1bohDFyXhRHCnieZbs3LjVAHzPq 1Gv5ipeuRDLzZ6fz6OwWO25xdO0xvvUZdphhdObjCbcni/ILi9KkPPmymPZjlsto+37o 8Fig== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :content-language:accept-language:references:message-id:date :thread-index:thread-topic:subject:cc:to:from; bh=dDyq81ytFWNMqlhFqOMfI8FOfArj2x/eGxSr6CIjfJI=; b=U4bhu8A+GTXilQSVV66N27ngY4y3wHgSSpP92RSC+C8FueoMAK9mxHTmGsO/xXPQYb Vi7wqfX81gvIMN/JRww99vs7wrPD3U7DUdHv/Gf0xGfhO8eR/Q9eCbQk5qeAE9Mf8U3I 87kO/LSz/+Y4IZLM2Gwu+oOfUH9+5z3u+mMLFQ4AXp7hEv4F5NlWDIJD9OfHS5hJi2uC 7IYwKuOSo9h0ZuZgkv1TAJ+axWaICqp58nUteMhQqJ+BBeIkQnHIcj3q6bt25idsE2qU YdO2VqnkUuYcxfKcVTgUJH4ZYDq0cAFf9vRxl68Ys/kl5WzERgh5pOloQJl9zcPxpoKO hKXQ== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q4si41632091pll.127.2019.04.16.03.36.02; Tue, 16 Apr 2019 03:36:18 -0700 (PDT) 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729111AbfDPKfI convert rfc822-to-8bit (ORCPT + 99 others); Tue, 16 Apr 2019 06:35:08 -0400 Received: from mail-sh.amlogic.com ([58.32.228.43]:44326 "EHLO mail-sh.amlogic.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728625AbfDPKfI (ORCPT ); Tue, 16 Apr 2019 06:35:08 -0400 X-Greylist: delayed 901 seconds by postgrey-1.27 at vger.kernel.org; Tue, 16 Apr 2019 06:35:07 EDT Received: from mail-sh.amlogic.com (10.18.11.5) by mail-sh.amlogic.com (10.18.11.5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1591.10; Tue, 16 Apr 2019 18:20:05 +0800 Received: from mail-sh.amlogic.com ([::1]) by mail-sh.amlogic.com ([::1]) with mapi id 15.01.1591.012; Tue, 16 Apr 2019 18:20:05 +0800 From: Sky Zhou To: Neil Armstrong , "dri-devel@lists.freedesktop.org" CC: "linux-amlogic@lists.infradead.org" , "linux-kernel@vger.kernel.org" Subject: Re: [PATCH] drm/meson: add size and alignment requirements for dumb buffers Thread-Topic: [PATCH] drm/meson: add size and alignment requirements for dumb buffers Thread-Index: AQHU7emyYXrKpM5Hu0ukuwfto14jpw== Date: Tue, 16 Apr 2019 10:20:05 +0000 Message-ID: References: <20190408090137.2402-1-narmstrong@baylibre.com> Accept-Language: en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-originating-ip: [10.18.29.243] Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 8BIT MIME-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2019/4/8 17:01, Neil Armstrong wrote: > The Amlogic SoCs Canvas buffers stride must be aligned on 64bytes > and overall size should be aligned on PAGE width. > > Adds a custom dumb_create op to adds these requirements. > > Fixes: bbbe775ec5b5 ("drm: Add support for Amlogic Meson Graphic Controller") > Suggested-by: Sky Zhou > Signed-off-by: Neil Armstrong > --- > drivers/gpu/drm/meson/meson_drv.c | 14 +++++++++++++- > 1 file changed, 13 insertions(+), 1 deletion(-) > > diff --git a/drivers/gpu/drm/meson/meson_drv.c b/drivers/gpu/drm/meson/meson_drv.c > index faf1b1b0357c..72b01e6be0d9 100644 > --- a/drivers/gpu/drm/meson/meson_drv.c > +++ b/drivers/gpu/drm/meson/meson_drv.c > @@ -90,6 +90,18 @@ static irqreturn_t meson_irq(int irq, void *arg) > return IRQ_HANDLED; > } > > +static int meson_dumb_create(struct drm_file *file, struct drm_device *dev, > + struct drm_mode_create_dumb *args) > +{ > + /* > + * We need 64bytes aligned stride, and PAGE aligned size > + */ > + args->pitch = ALIGN(DIV_ROUND_UP(args->width * args->bpp, 8), SZ_64); > + args->size = PAGE_ALIGN(args->pitch * args->height); > + > + return drm_gem_cma_dumb_create_internal(file, dev, args); > +} > + > DEFINE_DRM_GEM_CMA_FOPS(fops); > > static struct drm_driver meson_driver = { > @@ -112,7 +124,7 @@ static struct drm_driver meson_driver = { > .gem_prime_mmap = drm_gem_cma_prime_mmap, > > /* GEM Ops */ > - .dumb_create = drm_gem_cma_dumb_create, > + .dumb_create = meson_dumb_create, > .gem_free_object_unlocked = drm_gem_cma_free_object, > .gem_vm_ops = &drm_gem_cma_vm_ops, > > Reviewed-by: Sky Zhou