Received: by 2002:a05:7412:419a:b0:f3:1519:9f41 with SMTP id i26csp3062387rdh; Mon, 27 Nov 2023 05:53:43 -0800 (PST) X-Google-Smtp-Source: AGHT+IHV2oQL8A7PMQuFn5q+J9yHEd+c8ms8+E0Qh2bdQUgJZV8GU6iOYmcicnys6LiPQqjePRBp X-Received: by 2002:a05:6a21:9981:b0:18b:37a2:c4db with SMTP id ve1-20020a056a21998100b0018b37a2c4dbmr19145439pzb.10.1701093222995; Mon, 27 Nov 2023 05:53:42 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1701093222; cv=pass; d=google.com; s=arc-20160816; b=VLl+otkkOi2are1zbXur7DKYIM1/jijVrU644FJLWwq+NDGtPVu90C+biNm56HSTad Q4ZFE/gmW5FnNRukBxOawNxskUoMBRdDjqX/bn3/ZGZZPg/uJ5z3n2b7uNOKv4l6wuHK /U22LyUkEcjmqu2cd0KHswnGtEqKFWlpbrqE/NPVGxI3vTdhQ0gRoAGo8l0VJ5wFIUcD ET7qMH0yVEdYXdZK1u+3DZI7xSkxw04V2B+NeevlDZB/whsTkJuqOIFqBN5RxtiQFMqo vMWMtEuMz7oDn/MZ8GBGpYwuUVm+J6Ud+vsheCd0hcx2UVEKHelZGCtt1fEy5emSBadi aOTg== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:content-transfer-encoding :in-reply-to:from:references:cc:to:content-language:subject :user-agent:date:message-id:dkim-signature; bh=bD3ddLFmXpoAuHUmcYxbnmU2hJRIUZGxn3Sk/7JLWlY=; fh=KLyukNrP+3V4KYeXzBzvPKN5LkALKIBGL2K3UWbgcD0=; b=Zh5th9dyjAYg27Z82ryCK2Jeh+pbM6dlJGC7Ueg/cnzopZV3O//TbLulkiDI17HDZF QUTA0L2wlPvRMIdM7NzxAYsWxaVn3vvucQ6TMQNwLdRsj97/b1HthQGXYsRDAGuVkDlu ms39rKzCJsKbmx8wbzseod3Ldhsqp37wv6I2gxYMHJz0GIkwatghHQx3ZrqqotsLznCe SIdBoYuD2xoR6TJwojMLgsWwdn+6Jw9s4RU4guYRjUV6nmwS3FMGyObq65SIkdLRTx9V Nh4tx62e49mxWZ5StYPRXUbERRXKhYZaiab8yJVHsRsrbprV/LPgoLxFt6qhYOOHJWcN 6Fyw== ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@amd.com header.s=selector1 header.b=ZMqaUUwR; arc=pass (i=1 spf=pass spfdomain=amd.com dkim=pass dkdomain=amd.com dmarc=pass fromdomain=amd.com); spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=amd.com Return-Path: Received: from agentk.vger.email (agentk.vger.email. [2620:137:e000::3:2]) by mx.google.com with ESMTPS id 30-20020a63155e000000b005c207717411si9857303pgv.864.2023.11.27.05.53.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 27 Nov 2023 05:53:42 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) client-ip=2620:137:e000::3:2; Authentication-Results: mx.google.com; dkim=pass header.i=@amd.com header.s=selector1 header.b=ZMqaUUwR; arc=pass (i=1 spf=pass spfdomain=amd.com dkim=pass dkdomain=amd.com dmarc=pass fromdomain=amd.com); spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=amd.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by agentk.vger.email (Postfix) with ESMTP id 094CA8098409; Mon, 27 Nov 2023 05:53:40 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at agentk.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233217AbjK0Nw6 (ORCPT + 99 others); Mon, 27 Nov 2023 08:52:58 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:36228 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233147AbjK0Nwz (ORCPT ); Mon, 27 Nov 2023 08:52:55 -0500 Received: from NAM10-MW2-obe.outbound.protection.outlook.com (mail-mw2nam10on2058.outbound.protection.outlook.com [40.107.94.58]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1AFD1138 for ; Mon, 27 Nov 2023 05:53:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=l5aDj8nD5rG3DWBnBVkPsHKkzJSTn8+Ji5n8Ir/A/es5jMs19hJ8hgsRhPTV5RrQeXxCpO5kks5/y7Tu5UO3YZoqHt06sUzuXyYaEykLhoSRXjOTEwOV0hSxEOAYIhHrpkbhWHWPragg6cZ9xFt+ZcgsyyLkgpNaVUN8/nwgFuLOMHjHltLAFyUFJ4Qk0UShjPn2GrdIL8/Nxp+M4dlT5rq56sgwKIdR9X7hHnKBoM0VvbYMYae+morQxYznCgmljN5hVYsa/AHlVP9jYyiimfGvtEcoy8imBFWyrJADKLat5fGNZWIoB51H2vesAOfjqLSsVncbZ9lqEhBSgYiP1g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; 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=bD3ddLFmXpoAuHUmcYxbnmU2hJRIUZGxn3Sk/7JLWlY=; b=Qk8hLjp/pJe26qZC7tp+1Rxfh2ljPBVxdl8+2BB2j6jqYhmLvQtmV+4UkWK4j/lYFG5IYrcx8VEObHrqO9+hBSD8WATV0PvnmXA4Uc9j886kABwkWy+vrl8zNMeShC+D4UVyaPqllrHR0Cx8fU4dcSnmyHs1sLoTsANyIOxdxhZS8MWCCjaSd7q1kgzPMUtF4Fxmp4zTdlQ8lCb5PyJ7llYdpDXTw5pjFGC/WpUDIG8pO68qsgRJbn/TOR856/svC5Tg9AxCRuU4KMSBNdU9L1r9Yn8Fpus/995PlkmDLqgp/FwyaUFQ4I83c6ZpUNxtVdE/WsKkFP2QjhioiyFBNg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=amd.com; dmarc=pass action=none header.from=amd.com; dkim=pass header.d=amd.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=bD3ddLFmXpoAuHUmcYxbnmU2hJRIUZGxn3Sk/7JLWlY=; b=ZMqaUUwRPz+Qwt74Pz/BY1NXktsjJ/4ev/mndxZGFfk1+2eCcAZ6KwZe7qG72vYUnJ4uRqejovQ086KkkX6M/N6tT9fv+hNth8hcrZQfZTopSxoBTOTdYPIJ8TPqktU3gjg1cqGe9OaUS1O/SGq/fMDU4pPdPvLO4BTo2qXsgK0= Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=amd.com; Received: from BN8PR12MB3587.namprd12.prod.outlook.com (2603:10b6:408:43::13) by MN2PR12MB4390.namprd12.prod.outlook.com (2603:10b6:208:26e::21) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7025.29; Mon, 27 Nov 2023 13:52:56 +0000 Received: from BN8PR12MB3587.namprd12.prod.outlook.com ([fe80::ca80:8f1c:c11:ded3]) by BN8PR12MB3587.namprd12.prod.outlook.com ([fe80::ca80:8f1c:c11:ded3%7]) with mapi id 15.20.7025.022; Mon, 27 Nov 2023 13:52:56 +0000 Message-ID: <762bb5f4-f9f5-4ebc-84d3-5465df3ffbf6@amd.com> Date: Mon, 27 Nov 2023 14:52:51 +0100 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH drm-misc-next 4/5] drm/gpuvm: fall back to drm_exec_lock_obj() Content-Language: en-US To: Danilo Krummrich Cc: mripard@kernel.org, airlied@gmail.com, daniel@ffwll.ch, frank.binns@imgtec.com, donald.robson@imgtec.com, matt.coster@imgtec.com, sarah.walker@imgtec.com, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org References: <20231124233650.152653-1-dakr@redhat.com> <20231124233650.152653-5-dakr@redhat.com> <3c7b7683-da36-4ffe-a250-91eef019499f@redhat.com> From: =?UTF-8?Q?Christian_K=C3=B6nig?= In-Reply-To: <3c7b7683-da36-4ffe-a250-91eef019499f@redhat.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-ClientProxiedBy: FR4P281CA0291.DEUP281.PROD.OUTLOOK.COM (2603:10a6:d10:e7::17) To BN8PR12MB3587.namprd12.prod.outlook.com (2603:10b6:408:43::13) MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: BN8PR12MB3587:EE_|MN2PR12MB4390:EE_ X-MS-Office365-Filtering-Correlation-Id: 5175c31b-ccca-4586-585e-08dbef5028ad X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: NSGwF48MJ9o733LEOGcjVman7SdHewQu+BSog1MGUblS/H2Q4jpfytTn6uYo95RlXQ5uFqEljHRiLNMH7AuapKOWBY4qQWMVO22xLFrPSGHIhSSkpLCy4ckzehfbmGpR07lEiVxWppvylOyiVKSrbFzczmBwzK468Pe+Lf3+XdLd6P8b0ynZhesIjv+etAULKxCxSqVNb6w1WKkf5Rba23cWH3kytOMzjbXfJcXYkwiSWaHFV2Fw6UbkDo4xk088XRtchzakCttQZwpkH7W5TMb18RBbQPYeXT8uebOtm9eRGZRqs+JBEJspXdY/2ESTjreC6B0/1CyzHfRB+5Lx9jhyq10ThPjY4eWEZRlJufFVGlEZq0cNpBrvI5KAPwrI04QHh62dD2bBPdjY4y6xPYwPILtncQoFZrcYydiCN2748NzfQMUd/JxCJZ/rGDObT28TbV4aMA7VWS7dVh2gQeE8exaLztkmDNNseAriQ9w/FNx3hN+NGa2hMrpA/yehhdSgrO0T3UuleD8ji/iwkv2skbgS+K1pqO78LcNnQVIPLz3KEq4iUZMiUj4guzNU6IiSYxRlsUQWl8wx+cjNtNSVaMJxd5beII8oSFpvAjI1uGKV4OFi7wivf0Lijf4d7QYP5mcz9ORNtC84Rov5htokpK4C42x/+kxWyyPvK/nq21zNbOjOftQieE1DyJrM X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:BN8PR12MB3587.namprd12.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230031)(346002)(39860400002)(136003)(366004)(376002)(396003)(230173577357003)(230922051799003)(230273577357003)(451199024)(64100799003)(1800799012)(186009)(31686004)(26005)(6486002)(2616005)(6506007)(53546011)(6666004)(478600001)(6512007)(38100700002)(86362001)(31696002)(36756003)(5660300002)(41300700001)(7416002)(2906002)(66946007)(66574015)(83380400001)(66556008)(316002)(6916009)(66476007)(4326008)(8936002)(8676002)(43740500002)(45980500001);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?B?VHlHSmVGemdRaGljWkwxTTBudjQvaTJjNUlDK0JmZkVIbDk4R3JRNkwzMStY?= =?utf-8?B?N1ZjWEVJYzdLWndSRTF5K1dHTlZyc1NLQ1NxMngzcGx6MjV4VktZQ3djKzR5?= =?utf-8?B?YjlWWWFQTEhpRllxOURObjIxR08xdjNDOTEzN0FzWE9QUjVpOEZIV2NMZDgr?= =?utf-8?B?UmdyWXk5Q1dUMno4SUR4S25IcVdsbU9jWkRqNjhlWGhRRGlkcGxTOGJGNGhL?= =?utf-8?B?cjlhZk9WZWQ5UUgrVWFiNTNBcStCSEI1NS9DS24rblNnWGFOQUlvTzJrT0dl?= =?utf-8?B?WWRiVy9QTXE2ZzhKUFVMU2w2Wkc0L0kvMnViZlVkcFk1aGI4bUJVanBRaUNU?= =?utf-8?B?NlFmWVVSaHNDVlZ3REplTTdUd2Zvd1c2WTU4OE5XbVRlSFNZTE5YUmVoNWF4?= =?utf-8?B?Z0JHdWlOMTFYNU1oTlhVYUt5YnVzakQvTDF0cjYwMHY0WFgySy9jcTljaTht?= =?utf-8?B?VUZpdGZBMitUODN6dXZwWVNObytRT1FlTUl5dXJ1bHFJWDdubFdDdlZpY01a?= =?utf-8?B?SUxsakc4RzArMGtYSWtHSkFqQUx4VGdpamJLOHZRWlFZMWF0ckpxNVhiSTQw?= =?utf-8?B?RWdHZkUreE91S1JWdk1FVjVGY0RxZVhBZStHakJYSTBNWXRMT1lLaWtROGRO?= =?utf-8?B?TzR0WnU5ZTZlUWorNEhJK3djMmNQeEtzRTRua251cXQvYWc1ZFVUWVl1b0c2?= =?utf-8?B?S2xwMzh6V0pRL0R6ODZ3TzBaaEt4eWpucW00bytPRG50aGc4RTRtMG0xMEdT?= =?utf-8?B?WHRWQXNoOTdmZnVPb0lma3ZDOXVBWmNDTzBVblQvNzZ4ZXlFV1ZvbjRONk90?= =?utf-8?B?N2NVUXJIUWJ1TjB0WTNadWtIeS94dmVaM3VrVFp2cFlkZFdhQWtUbmhTRjBO?= =?utf-8?B?bGwwZTBVaFV3ZU1CaFJ5d281blBJVmFZUjhqRHJ6ajNMU09STEdibGxIcDBO?= =?utf-8?B?VVRuQTM4ejVjUFJ2d3RUQlIvS2phTHNwcXk5TFJNdTN3TUFFMXlaY1FKcG1m?= =?utf-8?B?ZWp3NnUwVk1McUJLL0d3SjhUN0FHRk92R0RQMkxMeGR0S2RKSktKVDBWYVVV?= =?utf-8?B?eFpFbmlVVUhHZklnemtmbDlPS0YxSjBxMEpNeTcyRCs2aFYyZVF6Mk9PL05O?= =?utf-8?B?bnVETlJPWGFnd0t5V2RUTUtJVkdoZ09CekE1QWFCZ280M05KbXV0QUZHblBR?= =?utf-8?B?eVNWTEUwbGdTT29LUHRLWTNtYi9mNmxuUnkxbjZ0YWxyenJHWThyM0xBSjdZ?= =?utf-8?B?SHVnL2U5YzJDbHh5VkxsbXEwazN1anhIRFY5Tlhwb1FaSWpxb3BLc3UyeXNJ?= =?utf-8?B?eU1hb3RSNkFDcUJGUkFVR3ZwQkhKVmwvSmIyMXU5VVNGWG1FZkFSMkM5eEhJ?= =?utf-8?B?Mmg1K0NmWWJHSXhRV3ZSbUtFNmY4Z2plUUhpbWVPUVU3bVNQWjlSeVFNakpw?= =?utf-8?B?UEg2OG4vbWtVdGhLRWtWSHhVbyt3elkwRVMzK3ltYzdGbEtGZ3RkL1dJOS9q?= =?utf-8?B?ZXhZZWxjRUIyTE43cjF4SWZndWRRbTltWHlPSTRHMVEwM2FKRDduYk5LRHVj?= =?utf-8?B?dHBDVGgxd1B5cmZDUmZsemVJZjArbW1xTVcra1hNTm9lMlNVU0VOOHNJSFBw?= =?utf-8?B?bGlOSVExZE1oVFVoRWdGcXUzcWtkNGdKNm5jWVVXdVdVOWtnNWxYUDlkcmNs?= =?utf-8?B?bkdOVFlQelVyZXJVdkxGZ2l2dTNxWTVEd040RDh3TGlMWVREa1NHaTFkL3NR?= =?utf-8?B?RGg3dVJhV2dPV3lQWGt1UXR4U2RFTlZoV0xQVHlxaXUveUgxUWVmcitzWEVl?= =?utf-8?B?UjJJMjByaXFiejhMMDZFdVFvMmJqaXJTY0tMQWJOeDhpdWIzeTFHaGpXcExw?= =?utf-8?B?ZVBOa1BqMlJqazJEQ0wvS3NCY0c5OTZUM3RoYXNVOWtSbG5wZnJ0OW43SHBt?= =?utf-8?B?VVJuQUNoQ3J3U1dvTDVvY0NpRkdTVjFyQnQyZnVXRGVoV2FDbloybG1WcHVq?= =?utf-8?B?akdhQ2p1WUlYMWRMZ01aYXJUelNRU2hHelU1dElaMjlpSWltRmJVVHZPRWpD?= =?utf-8?B?N0ZWazczN2NDZVViOHgrbGtXVktCUjU1U01ISHJCaExvSXlyd0VJZ29HeHZl?= =?utf-8?Q?S/NdWurMLR6K5pH4PTY0UA911?= X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-Network-Message-Id: 5175c31b-ccca-4586-585e-08dbef5028ad X-MS-Exchange-CrossTenant-AuthSource: BN8PR12MB3587.namprd12.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 27 Nov 2023 13:52:56.4132 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: nYG2vBXgQYqOz4EWQEyARcvWE0byHc1js4il6Bc9TMDGdePcg5Otms5GGA4qKxtp X-MS-Exchange-Transport-CrossTenantHeadersStamped: MN2PR12MB4390 X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on agentk.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (agentk.vger.email [0.0.0.0]); Mon, 27 Nov 2023 05:53:40 -0800 (PST) Am 25.11.23 um 00:40 schrieb Danilo Krummrich: > Hi Christian, > > do you think it makes sense to handle this in drm_exec_prepare_obj() or > even dma_resv_reserve_fences() even? IIRC for drm_exec the discussion has gone a bit back and forth between handling 0 and having a separate function which doesn't allocate fences. We ended up with the solution using separate calls since you either know that you don't need fences (because you for example only need to look something up) or you need fences and eventually calculate the number you need dynamically and if you then end up with 0 it's a bug. So to sum it up the conclusion was that it's more defensive to complain about 0 fences to reserve (which reminds me that dma_resv_reserve_fences() still needs to get a warning for 0 fences as well). Regards, Christian. > > - Danilo > > On 11/25/23 00:36, Danilo Krummrich wrote: >> Fall back to drm_exec_lock_obj() if num_fences is zero for the >> drm_gpuvm_prepare_* function family. >> >> Otherwise dma_resv_reserve_fences() would actually allocate slots even >> though num_fences is zero. >> >> Cc: Christian König >> Signed-off-by: Danilo Krummrich >> --- >>   drivers/gpu/drm/drm_gpuvm.c | 36 +++++++++++++++++++++++++++++++++--- >>   include/drm/drm_gpuvm.h     | 23 +++-------------------- >>   2 files changed, 36 insertions(+), 23 deletions(-) >> >> diff --git a/drivers/gpu/drm/drm_gpuvm.c b/drivers/gpu/drm/drm_gpuvm.c >> index 54f5e8851de5..d1d1c2379e44 100644 >> --- a/drivers/gpu/drm/drm_gpuvm.c >> +++ b/drivers/gpu/drm/drm_gpuvm.c >> @@ -1085,6 +1085,36 @@ drm_gpuvm_put(struct drm_gpuvm *gpuvm) >>   } >>   EXPORT_SYMBOL_GPL(drm_gpuvm_put); >>   +static int >> +exec_prepare_obj(struct drm_exec *exec, struct drm_gem_object *obj, >> +         unsigned int num_fences) >> +{ >> +    return num_fences ? drm_exec_prepare_obj(exec, obj, num_fences) : >> +                drm_exec_lock_obj(exec, obj); >> +} >> + >> +/** >> + * drm_gpuvm_prepare_vm() - prepare the GPUVMs common dma-resv >> + * @gpuvm: the &drm_gpuvm >> + * @exec: the &drm_exec context >> + * @num_fences: the amount of &dma_fences to reserve >> + * >> + * Calls drm_exec_prepare_obj() for the GPUVMs dummy &drm_gem_object. >> + * >> + * Using this function directly, it is the drivers responsibility to >> call >> + * drm_exec_init() and drm_exec_fini() accordingly. >> + * >> + * Returns: 0 on success, negative error code on failure. >> + */ >> +int >> +drm_gpuvm_prepare_vm(struct drm_gpuvm *gpuvm, >> +             struct drm_exec *exec, >> +             unsigned int num_fences) >> +{ >> +    return exec_prepare_obj(exec, gpuvm->r_obj, num_fences); >> +} >> +EXPORT_SYMBOL_GPL(drm_gpuvm_prepare_vm); >> + >>   static int >>   __drm_gpuvm_prepare_objects(struct drm_gpuvm *gpuvm, >>                   struct drm_exec *exec, >> @@ -1095,7 +1125,7 @@ __drm_gpuvm_prepare_objects(struct drm_gpuvm >> *gpuvm, >>       int ret = 0; >>         for_each_vm_bo_in_list(gpuvm, extobj, &extobjs, vm_bo) { >> -        ret = drm_exec_prepare_obj(exec, vm_bo->obj, num_fences); >> +        ret = exec_prepare_obj(exec, vm_bo->obj, num_fences); >>           if (ret) >>               break; >>       } >> @@ -1116,7 +1146,7 @@ drm_gpuvm_prepare_objects_locked(struct >> drm_gpuvm *gpuvm, >>         drm_gpuvm_resv_assert_held(gpuvm); >>       list_for_each_entry(vm_bo, &gpuvm->extobj.list, >> list.entry.extobj) { >> -        ret = drm_exec_prepare_obj(exec, vm_bo->obj, num_fences); >> +        ret = exec_prepare_obj(exec, vm_bo->obj, num_fences); >>           if (ret) >>               break; >>   @@ -1186,7 +1216,7 @@ drm_gpuvm_prepare_range(struct drm_gpuvm >> *gpuvm, struct drm_exec *exec, >>       drm_gpuvm_for_each_va_range(va, gpuvm, addr, end) { >>           struct drm_gem_object *obj = va->gem.obj; >>   -        ret = drm_exec_prepare_obj(exec, obj, num_fences); >> +        ret = exec_prepare_obj(exec, obj, num_fences); >>           if (ret) >>               return ret; >>       } >> diff --git a/include/drm/drm_gpuvm.h b/include/drm/drm_gpuvm.h >> index f94fec9a8517..b3f82ec7fb17 100644 >> --- a/include/drm/drm_gpuvm.h >> +++ b/include/drm/drm_gpuvm.h >> @@ -544,26 +544,9 @@ struct drm_gpuvm_exec { >>       } extra; >>   }; >>   -/** >> - * drm_gpuvm_prepare_vm() - prepare the GPUVMs common dma-resv >> - * @gpuvm: the &drm_gpuvm >> - * @exec: the &drm_exec context >> - * @num_fences: the amount of &dma_fences to reserve >> - * >> - * Calls drm_exec_prepare_obj() for the GPUVMs dummy &drm_gem_object. >> - * >> - * Using this function directly, it is the drivers responsibility to >> call >> - * drm_exec_init() and drm_exec_fini() accordingly. >> - * >> - * Returns: 0 on success, negative error code on failure. >> - */ >> -static inline int >> -drm_gpuvm_prepare_vm(struct drm_gpuvm *gpuvm, >> -             struct drm_exec *exec, >> -             unsigned int num_fences) >> -{ >> -    return drm_exec_prepare_obj(exec, gpuvm->r_obj, num_fences); >> -} >> +int drm_gpuvm_prepare_vm(struct drm_gpuvm *gpuvm, >> +             struct drm_exec *exec, >> +             unsigned int num_fences); >>     int drm_gpuvm_prepare_objects(struct drm_gpuvm *gpuvm, >>                     struct drm_exec *exec, >