21 #include <xmmintrin.h>
27 __m128 current_max, current_min, work;
30 current_min = _mm_set1_ps(*min);
31 current_max = _mm_set1_ps(*max);
34 while ( ((
intptr_t)buf) % 16 != 0 && nframes > 0) {
37 work = _mm_set1_ps(*buf);
39 current_min = _mm_min_ps(current_min, work);
40 current_max = _mm_max_ps(current_max, work);
47 while (nframes >= 16) {
49 _mm_prefetch(((
char*)buf+64), 0);
50 #else // the line below but waiting to be tested !!
51 __builtin_prefetch(buf+64,0,0);
53 work = _mm_load_ps(buf);
54 current_min = _mm_min_ps(current_min, work);
55 current_max = _mm_max_ps(current_max, work);
57 work = _mm_load_ps(buf);
58 current_min = _mm_min_ps(current_min, work);
59 current_max = _mm_max_ps(current_max, work);
61 work = _mm_load_ps(buf);
62 current_min = _mm_min_ps(current_min, work);
63 current_max = _mm_max_ps(current_max, work);
65 work = _mm_load_ps(buf);
66 current_min = _mm_min_ps(current_min, work);
67 current_max = _mm_max_ps(current_max, work);
73 while (nframes >= 4) {
75 work = _mm_load_ps(buf);
77 current_min = _mm_min_ps(current_min, work);
78 current_max = _mm_max_ps(current_max, work);
85 while ( nframes > 0) {
88 work = _mm_set1_ps(*buf);
90 current_min = _mm_min_ps(current_min, work);
91 current_max = _mm_max_ps(current_max, work);
100 work = _mm_shuffle_ps(work, work, _MM_SHUFFLE(2, 3, 0, 1));
101 work = _mm_min_ps (work, current_min);
103 work = _mm_shuffle_ps(work, work, _MM_SHUFFLE(1, 0, 3, 2));
104 work = _mm_min_ps (work, current_min);
106 _mm_store_ss(min, work);
109 work = _mm_shuffle_ps(work, work, _MM_SHUFFLE(2, 3, 0, 1));
110 work = _mm_max_ps (work, current_max);
112 work = _mm_shuffle_ps(work, work, _MM_SHUFFLE(1, 0, 3, 2));
113 work = _mm_max_ps (work, current_max);
115 _mm_store_ss(max, work);
void x86_sse_find_peaks(const ARDOUR::Sample *buf, ARDOUR::pframes_t nframes, float *min, float *max)