On Thu, Sep 11, 2014 at 5:33 AM, Sergey Isakov <[email protected]> wrote:
> CodeModule: IntelFrameworkModulePkg/Library/LzmaCustomDecompressLib
>
> I resolved the issue. The problem is in structure coping that must be
> replaced by CopyMem
> ---
> diff -Nurpb -x .svn C/LzmaDec.c C-new/LzmaDec.c
> --- C/LzmaDec.c 2014-04-04 14:19:18.000000000 +0400
> +++ C-new/LzmaDec.c 2014-09-11 16:16:16.000000000 +0400
>
> @@ -848,7 +850,7 @@ SRes LzmaDec_DecodeToDic(CLzmaDec *p, Si
>              return SZ_ERROR_DATA;
>            }
>          }
> -        p->buf = p->tempBuf;
> +        p->buf = &(p->tempBuf[0]);

Is this change actually needed? It doesn't seem related to the
structure copying issue you mention.

-Jordan

>          if (LzmaDec_DecodeReal2(p, dicLimit, p->buf) != 0)
>            return SZ_ERROR_DATA;
>          lookAhead -= (rem - (unsigned)(p->buf - p->tempBuf));
> @@ -966,7 +968,8 @@ SRes LzmaDec_AllocateProbs(CLzmaDec *p,
>    CLzmaProps propNew;
>    RINOK(LzmaProps_Decode(&propNew, props, propsSize));
>    RINOK(LzmaDec_AllocateProbs2(p, &propNew, alloc));
> -  p->prop = propNew;
> +  CopyMem(&(p->prop), &propNew, sizeof(CLzmaProps));
>    return SZ_OK;
>  }
>
> @@ -988,7 +991,8 @@ SRes LzmaDec_Allocate(CLzmaDec *p, const
>      }
>    }
>    p->dicBufSize = dicBufSize;
> -  p->prop = propNew;
> +  CopyMem(&(p->prop), &propNew, sizeof(CLzmaProps));
>    return SZ_OK;
>  }
>
> ---
> Contributed-under: TianoCore Contribution Agreement 1.0
> Signed-off-by: Sergey Isakov <[email protected]>
>
>
> On 10.09.2014, at 18:01, Sergey Isakov wrote:
>
> Hi all,
> I encounter a problem that LzmaCustomDecompressLib is not working if
> compiled by Clang into IA32. But it works fine with GCC49.
> The sources are very complex and I see no significant constructions that may
> be differ from gcc to clang.
> Can anybody point me what to look?
> The version is 4.65 while original sources already at 9.2 version. Can we
> switch to recent version?
>
> Symptoms:
> -------
>   PrintString ("BFV decompress: DestinationSize = %x, ScratchSize = %x\n",
> (UINTN) DestinationSize, (UINTN) ScratchSize);
>   Status =  LzmaUefiDecompress (
>     (VOID *)(UINTN)(EFILDR_HEADER_ADDRESS + EFILDRImage->Offset),
>     EFILDRImage->Length,
>     (VOID *)(UINTN)EFI_DECOMPRESSED_BUFFER_ADDRESS,
>     (VOID *)(UINTN)((EFI_DECOMPRESSED_BUFFER_ADDRESS + DestinationSize +
> 0x1000) & 0xfffff000)
>     );
>
>
> -------
> It prints "BFV decompress: DestinationSize = 2A0000, ScratchSize = 10000"
> and then crash QEMU.
> Same, compiled by gcc is working.
>
> Sergey
> ------------------------------------------------------------------------------
> Want excitement?
> Manually upgrade your production database.
> When you want reliability, choose Perforce
> Perforce version control. Predictably reliable.
> http://pubads.g.doubleclick.net/gampad/clk?id=157508191&iu=/4140/ostg.clktrk_______________________________________________
> edk2-devel mailing list
> [email protected]
> https://lists.sourceforge.net/lists/listinfo/edk2-devel
>
>
>
> ------------------------------------------------------------------------------
> Want excitement?
> Manually upgrade your production database.
> When you want reliability, choose Perforce
> Perforce version control. Predictably reliable.
> http://pubads.g.doubleclick.net/gampad/clk?id=157508191&iu=/4140/ostg.clktrk
> _______________________________________________
> edk2-devel mailing list
> [email protected]
> https://lists.sourceforge.net/lists/listinfo/edk2-devel
>

------------------------------------------------------------------------------
Want excitement?
Manually upgrade your production database.
When you want reliability, choose Perforce
Perforce version control. Predictably reliable.
http://pubads.g.doubleclick.net/gampad/clk?id=157508191&iu=/4140/ostg.clktrk
_______________________________________________
edk2-devel mailing list
[email protected]
https://lists.sourceforge.net/lists/listinfo/edk2-devel

Reply via email to