Received: by 10.223.185.116 with SMTP id b49csp2157037wrg; Thu, 22 Feb 2018 09:00:39 -0800 (PST) X-Google-Smtp-Source: AH8x225UxXCShVu+44AjXr80EYjPHCG/hKAnhN2x4PoJxurv1u3Hy0g+F3b+jj6n2P+1lr1w6Z2+ X-Received: by 10.99.109.70 with SMTP id i67mr6206220pgc.190.1519318839119; Thu, 22 Feb 2018 09:00:39 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1519318839; cv=none; d=google.com; s=arc-20160816; b=Unq7WWIQhFBOYg2OGK/h2gnlxYRbW8uQK3qOPT3/PZTNCOD4u0M6AsqIbyInVX8AL2 UR7r4TKG5Xs/4zv39aW/N3vgouw47scOZdiFpj6bVmTewPDm2qcQ7Ywwra8FwGjUJ8iU D/V56QFRAMm6J7L8hsb8+6YjJtHvwz6IWshB7TMqcvDrpz6W/DpdN7iseo9aThs9ku5Y zFID1se9TT/zFMaLPitjSpjSWIIduuaKDVwRXuDOPIXD0bjzutzGxSV5x9NyROOx5+xB eFUjOSQUScCLZ7Lrn9KLKZGMQUESwXsk0yBXCeO8hBBY40pjUXL83+MFTi/Usz8q/o0y xbHg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:mail-followup-to :message-id:subject:cc:to:from:date:dkim-signature :arc-authentication-results; bh=QJ9g/PEg60tYnWcuFAlfHFuzqn9F1X2Uv+SHta+Rc/c=; b=PQREgY+mqwUkty4xt8LwhTdhDm2x82sOc8YbuJH7B17Pdajt30lJm+GAUQ0MGDikZX MCpgZ0vYV4tbUprlR3tZkB591skZmc0G7GUuWZHyxYFHPyOBg2zHLiJSP573X4QpFJG7 u9GMYTLfwh679/zGj6xd5iSHVdfKFVwdNgeMl0rLUuPPgR2TanLdLSOJeAivnALG1yf/ IPDLSxcDhsGzSQjpV0eezQ0xw54VkpLjgTitvMt/ZyoeA9SqXO+k/FwNgxS5zv0h1OJb IdcqP7Y9X2BIcIoJOv/lRecV2ZoMu04zF66NpWaU2OWkoRQJo9qhwgWgfRY6nd2w5CEZ gdhw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@ffwll.ch header.s=google header.b=WGA6bgJa; 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 a61-v6si298178plc.669.2018.02.22.09.00.24; Thu, 22 Feb 2018 09:00:39 -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=fail header.i=@ffwll.ch header.s=google header.b=WGA6bgJa; 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 S933398AbeBVQ7Y (ORCPT + 99 others); Thu, 22 Feb 2018 11:59:24 -0500 Received: from mail-wm0-f68.google.com ([74.125.82.68]:38610 "EHLO mail-wm0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933214AbeBVQ7V (ORCPT ); Thu, 22 Feb 2018 11:59:21 -0500 Received: by mail-wm0-f68.google.com with SMTP id z9so4944175wmb.3 for ; Thu, 22 Feb 2018 08:59:20 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=sender:date:from:to:cc:subject:message-id:mail-followup-to :references:mime-version:content-disposition:in-reply-to:user-agent; bh=QJ9g/PEg60tYnWcuFAlfHFuzqn9F1X2Uv+SHta+Rc/c=; b=WGA6bgJaMzwFP1xHczZVXdHvCYN/3Mv1568qrw9hzlVzfl7yGe4kjatMrvSU5u9CSI yeVSPZLmS/Si+8HxnOWbhvAhhuEb/dqJIOOfxIqYX7kjMtwludqsTKIwK+tLJ3QS0Usg tRF5Ai2kI3Q0oc5BQppk83HSSmsQoAHzZhs0Y= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:from:to:cc:subject:message-id :mail-followup-to:references:mime-version:content-disposition :in-reply-to:user-agent; bh=QJ9g/PEg60tYnWcuFAlfHFuzqn9F1X2Uv+SHta+Rc/c=; b=q3xIizqvs0w1U4facUdHDx06Y5gPFz0f1HO9REXPv514a/tdmbqdkuFIIEir8fZrK1 fAopIBcAo7tfIcauhb+UB9Xr/RdR8EQUf1TFCDIQhJ59FP/W277w2hp90QOhfptl6mGf YLKMkdtdYZbmNqs53cqdzWrUB9BFWQh1ODiVjWT0eJDWXFnhjWFjpY7Gdkjhypwnlwsg /K17q49+XjeBFAKjK7b6NKlkPDXH7ygXDUG03S00QeqeIkzxqEq7c/7bLDatGSdIWRcP OuVyDd4EtVpitLtzHViaTbkqF+U0qwkz0cH9otZGGOX/kbhCukvnfvrzuSvbXM29+Op1 8Iow== X-Gm-Message-State: APf1xPCsAaYGMVs8kXiQCPQQhe88pzEpYp+kPGdQ+DtxgEs3Ou32FChW hNxLhr5ofcPbg1kUTYXfWoxDJA== X-Received: by 10.80.194.25 with SMTP id n25mr10214466edf.84.1519318760266; Thu, 22 Feb 2018 08:59:20 -0800 (PST) Received: from phenom.ffwll.local ([2a02:168:5635:0:39d2:f87e:2033:9f6]) by smtp.gmail.com with ESMTPSA id w4sm499531edf.76.2018.02.22.08.59.18 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Thu, 22 Feb 2018 08:59:18 -0800 (PST) Date: Thu, 22 Feb 2018 17:59:16 +0100 From: Daniel Vetter To: Oleksandr Andrushchenko Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, airlied@linux.ie, daniel.vetter@intel.com, Oleksandr Andrushchenko Subject: Re: [PATCH 1/4] drm/simple_kms_helper: Add {enable|disable}_vblank callback support Message-ID: <20180222165916.GD6419@phenom.ffwll.local> Mail-Followup-To: Oleksandr Andrushchenko , dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, airlied@linux.ie, daniel.vetter@intel.com, Oleksandr Andrushchenko References: <1518425574-32671-1-git-send-email-andr2000@gmail.com> <1518425574-32671-2-git-send-email-andr2000@gmail.com> <00b01a2d-ad16-e171-f52f-88fba2896386@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <00b01a2d-ad16-e171-f52f-88fba2896386@gmail.com> X-Operating-System: Linux phenom 4.14.0-3-amd64 User-Agent: Mutt/1.9.3 (2018-01-21) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Feb 19, 2018 at 11:11:23AM +0200, Oleksandr Andrushchenko wrote: > ping > On 02/12/2018 10:52 AM, Oleksandr Andrushchenko wrote: > > From: Oleksandr Andrushchenko > > > > If simple_kms_helper based driver needs to work with vblanks, > > then it has to provide drm_driver.{enable|disable}_vblank callbacks, > > because drm_simple_kms_helper.drm_crtc_funcs does not provide any. > > At the same time drm_driver.{enable|disable}_vblank callbacks > > are marked as deprecated and shouldn't be used by new drivers. > > > > Fix this by extending drm_simple_kms_helper.drm_crtc_funcs > > to provide the missing callbacks. > > > > Signed-off-by: Oleksandr Andrushchenko lgtm, all 4 applied, thanks for your patches. -Daniel > > --- > > drivers/gpu/drm/drm_simple_kms_helper.c | 24 ++++++++++++++++++++++++ > > include/drm/drm_simple_kms_helper.h | 18 ++++++++++++++++++ > > 2 files changed, 42 insertions(+) > > > > diff --git a/drivers/gpu/drm/drm_simple_kms_helper.c b/drivers/gpu/drm/drm_simple_kms_helper.c > > index 9d3f6b70812c..9ca8a4a59b74 100644 > > --- a/drivers/gpu/drm/drm_simple_kms_helper.c > > +++ b/drivers/gpu/drm/drm_simple_kms_helper.c > > @@ -77,6 +77,28 @@ static const struct drm_crtc_helper_funcs drm_simple_kms_crtc_helper_funcs = { > > .atomic_disable = drm_simple_kms_crtc_disable, > > }; > > +static int drm_simple_kms_crtc_enable_vblank(struct drm_crtc *crtc) > > +{ > > + struct drm_simple_display_pipe *pipe; > > + > > + pipe = container_of(crtc, struct drm_simple_display_pipe, crtc); > > + if (!pipe->funcs || !pipe->funcs->enable_vblank) > > + return 0; > > + > > + return pipe->funcs->enable_vblank(pipe); > > +} > > + > > +static void drm_simple_kms_crtc_disable_vblank(struct drm_crtc *crtc) > > +{ > > + struct drm_simple_display_pipe *pipe; > > + > > + pipe = container_of(crtc, struct drm_simple_display_pipe, crtc); > > + if (!pipe->funcs || !pipe->funcs->disable_vblank) > > + return; > > + > > + pipe->funcs->disable_vblank(pipe); > > +} > > + > > static const struct drm_crtc_funcs drm_simple_kms_crtc_funcs = { > > .reset = drm_atomic_helper_crtc_reset, > > .destroy = drm_crtc_cleanup, > > @@ -84,6 +106,8 @@ static const struct drm_crtc_funcs drm_simple_kms_crtc_funcs = { > > .page_flip = drm_atomic_helper_page_flip, > > .atomic_duplicate_state = drm_atomic_helper_crtc_duplicate_state, > > .atomic_destroy_state = drm_atomic_helper_crtc_destroy_state, > > + .enable_vblank = drm_simple_kms_crtc_enable_vblank, > > + .disable_vblank = drm_simple_kms_crtc_disable_vblank, > > }; > > static int drm_simple_kms_plane_atomic_check(struct drm_plane *plane, > > diff --git a/include/drm/drm_simple_kms_helper.h b/include/drm/drm_simple_kms_helper.h > > index 6d9adbb46293..79567826b099 100644 > > --- a/include/drm/drm_simple_kms_helper.h > > +++ b/include/drm/drm_simple_kms_helper.h > > @@ -93,6 +93,24 @@ struct drm_simple_display_pipe_funcs { > > */ > > void (*cleanup_fb)(struct drm_simple_display_pipe *pipe, > > struct drm_plane_state *plane_state); > > + > > + /** > > + * @enable_vblank: > > + * > > + * Optional, called by &drm_crtc_funcs.enable_vblank. Please read > > + * the documentation for the &drm_crtc_funcs.enable_vblank hook for > > + * more details. > > + */ > > + int (*enable_vblank)(struct drm_simple_display_pipe *pipe); > > + > > + /** > > + * @disable_vblank: > > + * > > + * Optional, called by &drm_crtc_funcs.disable_vblank. Please read > > + * the documentation for the &drm_crtc_funcs.disable_vblank hook for > > + * more details. > > + */ > > + void (*disable_vblank)(struct drm_simple_display_pipe *pipe); > > }; > > /** > > _______________________________________________ > dri-devel mailing list > dri-devel@lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/dri-devel -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch