Only create signatures with even S, and verification mode to check.
To fix a minor malleability found by Sergio Lerner (reported here: https://bitcointalk.org/index.php?topic=8392.msg1245898#msg1245898) The problem is that if (R,S) is a valid ECDSA signature for a given message and public key, (R,-S) is also valid. Modulo N (the order of the secp256k1 curve), this means that both (R,S) and (R,N-S) are valid. Given that N is odd, S and N-S have a different lowest bit. We solve the problem by forcing signatures to have an even S value, excluding one of the alternatives. This commit just changes the signing code to always produce even S values, and adds a verification mode to check it. This code is not enabled anywhere yet. Existing tests in key_tests.cpp verify that the produced signatures are still valid.
This commit is contained in:
committed by
Pieter Wuille
parent
4323bfeafd
commit
a81cd96805
@@ -64,7 +64,7 @@ BOOST_AUTO_TEST_CASE(script_canon)
|
||||
string test = tv.get_str();
|
||||
if (IsHex(test)) {
|
||||
std::vector<unsigned char> sig = ParseHex(test);
|
||||
BOOST_CHECK_MESSAGE(IsCanonicalSignature(sig), test);
|
||||
BOOST_CHECK_MESSAGE(IsCanonicalSignature(sig, SCRIPT_VERIFY_STRICTENC), test);
|
||||
BOOST_CHECK_MESSAGE(IsCanonicalSignature_OpenSSL(sig), test);
|
||||
}
|
||||
}
|
||||
@@ -78,7 +78,7 @@ BOOST_AUTO_TEST_CASE(script_noncanon)
|
||||
string test = tv.get_str();
|
||||
if (IsHex(test)) {
|
||||
std::vector<unsigned char> sig = ParseHex(test);
|
||||
BOOST_CHECK_MESSAGE(!IsCanonicalSignature(sig), test);
|
||||
BOOST_CHECK_MESSAGE(!IsCanonicalSignature(sig, SCRIPT_VERIFY_STRICTENC), test);
|
||||
BOOST_CHECK_MESSAGE(!IsCanonicalSignature_OpenSSL(sig), test);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user