diff --git a/lib/Target/CBackend/CBackend.cpp b/lib/Target/CBackend/CBackend.cpp index a12afa79581..954266163b1 100644 --- a/lib/Target/CBackend/CBackend.cpp +++ b/lib/Target/CBackend/CBackend.cpp @@ -435,7 +435,9 @@ void CWriter::printConstant(Constant *CPV) { case Type::PointerTyID: if (isa(CPV)) { - Out << "(NULL)"; + Out << "(("; + printType(Out, CPV->getType()); + Out << ")/*NULL*/0)"; break; } else if (ConstantPointerRef *CPR = dyn_cast(CPV)) { writeOperand(CPR->getValue()); @@ -545,9 +547,8 @@ void CWriter::printModule(Module *M) { Out << "#include \n"; Out << "#include \n"; - // Provide a definition for null if one does not already exist, - // and for `bool' if not compiling with a C++ compiler. - Out << "#ifndef NULL\n#define NULL 0\n#endif\n\n" + // Provide a definition for `bool' if not compiling with a C++ compiler. + Out << "\n" << "#ifndef __cplusplus\ntypedef unsigned char bool;\n#endif\n" << "\n\n/* Support for floating point constants */\n" diff --git a/lib/Target/CBackend/Writer.cpp b/lib/Target/CBackend/Writer.cpp index a12afa79581..954266163b1 100644 --- a/lib/Target/CBackend/Writer.cpp +++ b/lib/Target/CBackend/Writer.cpp @@ -435,7 +435,9 @@ void CWriter::printConstant(Constant *CPV) { case Type::PointerTyID: if (isa(CPV)) { - Out << "(NULL)"; + Out << "(("; + printType(Out, CPV->getType()); + Out << ")/*NULL*/0)"; break; } else if (ConstantPointerRef *CPR = dyn_cast(CPV)) { writeOperand(CPR->getValue()); @@ -545,9 +547,8 @@ void CWriter::printModule(Module *M) { Out << "#include \n"; Out << "#include \n"; - // Provide a definition for null if one does not already exist, - // and for `bool' if not compiling with a C++ compiler. - Out << "#ifndef NULL\n#define NULL 0\n#endif\n\n" + // Provide a definition for `bool' if not compiling with a C++ compiler. + Out << "\n" << "#ifndef __cplusplus\ntypedef unsigned char bool;\n#endif\n" << "\n\n/* Support for floating point constants */\n"