params_api_test.c 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870
  1. /*
  2. * Copyright 2019-2025 The OpenSSL Project Authors. All Rights Reserved.
  3. * Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
  4. *
  5. * Licensed under the Apache License 2.0 (the "License"). You may not use
  6. * this file except in compliance with the License. You can obtain a copy
  7. * in the file LICENSE in the source distribution or at
  8. * https://www.openssl.org/source/license.html
  9. */
  10. #include <string.h>
  11. #include "testutil.h"
  12. #include "internal/nelem.h"
  13. #include "internal/endian.h"
  14. #include <openssl/params.h>
  15. #include <openssl/bn.h>
  16. /* The maximum size of the static buffers used to test most things */
  17. #define MAX_LEN 20
  18. static void swap_copy(unsigned char *out, const void *in, size_t len)
  19. {
  20. size_t j;
  21. for (j = 0; j < len; j++)
  22. out[j] = ((unsigned char *)in)[len - j - 1];
  23. }
  24. /*
  25. * A memory copy that converts the native byte ordering either to or from
  26. * little endian format.
  27. *
  28. * On a little endian machine copying either is just a memcpy(3), on a
  29. * big endian machine copying from native to or from little endian involves
  30. * byte reversal.
  31. */
  32. static void le_copy(unsigned char *out, size_t outlen,
  33. const void *in, size_t inlen)
  34. {
  35. DECLARE_IS_ENDIAN;
  36. if (IS_LITTLE_ENDIAN) {
  37. memcpy(out, in, outlen);
  38. } else {
  39. if (outlen < inlen) {
  40. in = (const char *)in + inlen - outlen;
  41. inlen = outlen;
  42. }
  43. if (!ossl_assert(outlen <= inlen))
  44. return;
  45. swap_copy(out, in, inlen);
  46. }
  47. }
  48. static const struct {
  49. size_t len;
  50. unsigned char value[MAX_LEN];
  51. } raw_values[] = {
  52. { 1, { 0x47 } },
  53. { 1, { 0xd0 } },
  54. { 2, { 0x01, 0xe9 } },
  55. { 2, { 0xff, 0x53 } },
  56. { 3, { 0x16, 0xff, 0x7c } },
  57. { 3, { 0xa8, 0x9c, 0x0e } },
  58. { 4, { 0x38, 0x27, 0xbf, 0x3b } },
  59. { 4, { 0x9f, 0x26, 0x48, 0x22 } },
  60. { 5, { 0x30, 0x65, 0xfa, 0xe4, 0x81 } },
  61. { 5, { 0xd1, 0x76, 0x01, 0x1b, 0xcd } },
  62. { 8, { 0x59, 0xb2, 0x1a, 0xe9, 0x2a, 0xd8, 0x46, 0x40 } },
  63. { 8, { 0xb4, 0xae, 0xbd, 0xb4, 0xdd, 0x04, 0xb1, 0x4c } },
  64. { 16, { 0x61, 0xe8, 0x7e, 0x31, 0xe9, 0x33, 0x83, 0x3d,
  65. 0x87, 0x99, 0xc7, 0xd8, 0x5d, 0xa9, 0x8b, 0x42 } },
  66. { 16, { 0xee, 0x6e, 0x8b, 0xc3, 0xec, 0xcf, 0x37, 0xcc,
  67. 0x89, 0x67, 0xf2, 0x68, 0x33, 0xa0, 0x14, 0xb0 } },
  68. };
  69. static int test_param_type_null(OSSL_PARAM *param)
  70. {
  71. int rc = 0;
  72. uint64_t intval;
  73. double dval;
  74. BIGNUM *bn;
  75. switch(param->data_type) {
  76. case OSSL_PARAM_INTEGER:
  77. if (param->data_size == sizeof(int32_t))
  78. rc = OSSL_PARAM_get_int32(param, (int32_t *)&intval);
  79. else if (param->data_size == sizeof(uint64_t))
  80. rc = OSSL_PARAM_get_int64(param, (int64_t *)&intval);
  81. else
  82. return 1;
  83. break;
  84. case OSSL_PARAM_UNSIGNED_INTEGER:
  85. if (param->data_size == sizeof(uint32_t))
  86. rc = OSSL_PARAM_get_uint32(param, (uint32_t *)&intval);
  87. else if (param->data_size == sizeof(uint64_t))
  88. rc = OSSL_PARAM_get_uint64(param, &intval);
  89. else
  90. rc = OSSL_PARAM_get_BN(param, &bn);
  91. break;
  92. case OSSL_PARAM_REAL:
  93. rc = OSSL_PARAM_get_double(param, &dval);
  94. break;
  95. case OSSL_PARAM_UTF8_STRING:
  96. case OSSL_PARAM_OCTET_STRING:
  97. case OSSL_PARAM_UTF8_PTR:
  98. case OSSL_PARAM_OCTET_PTR:
  99. /* these are allowed to be null */
  100. return 1;
  101. break;
  102. }
  103. /*
  104. * we expect the various OSSL_PARAM_get functions above
  105. * to return failure when the data is set to NULL
  106. */
  107. return rc == 0;
  108. }
  109. static int test_param_type_extra(OSSL_PARAM *param, const unsigned char *cmp,
  110. size_t width)
  111. {
  112. int32_t i32;
  113. int64_t i64;
  114. size_t s, sz;
  115. unsigned char buf[MAX_LEN];
  116. const int bit32 = param->data_size <= sizeof(int32_t);
  117. const int sizet = param->data_size <= sizeof(size_t);
  118. const int signd = param->data_type == OSSL_PARAM_INTEGER;
  119. /*
  120. * Set the unmodified sentinel directly because there is no param array
  121. * for these tests.
  122. */
  123. param->return_size = OSSL_PARAM_UNMODIFIED;
  124. if (signd) {
  125. if ((bit32 && !TEST_true(OSSL_PARAM_get_int32(param, &i32)))
  126. || !TEST_true(OSSL_PARAM_get_int64(param, &i64)))
  127. return 0;
  128. } else {
  129. if ((bit32
  130. && !TEST_true(OSSL_PARAM_get_uint32(param, (uint32_t *)&i32)))
  131. || !TEST_true(OSSL_PARAM_get_uint64(param, (uint64_t *)&i64))
  132. || (sizet && !TEST_true(OSSL_PARAM_get_size_t(param, &s))))
  133. return 0;
  134. }
  135. if (!TEST_false(OSSL_PARAM_modified(param)))
  136. return 0;
  137. /* Check signed types */
  138. if (bit32) {
  139. le_copy(buf, sizeof(i32), &i32, sizeof(i32));
  140. sz = sizeof(i32) < width ? sizeof(i32) : width;
  141. if (!TEST_mem_eq(buf, sz, cmp, sz))
  142. return 0;
  143. }
  144. le_copy(buf, sizeof(i64), &i64, sizeof(i64));
  145. sz = sizeof(i64) < width ? sizeof(i64) : width;
  146. if (!TEST_mem_eq(buf, sz, cmp, sz))
  147. return 0;
  148. if (sizet && !signd) {
  149. le_copy(buf, sizeof(s), &s, sizeof(s));
  150. sz = sizeof(s) < width ? sizeof(s) : width;
  151. if (!TEST_mem_eq(buf, sz, cmp, sz))
  152. return 0;
  153. }
  154. /* Check a widening write if possible */
  155. if (sizeof(size_t) > width) {
  156. if (signd) {
  157. if (!TEST_true(OSSL_PARAM_set_int32(param, 12345))
  158. || !TEST_true(OSSL_PARAM_get_int64(param, &i64))
  159. || !TEST_size_t_eq((size_t)i64, 12345))
  160. return 0;
  161. } else {
  162. if (!TEST_true(OSSL_PARAM_set_uint32(param, 12345))
  163. || !TEST_true(OSSL_PARAM_get_uint64(param, (uint64_t *)&i64))
  164. || !TEST_size_t_eq((size_t)i64, 12345))
  165. return 0;
  166. }
  167. if (!TEST_true(OSSL_PARAM_modified(param)))
  168. return 0;
  169. }
  170. return 1;
  171. }
  172. /*
  173. * The test cases for each of the bastic integral types are similar.
  174. * For each type, a param of that type is set and an attempt to read it
  175. * get is made. Finally, the above function is called to verify that
  176. * the params can be read as other types.
  177. *
  178. * All the real work is done via byte buffers which are converted to machine
  179. * byte order and to little endian for comparisons. Narrower values are best
  180. * compared using little endian because their values and positions don't
  181. * change.
  182. */
  183. static int test_param_int(int n)
  184. {
  185. int in, out;
  186. unsigned char buf[MAX_LEN], cmp[sizeof(int)];
  187. const size_t len = raw_values[n].len >= sizeof(int) ?
  188. sizeof(int) : raw_values[n].len;
  189. OSSL_PARAM param = OSSL_PARAM_int("a", NULL);
  190. if (!TEST_int_eq(test_param_type_null(&param), 1))
  191. return 0;
  192. memset(buf, 0, sizeof(buf));
  193. le_copy(buf, sizeof(in), raw_values[n].value, sizeof(in));
  194. memcpy(&in, buf, sizeof(in));
  195. param.data = &out;
  196. if (!TEST_true(OSSL_PARAM_set_int(&param, in)))
  197. return 0;
  198. le_copy(cmp, sizeof(out), &out, sizeof(out));
  199. if (!TEST_mem_eq(cmp, len, raw_values[n].value, len))
  200. return 0;
  201. in = 0;
  202. if (!TEST_true(OSSL_PARAM_get_int(&param, &in)))
  203. return 0;
  204. le_copy(cmp, sizeof(in), &in, sizeof(in));
  205. if (!TEST_mem_eq(cmp, sizeof(in), raw_values[n].value, sizeof(in)))
  206. return 0;
  207. param.data = &out;
  208. return test_param_type_extra(&param, raw_values[n].value, sizeof(int));
  209. }
  210. static int test_param_long(int n)
  211. {
  212. long int in, out;
  213. unsigned char buf[MAX_LEN], cmp[sizeof(long int)];
  214. const size_t len = raw_values[n].len >= sizeof(long int)
  215. ? sizeof(long int) : raw_values[n].len;
  216. OSSL_PARAM param = OSSL_PARAM_long("a", NULL);
  217. if (!TEST_int_eq(test_param_type_null(&param), 1))
  218. return 0;
  219. memset(buf, 0, sizeof(buf));
  220. le_copy(buf, sizeof(in), raw_values[n].value, sizeof(in));
  221. memcpy(&in, buf, sizeof(in));
  222. param.data = &out;
  223. if (!TEST_true(OSSL_PARAM_set_long(&param, in)))
  224. return 0;
  225. le_copy(cmp, sizeof(out), &out, sizeof(out));
  226. if (!TEST_mem_eq(cmp, len, raw_values[n].value, len))
  227. return 0;
  228. in = 0;
  229. if (!TEST_true(OSSL_PARAM_get_long(&param, &in)))
  230. return 0;
  231. le_copy(cmp, sizeof(in), &in, sizeof(in));
  232. if (!TEST_mem_eq(cmp, sizeof(in), raw_values[n].value, sizeof(in)))
  233. return 0;
  234. param.data = &out;
  235. return test_param_type_extra(&param, raw_values[n].value, sizeof(long int));
  236. }
  237. static int test_param_uint(int n)
  238. {
  239. unsigned int in, out;
  240. unsigned char buf[MAX_LEN], cmp[sizeof(unsigned int)];
  241. const size_t len = raw_values[n].len >= sizeof(unsigned int) ? sizeof(unsigned int) : raw_values[n].len;
  242. OSSL_PARAM param = OSSL_PARAM_uint("a", NULL);
  243. if (!TEST_int_eq(test_param_type_null(&param), 1))
  244. return 0;
  245. memset(buf, 0, sizeof(buf));
  246. le_copy(buf, sizeof(in), raw_values[n].value, sizeof(in));
  247. memcpy(&in, buf, sizeof(in));
  248. param.data = &out;
  249. if (!TEST_true(OSSL_PARAM_set_uint(&param, in)))
  250. return 0;
  251. le_copy(cmp, sizeof(out), &out, sizeof(out));
  252. if (!TEST_mem_eq(cmp, len, raw_values[n].value, len))
  253. return 0;
  254. in = 0;
  255. if (!TEST_true(OSSL_PARAM_get_uint(&param, &in)))
  256. return 0;
  257. le_copy(cmp, sizeof(in), &in, sizeof(in));
  258. if (!TEST_mem_eq(cmp, sizeof(in), raw_values[n].value, sizeof(in)))
  259. return 0;
  260. param.data = &out;
  261. return test_param_type_extra(&param, raw_values[n].value, sizeof(unsigned int));
  262. }
  263. static int test_param_ulong(int n)
  264. {
  265. unsigned long int in, out;
  266. unsigned char buf[MAX_LEN], cmp[sizeof(unsigned long int)];
  267. const size_t len = raw_values[n].len >= sizeof(unsigned long int)
  268. ? sizeof(unsigned long int) : raw_values[n].len;
  269. OSSL_PARAM param = OSSL_PARAM_ulong("a", NULL);
  270. if (!TEST_int_eq(test_param_type_null(&param), 1))
  271. return 0;
  272. memset(buf, 0, sizeof(buf));
  273. le_copy(buf, sizeof(in), raw_values[n].value, sizeof(in));
  274. memcpy(&in, buf, sizeof(in));
  275. param.data = &out;
  276. if (!TEST_true(OSSL_PARAM_set_ulong(&param, in)))
  277. return 0;
  278. le_copy(cmp, sizeof(out), &out, sizeof(out));
  279. if (!TEST_mem_eq(cmp, len, raw_values[n].value, len))
  280. return 0;
  281. in = 0;
  282. if (!TEST_true(OSSL_PARAM_get_ulong(&param, &in)))
  283. return 0;
  284. le_copy(cmp, sizeof(in), &in, sizeof(in));
  285. if (!TEST_mem_eq(cmp, sizeof(in), raw_values[n].value, sizeof(in)))
  286. return 0;
  287. param.data = &out;
  288. return test_param_type_extra(&param, raw_values[n].value, sizeof(unsigned long int));
  289. }
  290. static int test_param_int32(int n)
  291. {
  292. int32_t in, out;
  293. unsigned char buf[MAX_LEN], cmp[sizeof(int32_t)];
  294. const size_t len = raw_values[n].len >= sizeof(int32_t)
  295. ? sizeof(int32_t) : raw_values[n].len;
  296. OSSL_PARAM param = OSSL_PARAM_int32("a", NULL);
  297. if (!TEST_int_eq(test_param_type_null(&param), 1))
  298. return 0;
  299. memset(buf, 0, sizeof(buf));
  300. le_copy(buf, sizeof(in), raw_values[n].value, sizeof(in));
  301. memcpy(&in, buf, sizeof(in));
  302. param.data = &out;
  303. if (!TEST_true(OSSL_PARAM_set_int32(&param, in)))
  304. return 0;
  305. le_copy(cmp, sizeof(out), &out, sizeof(out));
  306. if (!TEST_mem_eq(cmp, len, raw_values[n].value, len))
  307. return 0;
  308. in = 0;
  309. if (!TEST_true(OSSL_PARAM_get_int32(&param, &in)))
  310. return 0;
  311. le_copy(cmp, sizeof(in), &in, sizeof(in));
  312. if (!TEST_mem_eq(cmp, sizeof(in), raw_values[n].value, sizeof(in)))
  313. return 0;
  314. param.data = &out;
  315. return test_param_type_extra(&param, raw_values[n].value, sizeof(int32_t));
  316. }
  317. static int test_param_uint32(int n)
  318. {
  319. uint32_t in, out;
  320. unsigned char buf[MAX_LEN], cmp[sizeof(uint32_t)];
  321. const size_t len = raw_values[n].len >= sizeof(uint32_t)
  322. ? sizeof(uint32_t) : raw_values[n].len;
  323. OSSL_PARAM param = OSSL_PARAM_uint32("a", NULL);
  324. if (!TEST_int_eq(test_param_type_null(&param), 1))
  325. return 0;
  326. memset(buf, 0, sizeof(buf));
  327. le_copy(buf, sizeof(in), raw_values[n].value, sizeof(in));
  328. memcpy(&in, buf, sizeof(in));
  329. param.data = &out;
  330. if (!TEST_true(OSSL_PARAM_set_uint32(&param, in)))
  331. return 0;
  332. le_copy(cmp, sizeof(out), &out, sizeof(out));
  333. if (!TEST_mem_eq(cmp, len, raw_values[n].value, len))
  334. return 0;
  335. in = 0;
  336. if (!TEST_true(OSSL_PARAM_get_uint32(&param, &in)))
  337. return 0;
  338. le_copy(cmp, sizeof(in), &in, sizeof(in));
  339. if (!TEST_mem_eq(cmp, sizeof(in), raw_values[n].value, sizeof(in)))
  340. return 0;
  341. param.data = &out;
  342. return test_param_type_extra(&param, raw_values[n].value, sizeof(uint32_t));
  343. }
  344. static int test_param_int64(int n)
  345. {
  346. int64_t in, out;
  347. unsigned char buf[MAX_LEN], cmp[sizeof(int64_t)];
  348. const size_t len = raw_values[n].len >= sizeof(int64_t)
  349. ? sizeof(int64_t) : raw_values[n].len;
  350. OSSL_PARAM param = OSSL_PARAM_int64("a", NULL);
  351. if (!TEST_int_eq(test_param_type_null(&param), 1))
  352. return 0;
  353. memset(buf, 0, sizeof(buf));
  354. le_copy(buf, sizeof(in), raw_values[n].value, sizeof(in));
  355. memcpy(&in, buf, sizeof(in));
  356. param.data = &out;
  357. if (!TEST_true(OSSL_PARAM_set_int64(&param, in)))
  358. return 0;
  359. le_copy(cmp, sizeof(out), &out, sizeof(out));
  360. if (!TEST_mem_eq(cmp, len, raw_values[n].value, len))
  361. return 0;
  362. in = 0;
  363. if (!TEST_true(OSSL_PARAM_get_int64(&param, &in)))
  364. return 0;
  365. le_copy(cmp, sizeof(in), &in, sizeof(in));
  366. if (!TEST_mem_eq(cmp, sizeof(in), raw_values[n].value, sizeof(in)))
  367. return 0;
  368. param.data = &out;
  369. return test_param_type_extra(&param, raw_values[n].value, sizeof(int64_t));
  370. }
  371. static int test_param_uint64(int n)
  372. {
  373. uint64_t in, out;
  374. unsigned char buf[MAX_LEN], cmp[sizeof(uint64_t)];
  375. const size_t len = raw_values[n].len >= sizeof(uint64_t)
  376. ? sizeof(uint64_t) : raw_values[n].len;
  377. OSSL_PARAM param = OSSL_PARAM_uint64("a", NULL);
  378. if (!TEST_int_eq(test_param_type_null(&param), 1))
  379. return 0;
  380. memset(buf, 0, sizeof(buf));
  381. le_copy(buf, sizeof(in), raw_values[n].value, sizeof(in));
  382. memcpy(&in, buf, sizeof(in));
  383. param.data = &out;
  384. if (!TEST_true(OSSL_PARAM_set_uint64(&param, in)))
  385. return 0;
  386. le_copy(cmp, sizeof(out), &out, sizeof(out));
  387. if (!TEST_mem_eq(cmp, len, raw_values[n].value, len))
  388. return 0;
  389. in = 0;
  390. if (!TEST_true(OSSL_PARAM_get_uint64(&param, &in)))
  391. return 0;
  392. le_copy(cmp, sizeof(in), &in, sizeof(in));
  393. if (!TEST_mem_eq(cmp, sizeof(in), raw_values[n].value, sizeof(in)))
  394. return 0;
  395. param.data = &out;
  396. return test_param_type_extra(&param, raw_values[n].value, sizeof(uint64_t));
  397. }
  398. static int test_param_size_t(int n)
  399. {
  400. size_t in, out;
  401. unsigned char buf[MAX_LEN], cmp[sizeof(size_t)];
  402. const size_t len = raw_values[n].len >= sizeof(size_t)
  403. ? sizeof(size_t) : raw_values[n].len;
  404. OSSL_PARAM param = OSSL_PARAM_size_t("a", NULL);
  405. if (!TEST_int_eq(test_param_type_null(&param), 1))
  406. return 0;
  407. memset(buf, 0, sizeof(buf));
  408. le_copy(buf, sizeof(in), raw_values[n].value, sizeof(in));
  409. memcpy(&in, buf, sizeof(in));
  410. param.data = &out;
  411. if (!TEST_true(OSSL_PARAM_set_size_t(&param, in)))
  412. return 0;
  413. le_copy(cmp, sizeof(out), &out, sizeof(out));
  414. if (!TEST_mem_eq(cmp, len, raw_values[n].value, len))
  415. return 0;
  416. in = 0;
  417. if (!TEST_true(OSSL_PARAM_get_size_t(&param, &in)))
  418. return 0;
  419. le_copy(cmp, sizeof(in), &in, sizeof(in));
  420. if (!TEST_mem_eq(cmp, sizeof(in), raw_values[n].value, sizeof(in)))
  421. return 0;
  422. param.data = &out;
  423. return test_param_type_extra(&param, raw_values[n].value, sizeof(size_t));
  424. }
  425. static int test_param_time_t(int n)
  426. {
  427. time_t in, out;
  428. unsigned char buf[MAX_LEN], cmp[sizeof(time_t)];
  429. const size_t len = raw_values[n].len >= sizeof(time_t)
  430. ? sizeof(time_t) : raw_values[n].len;
  431. OSSL_PARAM param = OSSL_PARAM_time_t("a", NULL);
  432. if (!TEST_int_eq(test_param_type_null(&param), 1))
  433. return 0;
  434. memset(buf, 0, sizeof(buf));
  435. le_copy(buf, sizeof(in), raw_values[n].value, sizeof(in));
  436. memcpy(&in, buf, sizeof(in));
  437. param.data = &out;
  438. if (!TEST_true(OSSL_PARAM_set_time_t(&param, in)))
  439. return 0;
  440. le_copy(cmp, sizeof(out), &out, sizeof(out));
  441. if (!TEST_mem_eq(cmp, len, raw_values[n].value, len))
  442. return 0;
  443. in = 0;
  444. if (!TEST_true(OSSL_PARAM_get_time_t(&param, &in)))
  445. return 0;
  446. le_copy(cmp, sizeof(in), &in, sizeof(in));
  447. if (!TEST_mem_eq(cmp, sizeof(in), raw_values[n].value, sizeof(in)))
  448. return 0;
  449. param.data = &out;
  450. return test_param_type_extra(&param, raw_values[n].value, sizeof(size_t));
  451. }
  452. static int test_param_bignum(int n)
  453. {
  454. unsigned char buf[MAX_LEN], bnbuf[MAX_LEN];
  455. const size_t len = raw_values[n].len;
  456. BIGNUM *b = NULL, *c = NULL;
  457. OSSL_PARAM param = OSSL_PARAM_DEFN("bn", OSSL_PARAM_UNSIGNED_INTEGER,
  458. NULL, 0);
  459. int ret = 0;
  460. if (!TEST_int_eq(test_param_type_null(&param), 1))
  461. return 0;
  462. param.data = bnbuf;
  463. param.data_size = sizeof(bnbuf);
  464. if (!TEST_ptr(b = BN_lebin2bn(raw_values[n].value, (int)len, NULL)))
  465. goto err;
  466. if (!TEST_true(OSSL_PARAM_set_BN(&param, b)))
  467. goto err;
  468. le_copy(buf, len, bnbuf, sizeof(bnbuf));
  469. if (!TEST_mem_eq(raw_values[n].value, len, buf, len))
  470. goto err;
  471. param.data_size = param.return_size;
  472. if (!TEST_true(OSSL_PARAM_get_BN(&param, &c))
  473. || !TEST_BN_eq(b, c))
  474. goto err;
  475. ret = 1;
  476. err:
  477. BN_free(b);
  478. BN_free(c);
  479. return ret;
  480. }
  481. static int test_param_signed_bignum(int n)
  482. {
  483. unsigned char buf[MAX_LEN], bnbuf[MAX_LEN];
  484. const size_t len = raw_values[n].len;
  485. BIGNUM *b = NULL, *c = NULL;
  486. OSSL_PARAM param = OSSL_PARAM_DEFN("bn", OSSL_PARAM_INTEGER, NULL, 0);
  487. int ret = 0;
  488. if (!TEST_int_eq(test_param_type_null(&param), 1))
  489. return 0;
  490. param.data = bnbuf;
  491. param.data_size = sizeof(bnbuf);
  492. if (!TEST_ptr(b = BN_signed_lebin2bn(raw_values[n].value, (int)len, NULL)))
  493. goto err;
  494. /* raw_values are little endian */
  495. if (!TEST_false(!!(raw_values[n].value[len - 1] & 0x80) ^ BN_is_negative(b)))
  496. goto err;
  497. if (!TEST_true(OSSL_PARAM_set_BN(&param, b)))
  498. goto err;
  499. le_copy(buf, len, bnbuf, sizeof(bnbuf));
  500. if (!TEST_mem_eq(raw_values[n].value, len, buf, len))
  501. goto err;
  502. param.data_size = param.return_size;
  503. if (!TEST_true(OSSL_PARAM_get_BN(&param, &c))
  504. || !TEST_BN_eq(b, c)) {
  505. BN_print_fp(stderr, c);
  506. goto err;
  507. }
  508. ret = 1;
  509. err:
  510. BN_free(b);
  511. BN_free(c);
  512. return ret;
  513. }
  514. static int test_param_real(void)
  515. {
  516. double p;
  517. OSSL_PARAM param = OSSL_PARAM_double("r", NULL);
  518. if (!TEST_int_eq(test_param_type_null(&param), 1))
  519. return 0;
  520. param.data = &p;
  521. return TEST_true(OSSL_PARAM_set_double(&param, 3.14159))
  522. && TEST_double_eq(p, 3.14159);
  523. }
  524. static int test_param_construct(int tstid)
  525. {
  526. static const char *int_names[] = {
  527. "int", "long", "int32", "int64"
  528. };
  529. static const char *uint_names[] = {
  530. "uint", "ulong", "uint32", "uint64", "size_t"
  531. };
  532. static const unsigned char bn_val[16] = {
  533. 0xac, 0x75, 0x22, 0x7d, 0x81, 0x06, 0x7a, 0x23,
  534. 0xa6, 0xed, 0x87, 0xc7, 0xab, 0xf4, 0x73, 0x22
  535. };
  536. OSSL_PARAM *p = NULL, *p1 = NULL;
  537. static const OSSL_PARAM params_empty[] = {
  538. OSSL_PARAM_END
  539. };
  540. OSSL_PARAM params[20];
  541. char buf[100], buf2[100], *bufp, *bufp2;
  542. unsigned char ubuf[100];
  543. void *vp, *vpn = NULL, *vp2;
  544. OSSL_PARAM *cp;
  545. int i, n = 0, ret = 0;
  546. unsigned int u;
  547. long int l;
  548. unsigned long int ul;
  549. int32_t i32;
  550. uint32_t u32;
  551. int64_t i64;
  552. uint64_t u64;
  553. size_t j, k, s;
  554. double d, d2;
  555. BIGNUM *bn = NULL, *bn2 = NULL;
  556. params[n++] = OSSL_PARAM_construct_int("int", &i);
  557. params[n++] = OSSL_PARAM_construct_uint("uint", &u);
  558. params[n++] = OSSL_PARAM_construct_long("long", &l);
  559. params[n++] = OSSL_PARAM_construct_ulong("ulong", &ul);
  560. params[n++] = OSSL_PARAM_construct_int32("int32", &i32);
  561. params[n++] = OSSL_PARAM_construct_int64("int64", &i64);
  562. params[n++] = OSSL_PARAM_construct_uint32("uint32", &u32);
  563. params[n++] = OSSL_PARAM_construct_uint64("uint64", &u64);
  564. params[n++] = OSSL_PARAM_construct_size_t("size_t", &s);
  565. params[n++] = OSSL_PARAM_construct_double("double", &d);
  566. params[n++] = OSSL_PARAM_construct_BN("bignum", ubuf, sizeof(ubuf));
  567. params[n++] = OSSL_PARAM_construct_utf8_string("utf8str", buf, sizeof(buf));
  568. params[n++] = OSSL_PARAM_construct_octet_string("octstr", buf, sizeof(buf));
  569. params[n++] = OSSL_PARAM_construct_utf8_ptr("utf8ptr", &bufp, 0);
  570. params[n++] = OSSL_PARAM_construct_octet_ptr("octptr", &vp, 0);
  571. params[n] = OSSL_PARAM_construct_end();
  572. switch (tstid) {
  573. case 0:
  574. p = params;
  575. break;
  576. case 1:
  577. p = OSSL_PARAM_merge(params, params_empty);
  578. break;
  579. case 2:
  580. p = OSSL_PARAM_dup(params);
  581. break;
  582. default:
  583. p1 = OSSL_PARAM_dup(params);
  584. p = OSSL_PARAM_merge(p1, params_empty);
  585. break;
  586. }
  587. /* Search failure */
  588. if (!TEST_ptr_null(OSSL_PARAM_locate(p, "fnord")))
  589. goto err;
  590. /* All signed integral types */
  591. for (j = 0; j < OSSL_NELEM(int_names); j++) {
  592. if (!TEST_ptr(cp = OSSL_PARAM_locate(p, int_names[j]))
  593. || !TEST_true(OSSL_PARAM_set_int32(cp, (int32_t)(3 + j)))
  594. || !TEST_true(OSSL_PARAM_get_int64(cp, &i64))
  595. || !TEST_size_t_eq(cp->data_size, cp->return_size)
  596. || !TEST_size_t_eq((size_t)i64, 3 + j)) {
  597. TEST_note("iteration %zu var %s", j + 1, int_names[j]);
  598. goto err;
  599. }
  600. }
  601. /* All unsigned integral types */
  602. for (j = 0; j < OSSL_NELEM(uint_names); j++) {
  603. if (!TEST_ptr(cp = OSSL_PARAM_locate(p, uint_names[j]))
  604. || !TEST_true(OSSL_PARAM_set_uint32(cp, (uint32_t)(3 + j)))
  605. || !TEST_true(OSSL_PARAM_get_uint64(cp, &u64))
  606. || !TEST_size_t_eq(cp->data_size, cp->return_size)
  607. || !TEST_size_t_eq((size_t)u64, 3 + j)) {
  608. TEST_note("iteration %zu var %s", j + 1, uint_names[j]);
  609. goto err;
  610. }
  611. }
  612. /* Real */
  613. if (!TEST_ptr(cp = OSSL_PARAM_locate(p, "double"))
  614. || !TEST_true(OSSL_PARAM_set_double(cp, 3.14))
  615. || !TEST_true(OSSL_PARAM_get_double(cp, &d2))
  616. || !TEST_size_t_eq(cp->return_size, sizeof(double))
  617. || !TEST_double_eq(d2, 3.14)
  618. || (tstid <= 1 && !TEST_double_eq(d, d2)))
  619. goto err;
  620. /* UTF8 string */
  621. bufp = NULL;
  622. if (!TEST_ptr(cp = OSSL_PARAM_locate(p, "utf8str"))
  623. || !TEST_true(OSSL_PARAM_set_utf8_string(cp, "abcdef"))
  624. || !TEST_size_t_eq(cp->return_size, sizeof("abcdef") - 1)
  625. || !TEST_true(OSSL_PARAM_get_utf8_string(cp, &bufp, 0))
  626. || !TEST_str_eq(bufp, "abcdef")) {
  627. OPENSSL_free(bufp);
  628. goto err;
  629. }
  630. OPENSSL_free(bufp);
  631. bufp = buf2;
  632. if (!TEST_true(OSSL_PARAM_get_utf8_string(cp, &bufp, sizeof(buf2)))
  633. || !TEST_str_eq(buf2, "abcdef"))
  634. goto err;
  635. /* UTF8 pointer */
  636. /* Note that the size of a UTF8 string does *NOT* include the NUL byte */
  637. bufp = buf;
  638. if (!TEST_ptr(cp = OSSL_PARAM_locate(p, "utf8ptr"))
  639. || !TEST_true(OSSL_PARAM_set_utf8_ptr(cp, "tuvwxyz"))
  640. || !TEST_size_t_eq(cp->return_size, sizeof("tuvwxyz") - 1)
  641. || !TEST_true(OSSL_PARAM_get_utf8_ptr(cp, (const char **)&bufp2))
  642. || !TEST_str_eq(bufp2, "tuvwxyz")
  643. || (tstid <= 1 && !TEST_ptr_eq(bufp2, bufp)))
  644. goto err;
  645. /* OCTET string */
  646. if (!TEST_ptr(cp = OSSL_PARAM_locate(p, "octstr"))
  647. || !TEST_true(OSSL_PARAM_set_octet_string(cp, "abcdefghi",
  648. sizeof("abcdefghi")))
  649. || !TEST_size_t_eq(cp->return_size, sizeof("abcdefghi")))
  650. goto err;
  651. /* Match the return size to avoid trailing garbage bytes */
  652. cp->data_size = cp->return_size;
  653. if (!TEST_true(OSSL_PARAM_get_octet_string(cp, &vpn, 0, &s))
  654. || !TEST_size_t_eq(s, sizeof("abcdefghi"))
  655. || !TEST_mem_eq(vpn, sizeof("abcdefghi"),
  656. "abcdefghi", sizeof("abcdefghi")))
  657. goto err;
  658. vp = buf2;
  659. if (!TEST_true(OSSL_PARAM_get_octet_string(cp, &vp, sizeof(buf2), &s))
  660. || !TEST_size_t_eq(s, sizeof("abcdefghi"))
  661. || !TEST_mem_eq(vp, sizeof("abcdefghi"),
  662. "abcdefghi", sizeof("abcdefghi")))
  663. goto err;
  664. /* OCTET pointer */
  665. vp = &l;
  666. if (!TEST_ptr(cp = OSSL_PARAM_locate(p, "octptr"))
  667. || !TEST_true(OSSL_PARAM_set_octet_ptr(cp, &ul, sizeof(ul)))
  668. || !TEST_size_t_eq(cp->return_size, sizeof(ul))
  669. || (tstid <= 1 && !TEST_ptr_eq(vp, &ul)))
  670. goto err;
  671. /* Match the return size to avoid trailing garbage bytes */
  672. cp->data_size = cp->return_size;
  673. if (!TEST_true(OSSL_PARAM_get_octet_ptr(cp, (const void **)&vp2, &k))
  674. || !TEST_size_t_eq(k, sizeof(ul))
  675. || (tstid <= 1 && !TEST_ptr_eq(vp2, vp)))
  676. goto err;
  677. /* BIGNUM */
  678. if (!TEST_ptr(cp = OSSL_PARAM_locate(p, "bignum"))
  679. || !TEST_ptr(bn = BN_lebin2bn(bn_val, (int)sizeof(bn_val), NULL))
  680. || !TEST_true(OSSL_PARAM_set_BN(cp, bn))
  681. || !TEST_size_t_eq(cp->data_size, cp->return_size))
  682. goto err;
  683. /* Match the return size to avoid trailing garbage bytes */
  684. cp->data_size = cp->return_size;
  685. if (!TEST_true(OSSL_PARAM_get_BN(cp, &bn2))
  686. || !TEST_BN_eq(bn, bn2))
  687. goto err;
  688. ret = 1;
  689. err:
  690. if (p != params)
  691. OPENSSL_free(p);
  692. OPENSSL_free(p1);
  693. OPENSSL_free(vpn);
  694. BN_free(bn);
  695. BN_free(bn2);
  696. return ret;
  697. }
  698. static int test_param_modified(void)
  699. {
  700. OSSL_PARAM param[3] = { OSSL_PARAM_int("a", NULL),
  701. OSSL_PARAM_int("b", NULL),
  702. OSSL_PARAM_END };
  703. int a, b;
  704. param->data = &a;
  705. param[1].data = &b;
  706. if (!TEST_false(OSSL_PARAM_modified(param))
  707. && !TEST_true(OSSL_PARAM_set_int32(param, 1234))
  708. && !TEST_true(OSSL_PARAM_modified(param))
  709. && !TEST_false(OSSL_PARAM_modified(param + 1))
  710. && !TEST_true(OSSL_PARAM_set_int32(param + 1, 1))
  711. && !TEST_true(OSSL_PARAM_modified(param + 1)))
  712. return 0;
  713. OSSL_PARAM_set_all_unmodified(param);
  714. if (!TEST_false(OSSL_PARAM_modified(param))
  715. && !TEST_true(OSSL_PARAM_set_int32(param, 4321))
  716. && !TEST_true(OSSL_PARAM_modified(param))
  717. && !TEST_false(OSSL_PARAM_modified(param + 1))
  718. && !TEST_true(OSSL_PARAM_set_int32(param + 1, 2))
  719. && !TEST_true(OSSL_PARAM_modified(param + 1)))
  720. return 0;
  721. return 1;
  722. }
  723. static int test_param_copy_null(void)
  724. {
  725. int ret, val;
  726. int a = 1, b = 2, i = 0;
  727. OSSL_PARAM *cp1 = NULL, *cp2 = NULL, *p;
  728. OSSL_PARAM param[3];
  729. param[i++] = OSSL_PARAM_construct_int("a", &a);
  730. param[i++] = OSSL_PARAM_construct_int("b", &b);
  731. param[i] = OSSL_PARAM_construct_end();
  732. ret = TEST_ptr_null(OSSL_PARAM_dup(NULL))
  733. && TEST_ptr(cp1 = OSSL_PARAM_merge(NULL, param))
  734. && TEST_ptr(p = OSSL_PARAM_locate(cp1, "a"))
  735. && TEST_true(OSSL_PARAM_get_int(p, &val))
  736. && TEST_int_eq(val, 1)
  737. && TEST_ptr(p = OSSL_PARAM_locate(cp1, "b"))
  738. && TEST_true(OSSL_PARAM_get_int(p, &val))
  739. && TEST_int_eq(val, 2)
  740. && TEST_ptr(cp2 = OSSL_PARAM_merge(param, NULL))
  741. && TEST_ptr(p = OSSL_PARAM_locate(cp2, "a"))
  742. && TEST_true(OSSL_PARAM_get_int(p, &val))
  743. && TEST_int_eq(val, 1)
  744. && TEST_ptr(p = OSSL_PARAM_locate(cp2, "b"))
  745. && TEST_true(OSSL_PARAM_get_int(p, &val))
  746. && TEST_int_eq(val, 2)
  747. && TEST_ptr_null(OSSL_PARAM_merge(NULL, NULL));
  748. OSSL_PARAM_free(cp2);
  749. OSSL_PARAM_free(cp1);
  750. return ret;
  751. }
  752. static int test_param_merge(void)
  753. {
  754. int val, ret;
  755. int values[] = {1, 2, 3, 4};
  756. OSSL_PARAM *p = NULL, *cp = NULL;
  757. OSSL_PARAM param[3], param1[3];
  758. param[0] = OSSL_PARAM_construct_int("diff1", &values[0]);
  759. param[1] = OSSL_PARAM_construct_int("same", &values[1]);
  760. param[2] = OSSL_PARAM_construct_end();
  761. param1[0] = OSSL_PARAM_construct_int("diff2", &values[2]);
  762. param1[1] = OSSL_PARAM_construct_int("same", &values[3]);
  763. param1[2] = OSSL_PARAM_construct_end();
  764. ret = TEST_ptr(p = OSSL_PARAM_merge(param, param1))
  765. && TEST_ptr(cp = OSSL_PARAM_locate(p, "diff1"))
  766. && TEST_true(OSSL_PARAM_get_int(p, &val))
  767. && TEST_int_eq(val, values[0])
  768. && TEST_ptr(cp = OSSL_PARAM_locate(p, "diff2"))
  769. && TEST_true(OSSL_PARAM_get_int(cp, &val))
  770. && TEST_int_eq(val, values[2])
  771. && TEST_ptr(cp = OSSL_PARAM_locate(p, "same"))
  772. && TEST_true(OSSL_PARAM_get_int(cp, &val))
  773. && TEST_int_eq(val, values[3]);
  774. OSSL_PARAM_free(p);
  775. return ret;
  776. }
  777. int setup_tests(void)
  778. {
  779. ADD_ALL_TESTS(test_param_int, OSSL_NELEM(raw_values));
  780. ADD_ALL_TESTS(test_param_long, OSSL_NELEM(raw_values));
  781. ADD_ALL_TESTS(test_param_uint, OSSL_NELEM(raw_values));
  782. ADD_ALL_TESTS(test_param_ulong, OSSL_NELEM(raw_values));
  783. ADD_ALL_TESTS(test_param_int32, OSSL_NELEM(raw_values));
  784. ADD_ALL_TESTS(test_param_uint32, OSSL_NELEM(raw_values));
  785. ADD_ALL_TESTS(test_param_size_t, OSSL_NELEM(raw_values));
  786. ADD_ALL_TESTS(test_param_time_t, OSSL_NELEM(raw_values));
  787. ADD_ALL_TESTS(test_param_int64, OSSL_NELEM(raw_values));
  788. ADD_ALL_TESTS(test_param_uint64, OSSL_NELEM(raw_values));
  789. ADD_ALL_TESTS(test_param_bignum, OSSL_NELEM(raw_values));
  790. ADD_ALL_TESTS(test_param_signed_bignum, OSSL_NELEM(raw_values));
  791. ADD_TEST(test_param_real);
  792. ADD_ALL_TESTS(test_param_construct, 4);
  793. ADD_TEST(test_param_modified);
  794. ADD_TEST(test_param_copy_null);
  795. ADD_TEST(test_param_merge);
  796. return 1;
  797. }