1 /* vim: set ts=8 sts=4 sw=4 tw=80 noet: */
2 /*======================================================================
3 Copyright (C) 2004,2005,2009,2011 Walter Doekes <walter+tthsum@wjd.nu>
4 This file is part of tthsum.
5 
6 tthsum is free software: you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation, either version 3 of the License, or
9 (at your option) any later version.
10 
11 tthsum is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 GNU General Public License for more details.
15 
16 You should have received a copy of the GNU General Public License
17 along with tthsum.  If not, see <http://www.gnu.org/licenses/>.
18 ========================================================================
19 
20 The greater part of this source comes from the creators of the Tiger
21 Hash algorithm, Ross Anderson and Eli Biham.
22 
23 ======================================================================*/
24 #include "tiger.h"
25 
26 #include "endian.h"
27 #include <assert.h>
28 #include <string.h>
29 
30 
31 /* Tiger S boxes */
32 static uint64_t tiger_sboxes[1024] = {
33     _ULL(0x02AAB17CF7E90C5E) /*    0 */, _ULL(0xAC424B03E243A8EC) /*    1 */,
34     _ULL(0x72CD5BE30DD5FCD3) /*    2 */, _ULL(0x6D019B93F6F97F3A) /*    3 */,
35     _ULL(0xCD9978FFD21F9193) /*    4 */, _ULL(0x7573A1C9708029E2) /*    5 */,
36     _ULL(0xB164326B922A83C3) /*    6 */, _ULL(0x46883EEE04915870) /*    7 */,
37     _ULL(0xEAACE3057103ECE6) /*    8 */, _ULL(0xC54169B808A3535C) /*    9 */,
38     _ULL(0x4CE754918DDEC47C) /*   10 */, _ULL(0x0AA2F4DFDC0DF40C) /*   11 */,
39     _ULL(0x10B76F18A74DBEFA) /*   12 */, _ULL(0xC6CCB6235AD1AB6A) /*   13 */,
40     _ULL(0x13726121572FE2FF) /*   14 */, _ULL(0x1A488C6F199D921E) /*   15 */,
41     _ULL(0x4BC9F9F4DA0007CA) /*   16 */, _ULL(0x26F5E6F6E85241C7) /*   17 */,
42     _ULL(0x859079DBEA5947B6) /*   18 */, _ULL(0x4F1885C5C99E8C92) /*   19 */,
43     _ULL(0xD78E761EA96F864B) /*   20 */, _ULL(0x8E36428C52B5C17D) /*   21 */,
44     _ULL(0x69CF6827373063C1) /*   22 */, _ULL(0xB607C93D9BB4C56E) /*   23 */,
45     _ULL(0x7D820E760E76B5EA) /*   24 */, _ULL(0x645C9CC6F07FDC42) /*   25 */,
46     _ULL(0xBF38A078243342E0) /*   26 */, _ULL(0x5F6B343C9D2E7D04) /*   27 */,
47     _ULL(0xF2C28AEB600B0EC6) /*   28 */, _ULL(0x6C0ED85F7254BCAC) /*   29 */,
48     _ULL(0x71592281A4DB4FE5) /*   30 */, _ULL(0x1967FA69CE0FED9F) /*   31 */,
49     _ULL(0xFD5293F8B96545DB) /*   32 */, _ULL(0xC879E9D7F2A7600B) /*   33 */,
50     _ULL(0x860248920193194E) /*   34 */, _ULL(0xA4F9533B2D9CC0B3) /*   35 */,
51     _ULL(0x9053836C15957613) /*   36 */, _ULL(0xDB6DCF8AFC357BF1) /*   37 */,
52     _ULL(0x18BEEA7A7A370F57) /*   38 */, _ULL(0x037117CA50B99066) /*   39 */,
53     _ULL(0x6AB30A9774424A35) /*   40 */, _ULL(0xF4E92F02E325249B) /*   41 */,
54     _ULL(0x7739DB07061CCAE1) /*   42 */, _ULL(0xD8F3B49CECA42A05) /*   43 */,
55     _ULL(0xBD56BE3F51382F73) /*   44 */, _ULL(0x45FAED5843B0BB28) /*   45 */,
56     _ULL(0x1C813D5C11BF1F83) /*   46 */, _ULL(0x8AF0E4B6D75FA169) /*   47 */,
57     _ULL(0x33EE18A487AD9999) /*   48 */, _ULL(0x3C26E8EAB1C94410) /*   49 */,
58     _ULL(0xB510102BC0A822F9) /*   50 */, _ULL(0x141EEF310CE6123B) /*   51 */,
59     _ULL(0xFC65B90059DDB154) /*   52 */, _ULL(0xE0158640C5E0E607) /*   53 */,
60     _ULL(0x884E079826C3A3CF) /*   54 */, _ULL(0x930D0D9523C535FD) /*   55 */,
61     _ULL(0x35638D754E9A2B00) /*   56 */, _ULL(0x4085FCCF40469DD5) /*   57 */,
62     _ULL(0xC4B17AD28BE23A4C) /*   58 */, _ULL(0xCAB2F0FC6A3E6A2E) /*   59 */,
63     _ULL(0x2860971A6B943FCD) /*   60 */, _ULL(0x3DDE6EE212E30446) /*   61 */,
64     _ULL(0x6222F32AE01765AE) /*   62 */, _ULL(0x5D550BB5478308FE) /*   63 */,
65     _ULL(0xA9EFA98DA0EDA22A) /*   64 */, _ULL(0xC351A71686C40DA7) /*   65 */,
66     _ULL(0x1105586D9C867C84) /*   66 */, _ULL(0xDCFFEE85FDA22853) /*   67 */,
67     _ULL(0xCCFBD0262C5EEF76) /*   68 */, _ULL(0xBAF294CB8990D201) /*   69 */,
68     _ULL(0xE69464F52AFAD975) /*   70 */, _ULL(0x94B013AFDF133E14) /*   71 */,
69     _ULL(0x06A7D1A32823C958) /*   72 */, _ULL(0x6F95FE5130F61119) /*   73 */,
70     _ULL(0xD92AB34E462C06C0) /*   74 */, _ULL(0xED7BDE33887C71D2) /*   75 */,
71     _ULL(0x79746D6E6518393E) /*   76 */, _ULL(0x5BA419385D713329) /*   77 */,
72     _ULL(0x7C1BA6B948A97564) /*   78 */, _ULL(0x31987C197BFDAC67) /*   79 */,
73     _ULL(0xDE6C23C44B053D02) /*   80 */, _ULL(0x581C49FED002D64D) /*   81 */,
74     _ULL(0xDD474D6338261571) /*   82 */, _ULL(0xAA4546C3E473D062) /*   83 */,
75     _ULL(0x928FCE349455F860) /*   84 */, _ULL(0x48161BBACAAB94D9) /*   85 */,
76     _ULL(0x63912430770E6F68) /*   86 */, _ULL(0x6EC8A5E602C6641C) /*   87 */,
77     _ULL(0x87282515337DDD2B) /*   88 */, _ULL(0x2CDA6B42034B701B) /*   89 */,
78     _ULL(0xB03D37C181CB096D) /*   90 */, _ULL(0xE108438266C71C6F) /*   91 */,
79     _ULL(0x2B3180C7EB51B255) /*   92 */, _ULL(0xDF92B82F96C08BBC) /*   93 */,
80     _ULL(0x5C68C8C0A632F3BA) /*   94 */, _ULL(0x5504CC861C3D0556) /*   95 */,
81     _ULL(0xABBFA4E55FB26B8F) /*   96 */, _ULL(0x41848B0AB3BACEB4) /*   97 */,
82     _ULL(0xB334A273AA445D32) /*   98 */, _ULL(0xBCA696F0A85AD881) /*   99 */,
83     _ULL(0x24F6EC65B528D56C) /*  100 */, _ULL(0x0CE1512E90F4524A) /*  101 */,
84     _ULL(0x4E9DD79D5506D35A) /*  102 */, _ULL(0x258905FAC6CE9779) /*  103 */,
85     _ULL(0x2019295B3E109B33) /*  104 */, _ULL(0xF8A9478B73A054CC) /*  105 */,
86     _ULL(0x2924F2F934417EB0) /*  106 */, _ULL(0x3993357D536D1BC4) /*  107 */,
87     _ULL(0x38A81AC21DB6FF8B) /*  108 */, _ULL(0x47C4FBF17D6016BF) /*  109 */,
88     _ULL(0x1E0FAADD7667E3F5) /*  110 */, _ULL(0x7ABCFF62938BEB96) /*  111 */,
89     _ULL(0xA78DAD948FC179C9) /*  112 */, _ULL(0x8F1F98B72911E50D) /*  113 */,
90     _ULL(0x61E48EAE27121A91) /*  114 */, _ULL(0x4D62F7AD31859808) /*  115 */,
91     _ULL(0xECEBA345EF5CEAEB) /*  116 */, _ULL(0xF5CEB25EBC9684CE) /*  117 */,
92     _ULL(0xF633E20CB7F76221) /*  118 */, _ULL(0xA32CDF06AB8293E4) /*  119 */,
93     _ULL(0x985A202CA5EE2CA4) /*  120 */, _ULL(0xCF0B8447CC8A8FB1) /*  121 */,
94     _ULL(0x9F765244979859A3) /*  122 */, _ULL(0xA8D516B1A1240017) /*  123 */,
95     _ULL(0x0BD7BA3EBB5DC726) /*  124 */, _ULL(0xE54BCA55B86ADB39) /*  125 */,
96     _ULL(0x1D7A3AFD6C478063) /*  126 */, _ULL(0x519EC608E7669EDD) /*  127 */,
97     _ULL(0x0E5715A2D149AA23) /*  128 */, _ULL(0x177D4571848FF194) /*  129 */,
98     _ULL(0xEEB55F3241014C22) /*  130 */, _ULL(0x0F5E5CA13A6E2EC2) /*  131 */,
99     _ULL(0x8029927B75F5C361) /*  132 */, _ULL(0xAD139FABC3D6E436) /*  133 */,
100     _ULL(0x0D5DF1A94CCF402F) /*  134 */, _ULL(0x3E8BD948BEA5DFC8) /*  135 */,
101     _ULL(0xA5A0D357BD3FF77E) /*  136 */, _ULL(0xA2D12E251F74F645) /*  137 */,
102     _ULL(0x66FD9E525E81A082) /*  138 */, _ULL(0x2E0C90CE7F687A49) /*  139 */,
103     _ULL(0xC2E8BCBEBA973BC5) /*  140 */, _ULL(0x000001BCE509745F) /*  141 */,
104     _ULL(0x423777BBE6DAB3D6) /*  142 */, _ULL(0xD1661C7EAEF06EB5) /*  143 */,
105     _ULL(0xA1781F354DAACFD8) /*  144 */, _ULL(0x2D11284A2B16AFFC) /*  145 */,
106     _ULL(0xF1FC4F67FA891D1F) /*  146 */, _ULL(0x73ECC25DCB920ADA) /*  147 */,
107     _ULL(0xAE610C22C2A12651) /*  148 */, _ULL(0x96E0A810D356B78A) /*  149 */,
108     _ULL(0x5A9A381F2FE7870F) /*  150 */, _ULL(0xD5AD62EDE94E5530) /*  151 */,
109     _ULL(0xD225E5E8368D1427) /*  152 */, _ULL(0x65977B70C7AF4631) /*  153 */,
110     _ULL(0x99F889B2DE39D74F) /*  154 */, _ULL(0x233F30BF54E1D143) /*  155 */,
111     _ULL(0x9A9675D3D9A63C97) /*  156 */, _ULL(0x5470554FF334F9A8) /*  157 */,
112     _ULL(0x166ACB744A4F5688) /*  158 */, _ULL(0x70C74CAAB2E4AEAD) /*  159 */,
113     _ULL(0xF0D091646F294D12) /*  160 */, _ULL(0x57B82A89684031D1) /*  161 */,
114     _ULL(0xEFD95A5A61BE0B6B) /*  162 */, _ULL(0x2FBD12E969F2F29A) /*  163 */,
115     _ULL(0x9BD37013FEFF9FE8) /*  164 */, _ULL(0x3F9B0404D6085A06) /*  165 */,
116     _ULL(0x4940C1F3166CFE15) /*  166 */, _ULL(0x09542C4DCDF3DEFB) /*  167 */,
117     _ULL(0xB4C5218385CD5CE3) /*  168 */, _ULL(0xC935B7DC4462A641) /*  169 */,
118     _ULL(0x3417F8A68ED3B63F) /*  170 */, _ULL(0xB80959295B215B40) /*  171 */,
119     _ULL(0xF99CDAEF3B8C8572) /*  172 */, _ULL(0x018C0614F8FCB95D) /*  173 */,
120     _ULL(0x1B14ACCD1A3ACDF3) /*  174 */, _ULL(0x84D471F200BB732D) /*  175 */,
121     _ULL(0xC1A3110E95E8DA16) /*  176 */, _ULL(0x430A7220BF1A82B8) /*  177 */,
122     _ULL(0xB77E090D39DF210E) /*  178 */, _ULL(0x5EF4BD9F3CD05E9D) /*  179 */,
123     _ULL(0x9D4FF6DA7E57A444) /*  180 */, _ULL(0xDA1D60E183D4A5F8) /*  181 */,
124     _ULL(0xB287C38417998E47) /*  182 */, _ULL(0xFE3EDC121BB31886) /*  183 */,
125     _ULL(0xC7FE3CCC980CCBEF) /*  184 */, _ULL(0xE46FB590189BFD03) /*  185 */,
126     _ULL(0x3732FD469A4C57DC) /*  186 */, _ULL(0x7EF700A07CF1AD65) /*  187 */,
127     _ULL(0x59C64468A31D8859) /*  188 */, _ULL(0x762FB0B4D45B61F6) /*  189 */,
128     _ULL(0x155BAED099047718) /*  190 */, _ULL(0x68755E4C3D50BAA6) /*  191 */,
129     _ULL(0xE9214E7F22D8B4DF) /*  192 */, _ULL(0x2ADDBF532EAC95F4) /*  193 */,
130     _ULL(0x32AE3909B4BD0109) /*  194 */, _ULL(0x834DF537B08E3450) /*  195 */,
131     _ULL(0xFA209DA84220728D) /*  196 */, _ULL(0x9E691D9B9EFE23F7) /*  197 */,
132     _ULL(0x0446D288C4AE8D7F) /*  198 */, _ULL(0x7B4CC524E169785B) /*  199 */,
133     _ULL(0x21D87F0135CA1385) /*  200 */, _ULL(0xCEBB400F137B8AA5) /*  201 */,
134     _ULL(0x272E2B66580796BE) /*  202 */, _ULL(0x3612264125C2B0DE) /*  203 */,
135     _ULL(0x057702BDAD1EFBB2) /*  204 */, _ULL(0xD4BABB8EACF84BE9) /*  205 */,
136     _ULL(0x91583139641BC67B) /*  206 */, _ULL(0x8BDC2DE08036E024) /*  207 */,
137     _ULL(0x603C8156F49F68ED) /*  208 */, _ULL(0xF7D236F7DBEF5111) /*  209 */,
138     _ULL(0x9727C4598AD21E80) /*  210 */, _ULL(0xA08A0896670A5FD7) /*  211 */,
139     _ULL(0xCB4A8F4309EBA9CB) /*  212 */, _ULL(0x81AF564B0F7036A1) /*  213 */,
140     _ULL(0xC0B99AA778199ABD) /*  214 */, _ULL(0x959F1EC83FC8E952) /*  215 */,
141     _ULL(0x8C505077794A81B9) /*  216 */, _ULL(0x3ACAAF8F056338F0) /*  217 */,
142     _ULL(0x07B43F50627A6778) /*  218 */, _ULL(0x4A44AB49F5ECCC77) /*  219 */,
143     _ULL(0x3BC3D6E4B679EE98) /*  220 */, _ULL(0x9CC0D4D1CF14108C) /*  221 */,
144     _ULL(0x4406C00B206BC8A0) /*  222 */, _ULL(0x82A18854C8D72D89) /*  223 */,
145     _ULL(0x67E366B35C3C432C) /*  224 */, _ULL(0xB923DD61102B37F2) /*  225 */,
146     _ULL(0x56AB2779D884271D) /*  226 */, _ULL(0xBE83E1B0FF1525AF) /*  227 */,
147     _ULL(0xFB7C65D4217E49A9) /*  228 */, _ULL(0x6BDBE0E76D48E7D4) /*  229 */,
148     _ULL(0x08DF828745D9179E) /*  230 */, _ULL(0x22EA6A9ADD53BD34) /*  231 */,
149     _ULL(0xE36E141C5622200A) /*  232 */, _ULL(0x7F805D1B8CB750EE) /*  233 */,
150     _ULL(0xAFE5C7A59F58E837) /*  234 */, _ULL(0xE27F996A4FB1C23C) /*  235 */,
151     _ULL(0xD3867DFB0775F0D0) /*  236 */, _ULL(0xD0E673DE6E88891A) /*  237 */,
152     _ULL(0x123AEB9EAFB86C25) /*  238 */, _ULL(0x30F1D5D5C145B895) /*  239 */,
153     _ULL(0xBB434A2DEE7269E7) /*  240 */, _ULL(0x78CB67ECF931FA38) /*  241 */,
154     _ULL(0xF33B0372323BBF9C) /*  242 */, _ULL(0x52D66336FB279C74) /*  243 */,
155     _ULL(0x505F33AC0AFB4EAA) /*  244 */, _ULL(0xE8A5CD99A2CCE187) /*  245 */,
156     _ULL(0x534974801E2D30BB) /*  246 */, _ULL(0x8D2D5711D5876D90) /*  247 */,
157     _ULL(0x1F1A412891BC038E) /*  248 */, _ULL(0xD6E2E71D82E56648) /*  249 */,
158     _ULL(0x74036C3A497732B7) /*  250 */, _ULL(0x89B67ED96361F5AB) /*  251 */,
159     _ULL(0xFFED95D8F1EA02A2) /*  252 */, _ULL(0xE72B3BD61464D43D) /*  253 */,
160     _ULL(0xA6300F170BDC4820) /*  254 */, _ULL(0xEBC18760ED78A77A) /*  255 */,
161     _ULL(0xE6A6BE5A05A12138) /*  256 */, _ULL(0xB5A122A5B4F87C98) /*  257 */,
162     _ULL(0x563C6089140B6990) /*  258 */, _ULL(0x4C46CB2E391F5DD5) /*  259 */,
163     _ULL(0xD932ADDBC9B79434) /*  260 */, _ULL(0x08EA70E42015AFF5) /*  261 */,
164     _ULL(0xD765A6673E478CF1) /*  262 */, _ULL(0xC4FB757EAB278D99) /*  263 */,
165     _ULL(0xDF11C6862D6E0692) /*  264 */, _ULL(0xDDEB84F10D7F3B16) /*  265 */,
166     _ULL(0x6F2EF604A665EA04) /*  266 */, _ULL(0x4A8E0F0FF0E0DFB3) /*  267 */,
167     _ULL(0xA5EDEEF83DBCBA51) /*  268 */, _ULL(0xFC4F0A2A0EA4371E) /*  269 */,
168     _ULL(0xE83E1DA85CB38429) /*  270 */, _ULL(0xDC8FF882BA1B1CE2) /*  271 */,
169     _ULL(0xCD45505E8353E80D) /*  272 */, _ULL(0x18D19A00D4DB0717) /*  273 */,
170     _ULL(0x34A0CFEDA5F38101) /*  274 */, _ULL(0x0BE77E518887CAF2) /*  275 */,
171     _ULL(0x1E341438B3C45136) /*  276 */, _ULL(0xE05797F49089CCF9) /*  277 */,
172     _ULL(0xFFD23F9DF2591D14) /*  278 */, _ULL(0x543DDA228595C5CD) /*  279 */,
173     _ULL(0x661F81FD99052A33) /*  280 */, _ULL(0x8736E641DB0F7B76) /*  281 */,
174     _ULL(0x15227725418E5307) /*  282 */, _ULL(0xE25F7F46162EB2FA) /*  283 */,
175     _ULL(0x48A8B2126C13D9FE) /*  284 */, _ULL(0xAFDC541792E76EEA) /*  285 */,
176     _ULL(0x03D912BFC6D1898F) /*  286 */, _ULL(0x31B1AAFA1B83F51B) /*  287 */,
177     _ULL(0xF1AC2796E42AB7D9) /*  288 */, _ULL(0x40A3A7D7FCD2EBAC) /*  289 */,
178     _ULL(0x1056136D0AFBBCC5) /*  290 */, _ULL(0x7889E1DD9A6D0C85) /*  291 */,
179     _ULL(0xD33525782A7974AA) /*  292 */, _ULL(0xA7E25D09078AC09B) /*  293 */,
180     _ULL(0xBD4138B3EAC6EDD0) /*  294 */, _ULL(0x920ABFBE71EB9E70) /*  295 */,
181     _ULL(0xA2A5D0F54FC2625C) /*  296 */, _ULL(0xC054E36B0B1290A3) /*  297 */,
182     _ULL(0xF6DD59FF62FE932B) /*  298 */, _ULL(0x3537354511A8AC7D) /*  299 */,
183     _ULL(0xCA845E9172FADCD4) /*  300 */, _ULL(0x84F82B60329D20DC) /*  301 */,
184     _ULL(0x79C62CE1CD672F18) /*  302 */, _ULL(0x8B09A2ADD124642C) /*  303 */,
185     _ULL(0xD0C1E96A19D9E726) /*  304 */, _ULL(0x5A786A9B4BA9500C) /*  305 */,
186     _ULL(0x0E020336634C43F3) /*  306 */, _ULL(0xC17B474AEB66D822) /*  307 */,
187     _ULL(0x6A731AE3EC9BAAC2) /*  308 */, _ULL(0x8226667AE0840258) /*  309 */,
188     _ULL(0x67D4567691CAECA5) /*  310 */, _ULL(0x1D94155C4875ADB5) /*  311 */,
189     _ULL(0x6D00FD985B813FDF) /*  312 */, _ULL(0x51286EFCB774CD06) /*  313 */,
190     _ULL(0x5E8834471FA744AF) /*  314 */, _ULL(0xF72CA0AEE761AE2E) /*  315 */,
191     _ULL(0xBE40E4CDAEE8E09A) /*  316 */, _ULL(0xE9970BBB5118F665) /*  317 */,
192     _ULL(0x726E4BEB33DF1964) /*  318 */, _ULL(0x703B000729199762) /*  319 */,
193     _ULL(0x4631D816F5EF30A7) /*  320 */, _ULL(0xB880B5B51504A6BE) /*  321 */,
194     _ULL(0x641793C37ED84B6C) /*  322 */, _ULL(0x7B21ED77F6E97D96) /*  323 */,
195     _ULL(0x776306312EF96B73) /*  324 */, _ULL(0xAE528948E86FF3F4) /*  325 */,
196     _ULL(0x53DBD7F286A3F8F8) /*  326 */, _ULL(0x16CADCE74CFC1063) /*  327 */,
197     _ULL(0x005C19BDFA52C6DD) /*  328 */, _ULL(0x68868F5D64D46AD3) /*  329 */,
198     _ULL(0x3A9D512CCF1E186A) /*  330 */, _ULL(0x367E62C2385660AE) /*  331 */,
199     _ULL(0xE359E7EA77DCB1D7) /*  332 */, _ULL(0x526C0773749ABE6E) /*  333 */,
200     _ULL(0x735AE5F9D09F734B) /*  334 */, _ULL(0x493FC7CC8A558BA8) /*  335 */,
201     _ULL(0xB0B9C1533041AB45) /*  336 */, _ULL(0x321958BA470A59BD) /*  337 */,
202     _ULL(0x852DB00B5F46C393) /*  338 */, _ULL(0x91209B2BD336B0E5) /*  339 */,
203     _ULL(0x6E604F7D659EF19F) /*  340 */, _ULL(0xB99A8AE2782CCB24) /*  341 */,
204     _ULL(0xCCF52AB6C814C4C7) /*  342 */, _ULL(0x4727D9AFBE11727B) /*  343 */,
205     _ULL(0x7E950D0C0121B34D) /*  344 */, _ULL(0x756F435670AD471F) /*  345 */,
206     _ULL(0xF5ADD442615A6849) /*  346 */, _ULL(0x4E87E09980B9957A) /*  347 */,
207     _ULL(0x2ACFA1DF50AEE355) /*  348 */, _ULL(0xD898263AFD2FD556) /*  349 */,
208     _ULL(0xC8F4924DD80C8FD6) /*  350 */, _ULL(0xCF99CA3D754A173A) /*  351 */,
209     _ULL(0xFE477BACAF91BF3C) /*  352 */, _ULL(0xED5371F6D690C12D) /*  353 */,
210     _ULL(0x831A5C285E687094) /*  354 */, _ULL(0xC5D3C90A3708A0A4) /*  355 */,
211     _ULL(0x0F7F903717D06580) /*  356 */, _ULL(0x19F9BB13B8FDF27F) /*  357 */,
212     _ULL(0xB1BD6F1B4D502843) /*  358 */, _ULL(0x1C761BA38FFF4012) /*  359 */,
213     _ULL(0x0D1530C4E2E21F3B) /*  360 */, _ULL(0x8943CE69A7372C8A) /*  361 */,
214     _ULL(0xE5184E11FEB5CE66) /*  362 */, _ULL(0x618BDB80BD736621) /*  363 */,
215     _ULL(0x7D29BAD68B574D0B) /*  364 */, _ULL(0x81BB613E25E6FE5B) /*  365 */,
216     _ULL(0x071C9C10BC07913F) /*  366 */, _ULL(0xC7BEEB7909AC2D97) /*  367 */,
217     _ULL(0xC3E58D353BC5D757) /*  368 */, _ULL(0xEB017892F38F61E8) /*  369 */,
218     _ULL(0xD4EFFB9C9B1CC21A) /*  370 */, _ULL(0x99727D26F494F7AB) /*  371 */,
219     _ULL(0xA3E063A2956B3E03) /*  372 */, _ULL(0x9D4A8B9A4AA09C30) /*  373 */,
220     _ULL(0x3F6AB7D500090FB4) /*  374 */, _ULL(0x9CC0F2A057268AC0) /*  375 */,
221     _ULL(0x3DEE9D2DEDBF42D1) /*  376 */, _ULL(0x330F49C87960A972) /*  377 */,
222     _ULL(0xC6B2720287421B41) /*  378 */, _ULL(0x0AC59EC07C00369C) /*  379 */,
223     _ULL(0xEF4EAC49CB353425) /*  380 */, _ULL(0xF450244EEF0129D8) /*  381 */,
224     _ULL(0x8ACC46E5CAF4DEB6) /*  382 */, _ULL(0x2FFEAB63989263F7) /*  383 */,
225     _ULL(0x8F7CB9FE5D7A4578) /*  384 */, _ULL(0x5BD8F7644E634635) /*  385 */,
226     _ULL(0x427A7315BF2DC900) /*  386 */, _ULL(0x17D0C4AA2125261C) /*  387 */,
227     _ULL(0x3992486C93518E50) /*  388 */, _ULL(0xB4CBFEE0A2D7D4C3) /*  389 */,
228     _ULL(0x7C75D6202C5DDD8D) /*  390 */, _ULL(0xDBC295D8E35B6C61) /*  391 */,
229     _ULL(0x60B369D302032B19) /*  392 */, _ULL(0xCE42685FDCE44132) /*  393 */,
230     _ULL(0x06F3DDB9DDF65610) /*  394 */, _ULL(0x8EA4D21DB5E148F0) /*  395 */,
231     _ULL(0x20B0FCE62FCD496F) /*  396 */, _ULL(0x2C1B912358B0EE31) /*  397 */,
232     _ULL(0xB28317B818F5A308) /*  398 */, _ULL(0xA89C1E189CA6D2CF) /*  399 */,
233     _ULL(0x0C6B18576AAADBC8) /*  400 */, _ULL(0xB65DEAA91299FAE3) /*  401 */,
234     _ULL(0xFB2B794B7F1027E7) /*  402 */, _ULL(0x04E4317F443B5BEB) /*  403 */,
235     _ULL(0x4B852D325939D0A6) /*  404 */, _ULL(0xD5AE6BEEFB207FFC) /*  405 */,
236     _ULL(0x309682B281C7D374) /*  406 */, _ULL(0xBAE309A194C3B475) /*  407 */,
237     _ULL(0x8CC3F97B13B49F05) /*  408 */, _ULL(0x98A9422FF8293967) /*  409 */,
238     _ULL(0x244B16B01076FF7C) /*  410 */, _ULL(0xF8BF571C663D67EE) /*  411 */,
239     _ULL(0x1F0D6758EEE30DA1) /*  412 */, _ULL(0xC9B611D97ADEB9B7) /*  413 */,
240     _ULL(0xB7AFD5887B6C57A2) /*  414 */, _ULL(0x6290AE846B984FE1) /*  415 */,
241     _ULL(0x94DF4CDEACC1A5FD) /*  416 */, _ULL(0x058A5BD1C5483AFF) /*  417 */,
242     _ULL(0x63166CC142BA3C37) /*  418 */, _ULL(0x8DB8526EB2F76F40) /*  419 */,
243     _ULL(0xE10880036F0D6D4E) /*  420 */, _ULL(0x9E0523C9971D311D) /*  421 */,
244     _ULL(0x45EC2824CC7CD691) /*  422 */, _ULL(0x575B8359E62382C9) /*  423 */,
245     _ULL(0xFA9E400DC4889995) /*  424 */, _ULL(0xD1823ECB45721568) /*  425 */,
246     _ULL(0xDAFD983B8206082F) /*  426 */, _ULL(0xAA7D29082386A8CB) /*  427 */,
247     _ULL(0x269FCD4403B87588) /*  428 */, _ULL(0x1B91F5F728BDD1E0) /*  429 */,
248     _ULL(0xE4669F39040201F6) /*  430 */, _ULL(0x7A1D7C218CF04ADE) /*  431 */,
249     _ULL(0x65623C29D79CE5CE) /*  432 */, _ULL(0x2368449096C00BB1) /*  433 */,
250     _ULL(0xAB9BF1879DA503BA) /*  434 */, _ULL(0xBC23ECB1A458058E) /*  435 */,
251     _ULL(0x9A58DF01BB401ECC) /*  436 */, _ULL(0xA070E868A85F143D) /*  437 */,
252     _ULL(0x4FF188307DF2239E) /*  438 */, _ULL(0x14D565B41A641183) /*  439 */,
253     _ULL(0xEE13337452701602) /*  440 */, _ULL(0x950E3DCF3F285E09) /*  441 */,
254     _ULL(0x59930254B9C80953) /*  442 */, _ULL(0x3BF299408930DA6D) /*  443 */,
255     _ULL(0xA955943F53691387) /*  444 */, _ULL(0xA15EDECAA9CB8784) /*  445 */,
256     _ULL(0x29142127352BE9A0) /*  446 */, _ULL(0x76F0371FFF4E7AFB) /*  447 */,
257     _ULL(0x0239F450274F2228) /*  448 */, _ULL(0xBB073AF01D5E868B) /*  449 */,
258     _ULL(0xBFC80571C10E96C1) /*  450 */, _ULL(0xD267088568222E23) /*  451 */,
259     _ULL(0x9671A3D48E80B5B0) /*  452 */, _ULL(0x55B5D38AE193BB81) /*  453 */,
260     _ULL(0x693AE2D0A18B04B8) /*  454 */, _ULL(0x5C48B4ECADD5335F) /*  455 */,
261     _ULL(0xFD743B194916A1CA) /*  456 */, _ULL(0x2577018134BE98C4) /*  457 */,
262     _ULL(0xE77987E83C54A4AD) /*  458 */, _ULL(0x28E11014DA33E1B9) /*  459 */,
263     _ULL(0x270CC59E226AA213) /*  460 */, _ULL(0x71495F756D1A5F60) /*  461 */,
264     _ULL(0x9BE853FB60AFEF77) /*  462 */, _ULL(0xADC786A7F7443DBF) /*  463 */,
265     _ULL(0x0904456173B29A82) /*  464 */, _ULL(0x58BC7A66C232BD5E) /*  465 */,
266     _ULL(0xF306558C673AC8B2) /*  466 */, _ULL(0x41F639C6B6C9772A) /*  467 */,
267     _ULL(0x216DEFE99FDA35DA) /*  468 */, _ULL(0x11640CC71C7BE615) /*  469 */,
268     _ULL(0x93C43694565C5527) /*  470 */, _ULL(0xEA038E6246777839) /*  471 */,
269     _ULL(0xF9ABF3CE5A3E2469) /*  472 */, _ULL(0x741E768D0FD312D2) /*  473 */,
270     _ULL(0x0144B883CED652C6) /*  474 */, _ULL(0xC20B5A5BA33F8552) /*  475 */,
271     _ULL(0x1AE69633C3435A9D) /*  476 */, _ULL(0x97A28CA4088CFDEC) /*  477 */,
272     _ULL(0x8824A43C1E96F420) /*  478 */, _ULL(0x37612FA66EEEA746) /*  479 */,
273     _ULL(0x6B4CB165F9CF0E5A) /*  480 */, _ULL(0x43AA1C06A0ABFB4A) /*  481 */,
274     _ULL(0x7F4DC26FF162796B) /*  482 */, _ULL(0x6CBACC8E54ED9B0F) /*  483 */,
275     _ULL(0xA6B7FFEFD2BB253E) /*  484 */, _ULL(0x2E25BC95B0A29D4F) /*  485 */,
276     _ULL(0x86D6A58BDEF1388C) /*  486 */, _ULL(0xDED74AC576B6F054) /*  487 */,
277     _ULL(0x8030BDBC2B45805D) /*  488 */, _ULL(0x3C81AF70E94D9289) /*  489 */,
278     _ULL(0x3EFF6DDA9E3100DB) /*  490 */, _ULL(0xB38DC39FDFCC8847) /*  491 */,
279     _ULL(0x123885528D17B87E) /*  492 */, _ULL(0xF2DA0ED240B1B642) /*  493 */,
280     _ULL(0x44CEFADCD54BF9A9) /*  494 */, _ULL(0x1312200E433C7EE6) /*  495 */,
281     _ULL(0x9FFCC84F3A78C748) /*  496 */, _ULL(0xF0CD1F72248576BB) /*  497 */,
282     _ULL(0xEC6974053638CFE4) /*  498 */, _ULL(0x2BA7B67C0CEC4E4C) /*  499 */,
283     _ULL(0xAC2F4DF3E5CE32ED) /*  500 */, _ULL(0xCB33D14326EA4C11) /*  501 */,
284     _ULL(0xA4E9044CC77E58BC) /*  502 */, _ULL(0x5F513293D934FCEF) /*  503 */,
285     _ULL(0x5DC9645506E55444) /*  504 */, _ULL(0x50DE418F317DE40A) /*  505 */,
286     _ULL(0x388CB31A69DDE259) /*  506 */, _ULL(0x2DB4A83455820A86) /*  507 */,
287     _ULL(0x9010A91E84711AE9) /*  508 */, _ULL(0x4DF7F0B7B1498371) /*  509 */,
288     _ULL(0xD62A2EABC0977179) /*  510 */, _ULL(0x22FAC097AA8D5C0E) /*  511 */,
289     _ULL(0xF49FCC2FF1DAF39B) /*  512 */, _ULL(0x487FD5C66FF29281) /*  513 */,
290     _ULL(0xE8A30667FCDCA83F) /*  514 */, _ULL(0x2C9B4BE3D2FCCE63) /*  515 */,
291     _ULL(0xDA3FF74B93FBBBC2) /*  516 */, _ULL(0x2FA165D2FE70BA66) /*  517 */,
292     _ULL(0xA103E279970E93D4) /*  518 */, _ULL(0xBECDEC77B0E45E71) /*  519 */,
293     _ULL(0xCFB41E723985E497) /*  520 */, _ULL(0xB70AAA025EF75017) /*  521 */,
294     _ULL(0xD42309F03840B8E0) /*  522 */, _ULL(0x8EFC1AD035898579) /*  523 */,
295     _ULL(0x96C6920BE2B2ABC5) /*  524 */, _ULL(0x66AF4163375A9172) /*  525 */,
296     _ULL(0x2174ABDCCA7127FB) /*  526 */, _ULL(0xB33CCEA64A72FF41) /*  527 */,
297     _ULL(0xF04A4933083066A5) /*  528 */, _ULL(0x8D970ACDD7289AF5) /*  529 */,
298     _ULL(0x8F96E8E031C8C25E) /*  530 */, _ULL(0xF3FEC02276875D47) /*  531 */,
299     _ULL(0xEC7BF310056190DD) /*  532 */, _ULL(0xF5ADB0AEBB0F1491) /*  533 */,
300     _ULL(0x9B50F8850FD58892) /*  534 */, _ULL(0x4975488358B74DE8) /*  535 */,
301     _ULL(0xA3354FF691531C61) /*  536 */, _ULL(0x0702BBE481D2C6EE) /*  537 */,
302     _ULL(0x89FB24057DEDED98) /*  538 */, _ULL(0xAC3075138596E902) /*  539 */,
303     _ULL(0x1D2D3580172772ED) /*  540 */, _ULL(0xEB738FC28E6BC30D) /*  541 */,
304     _ULL(0x5854EF8F63044326) /*  542 */, _ULL(0x9E5C52325ADD3BBE) /*  543 */,
305     _ULL(0x90AA53CF325C4623) /*  544 */, _ULL(0xC1D24D51349DD067) /*  545 */,
306     _ULL(0x2051CFEEA69EA624) /*  546 */, _ULL(0x13220F0A862E7E4F) /*  547 */,
307     _ULL(0xCE39399404E04864) /*  548 */, _ULL(0xD9C42CA47086FCB7) /*  549 */,
308     _ULL(0x685AD2238A03E7CC) /*  550 */, _ULL(0x066484B2AB2FF1DB) /*  551 */,
309     _ULL(0xFE9D5D70EFBF79EC) /*  552 */, _ULL(0x5B13B9DD9C481854) /*  553 */,
310     _ULL(0x15F0D475ED1509AD) /*  554 */, _ULL(0x0BEBCD060EC79851) /*  555 */,
311     _ULL(0xD58C6791183AB7F8) /*  556 */, _ULL(0xD1187C5052F3EEE4) /*  557 */,
312     _ULL(0xC95D1192E54E82FF) /*  558 */, _ULL(0x86EEA14CB9AC6CA2) /*  559 */,
313     _ULL(0x3485BEB153677D5D) /*  560 */, _ULL(0xDD191D781F8C492A) /*  561 */,
314     _ULL(0xF60866BAA784EBF9) /*  562 */, _ULL(0x518F643BA2D08C74) /*  563 */,
315     _ULL(0x8852E956E1087C22) /*  564 */, _ULL(0xA768CB8DC410AE8D) /*  565 */,
316     _ULL(0x38047726BFEC8E1A) /*  566 */, _ULL(0xA67738B4CD3B45AA) /*  567 */,
317     _ULL(0xAD16691CEC0DDE19) /*  568 */, _ULL(0xC6D4319380462E07) /*  569 */,
318     _ULL(0xC5A5876D0BA61938) /*  570 */, _ULL(0x16B9FA1FA58FD840) /*  571 */,
319     _ULL(0x188AB1173CA74F18) /*  572 */, _ULL(0xABDA2F98C99C021F) /*  573 */,
320     _ULL(0x3E0580AB134AE816) /*  574 */, _ULL(0x5F3B05B773645ABB) /*  575 */,
321     _ULL(0x2501A2BE5575F2F6) /*  576 */, _ULL(0x1B2F74004E7E8BA9) /*  577 */,
322     _ULL(0x1CD7580371E8D953) /*  578 */, _ULL(0x7F6ED89562764E30) /*  579 */,
323     _ULL(0xB15926FF596F003D) /*  580 */, _ULL(0x9F65293DA8C5D6B9) /*  581 */,
324     _ULL(0x6ECEF04DD690F84C) /*  582 */, _ULL(0x4782275FFF33AF88) /*  583 */,
325     _ULL(0xE41433083F820801) /*  584 */, _ULL(0xFD0DFE409A1AF9B5) /*  585 */,
326     _ULL(0x4325A3342CDB396B) /*  586 */, _ULL(0x8AE77E62B301B252) /*  587 */,
327     _ULL(0xC36F9E9F6655615A) /*  588 */, _ULL(0x85455A2D92D32C09) /*  589 */,
328     _ULL(0xF2C7DEA949477485) /*  590 */, _ULL(0x63CFB4C133A39EBA) /*  591 */,
329     _ULL(0x83B040CC6EBC5462) /*  592 */, _ULL(0x3B9454C8FDB326B0) /*  593 */,
330     _ULL(0x56F56A9E87FFD78C) /*  594 */, _ULL(0x2DC2940D99F42BC6) /*  595 */,
331     _ULL(0x98F7DF096B096E2D) /*  596 */, _ULL(0x19A6E01E3AD852BF) /*  597 */,
332     _ULL(0x42A99CCBDBD4B40B) /*  598 */, _ULL(0xA59998AF45E9C559) /*  599 */,
333     _ULL(0x366295E807D93186) /*  600 */, _ULL(0x6B48181BFAA1F773) /*  601 */,
334     _ULL(0x1FEC57E2157A0A1D) /*  602 */, _ULL(0x4667446AF6201AD5) /*  603 */,
335     _ULL(0xE615EBCACFB0F075) /*  604 */, _ULL(0xB8F31F4F68290778) /*  605 */,
336     _ULL(0x22713ED6CE22D11E) /*  606 */, _ULL(0x3057C1A72EC3C93B) /*  607 */,
337     _ULL(0xCB46ACC37C3F1F2F) /*  608 */, _ULL(0xDBB893FD02AAF50E) /*  609 */,
338     _ULL(0x331FD92E600B9FCF) /*  610 */, _ULL(0xA498F96148EA3AD6) /*  611 */,
339     _ULL(0xA8D8426E8B6A83EA) /*  612 */, _ULL(0xA089B274B7735CDC) /*  613 */,
340     _ULL(0x87F6B3731E524A11) /*  614 */, _ULL(0x118808E5CBC96749) /*  615 */,
341     _ULL(0x9906E4C7B19BD394) /*  616 */, _ULL(0xAFED7F7E9B24A20C) /*  617 */,
342     _ULL(0x6509EADEEB3644A7) /*  618 */, _ULL(0x6C1EF1D3E8EF0EDE) /*  619 */,
343     _ULL(0xB9C97D43E9798FB4) /*  620 */, _ULL(0xA2F2D784740C28A3) /*  621 */,
344     _ULL(0x7B8496476197566F) /*  622 */, _ULL(0x7A5BE3E6B65F069D) /*  623 */,
345     _ULL(0xF96330ED78BE6F10) /*  624 */, _ULL(0xEEE60DE77A076A15) /*  625 */,
346     _ULL(0x2B4BEE4AA08B9BD0) /*  626 */, _ULL(0x6A56A63EC7B8894E) /*  627 */,
347     _ULL(0x02121359BA34FEF4) /*  628 */, _ULL(0x4CBF99F8283703FC) /*  629 */,
348     _ULL(0x398071350CAF30C8) /*  630 */, _ULL(0xD0A77A89F017687A) /*  631 */,
349     _ULL(0xF1C1A9EB9E423569) /*  632 */, _ULL(0x8C7976282DEE8199) /*  633 */,
350     _ULL(0x5D1737A5DD1F7ABD) /*  634 */, _ULL(0x4F53433C09A9FA80) /*  635 */,
351     _ULL(0xFA8B0C53DF7CA1D9) /*  636 */, _ULL(0x3FD9DCBC886CCB77) /*  637 */,
352     _ULL(0xC040917CA91B4720) /*  638 */, _ULL(0x7DD00142F9D1DCDF) /*  639 */,
353     _ULL(0x8476FC1D4F387B58) /*  640 */, _ULL(0x23F8E7C5F3316503) /*  641 */,
354     _ULL(0x032A2244E7E37339) /*  642 */, _ULL(0x5C87A5D750F5A74B) /*  643 */,
355     _ULL(0x082B4CC43698992E) /*  644 */, _ULL(0xDF917BECB858F63C) /*  645 */,
356     _ULL(0x3270B8FC5BF86DDA) /*  646 */, _ULL(0x10AE72BB29B5DD76) /*  647 */,
357     _ULL(0x576AC94E7700362B) /*  648 */, _ULL(0x1AD112DAC61EFB8F) /*  649 */,
358     _ULL(0x691BC30EC5FAA427) /*  650 */, _ULL(0xFF246311CC327143) /*  651 */,
359     _ULL(0x3142368E30E53206) /*  652 */, _ULL(0x71380E31E02CA396) /*  653 */,
360     _ULL(0x958D5C960AAD76F1) /*  654 */, _ULL(0xF8D6F430C16DA536) /*  655 */,
361     _ULL(0xC8FFD13F1BE7E1D2) /*  656 */, _ULL(0x7578AE66004DDBE1) /*  657 */,
362     _ULL(0x05833F01067BE646) /*  658 */, _ULL(0xBB34B5AD3BFE586D) /*  659 */,
363     _ULL(0x095F34C9A12B97F0) /*  660 */, _ULL(0x247AB64525D60CA8) /*  661 */,
364     _ULL(0xDCDBC6F3017477D1) /*  662 */, _ULL(0x4A2E14D4DECAD24D) /*  663 */,
365     _ULL(0xBDB5E6D9BE0A1EEB) /*  664 */, _ULL(0x2A7E70F7794301AB) /*  665 */,
366     _ULL(0xDEF42D8A270540FD) /*  666 */, _ULL(0x01078EC0A34C22C1) /*  667 */,
367     _ULL(0xE5DE511AF4C16387) /*  668 */, _ULL(0x7EBB3A52BD9A330A) /*  669 */,
368     _ULL(0x77697857AA7D6435) /*  670 */, _ULL(0x004E831603AE4C32) /*  671 */,
369     _ULL(0xE7A21020AD78E312) /*  672 */, _ULL(0x9D41A70C6AB420F2) /*  673 */,
370     _ULL(0x28E06C18EA1141E6) /*  674 */, _ULL(0xD2B28CBD984F6B28) /*  675 */,
371     _ULL(0x26B75F6C446E9D83) /*  676 */, _ULL(0xBA47568C4D418D7F) /*  677 */,
372     _ULL(0xD80BADBFE6183D8E) /*  678 */, _ULL(0x0E206D7F5F166044) /*  679 */,
373     _ULL(0xE258A43911CBCA3E) /*  680 */, _ULL(0x723A1746B21DC0BC) /*  681 */,
374     _ULL(0xC7CAA854F5D7CDD3) /*  682 */, _ULL(0x7CAC32883D261D9C) /*  683 */,
375     _ULL(0x7690C26423BA942C) /*  684 */, _ULL(0x17E55524478042B8) /*  685 */,
376     _ULL(0xE0BE477656A2389F) /*  686 */, _ULL(0x4D289B5E67AB2DA0) /*  687 */,
377     _ULL(0x44862B9C8FBBFD31) /*  688 */, _ULL(0xB47CC8049D141365) /*  689 */,
378     _ULL(0x822C1B362B91C793) /*  690 */, _ULL(0x4EB14655FB13DFD8) /*  691 */,
379     _ULL(0x1ECBBA0714E2A97B) /*  692 */, _ULL(0x6143459D5CDE5F14) /*  693 */,
380     _ULL(0x53A8FBF1D5F0AC89) /*  694 */, _ULL(0x97EA04D81C5E5B00) /*  695 */,
381     _ULL(0x622181A8D4FDB3F3) /*  696 */, _ULL(0xE9BCD341572A1208) /*  697 */,
382     _ULL(0x1411258643CCE58A) /*  698 */, _ULL(0x9144C5FEA4C6E0A4) /*  699 */,
383     _ULL(0x0D33D06565CF620F) /*  700 */, _ULL(0x54A48D489F219CA1) /*  701 */,
384     _ULL(0xC43E5EAC6D63C821) /*  702 */, _ULL(0xA9728B3A72770DAF) /*  703 */,
385     _ULL(0xD7934E7B20DF87EF) /*  704 */, _ULL(0xE35503B61A3E86E5) /*  705 */,
386     _ULL(0xCAE321FBC819D504) /*  706 */, _ULL(0x129A50B3AC60BFA6) /*  707 */,
387     _ULL(0xCD5E68EA7E9FB6C3) /*  708 */, _ULL(0xB01C90199483B1C7) /*  709 */,
388     _ULL(0x3DE93CD5C295376C) /*  710 */, _ULL(0xAED52EDF2AB9AD13) /*  711 */,
389     _ULL(0x2E60F512C0A07884) /*  712 */, _ULL(0xBC3D86A3E36210C9) /*  713 */,
390     _ULL(0x35269D9B163951CE) /*  714 */, _ULL(0x0C7D6E2AD0CDB5FA) /*  715 */,
391     _ULL(0x59E86297D87F5733) /*  716 */, _ULL(0x298EF221898DB0E7) /*  717 */,
392     _ULL(0x55000029D1A5AA7E) /*  718 */, _ULL(0x8BC08AE1B5061B45) /*  719 */,
393     _ULL(0xC2C31C2B6C92703A) /*  720 */, _ULL(0x94CC596BAF25EF42) /*  721 */,
394     _ULL(0x0A1D73DB22540456) /*  722 */, _ULL(0x04B6A0F9D9C4179A) /*  723 */,
395     _ULL(0xEFFDAFA2AE3D3C60) /*  724 */, _ULL(0xF7C8075BB49496C4) /*  725 */,
396     _ULL(0x9CC5C7141D1CD4E3) /*  726 */, _ULL(0x78BD1638218E5534) /*  727 */,
397     _ULL(0xB2F11568F850246A) /*  728 */, _ULL(0xEDFABCFA9502BC29) /*  729 */,
398     _ULL(0x796CE5F2DA23051B) /*  730 */, _ULL(0xAAE128B0DC93537C) /*  731 */,
399     _ULL(0x3A493DA0EE4B29AE) /*  732 */, _ULL(0xB5DF6B2C416895D7) /*  733 */,
400     _ULL(0xFCABBD25122D7F37) /*  734 */, _ULL(0x70810B58105DC4B1) /*  735 */,
401     _ULL(0xE10FDD37F7882A90) /*  736 */, _ULL(0x524DCAB5518A3F5C) /*  737 */,
402     _ULL(0x3C9E85878451255B) /*  738 */, _ULL(0x4029828119BD34E2) /*  739 */,
403     _ULL(0x74A05B6F5D3CECCB) /*  740 */, _ULL(0xB610021542E13ECA) /*  741 */,
404     _ULL(0x0FF979D12F59E2AC) /*  742 */, _ULL(0x6037DA27E4F9CC50) /*  743 */,
405     _ULL(0x5E92975A0DF1847D) /*  744 */, _ULL(0xD66DE190D3E623FE) /*  745 */,
406     _ULL(0x5032D6B87B568048) /*  746 */, _ULL(0x9A36B7CE8235216E) /*  747 */,
407     _ULL(0x80272A7A24F64B4A) /*  748 */, _ULL(0x93EFED8B8C6916F7) /*  749 */,
408     _ULL(0x37DDBFF44CCE1555) /*  750 */, _ULL(0x4B95DB5D4B99BD25) /*  751 */,
409     _ULL(0x92D3FDA169812FC0) /*  752 */, _ULL(0xFB1A4A9A90660BB6) /*  753 */,
410     _ULL(0x730C196946A4B9B2) /*  754 */, _ULL(0x81E289AA7F49DA68) /*  755 */,
411     _ULL(0x64669A0F83B1A05F) /*  756 */, _ULL(0x27B3FF7D9644F48B) /*  757 */,
412     _ULL(0xCC6B615C8DB675B3) /*  758 */, _ULL(0x674F20B9BCEBBE95) /*  759 */,
413     _ULL(0x6F31238275655982) /*  760 */, _ULL(0x5AE488713E45CF05) /*  761 */,
414     _ULL(0xBF619F9954C21157) /*  762 */, _ULL(0xEABAC46040A8EAE9) /*  763 */,
415     _ULL(0x454C6FE9F2C0C1CD) /*  764 */, _ULL(0x419CF6496412691C) /*  765 */,
416     _ULL(0xD3DC3BEF265B0F70) /*  766 */, _ULL(0x6D0E60F5C3578A9E) /*  767 */,
417     _ULL(0x5B0E608526323C55) /*  768 */, _ULL(0x1A46C1A9FA1B59F5) /*  769 */,
418     _ULL(0xA9E245A17C4C8FFA) /*  770 */, _ULL(0x65CA5159DB2955D7) /*  771 */,
419     _ULL(0x05DB0A76CE35AFC2) /*  772 */, _ULL(0x81EAC77EA9113D45) /*  773 */,
420     _ULL(0x528EF88AB6AC0A0D) /*  774 */, _ULL(0xA09EA253597BE3FF) /*  775 */,
421     _ULL(0x430DDFB3AC48CD56) /*  776 */, _ULL(0xC4B3A67AF45CE46F) /*  777 */,
422     _ULL(0x4ECECFD8FBE2D05E) /*  778 */, _ULL(0x3EF56F10B39935F0) /*  779 */,
423     _ULL(0x0B22D6829CD619C6) /*  780 */, _ULL(0x17FD460A74DF2069) /*  781 */,
424     _ULL(0x6CF8CC8E8510ED40) /*  782 */, _ULL(0xD6C824BF3A6ECAA7) /*  783 */,
425     _ULL(0x61243D581A817049) /*  784 */, _ULL(0x048BACB6BBC163A2) /*  785 */,
426     _ULL(0xD9A38AC27D44CC32) /*  786 */, _ULL(0x7FDDFF5BAAF410AB) /*  787 */,
427     _ULL(0xAD6D495AA804824B) /*  788 */, _ULL(0xE1A6A74F2D8C9F94) /*  789 */,
428     _ULL(0xD4F7851235DEE8E3) /*  790 */, _ULL(0xFD4B7F886540D893) /*  791 */,
429     _ULL(0x247C20042AA4BFDA) /*  792 */, _ULL(0x096EA1C517D1327C) /*  793 */,
430     _ULL(0xD56966B4361A6685) /*  794 */, _ULL(0x277DA5C31221057D) /*  795 */,
431     _ULL(0x94D59893A43ACFF7) /*  796 */, _ULL(0x64F0C51CCDC02281) /*  797 */,
432     _ULL(0x3D33BCC4FF6189DB) /*  798 */, _ULL(0xE005CB184CE66AF1) /*  799 */,
433     _ULL(0xFF5CCD1D1DB99BEA) /*  800 */, _ULL(0xB0B854A7FE42980F) /*  801 */,
434     _ULL(0x7BD46A6A718D4B9F) /*  802 */, _ULL(0xD10FA8CC22A5FD8C) /*  803 */,
435     _ULL(0xD31484952BE4BD31) /*  804 */, _ULL(0xC7FA975FCB243847) /*  805 */,
436     _ULL(0x4886ED1E5846C407) /*  806 */, _ULL(0x28CDDB791EB70B04) /*  807 */,
437     _ULL(0xC2B00BE2F573417F) /*  808 */, _ULL(0x5C9590452180F877) /*  809 */,
438     _ULL(0x7A6BDDFFF370EB00) /*  810 */, _ULL(0xCE509E38D6D9D6A4) /*  811 */,
439     _ULL(0xEBEB0F00647FA702) /*  812 */, _ULL(0x1DCC06CF76606F06) /*  813 */,
440     _ULL(0xE4D9F28BA286FF0A) /*  814 */, _ULL(0xD85A305DC918C262) /*  815 */,
441     _ULL(0x475B1D8732225F54) /*  816 */, _ULL(0x2D4FB51668CCB5FE) /*  817 */,
442     _ULL(0xA679B9D9D72BBA20) /*  818 */, _ULL(0x53841C0D912D43A5) /*  819 */,
443     _ULL(0x3B7EAA48BF12A4E8) /*  820 */, _ULL(0x781E0E47F22F1DDF) /*  821 */,
444     _ULL(0xEFF20CE60AB50973) /*  822 */, _ULL(0x20D261D19DFFB742) /*  823 */,
445     _ULL(0x16A12B03062A2E39) /*  824 */, _ULL(0x1960EB2239650495) /*  825 */,
446     _ULL(0x251C16FED50EB8B8) /*  826 */, _ULL(0x9AC0C330F826016E) /*  827 */,
447     _ULL(0xED152665953E7671) /*  828 */, _ULL(0x02D63194A6369570) /*  829 */,
448     _ULL(0x5074F08394B1C987) /*  830 */, _ULL(0x70BA598C90B25CE1) /*  831 */,
449     _ULL(0x794A15810B9742F6) /*  832 */, _ULL(0x0D5925E9FCAF8C6C) /*  833 */,
450     _ULL(0x3067716CD868744E) /*  834 */, _ULL(0x910AB077E8D7731B) /*  835 */,
451     _ULL(0x6A61BBDB5AC42F61) /*  836 */, _ULL(0x93513EFBF0851567) /*  837 */,
452     _ULL(0xF494724B9E83E9D5) /*  838 */, _ULL(0xE887E1985C09648D) /*  839 */,
453     _ULL(0x34B1D3C675370CFD) /*  840 */, _ULL(0xDC35E433BC0D255D) /*  841 */,
454     _ULL(0xD0AAB84234131BE0) /*  842 */, _ULL(0x08042A50B48B7EAF) /*  843 */,
455     _ULL(0x9997C4EE44A3AB35) /*  844 */, _ULL(0x829A7B49201799D0) /*  845 */,
456     _ULL(0x263B8307B7C54441) /*  846 */, _ULL(0x752F95F4FD6A6CA6) /*  847 */,
457     _ULL(0x927217402C08C6E5) /*  848 */, _ULL(0x2A8AB754A795D9EE) /*  849 */,
458     _ULL(0xA442F7552F72943D) /*  850 */, _ULL(0x2C31334E19781208) /*  851 */,
459     _ULL(0x4FA98D7CEAEE6291) /*  852 */, _ULL(0x55C3862F665DB309) /*  853 */,
460     _ULL(0xBD0610175D53B1F3) /*  854 */, _ULL(0x46FE6CB840413F27) /*  855 */,
461     _ULL(0x3FE03792DF0CFA59) /*  856 */, _ULL(0xCFE700372EB85E8F) /*  857 */,
462     _ULL(0xA7BE29E7ADBCE118) /*  858 */, _ULL(0xE544EE5CDE8431DD) /*  859 */,
463     _ULL(0x8A781B1B41F1873E) /*  860 */, _ULL(0xA5C94C78A0D2F0E7) /*  861 */,
464     _ULL(0x39412E2877B60728) /*  862 */, _ULL(0xA1265EF3AFC9A62C) /*  863 */,
465     _ULL(0xBCC2770C6A2506C5) /*  864 */, _ULL(0x3AB66DD5DCE1CE12) /*  865 */,
466     _ULL(0xE65499D04A675B37) /*  866 */, _ULL(0x7D8F523481BFD216) /*  867 */,
467     _ULL(0x0F6F64FCEC15F389) /*  868 */, _ULL(0x74EFBE618B5B13C8) /*  869 */,
468     _ULL(0xACDC82B714273E1D) /*  870 */, _ULL(0xDD40BFE003199D17) /*  871 */,
469     _ULL(0x37E99257E7E061F8) /*  872 */, _ULL(0xFA52626904775AAA) /*  873 */,
470     _ULL(0x8BBBF63A463D56F9) /*  874 */, _ULL(0xF0013F1543A26E64) /*  875 */,
471     _ULL(0xA8307E9F879EC898) /*  876 */, _ULL(0xCC4C27A4150177CC) /*  877 */,
472     _ULL(0x1B432F2CCA1D3348) /*  878 */, _ULL(0xDE1D1F8F9F6FA013) /*  879 */,
473     _ULL(0x606602A047A7DDD6) /*  880 */, _ULL(0xD237AB64CC1CB2C7) /*  881 */,
474     _ULL(0x9B938E7225FCD1D3) /*  882 */, _ULL(0xEC4E03708E0FF476) /*  883 */,
475     _ULL(0xFEB2FBDA3D03C12D) /*  884 */, _ULL(0xAE0BCED2EE43889A) /*  885 */,
476     _ULL(0x22CB8923EBFB4F43) /*  886 */, _ULL(0x69360D013CF7396D) /*  887 */,
477     _ULL(0x855E3602D2D4E022) /*  888 */, _ULL(0x073805BAD01F784C) /*  889 */,
478     _ULL(0x33E17A133852F546) /*  890 */, _ULL(0xDF4874058AC7B638) /*  891 */,
479     _ULL(0xBA92B29C678AA14A) /*  892 */, _ULL(0x0CE89FC76CFAADCD) /*  893 */,
480     _ULL(0x5F9D4E0908339E34) /*  894 */, _ULL(0xF1AFE9291F5923B9) /*  895 */,
481     _ULL(0x6E3480F60F4A265F) /*  896 */, _ULL(0xEEBF3A2AB29B841C) /*  897 */,
482     _ULL(0xE21938A88F91B4AD) /*  898 */, _ULL(0x57DFEFF845C6D3C3) /*  899 */,
483     _ULL(0x2F006B0BF62CAAF2) /*  900 */, _ULL(0x62F479EF6F75EE78) /*  901 */,
484     _ULL(0x11A55AD41C8916A9) /*  902 */, _ULL(0xF229D29084FED453) /*  903 */,
485     _ULL(0x42F1C27B16B000E6) /*  904 */, _ULL(0x2B1F76749823C074) /*  905 */,
486     _ULL(0x4B76ECA3C2745360) /*  906 */, _ULL(0x8C98F463B91691BD) /*  907 */,
487     _ULL(0x14BCC93CF1ADE66A) /*  908 */, _ULL(0x8885213E6D458397) /*  909 */,
488     _ULL(0x8E177DF0274D4711) /*  910 */, _ULL(0xB49B73B5503F2951) /*  911 */,
489     _ULL(0x10168168C3F96B6B) /*  912 */, _ULL(0x0E3D963B63CAB0AE) /*  913 */,
490     _ULL(0x8DFC4B5655A1DB14) /*  914 */, _ULL(0xF789F1356E14DE5C) /*  915 */,
491     _ULL(0x683E68AF4E51DAC1) /*  916 */, _ULL(0xC9A84F9D8D4B0FD9) /*  917 */,
492     _ULL(0x3691E03F52A0F9D1) /*  918 */, _ULL(0x5ED86E46E1878E80) /*  919 */,
493     _ULL(0x3C711A0E99D07150) /*  920 */, _ULL(0x5A0865B20C4E9310) /*  921 */,
494     _ULL(0x56FBFC1FE4F0682E) /*  922 */, _ULL(0xEA8D5DE3105EDF9B) /*  923 */,
495     _ULL(0x71ABFDB12379187A) /*  924 */, _ULL(0x2EB99DE1BEE77B9C) /*  925 */,
496     _ULL(0x21ECC0EA33CF4523) /*  926 */, _ULL(0x59A4D7521805C7A1) /*  927 */,
497     _ULL(0x3896F5EB56AE7C72) /*  928 */, _ULL(0xAA638F3DB18F75DC) /*  929 */,
498     _ULL(0x9F39358DABE9808E) /*  930 */, _ULL(0xB7DEFA91C00B72AC) /*  931 */,
499     _ULL(0x6B5541FD62492D92) /*  932 */, _ULL(0x6DC6DEE8F92E4D5B) /*  933 */,
500     _ULL(0x353F57ABC4BEEA7E) /*  934 */, _ULL(0x735769D6DA5690CE) /*  935 */,
501     _ULL(0x0A234AA642391484) /*  936 */, _ULL(0xF6F9508028F80D9D) /*  937 */,
502     _ULL(0xB8E319A27AB3F215) /*  938 */, _ULL(0x31AD9C1151341A4D) /*  939 */,
503     _ULL(0x773C22A57BEF5805) /*  940 */, _ULL(0x45C7561A07968633) /*  941 */,
504     _ULL(0xF913DA9E249DBE36) /*  942 */, _ULL(0xDA652D9B78A64C68) /*  943 */,
505     _ULL(0x4C27A97F3BC334EF) /*  944 */, _ULL(0x76621220E66B17F4) /*  945 */,
506     _ULL(0x967743899ACD7D0B) /*  946 */, _ULL(0xF3EE5BCAE0ED6782) /*  947 */,
507     _ULL(0x409F753600C879FC) /*  948 */, _ULL(0x06D09A39B5926DB6) /*  949 */,
508     _ULL(0x6F83AEB0317AC588) /*  950 */, _ULL(0x01E6CA4A86381F21) /*  951 */,
509     _ULL(0x66FF3462D19F3025) /*  952 */, _ULL(0x72207C24DDFD3BFB) /*  953 */,
510     _ULL(0x4AF6B6D3E2ECE2EB) /*  954 */, _ULL(0x9C994DBEC7EA08DE) /*  955 */,
511     _ULL(0x49ACE597B09A8BC4) /*  956 */, _ULL(0xB38C4766CF0797BA) /*  957 */,
512     _ULL(0x131B9373C57C2A75) /*  958 */, _ULL(0xB1822CCE61931E58) /*  959 */,
513     _ULL(0x9D7555B909BA1C0C) /*  960 */, _ULL(0x127FAFDD937D11D2) /*  961 */,
514     _ULL(0x29DA3BADC66D92E4) /*  962 */, _ULL(0xA2C1D57154C2ECBC) /*  963 */,
515     _ULL(0x58C5134D82F6FE24) /*  964 */, _ULL(0x1C3AE3515B62274F) /*  965 */,
516     _ULL(0xE907C82E01CB8126) /*  966 */, _ULL(0xF8ED091913E37FCB) /*  967 */,
517     _ULL(0x3249D8F9C80046C9) /*  968 */, _ULL(0x80CF9BEDE388FB63) /*  969 */,
518     _ULL(0x1881539A116CF19E) /*  970 */, _ULL(0x5103F3F76BD52457) /*  971 */,
519     _ULL(0x15B7E6F5AE47F7A8) /*  972 */, _ULL(0xDBD7C6DED47E9CCF) /*  973 */,
520     _ULL(0x44E55C410228BB1A) /*  974 */, _ULL(0xB647D4255EDB4E99) /*  975 */,
521     _ULL(0x5D11882BB8AAFC30) /*  976 */, _ULL(0xF5098BBB29D3212A) /*  977 */,
522     _ULL(0x8FB5EA14E90296B3) /*  978 */, _ULL(0x677B942157DD025A) /*  979 */,
523     _ULL(0xFB58E7C0A390ACB5) /*  980 */, _ULL(0x89D3674C83BD4A01) /*  981 */,
524     _ULL(0x9E2DA4DF4BF3B93B) /*  982 */, _ULL(0xFCC41E328CAB4829) /*  983 */,
525     _ULL(0x03F38C96BA582C52) /*  984 */, _ULL(0xCAD1BDBD7FD85DB2) /*  985 */,
526     _ULL(0xBBB442C16082AE83) /*  986 */, _ULL(0xB95FE86BA5DA9AB0) /*  987 */,
527     _ULL(0xB22E04673771A93F) /*  988 */, _ULL(0x845358C9493152D8) /*  989 */,
528     _ULL(0xBE2A488697B4541E) /*  990 */, _ULL(0x95A2DC2DD38E6966) /*  991 */,
529     _ULL(0xC02C11AC923C852B) /*  992 */, _ULL(0x2388B1990DF2A87B) /*  993 */,
530     _ULL(0x7C8008FA1B4F37BE) /*  994 */, _ULL(0x1F70D0C84D54E503) /*  995 */,
531     _ULL(0x5490ADEC7ECE57D4) /*  996 */, _ULL(0x002B3C27D9063A3A) /*  997 */,
532     _ULL(0x7EAEA3848030A2BF) /*  998 */, _ULL(0xC602326DED2003C0) /*  999 */,
533     _ULL(0x83A7287D69A94086) /* 1000 */, _ULL(0xC57A5FCB30F57A8A) /* 1001 */,
534     _ULL(0xB56844E479EBE779) /* 1002 */, _ULL(0xA373B40F05DCBCE9) /* 1003 */,
535     _ULL(0xD71A786E88570EE2) /* 1004 */, _ULL(0x879CBACDBDE8F6A0) /* 1005 */,
536     _ULL(0x976AD1BCC164A32F) /* 1006 */, _ULL(0xAB21E25E9666D78B) /* 1007 */,
537     _ULL(0x901063AAE5E5C33C) /* 1008 */, _ULL(0x9818B34448698D90) /* 1009 */,
538     _ULL(0xE36487AE3E1E8ABB) /* 1010 */, _ULL(0xAFBDF931893BDCB4) /* 1011 */,
539     _ULL(0x6345A0DC5FBBD519) /* 1012 */, _ULL(0x8628FE269B9465CA) /* 1013 */,
540     _ULL(0x1E5D01603F9C51EC) /* 1014 */, _ULL(0x4DE44006A15049B7) /* 1015 */,
541     _ULL(0xBF6C70E5F776CBB1) /* 1016 */, _ULL(0x411218F2EF552BED) /* 1017 */,
542     _ULL(0xCB0C0708705A36A3) /* 1018 */, _ULL(0xE74D14754F986044) /* 1019 */,
543     _ULL(0xCD56D9430EA8280E) /* 1020 */, _ULL(0xC12591D7535F5065) /* 1021 */,
544     _ULL(0xC83223F1720AEF96) /* 1022 */, _ULL(0xC3A0396F7363A51F) /* 1023 */
545 };
546 
547 /* The following macro denotes that an optimization */
548 /* for Alpha is required. It is used only for	    */
549 /* optimization of time. Otherwise it does nothing. */
550 #ifdef __alpha
551 #    define OPTIMIZE_FOR_ALPHA
552 #endif
553 
554 /* NOTE that this code is NOT FULLY OPTIMIZED for any  */
555 /* machine. Assembly code might be much faster on some */
556 /* machines, especially if the code is compiled with   */
557 /* gcc.						       */
558 
559 /* The number of passes of the hash function.    */
560 /* Three passes are recommended.		 */
561 /* Use four passes when you need extra security. */
562 /* Must be at least three.			 */
563 #define PASSES 3
564 
565 
566 #define t1 (tiger_sboxes)
567 #define t2 (tiger_sboxes + 256)
568 #define t3 (tiger_sboxes + 256 * 2)
569 #define t4 (tiger_sboxes + 256 * 3)
570 
571 #define save_abc \
572     aa = a; \
573     bb = b; \
574     cc = c;
575 
576 #ifdef OPTIMIZE_FOR_ALPHA
577 /* This is the official definition of round */
578 #define round(a,b,c,x,mul) \
579     c ^= x; \
580     a -= t1[((c)>>(0*8))&0xFF] ^ t2[((c)>>(2*8))&0xFF] ^ \
581 	t3[((c)>>(4*8))&0xFF] ^ t4[((c)>>(6*8))&0xFF]; \
582     b += t4[((c)>>(1*8))&0xFF] ^ t3[((c)>>(3*8))&0xFF] ^ \
583 	t2[((c)>>(5*8))&0xFF] ^ t1[((c)>>(7*8))&0xFF]; \
584     b *= mul;
585 #else
586 /* This code works faster when compiled on 32-bit machines */
587 /* (but works slower on Alpha) */
588 #define round(a,b,c,x,mul) \
589     c ^= x; \
590     a -= t1[(uint8_t)(c)] ^ \
591 	t2[(uint8_t)(((uint32_t)(c))>>(2*8))] ^ \
592 	t3[(uint8_t)((c)>>(4*8))] ^ \
593 	t4[(uint8_t)(((uint32_t)((c)>>(4*8)))>>(2*8))]; \
594     b += t4[(uint8_t)(((uint32_t)(c))>>(1*8))] ^ \
595 	t3[(uint8_t)(((uint32_t)(c))>>(3*8))] ^ \
596 	t2[(uint8_t)(((uint32_t)((c)>>(4*8)))>>(1*8))] ^ \
597 	t1[(uint8_t)(((uint32_t)((c)>>(4*8)))>>(3*8))]; \
598     b *= mul;
599 #endif
600 
601 #define pass(a,b,c,mul) \
602     round(a,b,c,x0,mul) \
603     round(b,c,a,x1,mul) \
604     round(c,a,b,x2,mul) \
605     round(a,b,c,x3,mul) \
606     round(b,c,a,x4,mul) \
607     round(c,a,b,x5,mul) \
608     round(a,b,c,x6,mul) \
609     round(b,c,a,x7,mul)
610 
611 #define key_schedule \
612     x0 -= x7 ^ _ULL(0xA5A5A5A5A5A5A5A5); \
613     x1 ^= x0; \
614     x2 += x1; \
615     x3 -= x2 ^ ((~x1)<<19); \
616     x4 ^= x3; \
617     x5 += x4; \
618     x6 -= x5 ^ ((~x4)>>23); \
619     x7 ^= x6; \
620     x0 += x7; \
621     x1 -= x0 ^ ((~x7)<<19); \
622     x2 ^= x1; \
623     x3 += x2; \
624     x4 -= x3 ^ ((~x2)>>23); \
625     x5 ^= x4; \
626     x6 += x5; \
627     x7 -= x6 ^ _ULL(0x0123456789ABCDEF);
628 
629 #define feedforward \
630     a ^= aa; \
631     b -= bb; \
632     c += cc;
633 
634 #ifdef OPTIMIZE_FOR_ALPHA
635 /* The loop is unrolled: works better on Alpha */
636 #define compress \
637     save_abc \
638     pass(a,b,c,5) \
639     key_schedule \
640     pass(c,a,b,7) \
641     key_schedule \
642     pass(b,c,a,9) \
643     for (pass_no=3; pass_no<PASSES; pass_no++) { \
644 	key_schedule \
645 	pass(a,b,c,9) \
646 	tmpa = a; a = c; c = b; b = tmpa; \
647     } \
648     feedforward
649 #else
650 /* loop: works better on PC and Sun (smaller cache?) */
651 #define compress \
652     save_abc \
653     for (pass_no=0; pass_no<PASSES; pass_no++) { \
654 	if (pass_no != 0) {key_schedule} \
655 	    pass(a,b,c,(pass_no==0?5:pass_no==1?7:9)); \
656 	tmpa = a; a = c; c = b; b = tmpa; \
657     } \
658     feedforward
659 #endif
660 
661 #define tiger_compress_macro(str, state) { \
662     register uint64_t a, b, c, tmpa; \
663     uint64_t aa, bb, cc; \
664     register uint64_t x0, x1, x2, x3, x4, x5, x6, x7; \
665     int pass_no; \
666     \
667     a = state[0]; \
668     b = state[1]; \
669     c = state[2]; \
670     \
671     x0 = str[0]; x1 = str[1]; x2 = str[2]; x3 = str[3]; \
672     x4 = str[4]; x5 = str[5]; x6 = str[6]; x7 = str[7]; \
673     \
674     compress \
675     \
676     state[0] = a; \
677     state[1] = b; \
678     state[2] = c; \
679 }
680 
681 /* The compress function is a function. Requires smaller cache? */
tiger_compress(const uint64_t * str,uint64_t * state)682 static void tiger_compress(const uint64_t* str, uint64_t* state) {
683     tiger_compress_macro(((const uint64_t*)str), ((uint64_t*)state));
684 }
685 
686 #ifdef OPTIMIZE_FOR_ALPHA
687 /* The compress function is inlined: works better on Alpha.	   */
688 /* Still leaves the function above in the code, in case some other */
689 /* module calls it directly.					   */
690 #define tiger_compress(str, state) \
691     tiger_compress_macro(((const uint64_t*)str), ((uint64_t*)state))
692 #endif
693 
tiger(const uint64_t * str,unsigned length,uint64_t * result)694 void tiger(const uint64_t* str, unsigned length, uint64_t* result) {
695     register unsigned i, j;
696 
697     /* Ensure that temp is 64-bit aligned, but provide 8-bit access: */
698 #if 0
699     /* This is technically not aliasing-safe... */
700     uint64_t temp64[8];
701     uint8_t *temp8 = (uint8_t*)&temp64[0];
702 #else
703     /* ...but this isn't guaranteerd to work either, although it usually
704      * will. */
705     union {
706 	uint64_t temp64[8];
707 	int8_t temp8[64];
708     } temp;
709 #   define temp8 temp.temp8
710 #   define temp64 temp.temp64
711 #endif
712 
713     result[0] = _ULL(0x0123456789ABCDEF);
714     result[1] = _ULL(0xFEDCBA9876543210);
715     result[2] = _ULL(0xF096A5B4C3B2E187);
716 
717     for (i = length; i >= 64; i -= 64) {
718 #if BYTE_ORDER == BIG_ENDIAN
719 	for (j = 0; j < 64; ++j)
720 	    temp8[j ^ 7] = ((const uint8_t*)str)[j];
721 	tiger_compress(temp64, result);
722 #else /* BYTE_ORDER != BIG_ENDIAN */
723 	tiger_compress(str, result);
724 #endif /* BYTE_ORDER != BIG_ENDIAN */
725 	str += 8;
726     }
727 
728 #if BYTE_ORDER == BIG_ENDIAN
729     for (j = 0; j < i; ++j)
730 	temp8[j ^ 7] = ((const uint8_t*)str)[j];
731 
732     temp8[j ^ 7] = 0x01;
733     j++;
734     for (; j & 7; ++j)
735 	temp8[j ^ 7] = 0;
736 #else /* BYTE_ORDER != BIG_ENDIAN */
737     for (j = 0; j < i; ++j)
738 	temp8[j] = ((const uint8_t*)str)[j];
739 
740     temp8[j++] = 0x01;
741     for (; j & 7; ++j)
742 	temp8[j] = 0;
743 #endif /* BYTE_ORDER != BIG_ENDIAN */
744 
745     /* Ensure that we don't mind endianness here */
746     assert((j % 8) == 0);
747 
748     if (j > 56) {
749 	for (; j < 64; ++j)
750 	    temp8[j] = 0;
751 	tiger_compress(temp64, result);
752 	j = 0;
753     }
754 
755     for (; j < 56; ++j)
756 	temp8[j] = 0;
757     temp64[7] = ((uint64_t)length) << 3;
758     tiger_compress(temp64, result);
759 #undef temp8
760 #undef temp64
761 }
762 
763 /* The tiger_bp function does the same as the tiger function,
764  * except that it prepends the specified byte to the input.
765  * The THEX algorithm requires this prepended byte.
766  * This function is here to prevent useless copying of large
767  * blocks of data, since one should be able to drop a read-only
768  * block of a (let's say memory mapped) file here.
769  *
770  * In the best case -- on LITTLE_ENDIAN -- data should be aligned at
771  * (data%8)+1, but that's impractical: most of the time you'll call
772  * this with either 3-int64's or with data read from disk (where it
773  * is *not* cheaper to read smaller unaligned blocks). The
774  * REQUIRE_ALIGNMENT preprocessor directive ensures that alignment
775  * is enforced when absolutely necessary.
776  *
777  * (On BIG_ENDIAN this isn't an issue, as we need to swap the octets
778  * anyway, aligning them at the same time.) */
tiger_bp(char prepend,const void * data,unsigned length,uint64_t * result)779 void tiger_bp(char prepend, const void* data, unsigned length,
780 	uint64_t* result) {
781     register unsigned j;
782 
783     /* Ensure that temp is 64-bit aligned, but provide 8-bit access: */
784 #if 0
785     /* This is technically not aliasing-safe... */
786     uint64_t temp64[8];
787     uint8_t *temp8 = (uint8_t*)&temp64[0];
788 #else
789     /* ...but this isn't guaranteerd to work either, although it usually
790      * will. */
791     union {
792 	uint64_t temp64[8];
793 	int8_t temp8[64];
794     } temp;
795 #   define temp8 temp.temp8
796 #   define temp64 temp.temp64
797 #endif
798 
799     result[0] = _ULL(0x0123456789ABCDEF);
800     result[1] = _ULL(0xFEDCBA9876543210);
801     result[2] = _ULL(0xF096A5B4C3B2E187);
802 
803     if (length >= 63) {
804 	register unsigned i = length + 1;
805 	const uint8_t* str;
806 
807 #if BYTE_ORDER == BIG_ENDIAN
808 	temp8[7] = (uint8_t)prepend;
809 	for (j = 1; j < 64; ++j)
810 	    temp8[j ^ 7] = ((const uint8_t*)data)[j-1];
811 #else /* BYTE_ORDER != BIG_ENDIAN */
812 	temp8[0] = prepend;
813 	memcpy(temp8 + 1, (const uint8_t*)data, 63);
814 #endif /* BYTE_ORDER != BIG_ENDIAN */
815 	tiger_compress(temp64, result);
816 
817 	/* Not 64-bit aligned! */
818 	str = ((const uint8_t*)data) + 63;
819 	i -= 64;
820 
821 	for (; i >= 64; i -= 64) {
822 #if BYTE_ORDER == BIG_ENDIAN
823 	    for (j = 0; j < 64; ++j)
824 		temp8[j ^ 7] = str[j];
825 	    tiger_compress(temp64, result);
826 #else /* BYTE_ORDER != BIG_ENDIAN */
827 #ifdef REQUIRE_ALIGNMENT
828 	    memcpy(temp8, str, 64); /* 3.5% penalty on x86_64 */
829 	    tiger_compress(temp64, result);
830 #else
831 	    /* Misaligned, but cheaper than the above option on x86 */
832 	    tiger_compress((const uint64_t*)str, result);
833 #endif
834 #endif /* BYTE_ORDER != BIG_ENDIAN */
835 	    str += 64;
836 	}
837 
838 #if BYTE_ORDER == BIG_ENDIAN
839 	for (j = 0; j < i; ++j)
840 	    temp8[j ^ 7] = str[j];
841 
842 	temp8[j++ ^ 7] = 0x01;
843 	for (; j & 7; ++j)
844 	    temp8[j ^ 7] = 0;
845 #else /* BYTE_ORDER != BIG_ENDIAN */
846 	for (j = 0; j < i; ++j)
847 	    temp8[j] = str[j];
848 
849 	temp8[j++] = 0x01;
850 	for (; j & 7; j++)
851 	    temp8[j] = 0;
852 #endif /* BYTE_ORDER != BIG_ENDIAN */
853 
854     } else /* i < 64 and we didn't prepend anything yet */ {
855 #if BYTE_ORDER == BIG_ENDIAN
856 	temp8[7] = (uint8_t)prepend;
857 	for (j = 1; j < length + 1; ++j)
858 	    temp8[j ^ 7] = ((const uint8_t*)data)[j-1];
859 	temp8[j++ ^ 7] = 0x01;
860 	for (; j & 7; ++j)
861 	    temp8[j ^ 7] = 0;
862 #else /* BYTE_ORDER != BIG_ENDIAN */
863 	temp8[0] = prepend;
864 	memcpy(temp8 + 1, (const uint8_t*)data, length);
865 	j = length + 1;
866 	temp8[j++] = 0x01;
867 	for (; j & 7; ++j)
868 	    temp8[j] = 0;
869 #endif /* BYTE_ORDER != BIG_ENDIAN */
870     }
871 
872     /* Ensure that we don't mind endianness here */
873     assert((j % 8) == 0);
874 
875     if (j > 56) {
876 	for (; j < 64; ++j)
877 	    temp8[j] = 0;
878 	tiger_compress(temp64, result);
879 	j = 0;
880     }
881 
882     for (; j < 56; ++j)
883 	temp8[j] = 0;
884     temp64[7] = ((uint64_t)length + 1) << 3;
885     tiger_compress(temp64, result);
886 #undef temp8
887 #undef temp64
888 }
889