summaryrefslogtreecommitdiff
path: root/lib/avb/fsl/fsl_avbkey.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/avb/fsl/fsl_avbkey.c')
-rw-r--r--lib/avb/fsl/fsl_avbkey.c16
1 files changed, 16 insertions, 0 deletions
diff --git a/lib/avb/fsl/fsl_avbkey.c b/lib/avb/fsl/fsl_avbkey.c
index 890ff713226..85428db029d 100644
--- a/lib/avb/fsl/fsl_avbkey.c
+++ b/lib/avb/fsl/fsl_avbkey.c
@@ -15,6 +15,7 @@
#include <mapmem.h>
#include <fsl_avb.h>
+#include "trusty/avb.h"
#ifdef CONFIG_IMX_TRUSTY_OS
#include <trusty/libtipc.h>
#endif
@@ -1127,5 +1128,20 @@ fail:
return ret;
}
+
+int avb_set_public_key(uint8_t *staged_buffer, uint32_t size) {
+
+ if ((staged_buffer == NULL) || (size <= 0)) {
+ ERR("Error. Get null staged_buffer\n");
+ return -1;
+ }
+ if (trusty_write_vbmeta_public_key(staged_buffer, size)) {
+ ERR("Error. Failed to write vbmeta public key into secure storage\n");
+ return -1;
+ } else
+ printf("Set vbmeta public key successfully!\n");
+
+ return 0;
+}
#endif /* CONFIG_IMX_TRUSTY_OS && CONFIG_ANDROID_AUTO_SUPPORT */
#endif /* CONFIG_SPL_BUILD */