diff options
| author | Evgeniy Stepanov <eugeni.stepanov@gmail.com> | 2014-06-09 08:58:41 +0000 |
|---|---|---|
| committer | Evgeniy Stepanov <eugeni.stepanov@gmail.com> | 2014-06-09 08:58:41 +0000 |
| commit | 66c6a18d39698957f6f3433337654686201213c7 (patch) | |
| tree | 3094e5b5c5a6488d412bd9afba255fb2d77dfc10 | |
| parent | aaaf74f9fb57f37e9cfb33518dd6080ada19ee4c (diff) | |
| download | bcm5719-llvm-66c6a18d39698957f6f3433337654686201213c7.tar.gz bcm5719-llvm-66c6a18d39698957f6f3433337654686201213c7.zip | |
[msan] Add a test for mmx.packuswb.
llvm-svn: 210458
| -rw-r--r-- | compiler-rt/lib/msan/tests/msan_test.cc | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/compiler-rt/lib/msan/tests/msan_test.cc b/compiler-rt/lib/msan/tests/msan_test.cc index d9de941a795..34168786429 100644 --- a/compiler-rt/lib/msan/tests/msan_test.cc +++ b/compiler-rt/lib/msan/tests/msan_test.cc @@ -3641,6 +3641,28 @@ TEST(VectorPackTest, sse2_packssdw_128) { EXPECT_EQ(c[7], S2_max); } +TEST(VectorPackTest, mmx_packuswb) { + const unsigned U1_max = (1 << 8) - 1; + V4x16 a = {Poisoned<U2>(0, 0xFF00), Poisoned<U2>(0, 0xF000U), U1_max + 100, + 4}; + V4x16 b = {Poisoned<U2>(0, 0xFF), U1_max - 1, Poisoned<U2>(0, 0xF), U1_max}; + V8x8 c = _mm_packs_pu16(a, b); + + EXPECT_POISONED(c[0]); + EXPECT_POISONED(c[1]); + EXPECT_NOT_POISONED(c[2]); + EXPECT_NOT_POISONED(c[3]); + EXPECT_POISONED(c[4]); + EXPECT_NOT_POISONED(c[5]); + EXPECT_POISONED(c[6]); + EXPECT_NOT_POISONED(c[7]); + + EXPECT_EQ(c[2], U1_max); + EXPECT_EQ(c[3], 4); + EXPECT_EQ(c[5], U1_max - 1); + EXPECT_EQ(c[7], U1_max); +} + TEST(MemorySanitizerDr, StoreInDSOTest) { if (!__msan_has_dynamic_component()) return; char* s = new char[10]; |

