From nobody Mon Jun 8 14:37:08 2026 Received: from MRWPR03CU001.outbound.protection.outlook.com (mail-francesouthazon11011039.outbound.protection.outlook.com [40.107.130.39]) (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 B94C723393A for ; Thu, 28 May 2026 15:07:04 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.130.39 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980826; cv=fail; b=Jr4vHC7qwLpUtGGIvEgIa/F/tfU9f3je4DH4E2PduWu+rYhR26T4uKink1Fx9ZOvNr01/a5Q1YCYg6MPuGBR+mW8nkZ54n17jCh5CarpCJGOmq8hcjF6sjCTN75Pi7UNRBNrz0R76wLfpxJFhFPLoMGaqzB+MvaQUtSqHlyE2/A= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980826; c=relaxed/simple; bh=bIjEILbtzU2Hs+IIXb5EnzLEaSGyH+J1n2C2BuLIcrk=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=A1hKm5AvT3TSB9sjt5xMovZLfAw0R/1eooAl2/MRakL3X+Oh2+xCJgvHysUuTVWP19aMkQ32sC+bKGm++fT1pXkSP9US7f+GseoPvupyQwX9nqojdLdzxwXJGcEo4d0myzMYxhbsON/6ulaakpJsZ5qGh7oI6A8480nBbdtW1Yo= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=iIPAN0Zn; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=iIPAN0Zn; arc=fail smtp.client-ip=40.107.130.39 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="iIPAN0Zn"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="iIPAN0Zn" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=CIjK7Q0e4vUTPflX1Sm2MLWIXLq+xLSgZUtUq1JSHgt7NtBLGY/hLiJl9fVHb6QLapdecn7p4sf97pSgQx9U9XU/Z1M8/xDiilr0hU6/w8EEJeThNxtx1XsSJeFmq2s+bLdA7Z5EqeA297zWFA44X/xwq5Db6L01UIOoD4aQACidl60jJeSUDmj2zqRUorbRFChRmiXVm5AODDq3XslVborIGs/uZIHK2dzicjjStq2AgSe/YaTqBGbtQuqjLUIITh94OtDRdT2O2yALIPJtRy5Rj4l1r8TxkXvOiN7XrTOCo8XQIrrshRAGFPfQG0cmcm1VR+LKU/undOH7IjMTuQ== ARC-Message-Signature: i=2; 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=j5yEfcRfOcL4cwGlyS8gwoplwDQ/pb0/5zcF4KocOSI=; b=iaDAyiXZn8C13iGLTLmhI5FpikhS5u6S0jXnGDRQTgje/l2Q9DSRedna9NRLgozHesXhUpJ/WS43ItpvvsDJPhX1uvhj23QLWhhk+l+S5uaSic6eP0RCmv8eX0zsS4SVuuvFhrkC82BGRDVR6j1sVGoE2TR0OKYbxP3aGOdmKGEwNl1wJ3ppi8R1tfLDAaFV6lmnxTbOQvqtIbN8qQUuX9UfCWrPUZbpZGQOyeYybXnjpMeonJbUwEcPZelSVSXKoLq5R/toIdFYN3hfrZZ0d4e7A+EHZa8OtGNNH1lJebjcn0lGjWypVClQCDhy76tDIvT9yic7yncFpjO0DveNJg== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=j5yEfcRfOcL4cwGlyS8gwoplwDQ/pb0/5zcF4KocOSI=; b=iIPAN0ZnF/FoIplxRb1cKncAjBYMwNYhtcmLfx8wbEi7e7266lvo1uiAsPnDKnUjELpmiojn795KTqtiIUfcNXvI4ndljH/Re59NBAuhzOv/udkyH5TBjZD/6HSuZCDKjuVuQvVD7lrmKXDEIVSJJGFd4XhhWsxA0MX/AkbRhE8= Received: from DU2P250CA0016.EURP250.PROD.OUTLOOK.COM (2603:10a6:10:231::21) by VI0PR08MB10684.eurprd08.prod.outlook.com (2603:10a6:800:212::7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.12; Thu, 28 May 2026 15:07:00 +0000 Received: from DU6PEPF0000A7DF.eurprd02.prod.outlook.com (2603:10a6:10:231:cafe::5b) by DU2P250CA0016.outlook.office365.com (2603:10a6:10:231::21) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.13 via Frontend Transport; Thu, 28 May 2026 15:06:59 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by DU6PEPF0000A7DF.mail.protection.outlook.com (10.167.8.36) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.92.5 via Frontend Transport; Thu, 28 May 2026 15:06:59 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=k2oJKow0EaHn3fFNhMT0j2vf23eRuBzFLm1KqzPhWOevm5/NGXM16ERctc9JNLEvSc3Wb4IgUAo5doIrcT9Bn/QM7Vj1hSXthK8+Sdh6BM+6ovZDYdXAI7Y4AEQhX4zlrhrFE8HjVwf4g7Rz+qxPB+zDaVKYztrKtP53QToAtffTP/CDtg7yhbhH6y6W3vyHL0VzJN9wjKtTyPfJiMbAgLyoLv3D7nlSVC0F1fXrgqhzfzAtWjVEyJUKjOLmZ7E4u0zWcITRO2tDG0QBj3dWYNIgsKsfxKyDEEojHCEXx5onT7B7ioi4bZa70KzmGWsyDyDwWdVNRFaXUH8LnzJJow== 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=j5yEfcRfOcL4cwGlyS8gwoplwDQ/pb0/5zcF4KocOSI=; b=lazCvwBcwi6cawey8F3XIbNI+tafignggHUt0iV5Tf0HtMVqVuPsgWoj1qpq1fl4TWQkVDPjySAGI9SHBTyX63NldxtElYyo2D2c8jXugQDmBygMqZRYJIPQoqh8xTtF9mJrvzYovOtwpy6KaUznrK2l1QSqsnFaVtFCRR0XsJTkKczXv09x70o3g9vAjbqAqws18eLK5wAkw/NQumL8BhIRpp4CTGeowNWmp4XuMo1mIFjb+TWi35qVrnDmfgYHz4tQDCzplRxhKEq6so6V4wYDff4w1acZbbNxP7dNJk82cmc4nacxIAqxoI+y5AyysY+85UbNO8bRUgORRnWLbQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=j5yEfcRfOcL4cwGlyS8gwoplwDQ/pb0/5zcF4KocOSI=; b=iIPAN0ZnF/FoIplxRb1cKncAjBYMwNYhtcmLfx8wbEi7e7266lvo1uiAsPnDKnUjELpmiojn795KTqtiIUfcNXvI4ndljH/Re59NBAuhzOv/udkyH5TBjZD/6HSuZCDKjuVuQvVD7lrmKXDEIVSJJGFd4XhhWsxA0MX/AkbRhE8= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:05:55 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:05:55 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 01/18] drm/panthor: Ignore -EOPNOTSUPP for shader-present nvmem lookup Date: Thu, 28 May 2026 16:05:29 +0100 Message-ID: <20260528150546.3168527-2-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: PR3P250CA0003.EURP250.PROD.OUTLOOK.COM (2603:10a6:102:57::8) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|DU6PEPF0000A7DF:EE_|VI0PR08MB10684:EE_ X-MS-Office365-Filtering-Correlation-Id: 32fd499e-27d6-4730-03a0-08debccac416 X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|22082099003|18002099003|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: wZELnWjoQqJYioLshouAJBtEY1eaqBp/Sir4jtUsnUFgXe8dUx7Ooow8pF14OjERa+8vdN8Q2BFvzj5CJI/EK7yVabv7mYnkTmamfZqekQR9EcBhoESD+uZ/bMqmMiWrEV2riHO7R033AOZs9Jz/SaO2n+1iQdez8EKl1YOBsFsh9zji82MrIkCjX5fBM+FOCKHX2PNPwoaS+u+Pe0aAzizidEvX1sBi74WeKdkNqJI3GyYv52KqcZnEEXr6J7fF8VyQjarxaE+k/zbnbTMuzT7oYvH21n5Okn9s5dENmp8VmLvCJZdP6Ot9fU9821mdkgtMCet0son+zKpbCSGflichCVn7aTC9/89w1MempBlB+gsruTkygmq0PqyRtrWnaA/fXYUT6MsSPwKXTiOA8GLQc6IP/V+Xv71SQvOYT3EgmgawSHaYDlwCLh+rnj8hIHV1p61iPNmqQi/3Cu9KyszsZ/XuzWG7UWu6UBMIfKHdciGEDxZvvtVCj57H7EZuVHcHviJksp3MFv34WODo2r7ceZe4rWTf4GBDrVLkJ1gCl8h1UCPyKBs1zln0aIEpUE7FAvoqKxhW2vajBVGiXwU7f6vOHg6YpO86TemyZeF0qYVjEtRhyk/9B64Qzjb5EzcQs4KUQRiPwNlQ87Au/iLcFL9l2+pCDrzTVzxyhT6dpWYbbjZ5OoHdngjGL2Qd X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(22082099003)(18002099003)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: YA+NWDTjeBppUe3FZ/D3OlbViganzeVws9bhSXHgp6ugtpyoac34Z4lUP4ajAV87Geho5VMSzAQilAs0+WXAjd8dfMMhul1QNKhxpnYcwzP2KNKGsSGye25b3eI22P7iSWH5Ilj+am4FrTwfq7dDphSnwBJsAtxFBIzoTAnnbXg0+1ScQUQCdIZg4EBBm2tp+mAuGvHfWmA9Q6LXLTtcEtJm+zELqDBfoh53MQZumQ9ahQfUG5jtbDwmlxUJVunk9RSSJsYC2oRMi50ukkxJybOSymIFu19AQc3MKPXtMOB3At4zztNwwd+iQO4NUTHD0RNy+UYhkz2YhbIzb3SlpQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: DU6PEPF0000A7DF.eurprd02.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: e6fb9319-ac0e-46f6-59cc-08debcca9dc3 X-Microsoft-Antispam: BCL:0;ARA:13230040|36860700016|376014|82310400026|14060799003|1800799024|35042699022|22082099003|18002099003|11063799006|56012099006; X-Microsoft-Antispam-Message-Info: N0hVULT+DQT3ANRL7yLwjGkujmIGXnwOB5NhwA6yyxuDyZgivtpFaxPmBSHkrWuf0nG4z6pwPcZDKBhofS9sFSzUsLx1UZgKDk7M9NyQe7ENmZ9LM6d8DpiMS9Zgx7DHPoR449y0KiHNeUmL12W39/YWIzSc1yTk+Nc8cCt/Z6wX0uZ9GOHp6Vh95LxW6k4GVLAIeq8lQxw4k6q2nUa39T460LvX4rfHUCeePUmZn1GH/zpsvJRA9VwAOwg33Hx9TR4azDpnOogWYLjYKTgs1doPPXHmqiko/ie3XAt6Dox1WQ3bCFg9TexKOeSYUlWbi/ixZACsR46GcAlsSYwfxOv0NBrB+0Cbin4FD6yPUE3xX9S4Roz/c797DmNso8br3v8k4/sAyuyrTuWl826CLMqqJflVxTTJP5DDn+eMGVQQeHgt02j6j9Wn4fTTtJTvtiT9tS4Dp05EIs9Z5anjQnUFxKv7k74bHyPRp/uxTSKFfTE/EJtkRpmq0abtfnL3E5OQXrOUdo/6xXzc8qs6Rq7RPCj0vfbQ4UMBnSEXmsGGaZwxvZXf9pW+hs74zVbgmTQ0s5+mpQd6t57V+ucaZ/mT7oVwF25/zTa68WPGJUrcUFmMNo3gacBe244tctatUmCg3jC6ZkzLPrGL29ybN17H2qMgZZ2dTS/Zv6CkruwDHE6uHtiyX6xlCokqFNoOMNsU5URYhoI/fviXt5svwJrQO4ieuJTZjA6Q/o00UWY= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(36860700016)(376014)(82310400026)(14060799003)(1800799024)(35042699022)(22082099003)(18002099003)(11063799006)(56012099006);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: xqdbKo2OPA/WKw59fgkAaK7uoMqAzWCdj1ahcDNPanhINJLMNxv+T0JEZzfKEWyW+utFgC+8Zu44Jngy09Vh5kD2IAgLYf5W4Ut9zbGJ59QKUjsx0ie6ikiQVDjw23hJ8ZwhnrKc8WNfsgjWqiREb4W394YFFNWv/IqiiXCfub2bKeWZZ21UAMlcMIBlFenctAWCwx5n1NmBFFo8w1Mywt5m/WW7jCG4LHy2uzgXROMFsX4N/SBQ1tzehaein9UdXuS4Z+IMEC+kHTcdq4LRjWHhd1nCF1f8I6U000fnili9KAqcjqKWCPWlEDev71m68zGPmSM6lIHx4oLASThyiTH9IpGdwmbLTV9ziWsXyr8vX2Y5ECClnBkkm7n6Bsr8FOJFQYaHvv0Me0BHGBYNC05rcjsSFMrlNOuB62eCVLvdYEO93qgSLLwebLDt7wc2 X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:06:59.1400 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 32fd499e-27d6-4730-03a0-08debccac416 X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: DU6PEPF0000A7DF.eurprd02.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI0PR08MB10684 Content-Type: text/plain; charset="utf-8" When CONFIG_NVMEM is disabled, reading the optional "shader-present" nvmem cell can return -EOPNOTSUPP. Treat this the same as the cell being absent so panthor can continue probing on platforms that do not provide shader-present fuses through nvmem. Signed-off-by: Karunika Choo Reviewed-by: Boris Brezillon --- drivers/gpu/drm/panthor/panthor_hw.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/gpu/drm/panthor/panthor_hw.c b/drivers/gpu/drm/panthor= /panthor_hw.c index 7e315708ca7c..4c96573b649a 100644 --- a/drivers/gpu/drm/panthor/panthor_hw.c +++ b/drivers/gpu/drm/panthor/panthor_hw.c @@ -182,7 +182,7 @@ static int overload_shader_present(struct panthor_devic= e *ptdev) &contents); if (!ret) ptdev->gpu_info.shader_present =3D contents; - else if (ret =3D=3D -ENOENT) + else if (ret =3D=3D -ENOENT || ret =3D=3D -EOPNOTSUPP) return 0; else return dev_err_probe(ptdev->base.dev, ret, --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from DU2PR03CU002.outbound.protection.outlook.com (mail-northeuropeazon11011022.outbound.protection.outlook.com [52.101.65.22]) (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 80FB72D7D3A for ; Thu, 28 May 2026 15:07:04 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.65.22 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980827; cv=fail; b=QH3UCPToKjOpe3RAYo8I4L31Vg6jjsWpcBCR2exPvXwSG1lk+eJD4GPtqSD9v2Qe7xwepXohuQMMD23ht95UFvxbDq4NI7G3xTjbdeUySAPQGi542Ccg7pntJT6OAA3jZ3oTqz463NuPDi03HlN174s6Ry8o/UWFacgxEnrZjmg= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980827; c=relaxed/simple; bh=ZBPuxldjW3HuL+oMh/ywTvH6gfzytCQzTKrXXExwgn4=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=dLEdJL+ls3tP0UOilExt+YjHQ0jEKtNCJ6+g2VTKTn4m7cDHufu42ua8tTxi7J0BnJlLnKJFYzNbyx7Ras4GhYN77VCf+gHSVCAMtAfPDhtYlt7MNXt7yFaUdvTmS3ET5TC5inmnXwYYEzuf/KD78QnYWMVsPIZMa4zWjQ3oznc= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=h0h4PTk7; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=h0h4PTk7; arc=fail smtp.client-ip=52.101.65.22 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="h0h4PTk7"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="h0h4PTk7" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=r+2ggdrxn4DICfN2q0Kz+27R9dYon+54CO4WuHahgInL1GPJbCLnrrMU3u9sxyrC7P3gXksu94XOZL1VYnWeaFlqCnCUV9lYfvxHpGjHqEQ+k0iw/QUx0/5gZDSTp8+RNOWykFjcbiDJ2r2K7wBGQ1oQVDFkUAxblnpUiP0qUY1oQz5lK8VReLzWMpr6qubogK+ON9XQX8s8vgB5Ahcwl3fZyIQWjL1T9OUSHISqFPOLws4yob1jZxyyH6GI0ycDwamTjxAUhBTamie1wYbSmeUD103U1OFsuAHy6fRy2DTlxvMk47iiNVdGwZBOsdaqG1gBlYuSFoAI525C6bPfOw== ARC-Message-Signature: i=2; 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=nkfW/UxXjYlbbFp09u6efB9juXDbbUwiyw9vQHXuTVM=; b=IZdZE9mRSbPDrYNT/LlgcCyqdSuuoUJ7gc9kgotwAiaXAOKZg8NgLJXOiJUz9pH9vOi1W7QRK2tcBZ8/St/vPXrr8cSlcvmjIsYWEXIgmYy4OOWZOyZO96xrZwgBludLA6rXIaisRQTQboW1UCNIwzAqjhin9lWC5SLo8/vT4gndL5bJxGi24WGTI8X9BFr3heFVGxAhGfuxHkiChxTID+tF6sG22x8AdWZ0R0GlZahlgVWZLB50vTXTzuCgtWlNlJA4x1XgPZGsz/g1R5mJu9Z9kVxJF679ZV0Ky6DKDqWrvfiG5fzA+F2VlsxpHbhbmiZL+BW9Jp7EUzt5Ylt87w== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=nkfW/UxXjYlbbFp09u6efB9juXDbbUwiyw9vQHXuTVM=; b=h0h4PTk7lMJ7NolkroukqbLDPiXRaAGl9HusLffvWPgATrusPqICyG7Noa6H5HnLVzJZmUUG4LzSPeLTwCGZXhDDhQfXvPnBDwiZyyZzCE3WY5lXQOh/esgqsdZkivGvVWVHrEEu7yo5iYUORXCgc+WAzLaoebW3iH2XL6rvxIQ= Received: from AS9PR05CA0350.eurprd05.prod.outlook.com (2603:10a6:20b:490::11) by AM9PR08MB5907.eurprd08.prod.outlook.com (2603:10a6:20b:2da::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:59 +0000 Received: from AM2PEPF0001C716.eurprd05.prod.outlook.com (2603:10a6:20b:490:cafe::2) by AS9PR05CA0350.outlook.office365.com (2603:10a6:20b:490::11) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.14 via Frontend Transport; Thu, 28 May 2026 15:06:59 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by AM2PEPF0001C716.mail.protection.outlook.com (10.167.16.186) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.7 via Frontend Transport; Thu, 28 May 2026 15:06:59 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=tkk7yJ/o71bPHdCITP5KNcxlDe51CFAyJjiK/BVV3DmTsuvd9euk1T0DQvSb3N4gEKsJ0xZEi+gi1ZxgXO55x23qDP4C3ylodY2xSOtRw8WglIlCdFMP7e2Eppv2zTuI11emoCYLMfqnJjAGuSX6UydX19JT8UlQeTbATCVxZ19u9NnXcc0cv3n3YDVgLZbnePrqdbCDV5hWBGzP+famRJ7LwN42TLWAqnsWMsrE39g7g+emuUenRg3PVViylX5Z9vqLIQkefh28OEQHYM+wbvX5rtUQN3WMtpkQMD2+03QVEi/hFStCbhBlM2aiVzmQvUXuRkCmgxupK8eXIpK1eA== 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=nkfW/UxXjYlbbFp09u6efB9juXDbbUwiyw9vQHXuTVM=; b=Do79yobnuNGDCnqDqjLqAwLnShIJ/3Lc+fUpmvSY/hH+RWc+02S5x9kmnb61FqezCKF35FXZsAfcgF7S1Q+FwRia+UcU0Ok9f1tbNzx7nVM7R46sm1spxcA7Zo/hlTujWrXndKtcr3z8niLsyoKoUdFgLX5YV8XrVm3gHe+B9PTBanrwnhyH6CMSPztyxWfLIzW2tJ+O/vrpiKo6QCdnGd2QVyf33C5hjS9DAwmm+MiFeZ3rYLcYIX9NxqxRLtXttUMiQDWzCSlksAP5N5zyDh7FeCPpfbS3dKH8t25WQgZA7IzqbgW7jJbO7Gj9pdkdfoC0AqThJJB1JsZUKp8IbQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=nkfW/UxXjYlbbFp09u6efB9juXDbbUwiyw9vQHXuTVM=; b=h0h4PTk7lMJ7NolkroukqbLDPiXRaAGl9HusLffvWPgATrusPqICyG7Noa6H5HnLVzJZmUUG4LzSPeLTwCGZXhDDhQfXvPnBDwiZyyZzCE3WY5lXQOh/esgqsdZkivGvVWVHrEEu7yo5iYUORXCgc+WAzLaoebW3iH2XL6rvxIQ= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:05:56 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:05:56 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 02/18] drm/panthor: Move register access helpers out of panthor_device.h Date: Thu, 28 May 2026 16:05:30 +0100 Message-ID: <20260528150546.3168527-3-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: PR3P191CA0047.EURP191.PROD.OUTLOOK.COM (2603:10a6:102:55::22) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|AM2PEPF0001C716:EE_|AM9PR08MB5907:EE_ X-MS-Office365-Filtering-Correlation-Id: abcac078-be37-43a2-68a7-08debccac447 X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|22082099003|18002099003|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: O7Ed/TCzn9Yhvlcpph4MbhIbxqRkI/BMtkBkb4mNv6ZOx3RDg5/Ai0wfPcgVk9KTux0mn/2R/B6DtDWiJSoR0TbLlGp/Kq5sf0i1GYxjx85JXVOobqp9XVIS3WNjN/WIYDw5RKYQl4YYQWOQO3MYbtgHJBuuY4PxKe6mOy/9hcFJW9ZsZMDPMfXDYRqu9y+NKbu95izXacdKo4qKqljIWOaqx+OWiu4fX5tyoKeKmJl61IuT3w2q4z5SAoWzs7AoHc0M34UzuZ/Zu3aoCx6PxUQ3HRkFEfKC8FbnXJkpbALxouCjLEH3erbkde49C/GrbSvcrBWXeiSsz7Ul/Go4PERNj+jezQn3chESYLZcNNufxQWzUrblJd9AQq7qr1nS36IHkNFO9CMZ8ZfFz/B3cYHQNOfa6baXwRFitkGvpE8eCkXEQH7cTchXQmYta9jOd2xswE8XYN1N2dVOYb53UpkRlXZdcLT8qkcERKedj6s97PDB1bXm75b4zW10MLbsqb32Cn1CaYuOqsX7PiKpUdnZU9YF/lFiqM7wFwWILgI5kaXGBVh68biccNhS0U6dvE4D8qY/TpyKsyK2zqp1xBIdjW0728CCPOghzPoOg3huyCNgXMddTYzq0mXysSkMyUDAMv0LdWdPHxLL29xELdfiakpvTj2+IGedgOIXw3r2GlBbibjSnLHslkeoPfgP X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(22082099003)(18002099003)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: MUT8Vx1EvHgHoIySrxl2ggke2WtmgTtwcymDd8DlKRhQepyG15n9OJU4iDn4oJDqKrpPutpTvJOhMAJHt7gmrKJo5qfkLwIo/x0dtTgRuUjr0ceI3GBocFPhKV2mku2ZumWp4S59xK+kRbtsj06TjHsfSfnRhuNdWjAH7Yzgtbd9u7VLT5NA23iblpQbXWvKhzFV8DZhoqelVJMRpGojkBm5yooqO09qsUuZLad8SahxeoyRnce5L2k9vM/ncKOtBbDTeCol9+/mLH4bd6PkQ0Hl5psad3+Tc/5XhPq2dLBZqZmZ1Q5UysGpzruGioF+Z7M85lJBmxcvhLqxarKC9g== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: AM2PEPF0001C716.eurprd05.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: 68c70252-7949-4b6e-a082-08debcca9e8b X-Microsoft-Antispam: BCL:0;ARA:13230040|82310400026|35042699022|36860700016|14060799003|376014|1800799024|11063799006|56012099006|18002099003|22082099003; X-Microsoft-Antispam-Message-Info: vQgEyw4rKN74LVRs331yzSuvALr1CMPvW517Qrw2jYB3tYHsF4I0CiHrbfWUDkNd8S3synsLIxw7trporM6FTgTrAVetqFvQLyHKprALlO0DT3ibn59Is0SYjobteehqabQ7BfGXUOpMz/QlTzW6g/q72jgaGX0lAALlX3vzHS970Ug0Mna1ShQYjtasYGOvaxk2qFfGi1xnHMJje1ocmpsR2jWsFUDZxmVFw4JKROh15DukiLpUfnF0l8TZ/TjN2F3G2wEkg3IOXQBfjkd8bZ4aCh2Wq1YsnWA0lqEEVAZbCWfAcIO5Ne9GIWawTmQ8QD/u0jVhZ+pXua9+TWsh++wu5o/uy29h0QbUFWgk8VZWnnSNd/pmzfyY30ESLMxGTCLU3l6w9oIAwGrCIpFlD0ljB8IRacBmx8WbrztP3iIokWUzuTfGGrSCS9mRXlChRuJQ8gnh/ZE6xwGffdtwu2NB/OftQpH60TvPVht6OPmoZJ/kZ1mA+gttb2gi0ta6d/4S0vkNArauS2UDL4VieF3vibFMHKuGEUFqIOLJswHR+hkjS7W9V+8b+v0mtgJwW88rp5bpxLPiwlcpJHXp7JfFROc2axczv2ZJWleeyoJ5PoSQ3RVHYA29VWOrvjtRs81bQq+F+WDzk96XW9qq0iNkd/YKDG9lCAggY63kB7MJgevVGB1fyjegrRWo0rRSgjC7YMmnkb6DaCq7TZ/2CdoNgVHXqxbgsrSYfca2R1o= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(82310400026)(35042699022)(36860700016)(14060799003)(376014)(1800799024)(11063799006)(56012099006)(18002099003)(22082099003);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: IHxWRICs9KUUr98+1S/mYkvjVyQK+DG+xH0XZYx4KJeeNn7f6KKST4lI34fKFESWOoEqDiprIc8+NiEPoB7quCQqyuM648bCnqGQGLEpONrkqkKZWDjUrBtCB8VCI5ptMxs5ZlFfuqYSlibbyLhNEZqtPqcXtSdU0AMwlGnyP19DArzcC5u7BLufg1RsMfxgFqaqSNoqJLzSZjRpYC0N74gDPT4xriSqBI+q2SaIxkh/9grZXWwbdwt1eGx5FVnIvtF/d+zSVdwTgZemgYkq15+eGZXtOfXKtM7VgiyJgVSMr+SaeMUUjY8dNNQcF0Zb4TsZpNsoVki6l2fKwntoLAUFgcE5rVFcaVMlPhDobuU/aRC87LZD+H9GtkAT7kUmuwVFGgl1gJg1FTSPxQsCciu/ZE/nkSed6LxsMJxud7fgUVQ3BDrj9wlYzmAgUF9g X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:06:59.4662 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: abcac078-be37-43a2-68a7-08debccac447 X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: AM2PEPF0001C716.eurprd05.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM9PR08MB5907 Content-Type: text/plain; charset="utf-8" panthor_device.h should describe the panthor device state, not provide generic MMIO helpers. Move the register accessors and poll-timeout wrappers to a dedicated panthor_device_io.h header and include it from the users that need MMIO access. This makes the dependency explicit and avoids pulling the full device definition into code that only needs register helpers. No functional change. Signed-off-by: Karunika Choo Reviewed-by: Boris Brezillon --- drivers/gpu/drm/panthor/panthor_device.h | 72 ------------------ drivers/gpu/drm/panthor/panthor_device_io.h | 81 +++++++++++++++++++++ drivers/gpu/drm/panthor/panthor_fw.c | 1 + drivers/gpu/drm/panthor/panthor_gpu.c | 1 + drivers/gpu/drm/panthor/panthor_hw.c | 1 + drivers/gpu/drm/panthor/panthor_mmu.c | 1 + drivers/gpu/drm/panthor/panthor_pwr.c | 1 + 7 files changed, 86 insertions(+), 72 deletions(-) create mode 100644 drivers/gpu/drm/panthor/panthor_device_io.h diff --git a/drivers/gpu/drm/panthor/panthor_device.h b/drivers/gpu/drm/pan= thor/panthor_device.h index 4e4607bca7cc..c376e52e8564 100644 --- a/drivers/gpu/drm/panthor/panthor_device.h +++ b/drivers/gpu/drm/panthor/panthor_device.h @@ -6,7 +6,6 @@ #ifndef __PANTHOR_DEVICE_H__ #define __PANTHOR_DEVICE_H__ =20 -#include #include #include #include @@ -630,75 +629,4 @@ static inline void panthor_ ## __name ## _irq_disable_= events(struct panthor_irq =20 extern struct workqueue_struct *panthor_cleanup_wq; =20 -static inline void gpu_write(void __iomem *iomem, u32 reg, u32 data) -{ - writel(data, iomem + reg); -} - -static inline u32 gpu_read(void __iomem *iomem, u32 reg) -{ - return readl(iomem + reg); -} - -static inline u32 gpu_read_relaxed(void __iomem *iomem, u32 reg) -{ - return readl_relaxed(iomem + reg); -} - -static inline void gpu_write64(void __iomem *iomem, u32 reg, u64 data) -{ - gpu_write(iomem, reg, lower_32_bits(data)); - gpu_write(iomem, reg + 4, upper_32_bits(data)); -} - -static inline u64 gpu_read64(void __iomem *iomem, u32 reg) -{ - return (gpu_read(iomem, reg) | ((u64)gpu_read(iomem, reg + 4) << 32)); -} - -static inline u64 gpu_read64_relaxed(void __iomem *iomem, u32 reg) -{ - return (gpu_read_relaxed(iomem, reg) | - ((u64)gpu_read_relaxed(iomem, reg + 4) << 32)); -} - -static inline u64 gpu_read64_counter(void __iomem *iomem, u32 reg) -{ - u32 lo, hi1, hi2; - do { - hi1 =3D gpu_read(iomem, reg + 4); - lo =3D gpu_read(iomem, reg); - hi2 =3D gpu_read(iomem, reg + 4); - } while (hi1 !=3D hi2); - return lo | ((u64)hi2 << 32); -} - -#define gpu_read_poll_timeout(iomem, reg, val, cond, delay_us, timeout_us)= \ - read_poll_timeout(gpu_read, val, cond, delay_us, timeout_us, false, \ - iomem, reg) - -#define gpu_read_poll_timeout_atomic(iomem, reg, val, cond, delay_us, \ - timeout_us) \ - read_poll_timeout_atomic(gpu_read, val, cond, delay_us, timeout_us, \ - false, iomem, reg) - -#define gpu_read64_poll_timeout(iomem, reg, val, cond, delay_us, timeout_u= s) \ - read_poll_timeout(gpu_read64, val, cond, delay_us, timeout_us, false, \ - iomem, reg) - -#define gpu_read64_poll_timeout_atomic(iomem, reg, val, cond, delay_us, \ - timeout_us) \ - read_poll_timeout_atomic(gpu_read64, val, cond, delay_us, timeout_us, \ - false, iomem, reg) - -#define gpu_read_relaxed_poll_timeout_atomic(iomem, reg, val, cond, delay_= us, \ - timeout_us) \ - read_poll_timeout_atomic(gpu_read_relaxed, val, cond, delay_us, \ - timeout_us, false, iomem, reg) - -#define gpu_read64_relaxed_poll_timeout(iomem, reg, val, cond, delay_us, \ - timeout_us) \ - read_poll_timeout(gpu_read64_relaxed, val, cond, delay_us, timeout_us, \ - false, iomem, reg) - #endif diff --git a/drivers/gpu/drm/panthor/panthor_device_io.h b/drivers/gpu/drm/= panthor/panthor_device_io.h new file mode 100644 index 000000000000..54e206c6aaa5 --- /dev/null +++ b/drivers/gpu/drm/panthor/panthor_device_io.h @@ -0,0 +1,81 @@ +/* SPDX-License-Identifier: GPL-2.0 or MIT */ +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#ifndef __PANTHOR_DEVICE_IO_H__ +#define __PANTHOR_DEVICE_IO_H__ + +#include +#include + +static inline void gpu_write(void __iomem *iomem, u32 reg, u32 data) +{ + writel(data, iomem + reg); +} + +static inline u32 gpu_read(void __iomem *iomem, u32 reg) +{ + return readl(iomem + reg); +} + +static inline u32 gpu_read_relaxed(void __iomem *iomem, u32 reg) +{ + return readl_relaxed(iomem + reg); +} + +static inline void gpu_write64(void __iomem *iomem, u32 reg, u64 data) +{ + gpu_write(iomem, reg, lower_32_bits(data)); + gpu_write(iomem, reg + 4, upper_32_bits(data)); +} + +static inline u64 gpu_read64(void __iomem *iomem, u32 reg) +{ + return (gpu_read(iomem, reg) | ((u64)gpu_read(iomem, reg + 4) << 32)); +} + +static inline u64 gpu_read64_relaxed(void __iomem *iomem, u32 reg) +{ + return (gpu_read_relaxed(iomem, reg) | + ((u64)gpu_read_relaxed(iomem, reg + 4) << 32)); +} + +static inline u64 gpu_read64_counter(void __iomem *iomem, u32 reg) +{ + u32 lo, hi1, hi2; + do { + hi1 =3D gpu_read(iomem, reg + 4); + lo =3D gpu_read(iomem, reg); + hi2 =3D gpu_read(iomem, reg + 4); + } while (hi1 !=3D hi2); + return lo | ((u64)hi2 << 32); +} + +#define gpu_read_poll_timeout(iomem, reg, val, cond, delay_us, timeout_us)= \ + read_poll_timeout(gpu_read, val, cond, delay_us, timeout_us, false, \ + iomem, reg) + +#define gpu_read_poll_timeout_atomic(iomem, reg, val, cond, delay_us, \ + timeout_us) \ + read_poll_timeout_atomic(gpu_read, val, cond, delay_us, timeout_us, \ + false, iomem, reg) + +#define gpu_read64_poll_timeout(iomem, reg, val, cond, delay_us, timeout_u= s) \ + read_poll_timeout(gpu_read64, val, cond, delay_us, timeout_us, false, \ + iomem, reg) + +#define gpu_read64_poll_timeout_atomic(iomem, reg, val, cond, delay_us, \ + timeout_us) \ + read_poll_timeout_atomic(gpu_read64, val, cond, delay_us, timeout_us, \ + false, iomem, reg) + +#define gpu_read_relaxed_poll_timeout_atomic(iomem, reg, val, cond, delay_= us, \ + timeout_us) \ + read_poll_timeout_atomic(gpu_read_relaxed, val, cond, delay_us, \ + timeout_us, false, iomem, reg) + +#define gpu_read64_relaxed_poll_timeout(iomem, reg, val, cond, delay_us, \ + timeout_us) \ + read_poll_timeout(gpu_read64_relaxed, val, cond, delay_us, timeout_us, \ + false, iomem, reg) + +#endif /* __PANTHOR_DEVICE_IO_H__ */ diff --git a/drivers/gpu/drm/panthor/panthor_fw.c b/drivers/gpu/drm/panthor= /panthor_fw.c index 986151681b24..52f176644aa6 100644 --- a/drivers/gpu/drm/panthor/panthor_fw.c +++ b/drivers/gpu/drm/panthor/panthor_fw.c @@ -19,6 +19,7 @@ #include =20 #include "panthor_device.h" +#include "panthor_device_io.h" #include "panthor_fw.h" #include "panthor_fw_regs.h" #include "panthor_gem.h" diff --git a/drivers/gpu/drm/panthor/panthor_gpu.c b/drivers/gpu/drm/pantho= r/panthor_gpu.c index e52c5675981f..b63a33fe155e 100644 --- a/drivers/gpu/drm/panthor/panthor_gpu.c +++ b/drivers/gpu/drm/panthor/panthor_gpu.c @@ -18,6 +18,7 @@ #include =20 #include "panthor_device.h" +#include "panthor_device_io.h" #include "panthor_gpu.h" #include "panthor_gpu_regs.h" #include "panthor_hw.h" diff --git a/drivers/gpu/drm/panthor/panthor_hw.c b/drivers/gpu/drm/panthor= /panthor_hw.c index 4c96573b649a..5cf54028f606 100644 --- a/drivers/gpu/drm/panthor/panthor_hw.c +++ b/drivers/gpu/drm/panthor/panthor_hw.c @@ -7,6 +7,7 @@ #include =20 #include "panthor_device.h" +#include "panthor_device_io.h" #include "panthor_gpu.h" #include "panthor_gpu_regs.h" #include "panthor_hw.h" diff --git a/drivers/gpu/drm/panthor/panthor_mmu.c b/drivers/gpu/drm/pantho= r/panthor_mmu.c index 452d0b6d4668..48127313332f 100644 --- a/drivers/gpu/drm/panthor/panthor_mmu.c +++ b/drivers/gpu/drm/panthor/panthor_mmu.c @@ -31,6 +31,7 @@ #include =20 #include "panthor_device.h" +#include "panthor_device_io.h" #include "panthor_gem.h" #include "panthor_gpu.h" #include "panthor_gpu_regs.h" diff --git a/drivers/gpu/drm/panthor/panthor_pwr.c b/drivers/gpu/drm/pantho= r/panthor_pwr.c index 7c7f424a1436..1cba093a2452 100644 --- a/drivers/gpu/drm/panthor/panthor_pwr.c +++ b/drivers/gpu/drm/panthor/panthor_pwr.c @@ -11,6 +11,7 @@ #include =20 #include "panthor_device.h" +#include "panthor_device_io.h" #include "panthor_gpu_regs.h" #include "panthor_hw.h" #include "panthor_pwr.h" --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from DB3PR0202CU003.outbound.protection.outlook.com (mail-northeuropeazon11010053.outbound.protection.outlook.com [52.101.84.53]) (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 657622F8E93 for ; Thu, 28 May 2026 15:07:06 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.84.53 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980829; cv=fail; b=FV32ZoSAyL16y/djVojr+yip/GUGV7xEdtpeUEkM0FbP0HSLbxIoY0LNURFGTZXVbFu8kqg9cMP9V50MD00BCATzS0nn/VEEdr++ru8IUQ1vlnou4sdpOiXVOVVfwvhxsfZNGgGliCNsObtAecM+gFtYgOwMo6LIGuHg0VljirI= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980829; c=relaxed/simple; bh=7gRWSkVXZuM4TteCezpnZKGWQ3mroZENPot4qQYoNpQ=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=kpAGlepaTItk3H/iUm8MwMC8Ds9Yv6iYYnT3B0OImBgYpNqjPoQqgzz4wuQX7YrnwI7Mdns3Iq/nNsWLFcHjWj4iO+/LsXGQ2wUHm8DgCyPRbDitAplA8iiRPHYcVSLDz2xfXZcrMmg71p1PttliQpdVWNm57S5WDFbxxr4ouRA= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=QnTyXfgF; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=QnTyXfgF; arc=fail smtp.client-ip=52.101.84.53 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="QnTyXfgF"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="QnTyXfgF" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=GtqWwRt/qxTv3raWH/XbiKP+A9gFpZrNKQaSDGE1DWn3Or+pjbQCwdeXMmg28/qx7PakEHEJot8Tq+sfvZ+wpNwa3hEF1ap5qf22+/j8ushzzl0/sdnEyKX67DbfvRWbspDY5asEgojxgcZzUyeT+UR2SJMAyU9UwDn47+3CsPEseFI7L8wMU9XQCbMBNdcZZB2KSo4A8sC7CHW6AShm/fN0n1M19Eyy3weY40AnAssTjM0tHSvFw6jrCvvtSBHNDKyjTCnXa2moAuF3E3T530WIQ7DsO5rSGYUpmHe2YvJfjL2rqaG1oUgRYnoYv4pLy0eXDMbnPIKzIytyLbkNnQ== ARC-Message-Signature: i=2; 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=Lgs0Ixq4GIOAXKi2TG690PcnymTESPlK/cFaoN15goI=; b=eRv6tF5iUHFMZJv5LCCTy16WnMpJ6t0nOEuiswVkrNnva+R28RSW5PN71rqxXSR8joA7KK9XLP/MXaLu1oZVgjaMIKWaZQ81efdk4RmCcZ4wauZfItDXegj6B9Ekl7hgV1KYsUdhRCNLfZZRonf7o/8co3L/8zjSRBS0EfcERVdk0ea7KrimYoX4c5SO9jFW/gTQw8Sqt3lSW9cDM+sZsfXxtDx1tlHCGDo1OdAac9poqtz2TWQqmAIzoZ702SzPaaw8GggRqK9ZJHGZiskF036AdiN2Q8PpoZpCj7lflGqKCH8szr7rkAzcTC8vqOA1doK3sst+nF1ABKs9GscMzg== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=Lgs0Ixq4GIOAXKi2TG690PcnymTESPlK/cFaoN15goI=; b=QnTyXfgFwVXngc2ZWpPBWBbxy7Yr6TfYyruf8YS3zcBKbcWdQ2c8rNLmemBw5ae7bcB4PaqddtI/mAzEboBKvnXdgla/81SOxjtDclg+tvG/4cMUEVQeLqgTBm6DgKITNSQzkZqoQkVi80FJwy4VDyQSlbrs3Ah77GCaY6Xj5/g= Received: from PA7P264CA0208.FRAP264.PROD.OUTLOOK.COM (2603:10a6:102:36d::10) by DU5PR08MB10398.eurprd08.prod.outlook.com (2603:10a6:10:51f::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.12; Thu, 28 May 2026 15:07:02 +0000 Received: from AM4PEPF00025F9B.EURPRD83.prod.outlook.com (2603:10a6:102:36d:cafe::2d) by PA7P264CA0208.outlook.office365.com (2603:10a6:102:36d::10) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.13 via Frontend Transport; Thu, 28 May 2026 15:07:01 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by AM4PEPF00025F9B.mail.protection.outlook.com (10.167.16.10) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.92.0 via Frontend Transport; Thu, 28 May 2026 15:07:01 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=ePU80Bbkns/jPQ3SCHUF4Z6fElWmf+64pskAoTGLFVj2N7c3uv0JbJPWtcpbaaY48yzAmYI7swnXgKLB79HF3nbWFSMlsZ8VEYmFECb1VtuVjTU0ss0in/W0zPVWnXUyVxpiNsNrplDPH31mA2Scxxfdb5XrrxEJ+kuZToRytDzuifcmLbrqA9uGwZkgn0INiVyhEe2niUtDzA9JPc7WB2bS132DevEVMwAf1SPBdrF5OOxa23hJnrAnF4/NifmGdVgoKYIuf61MQMfQ9s4aV/ACFvOBgBPALlfq70eICbO6WAdxK1jcT31AYvx+2IRIBUZtQVFC1U6BfLu3u987sw== 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=Lgs0Ixq4GIOAXKi2TG690PcnymTESPlK/cFaoN15goI=; b=Nms/FawEWMS3YR60qkkUB6m7+aeueNoawncLMyuIDY3C78e1TE8BU+HoA+0Axehb+MuOgfDaeqHLGNBKQxfT6lFrbJyFmSb2pEjpByzeHjyrpcYY5gTJId5PUy+DKBXhyGhqPpCkHSYTESB48arpVM2vy0W0fhNBqf7/4WxD9IUOj4fGJ9+JRmFIGDvmJ8nN/LvPUB3920KdqKZwdwCyhlyHgr26cpHySNJ8zzi6vur4B7KNcAK4jZW1zZJTf922kcaSb+WgcsitU2rR1yNtY3d6GnOVf2CMlcdsz8wTYS14oOVB1uAtLFJW0H7jS5Ux3NGJ9uK/hobohJlnYUEvQw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=Lgs0Ixq4GIOAXKi2TG690PcnymTESPlK/cFaoN15goI=; b=QnTyXfgFwVXngc2ZWpPBWBbxy7Yr6TfYyruf8YS3zcBKbcWdQ2c8rNLmemBw5ae7bcB4PaqddtI/mAzEboBKvnXdgla/81SOxjtDclg+tvG/4cMUEVQeLqgTBm6DgKITNSQzkZqoQkVi80FJwy4VDyQSlbrs3Ah77GCaY6Xj5/g= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:05:57 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:05:57 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 03/18] drm/panthor: Parse and store GPU_ID fields Date: Thu, 28 May 2026 16:05:31 +0100 Message-ID: <20260528150546.3168527-4-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: PR1P264CA0073.FRAP264.PROD.OUTLOOK.COM (2603:10a6:102:2cc::20) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|AM4PEPF00025F9B:EE_|DU5PR08MB10398:EE_ X-MS-Office365-Filtering-Correlation-Id: ea544cd4-6a0c-41e3-f2f1-08debccac539 X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|6133799003|22082099003|18002099003|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: LfrFZUMJdQn8gCc+veQau1ABSDieiLqjhOshlRbJSIvcA65dr6R7N4f71aHgaOtD8kRa4kqjtYXTrYAO2cycJe16xgTxx43pt4m1+mM1jFztKlHFo6YGsQOrH7SdJHPVYK3dt1/FsF0y8Mq/h8sPfd7zNfJ5wkqz3XJwzN4zEqY+4foH8jURykUuqh4vDUG6q1J3JrWZzr7VZ0NiXSd3ZdZvAl/h0A0ojj4L1GETR71SFLW2r1KRILzrYkjxlYI4QZX3BXc73lya5PvTo5Hxq9C00Kzso+ccgtJLwcltDvQvz9UaGGBSopSmrE4eS3mDFKUdVoGIDgOea5J53FY4hijk89wRdR02oW2z7gasfmjC0KTrYjIv32k1t5Km1bHebi9LqqNMkaEK4dQpOqzgboocvj+cHnLfes93Cz1EK/leEs4v/TAd10NXYAhjy9mIkJbqXIr5JZoJ43eb3fXWZ4S8b7jViEnBWSimBgRHJCWs29TXcktDNxthgJx8JUWTzLcgVjV0uMhM/Xu6uZArZ02xLssolldp6JAbU9Uyr2s3f/mPD/w/FjqP1FJMW8ytni/kFs4aslNkY3Nr5C7t3qxWbDM2qtOXSyzShBHCfuyKidAvx2RdWMGvC/EHHPyq0085q7hYhmbUGzIBut4+k2egaAkVh9d/MIDn0fqudurRXnDwN8Jr5ThUx3sAUm42 X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(6133799003)(22082099003)(18002099003)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: iL1Pr1xtKkUEL9YVG2gH6U8UXYWqdnakFSVaH9HywNiOIl82f6s9HoAZao5+6ePIeLPxDG4rEBK/XF25TdcH0Odo97O0rj0Z4Bf+fWSsqMfOnJ14D3sLrxIhyhSNgZd6nu1I+gn6lTMWVVYFedYGLdL2vN29e8kKn+3yvM9OX6JgIviBPVxhIUqSv49Hmi+gvpSwzwK8GxORQS+xr+rJFsHybtisI9Z8OeKbV9kUjgI9xowEjzprR0TX0ZHR5+bXWCxkZ10wT/jb71MrSbV/JYJk+xFfiCEuPmQWg5yj+zEjoe7jj4k8685CO0dxv2puelviSdp5jjUnTw6BQnxHog== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: AM4PEPF00025F9B.EURPRD83.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: 19d8cb76-c721-4047-d692-08debcca9f58 X-Microsoft-Antispam: BCL:0;ARA:13230040|36860700016|82310400026|14060799003|376014|35042699022|1800799024|11063799006|56012099006|6133799003|22082099003|18002099003; X-Microsoft-Antispam-Message-Info: YdnZLTH+mWgdjmAGgfK1GsZB6eIu5coxj55K/R33LERdRT82V9WGmdy3J+h8trgw3VIyDMH6A8HX1BBYcC48cy0F481zfq4hZl/XKLSZ2BdYlH/R69SDocV8RvAfXLbcFkaz9IzvR7aJNL+L8IdTm30VUzpwUpc1lyAIyLSiQKe0SlN4A6SUwtrocfuUjAJ9GBy+d3yZ0mqcEkC3xjWxVPwLZlLKAf24UjsB4m7f2hzdbOslGlbYw4KifR+DkNGNZNFTNgjVI2VibEYumKOUPIgBOuMaV3r2yYh88ReV4plWdzhIqgZKww1L3rDPaH3h3ObwQQ0WyljTdk8oW7OMyx9p6RBp3qi6p82j0i8g9ZRZLKsCO1ltmYYn/oCxZyStRBxiw3rcP0N8Qj1A9YhH9TfLMcRpUk+KAqAFDJNmTHOdca6MuS7UlydjdcpWV2/fIwgg0LjFYlPrzMBg/2eMjlvN7jYhZVVHyc2j/uc3ErceslCqiW/5Ilr+ZHRucYmeGkJmiiXFR1cyKbCXOGP1AFiVkOndu9LNr9QaBUgtgkpCHKn8Pkn/9Sds/O185DK9zFaNt6BBw2u3OZ4OrAYtDmu1ZLCG0SNWKKZqiH1VG8j+Se4vurwDr5hwC1CUVbPRVELvljkTC3jnJhgGG8g69cmmcShNYagVQxc/FHjgThNxuxynk6tLU6PIPtbca5tW42G8RTxcsW9qHyYuHqx1orW4E5O6viGrkGg5F6SIKkg= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(36860700016)(82310400026)(14060799003)(376014)(35042699022)(1800799024)(11063799006)(56012099006)(6133799003)(22082099003)(18002099003);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: xJRTNGunWSG/oPbVm8VVKNqPmkpvkrKxivNwo0E1/RBaoY5lxNg5B+/g8bn7FM8Ab4ydBJYREpam91MCfhkfuDCeiUU+bbSJoUo3lMQzaNoDDaRy6m+nENsVM+ZqQff3ysq5Y5phkt2XmTqX4fv8GR70WiDRcw3VHIXe5up1cH76/J84FSotrKhGsbNEco9UuHGuzeGgFk3PT6SkRDyrxLIB4+kBSvQQu9qxr15X9wHTrDJjxMUb52WankjDBykib3AqHkrNWk9twDm5QHcP8d36Tz9G3p+UL3wka+zoC6al30flmSCpKC+VSmXEy3VVl1ZBsYn5v9yyri9FUmsX6gkd9EmSabiGs3ATceYi8z8gSO6p7EgEqAUZEDbnyiojnqsbzYRSByqrnY0xuFLpgTARyU+YtBSGJU/MVy1p7O1TUMlTZXPJHe4hRUcPHpzd X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:01.0542 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: ea544cd4-6a0c-41e3-f2f1-08debccac539 X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: AM4PEPF00025F9B.EURPRD83.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU5PR08MB10398 Content-Type: text/plain; charset="utf-8" Prepare for Mali v15, where GPU_ID expands to 64 bits and its field layout changes. Introduce a small panthor_gpu_id structure and parse the GPU_ID fields once during hardware initialization. Convert existing users to consume the cached fields instead of extracting them repeatedly from the raw register value. This centralizes GPU_ID decoding and makes it easier to support both the existing and v15 formats. Signed-off-by: Karunika Choo Reviewed-by: Boris Brezillon --- drivers/gpu/drm/panthor/panthor_device.h | 33 ++++++++++++++++++++++++ drivers/gpu/drm/panthor/panthor_fw.c | 4 +-- drivers/gpu/drm/panthor/panthor_gpu.c | 2 +- drivers/gpu/drm/panthor/panthor_hw.c | 26 +++++++++++++------ drivers/gpu/drm/panthor/panthor_hw.h | 3 +-- 5 files changed, 55 insertions(+), 13 deletions(-) diff --git a/drivers/gpu/drm/panthor/panthor_device.h b/drivers/gpu/drm/pan= thor/panthor_device.h index c376e52e8564..8b2a9bb426fc 100644 --- a/drivers/gpu/drm/panthor/panthor_device.h +++ b/drivers/gpu/drm/panthor/panthor_device.h @@ -104,6 +104,36 @@ struct panthor_irq { atomic_t state; }; =20 +/** + * struct panthor_gpu_id - Parsed GPU_ID fields + */ +struct panthor_gpu_id { + struct { + /** @arch.major: Architecture major revision */ + u8 major; + + /** @arch.minor: Architecture minor revision */ + u8 minor; + + /** @arch.rev: Architecture patch revision */ + u8 rev; + } arch; + + /** @prod_major: Product identifier */ + u8 prod_major; + + struct { + /** @ver.major: Major release version number */ + u8 major; + + /** @ver.minor: Minor release version number */ + u8 minor; + + /** @ver.status: Status of GPU release */ + u8 status; + } ver; +}; + /** * enum panthor_device_profiling_mode - Profiling state */ @@ -160,6 +190,9 @@ struct panthor_device { /** @csif_info: Command stream interface information. */ struct drm_panthor_csif_info csif_info; =20 + /** @gpu_id: Parsed GPU_ID fields */ + struct panthor_gpu_id gpu_id; + /** @hw: GPU-specific data. */ struct panthor_hw *hw; =20 diff --git a/drivers/gpu/drm/panthor/panthor_fw.c b/drivers/gpu/drm/panthor= /panthor_fw.c index 52f176644aa6..784d0a25beb2 100644 --- a/drivers/gpu/drm/panthor/panthor_fw.c +++ b/drivers/gpu/drm/panthor/panthor_fw.c @@ -799,8 +799,8 @@ static int panthor_fw_load(struct panthor_device *ptdev) int ret; =20 snprintf(fw_path, sizeof(fw_path), "arm/mali/arch%d.%d/%s", - (u32)GPU_ARCH_MAJOR(ptdev->gpu_info.gpu_id), - (u32)GPU_ARCH_MINOR(ptdev->gpu_info.gpu_id), + (u32)ptdev->gpu_id.arch.major, + (u32)ptdev->gpu_id.arch.minor, CSF_FW_NAME); =20 ret =3D request_firmware(&fw, fw_path, ptdev->base.dev); diff --git a/drivers/gpu/drm/panthor/panthor_gpu.c b/drivers/gpu/drm/pantho= r/panthor_gpu.c index b63a33fe155e..bb5e64188a15 100644 --- a/drivers/gpu/drm/panthor/panthor_gpu.c +++ b/drivers/gpu/drm/panthor/panthor_gpu.c @@ -74,7 +74,7 @@ static void panthor_gpu_l2_config_set(struct panthor_devi= ce *ptdev) if (!data || !data->asn_hash_enable) return; =20 - if (GPU_ARCH_MAJOR(ptdev->gpu_info.gpu_id) < 11) { + if (ptdev->gpu_id.arch.major < 11) { drm_err(&ptdev->base, "Custom ASN hash not supported by the device"); return; } diff --git a/drivers/gpu/drm/panthor/panthor_hw.c b/drivers/gpu/drm/panthor= /panthor_hw.c index 5cf54028f606..3570e2889584 100644 --- a/drivers/gpu/drm/panthor/panthor_hw.c +++ b/drivers/gpu/drm/panthor/panthor_hw.c @@ -120,9 +120,9 @@ void panthor_hw_power_status_unregister(void) =20 static char *get_gpu_model_name(struct panthor_device *ptdev) { - const u32 gpu_id =3D ptdev->gpu_info.gpu_id; - const u32 product_id =3D GPU_PROD_ID_MAKE(GPU_ARCH_MAJOR(gpu_id), - GPU_PROD_MAJOR(gpu_id)); + const struct panthor_gpu_id *gpu_id =3D &ptdev->gpu_id; + const u32 product_id =3D GPU_PROD_ID_MAKE(gpu_id->arch.major, + gpu_id->prod_major); const bool ray_intersection =3D !!(ptdev->gpu_info.gpu_features & GPU_FEATURES_RAY_INTERSECTION); const u8 shader_core_count =3D hweight64(ptdev->gpu_info.shader_present); @@ -246,13 +246,13 @@ static int panthor_hw_info_init(struct panthor_device= *ptdev) if (ret) return ret; =20 - major =3D GPU_VER_MAJOR(ptdev->gpu_info.gpu_id); - minor =3D GPU_VER_MINOR(ptdev->gpu_info.gpu_id); - status =3D GPU_VER_STATUS(ptdev->gpu_info.gpu_id); + major =3D ptdev->gpu_id.ver.major; + minor =3D ptdev->gpu_id.ver.minor; + status =3D ptdev->gpu_id.ver.status; =20 drm_info(&ptdev->base, "%s id 0x%x major 0x%x minor 0x%x status 0x%x", - get_gpu_model_name(ptdev), ptdev->gpu_info.gpu_id >> 16, + get_gpu_model_name(ptdev), ptdev->gpu_id.prod_major, major, minor, status); =20 drm_info(&ptdev->base, @@ -274,7 +274,7 @@ static int panthor_hw_info_init(struct panthor_device *= ptdev) static int panthor_hw_bind_device(struct panthor_device *ptdev) { struct panthor_hw *hdev =3D NULL; - const u32 arch_major =3D GPU_ARCH_MAJOR(ptdev->gpu_info.gpu_id); + const u32 arch_major =3D ptdev->gpu_id.arch.major; int i =3D 0; =20 for (i =3D 0; i < ARRAY_SIZE(panthor_hw_match); i++) { @@ -296,10 +296,20 @@ static int panthor_hw_bind_device(struct panthor_devi= ce *ptdev) =20 static int panthor_hw_gpu_id_init(struct panthor_device *ptdev) { + struct panthor_gpu_id *gpu_id =3D &ptdev->gpu_id; ptdev->gpu_info.gpu_id =3D gpu_read(ptdev->iomem, GPU_ID); + if (!ptdev->gpu_info.gpu_id) return -ENXIO; =20 + gpu_id->arch.major =3D GPU_ARCH_MAJOR(ptdev->gpu_info.gpu_id); + gpu_id->arch.minor =3D GPU_ARCH_MINOR(ptdev->gpu_info.gpu_id); + gpu_id->arch.rev =3D GPU_ARCH_REV(ptdev->gpu_info.gpu_id); + gpu_id->prod_major =3D GPU_PROD_MAJOR(ptdev->gpu_info.gpu_id); + gpu_id->ver.major =3D GPU_VER_MAJOR(ptdev->gpu_info.gpu_id); + gpu_id->ver.minor =3D GPU_VER_MINOR(ptdev->gpu_info.gpu_id); + gpu_id->ver.status =3D GPU_VER_STATUS(ptdev->gpu_info.gpu_id); + return 0; } =20 diff --git a/drivers/gpu/drm/panthor/panthor_hw.h b/drivers/gpu/drm/panthor= /panthor_hw.h index f797663893b2..2a666d8cdb98 100644 --- a/drivers/gpu/drm/panthor/panthor_hw.h +++ b/drivers/gpu/drm/panthor/panthor_hw.h @@ -5,7 +5,6 @@ #define __PANTHOR_HW_H__ =20 #include "panthor_device.h" -#include "panthor_gpu_regs.h" =20 /** * struct panthor_hw_ops - HW operations that are specific to a GPU @@ -58,7 +57,7 @@ static inline void panthor_hw_l2_power_off(struct panthor= _device *ptdev) =20 static inline bool panthor_hw_has_pwr_ctrl(struct panthor_device *ptdev) { - return GPU_ARCH_MAJOR(ptdev->gpu_info.gpu_id) >=3D 14; + return ptdev->gpu_id.arch.major >=3D 14; } =20 #endif /* __PANTHOR_HW_H__ */ --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from MRWPR03CU001.outbound.protection.outlook.com (mail-francesouthazon11011057.outbound.protection.outlook.com [40.107.130.57]) (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 5D9672E7398 for ; Thu, 28 May 2026 15:07:13 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.130.57 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980835; cv=fail; b=YJhqRwT96A4iRe5brIMkd5L2Oh6Wuq1afLHOar+guU32aiIEuu7Tki+jgumJyg/cTZ+rwn93tKzmSGsSXGIdgZzl3hY7FIUGP7bafZJqlZf0ibSUYVzBHHKFmgATKXMsILb/UIDAZqKoOGCq0mNiq3wvmB9TfUuYcDWq5O8bl80= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980835; c=relaxed/simple; bh=8V1kU4NJyfaxnxjpnowN5yqvY0BxWpe86wkycmYVN2Y=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=cvUZSQabO57ITgvBhdtE/VOb5qCCVglHx1QYmku7yml7o9HmmW6TKU7/G/Sw2YbdCtCM9e0m9Xk6exaxDQK0IxaCMHkR5eqNB9/gpIW0RupuGrL//Z6kBD+vCMNYmwC4+NuJGEO+5aWbPG8qrq1Q2CjIs2VD9OmvP3gNVU79xg0= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=A0uuasu6; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=A0uuasu6; arc=fail smtp.client-ip=40.107.130.57 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="A0uuasu6"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="A0uuasu6" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=IcA6AnK0tlhyb+A5+DugWT4HZhuWU4FOVYOciGZwmFxvTDT6aE5/wLj26RJcllOlAlg2BHlcVmos/od7iAOYp/eD9kosfRDl4iOs6GX3eLkUxK5m0w4M+yyJHTpPI34t2NBJnHp4Oj7IEq2S/bDVp1cnVsOuvVzXJSse42ZWEFG6p844kuXWiLHSnc/8JdJ+cmKQN11o+OFI+l6EMPV6oJ2J3Om7QZ2qGhbufvE+KzaA4Yq8Ursk56j90831PFy5R/4pv04pQjpMK7nqOhZciuqHUfWtPxRMvyfnV1bz/uz+tGSqUls6SMBwi1VU0SZR7gVZqeORmz+wrjYDp0nkqQ== ARC-Message-Signature: i=2; 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=ajFSQ6s+SFFXMbMKlZr9T+8HkC//oBq+W61GyD4LJt8=; b=kxCWuJDi0ykXRiAhS21BBp1WAhwln9BtTnyFl+Jn1zPed3ZrqY4ieU+g79qpE5uPR42rB0HIsN0/0Jp68/8b8t3bRwbdPokYj2ualIsxaLmfug3lgNQXNy9Vhn+zCqcEwZ/typDz2H83c3ObLBdj9iQNQ/JdUCUZGjdUExpLFXgnMFisyp7wlAgaxO8BwPadaqFJFYnpPeZdyzfStd/CUyicdP2ItEKKC5x4aov7mKtB6yTNySyhW1oHs5jI2ptoUSEWtp2dlLK5w6bOLHyzZX8i+wSyCDHR+5Gt9dLzGqLSYmgE2JKZ1FH6PnvBZe6Hg7fgny7/64sMVE/bAUJ8kQ== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=ajFSQ6s+SFFXMbMKlZr9T+8HkC//oBq+W61GyD4LJt8=; b=A0uuasu6ODRBe//M1kShNi7TOXoaNFC+g2QUTBWyEBrl1f2YKrJ00qLc6wsZugKUCpA36FQGF6kjJ4rDGBkFUyQlA2QGIjDEhucNALOAl4FMpKZP8ms3AWK1YZiAoMCIgaGhtMGVBgBN4f//SsBGFHPP08OHPSie7t3qRpwK7Y0= Received: from DB3PR06CA0031.eurprd06.prod.outlook.com (2603:10a6:8:1::44) by PAWPR08MB9639.eurprd08.prod.outlook.com (2603:10a6:102:2e3::10) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.13; Thu, 28 May 2026 15:07:04 +0000 Received: from DB5PEPF00014B8B.eurprd02.prod.outlook.com (2603:10a6:8:1:cafe::6b) by DB3PR06CA0031.outlook.office365.com (2603:10a6:8:1::44) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.14 via Frontend Transport; Thu, 28 May 2026 15:07:04 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by DB5PEPF00014B8B.mail.protection.outlook.com (10.167.8.199) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.7 via Frontend Transport; Thu, 28 May 2026 15:07:04 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=a9/+i8nrhbXwB7ydI226xE4Pubq6CVZfy7GuxSzKaTFt0a1XFV3k5jiENMWL/e72jB5aYmqNaEs3tlthHe1SE6aS7s8+A182pNORHJPBalUlReVLzajbfOTm//3Wzn05Z89JC+wNevH4COG1CauvoMzW7CP8hB/lB7TuSoWaS4QYFMLhVD1gRm98f3kCb+PWE10gVY1sflBbQx5ry4sQ9bvHI7MWnBR7Pk1Dv4v+NH4L+xsbPsNz9DbfVUluds+2bnnADGc5nnJ/2XdKyQ4Uz+PP+quNNxTpziCEDyBU89EErD6Ks5O46Hykm+O1m6Dw4bRBvrGrWc9X4QUFLx4VcA== 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=ajFSQ6s+SFFXMbMKlZr9T+8HkC//oBq+W61GyD4LJt8=; b=vD47e8VuaIItYL1sGW05xadmFJ/kpyxmeC7NRuRXwmipRYlnGSDJ+oXEMfPy0t5Tf/xLZTLK7aq34m41GDsuTUqY52TfqLkP1JZGI7JgiYE69uaUVVlNdoO/d+GYTWdZom46qU+bXOGYHwbUVZ9GAU+6i07yrEHsmeALHZGMVWRG1vLz741BCRzV7I9qBVFzNxoxTeMuPgtc+9IWwKFr0YsfGEqVQ3lShyifBlvo4dQ4K6Pql1fgOPVwmDodqxv48HUnZbIs+MoETfAFQo/XuE0A1Bxs5v60DscAv14luUb9Zs1Yxw6AnBrmVIROnGOFES9tPM7+KPnkCBaBwfes/A== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=ajFSQ6s+SFFXMbMKlZr9T+8HkC//oBq+W61GyD4LJt8=; b=A0uuasu6ODRBe//M1kShNi7TOXoaNFC+g2QUTBWyEBrl1f2YKrJ00qLc6wsZugKUCpA36FQGF6kjJ4rDGBkFUyQlA2QGIjDEhucNALOAl4FMpKZP8ms3AWK1YZiAoMCIgaGhtMGVBgBN4f//SsBGFHPP08OHPSie7t3qRpwK7Y0= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:05:59 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:05:59 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 04/18] drm/panthor: Add 64-bit GPU_ID decoding for v15 GPUs Date: Thu, 28 May 2026 16:05:32 +0100 Message-ID: <20260528150546.3168527-5-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: PA7P264CA0297.FRAP264.PROD.OUTLOOK.COM (2603:10a6:102:370::7) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|DB5PEPF00014B8B:EE_|PAWPR08MB9639:EE_ X-MS-Office365-Filtering-Correlation-Id: df3e3379-af72-40a1-7b9b-08debccac719 X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|6133799003|22082099003|18002099003|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: YdV/PnOsDUABulvXOKSclt7RibqRdyI89e+/pbKgobjgdd+tVJFglVcwaIs1FSHlnNWEynj2ncz6HmjzD+w09Lm9BoVOlnbvKHYsHq9qWISYGHEJPr7DKV880XAZe1Mpi0g+aY91vxfYQvHjhwxVpZAgU5T65g9ciuVpMZuSJWA1fdiaZQ+fyFQEc6a/+Kpt5wJdAqZYXXomF6CXUJ/gg4CRcJxbuCuB5Jfx8csgewEMeJefcIT93MGiZGBbKYctMWzl9PrCRtbhnU8ep1wObLSvTizN7y1B/KMgvy2sIcFv+yih+aXN0Z6TcMei48FW+2uFd3qFXgFSPuhzrZaLgoYmruxVQKvtxvQn23HFvXh9CPkdJeM/8uObEVH4GGb48kleKoqmqNm01hHEjmb3rReGEJHwWZBBqsnxsXB2sOFkSm/U5ZNpriWauDzMqq4jO8JR7yfJGNC6DZBN2SPnkBUzy/d32PbC4tFQtAuesm00ieHiPdlGqWju3y4CUGg5Dn6Vl1hWrnTAKiwckJht2WcJbYIMFSrThWGs3OEk3oqpcgKOReUSb2sUh0/M3eEK9GD/GLIJ63xbCdMyOM5gblAQI5cDX6hLy+lJGJXR2aLINHadNQPDRSXFZkQfPWj8ytv1ykenUQgpsQ9pu1gj1/jI/Rs74pb0Oav0k34s/HWUa74yY+YQIJ0hsZRQ5wOF X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(6133799003)(22082099003)(18002099003)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: Hm7/tnrm+Z/xcsclOb5JXn+tLVu1oBjs7Kq8fU/PLBOwnYzSOHXEMxKucC0GvAVNU4kEjCbunq8SfNQQj+tdiel4UKVD2+KuGHCCFkpXcxEJ97UMee3pzNInFVzzUYYtdG92iid7s/wXutQKdZbWoubfkhT4ZQZVzZdb8MmH5Za1ttu+1ZQ//nHSGaS+2gSE4t8xxRv3PY6qTbrmzbQx2ueFOF97CDsrCP5KReyofJRr6xaAkiEhMEQ1HbRLNPkFi/CEUibSQ9iJJx9XHJQXPQ8A98PrWWyvP56tX8XKF4Nv92T1BmR+5owDd4oEoBsq5iO80othUXuFTU/Nxh1ciQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: DB5PEPF00014B8B.eurprd02.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: bdda2afb-68ef-4f58-470f-08debccaa027 X-Microsoft-Antispam: BCL:0;ARA:13230040|14060799003|376014|1800799024|36860700016|82310400026|35042699022|6133799003|56012099006|11063799006|18002099003|22082099003; X-Microsoft-Antispam-Message-Info: gU3DrCota1jdiY/pOC34NMIjsGAbjMI51l1Nx1SMeTGPkkBvwu2tqrIfvMIzMkQiFwZEyVNEW42D1E4tzuk72WFOd2tOgvdB/A2NCVJ1mBVF0by/qmIf2VjE6WmaC8BQTNcwPedSa4FOdRRwf8NLfz1mqKK0bX+DTScAWZbDMxzsq5OGo7eibuw+h1U/WhiI8S6vBljLSyjdT3vphGoKuYnBEK/vSbHOuzY03qWQlbi4t7Zco4bC3CZuCE1XSY1OinIgln/3k3hIx8MhHC1i5dCcsTi8eXVhqKy0k6zfirQosXZUdtFN2xjvFPvBdSCe3YcRSSrJhjkKoWwvJHuLCELxF0yQwtM0rGA29oalT9lytFMTaQYztgfQ2dRal+jKRyOoZmE5LKa+IzNjF8UzFE8/r7ih7DURFaFUfczG9jqzS/PzYlCVRx3n3JHjDyCDQv7uzR/GNUc9rL6k4Oi2EcmUIrPYwbn19152qVn6+i6Z0tzltk4+oBiO4hjTsnFxWpWbgMPPVcYDOsh9zgxSbL4l7M6WIiV69Evqoz4MNNQkxjtSNVCwrT7fnSgH2YqKDaWqywbP7j5Ob8doHNPtyQ3m38A7X5VjhF84XVI4PjlPSh5FDQcKJHp90plWrndFM9bl82VWHNj35Qr2LrIatevkSzGC5Z/D/fCE6kLe3B0jNwYyarNm3cM7SerIgOOJWl09tUD457ACDvMPMPFlOL5KJs5X751ch+uata5Ouug= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(14060799003)(376014)(1800799024)(36860700016)(82310400026)(35042699022)(6133799003)(56012099006)(11063799006)(18002099003)(22082099003);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: gmHgKcYVMUcxjFEgAQTyqUX38Gs4iNOBqRUJMMaLY8voS2L3e7508QDhQ9xOGjiqn1DiXu3VfULUuB0Gowg94aSThaeaZu+msLlrVpWd0GExFimv+aRdRrR8+UrkSfMwfCwktEywfPLEnDxIiFjNY5XcsPMV41eOhe8/FIj6zlTSCIB796TBWWLBW26O8dbmshzlCFuQQFyJWWsvanzKTlkpHCyXBT+tseddX/BuLhPvGJSCJ9mpsrH/B+JIvD5Lw94vtGb8YlwAHDtoiG/Uw4xw+nVNzrN0NQ/5ikzP0lRk4stJ0YHNDb7i9qpgunPrRUgx9luG1f1pdN634Zaun03gcjW/TQkvWcBEpVuHxh6ZqoWKH/aAGNKDSuXMIXhfNH0rTCrlErnhL6PcfFfLq5yfByl5s1WcjiZm6aT9fjyNctlsDOyD0uAILzQK3PnT X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:04.1899 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: df3e3379-af72-40a1-7b9b-08debccac719 X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: DB5PEPF00014B8B.eurprd02.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: PAWPR08MB9639 Content-Type: text/plain; charset="utf-8" Mali v15 exposes a 64-bit GPU_ID register with a different field layout from earlier GPUs. Add the register definitions and decoding helpers for the new format, read GPU_WIDE_ID when the compatibility value indicates a v15 GPU, and populate both the cached GPU_ID fields and the uAPI gpu_id_hi field. This allows userspace and the driver to identify v15 GPUs correctly. Signed-off-by: Karunika Choo --- .../drm/panthor/panthor_gpu_discover_regs.h | 17 +++++++++ drivers/gpu/drm/panthor/panthor_hw.c | 38 ++++++++++++++----- include/uapi/drm/panthor_drm.h | 10 +++++ 3 files changed, 56 insertions(+), 9 deletions(-) create mode 100644 drivers/gpu/drm/panthor/panthor_gpu_discover_regs.h diff --git a/drivers/gpu/drm/panthor/panthor_gpu_discover_regs.h b/drivers/= gpu/drm/panthor/panthor_gpu_discover_regs.h new file mode 100644 index 000000000000..54bb104902ee --- /dev/null +++ b/drivers/gpu/drm/panthor/panthor_gpu_discover_regs.h @@ -0,0 +1,17 @@ +/* SPDX-License-Identifier: GPL-2.0 or MIT */ +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#ifndef __PANTHOR_GPU_DISCOVER_REGS_H__ +#define __PANTHOR_GPU_DISCOVER_REGS_H__ + +#define GPU_WIDE_ID 0x0 +#define GPU_WIDE_COMPAT 0xF +#define GPU_WIDE_ARCH_MAJOR(x) (((x) & GENMASK(63, 56)) >> 56) +#define GPU_WIDE_ARCH_MINOR(x) (((x) & GENMASK(55, 48)) >> 48) +#define GPU_WIDE_ARCH_REV(x) (((x) & GENMASK(47, 40)) >> 40) +#define GPU_WIDE_PROD_MAJOR(x) (((x) & GENMASK(39, 32)) >> 32) +#define GPU_WIDE_VER_MAJOR(x) (((x) & GENMASK(23, 16)) >> 16) +#define GPU_WIDE_VER_MINOR(x) (((x) & GENMASK(15, 8)) >> 8) +#define GPU_WIDE_VER_STATUS(x) ((x) & GENMASK(7, 0)) + +#endif /* __PANTHOR_GPU_DISCOVER_REGS_H__ */ diff --git a/drivers/gpu/drm/panthor/panthor_hw.c b/drivers/gpu/drm/panthor= /panthor_hw.c index 3570e2889584..833d10cbb2d6 100644 --- a/drivers/gpu/drm/panthor/panthor_hw.c +++ b/drivers/gpu/drm/panthor/panthor_hw.c @@ -9,6 +9,7 @@ #include "panthor_device.h" #include "panthor_device_io.h" #include "panthor_gpu.h" +#include "panthor_gpu_discover_regs.h" #include "panthor_gpu_regs.h" #include "panthor_hw.h" #include "panthor_pwr.h" @@ -297,18 +298,37 @@ static int panthor_hw_bind_device(struct panthor_devi= ce *ptdev) static int panthor_hw_gpu_id_init(struct panthor_device *ptdev) { struct panthor_gpu_id *gpu_id =3D &ptdev->gpu_id; - ptdev->gpu_info.gpu_id =3D gpu_read(ptdev->iomem, GPU_ID); + u32 gpu_id32 =3D gpu_read(ptdev->iomem, GPU_ID); =20 - if (!ptdev->gpu_info.gpu_id) + if (!gpu_id32) return -ENXIO; =20 - gpu_id->arch.major =3D GPU_ARCH_MAJOR(ptdev->gpu_info.gpu_id); - gpu_id->arch.minor =3D GPU_ARCH_MINOR(ptdev->gpu_info.gpu_id); - gpu_id->arch.rev =3D GPU_ARCH_REV(ptdev->gpu_info.gpu_id); - gpu_id->prod_major =3D GPU_PROD_MAJOR(ptdev->gpu_info.gpu_id); - gpu_id->ver.major =3D GPU_VER_MAJOR(ptdev->gpu_info.gpu_id); - gpu_id->ver.minor =3D GPU_VER_MINOR(ptdev->gpu_info.gpu_id); - gpu_id->ver.status =3D GPU_VER_STATUS(ptdev->gpu_info.gpu_id); + ptdev->gpu_info.gpu_id =3D gpu_id32; + + gpu_id->arch.major =3D GPU_ARCH_MAJOR(gpu_id32); + gpu_id->arch.minor =3D GPU_ARCH_MINOR(gpu_id32); + gpu_id->arch.rev =3D GPU_ARCH_REV(gpu_id32); + gpu_id->prod_major =3D GPU_PROD_MAJOR(gpu_id32); + gpu_id->ver.major =3D GPU_VER_MAJOR(gpu_id32); + gpu_id->ver.minor =3D GPU_VER_MINOR(gpu_id32); + gpu_id->ver.status =3D GPU_VER_STATUS(gpu_id32); + + if (GPU_ARCH_MAJOR(gpu_id32) =3D=3D GPU_WIDE_COMPAT) { + u64 gpu_id64 =3D gpu_read64(ptdev->iomem, GPU_WIDE_ID); + if (!gpu_id64) + return -ENXIO; + + ptdev->gpu_info.gpu_wide_id =3D gpu_id64; + ptdev->gpu_info.gpu_id =3D 0; + + gpu_id->arch.major =3D GPU_WIDE_ARCH_MAJOR(gpu_id64); + gpu_id->arch.minor =3D GPU_WIDE_ARCH_MINOR(gpu_id64); + gpu_id->arch.rev =3D GPU_WIDE_ARCH_REV(gpu_id64); + gpu_id->prod_major =3D GPU_WIDE_PROD_MAJOR(gpu_id64); + gpu_id->ver.major =3D GPU_WIDE_VER_MAJOR(gpu_id64); + gpu_id->ver.minor =3D GPU_WIDE_VER_MINOR(gpu_id64); + gpu_id->ver.status =3D GPU_WIDE_VER_STATUS(gpu_id64); + } =20 return 0; } diff --git a/include/uapi/drm/panthor_drm.h b/include/uapi/drm/panthor_drm.h index 0e455d91e77d..04fc9f133152 100644 --- a/include/uapi/drm/panthor_drm.h +++ b/include/uapi/drm/panthor_drm.h @@ -373,6 +373,16 @@ struct drm_panthor_gpu_info { =20 /** @gpu_features: Bitmask describing supported GPU-wide features */ __u64 gpu_features; + + /** @gpu_wide_id: 64-bit GPU_ID for v15 onwards. */ + __u64 gpu_wide_id; +#define DRM_PANTHOR_WIDE_ARCH_MAJOR(x) (((x) >> 56) & 0xff) +#define DRM_PANTHOR_WIDE_ARCH_MINOR(x) (((x) >> 48) & 0xff) +#define DRM_PANTHOR_WIDE_ARCH_REV(x) (((x) >> 40) & 0xff) +#define DRM_PANTHOR_WIDE_PRODUCT_MAJOR(x) (((x) >> 32) & 0xff) +#define DRM_PANTHOR_WIDE_VERSION_MAJOR(x) (((x) >> 16) & 0xff) +#define DRM_PANTHOR_WIDE_VERSION_MINOR(x) (((x) >> 8) & 0xff) +#define DRM_PANTHOR_WIDE_VERSION_STATUS(x) ((x) & 0xff) }; =20 /** --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from AS8PR04CU009.outbound.protection.outlook.com (mail-westeuropeazon11011041.outbound.protection.outlook.com [52.101.70.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 48E773F7AAB for ; Thu, 28 May 2026 15:07:13 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.70.41 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980836; cv=fail; b=MVI0bKqwAbtXsb2iioQdd5bJpidfPV5qB6wkJ/aOlMIPz5Ikwh0HjbKYbT73reHPwqvX8b3JTSs1xKUeEbKhTkROBX7jojCkCsCAQenknBeWPNqIZWKP/jPG5jNHEtwsUOhE/fYFK5jE3A4Zf8EdBN+x1EUCwXDuoTEAG5Qxg0U= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980836; c=relaxed/simple; bh=UVGSOuFPmLibtmTwbqv0TaMU9h8cd8RjJMbtUZQOP3E=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=YhO7B8AVR8YfxybI5v3nM6k7fI/naKpxXDu+2Dq4fwdNxe6xkGPpng3lfrJROqmfdCe9MJE0PEmP1mO+3Epo10usXSerzAy25HqdaC7/PBiQqTZ+Y0tIMImp0nfckJkE/23qowAr9zwNOrCHb8vX1DnqLODzw+9gMpHo3J/OPKg= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=dhIFR03a; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=dhIFR03a; arc=fail smtp.client-ip=52.101.70.41 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="dhIFR03a"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="dhIFR03a" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=wW9uAo4t4dEP5moRp/5GqCDTZTWq0X4Ozdou5xoYgp9Hha5u3ESSfT40/Jko8iO6EfBpohgvO6h7zBRDKdzZZyOnpsNtSbso5FTzvyH84ww4UITFDd7L1T8/Q7Hnr8WY3swHu7cuZ64Gm+WPUeT/F4otnwW7Ik0Z3WI6NxqpcHJvFKzpIMxqz2X7RIxna5onJrfnRdf2dcV1xLIuraG5AdS0qplte5g1yz6BZyaXjSmyCbzJrO4HDTTsL7qhNr0mHJfLa4gwb30rcU2WbYyj8OEKrAdWAKGTOSLYdHgVCeY3+MZmr3yYJp26TuztXWFu+Te0gAVaPFJO10+DMeK0bg== ARC-Message-Signature: i=2; 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=o2eHSYICaROJhfP5w00n+r6BkZz0t3L3qAUDdaRAshU=; b=h3Q+7i3h1/6J+D1RF6wxrzZuQOPi92ubj4Z7sxx3tGQHaS3i/Ii2JjmBGeBM9XBXVmnyzdbDxNNuxxQW58Mdd/6GbjTOadNk6y/bRrAjLsf9XF76Iu0Q2I7zZnqhNa9vV6fVS8BocyvoBn+Sv1FUvT7J3cEEl1vkMtjZUstlCJV8GGFm/K9TJadWNS3UisYlEqDCj6CVAZisIaEXJvIoTnA9ndXJf4EFtz/xSSnL66h5e8foDRROwQkgay0oEZ9rotHKGWJU7GIVAuYBfS2wgq9lp8wR+TyhiGk8X7V17bbq52XNp6UxTwO149kAyM+erecU0hZNs0KrIzEGfdt1mw== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=o2eHSYICaROJhfP5w00n+r6BkZz0t3L3qAUDdaRAshU=; b=dhIFR03aGMnmFdl8Cl/fETOOvtHnJxH1m6VqoPE7X507d+N/whsyPoqgny6RekZ8gt2hmk6zexZXkvXYRY8bW/H2/gvuC0S2HDbeyIh0bk3wnlc5NTjQLsBhFtGdk64QL9B8iDrDrJpvLCjvbtVr8QBEmjsuu67SiswMLzD23uk= Received: from CWLP123CA0173.GBRP123.PROD.OUTLOOK.COM (2603:10a6:400:19b::8) by VI0PR08MB10448.eurprd08.prod.outlook.com (2603:10a6:800:210::21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.11; Thu, 28 May 2026 15:07:06 +0000 Received: from AMS0EPF00000198.eurprd05.prod.outlook.com (2603:10a6:400:19b:cafe::57) by CWLP123CA0173.outlook.office365.com (2603:10a6:400:19b::8) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.13 via Frontend Transport; Thu, 28 May 2026 15:07:06 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by AMS0EPF00000198.mail.protection.outlook.com (10.167.16.244) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.7 via Frontend Transport; Thu, 28 May 2026 15:07:05 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=fhjxhr5GjTQ9mEiR3Ql1d7S9u0sqmrd4t/XuTgd2zWUT94C1LV2ev6VlwQm4eChtwkkGiF3Jmw6zHzndsKzVrI207D4S4M9UK1/Xf/38ULKr9Jju07rMSFl30lxoJ5JqFDtfp368DpzV1BmJsyGC2+WOCzu/zfOMdhyq0BI1zvEijFttUrcP8e7AafOiRQIZm3A1axNd6Qretmhf/kLb3eBF2M7sd5kUqsrwYqL5aJo9Az6wfGFFkTQW266rMfxm1WqKYxrQ7PK+b8j7LHw9at1J0mr7dyM/fSV2io3Q6ti1ooM2WSOihi1HHguX/xWYMpivUVbGJ8NmR6kIO9d/TQ== 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=o2eHSYICaROJhfP5w00n+r6BkZz0t3L3qAUDdaRAshU=; b=qchDodPwYwxiET9y63FFUlyG/yNEl90+tkZQNioDGsgdsqjrWfSiZ+PYxFKEQzAQfroxUjlMvHsaS76iryRrA4tHNwuEKP/wE4TvyZmhjdphcLBh2gtMe9F92Cvar9TKa7EAfpvsmDsKEI3QYl5fljvSrNkK97y3sx7G9GPp04e0sBOdtw7WCfAPbnPB4uzgUCftXzwwZJQPSMZK7uaTTzk7nFKsY4+PH/79KhE44Ip0xscZ1wO/DBO2qXCYeA8W8hQULre7VilMgcK+Fd354yEgh5Q4XGA2VMAzBvg0UZWaeuZzDIyaGf4b9rAYD8HnuKx2xclk7wn5SRhWLZDBng== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=o2eHSYICaROJhfP5w00n+r6BkZz0t3L3qAUDdaRAshU=; b=dhIFR03aGMnmFdl8Cl/fETOOvtHnJxH1m6VqoPE7X507d+N/whsyPoqgny6RekZ8gt2hmk6zexZXkvXYRY8bW/H2/gvuC0S2HDbeyIh0bk3wnlc5NTjQLsBhFtGdk64QL9B8iDrDrJpvLCjvbtVr8QBEmjsuu67SiswMLzD23uk= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:00 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:00 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 05/18] drm/panthor: Move register base offsets to the HW description Date: Thu, 28 May 2026 16:05:33 +0100 Message-ID: <20260528150546.3168527-6-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: PA7P264CA0310.FRAP264.PROD.OUTLOOK.COM (2603:10a6:102:395::7) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|AMS0EPF00000198:EE_|VI0PR08MB10448:EE_ X-MS-Office365-Filtering-Correlation-Id: ef8175b5-8582-4910-4b92-08debccac822 X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|6133799003|22082099003|18002099003|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: J8vKTTO2nimI/Bpht8VSgbE11ZzlTAbvwALbm2MzAjdESSkKVVhs+qNjgFWhrJn42wiJsJMawbRBTREC/ytNj1UA05Mz6nYs7Dj2dUp2bxCzcULVLm4CMuX7vPwvMQ+ElHJLTi/0y2LgPYE2sDLGwRwEB8eO7tEv+QDs3IMhWyQhEi5o46oRdDSs2WObKa95Rt/4yGprZooEALR3tFbFtlKhhXdtEAKoV2Ka/vPqdRbKD/osKuSCqCC+9heeXLehJb0LWXfsZcpGFCK7MWvp2H0VEc8O9lI5TI8HoLQRKExKQMKoRnGZJjm6Pg/IIdL+T2E1FEFNh1LYLsey8cqz0BovpXrffvKPeR//7H9cmQLYKBKS89pwMZYexmSl++MHmKpeGNQ6YavSvOfr2VRDCUkCcJD8T3oR9QAQX85wZbaq6YWJN8xAytg9b5CgPLD8YhL37y0XEyQdCwWRx7n7fVCdklPmGXQvDBJ7cesNZ3XwgucyYbUGAVd/QuV5IeUMmz/YK8+q1GkyNyZ1fndqvSwKBk7UmtD6RToN7Iig773i8+gyGUB8ysjUy+bBhqJvQkehcx7WdkR0PIQsmkUQ5ejwErwxdtwc7jdl6oZj5c88LPyTgAY6/P0i9IDRgheST14xiNkgGZukhaWAZ8Mh/jm9lMkKnOEYNuvZUh3zQ6xNdiQ3HKZmVoz9WpIk6r6j X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(6133799003)(22082099003)(18002099003)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: QNMuumzNSX+gH2nwYbj+57VRq7IoDfvWtam5LnfBktbTuvT0J/pt0oLSu/QZ/XXOL/cHjwpPT5JiffVYzGHu0QOp8PYc+bunlaucIzN29CYySfj1/UhY1/frHCzFq/zVH3e+rZRdlOMn7F6GWQRCjCUw6PAgeabWbMHABcZhLTemRBZDT7iSVfP25Zzpc4o028wP3s6NUv+CQRix+OgESWjUAzzycFCpY48EN4H9mkPGrOXNZlQp4yb/luoaKqiA6pFroQ8Dlx0zNfpQTNecAczTQ5kBa/kfJtzYxh8xj2FxYp6yqtSJklHuwGtFxXbEpqSqBY678lu25C3bTwjxnQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: AMS0EPF00000198.eurprd05.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: 79a2eecd-e253-4f73-5a52-08debccaa0fd X-Microsoft-Antispam: BCL:0;ARA:13230040|376014|82310400026|36860700016|1800799024|14060799003|35042699022|11063799006|6133799003|22082099003|56012099006|18002099003; X-Microsoft-Antispam-Message-Info: 9pmtWfSAdNGE77IfXDd9i9izazAVZ9beTCEVbgoWFd5RBBozXbTeVZu8f/3ZrNEGr8teR43FEQGz4B4+JRRetTxZOsU66V1M6OFD49Wi+UVUsCvcpeCwepJbhl+p4aP5/Y/iEpiQG6PwcNosFN/9yDC0HifeDydWsadQYPv9Q2a9HfAlZBOXcaxRwiXfhSNp/mnRPqKOdX/yZaPq17lxnXPjxburEgtDvhDe5fE7TjCioGaB3ssOZJHhkrh8VAecdZTbocZciDIntNk/lfL8sDSIJEHMJHoxaSnRpba+egoRyJnXaaH7GqV/vWKU6qf6aRDislZBBMD8bjgT6ytsm22SoGwXwS40k2QUesfQySAzBCUWy8+mySVZUm4hPgFZntRl2z/PshQOd2TbfYxat3jWIGLATwYgx5tkebhhZWXtjIul+eFYPkMBtsLEJKyBrGTfpz0zDnadxdcvBxdJVuHTld2oVKXrRMkZptuEnQdRDXoBQDd4yv4244trxx0aKAKENTduaBtwoGkoN1gO3sNHEG1Ld9Kpvh31PGIwF9R1l3VHilB6cVhA0qLqQX+W9UyDoESkpu3tYWuyJB4gzBJBNdVVpebXvV4+BB/d3pLIlGKhh3SOtEEtO0WWThp3ltjpOszYvcqazZP3e0XV7OnSo4vywg0zMHsBUOcz05CHsUTVcv2VSUwvgcQCo0N2kNklFqYIG2WvtxHhKrQtFAZjfUeRY+aoiaFVj0qWxxQ= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(376014)(82310400026)(36860700016)(1800799024)(14060799003)(35042699022)(11063799006)(6133799003)(22082099003)(56012099006)(18002099003);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: 9F53V5BuJ3vu7t0Yr6BXbcWl2thMbF2c+PKPLk/cBwGHUhVeZmxjsUQ0qDHWx72nRstchrJ4gTkj/zTKQxNlfhJLs9uCkKDll9ROzL5vz1XVtkwmwf/b5oV/LMu9JRXTSF11IGi7XxWeBV9GYqaBfe49kkv3JRoybFkFpB81QyCUaJYlzHOOCtr1WOrZfebaRtxLNzqgaC/YUrKUnIfzyrRgYEQrGi4KTNBGGmPgiFiHDIrrolkRXGKpbO5HdSuDB75lOguUCzSVkS/2vYq50nwzJjNFy1HlaHMaFfYeSu3/gsGn6Br57pn7iJ3eogYwjhJ+MIBpqt6GjK6b/H6ZLVPs2NRH19AaCgeprHR3dL6SD90hotTPc8dy9k+KifsGK75YJN8HyEUq+fjIIs75OsIAqzjCwhkYLQMGp+OfCYS9sEEw7dKnlrsHW4UCWTM/ X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:05.9337 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: ef8175b5-8582-4910-4b92-08debccac822 X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: AMS0EPF00000198.eurprd05.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI0PR08MB10448 Content-Type: text/plain; charset="utf-8" Mali v15 reorders several register regions, including GPU_CONTROL, MCU_CONTROL and PWR_CONTROL, so the driver can no longer assume a single fixed base layout across all supported GPUs. Add per-GPU register base offsets to the panthor hardware description and switch the GPU, FW and PWR local iomem setup to use those stored values. With the base addresses now owned by the hardware description, drop the corresponding fixed base-offset definitions from the register headers. This prepares the driver for GPUs with different register layouts without changing the existing behaviour on currently supported parts. Signed-off-by: Karunika Choo --- drivers/gpu/drm/panthor/panthor_fw.c | 2 +- drivers/gpu/drm/panthor/panthor_fw_regs.h | 2 -- drivers/gpu/drm/panthor/panthor_gpu.c | 7 +++---- drivers/gpu/drm/panthor/panthor_gpu_regs.h | 2 -- drivers/gpu/drm/panthor/panthor_hw.c | 13 +++++++++++-- drivers/gpu/drm/panthor/panthor_hw.h | 19 +++++++++++++++++-- drivers/gpu/drm/panthor/panthor_pwr.c | 4 ++-- drivers/gpu/drm/panthor/panthor_pwr_regs.h | 3 --- 8 files changed, 34 insertions(+), 18 deletions(-) diff --git a/drivers/gpu/drm/panthor/panthor_fw.c b/drivers/gpu/drm/panthor= /panthor_fw.c index 784d0a25beb2..f6381f5f236f 100644 --- a/drivers/gpu/drm/panthor/panthor_fw.c +++ b/drivers/gpu/drm/panthor/panthor_fw.c @@ -1467,7 +1467,7 @@ int panthor_fw_init(struct panthor_device *ptdev) if (!fw) return -ENOMEM; =20 - fw->iomem =3D ptdev->iomem + MCU_CONTROL_BASE; + fw->iomem =3D ptdev->iomem + ptdev->hw->map.mcu_control_base; ptdev->fw =3D fw; init_waitqueue_head(&fw->req_waitqueue); INIT_LIST_HEAD(&fw->sections); diff --git a/drivers/gpu/drm/panthor/panthor_fw_regs.h b/drivers/gpu/drm/pa= nthor/panthor_fw_regs.h index b2e59cfc22b0..a3492f7f913f 100644 --- a/drivers/gpu/drm/panthor/panthor_fw_regs.h +++ b/drivers/gpu/drm/panthor/panthor_fw_regs.h @@ -4,8 +4,6 @@ #ifndef __PANTHOR_FW_REGS_H__ #define __PANTHOR_FW_REGS_H__ =20 -#define MCU_CONTROL_BASE 0x700 - #define MCU_CONTROL 0x0 #define MCU_CONTROL_ENABLE 1 #define MCU_CONTROL_AUTO 2 diff --git a/drivers/gpu/drm/panthor/panthor_gpu.c b/drivers/gpu/drm/pantho= r/panthor_gpu.c index bb5e64188a15..3c88a25287bf 100644 --- a/drivers/gpu/drm/panthor/panthor_gpu.c +++ b/drivers/gpu/drm/panthor/panthor_gpu.c @@ -154,7 +154,7 @@ int panthor_gpu_init(struct panthor_device *ptdev) if (!gpu) return -ENOMEM; =20 - gpu->iomem =3D ptdev->iomem + GPU_CONTROL_BASE; + gpu->iomem =3D ptdev->iomem + ptdev->hw->map.gpu_control_base; spin_lock_init(&gpu->reqs_lock); init_waitqueue_head(&gpu->reqs_acked); mutex_init(&gpu->cache_flush_lock); @@ -170,9 +170,8 @@ int panthor_gpu_init(struct panthor_device *ptdev) if (irq < 0) return irq; =20 - ret =3D panthor_request_gpu_irq(ptdev, &ptdev->gpu->irq, irq, - GPU_INTERRUPTS_MASK, - ptdev->iomem + GPU_INT_BASE); + ret =3D panthor_request_gpu_irq(ptdev, &ptdev->gpu->irq, irq, GPU_INTERRU= PTS_MASK, + gpu->iomem + GPU_INT_BASE); if (ret) return ret; =20 diff --git a/drivers/gpu/drm/panthor/panthor_gpu_regs.h b/drivers/gpu/drm/p= anthor/panthor_gpu_regs.h index 4c5b953796e4..753df8700990 100644 --- a/drivers/gpu/drm/panthor/panthor_gpu_regs.h +++ b/drivers/gpu/drm/panthor/panthor_gpu_regs.h @@ -4,8 +4,6 @@ #ifndef __PANTHOR_GPU_REGS_H__ #define __PANTHOR_GPU_REGS_H__ =20 -#define GPU_CONTROL_BASE 0x0 - #define GPU_ID 0x0 #define GPU_ARCH_MAJOR(x) ((x) >> 28) #define GPU_ARCH_MINOR(x) (((x) & GENMASK(27, 24)) >> 24) diff --git a/drivers/gpu/drm/panthor/panthor_hw.c b/drivers/gpu/drm/panthor= /panthor_hw.c index 833d10cbb2d6..1f7fab4caf4d 100644 --- a/drivers/gpu/drm/panthor/panthor_hw.c +++ b/drivers/gpu/drm/panthor/panthor_hw.c @@ -38,6 +38,10 @@ static struct panthor_hw panthor_hw_arch_v10 =3D { .power_changed_off =3D panthor_gpu_power_changed_off, .power_changed_on =3D panthor_gpu_power_changed_on, }, + .map =3D { + .gpu_control_base =3D 0x0, + .mcu_control_base =3D 0x700, + }, }; =20 static struct panthor_hw panthor_hw_arch_v14 =3D { @@ -46,6 +50,11 @@ static struct panthor_hw panthor_hw_arch_v14 =3D { .l2_power_off =3D panthor_pwr_l2_power_off, .l2_power_on =3D panthor_pwr_l2_power_on, }, + .map =3D { + .gpu_control_base =3D 0x0, + .pwr_control_base =3D 0x800, + .mcu_control_base =3D 0x700, + }, }; =20 static struct panthor_hw_entry panthor_hw_match[] =3D { @@ -197,7 +206,7 @@ static int panthor_gpu_info_init(struct panthor_device = *ptdev) { unsigned int i; =20 - void __iomem *gpu_iomem =3D ptdev->iomem + GPU_CONTROL_BASE; + void __iomem *gpu_iomem =3D ptdev->iomem + ptdev->hw->map.gpu_control_bas= e; =20 ptdev->gpu_info.csf_id =3D gpu_read(gpu_iomem, GPU_CSF_ID); ptdev->gpu_info.gpu_rev =3D gpu_read(gpu_iomem, GPU_REVID); @@ -223,7 +232,7 @@ static int panthor_gpu_info_init(struct panthor_device = *ptdev) ptdev->gpu_info.gpu_features =3D gpu_read64(gpu_iomem, GPU_FEATURES); =20 if (panthor_hw_has_pwr_ctrl(ptdev)) { - void __iomem *pwr_iomem =3D gpu_iomem + PWR_CONTROL_BASE; + void __iomem *pwr_iomem =3D ptdev->iomem + ptdev->hw->map.pwr_control_ba= se; =20 /* Introduced in arch 14.x */ ptdev->gpu_info.l2_present =3D gpu_read64(pwr_iomem, PWR_L2_PRESENT); diff --git a/drivers/gpu/drm/panthor/panthor_hw.h b/drivers/gpu/drm/panthor= /panthor_hw.h index 2a666d8cdb98..58673a427bc9 100644 --- a/drivers/gpu/drm/panthor/panthor_hw.h +++ b/drivers/gpu/drm/panthor/panthor_hw.h @@ -26,14 +26,29 @@ struct panthor_hw_ops { void (*power_changed_off)(struct panthor_device *ptdev); }; =20 +/** + * struct panthor_hw_regmap - Register base addresses + */ +struct panthor_hw_regmap { + /** @gpu_control_base: GPU_CONTROL base address */ + u32 gpu_control_base; + + /** @pwr_control_base: PWR_CONTROL base address */ + u32 pwr_control_base; + + /** @mcu_control_base: MCU_CONTROL base address */ + u32 mcu_control_base; +}; + /** * struct panthor_hw - GPU specific register mapping and functions */ struct panthor_hw { - /** @features: Bitmap containing panthor_hw_feature */ - /** @ops: Panthor HW specific operations */ struct panthor_hw_ops ops; + + /** @map: Panthor HW-specific register base addresses */ + struct panthor_hw_regmap map; }; =20 int panthor_hw_init(struct panthor_device *ptdev); diff --git a/drivers/gpu/drm/panthor/panthor_pwr.c b/drivers/gpu/drm/pantho= r/panthor_pwr.c index 1cba093a2452..b833e4559e45 100644 --- a/drivers/gpu/drm/panthor/panthor_pwr.c +++ b/drivers/gpu/drm/panthor/panthor_pwr.c @@ -475,7 +475,7 @@ int panthor_pwr_init(struct panthor_device *ptdev) if (!pwr) return -ENOMEM; =20 - pwr->iomem =3D ptdev->iomem + PWR_CONTROL_BASE; + pwr->iomem =3D ptdev->iomem + ptdev->hw->map.pwr_control_base; spin_lock_init(&pwr->reqs_lock); init_waitqueue_head(&pwr->reqs_acked); ptdev->pwr =3D pwr; @@ -486,7 +486,7 @@ int panthor_pwr_init(struct panthor_device *ptdev) =20 err =3D panthor_request_pwr_irq( ptdev, &pwr->irq, irq, PWR_INTERRUPTS_MASK, - pwr->iomem + PWR_INT_BASE); + pwr->iomem); if (err) return err; =20 diff --git a/drivers/gpu/drm/panthor/panthor_pwr_regs.h b/drivers/gpu/drm/p= anthor/panthor_pwr_regs.h index 9cf7a715066f..12939dcd7519 100644 --- a/drivers/gpu/drm/panthor/panthor_pwr_regs.h +++ b/drivers/gpu/drm/panthor/panthor_pwr_regs.h @@ -4,9 +4,6 @@ #ifndef __PANTHOR_PWR_REGS_H__ #define __PANTHOR_PWR_REGS_H__ =20 -#define PWR_CONTROL_BASE 0x800 - -#define PWR_INT_BASE 0x0 #define PWR_IRQ_POWER_CHANGED_SINGLE BIT(0) #define PWR_IRQ_POWER_CHANGED_ALL BIT(1) #define PWR_IRQ_DELEGATION_CHANGED BIT(2) --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from AS8PR04CU009.outbound.protection.outlook.com (mail-westeuropeazon11011030.outbound.protection.outlook.com [52.101.70.30]) (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 004A13F870F for ; Thu, 28 May 2026 15:07:14 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.70.30 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980838; cv=fail; b=lYohTnrRkVQQdtRbJuFAMufTE6iBz39kkP6FlX334Kyxs3y2D3r8CrAvHMmgdFrXg4QBnoLGFTJI+p10YTfkdhIbY18Lx/8RRU2QTdPrdskn58pzumD/eFi1upGY7Z3Pek9AH0BJ0duppxEWhvFbwVkrrUFE2/gzkqkNvvcRHSY= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980838; c=relaxed/simple; bh=4zBCDs0P5qxJyZr7/THI3dTM/WGSzbBDQLEC3JcXHN8=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=gB7pqt8k0rmxPfqFQ9J9FqmeN4L5UMqCbq7E+oQjfOixHg65xS+BuW3I/GufJSU5ALHEyrGwKUZKpDO1Atba6UEr0K62wcTBzPBJLddoGKAIeZ64tlEZ0yDnSpZe558rrfcCQIxIYsTOZTdDKy/MrHaPtq+jXddXmfOqm3Gt/xc= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=boHqnTWR; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=boHqnTWR; arc=fail smtp.client-ip=52.101.70.30 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="boHqnTWR"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="boHqnTWR" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=vxbZ/Y3f1qzMRUjU/CgkQMyNC4FUMYzK6WBE6IRL9Noy/S1zokTQIyXNqtOssnkdQA6R70XumyREivwKcwzs0PLYFj8/RrqeIooY16JW8Und6p2hlHUWXDuamvT9Jn/LAfIKAI1RNVhARhZT25DwvK4Oc5vBue1BqAFJP09ex8SvnCDXVEjYwvFjckEhN3LMbc66Tb65TB5h0pfJnM2Qrc2jZ6jjV2lF9BaXNPck3lmr0bhtzNxJTizVW4IpPN2Qsqx0RIBH8qhB1kScZ8rZECBsZT683+CvGKilX7j4fl3ukoS+Cd5FVFv84gTyl+ycTLx0PYBsbCWjp6Bnv1tvng== ARC-Message-Signature: i=2; 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=it8tT5J8c9zU7HbJtk2+sJYs94lgrOvlespGby71dbQ=; b=RUdzSS9Wgdusggo1LjDqMKLGEIxeprF1tulZmfNB4X0Q8VdP7wRDac/DI8coCIMtDsk+qDe56KgwBji/OYNWyfTENgRSGBOk2eyIfeZDF+fztHu2A8yUTmTtkSi0tB9eC9hVyuayIGeIrf74hMiUMbv8yPQZUvtKV5PAPmq/9M90j1g1qjUufIlZsJu7TVscuAVZw50Zemq0egmJaDcrzbhc5F/rAjXOQ8lgQM1Em4YJ3K7q4mFim0kuYzFV5YVoHjQk2hJk2E6jrWFAOFgE8moT60pFsqkzKDs1DB7GM1i3Idp1e4TlmT8vkjJLxwf+xSIUyZvSRtLT1L3qttPbLg== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=it8tT5J8c9zU7HbJtk2+sJYs94lgrOvlespGby71dbQ=; b=boHqnTWRo2z+d5UKKEh8/ysySI8GT67a6buytM37KnAlb7Dwk/ENdr47UbvupNlXAU0l5ZsapF+EHiDzGPWYxSBDy70Onbide/0dYWtqlUinu06HERbm3RYTgIVnYHm9Wi2nTZCWzZsuKY3LulPD0n8GvEkXhhlvRVd+Kr1CFT4= Received: from DUZPR01CA0155.eurprd01.prod.exchangelabs.com (2603:10a6:10:4bd::11) by GV1PR08MB10908.eurprd08.prod.outlook.com (2603:10a6:150:1f5::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.11; Thu, 28 May 2026 15:07:08 +0000 Received: from DB1PEPF000509F5.eurprd02.prod.outlook.com (2603:10a6:10:4bd:cafe::79) by DUZPR01CA0155.outlook.office365.com (2603:10a6:10:4bd::11) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.14 via Frontend Transport; Thu, 28 May 2026 15:07:06 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by DB1PEPF000509F5.mail.protection.outlook.com (10.167.242.151) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.7 via Frontend Transport; Thu, 28 May 2026 15:07:05 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=JgMt7eblqxEj8VrJJqFxbmfYPH0pSpEdxuwWMIJMwxEY4wj9+J8z/S5kLmg7OL/XcBJE4OAY5rxNu/BMsKG6MCH6fVbztEJrVf0VGXFH/BSuWvzqjr6iEpFp7S1EaQMFcPZEeNZnVYBtJBSVtZ9fcs2VBRX7gtqwL1pXfBuuNuAKVeFuMO5lE0SCZXjOzDeU92LsmhLx8gQXn/dtr5vAnTbcR4mH45/KmtSj0ZG7Y5cMRscBDr2TtB132Wq6CfhWGujWVkjtLwmAw3nZNXf/81rjMr2KJACmOrKo4Uw8wr9PfeaLn2puorbNOgWnjkgM34ujcfHWNSjwsZuN8VhJwA== 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=it8tT5J8c9zU7HbJtk2+sJYs94lgrOvlespGby71dbQ=; b=IJLIma9SCKt5Ws/VgMWWtDH2S7tpl5A+GHUuNlRrUXls1ohkEZ/WoV7yvFMAZ41FMiDEKkGJcU4DxCFJ95gTrncb1yTwfusE7kcjpxqshqHGvKc6GQclKjwy25yxmvet4bJje1L668DVmAZRFBVLyi61Jl/9CWd+svGiJNXVX4ovCfvzKzsqlgdJOdtTd8NeZ+awbH37FbGEczed6zfH24kPr71YD/bqMymM7e4+iKPFQvWOr461BVr5WzQVVHCJzz+8vcJApphiy6Pj7qpjoicXeqhJN8vNjNhlagL1OPN3faq4pwnmxwNhmPpEeEdJViHmpDSy1K1X3UNWubprCw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=it8tT5J8c9zU7HbJtk2+sJYs94lgrOvlespGby71dbQ=; b=boHqnTWRo2z+d5UKKEh8/ysySI8GT67a6buytM37KnAlb7Dwk/ENdr47UbvupNlXAU0l5ZsapF+EHiDzGPWYxSBDy70Onbide/0dYWtqlUinu06HERbm3RYTgIVnYHm9Wi2nTZCWzZsuKY3LulPD0n8GvEkXhhlvRVd+Kr1CFT4= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:03 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:01 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 06/18] drm/panthor: Derive MMU AS register addresses from base and stride Date: Thu, 28 May 2026 16:05:34 +0100 Message-ID: <20260528150546.3168527-7-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: PA7P264CA0068.FRAP264.PROD.OUTLOOK.COM (2603:10a6:102:2de::14) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|DB1PEPF000509F5:EE_|GV1PR08MB10908:EE_ X-MS-Office365-Filtering-Correlation-Id: 0af7514f-d87c-45f0-bd44-08debccac82b X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|22082099003|18002099003|3023799007|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: j4yaiuO7qGpzgrrE/lpwdpBQKXKkh1Pnw/qQBE6YaXI0ApPtlPV8DuT88x4+6NbUlLvVlGol2U9jTf4jwfgnY9rLYLh0NBG57e3kTK1ZPhu8h8ppfZdZElCOWX8mGhr/Kd8JtFazC5NkLU0oShkMqW6CEL6Dw1aroUXs9bdXBsMvB+wWzdY8B1FSGLsYn5pV3jUHDx85FdaYQOom6fFVo7ZF0/33INJAUVZt3aaM4zPjO88Sl+pmneXz5yP8SkLMn9pBCKtiT5XvUZ+EQkacu+rMCKGQIfsOr/TTJlPcq3WKfAXXnhx9vky3se68Kf3eHzddrnJ3xM1LuXSD/zoqcOJKSY3nnBwBSlYO+xJUQZg9Yn0sItm/v+oCsx/SZeYyrx1Xcykc1eJQ5F+KLc7eO3x5+mkZe9cskowtIU3a3ihF1Hu0blqUBMRz0ChhXvixy7+lopdGumQOkvEbmYOgQFr1XBsyq5TGYmmn1mC74QHGPVxCdO8DGs7Ls64aOkzcu86Io0lmFKJ6zVRHO6agtXmuDmxuMh2G4GXK0dwyayrl818J3atoSWF8dfARJYJ9OVzuTq2zsIgc0dNIjYQQ/Fh0nc1sgEuyUgKMlKWDHws9dcbD3bweYJzKv8jTsFym+rY6PV9yGEx1Kif1bITMxISctHJrf1Y3NmesQNtGkEr48BhIrLEENSZcQTOvmfuT X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(22082099003)(18002099003)(3023799007)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: nsboRWAtkbiyKi/ZzxcZGyWx9jlr+6R/T1fnMc841nqnDucGEwxXPXaNid5wlkWcZVqMgM5aAAShUSs+KsmbQaXpfuTUUgNN4y6zk5skR573lMbr6/+2EbVPHCtvdQbzS6EuPvH5BVlQCOAUObNytimr3IBWmqfCtcLDK7Sq+PIQWJ24RZ1jip4rbgNd/gJfOK3CBYMAo9QX49x8zbJoS8nyBU8beGr+63Je+JfxKsk9kKMBI5saEweNRMZwrlSPpgIzrlgbz8EbvV5itiEXR8O5gJfetrXaLZm/Jk55HoCYFwZRygtWZ0os4jbilNR/GjmyVYsxrjWWklPjEGS5Ug== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: DB1PEPF000509F5.eurprd02.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: 01de8ad6-4d7e-479e-8a73-08debccaa1b3 X-Microsoft-Antispam: BCL:0;ARA:13230040|35042699022|376014|14060799003|1800799024|82310400026|36860700016|11063799006|3023799007|56012099006|22082099003|18002099003; X-Microsoft-Antispam-Message-Info: ZTm3wn40vPxJN1uSCcCavwEfGw6DCb8rSiLAFzwtRslxSrFog7oKDcw32Ouwbxg+LNIgCsu3C1ApTXm6C5tJTYptq2eJMFZeVQIyOFR9TE2E8+hj1Kr48OaUx4i3nw/E4we/Um8oI/y2bPlq1lsREG9l4aQYpOGF712ld8JlBp4pfOKoYlmQwZRrM5p1hvoY//cfOTG/0KmvBMCwwEmrY+8yhA4uAYi4mhMrhgkKbieLzhx0SSjrbwsBX44NbZg+CwBhKU0a0ap0fFwQ0ElJrJMe48tjP0N8Fk4sdN97A7SC26K/b22euaHQKXegjcbyqS30WFUjy7fOWTvv6SGyRbVEltM76yFGgevt40PxAyIcgCHl8PA1SYbd3izgcWg9uI2CQMyulIpgyzYmw+14JoBpmHyf343ymGFXL3HSsSjTJIYs/Iq8V6cxkpNKTXMvsi6Xa45KQm7SpYoW2NNX2A6ELj+59gQoFmxD7Ar7IUscJmyKTgpi/FRW0aRR39CKIzCymXRsMk4A6oowbNvLAGMW+QlaWZksKpFieFCh2VdmV8Q7T6QoOsyQZyrxU0z7pqrfjOeG2ewbgAVqQoXMhhboIdRvQ22AcCl7+4WSlJxKmhI/FpZwfr2pHV49HcrL9KM7Mct/zGLfoSigVxF2q+xoD09X56DWIwppqYr1w+V4qL/NmweEFcA6r2NYDzvnhBCWVOcJs4ZE5rygztjHEGIgQiD6TjA25tlT0T8ZI60= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(35042699022)(376014)(14060799003)(1800799024)(82310400026)(36860700016)(11063799006)(3023799007)(56012099006)(22082099003)(18002099003);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: //aBTQU0SSY3AcrCj3pKI5iECUtuyNCHVvng/5OPm4vWnMofg4io4LIxOPF8rbI4aUWjkyvUzUPApYpZdwDF6o5QnuKRETcc7WoUhW2vHyixm9nb9sIVj8e+FNz34kuvfisZSybU3lp/Z+wcT+J7HJ6w7DzQOcpu2LA4+KzccVp0AYhKgeYvI6UoSoLFhpp7mxN6zFuj1aE24tOKK9toUVGivRoduNCZ84RubtqHve1GFcTVV6UVHpWVNhfDXR2nBuJEPWCJBSGPCho8i4RcDmXdZgGX8dNGfAVNdtH7RLErAS3bMEsPV26jF8zFTAOZ9hj0eLdBfSSRcW8Tt8YXR2YT2IzKirDPvPejCLr16ytYtSyVxjf0pZzvfgRwHL1hjsOHnbidLaAm78QMSxFOIr5Fp99eDqFJqvOfh/dK9h/dKhSyLNn2wzPxV17rVZW5 X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:05.9839 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 0af7514f-d87c-45f0-bd44-08debccac82b X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: DB1PEPF000509F5.eurprd02.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: GV1PR08MB10908 Content-Type: text/plain; charset="utf-8" Move the MMU address-space register layout into the hardware description by storing the MMU_AS base offset and per-AS stride in the Panthor HW map. Use those values to compute the iomem pointer for each AS slot and make the MMU AS register definitions relative to the per-slot register window instead of hard-coding the slot offset in every register macro. This prepares the MMU code for GPUs where the MMU AS register region is not at a fixed offset while keeping the existing register accesses scoped to a single AS window. Signed-off-by: Karunika Choo --- drivers/gpu/drm/panthor/panthor_hw.c | 8 +++++ drivers/gpu/drm/panthor/panthor_hw.h | 8 +++++ drivers/gpu/drm/panthor/panthor_mmu.c | 35 ++++++++++++++-------- drivers/gpu/drm/panthor/panthor_mmu_regs.h | 23 ++++++-------- 4 files changed, 47 insertions(+), 27 deletions(-) diff --git a/drivers/gpu/drm/panthor/panthor_hw.c b/drivers/gpu/drm/panthor= /panthor_hw.c index 1f7fab4caf4d..e677f1a8f488 100644 --- a/drivers/gpu/drm/panthor/panthor_hw.c +++ b/drivers/gpu/drm/panthor/panthor_hw.c @@ -41,6 +41,10 @@ static struct panthor_hw panthor_hw_arch_v10 =3D { .map =3D { .gpu_control_base =3D 0x0, .mcu_control_base =3D 0x700, + .mmu_as =3D { + .base =3D 0x2400, + .stride =3D 0x40, + }, }, }; =20 @@ -54,6 +58,10 @@ static struct panthor_hw panthor_hw_arch_v14 =3D { .gpu_control_base =3D 0x0, .pwr_control_base =3D 0x800, .mcu_control_base =3D 0x700, + .mmu_as =3D { + .base =3D 0x2400, + .stride =3D 0x40, + }, }, }; =20 diff --git a/drivers/gpu/drm/panthor/panthor_hw.h b/drivers/gpu/drm/panthor= /panthor_hw.h index 58673a427bc9..0ae11b78c77e 100644 --- a/drivers/gpu/drm/panthor/panthor_hw.h +++ b/drivers/gpu/drm/panthor/panthor_hw.h @@ -38,6 +38,14 @@ struct panthor_hw_regmap { =20 /** @mcu_control_base: MCU_CONTROL base address */ u32 mcu_control_base; + + struct { + /** @mmu_as.base: MMU_AS base address */ + u32 base; + + /** @mmu_as.stride: Stride between subsequent MMU_AS register blocks */ + u32 stride; + } mmu_as; }; =20 /** diff --git a/drivers/gpu/drm/panthor/panthor_mmu.c b/drivers/gpu/drm/pantho= r/panthor_mmu.c index 48127313332f..9a64f977d28c 100644 --- a/drivers/gpu/drm/panthor/panthor_mmu.c +++ b/drivers/gpu/drm/panthor/panthor_mmu.c @@ -36,6 +36,7 @@ #include "panthor_gpu.h" #include "panthor_gpu_regs.h" #include "panthor_heap.h" +#include "panthor_hw.h" #include "panthor_mmu.h" #include "panthor_mmu_regs.h" #include "panthor_sched.h" @@ -57,7 +58,7 @@ struct panthor_as_slot { */ struct panthor_mmu { /** @iomem: CPU mapping of MMU_AS_CONTROL iomem region */ - void __iomem *iomem; + void __iomem *iomem[MAX_AS_SLOTS]; =20 /** @irq: The MMU irq. */ struct panthor_irq irq; @@ -528,7 +529,7 @@ static int wait_ready(struct panthor_device *ptdev, u32= as_nr) /* Wait for the MMU status to indicate there is no active command, in * case one is pending. */ - ret =3D gpu_read_relaxed_poll_timeout_atomic(mmu->iomem, AS_STATUS(as_nr)= , val, + ret =3D gpu_read_relaxed_poll_timeout_atomic(mmu->iomem[as_nr], AS_STATUS= , val, !(val & AS_STATUS_AS_ACTIVE), 10, 100000); =20 if (ret) { @@ -546,7 +547,7 @@ static int as_send_cmd_and_wait(struct panthor_device *= ptdev, u32 as_nr, u32 cmd /* write AS_COMMAND when MMU is ready to accept another command */ status =3D wait_ready(ptdev, as_nr); if (!status) { - gpu_write(ptdev->mmu->iomem, AS_COMMAND(as_nr), cmd); + gpu_write(ptdev->mmu->iomem[as_nr], AS_COMMAND, cmd); status =3D wait_ready(ptdev, as_nr); } =20 @@ -599,9 +600,9 @@ static int panthor_mmu_as_enable(struct panthor_device = *ptdev, u32 as_nr, panthor_mmu_irq_enable_events(&ptdev->mmu->irq, panthor_mmu_as_fault_mask(ptdev, as_nr)); =20 - gpu_write64(mmu->iomem, AS_TRANSTAB(as_nr), transtab); - gpu_write64(mmu->iomem, AS_MEMATTR(as_nr), memattr); - gpu_write64(mmu->iomem, AS_TRANSCFG(as_nr), transcfg); + gpu_write64(mmu->iomem[as_nr], AS_TRANSTAB, transtab); + gpu_write64(mmu->iomem[as_nr], AS_MEMATTR, memattr); + gpu_write64(mmu->iomem[as_nr], AS_TRANSCFG, transcfg); =20 return as_send_cmd_and_wait(ptdev, as_nr, AS_COMMAND_UPDATE); } @@ -637,9 +638,9 @@ static int panthor_mmu_as_disable(struct panthor_device= *ptdev, u32 as_nr, if (recycle_slot) return 0; =20 - gpu_write64(mmu->iomem, AS_TRANSTAB(as_nr), 0); - gpu_write64(mmu->iomem, AS_MEMATTR(as_nr), 0); - gpu_write64(mmu->iomem, AS_TRANSCFG(as_nr), AS_TRANSCFG_ADRMODE_UNMAPPED); + gpu_write64(mmu->iomem[as_nr], AS_TRANSTAB, 0); + gpu_write64(mmu->iomem[as_nr], AS_MEMATTR, 0); + gpu_write64(mmu->iomem[as_nr], AS_TRANSCFG, AS_TRANSCFG_ADRMODE_UNMAPPED); =20 return as_send_cmd_and_wait(ptdev, as_nr, AS_COMMAND_UPDATE); } @@ -1739,7 +1740,7 @@ static int panthor_vm_lock_region(struct panthor_vm *= vm, u64 start, u64 size) mutex_lock(&ptdev->mmu->as.slots_lock); if (vm->as.id >=3D 0 && size) { /* Lock the region that needs to be updated */ - gpu_write64(ptdev->mmu->iomem, AS_LOCKADDR(vm->as.id), + gpu_write64(ptdev->mmu->iomem[vm->as.id], AS_LOCKADDR, pack_region_range(ptdev, &start, &size)); =20 /* If the lock succeeded, update the locked_region info. */ @@ -1801,8 +1802,8 @@ static void panthor_mmu_irq_handler(struct panthor_de= vice *ptdev, u32 status) u32 access_type; u32 source_id; =20 - fault_status =3D gpu_read(mmu->iomem, AS_FAULTSTATUS(as)); - addr =3D gpu_read64(mmu->iomem, AS_FAULTADDRESS(as)); + fault_status =3D gpu_read(mmu->iomem[as], AS_FAULTSTATUS); + addr =3D gpu_read64(mmu->iomem[as], AS_FAULTADDRESS); =20 /* decode the fault status */ exception_type =3D fault_status & 0xFF; @@ -3237,8 +3238,11 @@ static void panthor_mmu_release_wq(struct drm_device= *ddev, void *res) int panthor_mmu_init(struct panthor_device *ptdev) { u32 va_bits =3D GPU_MMU_FEATURES_VA_BITS(ptdev->gpu_info.mmu_features); + unsigned long as_present_mask =3D ptdev->gpu_info.as_present; + struct panthor_hw_regmap *regmap =3D &ptdev->hw->map; struct panthor_mmu *mmu; int ret, irq; + u32 as_id; =20 mmu =3D drmm_kzalloc(&ptdev->base, sizeof(*mmu), GFP_KERNEL); if (!mmu) @@ -3255,7 +3259,12 @@ int panthor_mmu_init(struct panthor_device *ptdev) if (ret) return ret; =20 - mmu->iomem =3D ptdev->iomem + MMU_AS_BASE; + for_each_set_bit(as_id, &as_present_mask, MAX_AS_SLOTS) { + u64 offset =3D regmap->mmu_as.base + (regmap->mmu_as.stride * as_id); + + mmu->iomem[as_id] =3D ptdev->iomem + offset; + } + ptdev->mmu =3D mmu; =20 irq =3D platform_get_irq_byname(to_platform_device(ptdev->base.dev), "mmu= "); diff --git a/drivers/gpu/drm/panthor/panthor_mmu_regs.h b/drivers/gpu/drm/p= anthor/panthor_mmu_regs.h index 4e32ab931949..9d3747601e69 100644 --- a/drivers/gpu/drm/panthor/panthor_mmu_regs.h +++ b/drivers/gpu/drm/panthor/panthor_mmu_regs.h @@ -10,13 +10,8 @@ =20 /* AS_COMMAND register commands */ =20 -#define MMU_AS_BASE 0x2400 - -#define MMU_AS_SHIFT 6 -#define MMU_AS(as) ((as) << MMU_AS_SHIFT) - -#define AS_TRANSTAB(as) (MMU_AS(as) + 0x0) -#define AS_MEMATTR(as) (MMU_AS(as) + 0x8) +#define AS_TRANSTAB 0x0 +#define AS_MEMATTR 0x8 #define AS_MEMATTR_AARCH64_INNER_ALLOC_IMPL (2 << 2) #define AS_MEMATTR_AARCH64_INNER_ALLOC_EXPL(w, r) ((3 << 2) | \ ((w) ? BIT(0) : 0) | \ @@ -28,8 +23,8 @@ #define AS_MEMATTR_AARCH64_INNER_OUTER_NC (1 << 6) #define AS_MEMATTR_AARCH64_INNER_OUTER_WB (2 << 6) #define AS_MEMATTR_AARCH64_FAULT (3 << 6) -#define AS_LOCKADDR(as) (MMU_AS(as) + 0x10) -#define AS_COMMAND(as) (MMU_AS(as) + 0x18) +#define AS_LOCKADDR 0x10 +#define AS_COMMAND 0x18 #define AS_COMMAND_NOP 0 #define AS_COMMAND_UPDATE 1 #define AS_COMMAND_LOCK 2 @@ -37,16 +32,16 @@ #define AS_COMMAND_FLUSH_PT 4 #define AS_COMMAND_FLUSH_MEM 5 #define AS_LOCK_REGION_MIN_SIZE (1ULL << 15) -#define AS_FAULTSTATUS(as) (MMU_AS(as) + 0x1C) +#define AS_FAULTSTATUS 0x1C #define AS_FAULTSTATUS_ACCESS_TYPE_MASK (0x3 << 8) #define AS_FAULTSTATUS_ACCESS_TYPE_ATOMIC (0x0 << 8) #define AS_FAULTSTATUS_ACCESS_TYPE_EX (0x1 << 8) #define AS_FAULTSTATUS_ACCESS_TYPE_READ (0x2 << 8) #define AS_FAULTSTATUS_ACCESS_TYPE_WRITE (0x3 << 8) -#define AS_FAULTADDRESS(as) (MMU_AS(as) + 0x20) -#define AS_STATUS(as) (MMU_AS(as) + 0x28) +#define AS_FAULTADDRESS 0x20 +#define AS_STATUS 0x28 #define AS_STATUS_AS_ACTIVE BIT(0) -#define AS_TRANSCFG(as) (MMU_AS(as) + 0x30) +#define AS_TRANSCFG 0x30 #define AS_TRANSCFG_ADRMODE_UNMAPPED (1 << 0) #define AS_TRANSCFG_ADRMODE_IDENTITY (2 << 0) #define AS_TRANSCFG_ADRMODE_AARCH64_4K (6 << 0) @@ -64,6 +59,6 @@ #define AS_TRANSCFG_DISABLE_AF_FAULT BIT(34) #define AS_TRANSCFG_WXN BIT(35) #define AS_TRANSCFG_XREADABLE BIT(36) -#define AS_FAULTEXTRA(as) (MMU_AS(as) + 0x38) +#define AS_FAULTEXTRA 0x38 =20 #endif /* __PANTHOR_MMU_REGS_H__ */ --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from DU2PR03CU002.outbound.protection.outlook.com (mail-northeuropeazon11011023.outbound.protection.outlook.com [52.101.65.23]) (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 572CB3F39FC for ; Thu, 28 May 2026 15:07:16 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.65.23 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980843; cv=fail; b=uSrubA8Ya7mnvkvgEtGqujUvgV3qHwEdDAq1AQOfZdiHxlvTap59+buxME9xyUHRtyeC8ozXtU9rn/Ai7H5uBAUMLaY3kKlJ64paePFheTzS9NbuMP+JH7OA2rSk7AudhabhrkEc8noldqcr38PsLfQajOnktMNleZAos8wmMN4= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980843; c=relaxed/simple; bh=Hn0b3mb31ekKuLVJ2Q+li5t4VrKh9dECMhWB4hgdtDI=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=GczfnRV2I9xsTFSr9InhcJJJ/RHX8Oq5eb1iB+ZamaYlI/hsS7wDXaFJLdnVU8rK+flSHP7NuWlXCGgYvA4xHLbyR7ncrIRMmSGy5rBMaGdcW69N3/mDKt4ukVca1vkL2jsQCVUfL1+57HXZ5AwI6K1sGXj93xLsNmid8QRDd7Q= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=AEevoAM9; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=AEevoAM9; arc=fail smtp.client-ip=52.101.65.23 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="AEevoAM9"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="AEevoAM9" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=c4aBD2ePJ0oP5ih1LtEbIUkfkcBn95+ObTG2J+QjgsPT2HUpMIlVeCvPKMWGQ2IKqZxF2a7Jt9IzZPbWkoRAe1JJwXWr3scwqQhaZKiEpXTcMIo/SGxXn8jHefmDq6cep2rLzD4/4umExWM1mso3vRmfikeV4GbLC/noSvgi/zV/NBG3aUDMO5eN/JTVB0LH3GNgYdlSA85IhX6L+DyvzLsp7vsYAQJi+4Nd6p5YuP/HFyrxm1OpCltRams2FNag1mDPuOH9hdApMtw00tCfM/4rYOzYEivTYsXbR7to+VUQMR7y1mgyGvX4cdmyJzqJmjBLKAMCuNYddqagA0/+3w== ARC-Message-Signature: i=2; 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=/9l4J+Wa9HlncrFg48/Cw/gSHh7yTxKzXMxQ175aARw=; b=HRa4UGsD5S16Iy/9lJKQCj9hAkZFRkWt5TtuLlfoCNswalVQyZCLMaYxtXI9WbmlLh8vfrdTkI7+BdLAhuy4+4BlC1dabUWbozPGlklmU3qq3cG8LCdr3dos0rk4bCGJL07nkqo6T/+MSEwRD36tnOuLuaJN9q7PDUccBTalEtLuZlYKLEFpOy7yKlYoeBnXlhYnXeq9anFX5fjyBJyS1g+gdEyGnvBrnrLt1NNm/Lty72WP/SpxIh1Z+kRpWk9L7s86XQu7ak2UgaACXkTA2EvjF8WPh8q+5KQ+pY3A76TXL1VUJtE9D6QmsKSMTw/ktaSWc8FxAS9UXpWUmYJ8ig== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=/9l4J+Wa9HlncrFg48/Cw/gSHh7yTxKzXMxQ175aARw=; b=AEevoAM9LZr6cRvN8T/pqRYoe492/TsCToKap0YedJSqMIz143e52UBkfB9fjTIGUPU+zS4KviNTSx8/CtdiLnZGOdLbWJeC0HbTKWS9osGcADDrsGxsCvjY1ZtnxBkkW+yWYPbuNbTtFaNUjOLvMgjWzNdcNCeFG3ugIkK3Yug= Received: from DU7P190CA0011.EURP190.PROD.OUTLOOK.COM (2603:10a6:10:550::28) by GV2PR08MB8413.eurprd08.prod.outlook.com (2603:10a6:150:c3::13) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.12; Thu, 28 May 2026 15:07:06 +0000 Received: from DU6PEPF00009526.eurprd02.prod.outlook.com (2603:10a6:10:550:cafe::8a) by DU7P190CA0011.outlook.office365.com (2603:10a6:10:550::28) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.13 via Frontend Transport; Thu, 28 May 2026 15:07:06 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by DU6PEPF00009526.mail.protection.outlook.com (10.167.8.7) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.7 via Frontend Transport; Thu, 28 May 2026 15:07:06 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=QCz7SApuYspcihmLXMfVEJ2W6nzb58guQV8h2aq9Uh/w+GuVQBeeixghQW1nafXWloD6bK2wecORU3Q+kiz8Vj0Wm1vBolDI6dJMHaOnXBszEa2zG06zGsh57G0pzlKeoDn95bWD3G58/j6Mgn0HPhHvQHHo0+iAk0n3uh0p83pQN9KlXlzJ1IKB0+Gvt/m1+z4QdHTQ2qy14LPeI+fqIG54eIxfOZn8OuchPj2v7B8vP20pkyTqcy/rfQ7xRg6GR+hh1mOzy2v7YlpmRblO06FBzTlankRODQBUXnNwuqB3NF093IbgJmxTkfqybZpo4HeWV/KhSRSknM/NWGGSRg== 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=/9l4J+Wa9HlncrFg48/Cw/gSHh7yTxKzXMxQ175aARw=; b=WlacGpJBhAMAePhdjXIQM1F2BxdXe++7pCD+on8MezOvAahbq6nj8ldlvFVz7f2q2IdEEI7p+R7Prxh6ThkVOaKipWYFYMLnmCQStdkO22I9BQonv3Bw7S+IJQ1deGDbOzV8JIWW5/+rcTsHHtG9P5CLQGH2dToAiaw+ffd8rKgIzNn0rKsHbj7lHHc+vC6EVrnxN2Os/mDYSvC8DVzdctdv41m3kGcHUGyoSl1c/pGcwztCOnqFlaMcolYSXGBRIE0r9OpPFPFfSoAf8RDyk7BizkUmdMy4jPLT6njGIq5V1XlQR8rS8oX15+YQWCbi/8OKyysziq7UzhV3QHo2Wg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=/9l4J+Wa9HlncrFg48/Cw/gSHh7yTxKzXMxQ175aARw=; b=AEevoAM9LZr6cRvN8T/pqRYoe492/TsCToKap0YedJSqMIz143e52UBkfB9fjTIGUPU+zS4KviNTSx8/CtdiLnZGOdLbWJeC0HbTKWS9osGcADDrsGxsCvjY1ZtnxBkkW+yWYPbuNbTtFaNUjOLvMgjWzNdcNCeFG3ugIkK3Yug= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:03 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:03 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 07/18] drm/panthor: Add Mali v15 hardware support Date: Thu, 28 May 2026 16:05:35 +0100 Message-ID: <20260528150546.3168527-8-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: PA7P264CA0178.FRAP264.PROD.OUTLOOK.COM (2603:10a6:102:36f::10) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|DU6PEPF00009526:EE_|GV2PR08MB8413:EE_ X-MS-Office365-Filtering-Correlation-Id: b7efe91f-7a3d-4a39-9066-08debccac872 X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|6133799003|22082099003|18002099003|3023799007|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: MpPu25yc+09cn3hao2RWrhBhmDrTIFDHz10YbX7ycRpqh1rMht4z4voo1SiBj0WJb9Gp/8ZFcYuX1K4D7yUK0pRmjU+gkkhFjywS2CwTsf5yKCzdq19VnvfcRh2e4KOrCLlsxDBx73mzZShd0y2Q1vx0ZiVW9mqqw11YU7WsFkvq2a7aw1DvsN/xhjjp58abervGmDtLCG9fY0ge+SGBN5gYmnqhGzULLYtDARf/XPK9lFnVlwJk/Zskbu/u2Tvxcj9C5QDzuKTpEJK69Xiw9RTG0MYoOMhfcRX380W4QoP9xaCdruULhx6HoAJ5Ui4IoM6E/S/Mz/4yV8P8xgfwHvEXs7yFksdDEKq1cv0wmztKjlgeVr8F8WNCjpsiziUgTYx7o4tKuMjC/uk7lilePChODWgRf9mIAcWi4UEdAsnYxSVHghonlDu5OUtZklsQSYED2NpYIVX+KbdYXvcw0oIr5Zq/tIl+HM/Sab25OuPUh95ofOCZxgJ/632d/3fMjI3jIaSROQz5xekJyvj+YervzytTL88tOCv25gwjsxI9SJmwy0+X+UC5fnsOFvnitr1a8qJ4aQB+pCxPsCbRuK82diAZ2eANT1maHYRLgObPSHFZpcCR2eY/cGKl7JMFitO00BBQxSozwUNPcc1/zdbcCPgCJ0Pq1ZZiyQtSKi1pOrlvkThZgKH+LQEs8rrI X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(6133799003)(22082099003)(18002099003)(3023799007)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: rDv5WKIbtcD0HYY2bG11bPG+2P5l5g6tKygR0TeHFssyMhO8dLVR3+U7hs5d00c8071vsof99Dhb4EG3gGBwYfG5PIC8feSzIfyHR93I8Ys1DiUoweW6TL4xIvPmHCVC2izYUTL3HhwLraTgAJeQreuZTjhgvBYGEyx7EAiXacOHWNbe43U/P9GJrCyWRJ05HrgcwNrC2zQfcttLZzcUX2mkbvDEsJO8PdpvXPzcCm9m5pvgYtkpbkhn6ag1GOV4sOpED0C6s0YxoMexvcyUXl0UTI7QlMhXWHM1YM2oQlFq1B8b6Q0Wf7FqO4k8vNXVt3fM+cacTNb4BAgsUwrIBw== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: DU6PEPF00009526.eurprd02.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: bb465505-aa9c-434b-b90a-08debccaa286 X-Microsoft-Antispam: BCL:0;ARA:13230040|82310400026|376014|36860700016|1800799024|14060799003|35042699022|11063799006|6133799003|56012099006|3023799007|22082099003|18002099003; X-Microsoft-Antispam-Message-Info: AGEDiTk7C/wsf5So3OilGdMkPs+GtBQGyWtyq17HxqRPBtp9W1AEUHsIkb4PE0DmGgLoR0D5cqf319+SwhY8LyhTrNCr1sQG3/D551Sw4IHsnDeSfI9co0haSWv8u9cGaOKZ7ruj9HzbOhAWiW28ghH1DL5QuujriN4dpySa7681F7pWhn14kMic7T0c4jC/yd2mveXZmTiu+axVW0ncvG/RJCiHxm7nb95U1HED4NeW9bw8sOtpOlvxjCKI1X4oacMqDbfRy7LDF3mrcfFh264/bzeHcHDV96sRkw5d2lR1CCip+iWh9OUkQmWs2ctshlR7zw6tMbOZZEfbYQSuA4zGyLb4RzVtFfFTVNMXLxrVh49iAuPBMtMruCYpODKj4luOeUgSIrDRA2GrkLVocir2HgvnOlnJM63v1Y4KQe9JeQRDcYYABTnDu/rxxxbF+QpfxBTlxdiRgLT+0bFqMZHwV2KX96fw+4siVdsAdUbk79vjK5DnFFaBzQHyLkjd2r7hCeYFtd4cfrTLUfCOQww9CZTk3veMOhnOlYyXHBUXzBEZI78aSgkJmApxvYwxM8FyM1qPmCgatzv1Y94qZJcKMBZZ/4fTYIryaW8VX4DewCowoV0VrzPpbH5ynP3QpJqbavASWxnzl4qRwxTLYAjMEyKfud2AyQW5o7LHCLZ2kNdy31O32pezLHuhc1pfjjI5KavI/d4LW0Z8DWeAPPsrZ27eKa4B/yd9b90bs1c= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(82310400026)(376014)(36860700016)(1800799024)(14060799003)(35042699022)(11063799006)(6133799003)(56012099006)(3023799007)(22082099003)(18002099003);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: OHobKJTytizB0CpXmxqkTJoD0InFeuHZpgDvqhi2GosMKrQ8XOKPiqBz7oDoZzTT+LYlXCNBEbharSsDxPl1oRSQQU6iHkvsiFYvsS073sKjjeRdE2Yxj0IbUH9In60tRLcCIUJ9xS2NstmB2m7S9EVpJRqnzLsz+aQftHsreJQjc953Rv1mIngGBJrKLVdIod/IZSuwf6HHZSTC91G/LH0vjXMez8z9aUdmt8pT6N8m70McawL4hLOZBxlwwn7W3YaK2i27ITPdpmbFBwMRh/uv+yNth5PeoNORFQs/m1K+pw5mvdX0OqhKN51riHTrTPM4XtzFirITvKlBgTP2sskbvUtHu74zBQzPljG2eBEppnyWemJUo9XqEAToUbINGOkdKm2zCQPy+kIYeM8Bf3/Jv4fAU2rDVki4EIo1MKFRHjTQ3MIA+UGaZ75uhEPB X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:06.4409 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: b7efe91f-7a3d-4a39-9066-08debccac872 X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: DU6PEPF00009526.eurprd02.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: GV2PR08MB8413 Content-Type: text/plain; charset="utf-8" Add the panthor hardware description for Mali v15 GPUs and hook it into device matching. This includes the v15 register map and product identification needed to populate the GPU information exposed by the driver and its uAPI. Add compatibility string for v15 GPUs. Signed-off-by: Karunika Choo --- drivers/gpu/drm/panthor/panthor_drv.c | 1 + drivers/gpu/drm/panthor/panthor_fw.c | 1 + .../drm/panthor/panthor_gpu_discover_regs.h | 25 ++++++ drivers/gpu/drm/panthor/panthor_heap.c | 3 +- drivers/gpu/drm/panthor/panthor_hw.c | 81 ++++++++++++++++++- drivers/gpu/drm/panthor/panthor_hw.h | 13 +++ include/uapi/drm/panthor_drm.h | 10 ++- 7 files changed, 128 insertions(+), 6 deletions(-) diff --git a/drivers/gpu/drm/panthor/panthor_drv.c b/drivers/gpu/drm/pantho= r/panthor_drv.c index e8dc4096c1d2..21644a60c8e4 100644 --- a/drivers/gpu/drm/panthor/panthor_drv.c +++ b/drivers/gpu/drm/panthor/panthor_drv.c @@ -1875,6 +1875,7 @@ static const struct of_device_id dt_match[] =3D { { .compatible =3D "mediatek,mt8196-mali", .data =3D &soc_data_mediatek_mt= 8196, }, { .compatible =3D "rockchip,rk3588-mali" }, { .compatible =3D "arm,mali-valhall-csf" }, + { .compatible =3D "arm,mali-gen5-am" }, {} }; MODULE_DEVICE_TABLE(of, dt_match); diff --git a/drivers/gpu/drm/panthor/panthor_fw.c b/drivers/gpu/drm/panthor= /panthor_fw.c index f6381f5f236f..e2a511b741f4 100644 --- a/drivers/gpu/drm/panthor/panthor_fw.c +++ b/drivers/gpu/drm/panthor/panthor_fw.c @@ -1529,3 +1529,4 @@ MODULE_FIRMWARE("arm/mali/arch11.8/mali_csffw.bin"); MODULE_FIRMWARE("arm/mali/arch12.8/mali_csffw.bin"); MODULE_FIRMWARE("arm/mali/arch13.8/mali_csffw.bin"); MODULE_FIRMWARE("arm/mali/arch14.8/mali_csffw.bin"); +MODULE_FIRMWARE("arm/mali/arch15.8/mali_csffw.bin"); diff --git a/drivers/gpu/drm/panthor/panthor_gpu_discover_regs.h b/drivers/= gpu/drm/panthor/panthor_gpu_discover_regs.h index 54bb104902ee..9c64676dc35a 100644 --- a/drivers/gpu/drm/panthor/panthor_gpu_discover_regs.h +++ b/drivers/gpu/drm/panthor/panthor_gpu_discover_regs.h @@ -14,4 +14,29 @@ #define GPU_WIDE_VER_MINOR(x) (((x) & GENMASK(15, 8)) >> 8) #define GPU_WIDE_VER_STATUS(x) ((x) & GENMASK(7, 0)) =20 +#define DISCOVER_REVIDR 0x8 +#define DISCOVER_GPU_FEATURES 0x20 +#define GPU_FEATURES_VARIABLE_RATE_SHADING BIT(0) +#define GPU_FEATURES_SIMD_STATE BIT(1) +#define GPU_FEATURES_CROSS_STREAM_SYNC BIT(3) +#define GPU_FEATURES_NX BIT(4) +#define GPU_FEATURES_RAY_TRAVERSAL BIT(5) +#define GPU_FEATURES_LD_LEA_TENSOR_INSTRUCTIONS BIT(6) +#define DISCOVER_MCU_FEATURES 0x40 +#define DISCOVER_PRFCNT_FEATURES 0x50 +#define PRFCNT_FEATURES_COUNTER_BLOCK_SIZE(x) (((x) & GENMASK(7, 0)) <<= 8) +#define DISCOVER_DOORBELL_FEATURES 0x60 +#define DISCOVER_MEM_FEATURES 0x100 +#define DISCOVER_MMU_FEATURES 0x108 +#define MMU_FEATURES_AS_COUNT(x) (((x) & GENMASK(23, 16)) >> 16) +#define DISCOVER_AMBA_FEATURES 0x120 + +#define DISCOVER_L2_FEATURES 0x128 +#define DISCOVER_TILER_FEATURES 0x200 +#define DISCOVER_CORE_FEATURES 0x300 +#define DISCOVER_THREAD_FEATURES 0x320 +#define DISCOVER_THREAD_MAX_THREADS 0x330 +#define DISCOVER_THREAD_NUM_ACTIVE_GRANULARITY 0x334 +#define DISCOVER_TEXTURE_FEATURES 0x360 + #endif /* __PANTHOR_GPU_DISCOVER_REGS_H__ */ diff --git a/drivers/gpu/drm/panthor/panthor_heap.c b/drivers/gpu/drm/panth= or/panthor_heap.c index 99311abdf1e9..afb7d68abc87 100644 --- a/drivers/gpu/drm/panthor/panthor_heap.c +++ b/drivers/gpu/drm/panthor/panthor_heap.c @@ -11,6 +11,7 @@ #include "panthor_gem.h" #include "panthor_gpu_regs.h" #include "panthor_heap.h" +#include "panthor_hw.h" #include "panthor_mmu.h" =20 /* @@ -105,7 +106,7 @@ struct panthor_heap_pool { =20 static int panthor_heap_ctx_stride(struct panthor_device *ptdev) { - u32 l2_features =3D ptdev->gpu_info.l2_features; + u64 l2_features =3D panthor_hw_get_l2_features(ptdev); u32 gpu_cache_line_size =3D GPU_L2_FEATURES_LINE_SIZE(l2_features); =20 return ALIGN(HEAP_CONTEXT_SIZE, gpu_cache_line_size); diff --git a/drivers/gpu/drm/panthor/panthor_hw.c b/drivers/gpu/drm/panthor= /panthor_hw.c index e677f1a8f488..52271fb9db52 100644 --- a/drivers/gpu/drm/panthor/panthor_hw.c +++ b/drivers/gpu/drm/panthor/panthor_hw.c @@ -65,6 +65,23 @@ static struct panthor_hw panthor_hw_arch_v14 =3D { }, }; =20 +static struct panthor_hw panthor_hw_arch_v15 =3D { + .ops =3D { + .soft_reset =3D panthor_pwr_reset_soft, + .l2_power_off =3D panthor_pwr_l2_power_off, + .l2_power_on =3D panthor_pwr_l2_power_on, + }, + .map =3D { + .gpu_control_base =3D 0x3000, + .pwr_control_base =3D 0x3800, + .mcu_control_base =3D 0x3100, + .mmu_as =3D { + .base =3D 0x2800, + .stride =3D 0x80, + }, + }, +}; + static struct panthor_hw_entry panthor_hw_match[] =3D { { .arch_min =3D 10, @@ -76,6 +93,11 @@ static struct panthor_hw_entry panthor_hw_match[] =3D { .arch_max =3D 14, .hwdev =3D &panthor_hw_arch_v14, }, + { + .arch_min =3D 15, + .arch_max =3D 15, + .hwdev =3D &panthor_hw_arch_v15, + } }; =20 static int panthor_hw_set_power_tracing(struct device *dev, void *data) @@ -187,6 +209,12 @@ static char *get_gpu_model_name(struct panthor_device = *ptdev) return "Mali-G1-Premium"; case GPU_PROD_ID_MAKE(14, 3): return "Mali-G1-Pro"; + case GPU_PROD_ID_MAKE(15, 0): + return "Mali-G2-Ultra"; + case GPU_PROD_ID_MAKE(15, 1): + return "Mali-G2-Premium"; + case GPU_PROD_ID_MAKE(15, 3): + return "Mali-G2-Pro"; } =20 return "(Unknown Mali GPU)"; @@ -210,7 +238,7 @@ static int overload_shader_present(struct panthor_devic= e *ptdev) return 0; } =20 -static int panthor_gpu_info_init(struct panthor_device *ptdev) +static void panthor_gpu_info_v10_init(struct panthor_device *ptdev) { unsigned int i; =20 @@ -251,12 +279,56 @@ static int panthor_gpu_info_init(struct panthor_devic= e *ptdev) ptdev->gpu_info.tiler_present =3D gpu_read64(gpu_iomem, GPU_TILER_PRESEN= T); ptdev->gpu_info.l2_present =3D gpu_read64(gpu_iomem, GPU_L2_PRESENT); } +} + +static void panthor_gpu_info_v15_init(struct panthor_device *ptdev) +{ + void __iomem *pwr_iomem =3D ptdev->iomem + ptdev->hw->map.pwr_control_bas= e; + u64 texture_features; + + ptdev->gpu_info.gpu_rev_wide =3D gpu_read64(ptdev->iomem, DISCOVER_REVIDR= ); + ptdev->gpu_info.l2_features_wide =3D gpu_read64(ptdev->iomem, DISCOVER_L2= _FEATURES); + + texture_features =3D gpu_read64(ptdev->iomem, DISCOVER_TEXTURE_FEATURES); + ptdev->gpu_info.texture_features[0] =3D lower_32_bits(texture_features); + ptdev->gpu_info.texture_features[1] =3D upper_32_bits(texture_features); + + ptdev->gpu_info.thread_features =3D gpu_read(ptdev->iomem, DISCOVER_THREA= D_FEATURES); + ptdev->gpu_info.max_threads =3D gpu_read(ptdev->iomem, DISCOVER_THREAD_MA= X_THREADS); + ptdev->gpu_info.thread_num_active_granularity =3D + gpu_read(ptdev->iomem, DISCOVER_THREAD_NUM_ACTIVE_GRANULARITY); + + ptdev->gpu_info.gpu_features =3D gpu_read64(ptdev->iomem, DISCOVER_GPU_FE= ATURES); + + /* The following _HI registers do not contain any information (yet) */ + ptdev->gpu_info.mem_features =3D gpu_read(ptdev->iomem, DISCOVER_MEM_FEAT= URES); + ptdev->gpu_info.mmu_features =3D gpu_read(ptdev->iomem, DISCOVER_MMU_FEAT= URES); + ptdev->gpu_info.coherency_features =3D gpu_read(ptdev->iomem, DISCOVER_AM= BA_FEATURES); + ptdev->gpu_info.tiler_features =3D gpu_read(ptdev->iomem, DISCOVER_TILER_= FEATURES); + ptdev->gpu_info.core_features =3D gpu_read(ptdev->iomem, DISCOVER_CORE_FE= ATURES); + + /* AS_PRESENT register removed on v15+ create virtual mask from MMU_FEATU= RES.AS_COUNT */ + ptdev->gpu_info.as_present =3D + (1U << MMU_FEATURES_AS_COUNT(ptdev->gpu_info.mmu_features)) - 1; + + ptdev->gpu_info.l2_present =3D gpu_read64(pwr_iomem, PWR_L2_PRESENT); + ptdev->gpu_info.tiler_present =3D gpu_read64(pwr_iomem, PWR_TILER_PRESENT= ); + ptdev->gpu_info.shader_present =3D gpu_read64(pwr_iomem, PWR_SHADER_PRESE= NT); +} + +static int panthor_gpu_info_init(struct panthor_device *ptdev) +{ + if (panthor_hw_has_gpu_discover(ptdev)) + panthor_gpu_info_v15_init(ptdev); + else + panthor_gpu_info_v10_init(ptdev); =20 return overload_shader_present(ptdev); } =20 static int panthor_hw_info_init(struct panthor_device *ptdev) { + u64 l2_features =3D ptdev->gpu_info.l2_features; u32 major, minor, status; int ret; =20 @@ -268,14 +340,17 @@ static int panthor_hw_info_init(struct panthor_device= *ptdev) minor =3D ptdev->gpu_id.ver.minor; status =3D ptdev->gpu_id.ver.status; =20 + if (panthor_hw_has_gpu_discover(ptdev)) + l2_features =3D ptdev->gpu_info.l2_features_wide; + drm_info(&ptdev->base, "%s id 0x%x major 0x%x minor 0x%x status 0x%x", get_gpu_model_name(ptdev), ptdev->gpu_id.prod_major, major, minor, status); =20 drm_info(&ptdev->base, - "Features: L2:%#x Tiler:%#x Mem:%#x MMU:%#x AS:%#x", - ptdev->gpu_info.l2_features, + "Features: L2:%#llx Tiler:%#x Mem:%#x MMU:%#x AS:%#x", + l2_features, ptdev->gpu_info.tiler_features, ptdev->gpu_info.mem_features, ptdev->gpu_info.mmu_features, diff --git a/drivers/gpu/drm/panthor/panthor_hw.h b/drivers/gpu/drm/panthor= /panthor_hw.h index 0ae11b78c77e..1b2678ea00db 100644 --- a/drivers/gpu/drm/panthor/panthor_hw.h +++ b/drivers/gpu/drm/panthor/panthor_hw.h @@ -83,4 +83,17 @@ static inline bool panthor_hw_has_pwr_ctrl(struct pantho= r_device *ptdev) return ptdev->gpu_id.arch.major >=3D 14; } =20 +static inline bool panthor_hw_has_gpu_discover(struct panthor_device *ptde= v) +{ + return ptdev->gpu_id.arch.major >=3D 15; +} + +static inline u64 panthor_hw_get_l2_features(struct panthor_device *ptdev) +{ + if (panthor_hw_has_gpu_discover(ptdev)) + return ptdev->gpu_info.l2_features_wide; + + return ptdev->gpu_info.l2_features; +} + #endif /* __PANTHOR_HW_H__ */ diff --git a/include/uapi/drm/panthor_drm.h b/include/uapi/drm/panthor_drm.h index 04fc9f133152..2ecc50eade27 100644 --- a/include/uapi/drm/panthor_drm.h +++ b/include/uapi/drm/panthor_drm.h @@ -368,8 +368,8 @@ struct drm_panthor_gpu_info { /** @core_features: Used to discriminate core variants when they exist. */ __u32 core_features; =20 - /** @pad: MBZ. */ - __u32 pad; + /** @thread_num_active_granularity: Granularity of number of active threa= ds */ + __u32 thread_num_active_granularity; =20 /** @gpu_features: Bitmask describing supported GPU-wide features */ __u64 gpu_features; @@ -383,6 +383,12 @@ struct drm_panthor_gpu_info { #define DRM_PANTHOR_WIDE_VERSION_MAJOR(x) (((x) >> 16) & 0xff) #define DRM_PANTHOR_WIDE_VERSION_MINOR(x) (((x) >> 8) & 0xff) #define DRM_PANTHOR_WIDE_VERSION_STATUS(x) ((x) & 0xff) + + /** @gpu_rev_wide: 64-bit GPU revision for v15 onwards */ + __u64 gpu_rev_wide; + + /** @l2_features_wide: 64-bit L2_FEATURES for v15 onwards */ + __u64 l2_features_wide; }; =20 /** --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from MRWPR03CU001.outbound.protection.outlook.com (mail-francesouthazon11011000.outbound.protection.outlook.com [40.107.130.0]) (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 5A96A2E54AA for ; Thu, 28 May 2026 15:07:13 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.130.0 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980835; cv=fail; b=OYqIPH9ZHTQIMe3dHDUq4X7VfVWVyxcNxsmddzu62c6xT/9921fLCG+r6Kn/PiJt19czXC/+MoAbtyI94C+i+csARlwoMAL0oD3MKFy3lE2GqmNH+4ovCDKdT9Q+H5UVmBI/rqHuEZav8/JeYF9jkHprVBnQT6AHSnIMavn5lNw= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980835; c=relaxed/simple; bh=AjM2ipuSxKu+grl1KzGf4zEsEx/a6MWj/cHDHKcHi2Y=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=QN9mY5ewVAOgFcRxNVjLU3x8lxBN6Px8cB5YOY1WqiMsK4QDI4ixM+Inayv88wlKvlhv4rtaAbbqNxw8I5JSO9oCyY+duZjGOQHo6xfJUL6RvogSXnWd3GY1Y/mSr9LpzTkaPOvQ20CZ9PBBIt9BWHI/ebMPyQ3S5j03C4kUjek= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=CoDpISwL; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=CoDpISwL; arc=fail smtp.client-ip=40.107.130.0 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="CoDpISwL"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="CoDpISwL" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=xKJvlKV6+rnNS5Mrr83Q9pr93ncMl80mXtl5IShv9+021DnT9dRAn38vbf7e8zmewunFZYafZGDKpztez/pI+/YFsKMWO7lCbvm9sZkvl3OpGFJrtEKcwPxQvNFRmoDCFbME6Pkuc+hJA6pJ+FSgQYMtVXQzMquQwsNo6DuevCJvNXS3uwqcKCxqXdqE8lUetHV+mH8TY8H9gRmmj3XxMjRH3tKJgH4VM8sBBAJicMjWOKcm/I+GXJqk2BGBeHInLWrR7cdai0aMWrguimFKrt5O/eypD+vCPaFtEBnbAF/ZkYfOuiunYfQuza4BdMVl0gKfgw0OoaZZhwfdEgEA9w== ARC-Message-Signature: i=2; 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=G9Qkc6+z1hvUJ2vKC4l6P0u7Bf0zI1lM78/E0DS0uB4=; b=WnHAe11m5fFSr+mps9ELoJCq7im/r/Kl9wO4TC96QqaR+8LS5rhdt/5/fSuN3gOkVs6Vf9eieQtXqS0Xo2AsHaSlcd9ttNX8nPmyqXRwt2vhA+rqFxt6M2L2bKQRULVAUcbBLyk3OVMBETaZ62uMLKdkwsJSVH9ewv8lpnkEgAY+v2CLRHVFvGnjphkUD9duWjkDGw+1YwJtlr0Fu2zO4Mfy2ST8GSqDIfvF5N8zFu75uMYwej4azOG1+ooXU70RDmgjVwSsFPvK7+ki7VIYmHnFeWuxzV7fGOma98XlR5hTste/O7TMXQRbGd35QABjvm9SQXe+enEP7DqvGTTkjw== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=G9Qkc6+z1hvUJ2vKC4l6P0u7Bf0zI1lM78/E0DS0uB4=; b=CoDpISwLFjqy+BxAglwJiUihNstEN0n2zdk4JNlXCC2HNqxTBLQrUwERvUJ2WgT5EXh5He9QdBvxMILYEvVej9a24e+Zb2ZlLPZR2iqB2rCRObA3lC2R0DRkeNQ9zwST1QyhqICnq+qBxjAUc/GrrQtllg1JCegnbOj2fBXkqso= Received: from CWLP265CA0448.GBRP265.PROD.OUTLOOK.COM (2603:10a6:400:1b7::19) by AS8PR08MB10269.eurprd08.prod.outlook.com (2603:10a6:20b:63c::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.12; Thu, 28 May 2026 15:07:07 +0000 Received: from AMS0EPF0000019D.eurprd05.prod.outlook.com (2603:10a6:400:1b7:cafe::f7) by CWLP265CA0448.outlook.office365.com (2603:10a6:400:1b7::19) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.13 via Frontend Transport; Thu, 28 May 2026 15:07:07 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by AMS0EPF0000019D.mail.protection.outlook.com (10.167.16.249) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.7 via Frontend Transport; Thu, 28 May 2026 15:07:07 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=fKA1pGhEO/ha+hnRD8XUh+AwUHN7CeVT9dsfzw8EZ8PSDj2qeLYX+84uiWPGsfyWwfShNVK3dosrrx75f7WrVLgp2d1bPOiqBhgVDHvp1giARwAJ0CbweGyDVrDblZVQ1CSYqB8Vws1g+y+mvDjfA3wngFM7/4lygmLN+UOlLlzSLjL/MJuP3BrzjqIM1/g7E5fnIHfBgwpmkhYeU3HzTxlpQUS/JDI8VlQ2gMmC7k4gKSykYRgWyqqKnkBDrurVbmGOI6ASQYwIC4SqMxvcm3ROOuBnE8iNNXRBJApMQtrfogs3M8SDdbtywyL9t8sBBNBAG0VXGdwkTRuRMkWsrA== 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=G9Qkc6+z1hvUJ2vKC4l6P0u7Bf0zI1lM78/E0DS0uB4=; b=qgWnhGj7WxIvXwclDD1MYXzz76MpPsH1LbaMOKVd76jVoEV0u8vGXSJ4MPWBG3M9iHGlxJWvBBJiwesH4u4lTWX1wLLPmSN9GzM8lH6znUJmoruOEWqit0n6AunSmc+M3e6u2D3xjXpHLdu8Jw9PFeyYk37zfuO9Ftq+s+On7pP+qYrhzkTZ6NWqptMs95ewrx9YRDwABESXyMlhCtHd8NCMygYPyTewhe25q4nF5IAzjWh7VDpV7XN0WlAyDQfW69cnlVwIllnq1HNOplgc87Bm78KKb9TzQf5N4O+AuHwFv7tqi4aXFdz/aVNH4AJ64Zwhdxa7XAp/1pkdJY0jWQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=G9Qkc6+z1hvUJ2vKC4l6P0u7Bf0zI1lM78/E0DS0uB4=; b=CoDpISwLFjqy+BxAglwJiUihNstEN0n2zdk4JNlXCC2HNqxTBLQrUwERvUJ2WgT5EXh5He9QdBvxMILYEvVej9a24e+Zb2ZlLPZR2iqB2rCRObA3lC2R0DRkeNQ9zwST1QyhqICnq+qBxjAUc/GrrQtllg1JCegnbOj2fBXkqso= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:04 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:04 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 08/18] drm/panthor: Skip devfreq when no OPP table is present Date: Thu, 28 May 2026 16:05:36 +0100 Message-ID: <20260528150546.3168527-9-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: PR3P191CA0052.EURP191.PROD.OUTLOOK.COM (2603:10a6:102:55::27) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|AMS0EPF0000019D:EE_|AS8PR08MB10269:EE_ X-MS-Office365-Filtering-Correlation-Id: 5c29a824-17c0-44f7-f573-08debccac8d2 X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|22082099003|18002099003|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: 37+sS3rU4KmLvhtuN7Jd9q8+CcuOOsn0StHTJv6K8EwQ7UXm3ha+cdeW6bngKJ0RY1BLpMyogyH07dcoLFqkEaZTFAqBnsmMnGg2oeXAsKidBaxgkRs5B2Rk8wK7d7PyV1tLXvLEZsIFnVYmMPXqUUn6kOTc3Q4CbekwjQAYmBsPz0WBuzLbbcgT4o56O931mv5jBsgGBF+5Urit9suVMVWi/DY7YZQL8V9XhpMIHOuc27SC/pTswHMRIdR1fD4ZQXXrG7eyd/vLWAk10OglLUTD0uXowbpOHZWQAEjTo7YxOz71M5CqQ5H6oPbzhF03KVyU3Q896elwJRRELFSjkgzbTzMrA8ZKuWF0/BybQJipw8e1yXCzNGLv9f2TGh+slhxplaTyT13ZVC6rX9wjgxXECjIawmzOZiIK0f5e9/ABdhWtPclUn0y4ZNUDGfiJVs4kwy8EcNvwCUf7AJJLIzVwVXmwGGm5tOK4sSLGdGQ1z1ZJnBWH4vOF5Yto/bfv1MbQkQbvmeP7nf0l0hdOK/7nLTM5ZkBeJNIR3iBcJ/A/G/6v1W2E5KKKZgj8m90C6iic+HXM+0aPRC4a4xQL+VepgviqecxEgvVOFuKARVop4zZbzY9g9wwTHAwJQFQlC9XmPbSBu1Uc6QJfhkSDU24zSC+940vBNt1kbVhjTVNmEXMmkWNnKlbiIq28Fc6f X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(22082099003)(18002099003)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: eYJA4WtPDlEJglmJq1MY7JD9wHGtapb2U70wlUVUI80TBdpsJRPmYzz2MgZNW7ece8yzBHyqn34bLjoOk67Ie/zSxR8FlVDF9e197ckuh1GN6B5BiLIligiXD//CHpHx9QfQkcCPPp86JMKKLQes1AOBg+nCG212tTQSNmTnvAveGwFsIMixerVFhN8wxL2lSHqm3/M1uoQBQOEv7h7UMv/o5Wfm1mn0vATx/idJzyErdqCeI2LSHhRTQDTPfhNQcuGcyQ79cDm9TuekVCyC2bXkYkgitTxMDGtb0Tyc6zFyc0giKNe9UXwoV7gxG/c4BIh4qFMqe7X8WDvUZljU2w== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: AMS0EPF0000019D.eurprd05.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: 4b40c98c-ce07-4196-7f79-08debccaa350 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|14060799003|36860700016|35042699022|82310400026|376014|56012099006|11063799006|22082099003|18002099003; X-Microsoft-Antispam-Message-Info: 6V2M1+WfpzyIgbok+0BXGe/qW9H+tlkbLk8xWuj2hNhT5nJgtsbvzKYToHz87OMT8QwE7Tq0eUtK3IhqUAA6e+dWTruAGCoWYNxV/BGXaMfQcVWZ1FmDp/7V6dB/+yeW1WbXmn442zjTVJaIYFtMVWpY+7pCHPgPJJ3U264VJb5G6Q8l89t+0ZUGGGBaD6SQxP4IL7QQkCFMTr2XCFnQsXZT2vSkcZTbUHxHWzj3VRVmoyEQOm4vJTYfX2egjnOTQnLST3DSiG7IZtDhz/EfG+JF4IbPXEFcuMRGoPF3TIekUw/HIG+/E20Rd0grEecpim8tcuuQ4GUhle38pca41YWh3UjAlj8HHlpk5y0EkAKFZfB3Zcy53YgzXHBSJwBixu3dmjYNizC/9AYXD33v0YAVQVd+hN/TeE/gxTEGbdNMMGMiLMWun2IHpgUDYs3u004XgHakn37GkqzS7sxAO3xpH4ikkp2RudnK3QwaWM58ghR3qPffILWrPOhX/AZNappxAHuuEZj1BjCDVyOYA5J1lLqGUYMrrpDmDa9TgxHK3hbZ9w0jdq6O+dAxCKOq4F8tYZ9k6RLO1TZ0SrXt2XIg9rMQIoxlisCmloHGP0cUDHolbeTCaVltc1x7w86wlkCxulaZml3ME4ehOZ5tQueq4VF0MwrQ5nYHnX5yRrlRobGPPyb/WoL1XzLN5KAdhFSgJFRqIgIyqwSgH8VW88L072m9YK6XnexSDR2jyns= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(1800799024)(14060799003)(36860700016)(35042699022)(82310400026)(376014)(56012099006)(11063799006)(22082099003)(18002099003);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: sN9B8CUwhdKEA8QjYxrcwV2/l8H9a5mnEhb1euELLvjIrRz3/tBHBt2rawzGY3Bb1QNqBbppUXw+VRGs1E4lJYQMuTnyODghwP9rtsOEaFd9P4/DFgbJjxUiRQvuYnFh5NyEHb+7GOcnzyXAbJUrgwlvYiqupF23e9kXqEqyxwP09mLhuJQQbgY3IgZHlIgaXfFto0wjCbWVgF6/qt/dx+d5hYve7LxEEWSCvztxlHYoi7VRT3uEueumAKQWL+mhT95GvhjDm4TLXavzKDDEEVeWE5aLHABJBeRlDWV0CVmf793Hs9jx+6+8KBiirUxAxvBDXcum80iFL+eFBDAoNozQ44p3+t9abDQxMvrGRQIPoaRyS8V5x4dCgXGZEeSZBF7xRuH+2UiDL/p3S4c6Bnu2dHCkk4ofBQoQxgupctStbFv9Yp42IQyDsXe+3z0D X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:07.0953 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 5c29a824-17c0-44f7-f573-08debccac8d2 X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: AMS0EPF0000019D.eurprd05.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: AS8PR08MB10269 Content-Type: text/plain; charset="utf-8" On Mali v15 AM systems, frequency scaling is handled outside panthor by the AM_GOVERNOR block, so the GPU DT node may not provide an OPP table. Make panthor_devfreq_init() return early when operating-points-v2 is absent, and guard the devfreq helper paths against a missing devfreq instance. This keeps devfreq enabled for existing platforms while allowing v15 AM systems to probe without a local devfreq setup. Signed-off-by: Karunika Choo Reviewed-by: Boris Brezillon --- drivers/gpu/drm/panthor/panthor_devfreq.c | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/drivers/gpu/drm/panthor/panthor_devfreq.c b/drivers/gpu/drm/pa= nthor/panthor_devfreq.c index 2249b41ca4af..c3252ce54437 100644 --- a/drivers/gpu/drm/panthor/panthor_devfreq.c +++ b/drivers/gpu/drm/panthor/panthor_devfreq.c @@ -148,6 +148,9 @@ int panthor_devfreq_init(struct panthor_device *ptdev) unsigned long freq =3D ULONG_MAX; int ret; =20 + if (!device_property_read_bool(ptdev->base.dev, "operating-points-v2")) + return 0; + pdevfreq =3D drmm_kzalloc(&ptdev->base, sizeof(*ptdev->devfreq), GFP_KERN= EL); if (!pdevfreq) return -ENOMEM; @@ -267,7 +270,7 @@ void panthor_devfreq_resume(struct panthor_device *ptde= v) { struct panthor_devfreq *pdevfreq =3D ptdev->devfreq; =20 - if (!pdevfreq->devfreq) + if (!pdevfreq || !pdevfreq->devfreq) return; =20 panthor_devfreq_reset(pdevfreq); @@ -279,7 +282,7 @@ void panthor_devfreq_suspend(struct panthor_device *ptd= ev) { struct panthor_devfreq *pdevfreq =3D ptdev->devfreq; =20 - if (!pdevfreq->devfreq) + if (!pdevfreq || !pdevfreq->devfreq) return; =20 drm_WARN_ON(&ptdev->base, devfreq_suspend_device(pdevfreq->devfreq)); @@ -290,7 +293,7 @@ void panthor_devfreq_record_busy(struct panthor_device = *ptdev) struct panthor_devfreq *pdevfreq =3D ptdev->devfreq; unsigned long irqflags; =20 - if (!pdevfreq->devfreq) + if (!pdevfreq || !pdevfreq->devfreq) return; =20 spin_lock_irqsave(&pdevfreq->lock, irqflags); @@ -306,7 +309,7 @@ void panthor_devfreq_record_idle(struct panthor_device = *ptdev) struct panthor_devfreq *pdevfreq =3D ptdev->devfreq; unsigned long irqflags; =20 - if (!pdevfreq->devfreq) + if (!pdevfreq || !pdevfreq->devfreq) return; =20 spin_lock_irqsave(&pdevfreq->lock, irqflags); @@ -323,7 +326,7 @@ unsigned long panthor_devfreq_get_freq(struct panthor_d= evice *ptdev) unsigned long freq =3D 0; int ret; =20 - if (!pdevfreq->devfreq) + if (!pdevfreq || !pdevfreq->devfreq) return 0; =20 ret =3D pdevfreq->devfreq->profile->get_cur_freq(ptdev->base.dev, &freq); --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from PA4PR04CU001.outbound.protection.outlook.com (mail-francecentralazon11013020.outbound.protection.outlook.com [40.107.162.20]) (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 A82C93F8EB2 for ; Thu, 28 May 2026 15:07:17 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.162.20 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980841; cv=fail; b=P9hscesJGdSWJl5ncF9SRdhW9mtTnuSX6zI1KF8dQxDP1AGwRKHDacoU3LTrIvAtnh9OxFpaKnXigca3iEo75KaWKal6uwzGxzuVQtnu6ahJyMWtHOS2v4KepuszFlo2eFItwv/yo+EohhkLiCs0cVgYbzWDu8X68/X/pU0XWyk= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980841; c=relaxed/simple; bh=JlSC7D1Js6FIHh405jpNW5VCLOEJRpaY98pe435cJg0=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=VyfcGmfj80GyzMuOzy50/o8ezpTnYlM4JuZQ4VGV9kLIuJYh2KY9vQviAWDlkfRgjtwO4kNsiODszoJhgd0Zc3hdupi3VBN1spGMtuq5umNQTSgW/zFxE1dQjAEPwB6BZQ9ejXocqFgdFhmMG/nSNZHaw3oAfpZ1zR/zo40r1M0= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=WjlSJAoq; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=WjlSJAoq; arc=fail smtp.client-ip=40.107.162.20 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="WjlSJAoq"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="WjlSJAoq" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=Q1o2Xam9BMGzf52EQxQ/CWaJPrwpY8Gi8FqTc4gjLe0NpZt9SVkRNP21aHOs+0OMy0xpZVCtYF0+UeY2H36EkKtVN+EDmoyZ0ikRuVOgjLBJFhNsZjJ5UFOHyaixXeuvYg65MUjOMAHN09D7JC5cr8ktwPJ8lYNXuFTPsNcocYB+7s/a+XKBVYYoLYQWtlIixW0FrIZW0VvsHVRglJ0fZ8uxNxQF0jJ5cIS02vs9rRbpX0VZ9S3IvVn+5UvG5HS6J7wXr30DH3V9P5vRuVnXCDFybgac+GCBOFUrmc/PI148Lg8M5vdyfdsesSlHHdOSAeCjxv3cGpGnO41mgk7EUg== ARC-Message-Signature: i=2; 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=G4w67VEEgS+Q2jYNrikMStPGpS8eupxXlUrIZ1Hn1E4=; b=CIFBRzRH2AloeSNWSTJVRGJbpoyGPUckdk800p0PIyMDAtGR2z6B7SrX+X/KmvPQ84Up5WGgOXsO4naK/EaP+A+lWjD79knsYBWgbeTHgSqk0RtCxgoTJbCeiufSFPZOM/zxpt6O7zevGCwNxzeZcCYR/hb37WK6tzlJByESIW4eshLsJVBLxqKyxIIzkecP3MKxDh0zoIzfVu/Qr1q4s5KFCOjVsQRysCfUZgZTnx/lpFjDByLnDaL/XyGcjWuMrXqV8ObVtJi2RnUSk3PSjAms5VObOAnZIbsY/RGx+NsDQ/xCdw6YCxRNrH7wqIbE5HZdyOMNpyCcblWKwaYbfQ== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=G4w67VEEgS+Q2jYNrikMStPGpS8eupxXlUrIZ1Hn1E4=; b=WjlSJAoqma5YQ/yn19lREbXd3rm6Ty4scaGBPonUaS9YjlClZFJbxM3JLvHDWZGcMLpJ/kF6Ngzu+wCsfkjEVauCznpjj+nitQ7b2TgOKffQPenyK+L+C1/Bypr2XiylBmdmpwO6I4eKaszwDKwRVq8GABsURHoEk0o1wUhVAJE= Received: from DB8P191CA0023.EURP191.PROD.OUTLOOK.COM (2603:10a6:10:130::33) by AS8PR08MB5878.eurprd08.prod.outlook.com (2603:10a6:20b:29b::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.13; Thu, 28 May 2026 15:07:08 +0000 Received: from DB1PEPF000509E3.eurprd03.prod.outlook.com (2603:10a6:10:130:cafe::4e) by DB8P191CA0023.outlook.office365.com (2603:10a6:10:130::33) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.13 via Frontend Transport; Thu, 28 May 2026 15:07:08 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by DB1PEPF000509E3.mail.protection.outlook.com (10.167.242.53) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.48.11 via Frontend Transport; Thu, 28 May 2026 15:07:08 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=sWZJF6c0n4Hp+6kOHZvR2nUGlLZY018s9F8m39jq7b5HWbnZVAjS4vBr/BAqMjwEUvCcRbA8sE0zjKD4MAtora0pg/IH9IrZV0t6eaoVVEhDOCasW+KaUniUft30VMmywvRNoTJtpT71jeyXOFa5RJuTxLklwDkeKN08ihwNXYGyQbsHdf1uRxZvJBfNAqSAx8FYOc5oDpvjXoTvCimOg9TiXIib62ijuL7TZq+hl2gXaLm3C0rK7eiK852TYiUz/n0uMqQqfFv5PJmrc42hYY/4ICC0h7YFlta/Y7a9aTsB+dbY1Rvb9/+AU8WDjgYd/gLGEcarhQZfhcv+opx3Pw== 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=G4w67VEEgS+Q2jYNrikMStPGpS8eupxXlUrIZ1Hn1E4=; b=uylNQKJSyyT7XSqu6g7MY5MIDOapMzjQONGVcvn2ExYzojTPpF0sjq8m0S/HJs46iZ9VoBfAofG8BOAwUhaF94Jdn93LTZ3UBa8lElFXs2ONB1PJwUbfjI7YNaHz3k2W3kuPje7cnfx7T9SJcRwYGUZTbHUW57FITiiwVz2fYFaizFdw59NGid9pPFxA77B22CzYawVaDTIfDTYqCszBOLm1tn7dG3e47Ke/phvCOvZcgBapK1GrpMxx62nghvfN9wwWpod7mhAWaq/U2exUYQzK8qZH6FKgmaeGioKZ+QD4reDIoSXokVNmK6A6mmI0WvPUTZBvctKmZS+NtcuxhQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=G4w67VEEgS+Q2jYNrikMStPGpS8eupxXlUrIZ1Hn1E4=; b=WjlSJAoqma5YQ/yn19lREbXd3rm6Ty4scaGBPonUaS9YjlClZFJbxM3JLvHDWZGcMLpJ/kF6Ngzu+wCsfkjEVauCznpjj+nitQ7b2TgOKffQPenyK+L+C1/Bypr2XiylBmdmpwO6I4eKaszwDKwRVq8GABsURHoEk0o1wUhVAJE= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:05 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:05 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 09/18] drm/panthor: Add basic AM_SYSTEM support Date: Thu, 28 May 2026 16:05:37 +0100 Message-ID: <20260528150546.3168527-10-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: PA7P264CA0281.FRAP264.PROD.OUTLOOK.COM (2603:10a6:102:373::18) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|DB1PEPF000509E3:EE_|AS8PR08MB5878:EE_ X-MS-Office365-Filtering-Correlation-Id: e4298bcb-bcb3-47f2-41f7-08debccac97b X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|6133799003|22082099003|18002099003|3023799007|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: Ac3W1940P16kozDHcF9f/vjhJ7NWSDGI18+PhCFAVwurNQJRBbBUWi7LHJLJZcM66pSa3R/9xOj7oVu2eaDQJ3H1VTNFVEGeE0oaKs2/sUcUiptewytlwAWh7nlTHDHyc9pWF5zo6myht1BjaM9f6G77ipTuq7kWvvS1pmuoF1KZ0oAFkbRyjmMoo0TyJpo2fkIDp51X2fEnY+n64HRcrrd6mbkomDmETX0hNFIwj4hAXglOisHchxMnZFgSECngpxy1zciB1G5PL8J9/L/Rn3SZnuXAjd0lTpT3Dju5r/5bdluMvq8iXv2whT3nDFofns6ZQ6ENzNSEhLJ3wDjdN7rAwxWRd7/zMMX0nZpR1rDLovzDpAKgzVmS90SvwwEjgqqGoHsJ/MUfP58xfQGdv/dSrp4V2mJA00XK3+2QvRlQqEtLHbysfACyPsMUX/1uwnubxyhGz1PwxqAVFXBnH7J3o81HWfXKHuiyyM2MkxQUSftv0ormiIuup5aBcPctOrfzUoF+nbpdC1zX685WOsQ8tgl4idcXHIiyI0Lz2TkunVDb2lhI6cuyvzyUkfxN93PBbPmKN0QwibUllFLMHFbTu+uAagGNdOBNx1Dwsk4v03OqjDTFnUBv1v3KXHYQxs2VqmsjROBFu+v/Euv0IEsqCbYa1zClnEcngQYNHDocwkSC1+zXSa2GQhcqBi3Q X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(6133799003)(22082099003)(18002099003)(3023799007)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: R5NRchmi8BHRjQedhUqahIiIr06WJegcFvEXHtNTXKcelBfIAC11OLMT1saoywQrrrVtTvPPYI02tLED6jP1mH6Wzer5DMfFRG4SSICr50bYLrGFQfZCbR35zV8DmrQHp4e6POv9Qao59TmNKQAcutgSLZQJgIPrBXhCApNZ536/+2V1304UlTrbSms72OJaoXpngtLma24uCJ0vslNBbCHKGuVqERvPvECsuzqai9WECh9UGCDGqpnnIr1AbWDYZIayZmXGOag7WP1Wd2Js58lNwdD1dlj2EANcdEKfZOYRfShYMcGZjfyhXPh5zxEYcX+vxjmG0NwM+FY1YqRwYQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: DB1PEPF000509E3.eurprd03.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: c1bdf968-ead4-48e5-888e-08debccaa415 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|14060799003|376014|35042699022|82310400026|36860700016|22082099003|18002099003|11063799006|3023799007|6133799003|56012099006; X-Microsoft-Antispam-Message-Info: H4KfndtkeedbJaYMuqtHfxhtgWkCg3TjcrjeGUkrYeGGNqOil0ei77Ks+ExEzydd1BnIUQZ+MUaHGyAKDJleO9evZbsES/801Dq8oVl+YaAxTaLZbTnTBllMC5ZrAz5ZcQ1xCL4XJXLqNUwv6gcA4IZ0ytvgU4x1do4UjM8GFO87PhT/gSBusZNATNTvzVKtDiJPy3mEf8AFONl90WtY8WjgLWKYnVDEYVYsEiDlAzMTVtxXXdFCLtBHOsMKjB5QymxptPjaq4UYMRzmT/ZoAWl159HnJOhqB+fdxF3zMhT2TGaqVS1dQs6etmVWRb4/TDIc0WLedEuJ3UX31ll2A3T+ROh9pnKD6X0QUxMDQVyYWvi0FAMSMNil1enXBd7h/sJ9kEW2zJvhEc30l/EQsVakuB9WwokVXkLy3F1cZ1qmfhjW2PRE8l3JwgoUfO8I4senrQQ6YQQ+PLsE1CA5X7onXSUsi8ZnVchnq/pPd7hsrISBNL8gekqvBRBOzA8JhHyVraMonY0wxdNpibW49NZdYiC6SjPR2laf7ifQPx4Wik0q/MAFGqaeAyzCPR071yaxg8kC0A1uZzqhmA6qP9gY0089lj7WmFgSSt2Xjlyg3uyJdQNVLSqs4VtxiArTK66T/63sQjZf99z+s2n4mLyE5edBU/g4kItCNCJISFVKcHdnHyXHaFZz3MYs62q6fgG0ip5rWCkhIjba3CRvBs5ZqHfosRfyYwcOORagoxY= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(1800799024)(14060799003)(376014)(35042699022)(82310400026)(36860700016)(22082099003)(18002099003)(11063799006)(3023799007)(6133799003)(56012099006);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: OYs2ol1ZQyzPAzKkCAMudrh+e1r+v7Zh4bfkw10DxyYp842F3+VUKsOvgApy71QuZlyN/zFBqRAe+cdf1SLjPO0r1hXrht9uVAcBZVD7uLcz6KAkuO7fjxvCDZphitA/SvPRBMoqCKar8o1A3yf7WIIzPr4oDe+MtR+AO30xBjt5AkCR6BfyNSfvJLAWaUhXN7XpvNkv6zZzoeIRrgXpqO+JkMjcDxIWU/247wtGP08ga7vq98DRLq49BKH5EQiZcA4W1KUWQuCMT19Fm9chN4jEQAVbKnlaunrIGdjWEVppgZndHS+3TfiZy7op+gVQm/T6r6e4DIWJAVQXUXFRL90yF0LM9sReuaDXJnMupjoaWa25uECGeF9y+eIyrN2wtEJBWjFcF22xbsIy3O/NVQeDJEhjaPfs1SYDSnZfZL6aZXS3+AI9e+pSaxYZjESi X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:08.1800 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: e4298bcb-bcb3-47f2-41f7-08debccac97b X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: DB1PEPF000509E3.eurprd03.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: AS8PR08MB5878 Content-Type: text/plain; charset="utf-8" Mali v15 AM systems expose an AM_SYSTEM block for GPU-wide control. Add a small AM_SYSTEM platform driver, wire it into Kconfig and the panthor build, and use it to manage the GPU clock and regulator resources. The driver also performs the initial GPU reset sequence during probe so the panthor GPU driver can subsequently bind to the device. Signed-off-by: Karunika Choo --- drivers/gpu/drm/panthor/Kconfig | 7 + drivers/gpu/drm/panthor/Makefile | 1 + drivers/gpu/drm/panthor/system/Makefile | 12 + .../gpu/drm/panthor/system/panthor_system.c | 298 ++++++++++++++++++ 4 files changed, 318 insertions(+) create mode 100644 drivers/gpu/drm/panthor/system/Makefile create mode 100644 drivers/gpu/drm/panthor/system/panthor_system.c diff --git a/drivers/gpu/drm/panthor/Kconfig b/drivers/gpu/drm/panthor/Kcon= fig index 911e7f4810c3..da6b9bc1c67b 100644 --- a/drivers/gpu/drm/panthor/Kconfig +++ b/drivers/gpu/drm/panthor/Kconfig @@ -20,3 +20,10 @@ config DRM_PANTHOR =20 Note that the Mali-G68 and Mali-G78, while Valhall architecture, will be supported with the panfrost driver as they are not CSF GPUs. + +config DRM_PANTHOR_SYSTEM + tristate "GPU-wide configuration for Arm Mali 5th Gen AM GPUs" + depends on DRM_PANTHOR + depends on OF + help + Driver for GPU-wide configuration of Arm Mali 5th Gen AM GPUs. diff --git a/drivers/gpu/drm/panthor/Makefile b/drivers/gpu/drm/panthor/Mak= efile index dd15d52a88ba..488a5e03efbc 100644 --- a/drivers/gpu/drm/panthor/Makefile +++ b/drivers/gpu/drm/panthor/Makefile @@ -14,5 +14,6 @@ panthor-y :=3D \ panthor_sched.o =20 obj-$(CONFIG_DRM_PANTHOR) +=3D panthor.o +obj-$(CONFIG_DRM_PANTHOR_SYSTEM) +=3D system/ =20 CFLAGS_panthor_gpu.o :=3D -I$(src) diff --git a/drivers/gpu/drm/panthor/system/Makefile b/drivers/gpu/drm/pant= hor/system/Makefile new file mode 100644 index 000000000000..cafa509148cc --- /dev/null +++ b/drivers/gpu/drm/panthor/system/Makefile @@ -0,0 +1,12 @@ +# SPDX-License-Identifier: GPL-2.0 OR MIT +# Copyright 2026 ARM Limited. All rights reserved. + +obj-$(CONFIG_DRM_PANTHOR_SYSTEM) +=3D panthor_system.o + +INCLUDES =3D \ + -I$(src)/.. + +ccflags-y +=3D $(INCLUDES) +subdir-ccflags-y +=3D $(INCLUDES) + + diff --git a/drivers/gpu/drm/panthor/system/panthor_system.c b/drivers/gpu/= drm/panthor/system/panthor_system.c new file mode 100644 index 000000000000..985a1ecc5d2f --- /dev/null +++ b/drivers/gpu/drm/panthor/system/panthor_system.c @@ -0,0 +1,298 @@ +// SPDX-License-Identifier: GPL-2.0 or MIT +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "panthor_device_io.h" + +#define AM_SYS_IRQ_RAWSTAT 0x40 +#define AM_SYS_IRQ_CLEAR 0x4C +#define AM_SYS_IRQ_MASK 0x58 +#define AM_SYS_IRQ_STATUS 0x70 +#define AM_SYS_IRQ_RESET_COMPLETED BIT(1) +#define AM_SYS_IRQ_INVALID_COMMAND BIT(2) +#define AM_SYS_IRQ_INVALID_ACCESS_MASK GENMASK(31, 16) +#define AM_SYS_IRQ_INVALID_ACCESS(x) FIELD_GET(AM_IRQ_INVALID_ACCESS_MA= SK, x) + +#define AM_SYS_STATUS 0xC0 +#define AM_SYS_COMMAND 0xC4 +#define AM_SYS_CMD_INDEX(x) FIELD_PREP(GENMASK(11, 8), x) +#define AM_SYS_CMD_SOFT_RESET 0x10 +#define AM_SYS_CMD_HARD_RESET 0x11 +#define AM_SYS_CMD_AW_RESET 0x12 + +#define AM_SYS_RESET_SLEEP_US 10 +#define AM_RESET_TIMEOUT_US (20 * USEC_PER_MSEC) + +/** + * struct panthor_system - System device + */ +struct panthor_system { + /** @dev: Device pointer */ + struct device *dev; + + /** @iomem: CPU mapping of the AM_SYSTEM IOMEM region */ + void __iomem *iomem; + + /** @regulator: Pointer to device regulator */ + struct regulator *regulator; + + /** @clk: Pointer to device clk */ + struct clk *clk; +}; + +static int panthor_system_regulator_init(struct panthor_system *sdev) +{ + struct device_node *np =3D sdev->dev->of_node; + struct regulator *regulator =3D NULL; + const char *regulator_name =3D NULL; + int ret, cnt; + + cnt =3D of_property_count_strings(np, "clock-names"); + /* No clock-names defined. Exit */ + if (!cnt || (cnt =3D=3D -EINVAL)) + return 0; + else if (cnt < 0) + return dev_err_probe(sdev->dev, cnt, + "Failed to count clock-names"); + + ret =3D of_property_read_string_index(np, "clock-names", 0, + ®ulator_name); + if (ret) + return dev_err_probe(sdev->dev, ret, + "Failed to get string from clock-names"); + + regulator =3D devm_regulator_get_optional(sdev->dev, regulator_name); + if (IS_ERR(regulator)) { + ret =3D PTR_ERR(regulator); + + /* Regulator not found. Exit */ + if (ret =3D=3D -ENODEV) + return 0; + + return dev_err_probe(sdev->dev, ret, "Failed to get %s-supply", + regulator_name); + } + + sdev->regulator =3D regulator; + + return 0; +} + +static int panthor_system_regulator_resume(struct panthor_system *sdev) +{ + int ret; + + if (!sdev->regulator) + return 0; + + ret =3D regulator_enable(sdev->regulator); + if (ret) { + dev_err(sdev->dev, "Failed to enable regulator"); + return ret; + } + + return 0; +} + +static int panthor_system_regulator_suspend(struct panthor_system *sdev) +{ + int ret; + + if (!sdev->regulator) + return 0; + + ret =3D regulator_disable(sdev->regulator); + if (ret) { + dev_err(sdev->dev, "Failed to disable regulator"); + return ret; + } + + return 0; +} + +static int panthor_system_clk_init(struct panthor_system *sdev) +{ + struct clk *clk =3D NULL; + + clk =3D devm_clk_get(sdev->dev, NULL); + if (IS_ERR(clk)) + return dev_err_probe(sdev->dev, PTR_ERR(clk), + "Failed to get clk"); + + sdev->clk =3D clk; + + return 0; +} + +static int panthor_system_clk_resume(struct panthor_system *sdev) +{ + int ret; + + ret =3D clk_prepare_enable(sdev->clk); + if (ret) { + dev_err(sdev->dev, "Failed to enable clk: %d", ret); + return ret; + } + + return 0; +} + +static void panthor_system_clk_suspend(struct panthor_system *sdev) +{ + clk_disable_unprepare(sdev->clk); +} + +static int __panthor_system_reset(struct panthor_system *sdev, u32 cmd) +{ + u64 val; + + gpu_write(sdev->iomem, AM_SYS_COMMAND, cmd); + + return read_poll_timeout(gpu_read64, val, + (val & AM_SYS_IRQ_RESET_COMPLETED), + AM_SYS_RESET_SLEEP_US, AM_RESET_TIMEOUT_US, false, + sdev->iomem, AM_SYS_IRQ_RAWSTAT); +} + +static int panthor_system_reset(struct panthor_system *sdev) +{ + int ret; + + ret =3D __panthor_system_reset(sdev, AM_SYS_CMD_SOFT_RESET); + if (ret) { + dev_err(sdev->dev, "SOFT_RESET failed, attempting HARD_RESET"); + + ret =3D __panthor_system_reset(sdev, AM_SYS_CMD_HARD_RESET); + if (ret) { + dev_err(sdev->dev, "HARD_RESET failed"); + return -EIO; + } + } + + gpu_write64(sdev->iomem, AM_SYS_IRQ_CLEAR, AM_SYS_IRQ_RESET_COMPLETED); + + return 0; +} + +static int panthor_system_suspend(struct device *dev) +{ + struct panthor_system *sdev =3D dev_get_drvdata(dev); + + panthor_system_clk_suspend(sdev); + return panthor_system_regulator_suspend(sdev); +} + +static int panthor_system_resume(struct device *dev) +{ + struct panthor_system *sdev =3D dev_get_drvdata(dev); + int ret; + + ret =3D panthor_system_regulator_resume(sdev); + if (ret) + return ret; + + ret =3D panthor_system_clk_resume(sdev); + if (ret) + goto err_regulator_suspend; + + return 0; + +err_regulator_suspend: + panthor_system_regulator_suspend(sdev); + + return ret; +} + +static int panthor_system_probe(struct platform_device *pdev) +{ + struct device *dev =3D &pdev->dev; + struct panthor_system *sdev; + void __iomem *iomem; + int ret; + + sdev =3D devm_kzalloc(dev, sizeof(*sdev), GFP_KERNEL); + if (!sdev) + return -ENOMEM; + + iomem =3D devm_platform_ioremap_resource(pdev, 0); + if (IS_ERR(iomem)) { + dev_err(dev, "Failed to ioremap"); + return PTR_ERR(iomem); + } + + sdev->dev =3D dev; + sdev->iomem =3D iomem; + + ret =3D panthor_system_regulator_init(sdev); + if (ret) + return ret; + + ret =3D panthor_system_clk_init(sdev); + if (ret) + return ret; + + dev_set_drvdata(dev, sdev); + + ret =3D devm_pm_runtime_enable(dev); + if (ret) + return dev_err_probe(dev, ret, "Failed to enable runtime PM"); + + ret =3D pm_runtime_resume_and_get(dev); + if (ret) + return dev_err_probe(dev, ret, "Failed to resume device"); + + ret =3D panthor_system_reset(sdev); + if (ret) { + dev_err(dev, "Failed to reset GPU"); + goto err_exit; + } + + /* TODO: IRQs */ + +err_exit: + pm_runtime_put_sync_suspend(dev); + + return ret; +} + +static void panthor_system_remove(struct platform_device *pdev) +{ +} + +static const struct dev_pm_ops panthor_system_pm_ops =3D { + .suspend =3D pm_runtime_force_suspend, + .resume =3D pm_runtime_force_resume, + .runtime_suspend =3D panthor_system_suspend, + .runtime_resume =3D panthor_system_resume, +}; + +static const struct of_device_id panthor_system_dt_match[] =3D { + { .compatible =3D "arm,mali-gen5-am-system" }, + {} +}; + +static struct platform_driver panthor_system_driver =3D { + .probe =3D panthor_system_probe, + .remove =3D panthor_system_remove, + .driver =3D { + .name =3D "panthor_system", + .pm =3D pm_ptr(&panthor_system_pm_ops), + .of_match_table =3D panthor_system_dt_match, + }, +}; + +module_platform_driver(panthor_system_driver); + +MODULE_AUTHOR("ARM Ltd."); +MODULE_DESCRIPTION("GPU system driver for AM GPUs"); +MODULE_LICENSE("Dual MIT/GPL"); --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from DB3PR0202CU003.outbound.protection.outlook.com (mail-northeuropeazon11010008.outbound.protection.outlook.com [52.101.84.8]) (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 F39E33F9F26 for ; Thu, 28 May 2026 15:07:25 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.84.8 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980849; cv=fail; b=X8gL86KnPfIReS3VbP71DcsYcJbm2AFmyJ+BulFdifxYz111Dzzzl4LUa5QWnAVeY11IrrOher5rHpp9C3AXmQXgP2z3daC8bvyI4OVDbb8mA8WHV3XnjZKXj//sdWUi3lLZWeSdWkTHlrZPoAEpv/KrmxhK68sUnYMPsN2bZSU= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980849; c=relaxed/simple; bh=7qMzz1Z8RDrJZ/VCMiF6lrkzPsY6XEJxJQgrmFaHsG0=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=fGyskb5c8kwFBPfwVmWZl9RuYKosAbrzTK//ZFkioImgEUZKW7zzuZ5WYW9/ifOGv+hYX7S653z6GJhx9OloFOtFYQIqPavWH4E2gBC1D7LnWBu95YukCua6LmdGN/n163zHH/ZDfVeNGM7NjzqIS0ezGvD7sOLe7By97h+H+w8= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=XacbGUlL; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=XacbGUlL; arc=fail smtp.client-ip=52.101.84.8 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="XacbGUlL"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="XacbGUlL" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=V+XDKxZ9jgqz0ARL6ejOo+gcUvOQdS7dukWZGs4YGHVXFL9OTwt9do9kFUd2znhzwYlbmSLSocXQvYfcStOYTCDeEQJGEsHeADSL7PioieRdg1KoZBhgODrDkMtnOTuCqOQbouZE9NIQaKzUVDWK7p2Ek2kH1Wjg4YUXbyqHcT5aLhjoklg0iUzbYiwXGewy4BHmidaEB8IE/ny/vDD6Iy7B3ZVJT6R/lHfcXCZ+b+qO70+onU0hiOsSPSGi0FU4gL22oAqUdbRcxu1TtX8HMKKSrZnaVsOeUjkmzQAJZRnRrb3hxlj6p+sAdWlHaMsSivDH9yvS8l1CQWHoHKgGsw== ARC-Message-Signature: i=2; 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=iHP2FktcKcg1brfPRDbaQZ9x9GedExf7CLqejjt0ILY=; b=ukmKDGdQ56JMVnQOiGhxnEHpyUVBd+I6AbFguXHEKc4hcoMN0lpBQwjdRe70rJdHjKnk/0qQAusAaxkzkJ2Ip9eCFEyxuOpPp9lhJDjRe5mq9Ts01Qv5ai0DhEdGJneDxNdKi3A6dQ9TB07hd51I9CZQ8Pi/EdFnmOK76po/10QoVnzTf8gujHnKoahXI+waxA4pEffX1dcvJJX6EiyXfNhzO9iacrWS7N3OYJOiaPFNV1FO8GpAnQYwuUNmHv3qeqntA4xv+GjB7p1R2FvsPxIUZ2B0/tx/OgJ5oUFLkBlFrCwCPALYFXC23Hz8fwz6l1HJVGu8PVSdHDKnc0aafg== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=iHP2FktcKcg1brfPRDbaQZ9x9GedExf7CLqejjt0ILY=; b=XacbGUlLbcWk6J72tZqG1gwMv/QT3lTvZEXPnVrbojgDTgZWCBwdSn39gRrfjrdjOLJ4NHC4vV5BLSK1ym3G1MseVjvjOjoKipSx8SVgjLusa5Z/EeLUGta0DECMrgJWibC3n5ekofL5IuAG7osAxDkEddi/P5SY/0sdilLxBA4= Received: from AS4P191CA0023.EURP191.PROD.OUTLOOK.COM (2603:10a6:20b:5d9::19) by AS2PR08MB8781.eurprd08.prod.outlook.com (2603:10a6:20b:5f1::13) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:07:12 +0000 Received: from AM3PEPF0000A79C.eurprd04.prod.outlook.com (2603:10a6:20b:5d9:cafe::64) by AS4P191CA0023.outlook.office365.com (2603:10a6:20b:5d9::19) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.14 via Frontend Transport; Thu, 28 May 2026 15:07:10 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by AM3PEPF0000A79C.mail.protection.outlook.com (10.167.16.107) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.7 via Frontend Transport; Thu, 28 May 2026 15:07:10 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=nJam984jbMz62PdbaQ0mmRjf8hmsq+OvppxVZJfkDZ9n6grXFBJj7Qi+2uXv+TNw6tgLZpJyRgxlfdyqOX06QHNfoYOnkh4aCfIIh4OkSZgUoa72apQyxS3jjsR70plSsZwzd9tp+JeeqhaOmy+t+WWG39QHFpm+o7jpkwXO+JNWOcVccED558gIsNFGjiWwodAkkLiH7ZVzHx2V9McZLiBkfA1h2W0Lobe9Ki064o/y+TniJvJIoAbJF3mAZbvvHXCFEWkUpGgalRckT55ymm1kQM/pqvf8GVj8icwWC0BJXMy63CEelIiOpkax0eDVRZc6qxJ7AC2VPyEc8yQM1A== 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=iHP2FktcKcg1brfPRDbaQZ9x9GedExf7CLqejjt0ILY=; b=agTryW9RwQAdS5mBkQen1r00nDdIdsR+rIOQl6+gBpDj2mNdiPgfqLclgoAI1U/G3rqK8mm7096MTdfnSna/joyCEM1DrAfLIw19uk8S5KmHHEQ9zGM3oLVggIGmgHzx+O+v2IFkh6rIyL2ipPqNwxnvN/Utpaz0S8LPlSWXNIKtczURDSDMcFdsgIPV95Y+wJCk7HMhe9zt6EmWdBuI9Olk8lIhnyI9QxCDq5f1GitxYPAyhLo7xIsBznFzLUhPrSVBuoeRPMSXJQ72MgRSTEST3aA15ojXrGIdPjhqHGLQ16gnCShV+Kr1jABBwNSjTFHqZUwFYNdjiJZxLju/OQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=iHP2FktcKcg1brfPRDbaQZ9x9GedExf7CLqejjt0ILY=; b=XacbGUlLbcWk6J72tZqG1gwMv/QT3lTvZEXPnVrbojgDTgZWCBwdSn39gRrfjrdjOLJ4NHC4vV5BLSK1ym3G1MseVjvjOjoKipSx8SVgjLusa5Z/EeLUGta0DECMrgJWibC3n5ekofL5IuAG7osAxDkEddi/P5SY/0sdilLxBA4= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:07 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:07 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 10/18] drm/panthor: Add AM_PARTITION_CONTROL support Date: Thu, 28 May 2026 16:05:38 +0100 Message-ID: <20260528150546.3168527-11-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: LO4P123CA0026.GBRP123.PROD.OUTLOOK.COM (2603:10a6:600:151::13) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|AM3PEPF0000A79C:EE_|AS2PR08MB8781:EE_ X-MS-Office365-Filtering-Correlation-Id: 87b95228-06b8-49e7-2bc5-08debccacabe X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|6133799003|22082099003|18002099003|56012099006|5023799004|11063799006; X-Microsoft-Antispam-Message-Info-Original: BShVTFKG5hy0dm1ez+mkzfdzMxfsNYZfHLx05COzp299/WyUtruXXW0JzvpV1OXVRvjMJ+mp2+8EikItWqy7ieDFYY3W4mxRP6y+i6O0nHLMVfQ7Yb5aKaN2I83LmFeubE89kN7Vz6FVN0A60/9hU8dbmKRM9qW8zrlcXpd0cs/yX49A+6W5w2oniZ1PiRIvdAGCFnw5P+rsKJCOAS9ynsH85Gi26pXbqEKygyCB+qSwtSN+5RAEAMoln7QNK3QA/Z6h6/WKhjyo5rKUTykbwVxatUYdHp1f+hoMe4qjBeMgAclo9B/Zez3s4s5T4+uEqc8DZRqLQ1HeWeUozUnsCws9i+VBV3t7aGq5RXerjzgkcym01Lk4jRW3QfaivWdTdo1wZRorkHzV2QsQRxfxRvBPetoVoG0yegFV5d08WjpUw7l/i18bKDOwZo7Gqcm8kBuOI30fQ5RIV04x+7fB/o75jJ2SltbRfKYjNyZr+DBPIThYcLfugbuixFEMd7h9KvOET+kA3535mXU8kTIY7aYrCzjI8sB5wtZ0CjmSDdVmiHWnw9ZzabxnZLv7csaXulrQztBhFNGyvYZQ8iPM71ZAtt5bJdCwaVWAndRUFHCksLWuzwP/7Npy74cDuP7yQGjN0ZtXmWYmzGyqpGr+MHGoOKm883xGGaXqyfip+EQulSq8y/Gve3rVEXxDwmat X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(6133799003)(22082099003)(18002099003)(56012099006)(5023799004)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: XWVnLFD6l/H1z+B7EnN+J+W8n8GfUku7kb7uWY2aMZf9gQOcUUIxEAwkSuZFB40pTPF5fwVbIOZGlb4HnaklI/sgERE/h7gn2cWD2d8QxDncL47P+I3+dqeJ4AD6RUz6RizXwq6cbE24LPwLGilwnKvQh5O/LPvbtNfeqAOXIzINzKnEaOpctbH1ltCATdPlUS6B1fUe8PXjX/hpDbQfJcMaYjzBmx8lQYcbwhQTQ52CZaWT1+v/jaS6owONYlrau6pKtIrVKfJ8NaQ4JlHIz1toEACObxK0vyMWmpaG8g1t7K6G/MwcQ+vnM8QnWYUAjmSZSRwZBdCpPqx1R5L9KA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: AM3PEPF0000A79C.eurprd04.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: 0daaf1bd-cdd1-4f8c-b052-08debccaa4f4 X-Microsoft-Antispam: BCL:0;ARA:13230040|36860700016|35042699022|82310400026|14060799003|376014|1800799024|6133799003|22082099003|18002099003|56012099006|5023799004|11063799006; X-Microsoft-Antispam-Message-Info: cYqd5XZAo//f5BD+hs/FXKMgIzs7PiExH3naphwYYSfGkLfsGxgplTc2/Wsx4ZtdamD++G4b/LS5nLW/AmR5KdHmJJcPBVWKZRgia/XlFAssdYCQRSRwyKb+I7qIitHtdlIZP7qadUWWg2ihrhmxj2s07xUri6TboGcb2k4mID4/q+thjwZcMm4I9RgtaVNnxzA5R7wsVXBLYW4d0bQDfUOCesW4qkBIV9QqMDcwWvxIKOSVfZy9EpzRJzAkYA0fo0UfsZn7dY7rOKu9KWz+IiN1/b4ukE4/tMMo/qYhpb6zZB5zMqhCCilkyOny/VNu+V/3OvcG//aYc8zLVqxnXZQ+/uI8ssRBKIJr+C1UvpDf/AXqMAEhvMJ4jfuCNwdeD88xhWH+vs2T08+CpCRfH8HSaElE5J/JObSXkKJScoLCSn030MNOlNP/EcR/3XLyr413UfCAOEocvee2rvniGxNd4C2c0bIGY9JwygRxYaPbgmcLYx+OhKTVVfX+XER8SVNtlcwN0J2gDLUwUENDl99aHVd//Fn+IVgBFSCKwvVLftZGwsY/bySj+cwL8EGWU2lfYmCYnHSvYgjHNM7N79xokTFFksY9kIEUfn7WrrBafyxgXQks9l/wsTWwK5UkhJv82b9mrs4t6tCHTPynmm4SWI08bd5Kpnl1R/Rq8m7laMKxXBD4LUsI+WtQCza/8AzXNWltWui0BBgYceOQAJJMNtgaQBD2ouH+CzGFgFQ= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(36860700016)(35042699022)(82310400026)(14060799003)(376014)(1800799024)(6133799003)(22082099003)(18002099003)(56012099006)(5023799004)(11063799006);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: es5pBrP/e83uQdyReukZ4OgMH6hv2EdMrGvpzK+ejKlsZw04mwpOI+oL9n+RuDf8MTOhct+H56gJxq/RHkL3FbIYiMyXSUvMa2Il99mNyxoi4ooGI63Tge8ZoSjQNZC6PeAPE/wRe0MyDR2h3AIu+I392CnS7uU75VMwAIfE07kyd91/iVGfuR74OrC4OINlhBHwk/ctAJ0pefoDOlwsbA3ltx+jEuxi8Lzx5yyF86hDs6LzwQFdUSanWnKYIa4s1/yrOdrinsWIJjlF0ciD2mjksIRsGu/JnTR12mG/fsgqefrnGsUHLwSNVujKMhAngFUi1MtlwJKuAvXQeZYjyHyimv/TFhUc/d/ilJvTHXbVB8CP2vnpFTrAC3w4VORjtBfgfAGiIx7TtF9TnLau+peCc9ZUKSZEmXpqdeHUuGkXUH+RtZKPURwbeOO6ofoT X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:10.3092 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 87b95228-06b8-49e7-2bc5-08debccacabe X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: AM3PEPF0000A79C.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: AS2PR08MB8781 Content-Type: text/plain; charset="utf-8" Mali v15 AM GPUs expose AM_PARTITION_CONTROL blocks to manage partition access windows. Add a panthor arbitration platform driver and wire it into Kconfig and the panthor build. The driver maps pcN partition-control resources, handles RESET_DONE and INVALID_COMMAND interrupts, and provides helpers to open, close and yield partition access windows. Signed-off-by: Karunika Choo --- drivers/gpu/drm/panthor/Kconfig | 7 + drivers/gpu/drm/panthor/Makefile | 1 + drivers/gpu/drm/panthor/arbitration/Makefile | 15 + .../panthor/arbitration/panthor_arbitration.h | 24 ++ .../arbitration/panthor_arbitration_drv.c | 127 ++++++ .../arbitration/panthor_partition_control.c | 381 ++++++++++++++++++ .../arbitration/panthor_partition_control.h | 27 ++ 7 files changed, 582 insertions(+) create mode 100644 drivers/gpu/drm/panthor/arbitration/Makefile create mode 100644 drivers/gpu/drm/panthor/arbitration/panthor_arbitration= .h create mode 100644 drivers/gpu/drm/panthor/arbitration/panthor_arbitration= _drv.c create mode 100644 drivers/gpu/drm/panthor/arbitration/panthor_partition_c= ontrol.c create mode 100644 drivers/gpu/drm/panthor/arbitration/panthor_partition_c= ontrol.h diff --git a/drivers/gpu/drm/panthor/Kconfig b/drivers/gpu/drm/panthor/Kcon= fig index da6b9bc1c67b..55b9b80f45d1 100644 --- a/drivers/gpu/drm/panthor/Kconfig +++ b/drivers/gpu/drm/panthor/Kconfig @@ -27,3 +27,10 @@ config DRM_PANTHOR_SYSTEM depends on OF help Driver for GPU-wide configuration of Arm Mali 5th Gen AM GPUs. + +config DRM_PANTHOR_ARBITRATION + tristate "HW-assisted virtualization for Mali 5th Gen AM GPUs" + depends on DRM_PANTHOR + depends on OF + help + HW-assisted virtualization driver for Mali 5th Gen AM GPUs. diff --git a/drivers/gpu/drm/panthor/Makefile b/drivers/gpu/drm/panthor/Mak= efile index 488a5e03efbc..5d4d0ae64952 100644 --- a/drivers/gpu/drm/panthor/Makefile +++ b/drivers/gpu/drm/panthor/Makefile @@ -15,5 +15,6 @@ panthor-y :=3D \ =20 obj-$(CONFIG_DRM_PANTHOR) +=3D panthor.o obj-$(CONFIG_DRM_PANTHOR_SYSTEM) +=3D system/ +obj-$(CONFIG_DRM_PANTHOR_ARBITRATION) +=3D arbitration/ =20 CFLAGS_panthor_gpu.o :=3D -I$(src) diff --git a/drivers/gpu/drm/panthor/arbitration/Makefile b/drivers/gpu/drm= /panthor/arbitration/Makefile new file mode 100644 index 000000000000..5d5b2b8d84bc --- /dev/null +++ b/drivers/gpu/drm/panthor/arbitration/Makefile @@ -0,0 +1,15 @@ +# SPDX-License-Identifier: GPL-2.0 OR MIT +# Copyright 2026 ARM Limited. All rights reserved. + +obj-$(CONFIG_DRM_PANTHOR_ARBITRATION) +=3D panthor_arbitration.o +panthor_arbitration-y :=3D \ + panthor_arbitration_drv.o \ + panthor_partition_control.o + +INCLUDES =3D \ + -I$(src)/.. + +ccflags-y +=3D $(INCLUDES) +subdir-ccflags-y +=3D $(INCLUDES) + + diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration.h b/dr= ivers/gpu/drm/panthor/arbitration/panthor_arbitration.h new file mode 100644 index 000000000000..5e35ae8463c4 --- /dev/null +++ b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration.h @@ -0,0 +1,24 @@ +/* SPDX-License-Identifier: GPL-2.0 or MIT */ +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#ifndef __PANTHOR_ARBITRATION_H__ +#define __PANTHOR_ARBITRATION_H__ + +struct device; +struct panthor_partition_control; + +#define AM_ARB_MAX_PC_COUNT 1 +#define AM_ARB_MAX_AW_COUNT 16 + +/** + * struct panthor_arbitration - Arbitration device + */ +struct panthor_arbitration { + /** @dev: Device pointer */ + struct device *dev; + + /** @pc: Pointer array to partition control data */ + struct panthor_partition_control *pc[AM_ARB_MAX_PC_COUNT]; +}; + +#endif diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c = b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c new file mode 100644 index 000000000000..07a566168e6a --- /dev/null +++ b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c @@ -0,0 +1,127 @@ +// SPDX-License-Identifier: GPL-2.0 or MIT +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#include +#include +#include +#include +#include +#include + +#include "panthor_arbitration.h" +#include "panthor_partition_control.h" + +#define PANTHOR_PM_AUTOSUSPEND_DELAY_MS 100 + +static int panthor_arbitration_runtime_suspend(struct device *dev) +{ + struct panthor_arbitration *adev =3D dev_get_drvdata(dev); + int ret =3D 0; + + ret =3D panthor_partition_control_suspend(adev); + if (ret) + return ret; + + return 0; +} + +static int panthor_arbitration_runtime_resume(struct device *dev) +{ + struct panthor_arbitration *adev =3D dev_get_drvdata(dev); + int ret =3D 0; + + ret =3D panthor_partition_control_resume(adev); + if (ret) + return ret; + + return 0; +} + +static int panthor_arbitration_probe(struct platform_device *pdev) +{ + struct panthor_arbitration *adev; + struct device *dev =3D &pdev->dev; + int ret; + + if (!pdev) + return -EINVAL; + + adev =3D devm_kzalloc(dev, sizeof(*adev), GFP_KERNEL); + if (!adev) + return -ENOMEM; + + adev->dev =3D dev; + + dev_set_drvdata(dev, adev); + + ret =3D devm_pm_runtime_enable(dev); + if (ret) + return ret; + + ret =3D pm_runtime_resume_and_get(dev); + if (ret) + return ret; + + ret =3D panthor_partition_control_init(adev); + if (ret) + goto err_out; + + pm_runtime_set_autosuspend_delay(dev, PANTHOR_PM_AUTOSUSPEND_DELAY_MS); + pm_runtime_use_autosuspend(dev); + + pm_runtime_put_autosuspend(dev); + + return 0; + +err_out: + pm_runtime_put_noidle(dev); + return ret; +} + +static void panthor_arbitration_remove(struct platform_device *pdev) +{ + struct panthor_arbitration *adev =3D platform_get_drvdata(pdev); + int ret; + + if (!adev) + return; + + ret =3D pm_runtime_resume_and_get(adev->dev); + if (ret < 0) + goto out_suspended; + + panthor_partition_control_term(adev); + + pm_runtime_put_noidle(adev->dev); + +out_suspended: + pm_runtime_set_suspended(adev->dev); +} + +static const struct dev_pm_ops panthor_arbitration_pm_ops =3D { + .resume =3D pm_runtime_force_resume, + .suspend =3D pm_runtime_force_suspend, + .runtime_resume =3D panthor_arbitration_runtime_resume, + .runtime_suspend =3D panthor_arbitration_runtime_suspend, +}; + +static const struct of_device_id panthor_arbitration_of_match[] =3D { + { .compatible =3D "arm,mali-gen5-am-arbitration" }, + { /* Sentinel */ }, +}; + +static struct platform_driver panthor_arbitration_driver =3D { + .probe =3D panthor_arbitration_probe, + .remove =3D panthor_arbitration_remove, + .driver =3D { + .name =3D "panthor-arbitration", + .of_match_table =3D panthor_arbitration_of_match, + .pm =3D pm_ptr(&panthor_arbitration_pm_ops), + }, +}; + +module_platform_driver(panthor_arbitration_driver); + +MODULE_AUTHOR("ARM Ltd."); +MODULE_DESCRIPTION("Panthor HW-assisted virtualization Driver"); +MODULE_LICENSE("Dual MIT/GPL"); diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_partition_control.= c b/drivers/gpu/drm/panthor/arbitration/panthor_partition_control.c new file mode 100644 index 000000000000..f4bad839610d --- /dev/null +++ b/drivers/gpu/drm/panthor/arbitration/panthor_partition_control.c @@ -0,0 +1,381 @@ +// SPDX-License-Identifier: GPL-2.0 or MIT +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#include +#include +#include +#include + +#include "panthor_arbitration.h" +#include "panthor_device_io.h" +#include "panthor_partition_control.h" + +#define AM_PART_IRQ_RAWSTAT 0x40 +#define AM_PART_IRQ_CLEAR 0x44 +#define AM_PART_IRQ_MASK 0x48 +#define AM_PART_IRQ_STATUS 0x4C +#define PART_RESET_DONE BIT(3) +#define PART_INVALID_COMMAND BIT(6) + +#define AM_PART_STATE 0x60 +#define AM_PART_STATE_GET(x) FIELD_GET(GENMASK(11, 8), x) +#define PART_STATE_RESET 0 +#define PART_STATE_WINDOW_OPENING 1 +#define PART_STATE_WINDOW_OPEN 7 +#define PART_STATE_WINDOW_CLOSED 8 +#define AM_PART_STATE_WINDOW_GET(x) FIELD_GET(GENMASK(15, 12), x) + +#define AM_PART_COMMAND 0x100 +#define AM_PART_SET_COMMAND(x) FIELD_PREP(GENMASK(7, 0), x) +#define PART_CMD_YIELD_IDLE 0x10 +#define PART_CMD_YIELD_NOW 0x11 +#define PART_CMD_CLOSE_WINDOW 0x20 +#define PART_CMD_OPEN_WINDOW 0x21 +#define AM_PART_SET_WINDOW(x) FIELD_PREP(GENMASK(11, 8), x) + +#define PART_CONTROL_IRQ_MASK \ + (PART_RESET_DONE | PART_INVALID_COMMAND) + +#define PART_REG_POLL_SLEEP_US 10 +#define PART_STATE_TRANSITION_TIMEOUT_US 5000000 + +/** + * struct panthor_partition_control - Partition control data + */ +struct panthor_partition_control { + /** @dev: Device pointer */ + struct device *dev; + + /** @name: Resource name */ + char *name; + + /** @iomem: CPU mapping of the partition control IOMEM region */ + void __iomem *iomem; + + /** @irq: IRQ number */ + int irq; + + /** @lock: Proctects partition control state data */ + spinlock_t lock; + + /** @current_aw: currently open access window */ + int current_aw; + + /** @closing: synchronous closing of the partition */ + bool closing; + + /** @waitqueue: Event wait queue. Not IRQ safe */ + wait_queue_head_t waitqueue; +}; + +static void partition_irq_suspend(struct panthor_partition_control *pc) +{ + gpu_write(pc->iomem, AM_PART_IRQ_MASK, 0); +} + +static void partition_irq_resume(struct panthor_partition_control *pc) +{ + gpu_write(pc->iomem, AM_PART_IRQ_MASK, PART_CONTROL_IRQ_MASK); +} + +static u32 partition_state_get(struct panthor_partition_control *pc) +{ + const u32 state =3D gpu_read(pc->iomem, AM_PART_STATE); + + return AM_PART_STATE_GET(state); +} + +static u8 partition_aw_get(struct panthor_partition_control *pc) +{ + const u32 state =3D gpu_read(pc->iomem, AM_PART_STATE); + + return AM_PART_STATE_WINDOW_GET(state); +} + +static int partition_state_wait(struct panthor_partition_control *pc, u32 = state) +{ + u32 partition_state; + + return read_poll_timeout_atomic(partition_state_get, partition_state, + partition_state =3D=3D state, + PART_REG_POLL_SLEEP_US, + PART_STATE_TRANSITION_TIMEOUT_US, + false, pc); +} + +static int partition_state_wait_transition(struct panthor_partition_contro= l *pc) +{ + int ret; + +again: + switch (partition_state_get(pc)) { + case PART_STATE_WINDOW_CLOSED: + ret =3D partition_state_wait(pc, PART_STATE_RESET); + if (ret) + return ret; + goto again; + case PART_STATE_WINDOW_OPENING: + ret =3D partition_state_wait(pc, PART_STATE_WINDOW_OPEN); + if (ret) + return ret; + goto again; + case PART_STATE_RESET: + case PART_STATE_WINDOW_OPEN: + return 0; + default: + dev_err(pc->dev, "%s: Unknown state %u", pc->name, + partition_state_get(pc)); + return -EINVAL; + } +} + +static int yield_now(struct panthor_partition_control *pc) +{ + int ret; + + ret =3D partition_state_wait_transition(pc); + if (ret) + return ret; + + /* Partition already reset, nothing to yield */ + if (partition_state_get(pc) =3D=3D PART_STATE_RESET) + return 0; + + gpu_write(pc->iomem, AM_PART_COMMAND, + AM_PART_SET_COMMAND(PART_CMD_YIELD_NOW)); + + return 0; +} + +static int window_close(struct panthor_partition_control *pc) +{ + int ret; + + ret =3D partition_state_wait_transition(pc); + if (ret) + return ret; + + /* Partition already closed. */ + if (partition_state_get(pc) =3D=3D PART_STATE_RESET) + return 0; + + scoped_guard(spinlock_irqsave, &pc->lock) + pc->closing =3D true; + + gpu_write(pc->iomem, AM_PART_COMMAND, + AM_PART_SET_COMMAND(PART_CMD_CLOSE_WINDOW)); + + /* + * Wait for RESET_DONE interrupt to clear pc->closing. Prevents stale + * RESET_DONE from being misinterpreted as RESET_DONE due to YIELD_DONE. + */ + if (!wait_event_timeout( + pc->waitqueue, !pc->closing, + usecs_to_jiffies(PART_STATE_TRANSITION_TIMEOUT_US))) { + if (pc->closing) { + dev_err(pc->dev, + "%s: Timed out waiting for partition to close: %d", + pc->name, ret); + return -ETIMEDOUT; + } + } + + return 0; +} + +static int window_open(struct panthor_partition_control *pc, u8 aw_id) +{ + int ret; + + if (aw_id >=3D AM_ARB_MAX_AW_COUNT) + return -EINVAL; + + ret =3D partition_state_wait_transition(pc); + if (ret) + return ret; + + if (partition_state_get(pc) =3D=3D PART_STATE_WINDOW_OPEN) { + dev_warn(pc->dev, + "%s: Window opem for %u Failed. Already opened. aw=3D%u, state=3D%u", + pc->name, aw_id, partition_aw_get(pc), + partition_state_get(pc)); + return 0; + } + + gpu_write(pc->iomem, AM_PART_COMMAND, + AM_PART_SET_COMMAND(PART_CMD_OPEN_WINDOW) | AM_PART_SET_WINDOW(aw_id)); + + ret =3D partition_state_wait(pc, PART_STATE_WINDOW_OPEN); + if (ret) { + dev_err(pc->dev, "%s: Timed out waiting for partition to open: %d", + pc->name, ret); + return ret; + } + + scoped_guard(spinlock_irqsave, &pc->lock) + pc->current_aw =3D aw_id; + + return 0; +} + +static void partition_handle_reset_done(struct panthor_partition_control *= pc) +{ + scoped_guard(spinlock_irqsave, &pc->lock) { + pc->current_aw =3D -1; + + /* RESET_DONE from CLOSE_WINDOW */ + if (pc->closing) + pc->closing =3D false; + } + + wake_up_all(&pc->waitqueue); +} + +static irqreturn_t partition_irq_raw_handler(int irq, void *data) +{ + struct panthor_partition_control *pc =3D data; + u32 status; + + status =3D gpu_read(pc->iomem, AM_PART_IRQ_STATUS); + if (!status) + return IRQ_NONE; + + if (status & PART_RESET_DONE) + partition_handle_reset_done(pc); + + if (status & PART_INVALID_COMMAND) + dev_warn(pc->dev, "%s: Invalid command", pc->name); + + gpu_write(pc->iomem, AM_PART_IRQ_CLEAR, status); + + return IRQ_HANDLED; +} + +int panthor_partition_control_suspend(struct panthor_arbitration *adev) +{ + for (int i =3D 0; i < AM_ARB_MAX_PC_COUNT; i++) { + struct panthor_partition_control *pc =3D adev->pc[i]; + + if (!pc) + continue; + + partition_irq_suspend(pc); + } + + return 0; +} + +int panthor_partition_control_resume(struct panthor_arbitration *adev) +{ + for (int i =3D 0; i < AM_ARB_MAX_PC_COUNT; i++) { + struct panthor_partition_control *pc =3D adev->pc[i]; + + if (!pc) + continue; + + partition_irq_resume(pc); + } + + return 0; +} + +void panthor_partition_control_term(struct panthor_arbitration *adev) +{ + for (int i =3D 0; i < AM_ARB_MAX_PC_COUNT; i++) { + struct panthor_partition_control *pc =3D adev->pc[i]; + + if (!pc) + continue; + + if (!WARN_ON(window_close(pc))) + WARN_ON(partition_state_wait(pc, PART_STATE_RESET)); + + partition_irq_suspend(pc); + } +} + +static int partition_control_init(struct panthor_arbitration *adev, int i) +{ + struct device *dev =3D adev->dev; + struct platform_device *pdev =3D to_platform_device(dev); + struct panthor_partition_control *pc; + struct resource *res; + void __iomem *iomem; + char *name; + int irq; + int ret; + + if (i >=3D AM_ARB_MAX_PC_COUNT) + return -EINVAL; + + name =3D devm_kasprintf(dev, GFP_KERNEL, "pc%d", i); + + res =3D platform_get_resource_byname(pdev, IORESOURCE_MEM, name); + if (!res) { + devm_kfree(dev, name); + return -ENODEV; + } + + pc =3D devm_kzalloc(dev, sizeof(*pc), GFP_KERNEL); + if (!pc) + return -ENOMEM; + + iomem =3D devm_ioremap_resource(dev, res); + if (IS_ERR(iomem)) { + return dev_err_probe(dev, PTR_ERR(iomem), + "%s: Failed to ioremap", name); + } + + pc->name =3D name; + pc->dev =3D dev; + pc->iomem =3D iomem; + + init_waitqueue_head(&pc->waitqueue); + spin_lock_init(&pc->lock); + pc->current_aw =3D -1; + + adev->pc[i] =3D pc; + + irq =3D platform_get_irq_byname(pdev, name); + if (irq < 0) + return irq; + + ret =3D devm_request_irq( + dev, irq, partition_irq_raw_handler, IRQF_SHARED, + devm_kasprintf(dev, GFP_KERNEL, "panthor-%s-irq", name), pc); + if (ret) + return ret; + + partition_irq_resume(pc); + + return 0; +} + +int panthor_partition_control_init(struct panthor_arbitration *adev) +{ + for (int i =3D 0; i < AM_ARB_MAX_PC_COUNT; i++) { + int ret =3D partition_control_init(adev, i); + if (ret =3D=3D -ENODEV) + continue; + + if (ret) + return ret; + } + + return 0; +} + +int panthor_partition_control_open_window(struct panthor_partition_control= *pc, u8 aw_id) +{ + return window_open(pc, aw_id); +} + +int panthor_partition_control_close_window(struct panthor_partition_contro= l *pc) +{ + return window_close(pc); +} + +int panthor_partition_control_yield_now(struct panthor_partition_control *= pc) +{ + return yield_now(pc); +} diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_partition_control.= h b/drivers/gpu/drm/panthor/arbitration/panthor_partition_control.h new file mode 100644 index 000000000000..bd935de04137 --- /dev/null +++ b/drivers/gpu/drm/panthor/arbitration/panthor_partition_control.h @@ -0,0 +1,27 @@ +/* SPDX-License-Identifier: GPL-2.0 or MIT */ +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#ifndef __PANTHOR_PARTITION_CONTROL_H__ +#define __PANTHOR_PARTITION_CONTROL_H__ + +#include + +struct device; +struct panthor_arbitration; +struct panthor_partition_control; + +int panthor_partition_control_init(struct panthor_arbitration *adev); + +void panthor_partition_control_term(struct panthor_arbitration *adev); + +int panthor_partition_control_suspend(struct panthor_arbitration *adev); + +int panthor_partition_control_resume(struct panthor_arbitration *adev); + +int panthor_partition_control_open_window(struct panthor_partition_control= *pc, u8 aw_id); + +int panthor_partition_control_close_window(struct panthor_partition_contro= l *pc); + +int panthor_partition_control_yield_now(struct panthor_partition_control *= pc); + +#endif --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from GVXPR05CU001.outbound.protection.outlook.com (mail-swedencentralazon11013032.outbound.protection.outlook.com [52.101.83.32]) (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 8C1E93F44D1 for ; Thu, 28 May 2026 15:07:19 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.83.32 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980843; cv=fail; b=FxX5a9dw/Ge1q9OhLYCEg24PuxThFVjRtqLtgZQl2Z/l2DYOd636mQc6PGhFog4QiDsKRuHeRs5E0xuibBf7jb1BVn33+vf1GAo292jGMwWShH/jrw7U5WwUr16kbqzC19urUF4b2N4pduOCXOIwCGHXovLsvZiKYOFQtsAtmMw= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980843; c=relaxed/simple; bh=RIclo6Wk0DnUpGxaIEvnRzW5Z4gs9MRSxa4yLSbDlpY=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=Zt4wvKw317UeoCx+zD8Sy+bCez6KGknBx5hSKTfqwKxLXwvb8fmIutjQWGO8oqijkuGZE6JBzG3Dv/dzZLZt4P6A0tIUjFzYk7FKeysHd+FNX+tcoZF89OUA2TmneuGUgaGNHBMNe5Y6agXC4Zk3V2Zr6IspPKKN/TMn4JkJM44= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=SdMdpXP4; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=SdMdpXP4; arc=fail smtp.client-ip=52.101.83.32 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="SdMdpXP4"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="SdMdpXP4" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=M7a0oHMLoeAebcK1elc6+eL2Ci8nDMA5W/hSIQkUvaGUxL9E+TT1CiaV0r6qeE8xgdHBcRHrEIW42CBjNXaBUGom8YsqOfSAJtgfL5UwI7lJHfmtTCT/QKFvwaA9xC4qLaDjXzO1B3oA75V74cvF9+w86MLyJTgEkTz6OnM0Y+iojEXLxI2vbAztQEKiVUySChMFPPXdaKYZrB8E1No3BdmFudlOJTam1jA2Ptsor8xDMYiwzggBAbLhI8hZVaSVeE9oK0RliTqTkmq5f359IjlJDkAHaN+aHIwYn3TogoXXs2BRg8jzTRQG+tE4rdSgmtF6j2QvFLj7L4xUwnbwDA== ARC-Message-Signature: i=2; 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=NlsiOMDyWO3C6YjKkbHsPXa4SWDGHhYpRvhQJGfbM48=; b=l/kRp1fQMXon52ZR/pKup8UmWsznjk1fkngS20o+iQ6V+aTWfnGzyLqosPzhRQOr+AG+i/Dq39qGBzJutVMCgF+Rdk3AhFK7/g9cznnbjS7F/Sp+8j7VI9lH3RAXyTIIvkpOUUhGUgoNl9g2QeTYbrOXjJVMEHeYez4Bor/+PQrIWxBzC/A3K8PZ0yDL3cO2vUclzar29cpbkuMDXNSpjGtVloSc3pbofC9C1gdQVzgyLlGhYB+OjWL8QjsuT7USCUJLYWxnY1/Znk4y+a4L64WkHijZzA+R1k0luogSxol8mN4v4XGdQdOI8vlOZ7UJaOvxWCYepbNTG9Uo6FGzWA== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=NlsiOMDyWO3C6YjKkbHsPXa4SWDGHhYpRvhQJGfbM48=; b=SdMdpXP4wVMtRlZjP0LVHevFuGv4FyQ/dFSyc/7Be/D9OyEOfddIInjCFI0u8hyVDRk6BwOnKZyn0zL1NFfUK+SJOIf7if9yJ82X3UO2EtJsuPxQTh1AY6m/1VGsS3VUR9fOD/H1tJMfIlBPZcmKa/ub9X3GtgpDExZVXzfrmSs= Received: from DUZPR01CA0269.eurprd01.prod.exchangelabs.com (2603:10a6:10:4b9::18) by PA4PR08MB7548.eurprd08.prod.outlook.com (2603:10a6:102:26e::9) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.13; Thu, 28 May 2026 15:07:12 +0000 Received: from DB1PEPF000509E7.eurprd03.prod.outlook.com (2603:10a6:10:4b9:cafe::24) by DUZPR01CA0269.outlook.office365.com (2603:10a6:10:4b9::18) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.14 via Frontend Transport; Thu, 28 May 2026 15:07:12 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by DB1PEPF000509E7.mail.protection.outlook.com (10.167.242.57) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.48.11 via Frontend Transport; Thu, 28 May 2026 15:07:11 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=nkQBaFMwkn1d8eFukX/evGueUWGUjo7XpmZuDQ2fyVEMa+nG5cAW9d48QlEUWHKBB8OJKCRPR1YDvi7nPgEyeU0wXwlZavH1DZbdvlwkXZWRS0jseReph+kRFRqV6l8ZHbaIt0OX1PxlzMFJTEML1GdQkEnZ7NQBLmNK1L+FMYhtWgk4HL7XGsx3NRFdphBVGAdWLjuANwwj2b9YSYGP0bsS4mrmmobTRDNkRIJbGsG727dZwbLwnqLFxW5Q7aP1vAVgZygc4aaEG+SX7V+2kazX2/f86mQO3VRN9gUErmuQ0vOWOEFlYjvG1TQ2s7jyfaHh2xK9/CPBdc2EXCQoVA== 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=NlsiOMDyWO3C6YjKkbHsPXa4SWDGHhYpRvhQJGfbM48=; b=uuABC4N9oEEDP7B9WuN6oAqvrm5V7pKlsxTuKQ4NAD120cAJwoL7bWYiya5ob7sjj9y/rrRaiob69lTN1eA8PhsEaSRe6kBea/DrkbHCn98bNF4ffazObA4jSCTs/aaytP1MbOgVIKTQzHhxbASY7xSS5BSjINnxgSWSSTo8huMzpkEW3S9ez4hRWfWh+42+C7ZKe6KiZbZTA3RJSOZCVNiP95andDZiWnDHGx4FXcZ5ejMzJ9r751COncRrsfOfNhqBudJbjpdzL6+PrgblwF6LlNkAiYeSwmZST/VRpGIjdzPAHy+Fe5WHPkeJsvZTDR97sOPPw6WWSvKDF3nbCg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=NlsiOMDyWO3C6YjKkbHsPXa4SWDGHhYpRvhQJGfbM48=; b=SdMdpXP4wVMtRlZjP0LVHevFuGv4FyQ/dFSyc/7Be/D9OyEOfddIInjCFI0u8hyVDRk6BwOnKZyn0zL1NFfUK+SJOIf7if9yJ82X3UO2EtJsuPxQTh1AY6m/1VGsS3VUR9fOD/H1tJMfIlBPZcmKa/ub9X3GtgpDExZVXzfrmSs= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:08 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:08 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 11/18] drm/panthor: Add AM message helpers Date: Thu, 28 May 2026 16:05:39 +0100 Message-ID: <20260528150546.3168527-12-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: LO4P123CA0500.GBRP123.PROD.OUTLOOK.COM (2603:10a6:600:1ab::19) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|DB1PEPF000509E7:EE_|PA4PR08MB7548:EE_ X-MS-Office365-Filtering-Correlation-Id: 751d8226-c0d2-4424-da12-08debccacb8a X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|22082099003|18002099003|3023799007|56012099006|5023799004|11063799006; X-Microsoft-Antispam-Message-Info-Original: UQSvzjw+H3LjGMS08SGHyfAIHucdIksYbnYUPHDSGvlm+T21ZDT5Xi7pRERjeJ3nIQemYqa5+P6/0u7csx5oAe7kINfeKmAOvmpovqq78a7mw6QmtieRbcnYCmsCGMnUYDMGRAZbzwL4Xfn326vPAyFssgj0Q0cY1e+fY7Sn+JOB8AGlZaAg64BdCXWLdQjJwa3nfsW5qJUlBecyVDI1buCdYP7CZ4skNSU8HiLO0wSZrwpVuUVMqe8zDKw/1lO4KHOmcyz+UA4QpiPKDMDEc1fSVYxewzZL55IWRI6veUnHxygiNtz0biw58Eh9RLBBDbam6eHMiNhPfHM8RK6ksOSKDuIPQdsaIKVkJefwXrGSqkznH/kFaqhsYnhFou9jnHV4YsEc4n8xByZ707xe2eCOnFBSOPwvJhAT7PWU9Z650Yy7ub1kKSgLmE5Y0rpoLdXFbdwUAkgqyhAUvDCOrRhzXZDFiaB4ZkBHmT+UsKoihBL8bpynJFuotiZlFk10W1ttdY5HOAWMFw33dRXSRmrAXY2BHgwbJ3fKsxxhXX/+CGgD/ZELmnkgHtxeU0rdGwb90KFKwPUwX7Xn65F/4C+w/9hFa9W4upw170567QKBRGpJBluvnbSUcwZsvYp61RmoZ4eTu78S4+CFhVOt2FmbqeVpQD4BW2DbwylNikw9vBua+2rooaiIz6aNBWrt X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(22082099003)(18002099003)(3023799007)(56012099006)(5023799004)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: ZB0wv1BGVEp73SWXtfA5uHIZP0cd6whNbZuVyJlEMEK12t91dOlJ3vW0VmQrvPJAMwbpg9BuPr9zEmI0iorbYw5MC0A+iWdATo3AWKGNYHYdIm0GC0ntbLo4P8O2CM1dmBTODZO7c/1Grfkgz5a5u5omPx3D1CrruNjA5YCzEvB/9iVcp6B6Du7B/wJt7+iBFd1kgdspLzQ1cg5uZ4a8wzqC0VGsupacXYqGAJx0b1DVka6HMAkBA83JXAYxTEv9ei2IJWtK8inEjrVshEOpbspeGnwbgRZvPt+T7IS+MbZPN+4ApDbeesoR7frKXvy0E59q7NHreuOQKla2h0bErw== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: DB1PEPF000509E7.eurprd03.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: a792d752-005b-4ad1-4400-08debccaa5d0 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|14060799003|36860700016|376014|82310400026|35042699022|18002099003|22082099003|56012099006|3023799007|11063799006|5023799004; X-Microsoft-Antispam-Message-Info: tuhy1xQg8KBZKBoZs1KQfyhKziqBu3biZW4Ynv9Xa+OivMAE9K7J5pkJb8WnW1xCxJw7+lQan6pyCixt0RDQ9bBDbxj40G7sFpv4H6Tfnz3Ty4Mcz31M/G2BoFFampXxhloli0tEYMXPp0TvMQ5RnaagUSCN8qEr3qLl9HUf4sexiKhhO3To3i+ZLgG5n+DG6fcZ6StP411y7P+Z6TpPIUWf9bridyIvLQBQjUrqQXT9pSeRdU4UGBLLY26TaD/DV+l9ziLSWUqTRxL6m17F/lTxl+AHR1vzMdMP0IKAQDBi8t7xuESMZAS0YB4jWiNg9JYWY4zfS+GX5ZmoDqkTzJ2teXOc2Oc2rT6lgz5bvwC3QEYrXFXUMsHsDkk8I0U28navc1NICVblFiKhPeSN3nKhGg/4GVkky/5KpW74p+fA3i5AXe1lrgxa/l0anfMk998A3AArcKwnPFG09tsVwfb1RH3V5tbDMUAxs0C1Jm3wd9xXIEYoElHu9nAJqpcBiTFbcjVTeeeeHLIJEfurex0ZtyAhiVbZE409q9HOQQe27k7jRWpCzEjnJWf/SyIwXcSRzXYSX70ht0MPszulmmvbxklG4TLJkTHguF4Ijon7siVcwTSWVN4ruRu59Y3Avtm1jCK9icTj1j4a9bPquWTzjGyMQT8pD+NMboZ5EfUufpz2cjRYy9kZ1uaJmZ3AdVLavNvix2DZb0wMoyR0WfEtAQ9Eyv3jG1OdGoRgZ+I= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(1800799024)(14060799003)(36860700016)(376014)(82310400026)(35042699022)(18002099003)(22082099003)(56012099006)(3023799007)(11063799006)(5023799004);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: vUS2zb8fUTakEPOe10TMK3vUPWg3Iq6KiN2OO5qfa2roTIvzWxOHrmaWioffrg20LFJo5noH4oOlGGZtK07DKzYz14gsySXfl4C4xOpbS3V7CKoc5QDtvZn9GYNmNOPg3QHin2vcDvprTs8Uoe1snAwWo+N22GTlFEmX/c3grvR31x0Tb2m5E/K81tLs7naNutcyYbZqy2jmvy2z7ZXCXktPzr6DeGvd40cNmxZpP0snrlLzzjNSEgUYMXY9IllBGvxfbVgwjrL14+LJEaLqnAN01JOxbCDr/fHWBucsUdFQVctZRTdIr8fn9kkMZ9LlHC395sEWrdZKxixSeR610uM3eJi5cw+JOd/bFKtAliNMslMHkxs/w3BWWNk0pEwSmkN5N9nEJmolosVEtXLQk2aBm5sY1ghiTwI6/0/gZpWjGakCfAvwNkOvX4Z93swX X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:11.6387 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 751d8226-c0d2-4424-da12-08debccacb8a X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: DB1PEPF000509E7.eurprd03.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: PA4PR08MB7548 Content-Type: text/plain; charset="utf-8" Add a shared helper layer for the AM_MESSAGE registers used by v15 GPUs to coordinate between access windows to enable virtualisation of the GPU. The helper defines message IDs, register accessors, version negotiation, and FIFO-backed sending. Outgoing messages are serialized with a spinlock, written in the required register order, and queued for later retry when the hardware outgoing slot is busy. Signed-off-by: Karunika Choo --- drivers/gpu/drm/panthor/panthor_am_msg.h | 157 +++++++++++++++++++++++ 1 file changed, 157 insertions(+) create mode 100644 drivers/gpu/drm/panthor/panthor_am_msg.h diff --git a/drivers/gpu/drm/panthor/panthor_am_msg.h b/drivers/gpu/drm/pan= thor/panthor_am_msg.h new file mode 100644 index 000000000000..bc4dedcd03ba --- /dev/null +++ b/drivers/gpu/drm/panthor/panthor_am_msg.h @@ -0,0 +1,157 @@ +/* SPDX-License-Identifier: GPL-2.0 or MIT */ +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#ifndef __PANTHOR_AM_H__ +#define __PANTHOR_AM_H__ + +#include +#include +#include +#include +#include + +#include "panthor_device_io.h" + +/* Protocol versioning */ +#define AM_MSG_MIN_SUPPORTED_VERSION 0x1 +#define AM_MSG_CURRENT_VERSION 0x1 + +#define AM_INCOMING_MESSAGE0 0x0 +#define AM_INCOMING_MESSAGE1 0x4 +#define AM_OUTGOING_MESSAGE_STATUS 0x8 +#define AM_OUTGOING_MESSAGE0 0xc +#define AM_OUTGOING_MESSAGE1 0x10 + +/* Arbiter to VM message IDs */ +#define ARB_VM_GPU_STOP 0x01 +#define ARB_VM_INIT 0x04 + +/* VM to Arbiter message IDs */ +#define VM_ARB_INIT 0x05 +#define VM_ARB_GPU_REQUEST 0x08 +#define VM_ARB_GPU_STOPPED 0x09 + +#define AM_MSG_ID_MASK GENMASK(7, 0) +#define AM_MSG_ACK_MASK BIT(8) +#define AM_MSG_VERSION_MASK GENMASK(15, 9) + +#define AM_MSG_ID_GET(x) FIELD_GET(AM_MSG_ID_MASK, x) +#define AM_MSG_ACK_GET(x) FIELD_GET(AM_MSG_ACK_MASK, x) +#define AM_MSG_VERSION_GET(x) FIELD_GET(AM_MSG_VERSION_MASK, x) + +#define AM_MSG_INIT_MAKE(_id, _ack, _version) \ + ((_id) | FIELD_PREP(AM_MSG_ACK_MASK, _ack) | FIELD_PREP(AM_MSG_VERSION_MA= SK, _version)) + +#define ARB_VM_INIT_MAKE(_ack, _version) AM_MSG_INIT_MAKE(ARB_VM_INIT, _ac= k, _version) +#define VM_ARB_INIT_MAKE(_ack, _version) AM_MSG_INIT_MAKE(VM_ARB_INIT, _ac= k, _version) + +#define AM_MSG_DEFAULT_FIFO_SIZE 4 + +struct panthor_am_msg { + /** @iomem: CPU mapping of the AM_MESSAGE registers */ + void __iomem *iomem; + + /** @lock: Lock for send_fifo and outgoing message register */ + spinlock_t lock; + + /** @send_fifo: FIFO to queue of messages to send */ + DECLARE_KFIFO(send_fifo, u64, AM_MSG_DEFAULT_FIFO_SIZE); + + /** @version: Protocol version */ + u8 version; +}; + +static inline void panthor_am_msg_init(struct panthor_am_msg *msg, + void __iomem *iomem) +{ + spin_lock_init(&msg->lock); + INIT_KFIFO(msg->send_fifo); + msg->iomem =3D iomem; +} + +static inline bool panthor_am_msg_pending(struct panthor_am_msg *msg) +{ + return !!gpu_read(msg->iomem, AM_OUTGOING_MESSAGE_STATUS); +} + +static inline u64 panthor_am_msg_read(struct panthor_am_msg *msg) +{ + return gpu_read64(msg->iomem, AM_INCOMING_MESSAGE0); +} + +static inline void panthor_am_msg_write(struct panthor_am_msg *msg, u64 me= ssage) +{ + lockdep_assert_held(&msg->lock); + + /* + * Registers must be written in this exact order to prevent interrupts + * being raised before the complete message is written. + */ + gpu_write(msg->iomem, AM_OUTGOING_MESSAGE0, lower_32_bits(message)); + gpu_write(msg->iomem, AM_OUTGOING_MESSAGE1, upper_32_bits(message)); +} + +static inline int panthor_am_msg_retry(struct panthor_am_msg *msg) +{ + u64 message; + + guard(spinlock_irqsave)(&msg->lock); + + if (kfifo_is_empty(&msg->send_fifo)) + return 0; + + if (panthor_am_msg_pending(msg)) + return -EBUSY; + + /* FIFO should never be empty at this point */ + if (!kfifo_get(&msg->send_fifo, &message)) + return -EINVAL; + + panthor_am_msg_write(msg, message); + + /* There are still messages in the FIFO, notify caller to retry again */ + if (!kfifo_is_empty(&msg->send_fifo)) + return -EAGAIN; + + return 0; +} + +static inline int panthor_am_msg_send(struct panthor_am_msg *msg, u64 mess= age) +{ + guard(spinlock_irqsave)(&msg->lock); + + /* + * If there already is a pending message in the FIFO or the outgoing + * message is still not read by the receipient, add to the FIFO. + */ + if (!kfifo_is_empty(&msg->send_fifo) || panthor_am_msg_pending(msg)) { + if (!kfifo_put(&msg->send_fifo, message)) + return -ENOMEM; + + /* + * return -EBUSY to indicate to the caller to schedule work to + * retry sending messages in the FIFO. + */ + return -EBUSY; + } + + /* We are free to write to AM_OUTGOING_MESSAGE */ + panthor_am_msg_write(msg, message); + + return 0; +} + +static inline int panthor_am_msg_version_validate(struct panthor_am_msg *m= sg, + u8 version) +{ + if (version < AM_MSG_MIN_SUPPORTED_VERSION) { + msg->version =3D AM_MSG_MIN_SUPPORTED_VERSION; + return -EOPNOTSUPP; + } + + msg->version =3D min(version, AM_MSG_CURRENT_VERSION); + + return 0; +} + +#endif --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from AM0PR02CU008.outbound.protection.outlook.com (mail-westeuropeazon11013026.outbound.protection.outlook.com [52.101.72.26]) (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 0B3A8370D6B for ; Thu, 28 May 2026 15:07:20 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.72.26 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980844; cv=fail; b=piA3KVm2ISlXKza3431m9kLJID9xrUCKXQYlUI40zXmveZ/x/jSrdoH8FZi8UUeAV1xw03Mpu0Vt72nREzNkSVtK/rgadIMKdoiM8XrNNi2ELomk2KWdSRQC8bEyJ+XsKMtz+bMmViU0bhUaZOSAF5Y73Qmabw52TcQUROmTlik= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980844; c=relaxed/simple; bh=owpL5/5PlL55PA6B+pnZzSSTB3SkvEeyWT303DZm9aA=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=OJJJGnj+gzDU3c6nI8cqLEsjagdFv/tK6ur1UaX5A7Q3pSWzfYj/SUsPZAs5KqYtdiW+b2YvzVevY9DWgiQmZKuWo1tVnttrxRTQ3Zotn37twOV94AR7eAIvJPs8aQujShE8CScL/aJ6HxCCBTbzBC+f4FSygUdt4Rg5dm/PvFU= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=r/8WXy2t; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=r/8WXy2t; arc=fail smtp.client-ip=52.101.72.26 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="r/8WXy2t"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="r/8WXy2t" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=Aa4d6l6yRhI7ryldnykR7UjEKfL9yLKFJUK26LfNxS/CPyaJYPje3nJf/rB/UARjsZJDEbFMs64d5abSfJriOJIjV7jJvFTJRrIp/ImGr3Kc8W56DihdyVrBRS32gzVAWl2/Va9+4m+A3lIFg6lJw1CPFtswQXhziGg5//vOgwhlUFi0sTozzy4MRPOwB7DuLgI0aFH6V5UuJzxld18qbD9qlBioswB9LWg/C5nK6xepPpFLnhhoY/HOLlBhBfsohugMC/95crGeZ9fSDuQv9O7xUZoH/5RbY+WEwNG0Iovaz40y1Zvv58iQKD9zvsSC/mpcOOnZodMGYZq2iLHzHg== ARC-Message-Signature: i=2; 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=XIIgXhdn+z5O1hAbaPaHsxkD75dO4Et/9niSDGQcR4o=; b=xB683i8ncl62maN6tORs7mlhNWPaegBbog6n0djttYmWa5UF0/LFtH+9nB6Wv0IQvnCF+38875Mp8vw4jlyRrJraepLbakV9C3qOyuDPpr/NVkXv/Ko4TKX++S3GNgyvQurA4g4x+jWxUVkus4JHS+CwlnXE9P2WpsYVPVVDQUQE+4QPl/4B+RxOr41yKzWZbZ2eLiI0oXQwt+m0GKPkpgB3FcQo/lfKN24wm80e4LIKwt17P3VByT4fJni9Oh13LdGNirqqCjEKDTwyzkBueyk+2r8NPKHwmRKqfW9WUxKWRjbewXqs2lvmvp1Jveu0VHTXIQwGLAHf5fkpaJgAig== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=XIIgXhdn+z5O1hAbaPaHsxkD75dO4Et/9niSDGQcR4o=; b=r/8WXy2tBy8JMO4KhPpzkDg16Whdn4gGWlcg95B0n7JKpteptPe95pj75FMooiBsxV3Y3ESBkl7BLHvhketk9lVAdoZMhhZQVd6nf+Fp18ZxjcLCS2GBKWDoWJHg4aCQMVvicu1IuYPCAV6o37tPqgzvttSOVcERf0lpu8AQzBM= Received: from AS4PR10CA0019.EURPRD10.PROD.OUTLOOK.COM (2603:10a6:20b:5d8::19) by VI1PR08MB10242.eurprd08.prod.outlook.com (2603:10a6:800:1be::9) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.48.14; Thu, 28 May 2026 15:07:14 +0000 Received: from AMS1EPF00000042.eurprd04.prod.outlook.com (2603:10a6:20b:5d8:cafe::49) by AS4PR10CA0019.outlook.office365.com (2603:10a6:20b:5d8::19) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.13 via Frontend Transport; Thu, 28 May 2026 15:07:14 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by AMS1EPF00000042.mail.protection.outlook.com (10.167.16.39) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.7 via Frontend Transport; Thu, 28 May 2026 15:07:14 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=eVNq/U/Ka4xdZ0N8SjpGVJsPlNo7D2buTLb5czxT6rc5aBEV+b8jqCLVXr3QhK1/vh0YHkid7Ed+6FAYpMz8OBFiMbIEZLXXqqbwuxbRRVaCh+BTaFNtfmS7Uzsma4FPSA/S3t5Se3WKoNnUXjVm2b5yFA5quonkUGagS6+cr6ys6X6vwQxzaLScma0XNtB7KDoSVGRw4ggZgdMJ44R7UE5Db0sjivVeFD6vjNDdXFU7jMOaXpWeN8/GqrCE4olGu80+fCxm3GrLfFZTrao1I1OZ3H3yb5hBaulepyoiobSCqos7hCMgz7C/hkcF+ngunJWlgT0JKruJtsAh3eSd5w== 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=XIIgXhdn+z5O1hAbaPaHsxkD75dO4Et/9niSDGQcR4o=; b=K16iEtxc2/lYbGYUW39PvRR7NykmGngRi1OdtAOxQQDTtIxgfr3A9S7UqprDECwgSY06I016ImpZMjaXfnFXtEOxqRWdqD9jw8zMgWWpkENlU0vnIfk9qpcECSdF5xQhBWbIHRMEMBo3tIaHJcseN7fn0JVPUrbQliOPPORA4seZ1lymSzgr9nVVUunn/r1PgY9bYZu879K4ke+QLlsqEoPY5LT2uROsVOhcx1ixvTPLApNa1PP5pbDkuD6CCMAkLtbz1U/bsfNjApoNl9bf0/RGQeljeoHsaV2Nj1TGBGkTFYj1Y80ejH48V6NjZqHFX9e93fyTrLf66HquqzgyrQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=XIIgXhdn+z5O1hAbaPaHsxkD75dO4Et/9niSDGQcR4o=; b=r/8WXy2tBy8JMO4KhPpzkDg16Whdn4gGWlcg95B0n7JKpteptPe95pj75FMooiBsxV3Y3ESBkl7BLHvhketk9lVAdoZMhhZQVd6nf+Fp18ZxjcLCS2GBKWDoWJHg4aCQMVvicu1IuYPCAV6o37tPqgzvttSOVcERf0lpu8AQzBM= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:09 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:09 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 12/18] drm/panthor: Add AM_RESOURCE_GROUP support Date: Thu, 28 May 2026 16:05:40 +0100 Message-ID: <20260528150546.3168527-13-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: LO4P123CA0639.GBRP123.PROD.OUTLOOK.COM (2603:10a6:600:296::6) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|AMS1EPF00000042:EE_|VI1PR08MB10242:EE_ X-MS-Office365-Filtering-Correlation-Id: bf7f8bb2-e555-44a4-2393-08debccacd1c X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|22082099003|18002099003|3023799007|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: j6lDOHG1NCDSmTKKnK1mIlk9SuuOMDDPc5/xp+fI70BKEyUTCqSZxUPxszKHkxISOp6Mvk+kwvLzNR+rEHUb5tB97UZTKx6R3NqLpqV6kBPXbz+WTfcfFjmq9ftEPEALCC32e4NAbI8XAiKH1jNQvtKTcS1YfXGzJszKjPi/XL3VBqIEo6tbf63AlqaShj8Uzs3gvevcTkJ6DFCfurFBabn2RboMz4YBqMpPf38USZOHOsGvXGh09HM6/zvXuxoGTRn7CTOGxqM/42i5YVNX6K/IwEiH7fCXupVFXgpIrSF2xwZRX+jmTwIqywjt2pEXy7I8VNQOX0escPC51tXHCc72FJFeSVG6ROgcFGmkVCrrxhPP8YXSortt835HCwKI1C5E/40OnsNTuG40kCDFduYYId5zU6KYqTiGrG4E9z8rN8jaEb7pLO4sKTXFUDXB3pQvVpbdEdwCqc9we+rL6yOiMtsOB9L/Iqioeq7pLLzc8o+n+D0yt7znfzsjrVyDhMF2ZNIuc7OpfoQhjklKeeQ9xUrrGyrYUsa0QDnmdW/j4wayGu74cQY33fSckrU+PifCH0X/nxiWMEPJuUAaFT4Hqaxhp4PQyZpXqLIhydPXJEWSf9WHpZ+1xRkeeDnvIroZm6p+6F0zpT3eSv4TZZDCnpfKybtyv6eHL7lvLaFj64XSAmpIL1JP3YSeE9nq X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(22082099003)(18002099003)(3023799007)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: rri8Q+dOagj87b2T6lQ07VJ5UkaMrz7umJ71hvpUK0atuM8tx7fDcqyTQpsni0U90qh/rWfNMH93v65PfdEsza5nf+3jmG0BuJiPFPLp2/LrlG9LVLilProAd3zgesJrPJlKl+BLonlNIjVVVE3P1/d0fuplFJZzEXiUGbPNzRZk21aZohvnjMMDIyu/p4lg5oRucZ675zeWPQv3iLTazk8GC6DsLY8MzcO9/k6uvDHnJxSc7ct7bx+MAOtIQvqAnht6y+qxPsxBczr84reSKAu0R1Uvb1ZaUtrN9LBTaOPixq/ApRrh84nQuNYT1tR/RPpd+c6tdcRgjwHl332Dxw== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: AMS1EPF00000042.eurprd04.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: 53f8eedf-eda4-416c-4fdf-08debccaa696 X-Microsoft-Antispam: BCL:0;ARA:13230040|35042699022|82310400026|1800799024|14060799003|36860700016|376014|56012099006|22082099003|11063799006|3023799007|18002099003; X-Microsoft-Antispam-Message-Info: bXWQtvGB0QnY6QGBKGamsJnYrJnPqFGZLVuL3AOzQ7svVnmqjSLSlmHMLAgCfljR+ih+Ixn7Zg1YE7krYiFMsQAt6rR23EDU2Wq4jJu4jM++SQD9HLDiVGG7DND7hEFwH/oNafFCQyTUAGkKFp/s3jq7adJZgAsaYQFZdDC8K+OVw1Ev+yzjJnaKMEX3QlNsVUyrf6+o/z8LjIUeKp2KzjWFM6qkcHDwSizgQBeWcuL6A1huOAlFwnLem++LqPBz//L59aQH0gMoHRhhVlxcJpIhKBW/J/hFfJzIph6TJYNqPwqhQC3UMBkRw+94JRlk4ueEZGRhH6DPL6lauWEEs9CgcZahYhoQqBhsuKoxYrcXe0xhMAiyuB6cBO/w+dUod9MzlWP51whWSfC56iShOuAhnopr5NBQt+jrJ4tFLrYbYN8ijJ+lRQBRZIFDtMirdagFDjdvC6OO6TXGzYgsO+w4w2VRbh1EerddNS8ZUmUdIbua1BKXn+D7ITrsE/2Z0/vFCcZa9MzajSWAqJkcpj9NICjyIbwqb2iRBdboTk3u7HnsiQsVgkJ3U6bN6MNUtcfUGg3XhicO56RwT7r84GTzByyJkvuDDpmn5dkMtMP0P7Ha1kXB3VjE//5kFFHNWUQBdpNeAgIpZmfY2HMJsaUg82qISxBUgQOCg3tm3jb6WRWxP7CUiglM+fv5OBSMPS1LGIhF/1fyZBpulWCXs/0bQf+iZ84i2A1h2Tztza0= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(35042699022)(82310400026)(1800799024)(14060799003)(36860700016)(376014)(56012099006)(22082099003)(11063799006)(3023799007)(18002099003);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: f8jMaRMLJiG564kNI5x4eW6C5ZMKHZbWjxikVbzQuDyjhIufHRdpMx2KmzCGmMM1T8lO/hvjq9nByf1ekGFKQG8f8xWC1UWwgn2flK/fyHhx/haAo7FtcNEsSmAUE5fBF/LbFWhBakh3tObcOaOCP/s4D8cIvu+gUnrvQUnJ4U+fTlB4hW6TyA2B7YM0XyjTd4/IK11n0a0x4oKJrLFz9PHAw2VU5/oYKIjvlWpnnE3MM6g1ld0s1UryVz59FHzr+LvGBNqnUbyePaBsjOsBzpJIeQNV6SXQRd8OgPHhPWWVtZbyBQ1Dj4IAWCZcucFqgaCai5kNm5QTvl2DgVPrQhtukg3DsQ7sDsUxZkfEyX6HyY7121UWi6+aP6ke5im7wmD+Ryx2KP6oMOpqWUQr15Zg0V7fduKM9qnz+KqyhDafOX6OGqhCyDS9+QV4IfAI X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:14.2769 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: bf7f8bb2-e555-44a4-2393-08debccacd1c X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: AMS1EPF00000042.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR08MB10242 Content-Type: text/plain; charset="utf-8" Add resource-group probing for the arbitration device, including MMIO resources, IRQ handling, per-AW AM message helpers, handshake negotiation, and retry work for deferred outgoing messages. Hook resource groups into arbitration init, teardown, and runtime PM. Signed-off-by: Karunika Choo --- drivers/gpu/drm/panthor/arbitration/Makefile | 3 +- .../panthor/arbitration/panthor_arbitration.h | 5 + .../arbitration/panthor_arbitration_drv.c | 17 ++ .../arbitration/panthor_resource_group.c | 288 ++++++++++++++++++ .../arbitration/panthor_resource_group.h | 20 ++ 5 files changed, 332 insertions(+), 1 deletion(-) create mode 100644 drivers/gpu/drm/panthor/arbitration/panthor_resource_gr= oup.c create mode 100644 drivers/gpu/drm/panthor/arbitration/panthor_resource_gr= oup.h diff --git a/drivers/gpu/drm/panthor/arbitration/Makefile b/drivers/gpu/drm= /panthor/arbitration/Makefile index 5d5b2b8d84bc..0ea5b70d524a 100644 --- a/drivers/gpu/drm/panthor/arbitration/Makefile +++ b/drivers/gpu/drm/panthor/arbitration/Makefile @@ -4,7 +4,8 @@ obj-$(CONFIG_DRM_PANTHOR_ARBITRATION) +=3D panthor_arbitration.o panthor_arbitration-y :=3D \ panthor_arbitration_drv.o \ - panthor_partition_control.o + panthor_partition_control.o \ + panthor_resource_group.o =20 INCLUDES =3D \ -I$(src)/.. diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration.h b/dr= ivers/gpu/drm/panthor/arbitration/panthor_arbitration.h index 5e35ae8463c4..38c8f8674a02 100644 --- a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration.h +++ b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration.h @@ -6,8 +6,10 @@ =20 struct device; struct panthor_partition_control; +struct panthor_resource_group; =20 #define AM_ARB_MAX_PC_COUNT 1 +#define AM_ARB_MAX_RG_COUNT 1 #define AM_ARB_MAX_AW_COUNT 16 =20 /** @@ -19,6 +21,9 @@ struct panthor_arbitration { =20 /** @pc: Pointer array to partition control data */ struct panthor_partition_control *pc[AM_ARB_MAX_PC_COUNT]; + + /** @rg: Pointer array to resource group data */ + struct panthor_resource_group *rg[AM_ARB_MAX_RG_COUNT]; }; =20 #endif diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c = b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c index 07a566168e6a..ac395b89b483 100644 --- a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c +++ b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c @@ -10,6 +10,7 @@ =20 #include "panthor_arbitration.h" #include "panthor_partition_control.h" +#include "panthor_resource_group.h" =20 #define PANTHOR_PM_AUTOSUSPEND_DELAY_MS 100 =20 @@ -22,6 +23,10 @@ static int panthor_arbitration_runtime_suspend(struct de= vice *dev) if (ret) return ret; =20 + ret =3D panthor_resource_group_suspend(adev); + if (ret) + return ret; + return 0; } =20 @@ -30,6 +35,10 @@ static int panthor_arbitration_runtime_resume(struct dev= ice *dev) struct panthor_arbitration *adev =3D dev_get_drvdata(dev); int ret =3D 0; =20 + ret =3D panthor_resource_group_resume(adev); + if (ret) + return ret; + ret =3D panthor_partition_control_resume(adev); if (ret) return ret; @@ -66,6 +75,10 @@ static int panthor_arbitration_probe(struct platform_dev= ice *pdev) if (ret) goto err_out; =20 + ret =3D panthor_resource_group_init(adev); + if (ret) + goto err_term_partition; + pm_runtime_set_autosuspend_delay(dev, PANTHOR_PM_AUTOSUSPEND_DELAY_MS); pm_runtime_use_autosuspend(dev); =20 @@ -73,6 +86,9 @@ static int panthor_arbitration_probe(struct platform_devi= ce *pdev) =20 return 0; =20 +err_term_partition: + panthor_partition_control_term(adev); + err_out: pm_runtime_put_noidle(dev); return ret; @@ -90,6 +106,7 @@ static void panthor_arbitration_remove(struct platform_d= evice *pdev) if (ret < 0) goto out_suspended; =20 + panthor_resource_group_term(adev); panthor_partition_control_term(adev); =20 pm_runtime_put_noidle(adev->dev); diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_resource_group.c b= /drivers/gpu/drm/panthor/arbitration/panthor_resource_group.c new file mode 100644 index 000000000000..cd1ad0532766 --- /dev/null +++ b/drivers/gpu/drm/panthor/arbitration/panthor_resource_group.c @@ -0,0 +1,288 @@ +// SPDX-License-Identifier: GPL-2.0 or MIT +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#include +#include +#include +#include + +#include "panthor_am_msg.h" +#include "panthor_arbitration.h" +#include "panthor_device_io.h" +#include "panthor_resource_group.h" + +#define AM_RG_IRQ_RAWSTAT 0x80 +#define AM_RG_IRQ_CLEAR 0x84 +#define AM_RG_IRQ_MASK 0x88 +#define AM_RG_IRQ_STATUS 0x8C +#define AM_RG_MESSAGE_MASK GENMASK(15, 0) + +#define AM_RG_AW_MESSAGE(n) (0x100 + (n) * 0x20) + +struct rg_aw_data { + /** @msg: Messaging data */ + struct panthor_am_msg msg; +}; + +struct panthor_resource_group { + /** @dev: Device pointer */ + struct device *dev; + + /** @name: Resource name */ + char *name; + + /** @iomem: CPU mapping of the partition control IOMEM region */ + void __iomem *iomem; + + /** @irq: IRQ number */ + int irq; + + /** @aw_data: Data for each access window */ + struct rg_aw_data aw_data[AM_ARB_MAX_AW_COUNT]; + + /** @wq: Resource group workqueue */ + struct workqueue_struct *wq; + + /** @msg_retry_work: Work to retry sending pending messages */ + struct work_struct msg_retry_work; +}; + +static void rg_retry_messages(struct work_struct *work) +{ + struct panthor_resource_group *rg =3D container_of( + work, struct panthor_resource_group, msg_retry_work); + bool retry =3D false; + + for (u8 aw_id =3D 0; aw_id < AM_ARB_MAX_AW_COUNT; aw_id++) { + struct panthor_am_msg *msg =3D &rg->aw_data[aw_id].msg; + int ret; + + ret =3D panthor_am_msg_retry(msg); + if (ret =3D=3D -EBUSY || ret =3D=3D -EAGAIN) + retry =3D true; + + if (ret =3D=3D -EINVAL) + dev_warn(rg->dev, "AW%u send FIFO unexpectedy empty", aw_id); + } + + if (retry) + queue_work(rg->wq, &rg->msg_retry_work); +} + +static void rg_send_msg(struct panthor_resource_group *rg, u8 aw_id, + u64 message) +{ + int ret; + + ret =3D panthor_am_msg_send(&rg->aw_data[aw_id].msg, message); + if (ret =3D=3D -ENOMEM) + dev_err(rg->dev, "AW%u send FIFO is full", aw_id); + + if (ret =3D=3D -EBUSY) { + dev_dbg(rg->dev, "AW%u has pending messages, scheduling retry work", aw_= id); + queue_work(rg->wq, &rg->msg_retry_work); + } +} + +static void rg_respond_to_handshake(struct panthor_resource_group *rg, + u8 aw_id, u64 message) +{ + struct rg_aw_data *aw_data =3D &rg->aw_data[aw_id]; + bool acked =3D AM_MSG_ACK_GET(message); + u8 version =3D AM_MSG_VERSION_GET(message); + int ret; + + ret =3D panthor_am_msg_version_validate(&aw_data->msg, version); + if (ret =3D=3D -EOPNOTSUPP) + dev_warn(rg->dev, + "AW%u protocol version less than minimum supported (%u < %u)", + aw_id, version, AM_MSG_MIN_SUPPORTED_VERSION); + + if (!acked) { + /* AW initiated the handshake, reply with supported version */ + u64 reply =3D ARB_VM_INIT_MAKE(1, aw_data->msg.version); + + rg_send_msg(rg, aw_id, reply); + } +} + +static void rg_handshake_init(struct panthor_resource_group *rg) +{ + for (u8 aw_id =3D 0; aw_id < AM_ARB_MAX_AW_COUNT; aw_id++) { + u64 message =3D ARB_VM_INIT_MAKE(0, AM_MSG_CURRENT_VERSION); + + rg_send_msg(rg, aw_id, message); + } +} + +static void rg_handle_message(struct panthor_resource_group *rg, u8 aw_id, + u64 message) +{ + u8 msg_id =3D AM_MSG_ID_GET(message); + if (!msg_id) + return; + + switch (msg_id) { + case VM_ARB_INIT: + rg_respond_to_handshake(rg, aw_id, message); + break; + case VM_ARB_GPU_REQUEST: + /* TODO: on_request */ + break; + case VM_ARB_GPU_STOPPED: + /* TODO: on_idle */ + break; + default: + dev_warn(rg->dev, "Invalid message (0x%llx)", message); + break; + } +} + +static irqreturn_t rg_irq_raw_handler(int irq, void *data) +{ + struct panthor_resource_group *rg =3D data; + unsigned long message_mask; + u32 status; + u8 aw_id; + + status =3D gpu_read(rg->iomem, AM_RG_IRQ_STATUS); + if (!status) + return IRQ_NONE; + + message_mask =3D status; + for_each_set_bit(aw_id, &message_mask, AM_ARB_MAX_AW_COUNT) { + u64 message =3D panthor_am_msg_read(&rg->aw_data[aw_id].msg); + + rg_handle_message(rg, aw_id, message); + } + + gpu_write(rg->iomem, AM_RG_IRQ_CLEAR, status); + + return IRQ_HANDLED; +} + +static void rg_irq_suspend(struct panthor_resource_group *rg) +{ + gpu_write(rg->iomem, AM_RG_IRQ_MASK, 0); +} + +static void rg_irq_resume(struct panthor_resource_group *rg) +{ + gpu_write(rg->iomem, AM_RG_IRQ_MASK, AM_RG_MESSAGE_MASK); +} + +int panthor_resource_group_suspend(struct panthor_arbitration *adev) +{ + for (int i =3D 0; i < AM_ARB_MAX_RG_COUNT; i++) { + struct panthor_resource_group *rg =3D adev->rg[i]; + + if (!rg) + continue; + + rg_irq_suspend(rg); + } + + return 0; +} + +int panthor_resource_group_resume(struct panthor_arbitration *adev) +{ + for (int i =3D 0; i < AM_ARB_MAX_RG_COUNT; i++) { + struct panthor_resource_group *rg =3D adev->rg[i]; + + if (!rg) + continue; + + rg_irq_resume(rg); + } + + return 0; +} + +void panthor_resource_group_term(struct panthor_arbitration *adev) +{ + for (int i =3D 0; i < AM_ARB_MAX_RG_COUNT; i++) { + struct panthor_resource_group *rg =3D adev->rg[i]; + + if (!rg) + continue; + + disable_work_sync(&rg->msg_retry_work); + rg_irq_suspend(rg); + } +} + +static int resource_group_init(struct panthor_arbitration *adev, int i) +{ + struct device *dev =3D adev->dev; + struct platform_device *pdev =3D to_platform_device(dev); + struct panthor_resource_group *rg; + struct resource *res; + void __iomem *iomem; + char *name; + int ret =3D 0; + int irq; + + name =3D devm_kasprintf(dev, GFP_KERNEL, "rg%d", i); + + res =3D platform_get_resource_byname(pdev, IORESOURCE_MEM, name); + if (!res) { + devm_kfree(dev, name); + return -ENODEV; + } + + iomem =3D devm_ioremap_resource(dev, res); + if (IS_ERR(iomem)) { + dev_err(dev, "%s: Failed to ioremap", name); + return PTR_ERR(iomem); + } + + rg =3D devm_kzalloc(dev, sizeof(*rg), GFP_KERNEL); + if (!rg) + return -ENOMEM; + + rg->dev =3D dev; + rg->iomem =3D iomem; + + rg->wq =3D devm_alloc_ordered_workqueue(dev, "panthor-%s-wq", 0, name); + if (!rg->wq) + return -ENOMEM; + + INIT_WORK(&rg->msg_retry_work, rg_retry_messages); + + for (int i =3D 0; i < AM_ARB_MAX_AW_COUNT; i++) + panthor_am_msg_init(&rg->aw_data[i].msg, + rg->iomem + AM_RG_AW_MESSAGE(i)); + + adev->rg[i] =3D rg; + + irq =3D platform_get_irq_byname(pdev, name); + if (irq < 0) + return irq; + + ret =3D devm_request_irq( + dev, irq, rg_irq_raw_handler, IRQF_SHARED, + devm_kasprintf(dev, GFP_KERNEL, "panthor-%s-irq", name), rg); + if (ret) + return ret; + + rg_irq_resume(rg); + + rg_handshake_init(rg); + + return 0; +} + +int panthor_resource_group_init(struct panthor_arbitration *adev) +{ + for (int i =3D 0; i < AM_ARB_MAX_RG_COUNT; i++) { + int ret =3D resource_group_init(adev, i); + if (ret =3D=3D -ENODEV) + continue; + + if (ret) + return ret; + } + + return 0; +} diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_resource_group.h b= /drivers/gpu/drm/panthor/arbitration/panthor_resource_group.h new file mode 100644 index 000000000000..b8633abdd8eb --- /dev/null +++ b/drivers/gpu/drm/panthor/arbitration/panthor_resource_group.h @@ -0,0 +1,20 @@ +/* SPDX-License-Identifier: GPL-2.0 or MIT */ +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#ifndef __PANTHOR_RESOURCE_GROUP_H__ +#define __PANTHOR_RESOURCE_GROUP_H__ + +#include + +struct device; +struct panthor_arbitration; + +int panthor_resource_group_init(struct panthor_arbitration *adev); + +void panthor_resource_group_term(struct panthor_arbitration *adev); + +int panthor_resource_group_suspend(struct panthor_arbitration *adev); + +int panthor_resource_group_resume(struct panthor_arbitration *adev); + +#endif --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from AM0PR83CU005.outbound.protection.outlook.com (mail-westeuropeazon11010058.outbound.protection.outlook.com [52.101.69.58]) (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 959BE3F8EDC for ; Thu, 28 May 2026 15:07:19 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.69.58 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980843; cv=fail; b=UXXljzXo1EP5LYZ7lAGZTYBUzVua3tXPpnTDzxdTKtQy4kyoEzziKvz2agzDlZHOXIdBxjIY2f1Rhpu0lp9Yo3Ufqx26ZIaE2lcvTQUXRgbbZdilFUMOPaJfAgboLsvgYn+lQhmOpWe0I1gOdrZ/J8zubXrjPM91S0Z/N7IlEfg= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980843; c=relaxed/simple; bh=YM9MwbGmMyZeZg7f8g2Atotbql3QPeoxtdzSBW4VkmU=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=gX5lqd8F4C9pJjlX841kBMAc3+o5VFuq0W8MIP1KytASH8f0xn1bioObkug2/2rYTqJNfg+/nTfcAptTCFuQav2t1zkINMQdHKITPWSzfIWvifPn77nATQHWAld0LjOiKUcqMDKZbv9iEcvvsTsJ5lIj4VT9/l6F9shQlU8eWog= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=T+FdPUkC; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=T+FdPUkC; arc=fail smtp.client-ip=52.101.69.58 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="T+FdPUkC"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="T+FdPUkC" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=fjnQmSyOLAM8p2ODHj9ku1lwk/OV1nbiLnH8QoTN9KQZ+BbF5PMyxybLeyvQwbjl1APN+TkYfS+TdR3BQfbLQT9rpYu+A678G6Zsul8IIMQpwYwqWIdXQS8vPbD9x06GlFzhmU1cFY06wKl57Fr16NS4uenXBner6NPJKHttzQuP8KKWLfF1iBlgj5ShjLzGgOBjnKJEvZHSn5P+s01f6zGJG1IJNeROnIPG4esa95Aim7JQ6tzrufRhcgMqd/doMvGtUiL2wJ9Dv5wKOI/5piKrSMq9RfIOTv1O7Vbqh/vhXGmh+e+dv/fgvcL/puMoBIYPg1o6l1ot7fCjhSa6CQ== ARC-Message-Signature: i=2; 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=cv06PwZpcdOvWwvgaOF4y1FMW1A65mXUf2yzjRjiQZQ=; b=V72vryUb4BEXTEh4mqjmNYvkTgfuB0A623dgTTE9YLvQkoqO5POCI1uqBjuMaEwDxmR2+ZpF7gEneJkBaDwJ3twRSyBqmg56/FSDlgxfQHHgLUMe6/UqVOyvxs/psHxuvOQSWrNReEKUEnFmqD5Zvjz8FP6S2N1l5ybUjlsEDpUJwiPT3SqsYSB53CDSnaJGG1Hb8EsCkv+cWFZ8GCxJ7jQa6tX/fgpijXyHeffBsWhYjyfsahee5pTOs47vfZmMBWBykKtHwEm6iOxGpTddRPk6HgRvoutjwzn4mQuC7E53IV6oe/L++mLO2AFsUNY1xKbMe5tVFZ2RFueJov5BkA== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=cv06PwZpcdOvWwvgaOF4y1FMW1A65mXUf2yzjRjiQZQ=; b=T+FdPUkCsmSi17IzS3R1JuHa7U8UuU2cItdjQwE94vLGjivk9dpxFroWYUfkvv4xXWDJKfs/OMEaiR6gPQTwnezhuKRCV2+4YgKdeQWdoH8n28IO39dNEewBOzbWl3e6wDShr0lgqe2eQEJRfz9ZlKIrRcI667MqV02RAJzK8qA= Received: from AS4P192CA0042.EURP192.PROD.OUTLOOK.COM (2603:10a6:20b:658::21) by FRZPR08MB11902.eurprd08.prod.outlook.com (2603:10a6:d10:1c9::23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.12; Thu, 28 May 2026 15:07:16 +0000 Received: from AM3PEPF0000A78F.eurprd04.prod.outlook.com (2603:10a6:20b:658:cafe::5b) by AS4P192CA0042.outlook.office365.com (2603:10a6:20b:658::21) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.13 via Frontend Transport; Thu, 28 May 2026 15:07:16 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by AM3PEPF0000A78F.mail.protection.outlook.com (10.167.16.118) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.7 via Frontend Transport; Thu, 28 May 2026 15:07:16 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=gMSDnJjLlriPjXOGGjMPfAmwVCwQckkwsLSjdYfcJIdgw9xtUhWzJ+lwoWSBSux9KlcyNXOu1O6TmJ5gM/hG3JTY3k1h+8VZRfRxBk7f0qMqX6EsApUh94OFhn7MAISf5dHwx0QdZh81OhABhfKTgOeZ+TfuMsvO1Tc6mdRLvEeeC3aLkt6hvcY1Zudlp3wIV6w4ZEOQlPz3T2L+ZQ7W33YpkMjxAoiMRgm6hEGN5Q3cftyjt3UW+rDk3Pwj+fAI/RtsBbCVvt9jjRPzrJxgsXzdPDXiIzVrwPJWeAN8mhGtYDE8VVj8ZdSxhob06CayVzfj9tG4LWEvACIAk0+08Q== 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=cv06PwZpcdOvWwvgaOF4y1FMW1A65mXUf2yzjRjiQZQ=; b=gxcyWHM2Pmp3YC62pQgQpTPQ/DTpIMgVkrvMkZJOQ+qeiYxpslcPH5c2ScrYl5A/qjoOr6/YlRxKZYQGHBx/n1pjSPMC6CsUsszUgn4y7vk0phvZsA3AK56dA4p1H4qyXMLeHg0WJIH6pIrscp/o1inls0SDWdrJoweYOoEV1ZG2p4C2IWW61zWsWEhH9hreD0EOe8I/ssPmzxBGZCZLRmANM/iP9zB8WZs/J4OG0TQuW//job04y+iJ92K12HcxJZbs8pp6sIhsQXJk6q7DGLyt1hIA+K6ilmrnfmIJ1HRz0Sj6fOCOrXlWSbH5Z221nGj81gVBCcWNTi1sYOSfRQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=cv06PwZpcdOvWwvgaOF4y1FMW1A65mXUf2yzjRjiQZQ=; b=T+FdPUkCsmSi17IzS3R1JuHa7U8UuU2cItdjQwE94vLGjivk9dpxFroWYUfkvv4xXWDJKfs/OMEaiR6gPQTwnezhuKRCV2+4YgKdeQWdoH8n28IO39dNEewBOzbWl3e6wDShr0lgqe2eQEJRfz9ZlKIrRcI667MqV02RAJzK8qA= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:11 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:11 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 13/18] drm/panthor: Add arbitration scheduler Date: Thu, 28 May 2026 16:05:41 +0100 Message-ID: <20260528150546.3168527-14-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: LO4P265CA0217.GBRP265.PROD.OUTLOOK.COM (2603:10a6:600:33a::14) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|AM3PEPF0000A78F:EE_|FRZPR08MB11902:EE_ X-MS-Office365-Filtering-Correlation-Id: 655c554e-15b0-4794-e147-08debccace45 X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|6133799003|22082099003|18002099003|3023799007|56012099006|5023799004|11063799006; X-Microsoft-Antispam-Message-Info-Original: /lPowMs+jk98GxZESe0kmfkkOOCzghNsSnU3CvLj8mOAMVhsr7rbW/J0HFAMwzKg1h8FTNsyar4iBKWaJmhFRDGREd1WFPz4ZCHXCWPrCuqby1qSmJC7uq9/sfnWtmJHmb5efMrbEz3Adagss6i6Rullpcom17wHYcZRRcKkpB3k+uhsBbW8yMZA3fD6NOKSBtkEeH+pYgi6I8r+kehHkR5nFZPCpZPWdNARCGLAUzK1Y0066pOWgaMqR/HwERNw7XNOUm/ElNnnpYryhbuTVKZc7jdI3wqUP60P+AWjw9pUXlHd/cvyjFBcs/KI/0mIPMMcw+yBSTqPiHcgcIc+H5jcN6QcX/+ByGSEOwIjtHXeZ65zmcZxI3j4btkjQreNzLht7pwqtKQM1w1JctoEo4qJrQ71w8+HIBzhAgYfc4S4pnKj6MjsSB+qzBPnGno5sZmX6ms7VrqvZe45Lz1q9lAxuEwZ9H1OSQcN8kv7qpvGBwu9STuPvL2wkU5kYucfXe3BsGmvZvp3vv11lD8EQArq/gJinGuEmLQCMEJ6zOazJkF/dY+PP6Hy5kLSZZBMNIbPmX90nzaZ1Vsg5PIJOyCu9+oyBN6GOu00eDihV2yL4IOAvq8Kg2kDbbCT6+UuFKTen85hr7vUigoxE4n9u1d+esVzwFEy6n5tJbNJwfkATr4pKQOg1oaMfPC9Dklu X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(6133799003)(22082099003)(18002099003)(3023799007)(56012099006)(5023799004)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: op/0YrdHOXxHS+3Vc/8HIBpemMXJimvgzqO5+CUv9MaWiYh24HPd9zcmnFxRtjgHX3wUs5h9FCvjH4zXc7DimHifRkIlG6JlaSr6ZsVFSFlGz50OnEZoLDOa1Gbsw13xE3+XKouiX+8m6H/5vibaa01bNWvXQdebj6LPkA0eT9fW9qiscfAxjgy64anv1Po+htGwXawmXkUFnapspz1VFccRAIJqEfl9wvF5oNeEbtCI0Ykfzh3t65j4E5N9EvSlBVmAF4x39DUxeSFe2GNpjBlkhpeeeNQ8QdYhkiZ7r4K6ZkQOuC0wABK08h15Eg99HgcRmm6bMG9px3FWT/B+NA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: AM3PEPF0000A78F.eurprd04.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: 14d81013-4ce8-4e0f-b77e-08debccaa76f X-Microsoft-Antispam: BCL:0;ARA:13230040|82310400026|36860700016|35042699022|14060799003|376014|1800799024|6133799003|5023799004|11063799006|3023799007|22082099003|18002099003|56012099006; X-Microsoft-Antispam-Message-Info: sgW7J/kTrsAzdstt2ShcGkbT03NfWu4nNr8NKCp+37l6gQZZxr85mkAG8Gr7OTft6YcsrT+0v8QWXzh2MfJf1Tq5riXJmHPdf8NWjdj0dfl64o0OVb/u2lbq+kmXoaUkeVIb8J+chtKAd9SOYbK5Su0ydvP6PKzEZ1htNYcR4Xa+Qq421ow7PAnKSe7B4FYTpQGy9RU+NbUHodn/JtSW/q0hQQzbmFrdqWMqddO2kOhhvVxYcOnJ0JtQY3K/NWLNGgGpaeoDkcJcNefVdR4dCe+gy0FChyQ3uvIkvjSk6QrHUPFqpXCVqMJQLhZFHL7XBss4d3bJeM7woneJ/YTDiwCQ07HGk8dJBt+bEj3+pZjpeiBIYzkajVDZ3fHd6DNRyjWsBwkq2DMAThY7SOWA/tDYLjb8R/2dOUn3SNeqo514jOM+zHSjTJD9tjq2t6RFO0y3pF19sgyVXnGA6YOmzmzzDMMCmOzaWVwGzo0AclqEmwFMuV53hDq/hdlBskGhAvmR4SQUXz6SIPcxYb2J5KbPBZD7iezzcSEF9Fnen92ltAneDXy8+g9sCpcHQygIgza7EKueFKjaS9JXIGaegxbm+oH1URcuHbzJtCXG/9WXRlQ9SWvGy+5F2PSz+5ta9B0FM6da/y/N+DGpkj/sPJmVMs54ztA+2zwDJ0B3agcM2kWHL+noEzNR+WStym13pgaCb20+zTWupdwy2LbnAJij5L7be1CdPBXq02vtXxc= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(82310400026)(36860700016)(35042699022)(14060799003)(376014)(1800799024)(6133799003)(5023799004)(11063799006)(3023799007)(22082099003)(18002099003)(56012099006);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: A5f18iaG75S35sgIsaTJ1IBau+SsuN4p3ft/7bzf6ac3jCh2EQUNCsBmhPDuMxdyYpiyTAKiC1FvhNutVsURGReKMLcXpveY0tlpWlo5JD3Wm+QHfZOSctD88FzMXwfM9kwcoE98xOssn8yMEVyEbSrzC8tMQL+kq+RekmS0CAUZD3V+XysupKTWOGnX7xWrkD4FelOW/RhiNBrBU0VW79YvD2X23f87ctzlvCZ9gSkzpFNF0JMekfvizR4p3JNXv6HXXYfxnRkPPraNI4a9Kf6YYohy/SZyOL8K37ZdMbXHkZEGTLtyxJfIcZ1qHiAd84rBWkwlCJYbQZFgS98SsVoFP5MTDhfQ1N6j/M9+ji3cKaqWA6ynu3Ofa3n6EdgxpKRhITnB2PI6+UZyHlBWeoIyFlrakrG6quyyo+vDA2DrTTXWaLWQzRXE5ErWvARc X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:16.2296 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 655c554e-15b0-4794-e147-08debccace45 X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: AM3PEPF0000A78F.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: FRZPR08MB11902 Content-Type: text/plain; charset="utf-8" Add a per-partition arbitration scheduler that queues access-window GPU requests, grants the active window, asks it to stop when its lease expires, and force-closes it if it does not yield in time. Use ordered workqueues and hrtimers for grant/stop sequencing, with module parameters controlling grant and yield timeouts. Signed-off-by: Karunika Choo --- drivers/gpu/drm/panthor/arbitration/Makefile | 1 + .../panthor/arbitration/panthor_arbitration.h | 4 + .../arbitration/panthor_arbitration_drv.c | 17 + .../arbitration/panthor_arbitration_sched.c | 692 ++++++++++++++++++ .../arbitration/panthor_arbitration_sched.h | 25 + 5 files changed, 739 insertions(+) create mode 100644 drivers/gpu/drm/panthor/arbitration/panthor_arbitration= _sched.c create mode 100644 drivers/gpu/drm/panthor/arbitration/panthor_arbitration= _sched.h diff --git a/drivers/gpu/drm/panthor/arbitration/Makefile b/drivers/gpu/drm= /panthor/arbitration/Makefile index 0ea5b70d524a..83be25341ba0 100644 --- a/drivers/gpu/drm/panthor/arbitration/Makefile +++ b/drivers/gpu/drm/panthor/arbitration/Makefile @@ -4,6 +4,7 @@ obj-$(CONFIG_DRM_PANTHOR_ARBITRATION) +=3D panthor_arbitration.o panthor_arbitration-y :=3D \ panthor_arbitration_drv.o \ + panthor_arbitration_sched.o \ panthor_partition_control.o \ panthor_resource_group.o =20 diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration.h b/dr= ivers/gpu/drm/panthor/arbitration/panthor_arbitration.h index 38c8f8674a02..0bc683e6a71d 100644 --- a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration.h +++ b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration.h @@ -5,6 +5,7 @@ #define __PANTHOR_ARBITRATION_H__ =20 struct device; +struct panthor_arbitration_sched; struct panthor_partition_control; struct panthor_resource_group; =20 @@ -24,6 +25,9 @@ struct panthor_arbitration { =20 /** @rg: Pointer array to resource group data */ struct panthor_resource_group *rg[AM_ARB_MAX_RG_COUNT]; + + /** @shed: Pointer to scheduler data. 1 sched per partition */ + struct panthor_arbitration_sched *sched[AM_ARB_MAX_PC_COUNT]; }; =20 #endif diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c = b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c index ac395b89b483..5cdefd9ed5c9 100644 --- a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c +++ b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c @@ -9,6 +9,7 @@ #include =20 #include "panthor_arbitration.h" +#include "panthor_arbitration_sched.h" #include "panthor_partition_control.h" #include "panthor_resource_group.h" =20 @@ -19,6 +20,10 @@ static int panthor_arbitration_runtime_suspend(struct de= vice *dev) struct panthor_arbitration *adev =3D dev_get_drvdata(dev); int ret =3D 0; =20 + ret =3D panthor_arbitration_sched_suspend(adev); + if (ret) + return ret; + ret =3D panthor_partition_control_suspend(adev); if (ret) return ret; @@ -43,6 +48,10 @@ static int panthor_arbitration_runtime_resume(struct dev= ice *dev) if (ret) return ret; =20 + ret =3D panthor_arbitration_sched_resume(adev); + if (ret) + return ret; + return 0; } =20 @@ -79,6 +88,10 @@ static int panthor_arbitration_probe(struct platform_dev= ice *pdev) if (ret) goto err_term_partition; =20 + ret =3D panthor_arbitration_sched_init(adev); + if (ret) + goto err_term_resgroup; + pm_runtime_set_autosuspend_delay(dev, PANTHOR_PM_AUTOSUSPEND_DELAY_MS); pm_runtime_use_autosuspend(dev); =20 @@ -86,6 +99,9 @@ static int panthor_arbitration_probe(struct platform_devi= ce *pdev) =20 return 0; =20 +err_term_resgroup: + panthor_resource_group_term(adev); + err_term_partition: panthor_partition_control_term(adev); =20 @@ -106,6 +122,7 @@ static void panthor_arbitration_remove(struct platform_= device *pdev) if (ret < 0) goto out_suspended; =20 + panthor_arbitration_sched_term(adev); panthor_resource_group_term(adev); panthor_partition_control_term(adev); =20 diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_sched.= c b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_sched.c new file mode 100644 index 000000000000..a6c5efee7b8d --- /dev/null +++ b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_sched.c @@ -0,0 +1,692 @@ +// SPDX-License-Identifier: GPL-2.0 or MIT +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#include +#include +#include +#include + +#include "panthor_arbitration.h" +#include "panthor_arbitration_sched.h" +#include "panthor_resource_group.h" + +static u64 grant_timeout_us =3D 1 * USEC_PER_SEC; +static u64 yield_timeout_us =3D 1 * USEC_PER_SEC; + +module_param(grant_timeout_us, ullong, 0664); +MODULE_PARM_DESC(grant_timeout_us, "Time the GPU will be granted to the AW= in microseconds."); + +module_param(yield_timeout_us, ullong, 0664); +MODULE_PARM_DESC(yield_timeout_us, "Time, in microseconds, within which th= e AW must yeild the GPU."); + +enum arbitration_sched_phase { + ARB_SCHED_PHASE_IDLE =3D 0, + ARB_SCHED_PHASE_GRANTING, + ARB_SCHED_PHASE_GRANTED, + ARB_SCHED_PHASE_STOPPING, + ARB_SCHED_PHASE_LOST, +}; + +struct panthor_arbitration_timer { + /** @timer: High-resolution timer */ + struct hrtimer timer; + + /** @epoch: The lease generation for which the timer was triggered */ + u32 epoch; +}; + +struct panthor_arbitration_work { + /** @work: Work struct */ + struct work_struct work; + + /** @aw_id: Window for which the work was queued */ + u8 aw_id; + + /** @epoch: The lease generation for which the work was queued */ + u32 epoch; +}; + +struct panthor_arbitration_sched { + /** @dev: Device pointer */ + struct device *dev; + + /** @name: Scheduler indentifying name */ + char *name; + + /** @waitqueue: Event wait queue. Not IRQ safe */ + wait_queue_head_t waitqueue; + + /** @lock: Protects scheduler state */ + spinlock_t lock; + + /** @queue: Pending request FIFO */ + DECLARE_KFIFO(queue, u8, 16); + + /** @queued_mask: Mask of currently queued AWs */ + DECLARE_BITMAP(queued_mask, AM_ARB_MAX_AW_COUNT); + + /** @active_aw_id: Currently active AW. Can be -1 */ + s8 active_aw_id; + + /** @phase: Current scheduling phase */ + enum arbitration_sched_phase phase; + + /** @epoch: Current active lease generation */ + u32 epoch; + + /** @wq: Scheduler workqueue to dispatch events */ + struct workqueue_struct *wq; + + /** @grant_work: Work to grant the GPU to the AW */ + struct panthor_arbitration_work grant_work; + + /** @stop_work: Work to hard-close the AW */ + struct panthor_arbitration_work stop_work; + + /** @close_work: Work to hard-close the AW */ + struct panthor_arbitration_work close_work; + + /** @grant_timer: Timer to indicate grant window has lapsed */ + struct panthor_arbitration_timer grant_timer; + + /** @stop_timer: Timer to indicate yield window has lapsed */ + struct panthor_arbitration_timer stop_timer; + + /** @disabled: Scheduler disabled. No further scheduling can happen */ + bool disabled; + + /** + * @grant_previously_expired: Grant period previously expired but was + * not asked to stop + */ + bool grant_previously_expired; +}; + +static inline struct panthor_arbitration * +to_adev(struct panthor_arbitration_sched *sched) +{ + return dev_get_drvdata(sched->dev); +} + +static inline struct panthor_arbitration_work *to_work(struct work_struct = *w) +{ + return container_of(w, struct panthor_arbitration_work, work); +} + +static bool arb_sched_phase_reached(struct panthor_arbitration_sched *sche= d, + enum arbitration_sched_phase phase) +{ + guard(spinlock_irqsave)(&sched->lock); + + return sched->phase =3D=3D phase; +} + +/** + * sched_wait_phase - Wait for scheduler to enter a phase + * + * This method is not IRQ safe as it sleeps. + */ +static int arb_sched_wait_phase(struct panthor_arbitration_sched *sched, + enum arbitration_sched_phase phase, + u64 timeout_us) +{ + if (!wait_event_timeout( + sched->waitqueue, arb_sched_phase_reached(sched, phase), + usecs_to_jiffies(timeout_us))) { + + if (!arb_sched_phase_reached(sched, phase)) + return -ETIMEDOUT; + } + + return 0; +} + +static void arb_sched_disable(struct panthor_arbitration_sched *sched) +{ + scoped_guard(spinlock_irqsave, &sched->lock) + sched->disabled =3D true; + + hrtimer_cancel(&sched->grant_timer.timer); +} + +static void arb_sched_enable(struct panthor_arbitration_sched *sched) +{ + scoped_guard(spinlock_irqsave, &sched->lock) + sched->disabled =3D false; +} + +static void arb_sched_queue_work(struct panthor_arbitration_sched *sched, + struct panthor_arbitration_work *work) +{ + lockdep_assert_held(&sched->lock); + + work->aw_id =3D sched->active_aw_id; + work->epoch =3D sched->epoch; + queue_work(sched->wq, &work->work); +} + +static void arb_sched_request_stop_locked(struct panthor_arbitration_sched= *sched) +{ + lockdep_assert_held(&sched->lock); + + if (sched->phase !=3D ARB_SCHED_PHASE_GRANTED) + return; + + if (sched->active_aw_id < 0) + return; + + /* + * In the event of a single requesting AW, let it continue to + * lease the GPU until another request comes in. + */ + if (!sched->disabled && kfifo_is_empty(&sched->queue)) { + sched->grant_previously_expired =3D true; + return; + } + + sched->phase =3D ARB_SCHED_PHASE_STOPPING; + arb_sched_queue_work(sched, &sched->stop_work); + + wake_up_all(&sched->waitqueue); +} + +static void arb_sched_request_stop(struct panthor_arbitration_sched *sched) +{ + guard(spinlock_irqsave)(&sched->lock); + + arb_sched_request_stop_locked(sched); +} + +static void arb_sched_force_close_locked(struct panthor_arbitration_sched = *sched) +{ + lockdep_assert_held(&sched->lock); + + if (sched->phase =3D=3D ARB_SCHED_PHASE_IDLE || + sched->phase =3D=3D ARB_SCHED_PHASE_LOST) + return; + + if (sched->active_aw_id < 0) + return; + + sched->phase =3D ARB_SCHED_PHASE_LOST; + + arb_sched_queue_work(sched, &sched->close_work); + + wake_up_all(&sched->waitqueue); +} + +static void arb_sched_force_close(struct panthor_arbitration_sched *sched) +{ + guard(spinlock_irqsave)(&sched->lock); + + arb_sched_force_close_locked(sched); +} + +static int arb_sched_next_locked(struct panthor_arbitration_sched *sched) +{ + u8 aw_id; + + lockdep_assert_held(&sched->lock); + + if (sched->disabled) + return 0; + + /* already have a running aw */ + if (sched->active_aw_id >=3D 0) + return 0; + + /* nothing to schedule */ + if (kfifo_is_empty(&sched->queue)) + return 0; + + if (!kfifo_get(&sched->queue, &aw_id)) { + dev_warn(sched->dev, "%s: queue unexpectedly empty", + sched->name); + return -EINVAL; + } + + clear_bit(aw_id, sched->queued_mask); + + sched->active_aw_id =3D aw_id; + sched->epoch++; + sched->phase =3D ARB_SCHED_PHASE_GRANTING; + + arb_sched_queue_work(sched, &sched->grant_work); + + wake_up_all(&sched->waitqueue); + + return 0; +} + +static int arb_sched_next(struct panthor_arbitration_sched *sched) +{ + guard(spinlock_irqsave)(&sched->lock); + + return arb_sched_next_locked(sched); +} + +static void arb_sched_reset(struct panthor_arbitration_sched *sched, + u32 epoch, u8 aw_id) +{ + scoped_guard(spinlock_irqsave, &sched->lock) { + if (sched->epoch !=3D epoch) + return; + + if (sched->active_aw_id !=3D aw_id) + return; + + dev_warn(sched->dev, "%s: scheduler reset. active_aw=3D%u", + sched->name, sched->active_aw_id); + + sched->epoch++; + sched->active_aw_id =3D -1; + sched->phase =3D ARB_SCHED_PHASE_IDLE; + sched->grant_previously_expired =3D false; + + wake_up_all(&sched->waitqueue); + } + + hrtimer_cancel(&sched->grant_timer.timer); + hrtimer_cancel(&sched->stop_timer.timer); + + arb_sched_next(sched); +} + +static void arb_sched_grant_work(struct work_struct *work) +{ + struct panthor_arbitration_work *w =3D to_work(work); + struct panthor_arbitration_sched *sched =3D + container_of(w, struct panthor_arbitration_sched, grant_work); + int ret; + u32 epoch; + u8 aw_id; + + scoped_guard(spinlock_irqsave, &sched->lock) { + if (sched->epoch !=3D w->epoch) + return; + + if (sched->active_aw_id !=3D w->aw_id) + return; + + epoch =3D sched->epoch; + aw_id =3D sched->active_aw_id; + } + + ret =3D panthor_arbitration_on_grant(to_adev(sched), aw_id); + if (!ret) { + guard(spinlock_irqsave)(&sched->lock); + + if (sched->phase !=3D ARB_SCHED_PHASE_GRANTING) { + dev_warn(sched->dev, "%s: Grant ACKED when not granting", + sched->name); + return; + } + + if (sched->active_aw_id !=3D aw_id) + return; + + if (sched->disabled) { + sched->phase =3D ARB_SCHED_PHASE_STOPPING; + arb_sched_queue_work(sched, &sched->stop_work); + } else { + sched->phase =3D ARB_SCHED_PHASE_GRANTED; + + sched->grant_timer.epoch =3D sched->epoch; + hrtimer_start(&sched->grant_timer.timer, + us_to_ktime(grant_timeout_us), + HRTIMER_MODE_REL); + } + + wake_up_all(&sched->waitqueue); + } else { + dev_err(sched->dev, "%s: Failed to grant access to AW%u", + sched->name, aw_id); + + arb_sched_reset(sched, epoch, aw_id); + } +} + +static void arb_sched_stop_work(struct work_struct *work) +{ + struct panthor_arbitration_work *w =3D to_work(work); + struct panthor_arbitration_sched *sched =3D + container_of(w, struct panthor_arbitration_sched, stop_work); + int ret; + u32 epoch; + u8 aw_id; + + scoped_guard(spinlock_irqsave, &sched->lock) { + if (sched->epoch !=3D w->epoch) + return; + + if (sched->active_aw_id !=3D w->aw_id) + return; + + epoch =3D sched->epoch; + aw_id =3D sched->active_aw_id; + } + + ret =3D panthor_arbitration_on_stop(to_adev(sched), aw_id); + if (!ret) { + guard(spinlock_irqsave)(&sched->lock); + + if (sched->phase !=3D ARB_SCHED_PHASE_STOPPING) { + dev_warn(sched->dev, "%s: Stop ACKED when not yielding", + sched->name); + return; + } + + if (sched->active_aw_id !=3D aw_id) + return; + + sched->stop_timer.epoch =3D sched->epoch; + hrtimer_start(&sched->stop_timer.timer, + us_to_ktime(yield_timeout_us), HRTIMER_MODE_REL); + } else { + dev_err(sched->dev, "%s: Failed to send yield to AW%u", + sched->name, aw_id); + + arb_sched_reset(sched, epoch, aw_id); + } +} + +static void arb_sched_close_work(struct work_struct *work) +{ + struct panthor_arbitration_work *w =3D to_work(work); + struct panthor_arbitration_sched *sched =3D + container_of(w, struct panthor_arbitration_sched, close_work); + int ret; + u32 epoch; + u8 aw_id; + + scoped_guard(spinlock_irqsave, &sched->lock) { + if (sched->epoch !=3D w->epoch) + return; + + if (sched->active_aw_id !=3D w->aw_id) + return; + + epoch =3D sched->epoch; + aw_id =3D sched->active_aw_id; + } + + ret =3D panthor_arbitration_on_close(to_adev(sched), w->aw_id); + if (ret) { + dev_err(sched->dev, "%s: Failed to close AW%u", + sched->name, aw_id); + arb_sched_reset(sched, epoch, aw_id); + } else { + panthor_arbitration_sched_on_stopped(sched, w->aw_id); + } +} + +static enum hrtimer_restart +panthor_arbitration_sched_on_stop_timeout(struct hrtimer *timer) +{ + struct panthor_arbitration_timer *atmr =3D container_of( + timer, struct panthor_arbitration_timer, timer); + struct panthor_arbitration_sched *sched =3D container_of( + atmr, struct panthor_arbitration_sched, stop_timer); + + guard(spinlock_irqsave)(&sched->lock); + + if (sched->epoch !=3D atmr->epoch) + return HRTIMER_NORESTART; + + dev_warn(sched->dev, + "%s: AW%d failed to stop in time. Force closing...", + sched->name, sched->active_aw_id); + arb_sched_force_close_locked(sched); + + return HRTIMER_NORESTART; +} + +static enum hrtimer_restart +panthor_arbitration_sched_on_grant_timeout(struct hrtimer *timer) +{ + struct panthor_arbitration_timer *atmr =3D container_of( + timer, struct panthor_arbitration_timer, timer); + struct panthor_arbitration_sched *sched =3D container_of( + atmr, struct panthor_arbitration_sched, grant_timer); + + guard(spinlock_irqsave)(&sched->lock); + + if (sched->epoch !=3D atmr->epoch) + return HRTIMER_NORESTART; + + arb_sched_request_stop_locked(sched); + + return HRTIMER_NORESTART; +} + +int panthor_arbitration_sched_on_request(struct panthor_arbitration_sched = *sched, u8 aw_id) +{ + guard(spinlock_irqsave)(&sched->lock); + + if (aw_id >=3D AM_ARB_MAX_AW_COUNT) + return -EINVAL; + + if (test_bit(aw_id, sched->queued_mask) || + (sched->active_aw_id =3D=3D aw_id && + sched->phase !=3D ARB_SCHED_PHASE_STOPPING)) { + dev_warn(sched->dev, "%s: AW%u already in request queue.", + sched->name, aw_id); + return -EEXIST; + } + + /* Always put onto queue */ + kfifo_put(&sched->queue, aw_id); + set_bit(aw_id, sched->queued_mask); + + /* Already have running or pending, exit. */ + if (sched->active_aw_id >=3D 0) { + /* + * Grant timer for the current AW has previously expired, + * request it to yield the GPU. + */ + if (sched->grant_previously_expired) + arb_sched_request_stop_locked(sched); + + return 0; + } + + return arb_sched_next_locked(sched); +} + +int panthor_arbitration_sched_on_idle(struct panthor_arbitration_sched *sc= hed, u8 aw_id) +{ + guard(spinlock_irqsave)(&sched->lock); + + if (aw_id >=3D AM_ARB_MAX_AW_COUNT) + return -EINVAL; + + if (sched->active_aw_id !=3D aw_id) + return 0; + + if (sched->phase !=3D ARB_SCHED_PHASE_GRANTED) + return 0; + + sched->phase =3D ARB_SCHED_PHASE_STOPPING; + arb_sched_queue_work(sched, &sched->close_work); + + return 0; +} + +int panthor_arbitration_sched_on_stopped(struct panthor_arbitration_sched = *sched, u8 aw_id) +{ + guard(spinlock_irqsave)(&sched->lock); + + if (aw_id >=3D AM_ARB_MAX_AW_COUNT) + return -EINVAL; + + if (sched->phase =3D=3D ARB_SCHED_PHASE_IDLE) + return 0; + + if (sched->active_aw_id !=3D aw_id) + return 0; + + /* retire old lease */ + sched->epoch++; + + sched->grant_previously_expired =3D false; + sched->active_aw_id =3D -1; + sched->phase =3D ARB_SCHED_PHASE_IDLE; + + wake_up_all(&sched->waitqueue); + + return arb_sched_next_locked(sched); +} + +static void arbitration_sched_term(struct panthor_arbitration_sched *sched) +{ + WARN_ON(panthor_arbitration_sched_stop(sched)); + + disable_work_sync(&sched->grant_work.work); + disable_work_sync(&sched->stop_work.work); + disable_work_sync(&sched->close_work.work); +} + +static int arbitration_sched_init(struct panthor_arbitration *adev, int i) +{ + struct device *dev =3D adev->dev; + struct panthor_arbitration_sched *sched; + + sched =3D devm_kzalloc(dev, sizeof(*sched), GFP_KERNEL); + if (!sched) + return -ENOMEM; + + sched->name =3D devm_kasprintf(dev, GFP_KERNEL, "sched%d", i); + sched->dev =3D dev; + + sched->wq =3D devm_alloc_ordered_workqueue(dev, "%s-wq", 0, sched->name); + if (!sched->wq) + return -ENOMEM; + + INIT_WORK(&sched->grant_work.work, arb_sched_grant_work); + INIT_WORK(&sched->stop_work.work, arb_sched_stop_work); + INIT_WORK(&sched->close_work.work, arb_sched_close_work); + + init_waitqueue_head(&sched->waitqueue); + + spin_lock_init(&sched->lock); + INIT_KFIFO(sched->queue); + sched->active_aw_id =3D -1; + sched->phase =3D ARB_SCHED_PHASE_IDLE; + + hrtimer_setup(&sched->grant_timer.timer, + panthor_arbitration_sched_on_grant_timeout, + CLOCK_MONOTONIC, HRTIMER_MODE_REL); + hrtimer_setup(&sched->stop_timer.timer, + panthor_arbitration_sched_on_stop_timeout, + CLOCK_MONOTONIC, HRTIMER_MODE_REL); + + adev->sched[i] =3D sched; + + return 0; +} + +void panthor_arbitration_sched_term(struct panthor_arbitration *adev) +{ + for (int i =3D 0; i < AM_ARB_MAX_PC_COUNT; i++) { + struct panthor_arbitration_sched *sched =3D adev->sched[i]; + + if (!sched) + continue; + + arbitration_sched_term(sched); + } +} + +int panthor_arbitration_sched_init(struct panthor_arbitration *adev) +{ + + for (int i =3D 0; i < AM_ARB_MAX_PC_COUNT; i++) { + int ret =3D arbitration_sched_init(adev, i); + + if (ret =3D=3D -ENODEV) + continue; + + if (ret) + return ret; + } + + return 0; +} + +int panthor_arbitration_sched_suspend(struct panthor_arbitration *adev) +{ + for (int i =3D 0; i < AM_ARB_MAX_PC_COUNT; i++) { + struct panthor_arbitration_sched *sched =3D adev->sched[i]; + int ret; + + if (!sched) + continue; + + ret =3D panthor_arbitration_sched_stop(sched); + if (ret) + return ret; + } + + return 0; +} + +int panthor_arbitration_sched_resume(struct panthor_arbitration *adev) +{ + for (int i =3D 0; i < AM_ARB_MAX_PC_COUNT; i++) { + struct panthor_arbitration_sched *sched =3D adev->sched[i]; + int ret; + + if (!sched) + continue; + + ret =3D panthor_arbitration_sched_start(sched); + if (ret) + return ret; + } + + return 0; +} + +/** + * panthor_arbitration_sched_stop - Stop active aw and pause scheduler + * + * This method is not IRQ safe as it waits for on_stopped() to be called. + */ +int panthor_arbitration_sched_stop(struct panthor_arbitration_sched *sched) +{ + int ret; + + arb_sched_disable(sched); + + arb_sched_request_stop(sched); + + /* + * Provisionally waiting for up to 2x yield_timeout, but path may + * include time taken for panthor_arbitration_on_grant() to complete + * if sched_request_stop() is called while in the GRANTING state. + * + * Realistically, if granting takes more than yield_timeout, HW is in + * bad state either way. Best continue and stop the scheduler. + */ + ret =3D arb_sched_wait_phase(sched, ARB_SCHED_PHASE_IDLE, + grant_timeout_us + yield_timeout_us); + if (ret) + arb_sched_force_close(sched); + + /* Should no longer have any further activity. Cancel timer. */ + hrtimer_cancel(&sched->stop_timer.timer); + flush_workqueue(sched->wq); + + scoped_guard(spinlock_irqsave, &sched->lock) + if (sched->phase =3D=3D ARB_SCHED_PHASE_IDLE) + return 0; + + return ret; +} + +int panthor_arbitration_sched_start(struct panthor_arbitration_sched *sche= d) +{ + arb_sched_enable(sched); + + return arb_sched_next(sched); +} diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_sched.= h b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_sched.h new file mode 100644 index 000000000000..4625b36f4ce6 --- /dev/null +++ b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_sched.h @@ -0,0 +1,25 @@ +/* SPDX-License-Identifier: GPL-2.0 or MIT */ +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#ifndef __PANTHOR_ARBITRATION_SCHED_H__ +#define __PANTHOR_ARBITRATION_SCHED_H__ + +#include + +struct panthor_arbitration; +struct panthor_arbitration_sched; + +int panthor_arbitration_sched_init(struct panthor_arbitration *adev); +void panthor_arbitration_sched_term(struct panthor_arbitration *adev); + +int panthor_arbitration_sched_suspend(struct panthor_arbitration *adev); +int panthor_arbitration_sched_resume(struct panthor_arbitration *adev); + +int panthor_arbitration_sched_stop(struct panthor_arbitration_sched *sched= ); +int panthor_arbitration_sched_start(struct panthor_arbitration_sched *sche= d); + +int panthor_arbitration_sched_on_request(struct panthor_arbitration_sched = *sched, u8 aw_id); +int panthor_arbitration_sched_on_idle(struct panthor_arbitration_sched *sc= hed, u8 aw_id); +int panthor_arbitration_sched_on_stopped(struct panthor_arbitration_sched = *sched, u8 aw_id); + +#endif --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from PA4PR04CU001.outbound.protection.outlook.com (mail-francecentralazon11013007.outbound.protection.outlook.com [40.107.162.7]) (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 192043ED3A5 for ; Thu, 28 May 2026 15:07:21 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.162.7 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980844; cv=fail; b=QAQVkE97BohQwYiYJME7MvQyYpibg/7wN9oKkJ+bd0yDBWL37osW7U1D5dXgqPfhDF9JTPYM6RGRVz6RYGM2dd0rrE/VYvijDWBNLkuRZLEISgwx7+cG9O7JSL4+nXh7z7OM+n+5QxDgITtcufS9th7NR2EpSvstcTEUIghsz4s= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980844; c=relaxed/simple; bh=ZyeaIDePEIIQp3ZrmgCM5yEQL0ZWF+TUyLE7GpHagKU=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=TPV1N9b8aWUefOszC8k8dbBBDGpj2Ctg0H9QyPeH9iz14gMStFHNeQtuIk4hYSrJFE0cG5I9Np+2O2DxvGK7GJjZAbN5E9gg8mfIu1ikoLe79Nu0cF3M8XsNasTR9Ax58KVDlCMxVDcWAuKump0Nnfnsp3e7xXqNF19761EG7tQ= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=JradGPD7; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=JradGPD7; arc=fail smtp.client-ip=40.107.162.7 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="JradGPD7"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="JradGPD7" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=n9S19tLdlEm/yimevpUifH0Dm282fT/0f/JtQu/M/YaXvqw96vESyank/9/rkBaeq6kFHYjdL1jlytHw6LMd4+q93/+ruUberdO729uZ9i4hJpyJ8PTfp5LQJabWeJOXNMiu8TK3jIghyjiizXy9Q1ZfKfrui0ouujN7sLZR3F1De0TIUOMYQ7KMjxwloAdhqRFlDlWR9XkIDqzL4upjW0mT1pkYzPmwnkLJGKuTi1jrwqJR8rhWZJVr0zQ2XGQOUGQUPJEDcLvzt6f1rU0mJlt1gxK62fFbhYGnhSNnRmIShDzJ1++miVUQA4nRaWD6dgsqxi4+URGu70kMt3rvkQ== ARC-Message-Signature: i=2; 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=wbSAjjclZghagaKTSrx5vnYkjZ7WfMN9xwRwP62qQqk=; b=eTE0kxMWFDW5T8msKBO4lx1lYrSLRszfv4cq7Ta3gqqmP3VoaYeH06SWu1xzVq0R3sEZhopDPnyOspCGX3mjD8NKCNxGUU6+qdP+/8hpsaRufNP2MayKDa9rZ9jfdCtkgq5YQYuZwOMD1U3DZaX3ndRi5/QtHeNO3zleujmOWaGe5hNWPH7Nvwn6dOdhb9ucTTbwO3tlIAfT7ASWZQs5rZPIXuMtC7PXyejuztte4uo/xbGCWMF5ZpyFoog2n2+tt2iLroGDyRbiRzO+u+YJTvS+itxeFfua/sXNdut8nSSxRr0pFFtaHgWcOdGjrrGzUzpOap8EXQVpybWIaq+NhA== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=wbSAjjclZghagaKTSrx5vnYkjZ7WfMN9xwRwP62qQqk=; b=JradGPD7ovTLmBGXCFOIms2MLXi3XjQqR8YKQV6J0S9DRYE7Hj+AuafDOuj6ib/7fvC5Z7O5g0wx/+bH81zUSatF+ywzclprSHoIRje9Ol274xC8UM/C6ZR8qK7UESd7IN6Bt7raTKT/COzQT0FPOxU89nb/Baj9bu7bVfVLOOs= Received: from AM0PR05CA0080.eurprd05.prod.outlook.com (2603:10a6:208:136::20) by DBAPR08MB5735.eurprd08.prod.outlook.com (2603:10a6:10:1a1::21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:07:16 +0000 Received: from AM2PEPF0001C717.eurprd05.prod.outlook.com (2603:10a6:208:136:cafe::48) by AM0PR05CA0080.outlook.office365.com (2603:10a6:208:136::20) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.13 via Frontend Transport; Thu, 28 May 2026 15:07:16 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by AM2PEPF0001C717.mail.protection.outlook.com (10.167.16.187) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.7 via Frontend Transport; Thu, 28 May 2026 15:07:16 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=PfGRCmbtXHzSFwomThuef2UzsYiBPrcWT2IcOv+3hXEhE/St8D1tCg/riu1vp/iM1bXQ/yI7UQWadvpOm4rn+D9F3V3Cl71aP72A2bwn0s35nw/y2p1tctgmv5mioozyfpSADMnwxin1UOaXuCfedS88fM3OPFa6G3hyYAuEXW0x6ot8zAiVGQ0AVvKR2AEQMoX5ZrCCx3gha1D1aB4CbrbX+QT7Y8CsgnM56kBu2UWv2jN6BWuEofBO8ONEI+l+qhYH5L5s09XsfReUSWHhQ83729n0/lN+hNj4DuKkW7pEFatLrCHg5RjmGKsSkYAQnyUrXWXIQuxFprTQcHgiyQ== 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=wbSAjjclZghagaKTSrx5vnYkjZ7WfMN9xwRwP62qQqk=; b=AegvnZvJUaJ+n4HmQozU5JLwwuUzrNauHep3tfuJh5B4sYhPQitaOiqn3RlobVxpjh6BqLYMWuVGipTiNqgIrYPP6brVZC235j0K0F435QGWXSMNVk4ZppyIZspJRQEFJPSwre05ElUvdU8SZbRHsMw232TPkaiO8u37rxNSZfVWRAf4f3divY8+I2ECO3Dp2Ptiklxy8QduAPSu4dtKcinkyvdQgR2ukMMK9pgy5N/4K0rD6QafY25ohZGQ95/0sCG+9SjQ9OfVIwzhXemMEhoigflqx7KbuCup5TKzegWSLzGxDEacyvlO1bnggA0PFpw7fuMktn2xmr0Y6g2Wzg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=wbSAjjclZghagaKTSrx5vnYkjZ7WfMN9xwRwP62qQqk=; b=JradGPD7ovTLmBGXCFOIms2MLXi3XjQqR8YKQV6J0S9DRYE7Hj+AuafDOuj6ib/7fvC5Z7O5g0wx/+bH81zUSatF+ywzclprSHoIRje9Ol274xC8UM/C6ZR8qK7UESd7IN6Bt7raTKT/COzQT0FPOxU89nb/Baj9bu7bVfVLOOs= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:13 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:12 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 14/18] drm/panthor: Route arbitration events Date: Thu, 28 May 2026 16:05:42 +0100 Message-ID: <20260528150546.3168527-15-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: LO4P265CA0055.GBRP265.PROD.OUTLOOK.COM (2603:10a6:600:2af::11) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|AM2PEPF0001C717:EE_|DBAPR08MB5735:EE_ X-MS-Office365-Filtering-Correlation-Id: 1223ddee-38ff-4558-7afc-08debccace6b X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|6133799003|22082099003|18002099003|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: rpG/j52fSwVEphI9tXYBzkuqmvuOwZFR37saJnO9cYnbojwaq5yN+WwwKKXyIF6KuqUIkPCVmnQ/6M4onqBcm4MYHqkyn7rhns38OR1dKyXZUhe1B58WoEVGFng6jWL3Jbk3iTicemC30+7iGLTjZYI6MpjAKkdZhpS1LLR4sRsHKIBIDMwc5iquc4UzZyl7qrTv4boj/6ghjP2ijsdmmcQLF82kFsEi+CNmWi26fqjO33Saff+Fuv+WSc9UIbyZ5Nd9n2agq9UjPK2/XwB4qOOlfMmoNKYlUnh+4ikMslaNrweOyApTRMutDGQEkzIebEWgCa5UybTuDfV/O4gIiyW1X3aARQLx9QyFjRM/d4TDsf60Wg/HgrRuWsDHtQxB1+O0fGjQz1dwhRfYLEmZasEmqYjB5N0nz1EykJY6MvcA/nJRlg1wq2nJQw7Fy68KOymZlz0vQ0fQ6hGMyTiTpGZUx+AjvO81849DHUMldyhVYU2dc8V44y4hDG8tGsvOXXyIlt3A9T5HxjxGFLkhYKMgVQr2VuUe0aOuqZcmFYYGJCtq+nv7LwnyVH0E0oAYOsik8J3vXN85aOn3Sx+rL+yQukikKv3Y3KZABFxvMvg5Rvp4WXPsQnhJOleea9m3MYsu1DpxX16rMYs54kmDmWQNdlE9sg+9DY9Pw4GM4dZVP57hOX+1+zBDVOH7Xx96 X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(6133799003)(22082099003)(18002099003)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: oQhYlj/a1Ejc8WeYz/VdMA0QjRi8kEcVVUxM0/EZ1CDhIm9mV0iqQTEZyV/3/STNBowzXWQ34vJUSSVxtAl5oUI/qTaPT5Rly94ysZLEMfGaaPtT/4nXgYb5uk3wWl+sVtp09H0WL4iowdIFRqurY+ZD4fqMHe5scOltR0qkYdyfCz/odRzHDW1DC3rzLZl2pHXIe4BQRUbXXtA4vFp5tCXeUO3OulEvVDE1FDHVLiA6k8YKD//VcFldCG5TA9mHwlCOm5A9sWwZskWasqt2r7VhT7R95KDp9u5x5TNxIj6JqC+LkhfDo+2YbUEk7nX6uQI6l9V+RwWD22e8GvHbVw== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: AM2PEPF0001C717.eurprd05.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: b532d5ba-5cd4-4cfc-08ce-08debccaa847 X-Microsoft-Antispam: BCL:0;ARA:13230040|36860700016|1800799024|14060799003|376014|35042699022|82310400026|18002099003|22082099003|11063799006|6133799003|56012099006; X-Microsoft-Antispam-Message-Info: 9Hr3V3b81Viw/JrZhH7DMyFBRnQlelBGcU6ha76cJxvbxYCSZaVSXFzy+IuFAL1e3EQxewy2rrcij3c6XJpfhceBlQZPhtw0kOd5bOXlSwSdchnjLOdnTRKhzwwEK+rgA1pNPL9sOQCu8O9yX6ihSb6qbxNLmYynmBKHOPcEhefE7/FoPlDC78kfwpS3Bk9pcV26Y+ko2+dK65AmkmFczfhKhvt3wFX9w+cdKXIBVjA4raN3vdGOdkE02SmNHKKN6OcuWAZFtwG0h5V0bThkkmvYo4XCKTS5gCjCwBSkb/DRYWgXYZ9oNfGcrpx6iBAMQOTJ2VGxiSATSCo/iCoCWa7wNbuPF3CW9xt25wmCLW4kFU842L+l/vpomf431hVxsdc8bEiWS8GhNZXQcr5oi28Wt3ZNhR8b7oMTTSHgXpvJw3xch+haZOTe7rtPeVdbiepgdCZp+1fFohiON+pPsx2Uy26GiaZselT3LCdIqgDdBERiQy7dluP8ad7Z/otEA/ThtXGw2Bc+f8Tre4F76ipEbrlLNr8mQgurbrTfLOt0AP1ZQhhn10O+OKT9uwEVljMqbQX3uuiIUnHksSw488btB6Pm40BniqSgbxFggzWK8NspCelmwdP8/CXh/aRo9OPqhdT7IbMoqXDkQPlvCk3NGIJwYSk6ZNJTrDUAvsPBNdrrg3ufGg/F5AnLDbUUvhx/X6KspmvQDvTRC9APrh+vwCGnZH7MCniABTCdOzI= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(36860700016)(1800799024)(14060799003)(376014)(35042699022)(82310400026)(18002099003)(22082099003)(11063799006)(6133799003)(56012099006);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: HSa1g3/tSfWWGSs2A8FHOZM9r1lJLyTr82vypaoo9w+DxvB/GPi1k1lVv9lIRRtw2EoVsB4EWIv8wg+hVaN5/UR4R7HD4PrFmbbSmPIhBCvblrv0EXZU+kXDoS3aXF+aNRnWFL3VPIj2IEisSsKTQ61oePoCp69a5QtQRQmXxpQdyWY8pAKM1F7P5yWSk1SjGpSeqxmGAOHFJ1cxaKRcd1eUNIW9ikgDcHuVYT68gQH9DPdAH1/WFueI08kul4fyyO5M63IscRE6otF9ATlmZjVfmso3SMVezIb/Z0Rn0Itp7tM96bvZ60n79b/c2m2J0sNpoEXgRuETF8O14jXFdMi4ifetkcwy5+WYNXU5h2ERuZqlMsq5YvoVW3Xt/tm7ZcGeZGUHMtusSsTStdDREMpOthOok8T/3IjPPs2C8ijb6Cb7hCibYsqL1eFd9Bck X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:16.4712 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 1223ddee-38ff-4558-7afc-08debccace6b X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: AM2PEPF0001C717.eurprd05.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DBAPR08MB5735 Content-Type: text/plain; charset="utf-8" Wire the resource-group, scheduler, and partition-control blocks together. Resource-group messages now feed request and idle events into the scheduler, while partition RESET_DONE from a YIELD_DONE reports the active access window as stopped. Add the arbiter-to-window callbacks used by the scheduler to grant, yield, and close partition windows. Signed-off-by: Karunika Choo --- .../panthor/arbitration/panthor_arbitration.h | 12 ++++++ .../arbitration/panthor_arbitration_drv.c | 38 +++++++++++++++++++ .../arbitration/panthor_partition_control.c | 9 +++++ .../arbitration/panthor_resource_group.c | 4 +- 4 files changed, 61 insertions(+), 2 deletions(-) diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration.h b/dr= ivers/gpu/drm/panthor/arbitration/panthor_arbitration.h index 0bc683e6a71d..fca1a2325b16 100644 --- a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration.h +++ b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration.h @@ -4,6 +4,8 @@ #ifndef __PANTHOR_ARBITRATION_H__ #define __PANTHOR_ARBITRATION_H__ =20 +#include + struct device; struct panthor_arbitration_sched; struct panthor_partition_control; @@ -30,4 +32,14 @@ struct panthor_arbitration { struct panthor_arbitration_sched *sched[AM_ARB_MAX_PC_COUNT]; }; =20 +/* AW to Arbiter events */ +int panthor_arbitration_on_request(struct panthor_arbitration *adev, u8 aw= _id); +int panthor_arbitration_on_idle(struct panthor_arbitration *adev, u8 aw_id= ); +int panthor_arbitration_on_stopped(struct panthor_arbitration *adev, u8 aw= _id); + +/* Arbiter to AW events */ +int panthor_arbitration_on_grant(struct panthor_arbitration *adev, u8 aw_i= d); +int panthor_arbitration_on_stop(struct panthor_arbitration *adev, u8 aw_id= ); +int panthor_arbitration_on_close(struct panthor_arbitration *adev, u8 aw_i= d); + #endif diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c = b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c index 5cdefd9ed5c9..edbda1845068 100644 --- a/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c +++ b/drivers/gpu/drm/panthor/arbitration/panthor_arbitration_drv.c @@ -55,6 +55,44 @@ static int panthor_arbitration_runtime_resume(struct dev= ice *dev) return 0; } =20 +/* AW to Arbiter events */ +int panthor_arbitration_on_request(struct panthor_arbitration *adev, u8 aw= _id) +{ + /* TODO: AW to PC assignment */ + return panthor_arbitration_sched_on_request(adev->sched[0], aw_id); +} + +int panthor_arbitration_on_idle(struct panthor_arbitration *adev, u8 aw_id) +{ + /* TODO: AW to PC assignment */ + return panthor_arbitration_sched_on_idle(adev->sched[0], aw_id); +} + +int panthor_arbitration_on_stopped(struct panthor_arbitration *adev, u8 aw= _id) +{ + /* TODO: AW to PC assignment */ + return panthor_arbitration_sched_on_stopped(adev->sched[0], aw_id); +} + +/* Arbiter to AW events */ +int panthor_arbitration_on_grant(struct panthor_arbitration *adev, u8 aw_i= d) +{ + /* TODO: AW to PC assignment */ + return panthor_partition_control_open_window(adev->pc[0], aw_id); +} + +int panthor_arbitration_on_stop(struct panthor_arbitration *adev, u8 aw_id) +{ + /* TODO: AW to PC assignment */ + return panthor_partition_control_yield_now(adev->pc[0]); +} + +int panthor_arbitration_on_close(struct panthor_arbitration *adev, u8 aw_i= d) +{ + /* TODO: AW to PC assignment */ + return panthor_partition_control_close_window(adev->pc[0]); +} + static int panthor_arbitration_probe(struct platform_device *pdev) { struct panthor_arbitration *adev; diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_partition_control.= c b/drivers/gpu/drm/panthor/arbitration/panthor_partition_control.c index f4bad839610d..095e19c8d4c5 100644 --- a/drivers/gpu/drm/panthor/arbitration/panthor_partition_control.c +++ b/drivers/gpu/drm/panthor/arbitration/panthor_partition_control.c @@ -220,15 +220,24 @@ static int window_open(struct panthor_partition_contr= ol *pc, u8 aw_id) =20 static void partition_handle_reset_done(struct panthor_partition_control *= pc) { + bool notify_stopped =3D false; + int aw_id; + scoped_guard(spinlock_irqsave, &pc->lock) { + aw_id =3D pc->current_aw; pc->current_aw =3D -1; =20 /* RESET_DONE from CLOSE_WINDOW */ if (pc->closing) pc->closing =3D false; + else if (aw_id >=3D 0) + notify_stopped =3D true; } =20 wake_up_all(&pc->waitqueue); + + if (notify_stopped) + panthor_arbitration_on_stopped(dev_get_drvdata(pc->dev), aw_id); } =20 static irqreturn_t partition_irq_raw_handler(int irq, void *data) diff --git a/drivers/gpu/drm/panthor/arbitration/panthor_resource_group.c b= /drivers/gpu/drm/panthor/arbitration/panthor_resource_group.c index cd1ad0532766..6264efc2e29a 100644 --- a/drivers/gpu/drm/panthor/arbitration/panthor_resource_group.c +++ b/drivers/gpu/drm/panthor/arbitration/panthor_resource_group.c @@ -127,10 +127,10 @@ static void rg_handle_message(struct panthor_resource= _group *rg, u8 aw_id, rg_respond_to_handshake(rg, aw_id, message); break; case VM_ARB_GPU_REQUEST: - /* TODO: on_request */ + panthor_arbitration_on_request(dev_get_drvdata(rg->dev), aw_id); break; case VM_ARB_GPU_STOPPED: - /* TODO: on_idle */ + panthor_arbitration_on_idle(dev_get_drvdata(rg->dev), aw_id); break; default: dev_warn(rg->dev, "Invalid message (0x%llx)", message); --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from PA4PR04CU001.outbound.protection.outlook.com (mail-francecentralazon11013043.outbound.protection.outlook.com [40.107.162.43]) (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 497523F9A18 for ; Thu, 28 May 2026 15:07:23 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.162.43 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980846; cv=fail; b=P0CacwnxQYHG2ct/5ryWVkQ7y2FW4TUNQBR5LAGzzmaq/H3Y95C7VeDZcs0VCOogEZIoM9RaSHn0TC97PVvI16esu7Im+Kw7TOoZJqfWFchBZR4EVF8mbBT2hZqWa6TLGk86Vlh9UorSph1et+SQqoUoddUHfBKt2Ed+l7qVQYc= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980846; c=relaxed/simple; bh=oYio7FyctTQgApLUPvKpSPntXT2J6AGgHz8epuAtCFo=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=AIndd/c0AvZ/dxyGXTqtCzCKSs8ClAK/Uv73EWXnV1E+CgMKJU9+DFqSkmBryIqbheycrilr4YocJHjPW79Fuon/a8mN1pRXY99I/4gwoxq4ve40j2uwcvWPc5n3mlNDh5qrFXuAq8CqihWzgpE2/RgR1jKVrSYLo24mcJN3Prw= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=Ys9cd8RK; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=Ys9cd8RK; arc=fail smtp.client-ip=40.107.162.43 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="Ys9cd8RK"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="Ys9cd8RK" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=eokrLdg3PpQJu/GABUa6JSbcmC3yJ57AZ0btMe4y9rGNM+RwrvM15HgN9iO6GsTdC58nwfAOfB4n+KDPFSgxPKqpdk0B65WAijpPMHmBJvX4fCM3lYxHZU9Ln7yEwLA+rO08/b1n549/dqacDugwgtgrf5ptD21pV6SQRy+FstrkeZyNDHEiIe+mnrtDTzK/0HxHXenDaQ02FCSUHKRiE/eQfbkew7AK7IlkDr6qBFcuknAY05yDqEnKjiei2Xh1ZXaKXb+c2A11+9YrQ6WUkY4zhnk18ox8rPTEDRBUVnb4c1hUBO4o7vNH0J1/K2dETCRGnJ9p0by4fAbugmHlSw== ARC-Message-Signature: i=2; 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=PuHI0V/LvIrLHH3MAO+lRJ0d/Q/Ragsz9KhwufGENAw=; b=byP/3fkCNiiCAsoiNmOJ3RAtBNRT6WK9tvzPfMhJSO791lz6cqzEvXA0FBJsDG/Je0hBW2sF1dn7rKkMPcgWipcG7FatQyWR1v4Z9YP6Q7GmMlaeJLJDmuyAzZ9ZO0hj0QRrOVW69VowZkx1P2KQO/aAOcOzwsg4RYgy/Bz8aOQNocT/zA8t7I3+YFw6CkUY8nmJAQbbwBf7eOcjxIj/ufVG87YbMC5FLBvx4xg9Tr1NmRSH9w+mj5kni/Bh+eTkp0ZM6DvYuNqDP5KOuKpJmH33/zm7JYV2/f8AHj10Fs3iM0owRWl9dyuiZxHlIcL4SzlvGjj7X3JZthfjziXF+w== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=PuHI0V/LvIrLHH3MAO+lRJ0d/Q/Ragsz9KhwufGENAw=; b=Ys9cd8RKPGzHXNZVVAZVBd58PA2PXQKoQtnw3ThjvBbz7nuBFaS/lXFhLyzf+pz7UlAQAmIIa4wK0taGqO0+fY85QLzRZ5RoQuZkLkZF+1nEJrUCiC4D8p7U2KXjvbYCEJWg4Qz3Q9+fCBWEVltABqyrbbveH2Et9HTmG2++dHY= Received: from DUZP191CA0043.EURP191.PROD.OUTLOOK.COM (2603:10a6:10:4f8::26) by AM8PR08MB6578.eurprd08.prod.outlook.com (2603:10a6:20b:36a::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.11; Thu, 28 May 2026 15:07:16 +0000 Received: from DU2PEPF0001E9C2.eurprd03.prod.outlook.com (2603:10a6:10:4f8::4) by DUZP191CA0043.outlook.office365.com (2603:10a6:10:4f8::26) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.13 via Frontend Transport; Thu, 28 May 2026 15:07:16 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by DU2PEPF0001E9C2.mail.protection.outlook.com (10.167.8.71) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.7 via Frontend Transport; Thu, 28 May 2026 15:07:16 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=HBULt7555HvH6lnEhtVC6uKiZUhg55JD2wZx+nflQyMq4ksZY8Urn/1iB/YhTWz7XLMymy+znyUUFjLnI1DbTVZohweAhL53Pe+dD69rjhkvxlNbiQ5JidHsGYYt7NedyipXWmScXstUYDbowFqRixaeTsVuUD+iIh+7ocQaTeqN16lIqJdgjpnvsE0oIIokYMOgYyXrcLAMslqFy8oCEFjXy/tTgv1K2GIm4AVnjjZX84PLVaDt6h3/KhmztQffJ5UpxzE+9vn3F8R3NeKT3jsA+rOaWsSKhJsEeyIXaCFt46ok+7Vk+tWeXqUAc1QS7nOEGfhXXbdoJZeBaCGq2g== 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=PuHI0V/LvIrLHH3MAO+lRJ0d/Q/Ragsz9KhwufGENAw=; b=vLLSErjiAnO7g9xpmGhdgtpLkqXK0MkXBcHGHHPKnKVsSFQJTKpDHLvowq1gApzkH4bweBIUkp6XQ/TDm7SfOoSOajZp2RMFekss4mC2pioozd7CxKwF4SuNV+qmDbdRJ1Yrcu+V4L0f2zrXdNqFjybt3NMTojf0bl+Idp3hSBIK8Q3vuir7+ZZavqD5YkDc3rtYVW0FGZcXOyw6vdwgV9Qp/P7HvliH3MKeRrhq9ZuVQJ64k09C48u1lum4Ql8KiIwL1G8iXgu6fR3FwgYf3e638IZ1jv4Zds4nORG0DIJwrldl1otYxzBwD0j64tF0DbAogjsWESTibbxPdJCUtQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=PuHI0V/LvIrLHH3MAO+lRJ0d/Q/Ragsz9KhwufGENAw=; b=Ys9cd8RKPGzHXNZVVAZVBd58PA2PXQKoQtnw3ThjvBbz7nuBFaS/lXFhLyzf+pz7UlAQAmIIa4wK0taGqO0+fY85QLzRZ5RoQuZkLkZF+1nEJrUCiC4D8p7U2KXjvbYCEJWg4Qz3Q9+fCBWEVltABqyrbbveH2Et9HTmG2++dHY= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:14 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:14 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 15/18] drm/panthor: Add access-window support Date: Thu, 28 May 2026 16:05:43 +0100 Message-ID: <20260528150546.3168527-16-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: LO4P265CA0221.GBRP265.PROD.OUTLOOK.COM (2603:10a6:600:33a::20) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|DU2PEPF0001E9C2:EE_|AM8PR08MB6578:EE_ X-MS-Office365-Filtering-Correlation-Id: e466bfa9-b6d6-4595-f84d-08debccace8a X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|6133799003|22082099003|18002099003|3023799007|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: CuUODcuVMTS9EvJ7i/D3u726DL3MIwAD/UxQTWQ/FoNJCPVd6RryzzrVikkXrkQacElW36uVj6OFCHrrDCe1di9XM8nuCfcPlA4X8nUAz7XXYzZBD2s9bV1ZVrl+BHdUB+1qjhu4U14kvdp8PcMiPYW8CHmw5E8O36AmOwoKFIZfVOqj8GfTaV1Hq6Fojq6u7IXTFPjBzdfTb3GgwAntQpZxVx+e8rYt/FbDp9oO6bLulZK9gZhxYYtqmai3J0LEn476Mc0hWE3a2ATsjUPWn/UKBJWdesBoJHItFq2MpV03LT4FiXGCmGCsJcAbadC/Q7ppWKk12eGgJ3OBfQ98h/Fdmi7bzhvW8VeTAHrYbU3WWD3dbnzqPVRU13A2rrNxRzgXv/4w3FfJ2MDkntKnHWHSOFvNcKT9v7jUz6XwL7NhLoKN5obPXowhBiqut4kCga2DJkaNHJDSVAPy2ud+kSIbOENZ3Zm1rT3MXg0vqL01N31ddGx4YbxOqzVd+zaqmb8k9qkOyHqq2RFWWr2eEmaK1Bkm+nbDP10eKd6q6lh+k0hVuQtICAxBDxFwuv/o7GLcxPul2CkFfbfuYVGeHG8fqfX2CLABQJZDf3q4zeSLVv/266KnUONqu85B6nKrj25Fow0STB7JBGbP/Zskufr54lfmyMSLvj9+MLLbmTvG+6VJoP2UJxD0IbngLRQP X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(6133799003)(22082099003)(18002099003)(3023799007)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: NGeUMx5hERQu/aZw5Qy77ExR4I7O6ObDHKexsq3qSnHkcV44Pxmhgee9r23A3wJVjiBJi3BdHrAZN9DVzwEVcyvIoGVDd/DvAIM5OhyYRVBL7C2nC2+SuJ+33io976S0+T8CHJebKohmVaHjx/Wdq9p1ACUHE7EKeLhiIUpACUV0iJ4bRw3SSjoVu3oKSKaporps4x9+s320ItqGo2FuaBFPO5kL1RW8nkIKt37y86vR6JALrAGJqEAUK92mMLlfP1PEa2CfSAib70lmLQEXsrYddgVF+IVl9dv5jjNMz2e9M1CL2YFofJYF1Sv6iBSVm+OQzGgHcPu3DM3i0DvIlQ== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: DU2PEPF0001E9C2.eurprd03.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: ce7539f6-2028-4561-f662-08debccaa915 X-Microsoft-Antispam: BCL:0;ARA:13230040|35042699022|82310400026|14060799003|376014|1800799024|36860700016|6133799003|3023799007|11063799006|18002099003|56012099006|22082099003; X-Microsoft-Antispam-Message-Info: WASkaSLyHI5VUnZ/bSpKHAnU7a1NzeZew0h+eUHdGNUQteq7mkvCsvQhzt9ETbrxAMXy7sNhzkDXngMwWPI5LIF8Qe0+R01lzJ4IKMkbxwdGTJWisROU2WI9pH0/Wp/jYXiTf6u7wh+Rkn1b+OWiv0TfGRmgSelLslFXkhYtGsFjAWafCVCse+MZseRqlA0TtmdBaQqSym5a3QBUBzQ9ekLrbERXLHFgriQRcRkRxYXSDIhG8LQ2Pc4IqWFEq49NWX6ZmNQ6DKn2LgjH3iFXkAvfvp/yHEljGcpzFLlXNiNV6aZjGtH/69OrBzl/B1yBdd73weQZTIkii/e4KtZPhZVkXDgsUWHcWz0x1tukUcoB7K0AKEkUr5w20v17Q3wFRjxylSX3mp8BlnrRCJQyNGbuURvfIb8j11phK/apA8OOfc59a5sElOm30ALGN16/1IRcsIZ/1KQ+Iw9XHAzHj07tiXp3TM4F+8hNiz1IkWzm5t8KE/Dt14xzA0jTpaP9HgjyH3++vWcU04mrKLoUzbxHGQUu1OuMviNNysCZzvjVTLc77lUP7tPLaH2+q1d/bG+cCX9B3VD46fUgV9Fa79Vc1+Gcky50bGgE3KaunDC4nbqEv2Le81OTz1F2Z09gq5INiy4EgMCMPsMMA/shNotYw+J8WZWeaDDaAQcvhWWAOYz8DeXSRd+9CGj88afKivvKupREMcf8R5GF0wdladudPIbR8g+4NHgKh1qlTfk= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(35042699022)(82310400026)(14060799003)(376014)(1800799024)(36860700016)(6133799003)(3023799007)(11063799006)(18002099003)(56012099006)(22082099003);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: G8WjQpbXKivA1lFAb3KKtMzHxfdWh6cFxhZK9OEv5R1GfAMWi6ZJU2TNvw73HCFjCBXBs7HH9BPsroFpbyvJWIZ8BqCQjEx7Ex9OnrNlN/oHaqgTzuklyb8Ia9M+JzOGvsArWiTyemglHUvkVhM30nKFET2UeK5Yx93TliewRKbdePjpOmE6y2wAni3ksOpk3ByErTAs3fQwfrkjk2+hHv7hf4MJEXMatIUqk43888vHLCQfXhWs38mF+Furoez2kNTJfaHzHzU5Ryn5uXiNoSvlG8ihF8W+u6kvkeaUpzyZpV73MWuVGqXsRpq4ApxseScXIE5dXMuiVoaevjUEbONpNY1DeamUIUTWFoQ7Zllhm8GdBhsTGnj7MznHnpCaAQYT6u+uYYimBbzuSVeGMjlY1tyEvDgYuzDRdJu3S2DEbAQVGlD+2gTQlP9SmQqS X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:16.6681 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: e466bfa9-b6d6-4595-f84d-08debccace8a X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: DU2PEPF0001E9C2.eurprd03.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM8PR08MB6578 Content-Type: text/plain; charset="utf-8" Add the VM-side access-window component for v15 GPUs. The new code handles AM message handshakes, requests GPU access from the arbiter, waits for the window-open interrupt, and yields access on suspend. Split panthor_hw_init into bind device and initialize gpu_info after panthor_aw has ensured GPU access. Signed-off-by: Karunika Choo --- drivers/gpu/drm/panthor/Makefile | 1 + drivers/gpu/drm/panthor/panthor_aw.c | 421 +++++++++++++++++++++++ drivers/gpu/drm/panthor/panthor_aw.h | 42 +++ drivers/gpu/drm/panthor/panthor_device.c | 15 +- drivers/gpu/drm/panthor/panthor_device.h | 4 + drivers/gpu/drm/panthor/panthor_hw.c | 8 +- drivers/gpu/drm/panthor/panthor_hw.h | 2 + 7 files changed, 486 insertions(+), 7 deletions(-) create mode 100644 drivers/gpu/drm/panthor/panthor_aw.c create mode 100644 drivers/gpu/drm/panthor/panthor_aw.h diff --git a/drivers/gpu/drm/panthor/Makefile b/drivers/gpu/drm/panthor/Mak= efile index 5d4d0ae64952..aa48212653dc 100644 --- a/drivers/gpu/drm/panthor/Makefile +++ b/drivers/gpu/drm/panthor/Makefile @@ -1,6 +1,7 @@ # SPDX-License-Identifier: GPL-2.0 or MIT =20 panthor-y :=3D \ + panthor_aw.o \ panthor_devfreq.o \ panthor_device.o \ panthor_drv.o \ diff --git a/drivers/gpu/drm/panthor/panthor_aw.c b/drivers/gpu/drm/panthor= /panthor_aw.c new file mode 100644 index 000000000000..00a52175f3a3 --- /dev/null +++ b/drivers/gpu/drm/panthor/panthor_aw.c @@ -0,0 +1,421 @@ +// SPDX-License-Identifier: GPL-2.0 or MIT +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#include + +#include +#include +#include + +#include "panthor_am_msg.h" +#include "panthor_aw.h" +#include "panthor_device.h" +#include "panthor_fw.h" +#include "panthor_hw.h" +#include "panthor_sched.h" + +#include "panthor_trace.h" + +#define WINDOW_CONTROL_BASE 0x0 +#define WINDOW_CONTROL_SIZE 0x1000 + +#define WINDOW_STATUS 0x43c +#define WINDOW_STATUS_IRQ_WINDOW_CONTROL BIT(0) +#define WINDOW_STATUS_IRQ_GPU_CONTROL BIT(1) +#define WINDOW_STATUS_IRQ_GPU_POWER BIT(2) +#define WINDOW_STATUS_IRQ_JOB_CONTROL BIT(3) +#define WINDOW_STATUS_IRQ_MMU_CONTROL BIT(4) +#define WINDOW_STATUS_WINDOW_OPEN BIT(31) + +#define WINDOW_INT_BASE 0x440 +#define WINDOW_IRQ_MESSAGE BIT(0) +#define WINDOW_IRQ_INVALID_ACCESS BIT(1) +#define WINDOW_IRQ_WINDOW_OPENING BIT(2) +#define WINDOW_IRQ_WINDOW_OPENED BIT(3) +#define WINDOW_IRQ_WINDOW_CLOSED BIT(4) + +#define WINDOW_MESSAGE_BASE 0x460 + +#define WINDOW_IRQ_MASK \ + (WINDOW_IRQ_MESSAGE | WINDOW_IRQ_WINDOW_OPENED | WINDOW_IRQ_WINDOW_CLOSED) + +#define PANTHOR_AW_HANDSHAKE_TIMEOUT_MS (5 * MSEC_PER_SEC) +#define PANTHOR_AW_GPU_REQUEST_TIMEOUT_MS (5 * MSEC_PER_SEC) +#define PANTHOR_AW_STATE_TRANSITION_TIMEOUT_MS (5 * MSEC_PER_SEC) + +#define panthor_aw_wait_cond(_aw, _cond, _timeout_ms) \ +({ \ + int __ret =3D 0; \ + if (!wait_event_timeout((_aw)->waitqueue, _cond, \ + msecs_to_jiffies(_timeout_ms))) \ + if (!(_cond)) \ + __ret =3D -ETIMEDOUT; \ + __ret; \ +}) + +struct panthor_aw { + /** @ptdev: Pointer to Panthor device */ + struct panthor_device *ptdev; + + /** @iomem: CPU mapping of WINDOW_CONTROL iomem region */ + void __iomem *iomem; + + /** @irq: IRQ data */ + struct panthor_irq irq; + + /** @msg: Messaging data */ + struct panthor_am_msg msg; + + /** @waitqueue: Event wait queue. Not IRQ safe */ + wait_queue_head_t waitqueue; + + /** @state: Current state of the AW */ + atomic_t state; + + /** @wq: Scheduler workqueue to dispatch events */ + struct workqueue_struct *wq; + + /** @msg_retry_work: Work to resend messages */ + struct work_struct msg_retry_work; +}; + +static bool panthor_aw_is_open(struct panthor_aw *aw) +{ + return gpu_read(aw->iomem, WINDOW_STATUS) & WINDOW_STATUS_WINDOW_OPEN; +} + +static void panthor_aw_state_set(struct panthor_aw *aw, enum aw_states new) +{ + atomic_set(&aw->state, new); + + wake_up_all(&aw->waitqueue); +} + +static bool panthor_aw_state_try_set(struct panthor_aw *aw, + enum aw_states expected, + enum aw_states new) +{ + int old_state =3D atomic_cmpxchg(&aw->state, expected, new); + bool res =3D (old_state =3D=3D expected); + + if (res) + wake_up_all(&aw->waitqueue); + + return res; +} + +static int panthor_aw_state_wait(struct panthor_aw *aw, enum aw_states tar= get, u32 timeout_ms) +{ + return panthor_aw_wait_cond(aw, atomic_read(&aw->state) =3D=3D target, ti= meout_ms); +} + +static int panthor_aw_state_wait_transition(struct panthor_aw *aw, u32 tim= eout_ms) +{ + return panthor_aw_wait_cond( + aw, + (atomic_read(&aw->state) =3D=3D PANTHOR_AW_STATE_READY || + atomic_read(&aw->state) =3D=3D PANTHOR_AW_STATE_GPU_GRANTED), + timeout_ms); +} + +static void panthor_aw_msg_retry_work(struct work_struct *work) +{ + struct panthor_aw *aw =3D + container_of(work, struct panthor_aw, msg_retry_work); + struct panthor_am_msg *msg =3D &aw->msg; + int ret; + + ret =3D panthor_am_msg_retry(msg); + if (ret =3D=3D -EINVAL) + drm_warn(&aw->ptdev->base, "Send FIFO unexpectedly empty"); + + if (ret =3D=3D -EBUSY || ret =3D=3D -EAGAIN) + queue_work(aw->wq, &aw->msg_retry_work); +} + +static void panthor_aw_send_msg(struct panthor_aw *aw, u64 message) +{ + struct panthor_device *ptdev =3D aw->ptdev; + int ret; + + ret =3D panthor_am_msg_send(&aw->msg, message); + if (ret =3D=3D -ENOMEM) + drm_err(&ptdev->base, "Send FIFO is full"); + + if (ret =3D=3D -EBUSY) { + drm_dbg(&ptdev->base, "Pending messages, scheduling retry work"); + queue_work(aw->wq, &aw->msg_retry_work); + } +} + +static void panthor_aw_handshake_handle(struct panthor_aw *aw, u64 message) +{ + struct panthor_device *ptdev =3D aw->ptdev; + bool acked =3D AM_MSG_ACK_GET(message); + u8 version =3D AM_MSG_VERSION_GET(message); + int ret; + + ret =3D panthor_am_msg_version_validate(&aw->msg, version); + if (ret =3D=3D -EOPNOTSUPP) + drm_warn(&ptdev->base, + "Msg protocol version less than minimum supported (%u < %u)", + version, AM_MSG_MIN_SUPPORTED_VERSION); + + if (!acked) { + u64 reply =3D VM_ARB_INIT_MAKE(1, aw->msg.version); + + panthor_aw_send_msg(aw, reply); + + /* TODO: Handle AW restart */ + } + + panthor_aw_state_try_set(aw, PANTHOR_AW_STATE_INIT, PANTHOR_AW_STATE_READ= Y); +} + +static void panthor_aw_handshake_init(struct panthor_aw *aw) +{ + u64 message =3D VM_ARB_INIT_MAKE(0, AM_MSG_CURRENT_VERSION); + + panthor_aw_send_msg(aw, message); +} + +static void panthor_aw_handle_message(struct panthor_aw *aw) +{ + struct panthor_device *ptdev =3D aw->ptdev; + const u64 message =3D panthor_am_msg_read(&aw->msg); + const u8 msg_id =3D AM_MSG_ID_GET(message); + + /* currently only support ARB_VM_INIT */ + if (msg_id =3D=3D ARB_VM_INIT) + panthor_aw_handshake_handle(aw, message); + else + drm_warn(&ptdev->base, "Unsupported msg id (0x%x)", msg_id); +} + + +static irqreturn_t panthor_aw_irq_raw_hander(int irq, void *data) +{ + struct panthor_irq *pirq =3D data; + struct panthor_device *ptdev =3D pirq->ptdev; + struct panthor_aw *aw =3D ptdev->aw; + u32 status; + + scoped_guard(spinlock_irqsave, &pirq->mask_lock) { + if (atomic_read(&pirq->state) !=3D PANTHOR_IRQ_STATE_ACTIVE) + return IRQ_NONE; + } + + status =3D gpu_read(pirq->iomem, INT_STAT); + if (!status) + return IRQ_NONE; + + if (status & WINDOW_IRQ_MESSAGE) + panthor_aw_handle_message(aw); + + /* TODO: handle WINDOW_CLOSED*/ + + if ((status & WINDOW_IRQ_WINDOW_OPENED) && panthor_aw_is_open(aw)) + panthor_aw_state_try_set(aw, PANTHOR_AW_STATE_GPU_REQUEST, + PANTHOR_AW_STATE_GPU_GRANTED); + + gpu_write(pirq->iomem, INT_CLEAR, status); + + return IRQ_HANDLED; +} + +static void panthor_aw_irq_suspend(struct panthor_irq *pirq) +{ + scoped_guard(spinlock_irqsave, &pirq->mask_lock) { + atomic_set(&pirq->state, PANTHOR_IRQ_STATE_SUSPENDING); + gpu_write(pirq->iomem, INT_MASK, 0); + } + synchronize_irq(pirq->irq); + atomic_set(&pirq->state, PANTHOR_IRQ_STATE_SUSPENDED); +} + +static void panthor_aw_irq_resume(struct panthor_irq *pirq) +{ + guard(spinlock_irqsave)(&pirq->mask_lock); + + atomic_set(&pirq->state, PANTHOR_IRQ_STATE_ACTIVE); + gpu_write(pirq->iomem, INT_MASK, pirq->mask); +} + +static int panthor_request_aw_irq(struct panthor_device *ptdev, + struct panthor_irq *pirq, int irq, u32 mask, + void __iomem *iomem) +{ + int ret; + + pirq->ptdev =3D ptdev; + pirq->irq =3D irq; + pirq->mask =3D mask; + pirq->iomem =3D iomem; + spin_lock_init(&pirq->mask_lock); + + ret =3D devm_request_irq(ptdev->base.dev, irq, panthor_aw_irq_raw_hander, + IRQF_SHARED, "panthor-aw", pirq); + if (ret) + return ret; + + panthor_aw_irq_resume(pirq); + + return 0; +} + +static int panthor_aw_request(struct panthor_aw *aw) +{ + int ret; + +again: + switch(atomic_read(&aw->state)) { + case PANTHOR_AW_STATE_GPU_GRANTED: + return 0; + + case PANTHOR_AW_STATE_READY: + break; + + case PANTHOR_AW_STATE_INIT: + panthor_aw_handshake_init(aw); + ret =3D panthor_aw_state_wait(aw, PANTHOR_AW_STATE_READY, + PANTHOR_AW_HANDSHAKE_TIMEOUT_MS); + if (ret) + return ret; + goto again; + default: + ret =3D panthor_aw_state_wait_transition( + aw, PANTHOR_AW_STATE_TRANSITION_TIMEOUT_MS); + if (ret) + return ret; + goto again; + } + + if (!panthor_aw_state_try_set(aw, PANTHOR_AW_STATE_READY, + PANTHOR_AW_STATE_GPU_REQUEST)) + goto again; + + panthor_aw_send_msg(aw, VM_ARB_GPU_REQUEST); + + /* Wait for GPU to be granted */ + ret =3D panthor_aw_state_wait(aw, PANTHOR_AW_STATE_GPU_GRANTED, + PANTHOR_AW_GPU_REQUEST_TIMEOUT_MS); + if (ret) { + panthor_aw_state_set(aw, PANTHOR_AW_STATE_READY); + return ret; + } + + return 0; +} + +static int panthor_aw_yield(struct panthor_aw *aw) +{ + panthor_aw_send_msg(aw, VM_ARB_GPU_STOPPED); + + return panthor_aw_state_wait(aw, PANTHOR_AW_STATE_READY, + PANTHOR_AW_STATE_TRANSITION_TIMEOUT_MS); +} + +int panthor_aw_init(struct panthor_device *ptdev) +{ + struct panthor_aw *aw; + int irq; + int ret; + + if (!panthor_hw_has_gpu_discover(ptdev)) + return 0; + + aw =3D drmm_kzalloc(&ptdev->base, sizeof(*aw), GFP_KERNEL); + if (!aw) + return -ENOMEM; + + aw->wq =3D drmm_alloc_ordered_workqueue(&ptdev->base, "panthor-aw-wq", 0); + if (!aw->wq) + return -ENOMEM; + + aw->ptdev =3D ptdev; + aw->iomem =3D ptdev->iomem; + + INIT_WORK(&aw->msg_retry_work, panthor_aw_msg_retry_work); + + init_waitqueue_head(&aw->waitqueue); + atomic_set(&aw->state, PANTHOR_AW_STATE_INIT); + + panthor_am_msg_init(&aw->msg, aw->iomem + WINDOW_MESSAGE_BASE); + + ptdev->aw =3D aw; + + irq =3D platform_get_irq_byname(to_platform_device(ptdev->base.dev), "gpu= "); + if (irq < 0) + return irq; + + ret =3D panthor_request_aw_irq(ptdev, &aw->irq, irq, WINDOW_IRQ_MASK, + aw->iomem + WINDOW_INT_BASE); + if (ret) + return ret; + + ret =3D panthor_aw_request(aw); + if (ret) + return ret; + + return 0; +} + +void panthor_aw_unplug(struct panthor_device *ptdev) +{ + struct panthor_aw *aw =3D ptdev->aw; + + if (!aw) + return; + + disable_work_sync(&aw->msg_retry_work); + + panthor_aw_irq_suspend(&aw->irq); +} + +int panthor_aw_resume(struct panthor_device *ptdev) +{ + struct panthor_aw *aw =3D ptdev->aw; + int ret; + + if (!aw) + return 0; + + panthor_aw_irq_resume(&aw->irq); + + ret =3D panthor_aw_request(aw); + if (ret) { + drm_warn(&ptdev->base, "Timedout waiting for GPU to be granted"); + goto err_out; + } + + return 0; + +err_out: + panthor_aw_irq_suspend(&aw->irq); + return ret; +} + +int panthor_aw_suspend(struct panthor_device *ptdev) +{ + struct panthor_aw *aw =3D ptdev->aw; + int ret =3D 0; + + /* suspend hw components directly if AW is not supported */ + if (!aw) + return 0; + + if (atomic_read(&aw->state) =3D=3D PANTHOR_AW_STATE_READY) + goto out_irq_suspend; + + if (panthor_aw_state_try_set(aw, PANTHOR_AW_STATE_GPU_GRANTED, + PANTHOR_AW_STATE_GPU_STOPPED)) + ret =3D panthor_aw_yield(aw); + else + ret =3D panthor_aw_state_wait( + aw, PANTHOR_AW_STATE_READY, + PANTHOR_AW_STATE_TRANSITION_TIMEOUT_MS); + +out_irq_suspend: + panthor_aw_irq_suspend(&aw->irq); + return ret; +} diff --git a/drivers/gpu/drm/panthor/panthor_aw.h b/drivers/gpu/drm/panthor= /panthor_aw.h new file mode 100644 index 000000000000..c2b89caa87c4 --- /dev/null +++ b/drivers/gpu/drm/panthor/panthor_aw.h @@ -0,0 +1,42 @@ +/* SPDX-License-Identifier: GPL-2.0 or MIT */ +/* Copyright 2026 ARM Limited. All rights reserved. */ + +#ifndef __PANTHOR_AW_H__ +#define __PANTHOR_AW_H__ + +#include + +struct panthor_device; + +/** + * enum aw_states - Enumeration of possible Access Window states + */ +enum aw_states { + /** @PANTHOR_AW_STATE_INIT: Initial state, prior to handshake. */ + PANTHOR_AW_STATE_INIT =3D 0, + + /** @PANTHOR_AW_STATE_READY: Handshake with Resource Group completed. */ + PANTHOR_AW_STATE_READY, + + /** @PANTHOR_AW_STATE_GPU_REQUEST: AW requested for GPU access. */ + PANTHOR_AW_STATE_GPU_REQUEST, + + /** @PANTHOR_AW_STATE_GPU_GRANTED: AW is granted GPU access. */ + PANTHOR_AW_STATE_GPU_GRANTED, + + /** @PANTHOR_AW_STATE_GPU_STOP: AW is requested to stop GPU access. */ + PANTHOR_AW_STATE_GPU_STOP, + + /** @PANTHOR_AW_STATE_GPU_STOPPED: AW has stopped GPU access. */ + PANTHOR_AW_STATE_GPU_STOPPED, +}; + +int panthor_aw_init(struct panthor_device *ptdev); + +void panthor_aw_unplug(struct panthor_device *ptdev); + +int panthor_aw_resume(struct panthor_device *ptdev); + +int panthor_aw_suspend(struct panthor_device *ptdev); + +#endif diff --git a/drivers/gpu/drm/panthor/panthor_device.c b/drivers/gpu/drm/pan= thor/panthor_device.c index bd417d6ae8c0..7248e2aa9da2 100644 --- a/drivers/gpu/drm/panthor/panthor_device.c +++ b/drivers/gpu/drm/panthor/panthor_device.c @@ -16,6 +16,7 @@ #include #include =20 +#include "panthor_aw.h" #include "panthor_devfreq.h" #include "panthor_device.h" #include "panthor_fw.h" @@ -100,6 +101,7 @@ void panthor_device_unplug(struct panthor_device *ptdev) panthor_gem_shrinker_unplug(ptdev); panthor_gpu_unplug(ptdev); panthor_pwr_unplug(ptdev); + panthor_aw_unplug(ptdev); =20 pm_runtime_dont_use_autosuspend(ptdev->base.dev); pm_runtime_put_sync_suspend(ptdev->base.dev); @@ -255,10 +257,18 @@ int panthor_device_init(struct panthor_device *ptdev) if (ret) goto err_rpm_put; =20 - ret =3D panthor_pwr_init(ptdev); + ret =3D panthor_aw_init(ptdev); if (ret) goto err_rpm_put; =20 + ret =3D panthor_hw_info_init(ptdev); + if (ret) + goto err_unplug_aw; + + ret =3D panthor_pwr_init(ptdev); + if (ret) + goto err_unplug_aw; + ret =3D panthor_gpu_init(ptdev); if (ret) goto err_unplug_pwr; @@ -315,6 +325,9 @@ int panthor_device_init(struct panthor_device *ptdev) err_unplug_pwr: panthor_pwr_unplug(ptdev); =20 +err_unplug_aw: + panthor_aw_unplug(ptdev); + err_rpm_put: pm_runtime_put_sync_suspend(ptdev->base.dev); return ret; diff --git a/drivers/gpu/drm/panthor/panthor_device.h b/drivers/gpu/drm/pan= thor/panthor_device.h index 8b2a9bb426fc..a1092d02a1fe 100644 --- a/drivers/gpu/drm/panthor/panthor_device.h +++ b/drivers/gpu/drm/panthor/panthor_device.h @@ -18,6 +18,7 @@ #include #include =20 +struct panthor_aw; struct panthor_csf; struct panthor_csf_ctx; struct panthor_device; @@ -196,6 +197,9 @@ struct panthor_device { /** @hw: GPU-specific data. */ struct panthor_hw *hw; =20 + /** @aw: AW-specific data */ + struct panthor_aw *aw; + /** @pwr: Power control management data. */ struct panthor_pwr *pwr; =20 diff --git a/drivers/gpu/drm/panthor/panthor_hw.c b/drivers/gpu/drm/panthor= /panthor_hw.c index 52271fb9db52..aa77d1b7f21c 100644 --- a/drivers/gpu/drm/panthor/panthor_hw.c +++ b/drivers/gpu/drm/panthor/panthor_hw.c @@ -326,7 +326,7 @@ static int panthor_gpu_info_init(struct panthor_device = *ptdev) return overload_shader_present(ptdev); } =20 -static int panthor_hw_info_init(struct panthor_device *ptdev) +int panthor_hw_info_init(struct panthor_device *ptdev) { u64 l2_features =3D ptdev->gpu_info.l2_features; u32 major, minor, status; @@ -433,9 +433,5 @@ int panthor_hw_init(struct panthor_device *ptdev) if (ret) return ret; =20 - ret =3D panthor_hw_bind_device(ptdev); - if (ret) - return ret; - - return panthor_hw_info_init(ptdev); + return panthor_hw_bind_device(ptdev); } diff --git a/drivers/gpu/drm/panthor/panthor_hw.h b/drivers/gpu/drm/panthor= /panthor_hw.h index 1b2678ea00db..d60860102b95 100644 --- a/drivers/gpu/drm/panthor/panthor_hw.h +++ b/drivers/gpu/drm/panthor/panthor_hw.h @@ -60,6 +60,8 @@ struct panthor_hw { }; =20 int panthor_hw_init(struct panthor_device *ptdev); +int panthor_hw_info_init(struct panthor_device *ptdev); + int panthor_hw_power_status_register(void); void panthor_hw_power_status_unregister(void); =20 --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from DB3PR0202CU003.outbound.protection.outlook.com (mail-northeuropeazon11010018.outbound.protection.outlook.com [52.101.84.18]) (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 6DA703F6615 for ; Thu, 28 May 2026 15:07:25 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.84.18 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980848; cv=fail; b=LMnP0x1nZqTmF86JdhAZigl6cAr+1R4XN/SDmUZGqFzQz8YJDqC8QLuUZqXLaVRoOzX7IuQEuNRUbRO3yCmR+EIx6IG9HITa7Q8ShSjiCBwCdtPeH5nFwbYKk7N+WYLmPZO/OYp5llkmQE2MBJ28iTnEZq01X+guf7EbVSg7Hh4= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980848; c=relaxed/simple; bh=6UhhjsPlR2cOv99CVS+9gpL/SS43xmjrjQYtuaXzG9U=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=tldB/mVbJFAescPii4SGh+TJBjkaevNTgELEfqh5r2xtm7zcVQC2IQRkyteertli/aFNNqdILLSfsNBHLZEmoPAQ3KxrHpSKS6Z4pWckZMpZ+4pwF6VloTxqDtDlGJp2Kne/B3qJl0/dpD/RDeEKIyEvxfiyKmGT4vg55WTFweo= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=bQFjpbSs; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=bQFjpbSs; arc=fail smtp.client-ip=52.101.84.18 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="bQFjpbSs"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="bQFjpbSs" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=uL3t3obvrpoE5yVD3FTsKBEhu47J+2EeLZqqoPvb0AXx4ak6PM9SglHo3k3fPR2G6qJaCQWhdyLMt0YtSSaWSqKHVQArd73aeW5+Bubxv7JVYRfLAP+xI94WVvNtqHp11JHXnLL/B2YHuEaO7WQ0uYr6ClDaLp2qbJNE5YDCQyHQ5pUXRnJFqvkBsSwTA/b8FSW2t8NhyjIMyRpHKf0hZOpCtfIpUUpolt8ruhyHbujKeseMqAhmFN5wFxL3jxbYbpW1Oun4+A6LI5Q//QCnLnZN6kUO4Mj8XNgrh/GOjqEt/MhZAqPP3eY2+90sYtDUDs0+szIpEvZHWyOhF0g71w== ARC-Message-Signature: i=2; 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=csmd7x8DWA1r/TXv52SWxvm1IWd7JTks7dUJ/LaJN5c=; b=fcZ/JbctwLHx67tLv5IZmHslu3AmVb9nmIBrYsAYNfPC1vF/0uo7B9ghFAJEnd+H1GKpupFhBvjR1IlIiCtklOwWFvBjY1wn049PtmNyZDVUzCKhtM++WZwzTcXVqX7j6xZiyAsY8IbUT4mNwp0ywoW7xWVL68cmjJM/2Mu8WBBqJLoTaDjIpqbG6qLfkwa1HIUMn6Tr3/vyivjoNm9tyhSwNq16VOvq/lTXqI5BIibHSTKNlQjuxwP0bc5QT0gn8Eo4DQBvzYO3gkPQJLEuBhzResv/mODNEeiPhTho+Tneu3A2NoZ5TFcxFPZgXG6dME5OZo7hnjGlTaXLUjbANQ== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=csmd7x8DWA1r/TXv52SWxvm1IWd7JTks7dUJ/LaJN5c=; b=bQFjpbSsHZbrVcYZf+7GqX4RjWIx7Ii46Xwq0H6b0c/CIAn9yAR0tF/z1exvTC+nacDbdgDO7O02a/mXufiSYpWgzupRYY3dyEJmk3X0exE86QeveP7hy8FKQj5flJeQNTaAlkhHRETh2sHTHHbuvF2f2/mEk+ohfYWO8xa43AI= Received: from DUZPR01CA0012.eurprd01.prod.exchangelabs.com (2603:10a6:10:3c3::14) by DU0PR08MB9727.eurprd08.prod.outlook.com (2603:10a6:10:445::19) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.11; Thu, 28 May 2026 15:07:18 +0000 Received: from DB5PEPF00014B89.eurprd02.prod.outlook.com (2603:10a6:10:3c3:cafe::45) by DUZPR01CA0012.outlook.office365.com (2603:10a6:10:3c3::14) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.13 via Frontend Transport; Thu, 28 May 2026 15:07:18 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by DB5PEPF00014B89.mail.protection.outlook.com (10.167.8.197) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.92.5 via Frontend Transport; Thu, 28 May 2026 15:07:18 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=Td9O06qXNmaTA3U9DmXnr213YPqfUxTDjqCUGSe5gdPgg44Jjmh+Vu3X/x6hyQwC/hy1O2ovPWJoxDuTd4B0E2+smu7PWSOyWxXp0A4Oacj4FgxzQOUhwl+nhab5KmFRkBxQ/KRnbjz/qX92Ak5T172E59zSRIG7BPUqZbRM3Wk3R7Zb6DVmVnNx5w5RcfrCTaQvfZ4nl67/cAfcLcayAwAAfSNXd4TZpzJZLCbyrCpwsZBSJ/YODKPmlVeON4/5E0rIj3RTWR8CgAJkVvFbk1jdRLdiRLVt3qzkYn6xNbRl0orXw4e37WOFJJsMbi1k7ZumZVw8j5/BToSn7ne+FA== 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=csmd7x8DWA1r/TXv52SWxvm1IWd7JTks7dUJ/LaJN5c=; b=q+NT7hXa2Jc+erqTFoe3kMz4I9mzNe8B6vdzDxf3TTSw9uGVFtSaYVda5SFZFGGBvYT4wipiepuoiOUThUrN0r8wK+VM60f1Bmadcqu3YVTIuMUZ13PL20Xuult/8BBHDu/FjDp0rwLJZP4xVrPG7BgX6e9Aths7YDFOvd9zR6XsyJsaGGcRDtALDGrPv9PRR058/0t6JnNDhXL4OejDmwPXvQGsU40A1ZQnxhjw4/yXTwHLwXzx4vOUJ062z+tHPL2FvPe25YSYjMeH+u/Pqrmj4u+DQoboO3c9p/3lf6pCPhZQkKhDDUVb+GcVBM1hVcbPLaKukwvMs8gj64Ka3w== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=csmd7x8DWA1r/TXv52SWxvm1IWd7JTks7dUJ/LaJN5c=; b=bQFjpbSsHZbrVcYZf+7GqX4RjWIx7Ii46Xwq0H6b0c/CIAn9yAR0tF/z1exvTC+nacDbdgDO7O02a/mXufiSYpWgzupRYY3dyEJmk3X0exE86QeveP7hy8FKQj5flJeQNTaAlkhHRETh2sHTHHbuvF2f2/mEk+ohfYWO8xa43AI= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:15 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:15 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 16/18] drm/panthor: Synchronize HW component PM transitions Date: Thu, 28 May 2026 16:05:44 +0100 Message-ID: <20260528150546.3168527-17-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: LO4P123CA0184.GBRP123.PROD.OUTLOOK.COM (2603:10a6:600:1a4::9) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|DB5PEPF00014B89:EE_|DU0PR08MB9727:EE_ X-MS-Office365-Filtering-Correlation-Id: 71506bdc-fcb4-4ae5-5c24-08debccacf67 X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|22082099003|18002099003|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: g+bon8hC6YlTgMmt6iCWigP7QxsE6mW9I+ZucB40+fuoL54VRPpDbApgAHcyiV3vmCqT6skxkMXcTrlgycOQLNjot9H5ZvgFSjy+yHnvUo6jn9t78Y6Dl2Mf57F0CgM30HcaDV2D0g0ak1HZAAuDVNrxCd/VQqmZRgIgLbmcQKaUXAczpGhvq9vlQciK1EYCU5lK5kQFbu9jMe0WQY+I7N7lzbaLstpr6tBEitpNzromKpJQNXsc7NmpGW3rtT9mf2vEw2sWYjnUZqKrqj8e2ewc6ZgAW0fnd147cPOH6i1iHs5bGvYdW8S8BfRqwEDzM3aRqyxNGcER69PxcZCXLGNh/jJwVZpUZQtwyuEZZE7Opm8flXysxqDaRZtTWWS6hT9Utd9kM5KppEsfe433Z2+Jy+loTuvwRL+moMJsVALF6aR2BsTJn0p0pCze/vbz6NDmxnifkubhs9sHqcjBLdbLhNS719aAHJ7U01xpZw34EOVzrm3sa8wMJGHLqXB8dNjifwS02WEczYMEkA9UF2zcqK+mdbqswNd0SJXodN+FeYtSn/DX+eDi2BBWQBhyYmdD+SYJZmHy5DI5yxfzhpUDjj6S8aEZLI10qq+k3PdDnn/bsmWbVpEAsRfat28pAxuYJv/eRBpWNCRQFjv9Kq8iwCmibGx7F1DtyymbqCRomJtJLkHpou4dR2E8nKK5 X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(22082099003)(18002099003)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: Z6HkrkPFszYJPLv25v7SlpsrUg+m9mPg6+tnA4k8ZKBD3F/A1al1yxCK9L7hc+lOLGz7dHeOGyN4SBIqXtvFJYSbRqxupvv0oj1l/5iTF3qySQavFidWEdqnfMm4xU1TbbTRx6B5tVh24LXvNg+cAgcO+u2DnvfH1jEIlRLPx8t5M/0BKDMJimtYu4rxxaXjcVif4+xdgClmjbMngZb86qv3Z2N38VE63/+vMHoJiVs4v8n0+qZu1/OcrQA7JzLmYSZZ6NhSdZbO7iQUdtt/dIHIpWUA90XdpaBiVZQPC8Wxb/Osrj9DOK6O4BtzdhjXmowknEK9EPjZIOO6q5ting== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: DB5PEPF00014B89.eurprd02.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: d1a4648e-7967-4d82-e58a-08debccaa9ed X-Microsoft-Antispam: BCL:0;ARA:13230040|14060799003|376014|35042699022|1800799024|36860700016|82310400026|11063799006|22082099003|18002099003|56012099006; X-Microsoft-Antispam-Message-Info: bkSukHIEaUZ4pN7v6jL4Kg4seFn+98ohe8cfhd5G/Nz8Xsxor4xwP8HUZxR3fKZ/2b609xEqYTW6eK9WhYrOAmuvIjmrlAgPNH8K6pKpenQ9ih6hTNtqUC8iLPd9+wKyQacbjgnyWKKGVp817NHJ0uToOo1rZ73CFrERQ0p0VAPuuUYfAONxOC7f8X9JYH/UWYDtNinp2sdyr7oZBW0XO0CbZPVlyrjiyNmIps53ds4qTLYXSEdDDJ/sb71RO/xoAdv5s195CkMFyxPF2OzMI34IYUvqEpqzwWwueG4Izu6EF/ahyx7q1l/Me+YahOJrIY49uOoEA+sCSjNDVKtHlyluN01TB2dnzwVPNsMau1ooROGOaOxGyAJb4t0HibB1UpdaqMu3fIFd+mZHWKpNe3sJU/6RAt6WkjCgErGLMpjzcIQE2L4cg6wjRi5PZvbqXNLx7LuDsq/UzRaRdUFPhkBVe4dXcFpdB0IW1ZHc2TtVsmWH25rRGLzUESzADv4DdSwAv0PoZH6VcIs5YlcvsuXsQ/WRVjMc6KJZSXgwQZhbsa5jwNuGzFxlIH0m1tHLXy5OVEpoHO/R5BvmPYn862DSR98/4VKqn+WQAT2l7mSL1p0NAthtOiHxqJ+FDxbi3w26YdeYtGBos6+J9XJM/GiWtkW5B7u9z457aDFSGjcz85+0ZCjPZopvsttLDFHsSOrTCJnpO/FPwP2tJqMcVND5Nx8jlJSTOKetqQ+tq+8= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(14060799003)(376014)(35042699022)(1800799024)(36860700016)(82310400026)(11063799006)(22082099003)(18002099003)(56012099006);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: Mu4pYI2RS1NzqO105+GaO7CSRyJbuZY8fi+h+BP1VxrqVkEVVPyhB2QsrJqz19eWI6PajTzoCBksLBx6BsnO6gzAtWfMo5Z6QYlhRGK6KJhDgp0XguIXxTKfaPuXagFrbBFTl96qc7xp0T/nVqJQOMJDff7GfxFRa8P8lxLOII3uZufWL+P7KbzxJMcwwRJv8evtcEl4jUnJmAK/JAt+QIeeTFPnnnC8dqAgdGeiMMUYJY7JmiXbRQS6Ydp6VIJ27UdslHl9teTcIarHcBVrIIGteeBjhscNhIZrEva/dxupx9tUZRCcTjtUkOv9rglzVse1HuoolQ91vjMzNYL6+sRzSSM+xuJoe6XrXaugiZhqyJ2d2ITOLGEwwL2pte8YD37KSMjeETYFq/EO2Y9ZLordbbWT0xdl6IbVS7fxRAZt6qW5GoemCtPL8tZxFFAo X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:18.1295 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 71506bdc-fcb4-4ae5-5c24-08debccacf67 X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: DB5PEPF00014B89.eurprd02.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU0PR08MB9727 Content-Type: text/plain; charset="utf-8" Split hardware component suspend/resume from the top-level device PM path and protect those transitions with a dedicated mutex and state flag. This lets access-window arbitration suspend or resume GPU components while runtime PM state remains controlled by the outer PM path. Signed-off-by: Karunika Choo --- drivers/gpu/drm/panthor/panthor_aw.c | 1 - drivers/gpu/drm/panthor/panthor_device.c | 50 +++++++++++++++++++++--- drivers/gpu/drm/panthor/panthor_device.h | 9 +++++ 3 files changed, 53 insertions(+), 7 deletions(-) diff --git a/drivers/gpu/drm/panthor/panthor_aw.c b/drivers/gpu/drm/panthor= /panthor_aw.c index 00a52175f3a3..146907a3098d 100644 --- a/drivers/gpu/drm/panthor/panthor_aw.c +++ b/drivers/gpu/drm/panthor/panthor_aw.c @@ -192,7 +192,6 @@ static void panthor_aw_handle_message(struct panthor_aw= *aw) drm_warn(&ptdev->base, "Unsupported msg id (0x%x)", msg_id); } =20 - static irqreturn_t panthor_aw_irq_raw_hander(int irq, void *data) { struct panthor_irq *pirq =3D data; diff --git a/drivers/gpu/drm/panthor/panthor_device.c b/drivers/gpu/drm/pan= thor/panthor_device.c index 7248e2aa9da2..a8aedbee7c97 100644 --- a/drivers/gpu/drm/panthor/panthor_device.c +++ b/drivers/gpu/drm/panthor/panthor_device.c @@ -179,6 +179,10 @@ int panthor_device_init(struct panthor_device *ptdev) if (ret) return ret; =20 + ret =3D drmm_mutex_init(&ptdev->base, &ptdev->pm.hw_component_lock); + if (ret) + return ret; + ret =3D drmm_mutex_init(&ptdev->base, &ptdev->pm.mmio_lock); if (ret) return ret; @@ -289,6 +293,9 @@ int panthor_device_init(struct panthor_device *ptdev) if (ret) goto err_unplug_mmu; =20 + atomic_set(&ptdev->pm.hw_component_state, + PANTHOR_DEVICE_PM_STATE_ACTIVE); + ret =3D panthor_sched_init(ptdev); if (ret) goto err_unplug_fw; @@ -477,21 +484,55 @@ int panthor_device_mmap_io(struct panthor_device *ptd= ev, struct vm_area_struct * return 0; } =20 -static int panthor_device_resume_hw_components(struct panthor_device *ptde= v) +int panthor_device_suspend_hw_components(struct panthor_device *ptdev) +{ + guard(mutex)(&ptdev->pm.hw_component_lock); + + if (atomic_read(&ptdev->pm.hw_component_state) =3D=3D + PANTHOR_DEVICE_PM_STATE_SUSPENDED) + return 0; + + if (!pm_runtime_suspended(ptdev->base.dev)) { + panthor_fw_suspend(ptdev); + panthor_mmu_suspend(ptdev); + panthor_gpu_suspend(ptdev); + panthor_pwr_suspend(ptdev); + } + + atomic_set(&ptdev->pm.hw_component_state, + PANTHOR_DEVICE_PM_STATE_SUSPENDED); + + return 0; +} + +int panthor_device_resume_hw_components(struct panthor_device *ptdev) { int ret; =20 + guard(mutex)(&ptdev->pm.hw_component_lock); + + if (atomic_read(&ptdev->pm.hw_component_state) =3D=3D + PANTHOR_DEVICE_PM_STATE_ACTIVE) + return 0; + panthor_pwr_resume(ptdev); panthor_gpu_resume(ptdev); panthor_mmu_resume(ptdev); =20 ret =3D panthor_fw_resume(ptdev); - if (!ret) + if (!ret) { + atomic_set(&ptdev->pm.hw_component_state, + PANTHOR_DEVICE_PM_STATE_ACTIVE); return 0; + } =20 panthor_mmu_suspend(ptdev); panthor_gpu_suspend(ptdev); panthor_pwr_suspend(ptdev); + + atomic_set(&ptdev->pm.hw_component_state, + PANTHOR_DEVICE_PM_STATE_SUSPENDED); + return ret; } =20 @@ -602,10 +643,7 @@ int panthor_device_suspend(struct device *dev) * The end of the reset will happen in the resume path though. */ panthor_sched_suspend(ptdev); - panthor_fw_suspend(ptdev); - panthor_mmu_suspend(ptdev); - panthor_gpu_suspend(ptdev); - panthor_pwr_suspend(ptdev); + panthor_device_suspend_hw_components(ptdev); drm_dev_exit(cookie); } =20 diff --git a/drivers/gpu/drm/panthor/panthor_device.h b/drivers/gpu/drm/pan= thor/panthor_device.h index a1092d02a1fe..d7beb7165577 100644 --- a/drivers/gpu/drm/panthor/panthor_device.h +++ b/drivers/gpu/drm/panthor/panthor_device.h @@ -350,6 +350,12 @@ struct panthor_device { =20 /** @recovery_needed: True when a resume attempt failed. */ atomic_t recovery_needed; + + /** @hw_component_lock: Lock protects HW component PM state transitions = */ + struct mutex hw_component_lock; + + /** @hw_component_state: HW component PM state */ + atomic_t hw_component_state; } pm; =20 /** @profile_mask: User-set profiling flags for job accounting. */ @@ -439,6 +445,9 @@ int panthor_device_mmap_io(struct panthor_device *ptdev, int panthor_device_resume(struct device *dev); int panthor_device_suspend(struct device *dev); =20 +int panthor_device_suspend_hw_components(struct panthor_device *ptdev); +int panthor_device_resume_hw_components(struct panthor_device *ptdev); + static inline int panthor_device_resume_and_get(struct panthor_device *ptd= ev) { int ret =3D pm_runtime_resume_and_get(ptdev->base.dev); --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from MRWPR03CU001.outbound.protection.outlook.com (mail-francesouthazon11011018.outbound.protection.outlook.com [40.107.130.18]) (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 B90023FA5F2 for ; Thu, 28 May 2026 15:07:26 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.130.18 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980850; cv=fail; b=Cac4/Ofm9aripu2GO537qA/yXUDodT4AXx4mG+hLlaVNNuQgMOf0BYGrrPiVj7qLbvI4fBjBlKecImwFau4iVgTF7761VX+/L56M+pdr69jQ7Kfxbrz3Kc0p2ixt8FCg+ALYmF/D0iV/NtxBh/o3XFhCTWvQrpg2ifba5lCOvHg= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980850; c=relaxed/simple; bh=gJiT4YxDE1sGfrjYE6+8xMrrP1figSXQfcsAyztw7sk=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=euLLh08/Lf70KIl5XTLX0big8XTkemyQa/65gfYi8kFJv4u4RfYBeZ4OWJL487FyeMBGR7u+CiIPirTaPAE3FH5WEYfWQ1YNKFlKB0jh9TrUJZpFZ9+UqYwV79OAEYcdMhqZO7TU64U803VnFLAyQjVxbRZ++zJQx/Ftt6WIvx8= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=TQT4EZSq; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=TQT4EZSq; arc=fail smtp.client-ip=40.107.130.18 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="TQT4EZSq"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="TQT4EZSq" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=uT3XmRc5/izL3S0szYisZeLORIkQ6tExE6f+kcK8TBlITBeM316PfLGK6QZx06qDSjJ02sn9NpYWGkchB6bl0Yucp0jq5DtQ9Xre3zMY+qqWzpH9tTAfyBbygAbyxsqxd1hAlHF+Cxh5abOcQH2XFB2swsZdL5kaGHpUZpQHrFqYrwZGLwDpIxM60hbcKzFUG/kjCUR3eiE1Yc0Kd05IP2WmHwrXOBfnZ+/zAKqpN49aqmzGChjWRsBqlm8cdL7mn+nG2zJf1OHP/MZO1wX7PaB0PoKSTghdxcgA3/dwOVOE1530bltzrE4ODvskBj/j1QFDHfUHvTtrF2GPZaEOiQ== ARC-Message-Signature: i=2; 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=0GGdxHBOa9r1LNad74mK2GtFm8dSCyrwLQCVWshe5Fk=; b=iOoGtU6YA1IZ38FrVdB/f6NAsCpuNxIkyloOWXrtkqgt3CPqTHZhRdFzKHt9Y7E59W52yhJfVVF0mcE5+lJzC9Ybkbfr7gRi1NLdsJZLEZNDmQ8YjtYks5WYLDNC4W3AlOuYjvOSP1oJkb1SiziBbpln9F4O/gRX3jkyq8Y3Mxu/uOlQhtLiu9/bO/mfAmQFa7a8MUVLJugyxpteJWDry+OjgxADjzyBku27nMTeg+BnH98YRvT4M4mnBdbjpEdiFNAcFI+bCH8RtVQk5sOZUyFmAvE6AlE1XFDkMrx5qJeUwXIBK1I7BF/WEfDiqNjEcwRizo4tT3GeUPw9y8F7Ag== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=0GGdxHBOa9r1LNad74mK2GtFm8dSCyrwLQCVWshe5Fk=; b=TQT4EZSqW3VHoe6rBqY6jhWq9LqlHCBYX6Wv1JZGF2IvAm9xqJsgxdXvCKKef9588NFzKLLncuzNyY4uWzkQv1jcBK/hscKEWAA1VTrcjBdYxu5RO0a66zSEVpTC9GWXYT0peiTuH3hVy7gD0HqqSXUWare0lyIafDG0MMI4j9g= Received: from DU2P250CA0008.EURP250.PROD.OUTLOOK.COM (2603:10a6:10:231::13) by VE1PR08MB5695.eurprd08.prod.outlook.com (2603:10a6:800:1b3::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:07:20 +0000 Received: from DU6PEPF0000A7DF.eurprd02.prod.outlook.com (2603:10a6:10:231:cafe::45) by DU2P250CA0008.outlook.office365.com (2603:10a6:10:231::13) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.14 via Frontend Transport; Thu, 28 May 2026 15:07:20 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by DU6PEPF0000A7DF.mail.protection.outlook.com (10.167.8.36) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.92.5 via Frontend Transport; Thu, 28 May 2026 15:07:20 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=qVeHtTyu2GNvqrxO4kBQtKnb8RSDgcH1zrOiwMMC3l4/A8RBk8xmdWAk5Euwj1LuxCkh2xNYvoAXE7T33wOSXG17at+IQokIDPWqVioa7w8/QUTB0U4RW6az4E/labx5+SJ6+FR4Uj3XgttVljzdc4J5kDwJzAYt06JhoUoI+koaApt+SYXb4xY3zb2UBSva9jG5GEPem6L6qr9auqZBc8i7Jz30SJG3scWhW9DxsWFfk+9OoGZUWWd8sjjFs7NVisnCeQtu+CPtUx8ZNs7703r/IKCKG4dCnBCqFA0dHXiASqiET7LgUazLAZzTLIyarW/PnQ5nONYMDKrW2eytOA== 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=0GGdxHBOa9r1LNad74mK2GtFm8dSCyrwLQCVWshe5Fk=; b=RwPjXBexdIE/RIePNfKN3cS9U7lUhrZbqi8LWwXiuUq8M42XvGrlmlikFauoZcYxqe916j5xfZDeiIiJra9YE6GuMcaB1dcjX22TTHqe/UEC1o4PrpJwtpVlT5Y4r8UQzSIe9ZjK/Ko/Q/hXC41Y/C7cS2Y/EQDVhizxbRsKYlaJgu3CFOgGomSO0DfUJ1jahbcxvGL6KolSs220w7OeOWTfTNdg+4CDM/3SqoEYGDAmqVHKRAGKsshJ+4Gln9s9xNRopI9Lq51atTk9IMdXMT3dljyVfDmMoAs9WX6beRZf3CdjoSOiF1QSBiWTMVuJYS0+3i5Ex7sjh5b6m4fa9Q== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=0GGdxHBOa9r1LNad74mK2GtFm8dSCyrwLQCVWshe5Fk=; b=TQT4EZSqW3VHoe6rBqY6jhWq9LqlHCBYX6Wv1JZGF2IvAm9xqJsgxdXvCKKef9588NFzKLLncuzNyY4uWzkQv1jcBK/hscKEWAA1VTrcjBdYxu5RO0a66zSEVpTC9GWXYT0peiTuH3hVy7gD0HqqSXUWare0lyIafDG0MMI4j9g= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by DU2PR08MB10015.eurprd08.prod.outlook.com (2603:10a6:10:49f::5) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.14; Thu, 28 May 2026 15:06:16 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:16 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 17/18] drm/panthor: Route HW component PM through access windows Date: Thu, 28 May 2026 16:05:45 +0100 Message-ID: <20260528150546.3168527-18-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: LO4P265CA0219.GBRP265.PROD.OUTLOOK.COM (2603:10a6:600:33a::17) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|DU2PR08MB10015:EE_|DU6PEPF0000A7DF:EE_|VE1PR08MB5695:EE_ X-MS-Office365-Filtering-Correlation-Id: 553644c5-1bb3-40d8-31b8-08debccad0fa X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|376014|1800799024|366016|6133799003|22082099003|18002099003|56012099006|11063799006; X-Microsoft-Antispam-Message-Info-Original: 1qcWu6BTYuP/mUQ9FypLb+x3+DTdBXy+hyUvi7tKQyYFfkuZVm80kjPYp+5nTm06Ma6bAxKdfuUmyMI3Ver1hrQ6x4EZDLDnJt2uSOWuDNdz2sd2VNFYaR3RkaUWRcejTpDnGKUlsWV6QRHXrMVF1KlyDEekgoUVBmGByntoStEvSXRgDzbHyE/8/EDe+Ao3oblsATpK7U9YxHCuH/kEa1aXdmQuE68ORFE0N5saLIquAJKz7iCTO2WVdLblPFnsI7cLLs4/EMVYllvUwCe+ipCJG/n+WzW+JZ9ldccqAYFyxFyCOtyR8mj0VqsOIIVzyonjf2ePkdPvO9UzgRgIucLkv0vYITbjBwAzPNuCwpYCbf/NxeOdFl/ZtqhWjgDoPqxikFS3wjinfsMDVjG2gUZJ02N5pie+NaPFcm4+lS4cXLWSdlw9qVwq5b/eRurJGe/OlFyJ3ahLr4u4FvhVpJmkTTXzkgbp2B6Sa+ibYkLyqQEleby1lnTUGNMmEV2n71taN5pUDFeChmNFLaKa7/sY6WEGNGPOjKM4rY1k+cUWUQsbX75e7CyU8Hxgq9Zeo1LgDumOxWfpHjxFRCnc+rPZ+F/kowj2nKsIyrxkYcmxKRslG/RPMOSXnhXfwuXcu/gb1WjzbwQPgQ0/hJgL+MYQtjhPd82vZ0Cugsg+sCunHNQU9+YCo5zLs792pspx X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(376014)(1800799024)(366016)(6133799003)(22082099003)(18002099003)(56012099006)(11063799006);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: pAkyNCvFFxLXNhSXjnmJ/b0DOnV4N38Fjqllp+gWyzBlbj37hIpuZC1woP8do8TPOByzYFuRKKzg2+HwMNoPHqaCjTZJAD0dNGlTOC9cwv8LPDf/eyhnr/kju8gc9Ae7/61OdrvZv6LX4sQeP6G4lupvH7J+CZcB25G5Jw++BnrEztiL7f9C4NlktL9JBmYcM9nPg+GJOaV9sBdXPSWKX9HO7RrNHzZPn7b3eQnZ6QkkdEqnYMXF6dIjWugxV0/iiD5huPmebS2xHpG9fi81iqqFB+pt8phYcpmcjFiEAQgXPlY9dWC2nRKUYc/YMrJNgQVO1RhNGWH6D6SnoJ7llg== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DU2PR08MB10015 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: DU6PEPF0000A7DF.eurprd02.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: a0da8565-a961-47f2-0564-08debccaaab6 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|35042699022|82310400026|36860700016|14060799003|376014|56012099006|18002099003|6133799003|11063799006|22082099003; X-Microsoft-Antispam-Message-Info: NL7ZL32DOmbXb/mxqTdrpvrtEdD3utuhG3mHw4E+01LbZfhDgbtE9Ql/akx68q76ZG25A9BhLsLQIFeEgSrW48XaNfE7a0XKEsIPb7xwIe0N3kt3p8k6K55RLXFqRp8c7l5hexov/j6NeGk60HLFwfA4am7iRB2OKv53l4NEnYEACmM7VX3sGcRpOxbKuVtKyQQ3Rob2d5QMnUYr30b8FUt6aRdtJNOXaR2ucivWaQaQSUcypQzzoL/Fn/y6Tb8BgRTE8sHEFjbsQGpy3Y2U1ICW9c4cTmZ9JyW8u3qB3Ph7IL/5zA4oW8fHf3PyvTtKfWN3PQkME8UyiWUM1NRQZvK8+SWgT3AiDqCjNIkbVkRMF9K2Sdw4g7lN33IiMOt+F//KaLmplgvixFCxVecPu/zLwYpAF/bJd111K5vBfSd0hrFzeWAdPfw8P2nZnjGooQueRHVHGQwPgxl6/7uTuUdwgiZzAKN1d/TbQvek14jDS3YWRQ/JxFjILfMC3OiMYg9o+2PoAy475kZseFn0vgdfl8xfnVM7GI0GpDWbEI3Y5A78CJk/OhYf9pQOwOOa/lJjsFrUlQqG3EMGF55s/AZmikGTl/v8PLKR44+rnz0Zn4gZxAISiaFS85QgREx5Gs6wfnJhA/EHzjd9gF51K1oOWe4NSjtv+h6vogPsQJ+al3mgL+pQ/8fpU2gaqpJs8WGWnpvjc0j169NqW65DkP8gWuyjjK4DwCGBR+izF8M= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(1800799024)(35042699022)(82310400026)(36860700016)(14060799003)(376014)(56012099006)(18002099003)(6133799003)(11063799006)(22082099003);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: SYTRvR2lCYmuMVV+64P+eS+NilL2fR9+UP+a8hKVlXE6Oy/zTm8DXdN3LGnICvG4SyPP1DHojzHXAhkrbsn+rQ78JdZHJiM6mSTwroLljxR8u+HR174+KVEiyVYAjCluGA7x0ZZDZhs/8TmrOFsLFf9RsgC+E/V7RWXmMJ679B/kwS0B+7RZ7btTitWhKO0CAuQAcSZ85TLmYqrMw5R+bipFRuVUP7Ke6VbPrG3Byqan6F4n6PXjcKJAFj+8LVkKLZb4m4UUkdhtblckhxcCOnhbNpQbf+oU+xLC09v/zbaCvjudoAJA4fqXJY3bEMzLy0XLEzx8JiENb8jR4NNfezAJnuel3jNutdVMR2B+130kpuj+5s3/JmfftI/CyXmGG9EZQkOijG4HQs2utur9PnVyRjbQhfvpgebI7zZjc1QWUpYyv7h2gXjUjGWmgHsH X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:20.7583 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 553644c5-1bb3-40d8-31b8-08debccad0fa X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: DU6PEPF0000A7DF.eurprd02.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: VE1PR08MB5695 Content-Type: text/plain; charset="utf-8" Make access-window resume and suspend own GPU access when AW support is present, while keeping the direct HW component PM path for older GPUs. Handle WINDOW_CLOSED and arbiter restart events, defer post-yield cleanup to workqueue context, and make panthor_device_resume_and_get() ensure that GPU access is obtained before callers touch hardware. Signed-off-by: Karunika Choo --- drivers/gpu/drm/panthor/panthor_aw.c | 182 ++++++++++++++++++++--- drivers/gpu/drm/panthor/panthor_aw.h | 8 +- drivers/gpu/drm/panthor/panthor_device.c | 6 +- drivers/gpu/drm/panthor/panthor_device.h | 16 +- 4 files changed, 187 insertions(+), 25 deletions(-) diff --git a/drivers/gpu/drm/panthor/panthor_aw.c b/drivers/gpu/drm/panthor= /panthor_aw.c index 146907a3098d..7c7637a8a9f1 100644 --- a/drivers/gpu/drm/panthor/panthor_aw.c +++ b/drivers/gpu/drm/panthor/panthor_aw.c @@ -77,6 +77,9 @@ struct panthor_aw { =20 /** @msg_retry_work: Work to resend messages */ struct work_struct msg_retry_work; + + /** @post_yield_work: Work to yield the GPU */ + struct work_struct post_yield_work; }; =20 static bool panthor_aw_is_open(struct panthor_aw *aw) @@ -118,6 +121,52 @@ static int panthor_aw_state_wait_transition(struct pan= thor_aw *aw, u32 timeout_m timeout_ms); } =20 +static void panthor_aw_post_yield_work(struct work_struct *work) +{ + struct panthor_aw *aw =3D + container_of(work, struct panthor_aw, post_yield_work); + struct panthor_device *ptdev =3D aw->ptdev; + struct device *dev =3D ptdev->base.dev; + int ret; + + /* Something else has progressed the state to READY. */ + if (atomic_read(&aw->state) !=3D PANTHOR_AW_STATE_GPU_STOPPED) + return; + + /* + * Ensure in-progress resume is completed and prevent future RPM suspend + * to keep the clocks turned on when accessing HW registers. + */ + pm_runtime_get_noresume(dev); + pm_runtime_barrier(dev); + + ret =3D panthor_device_suspend_hw_components(ptdev); + if (ret) + dev_warn(dev, "Failed to suspend hardware components."); + + panthor_aw_state_set(aw, PANTHOR_AW_STATE_READY); + + /* + * schedule an immediate tick to re-evaluate if there is any additional + * work. This will request access to the GPU again and if the driver has + * gone idle, it will yield GPU access via the runtime suspend path. + */ + panthor_sched_resume(ptdev); + + pm_runtime_put_noidle(dev); +} + +static bool panthor_aw_schedule_post_yield_work(struct panthor_aw *aw) +{ + if (panthor_aw_state_try_set(aw, PANTHOR_AW_STATE_GPU_GRANTED, + PANTHOR_AW_STATE_GPU_STOPPED)) { + queue_work(aw->wq, &aw->post_yield_work); + return true; + } + + return false; +} + static void panthor_aw_msg_retry_work(struct work_struct *work) { struct panthor_aw *aw =3D @@ -166,7 +215,9 @@ static void panthor_aw_handshake_handle(struct panthor_= aw *aw, u64 message) =20 panthor_aw_send_msg(aw, reply); =20 - /* TODO: Handle AW restart */ + /* Arbiter was restarted. Window is no longer granted access. */ + if (panthor_aw_schedule_post_yield_work(aw)) + drm_info(&ptdev->base, "Arbiter was restarted, yielding GPU"); } =20 panthor_aw_state_try_set(aw, PANTHOR_AW_STATE_INIT, PANTHOR_AW_STATE_READ= Y); @@ -192,6 +243,38 @@ static void panthor_aw_handle_message(struct panthor_a= w *aw) drm_warn(&ptdev->base, "Unsupported msg id (0x%x)", msg_id); } =20 +static void panthor_aw_handle_window_closed(struct panthor_aw *aw) +{ + struct panthor_device *ptdev =3D aw->ptdev; + + /* Ignore this WINDOW_CLOSED as part of reset operation. */ + if (panthor_device_reset_is_pending(ptdev)) + return; + + if (atomic_read(&aw->state) =3D=3D PANTHOR_AW_STATE_GPU_STOPPED || + atomic_read(&aw->state) =3D=3D PANTHOR_AW_STATE_READY || + atomic_read(&aw->state) =3D=3D PANTHOR_AW_STATE_INIT) { + drm_warn(&ptdev->base, "Unexpected WINDOW_CLOSED received"); + return; + } + + /* + * Window may have been closed immediately after opening. + * Setting state back to READY will prevent WINDOW_OPENDED from + * mistakenly transitioning the state to GRANTED. + */ + if (panthor_aw_state_try_set(aw, PANTHOR_AW_STATE_GPU_REQUEST, + PANTHOR_AW_STATE_READY)) + return; + + /* Triggerred from messaged-based yield. Unblock its wait */ + if (panthor_aw_state_try_set(aw, PANTHOR_AW_STATE_STOPPED_IDLE, + PANTHOR_AW_STATE_READY)) + return; + + panthor_aw_schedule_post_yield_work(aw); +} + static irqreturn_t panthor_aw_irq_raw_hander(int irq, void *data) { struct panthor_irq *pirq =3D data; @@ -211,7 +294,9 @@ static irqreturn_t panthor_aw_irq_raw_hander(int irq, v= oid *data) if (status & WINDOW_IRQ_MESSAGE) panthor_aw_handle_message(aw); =20 - /* TODO: handle WINDOW_CLOSED*/ + if (status & WINDOW_IRQ_WINDOW_CLOSED) + panthor_aw_handle_window_closed(aw); + =20 if ((status & WINDOW_IRQ_WINDOW_OPENED) && panthor_aw_is_open(aw)) panthor_aw_state_try_set(aw, PANTHOR_AW_STATE_GPU_REQUEST, @@ -264,6 +349,7 @@ static int panthor_request_aw_irq(struct panthor_device= *ptdev, =20 static int panthor_aw_request(struct panthor_aw *aw) { + struct panthor_device *ptdev =3D aw->ptdev; int ret; =20 again: @@ -271,6 +357,9 @@ static int panthor_aw_request(struct panthor_aw *aw) case PANTHOR_AW_STATE_GPU_GRANTED: return 0; =20 + case PANTHOR_AW_STATE_GPU_STOPPED: + return -EAGAIN; + case PANTHOR_AW_STATE_READY: break; =20 @@ -278,14 +367,22 @@ static int panthor_aw_request(struct panthor_aw *aw) panthor_aw_handshake_init(aw); ret =3D panthor_aw_state_wait(aw, PANTHOR_AW_STATE_READY, PANTHOR_AW_HANDSHAKE_TIMEOUT_MS); - if (ret) + if (ret) { + drm_err(&ptdev->base, + "Timed out waiting for handshake to complete"); return ret; + } + goto again; default: ret =3D panthor_aw_state_wait_transition( aw, PANTHOR_AW_STATE_TRANSITION_TIMEOUT_MS); - if (ret) + if (ret) { + drm_err(&ptdev->base, + "Timed out waiting for AW state transition"); return ret; + } + goto again; } =20 @@ -295,15 +392,20 @@ static int panthor_aw_request(struct panthor_aw *aw) =20 panthor_aw_send_msg(aw, VM_ARB_GPU_REQUEST); =20 - /* Wait for GPU to be granted */ - ret =3D panthor_aw_state_wait(aw, PANTHOR_AW_STATE_GPU_GRANTED, - PANTHOR_AW_GPU_REQUEST_TIMEOUT_MS); + ret =3D panthor_aw_wait_cond( + aw, atomic_read(&aw->state) !=3D PANTHOR_AW_STATE_GPU_REQUEST, + PANTHOR_AW_GPU_REQUEST_TIMEOUT_MS); if (ret) { - panthor_aw_state_set(aw, PANTHOR_AW_STATE_READY); + if (!panthor_aw_state_try_set(aw, PANTHOR_AW_STATE_GPU_REQUEST, + PANTHOR_AW_STATE_READY)) + goto again; + + drm_err(&ptdev->base, + "Timed out waiting for AW GPU to be granted"); return ret; } =20 - return 0; + goto again; } =20 static int panthor_aw_yield(struct panthor_aw *aw) @@ -335,6 +437,7 @@ int panthor_aw_init(struct panthor_device *ptdev) aw->iomem =3D ptdev->iomem; =20 INIT_WORK(&aw->msg_retry_work, panthor_aw_msg_retry_work); + INIT_WORK(&aw->post_yield_work, panthor_aw_post_yield_work); =20 init_waitqueue_head(&aw->waitqueue); atomic_set(&aw->state, PANTHOR_AW_STATE_INIT); @@ -367,6 +470,7 @@ void panthor_aw_unplug(struct panthor_device *ptdev) return; =20 disable_work_sync(&aw->msg_retry_work); + disable_work_sync(&aw->post_yield_work); =20 panthor_aw_irq_suspend(&aw->irq); } @@ -376,17 +480,48 @@ int panthor_aw_resume(struct panthor_device *ptdev) struct panthor_aw *aw =3D ptdev->aw; int ret; =20 + /* resume hw components directly if AW is not supported */ if (!aw) - return 0; + return panthor_device_resume_hw_components(ptdev); =20 panthor_aw_irq_resume(&aw->irq); =20 +again: ret =3D panthor_aw_request(aw); + if (ret) + goto err_out; + + ret =3D panthor_device_resume_hw_components(ptdev); if (ret) { - drm_warn(&ptdev->base, "Timedout waiting for GPU to be granted"); + /* Yield GPU access if HW components failed to resume */ + if (panthor_aw_state_try_set(aw, PANTHOR_AW_STATE_GPU_GRANTED, + PANTHOR_AW_STATE_STOPPED_IDLE)) { + /* + * If failure is caused by WINDOW_CLOSED and the IRQ is + * handled after this condition, AW may emit a rogue + * idle event that will be ignored by the arbitration + * scheduler. WINDOW_CLOSED handler will then transition + * the state back to READY. + */ + panthor_aw_yield(aw); + } + goto err_out; } =20 + /* + * WINDOW_CLOSED won the race. post_yield_work owns component cleanup + * and will transition state to READY after this PM transition is + * complete. + */ + if (atomic_read(&aw->state) =3D=3D PANTHOR_AW_STATE_GPU_STOPPED) { + ret =3D -EAGAIN; + goto err_out; + } + + if (atomic_read(&aw->state) !=3D PANTHOR_AW_STATE_GPU_GRANTED) + goto again; + return 0; =20 err_out: @@ -401,20 +536,33 @@ int panthor_aw_suspend(struct panthor_device *ptdev) =20 /* suspend hw components directly if AW is not supported */ if (!aw) - return 0; + return panthor_device_suspend_hw_components(ptdev); =20 if (atomic_read(&aw->state) =3D=3D PANTHOR_AW_STATE_READY) goto out_irq_suspend; =20 + if (atomic_read(&aw->state) =3D=3D PANTHOR_AW_STATE_GPU_GRANTED) { + ret =3D panthor_device_suspend_hw_components(ptdev); + if (ret) + goto out_irq_suspend; + } + if (panthor_aw_state_try_set(aw, PANTHOR_AW_STATE_GPU_GRANTED, - PANTHOR_AW_STATE_GPU_STOPPED)) + PANTHOR_AW_STATE_STOPPED_IDLE)) { ret =3D panthor_aw_yield(aw); - else - ret =3D panthor_aw_state_wait( - aw, PANTHOR_AW_STATE_READY, - PANTHOR_AW_STATE_TRANSITION_TIMEOUT_MS); + if (ret) + panthor_aw_state_set(aw, PANTHOR_AW_STATE_READY); + } =20 out_irq_suspend: panthor_aw_irq_suspend(&aw->irq); return ret; } + +int panthor_aw_ensure_gpu_access(struct panthor_device *ptdev) +{ + if (!ptdev->aw) + return 0; + + return panthor_aw_resume(ptdev); +} diff --git a/drivers/gpu/drm/panthor/panthor_aw.h b/drivers/gpu/drm/panthor= /panthor_aw.h index c2b89caa87c4..7a46a1e18093 100644 --- a/drivers/gpu/drm/panthor/panthor_aw.h +++ b/drivers/gpu/drm/panthor/panthor_aw.h @@ -24,10 +24,10 @@ enum aw_states { /** @PANTHOR_AW_STATE_GPU_GRANTED: AW is granted GPU access. */ PANTHOR_AW_STATE_GPU_GRANTED, =20 - /** @PANTHOR_AW_STATE_GPU_STOP: AW is requested to stop GPU access. */ - PANTHOR_AW_STATE_GPU_STOP, + /** @PANTHOR_AW_STATE_STOPPED_IDLE: AW has stopped GPU access. */ + PANTHOR_AW_STATE_STOPPED_IDLE, =20 - /** @PANTHOR_AW_STATE_GPU_STOPPED: AW has stopped GPU access. */ + /** @PANTHOR_AW_STATE_GPU_STOPPED: Window was closed, cleanup required. */ PANTHOR_AW_STATE_GPU_STOPPED, }; =20 @@ -39,4 +39,6 @@ int panthor_aw_resume(struct panthor_device *ptdev); =20 int panthor_aw_suspend(struct panthor_device *ptdev); =20 +int panthor_aw_ensure_gpu_access(struct panthor_device *ptdev); + #endif diff --git a/drivers/gpu/drm/panthor/panthor_device.c b/drivers/gpu/drm/pan= thor/panthor_device.c index a8aedbee7c97..441fe89d2e0a 100644 --- a/drivers/gpu/drm/panthor/panthor_device.c +++ b/drivers/gpu/drm/panthor/panthor_device.c @@ -570,11 +570,11 @@ int panthor_device_resume(struct device *dev) atomic_set(&ptdev->reset.pending, 0); } =20 - ret =3D panthor_device_resume_hw_components(ptdev); + ret =3D panthor_aw_resume(ptdev); if (ret && ptdev->reset.fast) { drm_err(&ptdev->base, "Fast reset failed, trying a slow reset"); ptdev->reset.fast =3D false; - ret =3D panthor_device_resume_hw_components(ptdev); + ret =3D panthor_aw_resume(ptdev); } =20 if (!ret) @@ -643,7 +643,7 @@ int panthor_device_suspend(struct device *dev) * The end of the reset will happen in the resume path though. */ panthor_sched_suspend(ptdev); - panthor_device_suspend_hw_components(ptdev); + panthor_aw_suspend(ptdev); drm_dev_exit(cookie); } =20 diff --git a/drivers/gpu/drm/panthor/panthor_device.h b/drivers/gpu/drm/pan= thor/panthor_device.h index d7beb7165577..d01456637f4c 100644 --- a/drivers/gpu/drm/panthor/panthor_device.h +++ b/drivers/gpu/drm/panthor/panthor_device.h @@ -18,6 +18,8 @@ #include #include =20 +#include "panthor_aw.h" + struct panthor_aw; struct panthor_csf; struct panthor_csf_ctx; @@ -464,8 +466,18 @@ static inline int panthor_device_resume_and_get(struct= panthor_device *ptdev) * succeeded. Given resume errors are not expected, this is probably * something we can live with. */ - if (ret && atomic_cmpxchg(&ptdev->pm.recovery_needed, 1, 0) =3D=3D 1) - pm_runtime_set_suspended(ptdev->base.dev); + if (ret) { + if (atomic_cmpxchg(&ptdev->pm.recovery_needed, 1, 0) =3D=3D 1) + pm_runtime_set_suspended(ptdev->base.dev); + + return ret; + } + + ret =3D panthor_aw_ensure_gpu_access(ptdev); + if (ret) { + pm_runtime_put_autosuspend(ptdev->base.dev); + return ret; + } =20 return ret; } --=20 2.43.0 From nobody Mon Jun 8 14:37:08 2026 Received: from DU2PR03CU002.outbound.protection.outlook.com (mail-northeuropeazon11011071.outbound.protection.outlook.com [52.101.65.71]) (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 9522023AB81 for ; Thu, 28 May 2026 15:07:32 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.101.65.71 ARC-Seal: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980855; cv=fail; b=G+6Cfy8mnnh4nutAxYdye0oqeJF0TzmNHMolIV1GVSgGvc6nVs1lAS8hjuz+i/Tiv7VLtMKetDNsFqowDwH0CkackvSxlDErLRPCN+AKVIHmia9a/a2P5idv2pSpj2H/gVIbiRqj3AEOQqzsf0nARLmZDQE2R174J56NK54hRog= ARC-Message-Signature: i=3; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1779980855; c=relaxed/simple; bh=7EzqBUBkfJrX9/AK/jwp82We00hSl2NRTBMHP0Ottv0=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=a/OYcx74VJYt2q6NQjgNRFAe6rbYT5ww9J9hX4l/st8GAQx/boWaW53ej+pT37mWZ92ZPhTlU8PZwaPXN+pugs+/UDCxewz4lqlsKTROCwJMEWtla3rAgTl/VRdCbd00AWs+uj+mu0oqhadhVFfc1mOExLai7lGhqIrfgheC16w= ARC-Authentication-Results: i=3; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com; spf=pass smtp.mailfrom=arm.com; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=reYIqc12; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b=reYIqc12; arc=fail smtp.client-ip=52.101.65.71 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=arm.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=arm.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="reYIqc12"; dkim=pass (1024-bit key) header.d=arm.com header.i=@arm.com header.b="reYIqc12" ARC-Seal: i=2; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=pass; b=jiZpZ0OUbfLRl2B2IU5fy1Yss8vRdCA3RISkQFfPH/V7IxfoBPGkt87CbwNAN81ZXEgni36jnQK3FXm+Js2zpVSYAklM1X4wM2NL6ZJv0akgOUcMzjz8ID5ae1K1jalANnQtP48zQsq2C2BroJ8GBUsLj9+LmG2s1xzLU0/ecvBKmu982kkT1P07a7xuoRcHPno8+Fv9YvF53T/SmTtnIDltB8SETHIyYyQckGYxy5P8fV9pFEtIXm0+1h53WNt+uaeCzbie+PjMYgpiNERo0FFcGNh3BiM5CVLTODbE4CiOVS4KqqlnRuL7RwV6tW21V/s/tDAmPPqwnPfWFvUyLw== ARC-Message-Signature: i=2; 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=iHO6gZg8CVx7MINayXVwxMkx3G31mn71D7xZPPWmgeU=; b=pFXUcOUJLo48ZwRymvkno1ESoUpDftl618PTeJwvYNrr34yqoM8UhjEyLbrItb9hjJW3cQ0zi8mDJMK5EnSq33iEjFri/M3aeXDk47uYOMPL6YZ5XBXSN200a2Zf3DyqU5GIHJYPRforCGcrUcW30vMm3C8VCbgzt28xO2xnBWDvZra6bZRSTqvb/m6/p8934Ez4qXUfdas9nZIXryXi0euo4V1y7PcPfcLCcZWurojW7ZVEMtX1O71Kvcx1peQYMbiBQwOulII6nWLknYr5D/YqaEGu8JA5+MkZ0azfzO9BvLm++EFUprG2gm1c6Km/JJVAqUOpsLoYrXKKeAivuw== ARC-Authentication-Results: i=2; mx.microsoft.com 1; spf=pass (sender ip is 4.158.2.129) smtp.rcpttodomain=lists.freedesktop.org smtp.mailfrom=arm.com; dmarc=pass (p=none sp=none pct=100) action=none header.from=arm.com; dkim=pass (signature was verified) header.d=arm.com; arc=pass (0 oda=1 ltdi=1 spf=[1,1,smtp.mailfrom=arm.com] dkim=[1,1,header.d=arm.com] dmarc=[1,1,header.from=arm.com]) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=iHO6gZg8CVx7MINayXVwxMkx3G31mn71D7xZPPWmgeU=; b=reYIqc12nnAgqsFVmya50WmH9/ipFk4s5zUxzL48xAyYLh0J4OSw+BsZ0q0sm5MwI9pSKH8CuHps07JFXqxNKgVAwfATYtVT3r+o52PKkpIGMpXbyCChtyHZrtUQUwjHG1A5kzUvdgmLqEgNqMXFotzzYieGQLLTDHEdS13bWkg= Received: from CWLP265CA0414.GBRP265.PROD.OUTLOOK.COM (2603:10a6:400:1b6::17) by GVXPR08MB10688.eurprd08.prod.outlook.com (2603:10a6:150:153::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.71.13; Thu, 28 May 2026 15:07:21 +0000 Received: from AMS0EPF0000019C.eurprd05.prod.outlook.com (2603:10a6:400:1b6:cafe::1d) by CWLP265CA0414.outlook.office365.com (2603:10a6:400:1b6::17) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.71.13 via Frontend Transport; Thu, 28 May 2026 15:07:21 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 4.158.2.129) smtp.mailfrom=arm.com; dkim=pass (signature was verified) header.d=arm.com;dmarc=pass action=none header.from=arm.com; Received-SPF: Pass (protection.outlook.com: domain of arm.com designates 4.158.2.129 as permitted sender) receiver=protection.outlook.com; client-ip=4.158.2.129; helo=outbound-uk1.az.dlp.m.darktrace.com; pr=C Received: from outbound-uk1.az.dlp.m.darktrace.com (4.158.2.129) by AMS0EPF0000019C.mail.protection.outlook.com (10.167.16.248) with Microsoft SMTP Server (version=TLS1_3, cipher=TLS_AES_256_GCM_SHA384) id 15.21.92.5 via Frontend Transport; Thu, 28 May 2026 15:07:21 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=SpRcyjvKpd1kC/Grt3vZNT4zcg8xRvGWecrDBZKh6g00QBYczkgdwIYm7Fy4NtxMjjC1Q84bEhugGYRkrckhZVkS8EuV/Xy06hIBGZ0WLh/IamxpwZvyow816KuorUTqweGer547EuGMHuHP28hL3WL9U4syLLM8l2eOixkNF6crGO0cdFaDpz/4t2rQS5jZzVCih9JhqxSri6inS+QpBorE/BPKZCYoMcDEe5Zeujvp3rQbU/nNAwnIUACHAQdzY4caZt1RJ2/2pzqdu39TneB6TiGSkXKFnK0bLD/eqQlnbdDXoEjWENGKaQgV0sVefW/axPG0ZMUYoE51h7YNyA== 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=iHO6gZg8CVx7MINayXVwxMkx3G31mn71D7xZPPWmgeU=; b=qY63skG4ePcnCMWJ7oRnaGZB6Lk35bIk4LnIhUXaJazucaIZ6w6IfyusibbBkMwg8E6/aINarqgFTLxkPU8bowbkPsFzpB90/SKR2efvfYkO/NZQNtfEAdvMT+hBfTw592eXwMD0s+aHLM3WEye5N3zlrPXITtwoWV9fbg/PIu1UCiNOcIaBCV7Lc0tJL0A49Qumox3XisISC7De8PUMP4wHNZrpO4//3tLR2WN/v4D9mzCuTM5hQq2Pxkoc74+TNRfJ8qJXi6e2VdsU99I6yE+6t4+izesq69V6yTenEtWjYZF7Ho18enN1IA+5dlz25hMaEYD9dR/ZQW6fjH/57w== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=arm.com; dmarc=pass action=none header.from=arm.com; dkim=pass header.d=arm.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=arm.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=iHO6gZg8CVx7MINayXVwxMkx3G31mn71D7xZPPWmgeU=; b=reYIqc12nnAgqsFVmya50WmH9/ipFk4s5zUxzL48xAyYLh0J4OSw+BsZ0q0sm5MwI9pSKH8CuHps07JFXqxNKgVAwfATYtVT3r+o52PKkpIGMpXbyCChtyHZrtUQUwjHG1A5kzUvdgmLqEgNqMXFotzzYieGQLLTDHEdS13bWkg= Authentication-Results-Original: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=arm.com; Received: from VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) by PR3PR08MB5754.eurprd08.prod.outlook.com (2603:10a6:102:91::15) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.21.48.14; Thu, 28 May 2026 15:06:18 +0000 Received: from VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d]) by VI0PR08MB11200.eurprd08.prod.outlook.com ([fe80::27c:ea0c:e75a:d41d%5]) with mapi id 15.21.0071.011; Thu, 28 May 2026 15:06:18 +0000 From: Karunika Choo To: dri-devel@lists.freedesktop.org Cc: nd@arm.com, Boris Brezillon , Steven Price , Liviu Dudau , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , linux-kernel@vger.kernel.org Subject: [RFC PATCH 18/18] drm/panthor: Tolerate access-window loss during HW waits Date: Thu, 28 May 2026 16:05:46 +0100 Message-ID: <20260528150546.3168527-19-karunika.choo@arm.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20260528150546.3168527-1-karunika.choo@arm.com> References: <20260528150546.3168527-1-karunika.choo@arm.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: LO4P123CA0553.GBRP123.PROD.OUTLOOK.COM (2603:10a6:600:33b::7) To VI0PR08MB11200.eurprd08.prod.outlook.com (2603:10a6:800:257::18) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-TrafficTypeDiagnostic: VI0PR08MB11200:EE_|PR3PR08MB5754:EE_|AMS0EPF0000019C:EE_|GVXPR08MB10688:EE_ X-MS-Office365-Filtering-Correlation-Id: f1582b5e-54f3-47a8-1ab5-08debccad146 X-LD-Processed: f34e5979-57d9-4aaa-ad4d-b122a662184d,ExtAddr,ExtAddr x-checkrecipientrouted: true NoDisclaimer: true X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam-Untrusted: BCL:0;ARA:13230040|1800799024|376014|366016|56012099006|6133799003|3023799007|11063799006|22082099003|18002099003; X-Microsoft-Antispam-Message-Info-Original: OE7W/K3kBsPYnkel28DDL7SdtyY+67Q1/ZX+FPIljL87RY9PacmTvVsdmEa3z7GO6sHuKOiSiwdqu8EtFn53X9/ffJHYh+vwfUftLtjP2+EqIUkKvKSKwT+BfLpI9HoebkCcd5BQktRk8MKwsvllfVDbgRdUtAkSyIdAH27A1O60LKUwbAlt8LGhU7FVVedeRpVCgCEan+SCpt10us/H9/8+GR71JotCp0JrfbqfmSKZ5xYb45Y9PlATh1oJFmXGy2lhaHJJtix4fRBBK9AT4nEKj8DWi5nJS3+8S4gyjONVE9BBTvWlpASaIa76sw5d80UuvoC7c3MdX3inq+x5VCt+BjQmlqtJWgM1uUtXHyRrJmt/o3jHYhx+VDptdg2emSVJL8ptV1/w+mxT0jWjSDMEFKIaE/JcIX+PD3A7WxbupuGowpR7u1OHcpzMA8T9qByZzYUgXn4FXvL05oE3056mPMoQqdhctIwd+TQ/eXM+0876zaCoXKQptb0f0I65LRw9AAN11Ytq4BsFWNUnhYkUhyN7/ZJXlFICJ/1gq3NUDHju/xMHRof+ApWeF5WDqsvNIEh0wp+K8ysMPrWbjWTSUnh44U7Xwe0D+1u0kphsifmlZP3S49eP2iBNupBQRyyCubJnppCeBaoV7oZij11TDrwrH6rqEzqdghjAkYBas2V+vJy5D1wBBv9r/EZD X-Forefront-Antispam-Report-Untrusted: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI0PR08MB11200.eurprd08.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(1800799024)(376014)(366016)(56012099006)(6133799003)(3023799007)(11063799006)(22082099003)(18002099003);DIR:OUT;SFP:1101; X-Exchange-RoutingPolicyChecked: e1Mcw0BAsF8G3L23nd/cXRUIf6xZP9k2A2Y8OCestN9grD2BgyPrxX9q6Qto4GVn9ZpbP3/017qLNPVwPsd0WuWDXNpcmDeJAZmyCy05/bRPPgGgHYiF/TFtBxO4rrTUL6vOOSsv7VfWoobGzKom8W2iCA+6JwEbET/KRVeiY0FpW1AaKqzprPHzByaYisR/E4HTtwv2cM9ZZaNpGoKykhyKsvaD4h2wzqQa0+4mKOc/pNpBYDolvTNkhg/I4Nco9RgCI4NX+e3Q+w+Cu/ENHXd/JZ2/eUnNuNpUJdITbo4OxE07ceIQqAH8rJYvsrzFBF3AdxgLVymzyENIdMnNUg== X-MS-Exchange-Transport-CrossTenantHeadersStamped: PR3PR08MB5754 X-EOPAttributedMessage: 0 X-MS-Exchange-Transport-CrossTenantHeadersStripped: AMS0EPF0000019C.eurprd05.prod.outlook.com X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id-Prvs: 25825e00-4e30-4812-84c9-08debccaab82 X-Microsoft-Antispam: BCL:0;ARA:13230040|376014|14060799003|36860700016|35042699022|82310400026|1800799024|11063799006|56012099006|6133799003|22082099003|18002099003|3023799007; X-Microsoft-Antispam-Message-Info: 2M7582sSgSXIM7Lm3bxAmZLX3Rjm7GvP99OZkSaONe3S/7GSQGv6fU4QBHF8felOdy3sdQfuSJFWDU/rC84ZDxIUdzZlsBr+CnGMBY4H8fgd+uv8B4BGMxiJa15E+WpAILVLdlPvEANGG+VTDmGdJf193c+LEi+ccYyCWTE9x8URwgf7/T5qrC9IBv4aClZ/JkBtRv72SH1zhD2FDXOGSI6EyiuJx60EMoZjhvEeWkqrdJx2r/7kwhRJRL3dRlpT78I43hveCvTMY6n24W70MBi2OqDMMDY2nw6TM1azJgg5EuruZfx7IwmkUxpFXpfewtPQrteIkWUabQaCdTfEQVExd4XcK+SEAce6auu2KWP0hYAgWKGb21z5Ws9v4h7DHgEfx6bmxmOEK5YzSctAQFDd3NilYlIa/+ma4QYbJafssqroZeclFlkZzq4oAeBm9ZvYpPIeCleaq9soHI8EMHtYt9E1f1QeYXUuuZ9Q90E5maWGQifE3YD1KCxHeDfYFurgiUWBehde+Z+l3PMVZIbfqs4GGQJu2znk61Z48QBHEtkMmmPk42zyQZPjGrNa1jQ5RFUnokUr5AR1D5diRthw9xqjY7yiDZYfKCb4kNX/2X0p0gGyfwqK0Z8h2u6EbvPDDd4q3CzmQwKFnRP90vhind9y4XDJ+1QeRaMts5zv13yDFjfXYCFzlV5hf0+7maCVfx4O89wp3JNtlGsklOL0LgzWMWbCUsgsqTGLp38= X-Forefront-Antispam-Report: CIP:4.158.2.129;CTRY:GB;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:outbound-uk1.az.dlp.m.darktrace.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230040)(376014)(14060799003)(36860700016)(35042699022)(82310400026)(1800799024)(11063799006)(56012099006)(6133799003)(22082099003)(18002099003)(3023799007);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: 8CthnJG6ikt3t/9JbuR1NK51yO9jEmX+EVCJwVdfYwGWeFnSA3NYZa0xmRY4FJWScCohpcxPW4iPDz2NVWQDGI0BkSdX74/Q00iyREZOO0nYSbjnb6bcaz8Bvweumq/vUR3lFnsJuOsu1L0+Z9py2QbEyTUPpWUX29Ir7FPawZY88XN2MyI9WeVJrDaILHNLwv02tjaftIC+f7YuQqe7FtnjiNHGy6eK6HTjufDDGOcOY4yDYbU4MpxYk5YjtOYyHr8SDhJd8M8I65S6bcjkpCq3mYSauKpoJ6rV2GUFy0HVb5AWEo2yfd/t2aNNGwfVKei6vI/HgsqCA8AyBc0Diw39VJWKyOv7/GTrl88XdCBOx80k+uw4kDS8bhIAG6bVkUCh2cKNOWHLjWQWV4ajekhcdnlZmWDzT2DdNF+ZBo1cXnPCBSantoQf36/SGQTQ X-OriginatorOrg: arm.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 May 2026 15:07:21.2575 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: f1582b5e-54f3-47a8-1ab5-08debccad146 X-MS-Exchange-CrossTenant-Id: f34e5979-57d9-4aaa-ad4d-b122a662184d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=f34e5979-57d9-4aaa-ad4d-b122a662184d;Ip=[4.158.2.129];Helo=[outbound-uk1.az.dlp.m.darktrace.com] X-MS-Exchange-CrossTenant-AuthSource: AMS0EPF0000019C.eurprd05.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: GVXPR08MB10688 Content-Type: text/plain; charset="utf-8" The arbiter can close the access window while the driver is waiting for GPU, power, or firmware acknowledgements. In that case the pending MMIO wait cannot complete, but it should not be treated as a hardware timeout or trigger recovery. Add a helper to report whether the access window still owns GPU access and use it to suppress timeout handling once access has been revoked. Also skip deferred scheduler FW event processing when the window is no longer available. Signed-off-by: Karunika Choo --- drivers/gpu/drm/panthor/panthor_aw.c | 8 ++++++++ drivers/gpu/drm/panthor/panthor_aw.h | 2 ++ drivers/gpu/drm/panthor/panthor_gpu.c | 4 +++- drivers/gpu/drm/panthor/panthor_pwr.c | 27 +++++++++++++++++++------ drivers/gpu/drm/panthor/panthor_sched.c | 9 ++++++--- 5 files changed, 40 insertions(+), 10 deletions(-) diff --git a/drivers/gpu/drm/panthor/panthor_aw.c b/drivers/gpu/drm/panthor= /panthor_aw.c index 7c7637a8a9f1..f23022e2b4cd 100644 --- a/drivers/gpu/drm/panthor/panthor_aw.c +++ b/drivers/gpu/drm/panthor/panthor_aw.c @@ -566,3 +566,11 @@ int panthor_aw_ensure_gpu_access(struct panthor_device= *ptdev) =20 return panthor_aw_resume(ptdev); } + +bool panthor_aw_has_gpu_access(struct panthor_device *ptdev) +{ + if (!ptdev->aw) + return true; + + return (atomic_read(&ptdev->aw->state) =3D=3D PANTHOR_AW_STATE_GPU_GRANTE= D); +} diff --git a/drivers/gpu/drm/panthor/panthor_aw.h b/drivers/gpu/drm/panthor= /panthor_aw.h index 7a46a1e18093..1da613fa330a 100644 --- a/drivers/gpu/drm/panthor/panthor_aw.h +++ b/drivers/gpu/drm/panthor/panthor_aw.h @@ -41,4 +41,6 @@ int panthor_aw_suspend(struct panthor_device *ptdev); =20 int panthor_aw_ensure_gpu_access(struct panthor_device *ptdev); =20 +bool panthor_aw_has_gpu_access(struct panthor_device *ptdev); + #endif diff --git a/drivers/gpu/drm/panthor/panthor_gpu.c b/drivers/gpu/drm/pantho= r/panthor_gpu.c index 3c88a25287bf..129bb3779ebd 100644 --- a/drivers/gpu/drm/panthor/panthor_gpu.c +++ b/drivers/gpu/drm/panthor/panthor_gpu.c @@ -17,6 +17,7 @@ #include #include =20 +#include "panthor_aw.h" #include "panthor_device.h" #include "panthor_device_io.h" #include "panthor_gpu.h" @@ -352,7 +353,8 @@ int panthor_gpu_flush_caches(struct panthor_device *ptd= ev, msecs_to_jiffies(100))) { spin_lock_irqsave(&ptdev->gpu->reqs_lock, flags); if ((ptdev->gpu->pending_reqs & GPU_IRQ_CLEAN_CACHES_COMPLETED) !=3D 0 && - !(gpu_read(gpu->irq.iomem, INT_RAWSTAT) & GPU_IRQ_CLEAN_CACHES_COMPL= ETED)) + !(gpu_read(gpu->irq.iomem, INT_RAWSTAT) & GPU_IRQ_CLEAN_CACHES_COMPL= ETED) && + panthor_aw_has_gpu_access(ptdev)) ret =3D -ETIMEDOUT; else ptdev->gpu->pending_reqs &=3D ~GPU_IRQ_CLEAN_CACHES_COMPLETED; diff --git a/drivers/gpu/drm/panthor/panthor_pwr.c b/drivers/gpu/drm/pantho= r/panthor_pwr.c index b833e4559e45..0c3fa311c1af 100644 --- a/drivers/gpu/drm/panthor/panthor_pwr.c +++ b/drivers/gpu/drm/panthor/panthor_pwr.c @@ -10,6 +10,7 @@ #include #include =20 +#include "panthor_aw.h" #include "panthor_device.h" #include "panthor_device_io.h" #include "panthor_gpu_regs.h" @@ -118,7 +119,8 @@ static int panthor_pwr_reset(struct panthor_device *ptd= ev, u32 reset_cmd) msecs_to_jiffies(PWR_RESET_TIMEOUT_MS))) { guard(spinlock_irqsave)(&ptdev->pwr->reqs_lock); =20 - if (reset_pending(ptdev) && !reset_irq_raised(ptdev)) { + if (reset_pending(ptdev) && !reset_irq_raised(ptdev) && + panthor_aw_has_gpu_access(ptdev)) { drm_err(&ptdev->base, "RESET timed out (0x%x)", reset_cmd); return -ETIMEDOUT; } @@ -262,9 +264,14 @@ static int panthor_pwr_domain_transition(struct pantho= r_device *ptdev, u32 cmd, =20 panthor_pwr_write_command(ptdev, pwr_cmd, mask); =20 - ret =3D gpu_read64_poll_timeout(pwr->iomem, ready_reg, val, (mask & val) = =3D=3D expected_val, + ret =3D gpu_read64_poll_timeout(pwr->iomem, ready_reg, val, + ((mask & val) =3D=3D expected_val || + !panthor_aw_has_gpu_access(ptdev)), 100, timeout_us); if (ret) { + if (!panthor_aw_has_gpu_access(ptdev)) + return 0; + drm_err(&ptdev->base, "timeout waiting on %s power domain transition, cmd(0x%x), arg(0x%llx)", get_domain_name(domain), pwr_cmd, mask); @@ -326,9 +333,13 @@ static int retract_domain(struct panthor_device *ptdev= , u32 domain) * allow-flag will be set with delegated-flag being cleared. */ ret =3D gpu_read64_poll_timeout(pwr->iomem, PWR_STATUS, val, - ((delegated_mask | allow_mask) & val) =3D=3D allow_mask, 10, - PWR_TRANSITION_TIMEOUT_US); + (((delegated_mask | allow_mask) & val) =3D=3D allow_mask || + !panthor_aw_has_gpu_access(ptdev)), + 10, PWR_TRANSITION_TIMEOUT_US); if (ret) { + if (!panthor_aw_has_gpu_access(ptdev)) + return 0; + drm_err(&ptdev->base, "Retracting %s domain timeout, cmd(0x%x)", get_domain_name(domain), pwr_cmd); return ret; @@ -383,9 +394,13 @@ static int delegate_domain(struct panthor_device *ptde= v, u32 domain) * allow-flag will be cleared with delegated-flag being set. */ ret =3D gpu_read64_poll_timeout(pwr->iomem, PWR_STATUS, val, - ((delegated_mask | allow_mask) & val) =3D=3D delegated_mask, + (((delegated_mask | allow_mask) & val) =3D=3D delegated_mask || + !panthor_aw_has_gpu_access(ptdev)), 10, PWR_TRANSITION_TIMEOUT_US); if (ret) { + if (!panthor_aw_has_gpu_access(ptdev)) + return 0; + drm_err(&ptdev->base, "Delegating %s domain timeout, cmd(0x%x)", get_domain_name(domain), pwr_cmd); return ret; @@ -512,7 +527,7 @@ void panthor_pwr_l2_power_off(struct panthor_device *pt= dev) const u64 pwr_status =3D gpu_read64(pwr->iomem, PWR_STATUS); =20 /* Abort if L2 power off constraints are not satisfied */ - if (!(pwr_status & l2_allow_mask)) { + if (!(pwr_status & l2_allow_mask) && panthor_aw_has_gpu_access(ptdev)) { drm_warn(&ptdev->base, "Power off L2 domain not allowed"); return; } diff --git a/drivers/gpu/drm/panthor/panthor_sched.c b/drivers/gpu/drm/pant= hor/panthor_sched.c index 5b34032deff8..f4bfb8fab0dd 100644 --- a/drivers/gpu/drm/panthor/panthor_sched.c +++ b/drivers/gpu/drm/panthor/panthor_sched.c @@ -1875,7 +1875,10 @@ static void process_fw_events_work(struct work_struc= t *work) u32 events =3D atomic_xchg(&sched->fw_events, 0); struct panthor_device *ptdev =3D sched->ptdev; =20 - mutex_lock(&sched->lock); + guard(mutex)(&sched->lock); + + if (!panthor_aw_has_gpu_access(ptdev)) + return; =20 if (events & JOB_INT_GLOBAL_IF) { sched_process_global_irq_locked(ptdev); @@ -1888,8 +1891,6 @@ static void process_fw_events_work(struct work_struct= *work) sched_process_csg_irq_locked(ptdev, csg_id); events &=3D ~BIT(csg_id); } - - mutex_unlock(&sched->lock); } =20 /** @@ -1983,6 +1984,8 @@ static int csgs_upd_ctx_apply_locked(struct panthor_d= evice *ptdev, csg_iface =3D panthor_fw_get_csg_iface(ptdev, csg_id); =20 ret =3D panthor_fw_csg_wait_acks(ptdev, csg_id, req_mask, &acked, 100); + if (ret && !panthor_aw_has_gpu_access(ptdev)) + ret =3D 0; =20 if (acked & CSG_ENDPOINT_CONFIG) csg_slot_sync_priority_locked(ptdev, csg_id); --=20 2.43.0