Received: by 2002:a25:1104:0:0:0:0:0 with SMTP id 4csp63865ybr; Fri, 22 May 2020 00:46:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwJIED6JdCGPY2tVp5nTDDSJ328+E9Goa6rJP+i6GjVsd5iroIBiVe0xgiysV66uWiOmy6o X-Received: by 2002:a17:907:10c2:: with SMTP id rv2mr6745788ejb.536.1590133587907; Fri, 22 May 2020 00:46:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590133587; cv=none; d=google.com; s=arc-20160816; b=aujC678rtlH+I3a4hr20BhS3u9RNMQrWYT72OevXaR7IUht4laepEgLRbgcjTUh8Jt hACdUlbnYhQUsMUvZBE0JRj9P/JvrGH/FJOx4G+3BJ7mv8JA4CtXZLYFMZ3ghVa5n+vZ nO5Ffo2YUh2biEluUiS5zEa9vQnMn+fsjPLOh+jv3njq6O9HTG6xxCWIJyazUD2SU/CS YJQ+v7eT3n3IpovST2TsBJqRNnKhXwThEaTM67l2BPwbR/phvWWD0M3UrjSWmmoJzF1v m9GDEfURCa1gcRjrOkWgg3iDCCRKcUB3GsDwcfw1GAUlMBBFWHAWFy1cxLNCu9akq11V 0FmQ== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=yHgMp9qQi+PCJI/VBjHbC9Rf08TFR7c0CBHdT2/5bV8=; b=RBrg1RF8PsVY5n60veUlEmOVbYhrFeLsmYU2/LQT71lDIoHIpFTKWE6MCNxX8rcvuH vF48FfyNFjOg6/Arxu7EkppQ4eVFg4gl3hs6igFPve6QjzLW/wjsFHagpijOGeE3myWP FlT4YEHjeCHFzYdBXsB3goDaZMf7BL9GOL//Zxmo/289czDypn91AmR2bKhVx7vD7VCJ y949cvRQl3kYs6GoXcaqrtbv+njlxQypJiFtzdYZ/9CTrR0BJksAXctjQyHo8dmSxxG3 0+i9se5Yr3QeGlIWp/QZ79f/rowrkQSSmYXmxcnw95r81MACiTc49JGv8P1BnbEHfiDb aTow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@endlessm-com.20150623.gappssmtp.com header.s=20150623 header.b=ouxLLASB; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s23si4477842ejc.195.2020.05.22.00.46.04; Fri, 22 May 2020 00:46:27 -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=@endlessm-com.20150623.gappssmtp.com header.s=20150623 header.b=ouxLLASB; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728618AbgEVHoi (ORCPT + 99 others); Fri, 22 May 2020 03:44:38 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47298 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727839AbgEVHoi (ORCPT ); Fri, 22 May 2020 03:44:38 -0400 Received: from mail-pf1-x443.google.com (mail-pf1-x443.google.com [IPv6:2607:f8b0:4864:20::443]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2F327C061A0E for ; Fri, 22 May 2020 00:44:38 -0700 (PDT) Received: by mail-pf1-x443.google.com with SMTP id v63so4844416pfb.10 for ; Fri, 22 May 2020 00:44:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=endlessm-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=yHgMp9qQi+PCJI/VBjHbC9Rf08TFR7c0CBHdT2/5bV8=; b=ouxLLASBd4bC1FEvoSmxHBT4ntXgoOvhe1Vmj1CaZUox/4yxYs+fx9NnjHLu9Fex71 hAGT95zYoP2Zk2jgyTdZpy3P4nNBSJVB1McrscQxhBzQP43cZfZt1bC0P6S8HkCHDW8B ItpJXCQ88y8RYeq5kKkqaS7Ubcyf8KV5aCwRRbtAQcIxDlXOFT0GaVALi4c7RP3h5PTw H28ocn4QRtImLDwoQe40X48RBLSh+nP6yHtMWO/KeuBDgfqrodgD4DFMMrh8UB0G0wDX Jfp2aeEVyxtrPKA8eCIQSdDPz1hlP5/ZL93BasEVKuokjNrfMaC14jBpQmIT7yQ70wMh cl2Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=yHgMp9qQi+PCJI/VBjHbC9Rf08TFR7c0CBHdT2/5bV8=; b=T/NZjIXJKH1Dex2xOF6fx5NTQyBRqUQItHnDimZgs5j9ys1m80Dgp6FExAxfJWCmEe kbhqr8DcK5C4nX4xxIUwGqapad8ejruAFjw7yfhgASCra78gGQy+3priQjVHs7W+8JSZ jzkVZ8V9cMKqWtnNilQbOymUqxmDu/eEQP8HmHLzgHmWaDPSdEVj7PgTwXBh8s5JOAzB y/ZFZWQgD4hMI3wyF7Wn4m6KQm6/22GEQsDH2KGgm6TGbgTSv0aGDxkCOUOorLCw4RiR jCEZMRV6cBU9CKLUYJVDIBoklpsjbOUgQy6B/PzalScjzYIfSqtCaBhNosB0y70cUC/w TxTQ== X-Gm-Message-State: AOAM531s7U9xJtkuPzVDbceBjix9kW9S7cy3nr9YcU+jVg96iwl3pmbG X4psTPnN6I53rdn1NdhfELONRg== X-Received: by 2002:aa7:81d1:: with SMTP id c17mr2732212pfn.58.1590133477438; Fri, 22 May 2020 00:44:37 -0700 (PDT) Received: from localhost.localdomain (59-127-47-126.HINET-IP.hinet.net. [59.127.47.126]) by smtp.gmail.com with ESMTPSA id u45sm5826659pjb.7.2020.05.22.00.44.35 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Fri, 22 May 2020 00:44:37 -0700 (PDT) From: Chris Chiu To: dvhart@infradead.org, andy@infradead.org, hdegoede@redhat.com, gregkh@linuxfoundation.org, gayatri.kammela@intel.com, mika.westerberg@linux.intel.com Cc: platform-driver-x86@vger.kernel.org, linux-kernel@vger.kernel.org, linux@endlessm.com, Chris Chiu Subject: [PATCH] platform/x86: asus_wmi: Reserve more space for struct bias_args Date: Fri, 22 May 2020 15:44:24 +0800 Message-Id: <20200522074424.54264-1-chiu@endlessm.com> X-Mailer: git-send-email 2.21.1 (Apple Git-122.3) MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On the ASUS laptop UX325JA/UX425JA, most of the media keys are not working due to the ASUS WMI driver fails to be loaded. The ACPI error as follows leads to the failure of asus_wmi_evaluate_method. ACPI BIOS Error (bug): AE_AML_BUFFER_LIMIT, Field [IIA3] at bit offset/length 96/32 exceeds size of target Buffer (96 bits) (20200326/dsopcode-203) No Local Variables are initialized for Method [WMNB] ACPI Error: Aborting method \_SB.ATKD.WMNB due to previous error (AE_AML_BUFFER_LIMIT) (20200326/psparse-531) The DSDT for the WMNB part shows that 5 DWORD required for local variables and the 3rd variable IIA3 hit the buffer limit. Method (WMNB, 3, Serialized) { .. CreateDWordField (Arg2, Zero, IIA0) CreateDWordField (Arg2, 0x04, IIA1) CreateDWordField (Arg2, 0x08, IIA2) CreateDWordField (Arg2, 0x0C, IIA3) CreateDWordField (Arg2, 0x10, IIA4) Local0 = (Arg1 & 0xFFFFFFFF) If ((Local0 == 0x54494E49)) .. } The limitation is determined by the input acpi_buffer size passed to the wmi_evaluate_method. Since the struct bios_args is the data structure used as input buffer by default for all ASUS WMI calls, the size needs to be expanded to fix the problem. Signed-off-by: Chris Chiu --- drivers/platform/x86/asus-wmi.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/drivers/platform/x86/asus-wmi.c b/drivers/platform/x86/asus-wmi.c index bb7c529d7d16..cd212ee210e2 100644 --- a/drivers/platform/x86/asus-wmi.c +++ b/drivers/platform/x86/asus-wmi.c @@ -116,6 +116,8 @@ struct bios_args { u32 arg0; u32 arg1; u32 arg2; /* At least TUF Gaming series uses 3 dword input buffer. */ + u32 arg4; + u32 arg5; } __packed; /* -- 2.25.2