/** @file Copyright (c) 2011-2014, ARM Ltd. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent **/ #include #include #include #include #include #define NOR_FLASH_DEVICE_COUNT 4 NOR_FLASH_DESCRIPTION mNorFlashDevices[NOR_FLASH_DEVICE_COUNT] = { { // BootMon ARM_VE_SMB_NOR0_BASE, ARM_VE_SMB_NOR0_BASE, SIZE_256KB * 255, SIZE_256KB, }, { // BootMon non-volatile storage ARM_VE_SMB_NOR0_BASE, ARM_VE_SMB_NOR0_BASE + SIZE_256KB * 255, SIZE_64KB * 4, SIZE_64KB, }, { // UEFI ARM_VE_SMB_NOR1_BASE, ARM_VE_SMB_NOR1_BASE, SIZE_256KB * 255, SIZE_256KB, }, { // UEFI Variable Services non-volatile storage ARM_VE_SMB_NOR1_BASE, ARM_VE_SMB_NOR1_BASE + SIZE_256KB * 255, SIZE_64KB * 3, //FIXME: Set 3 blocks because I did not succeed to copy 4 blocks into the ARM Versatile Express NOR Flash in the last NOR Flash. It should be 4 blocks SIZE_64KB, } }; EFI_STATUS NorFlashPlatformInitialization ( VOID ) { // Everything seems ok so far, so now we need to disable the platform-specific // flash write protection for Versatile Express if ((MmioRead32 (ARM_VE_SYS_FLASH) & 0x1) == 0) { // Writing to NOR FLASH is disabled, so enable it MmioWrite32 (ARM_VE_SYS_FLASH,1); DEBUG((DEBUG_BLKIO, "NorFlashWriteBlocks: informational - Had to enable HSYS_FLASH flag.\n" )); } return EFI_SUCCESS; } EFI_STATUS NorFlashPlatformGetDevices ( OUT NOR_FLASH_DESCRIPTION **NorFlashDevices, OUT UINT32 *Count ) { if ((NorFlashDevices == NULL) || (Count == NULL)) { return EFI_INVALID_PARAMETER; } *NorFlashDevices = mNorFlashDevices; *Count = NOR_FLASH_DEVICE_COUNT; return EFI_SUCCESS; }