teach MSAN about maskload

There is a very telling FIXME in the MSAN source code:
    // FIXME: detect and handle SSE maskstore/maskload

For now, just tell MSAN (correctly) that it's initialized.

CQ_INCLUDE_TRYBOTS=skia.primary:Test-Ubuntu-Clang-GCE-CPU-AVX2-x86_64-Debug-MSAN,Test-Ubuntu-GCC-GCE-CPU-AVX2-x86_64-Release-SKNX_NO_SIMD


Change-Id: I6aec67b99e4d930cb72e438458b33ed116535009
Reviewed-on: https://skia-review.googlesource.com/5311
Commit-Queue: Mike Klein <mtklein@chromium.org>
Reviewed-by: Brian Osman <brianosman@google.com>
diff --git a/src/opts/SkRasterPipeline_opts.h b/src/opts/SkRasterPipeline_opts.h
index d38e0ca..88a872c 100644
--- a/src/opts/SkRasterPipeline_opts.h
+++ b/src/opts/SkRasterPipeline_opts.h
@@ -14,6 +14,7 @@
 #include "SkColorSpaceXformPriv.h"
 #include "SkHalf.h"
 #include "SkImageShaderContext.h"
+#include "SkMSAN.h"
 #include "SkPM4f.h"
 #include "SkPM4fPriv.h"
 #include "SkRasterPipeline.h"
@@ -193,13 +194,22 @@
         return _mm256_mask_i32gather_epi32(SkNi(0).fVec,
                                            (const int*)src, offset.fVec, mask(tail), 4);
     }
+
+    static const char* bug = "I don't think MSAN understands maskstore.";
+
     SI void store(size_t tail, const SkNi& v,  int32_t* dst) {
-        tail ? _mm256_maskstore_epi32((int*)dst, mask(tail), v.fVec)
-             : v.store(dst);
+        if (tail) {
+            _mm256_maskstore_epi32((int*)dst, mask(tail), v.fVec);
+            return sk_msan_mark_initialized(dst, dst+tail, bug);
+        }
+        v.store(dst);
     }
     SI void store(size_t tail, const SkNu& v, uint32_t* dst) {
-        tail ? _mm256_maskstore_epi32((int*)dst, mask(tail), v.fVec)
-             : v.store(dst);
+        if (tail) {
+            _mm256_maskstore_epi32((int*)dst, mask(tail), v.fVec);
+            return sk_msan_mark_initialized(dst, dst+tail, bug);
+        }
+        v.store(dst);
     }
 #endif