mirror of
				https://git.proxmox.com/git/mirror_edk2
				synced 2025-10-25 21:17:31 +00:00 
			
		
		
		
	 11ff2c714b
			
		
	
	
		11ff2c714b
		
	
	
	
	
		
			
			Copy below two library instances from IntelFrameworkModulePkg to MdeModulePkg. Then, Platform dsc can refer to them from MdeModulePkg, and remove the dependency of IntelFrameworkModulePkg. The ones in IntelFrameworkModulePkg are still kept for compatibility. 1. PeiDxeDebugLibReportStatusCode 2. LzmaCustomDecompressLib Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Liming Gao <liming.gao@intel.com> Reviewed-by: Star Zeng <star.zeng@intel.com> Reviewed-by: Jordan Justen <jordan.l.justen@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@17112 6f19259b-4bc3-4df7-8a09-765794883524
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* Bra86.c -- Converter for x86 code (BCJ)
 | |
| 2008-10-04 : Igor Pavlov : Public domain */
 | |
| 
 | |
| #include "Bra.h"
 | |
| 
 | |
| #define Test86MSByte(b) ((b) == 0 || (b) == 0xFF)
 | |
| 
 | |
| const Byte kMaskToAllowedStatus[8] = {1, 1, 1, 0, 1, 0, 0, 0};
 | |
| const Byte kMaskToBitNumber[8] = {0, 1, 2, 2, 3, 3, 3, 3};
 | |
| 
 | |
| SizeT x86_Convert(Byte *data, SizeT size, UInt32 ip, UInt32 *state, int encoding)
 | |
| {
 | |
|   SizeT bufferPos = 0, prevPosT;
 | |
|   UInt32 prevMask = *state & 0x7;
 | |
|   if (size < 5)
 | |
|     return 0;
 | |
|   ip += 5;
 | |
|   prevPosT = (SizeT)0 - 1;
 | |
| 
 | |
|   for (;;)
 | |
|   {
 | |
|     Byte *p = data + bufferPos;
 | |
|     Byte *limit = data + size - 4;
 | |
|     for (; p < limit; p++)
 | |
|       if ((*p & 0xFE) == 0xE8)
 | |
|         break;
 | |
|     bufferPos = (SizeT)(p - data);
 | |
|     if (p >= limit)
 | |
|       break;
 | |
|     prevPosT = bufferPos - prevPosT;
 | |
|     if (prevPosT > 3)
 | |
|       prevMask = 0;
 | |
|     else
 | |
|     {
 | |
|       prevMask = (prevMask << ((int)prevPosT - 1)) & 0x7;
 | |
|       if (prevMask != 0)
 | |
|       {
 | |
|         Byte b = p[4 - kMaskToBitNumber[prevMask]];
 | |
|         if (!kMaskToAllowedStatus[prevMask] || Test86MSByte(b))
 | |
|         {
 | |
|           prevPosT = bufferPos;
 | |
|           prevMask = ((prevMask << 1) & 0x7) | 1;
 | |
|           bufferPos++;
 | |
|           continue;
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|     prevPosT = bufferPos;
 | |
| 
 | |
|     if (Test86MSByte(p[4]))
 | |
|     {
 | |
|       UInt32 src = ((UInt32)p[4] << 24) | ((UInt32)p[3] << 16) | ((UInt32)p[2] << 8) | ((UInt32)p[1]);
 | |
|       UInt32 dest;
 | |
|       for (;;)
 | |
|       {
 | |
|         Byte b;
 | |
|         int index;
 | |
|         if (encoding)
 | |
|           dest = (ip + (UInt32)bufferPos) + src;
 | |
|         else
 | |
|           dest = src - (ip + (UInt32)bufferPos);
 | |
|         if (prevMask == 0)
 | |
|           break;
 | |
|         index = kMaskToBitNumber[prevMask] * 8;
 | |
|         b = (Byte)(dest >> (24 - index));
 | |
|         if (!Test86MSByte(b))
 | |
|           break;
 | |
|         src = dest ^ ((1 << (32 - index)) - 1);
 | |
|       }
 | |
|       p[4] = (Byte)(~(((dest >> 24) & 1) - 1));
 | |
|       p[3] = (Byte)(dest >> 16);
 | |
|       p[2] = (Byte)(dest >> 8);
 | |
|       p[1] = (Byte)dest;
 | |
|       bufferPos += 5;
 | |
|     }
 | |
|     else
 | |
|     {
 | |
|       prevMask = ((prevMask << 1) & 0x7) | 1;
 | |
|       bufferPos++;
 | |
|     }
 | |
|   }
 | |
|   prevPosT = bufferPos - prevPosT;
 | |
|   *state = ((prevPosT > 3) ? 0 : ((prevMask << ((int)prevPosT - 1)) & 0x7));
 | |
|   return bufferPos;
 | |
| }
 |