| [1] | 1 | #include "config.h" | 
|---|
|  | 2 |  | 
|---|
|  | 3 | #ifdef HAVE_BROKEN_INCLUDES | 
|---|
|  | 4 | #define _ANSI_C_SOURCE | 
|---|
|  | 5 | #define _POSIX_SOURCE | 
|---|
|  | 6 | #endif | 
|---|
|  | 7 |  | 
|---|
|  | 8 | #include <stdio.h> | 
|---|
|  | 9 |  | 
|---|
|  | 10 | extern void exit(int status); | 
|---|
|  | 11 | extern int fclose(FILE *stream); | 
|---|
|  | 12 |  | 
|---|
|  | 13 | #ifndef TRUE | 
|---|
|  | 14 | #define TRUE (1 == 1) | 
|---|
|  | 15 | #endif | 
|---|
|  | 16 |  | 
|---|
|  | 17 | #ifndef FALSE | 
|---|
|  | 18 | #define FALSE (1 != 1) | 
|---|
|  | 19 | #endif | 
|---|
|  | 20 |  | 
|---|
|  | 21 | struct description_int | 
|---|
|  | 22 | { | 
|---|
|  | 23 | int int_size; | 
|---|
|  | 24 | char int_name[20]; | 
|---|
|  | 25 | }; | 
|---|
|  | 26 | struct description_int int_descrs[] = | 
|---|
|  | 27 | { | 
|---|
|  | 28 | #ifdef LONGLONG | 
|---|
|  | 29 | { sizeof(unsigned long long), "unsigned long long" }, | 
|---|
|  | 30 | #endif | 
|---|
|  | 31 | {  sizeof(unsigned long),     "unsigned long"      }, | 
|---|
|  | 32 | {  sizeof(unsigned int),      "unsigned int"       }, | 
|---|
|  | 33 | {  sizeof(unsigned short),    "unsigned short"     }, | 
|---|
|  | 34 | {  sizeof(unsigned char),     "unsigned char"      } | 
|---|
|  | 35 | }; | 
|---|
|  | 36 | int size_count = sizeof(int_descrs) / sizeof(struct description_int); | 
|---|
|  | 37 |  | 
|---|
|  | 38 | struct trnc_data | 
|---|
|  | 39 | { | 
|---|
|  | 40 | long a, b, q, r; | 
|---|
|  | 41 | }; | 
|---|
|  | 42 | struct trnc_data trunc_tbl[] = | 
|---|
|  | 43 | { | 
|---|
|  | 44 | {   13,  4,  3,  1 }, | 
|---|
|  | 45 | {   13, -4, -3,  1 }, | 
|---|
|  | 46 | {  -13,  4, -3, -1 }, | 
|---|
|  | 47 | {  -13, -4,  3, -1 }, | 
|---|
|  | 48 | {   15,  4,  3,  3 }, | 
|---|
|  | 49 | {   15, -4, -3,  3 }, | 
|---|
|  | 50 | {  -15,  4, -3, -3 }, | 
|---|
|  | 51 | {  -15, -4,  3, -3 } | 
|---|
|  | 52 | }; | 
|---|
|  | 53 | int size_trunc_tbl = sizeof(trunc_tbl) / sizeof(struct trnc_data); | 
|---|
|  | 54 |  | 
|---|
|  | 55 | struct rand_data | 
|---|
|  | 56 | { | 
|---|
|  | 57 | unsigned long dig_size, a1, c1, a2, c2; | 
|---|
|  | 58 | }; | 
|---|
|  | 59 | struct rand_data rand_tbl[] = | 
|---|
|  | 60 | { | 
|---|
|  | 61 | {  8,   197,   11,    37,    37 }, | 
|---|
|  | 62 | { 16,   805,  345,   925,   767 }, | 
|---|
|  | 63 | { 18, 13405, 4801, 20325, 19777 }, | 
|---|
|  | 64 | { 32, 13405, 4801, 20325, 19777 } | 
|---|
|  | 65 | }; | 
|---|
|  | 66 | int size_rand_tbl = sizeof(rand_tbl) / sizeof(struct rand_data); | 
|---|
|  | 67 |  | 
|---|
|  | 68 | int digit_bits; | 
|---|
|  | 69 |  | 
|---|
|  | 70 | int | 
|---|
|  | 71 | div_trunc_p(void) | 
|---|
|  | 72 | { | 
|---|
|  | 73 | int i; | 
|---|
|  | 74 |  | 
|---|
|  | 75 | for (i = 0; i < size_trunc_tbl; i++) | 
|---|
|  | 76 | { | 
|---|
|  | 77 | if (trunc_tbl[i].a / trunc_tbl[i].b != trunc_tbl[i].q) | 
|---|
|  | 78 | { | 
|---|
|  | 79 | printf("%ld / %ld = %ld, should have been %ld\n", | 
|---|
|  | 80 | trunc_tbl[i].a, | 
|---|
|  | 81 | trunc_tbl[i].b, | 
|---|
|  | 82 | trunc_tbl[i].a / trunc_tbl[i].b, | 
|---|
|  | 83 | trunc_tbl[i].q); | 
|---|
|  | 84 | printf("when division truncates towards zero.\n"); | 
|---|
|  | 85 | return FALSE; | 
|---|
|  | 86 | } | 
|---|
|  | 87 | if (trunc_tbl[i].a % trunc_tbl[i].b != trunc_tbl[i].r) | 
|---|
|  | 88 | { | 
|---|
|  | 89 | printf("%ld %% %ld = %ld, should have been %ld\n", | 
|---|
|  | 90 | trunc_tbl[i].a, | 
|---|
|  | 91 | trunc_tbl[i].b, | 
|---|
|  | 92 | trunc_tbl[i].a % trunc_tbl[i].b, | 
|---|
|  | 93 | trunc_tbl[i].r); | 
|---|
|  | 94 | printf("when division truncates towards zero.\n"); | 
|---|
|  | 95 | printf("Here a != q*b + r.  Very strange!\n"); | 
|---|
|  | 96 | return FALSE; | 
|---|
|  | 97 | } | 
|---|
|  | 98 | } | 
|---|
|  | 99 | return TRUE; | 
|---|
|  | 100 | } | 
|---|
|  | 101 |  | 
|---|
|  | 102 | int | 
|---|
|  | 103 | charsize(void) | 
|---|
|  | 104 | { | 
|---|
|  | 105 | int i = 0; | 
|---|
|  | 106 | unsigned char ch = 1; | 
|---|
|  | 107 | unsigned char oldch = 0; | 
|---|
|  | 108 |  | 
|---|
|  | 109 | while (ch > oldch) | 
|---|
|  | 110 | { | 
|---|
|  | 111 | oldch = ch; | 
|---|
|  | 112 | ch <<= 1; | 
|---|
|  | 113 | i++; | 
|---|
|  | 114 | } | 
|---|
|  | 115 | return i; | 
|---|
|  | 116 | } | 
|---|
|  | 117 |  | 
|---|
|  | 118 | void | 
|---|
|  | 119 | RandDefsOut(FILE *fpOut, int dig_size) | 
|---|
|  | 120 | { | 
|---|
|  | 121 | int i = 0; | 
|---|
|  | 122 |  | 
|---|
|  | 123 | while ((i < size_rand_tbl) && (dig_size != (int)rand_tbl[i].dig_size)) | 
|---|
|  | 124 | { | 
|---|
|  | 125 | i++; | 
|---|
|  | 126 | } | 
|---|
|  | 127 | if (i == size_rand_tbl) | 
|---|
|  | 128 | { | 
|---|
|  | 129 | if (dig_size < (int) rand_tbl[0].dig_size) | 
|---|
|  | 130 | { | 
|---|
|  | 131 | printf("Digit size %d too small.\n", dig_size); | 
|---|
|  | 132 | exit(10); | 
|---|
|  | 133 | } | 
|---|
|  | 134 | while ((int) rand_tbl[--i].dig_size > dig_size) | 
|---|
|  | 135 | { | 
|---|
|  | 136 | /* Count down `i' */ | 
|---|
|  | 137 | } | 
|---|
|  | 138 | } | 
|---|
|  | 139 | fprintf(fpOut, "\n#define BIG_RAND_A1 %ld\n", rand_tbl[i].a1); | 
|---|
|  | 140 | fprintf(fpOut,   "#define BIG_RAND_C1 %ld\n", rand_tbl[i].c1); | 
|---|
|  | 141 | fprintf(fpOut,   "#define BIG_RAND_A2 %ld\n", rand_tbl[i].a2); | 
|---|
|  | 142 | fprintf(fpOut,   "#define BIG_RAND_C2 %ld\n", rand_tbl[i].c2); | 
|---|
|  | 143 | } | 
|---|
|  | 144 |  | 
|---|
|  | 145 | int | 
|---|
|  | 146 | main(void) | 
|---|
|  | 147 | { | 
|---|
|  | 148 | int i, j = 0, ints_found = FALSE, char_bits; | 
|---|
|  | 149 | FILE *fpOut; | 
|---|
|  | 150 |  | 
|---|
|  | 151 | if (!div_trunc_p()) | 
|---|
|  | 152 | { | 
|---|
|  | 153 | printf("Can't do division on this machine!\n"); | 
|---|
|  | 154 | exit(10); | 
|---|
|  | 155 | } | 
|---|
|  | 156 |  | 
|---|
|  | 157 | if ((fpOut = fopen("internal.h", "w")) == NULL) | 
|---|
|  | 158 | { | 
|---|
|  | 159 | printf("Could not create \"internal.h\".\n"); | 
|---|
|  | 160 | exit(10); | 
|---|
|  | 161 | } | 
|---|
|  | 162 |  | 
|---|
|  | 163 | fprintf(fpOut, "#ifndef _BIGNUM_INTERNAL_H_\n"); | 
|---|
|  | 164 | fprintf(fpOut, "#define _BIGNUM_INTERNAL_H_\n\n"); | 
|---|
|  | 165 |  | 
|---|
|  | 166 | char_bits = charsize(); | 
|---|
|  | 167 |  | 
|---|
|  | 168 | for (i = 0; (i < size_count - 1) && !ints_found; i++) | 
|---|
|  | 169 | { | 
|---|
|  | 170 | for (j = i + 1; (j < size_count) && !ints_found; j++) | 
|---|
|  | 171 | { | 
|---|
|  | 172 | if (int_descrs[i].int_size >= 2 * int_descrs[j].int_size) | 
|---|
|  | 173 | { | 
|---|
|  | 174 | fprintf(fpOut, | 
|---|
|  | 175 | "#define BIGNUM_DIGIT %s\n", | 
|---|
|  | 176 | int_descrs[j].int_name); | 
|---|
|  | 177 | fprintf(fpOut, | 
|---|
|  | 178 | "#define BIGNUM_TWO_DIGITS %s\n\n", | 
|---|
|  | 179 | int_descrs[i].int_name); | 
|---|
|  | 180 | ints_found = TRUE; | 
|---|
|  | 181 | } | 
|---|
|  | 182 | } | 
|---|
|  | 183 | } | 
|---|
|  | 184 |  | 
|---|
|  | 185 | if (!ints_found) | 
|---|
|  | 186 | { | 
|---|
|  | 187 | fprintf(stderr, "Strange, no integer type was two times bigger "); | 
|---|
|  | 188 | fprintf(stderr, "than another integer type.\n"); | 
|---|
|  | 189 | fprintf(stderr, "Can't create header file.\nExiting.\n"); | 
|---|
|  | 190 | exit(10); | 
|---|
|  | 191 | } | 
|---|
|  | 192 |  | 
|---|
|  | 193 | if (i > 0) i--; | 
|---|
|  | 194 | if (j > 0) j--; | 
|---|
|  | 195 |  | 
|---|
|  | 196 | digit_bits = char_bits * int_descrs[j].int_size; | 
|---|
|  | 197 | fprintf(fpOut, "#define BIG_CHARBITS %d\n", char_bits); | 
|---|
|  | 198 | fprintf(fpOut, "#define BIGNUM_DIGIT_BITS %d\n", digit_bits); | 
|---|
|  | 199 | fprintf(fpOut, "#define BIGNUM_TWO_DIGITS_BITS %d\n\n", | 
|---|
|  | 200 | char_bits * int_descrs[i].int_size); | 
|---|
|  | 201 |  | 
|---|
|  | 202 | fprintf(fpOut, "struct big_struct\n{\n    int sign;\n"); | 
|---|
|  | 203 | fprintf(fpOut, "    unsigned long dgs_alloc;\n"); | 
|---|
|  | 204 | fprintf(fpOut, "    unsigned long dgs_used;\n"); | 
|---|
|  | 205 | fprintf(fpOut, "    BIGNUM_DIGIT *dp;\n};\n"); | 
|---|
|  | 206 |  | 
|---|
|  | 207 | RandDefsOut(fpOut, char_bits * int_descrs[j].int_size); | 
|---|
|  | 208 |  | 
|---|
|  | 209 | if (sizeof(long) == sizeof(int)) | 
|---|
|  | 210 | { | 
|---|
|  | 211 | fprintf(fpOut, "\n#define MEMCPY_LONG_COUNTER\n"); | 
|---|
|  | 212 | } | 
|---|
|  | 213 |  | 
|---|
|  | 214 | #ifdef BIG_SHORT_NAMES | 
|---|
|  | 215 | fprintf(fpOut, "\n#define BIG_SHORT_NAMES\n"); | 
|---|
|  | 216 | #endif | 
|---|
|  | 217 |  | 
|---|
|  | 218 | fprintf(fpOut, "\n#endif\n"); | 
|---|
|  | 219 | fclose(fpOut); | 
|---|
|  | 220 | exit(0); | 
|---|
|  | 221 | return 0;                   /* Keep gcc from complaining */ | 
|---|
|  | 222 | } | 
|---|