Skip to content

Commit

Permalink
Fix nonce sizes for various AES-based encryption algorithms
Browse files Browse the repository at this point in the history
* fix: IV size for AES-GCM

* del: IV size for AES-KW
  • Loading branch information
kentakayama authored Jul 18, 2024
1 parent 1eeef3b commit 672a803
Showing 1 changed file with 8 additions and 8 deletions.
16 changes: 8 additions & 8 deletions src/t_cose_util.c
Original file line number Diff line number Diff line change
Expand Up @@ -256,20 +256,20 @@ uint32_t
bits_iv_alg(int32_t cose_algorithm_id)
{
switch(cose_algorithm_id) {
case T_COSE_ALGORITHM_AES128CCM_16_128:
case T_COSE_ALGORITHM_A128KW:
case T_COSE_ALGORITHM_A128GCM:
case T_COSE_ALGORITHM_A192GCM:
case T_COSE_ALGORITHM_A256GCM:
return 96; /* 12 bytes, 4.1 of RFC 9053 */
case T_COSE_ALGORITHM_AES128CCM_16_128:
case T_COSE_ALGORITHM_AES256CCM_16_128:
return 104; /* 13 bytes, 4.2 of RFC 9053 */
case T_COSE_ALGORITHM_A128CTR:
case T_COSE_ALGORITHM_A128CBC:
case T_COSE_ALGORITHM_A192CTR:
case T_COSE_ALGORITHM_A192CBC:
case T_COSE_ALGORITHM_A256CTR:
case T_COSE_ALGORITHM_A256CBC: return 128;
case T_COSE_ALGORITHM_A192KW:
case T_COSE_ALGORITHM_A192GCM: return 192;
case T_COSE_ALGORITHM_AES256CCM_16_128:
case T_COSE_ALGORITHM_A256KW:
case T_COSE_ALGORITHM_A256GCM: return 256;
case T_COSE_ALGORITHM_A256CBC:
return 128; /* 16 bytes, the same length of the AES block size */
default: return UINT32_MAX;
}
}
Expand Down

0 comments on commit 672a803

Please sign in to comment.