edhoc 1.0.1 → 1.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (659) hide show
  1. package/binding.gyp +64 -0
  2. package/external/libedhoc/backends/cbor/include/backend_cbor_bstr_type_decode.h +35 -0
  3. package/external/libedhoc/backends/cbor/include/backend_cbor_bstr_type_encode.h +35 -0
  4. package/external/libedhoc/backends/cbor/include/backend_cbor_bstr_type_types.h +34 -0
  5. package/external/libedhoc/backends/cbor/include/backend_cbor_ead_decode.h +35 -0
  6. package/external/libedhoc/backends/cbor/include/backend_cbor_ead_encode.h +35 -0
  7. package/external/libedhoc/backends/cbor/include/backend_cbor_edhoc_types.h +97 -0
  8. package/external/libedhoc/backends/cbor/include/backend_cbor_enc_structure_decode.h +35 -0
  9. package/external/libedhoc/backends/cbor/include/backend_cbor_enc_structure_encode.h +35 -0
  10. package/external/libedhoc/backends/cbor/include/backend_cbor_enc_structure_types.h +37 -0
  11. package/external/libedhoc/backends/cbor/include/backend_cbor_id_cred_x_decode.h +35 -0
  12. package/external/libedhoc/backends/cbor/include/backend_cbor_id_cred_x_encode.h +35 -0
  13. package/external/libedhoc/backends/cbor/include/backend_cbor_info_decode.h +35 -0
  14. package/external/libedhoc/backends/cbor/include/backend_cbor_info_encode.h +35 -0
  15. package/external/libedhoc/backends/cbor/include/backend_cbor_int_type_decode.h +35 -0
  16. package/external/libedhoc/backends/cbor/include/backend_cbor_int_type_encode.h +35 -0
  17. package/external/libedhoc/backends/cbor/include/backend_cbor_int_type_types.h +34 -0
  18. package/external/libedhoc/backends/cbor/include/backend_cbor_message_1_decode.h +35 -0
  19. package/external/libedhoc/backends/cbor/include/backend_cbor_message_1_encode.h +35 -0
  20. package/external/libedhoc/backends/cbor/include/backend_cbor_message_2_decode.h +35 -0
  21. package/external/libedhoc/backends/cbor/include/backend_cbor_message_2_encode.h +35 -0
  22. package/external/libedhoc/backends/cbor/include/backend_cbor_message_3_decode.h +35 -0
  23. package/external/libedhoc/backends/cbor/include/backend_cbor_message_3_encode.h +35 -0
  24. package/external/libedhoc/backends/cbor/include/backend_cbor_message_4_decode.h +35 -0
  25. package/external/libedhoc/backends/cbor/include/backend_cbor_message_4_encode.h +35 -0
  26. package/external/libedhoc/backends/cbor/include/backend_cbor_message_error_decode.h +35 -0
  27. package/external/libedhoc/backends/cbor/include/backend_cbor_message_error_encode.h +35 -0
  28. package/external/libedhoc/backends/cbor/include/backend_cbor_plaintext_2_decode.h +35 -0
  29. package/external/libedhoc/backends/cbor/include/backend_cbor_plaintext_2_encode.h +35 -0
  30. package/external/libedhoc/backends/cbor/include/backend_cbor_plaintext_3_decode.h +35 -0
  31. package/external/libedhoc/backends/cbor/include/backend_cbor_plaintext_3_encode.h +35 -0
  32. package/external/libedhoc/backends/cbor/include/backend_cbor_plaintext_4_decode.h +35 -0
  33. package/external/libedhoc/backends/cbor/include/backend_cbor_plaintext_4_encode.h +35 -0
  34. package/external/libedhoc/backends/cbor/include/backend_cbor_sig_structure_decode.h +35 -0
  35. package/external/libedhoc/backends/cbor/include/backend_cbor_sig_structure_encode.h +35 -0
  36. package/external/libedhoc/backends/cbor/include/backend_cbor_sig_structure_types.h +38 -0
  37. package/external/libedhoc/backends/cbor/include/backend_cbor_x509_types.h +170 -0
  38. package/external/libedhoc/backends/cbor/src/backend_cbor_bstr_type_decode.c +59 -0
  39. package/external/libedhoc/backends/cbor/src/backend_cbor_bstr_type_encode.c +59 -0
  40. package/external/libedhoc/backends/cbor/src/backend_cbor_ead_decode.c +74 -0
  41. package/external/libedhoc/backends/cbor/src/backend_cbor_ead_encode.c +74 -0
  42. package/external/libedhoc/backends/cbor/src/backend_cbor_enc_structure_decode.c +62 -0
  43. package/external/libedhoc/backends/cbor/src/backend_cbor_enc_structure_encode.c +62 -0
  44. package/external/libedhoc/backends/cbor/src/backend_cbor_id_cred_x_decode.c +141 -0
  45. package/external/libedhoc/backends/cbor/src/backend_cbor_id_cred_x_encode.c +141 -0
  46. package/external/libedhoc/backends/cbor/src/backend_cbor_info_decode.c +61 -0
  47. package/external/libedhoc/backends/cbor/src/backend_cbor_info_encode.c +61 -0
  48. package/external/libedhoc/backends/cbor/src/backend_cbor_int_type_decode.c +59 -0
  49. package/external/libedhoc/backends/cbor/src/backend_cbor_int_type_encode.c +59 -0
  50. package/external/libedhoc/backends/cbor/src/backend_cbor_message_1_decode.c +112 -0
  51. package/external/libedhoc/backends/cbor/src/backend_cbor_message_1_encode.c +112 -0
  52. package/external/libedhoc/backends/cbor/src/backend_cbor_message_2_decode.c +59 -0
  53. package/external/libedhoc/backends/cbor/src/backend_cbor_message_2_encode.c +59 -0
  54. package/external/libedhoc/backends/cbor/src/backend_cbor_message_3_decode.c +59 -0
  55. package/external/libedhoc/backends/cbor/src/backend_cbor_message_3_encode.c +59 -0
  56. package/external/libedhoc/backends/cbor/src/backend_cbor_message_4_decode.c +59 -0
  57. package/external/libedhoc/backends/cbor/src/backend_cbor_message_4_encode.c +59 -0
  58. package/external/libedhoc/backends/cbor/src/backend_cbor_message_error_decode.c +93 -0
  59. package/external/libedhoc/backends/cbor/src/backend_cbor_message_error_encode.c +93 -0
  60. package/external/libedhoc/backends/cbor/src/backend_cbor_plaintext_2_decode.c +193 -0
  61. package/external/libedhoc/backends/cbor/src/backend_cbor_plaintext_2_encode.c +194 -0
  62. package/external/libedhoc/backends/cbor/src/backend_cbor_plaintext_3_decode.c +189 -0
  63. package/external/libedhoc/backends/cbor/src/backend_cbor_plaintext_3_encode.c +189 -0
  64. package/external/libedhoc/backends/cbor/src/backend_cbor_plaintext_4_decode.c +88 -0
  65. package/external/libedhoc/backends/cbor/src/backend_cbor_plaintext_4_encode.c +88 -0
  66. package/external/libedhoc/backends/cbor/src/backend_cbor_sig_structure_decode.c +63 -0
  67. package/external/libedhoc/backends/cbor/src/backend_cbor_sig_structure_encode.c +63 -0
  68. package/external/libedhoc/externals/compact25519/src/c25519/c25519.c +126 -0
  69. package/external/libedhoc/externals/compact25519/src/c25519/c25519.h +49 -0
  70. package/external/libedhoc/externals/compact25519/src/c25519/ed25519.c +323 -0
  71. package/external/libedhoc/externals/compact25519/src/c25519/ed25519.h +84 -0
  72. package/external/libedhoc/externals/compact25519/src/c25519/edsign.c +171 -0
  73. package/external/libedhoc/externals/compact25519/src/c25519/edsign.h +53 -0
  74. package/external/libedhoc/externals/compact25519/src/c25519/f25519.c +330 -0
  75. package/external/libedhoc/externals/compact25519/src/c25519/f25519.h +98 -0
  76. package/external/libedhoc/externals/compact25519/src/c25519/fprime.c +226 -0
  77. package/external/libedhoc/externals/compact25519/src/c25519/fprime.h +81 -0
  78. package/external/libedhoc/externals/compact25519/src/c25519/sha512.c +230 -0
  79. package/external/libedhoc/externals/compact25519/src/c25519/sha512.h +54 -0
  80. package/external/libedhoc/externals/compact25519/src/compact_ed25519.c +46 -0
  81. package/external/libedhoc/externals/compact25519/src/compact_ed25519.h +110 -0
  82. package/external/libedhoc/externals/compact25519/src/compact_wipe.c +12 -0
  83. package/external/libedhoc/externals/compact25519/src/compact_wipe.h +14 -0
  84. package/external/libedhoc/externals/compact25519/src/compact_x25519.c +68 -0
  85. package/external/libedhoc/externals/compact25519/src/compact_x25519.h +101 -0
  86. package/external/libedhoc/externals/compact25519/test/pcg_random.h +25 -0
  87. package/external/libedhoc/externals/compact25519/test/run-all.c +178 -0
  88. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/Hacl_Curve25519.h +21 -0
  89. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/everest.h +234 -0
  90. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/kremlib/FStar_UInt128.h +124 -0
  91. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/kremlib/FStar_UInt64_FStar_UInt32_FStar_UInt16_FStar_UInt8.h +280 -0
  92. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/kremlib.h +29 -0
  93. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/kremlin/c_endianness.h +204 -0
  94. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/kremlin/internal/builtin.h +16 -0
  95. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/kremlin/internal/callconv.h +46 -0
  96. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/kremlin/internal/compat.h +34 -0
  97. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/kremlin/internal/debug.h +57 -0
  98. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/kremlin/internal/target.h +102 -0
  99. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/kremlin/internal/types.h +61 -0
  100. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/kremlin/internal/wasmsupport.h +5 -0
  101. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/vs2013/Hacl_Curve25519.h +21 -0
  102. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/vs2013/inttypes.h +36 -0
  103. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/vs2013/stdbool.h +31 -0
  104. package/external/libedhoc/externals/mbedtls/3rdparty/everest/include/everest/x25519.h +190 -0
  105. package/external/libedhoc/externals/mbedtls/3rdparty/everest/library/Hacl_Curve25519.c +760 -0
  106. package/external/libedhoc/externals/mbedtls/3rdparty/everest/library/Hacl_Curve25519_joined.c +50 -0
  107. package/external/libedhoc/externals/mbedtls/3rdparty/everest/library/everest.c +102 -0
  108. package/external/libedhoc/externals/mbedtls/3rdparty/everest/library/kremlib/FStar_UInt128_extracted.c +413 -0
  109. package/external/libedhoc/externals/mbedtls/3rdparty/everest/library/kremlib/FStar_UInt64_FStar_UInt32_FStar_UInt16_FStar_UInt8.c +100 -0
  110. package/external/libedhoc/externals/mbedtls/3rdparty/everest/library/legacy/Hacl_Curve25519.c +805 -0
  111. package/external/libedhoc/externals/mbedtls/3rdparty/everest/library/x25519.c +186 -0
  112. package/external/libedhoc/externals/mbedtls/3rdparty/p256-m/p256-m/p256-m.c +1514 -0
  113. package/external/libedhoc/externals/mbedtls/3rdparty/p256-m/p256-m/p256-m.h +135 -0
  114. package/external/libedhoc/externals/mbedtls/3rdparty/p256-m/p256-m_driver_entrypoints.c +312 -0
  115. package/external/libedhoc/externals/mbedtls/3rdparty/p256-m/p256-m_driver_entrypoints.h +219 -0
  116. package/external/libedhoc/externals/mbedtls/configs/config-ccm-psk-dtls1_2.h +92 -0
  117. package/external/libedhoc/externals/mbedtls/configs/config-ccm-psk-tls1_2.h +83 -0
  118. package/external/libedhoc/externals/mbedtls/configs/config-no-entropy.h +73 -0
  119. package/external/libedhoc/externals/mbedtls/configs/config-suite-b.h +106 -0
  120. package/external/libedhoc/externals/mbedtls/configs/config-symmetric-only.h +77 -0
  121. package/external/libedhoc/externals/mbedtls/configs/config-thread.h +76 -0
  122. package/external/libedhoc/externals/mbedtls/configs/crypto-config-ccm-aes-sha256.h +25 -0
  123. package/external/libedhoc/externals/mbedtls/configs/crypto_config_profile_medium.h +136 -0
  124. package/external/libedhoc/externals/mbedtls/configs/tfm_mbedcrypto_config_profile_medium.h +609 -0
  125. package/external/libedhoc/externals/mbedtls/doxygen/input/doc_encdec.h +54 -0
  126. package/external/libedhoc/externals/mbedtls/doxygen/input/doc_hashing.h +30 -0
  127. package/external/libedhoc/externals/mbedtls/doxygen/input/doc_mainpage.h +19 -0
  128. package/external/libedhoc/externals/mbedtls/doxygen/input/doc_rng.h +27 -0
  129. package/external/libedhoc/externals/mbedtls/doxygen/input/doc_ssltls.h +37 -0
  130. package/external/libedhoc/externals/mbedtls/doxygen/input/doc_tcpip.h +32 -0
  131. package/external/libedhoc/externals/mbedtls/doxygen/input/doc_x509.h +31 -0
  132. package/external/libedhoc/externals/mbedtls/include/mbedtls/aes.h +627 -0
  133. package/external/libedhoc/externals/mbedtls/include/mbedtls/aria.h +341 -0
  134. package/external/libedhoc/externals/mbedtls/include/mbedtls/asn1.h +641 -0
  135. package/external/libedhoc/externals/mbedtls/include/mbedtls/asn1write.h +389 -0
  136. package/external/libedhoc/externals/mbedtls/include/mbedtls/base64.h +82 -0
  137. package/external/libedhoc/externals/mbedtls/include/mbedtls/bignum.h +1084 -0
  138. package/external/libedhoc/externals/mbedtls/include/mbedtls/build_info.h +146 -0
  139. package/external/libedhoc/externals/mbedtls/include/mbedtls/camellia.h +303 -0
  140. package/external/libedhoc/externals/mbedtls/include/mbedtls/ccm.h +518 -0
  141. package/external/libedhoc/externals/mbedtls/include/mbedtls/chacha20.h +202 -0
  142. package/external/libedhoc/externals/mbedtls/include/mbedtls/chachapoly.h +342 -0
  143. package/external/libedhoc/externals/mbedtls/include/mbedtls/check_config.h +1206 -0
  144. package/external/libedhoc/externals/mbedtls/include/mbedtls/cipher.h +1183 -0
  145. package/external/libedhoc/externals/mbedtls/include/mbedtls/cmac.h +246 -0
  146. package/external/libedhoc/externals/mbedtls/include/mbedtls/compat-2.x.h +46 -0
  147. package/external/libedhoc/externals/mbedtls/include/mbedtls/config_adjust_legacy_crypto.h +183 -0
  148. package/external/libedhoc/externals/mbedtls/include/mbedtls/config_adjust_legacy_from_psa.h +877 -0
  149. package/external/libedhoc/externals/mbedtls/include/mbedtls/config_adjust_psa_from_legacy.h +334 -0
  150. package/external/libedhoc/externals/mbedtls/include/mbedtls/config_adjust_psa_superset_legacy.h +142 -0
  151. package/external/libedhoc/externals/mbedtls/include/mbedtls/config_adjust_ssl.h +76 -0
  152. package/external/libedhoc/externals/mbedtls/include/mbedtls/config_adjust_x509.h +25 -0
  153. package/external/libedhoc/externals/mbedtls/include/mbedtls/config_psa.h +55 -0
  154. package/external/libedhoc/externals/mbedtls/include/mbedtls/constant_time.h +36 -0
  155. package/external/libedhoc/externals/mbedtls/include/mbedtls/ctr_drbg.h +564 -0
  156. package/external/libedhoc/externals/mbedtls/include/mbedtls/debug.h +308 -0
  157. package/external/libedhoc/externals/mbedtls/include/mbedtls/des.h +385 -0
  158. package/external/libedhoc/externals/mbedtls/include/mbedtls/dhm.h +972 -0
  159. package/external/libedhoc/externals/mbedtls/include/mbedtls/ecdh.h +441 -0
  160. package/external/libedhoc/externals/mbedtls/include/mbedtls/ecdsa.h +671 -0
  161. package/external/libedhoc/externals/mbedtls/include/mbedtls/ecjpake.h +298 -0
  162. package/external/libedhoc/externals/mbedtls/include/mbedtls/ecp.h +1362 -0
  163. package/external/libedhoc/externals/mbedtls/include/mbedtls/entropy.h +273 -0
  164. package/external/libedhoc/externals/mbedtls/include/mbedtls/error.h +201 -0
  165. package/external/libedhoc/externals/mbedtls/include/mbedtls/gcm.h +370 -0
  166. package/external/libedhoc/externals/mbedtls/include/mbedtls/hkdf.h +124 -0
  167. package/external/libedhoc/externals/mbedtls/include/mbedtls/hmac_drbg.h +434 -0
  168. package/external/libedhoc/externals/mbedtls/include/mbedtls/lms.h +440 -0
  169. package/external/libedhoc/externals/mbedtls/include/mbedtls/mbedtls_config.h +4116 -0
  170. package/external/libedhoc/externals/mbedtls/include/mbedtls/md.h +640 -0
  171. package/external/libedhoc/externals/mbedtls/include/mbedtls/md5.h +190 -0
  172. package/external/libedhoc/externals/mbedtls/include/mbedtls/memory_buffer_alloc.h +142 -0
  173. package/external/libedhoc/externals/mbedtls/include/mbedtls/net_sockets.h +299 -0
  174. package/external/libedhoc/externals/mbedtls/include/mbedtls/nist_kw.h +166 -0
  175. package/external/libedhoc/externals/mbedtls/include/mbedtls/oid.h +722 -0
  176. package/external/libedhoc/externals/mbedtls/include/mbedtls/pem.h +160 -0
  177. package/external/libedhoc/externals/mbedtls/include/mbedtls/pk.h +1091 -0
  178. package/external/libedhoc/externals/mbedtls/include/mbedtls/pkcs12.h +186 -0
  179. package/external/libedhoc/externals/mbedtls/include/mbedtls/pkcs5.h +197 -0
  180. package/external/libedhoc/externals/mbedtls/include/mbedtls/pkcs7.h +241 -0
  181. package/external/libedhoc/externals/mbedtls/include/mbedtls/platform.h +485 -0
  182. package/external/libedhoc/externals/mbedtls/include/mbedtls/platform_time.h +79 -0
  183. package/external/libedhoc/externals/mbedtls/include/mbedtls/platform_util.h +201 -0
  184. package/external/libedhoc/externals/mbedtls/include/mbedtls/poly1305.h +168 -0
  185. package/external/libedhoc/externals/mbedtls/include/mbedtls/private_access.h +20 -0
  186. package/external/libedhoc/externals/mbedtls/include/mbedtls/psa_util.h +104 -0
  187. package/external/libedhoc/externals/mbedtls/include/mbedtls/ripemd160.h +136 -0
  188. package/external/libedhoc/externals/mbedtls/include/mbedtls/rsa.h +1143 -0
  189. package/external/libedhoc/externals/mbedtls/include/mbedtls/sha1.h +219 -0
  190. package/external/libedhoc/externals/mbedtls/include/mbedtls/sha256.h +198 -0
  191. package/external/libedhoc/externals/mbedtls/include/mbedtls/sha3.h +172 -0
  192. package/external/libedhoc/externals/mbedtls/include/mbedtls/sha512.h +208 -0
  193. package/external/libedhoc/externals/mbedtls/include/mbedtls/ssl.h +5369 -0
  194. package/external/libedhoc/externals/mbedtls/include/mbedtls/ssl_cache.h +187 -0
  195. package/external/libedhoc/externals/mbedtls/include/mbedtls/ssl_ciphersuites.h +616 -0
  196. package/external/libedhoc/externals/mbedtls/include/mbedtls/ssl_cookie.h +106 -0
  197. package/external/libedhoc/externals/mbedtls/include/mbedtls/ssl_ticket.h +181 -0
  198. package/external/libedhoc/externals/mbedtls/include/mbedtls/threading.h +105 -0
  199. package/external/libedhoc/externals/mbedtls/include/mbedtls/timing.h +94 -0
  200. package/external/libedhoc/externals/mbedtls/include/mbedtls/version.h +78 -0
  201. package/external/libedhoc/externals/mbedtls/include/mbedtls/x509.h +550 -0
  202. package/external/libedhoc/externals/mbedtls/include/mbedtls/x509_crl.h +184 -0
  203. package/external/libedhoc/externals/mbedtls/include/mbedtls/x509_crt.h +1196 -0
  204. package/external/libedhoc/externals/mbedtls/include/mbedtls/x509_csr.h +319 -0
  205. package/external/libedhoc/externals/mbedtls/include/psa/build_info.h +20 -0
  206. package/external/libedhoc/externals/mbedtls/include/psa/crypto.h +4685 -0
  207. package/external/libedhoc/externals/mbedtls/include/psa/crypto_adjust_auto_enabled.h +21 -0
  208. package/external/libedhoc/externals/mbedtls/include/psa/crypto_adjust_config_key_pair_types.h +91 -0
  209. package/external/libedhoc/externals/mbedtls/include/psa/crypto_adjust_config_synonyms.h +45 -0
  210. package/external/libedhoc/externals/mbedtls/include/psa/crypto_builtin_composites.h +210 -0
  211. package/external/libedhoc/externals/mbedtls/include/psa/crypto_builtin_key_derivation.h +118 -0
  212. package/external/libedhoc/externals/mbedtls/include/psa/crypto_builtin_primitives.h +114 -0
  213. package/external/libedhoc/externals/mbedtls/include/psa/crypto_compat.h +153 -0
  214. package/external/libedhoc/externals/mbedtls/include/psa/crypto_config.h +153 -0
  215. package/external/libedhoc/externals/mbedtls/include/psa/crypto_driver_common.h +44 -0
  216. package/external/libedhoc/externals/mbedtls/include/psa/crypto_driver_contexts_composites.h +151 -0
  217. package/external/libedhoc/externals/mbedtls/include/psa/crypto_driver_contexts_key_derivation.h +52 -0
  218. package/external/libedhoc/externals/mbedtls/include/psa/crypto_driver_contexts_primitives.h +105 -0
  219. package/external/libedhoc/externals/mbedtls/include/psa/crypto_extra.h +2064 -0
  220. package/external/libedhoc/externals/mbedtls/include/psa/crypto_legacy.h +88 -0
  221. package/external/libedhoc/externals/mbedtls/include/psa/crypto_platform.h +92 -0
  222. package/external/libedhoc/externals/mbedtls/include/psa/crypto_se_driver.h +1383 -0
  223. package/external/libedhoc/externals/mbedtls/include/psa/crypto_sizes.h +1282 -0
  224. package/external/libedhoc/externals/mbedtls/include/psa/crypto_struct.h +460 -0
  225. package/external/libedhoc/externals/mbedtls/include/psa/crypto_types.h +453 -0
  226. package/external/libedhoc/externals/mbedtls/include/psa/crypto_values.h +2756 -0
  227. package/external/libedhoc/externals/mbedtls/library/aes.c +2315 -0
  228. package/external/libedhoc/externals/mbedtls/library/aesce.c +503 -0
  229. package/external/libedhoc/externals/mbedtls/library/aesce.h +121 -0
  230. package/external/libedhoc/externals/mbedtls/library/aesni.c +802 -0
  231. package/external/libedhoc/externals/mbedtls/library/aesni.h +158 -0
  232. package/external/libedhoc/externals/mbedtls/library/alignment.h +509 -0
  233. package/external/libedhoc/externals/mbedtls/library/aria.c +991 -0
  234. package/external/libedhoc/externals/mbedtls/library/asn1parse.c +467 -0
  235. package/external/libedhoc/externals/mbedtls/library/asn1write.c +436 -0
  236. package/external/libedhoc/externals/mbedtls/library/base64.c +299 -0
  237. package/external/libedhoc/externals/mbedtls/library/base64_internal.h +45 -0
  238. package/external/libedhoc/externals/mbedtls/library/bignum.c +2806 -0
  239. package/external/libedhoc/externals/mbedtls/library/bignum_core.c +894 -0
  240. package/external/libedhoc/externals/mbedtls/library/bignum_core.h +763 -0
  241. package/external/libedhoc/externals/mbedtls/library/bignum_mod.c +394 -0
  242. package/external/libedhoc/externals/mbedtls/library/bignum_mod.h +452 -0
  243. package/external/libedhoc/externals/mbedtls/library/bignum_mod_raw.c +276 -0
  244. package/external/libedhoc/externals/mbedtls/library/bignum_mod_raw.h +416 -0
  245. package/external/libedhoc/externals/mbedtls/library/bignum_mod_raw_invasive.h +34 -0
  246. package/external/libedhoc/externals/mbedtls/library/bn_mul.h +1094 -0
  247. package/external/libedhoc/externals/mbedtls/library/camellia.c +1044 -0
  248. package/external/libedhoc/externals/mbedtls/library/ccm.c +712 -0
  249. package/external/libedhoc/externals/mbedtls/library/chacha20.c +497 -0
  250. package/external/libedhoc/externals/mbedtls/library/chachapoly.c +478 -0
  251. package/external/libedhoc/externals/mbedtls/library/check_crypto_config.h +141 -0
  252. package/external/libedhoc/externals/mbedtls/library/cipher.c +1664 -0
  253. package/external/libedhoc/externals/mbedtls/library/cipher_wrap.c +2422 -0
  254. package/external/libedhoc/externals/mbedtls/library/cipher_wrap.h +132 -0
  255. package/external/libedhoc/externals/mbedtls/library/cmac.c +1067 -0
  256. package/external/libedhoc/externals/mbedtls/library/common.h +325 -0
  257. package/external/libedhoc/externals/mbedtls/library/constant_time.c +261 -0
  258. package/external/libedhoc/externals/mbedtls/library/constant_time_impl.h +554 -0
  259. package/external/libedhoc/externals/mbedtls/library/constant_time_internal.h +579 -0
  260. package/external/libedhoc/externals/mbedtls/library/ctr_drbg.c +881 -0
  261. package/external/libedhoc/externals/mbedtls/library/debug.c +465 -0
  262. package/external/libedhoc/externals/mbedtls/library/des.c +1042 -0
  263. package/external/libedhoc/externals/mbedtls/library/dhm.c +712 -0
  264. package/external/libedhoc/externals/mbedtls/library/ecdh.c +685 -0
  265. package/external/libedhoc/externals/mbedtls/library/ecdsa.c +867 -0
  266. package/external/libedhoc/externals/mbedtls/library/ecjpake.c +1216 -0
  267. package/external/libedhoc/externals/mbedtls/library/ecp.c +3631 -0
  268. package/external/libedhoc/externals/mbedtls/library/ecp_curves.c +5467 -0
  269. package/external/libedhoc/externals/mbedtls/library/ecp_curves_new.c +6043 -0
  270. package/external/libedhoc/externals/mbedtls/library/ecp_internal_alt.h +287 -0
  271. package/external/libedhoc/externals/mbedtls/library/ecp_invasive.h +325 -0
  272. package/external/libedhoc/externals/mbedtls/library/entropy.c +676 -0
  273. package/external/libedhoc/externals/mbedtls/library/entropy_poll.c +229 -0
  274. package/external/libedhoc/externals/mbedtls/library/entropy_poll.h +64 -0
  275. package/external/libedhoc/externals/mbedtls/library/error.c +878 -0
  276. package/external/libedhoc/externals/mbedtls/library/gcm.c +1168 -0
  277. package/external/libedhoc/externals/mbedtls/library/hkdf.c +161 -0
  278. package/external/libedhoc/externals/mbedtls/library/hmac_drbg.c +633 -0
  279. package/external/libedhoc/externals/mbedtls/library/lmots.c +821 -0
  280. package/external/libedhoc/externals/mbedtls/library/lmots.h +311 -0
  281. package/external/libedhoc/externals/mbedtls/library/lms.c +779 -0
  282. package/external/libedhoc/externals/mbedtls/library/md.c +1108 -0
  283. package/external/libedhoc/externals/mbedtls/library/md5.c +426 -0
  284. package/external/libedhoc/externals/mbedtls/library/md_psa.h +63 -0
  285. package/external/libedhoc/externals/mbedtls/library/md_wrap.h +46 -0
  286. package/external/libedhoc/externals/mbedtls/library/memory_buffer_alloc.c +745 -0
  287. package/external/libedhoc/externals/mbedtls/library/mps_common.h +181 -0
  288. package/external/libedhoc/externals/mbedtls/library/mps_error.h +89 -0
  289. package/external/libedhoc/externals/mbedtls/library/mps_reader.c +538 -0
  290. package/external/libedhoc/externals/mbedtls/library/mps_reader.h +366 -0
  291. package/external/libedhoc/externals/mbedtls/library/mps_trace.c +112 -0
  292. package/external/libedhoc/externals/mbedtls/library/mps_trace.h +154 -0
  293. package/external/libedhoc/externals/mbedtls/library/net_sockets.c +696 -0
  294. package/external/libedhoc/externals/mbedtls/library/nist_kw.c +725 -0
  295. package/external/libedhoc/externals/mbedtls/library/oid.c +1154 -0
  296. package/external/libedhoc/externals/mbedtls/library/padlock.c +155 -0
  297. package/external/libedhoc/externals/mbedtls/library/padlock.h +111 -0
  298. package/external/libedhoc/externals/mbedtls/library/pem.c +520 -0
  299. package/external/libedhoc/externals/mbedtls/library/pk.c +970 -0
  300. package/external/libedhoc/externals/mbedtls/library/pk_internal.h +118 -0
  301. package/external/libedhoc/externals/mbedtls/library/pk_wrap.c +1834 -0
  302. package/external/libedhoc/externals/mbedtls/library/pk_wrap.h +156 -0
  303. package/external/libedhoc/externals/mbedtls/library/pkcs12.c +447 -0
  304. package/external/libedhoc/externals/mbedtls/library/pkcs5.c +496 -0
  305. package/external/libedhoc/externals/mbedtls/library/pkcs7.c +773 -0
  306. package/external/libedhoc/externals/mbedtls/library/pkparse.c +1845 -0
  307. package/external/libedhoc/externals/mbedtls/library/pkwrite.c +836 -0
  308. package/external/libedhoc/externals/mbedtls/library/pkwrite.h +112 -0
  309. package/external/libedhoc/externals/mbedtls/library/platform.c +402 -0
  310. package/external/libedhoc/externals/mbedtls/library/platform_util.c +285 -0
  311. package/external/libedhoc/externals/mbedtls/library/poly1305.c +492 -0
  312. package/external/libedhoc/externals/mbedtls/library/psa_crypto.c +8432 -0
  313. package/external/libedhoc/externals/mbedtls/library/psa_crypto_aead.c +653 -0
  314. package/external/libedhoc/externals/mbedtls/library/psa_crypto_aead.h +499 -0
  315. package/external/libedhoc/externals/mbedtls/library/psa_crypto_cipher.c +590 -0
  316. package/external/libedhoc/externals/mbedtls/library/psa_crypto_cipher.h +293 -0
  317. package/external/libedhoc/externals/mbedtls/library/psa_crypto_client.c +67 -0
  318. package/external/libedhoc/externals/mbedtls/library/psa_crypto_core.h +838 -0
  319. package/external/libedhoc/externals/mbedtls/library/psa_crypto_core_common.h +52 -0
  320. package/external/libedhoc/externals/mbedtls/library/psa_crypto_driver_wrappers.h +2871 -0
  321. package/external/libedhoc/externals/mbedtls/library/psa_crypto_driver_wrappers_no_static.c +256 -0
  322. package/external/libedhoc/externals/mbedtls/library/psa_crypto_driver_wrappers_no_static.h +31 -0
  323. package/external/libedhoc/externals/mbedtls/library/psa_crypto_ecp.c +561 -0
  324. package/external/libedhoc/externals/mbedtls/library/psa_crypto_ecp.h +267 -0
  325. package/external/libedhoc/externals/mbedtls/library/psa_crypto_ffdh.c +295 -0
  326. package/external/libedhoc/externals/mbedtls/library/psa_crypto_ffdh.h +132 -0
  327. package/external/libedhoc/externals/mbedtls/library/psa_crypto_hash.c +470 -0
  328. package/external/libedhoc/externals/mbedtls/library/psa_crypto_hash.h +211 -0
  329. package/external/libedhoc/externals/mbedtls/library/psa_crypto_invasive.h +70 -0
  330. package/external/libedhoc/externals/mbedtls/library/psa_crypto_its.h +131 -0
  331. package/external/libedhoc/externals/mbedtls/library/psa_crypto_mac.c +496 -0
  332. package/external/libedhoc/externals/mbedtls/library/psa_crypto_mac.h +264 -0
  333. package/external/libedhoc/externals/mbedtls/library/psa_crypto_pake.c +571 -0
  334. package/external/libedhoc/externals/mbedtls/library/psa_crypto_pake.h +159 -0
  335. package/external/libedhoc/externals/mbedtls/library/psa_crypto_random_impl.h +192 -0
  336. package/external/libedhoc/externals/mbedtls/library/psa_crypto_rsa.c +727 -0
  337. package/external/libedhoc/externals/mbedtls/library/psa_crypto_rsa.h +317 -0
  338. package/external/libedhoc/externals/mbedtls/library/psa_crypto_se.c +373 -0
  339. package/external/libedhoc/externals/mbedtls/library/psa_crypto_se.h +185 -0
  340. package/external/libedhoc/externals/mbedtls/library/psa_crypto_slot_management.c +559 -0
  341. package/external/libedhoc/externals/mbedtls/library/psa_crypto_slot_management.h +213 -0
  342. package/external/libedhoc/externals/mbedtls/library/psa_crypto_storage.c +481 -0
  343. package/external/libedhoc/externals/mbedtls/library/psa_crypto_storage.h +384 -0
  344. package/external/libedhoc/externals/mbedtls/library/psa_its_file.c +259 -0
  345. package/external/libedhoc/externals/mbedtls/library/psa_util.c +160 -0
  346. package/external/libedhoc/externals/mbedtls/library/psa_util_internal.h +96 -0
  347. package/external/libedhoc/externals/mbedtls/library/ripemd160.c +490 -0
  348. package/external/libedhoc/externals/mbedtls/library/rsa.c +2640 -0
  349. package/external/libedhoc/externals/mbedtls/library/rsa_alt_helpers.c +447 -0
  350. package/external/libedhoc/externals/mbedtls/library/rsa_alt_helpers.h +208 -0
  351. package/external/libedhoc/externals/mbedtls/library/sha1.c +480 -0
  352. package/external/libedhoc/externals/mbedtls/library/sha256.c +946 -0
  353. package/external/libedhoc/externals/mbedtls/library/sha3.c +626 -0
  354. package/external/libedhoc/externals/mbedtls/library/sha512.c +1111 -0
  355. package/external/libedhoc/externals/mbedtls/library/ssl_cache.c +410 -0
  356. package/external/libedhoc/externals/mbedtls/library/ssl_ciphersuites.c +2050 -0
  357. package/external/libedhoc/externals/mbedtls/library/ssl_client.c +1017 -0
  358. package/external/libedhoc/externals/mbedtls/library/ssl_client.h +22 -0
  359. package/external/libedhoc/externals/mbedtls/library/ssl_cookie.c +380 -0
  360. package/external/libedhoc/externals/mbedtls/library/ssl_debug_helpers.h +78 -0
  361. package/external/libedhoc/externals/mbedtls/library/ssl_debug_helpers_generated.c +234 -0
  362. package/external/libedhoc/externals/mbedtls/library/ssl_misc.h +2847 -0
  363. package/external/libedhoc/externals/mbedtls/library/ssl_msg.c +6155 -0
  364. package/external/libedhoc/externals/mbedtls/library/ssl_ticket.c +540 -0
  365. package/external/libedhoc/externals/mbedtls/library/ssl_tls.c +9577 -0
  366. package/external/libedhoc/externals/mbedtls/library/ssl_tls12_client.c +3607 -0
  367. package/external/libedhoc/externals/mbedtls/library/ssl_tls12_server.c +4403 -0
  368. package/external/libedhoc/externals/mbedtls/library/ssl_tls13_client.c +3046 -0
  369. package/external/libedhoc/externals/mbedtls/library/ssl_tls13_generic.c +1740 -0
  370. package/external/libedhoc/externals/mbedtls/library/ssl_tls13_invasive.h +23 -0
  371. package/external/libedhoc/externals/mbedtls/library/ssl_tls13_keys.c +1897 -0
  372. package/external/libedhoc/externals/mbedtls/library/ssl_tls13_keys.h +651 -0
  373. package/external/libedhoc/externals/mbedtls/library/ssl_tls13_server.c +3146 -0
  374. package/external/libedhoc/externals/mbedtls/library/threading.c +181 -0
  375. package/external/libedhoc/externals/mbedtls/library/timing.c +154 -0
  376. package/external/libedhoc/externals/mbedtls/library/version.c +32 -0
  377. package/external/libedhoc/externals/mbedtls/library/version_features.c +826 -0
  378. package/external/libedhoc/externals/mbedtls/library/x509.c +1776 -0
  379. package/external/libedhoc/externals/mbedtls/library/x509_create.c +557 -0
  380. package/external/libedhoc/externals/mbedtls/library/x509_crl.c +712 -0
  381. package/external/libedhoc/externals/mbedtls/library/x509_crt.c +3292 -0
  382. package/external/libedhoc/externals/mbedtls/library/x509_csr.c +574 -0
  383. package/external/libedhoc/externals/mbedtls/library/x509write.c +174 -0
  384. package/external/libedhoc/externals/mbedtls/library/x509write_crt.c +681 -0
  385. package/external/libedhoc/externals/mbedtls/library/x509write_csr.c +331 -0
  386. package/external/libedhoc/externals/mbedtls/programs/aes/crypt_and_hash.c +573 -0
  387. package/external/libedhoc/externals/mbedtls/programs/cipher/cipher_aead_demo.c +259 -0
  388. package/external/libedhoc/externals/mbedtls/programs/fuzz/common.c +105 -0
  389. package/external/libedhoc/externals/mbedtls/programs/fuzz/common.h +25 -0
  390. package/external/libedhoc/externals/mbedtls/programs/fuzz/fuzz_client.c +195 -0
  391. package/external/libedhoc/externals/mbedtls/programs/fuzz/fuzz_dtlsclient.c +138 -0
  392. package/external/libedhoc/externals/mbedtls/programs/fuzz/fuzz_dtlsserver.c +183 -0
  393. package/external/libedhoc/externals/mbedtls/programs/fuzz/fuzz_pkcs7.c +20 -0
  394. package/external/libedhoc/externals/mbedtls/programs/fuzz/fuzz_privkey.c +106 -0
  395. package/external/libedhoc/externals/mbedtls/programs/fuzz/fuzz_pubkey.c +86 -0
  396. package/external/libedhoc/externals/mbedtls/programs/fuzz/fuzz_server.c +218 -0
  397. package/external/libedhoc/externals/mbedtls/programs/fuzz/fuzz_x509crl.c +41 -0
  398. package/external/libedhoc/externals/mbedtls/programs/fuzz/fuzz_x509crt.c +41 -0
  399. package/external/libedhoc/externals/mbedtls/programs/fuzz/fuzz_x509csr.c +41 -0
  400. package/external/libedhoc/externals/mbedtls/programs/fuzz/onefile.c +69 -0
  401. package/external/libedhoc/externals/mbedtls/programs/hash/generic_sum.c +209 -0
  402. package/external/libedhoc/externals/mbedtls/programs/hash/hello.c +45 -0
  403. package/external/libedhoc/externals/mbedtls/programs/hash/md_hmac_demo.c +136 -0
  404. package/external/libedhoc/externals/mbedtls/programs/pkey/dh_client.c +274 -0
  405. package/external/libedhoc/externals/mbedtls/programs/pkey/dh_genprime.c +161 -0
  406. package/external/libedhoc/externals/mbedtls/programs/pkey/dh_server.c +296 -0
  407. package/external/libedhoc/externals/mbedtls/programs/pkey/ecdh_curve25519.c +189 -0
  408. package/external/libedhoc/externals/mbedtls/programs/pkey/ecdsa.c +217 -0
  409. package/external/libedhoc/externals/mbedtls/programs/pkey/gen_key.c +419 -0
  410. package/external/libedhoc/externals/mbedtls/programs/pkey/key_app.c +316 -0
  411. package/external/libedhoc/externals/mbedtls/programs/pkey/key_app_writer.c +435 -0
  412. package/external/libedhoc/externals/mbedtls/programs/pkey/mpi_demo.c +84 -0
  413. package/external/libedhoc/externals/mbedtls/programs/pkey/pk_decrypt.c +153 -0
  414. package/external/libedhoc/externals/mbedtls/programs/pkey/pk_encrypt.c +154 -0
  415. package/external/libedhoc/externals/mbedtls/programs/pkey/pk_sign.c +155 -0
  416. package/external/libedhoc/externals/mbedtls/programs/pkey/pk_verify.c +128 -0
  417. package/external/libedhoc/externals/mbedtls/programs/pkey/rsa_decrypt.c +172 -0
  418. package/external/libedhoc/externals/mbedtls/programs/pkey/rsa_encrypt.c +149 -0
  419. package/external/libedhoc/externals/mbedtls/programs/pkey/rsa_genkey.c +141 -0
  420. package/external/libedhoc/externals/mbedtls/programs/pkey/rsa_sign.c +155 -0
  421. package/external/libedhoc/externals/mbedtls/programs/pkey/rsa_sign_pss.c +161 -0
  422. package/external/libedhoc/externals/mbedtls/programs/pkey/rsa_verify.c +131 -0
  423. package/external/libedhoc/externals/mbedtls/programs/pkey/rsa_verify_pss.c +136 -0
  424. package/external/libedhoc/externals/mbedtls/programs/psa/aead_demo.c +281 -0
  425. package/external/libedhoc/externals/mbedtls/programs/psa/crypto_examples.c +321 -0
  426. package/external/libedhoc/externals/mbedtls/programs/psa/hmac_demo.c +159 -0
  427. package/external/libedhoc/externals/mbedtls/programs/psa/key_ladder_demo.c +691 -0
  428. package/external/libedhoc/externals/mbedtls/programs/psa/psa_constant_names.c +310 -0
  429. package/external/libedhoc/externals/mbedtls/programs/psa/psa_constant_names_generated.c +474 -0
  430. package/external/libedhoc/externals/mbedtls/programs/random/gen_entropy.c +75 -0
  431. package/external/libedhoc/externals/mbedtls/programs/random/gen_random_ctr_drbg.c +107 -0
  432. package/external/libedhoc/externals/mbedtls/programs/ssl/dtls_client.c +342 -0
  433. package/external/libedhoc/externals/mbedtls/programs/ssl/dtls_server.c +408 -0
  434. package/external/libedhoc/externals/mbedtls/programs/ssl/mini_client.c +274 -0
  435. package/external/libedhoc/externals/mbedtls/programs/ssl/ssl_client1.c +288 -0
  436. package/external/libedhoc/externals/mbedtls/programs/ssl/ssl_client2.c +3118 -0
  437. package/external/libedhoc/externals/mbedtls/programs/ssl/ssl_context_info.c +1009 -0
  438. package/external/libedhoc/externals/mbedtls/programs/ssl/ssl_fork_server.c +381 -0
  439. package/external/libedhoc/externals/mbedtls/programs/ssl/ssl_mail_client.c +804 -0
  440. package/external/libedhoc/externals/mbedtls/programs/ssl/ssl_pthread_server.c +489 -0
  441. package/external/libedhoc/externals/mbedtls/programs/ssl/ssl_server.c +362 -0
  442. package/external/libedhoc/externals/mbedtls/programs/ssl/ssl_server2.c +4268 -0
  443. package/external/libedhoc/externals/mbedtls/programs/ssl/ssl_test_common_source.c +375 -0
  444. package/external/libedhoc/externals/mbedtls/programs/ssl/ssl_test_lib.c +601 -0
  445. package/external/libedhoc/externals/mbedtls/programs/ssl/ssl_test_lib.h +306 -0
  446. package/external/libedhoc/externals/mbedtls/programs/test/benchmark.c +1284 -0
  447. package/external/libedhoc/externals/mbedtls/programs/test/cmake_package/cmake_package.c +27 -0
  448. package/external/libedhoc/externals/mbedtls/programs/test/cmake_package_install/cmake_package_install.c +28 -0
  449. package/external/libedhoc/externals/mbedtls/programs/test/cmake_subproject/cmake_subproject.c +28 -0
  450. package/external/libedhoc/externals/mbedtls/programs/test/dlopen.c +92 -0
  451. package/external/libedhoc/externals/mbedtls/programs/test/query_compile_time_config.c +66 -0
  452. package/external/libedhoc/externals/mbedtls/programs/test/query_config.c +5137 -0
  453. package/external/libedhoc/externals/mbedtls/programs/test/query_config.h +34 -0
  454. package/external/libedhoc/externals/mbedtls/programs/test/query_included_headers.c +29 -0
  455. package/external/libedhoc/externals/mbedtls/programs/test/selftest.c +583 -0
  456. package/external/libedhoc/externals/mbedtls/programs/test/udp_proxy.c +967 -0
  457. package/external/libedhoc/externals/mbedtls/programs/test/zeroize.c +72 -0
  458. package/external/libedhoc/externals/mbedtls/programs/util/pem2der.c +265 -0
  459. package/external/libedhoc/externals/mbedtls/programs/util/strerror.c +61 -0
  460. package/external/libedhoc/externals/mbedtls/programs/wince_main.c +31 -0
  461. package/external/libedhoc/externals/mbedtls/programs/x509/cert_app.c +456 -0
  462. package/external/libedhoc/externals/mbedtls/programs/x509/cert_req.c +509 -0
  463. package/external/libedhoc/externals/mbedtls/programs/x509/cert_write.c +1012 -0
  464. package/external/libedhoc/externals/mbedtls/programs/x509/crl_app.c +132 -0
  465. package/external/libedhoc/externals/mbedtls/programs/x509/load_roots.c +165 -0
  466. package/external/libedhoc/externals/mbedtls/programs/x509/req_app.c +132 -0
  467. package/external/libedhoc/externals/mbedtls/tests/configs/tls13-only.h +31 -0
  468. package/external/libedhoc/externals/mbedtls/tests/configs/user-config-for-test.h +89 -0
  469. package/external/libedhoc/externals/mbedtls/tests/configs/user-config-malloc-0-null.h +22 -0
  470. package/external/libedhoc/externals/mbedtls/tests/configs/user-config-zeroize-memset.h +17 -0
  471. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/aes_alt.h +23 -0
  472. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/aria_alt.h +16 -0
  473. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/camellia_alt.h +16 -0
  474. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/ccm_alt.h +16 -0
  475. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/chacha20_alt.h +16 -0
  476. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/chachapoly_alt.h +18 -0
  477. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/cmac_alt.h +15 -0
  478. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/des_alt.h +22 -0
  479. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/dhm_alt.h +16 -0
  480. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/ecjpake_alt.h +15 -0
  481. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/ecp_alt.h +22 -0
  482. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/gcm_alt.h +16 -0
  483. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/md5_alt.h +16 -0
  484. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/nist_kw_alt.h +15 -0
  485. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/platform_alt.h +16 -0
  486. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/poly1305_alt.h +16 -0
  487. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/ripemd160_alt.h +16 -0
  488. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/rsa_alt.h +16 -0
  489. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/sha1_alt.h +16 -0
  490. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/sha256_alt.h +16 -0
  491. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/sha512_alt.h +16 -0
  492. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/threading_alt.h +14 -0
  493. package/external/libedhoc/externals/mbedtls/tests/include/alt-dummy/timing_alt.h +19 -0
  494. package/external/libedhoc/externals/mbedtls/tests/include/alt-extra/psa/crypto.h +7 -0
  495. package/external/libedhoc/externals/mbedtls/tests/include/baremetal-override/time.h +6 -0
  496. package/external/libedhoc/externals/mbedtls/tests/include/spe/crypto_spe.h +131 -0
  497. package/external/libedhoc/externals/mbedtls/tests/include/test/arguments.h +26 -0
  498. package/external/libedhoc/externals/mbedtls/tests/include/test/asn1_helpers.h +38 -0
  499. package/external/libedhoc/externals/mbedtls/tests/include/test/bignum_helpers.h +106 -0
  500. package/external/libedhoc/externals/mbedtls/tests/include/test/certs.h +234 -0
  501. package/external/libedhoc/externals/mbedtls/tests/include/test/constant_flow.h +71 -0
  502. package/external/libedhoc/externals/mbedtls/tests/include/test/drivers/aead.h +121 -0
  503. package/external/libedhoc/externals/mbedtls/tests/include/test/drivers/asymmetric_encryption.h +67 -0
  504. package/external/libedhoc/externals/mbedtls/tests/include/test/drivers/cipher.h +130 -0
  505. package/external/libedhoc/externals/mbedtls/tests/include/test/drivers/config_test_driver.h +44 -0
  506. package/external/libedhoc/externals/mbedtls/tests/include/test/drivers/crypto_config_test_driver_extension.h +430 -0
  507. package/external/libedhoc/externals/mbedtls/tests/include/test/drivers/hash.h +64 -0
  508. package/external/libedhoc/externals/mbedtls/tests/include/test/drivers/key_agreement.h +62 -0
  509. package/external/libedhoc/externals/mbedtls/tests/include/test/drivers/key_management.h +123 -0
  510. package/external/libedhoc/externals/mbedtls/tests/include/test/drivers/mac.h +125 -0
  511. package/external/libedhoc/externals/mbedtls/tests/include/test/drivers/pake.h +75 -0
  512. package/external/libedhoc/externals/mbedtls/tests/include/test/drivers/signature.h +112 -0
  513. package/external/libedhoc/externals/mbedtls/tests/include/test/drivers/test_driver.h +32 -0
  514. package/external/libedhoc/externals/mbedtls/tests/include/test/fake_external_rng_for_test.h +40 -0
  515. package/external/libedhoc/externals/mbedtls/tests/include/test/helpers.h +268 -0
  516. package/external/libedhoc/externals/mbedtls/tests/include/test/macros.h +250 -0
  517. package/external/libedhoc/externals/mbedtls/tests/include/test/psa_crypto_helpers.h +398 -0
  518. package/external/libedhoc/externals/mbedtls/tests/include/test/psa_exercise_key.h +223 -0
  519. package/external/libedhoc/externals/mbedtls/tests/include/test/psa_helpers.h +24 -0
  520. package/external/libedhoc/externals/mbedtls/tests/include/test/random.h +91 -0
  521. package/external/libedhoc/externals/mbedtls/tests/include/test/ssl_helpers.h +628 -0
  522. package/external/libedhoc/externals/mbedtls/tests/src/asn1_helpers.c +62 -0
  523. package/external/libedhoc/externals/mbedtls/tests/src/bignum_helpers.c +145 -0
  524. package/external/libedhoc/externals/mbedtls/tests/src/certs.c +480 -0
  525. package/external/libedhoc/externals/mbedtls/tests/src/drivers/hash.c +199 -0
  526. package/external/libedhoc/externals/mbedtls/tests/src/drivers/platform_builtin_keys.c +78 -0
  527. package/external/libedhoc/externals/mbedtls/tests/src/drivers/test_driver_aead.c +462 -0
  528. package/external/libedhoc/externals/mbedtls/tests/src/drivers/test_driver_asymmetric_encryption.c +151 -0
  529. package/external/libedhoc/externals/mbedtls/tests/src/drivers/test_driver_cipher.c +424 -0
  530. package/external/libedhoc/externals/mbedtls/tests/src/drivers/test_driver_key_agreement.c +147 -0
  531. package/external/libedhoc/externals/mbedtls/tests/src/drivers/test_driver_key_management.c +783 -0
  532. package/external/libedhoc/externals/mbedtls/tests/src/drivers/test_driver_mac.c +422 -0
  533. package/external/libedhoc/externals/mbedtls/tests/src/drivers/test_driver_pake.c +202 -0
  534. package/external/libedhoc/externals/mbedtls/tests/src/drivers/test_driver_signature.c +405 -0
  535. package/external/libedhoc/externals/mbedtls/tests/src/fake_external_rng_for_test.c +45 -0
  536. package/external/libedhoc/externals/mbedtls/tests/src/helpers.c +353 -0
  537. package/external/libedhoc/externals/mbedtls/tests/src/psa_crypto_helpers.c +196 -0
  538. package/external/libedhoc/externals/mbedtls/tests/src/psa_exercise_key.c +989 -0
  539. package/external/libedhoc/externals/mbedtls/tests/src/random.c +136 -0
  540. package/external/libedhoc/externals/mbedtls/tests/src/test_certs.h +1226 -0
  541. package/external/libedhoc/externals/mbedtls/tests/src/test_helpers/ssl_helpers.c +2292 -0
  542. package/external/libedhoc/externals/mbedtls/tests/src/threading_helpers.c +210 -0
  543. package/external/libedhoc/externals/zcbor/include/zcbor_common.h +422 -0
  544. package/external/libedhoc/externals/zcbor/include/zcbor_debug.h +69 -0
  545. package/external/libedhoc/externals/zcbor/include/zcbor_decode.h +358 -0
  546. package/external/libedhoc/externals/zcbor/include/zcbor_encode.h +296 -0
  547. package/external/libedhoc/externals/zcbor/include/zcbor_tags.h +94 -0
  548. package/external/libedhoc/externals/zcbor/samples/hello_world/src/main.c +41 -0
  549. package/external/libedhoc/externals/zcbor/samples/pet/include/pet_decode.h +39 -0
  550. package/external/libedhoc/externals/zcbor/samples/pet/include/pet_encode.h +39 -0
  551. package/external/libedhoc/externals/zcbor/samples/pet/include/pet_types.h +47 -0
  552. package/external/libedhoc/externals/zcbor/samples/pet/src/main.c +128 -0
  553. package/external/libedhoc/externals/zcbor/samples/pet/src/pet_decode.c +69 -0
  554. package/external/libedhoc/externals/zcbor/samples/pet/src/pet_encode.c +70 -0
  555. package/external/libedhoc/externals/zcbor/src/zcbor_common.c +257 -0
  556. package/external/libedhoc/externals/zcbor/src/zcbor_decode.c +1107 -0
  557. package/external/libedhoc/externals/zcbor/src/zcbor_encode.c +722 -0
  558. package/external/libedhoc/externals/zcbor/tests/decode/test1_suit_old_formats/src/main.c +368 -0
  559. package/external/libedhoc/externals/zcbor/tests/decode/test2_suit/src/main.c +189 -0
  560. package/external/libedhoc/externals/zcbor/tests/decode/test3_simple/src/main.c +529 -0
  561. package/external/libedhoc/externals/zcbor/tests/decode/test5_corner_cases/src/main.c +2010 -0
  562. package/external/libedhoc/externals/zcbor/tests/decode/test7_suit9_simple/src/main.c +134 -0
  563. package/external/libedhoc/externals/zcbor/tests/decode/test8_suit12/src/main.c +863 -0
  564. package/external/libedhoc/externals/zcbor/tests/decode/test9_manifest14/src/main.c +364 -0
  565. package/external/libedhoc/externals/zcbor/tests/encode/test1_suit/src/main.c +453 -0
  566. package/external/libedhoc/externals/zcbor/tests/encode/test2_simple/src/main.c +123 -0
  567. package/external/libedhoc/externals/zcbor/tests/encode/test3_corner_cases/src/main.c +1527 -0
  568. package/external/libedhoc/externals/zcbor/tests/encode/test4_senml/src/main.c +66 -0
  569. package/external/libedhoc/externals/zcbor/tests/fuzz/fuzz_manifest12.c +136 -0
  570. package/external/libedhoc/externals/zcbor/tests/fuzz/fuzz_pet.c +12 -0
  571. package/external/libedhoc/externals/zcbor/tests/fuzz/main_entry.c +60 -0
  572. package/external/libedhoc/externals/zcbor/tests/fuzz/main_entry.h +5 -0
  573. package/external/libedhoc/externals/zcbor/tests/unit/test1_unit_tests/src/main.c +1044 -0
  574. package/external/libedhoc/externals/zcbor/tests/unit/test3_float16/src/main.c +202 -0
  575. package/external/libedhoc/include/edhoc.h +393 -0
  576. package/external/libedhoc/include/edhoc_context.h +318 -0
  577. package/external/libedhoc/include/edhoc_credentials.h +217 -0
  578. package/external/libedhoc/include/edhoc_crypto.h +331 -0
  579. package/external/libedhoc/include/edhoc_ead.h +99 -0
  580. package/external/libedhoc/include/edhoc_macros.h +51 -0
  581. package/external/libedhoc/include/edhoc_values.h +181 -0
  582. package/external/libedhoc/library/edhoc.c +219 -0
  583. package/external/libedhoc/library/edhoc_exporter.c +543 -0
  584. package/external/libedhoc/library/edhoc_message_1.c +439 -0
  585. package/external/libedhoc/library/edhoc_message_2.c +2994 -0
  586. package/external/libedhoc/library/edhoc_message_3.c +2658 -0
  587. package/external/libedhoc/library/edhoc_message_4.c +826 -0
  588. package/external/libedhoc/library/edhoc_message_error.c +238 -0
  589. package/external/libedhoc/tests/include/cipher_suite_negotiation/test_edhoc_cipher_suite_negotiation.h +37 -0
  590. package/external/libedhoc/tests/include/cipher_suites/cipher_suite_0.h +134 -0
  591. package/external/libedhoc/tests/include/cipher_suites/cipher_suite_2.h +140 -0
  592. package/external/libedhoc/tests/include/cipher_suites/test_cipher_suite_0.h +48 -0
  593. package/external/libedhoc/tests/include/cipher_suites/test_cipher_suite_2.h +48 -0
  594. package/external/libedhoc/tests/include/edhoc_trace_1/authentication_credentials_1.h +60 -0
  595. package/external/libedhoc/tests/include/edhoc_trace_1/test_edhoc_handshake_1.h +208 -0
  596. package/external/libedhoc/tests/include/edhoc_trace_1/test_edhoc_handshake_ead_1.h +59 -0
  597. package/external/libedhoc/tests/include/edhoc_trace_1/test_vector_1.h +738 -0
  598. package/external/libedhoc/tests/include/edhoc_trace_2/authentication_credentials_2.h +60 -0
  599. package/external/libedhoc/tests/include/edhoc_trace_2/test_edhoc_handshake_2.h +199 -0
  600. package/external/libedhoc/tests/include/edhoc_trace_2/test_vector_2.h +525 -0
  601. package/external/libedhoc/tests/include/error_message/test_edhoc_error_message.h +48 -0
  602. package/external/libedhoc/tests/include/x509_chain_cs_0/authentication_credentials_x5chain_cs_0.h +92 -0
  603. package/external/libedhoc/tests/include/x509_chain_cs_0/test_edhoc_handshake_x5chain_cs_0.h +96 -0
  604. package/external/libedhoc/tests/include/x509_chain_cs_0/test_vector_x5chain_cs_0.h +140 -0
  605. package/external/libedhoc/tests/include/x509_chain_cs_2/authentication_credentials_x5chain_cs_2.h +58 -0
  606. package/external/libedhoc/tests/include/x509_chain_cs_2/test_edhoc_handshake_x5chain_cs_2.h +56 -0
  607. package/external/libedhoc/tests/include/x509_chain_cs_2/test_edhoc_handshake_x5chain_cs_2_ead.h +57 -0
  608. package/external/libedhoc/tests/include/x509_chain_cs_2/test_vector_x5chain_cs_2.h +169 -0
  609. package/external/libedhoc/tests/include/x509_chain_cs_2_static_dh/authentication_credentials_x5chain_cs_2_static_dh.h +59 -0
  610. package/external/libedhoc/tests/include/x509_chain_cs_2_static_dh/test_edhoc_handshake_x5chain_cs_2_static_dh_ead.h +57 -0
  611. package/external/libedhoc/tests/include/x509_chain_cs_2_static_dh/test_vector_x5chain_cs_2_static_dh.h +163 -0
  612. package/external/libedhoc/tests/include/x509_hash_cs_2/authentication_credentials_x5t_cs_2.h +60 -0
  613. package/external/libedhoc/tests/include/x509_hash_cs_2/test_edhoc_handshake_x5t_cs_2_ead.h +57 -0
  614. package/external/libedhoc/tests/include/x509_hash_cs_2/test_vector_x5t_cs_2.h +181 -0
  615. package/external/libedhoc/tests/src/cipher_suite_negotiation/test_edhoc_cipher_suite_negotiation.c +544 -0
  616. package/external/libedhoc/tests/src/cipher_suites/cipher_suite_0.c +447 -0
  617. package/external/libedhoc/tests/src/cipher_suites/cipher_suite_2.c +600 -0
  618. package/external/libedhoc/tests/src/cipher_suites/test_cipher_suite_0.c +475 -0
  619. package/external/libedhoc/tests/src/cipher_suites/test_cipher_suite_2.c +473 -0
  620. package/external/libedhoc/tests/src/edhoc_trace_1/authentication_credentials_1.c +252 -0
  621. package/external/libedhoc/tests/src/edhoc_trace_1/test_edhoc_handshake_1.c +1829 -0
  622. package/external/libedhoc/tests/src/edhoc_trace_1/test_edhoc_handshake_ead_1.c +1247 -0
  623. package/external/libedhoc/tests/src/edhoc_trace_2/authentication_credentials_2.c +170 -0
  624. package/external/libedhoc/tests/src/edhoc_trace_2/test_edhoc_handshake_2.c +1783 -0
  625. package/external/libedhoc/tests/src/error_message/test_edhoc_error_message.c +226 -0
  626. package/external/libedhoc/tests/src/tests.c +228 -0
  627. package/external/libedhoc/tests/src/x509_chain_cs_0/authentication_credentials_x5chain_cs_0.c +332 -0
  628. package/external/libedhoc/tests/src/x509_chain_cs_0/test_edhoc_handshake_x5chain_cs_0.c +936 -0
  629. package/external/libedhoc/tests/src/x509_chain_cs_2/authentication_credentials_x5chain_cs_2.c +166 -0
  630. package/external/libedhoc/tests/src/x509_chain_cs_2/test_edhoc_handshake_x5chain_cs_2.c +587 -0
  631. package/external/libedhoc/tests/src/x509_chain_cs_2/test_edhoc_handshake_x5chain_cs_2_ead.c +917 -0
  632. package/external/libedhoc/tests/src/x509_chain_cs_2_static_dh/authentication_credentials_x5chain_cs_2_static_dh.c +186 -0
  633. package/external/libedhoc/tests/src/x509_chain_cs_2_static_dh/test_edhoc_handshake_x5chain_cs_2_static_dh_ead.c +743 -0
  634. package/external/libedhoc/tests/src/x509_hash_cs_2/authentication_credentials_x5t_cs_2.c +261 -0
  635. package/external/libedhoc/tests/src/x509_hash_cs_2/test_edhoc_handshake_x5t_cs_2_ead.c +854 -0
  636. package/include/EdhocComposeAsyncWorker.h +61 -0
  637. package/include/EdhocCredentialManager.h +100 -0
  638. package/include/EdhocCryptoManager.h +504 -0
  639. package/include/EdhocEadManager.h +151 -0
  640. package/include/EdhocExportAsyncWorker.h +71 -0
  641. package/include/EdhocProcessAsyncWorker.h +76 -0
  642. package/include/LibEDHOC.h +304 -0
  643. package/include/Suites.h +27 -0
  644. package/include/UserContext.h +79 -0
  645. package/include/Utils.h +110 -0
  646. package/package.json +1 -1
  647. package/prebuilds/darwin-arm64/edhoc.node +0 -0
  648. package/prebuilds/win32-ia32/edhoc.node +0 -0
  649. package/prebuilds/win32-x64/edhoc.node +0 -0
  650. package/src/EdhocComposeAsyncWorker.cpp +88 -0
  651. package/src/EdhocCredentialManager.cpp +360 -0
  652. package/src/EdhocCryptoManager.cpp +967 -0
  653. package/src/EdhocEadManager.cpp +156 -0
  654. package/src/EdhocExportAsyncWorker.cpp +82 -0
  655. package/src/EdhocProcessAsyncWorker.cpp +74 -0
  656. package/src/LibEDHOC.cpp +369 -0
  657. package/src/Suites.cpp +153 -0
  658. package/src/Utils.cpp +115 -0
  659. /package/prebuilds/{darwin-x64+arm64 → darwin-x64}/edhoc.node +0 -0
