sm3-neon-glue.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. // SPDX-License-Identifier: GPL-2.0-or-later
  2. /*
  3. * sm3-neon-glue.c - SM3 secure hash using NEON instructions
  4. *
  5. * Copyright (C) 2022 Tianjia Zhang <[email protected]>
  6. */
  7. #include <asm/neon.h>
  8. #include <asm/simd.h>
  9. #include <asm/unaligned.h>
  10. #include <crypto/internal/hash.h>
  11. #include <crypto/internal/simd.h>
  12. #include <crypto/sm3.h>
  13. #include <crypto/sm3_base.h>
  14. #include <linux/cpufeature.h>
  15. #include <linux/crypto.h>
  16. #include <linux/module.h>
  17. asmlinkage void sm3_neon_transform(struct sm3_state *sst, u8 const *src,
  18. int blocks);
  19. static int sm3_neon_update(struct shash_desc *desc, const u8 *data,
  20. unsigned int len)
  21. {
  22. if (!crypto_simd_usable()) {
  23. sm3_update(shash_desc_ctx(desc), data, len);
  24. return 0;
  25. }
  26. kernel_neon_begin();
  27. sm3_base_do_update(desc, data, len, sm3_neon_transform);
  28. kernel_neon_end();
  29. return 0;
  30. }
  31. static int sm3_neon_final(struct shash_desc *desc, u8 *out)
  32. {
  33. if (!crypto_simd_usable()) {
  34. sm3_final(shash_desc_ctx(desc), out);
  35. return 0;
  36. }
  37. kernel_neon_begin();
  38. sm3_base_do_finalize(desc, sm3_neon_transform);
  39. kernel_neon_end();
  40. return sm3_base_finish(desc, out);
  41. }
  42. static int sm3_neon_finup(struct shash_desc *desc, const u8 *data,
  43. unsigned int len, u8 *out)
  44. {
  45. if (!crypto_simd_usable()) {
  46. struct sm3_state *sctx = shash_desc_ctx(desc);
  47. if (len)
  48. sm3_update(sctx, data, len);
  49. sm3_final(sctx, out);
  50. return 0;
  51. }
  52. kernel_neon_begin();
  53. if (len)
  54. sm3_base_do_update(desc, data, len, sm3_neon_transform);
  55. sm3_base_do_finalize(desc, sm3_neon_transform);
  56. kernel_neon_end();
  57. return sm3_base_finish(desc, out);
  58. }
  59. static struct shash_alg sm3_alg = {
  60. .digestsize = SM3_DIGEST_SIZE,
  61. .init = sm3_base_init,
  62. .update = sm3_neon_update,
  63. .final = sm3_neon_final,
  64. .finup = sm3_neon_finup,
  65. .descsize = sizeof(struct sm3_state),
  66. .base.cra_name = "sm3",
  67. .base.cra_driver_name = "sm3-neon",
  68. .base.cra_blocksize = SM3_BLOCK_SIZE,
  69. .base.cra_module = THIS_MODULE,
  70. .base.cra_priority = 200,
  71. };
  72. static int __init sm3_neon_init(void)
  73. {
  74. return crypto_register_shash(&sm3_alg);
  75. }
  76. static void __exit sm3_neon_fini(void)
  77. {
  78. crypto_unregister_shash(&sm3_alg);
  79. }
  80. module_init(sm3_neon_init);
  81. module_exit(sm3_neon_fini);
  82. MODULE_DESCRIPTION("SM3 secure hash using NEON instructions");
  83. MODULE_AUTHOR("Jussi Kivilinna <[email protected]>");
  84. MODULE_AUTHOR("Tianjia Zhang <[email protected]>");
  85. MODULE_LICENSE("GPL v2");