Commit 2e2b9baf authored by Ruili Ji's avatar Ruili Ji Committed by Alex Deucher
Browse files

drm/amdkfd: To fix sdma page fault issue for GC 11



For the MQD memory, KMD would always allocate 4K memory,
and mes scheduler would write to the end of MQD for unmap flag.

Signed-off-by: default avatarRuili Ji <ruiliji2@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent a48bba98
Loading
Loading
Loading
Loading
+3 −2
Original line number Diff line number Diff line
@@ -2373,7 +2373,7 @@ struct device_queue_manager *device_queue_manager_init(struct kfd_dev *dev)
	if (init_mqd_managers(dqm))
		goto out_free;

	if (allocate_hiq_sdma_mqd(dqm)) {
	if (!dev->shared_resources.enable_mes && allocate_hiq_sdma_mqd(dqm)) {
		pr_err("Failed to allocate hiq sdma mqd trunk buffer\n");
		goto out_free;
	}
@@ -2397,6 +2397,7 @@ static void deallocate_hiq_sdma_mqd(struct kfd_dev *dev,
void device_queue_manager_uninit(struct device_queue_manager *dqm)
{
	dqm->ops.uninitialize(dqm);
	if (!dqm->dev->shared_resources.enable_mes)
		deallocate_hiq_sdma_mqd(dqm->dev, &dqm->hiq_sdma_mqd);
	kfree(dqm);
}
+14 −1
Original line number Diff line number Diff line
@@ -308,11 +308,16 @@ static void init_mqd_sdma(struct mqd_manager *mm, void **mqd,
		struct queue_properties *q)
{
	struct v11_sdma_mqd *m;
	int size;

	m = (struct v11_sdma_mqd *) mqd_mem_obj->cpu_ptr;

	memset(m, 0, sizeof(struct v11_sdma_mqd));
	if (mm->dev->shared_resources.enable_mes)
		size = PAGE_SIZE;
	else
		size = sizeof(struct v11_sdma_mqd);

	memset(m, 0, size);
	*mqd = m;
	if (gart_addr)
		*gart_addr = mqd_mem_obj->gpu_addr;
@@ -443,6 +448,14 @@ struct mqd_manager *mqd_manager_init_v11(enum KFD_MQD_TYPE type,
#if defined(CONFIG_DEBUG_FS)
		mqd->debugfs_show_mqd = debugfs_show_mqd_sdma;
#endif
		/*
		 * To allocate SDMA MQDs by generic functions
		 * when MES is enabled.
		 */
		if (dev->shared_resources.enable_mes) {
			mqd->allocate_mqd = allocate_mqd;
			mqd->free_mqd = kfd_free_mqd_cp;
		}
		pr_debug("%s@%i\n", __func__, __LINE__);
		break;
	default: