loader.h (51229B)
1 /* 2 * loader.h - load platform dependent DSO containing freebl implementation. 3 * 4 * This Source Code Form is subject to the terms of the Mozilla Public 5 * License, v. 2.0. If a copy of the MPL was not distributed with this 6 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ 7 8 #ifndef _LOADER_H_ 9 #define _LOADER_H_ 1 10 11 #include "blapi.h" 12 13 #define FREEBL_VERSION 0x0332 14 15 struct FREEBLVectorStr { 16 17 unsigned short length; /* of this struct in bytes */ 18 unsigned short version; /* of this struct. */ 19 20 RSAPrivateKey *(*p_RSA_NewKey)(int keySizeInBits, 21 SECItem *publicExponent); 22 23 SECStatus (*p_RSA_PublicKeyOp)(RSAPublicKey *key, 24 unsigned char *output, 25 const unsigned char *input); 26 27 SECStatus (*p_RSA_PrivateKeyOp)(RSAPrivateKey *key, 28 unsigned char *output, 29 const unsigned char *input); 30 31 SECStatus (*p_DSA_NewKey)(const PQGParams *params, 32 DSAPrivateKey **privKey); 33 34 SECStatus (*p_DSA_SignDigest)(DSAPrivateKey *key, 35 SECItem *signature, 36 const SECItem *digest); 37 38 SECStatus (*p_DSA_VerifyDigest)(DSAPublicKey *key, 39 const SECItem *signature, 40 const SECItem *digest); 41 42 SECStatus (*p_DSA_NewKeyFromSeed)(const PQGParams *params, 43 const unsigned char *seed, 44 DSAPrivateKey **privKey); 45 46 SECStatus (*p_DSA_SignDigestWithSeed)(DSAPrivateKey *key, 47 SECItem *signature, 48 const SECItem *digest, 49 const unsigned char *seed); 50 51 SECStatus (*p_DH_GenParam)(int primeLen, DHParams **params); 52 53 SECStatus (*p_DH_NewKey)(DHParams *params, 54 DHPrivateKey **privKey); 55 56 SECStatus (*p_DH_Derive)(SECItem *publicValue, 57 SECItem *prime, 58 SECItem *privateValue, 59 SECItem *derivedSecret, 60 unsigned int maxOutBytes); 61 62 SECStatus (*p_KEA_Derive)(SECItem *prime, 63 SECItem *public1, 64 SECItem *public2, 65 SECItem *private1, 66 SECItem *private2, 67 SECItem *derivedSecret); 68 69 PRBool (*p_KEA_Verify)(SECItem *Y, SECItem *prime, SECItem *subPrime); 70 71 RC4Context *(*p_RC4_CreateContext)(const unsigned char *key, int len); 72 73 void (*p_RC4_DestroyContext)(RC4Context *cx, PRBool freeit); 74 75 SECStatus (*p_RC4_Encrypt)(RC4Context *cx, unsigned char *output, 76 unsigned int *outputLen, unsigned int maxOutputLen, 77 const unsigned char *input, unsigned int inputLen); 78 79 SECStatus (*p_RC4_Decrypt)(RC4Context *cx, unsigned char *output, 80 unsigned int *outputLen, unsigned int maxOutputLen, 81 const unsigned char *input, unsigned int inputLen); 82 83 RC2Context *(*p_RC2_CreateContext)(const unsigned char *key, 84 unsigned int len, const unsigned char *iv, 85 int mode, unsigned effectiveKeyLen); 86 87 void (*p_RC2_DestroyContext)(RC2Context *cx, PRBool freeit); 88 89 SECStatus (*p_RC2_Encrypt)(RC2Context *cx, unsigned char *output, 90 unsigned int *outputLen, unsigned int maxOutputLen, 91 const unsigned char *input, unsigned int inputLen); 92 93 SECStatus (*p_RC2_Decrypt)(RC2Context *cx, unsigned char *output, 94 unsigned int *outputLen, unsigned int maxOutputLen, 95 const unsigned char *input, unsigned int inputLen); 96 97 RC5Context *(*p_RC5_CreateContext)(const SECItem *key, unsigned int rounds, 98 unsigned int wordSize, const unsigned char *iv, int mode); 99 100 void (*p_RC5_DestroyContext)(RC5Context *cx, PRBool freeit); 101 102 SECStatus (*p_RC5_Encrypt)(RC5Context *cx, unsigned char *output, 103 unsigned int *outputLen, unsigned int maxOutputLen, 104 const unsigned char *input, unsigned int inputLen); 105 106 SECStatus (*p_RC5_Decrypt)(RC5Context *cx, unsigned char *output, 107 unsigned int *outputLen, unsigned int maxOutputLen, 108 const unsigned char *input, unsigned int inputLen); 109 110 DESContext *(*p_DES_CreateContext)(const unsigned char *key, 111 const unsigned char *iv, 112 int mode, PRBool encrypt); 113 114 void (*p_DES_DestroyContext)(DESContext *cx, PRBool freeit); 115 116 SECStatus (*p_DES_Encrypt)(DESContext *cx, unsigned char *output, 117 unsigned int *outputLen, unsigned int maxOutputLen, 118 const unsigned char *input, unsigned int inputLen); 119 120 SECStatus (*p_DES_Decrypt)(DESContext *cx, unsigned char *output, 121 unsigned int *outputLen, unsigned int maxOutputLen, 122 const unsigned char *input, unsigned int inputLen); 123 124 AESContext *(*p_AES_CreateContext)(const unsigned char *key, 125 const unsigned char *iv, 126 int mode, int encrypt, unsigned int keylen, 127 unsigned int blocklen); 128 129 void (*p_AES_DestroyContext)(AESContext *cx, PRBool freeit); 130 131 SECStatus (*p_AES_Encrypt)(AESContext *cx, unsigned char *output, 132 unsigned int *outputLen, unsigned int maxOutputLen, 133 const unsigned char *input, unsigned int inputLen); 134 135 SECStatus (*p_AES_Decrypt)(AESContext *cx, unsigned char *output, 136 unsigned int *outputLen, unsigned int maxOutputLen, 137 const unsigned char *input, unsigned int inputLen); 138 139 SECStatus (*p_MD5_Hash)(unsigned char *dest, const char *src); 140 141 SECStatus (*p_MD5_HashBuf)(unsigned char *dest, const unsigned char *src, 142 PRUint32 src_length); 143 144 MD5Context *(*p_MD5_NewContext)(void); 145 146 void (*p_MD5_DestroyContext)(MD5Context *cx, PRBool freeit); 147 148 void (*p_MD5_Begin)(MD5Context *cx); 149 150 void (*p_MD5_Update)(MD5Context *cx, 151 const unsigned char *input, unsigned int inputLen); 152 153 void (*p_MD5_End)(MD5Context *cx, unsigned char *digest, 154 unsigned int *digestLen, unsigned int maxDigestLen); 155 156 unsigned int (*p_MD5_FlattenSize)(MD5Context *cx); 157 158 SECStatus (*p_MD5_Flatten)(MD5Context *cx, unsigned char *space); 159 160 MD5Context *(*p_MD5_Resurrect)(unsigned char *space, void *arg); 161 162 void (*p_MD5_TraceState)(MD5Context *cx); 163 164 SECStatus (*p_MD2_Hash)(unsigned char *dest, const char *src); 165 166 MD2Context *(*p_MD2_NewContext)(void); 167 168 void (*p_MD2_DestroyContext)(MD2Context *cx, PRBool freeit); 169 170 void (*p_MD2_Begin)(MD2Context *cx); 171 172 void (*p_MD2_Update)(MD2Context *cx, 173 const unsigned char *input, unsigned int inputLen); 174 175 void (*p_MD2_End)(MD2Context *cx, unsigned char *digest, 176 unsigned int *digestLen, unsigned int maxDigestLen); 177 178 unsigned int (*p_MD2_FlattenSize)(MD2Context *cx); 179 180 SECStatus (*p_MD2_Flatten)(MD2Context *cx, unsigned char *space); 181 182 MD2Context *(*p_MD2_Resurrect)(unsigned char *space, void *arg); 183 184 SECStatus (*p_SHA1_Hash)(unsigned char *dest, const char *src); 185 186 SECStatus (*p_SHA1_HashBuf)(unsigned char *dest, const unsigned char *src, 187 PRUint32 src_length); 188 189 SHA1Context *(*p_SHA1_NewContext)(void); 190 191 void (*p_SHA1_DestroyContext)(SHA1Context *cx, PRBool freeit); 192 193 void (*p_SHA1_Begin)(SHA1Context *cx); 194 195 void (*p_SHA1_Update)(SHA1Context *cx, const unsigned char *input, 196 unsigned int inputLen); 197 198 void (*p_SHA1_End)(SHA1Context *cx, unsigned char *digest, 199 unsigned int *digestLen, unsigned int maxDigestLen); 200 201 void (*p_SHA1_TraceState)(SHA1Context *cx); 202 203 unsigned int (*p_SHA1_FlattenSize)(SHA1Context *cx); 204 205 SECStatus (*p_SHA1_Flatten)(SHA1Context *cx, unsigned char *space); 206 207 SHA1Context *(*p_SHA1_Resurrect)(unsigned char *space, void *arg); 208 209 SECStatus (*p_RNG_RNGInit)(void); 210 211 SECStatus (*p_RNG_RandomUpdate)(const void *data, size_t bytes); 212 213 SECStatus (*p_RNG_GenerateGlobalRandomBytes)(void *dest, size_t len); 214 215 void (*p_RNG_RNGShutdown)(void); 216 217 SECStatus (*p_PQG_ParamGen)(unsigned int j, PQGParams **pParams, 218 PQGVerify **pVfy); 219 220 SECStatus (*p_PQG_ParamGenSeedLen)(unsigned int j, unsigned int seedBytes, 221 PQGParams **pParams, PQGVerify **pVfy); 222 223 SECStatus (*p_PQG_VerifyParams)(const PQGParams *params, 224 const PQGVerify *vfy, SECStatus *result); 225 226 /* Version 3.001 came to here */ 227 228 SECStatus (*p_RSA_PrivateKeyOpDoubleChecked)(RSAPrivateKey *key, 229 unsigned char *output, 230 const unsigned char *input); 231 232 SECStatus (*p_RSA_PrivateKeyCheck)(const RSAPrivateKey *key); 233 234 void (*p_BL_Cleanup)(void); 235 236 /* Version 3.002 came to here */ 237 238 SHA256Context *(*p_SHA256_NewContext)(void); 239 void (*p_SHA256_DestroyContext)(SHA256Context *cx, PRBool freeit); 240 void (*p_SHA256_Begin)(SHA256Context *cx); 241 void (*p_SHA256_Update)(SHA256Context *cx, const unsigned char *input, 242 unsigned int inputLen); 243 void (*p_SHA256_End)(SHA256Context *cx, unsigned char *digest, 244 unsigned int *digestLen, unsigned int maxDigestLen); 245 SECStatus (*p_SHA256_HashBuf)(unsigned char *dest, const unsigned char *src, 246 PRUint32 src_length); 247 SECStatus (*p_SHA256_Hash)(unsigned char *dest, const char *src); 248 void (*p_SHA256_TraceState)(SHA256Context *cx); 249 unsigned int (*p_SHA256_FlattenSize)(SHA256Context *cx); 250 SECStatus (*p_SHA256_Flatten)(SHA256Context *cx, unsigned char *space); 251 SHA256Context *(*p_SHA256_Resurrect)(unsigned char *space, void *arg); 252 253 SHA512Context *(*p_SHA512_NewContext)(void); 254 void (*p_SHA512_DestroyContext)(SHA512Context *cx, PRBool freeit); 255 void (*p_SHA512_Begin)(SHA512Context *cx); 256 void (*p_SHA512_Update)(SHA512Context *cx, const unsigned char *input, 257 unsigned int inputLen); 258 void (*p_SHA512_End)(SHA512Context *cx, unsigned char *digest, 259 unsigned int *digestLen, unsigned int maxDigestLen); 260 SECStatus (*p_SHA512_HashBuf)(unsigned char *dest, const unsigned char *src, 261 PRUint32 src_length); 262 SECStatus (*p_SHA512_Hash)(unsigned char *dest, const char *src); 263 void (*p_SHA512_TraceState)(SHA512Context *cx); 264 unsigned int (*p_SHA512_FlattenSize)(SHA512Context *cx); 265 SECStatus (*p_SHA512_Flatten)(SHA512Context *cx, unsigned char *space); 266 SHA512Context *(*p_SHA512_Resurrect)(unsigned char *space, void *arg); 267 268 SHA384Context *(*p_SHA384_NewContext)(void); 269 void (*p_SHA384_DestroyContext)(SHA384Context *cx, PRBool freeit); 270 void (*p_SHA384_Begin)(SHA384Context *cx); 271 void (*p_SHA384_Update)(SHA384Context *cx, const unsigned char *input, 272 unsigned int inputLen); 273 void (*p_SHA384_End)(SHA384Context *cx, unsigned char *digest, 274 unsigned int *digestLen, unsigned int maxDigestLen); 275 SECStatus (*p_SHA384_HashBuf)(unsigned char *dest, const unsigned char *src, 276 PRUint32 src_length); 277 SECStatus (*p_SHA384_Hash)(unsigned char *dest, const char *src); 278 void (*p_SHA384_TraceState)(SHA384Context *cx); 279 unsigned int (*p_SHA384_FlattenSize)(SHA384Context *cx); 280 SECStatus (*p_SHA384_Flatten)(SHA384Context *cx, unsigned char *space); 281 SHA384Context *(*p_SHA384_Resurrect)(unsigned char *space, void *arg); 282 283 /* Version 3.003 came to here */ 284 285 AESKeyWrapContext *(*p_AESKeyWrap_CreateContext)(const unsigned char *key, 286 const unsigned char *iv, int encrypt, unsigned int keylen); 287 288 void (*p_AESKeyWrap_DestroyContext)(AESKeyWrapContext *cx, PRBool freeit); 289 290 SECStatus (*p_AESKeyWrap_Encrypt)(AESKeyWrapContext *cx, 291 unsigned char *output, 292 unsigned int *outputLen, unsigned int maxOutputLen, 293 const unsigned char *input, unsigned int inputLen); 294 295 SECStatus (*p_AESKeyWrap_Decrypt)(AESKeyWrapContext *cx, 296 unsigned char *output, 297 unsigned int *outputLen, unsigned int maxOutputLen, 298 const unsigned char *input, unsigned int inputLen); 299 300 /* Version 3.004 came to here */ 301 302 PRBool (*p_BLAPI_SHVerify)(const char *name, PRFuncPtr addr); 303 PRBool (*p_BLAPI_VerifySelf)(const char *name); 304 305 /* Version 3.005 came to here */ 306 307 SECStatus (*p_EC_NewKey)(ECParams *params, 308 ECPrivateKey **privKey); 309 310 SECStatus (*p_EC_NewKeyFromSeed)(ECParams *params, 311 ECPrivateKey **privKey, 312 const unsigned char *seed, 313 int seedlen); 314 315 SECStatus (*p_EC_ValidatePublicKey)(ECParams *params, 316 SECItem *publicValue); 317 318 SECStatus (*p_ECDH_Derive)(SECItem *publicValue, 319 ECParams *params, 320 SECItem *privateValue, 321 PRBool withCofactor, 322 SECItem *derivedSecret); 323 324 SECStatus (*p_ECDSA_SignDigest)(ECPrivateKey *key, 325 SECItem *signature, 326 const SECItem *digest); 327 328 SECStatus (*p_ECDSA_VerifyDigest)(ECPublicKey *key, 329 const SECItem *signature, 330 const SECItem *digest); 331 332 SECStatus (*p_ECDSA_SignDigestWithSeed)(ECPrivateKey *key, 333 SECItem *signature, 334 const SECItem *digest, 335 const unsigned char *seed, 336 const int seedlen); 337 338 /* Version 3.006 came to here */ 339 340 /* no modification to FREEBLVectorStr itself 341 * but ECParamStr was modified 342 */ 343 344 /* Version 3.007 came to here */ 345 346 SECStatus (*p_AES_InitContext)(AESContext *cx, 347 const unsigned char *key, 348 unsigned int keylen, 349 const unsigned char *iv, 350 int mode, 351 unsigned int encrypt, 352 unsigned int blocklen); 353 SECStatus (*p_AESKeyWrap_InitContext)(AESKeyWrapContext *cx, 354 const unsigned char *key, 355 unsigned int keylen, 356 const unsigned char *iv, 357 int mode, 358 unsigned int encrypt, 359 unsigned int blocklen); 360 SECStatus (*p_DES_InitContext)(DESContext *cx, 361 const unsigned char *key, 362 unsigned int keylen, 363 const unsigned char *iv, 364 int mode, 365 unsigned int encrypt, 366 unsigned int); 367 SECStatus (*p_RC2_InitContext)(RC2Context *cx, 368 const unsigned char *key, 369 unsigned int keylen, 370 const unsigned char *iv, 371 int mode, 372 unsigned int effectiveKeyLen, 373 unsigned int); 374 SECStatus (*p_RC4_InitContext)(RC4Context *cx, 375 const unsigned char *key, 376 unsigned int keylen, 377 const unsigned char *, 378 int, 379 unsigned int, 380 unsigned int); 381 382 AESContext *(*p_AES_AllocateContext)(void); 383 AESKeyWrapContext *(*p_AESKeyWrap_AllocateContext)(void); 384 DESContext *(*p_DES_AllocateContext)(void); 385 RC2Context *(*p_RC2_AllocateContext)(void); 386 RC4Context *(*p_RC4_AllocateContext)(void); 387 388 void (*p_MD2_Clone)(MD2Context *dest, MD2Context *src); 389 void (*p_MD5_Clone)(MD5Context *dest, MD5Context *src); 390 void (*p_SHA1_Clone)(SHA1Context *dest, SHA1Context *src); 391 void (*p_SHA256_Clone)(SHA256Context *dest, SHA256Context *src); 392 void (*p_SHA384_Clone)(SHA384Context *dest, SHA384Context *src); 393 void (*p_SHA512_Clone)(SHA512Context *dest, SHA512Context *src); 394 395 SECStatus (*p_TLS_PRF)(const SECItem *secret, const char *label, 396 SECItem *seed, SECItem *result, PRBool isFIPS); 397 398 const SECHashObject *(*p_HASH_GetRawHashObject)(HASH_HashType hashType); 399 400 HMACContext *(*p_HMAC_Create)(const SECHashObject *hashObj, 401 const unsigned char *secret, 402 unsigned int secret_len, PRBool isFIPS); 403 SECStatus (*p_HMAC_Init)(HMACContext *cx, const SECHashObject *hash_obj, 404 const unsigned char *secret, 405 unsigned int secret_len, PRBool isFIPS); 406 void (*p_HMAC_Begin)(HMACContext *cx); 407 void (*p_HMAC_Update)(HMACContext *cx, const unsigned char *data, 408 unsigned int data_len); 409 HMACContext *(*p_HMAC_Clone)(HMACContext *cx); 410 SECStatus (*p_HMAC_Finish)(HMACContext *cx, unsigned char *result, 411 unsigned int *result_len, 412 unsigned int max_result_len); 413 void (*p_HMAC_Destroy)(HMACContext *cx, PRBool freeit); 414 415 void (*p_RNG_SystemInfoForRNG)(void); 416 417 /* Version 3.008 came to here */ 418 419 SECStatus (*p_FIPS186Change_GenerateX)(unsigned char *XKEY, 420 const unsigned char *XSEEDj, 421 unsigned char *x_j); 422 SECStatus (*p_FIPS186Change_ReduceModQForDSA)(const unsigned char *w, 423 const unsigned char *q, 424 unsigned char *xj); 425 426 /* Version 3.009 came to here */ 427 428 SECStatus (*p_Camellia_InitContext)(CamelliaContext *cx, 429 const unsigned char *key, 430 unsigned int keylen, 431 const unsigned char *iv, 432 int mode, 433 unsigned int encrypt, 434 unsigned int unused); 435 436 CamelliaContext *(*p_Camellia_AllocateContext)(void); 437 CamelliaContext *(*p_Camellia_CreateContext)(const unsigned char *key, 438 const unsigned char *iv, 439 int mode, int encrypt, 440 unsigned int keylen); 441 void (*p_Camellia_DestroyContext)(CamelliaContext *cx, PRBool freeit); 442 443 SECStatus (*p_Camellia_Encrypt)(CamelliaContext *cx, unsigned char *output, 444 unsigned int *outputLen, 445 unsigned int maxOutputLen, 446 const unsigned char *input, 447 unsigned int inputLen); 448 449 SECStatus (*p_Camellia_Decrypt)(CamelliaContext *cx, unsigned char *output, 450 unsigned int *outputLen, 451 unsigned int maxOutputLen, 452 const unsigned char *input, 453 unsigned int inputLen); 454 455 void (*p_PQG_DestroyParams)(PQGParams *params); 456 457 void (*p_PQG_DestroyVerify)(PQGVerify *vfy); 458 459 /* Version 3.010 came to here */ 460 461 SECStatus (*p_SEED_InitContext)(SEEDContext *cx, 462 const unsigned char *key, 463 unsigned int keylen, 464 const unsigned char *iv, 465 int mode, 466 unsigned int encrypt, 467 unsigned int); 468 469 SEEDContext *(*p_SEED_AllocateContext)(void); 470 471 SEEDContext *(*p_SEED_CreateContext)(const unsigned char *key, 472 const unsigned char *iv, 473 int mode, PRBool encrypt); 474 475 void (*p_SEED_DestroyContext)(SEEDContext *cx, PRBool freeit); 476 477 SECStatus (*p_SEED_Encrypt)(SEEDContext *cx, unsigned char *output, 478 unsigned int *outputLen, unsigned int maxOutputLen, 479 const unsigned char *input, unsigned int inputLen); 480 481 SECStatus (*p_SEED_Decrypt)(SEEDContext *cx, unsigned char *output, 482 unsigned int *outputLen, unsigned int maxOutputLen, 483 const unsigned char *input, unsigned int inputLen); 484 485 SECStatus (*p_BL_Init)(void); 486 void (*p_BL_SetForkState)(PRBool); 487 488 SECStatus (*p_PRNGTEST_Instantiate)(const PRUint8 *entropy, 489 unsigned int entropy_len, 490 const PRUint8 *nonce, 491 unsigned int nonce_len, 492 const PRUint8 *personal_string, 493 unsigned int ps_len); 494 495 SECStatus (*p_PRNGTEST_Reseed)(const PRUint8 *entropy, 496 unsigned int entropy_len, 497 const PRUint8 *additional, 498 unsigned int additional_len); 499 500 SECStatus (*p_PRNGTEST_Generate)(PRUint8 *bytes, 501 unsigned int bytes_len, 502 const PRUint8 *additional, 503 unsigned int additional_len); 504 505 SECStatus (*p_PRNGTEST_Uninstantiate)(void); 506 /* Version 3.011 came to here */ 507 508 SECStatus (*p_RSA_PopulatePrivateKey)(RSAPrivateKey *key); 509 510 SECStatus (*p_DSA_NewRandom)(PLArenaPool *arena, const SECItem *q, 511 SECItem *seed); 512 513 SECStatus (*p_JPAKE_Sign)(PLArenaPool *arena, const PQGParams *pqg, 514 HASH_HashType hashType, const SECItem *signerID, 515 const SECItem *x, const SECItem *testRandom, 516 const SECItem *gxIn, SECItem *gxOut, 517 SECItem *gv, SECItem *r); 518 519 SECStatus (*p_JPAKE_Verify)(PLArenaPool *arena, const PQGParams *pqg, 520 HASH_HashType hashType, const SECItem *signerID, 521 const SECItem *peerID, const SECItem *gx, 522 const SECItem *gv, const SECItem *r); 523 524 SECStatus (*p_JPAKE_Round2)(PLArenaPool *arena, const SECItem *p, 525 const SECItem *q, const SECItem *gx1, 526 const SECItem *gx3, const SECItem *gx4, 527 SECItem *base, const SECItem *x2, 528 const SECItem *s, SECItem *x2s); 529 530 SECStatus (*p_JPAKE_Final)(PLArenaPool *arena, const SECItem *p, 531 const SECItem *q, const SECItem *x2, 532 const SECItem *gx4, const SECItem *x2s, 533 const SECItem *B, SECItem *K); 534 535 /* Version 3.012 came to here */ 536 537 SECStatus (*p_TLS_P_hash)(HASH_HashType hashAlg, 538 const SECItem *secret, 539 const char *label, 540 SECItem *seed, 541 SECItem *result, 542 PRBool isFIPS); 543 544 SHA224Context *(*p_SHA224_NewContext)(void); 545 void (*p_SHA224_DestroyContext)(SHA224Context *cx, PRBool freeit); 546 void (*p_SHA224_Begin)(SHA224Context *cx); 547 void (*p_SHA224_Update)(SHA224Context *cx, const unsigned char *input, 548 unsigned int inputLen); 549 void (*p_SHA224_End)(SHA224Context *cx, unsigned char *digest, 550 unsigned int *digestLen, unsigned int maxDigestLen); 551 SECStatus (*p_SHA224_HashBuf)(unsigned char *dest, const unsigned char *src, 552 PRUint32 src_length); 553 SECStatus (*p_SHA224_Hash)(unsigned char *dest, const char *src); 554 void (*p_SHA224_TraceState)(SHA224Context *cx); 555 unsigned int (*p_SHA224_FlattenSize)(SHA224Context *cx); 556 SECStatus (*p_SHA224_Flatten)(SHA224Context *cx, unsigned char *space); 557 SHA224Context *(*p_SHA224_Resurrect)(unsigned char *space, void *arg); 558 void (*p_SHA224_Clone)(SHA224Context *dest, SHA224Context *src); 559 PRBool (*p_BLAPI_SHVerifyFile)(const char *name); 560 561 /* Version 3.013 came to here */ 562 563 SECStatus (*p_PQG_ParamGenV2)(unsigned int L, unsigned int N, 564 unsigned int seedBytes, 565 PQGParams **pParams, PQGVerify **pVfy); 566 SECStatus (*p_PRNGTEST_RunHealthTests)(void); 567 568 /* Version 3.014 came to here */ 569 570 SECStatus (*p_HMAC_ConstantTime)( 571 unsigned char *result, 572 unsigned int *resultLen, 573 unsigned int maxResultLen, 574 const SECHashObject *hashObj, 575 const unsigned char *secret, 576 unsigned int secretLen, 577 const unsigned char *header, 578 unsigned int headerLen, 579 const unsigned char *body, 580 unsigned int bodyLen, 581 unsigned int bodyTotalLen); 582 583 SECStatus (*p_SSLv3_MAC_ConstantTime)( 584 unsigned char *result, 585 unsigned int *resultLen, 586 unsigned int maxResultLen, 587 const SECHashObject *hashObj, 588 const unsigned char *secret, 589 unsigned int secretLen, 590 const unsigned char *header, 591 unsigned int headerLen, 592 const unsigned char *body, 593 unsigned int bodyLen, 594 unsigned int bodyTotalLen); 595 596 /* Version 3.015 came to here */ 597 598 SECStatus (*p_RSA_SignRaw)(RSAPrivateKey *key, 599 unsigned char *output, 600 unsigned int *outputLen, 601 unsigned int maxOutputLen, 602 const unsigned char *input, 603 unsigned int inputLen); 604 SECStatus (*p_RSA_CheckSignRaw)(RSAPublicKey *key, 605 const unsigned char *sig, 606 unsigned int sigLen, 607 const unsigned char *hash, 608 unsigned int hashLen); 609 SECStatus (*p_RSA_CheckSignRecoverRaw)(RSAPublicKey *key, 610 unsigned char *data, 611 unsigned int *dataLen, 612 unsigned int maxDataLen, 613 const unsigned char *sig, 614 unsigned int sigLen); 615 SECStatus (*p_RSA_EncryptRaw)(RSAPublicKey *key, 616 unsigned char *output, 617 unsigned int *outputLen, 618 unsigned int maxOutputLen, 619 const unsigned char *input, 620 unsigned int inputLen); 621 SECStatus (*p_RSA_DecryptRaw)(RSAPrivateKey *key, 622 unsigned char *output, 623 unsigned int *outputLen, 624 unsigned int maxOutputLen, 625 const unsigned char *input, 626 unsigned int inputLen); 627 SECStatus (*p_RSA_EncryptOAEP)(RSAPublicKey *key, 628 HASH_HashType hashAlg, 629 HASH_HashType maskHashAlg, 630 const unsigned char *label, 631 unsigned int labelLen, 632 const unsigned char *seed, 633 unsigned int seedLen, 634 unsigned char *output, 635 unsigned int *outputLen, 636 unsigned int maxOutputLen, 637 const unsigned char *input, 638 unsigned int inputLen); 639 SECStatus (*p_RSA_DecryptOAEP)(RSAPrivateKey *key, 640 HASH_HashType hashAlg, 641 HASH_HashType maskHashAlg, 642 const unsigned char *label, 643 unsigned int labelLen, 644 unsigned char *output, 645 unsigned int *outputLen, 646 unsigned int maxOutputLen, 647 const unsigned char *input, 648 unsigned int inputLen); 649 SECStatus (*p_RSA_EncryptBlock)(RSAPublicKey *key, 650 unsigned char *output, 651 unsigned int *outputLen, 652 unsigned int maxOutputLen, 653 const unsigned char *input, 654 unsigned int inputLen); 655 SECStatus (*p_RSA_DecryptBlock)(RSAPrivateKey *key, 656 unsigned char *output, 657 unsigned int *outputLen, 658 unsigned int maxOutputLen, 659 const unsigned char *input, 660 unsigned int inputLen); 661 SECStatus (*p_RSA_SignPSS)(RSAPrivateKey *key, 662 HASH_HashType hashAlg, 663 HASH_HashType maskHashAlg, 664 const unsigned char *salt, 665 unsigned int saltLen, 666 unsigned char *output, 667 unsigned int *outputLen, 668 unsigned int maxOutputLen, 669 const unsigned char *input, 670 unsigned int inputLen); 671 SECStatus (*p_RSA_CheckSignPSS)(RSAPublicKey *key, 672 HASH_HashType hashAlg, 673 HASH_HashType maskHashAlg, 674 unsigned int saltLen, 675 const unsigned char *sig, 676 unsigned int sigLen, 677 const unsigned char *hash, 678 unsigned int hashLen); 679 SECStatus (*p_RSA_Sign)(RSAPrivateKey *key, 680 unsigned char *output, 681 unsigned int *outputLen, 682 unsigned int maxOutputLen, 683 const unsigned char *input, 684 unsigned int inputLen); 685 SECStatus (*p_RSA_CheckSign)(RSAPublicKey *key, 686 const unsigned char *sig, 687 unsigned int sigLen, 688 const unsigned char *data, 689 unsigned int dataLen); 690 SECStatus (*p_RSA_CheckSignRecover)(RSAPublicKey *key, 691 unsigned char *output, 692 unsigned int *outputLen, 693 unsigned int maxOutputLen, 694 const unsigned char *sig, 695 unsigned int sigLen); 696 697 /* Version 3.016 came to here */ 698 699 SECStatus (*p_EC_FillParams)(PLArenaPool *arena, 700 const SECItem *encodedParams, ECParams *params); 701 SECStatus (*p_EC_DecodeParams)(const SECItem *encodedParams, 702 ECParams **ecparams); 703 SECStatus (*p_EC_CopyParams)(PLArenaPool *arena, ECParams *dstParams, 704 const ECParams *srcParams); 705 706 /* Version 3.017 came to here */ 707 708 SECStatus (*p_ChaCha20Poly1305_InitContext)(ChaCha20Poly1305Context *ctx, 709 const unsigned char *key, 710 unsigned int keyLen, 711 unsigned int tagLen); 712 713 ChaCha20Poly1305Context *(*p_ChaCha20Poly1305_CreateContext)( 714 const unsigned char *key, unsigned int keyLen, unsigned int tagLen); 715 716 void (*p_ChaCha20Poly1305_DestroyContext)(ChaCha20Poly1305Context *ctx, 717 PRBool freeit); 718 719 SECStatus (*p_ChaCha20Poly1305_Seal)( 720 const ChaCha20Poly1305Context *ctx, unsigned char *output, 721 unsigned int *outputLen, unsigned int maxOutputLen, 722 const unsigned char *input, unsigned int inputLen, 723 const unsigned char *nonce, unsigned int nonceLen, 724 const unsigned char *ad, unsigned int adLen); 725 726 SECStatus (*p_ChaCha20Poly1305_Open)( 727 const ChaCha20Poly1305Context *ctx, unsigned char *output, 728 unsigned int *outputLen, unsigned int maxOutputLen, 729 const unsigned char *input, unsigned int inputLen, 730 const unsigned char *nonce, unsigned int nonceLen, 731 const unsigned char *ad, unsigned int adLen); 732 733 /* Version 3.018 came to here */ 734 735 int (*p_EC_GetPointSize)(const ECParams *); 736 737 /* Version 3.019 came to here */ 738 739 SECStatus (*p_BLAKE2B_Hash)(unsigned char *dest, const char *src); 740 SECStatus (*p_BLAKE2B_HashBuf)(unsigned char *output, 741 const unsigned char *input, PRUint32 inlen); 742 SECStatus (*p_BLAKE2B_MAC_HashBuf)(unsigned char *output, 743 const unsigned char *input, 744 unsigned int inlen, 745 const unsigned char *key, 746 unsigned int keylen); 747 BLAKE2BContext *(*p_BLAKE2B_NewContext)(); 748 void (*p_BLAKE2B_DestroyContext)(BLAKE2BContext *ctx, PRBool freeit); 749 SECStatus (*p_BLAKE2B_Begin)(BLAKE2BContext *ctx); 750 SECStatus (*p_BLAKE2B_MAC_Begin)(BLAKE2BContext *ctx, const PRUint8 *key, 751 const size_t keylen); 752 SECStatus (*p_BLAKE2B_Update)(BLAKE2BContext *ctx, const unsigned char *in, 753 unsigned int inlen); 754 SECStatus (*p_BLAKE2B_End)(BLAKE2BContext *ctx, unsigned char *out, 755 unsigned int *digestLen, size_t maxDigestLen); 756 unsigned int (*p_BLAKE2B_FlattenSize)(BLAKE2BContext *ctx); 757 SECStatus (*p_BLAKE2B_Flatten)(BLAKE2BContext *ctx, unsigned char *space); 758 BLAKE2BContext *(*p_BLAKE2B_Resurrect)(unsigned char *space, void *arg); 759 760 /* Version 3.020 came to here */ 761 762 SECStatus (*p_ChaCha20_Xor)(unsigned char *output, const unsigned char *block, 763 unsigned int len, const unsigned char *k, 764 const unsigned char *nonce, PRUint32 ctr); 765 766 /* Version 3.021 came to here */ 767 768 SECStatus (*p_CMAC_Init)(CMACContext *ctx, CMACCipher type, 769 const unsigned char *key, unsigned int key_len); 770 CMACContext *(*p_CMAC_Create)(CMACCipher type, const unsigned char *key, 771 unsigned int key_len); 772 SECStatus (*p_CMAC_Begin)(CMACContext *ctx); 773 SECStatus (*p_CMAC_Update)(CMACContext *ctx, const unsigned char *data, 774 unsigned int data_len); 775 SECStatus (*p_CMAC_Finish)(CMACContext *ctx, unsigned char *result, 776 unsigned int *result_len, 777 unsigned int max_result_len); 778 void (*p_CMAC_Destroy)(CMACContext *ctx, PRBool free_it); 779 780 /* Version 3.022 came to here */ 781 SECStatus (*p_ChaCha20Poly1305_Encrypt)( 782 const ChaCha20Poly1305Context *ctx, unsigned char *output, 783 unsigned int *outputLen, unsigned int maxOutputLen, 784 const unsigned char *input, unsigned int inputLen, 785 const unsigned char *nonce, unsigned int nonceLen, 786 const unsigned char *ad, unsigned int adLen, unsigned char *tagOut); 787 788 SECStatus (*p_ChaCha20Poly1305_Decrypt)( 789 const ChaCha20Poly1305Context *ctx, unsigned char *output, 790 unsigned int *outputLen, unsigned int maxOutputLen, 791 const unsigned char *input, unsigned int inputLen, 792 const unsigned char *nonce, unsigned int nonceLen, 793 const unsigned char *ad, unsigned int adLen, unsigned char *tagIn); 794 SECStatus (*p_AES_AEAD)(AESContext *cx, unsigned char *output, 795 unsigned int *outputLen, unsigned int maxOutputLen, 796 const unsigned char *input, unsigned int inputLen, 797 void *params, unsigned int paramsLen, 798 const unsigned char *aad, unsigned int aadLen); 799 SECStatus (*p_AESKeyWrap_EncryptKWP)(AESKeyWrapContext *cx, 800 unsigned char *output, 801 unsigned int *outputLen, 802 unsigned int maxOutputLen, 803 const unsigned char *input, 804 unsigned int inputLen); 805 806 SECStatus (*p_AESKeyWrap_DecryptKWP)(AESKeyWrapContext *cx, 807 unsigned char *output, 808 unsigned int *outputLen, 809 unsigned int maxOutputLen, 810 const unsigned char *input, 811 unsigned int inputLen); 812 813 /* Version 3.023 came to here */ 814 815 PRBool (*p_KEA_PrimeCheck)(SECItem *prime); 816 /* Version 3.024 came to here */ 817 818 SECStatus (*p_ChaCha20_InitContext)(ChaCha20Context *ctx, 819 const unsigned char *key, 820 unsigned int keyLen, 821 const unsigned char *nonce, 822 unsigned int nonceLen, 823 PRUint32 ctr); 824 825 ChaCha20Context *(*p_ChaCha20_CreateContext)(const unsigned char *key, 826 unsigned int keyLen, 827 const unsigned char *nonce, 828 unsigned int nonceLen, 829 PRUint32 ctr); 830 831 void (*p_ChaCha20_DestroyContext)(ChaCha20Context *ctx, PRBool freeit); 832 833 /* Version 3.025 came to here */ 834 835 SHA3_224Context *(*p_SHA3_224_NewContext)(void); 836 void (*p_SHA3_224_DestroyContext)(SHA3_224Context *cx, PRBool freeit); 837 unsigned int (*p_SHA3_224_FlattenSize)(SHA3_224Context *cx); 838 void (*p_SHA3_224_Begin)(SHA3_224Context *cx); 839 void (*p_SHA3_224_Update)(SHA3_224Context *cx, const unsigned char *input, 840 unsigned int inputLen); 841 void (*p_SHA3_224_End)(SHA3_224Context *cx, unsigned char *digest, 842 unsigned int *digestLen, unsigned int maxDigestLen); 843 844 SECStatus (*p_SHA3_224_HashBuf)(unsigned char *dest, const unsigned char *src, 845 PRUint32 src_length); 846 SECStatus (*p_SHA3_224_Hash)(unsigned char *dest, const char *src); 847 848 SHA3_256Context *(*p_SHA3_256_NewContext)(void); 849 void (*p_SHA3_256_DestroyContext)(SHA3_256Context *cx, PRBool freeit); 850 unsigned int (*p_SHA3_256_FlattenSize)(SHA3_256Context *cx); 851 void (*p_SHA3_256_Begin)(SHA3_256Context *cx); 852 void (*p_SHA3_256_Update)(SHA3_256Context *cx, const unsigned char *input, 853 unsigned int inputLen); 854 void (*p_SHA3_256_End)(SHA3_256Context *cx, unsigned char *digest, 855 unsigned int *digestLen, unsigned int maxDigestLen); 856 857 SECStatus (*p_SHA3_256_HashBuf)(unsigned char *dest, const unsigned char *src, 858 PRUint32 src_length); 859 SECStatus (*p_SHA3_256_Hash)(unsigned char *dest, const char *src); 860 861 SHA3_384Context *(*p_SHA3_384_NewContext)(void); 862 void (*p_SHA3_384_DestroyContext)(SHA3_384Context *cx, PRBool freeit); 863 unsigned int (*p_SHA3_384_FlattenSize)(SHA3_384Context *cx); 864 void (*p_SHA3_384_Begin)(SHA3_384Context *cx); 865 void (*p_SHA3_384_Update)(SHA3_384Context *cx, const unsigned char *input, 866 unsigned int inputLen); 867 void (*p_SHA3_384_End)(SHA3_384Context *cx, unsigned char *digest, 868 unsigned int *digestLen, unsigned int maxDigestLen); 869 870 SECStatus (*p_SHA3_384_HashBuf)(unsigned char *dest, const unsigned char *src, 871 PRUint32 src_length); 872 SECStatus (*p_SHA3_384_Hash)(unsigned char *dest, const char *src); 873 874 SHA3_512Context *(*p_SHA3_512_NewContext)(void); 875 void (*p_SHA3_512_DestroyContext)(SHA3_512Context *cx, PRBool freeit); 876 unsigned int (*p_SHA3_512_FlattenSize)(SHA3_512Context *cx); 877 void (*p_SHA3_512_Begin)(SHA3_512Context *cx); 878 void (*p_SHA3_512_Update)(SHA3_512Context *cx, const unsigned char *input, 879 unsigned int inputLen); 880 void (*p_SHA3_512_End)(SHA3_512Context *cx, unsigned char *digest, 881 unsigned int *digestLen, unsigned int maxDigestLen); 882 883 SECStatus (*p_SHA3_512_HashBuf)(unsigned char *dest, const unsigned char *src, 884 PRUint32 src_length); 885 SECStatus (*p_SHA3_512_Hash)(unsigned char *dest, const char *src); 886 887 SHAKE_128Context *(*p_SHAKE_128_NewContext)(void); 888 void (*p_SHAKE_128_DestroyContext)(SHAKE_128Context *cx, PRBool freeit); 889 void (*p_SHAKE_128_Begin)(SHAKE_128Context *cx); 890 void (*p_SHAKE_128_Absorb)(SHAKE_128Context *cx, const unsigned char *input, 891 unsigned int inputLen); 892 void (*p_SHAKE_128_SqueezeEnd)(SHAKE_128Context *cx, unsigned char *digest, 893 unsigned int digestLen); 894 895 SECStatus (*p_SHAKE_128_HashBuf)(unsigned char *dest, PRUint32 dest_length, 896 const unsigned char *src, PRUint32 src_length); 897 SECStatus (*p_SHAKE_128_Hash)(unsigned char *dest, PRUint32 dest_length, const char *src); 898 899 SHAKE_256Context *(*p_SHAKE_256_NewContext)(void); 900 void (*p_SHAKE_256_DestroyContext)(SHAKE_256Context *cx, PRBool freeit); 901 void (*p_SHAKE_256_Begin)(SHAKE_256Context *cx); 902 void (*p_SHAKE_256_Absorb)(SHAKE_256Context *cx, const unsigned char *input, 903 unsigned int inputLen); 904 void (*p_SHAKE_256_SqueezeEnd)(SHAKE_256Context *cx, unsigned char *digest, 905 unsigned int digestLen); 906 907 SECStatus (*p_SHAKE_256_HashBuf)(unsigned char *dest, PRUint32 dest_length, 908 const unsigned char *src, PRUint32 src_length); 909 SECStatus (*p_SHAKE_256_Hash)(unsigned char *dest, PRUint32 dest_length, const char *src); 910 911 /* Version 3.026 came to here */ 912 913 SECStatus (*p_Kyber_NewKey)(KyberParams params, const SECItem *seed, SECItem *privKey, SECItem *pubKey); 914 915 SECStatus (*p_Kyber_Encapsulate)(KyberParams params, const SECItem *seed, const SECItem *pubKey, SECItem *ciphertext, SECItem *secret); 916 917 SECStatus (*p_Kyber_Decapsulate)(KyberParams params, const SECItem *privKey, const SECItem *ciphertext, SECItem *secret); 918 919 /* Version 3.027 came to here */ 920 921 SECStatus (*p_ED_SignMessage)(ECPrivateKey *key, SECItem *signature, const SECItem *msg); 922 SECStatus (*p_ED_VerifyMessage)(ECPublicKey *key, const SECItem *signature, 923 const SECItem *msg); 924 925 SECStatus (*p_ED_DerivePublicKey)(const SECItem *privateKey, SECItem *publicKey); 926 /* Version 3.028 came to here */ 927 928 SECStatus (*p_X25519_DerivePublicKey)(const SECItem *privateKey, SECItem *publicKey); 929 /* Version 3.029 came to here */ 930 931 SECStatus (*p_EC_DerivePublicKey)(const SECItem *privateKey, const ECParams *ecParams, SECItem *publicKey); 932 /* Version 3.030 came to here */ 933 934 SECStatus (*p_MLDSA_NewKey)(CK_ML_DSA_PARAMETER_SET_TYPE paramSet, SECItem *seed, MLDSAPrivateKey *privKey, MLDSAPublicKey *pubKey); 935 SECStatus (*p_MLDSA_SignInit)(MLDSAPrivateKey *key, CK_HEDGE_TYPE hedgType, const SECItem *sgnCtx, MLDSAContext **ctx); 936 SECStatus (*p_MLDSA_SignUpdate)(MLDSAContext *ctx, const SECItem *data); 937 SECStatus (*p_MLDSA_SignFinal)(MLDSAContext *ctx, SECItem *signature); 938 SECStatus (*p_MLDSA_VerifyInit)(MLDSAPublicKey *key, const SECItem *sgnCtx, MLDSAContext **ctx); 939 SECStatus (*p_MLDSA_VerifyUpdate)(MLDSAContext *ctx, const SECItem *data); 940 SECStatus (*p_MLDSA_VerifyFinal)(MLDSAContext *ctx, const SECItem *signature); 941 /* Version 3.031 came to here */ 942 943 SECStatus (*p_EC_DecompressPublicKey)(const SECItem *publicCompressed, const ECParams *params, SECItem *publicUncompressed); 944 /* Version 3.032 came to here */ 945 946 /* Add new function pointers at the end of this struct and bump 947 * FREEBL_VERSION at the beginning of this file. */ 948 }; 949 950 typedef struct FREEBLVectorStr FREEBLVector; 951 952 #ifdef FREEBL_LOWHASH 953 #include "nsslowhash.h" 954 955 #define NSSLOW_VERSION 0x0300 956 957 struct NSSLOWVectorStr { 958 unsigned short length; /* of this struct in bytes */ 959 unsigned short version; /* of this struct. */ 960 const FREEBLVector *(*p_FREEBL_GetVector)(void); 961 NSSLOWInitContext *(*p_NSSLOW_Init)(void); 962 void (*p_NSSLOW_Shutdown)(NSSLOWInitContext *context); 963 void (*p_NSSLOW_Reset)(NSSLOWInitContext *context); 964 NSSLOWHASHContext *(*p_NSSLOWHASH_NewContext)( 965 NSSLOWInitContext *initContext, 966 HASH_HashType hashType); 967 void (*p_NSSLOWHASH_Begin)(NSSLOWHASHContext *context); 968 void (*p_NSSLOWHASH_Update)(NSSLOWHASHContext *context, 969 const unsigned char *buf, 970 unsigned int len); 971 void (*p_NSSLOWHASH_End)(NSSLOWHASHContext *context, 972 unsigned char *buf, 973 unsigned int *ret, unsigned int len); 974 void (*p_NSSLOWHASH_Destroy)(NSSLOWHASHContext *context); 975 unsigned int (*p_NSSLOWHASH_Length)(NSSLOWHASHContext *context); 976 }; 977 978 typedef struct NSSLOWVectorStr NSSLOWVector; 979 #endif 980 981 SEC_BEGIN_PROTOS 982 983 #ifdef FREEBL_LOWHASH 984 typedef const NSSLOWVector *NSSLOWGetVectorFn(void); 985 986 extern NSSLOWGetVectorFn NSSLOW_GetVector; 987 #endif 988 989 typedef const FREEBLVector *FREEBLGetVectorFn(void); 990 991 extern FREEBLGetVectorFn FREEBL_GetVector; 992 993 SEC_END_PROTOS 994 995 #endif 996 997 #ifdef NSS_DISABLE_DEPRECATED_SEED 998 typedef SECStatus (*F_SEED_InitContext)(SEEDContext *cx, 999 const unsigned char *key, 1000 unsigned int keylen, 1001 const unsigned char *iv, 1002 int mode, 1003 unsigned int encrypt, 1004 unsigned int); 1005 1006 typedef SEEDContext *(*F_SEED_AllocateContext)(void); 1007 1008 typedef SEEDContext *(*F_SEED_CreateContext)(const unsigned char *key, 1009 const unsigned char *iv, 1010 int mode, PRBool encrypt); 1011 1012 typedef void (*F_SEED_DestroyContext)(SEEDContext *cx, PRBool freeit); 1013 1014 typedef SECStatus (*F_SEED_Encrypt)(SEEDContext *cx, unsigned char *output, 1015 unsigned int *outputLen, unsigned int maxOutputLen, 1016 const unsigned char *input, unsigned int inputLen); 1017 1018 typedef SECStatus (*F_SEED_Decrypt)(SEEDContext *cx, unsigned char *output, 1019 unsigned int *outputLen, unsigned int maxOutputLen, 1020 const unsigned char *input, unsigned int inputLen); 1021 #endif 1022 1023 #ifdef NSS_DISABLE_DEPRECATED_RC2 1024 typedef RC2Context *(*F_RC2_CreateContext)(const unsigned char *key, 1025 unsigned int len, const unsigned char *iv, 1026 int mode, unsigned effectiveKeyLen); 1027 1028 typedef void (*F_RC2_DestroyContext)(RC2Context *cx, PRBool freeit); 1029 1030 typedef SECStatus (*F_RC2_Encrypt)(RC2Context *cx, unsigned char *output, 1031 unsigned int *outputLen, unsigned int maxOutputLen, 1032 const unsigned char *input, unsigned int inputLen); 1033 1034 typedef SECStatus (*F_RC2_Decrypt)(RC2Context *cx, unsigned char *output, 1035 unsigned int *outputLen, unsigned int maxOutputLen, 1036 const unsigned char *input, unsigned int inputLen); 1037 1038 typedef SECStatus (*F_RC2_InitContext)(RC2Context *cx, 1039 const unsigned char *key, 1040 unsigned int keylen, 1041 const unsigned char *iv, 1042 int mode, 1043 unsigned int effectiveKeyLen, 1044 unsigned int); 1045 1046 typedef RC2Context *(*F_RC2_AllocateContext)(void); 1047 #endif 1048 1049 typedef SECStatus (*F_Kyber_NewKey)(KyberParams params, const SECItem *seed, SECItem *privKey, SECItem *pubKey); 1050 1051 typedef SECStatus (*F_Kyber_Encapsulate)(KyberParams params, const SECItem *seed, const SECItem *pubKey, SECItem *ciphertext, SECItem *secret); 1052 1053 typedef SECStatus (*F_Kyber_Decapsulate)(KyberParams params, const SECItem *privKey, const SECItem *ciphertext, SECItem *secret);