1a8e1175bSopenharmony_ciDiffie-Hellman full exchange: tiny x_size 2a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":1:"1e32158a35e34d7b619657d6":0 3a8e1175bSopenharmony_ci 4a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 5-bit, x_size=3 5a8e1175bSopenharmony_cidhm_do_dhm:"17":3:"5":0 6a8e1175bSopenharmony_ci 7a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 5-bit, x_size=2 8a8e1175bSopenharmony_cidhm_do_dhm:"17":2:"5":0 9a8e1175bSopenharmony_ci 10a8e1175bSopenharmony_ci## Repeat this test case and a few similar ones several times. The RNG state 11a8e1175bSopenharmony_ci## changes, so we get to exercise the code with a few different values. 12a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 5-bit #1 13a8e1175bSopenharmony_cidhm_do_dhm:"17":1:"5":0 14a8e1175bSopenharmony_ci 15a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 5-bit #2 16a8e1175bSopenharmony_cidhm_do_dhm:"17":1:"5":0 17a8e1175bSopenharmony_ci 18a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 5-bit #3 19a8e1175bSopenharmony_cidhm_do_dhm:"17":1:"5":0 20a8e1175bSopenharmony_ci 21a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 5-bit #4 22a8e1175bSopenharmony_cidhm_do_dhm:"17":1:"5":0 23a8e1175bSopenharmony_ci 24a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 5-bit #5 25a8e1175bSopenharmony_cidhm_do_dhm:"17":1:"5":0 26a8e1175bSopenharmony_ci 27a8e1175bSopenharmony_ci## This is x_size = P_size + 1. Arguably x_size > P_size makes no sense, 28a8e1175bSopenharmony_ci## but it's the current undocumented behavior to treat it the same as when 29a8e1175bSopenharmony_ci## x_size = P_size. If this behavior changes in the future, change the expected 30a8e1175bSopenharmony_ci## return status from 0 to MBEDTLS_ERR_DHM_BAD_INPUT_DATA. 31a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 97-bit, x_size=14 32a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":14:"1e32158a35e34d7b619657d6":0 33a8e1175bSopenharmony_ci 34a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 97-bit #1 35a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":13:"1e32158a35e34d7b619657d6":0 36a8e1175bSopenharmony_ci 37a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 97-bit #2 38a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":13:"1e32158a35e34d7b619657d6":0 39a8e1175bSopenharmony_ci 40a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 97-bit #3 41a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":13:"1e32158a35e34d7b619657d6":0 42a8e1175bSopenharmony_ci 43a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 97-bit #4 44a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":13:"1e32158a35e34d7b619657d6":0 45a8e1175bSopenharmony_ci 46a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 97-bit #5 47a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":13:"1e32158a35e34d7b619657d6":0 48a8e1175bSopenharmony_ci 49a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 97-bit, x_size=12 50a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":12:"1e32158a35e34d7b619657d6":0 51a8e1175bSopenharmony_ci 52a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 97-bit, x_size=11 53a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":11:"1e32158a35e34d7b619657d6":0 54a8e1175bSopenharmony_ci 55a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 97-bit, x_size=1 #1 56a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":1:"1e32158a35e34d7b619657d6":0 57a8e1175bSopenharmony_ci 58a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 97-bit, x_size=1 #2 59a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":1:"1e32158a35e34d7b619657d6":0 60a8e1175bSopenharmony_ci 61a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 97-bit, x_size=1 #3 62a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":1:"1e32158a35e34d7b619657d6":0 63a8e1175bSopenharmony_ci 64a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 97-bit, x_size=1 #4 65a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":1:"1e32158a35e34d7b619657d6":0 66a8e1175bSopenharmony_ci 67a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 97-bit, x_size=1 #5 68a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":1:"1e32158a35e34d7b619657d6":0 69a8e1175bSopenharmony_ci 70a8e1175bSopenharmony_ciDiffie-Hellman full exchange: 286-bit 71a8e1175bSopenharmony_cidhm_do_dhm:"301abc09a57b66a953bfcc206a32e9ab56724084e4b47635779ca35fee79ce1060cb4117":36:"15aa1039b4dd361ed1b5b88e52f2919d0cbcb15adbe5fc290dab13b34e7":0 72a8e1175bSopenharmony_ci 73a8e1175bSopenharmony_ciDiffie-Hellman small modulus 74a8e1175bSopenharmony_cidhm_do_dhm:"3":1:"5":MBEDTLS_ERR_DHM_MAKE_PARAMS_FAILED+MBEDTLS_ERR_MPI_BAD_INPUT_DATA 75a8e1175bSopenharmony_ci 76a8e1175bSopenharmony_ciDiffie-Hellman zero modulus 77a8e1175bSopenharmony_cidhm_do_dhm:"0":1:"5":MBEDTLS_ERR_DHM_BAD_INPUT_DATA 78a8e1175bSopenharmony_ci 79a8e1175bSopenharmony_ciDiffie-Hellman with G=0 80a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":13:"0":MBEDTLS_ERR_DHM_BAD_INPUT_DATA 81a8e1175bSopenharmony_ci 82a8e1175bSopenharmony_ciDiffie-Hellman with G=1 83a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":13:"1":MBEDTLS_ERR_DHM_BAD_INPUT_DATA 84a8e1175bSopenharmony_ci 85a8e1175bSopenharmony_ciDiffie-Hellman with G=-1 86a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":13:"-1":MBEDTLS_ERR_DHM_BAD_INPUT_DATA 87a8e1175bSopenharmony_ci 88a8e1175bSopenharmony_ciDiffie-Hellman with G=P-1 89a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":13:"12df4d7689dff4c99d9ae57d6":MBEDTLS_ERR_DHM_BAD_INPUT_DATA 90a8e1175bSopenharmony_ci 91a8e1175bSopenharmony_ciDiffie-Hellman with G=P-2 92a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":13:"12df4d7689dff4c99d9ae57d5":0 93a8e1175bSopenharmony_ci 94a8e1175bSopenharmony_ciDiffie-Hellman with G=P 95a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":13:"12df4d7689dff4c99d9ae57d7":MBEDTLS_ERR_DHM_BAD_INPUT_DATA 96a8e1175bSopenharmony_ci 97a8e1175bSopenharmony_ciDiffie-Hellman with G=P+1 98a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":13:"12df4d7689dff4c99d9ae57d8":MBEDTLS_ERR_DHM_BAD_INPUT_DATA 99a8e1175bSopenharmony_ci 100a8e1175bSopenharmony_ciDiffie-Hellman with G=P+2 101a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":13:"12df4d7689dff4c99d9ae57d9":0 102a8e1175bSopenharmony_ci 103a8e1175bSopenharmony_ciDiffie-Hellman: x_size < 0 104a8e1175bSopenharmony_cidhm_do_dhm:"12df4d7689dff4c99d9ae57d7":-1:"1e32158a35e34d7b619657d6":MBEDTLS_ERR_DHM_BAD_INPUT_DATA 105a8e1175bSopenharmony_ci 106a8e1175bSopenharmony_ciDiffie-Hellman MPI_MAX_SIZE modulus 107a8e1175bSopenharmony_cidhm_make_public:MBEDTLS_MPI_MAX_SIZE:"5":0 108a8e1175bSopenharmony_ci 109a8e1175bSopenharmony_ciDiffie-Hellman MPI_MAX_SIZE + 1 modulus 110a8e1175bSopenharmony_cidhm_make_public:MBEDTLS_MPI_MAX_SIZE + 1:"5":MBEDTLS_ERR_DHM_MAKE_PUBLIC_FAILED+MBEDTLS_ERR_MPI_BAD_INPUT_DATA 111a8e1175bSopenharmony_ci 112a8e1175bSopenharmony_ciDH load parameters from PEM file (1024-bit, g=2) 113a8e1175bSopenharmony_cidepends_on:MBEDTLS_PEM_PARSE_C 114a8e1175bSopenharmony_cidhm_file:"data_files/dhparams.pem":"9e35f430443a09904f3a39a979797d070df53378e79c2438bef4e761f3c714553328589b041c809be1d6c6b5f1fc9f47d3a25443188253a992a56818b37ba9de5a40d362e56eff0be5417474c125c199272c8fe41dea733df6f662c92ae76556e755d10c64e6a50968f67fc6ea73d0dca8569be2ba204e23580d8bca2f4975b3":"02":128 115a8e1175bSopenharmony_ci 116a8e1175bSopenharmony_ciDH load parameters from PEM file (2048-bit, large g, privateValueLength) 117a8e1175bSopenharmony_cidepends_on:MBEDTLS_PEM_PARSE_C 118a8e1175bSopenharmony_cidhm_file:"data_files/dh.optlen.pem":"b3126aeaf47153c7d67f403030b292b5bd5a6c9eae1c137af34087fce2a36a578d70c5c560ad2bdb924c4a4dbee20a1671be7103ce87defa76908936803dbeca60c33e1289c1a03ac2c6c4e49405e5902fa0596a1cbaa895cc402d5213ed4a5f1f5ba8b5e1ed3da951a4c475afeb0ca660b7368c38c8e809f382d96ae19e60dc984e61cb42b5dfd723322acf327f9e413cda6400c15c5b2ea1fa34405d83982fba40e6d852da3d91019bf23511314254dc211a90833e5b1798ee52a78198c555644729ad92f060367c74ded37704adfc273a4a33fec821bd2ebd3bc051730e97a4dd14d2b766062592f5eec09d16bb50efebf2cc00dd3e0e3418e60ec84870f7":"800abfe7dc667aa17bcd7c04614bc221a65482ccc04b604602b0e131908a938ea11b48dc515dab7abcbb1e0c7fd66511edc0d86551b7632496e03df94357e1c4ea07a7ce1e381a2fcafdff5f5bf00df828806020e875c00926e4d011f88477a1b01927d73813cad4847c6396b9244621be2b00b63c659253318413443cd244215cd7fd4cbe796e82c6cf70f89cc0c528fb8e344809b31876e7ef739d5160d095c9684188b0c8755c7a468d47f56d6db9ea012924ecb0556fb71312a8d7c93bb2898ea08ee54eeb594548285f06a973cbbe2a0cb02e90f323fe045521f34c68354a6d3e95dbfff1eb64692edc0a44f3d3e408d0e479a541e779a6054259e2d854":256 119a8e1175bSopenharmony_ci 120a8e1175bSopenharmony_ciDH load parameters from DER file (2048-bit, large g, privateValueLength) 121a8e1175bSopenharmony_cidhm_file:"data_files/dh.optlen.der":"b3126aeaf47153c7d67f403030b292b5bd5a6c9eae1c137af34087fce2a36a578d70c5c560ad2bdb924c4a4dbee20a1671be7103ce87defa76908936803dbeca60c33e1289c1a03ac2c6c4e49405e5902fa0596a1cbaa895cc402d5213ed4a5f1f5ba8b5e1ed3da951a4c475afeb0ca660b7368c38c8e809f382d96ae19e60dc984e61cb42b5dfd723322acf327f9e413cda6400c15c5b2ea1fa34405d83982fba40e6d852da3d91019bf23511314254dc211a90833e5b1798ee52a78198c555644729ad92f060367c74ded37704adfc273a4a33fec821bd2ebd3bc051730e97a4dd14d2b766062592f5eec09d16bb50efebf2cc00dd3e0e3418e60ec84870f7":"800abfe7dc667aa17bcd7c04614bc221a65482ccc04b604602b0e131908a938ea11b48dc515dab7abcbb1e0c7fd66511edc0d86551b7632496e03df94357e1c4ea07a7ce1e381a2fcafdff5f5bf00df828806020e875c00926e4d011f88477a1b01927d73813cad4847c6396b9244621be2b00b63c659253318413443cd244215cd7fd4cbe796e82c6cf70f89cc0c528fb8e344809b31876e7ef739d5160d095c9684188b0c8755c7a468d47f56d6db9ea012924ecb0556fb71312a8d7c93bb2898ea08ee54eeb594548285f06a973cbbe2a0cb02e90f323fe045521f34c68354a6d3e95dbfff1eb64692edc0a44f3d3e408d0e479a541e779a6054259e2d854":256 122a8e1175bSopenharmony_ci 123a8e1175bSopenharmony_ciDiffie-Hellman selftest 124a8e1175bSopenharmony_cidhm_selftest: 125