// SPDX-License-Identifier: GPL-2.0+ /* * (C) Copyright 2021, Foundries.IO * */ #include #include #include #include int do_scp03_enable(struct cmd_tbl *cmdtp, int flag, int argc, char *const argv[]) { if (argc != 1) return CMD_RET_USAGE; if (tee_enable_scp03()) { printf("TEE failed to enable SCP03\n"); return CMD_RET_FAILURE; } printf("SCP03 is enabled\n"); return CMD_RET_SUCCESS; } int do_scp03_provision(struct cmd_tbl *cmdtp, int flag, int argc, char *const argv[]) { if (argc != 1) return CMD_RET_USAGE; if (tee_provision_scp03()) { printf("TEE failed to provision SCP03 keys\n"); return CMD_RET_FAILURE; } printf("SCP03 is provisioned\n"); return CMD_RET_SUCCESS; } static char text[] = "provides a command to enable SCP03 and provision the SCP03 keys\n" " enable - enable SCP03 on the TEE\n" " provision - provision SCP03 on the TEE\n"; U_BOOT_CMD_WITH_SUBCMDS(scp03, "Secure Channel Protocol 03 control", text, U_BOOT_SUBCMD_MKENT(enable, 1, 1, do_scp03_enable), U_BOOT_SUBCMD_MKENT(provision, 1, 1, do_scp03_provision));