@@ -0,0 +1,317 @@
1
+ /*
2
+ * PSA RSA layer on top of Mbed TLS crypto
3
+ */
4
+ /*
5
+ * Copyright The Mbed TLS Contributors
6
+ * SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
7
+ */
8
+
9
+ #ifndef PSA_CRYPTO_RSA_H
10
+ #define PSA_CRYPTO_RSA_H
11
+
12
+ #include <psa/crypto.h>
13
+ #include <mbedtls/rsa.h>
14
+
15
+ /** Load the contents of a key buffer into an internal RSA representation
16
+ *
17
+ * \param[in] type The type of key contained in \p data.
18
+ * \param[in] data The buffer from which to load the representation.
19
+ * \param[in] data_length The size in bytes of \p data.
20
+ * \param[out] p_rsa Returns a pointer to an RSA context on success.
21
+ * The caller is responsible for freeing both the
22
+ * contents of the context and the context itself
23
+ * when done.
24
+ */
25
+ psa_status_t mbedtls_psa_rsa_load_representation(psa_key_type_t type,
26
+ const uint8_t *data,
27
+ size_t data_length,
28
+ mbedtls_rsa_context **p_rsa);
29
+
30
+ /** Import an RSA key in binary format.
31
+ *
32
+ * \note The signature of this function is that of a PSA driver
33
+ * import_key entry point. This function behaves as an import_key
34
+ * entry point as defined in the PSA driver interface specification for
35
+ * transparent drivers.
36
+ *
37
+ * \param[in] attributes The attributes for the key to import.
38
+ * \param[in] data The buffer containing the key data in import
39
+ * format.
40
+ * \param[in] data_length Size of the \p data buffer in bytes.
41
+ * \param[out] key_buffer The buffer containing the key data in output
42
+ * format.
43
+ * \param[in] key_buffer_size Size of the \p key_buffer buffer in bytes. This
44
+ * size is greater or equal to \p data_length.
45
+ * \param[out] key_buffer_length The length of the data written in \p
46
+ * key_buffer in bytes.
47
+ * \param[out] bits The key size in number of bits.
48
+ *
49
+ * \retval #PSA_SUCCESS The RSA key was imported successfully.
50
+ * \retval #PSA_ERROR_INVALID_ARGUMENT
51
+ * The key data is not correctly formatted.
52
+ * \retval #PSA_ERROR_NOT_SUPPORTED \emptydescription
53
+ * \retval #PSA_ERROR_INSUFFICIENT_MEMORY \emptydescription
54
+ * \retval #PSA_ERROR_CORRUPTION_DETECTED \emptydescription
55
+ */
56
+ psa_status_t mbedtls_psa_rsa_import_key(
57
+ const psa_key_attributes_t *attributes,
58
+ const uint8_t *data, size_t data_length,
59
+ uint8_t *key_buffer, size_t key_buffer_size,
60
+ size_t *key_buffer_length, size_t *bits);
61
+
62
+ /** Export an RSA key to export representation
63
+ *
64
+ * \param[in] type The type of key (public/private) to export
65
+ * \param[in] rsa The internal RSA representation from which to export
66
+ * \param[out] data The buffer to export to
67
+ * \param[in] data_size The length of the buffer to export to
68
+ * \param[out] data_length The amount of bytes written to \p data
69
+ */
70
+ psa_status_t mbedtls_psa_rsa_export_key(psa_key_type_t type,
71
+ mbedtls_rsa_context *rsa,
72
+ uint8_t *data,
73
+ size_t data_size,
74
+ size_t *data_length);
75
+
76
+ /** Export a public RSA key or the public part of an RSA key pair in binary
77
+ * format.
78
+ *
79
+ * \note The signature of this function is that of a PSA driver
80
+ * export_public_key entry point. This function behaves as an
81
+ * export_public_key entry point as defined in the PSA driver interface
82
+ * specification.
83
+ *
84
+ * \param[in] attributes The attributes for the key to export.
85
+ * \param[in] key_buffer Material or context of the key to export.
86
+ * \param[in] key_buffer_size Size of the \p key_buffer buffer in bytes.
87
+ * \param[out] data Buffer where the key data is to be written.
88
+ * \param[in] data_size Size of the \p data buffer in bytes.
89
+ * \param[out] data_length On success, the number of bytes written in
90
+ * \p data.
91
+ *
92
+ * \retval #PSA_SUCCESS The RSA public key was exported successfully.
93
+ * \retval #PSA_ERROR_NOT_SUPPORTED \emptydescription
94
+ * \retval #PSA_ERROR_COMMUNICATION_FAILURE \emptydescription
95
+ * \retval #PSA_ERROR_HARDWARE_FAILURE \emptydescription
96
+ * \retval #PSA_ERROR_CORRUPTION_DETECTED \emptydescription
97
+ * \retval #PSA_ERROR_STORAGE_FAILURE \emptydescription
98
+ * \retval #PSA_ERROR_INSUFFICIENT_MEMORY \emptydescription
99
+ */
100
+ psa_status_t mbedtls_psa_rsa_export_public_key(
101
+ const psa_key_attributes_t *attributes,
102
+ const uint8_t *key_buffer, size_t key_buffer_size,
103
+ uint8_t *data, size_t data_size, size_t *data_length);
104
+
105
+ /**
106
+ * \brief Generate an RSA key.
107
+ *
108
+ * \note The signature of the function is that of a PSA driver generate_key
109
+ * entry point.
110
+ *
111
+ * \param[in] attributes The attributes for the RSA key to generate.
112
+ * \param[out] key_buffer Buffer where the key data is to be written.
113
+ * \param[in] key_buffer_size Size of \p key_buffer in bytes.
114
+ * \param[out] key_buffer_length On success, the number of bytes written in
115
+ * \p key_buffer.
116
+ *
117
+ * \retval #PSA_SUCCESS
118
+ * The key was successfully generated.
119
+ * \retval #PSA_ERROR_NOT_SUPPORTED
120
+ * Key length or type not supported.
121
+ * \retval #PSA_ERROR_BUFFER_TOO_SMALL
122
+ * The size of \p key_buffer is too small.
123
+ */
124
+ psa_status_t mbedtls_psa_rsa_generate_key(
125
+ const psa_key_attributes_t *attributes,
126
+ uint8_t *key_buffer, size_t key_buffer_size, size_t *key_buffer_length);
127
+
128
+ /** Sign an already-calculated hash with an RSA private key.
129
+ *
130
+ * \note The signature of this function is that of a PSA driver
131
+ * sign_hash entry point. This function behaves as a sign_hash
132
+ * entry point as defined in the PSA driver interface specification for
133
+ * transparent drivers.
134
+ *
135
+ * \param[in] attributes The attributes of the RSA key to use for the
136
+ * operation.
137
+ * \param[in] key_buffer The buffer containing the RSA key context.
138
+ * format.
139
+ * \param[in] key_buffer_size Size of the \p key_buffer buffer in bytes.
140
+ * \param[in] alg A signature algorithm that is compatible with
141
+ * an RSA key.
142
+ * \param[in] hash The hash or message to sign.
143
+ * \param[in] hash_length Size of the \p hash buffer in bytes.
144
+ * \param[out] signature Buffer where the signature is to be written.
145
+ * \param[in] signature_size Size of the \p signature buffer in bytes.
146
+ * \param[out] signature_length On success, the number of bytes
147
+ * that make up the returned signature value.
148
+ *
149
+ * \retval #PSA_SUCCESS \emptydescription
150
+ * \retval #PSA_ERROR_BUFFER_TOO_SMALL
151
+ * The size of the \p signature buffer is too small. You can
152
+ * determine a sufficient buffer size by calling
153
+ * #PSA_SIGN_OUTPUT_SIZE(\c PSA_KEY_TYPE_RSA_KEY_PAIR, \c key_bits,
154
+ * \p alg) where \c key_bits is the bit-size of the RSA key.
155
+ * \retval #PSA_ERROR_NOT_SUPPORTED \emptydescription
156
+ * \retval #PSA_ERROR_INVALID_ARGUMENT \emptydescription
157
+ * \retval #PSA_ERROR_INSUFFICIENT_MEMORY \emptydescription
158
+ * \retval #PSA_ERROR_CORRUPTION_DETECTED \emptydescription
159
+ * \retval #PSA_ERROR_INSUFFICIENT_ENTROPY \emptydescription
160
+ */
161
+ psa_status_t mbedtls_psa_rsa_sign_hash(
162
+ const psa_key_attributes_t *attributes,
163
+ const uint8_t *key_buffer, size_t key_buffer_size,
164
+ psa_algorithm_t alg, const uint8_t *hash, size_t hash_length,
165
+ uint8_t *signature, size_t signature_size, size_t *signature_length);
166
+
167
+ /**
168
+ * \brief Verify the signature a hash or short message using a public RSA key.
169
+ *
170
+ * \note The signature of this function is that of a PSA driver
171
+ * verify_hash entry point. This function behaves as a verify_hash
172
+ * entry point as defined in the PSA driver interface specification for
173
+ * transparent drivers.
174
+ *
175
+ * \param[in] attributes The attributes of the RSA key to use for the
176
+ * operation.
177
+ * \param[in] key_buffer The buffer containing the RSA key context.
178
+ * format.
179
+ * \param[in] key_buffer_size Size of the \p key_buffer buffer in bytes.
180
+ * \param[in] alg A signature algorithm that is compatible with
181
+ * an RSA key.
182
+ * \param[in] hash The hash or message whose signature is to be
183
+ * verified.
184
+ * \param[in] hash_length Size of the \p hash buffer in bytes.
185
+ * \param[in] signature Buffer containing the signature to verify.
186
+ * \param[in] signature_length Size of the \p signature buffer in bytes.
187
+ *
188
+ * \retval #PSA_SUCCESS
189
+ * The signature is valid.
190
+ * \retval #PSA_ERROR_INVALID_SIGNATURE
191
+ * The calculation was performed successfully, but the passed
192
+ * signature is not a valid signature.
193
+ * \retval #PSA_ERROR_NOT_SUPPORTED \emptydescription
194
+ * \retval #PSA_ERROR_INVALID_ARGUMENT \emptydescription
195
+ * \retval #PSA_ERROR_INSUFFICIENT_MEMORY \emptydescription
196
+ */
197
+ psa_status_t mbedtls_psa_rsa_verify_hash(
198
+ const psa_key_attributes_t *attributes,
199
+ const uint8_t *key_buffer, size_t key_buffer_size,
200
+ psa_algorithm_t alg, const uint8_t *hash, size_t hash_length,
201
+ const uint8_t *signature, size_t signature_length);
202
+
203
+ /**
204
+ * \brief Encrypt a short message with a public key.
205
+ *
206
+ * \param attributes The attributes for the key to import.
207
+ * \param key_buffer Buffer where the key data is to be written.
208
+ * \param key_buffer_size Size of the \p key_buffer buffer in bytes.
209
+ * \param input_length Size of the \p input buffer in bytes.
210
+ * \param[in] salt A salt or label, if supported by the
211
+ * encryption algorithm.
212
+ * If the algorithm does not support a
213
+ * salt, pass \c NULL.
214
+ * If the algorithm supports an optional
215
+ * salt and you do not want to pass a salt,
216
+ * pass \c NULL.
217
+ *
218
+ * - For #PSA_ALG_RSA_PKCS1V15_CRYPT, no salt is
219
+ * supported.
220
+ * \param salt_length Size of the \p salt buffer in bytes.
221
+ * If \p salt is \c NULL, pass 0.
222
+ * \param[out] output Buffer where the encrypted message is to
223
+ * be written.
224
+ * \param output_size Size of the \p output buffer in bytes.
225
+ * \param[out] output_length On success, the number of bytes
226
+ * that make up the returned output.
227
+ *
228
+ * \retval #PSA_SUCCESS \emptydescription
229
+ * \retval #PSA_ERROR_BUFFER_TOO_SMALL
230
+ * The size of the \p output buffer is too small. You can
231
+ * determine a sufficient buffer size by calling
232
+ * #PSA_ASYMMETRIC_ENCRYPT_OUTPUT_SIZE(\c key_type, \c key_bits, \p alg)
233
+ * where \c key_type and \c key_bits are the type and bit-size
234
+ * respectively of \p key.
235
+ * \retval #PSA_ERROR_NOT_SUPPORTED \emptydescription
236
+ * \retval #PSA_ERROR_INVALID_ARGUMENT \emptydescription
237
+ * \retval #PSA_ERROR_INSUFFICIENT_MEMORY \emptydescription
238
+ * \retval #PSA_ERROR_COMMUNICATION_FAILURE \emptydescription
239
+ * \retval #PSA_ERROR_HARDWARE_FAILURE \emptydescription
240
+ * \retval #PSA_ERROR_CORRUPTION_DETECTED \emptydescription
241
+ * \retval #PSA_ERROR_INSUFFICIENT_ENTROPY \emptydescription
242
+ * \retval #PSA_ERROR_BAD_STATE
243
+ * The library has not been previously initialized by psa_crypto_init().
244
+ * It is implementation-dependent whether a failure to initialize
245
+ * results in this error code.
246
+ */
247
+ psa_status_t mbedtls_psa_asymmetric_encrypt(const psa_key_attributes_t *attributes,
248
+ const uint8_t *key_buffer,
249
+ size_t key_buffer_size,
250
+ psa_algorithm_t alg,
251
+ const uint8_t *input,
252
+ size_t input_length,
253
+ const uint8_t *salt,
254
+ size_t salt_length,
255
+ uint8_t *output,
256
+ size_t output_size,
257
+ size_t *output_length);
258
+
259
+ /**
260
+ * \brief Decrypt a short message with a private key.
261
+ *
262
+ * \param attributes The attributes for the key to import.
263
+ * \param key_buffer Buffer where the key data is to be written.
264
+ * \param key_buffer_size Size of the \p key_buffer buffer in bytes.
265
+ * \param[in] input The message to decrypt.
266
+ * \param input_length Size of the \p input buffer in bytes.
267
+ * \param[in] salt A salt or label, if supported by the
268
+ * encryption algorithm.
269
+ * If the algorithm does not support a
270
+ * salt, pass \c NULL.
271
+ * If the algorithm supports an optional
272
+ * salt and you do not want to pass a salt,
273
+ * pass \c NULL.
274
+ *
275
+ * - For #PSA_ALG_RSA_PKCS1V15_CRYPT, no salt is
276
+ * supported.
277
+ * \param salt_length Size of the \p salt buffer in bytes.
278
+ * If \p salt is \c NULL, pass 0.
279
+ * \param[out] output Buffer where the decrypted message is to
280
+ * be written.
281
+ * \param output_size Size of the \c output buffer in bytes.
282
+ * \param[out] output_length On success, the number of bytes
283
+ * that make up the returned output.
284
+ *
285
+ * \retval #PSA_SUCCESS \emptydescription
286
+ * \retval #PSA_ERROR_BUFFER_TOO_SMALL
287
+ * The size of the \p output buffer is too small. You can
288
+ * determine a sufficient buffer size by calling
289
+ * #PSA_ASYMMETRIC_DECRYPT_OUTPUT_SIZE(\c key_type, \c key_bits, \p alg)
290
+ * where \c key_type and \c key_bits are the type and bit-size
291
+ * respectively of \p key.
292
+ * \retval #PSA_ERROR_NOT_SUPPORTED \emptydescription
293
+ * \retval #PSA_ERROR_INVALID_ARGUMENT \emptydescription
294
+ * \retval #PSA_ERROR_INSUFFICIENT_MEMORY \emptydescription
295
+ * \retval #PSA_ERROR_COMMUNICATION_FAILURE \emptydescription
296
+ * \retval #PSA_ERROR_HARDWARE_FAILURE \emptydescription
297
+ * \retval #PSA_ERROR_CORRUPTION_DETECTED \emptydescription
298
+ * \retval #PSA_ERROR_INSUFFICIENT_ENTROPY \emptydescription
299
+ * \retval #PSA_ERROR_INVALID_PADDING \emptydescription
300
+ * \retval #PSA_ERROR_BAD_STATE
301
+ * The library has not been previously initialized by psa_crypto_init().
302
+ * It is implementation-dependent whether a failure to initialize
303
+ * results in this error code.
304
+ */
305
+ psa_status_t mbedtls_psa_asymmetric_decrypt(const psa_key_attributes_t *attributes,
306
+ const uint8_t *key_buffer,
307
+ size_t key_buffer_size,
308
+ psa_algorithm_t alg,
309
+ const uint8_t *input,
310
+ size_t input_length,
311
+ const uint8_t *salt,
312
+ size_t salt_length,
313
+ uint8_t *output,
314
+ size_t output_size,
315
+ size_t *output_length);
316
+
317
+ #endif /* PSA_CRYPTO_RSA_H */
@@ -0,0 +1,373 @@
1
+ /*
2
+ * PSA crypto support for secure element drivers
3
+ */
4
+ /*
5
+ * Copyright The Mbed TLS Contributors
6
+ * SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
7
+ */
8
+
9
+ #include "common.h"
10
+
11
+ #if defined(MBEDTLS_PSA_CRYPTO_SE_C)
12
+
13
+ #include <stdint.h>
14
+ #include <string.h>
15
+
16
+ #include "psa/crypto_se_driver.h"
17
+
18
+ #include "psa_crypto_se.h"
19
+
20
+ #if defined(MBEDTLS_PSA_ITS_FILE_C)
21
+ #include "psa_crypto_its.h"
22
+ #else /* Native ITS implementation */
23
+ #include "psa/error.h"
24
+ #include "psa/internal_trusted_storage.h"
25
+ #endif
26
+
27
+ #include "mbedtls/platform.h"
28
+
29
+
30
+
31
+ /****************************************************************/
32
+ /* Driver lookup */
33
+ /****************************************************************/
34
+
35
+ /* This structure is identical to psa_drv_se_context_t declared in
36
+ * `crypto_se_driver.h`, except that some parts are writable here
37
+ * (non-const, or pointer to non-const). */
38
+ typedef struct {
39
+ void *persistent_data;
40
+ size_t persistent_data_size;
41
+ uintptr_t transient_data;
42
+ } psa_drv_se_internal_context_t;
43
+
44
+ struct psa_se_drv_table_entry_s {
45
+ psa_key_location_t location;
46
+ const psa_drv_se_t *methods;
47
+ union {
48
+ psa_drv_se_internal_context_t internal;
49
+ psa_drv_se_context_t context;
50
+ } u;
51
+ };
52
+
53
+ static psa_se_drv_table_entry_t driver_table[PSA_MAX_SE_DRIVERS];
54
+
55
+ psa_se_drv_table_entry_t *psa_get_se_driver_entry(
56
+ psa_key_lifetime_t lifetime)
57
+ {
58
+ size_t i;
59
+ psa_key_location_t location = PSA_KEY_LIFETIME_GET_LOCATION(lifetime);
60
+ /* In the driver table, location=0 means an entry that isn't used.
61
+ * No driver has a location of 0 because it's a reserved value
62
+ * (which designates transparent keys). Make sure we never return
63
+ * a driver entry for location 0. */
64
+ if (location == 0) {
65
+ return NULL;
66
+ }
67
+ for (i = 0; i < PSA_MAX_SE_DRIVERS; i++) {
68
+ if (driver_table[i].location == location) {
69
+ return &driver_table[i];
70
+ }
71
+ }
72
+ return NULL;
73
+ }
74
+
75
+ const psa_drv_se_t *psa_get_se_driver_methods(
76
+ const psa_se_drv_table_entry_t *driver)
77
+ {
78
+ return driver->methods;
79
+ }
80
+
81
+ psa_drv_se_context_t *psa_get_se_driver_context(
82
+ psa_se_drv_table_entry_t *driver)
83
+ {
84
+ return &driver->u.context;
85
+ }
86
+
87
+ int psa_get_se_driver(psa_key_lifetime_t lifetime,
88
+ const psa_drv_se_t **p_methods,
89
+ psa_drv_se_context_t **p_drv_context)
90
+ {
91
+ psa_se_drv_table_entry_t *driver = psa_get_se_driver_entry(lifetime);
92
+ if (p_methods != NULL) {
93
+ *p_methods = (driver ? driver->methods : NULL);
94
+ }
95
+ if (p_drv_context != NULL) {
96
+ *p_drv_context = (driver ? &driver->u.context : NULL);
97
+ }
98
+ return driver != NULL;
99
+ }
100
+
101
+
102
+
103
+ /****************************************************************/
104
+ /* Persistent data management */
105
+ /****************************************************************/
106
+
107
+ static psa_status_t psa_get_se_driver_its_file_uid(
108
+ const psa_se_drv_table_entry_t *driver,
109
+ psa_storage_uid_t *uid)
110
+ {
111
+ if (driver->location > PSA_MAX_SE_LOCATION) {
112
+ return PSA_ERROR_NOT_SUPPORTED;
113
+ }
114
+
115
+ /* ITS file sizes are limited to 32 bits. */
116
+ if (driver->u.internal.persistent_data_size > UINT32_MAX) {
117
+ return PSA_ERROR_NOT_SUPPORTED;
118
+ }
119
+
120
+ /* See the documentation of PSA_CRYPTO_SE_DRIVER_ITS_UID_BASE. */
121
+ *uid = PSA_CRYPTO_SE_DRIVER_ITS_UID_BASE + driver->location;
122
+ return PSA_SUCCESS;
123
+ }
124
+
125
+ psa_status_t psa_load_se_persistent_data(
126
+ const psa_se_drv_table_entry_t *driver)
127
+ {
128
+ psa_status_t status;
129
+ psa_storage_uid_t uid;
130
+ size_t length;
131
+
132
+ status = psa_get_se_driver_its_file_uid(driver, &uid);
133
+ if (status != PSA_SUCCESS) {
134
+ return status;
135
+ }
136
+
137
+ /* Read the amount of persistent data that the driver requests.
138
+ * If the data in storage is larger, it is truncated. If the data
139
+ * in storage is smaller, silently keep what is already at the end
140
+ * of the output buffer. */
141
+ /* psa_get_se_driver_its_file_uid ensures that the size_t
142
+ * persistent_data_size is in range, but compilers don't know that,
143
+ * so cast to reassure them. */
144
+ return psa_its_get(uid, 0,
145
+ (uint32_t) driver->u.internal.persistent_data_size,
146
+ driver->u.internal.persistent_data,
147
+ &length);
148
+ }
149
+
150
+ psa_status_t psa_save_se_persistent_data(
151
+ const psa_se_drv_table_entry_t *driver)
152
+ {
153
+ psa_status_t status;
154
+ psa_storage_uid_t uid;
155
+
156
+ status = psa_get_se_driver_its_file_uid(driver, &uid);
157
+ if (status != PSA_SUCCESS) {
158
+ return status;
159
+ }
160
+
161
+ /* psa_get_se_driver_its_file_uid ensures that the size_t
162
+ * persistent_data_size is in range, but compilers don't know that,
163
+ * so cast to reassure them. */
164
+ return psa_its_set(uid,
165
+ (uint32_t) driver->u.internal.persistent_data_size,
166
+ driver->u.internal.persistent_data,
167
+ 0);
168
+ }
169
+
170
+ psa_status_t psa_destroy_se_persistent_data(psa_key_location_t location)
171
+ {
172
+ psa_storage_uid_t uid;
173
+ if (location > PSA_MAX_SE_LOCATION) {
174
+ return PSA_ERROR_NOT_SUPPORTED;
175
+ }
176
+ uid = PSA_CRYPTO_SE_DRIVER_ITS_UID_BASE + location;
177
+ return psa_its_remove(uid);
178
+ }
179
+
180
+ psa_status_t psa_find_se_slot_for_key(
181
+ const psa_key_attributes_t *attributes,
182
+ psa_key_creation_method_t method,
183
+ psa_se_drv_table_entry_t *driver,
184
+ psa_key_slot_number_t *slot_number)
185
+ {
186
+ psa_status_t status;
187
+ psa_key_location_t key_location =
188
+ PSA_KEY_LIFETIME_GET_LOCATION(psa_get_key_lifetime(attributes));
189
+
190
+ /* If the location is wrong, it's a bug in the library. */
191
+ if (driver->location != key_location) {
192
+ return PSA_ERROR_CORRUPTION_DETECTED;
193
+ }
194
+
195
+ /* If the driver doesn't support key creation in any way, give up now. */
196
+ if (driver->methods->key_management == NULL) {
197
+ return PSA_ERROR_NOT_SUPPORTED;
198
+ }
199
+
200
+ if (psa_get_key_slot_number(attributes, slot_number) == PSA_SUCCESS) {
201
+ /* The application wants to use a specific slot. Allow it if
202
+ * the driver supports it. On a system with isolation,
203
+ * the crypto service must check that the application is
204
+ * permitted to request this slot. */
205
+ psa_drv_se_validate_slot_number_t p_validate_slot_number =
206
+ driver->methods->key_management->p_validate_slot_number;
207
+ if (p_validate_slot_number == NULL) {
208
+ return PSA_ERROR_NOT_SUPPORTED;
209
+ }
210
+ status = p_validate_slot_number(&driver->u.context,
211
+ driver->u.internal.persistent_data,
212
+ attributes, method,
213
+ *slot_number);
214
+ } else if (method == PSA_KEY_CREATION_REGISTER) {
215
+ /* The application didn't specify a slot number. This doesn't
216
+ * make sense when registering a slot. */
217
+ return PSA_ERROR_INVALID_ARGUMENT;
218
+ } else {
219
+ /* The application didn't tell us which slot to use. Let the driver
220
+ * choose. This is the normal case. */
221
+ psa_drv_se_allocate_key_t p_allocate =
222
+ driver->methods->key_management->p_allocate;
223
+ if (p_allocate == NULL) {
224
+ return PSA_ERROR_NOT_SUPPORTED;
225
+ }
226
+ status = p_allocate(&driver->u.context,
227
+ driver->u.internal.persistent_data,
228
+ attributes, method,
229
+ slot_number);
230
+ }
231
+ return status;
232
+ }
233
+
234
+ psa_status_t psa_destroy_se_key(psa_se_drv_table_entry_t *driver,
235
+ psa_key_slot_number_t slot_number)
236
+ {
237
+ psa_status_t status;
238
+ psa_status_t storage_status;
239
+ /* Normally a missing method would mean that the action is not
240
+ * supported. But psa_destroy_key() is not supposed to return
241
+ * PSA_ERROR_NOT_SUPPORTED: if you can create a key, you should
242
+ * be able to destroy it. The only use case for a driver that
243
+ * does not have a way to destroy keys at all is if the keys are
244
+ * locked in a read-only state: we can use the keys but not
245
+ * destroy them. Hence, if the driver doesn't support destroying
246
+ * keys, it's really a lack of permission. */
247
+ if (driver->methods->key_management == NULL ||
248
+ driver->methods->key_management->p_destroy == NULL) {
249
+ return PSA_ERROR_NOT_PERMITTED;
250
+ }
251
+ status = driver->methods->key_management->p_destroy(
252
+ &driver->u.context,
253
+ driver->u.internal.persistent_data,
254
+ slot_number);
255
+ storage_status = psa_save_se_persistent_data(driver);
256
+ return status == PSA_SUCCESS ? storage_status : status;
257
+ }
258
+
259
+ psa_status_t psa_init_all_se_drivers(void)
260
+ {
261
+ size_t i;
262
+ for (i = 0; i < PSA_MAX_SE_DRIVERS; i++) {
263
+ psa_se_drv_table_entry_t *driver = &driver_table[i];
264
+ if (driver->location == 0) {
265
+ continue; /* skipping unused entry */
266
+ }
267
+ const psa_drv_se_t *methods = psa_get_se_driver_methods(driver);
268
+ if (methods->p_init != NULL) {
269
+ psa_status_t status = methods->p_init(
270
+ &driver->u.context,
271
+ driver->u.internal.persistent_data,
272
+ driver->location);
273
+ if (status != PSA_SUCCESS) {
274
+ return status;
275
+ }
276
+ status = psa_save_se_persistent_data(driver);
277
+ if (status != PSA_SUCCESS) {
278
+ return status;
279
+ }
280
+ }
281
+ }
282
+ return PSA_SUCCESS;
283
+ }
284
+
285
+
286
+
287
+ /****************************************************************/
288
+ /* Driver registration */
289
+ /****************************************************************/
290
+
291
+ psa_status_t psa_register_se_driver(
292
+ psa_key_location_t location,
293
+ const psa_drv_se_t *methods)
294
+ {
295
+ size_t i;
296
+ psa_status_t status;
297
+
298
+ if (methods->hal_version != PSA_DRV_SE_HAL_VERSION) {
299
+ return PSA_ERROR_NOT_SUPPORTED;
300
+ }
301
+ /* Driver table entries are 0-initialized. 0 is not a valid driver
302
+ * location because it means a transparent key. */
303
+ MBEDTLS_STATIC_ASSERT(PSA_KEY_LOCATION_LOCAL_STORAGE == 0,
304
+ "Secure element support requires 0 to mean a local key");
305
+
306
+ if (location == PSA_KEY_LOCATION_LOCAL_STORAGE) {
307
+ return PSA_ERROR_INVALID_ARGUMENT;
308
+ }
309
+ if (location > PSA_MAX_SE_LOCATION) {
310
+ return PSA_ERROR_NOT_SUPPORTED;
311
+ }
312
+
313
+ for (i = 0; i < PSA_MAX_SE_DRIVERS; i++) {
314
+ if (driver_table[i].location == 0) {
315
+ break;
316
+ }
317
+ /* Check that location isn't already in use up to the first free
318
+ * entry. Since entries are created in order and never deleted,
319
+ * there can't be a used entry after the first free entry. */
320
+ if (driver_table[i].location == location) {
321
+ return PSA_ERROR_ALREADY_EXISTS;
322
+ }
323
+ }
324
+ if (i == PSA_MAX_SE_DRIVERS) {
325
+ return PSA_ERROR_INSUFFICIENT_MEMORY;
326
+ }
327
+
328
+ driver_table[i].location = location;
329
+ driver_table[i].methods = methods;
330
+ driver_table[i].u.internal.persistent_data_size =
331
+ methods->persistent_data_size;
332
+
333
+ if (methods->persistent_data_size != 0) {
334
+ driver_table[i].u.internal.persistent_data =
335
+ mbedtls_calloc(1, methods->persistent_data_size);
336
+ if (driver_table[i].u.internal.persistent_data == NULL) {
337
+ status = PSA_ERROR_INSUFFICIENT_MEMORY;
338
+ goto error;
339
+ }
340
+ /* Load the driver's persistent data. On first use, the persistent
341
+ * data does not exist in storage, and is initialized to
342
+ * all-bits-zero by the calloc call just above. */
343
+ status = psa_load_se_persistent_data(&driver_table[i]);
344
+ if (status != PSA_SUCCESS && status != PSA_ERROR_DOES_NOT_EXIST) {
345
+ goto error;
346
+ }
347
+ }
348
+
349
+ return PSA_SUCCESS;
350
+
351
+ error:
352
+ memset(&driver_table[i], 0, sizeof(driver_table[i]));
353
+ return status;
354
+ }
355
+
356
+ void psa_unregister_all_se_drivers(void)
357
+ {
358
+ size_t i;
359
+ for (i = 0; i < PSA_MAX_SE_DRIVERS; i++) {
360
+ if (driver_table[i].u.internal.persistent_data != NULL) {
361
+ mbedtls_free(driver_table[i].u.internal.persistent_data);
362
+ }
363
+ }
364
+ memset(driver_table, 0, sizeof(driver_table));
365
+ }
366
+
367
+
368
+
369
+ /****************************************************************/
370
+ /* The end */
371
+ /****************************************************************/
372
+
373
+ #endif /* MBEDTLS_PSA_CRYPTO_SE_C */