diff --git a/src/core/inc/amd_blit_sdma.h b/src/core/inc/amd_blit_sdma.h index 21dd55273..c7ebf9925 100644 --- a/src/core/inc/amd_blit_sdma.h +++ b/src/core/inc/amd_blit_sdma.h @@ -208,7 +208,7 @@ class BlitSdma : public BlitSdmaBase { void BuildGetGlobalTimestampCommand(char* cmd_addr, void* write_address); - void BuildTrapCommand(char* cmd_addr); + void BuildTrapCommand(char* cmd_addr, uint32_t event_id); void BuildGCRCommand(char* cmd_addr, bool invalidate); diff --git a/src/core/runtime/amd_blit_sdma.cpp b/src/core/runtime/amd_blit_sdma.cpp index f35ea8982..8af1d7683 100644 --- a/src/core/runtime/amd_blit_sdma.cpp +++ b/src/core/runtime/amd_blit_sdma.cpp @@ -384,7 +384,7 @@ hsa_status_t BlitSdma: static_cast(out_signal.signal_.event_id)); command_addr += fence_command_size_; - BuildTrapCommand(command_addr); + BuildTrapCommand(command_addr, out_signal.signal_.event_id); } ReleaseWriteAddress(curr_index, total_command_size); @@ -911,13 +911,14 @@ void BlitSdma void BlitSdma::BuildTrapCommand( - char* cmd_addr) { + char* cmd_addr, uint32_t event_id) { SDMA_PKT_TRAP* packet_addr = reinterpret_cast(cmd_addr); memset(packet_addr, 0, sizeof(SDMA_PKT_TRAP)); packet_addr->HEADER_UNION.op = SDMA_OP_TRAP; + packet_addr->INT_CONTEXT_UNION.int_ctx = event_id; } template