mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Fix lowering of cttz to work with signed values
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@21874 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -251,13 +251,12 @@ void DefaultIntrinsicLowering::LowerIntrinsicCall(CallInst *CI) { | ||||
|     break; | ||||
|   } | ||||
|   case Intrinsic::cttz: { | ||||
|     // cttz(x) -> ctpop(~X & (X-1)) | ||||
|     Value *Src = CI->getOperand(1); | ||||
|     Value *NotSrc = BinaryOperator::createNot(Src, Src->getName()+".not", CI); | ||||
|     Src = BinaryOperator::createAnd(NotSrc, | ||||
|                                     BinaryOperator::createSub(Src,  | ||||
|                            ConstantUInt::get(CI->getOperand(0)->getType(), 1), "", CI)); | ||||
|  | ||||
|     Src = LowerCTPOP(Src, CI); | ||||
|     Value *SrcM1  = ConstantInt::get(Src->getType(), 1); | ||||
|     SrcM1 = BinaryOperator::createSub(Src, SrcM1, "", CI); | ||||
|     Src = LowerCTPOP(BinaryOperator::createAnd(NotSrc, SrcM1, "", CI), CI); | ||||
|     CI->replaceAllUsesWith(Src); | ||||
|     break; | ||||
|   } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user