Received: by 2002:a05:7412:f589:b0:e2:908c:2ebd with SMTP id eh9csp372156rdb; Tue, 31 Oct 2023 09:43:19 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFGaOQXuL4ydI+IXHtisXgU014eIHkKJT/95CZsrpgFRiV1AjbZXV4l+u1iH1Y4J6tsRz49 X-Received: by 2002:a05:6a20:12c4:b0:154:bfaf:a710 with SMTP id v4-20020a056a2012c400b00154bfafa710mr12956732pzg.41.1698770599221; Tue, 31 Oct 2023 09:43:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698770599; cv=none; d=google.com; s=arc-20160816; b=OPxE5q5J1UbRopH5RtnabWcYXjVxxNuCn/FMvoLRpIYH5SJZOTZmwI9qsC8/uYog1/ tpfEf0R1H/ckvNeYEymw9RgFQk2j9SWypr2YsS7GGKMTzNhzE879ktPz1EhyEbVFU6O9 qPhbSMkEQePRjJuEYY2CpnQmHBcr+sX82L6jl3wzhw9kH/KeC33AV3r5FdBqfpQletni Uzelk4dMYP94Tk3vETBPBG5bmGaYfx7epTm1COaVryX/PUBuYrtU5Ae/8rwXZbOda8DL ibzsbJT4ZETIyVd+gxCz5mz5OtX2liPQJvZivUpCKMMdFYgpj62bfL+NT526MGlY5V+h MIlw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to :organization:from:references:cc:to:content-language:subject :user-agent:mime-version:date:message-id:dkim-signature; bh=XJqCZxrLTKcwcLAE87Zs5L0NcoxMkUhMyUSeCCjP4ho=; fh=O16NhvANMyz2hJ3rFLgU03XllihTbCbpAGpJmys9qF8=; b=cWTQsi6CSp+RTZVyGcotpLYmrSgiiGErvEsuddwXFPrrnOcIPe8kBUmkhespX46ft/ q4fB96eVNh/dWbR9JGOWgX1QIQUHvpyi0DOtAgTQG+2e1aAwYIADaN8StEeZPDnbYkAA TQ1e5b9jDNSOGMHKTg/05N5taOthB+w9prdLeSSh/SjRRnCoFvWERQcTRlXhNk+U7O5U UE8tn3E8B0lW4ZMBKqsLtJEjP6arR+DlqHkM9xjADH8V8Cf9hFNB7SqEvUONPisKyCbY Jg38Kyg45uaR+HXGbHYOzLiWidod2mU+8MntVfrdR6k58MLrgDl/SaZKy07p3r+ZTnI8 9JAw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=e8RJvwWE; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from howler.vger.email (howler.vger.email. [23.128.96.34]) by mx.google.com with ESMTPS id b15-20020a056a00114f00b006b1fec25a82si1180616pfm.403.2023.10.31.09.43.18 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 31 Oct 2023 09:43:19 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) client-ip=23.128.96.34; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=e8RJvwWE; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by howler.vger.email (Postfix) with ESMTP id 9DE3280C0DE6; Tue, 31 Oct 2023 09:43:16 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at howler.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345235AbjJaQm7 (ORCPT + 99 others); Tue, 31 Oct 2023 12:42:59 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47200 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236119AbjJaQmv (ORCPT ); Tue, 31 Oct 2023 12:42:51 -0400 Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3D55EA255 for ; Tue, 31 Oct 2023 09:40:06 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1698770378; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=XJqCZxrLTKcwcLAE87Zs5L0NcoxMkUhMyUSeCCjP4ho=; b=e8RJvwWETCmvqMLYFNueCelFvSZH1lRK3Wg9IdyI8grJR2A1WZvHROsf67Q07A2Q24JbA+ WVBPZVJUajhXWcVcgegMx7dGGYkN/WhR0CpQTG9rqPMuRCNi98HttIT2/d719i5IYSBZlF oNWxMnNpFFRsdhp7MRGst7hYQMs2ERY= Received: from mail-ej1-f69.google.com (mail-ej1-f69.google.com [209.85.218.69]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-166-1qVwYXYvOQWRFkDMsla7RQ-1; Tue, 31 Oct 2023 12:39:36 -0400 X-MC-Unique: 1qVwYXYvOQWRFkDMsla7RQ-1 Received: by mail-ej1-f69.google.com with SMTP id a640c23a62f3a-9d30a6a67abso178515166b.2 for ; Tue, 31 Oct 2023 09:39:36 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1698770375; x=1699375175; h=content-transfer-encoding:in-reply-to:organization:from:references :cc:to:content-language:subject:user-agent:mime-version:date :message-id:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=XJqCZxrLTKcwcLAE87Zs5L0NcoxMkUhMyUSeCCjP4ho=; b=AYqsBl+l7g/DZU/xB8x8+apC5MCPm5j/hMmAYUf9pOqc1uhNrAgaz6iI22xhIMqz0e zxyLGKnVUFKZpLXd8HG2x1+0Xmr1y3BlcgvCedlE9HogiL8tCR37FNGcql6BuujlWP8m Wc8RdJRUPTSDtdEzI7iahPc7lBXvKmJlhCgH6RoxTCfk86QLZZniFfPEi4lt/Npne4kb cXvOOwRYOY4iIB1wEpF7eVWVslhmWNAkUdqo3g6BMPokh7NPc59Q11t+MXhj7IuYvRqP uOLz+6aNEPxld0GbRP8VFXi7wmxZpT2Ey08+0z75zH9C+iic8Nu4lDINR4xq+3NHJ+1D xGuA== X-Gm-Message-State: AOJu0YyU0Hu4I53Ehcp5GXs5C03M/5wvNynJE6JRY/Fcm9MXsk4jhjKG 2tLqfz7CjyL8tW2/U99JWFtXH6/CwclBaNR2m29pVJlymdFgcnR0L66erZ5F75yo97LU2gNH0ub aeOElGvCCgTsiN6PUSkKZm0LJ X-Received: by 2002:a17:906:fd8b:b0:9bf:30e8:5bfd with SMTP id xa11-20020a170906fd8b00b009bf30e85bfdmr11756715ejb.48.1698770375522; Tue, 31 Oct 2023 09:39:35 -0700 (PDT) X-Received: by 2002:a17:906:fd8b:b0:9bf:30e8:5bfd with SMTP id xa11-20020a170906fd8b00b009bf30e85bfdmr11756697ejb.48.1698770375172; Tue, 31 Oct 2023 09:39:35 -0700 (PDT) Received: from ?IPV6:2a02:810d:4b3f:de9c:abf:b8ff:feee:998b? ([2a02:810d:4b3f:de9c:abf:b8ff:feee:998b]) by smtp.gmail.com with ESMTPSA id s25-20020a170906bc5900b009b9977867fbsm1230584ejv.109.2023.10.31.09.39.34 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 31 Oct 2023 09:39:34 -0700 (PDT) Message-ID: <980754a3-7f5a-465e-88a9-62a40c82cae8@redhat.com> Date: Tue, 31 Oct 2023 17:39:33 +0100 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH drm-misc-next v7 4/7] drm/gpuvm: add an abstraction for a VM / BO combination Content-Language: en-US To: =?UTF-8?Q?Thomas_Hellstr=C3=B6m?= , airlied@gmail.com, daniel@ffwll.ch, matthew.brost@intel.com, sarah.walker@imgtec.com, donald.robson@imgtec.com, boris.brezillon@collabora.com, christian.koenig@amd.com, faith@gfxstrand.net Cc: dri-devel@lists.freedesktop.org, nouveau@lists.freedesktop.org, linux-kernel@vger.kernel.org References: <20231023201659.25332-1-dakr@redhat.com> <20231023201659.25332-5-dakr@redhat.com> <4a51c1cd9e2435332e033f9426bac8fae1c21c60.camel@linux.intel.com> From: Danilo Krummrich Organization: RedHat In-Reply-To: <4a51c1cd9e2435332e033f9426bac8fae1c21c60.camel@linux.intel.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.3 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 howler.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 (howler.vger.email [0.0.0.0]); Tue, 31 Oct 2023 09:43:16 -0700 (PDT) On 10/31/23 12:25, Thomas Hellström wrote: > On Mon, 2023-10-23 at 22:16 +0200, Danilo Krummrich wrote: >> Add an abstraction layer between the drm_gpuva mappings of a >> particular >> drm_gem_object and this GEM object itself. The abstraction represents >> a >> combination of a drm_gem_object and drm_gpuvm. The drm_gem_object >> holds >> a list of drm_gpuvm_bo structures (the structure representing this >> abstraction), while each drm_gpuvm_bo contains list of mappings of >> this >> GEM object. >> >> This has multiple advantages: >> >> 1) We can use the drm_gpuvm_bo structure to attach it to various >> lists >>    of the drm_gpuvm. This is useful for tracking external and evicted >>    objects per VM, which is introduced in subsequent patches. >> >> 2) Finding mappings of a certain drm_gem_object mapped in a certain >>    drm_gpuvm becomes much cheaper. >> >> 3) Drivers can derive and extend the structure to easily represent >>    driver specific states of a BO for a certain GPUVM. >> >> The idea of this abstraction was taken from amdgpu, hence the credit >> for >> this idea goes to the developers of amdgpu. >> >> Cc: Christian König >> Signed-off-by: Danilo Krummrich >> --- >>  drivers/gpu/drm/drm_gpuvm.c            | 335 +++++++++++++++++++++-- >> -- >>  drivers/gpu/drm/nouveau/nouveau_uvmm.c |  64 +++-- >>  include/drm/drm_gem.h                  |  32 +-- >>  include/drm/drm_gpuvm.h                | 188 +++++++++++++- >>  4 files changed, 533 insertions(+), 86 deletions(-) > > That checkpatch.pl error still remains as well. I guess you refer to: ERROR: do not use assignment in if condition #633: FILE: drivers/gpu/drm/nouveau/nouveau_uvmm.c:1165: + if (!(op->gem.obj = obj)) This was an intentional decision, since in this specific case it seems to be more readable than the alternatives. However, if we consider this to be a hard rule, which we never ever break, I'm fine changing it too. > > Thanks, > Thomas >