diff options
Diffstat (limited to 'board/microchip/mpfs_icicle/mpfs_icicle.c')
| -rw-r--r-- | board/microchip/mpfs_icicle/mpfs_icicle.c | 72 | 
1 files changed, 72 insertions, 0 deletions
| diff --git a/board/microchip/mpfs_icicle/mpfs_icicle.c b/board/microchip/mpfs_icicle/mpfs_icicle.c index 4d7d843dfa3..ba622e38ee5 100644 --- a/board/microchip/mpfs_icicle/mpfs_icicle.c +++ b/board/microchip/mpfs_icicle/mpfs_icicle.c @@ -9,6 +9,7 @@  #include <init.h>  #include <asm/global_data.h>  #include <asm/io.h> +#include <asm/sections.h>  DECLARE_GLOBAL_DATA_PTR; @@ -50,6 +51,77 @@ static void read_device_serial_number(u8 *response, u8 response_size)  		response_buf[idx] = readb(MPFS_SYS_SERVICE_MAILBOX + idx);  } +#if defined(CONFIG_MULTI_DTB_FIT) +int board_fit_config_name_match(const char *name) +{ +	const void *fdt; +	int list_len; + +	/* +	 * If there's not a HSS provided dtb, there's no point re-selecting +	 * since we'd just end up re-selecting the same dtb again. +	 */ +	if (!gd->arch.firmware_fdt_addr) +		return -EINVAL; + +	fdt = (void *)gd->arch.firmware_fdt_addr; + +	list_len = fdt_stringlist_count(fdt, 0, "compatible"); +	if (list_len < 1) +		return -EINVAL; + +	for (int i = 0; i < list_len; i++) { +		int len, match; +		const char *compat; +		char copy[64]; +		char *devendored; + +		compat = fdt_stringlist_get(fdt, 0, "compatible", i, &len); +		if (!compat) +			return -EINVAL; + +		/* +		 * The naming scheme for compatibles doesn't produce anything +		 * close to this long. +		 */ +		if (len >= 64) +			return -EINVAL; + +		strncpy(copy, compat, 64); +		strtok(copy, ","); + +		devendored = strtok(NULL, ","); +		if (!devendored) +			return -EINVAL; + +		match = strcmp(devendored, name); +		if (!match) +			return 0; +	} + +	return -EINVAL; +} +#endif + +int board_fdt_blob_setup(void **fdtp) +{ +	fdtp = (void *)_end; + +	/* +	 * The devicetree provided by the previous stage is very minimal due to +	 * severe space constraints. The firmware performs no fixups etc. +	 * U-Boot, if providing a devicetree, almost certainly has a better +	 * more complete one than the firmware so that provided by the firmware +	 * is ignored for OF_SEPARATE. +	 */ +	if (IS_ENABLED(CONFIG_OF_BOARD) && !IS_ENABLED(CONFIG_MULTI_DTB_FIT)) { +		if (gd->arch.firmware_fdt_addr) +			fdtp = (void *)(uintptr_t)gd->arch.firmware_fdt_addr; +	} + +	return 0; +} +  int board_init(void)  {  	/* For now nothing to do here. */ | 
