]> git.proxmox.com Git - mirror_edk2.git/commitdiff
Gcc versions of the msa files. These files can be used in place of the normal msa...
authorbbahnsen <bbahnsen@6f19259b-4bc3-4df7-8a09-765794883524>
Wed, 24 May 2006 21:32:36 +0000 (21:32 +0000)
committerbbahnsen <bbahnsen@6f19259b-4bc3-4df7-8a09-765794883524>
Wed, 24 May 2006 21:32:36 +0000 (21:32 +0000)
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@270 6f19259b-4bc3-4df7-8a09-765794883524

MdePkg/Library/BaseLib/BaseLib-Gcc.msa [new file with mode: 0644]
MdePkg/Library/BaseMemoryLibMmx/BaseMemoryLibMmx-Gcc.msa [new file with mode: 0644]
MdePkg/Library/BaseMemoryLibRepStr/BaseMemoryLibRepStr-Gcc.msa [new file with mode: 0644]
MdePkg/Library/BaseMemoryLibSse2/BaseMemoryLibSse2-Gcc.msa [new file with mode: 0644]

diff --git a/MdePkg/Library/BaseLib/BaseLib-Gcc.msa b/MdePkg/Library/BaseLib/BaseLib-Gcc.msa
new file mode 100644 (file)
index 0000000..ff1f4a2
--- /dev/null
@@ -0,0 +1,312 @@
+<?xml version="1.0" encoding="UTF-8"?>\r
+<!--\r
+Copyright (c) 2006, Intel Corporation\r
+All rights reserved. This program and the accompanying materials\r
+are licensed and made available under the terms and conditions of the BSD License\r
+which accompanies this distribution.  The full text of the license may be found at\r
+http://opensource.org/licenses/bsd-license.php\r
+\r
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+-->\r
+<LibraryModuleSurfaceArea xmlns="http://www.TianoCore.org/2006/Edk2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.TianoCore.org/2006/Edk2.0  http://www.TianoCore.org/2006/Edk2.0/SurfaceArea.xsd">\r
+  <MsaLibHeader>\r
+    <BaseName>BaseLib</BaseName>\r
+    <ModuleType>BASE</ModuleType>\r
+    <ComponentType>LIBRARY</ComponentType>\r
+    <Guid>27d67720-ea68-48ae-93da-a3a074c90e30</Guid>\r
+    <Version>0</Version>\r
+    <Abstract>Memory-only library functions with no library constructordestructor</Abstract>\r
+    <Description>FIX ME!</Description>\r
+    <Copyright>Copyright (c) 2004-2006, Intel Corporation</Copyright>\r
+    <License>\r
+      All rights reserved. This program and the accompanying materials\r
+      are licensed and made available under the terms and conditions of the BSD License\r
+      which accompanies this distribution.  The full text of the license may be found at\r
+      http://opensource.org/licenses/bsd-license.php\r
+      THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+      WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+    </License>\r
+    <Specification>0</Specification>\r
+    <Created>2006-03-09 23:16</Created>\r
+    <Updated>2006-03-22 18:15</Updated>\r
+  </MsaLibHeader>\r
+  <LibraryClassDefinitions>\r
+    <LibraryClass Usage="ALWAYS_PRODUCED">BaseLib</LibraryClass>\r
+    <LibraryClass Usage="ALWAYS_CONSUMED">BaseMemoryLib</LibraryClass>\r
+    <LibraryClass Usage="ALWAYS_CONSUMED">DebugLib</LibraryClass>\r
+    <LibraryClass Usage="ALWAYS_CONSUMED">TimerLib</LibraryClass>\r
+  </LibraryClassDefinitions>\r
+  <SourceFiles>\r
+    <Filename>String.c</Filename>\r
+    <Filename>LinkedList.c</Filename>\r
+    <Filename>Synchronization.c</Filename>\r
+    <Filename>Cpu.c</Filename>\r
+    <Filename>CpuDeadLoop.c</Filename>\r
+    <Filename>BitField.c</Filename>\r
+    <Filename>ARShiftU64.c</Filename>\r
+    <Filename>DivS64x64Remainder.c</Filename>\r
+    <Filename>DivU64x32.c</Filename>\r
+    <Filename>DivU64x32Remainder.c</Filename>\r
+    <Filename>DivU64x64Remainder.c</Filename>\r
+    <Filename>GetPowerOfTwo32.c</Filename>\r
+    <Filename>GetPowerOfTwo64.c</Filename>\r
+    <Filename>HighBitSet32.c</Filename>\r
+    <Filename>HighBitSet64.c</Filename>\r
+    <Filename>LowBitSet32.c</Filename>\r
+    <Filename>LowBitSet64.c</Filename>\r
+    <Filename>LRotU32.c</Filename>\r
+    <Filename>LRotU64.c</Filename>\r
+    <Filename>LShiftU64.c</Filename>\r
+    <Filename>ModU64x32.c</Filename>\r
+    <Filename>MultS64x64.c</Filename>\r
+    <Filename>MultU64x32.c</Filename>\r
+    <Filename>MultU64x64.c</Filename>\r
+    <Filename>RRotU32.c</Filename>\r
+    <Filename>RRotU64.c</Filename>\r
+    <Filename>RShiftU64.c</Filename>\r
+    <Filename>SwapBytes16.c</Filename>\r
+    <Filename>SwapBytes32.c</Filename>\r
+    <Filename>SwapBytes64.c</Filename>\r
+    <Arch ArchType="IA32">\r
+      <Filename>x86LowLevel.c</Filename>\r
+      <Filename>x86Thunk.c</Filename>\r
+      <Filename>Unaligned.c</Filename>\r
+      <Filename>Ia32/Non-existing.c</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/LShiftU64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/RShiftU64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ARShiftU64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/LRotU64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/RRotU64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/MultU64x32.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/MultU64x64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/DivU64x32.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ModU64x32.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/DivU64x32Remainder.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/DivU64x64Remainder.s</Filename>\r
+      <Filename>Ia32/DivS64x64Remainder.c</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SwapBytes64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SetJump.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/LongJump.s</Filename>\r
+      <Filename>Ia32/SwitchStack.c</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/CpuId.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadEflags.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadMsr64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteMsr32.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteMsr64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadCr0.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadCr2.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadCr3.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadCr4.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteCr0.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteCr2.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteCr3.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteCr4.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadDr0.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadDr1.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadDr2.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadDr3.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadDr4.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadDr5.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadDr6.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadDr7.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteDr0.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteDr1.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteDr2.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteDr3.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteDr4.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteDr5.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteDr6.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteDr7.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadCs.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadDs.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadEs.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadFs.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadGs.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadSs.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadTr.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadGdtr.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteGdtr.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadIdtr.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteIdtr.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadLdtr.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteLdtr.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/FxSave.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/FxRestore.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadMm0.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadMm1.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadMm2.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadMm3.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadMm4.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadMm5.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadMm6.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadMm7.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteMm0.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteMm1.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteMm2.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteMm3.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteMm4.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteMm5.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteMm6.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/WriteMm7.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadTsc.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ReadPmc.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/Monitor.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/Mwait.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/EnablePaging32.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/DisablePaging32.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/EnablePaging64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/Wbinvd.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/Invd.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/FlushCacheLine.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/InterlockedIncrement.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/InterlockedDecrement.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/InterlockedCompareExchange32.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/InterlockedCompareExchange64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/EnableInterrupts.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/DisableInterrupts.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/EnableDisableInterrupts.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/CpuSleep.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/CpuPause.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/CpuBreakpoint.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/CpuFlushTlb.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/Thunk16.s</Filename>\r
+    </Arch>\r
+    <Arch ArchType="X64">\r
+      <Filename>x86LowLevel.c</Filename>\r
+      <Filename>x86Thunk.c</Filename>\r
+      <Filename>Unaligned.c</Filename>\r
+      <Filename>Math64.c</Filename>\r
+      <Filename>x64/Non-existing.c</Filename>\r
+      <Filename>x64/SwitchStack.asm</Filename>\r
+      <Filename>x64/SetJump.asm</Filename>\r
+      <Filename>x64/LongJump.asm</Filename>\r
+      <Filename>x64/CpuId.asm</Filename>\r
+      <Filename>x64/ReadEflags.asm</Filename>\r
+      <Filename>x64/ReadMsr32.asm</Filename>\r
+      <Filename>x64/ReadMsr64.asm</Filename>\r
+      <Filename>x64/WriteMsr32.asm</Filename>\r
+      <Filename>x64/WriteMsr64.asm</Filename>\r
+      <Filename>x64/ReadCr0.asm</Filename>\r
+      <Filename>x64/ReadCr2.asm</Filename>\r
+      <Filename>x64/ReadCr3.asm</Filename>\r
+      <Filename>x64/ReadCr4.asm</Filename>\r
+      <Filename>x64/WriteCr0.asm</Filename>\r
+      <Filename>x64/WriteCr2.asm</Filename>\r
+      <Filename>x64/WriteCr3.asm</Filename>\r
+      <Filename>x64/WriteCr4.asm</Filename>\r
+      <Filename>x64/ReadDr0.asm</Filename>\r
+      <Filename>x64/ReadDr1.asm</Filename>\r
+      <Filename>x64/ReadDr2.asm</Filename>\r
+      <Filename>x64/ReadDr3.asm</Filename>\r
+      <Filename>x64/ReadDr4.asm</Filename>\r
+      <Filename>x64/ReadDr5.asm</Filename>\r
+      <Filename>x64/ReadDr6.asm</Filename>\r
+      <Filename>x64/ReadDr7.asm</Filename>\r
+      <Filename>x64/WriteDr0.asm</Filename>\r
+      <Filename>x64/WriteDr1.asm</Filename>\r
+      <Filename>x64/WriteDr2.asm</Filename>\r
+      <Filename>x64/WriteDr3.asm</Filename>\r
+      <Filename>x64/WriteDr4.asm</Filename>\r
+      <Filename>x64/WriteDr5.asm</Filename>\r
+      <Filename>x64/WriteDr6.asm</Filename>\r
+      <Filename>x64/WriteDr7.asm</Filename>\r
+      <Filename>x64/ReadCs.asm</Filename>\r
+      <Filename>x64/ReadDs.asm</Filename>\r
+      <Filename>x64/ReadEs.asm</Filename>\r
+      <Filename>x64/ReadFs.asm</Filename>\r
+      <Filename>x64/ReadGs.asm</Filename>\r
+      <Filename>x64/ReadSs.asm</Filename>\r
+      <Filename>x64/ReadTr.asm</Filename>\r
+      <Filename>x64/ReadGdtr.asm</Filename>\r
+      <Filename>x64/WriteGdtr.asm</Filename>\r
+      <Filename>x64/ReadIdtr.asm</Filename>\r
+      <Filename>x64/WriteIdtr.asm</Filename>\r
+      <Filename>x64/ReadLdtr.asm</Filename>\r
+      <Filename>x64/WriteLdtr.asm</Filename>\r
+      <Filename>x64/FxSave.asm</Filename>\r
+      <Filename>x64/FxRestore.asm</Filename>\r
+      <Filename>x64/ReadMm0.asm</Filename>\r
+      <Filename>x64/ReadMm1.asm</Filename>\r
+      <Filename>x64/ReadMm2.asm</Filename>\r
+      <Filename>x64/ReadMm3.asm</Filename>\r
+      <Filename>x64/ReadMm4.asm</Filename>\r
+      <Filename>x64/ReadMm5.asm</Filename>\r
+      <Filename>x64/ReadMm6.asm</Filename>\r
+      <Filename>x64/ReadMm7.asm</Filename>\r
+      <Filename>x64/WriteMm0.asm</Filename>\r
+      <Filename>x64/WriteMm1.asm</Filename>\r
+      <Filename>x64/WriteMm2.asm</Filename>\r
+      <Filename>x64/WriteMm3.asm</Filename>\r
+      <Filename>x64/WriteMm4.asm</Filename>\r
+      <Filename>x64/WriteMm5.asm</Filename>\r
+      <Filename>x64/WriteMm6.asm</Filename>\r
+      <Filename>x64/WriteMm7.asm</Filename>\r
+      <Filename>x64/ReadTsc.asm</Filename>\r
+      <Filename>x64/ReadPmc.asm</Filename>\r
+      <Filename>x64/Monitor.asm</Filename>\r
+      <Filename>x64/Mwait.asm</Filename>\r
+      <Filename>x64/DisablePaging64.asm</Filename>\r
+      <Filename>x64/Wbinvd.asm</Filename>\r
+      <Filename>x64/Invd.asm</Filename>\r
+      <Filename>x64/FlushCacheLine.asm</Filename>\r
+      <Filename>x64/InterlockedIncrement.asm</Filename>\r
+      <Filename>x64/InterlockedDecrement.asm</Filename>\r
+      <Filename>x64/InterlockedCompareExchange32.asm</Filename>\r
+      <Filename>x64/InterlockedCompareExchange64.asm</Filename>\r
+      <Filename>x64/EnableInterrupts.asm</Filename>\r
+      <Filename>x64/DisableInterrupts.asm</Filename>\r
+      <Filename>x64/EnableDisableInterrupts.asm</Filename>\r
+      <Filename>x64/CpuSleep.asm</Filename>\r
+      <Filename>x64/CpuPause.asm</Filename>\r
+      <Filename>x64/CpuBreakpoint.asm</Filename>\r
+      <Filename>x64/CpuFlushTlb.asm</Filename>\r
+      <Filename>x64/Thunk16.asm</Filename>\r
+    </Arch>\r
+    <Arch ArchType="IPF">\r
+      <Filename>Math64.c</Filename>\r
+      <Filename>Ipf/setjmp.s</Filename>\r
+      <Filename>Ipf/SwitchStack.s</Filename>\r
+      <Filename>Ipf/Unaligned.c</Filename>\r
+      <Filename>Ipf/CpuBreakpoint.c</Filename>\r
+      <Filename>Ipf/InterlockedCompareExchange32.s</Filename>\r
+      <Filename>Ipf/InterlockedCompareExchange64.s</Filename>\r
+      <Filename>Ipf/Synchronization.c</Filename>\r
+      <Filename>Ipf/CpuPause.s</Filename>\r
+      <Filename>Ipf/CpuFlushTlb.s</Filename>\r
+    </Arch>\r
+    <Arch ArchType="EBC">\r
+      <Filename>Math64.c</Filename>\r
+      <Filename>SwitchStack.c</Filename>\r
+      <Filename>SetJumpLongJump.c</Filename>\r
+      <Filename>Unaligned.c</Filename>\r
+      <Filename>Ebc/CpuBreakpoint.c</Filename>\r
+      <Filename>Ebc/Synchronization.c</Filename>\r
+    </Arch>\r
+  </SourceFiles>\r
+ <Includes>\r
+    <PackageName>MdePkg</PackageName>\r
+  </Includes>\r
+  <PCDs>\r
+    <PcdData ItemType="FIXED_AT_BUILD">\r
+      <C_Name>PcdMaximumUnicodeStringLength</C_Name>\r
+      <Token>0x00000001</Token>\r
+      <DatumType>UINT32</DatumType>\r
+    </PcdData>\r
+    <PcdData ItemType="FIXED_AT_BUILD">\r
+      <C_Name>PcdMaximumAsciiStringLength</C_Name>\r
+      <Token>0x00000002</Token>\r
+      <DatumType>UINT32</DatumType>\r
+    </PcdData>\r
+    <PcdData ItemType="FIXED_AT_BUILD">\r
+      <C_Name>PcdMaximumLinkedListLength</C_Name>\r
+      <Token>0x00000003</Token>\r
+      <DatumType>UINT32</DatumType>\r
+    </PcdData>\r
+    <PcdData ItemType="FIXED_AT_BUILD">\r
+      <C_Name>PcdSpinLockTimeout</C_Name>\r
+      <Token>0x00000004</Token>\r
+      <DatumType>UINT32</DatumType>\r
+    </PcdData>\r
+  </PCDs>\r
+</LibraryModuleSurfaceArea>\r
diff --git a/MdePkg/Library/BaseMemoryLibMmx/BaseMemoryLibMmx-Gcc.msa b/MdePkg/Library/BaseMemoryLibMmx/BaseMemoryLibMmx-Gcc.msa
new file mode 100644 (file)
index 0000000..dd66121
--- /dev/null
@@ -0,0 +1,68 @@
+<?xml version="1.0" encoding="UTF-8"?>\r
+<!--\r
+Copyright (c) 2006, Intel Corporation\r
+All rights reserved. This program and the accompanying materials\r
+are licensed and made available under the terms and conditions of the BSD License\r
+which accompanies this distribution.  The full text of the license may be found at\r
+http://opensource.org/licenses/bsd-license.php\r
+\r
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+-->\r
+<LibraryModuleSurfaceArea xmlns="http://www.TianoCore.org/2006/Edk2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.TianoCore.org/2006/Edk2.0  http://www.TianoCore.org/2006/Edk2.0/SurfaceArea.xsd">\r
+  <MsaLibHeader>\r
+    <BaseName>BaseMemoryLibMmx</BaseName>\r
+    <ModuleType>BASE</ModuleType>\r
+    <ComponentType>LIBRARY</ComponentType>\r
+    <Guid>d458a654-f64c-49db-b8d1-3821306bf1f6</Guid>\r
+    <Version>EDK_RELEASE_VERSION        0x00090000</Version>\r
+    <Abstract>Memory-only library functions with no library constructor/destructor</Abstract>\r
+    <Description>FIX ME!</Description>\r
+    <Copyright>Copyright (c) 2006, Intel Corporation</Copyright>\r
+    <License>\r
+      All rights reserved. This program and the accompanying materials\r
+      are licensed and made available under the terms and conditions of the BSD License\r
+      which accompanies this distribution.  The full text of the license may be found at\r
+      http://opensource.org/licenses/bsd-license.php\r
+      THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+      WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+    </License>\r
+    <Specification>EFI_SPECIFICATION_VERSION    0x00000000</Specification>\r
+    <Created>2006-04-12 19:53</Created>\r
+  </MsaLibHeader>\r
+  <LibraryClassDefinitions>\r
+    <LibraryClass Usage="ALWAYS_PRODUCED">BaseMemoryLib</LibraryClass>\r
+    <LibraryClass Usage="ALWAYS_CONSUMED">BaseLib</LibraryClass>\r
+    <LibraryClass Usage="ALWAYS_CONSUMED">DebugLib</LibraryClass>\r
+  </LibraryClassDefinitions>\r
+  <SourceFiles>\r
+    <Arch ArchType="IA32">\r
+      <Filename>MemLibGuid.c</Filename>\r
+      <Filename>CopyMemWrapper.c</Filename>\r
+      <Filename>SetMemWrapper.c</Filename>\r
+      <Filename>SetMem16Wrapper.c</Filename>\r
+      <Filename>SetMem32Wrapper.c</Filename>\r
+      <Filename>SetMem64Wrapper.c</Filename>\r
+      <Filename>CompareMemWrapper.c</Filename>\r
+      <Filename>ZeroMemWrapper.c</Filename>\r
+      <Filename>ScanMem8Wrapper.c</Filename>\r
+      <Filename>ScanMem16Wrapper.c</Filename>\r
+      <Filename>ScanMem32Wrapper.c</Filename>\r
+      <Filename>ScanMem64Wrapper.c</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/CopyMem.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SetMem.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ZeroMem.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SetMem16.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SetMem32.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SetMem64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/CompareMem.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ScanMem8.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ScanMem16.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ScanMem32.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ScanMem64.s</Filename>\r
+    </Arch>\r
+  </SourceFiles>\r
+  <Includes>\r
+    <PackageName>MdePkg</PackageName>\r
+  </Includes>\r
+</LibraryModuleSurfaceArea>\r
diff --git a/MdePkg/Library/BaseMemoryLibRepStr/BaseMemoryLibRepStr-Gcc.msa b/MdePkg/Library/BaseMemoryLibRepStr/BaseMemoryLibRepStr-Gcc.msa
new file mode 100644 (file)
index 0000000..c7d7737
--- /dev/null
@@ -0,0 +1,93 @@
+<?xml version="1.0" encoding="UTF-8"?>\r
+<!--\r
+Copyright (c) 2006, Intel Corporation\r
+All rights reserved. This program and the accompanying materials\r
+are licensed and made available under the terms and conditions of the BSD License\r
+which accompanies this distribution.  The full text of the license may be found at\r
+http://opensource.org/licenses/bsd-license.php\r
+\r
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+-->\r
+<LibraryModuleSurfaceArea xmlns="http://www.TianoCore.org/2006/Edk2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.TianoCore.org/2006/Edk2.0  http://www.TianoCore.org/2006/Edk2.0/SurfaceArea.xsd">\r
+  <MsaLibHeader>\r
+    <BaseName>BaseMemoryLibRepStr</BaseName>\r
+    <ModuleType>BASE</ModuleType>\r
+    <ComponentType>LIBRARY</ComponentType>\r
+    <Guid>e7884bf4-51a1-485b-982a-ff89129983bc</Guid>\r
+    <Version>EDK_RELEASE_VERSION        0x00090000</Version>\r
+    <Abstract>Memory-only library functions with no library constructor/destructor</Abstract>\r
+    <Description>FIX ME!</Description>\r
+    <Copyright>Copyright (c) 2006, Intel Corporation</Copyright>\r
+    <License>\r
+      All rights reserved. This program and the accompanying materials\r
+      are licensed and made available under the terms and conditions of the BSD License\r
+      which accompanies this distribution.  The full text of the license may be found at\r
+      http://opensource.org/licenses/bsd-license.php\r
+      THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+      WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+    </License>\r
+    <Specification>EFI_SPECIFICATION_VERSION    0x00000000</Specification>\r
+    <Created>2006-04-12 13:39</Created>\r
+  </MsaLibHeader>\r
+  <LibraryClassDefinitions>\r
+    <LibraryClass Usage="ALWAYS_PRODUCED">BaseMemoryLib</LibraryClass>\r
+    <LibraryClass Usage="ALWAYS_CONSUMED">BaseLib</LibraryClass>\r
+    <LibraryClass Usage="ALWAYS_CONSUMED">DebugLib</LibraryClass>\r
+  </LibraryClassDefinitions>\r
+  <SourceFiles>\r
+    <Arch ArchType="IA32">\r
+      <Filename>MemLibGuid.c</Filename>\r
+      <Filename>CopyMemWrapper.c</Filename>\r
+      <Filename>SetMemWrapper.c</Filename>\r
+      <Filename>SetMem16Wrapper.c</Filename>\r
+      <Filename>SetMem32Wrapper.c</Filename>\r
+      <Filename>SetMem64Wrapper.c</Filename>\r
+      <Filename>CompareMemWrapper.c</Filename>\r
+      <Filename>ZeroMemWrapper.c</Filename>\r
+      <Filename>ScanMem8Wrapper.c</Filename>\r
+      <Filename>ScanMem16Wrapper.c</Filename>\r
+      <Filename>ScanMem32Wrapper.c</Filename>\r
+      <Filename>ScanMem64Wrapper.c</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/CopyMem.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SetMem.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SetMem16.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SetMem32.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SetMem64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ZeroMem.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/CompareMem.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ScanMem8.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ScanMem16.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ScanMem32.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ScanMem64.s</Filename>\r
+    </Arch>\r
+    <Arch ArchType="X64">\r
+      <Filename>MemLibGuid.c</Filename>\r
+      <Filename>CopyMemWrapper.c</Filename>\r
+      <Filename>SetMemWrapper.c</Filename>\r
+      <Filename>SetMem16Wrapper.c</Filename>\r
+      <Filename>SetMem32Wrapper.c</Filename>\r
+      <Filename>SetMem64Wrapper.c</Filename>\r
+      <Filename>CompareMemWrapper.c</Filename>\r
+      <Filename>ZeroMemWrapper.c</Filename>\r
+      <Filename>ScanMem8Wrapper.c</Filename>\r
+      <Filename>ScanMem16Wrapper.c</Filename>\r
+      <Filename>ScanMem32Wrapper.c</Filename>\r
+      <Filename>ScanMem64Wrapper.c</Filename>\r
+      <Filename>x64/CopyMem.asm</Filename>\r
+      <Filename>x64/SetMem.asm</Filename>\r
+      <Filename>x64/SetMem16.asm</Filename>\r
+      <Filename>x64/SetMem32.asm</Filename>\r
+      <Filename>x64/SetMem64.asm</Filename>\r
+      <Filename>x64/ZeroMem.asm</Filename>\r
+      <Filename>x64/CompareMem.asm</Filename>\r
+      <Filename>x64/ScanMem8.asm</Filename>\r
+      <Filename>x64/ScanMem16.asm</Filename>\r
+      <Filename>x64/ScanMem32.asm</Filename>\r
+      <Filename>x64/ScanMem64.asm</Filename>\r
+    </Arch>\r
+  </SourceFiles>\r
+  <Includes>\r
+    <PackageName>MdePkg</PackageName>\r
+  </Includes>\r
+</LibraryModuleSurfaceArea>\r
diff --git a/MdePkg/Library/BaseMemoryLibSse2/BaseMemoryLibSse2-Gcc.msa b/MdePkg/Library/BaseMemoryLibSse2/BaseMemoryLibSse2-Gcc.msa
new file mode 100644 (file)
index 0000000..9a40270
--- /dev/null
@@ -0,0 +1,93 @@
+<?xml version="1.0" encoding="UTF-8"?>\r
+<!--\r
+Copyright (c) 2006, Intel Corporation\r
+All rights reserved. This program and the accompanying materials\r
+are licensed and made available under the terms and conditions of the BSD License\r
+which accompanies this distribution.  The full text of the license may be found at\r
+http://opensource.org/licenses/bsd-license.php\r
+\r
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+-->\r
+<LibraryModuleSurfaceArea xmlns="http://www.TianoCore.org/2006/Edk2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.TianoCore.org/2006/Edk2.0  http://www.TianoCore.org/2006/Edk2.0/SurfaceArea.xsd">\r
+  <MsaLibHeader>\r
+    <BaseName>BaseMemoryLibSse2</BaseName>\r
+    <ModuleType>BASE</ModuleType>\r
+    <ComponentType>LIBRARY</ComponentType>\r
+    <Guid>65a18235-5096-4032-8c63-214f0249ce8d</Guid>\r
+    <Version>EDK_RELEASE_VERSION        0x00090000</Version>\r
+    <Abstract>Memory-only library functions with no library constructor/destructor</Abstract>\r
+    <Description>FIX ME!</Description>\r
+    <Copyright>Copyright (c) 2006, Intel Corporation</Copyright>\r
+    <License>\r
+      All rights reserved. This program and the accompanying materials\r
+      are licensed and made available under the terms and conditions of the BSD License\r
+      which accompanies this distribution.  The full text of the license may be found at\r
+      http://opensource.org/licenses/bsd-license.php\r
+      THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
+      WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
+    </License>\r
+    <Specification>EFI_SPECIFICATION_VERSION    0x00000000</Specification>\r
+    <Created>2006-04-12 13:46</Created>\r
+  </MsaLibHeader>\r
+  <LibraryClassDefinitions>\r
+    <LibraryClass Usage="ALWAYS_PRODUCED">BaseMemoryLib</LibraryClass>\r
+    <LibraryClass Usage="ALWAYS_CONSUMED">BaseLib</LibraryClass>\r
+    <LibraryClass Usage="ALWAYS_CONSUMED">DebugLib</LibraryClass>\r
+  </LibraryClassDefinitions>\r
+  <SourceFiles>\r
+    <Arch ArchType="IA32">\r
+      <Filename>MemLibGuid.c</Filename>\r
+      <Filename>CopyMemWrapper.c</Filename>\r
+      <Filename>SetMemWrapper.c</Filename>\r
+      <Filename>SetMem16Wrapper.c</Filename>\r
+      <Filename>SetMem32Wrapper.c</Filename>\r
+      <Filename>SetMem64Wrapper.c</Filename>\r
+      <Filename>CompareMemWrapper.c</Filename>\r
+      <Filename>ZeroMemWrapper.c</Filename>\r
+      <Filename>ScanMem8Wrapper.c</Filename>\r
+      <Filename>ScanMem16Wrapper.c</Filename>\r
+      <Filename>ScanMem32Wrapper.c</Filename>\r
+      <Filename>ScanMem64Wrapper.c</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/CopyMem.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SetMem.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SetMem16.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SetMem32.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/SetMem64.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ZeroMem.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/CompareMem.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ScanMem8.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ScanMem16.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ScanMem32.s</Filename>\r
+      <Filename FileType="GCC_Assembly_Code">Ia32/ScanMem64.s</Filename>\r
+    </Arch>\r
+    <Arch ArchType="X64">\r
+      <Filename>MemLibGuid.c</Filename>\r
+      <Filename>CopyMemWrapper.c</Filename>\r
+      <Filename>SetMemWrapper.c</Filename>\r
+      <Filename>SetMem16Wrapper.c</Filename>\r
+      <Filename>SetMem32Wrapper.c</Filename>\r
+      <Filename>SetMem64Wrapper.c</Filename>\r
+      <Filename>CompareMemWrapper.c</Filename>\r
+      <Filename>ZeroMemWrapper.c</Filename>\r
+      <Filename>ScanMem8Wrapper.c</Filename>\r
+      <Filename>ScanMem16Wrapper.c</Filename>\r
+      <Filename>ScanMem32Wrapper.c</Filename>\r
+      <Filename>ScanMem64Wrapper.c</Filename>\r
+      <Filename>x64/CopyMem.asm</Filename>\r
+      <Filename>x64/SetMem.asm</Filename>\r
+      <Filename>x64/SetMem16.asm</Filename>\r
+      <Filename>x64/SetMem32.asm</Filename>\r
+      <Filename>x64/SetMem64.asm</Filename>\r
+      <Filename>x64/ZeroMem.asm</Filename>\r
+      <Filename>x64/CompareMem.asm</Filename>\r
+      <Filename>x64/ScanMem8.asm</Filename>\r
+      <Filename>x64/ScanMem16.asm</Filename>\r
+      <Filename>x64/ScanMem32.asm</Filename>\r
+      <Filename>x64/ScanMem64.asm</Filename>\r
+    </Arch>\r
+  </SourceFiles>\r
+  <Includes>\r
+    <PackageName>MdePkg</PackageName>\r
+  </Includes>\r
+</LibraryModuleSurfaceArea>\r