Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp642382ybl; Wed, 14 Aug 2019 03:49:53 -0700 (PDT) X-Google-Smtp-Source: APXvYqwNQYWs2qB23mftKW1aAlndxHxP7PRoZ/xLKinIg0trdpVnAQX0XkXLkkrAFfCercu5aA0J X-Received: by 2002:aa7:9118:: with SMTP id 24mr44256437pfh.56.1565779793127; Wed, 14 Aug 2019 03:49:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1565779793; cv=none; d=google.com; s=arc-20160816; b=PrS3I8u4Jmepk+63FF5j4K/9Zxwi15by4AIXOz5rW9nnv0hjoYvxd5dkbqNhKM7iMM ohVn01dgwEscgtjBfUmdYIf3U8r2GNBLh58ULJsS1BodYsKpW4pLyMBiKs/zqIslFduM D0AdIHn6Cw4U4uZAQACrodob9fjV7EV1fdi5jUNGJ1B9Ous+hNiYzvQMvjLtt6P4vBXy r+Jg5fq8oPuuywkvhv+xWgLMmH3LjEFy35r+8P7K7ltZWnIUiTxIRiZfLoLwThzMQcON OQ97GKZDmufHyMm8cUxlrPGWUAG8ZtewDOigwrh3Sj8fguQwb2/yq+rY0pyIzxJSjB4y wFzA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=YKifwotMACtrRpQ4p1dRtUktXoFN3w1aiEIUGk9i0KM=; b=oqG7FejBsZMarwVCRula8yg1X5u4zytdQg0wHu9PiGrKjtyBSnWwx4PieyvLYPCMGd k3K1IrJTXCbgewDYk95M1rHsSc07Fyi85gV6+dSwCN10wjEDjPWYobMF7LDoNes5C++r DICn2DMKcBhyp/H/p5Ygq2FaZBSAU3eZLAJyrD31A8dFW8XXHsuGRjByaxtTMejUyy6K Pd6qDjyG495v00Z7JhlBr7Kk/fdCMf2vCh1ML4qntDCH6PmF70XwsdCfJz5FPEhnM6+M URTrXMe7LK90SRm93eAvS5Xs48pGnrfazTNa90sQ+9GN1OJQ8u5/WaCfP4OxZmF1LtmS 9Vpg== 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=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g62si7557002pfb.219.2019.08.14.03.49.37; Wed, 14 Aug 2019 03:49:53 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727968AbfHNKtH (ORCPT + 99 others); Wed, 14 Aug 2019 06:49:07 -0400 Received: from inva021.nxp.com ([92.121.34.21]:51830 "EHLO inva021.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727890AbfHNKtF (ORCPT ); Wed, 14 Aug 2019 06:49:05 -0400 Received: from inva021.nxp.com (localhost [127.0.0.1]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id AE348200376; Wed, 14 Aug 2019 12:49:03 +0200 (CEST) Received: from inva024.eu-rdc02.nxp.com (inva024.eu-rdc02.nxp.com [134.27.226.22]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id AB48F2003CB; Wed, 14 Aug 2019 12:49:03 +0200 (CEST) Received: from fsr-ub1664-120.ea.freescale.net (fsr-ub1664-120.ea.freescale.net [10.171.82.81]) by inva024.eu-rdc02.nxp.com (Postfix) with ESMTP id AD1482060E; Wed, 14 Aug 2019 12:49:02 +0200 (CEST) From: Robert Chiras To: =?UTF-8?q?Guido=20G=C3=BCnther?= , Marek Vasut , Stefan Agner , David Airlie , Daniel Vetter , Rob Herring , Mark Rutland , Shawn Guo , Sascha Hauer , Fabio Estevam Cc: Pengutronix Kernel Team , NXP Linux Team , dri-devel@lists.freedesktop.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH v2 07/15] drm/mxsfb: Fix the vblank events Date: Wed, 14 Aug 2019 13:48:43 +0300 Message-Id: <1565779731-1300-8-git-send-email-robert.chiras@nxp.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1565779731-1300-1-git-send-email-robert.chiras@nxp.com> References: <1565779731-1300-1-git-send-email-robert.chiras@nxp.com> X-Virus-Scanned: ClamAV using ClamSMTP Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently, the vblank support is not correctly implemented in MXSFB_DRM driver. The call to drm_vblank_init is made with mode_config.num_crtc which at that time is 0. Because of this, vblank is not activated, so there won't be any vblank event submitted. For example, when running modetest with the '-v' parameter will result in an astronomical refresh rate (10000+ Hz), because of that. Signed-off-by: Robert Chiras --- drivers/gpu/drm/mxsfb/mxsfb_drv.c | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/drivers/gpu/drm/mxsfb/mxsfb_drv.c b/drivers/gpu/drm/mxsfb/mxsfb_drv.c index 2743975..829abec 100644 --- a/drivers/gpu/drm/mxsfb/mxsfb_drv.c +++ b/drivers/gpu/drm/mxsfb/mxsfb_drv.c @@ -38,6 +38,9 @@ #include "mxsfb_drv.h" #include "mxsfb_regs.h" +/* The eLCDIF max possible CRTCs */ +#define MAX_CRTCS 1 + enum mxsfb_devtype { MXSFB_V3, MXSFB_V4, @@ -138,6 +141,8 @@ static void mxsfb_pipe_enable(struct drm_simple_display_pipe *pipe, mxsfb->connector = &mxsfb->panel_connector; } + drm_crtc_vblank_on(&pipe->crtc); + pm_runtime_get_sync(drm->dev); drm_panel_prepare(mxsfb->panel); mxsfb_crtc_enable(mxsfb); @@ -164,6 +169,8 @@ static void mxsfb_pipe_disable(struct drm_simple_display_pipe *pipe) } spin_unlock_irq(&drm->event_lock); + drm_crtc_vblank_off(&pipe->crtc); + if (mxsfb->connector != &mxsfb->panel_connector) mxsfb->connector = NULL; } @@ -246,7 +253,7 @@ static int mxsfb_load(struct drm_device *drm, unsigned long flags) pm_runtime_enable(drm->dev); - ret = drm_vblank_init(drm, drm->mode_config.num_crtc); + ret = drm_vblank_init(drm, MAX_CRTCS); if (ret < 0) { dev_err(drm->dev, "Failed to initialise vblank\n"); goto err_vblank; @@ -269,6 +276,8 @@ static int mxsfb_load(struct drm_device *drm, unsigned long flags) goto err_vblank; } + drm_crtc_vblank_off(&mxsfb->pipe.crtc); + /* * Attach panel only if there is one. * If there is no panel attach, it must be a bridge. In this case, we -- 2.7.4