Commit first round work of PR1373. "noalias" is now fully supported in
authorZhou Sheng <zhousheng00@gmail.com>
Tue, 5 Jun 2007 05:28:26 +0000 (05:28 +0000)
committerZhou Sheng <zhousheng00@gmail.com>
Tue, 5 Jun 2007 05:28:26 +0000 (05:28 +0000)
VMCore, BitCode, and Assembly. Documentation and test case paramattrs.ll
updated also.

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

docs/LangRef.html
include/llvm/ParameterAttributes.h
lib/AsmParser/Lexer.l
lib/AsmParser/llvmAsmParser.y
lib/VMCore/Function.cpp
test/Feature/paramattrs.ll
tools/llvm2cpp/CppWriter.cpp

index e9b3c5601f16cc6a67a72280bdc7b8800b018f33..8d2dc2f98a87a25ea9dea42922c8df0598bc31da 100644 (file)
@@ -784,6 +784,9 @@ a power of 2.</p>
     <dt><tt>sret</tt></dt>
     <dd>This indicates that the parameter specifies the address of a structure
     that is the return value of the function in the source program.</dd>
+    <dt><tt>noalias</tt></dt>
+    <dd>This indicates that the parameter not alias any other object or any 
+    other "noalias" objects during the function call.
     <dt><tt>noreturn</tt></dt>
     <dd>This function attribute indicates that the function never returns. This
     indicates to LLVM that every call to this function should be treated as if
index 35d347690da915d43934b519e4dc06f46e17c27b..dcfe09514117ffb0200c82b00bde4a52ae56a9de 100644 (file)
@@ -35,7 +35,8 @@ enum Attributes {
   NoReturn   = 1 << 2, ///< mark the function as not returning
   InReg      = 1 << 3, ///< force argument to be passed in register
   StructRet  = 1 << 4, ///< hidden pointer to structure to return
-  NoUnwind   = 1 << 5  ///< Function doesn't unwind stack
+  NoUnwind   = 1 << 5, ///< Function doesn't unwind stack
+  NoAlias    = 1 << 6  ///< Considered to not alias after call.
 };
 
 }
index ca6ee2cf73d1fff0a37ae78a5858fcd800b64170..6391d17a52eb536c49cdf6173d69b139564f5db1 100644 (file)
@@ -229,6 +229,7 @@ inreg           { return INREG; }
 sret            { return SRET;  }
 nounwind        { return NOUNWIND; }
 noreturn        { return NORETURN; }
+noalias         { return NOALIAS; }
 
 void            { RET_TY(Type::VoidTy,  VOID);  }
 float           { RET_TY(Type::FloatTy, FLOAT); }
index 01d67ed980360d318d26278561339023cc6d160c..94aeecaf831acf4b76c36be291b703e2a629d379 100644 (file)
@@ -1101,7 +1101,7 @@ Module *llvm::RunVMAsmParser(const char * AsmString, Module * M) {
 %token <OtherOpVal> EXTRACTELEMENT INSERTELEMENT SHUFFLEVECTOR
 
 // Function Attributes
-%token NORETURN INREG SRET NOUNWIND
+%token NORETURN INREG SRET NOUNWIND NOALIAS
 
 // Visibility Styles
 %token DEFAULT HIDDEN PROTECTED
@@ -1224,10 +1224,11 @@ OptCallingConv : /*empty*/          { $$ = CallingConv::C; } |
                   CHECK_FOR_ERROR
                  };
 
-ParamAttr     : ZEXT  { $$ = ParamAttr::ZExt;      }
-              | SEXT  { $$ = ParamAttr::SExt;      }
-              | INREG { $$ = ParamAttr::InReg;     }
-              | SRET  { $$ = ParamAttr::StructRet; }
+ParamAttr     : ZEXT    { $$ = ParamAttr::ZExt;      }
+              | SEXT    { $$ = ParamAttr::SExt;      }
+              | INREG   { $$ = ParamAttr::InReg;     }
+              | SRET    { $$ = ParamAttr::StructRet; }
+              | NOALIAS { $$ = ParamAttr::NoAlias;   }
               ;
 
 OptParamAttrs : /* empty */  { $$ = ParamAttr::None; }
index 8b91c18ffff8e389f333593821d9eaa44e462ac0..54ed25c7b7f21c9a830298c26a5ad8649161191e 100644 (file)
@@ -99,6 +99,8 @@ ParamAttrsList::getParamAttrsText(uint16_t Attrs) {
     Result += "nounwind ";
   if (Attrs & ParamAttr::InReg)
     Result += "inreg ";
+  if (Attrs & ParamAttr::NoAlias)
+    Result += "noalias ";
   if (Attrs & ParamAttr::StructRet)
     Result += "sret ";  
   return Result;
index 84116781f9e9db885a2b01681099da44e576dbea..01dc2fa93a89f000890ed1a999201ee92e0b9b5b 100644 (file)
@@ -8,6 +8,8 @@
 declare i16 @"test"(i16 sext %arg) sext 
 declare i8 @"test2" (i16 zext %a2) zext 
 
+declare i32 @"test3"(i32* noalias %p)
+
 declare void @exit(i32) noreturn nounwind
 
 define i32 @main(i32 %argc, i8 **%argv) nounwind inreg {
index 58c67b716e3758dd9d120a015a604d54bd1ed28d..86e266147c00ce288af33797748a550015dabc86 100644 (file)
@@ -473,6 +473,8 @@ CppWriter::printTypeInternal(const Type* Ty) {
             Out << " | ParamAttr::SExt";
           if (attrs & ParamAttr::ZExt)
             Out << " | ParamAttr::ZExt";
+          if (attrs & ParamAttr::NoAlias)
+            Out << " | ParamAttr::NoAlias";
           if (attrs & ParamAttr::StructRet)
             Out << " | ParamAttr::StructRet";
           if (attrs & ParamAttr::InReg)