Skip to content

Commit d35b489

Browse files
New macro PSA_ALG_IS_HASH_AND_SIGN
Test for a subclass of public-key algorithm: those that perform full-domain hashing, i.e. algorithms that can be broken down as sign(key, hash(message)).
1 parent 8d4be19 commit d35b489

File tree

3 files changed

+32
-14
lines changed

3 files changed

+32
-14
lines changed

include/psa/crypto_values.h

Lines changed: 18 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1046,6 +1046,23 @@
10461046
#define PSA_ALG_IS_RANDOMIZED_ECDSA(alg) \
10471047
(PSA_ALG_IS_ECDSA(alg) && !PSA_ALG_ECDSA_IS_DETERMINISTIC(alg))
10481048

1049+
/** Whether the specified algorithm is a hash-and-sign algorithm.
1050+
*
1051+
* Hash-and-sign algorithms are public-key signature algorithms structured
1052+
* in two parts: first the calculation of a hash in a way that does not
1053+
* depend on the key, then the calculation of a signature from the
1054+
* hash value and the key.
1055+
*
1056+
* \param alg An algorithm identifier (value of type #psa_algorithm_t).
1057+
*
1058+
* \return 1 if \p alg is a hash-and-sign algorithm, 0 otherwise.
1059+
* This macro may return either 0 or 1 if \p alg is not a supported
1060+
* algorithm identifier.
1061+
*/
1062+
#define PSA_ALG_IS_HASH_AND_SIGN(alg) \
1063+
(PSA_ALG_IS_RSA_PSS(alg) || PSA_ALG_IS_RSA_PKCS1V15_SIGN(alg) || \
1064+
PSA_ALG_IS_DSA(alg) || PSA_ALG_IS_ECDSA(alg))
1065+
10491066
/** Get the hash used by a hash-and-sign signature algorithm.
10501067
*
10511068
* A hash-and-sign algorithm is a signature algorithm which is
@@ -1065,8 +1082,7 @@
10651082
* if it is not supported by the implementation.
10661083
*/
10671084
#define PSA_ALG_SIGN_GET_HASH(alg) \
1068-
(PSA_ALG_IS_RSA_PSS(alg) || PSA_ALG_IS_RSA_PKCS1V15_SIGN(alg) || \
1069-
PSA_ALG_IS_DSA(alg) || PSA_ALG_IS_ECDSA(alg) ? \
1085+
(PSA_ALG_IS_HASH_AND_SIGN(alg) ? \
10701086
((alg) & PSA_ALG_HASH_MASK) == 0 ? /*"raw" algorithm*/ 0 : \
10711087
((alg) & PSA_ALG_HASH_MASK) | PSA_ALG_CATEGORY_HASH : \
10721088
0)

tests/suites/test_suite_psa_crypto_metadata.data

Lines changed: 8 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -200,35 +200,35 @@ aead_algorithm:PSA_ALG_GCM:0:16
200200

201201
Asymmetric signature: RSA PKCS#1 v1.5 raw
202202
depends_on:MBEDTLS_RSA_C:MBEDTLS_PKCS1_V15
203-
asymmetric_signature_algorithm:PSA_ALG_RSA_PKCS1V15_SIGN_RAW:ALG_IS_RSA_PKCS1V15_SIGN
203+
asymmetric_signature_algorithm:PSA_ALG_RSA_PKCS1V15_SIGN_RAW:ALG_IS_RSA_PKCS1V15_SIGN | ALG_IS_HASH_AND_SIGN
204204

205205
Asymmetric signature: RSA PKCS#1 v1.5 SHA-256
206206
depends_on:MBEDTLS_RSA_C:MBEDTLS_PKCS1_V15:MBEDTLS_SHA256_C
207-
asymmetric_signature_algorithm:PSA_ALG_RSA_PKCS1V15_SIGN( PSA_ALG_SHA_256 ):ALG_IS_RSA_PKCS1V15_SIGN
207+
asymmetric_signature_algorithm:PSA_ALG_RSA_PKCS1V15_SIGN( PSA_ALG_SHA_256 ):ALG_IS_RSA_PKCS1V15_SIGN | ALG_IS_HASH_AND_SIGN
208208

209209
Asymmetric signature: RSA PSS SHA-256
210210
depends_on:MBEDTLS_RSA_C:MBEDTLS_PKCS1_V21:MBEDTLS_SHA256_C
211-
asymmetric_signature_algorithm:PSA_ALG_RSA_PSS( PSA_ALG_SHA_256 ):ALG_IS_RSA_PSS
211+
asymmetric_signature_algorithm:PSA_ALG_RSA_PSS( PSA_ALG_SHA_256 ):ALG_IS_RSA_PSS | ALG_IS_HASH_AND_SIGN
212212

213213
Asymmetric signature: SHA-256 + randomized DSA SHA-256 using SHA-256
214214
depends_on:MBEDTLS_DSA_C:MBEDTLS_SHA256_C
215-
asymmetric_signature_algorithm:PSA_ALG_DSA( PSA_ALG_SHA_256 ):ALG_IS_DSA | ALG_IS_RANDOMIZED_DSA
215+
asymmetric_signature_algorithm:PSA_ALG_DSA( PSA_ALG_SHA_256 ):ALG_IS_DSA | ALG_IS_RANDOMIZED_DSA | ALG_IS_HASH_AND_SIGN
216216

217217
Asymmetric signature: SHA-256 + deterministic DSA using SHA-256
218218
depends_on:MBEDTLS_DSA_C:MBEDTLS_SHA256_C:MBEDTLS_DSA_DETERMINISTIC
219-
asymmetric_signature_algorithm:PSA_ALG_DETERMINISTIC_DSA( PSA_ALG_SHA_256 ):ALG_IS_DSA | ALG_IS_DETERMINISTIC_DSA | ALG_DSA_IS_DETERMINISTIC
219+
asymmetric_signature_algorithm:PSA_ALG_DETERMINISTIC_DSA( PSA_ALG_SHA_256 ):ALG_IS_DSA | ALG_IS_DETERMINISTIC_DSA | ALG_DSA_IS_DETERMINISTIC | ALG_IS_HASH_AND_SIGN
220220

221221
Asymmetric signature: randomized ECDSA (no hashing)
222222
depends_on:MBEDTLS_ECDSA_C
223-
asymmetric_signature_algorithm:PSA_ALG_ECDSA_ANY:ALG_IS_ECDSA | ALG_IS_RANDOMIZED_ECDSA
223+
asymmetric_signature_algorithm:PSA_ALG_ECDSA_ANY:ALG_IS_ECDSA | ALG_IS_RANDOMIZED_ECDSA | ALG_IS_HASH_AND_SIGN
224224

225225
Asymmetric signature: SHA-256 + randomized ECDSA
226226
depends_on:MBEDTLS_ECDSA_C:MBEDTLS_SHA256_C
227-
asymmetric_signature_algorithm:PSA_ALG_ECDSA( PSA_ALG_SHA_256 ):ALG_IS_ECDSA | ALG_IS_RANDOMIZED_ECDSA
227+
asymmetric_signature_algorithm:PSA_ALG_ECDSA( PSA_ALG_SHA_256 ):ALG_IS_ECDSA | ALG_IS_RANDOMIZED_ECDSA | ALG_IS_HASH_AND_SIGN
228228

229229
Asymmetric signature: SHA-256 + deterministic DSA using SHA-256
230230
depends_on:MBEDTLS_ECDSA_C:MBEDTLS_ECDSA_DETERMINISTIC:MBEDTLS_SHA256_C
231-
asymmetric_signature_algorithm:PSA_ALG_DETERMINISTIC_ECDSA( PSA_ALG_SHA_256 ):ALG_IS_ECDSA | ALG_IS_DETERMINISTIC_ECDSA | ALG_ECDSA_IS_DETERMINISTIC
231+
asymmetric_signature_algorithm:PSA_ALG_DETERMINISTIC_ECDSA( PSA_ALG_SHA_256 ):ALG_IS_ECDSA | ALG_IS_DETERMINISTIC_ECDSA | ALG_ECDSA_IS_DETERMINISTIC | ALG_IS_HASH_AND_SIGN
232232

233233
Asymmetric encryption: RSA PKCS#1 v1.5
234234
depends_on:MBEDTLS_RSA_C:MBEDTLS_PKCS1_V15

tests/suites/test_suite_psa_crypto_metadata.function

Lines changed: 6 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -29,10 +29,11 @@
2929
#define ALG_ECDSA_IS_DETERMINISTIC ( 1u << 11 )
3030
#define ALG_IS_DETERMINISTIC_ECDSA ( 1u << 12 )
3131
#define ALG_IS_RANDOMIZED_ECDSA ( 1u << 13 )
32-
#define ALG_IS_RSA_OAEP ( 1u << 14 )
33-
#define ALG_IS_HKDF ( 1u << 15 )
34-
#define ALG_IS_FFDH ( 1u << 16 )
35-
#define ALG_IS_ECDH ( 1u << 17 )
32+
#define ALG_IS_HASH_AND_SIGN ( 1u << 14 )
33+
#define ALG_IS_RSA_OAEP ( 1u << 15 )
34+
#define ALG_IS_HKDF ( 1u << 16 )
35+
#define ALG_IS_FFDH ( 1u << 17 )
36+
#define ALG_IS_ECDH ( 1u << 18 )
3637

3738
/* Flags for key type classification macros. There is a flag for every
3839
* key type classification macro PSA_KEY_TYPE_IS_xxx except for some that
@@ -67,6 +68,7 @@ void algorithm_classification( psa_algorithm_t alg, unsigned flags )
6768
TEST_CLASSIFICATION_MACRO( ALG_ECDSA_IS_DETERMINISTIC, alg, flags );
6869
TEST_CLASSIFICATION_MACRO( ALG_IS_DETERMINISTIC_ECDSA, alg, flags );
6970
TEST_CLASSIFICATION_MACRO( ALG_IS_RANDOMIZED_ECDSA, alg, flags );
71+
TEST_CLASSIFICATION_MACRO( ALG_IS_HASH_AND_SIGN, alg, flags );
7072
TEST_CLASSIFICATION_MACRO( ALG_IS_RSA_OAEP, alg, flags );
7173
TEST_CLASSIFICATION_MACRO( ALG_IS_HKDF, alg, flags );
7274
exit: ;

0 commit comments

Comments
 (0)