提交 27f6642d 编写于 作者: J Jammy Zhou 提交者: Alex Deucher

drm/amdgpu: add amd_sched_next_queued_seq function

This function is used to get the next queued sequence number
Signed-off-by: NJammy Zhou <Jammy.Zhou@amd.com>
Reviewed-by: NChristian König <christian.koenig@amd.com>
Reviewed-by: NAlex Deucher <alexander.deucher@amd.com>
上级 63ad8d58
...@@ -310,7 +310,7 @@ struct fence *amdgpu_ctx_get_fence(struct amdgpu_ctx *ctx, ...@@ -310,7 +310,7 @@ struct fence *amdgpu_ctx_get_fence(struct amdgpu_ctx *ctx,
spin_lock(&ctx->ring_lock); spin_lock(&ctx->ring_lock);
if (amdgpu_enable_scheduler) if (amdgpu_enable_scheduler)
queued_seq = atomic64_read(&cring->c_entity.last_queued_v_seq) + 1; queued_seq = amd_sched_next_queued_seq(&cring->c_entity);
else else
queued_seq = cring->sequence; queued_seq = cring->sequence;
......
...@@ -507,3 +507,15 @@ void amd_sched_emit(struct amd_context_entity *c_entity, uint64_t seq) ...@@ -507,3 +507,15 @@ void amd_sched_emit(struct amd_context_entity *c_entity, uint64_t seq)
atomic64_set(&c_entity->last_emitted_v_seq, seq); atomic64_set(&c_entity->last_emitted_v_seq, seq);
wake_up_all(&c_entity->wait_emit); wake_up_all(&c_entity->wait_emit);
} }
/**
* Get next queued sequence number
*
* @entity The context entity
*
* return the next queued sequence number
*/
uint64_t amd_sched_next_queued_seq(struct amd_context_entity *c_entity)
{
return atomic64_read(&c_entity->last_queued_v_seq) + 1;
}
...@@ -153,4 +153,6 @@ int amd_context_entity_init(struct amd_gpu_scheduler *sched, ...@@ -153,4 +153,6 @@ int amd_context_entity_init(struct amd_gpu_scheduler *sched,
void amd_sched_emit(struct amd_context_entity *c_entity, uint64_t seq); void amd_sched_emit(struct amd_context_entity *c_entity, uint64_t seq);
uint64_t amd_sched_next_queued_seq(struct amd_context_entity *c_entity);
#endif #endif
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册