cd6e477f31
ALL: add missing includes
2014-06-09 00:10:37 +02:00
f7131410bf
ALL: prefix all files with ntru_
2014-06-09 00:10:37 +02:00
58bf823e36
Rm obsolete file
2014-06-09 00:10:37 +02:00
6dccef4dc9
ALL: rename context to params
2014-06-09 00:10:37 +02:00
516b14414a
DOC: fix various doxygen comments
2014-06-09 00:10:36 +02:00
8c5649ea24
RND: use function callback for random ints
2014-06-09 00:10:36 +02:00
e88dc81c90
RND: make random int functions public
2014-06-09 00:10:36 +02:00
9b71469b51
RND: first try of random module
...
Currently only works with specifying the number
of negative and positive ones.
2014-06-09 00:10:36 +02:00
2eb7af07dc
POLY: add null-ptr tolerant fmpz_cmp_si_n() function
2014-06-09 00:10:36 +02:00
f23720fe07
ENC: rm obsolete comment
2014-06-09 00:10:35 +02:00
81b570d9a9
POLY->ASCII: improve modularity
2014-06-09 00:10:35 +02:00
2503fdcfa4
ASCII->POLY: split up to poly_ascii.c
2014-06-09 00:10:35 +02:00
b82126d180
ASCII->POLY: rm obsolete comments
2014-06-09 00:10:35 +02:00
a265a89a0d
ALL: use const modifiers on parameters where possible
2014-06-09 00:10:35 +02:00
9b8b7e9129
DEC: make sure all polynomials are shifted [-q/2, q/2]
2014-06-09 00:10:35 +02:00
19a6ab89c7
KEYGEN: fix typo
2014-05-30 22:26:36 +02:00
7f23aa2a35
ALL: fix memory leaks
2014-05-30 19:54:50 +02:00
8871b496c2
KEYGEN: support import/export of keys
2014-05-30 19:23:45 +02:00
a42b65505a
KEYGEN: we need the pubkey unshifted
2014-05-30 19:11:57 +02:00
d6cbb73865
ASCII->POLY: fix binary support, rm obsolete logic, minor fixes
2014-05-30 18:54:51 +02:00
f7b3462dc6
POLY: consistent var naming
2014-05-30 18:42:09 +02:00
c125d48209
BUILD: update clean target
2014-05-30 18:40:42 +02:00
82ae4a7a52
ASCII->POLY: rm redundant counter
2014-05-30 01:37:03 +02:00
0f2f2aec06
ASCII->POLY: update doxygen comment
2014-05-29 22:16:50 +02:00
27b20f97b7
ASCII->POLY: avoid trailing junk data
2014-05-29 22:11:05 +02:00
bdc3aad651
ENC: fix encryption
...
It was actually broken, since we did overwrite the
out-coefficients instead of adding to them. Fixing this
again causes the same problems as described in the
inline comment, no matter which implementation we use.
2014-05-29 16:46:35 +02:00
a050b8853a
ENC: rm redundant code
2014-05-29 00:20:16 +02:00
bb0207ba03
KEYGEN: improve error handling
2014-05-28 23:11:52 +02:00
67ec5615c7
POLY: readability
2014-05-28 23:11:13 +02:00
7759bff8f7
RAND: rm obsolete implementation
2014-05-28 21:19:57 +02:00
6142381abb
BUILD: cleanup
2014-05-28 21:18:33 +02:00
4def114c5c
POLY: style/readability
2014-05-28 20:57:55 +02:00
67a4557487
ASCII->POLY: also allow binary data
2014-05-28 20:57:40 +02:00
72d13839ee
ENC: improve error handling
2014-05-28 20:57:22 +02:00
52c1abe8ee
DEC: style fix
2014-05-28 20:56:57 +02:00
c48dad818e
DEC: improve error handling
2014-05-28 20:56:43 +02:00
2a6ad998ce
ENC: cleanup
2014-05-28 19:54:51 +02:00
ecdfbad591
ENC: style fix
2014-05-28 19:44:49 +02:00
f0eefe7885
ENC: fix encryption
...
In some very rare cases such as the polynom
1, -1, -1, 1, 1, -1, -1, 1, -1, -1, 1
the encryption->decryption cycle caused an incorrect result.
This wasn't reproducible for all polynomials, just for some.
Implementing the algorithm manually instead of using
the shortcut through
fmpz_poly_add(out, out, tmp_poly_msg);
fmpz_poly_mod_unsigned(out, ctx->q);
seems to have solved the issue.
Still unknown what happened there.
2014-05-28 19:44:40 +02:00
f17b3fd6d0
ASCII->POLY: use malloc instead of calloc
2014-05-28 19:42:08 +02:00
0c9e53b5fb
ASCII->POLY: cosmetic cleanup
2014-05-28 19:41:51 +02:00
4440322d29
ASCII->POLY: fix broken loop
2014-05-28 19:40:39 +02:00
hasufell
593c24ff90
ASCII->POLY: fix some valgrind warnings
...
Especially uninitalized memory warnings.
2014-05-28 11:20:28 +02:00
bf192a0498
ASCII->POLY: use double base64 encoding for more entropy
2014-05-28 02:04:45 +02:00
51c6537777
BUILD: refactor Makefiles
2014-05-28 01:38:55 +02:00
2ec61bc87e
ALL: improve readability
2014-05-28 01:17:19 +02:00
9f6b7319bb
ASCII->POLY: refactor
...
Use base64 (via glib) instead of plain char cast.
Remove ascii_to_poly() since it's unreliable (we don't
really know how many polynomials we will need
for a string).
2014-05-28 01:09:52 +02:00
8b9134628c
STRING: improve doxygen comment
2014-05-27 01:08:52 +02:00
fd9ac4ecb8
STRING: add prints() for printing
2014-05-27 01:08:42 +02:00
e0b75b98e2
ASCII->POLY: refactor and make more modular
...
Introduced appropriate function for single polynomials
as well.
2014-05-27 01:08:17 +02:00