Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp3804585ybi; Mon, 29 Jul 2019 12:59:00 -0700 (PDT) X-Google-Smtp-Source: APXvYqy87nG4SoYTVP6VjqON70MPx4bpj10G0qJ8pSI+1KjJhCKB3Vbineaxq29PDhnhxVmh2OjW X-Received: by 2002:a65:4044:: with SMTP id h4mr105874765pgp.164.1564430340738; Mon, 29 Jul 2019 12:59:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564430340; cv=none; d=google.com; s=arc-20160816; b=BYMTd+NGPk2ZHh00Jl3nm+bbOI/Pq7Tw6lhqRgF+tryVarH8tZL2cEnh9ppJVv01fA BV/nehADB8vLZnYrUNBK+usUzmfBQ1T9ySIH+2v8UHoxho2dWtRKesxubD6IcXbrWJAb ShtR5BuqZwNPCZhCmaOrA4UlCK07s7rHZpE7xbgVce9UW3A0xN3VQw4DuwoSsCc7HP++ XleCLtAgX7E7d+I9K6BwcBF1I+SSVAOhxAufns66k3S+UwKBlMAMjxPUYVYFIks7loYm +QC4D75daDTXkaNtv5vULgaySjfsU828xQl7U+EHRpvmLmLpP66VwuT8RDyE2uwDg376 DjMw== 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=8rdz7ExNCnZfjiD0BW+XdWgCMJiVsYgUTmepp+JHW2Q=; b=0vxRf540RfgqG6w4uj4i/NWu4seKA4MuVkQ0duuMyUouQ+BP68cfvZUK+JDU+hTajz BZZHik5GUa2/0QxaOW0V06L6Z6CqWUQzBsQ9wcjAeK2/AIRkxY4EE4ECRk7JWVUynQyn A6qtbz0KCE3tzXPsePHqpxRcS+Vc5EWT9amt+8ML7VmGT9IEPg+YKeiAy5iOf7nH9q0K 9t/Og8wvX3FqiOQnz22CW9XEtrqda1BWRkvJGt/eOankWl3KsiQEHfu6dtOf5KzdQ05s 0RzQddGyRmPRz3Dl6BLaJi0TksFxhHNIJr7LYeGvAAkhzePeuR2X7h1KMcVUhfYp53vH Ahow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=aEStrOQO; 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 b9si27162984pgb.478.2019.07.29.12.58.45; Mon, 29 Jul 2019 12:59:00 -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=aEStrOQO; 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 S2404013AbfG2Ty1 (ORCPT + 99 others); Mon, 29 Jul 2019 15:54:27 -0400 Received: from mail.kernel.org ([198.145.29.99]:46854 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2391014AbfG2TyP (ORCPT ); Mon, 29 Jul 2019 15:54:15 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (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 5D409204EC; Mon, 29 Jul 2019 19:54:13 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1564430053; bh=wb7JobYxQwKUM5KVL6HwRUr07E2etF55+QCdxL56Di8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=aEStrOQOYScv5CzEssH1UfztltLST4ZY+OSHa1oargP69Z425FBq3COsaEYerBdP/ jaD0aLJ9V+QetcAmXQcY9L2t9L98hm8rXWz8Hn8ddo4BWm3HRI06V708CGXVjhvRZZ WJytyXXu5Ir+HjwaQBXQEpwdfGN/+PlPErhjYIoU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Hans de Goede , Thomas Gleixner Subject: [PATCH 5.2 181/215] x86/sysfb_efi: Add quirks for some devices with swapped width and height Date: Mon, 29 Jul 2019 21:22:57 +0200 Message-Id: <20190729190811.458919191@linuxfoundation.org> X-Mailer: git-send-email 2.22.0 In-Reply-To: <20190729190739.971253303@linuxfoundation.org> References: <20190729190739.971253303@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: Hans de Goede commit d02f1aa39189e0619c3525d5cd03254e61bf606a upstream. Some Lenovo 2-in-1s with a detachable keyboard have a portrait screen but advertise a landscape resolution and pitch, resulting in a messed up display if the kernel tries to show anything on the efifb (because of the wrong pitch). Fix this by adding a new DMI match table for devices which need to have their width and height swapped. At first it was tried to use the existing table for overriding some of the efifb parameters, but some of the affected devices have variants with different LCD resolutions which will not work with hardcoded override values. Reference: https://bugzilla.redhat.com/show_bug.cgi?id=1730783 Signed-off-by: Hans de Goede Signed-off-by: Thomas Gleixner Cc: stable@vger.kernel.org Link: https://lkml.kernel.org/r/20190721152418.11644-1-hdegoede@redhat.com Signed-off-by: Greg Kroah-Hartman --- arch/x86/kernel/sysfb_efi.c | 46 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) --- a/arch/x86/kernel/sysfb_efi.c +++ b/arch/x86/kernel/sysfb_efi.c @@ -230,9 +230,55 @@ static const struct dmi_system_id efifb_ {}, }; +/* + * Some devices have a portrait LCD but advertise a landscape resolution (and + * pitch). We simply swap width and height for these devices so that we can + * correctly deal with some of them coming with multiple resolutions. + */ +static const struct dmi_system_id efifb_dmi_swap_width_height[] __initconst = { + { + /* + * Lenovo MIIX310-10ICR, only some batches have the troublesome + * 800x1280 portrait screen. Luckily the portrait version has + * its own BIOS version, so we match on that. + */ + .matches = { + DMI_EXACT_MATCH(DMI_SYS_VENDOR, "LENOVO"), + DMI_EXACT_MATCH(DMI_PRODUCT_VERSION, "MIIX 310-10ICR"), + DMI_EXACT_MATCH(DMI_BIOS_VERSION, "1HCN44WW"), + }, + }, + { + /* Lenovo MIIX 320-10ICR with 800x1280 portrait screen */ + .matches = { + DMI_EXACT_MATCH(DMI_SYS_VENDOR, "LENOVO"), + DMI_EXACT_MATCH(DMI_PRODUCT_VERSION, + "Lenovo MIIX 320-10ICR"), + }, + }, + { + /* Lenovo D330 with 800x1280 or 1200x1920 portrait screen */ + .matches = { + DMI_EXACT_MATCH(DMI_SYS_VENDOR, "LENOVO"), + DMI_EXACT_MATCH(DMI_PRODUCT_VERSION, + "Lenovo ideapad D330-10IGM"), + }, + }, + {}, +}; + __init void sysfb_apply_efi_quirks(void) { if (screen_info.orig_video_isVGA != VIDEO_TYPE_EFI || !(screen_info.capabilities & VIDEO_CAPABILITY_SKIP_QUIRKS)) dmi_check_system(efifb_dmi_system_table); + + if (screen_info.orig_video_isVGA == VIDEO_TYPE_EFI && + dmi_check_system(efifb_dmi_swap_width_height)) { + u16 temp = screen_info.lfb_width; + + screen_info.lfb_width = screen_info.lfb_height; + screen_info.lfb_height = temp; + screen_info.lfb_linelength = 4 * screen_info.lfb_width; + } }