[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 | }
|
---|