Skip to content

Commit

Permalink
import-object: Avoid integer truncation on 32-bit platforms
Browse files Browse the repository at this point in the history
The build fails when compiling for 32-bit platforms with
-Werror=incompatible-pointer-types:

  CFLAGS="-m32 -march=i686 -Werror=incompatible-pointer-types -Werror=implicit -Werror=int-conversion" setarch i686 -- meson setup _build
  setarch i686 -- meson compile -C _build -v
  ...

  ../p11-kit/import-object.c: In function ‘add_attrs_pubkey_rsa’:
  ../p11-kit/import-object.c:223:62: error: passing argument 3 of ‘p11_asn1_read’ from incompatible pointer type [-Werror=incompatible-pointer-types]
    223 |         attr_modulus.pValue = p11_asn1_read (asn, "modulus", &attr_modulus.ulValueLen);
        |                                                              ^~~~~~~~~~~~~~~~~~~~~~~~
        |                                                              |
        |                                                              long unsigned int *

Reported by Sam James in:
p11-glue#608

Signed-off-by: Daiki Ueno <[email protected]>
  • Loading branch information
ueno committed Dec 2, 2023
1 parent 58cd1c0 commit 6f05ca1
Showing 1 changed file with 28 additions and 4 deletions.
32 changes: 28 additions & 4 deletions p11-kit/import-object.c
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@
#endif

#include <assert.h>
#include <limits.h>
#include <stdbool.h>
#include <stdlib.h>
#include <string.h>
Expand Down Expand Up @@ -201,6 +202,7 @@ add_attrs_pubkey_rsa (CK_ATTRIBUTE *attrs,
CK_ATTRIBUTE attr_encrypt = { CKA_ENCRYPT, &tval, sizeof (tval) };
CK_ATTRIBUTE attr_modulus = { CKA_MODULUS, };
CK_ATTRIBUTE attr_exponent = { CKA_PUBLIC_EXPONENT, };
size_t len;

pubkey = p11_asn1_read (info, "subjectPublicKey", &pubkey_len);
if (pubkey == NULL) {
Expand All @@ -220,17 +222,31 @@ add_attrs_pubkey_rsa (CK_ATTRIBUTE *attrs,
goto cleanup;
}

attr_modulus.pValue = p11_asn1_read (asn, "modulus", &attr_modulus.ulValueLen);
attr_modulus.pValue = p11_asn1_read (asn, "modulus", &len);
if (attr_modulus.pValue == NULL) {
p11_message (_("failed to obtain modulus"));
goto cleanup;
}
#if ULONG_MAX < SIZE_MAX
if (len > ULONG_MAX) {
p11_message (_("failed to obtain modulus"));
goto cleanup;
}
#endif
attr_modulus.ulValueLen = len;

attr_exponent.pValue = p11_asn1_read (asn, "publicExponent", &attr_exponent.ulValueLen);
if (attr_exponent.pValue == NULL) {
attr_exponent.pValue = p11_asn1_read (asn, "publicExponent", &len);
if (attr_exponent.pValue == NULL || len > ULONG_MAX) {
p11_message (_("failed to obtain exponent"));
goto cleanup;
}
#if ULONG_MAX < SIZE_MAX
if (len > ULONG_MAX) {
p11_message (_("failed to obtain exponent"));
goto cleanup;
}
#endif
attr_exponent.ulValueLen = len;

result = p11_attrs_build (attrs, &attr_key_type, &attr_encrypt, &attr_modulus, &attr_exponent, NULL);
if (result == NULL) {
Expand Down Expand Up @@ -260,12 +276,20 @@ add_attrs_pubkey_ec (CK_ATTRIBUTE *attrs,
CK_ATTRIBUTE attr_key_type = { CKA_KEY_TYPE, &key_type, sizeof (key_type) };
CK_ATTRIBUTE attr_ec_params = { CKA_EC_PARAMS, };
CK_ATTRIBUTE attr_ec_point = { CKA_EC_POINT, };
size_t len;

attr_ec_params.pValue = p11_asn1_read (info, "algorithm.parameters", &attr_ec_params.ulValueLen);
attr_ec_params.pValue = p11_asn1_read (info, "algorithm.parameters", &len);
if (attr_ec_params.pValue == NULL) {
p11_message (_("failed to obtain EC parameters"));
goto cleanup;
}
#if ULONG_MAX < SIZE_MAX
if (len > ULONG_MAX) {
p11_message (_("failed to obtain EC parameters"));
goto cleanup;
}
#endif
attr_ec_params.ulValueLen = len;

/* subjectPublicKey is read as BIT STRING value which contains
* EC point data. We need to DER encode this data as OCTET STRING.
Expand Down

0 comments on commit 6f05ca1

Please sign in to comment.