blob: 9041027adc8f7fb1d77e86b95b4ddc198c5096f3 [file] [log] [blame]
// Copyright 2016 The Emscripten Authors. All rights reserved.
// Emscripten is available under two separate licenses, the MIT license and the
// University of Illinois/NCSA Open Source License. Both these licenses can be
// found in the LICENSE file.
// This file uses SSSE3 by calling different functions with different interesting inputs and prints the results.
// Use a diff tool to compare the results between platforms.
#include <tmmintrin.h>
#define ENABLE_SSE2
#include "test_sse_full.h"
float *interesting_floats = get_interesting_floats();
int numInterestingFloats = sizeof(interesting_floats_)/sizeof(interesting_floats_[0]);
uint32_t *interesting_ints = get_interesting_ints();
int numInterestingInts = sizeof(interesting_ints_)/sizeof(interesting_ints_[0]);
double *interesting_doubles = get_interesting_doubles();
int numInterestingDoubles = sizeof(interesting_doubles_)/sizeof(interesting_doubles_[0]);
int main()
{
assert(numInterestingFloats % 4 == 0);
assert(numInterestingInts % 4 == 0);
assert(numInterestingDoubles % 4 == 0);
Ret_M128i(__m128i, _mm_abs_epi8);
Ret_M128i(__m128i, _mm_abs_epi16);
Ret_M128i(__m128i, _mm_abs_epi32);
Ret_M128i_M128i_Tint(__m128i, _mm_alignr_epi8);
M128i_M128i_M128i(_mm_hadd_epi16);
M128i_M128i_M128i(_mm_hadd_epi32);
M128i_M128i_M128i(_mm_hadds_epi16);
M128i_M128i_M128i(_mm_hsub_epi16);
M128i_M128i_M128i(_mm_hsub_epi32);
M128i_M128i_M128i(_mm_hsubs_epi16);
M128i_M128i_M128i(_mm_maddubs_epi16);
M128i_M128i_M128i(_mm_mulhrs_epi16);
M128i_M128i_M128i(_mm_shuffle_epi8);
M128i_M128i_M128i(_mm_sign_epi16);
M128i_M128i_M128i(_mm_sign_epi32);
M128i_M128i_M128i(_mm_sign_epi8);
}