From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from EUR05-VI1-obe.outbound.protection.outlook.com (EUR05-VI1-obe.outbound.protection.outlook.com [40.107.21.83]) by mx.groups.io with SMTP id smtpd.web11.7765.1586167727039679702 for ; Mon, 06 Apr 2020 03:08:48 -0700 Authentication-Results: mx.groups.io; dkim=pass header.i=@nxp1.onmicrosoft.com header.s=selector2-nxp1-onmicrosoft-com header.b=ZbZPIZEg; spf=pass (domain: oss.nxp.com, ip: 40.107.21.83, mailfrom: pankaj.bansal@oss.nxp.com) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=ZPjmn5/lPKIhdHqQlcsfcV1T5sHQ+GXFTuOColuWwfIvOdMACbSk1VH1cmIdORoZSMgK4tSy9jQSVT7/iz7fzTgnlHFtp/z2d77xJxbBtemNQHxuQvLlBud4kNk5ybL8Btsky/lt1P8h5y7u1mDF/RZVZJ4RcMU7Uz9OvvRLJV5uifNwqj/6keicAyQ9duvujrI2KyWG3KuY27kQOxpap9xGnvb8W4sseF7myErz4Yl9iQco0YBCVyB/M3g7Dp5eoEy5myF9DxFiHJw/b+qFh+x1hw+cNAyAoYmKXdVyMZfaJJ79xKJFKbBdjmtK04wf938c+sFC139VUq7dSPCrLQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=LTt5p6EzulX+r8ET0Mg+OuqSbc5TRNOW1T1+pwqAFFc=; b=PgusFu55AbbE2ZqTGFKBJonqxQlsDkf4l3Ep5yDWVda5S7aoU54grGNKpWI8+C5AAffT5x81IXLUhQ8wubeDb4yrthz8Vm/ue/NgyYucDaEiyGC/gTdVMUUFPl1fB/4JUt8QxWlKK1tMWQuFDkDzbpCDQY3G5ariwWGY659q9y/BJ/XP+8yH/TnaspEa1Hl5cYZaq0frFw4l+9rVVpNOnP2ExRpTY6YT0pqunjuy81UIHIcfoPpwuZ1zwIDsgmsVz0fyhQgSAljCnIKo6UWfN8+NuSmt/gEpVClNMrbE1aepysDTQO3/pkORwF79N1Ho2jaLkU9Pg6ll9nE5yADPjw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=oss.nxp.com; dmarc=pass action=none header.from=oss.nxp.com; dkim=pass header.d=oss.nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=NXP1.onmicrosoft.com; s=selector2-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=LTt5p6EzulX+r8ET0Mg+OuqSbc5TRNOW1T1+pwqAFFc=; b=ZbZPIZEgj/w0y6bHYSU8gR8EpRzN1ghdizcDkTWLBWZC2r5qulnJCKMFO2jo5j5wXRTzf+oM4fzX56l+pEO2gNAuWZqqYiQ1HsuW/wudJikJAtLnIlw4l5N4u45gDaQwyvrNO0wP6+xOj6LnhDJF1HFS/cwu7B2/sPkVOjC4CWg= Received: from VI1PR04MB5933.eurprd04.prod.outlook.com (2603:10a6:803:ec::16) by VI1PR04MB2976.eurprd04.prod.outlook.com (2603:10a6:802:8::30) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.2878.21; Mon, 6 Apr 2020 10:08:44 +0000 Received: from VI1PR04MB5933.eurprd04.prod.outlook.com ([fe80::e581:c145:2f3c:fa18]) by VI1PR04MB5933.eurprd04.prod.outlook.com ([fe80::e581:c145:2f3c:fa18%6]) with mapi id 15.20.2878.018; Mon, 6 Apr 2020 10:08:44 +0000 From: "Pankaj Bansal" To: Leif Lindholm , "Pankaj Bansal (OSS)" CC: Meenakshi Aggarwal , Michael D Kinney , "devel@edk2.groups.io" , Varun Sethi , Samer El-Haj-Mahmoud , Jon Nettleton Subject: Re: [PATCH v2 15/28] Silicon/NXP: Move RAM retrieval from SocLib Thread-Topic: [PATCH v2 15/28] Silicon/NXP: Move RAM retrieval from SocLib Thread-Index: AQHWC/tavQnQk7nSDEKhhap7zDCFvw== Date: Mon, 6 Apr 2020 10:08:43 +0000 Message-ID: References: <20200320143543.18615-1-pankaj.bansal@oss.nxp.com> <20200320143543.18615-16-pankaj.bansal@oss.nxp.com> <20200401124255.GW7468@vanye> In-Reply-To: <20200401124255.GW7468@vanye> Accept-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: authentication-results: spf=none (sender IP is ) smtp.mailfrom=pankaj.bansal@oss.nxp.com; x-ms-exchange-messagesentrepresentingtype: 1 x-originating-ip: [49.36.135.41] x-ms-publictraffictype: Email x-ms-office365-filtering-ht: Tenant x-ms-office365-filtering-correlation-id: 7431806f-b86d-4973-d149-08d7da127d2e x-ms-traffictypediagnostic: VI1PR04MB2976:|VI1PR04MB2976: x-ms-exchange-sharedmailbox-routingagent-processed: True x-ms-exchange-transport-forked: True x-microsoft-antispam-prvs: x-ms-oob-tlc-oobclassifiers: OLM:9508; x-forefront-prvs: 0365C0E14B x-forefront-antispam-report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:VI1PR04MB5933.eurprd04.prod.outlook.com;PTR:;CAT:NONE;SFTY:;SFS:(10009020)(4636009)(366004)(136003)(346002)(39860400002)(376002)(396003)(81166006)(6506007)(19627235002)(5660300002)(52536014)(55016002)(8936002)(53546011)(66446008)(64756008)(7696005)(76116006)(30864003)(316002)(66556008)(66476007)(86362001)(54906003)(33656002)(4326008)(9686003)(2906002)(8676002)(66946007)(110136005)(478600001)(186003)(81156014)(71200400001)(26005);DIR:OUT;SFP:1101; received-spf: None (protection.outlook.com: oss.nxp.com does not designate permitted sender hosts) x-ms-exchange-senderadcheck: 1 x-microsoft-antispam: BCL:0; x-microsoft-antispam-message-info: Pedzix3lnu9hIUmcgVLPO9QCY95wter8QvJ1qLFsQwpTXQCOq4nwBAd1g6yC7IURSnb6jTlr4egqJWO/mFpfisaargsL1ihWXvzk07oqZyZrDwhOxVs/Q4YKaJsU8hqfCwyThU2HGTc06wpUmUv4RME+KpZZUqs73yAaDzVgaDGJ01kXxWV/+6tIgqJLF4dXin8WU/sSw3x+Y9OEIxaGVFZmLcYNxanhZpf9TUtby1TecKnQpLsqFYjhvzUFPwrpBsKA//taKd17BNK5Nir0vyO64+7oV5KYBJmtUhlbofVG0tYIK18omjNH0pa6v+3QgC5gJc/8bF5QabMNKZNk4hZSuHl4u4A5MAQgSt8KWJAV2Wc6+erfqihY9sWYGtWGEc0N7bukZm3I6Sv+eg1ead6B84ukDV1qpPF7moCzYezSs2+S7YhY/k4XXuv2Bg9O x-ms-exchange-antispam-messagedata: qi1XqB073jRBdW8nut+jxtdnV7ZJSMi5VkRDcAhCwACcz1GNt4WgVtP5s/wWLZhvV5mN/tHMnfiMElfPbdKmxjud4v1WNlO+aLA4pVIomubf3ZLRi1WRAb/olfI0Vzkw0oqG7tcHViJbR072ZVWvSw== MIME-Version: 1.0 X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 7431806f-b86d-4973-d149-08d7da127d2e X-MS-Exchange-CrossTenant-originalarrivaltime: 06 Apr 2020 10:08:43.9301 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-mailboxtype: HOSTED X-MS-Exchange-CrossTenant-userprincipalname: h4Fg4uVcl2ZGO2bnl/kLm2/hCeyC2totGgyM2mOma0Z9AXk/XYUKBG7x9LBNTMQ92zo6UIJrXBeJa7tj659yXg== X-MS-Exchange-Transport-CrossTenantHeadersStamped: VI1PR04MB2976 Content-Language: en-US Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: quoted-printable > -----Original Message----- > From: Leif Lindholm > Sent: Wednesday, April 1, 2020 6:13 PM > To: Pankaj Bansal (OSS) > Cc: Meenakshi Aggarwal ; Michael D Kinney > ; devel@edk2.groups.io; Varun Sethi > ; Samer El-Haj-Mahmoud Mahmoud@arm.com>; Jon Nettleton > Subject: Re: [PATCH v2 15/28] Silicon/NXP: Move RAM retrieval from SocLib >=20 > On Fri, Mar 20, 2020 at 20:05:30 +0530, Pankaj Bansal wrote: > > From: Pankaj Bansal > > > > RAM retrieval using SMC commands is common to all Layerscape SOCs. > > Therefore, move it to commom MemoryInit Pei Lib. > > > > Signed-off-by: Pankaj Bansal > > --- > > Silicon/NXP/Include/DramInfo.h | 38 ----- > > .../Library/MemoryInitPei/MemoryInitPeiLib.c | 137 ++++++++++++++---- > > .../Library/MemoryInitPei/MemoryInitPeiLib.h | 25 ++++ > > .../MemoryInitPei/MemoryInitPeiLib.inf | 7 +- > > Silicon/NXP/Library/SocLib/Chassis.c | 67 --------- > > Silicon/NXP/Library/SocLib/LS1043aSocLib.inf | 1 - > > 6 files changed, 140 insertions(+), 135 deletions(-) > > delete mode 100644 Silicon/NXP/Include/DramInfo.h > > create mode 100644 Silicon/NXP/Library/MemoryInitPei/MemoryInitPeiLib.= h > > > > diff --git a/Silicon/NXP/Include/DramInfo.h b/Silicon/NXP/Include/DramI= nfo.h > > deleted file mode 100644 > > index a934aaeff1f5..000000000000 > > --- a/Silicon/NXP/Include/DramInfo.h > > +++ /dev/null > > @@ -1,38 +0,0 @@ > > -/** @file > > -* Header defining the structure for Dram Information > > -* > > -* Copyright 2019 NXP > > -* > > -* SPDX-License-Identifier: BSD-2-Clause-Patent > > -* > > -**/ > > - > > -#ifndef DRAM_INFO_H_ > > -#define DRAM_INFO_H_ > > - > > -#include > > - > > -#define SMC_DRAM_BANK_INFO (0xC200FF12) > > - > > -typedef struct { > > - UINTN BaseAddress; > > - UINTN Size; > > -} DRAM_REGION_INFO; > > - > > -typedef struct { > > - UINT32 NumOfDrams; > > - UINT32 Reserved; > > - DRAM_REGION_INFO DramRegion[3]; > > -} DRAM_INFO; > > - > > -EFI_STATUS > > -GetDramBankInfo ( > > - IN OUT DRAM_INFO *DramInfo > > - ); > > - > > -VOID > > -UpdateDpaaDram ( > > - IN OUT DRAM_INFO *DramInfo > > - ); > > - > > -#endif /* DRAM_INFO_H_ */ > > diff --git a/Silicon/NXP/Library/MemoryInitPei/MemoryInitPeiLib.c > b/Silicon/NXP/Library/MemoryInitPei/MemoryInitPeiLib.c > > index 3ea773678667..54d026ef1270 100644 > > --- a/Silicon/NXP/Library/MemoryInitPei/MemoryInitPeiLib.c > > +++ b/Silicon/NXP/Library/MemoryInitPei/MemoryInitPeiLib.c > > @@ -17,8 +17,10 @@ > > #include > > #include > > #include > > +#include >=20 > Please insert alpabetically sorted. Ok. >=20 > > + > > +#include "MemoryInitPeiLib.h" > > > > -#include > > > > VOID > > BuildMemoryTypeInformationHob ( > > @@ -68,10 +70,17 @@ MemoryPeim ( > > ) > > { > > ARM_MEMORY_REGION_DESCRIPTOR *MemoryTable; > > + ARM_SMC_ARGS ArmSmcArgs; > > + INT32 Index; > > + UINTN DramSize; > > + UINTN BaseAddress; > > + UINTN Size; > > + UINTN Top; > > + DRAM_REGION_INFO DramRegions[MAX_DRAM_REGIONS]; > > EFI_RESOURCE_ATTRIBUTE_TYPE ResourceAttributes; > > - EFI_PEI_HOB_POINTERS NextHob; > > - BOOLEAN Found; > > - DRAM_INFO DramInfo; > > + UINTN FdBase; > > + UINTN FdTop; > > + BOOLEAN FoundSystemMem; > > > > // Get Virtual Memory Map from the Platform Library > > ArmPlatformGetVirtualMemoryMap (&MemoryTable); > > @@ -94,40 +103,112 @@ MemoryPeim ( > > EFI_RESOURCE_ATTRIBUTE_TESTED > > ); > > > > - if (GetDramBankInfo (&DramInfo)) { > > - DEBUG ((DEBUG_ERROR, "Failed to get DRAM information, exiting...\n= ")); > > - return EFI_UNSUPPORTED; > > - } > > - > > - while (DramInfo.NumOfDrams--) { > > - // > > - // Check if the resource for the main system memory has been decla= red > > - // > > - Found =3D FALSE; > > - NextHob.Raw =3D GetHobList (); > > - while ((NextHob.Raw =3D GetNextHob > (EFI_HOB_TYPE_RESOURCE_DESCRIPTOR, NextHob.Raw)) !=3D NULL) { > > - if ((NextHob.ResourceDescriptor->ResourceType =3D=3D > EFI_RESOURCE_SYSTEM_MEMORY) && > > - (DramInfo.DramRegion[DramInfo.NumOfDrams].BaseAddress >=3D > NextHob.ResourceDescriptor->PhysicalStart) && > > - (NextHob.ResourceDescriptor->PhysicalStart + > NextHob.ResourceDescriptor->ResourceLength <=3D > > - DramInfo.DramRegion[DramInfo.NumOfDrams].BaseAddress + > DramInfo.DramRegion[DramInfo.NumOfDrams].Size)) > > - { > > - Found =3D TRUE; > > - break; > > + FoundSystemMem =3D FALSE; > > + ZeroMem (DramRegions, sizeof (DramRegions)); > > + > > + Index =3D -1; > > + do { > > + ArmSmcArgs.Arg0 =3D SMC_DRAM_BANK_INFO; > > + ArmSmcArgs.Arg1 =3D Index++; > > + > > + ArmCallSmc (&ArmSmcArgs); > > + ASSERT (!(ArmSmcArgs.Arg0 && !Index)); >=20 > This is being a bit too clever for its own good. > We're verifying that if one of the inputs to the function we just > called is zero (i.e. is the first time around the loop), the value > returned in the struct must also be zero? >=20 > Is this equivalent to > if (Index =3D=3D 0) { > ASSERT (ArmSmcArgs.Arg0 =3D=3D SMC_WHATEVER_OK); > } > ? >=20 > If so, please use that form. >=20 > Don't use !Index when you mean Index =3D=3D 0. >=20 > Regardless, a short explanation of the protocol and expected responses > are needed unless the code can be made more self-explanatory. Ok. I will provide more detailed comments and try to simplify the code acco= rdingly. >=20 > > + if (!Index) { > > + DramSize =3D ArmSmcArgs.Arg1; > > + } else { > > + if (!ArmSmcArgs.Arg0) { > > + BaseAddress =3D ArmSmcArgs.Arg1; > > + Size =3D ArmSmcArgs.Arg2; > > + ASSERT (BaseAddress && Size); > > + > > + DramRegions[Index - 1].BaseAddress =3D BaseAddress; > > + DramRegions[Index - 1].Size =3D Size; >=20 > There's a lot of "-1" going on in this function, which should be > possible to avoid by incrementing Index at the end of the loop and > initializing it to 0. The compiler *will* do a better job at > optimizing code for you in all but the most exceptional cases, so try > to avoid optimising C. Ok. >=20 > > + DramSize -=3D Size; > > + > > + DEBUG ((DEBUG_INFO, "bank[%d]: start 0x%lx, size 0x%lx\n", > > + Index, BaseAddress, Size)); > > } > > - NextHob.Raw =3D GET_NEXT_HOB (NextHob); > > + } > > + } while (DramSize && Index < MAX_DRAM_REGIONS); > > + > > + ASSERT (!DramSize); >=20 > And this (human language) semantically says "throw an exception if we > have RAM". >=20 > I can sort of start to make educated guesses at this point, but I > shouldn't have to. If making the ArmCallSmc with .Arg1 =3D=3D 0 is a > special request to report the total amount of RAM in the system, that > shouldn't be part of the same loop as the calls extracting the size of > individual regions. OK. >=20 > > + > > + FdBase =3D (UINTN)FixedPcdGet64 (PcdFdBaseAddress); > > + FdTop =3D FdBase + (UINTN)FixedPcdGet32 (PcdFdSize); > > + > > + // Declare memory regios to system >=20 > regions OK >=20 > > + for (Index =3D MAX_DRAM_REGIONS - 1; Index >=3D 0; Index--) { >=20 > I guess what confuses me about this loop is the combination of: > - Iterating over the DRAM regions backwards (optimization?) > - Not terminating the iteration once all of the Fd region has been > covered (the opposite of optimization). >=20 > Could something be done about that? >=20 The DRAM region info is sorted based on the RAM address is SOC memory map. i.e. region0 is at lower address, as compared to region1. The goal to start from last region is to find the topmost RAM region that c= an contain UEFI DXE region i.e. PcdSystemMemoryUefiRegionSize. In the upcoming patches I would update the PcdSystemMemoryBase dynamically = from that region. If UEFI were to allocate any reserved or runtime region, it would be alloca= ted from topmost RAM region. This ensures that maximum amount of lower RAM (32 bit addresses) are left f= or OS to allocate to devices that can only work with 32bit physical addresses. E.g. legacy devices that need to DMA to= 32bit addresses. > / > Leif >=20 > > + if (!DramRegions[Index].Size) { > > + continue; > > } > > > > - if (!Found) { > > - // Reserved the memory space occupied by the firmware volume > > + BaseAddress =3D DramRegions[Index].BaseAddress; > > + Top =3D DramRegions[Index].BaseAddress + DramRegions[Index].Size; > > + > > + // EDK2 does not have the concept of boot firmware copied into DRA= M. > > + // To avoid the DXE core to overwrite this area we must create a m= emory > > + // allocation HOB for the region, but this only works if we split = off the > > + // underlying resource descriptor as well. > > + if (FdBase >=3D BaseAddress && FdTop <=3D Top) { > > + // Update Size > > + Size =3D FdBase - BaseAddress; > > + if (Size) { > > + BuildResourceDescriptorHob ( > > + EFI_RESOURCE_SYSTEM_MEMORY, > > + ResourceAttributes, > > + BaseAddress, > > + Size > > + ); > > + } > > + // create the System Memory HOB for the firmware > > BuildResourceDescriptorHob ( > > EFI_RESOURCE_SYSTEM_MEMORY, > > ResourceAttributes, > > - DramInfo.DramRegion[DramInfo.NumOfDrams].BaseAddress, > > - DramInfo.DramRegion[DramInfo.NumOfDrams].Size > > + FdBase, > > + PcdGet32 (PcdFdSize) > > ); > > + // Create the System Memory HOB for the remaining region (top of= the > FD)s > > + Size =3D Top - FdTop; > > + if (Size) { > > + BuildResourceDescriptorHob ( > > + EFI_RESOURCE_SYSTEM_MEMORY, > > + ResourceAttributes, > > + FdTop, > > + Size > > + ); > > + }; > > + // Mark the memory covering the Firmware Device as boot services= data > > + BuildMemoryAllocationHob (FixedPcdGet64 (PcdFdBaseAddress), > > + FixedPcdGet32 (PcdFdSize), > > + EfiBootServicesData); > > + } else { > > + BuildResourceDescriptorHob ( > > + EFI_RESOURCE_SYSTEM_MEMORY, > > + ResourceAttributes, > > + DramRegions[Index].BaseAddress, > > + DramRegions[Index].Size > > + ); > > + } > > + > > + if (FoundSystemMem) { > > + continue; > > + } > > + > > + BaseAddress =3D DramRegions[Index].BaseAddress; > > + Size =3D DramRegions[Index].Size; > > + Top =3D DramRegions[Index].BaseAddress + DramRegions[Index].Size; > > + > > + if (FdBase >=3D BaseAddress && FdTop <=3D Top) { > > + Size -=3D (UINTN)FixedPcdGet32 (PcdFdSize); > > + } > > + > > + if (Size >=3D FixedPcdGet32 (PcdSystemMemoryUefiRegionSize)) { > > + FoundSystemMem =3D TRUE; > > } > > } > > > > + ASSERT (FoundSystemMem); > > + > > // Build Memory Allocation Hob > > InitMmu (MemoryTable); > > > > diff --git a/Silicon/NXP/Library/MemoryInitPei/MemoryInitPeiLib.h > b/Silicon/NXP/Library/MemoryInitPei/MemoryInitPeiLib.h > > new file mode 100644 > > index 000000000000..edbf0ceaf638 > > --- /dev/null > > +++ b/Silicon/NXP/Library/MemoryInitPei/MemoryInitPeiLib.h > > @@ -0,0 +1,25 @@ > > +/** @file > > +* > > +* Copyright 2020 NXP > > +* > > +* SPDX-License-Identifier: BSD-2-Clause-Patent > > +* > > +**/ > > + > > +#ifndef MEMORY_INIT_PEI_LIB_H_ > > +#define MEMORY_INIT_PEI_LIB_H_ > > + > > +#include > > + > > +// Specifies the Maximum regions onto which DDR memory can be mapped i= n > > +// a Platform > > +#define MAX_DRAM_REGIONS 3 > > +#define SMC_DRAM_BANK_INFO (0xC200FF12) > > + > > +typedef struct { > > + UINTN BaseAddress; > > + UINTN Size; > > +} DRAM_REGION_INFO; > > + > > +#endif // MEMORY_INIT_PEI_LIB_H_ > > + > > diff --git a/Silicon/NXP/Library/MemoryInitPei/MemoryInitPeiLib.inf > b/Silicon/NXP/Library/MemoryInitPei/MemoryInitPeiLib.inf > > index a5bd39415def..ad2371115b17 100644 > > --- a/Silicon/NXP/Library/MemoryInitPei/MemoryInitPeiLib.inf > > +++ b/Silicon/NXP/Library/MemoryInitPei/MemoryInitPeiLib.inf > > @@ -18,7 +18,6 @@ [Defines] > > [Sources] > > MemoryInitPeiLib.c > > > > - > > [Packages] > > ArmPkg/ArmPkg.dec > > ArmPlatformPkg/ArmPlatformPkg.dec > > @@ -30,6 +29,7 @@ [Packages] > > [LibraryClasses] > > ArmMmuLib > > ArmPlatformLib > > + ArmSmcLib > > DebugLib > > HobLib > > PcdLib > > @@ -40,6 +40,11 @@ [Guids] > > [FeaturePcd] > > gEmbeddedTokenSpaceGuid.PcdPrePiProduceMemoryTypeInformationHob > > > > +[FixedPcd] > > + gArmTokenSpaceGuid.PcdFdBaseAddress > > + gArmTokenSpaceGuid.PcdFdSize > > + gArmPlatformTokenSpaceGuid.PcdSystemMemoryUefiRegionSize > > + > > [Pcd] > > gArmTokenSpaceGuid.PcdSystemMemoryBase > > gArmTokenSpaceGuid.PcdSystemMemorySize > > diff --git a/Silicon/NXP/Library/SocLib/Chassis.c > b/Silicon/NXP/Library/SocLib/Chassis.c > > index 847331a63152..1ef99e8de25f 100644 > > --- a/Silicon/NXP/Library/SocLib/Chassis.c > > +++ b/Silicon/NXP/Library/SocLib/Chassis.c > > @@ -22,7 +22,6 @@ > > #include > > #include > > > > -#include > > #include "NxpChassis.h" > > > > UINT32 > > @@ -75,69 +74,3 @@ SmmuInit ( > > MmioWrite32 ((UINTN)SMMU_REG_NSCR0, Value); > > } > > > > -UINTN > > -GetDramSize ( > > - IN VOID > > - ) > > -{ > > - ARM_SMC_ARGS ArmSmcArgs; > > - > > - ArmSmcArgs.Arg0 =3D SMC_DRAM_BANK_INFO; > > - ArmSmcArgs.Arg1 =3D -1; > > - > > - ArmCallSmc (&ArmSmcArgs); > > - > > - if (ArmSmcArgs.Arg0) { > > - return 0; > > - } else { > > - return ArmSmcArgs.Arg1; > > - } > > -} > > - > > -EFI_STATUS > > -GetDramBankInfo ( > > - IN OUT DRAM_INFO *DramInfo > > - ) > > -{ > > - ARM_SMC_ARGS ArmSmcArgs; > > - UINT32 I; > > - UINTN DramSize; > > - > > - DramSize =3D GetDramSize (); > > - DEBUG ((DEBUG_INFO, "DRAM Total Size 0x%lx \n", DramSize)); > > - > > - // Ensure DramSize has been set > > - ASSERT (DramSize !=3D 0); > > - > > - I =3D 0; > > - > > - do { > > - ArmSmcArgs.Arg0 =3D SMC_DRAM_BANK_INFO; > > - ArmSmcArgs.Arg1 =3D I; > > - > > - ArmCallSmc (&ArmSmcArgs); > > - if (ArmSmcArgs.Arg0) { > > - if (I > 0) { > > - break; > > - } else { > > - ASSERT (ArmSmcArgs.Arg0 =3D=3D 0); > > - } > > - } > > - > > - DramInfo->DramRegion[I].BaseAddress =3D ArmSmcArgs.Arg1; > > - DramInfo->DramRegion[I].Size =3D ArmSmcArgs.Arg2; > > - > > - DramSize -=3D DramInfo->DramRegion[I].Size; > > - > > - DEBUG ((DEBUG_INFO, "bank[%d]: start 0x%lx, size 0x%lx\n", > > - I, DramInfo->DramRegion[I].BaseAddress, DramInfo- > >DramRegion[I].Size)); > > - > > - I++; > > - } while (DramSize); > > - > > - DramInfo->NumOfDrams =3D I; > > - > > - DEBUG ((DEBUG_INFO, "Number Of DRAM in system %d \n", DramInfo- > >NumOfDrams)); > > - > > - return EFI_SUCCESS; > > -} > > diff --git a/Silicon/NXP/Library/SocLib/LS1043aSocLib.inf > b/Silicon/NXP/Library/SocLib/LS1043aSocLib.inf > > index b7c7fc78cc8f..99d89498e0e2 100644 > > --- a/Silicon/NXP/Library/SocLib/LS1043aSocLib.inf > > +++ b/Silicon/NXP/Library/SocLib/LS1043aSocLib.inf > > @@ -20,7 +20,6 @@ [Packages] > > Silicon/NXP/NxpQoriqLs.dec > > > > [LibraryClasses] > > - ArmSmcLib > > BaseLib > > DebugLib > > IoAccessLib > > -- > > 2.17.1 > >