Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. /******************************************************************************
  2. * Copyright(c) 2012, Intel Corp.
  3. * Developers and authors:
  4. * Shay Gueron (1, 2), and Vlad Krasnov (1)
  5. * (1) Intel Corporation, Israel Development Center, Haifa, Israel
  6. * (2) University of Haifa, Israel
  7. ******************************************************************************
  8. * LICENSE:
  9. * This submission to OpenSSL is to be made available under the OpenSSL
  10. * license, and only to the OpenSSL project, in order to allow integration
  11. * into the publicly distributed code.
  12. * The use of this code, or portions of this code, or concepts embedded in
  13. * this code, or modification of this code and/or algorithm(s) in it, or the
  14. * use of this code for any other purpose than stated above, requires special
  15. * licensing.
  16. ******************************************************************************
  17. * DISCLAIMER:
  18. * THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS AND THE COPYRIGHT OWNERS
  19. * ``AS IS''. ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
  20. * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  21. * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS OR THE COPYRIGHT
  22. * OWNERS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
  23. * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  24. * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  25. * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  26. * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  27. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  28. * POSSIBILITY OF SUCH DAMAGE.
  29. ******************************************************************************/
  30. #ifndef RSAZ_EXP_H
  31. #define RSAZ_EXP_H
  32. #include <openssl/bn.h>
  33. void RSAZ_1024_mod_exp_avx2(BN_ULONG result[16],
  34. const BN_ULONG base_norm[16], const BN_ULONG exponent[16],
  35. const BN_ULONG m_norm[16], const BN_ULONG RR[16], BN_ULONG k0);
  36. int rsaz_avx2_eligible(void);
  37. void RSAZ_512_mod_exp(BN_ULONG result[8],
  38. const BN_ULONG base_norm[8], const BN_ULONG exponent[8],
  39. const BN_ULONG m_norm[8], BN_ULONG k0, const BN_ULONG RR[8]);
  40. #endif