Add support for __builtin_expect which is needed for assert, 
among other things.

Also change a codegen warning to dump to stderr so it doesn't
mess with -emit-llvm output



git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@44497 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/CodeGen/CGBuiltin.cpp b/CodeGen/CGBuiltin.cpp
index 803d89e..52a41d8 100644
--- a/CodeGen/CGBuiltin.cpp
+++ b/CodeGen/CGBuiltin.cpp
@@ -97,6 +97,10 @@
     
     return RValue::get(Result);
   }
+  case Builtin::BI__builtin_expect: {
+    llvm::Value *Condition = EmitScalarExpr(E->getArg(0));   
+    return RValue::get(Condition);
+  }
   }
   
   return RValue::get(0);
diff --git a/CodeGen/CGStmt.cpp b/CodeGen/CGStmt.cpp
index 9059a83..b010e81 100644
--- a/CodeGen/CGStmt.cpp
+++ b/CodeGen/CGStmt.cpp
@@ -38,7 +38,7 @@
       else
         EmitAggExpr(E, 0, false);
     } else {
-      printf("Unimplemented stmt!\n");
+      fprintf(stderr, "Unimplemented stmt!\n");
       S->dump(getContext().SourceMgr);
     }
     break;
diff --git a/include/clang/AST/Builtins.def b/include/clang/AST/Builtins.def
index 7733a9b..f2f1824 100644
--- a/include/clang/AST/Builtins.def
+++ b/include/clang/AST/Builtins.def
@@ -67,5 +67,6 @@
 BUILTIN(__builtin_va_end, "va&", "n")
 BUILTIN(__builtin_va_copy, "va&a", "n")
 BUILTIN(__builtin_memcpy, "v*v*vC*z", "n")
+BUILTIN(__builtin_expect, "iii"   , "nc")
 
 #undef BUILTIN