mod_exp_sw.c 790 B

123456789101112131415161718192021222324252627282930313233343536373839
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * (C) Copyright 2014 Freescale Semiconductor, Inc.
  4. * Author: Ruchika Gupta <ruchika.gupta@freescale.com>
  5. */
  6. #include <config.h>
  7. #include <common.h>
  8. #include <dm.h>
  9. #include <u-boot/rsa-mod-exp.h>
  10. int mod_exp_sw(struct udevice *dev, const uint8_t *sig, uint32_t sig_len,
  11. struct key_prop *prop, uint8_t *out)
  12. {
  13. int ret = 0;
  14. ret = rsa_mod_exp_sw(sig, sig_len, prop, out);
  15. if (ret) {
  16. debug("%s: RSA failed to verify: %d\n", __func__, ret);
  17. return ret;
  18. }
  19. return 0;
  20. }
  21. static const struct mod_exp_ops mod_exp_ops_sw = {
  22. .mod_exp = mod_exp_sw,
  23. };
  24. U_BOOT_DRIVER(mod_exp_sw) = {
  25. .name = "mod_exp_sw",
  26. .id = UCLASS_MOD_EXP,
  27. .ops = &mod_exp_ops_sw,
  28. .flags = DM_FLAG_PRE_RELOC,
  29. };
  30. U_BOOT_DEVICE(mod_exp_sw) = {
  31. .name = "mod_exp_sw",
  32. };