1 /*
2  * This file derives from SFMT 1.3.3
3  * (http://www.math.sci.hiroshima-u.ac.jp/~m-mat/MT/SFMT/index.html), which was
4  * released under the terms of the following license:
5  *
6  *   Copyright (c) 2006,2007 Mutsuo Saito, Makoto Matsumoto and Hiroshima
7  *   University. All rights reserved.
8  *
9  *   Redistribution and use in source and binary forms, with or without
10  *   modification, are permitted provided that the following conditions are
11  *   met:
12  *
13  *       * Redistributions of source code must retain the above copyright
14  *         notice, this list of conditions and the following disclaimer.
15  *       * Redistributions in binary form must reproduce the above
16  *         copyright notice, this list of conditions and the following
17  *         disclaimer in the documentation and/or other materials provided
18  *         with the distribution.
19  *       * Neither the name of the Hiroshima University nor the names of
20  *         its contributors may be used to endorse or promote products
21  *         derived from this software without specific prior written
22  *         permission.
23  *
24  *   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
25  *   "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
26  *   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
27  *   A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
28  *   OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
29  *   SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
30  *   LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
31  *   DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
32  *   THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
33  *   (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
34  *   OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
35  */
36 #ifndef SFMT_PARAMS1279_H
37 #define SFMT_PARAMS1279_H
38 
39 #define POS1	7
40 #define SL1	14
41 #define SL2	3
42 #define SR1	5
43 #define SR2	1
44 #define MSK1	0xf7fefffdU
45 #define MSK2	0x7fefcfffU
46 #define MSK3	0xaff3ef3fU
47 #define MSK4	0xb5ffff7fU
48 #define PARITY1	0x00000001U
49 #define PARITY2	0x00000000U
50 #define PARITY3	0x00000000U
51 #define PARITY4	0x20000000U
52 
53 
54 /* PARAMETERS FOR ALTIVEC */
55 #if defined(__APPLE__)	/* For OSX */
56     #define ALTI_SL1	(vector unsigned int)(SL1, SL1, SL1, SL1)
57     #define ALTI_SR1	(vector unsigned int)(SR1, SR1, SR1, SR1)
58     #define ALTI_MSK	(vector unsigned int)(MSK1, MSK2, MSK3, MSK4)
59     #define ALTI_MSK64 \
60 	(vector unsigned int)(MSK2, MSK1, MSK4, MSK3)
61     #define ALTI_SL2_PERM \
62 	(vector unsigned char)(3,21,21,21,7,0,1,2,11,4,5,6,15,8,9,10)
63     #define ALTI_SL2_PERM64 \
64 	(vector unsigned char)(3,4,5,6,7,29,29,29,11,12,13,14,15,0,1,2)
65     #define ALTI_SR2_PERM \
66 	(vector unsigned char)(7,0,1,2,11,4,5,6,15,8,9,10,17,12,13,14)
67     #define ALTI_SR2_PERM64 \
68 	(vector unsigned char)(15,0,1,2,3,4,5,6,17,8,9,10,11,12,13,14)
69 #else	/* For OTHER OSs(Linux?) */
70     #define ALTI_SL1	{SL1, SL1, SL1, SL1}
71     #define ALTI_SR1	{SR1, SR1, SR1, SR1}
72     #define ALTI_MSK	{MSK1, MSK2, MSK3, MSK4}
73     #define ALTI_MSK64	{MSK2, MSK1, MSK4, MSK3}
74     #define ALTI_SL2_PERM	{3,21,21,21,7,0,1,2,11,4,5,6,15,8,9,10}
75     #define ALTI_SL2_PERM64	{3,4,5,6,7,29,29,29,11,12,13,14,15,0,1,2}
76     #define ALTI_SR2_PERM	{7,0,1,2,11,4,5,6,15,8,9,10,17,12,13,14}
77     #define ALTI_SR2_PERM64	{15,0,1,2,3,4,5,6,17,8,9,10,11,12,13,14}
78 #endif	/* For OSX */
79 #define IDSTR	"SFMT-1279:7-14-3-5-1:f7fefffd-7fefcfff-aff3ef3f-b5ffff7f"
80 
81 #endif /* SFMT_PARAMS1279_H */
82