Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp2965071pxb; Tue, 13 Apr 2021 15:00:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyO+j41ipF7A0/7uAarHoLzVlQKkip58lHIwv4WeSdqPvYWGJr4clTOEmi54+Z7h8sTq3sK X-Received: by 2002:a17:906:4fcd:: with SMTP id i13mr34514991ejw.341.1618351239487; Tue, 13 Apr 2021 15:00:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618351239; cv=none; d=google.com; s=arc-20160816; b=mpC93rLu3aeWRAq4mfB2MIbA1o6zlziOSXgRM/SwTiaoD6O6YIbe5OSZwfKfcLmqYC Vih/q7K0tyJqlChvXwcBN4yape39K6TEJ1gJweuOk3ln3dC1DkugOFcfW81no3lo7QZ1 Hd2ix0WqktCGy7yf66z6gYoW09Mec1L4z73a4X1n74Zyx2/GHSl17cU4QvjSCg0SZEDa aJn2zoS0WtnqK6wj9e3L6jQakHdgL1uKNWshQkenUH0DIraTPDde/EOd1IW5tq5IIUHY +TRzVSPQfiHWSycZwrdKzwembJIwiGzFfpIRPi530MDHudZPQU8ch9a5S5IqKjMjNekq A6+A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=ZMl8qY8AQ+43tiyofU1xtjiz/mdzg+39SlQhPFsZBeY=; b=KlN0cbY7WzFpMW9yCwvSBLz0Xz4FEZeWFVedCyePhdE8qml+Re1F8x+mB9qQKEr+xx qQAIAbVvtqoLP6MoKwOfWsqN69E8OEjClSI2kJPhVccU+EPShlpM3/rD+k8Y/Feflwqx d8+MAfgxaguEcBBuL0y/hfj6h1VXllIS2vW8BE7v1kF1Xku3mxdoftSAByF6wp/qVq5Y fh8W1q0pr7Tql1dRCpL4EOSb9KXP75tzgP6/EJTSZsh/CEpkkajFvdD1/D8EGJxKxncF TkiRdhPPJSJp0FnMkrkbifo8yiy21IQ+QVj6FFDGtOWreF7cWelcrmtJrpNAkLsLnvxd acmQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=canonical.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i21si7157242ejk.516.2021.04.13.15.00.15; Tue, 13 Apr 2021 15:00:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=canonical.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1347016AbhDMRFj (ORCPT + 99 others); Tue, 13 Apr 2021 13:05:39 -0400 Received: from youngberry.canonical.com ([91.189.89.112]:34529 "EHLO youngberry.canonical.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239106AbhDMRFi (ORCPT ); Tue, 13 Apr 2021 13:05:38 -0400 Received: from 1-171-231-81.dynamic-ip.hinet.net ([1.171.231.81] helo=localhost) by youngberry.canonical.com with esmtpsa (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.86_2) (envelope-from ) id 1lWMTS-0005T2-Fo; Tue, 13 Apr 2021 17:05:15 +0000 From: Kai-Heng Feng To: pjones@redhat.com Cc: Kai-Heng Feng , Thomas Zimmermann , Alex Deucher , linux-fbdev@vger.kernel.org (open list:EFIFB FRAMEBUFFER DRIVER), dri-devel@lists.freedesktop.org (open list:FRAMEBUFFER LAYER), linux-kernel@vger.kernel.org (open list) Subject: [PATCH] efifb: Check efifb_pci_dev before using it Date: Wed, 14 Apr 2021 01:05:08 +0800 Message-Id: <20210413170508.968148-1-kai.heng.feng@canonical.com> X-Mailer: git-send-email 2.30.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On some platforms like Hyper-V and RPi4 with UEFI firmware, efifb is not a PCI device. So make sure efifb_pci_dev is found before using it. Fixes: a6c0fd3d5a8b ("efifb: Ensure graphics device for efifb stays at PCI D0") BugLink: https://bugs.launchpad.net/bugs/1922403 Signed-off-by: Kai-Heng Feng --- drivers/video/fbdev/efifb.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/drivers/video/fbdev/efifb.c b/drivers/video/fbdev/efifb.c index f58a545b3bf3..8ea8f079cde2 100644 --- a/drivers/video/fbdev/efifb.c +++ b/drivers/video/fbdev/efifb.c @@ -575,7 +575,8 @@ static int efifb_probe(struct platform_device *dev) goto err_fb_dealoc; } fb_info(info, "%s frame buffer device\n", info->fix.id); - pm_runtime_get_sync(&efifb_pci_dev->dev); + if (efifb_pci_dev) + pm_runtime_get_sync(&efifb_pci_dev->dev); return 0; err_fb_dealoc: @@ -602,7 +603,8 @@ static int efifb_remove(struct platform_device *pdev) unregister_framebuffer(info); sysfs_remove_groups(&pdev->dev.kobj, efifb_groups); framebuffer_release(info); - pm_runtime_put(&efifb_pci_dev->dev); + if (efifb_pci_dev) + pm_runtime_put(&efifb_pci_dev->dev); return 0; } -- 2.30.2