[llvm-commits] CVS: llvm/lib/Transforms/ExprTypeConvert.cpp TransformInternals.cpp

Chris Lattner lattner at cs.uiuc.edu
Mon Jun 23 12:38:00 PDT 2003


Changes in directory llvm/lib/Transforms:

ExprTypeConvert.cpp updated: 1.73 -> 1.74
TransformInternals.cpp updated: 1.35 -> 1.36

---
Log message:

avoid dividing by zero when dealing with zero sized types (like [0 x double])


---
Diffs of the changes:

Index: llvm/lib/Transforms/ExprTypeConvert.cpp
diff -u llvm/lib/Transforms/ExprTypeConvert.cpp:1.73 llvm/lib/Transforms/ExprTypeConvert.cpp:1.74
--- llvm/lib/Transforms/ExprTypeConvert.cpp:1.73	Thu May 29 10:12:27 2003
+++ llvm/lib/Transforms/ExprTypeConvert.cpp	Mon Jun 23 12:36:49 2003
@@ -49,6 +49,7 @@
 
   // Get information about the base datatype being allocated, before & after
   int ReqTypeSize = TD.getTypeSize(Ty);
+  if (ReqTypeSize == 0) return false;
   unsigned OldTypeSize = TD.getTypeSize(MI->getType()->getElementType());
 
   // Must have a scale or offset to analyze it...


Index: llvm/lib/Transforms/TransformInternals.cpp
diff -u llvm/lib/Transforms/TransformInternals.cpp:1.35 llvm/lib/Transforms/TransformInternals.cpp:1.36
--- llvm/lib/Transforms/TransformInternals.cpp:1.35	Sat Jun  7 16:45:42 2003
+++ llvm/lib/Transforms/TransformInternals.cpp	Mon Jun 23 12:36:49 2003
@@ -119,6 +119,7 @@
       if (!ElTy->isSized() || (isa<PointerType>(CompTy) && !Indices.empty()))
         return 0; // Type is unreasonable... escape!
       unsigned ElSize = TD.getTypeSize(ElTy);
+      if (ElSize == 0) return 0;   // Avoid division by zero...
       int64_t ElSizeS = ElSize;
 
       // See if the user is indexing into a different cell of this array...





More information about the llvm-commits mailing list