On 31 March 2016 at 16:09, Yao, Jiewen <jiewen....@intel.com> wrote:
> Thanks for your quick response.
>
> Then I will be waiting for your investigation result.
>
> If you see the value to have this dump tool check in, maybe we can put to 
> MdeModulePkg/Application.
> Next time, we do not need share it via email.
>


I have to apologise for the noise. This issue is an OS problem, not a
firmware problem: if I dump the contents of the table very early
during boot, it looks fine, but later when I process it, the first
entry is corrupted.

Thanks for the help!
Ard.


>> -----Original Message-----
>> From: Ard Biesheuvel [mailto:ard.biesheu...@linaro.org]
>> Sent: Thursday, March 31, 2016 9:34 PM
>> To: Yao, Jiewen <jiewen....@intel.com>
>> Cc: Gao, Liming <liming....@intel.com>; edk2-devel@lists.01.org
>> <edk2-de...@ml01.01.org>
>> Subject: Re: [edk2] [patch V3] MdeModulePkg: Fix Memory Attributes table
>> type issue
>>
>> On 31 March 2016 at 15:20, Yao, Jiewen <jiewen....@intel.com> wrote:
>> > Hi Ard
>> > Thanks for your log. Yes, it seems new issue, I have never encountered
>> before.
>> >
>> > Here is what I found:
>> >
>> > 1) MemoryAttributeTable is always installed in ReadyToBoot event. (Sorry, I
>> gave wrong info on EndOfDxe, that is for old properties table)
>> >
>>
>> OK
>>
>> > 2) In this log, I have seen MemoryAttributeTable is installed 6 times. It
>> means this system boot 6 boot options. First 5 fail, and last one success. I 
>> am
>> not clear what device you want to boot, but it seems "Booting EFI Misc
>> Device" category. It is also weird that RT_Data entry is changed every time.
>> Does this boot device allocate/free RT_Data?
>> >
>>
>> Good question, I can investigate
>>
>> > 3) In this log, it shows MemoryAttributeTable is always correct. See line
>> 1427. I do not know why it is corrupt in efimemmap.log.
>> > This memory attribute table is allocated in "BootServicesData" type
>> memory. Are you sure that system does not corrupt BootServicesData when
>> efimemmap.log is created?
>> >
>> > 4) So I suggest we check *when* this table is corrupted. I have
>> MemoryAttributesDump UEFI APPLICATION (See attachment, password:
>> 12345678). Maybe can you help run it in UEFI shell to see if
>> MemoryAttributes table is correct or not?
>> > We can use this way to narrow down the corruption - *when* it is created,
>> or *after* it is created.
>> >
>>
>> Shell> MemoryAttributesDump.efi
>> MemoryAttributesTable:
>>   Version         - 0x00000001
>>   NumberOfEntries - 0x00000019
>>   DescriptorSize  - 0x00000030
>>
>> Type       Start            End              # Pages
>> Attributes
>> RT_Data    00000000F5B50000-0000000000000000 0000000000000030
>> 8000000000004000
>> RT_Code    00000000F5B80000-0000000000000000 0000000000000010
>> 8000000000004000
>> RT_Code    00000000F5B90000-0000000000000000 0000000000000010
>> 8000000000020000
>> RT_Code    00000000F5BA0000-0000000000000000 0000000000000030
>> 8000000000004000
>> RT_Code    00000000F5BD0000-0000000000000000 0000000000000010
>> 8000000000020000
>> RT_Code    00000000F5BE0000-0000000000000000 0000000000000020
>> 8000000000004000
>> RT_Code    00000000F5C80000-0000000000000000 0000000000000010
>> 8000000000004000
>> RT_Code    00000000F5C90000-0000000000000000 0000000000000010
>> 8000000000020000
>> RT_Code    00000000F5CA0000-0000000000000000 0000000000000020
>> 8000000000004000
>> RT_Data    00000000F5CC0000-0000000000000000 0000000000000090
>> 8000000000004000
>> RT_Code    00000000F5D50000-0000000000000000 0000000000000010
>> 8000000000004000
>> RT_Code    00000000F5D60000-0000000000000000 0000000000000010
>> 8000000000020000
>> RT_Code    00000000F5D70000-0000000000000000 0000000000000030
>> 8000000000004000
>> RT_Data    00000000F5DA0000-0000000000000000 00000000000000F0
>> 8000000000004000
>> RT_Code    00000000F5E90000-0000000000000000 0000000000000010
>> 8000000000004000
>> RT_Code    00000000F5EA0000-0000000000000000 0000000000000010
>> 8000000000020000
>> RT_Code    00000000F5EB0000-0000000000000000 0000000000000030
>> 8000000000004000
>> RT_Data    00000000F5EE0000-0000000000000000 0000000000000050
>> 8000000000004000
>> RT_Code    00000000F5F30000-0000000000000000 0000000000000010
>> 8000000000004000
>> RT_Code    00000000F5F40000-0000000000000000 0000000000000010
>> 8000000000020000
>> RT_Code    00000000F5F50000-0000000000000000 0000000000000030
>> 8000000000004000
>> RT_Code    00000000FAF50000-0000000000000000 0000000000000010
>> 8000000000004000
>> RT_Code    00000000FAF60000-0000000000000000 0000000000000010
>> 8000000000020000
>> RT_Code    00000000FAF70000-0000000000000000 0000000000000020
>> 8000000000004000
>> RT_Data    00000000FAFA0000-0000000000000000 0000000000000050
>> 8000000000004000
>>
>> So it looks like the table gets corrupted by the OS loader. I will
>> investigate a bit more
>>
>> Thanks,
>> Ard.
_______________________________________________
edk2-devel mailing list
edk2-devel@lists.01.org
https://lists.01.org/mailman/listinfo/edk2-devel

Reply via email to