cipher_aes_xts.h 1023 B

1234567891011121314151617181920212223242526272829
  1. /*
  2. * Copyright 2019 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. #include <openssl/aes.h>
  10. #include "internal/ciphers/ciphercommon.h"
  11. PROV_CIPHER_FUNC(void, xts_stream,
  12. (const unsigned char *in, unsigned char *out, size_t len,
  13. const AES_KEY *key1, const AES_KEY *key2,
  14. const unsigned char iv[16]));
  15. typedef struct prov_aes_xts_ctx_st {
  16. PROV_CIPHER_CTX base; /* Must be first */
  17. union {
  18. OSSL_UNION_ALIGN;
  19. AES_KEY ks;
  20. } ks1, ks2; /* AES key schedules to use */
  21. XTS128_CONTEXT xts;
  22. OSSL_xts_stream_fn stream;
  23. unsigned int iv_set : 1; /* Set if an iv is set */
  24. } PROV_AES_XTS_CTX;
  25. const PROV_CIPHER_HW *PROV_CIPHER_HW_aes_xts(size_t keybits);