]>
cvs.zerfleddert.de Git - proxmark3-svn/blob - client/reveng/preset.c
2 * Greg Cook, 26/Jul/2016
5 /* CRC RevEng: arbitrary-precision CRC calculator and algorithm finder
6 * Copyright (C) 2010, 2011, 2012, 2013, 2014, 2015, 2016 Gregory Cook
8 * This file is part of CRC RevEng.
10 * CRC RevEng is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation, either version 3 of the License, or
13 * (at your option) any later version.
15 * CRC RevEng is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with CRC RevEng. If not, see <https://www.gnu.org/licenses/>.
24 /* 2016-07-26: added array order checking code
25 * 2016-07-25: added 5 new algorithms
26 * 2016-07-14: added CRC-16/CMS
27 * 2016-07-08: added CRC-16/PROFIBUS
28 * 2016-02-23: added 11 new algorithms, 4 new aliases
29 * 2016-02-22: split off from model.c
30 * 2016-02-22: preset points to primary alias, eliminated strcmp()
31 * 2016-02-22: eliminated bogus calls to bsearch()
32 * 2015-07-29: eliminated struct malias.isprimry
33 * 2014-01-14: added CRC-8/DVB-S2
34 * 2014-01-11: corrected CRC-40/GSM, added alias CRC-8/AES
35 * 2013-10-14: added CRC-13/BBC and six cdma2000 algorithms
36 * 2013-06-11: ensure BMP_BIT is an integer constant to compile presets
37 * 2013-01-20: big polynomials autogenerated, corrected CRC-82/DARC
38 * 2012-07-19: added CRC-8/EBU
39 * 2012-07-16: added CRC-15/MPT1327
40 * 2012-05-25: removed CRC-1/PARITY-EVEN, CRC-1/PARITY-ODD
41 * 2012-04-12: added model CRC-31/PHILIPS
42 * 2012-02-20: corrected model CRC-6/DARC
43 * 2011-08-28: added model CRC-64/XZ
44 * 2011-04-30: added models CRC-16/TMS37157 and CRC-A, and alias CRC-B
45 * 2011-02-10: made preset models ANSI C compliant
46 * 2011-01-17: fixed ANSI C warnings (except preset models)
47 * 2011-01-01: added mbynum(), mcount()
48 * 2010-12-26: renamed CRC RevEng
49 * 2010-12-18: minor change to mtostr() output format
50 * 2010-12-15: added mcmp(), mmatch()
51 * 2010-12-14: finished mbynam(), mnames()
52 * 2010-12-13: restarted with PCONST macros
53 * 2010-12-12: was having so much fun I didn't think to try compiling. :(
54 * 2010-12-12: started models.c
63 /* Private declarations */
65 /* incomplete type declaration to permit cross-reference */
69 const unsigned long width
; /* width of CRC algorithm */
70 const bmp_t
*const bspoly
; /* polynomial with highest-order term removed. length determines CRC width */
71 const bmp_t
*const binit
; /* initial register value. length == poly.length */
72 const int flags
; /* P_REFIN and P_REFOUT indicate reflected input/output */
73 const bmp_t
*const bxorout
; /* final register XOR mask. length == poly.length */
74 const bmp_t
*const bcheck
; /* optional check value, the CRC of the UTF-8 string "123456789" */
75 const struct malias
*const alias
; /* optional canonical name of the model */
79 const char *name
; /* name of alias */
80 const struct mpreset
*const model
; /* corresponding model */
85 # error config.h: BMP_BIT must be an integer constant macro to compile presets
88 /* Big polynomial constants. */
90 /* Directives for relink.pl */
91 /* CONSTANT b40 = (40, 0x0004820009) */
92 /* CONSTANT b40a = (40, 0xffffffffff) */
93 /* CONSTANT b40b = (40, 0xd4164fc646) */
94 /* CONSTANT b64 = (64, 0x42f0e1eba9ea3693) */
95 /* CONSTANT b64a = (64, 0x6c40df5f0b497347) */
96 /* CONSTANT b64b = (64, 0xffffffffffffffff) */
97 /* CONSTANT b64c = (64, 0x62ec59e3f1a4f00a) */
98 /* CONSTANT b64d = (64, 0x995dc9bbdf1939fa) */
99 /* CONSTANT b82 = (82, 0x0308c0111011401440411) */
100 /* CONSTANT b82a = (82, 0x09ea83f625023801fd612) */
102 /* The next section was generated by relink.pl from the directives above. */
104 /* DO NOT EDIT the section below, INCLUDING the next comment. */
105 /* BEGIN AUTO-GENERATED CONSTANTS */
107 static const bmp_t b40
[] = {
108 BMP_C(0x0004820009) << (BMP_BIT
- 40),
110 static const bmp_t b40a
[] = {
111 BMP_C(0xffffffffff) << (BMP_BIT
- 40),
113 static const bmp_t b40b
[] = {
114 BMP_C(0xd4164fc646) << (BMP_BIT
- 40),
117 static const bmp_t b40
[] = {
118 BMP_C(0x00048200) << (BMP_BIT
- 32) | BMP_C(0x04) >> (39 - BMP_BIT
),
119 BMP_C(0x09) << (BMP_BIT
* 2 - 40),
121 static const bmp_t b40a
[] = {
122 BMP_C(0xffffffff) << (BMP_BIT
- 32) | BMP_C(0x7f) >> (39 - BMP_BIT
),
123 BMP_C(0xff) << (BMP_BIT
* 2 - 40),
125 static const bmp_t b40b
[] = {
126 BMP_C(0xd4164fc6) << (BMP_BIT
- 32) | BMP_C(0x23) >> (39 - BMP_BIT
),
127 BMP_C(0x46) << (BMP_BIT
* 2 - 40),
129 # endif /* BMP_BIT */
132 static const bmp_t b64
[] = {
133 BMP_C(0x42f0e1eba9ea3693) << (BMP_BIT
- 64),
135 static const bmp_t b64a
[] = {
136 BMP_C(0x6c40df5f0b497347) << (BMP_BIT
- 64),
138 static const bmp_t b64b
[] = {
139 BMP_C(0xffffffffffffffff) << (BMP_BIT
- 64),
141 static const bmp_t b64c
[] = {
142 BMP_C(0x62ec59e3f1a4f00a) << (BMP_BIT
- 64),
144 static const bmp_t b64d
[] = {
145 BMP_C(0x995dc9bbdf1939fa) << (BMP_BIT
- 64),
148 static const bmp_t b64
[] = {
149 BMP_C(0x42f0e1eb) << (BMP_BIT
- 32) | BMP_C(0x54f51b49) >> (63 - BMP_BIT
),
150 BMP_C(0xa9ea3693) << (BMP_BIT
* 2 - 64),
152 static const bmp_t b64a
[] = {
153 BMP_C(0x6c40df5f) << (BMP_BIT
- 32) | BMP_C(0x05a4b9a3) >> (63 - BMP_BIT
),
154 BMP_C(0x0b497347) << (BMP_BIT
* 2 - 64),
156 static const bmp_t b64b
[] = {
157 BMP_C(0xffffffff) << (BMP_BIT
- 32) | BMP_C(0x7fffffff) >> (63 - BMP_BIT
),
158 BMP_C(0xffffffff) << (BMP_BIT
* 2 - 64),
160 static const bmp_t b64c
[] = {
161 BMP_C(0x62ec59e3) << (BMP_BIT
- 32) | BMP_C(0x78d27805) >> (63 - BMP_BIT
),
162 BMP_C(0xf1a4f00a) << (BMP_BIT
* 2 - 64),
164 static const bmp_t b64d
[] = {
165 BMP_C(0x995dc9bb) << (BMP_BIT
- 32) | BMP_C(0x6f8c9cfd) >> (63 - BMP_BIT
),
166 BMP_C(0xdf1939fa) << (BMP_BIT
* 2 - 64),
168 # endif /* BMP_BIT */
171 static const bmp_t b82
[] = {
172 BMP_C(0x0308c0111011401440411) << (BMP_BIT
- 82),
174 static const bmp_t b82a
[] = {
175 BMP_C(0x09ea83f625023801fd612) << (BMP_BIT
- 82),
178 static const bmp_t b82
[] = {
179 BMP_C(0x01846008880) << (BMP_BIT
- 41) | BMP_C(0x08a00a20208) >> (81 - BMP_BIT
),
180 BMP_C(0x11401440411) << (BMP_BIT
* 2 - 82),
182 static const bmp_t b82a
[] = {
183 BMP_C(0x04f541fb128) << (BMP_BIT
- 41) | BMP_C(0x011c00feb09) >> (81 - BMP_BIT
),
184 BMP_C(0x023801fd612) << (BMP_BIT
* 2 - 82),
187 static const bmp_t b82
[] = {
188 BMP_C(0x0c230044) << (BMP_BIT
- 32) | BMP_C(0x040) >> (40 - BMP_BIT
),
189 BMP_C(0x40450051) << (BMP_BIT
* 2 - 64) | BMP_C(0x00104) >> (80 - BMP_BIT
* 2),
190 BMP_C(0x00411) << (BMP_BIT
* 3 - 82),
192 static const bmp_t b82a
[] = {
193 BMP_C(0x27aa0fd8) << (BMP_BIT
- 32) | BMP_C(0x094) >> (40 - BMP_BIT
),
194 BMP_C(0x9408e007) << (BMP_BIT
* 2 - 64) | BMP_C(0x0f584) >> (80 - BMP_BIT
* 2),
195 BMP_C(0x3d612) << (BMP_BIT
* 3 - 82),
197 # endif /* BMP_BIT */
199 /* END AUTO-GENERATED CONSTANTS */
200 /* DO NOT EDIT the section above, INCLUDING the previous comment. */
202 /* Array of the polynomial bitmaps used in the model table. */
203 static const bmp_t b32
[] = {
204 BMP_C(0x00000000) << (BMP_BIT
- 32), /* 0 -- 5, 00 */
205 BMP_C(0x000000af) << (BMP_BIT
- 32), /* 1 -- 32,000000af */
206 BMP_C(0x00010000) << (BMP_BIT
- 32), /* 2 -- 16, 0001 */
207 BMP_C(0x00020000) << (BMP_BIT
- 32), /* 3 -- 15, 0001 */
208 BMP_C(0x00065b00) << (BMP_BIT
- 32), /* 4 -- 24, 00065b */
209 BMP_C(0x007e0000) << (BMP_BIT
- 32), /* 5 -- 16, 007e */
210 BMP_C(0x007f0000) << (BMP_BIT
- 32), /* 6 -- 16, 007f */
211 BMP_C(0x03400000) << (BMP_BIT
- 32), /* 7 -- 11, 01a */
212 BMP_C(0x0376e6e7) << (BMP_BIT
- 32), /* 8 -- 32,0376e6e7 */
213 BMP_C(0x04c11db7) << (BMP_BIT
- 32), /* 9 -- 32,04c11db7 */
214 BMP_C(0x05890000) << (BMP_BIT
- 32), /* 10 -- 16, 0589 */
215 BMP_C(0x07000000) << (BMP_BIT
- 32), /* 11 -- 8, 07 */
216 BMP_C(0x09823b6e) << (BMP_BIT
- 32), /* 12 -- 31,04c11db7 */
217 BMP_C(0x0b3c0000) << (BMP_BIT
- 32), /* 13 -- 15, 059e */
218 BMP_C(0x0c000000) << (BMP_BIT
- 32), /* 14 -- 6, 03 */
219 BMP_C(0x0c200000) << (BMP_BIT
- 32), /* 15 -- 11, 061 */
220 BMP_C(0x0fb30000) << (BMP_BIT
- 32), /* 16 -- 16, 0fb3 */
221 BMP_C(0x10210000) << (BMP_BIT
- 32), /* 17 -- 16, 1021 */
222 BMP_C(0x12000000) << (BMP_BIT
- 32), /* 18 -- 7, 09 */
223 BMP_C(0x130d2afc) << (BMP_BIT
- 32), /* 19 -- 30,04c34abf */
224 BMP_C(0x15000000) << (BMP_BIT
- 32), /* 20 -- 8, 15 */
225 BMP_C(0x1697d06a) << (BMP_BIT
- 32), /* 21 -- 32,1697d06a */
226 BMP_C(0x18000000) << (BMP_BIT
- 32), /* 22 -- 6, 06 */
227 BMP_C(0x19d3c8d8) << (BMP_BIT
- 32), /* 23 -- 31,0ce9e46c */
228 BMP_C(0x1c000000) << (BMP_BIT
- 32), /* 24 -- 6, 07 */
229 BMP_C(0x1d000000) << (BMP_BIT
- 32), /* 25 -- 8, 1d */
230 BMP_C(0x1d0f0000) << (BMP_BIT
- 32), /* 26 -- 16, 1d0f */
231 BMP_C(0x1dcf0000) << (BMP_BIT
- 32), /* 27 -- 16, 1dcf */
232 BMP_C(0x1edc6f41) << (BMP_BIT
- 32), /* 28 -- 32,1edc6f41 */
233 BMP_C(0x1f23b800) << (BMP_BIT
- 32), /* 29 -- 24, 1f23b8 */
234 BMP_C(0x20140000) << (BMP_BIT
- 32), /* 30 -- 14, 0805 */
235 BMP_C(0x20b40000) << (BMP_BIT
- 32), /* 31 -- 14, 082d */
236 BMP_C(0x20fe0000) << (BMP_BIT
- 32), /* 32 -- 16, 20fe */
237 BMP_C(0x21890000) << (BMP_BIT
- 32), /* 33 -- 16, 2189 */
238 BMP_C(0x21cf0200) << (BMP_BIT
- 32), /* 34 -- 24, 21cf02 */
239 BMP_C(0x23ef5200) << (BMP_BIT
- 32), /* 35 -- 24, 23ef52 */
240 BMP_C(0x25000000) << (BMP_BIT
- 32), /* 36 -- 8, 25 */
241 BMP_C(0x26b10000) << (BMP_BIT
- 32), /* 37 -- 16, 26b1 */
242 BMP_C(0x27d00000) << (BMP_BIT
- 32), /* 38 -- 13, 04fa */
243 BMP_C(0x28000000) << (BMP_BIT
- 32), /* 39 -- 5, 05 */
244 BMP_C(0x29b10000) << (BMP_BIT
- 32), /* 40 -- 16, 29b1 */
245 BMP_C(0x2f000000) << (BMP_BIT
- 32), /* 41 -- 8, 2f */
246 BMP_C(0x30000000) << (BMP_BIT
- 32), /* 42 -- 4, 3 */
247 BMP_C(0x3010bf7f) << (BMP_BIT
- 32), /* 43 -- 32,3010bf7f */
248 BMP_C(0x31000000) << (BMP_BIT
- 32), /* 44 -- 8, 31 */
249 BMP_C(0x31c30000) << (BMP_BIT
- 32), /* 45 -- 16, 31c3 */
250 BMP_C(0x328b6300) << (BMP_BIT
- 32), /* 46 -- 24, 328b63 */
251 BMP_C(0x34000000) << (BMP_BIT
- 32), /* 47 -- 6, 0d */
252 BMP_C(0x340bc6d9) << (BMP_BIT
- 32), /* 48 -- 32,340bc6d9 */
253 BMP_C(0x38000000) << (BMP_BIT
- 32), /* 49 -- 5, 07 */
254 BMP_C(0x39000000) << (BMP_BIT
- 32), /* 50 -- 8, 39 */
255 BMP_C(0x3d650000) << (BMP_BIT
- 32), /* 51 -- 16, 3d65 */
256 BMP_C(0x3e000000) << (BMP_BIT
- 32), /* 52 -- 8, 3e */
257 BMP_C(0x44c20000) << (BMP_BIT
- 32), /* 53 -- 16, 44c2 */
258 BMP_C(0x48000000) << (BMP_BIT
- 32), /* 54 -- 5, 09 */
259 BMP_C(0x4acc0000) << (BMP_BIT
- 32), /* 55 -- 15, 2566 */
260 BMP_C(0x4b000000) << (BMP_BIT
- 32), /* 56 -- 8, 4b */
261 BMP_C(0x4b370000) << (BMP_BIT
- 32), /* 57 -- 16, 4b37 */
262 BMP_C(0x4c060000) << (BMP_BIT
- 32), /* 58 -- 16, 4c06 */
263 BMP_C(0x55000000) << (BMP_BIT
- 32), /* 59 -- 8, 55 */
264 BMP_C(0x55555500) << (BMP_BIT
- 32), /* 60 -- 24, 555555 */
265 BMP_C(0x59350000) << (BMP_BIT
- 32), /* 61 -- 16, 5935 */
266 BMP_C(0x5d380000) << (BMP_BIT
- 32), /* 62 -- 16, 5d38 */
267 BMP_C(0x5d6dcb00) << (BMP_BIT
- 32), /* 63 -- 24, 5d6dcb */
268 BMP_C(0x60000000) << (BMP_BIT
- 32), /* 64 -- 3, 3 */
269 BMP_C(0x60e00000) << (BMP_BIT
- 32), /* 65 -- 11, 307 */
270 BMP_C(0x63d00000) << (BMP_BIT
- 32), /* 66 -- 16, 63d0 */
271 BMP_C(0x64000000) << (BMP_BIT
- 32), /* 67 -- 6, 19 */
272 BMP_C(0x66400000) << (BMP_BIT
- 32), /* 68 -- 10, 199 */
273 BMP_C(0x6f630000) << (BMP_BIT
- 32), /* 69 -- 16, 6f63 */
274 BMP_C(0x6f910000) << (BMP_BIT
- 32), /* 70 -- 16, 6f91 */
275 BMP_C(0x70000000) << (BMP_BIT
- 32), /* 71 -- 4, 7 */
276 BMP_C(0x70a00000) << (BMP_BIT
- 32), /* 72 -- 11, 385 */
277 BMP_C(0x755b0000) << (BMP_BIT
- 32), /* 73 -- 16, 755b */
278 BMP_C(0x765e7680) << (BMP_BIT
- 32), /* 74 -- 32,765e7680 */
279 BMP_C(0x7979bd00) << (BMP_BIT
- 32), /* 75 -- 24, 7979bd */
280 BMP_C(0x7e000000) << (BMP_BIT
- 32), /* 76 -- 8, 7e */
281 BMP_C(0x80006300) << (BMP_BIT
- 32), /* 77 -- 24, 800063 */
282 BMP_C(0x80050000) << (BMP_BIT
- 32), /* 78 -- 16, 8005 */
283 BMP_C(0x800d0000) << (BMP_BIT
- 32), /* 79 -- 16, 800d */
284 BMP_C(0x80c2e71c) << (BMP_BIT
- 32), /* 80 -- 30,2030b9c7 */
285 BMP_C(0x80f00000) << (BMP_BIT
- 32), /* 81 -- 12, 80f */
286 BMP_C(0x814141ab) << (BMP_BIT
- 32), /* 82 -- 32,814141ab */
287 BMP_C(0x864cfb00) << (BMP_BIT
- 32), /* 83 -- 24, 864cfb */
288 BMP_C(0x87315576) << (BMP_BIT
- 32), /* 84 -- 32,87315576 */
289 BMP_C(0x89ec0000) << (BMP_BIT
- 32), /* 85 -- 16, 89ec */
290 BMP_C(0x8a000000) << (BMP_BIT
- 32), /* 86 -- 7, 45 */
291 BMP_C(0x8b320000) << (BMP_BIT
- 32), /* 87 -- 15, 4599 */
292 BMP_C(0x8bb70000) << (BMP_BIT
- 32), /* 88 -- 16, 8bb7 */
293 BMP_C(0x8cc00000) << (BMP_BIT
- 32), /* 89 -- 10, 233 */
294 BMP_C(0x906e0000) << (BMP_BIT
- 32), /* 90 -- 16, 906e */
295 BMP_C(0x97000000) << (BMP_BIT
- 32), /* 91 -- 8, 97 */
296 BMP_C(0x98000000) << (BMP_BIT
- 32), /* 92 -- 6, 26 */
297 BMP_C(0x9b000000) << (BMP_BIT
- 32), /* 93 -- 8, 9b */
298 BMP_C(0x9c000000) << (BMP_BIT
- 32), /* 94 -- 6, 27 */
299 BMP_C(0x9e000000) << (BMP_BIT
- 32), /* 95 -- 7, 4f */
300 BMP_C(0x9ecf0000) << (BMP_BIT
- 32), /* 96 -- 16, 9ecf */
301 BMP_C(0xa0970000) << (BMP_BIT
- 32), /* 97 -- 16, a097 */
302 BMP_C(0xa1000000) << (BMP_BIT
- 32), /* 98 -- 8, a1 */
303 BMP_C(0xa6000000) << (BMP_BIT
- 32), /* 99 -- 7, 53 */
304 BMP_C(0xa8000000) << (BMP_BIT
- 32), /* 100 -- 5, 15 */
305 BMP_C(0xa8190000) << (BMP_BIT
- 32), /* 101 -- 16, a819 */
306 BMP_C(0xa833982b) << (BMP_BIT
- 32), /* 102 -- 32,a833982b */
307 BMP_C(0xabcdef00) << (BMP_BIT
- 32), /* 103 -- 24, abcdef */
308 BMP_C(0xaee70000) << (BMP_BIT
- 32), /* 104 -- 16, aee7 */
309 BMP_C(0xb0000000) << (BMP_BIT
- 32), /* 105 -- 4, b */
310 BMP_C(0xb2aa0000) << (BMP_BIT
- 32), /* 106 -- 16, b2aa */
311 BMP_C(0xb4600000) << (BMP_BIT
- 32), /* 107 -- 11, 5a3 */
312 BMP_C(0xb4c80000) << (BMP_BIT
- 32), /* 108 -- 16, b4c8 */
313 BMP_C(0xb4f3e600) << (BMP_BIT
- 32), /* 109 -- 24, b4f3e6 */
314 BMP_C(0xb704ce00) << (BMP_BIT
- 32), /* 110 -- 24, b704ce */
315 BMP_C(0xbb3d0000) << (BMP_BIT
- 32), /* 111 -- 16, bb3d */
316 BMP_C(0xbc000000) << (BMP_BIT
- 32), /* 112 -- 8, bc */
317 BMP_C(0xbd0be338) << (BMP_BIT
- 32), /* 113 -- 32,bd0be338 */
318 BMP_C(0xbdf40000) << (BMP_BIT
- 32), /* 114 -- 16, bdf4 */
319 BMP_C(0xbf050000) << (BMP_BIT
- 32), /* 115 -- 16, bf05 */
320 BMP_C(0xc0000000) << (BMP_BIT
- 32), /* 116 -- 3, 6 */
321 BMP_C(0xc2000000) << (BMP_BIT
- 32), /* 117 -- 7, 61 */
322 BMP_C(0xc25a5600) << (BMP_BIT
- 32), /* 118 -- 24, c25a56 */
323 BMP_C(0xc2b70000) << (BMP_BIT
- 32), /* 119 -- 16, c2b7 */
324 BMP_C(0xc6c60000) << (BMP_BIT
- 32), /* 120 -- 16, c6c6 */
325 BMP_C(0xc8000000) << (BMP_BIT
- 32), /* 121 -- 5, 19 */
326 BMP_C(0xc8670000) << (BMP_BIT
- 32), /* 122 -- 16, c867 */
327 BMP_C(0xcbf43926) << (BMP_BIT
- 32), /* 123 -- 32,cbf43926 */
328 BMP_C(0xcde70300) << (BMP_BIT
- 32), /* 124 -- 24, cde703 */
329 BMP_C(0xd0000000) << (BMP_BIT
- 32), /* 125 -- 8, d0 */
330 BMP_C(0xd02a0000) << (BMP_BIT
- 32), /* 126 -- 15, 6815 */
331 BMP_C(0xd0db0000) << (BMP_BIT
- 32), /* 127 -- 16, d0db */
332 BMP_C(0xd4d00000) << (BMP_BIT
- 32), /* 128 -- 12, d4d */
333 BMP_C(0xd5000000) << (BMP_BIT
- 32), /* 129 -- 8, d5 */
334 BMP_C(0xd64e0000) << (BMP_BIT
- 32), /* 130 -- 16, d64e */
335 BMP_C(0xda000000) << (BMP_BIT
- 32), /* 131 -- 8, da */
336 BMP_C(0xdaf00000) << (BMP_BIT
- 32), /* 132 -- 12, daf */
337 BMP_C(0xdf000000) << (BMP_BIT
- 32), /* 133 -- 8, df */
338 BMP_C(0xe0000000) << (BMP_BIT
- 32), /* 134 -- 3, 7 */
339 BMP_C(0xe3069283) << (BMP_BIT
- 32), /* 135 -- 32,e3069283 */
340 BMP_C(0xe5cc0000) << (BMP_BIT
- 32), /* 136 -- 16, e5cc */
341 BMP_C(0xe7a80000) << (BMP_BIT
- 32), /* 137 -- 13, 1cf5 */
342 BMP_C(0xea000000) << (BMP_BIT
- 32), /* 138 -- 7, 75 */
343 BMP_C(0xea820000) << (BMP_BIT
- 32), /* 139 -- 16, ea82 */
344 BMP_C(0xec000000) << (BMP_BIT
- 32), /* 140 -- 6, 3b */
345 BMP_C(0xf0000000) << (BMP_BIT
- 32), /* 141 -- 4, f */
346 BMP_C(0xf1300000) << (BMP_BIT
- 32), /* 142 -- 12, f13 */
347 BMP_C(0xf4000000) << (BMP_BIT
- 32), /* 143 -- 8, f4 */
348 BMP_C(0xf4acfb13) << (BMP_BIT
- 32), /* 144 -- 32,f4acfb13 */
349 BMP_C(0xf5b00000) << (BMP_BIT
- 32), /* 145 -- 12, f5b */
350 BMP_C(0xf6400000) << (BMP_BIT
- 32), /* 146 -- 10, 3d9 */
351 BMP_C(0xf8000000) << (BMP_BIT
- 32), /* 147 -- 5, 1f */
352 BMP_C(0xfc000000) << (BMP_BIT
- 32), /* 148 -- 6, 3f */
353 BMP_C(0xfc891918) << (BMP_BIT
- 32), /* 149 -- 32,fc891918 */
354 BMP_C(0xfd000000) << (BMP_BIT
- 32), /* 150 -- 8, fd */
355 BMP_C(0xfe000000) << (BMP_BIT
- 32), /* 151 -- 7, 7f */
356 BMP_C(0xfedcba00) << (BMP_BIT
- 32), /* 152 -- 24, fedcba */
357 BMP_C(0xfee80000) << (BMP_BIT
- 32), /* 153 -- 16, fee8 */
358 BMP_C(0xff000000) << (BMP_BIT
- 32), /* 154 -- 8, ff */
359 BMP_C(0xffc00000) << (BMP_BIT
- 32), /* 155 -- 10, 3ff */
360 BMP_C(0xfff00000) << (BMP_BIT
- 32), /* 156 -- 12, fff */
361 BMP_C(0xffff0000) << (BMP_BIT
- 32), /* 157 -- 16, ffff */
362 BMP_C(0xffffff00) << (BMP_BIT
- 32), /* 158 -- 24, ffffff */
363 BMP_C(0xfffffffc) << (BMP_BIT
- 32), /* 159 -- 30,3fffffff */
364 BMP_C(0xfffffffe) << (BMP_BIT
- 32), /* 160 -- 31,7fffffff */
365 BMP_C(0xffffffff) << (BMP_BIT
- 32), /* 161 -- 32,ffffffff */
368 static const struct malias aliases
[];
370 /* Table of preset CRC models.
371 * Sorted by left-justified polynomial for bsearch().
373 static const struct mpreset models
[] = {
374 {32UL, b32
+ 1, 0, P_BE
, 0, b32
+113, aliases
+123}, /* 0 */
375 {40UL, b40
, 0, P_BE
, b40a
, b40b
, aliases
+ 80}, /* 1 */
376 {24UL, b32
+ 4, b32
+ 60, P_LE
, 0, b32
+118, aliases
+ 54}, /* 2 */
377 {32UL, b32
+ 9, 0, P_BE
, b32
+161, b32
+ 74, aliases
+ 74}, /* 3 */
378 {32UL, b32
+ 9, b32
+161, P_BE
, 0, b32
+ 8, aliases
+ 73}, /* 4 */
379 {32UL, b32
+ 9, b32
+161, P_BE
, b32
+161, b32
+149, aliases
+ 68}, /* 5 */
380 {32UL, b32
+ 9, b32
+161, P_LE
, 0, b32
+ 48, aliases
+115}, /* 6 */
381 {32UL, b32
+ 9, b32
+161, P_LE
, b32
+161, b32
+123, aliases
+ 64}, /* 7 */
382 {16UL, b32
+ 10, 0, P_BE
, 0, b32
+ 6, aliases
+ 28}, /* 8 */
383 {16UL, b32
+ 10, 0, P_BE
, b32
+ 2, b32
+ 5, aliases
+ 27}, /* 9 */
384 { 8UL, b32
+ 11, 0, P_BE
, 0, b32
+143, aliases
+ 94}, /* 10 */
385 { 8UL, b32
+ 11, 0, P_BE
, b32
+ 59, b32
+ 98, aliases
+102}, /* 11 */
386 { 8UL, b32
+ 11, b32
+154, P_LE
, 0, b32
+125, aliases
+106}, /* 12 */
387 {31UL, b32
+ 12, b32
+160, P_BE
, b32
+160, b32
+ 23, aliases
+ 63}, /* 13 */
388 { 6UL, b32
+ 14, 0, P_LE
, 0, b32
+ 22, aliases
+ 87}, /* 14 */
389 {82UL, b82
, 0, P_LE
, 0, b82a
, aliases
+109}, /* 15 */
390 {16UL, b32
+ 17, 0, P_BE
, 0, b32
+ 45, aliases
+124}, /* 16 */
391 {16UL, b32
+ 17, 0, P_LE
, 0, b32
+ 33, aliases
+116}, /* 17 */
392 {16UL, b32
+ 17, b32
+ 26, P_BE
, 0, b32
+136, aliases
+ 18}, /* 18 */
393 {16UL, b32
+ 17, b32
+ 85, P_LE
, 0, b32
+ 37, aliases
+ 49}, /* 19 */
394 {16UL, b32
+ 17, b32
+106, P_LE
, 0, b32
+ 66, aliases
+ 45}, /* 20 */
395 {16UL, b32
+ 17, b32
+120, P_LE
, 0, b32
+115, aliases
+110}, /* 21 */
396 {16UL, b32
+ 17, b32
+157, P_BE
, 0, b32
+ 40, aliases
+ 21}, /* 22 */
397 {16UL, b32
+ 17, b32
+157, P_BE
, b32
+157, b32
+130, aliases
+ 32}, /* 23 */
398 {16UL, b32
+ 17, b32
+157, P_LE
, 0, b32
+ 70, aliases
+ 41}, /* 24 */
399 {16UL, b32
+ 17, b32
+157, P_LE
, b32
+157, b32
+ 90, aliases
+120}, /* 25 */
400 { 7UL, b32
+ 18, 0, P_BE
, 0, b32
+138, aliases
+ 91}, /* 26 */
401 { 6UL, b32
+ 24, b32
+148, P_BE
, 0, b32
+140, aliases
+ 85}, /* 27 */
402 { 8UL, b32
+ 25, b32
+150, P_BE
, 0, b32
+ 76, aliases
+101}, /* 28 */
403 { 8UL, b32
+ 25, b32
+154, P_BE
, b32
+154, b32
+ 56, aliases
+107}, /* 29 */
404 { 8UL, b32
+ 25, b32
+154, P_LE
, 0, b32
+ 91, aliases
+100}, /* 30 */
405 {16UL, b32
+ 27, b32
+157, P_BE
, b32
+157, b32
+101, aliases
+ 44}, /* 31 */
406 {32UL, b32
+ 28, b32
+161, P_LE
, b32
+161, b32
+135, aliases
+ 75}, /* 32 */
407 {14UL, b32
+ 30, 0, P_LE
, 0, b32
+ 31, aliases
+ 12}, /* 33 */
408 { 5UL, b32
+ 39, b32
+147, P_LE
, b32
+147, b32
+121, aliases
+ 83}, /* 34 */
409 { 8UL, b32
+ 41, 0, P_BE
, 0, b32
+ 52, aliases
+105}, /* 35 */
410 { 8UL, b32
+ 41, b32
+154, P_BE
, b32
+154, b32
+133, aliases
+ 96}, /* 36 */
411 { 4UL, b32
+ 42, 0, P_LE
, 0, b32
+ 71, aliases
+ 79}, /* 37 */
412 { 4UL, b32
+ 42, b32
+141, P_BE
, b32
+141, b32
+105, aliases
+ 78}, /* 38 */
413 { 8UL, b32
+ 44, 0, P_LE
, 0, b32
+ 98, aliases
+104}, /* 39 */
414 {24UL, b32
+ 46, b32
+158, P_BE
, b32
+158, b32
+109, aliases
+ 57}, /* 40 */
415 { 8UL, b32
+ 50, 0, P_LE
, 0, b32
+ 20, aliases
+ 98}, /* 41 */
416 {16UL, b32
+ 51, 0, P_BE
, b32
+157, b32
+119, aliases
+ 30}, /* 42 */
417 {16UL, b32
+ 51, 0, P_LE
, b32
+157, b32
+139, aliases
+ 29}, /* 43 */
418 {64UL, b64
, 0, P_BE
, 0, b64a
, aliases
+ 88}, /* 44 */
419 {64UL, b64
, b64b
, P_BE
, b64b
, b64c
, aliases
+ 89}, /* 45 */
420 {64UL, b64
, b64b
, P_LE
, b64b
, b64d
, aliases
+ 90}, /* 46 */
421 { 5UL, b32
+ 54, b32
+ 54, P_BE
, 0, b32
+ 0, aliases
+ 81}, /* 47 */
422 {16UL, b32
+ 61, 0, P_BE
, 0, b32
+ 62, aliases
+ 42}, /* 48 */
423 {24UL, b32
+ 63, b32
+103, P_BE
, 0, b32
+ 29, aliases
+ 56}, /* 49 */
424 {24UL, b32
+ 63, b32
+152, P_BE
, 0, b32
+ 75, aliases
+ 55}, /* 50 */
425 { 3UL, b32
+ 64, b32
+134, P_LE
, 0, b32
+116, aliases
+ 61}, /* 51 */
426 {11UL, b32
+ 65, 0, P_BE
, 0, b32
+ 15, aliases
+ 6}, /* 52 */
427 { 6UL, b32
+ 67, 0, P_LE
, 0, b32
+ 92, aliases
+ 86}, /* 53 */
428 {16UL, b32
+ 69, 0, P_BE
, 0, b32
+114, aliases
+ 38}, /* 54 */
429 {11UL, b32
+ 72, b32
+ 7, P_BE
, 0, b32
+107, aliases
+ 5}, /* 55 */
430 {16UL, b32
+ 73, 0, P_BE
, 0, b32
+ 32, aliases
+ 43}, /* 56 */
431 {24UL, b32
+ 77, 0, P_BE
, 0, b32
+ 35, aliases
+ 59}, /* 57 */
432 {16UL, b32
+ 78, 0, P_BE
, 0, b32
+153, aliases
+ 19}, /* 58 */
433 {16UL, b32
+ 78, 0, P_LE
, 0, b32
+111, aliases
+ 0}, /* 59 */
434 {16UL, b32
+ 78, 0, P_LE
, b32
+157, b32
+ 53, aliases
+ 40}, /* 60 */
435 {16UL, b32
+ 78, b32
+ 79, P_BE
, 0, b32
+ 96, aliases
+ 26}, /* 61 */
436 {16UL, b32
+ 78, b32
+157, P_BE
, 0, b32
+104, aliases
+ 24}, /* 62 */
437 {16UL, b32
+ 78, b32
+157, P_LE
, 0, b32
+ 57, aliases
+117}, /* 63 */
438 {16UL, b32
+ 78, b32
+157, P_LE
, b32
+157, b32
+108, aliases
+ 51}, /* 64 */
439 {30UL, b32
+ 80, b32
+159, P_BE
, b32
+159, b32
+ 19, aliases
+ 62}, /* 65 */
440 {12UL, b32
+ 81, 0, P_BE
, 0, b32
+145, aliases
+ 9}, /* 66 */
441 {12UL, b32
+ 81, 0, P_BELE
, 0, b32
+132, aliases
+ 10}, /* 67 */
442 {32UL, b32
+ 82, 0, P_BE
, 0, b32
+ 43, aliases
+ 77}, /* 68 */
443 {24UL, b32
+ 83, 0, P_BE
, 0, b32
+124, aliases
+ 58}, /* 69 */
444 {24UL, b32
+ 83, b32
+110, P_BE
, 0, b32
+ 34, aliases
+ 53}, /* 70 */
445 { 7UL, b32
+ 86, 0, P_BE
, 0, b32
+117, aliases
+ 93}, /* 71 */
446 {15UL, b32
+ 87, 0, P_BE
, 0, b32
+ 13, aliases
+ 13}, /* 72 */
447 {16UL, b32
+ 88, 0, P_BE
, 0, b32
+127, aliases
+ 47}, /* 73 */
448 {10UL, b32
+ 89, 0, P_BE
, 0, b32
+ 68, aliases
+ 3}, /* 74 */
449 { 8UL, b32
+ 93, 0, P_BE
, 0, b32
+138, aliases
+103}, /* 75 */
450 { 8UL, b32
+ 93, 0, P_LE
, 0, b32
+ 36, aliases
+108}, /* 76 */
451 { 8UL, b32
+ 93, b32
+154, P_BE
, 0, b32
+131, aliases
+ 97}, /* 77 */
452 { 6UL, b32
+ 94, b32
+148, P_BE
, 0, b32
+ 47, aliases
+ 84}, /* 78 */
453 { 7UL, b32
+ 95, b32
+151, P_LE
, 0, b32
+ 99, aliases
+ 92}, /* 79 */
454 {16UL, b32
+ 97, 0, P_BE
, 0, b32
+ 16, aliases
+ 48}, /* 80 */
455 { 5UL, b32
+100, 0, P_LE
, 0, b32
+ 49, aliases
+ 82}, /* 81 */
456 {32UL, b32
+102, b32
+161, P_LE
, b32
+161, b32
+ 84, aliases
+ 76}, /* 82 */
457 {16UL, b32
+122, b32
+157, P_BE
, 0, b32
+ 58, aliases
+ 23}, /* 83 */
458 {15UL, b32
+126, 0, P_BE
, b32
+ 3, b32
+ 55, aliases
+ 14}, /* 84 */
459 { 8UL, b32
+129, 0, P_BE
, 0, b32
+112, aliases
+ 99}, /* 85 */
460 {13UL, b32
+137, 0, P_BE
, 0, b32
+ 38, aliases
+ 11}, /* 86 */
461 {12UL, b32
+142, b32
+156, P_BE
, 0, b32
+128, aliases
+ 8}, /* 87 */
462 {32UL, b32
+144, b32
+161, P_LE
, b32
+161, b32
+ 21, aliases
+ 67}, /* 88 */
463 {10UL, b32
+146, b32
+155, P_BE
, 0, b32
+ 89, aliases
+ 4}, /* 89 */
464 { 0UL, 0, 0, P_BE
, 0, 0, NULL
}, /* terminating entry */
468 /* List of names with pointers to models, pre-sorted for use with bsearch() */
469 static const struct malias aliases
[] = {
470 {"ARC", models
+59}, /* 0 */
471 {"B-CRC-32", models
+ 5}, /* 1 */
472 {"CKSUM", models
+ 3}, /* 2 */
473 {"CRC-10", models
+74}, /* 3 */
474 {"CRC-10/CDMA2000", models
+89}, /* 4 */
475 {"CRC-11", models
+55}, /* 5 */
476 {"CRC-11/UMTS", models
+52}, /* 6 */
477 {"CRC-12/3GPP", models
+67}, /* 7 */
478 {"CRC-12/CDMA2000", models
+87}, /* 8 */
479 {"CRC-12/DECT", models
+66}, /* 9 */
480 {"CRC-12/UMTS", models
+67}, /* 10 */
481 {"CRC-13/BBC", models
+86}, /* 11 */
482 {"CRC-14/DARC", models
+33}, /* 12 */
483 {"CRC-15", models
+72}, /* 13 */
484 {"CRC-15/MPT1327", models
+84}, /* 14 */
485 {"CRC-16", models
+59}, /* 15 */
486 {"CRC-16/ACORN", models
+16}, /* 16 */
487 {"CRC-16/ARC", models
+59}, /* 17 */
488 {"CRC-16/AUG-CCITT", models
+18}, /* 18 */
489 {"CRC-16/BUYPASS", models
+58}, /* 19 */
490 {"CRC-16/CCITT", models
+17}, /* 20 */
491 {"CRC-16/CCITT-FALSE", models
+22}, /* 21 */
492 {"CRC-16/CCITT-TRUE", models
+17}, /* 22 */
493 {"CRC-16/CDMA2000", models
+83}, /* 23 */
494 {"CRC-16/CMS", models
+62}, /* 24 */
495 {"CRC-16/DARC", models
+23}, /* 25 */
496 {"CRC-16/DDS-110", models
+61}, /* 26 */
497 {"CRC-16/DECT-R", models
+ 9}, /* 27 */
498 {"CRC-16/DECT-X", models
+ 8}, /* 28 */
499 {"CRC-16/DNP", models
+43}, /* 29 */
500 {"CRC-16/EN-13757", models
+42}, /* 30 */
501 {"CRC-16/EPC", models
+23}, /* 31 */
502 {"CRC-16/GENIBUS", models
+23}, /* 32 */
503 {"CRC-16/I-CODE", models
+23}, /* 33 */
504 {"CRC-16/IBM-SDLC", models
+25}, /* 34 */
505 {"CRC-16/IEC-61158-2", models
+31}, /* 35 */
506 {"CRC-16/ISO-HDLC", models
+25}, /* 36 */
507 {"CRC-16/LHA", models
+59}, /* 37 */
508 {"CRC-16/LJ1200", models
+54}, /* 38 */
509 {"CRC-16/LTE", models
+16}, /* 39 */
510 {"CRC-16/MAXIM", models
+60}, /* 40 */
511 {"CRC-16/MCRF4XX", models
+24}, /* 41 */
512 {"CRC-16/OPENSAFETY-A", models
+48}, /* 42 */
513 {"CRC-16/OPENSAFETY-B", models
+56}, /* 43 */
514 {"CRC-16/PROFIBUS", models
+31}, /* 44 */
515 {"CRC-16/RIELLO", models
+20}, /* 45 */
516 {"CRC-16/SPI-FUJITSU", models
+18}, /* 46 */
517 {"CRC-16/T10-DIF", models
+73}, /* 47 */
518 {"CRC-16/TELEDISK", models
+80}, /* 48 */
519 {"CRC-16/TMS37157", models
+19}, /* 49 */
520 {"CRC-16/UMTS", models
+58}, /* 50 */
521 {"CRC-16/USB", models
+64}, /* 51 */
522 {"CRC-16/VERIFONE", models
+58}, /* 52 */
523 {"CRC-24", models
+70}, /* 53 */
524 {"CRC-24/BLE", models
+ 2}, /* 54 */
525 {"CRC-24/FLEXRAY-A", models
+50}, /* 55 */
526 {"CRC-24/FLEXRAY-B", models
+49}, /* 56 */
527 {"CRC-24/INTERLAKEN", models
+40}, /* 57 */
528 {"CRC-24/LTE-A", models
+69}, /* 58 */
529 {"CRC-24/LTE-B", models
+57}, /* 59 */
530 {"CRC-24/OPENPGP", models
+70}, /* 60 */
531 {"CRC-3/ROHC", models
+51}, /* 61 */
532 {"CRC-30/CDMA", models
+65}, /* 62 */
533 {"CRC-31/PHILIPS", models
+13}, /* 63 */
534 {"CRC-32", models
+ 7}, /* 64 */
535 {"CRC-32/AAL5", models
+ 5}, /* 65 */
536 {"CRC-32/ADCCP", models
+ 7}, /* 66 */
537 {"CRC-32/AUTOSAR", models
+88}, /* 67 */
538 {"CRC-32/BZIP2", models
+ 5}, /* 68 */
539 {"CRC-32/CASTAGNOLI", models
+32}, /* 69 */
540 {"CRC-32/DECT-B", models
+ 5}, /* 70 */
541 {"CRC-32/INTERLAKEN", models
+32}, /* 71 */
542 {"CRC-32/ISCSI", models
+32}, /* 72 */
543 {"CRC-32/MPEG-2", models
+ 4}, /* 73 */
544 {"CRC-32/POSIX", models
+ 3}, /* 74 */
545 {"CRC-32C", models
+32}, /* 75 */
546 {"CRC-32D", models
+82}, /* 76 */
547 {"CRC-32Q", models
+68}, /* 77 */
548 {"CRC-4/INTERLAKEN", models
+38}, /* 78 */
549 {"CRC-4/ITU", models
+37}, /* 79 */
550 {"CRC-40/GSM", models
+ 1}, /* 80 */
551 {"CRC-5/EPC", models
+47}, /* 81 */
552 {"CRC-5/ITU", models
+81}, /* 82 */
553 {"CRC-5/USB", models
+34}, /* 83 */
554 {"CRC-6/CDMA2000-A", models
+78}, /* 84 */
555 {"CRC-6/CDMA2000-B", models
+27}, /* 85 */
556 {"CRC-6/DARC", models
+53}, /* 86 */
557 {"CRC-6/ITU", models
+14}, /* 87 */
558 {"CRC-64", models
+44}, /* 88 */
559 {"CRC-64/WE", models
+45}, /* 89 */
560 {"CRC-64/XZ", models
+46}, /* 90 */
561 {"CRC-7", models
+26}, /* 91 */
562 {"CRC-7/ROHC", models
+79}, /* 92 */
563 {"CRC-7/UMTS", models
+71}, /* 93 */
564 {"CRC-8", models
+10}, /* 94 */
565 {"CRC-8/AES", models
+30}, /* 95 */
566 {"CRC-8/AUTOSAR", models
+36}, /* 96 */
567 {"CRC-8/CDMA2000", models
+77}, /* 97 */
568 {"CRC-8/DARC", models
+41}, /* 98 */
569 {"CRC-8/DVB-S2", models
+85}, /* 99 */
570 {"CRC-8/EBU", models
+30}, /* 100 */
571 {"CRC-8/I-CODE", models
+28}, /* 101 */
572 {"CRC-8/ITU", models
+11}, /* 102 */
573 {"CRC-8/LTE", models
+75}, /* 103 */
574 {"CRC-8/MAXIM", models
+39}, /* 104 */
575 {"CRC-8/OPENSAFETY", models
+35}, /* 105 */
576 {"CRC-8/ROHC", models
+12}, /* 106 */
577 {"CRC-8/SAE-J1850", models
+29}, /* 107 */
578 {"CRC-8/WCDMA", models
+76}, /* 108 */
579 {"CRC-82/DARC", models
+15}, /* 109 */
580 {"CRC-A", models
+21}, /* 110 */
581 {"CRC-B", models
+25}, /* 111 */
582 {"CRC-CCITT", models
+17}, /* 112 */
583 {"CRC-IBM", models
+59}, /* 113 */
584 {"DOW-CRC", models
+39}, /* 114 */
585 {"JAMCRC", models
+ 6}, /* 115 */
586 {"KERMIT", models
+17}, /* 116 */
587 {"MODBUS", models
+63}, /* 117 */
588 {"PKZIP", models
+ 7}, /* 118 */
589 {"R-CRC-16", models
+ 9}, /* 119 */
590 {"X-25", models
+25}, /* 120 */
591 {"X-CRC-12", models
+66}, /* 121 */
592 {"X-CRC-16", models
+ 8}, /* 122 */
593 {"XFER", models
+ 0}, /* 123 */
594 {"XMODEM", models
+16}, /* 124 */
595 {"ZMODEM", models
+16}, /* 125 */
596 {NULL
, NULL
}, /* terminating entry */
598 # define NALIASES 126
600 # endif /* BMP_BIT */
603 static const struct mpreset models
[] = {
604 { 0UL, 0, 0, P_BE
, 0, 0, NULL
}, /* terminating entry */
608 static const struct malias aliases
[] = {
609 {NULL
, NULL
}, /* terminating entry */
615 static void munpack(model_t
*, const struct mpreset
*);
617 /* copy a parameter of a preset to a poly */
618 #define PUNPACK(poly, preset, field) {\
619 unsigned long iter, idx; \
620 praloc((poly), ((preset)->field ? (preset)->width : 0UL)); \
621 for(iter=0UL, idx=0UL; iter < (poly)->length; iter += BMP_BIT, ++idx) \
622 (poly)->bitmap[idx] = (preset)->field[idx]; \
625 /* copy a parameter of a preset into a model */
626 #define MUNPACK(parm) PUNPACK(&dest->parm, src, b##parm)
631 mbynam(model_t
*dest
, const char *key
) {
632 /* Sets parameters in dest according to the model named by key.
634 size_t left
= 0, right
= NALIASES
, middle
= 0;
640 if(!(ukey
= malloc((size_t) 1 + strlen(key
)))) {
641 uerror("cannot allocate memory for comparison string");
646 *uptr
++ = toupper(*key
);
649 while(left
< right
&& cmp
) {
650 middle
= (left
>> 1) + (right
>> 1);
651 cmp
= strcmp(ukey
, aliases
[middle
].name
);
652 if(cmp
< 0) right
= middle
;
653 else if(cmp
> 0) left
= middle
+ 1;
659 munpack(dest
, aliases
[middle
].model
);
664 mbynum(model_t
*dest
, int num
) {
665 /* Sets parameters in dest according to the model indexed by num. */
668 munpack(dest
, num
+models
);
673 /* Returns the number of preset models. */
679 /* Returns a malloc()-ed string of the names of all preset
680 * models, separated by newlines and terminated by NULL.
681 * Aliases are not listed.
685 const struct malias
*aptr
= aliases
;
688 if(aptr
== aptr
->model
->alias
)
689 size
+= strlen(aptr
->name
) + 1;
692 if(!size
) return(NULL
);
693 if((string
= malloc(size
))) {
697 if(aptr
== aptr
->model
->alias
) {
698 strcpy(sptr
, aptr
->name
);
699 sptr
+= strlen(aptr
->name
);
706 uerror("cannot allocate memory for list of models");
712 mmatch(model_t
*model
, int flags
) {
713 /* searches models[] for a model matching the argument, and links a name if found
714 * if flags & M_OVERWR, copies the found model onto the argument. */
715 size_t left
= 0, right
= NPRESETS
, middle
= 0;
720 while(left
< right
&& cmp
) {
721 middle
= (left
>> 1) + (right
>> 1);
722 PUNPACK(&poly
, models
+middle
, bspoly
);
723 cmp
= psncmp(&model
->spoly
, &poly
);
725 PUNPACK(&poly
, models
+middle
, binit
);
726 cmp
= psncmp(&model
->init
, &poly
);
729 if((model
->flags
& P_REFIN
) && (~models
[middle
].flags
& P_REFIN
))
731 else if((~model
->flags
& P_REFIN
) && (models
[middle
].flags
& P_REFIN
))
733 else if((model
->flags
& P_REFOUT
) && (~models
[middle
].flags
& P_REFOUT
))
735 else if((~model
->flags
& P_REFOUT
) && (models
[middle
].flags
& P_REFOUT
))
738 PUNPACK(&poly
, models
+middle
, bxorout
);
739 cmp
= psncmp(&model
->xorout
, &poly
);
742 if(cmp
< 0) right
= middle
;
743 else if(cmp
> 0) left
= middle
+ 1;
748 model
->name
= models
[middle
].alias
->name
;
750 munpack(model
, models
+middle
);
754 /* Private functions */
757 munpack(model_t
*dest
, const struct mpreset
*src
) {
758 /* Copies the parameters of src to dest.
759 * dest must be an initialised model.
761 if(!dest
|| !src
) return;
766 dest
->flags
= src
->flags
;
767 /* link to the name as it is static */
768 dest
->name
= src
->alias
->name
;