mce signature size checks
This commit is contained in:
parent
2c7d4276cf
commit
31ef38bfa7
|
@ -117,7 +117,7 @@ int privkey::sign (const bvector&in, bvector&out, uint delta, uint attempts, prn
|
||||||
|
|
||||||
s = cipher_size();
|
s = cipher_size();
|
||||||
|
|
||||||
//TODO check sizes of everything!
|
if (in.size() != s) return 2;
|
||||||
|
|
||||||
//first, prepare the codeword to canonical form for decoding
|
//first, prepare the codeword to canonical form for decoding
|
||||||
Pinv.permute (in, e2);
|
Pinv.permute (in, e2);
|
||||||
|
@ -161,8 +161,8 @@ int privkey::sign (const bvector&in, bvector&out, uint delta, uint attempts, prn
|
||||||
int pubkey::verify (const bvector&in, const bvector&hash, uint delta)
|
int pubkey::verify (const bvector&in, const bvector&hash, uint delta)
|
||||||
{
|
{
|
||||||
bvector tmp;
|
bvector tmp;
|
||||||
//TODO check sizes!
|
if (!G.mult_vecT_left (in, tmp) ) return 2; //wrong size of input
|
||||||
G.mult_vecT_left (in, tmp);
|
if (hash.size() != tmp.size() ) return 1; //wrong size of hash, not a sig.
|
||||||
tmp.add (hash);
|
tmp.add (hash);
|
||||||
if (tmp.hamming_weight() > (t + delta) ) return 1; //not a signature
|
if (tmp.hamming_weight() > (t + delta) ) return 1; //not a signature
|
||||||
return 0; //sig OK
|
return 0; //sig OK
|
||||||
|
|
Loading…
Reference in a new issue