On Tue, 3 Mar 2020 at 11:33, Pete Batard <p...@akeo.ie> wrote: > > From: Andrei Warkentin <andrey.warken...@gmail.com> > > Add a new RPiFirmwareGetModelInstalledMB () call in RpiFirmwareDxe > to return the amount of detected installed RAM on the system (in MB). > > Use the new call in PlatformSmbiosDxe. > > Signed-off-by: Pete Batard <p...@akeo.ie>
Please split this into two patches > --- > Platform/RaspberryPi/Drivers/PlatformSmbiosDxe/PlatformSmbiosDxe.c | 10 ++--- > Platform/RaspberryPi/Drivers/RpiFirmwareDxe/RpiFirmwareDxe.c | 29 > +++++++++++- > Platform/RaspberryPi/Include/Protocol/RpiFirmware.h | 47 > +++++++++++--------- > 3 files changed, 59 insertions(+), 27 deletions(-) > > diff --git > a/Platform/RaspberryPi/Drivers/PlatformSmbiosDxe/PlatformSmbiosDxe.c > b/Platform/RaspberryPi/Drivers/PlatformSmbiosDxe/PlatformSmbiosDxe.c > index f25c439f89c8..5585cb846f41 100644 > --- a/Platform/RaspberryPi/Drivers/PlatformSmbiosDxe/PlatformSmbiosDxe.c > +++ b/Platform/RaspberryPi/Drivers/PlatformSmbiosDxe/PlatformSmbiosDxe.c > @@ -870,21 +870,19 @@ MemArrMapInfoUpdateSmbiosType19 ( > ) > { > EFI_STATUS Status; > - UINT32 BoardRevision = 0; > + UINT32 InstalledMB = 0; > > // Note: Type 19 addresses are expressed in KB, not bytes > // The memory layout used in all known Pi SoC's starts at 0 > mMemArrMapInfoType19.StartingAddress = 0; > + > // The minimum RAM size used on any Raspberry Pi model is 256 MB > mMemArrMapInfoType19.EndingAddress = 256 * 1024; > - Status = mFwProtocol->GetModelRevision (&BoardRevision); > + Status = mFwProtocol->GetModelInstalledMB (&InstalledMB); > if (Status != EFI_SUCCESS) { > DEBUG ((DEBUG_WARN, "Couldn't get the board memory size - defaulting to > 256 MB: %r\n", Status)); > } else { > - // > www.raspberrypi.org/documentation/hardware/raspberrypi/revision-codes/README.md > - // Bits [20-22] indicate the amount of memory starting with 256MB (000b) > - // and doubling in size for each value (001b = 512 MB, 010b = 1GB, etc.) > - mMemArrMapInfoType19.EndingAddress <<= (BoardRevision >> 20) & 0x07; > + mMemArrMapInfoType19.EndingAddress = InstalledMB * 1024; > } > mMemArrMapInfoType19.EndingAddress -= 1; > > diff --git a/Platform/RaspberryPi/Drivers/RpiFirmwareDxe/RpiFirmwareDxe.c > b/Platform/RaspberryPi/Drivers/RpiFirmwareDxe/RpiFirmwareDxe.c > index 75826fdc0e53..40c78b5d57cf 100644 > --- a/Platform/RaspberryPi/Drivers/RpiFirmwareDxe/RpiFirmwareDxe.c > +++ b/Platform/RaspberryPi/Drivers/RpiFirmwareDxe/RpiFirmwareDxe.c > @@ -606,6 +606,32 @@ RpiFirmwareGetModelName ( > } > } > > +STATIC > +EFI_STATUS > +EFIAPI > +RPiFirmwareGetModelInstalledMB ( > + OUT UINT32 *InstalledMB > + ) > +{ > + EFI_STATUS Status; > + UINT32 Revision; > + > + Status = RpiFirmwareGetModelRevision(&Revision); > + if (EFI_ERROR(Status)) { > + DEBUG ((DEBUG_ERROR, "%a: Could not get the board revision: Status == > %r\n", > + __FUNCTION__, Status)); > + return EFI_DEVICE_ERROR; > + } > + > + // > + // > www.raspberrypi.org/documentation/hardware/raspberrypi/revision-codes/README.md > + // Bits [20-22] indicate the amount of memory starting with 256MB (000b) > + // and doubling in size for each value (001b = 512 MB, 010b = 1GB, etc.) > + // > + *InstalledMB = 256 << ((Revision >> 20) & 0x07); > + return EFI_SUCCESS; > +} > + > STATIC > EFI_STATUS > EFIAPI > @@ -1236,7 +1262,8 @@ STATIC RASPBERRY_PI_FIRMWARE_PROTOCOL > mRpiFirmwareProtocol = { > RpiFirmwareGetFirmwareRevision, > RpiFirmwareGetManufacturerName, > RpiFirmwareGetCpuName, > - RpiFirmwareGetArmMemory > + RpiFirmwareGetArmMemory, > + RPiFirmwareGetModelInstalledMB, > }; > > /** > diff --git a/Platform/RaspberryPi/Include/Protocol/RpiFirmware.h > b/Platform/RaspberryPi/Include/Protocol/RpiFirmware.h > index e3287e3c040f..108becbd3b6d 100644 > --- a/Platform/RaspberryPi/Include/Protocol/RpiFirmware.h > +++ b/Platform/RaspberryPi/Include/Protocol/RpiFirmware.h > @@ -115,6 +115,12 @@ EFI_STATUS > UINT32 *Revision > ); > > +typedef > +EFI_STATUS > +(EFIAPI *GET_MODEL_INSTALLED_MB) ( > + UINT32 *InstalledMB > + ); > + > typedef > CHAR8* > (EFIAPI *GET_MANUFACTURER_NAME) ( > @@ -135,26 +141,27 @@ EFI_STATUS > ); > > typedef struct { > - SET_POWER_STATE SetPowerState; > - GET_MAC_ADDRESS GetMacAddress; > - GET_COMMAND_LINE GetCommandLine; > - GET_CLOCK_RATE GetClockRate; > - GET_CLOCK_RATE GetMaxClockRate; > - GET_CLOCK_RATE GetMinClockRate; > - SET_CLOCK_RATE SetClockRate; > - GET_FB GetFB; > - FREE_FB FreeFB; > - GET_FB_SIZE GetFBSize; > - SET_LED SetLed; > - GET_SERIAL GetSerial; > - GET_MODEL GetModel; > - GET_MODEL_REVISION GetModelRevision; > - GET_MODEL_NAME GetModelName; > - GET_MODEL_FAMILY GetModelFamily; > - GET_FIRMWARE_REVISION GetFirmwareRevision; > - GET_MANUFACTURER_NAME GetManufacturerName; > - GET_CPU_NAME GetCpuName; > - GET_ARM_MEM GetArmMem; > + SET_POWER_STATE SetPowerState; > + GET_MAC_ADDRESS GetMacAddress; > + GET_COMMAND_LINE GetCommandLine; > + GET_CLOCK_RATE GetClockRate; > + GET_CLOCK_RATE GetMaxClockRate; > + GET_CLOCK_RATE GetMinClockRate; > + SET_CLOCK_RATE SetClockRate; > + GET_FB GetFB; > + FREE_FB FreeFB; > + GET_FB_SIZE GetFBSize; > + SET_LED SetLed; > + GET_SERIAL GetSerial; > + GET_MODEL GetModel; > + GET_MODEL_REVISION GetModelRevision; > + GET_MODEL_NAME GetModelName; > + GET_MODEL_FAMILY GetModelFamily; > + GET_FIRMWARE_REVISION GetFirmwareRevision; > + GET_MANUFACTURER_NAME GetManufacturerName; > + GET_CPU_NAME GetCpuName; > + GET_ARM_MEM GetArmMem; > + GET_MODEL_INSTALLED_MB GetModelInstalledMB; > } RASPBERRY_PI_FIRMWARE_PROTOCOL; > > extern EFI_GUID gRaspberryPiFirmwareProtocolGuid; > -- > 2.21.0.windows.1 > -=-=-=-=-=-=-=-=-=-=-=- Groups.io Links: You receive all messages sent to this group. View/Reply Online (#55309): https://edk2.groups.io/g/devel/message/55309 Mute This Topic: https://groups.io/mt/71697495/21656 Group Owner: devel+ow...@edk2.groups.io Unsubscribe: https://edk2.groups.io/g/devel/unsub [arch...@mail-archive.com] -=-=-=-=-=-=-=-=-=-=-=-