Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3476940pxk; Mon, 21 Sep 2020 15:01:21 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzM4ez7MuDrdNeTD6ytdx9KPlm+U8uuQwvsC/p7pIu7VrjRWg2JOLktqkPQbkAgL23yOCn3 X-Received: by 2002:a17:906:cb92:: with SMTP id mf18mr1663846ejb.485.1600725681321; Mon, 21 Sep 2020 15:01:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600725681; cv=none; d=google.com; s=arc-20160816; b=u96RDMM8s7yR8rUesd/t/y6DF7/zIGkGG6aodiAe8zl19yhY117gqMZnCro6JdFbfW pf1LP+d9GNkir77mW2MFIsRcHS/Rrjy368S4aAO8KBO2F6AaPN/khtq3i7S3+WrtOHjJ s82212sNM+uTmSkMTnVtqNC2YMwhGSMdirPozKIc+IsOdhXRWovoOkwissS+2GfIEBoY QuDPjow28BOA9oQwsfx8cQMAg8oKANMMnHHwT1JU5axfzYQP9j+kesH4x7mtowlYR4Sr Gs2yk2oP9WitnfmdUFSTOCnfDF7h3iDMj6yifZGiMbkUSTn+s7ITn3Sp7auTlBYfC8MQ g53w== 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:dkim-signature; bh=rSEHJXHj9+tzEtZxthMuBV/BCzmmpJbJqqHn0YCShZA=; b=xjASMFwozqzQcb3icQs9mHNMEons379H6DVOxQulU792iWWw4jWiMA8omf5yVqQ+du Dmf0ZQz9Ssf5OwIhzFurdu1SyZbtacf33yuKqPiksiZFHKBSpkKQpuAY+TgD26nrwa+d eHIXS9/CNTi0sVqQitgm8DNPife+Kn6F/KHZc5QviHMoPazU+od+i8WgkPNLIiQtpFWn cR41QT2beS8JZELtXvThzr7L7+fiKlWJGtTTJMMYpQbAMsgiX/BM0kdC9uJVd/x7lnqa 3mZSOwi9F8/XIiEc/HGLOb52wcf+jwyu2jpEs/FkX5A3J2ZvJxIreBIkASis2lbmZX+Z mfVQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@wildgooses.com header.s=dkim header.b=eIJ3U+ru; 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=pass (p=NONE sp=NONE dis=NONE) header.from=wildgooses.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id d9si9086246edz.97.2020.09.21.15.00.57; Mon, 21 Sep 2020 15:01:21 -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; dkim=pass header.i=@wildgooses.com header.s=dkim header.b=eIJ3U+ru; 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=pass (p=NONE sp=NONE dis=NONE) header.from=wildgooses.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727447AbgIUV7t (ORCPT + 99 others); Mon, 21 Sep 2020 17:59:49 -0400 Received: from mail1.nippynetworks.com ([91.220.24.129]:52894 "EHLO mail1.nippynetworks.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726497AbgIUV7s (ORCPT ); Mon, 21 Sep 2020 17:59:48 -0400 Received: from twocubed.nippynetworks.com (office.nippynetworks.com [46.17.61.232]) by mail1.nippynetworks.com (Postfix) with SMTP id 4BwJJJ3DxYzTh52; Mon, 21 Sep 2020 22:59:44 +0100 (BST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=wildgooses.com; s=dkim; t=1600725585; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding; bh=rSEHJXHj9+tzEtZxthMuBV/BCzmmpJbJqqHn0YCShZA=; b=eIJ3U+ruHMXCv19xGznQxLQTuXwtFKB1ZqgLJSZ3dQPZ3P/oNp7NUwRhLGd1jYsNbJWikO 1dp1ifekWiGDD4XQqNUU9/YAb0ot2h9yOi0+/iqzVByPqBAJdxv5f9umBKd8spTC+q4laN 0Y8umWNjT37zAtxkmXpHC4Tik7BqM8Y= Received: by twocubed.nippynetworks.com (sSMTP sendmail emulation); Mon, 21 Sep 2020 22:59:44 +0100 From: Ed Wildgoose To: linux-kernel@vger.kernel.org Cc: fe@dev.tdt.de, Ed Wildgoose , "Enrico Weigelt, metux IT consult" , Darren Hart , Andy Shevchenko , platform-driver-x86@vger.kernel.org Subject: [PATCH 1/2] x86: Remove led/gpio setup from pcengines platform driver Date: Mon, 21 Sep 2020 22:59:18 +0100 Message-Id: <20200921215919.3072-1-lists@wildgooses.com> X-Mailer: git-send-email 2.26.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The pcengines bios/firmware includes ACPI tables (since 4.10.0.1) which will cause the kernel to automatically create led + gpio_key devices for the platform. This means that the platform setup now creates duplicates of all these led/key devices. Anyone with a much older bios can use the 'leds-apu' driver to get the same set of led devices as created by the kernel with a modern bios. Signed-off-by: Ed Wildgoose --- drivers/platform/x86/pcengines-apuv2.c | 76 +------------------------- 1 file changed, 1 insertion(+), 75 deletions(-) diff --git a/drivers/platform/x86/pcengines-apuv2.c b/drivers/platform/x86/pcengines-apuv2.c index c37349f97..41e3005cd 100644 --- a/drivers/platform/x86/pcengines-apuv2.c +++ b/drivers/platform/x86/pcengines-apuv2.c @@ -72,60 +72,6 @@ static const struct amd_fch_gpio_pdata board_apu2 = { .gpio_names = apu2_gpio_names, }; -/* GPIO LEDs device */ - -static const struct gpio_led apu2_leds[] = { - { .name = "apu:green:1" }, - { .name = "apu:green:2" }, - { .name = "apu:green:3" }, -}; - -static const struct gpio_led_platform_data apu2_leds_pdata = { - .num_leds = ARRAY_SIZE(apu2_leds), - .leds = apu2_leds, -}; - -static struct gpiod_lookup_table gpios_led_table = { - .dev_id = "leds-gpio", - .table = { - GPIO_LOOKUP_IDX(AMD_FCH_GPIO_DRIVER_NAME, APU2_GPIO_LINE_LED1, - NULL, 0, GPIO_ACTIVE_LOW), - GPIO_LOOKUP_IDX(AMD_FCH_GPIO_DRIVER_NAME, APU2_GPIO_LINE_LED2, - NULL, 1, GPIO_ACTIVE_LOW), - GPIO_LOOKUP_IDX(AMD_FCH_GPIO_DRIVER_NAME, APU2_GPIO_LINE_LED3, - NULL, 2, GPIO_ACTIVE_LOW), - } -}; - -/* GPIO keyboard device */ - -static struct gpio_keys_button apu2_keys_buttons[] = { - { - .code = KEY_RESTART, - .active_low = 1, - .desc = "front button", - .type = EV_KEY, - .debounce_interval = 10, - .value = 1, - }, -}; - -static const struct gpio_keys_platform_data apu2_keys_pdata = { - .buttons = apu2_keys_buttons, - .nbuttons = ARRAY_SIZE(apu2_keys_buttons), - .poll_interval = 100, - .rep = 0, - .name = "apu2-keys", -}; - -static struct gpiod_lookup_table gpios_key_table = { - .dev_id = "gpio-keys-polled", - .table = { - GPIO_LOOKUP_IDX(AMD_FCH_GPIO_DRIVER_NAME, APU2_GPIO_LINE_MODESW, - NULL, 0, GPIO_ACTIVE_LOW), - } -}; - /* Board setup */ /* Note: matching works on string prefix, so "apu2" must come before "apu" */ @@ -217,8 +163,6 @@ static const struct dmi_system_id apu_gpio_dmi_table[] __initconst = { }; static struct platform_device *apu_gpio_pdev; -static struct platform_device *apu_leds_pdev; -static struct platform_device *apu_keys_pdev; static struct platform_device * __init apu_create_pdev( const char *name, @@ -247,38 +191,20 @@ static int __init apu_board_init(void) id = dmi_first_match(apu_gpio_dmi_table); if (!id) { - pr_err("failed to detect APU board via DMI\n"); + pr_err("No APU board detected via DMI\n"); return -ENODEV; } - gpiod_add_lookup_table(&gpios_led_table); - gpiod_add_lookup_table(&gpios_key_table); - apu_gpio_pdev = apu_create_pdev( AMD_FCH_GPIO_DRIVER_NAME, id->driver_data, sizeof(struct amd_fch_gpio_pdata)); - apu_leds_pdev = apu_create_pdev( - "leds-gpio", - &apu2_leds_pdata, - sizeof(apu2_leds_pdata)); - - apu_keys_pdev = apu_create_pdev( - "gpio-keys-polled", - &apu2_keys_pdata, - sizeof(apu2_keys_pdata)); - return 0; } static void __exit apu_board_exit(void) { - gpiod_remove_lookup_table(&gpios_led_table); - gpiod_remove_lookup_table(&gpios_key_table); - - platform_device_unregister(apu_keys_pdev); - platform_device_unregister(apu_leds_pdev); platform_device_unregister(apu_gpio_pdev); } -- 2.26.2