Skip to content
Snippets Groups Projects
Commit 0d8677bc authored by Akash Kothari's avatar Akash Kothari :speech_balloon:
Browse files

Fix bug involving casts in internal nodes

parent f2bbcd36
No related branches found
No related tags found
No related merge requests found
......@@ -337,52 +337,55 @@ void BuildDFG::handleBindOutput(DFInternalNode* N, IntrinsicInst* II) {
}
void BuildDFG::BuildGraph (DFInternalNode* N, Function *F) {
errs() << "FUNCTION: " << F->getName() << "\n";
// TODO: Place checks for valid visc functions. For example one of the
// check can be that any function that contains visc dataflow graph
// construction intrinsics should not have other llvm IR statements.
// Iterate over all the instructions of a function and look for visc
// intrinsics.
for (inst_iterator i = inst_begin(F), e = inst_end(F); i != e; ++i) {
Instruction* I = &*i; // Grab pointer to instruction reference
DEBUG(errs() << *I << "\n");
if(IntrinsicInst* II = dyn_cast<IntrinsicInst>(I)) {
DEBUG(errs() << "IntrinsicID = " << II->getIntrinsicID() << ": " << II->getCalledFunction()->getName()<<"\n");
switch(II->getIntrinsicID()) {
case Intrinsic::visc_createNode:
case Intrinsic::visc_createNode1D:
case Intrinsic::visc_createNode2D:
case Intrinsic::visc_createNode3D:
handleCreateNode (N, II);
break;
case Intrinsic::visc_createEdge:
handleCreateEdge(N, II);
break;
case Intrinsic::visc_bind_input:
handleBindInput(N, II);
break;
case Intrinsic::visc_bind_output:
handleBindOutput(N, II);
break;
//TODO: Reconsider launch within a dataflow graph (recursion?)
case Intrinsic::visc_wait:
case Intrinsic::visc_launch:
errs() << "Error: Launch/wait intrinsic used within a dataflow graph\n\t" << *II << "\n";
break;
default:
errs() << "Error: Invalid VISC Intrinsic inside Internal node!\n\t" << *II << "\n";
break;
}
}
else if(!isa<ReturnInst>(I)) {
errs() << "Non-intrinsic instruction: " << *I << "\n";
llvm_unreachable("Found non-intrinsic instruction inside an internal node. Only return instruction is allowed!");
for(auto &BB : *F) {
for(auto &Inst : BB) {
Instruction* I = &Inst;
DEBUG(errs() << *I << "\n");
if(IntrinsicInst* II = dyn_cast<IntrinsicInst>(I)) {
DEBUG(errs() << "IntrinsicID = " << II->getIntrinsicID() << ": " << II->getCalledFunction()->getName()<<"\n");
switch(II->getIntrinsicID()) {
case Intrinsic::visc_createNode:
case Intrinsic::visc_createNode1D:
case Intrinsic::visc_createNode2D:
case Intrinsic::visc_createNode3D:
handleCreateNode (N, II);
break;
case Intrinsic::visc_createEdge:
handleCreateEdge(N, II);
break;
case Intrinsic::visc_bind_input:
handleBindInput(N, II);
break;
case Intrinsic::visc_bind_output:
handleBindOutput(N, II);
break;
//TODO: Reconsider launch within a dataflow graph (recursion?)
case Intrinsic::visc_wait:
case Intrinsic::visc_launch:
errs() << "Error: Launch/wait intrinsic used within a dataflow graph\n\t" << *II << "\n";
break;
default:
errs() << "Error: Invalid VISC Intrinsic inside Internal node!\n\t" << *II << "\n";
break;
}
continue;
}
if(!isa<ReturnInst>(I) && !isa<CastInst>(I)) {
errs() << "Non-intrinsic instruction: " << *I << "\n";
llvm_unreachable("Found non-intrinsic instruction inside an internal node. Only return instruction is allowed!");
}
}
}
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment