Received: by 2002:a05:7412:bbc7:b0:fc:a2b0:25d7 with SMTP id kh7csp3320479rdb; Tue, 6 Feb 2024 14:05:32 -0800 (PST) X-Google-Smtp-Source: AGHT+IFMoRcyacbal5lzYBAeDLmaZvxHLiDnGCYad97EVwLT6UDvJ0S3pH2KdHXn7mqlAg/pwyvT X-Received: by 2002:aa7:d893:0:b0:55f:e543:b006 with SMTP id u19-20020aa7d893000000b0055fe543b006mr4331857edq.13.1707257131775; Tue, 06 Feb 2024 14:05:31 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1707257131; cv=pass; d=google.com; s=arc-20160816; b=Soas8L+DmgG7jjU7TwB6suZDt5+CHalfZ6P39K9m1viRQ1GAcSN+sttgbkHs/Wwp2Q txN1MyUhadf++V7VVR1hAKHcy35o7072/fGp7RM81fnhr0RPF+WyWA5jHGvqGa/uoVxi +F4VxMP97nJkB4kCFo83SWk3tE9eNalr53e6lQJa1P1ipN6Jf7PBFmIdTEcoU/z0+/FI PHf4eJwvedj9+FxJV6013LrnrJ6OoiavUVPX+nbt8OO0ZE2dcRjT/Y623Ler2udQPbj9 2GTadftzD2Rj+GSmLxZaIIQeFlI9qovfUtCdT5AdcsfLkWDxiqgar696uYsnvkedNvUA qI2A== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=ui-outboundreport:content-transfer-encoding:mime-version :list-unsubscribe:list-subscribe:list-id:precedence:references :in-reply-to:message-id:date:subject:cc:to:from:dkim-signature; bh=avjb5gExHtJqAzpWfzskifik3hQcyLBrZHuXVylDKgE=; fh=NYAR9qYQyF6Ks5KkQ/wHVR06PZEAIkKqnxyveUqXkn0=; b=vJ5WR07JALbFopjjL8Xfv4OiG5K42hxU9CUju8u3GCBVsL7pwzhO/iS1aPMxyZXOvZ 6Y0dWesDB5cQa1HijuPHzR20YcVLguKM1VZmBbn0RxVX1Yb0aEuznDfi+6aR0TalLDnh +H+luX3bpnArRFKYI7EiAdVa2Um4DCd3CHSURMglDfjPKe6Xa2K9PwiaHyJYcp8OeBG2 X1aeIphJVDxJahFRcgRaWJtk+K4jNqcuFFsDiVZNoLvhS00yVsMRUe8ZuP/fO70oex3W If20tEabC4yr9Xw4sMdX/lS5UAcCKjgDzg9bxU/W0uO8eJTJNRSPkbSePOAX8P0fzObE /moQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@gmx.de header.s=s31663417 header.b=R+CIzvPJ; arc=pass (i=1 spf=pass spfdomain=gmx.de dkim=pass dkdomain=gmx.de dmarc=pass fromdomain=gmx.de); spf=pass (google.com: domain of linux-kernel+bounces-55668-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-55668-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=gmx.de X-Forwarded-Encrypted: i=1; AJvYcCUImhvhgu8VISUPQfCzV8IY7roOzy9CHmok1/eyZc2hjzDJ0kpSi2EB6uAbfMsmcrqApvyVuuaOetqUSeGa6QAv/t3Tq1VR+azrAzJCOQ== Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [147.75.80.249]) by mx.google.com with ESMTPS id a26-20020a509b5a000000b00560c1de27cbsi500091edj.69.2024.02.06.14.05.31 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 06 Feb 2024 14:05:31 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-55668-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) client-ip=147.75.80.249; Authentication-Results: mx.google.com; dkim=pass header.i=@gmx.de header.s=s31663417 header.b=R+CIzvPJ; arc=pass (i=1 spf=pass spfdomain=gmx.de dkim=pass dkdomain=gmx.de dmarc=pass fromdomain=gmx.de); spf=pass (google.com: domain of linux-kernel+bounces-55668-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-55668-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=gmx.de Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id 84AB41F23B2F for ; Tue, 6 Feb 2024 22:05:31 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 9C3681C28F; Tue, 6 Feb 2024 22:05:13 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmx.de header.i=w_armin@gmx.de header.b="R+CIzvPJ" Received: from mout.gmx.net (mout.gmx.net [212.227.15.15]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 5AB111BC30; Tue, 6 Feb 2024 22:05:09 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=212.227.15.15 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1707257112; cv=none; b=E3u0lXqjoBvYiaicoiw3u0uzUCmnQV6qoPG+J7PnChB0sVlKNRPIu24e1GLUA7Wgi1/Pwes7Ybf0VyzQutxKzKh291/bZ62jGA75yLgE1/zD0SLtDa91xKYCAV0cmgHk6yiALpRqD5HxYspG+Wo0mIx80IwKFsZ4wSFKPpZnp+o= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1707257112; c=relaxed/simple; bh=YBOlzgKtDMyIfKshatb5mZPaRTlCvs+Ik0B0XiYSl0E=; h=From:To:Cc:Subject:Date:Message-Id:In-Reply-To:References: MIME-Version; b=cvdt6BZHm5e8PeEvY/sAzuxnOop+ar7yyVXydg2B7F/EEjdJQyj2QEOTd7U9xj0EYDDABhm43fEdK1ydYH1sYAMEaIaktnWwxDy0Sf7iOJcc1jhp00manr6NxM8tLgEQJH/wiOUoc/jSsbo2X+wPrSythML+uanAEaga3OrgKpE= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=gmx.de; spf=pass smtp.mailfrom=gmx.de; dkim=pass (2048-bit key) header.d=gmx.de header.i=w_armin@gmx.de header.b=R+CIzvPJ; arc=none smtp.client-ip=212.227.15.15 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=gmx.de Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmx.de DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=gmx.de; s=s31663417; t=1707257102; x=1707861902; i=w_armin@gmx.de; bh=YBOlzgKtDMyIfKshatb5mZPaRTlCvs+Ik0B0XiYSl0E=; h=X-UI-Sender-Class:From:To:Cc:Subject:Date:In-Reply-To: References; b=R+CIzvPJcnB6k0Ob/X3LYMzXw75VcSoB0fWXvwIWdAc9Ou8/lgk5SRnEozUmc0Ui WXguSi5ihsIb+JbzPPWJ5IXJpW4BSSDjcho2+0GtNb5eC5yEGiNf1QZDfsyPNWgFH Mlf0DZQxpNradPhLXpFSQXWRdnDSt8zX93qSWp+2g75v3Dibh03bgZqaaIweBzCeZ aXeWJ4dlqU2OB7KzMiavVhozySbNYNV7Epl2gsovE2R7F5WTa+08xOZ+MZVKCMkWe OsFxLeDD2zvAaWg8TO9DLa7FZqO5skCydOkQ0oVudCu0PrZGIT5KyMGrNPrfTBFNL B1l6W107z44OYWfpcw== X-UI-Sender-Class: 724b4f7f-cbec-4199-ad4e-598c01a50d3a Received: from mx-amd-b650.users.agdsn.de ([141.30.226.129]) by mail.gmx.net (mrgmx004 [212.227.17.190]) with ESMTPSA (Nemesis) id 1MdvmO-1qygm03PHS-00b6qU; Tue, 06 Feb 2024 23:05:02 +0100 From: Armin Wolf To: hdegoede@redhat.com, ilpo.jarvinen@linux.intel.com Cc: platform-driver-x86@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH 2/4] platform/x86: wmi: Use FW_BUG when warning about missing control methods Date: Tue, 6 Feb 2024 23:04:45 +0100 Message-Id: <20240206220447.3102-2-W_Armin@gmx.de> X-Mailer: git-send-email 2.39.2 In-Reply-To: <20240206220447.3102-1-W_Armin@gmx.de> References: <20240206220447.3102-1-W_Armin@gmx.de> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Provags-ID: V03:K1:xsnmaZxeuG9ddF4HDj+QsOlnZD4yimW1Y6akEJN8yys8VKBUiiI 4q5Z8t6yeou6Z0msdKhCTRMXG4w+XA/t4t493ZtU0HjS/OrPbxJru18+75IhojepYjCkE2U +J9v/bRTKZBVxZuPUDGTiFUhFAwId+gLi9lmDNEO9fkzbE3QKD7XNTm1MBf8nbv/6EcV8Gz cIGwF5jMym2UqMUfJbr0w== X-Spam-Flag: NO UI-OutboundReport: notjunk:1;M01:P0:d5RavgR5U4k=;pfOK4XPpO33tSCRC7M9m4bi9kFK rPrlyF25/eHhz8Sibr6/q/p4FL4rLAoRb2Le/YPGyelCJTxa5N9j/m+yQrKuE4JFiZ409d9JU e7cZA5FBc1ZdpKoeLSKs/pFVF75crO0Huhg5t1kBOjQrPTEl/22cXKp5jz7XMZM2aCc/wfwwa GdeWivrKymAC0pxigQ/jZWVB7Vf8qZSgLzKA1srEk8fasm72Jmr5KTDp787ydMRXH0/wfAAVi 5uXZg5RfHCm/SrOpPykmmaZvQVoCjdUqpBqUMdqR76tT4cYUtm1Uj/9pxgB0Gm2rV5/aXBefB SdFk3TLF1j1L2cW356JjIK9aq/39buWAa6qwn2h3ZAGABjsh4JtZ4obe3XEZMgXZdUsmEdKLv lBaHn6A76O60IO+5eXcFcU7pmzyGXlasYDGeMDyewl4pxF++eITb8OfSNCPmhVntM/zkTAjaX XNO1Ij5EA3GF/4oB7nbkf3Qdiu/6OaNf+zeawVn5mYd+hJU5YvDizQTfCp1cpeSQlH8R9w0sz L8oCAIHNzUa9p16VwQOCTJMcLOWgTyFt2uDBE7UtlOYfOWki5eH6ltKaLrUjJ6HHQDCNNA6h5 V4/wnkutuSf3qowmzP4Z11aQ8QWrlflRg74zqnVqRa7FZxwHU3B1YhLYlfEB4rGLPHayz7Gtf heyCtPqXv8tCWHNbwuAh50TNyObEJdikaly3GRVLtPVPs1M+WB6ZLNU9gMBX2WdwyYXXE2XdS 5A2kAsO4N0NYt/rXYuLsKraoxkh8KXsJalCWky2tTJm88G3GIk3volj4yU/T+cifwycLnNbXm SFxTNFax5DgWMagXUV20LKr6O5L5NHRKz0Tvt2+nK7Ask= A missing WQxx control method is a firmware bug and should be marked as such using FW_BUG so that users know that the issue is not a kernel issue. Since get_subobj_info() might fail even if the control method is present, we need to print the warning only if acpi_get_handle() fails. Signed-off-by: Armin Wolf =2D-- drivers/platform/x86/wmi.c | 39 ++++++++++++-------------------------- 1 file changed, 12 insertions(+), 27 deletions(-) diff --git a/drivers/platform/x86/wmi.c b/drivers/platform/x86/wmi.c index 9d544c85e5a8..545d6696d7cb 100644 =2D-- a/drivers/platform/x86/wmi.c +++ b/drivers/platform/x86/wmi.c @@ -132,26 +132,6 @@ static const void *find_guid_context(struct wmi_block= *wblock, return NULL; } -static int get_subobj_info(acpi_handle handle, const char *pathname, - struct acpi_device_info **info) -{ - acpi_handle subobj_handle; - acpi_status status; - - status =3D acpi_get_handle(handle, pathname, &subobj_handle); - if (status =3D=3D AE_NOT_FOUND) - return -ENOENT; - - if (ACPI_FAILURE(status)) - return -EIO; - - status =3D acpi_get_object_info(subobj_handle, info); - if (ACPI_FAILURE(status)) - return -EIO; - - return 0; -} - static acpi_status wmi_method_enable(struct wmi_block *wblock, bool enabl= e) { struct guid_block *block; @@ -979,9 +959,10 @@ static int wmi_create_device(struct device *wmi_bus_d= ev, struct wmi_block *wblock, struct acpi_device *device) { - struct acpi_device_info *info; char method[WMI_ACPI_METHOD_NAME_SIZE]; - int result; + struct acpi_device_info *info; + acpi_handle method_handle; + acpi_status status; uint count; if (wblock->gblock.flags & ACPI_WMI_EVENT) { @@ -1009,15 +990,19 @@ static int wmi_create_device(struct device *wmi_bus= _dev, * we ignore this data block. */ get_acpi_method_name(wblock, 'Q', method); - result =3D get_subobj_info(device->handle, method, &info); - - if (result) { + status =3D acpi_get_handle(device->handle, method, &method_handle); + if (ACPI_FAILURE(status)) { dev_warn(wmi_bus_dev, - "%s data block query control method not found\n", + FW_BUG "%s data block query control method not found\n", method); - return result; + + return -ENXIO; } + status =3D acpi_get_object_info(method_handle, &info); + if (ACPI_FAILURE(status)) + return -EIO; + wblock->dev.dev.type =3D &wmi_type_data; /* =2D- 2.39.2