-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy pathpolygen.c
executable file
·41 lines (39 loc) · 1.4 KB
/
polygen.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#include "polygen.h"
uint64_t calculate_num_of_equations(int r, int number_of_plains)
{
uint64_t output;
output = number_of_plains * (64 + (r * 3));
return output;
}
void polynomials(uint32_t *plains, uint32_t *ciphers, polynomial *equations, int r, int number_of_plains)
{
int i, j;
uint64_t eqs_ctr = 0;
for (i = 0; i < number_of_plains; i++)
{
for (j = 0; j < 32; j++)
{
sprintf(equations[eqs_ctr].poly, EQ1, i, j, ((plains[i] >> j) & 0x1));
eqs_ctr++;
}
for (j = 32; j < r + 32; j++)
{
sprintf(equations[eqs_ctr].poly, EQ2,
i, j, (j - 32) % 64, i, (j - 32), i, (j - 16), i, (j - 23),
i, (j - 31), i, (j - 1), i, (j - 12), i, j, i, (j - 6), i,
(j - 12), i, (j - 6), i, (j - 31), i, (j - 12), i, (j - 23),
i, (j - 23), i, (j - 31), i, j, i, (j - 23), i, j, i, (j - 12),
i, j, i, (j - 23), i, j, i, (j - 12));
eqs_ctr++;
sprintf(equations[eqs_ctr].poly, EQ3, i, j, i, (j - 1), i, (j - 6));
eqs_ctr++;
sprintf(equations[eqs_ctr].poly, EQ4, i, j, i, (j - 1), i, (j - 31));
eqs_ctr++;
}
for (j = r; j < r + 32; j++)
{
sprintf(equations[eqs_ctr].poly, EQ1, i, j, ((ciphers[i] >> (j - r)) & 0x1));
eqs_ctr++;
}
}
}