diff --git a/rocclr/runtime/device/rocm/rocvirtual.cpp b/rocclr/runtime/device/rocm/rocvirtual.cpp index 4af1354d6e..c0679a7170 100644 --- a/rocclr/runtime/device/rocm/rocvirtual.cpp +++ b/rocclr/runtime/device/rocm/rocvirtual.cpp @@ -2059,23 +2059,28 @@ bool VirtualGPU::submitKernelInternal(const amd::NDRangeContainer& sizes, const break; } case amd::KernelParameterDescriptor::HiddenDefaultQueue: { + uint64_t vqVA = 0; amd::DeviceQueue* defQueue = kernel.program().context().defDeviceQueue(dev()); - - if (!createVirtualQueue(defQueue->size()) || !createSchedulerParam()) { - return false; + if (nullptr != defQueue) { + if (!createVirtualQueue(defQueue->size()) || !createSchedulerParam()) { + return false; + } + gpuKernel.setDynamicParallelFlag(true); + vqVA = getVQVirtualAddress(); } - gpuKernel.setDynamicParallelFlag(true); - uint64_t vqVA = getVQVirtualAddress(); WriteAqlArgAt(const_cast
(parameters), &vqVA, it.size_, it.offset_); break; } case amd::KernelParameterDescriptor::HiddenCompletionAction: { - Memory* schedulerMem = dev().getRocMemory(schedulerParam_); - AmdAqlWrap* wrap = reinterpret_cast