mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-26 14:01:50 +01:00 
			
		
		
		
	Add a structure which defines the information that is needed for executing capsule updates on a platform. Some information in the structure like the dfu string is used for making the update process more robust while some information like the per platform image GUIDs is used for fixing issues. Initialise this structure in the board file, and use the information for the capsule updates. Signed-off-by: Sughosh Ganu <sughosh.ganu@linaro.org>
		
			
				
	
	
		
			182 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			182 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0+
 | |
| /*
 | |
|  * Copyright (c) 2017 Tuomas Tynkkynen
 | |
|  */
 | |
| 
 | |
| #include <common.h>
 | |
| #include <cpu_func.h>
 | |
| #include <dm.h>
 | |
| #include <efi.h>
 | |
| #include <efi_loader.h>
 | |
| #include <fdtdec.h>
 | |
| #include <init.h>
 | |
| #include <log.h>
 | |
| #include <virtio_types.h>
 | |
| #include <virtio.h>
 | |
| 
 | |
| #include <linux/kernel.h>
 | |
| 
 | |
| #ifdef CONFIG_ARM64
 | |
| #include <asm/armv8/mmu.h>
 | |
| 
 | |
| #if CONFIG_IS_ENABLED(EFI_HAVE_CAPSULE_SUPPORT)
 | |
| struct efi_fw_image fw_images[] = {
 | |
| #if defined(CONFIG_TARGET_QEMU_ARM_32BIT)
 | |
| 	{
 | |
| 		.image_type_id = QEMU_ARM_UBOOT_IMAGE_GUID,
 | |
| 		.fw_name = u"Qemu-Arm-UBOOT",
 | |
| 		.image_index = 1,
 | |
| 	},
 | |
| #elif defined(CONFIG_TARGET_QEMU_ARM_64BIT)
 | |
| 	{
 | |
| 		.image_type_id = QEMU_ARM64_UBOOT_IMAGE_GUID,
 | |
| 		.fw_name = u"Qemu-Arm-UBOOT",
 | |
| 		.image_index = 1,
 | |
| 	},
 | |
| #endif
 | |
| };
 | |
| 
 | |
| struct efi_capsule_update_info update_info = {
 | |
| 	.images = fw_images,
 | |
| };
 | |
| 
 | |
| u8 num_image_type_guids = ARRAY_SIZE(fw_images);
 | |
| #endif /* EFI_HAVE_CAPSULE_SUPPORT */
 | |
| 
 | |
| static struct mm_region qemu_arm64_mem_map[] = {
 | |
| 	{
 | |
| 		/* Flash */
 | |
| 		.virt = 0x00000000UL,
 | |
| 		.phys = 0x00000000UL,
 | |
| 		.size = 0x08000000UL,
 | |
| 		.attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
 | |
| 			 PTE_BLOCK_INNER_SHARE
 | |
| 	}, {
 | |
| 		/* Lowmem peripherals */
 | |
| 		.virt = 0x08000000UL,
 | |
| 		.phys = 0x08000000UL,
 | |
| 		.size = 0x38000000,
 | |
| 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
 | |
| 			 PTE_BLOCK_NON_SHARE |
 | |
| 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN
 | |
| 	}, {
 | |
| 		/* RAM */
 | |
| 		.virt = 0x40000000UL,
 | |
| 		.phys = 0x40000000UL,
 | |
| 		.size = 255UL * SZ_1G,
 | |
| 		.attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
 | |
| 			 PTE_BLOCK_INNER_SHARE
 | |
| 	}, {
 | |
| 		/* Highmem PCI-E ECAM memory area */
 | |
| 		.virt = 0x4010000000ULL,
 | |
| 		.phys = 0x4010000000ULL,
 | |
| 		.size = 0x10000000,
 | |
| 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
 | |
| 			 PTE_BLOCK_NON_SHARE |
 | |
| 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN
 | |
| 	}, {
 | |
| 		/* Highmem PCI-E MMIO memory area */
 | |
| 		.virt = 0x8000000000ULL,
 | |
| 		.phys = 0x8000000000ULL,
 | |
| 		.size = 0x8000000000ULL,
 | |
| 		.attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
 | |
| 			 PTE_BLOCK_NON_SHARE |
 | |
| 			 PTE_BLOCK_PXN | PTE_BLOCK_UXN
 | |
| 	}, {
 | |
| 		/* List terminator */
 | |
| 		0,
 | |
| 	}
 | |
| };
 | |
| 
 | |
| struct mm_region *mem_map = qemu_arm64_mem_map;
 | |
| #endif
 | |
| 
 | |
| int board_init(void)
 | |
| {
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| int board_late_init(void)
 | |
| {
 | |
| 	/*
 | |
| 	 * Make sure virtio bus is enumerated so that peripherals
 | |
| 	 * on the virtio bus can be discovered by their drivers
 | |
| 	 */
 | |
| 	virtio_init();
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| int dram_init(void)
 | |
| {
 | |
| 	if (fdtdec_setup_mem_size_base() != 0)
 | |
| 		return -EINVAL;
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| int dram_init_banksize(void)
 | |
| {
 | |
| 	fdtdec_setup_memory_banksize();
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| void *board_fdt_blob_setup(int *err)
 | |
| {
 | |
| 	*err = 0;
 | |
| 	/* QEMU loads a generated DTB for us at the start of RAM. */
 | |
| 	return (void *)CONFIG_SYS_SDRAM_BASE;
 | |
| }
 | |
| 
 | |
| void enable_caches(void)
 | |
| {
 | |
| 	 icache_enable();
 | |
| 	 dcache_enable();
 | |
| }
 | |
| 
 | |
| #ifdef CONFIG_ARM64
 | |
| #define __W	"w"
 | |
| #else
 | |
| #define __W
 | |
| #endif
 | |
| 
 | |
| u8 flash_read8(void *addr)
 | |
| {
 | |
| 	u8 ret;
 | |
| 
 | |
| 	asm("ldrb %" __W "0, %1" : "=r"(ret) : "m"(*(u8 *)addr));
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| u16 flash_read16(void *addr)
 | |
| {
 | |
| 	u16 ret;
 | |
| 
 | |
| 	asm("ldrh %" __W "0, %1" : "=r"(ret) : "m"(*(u16 *)addr));
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| u32 flash_read32(void *addr)
 | |
| {
 | |
| 	u32 ret;
 | |
| 
 | |
| 	asm("ldr %" __W "0, %1" : "=r"(ret) : "m"(*(u32 *)addr));
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| void flash_write8(u8 value, void *addr)
 | |
| {
 | |
| 	asm("strb %" __W "1, %0" : "=m"(*(u8 *)addr) : "r"(value));
 | |
| }
 | |
| 
 | |
| void flash_write16(u16 value, void *addr)
 | |
| {
 | |
| 	asm("strh %" __W "1, %0" : "=m"(*(u16 *)addr) : "r"(value));
 | |
| }
 | |
| 
 | |
| void flash_write32(u32 value, void *addr)
 | |
| {
 | |
| 	asm("str %" __W "1, %0" : "=m"(*(u32 *)addr) : "r"(value));
 | |
| }
 |