Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp249078ybi; Wed, 29 May 2019 20:37:25 -0700 (PDT) X-Google-Smtp-Source: APXvYqwxVEPqnnLL+UZWQ7ktuFK01u8ygBcyDqg7A+l3oTj+UcBH8D1osDfwPAFagdbqHYZ///2k X-Received: by 2002:a17:902:9f94:: with SMTP id g20mr1762272plq.56.1559187445547; Wed, 29 May 2019 20:37:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559187445; cv=none; d=google.com; s=arc-20160816; b=uAO2TaD1Dl8kFrTEZCDQf2yufmuhN+UeM6z2p9kmulebKYBFMdF08PfM8mZzSnCdem XUUAcNjkqKEnsdwo4kT0iUzFY+jqFrY0RyoyEZECPZKTqO4xXICUzHTTPfIdS1pQf7XD wx+ZPLODD3wUsRp42XFLolQhCGMKRZV2BEvoCcpH2YcDwhHYyK2HleNzwdNhUGFfC/9d i7YL5TPewuLbYB+xfd5NIr3SZf7vHBqJ5Vun7kfle7VPX7lnD+CUeF5obDgf55ijbkIF J1NXrD4hMrAWp83/LfSlM4WEWV9TQ2r1kQydCnGSZHYn21esOcxEQ7HXNP7CZM2Egmo7 hPzw== 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=9s8Ry7CJ2uxKoL0LaDA9AWUfDcP7eiDOaGqkgNdrKbg=; b=UvlZFSUUB9w06e3s/5qvTB75QHA0753lsu3m/DOiOzqXd4Gqo7hHUaQrKN7/MFYEW6 LPhRiIU3cli/KIob705rVI+jpQg4qt6SASziOxt9nSX361Hemj2tMbou6xxiWPlHpALM eAkzGces4fbG9WHKAU1uaacgbWDk/bKrEyYSHuD1XMHOAQroUcpPmBwwtYCHcweUbsFw y29FxlenBp85T3Wn6tY4oJ1xdJ7GA6Lb9/5gve4+xECTVMj67PPfeAs+duTiJxGbi0gj 9dp+/gWC1+bFkXC07V7hw5NFZ9N0bt50n+sJ4G5PFoHYr+WxxL8SQIRrQtxoIaQTJLVi clTQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=0hOrIda8; 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 b8si1883277ple.370.2019.05.29.20.37.10; Wed, 29 May 2019 20:37:25 -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; dkim=pass header.i=@kernel.org header.s=default header.b=0hOrIda8; 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 S1732702AbfE3DZb (ORCPT + 99 others); Wed, 29 May 2019 23:25:31 -0400 Received: from mail.kernel.org ([198.145.29.99]:50856 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731566AbfE3DSa (ORCPT ); Wed, 29 May 2019 23:18:30 -0400 Received: from localhost (ip67-88-213-2.z213-88-67.customer.algx.net [67.88.213.2]) (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 B72622472C; Thu, 30 May 2019 03:18:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1559186309; bh=8gRQZ733zbroR7nLj5wr3+V5DHtMrt2aYomVG95miOY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=0hOrIda8REVcbtSlduRMmOzECRvumE/hIwduBdcXRnv30VaW0eORJKq21M95KQi5S Iaouj0K3UpNZQLZInt2KMQ/ixzKXP4C78plfl5PvkQ88CdsCFBrogkEwEPp3uoKD4d tTGXSCMy9MJuVk7ACofeeORaBSKrzp7gwfZeKEQQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Eric Anholt , Dave Emett , Sasha Levin Subject: [PATCH 4.19 270/276] drm/v3d: Handle errors from IRQ setup. Date: Wed, 29 May 2019 20:07:08 -0700 Message-Id: <20190530030542.094351553@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190530030523.133519668@linuxfoundation.org> References: <20190530030523.133519668@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 [ Upstream commit fc22771547e7e8a63679f0218e943d72b107de65 ] Noted in review by Dave Emett for V3D 4.2 support. Signed-off-by: Eric Anholt Link: https://patchwork.freedesktop.org/patch/msgid/20190308174336.7866-1-eric@anholt.net Reviewed-by: Dave Emett Signed-off-by: Sasha Levin --- drivers/gpu/drm/v3d/v3d_drv.c | 8 ++++++-- drivers/gpu/drm/v3d/v3d_drv.h | 2 +- drivers/gpu/drm/v3d/v3d_irq.c | 13 +++++++++++-- 3 files changed, 18 insertions(+), 5 deletions(-) diff --git a/drivers/gpu/drm/v3d/v3d_drv.c b/drivers/gpu/drm/v3d/v3d_drv.c index 2a85fa68ffea5..2a4c6187e675f 100644 --- a/drivers/gpu/drm/v3d/v3d_drv.c +++ b/drivers/gpu/drm/v3d/v3d_drv.c @@ -305,14 +305,18 @@ static int v3d_platform_drm_probe(struct platform_device *pdev) if (ret) goto dev_destroy; - v3d_irq_init(v3d); + ret = v3d_irq_init(v3d); + if (ret) + goto gem_destroy; ret = drm_dev_register(drm, 0); if (ret) - goto gem_destroy; + goto irq_disable; return 0; +irq_disable: + v3d_irq_disable(v3d); gem_destroy: v3d_gem_destroy(drm); dev_destroy: diff --git a/drivers/gpu/drm/v3d/v3d_drv.h b/drivers/gpu/drm/v3d/v3d_drv.h index e6fed696ad869..0ad73f4b7509a 100644 --- a/drivers/gpu/drm/v3d/v3d_drv.h +++ b/drivers/gpu/drm/v3d/v3d_drv.h @@ -284,7 +284,7 @@ void v3d_invalidate_caches(struct v3d_dev *v3d); void v3d_flush_caches(struct v3d_dev *v3d); /* v3d_irq.c */ -void v3d_irq_init(struct v3d_dev *v3d); +int v3d_irq_init(struct v3d_dev *v3d); void v3d_irq_enable(struct v3d_dev *v3d); void v3d_irq_disable(struct v3d_dev *v3d); void v3d_irq_reset(struct v3d_dev *v3d); diff --git a/drivers/gpu/drm/v3d/v3d_irq.c b/drivers/gpu/drm/v3d/v3d_irq.c index e07514eb11b51..22be0f2dff99c 100644 --- a/drivers/gpu/drm/v3d/v3d_irq.c +++ b/drivers/gpu/drm/v3d/v3d_irq.c @@ -137,7 +137,7 @@ v3d_hub_irq(int irq, void *arg) return status; } -void +int v3d_irq_init(struct v3d_dev *v3d) { int ret, core; @@ -154,13 +154,22 @@ v3d_irq_init(struct v3d_dev *v3d) ret = devm_request_irq(v3d->dev, platform_get_irq(v3d->pdev, 0), v3d_hub_irq, IRQF_SHARED, "v3d_hub", v3d); + if (ret) + goto fail; + ret = devm_request_irq(v3d->dev, platform_get_irq(v3d->pdev, 1), v3d_irq, IRQF_SHARED, "v3d_core0", v3d); if (ret) - dev_err(v3d->dev, "IRQ setup failed: %d\n", ret); + goto fail; v3d_irq_enable(v3d); + return 0; + +fail: + if (ret != -EPROBE_DEFER) + dev_err(v3d->dev, "IRQ setup failed: %d\n", ret); + return ret; } void -- 2.20.1