Commit 7386f88a authored by Jonathan Kim's avatar Jonathan Kim Committed by Alex Deucher

drm/amdkfd: fix vmfault signalling with additional data.

Exception handling for vmfaults should be raised with additional data.
Reported-by: default avatarMukul Joshi <mukul.joshi@amd.com>
Signed-off-by: default avatarJonathan Kim <jonathan.kim@amd.com>
Reviewed-by: default avatarMukul Joshi <mukul.joshi@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 0bc3137b
...@@ -1240,19 +1240,24 @@ void kfd_signal_vm_fault_event(struct kfd_node *dev, u32 pasid, ...@@ -1240,19 +1240,24 @@ void kfd_signal_vm_fault_event(struct kfd_node *dev, u32 pasid,
return; return;
} }
memset(&memory_exception_data, 0, sizeof(memory_exception_data)); /* SoC15 chips and onwards will pass in data from now on. */
memory_exception_data.gpu_id = user_gpu_id; if (!data) {
memory_exception_data.failure.imprecise = true; memset(&memory_exception_data, 0, sizeof(memory_exception_data));
/* Set failure reason */ memory_exception_data.gpu_id = user_gpu_id;
if (info) { memory_exception_data.failure.imprecise = true;
memory_exception_data.va = (info->page_addr) << PAGE_SHIFT;
memory_exception_data.failure.NotPresent = /* Set failure reason */
info->prot_valid ? 1 : 0; if (info) {
memory_exception_data.failure.NoExecute = memory_exception_data.va = (info->page_addr) <<
info->prot_exec ? 1 : 0; PAGE_SHIFT;
memory_exception_data.failure.ReadOnly = memory_exception_data.failure.NotPresent =
info->prot_write ? 1 : 0; info->prot_valid ? 1 : 0;
memory_exception_data.failure.imprecise = 0; memory_exception_data.failure.NoExecute =
info->prot_exec ? 1 : 0;
memory_exception_data.failure.ReadOnly =
info->prot_write ? 1 : 0;
memory_exception_data.failure.imprecise = 0;
}
} }
rcu_read_lock(); rcu_read_lock();
...@@ -1261,7 +1266,8 @@ void kfd_signal_vm_fault_event(struct kfd_node *dev, u32 pasid, ...@@ -1261,7 +1266,8 @@ void kfd_signal_vm_fault_event(struct kfd_node *dev, u32 pasid,
idr_for_each_entry_continue(&p->event_idr, ev, id) idr_for_each_entry_continue(&p->event_idr, ev, id)
if (ev->type == KFD_EVENT_TYPE_MEMORY) { if (ev->type == KFD_EVENT_TYPE_MEMORY) {
spin_lock(&ev->lock); spin_lock(&ev->lock);
ev->memory_exception_data = memory_exception_data; ev->memory_exception_data = data ? *data :
memory_exception_data;
set_event(ev); set_event(ev);
spin_unlock(&ev->lock); spin_unlock(&ev->lock);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment