From patchwork Wed Jun 28 15:47:02 2017 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Aleksandar Markovic X-Patchwork-Id: 9814811 Return-Path: Received: from mail.wl.linuxfoundation.org (pdx-wl-mail.web.codeaurora.org [172.30.200.125]) by pdx-korg-patchwork.web.codeaurora.org (Postfix) with ESMTP id DBBE6603D7 for ; Wed, 28 Jun 2017 15:59:44 +0000 (UTC) Received: from mail.wl.linuxfoundation.org (localhost [127.0.0.1]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id CC04B28488 for ; Wed, 28 Jun 2017 15:59:44 +0000 (UTC) Received: by mail.wl.linuxfoundation.org (Postfix, from userid 486) id BFEDA285FC; Wed, 28 Jun 2017 15:59:44 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on pdx-wl-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.9 required=2.0 tests=BAYES_00,RCVD_IN_DNSWL_HI autolearn=ham version=3.3.1 Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.wl.linuxfoundation.org (Postfix) with ESMTP id 5778F28488 for ; Wed, 28 Jun 2017 15:59:44 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751560AbdF1P7k (ORCPT ); Wed, 28 Jun 2017 11:59:40 -0400 Received: from mx2.rt-rk.com ([89.216.37.149]:50910 "EHLO mail.rt-rk.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751701AbdF1P7X (ORCPT ); Wed, 28 Jun 2017 11:59:23 -0400 X-Greylist: delayed 357 seconds by postgrey-1.27 at vger.kernel.org; Wed, 28 Jun 2017 11:59:22 EDT Received: from localhost (localhost [127.0.0.1]) by mail.rt-rk.com (Postfix) with ESMTP id 0E70B1A47FB; Wed, 28 Jun 2017 17:53:24 +0200 (CEST) X-Virus-Scanned: amavisd-new at rt-rk.com Received: from rtrkw197-lin.domain.local (unknown [10.10.13.95]) by mail.rt-rk.com (Postfix) with ESMTPSA id 97AB01A47C6; Wed, 28 Jun 2017 17:53:23 +0200 (CEST) From: Aleksandar Markovic To: linux-mips@linux-mips.org Cc: Miodrag Dinic , Goran Ferenc , Aleksandar Markovic , Dmitry Torokhov , Douglas Leung , James Hogan , Jonas Gorski , linux-input@vger.kernel.org, linux-kernel@vger.kernel.org, Marcin Nowakowski , Marcos Paulo de Souza , Paul Burton , Petar Jovanovic , Raghu Gandham , Ralf Baechle Subject: [PATCH v2 09/10] MIPS: i8042: Probe this device only if it exists Date: Wed, 28 Jun 2017 17:47:02 +0200 Message-Id: <1498664922-28493-10-git-send-email-aleksandar.markovic@rt-rk.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1498664922-28493-1-git-send-email-aleksandar.markovic@rt-rk.com> References: <1498664922-28493-1-git-send-email-aleksandar.markovic@rt-rk.com> Sender: linux-input-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-input@vger.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP From: Miodrag Dinic ARCH_MIGHT_HAVE_PC_SERIO is selected by default for MIPS platforms. As a consequence SERIO_I8042 would be automatically selected for any MIPS board which wants to enable input support like keyboard (INPUT_KEYBOARD) regardless of i8042 controller existence. The dependency is as follows : config ARCH_MIGHT_HAVE_PC_SERIO [=y] Defined at drivers/input/serio/Kconfig:19 Depends on: !UML Selected by: MIPS [=y] config SERIO Defined at drivers/input/serio/Kconfig:4 default y Depends on: !UML Selected by: KEYBOARD_ATKBD [=y] && !UML && INPUT [=y] && INPUT_KEYBOARD [=y] config SERIO_I8042 Defined at drivers/input/serio/Kconfig:28 tristate "i8042 PC Keyboard controller" default y Depends on: !UML && SERIO [=y] && ARCH_MIGHT_HAVE_PC_SERIO [=y] Selected by: KEYBOARD_ATKBD [=y] && !UML && INPUT [=y] && INPUT_KEYBOARD [=y] && ARCH_MIGHT_HAVE_PC_SERIO [=y] If this driver probes the I8042_DATA_REG not knowing if the device exists it can cause a kernel to crash. Using check_legacy_ioport() interface we can selectively enable this driver only for the MIPS boards which actually have the i8042 controller. New "Ranchu" virtual platform does not support i8042 controller so it's added to the blacklist match table. Each MIPS machine should update this table with it's compatible strings if it does not support i8042 controller. In order to utilize this mechanism, each MIPS machine that do not have i8042 controller should update the blacklist table with its compatible strings. Signed-off-by: Miodrag Dinic Signed-off-by: Goran Ferenc Signed-off-by: Aleksandar Markovic --- arch/mips/kernel/setup.c | 16 ++++++++++++++++ drivers/input/serio/i8042-io.h | 2 +- 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/arch/mips/kernel/setup.c b/arch/mips/kernel/setup.c index c22cde8..c3e0d2b 100644 --- a/arch/mips/kernel/setup.c +++ b/arch/mips/kernel/setup.c @@ -79,6 +79,15 @@ const unsigned long mips_io_port_base = -1; EXPORT_SYMBOL(mips_io_port_base); /* + * Here we blacklist all MIPS boards which do not have i8042 controller + */ +static const struct of_device_id i8042_blacklist_of_match[] = { + { .compatible = "mti,ranchu", }, + {}, +}; +#define I8042_DATA_REG 0x60 + +/* * Check for existence of legacy devices * * Some drivers may try to probe some I/O ports which can lead to @@ -90,9 +99,16 @@ EXPORT_SYMBOL(mips_io_port_base); */ int check_legacy_ioport(unsigned long base_port) { + struct device_node *np; int ret = 0; switch (base_port) { + case I8042_DATA_REG: + np = of_find_matching_node(NULL, i8042_blacklist_of_match); + if (np) + ret = -ENODEV; + of_node_put(np); + break; default: /* We will assume that the I/O device port exists if * not explicitly added to the blacklist match table diff --git a/drivers/input/serio/i8042-io.h b/drivers/input/serio/i8042-io.h index 34da81c..ec5fe9e 100644 --- a/drivers/input/serio/i8042-io.h +++ b/drivers/input/serio/i8042-io.h @@ -72,7 +72,7 @@ static inline int i8042_platform_init(void) * On some platforms touching the i8042 data register region can do really * bad things. Because of this the region is always reserved on such boxes. */ -#if defined(CONFIG_PPC) +#if defined(CONFIG_PPC) || defined(CONFIG_MIPS) if (check_legacy_ioport(I8042_DATA_REG)) return -ENODEV; #endif