Index: lib/Transforms/Instrumentation/MemorySanitizer.cpp =================================================================== --- lib/Transforms/Instrumentation/MemorySanitizer.cpp +++ lib/Transforms/Instrumentation/MemorySanitizer.cpp @@ -120,10 +120,12 @@ #define DEBUG_TYPE "msan" -static const uint64_t kShadowMask32 = 1ULL << 31; -static const uint64_t kShadowMask64 = 1ULL << 46; -static const uint64_t kOriginOffset32 = 1ULL << 30; -static const uint64_t kOriginOffset64 = 1ULL << 45; +static const uint64_t kX86ShadowMask = 1ULL << 31; +static const uint64_t kX86_64ShadowMask = 1ULL << 46; +static const uint64_t kMIPS64ShadowMask = 1ULL << 38; +static const uint64_t kX86OriginOffset = 1ULL << 30; +static const uint64_t kX86_64OriginOffset = 1ULL << 45; +static const uint64_t kMIPS64OriginOffset = 1ULL << 37; static const unsigned kMinOriginAlignment = 4; static const unsigned kShadowTLSAlignment = 8; @@ -384,6 +386,12 @@ /// /// inserts a call to __msan_init to the module's constructor list. bool MemorySanitizer::doInitialization(Module &M) { + llvm::Triple TargetTriple(M.getTargetTriple()); + bool IsX86_64 = TargetTriple.getArch() == llvm::Triple::x86_64; + bool IsX86 = TargetTriple.getArch() == llvm::Triple::x86; + bool IsMIPS64 = TargetTriple.getArch() == llvm::Triple::mips64 || + TargetTriple.getArch() == llvm::Triple::mips64el; + DataLayoutPass *DLP = getAnalysisIfAvailable(); if (!DLP) report_fatal_error("data layout missing"); @@ -393,12 +401,23 @@ unsigned PtrSize = DL->getPointerSizeInBits(/* AddressSpace */0); switch (PtrSize) { case 64: - ShadowMask = kShadowMask64; - OriginOffset = kOriginOffset64; + if (IsX86_64) { + ShadowMask = kX86_64ShadowMask; + OriginOffset = kX86_64OriginOffset; + } else if (IsMIPS64) { + ShadowMask = kMIPS64ShadowMask; + OriginOffset = kMIPS64OriginOffset; + } else { + report_fatal_error("unsupported triple"); + } break; case 32: - ShadowMask = kShadowMask32; - OriginOffset = kOriginOffset32; + if (IsX86) { + ShadowMask = kX86ShadowMask; + OriginOffset = kX86OriginOffset; + } else { + report_fatal_error("unsupported triple"); + } break; default: report_fatal_error("unsupported pointer size");