Received: by 2002:a05:7412:419a:b0:f3:1519:9f41 with SMTP id i26csp3516951rdh; Mon, 27 Nov 2023 16:58:07 -0800 (PST) X-Google-Smtp-Source: AGHT+IGRr87lj5HxV8rHhrersErEegvXBRklnBhD5X/DZ/LKi6n6ZOT46oqCrEjiVRcmzZVBBcsX X-Received: by 2002:a17:903:643:b0:1cf:6453:b23a with SMTP id kh3-20020a170903064300b001cf6453b23amr10413957plb.53.1701133086744; Mon, 27 Nov 2023 16:58:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701133086; cv=none; d=google.com; s=arc-20160816; b=d3JCE34NFDfbkUbNE0aSVQFoShSfBDnw5Q+puWXw663Jh+4of5bckvr+em4QGgl8mq Q7tDNlYyVx+53Rm+QI+f8qlX+FBpwiAoOpTGslEUATTDm2uFV7cEtmxYC69EbLq2Srj8 5fXIKOF5CjW9GMJvsxuP+zScMghiKpH3ImTv/ZWHRlti3EfAdptxTBkYQb0w5owcHLPG +wcS9mqzcuscu6Tgmq6bD4NbFNS6eniTn+oVDExX1Q9yDI3/UlvbNYXR251YLM77h9i/ nVzST+sawLI3xFRtdH9FBEch1WAFtRSusNPEQDBC2OWqIplxllHQ1dXfegXskj+2ucaY nO0w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :cc:to:subject:from:date:feedback-id:dkim-signature:dkim-signature; bh=cSxFe317qFdV/Hi2j4HY7ZnvHkNMT7ieNvLCr1dClkM=; fh=Hel3wXSVto0lUb6+dXsl310mQtkadPt0tgrbj04hCcA=; b=KtUyFk0InQyrhM2RRRQI/72ftBPoJwyT3AOBiaww2FdsK81Mg+1IMV/tw1SA/W4z19 YIaZCuPpoh8HaH62lnpqS+aCzmm16OqxUMSSSEx6M7ankXL4cvtsTnOnfpEBv2v17f72 U88Sq2IaK3/Yoogrc5Jcht+qdcUb83dCTCFueugyfApQ6D1vD+SE0h+sjoVLAXbtW1Kb JdiHdniVGHaQqjK8LaIeJeBF7Xl3Vv1e7UdP4AXbzJQPS3rhxb7hLU8xW2kwecEV90Gg kUwCC78XTGok6X5FZMVdMHQsVak0SOC8PZ5Le+YNUlcmdnZjHVdEZUsn8FGDE5D/lmDy EUzQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ljones.dev header.s=fm2 header.b="nhjkYMh/"; dkim=pass header.i=@messagingengine.com header.s=fm1 header.b=ZLk2klnH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from snail.vger.email (snail.vger.email. [23.128.96.37]) by mx.google.com with ESMTPS id z1-20020a170902708100b001cfd5046486si2457865plk.181.2023.11.27.16.58.06 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 27 Nov 2023 16:58:06 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) client-ip=23.128.96.37; Authentication-Results: mx.google.com; dkim=pass header.i=@ljones.dev header.s=fm2 header.b="nhjkYMh/"; dkim=pass header.i=@messagingengine.com header.s=fm1 header.b=ZLk2klnH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.37 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by snail.vger.email (Postfix) with ESMTP id 6AEB480A7E65; Mon, 27 Nov 2023 16:58:05 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at snail.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231602AbjK1A5z (ORCPT + 99 others); Mon, 27 Nov 2023 19:57:55 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56938 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229488AbjK1A5y (ORCPT ); Mon, 27 Nov 2023 19:57:54 -0500 Received: from out1-smtp.messagingengine.com (out1-smtp.messagingengine.com [66.111.4.25]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A28C21B8; Mon, 27 Nov 2023 16:58:00 -0800 (PST) Received: from compute7.internal (compute7.nyi.internal [10.202.2.48]) by mailout.nyi.internal (Postfix) with ESMTP id 1A4EC5C029C; Mon, 27 Nov 2023 19:58:00 -0500 (EST) Received: from mailfrontend1 ([10.202.2.162]) by compute7.internal (MEProxy); Mon, 27 Nov 2023 19:58:00 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ljones.dev; h=cc :cc:content-type:content-type:date:date:from:from:in-reply-to :in-reply-to:message-id:mime-version:references:reply-to:sender :subject:subject:to:to; s=fm2; t=1701133080; x=1701219480; bh=cS xFe317qFdV/Hi2j4HY7ZnvHkNMT7ieNvLCr1dClkM=; b=nhjkYMh/yXxhogb/4E yLT7TtmGC7lpvRzNHCClwamGvjeB7sO0ZEFMCq5k3Zq7CrBKrLPf7RjDVGQF1dxS cyK4cjMJ4vJ0qoq0vOj9iDGFZMBj+qfyq0UGjpCuBxwQuTjsIGHIvSByamkYM5ao TMhJ4+cBnoXKDf+sbKDkjfyNrCg831vN5wOFmK9s7V4QDi1H7kOn/gBaNqaEl/pN vuAvfkPUHq4xJJg9TOLE0iMbJTa61Uw+bgy4WcopJKpCQAqPl952nXqQ91j1KWY0 soZTjK8BkO094j0XsPZFNTz6Y7SxBCV//h8BZ4MHBUOwugLb+nwsO+ycj1fiDEHm ICow== DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d= messagingengine.com; h=cc:cc:content-type:content-type:date:date :feedback-id:feedback-id:from:from:in-reply-to:in-reply-to :message-id:mime-version:references:reply-to:sender:subject :subject:to:to:x-me-proxy:x-me-proxy:x-me-sender:x-me-sender :x-sasl-enc; s=fm1; t=1701133080; x=1701219480; bh=cSxFe317qFdV/ Hi2j4HY7ZnvHkNMT7ieNvLCr1dClkM=; b=ZLk2klnHY6P0JZ3mioWdcdhTGoiLA UCpkllFKVAlsXwrQTDwk11r4Zzk7lLmq/KuA71wlcrBuBO6a5zmQNISor4r5IFnX miUbb5G7WkkalgCSmVQQ+iJ53GsuV8nSguGJRgOhTSSyodyxJXyO3Hs9ql4bAdHo p3aAQNUBI9fOrkcTQQNVmiI/6d3e7fjxi9TZBZSxoyjNFNt+tjsDMwpCDG7r7FBs gV1sbX1hPrEYb4GlV6QMvq8sq2oPqPJBUJyQWpBTCNseH4xRGpwt4S0jLrm/hI+s rlyCjwOreNdv3YjUCofX4NASKzRQX1GhftjEKixs7/4F3bf9cLcxUIJ2Q== X-ME-Sender: X-ME-Received: X-ME-Proxy-Cause: gggruggvucftvghtrhhoucdtuddrgedvkedrudeivddgvdekucetufdoteggodetrfdotf fvucfrrhhofhhilhgvmecuhfgrshhtofgrihhlpdfqfgfvpdfurfetoffkrfgpnffqhgen uceurghilhhouhhtmecufedttdenucesvcftvggtihhpihgvnhhtshculddquddttddmne cujfgurhepfffhuffvvefkjghfofggtgesthdtredtredtvdenucfhrhhomhepnfhukhgv ucflohhnvghsuceolhhukhgvsehljhhonhgvshdruggvvheqnecuggftrfgrthhtvghrnh ephfeigedtveefjeeukeetfeektdeffeefteekfeffieeiteeigeehhfdutdeitdehnecu ffhomhgrihhnpehkvghrnhgvlhdrohhrghenucevlhhushhtvghrufhiiigvpedtnecurf grrhgrmhepmhgrihhlfhhrohhmpehluhhkvgeslhhjohhnvghsrdguvghv X-ME-Proxy: Feedback-ID: i5ec1447f:Fastmail Received: by mail.messagingengine.com (Postfix) with ESMTPA; Mon, 27 Nov 2023 19:57:56 -0500 (EST) Date: Tue, 28 Nov 2023 13:57:42 +1300 From: Luke Jones Subject: Re: [PATCH v2 1/1] platform/x86: asus-wmi: disable USB0 hub on ROG Ally before suspend To: Hans de Goede Cc: ilpo.jarvinen@linux.intel.com, corentin.chary@gmail.com, platform-driver-x86@vger.kernel.org, linux-kernel@vger.kernel.org Message-Id: <6O6T4S.WF73A40XF38P@ljones.dev> In-Reply-To: References: <20231126230521.125708-1-luke@ljones.dev> <20231126230521.125708-2-luke@ljones.dev> <1c5f3bd2-9f10-4e5d-8c6d-76441b2da850@redhat.com> X-Mailer: geary/44.1 MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii; format=flowed X-Spam-Status: No, score=-2.8 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_LOW, RCVD_IN_MSPIKE_H3,RCVD_IN_MSPIKE_WL,SPF_HELO_PASS,SPF_NONE, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (snail.vger.email [0.0.0.0]); Mon, 27 Nov 2023 16:58:05 -0800 (PST) On Mon, Nov 27 2023 at 11:39:09 PM +01:00:00, Hans de Goede wrote: > Hi, > > On 11/27/23 21:17, Luke Jones wrote: >> >> >> On Mon, Nov 27 2023 at 09:53:13 AM +01:00:00, Hans de Goede >> wrote: >>> Hi, >>> >>> On 11/27/23 00:05, Luke D. Jones wrote: >>>> ASUS have worked around an issue in XInput where it doesn't >>>> support USB >>>> selective suspend, which causes suspend issues in Windows. They >>>> worked >>>> around this by adjusting the MCU firmware to disable the USB0 >>>> hub when >>>> the screen is switched off during the Microsoft DSM suspend path >>>> in ACPI. >>>> >>>> The issue we have with this however is one of timing - the call >>>> the tells >>>> the MCU to this isn't able to complete before suspend is done so >>>> we call >>>> this in a prepare() and add a small msleep() to ensure it is >>>> done. This >>>> must be done before the screen is switched off to prevent a >>>> variety of >>>> possible races. >>>> >>>> Further to this the MCU powersave option must also be disabled >>>> as it can >>>> cause a number of issues such as: >>>> - unreliable resume connection of N-Key >>>> - complete loss of N-Key if the power is plugged in while >>>> suspended >>>> Disabling the powersave option prevents this. >>>> >>>> Without this the MCU is unable to initialise itself correctly on >>>> resume. >>>> >>>> Signed-off-by: Luke D. Jones >>> >>> Thanks, patch looks good to me, except that all the new lines >>> seem to use 4 spaces rather then a tab char as indent. >> >> Apologies for the previous HTML email. >> I must be going mad... are you sure? I've checked the patch file I >> submitted. Run checkpatch on it. Checked my email copy, and checked >> in lore... I can't see where space chars are? > > So I just checked the copy in patchwork: > > https://patchwork.kernel.org/project/platform-driver-x86/patch/20231126230521.125708-2-luke@ljones.dev/ > > and you are rights, no 4 spaces there. > > Where as if you look further down in this reply, where the original > patch is quoted the 4 spaces are right there, so now I'm wondering > if maybe my mail client introduced the problem when I was replying ? > > (replies to other patches preserve the tabs just fine). > > So this is weird, but lets just forget about it, just some weird > glitch ... > Sun flares and cosmic particles. I'm comfortable with this being merged and doing through stable also. I did many many more tests this morning, along with a half dozen other people and this solution appears to be the only reliable option. When ASUS provide a way to turn off the MCU unplug feature I will update with a new patch (and add the TODO). > > > >> >>> >>> With that fixed you can add my: >>> >>> Reviewed-by: Hans de Goede >>> >>> to the next version. >>> >>> Regards, >>> >>> Hans >>> >>> >>>> --- >>>> drivers/platform/x86/asus-wmi.c | 50 >>>> ++++++++++++++++++++++ >>>> include/linux/platform_data/x86/asus-wmi.h | 3 ++ >>>> 2 files changed, 53 insertions(+) >>>> >>>> diff --git a/drivers/platform/x86/asus-wmi.c >>>> b/drivers/platform/x86/asus-wmi.c >>>> index 6a79f16233ab..4ba33dfebfd4 100644 >>>> --- a/drivers/platform/x86/asus-wmi.c >>>> +++ b/drivers/platform/x86/asus-wmi.c >>>> @@ -16,6 +16,7 @@ >>>> #include >>>> #include >>>> #include >>>> +#include >>>> #include >>>> #include >>>> #include >>>> @@ -132,6 +133,11 @@ module_param(fnlock_default, bool, 0444); >>>> #define ASUS_SCREENPAD_BRIGHT_MAX 255 >>>> #define ASUS_SCREENPAD_BRIGHT_DEFAULT 60 >>>> >>>> +/* Controls the power state of the USB0 hub on ROG Ally which >>>> input is on */ >>>> +#define ASUS_USB0_PWR_EC0_CSEE "\\_SB.PCI0.SBRG.EC0.CSEE" >>>> +/* 300ms so far seems to produce a reliable result on AC and >>>> battery */ >>>> +#define ASUS_USB0_PWR_EC0_CSEE_WAIT 300 >>>> + >>>> static const char * const ashs_ids[] = { "ATK4001", "ATK4002", >>>> NULL }; >>>> >>>> static int throttle_thermal_policy_write(struct asus_wmi *); >>>> @@ -300,6 +306,9 @@ struct asus_wmi { >>>> >>>> bool fnlock_locked; >>>> >>>> + /* The ROG Ally device requires the MCU USB device be >>>> disconnected before suspend */ >>>> + bool ally_mcu_usb_switch; >>>> + >>>> struct asus_wmi_debug debug; >>>> >>>> struct asus_wmi_driver *driver; >>>> @@ -4488,6 +4497,8 @@ static int asus_wmi_add(struct >>>> platform_device *pdev) >>>> asus->nv_temp_tgt_available = asus_wmi_dev_is_present(asus, >>>> ASUS_WMI_DEVID_NV_THERM_TARGET); >>>> asus->panel_overdrive_available = >>>> asus_wmi_dev_is_present(asus, ASUS_WMI_DEVID_PANEL_OD); >>>> asus->mini_led_mode_available = >>>> asus_wmi_dev_is_present(asus, ASUS_WMI_DEVID_MINI_LED_MODE); >>>> + asus->ally_mcu_usb_switch = acpi_has_method(NULL, >>>> ASUS_USB0_PWR_EC0_CSEE) >>>> + && dmi_match(DMI_BOARD_NAME, "RC71L"); >>>> >>>> err = fan_boost_mode_check_present(asus); >>>> if (err) >>>> @@ -4654,6 +4665,43 @@ static int asus_hotk_resume(struct device >>>> *device) >>>> asus_wmi_fnlock_update(asus); >>>> >>>> asus_wmi_tablet_mode_get_state(asus); >>>> + >>>> + return 0; >>>> +} >>>> + >>>> +static int asus_hotk_resume_early(struct device *device) >>>> +{ >>>> + struct asus_wmi *asus = dev_get_drvdata(device); >>>> + >>>> + if (asus->ally_mcu_usb_switch) { >>>> + if (ACPI_FAILURE(acpi_execute_simple_method(NULL, >>>> ASUS_USB0_PWR_EC0_CSEE, 0xB8))) >>>> + dev_err(device, "ROG Ally MCU failed to connect USB >>>> dev\n"); >>>> + else >>>> + msleep(ASUS_USB0_PWR_EC0_CSEE_WAIT); >>>> + } >>>> + return 0; >>>> +} >>>> + >>>> +static int asus_hotk_prepare(struct device *device) >>>> +{ >>>> + struct asus_wmi *asus = dev_get_drvdata(device); >>>> + int result, err; >>>> + >>>> + if (asus->ally_mcu_usb_switch) { >>>> + /* When powersave is enabled it causes many issues with >>>> resume of USB hub */ >>>> + result = asus_wmi_get_devstate_simple(asus, >>>> ASUS_WMI_DEVID_MCU_POWERSAVE); >>>> + if (result == 1) { >>>> + dev_warn(device, "MCU powersave enabled, disabling >>>> to prevent resume issues"); >>>> + err = >>>> asus_wmi_set_devstate(ASUS_WMI_DEVID_MCU_POWERSAVE, 0, &result); >>>> + if (err || result != 1) >>>> + dev_err(device, "Failed to set MCU powersave >>>> mode: %d\n", err); >>>> + } >>>> + /* sleep required to ensure USB0 is disabled before >>>> sleep continues */ >>>> + if (ACPI_FAILURE(acpi_execute_simple_method(NULL, >>>> ASUS_USB0_PWR_EC0_CSEE, 0xB7))) >>>> + dev_err(device, "ROG Ally MCU failed to disconnect >>>> USB dev\n"); >>>> + else >>>> + msleep(ASUS_USB0_PWR_EC0_CSEE_WAIT); >>>> + } >>>> return 0; >>>> } >>>> >>>> @@ -4701,6 +4749,8 @@ static const struct dev_pm_ops asus_pm_ops >>>> = { >>>> .thaw = asus_hotk_thaw, >>>> .restore = asus_hotk_restore, >>>> .resume = asus_hotk_resume, >>>> + .resume_early = asus_hotk_resume_early, >>>> + .prepare = asus_hotk_prepare, >>>> }; >>>> >>>> /* Registration >>>> ***************************************************************/ >>>> diff --git a/include/linux/platform_data/x86/asus-wmi.h >>>> b/include/linux/platform_data/x86/asus-wmi.h >>>> index 63e630276499..ab1c7deff118 100644 >>>> --- a/include/linux/platform_data/x86/asus-wmi.h >>>> +++ b/include/linux/platform_data/x86/asus-wmi.h >>>> @@ -114,6 +114,9 @@ >>>> /* Charging mode - 1=Barrel, 2=USB */ >>>> #define ASUS_WMI_DEVID_CHARGE_MODE 0x0012006C >>>> >>>> +/* MCU powersave mode */ >>>> +#define ASUS_WMI_DEVID_MCU_POWERSAVE 0x001200E2 >>>> + >>>> /* epu is connected? 1 == true */ >>>> #define ASUS_WMI_DEVID_EGPU_CONNECTED 0x00090018 >>>> /* egpu on/off */ >>> >> >> >