Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2707315imu; Sun, 27 Jan 2019 11:04:32 -0800 (PST) X-Google-Smtp-Source: ALg8bN5+xSqNXDAYbJQl4CmJmO7tEs8/Vr0qZXEMAknPJVgtkrbXSdWZ3jdQ5cdYfkvyrOgfylpb X-Received: by 2002:a63:3e05:: with SMTP id l5mr10013637pga.96.1548615872612; Sun, 27 Jan 2019 11:04:32 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1548615872; cv=none; d=google.com; s=arc-20160816; b=cFkPn0EAhRJWDqGfUILu66gz9qJOvJr+E0YpFI49fnZZSuB5ji99xYrXa4s5Rq70vm uvdnVM9PMtTG5GZSIddmmEjTsyEJXfEZvcrYvH9XW1sW4WiWEDQ5c0AVSJV+LnH555GY XfTpqh5+l5uaGNYAg3j1Vnh54j0Q2CiY/8SRYBUipEUhuiTNCRxXLGO84IjZ9cAZ5FOz bz+/r/DjQsYT1w6K2FeQdPKciMDUiSPd1PoPNQM+3QYYEtJ0d7fXAQDhB5B6EXRljwvJ soloL6/wvebiqr1VYYf/CfRwRKDPj2dwcm+s6w4tDAeWNooOFkGs4GG/aAKOvaWCCKiW my8A== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=yPB770F+mT+Mx3RJXKzAZEPiYBbCJmTo4EAT/ui8Jrw=; b=FLv/giKmSkKLZsK4AF57stilVSSBoPMNeWd8LQwVtbKJSxDs/BDt28nRrehXvD7x4d iLCbDZL1L/2L8Aac6UR9195MBgaLL9LL6oQs+o0VK5MJTR2QQF0LoovHX+g8fl3OAEMP NwyvFwTjNwj3ck4iCNOtZvtgUT9bVPVblLTjhvpkgjj+dRkiaQMTz14eS4c5Wht8bTT8 sYcpirenpRAMYN3SuHqfsJl5LroJO90qOBuMHrZ8wiXHc7YmssqkaGLHrTLO3wZqMm87 N/aO1FF2e3PDgTflDHzykRj4yEatCOg4kFSK5ajt5ErNICCIyXBj4GdKVSTFKUHwMf8j KLlA== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mok.nu Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j11si49466plb.253.2019.01.27.11.04.17; Sun, 27 Jan 2019 11:04:32 -0800 (PST) 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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=mok.nu Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727040AbfA0TEK (ORCPT + 99 others); Sun, 27 Jan 2019 14:04:10 -0500 Received: from proxy04.fsdata.se ([89.221.252.227]:33575 "EHLO mail-gw01.fsdata.se" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726630AbfA0TEK (ORCPT ); Sun, 27 Jan 2019 14:04:10 -0500 Received: from localhost (94.234.44.129) by DAG01.HMC.local (192.168.46.11) with Microsoft SMTP Server (TLS) id 15.0.1263.5; Sun, 27 Jan 2019 20:03:58 +0100 From: Mattias Jacobsson <2pi@mok.nu> To: , , , , CC: <2pi@mok.nu>, , Subject: [PATCH v2 2/3] platform/x86: wmi: add WMI support to MODULE_DEVICE_TABLE() Date: Sun, 27 Jan 2019 20:03:28 +0100 Message-ID: <680df320c7263bdd35f87794ae12fb9a9ef3b71c.1548610407.git.2pi@mok.nu> X-Mailer: git-send-email 2.20.1 In-Reply-To: References: MIME-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 8bit X-Originating-IP: [94.234.44.129] X-ClientProxiedBy: PROXY04.HMC.local (192.168.46.54) To DAG01.HMC.local (192.168.46.11) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The kernel provides the macro MODULE_DEVICE_TABLE() where driver authors can specify their device type and their array of device_ids and thereby trigger the generation of the appropriate MODULE_ALIAS() output. This is opposed to having to specify one MODULE_ALIAS() for each device. The WMI device type is currently not supported. While using MODULE_DEVICE_TABLE() does increase the complexity as well as spreading out the implementation across the kernel, it does come with some benefits too; * It makes different drivers look more similar; if you can specify the array of device_ids any device type specific input to MODULE_ALIAS() will automatically be generated for you. * It helps each driver avoid keeping multiple versions of the same information in sync. That is, both the array of device_ids and the potential multitude of MODULE_ALIAS()'s. Add WMI support to MODULE_DEVICE_TABLE() by adding info about struct wmi_device_id in devicetable-offsets.c and add a WMI entry point in file2alias.c. The type argument for MODULE_DEVICE_TABLE(type, name) is wmi. Suggested-by: Pali Rohár Signed-off-by: Mattias Jacobsson <2pi@mok.nu> --- scripts/mod/devicetable-offsets.c | 3 +++ scripts/mod/file2alias.c | 18 ++++++++++++++++++ 2 files changed, 21 insertions(+) diff --git a/scripts/mod/devicetable-offsets.c b/scripts/mod/devicetable-offsets.c index 293004499b4d..99276a422e77 100644 --- a/scripts/mod/devicetable-offsets.c +++ b/scripts/mod/devicetable-offsets.c @@ -225,5 +225,8 @@ int main(void) DEVID_FIELD(typec_device_id, svid); DEVID_FIELD(typec_device_id, mode); + DEVID(wmi_device_id); + DEVID_FIELD(wmi_device_id, guid_string); + return 0; } diff --git a/scripts/mod/file2alias.c b/scripts/mod/file2alias.c index a37af7d71973..f014a2466ff7 100644 --- a/scripts/mod/file2alias.c +++ b/scripts/mod/file2alias.c @@ -1287,6 +1287,23 @@ static int do_typec_entry(const char *filename, void *symval, char *alias) return 1; } +/* Looks like: wmi:guid */ +static int do_wmi_entry(const char *filename, void *symval, char *alias) +{ + DEF_FIELD_ADDR(symval, wmi_device_id, guid_string); + if (strlen(*guid_string) != WMI_GUID_STRING_LEN) { + warn("Invalid WMI device id 'wmi:%s' in '%s'\n", + *guid_string, filename); + return 0; + } + if (snprintf(alias, 500, WMI_MODULE_PREFIX "%s", *guid_string) < 0) { + warn("Could not generate all MODULE_ALIAS's in '%s'\n", + filename); + return 0; + } + return 1; +} + /* Does namelen bytes of name exactly match the symbol? */ static bool sym_is(const char *name, unsigned namelen, const char *symbol) { @@ -1357,6 +1374,7 @@ static const struct devtable devtable[] = { {"fslmc", SIZE_fsl_mc_device_id, do_fsl_mc_entry}, {"tbsvc", SIZE_tb_service_id, do_tbsvc_entry}, {"typec", SIZE_typec_device_id, do_typec_entry}, + {"wmi", SIZE_wmi_device_id, do_wmi_entry}, }; /* Create MODULE_ALIAS() statements. -- 2.20.1