Make shl instruction mask its result to the correct bitsize. This is
authorReid Spencer <rspencer@reidspencer.com>
Thu, 18 Jan 2007 01:32:46 +0000 (01:32 +0000)
committerReid Spencer <rspencer@reidspencer.com>
Thu, 18 Jan 2007 01:32:46 +0000 (01:32 +0000)
sufficient to get llvm-test/SingleSource/UnitTests/Integer/general-test.ll
working with lli in interpreter mode.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@33321 91177308-0d34-0410-b5e6-96231b3b80d8

lib/ExecutionEngine/Interpreter/Execution.cpp

index 383e809b18a2c3f8e9df6ae549d914639023b14b..177ad368be5fc30ed97e973a2425ae38fd4bd102 100644 (file)
@@ -1187,15 +1187,20 @@ static GenericValue executeShlInst(GenericValue Src1, GenericValue Src2,
   GenericValue Dest;
   if (const IntegerType *ITy = cast<IntegerType>(Ty)) {
     unsigned BitWidth = ITy->getBitWidth();
-    if (BitWidth <= 8)
+    uint32_t BitMask = (1ull << BitWidth) - 1;
+    if (BitWidth <= 8) {
       Dest.Int8Val  = ((uint8_t)Src1.Int8Val)   << ((uint32_t)Src2.Int8Val);
-    else if (BitWidth <= 16)
+      Dest.Int8Val &= BitMask;
+    } else if (BitWidth <= 16) {
       Dest.Int16Val = ((uint16_t)Src1.Int16Val) << ((uint32_t)Src2.Int8Val);
-    else if (BitWidth <= 32)
+      Dest.Int16Val &= BitMask;
+    } else if (BitWidth <= 32) {
       Dest.Int32Val = ((uint32_t)Src1.Int32Val) << ((uint32_t)Src2.Int8Val);
-    else if (BitWidth <= 64)
+      Dest.Int32Val &= BitMask;
+    } else if (BitWidth <= 64) {
       Dest.Int64Val = ((uint64_t)Src1.Int64Val) << ((uint32_t)Src2.Int8Val);
-    else {
+      Dest.Int64Val &= BitMask;
+    } else {
       cerr << "Integer types > 64 bits not supported: " << *Ty << "\n";
       abort();
     }