cipher_aes_gcm_hw_rv64i.inc 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. /*
  2. * Copyright 2022 The OpenSSL Project Authors. All Rights Reserved.
  3. *
  4. * Licensed under the Apache License 2.0 (the "License"). You may not use
  5. * this file except in compliance with the License. You can obtain a copy
  6. * in the file LICENSE in the source distribution or at
  7. * https://www.openssl.org/source/license.html
  8. */
  9. /*-
  10. * RISC-V 64 ZKND ZKNE support for AES GCM.
  11. * This file is included by cipher_aes_gcm_hw.c
  12. */
  13. static int rv64i_zknd_zkne_gcm_initkey(PROV_GCM_CTX *ctx, const unsigned char *key,
  14. size_t keylen)
  15. {
  16. PROV_AES_GCM_CTX *actx = (PROV_AES_GCM_CTX *)ctx;
  17. AES_KEY *ks = &actx->ks.ks;
  18. GCM_HW_SET_KEY_CTR_FN(ks, rv64i_zkne_set_encrypt_key, rv64i_zkne_encrypt,
  19. NULL);
  20. return 1;
  21. }
  22. static const PROV_GCM_HW rv64i_zknd_zkne_gcm = {
  23. rv64i_zknd_zkne_gcm_initkey,
  24. ossl_gcm_setiv,
  25. ossl_gcm_aad_update,
  26. generic_aes_gcm_cipher_update,
  27. ossl_gcm_cipher_final,
  28. ossl_gcm_one_shot
  29. };
  30. const PROV_GCM_HW *ossl_prov_aes_hw_gcm(size_t keybits)
  31. {
  32. if (RISCV_HAS_ZKND_AND_ZKNE())
  33. return &rv64i_zknd_zkne_gcm;
  34. else
  35. return &aes_gcm;
  36. }