Reviewed-by: Hao Wu <hao.a...@intel.com>

Best Regards,
Hao Wu


> -----Original Message-----
> From: Chen, Chen A
> Sent: Wednesday, June 13, 2018 11:44 AM
> To: edk2-devel@lists.01.org
> Cc: Chen, Chen A; Ni, Ruiyu; Wu, Hao A; Kinney, Michael D
> Subject: [PATCH 09/37] DuetPkg: Removing ipf which is no longer supported
> from edk2.
> 
> Removing rules for Ipf sources file:
> * Remove the source file which path with "ipf" and also listed in
>   [Sources.IPF] section of INF file.
> * Remove the source file which listed in [Components.IPF] section
>   of DSC file and not listed in any other [Components] section.
> * Remove the embedded Ipf code for MDE_CPU_IPF.
> 
> Removing rules for Inf file:
> * Remove IPF from VALID_ARCHITECTURES comments.
> * Remove DXE_SAL_DRIVER from LIBRARY_CLASS in [Defines] section.
> * Remove the INF which only listed in [Components.IPF] section in DSC.
> * Remove statements from [BuildOptions] that provide IPF specific flags.
> * Remove any IPF sepcific sections.
> 
> Removing rules for Dec file:
> * Remove [Includes.IPF] section from Dec.
> 
> Removing rules for Dsc file:
> * Remove IPF from SUPPORTED_ARCHITECTURES in [Defines] section of DSC.
> * Remove any IPF specific sections.
> * Remove statements from [BuildOptions] that provide IPF specific flags.
> 
> Cc: Ruiyu Ni <ruiyu...@intel.com>
> Cc: Hao Wu <hao.a...@intel.com>
> Cc: Michael D Kinney <michael.d.kin...@intel.com>
> Signed-off-by: chenc2 <chen.a.c...@intel.com>
> Contributed-under: TianoCore Contribution Agreement 1.1
> ---
>  DuetPkg/EfiLdr/PeLoader.c                          |   6 -
>  .../DxeCoreReportStatusCodeLibFromHob.inf          |   2 +-
>  DuetPkg/PciRootBridgeNoEnumerationDxe/Ipf/PcatIo.c | 459 
> ---------------------
>  .../PciRootBridgeNoEnumeration.inf                 |   3 -
>  DuetPkg/SataControllerDxe/SataControllerDxe.inf    |   2 +-
>  5 files changed, 2 insertions(+), 470 deletions(-)
>  delete mode 100644 DuetPkg/PciRootBridgeNoEnumerationDxe/Ipf/PcatIo.c
> 
> diff --git a/DuetPkg/EfiLdr/PeLoader.c b/DuetPkg/EfiLdr/PeLoader.c
> index 7fafdfb14b..8f71b22531 100644
> --- a/DuetPkg/EfiLdr/PeLoader.c
> +++ b/DuetPkg/EfiLdr/PeLoader.c
> @@ -630,12 +630,6 @@ EfiLdrPeCoffCheckImageMachineType (
>    }
>  #endif
> 
> -#ifdef MDE_CPU_IPF
> -  if (MachineType == EFI_IMAGE_MACHINE_IA64) {
> -    Status = EFI_SUCCESS;
> -  }
> -#endif
> -
>    return Status;
>  }
> 
> diff --git
> a/DuetPkg/Library/DxeCoreReportStatusCodeLibFromHob/DxeCoreReportStatu
> sCodeLibFromHob.inf
> b/DuetPkg/Library/DxeCoreReportStatusCodeLibFromHob/DxeCoreReportStatu
> sCodeLibFromHob.inf
> index 9b4649c7d5..14381b6f70 100644
> ---
> a/DuetPkg/Library/DxeCoreReportStatusCodeLibFromHob/DxeCoreReportStatu
> sCodeLibFromHob.inf
> +++
> b/DuetPkg/Library/DxeCoreReportStatusCodeLibFromHob/DxeCoreReportStatu
> sCodeLibFromHob.inf
> @@ -29,7 +29,7 @@
>  #
>  # The following information is for reference only and not required by the 
> build
> tools.
>  #
> -#  VALID_ARCHITECTURES           = IA32 X64 IPF EBC
> +#  VALID_ARCHITECTURES           = IA32 X64 EBC
>  #
> 
>  [Sources]
> diff --git a/DuetPkg/PciRootBridgeNoEnumerationDxe/Ipf/PcatIo.c
> b/DuetPkg/PciRootBridgeNoEnumerationDxe/Ipf/PcatIo.c
> deleted file mode 100644
> index 97857c2981..0000000000
> --- a/DuetPkg/PciRootBridgeNoEnumerationDxe/Ipf/PcatIo.c
> +++ /dev/null
> @@ -1,459 +0,0 @@
> -/*++
> -
> -Copyright (c) 2005 - 2012, Intel Corporation. All rights reserved.<BR>
> -This program and the accompanying materials
> -are licensed and made available under the terms and conditions of the BSD
> License
> -which accompanies this distribution.  The full text of the license may be 
> found
> at
> -http://opensource.org/licenses/bsd-license.php
> -
> -THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
> -WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS
> OR IMPLIED.
> -
> -Module Name:
> -    PcatPciRootBridgeIo.c
> -
> -Abstract:
> -
> -    EFI PC AT PCI Root Bridge Io Protocol
> -
> -Revision History
> -
> ---*/
> -
> -#include "PcatPciRootBridge.h"
> -#include <IndustryStandard/Pci.h>
> -#include "SalProc.h"
> -
> -#include EFI_GUID_DEFINITION (SalSystemTable)
> -
> -//
> -// Might be good to put this in an include file, but people may start
> -//  using it! They should always access the EFI abstraction that is
> -//  contained in this file. Just a little information hiding.
> -//
> -#define PORT_TO_MEM(_Port) ( ((_Port) & 0xffffffffffff0000) | (((_Port) &
> 0xfffc) << 10) | ((_Port) & 0x0fff) )
> -
> -//
> -// Macro's with casts make this much easier to use and read.
> -//
> -#define PORT_TO_MEM8(_Port)     (*(UINT8  *)(PORT_TO_MEM(_Port)))
> -#define PORT_TO_MEM16(_Port)    (*(UINT16 *)(PORT_TO_MEM(_Port)))
> -#define PORT_TO_MEM32(_Port)    (*(UINT32 *)(PORT_TO_MEM(_Port)))
> -
> -#define EFI_PCI_ADDRESS_IA64(_seg, _bus,_dev,_func,_reg) \
> -    ( (UINT64) ( (((UINTN)_seg) << 24) + (((UINTN)_bus) << 16) + 
> (((UINTN)_dev)
> << 11) + (((UINTN)_func) << 8) + ((UINTN)_reg)) )
> -
> -//
> -// Local variables for performing SAL Proc calls
> -//
> -PLABEL         mSalProcPlabel;
> -CALL_SAL_PROC  mGlobalSalProc;
> -
> -EFI_STATUS
> -PcatRootBridgeIoIoRead (
> -  IN     EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL        *This,
> -  IN     EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL_WIDTH  Width,
> -  IN     UINT64                                 UserAddress,
> -  IN     UINTN                                  Count,
> -  IN OUT VOID                                   *UserBuffer
> -  )
> -{
> -  PCAT_PCI_ROOT_BRIDGE_INSTANCE *PrivateData;
> -  UINTN                         InStride;
> -  UINTN                         OutStride;
> -  UINTN                         AlignMask;
> -  UINTN                         Address;
> -  PTR                           Buffer;
> -  UINT16                        Data16;
> -  UINT32                        Data32;
> -
> -
> -  if ( UserBuffer == NULL ) {
> -    return EFI_INVALID_PARAMETER;
> -  }
> -
> -  PrivateData = DRIVER_INSTANCE_FROM_PCI_ROOT_BRIDGE_IO_THIS(This);
> -
> -  Address    = (UINTN)  UserAddress;
> -  Buffer.buf = (UINT8 *)UserBuffer;
> -
> -  if ( Address < PrivateData->IoBase || Address > PrivateData->IoLimit ) {
> -    return EFI_INVALID_PARAMETER;
> -  }
> -
> -  if ((UINT32)Width >= EfiPciWidthMaximum) {
> -    return EFI_INVALID_PARAMETER;
> -  }
> -
> -  if ((Width & 0x03) == EfiPciWidthUint64) {
> -    return EFI_INVALID_PARAMETER;
> -  }
> -
> -  AlignMask = (1 << (Width & 0x03)) - 1;
> -  if ( Address & AlignMask ) {
> -    return EFI_INVALID_PARAMETER;
> -  }
> -
> -  InStride  = 1 << (Width & 0x03);
> -  OutStride = InStride;
> -  if (Width >=EfiPciWidthFifoUint8 && Width <= EfiPciWidthFifoUint64) {
> -    InStride = 0;
> -  }
> -  if (Width >=EfiPciWidthFillUint8 && Width <= EfiPciWidthFillUint64) {
> -    OutStride = 0;
> -  }
> -  Width = Width & 0x03;
> -
> -  Address += PrivateData->PhysicalIoBase;
> -
> -  //
> -  // Loop for each iteration and move the data
> -  //
> -
> -  switch (Width) {
> -  case EfiPciWidthUint8:
> -    for (; Count > 0; Count--, Buffer.buf += OutStride, Address += InStride) 
> {
> -      MEMORY_FENCE();
> -      *Buffer.ui8 = PORT_TO_MEM8(Address);
> -      MEMORY_FENCE();
> -    }
> -    break;
> -
> -  case EfiPciWidthUint16:
> -    for (; Count > 0; Count--, Buffer.buf += OutStride, Address += InStride) 
> {
> -      MEMORY_FENCE();
> -      if (Buffer.ui & 0x1) {
> -        Data16 = PORT_TO_MEM16(Address);
> -        *Buffer.ui8     = (UINT8)(Data16 & 0xff);
> -        *(Buffer.ui8+1) = (UINT8)((Data16 >> 8) & 0xff);
> -      } else {
> -        *Buffer.ui16 = PORT_TO_MEM16(Address);
> -      }
> -      MEMORY_FENCE();
> -    }
> -    break;
> -
> -  case EfiPciWidthUint32:
> -    for (; Count > 0; Count--, Buffer.buf += OutStride, Address += InStride) 
> {
> -      MEMORY_FENCE();
> -      if (Buffer.ui & 0x3) {
> -        Data32 = PORT_TO_MEM32(Address);
> -        *Buffer.ui8     = (UINT8)(Data32 & 0xff);
> -        *(Buffer.ui8+1) = (UINT8)((Data32 >> 8) & 0xff);
> -        *(Buffer.ui8+2) = (UINT8)((Data32 >> 16) & 0xff);
> -        *(Buffer.ui8+3) = (UINT8)((Data32 >> 24) & 0xff);
> -      } else {
> -        *Buffer.ui32 = PORT_TO_MEM32(Address);
> -      }
> -      MEMORY_FENCE();
> -    }
> -    break;
> -  }
> -
> -  return EFI_SUCCESS;
> -}
> -
> -EFI_STATUS
> -PcatRootBridgeIoIoWrite (
> -  IN EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL        *This,
> -  IN EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL_WIDTH  Width,
> -  IN UINT64                                 UserAddress,
> -  IN UINTN                                  Count,
> -  IN OUT VOID                               *UserBuffer
> -  )
> -{
> -  PCAT_PCI_ROOT_BRIDGE_INSTANCE  *PrivateData;
> -  UINTN                          InStride;
> -  UINTN                          OutStride;
> -  UINTN                          AlignMask;
> -  UINTN                          Address;
> -  PTR                            Buffer;
> -  UINT16                         Data16;
> -  UINT32                         Data32;
> -
> -  if ( UserBuffer == NULL ) {
> -    return EFI_INVALID_PARAMETER;
> -  }
> -
> -  PrivateData = DRIVER_INSTANCE_FROM_PCI_ROOT_BRIDGE_IO_THIS(This);
> -
> -  Address    = (UINTN)  UserAddress;
> -  Buffer.buf = (UINT8 *)UserBuffer;
> -
> -  if ( Address < PrivateData->IoBase || Address > PrivateData->IoLimit ) {
> -    return EFI_INVALID_PARAMETER;
> -  }
> -
> -  if (Width < 0 || Width >= EfiPciWidthMaximum) {
> -    return EFI_INVALID_PARAMETER;
> -  }
> -
> -  if ((Width & 0x03) == EfiPciWidthUint64) {
> -    return EFI_INVALID_PARAMETER;
> -  }
> -
> -  AlignMask = (1 << (Width & 0x03)) - 1;
> -  if ( Address & AlignMask ) {
> -    return EFI_INVALID_PARAMETER;
> -  }
> -
> -  InStride  = 1 << (Width & 0x03);
> -  OutStride = InStride;
> -  if (Width >=EfiPciWidthFifoUint8 && Width <= EfiPciWidthFifoUint64) {
> -    InStride = 0;
> -  }
> -  if (Width >=EfiPciWidthFillUint8 && Width <= EfiPciWidthFillUint64) {
> -    OutStride = 0;
> -  }
> -  Width = Width & 0x03;
> -
> -  Address += PrivateData->PhysicalIoBase;
> -
> -  //
> -  // Loop for each iteration and move the data
> -  //
> -
> -  switch (Width) {
> -  case EfiPciWidthUint8:
> -    for (; Count > 0; Count--, Buffer.buf += OutStride, Address += InStride) 
> {
> -      MEMORY_FENCE();
> -      PORT_TO_MEM8(Address) = *Buffer.ui8;
> -      MEMORY_FENCE();
> -    }
> -    break;
> -
> -  case EfiPciWidthUint16:
> -    for (; Count > 0; Count--, Buffer.buf += OutStride, Address += InStride) 
> {
> -      MEMORY_FENCE();
> -      if (Buffer.ui & 0x1) {
> -        Data16 = *Buffer.ui8;
> -        Data16 = Data16 | (*(Buffer.ui8+1) << 8);
> -        PORT_TO_MEM16(Address) = Data16;
> -      } else {
> -        PORT_TO_MEM16(Address) = *Buffer.ui16;
> -      }
> -      MEMORY_FENCE();
> -    }
> -    break;
> -  case EfiPciWidthUint32:
> -    for (; Count > 0; Count--, Buffer.buf += OutStride, Address += InStride) 
> {
> -      MEMORY_FENCE();
> -      if (Buffer.ui & 0x3) {
> -        Data32 = *Buffer.ui8;
> -        Data32 = Data32 | (*(Buffer.ui8+1) << 8);
> -        Data32 = Data32 | (*(Buffer.ui8+2) << 16);
> -        Data32 = Data32 | (*(Buffer.ui8+3) << 24);
> -        PORT_TO_MEM32(Address) = Data32;
> -      } else {
> -        PORT_TO_MEM32(Address) = *Buffer.ui32;
> -      }
> -      MEMORY_FENCE();
> -    }
> -    break;
> -  }
> -
> -  return EFI_SUCCESS;
> -}
> -
> -EFI_STATUS
> -PcatRootBridgeIoGetIoPortMapping (
> -  OUT EFI_PHYSICAL_ADDRESS  *IoPortMapping,
> -  OUT EFI_PHYSICAL_ADDRESS  *MemoryPortMapping
> -  )
> -/*++
> -
> -  Get the IO Port Map from the SAL System Table.
> -
> ---*/
> -{
> -  SAL_SYSTEM_TABLE_ASCENDING_ORDER    *SalSystemTable;
> -  SAL_ST_MEMORY_DESCRIPTOR_ENTRY      *SalMemDesc;
> -  EFI_STATUS                          Status;
> -
> -  //
> -  // On all Itanium architectures, bit 63 is the I/O bit for performming 
> Memory
> Mapped I/O operations
> -  //
> -  *MemoryPortMapping = 0x8000000000000000;
> -
> -  Status = EfiLibGetSystemConfigurationTable(&gEfiSalSystemTableGuid,
> &SalSystemTable);
> -  if (EFI_ERROR(Status)) {
> -    return EFI_NOT_FOUND;
> -  }
> -
> -  //
> -  // BugBug: Add code to test checksum on the Sal System Table
> -  //
> -  if (SalSystemTable->Entry0.Type != 0) {
> -    return EFI_UNSUPPORTED;
> -  }
> -
> -  mSalProcPlabel.ProcEntryPoint = SalSystemTable->Entry0.SalProcEntry;
> -  mSalProcPlabel.GP             = SalSystemTable->Entry0.GlobalDataPointer;
> -  mGlobalSalProc                =
> (CALL_SAL_PROC)&mSalProcPlabel.ProcEntryPoint;
> -
> -  //
> -  // The SalSystemTable pointer includes the Type 0 entry.
> -  //  The SalMemDesc is Type 1 so it comes next.
> -  //
> -  SalMemDesc = (SAL_ST_MEMORY_DESCRIPTOR_ENTRY *)(SalSystemTable +
> 1);
> -  while (SalMemDesc->Type == SAL_ST_MEMORY_DESCRIPTOR) {
> -    if (SalMemDesc->MemoryType == SAL_IO_PORT_MAPPING) {
> -      *IoPortMapping = SalMemDesc->PhysicalMemoryAddress;
> -      *IoPortMapping |= 0x8000000000000000;
> -      return EFI_SUCCESS;
> -    }
> -    SalMemDesc++;
> -  }
> -  return EFI_UNSUPPORTED;
> -}
> -
> -EFI_STATUS
> -PcatRootBridgeIoPciRW (
> -  IN     EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL        *This,
> -  IN     BOOLEAN                                Write,
> -  IN     EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL_WIDTH  Width,
> -  IN     UINT64                                 UserAddress,
> -  IN     UINTN                                  Count,
> -  IN OUT UINT8                                  *UserBuffer
> -  )
> -{
> -  PCAT_PCI_ROOT_BRIDGE_INSTANCE  *PrivateData;
> -  UINTN                          AlignMask;
> -  UINTN                          InStride;
> -  UINTN                          OutStride;
> -  UINT64                         Address;
> -  DEFIO_PCI_ADDR                 *Defio;
> -  PTR                            Buffer;
> -  UINT32                         Data32;
> -  UINT16                         Data16;
> -  rArg                           Return;
> -
> -  if (Width < 0 || Width >= EfiPciWidthMaximum) {
> -    return EFI_INVALID_PARAMETER;
> -  }
> -
> -  if ((Width & 0x03) == EfiPciWidthUint64) {
> -    return EFI_INVALID_PARAMETER;
> -  }
> -
> -  AlignMask = (1 << (Width & 0x03)) - 1;
> -  if ( UserAddress & AlignMask ) {
> -    return EFI_INVALID_PARAMETER;
> -  }
> -
> -  InStride  = 1 << (Width & 0x03);
> -  OutStride = InStride;
> -  if (Width >=EfiPciWidthFifoUint8 && Width <= EfiPciWidthFifoUint64) {
> -    InStride = 0;
> -  }
> -  if (Width >=EfiPciWidthFillUint8 && Width <= EfiPciWidthFillUint64) {
> -    OutStride = 0;
> -  }
> -  Width = Width & 0x03;
> -
> -  Defio = (DEFIO_PCI_ADDR *)&UserAddress;
> -
> -  if ((Defio->Function > PCI_MAX_FUNC) || (Defio->Device >
> PCI_MAX_DEVICE)) {
> -    return EFI_UNSUPPORTED;
> -  }
> -
> -  Buffer.buf = (UINT8 *)UserBuffer;
> -
> -  PrivateData = DRIVER_INSTANCE_FROM_PCI_ROOT_BRIDGE_IO_THIS(This);
> -
> -  Address = EFI_PCI_ADDRESS_IA64(
> -              This->SegmentNumber,
> -              Defio->Bus,
> -              Defio->Device,
> -              Defio->Function,
> -              Defio->Register
> -              );
> -
> -  //
> -  // PCI Config access are all 32-bit alligned, but by accessing the
> -  //  CONFIG_DATA_REGISTER (0xcfc) with different widths more cycle types
> -  //  are possible on PCI.
> -  //
> -  // SalProc takes care of reading the proper register depending on stride
> -  //
> -
> -  EfiAcquireLock(&PrivateData->PciLock);
> -
> -  while (Count) {
> -
> -    if(Write) {
> -
> -      if (Buffer.ui & 0x3) {
> -        Data32  = (*(Buffer.ui8+0) << 0);
> -        Data32 |= (*(Buffer.ui8+1) << 8);
> -        Data32 |= (*(Buffer.ui8+2) << 16);
> -        Data32 |= (*(Buffer.ui8+3) << 24);
> -      } else {
> -        Data32 = *Buffer.ui32;
> -      }
> -
> -      Return.p0 = -3;
> -      Return    = mGlobalSalProc((UINT64) SAL_PCI_CONFIG_WRITE,
> -                                 Address, 1 << Width, Data32, 0, 0, 0, 0);
> -
> -      if(Return.p0) {
> -        EfiReleaseLock(&PrivateData->PciLock);
> -        return EFI_UNSUPPORTED;
> -      }
> -
> -    } else {
> -
> -      Return.p0 = -3;
> -      Return    = mGlobalSalProc((UINT64) SAL_PCI_CONFIG_READ,
> -                                 Address, 1 << Width, 0, 0, 0, 0, 0);
> -
> -      if(Return.p0) {
> -        EfiReleaseLock(&PrivateData->PciLock);
> -        return EFI_UNSUPPORTED;
> -      }
> -
> -      switch (Width) {
> -      case EfiPciWidthUint8:
> -        *Buffer.ui8 = (UINT8)Return.p1;
> -        break;
> -      case EfiPciWidthUint16:
> -        if (Buffer.ui & 0x1) {
> -          Data16 = (UINT16)Return.p1;
> -          *(Buffer.ui8 + 0) = Data16 & 0xff;
> -          *(Buffer.ui8 + 1) = (Data16 >> 8) & 0xff;
> -        } else {
> -          *Buffer.ui16 = (UINT16)Return.p1;
> -        }
> -        break;
> -      case EfiPciWidthUint32:
> -        if (Buffer.ui & 0x3) {
> -          Data32 = (UINT32)Return.p1;
> -          *(Buffer.ui8 + 0) = (UINT8)(Data32 & 0xff);
> -          *(Buffer.ui8 + 1) = (UINT8)((Data32 >> 8) & 0xff);
> -          *(Buffer.ui8 + 2) = (UINT8)((Data32 >> 16) & 0xff);
> -          *(Buffer.ui8 + 3) = (UINT8)((Data32 >> 24) & 0xff);
> -        } else {
> -          *Buffer.ui32 = (UINT32)Return.p1;
> -        }
> -        break;
> -      }
> -    }
> -
> -    Address += InStride;
> -    Buffer.buf += OutStride;
> -    Count -= 1;
> -  }
> -
> -  EfiReleaseLock(&PrivateData->PciLock);
> -
> -  return EFI_SUCCESS;
> -}
> -
> -EFI_STATUS
> -ScanPciRootBridgeForRoms(
> -  EFI_PCI_ROOT_BRIDGE_IO_PROTOCOL  *IoDev
> -  )
> -
> -{
> -  return EFI_UNSUPPORTED;
> -}
> diff --git
> a/DuetPkg/PciRootBridgeNoEnumerationDxe/PciRootBridgeNoEnumeration.inf
> b/DuetPkg/PciRootBridgeNoEnumerationDxe/PciRootBridgeNoEnumeration.inf
> index 8f7ef1b17d..b7d9c51546 100644
> ---
> a/DuetPkg/PciRootBridgeNoEnumerationDxe/PciRootBridgeNoEnumeration.inf
> +++
> b/DuetPkg/PciRootBridgeNoEnumerationDxe/PciRootBridgeNoEnumeration.inf
> @@ -53,9 +53,6 @@
>  [Sources.x64]
>    X64/PcatIo.c
> 
> -[Sources.ipf]
> -  Ipf/PcatIo.c
> -
>  [Protocols]
>    gEfiPciRootBridgeIoProtocolGuid
>    gEfiDeviceIoProtocolGuid
> diff --git a/DuetPkg/SataControllerDxe/SataControllerDxe.inf
> b/DuetPkg/SataControllerDxe/SataControllerDxe.inf
> index b3b37ddd0e..3608956f57 100644
> --- a/DuetPkg/SataControllerDxe/SataControllerDxe.inf
> +++ b/DuetPkg/SataControllerDxe/SataControllerDxe.inf
> @@ -24,7 +24,7 @@
>  #
>  # The following information is for reference only and not required by the 
> build
> tools.
>  #
> -#  VALID_ARCHITECTURES           = IA32 X64 IPF EBC
> +#  VALID_ARCHITECTURES           = IA32 X64 EBC
>  #
> 
>  [Sources]
> --
> 2.16.2.windows.1

_______________________________________________
edk2-devel mailing list
edk2-devel@lists.01.org
https://lists.01.org/mailman/listinfo/edk2-devel

Reply via email to