cmds.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /*
  2. * (C) Copyright 2018 Xilinx, Inc.
  3. * Siva Durga Prasad Paladugu <siva.durga.paladugu@xilinx.com>
  4. *
  5. * SPDX-License-Identifier: GPL-2.0
  6. */
  7. #include <common.h>
  8. #include <malloc.h>
  9. #include <asm/arch/sys_proto.h>
  10. #include <asm/io.h>
  11. static int zynqmp_verify_secure(u8 *key_ptr, u8 *src_ptr, u32 len)
  12. {
  13. int ret;
  14. u32 src_lo, src_hi;
  15. u32 key_lo = 0;
  16. u32 key_hi = 0;
  17. u32 ret_payload[PAYLOAD_ARG_CNT];
  18. u64 addr;
  19. if ((ulong)src_ptr != ALIGN((ulong)src_ptr,
  20. CONFIG_SYS_CACHELINE_SIZE)) {
  21. printf("Failed: source address not aligned:%p\n", src_ptr);
  22. return -EINVAL;
  23. }
  24. src_lo = lower_32_bits((ulong)src_ptr);
  25. src_hi = upper_32_bits((ulong)src_ptr);
  26. flush_dcache_range((ulong)src_ptr, (ulong)(src_ptr + len));
  27. if (key_ptr) {
  28. key_lo = lower_32_bits((ulong)key_ptr);
  29. key_hi = upper_32_bits((ulong)key_ptr);
  30. flush_dcache_range((ulong)key_ptr,
  31. (ulong)(key_ptr + KEY_PTR_LEN));
  32. }
  33. ret = invoke_smc(ZYNQMP_SIP_SVC_PM_SECURE_IMG_LOAD, src_lo, src_hi,
  34. key_lo, key_hi, ret_payload);
  35. if (ret) {
  36. printf("Failed: secure op status:0x%x\n", ret);
  37. } else {
  38. addr = (u64)ret_payload[1] << 32 | ret_payload[2];
  39. printf("Verified image at 0x%llx\n", addr);
  40. env_set_hex("zynqmp_verified_img_addr", addr);
  41. }
  42. return ret;
  43. }
  44. /**
  45. * do_zynqmp - Handle the "zynqmp" command-line command
  46. * @cmdtp: Command data struct pointer
  47. * @flag: Command flag
  48. * @argc: Command-line argument count
  49. * @argv: Array of command-line arguments
  50. *
  51. * Processes the zynqmp specific commands
  52. *
  53. * Return: return 0 on success and CMD_RET_USAGE incase of misuse and error
  54. */
  55. static int do_zynqmp(cmd_tbl_t *cmdtp, int flag, int argc,
  56. char *const argv[])
  57. {
  58. u64 src_addr;
  59. u32 len;
  60. u8 *key_ptr = NULL;
  61. u8 *src_ptr;
  62. int ret;
  63. if (argc > 5 || argc < 4 || strncmp(argv[1], "secure", 6))
  64. return CMD_RET_USAGE;
  65. src_addr = simple_strtoull(argv[2], NULL, 16);
  66. len = simple_strtoul(argv[3], NULL, 16);
  67. if (argc > 4)
  68. key_ptr = (uint8_t *)(uintptr_t)simple_strtoull(argv[4],
  69. NULL, 16);
  70. src_ptr = (uint8_t *)(uintptr_t)src_addr;
  71. ret = zynqmp_verify_secure(key_ptr, src_ptr, len);
  72. if (ret)
  73. return CMD_RET_FAILURE;
  74. return CMD_RET_SUCCESS;
  75. }
  76. /***************************************************/
  77. #ifdef CONFIG_SYS_LONGHELP
  78. static char zynqmp_help_text[] =
  79. "secure src len [key_addr] - verifies secure images of $len bytes\n"
  80. " long at address $src. Optional key_addr\n"
  81. " can be specified if user key needs to\n"
  82. " be used for decryption\n";
  83. #endif
  84. U_BOOT_CMD(
  85. zynqmp, 5, 1, do_zynqmp,
  86. "Verify and load secure images",
  87. zynqmp_help_text
  88. )