{"id":2227110,"url":"http://patchwork.ozlabs.org/api/patches/2227110/?format=json","web_url":"http://patchwork.ozlabs.org/project/linux-tegra/patch/20260423085718.70762-10-akhilrajeev@nvidia.com/","project":{"id":21,"url":"http://patchwork.ozlabs.org/api/projects/21/?format=json","name":"Linux Tegra Development","link_name":"linux-tegra","list_id":"linux-tegra.vger.kernel.org","list_email":"linux-tegra@vger.kernel.org","web_url":null,"scm_url":null,"webscm_url":null,"list_archive_url":"","list_archive_url_format":"","commit_url_format":""},"msgid":"<20260423085718.70762-10-akhilrajeev@nvidia.com>","list_archive_url":null,"date":"2026-04-23T08:57:08","name":"[v3,09/13] i3c: dw-i3c-master: Add a quirk to skip clock and reset","commit_ref":null,"pull_url":null,"state":"new","archived":false,"hash":"371ab89c8e8ec2dbe6deed2ec91c9c7e8a10ac43","submitter":{"id":81965,"url":"http://patchwork.ozlabs.org/api/people/81965/?format=json","name":"Akhil R","email":"akhilrajeev@nvidia.com"},"delegate":null,"mbox":"http://patchwork.ozlabs.org/project/linux-tegra/patch/20260423085718.70762-10-akhilrajeev@nvidia.com/mbox/","series":[{"id":501164,"url":"http://patchwork.ozlabs.org/api/series/501164/?format=json","web_url":"http://patchwork.ozlabs.org/project/linux-tegra/list/?series=501164","date":"2026-04-23T08:56:59","name":"Support ACPI and SETAASA device discovery","version":3,"mbox":"http://patchwork.ozlabs.org/series/501164/mbox/"}],"comments":"http://patchwork.ozlabs.org/api/patches/2227110/comments/","check":"pending","checks":"http://patchwork.ozlabs.org/api/patches/2227110/checks/","tags":{},"related":[],"headers":{"Return-Path":"\n <linux-tegra+bounces-13862-incoming=patchwork.ozlabs.org@vger.kernel.org>","X-Original-To":["incoming@patchwork.ozlabs.org","linux-tegra@vger.kernel.org"],"Delivered-To":"patchwork-incoming@legolas.ozlabs.org","Authentication-Results":["legolas.ozlabs.org;\n\tdkim=pass (2048-bit key;\n unprotected) header.d=Nvidia.com header.i=@Nvidia.com header.a=rsa-sha256\n header.s=selector2 header.b=dyIA0VQC;\n\tdkim-atps=neutral","legolas.ozlabs.org;\n spf=pass (sender SPF authorized) smtp.mailfrom=vger.kernel.org\n (client-ip=2600:3c0a:e001:db::12fc:5321; helo=sea.lore.kernel.org;\n envelope-from=linux-tegra+bounces-13862-incoming=patchwork.ozlabs.org@vger.kernel.org;\n receiver=patchwork.ozlabs.org)","smtp.subspace.kernel.org;\n\tdkim=pass (2048-bit key) header.d=Nvidia.com header.i=@Nvidia.com\n header.b=\"dyIA0VQC\"","smtp.subspace.kernel.org;\n arc=fail smtp.client-ip=52.101.193.1","smtp.subspace.kernel.org;\n dmarc=pass (p=reject dis=none) header.from=nvidia.com","smtp.subspace.kernel.org;\n spf=fail smtp.mailfrom=nvidia.com"],"Received":["from sea.lore.kernel.org (sea.lore.kernel.org\n [IPv6:2600:3c0a:e001:db::12fc:5321])\n\t(using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)\n\t key-exchange x25519 server-signature ECDSA (secp384r1) server-digest SHA384)\n\t(No client certificate requested)\n\tby legolas.ozlabs.org (Postfix) with ESMTPS id 4g1VYx2TbZz1y2d\n\tfor <incoming@patchwork.ozlabs.org>; Thu, 23 Apr 2026 19:05:57 +1000 (AEST)","from smtp.subspace.kernel.org (conduit.subspace.kernel.org\n [100.90.174.1])\n\tby sea.lore.kernel.org (Postfix) with ESMTP id CC74530E6631\n\tfor <incoming@patchwork.ozlabs.org>; Thu, 23 Apr 2026 09:00:30 +0000 (UTC)","from localhost.localdomain (localhost.localdomain [127.0.0.1])\n\tby smtp.subspace.kernel.org (Postfix) with ESMTP id A62E83E0230;\n\tThu, 23 Apr 2026 09:00:30 +0000 (UTC)","from CH1PR05CU001.outbound.protection.outlook.com\n (mail-northcentralusazon11010001.outbound.protection.outlook.com\n [52.101.193.1])\n\t(using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits))\n\t(No client certificate requested)\n\tby smtp.subspace.kernel.org (Postfix) with ESMTPS id D59683E0224;\n\tThu, 23 Apr 2026 09:00:28 +0000 (UTC)","from BYAPR05CA0042.namprd05.prod.outlook.com (2603:10b6:a03:74::19)\n by CH1PR12MB9670.namprd12.prod.outlook.com (2603:10b6:610:2af::6) with\n Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9846.21; Thu, 23 Apr\n 2026 09:00:16 +0000","from CO1PEPF000075F2.namprd03.prod.outlook.com\n (2603:10b6:a03:74:cafe::63) by BYAPR05CA0042.outlook.office365.com\n (2603:10b6:a03:74::19) with Microsoft SMTP Server (version=TLS1_3,\n cipher=TLS_AES_256_GCM_SHA384) id 15.20.9846.20 via Frontend Transport; Thu,\n 23 Apr 2026 09:00:13 +0000","from mail.nvidia.com (216.228.117.160) by\n CO1PEPF000075F2.mail.protection.outlook.com (10.167.249.41) with Microsoft\n SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id\n 15.20.9846.18 via Frontend Transport; Thu, 23 Apr 2026 09:00:13 +0000","from rnnvmail201.nvidia.com (10.129.68.8) by mail.nvidia.com\n (10.129.200.66) with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.2562.20; Thu, 23 Apr\n 2026 01:59:55 -0700","from rnnvmail202.nvidia.com (10.129.68.7) by rnnvmail201.nvidia.com\n (10.129.68.8) with Microsoft SMTP Server (version=TLS1_2,\n cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.2562.20; Thu, 23 Apr\n 2026 01:59:54 -0700","from BUILDSERVER-IO-L4T.nvidia.com (10.127.8.9) by mail.nvidia.com\n (10.129.68.7) with Microsoft SMTP Server id 15.2.2562.20 via Frontend\n Transport; Thu, 23 Apr 2026 01:59:46 -0700"],"ARC-Seal":["i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116;\n\tt=1776934830; cv=fail;\n b=EgnNOUVGp/ewKlnaJukchgeCtCetaQ7rvH5u6Gf66no7vjydnA6sNjk1DD52A9beGRsKFCxmQIdZgfId/Xd6r9EEp5mQghuyV9qxCLa1jPJt80083suurY2enH2SSJe1WypOc8KFkaSq0vprG1w9A1IFhmwXbhU2mziGYZaOS98=","i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none;\n b=W+kZxZ1ULhFgyhzCk4aMloyeNvkXBuHJZTAXkr6LjFY98MxPsnS0s/kSYIq5L4xVOiEEQ9HntBD+1nhQ2FTZBkU3K8AzH6Pdg4HtPLSFcUCduY6W/cmlxpSHlhfykVFNyQuRRjlG+AynNI1TF23pSCwJ/PrngqWHauffdGexIU5AUPbMsQTrX1pmDGoSAFmdfz+999OFrkiCr0h2UJ9/aoYjU4UN5NIcr44Gs2NDerPir7Ifb2JX0gEXrfv5W5OHWPlrSHQXoFkiM0XX31upFAlI/MWfBIHfk9sq8iWgpBYE+CgShgBVsG7YApmAYlLhKGLCqfDChVa5bQmxHr+52g=="],"ARC-Message-Signature":["i=2; a=rsa-sha256; d=subspace.kernel.org;\n\ts=arc-20240116; t=1776934830; c=relaxed/simple;\n\tbh=DN5mGreSeSkmYAGO0SgIABxIZdObp1vS6ukdFcieVuM=;\n\th=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References:\n\t MIME-Version:Content-Type;\n b=jPTT7uA3bnRiT8ydsr1XGt22Ub4SbOwIf0fms+A3EJFVY9CZ1Rb/oEmK9969vOrofla6+PK8hAZCSkklIfYksVMwcqwdWbuPrJLP/0nEMLmoXOF7kXoG34tENtGEawYeCnRY7lndaCFbLbM5HvI1BEWVRgQoRKZreqXgavPorFc=","i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com;\n s=arcselector10001;\n 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;\n bh=8uJBanFBW09xuPUHtSPbmlSlMq6/XJwVFb90HY665dE=;\n b=xU0ibjRpx3GWySULTtAQyyAK7JZcqcC5/SyQQCUnSWB+7Oahi/myBLn3cbjh5LHzaOMTokclAxYLdmEqMbR0e93y6n/JGriQQRsTIYsQTndxZr+AVr9A0geptomhzC5ECV9gF9YUbgr1z2WVQxFHviR/dH7eHMgVkVjppPaKY+bNbfRDNr8N1VoegEpXuKYw0Q1Gg6gR9DxSJ0P4MVRXoECKeWN7GRlCoD2YKa6DGiANkG3IE1VAPdOjBnbIfq1m6XPZQ8rJ9o1i2rWu8NYZ20JUGdhXjCXAArv42pYdasgjR401r9+86siQEt0ck3Idql52GfhfcsHh8uAI0mrOIQ=="],"ARC-Authentication-Results":["i=2; smtp.subspace.kernel.org;\n dmarc=pass (p=reject dis=none) header.from=nvidia.com;\n spf=fail smtp.mailfrom=nvidia.com;\n dkim=pass (2048-bit key) header.d=Nvidia.com header.i=@Nvidia.com\n header.b=dyIA0VQC; arc=fail smtp.client-ip=52.101.193.1","i=1; mx.microsoft.com 1; spf=pass (sender ip is\n 216.228.117.160) smtp.rcpttodomain=bootlin.com smtp.mailfrom=nvidia.com;\n dmarc=pass (p=reject sp=reject pct=100) action=none header.from=nvidia.com;\n dkim=none (message not signed); arc=none (0)"],"DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed; d=Nvidia.com;\n s=selector2;\n h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck;\n bh=8uJBanFBW09xuPUHtSPbmlSlMq6/XJwVFb90HY665dE=;\n b=dyIA0VQCyPhcN8Rcc2ZzJA4sNk2HK7LwAXc7uUAiWwKwlQ1NOQ8XaREOQJpXBJZ33oG+s5SccXQY3GR4wwKmnrgunhRB1F2ZJz1s7/ykscSlgStqJfA6VqT7ar/WJ3XlFtGXpb4KjruA+1jJaj+bUAhc71X5oaf/fRSSPCT/g2gzIe81fejYQROizp4HtMucjnVm+GaF9vKMyLKaHOMytC5DOM11lduIp1kGFFCkFyBlrsGO00f4Ugw1rN9O3NxNV84a5kgpLrDS+lkKVKPNgWFFcAIy8UULgN9yiVCQx5Z9YoLZEAUvTpJj0vgO57ll0Yz8KcnZIyepyEmNBd4Mhw==","X-MS-Exchange-Authentication-Results":"spf=pass (sender IP is 216.228.117.160)\n smtp.mailfrom=nvidia.com; dkim=none (message not signed)\n header.d=none;dmarc=pass action=none header.from=nvidia.com;","Received-SPF":"Pass (protection.outlook.com: domain of nvidia.com designates\n 216.228.117.160 as permitted sender) receiver=protection.outlook.com;\n client-ip=216.228.117.160; helo=mail.nvidia.com; pr=C","From":"Akhil R <akhilrajeev@nvidia.com>","To":"Alexandre Belloni <alexandre.belloni@bootlin.com>, Frank Li\n\t<Frank.Li@nxp.com>, Rob Herring <robh@kernel.org>, Krzysztof Kozlowski\n\t<krzk+dt@kernel.org>, Conor Dooley <conor+dt@kernel.org>, \"Rafael J .\n Wysocki\" <rafael@kernel.org>, Saket Dumbre <saket.dumbre@intel.com>, \"Len\n Brown\" <lenb@kernel.org>, Guenter Roeck <linux@roeck-us.net>, Philipp Zabel\n\t<p.zabel@pengutronix.de>, Bjorn Andersson <bjorn.andersson@oss.qualcomm.com>,\n\tGeert Uytterhoeven <geert@linux-m68k.org>, Dmitry Baryshkov\n\t<dmitry.baryshkov@oss.qualcomm.com>, Arnd Bergmann <arnd@arndb.de>, \"Eric\n Biggers\" <ebiggers@kernel.org>, Wolfram Sang\n\t<wsa+renesas@sang-engineering.com>, Miquel Raynal\n\t<miquel.raynal@bootlin.com>, Jon Hunter <jonathanh@nvidia.com>, \"Thierry\n Reding\" <treding@nvidia.com>, <linux-tegra@vger.kernel.org>,\n\t<linux-i3c@lists.infradead.org>, <devicetree@vger.kernel.org>,\n\t<linux-kernel@vger.kernel.org>, <linux-acpi@vger.kernel.org>,\n\t<acpica-devel@lists.linux.dev>, <linux-hwmon@vger.kernel.org>","CC":"Akhil R <akhilrajeev@nvidia.com>","Subject":"[PATCH v3 09/13] i3c: dw-i3c-master: Add a quirk to skip clock and\n reset","Date":"Thu, 23 Apr 2026 14:27:08 +0530","Message-ID":"<20260423085718.70762-10-akhilrajeev@nvidia.com>","X-Mailer":"git-send-email 2.50.1","In-Reply-To":"<20260423085718.70762-1-akhilrajeev@nvidia.com>","References":"<20260423085718.70762-1-akhilrajeev@nvidia.com>","Precedence":"bulk","X-Mailing-List":"linux-tegra@vger.kernel.org","List-Id":"<linux-tegra.vger.kernel.org>","List-Subscribe":"<mailto:linux-tegra+subscribe@vger.kernel.org>","List-Unsubscribe":"<mailto:linux-tegra+unsubscribe@vger.kernel.org>","MIME-Version":"1.0","X-NVConfidentiality":"public","Content-Transfer-Encoding":"8bit","Content-Type":"text/plain","X-NV-OnPremToCloud":"ExternallySecured","X-EOPAttributedMessage":"0","X-MS-PublicTrafficType":"Email","X-MS-TrafficTypeDiagnostic":"CO1PEPF000075F2:EE_|CH1PR12MB9670:EE_","X-MS-Office365-Filtering-Correlation-Id":"4c8bca67-68a5-4e63-8388-08dea116bb35","X-MS-Exchange-SenderADCheck":"1","X-MS-Exchange-AntiSpam-Relay":"0","X-Microsoft-Antispam":"\n\tBCL:0;ARA:13230040|376014|7416014|82310400026|36860700016|1800799024|921020|56012099003|18002099003|22082099003;","X-Microsoft-Antispam-Message-Info":"\n\t7mCTmjFMBS0/xrgqt9iENA6utWCS3vXj9SFFX7ZAIuEV6bpXZv7KJxzrX9icF5mdljgmYHFcBr6SLETiT6R7nF/mQTZPkQx0oBUWeMjJbzYjNsDiLQHUMcP0/yzIhfjBhwiwU6fKNUkqRvqhH7xbfMhwLYyMJjQiq9SCPspkN32TbicSLOVESisgp30uKT2THOFdVXGPeh35rag8uyGk0cD2lboOXgCJ1wqnq8vBg+9YOPiszO8qiLZQrDOKtlWJ7dw5fui2TK2BE9jmgJe0jvRkhxQQrjENrkf0zApRAXspXPBBP3Mv6UMnhQSFxFjz1dB7nUpL0tOKxkAKfce68yH/XxFHhZQc74LDrBig+7ymdgtEuNhM3CS9EfuSUB8fFWtAooE/OGUkXK5hZTher08pKN3I3rdMlYWAAySNkE9KGkq26TNB/AdzRBx5YXoDz1dzu92Z3InOxi8+oYGOIYjpU0LCe0kb/EIpb5t1lDHt4pxKXLfw0S3fz0tetRE4N01sXGYhi9d5tMLfbwe78ZHtldXGCYykRGr37GSXnuIYRGhQ1N6cbI/HjTBUNn/+C/wC8CSAIatnsDWL5eTNxFZzRU18R/9/+Yb6pIgv7BG/eWKIk13j22YeCjEcUs/vHjIEys0N/iswbNlyyu0TwvEQBkdzCRGcrpqAcUHjuMdCxwyAeiP0IZWuxmHkeRJDftBRX6k97YcBsvo9fd9WoA9/2gK0/8Akaqo6AqtDFsXB2eT6vQCLhmcfX5PGSWwn5c0fG3eCfWJX3pTGQf4pcREOss20Xke6Dgq2TbJIN4NCUtrHyqGyDSabcR+zp0xi","X-Forefront-Antispam-Report":"\n\tCIP:216.228.117.160;CTRY:US;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:mail.nvidia.com;PTR:dc6edge1.nvidia.com;CAT:NONE;SFS:(13230040)(376014)(7416014)(82310400026)(36860700016)(1800799024)(921020)(56012099003)(18002099003)(22082099003);DIR:OUT;SFP:1101;","X-MS-Exchange-AntiSpam-MessageData-ChunkCount":"1","X-MS-Exchange-AntiSpam-MessageData-0":"\n\toiZbWy+Es2im/JsOvx54PTbLAiiNTLNi3ln4eVYV+vQIbfrYcwIwLfWMgXmujxWWpC25IVFb4/xmYtbbtPcWEk50YTqSu+r4qz2JkVgieNK0KPnR/6P17QLVqWhhQwrieCRxotyAQbsY6fwMCi41nfiJhHFJDf5n13VwFmcGnZNhUMv4u1tOhiHVhgmlG82Y1rxp394DAXW/KaGjY2y6c1yfaoZoi17D4zF+Pz+nTW9WOWsva/BLlrZA2tXlML6W8H8UiO2NChjgbK8LQebaecAREN7vKNtRDh6yuL51QFfOqsaF0VKswba9n2TT2ef2ldNqaNFW8fFHlei0ayRpLhw1KSyo8oVssW8iqjp4O4nmC0KqIXYwaWSaqInCfHENMJNwH9rflFXEUJQQdnaBKaljzBPCbFAlRAq0CoeP80G7S8tkDBCyk9ID8TvfYk8D","X-OriginatorOrg":"Nvidia.com","X-MS-Exchange-CrossTenant-OriginalArrivalTime":"23 Apr 2026 09:00:13.3907\n (UTC)","X-MS-Exchange-CrossTenant-Network-Message-Id":"\n 4c8bca67-68a5-4e63-8388-08dea116bb35","X-MS-Exchange-CrossTenant-Id":"43083d15-7273-40c1-b7db-39efd9ccc17a","X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp":"\n TenantId=43083d15-7273-40c1-b7db-39efd9ccc17a;Ip=[216.228.117.160];Helo=[mail.nvidia.com]","X-MS-Exchange-CrossTenant-AuthSource":"\n\tCO1PEPF000075F2.namprd03.prod.outlook.com","X-MS-Exchange-CrossTenant-AuthAs":"Anonymous","X-MS-Exchange-CrossTenant-FromEntityHeader":"HybridOnPrem","X-MS-Exchange-Transport-CrossTenantHeadersStamped":"CH1PR12MB9670"},"content":"Some ACPI-enumerated devices like Tegra410 do not have clock and reset\nresources exposed via the clk/reset frameworks. Unlike device tree, ACPI\non Arm does not model such provider functions. The hardware is expected\nto be brought out of reset and have its clocks enabled by the firmware\nbefore the OS takes over. Any data to be shared with the OS is passed\nusing the _DSD property.\n\nAdd a match data for such devices to skip acquiring clock and reset\ncontrols during probe and read the clock rate from the \"clock-frequency\"\n_DSD property. Note that the \"clock-frequency\" here is the controller's\ncore clock and not the bus speed. I3C specifies the bus speed separately\nusing \"i3c-scl-hz\" and \"i2c-scl-hz\" and hence this should not cause any\nconflict.\n\nAlso, move match data parsing before clock/reset acquisition so the quirk\nis available early enough.\n\nSigned-off-by: Akhil R <akhilrajeev@nvidia.com>\n---\n drivers/i3c/master/dw-i3c-master.c | 57 ++++++++++++++++++++----------\n 1 file changed, 38 insertions(+), 19 deletions(-)","diff":"diff --git a/drivers/i3c/master/dw-i3c-master.c b/drivers/i3c/master/dw-i3c-master.c\nindex edd42daf7553..b90756ade2db 100644\n--- a/drivers/i3c/master/dw-i3c-master.c\n+++ b/drivers/i3c/master/dw-i3c-master.c\n@@ -242,6 +242,7 @@\n /* List of quirks */\n #define AMD_I3C_OD_PP_TIMING\t\tBIT(1)\n #define DW_I3C_DISABLE_RUNTIME_PM_QUIRK\tBIT(2)\n+#define DW_I3C_ACPI_SKIP_CLK_RST\t\tBIT(3)\n \n struct dw_i3c_cmd {\n \tu32 cmd_lo;\n@@ -556,13 +557,26 @@ static void dw_i3c_master_set_intr_regs(struct dw_i3c_master *master)\n \twritel(IBI_REQ_REJECT_ALL, master->regs + IBI_MR_REQ_REJECT);\n }\n \n+static unsigned long dw_i3c_master_get_core_rate(struct dw_i3c_master *master)\n+{\n+\tunsigned int core_rate_prop;\n+\n+\tif (!(master->quirks & DW_I3C_ACPI_SKIP_CLK_RST))\n+\t\treturn clk_get_rate(master->core_clk);\n+\n+\tif (device_property_read_u32(master->dev, \"clock-frequency\", &core_rate_prop))\n+\t\treturn 0;\n+\n+\treturn core_rate_prop;\n+}\n+\n static int dw_i3c_clk_cfg(struct dw_i3c_master *master)\n {\n \tunsigned long core_rate, core_period;\n \tu32 scl_timing;\n \tu8 hcnt, lcnt;\n \n-\tcore_rate = clk_get_rate(master->core_clk);\n+\tcore_rate = dw_i3c_master_get_core_rate(master);\n \tif (!core_rate)\n \t\treturn -EINVAL;\n \n@@ -615,7 +629,7 @@ static int dw_i2c_clk_cfg(struct dw_i3c_master *master)\n \tu16 hcnt, lcnt;\n \tu32 scl_timing;\n \n-\tcore_rate = clk_get_rate(master->core_clk);\n+\tcore_rate = dw_i3c_master_get_core_rate(master);\n \tif (!core_rate)\n \t\treturn -EINVAL;\n \n@@ -1580,19 +1594,33 @@ int dw_i3c_common_probe(struct dw_i3c_master *master,\n \tif (IS_ERR(master->regs))\n \t\treturn PTR_ERR(master->regs);\n \n-\tmaster->core_clk = devm_clk_get_enabled(&pdev->dev, NULL);\n-\tif (IS_ERR(master->core_clk))\n-\t\treturn PTR_ERR(master->core_clk);\n+\tif (has_acpi_companion(&pdev->dev)) {\n+\t\tquirks = (unsigned long)device_get_match_data(&pdev->dev);\n+\t} else if (pdev->dev.of_node) {\n+\t\tdrvdata = device_get_match_data(&pdev->dev);\n+\t\tif (drvdata)\n+\t\t\tquirks = drvdata->flags;\n+\t}\n+\tmaster->quirks = quirks;\n+\n+\tif (master->quirks & DW_I3C_ACPI_SKIP_CLK_RST) {\n+\t\tmaster->core_clk = NULL;\n+\t\tmaster->core_rst = NULL;\n+\t} else {\n+\t\tmaster->core_clk = devm_clk_get_enabled(&pdev->dev, NULL);\n+\t\tif (IS_ERR(master->core_clk))\n+\t\t\treturn PTR_ERR(master->core_clk);\n+\n+\t\tmaster->core_rst = devm_reset_control_get_optional_exclusive_deasserted(&pdev->dev,\n+\t\t\t\t\t\t\t\t\t\t\t\"core_rst\");\n+\t\tif (IS_ERR(master->core_rst))\n+\t\t\treturn PTR_ERR(master->core_rst);\n+\t}\n \n \tmaster->pclk = devm_clk_get_optional_enabled(&pdev->dev, \"pclk\");\n \tif (IS_ERR(master->pclk))\n \t\treturn PTR_ERR(master->pclk);\n \n-\tmaster->core_rst = devm_reset_control_get_optional_exclusive_deasserted(&pdev->dev,\n-\t\t\t\t\t\t\t\t\t\t\"core_rst\");\n-\tif (IS_ERR(master->core_rst))\n-\t\treturn PTR_ERR(master->core_rst);\n-\n \tspin_lock_init(&master->xferqueue.lock);\n \tINIT_LIST_HEAD(&master->xferqueue.list);\n \n@@ -1625,15 +1653,6 @@ int dw_i3c_common_probe(struct dw_i3c_master *master,\n \tmaster->maxdevs = ret >> 16;\n \tmaster->free_pos = GENMASK(master->maxdevs - 1, 0);\n \n-\tif (has_acpi_companion(&pdev->dev)) {\n-\t\tquirks = (unsigned long)device_get_match_data(&pdev->dev);\n-\t} else if (pdev->dev.of_node) {\n-\t\tdrvdata = device_get_match_data(&pdev->dev);\n-\t\tif (drvdata)\n-\t\t\tquirks = drvdata->flags;\n-\t}\n-\tmaster->quirks = quirks;\n-\n \t/* Keep controller enabled by preventing runtime suspend */\n \tif (master->quirks & DW_I3C_DISABLE_RUNTIME_PM_QUIRK)\n \t\tpm_runtime_get_noresume(&pdev->dev);\n","prefixes":["v3","09/13"]}