Gilles Peskine
f7b4137e69
Untangle PSA_ALG_IS_HASH_AND_SIGN and PSA_ALG_IS_SIGN_HASH
...
The current definition of PSA_ALG_IS_HASH_AND_SIGN includes
PSA_ALG_RSA_PKCS1V15_SIGN_RAW and PSA_ALG_ECDSA_ANY, which don't strictly
follow the hash-and-sign paradigm: the algorithm does not encode a hash
algorithm that is applied prior to the signature step. The definition in
fact encompasses what can be used with psa_sign_hash/psa_verify_hash, so
it's the correct definition for PSA_ALG_IS_SIGN_HASH. Therefore this commit
moves definition of PSA_ALG_IS_HASH_AND_SIGN to PSA_ALG_IS_SIGN_HASH, and
replace the definition of PSA_ALG_IS_HASH_AND_SIGN by a correct one (based
on PSA_ALG_IS_SIGN_HASH, excluding the algorithms where the pre-signature
step isn't to apply the hash encoded in the algorithm).
In the definition of PSA_ALG_SIGN_GET_HASH, keep the condition for a nonzero
output to be PSA_ALG_IS_HASH_AND_SIGN.
Everywhere else in the code base (definition of PSA_ALG_IS_SIGN_MESSAGE, and
every use of PSA_ALG_IS_HASH_AND_SIGN outside of crypto_values.h), we meant
PSA_ALG_IS_SIGN_HASH where we wrote PSA_ALG_IS_HASH_AND_SIGN, so do a
global replacement.
```
git grep -l IS_HASH_AND_SIGN ':!include/psa/crypto_values.h' | xargs perl -i -pe 's/ALG_IS_HASH_AND_SIGN/ALG_IS_SIGN_HASH/g'
```
Signed-off-by: Gilles Peskine <Gilles.Peskine@arm.com >
2021-11-03 15:48:15 +01:00
..
2021-06-14 16:17:32 +02:00
2021-10-19 22:32:44 +02:00
2021-07-20 13:36:16 +02:00
2019-08-15 15:44:50 +01:00
2019-08-15 15:44:50 +01:00
2019-08-15 15:44:50 +01:00
2021-09-27 16:22:08 +02:00
2019-08-15 15:44:50 +01:00
2021-05-27 17:27:14 +02:00
2019-08-15 15:44:50 +01:00
2021-05-27 17:35:04 +02:00
2021-05-28 12:56:57 +02:00
2020-02-05 15:40:22 +00:00
2021-06-22 12:44:05 +02:00
2019-10-31 19:17:36 +02:00
2021-04-07 16:31:09 +01:00
2021-10-25 22:15:19 +02:00
2021-10-25 22:15:19 +02:00
2021-05-27 17:35:04 +02:00
2021-05-27 17:35:04 +02:00
2021-09-06 12:09:34 +02:00
2021-09-17 09:38:07 +02:00
2021-05-27 17:27:14 +02:00
2021-05-27 17:27:14 +02:00
2021-05-27 17:27:14 +02:00
2021-05-27 17:27:14 +02:00
2021-09-29 19:50:07 +02:00
2019-07-29 17:46:29 +02:00
2020-03-24 13:18:58 -04:00
2019-08-15 15:44:50 +01:00
2019-08-15 15:44:50 +01:00
2019-08-15 15:44:50 +01:00
2019-09-20 15:59:31 +02:00
2021-09-29 19:50:07 +02:00
2020-06-26 22:40:58 +02:00
2019-08-15 15:44:50 +01:00
2019-09-20 16:01:59 +02:00
2019-09-20 15:59:31 +02:00
2021-06-16 10:34:25 +02:00
2019-08-15 15:44:50 +01:00
2019-08-15 15:44:50 +01:00
2019-11-21 13:49:20 +01:00
2021-06-08 16:45:41 +02:00
2021-06-17 21:46:29 +02:00
2021-08-10 13:34:32 +08:00
2019-08-15 15:44:50 +01:00
2021-09-27 16:22:08 +02:00
2021-06-22 12:47:21 +02:00
2021-06-22 12:44:05 +02:00
2021-06-07 15:41:49 +02:00
2021-06-22 12:44:05 +02:00
2021-05-27 17:27:14 +02:00
2021-06-25 00:46:22 +02:00
2021-03-17 11:36:31 +01:00
2021-05-27 17:34:14 +02:00
2021-07-12 20:47:11 +05:30
2021-06-22 12:44:05 +02:00
2021-05-11 13:15:19 +02:00
2021-04-07 16:31:09 +01:00
2021-10-04 13:54:55 +02:00
2021-10-04 13:54:55 +02:00
2019-09-20 15:59:31 +02:00
2019-09-20 15:59:31 +02:00
2019-09-20 15:59:31 +02:00
2019-09-20 15:59:31 +02:00
2019-08-15 15:44:50 +01:00
2021-10-21 14:55:59 +02:00
2021-05-27 17:35:04 +02:00
2021-06-16 10:34:45 +02:00
2021-03-10 12:52:37 +00:00
2020-11-25 14:25:56 -08:00
2021-05-10 13:51:53 +02:00
2021-05-10 13:51:53 +02:00
2021-04-28 14:38:37 +02:00
2021-04-28 14:38:37 +02:00
2021-06-16 10:34:25 +02:00
2020-07-01 17:10:15 +02:00
2021-06-16 10:34:25 +02:00
2021-06-16 10:34:25 +02:00
2019-10-31 15:07:35 +01:00
2019-10-31 15:07:45 +01:00
2021-06-22 12:47:21 +02:00
2021-06-22 12:47:21 +02:00
2021-03-29 14:20:18 +01:00
2021-03-29 14:20:18 +01:00
2021-02-25 15:56:48 +01:00
2021-09-24 09:21:29 +09:00
2021-06-21 13:27:29 +02:00
2020-06-26 10:45:16 +02:00
2021-05-10 13:51:53 +02:00
2021-04-27 17:18:52 +01:00
2019-08-15 15:44:50 +01:00
2019-08-15 15:44:50 +01:00
2021-05-27 17:27:14 +02:00
2021-06-25 00:46:22 +02:00
2021-05-12 15:18:20 +01:00
2021-06-24 10:28:20 +02:00
2021-04-28 14:38:37 +02:00
2021-06-22 18:39:53 +02:00
2021-04-28 14:38:37 +02:00
2020-06-12 14:33:08 +02:00
2021-06-18 12:59:38 +02:00
2021-06-17 09:38:38 +02:00
2019-11-05 15:32:53 +01:00
2021-06-17 09:38:38 +02:00
2021-05-27 17:27:14 +02:00
2021-05-27 17:27:14 +02:00
2021-03-24 09:26:44 +01:00
2021-02-01 13:17:23 +01:00
2021-06-29 19:55:24 +02:00
2021-09-24 11:18:13 +01:00
2021-03-10 13:19:45 -07:00
2021-04-19 10:55:21 +02:00
2021-06-16 10:34:25 +02:00
2021-01-06 18:21:18 +01:00
2019-10-23 19:47:05 +02:00
2021-06-15 15:47:44 +02:00
2021-11-03 15:48:15 +01:00
2021-11-03 15:48:15 +01:00
2021-10-11 10:43:17 +02:00
2021-02-17 14:50:17 +01:00
2021-06-23 13:43:08 +02:00
2021-06-23 13:43:08 +02:00
2020-05-11 11:15:26 +02:00
2021-01-06 18:21:18 +01:00
2021-09-21 11:59:39 +02:00
2021-02-23 20:36:07 +01:00
2021-08-17 02:46:00 +05:30
2021-06-29 17:06:33 +02:00
2021-06-23 13:44:35 +02:00
2021-07-13 17:12:53 +02:00
2021-11-02 16:51:24 +01:00
2021-11-03 15:48:15 +01:00
2020-11-26 15:54:35 +01:00
2021-03-10 17:00:32 +00:00
2021-02-16 15:46:06 +01:00
2021-05-11 13:15:19 +02:00
2021-06-22 12:47:21 +02:00
2021-06-25 11:17:12 +01:00
2021-05-27 17:35:04 +02:00
2021-06-08 16:45:41 +02:00
2021-10-29 14:07:46 +01:00
2021-10-29 14:07:46 +01:00
2021-06-15 15:47:44 +02:00
2021-06-15 15:47:44 +02:00
2021-06-30 23:09:51 +01:00
2020-04-22 16:01:48 +02:00
2021-06-18 12:59:38 +02:00
2021-06-07 13:52:23 +02:00
2021-06-16 10:34:25 +02:00
2021-06-22 12:44:05 +02:00