From patchwork Fri Jan 10 15:46:28 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Krzysztof Karas X-Patchwork-Id: 13935072 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 277B9E77188 for ; Fri, 10 Jan 2025 15:47:25 +0000 (UTC) Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id 93B7710F115; Fri, 10 Jan 2025 15:47:24 +0000 (UTC) Authentication-Results: gabe.freedesktop.org; dkim=pass (2048-bit key; unprotected) header.d=intel.com header.i=@intel.com header.b="cbzgejDc"; dkim-atps=neutral Received: from mgamail.intel.com (mgamail.intel.com [198.175.65.11]) by gabe.freedesktop.org (Postfix) with ESMTPS id 3411110E075; Fri, 10 Jan 2025 15:47:23 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1736524043; x=1768060043; h=date:from:to:cc:subject:message-id:mime-version; bh=txcn1Dt++OcMgItlzhO14t89rakJDLcz5rhFWAqttBI=; b=cbzgejDc37FI9/d1lrqsMfsAjr82q14ZraTjO9WKFnYcRNw0DmOgSrqK acTO1egWT5JC04lQ/VH3Aq/FppSWKYFSvey9WQTT9pn/PKGyOBEeyIPAc QUxLaP3xuXkIYXMEVw8eBNidrEEgT7q9ePkkoXv3TFA0j7kSlTlMYV+Pj Btb1tf+OxUi7uw+FjFlshx3kQMGZTdHqeC8jbgKx3NN16evgZccRcWTB4 X/arlVaupy8P3yf/52LFzfhSyMnuedoDpJi/G7nP1BJ5awKEHMBB/bGfT cuA8/XH3X/xm/+mtAIJULm0o0mIj7+gFF8tGfSLNRmz5SnwAseiCPhWvz w==; X-CSE-ConnectionGUID: UuWTYXRXRdWE2QSBXKWBdQ== X-CSE-MsgGUID: Dxnlw+MKQX6mFDniZTLvtQ== X-IronPort-AV: E=McAfee;i="6700,10204,11311"; a="47316312" X-IronPort-AV: E=Sophos;i="6.12,303,1728975600"; d="scan'208";a="47316312" Received: from orviesa003.jf.intel.com ([10.64.159.143]) by orvoesa103.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 10 Jan 2025 07:47:23 -0800 X-CSE-ConnectionGUID: lupx/CKCSsurs19fOdvT9g== X-CSE-MsgGUID: kMS0yIajQau1m+lKaLpnGw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="6.11,199,1725346800"; d="scan'208";a="108806654" Received: from orsmsx603.amr.corp.intel.com ([10.22.229.16]) by orviesa003.jf.intel.com with ESMTP/TLS/AES256-GCM-SHA384; 10 Jan 2025 07:47:23 -0800 Received: from orsmsx601.amr.corp.intel.com (10.22.229.14) by ORSMSX603.amr.corp.intel.com (10.22.229.16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.44; Fri, 10 Jan 2025 07:47:22 -0800 Received: from orsedg603.ED.cps.intel.com (10.7.248.4) by orsmsx601.amr.corp.intel.com (10.22.229.14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.44 via Frontend Transport; Fri, 10 Jan 2025 07:47:22 -0800 Received: from NAM11-CO1-obe.outbound.protection.outlook.com (104.47.56.176) by edgegateway.intel.com (134.134.137.100) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.1.2507.44; Fri, 10 Jan 2025 07:47:22 -0800 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=xwfm6yQ99edck2/H5EkK/z9labXhZF9e1T5tTD0o/Wp2XEDf8U3aaBA6ftkqWpQz3PrutC2BsdxR7ud+JXygwAN6+1KtjHhL7+yzY17mo56Jv5s6RwMoNtGmbhUvBaX616DTEQvpSravO4sKC6kRULe6cVzfMwW+TNKMPxjk0ErxtDnkHZYZCwoczxshl4gR+5NrhRn1sQed+XqNcIqHjOkJEe2X9UgX3eeLxYnN5LhxOIPoaxh3B0iOrTtX4OvLS139MMU7/HncxSHscMkAvWviXy1rRbMx0gxgjRR1oJ4aPCiPsWnw1ociql2Gkmec3UbY9VlJ5Jo/hwH2IWgCdQ== 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=IHcmb3pGDi89lwkhVs/yvmVcxJVAOQMDgRRik1Sx9ug=; b=hHCWgbNSVzq1onTvNQhdVLy7oJfaEE52oLEsYS3roQsCBWd3ROym/t7qYWYotvazIXYqLaLKA5h0JxDZIBslvEwrOqooS9F0z4eV/MOzRpNd/R9AU/KwVPft0KY60NqtBvzyWOGLl+IO5D55JtC7EkRE/URMRUTo2bu4t5ld5NlBg+AXgQstbG1OXnllDi/rX1k0te6z412cmwUEodW1Cp/bn63EA1wHQHBxJksCe3pY+3bk4Aqg03MW7zIHRM8JzLhHq4vJRIcJb8o3e2BFQ9d6h4jQOEABYqoJnCyE+aTopZfbxPJAsrBB6Oe39ea1Qw5QUGV5EEDG2B8xcpNiKg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=intel.com; dmarc=pass action=none header.from=intel.com; dkim=pass header.d=intel.com; arc=none Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=intel.com; Received: from CO1PR11MB5057.namprd11.prod.outlook.com (2603:10b6:303:6c::15) by DS0PR11MB7410.namprd11.prod.outlook.com (2603:10b6:8:151::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8335.10; Fri, 10 Jan 2025 15:46:37 +0000 Received: from CO1PR11MB5057.namprd11.prod.outlook.com ([fe80::4610:6d6c:9af6:2548]) by CO1PR11MB5057.namprd11.prod.outlook.com ([fe80::4610:6d6c:9af6:2548%4]) with mapi id 15.20.8335.012; Fri, 10 Jan 2025 15:46:37 +0000 Date: Fri, 10 Jan 2025 15:46:28 +0000 From: Krzysztof Karas To: intel-gfx , dri-devel CC: Krzysztof Karas Subject: [PATCH] drm/i915: replace in_atomic() with manually set flag Message-ID: "Organization: Intel Technology Poland sp. z o.o. - ul. Slowackiego 173, 80-298 Gdansk - KRS 101882 - NIP 957-07-52-316" Content-Disposition: inline X-ClientProxiedBy: DUZPR01CA0092.eurprd01.prod.exchangelabs.com (2603:10a6:10:4bb::27) To CO1PR11MB5057.namprd11.prod.outlook.com (2603:10b6:303:6c::15) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: CO1PR11MB5057:EE_|DS0PR11MB7410:EE_ X-MS-Office365-Filtering-Correlation-Id: d8c95573-1ec2-46a8-1d76-08dd318df7f4 X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|376014|1800799024|27256017; X-Microsoft-Antispam-Message-Info: =?utf-8?q?s0q4TCqrbOE9rB4sVHAZDSGrRbtnwzP?= =?utf-8?q?3YnmdEejjimmzMU6wULBhXGs45aS2p40iJ0NPM7MKJV64Z5z0whF+KQ+NJvmgzm1O?= =?utf-8?q?Hb8Qz14cKBogSInGqo/CLhiVZFPLbf4xRNDBsdFn8PhQX1nFHqZDR4iaSG9IbEO0v?= =?utf-8?q?6jO9axFZkV4NIbKc9s7trXlIfYGuxSAZGOAv5wOVxvgV7ozF5p/gfD2RxSQMZo4Er?= =?utf-8?q?IWeizo4JJK9+QPl9FVbGCG9ge/XiRNeUOgwxGY7cMx3mt8wipsBJsAkDT37exsTXc?= =?utf-8?q?81USRcuS+GYtBbHQHstwLVykpkoZPXEgBR3tPywQ/2LSivil8bcNdTx5JMDZafWJh?= =?utf-8?q?liqiYFeYnvVdeDcZFGx73kr6DBg0vDwgVX1PPLIYXgUY+gySoGd28ZslJ2W4Q7x2W?= =?utf-8?q?DXWKVuzthbIG7DGonetIqmesdEv3SV3apcW5k5P6s+BQ1/A7wrLYqwT7EmpCdpNp+?= =?utf-8?q?mPZQYNxk7oTLJJq6Tec7mgXBy4UaQSp88aXXppQTD2/5a3Cwna25bkmVhBNI5Sp3K?= =?utf-8?q?73bZB0uaoJFbHPC5+DrXcpY+tC+RPyhaAaGmpTWlqmeVMo/IRThgOoYJHTGFLrxF2?= =?utf-8?q?YOK955QQlot99/0HlU/TUq5WCT0gRxsj+paY0IFXU9KSQ576r1mpsss1is2lGJba/?= =?utf-8?q?vApg9w7GXOcsfoA86sCxd6hzPLvVAOgx5KE4pa0LQUBJY1y3ioi2INCZs1cuJhFyV?= =?utf-8?q?UkovtvkX72CtHtuIMU689jvQEnq2c1axWMz0IKbuwQeEt5Shw03GdRlZKdX+FInv5?= =?utf-8?q?8kjxa4TM0YcipYXQWX94XsizuqklVnq0+9AN6CtP7JH0VYCw3yM2EBbRV665J27BP?= =?utf-8?q?MPs6quPs625YoTob7lq9ok8FMvCigZ9YeZxhRcm/bkeXz26SRdemg+XGzokopJAhO?= =?utf-8?q?I207Z9zh6roKtVati9Jamrp6dnV/h+NVfbfNN5nomkiSPa50TcxtaUTAn8qWO8b9N?= =?utf-8?q?4HE+af7VKhzvEfDvjizCRlotn7QMeJqlrTePp3rTYvx8VgaFo5wQstlVFkxFK7QfW?= =?utf-8?q?4CPgwBPrfyH5cJggAR5BsDr8j2/1V/QMzoJVODyna/GF08HBQ/yibRvkHNPl5DY8F?= =?utf-8?q?UH5uX9fLlcIk4f/rM1UkMg+ByFAVjgZKP/HMQaWK2oGyqabk+3T+JuXJTR/joFyE8?= =?utf-8?q?85GMtD2/e14+Cmcl2JbqDCQqOEwRcf61DB93aHep0owqKQfBRcwMd8+UvwVIVjVj7?= =?utf-8?q?WOKOyXrLFhbRMP2k8nO8YErd0BNMh4wQ/dcT3gsmeyKBpmhBd8TNWkX77DZ1iQnQy?= =?utf-8?q?j0nk6coB3mQx+pyt/W8gb8bXRoaxpAb6WX2gQwBpmeM2ybtxLd53FgudXCn1FTwXd?= =?utf-8?q?Jcab0X0wjRFowbuhK3/vqQHgCLA6aBPmxCoEh2//nfE0VhUxO4tvpJtoygv9mUWw6?= =?utf-8?q?9e4m5oSyjWo?= X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:CO1PR11MB5057.namprd11.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230040)(366016)(376014)(1800799024)(27256017); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?q?Kl6cBrdSMexhLlcZvBaXEdbK46Nx?= =?utf-8?q?uJHdyRMVgNlqaszTcpFspfqXJm+M7wlsNWYoOa7hSaUiItuLp28hugYnE1VjvqDfu?= =?utf-8?q?+gyhRHCBGHJeHA8PM7bL5JxBf2AQUeC1z4KrOSUQxfpd1eFvUTMkeQAESjHlqf2/N?= =?utf-8?q?o+n5mn9nedawDZAre4PevKP41qzq7jN1A6d1zSkqtiVTectzTiPLFeSXEY5LjBJVQ?= =?utf-8?q?6Npu8CNg4S5oWk1tJ3Yk0nFpixQOPYy/AqKakbY8sSJ5hEvojRaxf8sc91I6irdEh?= =?utf-8?q?lD5Vx97wXqIwJGhc6JVg6Q9vNlhAH0Jv/ETvylFb0/g3+dCiRwDxKQNyVjQqSdyn7?= =?utf-8?q?DhKc4/o265tB4PEhuyKM92nd40PKXnwp9ruWb0IIhZV5dKZJLvpidmcX2e7cvPmjM?= =?utf-8?q?btSn0EpGSFC0OF2ehEKAf5kI6s5sDsDcsnVZzkj1wvf0ULa4LwcjZwtJ2YTq4oSOp?= =?utf-8?q?BLX//7Mg+xdnUO3PBGzQ5XvLeFdxlduBMlycXrG5GMGnkcoktRRblUqM/VLkzZKfk?= =?utf-8?q?LwkbdYgKToYsRYCfT+dNcpkAhxFCUJV/QibOR+ez2ybUNd1nKOAlQOirGdKbNr3ib?= =?utf-8?q?3UvpEuyTn4CLJWQXAUdrwIT8UoK647BSrjgnhVgBFQJQv8B9CzGJRnPnQfJLokWGF?= =?utf-8?q?t54XbL+kQx2Sz7DRsOG3wTu/6Lg9WjHOM09Mczazl/9Z8mf0ycLoGB0EFReMzJZQ1?= =?utf-8?q?sx15hGZwi2llfwd0ilWiGHGx4LHoBmv3LytJqo3ny8gvoIdLecE8LrTH6ds78Jp98?= =?utf-8?q?dmh2EzlA00jKdtUV/+9OUm9jfVke3jpgj6LXzE5Xxmp/a+Z9sQHlY+ahYytEFk1Az?= =?utf-8?q?44LWh9vPpR4bklf6TsiKtIIzUPsxcdr8k1TmJNGs5TYdA/3nu3PDFMB2hJz9NHWf9?= =?utf-8?q?X8vZeXfUBfmQd+q6lMVN0eOPPNFwL00D//ZgaYnIbTX9sFPCZnqG7z9qfeUVID0Ud?= =?utf-8?q?aY2/250lHkRlU2mWaJ8Mv2/bMmWtFpFSKLYu3voO8WVAHhAvGFbtnQFuqRt2zGQ5U?= =?utf-8?q?SLBxnpG0iNj7DqFaAwC+5zA70mM/mRhNNjy2KlvKZ5WFItYunSAa91LluLgW4/M7L?= =?utf-8?q?ujMXd5E9OuLSmcL/+reKMjd+QcC3rX3jcUzrRYjEA9pr5zL1gZQIqsInWQs3iAflI?= =?utf-8?q?F01a07IlbNIYiRP+q5b3dTo8ZOhvv1z1yiAD6yUIGkmXdVb24j9+vT9KW8j0ULyD0?= =?utf-8?q?AXKktAwgiCfDAAEX8kDzs87bCj3DdONiWJ/L+5fvpFxQrMaUqIMSScYipO+3bpZmo?= =?utf-8?q?9nq2fCt+fugEUQ7cNlRB4jATOgmS6P6PcWXuac+qTomrWlf6OMD5vnaQWFtwRvAmb?= =?utf-8?q?3BAuG7DOzKwhEPmyfDufzBZ2s9cLG2SgTX3WpJQfAHcYAc8cq358eAqk5RITDzDbC?= =?utf-8?q?z5DiICxLT9xyD36osI08k42On1Xa5WzyGSBpG0UR6/FHh1TNRoeWgoZsfB4VoW7wX?= =?utf-8?q?4bEXUfYnsjImSNj1/m7BJLK7iKRBXiz6/TnpqDFGVyjROysmQNY7vEVuaN6Ba0tH+?= =?utf-8?q?6KYbKAhNrDIS5kRnnGrjEiK3c/hxbB+GFA=3D=3D?= X-MS-Exchange-CrossTenant-Network-Message-Id: d8c95573-1ec2-46a8-1d76-08dd318df7f4 X-MS-Exchange-CrossTenant-AuthSource: CO1PR11MB5057.namprd11.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 10 Jan 2025 15:46:37.8415 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 46c98d88-e344-4ed4-8496-4ed7712e255d X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: av/X7LBNPxjgH5CFjJy3blnHkldQ/fYsHFhUAGAjwS3B/UE385eYFN9Zi62u/NHu0/pgJQyYYT8OR9F+QRBCmpfvU2wbn/Kg6rb2j6VsWZY= X-MS-Exchange-Transport-CrossTenantHeadersStamped: DS0PR11MB7410 X-OriginatorOrg: intel.com X-BeenThere: intel-gfx@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Intel graphics driver community testing & development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: intel-gfx-bounces@lists.freedesktop.org Sender: "Intel-gfx" GuC code uses in_atomic() function to determine if the current context is atomic. As noted by the function's description it should not be used in driver code, as it is not guaranteed to determine atomicity correctly in every instance. This is also pointed out by the FIXME note suggesting that the caller of intel_guc_send_busy_loop() should be responsible for providing information about whether the context is atomic or not to avoid in_atomic() usage there. Add a new flag to indicate active spin locks and pass it down to intel_guc_send_busy_loop(), similarly to how "loop" flag is handled. Signed-off-by: Krzysztof Karas --- drivers/gpu/drm/i915/gt/uc/intel_guc.h | 12 +- drivers/gpu/drm/i915/gt/uc/intel_guc_ads.c | 2 +- .../gpu/drm/i915/gt/uc/intel_guc_submission.c | 127 ++++++++++-------- 3 files changed, 74 insertions(+), 67 deletions(-) diff --git a/drivers/gpu/drm/i915/gt/uc/intel_guc.h b/drivers/gpu/drm/i915/gt/uc/intel_guc.h index 57b903132776..0ccd97dc32f7 100644 --- a/drivers/gpu/drm/i915/gt/uc/intel_guc.h +++ b/drivers/gpu/drm/i915/gt/uc/intel_guc.h @@ -358,18 +358,12 @@ static inline int intel_guc_send_busy_loop(struct intel_guc *guc, const u32 *action, u32 len, u32 g2h_len_dw, - bool loop) + bool loop, + bool locked) { int err; unsigned int sleep_period_ms = 1; - bool not_atomic = !in_atomic() && !irqs_disabled(); - - /* - * FIXME: Have caller pass in if we are in an atomic context to avoid - * using in_atomic(). It is likely safe here as we check for irqs - * disabled which basically all the spin locks in the i915 do but - * regardless this should be cleaned up. - */ + bool not_atomic = !locked && !irqs_disabled(); /* No sleeping with spin locks, just busy loop */ might_sleep_if(loop && not_atomic); diff --git a/drivers/gpu/drm/i915/gt/uc/intel_guc_ads.c b/drivers/gpu/drm/i915/gt/uc/intel_guc_ads.c index 46fabbfc775e..6d7ec67e8f58 100644 --- a/drivers/gpu/drm/i915/gt/uc/intel_guc_ads.c +++ b/drivers/gpu/drm/i915/gt/uc/intel_guc_ads.c @@ -198,7 +198,7 @@ static int guc_action_policies_update(struct intel_guc *guc, u32 policy_offset) policy_offset }; - return intel_guc_send_busy_loop(guc, action, ARRAY_SIZE(action), 0, true); + return intel_guc_send_busy_loop(guc, action, ARRAY_SIZE(action), 0, true, false); } int intel_guc_global_policies_update(struct intel_guc *guc) diff --git a/drivers/gpu/drm/i915/gt/uc/intel_guc_submission.c b/drivers/gpu/drm/i915/gt/uc/intel_guc_submission.c index 12f1ba7ca9c1..2154718d278c 100644 --- a/drivers/gpu/drm/i915/gt/uc/intel_guc_submission.c +++ b/drivers/gpu/drm/i915/gt/uc/intel_guc_submission.c @@ -618,7 +618,8 @@ static int guc_submission_send_busy_loop(struct intel_guc *guc, const u32 *action, u32 len, u32 g2h_len_dw, - bool loop) + bool loop, + bool locked) { int ret; @@ -632,7 +633,7 @@ static int guc_submission_send_busy_loop(struct intel_guc *guc, if (g2h_len_dw) atomic_inc(&guc->outstanding_submission_g2h); - ret = intel_guc_send_busy_loop(guc, action, len, g2h_len_dw, loop); + ret = intel_guc_send_busy_loop(guc, action, len, g2h_len_dw, loop, locked); if (ret) atomic_dec(&guc->outstanding_submission_g2h); @@ -690,8 +691,8 @@ int intel_guc_wait_for_idle(struct intel_guc *guc, long timeout) true, timeout); } -static int guc_context_policy_init_v70(struct intel_context *ce, bool loop); -static int try_context_registration(struct intel_context *ce, bool loop); +static int guc_context_policy_init_v70(struct intel_context *ce, bool loop, bool locked); +static int try_context_registration(struct intel_context *ce, bool loop, bool locked); static int __guc_add_request(struct intel_guc *guc, struct i915_request *rq) { @@ -718,7 +719,7 @@ static int __guc_add_request(struct intel_guc *guc, struct i915_request *rq) GEM_BUG_ON(context_guc_id_invalid(ce)); if (context_policy_required(ce)) { - err = guc_context_policy_init_v70(ce, false); + err = guc_context_policy_init_v70(ce, false, true); if (err) return err; } @@ -991,7 +992,7 @@ static int guc_dequeue_one_context(struct intel_guc *guc) if (unlikely(!ctx_id_mapped(guc, ce->guc_id.id) && intel_context_is_schedulable(ce))) { - ret = try_context_registration(ce, false); + ret = try_context_registration(ce, false, true); if (unlikely(ret == -EPIPE)) { goto deadlk; } else if (ret == -EBUSY) { @@ -2445,7 +2446,8 @@ static int __guc_action_register_multi_lrc_v69(struct intel_guc *guc, struct intel_context *ce, u32 guc_id, u32 offset, - bool loop) + bool loop, + bool locked) { struct intel_context *child; u32 action[4 + MAX_ENGINE_INSTANCE]; @@ -2462,13 +2464,14 @@ static int __guc_action_register_multi_lrc_v69(struct intel_guc *guc, action[len++] = offset; } - return guc_submission_send_busy_loop(guc, action, len, 0, loop); + return guc_submission_send_busy_loop(guc, action, len, 0, loop, locked); } static int __guc_action_register_multi_lrc_v70(struct intel_guc *guc, struct intel_context *ce, struct guc_ctxt_registration_info *info, - bool loop) + bool loop, + bool locked) { struct intel_context *child; u32 action[13 + (MAX_ENGINE_INSTANCE * 2)]; @@ -2505,13 +2508,14 @@ static int __guc_action_register_multi_lrc_v70(struct intel_guc *guc, GEM_BUG_ON(len > ARRAY_SIZE(action)); - return guc_submission_send_busy_loop(guc, action, len, 0, loop); + return guc_submission_send_busy_loop(guc, action, len, 0, loop, locked); } static int __guc_action_register_context_v69(struct intel_guc *guc, u32 guc_id, u32 offset, - bool loop) + bool loop, + bool locked) { u32 action[] = { INTEL_GUC_ACTION_REGISTER_CONTEXT, @@ -2520,12 +2524,13 @@ static int __guc_action_register_context_v69(struct intel_guc *guc, }; return guc_submission_send_busy_loop(guc, action, ARRAY_SIZE(action), - 0, loop); + 0, loop, locked); } static int __guc_action_register_context_v70(struct intel_guc *guc, struct guc_ctxt_registration_info *info, - bool loop) + bool loop, + bool locked) { u32 action[] = { INTEL_GUC_ACTION_REGISTER_CONTEXT, @@ -2543,7 +2548,7 @@ static int __guc_action_register_context_v70(struct intel_guc *guc, }; return guc_submission_send_busy_loop(guc, action, ARRAY_SIZE(action), - 0, loop); + 0, loop, locked); } static void prepare_context_registration_info_v69(struct intel_context *ce); @@ -2551,7 +2556,7 @@ static void prepare_context_registration_info_v70(struct intel_context *ce, struct guc_ctxt_registration_info *info); static int -register_context_v69(struct intel_guc *guc, struct intel_context *ce, bool loop) +register_context_v69(struct intel_guc *guc, struct intel_context *ce, bool loop, bool locked) { u32 offset = intel_guc_ggtt_offset(guc, guc->lrc_desc_pool_v69) + ce->guc_id.id * sizeof(struct guc_lrc_desc_v69); @@ -2560,26 +2565,26 @@ register_context_v69(struct intel_guc *guc, struct intel_context *ce, bool loop) if (intel_context_is_parent(ce)) return __guc_action_register_multi_lrc_v69(guc, ce, ce->guc_id.id, - offset, loop); + offset, loop, locked); else return __guc_action_register_context_v69(guc, ce->guc_id.id, - offset, loop); + offset, loop, locked); } static int -register_context_v70(struct intel_guc *guc, struct intel_context *ce, bool loop) +register_context_v70(struct intel_guc *guc, struct intel_context *ce, bool loop, bool locked) { struct guc_ctxt_registration_info info; prepare_context_registration_info_v70(ce, &info); if (intel_context_is_parent(ce)) - return __guc_action_register_multi_lrc_v70(guc, ce, &info, loop); + return __guc_action_register_multi_lrc_v70(guc, ce, &info, loop, locked); else - return __guc_action_register_context_v70(guc, &info, loop); + return __guc_action_register_context_v70(guc, &info, loop, locked); } -static int register_context(struct intel_context *ce, bool loop) +static int register_context(struct intel_context *ce, bool loop, bool locked) { struct intel_guc *guc = ce_to_guc(ce); int ret; @@ -2588,9 +2593,9 @@ static int register_context(struct intel_context *ce, bool loop) trace_intel_context_register(ce); if (GUC_SUBMIT_VER(guc) >= MAKE_GUC_VER(1, 0, 0)) - ret = register_context_v70(guc, ce, loop); + ret = register_context_v70(guc, ce, loop, locked); else - ret = register_context_v69(guc, ce, loop); + ret = register_context_v69(guc, ce, loop, locked); if (likely(!ret)) { unsigned long flags; @@ -2600,14 +2605,15 @@ static int register_context(struct intel_context *ce, bool loop) spin_unlock_irqrestore(&ce->guc_state.lock, flags); if (GUC_SUBMIT_VER(guc) >= MAKE_GUC_VER(1, 0, 0)) - guc_context_policy_init_v70(ce, loop); + guc_context_policy_init_v70(ce, loop, locked); } return ret; } static int __guc_action_deregister_context(struct intel_guc *guc, - u32 guc_id) + u32 guc_id, + bool locked) { u32 action[] = { INTEL_GUC_ACTION_DEREGISTER_CONTEXT, @@ -2616,17 +2622,17 @@ static int __guc_action_deregister_context(struct intel_guc *guc, return guc_submission_send_busy_loop(guc, action, ARRAY_SIZE(action), G2H_LEN_DW_DEREGISTER_CONTEXT, - true); + true, locked); } -static int deregister_context(struct intel_context *ce, u32 guc_id) +static int deregister_context(struct intel_context *ce, u32 guc_id, bool locked) { struct intel_guc *guc = ce_to_guc(ce); GEM_BUG_ON(intel_context_is_child(ce)); trace_intel_context_deregister(ce); - return __guc_action_deregister_context(guc, guc_id); + return __guc_action_deregister_context(guc, guc_id, locked); } static inline void clear_children_join_go_memory(struct intel_context *ce) @@ -2691,14 +2697,15 @@ MAKE_CONTEXT_POLICY_ADD(slpc_ctx_freq_req, SLPM_GT_FREQUENCY) static int __guc_context_set_context_policies(struct intel_guc *guc, struct context_policy *policy, - bool loop) + bool loop, + bool locked) { return guc_submission_send_busy_loop(guc, (u32 *)&policy->h2g, __guc_context_policy_action_size(policy), - 0, loop); + 0, loop, locked); } -static int guc_context_policy_init_v70(struct intel_context *ce, bool loop) +static int guc_context_policy_init_v70(struct intel_context *ce, bool loop, bool locked) { struct intel_engine_cs *engine = ce->engine; struct intel_guc *guc = gt_to_guc(engine->gt); @@ -2730,7 +2737,7 @@ static int guc_context_policy_init_v70(struct intel_context *ce, bool loop) if (engine->flags & I915_ENGINE_WANT_FORCED_PREEMPTION) __guc_context_policy_add_preempt_to_idle(&policy, 1); - ret = __guc_context_set_context_policies(guc, &policy, loop); + ret = __guc_context_set_context_policies(guc, &policy, loop, locked); spin_lock_irqsave(&ce->guc_state.lock, flags); if (ret != 0) @@ -2910,7 +2917,7 @@ static void prepare_context_registration_info_v70(struct intel_context *ce, } } -static int try_context_registration(struct intel_context *ce, bool loop) +static int try_context_registration(struct intel_context *ce, bool loop, bool locked) { struct intel_engine_cs *engine = ce->engine; struct intel_runtime_pm *runtime_pm = engine->uncore->rpm; @@ -2960,12 +2967,12 @@ static int try_context_registration(struct intel_context *ce, bool loop) * context whose guc_id was stolen. */ with_intel_runtime_pm(runtime_pm, wakeref) - ret = deregister_context(ce, ce->guc_id.id); + ret = deregister_context(ce, ce->guc_id.id, locked); if (unlikely(ret == -ENODEV)) ret = 0; /* Will get registered later */ } else { with_intel_runtime_pm(runtime_pm, wakeref) - ret = register_context(ce, loop); + ret = register_context(ce, loop, locked); if (unlikely(ret == -EBUSY)) { clr_ctx_id_mapping(guc, ctx_id); } else if (unlikely(ret == -ENODEV)) { @@ -3036,7 +3043,8 @@ static void guc_context_post_unpin(struct intel_context *ce) } static void __guc_context_sched_enable(struct intel_guc *guc, - struct intel_context *ce) + struct intel_context *ce, + bool locked) { u32 action[] = { INTEL_GUC_ACTION_SCHED_CONTEXT_MODE_SET, @@ -3047,12 +3055,13 @@ static void __guc_context_sched_enable(struct intel_guc *guc, trace_intel_context_sched_enable(ce); guc_submission_send_busy_loop(guc, action, ARRAY_SIZE(action), - G2H_LEN_DW_SCHED_CONTEXT_MODE_SET, true); + G2H_LEN_DW_SCHED_CONTEXT_MODE_SET, true, locked); } static void __guc_context_sched_disable(struct intel_guc *guc, struct intel_context *ce, - u16 guc_id) + u16 guc_id, + bool locked) { u32 action[] = { INTEL_GUC_ACTION_SCHED_CONTEXT_MODE_SET, @@ -3066,7 +3075,7 @@ static void __guc_context_sched_disable(struct intel_guc *guc, trace_intel_context_sched_disable(ce); guc_submission_send_busy_loop(guc, action, ARRAY_SIZE(action), - G2H_LEN_DW_SCHED_CONTEXT_MODE_SET, true); + G2H_LEN_DW_SCHED_CONTEXT_MODE_SET, true, locked); } static void guc_blocked_fence_complete(struct intel_context *ce) @@ -3139,7 +3148,7 @@ static struct i915_sw_fence *guc_context_block(struct intel_context *ce) spin_unlock_irqrestore(&ce->guc_state.lock, flags); with_intel_runtime_pm(runtime_pm, wakeref) - __guc_context_sched_disable(guc, ce, guc_id); + __guc_context_sched_disable(guc, ce, guc_id, false); return &ce->guc_state.blocked; } @@ -3190,7 +3199,7 @@ static void guc_context_unblock(struct intel_context *ce) if (enable) { with_intel_runtime_pm(runtime_pm, wakeref) - __guc_context_sched_enable(guc, ce); + __guc_context_sched_enable(guc, ce, false); } } @@ -3219,14 +3228,15 @@ static void guc_context_cancel_request(struct intel_context *ce, static void __guc_context_set_preemption_timeout(struct intel_guc *guc, u16 guc_id, - u32 preemption_timeout) + u32 preemption_timeout, + bool locked) { if (GUC_SUBMIT_VER(guc) >= MAKE_GUC_VER(1, 0, 0)) { struct context_policy policy; __guc_context_policy_start_klv(&policy, guc_id); __guc_context_policy_add_preemption_timeout(&policy, preemption_timeout); - __guc_context_set_context_policies(guc, &policy, true); + __guc_context_set_context_policies(guc, &policy, true, locked); } else { u32 action[] = { INTEL_GUC_ACTION_V69_SET_CONTEXT_PREEMPTION_TIMEOUT, @@ -3234,7 +3244,7 @@ static void __guc_context_set_preemption_timeout(struct intel_guc *guc, preemption_timeout }; - intel_guc_send_busy_loop(guc, action, ARRAY_SIZE(action), 0, true); + intel_guc_send_busy_loop(guc, action, ARRAY_SIZE(action), 0, true, locked); } } @@ -3280,15 +3290,17 @@ guc_context_revoke(struct intel_context *ce, struct i915_request *rq, */ with_intel_runtime_pm(runtime_pm, wakeref) { __guc_context_set_preemption_timeout(guc, guc_id, - preempt_timeout_ms); - __guc_context_sched_disable(guc, ce, guc_id); + preempt_timeout_ms, + false); + __guc_context_sched_disable(guc, ce, guc_id, false); } } else { if (!context_guc_id_invalid(ce)) with_intel_runtime_pm(runtime_pm, wakeref) __guc_context_set_preemption_timeout(guc, ce->guc_id.id, - preempt_timeout_ms); + preempt_timeout_ms, + true); spin_unlock_irqrestore(&ce->guc_state.lock, flags); } } @@ -3307,7 +3319,7 @@ static void do_sched_disable(struct intel_guc *guc, struct intel_context *ce, spin_unlock_irqrestore(&ce->guc_state.lock, flags); with_intel_runtime_pm(runtime_pm, wakeref) - __guc_context_sched_disable(guc, ce, guc_id); + __guc_context_sched_disable(guc, ce, guc_id, false); } static bool bypass_sched_disable(struct intel_guc *guc, @@ -3431,7 +3443,7 @@ static inline int guc_lrc_desc_unpin(struct intel_context *ce) * with suspend, so we undo everything if the H2G fails in deregister_context so * that GuC reset will find this context during clean up. */ - ret = deregister_context(ce, ce->guc_id.id); + ret = deregister_context(ce, ce->guc_id.id, false); if (ret) { spin_lock(&ce->guc_state.lock); set_context_registered(ce); @@ -3596,14 +3608,15 @@ static int guc_context_alloc(struct intel_context *ce) } static void __guc_context_set_prio(struct intel_guc *guc, - struct intel_context *ce) + struct intel_context *ce, + bool locked) { if (GUC_SUBMIT_VER(guc) >= MAKE_GUC_VER(1, 0, 0)) { struct context_policy policy; __guc_context_policy_start_klv(&policy, ce->guc_id.id); __guc_context_policy_add_priority(&policy, ce->guc_state.prio); - __guc_context_set_context_policies(guc, &policy, true); + __guc_context_set_context_policies(guc, &policy, true, locked); } else { u32 action[] = { INTEL_GUC_ACTION_V69_SET_CONTEXT_PRIORITY, @@ -3611,7 +3624,7 @@ static void __guc_context_set_prio(struct intel_guc *guc, ce->guc_state.prio, }; - guc_submission_send_busy_loop(guc, action, ARRAY_SIZE(action), 0, true); + guc_submission_send_busy_loop(guc, action, ARRAY_SIZE(action), 0, true, locked); } } @@ -3630,7 +3643,7 @@ static void guc_context_set_prio(struct intel_guc *guc, } ce->guc_state.prio = prio; - __guc_context_set_prio(guc, ce); + __guc_context_set_prio(guc, ce, true); trace_intel_context_set_prio(ce); } @@ -3927,7 +3940,7 @@ static int guc_request_alloc(struct i915_request *rq) if (unlikely(ret < 0)) return ret; if (context_needs_register(ce, !!ret)) { - ret = try_context_registration(ce, true); + ret = try_context_registration(ce, true, false); if (unlikely(ret)) { /* unwind */ if (ret == -EPIPE) { disable_submission(guc); @@ -4447,7 +4460,7 @@ static inline int guc_kernel_context_pin(struct intel_guc *guc, if (!test_bit(CONTEXT_GUC_INIT, &ce->flags)) guc_context_init(ce); - ret = try_context_registration(ce, true); + ret = try_context_registration(ce, true, false); if (ret) unpin_guc_id(guc, ce); @@ -4990,7 +5003,7 @@ static int guc_send_invalidate_tlb(struct intel_guc *guc, add_wait_queue(&wq->wq, &wait); /* This is a critical reclaim path and thus we must loop here. */ - err = intel_guc_send_busy_loop(guc, action, size, G2H_LEN_DW_INVALIDATE_TLB, true); + err = intel_guc_send_busy_loop(guc, action, size, G2H_LEN_DW_INVALIDATE_TLB, true, false); if (err) goto out; @@ -5062,7 +5075,7 @@ int intel_guc_deregister_done_process_msg(struct intel_guc *guc, * register this context. */ with_intel_runtime_pm(runtime_pm, wakeref) - register_context(ce, true); + register_context(ce, true, false); guc_signal_context_fence(ce); intel_context_put(ce); } else if (context_destroyed(ce)) {