/* * Copyright (c) 2019-2020, ARM Limited. All rights reserved. * * SPDX-License-Identifier: BSD-3-Clause */ #include #include #include #include #include #include struct tbbr_dyn_config_t tbbr_dyn_config; int fconf_populate_tbbr_dyn_config(uintptr_t config) { int err; int node; /* As libfdt use void *, we can't avoid this cast */ const void *dtb = (void *)config; /* Assert the node offset point to "arm,tb_fw" compatible property */ const char *compatible_str = "arm,tb_fw"; node = fdt_node_offset_by_compatible(dtb, -1, compatible_str); if (node < 0) { ERROR("FCONF: Can't find %s compatible in dtb\n", compatible_str); return node; } /* Locate the disable_auth cell and read the value */ err = fdtw_read_cells(dtb, node, "disable_auth", 1, &tbbr_dyn_config.disable_auth); if (err < 0) { WARN("FCONF: Read cell failed for `disable_auth`\n"); return err; } /* Check if the value is boolean */ if ((tbbr_dyn_config.disable_auth != 0U) && (tbbr_dyn_config.disable_auth != 1U)) { WARN("Invalid value for `disable_auth` cell %d\n", tbbr_dyn_config.disable_auth); return -1; } #if defined(DYN_DISABLE_AUTH) if (tbbr_dyn_config.disable_auth == 1) dyn_disable_auth(); #endif VERBOSE("FCONF:tbbr.disable_auth cell found with value = %d\n", tbbr_dyn_config.disable_auth); return 0; } FCONF_REGISTER_POPULATOR(tbbr, fconf_populate_tbbr_dyn_config);