Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp4496453ybx; Mon, 4 Nov 2019 14:22:40 -0800 (PST) X-Google-Smtp-Source: APXvYqyJuH92kSLmA0aVyt5Kbpiw60MYe0PxuwgFmyDucvGa6OPmIlkBxgTNB8kVoioY6ZygvUQK X-Received: by 2002:a50:90a6:: with SMTP id c35mr32278001eda.22.1572906160766; Mon, 04 Nov 2019 14:22:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1572906160; cv=none; d=google.com; s=arc-20160816; b=ky6F63Uor19jtg9LaqGFGUy4lkTH45ZGpXAwVg6Q6gTW/zUBAqax+lO/GP6pRCvdCs UgmewJYGlu6xRSkoLId0l92aDgXUkxOQIciC6by5EOo54gIYiFcKZv6jTJ7mAoHdI8sh fmEgP0N6+iWz2OxloyVdw0yj0bO7blwXBBjGJEadW6eaclkG+pTM/gaqAsHfq/ixbAqP nesD1+EbQwsgd59Mjh4ZOdQob/8rhh7yKe+eWE+3ZQn7FTuwrY8vQzBiIooKbQee8Map 6s9q2T8rOspkEUYJ76qa7S8i+XFxut3vWFmgqDJ04GmEbuq8ZtSBKWTpNIYsLAQtePqZ jEmg== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=PtpBaRK348jnrJMpZUlmiPlusuRZH/5mAuRw36seccg=; b=vqbPyqSVcm8/XqP5gLg07TuvqWP4txUILOJraKmwASY7qp51OY6uBYD9/rmPnFYdv9 IcPJJszK3/dapS2ftKJBK5Rb/92z4OpuApQ2+62dRLugRlhIt8K5MzkQdAKfCl4q1T0W GKi88m5XLWsj7WOH8aNkea9ulz6uwCBFjmw0O0O6qANitqFNmbS757j7dlUy2IXVioLj pUMxljiVKaXyDxTx8+k0uOdGu/yl8zK7g1d9ZhtwwRmXlEiDSq3PJuv8vmHb59wcZc/+ isRByCwhtfgJVI6a85DGnKNCxfAu53fDQPzoYRIrXy8rmoO5vfQIwLgt6QKGksF8NJ7n VTIQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=JmEiOEMR; 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 k12si8026434ede.181.2019.11.04.14.22.16; Mon, 04 Nov 2019 14:22:40 -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 header.i=@kernel.org header.s=default header.b=JmEiOEMR; 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 S2388584AbfKDV50 (ORCPT + 99 others); Mon, 4 Nov 2019 16:57:26 -0500 Received: from mail.kernel.org ([198.145.29.99]:53560 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388568AbfKDV5X (ORCPT ); Mon, 4 Nov 2019 16:57:23 -0500 Received: from localhost (6.204-14-84.ripe.coltfrance.com [84.14.204.6]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 46990214D8; Mon, 4 Nov 2019 21:57:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1572904641; bh=2K3Nhn17oyQlttcoEwq3Au9rsNdUXZ/WhlXS/lb70BA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=JmEiOEMR4EPmST5Pnylvv3fW6hzK2XJ30TADNB7n0MR7pSVOyxZXeSbTa0OW3djKA QZiEYENmtN8T0Q23KeyssihVVnq6Ez6shDNdPLFor5tGTt0I72Y11pfmqecx+I6CbF KoAZK0wMcMhwGSrXReUQT7kV7MtpuTrTFT6eaA64= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Jeykumar Sankaran , Sean Paul , Sasha Levin Subject: [PATCH 4.19 019/149] drm/msm/dpu: handle failures while initializing displays Date: Mon, 4 Nov 2019 22:43:32 +0100 Message-Id: <20191104212136.271271541@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191104212126.090054740@linuxfoundation.org> References: <20191104212126.090054740@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jeykumar Sankaran [ Upstream commit a802ee99c448ca0496fa307f3e46b834ae2a46a3 ] Bail out KMS hw init on display initialization failures with proper error logging. changes in v3: - introduced in the series changes in v4: - avoid duplicate return on errors (Sean Paul) - avoid spamming errors on failures (Jordon Crouse) Signed-off-by: Jeykumar Sankaran Signed-off-by: Sean Paul Signed-off-by: Sasha Levin --- drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c | 31 ++++++++++++++----------- 1 file changed, 18 insertions(+), 13 deletions(-) diff --git a/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c b/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c index 74cc204b07e80..2d9b7b5fb49c8 100644 --- a/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c +++ b/drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c @@ -442,35 +442,38 @@ static void dpu_kms_wait_for_commit_done(struct msm_kms *kms, } } -static void _dpu_kms_initialize_dsi(struct drm_device *dev, +static int _dpu_kms_initialize_dsi(struct drm_device *dev, struct msm_drm_private *priv, struct dpu_kms *dpu_kms) { struct drm_encoder *encoder = NULL; - int i, rc; + int i, rc = 0; + + if (!(priv->dsi[0] || priv->dsi[1])) + return rc; /*TODO: Support two independent DSI connectors */ encoder = dpu_encoder_init(dev, DRM_MODE_ENCODER_DSI); - if (IS_ERR_OR_NULL(encoder)) { + if (IS_ERR(encoder)) { DPU_ERROR("encoder init failed for dsi display\n"); - return; + return PTR_ERR(encoder); } priv->encoders[priv->num_encoders++] = encoder; for (i = 0; i < ARRAY_SIZE(priv->dsi); i++) { - if (!priv->dsi[i]) { - DPU_DEBUG("invalid msm_dsi for ctrl %d\n", i); - return; - } + if (!priv->dsi[i]) + continue; rc = msm_dsi_modeset_init(priv->dsi[i], dev, encoder); if (rc) { DPU_ERROR("modeset_init failed for dsi[%d], rc = %d\n", i, rc); - continue; + break; } } + + return rc; } /** @@ -481,16 +484,16 @@ static void _dpu_kms_initialize_dsi(struct drm_device *dev, * @dpu_kms: Pointer to dpu kms structure * Returns: Zero on success */ -static void _dpu_kms_setup_displays(struct drm_device *dev, +static int _dpu_kms_setup_displays(struct drm_device *dev, struct msm_drm_private *priv, struct dpu_kms *dpu_kms) { - _dpu_kms_initialize_dsi(dev, priv, dpu_kms); - /** * Extend this function to initialize other * types of displays */ + + return _dpu_kms_initialize_dsi(dev, priv, dpu_kms); } static void _dpu_kms_drm_obj_destroy(struct dpu_kms *dpu_kms) @@ -552,7 +555,9 @@ static int _dpu_kms_drm_obj_init(struct dpu_kms *dpu_kms) * Create encoder and query display drivers to create * bridges and connectors */ - _dpu_kms_setup_displays(dev, priv, dpu_kms); + ret = _dpu_kms_setup_displays(dev, priv, dpu_kms); + if (ret) + goto fail; max_crtc_count = min(catalog->mixer_count, priv->num_encoders); -- 2.20.1