From nobody Mon Jun 8 06:38:20 2026 Received: from AM0PR83CU005.outbound.protection.outlook.com (mail-westeuropeazon11010060.outbound.protection.outlook.com [52.101.69.60]) (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 60BBC37CD32; Wed, 3 Jun 2026 05:34:21 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.69.60 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780464865; cv=fail; b=thcyMUp7AfQo+bbVP9MQxdICVsDqqcqBZZCz/83xvA2PVjnVjYHb0zdaY5WQks0SnbkIroNtULW8XZyIDf/bifqWkKtFBpx5DzeNprgFasFBMhdd+vObcN1OKrL5XfivDnjkssxSgWJNy1OVs14VDr0jYZDyJ/cCM3KqrRp6C0M= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780464865; c=relaxed/simple; bh=MH2mrFIkxStXxbTW33GqDqt1eq++h0baSrnWbjkqvfc=; h=From:Date:Subject:Content-Type:Message-Id:References:In-Reply-To: To:Cc:MIME-Version; b=aZrWYv17h7Di44A/xVmDZDGfSKe2VBgEc+gBv6KFgISKgmC7e1DOxPtMYLrcLUGZqOkRkntzAcMhmds/md3Zb4eMbgbjLQBYTWD8AtN0GTti1vj9FdrfMl3Gr8kMrv28QC8iUFVuofVST6YSek7qAAP2GQB+xvcHlOolKhJTcAA= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oss.nxp.com; spf=pass smtp.mailfrom=oss.nxp.com; dkim=pass (2048-bit key) header.d=NXP1.onmicrosoft.com header.i=@NXP1.onmicrosoft.com header.b=AZSB9w14; arc=fail smtp.client-ip=52.101.69.60 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oss.nxp.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.nxp.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=NXP1.onmicrosoft.com header.i=@NXP1.onmicrosoft.com header.b="AZSB9w14" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=hWFUB6c3PwXtEBB7+UC7jpSelPt2/yqm/VGQf34NCUbn9dryjnDkOUHEzD9GcMQZrcAcPy2c/KW31WCk+YOX65trMD5+k49QwRmlOptjTbnVeMFeFxzEn1b10IQk7HSAd0ba3xOfeajpWxc/I2URzuvaFsvmWCeeIF6ypfwJNEQe8bWXtf7Moui1V0VQuEcqtUVygphv4nSckCxQaUasgKKk7xOTBDkNGU/jWP2mzB+IADIj06MshlkKWQjbabPHx2qz4Yw/jSnuwYNiLOAh1aM8zfO1hEuA+7PVuHNyHTsVZc/oxICDC9g4/AjBeWkGG/mtVTjTVevutKvZ8xDoHQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=8NuiGbCBdeysNfrDec3PeO6dHqHxhRMOZo7mPAwvgA0=; b=iK0BPm0hixBPcCBWCKwagEEYlVNkCuBWQK9SurzPJAGViKMiP66oMELuoW4NRY4bs85KILsTpVAVDSa352WFxIjNixPHyZ+ajfr+PI5MuWHdhMGDFzAaqCW4lNNlTuwduIoXYaH4qxHyz6Cbhpr5TQ8PuWMBHhCarumzGLbJeATlzQcHnvv4+2FJ06i1ELXjKPYVoHTpQIbV/1KK9HSeiJMZneM+T94A4cMtk3TzUF8xBZfyox7+w73pBH5Wt41MmDn/K8nV5aOiB7fci/3NQd0zFJdPe2Rj/dVqglbPOpnA/936LvpLlBjrFu3Zra9T7fQeYRSK3cO8hbXbcytO5w== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=oss.nxp.com; dmarc=pass action=none header.from=oss.nxp.com; dkim=pass header.d=oss.nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=NXP1.onmicrosoft.com; s=selector1-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=8NuiGbCBdeysNfrDec3PeO6dHqHxhRMOZo7mPAwvgA0=; b=AZSB9w14RdTqxTBnDCIUTLg41IfBZamxbuennoh7ZW6nXUp007A1GokxZHc4P8wiGJTcGseBZuP/SKxNaKqf90a3Fjirj8Mc9zPn7RA/phjfetB+1VcZ1XUZwBUUdzbnEs9XfIWxwgieI3ofz+7/JaoSca5gd/k9/60oqd89Hogvuw/C7ullx55IwG/xkfDAKYPUqsRXqEmMvvs544uXaOcgSoXdWBEYZKALNVbjw5DXdW/hdCBwo5MuVDQ/8dO/cfuSSKcomixXeDvaRHcaNlUr1uP4ssQa3Qc47cPIos8Hi8YbdpDH0joAAvmfTOznMpxjm28ArdQ9Kmx3we5FXA== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=oss.nxp.com; Received: from PAXPR04MB9422.eurprd04.prod.outlook.com (2603:10a6:102:2b4::21) by AS8PR04MB8150.eurprd04.prod.outlook.com (2603:10a6:20b:3f0::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.92.7; Wed, 3 Jun 2026 05:34:19 +0000 Received: from PAXPR04MB9422.eurprd04.prod.outlook.com ([fe80::54e:28bf:aa85:d25d]) by PAXPR04MB9422.eurprd04.prod.outlook.com ([fe80::54e:28bf:aa85:d25d%4]) with mapi id 15.21.0071.015; Wed, 3 Jun 2026 05:34:19 +0000 From: Xu Yang Date: Wed, 03 Jun 2026 13:37:14 +0800 Subject: [PATCH v3 1/5] phy: fsl-imx8mq-usb: fix typec switch leak on probe error path Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20260603-imx8mp-usb-phy-improvement-v3-1-7afb8f89abc6@nxp.com> References: <20260603-imx8mp-usb-phy-improvement-v3-0-7afb8f89abc6@nxp.com> In-Reply-To: <20260603-imx8mp-usb-phy-improvement-v3-0-7afb8f89abc6@nxp.com> To: Vinod Koul , Neil Armstrong , Frank Li , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam , Jun Li Cc: linux-phy@lists.infradead.org, imx@lists.linux.dev, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Felix Gu , stable@vger.kernel.org, Xu Yang X-Mailer: b4 0.15.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1780465041; l=2836; i=xu.yang_2@nxp.com; s=20250815; h=from:subject:message-id; bh=F5tZWwCCXccCYGGdg/r8AVNlU/mFAd4meggsWHjIQ9k=; b=TFYxtgT5dWTbBBvt1eU0sUT7e80uaTC2SM5bG05rZM9Usa4FVaXdOuKnfpQhge7ESe/IC72O0 h7XQuFeNQVgB9tq9ju7sK92ccOVVlsPMWCOeUAac14vMPZueRKNsyrp X-Developer-Key: i=xu.yang_2@nxp.com; a=ed25519; pk=5c2HwftfKxFlMJboUe40+xawMtfnp5F8iEiv5CiKS+4= X-ClientProxiedBy: SI1PR02CA0014.apcprd02.prod.outlook.com (2603:1096:4:1f7::9) To PAXPR04MB9422.eurprd04.prod.outlook.com (2603:10a6:102:2b4::21) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PAXPR04MB9422:EE_|AS8PR04MB8150:EE_ X-MS-Office365-Filtering-Correlation-Id: 770b497b-3a9d-4923-e302-08dec131c258 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|19092799006|376014|7416014|366016|18002099003|22082099003|56012099006|11063799006; X-Microsoft-Antispam-Message-Info: 3IyFA62WTWawbKEMqLaKZS/yImAorNyAhyt+pAhG3Dh3eFiurtPc0IcNNOrVeoLk2aOzVFYwA7T1mRvdQ6UWBn2cjDaqHUmFG/dw+aDdr2S4VM8Hgrgp9Y6MZKAATFn8/FT9FiRKcvu86xI41yO6Hui9RaPRoIgekcU8gwjL764R+VsgIPX/t0fOu3Y3vu04z9X/uaUmj2qcM3VRxADplf7LJ0MI92+PlfWxHptY79b3G530MHqFG6QFUwAQcU8gALm1b265WcHDtsfbmbg6ZWbLZT4z7e2BnB5Wg1OiTkCdK4/GZmiRPo+QwlVXCjIkYw3ugsaXs+j36Ik5MKgHnMnlH838uz04SVFZKb0J9BpLmMp5y6iExvTNBJVCfRtEbVzMDNqRa7nkdSiQo2wImVOmsfDst60eK7yQl4W/GnZJkCGOzVsAXAc4deI1GGIhzsIwws8fBEHL6YR07ih3EqrvH/5nhmjL8t/cjpkZ9vxgXHNjL+poxCTaVRipbERkFDeGnDivSdOuIfJbQ51jLOA+tFAwL/5slsr0RkFhK4wB08lsidOieNZKk3TF7vlJMurg30q/9EukfXGVKkq+V22f3zlEapK+oyMRfJX+GpRzef656Usc5bpuEa35lq7HJrL7aGasfVGF0Ic480oYLcUbAZMhU1UnG8rBZP3R03KaVQW+HF2qHKCi6Atznw+F X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PAXPR04MB9422.eurprd04.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(1800799024)(19092799006)(376014)(7416014)(366016)(18002099003)(22082099003)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?B?UDVtTVl6WGwzYXVGczhHVTE4UGx2QmcrMjd2dTN1UG5Ia1IwYlZxRjIrVEk3?= =?utf-8?B?OG9GZHI0K2h2ZUxQNEYzMkd5UDl5YTMxSC83QnRlNmZBdS9RcXM2TGc5aEsv?= =?utf-8?B?Y2x1cU1uL1NsRzlySlNIU3B6VU1IOHo1WG9Jb0JHaUtqcHg5bVJLcXU2MlA0?= =?utf-8?B?bU85Y3RwRDNCVnVuRVFIWndDWHFHdEphaWMxb3JEN0MwMVY0QkcwckNuamY5?= =?utf-8?B?dW82WUsxNS85U0xweHE2c3VyRWNEMGdyTWlDUUN2bkNqdElyNmhWYis4Q3FX?= =?utf-8?B?TDlvdDYxQndNdFNUQm8vcFVaUXphQjQ2NmE1OVVoejdOL1AwZ2ZWTU4yT09S?= =?utf-8?B?WmxYTUJMSWNqb0J6WDNwbkROU2hsRmdPelRZSXNpT1JkL0llaEpIMUxRbTFY?= =?utf-8?B?Z1BvYjNyaERDR1BQTFdnY0RrbndLeHh3WVptMjFHYkJlaE5Gc2Q4eWV4dEZm?= =?utf-8?B?bzRtQXlocE9GeHBaNjNzYUY4UE85b2JnS1dUaWE3dGpSeTQvdy84VDJEOHNP?= =?utf-8?B?U1hpd1pMVENBY1dXYzhMSHBuZXRCd1k4ck9wVXNhVFYvQmR5Uk1mYWxVajlF?= =?utf-8?B?S09tSmRHS3pGSWJQaHVwbmpWcm9FRzZCdDRNanErb2dsa0FYR3JBeTNEdzN3?= =?utf-8?B?bEhYYzJ3SjBNeFRvdytmOU1OTkNXbDZqN01FTXFWNitrdFhiTEVtUXF5SG1W?= =?utf-8?B?NFZxTkEyZm1DYkFEblVQc1V3OWV3dWRRMjZOUmpVckQxM3hrY05BYkFNRjZ0?= =?utf-8?B?Zmpnc0dCWDVzUThBODhXTW52eXNqaDN3VGtkVzVGN0dVc1RFNktUQ0pQUnlt?= =?utf-8?B?WEdvZ2JhYUVxclhmL2psVmFiUklWdEh2cXVtMDg5dXhrMld0RnJEaURKdDFZ?= =?utf-8?B?bndWMjJoVTRQc05SRHE4L1ltMWFKejMvV3FhQ3MvNGhQYnpDTTdGVDRUeGdw?= =?utf-8?B?YlFrc2JJb292Q2ZUZkpLQnVDOGw0a1pXR1phQ0lrWmZxMXpKak5rd04zb3hH?= =?utf-8?B?bElXcEtlVUVLa01XZnFqM09tUVVndm9mNHZaU2FSQkRlR3dPY1RUWWZTYXZP?= =?utf-8?B?MnpqM2xUTjB3b2x1MWttM3BCdlg1VWxCUWF0eVdoZTBWYUh5d0kwZDdleVN5?= =?utf-8?B?aUZPSDhXK2ZkYTdZYm9pUlZkUFVLam9nVlRRdFcwaTJKRk94aldTNS9iY09O?= =?utf-8?B?MURqZjYyTWxqc3hwc2V5Y0tIRll1Zk9UaXRWK3VHZE1DaFRTcWJCN040ZXlp?= =?utf-8?B?dmduRHhON1g2dzRaS2tVbHM2aC93VUdMbHhSSnF0ZVg2TzVaWENHajF1MnpM?= =?utf-8?B?QjEzdXNoZC85Q2FFcWJaWHJsTDJyNmlhdndkb0MxQ0N6SWpBUkhtSk5zMzF3?= =?utf-8?B?Z294M2l2cmJncXBONzBZeWx6bHIxVFR0bnRlUXhrb28ranZiRFNhZmYyY01w?= =?utf-8?B?SjZqWmMrWnNucXZHN0hubFRXTEtRU21vUWhHNFNOOFNYRmt4MGhMQkFnaHh1?= =?utf-8?B?Rk8vbnBMeDczcUhBUE1TUlByS2o1WUNldHlHZDh6TUhZRzFNVG5NVkMwVG1W?= =?utf-8?B?RUJzVHIvQ1FrU1lYRjdCMFVZU1BYRlFOUGZhOVN2dUg0eUxhYWNLcTZNV2gx?= =?utf-8?B?a20wQXNRS1N3bEM3ZkJsYmsvd2lycXBaZ2tsbGpGMWtkZzJ0Q2RsdzVVVVJl?= =?utf-8?B?UStXRE5qSWlLNDNBZ2NCdjZoL1hkNlV1cWxwd1FVc3VnRjVROUxvaTI2aGJI?= =?utf-8?B?L2pNZzB5eTMzM1N0SUF6ZVk5cVY5a0lrM21Nd2EveC9wRXB2R2tMdm5zb00w?= =?utf-8?B?VFAyZyszajBHUUM2L1IzSnNyTDhuYk5zUm9HbVhNYUhrRTFpaFlWVFVweEN0?= =?utf-8?B?YjMwVFpzY0hkb2J1a2RhYlFIcU9TOHZ4QmVhMzZkSW4yY2hHR1pwM2FGOGxX?= =?utf-8?B?SVA3dFExa0hvUXMzRmVhQmIxalkrZlkycncvOC9UVno5Y2pHNmtTSFEzdmNE?= =?utf-8?B?SUs4Y1Y2VE9SdWVtaS9PLzdGbTBWVGxZRENEeHExc0pDWkNCQWVtN2RHRzRG?= =?utf-8?B?RjI1QkZIWk0xSHduNjJLU0x5WnoyZXRMMCs5VC9oa3dmNGNuRzFpek9Wb0ZC?= =?utf-8?B?YXlqU0MvYU42VkVyaS9EbnlIZWRuSWZrOXNHa0tqQzMrQ1lqM0Z4VDNmQkZG?= =?utf-8?B?bWRGeFlrWWF1V1BQYUJHZ05qclowQ0JmUUNuQXhpNzVVYkoxUVVzTGt4ZklT?= =?utf-8?B?NTMvRGpGajhISUpUWjdsYS9rYkJGT2hqd01NTkNRNW0rUEh1bDZWazRSa2Z2?= =?utf-8?B?Q2dtZkFwb2FXallENzlMRjZvMEYyUGhkM0UySXlQS2dxV1dSUFByYlBSMzdR?= =?utf-8?Q?iCDUpRAs8EdFmlDeqk0y/k12ASL1MVX7xWa6r?= X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 770b497b-3a9d-4923-e302-08dec131c258 X-MS-Exchange-CrossTenant-AuthSource: PAXPR04MB9422.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Jun 2026 05:34:19.3892 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: F2UuXNW8vUlU7oI7fbHyd5qqhS714kPvEBcXX68dU5PxbXSc3sfcEka9Pm9HANOLjoaWP1gZXQrc9vaAO8Ut6ToL5ALvdfx2wtwDS1HfmJfAqIBsmIT9jmXwPQ+/5yLT X-MS-Exchange-Transport-CrossTenantHeadersStamped: AS8PR04MB8150 From: Felix Gu If probe fails after imx95_usb_phy_get_tca() succeeds, the typec switch leaks because the only cleanup path was in .remove, which never runs on probe failure. Use devm_add_action_or_reset() so the switch is cleaned up on both probe failure and driver removal. The .remove callback and imx95_usb_phy_put_tca() are no longer needed. Fixes: b58f0f86fd61 ("phy: fsl-imx8mq-usb: add tca function driver for imx9= 5") Cc: stable@vger.kernel.org Reviewed-by: Frank Li Reviewed-by: Xu Yang Signed-off-by: Felix Gu --- Changes in v3: - add R-b tag - cc statble - drop "sw =3D data" conversion --- drivers/phy/freescale/phy-fsl-imx8mq-usb.c | 27 +++++++-------------------- 1 file changed, 7 insertions(+), 20 deletions(-) diff --git a/drivers/phy/freescale/phy-fsl-imx8mq-usb.c b/drivers/phy/frees= cale/phy-fsl-imx8mq-usb.c index b05d80e849a1..88b804b2c982 100644 --- a/drivers/phy/freescale/phy-fsl-imx8mq-usb.c +++ b/drivers/phy/freescale/phy-fsl-imx8mq-usb.c @@ -173,9 +173,9 @@ static struct typec_switch_dev *tca_blk_get_typec_switc= h(struct platform_device return sw; } =20 -static void tca_blk_put_typec_switch(struct typec_switch_dev *sw) +static void tca_blk_put_typec_switch(void *data) { - typec_switch_unregister(sw); + typec_switch_unregister(data); } =20 static void tca_blk_orientation_set(struct tca_blk *tca, @@ -248,6 +248,7 @@ static struct tca_blk *imx95_usb_phy_get_tca(struct pla= tform_device *pdev, struct device *dev =3D &pdev->dev; struct resource *res; struct tca_blk *tca; + int ret; =20 res =3D platform_get_resource(pdev, IORESOURCE_MEM, 1); if (!res) @@ -266,17 +267,11 @@ static struct tca_blk *imx95_usb_phy_get_tca(struct p= latform_device *pdev, tca->orientation =3D TYPEC_ORIENTATION_NORMAL; tca->sw =3D tca_blk_get_typec_switch(pdev, imx_phy); =20 - return tca; -} - -static void imx95_usb_phy_put_tca(struct imx8mq_usb_phy *imx_phy) -{ - struct tca_blk *tca =3D imx_phy->tca; - - if (!tca) - return; + ret =3D devm_add_action_or_reset(&pdev->dev, tca_blk_put_typec_switch, tc= a->sw); + if (ret) + return ERR_PTR(ret); =20 - tca_blk_put_typec_switch(tca->sw); + return tca; } =20 static u32 phy_tx_vref_tune_from_property(u32 percent) @@ -739,16 +734,8 @@ static int imx8mq_usb_phy_probe(struct platform_device= *pdev) return PTR_ERR_OR_ZERO(phy_provider); } =20 -static void imx8mq_usb_phy_remove(struct platform_device *pdev) -{ - struct imx8mq_usb_phy *imx_phy =3D platform_get_drvdata(pdev); - - imx95_usb_phy_put_tca(imx_phy); -} - static struct platform_driver imx8mq_usb_phy_driver =3D { .probe =3D imx8mq_usb_phy_probe, - .remove =3D imx8mq_usb_phy_remove, .driver =3D { .name =3D "imx8mq-usb-phy", .of_match_table =3D imx8mq_usb_phy_of_match, --=20 2.34.1 From nobody Mon Jun 8 06:38:20 2026 Received: from AM0PR83CU005.outbound.protection.outlook.com (mail-westeuropeazon11010063.outbound.protection.outlook.com [52.101.69.63]) (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 6CE853126DA for ; Wed, 3 Jun 2026 05:34:27 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.69.63 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780464871; cv=fail; b=M9EN0zJ0cXAROk1Dc/EFz7mzEGg1IuxrfQ0gcCR4SVu6SM0kapl0vx7q3HjNUKIJvlKyOB9mbEX7w8sZvFUgK1RbYuloW/A+Du0WB1fMQwg1BI2mlNgHPp+XSJzQdMq8Mbma3J7gMZ2VWzOwyjAt8Zb7jYh0TnnK7wZv9i8ZiRc= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780464871; c=relaxed/simple; bh=YXsFyJsvM3tZ4tlLtnPzmotPrkSK5kNlAzpQYrBakk8=; h=From:Date:Subject:Content-Type:Message-Id:References:In-Reply-To: To:Cc:MIME-Version; b=b/e7TYGaWfnkbirBaLsRi8HKO6RAJIH36mO7mwjOo5fjHWykcyvAIfof9mdmCvNKkaT2su04TnSpKJhFDJwdqj5/6b4BL1schxESqNa9QO2+MEe8AIjmIzVLhalRHHEd4E0V/dlgfqok6eoNC7DGse9tRJV6Va3jrjJ82DJjwEA= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oss.nxp.com; spf=pass smtp.mailfrom=oss.nxp.com; dkim=pass (2048-bit key) header.d=NXP1.onmicrosoft.com header.i=@NXP1.onmicrosoft.com header.b=KI0PXPHJ; arc=fail smtp.client-ip=52.101.69.63 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oss.nxp.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.nxp.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=NXP1.onmicrosoft.com header.i=@NXP1.onmicrosoft.com header.b="KI0PXPHJ" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=qTh39KJFUN8XB25EGl/KhVfPUC2ojNKrLLPPDiW198Ub/HTwLjH+eaPr/t4fqelD8TTo35c7q7FbfZElwrLtRwQNSNtpMvEyQGbrlUxqjzTUDLKXkxl7Yey7OCjK2Aivo4pi+ud8coqFVb/LZ/RZaSxQcPXjyPD4WUdzaFl0i38ffL4Zmztoev34Gjqrn2exML19YkLnY/gT6dKj8UX4CKnKJkyfOMGdThMV6jllUV9pspiZoFqV7ACcEZ11iBhR4T3DSJu23KxTnXoR/8MdUlx3sDZgFKQ5ZIaGooHpL894liRoMihAFG7voFuHvxvEo1pZVpt+1JLpluoVBsvwFg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=UivgvCCqccs/5kdWJnU9L8m4eX+264iU6Fg5Te36S2c=; b=O6XlPXkKP25kBLIoYrGAJWKwJh6TUxo0aDtTZmTRUgCJe3Vo77TX9nKDnT/xeRJ1auyRyeNQAzRyQe1RxbbEGl5LKbimDtUuQDn8MRwM07sSizTn7RqIX/i+w/+sJPBcGUuMTHHus0esNgvknKs/kqG03KHxyMOtBf3SSLi46H5TPPMhQ1DgmEgDyzQQNbiJvdSMcPQX1fjk4nR7gqRpmxLlCRkJDtPa7Dzz6zl08E816zHq/YpDbCkl3kcth+FdmLZJhOdEooIQVPQpe7GtdcJOSdNK5QgiQoG4r+QBP71DQ376XOZ5TUdUGcwS9ktlOy/fPKAmsEh8ktLC7yvKnw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=oss.nxp.com; dmarc=pass action=none header.from=oss.nxp.com; dkim=pass header.d=oss.nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=NXP1.onmicrosoft.com; s=selector1-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=UivgvCCqccs/5kdWJnU9L8m4eX+264iU6Fg5Te36S2c=; b=KI0PXPHJcSOehurYefh5ooiwmoua8Zjz9UOlN215JYdUGGI+9n80psiKATcIXL/lmZO5xu4Q8rprDKwSszH4wkDaWD+dsQ2zwU/iUig7iN8UDBsXj5mlgPz92i3j27tj1wjeqdMcrolcdlXkUBl+D4SWHuSqxxh83U7z/O3lIIk4CWpS+EwnqjfZqpElsvRD1JyozlQtDob+giRBKsvZRQsRv0J50JRbLGkY504cJlhkg7LGW3eNFnCg/YzMDqqvwjd024LRpWajvyJ3tvR2ZIjYylAQs1VtVSFKqZhLygzWEMQd4MyrsI8S8UkTSwljoJGrl5mMRGrc6Wq0XemWKw== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=oss.nxp.com; Received: from PAXPR04MB9422.eurprd04.prod.outlook.com (2603:10a6:102:2b4::21) by AS8PR04MB8150.eurprd04.prod.outlook.com (2603:10a6:20b:3f0::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.92.7; Wed, 3 Jun 2026 05:34:24 +0000 Received: from PAXPR04MB9422.eurprd04.prod.outlook.com ([fe80::54e:28bf:aa85:d25d]) by PAXPR04MB9422.eurprd04.prod.outlook.com ([fe80::54e:28bf:aa85:d25d%4]) with mapi id 15.21.0071.015; Wed, 3 Jun 2026 05:34:24 +0000 From: Xu Yang Date: Wed, 03 Jun 2026 13:37:15 +0800 Subject: [PATCH v3 2/5] phy: fsl-imx8mq-usb: set usb phy to be wakeup capable Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20260603-imx8mp-usb-phy-improvement-v3-2-7afb8f89abc6@nxp.com> References: <20260603-imx8mp-usb-phy-improvement-v3-0-7afb8f89abc6@nxp.com> In-Reply-To: <20260603-imx8mp-usb-phy-improvement-v3-0-7afb8f89abc6@nxp.com> To: Vinod Koul , Neil Armstrong , Frank Li , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam , Jun Li Cc: linux-phy@lists.infradead.org, imx@lists.linux.dev, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Xu Yang X-Mailer: b4 0.15.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1780465041; l=816; i=xu.yang_2@nxp.com; s=20250815; h=from:subject:message-id; bh=gmaRyDvzZ1FJnRyPBnMJ9+F5cb0r2KeZpK2ckmm9rEA=; b=EiVQAemeZIRRB3sMHviTpZcX3yWMROBuj7ZKFSmQxi8fg5qxAzigBdEhIQpfpbWOFZjwDwRFi QyHNVQlIhKOD/LkQIMvejIBIq/iPlzWvCmyyRudcgP+RBRrSO6vDLtS X-Developer-Key: i=xu.yang_2@nxp.com; a=ed25519; pk=5c2HwftfKxFlMJboUe40+xawMtfnp5F8iEiv5CiKS+4= X-ClientProxiedBy: SI2PR01CA0045.apcprd01.prod.exchangelabs.com (2603:1096:4:193::19) To PAXPR04MB9422.eurprd04.prod.outlook.com (2603:10a6:102:2b4::21) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PAXPR04MB9422:EE_|AS8PR04MB8150:EE_ X-MS-Office365-Filtering-Correlation-Id: 2d442e37-906f-4156-e979-08dec131c583 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|19092799006|376014|366016|18002099003|22082099003|56012099006|11063799006|5023799004; X-Microsoft-Antispam-Message-Info: zN6B4BuI/DV7z/0SRvA17gJOb+swJYkm391pA1ktEbbLCGAZqQGFmzrk5gjb2H3gGTIVImLdnPIc8oCIHqg4rWyJzzhK3NiyATIRysH1jTIs5TKU0ZDIhae2GKbefuZ7D3K0kT19tnFBMdURtMz1OgujOmBxxEcw9kmHiQIZRc6+acIAQXVQ0YXSGvZgIDe3YK8AJuEtUG5DqH/G3YWwYgF2SFoZkVFSJDtXGp1o5Oh0YOUhYppntbJ2te9xi7wwnnTLtxsNwJoum4jATtCQ4pnzPnDGUgAJBY/470pP+3t2VsQfxiqPrkawl0KoEXfl+163tt4NFb9wFNX94Up5JlkDz0xeA2tZDGGEwci7itxY+zRPvNVOEyPZQTwd1NEKeLlFs44bjYmkv2TU5K/1ifi8WfwLAELQd3h/CnZsIEghp+Ux1+Yrs9F8Y+YNKELDfoPzvQJyRHpUgrRg86nh35DQoGt8T9FnpPLMJrFvOyFLXGFjy4Inie8rT9XTbv9XczvaaUnPIbMHiuP0v0N6/KlVkM4kVRY1ZAjKNMACvD7x0NXLJeN5GBFHiQGv9lTmxzVld4JVILE4xYzSPM8tIha0aMnr6PVghiaWBQKu5VuX8VJEsPW+AyXSlnx6IKXjwPDPHdfdmt3mj5kkinHzXKX4TDRfMizZKcrVf0c+U14ODS++CuzHGw0icebeKPXt X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PAXPR04MB9422.eurprd04.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(1800799024)(19092799006)(376014)(366016)(18002099003)(22082099003)(56012099006)(11063799006)(5023799004);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?B?M08ySWhxc1hzd3NvVXBRTlhsZHJaY1YyQlYvNVg1a3FxeXp3R0pPMnprZENN?= =?utf-8?B?QjgvMUIvMXhhRlJIYTJBRnErNy9zRDBIZ3hoMStmNkNYMEtUTnpCKzR6aExF?= =?utf-8?B?eTNKNXBoa1E4dHNzVWVNbUI1TUdobVhROUFCUFRIbUY4cVhPSTJ5SDdPaEps?= =?utf-8?B?dThvNmhKc2hvVGd3MHlBaFdyQTBvQ1JFeXJINmJoWEVFVFdreG5uMVhVZ0Q4?= =?utf-8?B?bnlBQ0xxbFppRDZUT0NvU0RMTUJaSUJScThSbEpzMkkwS0tONE53Qy93cnZJ?= =?utf-8?B?UzRUV3dYdWtLMllkZlVNNk1CaFUxTk4rK0JUSGJrYzNPT0I2TmIvRk9vc05k?= =?utf-8?B?ZTh0RzVkQlZlMFltNHNlQWpNQmFGODVFamE3MEZ4aTkyUnJ5WnEyQ2NiaVVk?= =?utf-8?B?OVBBWFpFOU1HSVFsR3BaLzBBbzNUY09GbmU2QU1yZXdxakhta3oxMXFkekUr?= =?utf-8?B?VzkzelhkNERiUmJuK2ZjYXhJbG5WSVVQMStKa0FaanZ0a2VrU0lnK04zdVBZ?= =?utf-8?B?MlRkalhDOEx2TjhEN3dKVWQzY2lUL2I4MUY0bXlzcWZldVBqMDdjTGRXOEF0?= =?utf-8?B?cTdFK0NkNkI2T3U0OFBjakVWcnprVGtWbVR1a0hhNGRJZ1hnRUpTa2l5ZCtt?= =?utf-8?B?UnAyNTVlNTM0MEhkU3NRSDBGczQxSC9KOFlvYTdmbVFEY09yalhwckQwdVZU?= =?utf-8?B?NmptZjdQWDI2TldoUThXdUYxWWhxLzJUc2x0ZmZ2YXRSVUJaVHRSMVVuY1RY?= =?utf-8?B?VTc1a1JoZjA1RlpBS1VoU2dnbHR2QjRQWlRQL0F5RnRmM2tzRUJ3dTBjVnE3?= =?utf-8?B?MmtPT1poREpJVzFYaXBHMnBNTW52NWVpU2RFT01kSVJPcllMTjVMbE5QZ2ZS?= =?utf-8?B?a0p2dkN0SmRvWmcyV2RicXNOVEplZmRlc0pUQ0oreUhEVDQyMFJVckhFUCt2?= =?utf-8?B?MDRrT21WZmlINCtGS2Joamwyc2EwM2lBVk54N0NTMGV3RXU2aW95WXltN0ZE?= =?utf-8?B?dGVIcWVrNzBCQ1RQYzdIaGM3aXRCVGlDYkU5UVB2ZW5OYjd3NndCM3JUSFZX?= =?utf-8?B?Nm1GOTFkeTNDa1prSGFmWGR6dFFwNGk4dWY5WDBmZTBlSmFXVzM2V2pNaTVm?= =?utf-8?B?ZEJpbUYrR2tMQlVCTURDb29UaldSdjMyMUllVVZxaUF4MVIvcDlldHp3aXVv?= =?utf-8?B?aU0zcmp5Z3NIenpEQitwdFpaMlloR200RHV4b0M5WUdMQ3VDaVhGK3UyNXVL?= =?utf-8?B?MUZBdUM1c29URFhvbm4xN1ZDUEdSb0dKOHdZUnBvSmpRbURFU0F3S2VZaUpV?= =?utf-8?B?Z2lCOGxBaHRIQUNmZkJGU0xnLzJ0UjQra3NnVlhGL2o4Z1ZGYStaVzJrMFZr?= =?utf-8?B?T2oxVkY2WUJNMHFlUTZ4M05HTkNsbnhtOUJJWEZMaDB2cXhVNExpenUwYVY0?= =?utf-8?B?aXpvcjd2RGdSeG9JYjNHbHJibmlGUXo5TkRMSG9LdGxLdEpGeE9YMFZ3NDBO?= =?utf-8?B?NExpQ1UvcHNkYVd2NU00ZlpMNXlUVUExcUVYeFZlVklDUFRnVUFsbVMwb01m?= =?utf-8?B?VUpsdHZZN3didC85K0JLc2FCeTQwWEsyMldNZldiUUFNckw1cW9qRnQ1OXNU?= =?utf-8?B?SVhMdDFHZUlZTmFIajVhVEhJbWJXUHBRZitoVUFyaVdxdXNUamNMd3VNeVlG?= =?utf-8?B?WlN6YnZ6bWc5TzMwU2dSQTVHVlQxaGsxcjgvQmxxTVJPeUY4dkhwTmF4VStN?= =?utf-8?B?WlBoUGlWVzdpZDAvdEFqN1NnYUxwZ1NDbm9JMDJCekFWdlB0RnZtNTdVRlA2?= =?utf-8?B?NUxxOGtxV3RTeDIvdXArVS95SWNlK1IrWGRCNzUrTEJyWUV4U2FNcUw1NXJ6?= =?utf-8?B?UkFCNmpiOTQwb2NIMkYxdng4aUNxd2VVYlBKandHVGJKYjF1Yy9zRm9mck02?= =?utf-8?B?YkNlV2pWb1I1dE9tQmlHdisrUjdkTWppUHdTcCs0SDk4ekhOanRiLzNxSE8v?= =?utf-8?B?K0Z6K3dESGRNYWpwOUc5MURqczNqb0JvOGZRYUNWVWJqVytRbU14NUxicmRa?= =?utf-8?B?RVF1K1hiUTFMWGdzVjdzcEVla1NKaFdyWEF3bkxDQ0s3enRqeVZOMUt3Q1RT?= =?utf-8?B?L1Z2aG9idVhTdTZpajl3YVNUY3pNOE5OZ3RaZHNaWEdxYStvQnRKMjZtTmJH?= =?utf-8?B?ZEh0ZGl5NDdmMDJZT2VscFN5R2NKaGJQeTFWSnZlckZyYkhQZjB3QzNzRlhH?= =?utf-8?B?c0ZSeFVEMU1ManRhbEZkZGJzdFR6dS9CVE5vVFptT3FGNVZvdCtNdW42ZFpx?= =?utf-8?B?SEM3OS9tTEJDeFQ3bjFqbW1CVVVDTFowcVBkWWNCcitEZVIzSGljM0xQNnRG?= =?utf-8?Q?NV2tIomaNoeJRpK/PReC9uyEJvd16y1sQAX+j?= X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 2d442e37-906f-4156-e979-08dec131c583 X-MS-Exchange-CrossTenant-AuthSource: PAXPR04MB9422.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Jun 2026 05:34:24.5443 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: yrZaixBMspTJYsUJywWePaS7YB+0Lo6s8LakB01MOogVhHjCr7S8kAlFR+8Bxmd2a6MMUyuPDtODSVveLRy69vjArYEfHBXz1sM1cIdFzw+NGqSQyoT12utgIlC+cmVb X-MS-Exchange-Transport-CrossTenantHeadersStamped: AS8PR04MB8150 From: Xu Yang Set PHY wakeup capable because this PHY supports remote wakeup function. Signed-off-by: Xu Yang Reviewed-by: Frank Li --- Changes in v3: - no changes Changes in v2: - no changes --- drivers/phy/freescale/phy-fsl-imx8mq-usb.c | 1 + 1 file changed, 1 insertion(+) diff --git a/drivers/phy/freescale/phy-fsl-imx8mq-usb.c b/drivers/phy/frees= cale/phy-fsl-imx8mq-usb.c index 88b804b2c982..591ddf346061 100644 --- a/drivers/phy/freescale/phy-fsl-imx8mq-usb.c +++ b/drivers/phy/freescale/phy-fsl-imx8mq-usb.c @@ -728,6 +728,7 @@ static int imx8mq_usb_phy_probe(struct platform_device = *pdev) "failed to get tca\n"); =20 imx8m_get_phy_tuning_data(imx_phy); + device_set_wakeup_capable(dev, true); =20 phy_provider =3D devm_of_phy_provider_register(dev, of_phy_simple_xlate); =20 --=20 2.34.1 From nobody Mon Jun 8 06:38:20 2026 Received: from PA4PR04CU001.outbound.protection.outlook.com (mail-francecentralazon11013041.outbound.protection.outlook.com [40.107.162.41]) (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 41B6D379C27 for ; Wed, 3 Jun 2026 05:34:36 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.162.41 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780464878; cv=fail; b=ZwV+7OGut/EwYr0VN6alVn6OQ3Sj6EDcX2iFFR7Unb9cCmnawficA65aXfQ8hBJNLld/4mY0oTQQQ4DDovpbvc7Nc07nYVnUCn/1tgLp5cQBp8CNE37MFXwGp16QxF5Now+O8dtIpQ1h0a74mYjWUKaQ1HhjZryUipgl80DuCC8= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780464878; c=relaxed/simple; bh=hiUo1PAcEQdp2Ygh9ya0G2fmgAhcNJDwnODZWRmNrPA=; h=From:Date:Subject:Content-Type:Message-Id:References:In-Reply-To: To:Cc:MIME-Version; b=IEUsi4tTWbJKqXI9yZFvGg1fCFogILvraZdZIyQqs86a91EqKHWGZdVj1gv0n0ZEBCKtnaibx14pKT9IYr7LIumfUEmd7Velk3FAuU1d0zmzFCvVh046vo2bUXlsaGEFqWUAIWV2TfnA92IbXyAcNvnzOwJHOh6JRekmO6wd75A= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oss.nxp.com; spf=pass smtp.mailfrom=oss.nxp.com; dkim=pass (2048-bit key) header.d=NXP1.onmicrosoft.com header.i=@NXP1.onmicrosoft.com header.b=SXPMLMzk; arc=fail smtp.client-ip=40.107.162.41 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oss.nxp.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.nxp.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=NXP1.onmicrosoft.com header.i=@NXP1.onmicrosoft.com header.b="SXPMLMzk" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=DmRC/SclFRG5NT56KyF9K8LI1HBVNlpqIv3QYbGFkBHlMve+YMDGA4Zk9g8RqDIsoTV/5p0YsNtMPH6nULcYW1KJZyIcPpsRcaVsac4TXZgU5DAbH39PjSQE2NCm3Zh/OBMk169uit96zjSc64Tn96jU9azNJGtL1kE65dW8mTy1xbBP1fBmg/veeo8SYQJ3pz6c8ICAQWtviesaB128EMnEh5Jjap+znY2Qr+MjPZmFcdB8MD8CMdD7LqUooji6WbZPZ4rzXk55dHMKpjmICJViwPzGQXyH8Riu16WykbnVgawv4TioauhiP8bxZUMzGNUbnLydkYTN1KgZf3GzRA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=Foe8qWvN7pc7a47xF/+zqGqV0l4IgoVNhFJK614TNC4=; b=w+Uq2RgjArofrbj3+baR9S5iRHGZBo7TAYHYeBTGJ6wzqfOLcMNcmcXnGe9mVKyWFvOkFp5eVr7mrgm2N3Rg1wTeLLo7X5UxfmQlv7/uVV80EwLKHXLeQ4HCy2kMUITprFqPTezQTfnz/fz3xl4MobjCJj1CwCnWutNMcOJxt8sIszflwT5RNnzBaUHsmE7kwAXJQHbLTI/IUQHCeSGVC1u82odf2l1CpFXQ6iiyUZmWiZoG/Af3LoHWNskitAv6qpdu2ciegMoWlj5stEtAY4lKBGAL0KkkrcMEnL5V/vIokYLKbmmzxQ+ymjAH3NWzshPfx5ywBY4iheGt9/YA/A== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=oss.nxp.com; dmarc=pass action=none header.from=oss.nxp.com; dkim=pass header.d=oss.nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=NXP1.onmicrosoft.com; s=selector1-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=Foe8qWvN7pc7a47xF/+zqGqV0l4IgoVNhFJK614TNC4=; b=SXPMLMzkCsXUNc+hGv82kFFHvs2J3f//bwJnuNSo6QsLi4BcRNrUzTmZz473RNXAIFb6QqX5XB6bamdTu09xr3GHnYUiup/2YtqaFQUHTqQpdIyXupaRxEb15m4Nnkk88CCFA9YPIla5Rw6yIYM9zOk8rwglGDDTgQJWy3FFNek2KQaD0D0hx7bpoB68f0jHPwSA4geZTC6RVf/lmQSPQhRsbmgqYLiIi960Uh/7wB9yk40kY9HKn5HeYn+l8lTbC/uauNsAufLWZGldsE8RBwhs13ClN3/ae1RPezSytjzZ3O9/mDADELTvHSgxO8sdVRXK9tsqSlefeioXMkqtnQ== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=oss.nxp.com; Received: from PAXPR04MB9422.eurprd04.prod.outlook.com (2603:10a6:102:2b4::21) by AS8PR04MB8150.eurprd04.prod.outlook.com (2603:10a6:20b:3f0::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.92.7; Wed, 3 Jun 2026 05:34:30 +0000 Received: from PAXPR04MB9422.eurprd04.prod.outlook.com ([fe80::54e:28bf:aa85:d25d]) by PAXPR04MB9422.eurprd04.prod.outlook.com ([fe80::54e:28bf:aa85:d25d%4]) with mapi id 15.21.0071.015; Wed, 3 Jun 2026 05:34:30 +0000 From: Xu Yang Date: Wed, 03 Jun 2026 13:37:16 +0800 Subject: [PATCH v3 3/5] phy: fsl-imx8mq-usb: add runtime PM support Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20260603-imx8mp-usb-phy-improvement-v3-3-7afb8f89abc6@nxp.com> References: <20260603-imx8mp-usb-phy-improvement-v3-0-7afb8f89abc6@nxp.com> In-Reply-To: <20260603-imx8mp-usb-phy-improvement-v3-0-7afb8f89abc6@nxp.com> To: Vinod Koul , Neil Armstrong , Frank Li , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam , Jun Li Cc: linux-phy@lists.infradead.org, imx@lists.linux.dev, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Xu Yang X-Mailer: b4 0.15.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1780465041; l=4731; i=xu.yang_2@nxp.com; s=20250815; h=from:subject:message-id; bh=tvzFlWPN40OVjbqcSZibLcu6oyplmN9svCQ1SFVorT0=; b=Q45KbP96vb4RfAbubAokAkuQ+BCQ1Z6h6+QxCPYzb1GhSUwULMdBcppaDiF58eNOZPyYDOa0n p4HiHU8T3/VCwIPp0+oNnb/1cBtIcmSr1phbQDoG+EC4hG2p/xFdVbN X-Developer-Key: i=xu.yang_2@nxp.com; a=ed25519; pk=5c2HwftfKxFlMJboUe40+xawMtfnp5F8iEiv5CiKS+4= X-ClientProxiedBy: MA5P287CA0134.INDP287.PROD.OUTLOOK.COM (2603:1096:a01:1d2::17) To PAXPR04MB9422.eurprd04.prod.outlook.com (2603:10a6:102:2b4::21) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PAXPR04MB9422:EE_|AS8PR04MB8150:EE_ X-MS-Office365-Filtering-Correlation-Id: 6430277c-a4da-4bc0-ccbd-08dec131c8d7 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|19092799006|376014|366016|18002099003|22082099003|3023799007|56012099006|11063799006; X-Microsoft-Antispam-Message-Info: BLsJQHLBdRJzY4eqZzIHqVCQ/k9a83Mac3VwaLTX6/lnwoDc7kWvM0qLmIrpe8DX7mg/NRTeQ9NVCz48hjLk5cOveTrov7Ag8OSOEPTIV3yctykNseZxp4QqlUL6athlIN/aFmYZQymOa9mjoJa1vAmuJFbSmHFIAfT+PIOUX4Tcnd7EcwqiTKm9n7pNLsdrqUfd8+MP8rsLm/f3pPA2Ujonrv8C+c2HIZzOgw9BCXzzt7fQvdLlgkUMoKr2S5AtJV0x4cUB4nqCCv0AVgNatRJPp1x1OY6eXiD4MX2vjM9xtPG4KTBFrJkPHBSWweIpTN39fkqm2xpUi4Xd+B0TKwGthlH4QdFPoIemZrdwSD/dfVOX2uVprarVHOPu2AUUreT+vCVTAfex/CSnQePehG8zuuBILtFVzr3oThhTXC+axOMkSOUCO/4C8eUDe74uobzUgpbz73GFQ0Qb2ZjhUpV891Q28PxRU4MchZNTioPcMjhlXe6zXf9tsUK21mEYBFubgK6OVh8Sq+bFVZ5hnsDxlSxKert9hCmy5R5lk+2WIFtpz4ox9Pfjb1q3RCL3ujDORwC9HhCrKKLbe66Xl7Sa5zCW4L0IqFv8El/+Jrz2hEPKptqGW4+JwaQQdSKG23n56Nxzn4FtAuAQ5hzrrTWmlILboMqw8dkm68SB4WHkNInO9RXFylio3yIg6AqG X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PAXPR04MB9422.eurprd04.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(1800799024)(19092799006)(376014)(366016)(18002099003)(22082099003)(3023799007)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?B?S002cVNRM3pwRVA0T2VMTVB5ZkVGUzU0d1NEZG9OREVlV1NvdTJ6NkZWM1NS?= =?utf-8?B?cUQ5R1lIRjljV05wNDJzV3BLeFJ6aE93WU9sUzRRS0lYQ01HNWZOQ3lwVzB2?= =?utf-8?B?MXJIKzh2Zzg2YUpDSnZEc2VIN21pdjBXRnhEVmxWLzFGUEN1WTJhQkdodGV0?= =?utf-8?B?Z1BwVFU2SHFRaG9FZjlQTWRoMncvMElza2lBd28yeERudklKK2xnaGVuNmFI?= =?utf-8?B?TW1RaEZGZHV3NTBHWm1mRGNBK1hZKzl0SHBSZXBhQm5YS1RrOW16NUthYlE0?= =?utf-8?B?a2pMOWswK3l0eW1TNkNFVHUvMVpYY09NejI2b2Q1VmlSblB1dXBYTXN5S28y?= =?utf-8?B?cTM5Z1ZRNE83Z1hYek9od3VnL282RlVUTFBQYlc0eEhPNUpkZ3FHK2cxa3hv?= =?utf-8?B?bC9YT3ZqeGdpOWFmYUFUdGE3c3YxYVdYRGxxV1k5bEU5S2Z1RVphWVY3aDNt?= =?utf-8?B?TmNHbDVvSnp1M0RHOE9zRVVNeW9aM2RQOGkySDcweVRlL05Lb3lsZXhiWEpS?= =?utf-8?B?QUI0cEtMSkE3d0R3cFFQZTllUW1yZGtRZ010eC9ULzBPQWZSaEI0OEZIQ0dW?= =?utf-8?B?WVF4NWpNYnljQUh0enJNMWlYVkExNDBCbHY3VmVtNWM3YWJGUlNETU4zTE04?= =?utf-8?B?bmRYdjkvcFl0ZDRPWWFhT0c1NjViT0pXZmorVjQ2MFhJVzN1WWxHZUNBOFlp?= =?utf-8?B?WVFqLzFqd2MreC90NWljbTVENHlHUnh4UE1KdE1vVXE3SW9VOG9mYjZRb09p?= =?utf-8?B?cm9HejdWbjZLVGdEdjd4MUtvbVFIcnNlSnV6VjdQZUZjajRFaVdQUEJhMG1s?= =?utf-8?B?cEl0dEE0ZHAwZG93b2NHWHNyN0lVT0sra29ZM3BXTERyZG1WT3hkTHA2U05o?= =?utf-8?B?SXRneWlEZXRrT2dYek5YMUY2Nkl1bndGbEdIVmwrYUE3TlRyRUsvcGhvU3lk?= =?utf-8?B?NzI0THd1VWtGQ00rY1QwS09Ma3lBN1ZEVEUvNmMvbFI1NkFzUU91eSs5NHNv?= =?utf-8?B?MnRFUU1hWGsyc3hNd3JEYTRRRjhrQ29ubVl6SElRVXhrWEs3WXR0SmtKSTlz?= =?utf-8?B?a1FOd3pUeU9JdUpqWVZSOUI1aFJTOWRIK1pxcFZDcTJHdU9mUnR3VHdEWSt0?= =?utf-8?B?dE1YMkhXYXZiZDNPZ3BGemxLcTRLbk9vWXhWOXlkNFU3REJqOTEvenNXNnkv?= =?utf-8?B?N1htNGwwUGxyTTZVMWZDZ1ZDYU1KS3ZRQnYwMWRoNUNBTWVtQTRpenU3Y0JM?= =?utf-8?B?MVIwRlk3VzFWUVJxeklsY3ZrMkRaTHM1QWxEbjVFSUhYbDQyN3U1QytpS0k4?= =?utf-8?B?MVFSaUQ0Q0NWL0Faa0lvMzVoU1Nic1loWjV5MlA4MkwxbVE2ZXpsYk5HSGtG?= =?utf-8?B?VjVWV01BVVJwY1NmTkg2SWlueldnTGw3aEhDTjBUbHdPUCtzUWZHa2d5YXdW?= =?utf-8?B?d1dJY0RwMnc0WmtsUm9IS1o4dm5sWmtYRVpaY1RhUmNKdWdzdnhxaytZc1pC?= =?utf-8?B?SEZEQzBVY3dPeENaUzhYbjNUOHRIRGZvSUFoRDRWWkV4STA2dlFWWE9OWFIx?= =?utf-8?B?d3l5bzkxWmRtZEJVK3ArUWV1MGE2aEgxNHhvL1QrZG5OSGk0WlVQTkhocEtY?= =?utf-8?B?VTVPdGljK1dTUVJ6cEpLRDlhUFRuM0hSM1JIQzZBNWNqV2FDUWpHY3cxU3hh?= =?utf-8?B?SVpCWXRKYkNLeU1BajBGNUVvd21kVTZLTW1qa1lURGRwYk9nelNyR00rZlhv?= =?utf-8?B?VWsyQk9Ga0NBUDFwZTRLL3FHWUZPRjlIdE0xWEVWellYNURNRVFIcU5sU0p6?= =?utf-8?B?WmRrMmxpWXZld3pxbDRISlNQOEtLK2tOd1VTSzdrVTRRb1NZYTJoNmcyeWZJ?= =?utf-8?B?NnVMdUVTazd0RXF3cElwRkFLOXNndSthUTlJS2ZVYndKS1VVcnVIRlhXOXJx?= =?utf-8?B?eGJLeWFkNlEyWVA1ckF2T1ErcmhkTUNRQTQvZUVJZjZRYWhXQUwxVVFjMjlT?= =?utf-8?B?VHIxWXU4ekYwUFozSVcvb3dQb1hJT09DNUZCei9hVzVkMDRTdm5UWUZTemVT?= =?utf-8?B?dThWbk9CcmlJaUJzMThrTzd4WnMrZTZtS2plNjFwcGtoZlJZNzI3VmNsbUxD?= =?utf-8?B?UytNbDBuT1BJbzFIZ3RLZlRvOEdzblVHTUplT3Y1YnBUM0R3VTdJOW5CUWpi?= =?utf-8?B?djB4bEdOWlk5dXk5MzUxZ2JKczR1K2draHU0aXBtTW1WUmovTkJvcFNyVDhL?= =?utf-8?B?K1BMdlJJS21ZYnRHazFSck9qS0ZlMnEwZmZQblVKMVQyZzFXV2l1ZjJ0eWJq?= =?utf-8?B?a2VjZ0ZBY1g2S2RCRmpNNk9EZlVHaCtjK1FsSHB0K3hmQmE0Q3RzdTBNa2Vn?= =?utf-8?Q?K+9/cozQmDJ2xOVV8pOrm3Ihh7dH6ouLHj9lR?= X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 6430277c-a4da-4bc0-ccbd-08dec131c8d7 X-MS-Exchange-CrossTenant-AuthSource: PAXPR04MB9422.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Jun 2026 05:34:30.1426 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 41O/BlE+pQAzAi4rvozPR/TPfZlGk+N1wxZ6UsGMqFSZeh3uQBCTqLEqf+lk2OglundT4aJMh43bIkWmPdyYh34RZ2IIPlOrqhA/tfzy7PO4SZhi02vlkJrjr0Q8fv36 X-MS-Exchange-Transport-CrossTenantHeadersStamped: AS8PR04MB8150 From: Xu Yang Add runtime PM to ensure the PHY is properly powered and clocked during register access, preventing potential system hangs. It guards register access in the following scenarios: - PHY operations: init() and power_on/off() callbacks are guarded by phy core - Type-C orientation switching when PHY/Controller are suspended which needs explicitly care - Future PHY control port register regmap debugfs access Signed-off-by: Xu Yang --- Changes in v3: - new patch --- drivers/phy/freescale/phy-fsl-imx8mq-usb.c | 60 ++++++++++++++++++++------= ---- 1 file changed, 41 insertions(+), 19 deletions(-) diff --git a/drivers/phy/freescale/phy-fsl-imx8mq-usb.c b/drivers/phy/frees= cale/phy-fsl-imx8mq-usb.c index 591ddf346061..b0092c34416e 100644 --- a/drivers/phy/freescale/phy-fsl-imx8mq-usb.c +++ b/drivers/phy/freescale/phy-fsl-imx8mq-usb.c @@ -9,6 +9,7 @@ #include #include #include +#include #include #include =20 @@ -136,17 +137,13 @@ static int tca_blk_typec_switch_set(struct typec_swit= ch_dev *sw, { struct imx8mq_usb_phy *imx_phy =3D typec_switch_get_drvdata(sw); struct tca_blk *tca =3D imx_phy->tca; - int ret; =20 if (tca->orientation =3D=3D orientation) return 0; =20 - ret =3D clk_prepare_enable(imx_phy->clk); - if (ret) - return ret; + guard(pm_runtime_active)(&imx_phy->phy->dev); =20 tca_blk_orientation_set(tca, orientation); - clk_disable_unprepare(imx_phy->clk); =20 return 0; } @@ -620,16 +617,6 @@ static int imx8mq_phy_power_on(struct phy *phy) if (ret) return ret; =20 - ret =3D clk_prepare_enable(imx_phy->clk); - if (ret) - return ret; - - ret =3D clk_prepare_enable(imx_phy->alt_clk); - if (ret) { - clk_disable_unprepare(imx_phy->clk); - return ret; - } - /* Disable rx term override */ value =3D readl(imx_phy->base + PHY_CTRL6); value &=3D ~PHY_CTRL6_RXTERM_OVERRIDE_SEL; @@ -648,8 +635,6 @@ static int imx8mq_phy_power_off(struct phy *phy) value |=3D PHY_CTRL6_RXTERM_OVERRIDE_SEL; writel(value, imx_phy->base + PHY_CTRL6); =20 - clk_disable_unprepare(imx_phy->alt_clk); - clk_disable_unprepare(imx_phy->clk); regulator_disable(imx_phy->vbus); =20 return 0; @@ -686,6 +671,7 @@ static int imx8mq_usb_phy_probe(struct platform_device = *pdev) struct device *dev =3D &pdev->dev; struct imx8mq_usb_phy *imx_phy; const struct phy_ops *phy_ops; + int ret; =20 imx_phy =3D devm_kzalloc(dev, sizeof(*imx_phy), GFP_KERNEL); if (!imx_phy) @@ -693,13 +679,13 @@ static int imx8mq_usb_phy_probe(struct platform_devic= e *pdev) =20 platform_set_drvdata(pdev, imx_phy); =20 - imx_phy->clk =3D devm_clk_get(dev, "phy"); + imx_phy->clk =3D devm_clk_get_enabled(dev, "phy"); if (IS_ERR(imx_phy->clk)) { dev_err(dev, "failed to get imx8mq usb phy clock\n"); return PTR_ERR(imx_phy->clk); } =20 - imx_phy->alt_clk =3D devm_clk_get_optional(dev, "alt"); + imx_phy->alt_clk =3D devm_clk_get_optional_enabled(dev, "alt"); if (IS_ERR(imx_phy->alt_clk)) return dev_err_probe(dev, PTR_ERR(imx_phy->alt_clk), "Failed to get alt clk\n"); @@ -708,6 +694,10 @@ static int imx8mq_usb_phy_probe(struct platform_device= *pdev) if (IS_ERR(imx_phy->base)) return PTR_ERR(imx_phy->base); =20 + ret =3D devm_pm_runtime_set_active_enabled(dev); + if (ret) + return dev_err_probe(dev, ret, "Failed to enable runtime PM\n"); + phy_ops =3D of_device_get_match_data(dev); if (!phy_ops) return -EINVAL; @@ -735,11 +725,43 @@ static int imx8mq_usb_phy_probe(struct platform_devic= e *pdev) return PTR_ERR_OR_ZERO(phy_provider); } =20 +static int imx8mq_usb_phy_runtime_suspend(struct device *dev) +{ + struct imx8mq_usb_phy *imx_phy =3D dev_get_drvdata(dev); + + clk_disable_unprepare(imx_phy->alt_clk); + clk_disable_unprepare(imx_phy->clk); + + return 0; +} + +static int imx8mq_usb_phy_runtime_resume(struct device *dev) +{ + struct imx8mq_usb_phy *imx_phy =3D dev_get_drvdata(dev); + int ret; + + ret =3D clk_prepare_enable(imx_phy->clk); + if (ret) + return ret; + + ret =3D clk_prepare_enable(imx_phy->alt_clk); + if (ret) { + clk_disable_unprepare(imx_phy->clk); + return ret; + } + + return 0; +} + +static DEFINE_RUNTIME_DEV_PM_OPS(imx8mq_usb_phy_pm_ops, imx8mq_usb_phy_run= time_suspend, + imx8mq_usb_phy_runtime_resume, NULL); + static struct platform_driver imx8mq_usb_phy_driver =3D { .probe =3D imx8mq_usb_phy_probe, .driver =3D { .name =3D "imx8mq-usb-phy", .of_match_table =3D imx8mq_usb_phy_of_match, + .pm =3D pm_ptr(&imx8mq_usb_phy_pm_ops), .suppress_bind_attrs =3D true, } }; --=20 2.34.1 From nobody Mon Jun 8 06:38:20 2026 Received: from PA4PR04CU001.outbound.protection.outlook.com (mail-francecentralazon11013041.outbound.protection.outlook.com [40.107.162.41]) (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 8977737B032 for ; Wed, 3 Jun 2026 05:34:38 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.162.41 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780464880; cv=fail; b=SZ+ni8KF2/DY0uUWsQiJdkCbkrXm8j9yCG2GMX+zP6Nbb41zSZP5wiXDS16vK2vNL8Fu0WkiF4xYqpW/GIfYocJKiWxwpDhtOnB4S89J9kuDGKuzHEVqbhGLJV455Bn1S+yqNcgzTl9AW/pU1FjXv1bUHGzvXJwKItVA+vMkf6k= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780464880; c=relaxed/simple; bh=k1zFy5T+zt+KO555Ji9eLQGix60NX84CvxCZeHIsSU8=; h=From:Date:Subject:Content-Type:Message-Id:References:In-Reply-To: To:Cc:MIME-Version; b=WhE7Tuf6wsQy9r5HdbRIXgRFJmVOTbhKcNkh6jM+HSMX52h3FoFJRfH4/KPkAYDX16rzWSpI8mo5/wCjQapyqwai2quSdQbJtLI4BeiBKnn6me+F/Q2i6exneRwPk90usVl6BLqDy5zf/fY2PERRZTABdIzYR4svnxFfDggxnWw= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oss.nxp.com; spf=pass smtp.mailfrom=oss.nxp.com; dkim=pass (2048-bit key) header.d=NXP1.onmicrosoft.com header.i=@NXP1.onmicrosoft.com header.b=MwQjPcNd; arc=fail smtp.client-ip=40.107.162.41 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oss.nxp.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.nxp.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=NXP1.onmicrosoft.com header.i=@NXP1.onmicrosoft.com header.b="MwQjPcNd" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=ShQqyX+2O4XS3VzD3tROmo6y8zf1aDDnSn4QttT37X22219aKuYdiXvqje+Ou4I4C56FNp89ZQ4bFgiDxsmNF5anO8Ou90K6Vt5MzwO3enhTjjv6rSUGOSU98xD6J6Aqqbm74b10LnGF2OHetIq4kHvu1MTX62cndyuKMSDqCI1V318s3WIzpPHRytuAMT6bRI8yd3YPWAllNUvt/Ftc7LgYGRUjf0JSjkgAQ0vMjk1qW66z67yoyvRUkm6uw4qXsBeKS3JzNWs84GNqqgJ2QsAP4F0v9UDgPhUgRTOdnHgUy+JcNCjYTeiMPRBEc363+kQpJLo3JNbMbvJ8rsAQzg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=Nt+OeIiZC6xw0TYAX7LYrBBfk/8tBSxXm0WiKMs0Ytw=; b=dAcwtjaQzHj93cnPUHyRUTDupFxLBECsB94ZZTQBLfu5pgF5m9ZTAiee8mIGSG6XW9o4QqJZ7pIdLM3ByfGAzKwXxwMbtv99nI8JLIw86guPVVLU3DpQBbx1nigF4dNJ8uW8Dpp2eWMETJZOzSLXUgb+yRDexLpEZLGFBHlp0h9CXNWPLhlUXWWMTuDNKctcdfReLZCiNDB1jdwvZ9hOXnkRBGgYzcLSBhkp3jWduSXygnr5dw1Fa+J8A1liJ2/hct3ZiJJBxhQumzuq4JQKzcz1tGXVzE1wm/wJbmtyV+kqpxsYgThpRwSL2TAPWXRN0K+NRPdZwGDQCFLgu7anJw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=oss.nxp.com; dmarc=pass action=none header.from=oss.nxp.com; dkim=pass header.d=oss.nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=NXP1.onmicrosoft.com; s=selector1-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=Nt+OeIiZC6xw0TYAX7LYrBBfk/8tBSxXm0WiKMs0Ytw=; b=MwQjPcNdjQ8PuTvEkSgHLwmjMhxdg2DsRkdZZ47EmjWZIqZb7Olv4hFRYSzYGGJtXpilVxx+B3LnxQTyRpfOEUhRfB1hgSzqvbtqhILZcsEXb0ZiwbVBaLhJ8cbFeeWQsNF1l0LNbzaeX6sN6/c+4q5PFXMvwePgKwC/H5wACgfpLguftnsZlHtkD88Wyla4/aad+dKkQX5cJLoP18jhb0t/ibLMnrwZkud9Y1ddU8ZJQx8Os4CxeGHlmII6vvRaqvkAIhy/ZyFoa+nRFR2P7qjBgo1MbA1k2Ul5il6JW7K562udJzNdiffnFwQ198CJlaXkv4fpqaaqVyXNr3V3dQ== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=oss.nxp.com; Received: from PAXPR04MB9422.eurprd04.prod.outlook.com (2603:10a6:102:2b4::21) by AS8PR04MB8150.eurprd04.prod.outlook.com (2603:10a6:20b:3f0::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.92.7; Wed, 3 Jun 2026 05:34:34 +0000 Received: from PAXPR04MB9422.eurprd04.prod.outlook.com ([fe80::54e:28bf:aa85:d25d]) by PAXPR04MB9422.eurprd04.prod.outlook.com ([fe80::54e:28bf:aa85:d25d%4]) with mapi id 15.21.0071.015; Wed, 3 Jun 2026 05:34:34 +0000 From: Xu Yang Date: Wed, 03 Jun 2026 13:37:17 +0800 Subject: [PATCH v3 4/5] phy: fsl-imx8mq-usb: add control register regmap Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20260603-imx8mp-usb-phy-improvement-v3-4-7afb8f89abc6@nxp.com> References: <20260603-imx8mp-usb-phy-improvement-v3-0-7afb8f89abc6@nxp.com> In-Reply-To: <20260603-imx8mp-usb-phy-improvement-v3-0-7afb8f89abc6@nxp.com> To: Vinod Koul , Neil Armstrong , Frank Li , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam , Jun Li Cc: linux-phy@lists.infradead.org, imx@lists.linux.dev, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Xu Yang X-Mailer: b4 0.15.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1780465041; l=3073; i=xu.yang_2@nxp.com; s=20250815; h=from:subject:message-id; bh=i3uz3mgzoRinmbGZIGPs0vdmGXlsJkbN2arPhg0BuEA=; b=eeG2K4NqN5umAAVkD8jFWd0nsmnk0NQgm8AJqc6CEHxcd30YPMwyFm+TsGQlZa8xsbmcO0EI6 SVhGpMTTE/GBqGW8lVKilhDjl51NguM3Dk3jwyVjenaTDatVZFdBCg+ X-Developer-Key: i=xu.yang_2@nxp.com; a=ed25519; pk=5c2HwftfKxFlMJboUe40+xawMtfnp5F8iEiv5CiKS+4= X-ClientProxiedBy: MA0P287CA0009.INDP287.PROD.OUTLOOK.COM (2603:1096:a01:d9::9) To PAXPR04MB9422.eurprd04.prod.outlook.com (2603:10a6:102:2b4::21) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PAXPR04MB9422:EE_|AS8PR04MB8150:EE_ X-MS-Office365-Filtering-Correlation-Id: 75c8ce0c-daa3-4582-f630-08dec131cb93 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|19092799006|376014|366016|18002099003|22082099003|56012099006|11063799006; X-Microsoft-Antispam-Message-Info: a+SS6K9prcs4npSoRVwSyp2n4ZkxNiiiSVJ3l3SCrcTsTWE+/niXRAYwU9TqM/pllGdh4kHfSBunSUYWeL9LrknT5cEirygM50tbdC3QiXpfk3MjRk5d5tPicUmSlHBWpZxthYt7jsexRLYM5TjXMxM0wVxB4qCy9ACsaezy3rbepcewAfsIUxIARcuGYJ9qQtU34atM/BQDJ8GRNFRE9a5v9K2rlokCLpxcxchflJkyQXGRJeEndMHnDTcumuNUpoMIsXRVPSGbACwOmis1AaAvyguJGJkJNVq+wU7X7DOECPpM/okyWAbNvhCij7c2TMC4YCkQNSLmyUufV5xzj7rv0tW7cTuSVAJIcFCeYAqW9TIfkxmQy4+ASOj/c7cvYDOfUkxFMDHRXf5hdgBBWKwZ8/D22Gzh9ttO/yjJmgkd0V5/9PnIITedQTqSyAzfWuS+e08uquRsA0hyDzu1ILNeKgWT0Yj7LcocpLtAOkWauHZEQppO2bfc0/HvEdEBGZ2FrIROkrM88lzmSV2KteyfVJgzqY50f7/QgQyDBVs5BNOw/ff0dh8J+q4G/dgtpMHesuPTxt2XkeWXL+qETkwNPc5kR0HLcWUgDYSicWKPRdSuEegsFtw6Sz0LGxhkzo3M4KnlDxCFsxbEw4hs69RmuYv9nAM9ar/pIoVt6OLN8HqfdZdyaOtJ2BE9bhql X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PAXPR04MB9422.eurprd04.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(1800799024)(19092799006)(376014)(366016)(18002099003)(22082099003)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?B?a3JDcHZlaW50WWJ6WFlaWTBZVVM5QjJEZlo1WFBsZTBZVGtnT2djMmZxNzFk?= =?utf-8?B?ZS9XUEV3Q3VEbDhBN0ExN1lyWC9QNTdWMG5DalY3VHBkK090UHZqL01WN0wr?= =?utf-8?B?OTRwL0gzWkpTd3NkSnIwaDdoYTh2RXVhc21QNy9rb0MxMiswRVJ1NWl0cEJB?= =?utf-8?B?Nm1ZdklJTlRVVTBkeTlXczJtVm8xU1hPSWRDUk0vRERRSzcySVZLQ2Z3K1BV?= =?utf-8?B?Y1NRSzd4Qy92QUp3SWRyTjUrNUw5b01ZTFY4WnJwdmdnYUFnQnBiUDROSXcx?= =?utf-8?B?bU1HUi9FTGdXS1NiUGprNUhidVlycnlJbVo1YXVDSklMZ1BWZEd3ZmZzbEtH?= =?utf-8?B?Ujl0UWlMazVxNlVuR1Z2anliTEl5eXN0V0pBNFI4bWFDa291bkh2U3YvTzNl?= =?utf-8?B?Tys1aFE3MHlhTzYvVE9naENKQ1hkTXBkV0tGNEpxUXFBUFUxcVZncitCZkVm?= =?utf-8?B?dkk1RVJ2Rk5yY3BpdlpvTXp0UDJwbytVbExaNDBBUEhPSnN1Wmw3NDl5TzMx?= =?utf-8?B?SXJSSEZLM0l5S2JTa2lwVHdGandnRFlVS1FXcndEdUVXN2gwdlN1UktubVNl?= =?utf-8?B?THlWRGpEQ2Z0cFlIUUJDWmZNN3VsSndTOUY2Z2ViNUFscUNZbGtrWVBaWWdM?= =?utf-8?B?NHZoblkzMitqejdtSXFza1BERUlvcmYxQnNzUWF6ZUNLYVB4ZEJXb3FQQThs?= =?utf-8?B?TWdZdEVRblhoRzRiWVdJNmowenhwUDAvVWEyMzNzTUNiK0I1RjhBTE1PMS9F?= =?utf-8?B?VmRrbSsrQWw3dlRvQW1Ba0p2R0JjSzZPeDlDcG9OMWJIcFVEMlJvZVdJelRa?= =?utf-8?B?Q3MvYTJYYkFFRTNZRjZYd0dlUUNkL0l5WjBxeWhhVkEzaU4yZEhha3hDVkRh?= =?utf-8?B?a21RNVhHNEdOVWE0cDRRNHJIZEpQWHhSOGE3Nm1nSGlhQ1pCclJlam5Rcjcx?= =?utf-8?B?Y21yK1p1eXcrOG81eHIzMDBDRDFRZ0ZCZjU1NTNFWVB1aXR2ZUh4S2RPZ2tB?= =?utf-8?B?UUJhQkkzckk1N2o3aUNkMHI4STlkSFNBK3huZzB6N1JVYUVPR09pNEJYNFdT?= =?utf-8?B?ZENNdkJEMzBBK3J6c3dkdHFTTW5xdHB1VFhodGxpeFZoc2tUR244TUcxWTBr?= =?utf-8?B?MjFPdUlqanRyVUUwdWR2WUtreXdPcVpTMENueTFvTDZiUHlPTTRYU0pDN0xT?= =?utf-8?B?SHNSejlsdXAyV0V6Y3ZEcDdFNEU0OWJ0ZWs3a1FrcTY0WjFzUUx1R3k1eDFI?= =?utf-8?B?WXR3RmhkT3FWVzNTS0czZ3Y3UStGaUMwMGRIYVRodEVhbTl1QTU3U2xkbGJy?= =?utf-8?B?a2ZUbkdxZWxEdy9YTFFWWjBLK3F2OW1Gamdaay9POU1uQkZ3T0x2MjVNWFhL?= =?utf-8?B?NEpvVlZuNlVxN3Z3MlJITEtDMUthS2EwQjB2UnlkWkwrUGRJUjJVcWxSMXlu?= =?utf-8?B?LzhWakNaMzBGM3RiSWgvMU9LY0k5L1l2SGpiL0lpbXIyaExtUUZqM0J2WFJW?= =?utf-8?B?ZUlmVytBN3lybmg5U1k4NndId2ZObFRxemJ3a24rZk5jUnlGcENlc0tOOWly?= =?utf-8?B?R1VEdCt3UVlHL2RZZ0tWQlZRaFJ0T0t2UVBZb1FPOWRpMTNSMlkwR05FWHJl?= =?utf-8?B?S09VcTVCVE5pUjRqMVhqdkZXYlpIL3ROWEw4TldMUE9vREhMU2d3WC8ybmlk?= =?utf-8?B?ZlQycVBIRG1nQXVwczlOeW5sSnNhdEhkWmhoeEFhbHdpSVdlMGMwWFYxaVNj?= =?utf-8?B?aTl0eG1KSWNpWU44YUVoZlhsaUVRVE1iaGtmckRTNU9sSTJza2hYZk52Unll?= =?utf-8?B?bmFNR09MUGVPei9la3oyUDNHaWJ0dW1qSVpsVDIyd0hjNit3VVk3YnR0YzBL?= =?utf-8?B?MVFFWmtNUFNjMGRiRkx5YlpwTFFtcllpeTlWWmFEanRObWt6RWpmYnpwYVZu?= =?utf-8?B?UDE5Y2k3NWQwYVlGYllmdUlCZTFkT1RqOUhQMVNUWU9TdGlHMDhBaHFHWmNX?= =?utf-8?B?TUdkckNhSVJqUmU5VUJRTnZTeFlvMml6a1hBalpsZHdla2l0VUVCMi9JVy8r?= =?utf-8?B?emx4Y1NGUUdXNlhrVFFiem1za1hlM1RYVndMd1lEc0wrVUVaWWNaSjdadGx2?= =?utf-8?B?K0hpN2lqelMzVjlENmlkQUpWck4vSUQ2MzRieVhBYjVDcEluMFFIQUhDSDdo?= =?utf-8?B?NXNaZnlBek9aTmQ2Q0RDNnpQQldkWTJESEFWMWdTMmZ0VEZ1Ni96MkRJTDhE?= =?utf-8?B?WndDNFkwRlNTOXZxZTNhTWNkakdmZVQxNTNXU2d2MzQ3Yk1EZnhGM0VEemtJ?= =?utf-8?B?VGJleEsraFdSRnFHNFVxMmQ2UFVkdWRmTUg5V1hNUzltemlWUE1aUXVUYlZZ?= =?utf-8?Q?vZ7Q6Vm8xH+IjeRba2kuJgqG6KxQpdBpEnqaR?= X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 75c8ce0c-daa3-4582-f630-08dec131cb93 X-MS-Exchange-CrossTenant-AuthSource: PAXPR04MB9422.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Jun 2026 05:34:34.7548 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: sgF3glrB8JScURjN4dM0aXb5KDVSDq9q6FF3zwGFbuZPlrQ7w1USRvT+vNpTO3SkNcLcUUSZ2E+TdidmoOyjFLGVlcKCrJ5yByjpk6wdIpf3KW8L86zagu3jRFYeAk9l X-MS-Exchange-Transport-CrossTenantHeadersStamped: AS8PR04MB8150 From: Xu Yang The CR port is a simple 16-bit data/address parallel port that is provided for on-chip access to the control registers inside the USB 3.0 femtoPHY. Add control register regmap and export these registers by debugfs to help PHY's diagnostic. Signed-off-by: Xu Yang --- Changes in v3: - drop Frank's tag because it includes other changes - new patch --- drivers/phy/freescale/phy-fsl-imx8mq-usb.c | 27 ++++++++++++++++++++++++++- 1 file changed, 26 insertions(+), 1 deletion(-) diff --git a/drivers/phy/freescale/phy-fsl-imx8mq-usb.c b/drivers/phy/frees= cale/phy-fsl-imx8mq-usb.c index b0092c34416e..cda88ea1f12d 100644 --- a/drivers/phy/freescale/phy-fsl-imx8mq-usb.c +++ b/drivers/phy/freescale/phy-fsl-imx8mq-usb.c @@ -1,5 +1,5 @@ // SPDX-License-Identifier: GPL-2.0+ -/* Copyright (c) 2017 NXP. */ +/* Copyright 2017-2026 NXP. */ =20 #include #include @@ -11,6 +11,7 @@ #include #include #include +#include #include =20 #define PHY_CTRL0 0x0 @@ -56,6 +57,8 @@ #define PHY_CTRL6_ALT_CLK_EN BIT(1) #define PHY_CTRL6_ALT_CLK_SEL BIT(0) =20 +#define PHY_CRCTL 0x30 + #define PHY_TUNE_DEFAULT 0xffffffff =20 #define TCA_CLK_RST 0x00 @@ -119,6 +122,7 @@ struct imx8mq_usb_phy { void __iomem *base; struct regulator *vbus; struct tca_blk *tca; + struct regmap *cr_regmap; u32 pcs_tx_swing_full; u32 pcs_tx_deemph_3p5db; u32 tx_vref_tune; @@ -665,6 +669,14 @@ static const struct of_device_id imx8mq_usb_phy_of_mat= ch[] =3D { }; MODULE_DEVICE_TABLE(of, imx8mq_usb_phy_of_match); =20 +static const struct regmap_config imx_cr_regmap_config =3D { + .name =3D "cr", + .reg_bits =3D 32, + .val_bits =3D 32, + .reg_stride =3D 4, + .max_register =3D 0x7, +}; + static int imx8mq_usb_phy_probe(struct platform_device *pdev) { struct phy_provider *phy_provider; @@ -694,6 +706,13 @@ static int imx8mq_usb_phy_probe(struct platform_device= *pdev) if (IS_ERR(imx_phy->base)) return PTR_ERR(imx_phy->base); =20 + imx_phy->cr_regmap =3D devm_regmap_init_mmio(dev, imx_phy->base + PHY_CRC= TL, + &imx_cr_regmap_config); + if (IS_ERR(imx_phy->cr_regmap)) { + dev_warn(dev, "Fail to init debug register regmap\n"); + imx_phy->cr_regmap =3D NULL; + } + ret =3D devm_pm_runtime_set_active_enabled(dev); if (ret) return dev_err_probe(dev, ret, "Failed to enable runtime PM\n"); @@ -729,6 +748,9 @@ static int imx8mq_usb_phy_runtime_suspend(struct device= *dev) { struct imx8mq_usb_phy *imx_phy =3D dev_get_drvdata(dev); =20 + if (imx_phy->cr_regmap) + regcache_cache_only(imx_phy->cr_regmap, true); + clk_disable_unprepare(imx_phy->alt_clk); clk_disable_unprepare(imx_phy->clk); =20 @@ -750,6 +772,9 @@ static int imx8mq_usb_phy_runtime_resume(struct device = *dev) return ret; } =20 + if (imx_phy->cr_regmap) + regcache_cache_only(imx_phy->cr_regmap, false); + return 0; } =20 --=20 2.34.1 From nobody Mon Jun 8 06:38:20 2026 Received: from AS8PR04CU009.outbound.protection.outlook.com (mail-westeuropeazon11011027.outbound.protection.outlook.com [52.101.70.27]) (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 E964737DAA4 for ; Wed, 3 Jun 2026 05:34:42 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.70.27 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780464887; cv=fail; b=GuYO/46R6fFBlmcR5k2B13GG7c97jaVBl4WzzgUPre52jbTcLBkICIRV3Ea8DEPi9HTIJlJgNL4BMLR+UgtYbN/SxGlvqWkGEWgN846rGC5EP/zQVisl665sxgMtBWXsawts6UZXGidg3XFkAEqZPgbevjS9USyjGv6BdoPoT8U= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1780464887; c=relaxed/simple; bh=Lp89TCB5aqjCYfXCLQCpYZM2IWx5adxRXq++uV9Pg0s=; h=From:Date:Subject:Content-Type:Message-Id:References:In-Reply-To: To:Cc:MIME-Version; b=s/NfWa/WE3YJkjBUyPkWKKtbRITnzzTDvQkSwcGNlEs8LR06QfHHDdOmOe0W64mfGWzznCenj39er5vHSwBKVXKteB8SnNbchUAfdMTGpNoL6XNXgou2rU731omxNmGRZN0dIexHgQAm6lmGZMHZOHDajayn/wKtvt8CS+AzfN0= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oss.nxp.com; spf=pass smtp.mailfrom=oss.nxp.com; dkim=pass (2048-bit key) header.d=NXP1.onmicrosoft.com header.i=@NXP1.onmicrosoft.com header.b=Ui3i39fV; arc=fail smtp.client-ip=52.101.70.27 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oss.nxp.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.nxp.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=NXP1.onmicrosoft.com header.i=@NXP1.onmicrosoft.com header.b="Ui3i39fV" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=k75l9nLdIXjm7skPXY7OdR9azO9PJCbT4xKAF/m4FyvADGD+nI9JvA8S8UDgNhtCOnUeKOEVlh9Z3H8cjcgFz2XElXK4iRcay1gPUOz0y7RWrm40WmhNTmLSuBnPG894MnrC7pZ2yZZCWnmYRAJIMFgNfgmi4784n6AwH6x3lKKnXZ2zaFeMQr6fXh6w9pg+Fku/TyQFV/2Al5tE5urgtoWRV8+5oXlVakc0IE+dGyoEnkPSAdqzJu8QZRGHU9t6vnsSCyKUtSLEg+jPzuFBv0Z2IMjSjTRyF7CaFMB8uGoQnvGANwI/M3me5sSW5q2jCZ3TwTX+lpC9LbHq5JgkBw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=VYiGaFr68OgJHwMU2weoYosP1dcQtWbOBNfSKfg3nb8=; b=HRVP6bQ1o2We4AYY0qldV2Dv38jJmVEHeysUf79bQJM0d3DA+prhJpBk9CivroAF6uNYO6AlRIAaPrzCK0eafAYpfAYvdiUrRgkHVu4W6z87SihE7R1CEh1SSCWGAUdRxd1TYmPRovG7wKZrDZpvRXUXAXAN0SiGkKMQpEY7ruODJEfo/JM4mwPLmXRHqrJGkbQQVyf+KOayvSO6Z01dVdUg4pQJbbPFX/F/b3w9Sr9sJFDbE1s8qnpnGyE66Ig7JuqL8EXxCOgNmIlNgeNc23In/5xBGevrNnG6NJCWtyrLeeUjCx8aiDSWmGZoSAQDbagbNfzmZawueW5e9Cr+yA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=oss.nxp.com; dmarc=pass action=none header.from=oss.nxp.com; dkim=pass header.d=oss.nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=NXP1.onmicrosoft.com; s=selector1-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=VYiGaFr68OgJHwMU2weoYosP1dcQtWbOBNfSKfg3nb8=; b=Ui3i39fV7k1BhuxTL14TokWDxx+M/RodnwjaUUYG+wS301y1/2ESE7L9pp1rsNtJsQpFKcczKfElMHmUEgdgEnBAu/+jUqdDAbFvh+pq9Tlxo/Hp3sHr4i2S91WmO17v/YthYqydYIr2EyBo6QnrB6W+8G18VKKsvpmCOYaQc/ZzgTeIDq0bgHdXyjCPyVIItn1r1RDbiL2dwOgqfObG2LjiuWdUZVINrgh94fYdg4oahho1A7ULehsPObzRhQ0BhGQlXx33AEE2VbzD1nPt2bTqla+DrbmPnEwUV1R1/WaaLAtGM9eQxtDxSt7B3Wy9vwPLLy82bUtPcEkdp6LuVw== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=oss.nxp.com; Received: from PAXPR04MB9422.eurprd04.prod.outlook.com (2603:10a6:102:2b4::21) by AS8PR04MB8150.eurprd04.prod.outlook.com (2603:10a6:20b:3f0::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.92.7; Wed, 3 Jun 2026 05:34:40 +0000 Received: from PAXPR04MB9422.eurprd04.prod.outlook.com ([fe80::54e:28bf:aa85:d25d]) by PAXPR04MB9422.eurprd04.prod.outlook.com ([fe80::54e:28bf:aa85:d25d%4]) with mapi id 15.21.0071.015; Wed, 3 Jun 2026 05:34:40 +0000 From: Xu Yang Date: Wed, 03 Jun 2026 13:37:18 +0800 Subject: [PATCH v3 5/5] phy: fsl-imx8mq-usb: keep PHY power domain runtime always-on for i.MX8MP Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Message-Id: <20260603-imx8mp-usb-phy-improvement-v3-5-7afb8f89abc6@nxp.com> References: <20260603-imx8mp-usb-phy-improvement-v3-0-7afb8f89abc6@nxp.com> In-Reply-To: <20260603-imx8mp-usb-phy-improvement-v3-0-7afb8f89abc6@nxp.com> To: Vinod Koul , Neil Armstrong , Frank Li , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam , Jun Li Cc: linux-phy@lists.infradead.org, imx@lists.linux.dev, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Xu Yang X-Mailer: b4 0.15.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1780465041; l=2555; i=xu.yang_2@nxp.com; s=20250815; h=from:subject:message-id; bh=1S8worVGXuViLFCGKuwX+ce7m/H5ooU9b32ioGpEiCk=; b=NuRmkmtlezaLa0fpKjuVNNFU/I5DtmcmA7rV1CYz1DgUL0UsNvXtrLOD1Mr0UlMe0BMSE6bVw 0vlStUH+3avAmDa5C6gPPBDaXmfPW/aWc5ZERk5Vjv3ccDg3EKqHKgy X-Developer-Key: i=xu.yang_2@nxp.com; a=ed25519; pk=5c2HwftfKxFlMJboUe40+xawMtfnp5F8iEiv5CiKS+4= X-ClientProxiedBy: MA5P287CA0043.INDP287.PROD.OUTLOOK.COM (2603:1096:a01:175::6) To PAXPR04MB9422.eurprd04.prod.outlook.com (2603:10a6:102:2b4::21) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PAXPR04MB9422:EE_|AS8PR04MB8150:EE_ X-MS-Office365-Filtering-Correlation-Id: 9d883366-35d0-4a9a-c7b0-08dec131ceae X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|19092799006|376014|366016|18002099003|22082099003|56012099006|11063799006; X-Microsoft-Antispam-Message-Info: zYMhEzSEG+7/WtKdEYXNVjmLoke+3tLFffQqqgOnOHfU2cTXtAzNOIek5fYVWfPglfyBenopdY7lN/tKpkIilCq6X++MrwZvw7PMQp29PDZGGBnAUuOkh7TB+HSIGQV6lTcqDxBCSLRks7PouTUW2Bo5C93C9sdAmSAVnnFFyWb7ZHFM6c8UhaLxGxjqkancujAnhJb2H0ewlQrNE8E4Ua6sm0XAzrf8ZekSCCsMWqqDF/p8XJBPNRcuvyaIcSvGdS9ct8EMW6UXeYWOE75wOHJsUrWDMwcKjQ97BXWFjo0hdVvk47tUpZ6qEHxlDmGmDcj/G6bqya9CBXhm8kEuO5NnugmVIHBhlDp/om+7SyO76ImDDncwPOO0LvdxL3/oj3eMA6NGtu19fWLLKXQNkFEjrCS4UqHOj3A6hJLzh3UjHgJi1ErJjY5Lqf29uwyqa+ssbauSna9vUYd4RUMyFMGmdO8q01L6bGXBqBY52Qg0riBhxjd27qEnZIh/SlQfUZBGjzI0TTjvAub/Q9W3FoCkslyeN8EEI/+9J6E5OftHa2Ij7kUKCNwO9GAZKruCTei3z91iCZ+5vj/uNy9iUirx7r3kGWdtFhzBEGzFS1Kf+uFIKJlAZ+8qez/b/h9+Cj11nZgMAYn2fleBw2OR78SyrDDcJLNAKpIuD5iCCeRKFwjRQ1mBncm5IvztyqFA X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PAXPR04MB9422.eurprd04.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(1800799024)(19092799006)(376014)(366016)(18002099003)(22082099003)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?B?eThzK2FtZUlaUzRwVFJUdzVOYlBkYnZtd1lrazRjTmFma0ViZVVOSkFTM2Fq?= =?utf-8?B?UnZrUVpsamNXUENUWmkwb21MaXBqc1FkYmQvRWV6Q21KYllSSmE0S2twa0FR?= =?utf-8?B?M1ZRSGtlbGs2dEZzSjJxcHdFb2RQVXAzcDZicko4VVc4bWZwWkZwMVU4QWRT?= =?utf-8?B?K2xWQWJTU0RTTlgyUVRzVG5mNTV0VU8rVER0bnVxaHZNanhieTRoRlRFK2Zx?= =?utf-8?B?U2RlQW9MSjI0VDJURVg5anFIaFQzaGVOd0srTlBCUEk1cFA4MUVGYXVXSlJM?= =?utf-8?B?TmV1ZWpLRHVwVFQwR29IdTVQcTBxaWlwS29IOTBwNkhMWU5VN05NKzVKblNw?= =?utf-8?B?bWJOQU1NTW4za0FXUDBqdFZVYVRDWGlsTHdnczFUa2xEbHBoUHdpOUc0K1RC?= =?utf-8?B?NU1BZDhwZHFUVDZ0eE10dUpLenB4cm1wVHpxRVpwWmF6ajRBMWRlQ3hTSysr?= =?utf-8?B?Y2hSam9YNFhoS2V6a0FFUXUraDRaamlXOU5EYTkxRThFRjFHMDRVNXBVWlNu?= =?utf-8?B?M2NNOEdhSmp6STl6bVBWNFcrclJvcjFIUzNMbnl0UkVmQjIwWnNGVHBwT3Rh?= =?utf-8?B?VmFzejBiczdGa0FXa3I4b0dnNzAzdzQzZ0gwMGsvaVZEUEhsVkhPbm1CU2hy?= =?utf-8?B?ZGhMcTFNeUQvanNpeC9UT1VERnQwczVJdSs3QWRyeC9wb04wb1FQWmFTNjZ3?= =?utf-8?B?eHhDU3Qrb3VYZXNvU3Z6V1dNODdTWThOUFhFQndyZWVUbXlSdXUxd0ZtdUk2?= =?utf-8?B?MTg5THdJL1M3MzZaVVM1WHNPZFV5ak0zczU2YVlKY3RReHY0MXVwMlN5SEha?= =?utf-8?B?Tml4SlVSSmJLejNIU3d1dG1QOEZqMlprZXUrSm8yVjF5ck1QSUpUU3UvMDZP?= =?utf-8?B?YlZMcEdXSFRnVXp6Qm0wRkllc2FCdkFBdUxwYU1ZYUFXQVdHNmJybExZYzEv?= =?utf-8?B?LzRKMnFnc0M1ZHlyNS91NFdLZlNhUEM3a2d3RWM4Q2FUNXFOWTNqZ0UzcWVa?= =?utf-8?B?TlN1ejVvSDYzZGV0ZTdxMlVjaHZhbW1QZ1RtcEI5Z1MzMHNtM3NodEpTOWtS?= =?utf-8?B?U01KeExmMjB3U0w4Ymp3dTQ5dlQvZFF6T283QTlBdjBhM3ZBK2EvYjYzQmxw?= =?utf-8?B?SmRhaFh3MFgrZUVWT1BmNTBxVW5BbmdQK3lycFhtbjFUaHgzTDE0STYzYThP?= =?utf-8?B?TWtRWWZJU0tKYXdKd0Jzb2U5ekFYMThQbmhSTERWaDRNcXE5TndreXpySDFy?= =?utf-8?B?SWdSNGoxZURXSFhXbzRHVWNCT3BaT2JXUE1VK2xJYzdEZFB4V2VWRkJrM0Zj?= =?utf-8?B?U25oZ0FFM2t0WUExRytRMC91T05kQmxmbmphWE9zYUNFQXQyRDZUNDJadXJk?= =?utf-8?B?R0M3dVNJTFNkZWx5em5HRnFuRTUrZ3k1a0lzRWI0cGdpODRPWTNrN1ZORkkw?= =?utf-8?B?NHhVYVhQS3FsV1JrQkoxbWRESFIrcllZWjVyZ1ZyOGFwZ3BmLzhMRDRLa01s?= =?utf-8?B?NEs3bTdrT0V3RDZjUmxMQnZRZFI1MVNVQ3FEVjluanFsdU95cUk5T0ttQktl?= =?utf-8?B?MncreE9MK2taaXJidWZmdGxUcXQyVlE4RlpMbmZZeHk0MENEalF2TWkvUkR0?= =?utf-8?B?OFY3dVVDYzFsdFBYY25nWVZmbUJMcFhqZ054d2NoRW5FQVZGVzdtSHZEQnYy?= =?utf-8?B?SW5pbmQraTVkZHp1Ly9rQlFvTlpyN1dFa2h3anF0dHFYZTJFSFd2bHZ4VEgv?= =?utf-8?B?dXRSVUUrV3ZTMlV6Q3RCc0lwY0FiNkFjZ3lYRlUvNmxvRUFRRWxwMGZpbk9G?= =?utf-8?B?WTZPVjhpSTlWV0RkcEczRWd0RUNCVG1xaFYwWEluc3dVRE5idnd5dWRDUmd6?= =?utf-8?B?RFMwdE1QZTlIakg4OFA2WFIwYXI3Z3U3OVVncHdkNms2RFJmQVdiaGh2MXZD?= =?utf-8?B?U1k4dzc2Zm5Ta1dyZjJQbHpCcWtMZTFPSVZqL25zN2xBNGEwTHRad21PN1BP?= =?utf-8?B?UzE0VXpraE8rcFg0cFhoUVFvdjZPaG9wdW1YbEovSnM2MHVQRk9wU1ptN0xN?= =?utf-8?B?Nk5wVENERGF5L2VGYnFZUWRCUURySTIzR1ovd3hEYVZLQkNUelB0RHlScWx6?= =?utf-8?B?cXAzWGt2WFJ3QkdkMWtoOTBjWitGbVE4amxWdUhhQTZ2YnpURUl1a21VMkc4?= =?utf-8?B?U2FYdHU5akJVTmh2MDFISWplRU9jYkoveWg2SVhteUV5ZUJZVUNsY1FCdUtQ?= =?utf-8?B?bVhWeGdCVTA3YkdLR0x6WEhIQksxMS9vdGMzaDJBVC92a1ZhWU1wakFUZFdI?= =?utf-8?B?WkY4NHc3Y1lva3RubWtEZlAzelR4QWdXT01Belc5Y3plNWl1WnNNblN3eDBk?= =?utf-8?Q?PuDHwSmcHmrOGWYDlyVtWG4MJvjdviyYAs1YJ?= X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 9d883366-35d0-4a9a-c7b0-08dec131ceae X-MS-Exchange-CrossTenant-AuthSource: PAXPR04MB9422.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Jun 2026 05:34:40.0493 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: gaXLcKDxSO/8MkEMw9J1S4SfzC27FF3nnbjR8zg05hHELwhXztma8PEhnqu0bB3JHQU3yOXAKxHvHsbuSlDpL6n/YZRlbDjO38MMgvt2scYKO8lr4DiMkttun14g3x1B X-MS-Exchange-Transport-CrossTenantHeadersStamped: AS8PR04MB8150 From: Xu Yang On i.MX8MP, the USB PHY has a dedicated power domain that was previously never powered off at runtime. With the introduction of runtime PM support, the power domain will be powered off if the device is runtime suspended, which breaks USB wakeup functionality. To preserve wakeup functionality, mark the PHY power domain as runtime always-on for i.MX8MP platform. To limit the behavior to i.MX8MP, add a new imx95_usb_phy_ops for i.MX95 and introduce usb_phy_is_imx8mp() helper to identify i.MX8MP PHY instance. Signed-off-by: Xu Yang --- Changes in v3: - new patch --- drivers/phy/freescale/phy-fsl-imx8mq-usb.c | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/drivers/phy/freescale/phy-fsl-imx8mq-usb.c b/drivers/phy/frees= cale/phy-fsl-imx8mq-usb.c index cda88ea1f12d..2c3c22c6c66d 100644 --- a/drivers/phy/freescale/phy-fsl-imx8mq-usb.c +++ b/drivers/phy/freescale/phy-fsl-imx8mq-usb.c @@ -9,6 +9,7 @@ #include #include #include +#include #include #include #include @@ -658,13 +659,20 @@ static const struct phy_ops imx8mp_usb_phy_ops =3D { .owner =3D THIS_MODULE, }; =20 +static const struct phy_ops imx95_usb_phy_ops =3D { + .init =3D imx8mp_usb_phy_init, + .power_on =3D imx8mq_phy_power_on, + .power_off =3D imx8mq_phy_power_off, + .owner =3D THIS_MODULE, +}; + static const struct of_device_id imx8mq_usb_phy_of_match[] =3D { {.compatible =3D "fsl,imx8mq-usb-phy", .data =3D &imx8mq_usb_phy_ops,}, {.compatible =3D "fsl,imx8mp-usb-phy", .data =3D &imx8mp_usb_phy_ops,}, {.compatible =3D "fsl,imx95-usb-phy", - .data =3D &imx8mp_usb_phy_ops,}, + .data =3D &imx95_usb_phy_ops,}, { } }; MODULE_DEVICE_TABLE(of, imx8mq_usb_phy_of_match); @@ -677,6 +685,11 @@ static const struct regmap_config imx_cr_regmap_config= =3D { .max_register =3D 0x7, }; =20 +static bool usb_phy_is_imx8mp(const void *data) +{ + return data =3D=3D &imx8mp_usb_phy_ops; +} + static int imx8mq_usb_phy_probe(struct platform_device *pdev) { struct phy_provider *phy_provider; @@ -721,6 +734,9 @@ static int imx8mq_usb_phy_probe(struct platform_device = *pdev) if (!phy_ops) return -EINVAL; =20 + if (usb_phy_is_imx8mp(phy_ops)) + dev_pm_genpd_rpm_always_on(dev, true); + imx_phy->phy =3D devm_phy_create(dev, NULL, phy_ops); if (IS_ERR(imx_phy->phy)) return PTR_ERR(imx_phy->phy); --=20 2.34.1