forked from OSchip/llvm-project
Added support for the llvm.readio and llvm.writeio intrinsics.
On x86, memory operations occur in-order, so these are just lowered into volatile loads and stores. llvm-svn: 12936
This commit is contained in:
parent
9042e381d8
commit
beded72a08
|
@ -1541,6 +1541,35 @@ void ISel::LowerUnknownIntrinsicFunctionCalls(Function &F) {
|
|||
case Intrinsic::writeport:
|
||||
// We directly implement these intrinsics
|
||||
break;
|
||||
case Intrinsic::readio: {
|
||||
// On X86, memory operations are in-order. Lower this intrinsic
|
||||
// into a volatile load.
|
||||
Instruction *Before = CI->getPrev();
|
||||
LoadInst * LI = new LoadInst (CI->getOperand(1), "", true, CI);
|
||||
CI->replaceAllUsesWith (LI);
|
||||
BB->getInstList().erase (CI);
|
||||
if (Before) { // Move iterator to instruction after call
|
||||
I = Before; ++I;
|
||||
} else {
|
||||
I = BB->begin();
|
||||
}
|
||||
break;
|
||||
}
|
||||
case Intrinsic::writeio: {
|
||||
// On X86, memory operations are in-order. Lower this intrinsic
|
||||
// into a volatile store.
|
||||
Instruction *Before = CI->getPrev();
|
||||
StoreInst * LI = new StoreInst (CI->getOperand(1),
|
||||
CI->getOperand(2), true, CI);
|
||||
CI->replaceAllUsesWith (LI);
|
||||
BB->getInstList().erase (CI);
|
||||
if (Before) { // Move iterator to instruction after call
|
||||
I = Before; ++I;
|
||||
} else {
|
||||
I = BB->begin();
|
||||
}
|
||||
break;
|
||||
}
|
||||
default:
|
||||
// All other intrinsic calls we must lower.
|
||||
Instruction *Before = CI->getPrev();
|
||||
|
|
Loading…
Reference in New Issue