Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp1369467iob; Fri, 29 Apr 2022 04:07:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw35bBZ/q+tbXOaq0d5Wfjcl8vv6H7NnPBTs/I/57dxSJJlCcvAVpp/TRQ+jMkkz4bDzoxg X-Received: by 2002:a2e:80d1:0:b0:24f:77a:c7c6 with SMTP id r17-20020a2e80d1000000b0024f077ac7c6mr19584360ljg.200.1651230424050; Fri, 29 Apr 2022 04:07:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651230424; cv=none; d=google.com; s=arc-20160816; b=Q4bnstlV5zSNs0BI00hNkaZpcByX97aDHKQrbEwEsy7eoNGepCmwRhSsk7A9nCxskk npuFZWICZo5m1GOtlHhVJN/8o3iaPUzoJYCNEDKmO6LSaQ5QWJ25IO+CaIjxGr1CHBSi XroS+YQ36/xu61v9nTsCEqtOerarOCFKePhrqSekhzpmCeNm9BrQOIXMkZyALOVb/UXl ALBgxptvCZL6RTxOvAxgmjxiaV7RzAtivXYNXBLvwM+laOELNwIGzK3IYAmkX07AGCxd FeJ3zEESOgSOFf698rJDq1zSazLJYr9CfrV+GIdJPUybh7MfPqL7PaRz008Qfh6o9gQH 3PRw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=0n5HVSJrrPauy0hNBu4mewBo83XfO+pD5lc0CdaVyyg=; b=J6ceUYTktgrcbmmAR3TftDcysG9mt4iDZ9+hV0af78xZaAYWG058YR+2tEjGeLqSWP R5s5KeY/j91LtDgz/pBc5C5IY2l08i5oSKxLXSdaxYaNxFtcfaGVwAVjN/sUPIejI1e+ OMrziHZqrdoF4L+7SsvWflGXkfWgb4m3g30oe9wPFCaAWmuAlxiwg1B8yFxpbzMLg2/N FIZprwuyBtudMEOQPWjewSJM66+B7HuMUNV2aHvt23iZ9yk4F1BjVkUZoKJ0l0LJ7wxI 6QjCRHaMC7oI6vlLTEBQmyIpxNF/AzSvt7mGu1p2xGN3SnSK/X84iKlEr52QfdBkVtXJ PQAA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=UauZUE8l; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id f7-20020a056512228700b00449fff280f8si7198733lfu.122.2022.04.29.04.06.33; Fri, 29 Apr 2022 04:07:04 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=UauZUE8l; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1351672AbiD1UPl (ORCPT + 99 others); Thu, 28 Apr 2022 16:15:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40966 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1351667AbiD1UPh (ORCPT ); Thu, 28 Apr 2022 16:15:37 -0400 Received: from bhuna.collabora.co.uk (bhuna.collabora.co.uk [46.235.227.227]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1363DBF965 for ; Thu, 28 Apr 2022 13:12:21 -0700 (PDT) Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: bbeckett) with ESMTPSA id A91711F45C29 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=collabora.com; s=mail; t=1651176739; bh=oJtm6y844TMMDR7gVwJerQck47PYpIkgVwT8tzvcr4E=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=UauZUE8l3Dc7aKwTeVQ+2OV/uOndERjgLd9z6vMh1FgidMIDrs6Aq4onzVCgCT9cb iKb8Ga5e/Vxad+8obHRp0vqdNpIR2zkcsNCE/tOldLeoH4KDRe9TfzeqJN3yUatAx+ py4BmLrx1oUX23VOPFtuWTdlnZ7c443M3oTuBm3tkSBBCDKe/nrwaHDB5SP/00QPIx AL2eIo8ClH7VzkiVyNZne3cGw+19oZdMKK9rpzhfuDfxgvIyQxiBzn/kNLYHw1ETxQ bFm9CixAAhDekziGwXim904GckV4bG/uFMAyp/PSr7CEGZhKRA9vDx8joO+K0V2eG3 SjkTsVSU6zBEQ== From: Robert Beckett To: dri-devel@lists.freedesktop.org, intel-gfx@lists.freedesktop.org, Jani Nikula , Joonas Lahtinen , Rodrigo Vivi , Tvrtko Ursulin , David Airlie , Daniel Vetter Cc: Robert Beckett , Matthew Auld , =?UTF-8?q?Thomas=20Hellstr=C3=B6m?= , linux-kernel@vger.kernel.org Subject: [PATCH v5 3/6] drm/i915: ttm move/clear logic fix Date: Thu, 28 Apr 2022 20:11:22 +0000 Message-Id: <20220428201125.412896-4-bob.beckett@collabora.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220428201125.412896-1-bob.beckett@collabora.com> References: <20220428201125.412896-1-bob.beckett@collabora.com> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_PASS,SPF_PASS, UNPARSEABLE_RELAY autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org ttm managed buffers start off with system resource definitions and ttm_tt tracking structures allocated (though unpopulated). currently this prevents clearing of buffers on first move to desired placements. The desired behaviour is to clear user allocated buffers and any kernel buffers that specifically requests it only. Make the logic match the desired behaviour. Signed-off-by: Robert Beckett Reviewed-by: Thomas Hellström --- drivers/gpu/drm/i915/gem/i915_gem_ttm_move.c | 22 +++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/drivers/gpu/drm/i915/gem/i915_gem_ttm_move.c b/drivers/gpu/drm/i915/gem/i915_gem_ttm_move.c index 48046cfd8c4b..2895e13a1cac 100644 --- a/drivers/gpu/drm/i915/gem/i915_gem_ttm_move.c +++ b/drivers/gpu/drm/i915/gem/i915_gem_ttm_move.c @@ -3,6 +3,7 @@ * Copyright © 2021 Intel Corporation */ +#include "drm/ttm/ttm_tt.h" #include #include "i915_deps.h" @@ -471,6 +472,25 @@ __i915_ttm_move(struct ttm_buffer_object *bo, return fence; } +static bool +allow_clear(struct drm_i915_gem_object *obj, struct ttm_tt *ttm, struct ttm_resource *dst_mem) +{ + /* never clear stolen */ + if (dst_mem->mem_type == I915_PL_STOLEN) + return false; + /* + * we want to clear user buffers and any kernel buffers + * that specifically request clearing. + */ + if (obj->flags & I915_BO_ALLOC_USER) + return true; + + if (ttm && ttm->page_flags & TTM_TT_FLAG_ZERO_ALLOC) + return true; + + return false; +} + /** * i915_ttm_move - The TTM move callback used by i915. * @bo: The buffer object. @@ -521,7 +541,7 @@ int i915_ttm_move(struct ttm_buffer_object *bo, bool evict, return PTR_ERR(dst_rsgt); clear = !i915_ttm_cpu_maps_iomem(bo->resource) && (!ttm || !ttm_tt_is_populated(ttm)); - if (!(clear && ttm && !(ttm->page_flags & TTM_TT_FLAG_ZERO_ALLOC))) { + if (!clear || allow_clear(obj, ttm, dst_mem)) { struct i915_deps deps; i915_deps_init(&deps, GFP_KERNEL | __GFP_NORETRY | __GFP_NOWARN); -- 2.25.1