2015-06-07 17:35:49 +08:00
|
|
|
/* bmpbit.c
|
2016-08-22 02:51:29 +08:00
|
|
|
* Greg Cook, 27/Jun/2016
|
2015-06-07 17:35:49 +08:00
|
|
|
*/
|
|
|
|
|
2016-08-22 02:51:29 +08:00
|
|
|
/* CRC RevEng: arbitrary-precision CRC calculator and algorithm finder
|
2016-04-05 09:35:12 +08:00
|
|
|
* Copyright (C) 2010, 2011, 2012, 2013, 2014, 2015, 2016 Gregory Cook
|
2015-06-07 17:35:49 +08:00
|
|
|
*
|
|
|
|
* This file is part of CRC RevEng.
|
|
|
|
*
|
|
|
|
* CRC RevEng is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* CRC RevEng is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
2016-08-22 02:51:29 +08:00
|
|
|
* along with CRC RevEng. If not, see <https://www.gnu.org/licenses/>.
|
2015-06-07 17:35:49 +08:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef BMPTST
|
|
|
|
# include <stdio.h>
|
|
|
|
# include <stdlib.h>
|
|
|
|
#else
|
|
|
|
# define FILE void
|
|
|
|
#endif
|
|
|
|
#include "reveng.h"
|
|
|
|
|
|
|
|
#if (defined BMPTST) || (BMP_BIT < 32)
|
|
|
|
/* Size in bits of a bmp_t. Not necessarily a power of two. */
|
|
|
|
int bmpbit;
|
|
|
|
|
|
|
|
/* The highest power of two that is strictly less than BMP_BIT.
|
|
|
|
* Initialises the index of a binary search for set bits in a bmp_t.
|
|
|
|
* (Computed correctly for BMP_BIT >= 2)
|
|
|
|
*/
|
|
|
|
int bmpsub;
|
|
|
|
|
|
|
|
void
|
|
|
|
setbmp(void) {
|
|
|
|
/* Initialise BMP_BIT and BMP_SUB for the local architecture. */
|
|
|
|
bmp_t bmpmax = ~(bmp_t) 0;
|
|
|
|
|
|
|
|
bmpbit = 0; bmpsub = 1;
|
|
|
|
|
|
|
|
while(bmpmax) {
|
|
|
|
bmpmax <<= 1;
|
|
|
|
++bmpbit;
|
|
|
|
}
|
|
|
|
|
|
|
|
while((bmpsub | (bmpsub - 1)) < bmpbit - 1)
|
|
|
|
bmpsub <<= 1;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef BMPTST
|
|
|
|
int
|
|
|
|
main(int argc, char *argv[]) {
|
|
|
|
/* check the compile-time bitmap width is correct, otherwise
|
|
|
|
* searches run forever. */
|
|
|
|
# if BMP_BIT > 0
|
|
|
|
setbmp();
|
|
|
|
if(BMP_BIT != bmpbit || BMP_SUB != bmpsub) {
|
|
|
|
fprintf(stderr,"reveng: configuration fault. Update "
|
|
|
|
"config.h with these definitions and "
|
|
|
|
"recompile:\n"
|
|
|
|
"\t#define BMP_BIT %d\n"
|
|
|
|
"\t#define BMP_SUB %d\n",
|
|
|
|
bmpbit, bmpsub);
|
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
}
|
|
|
|
# endif /* BMP_BIT > 0 */
|
|
|
|
/* check the bitmap constant macro */
|
|
|
|
if(~(bmp_t) 0 != ~BMP_C(0)) {
|
|
|
|
fprintf(stderr, "reveng: configuration fault. Edit "
|
|
|
|
"the definition of BMP_C() in config.h to "
|
|
|
|
"match BMP_T and recompile.\n");
|
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
}
|
|
|
|
exit(EXIT_SUCCESS);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* BMPTST */
|