Received: by 2002:a05:7412:2a8c:b0:e2:908c:2ebd with SMTP id u12csp654497rdh; Sun, 24 Sep 2023 06:19:07 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHQKCYSWEH9vWlov1NLUWHfns/WpDccaorVzyTaWpGka13kzdeHXDHibed2xXlNR5e/ATlh X-Received: by 2002:a05:6a21:3d87:b0:15a:2d98:bc81 with SMTP id bj7-20020a056a213d8700b0015a2d98bc81mr2916739pzc.53.1695561547052; Sun, 24 Sep 2023 06:19:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1695561547; cv=none; d=google.com; s=arc-20160816; b=CjE+c9aePWw1gKyYcdL2Fwv9DTY3iyfMOUDJdwgO2NeIv1VUcl+FIsYb7jGfE1FhC9 egfl7QOqFzH3pMcXXwbBmbELx5TOnFk8jNFjh1PbWASk/lG7a8jUGGJCCxw2jpZB2JxY xu1QL6ypszfsjED2rFLzKBe9HUZk8Hc82sCMmhPZjyXBifsL1aDV1YQWs+ASV72JgdLb pMsbMkUutjkZLFcPP3Vx8ceubINxAJ9ndUejt/Iy5XOFXr/hnhlS4AVN+Gj/I1kdk2AQ dC8z3/OM7s5NkRNn9B1aLCI5FPP8324q8ZPRosckGZreuVkLoM7Ro7UY/Q1HEzYwYOU1 +uBQ== 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=sb9sOh0s11wpl8LXdXPCBZ0KbbiDjG6vpIOxJn1OffE=; fh=YKDty959VsRqAflCxjUSG/+13ccIqVYiRft+3Id/6k0=; b=FippTebZTr8RnlOZFJWFwLcC5Wu6+31vtYMnMNS7+RVBtqvamJeEvn+nUwPhX6xRk2 1JsK3yaPkwlz5r1Msc3AN3X2HfDJr6Sox61f8xNiaOUi8jwKoMmI1UlAWBns4nM9ppMu 5NIhl5h493l2jBeZAuOqGts79Fp4c1tDq1MPmmrhhWX7uIgjcLENALEcNcZWAF8uUOqA rejgqY38hOlkKSJYTnaX2uFyHqL587DH0vE0BJAZChP9JpD7pLpjEdTz2luKLthAhpGM xSTiwNuSeSDF8GrNZKY+bvq830RxwhUGa45cg+ksXOYG7AwFREPXuOThYYs39N1WgJ7v ipVw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b="idzV2Yw/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from morse.vger.email (morse.vger.email. [2620:137:e000::3:1]) by mx.google.com with ESMTPS id b14-20020a170902650e00b001c61bd7cee0si84419plk.211.2023.09.24.06.19.06 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 24 Sep 2023 06:19:07 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) client-ip=2620:137:e000::3:1; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b="idzV2Yw/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by morse.vger.email (Postfix) with ESMTP id C8ACF8022090; Sun, 24 Sep 2023 06:19:03 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at morse.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229688AbjIXNTB (ORCPT + 99 others); Sun, 24 Sep 2023 09:19:01 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41552 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230241AbjIXNSh (ORCPT ); Sun, 24 Sep 2023 09:18:37 -0400 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1A8AE1FC1; Sun, 24 Sep 2023 06:17:25 -0700 (PDT) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 27D2CC433BD; Sun, 24 Sep 2023 13:17:23 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1695561444; bh=d3MIZ2fZqZ8L6qjp0pv9yd66PqAm27pXdBW8ssP+3xE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=idzV2Yw/VnFq7MFK16QCE3VOROI3UDD01scr7fvG0I5gtZk3ssmX8wbgBSS/a6y8J jFakfLCLRPbwibeSiV4mXmUC64U6VSwOzouUhMaN/OI6UYE/V/ctwr3LMw2z3YIBQL 9EovpyywjnWaLb+Flh3t77iQVVaTkEL1VRcvO5TC3R0rDeAR48FUxnfNlcTDB90kca YAh54vRGtErM2FfChxyrntEijuHuXPgl6UfWHnvl/hVLBGRGBfFzCAH3Js0FK4tuRv m1fl8lJj1dSP9lYEgO+DdGaaO8/AAsiSsrWovPZdJvrdGEZGtsG/UsDsPoXPf+kP8w qakyPHiC9Xejg== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: David Francis , Felix Kuehling , Harish Kasiviswanathan , Alex Deucher , Sasha Levin , Felix.Kuehling@amd.com, christian.koenig@amd.com, Xinhui.Pan@amd.com, airlied@gmail.com, daniel@ffwll.ch, amd-gfx@lists.freedesktop.org, dri-devel@lists.freedesktop.org Subject: [PATCH AUTOSEL 6.5 32/41] drm/amdkfd: Checkpoint and restore queues on GFX11 Date: Sun, 24 Sep 2023 09:15:20 -0400 Message-Id: <20230924131529.1275335-32-sashal@kernel.org> X-Mailer: git-send-email 2.40.1 In-Reply-To: <20230924131529.1275335-1-sashal@kernel.org> References: <20230924131529.1275335-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore X-stable-base: Linux 6.5.5 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.2 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on morse.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 (morse.vger.email [0.0.0.0]); Sun, 24 Sep 2023 06:19:03 -0700 (PDT) From: David Francis [ Upstream commit 9296da8c40900b4dae3d973aa22be306e2a77671 ] The code in kfd_mqd_manager_v11.c to support criu dump and restore of queue state was missing. Added it; should be equivalent to kfd_mqd_manager_v10.c. CC: Felix Kuehling Reviewed-by: Harish Kasiviswanathan Acked-by: Alex Deucher Signed-off-by: David Francis Signed-off-by: Alex Deucher Signed-off-by: Sasha Levin --- .../gpu/drm/amd/amdkfd/kfd_mqd_manager_v11.c | 41 +++++++++++++++++++ 1 file changed, 41 insertions(+) diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_mqd_manager_v11.c b/drivers/gpu/drm/amd/amdkfd/kfd_mqd_manager_v11.c index 97f754949ca92..352757f2d3202 100644 --- a/drivers/gpu/drm/amd/amdkfd/kfd_mqd_manager_v11.c +++ b/drivers/gpu/drm/amd/amdkfd/kfd_mqd_manager_v11.c @@ -321,6 +321,43 @@ static int get_wave_state(struct mqd_manager *mm, void *mqd, return 0; } +static void checkpoint_mqd(struct mqd_manager *mm, void *mqd, void *mqd_dst, void *ctl_stack_dst) +{ + struct v11_compute_mqd *m; + + m = get_mqd(mqd); + + memcpy(mqd_dst, m, sizeof(struct v11_compute_mqd)); +} + +static void restore_mqd(struct mqd_manager *mm, void **mqd, + struct kfd_mem_obj *mqd_mem_obj, uint64_t *gart_addr, + struct queue_properties *qp, + const void *mqd_src, + const void *ctl_stack_src, const u32 ctl_stack_size) +{ + uint64_t addr; + struct v11_compute_mqd *m; + + m = (struct v11_compute_mqd *) mqd_mem_obj->cpu_ptr; + addr = mqd_mem_obj->gpu_addr; + + memcpy(m, mqd_src, sizeof(*m)); + + *mqd = m; + if (gart_addr) + *gart_addr = addr; + + m->cp_hqd_pq_doorbell_control = + qp->doorbell_off << + CP_HQD_PQ_DOORBELL_CONTROL__DOORBELL_OFFSET__SHIFT; + pr_debug("cp_hqd_pq_doorbell_control 0x%x\n", + m->cp_hqd_pq_doorbell_control); + + qp->is_active = 0; +} + + static void init_mqd_hiq(struct mqd_manager *mm, void **mqd, struct kfd_mem_obj *mqd_mem_obj, uint64_t *gart_addr, struct queue_properties *q) @@ -438,6 +475,8 @@ struct mqd_manager *mqd_manager_init_v11(enum KFD_MQD_TYPE type, mqd->mqd_size = sizeof(struct v11_compute_mqd); mqd->get_wave_state = get_wave_state; mqd->mqd_stride = kfd_mqd_stride; + mqd->checkpoint_mqd = checkpoint_mqd; + mqd->restore_mqd = restore_mqd; #if defined(CONFIG_DEBUG_FS) mqd->debugfs_show_mqd = debugfs_show_mqd; #endif @@ -482,6 +521,8 @@ struct mqd_manager *mqd_manager_init_v11(enum KFD_MQD_TYPE type, mqd->update_mqd = update_mqd_sdma; mqd->destroy_mqd = kfd_destroy_mqd_sdma; mqd->is_occupied = kfd_is_occupied_sdma; + mqd->checkpoint_mqd = checkpoint_mqd; + mqd->restore_mqd = restore_mqd; mqd->mqd_size = sizeof(struct v11_sdma_mqd); mqd->mqd_stride = kfd_mqd_stride; #if defined(CONFIG_DEBUG_FS) -- 2.40.1