Fix bug in FunctionEmitContext::SyncInst()
The launch group handle is now reset to NULL after sync is called; this ensures that if tasks are launched in the same function after a sync, that the ISPCAlloc() call for the next launch will be passed a NULL handle (as it should be).
This commit is contained in:
8
ctx.cpp
8
ctx.cpp
@@ -2352,7 +2352,8 @@ FunctionEmitContext::LaunchInst(llvm::Value *callee,
|
||||
void
|
||||
FunctionEmitContext::SyncInst() {
|
||||
llvm::Value *launchGroupHandle = LoadInst(launchGroupHandlePtr);
|
||||
llvm::Value *nullPtrValue = llvm::Constant::getNullValue(LLVMTypes::VoidPointerType);
|
||||
llvm::Value *nullPtrValue =
|
||||
llvm::Constant::getNullValue(LLVMTypes::VoidPointerType);
|
||||
llvm::Value *nonNull = CmpInst(llvm::Instruction::ICmp,
|
||||
llvm::CmpInst::ICMP_NE,
|
||||
launchGroupHandle, nullPtrValue);
|
||||
@@ -2365,6 +2366,11 @@ FunctionEmitContext::SyncInst() {
|
||||
if (fsync == NULL)
|
||||
FATAL("Couldn't find ISPCSync declaration?!");
|
||||
CallInst(fsync, NULL, launchGroupHandle, "");
|
||||
|
||||
// zero out the handle so that if ISPCLaunch is called again in this
|
||||
// function, it knows it's starting out from scratch
|
||||
StoreInst(nullPtrValue, launchGroupHandlePtr);
|
||||
|
||||
BranchInst(bPostSync);
|
||||
|
||||
SetCurrentBasicBlock(bPostSync);
|
||||
|
||||
Reference in New Issue
Block a user