2019-09-17 13:43:38 +00:00
|
|
|
diff -up gdl-287007567ba3998b4b70119025c3def86bdef649/src/dSFMT/dSFMT-common.h.std gdl-287007567ba3998b4b70119025c3def86bdef649/src/dSFMT/dSFMT-common.h
|
|
|
|
--- gdl-287007567ba3998b4b70119025c3def86bdef649/src/dSFMT/dSFMT-common.h.std 2019-09-16 03:51:53.000000000 -0600
|
|
|
|
+++ gdl-287007567ba3998b4b70119025c3def86bdef649/src/dSFMT/dSFMT-common.h 2019-09-16 21:15:07.887885236 -0600
|
2019-02-13 21:04:38 +00:00
|
|
|
@@ -44,25 +44,25 @@ static const union X128I_T sse2_param_ma
|
|
|
|
#if defined(HAVE_ALTIVEC)
|
|
|
|
inline static void do_recursion(w128_t *r, w128_t *a, w128_t * b,
|
|
|
|
w128_t *lung) {
|
|
|
|
- const vector unsigned char sl1 = ALTI_SL1;
|
|
|
|
- const vector unsigned char sl1_perm = ALTI_SL1_PERM;
|
|
|
|
- const vector unsigned int sl1_msk = ALTI_SL1_MSK;
|
|
|
|
- const vector unsigned char sr1 = ALTI_SR;
|
|
|
|
- const vector unsigned char sr1_perm = ALTI_SR_PERM;
|
|
|
|
- const vector unsigned int sr1_msk = ALTI_SR_MSK;
|
|
|
|
- const vector unsigned char perm = ALTI_PERM;
|
|
|
|
- const vector unsigned int msk1 = ALTI_MSK;
|
|
|
|
- vector unsigned int w, x, y, z;
|
|
|
|
+ const __vector unsigned char sl1 = ALTI_SL1;
|
|
|
|
+ const __vector unsigned char sl1_perm = ALTI_SL1_PERM;
|
|
|
|
+ const __vector unsigned int sl1_msk = ALTI_SL1_MSK;
|
|
|
|
+ const __vector unsigned char sr1 = ALTI_SR;
|
|
|
|
+ const __vector unsigned char sr1_perm = ALTI_SR_PERM;
|
|
|
|
+ const __vector unsigned int sr1_msk = ALTI_SR_MSK;
|
|
|
|
+ const __vector unsigned char perm = ALTI_PERM;
|
|
|
|
+ const __vector unsigned int msk1 = ALTI_MSK;
|
|
|
|
+ __vector unsigned int w, x, y, z;
|
|
|
|
|
|
|
|
z = a->s;
|
|
|
|
w = lung->s;
|
|
|
|
- x = vec_perm(w, (vector unsigned int)perm, perm);
|
|
|
|
- y = vec_perm(z, (vector unsigned int)sl1_perm, sl1_perm);
|
|
|
|
+ x = vec_perm(w, (__vector unsigned int)perm, perm);
|
|
|
|
+ y = vec_perm(z, (__vector unsigned int)sl1_perm, sl1_perm);
|
|
|
|
y = vec_sll(y, sl1);
|
|
|
|
y = vec_and(y, sl1_msk);
|
|
|
|
w = vec_xor(x, b->s);
|
|
|
|
w = vec_xor(w, y);
|
|
|
|
- x = vec_perm(w, (vector unsigned int)sr1_perm, sr1_perm);
|
|
|
|
+ x = vec_perm(w, (__vector unsigned int)sr1_perm, sr1_perm);
|
|
|
|
x = vec_srl(x, sr1);
|
|
|
|
x = vec_and(x, sr1_msk);
|
|
|
|
y = vec_and(w, msk1);
|
2019-09-17 13:43:38 +00:00
|
|
|
diff -up gdl-287007567ba3998b4b70119025c3def86bdef649/src/dSFMT/dSFMT.h.std gdl-287007567ba3998b4b70119025c3def86bdef649/src/dSFMT/dSFMT.h
|
|
|
|
--- gdl-287007567ba3998b4b70119025c3def86bdef649/src/dSFMT/dSFMT.h.std 2019-09-16 03:51:53.000000000 -0600
|
|
|
|
+++ gdl-287007567ba3998b4b70119025c3def86bdef649/src/dSFMT/dSFMT.h 2019-09-16 21:15:07.887885236 -0600
|
2019-02-13 21:04:38 +00:00
|
|
|
@@ -143,7 +143,7 @@ extern "C" {
|
|
|
|
|
|
|
|
/** 128-bit data structure */
|
|
|
|
union W128_T {
|
|
|
|
- vector unsigned int s;
|
|
|
|
+ __vector unsigned int s;
|
|
|
|
uint64_t u[2];
|
|
|
|
uint32_t u32[4];
|
|
|
|
double d[2];
|