blob: c0e7db2d65c3743bd60f2e25eaf98c4bdef986d7 [file] [log] [blame] [edit]
// This file uses SSE3 by calling different functions with different interesting inputs and prints the results.
// Use a diff tool to compare the results between platforms.
#include <pmmintrin.h>
#define ENABLE_SSE2
#include "test_sse_full.h"
#ifndef _DEBUG
// The following tests break when optimizer is applied, so disable them for now. Baby steps.
// See https://github.com/kripken/emscripten/issues/3789
#define BREAKS_UNDER_OPTIMIZATION
#endif
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_M128d_M128d(__m128d, _mm_addsub_pd);
Ret_M128_M128(__m128, _mm_addsub_ps);
Ret_M128d_M128d(__m128d, _mm_hadd_pd);
Ret_M128_M128(__m128, _mm_hadd_ps);
Ret_M128d_M128d(__m128d, _mm_hsub_pd);
Ret_M128_M128(__m128, _mm_hsub_ps);
#ifndef BREAKS_UNDER_OPTIMIZATION
Ret_IntPtr(__m128i, _mm_lddqu_si128, __m128i*, 4, 1);
#endif
Ret_DoublePtr(__m128d, _mm_loaddup_pd, 1, 1);
Ret_M128d(__m128d, _mm_movedup_pd);
Ret_M128(__m128, _mm_movehdup_ps);
Ret_M128(__m128, _mm_moveldup_ps);
}